
:root{
  --bg:#1A1410;--sf:#221810;--sf2:#2C2018;--sf3:#38281C;
  --br:#4A3828;--br2:#5E4C38;
  --A:#D4922A;--Ad:rgba(212,146,42,.13);--Ab:rgba(212,146,42,.24);
  --B:#C4341A;--Bd:rgba(196,52,26,.13);
  --O:#E8553A;--Od:rgba(232,85,58,.13);
  --R:#D84030;--Rd:rgba(216,64,48,.13);
  --st-ok:#52b270;
  --C:#B8903A;--Cd:rgba(184,144,58,.13);
  --Y:#D4922A;--Yd:rgba(212,146,42,.13);
  --tx:#FAF8F3;--mu:#9A8472;--mu2:#6A5448;
  --p1:#D4922A;--p2:#C4341A;
  /* Status colors */
  --st-prev:#9A8472;--st-conf:#D4922A;--st-corso:#E8553A;
  --st-cons:#B8903A;--st-comp:#D4922A;--st-rit:#C4341A;--st-stby:#9A8472;
}
/* ─── LIGHT THEME ─── */
[data-theme="light"]{
  --bg:#FAF8F3;--sf:#FFFFFF;--sf2:#F2EDE4;--sf3:#E8E2D8;
  --br:#D0C4B4;--br2:#B8ADA0;
  --A:#C4341A;--Ad:rgba(196,52,26,.1);--Ab:rgba(196,52,26,.2);
  --B:#D4922A;--Bd:rgba(212,146,42,.12);
  --O:#B84420;--Od:rgba(184,68,32,.1);
  --R:#A82C16;--Rd:rgba(168,44,22,.1);
  --C:#9A7220;--Cd:rgba(154,114,32,.1);
  --Y:#9A7220;--Yd:rgba(154,114,32,.1);
  --tx:#1A1410;--mu:#6A5448;--mu2:#7A5C4C;
  --p1:#C4341A;--p2:#D4922A;
  --st-prev:#9A8472;--st-conf:#9A7220;--st-corso:#B84420;
  --st-cons:#9A7220;--st-comp:#C4341A;--st-rit:#A82C16;--st-stby:#7A6858;
  --st-ok:#2e8b57;
}
[data-theme="light"] body{background:var(--bg)}
[data-theme="light"] #topbar{background:rgba(250,248,243,.97);border-bottom-color:var(--br)}
[data-theme="light"] #sidebar{background:var(--sf2);border-right:1px solid var(--br2)}
[data-theme="light"] ::-webkit-scrollbar-thumb{background:var(--br2)}
[data-theme="light"] .modal{box-shadow:0 8px 40px rgba(0,0,0,.15)}
[data-theme="light"] .fi,[data-theme="light"] .fsel,[data-theme="light"] .fsel2,[data-theme="light"] .srch{background:var(--sf);border-color:var(--br);color:var(--tx)}
[data-theme="light"] .fi:focus,[data-theme="light"] .fsel:focus,[data-theme="light"] .fsel2:focus,[data-theme="light"] .srch:focus{border-color:var(--B)}
[data-theme="light"] .day-group,[data-theme="light"] .card,[data-theme="light"] .kpi{background:var(--sf);border-color:var(--br)}
[data-theme="light"] .day-hdr,[data-theme="light"] .th-r{background:var(--sf2)}
[data-theme="light"] .ev-r:hover{background:var(--sf2)}
[data-theme="light"] .modal{background:var(--sf)}
[data-theme="light"] #bottom-nav{background:var(--sf);border-top-color:var(--br)}

/* ─── LIGHT MODE OVERRIDES (palette Giapponese) ─── */
/* Status badges */
[data-theme="light"] .st-completato{background:rgba(196,52,26,.1);border-color:rgba(196,52,26,.3)}
[data-theme="light"] .st-confermato{background:rgba(154,114,32,.1);border-color:rgba(154,114,32,.3)}
[data-theme="light"] .st-in_corso{background:rgba(184,68,32,.12);border-color:rgba(184,68,32,.35)}
[data-theme="light"] .st-in_ritardo{background:rgba(168,44,22,.1);border-color:rgba(168,44,22,.3)}
[data-theme="light"] .st-standby{background:rgba(122,104,88,.1);border-color:rgba(122,104,88,.3)}
[data-theme="light"] .st-preventivo{background:rgba(106,84,72,.1);border-color:rgba(106,84,72,.3)}
[data-theme="light"] .st-rifiutato{background:rgba(106,84,72,.07);border-color:rgba(106,84,72,.2)}
/* Consegna badges */
[data-theme="light"] .csb-consegnata{background:rgba(196,52,26,.1);border-color:rgba(196,52,26,.3)}
[data-theme="light"] .csb-prevista{background:rgba(154,114,32,.1);border-color:rgba(154,114,32,.3)}
[data-theme="light"] .csb-ritardata{background:rgba(168,44,22,.1);border-color:rgba(168,44,22,.3)}
/* Deadline pills */
[data-theme="light"] .dl-close{background:rgba(168,44,22,.08);border-color:rgba(168,44,22,.3)}
[data-theme="light"] .dl-urgent{background:rgba(168,44,22,.12);border-color:var(--R)}
[data-theme="light"] .dl-med{border-color:rgba(184,68,32,.35)}
/* Primary buttons: testo bianco su Rosso Kohaku */
[data-theme="light"] .btn-p{color:#fff}
[data-theme="light"] .day-toggle button.on{color:#fff}
[data-theme="light"] .tog button.on{color:#fff}
[data-theme="light"] .modal-step.on{color:#fff}
/* Calendario: celle su Carta di Riso */
[data-theme="light"] .cc.other{background:rgba(26,20,16,.03)}
[data-theme="light"] .cc:not(.other):hover{background:rgba(26,20,16,.055)}
[data-theme="light"] .cc.today{background:rgba(196,52,26,.07);outline:1px inset rgba(196,52,26,.25)}
[data-theme="light"] .cc.dragover{background:rgba(196,52,26,.12)!important}
/* Calendario eventi: P1 = Rosso Kohaku, P2 = Oro Koi */
[data-theme="light"] .cc-ev.p1r{border-color:var(--A);background:var(--Ad);color:var(--A)}
[data-theme="light"] .cc-ev.p1n{border-color:rgba(196,52,26,.45);background:rgba(196,52,26,.08);color:rgba(196,52,26,.88)}
[data-theme="light"] .cc-ev.p2r{color:var(--B)}
[data-theme="light"] .cc-ev.p2n{border-color:rgba(212,146,42,.5);background:rgba(212,146,42,.1);color:rgba(154,114,32,.95)}
/* Input note rapide */
[data-theme="light"] .quick-note{background:var(--sf)}
[data-theme="light"] .db-sp{background:var(--sf2);border-color:var(--br)}

/* ─── THEME TOGGLE ─── */
.theme-sw{display:flex;align-items:center;gap:6px;cursor:pointer;user-select:none}
.theme-sw input{position:absolute;opacity:0;width:0;height:0;pointer-events:none}
.theme-track{width:38px;height:22px;background:var(--sf2);border:1px solid var(--br);border-radius:11px;position:relative;transition:.2s;flex-shrink:0}
.theme-thumb{position:absolute;top:3px;left:3px;width:14px;height:14px;background:var(--mu);border-radius:50%;transition:.2s}
.theme-sw input:checked~.theme-track{background:var(--Ad);border-color:var(--A)}
.theme-sw input:checked~.theme-track .theme-thumb{transform:translateX(16px);background:var(--A)}
.theme-sw-ico{font-size:10px;color:var(--mu);letter-spacing:.5px;white-space:nowrap;text-transform:uppercase}

/* ─── MODAL STEPS ─── */
.modal-steps{display:flex;margin-bottom:20px;border:1px solid var(--br);border-radius:8px;overflow:hidden}
.modal-step{flex:1;padding:8px 14px;text-align:center;color:var(--mu);background:var(--sf2);cursor:pointer;transition:background .18s ease,color .18s ease,box-shadow .18s ease;border:none;font-family:'DM Mono',monospace}
.modal-step:hover:not(.on){color:var(--tx);background:var(--sf3)}
.modal-step:active{transform:scale(0.97)}
.modal-step.on{background:var(--A);color:var(--bg);font-weight:700;box-shadow:inset 0 -2px 0 rgba(0,0,0,.15)}
.modal-step-n{font-family:'Syne',sans-serif;font-size:17px;font-weight:800;display:block;line-height:1;margin-bottom:2px}
.modal-step-lbl{font-size:9px;text-transform:uppercase;letter-spacing:1px;display:block}

*{margin:0;padding:0;box-sizing:border-box}
body{background:var(--bg);color:var(--tx);font-family:'Syne',sans-serif;height:100vh;overflow:hidden;display:flex}
::-webkit-scrollbar{width:4px;height:4px}
:focus-visible{outline:2px solid var(--A);outline-offset:2px;border-radius:3px}
::-webkit-scrollbar-thumb{background:var(--br2);border-radius:2px}
::-webkit-scrollbar-track{background:transparent}

/* ─── SIDEBAR ─── */
#sidebar{width:230px;min-width:230px;height:100vh;background:var(--sf);border-right:1px solid var(--br);display:flex;flex-direction:column;overflow-y:auto;overflow-x:hidden}
.logo-wrap{padding:20px 18px 16px;border-bottom:1px solid var(--br)}
.logo{font-family:'Syne',sans-serif;font-weight:800;font-size:19px;color:var(--A);letter-spacing:-.5px}
.logo-sub{font-size:10px;color:var(--mu);letter-spacing:2px;margin-top:2px}
.person-tabs{display:flex;margin:12px 12px 0;border:1px solid var(--br);border-radius:8px;overflow:hidden}
.ptab{flex:1;padding:7px 4px;text-align:center;font-size:11px;cursor:pointer;background:transparent;border:none;color:var(--mu);transition:background .16s ease,color .16s ease;font-family:'DM Mono',monospace;letter-spacing:.3px}
.ptab:hover{color:var(--tx);background:rgba(255,255,255,.04)}
.ptab:active{transform:scale(0.96)}
.ptab.p1.on{background:var(--Ad);color:var(--p1)}
.ptab.p2.on{background:var(--Bd);color:var(--p2)}
.ptab.both.on{background:var(--sf2);color:var(--tx)}
.nav-sec{font-size:10px;color:var(--mu2);letter-spacing:2px;text-transform:uppercase;padding:12px 18px 4px;margin-top:4px}
.ni{display:flex;align-items:center;gap:9px;padding:10px 18px;cursor:pointer;font-size:12.5px;color:var(--mu);background:none;border:none;width:100%;text-align:left;transition:background .16s ease,color .16s ease,border-color .16s ease,padding .16s ease;border-radius:0;min-height:40px;border-left:3px solid transparent;text-transform:uppercase;letter-spacing:.04em}
.ni:hover{color:var(--tx);background:var(--sf2)}
.ni.on{color:var(--A);background:var(--Ad);border-left-color:var(--A);padding-left:15px}
.ni .ic{font-size:14px;width:16px;text-align:center}
.msep{height:1px;background:var(--br);margin:8px 14px}
.mi{display:flex;align-items:center;justify-content:space-between;padding:6px 18px;cursor:pointer;font-size:12px;color:var(--mu);background:none;border:none;width:100%;text-align:left;transition:.1s}
.mi:hover{color:var(--tx);background:var(--sf2)}
.mi.on{color:var(--A);background:var(--Ad);border-left:3px solid var(--A);padding-left:15px}
.mbadge{background:var(--sf2);color:var(--mu2);font-size:10px;padding:1px 6px;border-radius:8px}
.mi.on .mbadge{background:var(--Ab);color:var(--A)}

/* ─── MAIN ─── */
#main{flex:1;display:flex;flex-direction:column;overflow:hidden}
#topbar{height:52px;min-height:52px;border-bottom:1px solid var(--br);display:grid;grid-template-columns:1fr auto 1fr;align-items:center;padding:0 24px;background:rgba(26,20,16,.92);backdrop-filter:blur(12px);position:relative;flex-shrink:0;z-index:20}
#ptitle{font-family:'Syne',sans-serif;font-size:15px;font-weight:700}

/* ─── TOPBAR RESTRUCTURE ─── */
.topbar-l{display:flex;align-items:center;gap:12px;min-width:0}
.tbar-r{display:flex;gap:8px;align-items:center;justify-content:flex-end;min-width:0}

/* ─── MONTH NAV (topbar center — grid column auto) ─── */
.month-nav{
  position:relative;
  display:flex;align-items:center;gap:4px;
  z-index:10;justify-self:center;
}
.mna-arr{
  background:none;border:1px solid var(--br);border-radius:6px;
  color:var(--mu);cursor:pointer;
  min-width:44px;min-height:44px;display:flex;align-items:center;justify-content:center;
  font-size:16px;transition:background .15s ease,color .15s ease,border-color .15s ease;
  font-family:'DM Mono',monospace;flex-shrink:0;
}
.mna-arr:hover{color:var(--tx);background:var(--sf2);border-color:var(--br2)}
.mna-arr:active{transform:scale(0.92)}
.mna-label{
  display:flex;align-items:center;gap:6px;
  padding:5px 12px;border:1px solid var(--br);border-radius:6px;
  cursor:pointer;background:var(--sf2);transition:background .15s ease,border-color .15s ease;
  min-width:130px;justify-content:center;
  font-family:'Syne',sans-serif;font-size:13px;font-weight:700;
  white-space:nowrap;user-select:none;
}
.mna-label:hover{border-color:var(--A);background:var(--Ad)}
#mna-text{color:var(--tx)}
.mna-caret{color:var(--mu);font-size:10px;transition:transform .15s ease}
.month-nav.picker-open .mna-caret{transform:rotate(180deg)}
.month-nav.picker-open .mna-label{border-color:var(--A);background:var(--Ad)}
.mna-picker{
  position:absolute;top:calc(100% + 8px);left:50%;transform:translateX(-50%);
  background:var(--sf2);border:1px solid var(--br);border-radius:10px;
  padding:8px;gap:4px;z-index:400;
  display:none;
  grid-template-columns:repeat(4,1fr);
  min-width:240px;
  box-shadow:0 8px 32px rgba(0,0,0,.3);
}
.mna-picker.on{display:grid}
.mna-opt{
  padding:6px 10px;border:1px solid transparent;border-radius:6px;
  background:none;color:var(--mu);cursor:pointer;
  font-family:'DM Mono',monospace;font-size:11px;
  transition:background .12s ease,color .12s ease,border-color .12s ease;
  white-space:nowrap;text-align:center;
}
.mna-opt:hover{color:var(--tx);background:var(--sf3)}
.mna-opt.on{background:var(--Ad);color:var(--A);border-color:var(--Ab);font-weight:700}
.mna-opt[data-mp="all"]{grid-column:1/-1;font-size:11px}
.mna-sep{width:1px;height:18px;background:var(--br2);margin:0 6px;flex-shrink:0;align-self:center}
.mna-year{font-family:'DM Mono',monospace;font-size:12px;font-weight:600;color:var(--mu);padding:5px 10px;white-space:nowrap;text-align:center;border:1px solid var(--br);border-radius:6px;background:var(--sf2);min-width:52px;letter-spacing:.5px}
.mna-yr-arr{opacity:.6}
.mna-yr-arr:hover{opacity:1}
.person-indicator{display:flex;align-items:center;gap:6px;padding:4px 10px;border-radius:6px;font-size:11px;border:1px solid var(--br)}
.person-dot{width:7px;height:7px;border-radius:50%}
.btn{font-family:'DM Mono',monospace;font-size:11px;padding:7px 13px;border-radius:6px;border:1px solid var(--br);cursor:pointer;transition:background .16s ease,border-color .16s ease,color .16s ease,box-shadow .16s ease,transform .09s ease,filter .16s ease;letter-spacing:.3px;white-space:nowrap;min-height:36px;display:inline-flex;align-items:center;gap:5px}
.btn:active{transform:scale(0.95)}
.btn-p{background:var(--A);color:#09090c;border-color:var(--A);font-weight:700}
.btn-p:hover{filter:brightness(1.12);box-shadow:0 0 0 3px var(--Ab),0 2px 8px rgba(0,0,0,.25)}
.btn-p:active{filter:brightness(1.0);box-shadow:none;transform:scale(0.95)}
.btn-g{background:transparent;color:var(--mu)}
.btn-g:hover{color:var(--tx);background:var(--sf2);border-color:var(--br2);box-shadow:0 2px 6px rgba(0,0,0,.12)}
#content{flex:1;overflow-y:auto;overflow-x:hidden}
.page{display:none;flex-direction:column;gap:20px;padding:24px;min-height:100%}
.page.on{display:flex}
.card{background:var(--sf);border:1px solid var(--br);border-radius:12px}
.card-p{padding:20px 22px}
.card-title{font-family:'Syne',sans-serif;font-size:13px;font-weight:700;margin-bottom:14px;display:flex;align-items:center;justify-content:space-between;color:var(--tx)}
.card-title small{font-family:'DM Mono',monospace;font-weight:400;font-size:10.5px;color:var(--mu)}

/* ─── KPI ─── */
.kpi-row{display:grid;grid-template-columns:repeat(5,1fr);gap:14px}
.kpi{background:var(--sf);border:1px solid var(--br);border-radius:14px;padding:18px 20px;position:relative;overflow:hidden;cursor:default;border-left:3px solid var(--br2)}
.kpi.kpi-pos{border-left-color:var(--A)}
.kpi.kpi-neg{border-left-color:var(--R)}
.kpi.kpi-green{border-left-color:var(--st-ok)}
.kpi.kpi-pend{border-left-color:var(--O)}
.kpi-dir{position:absolute;right:14px;top:12px;opacity:.4;line-height:0;display:flex;align-items:center;justify-content:center}
.kpi-l{font-size:9px;color:var(--mu);text-transform:uppercase;letter-spacing:2px;margin-bottom:8px}
.kpi-v{font-family:'Syne',sans-serif;font-size:28px;font-weight:800;line-height:1;margin-bottom:3px;font-variant-numeric:tabular-nums}
.kpi-s{font-size:10.5px;color:var(--mu);margin-top:4px}
.kpi-glow{position:absolute;right:-20px;bottom:-20px;width:80px;height:80px;border-radius:50%;opacity:.07;filter:blur(22px)}
.kpi-bar{height:2px;border-radius:2px;margin-top:14px;background:var(--br);overflow:hidden;opacity:.7}
.kpi-bar-fill{height:100%;border-radius:2px;transition:width 1s cubic-bezier(.22,1,.36,1)}
.ca{color:var(--A)}.cb{color:var(--B)}.co{color:var(--O)}.cr{color:var(--R)}.cc{color:var(--C)}

/* ─── CHARTS ─── */
.charts-row{display:grid;grid-template-columns:2fr 1fr;gap:14px}
.chart-h{height:240px;position:relative}
.dash-mid{display:grid;grid-template-columns:3fr 2fr;gap:14px}
.dash-bot{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.db-mid-h{height:190px;position:relative}
.db-split-wrap{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:10px}
.db-sp{background:var(--sf2);border:1px solid var(--br);border-radius:10px;padding:14px 16px;display:flex;flex-direction:column;gap:0}
.db-sp-head{display:flex;align-items:center;gap:7px;margin-bottom:10px;padding-bottom:8px;border-bottom:1px solid var(--br)}
.db-sp-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}
.db-sp-name{font-family:'Syne',sans-serif;font-size:12px;font-weight:700}
.db-sp-row{display:flex;justify-content:space-between;align-items:center;padding:5px 0;border-bottom:1px solid var(--br);font-size:11px}
.db-sp-row:last-child{border-bottom:none;padding-bottom:0}
.db-sp-lbl{color:var(--mu)}
.db-sp-val{font-family:'DM Mono',monospace;font-weight:500}

/* ─── OBIETTIVI CARD ─── */
.obj-card{background:var(--sf2);border:1px solid var(--br);border-radius:10px;padding:12px 14px}
.obj-card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:6px}
.obj-card-name{font-size:9px;text-transform:uppercase;letter-spacing:1px;font-weight:600}
.obj-card-amount{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:2px}
.obj-card-big{font-family:'Syne',sans-serif;font-size:18px;font-weight:800;color:var(--tx)}
.obj-card-target{font-size:11px;color:var(--mu)}
.obj-card-nd{font-size:10px;color:var(--mu2)}
.obj-card-progress{margin:8px 0 4px}
.obj-card-progress-hdr{display:flex;justify-content:space-between;font-size:10px;color:var(--mu);margin-bottom:3px}
.obj-card-progress-track{height:5px;background:var(--sf3);border-radius:3px}
.obj-card-progress-fill{height:5px;border-radius:3px;max-width:100%;transition:width .5s}
.obj-card-monthly{font-size:10px;color:var(--mu)}
.obj-card-proj{margin-top:6px;padding-top:6px;border-top:1px solid var(--br)}
.obj-card-proj-row{display:flex;justify-content:space-between;font-size:10px}
.obj-card-proj-lbl{color:var(--mu)}
.obj-card-proj-val{font-family:'DM Mono',monospace;font-weight:600;color:var(--A)}
.obj-card-scarto{font-size:9px;margin-top:2px}
.mom-badge{font-size:10px;padding:2px 6px;border-radius:4px}
.mom-badge.pos{background:rgba(82,178,112,.15);color:var(--st-ok)}
.mom-badge.neg{background:var(--Rd);color:var(--R)}

/* ─── PIVA SETTINGS GRID ─── */
#piva-settings-cards{grid-column:1/-1;display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:16px}

/* IVA */
.iva-big{font-family:'Syne',sans-serif;font-size:30px;font-weight:800;color:var(--O);line-height:1}
.iva-sub{font-size:11px;color:var(--mu);margin-top:4px;margin-bottom:12px}
.deadline-pill{display:flex;align-items:center;gap:8px;padding:8px 10px;border-radius:7px;font-size:11px;margin-top:6px;border:1px solid;font-weight:500;cursor:default}
.dl-far{background:rgba(107,108,132,.07);border-color:var(--br);color:var(--mu)}
.dl-med{background:var(--Od);border-color:rgba(255,124,64,.3);color:var(--O)}
.dl-close{background:rgba(255,77,106,.1);border-color:rgba(255,77,106,.4);color:var(--R)}
.dl-urgent{background:rgba(255,77,106,.18);border-color:var(--R);color:var(--R);animation:puls 1.5s infinite}
.dl-past{background:rgba(107,108,132,.05);border-color:var(--br);color:var(--mu2)}
@keyframes puls{0%,100%{box-shadow:0 0 0 0 rgba(255,77,106,.3)}50%{box-shadow:0 0 0 5px rgba(255,77,106,0)}}

@keyframes savedPulse{0%{background:var(--Ad)}100%{background:transparent}}
.ev-r.just-saved{animation:savedPulse 1.2s ease-out}


/* open invoices */
.inv-row{display:flex;align-items:center;justify-content:space-between;padding:7px 0;border-bottom:1px solid var(--br);cursor:pointer;transition:.1s}
.inv-row:last-child{border-bottom:none}
.inv-row:hover{background:var(--sf2);opacity:1}
.see-all-link{font-size:10.5px;color:var(--mu);text-decoration:none;cursor:pointer}
.see-all-link:hover{color:var(--A)}
.inv-name{font-size:12px;color:var(--tx)}
.inv-meta{font-size:10px;color:var(--mu);margin-top:1px}
.inv-amt{font-size:12px;font-weight:600;color:var(--A)}

/* scadenze */
.sc-row{display:flex;align-items:flex-start;gap:9px;padding:7px 0;border-bottom:1px solid var(--br);font-size:11.5px}
.sc-row:last-child{border-bottom:none}
.sc-dot{width:6px;height:6px;border-radius:50%;margin-top:4px;flex-shrink:0}
.sc-piva{background:var(--B)}.sc-iva{background:var(--O)}.sc-consegna{background:var(--C)}
.sc-row.sc-urgent{background:var(--Rd);border-radius:6px;padding-left:6px;padding-right:6px}
.sc-row.sc-urgent .sc-name,.sc-row.sc-urgent .sc-date{color:var(--R)}
.sc-row.sc-warn{background:var(--Od);border-radius:6px;padding-left:6px;padding-right:6px}
.sc-row.sc-warn .sc-date{color:var(--O)}
.sc-info{flex:1}.sc-name{color:var(--tx);font-size:11.5px}.sc-date{color:var(--mu);font-size:10px;margin-top:1px}
.sc-cost{color:var(--O);font-size:11px;flex-shrink:0}

/* ─── PERSON SPLIT ─── */
.split-row{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.split-card{background:var(--sf);border:1px solid var(--br);border-radius:12px;padding:18px 20px}
.split-head{display:flex;align-items:center;gap:8px;margin-bottom:14px;padding-bottom:12px;border-bottom:1px solid var(--br)}
.split-head .dot{width:8px;height:8px;border-radius:50%}
.split-name{font-family:'Syne',sans-serif;font-size:13px;font-weight:700}
.split-role{font-size:10px;color:var(--mu);margin-top:1px}
.split-kpi{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:14px}
.sk{background:var(--sf2);border-radius:8px;padding:10px 12px}
.sk-l{font-size:9px;color:var(--mu);text-transform:uppercase;letter-spacing:1px;margin-bottom:3px}
.sk-v{font-family:'Syne',sans-serif;font-size:18px;font-weight:700}

/* ─── STATUS BADGES ─── */
.st-badge{display:inline-flex;align-items:center;gap:4px;font-size:10px;padding:2px 7px;border-radius:12px;border:1px solid;white-space:nowrap;font-weight:600}
.st-preventivo{background:rgba(107,108,132,.12);border-color:rgba(107,108,132,.3);color:var(--st-prev)}
.st-confermato{background:rgba(63,216,199,.1);border-color:rgba(63,216,199,.3);color:var(--st-conf)}
.st-in_corso{background:rgba(255,201,64,.1);border-color:rgba(255,201,64,.3);color:var(--st-corso)}

.st-completato{background:rgba(201,241,53,.1);border-color:rgba(201,241,53,.3);color:var(--st-comp)}
.st-in_ritardo{background:rgba(255,77,106,.1);border-color:rgba(255,77,106,.3);color:var(--st-rit)}
.st-standby{background:rgba(255,159,67,.1);border-color:rgba(255,159,67,.3);color:var(--st-stby)}
.st-rifiutato{background:rgba(107,108,132,.08);border-color:rgba(107,108,132,.2);color:var(--mu2)}

/* ─── LISTA ─── */
.toolbar{display:flex;gap:8px;flex-wrap:wrap;align-items:center}
.srch{flex:1;min-width:150px;background:var(--sf);border:1px solid var(--br);border-radius:7px;padding:7px 12px;font-family:'DM Mono',monospace;font-size:12px;color:var(--tx);outline:none;transition:border-color .15s ease,box-shadow .15s ease}
.srch:focus{border-color:var(--B);box-shadow:0 0 0 3px var(--Bd)}
.srch::placeholder{color:var(--mu2)}
.fsel{background:var(--sf);border:1px solid var(--br);border-radius:7px;padding:7px 10px;font-family:'DM Mono',monospace;font-size:11px;color:var(--tx);outline:none;cursor:pointer}
.fsel:focus{border-color:var(--B)}
.day-group{background:var(--sf);border:1px solid var(--br);border-radius:12px;overflow:hidden;border-left:3px solid var(--br2)}
.day-hdr{background:var(--sf2);padding:10px 16px;display:flex;align-items:center;gap:10px;border-bottom:1px solid var(--br)}
.day-dt{font-family:'Syne',sans-serif;font-size:13.5px;font-weight:700;min-width:140px}
.day-dt.sun{color:var(--O)}
.day-pills{display:flex;gap:6px;align-items:center;flex-wrap:wrap}
.pill-time{display:inline-flex;align-items:center;gap:4px;font-size:10px;padding:2px 7px;border-radius:12px;background:var(--Cd);color:var(--C)}
.pill-p1{display:inline-flex;align-items:center;gap:4px;font-size:10px;padding:2px 7px;border-radius:12px;background:var(--Ad);color:var(--A)}
.pill-p2{display:inline-flex;align-items:center;gap:4px;font-size:10px;padding:2px 7px;border-radius:12px;background:var(--Bd);color:var(--B)}
.day-meta-r{display:flex;gap:10px;align-items:center;margin-left:auto;font-size:11px}
.th-r{display:grid;grid-template-columns:1fr 112px 112px 88px 100px 72px 85px 112px;padding:7px 16px;border-bottom:1px solid var(--br);background:var(--sf3)}
.th{font-size:9px;text-transform:uppercase;letter-spacing:1.8px;color:var(--mu);font-weight:500}
.ev-r{display:grid;grid-template-columns:1fr 112px 112px 88px 100px 72px 85px 112px;padding:10px 16px;border-bottom:1px solid var(--br);align-items:center;cursor:pointer;transition:background .15s ease;gap:4px}
.ev-r:last-child{border-bottom:none}
.ev-r:hover{background:var(--sf2)}
.c{font-size:11.5px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.c-m{color:var(--mu)}.c-g{color:var(--A);font-weight:600}.c-o{color:var(--O)}.c-b{color:var(--B)}
.who-dot{display:inline-block;width:6px;height:6px;border-radius:50%;margin-right:3px}
.tp-tag{display:inline-block;font-size:10px;padding:2px 6px;border-radius:4px;background:var(--sf3);border:1px solid var(--br);color:var(--mu);white-space:nowrap}
.fb{display:inline-flex;align-items:center;gap:3px;font-size:10.5px;padding:3px 7px;border-radius:20px;white-space:nowrap}
.fb-s{background:var(--Ad);color:var(--A)}.fb-i{background:var(--Bd);color:var(--B)}
.fb-d{background:var(--Od);color:var(--O)}.fb-n{background:var(--sf3);color:var(--mu2)}

/* ─── CONTRATTI RICORRENTI ─── */
.kontr-summary{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin-bottom:20px}
.kontr-kpi{background:var(--sf2);border:1px solid var(--br);border-radius:10px;padding:14px 16px}
.kontr-kpi-lbl{font-size:10px;color:var(--mu);text-transform:uppercase;letter-spacing:1.2px;margin-bottom:4px}
.kontr-kpi-val{font-family:'Syne',sans-serif;font-size:20px;font-weight:700;color:var(--A)}
.kontr-kpi-sub{font-size:10px;color:var(--mu);margin-top:2px}
.kontr-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:14px;margin-top:4px}
.kontr-card{background:var(--sf);border:1px solid var(--br);border-radius:12px;padding:16px;transition:border-color .18s ease,transform .18s ease,box-shadow .18s ease}
.kontr-card:hover{border-color:var(--br2);transform:translateY(-2px);box-shadow:0 6px 22px rgba(0,0,0,.22)}
.kontr-card.sospeso{opacity:.55}
.kontr-head{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:10px}
.kontr-nome{font-family:'Syne',sans-serif;font-size:14px;font-weight:700;color:var(--tx)}
.kontr-cliente{font-size:12px;color:var(--mu);margin-top:2px}
.kontr-badge-sosp{font-size:10px;padding:2px 7px;border-radius:10px;background:var(--sf3);color:var(--mu);border:1px solid var(--br)}
.kontr-row{display:flex;justify-content:space-between;align-items:center;margin-bottom:6px;font-size:12px}
.kontr-row .kl{color:var(--mu)}
.kontr-row .kv{font-family:'DM Mono',monospace;color:var(--tx);font-weight:500}
.kontr-row .kv.pos{color:var(--A)}
.kontr-row .kv.neg{color:var(--R)}
.kontr-divider{border:none;border-top:1px solid var(--br);margin:10px 0}
.kontr-guadagno{display:flex;justify-content:space-between;align-items:center;font-size:13px;font-weight:600}
.kontr-guadagno .kl{color:var(--mu);font-size:11px;text-transform:uppercase;letter-spacing:.8px}
.kontr-collab{margin-top:10px;border-top:1px solid var(--br);padding-top:8px}
.kontr-collab-title{font-size:10px;color:var(--mu);text-transform:uppercase;letter-spacing:1px;margin-bottom:6px}
.kontr-collab-item{font-size:11px;color:var(--mu);margin-bottom:3px;padding-left:8px;position:relative}
.kontr-collab-item::before{content:'•';position:absolute;left:0;color:var(--br2)}
.kontr-collab-total{font-size:11px;color:var(--mu);margin-top:4px;font-family:'DM Mono',monospace}
.kontr-date{font-size:10px;color:var(--mu2);margin-top:8px}
.kontr-note{font-size:11px;color:var(--mu2);margin-top:8px;font-style:italic;border-top:1px solid var(--br);padding-top:8px}
.kontr-actions{display:flex;gap:8px;margin-top:12px}
.kontr-actions .btn{flex:1;font-size:11px;padding:6px 10px}
.kontr-sec-title{font-family:'Syne',sans-serif;font-size:12px;font-weight:700;color:var(--mu);text-transform:uppercase;letter-spacing:1px;margin:18px 0 10px;padding-bottom:6px;border-bottom:1px solid var(--br)}
.kontr-collab-row{display:flex;align-items:center;gap:8px;padding:6px 0;border-bottom:1px solid var(--br)}
.kontr-collab-row:last-child{border-bottom:none}
.kontr-collab-row .kcr-name{flex:1;font-size:12px;color:var(--tx)}
.kontr-collab-row .kcr-desc{font-size:11px;color:var(--mu);min-width:80px}
.kontr-collab-row .kcr-imp{font-family:'DM Mono',monospace;font-size:12px;color:var(--A);min-width:80px;text-align:right}
.kontr-collab-row .kcr-del{background:none;border:none;color:var(--mu);cursor:pointer;font-size:14px;padding:0 4px;line-height:1}
.kontr-collab-row .kcr-del:hover{color:var(--R)}
/* ── Rate mensili ─────────────────────────────────────────── */
.rate-section{margin-top:12px;border-top:1px solid var(--br);padding-top:10px}
.rate-sec-title{font-size:11px;color:var(--mu);text-transform:uppercase;letter-spacing:.8px;margin-bottom:8px}
.rate-list{display:flex;flex-direction:column;gap:4px}
.rata-row{display:flex;align-items:center;gap:8px;padding:4px 0;flex-wrap:wrap}
.rata-mese{min-width:110px;font-size:13px;color:var(--sf)}
.rata-imp{width:90px;padding:3px 6px;border:1px solid var(--br);border-radius:4px;font-size:12px;background:var(--sf3);color:var(--sf);text-align:right}
.rata-imp:focus{outline:none;border-color:var(--A)}
.rata-data-input{padding:3px 6px;border:1px solid var(--br);border-radius:4px;font-size:12px;background:var(--sf3);color:var(--sf)}
.rata-data-input:focus{outline:none;border-color:var(--A)}
.rata-badge{font-size:11px;padding:2px 8px;border-radius:10px;font-weight:600;white-space:nowrap}
.rata-verde{background:rgba(82,178,112,.15);color:#52b270}
.rata-giallo{background:rgba(212,146,42,.15);color:#D4922A}
.rata-clear{background:none;border:none;cursor:pointer;color:var(--mu);font-size:15px;padding:0 2px;line-height:1;flex-shrink:0}
.rata-clear:hover{color:var(--R)}
.rate-empty{text-align:center;padding:12px;color:var(--mu);font-size:12px}
@media(max-width:768px){
  .kontr-summary{grid-template-columns:1fr 1fr}
  .kontr-grid{grid-template-columns:1fr}
}

/* ─── COLLABORATORI ─── */
.collab-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:14px;margin-top:4px}
.collab-card{background:var(--sf);border:1px solid var(--br);border-radius:12px;padding:16px;transition:border-color .18s ease,transform .18s ease,box-shadow .18s ease}
.collab-card:hover{border-color:var(--br2);transform:translateY(-2px);box-shadow:0 6px 22px rgba(0,0,0,.22)}
.collab-nome{font-family:'Syne',sans-serif;font-size:14px;font-weight:700;color:var(--tx)}
.collab-ruolo{font-size:11px;color:var(--mu);margin-top:2px;margin-bottom:10px}
.collab-info{font-size:11px;color:var(--mu2);margin-bottom:3px}
.collab-actions{display:flex;gap:8px;margin-top:12px}
.collab-actions .btn{flex:1;font-size:11px;padding:6px 10px}
@media(max-width:768px){.collab-grid{grid-template-columns:1fr}}

/* ─── PREVENTIVO vs CONSULTIVO ─── */


/* ─── CALENDAR ─── */
.cal-nav{display:flex;align-items:center;gap:12px}
.cal-nav-t{font-family:'Syne',sans-serif;font-size:17px;font-weight:700;min-width:160px;text-align:center}
.cal-grid{background:var(--sf);border:1px solid var(--br);border-radius:12px;overflow:hidden}
.cal-wdys{display:grid;grid-template-columns:repeat(7,1fr);background:var(--sf2);border-bottom:1px solid var(--br)}
.cal-wd{padding:8px 0;text-align:center;font-size:9.5px;text-transform:uppercase;letter-spacing:1.5px;color:var(--mu)}
.cal-wd.sun{color:var(--O)}
.cal-days{display:grid;grid-template-columns:repeat(7,1fr)}
.cc{min-height:110px;border-right:1px solid var(--br);border-bottom:1px solid var(--br);padding:6px;overflow:hidden;position:relative}
.cc:nth-child(7n){border-right:none}
.cc.other{background:rgba(255,255,255,.008)}
.cc.today{background:rgba(201,241,53,.025);outline:1px inset rgba(201,241,53,.15)}
.cc:not(.other){cursor:pointer}
.cc:not(.other):hover{background:rgba(255,255,255,.025)}
.cc.dragover{background:rgba(201,241,53,.08)!important;outline:1px dashed var(--A)}
.cc-num{font-size:11px;font-weight:600;color:var(--mu);margin-bottom:3px;display:flex;justify-content:space-between;align-items:center}
.cc.today .cc-num{color:var(--A)}.cc.sun-c .cc-num{color:var(--O)}
.cc-time{font-size:9px;padding:2px 4px;border-radius:3px;background:var(--Cd);color:var(--C);margin-bottom:3px;display:inline-block}
.cc-ev{padding:2px 5px;border-radius:3px;font-size:9.5px;margin-bottom:2px;cursor:grab;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;display:flex;align-items:center;gap:3px;border-left:2px solid;transition:.1s}
.cc-ev:hover{filter:brightness(1.3)}
.cc-md{font-size:8px;opacity:.7;margin-left:3px;flex-shrink:0}
.cc-ev.md-span{border-color:#4A9ECC;background:rgba(74,158,204,.18);color:#6AB8D8}
[data-theme="light"] .cc-ev.md-span{border-color:#2563EB;background:rgba(37,99,235,.1);color:#1E40AF}
.cc-ev.p1r{border-color:var(--A);background:var(--Ad);color:var(--A)}
.cc-ev.p1n{border-color:rgba(212,146,42,.4);background:rgba(212,146,42,.07);color:rgba(212,146,42,.72)}
.cc-ev.p2r{border-color:var(--B);background:var(--Bd);color:#E8896A}
.cc-ev.p2n{border-color:rgba(196,52,26,.4);background:rgba(196,52,26,.07);color:rgba(196,52,26,.72)}
.cc-ev.saldato::after{content:"✓";font-size:8px;margin-left:auto;flex-shrink:0;opacity:.7}
.cc-more{font-size:9.5px;color:var(--mu);margin-top:1px;cursor:pointer}.cc-more:hover{color:var(--B)}
.cc-who{width:5px;height:5px;border-radius:50%;flex-shrink:0}
.cc-consegna{background:var(--Cd);border-color:var(--C);color:var(--C);border-left:2px solid var(--C)}

/* ─── LISTA VIEWS ─── */
.view-sw{display:flex;gap:0;border:1px solid var(--br);border-radius:7px;overflow:hidden}
.view-sw button{padding:6px 12px;font-family:'DM Mono',monospace;font-size:11px;border:none;cursor:pointer;background:transparent;color:var(--mu);transition:background .15s ease,color .15s ease;white-space:nowrap}
.view-sw button:hover:not(.on){color:var(--tx);background:rgba(255,255,255,.04)}
.view-sw button:active{transform:scale(0.96)}
.view-sw button.on{background:var(--sf2);color:var(--tx)}
.kanban-wrap{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:12px;align-items:start}
.kanban-col{background:var(--sf);border:1px solid var(--br);border-radius:12px;overflow:hidden}
.kanban-col-hdr{padding:10px 14px;border-bottom:1px solid var(--br);display:flex;align-items:center;justify-content:space-between}
.kanban-col-title{font-family:'Syne',sans-serif;font-size:12px;font-weight:700}
.kanban-cnt{font-size:10px;padding:1px 6px;border-radius:8px;background:var(--sf2);color:var(--mu)}
.kanban-items{padding:8px;display:flex;flex-direction:column;gap:6px}
.kanban-item{background:var(--sf2);border:1px solid var(--br);border-radius:8px;padding:10px 12px;cursor:pointer;transition:border-color .16s ease,background .16s ease,transform .1s ease,box-shadow .16s ease}
.kanban-item:hover{border-color:var(--br2);background:var(--sf3);transform:translateY(-1px);box-shadow:0 3px 10px rgba(0,0,0,.15)}
.kanban-item:active{transform:scale(0.98)}
.kanban-item-client{font-size:12px;font-weight:600;color:var(--tx);margin-bottom:3px}
.kanban-item-meta{font-size:10px;color:var(--mu);line-height:1.5}
.cc-ev.opz{border-color:rgba(107,108,132,.4);background:rgba(107,108,132,.06);color:var(--mu);font-style:italic}
.quick-note{width:100%;background:var(--bg);border:1px solid var(--br);border-radius:7px;padding:8px 12px;font-family:'DM Mono',monospace;font-size:12px;color:var(--tx);outline:none;resize:vertical;min-height:60px;transition:.15s;margin-top:4px}
.quick-note:focus{border-color:var(--B)}
.prev-card{background:var(--sf);border:1px solid var(--br);border-radius:10px;padding:16px 18px;display:flex;align-items:flex-start;gap:12px;cursor:pointer;transition:background .16s ease,border-color .16s ease,transform .1s ease,box-shadow .16s ease;flex-wrap:wrap}
.prev-card:hover{background:var(--sf2);border-color:var(--br2);transform:translateY(-1px);box-shadow:0 4px 14px rgba(0,0,0,.16)}
.prev-card:active{transform:scale(0.99)}
.prev-card.rifiutato{opacity:.5}
.prev-card-info{flex:1;min-width:0}
.prev-card-client{font-size:13px;font-weight:600;color:var(--tx);margin-bottom:3px}
.prev-card-meta{font-size:10.5px;color:var(--mu)}
.prev-card-imp{font-family:'Syne',sans-serif;font-size:16px;font-weight:700;color:var(--C);text-align:right}
.prev-card-actions{display:flex;gap:6px;flex-shrink:0;align-items:flex-start}

/* ─── CALENDAR TABS ─── */
.cal-tabs{display:flex;gap:0;border:1px solid var(--br);border-radius:7px;overflow:hidden;max-width:280px}
.cal-tab{flex:1;padding:6px 12px;text-align:center;font-size:11px;cursor:pointer;background:transparent;border:none;color:var(--mu);transition:background .15s ease,color .15s ease;font-family:'DM Mono',monospace}
.cal-tab:hover:not(.on){color:var(--tx);background:rgba(255,255,255,.04)}
.cal-tab:active{transform:scale(0.96)}
.cal-tab.on{background:var(--sf2);color:var(--tx)}

/* ─── SETTINGS ─── */
.settings-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.set-card{background:var(--sf);border:1px solid var(--br);border-radius:12px;padding:20px 22px}
.set-title{font-family:'Syne',sans-serif;font-size:13px;font-weight:700;margin-bottom:16px;padding-bottom:12px;border-bottom:1px solid var(--br);display:flex;align-items:center;gap:8px}
.set-dot{width:8px;height:8px;border-radius:50%}
.fg{display:flex;flex-direction:column;gap:5px;margin-bottom:12px}
.fl{font-size:12px;color:var(--mu);text-transform:uppercase;letter-spacing:1px}
.fi{width:100%;background:var(--bg);border:1px solid var(--br);border-radius:7px;padding:8px 12px;font-family:'DM Mono',monospace;font-size:12px;color:var(--tx);outline:none;transition:border-color .15s ease,box-shadow .15s ease}
.fi:focus{border-color:var(--B);box-shadow:0 0 0 3px var(--Bd)}
.fi.err{border-color:var(--R)!important;background:var(--Rd)}

.fg2{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.set-full{grid-column:1/-1}
.save-row{display:flex;justify-content:flex-end;margin-top:4px}
.scad-admin{margin-top:16px}
.scad-adm-row{display:flex;align-items:center;gap:8px;margin-bottom:8px}
.scad-adm-row .fi{flex:1}
.scad-list-admin{display:flex;flex-direction:column;gap:6px;max-height:220px;overflow-y:auto}
.scad-adm-item{display:flex;align-items:center;gap:8px;background:var(--sf2);padding:8px 10px;border-radius:7px;border:1px solid var(--br)}
.scad-adm-info{flex:1;min-width:0}
.scad-adm-name{font-size:12px;color:var(--tx)}
.scad-adm-meta{font-size:10px;color:var(--mu)}
.scad-adm-del{background:none;border:none;cursor:pointer;color:var(--mu2);font-size:14px;padding:2px 4px;border-radius:4px;transition:.1s}
.scad-adm-del:hover{color:var(--R);background:var(--Rd)}

/* ─── JOB TYPES ADMIN ─── */
.tipo-tag-list{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:10px}
.tipo-tag{display:inline-flex;align-items:center;gap:5px;background:var(--sf2);border:1px solid var(--br);border-radius:6px;padding:4px 8px;font-size:11px;color:var(--tx)}
.tipo-tag-del{background:none;border:none;color:var(--mu2);cursor:pointer;font-size:12px;padding:0 2px;line-height:1}
.tipo-tag-del:hover{color:var(--R)}

/* ─── CLIENTI ─── */
.client-card{background:var(--sf);border:1px solid var(--br);border-radius:12px;padding:18px 20px;transition:border-color .18s ease,transform .18s ease,box-shadow .18s ease}
.client-card:hover{border-color:var(--br2);transform:translateY(-2px);box-shadow:0 6px 22px rgba(0,0,0,.22)}
.client-name{font-family:'Syne',sans-serif;font-size:14px;font-weight:700;margin-bottom:4px}
.client-meta{font-size:10px;color:var(--mu);margin-bottom:12px}
.contact-row{display:flex;align-items:flex-start;gap:10px;padding:8px 0;border-bottom:1px solid var(--br)}
.contact-row:last-child{border-bottom:none}
.contact-role{font-size:9px;text-transform:uppercase;letter-spacing:1px;padding:2px 6px;border-radius:4px;background:var(--sf3);border:1px solid var(--br);color:var(--mu);white-space:nowrap;flex-shrink:0}
.contact-info{flex:1;min-width:0}
.contact-nome{font-size:12px;color:var(--tx);font-weight:600}
.contact-details{font-size:10.5px;color:var(--mu);margin-top:2px}
.clients-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:14px}

/* ─── CONSEGNE ─── */
.cons-card{background:var(--sf);border:1px solid var(--br);border-radius:10px;padding:14px 16px;display:flex;align-items:center;gap:14px;cursor:pointer;transition:background .16s ease,border-color .16s ease,transform .1s ease,box-shadow .16s ease}
.cons-card:hover{background:var(--sf2);border-color:var(--br2);transform:translateY(-1px);box-shadow:0 4px 14px rgba(0,0,0,.16)}
.cons-card:active{transform:scale(0.99)}
.cons-date-block{background:var(--sf2);border-radius:8px;padding:8px 12px;text-align:center;min-width:56px;flex-shrink:0}
.cons-day{font-family:'Syne',sans-serif;font-size:20px;font-weight:700;line-height:1}
.cons-mon{font-size:9px;text-transform:uppercase;letter-spacing:1px;color:var(--mu);margin-top:2px}
.cons-info{flex:1;min-width:0}
.cons-client{font-size:13px;font-weight:600;color:var(--tx)}
.cons-tipo{font-size:11px;color:var(--mu);margin-top:2px}
.cons-st-prevista{color:var(--C)}.cons-st-ritardata{color:var(--R)}.cons-st-consegnata{color:var(--A)}
.cons-badge{display:inline-flex;align-items:center;gap:4px;font-size:10px;padding:2px 7px;border-radius:12px;border:1px solid;white-space:nowrap}
.csb-prevista{background:rgba(63,216,199,.1);border-color:rgba(63,216,199,.3);color:var(--C)}
.csb-ritardata{background:rgba(255,77,106,.1);border-color:rgba(255,77,106,.3);color:var(--R)}
.csb-consegnata{background:rgba(201,241,53,.1);border-color:rgba(201,241,53,.3);color:var(--A)}

/* ─── CALCOLATORE ─── */
.calc-wrap{display:grid;grid-template-columns:1fr 1fr;gap:16px;max-width:860px}
.calc-p{background:var(--sf);border:1px solid var(--br);border-radius:12px;padding:24px}
.calc-t{font-family:'Syne',sans-serif;font-size:14px;font-weight:700;margin-bottom:18px}
.tog{display:flex;border:1px solid var(--br);border-radius:7px;overflow:hidden;margin-bottom:14px}
.tog button{flex:1;padding:7px;font-family:'DM Mono',monospace;font-size:11px;border:none;cursor:pointer;background:transparent;color:var(--mu);transition:background .16s ease,color .16s ease,box-shadow .16s ease;font-weight:500}
.tog button:hover:not(.on){color:var(--tx);background:rgba(255,255,255,.04)}
.tog button:active{transform:scale(0.96)}
.tog button.on{background:var(--A);color:#09090c;font-weight:700;box-shadow:inset 0 -2px 0 rgba(0,0,0,.15)}
.cr-wrap{background:var(--sf2);border:1px solid var(--br);border-radius:12px;padding:24px;display:flex;flex-direction:column;gap:0}
.cr-row{display:flex;align-items:baseline;justify-content:space-between;padding:10px 0;border-bottom:1px solid var(--br)}
.cr-row:last-child{border-bottom:none}
.cr-l{font-size:10px;color:var(--mu);text-transform:uppercase;letter-spacing:1px}
.cr-f{font-size:10px;color:var(--mu2);font-style:italic;margin-top:2px}
.cr-v{font-family:'Syne',sans-serif;font-size:20px;font-weight:700}
.cr-big{font-size:30px!important;color:var(--A)!important}
.cr-iva{color:var(--O)}.cr-riten{color:var(--R)}.cr-net{color:var(--tx)}.cr-tax{color:var(--R)}

/* ─── MODAL ─── */
#overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,.78);z-index:300;align-items:center;justify-content:center}
#overlay.on{display:flex}
.modal{background:var(--sf);border:1px solid var(--br);border-radius:14px;width:680px;max-width:95vw;max-height:88vh;overflow-y:auto;padding:26px;position:relative}
.mx{position:absolute;top:12px;right:12px;background:var(--sf2);border:1px solid var(--br);border-radius:5px;min-width:44px;min-height:44px;cursor:pointer;color:var(--mu);font-size:13px;display:flex;align-items:center;justify-content:center;transition:.12s}
.mx:hover{color:var(--tx);background:var(--br)}
.mt{font-family:'Syne',sans-serif;font-size:17px;font-weight:700;margin-bottom:20px;padding-right:60px;color:var(--A)}
.fg2m{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.fg3m{display:grid;grid-template-columns:1fr 1fr 1fr;gap:12px}
.fsel2{width:100%;background:var(--bg);border:1px solid var(--br);border-radius:7px;padding:8px 12px;font-family:'DM Mono',monospace;font-size:12px;color:var(--tx);outline:none;cursor:pointer}
.fsel2:focus{border-color:var(--B)}
.mfooter{display:flex;justify-content:flex-end;gap:8px;margin-top:18px;padding-top:16px;border-top:1px solid var(--br)}
.btn-del{background:transparent;border:1px solid rgba(255,77,106,.3);color:var(--R);font-family:'DM Mono',monospace;font-size:11px;padding:6px 12px;border-radius:6px;cursor:pointer;transition:.12s}
.btn-del:hover{background:var(--Rd)}
.det-g{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:16px}
.det-f .dl{font-size:9.5px;color:var(--mu);text-transform:uppercase;letter-spacing:1.5px;margin-bottom:3px}
.det-f .dv{font-size:13px;color:var(--tx)}.det-f .dv.emp{color:var(--mu2);font-style:italic}
.msec{font-family:'Syne',sans-serif;font-size:12px;font-weight:700;margin:16px 0 10px;padding-bottom:8px;border-bottom:1px solid var(--br);color:var(--mu);text-transform:uppercase;letter-spacing:1px}
.day-toggle{display:flex;border:1px solid var(--br);border-radius:8px;overflow:hidden;margin-bottom:14px}
.day-toggle button{flex:1;padding:8px;font-family:'DM Mono',monospace;font-size:11px;border:none;cursor:pointer;background:transparent;color:var(--mu);transition:.12s;font-weight:500}
.day-toggle button.on{background:var(--A);color:#09090c;font-weight:700}

/* multi-date */
.date-list{display:flex;flex-direction:column;gap:6px;margin-bottom:8px}
.date-item{display:flex;align-items:center;gap:8px;background:var(--sf2);padding:6px 10px;border-radius:6px;font-size:11px}
.date-item-lbl{flex:1;color:var(--tx)}
.date-item-del{background:none;border:none;color:var(--mu2);cursor:pointer;font-size:13px}
.date-item-del:hover{color:var(--R)}
.date-add-row{display:flex;gap:8px;align-items:center;flex-wrap:wrap}

/* tipo dropdown */
.tdd{position:relative}
.tdd-list{position:absolute;top:calc(100%+3px);left:0;right:0;background:var(--sf2);border:1px solid var(--br2);border-radius:8px;z-index:100;max-height:170px;overflow-y:auto;display:none}
.tdd-list.on{display:block}
.tdd-i{padding:7px 11px;font-size:12px;cursor:pointer;transition:.1s}
.tdd-i:hover{background:var(--sf3);color:var(--A)}

/* toast */
#toast{position:fixed;bottom:24px;right:24px;background:var(--sf2);border:1px solid var(--A);color:var(--A);padding:10px 18px;border-radius:8px;font-size:12px;z-index:9999;opacity:0;transform:translateY(8px);transition:.25s;pointer-events:none;max-width:320px}
#toast.on{opacity:1;transform:translateY(0)}

/* empty */
.empty{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:40px;color:var(--mu);gap:8px;font-size:12.5px}
.empty .ei{font-size:32px;opacity:.25}

/* ═══════════════════════════════
   MOBILE
═══════════════════════════════ */
#mob-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,.6);z-index:190;backdrop-filter:blur(2px)}
#mob-overlay.on{display:block}
.ham-btn{display:none;background:none;border:none;color:var(--tx);font-size:20px;cursor:pointer;padding:6px 8px;line-height:1;flex-shrink:0}
#bottom-nav{display:none;position:fixed;bottom:0;left:0;right:0;height:60px;background:var(--sf);border-top:1px solid var(--br);z-index:180;flex-direction:row;align-items:stretch}
.bn-item{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;background:none;border:none;color:var(--mu);cursor:pointer;transition:.12s;font-family:'DM Mono',monospace;-webkit-tap-highlight-color:transparent}
.bn-item:active{background:var(--sf2)}.bn-item.on{color:var(--A)}
.bn-ico{font-size:18px;line-height:1}.bn-lbl{font-size:8px;letter-spacing:.3px}

#month-strip{display:none;overflow-x:auto;gap:6px;padding:8px 14px 0;flex-shrink:0;-webkit-overflow-scrolling:touch;scrollbar-width:none}
#month-strip::-webkit-scrollbar{display:none}
.ms-btn{flex-shrink:0;padding:5px 12px;border-radius:20px;border:1px solid var(--br);background:var(--sf);color:var(--mu);font-family:'DM Mono',monospace;font-size:11px;cursor:pointer;white-space:nowrap;transition:.12s;-webkit-tap-highlight-color:transparent}
.ms-btn.on{background:var(--Ad);color:var(--A);border-color:var(--Ab)}

/* ─── DESKTOP STRETTO: progressive disclosure topbar ─── */
/* < 1640px: nasconde indicatore persona (ridondante col sidebar) + Esporta + label tema.
   Soglia: con month-nav ~395px e tbar-r completa ~500px, la colonna 1fr ≥ 484px
   solo a partire da W ≥ 1640px → overlap residuo ≤ 16px (accettabile con overflow:visible) */
@media(min-width:769px) and (max-width:1639px){
  .person-indicator{display:none}
  .tbar-r .btn-g{display:none}
  .theme-sw-ico{display:none}
}
/* < 1200px: nasconde navigazione anno per compattare il centro (226px vs 395px).
   Soglia aggiornata: con tbar-r compatta (238px) il 1fr disponibile a 1200px è ~264px,
   margine di 26px rispetto al contenuto — sicuro senza clip */
@media(min-width:769px) and (max-width:1199px){
  .mna-sep,.mna-year,.mna-yr-arr{display:none}
}

@media(max-width:768px){
  body{overflow:hidden}
  .ham-btn{display:flex;align-items:center}
  #bottom-nav{display:flex}
  #sidebar{position:fixed;left:0;top:0;bottom:0;transform:translateX(-100%);box-shadow:none;z-index:200}
  #sidebar.open{transform:translateX(0);box-shadow:4px 0 40px rgba(0,0,0,.5)}
  #sidebar .msep,#sidebar .nav-sec:last-of-type,#sidebar .mi{display:none}
  #main{width:100%;padding-bottom:60px}
  #topbar{padding:0 14px;height:52px}
  #ptitle{font-size:14px}
  .person-indicator{display:none}
  .page{padding:14px;gap:14px}
  .kpi-row{grid-template-columns:1fr 1fr!important;gap:10px}
  .kpi-row .kpi:last-child:nth-child(odd){grid-column:1/-1;max-width:50%;justify-self:center}
  .kpi{padding:14px}.kpi-v{font-size:22px}.kpi-l{font-size:9px}.kpi-s{font-size:9.5px}
  .charts-row,.dash-mid{grid-template-columns:1fr!important}
  .chart-h{height:180px}
  .db-mid-h{height:160px}
  .split-row{grid-template-columns:1fr!important}
  .dash-bot{grid-template-columns:1fr!important}
  .db-split-wrap{grid-template-columns:1fr 1fr!important}
  #piva-settings-cards{grid-template-columns:1fr!important}
  .card-p{padding:14px}
  .toolbar{gap:8px}
  .srch{min-width:100%;font-size:16px!important}
  .fsel{font-size:16px!important;flex:1}
  .day-hdr{flex-wrap:wrap;gap:6px;padding:8px 12px}
  .day-meta-r{margin-left:0;width:100%}
  .th-r{display:none}
  .ev-r{grid-template-columns:1fr 1fr!important;grid-template-rows:auto auto auto;gap:4px 8px;padding:10px 12px}
  .ev-r .c:nth-child(1){grid-column:1/-1;font-size:13px;font-weight:600}
  .ev-r .c:nth-child(2){grid-column:1/2}
  .ev-r .c:nth-child(3){grid-column:2/3}
  .ev-r .c:nth-child(4){grid-column:1/-1;font-size:10px;color:var(--mu)}
  .ev-r .c:nth-child(5){display:none}
  .ev-r .c:nth-child(6){display:none}
  .ev-r .c:nth-child(7){grid-column:1/-1;font-size:13px;font-weight:600;color:var(--A)}
  .ev-r .c:nth-child(8){grid-column:1/-1}
  .cc{min-height:72px;padding:4px}.cc-num{font-size:10px}.cc-ev{font-size:8.5px;padding:1px 3px}
  .cc-time{font-size:8px;padding:1px 3px}.cal-wd{font-size:8.5px;padding:6px 0}.cal-nav-t{font-size:15px}
  .calc-wrap{grid-template-columns:1fr!important;max-width:100%}
  .cr-v{font-size:16px!important}.cr-big{font-size:24px!important}
  .settings-grid{grid-template-columns:1fr!important}
  .scad-adm-row{flex-wrap:wrap}.scad-adm-row .fi{min-width:0;flex:1 1 100%}.scad-adm-row .btn{width:100%}
  .fg2{grid-template-columns:1fr!important}.fg2m{grid-template-columns:1fr 1fr!important}.fg3m{grid-template-columns:1fr!important}
  .modal{width:100%!important;max-width:100%!important;margin:0;border-radius:16px 16px 0 0!important;max-height:90vh!important;padding:20px 16px!important;position:fixed!important;bottom:0!important;left:0!important;top:auto!important;transform:none!important}
  #overlay{align-items:flex-end!important}
  .fi,.fsel2{font-size:16px!important}
  .btn{padding:8px 12px;font-size:12px}
  .tbar-r .btn-g{display:none}
  .split-kpi{grid-template-columns:1fr 1fr}
  #month-strip{display:flex}
  .clients-grid{grid-template-columns:1fr!important}
  #sidebar-close-btn{display:flex!important;align-items:center;justify-content:center}
  .ni{padding:12px 18px;font-size:13px}
  .ptab{padding:10px 4px;font-size:12px}
  /* Toolbar mobile: filtri su riga separata */
  .toolbar{gap:6px}
  .view-sw button{padding:5px 9px;font-size:10px}
  #prev-status-sw{overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none;flex-wrap:nowrap;max-width:calc(100vw - 28px)}
  #prev-status-sw::-webkit-scrollbar{display:none}
  /* Kanban compatto */
  .kanban-wrap{grid-template-columns:repeat(2,1fr)}
  /* Consegne card */
  .cons-card{gap:10px}
  /* Safe area iPhone */
  #bottom-nav{padding-bottom:env(safe-area-inset-bottom)}
  /* Month nav: nascosto nel topbar su mobile, la striscia #month-strip gestisce il mobile */
  #topbar .month-nav{display:none}
  #month-strip{display:flex}
}

/* ─── DASHBOARD & PAGE ANIMATIONS ─── */
@keyframes kpiReveal{
  from{opacity:0;transform:translateY(20px) scale(.96)}
  to{opacity:1;transform:translateY(0) scale(1)}
}
@keyframes pageIn{
  from{opacity:0;transform:translateY(10px)}
  to{opacity:1;transform:translateY(0)}
}
@keyframes shimmerPass{
  from{transform:translateX(-110%) skewX(-15deg)}
  to{transform:translateX(230%) skewX(-15deg)}
}
@keyframes kpiGlowPulse{
  0%,100%{opacity:.08}50%{opacity:.18}
}
@keyframes floatIn{
  from{opacity:0;transform:translateX(-8px)}
  to{opacity:1;transform:translateX(0)}
}
.page.on{animation:pageIn .38s cubic-bezier(.22,1,.36,1) both}
.kpi{transition:transform .22s cubic-bezier(.22,1,.36,1),border-color .15s,box-shadow .22s}
.kpi::before{content:'';position:absolute;inset:0;background:linear-gradient(90deg,transparent,rgba(255,255,255,.05),transparent);transform:translateX(-110%) skewX(-15deg);pointer-events:none;z-index:1;border-radius:inherit}
.kpi:hover{transform:translateY(-4px);border-color:var(--br2);box-shadow:0 10px 32px rgba(0,0,0,.28)}
.kpi:hover::before{animation:shimmerPass .3s ease forwards}
.kpi:hover .kpi-glow{animation:kpiGlowPulse 1.2s ease-in-out infinite}
[data-theme="light"] .kpi:hover{box-shadow:0 6px 20px rgba(0,0,0,.12)}
.kpi-v{transition:color .25s}
.split-card{transition:border-color .18s,box-shadow .22s,transform .22s cubic-bezier(.22,1,.36,1)}
.split-card:hover{border-color:var(--br2);transform:translateY(-2px);box-shadow:0 6px 22px rgba(0,0,0,.2)}
[data-theme="light"] .split-card:hover{box-shadow:0 4px 14px rgba(0,0,0,.08)}
.sk{transition:background .15s,transform .18s}
.sk:hover{background:var(--sf3)!important;transform:scale(1.04)}
.inv-row{transition:transform .15s ease,background .12s!important}
.inv-row:hover{transform:translateX(4px)}
.sc-row{transition:background .12s,border-radius .12s}
.card-title{position:relative}
.kpi-row .kpi:nth-child(1){--reveal-delay:0ms}
.kpi-row .kpi:nth-child(2){--reveal-delay:70ms}
.kpi-row .kpi:nth-child(3){--reveal-delay:140ms}
.kpi-row .kpi:nth-child(4){--reveal-delay:210ms}
.kpi-row .kpi:nth-child(5){--reveal-delay:280ms}
.dash-bot .card,.split-row .split-card,.charts-row .card{
  transition:border-color .18s,box-shadow .2s,transform .2s cubic-bezier(.22,1,.36,1)
}
.dash-bot .card:hover,.charts-row .card:hover{
  border-color:var(--br2);box-shadow:0 4px 18px rgba(0,0,0,.16);transform:translateY(-1px)
}
[data-theme="light"] .dash-bot .card:hover,[data-theme="light"] .charts-row .card:hover{
  box-shadow:0 3px 12px rgba(0,0,0,.08)
}

/* ─── LOGIN SCREEN ─── */
#login-screen{
  position:fixed;inset:0;z-index:9999;
  background:var(--bg);
  display:flex;align-items:center;justify-content:center;
}
#login-screen.hidden{display:none}
.login-box{
  background:var(--sf2);
  border:1px solid var(--br);
  border-radius:12px;
  padding:40px 44px 36px;
  width:340px;max-width:94vw;
  display:flex;flex-direction:column;gap:20px;
}
.login-logo{
  font-family:'Syne',sans-serif;
  font-size:22px;font-weight:800;
  color:var(--tx);letter-spacing:-.5px;
  text-align:center;margin-bottom:4px;
}
.login-logo span{color:var(--A)}
.login-sub{
  font-size:11px;color:var(--mu);
  text-align:center;letter-spacing:.5px;
  text-transform:uppercase;margin-top:-14px;
}
#login-form{display:flex;flex-direction:column;gap:20px}
.login-field{display:flex;flex-direction:column;gap:6px}
.login-label{font-size:11px;color:var(--mu);letter-spacing:.5px;text-transform:uppercase}
.login-input{
  background:var(--sf3);border:1px solid var(--br);
  border-radius:6px;padding:10px 14px;
  color:var(--tx);font-size:14px;outline:none;
  transition:border-color .2s;
}
.login-input:focus{border-color:var(--A)}
.login-btn{
  background:var(--B);color:#fff;
  border:none;border-radius:6px;
  padding:12px;font-size:14px;font-weight:600;
  cursor:pointer;transition:background .2s;margin-top:4px;
  width:100%;font-family:'Syne',sans-serif;
}
.login-btn:hover{background:var(--O)}
.login-err{
  font-size:12px;color:var(--B);
  text-align:center;min-height:18px;
}
.btn-logout{
  background:transparent;border:1px solid var(--br2);
  color:var(--mu);border-radius:6px;
  padding:6px 12px;font-size:12px;cursor:pointer;
  display:inline-flex;align-items:center;gap:5px;
  transition:border-color .16s ease,color .16s ease,transform .09s ease;
}
.btn-logout:hover{border-color:var(--B);color:var(--B)}
.btn-logout:active{transform:scale(0.95)}

/* ─── INTERACTIVE ENHANCEMENTS ─── */
/* Day-group toggle buttons */
.day-toggle button{transition:background .16s ease,color .16s ease,box-shadow .16s ease}
.day-toggle button:active{transform:scale(0.95)}
/* Inv rows */
.inv-row{transition:background .15s ease,transform .15s ease}
.inv-row:hover{transform:translateX(4px)}
/* Fsel */
.fsel{transition:border-color .15s ease,box-shadow .15s ease}
.fsel:focus{box-shadow:0 0 0 3px var(--Bd)}
/* Delete small buttons */
.scad-adm-del{transition:color .15s ease,background .15s ease;border-radius:4px}
.kcr-del{transition:color .15s ease}

/* prefers-reduced-motion */
@media(prefers-reduced-motion:reduce){
  *{transition-duration:.01ms!important;animation-duration:.01ms!important;animation-iteration-count:1!important}
}

/* ── VIEWER MODE ──────────────────────────────────────────────── */
body.viewer-mode .ni:not(#ni-calendar)              { display: none !important; }
body.viewer-mode #topbar .btn-p                     { display: none !important; }
body.viewer-mode #topbar .btn-g                     { display: none !important; }
body.viewer-mode #bottom-nav .bn-item:not(#bn-calendar) { display: none !important; }
body.viewer-mode #sec-card                          { display: none !important; }

/* ── Colori principio di cassa ── */
.ic-green { color: #52b270; }
.ic-yellow { color: #D4922A; }
.ic-grey   { color: #6b6259; }

.kpi-inc-green { border-left: 3px solid #52b270; }
.kpi-inc-yellow { border-left: 3px solid #D4922A; }

/* Fatture aperte scadute (>30gg) */
.inv-overdue .inv-name { color: var(--R); }
.inv-overdue .inv-amt  { color: var(--R) !important; }

/* Filter row dashboard */
.dash-filter-row {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 10px 14px;
  background: var(--sf2);
  border-radius: 8px;
  border: 1px solid var(--br);
  margin-bottom: 14px;
  flex-wrap: wrap;
}

/* ─── ACCESSIBILITÀ ─── */
.sr-only{position:absolute;width:1px;height:1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}

/* ─── LUCIDE SVG ICONS ─── */
.ic{display:inline-flex;align-items:center;justify-content:center;line-height:0}
.ic svg{display:block;flex-shrink:0;stroke:currentColor}
.bn-ico{display:flex;align-items:center;justify-content:center;line-height:0}
.bn-ico svg{display:block;width:20px;height:20px;stroke:currentColor}

/* ─── PASSWORD TOGGLE ─── */
.pw-wrap{position:relative}
.pw-wrap .login-input,.pw-wrap .fi{padding-right:44px!important;width:100%}
.pw-toggle{position:absolute;right:8px;top:50%;transform:translateY(-50%);background:none;border:none;color:var(--mu);cursor:pointer;padding:6px;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:color .15s ease;line-height:0;min-width:32px;min-height:32px}
.pw-toggle:hover{color:var(--tx)}
.pw-toggle svg{display:block;width:16px;height:16px;stroke:currentColor;fill:none}

/* ─── DASHBOARD DENSITY ─── */
#page-dashboard{gap:14px}
#page-dashboard .card-p{padding:16px 18px}
#page-dashboard .card-title{margin-bottom:10px}
#page-dashboard .kpi{padding:13px 15px}
#page-dashboard .kpi-v{font-size:24px}
#page-dashboard .kpi-l{margin-bottom:4px}
#page-dashboard .kpi-dir{font-size:17px;top:11px;right:13px}
#page-dashboard .db-split-wrap{grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:8px}
#page-dashboard .db-sp{padding:10px 12px}
#page-dashboard .db-sp-head{margin-bottom:7px;padding-bottom:6px}
#page-dashboard .db-sp-row{padding:3px 0;font-size:10.5px}
#page-dashboard .obj-card{padding:10px 12px}
#page-dashboard .obj-card-big{font-size:16px}
#page-dashboard .obj-card-progress{margin:6px 0 3px}
