/* ── TOKENS ─────────────────────────────────────────────────── */
:root,[data-theme="dark"]{
  --color-bg:#090d1a;
  --color-surface:#0f1629;
  --color-surface-2:#131d35;
  --color-surface-offset:#1a2540;
  --color-surface-dynamic:#1e2b4a;
  --color-divider:#1e2d4d;
  --color-border:#243355;
  --color-text:#e2e8f8;
  --color-text-muted:#7b8db8;
  --color-text-faint:#3d4f72;
  --color-text-inverse:#090d1a;
  --color-primary:#128C7E;
  --color-primary-hover:#075E54;
  --color-primary-hl:rgba(18,140,126,0.15);
  --color-green:#34d399;--color-green-bg:rgba(52,211,153,0.12);
  --color-yellow:#fbbf24;--color-yellow-bg:rgba(251,191,36,0.12);
  --color-red:#f87171;--color-red-bg:rgba(248,113,113,0.12);
  --color-blue:#60a5fa;--color-blue-bg:rgba(96,165,250,0.12);
  --color-gray:#64748b;--color-gray-bg:rgba(100,116,139,0.12);
  --shadow-sm:0 1px 3px rgba(0,0,0,0.4);
  --shadow-md:0 4px 20px rgba(0,0,0,0.5);
  --shadow-glow:0 0 24px rgba(18,140,126,0.08);
  --r-sm:.375rem;--r-md:.5rem;--r-lg:.75rem;--r-xl:1rem;--r-full:9999px;
  --text-xs:clamp(0.75rem,.7rem + .25vw,.875rem);
  --text-sm:clamp(0.875rem,.8rem + .35vw,1rem);
  --text-base:clamp(1rem,.95rem + .25vw,1.125rem);
  --text-xl:clamp(1.5rem,1.2rem + 1.25vw,2.25rem);
  --sp1:.25rem;--sp2:.5rem;--sp3:.75rem;--sp4:1rem;
  --sp5:1.25rem;--sp6:1.5rem;--sp8:2rem;--sp10:2.5rem;
  --sidebar-w:230px;
  --tr:170ms cubic-bezier(0.16,1,0.3,1);
}
[data-theme="light"]{
  --color-bg:#f0f4ff;--color-surface:#ffffff;--color-surface-2:#f8faff;
  --color-surface-offset:#eef2ff;--color-surface-dynamic:#e4eaff;
  --color-divider:#dce4f5;--color-border:#c8d4ee;
  --color-text:#0f172a;--color-text-muted:#4a5a8a;--color-text-faint:#94a3b8;
  --color-text-inverse:#ffffff;
  --color-primary:#075E54;--color-primary-hover:#054d45;--color-primary-hl:rgba(7,94,84,0.1);
  --color-green:#059669;--color-green-bg:rgba(5,150,105,0.1);
  --color-yellow:#d97706;--color-yellow-bg:rgba(217,119,6,0.1);
  --color-red:#dc2626;--color-red-bg:rgba(220,38,38,0.1);
  --color-blue:#2563eb;--color-blue-bg:rgba(37,99,235,0.1);
  --color-gray:#64748b;--color-gray-bg:rgba(100,116,139,0.1);
  --shadow-sm:0 1px 3px rgba(15,23,42,0.08);--shadow-md:0 4px 20px rgba(15,23,42,0.1);--shadow-glow:none;
}
@media(prefers-color-scheme:dark){:root:not([data-theme]){
  --color-bg:#090d1a;--color-surface:#0f1629;--color-surface-2:#131d35;
  --color-surface-offset:#1a2540;--color-surface-dynamic:#1e2b4a;
  --color-divider:#1e2d4d;--color-border:#243355;
  --color-text:#e2e8f8;--color-text-muted:#7b8db8;--color-text-faint:#3d4f72;
  --color-text-inverse:#090d1a;
  --color-primary:#128C7E;--color-primary-hover:#075E54;--color-primary-hl:rgba(18,140,126,0.15);
  --color-green:#34d399;--color-green-bg:rgba(52,211,153,0.12);
  --color-yellow:#fbbf24;--color-yellow-bg:rgba(251,191,36,0.12);
  --color-red:#f87171;--color-red-bg:rgba(248,113,113,0.12);
  --color-blue:#60a5fa;--color-blue-bg:rgba(96,165,250,0.12);
  --color-gray:#64748b;--color-gray-bg:rgba(100,116,139,0.12);
  --shadow-sm:0 1px 3px rgba(0,0,0,0.4);--shadow-md:0 4px 20px rgba(0,0,0,0.5);
  --shadow-glow:0 0 24px rgba(18,140,126,0.08);
}}

/* ── BASE ──────────────────────────────────────────────────── */
*,*::before,*::after{
  box-sizing:border-box;
  margin:0;
  padding:0;
  -webkit-tap-highlight-color:transparent;
}
html{-webkit-font-smoothing:antialiased;font-size:16px}
body{min-height:100dvh;font-family:'Inter',system-ui,sans-serif;font-size:var(--text-sm);color:var(--color-text);background:var(--color-bg);display:flex;overflow-x:hidden}
button{
  cursor:pointer;
  background:none;
  border:none;
  font:inherit;
  color:inherit;
  -webkit-tap-highlight-color:transparent;
  user-select:none;
  -webkit-user-select:none;
  -webkit-touch-callout:none;
}
input,select{
  font:inherit;
  color:inherit;
  -webkit-tap-highlight-color:transparent;
}
:focus{outline:none}
:focus-visible{outline:2px solid var(--color-primary);outline-offset:3px;border-radius:var(--r-sm)}
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap}
@media(prefers-reduced-motion:reduce){*,*::before,*::after{transition-duration:.01ms!important}}

/* ── SIDEBAR ───────────────────────────────────────────────── */
.sidebar{width:var(--sidebar-w);min-height:100dvh;background:rgba(15,22,41,.85);border-right:1px solid var(--color-divider);display:flex;flex-direction:column;position:fixed;left:0;top:0;bottom:0;z-index:100;transition:transform var(--tr),opacity .4s ease;box-shadow:var(--shadow-glow);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);opacity:0}
.sidebar.content-entered{opacity:1}
.sidebar-logo{display:flex;align-items:center;gap:var(--sp3);padding:var(--sp5) var(--sp4);border-bottom:1px solid var(--color-divider)}
.sidebar-title{font-size:var(--text-base);font-weight:700;letter-spacing:-.02em;color:#ffffff}
.sidebar-nav{flex:1;padding:var(--sp3);display:flex;flex-direction:column;gap:2px}
.nav-sep{height:1px;background:var(--color-border);margin:8px 12px;opacity:.35}
.nav-item{display:flex;align-items:center;gap:var(--sp3);padding:var(--sp2) var(--sp3);border-radius:var(--r-md);font-size:var(--text-sm);color:var(--color-text-muted);text-align:left;width:100%;transition:background var(--tr),color var(--tr);position:relative}
.nav-item:hover{background:var(--color-surface-offset);color:var(--color-text)}
.nav-item.active{background:var(--color-primary-hl);color:var(--color-primary);font-weight:600}
.nav-item.active::before{content:'';position:absolute;left:0;top:20%;bottom:20%;width:3px;border-radius:0 var(--r-full) var(--r-full) 0;background:var(--color-primary)}
.sidebar-footer{padding:var(--sp4);border-top:1px solid var(--color-divider)}

/* ── MOBILE HEADER ─────────────────────────────────────────── */
.mobile-header{display:none;align-items:center;justify-content:center;padding:0 var(--sp4);height:52px;background:rgba(15,22,41,.4);border-bottom:1px solid rgba(36,51,85,.4);position:fixed;top:0;left:0;right:0;z-index:200;backdrop-filter:blur(30px) saturate(1.4);-webkit-backdrop-filter:blur(30px) saturate(1.4)}
.mobile-header .hamburger{position:absolute;left:var(--sp4);top:50%;transform:translateY(-50%)}
.mobile-brand{display:flex;align-items:center;gap:var(--sp2)}
.mobile-title{font-size:var(--text-base);font-weight:700;color:#ffffff}
.hamburger{display:flex;align-items:center;justify-content:center;width:36px;height:36px;background:none;border:none;cursor:pointer;color:var(--color-text)}

/* ── MAIN ──────────────────────────────────────────────────── */
.main{margin-left:var(--sidebar-w);padding:var(--sp8) var(--sp10);flex:1;display:flex;flex-direction:column;align-items:center;overflow-x:hidden;min-width:0;opacity:0;transition:opacity .4s ease}
.main.content-entered{opacity:1}
.main > *{width:100%;max-width:1040px}
.section{content-visibility:auto;contain-intrinsic-size:500px;animation:sectionEnter .2s ease}
@keyframes sectionEnter{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}

/* ── TOPBAR ────────────────────────────────────────────────── */
.topbar{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--sp8);gap:var(--sp4);flex-wrap:wrap}
.topbar-left{display:flex;flex-direction:column;gap:4px}
.topbar-right{display:flex;align-items:center}
.page-title{font-size:var(--text-xl);font-weight:700;letter-spacing:-.03em;color:var(--color-text)}
.page-date{font-size:var(--text-xs);color:var(--color-text-muted)}
.kpi-bar{display:flex;gap:var(--sp2);flex-wrap:wrap}
.kpi-chip{display:flex;align-items:center;gap:var(--sp2);padding:var(--sp2) var(--sp3);background:rgba(15,22,41,.65);border:1px solid var(--color-border);border-radius:var(--r-full);font-size:var(--text-xs);color:var(--color-text-muted);white-space:nowrap;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px)}
.kpi-dot{width:7px;height:7px;border-radius:50%;flex-shrink:0}
.dot-green{background:var(--color-green);box-shadow:0 0 6px var(--color-green)}
.dot-yellow{background:var(--color-yellow);box-shadow:0 0 6px var(--color-yellow)}
.dot-red{background:var(--color-red);box-shadow:0 0 6px var(--color-red)}

/* ── NOTIFICATIONS ─────────────────────────────────────────── */
.notif-fab{position:fixed;top:29px;right:20px;width:auto;height:auto;display:flex;align-items:center;justify-content:center;z-index:500;cursor:pointer;color:var(--color-text-muted);transition:color var(--tr)}
.notif-fab:hover{color:var(--color-text)}
.notif-badge{position:absolute;top:-2px;right:-2px;min-width:18px;height:18px;display:flex;align-items:center;justify-content:center;background:var(--color-red);color:#fff;font-size:9px;font-weight:700;border-radius:var(--r-full);padding:0 5px;line-height:1;box-shadow:0 0 8px var(--color-red);border:2px solid var(--color-surface)}
.notif-dropdown{position:fixed;top:60px;right:20px;width:360px;max-width:calc(100vw - 40px);background:rgba(15,22,41,.85);border:1px solid var(--color-border);border-radius:var(--r-xl);box-shadow:0 12px 48px rgba(0,0,0,.5);z-index:500;max-height:60vh;display:flex;flex-direction:column;backdrop-filter:blur(24px);-webkit-backdrop-filter:blur(24px)}
.notif-header{padding:var(--sp3) var(--sp4);font-size:var(--text-sm);font-weight:600;color:var(--color-text);border-bottom:1px solid var(--color-divider)}
.notif-list{overflow-y:auto;padding:var(--sp2);display:flex;flex-direction:column;gap:3px}
.notif-item{display:flex;align-items:flex-start;gap:var(--sp2);padding:var(--sp2) var(--sp3);border-radius:var(--r-md);font-size:var(--text-xs);color:var(--color-text);cursor:pointer;transition:background var(--tr);text-align:left;width:100%}
.notif-item:hover{background:var(--color-surface-offset)}
.notif-dot{width:6px;height:6px;min-width:6px;border-radius:50%;margin-top:4px}
.notif-body{flex:1;min-width:0}
.notif-title{font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.notif-desc{color:var(--color-text-muted);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;margin-top:1px}
.notif-empty{padding:var(--sp6) var(--sp4);text-align:center;color:var(--color-text-faint);font-size:var(--text-xs)}

/* ── DASHBOARD ─────────────────────────────────────────────── */
.dash-welcome{margin-bottom:var(--sp8)}
.dash-greeting{font-size:var(--text-xl);font-weight:700;letter-spacing:-.03em;color:var(--color-text);margin-bottom:4px}
.dash-sub{font-size:var(--text-xs);color:var(--color-text-muted)}
.dash-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:var(--sp4);margin-bottom:var(--sp6)}
.dash-stat{display:flex;align-items:center;gap:var(--sp4);padding:var(--sp5);background:rgba(15,22,41,.65);border:1px solid var(--color-border);border-radius:var(--r-xl);box-shadow:var(--shadow-sm);backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px)}
.dash-stat-icon{width:44px;height:44px;border-radius:var(--r-lg);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.dash-stat-body{display:flex;flex-direction:column;gap:2px;min-width:0}
.dash-stat-value{font-size:var(--text-xl);font-weight:700;color:var(--color-text);line-height:1.2}
.dash-stat-label{font-size:var(--text-xs);color:var(--color-text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.dash-cols{display:flex;gap:var(--sp5);margin-bottom:var(--sp6)}
.dash-cols .card{margin-bottom:0}
.dash-today-item,.dash-urgent-item{display:flex;align-items:center;gap:var(--sp2);padding:var(--sp2) var(--sp3);border-radius:var(--r-md);font-size:var(--text-xs);color:var(--color-text);transition:background var(--tr);cursor:pointer}
.dash-today-item:hover,.dash-urgent-item:hover{background:var(--color-surface-offset)}
.dash-today-dot{width:6px;height:6px;min-width:6px;border-radius:50%}
.dash-today-body{flex:1;min-width:0}
.dash-today-title{font-weight:500;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.dash-today-desc{color:var(--color-text-muted);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}

/* ── CARDS ─────────────────────────────────────────────────── */
.card{background:rgba(15,22,41,.7);border:1px solid var(--color-border);border-radius:var(--r-xl);padding:var(--sp6);margin-bottom:var(--sp4);box-shadow:var(--shadow-sm);transition:box-shadow var(--tr);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px)}
.card:hover{box-shadow:var(--shadow-md)}
.card-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--sp4);flex-wrap:wrap;gap:var(--sp3)}
.card-title{font-size:var(--text-base);font-weight:600;color:var(--color-text)}

/* ── ADD FORM ──────────────────────────────────────────────── */
.add-form{display:flex;gap:var(--sp3);align-items:flex-end;flex-wrap:wrap}
.form-group{display:flex;flex-direction:column;gap:4px;flex:1;min-width:140px}
.form-group label{font-size:var(--text-xs);font-weight:500;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.04em}
.form-group input,.form-group select{padding:var(--sp2) var(--sp3);background:var(--color-surface-2);border:1px solid var(--color-border);border-radius:var(--r-md);height:38px;color:var(--color-text);transition:border-color var(--tr),box-shadow var(--tr)}
.form-group input:focus,.form-group select:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px var(--color-primary-hl);outline:none}
.form-group input::placeholder{color:var(--color-text-faint)}

/* ── BUTTONS ───────────────────────────────────────────────── */
.btn{display:inline-flex;align-items:center;gap:var(--sp2);padding:var(--sp2) var(--sp4);border-radius:var(--r-md);font-size:var(--text-sm);font-weight:500;transition:background var(--tr),box-shadow var(--tr),color var(--tr);white-space:nowrap;height:38px}
.btn-primary{background:linear-gradient(135deg,#075E54,#128C7E);color:#fff;box-shadow:0 2px 12px rgba(18,140,126,0.3)}
.btn-primary:hover{box-shadow:0 4px 18px rgba(18,140,126,0.45);background:linear-gradient(135deg,#054d45,#075E54)}
.btn-ghost{color:var(--color-text-muted);padding:var(--sp2) var(--sp3)}
.btn-ghost:hover{background:var(--color-surface-offset);color:var(--color-text)}
.btn-sm{height:28px;font-size:var(--text-xs);padding:0 var(--sp3)}
.btn-icon-sm{width:26px;height:26px;padding:0;display:flex;align-items:center;justify-content:center;border-radius:var(--r-sm);color:var(--color-text-faint);transition:background var(--tr),color var(--tr)}
.btn-icon-sm:hover{background:var(--color-red-bg);color:var(--color-red)}

/* ── BADGE ─────────────────────────────────────────────────── */
.badge{display:inline-flex;align-items:center;gap:5px;padding:2px var(--sp2);border-radius:var(--r-full);font-size:var(--text-xs);font-weight:600;white-space:nowrap;user-select:none;-webkit-user-select:none;-webkit-touch-callout:none}
.badge-green{background:var(--color-green-bg);color:var(--color-green);border:1px solid rgba(52,211,153,0.2)}
.badge-yellow{background:var(--color-yellow-bg);color:var(--color-yellow);border:1px solid rgba(251,191,36,0.2)}
.badge-red{background:var(--color-red-bg);color:var(--color-red);border:1px solid rgba(248,113,113,0.2)}
.badge-blue{background:var(--color-blue-bg);color:var(--color-blue);border:1px solid rgba(96,165,250,0.2)}
.badge-gray{background:var(--color-gray-bg);color:var(--color-gray);border:1px solid rgba(100,116,139,0.2)}
.badge-dot{width:5px;height:5px;border-radius:50%;background:currentColor}

/* ── PROGRESS ──────────────────────────────────────────────── */
.progress-wrap{margin-bottom:var(--sp4)}
.progress-track{height:5px;background:var(--color-surface-offset);border-radius:var(--r-full);overflow:hidden;margin-bottom:6px}
.progress-fill{height:100%;background:linear-gradient(90deg,#075E54,#128C7E,#34d399);border-radius:var(--r-full);transition:width 0.4s ease}
.progress-label{font-size:var(--text-xs);color:var(--color-text-muted)}

/* ── TASK TOOLBAR ──────────────────────────────────────────── */
.task-toolbar{display:flex;gap:var(--sp2);flex-wrap:wrap;align-items:center;margin-bottom:var(--sp4)}
.task-search{flex:1;min-width:150px;padding:var(--sp2) var(--sp3);background:var(--color-surface-2);border:1px solid var(--color-border);border-radius:var(--r-md);height:30px;font-size:var(--text-xs);color:var(--color-text);transition:border-color var(--tr),box-shadow var(--tr)}
.task-search:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px var(--color-primary-hl);outline:none}
.task-search::placeholder{color:var(--color-text-faint)}
.filter-group{display:flex;gap:3px;flex-wrap:wrap}
.filter-btn{padding:3px var(--sp3);border-radius:var(--r-full);font-size:var(--text-xs);font-weight:500;color:var(--color-text-muted);transition:background var(--tr),color var(--tr)}
.filter-btn:hover{background:var(--color-surface-offset);color:var(--color-text)}
.filter-btn.active{background:var(--color-primary-hl);color:var(--color-primary);font-weight:600}

/* ── TASK ROWS ─────────────────────────────────────────────── */
.task-list{display:flex;flex-direction:column;gap:6px}
.task-row{display:grid;grid-template-columns:4px 20px 1fr 26px;align-items:center;gap:var(--sp3);padding:var(--sp3) var(--sp4);background:var(--color-surface-2);border:1px solid var(--color-divider);border-radius:var(--r-lg);transition:background var(--tr),opacity var(--tr),border-color var(--tr)}
.task-row:hover{background:var(--color-surface-offset);border-color:var(--color-border)}
.task-row.done{opacity:.38}
.task-row.overdue{border-color:rgba(248,113,113,0.3);background:rgba(248,113,113,0.04)}
.task-pbar{width:4px;height:28px;border-radius:var(--r-full);flex-shrink:0}
.task-pbar-red{background:var(--color-red);box-shadow:0 0 6px var(--color-red)}
.task-pbar-yellow{background:var(--color-yellow);box-shadow:0 0 6px var(--color-yellow)}
.task-pbar-green{background:var(--color-green);box-shadow:0 0 6px var(--color-green)}
.task-check{width:20px;height:20px;min-width:20px;border:2px solid var(--color-border);border-radius:var(--r-sm);display:flex;align-items:center;justify-content:center;transition:background var(--tr),border-color var(--tr),box-shadow var(--tr);flex-shrink:0}
.task-check svg{opacity:0;transition:opacity var(--tr)}
.task-check.checked{background:var(--color-green);border-color:var(--color-green);box-shadow:0 0 8px rgba(52,211,153,0.4)}
.task-check.checked svg{opacity:1}
.task-body{min-width:0;flex:1}
.task-text{font-size:var(--text-sm);font-weight:450;line-height:1.4;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.task-row.done .task-text{text-decoration:line-through;color:var(--color-text-muted)}
.task-meta{display:flex;align-items:center;gap:var(--sp2);margin-top:3px;flex-wrap:wrap}
.task-due{display:flex;align-items:center;gap:3px;font-size:var(--text-xs);color:var(--color-text-muted)}
.task-due-over{color:var(--color-red);font-weight:600}
.task-del{opacity:0;transition:opacity var(--tr)}
.task-row:hover .task-del{opacity:1}

/* ── JOB ROWS ──────────────────────────────────────────────── */
.jobs-list{display:flex;flex-direction:column;gap:6px}
.job-row{display:grid;grid-template-columns:24px 1fr auto 26px;align-items:center;gap:var(--sp3);padding:var(--sp3) var(--sp4);background:var(--color-surface-2);border:1px solid var(--color-divider);border-radius:var(--r-lg);transition:background var(--tr),opacity var(--tr)}
.job-row:hover{background:var(--color-surface-offset);border-color:var(--color-border)}
.job-row.done{opacity:.35}
.job-check{width:22px;height:22px;min-width:22px;border:2px solid var(--color-border);border-radius:50%;display:flex;align-items:center;justify-content:center;transition:background var(--tr),border-color var(--tr),box-shadow var(--tr);flex-shrink:0}
.job-check svg{opacity:0;transition:opacity var(--tr)}
.job-check.checked{background:var(--color-green);border-color:var(--color-green);box-shadow:0 0 8px rgba(52,211,153,0.4)}
.job-check.checked svg{opacity:1}
.job-body{min-width:0}
.job-name{font-size:var(--text-sm);font-weight:500;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;user-select:none;-webkit-user-select:none}
.job-row.done .job-name{text-decoration:line-through}
.job-client{font-size:var(--text-xs);color:var(--color-text-muted)}
.job-right{display:flex;flex-direction:column;align-items:flex-end;gap:4px}
.job-dl{font-size:var(--text-xs);color:var(--color-text-faint);white-space:nowrap}
.job-dl-over{color:var(--color-red);font-weight:600}
.job-actions{display:flex;gap:4px;align-items:center}
.status-select{height:26px;padding:0 var(--sp2);font-size:var(--text-xs);background:var(--color-surface-offset);border:1px solid var(--color-border);border-radius:var(--r-md);color:var(--color-text-muted);cursor:pointer;transition:border-color var(--tr)}
.status-select:focus{border-color:var(--color-primary);outline:none}
.filter-bar{display:flex;gap:3px;flex-wrap:wrap}

/* ── EMPTY STATE ───────────────────────────────────────────── */
.empty-state{display:flex;flex-direction:column;align-items:center;text-align:center;padding:var(--sp10) var(--sp8);color:var(--color-text-faint);gap:var(--sp3)}
.empty-state svg{opacity:.3}
.empty-state p{font-size:var(--text-sm);line-height:1.6;color:var(--color-text-muted)}

/* ── TOAST ─────────────────────────────────────────────────── */
.toast-wrap{position:fixed;bottom:var(--sp6);right:var(--sp6);z-index:1000;display:flex;flex-direction:column;gap:var(--sp2)}
.toast{padding:var(--sp3) var(--sp4);background:var(--color-surface-offset);border:1px solid var(--color-border);border-radius:var(--r-lg);box-shadow:var(--shadow-md);font-size:var(--text-sm);max-width:300px;animation:tIn 180ms ease;backdrop-filter:blur(12px)}
.toast-error{border-color:var(--color-red)!important}
@keyframes tIn{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}
.toast-out{animation:tOut 300ms ease forwards}
@keyframes tOut{to{opacity:0;transform:translateY(6px)}}

/* ── SPINNER ───────────────────────────────────────────────── */
.spinner{width:14px;height:14px;border:2px solid rgba(255,255,255,0.3);border-top-color:#fff;border-radius:50%;animation:spin 0.7s linear infinite;display:inline-block}
@keyframes spin{to{transform:rotate(360deg)}}

/* ── OVERLAY ───────────────────────────────────────────────── */
.overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,0.6);z-index:90;backdrop-filter:blur(3px)}
.overlay.open{display:block}

/* ── RESPONSIVE ────────────────────────────────────────────── */
@media(max-width:768px){
  .sidebar{transform:translateX(-100%)}
  .sidebar.open{transform:translateX(0)}
  .mobile-header{display:flex}
  .main{margin-left:0;padding:var(--sp4);padding-top:calc(52px + var(--sp4));flex:1 1 100%}
  .main > *{max-width:100%}
  .topbar{flex-direction:column;gap:var(--sp3)}
  .topbar-left{align-items:center;text-align:center;width:100%}
  .topbar-right{width:100%}
  .kpi-bar{justify-content:center}
  .dash-stats{grid-template-columns:repeat(2,1fr)}
  .dash-cols{flex-direction:column}
  .card{padding:var(--sp4)}
  .dash-stat{padding:var(--sp4)}
  .dash-stat-icon{width:36px;height:36px}
  .add-form{flex-direction:column}
  .form-group{min-width:100%}
  .notif-fab{top:16px;right:14px}
  .task-del,.pacco-del,.excel-del{opacity:1}
  .task-row{padding:var(--sp2) var(--sp3);gap:var(--sp2)}
  .job-row{grid-template-columns:20px 1fr auto;gap:var(--sp2);padding:var(--sp2) var(--sp3)}
  .pacco-row{grid-template-columns:1fr auto;gap:var(--sp2);padding:var(--sp2) var(--sp3)}
  .excel-row{grid-template-columns:1fr 1fr 1fr;gap:var(--sp2);padding:var(--sp2) var(--sp3)}
  .event-row{padding:var(--sp2) var(--sp3)}
  .year-grid{grid-template-columns:repeat(2,1fr);gap:var(--sp1)}
  .cal-month{padding:2px}
  .cal-month-header{font-size:clamp(8px,.8vw + 2px,10px);padding:2px 0;margin-bottom:2px}
  .cal-days-grid{gap:0}
  .cal-day{height:clamp(14px,2.5vw + 2px,18px);font-size:clamp(5px,.6vw + 2px,8px)}
  .cal-day-name{font-size:clamp(4px,.5vw + 1px,6px);padding:0}
  .cal-day-dot{width:2px;height:2px;bottom:1px}
  .cal-month-block{min-height:70px;padding:var(--sp4) var(--sp2)}
  .cal-month-block-name{font-size:clamp(11px,.8rem + .5vw,var(--text-sm));overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:100%}
  .year-event-row{grid-template-columns:70px 1fr 26px}
  .job-row{grid-template-columns:24px 1fr auto 26px}
  .task-toolbar{flex-direction:column;align-items:stretch}
  .task-search{min-width:100%}
  .notes-grid{grid-template-columns:1fr}
  .excel-row{grid-template-columns:1fr 1fr auto 26px}
}
@media(max-width:480px){
  .year-grid{grid-template-columns:1fr;gap:var(--sp1)}
  .year-event-row{grid-template-columns:60px 1fr 26px}
  .dash-stats{grid-template-columns:1fr}
  .cal-month{padding:3px}
  .cal-month-header{font-size:10px;padding:3px 0}
  .cal-day-name{font-size:6px}
  .cal-day{height:20px;font-size:8px}
  .cal-days-grid{gap:0}
  .cal-day-dot{width:2px;height:2px;bottom:1px}
}

/* ── PIN SCREEN ────────────────────────────────────────────── */
#pin-screen{display:flex;align-items:center;justify-content:center;position:fixed;inset:0;z-index:9999;background:var(--color-bg);transition:opacity .45s ease,visibility .45s ease}
#pin-screen.hidden{opacity:0;visibility:hidden;pointer-events:none}
.pin-box{display:flex;flex-direction:column;align-items:center;gap:var(--sp4);text-align:center;padding:var(--sp8);background:rgba(15,22,41,.85);border:1px solid var(--color-border);border-radius:var(--r-xl);box-shadow:0 20px 60px rgba(0,0,0,0.4);width:320px;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);transition:transform .35s cubic-bezier(.4,0,.2,1),opacity .3s ease,filter .3s ease}
#pin-screen.hidden .pin-box{transform:perspective(500px) rotateX(15deg) translateY(-30px) scale(.8);opacity:0;filter:blur(14px) brightness(1.5)}
.pin-logo{margin-bottom:var(--sp2)}
.pin-welcome{font-size:var(--text-xl);font-weight:700;letter-spacing:-.02em;color:var(--color-text)}
.pin-subtitle{font-size:var(--text-sm);color:var(--color-text-muted)}
.pin-dots{display:flex;gap:var(--sp4);margin:var(--sp2) 0}
.pin-dot{width:14px;height:14px;border-radius:50%;border:2px solid var(--color-border);background:transparent;transition:background 0.15s,border-color 0.15s}
.pin-dot.filled{background:var(--color-primary);border-color:var(--color-primary)}
.pin-dot.shake{animation:pinShake 0.4s ease}
.pin-error{font-size:var(--text-xs);color:var(--color-red);min-height:18px;font-weight:500}
.pin-status{display:flex;align-items:center;justify-content:center;gap:6px;font-size:10px;font-weight:600;letter-spacing:.06em;color:var(--color-green);opacity:0;transition:opacity .3s ease;min-height:20px;text-transform:uppercase}
.pin-status.show{opacity:1}
.pin-status-dot{width:5px;height:5px;border-radius:50%;background:var(--color-green);animation:pinStatusPulse 1s ease-in-out infinite}
@keyframes pinStatusPulse{0%,100%{box-shadow:0 0 0 0 var(--color-green)}50%{box-shadow:0 0 0 4px transparent}}
.pin-pad{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--sp2);width:100%;margin-top:var(--sp2)}
.pin-key{
  height:56px;
  border-radius:var(--r-lg);
  font-size:var(--text-xl);
  font-weight:500;
  color:var(--color-text);
  background:var(--color-surface-offset);
  border:1px solid var(--color-border);
  transition:background var(--tr),transform 0.1s,box-shadow var(--tr);
  -webkit-tap-highlight-color:transparent;
  outline:none;
  user-select:none;
  -webkit-user-select:none;
  -webkit-touch-callout:none;
}
.pin-key:focus{outline:none}
.pin-key:focus-visible{outline:2px solid var(--color-primary);outline-offset:3px}
.pin-key:active{background:var(--color-primary-hl);transform:scale(0.95)}
.pin-key-del{font-size:var(--text-base)}
.pin-key-empty{background:transparent;border:none;pointer-events:none}
@keyframes pinShake{0%,100%{transform:translateX(0)}20%{transform:translateX(-8px)}40%{transform:translateX(8px)}60%{transform:translateX(-6px)}80%{transform:translateX(6px)}}

/* ── NOTES ─────────────────────────────────────────────────── */
.notes-grid{
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(220px,1fr));
  gap:var(--sp3);
}
.note-card{background:rgba(19,29,53,.65);border:1px solid var(--color-divider);border-radius:var(--r-lg);
  padding:var(--sp4);
  display:flex;
  flex-direction:column;
  gap:var(--sp2);
  min-height:120px;
  transition:transform var(--tr),background var(--tr),border-color var(--tr),box-shadow var(--tr);
  position:relative;
  backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);
}
.note-card:hover{
  background:var(--color-surface-offset);
  border-color:var(--color-primary);
  transform:translateY(-2px);
  box-shadow:var(--shadow-md);
}
.note-card-title{
  font-size:var(--text-sm);
  font-weight:600;
  color:var(--color-text);
  padding-right:28px;
  line-height:1.35;
}
.note-card-text{
  font-size:var(--text-xs);
  color:var(--color-text-muted);
  line-height:1.55;
  display:-webkit-box;
  -webkit-line-clamp:4;
  -webkit-box-orient:vertical;
  overflow:hidden;
  word-break:break-word;
}
.note-card-copy{
  position:absolute;
  top:10px;
  right:10px;
  font-size:11px;
  color:var(--color-primary);
  background:var(--color-primary-hl);
  border:1px solid rgba(18,140,126,0.18);
  border-radius:var(--r-full);
  padding:3px 8px;
  font-weight:600;
}
.note-card-actions{
  display:flex;
  justify-content:flex-end;
  margin-top:auto;
}
.note-del{
  opacity:.7;
}
.note-del:hover{
  opacity:1;
}

/* ── CALENDAR ──────────────────────────────────────────────── */
.cal-topbar{display:flex;align-items:center;justify-content:center;gap:var(--sp4);margin-bottom:var(--sp5)}
.cal-year-label{font-size:var(--text-xl);font-weight:700;letter-spacing:-.03em;color:var(--color-text);min-width:100px;text-align:center}
.year-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--sp3);overflow:hidden}
.cal-month{background:rgba(19,29,53,.7);border:1px solid var(--color-divider);border-radius:var(--r-lg);padding:var(--sp2);min-width:0;overflow:hidden;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px)}
.cal-month-header{font-size:clamp(10px,.8vw + 4px,var(--text-sm));font-weight:600;text-align:center;padding:var(--sp1) 0;color:var(--color-text);margin-bottom:var(--sp1)}
.cal-days-header{display:grid;grid-template-columns:repeat(7,1fr);text-align:center;margin-bottom:1px}
.cal-day-name{font-size:clamp(6px,.5vw + 3px,9px);font-weight:600;color:var(--color-text-faint);padding:1px 0;text-transform:uppercase;line-height:1;overflow:hidden}
.cal-days-grid{display:grid;grid-template-columns:repeat(7,minmax(0,1fr));gap:1px}
.cal-day{display:flex;flex-direction:column;align-items:center;justify-content:center;height:clamp(18px,2.2vw + 6px,28px);border-radius:var(--r-sm);font-size:clamp(7px,.6vw + 3px,11px);font-weight:450;color:var(--color-text);background:transparent;transition:background var(--tr);position:relative;gap:0;padding:0;min-width:0;overflow:hidden}
.cal-day:hover{background:var(--color-surface-offset)}
.cal-day-empty{background:transparent;pointer-events:none}
.cal-day-num{line-height:1}
.cal-day-dot{width:3px;height:3px;border-radius:50%;background:var(--color-primary);position:absolute;bottom:2px;left:50%;margin-left:-1.5px}
.cal-today{background:var(--color-primary-hl);color:var(--color-primary);font-weight:700}
.cal-today:hover{background:var(--color-primary-hl)}

/* ── MOBILE MONTH BLOCKS ───────────────────────────────────── */
.cal-month-block{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--sp1);padding:var(--sp5) var(--sp3);background:var(--color-surface-2);border:1px solid var(--color-divider);border-radius:var(--r-lg);cursor:pointer;transition:background var(--tr),border-color var(--tr),transform var(--tr);min-height:90px;text-align:center;overflow:hidden;width:100%}
.cal-month-block:hover{background:var(--color-surface-offset);border-color:var(--color-primary);transform:translateY(-1px)}
.cal-month-block-name{font-size:var(--text-base);font-weight:600;color:var(--color-text)}
.cal-month-block-count{font-size:var(--text-xs);color:var(--color-text-muted);font-weight:500}

/* ── MONTH MODAL ───────────────────────────────────────────── */
.month-modal-nav{display:flex;align-items:center;gap:var(--sp3)}
.month-modal-body{padding:var(--sp1) 0}
.month-modal-body .cal-month{background:transparent;border:none;padding:0}
.month-modal-body .cal-day{height:36px;font-size:var(--text-sm)}
.month-modal-body .cal-day-name{font-size:10px;padding:4px 0}
.month-modal-body .cal-days-grid{gap:2px}

/* ── YEAR EVENT LIST ───────────────────────────────────────── */
.year-event-list{display:flex;flex-direction:column;gap:4px}
.year-event-row{display:grid;grid-template-columns:90px 1fr 26px;align-items:center;gap:var(--sp2);padding:var(--sp2) var(--sp3);background:var(--color-surface-2);border:1px solid var(--color-divider);border-radius:var(--r-md);font-size:var(--text-xs);transition:background var(--tr),border-color var(--tr)}
.year-event-row:hover{background:var(--color-surface-offset);border-color:var(--color-border)}
.year-event-date{font-weight:600;color:var(--color-text-muted);white-space:nowrap;font-size:var(--text-xs)}
.year-event-title{color:var(--color-text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.cal-event-count{font-size:var(--text-xs);color:var(--color-text-muted);font-weight:500}
.year-event-del{opacity:0;transition:opacity var(--tr)}
.year-event-row:hover .year-event-del{opacity:1}

/* ── EVENT MODAL ───────────────────────────────────────────── */
.modal-overlay{display:none;position:fixed;inset:0;z-index:900;align-items:center;justify-content:center;width:100%;max-width:none;height:100%}
.modal-box{background:rgba(15,22,41,.88);border:1px solid var(--color-border);border-radius:var(--r-xl);padding:var(--sp5);width:400px;max-width:92vw;box-shadow:0 20px 60px rgba(0,0,0,.5);backdrop-filter:blur(24px);-webkit-backdrop-filter:blur(24px)}
.modal-top{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--sp4)}
.modal-title{font-size:var(--text-base);font-weight:600;color:var(--color-text)}
.modal-close{width:28px;height:28px}
.event-list{display:flex;flex-direction:column;gap:6px;max-height:260px;overflow-y:auto}
.event-row{display:flex;align-items:center;justify-content:space-between;padding:var(--sp2) var(--sp3);background:var(--color-surface-2);border:1px solid var(--color-divider);border-radius:var(--r-md);font-size:var(--text-sm);color:var(--color-text);gap:var(--sp3)}
.event-row:hover{background:var(--color-surface-offset)}

/* ── EXCEL ─────────────────────────────────────────────────── */
.excel-list{display:flex;flex-direction:column;gap:6px}
.excel-row{display:grid;grid-template-columns:1fr 1fr 1fr 26px;align-items:center;gap:var(--sp3);padding:var(--sp3) var(--sp4);background:var(--color-surface-2);border:1px solid var(--color-divider);border-radius:var(--r-lg);transition:background var(--tr),border-color var(--tr)}
.excel-row:hover{background:var(--color-surface-offset);border-color:var(--color-border)}
.excel-cell{font-size:var(--text-sm);font-weight:450;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.excel-cell-importo{font-weight:600;color:var(--color-green);text-align:right}
.excel-row:hover .excel-del{opacity:1}
.excel-del{opacity:0;transition:opacity var(--tr)}

/* ── PACCHI ────────────────────────────────────────────────── */
.pacco-list{display:flex;flex-direction:column;gap:6px}
.pacco-row{display:grid;grid-template-columns:1fr auto 26px;align-items:center;gap:var(--sp2);padding:var(--sp3) var(--sp4);background:var(--color-surface-2);border:1px solid var(--color-divider);border-radius:var(--r-lg);transition:background var(--tr),border-color var(--tr)}
.pacco-row:hover{background:var(--color-surface-offset);border-color:var(--color-border)}
.pacco-name{font-size:var(--text-sm);font-weight:500;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;user-select:none;-webkit-user-select:none}
.pacco-del{opacity:0;transition:opacity var(--tr)}
.pacco-row:hover .pacco-del{opacity:1}

