/* Extracted verbatim from mpl_client_portal_prototype.html (design source of truth). */
:root{
  --canvas:#F4ECDD; --paper:#FCF8F0; --panel:#F6EFE1;
  --ink:#23201B; --soft:#6A6256; --faint:#9A917F;
  --teal:#0F5A63; --teal-2:#2A9D8F; --teal-soft:#E2EEEC;
  --brass:#A9762B; --brass-soft:#F0E3C8;
  --line:#E4DAC4; --line-2:#D8CCAE;
  --ok:#5F7A4F; --warn:#B17B1F; --danger:#B5482C;
  --shadow:0 1px 2px rgba(35,32,27,.05),0 8px 24px rgba(35,32,27,.06);
  --radius:14px;
}
*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{font-family:Inter,system-ui,sans-serif;background:var(--canvas);color:var(--ink);
  -webkit-font-smoothing:antialiased;line-height:1.5;font-size:15px}
h1,h2,h3,h4{font-family:"Cormorant Garamond",Georgia,serif;font-weight:600;margin:0;line-height:1.12;letter-spacing:.2px}
.serif{font-family:"Cormorant Garamond",Georgia,serif}
button{font-family:inherit;cursor:pointer}
a{color:inherit}
.tnum{font-variant-numeric:tabular-nums}

/* ---------- buttons ---------- */
.btn{display:inline-flex;align-items:center;gap:8px;border-radius:10px;border:1px solid var(--teal);
  background:var(--teal);color:#fff;padding:9px 15px;font-size:13.5px;font-weight:500;transition:.15s}
.btn:hover{background:var(--teal-2);border-color:var(--teal-2)}
.btn.ghost{background:transparent;color:var(--teal);border-color:var(--line-2)}
.btn.ghost:hover{background:var(--teal-soft);border-color:var(--teal-2)}
.btn.sm{padding:6px 11px;font-size:12.5px;border-radius:8px}
.btn.block{width:100%;justify-content:center}
.linklike{background:none;border:none;color:var(--teal);font-weight:500;padding:0;font-size:13.5px}
.linklike:hover{color:var(--teal-2);text-decoration:underline}

/* ---------- pills ---------- */
.pill{display:inline-flex;align-items:center;gap:6px;font-size:11.5px;font-weight:600;
  padding:3px 9px;border-radius:999px;letter-spacing:.3px;text-transform:uppercase}
.pill.up{background:var(--teal-soft);color:var(--teal)}
.pill.prog{background:var(--brass-soft);color:var(--brass)}
.pill.done{background:#E9EFE4;color:var(--ok)}
.pill.dot::before{content:"";width:6px;height:6px;border-radius:50%;background:currentColor}

/* ====================================================== LOGIN */
#login{position:fixed;inset:0;background:
  radial-gradient(1200px 500px at 80% -10%,rgba(42,157,143,.16),transparent),
  radial-gradient(900px 500px at -10% 110%,rgba(169,118,43,.12),transparent),var(--canvas);
  display:flex;align-items:center;justify-content:center;z-index:60;padding:24px}
.login-card{background:var(--paper);border:1px solid var(--line);border-radius:20px;box-shadow:var(--shadow);
  width:min(420px,100%);padding:38px 34px;text-align:center}
.mark{display:inline-flex;align-items:center;gap:9px;margin-bottom:22px}
.leaf{width:30px;height:30px;display:block}
.brandname{font-family:"Cormorant Garamond",serif;font-size:23px;font-weight:600;letter-spacing:.5px}
.login-card h1{font-size:30px;margin:6px 0 4px}
.login-card p.sub{color:var(--soft);font-size:14px;margin:0 0 22px}
.field{text-align:left;margin-bottom:14px}
.field label{display:block;font-size:12.5px;font-weight:600;color:var(--soft);margin-bottom:6px}
.field input{width:100%;padding:11px 13px;border:1px solid var(--line-2);border-radius:10px;
  font-size:14.5px;background:#fff;color:var(--ink)}
.field input:focus{outline:none;border-color:var(--teal);box-shadow:0 0 0 3px var(--teal-soft)}
.fineprint{font-size:12px;color:var(--faint);margin-top:18px;line-height:1.5}
.sent{display:none}
.sent .check{width:54px;height:54px;border-radius:50%;background:var(--teal-soft);color:var(--teal);
  display:flex;align-items:center;justify-content:center;margin:0 auto 14px;font-size:26px}

/* ====================================================== APP SHELL */
#app{display:none;min-height:100vh}
.shell{display:grid;grid-template-columns:248px 1fr;min-height:100vh}
.side{background:var(--panel);border-right:1px solid var(--line);padding:22px 16px;
  display:flex;flex-direction:column;position:sticky;top:0;height:100vh}
.side .mark{padding:0 8px 20px;margin:0;border-bottom:1px solid var(--line)}
.nav{display:flex;flex-direction:column;gap:2px;margin-top:14px;flex:1}
.nav a{display:flex;align-items:center;gap:11px;padding:9px 12px;border-radius:10px;
  color:var(--soft);font-size:14px;font-weight:500;text-decoration:none;transition:.12s}
.nav a svg{width:18px;height:18px;opacity:.8;flex:none}
.nav a:hover{background:#fff;color:var(--ink)}
.nav a.active{background:var(--teal);color:#fff}
.nav a.active svg{opacity:1}
.side .book{margin:6px 0 16px}
.profile{display:flex;align-items:center;gap:10px;padding:10px 8px;border-top:1px solid var(--line)}
.avatar{width:34px;height:34px;border-radius:50%;background:var(--brass);color:#fff;display:flex;
  align-items:center;justify-content:center;font-weight:600;font-size:14px;flex:none}
.profile .nm{font-size:13.5px;font-weight:600;line-height:1.2}
.profile .em{font-size:11.5px;color:var(--faint)}

.main{padding:30px 40px 70px;max-width:1000px}
.topline{font-size:13px;color:var(--brass);font-family:"Cormorant Garamond",serif;
  font-style:italic;font-size:16px;margin-bottom:4px}
.page-h{font-size:34px;margin-bottom:2px}
.page-sub{color:var(--soft);font-size:14px;margin-bottom:26px}

/* cards */
.card{background:var(--paper);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow)}
.pad{padding:20px 22px}
.eyebrow{font-size:11px;letter-spacing:1.4px;text-transform:uppercase;color:var(--faint);font-weight:600}
.grid2{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.row{display:flex;align-items:center;justify-content:space-between;gap:14px}

/* reading "leaf" card */
.leafcard{position:relative;background:var(--paper);border:1px solid var(--line);border-radius:var(--radius);
  box-shadow:var(--shadow);overflow:hidden;margin-bottom:16px;transition:.15s}
.leafcard:hover{border-color:var(--line-2);transform:translateY(-1px)}
.leafcard .spine{position:absolute;left:0;top:0;bottom:0;width:5px;background:linear-gradient(var(--brass),#caa05a)}
.leafcard .body{padding:18px 22px 18px 26px}
.lc-top{display:flex;align-items:flex-start;justify-content:space-between;gap:12px}
.lc-title{font-size:23px}
.lc-meta{font-size:13px;color:var(--soft);margin-top:2px}
.filechips{display:flex;flex-wrap:wrap;gap:8px;margin-top:14px}
.chip{display:inline-flex;align-items:center;gap:7px;background:#fff;border:1px solid var(--line);
  border-radius:9px;padding:7px 11px;font-size:12.5px;color:var(--ink);font-weight:500}
.chip svg{width:15px;height:15px;color:var(--teal)}
.chip .sz{color:var(--faint);font-weight:500}
.chip.go{cursor:pointer}
.chip.go:hover{border-color:var(--teal);background:var(--teal-soft)}

/* detail */
.back{display:inline-flex;align-items:center;gap:6px;color:var(--soft);font-size:13px;margin-bottom:14px;
  background:none;border:none}
.back:hover{color:var(--teal)}
.detail-grid{display:grid;grid-template-columns:1.6fr 1fr;gap:18px;align-items:start}
.kv{display:flex;justify-content:space-between;padding:10px 0;border-bottom:1px dashed var(--line);font-size:13.5px}
.kv:last-child{border-bottom:none}
.kv .k{color:var(--soft)}
.filelist{display:flex;flex-direction:column;gap:9px;margin-top:6px}
.filerow{display:flex;align-items:center;gap:12px;padding:11px 13px;background:#fff;border:1px solid var(--line);border-radius:11px}
.fileicon{width:34px;height:34px;border-radius:8px;background:var(--teal-soft);color:var(--teal);
  display:flex;align-items:center;justify-content:center;flex:none}
.fileicon svg{width:17px;height:17px}
.filerow .fn{font-size:13.5px;font-weight:600}
.filerow .fmeta{font-size:11.5px;color:var(--faint)}

/* timeline */
.tl{position:relative;margin:6px 0 0;padding-left:22px}
.tl::before{content:"";position:absolute;left:6px;top:4px;bottom:8px;width:2px;background:var(--line-2)}
.tl li{list-style:none;position:relative;padding:0 0 16px}
.tl li::before{content:"";position:absolute;left:-19px;top:3px;width:11px;height:11px;border-radius:50%;
  background:#fff;border:2px solid var(--line-2)}
.tl li.done::before{background:var(--teal);border-color:var(--teal)}
.tl li.now::before{background:var(--brass);border-color:var(--brass);box-shadow:0 0 0 4px var(--brass-soft)}
.tl .t{font-size:13.5px;font-weight:600}
.tl .d{font-size:12px;color:var(--faint)}

/* table */
table{width:100%;border-collapse:collapse}
th{text-align:left;font-size:11px;letter-spacing:.6px;text-transform:uppercase;color:var(--faint);
  font-weight:600;padding:0 12px 10px}
td{padding:13px 12px;border-top:1px solid var(--line);font-size:13.5px}
tr:hover td{background:#fff8ec55}

/* messages */
.thread{display:flex;flex-direction:column;gap:12px;max-height:46vh;overflow:auto;padding:4px 2px}
.msg{max-width:74%;padding:11px 14px;border-radius:14px;font-size:13.5px;line-height:1.45}
.msg.them{background:#fff;border:1px solid var(--line);align-self:flex-start;border-bottom-left-radius:4px}
.msg.me{background:var(--teal);color:#fff;align-self:flex-end;border-bottom-right-radius:4px}
.msg .who{font-size:11px;opacity:.7;margin-bottom:3px;font-weight:600}
.composer{display:flex;gap:10px;margin-top:14px;border-top:1px solid var(--line);padding-top:14px}
.composer input{flex:1;padding:11px 13px;border:1px solid var(--line-2);border-radius:10px;font-size:14px;background:#fff}
.composer input:focus{outline:none;border-color:var(--teal);box-shadow:0 0 0 3px var(--teal-soft)}

/* account */
.acct-row{display:flex;align-items:center;justify-content:space-between;gap:14px;
  padding:15px 0;border-bottom:1px solid var(--line)}
.acct-row:last-child{border-bottom:none}
.acct-row .lab{font-size:12px;color:var(--faint);text-transform:uppercase;letter-spacing:.6px;font-weight:600}
.acct-row .val{font-size:14.5px;font-weight:500;margin-top:3px}
.note{font-size:12px;color:var(--warn);background:#fbf3df;border:1px solid #efe0bc;border-radius:9px;padding:7px 11px;display:inline-block}

/* modal */
.modal-bg{display:none;position:fixed;inset:0;background:rgba(35,32,27,.45);z-index:70;
  align-items:center;justify-content:center;padding:24px}
.modal{background:var(--paper);border-radius:18px;box-shadow:var(--shadow);width:min(640px,100%);
  padding:26px 28px;max-height:88vh;overflow:auto}
.svc-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-top:16px}
.svc{display:flex;flex-direction:column;gap:6px;padding:15px;border:1px solid var(--line);border-radius:12px;background:#fff}
.svc .nm{font-size:15px;font-weight:600}
.svc .ds{font-size:12.5px;color:var(--soft);flex:1}
.svc .pr{font-size:12.5px;color:var(--brass);font-weight:600}

/* toast */
#toast{position:fixed;bottom:22px;left:50%;transform:translateX(-50%) translateY(20px);opacity:0;
  background:var(--ink);color:#fff;padding:12px 18px;border-radius:11px;font-size:13.5px;z-index:90;
  transition:.25s;box-shadow:var(--shadow);display:flex;align-items:center;gap:9px;pointer-events:none}
#toast.show{opacity:1;transform:translateX(-50%) translateY(0)}
.proto{position:fixed;top:10px;left:12px;z-index:95;background:#23201B;color:#f0e6cf;font-size:11px;
  padding:4px 10px;border-radius:999px;letter-spacing:.4px;opacity:.85}

@media(max-width:860px){
  .shell{grid-template-columns:1fr}
  .side{position:static;height:auto;flex-direction:row;flex-wrap:wrap;gap:8px;align-items:center}
  .side .mark,.side .book,.profile{display:none}
  .nav{flex-direction:row;flex-wrap:wrap;margin:0}
  .nav a span{display:none}
  .main{padding:22px 18px 60px}
  .grid2,.detail-grid,.svc-grid{grid-template-columns:1fr}
  .page-h{font-size:28px}
}

.suggest{background:var(--paper);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow);
  padding:17px 19px;display:flex;gap:13px;align-items:flex-start}
.sg-ico{width:30px;height:30px;border-radius:50%;background:var(--brass-soft);color:var(--brass);
  display:flex;align-items:center;justify-content:center;font-size:15px;flex:none;margin-top:2px}
.pilgrim{position:relative;overflow:hidden;border-radius:var(--radius);box-shadow:var(--shadow);padding:24px 26px;
  background:radial-gradient(420px 180px at 88% -25%,rgba(169,118,43,.5),transparent),linear-gradient(135deg,#0F5A63,#0c4248)}
.pilgrim-eg{font-size:11px;letter-spacing:1.6px;text-transform:uppercase;color:#e7c98a;font-weight:600}
.btn-light{display:inline-flex;align-items:center;gap:7px;border-radius:10px;border:1px solid rgba(255,255,255,.55);
  background:rgba(255,255,255,.12);color:#fff;padding:9px 15px;font-size:13.5px;font-weight:500;font-family:inherit;cursor:pointer;transition:.15s}
.btn-light:hover{background:#fff;color:var(--teal);border-color:#fff}
.logoimg{width:38px;height:38px;object-fit:contain;display:block;flex:none}

.themebar{position:fixed;top:9px;right:12px;z-index:96;display:flex;align-items:center;gap:5px;
  background:rgba(35,32,27,.92);padding:5px 7px;border-radius:999px;box-shadow:0 4px 14px rgba(0,0,0,.18)}
.themebar .tb-label{color:#cdbf9f;font-size:10px;letter-spacing:1px;text-transform:uppercase;padding:0 4px;font-weight:600}
.themebar button{border:none;background:transparent;color:#e9dec5;font-size:11.5px;font-weight:500;
  padding:5px 9px;border-radius:999px;cursor:pointer;font-family:inherit;white-space:nowrap}
.themebar button:hover{background:rgba(255,255,255,.12)}
.themebar button.active{background:var(--brass);color:#fff}
@media(max-width:860px){.themebar .tb-label{display:none}.themebar button{padding:5px 7px;font-size:11px}}
:root{
  --canvas:#F7F0DA;--paper:#FFFFFF;--panel:#F3EBD7;--ink:#2A2318;--soft:#6E6452;--faint:#9C9077;
  --line:#E9DDC1;--line-2:#DDD0B2;--brass:#A9762B;--brass-soft:#F2E6CA;
  --teal:#0F5A63;--teal-2:#2A9D8F;--teal-soft:#E1EDEB;
}

.lc-left{display:flex;gap:14px;align-items:flex-start}
.lc-thumb{width:54px;height:54px;border-radius:50%;flex:none;display:flex;align-items:center;justify-content:center;
  background:radial-gradient(circle at 50% 32%,var(--brass-soft),#ecdfc0);color:var(--brass);border:1px solid var(--line-2)}
.lc-thumb svg{width:26px;height:26px}
.rec-thumb{width:104px;height:60px;border-radius:9px;flex:none;display:flex;align-items:center;justify-content:center;
  background:radial-gradient(120px 60px at 50% 20%,#1d4147,#0f5a63)}
.rec-thumb .play{width:30px;height:30px;border-radius:50%;background:rgba(255,255,255,.92);display:flex;align-items:center;justify-content:center;color:var(--teal)}
.rec-thumb .play svg{width:13px;height:13px;margin-left:2px}
.svc-img{height:80px;border-radius:9px;margin-bottom:4px;display:flex;align-items:center;justify-content:center;
  background:radial-gradient(circle at 50% 32%,var(--brass-soft),#ecdfc0);color:var(--brass);border:1px solid var(--line)}
.svc-img svg{width:32px;height:32px}

.lc-thumb{overflow:hidden}
.lc-thumb img,.svc-img img,.sg-img img{width:100%;height:100%;object-fit:cover;display:block}
.svc-img{overflow:hidden;padding:0}
.sg-img{width:46px;height:46px;border-radius:10px;overflow:hidden;flex:none}
.rec-thumb{position:relative;background-size:cover;background-position:center}
.rec-thumb::after{content:"";position:absolute;inset:0;background:rgba(15,40,44,.30)}
.rec-thumb .play{position:relative;z-index:1}

.lc-thumb{width:96px;height:96px;border-radius:14px}
.svc-img{height:134px}
.sg-img{width:62px;height:62px;border-radius:12px}
.rec-thumb{width:156px;height:90px}
@media(max-width:860px){.lc-thumb{width:72px;height:72px}.rec-thumb{width:128px;height:74px}}

.fchips{display:flex;gap:8px;margin-bottom:16px;flex-wrap:wrap}
.fchip{border:1px solid var(--line-2);background:#fff;color:var(--soft);font-size:13px;font-weight:500;padding:7px 14px;border-radius:999px;cursor:pointer;font-family:inherit}
.fchip:hover{border-color:var(--teal);color:var(--teal)}
.fchip.on{background:var(--teal);color:#fff;border-color:var(--teal)}
.rec-thumb.sm{width:92px;height:54px}

.img-thumb{width:92px;height:54px;border-radius:8px;flex:none;background-size:cover;background-position:center;border:1px solid var(--line-2)}
.doc-thumb{width:92px;height:54px;border-radius:8px;flex:none;position:relative;overflow:hidden;background:#fbf5ea;border:1px solid var(--line-2)}
.doc-thumb .topbar{position:absolute;top:0;left:0;right:0;height:13px;background:var(--brass)}
.doc-thumb .lines{position:absolute;top:19px;left:8px;right:8px}
.doc-thumb .lines i{display:block;height:3px;background:#e3d8c2;border-radius:2px;margin-bottom:3px}
.doc-thumb .lab{position:absolute;bottom:4px;left:8px;font-size:8.5px;font-weight:700;letter-spacing:.4px;color:var(--brass);text-transform:uppercase}

.codebox{font-family:"IBM Plex Mono",ui-monospace,monospace;font-size:19px;font-weight:600;letter-spacing:2px;
  color:var(--brass);background:#fbf5ea;border:1px dashed var(--line-2);border-radius:10px;padding:13px;text-align:center}

.days{display:flex;flex-direction:column;gap:8px}
.day{display:flex;align-items:center;gap:12px;padding:9px 11px;border:1px solid var(--line);border-radius:10px;background:#fff}
.day.hi{border-color:var(--brass);background:var(--brass-soft)}
.day .dn{font-family:"Cormorant Garamond",serif;font-size:22px;font-weight:600;color:var(--brass);width:26px;text-align:center;flex:none}
.day .dl{font-size:13px;color:var(--ink)}
.prog{height:8px;border-radius:999px;background:var(--line);overflow:hidden;margin-top:8px}
.prog span{display:block;height:100%;background:var(--teal)}
.wisdom{border:1px solid var(--line);border-radius:11px;padding:14px;background:#fff;cursor:pointer;transition:.12s}
.wisdom:hover{border-color:var(--teal)}
.wt{font-family:"Cormorant Garamond",serif;font-size:17px;font-weight:600;margin-bottom:4px}
.wd{font-size:12.5px;color:var(--soft)}
.evt{border:1px solid var(--line);border-radius:11px;padding:15px;background:#fff}
.evd{font-size:11px;letter-spacing:.6px;text-transform:uppercase;color:var(--brass);font-weight:600}
.evt-t{font-family:"Cormorant Garamond",serif;font-size:18px;font-weight:600;margin:3px 0 4px}
.evx{font-size:12.5px;color:var(--soft);margin-bottom:10px}
#guideBtn{position:fixed;bottom:24px;right:24px;z-index:80;width:60px;height:60px;border-radius:50%;border:none;cursor:pointer;padding:0;background:radial-gradient(circle at 38% 30%,#2EA89A,#0F5A63 80%);box-shadow:0 8px 24px rgba(15,90,99,.42),0 0 0 6px rgba(42,157,143,.12);display:flex;align-items:center;justify-content:center;transition:transform .15s,box-shadow .15s}
#guideBtn .orb-spark{width:30px;height:30px;filter:drop-shadow(0 1px 2px rgba(0,0,0,.18))}
#guideBtn:hover{transform:translateY(-2px) scale(1.04);box-shadow:0 12px 30px rgba(15,90,99,.5),0 0 0 9px rgba(42,157,143,.16)}
#guideCard{position:fixed;bottom:88px;right:22px;z-index:80;width:340px;max-width:calc(100vw - 32px);background:var(--paper);border:1px solid var(--line);border-radius:16px;box-shadow:0 16px 48px rgba(35,32,27,.22);display:none;flex-direction:column;overflow:hidden}
#guideCard.open{display:flex}
.g-head{display:flex;align-items:center;justify-content:space-between;padding:13px 16px;background:var(--teal);color:#fff}
.g-title{font-family:"Cormorant Garamond",serif;font-size:18px;font-weight:600;display:flex;align-items:center;gap:8px}
.g-orb{width:24px;height:24px;border-radius:50%;background:radial-gradient(circle at 38% 32%,#2A9D8F,#0F5A63 80%);display:inline-flex;align-items:center;justify-content:center;flex:none}
.g-orb svg{width:13px;height:13px}
.g-x{background:none;border:none;color:#fff;cursor:pointer;font-size:13px}
.g-body{padding:14px;display:flex;flex-direction:column;gap:9px;max-height:300px;overflow:auto}
.g-msg{max-width:86%;padding:10px 13px;border-radius:13px;font-size:13px;line-height:1.45}
.g-them{background:var(--panel);align-self:flex-start;border-bottom-left-radius:4px}
.g-me{background:var(--teal);color:#fff;align-self:flex-end;border-bottom-right-radius:4px}
.g-sugg{display:flex;flex-wrap:wrap;gap:6px;padding:0 14px 10px}
.g-sugg button{background:#fff;border:1px solid var(--line-2);color:var(--teal);font-size:11.5px;padding:6px 10px;border-radius:999px;cursor:pointer;font-family:inherit}
.g-sugg button:hover{background:var(--teal-soft)}
.g-input{display:flex;gap:8px;padding:12px 14px;border-top:1px solid var(--line)}
.g-input input{flex:1;border:1px solid var(--line-2);border-radius:9px;padding:9px 11px;font-size:13px;font-family:inherit}
.g-input input:focus{outline:none;border-color:var(--teal)}
.g-input button{background:var(--teal);color:#fff;border:none;border-radius:9px;width:38px;cursor:pointer;font-size:16px}

.rem-list{display:flex;flex-direction:column;gap:10px}
.rem{display:flex;align-items:center;gap:13px;padding:12px 13px;border:1px solid var(--line);border-radius:11px;background:#fff}
.rem-ic{width:48px;height:48px;border-radius:50%;flex:none;overflow:hidden}
.rem-ic img{width:100%;height:100%;object-fit:cover}
.rem-ic.gl{display:flex;align-items:center;justify-content:center;background:radial-gradient(circle at 50% 32%,var(--brass-soft),#ecdfc0);color:var(--brass);border:1px solid var(--line-2)}
.rem-ic.gl svg{width:24px;height:24px}
.rem-main{flex:1}
.rem-t{font-size:14.5px;font-weight:600;display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.rem-d{font-size:12.5px;color:var(--soft);margin-top:2px}
.pill.rec{background:#fff;color:var(--brass);border:1px solid var(--brass)}

.avatar.logo{background:transparent;border:1px solid var(--line-2);padding:2px}
.avatar.logo img{width:100%;height:100%;object-fit:contain;border-radius:50%}
.share-gift{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-top:18px}
.share-gift>div{background:var(--teal-soft);border:1px solid var(--line);border-radius:12px;padding:14px 16px}
.sg-h{font-size:11px;text-transform:uppercase;letter-spacing:.08em;color:var(--teal);font-weight:600;margin-bottom:4px}
.sg-d{font-size:13px;color:var(--ink);line-height:1.45}
@media(max-width:560px){.share-gift{grid-template-columns:1fr}}

.side-share{display:flex;align-items:center;gap:9px;padding:8px 12px;margin:0 0 6px;color:var(--brass);font-size:13px;font-weight:500;cursor:pointer;border-radius:10px;text-decoration:none}
.side-share:hover{background:#fff}
.side-share svg{width:15px;height:15px;flex:none}
.video-poster{position:relative;aspect-ratio:16/9;border-radius:14px;margin-top:14px;cursor:pointer;overflow:hidden;background:radial-gradient(circle at 50% 38%,#2A9D8F,#0F5A63 88%);display:flex;align-items:center;justify-content:center}
.vp-play{width:62px;height:62px;border-radius:50%;background:rgba(255,255,255,.93);display:flex;align-items:center;justify-content:center;box-shadow:0 6px 20px rgba(0,0,0,.28);transition:transform .15s}
.video-poster:hover .vp-play{transform:scale(1.06)}
.vp-play svg{width:26px;height:26px;color:var(--teal);margin-left:3px}
.vp-spark{position:absolute;top:13px;left:15px;width:24px;height:24px;opacity:.92}
.vp-dur{position:absolute;bottom:11px;right:13px;background:rgba(0,0,0,.45);color:#fff;font-size:12px;padding:2px 8px;border-radius:20px;font-variant-numeric:tabular-nums}
.mantra-text{margin-top:16px}
.mantra-line{font-family:"Cormorant Garamond",serif;font-size:27px;color:var(--brass);font-weight:600;letter-spacing:.3px;line-height:1.2}
.mantra-mean{font-size:13px;color:var(--soft);font-style:italic;margin-top:4px}
.mantra-mini{font-family:"Cormorant Garamond",serif;font-size:19px;color:var(--brass);font-weight:600;margin-top:12px}
.reward-box{margin-top:14px;background:var(--brass-soft);border:1px solid var(--line-2);border-radius:12px;padding:14px 16px}
.nav-share{cursor:pointer}

.now-list{display:flex;flex-direction:column;gap:10px}
.now{display:flex;align-items:center;gap:13px;padding:11px 13px;border:1px solid var(--line);border-radius:11px;cursor:pointer;transition:.12s}
.now:hover{background:var(--panel);border-color:var(--line-2)}
.now-ic{width:44px;height:44px;border-radius:50%;flex:none;overflow:hidden}
.now-ic img{width:100%;height:100%;object-fit:cover}
.now-ic.gl{display:flex;align-items:center;justify-content:center;background:radial-gradient(circle at 50% 32%,var(--brass-soft),#ecdfc0);color:var(--brass);border:1px solid var(--line-2)}
.now-ic.gl svg{width:22px;height:22px}
.now-main{flex:1}.now-t{font-size:14.5px;font-weight:600}.now-d{font-size:12.5px;color:var(--soft);margin-top:2px}
.now-go{color:var(--faint);font-size:18px}
.vm-p{font-size:13px;color:var(--soft);margin:0 0 8px;line-height:1.5}
.mantra-info{margin-top:4px}
#videoModal .modal{max-height:88vh;overflow:auto}
.video-frame{position:relative;aspect-ratio:16/9;margin-top:14px;border-radius:14px;overflow:hidden;background:#000}
.video-frame iframe{position:absolute;inset:0;width:100%;height:100%;border:0}

/* ---- additions: language switcher + server-rendered helpers ---- */
.langbar{display:flex;gap:6px;margin:6px 0 14px;padding-top:10px;border-top:1px solid var(--line)}
.langopt{font-size:11.5px;font-weight:600;letter-spacing:.4px;color:var(--faint);padding:4px 8px;border-radius:8px;text-decoration:none}
.langopt:hover{background:#fff;color:var(--teal)}
.langopt.on{background:var(--teal-soft);color:var(--teal)}
.profile .em{color:var(--faint);text-decoration:none}
.profile .em:hover{color:var(--teal);text-decoration:underline}
@media(max-width:860px){.langbar{border-top:none;margin:0;padding-top:0}}
@media (prefers-reduced-motion: reduce){*,*::before,*::after{animation-duration:.01ms!important;transition:none!important;scroll-behavior:auto!important}}
:focus-visible{outline:2px solid var(--teal);outline-offset:2px}

/* ---- reading progress stepper (Booked -> Leaf -> Reading -> Remedies -> Delivered) ---- */
.stepper{display:flex;list-style:none;margin:0;padding:0}
.stepper li{flex:1;text-align:center;position:relative;font-size:11.5px;color:var(--faint)}
.stepper li .dot{display:block;width:14px;height:14px;border-radius:50%;background:#fff;border:2px solid var(--line-2);margin:0 auto 6px;position:relative;z-index:1}
.stepper li::before{content:"";position:absolute;top:6px;left:-50%;width:100%;height:2px;background:var(--line-2)}
.stepper li:first-child::before{display:none}
.stepper li.done .dot{background:var(--teal);border-color:var(--teal)}
.stepper li.done::before,.stepper li.now::before{background:var(--teal)}
.stepper li.now .dot{background:var(--brass);border-color:var(--brass);box-shadow:0 0 0 4px var(--brass-soft)}
.stepper li.done .lbl,.stepper li.now .lbl{color:var(--ink)}
