/* ============================================================================
   Portale Report Call Center — stile Q-Farma
   Palette canonica dai report (reportpenutiriunione/static/report.css)
   ========================================================================== */
:root{
  --primary:#044f8b; --primary-dark:#033a66; --primary-light:#0565a8;
  --bg:#eef2f7; --card:#ffffff;
  --success:#009c4f; --success-dark:#007a3e;
  --warn:#ff9800; --warn-dark:#e65100; --danger:#e30513;
  --grey:#9aa7b4; --ink:#243b53; --muted:#6b7c8f; --line:#d8e0ea;
  --shadow:0 2px 10px rgba(4,79,139,.08); --shadow-h:0 10px 28px rgba(4,79,139,.18);
  --radius:12px;
}
*{box-sizing:border-box}
html,body{margin:0;padding:0;height:100%}
body{font-family:'Segoe UI',Roboto,Helvetica,Arial,sans-serif;background:var(--bg);color:var(--ink);
  -webkit-font-smoothing:antialiased;}
a{color:var(--primary);text-decoration:none}
a:hover{text-decoration:underline}

/* ── Top bar (header globale) ────────────────────────────────────────────── */
.topbar{position:sticky;top:0;z-index:40;display:flex;align-items:center;gap:14px;
  background:linear-gradient(135deg,var(--primary-dark),var(--primary) 55%,var(--primary-light));
  color:#fff;padding:10px 20px;box-shadow:0 3px 12px rgba(4,79,139,.22)}
.topbar .brand{display:flex;align-items:center;gap:12px;min-width:0}
.topbar .brand img{height:30px;background:#fff;border-radius:7px;padding:3px 9px;display:block}
.topbar .brand .tt{line-height:1.1;min-width:0}
.topbar .brand .tt b{font-size:15.5px;font-weight:800;letter-spacing:.2px;white-space:nowrap}
.topbar .brand .tt span{font-size:11px;opacity:.9;display:block}
.topbar .spacer{flex:1}
.topbar .who{font-size:12px;opacity:.95;display:flex;align-items:center;gap:10px;white-space:nowrap}
.topbar .who a{color:#fff;border:1px solid rgba(255,255,255,.5);border-radius:6px;padding:3px 9px;font-weight:600;font-size:11.5px}
.topbar .who a:hover{background:rgba(255,255,255,.16);text-decoration:none}
.topbar a.homelink{color:#fff;font-weight:700}
.topbar a.homelink:hover{text-decoration:none;opacity:.85}

/* select + chip nel topbar (shell) */
.topbar select{font-size:12.5px;padding:5px 8px;border-radius:7px;border:1px solid rgba(255,255,255,.5);
  background:rgba(255,255,255,.12);color:#fff;font-weight:600;max-width:260px}
.topbar select option{color:var(--ink)}
.topbar .rtitle{font-weight:800;font-size:14px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.chiprow{display:flex;align-items:center;gap:7px;flex-wrap:wrap}
.chip{font-size:12px;font-weight:600;color:#fff;background:rgba(255,255,255,.14);
  border:1px solid rgba(255,255,255,.45);border-radius:20px;padding:4px 12px;cursor:pointer;white-space:nowrap}
.chip:hover{background:rgba(255,255,255,.26);text-decoration:none}
.chip.active{background:#fff;color:var(--primary);border-color:#fff}
.btn-ghost{font-size:12px;font-weight:600;color:#fff;background:transparent;border:1px solid rgba(255,255,255,.5);
  border-radius:7px;padding:5px 11px;cursor:pointer;white-space:nowrap;text-decoration:none;display:inline-block}
.btn-ghost:hover{background:rgba(255,255,255,.16);text-decoration:none}

/* ── Landing ─────────────────────────────────────────────────────────────── */
.wrap{max-width:1240px;margin:0 auto;padding:26px 22px 60px}
.hero{display:flex;align-items:flex-end;justify-content:space-between;gap:20px;margin:6px 0 22px;flex-wrap:wrap}
.hero h1{margin:0;font-size:26px;font-weight:800;color:var(--primary-dark);letter-spacing:.2px}
.hero p{margin:6px 0 0;color:var(--muted);font-size:14px;max-width:760px}
.hero .count{font-size:12.5px;color:var(--muted);background:#fff;border:1px solid var(--line);
  border-radius:20px;padding:6px 14px;font-weight:600;box-shadow:var(--shadow)}

.section{margin:30px 0 6px}
.section h2{font-size:13px;text-transform:uppercase;letter-spacing:1px;color:var(--primary);
  margin:0 0 14px;display:flex;align-items:center;gap:10px}
.section h2::after{content:"";flex:1;height:1px;background:var(--line)}

.grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(310px,1fr));gap:18px}
.card{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);
  box-shadow:var(--shadow);padding:18px 18px 16px;display:flex;flex-direction:column;gap:10px;
  transition:transform .14s ease,box-shadow .14s ease,border-color .14s ease;position:relative;overflow:hidden}
.card::before{content:"";position:absolute;left:0;top:0;bottom:0;width:4px;
  background:linear-gradient(180deg,var(--primary),var(--primary-light))}
.card:hover{transform:translateY(-3px);box-shadow:var(--shadow-h);border-color:#b9cde3}
.card .c-head{display:flex;align-items:center;gap:12px}
.card .emoji{font-size:26px;width:46px;height:46px;flex:0 0 46px;display:grid;place-items:center;
  background:linear-gradient(180deg,#fafcff,#e9f1fa);border:1px solid var(--line);border-radius:11px}
.card h3{margin:0;font-size:16px;font-weight:800;color:var(--primary-dark);line-height:1.2}
.card .sub{color:var(--muted);font-size:12.8px;line-height:1.5;flex:1}
.card .c-foot{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-top:4px;flex-wrap:wrap}
.views{display:flex;gap:6px;flex-wrap:wrap}
.views a{font-size:11.5px;font-weight:600;color:var(--primary);background:#eef5fc;border:1px solid #cfe0f2;
  border-radius:16px;padding:3px 10px}
.views a:hover{background:var(--primary);color:#fff;text-decoration:none}
.btn{font-size:13px;font-weight:700;color:#fff;background:var(--primary);border:0;border-radius:8px;
  padding:8px 16px;cursor:pointer;display:inline-flex;align-items:center;gap:7px}
.btn:hover{background:var(--primary-light);text-decoration:none;color:#fff}
.btn.open::after{content:"→";font-weight:800}

/* ── Shell (report in iframe) ────────────────────────────────────────────── */
body.shell{display:flex;flex-direction:column;height:100vh;overflow:hidden;background:#dde5ee}
.shell-frame{flex:1 1 auto;border:0;width:100%;height:100%;background:#fff;display:block}
.shell-bar2{display:flex;align-items:center;gap:12px;background:#fff;border-bottom:1px solid var(--line);
  padding:7px 18px;box-shadow:0 1px 4px rgba(0,0,0,.05);flex-wrap:wrap}
.shell-bar2 .chip{color:var(--primary);background:#eef5fc;border-color:#cfe0f2}
.shell-bar2 .chip:hover{background:var(--primary-light);color:#fff}
.shell-bar2 .chip.active{background:var(--primary);color:#fff;border-color:var(--primary)}
.shell-bar2 .lbl{font-size:11.5px;color:var(--muted);font-weight:700;text-transform:uppercase;letter-spacing:.5px}
.shell-bar2 .spacer{flex:1}
.shell-bar2 a.act{font-size:12px;font-weight:600;color:var(--primary);border:1px solid var(--line);
  border-radius:7px;padding:5px 11px}
.shell-bar2 a.act:hover{background:var(--primary);color:#fff;text-decoration:none}

/* ── Login ───────────────────────────────────────────────────────────────── */
body.login{display:grid;place-items:center;min-height:100vh;
  background:linear-gradient(135deg,#0a3d6b,#044f8b 55%,#0565a8)}
.loginbox{width:360px;max-width:92vw;background:#fff;border-radius:16px;overflow:hidden;
  box-shadow:0 24px 60px rgba(0,0,0,.35)}
.loginbox .lh{background:linear-gradient(135deg,var(--primary-dark),var(--primary-light));
  padding:24px 26px;text-align:center;color:#fff}
.loginbox .lh img{height:34px;background:#fff;border-radius:8px;padding:5px 12px}
.loginbox .lh h1{margin:14px 0 2px;font-size:18px;font-weight:800}
.loginbox .lh p{margin:0;font-size:12px;opacity:.9}
.loginbox form{padding:22px 26px 26px;display:flex;flex-direction:column;gap:13px}
.loginbox label{font-size:12px;font-weight:700;color:var(--muted);display:block;margin-bottom:5px}
.loginbox input{width:100%;font-size:14px;padding:10px 12px;border:1px solid var(--line);border-radius:9px;color:var(--ink)}
.loginbox input:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px rgba(4,79,139,.12)}
.loginbox button{margin-top:4px;font-size:14px;font-weight:700;color:#fff;background:var(--primary);
  border:0;border-radius:9px;padding:11px;cursor:pointer}
.loginbox button:hover{background:var(--primary-light)}
.loginbox .err{background:#fdecea;color:#a3001a;border:1px solid #f5c2c7;border-radius:8px;
  padding:9px 12px;font-size:12.5px;font-weight:600}
.loginbox .foot{padding:0 26px 20px;text-align:center;color:var(--grey);font-size:11px}

/* ── Footer ──────────────────────────────────────────────────────────────── */
.pfoot{margin-top:40px;text-align:center;color:var(--grey);font-size:11.5px;line-height:1.7}
.pfoot b{color:var(--primary)}
.dot{width:7px;height:7px;border-radius:50%;background:var(--success);display:inline-block;vertical-align:1px;margin-right:5px}

@media (max-width:560px){
  .topbar .brand .tt span{display:none}
  .hero h1{font-size:22px}
}

/* ═══ Layout con sidebar persistente (app.html) ══════════════════════════════ */
body.app{display:flex;height:100vh;overflow:hidden;background:#dde5ee}
.sidebar{width:264px;flex:0 0 264px;height:100vh;display:flex;flex-direction:column;
  background:linear-gradient(180deg,var(--primary-dark),#043e6f 60%,var(--primary));
  color:#eaf1f8;box-shadow:2px 0 14px rgba(4,79,139,.25);z-index:10}
.sb-brand{display:flex;align-items:center;gap:11px;padding:16px 16px;border-bottom:1px solid rgba(255,255,255,.14);text-decoration:none}
.sb-brand:hover{text-decoration:none}
.sb-brand img{height:30px;background:#fff;border-radius:7px;padding:3px 9px}
.sb-brand .tt b{display:block;color:#fff;font-size:14.5px;font-weight:800;line-height:1.1}
.sb-brand .tt span{color:#b9d4ef;font-size:11px}
.sb-nav{flex:1 1 auto;overflow-y:auto;padding:10px 10px 16px}
.sb-nav::-webkit-scrollbar{width:8px}
.sb-nav::-webkit-scrollbar-thumb{background:rgba(255,255,255,.18);border-radius:4px}
.sb-cat{font-size:10px;text-transform:uppercase;letter-spacing:1px;color:#8fb6dd;
  font-weight:700;margin:16px 10px 6px}
.sb-item{display:flex;align-items:center;gap:10px;padding:9px 11px;border-radius:9px;
  color:#dbe8f6;text-decoration:none;font-size:13px;font-weight:600;cursor:pointer;
  margin-bottom:2px;border:1px solid transparent;line-height:1.2}
.sb-item .ic{width:20px;text-align:center;font-size:15px;flex:0 0 20px}
.sb-item .tx{flex:1;min-width:0}
.sb-item:hover{background:rgba(255,255,255,.10);color:#fff;text-decoration:none}
.sb-item.active{background:#fff;color:var(--primary-dark);border-color:#fff;box-shadow:0 2px 8px rgba(0,0,0,.18)}
.sb-foot{padding:11px 16px;border-top:1px solid rgba(255,255,255,.14);font-size:11.5px;
  color:#b9d4ef;display:flex;align-items:center;justify-content:space-between;gap:8px}
.sb-foot .u{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.sb-foot a{color:#fff;border:1px solid rgba(255,255,255,.5);border-radius:6px;padding:3px 10px;font-weight:600}
.sb-foot a:hover{background:rgba(255,255,255,.16);text-decoration:none}

.content{flex:1 1 auto;display:flex;flex-direction:column;min-width:0;height:100vh}
.cbar{display:flex;align-items:center;gap:10px;background:#fff;border-bottom:1px solid var(--line);
  padding:9px 18px;box-shadow:0 1px 5px rgba(0,0,0,.05)}
.cbar b{font-size:14.5px;color:var(--primary-dark);font-weight:800}
.cbar .spacer{flex:1}
.cbar a.act{font-size:12px;font-weight:600;color:var(--primary);border:1px solid var(--line);
  border-radius:7px;padding:5px 11px;text-decoration:none}
.cbar a.act:hover{background:var(--primary);color:#fff}
iframe.view{flex:1 1 auto;border:0;width:100%;height:100%;background:#fff;display:block}

@media (max-width:720px){
  .sidebar{width:64px;flex-basis:64px}
  .sb-brand .tt,.sb-item .tx,.sb-cat,.sb-foot .u{display:none}
  .sb-item{justify-content:center}
}

/* ═══ Panoramica KPI (overview.html) ═════════════════════════════════════════ */
body.overview{background:var(--bg)}
.ov-wrap{max-width:1200px;margin:0 auto;padding:22px 22px 50px}
.ov-head{margin:4px 0 18px}
.ov-head h1{margin:0;font-size:22px;font-weight:800;color:var(--primary-dark)}
.ov-head p{margin:5px 0 0;color:var(--muted);font-size:13px}
.ov-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(340px,1fr));gap:16px}
.ov-card{background:#fff;border:1px solid var(--line);border-radius:12px;box-shadow:var(--shadow);
  padding:15px 16px 14px;cursor:pointer;transition:transform .13s,box-shadow .13s,border-color .13s;
  position:relative;overflow:hidden}
.ov-card::before{content:"";position:absolute;left:0;top:0;bottom:0;width:4px;
  background:linear-gradient(180deg,var(--primary),var(--primary-light))}
.ov-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-h);border-color:#b9cde3}
.ov-card:focus{outline:2px solid var(--primary-light);outline-offset:2px}
.ov-h{display:flex;align-items:center;gap:11px;margin-bottom:12px}
.ov-h .em{font-size:22px;width:40px;height:40px;flex:0 0 40px;display:grid;place-items:center;
  background:linear-gradient(180deg,#fafcff,#e9f1fa);border:1px solid var(--line);border-radius:10px}
.ov-ti{flex:1;min-width:0}
.ov-ti b{display:block;font-size:14.5px;font-weight:800;color:var(--primary-dark);line-height:1.15}
.ov-ti .cat{font-size:11px;color:var(--muted)}
.ov-h .go{font-size:11.5px;font-weight:700;color:var(--primary);opacity:0;transition:opacity .13s;white-space:nowrap}
.ov-card:hover .go{opacity:1}
.ov-kpis{display:flex;gap:8px}
.ov-kpis .tile{flex:1;background:linear-gradient(180deg,#fafcff,#eef5fb);border:1px solid var(--line);
  border-top:3px solid var(--primary);border-radius:8px;padding:9px 6px;text-align:center;min-width:0}
.ov-kpis .tn{font-size:16.5px;font-weight:800;color:var(--primary);line-height:1.08;
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;font-variant-numeric:tabular-nums;
  letter-spacing:-.2px}
.ov-kpis .tl{font-size:9px;color:#667;text-transform:uppercase;letter-spacing:.2px;margin-top:4px;line-height:1.2}
.ov-kpis .ld,.ov-kpis .na{color:var(--grey);font-size:12px;padding:10px 4px;font-style:italic}

