/* ============================================================
   HIT HOUSE OHIO — Player Development demo
   Design system: matte-black + gold sports cockpit.
   Display = Fredoka, Body = Poppins.
   ============================================================ */
:root{
  --black:#0a0a0c; --surface:#15151a; --card:#1c1c22; --card-2:#202028;
  --gold:#FFB904; --gold-hi:#FFC835; --gold-dim:#8a6400;
  --white:#ffffff; --muted:#a6a6ad; --faint:#8c8c95;
  --line:#2a2a31; --line-2:#34343d;
  --green:#3fd27a; --red:#ff5a52; --amber:#FFB904; --blue:#4FA3FF;
  --t-developing:#7C7C85; --t-rising:#4FA3FF; --t-varsity:#A974FF; --t-elite:#FFB904;
  --shadow:0 8px 30px rgba(0,0,0,.45);
  --glow:0 0 28px rgba(255,185,4,.18);
  --r:18px; --r-sm:12px; --r-lg:26px;
  --maxw:520px;
  --nav-h:64px;
}
*{box-sizing:border-box;-webkit-tap-highlight-color:transparent}
html,body{margin:0;padding:0}
body{
  background:var(--black); color:var(--white);
  font-family:'Poppins',system-ui,-apple-system,sans-serif;
  font-size:15px; line-height:1.5;
  -webkit-font-smoothing:antialiased; text-rendering:optimizeLegibility;
  padding-bottom:calc(var(--nav-h) + env(safe-area-inset-bottom));
  overflow-x:hidden; scroll-padding-top:72px;
}
/* keyboard focus ring (only on keyboard nav, not mouse) */
:focus-visible{outline:2px solid var(--gold);outline-offset:2px;border-radius:8px}
:focus:not(:focus-visible){outline:none}
h1,h2,h3,h4,.fred{font-family:'Fredoka',sans-serif;font-weight:600;letter-spacing:.2px;margin:0}
button{font-family:inherit;cursor:pointer;border:none;background:none;color:inherit}
img{max-width:100%;display:block}
a{color:var(--gold);text-decoration:none}
::selection{background:var(--gold);color:#000}

/* ---------- Demo control bar ---------- */
.demobar{position:sticky;top:0;z-index:60;background:linear-gradient(180deg,#000,#0c0c10);border-bottom:1px solid var(--line)}
.demobar-in{max-width:var(--maxw);margin:0 auto;display:flex;align-items:center;gap:10px;padding:9px 14px}
.demobar-logo{height:30px;width:auto;opacity:.96}
.demobar-roles{display:flex;gap:5px;margin-left:auto;background:#000;border:1px solid var(--line);border-radius:999px;padding:3px}
.role-pill{font-size:11.5px;font-weight:600;color:var(--muted);padding:6px 11px;border-radius:999px;white-space:nowrap;transition:.18s}
.role-pill.is-active{background:var(--gold);color:#000}
.demobar-reset{font-size:11px;color:var(--faint);padding:6px 8px;border:1px solid var(--line);border-radius:999px}
.demobar-reset:active{color:var(--white)}
.demobar-note{max-width:var(--maxw);margin:0 auto;padding:0 14px 7px;font-size:10.5px;color:var(--faint);letter-spacing:.2px}

/* ---------- Layout ---------- */
.app{max-width:var(--maxw);margin:0 auto;padding:14px 14px 24px;min-height:60vh}
.view{animation:fade .35s ease}
@keyframes fade{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}
.sec-title{font-size:13px;text-transform:uppercase;letter-spacing:1.6px;color:var(--gold);font-weight:600;margin:22px 2px 11px;font-family:'Poppins'}
.sec-title:first-child{margin-top:4px}
.muted{color:var(--muted)} .faint{color:var(--faint)}
.row{display:flex;align-items:center;gap:10px}
.spacer{flex:1}
.center{text-align:center}

/* ---------- Page header ---------- */
.phead{display:flex;align-items:center;gap:12px;margin:2px 0 6px}
.phead h1{font-size:25px;font-weight:700}
.phead .sub{color:var(--muted);font-size:13px;margin-top:1px}
.kicker{font-size:11px;letter-spacing:1.5px;text-transform:uppercase;color:var(--gold);font-weight:600}

/* ---------- Buttons ---------- */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;font-weight:600;font-size:14.5px;
  padding:13px 18px;border-radius:14px;background:var(--card-2);color:var(--white);border:1px solid var(--line-2);transition:.15s;min-height:46px}
.btn:active{transform:scale(.98)}
.btn.gold{background:var(--gold);color:#000;border-color:var(--gold)}
.btn.gold:active{background:var(--gold-hi)}
.btn.ghost{background:transparent;border-color:var(--line-2);color:var(--white)}
.btn.block{width:100%}
.btn.sm{padding:8px 13px;min-height:36px;font-size:13px;border-radius:11px}
.btn:disabled{opacity:.4;pointer-events:none}

/* ---------- Cards / surfaces ---------- */
.card{background:var(--card);border:1px solid var(--line);border-radius:var(--r);padding:16px;box-shadow:var(--shadow)}
.card.flat{box-shadow:none}
.tile{background:var(--card);border:1px solid var(--line);border-radius:var(--r);padding:14px}
.list{display:flex;flex-direction:column;gap:10px}
.grid2{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.chip{display:inline-flex;align-items:center;gap:6px;font-size:12px;font-weight:600;padding:5px 10px;border-radius:999px;background:#000;border:1px solid var(--line);color:var(--muted)}
.chip.gold{background:rgba(255,185,4,.12);border-color:var(--gold-dim);color:var(--gold)}
.chip.green{background:rgba(63,210,122,.12);border-color:#1f6b40;color:var(--green)}
.pill-pos{font-family:'Fredoka';font-weight:600;font-size:12px;padding:3px 9px;border-radius:8px;background:#000;border:1px solid var(--line-2);color:var(--white)}

/* ---------- Hero / household ---------- */
.hero-band{position:relative;border-radius:var(--r-lg);overflow:hidden;margin-bottom:14px;border:1px solid var(--line)}
.hero-band img{width:100%;height:150px;object-fit:cover;object-position:center 38%;opacity:.5}
.hero-band .hb-grad{position:absolute;inset:0;background:linear-gradient(180deg,rgba(10,10,12,.2),rgba(10,10,12,.92))}
.hero-band .hb-txt{position:absolute;left:16px;right:16px;bottom:13px}
.hero-band .hb-txt .k{font-size:11px;letter-spacing:1.6px;text-transform:uppercase;color:var(--gold);font-weight:600}
.hero-band .hb-txt h2{font-size:21px;font-weight:700;margin-top:2px}

.athlete-switch{display:flex;align-items:center;gap:10px;background:var(--card);border:1px solid var(--line);border-radius:999px;padding:7px 8px 7px 7px}
.athlete-switch .av{width:38px;height:38px;border-radius:50%;background:linear-gradient(135deg,#26262e,#15151a);border:1.5px solid var(--gold);display:flex;align-items:center;justify-content:center;font-family:'Fredoka';font-weight:700;color:var(--gold);font-size:16px;flex:none}
.athlete-switch .nm{font-weight:600;font-size:14.5px;line-height:1.1}
.athlete-switch .nm small{display:block;color:var(--muted);font-weight:500;font-size:11.5px}
.athlete-switch .caret{margin-left:auto;color:var(--muted);font-size:13px;padding-right:6px}

.statline{display:flex;gap:8px;flex-wrap:wrap;margin-top:10px}
.ministat{flex:1;min-width:96px;background:var(--card);border:1px solid var(--line);border-radius:14px;padding:11px 12px}
.ministat .v{font-family:'Fredoka';font-weight:700;font-size:19px}
.ministat .l{font-size:10.5px;color:var(--muted);text-transform:uppercase;letter-spacing:.6px;margin-top:1px}
.ministat .v small{font-size:11px;color:var(--muted);font-weight:600}

/* mini player cards (household) */
.mini-cards{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.mini-card{background:linear-gradient(165deg,var(--card-2),var(--card));border:1px solid var(--line);border-radius:var(--r);padding:13px;text-align:center;position:relative;overflow:hidden}
.mini-card .mini-tier{display:inline-block;font-family:'Fredoka';font-weight:600;font-size:10px;letter-spacing:.4px;padding:3px 9px;border-radius:7px;margin-bottom:8px}
.mini-card .ovr{font-family:'Fredoka';font-weight:700;font-size:32px;line-height:1}
.mini-card .nm{font-weight:600;font-size:14px;margin-top:6px}
.mini-card .meta{font-size:11px;color:var(--muted)}
.mini-card .tierbar{height:4px;border-radius:4px;margin:9px auto 0;width:60%}

/* ---------- PLAYER CARD (hero artifact) ---------- */
.pcard{position:relative;border-radius:var(--r-lg);padding:18px 16px 16px;overflow:hidden;
  background:radial-gradient(120% 80% at 50% -10%, #24242c, #131318 60%, #0d0d11);
  border:1.5px solid var(--tier);box-shadow:0 10px 40px rgba(0,0,0,.5);}
.pcard.elite{box-shadow:0 10px 44px rgba(0,0,0,.5), var(--glow)}
.pcard::before{content:"";position:absolute;inset:0;background:linear-gradient(135deg,rgba(255,255,255,.05),transparent 40%);pointer-events:none}
.pcard-top{display:flex;align-items:flex-start;gap:14px}
.ovr-ring{position:relative;width:96px;height:96px;flex:none}
.ovr-ring svg{transform:rotate(-90deg)}
.ovr-ring .ovr-num{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center}
.ovr-ring .ovr-num b{font-family:'Fredoka';font-weight:700;font-size:34px;line-height:.9;color:#fff}
.ovr-ring .ovr-num span{font-size:9px;letter-spacing:1.5px;color:var(--muted);text-transform:uppercase}
.pcard-id{flex:1;min-width:0;padding-top:2px}
.pcard-id .nm{font-family:'Fredoka';font-weight:700;font-size:20px;line-height:1.05;padding-right:72px}
.pcard-id .jersey{color:var(--tier);font-weight:700}
.pcard-id .meta{font-size:12px;color:var(--muted);margin-top:3px;display:flex;gap:7px;flex-wrap:wrap;align-items:center}
.pcard-id .arch{display:inline-block;margin-top:8px;font-family:'Fredoka';font-size:12.5px;font-weight:600;color:var(--tier);background:rgba(255,255,255,.05);border:1px solid var(--line-2);padding:3px 10px;border-radius:8px}
.tier-frame-label{position:absolute;top:14px;right:0;max-width:128px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;background:var(--tier);color:#0a0a0c;font-family:'Fredoka';font-weight:700;font-size:11px;letter-spacing:.5px;padding:4px 12px 4px 14px;border-radius:10px 0 0 10px}
.tier-frame-label.dark{color:#fff}

.radar-wrap{margin-top:6px;display:flex;align-items:center;gap:6px}
.attr-legend{display:grid;grid-template-columns:1fr 1fr;gap:6px 14px;flex:1}
.attr-row{display:flex;align-items:center;gap:8px;cursor:pointer;padding:3px 2px;border-radius:8px}
.attr-row:active{background:rgba(255,255,255,.04)}
.attr-row .an{font-size:11.5px;color:var(--muted);flex:1;text-transform:uppercase;letter-spacing:.4px}
.attr-row .av{font-family:'Fredoka';font-weight:700;font-size:17px;width:30px;text-align:right}
.attr-row .tap{font-size:11px;color:var(--faint)}

.card-rails{display:flex;gap:8px;margin-top:14px}
.rail{flex:1;background:rgba(0,0,0,.35);border:1px solid var(--line);border-radius:14px;padding:10px 12px}
.rail .rl{font-size:10px;text-transform:uppercase;letter-spacing:.8px;color:var(--muted)}
.rail .rv{font-family:'Fredoka';font-weight:700;font-size:16px;display:flex;align-items:center;gap:6px}
.xp-track{height:6px;border-radius:6px;background:#000;margin-top:7px;overflow:hidden}
.xp-fill{height:100%;background:linear-gradient(90deg,var(--gold-dim),var(--gold));border-radius:6px}
.flame{color:var(--gold)}

.badge-shelf{display:flex;gap:8px;overflow-x:auto;padding:4px 0 2px;margin-top:12px;-webkit-overflow-scrolling:touch}
.badge-shelf::-webkit-scrollbar{display:none}
.badge{flex:none;width:74px;text-align:center}
.badge .ic{width:50px;height:50px;margin:0 auto;border-radius:14px;background:radial-gradient(circle at 50% 30%,#2a2a33,#15151a);border:1px solid var(--gold-dim);display:flex;align-items:center;justify-content:center;font-size:22px;box-shadow:inset 0 0 12px rgba(255,185,4,.15)}
.badge.locked .ic{border-color:var(--line);filter:grayscale(1);opacity:.4}
.badge .bl{font-size:9.5px;color:var(--muted);margin-top:5px;line-height:1.15}

.card-actions{display:flex;gap:9px;margin-top:14px}

/* ---------- Records / PR ---------- */
.records{display:flex;flex-direction:column;gap:8px}
.rec-item{display:flex;align-items:center;gap:11px;background:var(--card);border:1px solid var(--line);border-radius:14px;padding:11px 13px}
.rec-item .rdot{width:9px;height:9px;border-radius:50%;background:var(--gold);box-shadow:0 0 10px var(--gold)}
.rec-item .rn{font-weight:600;font-size:13.5px}
.rec-item .rv{font-family:'Fredoka';font-weight:700;font-size:18px;margin-left:auto;color:var(--gold)}
.rec-item .rd{font-size:11px;color:var(--faint)}

/* ---------- Charts ---------- */
.chart-card{background:var(--card);border:1px solid var(--line);border-radius:var(--r);padding:14px 12px 8px}
.chart-head{display:flex;align-items:baseline;gap:8px;padding:0 4px 4px}
.chart-head .cn{font-weight:600;font-size:13.5px}
.chart-head .cv{font-family:'Fredoka';font-weight:700;font-size:18px;margin-left:auto}
.chart-head .cv small{font-size:11px;font-weight:600;margin-left:3px}
.delta{font-size:11.5px;font-weight:600}
.delta.up{color:var(--green)} .delta.down{color:var(--red)} .delta.flat{color:var(--muted)}
.pgauge{height:8px;border-radius:8px;background:#000;overflow:hidden;margin-top:7px;position:relative}
.pgauge .pf{height:100%;border-radius:8px;background:linear-gradient(90deg,#2b6a44,var(--green) 70%,var(--gold))}
.gauge-tags{display:flex;justify-content:space-between;font-size:9.5px;color:var(--faint);margin-top:4px;text-transform:uppercase;letter-spacing:.5px}
.disc-tabs{display:flex;gap:6px;overflow-x:auto;margin-bottom:12px}
.disc-tabs::-webkit-scrollbar{display:none}
.disc-tab{flex:none;font-size:12.5px;font-weight:600;color:var(--muted);min-height:40px;padding:9px 15px;border-radius:999px;background:var(--card);border:1px solid var(--line)}
.disc-tab.is-active{background:var(--gold);color:#000;border-color:var(--gold)}

.since-banner{background:linear-gradient(135deg,rgba(255,185,4,.14),rgba(255,185,4,.03));border:1px solid var(--gold-dim);border-radius:var(--r);padding:14px 16px;display:flex;align-items:center;gap:12px}
.since-banner .big{font-family:'Fredoka';font-weight:700;font-size:26px;color:var(--gold);line-height:1}
.since-banner .tx{font-size:12.5px;color:#e8e2d0}

/* ---------- Booking stepper ---------- */
.stepper{display:flex;align-items:center;gap:4px;margin:4px 0 16px}
.step-dot{flex:1;height:4px;border-radius:4px;background:var(--line)}
.step-dot.done{background:var(--gold)}
.step-dot.cur{background:var(--gold-hi)}
.opt{display:flex;align-items:center;gap:12px;background:var(--card);border:1.5px solid var(--line);border-radius:var(--r);padding:14px;transition:.15s;width:100%;text-align:left}
.opt:active{transform:scale(.99)}
.opt.sel{border-color:var(--gold);background:linear-gradient(135deg,rgba(255,185,4,.08),var(--card))}
.opt .oi{width:42px;height:42px;border-radius:12px;background:#000;border:1px solid var(--line-2);display:flex;align-items:center;justify-content:center;font-size:20px;flex:none}
.opt .ot{font-weight:600;font-size:14.5px}
.opt .od{font-size:11.5px;color:var(--muted);margin-top:1px}
.opt .price{margin-left:auto;text-align:right;font-family:'Fredoka';font-weight:700;font-size:15px}
.opt .price small{display:block;font-size:10px;color:var(--muted);font-weight:500;font-family:'Poppins'}
.opt .price .was{text-decoration:line-through;color:var(--faint);font-size:11px;font-family:'Poppins';font-weight:500}

.trainer-card{display:flex;gap:12px;align-items:center;background:var(--card);border:1.5px solid var(--line);border-radius:var(--r);padding:13px;width:100%;text-align:left}
.trainer-card.sel{border-color:var(--gold)}
.trainer-card .tav{width:48px;height:48px;border-radius:50%;flex:none;background:linear-gradient(135deg,#26262e,#15151a);border:1.5px solid var(--gold-dim);display:flex;align-items:center;justify-content:center;font-family:'Fredoka';font-weight:700;color:var(--gold);font-size:17px}
.trainer-card .tn{font-weight:600;font-size:14.5px}
.trainer-card .ts{font-size:11.5px;color:var(--muted)}
.trainer-card .next{margin-left:auto;text-align:right}
.trainer-card .next .na{font-size:10px;color:var(--green);font-weight:600}
.trainer-card .next .rt{font-family:'Fredoka';font-weight:700;font-size:13px;color:var(--muted)}

.slotgrid{display:grid;grid-template-columns:repeat(3,1fr);gap:8px}
.slot{min-height:44px;display:flex;align-items:center;justify-content:center;padding:11px 6px;text-align:center;border-radius:12px;background:var(--card);border:1.5px solid var(--line);font-weight:600;font-size:13px}
.slot.sel{border-color:var(--gold);background:rgba(255,185,4,.1);color:var(--gold)}
.daypick{display:flex;gap:8px;overflow-x:auto;padding-bottom:4px}
.daypick::-webkit-scrollbar{display:none}
.day{flex:none;width:54px;text-align:center;padding:9px 0;border-radius:12px;background:var(--card);border:1.5px solid var(--line)}
.day.sel{border-color:var(--gold);background:rgba(255,185,4,.1)}
.day .dn{font-size:10px;color:var(--muted);text-transform:uppercase}
.day .dd{font-family:'Fredoka';font-weight:700;font-size:18px}

.sticky-bar{position:fixed;left:0;right:0;bottom:calc(var(--nav-h) + env(safe-area-inset-bottom));z-index:40;background:linear-gradient(180deg,transparent,var(--black) 22%);padding:14px}
.sticky-bar .in{max-width:var(--maxw);margin:0 auto;display:flex;align-items:center;gap:12px}
.sticky-bar .sum{flex:1}
.sticky-bar .sum .s1{font-size:11px;color:var(--muted)}
.sticky-bar .sum .s2{font-family:'Fredoka';font-weight:700;font-size:16px}

/* ---------- Trainer console ---------- */
.roster-row{display:flex;align-items:center;gap:12px;background:var(--card);border:1px solid var(--line);border-radius:var(--r);padding:12px 13px}
.roster-row .rav{width:44px;height:44px;border-radius:50%;flex:none;background:linear-gradient(135deg,#26262e,#15151a);border:1.5px solid var(--line-2);display:flex;align-items:center;justify-content:center;font-family:'Fredoka';font-weight:700;font-size:15px;color:var(--white)}
.roster-row .ri{flex:1;min-width:0}
.roster-row .ri .nm{font-weight:600;font-size:14.5px}
.roster-row .ri .mt{font-size:11.5px;color:var(--muted)}
.checkbtn{font-size:12px;font-weight:600;min-height:44px;padding:8px 13px;border-radius:11px;border:1px solid var(--line-2);background:#0e0e12;color:var(--muted);white-space:nowrap;transition:transform .06s ease}
.checkbtn:active{transform:scale(.96)}
.checkbtn.in{background:rgba(63,210,122,.14);border-color:#1f6b40;color:var(--green)}
.checkbtn.no{background:rgba(255,90,82,.1);border-color:#7a2b27;color:var(--red)}

.metric-sheet .ms-tabs{display:flex;gap:6px;margin-bottom:14px;overflow-x:auto}
.metric-sheet .ms-tabs::-webkit-scrollbar{display:none}
.stepper-field{display:flex;align-items:center;gap:12px;background:var(--card);border:1px solid var(--line);border-radius:14px;padding:10px 12px;margin-bottom:9px}
.stepper-field .sf-l{flex:1}
.stepper-field .sf-l .n{font-weight:600;font-size:13.5px}
.stepper-field .sf-l .u{font-size:11px;color:var(--muted)}
.stepper-field .sf-l .last{font-size:10.5px;color:var(--faint)}
.stepbtn{width:38px;height:38px;border-radius:11px;background:#000;border:1px solid var(--line-2);font-size:20px;font-weight:700;display:flex;align-items:center;justify-content:center;color:var(--gold)}
.stepper-field .val{font-family:'Fredoka';font-weight:700;font-size:21px;width:58px;text-align:center}
.stepper-field.pr{border-color:var(--gold);box-shadow:var(--glow)}
.chipset{display:flex;flex-wrap:wrap;gap:7px}
.tchip{font-size:12px;font-weight:500;min-height:40px;padding:9px 13px;border-radius:999px;background:var(--card);border:1px solid var(--line);color:var(--muted)}
.tchip.on{background:rgba(255,185,4,.13);border-color:var(--gold-dim);color:var(--gold)}

/* ---------- Owner analytics ---------- */
.kpi-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.kpi{background:var(--card);border:1px solid var(--line);border-radius:var(--r);padding:15px}
.kpi .kl{font-size:11px;text-transform:uppercase;letter-spacing:.6px;color:var(--muted)}
.kpi .kv{font-family:'Fredoka';font-weight:700;font-size:27px;margin-top:4px}
.kpi .kd{font-size:11.5px;font-weight:600;margin-top:2px}
.bars{display:flex;flex-direction:column;gap:10px;margin-top:4px}
.bar-row{display:flex;align-items:center;gap:10px}
.bar-row .bl{width:96px;font-size:12px;color:var(--muted)}
.bar-track{flex:1;height:10px;background:#000;border-radius:6px;overflow:hidden}
.bar-fill{height:100%;background:linear-gradient(90deg,var(--gold-dim),var(--gold));border-radius:6px}
.bar-row .bv{font-family:'Fredoka';font-weight:700;font-size:13px;width:40px;text-align:right}

/* ---------- Bottom nav ---------- */
.bottomnav{position:fixed;left:0;right:0;bottom:0;z-index:50;height:calc(var(--nav-h) + env(safe-area-inset-bottom));
  padding-bottom:env(safe-area-inset-bottom);background:rgba(12,12,16,.92);backdrop-filter:blur(14px);border-top:1px solid var(--line);
  display:flex;justify-content:center}
.bottomnav .in{max-width:var(--maxw);width:100%;display:flex;align-items:stretch}
.navbtn{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;color:var(--faint);font-size:10px;font-weight:600;padding-top:8px}
.navbtn .ni{font-size:20px;line-height:1}
.navbtn.is-active{color:var(--gold)}
.navbtn.is-active .ni{filter:drop-shadow(0 0 8px rgba(255,185,4,.5))}

/* ---------- Toast + modal ---------- */
.toast{position:fixed;left:50%;bottom:calc(var(--nav-h) + 24px);transform:translateX(-50%) translateY(20px);z-index:90;
  background:#000;border:1px solid var(--gold-dim);color:#fff;padding:12px 18px;border-radius:14px;font-size:13.5px;font-weight:500;
  box-shadow:var(--shadow);opacity:0;pointer-events:none;transition:.3s;max-width:90vw;text-align:center}
.toast.show{opacity:1;transform:translateX(-50%) translateY(0)}
.toast.pr{border-color:var(--gold);box-shadow:var(--glow),var(--shadow);font-family:'Fredoka';font-weight:600}

.modal-host{position:fixed;inset:0;z-index:80;display:none;align-items:flex-end;justify-content:center;background:rgba(0,0,0,.6);backdrop-filter:blur(4px)}
.modal-host.open{display:flex}
.modal{background:var(--surface);border:1px solid var(--line);border-radius:24px 24px 0 0;width:100%;max-width:var(--maxw);max-height:88vh;overflow-y:auto;padding:8px 16px calc(20px + env(safe-area-inset-bottom));animation:sheetUp .3s ease}
@keyframes sheetUp{from{transform:translateY(100%)}to{transform:none}}
.modal .grab{width:38px;height:4px;border-radius:4px;background:var(--line-2);margin:8px auto 14px}
.modal h3{font-size:19px;font-weight:700;margin-bottom:4px}

/* recruiting export sheet */
.export-card{border-radius:18px;overflow:hidden;border:1px solid var(--gold-dim);background:radial-gradient(120% 80% at 50% 0%,#22222a,#0d0d11)}
.export-card .ec-head{display:flex;align-items:center;gap:12px;padding:16px;border-bottom:1px solid var(--line)}
.export-card .ec-head img{height:42px;width:auto}
.export-card .ec-body{padding:14px 16px}
.measure{display:flex;justify-content:space-between;padding:9px 0;border-bottom:1px solid var(--line)}
.measure:last-child{border:none}
.measure .ml{font-size:12.5px;color:var(--muted)}
.measure .mv{font-family:'Fredoka';font-weight:700}
.verified{display:inline-flex;align-items:center;gap:4px;font-size:11px;color:var(--green);font-weight:600}

.empty{text-align:center;color:var(--muted);padding:30px 10px;font-size:13.5px}
.divider{height:1px;background:var(--line);margin:16px 0}
.note-quote{background:rgba(255,255,255,.03);border-left:3px solid var(--gold);padding:10px 13px;border-radius:0 12px 12px 0;font-size:13px;color:#ddd;font-style:italic}

/* level-up flash overlay */
.flash{position:fixed;inset:0;z-index:85;display:flex;align-items:center;justify-content:center;pointer-events:none}
.flash .fbox{background:rgba(0,0,0,.86);border:1.5px solid var(--gold);border-radius:24px;padding:28px 34px;text-align:center;box-shadow:var(--glow);animation:pop .5s ease}
.flash .fbox .fic{font-size:44px}
.flash .fbox .ft{font-family:'Fredoka';font-weight:700;font-size:22px;color:var(--gold);margin-top:6px}
.flash .fbox .fs{font-size:13px;color:#ddd;margin-top:2px}
@keyframes pop{0%{transform:scale(.7);opacity:0}50%{transform:scale(1.05)}100%{transform:scale(1);opacity:1}}

@media(min-width:560px){ :root{--maxw:540px} body{font-size:15px} }
/* ultra-narrow phones (iPhone SE etc.) — keep the role switcher + card meta readable on one line */
@media(max-width:380px){
  .demobar-in{gap:6px;padding:8px 10px}
  .demobar-logo{height:26px}
  .role-pill{font-size:10.5px;padding:5px 9px}
  .demobar-reset{font-size:10px;padding:5px 7px}
  .pcard-id .meta{font-size:11px;gap:5px}
  .pcard-id .nm{font-size:18px;padding-right:66px}
  .ovr-ring{width:84px;height:84px}
}
