:root{
  --ink:#14110F;
  --surface:#1F1B18;
  --surface-2:#2A2521;
  --line:rgba(245,241,236,.10);
  --line-strong:rgba(245,241,236,.18);
  --text:#F5F1EC;
  --muted:#A39A90;
  --ember:#E8643C;
  --ember-press:#cf512c;
  --teal:#36C5B0;
  --danger:#E5484D;
  --r:16px;
  --r-sm:11px;
  --tap:54px;
  --maxw:480px;
  font-synthesis:none;
}

*{box-sizing:border-box;margin:0;padding:0}
[hidden]{display:none!important}
html,body{height:100%}
body{
  background:var(--ink);
  color:var(--text);
  font-family:Inter,system-ui,-apple-system,sans-serif;
  font-size:16px;line-height:1.45;
  -webkit-font-smoothing:antialiased;
  font-feature-settings:"tnum" 1,"cv01" 1;
  overscroll-behavior-y:none;
}
.display{font-family:"Space Grotesk",Inter,sans-serif;letter-spacing:-.01em}

#app{max-width:var(--maxw);margin:0 auto;min-height:100dvh;display:flex;flex-direction:column}

/* ---------- generic ---------- */
.muted{color:var(--muted)}
.center{display:grid;place-items:center;text-align:center}
.pad{padding:24px}
.stack{display:flex;flex-direction:column;gap:14px}
.row{display:flex;align-items:center;gap:12px}
.spread{display:flex;align-items:center;justify-content:space-between;gap:12px}
.grow{flex:1}
.tnum{font-variant-numeric:tabular-nums}

/* ---------- topbar ---------- */
.topbar{
  display:flex;align-items:center;justify-content:space-between;
  padding:16px 20px;border-bottom:1px solid var(--line);
  position:sticky;top:0;background:rgba(20,17,15,.86);backdrop-filter:blur(10px);z-index:5;
}
.brand{display:flex;align-items:center;gap:10px;font-family:"Space Grotesk";font-weight:700;letter-spacing:.02em}
.brand .dot{width:9px;height:9px;border-radius:50%;background:var(--ember);box-shadow:0 0 0 4px rgba(232,100,60,.16)}
.chip{
  display:inline-flex;align-items:center;gap:7px;font-size:13px;color:var(--muted);
  background:var(--surface);border:1px solid var(--line);border-radius:999px;padding:6px 12px;
}
.role-tag{font-size:11px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--ember)}
.role-tag.client{color:var(--teal)}
.role-tag.admin{color:var(--text)}
.role-tag.superadmin{color:var(--ember);text-shadow:0 0 12px rgba(232,100,60,.45)}
/* icona nella topbar (es. "Il mio account") */
.tb-icon{flex:none;width:40px;height:40px;border-radius:10px;border:1px solid var(--line);background:transparent;color:var(--muted);font-size:17px;line-height:1;cursor:pointer;display:grid;place-items:center;transition:background .15s,color .15s,border-color .15s}
.tb-icon:active{background:var(--surface)}
.tb-icon:hover{color:var(--text);border-color:var(--line-strong)}
.tb-icon:focus-visible{outline:2px solid var(--text);outline-offset:2px}

/* ---------- switch di vista (doppio cappello: trainer ⇄ atleta) ---------- */
.viewswitch{display:inline-flex;background:var(--surface);border:1px solid var(--line);border-radius:999px;padding:3px;gap:2px}
.viewswitch button{border:none;background:transparent;color:var(--muted);font:inherit;font-family:"Space Grotesk";font-weight:600;font-size:12px;letter-spacing:.02em;padding:6px 12px;min-height:34px;border-radius:999px;cursor:pointer;transition:background .15s,color .15s}
.viewswitch button:active{transform:translateY(1px)}
.viewswitch button[data-v="trainer"].on{background:var(--ember);color:#1a0d07}
.viewswitch button[data-v="client"].on{background:var(--teal);color:#062b25}
.viewswitch button:focus-visible{outline:2px solid var(--text);outline-offset:2px}

/* ---------- auth ---------- */
.auth{flex:1;display:flex;flex-direction:column;justify-content:center;padding:32px 24px;gap:28px}
.auth-hero{text-align:left}
.auth-mark{display:flex;align-items:center;gap:12px;margin-bottom:22px}
.auth-mark img{width:44px;height:44px;border-radius:12px}
.auth-mark .name{font-family:"Space Grotesk";font-weight:700;font-size:22px;letter-spacing:.04em}
.auth h1{font-family:"Space Grotesk";font-weight:700;font-size:30px;line-height:1.1;letter-spacing:-.02em}
.auth h1 em{font-style:normal;color:var(--ember)}
.auth p.lead{color:var(--muted);margin-top:10px;max-width:34ch}

/* ---------- form ---------- */
.field{display:flex;flex-direction:column;gap:7px}
.field label{font-size:13px;color:var(--muted);font-weight:500}
.input{
  width:100%;min-height:var(--tap);
  background:var(--surface);border:1px solid var(--line-strong);border-radius:var(--r-sm);
  color:var(--text);font-size:16px;padding:0 16px;
  transition:border-color .15s,background .15s;
}
.input::placeholder{color:#6f675f}
.input:focus{outline:none;border-color:var(--ember);background:var(--surface-2)}
.input:focus-visible{outline:2px solid var(--ember);outline-offset:1px}

.btn{
  min-height:var(--tap);width:100%;
  border:none;border-radius:var(--r-sm);cursor:pointer;
  font-family:"Space Grotesk";font-weight:600;font-size:16px;letter-spacing:.01em;
  display:inline-flex;align-items:center;justify-content:center;gap:8px;
  transition:transform .06s,background .15s,opacity .15s;
}
.btn:active{transform:translateY(1px)}
.btn:focus-visible{outline:2px solid var(--text);outline-offset:2px}
.btn-primary{background:var(--ember);color:#1a0d07}
.btn-primary:active{background:var(--ember-press)}
.btn-primary:disabled{opacity:.55;cursor:default}
.btn-ghost{background:transparent;color:var(--muted);border:1px solid var(--line);min-height:46px;font-size:14px}
.btn-ghost:active{background:var(--surface)}

.switch{text-align:center;font-size:14px;color:var(--muted)}
.switch button{background:none;border:none;color:var(--ember);font:inherit;font-weight:600;cursor:pointer;padding:4px}

/* card-form riusabile (es. "Il mio account"): campi impilati + azione */
.acct-form{display:flex;flex-direction:column;gap:14px}
.acct-form .btn{margin-top:2px}

.note{font-size:13px;border-radius:var(--r-sm);padding:11px 14px;border:1px solid var(--line)}
.note.err{color:#ffd9d2;background:rgba(229,72,77,.10);border-color:rgba(229,72,77,.35)}
.note.ok{color:#cdeee6;background:rgba(54,197,176,.10);border-color:rgba(54,197,176,.32)}

/* ---------- home / cards ---------- */
.main{flex:1;padding:22px 20px 40px;display:flex;flex-direction:column;gap:20px}
.hello{font-family:"Space Grotesk";font-weight:700;font-size:24px;letter-spacing:-.01em}
.hello span{color:var(--ember)}
.sub{color:var(--muted);font-size:14px;margin-top:2px}

.stats{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.stat{
  background:var(--surface);border:1px solid var(--line);border-radius:var(--r);padding:16px 16px 14px;
}
.stat .n{font-family:"Space Grotesk";font-weight:700;font-size:30px;line-height:1}
.stat .l{color:var(--muted);font-size:12px;margin-top:6px;text-transform:uppercase;letter-spacing:.06em}
.stat.accent .n{color:var(--ember)}

.card{background:var(--surface);border:1px solid var(--line);border-radius:var(--r);padding:18px}
.card h3{font-family:"Space Grotesk";font-weight:600;font-size:16px;margin-bottom:6px}

.empty{
  border:1px dashed var(--line-strong);border-radius:var(--r);padding:28px 22px;text-align:center;color:var(--muted);
}
.empty .ico{font-size:26px;margin-bottom:10px;opacity:.7}
.empty strong{display:block;color:var(--text);font-family:"Space Grotesk";font-weight:600;margin-bottom:4px}

.teaser{
  border-left:3px solid var(--teal);background:var(--surface);border-radius:var(--r-sm);
  padding:14px 16px;font-size:14px;color:var(--muted);
}
.teaser b{color:var(--text)}

/* ---------- splash / loader ---------- */
.splash{flex:1;display:grid;place-items:center;gap:14px;text-align:center;padding:40px}
.spinner{width:30px;height:30px;border-radius:50%;border:3px solid var(--line-strong);border-top-color:var(--ember);animation:spin .8s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}

@media (prefers-reduced-motion: reduce){
  *{animation-duration:.001ms!important;transition-duration:.001ms!important}
}

/* ============ STADIO 2 — atleti + editor schede ============ */
.backbar{display:flex;align-items:center;gap:8px;padding:12px 16px;border-bottom:1px solid var(--line);position:sticky;top:0;background:rgba(20,17,15,.9);backdrop-filter:blur(10px);z-index:5}
.back{display:inline-flex;align-items:center;gap:6px;background:none;border:none;color:var(--muted);font:inherit;font-size:15px;cursor:pointer;padding:6px 8px;border-radius:8px}
.back:active{background:var(--surface)}
.backbar .ttl{font-family:"Space Grotesk";font-weight:600;font-size:16px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}

.section-h{font-family:"Space Grotesk";font-weight:600;font-size:12px;letter-spacing:.07em;text-transform:uppercase;color:var(--muted);margin:2px 2px 0}

.list{display:flex;flex-direction:column;gap:10px}
.list-item{display:flex;align-items:center;gap:13px;width:100%;text-align:left;background:var(--surface);border:1px solid var(--line);border-radius:var(--r);padding:14px 15px;color:var(--text);cursor:pointer;font:inherit;transition:border-color .15s,background .15s}
.list-item:active{background:var(--surface-2)}
.list-item:hover{border-color:var(--line-strong)}
.avatar{width:40px;height:40px;border-radius:11px;background:var(--surface-2);display:grid;place-items:center;font-family:"Space Grotesk";font-weight:700;color:var(--ember);flex:none}
.list-item .who{flex:1;min-width:0}
.list-item .who .nm{font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.list-item .who .meta{font-size:13px;color:var(--muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.list-item .chev{color:var(--muted);flex:none;font-size:20px}
.pill{font-size:11px;font-weight:600;padding:3px 9px;border-radius:999px;border:1px solid var(--line-strong);color:var(--muted);flex:none}
.pill.on{color:var(--teal);border-color:rgba(54,197,176,.4)}

.day-card{background:var(--surface);border:1px solid var(--line);border-radius:var(--r);padding:13px;display:flex;flex-direction:column;gap:11px}
.day-head{display:flex;align-items:center;gap:8px}
.day-head .input{min-height:44px;font-family:"Space Grotesk";font-weight:600}
.ex-card{background:var(--surface-2);border:1px solid var(--line);border-radius:var(--r-sm);padding:11px;display:flex;flex-direction:column;gap:9px}
.ex-top{display:flex;gap:8px;align-items:center}
.ex-top .input{min-height:44px}
.ex-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:7px}
.mini{display:flex;flex-direction:column;gap:4px}
.mini label{font-size:10.5px;color:var(--muted);letter-spacing:.03em;text-align:center;text-transform:uppercase}
.mini .input{min-height:42px;padding:0 6px;font-size:15px;text-align:center}
.reprange{display:flex;align-items:center;gap:3px}
.reprange .input{text-align:center;padding:0 2px}
.reprange span{color:var(--muted);font-size:13px}
.iconbtn{flex:none;width:42px;height:44px;border-radius:9px;border:1px solid var(--line-strong);background:transparent;color:var(--muted);font-size:19px;cursor:pointer;display:grid;place-items:center;line-height:1}
.iconbtn:active{background:var(--ink)}
.iconbtn.danger{color:var(--danger);border-color:rgba(229,72,77,.3)}
.addbtn{width:100%;min-height:46px;border:1px dashed var(--line-strong);background:transparent;color:var(--muted);border-radius:var(--r-sm);font:inherit;font-weight:600;font-size:14px;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:7px}
.addbtn:active{background:var(--surface)}
.addbtn.ember{color:var(--ember);border-color:rgba(232,100,60,.4)}

.savebar{position:sticky;bottom:0;background:linear-gradient(to top,var(--ink) 62%,rgba(20,17,15,0));padding:14px 0 20px;margin-top:4px;display:flex;gap:10px}
.savebar .btn{flex:1;width:auto}
.savebar .btn.slim{flex:none;width:auto;padding:0 18px}

.toast{position:fixed;left:50%;bottom:22px;transform:translateX(-50%);background:var(--surface-2);border:1px solid var(--line-strong);color:var(--text);padding:11px 18px;border-radius:999px;font-size:14px;font-weight:500;box-shadow:0 8px 24px rgba(0,0,0,.4);z-index:50;max-width:88%}
.toast.ok{border-color:rgba(54,197,176,.5)}
.toast.err{border-color:rgba(229,72,77,.5);color:#ffd9d2}

@media (max-width:360px){ .ex-grid{grid-template-columns:repeat(2,1fr)} }

/* ============ fix lista atleti (nome/email incolonnati) ============ */
.list-item .who{display:flex;flex-direction:column;gap:2px;overflow:hidden}
.list-item .who .nm,.list-item .who .meta{display:block;max-width:100%}

/* ============ STADIO 3 — allenamento atleta ============ */
.day-select{display:flex;flex-direction:column;gap:10px}
.daybtn{display:flex;align-items:center;justify-content:space-between;gap:12px;background:var(--surface);border:1px solid var(--line);border-radius:var(--r);padding:16px;color:var(--text);font:inherit;cursor:pointer;text-align:left;transition:border-color .15s,background .15s}
.daybtn:active{background:var(--surface-2)}
.daybtn:hover{border-color:var(--line-strong)}
.daybtn .nm{font-family:"Space Grotesk";font-weight:600;font-size:17px}
.daybtn .meta{font-size:13px;color:var(--muted);margin-top:2px}
.daybtn .go{color:var(--ember);font-weight:700;font-size:20px;flex:none}

.log-ex{background:var(--surface);border:1px solid var(--line);border-radius:var(--r);padding:15px;display:flex;flex-direction:column;gap:11px}
.log-ex .exh .nm{font-family:"Space Grotesk";font-weight:600;font-size:17px}
.log-ex .exh .tg{font-size:13px;color:var(--muted);margin-top:3px}
.log-ex .exh .note{font-size:12.5px;color:var(--muted);margin-top:2px;font-style:italic}
.log-ex .prev{font-size:12.5px;color:var(--teal);display:flex;align-items:center;gap:6px}
.set-head{display:grid;grid-template-columns:26px 1fr 1fr 48px;gap:8px;font-size:10.5px;color:var(--muted);text-transform:uppercase;letter-spacing:.04em;padding:0 2px}
.set-head span{text-align:center}
.set-row{display:grid;grid-template-columns:26px 1fr 1fr 48px;gap:8px;align-items:center}
.set-row .sn{font-family:"Space Grotesk";font-weight:700;color:var(--muted);text-align:center}
.set-row .input{min-height:46px;text-align:center;padding:0 4px}
.set-row .doneb{width:48px;height:46px;border-radius:10px;border:1px solid var(--line-strong);background:transparent;color:var(--muted);font-size:20px;cursor:pointer;display:grid;place-items:center;flex:none}
.set-row.done .doneb{background:var(--teal);border-color:var(--teal);color:#062b25}
.set-row.done .input{border-color:rgba(54,197,176,.4);color:var(--teal)}
.addset{align-self:flex-start;background:none;border:none;color:var(--muted);font:inherit;font-size:13px;font-weight:600;cursor:pointer;padding:6px 2px}
.addset:active{color:var(--text)}

.finishbar{position:sticky;bottom:0;background:linear-gradient(to top,var(--ink) 62%,rgba(20,17,15,0));padding:14px 0 20px;margin-top:4px}
.finishbar .btn{width:100%}

.resttimer{position:fixed;left:50%;bottom:18px;transform:translateX(-50%);width:min(440px,92%);background:var(--surface-2);border:1px solid var(--teal);border-radius:18px;padding:13px 15px;display:flex;align-items:center;gap:13px;box-shadow:0 12px 34px rgba(0,0,0,.55);z-index:40}
.resttimer .rt-time{font-family:"Space Grotesk";font-weight:700;font-size:29px;font-variant-numeric:tabular-nums;color:var(--teal);min-width:74px;text-align:center}
.resttimer .rt-mid{flex:1;min-width:0}
.resttimer .rt-lb{font-size:11.5px;color:var(--muted);text-transform:uppercase;letter-spacing:.05em;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.resttimer .rt-bar{height:5px;background:var(--ink);border-radius:3px;margin-top:6px;overflow:hidden}
.resttimer .rt-bar i{display:block;height:100%;width:100%;background:var(--teal);transition:width 1s linear}
.resttimer .rt-btns{display:flex;gap:6px;flex:none}
.rt-mini{border:1px solid var(--line-strong);background:transparent;color:var(--text);border-radius:9px;min-height:42px;padding:0 11px;font:inherit;font-weight:600;font-size:13px;cursor:pointer}
.rt-mini.skip{color:var(--ember);border-color:rgba(232,100,60,.4)}
.resttimer.done{border-color:var(--ember)}
.resttimer.done .rt-time{color:var(--ember)}
.resttimer.done .rt-bar i{background:var(--ember)}

/* ============ v2 — gruppi serie + timer a schermo intero ============ */
/* editor: gruppi di serie */
.grp-edit{background:var(--ink);border:1px solid var(--line);border-radius:10px;padding:10px;display:flex;flex-direction:column;gap:8px}
.grp-top{display:flex;gap:8px;align-items:center}
.grp-top .input{min-height:42px;font-size:14px}
.grp-grid{display:grid;grid-template-columns:1fr 1.5fr 1fr;gap:7px}
.ex-meta{display:grid;grid-template-columns:1fr;gap:7px}
.rec-field{display:flex;flex-direction:column;gap:4px;max-width:150px}
.rec-field label{font-size:10.5px;color:var(--muted);text-transform:uppercase;letter-spacing:.03em}
.rec-field .input{min-height:42px;text-align:center}

/* logger: etichetta gruppo */
.grp-label{font-size:12px;font-weight:700;color:var(--teal);letter-spacing:.02em;margin-top:6px;display:flex;gap:8px;align-items:baseline;flex-wrap:wrap}
.grp-label .sch{color:var(--muted);font-weight:500}
.set-head{grid-template-columns:26px 1fr 1fr 48px}
.set-row{grid-template-columns:26px 1fr 1fr 48px}
.prev.full{align-items:flex-start;line-height:1.5}

/* timer recupero a schermo intero */
.rest-overlay{position:fixed;inset:0;z-index:60;background:rgba(12,9,8,.94);backdrop-filter:blur(8px);
  display:flex;flex-direction:column;align-items:center;justify-content:center;gap:24px;padding:28px;text-align:center}
.rc{position:relative;width:236px;height:236px}
.rc svg{width:100%;height:100%;transform:rotate(-90deg)}
.rc .track{fill:none;stroke:var(--surface-2);stroke-width:12}
.rc .prog{fill:none;stroke:var(--teal);stroke-width:12;stroke-linecap:round;transition:stroke-dashoffset 1s linear}
.rc .ctr{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px}
.rc .time{font-family:"Space Grotesk";font-weight:700;font-size:54px;font-variant-numeric:tabular-nums;line-height:1}
.rc .lbl{font-size:12px;color:var(--muted);text-transform:uppercase;letter-spacing:.12em}
.rest-next{font-size:14px;color:var(--muted);max-width:32ch}
.rest-next b{color:var(--text);font-weight:600}
.rest-adds{display:flex;gap:9px}
.abtn{min-width:62px;min-height:52px;border-radius:13px;border:1px solid var(--line-strong);background:var(--surface);color:var(--text);font:inherit;font-family:"Space Grotesk";font-weight:700;font-size:15px;cursor:pointer}
.abtn:active{background:var(--surface-2)}
.skipbtn{min-height:54px;padding:0 40px;border-radius:14px;border:none;background:var(--ember);color:#1a0d07;
  font:inherit;font-family:"Space Grotesk";font-weight:700;font-size:17px;cursor:pointer}
.skipbtn:active{background:var(--ember-press)}
.rest-overlay.done .prog{stroke:var(--ember)}
.rest-overlay.done .time{color:var(--ember)}

/* ============ card "allenamento in corso" (ripresa da DB) ============ */
.resume-card{background:linear-gradient(135deg,rgba(232,100,60,.15),var(--surface));border:1px solid rgba(232,100,60,.42);border-radius:var(--r);padding:15px;display:flex;flex-direction:column;gap:13px}
.rz-top{display:flex;align-items:center;gap:12px}
.rz-dot{width:11px;height:11px;border-radius:50%;background:var(--ember);box-shadow:0 0 0 4px rgba(232,100,60,.18);flex:none;animation:rzpulse 1.6s infinite}
@keyframes rzpulse{0%,100%{opacity:1}50%{opacity:.35}}
.rz-h{font-family:"Space Grotesk";font-weight:700;font-size:16px}
.rz-m{font-size:13px;color:var(--muted);margin-top:2px}
.rz-btns{display:flex;gap:10px}
.rz-btns .btn{flex:1;width:auto}
.rz-btns .btn.slim{flex:none;padding:0 20px}

/* fix: nome giorno e conteggio incolonnati nel pulsante giorno */
.daybtn > span{display:flex;flex-direction:column;min-width:0}
.daybtn .nm,.daybtn .meta{display:block}

/* ============ STADIO 4 — statistiche & progressioni ============ */
.pr-item{background:var(--surface);border:1px solid var(--line);border-radius:var(--r);padding:14px 15px;display:flex;align-items:center;gap:12px}
.pr-item .exn{flex:1;min-width:0}
.pr-item .exn .n{font-family:"Space Grotesk";font-weight:600;font-size:15px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.pr-item .exn .v{font-size:12.5px;color:var(--muted);margin-top:3px}
.pr-item .big{font-family:"Space Grotesk";font-weight:700;font-size:22px;color:var(--ember);white-space:nowrap;text-align:right}
.pr-item .big small{font-size:12px;color:var(--muted);font-weight:500}

.chart-card{background:var(--surface);border:1px solid var(--line);border-radius:var(--r);padding:15px;display:flex;flex-direction:column;gap:12px}
.select{width:100%;min-height:46px;background:var(--surface-2);border:1px solid var(--line-strong);border-radius:var(--r-sm);color:var(--text);font:inherit;font-size:15px;padding:0 12px}
.seg{display:flex;gap:6px}
.seg button{flex:1;min-height:38px;border:1px solid var(--line-strong);background:transparent;color:var(--muted);border-radius:9px;font:inherit;font-weight:600;font-size:13px;cursor:pointer}
.seg button.on{background:var(--ember);color:#1a0d07;border-color:var(--ember)}
.chart svg{width:100%;height:auto;display:block}
.empty-mini{color:var(--muted);font-size:14px;text-align:center;padding:24px 10px}
.chart-last{font-size:13px;color:var(--muted)}
.chart-last b{color:var(--teal);font-family:"Space Grotesk"}

.adh{display:flex;align-items:flex-end;gap:5px;height:104px}
.adh .col{flex:1;display:flex;flex-direction:column;align-items:center;gap:5px;height:100%;justify-content:flex-end}
.adh .cnt{font-size:11px;font-weight:700;color:var(--text);font-family:"Space Grotesk"}
.adh .bar{width:100%;max-width:24px;background:var(--teal);border-radius:5px 5px 0 0;min-height:3px}
.adh .bar.zero{background:var(--surface-2)}
.adh .wk{font-size:9.5px;color:var(--muted)}
.adh-tot{font-size:13px;color:var(--muted);margin-top:2px}
.adh-tot b{color:var(--text)}

.hist-item{background:var(--surface);border:1px solid var(--line);border-radius:var(--r);overflow:hidden}
.hist-head{display:flex;align-items:center;gap:12px;padding:14px 15px;cursor:pointer;width:100%;background:none;border:none;color:var(--text);font:inherit;text-align:left}
.hist-head .d{flex:1;min-width:0}
.hist-head .d .dt{font-family:"Space Grotesk";font-weight:600}
.hist-head .d .mt{font-size:12.5px;color:var(--muted);margin-top:2px}
.hist-head .cv{color:var(--muted);font-size:18px;transition:transform .2s}
.hist-body{padding:2px 15px 14px;display:none;flex-direction:column;gap:8px}
.hist-item.open .hist-body{display:flex}
.hist-item.open .hist-head .cv{transform:rotate(90deg)}
.hist-ex{font-size:13px;line-height:1.5}
.hist-ex .hn{font-weight:600;color:var(--text)}
.hist-ex .hs{color:var(--muted)}

/* ============ S02 — pannello admin (gestione utenti) ============ */
.stats.three{grid-template-columns:repeat(3,1fr)}
.stats.three .stat{padding:14px 12px}
.stats.three .stat .n{font-size:26px}

.adm-tabs{margin-top:2px}
.rolefilter{flex-wrap:wrap}

/* riuso di .list-item: nella lista admin nome + email/metriche incolonnati */
.list-item .pill{text-transform:none}

/* header dettaglio utente */
.avatar.lg{width:56px;height:56px;border-radius:14px;font-size:20px}
.udetail .who{flex:1;min-width:0;display:flex;flex-direction:column;gap:2px;overflow:hidden}
.udetail .who .nm{font-family:"Space Grotesk";font-weight:700;font-size:18px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.udetail .who .meta{font-size:13px;color:var(--muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}

/* lista chiave/valore */
.kvlist{background:var(--surface);border:1px solid var(--line);border-radius:var(--r);overflow:hidden}
.kv{display:flex;align-items:center;justify-content:space-between;gap:14px;padding:13px 15px;border-bottom:1px solid var(--line)}
.kv:last-child{border-bottom:none}
.kv .k{color:var(--muted);font-size:13px}
.kv .v{font-weight:600;text-align:right;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}

/* ============ S03 — modale inviti (bottom-sheet mobile, card desktop) ============ */
.modal-overlay{position:fixed;inset:0;z-index:70;background:rgba(12,9,8,.7);backdrop-filter:blur(6px);
  display:flex;align-items:flex-end;justify-content:center;padding:0}
.modal{width:100%;max-width:var(--maxw);background:var(--surface);border:1px solid var(--line-strong);
  border-radius:var(--r) var(--r) 0 0;padding:20px 20px calc(20px + env(safe-area-inset-bottom));
  box-shadow:0 -12px 40px rgba(0,0,0,.5);animation:modalUp .22s ease}
@keyframes modalUp{from{transform:translateY(18px);opacity:.5}to{transform:none;opacity:1}}
.modal-h{display:flex;align-items:center;justify-content:space-between;gap:12px}
.modal-h .ttl{font-family:"Space Grotesk";font-weight:600;font-size:18px}
.modal-close{width:34px;height:34px;border-radius:9px;border:1px solid var(--line);background:transparent;
  color:var(--muted);font-size:15px;cursor:pointer;flex:none;display:grid;place-items:center}
.modal-close:active{background:var(--surface-2)}
.input[readonly]{opacity:.7;cursor:default}
@media (min-width:520px){
  .modal-overlay{align-items:center;padding:24px}
  .modal{border-radius:var(--r);padding:22px}
}
@media (prefers-reduced-motion: reduce){ .modal{animation:none} }
