  /* ── plan week nav ── */
  .plan-week-bar{display:flex;align-items:center;justify-content:space-between;padding:10px 0 4px;gap:8px}
  .wk-nav{background:var(--surface-2);border:1px solid var(--line);border-radius:8px;width:30px;height:30px;font-size:18px;cursor:pointer;display:flex;align-items:center;justify-content:center;color:var(--ink-2);transition:.15s}
  .wk-nav:hover:not(:disabled){background:var(--surface);border-color:var(--green);color:var(--green)}
  .wk-nav:disabled{opacity:.35;cursor:default}
  #plan-week-label{font-size:12.5px;font-weight:600;color:var(--ink);text-align:center;flex:1}

  /* ── goal card ── */
  .goal-card{display:flex;align-items:center;justify-content:space-between;background:linear-gradient(135deg,var(--green) 0%,#2E8061 100%);border-radius:var(--r-lg);padding:16px 18px;margin-bottom:14px;color:#fff}
  .gc-label{font-size:10px;font-weight:700;letter-spacing:.07em;text-transform:uppercase;opacity:.75;margin-bottom:5px}
  .gc-values{display:flex;align-items:center;gap:7px;margin-bottom:4px}
  .gc-curr{font-size:20px;font-weight:700}
  .gc-values svg{opacity:.7}
  .gc-target{font-size:16px;font-weight:600;opacity:.85}
  .gc-sub{font-size:12px;opacity:.85;margin-bottom:4px}
  .gc-date{font-size:11px;opacity:.7}

  /* ── chart range tabs ── */
  .range-tabs{display:flex;gap:3px;background:var(--surface-2);border:1px solid var(--line);border-radius:8px;padding:2px}
  .rt{font-size:10.5px;font-weight:600;padding:3px 8px;border-radius:6px;cursor:pointer;color:var(--ink-3);transition:.15s;user-select:none}
  .rt.on{background:#fff;color:var(--green);box-shadow:0 1px 3px rgba(0,0,0,.08)}
  .rt:hover:not(.on){color:var(--ink-2)}
  .ch-h{display:flex;align-items:center;justify-content:space-between;gap:8px;margin-bottom:8px}

  /* ============ PATIENT ============ */
  .patient-layout{display:grid; grid-template-columns:340px 1fr; gap:40px; align-items:start}
  @media(max-width:880px){ .patient-layout{grid-template-columns:1fr; gap:28px} }
  .phone-wrap{position:sticky; top:20px; display:flex; justify-content:center}
  @media(max-width:880px){ .phone-wrap{position:static} }
  .phone{width:332px; max-width:100%; background:#0E1F18; border-radius:42px; padding:11px; box-shadow:var(--shadow-lg); position:relative}
  .phone-screen{background:var(--surface-2); border-radius:32px; overflow:hidden; position:relative; height:690px; display:flex; flex-direction:column}
  .notch{position:absolute; top:11px; left:50%; transform:translateX(-50%); z-index:5; width:108px; height:26px; background:#0E1F18; border-radius:0 0 16px 16px}

  .p-top{padding:30px 20px 14px; background:var(--green); color:#fff; flex:none; position:relative; overflow:hidden}
  .p-top::after{content:""; position:absolute; right:-40px; top:-30px; width:140px; height:140px; background:radial-gradient(circle, rgba(224,160,46,.35), transparent 70%)}
  .p-greet{display:flex; align-items:center; justify-content:space-between; position:relative; z-index:1}
  .p-greet .hi{font-family:var(--display); font-weight:600; font-size:18px}
  .p-greet .date{font-size:12px; opacity:.78; margin-top:1px}
  .avatar{width:38px;height:38px;border-radius:50%;flex:none;display:grid;place-items:center; font-weight:600; font-size:14px; color:var(--green-dark); background:var(--saffron)}

  .p-body{flex:1; overflow-y:auto; padding:16px; scrollbar-width:thin}
  .p-body::-webkit-scrollbar{width:0}
  .screen{display:none; animation:fade .35s ease}
  .screen.on{display:block}
  @keyframes fade{from{opacity:0; transform:translateY(6px)} to{opacity:1;transform:none}}

  .card{background:var(--surface); border:1px solid var(--line-2); border-radius:var(--r-lg); padding:16px; margin-bottom:13px; box-shadow:var(--shadow)}
  .card-h{display:flex; align-items:center; justify-content:space-between; margin-bottom:13px}
  .card-h h4{font-size:14.5px}
  .card-h .tiny{font-size:11.5px; color:var(--ink-3); font-weight:500}

  .ring-row{display:flex; align-items:center; gap:16px}
  .ring{position:relative; flex:none}
  .ring svg{transform:rotate(0)}
  .ring-mid{position:absolute; inset:0; display:grid; place-items:center; text-align:center}
  .ring-mid .big{font-family:var(--display); font-weight:600; font-size:21px; line-height:1}
  .ring-mid .lbl{font-size:10px; color:var(--ink-3); margin-top:2px}
  .macros{flex:1; display:flex; flex-direction:column; gap:11px}
  .macro .mt{display:flex; justify-content:space-between; font-size:12px; margin-bottom:5px}
  .macro .mt b{font-weight:600}.macro .mt span{color:var(--ink-3)}
  .bar{height:7px; background:var(--line); border-radius:99px; overflow:hidden}
  .bar i{display:block; height:100%; border-radius:99px}

  .note{background:linear-gradient(180deg, #fff, var(--saffron-soft)); border:1px solid #F0DEB4; border-radius:var(--r-lg); padding:15px; margin-bottom:13px; box-shadow:var(--shadow)}
  .note-h{display:flex; align-items:center; gap:9px; margin-bottom:9px}
  .note-h .av{width:30px;height:30px;border-radius:50%;background:var(--green);color:#fff; display:grid;place-items:center;font-size:11px;font-weight:600;flex:none}
  .note-h .nm{font-size:12.5px; font-weight:600}
  .note-h .rl{font-size:10.5px; color:var(--saffron-ink); font-weight:500}
  .note p{font-size:13px; color:var(--ink); line-height:1.5}
  .note-foot{display:flex; gap:8px; margin-top:11px}
  .chip-btn{font-size:11.5px; font-weight:500; padding:7px 12px; border-radius:999px; background:var(--green); color:#fff; display:inline-flex; align-items:center; gap:5px}
  .chip-btn.ghost{background:#fff; color:var(--green); border:1px solid var(--green-soft)}

  .meal{display:flex; align-items:center; gap:12px; padding:11px 0; border-bottom:1px solid var(--line-2)}
  .meal:last-child{border-bottom:none; padding-bottom:0}
  .meal-ic{width:40px;height:40px;border-radius:12px;flex:none;display:grid;place-items:center; font-size:18px; background:var(--green-soft)}
  .meal-main{flex:1; min-width:0}
  .meal-main .mn{font-size:13.5px; font-weight:500}
  .meal-main .md{font-size:11.5px; color:var(--ink-3); white-space:nowrap; overflow:hidden; text-overflow:ellipsis}
  .meal-k{font-family:var(--display); font-weight:600; font-size:13px; color:var(--green); flex:none}
  .meal.empty .meal-ic{background:var(--line-2); color:var(--ink-3)}
  .add-row{display:flex; align-items:center; justify-content:center; gap:7px; margin-top:12px; padding:11px; border:1.5px dashed var(--line); border-radius:var(--r-md); font-size:12.5px; font-weight:500; color:var(--green)}

  .search{display:flex; align-items:center; gap:9px; background:#fff; border:1px solid var(--line); border-radius:var(--r-md); padding:11px 13px; margin-bottom:13px}
  .search input{border:none; outline:none; flex:1; font-size:13px; font-family:inherit; background:none; color:var(--ink)}
  .quick{display:flex; gap:7px; flex-wrap:wrap; margin-bottom:16px}
  .qchip{font-size:12px; font-weight:500; padding:7px 12px; border-radius:999px; background:#fff; border:1px solid var(--line); color:var(--ink-2)}
  .qchip.act{background:var(--green-soft); border-color:var(--green-soft); color:var(--green-dark)}
  .sec-lbl{font-size:11px; font-weight:600; letter-spacing:.05em; text-transform:uppercase; color:var(--ink-3); margin:4px 0 9px}
  .food{display:flex; align-items:center; gap:12px; padding:10px 12px; background:#fff; border:1px solid var(--line-2); border-radius:var(--r-md); margin-bottom:8px}
  .food .fic{width:34px;height:34px;border-radius:9px;background:var(--saffron-soft); display:grid;place-items:center;font-size:15px;flex:none}
  .food .fm{flex:1}.food .fm .fn{font-size:13px; font-weight:500}.food .fm .fd{font-size:11px; color:var(--ink-3)}
  .food .fadd{width:28px;height:28px;border-radius:8px;background:var(--green);color:#fff; display:grid;place-items:center;flex:none}

  .days{display:flex; gap:6px; margin-bottom:15px; overflow-x:auto; scrollbar-width:none}
  .days::-webkit-scrollbar{display:none}
  .day{flex:none; width:42px; text-align:center; padding:9px 0; border-radius:12px; background:#fff; border:1px solid var(--line-2)}
  .day .dd{font-size:10px; color:var(--ink-3); text-transform:uppercase; letter-spacing:.04em}
  .day .dn{font-family:var(--display); font-weight:600; font-size:15px; margin-top:2px}
  .day.act{background:var(--green); border-color:var(--green)}
  .day.act .dd{color:rgba(255,255,255,.7)} .day.act .dn{color:#fff}
  .plan-meal{background:#fff; border:1px solid var(--line-2); border-radius:var(--r-md); padding:13px; margin-bottom:10px}
  .plan-meal .pm-h{display:flex; justify-content:space-between; align-items:center; margin-bottom:8px}
  .plan-meal .pm-h .pt{font-size:12.5px; font-weight:600}
  .plan-meal .pm-h .pk{font-size:11px; color:var(--saffron-ink); font-weight:600; background:var(--saffron-soft); padding:3px 8px; border-radius:99px}
  .plan-meal ul{list-style:none; font-size:12.5px; color:var(--ink-2)}
  .plan-meal li{display:flex; align-items:center; gap:7px; padding:3px 0}
  .plan-meal li::before{content:""; width:5px; height:5px; border-radius:50%; background:var(--green-mid)}

  .appt{background:var(--green); color:#fff; border-radius:var(--r-lg); padding:15px; margin-bottom:14px; display:flex; align-items:center; gap:13px; position:relative; overflow:hidden}
  .appt::after{content:"";position:absolute;right:-30px;bottom:-30px;width:110px;height:110px; background:radial-gradient(circle,rgba(224,160,46,.3),transparent 70%)}
  .appt .ai{width:44px;height:44px;border-radius:13px;background:rgba(255,255,255,.16); display:grid;place-items:center;flex:none}
  .appt .am{flex:1; position:relative; z-index:1}
  .appt .am .at{font-size:13.5px; font-weight:600}.appt .am .ad{font-size:11.5px; opacity:.8; margin-top:1px}
  .appt .join{background:var(--saffron); color:var(--green-dark); font-size:12px; font-weight:600; padding:9px 14px; border-radius:99px; position:relative; z-index:1; flex:none}
  .thread{display:flex; flex-direction:column; gap:9px; margin-bottom:6px}
  .bub{max-width:80%; padding:10px 13px; border-radius:16px; font-size:12.5px; line-height:1.45}
  .bub.them{background:#fff; border:1px solid var(--line-2); border-bottom-left-radius:5px; align-self:flex-start}
  .bub.me{background:var(--green); color:#fff; border-bottom-right-radius:5px; align-self:flex-end}
  .bub .bt{font-size:9.5px; opacity:.55; margin-top:4px}
  .composer{display:flex; align-items:center; gap:8px; margin-top:12px; background:#fff; border:1px solid var(--line); border-radius:999px; padding:7px 7px 7px 15px}
  .composer input{flex:1;border:none;outline:none;font-size:12.5px;font-family:inherit;background:none}
  .composer .send{width:34px;height:34px;border-radius:50%;background:var(--green);color:#fff; display:grid;place-items:center;flex:none}

  /* profile / progress */
  .prof-head{display:flex; align-items:center; gap:13px; background:#fff; border:1px solid var(--line-2); border-radius:var(--r-lg); padding:16px; box-shadow:var(--shadow); margin-bottom:13px}
  .prof-head .pa{width:52px;height:52px;border-radius:16px;background:var(--green);color:#fff; display:grid;place-items:center;font-family:var(--display);font-weight:600;font-size:21px;flex:none}
  .prof-head .pn{font-family:var(--display);font-weight:600;font-size:16px}
  .prof-head .pd{font-size:12px;color:var(--ink-2);margin-top:2px}
  .mini-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:9px;margin-bottom:13px}
  .ms{background:#fff;border:1px solid var(--line-2);border-radius:var(--r-md);padding:12px;text-align:center}
  .ms .v{font-family:var(--display);font-weight:600;font-size:18px}
  .ms .l{font-size:10px;color:var(--ink-3);margin-top:2px}
  .chart-card{background:#fff;border:1px solid var(--line-2);border-radius:var(--r-lg);padding:15px;margin-bottom:13px;box-shadow:var(--shadow)}
  .chart-card .ch-h{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:12px}
  .chart-card .ch-h .ct{font-size:13px;font-weight:600}
  .chart-card .ch-h .cv{font-size:12px;font-weight:600}
  .wbars{display:flex;align-items:flex-end;gap:6px;height:70px;margin-top:6px}
  .wbars .wb{flex:1;display:flex;flex-direction:column;align-items:center;gap:5px}
  .wbars .wb i{width:100%;border-radius:5px 5px 2px 2px;background:var(--green-soft)}
  .wbars .wb i.hi{background:var(--green)} .wbars .wb i.lo{background:var(--saffron)}
  .wbars .wb span{font-size:9px;color:var(--ink-3)}
  .setting{display:flex;align-items:center;gap:12px;padding:13px 15px;background:#fff;border:1px solid var(--line-2);border-bottom:none;font-size:13px}
  .setting:first-of-type{border-radius:var(--r-md) var(--r-md) 0 0}
  .setting:last-of-type{border-radius:0 0 var(--r-md) var(--r-md);border-bottom:1px solid var(--line-2)}
  .setting .si{width:30px;height:30px;border-radius:8px;background:var(--green-soft);color:var(--green);display:grid;place-items:center;flex:none}
  .setting .st{flex:1}.setting .sv{font-size:12px;color:var(--ink-3)}

  .p-nav{flex:none; display:flex; background:#fff; border-top:1px solid var(--line-2); padding:9px 4px 13px}
  .p-nav button{flex:1; display:flex; flex-direction:column; align-items:center; gap:3px; font-size:9px; font-weight:500; color:var(--ink-3)}
  .p-nav button svg{width:20px;height:20px}
  .p-nav button.on{color:var(--green)}

  /* video call overlay (patient) */
  .call{position:absolute; inset:0; z-index:20; background:#0E1F18; display:none; flex-direction:column; color:#fff; border-radius:32px; overflow:hidden}
  .call.on{display:flex; animation:fade .3s ease}
  .call-top{padding:34px 18px 0; display:flex; align-items:center; justify-content:space-between}
  .call-top .ct{font-size:12.5px;font-weight:500} .call-top .tm{font-size:11px;opacity:.6}
  .call-stage{flex:1; display:grid; place-items:center; position:relative;
    background:radial-gradient(circle at 50% 40%, #1d3a2c, #0E1F18)}
  .call-remote{text-align:center}
  .call-remote .ca{width:96px;height:96px;border-radius:50%;background:var(--green-mid);color:#fff;
    display:grid;place-items:center;font-family:var(--display);font-weight:600;font-size:38px;margin:0 auto 12px}
  .call-remote .cn{font-family:var(--display);font-weight:600;font-size:17px}
  .call-remote .cs{font-size:11.5px;opacity:.6;margin-top:3px}
  .call-self{position:absolute;right:14px;bottom:14px;width:74px;height:100px;border-radius:14px;
    background:linear-gradient(160deg,#2E8061,#143C2D);border:2px solid rgba(255,255,255,.18);
    display:grid;place-items:center;font-size:11px;color:rgba(255,255,255,.8)}
  .call-ctrls{display:flex;justify-content:center;gap:16px;padding:18px 0 30px}
  .cc{width:50px;height:50px;border-radius:50%;background:rgba(255,255,255,.12);display:grid;place-items:center}
  .cc.end{background:var(--coral)}

  /* onboarding / intake */
  .ob{position:absolute;inset:0;z-index:25;background:var(--surface-2);display:none;flex-direction:column;border-radius:32px;overflow:hidden}
  .ob.on{display:flex;animation:fade .3s ease}
  .ob-top{padding:32px 20px 14px;display:flex;align-items:center;gap:12px}
  .ob-x{width:30px;height:30px;border-radius:9px;background:#fff;border:1px solid var(--line);display:grid;place-items:center;flex:none;color:var(--ink-2)}
  .ob-prog{flex:1;height:6px;background:var(--line);border-radius:99px;overflow:hidden}
  .ob-prog i{display:block;height:100%;background:var(--green);border-radius:99px;width:16%;transition:width .35s cubic-bezier(.2,.7,.3,1)}
  .ob-body{flex:1;overflow-y:auto;padding:8px 20px 16px;scrollbar-width:none}
  .ob-body::-webkit-scrollbar{width:0}
  .ob-step{display:none}.ob-step.on{display:block;animation:fade .3s ease}
  .ob-eyebrow{font-size:11px;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:var(--saffron-ink)}
  .ob-title{font-family:var(--display);font-weight:600;font-size:22px;margin:8px 0 6px;line-height:1.15}
  .ob-sub{font-size:13px;color:var(--ink-2);line-height:1.5;margin-bottom:18px}
  .ob-field{margin-bottom:13px;flex:1}
  .ob-label{font-size:11.5px;font-weight:600;color:var(--ink-2);margin-bottom:6px}
  .ob-input{width:100%;border:1px solid var(--line);border-radius:var(--r-md);padding:13px 14px;font-size:14px;font-family:inherit;outline:none;background:#fff;color:var(--ink)}
  .ob-input:focus{border-color:var(--green-mid)}
  .ob-row{display:flex;gap:10px}
  .ob-opt{display:flex;align-items:center;gap:12px;width:100%;text-align:left;background:#fff;border:1.5px solid var(--line);border-radius:var(--r-md);padding:12px 13px;margin-bottom:9px;cursor:pointer;transition:.15s}
  .ob-opt:hover{border-color:var(--green-soft)}
  .ob-opt.sel{border-color:var(--green);background:var(--green-soft)}
  .ob-opt .oi{width:36px;height:36px;border-radius:10px;background:var(--saffron-soft);display:grid;place-items:center;font-size:18px;flex:none}
  .ob-opt .ot{font-size:13.5px;font-weight:500}.ob-opt .od{font-size:11.5px;color:var(--ink-3)}
  .ob-opt .ok{margin-left:auto;width:20px;height:20px;border-radius:50%;border:1.5px solid var(--line);display:grid;place-items:center;flex:none;color:#fff;font-size:11px;background:#fff}
  .ob-opt.sel .ok{background:var(--green);border-color:var(--green)}
  .ob-chips{display:flex;gap:8px;flex-wrap:wrap}
  .ob-chip{padding:9px 15px;border-radius:999px;border:1.5px solid var(--line);background:#fff;font-size:13px;font-weight:500;cursor:pointer}
  .ob-chip.sel{border-color:var(--green);background:var(--green-soft);color:var(--green-dark)}
  .ob-doc{display:flex;gap:12px;background:#fff;border:1.5px solid var(--line);border-radius:var(--r-md);padding:13px;margin-bottom:10px;cursor:pointer;transition:.15s}
  .ob-doc.sel{border-color:var(--green);background:var(--green-soft)}
  .ob-doc .da{width:46px;height:46px;border-radius:13px;background:var(--green);color:#fff;display:grid;place-items:center;font-family:var(--display);font-weight:600;font-size:18px;flex:none}
  .ob-doc .dn2{font-size:13.5px;font-weight:600}.ob-doc .ds{font-size:11.5px;color:var(--ink-3);margin-top:1px}
  .ob-doc .dmeta{display:flex;gap:10px;margin-top:6px;font-size:10.5px;color:var(--ink-2);flex-wrap:wrap}
  .ob-doc .dmeta b{color:var(--green)}
  .ob-done{text-align:center;padding-top:24px}
  .ob-done .dc{width:74px;height:74px;border-radius:50%;background:var(--green-soft);color:var(--green);display:grid;place-items:center;margin:0 auto 16px}
  .ob-foot{padding:14px 20px 22px;border-top:1px solid var(--line-2);background:var(--surface-2)}
  .ob-btn{width:100%;background:var(--green);color:#fff;font-size:14px;font-weight:600;padding:14px;border-radius:var(--r-md);display:flex;align-items:center;justify-content:center;gap:8px}
  .ob-launch{display:inline-flex;align-items:center;gap:8px;margin-top:14px;background:var(--green);color:#fff;font-size:13px;font-weight:500;padding:9px 16px;border-radius:999px}
  .ob-launch:hover{background:var(--green-dark)}

  .feat-grid{display:grid; grid-template-columns:1fr 1fr; gap:13px}
  @media(max-width:520px){ .feat-grid{grid-template-columns:1fr} }
  .feat{background:var(--surface); border:1px solid var(--line-2); border-radius:var(--r-lg); padding:18px; box-shadow:var(--shadow); transition:transform .2s, box-shadow .2s}
  .feat:hover{transform:translateY(-3px); box-shadow:var(--shadow-lg)}
  .feat .fi{width:42px;height:42px;border-radius:12px;display:grid;place-items:center;margin-bottom:13px}
  .feat h4{font-size:15px; margin-bottom:5px}
  .feat p{font-size:13px; color:var(--ink-2); line-height:1.5}
  .feat .badge{display:inline-block;margin-top:10px;font-size:10.5px;font-weight:600; padding:3px 9px;border-radius:99px}
  .map-note{background:var(--surface);border:1px solid var(--line-2);border-radius:var(--r-lg);padding:18px;margin-top:13px;box-shadow:var(--shadow)}
  .map-note h4{font-size:14px;margin-bottom:10px}
  .map-note .mr{display:flex;align-items:center;gap:9px;font-size:12.5px;color:var(--ink-2);padding:6px 0}
  .map-note .mr .k{width:18px;height:18px;border-radius:6px;background:var(--green-soft);color:var(--green);display:grid;place-items:center;flex:none;font-size:11px}

