/* ═══════════════════════════════════════════════
   IronQx Clinical & Performance Coaching
   04-components — Hero, Cards, Buttons, Fields, Modals, Charts, Achievements, Patient UI
   AUTO-EXTRACTED — safe to edit individually
═══════════════════════════════════════════════ */


/* HERO */
.hero{
  background:linear-gradient(145deg,rgba(212,146,14,.13) 0%,rgba(212,146,14,.04) 55%,rgba(10,10,11,0) 100%);
  border:1px solid rgba(212,146,14,.22);
  border-radius:20px;padding:18px 16px 17px;margin-bottom:12px;
  display:flex;align-items:center;gap:14px;
  box-shadow:0 8px 32px rgba(0,0,0,.4),0 1px 0 rgba(212,146,14,.14) inset;
  position:relative;overflow:hidden
}
.hero::before{
  content:"IQX";position:absolute;right:-8px;top:50%;transform:translateY(-50%);
  font-family:"Barlow Condensed",sans-serif;font-size:120px;font-weight:900;letter-spacing:2px;
  color:rgba(212,146,14,.045);pointer-events:none;white-space:nowrap;line-height:1
}
.hero::after{
  content:"";position:absolute;top:0;left:0;right:0;height:1px;
  background:linear-gradient(90deg,transparent,rgba(212,146,14,.4),transparent);pointer-events:none
}
.hero-name{font-family:"Barlow Condensed",sans-serif;font-size:26px;font-weight:900;color:var(--txt);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;letter-spacing:.5px}
.hero-goal{font-size:10px;color:var(--gold);font-weight:700;letter-spacing:2px;text-transform:uppercase;margin-top:4px;display:flex;align-items:center;gap:5px}
.hero-goal::before{content:"";width:4px;height:4px;border-radius:50%;background:var(--gold);flex-shrink:0;box-shadow:0 0 6px var(--gold);animation:glow-pulse 2s ease-in-out infinite}
.hero-meta{font-size:11px;color:var(--txt2);margin-top:5px}

/* AVATAR */
.av{border-radius:50%;background:linear-gradient(135deg,var(--gold2),var(--gold3));display:flex;align-items:center;justify-content:center;font-family:"Barlow Condensed",sans-serif;font-weight:900;color:#080808;flex-shrink:0;border:2px solid rgba(212,146,14,.3);box-shadow:0 0 0 4px rgba(212,146,14,.1),0 0 20px rgba(212,146,14,.2),0 4px 16px rgba(0,0,0,.4)}
.av-xl{width:70px;height:70px;font-size:30px}.av-lg{width:52px;height:52px;font-size:22px}.av-md{width:42px;height:42px;font-size:18px}.av-sm{width:34px;height:34px;font-size:14px}
.av-dr{background:linear-gradient(135deg,#1a2240,#253468);border-color:rgba(85,119,238,.3)}

/* CARDS */
.card{background:rgba(17,18,20,.9);border:1px solid rgba(42,45,56,.8);border-radius:var(--r);overflow:hidden;margin-bottom:10px;box-shadow:0 2px 12px rgba(0,0,0,.2)}
.card-hd{display:flex;align-items:center;gap:11px;padding:13px 14px;background:rgba(24,25,31,.8);border-bottom:1px solid rgba(42,45,56,.6)}
.card-ico{font-size:19px;flex-shrink:0;width:26px;text-align:center;display:flex;align-items:center;justify-content:center;color:var(--gold)}
.card-ico .iq-ic{width:19px;height:19px}
.card-title{font-family:"Barlow Condensed",sans-serif;font-size:14px;font-weight:800;letter-spacing:1.5px;text-transform:uppercase}
.card-sub{font-size:11px;color:var(--muted);margin-top:1px}
.card-arr{margin-left:auto;color:var(--muted);font-size:18px;flex-shrink:0}
.card-bd{padding:14px}
.ctap{cursor:pointer;transition:border-color .15s,opacity .15s}.ctap:active{opacity:.8;border-color:var(--gold-brd)}

/* STAT GRID */
.sg{display:grid;gap:8px;margin-bottom:10px}
.sg.c2{grid-template-columns:repeat(2,1fr)}.sg.c3{grid-template-columns:repeat(3,1fr)}.sg.c4{grid-template-columns:repeat(4,1fr)}
.sc{background:rgba(17,18,22,.95);border:1px solid rgba(42,45,56,.9);border-radius:14px;padding:15px 10px 13px;text-align:center;position:relative;overflow:hidden;transition:border-color .2s,box-shadow .2s}
.sc.g{border-color:rgba(212,146,14,.22);background:linear-gradient(145deg,rgba(212,146,14,.11),rgba(212,146,14,.025));box-shadow:0 0 18px rgba(212,146,14,.06) inset}
.sc.g::after{content:"";position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,rgba(212,146,14,.45),transparent)}
.sc.gr{border-color:var(--green-brd);background:var(--green-bg)}.sc.rd{border-color:var(--red-brd);background:var(--red-bg)}.sc.am{border-color:var(--amber-brd);background:var(--amber-bg)}
.sv{font-family:"Barlow Condensed",sans-serif;font-size:34px;font-weight:900;color:var(--gold);line-height:1}
.su{font-size:9px;color:var(--muted);margin-top:3px;letter-spacing:.6px;text-transform:uppercase;font-family:"DM Mono",monospace}
.sl2{font-size:11px;color:var(--txt2);margin-top:5px;font-weight:700}

/* ─── PREMIUM HOME NAV CARDS ─── */
.home-nav-card{
  display:flex;align-items:center;gap:14px;
  background:rgba(14,15,19,.97);
  border:1px solid rgba(255,255,255,.055);
  border-radius:16px;padding:15px 14px;margin-bottom:9px;
  cursor:pointer;transition:all .18s cubic-bezier(.32,1,.36,1);
  position:relative;overflow:hidden;
  box-shadow:0 2px 16px rgba(0,0,0,.3)
}
.home-nav-card::after{content:"";position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,rgba(255,255,255,.07),transparent)}
.home-nav-card.gold{border-color:rgba(212,146,14,.12)}
.home-nav-card.blue{border-color:rgba(85,119,238,.12)}
.home-nav-card.green{border-color:rgba(46,171,101,.12)}
.home-nav-card:active{transform:scale(.975);box-shadow:0 0 0 2px rgba(212,146,14,.12),0 4px 20px rgba(0,0,0,.4)}
.home-nav-card.gold:active{border-color:rgba(212,146,14,.3)}
.home-nav-card.blue:active{border-color:rgba(85,119,238,.3)}
.home-nav-card.green:active{border-color:rgba(46,171,101,.3)}
.hnc-icon{width:44px;height:44px;border-radius:13px;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.hnc-icon.gold{background:linear-gradient(145deg,rgba(212,146,14,.2),rgba(212,146,14,.07));border:1px solid rgba(212,146,14,.22);color:var(--gold);box-shadow:0 0 14px rgba(212,146,14,.1) inset}
.hnc-icon.blue{background:linear-gradient(145deg,rgba(85,119,238,.2),rgba(85,119,238,.07));border:1px solid rgba(85,119,238,.22);color:var(--blue);box-shadow:0 0 14px rgba(85,119,238,.1) inset}
.hnc-icon.green{background:linear-gradient(145deg,rgba(46,171,101,.2),rgba(46,171,101,.07));border:1px solid rgba(46,171,101,.22);color:var(--green);box-shadow:0 0 14px rgba(46,171,101,.1) inset}
.hnc-icon .iq-ic{width:20px;height:20px}
.hnc-body{flex:1;min-width:0}
.hnc-title{font-family:"Barlow Condensed",sans-serif;font-size:15px;font-weight:800;letter-spacing:1.5px;text-transform:uppercase;color:var(--txt)}
.hnc-sub{font-size:11px;color:var(--muted);margin-top:2px;letter-spacing:.2px}
.hnc-arr{color:rgba(255,255,255,.12);flex-shrink:0;font-size:22px;font-weight:200;line-height:1;transition:transform .18s,color .18s;font-family:"Barlow",sans-serif}
.home-nav-card:active .hnc-arr{transform:translateX(4px);color:var(--gold)}

/* CARDS */
.card{background:rgba(14,15,19,.97);border:1px solid rgba(42,45,56,.75);border-radius:16px;overflow:hidden;margin-bottom:10px;box-shadow:0 2px 16px rgba(0,0,0,.25)}
.card-hd{display:flex;align-items:center;gap:11px;padding:13px 14px;background:rgba(20,21,27,.9);border-bottom:1px solid rgba(42,45,56,.5)}
.card-ico{font-size:19px;flex-shrink:0;width:26px;text-align:center;display:flex;align-items:center;justify-content:center;color:var(--gold)}
.card-ico .iq-ic{width:19px;height:19px}
.card-title{font-family:"Barlow Condensed",sans-serif;font-size:14px;font-weight:800;letter-spacing:1.5px;text-transform:uppercase}
.card-sub{font-size:11px;color:var(--muted);margin-top:1px}
.card-arr{margin-left:auto;color:var(--muted);font-size:18px;flex-shrink:0}
.card-bd{padding:14px}


/* PROGRESS BAR */
.pgw{margin:7px 0}.pgl{display:flex;justify-content:space-between;font-size:10px;color:var(--muted);margin-bottom:4px;font-family:"DM Mono",monospace}
.pgt{background:rgba(255,255,255,.05);border-radius:99px;height:5px;overflow:hidden;box-shadow:inset 0 1px 2px rgba(0,0,0,.3)}
.pgf{height:100%;border-radius:99px;background:linear-gradient(90deg,var(--gold2),var(--gold3));transition:width 1s cubic-bezier(.22,1,.36,1);box-shadow:0 0 6px rgba(212,146,14,.3)}

/* ADHERENCE */
.adh-g{display:grid;grid-template-columns:repeat(7,1fr);gap:4px;margin:10px 0}
.adh-d{aspect-ratio:1;border-radius:10px;border:1px solid rgba(42,45,56,.8);background:rgba(17,18,22,.9);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1px;cursor:pointer;transition:all .16s cubic-bezier(.32,1,.36,1);font-size:8px;color:var(--muted);text-transform:uppercase;box-shadow:0 1px 4px rgba(0,0,0,.2)}
.adh-n{font-family:"Barlow Condensed",sans-serif;font-size:14px;font-weight:900;color:var(--txt);line-height:1}
.adh-d.done{background:linear-gradient(145deg,rgba(46,171,101,.15),rgba(46,171,101,.04));border-color:rgba(46,171,101,.3);box-shadow:0 0 10px rgba(46,171,101,.08) inset,0 1px 6px rgba(0,0,0,.2)}.adh-d.done .adh-n{color:var(--green)}
.adh-d.part{background:linear-gradient(145deg,rgba(212,146,14,.14),rgba(212,146,14,.03));border-color:rgba(212,146,14,.28);box-shadow:0 0 10px rgba(212,146,14,.07) inset,0 1px 6px rgba(0,0,0,.2)}.adh-d.part .adh-n{color:var(--gold)}
.adh-d.miss{background:linear-gradient(145deg,rgba(221,68,68,.1),rgba(221,68,68,.02));border-color:rgba(221,68,68,.22);opacity:.65}
.adh-d.future{opacity:.25;pointer-events:none;cursor:default}
.adh-d:active{transform:scale(.86)}
.adh-d.locked{cursor:default;pointer-events:none;opacity:.7}

/* PLAN VIEWER */
#plan-wrap{position:absolute;inset:0;padding-top:calc(52px + var(--safe-t));padding-bottom:calc(68px + var(--safe-b));display:flex;flex-direction:column}
#plan-wrap.fullscreen{position:fixed;inset:0;padding:0;z-index:9999;background:var(--bg)}
#plan-wrap.fullscreen .plan-tb{display:none}
#plan-wrap.fullscreen #plan-frame{display:flex!important}
#plan-wrap.fullscreen #no-plan{display:none!important}
#plan-wrap.fullscreen #plan-susp{display:none!important}
#plan-fs-btn{background:none;border:none;cursor:pointer;padding:4px 8px;color:var(--muted);font-size:18px;line-height:1;margin-left:auto;transition:color .2s}
#plan-fs-btn:hover{color:var(--gold)}
#plan-fs-exit{display:none!important}
.plan-tb .iq-ic{width:18px;height:18px}
.plan-tb{padding:9px 14px;padding-top:calc(9px + var(--safe-t));background:rgba(10,10,11,.97);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-bottom:2px solid var(--gold);display:flex;align-items:center;gap:10px;flex-shrink:0}
#plan-frame{flex:1;border:none;background:var(--bg);width:100%;display:none}
.no-plan{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:36px 24px;text-align:center}
/* Native fullscreen: portal fills everything, HUD fades */
#plan-fs-portal:-webkit-full-screen{width:100vw;height:100vh}
#plan-fs-portal:-moz-full-screen{width:100vw;height:100vh}
#plan-fs-portal:fullscreen{width:100vw;height:100vh}
#plan-fs-hud.hud-hidden{opacity:0;pointer-events:none!important}
#plan-fs-hud.hud-hidden *{pointer-events:none!important}
@keyframes _hudFadeIn{from{opacity:0}to{opacity:1}}
#plan-fs-hud{animation:_hudFadeIn .3s ease}
.plan-susp{flex:1;display:none;flex-direction:column;align-items:center;justify-content:center;padding:36px 24px;text-align:center}
.plan-susp.show{display:flex}

/* ═══ REPORTE / PHOTOS ═══ */
/* Weekly report banner */
.report-banner{border-radius:16px;padding:16px;margin-bottom:12px;border:1px solid;position:relative;overflow:hidden;box-shadow:0 2px 16px rgba(0,0,0,.2)}
.report-banner.pending{background:linear-gradient(135deg,rgba(232,150,12,.12),rgba(232,150,12,.03));border-color:var(--amber-brd)}
.report-banner.urgent{background:linear-gradient(135deg,rgba(221,68,68,.12),rgba(221,68,68,.03));border-color:var(--red-brd);animation:pulse-brd 2s ease-in-out infinite}
.report-banner.sent{background:linear-gradient(135deg,rgba(46,171,101,.09),rgba(46,171,101,.02));border-color:var(--green-brd)}
.report-banner.late{background:linear-gradient(135deg,rgba(153,102,221,.1),rgba(153,102,221,.02));border-color:var(--purple-brd)}
@keyframes pulse-brd{0%,100%{box-shadow:0 0 0 0 rgba(221,68,68,0)}50%{box-shadow:0 0 0 4px rgba(221,68,68,.12)}}
.rb-header{display:flex;align-items:flex-start;gap:12px;margin-bottom:10px}
.rb-icon{font-size:28px;flex-shrink:0;line-height:1;color:var(--gold)}
.rb-icon .iq-ic{width:28px;height:28px}
 .rb-title{font-family:"Barlow Condensed",sans-serif;font-size:17px;font-weight:900;letter-spacing:1.5px;text-transform:uppercase}
.rb-sub{font-size:12px;color:var(--txt2);margin-top:3px;line-height:1.5}
.rb-tag{font-family:"DM Mono",monospace;font-size:10px;font-weight:700;letter-spacing:1px;padding:3px 8px;border-radius:6px;text-transform:uppercase;display:inline-block;margin-bottom:10px}
.rb-tag.pending{background:var(--amber-bg);color:var(--amber);border:1px solid var(--amber-brd)}
.rb-tag.urgent{background:var(--red-bg);color:var(--red);border:1px solid var(--red-brd)}
.rb-tag.sent{background:var(--green-bg);color:var(--green);border:1px solid var(--green-brd)}
.rb-tag.late{background:var(--purple-bg);color:var(--purple);border:1px solid var(--purple-brd)}

/* Report form inside tab */
.report-section{margin-bottom:18px}
.report-section-title{font-family:"Barlow Condensed",sans-serif;font-size:13px;font-weight:800;letter-spacing:2px;text-transform:uppercase;color:var(--gold);margin-bottom:10px;display:flex;align-items:center;gap:6px}

/* Report adh grid (in form — locked to current week) */
.report-adh{display:grid;grid-template-columns:repeat(7,1fr);gap:5px;margin-bottom:10px}
.ra-day{aspect-ratio:1;border-radius:9px;border:1.5px solid var(--line);background:var(--bg3);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;cursor:pointer;transition:all .16s;-webkit-tap-highlight-color:transparent}
.ra-n{font-family:"Barlow Condensed",sans-serif;font-size:16px;font-weight:900;color:var(--txt);line-height:1}
.ra-lbl{font-size:8px;color:var(--muted);text-transform:uppercase;letter-spacing:.3px;font-family:"DM Mono",monospace}
.ra-day.done{background:var(--green-bg);border-color:var(--green-brd)}.ra-day.done .ra-n{color:var(--green)}.ra-day.done .ra-lbl{color:var(--green)}
.ra-day.part{background:var(--gold-bg);border-color:var(--gold-brd)}.ra-day.part .ra-n{color:var(--gold)}.ra-day.part .ra-lbl{color:var(--gold)}
.ra-day.miss{background:var(--red-bg);border-color:var(--red-brd);opacity:.7}
.ra-day:active:not(.done):not(.part):not(.miss){transform:scale(.88)}

/* Photo strip (3 slots) */
.photo-strip{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin-bottom:10px}
.photo-slot{aspect-ratio:3/4;border-radius:10px;overflow:hidden;position:relative;cursor:pointer;transition:all .15s}
.photo-slot-empty{background:var(--bg4);border:2px dashed var(--line2);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:5px}
.photo-slot-empty:active{border-color:var(--gold-brd);background:var(--gold-bg)}
.photo-slot-empty .ps-ic{font-size:24px;opacity:.5;display:flex;align-items:center;justify-content:center}
.photo-slot-empty .ps-ic .iq-ic{width:24px;height:24px}
.photo-slot-empty .ps-lb{font-size:9px;color:var(--muted);letter-spacing:1px;text-transform:uppercase;font-family:"DM Mono",monospace}
.photo-slot-full img{width:100%;height:100%;object-fit:cover;display:block}
.photo-slot-full .ps-overlay{position:absolute;bottom:0;left:0;right:0;padding:6px 6px 5px;background:linear-gradient(transparent,rgba(0,0,0,.7));font-size:9px;font-weight:700;letter-spacing:1px;text-transform:uppercase;color:rgba(255,255,255,.85);font-family:"DM Mono",monospace}
.photo-slot:active{transform:scale(.95)}

/* Progress log entry */
.pe{display:flex;align-items:center;gap:11px;background:var(--bg3);border:1px solid var(--line);border-radius:var(--rs);padding:11px 13px;margin-bottom:7px}
.pe-day{font-family:"Barlow Condensed",sans-serif;font-size:22px;font-weight:900;color:var(--gold);line-height:1;text-align:center;min-width:38px}
.pe-mo{font-size:9px;color:var(--muted);letter-spacing:1px;text-transform:uppercase;text-align:center;font-family:"DM Mono",monospace}
.pe-div{width:1px;height:34px;background:var(--line);flex-shrink:0}
.pe-w{font-family:"Barlow Condensed",sans-serif;font-size:21px;font-weight:900;color:var(--txt)}
.pe-chg{font-size:11px;font-weight:700;margin-left:5px}
.pe-chg.dn{color:var(--green)}.pe-chg.up{color:var(--red)}.pe-chg.n{color:var(--muted)}
.pe-note{font-size:12px;color:var(--txt2);margin-top:3px;line-height:1.4}

/* ─── REPORTE CARD (admin inbox + patient history) ─── */
.report-card{background:var(--bg2);border:1px solid var(--line);border-radius:var(--r);margin-bottom:10px;overflow:hidden}
.report-card-hd{display:flex;align-items:center;gap:10px;padding:12px 14px;background:var(--bg3);border-bottom:1px solid var(--line);cursor:pointer}
.report-card-hd:active{opacity:.8}
.rc-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}
.rc-dot.unread{background:var(--gold);box-shadow:0 0 6px rgba(212,146,14,.5)}
.rc-dot.read{background:var(--line2)}
.rc-dot.late{background:var(--purple);box-shadow:0 0 6px rgba(153,102,221,.4)}
.report-card-bd{padding:14px;display:none}
.report-card-bd.open{display:block}
.rc-adh-mini{display:grid;grid-template-columns:repeat(7,1fr);gap:3px;margin:8px 0}
.rc-day{height:28px;border-radius:5px;border:1px solid var(--line);background:var(--bg4);display:flex;align-items:center;justify-content:center;font-size:9px;font-family:"DM Mono",monospace;color:var(--muted)}
.rc-day.done{background:var(--green-bg);border-color:var(--green-brd);color:var(--green)}
.rc-day.part{background:var(--gold-bg);border-color:var(--gold-brd);color:var(--gold)}
.rc-day.miss{background:var(--red-bg);border-color:var(--red-brd);opacity:.6;color:var(--red)}
.rc-photos{display:grid;grid-template-columns:repeat(3,1fr);gap:4px;margin:10px 0}
.rc-photo{aspect-ratio:3/4;border-radius:7px;overflow:hidden;position:relative;cursor:pointer}
.rc-photo img{width:100%;height:100%;object-fit:cover;transition:transform .2s}
.rc-photo:active img{transform:scale(.93)}
.rc-photo-lbl{position:absolute;bottom:0;left:0;right:0;padding:4px 5px;background:linear-gradient(transparent,rgba(0,0,0,.68));font-size:8px;font-weight:700;letter-spacing:1px;text-transform:uppercase;color:rgba(255,255,255,.8);font-family:"DM Mono",monospace}
.rc-no-photo{aspect-ratio:3/4;border-radius:7px;background:var(--bg4);border:1px solid var(--line);display:flex;align-items:center;justify-content:center;font-size:22px;opacity:.3}
.dr-reply{background:linear-gradient(135deg,var(--gold-bg),rgba(212,146,14,.03));border:1px solid var(--gold-brd);border-radius:var(--rs);padding:12px 13px;margin-top:10px}
.dr-reply-hd{font-family:"DM Mono",monospace;font-size:10px;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;color:var(--gold);margin-bottom:7px;display:flex;align-items:center;gap:6px}
.dr-reply-txt{font-size:13px;color:var(--txt2);line-height:1.65}

/* ─── SEMÁFORO / INBOX BADGES ─── */
.semaforo-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}
.sf-green{background:var(--green);box-shadow:0 0 6px rgba(46,171,101,.5)}
.sf-amber{background:var(--amber);box-shadow:0 0 6px rgba(232,150,12,.5)}
.sf-red{background:var(--red);box-shadow:0 0 6px rgba(221,68,68,.5)}
.sf-purple{background:var(--purple);box-shadow:0 0 6px rgba(153,102,221,.4)}
.sf-gray{background:var(--line2)}
.inbox-badge{background:var(--red);color:#fff;font-family:"DM Mono",monospace;font-size:9px;font-weight:800;padding:2px 6px;border-radius:99px;flex-shrink:0}

/* BUTTONS */
.btn{display:flex;align-items:center;justify-content:center;gap:7px;width:100%;padding:13px 16px;border-radius:var(--rs);font-family:"Barlow Condensed",sans-serif;font-size:15px;font-weight:800;letter-spacing:2px;text-transform:uppercase;cursor:pointer;border:none;transition:all .18s cubic-bezier(.32,1,.36,1)}
.btn:active{transform:scale(.95)}
.btn-gold{background:linear-gradient(135deg,var(--gold2),var(--gold3));color:#080808;box-shadow:0 3px 14px rgba(212,146,14,.25)}
.btn-out{background:transparent;border:1px solid var(--gold-brd);color:var(--gold)}.btn-out:active{background:var(--gold-bg)}
.btn-ghost{background:var(--bg3);border:1px solid var(--line);color:var(--txt2)}
.btn-danger{background:var(--red-bg);border:1px solid var(--red-brd);color:var(--red)}
.btn-green{background:var(--green-bg);border:1px solid var(--green-brd);color:var(--green)}
.btn-blue{background:var(--blue-bg);border:1px solid var(--blue-brd);color:var(--blue)}
.btn-amber{background:var(--amber-bg);border:1px solid var(--amber-brd);color:var(--amber)}
.btn-sm{padding:8px 13px;font-size:13px;width:auto;letter-spacing:1.5px}
.btn-xs{padding:6px 10px;font-size:11px;width:auto;letter-spacing:1px}

/* FIELDS */
.field{margin-bottom:12px}.field:last-child{margin-bottom:0}
.flbl{font-size:10px;font-weight:700;letter-spacing:2px;text-transform:uppercase;color:var(--muted);margin-bottom:5px;display:block;font-family:"DM Mono",monospace}
.field input,.field textarea,.field select{width:100%;background:var(--bg3);border:1px solid var(--line2);border-radius:var(--rs);padding:11px 13px;color:var(--txt);font-family:"Barlow",sans-serif;font-size:14px;outline:none;transition:border-color .15s,box-shadow .15s;-webkit-appearance:none}
.field input:focus,.field textarea:focus,.field select:focus{border-color:var(--gold);box-shadow:0 0 0 3px rgba(212,146,14,.1)}
.field textarea{resize:vertical;min-height:80px;line-height:1.6}
.field input::placeholder,.field textarea::placeholder{color:var(--muted);opacity:.6}
.field-hint{font-size:11px;color:var(--muted);margin-top:5px;line-height:1.5}
/* ══ PROFILE MODAL — LOGROS COMPACTOS ══ */
.mp-ach-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px}
.mp-ach-title{font-family:"Barlow Condensed",sans-serif;font-size:13px;font-weight:800;letter-spacing:2px;text-transform:uppercase;display:flex;align-items:center;gap:6px;color:var(--txt)}
.mp-ach-meta{display:flex;align-items:center;gap:8px}

.mp-ach-ver{font-family:"DM Mono",monospace;font-size:9px;color:var(--blue);letter-spacing:.5px;background:none;border:none;cursor:pointer;padding:0;text-transform:uppercase;font-weight:700}
.mp-ach-masterbar{height:3px;background:var(--line);border-radius:99px;margin-bottom:12px;overflow:hidden}
.mp-ach-masterbar-fill{height:100%;background:linear-gradient(90deg,var(--gold2),var(--gold3));border-radius:99px;width:0%;transition:width .7s cubic-bezier(.32,1,.36,1)}














/* ══ FORM SECTIONS (new patient + ficha) ══ */
.form-section{display:flex;align-items:center;gap:9px;margin:18px 0 12px;padding-bottom:9px;border-bottom:1px solid var(--line)}
.form-section:first-child{margin-top:6px}
.form-section-ic{width:28px;height:28px;border-radius:8px;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.form-section-ic.gold{background:var(--gold-bg);border:1px solid var(--gold-brd)}
.form-section-ic.teal{background:rgba(46,171,101,.1);border:1px solid rgba(46,171,101,.25)}
.form-section-ic.blue{background:var(--blue-bg);border:1px solid var(--blue-brd)}
.form-section-ic.red{background:var(--red-bg);border:1px solid var(--red-brd)}
.form-section-title{font-family:"Barlow Condensed",sans-serif;font-size:13px;font-weight:800;letter-spacing:2.5px;text-transform:uppercase;color:var(--txt)}
.form-section-sub{font-size:10px;color:var(--muted);font-family:"DM Mono",monospace;margin-top:1px}

/* FORM AVATAR PREVIEW */
.form-av-preview{display:flex;align-items:center;gap:14px;background:var(--gold-bg);border:1px solid var(--gold-brd);border-radius:var(--r);padding:12px 14px;margin-bottom:16px}
.form-av-circle{width:48px;height:48px;border-radius:50%;background:linear-gradient(135deg,var(--gold2),var(--gold3));display:flex;align-items:center;justify-content:center;font-family:"Barlow Condensed",sans-serif;font-size:18px;font-weight:900;color:#0a0a0b;flex-shrink:0;letter-spacing:1px;transition:all .2s}
.form-av-info{flex:1;min-width:0}
.form-av-name{font-family:"Barlow Condensed",sans-serif;font-size:15px;font-weight:800;letter-spacing:1px;color:var(--txt);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.form-av-user{font-family:"DM Mono",monospace;font-size:10px;color:var(--gold);margin-top:2px;opacity:.75}

/* FIELD WITH UNIT SUFFIX */
.field-unit{position:relative}
.field-unit input{padding-right:42px}
.field-unit-label{position:absolute;right:12px;top:50%;transform:translateY(-50%);font-family:"DM Mono",monospace;font-size:10px;color:var(--muted);letter-spacing:1px;pointer-events:none;margin-top:10px}

/* EDAD BADGE */
.edad-badge{padding:10px 13px;background:var(--bg3);border:1px solid var(--line2);border-radius:var(--rs);min-height:46px;display:flex;align-items:center;gap:8px;transition:border-color .2s}
.edad-badge.has-val{border-color:var(--gold-brd);background:var(--gold-bg)}
.edad-badge-val{font-family:"Barlow Condensed",sans-serif;font-size:22px;font-weight:900;color:var(--gold);line-height:1}
.edad-badge-unit{font-family:"DM Mono",monospace;font-size:9px;color:var(--muted);letter-spacing:1.5px;text-transform:uppercase;line-height:1.3}

/* GOAL SELECT WRAPPER */
.goal-select-wrap{position:relative}
.goal-select-wrap select{padding-right:34px}
.goal-select-wrap::after{content:"";position:absolute;right:12px;top:50%;transform:translateY(-50%);width:0;height:0;border-left:4px solid transparent;border-right:4px solid transparent;border-top:5px solid var(--muted);pointer-events:none;margin-top:8px}
.goal-chip{display:inline-flex;align-items:center;gap:5px;font-size:10px;font-weight:700;letter-spacing:.5px;padding:3px 9px;border-radius:99px;text-transform:uppercase;font-family:"DM Mono",monospace;margin-top:6px}
.goal-chip.rec{background:rgba(212,146,14,.12);color:var(--gold);border:1px solid var(--gold-brd)}
.goal-chip.cut{background:var(--red-bg);color:var(--red);border:1px solid var(--red-brd)}
.goal-chip.vol{background:var(--green-bg);color:var(--green);border:1px solid var(--green-brd)}
.goal-chip.dep{background:var(--blue-bg);color:var(--blue);border:1px solid var(--blue-brd)}
.goal-chip.sal{background:var(--purple-bg);color:var(--purple);border:1px solid var(--purple-brd)}

/* CLINICAL TEXTAREA FIELDS */
.field-clinical textarea{min-height:62px;font-size:13px}

/* FORM PROGRESS BAR */
.form-progress{height:3px;background:var(--line);border-radius:99px;margin-bottom:16px;overflow:hidden}
.form-progress-fill{height:100%;background:linear-gradient(90deg,var(--gold2),var(--gold3));border-radius:99px;width:0%;transition:width .4s cubic-bezier(.32,1,.36,1)}


/* BADGES / PILLS */
.badge{display:inline-flex;align-items:center;font-size:9px;font-weight:800;letter-spacing:.5px;padding:3px 8px;border-radius:7px;white-space:nowrap;text-transform:uppercase;font-family:"DM Mono",monospace}
.b-gold{background:var(--gold-bg);color:var(--gold);border:1px solid var(--gold-brd)}
.b-green{background:var(--green-bg);color:var(--green);border:1px solid var(--green-brd)}
.b-red{background:var(--red-bg);color:var(--red);border:1px solid var(--red-brd)}
.b-blue{background:var(--blue-bg);color:var(--blue);border:1px solid var(--blue-brd)}
.b-amber{background:var(--amber-bg);color:var(--amber);border:1px solid var(--amber-brd)}
.b-purple{background:var(--purple-bg);color:var(--purple);border:1px solid var(--purple-brd)}
.sp{display:inline-flex;align-items:center;gap:5px;padding:3px 9px;border-radius:99px;font-size:10px;font-weight:700;letter-spacing:.3px;text-transform:uppercase;font-family:"DM Mono",monospace}
.sp-dot{width:5px;height:5px;border-radius:50%;background:currentColor}
.sp-on{background:var(--green-bg);color:var(--green);border:1px solid var(--green-brd)}
.sp-off{background:var(--red-bg);color:var(--red);border:1px solid var(--red-brd)}
.sp-trial{background:var(--amber-bg);color:var(--amber);border:1px solid var(--amber-brd)}

/* UPLOAD ZONE */
.upzone{border:2px dashed var(--gold-brd);border-radius:var(--r);padding:20px 16px;text-align:center;cursor:pointer;transition:all .15s;background:var(--gold-bg)}
.upzone:active{border-color:var(--gold);background:rgba(212,146,14,.12)}

/* PHOTO VIEWER OVERLAY */
#pv-over{position:fixed;inset:0;z-index:400;background:rgba(0,0,0,.96);display:none;flex-direction:column;align-items:center;justify-content:center}
#pv-over.open{display:flex}
#pv-img{max-width:100%;max-height:calc(100vh - 70px);object-fit:contain;border-radius:8px}
#pv-close{position:absolute;top:calc(14px + var(--safe-t));right:14px;width:40px;height:40px;background:rgba(255,255,255,.1);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:20px;cursor:pointer}
#pv-lbl{position:absolute;bottom:calc(16px + var(--safe-b));font-family:"DM Mono",monospace;font-size:11px;letter-spacing:2px;text-transform:uppercase;color:rgba(255,255,255,.45)}

/* PIN */
#pin-screen{
  position:fixed;inset:0;z-index:1500;
  background:
    radial-gradient(ellipse at 50% 20%, rgba(212,146,14,.07) 0%, transparent 45%),
    linear-gradient(180deg,#060d14,#04090f);
  display:none;flex-direction:column;align-items:center;justify-content:center;padding:40px 22px
}
#pin-screen.open{display:flex}
#pin-logo{width:80px;height:auto;margin-bottom:8px;filter:drop-shadow(0 0 22px rgba(212,146,14,.35))}
.pin-brand-slogan{font-family:"DM Mono",monospace;font-size:8px;letter-spacing:2.5px;text-transform:uppercase;color:rgba(212,146,14,.5);margin-bottom:22px}
.pin-dots{display:flex;gap:14px;margin-bottom:28px}
.pd{width:14px;height:14px;border-radius:50%;border:1.5px solid rgba(255,255,255,.1);background:rgba(255,255,255,.025);transition:all .18s cubic-bezier(.32,1,.36,1)}
.pd.fill{background:var(--gold);border-color:var(--gold);box-shadow:0 0 10px rgba(212,146,14,.5),0 0 20px rgba(212,146,14,.2)}
.pd.err{background:var(--red);border-color:var(--red);box-shadow:0 0 8px rgba(221,68,68,.5)}
.pin-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;width:100%;max-width:280px}
.pk{
  height:70px;
  background:rgba(255,255,255,.04);
  border:1px solid rgba(255,255,255,.07);
  border-radius:16px;
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  cursor:pointer;transition:all .14s cubic-bezier(.32,1,.36,1);
  -webkit-tap-highlight-color:transparent;
  box-shadow:inset 0 1px 0 rgba(255,255,255,.04),0 2px 8px rgba(0,0,0,.2)
}
.pk:active{transform:scale(.89);background:rgba(212,146,14,.1);border-color:rgba(212,146,14,.25);box-shadow:0 0 0 3px rgba(212,146,14,.08)}
.pk-n{font-family:"Barlow Condensed",sans-serif;font-size:28px;font-weight:900;line-height:1;color:#eceef2}
.pk-l{font-size:8.5px;color:rgba(82,87,106,.7);letter-spacing:2px;margin-top:1px;font-family:"DM Mono",monospace}

/* MODALS */
.mover{position:fixed;inset:0;z-index:200;background:rgba(0,0,0,.75);backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);display:flex;align-items:flex-end;opacity:0;pointer-events:none;transition:opacity .22s}
.mover.open{opacity:1;pointer-events:all}
.msheet{width:100%;background:var(--bg2);border-radius:22px 22px 0 0;border-top:1.5px solid var(--gold-brd);padding:18px 16px calc(20px + var(--safe-b));transform:translateY(100%);transition:transform .35s cubic-bezier(.32,1,.36,1);max-height:92vh;overflow-y:auto}
.mover.open .msheet{transform:translateY(0)}
.mhandle{width:36px;height:4px;background:var(--line2);border-radius:99px;margin:0 auto 16px}
.mtitle{font-family:"Barlow Condensed",sans-serif;font-size:20px;font-weight:900;letter-spacing:2px;text-transform:uppercase;margin-bottom:3px}
.msub{font-size:12px;color:var(--muted);margin-bottom:16px;line-height:1.6}

/* PAY CARD */
.pay-c{
  border-radius:16px;padding:14px 15px;margin-bottom:10px;
  position:relative;overflow:hidden;
  box-shadow:0 2px 16px rgba(0,0,0,.25)
}
.pay-c::before{
  content:"";position:absolute;top:0;left:0;right:0;height:1px;
  background:linear-gradient(90deg,transparent,currentColor,transparent);
  opacity:.3;pointer-events:none
}
.pay-c.on{
  background:linear-gradient(145deg,rgba(46,171,101,.12),rgba(46,171,101,.03));
  border:1px solid rgba(46,171,101,.25);color:var(--green)
}
.pay-c.off{
  background:linear-gradient(145deg,rgba(221,68,68,.12),rgba(221,68,68,.03));
  border:1px solid rgba(221,68,68,.25);color:var(--red)
}
.pay-c.trial{
  background:linear-gradient(145deg,rgba(232,150,12,.12),rgba(232,150,12,.03));
  border:1px solid rgba(232,150,12,.25);color:var(--amber)
}
/* membership inner layout */
.pay-inner{display:flex;align-items:center;gap:12px}
.pay-dot-wrap{width:36px;height:36px;border-radius:11px;background:rgba(0,0,0,.2);border:1px solid currentColor;opacity:.8;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.pay-dot-wrap .iq-ic{width:17px;height:17px}
.pay-body{flex:1;min-width:0}
.pay-title{font-family:"Barlow Condensed",sans-serif;font-size:14px;font-weight:800;letter-spacing:1.5px;text-transform:uppercase;color:var(--txt);line-height:1.2}
.pay-sub{font-family:"DM Mono",monospace;font-size:10px;color:var(--muted);margin-top:3px;letter-spacing:.5px}
.pay-badge{font-family:"DM Mono",monospace;font-size:9px;font-weight:700;letter-spacing:1px;padding:3px 8px;border-radius:6px;white-space:nowrap;text-transform:uppercase;border:1px solid currentColor;opacity:.85;flex-shrink:0}
/* expiry progress bar (shown on .on and .trial) */
.pay-exp-bar{margin-top:10px;height:3px;background:rgba(255,255,255,.08);border-radius:99px;overflow:hidden}
.pay-exp-fill{height:100%;border-radius:99px;background:currentColor;opacity:.6;transition:width 1s cubic-bezier(.22,1,.36,1)}

/* INFO ROWS */
.info-row{display:flex;gap:8px;padding:9px 0;border-bottom:1px solid var(--line)}
.info-row:last-child{border-bottom:none;padding-bottom:0}
.info-k{font-family:"DM Mono",monospace;font-size:10px;color:var(--muted);letter-spacing:1px;text-transform:uppercase;min-width:100px;flex-shrink:0;padding-top:1px}
.info-v{font-size:13px;color:var(--txt);font-weight:600;line-height:1.4}
/* ficha 2-col compact grid */
.ficha-grid{display:grid;grid-template-columns:1fr 1fr;gap:1px;background:var(--line)}
.ficha-grid>.ficha-cell{background:var(--bg2);padding:8px 10px;min-width:0}
.ficha-cell-k{font-family:"DM Mono",monospace;font-size:8.5px;color:var(--muted);letter-spacing:1px;text-transform:uppercase;margin-bottom:3px}
.ficha-cell-v{font-size:13px;color:var(--txt);font-weight:600;line-height:1.35;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.ficha-cell.wide{grid-column:1/-1}
.ficha-cell.wide .ficha-cell-v{white-space:normal}

/* VER HISTORY */
.ver-item{display:flex;align-items:center;gap:11px;background:var(--bg3);border:1px solid var(--line);border-radius:var(--rs);padding:11px 13px;margin-bottom:7px}

/* BODY COMPOSITION CARDS */
.bc-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin-bottom:10px}
.bc-card{
  background:var(--bg3);border:1px solid var(--line);border-radius:var(--rs);
  padding:12px 10px 10px;text-align:center;position:relative;overflow:hidden;
  transition:border-color .3s,background .3s
}
.bc-card::before{
  content:"";position:absolute;inset:0;border-radius:inherit;
  background:radial-gradient(ellipse at 50% 0%,rgba(212,146,14,.06),transparent 70%);
  pointer-events:none;transition:opacity .4s
}
.bc-card.bc-green{--bc-glow:rgba(46,171,101,.09);border-color:var(--green-brd)}
.bc-card.bc-amber{--bc-glow:rgba(232,150,12,.1);border-color:var(--amber-brd)}
.bc-card.bc-red  {--bc-glow:rgba(221,68,68,.09);border-color:var(--red-brd)}
.bc-card.bc-blue {--bc-glow:rgba(85,119,238,.09);border-color:var(--blue-brd)}
.bc-card.bc-gold {--bc-glow:rgba(212,146,14,.08);border-color:var(--gold-brd)}
/* Mini-ring */
.bc-ring-wrap{position:absolute;top:7px;right:7px;opacity:.55}
.bc-ring-wrap svg{display:block}
.bc-ring-track{fill:none;stroke:rgba(255,255,255,.06);stroke-width:2.5}
.bc-ring-fill{fill:none;stroke-width:2.5;stroke-linecap:round;transition:stroke-dashoffset 1s cubic-bezier(.22,1,.36,1)}
.bc-card.bc-green .bc-ring-fill{stroke:var(--green)}
.bc-card.bc-amber .bc-ring-fill{stroke:var(--amber)}
.bc-card.bc-red   .bc-ring-fill{stroke:var(--red)}
.bc-card.bc-blue  .bc-ring-fill{stroke:var(--blue)}
.bc-card.bc-gold  .bc-ring-fill{stroke:var(--gold)}
.bc-val{
  font-family:"Barlow Condensed",sans-serif;font-size:28px;font-weight:900;
  line-height:1;color:var(--gold);
  transition:color .4s
}
.bc-card.bc-green .bc-val{color:var(--green)}
.bc-card.bc-amber .bc-val{color:var(--amber)}
.bc-card.bc-red   .bc-val{color:var(--red)}
.bc-card.bc-blue  .bc-val{color:var(--blue)}
.bc-unit{font-size:9px;color:var(--muted);margin-top:2px;letter-spacing:.5px;text-transform:uppercase;font-family:"DM Mono",monospace}
.bc-label{font-size:10px;font-weight:700;color:var(--txt2);margin-top:5px}
.bc-tag{
  display:inline-block;margin-top:5px;
  font-family:"DM Mono",monospace;font-size:7.5px;letter-spacing:1px;text-transform:uppercase;
  padding:2px 6px;border-radius:5px;
  background:rgba(255,255,255,.04);color:var(--muted);border:1px solid var(--line)
}
.bc-card.bc-green .bc-tag{background:var(--green-bg);color:var(--green);border-color:var(--green-brd)}
.bc-card.bc-amber .bc-tag{background:var(--amber-bg);color:var(--amber);border-color:var(--amber-brd)}
.bc-card.bc-red   .bc-tag{background:var(--red-bg);color:var(--red);border-color:var(--red-brd)}
.bc-card.bc-blue  .bc-tag{background:var(--blue-bg);color:var(--blue);border-color:var(--blue-brd)}
.bc-card.bc-gold  .bc-tag{background:var(--gold-bg);color:var(--gold);border-color:var(--gold-brd)}
.bc-empty{font-family:"DM Mono",monospace;font-size:8px;letter-spacing:1px;text-transform:uppercase;color:var(--muted);padding:4px 0}
/* Animated flash when values update */
@keyframes bc-flash{0%{opacity:.4;transform:scale(.96)}100%{opacity:1;transform:scale(1)}}
.bc-card.bc-updated{animation:bc-flash .45s cubic-bezier(.22,1,.36,1)}
/* Update timestamp */
.bc-updated-ts{font-family:"DM Mono",monospace;font-size:8.5px;letter-spacing:1.5px;text-transform:uppercase;color:var(--muted);margin-top:6px;text-align:right;padding-right:2px}

/* ── MACROS REFERENCE CARD ── */
.macros-card{
  background:linear-gradient(145deg,rgba(212,146,14,.1),rgba(212,146,14,.025));
  border:1px solid rgba(212,146,14,.2);
  border-radius:16px;padding:15px 14px;margin-bottom:10px;
  box-shadow:0 2px 16px rgba(0,0,0,.2),inset 0 1px 0 rgba(212,146,14,.1);
  position:relative;overflow:hidden
}
.macros-card::before{
  content:"";position:absolute;top:0;left:0;right:0;height:1px;
  background:linear-gradient(90deg,transparent,rgba(212,146,14,.35),transparent)
}
.macros-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}
.macros-kcal{font-family:"Barlow Condensed",sans-serif;font-size:38px;font-weight:900;line-height:1;color:var(--gold)}
.macros-kcal-unit{font-family:"DM Mono",monospace;font-size:9px;letter-spacing:1.5px;color:var(--muted);text-transform:uppercase;margin-top:2px}
.macros-nota{font-family:"DM Mono",monospace;font-size:9px;letter-spacing:1.5px;text-transform:uppercase;color:rgba(212,146,14,.55);padding:3px 8px;border:1px solid var(--gold-brd);border-radius:6px}
.macros-bars{display:grid;gap:7px}
.macro-row{display:flex;align-items:center;gap:10px}
.macro-label{font-family:"DM Mono",monospace;font-size:9px;letter-spacing:1px;text-transform:uppercase;width:28px;flex-shrink:0}
.macro-label.prot{color:var(--blue)}
.macro-label.carb{color:var(--amber)}
.macro-label.fat{color:var(--green)}
.macro-bar-fill{height:100%;border-radius:99px;transition:width 1s cubic-bezier(.22,1,.36,1)}
.macro-bar-fill.prot{background:linear-gradient(90deg,#3a55cc,var(--blue));box-shadow:0 0 6px rgba(85,119,238,.4)}
.macro-bar-fill.carb{background:linear-gradient(90deg,#b06a08,var(--amber));box-shadow:0 0 6px rgba(232,150,12,.4)}
.macro-bar-fill.fat{background:linear-gradient(90deg,#1e8048,var(--green));box-shadow:0 0 6px rgba(46,171,101,.4)}
.macro-bar-track{flex:1;height:7px;background:rgba(255,255,255,.05);border-radius:99px;overflow:hidden;border:1px solid rgba(255,255,255,.04)}
.macro-pct{font-family:"DM Mono",monospace;font-size:9px;color:var(--muted);min-width:28px;text-align:right}
.macro-val{font-family:"Barlow Condensed",sans-serif;font-size:16px;font-weight:900;min-width:38px;text-align:right}
.macro-val.prot{color:var(--blue)}.macro-val.carb{color:var(--amber)}.macro-val.fat{color:var(--green)}
.macros-footer{font-family:"DM Mono",monospace;font-size:8px;letter-spacing:1.5px;text-transform:uppercase;color:var(--muted);margin-top:10px;text-align:center}


/* ── WEEKLY SUMMARY CARD ── */
.week-sum{
  background:linear-gradient(145deg,rgba(17,18,26,.98),rgba(14,15,20,.98));
  border:1px solid rgba(42,45,56,.85);border-radius:18px;
  padding:15px;margin-bottom:10px;position:relative;overflow:hidden;
  box-shadow:0 4px 24px rgba(0,0,0,.3)
}
.week-sum::before{
  content:"";position:absolute;top:0;left:0;right:0;height:1px;
  background:linear-gradient(90deg,transparent,rgba(255,255,255,.1),transparent)
}
.week-sum-hd{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}
.week-sum-title{font-family:"Barlow Condensed",sans-serif;font-size:13px;font-weight:800;
  letter-spacing:2px;text-transform:uppercase;color:var(--txt2)}
.week-sum-badge{font-family:"DM Mono",monospace;font-size:8px;letter-spacing:1.5px;
  text-transform:uppercase;padding:3px 8px;border-radius:6px;border:1px solid var(--line);
  color:var(--muted)}
.week-sum-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin-bottom:12px}
.wsg-item{text-align:center;background:rgba(255,255,255,.03);border-radius:10px;padding:8px 4px;
  border:1px solid rgba(255,255,255,.04)}
.wsg-val{font-family:"Barlow Condensed",sans-serif;font-size:22px;font-weight:900;line-height:1.1}
.wsg-lbl{font-family:"DM Mono",monospace;font-size:8px;letter-spacing:1px;
  text-transform:uppercase;color:var(--muted);margin-top:2px}
.week-sum-msg{background:rgba(255,255,255,.03);border-radius:10px;padding:10px 12px;
  border:1px solid rgba(255,255,255,.04);display:flex;align-items:center;gap:10px}
.week-sum-emoji{font-size:20px;line-height:1;flex-shrink:0}
.week-sum-txt{flex:1;font-size:12px;color:var(--txt2);line-height:1.6}

/* ── NAV CARD LIVE DATA ── */
.hnc-live{display:flex;flex-direction:column;align-items:flex-end;gap:3px;flex-shrink:0;margin-right:2px}
.hnc-live-val{font-family:"Barlow Condensed",sans-serif;font-size:18px;font-weight:900;line-height:1}
.hnc-live-lbl{font-family:"DM Mono",monospace;font-size:8px;letter-spacing:1px;
  text-transform:uppercase;color:var(--muted)}
.hnc-live-pill{font-family:"DM Mono",monospace;font-size:8px;font-weight:700;letter-spacing:1px;
  padding:2px 7px;border-radius:6px;text-transform:uppercase;border:1px solid currentColor;opacity:.8}

/* ── TIMELINE ── */
.timeline{padding:0 0 4px}
.tl-item{display:flex;gap:12px;margin-bottom:0;position:relative}
.tl-left{display:flex;flex-direction:column;align-items:center;flex-shrink:0;width:32px}
.tl-dot{width:28px;height:28px;border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0;z-index:1}
.tl-dot .iq-ic{width:13px;height:13px}
.tl-dot.tl-gold{background:var(--gold-bg);border:1.5px solid var(--gold-brd)}
.tl-dot.tl-green{background:var(--green-bg);border:1.5px solid var(--green-brd)}
.tl-dot.tl-blue{background:var(--blue-bg);border:1.5px solid var(--blue-brd)}
.tl-dot.tl-purple{background:var(--purple-bg);border:1.5px solid var(--purple-brd)}
.tl-dot.tl-amber{background:var(--amber-bg);border:1.5px solid var(--amber-brd)}
.tl-dot.tl-red{background:var(--red-bg);border:1.5px solid rgba(221,68,68,.4)}
.tl-body{flex:1;padding-bottom:16px;min-width:0}
.tl-title{font-size:12px;font-weight:700;color:var(--txt);line-height:1.3}
.tl-meta{font-family:"DM Mono",monospace;font-size:9px;color:var(--muted);margin-top:2px;letter-spacing:.3px}
.tl-connector{width:1px;flex:1;background:var(--line);min-height:8px;margin-top:2px}
.tl-item:last-child .tl-connector{display:none}
.tl-show-all{display:block;width:100%;padding:8px;text-align:center;font-family:"DM Mono",monospace;font-size:9px;color:var(--gold);letter-spacing:.5px;background:transparent;border:none;cursor:pointer;border-top:1px solid var(--line);margin-top:4px}
.tl-line{flex:1;width:1px;background:linear-gradient(var(--line),transparent);min-height:12px}
.tl-content{flex:1;padding-bottom:16px;min-width:0}
.tl-date{font-family:"DM Mono",monospace;font-size:8.5px;color:var(--muted);letter-spacing:.5px;margin-bottom:2px}
.tl-title{font-size:12px;font-weight:600;color:var(--txt);line-height:1.35}
.tl-sub{font-size:11px;color:var(--muted);margin-top:1px;line-height:1.4}
.tl-empty{font-family:"DM Mono",monospace;font-size:10px;color:var(--muted);text-align:center;padding:16px 0;letter-spacing:.5px}
.adm-tl-wrap{max-height:400px;overflow-y:auto;padding-right:2px}
.adm-tl-wrap::-webkit-scrollbar{width:2px}
.adm-tl-wrap::-webkit-scrollbar-thumb{background:rgba(212,146,14,.2);border-radius:99px}
.tl-right{flex:1;padding-bottom:18px}
.tl-title{font-size:13px;font-weight:700;color:var(--txt);line-height:1.3}
.tl-date{font-family:"DM Mono",monospace;font-size:9px;letter-spacing:1.5px;text-transform:uppercase;color:var(--muted);margin-top:3px}
.tl-sub{font-size:11px;color:var(--txt2);margin-top:3px}

/* ── SCHEDULED NOTIFS ── */
.sched-item{display:flex;align-items:center;gap:9px;background:var(--bg3);border:1px solid var(--line);border-radius:var(--rs);padding:9px 11px;margin-bottom:6px}
.sched-item.delivered{opacity:.45}
.sched-date{font-family:"DM Mono",monospace;font-size:10px;letter-spacing:1px;color:var(--gold);min-width:52px}
.sched-msg{flex:1;font-size:12px;color:var(--txt2);line-height:1.4}
.sched-del{font-family:"DM Mono",monospace;font-size:8px;letter-spacing:1px;color:var(--muted);text-transform:uppercase;cursor:pointer;padding:3px 6px;border:1px solid var(--line);border-radius:5px}

/* ── BIOMETRIC BTN ── */
#bio-btn{
  width:100%;margin-top:8px;padding:13px;
  border:1px solid rgba(85,119,238,.25);border-radius:14px;cursor:pointer;
  background:linear-gradient(145deg,rgba(85,119,238,.1),rgba(85,119,238,.04));
  font-family:"Barlow Condensed",sans-serif;
  font-size:14px;font-weight:800;letter-spacing:2px;text-transform:uppercase;
  color:var(--blue);
  display:none;align-items:center;justify-content:center;gap:8px;
  transition:all .18s cubic-bezier(.32,1,.36,1);
  box-shadow:0 2px 12px rgba(85,119,238,.1)
}
#bio-btn:active{transform:scale(.96);background:rgba(85,119,238,.15)}
#bio-btn .iq-ic{width:18px;height:18px}

/* ── ONBOARDING ── */
.onb-slide{
  display:none;flex-direction:column;align-items:center;text-align:center;
  padding:0 8px;animation:fu .35s ease both;position:absolute;width:100%
}
.onb-slide.active{display:flex;position:relative}
.onb-slide-icon{
  width:88px;height:88px;border-radius:26px;border:1.5px solid;
  display:flex;align-items:center;justify-content:center;margin-bottom:24px;
  box-shadow:0 8px 24px rgba(0,0,0,.3),inset 0 1px 0 rgba(255,255,255,.06)
}
.onb-slide-title{
  font-family:"Barlow Condensed",sans-serif;font-size:24px;font-weight:900;
  letter-spacing:.5px;color:var(--txt);margin-bottom:10px;line-height:1.2
}
.onb-slide-sub{
  font-size:13px;color:var(--txt2);line-height:1.7;max-width:290px
}
.onb-dot{
  width:6px;height:6px;border-radius:50%;background:rgba(255,255,255,.15);
  transition:all .28s cubic-bezier(.32,1,.36,1)
}
.onb-dot.active{
  width:22px;border-radius:3px;background:var(--gold);
  box-shadow:0 0 8px rgba(212,146,14,.4)
}

/* confetti particle */
@keyframes confetti-fall{0%{transform:translateY(-20px) rotate(0deg);opacity:1}100%{transform:translateY(80px) rotate(360deg);opacity:0}}
.confetti-p{position:fixed;width:6px;height:6px;border-radius:50%;pointer-events:none;z-index:9999;animation:confetti-fall .9s ease forwards}
.toast{position:fixed;top:calc(14px + var(--safe-t));left:12px;right:12px;z-index:500;background:rgba(20,23,30,.97);border:1px solid rgba(212,146,14,.2);border-radius:14px;padding:12px 14px;display:flex;align-items:center;gap:10px;transform:translateY(-24px) scale(.96);opacity:0;transition:all .32s cubic-bezier(.32,1,.36,1);pointer-events:none;box-shadow:0 12px 32px rgba(0,0,0,.5),inset 0 1px 0 rgba(212,146,14,.06)}
.toast.show{transform:translateY(0) scale(1);opacity:1}

/* PATIENT ROW */
.ptrow{display:flex;align-items:center;gap:11px;background:var(--bg2);border:1px solid var(--line);border-radius:var(--rs);padding:12px 13px;margin-bottom:8px;cursor:pointer;transition:all .15s}
.ptrow:active{border-color:var(--gold-brd)}

/* ADMIN HEADER */
.adm-hd{background:linear-gradient(135deg,rgba(212,146,14,.11),rgba(212,146,14,.02));border:1px solid var(--gold-brd);border-radius:var(--r);padding:18px;margin-bottom:12px;text-align:center;position:relative;overflow:hidden}
.adm-hd::before{content:"";position:absolute;top:-50px;left:50%;transform:translateX(-50%);width:200px;height:200px;background:radial-gradient(circle,rgba(212,146,14,.1),transparent 70%);pointer-events:none}
.adm-logo{height:44px;width:auto;margin-bottom:8px;filter:drop-shadow(0 2px 10px rgba(212,146,14,.3))}

/* ADMIN PATIENT TABS */
.adm-tabs{display:flex;overflow-x:auto;padding:0;background:rgba(10,10,11,.97);border-bottom:1px solid var(--line2);flex-shrink:0;scrollbar-width:none;position:sticky;top:0;z-index:8}
.adm-tabs::-webkit-scrollbar{display:none}
.adm-tab{flex:1;min-width:72px;padding:11px 6px 10px;background:none;border:none;border-bottom:2px solid transparent;color:var(--muted);font-family:"Barlow Condensed",sans-serif;font-size:12px;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;cursor:pointer;transition:color .18s,border-color .18s;white-space:nowrap;display:flex;flex-direction:column;align-items:center;gap:3px;-webkit-tap-highlight-color:transparent}
.adm-tab .at-ic{font-size:16px;line-height:1;transition:transform .22s cubic-bezier(.32,1,.36,1)}
.adm-tab.on{color:var(--gold);border-bottom-color:var(--gold)}
.adm-tab.on .at-ic{transform:translateY(-2px) scale(1.1);filter:drop-shadow(0 0 4px rgba(212,146,14,.5))}
.adm-tab-pip{display:inline-block;width:6px;height:6px;background:var(--amber);border-radius:50%;margin-left:3px;vertical-align:middle;animation:bounce-in .3s ease}
.adm-tp{display:none;padding:0}
.adm-tp.on{display:block}

/* SU BANNER */
.su-ban{background:var(--blue-bg);border:1px solid var(--blue-brd);border-radius:var(--rs);padding:9px 13px;display:none;align-items:center;gap:9px;margin-bottom:10px}
.su-ban.on{display:flex}
.su-ban-btn{font-family:"Barlow Condensed",sans-serif;font-size:12px;font-weight:800;letter-spacing:1.5px;text-transform:uppercase;color:var(--blue);background:var(--blue-bg);border:1px solid var(--blue-brd);border-radius:6px;padding:5px 10px;cursor:pointer;flex-shrink:0}
