/* Sumerian Produttività — CSS estratto dal prototipo (invariato). */
:root{
    /* Sumerian design system — accent indigo, sfondo tinta indaco "vivo", card bianche in rilievo */
    --canvas:#e8eaf7;          /* area contenuti — tinta indaco tenue (non bianco piatto) */
    --surface:#ffffff;         /* sidebar, topbar, card */
    --card:#ffffff;
    --card-solid:#ffffff;
    --ink:#1a1930;             /* indaco scurissimo (più vivo del grigio) */
    --ink-soft:#4b496a;
    --muted:#7c7a96;
    --line:#e2e3f1;            /* hairline tinta indaco */
    --line-strong:#cdcee4;
    --field-bg:#f1f2fb;        /* sfondo campi input: distinto dalla card bianca */
    --accent:#4456e0;          /* indigo */
    --accent-ink:#2f3bb5;
    --accent-wash:#e6e8fb;     /* wash indigo chiaro */
    --ok:#1f9d63; --warn:#dd9326; --bad:#d6493a; --closed:#6f7ba6;        /* semaforo vivido */
    --ok-wash:#e4f4ec; --warn-wash:#fbf0df; --bad-wash:#fbe8e5;
    --shadow:0 1px 2px rgba(34,33,72,.05), 0 6px 18px rgba(34,33,72,.07);  /* leggera profondità per dare vita */
    --shadow-lg:0 8px 30px rgba(28,27,55,.18);
    --radius:10px;
    --blur:none;
    --mono:"IBM Plex Mono",ui-monospace,"SF Mono",Menlo,Consolas,monospace;
    --sans:"IBM Plex Sans",system-ui,-apple-system,Segoe UI,Roboto,sans-serif;
  }
  [data-theme="dark"]{
    --canvas:#1c1e2a;          /* più chiaro di prima (era quasi nero) */
    --surface:#272a39;         /* card nettamente staccate dallo sfondo */
    --card:#272a39;
    --card-solid:#2e3142;
    --ink:#f4f4fb;             /* testo molto leggibile */
    --ink-soft:#c7c9dc;
    --muted:#9a9cb4;
    --line:#3a3d50;            /* bordi visibili */
    --line-strong:#4c5067;
    --field-bg:#1b1d28;        /* input più scuri delle card → si distinguono */
    --accent:#8c98f6;
    --accent-ink:#aab2f9;
    --accent-wash:rgba(140,152,246,.20);
    --ok:#4cc187; --warn:#e6b557; --bad:#ec7f66; --closed:#8e9cb4;
    --ok-wash:rgba(76,193,135,.18); --warn-wash:rgba(230,181,87,.18); --bad-wash:rgba(236,127,102,.18);
    --shadow:0 1px 2px rgba(0,0,0,.3), 0 6px 20px rgba(0,0,0,.35);
    --shadow-lg:0 12px 40px rgba(0,0,0,.55);
  }
  *{box-sizing:border-box}
  html,body{margin:0;height:100%}
  body{
    font-family:var(--sans);background:var(--canvas);color:var(--ink);
    font-size:14px;line-height:1.5;-webkit-font-smoothing:antialiased;
    font-feature-settings:"cv05","ss01";
  }
  .num{font-variant-numeric:tabular-nums;font-family:var(--mono)}
  button{font-family:inherit;cursor:pointer}
  input,select{font-family:inherit;color:inherit}
  ::placeholder{color:var(--muted);opacity:.7}

  /* ---------- Layout shell ---------- */
  /* sidebar a scomparsa IN-FLOW: la colonna passa da 72px a 244px al passaggio del mouse,
     così il contenuto si RIDIMENSIONA (non viene coperto/tagliato). Logo solo in topbar. */
  .app{display:grid;grid-template-columns:72px 1fr;min-height:100vh;transition:grid-template-columns .18s ease}
  .app:has(.sidebar:hover){grid-template-columns:244px 1fr}
  .sidebar{
    background:var(--surface);border-right:1px solid var(--line);
    padding:16px 11px;display:flex;flex-direction:column;gap:4px;
    position:sticky;top:0;height:100vh;overflow-x:hidden;overflow-y:auto;
  }
  .nav-toptip{font-size:10px;text-transform:uppercase;letter-spacing:.10em;color:var(--muted);padding:2px 8px 10px;white-space:nowrap;opacity:0;transition:opacity .15s}
  .app:has(.sidebar:hover) .nav-toptip{opacity:1}
  /* stato a riposo (rail, non hover): solo icone */
  .sidebar:not(:hover) .nav-label{height:0;padding:0;margin:0;overflow:hidden;opacity:0}
  .sidebar:not(:hover) .nav-item{justify-content:center;padding:9px 0}
  .sidebar:not(:hover) .nav-item span{display:none}
  .sidebar:not(:hover) .nav-item .badge{position:absolute;top:3px;right:10px;margin:0;padding:0 5px;font-size:9px}
  .sidebar:not(:hover) .sidebar-foot{opacity:0;height:0;padding:0;overflow:hidden}
  .nav-item{position:relative}
  .logo-dark{display:none}
  [data-theme="dark"] .logo-light{display:none}
  [data-theme="dark"] .logo-dark{display:block}
  .brand-mark{
    width:30px;height:30px;border-radius:8px;flex:0 0 auto;
    background:linear-gradient(150deg,var(--accent),var(--accent-ink));
    display:grid;place-items:center;color:#fff;font-weight:700;font-size:15px;
    box-shadow:var(--shadow);
  }
  .brand-name{font-weight:650;letter-spacing:.2px;font-size:15px}
  .brand-sub{font-size:11px;color:var(--muted);margin-top:-2px;letter-spacing:.3px}
  .nav-label{font-size:10.5px;text-transform:uppercase;letter-spacing:.10em;color:var(--muted);padding:14px 8px 6px}
  .nav-item{
    display:flex;align-items:center;gap:10px;padding:8px 10px;border-radius:8px;
    color:var(--ink-soft);font-weight:500;font-size:13.5px;border:1px solid transparent;
    transition:background .12s,color .12s,border-color .12s;user-select:none;
  }
  .nav-item:hover{background:var(--accent-wash);color:var(--ink)}
  .nav-item.active{background:var(--card-solid);color:var(--ink);border-color:var(--line);box-shadow:var(--shadow)}
  .nav-item .ic{width:17px;height:17px;flex:0 0 auto;opacity:.85}
  .nav-item .badge{margin-left:auto;font-size:11px;background:var(--bad);color:#fff;border-radius:999px;padding:1px 7px;font-weight:600}
  .sidebar-foot{margin-top:auto;padding-top:14px;font-size:11px;color:var(--muted)}

  /* ---------- Topbar ---------- */
  .main{min-width:0;display:flex;flex-direction:column;grid-column:2}
  .topbar{
    position:sticky;top:0;z-index:20;display:flex;align-items:center;gap:14px;
    height:60px;padding:0 24px;background:var(--surface);border-bottom:1px solid var(--line);
  }
  .page-title{font-size:17px;font-weight:650;letter-spacing:-.2px}
  .page-sub{font-size:12.5px;color:var(--muted)}
  .top-right{margin-left:auto;display:flex;align-items:center;gap:10px}
  .seg{display:flex;background:var(--card-solid);border:1px solid var(--line);border-radius:8px;padding:2px;box-shadow:var(--shadow)}
  .seg button{border:0;background:transparent;color:var(--ink-soft);font-size:12.5px;font-weight:600;padding:5px 11px;border-radius:6px}
  .seg button.on{background:var(--accent);color:#fff}
  .login-as{display:flex;flex-direction:column;align-items:flex-end;gap:2px}
  .login-cap{font-size:9.5px;text-transform:uppercase;letter-spacing:.08em;color:var(--muted);font-weight:600}
  .ctrl{
    height:34px;border:1px solid var(--line);background:var(--card-solid);border-radius:8px;
    padding:0 10px;font-size:13px;color:var(--ink);box-shadow:var(--shadow);
  }
  .icon-btn{height:34px;width:34px;border:1px solid var(--line);background:var(--card-solid);border-radius:8px;display:grid;place-items:center;box-shadow:var(--shadow)}
  .icon-btn:hover{border-color:var(--line-strong)}
  .hamb{display:none}
  /* logo della testata (sempre visibile in alto a sinistra) */
  .topbar-logo{display:flex;align-items:center;margin-right:4px}
  .topbar-logo .brand-logo{height:20px;width:auto;display:block}
  .topbar-logo .logo-dark{display:none}
  [data-theme="dark"] .topbar-logo .logo-light{display:none}
  [data-theme="dark"] .topbar-logo .logo-dark{display:block}

  .content{padding:22px 24px 60px;max-width:none;width:100%}

  /* ---------- Cards / primitives ---------- */
  .card{
    background:var(--card);border:1px solid var(--line);border-radius:var(--radius);
    box-shadow:var(--shadow);backdrop-filter:var(--blur);-webkit-backdrop-filter:var(--blur);
  }
  .card.solid{background:var(--card-solid)}
  .pad{padding:16px 18px}
  .row{display:flex;align-items:center;gap:12px}
  .between{justify-content:space-between}
  .wrap{flex-wrap:wrap}
  .grid{display:grid;gap:14px}
  .muted{color:var(--muted)}
  .soft{color:var(--ink-soft)}
  .h{font-weight:650;letter-spacing:-.2px}
  .small{font-size:12.5px}
  .tiny{font-size:11px}
  .sep{height:1px;background:var(--line);margin:14px 0}
  .pill{display:inline-flex;align-items:center;gap:6px;font-size:11.5px;font-weight:600;padding:3px 9px;border-radius:999px;border:1px solid var(--line);color:var(--ink-soft);background:var(--card-solid)}
  .pill.accent{color:var(--accent-ink);background:var(--accent-wash);border-color:transparent}
  .dot{width:8px;height:8px;border-radius:50%;flex:0 0 auto;box-shadow:0 0 0 3px var(--canvas)}
  .dot.ok{background:var(--ok)} .dot.warn{background:var(--warn)} .dot.bad{background:var(--bad)} .dot.closed{background:var(--closed)}
  .status{display:inline-flex;align-items:center;gap:7px;font-size:12px;font-weight:600}
  .status.ok{color:var(--ok)} .status.warn{color:var(--warn)} .status.bad{color:var(--bad)} .status.closed{color:var(--closed)}

  .btn{display:inline-flex;align-items:center;gap:7px;height:36px;padding:0 15px;border-radius:8px;border:1px solid var(--line);background:var(--card-solid);color:var(--ink);font-weight:600;font-size:13px;box-shadow:var(--shadow)}
  .btn:hover{border-color:var(--line-strong)}
  .btn.primary{background:var(--accent);border-color:transparent;color:#fff}
  .btn.primary:hover{filter:brightness(1.05)}
  .btn.ghost{background:transparent;box-shadow:none;border-color:var(--line)}
  .btn.sm{height:30px;padding:0 11px;font-size:12.5px}
  .btn.danger{color:var(--bad)}
  .link{color:var(--accent-ink);font-weight:600;cursor:pointer}

  /* inputs */
  .in{height:34px;border:1px solid var(--line-strong);background:var(--field-bg);border-radius:7px;padding:0 9px;font-size:13px;width:100%}
  .in:focus{outline:2px solid var(--accent-wash);outline-offset:0;border-color:var(--accent)}
  .in.num{text-align:right}
  .in.prefill{color:var(--muted)}
  .field{display:flex;flex-direction:column;gap:5px}
  .field label{font-size:11.5px;font-weight:600;color:var(--ink-soft)}

  /* KPI */
  .kpis{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}
  .kpi .v{font-size:26px;font-weight:680;letter-spacing:-.6px;line-height:1.1}
  .kpi .l{font-size:12px;color:var(--muted);margin-top:3px}
  .kpi .t{font-size:11px;font-weight:600;margin-top:8px;display:inline-flex;align-items:center;gap:5px}
  .kpis6{grid-template-columns:repeat(6,1fr)}
  .minib{display:inline-block;width:56px;height:6px;border-radius:999px;background:var(--line);overflow:hidden;vertical-align:middle;margin-right:7px}
  .minib > i{display:block;height:100%;background:var(--accent);border-radius:999px}
  .minib > i.hot{background:var(--bad)}
  .pbar.big{height:10px;width:100%}
  .cap-kpis{display:grid;grid-template-columns:repeat(4,1fr);gap:10px;text-align:center}
  .ck-v{font-size:17px;font-weight:700;letter-spacing:-.3px}
  .ck-l{font-size:10.5px;color:var(--muted);margin-top:2px}
  .cap-row{display:flex;align-items:center;gap:10px;padding:5px 0}
  .stato-strip{display:flex;align-items:flex-end;gap:14px;flex-wrap:wrap;padding:8px 0 12px;margin-bottom:6px;border-bottom:1px dashed var(--line-strong)}
  .stato-strip .cat-name{align-self:center}
  .stato-f{min-width:172px}
  .stato-f label{font-size:10px}
  .catchip{font-size:10px;font-weight:600;padding:2px 8px;border-radius:999px;background:var(--line);color:var(--muted);cursor:pointer;user-select:none}
  .catchip.on{background:var(--accent-wash);color:var(--accent-ink)}
  .ms-list{max-height:190px;overflow:auto;border:1px solid var(--line);border-radius:8px;padding:6px 8px}
  .ms-list label{display:flex;align-items:center;gap:8px;padding:4px 2px;font-size:13px;cursor:pointer}
  .in.slim{padding:5px 8px;font-size:12px;min-width:148px}

  /* tables */
  table{width:100%;border-collapse:collapse}
  th{font-size:11px;text-transform:uppercase;letter-spacing:.06em;color:var(--muted);text-align:left;font-weight:600;padding:9px 10px;border-bottom:1px solid var(--line)}
  td{padding:10px;border-bottom:1px solid var(--line);font-size:13px;vertical-align:middle}
  tr:last-child td{border-bottom:0}
  th.r,td.r{text-align:right}
  .tablecard{overflow:hidden}
  .tbl-filter{padding:8px 12px;border-bottom:1px solid var(--line)}
  .tbl-filter input{max-width:260px;font-size:12.5px;padding:6px 9px}
  .sort-ar{font-size:9px;color:var(--muted);margin-left:2px}

  /* daily entry */
  .progress{display:flex;align-items:center;gap:10px}
  .pbar{height:6px;width:120px;background:var(--line);border-radius:999px;overflow:hidden}
  .pbar > i{display:block;height:100%;background:var(--accent);border-radius:999px;transition:width .3s}
  /* layout compilazione: tabella ~70% a sx, pannello riepiloghi ~30% a dx (la sx non scende sotto il contenuto) */
  .oggi-wrap{display:grid;grid-template-columns:7fr 3fr;gap:16px;align-items:start}
  .oggi-side{position:sticky;top:74px;display:flex;flex-direction:column;gap:14px;min-width:0}
  .side-ore{font-size:24px;font-weight:700}
  .side-ore{font-size:22px;font-weight:700}
  .co-card{margin-bottom:8px;overflow:hidden}
  /* header cliente: ben visibile, accent, compatto */
  .co-head{display:flex;align-items:center;gap:10px;padding:7px 12px;border-left:3px solid var(--accent);user-select:none;background:var(--accent-wash)}
  .co-title{font-weight:700;font-size:14.5px;color:var(--accent-ink);letter-spacing:-.2px}
  .co-meta{font-size:11px;color:var(--ink-soft)}
  .chev{margin-left:auto;transition:transform .2s;color:var(--muted)}
  .co-card.open .chev{transform:rotate(90deg)}
  .co-body{display:none;border-top:1px solid var(--line);padding:2px 10px 8px}
  .co-card.open .co-body{display:block}
  .acct-grid{width:100%;border-collapse:collapse}
  .acct-grid th{padding:4px 4px;font-size:9.5px}
  .acct-grid td{padding:1px 4px;vertical-align:middle}
  .acct-grid .in{height:25px;font-size:12.5px}
  /* Attività assorbe lo spazio a sinistra (spinge i campi a destra); Documenti/Ore/Data a contenuto; Note riempie la sua cella */
  .acct-grid td[data-l="Documenti"],.acct-grid td[data-l="Data ult. reg."],.acct-grid td[data-l="Ore"]{white-space:nowrap;width:1px}
  .acct-grid td[data-l="Attività"]{min-width:150px}
  .acct-grid td[data-l="Note"]{min-width:200px}
  .acct-grid .alt-desc{width:100%;max-width:none}
  .acct-grid th.col-ndoc{width:104px;white-space:normal;line-height:1.2;vertical-align:bottom}
  .acct-grid tbody tr.drow td{border-bottom:1px solid var(--line)}
  .acct-grid tbody tr.drow:hover td{background:var(--accent-wash)}
  .acct-grid tbody tr.drow.alt td{background:color-mix(in srgb,var(--accent) 5%,transparent)}
  .acct-grid tbody tr.drow.alt:hover td{background:var(--accent-wash)}
  .cat-row td{background:color-mix(in srgb,var(--accent) 7%,transparent);border-top:1px solid var(--line-strong);padding:2px 9px}
  @media (max-width:1280px){ .oggi-wrap{grid-template-columns:1fr} .oggi-side{position:static} }
  .cat-name{font-size:9px;font-weight:700;letter-spacing:.04em;text-transform:uppercase;color:var(--accent-ink)}
  .acct-name{font-weight:500;font-size:12.5px}
  .acct-type{font-size:9.5px;color:var(--muted);text-transform:uppercase;letter-spacing:.04em}
  /* gutter categoria a sinistra: stretto, una sola riga (non gonfia le righe) */
  .cat-cell{vertical-align:middle;background:color-mix(in srgb,var(--accent) 9%,transparent);border-right:2px solid var(--accent);white-space:nowrap;width:1px;padding:2px 6px!important}
  .acct-grid tr.cat-first td{border-top:2px solid var(--line-strong)}
  /* cella Documenti con protocollo: numero di IERI in sola lettura + campo di OGGI (largh. FISSA) + delta */
  .doc-proto{display:flex;align-items:center;gap:6px;justify-content:flex-start}
  /* sotto-caselle a larghezza FISSA → la colonna non cambia mai con i numeri inseriti */
  .doc-prev{flex:0 0 80px;width:80px;box-sizing:border-box;font-size:10.5px;font-weight:600;color:var(--muted);background:var(--field-bg);border:1px solid var(--line);border-radius:5px;padding:2px 6px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
  .doc-prev .dp-n{font-family:var(--mono)}
  .doc-in{width:84px;min-width:84px;max-width:84px;flex:0 0 84px}
  .doc-delta{flex:0 0 88px;width:88px;box-sizing:border-box;font-size:11px;font-weight:600;color:var(--accent-ink);white-space:nowrap;overflow:hidden}
  /* stepper Ore : Minuti — campo + frecce su/giù compatte su un solo lato */
  .ore-step{display:inline-flex;align-items:center;gap:3px}
  .ore-step input{height:24px;width:30px;text-align:center;border:1px solid var(--line-strong);background:var(--field-bg);border-radius:6px;font-size:12.5px;font-family:var(--mono);padding:0 2px;color:inherit}
  .ore-step input:focus{outline:2px solid var(--accent-wash);border-color:var(--accent)}
  .spin{display:inline-flex;flex-direction:column;flex:0 0 auto}
  .spin button{height:12px;width:15px;border:1px solid var(--line-strong);background:var(--card-solid);color:var(--ink-soft);font-size:7px;line-height:1;padding:0;display:grid;place-items:center;cursor:pointer}
  .spin button:first-child{border-radius:5px 5px 0 0;border-bottom:0}
  .spin button:last-child{border-radius:0 0 5px 5px}
  .spin button:hover{background:var(--accent-wash);border-color:var(--accent);color:var(--accent-ink)}
  .os-u{font-size:9.5px;color:var(--muted);margin-left:1px}
  .sub-tag{font-size:9px;font-weight:700;text-transform:uppercase;letter-spacing:.04em;padding:1px 6px;border-radius:999px;background:var(--accent-wash);color:var(--accent-ink);margin-left:7px;vertical-align:middle}
  .da-cell{display:flex;align-items:center;gap:6px;justify-content:flex-end}
  .in.prefill{background:var(--canvas);color:var(--muted)}
  .in.prefill:focus{background:var(--surface);color:var(--ink);border-color:var(--accent)}
  .in.ro{background:var(--canvas);color:var(--ink-soft);cursor:default}
  .in.ro:focus{outline:none}
  .in.ro-pref{background:var(--canvas);color:var(--muted);cursor:default}
  .da-tag{font-size:9px;font-weight:700;letter-spacing:.03em;color:var(--accent-ink);background:var(--accent-wash);border-radius:5px;padding:2px 5px;white-space:nowrap}
  .subin{display:flex;gap:10px;flex-wrap:wrap}
  .subin .field{flex:1;min-width:130px}
  .subin label{font-size:10px}
  .subin .in{max-width:none}
  .alt-desc{width:100%;text-align:left}
  .tot-bar{display:flex;align-items:center;gap:7px;font-size:13px}
  .tot-val{font-size:15px}
  .day-ore{display:flex;flex-direction:column;align-items:flex-end;line-height:1.25}
  .ferie-tgl{display:inline-flex;align-items:center;gap:7px;height:34px;padding:0 12px;border-radius:8px;border:1px solid var(--line-strong);background:var(--card-solid);font-weight:600;font-size:12.5px;cursor:pointer;user-select:none;box-shadow:var(--shadow)}
  .ferie-tgl.on{background:var(--warn-wash);border-color:transparent;color:var(--warn)}
  .ferie-tgl input{accent-color:var(--warn)}
  .bk-tgl{display:inline-flex;align-items:center;gap:7px;height:34px;padding:0 12px;border-radius:8px;border:1px solid var(--line-strong);background:var(--card-solid);font-weight:600;font-size:12.5px;cursor:pointer;user-select:none;box-shadow:var(--shadow)}
  .bk-tgl.on{background:var(--accent-wash);border-color:transparent;color:var(--accent-ink)}
  .bk-tgl input{accent-color:var(--accent)}
  .bk-count{font-size:10.5px;font-weight:700;background:var(--accent);color:#fff;border-radius:10px;padding:1px 7px}
  .datenav{display:inline-flex;align-items:center;gap:4px}
  .wk-badge{font-size:9.5px;font-weight:700;letter-spacing:.04em;text-transform:uppercase;color:var(--closed);background:var(--line);border-radius:5px;padding:2px 6px}
  .role-badge{font-size:10.5px;font-weight:700;letter-spacing:.03em;padding:2px 8px;border-radius:999px;text-transform:uppercase}
  .role-tit{background:var(--accent-wash);color:var(--accent-ink)}
  .role-bk{background:var(--line);color:var(--ink-soft)}
  .saved-chip{font-size:11px;color:var(--ok);font-weight:600;display:inline-flex;gap:5px;align-items:center}

  /* drawer */
  .scrim{position:fixed;inset:0;background:rgba(20,16,12,.36);backdrop-filter:blur(2px);z-index:40;opacity:0;pointer-events:none;transition:opacity .2s}
  .scrim.show{opacity:1;pointer-events:auto}
  .drawer{position:fixed;top:0;right:0;height:100vh;width:min(460px,92vw);background:var(--surface);border-left:1px solid var(--line);z-index:50;transform:translateX(100%);transition:transform .24s cubic-bezier(.2,.8,.2,1);box-shadow:var(--shadow-lg);display:flex;flex-direction:column}
  .drawer.show{transform:none}
  .drawer-head{padding:18px 20px;border-bottom:1px solid var(--line);display:flex;align-items:center;gap:10px}
  .drawer-body{padding:18px 20px;overflow:auto;flex:1}

  /* toast */
  .toasts{position:fixed;bottom:20px;left:50%;transform:translateX(-50%);z-index:80;display:flex;flex-direction:column;gap:8px;align-items:center}
  .toast{background:var(--ink);color:var(--canvas);padding:10px 16px;border-radius:9px;font-size:13px;font-weight:500;box-shadow:var(--shadow-lg);display:flex;align-items:center;gap:9px;animation:pop .25s}
  .toast .dot{box-shadow:none}
  @keyframes pop{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}

  .empty{padding:40px 20px;text-align:center;color:var(--muted)}
  .chart-box{position:relative;height:230px}
  .legend{display:flex;gap:14px;flex-wrap:wrap;font-size:12px;color:var(--ink-soft)}
  .legend i{width:9px;height:9px;border-radius:50%;display:inline-block;margin-right:6px}

  .mailprev{font-family:var(--mono);font-size:12px;background:var(--surface);border:1px dashed var(--line-strong);border-radius:8px;padding:12px 14px;color:var(--ink-soft);white-space:pre-wrap;line-height:1.6}

  /* login */
  .login-screen{position:fixed;inset:0;z-index:200;background:var(--canvas);display:none;align-items:center;justify-content:center;padding:20px}
  .login-screen.show{display:flex}
  .login-card{width:min(380px,94vw);background:var(--surface);border:1px solid var(--line);border-radius:14px;padding:30px 28px}
  .login-brand{display:flex;align-items:center;gap:12px;margin-bottom:6px}
  .login-brand .brand-mark{width:38px;height:38px;font-size:18px}
  .login-title{font-size:18px;font-weight:650}
  .login-sub{font-size:12.5px;color:var(--muted);margin:2px 0 22px}
  .login-err{display:none;font-size:12.5px;color:var(--bad);background:var(--bad-wash);border-radius:8px;padding:8px 10px;margin-bottom:12px}
  .login-err.show{display:block}
  .login-note{font-size:11px;color:var(--muted);margin-top:18px;line-height:1.5;border-top:1px solid var(--line);padding-top:14px}
  .user-chip{display:flex;flex-direction:column;align-items:flex-end;line-height:1.2}
  .user-chip .nm{font-size:13px;font-weight:600}
  .user-chip .rl{font-size:10px;text-transform:uppercase;letter-spacing:.06em;color:var(--muted)}
  .mod-badge{font-size:11px;font-weight:700;padding:3px 9px;border-radius:999px;background:var(--accent-wash);color:var(--accent-ink);white-space:nowrap;letter-spacing:.02em}

  @media (max-width:860px){
    .app,.app:has(.sidebar:hover){grid-template-columns:1fr}
    .main{grid-column:1}
    .sidebar{position:fixed;z-index:60;width:244px;transform:translateX(-100%);transition:transform .24s;height:100vh;padding:18px 14px}
    .sidebar.show{transform:none;box-shadow:var(--shadow-lg)}
    .nav-toptip{display:none}
    /* su mobile il menu off-canvas mostra sempre etichette complete (no rail) */
    .sidebar:not(:hover) .nav-label{height:auto;padding:14px 8px 6px;opacity:1}
    .sidebar:not(:hover) .nav-item{justify-content:flex-start;padding:8px 10px}
    .sidebar:not(:hover) .nav-item span{display:inline}
    .sidebar:not(:hover) .sidebar-foot{opacity:1;height:auto;padding-top:14px}
    .hamb{display:grid}
    .kpis{grid-template-columns:repeat(2,1fr)}
    .content{padding:16px 14px 60px}
    .topbar{padding:10px 14px}
    .acct-grid thead{display:none}
    .acct-grid, .acct-grid tbody{display:block;width:100%}
    .acct-grid tr.cat-row{display:block;margin:16px 0 4px}
    .acct-grid tr.cat-row td{display:block;background:transparent;border:0;padding:0}
    .acct-grid tr.drow{display:block;border:1px solid var(--line);border-radius:9px;padding:6px 10px;margin-bottom:8px;background:var(--card-solid)}
    .acct-grid tr.drow td{display:flex;border:0!important;background:transparent!important;padding:7px 0;justify-content:space-between;align-items:center;gap:10px}
    .acct-grid tr.drow td::before{content:attr(data-l);font-size:11px;color:var(--muted);font-weight:600}
    .acct-grid td .in{max-width:160px}
    .da-cell{justify-content:flex-end}
    .subin{flex-direction:column;width:100%}
    .subin .field{width:100%}
    .alt-desc{max-width:none!important}
  }
