:root{
  --bg:#f6f6f4; --surface:#ffffff; --surface2:#f0f0ee;
  --text:#1c1d1f; --text2:#73757a; --border:#e9e9e6;
  --accent:#5363e0; --accent-soft:#edeffc;
  --green:#23945f; --green-soft:#e7f4ed;
  --amber:#c07c20; --amber-soft:#f8f0e1;
  --blue:#3d7cc2; --blue-soft:#e9f1f9;
  --rose:#c14e64; --rose-soft:#f9ecef;
  --red:#d04f47;
  --shadow:0 1px 2px rgba(0,0,0,.04);
  --glass:rgba(255,255,255,.84);
  --radius:14px;
}
html[data-theme="dark"]{
  --bg:#101113; --surface:#17181b; --surface2:#1f2125;
  --text:#e4e5e7; --text2:#93959b; --border:#25272c;
  --accent:#8f9af0; --accent-soft:#20223a;
  --green:#4cc592; --green-soft:#142a20;
  --amber:#d9b35e; --amber-soft:#282113;
  --blue:#6fa8e8; --blue-soft:#16222e;
  --rose:#e08198; --rose-soft:#2c1a20;
  --red:#e08a82;
  --shadow:0 1px 2px rgba(0,0,0,.2);
  --glass:rgba(23,24,27,.86);
  --radius:14px;
}
*{margin:0;padding:0;box-sizing:border-box}
html{overscroll-behavior:none;-webkit-tap-highlight-color:transparent}
body{
  font-family:-apple-system,BlinkMacSystemFont,'Segoe UI',Roboto,'Helvetica Neue',sans-serif;
  background:var(--bg); color:var(--text);
  transition:background .25s,color .25s;
  padding-bottom:env(safe-area-inset-bottom);
}
button{font:inherit;color:inherit;background:none;border:none;cursor:pointer}
input,select,textarea{font:inherit;color:var(--text)}

/* ===== Navbar fluttuante ===== */
.app{min-height:100vh}
.topnav{
  position:fixed;top:14px;left:50%;transform:translateX(-50%);z-index:60;
  width:min(1140px,calc(100% - 28px));
  display:flex;align-items:center;gap:10px;padding:8px 12px;
  background:var(--glass);
  -webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);
  border:1px solid var(--border);border-radius:18px;
  box-shadow:0 6px 20px rgba(0,0,0,.07);
}
.logo{display:flex;align-items:center;gap:9px;font-size:17px;font-weight:700;padding:0 12px 0 4px}
.logo .mark{width:30px;height:30px;border-radius:9px;background:var(--accent);display:grid;place-items:center;color:#fff;font-size:15px}
.nav{display:flex;align-items:center;gap:4px;flex:1}
.nav button{display:flex;align-items:center;gap:8px;padding:9px 14px;border-radius:11px;font-size:14px;font-weight:500;color:var(--text2)}
.nav button svg{width:19px;height:19px;flex-shrink:0}
.nav button:hover{background:var(--surface2);color:var(--text)}
.nav button.active{background:var(--accent-soft);color:var(--accent);font-weight:600}
.theme-btn{display:grid;place-items:center;width:38px;height:38px;border-radius:11px;color:var(--text2)}
.theme-btn:hover{background:var(--surface2);color:var(--text)}
.theme-btn svg{width:19px;height:19px}
.theme-btn.mobile-theme{display:none}

.main{padding:96px 32px 60px;max-width:1200px;margin:0 auto}
.topbar{display:flex;align-items:center;justify-content:space-between;margin-bottom:24px}
.topbar h1{font-size:24px;font-weight:700}
.topbar .date{font-size:13.5px;color:var(--text2);margin-top:3px}
.avatar{width:38px;height:38px;border-radius:50%;background:var(--accent);display:grid;place-items:center;color:#fff;font-weight:600;font-size:15px}

/* ===== Cards ===== */
.grid{display:grid;gap:16px}
.grid.cols4{grid-template-columns:repeat(4,1fr)}
.grid.cols3{grid-template-columns:repeat(3,1fr)}
.grid.cols2{grid-template-columns:repeat(2,1fr)}
.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:20px;box-shadow:var(--shadow)}
.card h3{font-size:15px;font-weight:600;margin-bottom:14px;display:flex;align-items:center;justify-content:space-between;gap:8px}
.card h3 .link{font-size:12.5px;color:var(--accent);font-weight:500;cursor:pointer}
.stat .label{display:flex;align-items:center;gap:8px;font-size:13px;color:var(--text2);font-weight:500}
/* chip icone: neutre di default, colorate con le classi c-* dove serve */
.stat .icon{width:30px;height:30px;border-radius:8px;display:grid;place-items:center;background:var(--surface2);color:var(--text2)}
.stat .icon svg{width:15px;height:15px;display:block}
.c-accent{background:var(--accent-soft)!important;color:var(--accent)!important}
.c-green{background:var(--green-soft)!important;color:var(--green)!important}
.c-amber{background:var(--amber-soft)!important;color:var(--amber)!important}
.c-blue{background:var(--blue-soft)!important;color:var(--blue)!important}
.c-rose{background:var(--rose-soft)!important;color:var(--rose)!important}
.stat .value{font-size:24px;font-weight:700;margin-top:10px}
.stat .delta{font-size:12.5px;margin-top:4px;font-weight:500}
.up{color:var(--green)} .down{color:var(--red)}
.muted{color:var(--text2)}
.empty{color:var(--text2);font-size:13.5px;padding:14px 0;text-align:center}

.progress{height:6px;background:var(--surface2);border-radius:99px;overflow:hidden}
.progress span{display:block;height:100%;border-radius:99px}

.row{display:flex;align-items:center;gap:12px;padding:11px 0;border-bottom:1px solid var(--border)}
.row:last-child{border-bottom:none;padding-bottom:0}
.row .ricon{width:36px;height:36px;border-radius:10px;display:grid;place-items:center;flex-shrink:0;background:var(--surface2);color:var(--text2)}
.row .ricon svg{width:17px;height:17px;display:block}
.row .rbody{flex:1;min-width:0}
.row .rtitle{font-size:14px;font-weight:500}
.row .rsub{font-size:12.5px;color:var(--text2);margin-top:1px}
.row .ramount{font-size:14px;font-weight:600;white-space:nowrap}
.row .del{opacity:0;color:var(--text2);font-size:15px;padding:4px 6px;border-radius:7px;transition:opacity .15s}
.row:hover .del{opacity:1}
.row .del:hover{background:var(--rose-soft);color:var(--rose)}

/* badge: sfondo neutro, testo colorato per gli stati che contano */
.badge{font-size:11.5px;font-weight:600;padding:3px 9px;border-radius:99px;white-space:nowrap;background:var(--surface2);color:var(--text2)}
.b-green{background:var(--green-soft);color:var(--green)}
.b-amber{color:var(--amber)}
.b-blue{color:var(--blue)}
.b-rose{color:var(--rose)}
.b-accent{color:var(--accent)}

.fab{
  position:fixed;right:24px;bottom:calc(24px + env(safe-area-inset-bottom));z-index:50;
  width:54px;height:54px;border-radius:17px;background:var(--accent);color:#fff;
  font-size:24px;box-shadow:0 5px 14px rgba(83,99,224,.35);display:grid;place-items:center;
}

/* ===== Bottom nav ===== */
.bottomnav{
  display:none;position:fixed;left:0;right:0;bottom:0;z-index:40;
  background:var(--surface);border-top:1px solid var(--border);
  padding:6px 8px calc(6px + env(safe-area-inset-bottom));
}
.bottomnav .inner{display:flex;justify-content:space-around;max-width:500px;margin:0 auto}
.bottomnav button{display:flex;flex-direction:column;align-items:center;gap:3px;padding:6px 10px;border-radius:10px;font-size:10.5px;font-weight:500;color:var(--text2)}
.bottomnav button svg{width:22px;height:22px}
.bottomnav button.active{color:var(--accent)}

/* ===== Sezioni ===== */
.view{display:none}
.view.active{display:block;animation:fadein .2s ease}
@keyframes fadein{from{opacity:0;transform:translateY(4px)}to{opacity:1;transform:none}}
.section-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:18px}
.section-head h2{font-size:19px;font-weight:700}
.pill-btn{background:var(--accent);color:#fff;font-size:13.5px;font-weight:600;padding:9px 16px;border-radius:10px}
.pill-btn.secondary{background:var(--surface2);color:var(--text)}
.filterbar{float:right;display:inline-flex;gap:6px;align-items:center;font-weight:400}
.filterbar input[type=month]{background:var(--surface2);border-radius:8px;padding:5px 8px;font-size:12.5px;color:var(--text);border:none}
.mini-btn{background:var(--surface2);color:var(--text2);font-size:12px;font-weight:600;padding:6px 10px;border-radius:8px}
.mini-btn:hover{color:var(--text)}

/* Revisione import bancario */
.rev-toolbar{display:flex;gap:8px;margin-bottom:10px}
.rev-row{display:flex;align-items:center;gap:10px;padding:9px 0;border-bottom:1px solid var(--border)}
.rev-row:last-child{border-bottom:none}
.rev-row input[type=checkbox]{width:16px;height:16px;flex-shrink:0;accent-color:var(--accent)}
.rev-row .rdate{font-size:12px;color:var(--text2);width:64px;flex-shrink:0;font-variant-numeric:tabular-nums}
.rev-row .rdesc{flex:1;min-width:0;font-size:13.5px;font-weight:500;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.rev-row .rnote{font-size:11.5px;color:var(--text2);font-weight:400;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.rev-row .ramt{font-size:13.5px;font-weight:600;white-space:nowrap;width:90px;text-align:right;flex-shrink:0}
.rev-row select{background:var(--surface2);border:1px solid var(--border);border-radius:8px;padding:6px 8px;font-size:12.5px;color:var(--text);width:150px;flex-shrink:0}
.rev-row.off{opacity:.45}
@media (max-width:767px){
  .rev-row{flex-wrap:wrap}
  .rev-row .rdesc{flex-basis:calc(100% - 200px)}
  .rev-row select{width:100%;margin-left:26px}
}
code{background:var(--surface2);padding:1px 5px;border-radius:5px;font-size:11.5px}
.tabs{display:flex;gap:6px;margin-bottom:18px;background:var(--surface2);padding:4px;border-radius:11px;width:max-content}
.tabs button{padding:7px 16px;border-radius:8px;font-size:13px;font-weight:500;color:var(--text2)}
.tabs button.active{background:var(--surface);color:var(--text);box-shadow:var(--shadow);font-weight:600}

/* Grafico a barre */
.chart{display:flex;align-items:flex-end;gap:10px;height:140px;padding-top:8px}
.chart .col{flex:1;display:flex;flex-direction:column;align-items:center;gap:6px;height:100%;justify-content:flex-end}
.chart .bars{display:flex;gap:4px;align-items:flex-end;height:100%}
.chart .bar{width:14px;border-radius:5px 5px 2px 2px;min-height:2px}
.chart .lbl{font-size:11px;color:var(--text2)}

/* Kanban */
.kanban{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.kanban .colhead{display:flex;align-items:center;gap:8px;font-size:13px;font-weight:600;color:var(--text2);margin-bottom:12px;text-transform:uppercase;letter-spacing:.4px}
.kanban .dot{width:8px;height:8px;border-radius:50%}
.kcard{background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:14px;box-shadow:var(--shadow);margin-bottom:10px}
.kcard .ktitle{font-size:14px;font-weight:600;display:flex;justify-content:space-between;gap:6px}
.kcard .ksub{font-size:12.5px;color:var(--text2);margin:5px 0 10px}
.kcard .kfoot{display:flex;align-items:center;justify-content:space-between;font-size:12px;color:var(--text2)}
.kcard .kactions{display:flex;gap:2px}
.kcard .kactions button{font-size:12px;color:var(--text2);padding:2px 6px;border-radius:6px}
.kcard .kactions button:hover{background:var(--surface2);color:var(--text)}

/* Settimana allenamento */
.week{display:grid;grid-template-columns:repeat(7,1fr);gap:8px}
.day{background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:12px 6px;text-align:center}
.day .dname{font-size:11px;color:var(--text2);font-weight:600;text-transform:uppercase}
.day .dnum{font-size:16px;font-weight:700;margin:6px 0}
.day .dicon{width:30px;height:30px;margin:0 auto;border-radius:50%;display:grid;place-items:center;font-size:13px}
.day.done .dicon{background:var(--green-soft);color:var(--green)}
.day.rest .dicon{background:var(--surface2);color:var(--text2)}
.day.today{border-color:var(--accent);box-shadow:0 0 0 1px var(--accent)}

/* Obiettivi */
.goal{margin-bottom:4px}
.goal .gtop{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px;gap:8px}
.goal .gname{font-size:14px;font-weight:600;display:flex;align-items:center;gap:10px;min-width:0}
.goal .gname .gicon{width:34px;height:34px;border-radius:10px;display:grid;place-items:center;flex-shrink:0;background:var(--surface2);color:var(--text2)}
.goal .gname .gicon svg{width:16px;height:16px;display:block}
.goal .gpct{font-size:13px;font-weight:600;color:var(--text2);white-space:nowrap}
.goal .gsub{font-size:12.5px;color:var(--text2);margin-top:7px}
.goal .gactions{display:flex;gap:4px;margin-top:10px}
.goal .gactions button{font-size:12px;font-weight:600;padding:5px 10px;border-radius:8px;background:var(--surface2);color:var(--text2)}
.goal .gactions button:hover{color:var(--text)}

/* Tabella posizioni */
.table{width:100%;border-collapse:collapse;font-size:13.5px}
.table th{text-align:left;font-size:11.5px;text-transform:uppercase;letter-spacing:.4px;color:var(--text2);font-weight:600;padding:8px 10px;border-bottom:1px solid var(--border)}
.table td{padding:10px;border-bottom:1px solid var(--border)}
.table tr:last-child td{border-bottom:none}
.table .num{text-align:right;font-variant-numeric:tabular-nums}

/* ===== Modal ===== */
.overlay{position:fixed;inset:0;background:rgba(0,0,0,.45);z-index:100;display:none;align-items:flex-end;justify-content:center}
.overlay.open{display:flex}
.modal{background:var(--surface);border:1px solid var(--border);border-radius:20px 20px 0 0;width:100%;max-width:480px;padding:22px;max-height:88vh;overflow-y:auto;animation:slideup .22s ease}
@keyframes slideup{from{transform:translateY(40px);opacity:0}to{transform:none;opacity:1}}
.modal h3{font-size:17px;font-weight:700;margin-bottom:16px}
.field{margin-bottom:13px}
.field label{display:block;font-size:12.5px;font-weight:600;color:var(--text2);margin-bottom:5px}
.field input,.field select,.field textarea{
  width:100%;padding:10px 12px;border:1px solid var(--border);border-radius:10px;
  background:var(--surface2);outline:none;
}
.field input:focus,.field select:focus,.field textarea:focus{border-color:var(--accent)}
.field-row{display:flex;gap:10px}
.field-row .field{flex:1}
.seg{display:flex;gap:6px}
.seg button{flex:1;padding:9px;border-radius:10px;background:var(--surface2);font-size:13.5px;font-weight:600;color:var(--text2)}
.seg button.active{background:var(--accent-soft);color:var(--accent)}
.modal-actions{display:flex;gap:10px;margin-top:18px}
.modal-actions .pill-btn{flex:1;padding:12px}
.modal-actions .ghost{flex:1;padding:12px;border-radius:10px;background:var(--surface2);font-weight:600;color:var(--text2)}

/* ===== Responsive ===== */
@media (min-width:768px){
  .overlay{align-items:center;padding:20px}
  .modal{border-radius:20px}
}
@media (max-width:1023px){
  .nav button{padding:10px 12px}
  .nav button .txt{display:none}
  .grid.cols4{grid-template-columns:repeat(2,1fr)}
}
@media (max-width:767px){
  .topnav{display:none}
  .bottomnav{display:block}
  .theme-btn.mobile-theme{display:grid;background:var(--surface);border:1px solid var(--border)}
  .main{padding:18px 16px 110px}
  .grid.cols4,.grid.cols3,.grid.cols2{grid-template-columns:repeat(2,1fr)}
  .grid.cols2.stack,.grid.cols3.stack{grid-template-columns:1fr}
  .kanban{grid-template-columns:1fr}
  .topbar h1{font-size:21px}
  .week{gap:5px}
  .day{padding:9px 2px}
  .fab{right:18px;bottom:calc(78px + env(safe-area-inset-bottom))}
  .chart .bar{width:10px}
  .row .del{opacity:1}
}
