*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  --bg:#0F1117;--surface:#1A1D27;--surface2:#22263A;--border:#2E3348;
  --text:#E2E8F0;--muted:#8892A4;--accent:#6C63FF;--accent2:#A78BFA;
  --green:#22C55E;--red:#EF4444;--yellow:#F59E0B;
  --radius:12px;--radius-sm:8px;--font:'Inter',system-ui,-apple-system,sans-serif;
}
html{-webkit-text-size-adjust:100%}
body{font-family:var(--font);background:var(--bg);color:var(--text);min-height:100vh;min-height:100dvh;font-size:15px;line-height:1.6;-webkit-font-smoothing:antialiased;overflow-x:hidden}

/* ── Mobile top bar ───────────────────────────────────────── */
.topbar{
  display:none;position:fixed;top:0;left:0;right:0;height:56px;
  background:var(--surface);border-bottom:1px solid var(--border);
  z-index:400;align-items:center;padding:0 16px;gap:10px;
}
.topbar-icon{width:30px;height:30px;background:linear-gradient(135deg,var(--accent),var(--accent2));border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:14px}
.topbar-title{font-size:14px;font-weight:700}
.topbar-hamburger{margin-left:auto;width:40px;height:40px;display:flex;align-items:center;justify-content:center;background:none;border:none;cursor:pointer;color:var(--text);font-size:24px;border-radius:8px;-webkit-tap-highlight-color:transparent}
.topbar-hamburger:active{background:var(--surface2)}

/* ── Overlay ──────────────────────────────────────────────── */
.overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,.55);z-index:450;-webkit-tap-highlight-color:transparent}
.overlay.show{display:block}

/* ── Sidebar ──────────────────────────────────────────────── */
.sidebar{
  width:240px;background:var(--surface);border-right:1px solid var(--border);
  display:flex;flex-direction:column;padding:20px 14px;
  position:fixed;top:0;left:0;height:100vh;height:100dvh;z-index:500;
  transition:transform .25s ease;
}
.brand{display:flex;align-items:center;gap:10px;padding:0 6px 18px;border-bottom:1px solid var(--border);margin-bottom:14px}
.brand-icon{width:34px;height:34px;background:linear-gradient(135deg,var(--accent),var(--accent2));border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:16px}
.brand-name{font-size:15px;font-weight:700;letter-spacing:-.3px}
nav a{display:flex;align-items:center;gap:10px;padding:11px 12px;border-radius:var(--radius-sm);color:var(--muted);text-decoration:none;font-size:14px;font-weight:500;transition:.15s;margin-bottom:2px;-webkit-tap-highlight-color:transparent}
nav a:hover,nav a:active{color:var(--text);background:var(--surface2)}
nav a.active{color:var(--text);background:var(--surface2);border-left:3px solid var(--accent);padding-left:9px}
nav a .ico{width:20px;text-align:center}
.sidebar-footer{margin-top:auto;padding-top:14px;border-top:1px solid var(--border)}

/* ── Main ─────────────────────────────────────────────────── */
.layout{display:flex;min-height:100vh;min-height:100dvh}
.main{margin-left:240px;flex:1;padding:24px;max-width:1280px;width:calc(100% - 240px)}

/* ── Page header ──────────────────────────────────────────── */
.page-header{margin-bottom:22px}
.page-header h1{font-size:20px;font-weight:700}
.page-header p{color:var(--muted);font-size:13px;margin-top:2px}

/* ── Cards ────────────────────────────────────────────────── */
.cards{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-bottom:22px}
.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:18px}
.card-label{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:var(--muted);margin-bottom:6px}
.card-value{font-size:22px;font-weight:700}
.card-sub{font-size:11px;color:var(--muted);margin-top:3px}
.card-value.green{color:var(--green)}.card-value.red{color:var(--red)}

/* ── Table ────────────────────────────────────────────────── */
.table-wrap{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);overflow-x:auto;-webkit-overflow-scrolling:touch}
table{width:100%;border-collapse:collapse;font-size:13px}
th{background:var(--surface2);color:var(--muted);font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.4px;padding:10px 12px;text-align:left;white-space:nowrap}
td{padding:10px 12px;border-top:1px solid var(--border)}
tr:hover td{background:rgba(255,255,255,.02)}

/* ── Badge / Importo ──────────────────────────────────────── */
.badge{display:inline-block;padding:2px 8px;border-radius:20px;font-size:11px;font-weight:600;white-space:nowrap}
.pos{color:var(--green);font-weight:600}.neg{color:var(--red);font-weight:600}

/* ── Charts ───────────────────────────────────────────────── */
.charts-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:22px}
.chart-box{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:18px}
.chart-box h3{font-size:12px;font-weight:600;color:var(--muted);margin-bottom:14px;text-transform:uppercase;letter-spacing:.4px}
canvas{max-height:260px}

/* ── Buttons ──────────────────────────────────────────────── */
.btn{display:inline-flex;align-items:center;gap:6px;padding:9px 16px;border-radius:var(--radius-sm);border:none;font-size:14px;font-weight:600;cursor:pointer;transition:.15s;text-decoration:none;white-space:nowrap;-webkit-tap-highlight-color:transparent}
.btn-primary{background:var(--accent);color:#fff}.btn-primary:hover{background:#5a52d5}
.btn-sm{padding:6px 10px;font-size:12px}
.btn-ghost{background:var(--surface2);color:var(--text);border:1px solid var(--border)}
.btn-ghost:hover{border-color:var(--accent)}
.btn-danger{background:var(--red);color:#fff}

/* ── Forms ────────────────────────────────────────────────── */
.form-group{margin-bottom:14px}
.form-group label{display:block;font-size:12px;font-weight:600;color:var(--muted);margin-bottom:5px}
input[type=text],input[type=email],input[type=password],input[type=number],input[type=date],select,textarea{
  width:100%;background:var(--surface2);border:1px solid var(--border);color:var(--text);
  border-radius:var(--radius-sm);padding:10px 12px;font-size:16px;font-family:var(--font);-webkit-appearance:none;
}
input:focus,select:focus,textarea:focus{outline:none;border-color:var(--accent)}

/* ── Upload ───────────────────────────────────────────────── */
.upload-zone{border:2px dashed var(--border);border-radius:var(--radius);padding:40px 20px;text-align:center;cursor:pointer;transition:.2s}
.upload-zone:hover,.upload-zone.drag{border-color:var(--accent);background:rgba(108,99,255,.05)}
.upload-zone .icon{font-size:36px;margin-bottom:10px}
.upload-zone p{color:var(--muted);font-size:14px}
.upload-zone strong{color:var(--accent)}

/* ── Alerts ───────────────────────────────────────────────── */
.alert{padding:12px 16px;border-radius:var(--radius-sm);font-size:14px;margin-bottom:16px;line-height:1.5}
.alert-success{background:rgba(34,197,94,.12);border:1px solid rgba(34,197,94,.3);color:var(--green)}
.alert-error{background:rgba(239,68,68,.12);border:1px solid rgba(239,68,68,.3);color:var(--red)}
.alert-info{background:rgba(108,99,255,.12);border:1px solid rgba(108,99,255,.3);color:var(--accent2)}

/* ── Login ────────────────────────────────────────────────── */
.login-wrap{min-height:100vh;min-height:100dvh;display:flex;align-items:center;justify-content:center;background:var(--bg);padding:20px}
.login-box{background:var(--surface);border:1px solid var(--border);border-radius:16px;padding:32px;width:100%;max-width:400px}
.login-box h1{font-size:20px;text-align:center;margin-bottom:6px}
.login-box p{text-align:center;color:var(--muted);font-size:13px;margin-bottom:24px}

/* ── Filters ──────────────────────────────────────────────── */
.filters{display:flex;gap:10px;align-items:flex-end;flex-wrap:wrap;margin-bottom:16px}
.filters .form-group{margin-bottom:0;min-width:110px}

/* ── Pagination ───────────────────────────────────────────── */
.pagination{display:flex;gap:5px;justify-content:center;margin-top:16px;flex-wrap:wrap}
.pagination a,.pagination span{display:inline-block;padding:8px 12px;border:1px solid var(--border);border-radius:6px;font-size:13px;text-decoration:none;color:var(--text)}
.pagination a:hover{border-color:var(--accent);color:var(--accent)}
.pagination .current{background:var(--accent);border-color:var(--accent);color:#fff}

/* ── Progress bar ─────────────────────────────────────────── */
.progress-bar{height:6px;background:var(--surface2);border-radius:3px;overflow:hidden}
.progress-fill{height:100%;border-radius:3px;transition:width .4s}

/* ── Modal ────────────────────────────────────────────────── */
.modal-bg{display:none;position:fixed;inset:0;background:rgba(0,0,0,.6);z-index:600;align-items:center;justify-content:center;padding:16px}
.modal-bg.show{display:flex}
.modal{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:24px;width:100%;max-width:460px;max-height:90vh;overflow-y:auto}

/* ── Utilities ────────────────────────────────────────────── */
.flex{display:flex}.items-center{align-items:center}.justify-between{justify-content:space-between}
.gap-8{gap:8px}.mt-4{margin-top:4px}.mb-16{margin-bottom:16px}
.text-sm{font-size:13px}.text-muted{color:var(--muted)}.font-bold{font-weight:700}.w-full{width:100%}
::-webkit-scrollbar{width:5px;height:5px}::-webkit-scrollbar-track{background:var(--surface)}::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}

/* ══════════════════════════════════════════════════════════ */
/* TABLET                                                     */
/* ══════════════════════════════════════════════════════════ */
@media(max-width:1024px){
  .charts-grid{grid-template-columns:1fr}
  .cards{grid-template-columns:repeat(2,1fr)}
}

/* ══════════════════════════════════════════════════════════ */
/* MOBILE                                                     */
/* ══════════════════════════════════════════════════════════ */
@media(max-width:768px){
  .topbar{display:flex}
  .sidebar{transform:translateX(-100%);width:280px;padding-top:16px}
  .sidebar.open{transform:translateX(0)}
  .main{margin-left:0;width:100%;padding:68px 14px 24px}
  .cards{grid-template-columns:1fr 1fr;gap:10px}
  .card{padding:14px}.card-value{font-size:18px}.card-label,.card-sub{font-size:10px}
  .page-header h1{font-size:17px}
  .page-header .flex{flex-direction:column;align-items:flex-start!important;gap:10px}
  .charts-grid{grid-template-columns:1fr;gap:12px}
  .chart-box{padding:14px}
  table{font-size:12px}th,td{padding:8px 8px}
  .filters{gap:8px}.filters .form-group{min-width:calc(50% - 4px);flex:1}
  .upload-zone{padding:28px 14px}
  .table-wrap{border-radius:var(--radius-sm)}
  .modal{margin:12px;padding:20px}
}

/* ── SMALL PHONE (SE, mini) ───────────────────────────────── */
@media(max-width:420px){
  .cards{grid-template-columns:1fr}
  .filters{flex-direction:column}.filters .form-group{min-width:100%}
}
/* ── Budget grid responsive ───────────────────────────────── */
.budget-grid{display:grid;grid-template-columns:1fr 1fr 1fr;gap:14px;margin-bottom:14px}
@media(max-width:600px){
  .budget-grid{grid-template-columns:1fr !important}
}

/* ── iOS safe areas ───────────────────────────────────────── */
@supports(padding-top:env(safe-area-inset-top)){
  .topbar{padding-top:env(safe-area-inset-top);height:calc(56px + env(safe-area-inset-top))}
  @media(max-width:768px){
    .main{padding-top:calc(68px + env(safe-area-inset-top))}
    body{padding-bottom:env(safe-area-inset-bottom)}
  }
}
