/* =====================================================================
   Impianti Stampa — tema in stile Asana
   Manrope · accento corallo · superfici chiare · angoli morbidi
   ===================================================================== */
:root{
  --bg:        #f8f8f7;
  --surface:   #ffffff;
  --surface-2: #faf9f9;
  --ink:       #1e1f21;
  --ink-soft:  #6d6e6f;
  --ink-faint: #9b9ca0;
  --line:      #ececec;
  --line-2:    #e2e2e3;

  --coral:     #f06a6a;   /* azione primaria (Asana) */
  --coral-700: #d65a5a;
  --coral-50:  #fdeeee;

  --green:     #1ea672;
  --green-50:  #e6f6ef;
  --amber:     #e8a13a;
  --amber-50:  #fbf2e2;
  --slate-50:  #eef0f2;

  --radius:    12px;
  --radius-sm: 9px;
  --shadow:    0 1px 2px rgba(20,20,30,.05), 0 6px 20px rgba(20,20,30,.04);
  --shadow-sm: 0 1px 2px rgba(20,20,30,.06);
}

*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{
  font-family:'Manrope',system-ui,-apple-system,Segoe UI,Roboto,sans-serif;
  background:var(--bg);
  color:var(--ink);
  font-size:14.5px;
  line-height:1.5;
  -webkit-font-smoothing:antialiased;
}
a{color:inherit;text-decoration:none}

/* ---------- Layout ---------- */
.app{display:flex;min-height:100vh}

.sidebar{
  width:248px;flex:0 0 248px;
  background:var(--surface);
  border-right:1px solid var(--line);
  display:flex;flex-direction:column;
  padding:18px 14px;
  position:sticky;top:0;height:100vh;
}
.brand{display:flex;align-items:center;gap:11px;padding:6px 8px 18px}
.brand-mark{
  width:36px;height:36px;border-radius:10px;flex:none;
  background:linear-gradient(135deg,var(--coral),#f58b6f);
  color:#fff;font-weight:800;font-size:14px;
  display:grid;place-items:center;letter-spacing:.5px;
}
.brand-text strong{display:block;font-size:14.5px;font-weight:700;line-height:1.1}
.brand-text small{color:var(--ink-faint);font-size:11.5px}

.nav{display:flex;flex-direction:column;gap:3px;margin-top:4px}
.nav-link{
  display:flex;align-items:center;gap:11px;
  padding:9px 11px;border-radius:var(--radius-sm);
  color:var(--ink-soft);font-weight:600;font-size:14px;
  transition:background .12s,color .12s;
}
.nav-link:hover{background:var(--surface-2);color:var(--ink)}
.nav-link.is-active{background:var(--coral-50);color:var(--coral-700)}
.nav-ico{width:20px;text-align:center;font-size:15px;opacity:.85}

.sidebar-foot{margin-top:auto;padding-top:14px;border-top:1px solid var(--line)}
.user-chip{display:flex;align-items:center;gap:10px;padding:6px 8px}
.avatar{
  width:34px;height:34px;border-radius:50%;flex:none;
  background:var(--slate-50);color:var(--ink);
  display:grid;place-items:center;font-weight:700;
}
.user-meta strong{display:block;font-size:13.5px;line-height:1.1}
.user-meta small{color:var(--ink-faint);font-size:11.5px;text-transform:capitalize}
.logout{
  display:block;text-align:center;margin-top:8px;
  padding:8px;border-radius:var(--radius-sm);
  color:var(--ink-soft);font-weight:600;font-size:13px;
}
.logout:hover{background:var(--surface-2);color:var(--coral-700)}

.main{flex:1;min-width:0;display:flex;flex-direction:column}
.topbar{
  display:flex;align-items:center;gap:14px;
  padding:18px 28px;border-bottom:1px solid var(--line);
  background:var(--surface);position:sticky;top:0;z-index:5;
}
.topbar h1{font-size:19px;font-weight:800;margin:0;letter-spacing:-.2px}
.burger{display:none;font-size:20px;cursor:pointer;color:var(--ink-soft)}
.content{padding:24px 28px 60px;max-width:1240px;width:100%}

/* ---------- Flash ---------- */
.flash{
  padding:11px 15px;border-radius:var(--radius-sm);margin-bottom:16px;
  font-weight:600;font-size:13.5px;border:1px solid transparent;
}
.flash-ok{background:var(--green-50);color:#0f7a52;border-color:#c7ecda}
.flash-warn{background:var(--amber-50);color:#9a6a14;border-color:#f0dcb4}
.flash-err{background:var(--coral-50);color:var(--coral-700);border-color:#f6d2d2}

/* ---------- Card / sezioni ---------- */
.card{
  background:var(--surface);border:1px solid var(--line);
  border-radius:var(--radius);box-shadow:var(--shadow);
  padding:20px;margin-bottom:20px;
}
.card-head{display:flex;align-items:center;justify-content:space-between;gap:14px;margin-bottom:16px}
.card-head h2{font-size:16px;font-weight:800;margin:0}
.muted{color:var(--ink-soft)}

/* ---------- KPI ---------- */
.kpis{display:grid;grid-template-columns:repeat(auto-fit,minmax(170px,1fr));gap:14px;margin-bottom:22px}
.kpi{
  background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);
  padding:16px 18px;box-shadow:var(--shadow-sm);
}
.kpi .v{font-size:26px;font-weight:800;letter-spacing:-.5px;line-height:1}
.kpi .l{color:var(--ink-soft);font-size:12.5px;font-weight:600;margin-top:6px}
.kpi.accent .v{color:var(--coral-700)}
.kpi.warn   .v{color:var(--amber)}
.kpi.green  .v{color:var(--green)}

/* ---------- Pills / badge ---------- */
.pill{
  display:inline-block;padding:3px 10px;border-radius:999px;
  font-size:12px;font-weight:700;line-height:1.5;white-space:nowrap;
}
.pill-ok{background:var(--green-50);color:#0f7a52}
.pill-warn{background:var(--amber-50);color:#9a6a14}
.pill-muted{background:var(--slate-50);color:var(--ink-soft)}
.pill-zona{background:#eef1fb;color:#4257b2}

/* ---------- Tabelle ---------- */
.table-wrap{overflow-x:auto;border:1px solid var(--line);border-radius:var(--radius);background:var(--surface)}
table{width:100%;border-collapse:collapse;font-size:13.5px}
thead th{
  text-align:left;font-weight:700;color:var(--ink-soft);
  font-size:11.5px;text-transform:uppercase;letter-spacing:.4px;
  padding:11px 14px;border-bottom:1px solid var(--line-2);background:var(--surface-2);
  white-space:nowrap;
}
tbody td{padding:11px 14px;border-bottom:1px solid var(--line);vertical-align:middle}
tbody tr:last-child td{border-bottom:none}
tbody tr:hover{background:var(--surface-2)}
.code{font-weight:800;letter-spacing:.3px}
.t-right{text-align:right}
.nowrap{white-space:nowrap}
.empty{padding:40px;text-align:center;color:var(--ink-faint)}

/* ---------- Bottoni ---------- */
.btn{
  display:inline-flex;align-items:center;gap:7px;justify-content:center;
  padding:9px 15px;border-radius:var(--radius-sm);
  font-family:inherit;font-weight:700;font-size:13.5px;cursor:pointer;
  border:1px solid var(--line-2);background:var(--surface);color:var(--ink);
  transition:background .12s,border-color .12s,transform .04s;
}
.btn:hover{background:var(--surface-2)}
.btn:active{transform:translateY(1px)}
.btn-primary{background:var(--coral);border-color:var(--coral);color:#fff}
.btn-primary:hover{background:var(--coral-700);border-color:var(--coral-700)}
.btn-ghost{border-color:transparent;background:transparent;color:var(--ink-soft)}
.btn-ghost:hover{background:var(--surface-2);color:var(--ink)}
.btn-danger{color:var(--coral-700);border-color:#f1c9c9}
.btn-danger:hover{background:var(--coral-50)}
.btn-sm{padding:6px 11px;font-size:12.5px}
.btn-row{display:flex;gap:8px;flex-wrap:wrap}

/* ---------- Form ---------- */
.filters{display:flex;gap:10px;flex-wrap:wrap;align-items:flex-end;margin-bottom:18px}
.field{display:flex;flex-direction:column;gap:5px}
.field label{font-size:12px;font-weight:700;color:var(--ink-soft)}
input[type=text],input[type=search],input[type=password],input[type=number],
input[type=date],select,textarea{
  font-family:inherit;font-size:14px;color:var(--ink);
  padding:9px 11px;border:1px solid var(--line-2);border-radius:var(--radius-sm);
  background:var(--surface);outline:none;transition:border-color .12s,box-shadow .12s;
  width:100%;
}
input:focus,select:focus,textarea:focus{
  border-color:var(--coral);box-shadow:0 0 0 3px var(--coral-50);
}
textarea{resize:vertical;min-height:80px}
.field-grow{flex:1;min-width:180px}

.form-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:16px}
.form-grid .full{grid-column:1/-1}
.form-actions{display:flex;gap:10px;justify-content:flex-end;margin-top:8px}

/* ---------- Login ---------- */
.login-wrap{min-height:100vh;display:grid;place-items:center;padding:24px;
  background:radial-gradient(1200px 500px at 50% -10%, #fff, var(--bg));}
.login-card{
  width:100%;max-width:380px;background:var(--surface);
  border:1px solid var(--line);border-radius:18px;box-shadow:var(--shadow);
  padding:30px;
}
.login-card .brand{justify-content:center;padding-bottom:8px}
.login-card h2{text-align:center;margin:4px 0 22px;font-size:18px}
.login-card .field{margin-bottom:14px}

/* ---------- Storico timeline ---------- */
.timeline{position:relative;margin-left:6px}
.tl-item{position:relative;padding:0 0 18px 26px;border-left:2px solid var(--line-2)}
.tl-item:last-child{border-left-color:transparent}
.tl-dot{position:absolute;left:-7px;top:2px;width:12px;height:12px;border-radius:50%;
  background:var(--coral);border:2px solid var(--surface)}
.tl-meta{font-size:12px;color:var(--ink-faint);margin-bottom:2px}
.tl-body{font-size:13.5px}
.tl-body b{font-weight:700}
.tag{display:inline-block;padding:1px 8px;border-radius:6px;background:var(--slate-50);
  font-size:11px;font-weight:700;color:var(--ink-soft);margin-right:6px;text-transform:capitalize}

/* ---------- Responsive ---------- */
@media (max-width:860px){
  .sidebar{
    position:fixed;z-index:30;left:0;top:0;transform:translateX(-100%);
    transition:transform .18s ease;box-shadow:var(--shadow);
  }
  #menu-toggle:checked ~ .app .sidebar{transform:translateX(0)}
  .burger{display:inline}
  .content{padding:18px 16px 50px}
  .topbar{padding:14px 16px}
  .form-grid{grid-template-columns:1fr}
}
