:root{
    --gold:#D8AE6B; --gold-dark:#bd9450; --gold-soft:#f4ead6;
    --ink:#2b2b2b; --soft:#f7f5f0; --line:#ece6da;
    --alma:#8e6fc4; --compass:#3a7bd5; --cofidis:#e08b2f;
    --ok:#1d8a4c; --warn:#c0392b;
    --shadow-sm:0 2px 8px rgba(120,95,45,.06);
    --shadow-md:0 10px 30px rgba(150,120,60,.10);
    --shadow-lg:0 24px 60px rgba(160,128,70,.14);
    --r:18px; --sidebar-w:248px;
}
*{box-sizing:border-box;margin:0;padding:0;}
svg.ic{width:20px;height:20px;flex:0 0 auto;display:inline-block;vertical-align:middle;}
html{scroll-behavior:smooth;}
body{font-family:'Segoe UI',system-ui,-apple-system,sans-serif;background:var(--soft);color:var(--ink);}
a{color:inherit;text-decoration:none;}

/* ===== LOGIN ===== */
.login-page{display:flex;align-items:center;justify-content:center;min-height:100vh;
    background:radial-gradient(900px 500px at 50% -10%,#fbf4e7,transparent 60%),linear-gradient(135deg,#fff 0%,#faf6ee 100%);}
.login-box{background:#fff;border:1px solid var(--line);border-radius:24px;padding:46px 40px;width:400px;max-width:92vw;
    text-align:center;box-shadow:var(--shadow-lg);position:relative;overflow:hidden;}
.login-box::before{content:"";position:absolute;inset:0 0 auto 0;height:5px;background:linear-gradient(90deg,var(--gold),var(--gold-dark));}
.login-logo{max-width:120px;margin-bottom:16px;}
.login-box h1{font-size:21px;font-weight:700;margin-bottom:26px;}
.login-box label{display:block;text-align:left;font-size:12px;text-transform:uppercase;letter-spacing:.6px;margin:16px 0 7px;color:#9a9384;font-weight:600;}
.login-box input{width:100%;padding:13px 15px;border:1px solid var(--line);border-radius:12px;font-size:15px;outline:none;transition:.2s;background:#fcfaf6;}
.login-box input:focus{border-color:var(--gold);background:#fff;box-shadow:0 0 0 4px rgba(216,174,107,.16);}
.login-box .btn-gold{width:100%;justify-content:center;margin-top:24px;}

/* ===== BUTTONS ===== */
.btn-gold{background:linear-gradient(135deg,var(--gold),var(--gold-dark));color:#fff;border:none;padding:11px 20px;
    border-radius:12px;font-size:14px;font-weight:600;cursor:pointer;transition:.2s;box-shadow:0 6px 16px rgba(189,148,80,.28);
    display:inline-flex;align-items:center;gap:8px;}
.btn-gold:hover{filter:brightness(1.05);transform:translateY(-1px);}
.btn-ghost{display:inline-flex;align-items:center;gap:7px;padding:10px 16px;border:1px solid var(--gold);color:var(--gold-dark);
    border-radius:12px;font-size:14px;font-weight:600;transition:.2s;background:#fff;cursor:pointer;}
.btn-ghost:hover{background:var(--gold);color:#fff;}
.btn-block{width:100%;justify-content:center;}

/* ===== APP LAYOUT ===== */
.app{display:flex;min-height:100vh;}
.sidebar{width:var(--sidebar-w);background:#fff;border-right:1px solid var(--line);position:fixed;top:0;left:0;bottom:0;
    display:flex;flex-direction:column;padding:22px 16px;z-index:60;box-shadow:var(--shadow-sm);}
.sidebar-logo{text-align:center;padding:6px 0 22px;border-bottom:1px solid var(--line);margin-bottom:18px;}
.sidebar-logo img{max-width:140px;}
.menu{display:flex;flex-direction:column;gap:5px;flex:1;}
.menu-item{display:flex;align-items:center;gap:12px;padding:11px 14px;border-radius:11px;color:#8a8273;font-weight:600;font-size:14px;transition:.18s;}
.menu-item svg{width:19px;height:19px;}
.menu-item:hover{background:var(--soft);color:var(--ink);}
.menu-item.active{background:linear-gradient(135deg,var(--gold),var(--gold-dark));color:#fff;box-shadow:0 6px 16px rgba(189,148,80,.30);}
.sidebar-foot{border-top:1px solid var(--line);padding-top:16px;display:flex;flex-direction:column;gap:12px;}
.sidebar-foot .who{display:flex;align-items:center;gap:10px;font-weight:600;font-size:14px;color:#6b6456;}
.avatar{width:30px;height:30px;border-radius:50%;background:linear-gradient(135deg,var(--gold),var(--gold-dark));color:#fff;
    display:grid;place-items:center;font-size:13px;font-weight:700;flex:0 0 auto;}

.main{margin-left:var(--sidebar-w);flex:1;min-width:0;display:flex;flex-direction:column;}
.topbar{display:flex;align-items:center;gap:14px;background:rgba(255,255,255,.85);backdrop-filter:saturate(180%) blur(12px);
    padding:16px 30px;border-bottom:1px solid var(--line);position:sticky;top:0;z-index:40;}
.page-head h1{font-size:20px;font-weight:700;}
.page-head p{font-size:13px;color:#9a9384;margin-top:2px;}
.hamburger{display:none;border:1px solid var(--line);background:#fff;border-radius:10px;padding:8px;cursor:pointer;color:var(--ink);}
.content{padding:26px 30px;max-width:1280px;width:100%;}

/* ===== PANELS ===== */
.panel{background:#fff;border:1px solid var(--line);border-radius:var(--r);padding:24px 26px;margin-bottom:22px;box-shadow:var(--shadow-sm);}
.muted{color:#9a9384;font-size:13px;}
.note{margin-top:14px;font-size:12.5px;color:#a98b56;background:linear-gradient(90deg,#fdfaf3,#fff);padding:11px 15px;border-radius:10px;border-left:3px solid var(--gold);}
.section-title{display:flex;align-items:center;gap:12px;margin-bottom:18px;}
.section-title .ico{width:38px;height:38px;border-radius:11px;display:grid;place-items:center;background:var(--gold-soft);color:var(--gold-dark);flex:0 0 auto;}
.section-title .ico svg{width:20px;height:20px;}
.section-title h2{font-size:17px;font-weight:700;}
.section-title p{font-size:13px;color:#9a9384;margin-top:2px;}

/* ===== FILTERBAR ===== */
.filterbar{display:flex;justify-content:space-between;gap:18px;flex-wrap:wrap;align-items:center;padding:18px 22px;}
.filterbar .group{display:flex;align-items:center;gap:12px;flex-wrap:wrap;}
.filterbar label{font-size:12px;text-transform:uppercase;letter-spacing:.5px;color:#9a9384;font-weight:600;}
.filterbar input[type=date]{padding:10px 12px;border:1px solid var(--line);border-radius:11px;font-size:14px;background:#fcfaf6;outline:none;}
.filterbar input[type=date]:focus{border-color:var(--gold);background:#fff;}
.file-input input[type=file]{border:1px dashed var(--gold);background:#fffdf8;cursor:pointer;border-radius:11px;padding:9px 12px;}

/* ===== KPI ===== */
.kpi-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:16px;margin-bottom:24px;}
.kpi{background:#fff;border:1px solid var(--line);border-radius:16px;padding:20px;box-shadow:var(--shadow-sm);position:relative;overflow:hidden;transition:.22s;}
.kpi:hover{transform:translateY(-3px);box-shadow:var(--shadow-md);}
.kpi::before{content:"";position:absolute;top:0;left:0;width:100%;height:4px;background:linear-gradient(90deg,var(--gold),var(--gold-dark));opacity:.85;}
.kpi .ico{width:42px;height:42px;border-radius:12px;display:grid;place-items:center;background:var(--gold-soft);color:var(--gold-dark);margin-bottom:14px;}
.kpi .ico svg{width:21px;height:21px;}
.kpi .lbl{font-size:11.5px;text-transform:uppercase;letter-spacing:.6px;color:#a39a88;font-weight:600;}
.kpi .val{font-size:22px;font-weight:700;margin-top:4px;letter-spacing:-.3px;}
.kpi .sub{font-size:12px;margin-top:6px;font-weight:600;}
.kpi .sub.ok{color:var(--ok);} .kpi .sub.warn{color:var(--warn);} .kpi .sub.dim{color:#a39a88;font-weight:500;}

/* ===== TABLE ===== */
.table-wrap{border:1px solid var(--line);border-radius:14px;overflow:hidden;}
table.data{width:100%;border-collapse:collapse;font-size:14px;}
table.data thead th{background:linear-gradient(135deg,var(--gold),var(--gold-dark));color:#fff;text-align:left;padding:13px 14px;font-weight:600;font-size:12.5px;text-transform:uppercase;letter-spacing:.4px;}
table.data tbody td{padding:12px 14px;border-bottom:1px solid var(--line);}
table.data tbody tr:last-child td{border-bottom:none;}
table.data tbody tr:nth-child(even){background:#fcfaf6;}
table.data tbody tr:hover{background:var(--gold-soft);transition:.15s;}
table.data tfoot td{padding:13px 14px;font-weight:700;background:#fbf6ec;border-top:2px solid var(--gold);}
.num{text-align:right;font-variant-numeric:tabular-nums;}
.gold-text{color:var(--gold-dark);font-weight:700;}
.code{font-family:ui-monospace,monospace;font-size:12.5px;color:#8a8273;}
td.ok{color:var(--ok);font-weight:700;} td.warn{color:var(--warn);font-weight:700;}

.pill{display:inline-flex;align-items:center;gap:6px;padding:4px 11px;border-radius:30px;font-size:12px;font-weight:700;}
.pill.ok{background:#e7f6ec;color:var(--ok);} .pill.warn{background:#fdeaea;color:var(--warn);}
.provider-tag{display:inline-flex;align-items:center;gap:6px;padding:4px 12px;border-radius:30px;font-size:12px;font-weight:700;color:#fff;}
.provider-tag.alma{background:var(--alma);} .provider-tag.compass{background:var(--compass);} .provider-tag.cofidis{background:var(--cofidis);}
.provider-tag.banca,.provider-tag.altro{background:#666;}
.bar{height:8px;border-radius:6px;background:var(--line);overflow:hidden;min-width:90px;}
.bar > i{display:block;height:100%;border-radius:6px;background:linear-gradient(90deg,var(--gold),var(--gold-dark));}
/* ===== REPORT ===== */
.report-grid{display:grid;grid-template-columns:1fr 1fr;gap:22px;}
.donut-wrap{display:flex;align-items:center;gap:28px;flex-wrap:wrap;}
.donut{width:170px;height:170px;border-radius:50%;flex:0 0 auto;position:relative;
    -webkit-mask:radial-gradient(circle 54px at center,transparent 98%,#000 100%);
    mask:radial-gradient(circle 54px at center,transparent 98%,#000 100%);}
.donut-center{position:absolute;inset:0;display:grid;place-items:center;text-align:center;}
.donut-center small{color:#a39a88;font-size:11px;text-transform:uppercase;letter-spacing:.5px;}
.donut-side{flex:1;min-width:200px;}
.donut-total{font-size:24px;font-weight:700;letter-spacing:-.4px;margin-bottom:16px;color:var(--ink);}
.legend{list-style:none;display:flex;flex-direction:column;gap:12px;}
.legend li{display:flex;align-items:center;gap:10px;font-size:14px;}
.legend .dot{width:12px;height:12px;border-radius:4px;}
.legend .v{margin-left:auto;font-weight:700;font-variant-numeric:tabular-nums;}
.barlist{display:flex;flex-direction:column;gap:16px;}
.barlist .row{display:grid;grid-template-columns:140px 1fr auto;align-items:center;gap:14px;}
.barlist .name{font-size:13.5px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.barlist .track{height:12px;border-radius:8px;background:var(--soft);overflow:hidden;}
.barlist .track > i{display:block;height:100%;border-radius:8px;}
.barlist .amt{font-size:13px;font-weight:700;font-variant-numeric:tabular-nums;white-space:nowrap;}
.stat-row{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;}
.stat{background:#fcfaf6;border:1px solid var(--line);border-radius:14px;padding:18px;text-align:center;}
.stat .v{font-size:22px;font-weight:700;color:var(--gold-dark);}
.stat .l{font-size:12px;color:#a39a88;text-transform:uppercase;letter-spacing:.5px;margin-top:4px;font-weight:600;}

/* ===== USERS PAGE ===== */
.grid-2{display:grid;grid-template-columns:340px 1fr;gap:22px;align-items:start;}
.form-stack{display:flex;flex-direction:column;gap:6px;}
.form-stack label{font-size:12px;text-transform:uppercase;letter-spacing:.5px;color:#9a9384;font-weight:600;margin-top:10px;}
.form-stack input{padding:11px 13px;border:1px solid var(--line);border-radius:11px;font-size:14px;background:#fcfaf6;outline:none;}
.form-stack input:focus{border-color:var(--gold);background:#fff;box-shadow:0 0 0 3px rgba(216,174,107,.15);}
.form-stack .btn-gold{margin-top:18px;}
.row-actions{display:flex;align-items:center;gap:8px;flex-wrap:wrap;}
.inline-pw{display:flex;align-items:center;gap:6px;}
.inline-pw input{padding:8px 10px;border:1px solid var(--line);border-radius:9px;font-size:13px;background:#fcfaf6;width:150px;outline:none;}
.inline-pw input:focus{border-color:var(--gold);background:#fff;}
.btn-mini{border:1px solid var(--line);background:#fff;border-radius:9px;padding:8px;cursor:pointer;color:var(--gold-dark);display:inline-flex;transition:.18s;}
.btn-mini:hover{background:var(--gold-soft);}
.btn-mini.danger{color:var(--warn);}
.btn-mini.danger:hover{background:#fdeaea;}

/* ===== ALERTS ===== */
.alert{padding:14px 18px;border-radius:13px;margin-bottom:20px;font-size:14px;display:flex;align-items:center;gap:10px;box-shadow:var(--shadow-sm);}
.alert svg{width:18px;height:18px;flex:0 0 auto;}
.alert.success{background:#eef9f1;color:var(--ok);border:1px solid #bfe6cd;}
.alert.error{background:#fdeeee;color:var(--warn);border:1px solid #f0c6c6;}
.empty{text-align:center;color:#b3aa97;padding:34px;font-size:14px;}

/* ===== RESPONSIVE ===== */
@media(max-width:1100px){ .kpi-grid{grid-template-columns:repeat(3,1fr);} .grid-2{grid-template-columns:1fr;} }
@media(max-width:900px){
    .sidebar{transform:translateX(-100%);transition:transform .25s;}
    .sidebar.open{transform:translateX(0);}
    .main{margin-left:0;}
    .hamburger{display:inline-flex;}
    .report-grid{grid-template-columns:1fr;}
}
@media(max-width:680px){
    .kpi-grid{grid-template-columns:1fr 1fr;}
    .stat-row{grid-template-columns:1fr;}
    .content{padding:18px;}
    table.data{min-width:600px;}
    .table-wrap{overflow-x:auto;}
    .barlist .row{grid-template-columns:100px 1fr;}
    .barlist .amt{grid-column:2;text-align:right;}
}