:root{
  --blu:#314e68; --blu-d:#28405a; --ambra:#f2be41; --arancio:#ec6608; --viola:#5f437d;
  --ink:#1c2733; --muted:#6b7a88; --line:#e3e8ee; --bg:#eef1f5; --soft:#f6f8fa;
  --ok:#1f8a52; --neg:#b23b3b; --radius:12px;
}
*{ box-sizing:border-box; }
body{ margin:0; background:var(--bg); color:var(--ink);
  font-family:"Helvetica Neue",-apple-system,Arial,sans-serif; font-size:14px; line-height:1.5; }
a{ color:var(--blu); }

.topbar{ background:linear-gradient(135deg,var(--blu),var(--blu-d)); color:#fff; padding:14px 26px;
  display:flex; align-items:center; gap:16px; }
.topbar img{ height:30px; }
.topbar .t{ font-size:14px; color:#cdd9e6; border-left:1px solid rgba(255,255,255,.25); padding-left:16px; }
.topbar .sp{ flex:1; }
.topbar a.nav{ color:#cdd9e6; text-decoration:none; font-weight:600; font-size:13px; padding:7px 13px; border-radius:8px; }
.topbar a.nav:hover{ background:rgba(255,255,255,.10); color:#fff; }
.topbar .who{ color:#cdd9e6; font-size:13px; font-weight:600; padding-left:8px; border-left:1px solid rgba(255,255,255,.25); }
.topbar .logoutform{ margin:0; }
.topbar .nav.logout{ background:rgba(255,255,255,.08); border:0; color:#cdd9e6; font-family:inherit; cursor:pointer; }
.topbar .nav.logout:hover{ background:rgba(255,255,255,.18); color:#fff; }

/* ---------- login ---------- */
.loginbg{ background:linear-gradient(135deg,var(--blu),var(--blu-d)); min-height:100vh; }
.loginwrap{ max-width:380px; margin:0 auto; padding:64px 20px; }
.logincard{ background:#fff; border-radius:14px; padding:30px 28px; box-shadow:0 18px 50px rgba(0,0,0,.28); }
.loginhead{ text-align:center; margin-bottom:18px; }
.loginhead img{ height:38px; margin-bottom:12px; }
.loginhead h1{ font-size:20px; color:var(--blu); margin:0 0 4px; }
.loginhead p{ margin:0; }
.loginfoot{ text-align:center; color:#cdd9e6; margin-top:18px; }

.container{ max-width:920px; margin:26px auto; padding:0 20px; }
.steps{ display:flex; gap:10px; margin-bottom:18px; }
.step{ flex:1; background:#fff; border:1px solid var(--line); border-radius:10px; padding:10px 14px; font-size:13px; color:var(--muted); }
.step b{ display:inline-block; width:20px; height:20px; border-radius:50%; background:var(--soft); color:var(--muted); text-align:center; line-height:20px; font-size:12px; margin-right:8px; }
.step.on{ border-color:var(--blu); color:var(--ink); } .step.on b{ background:var(--blu); color:#fff; }
.step.done b{ background:var(--ok); color:#fff; }

.card{ background:#fff; border:1px solid var(--line); border-radius:var(--radius); padding:22px 24px; box-shadow:0 4px 16px rgba(49,78,104,.06); margin-bottom:18px; }
.card h2{ font-size:16px; margin:0 0 4px; color:var(--blu); }
.card .hint{ color:var(--muted); font-size:13px; margin:0 0 16px; }

.drop{ border:2px dashed #c3cedb; border-radius:10px; padding:18px; text-align:center; color:var(--muted);
  background:var(--soft); cursor:pointer; }
.drop b{ color:var(--blu); }
.drop input{ display:none; }

.grid2{ display:grid; grid-template-columns:1fr 1fr; gap:14px 18px; }
.grid3{ display:grid; grid-template-columns:1fr 1fr 1fr; gap:14px 18px; }
label.f{ display:block; font-size:12px; font-weight:600; color:var(--muted); text-transform:uppercase; letter-spacing:.3px; margin-bottom:5px; }
input,select{ width:100%; height:40px; border:1px solid var(--line); border-radius:9px; padding:0 12px; font-size:14px; color:var(--ink); background:#fff; }
input:focus,select:focus{ outline:none; border-color:var(--blu); box-shadow:0 0 0 3px rgba(49,78,104,.12); }
.field{ margin-bottom:4px; }
.req::after{ content:" *"; color:var(--arancio); }

.btn{ height:44px; padding:0 22px; border:none; border-radius:10px; font-size:14px; font-weight:700; cursor:pointer; }
.btn-primary{ background:var(--arancio); color:#fff; }
.btn-primary:hover{ background:#d35c06; }
.btn-ghost{ background:#fff; color:var(--blu); border:1px solid var(--line); }
.actions{ display:flex; gap:12px; align-items:center; margin-top:18px; }

.banner{ border-radius:10px; padding:12px 16px; font-size:13px; margin-bottom:16px; }
.banner.warn{ background:rgba(242,190,65,.14); border-left:3px solid var(--ambra); color:#7a5b12; }
.banner.hr{ background:rgba(178,59,59,.08); border-left:3px solid var(--neg); color:#8a2f2f; }

.result-head{ display:flex; align-items:center; justify-content:space-between; flex-wrap:wrap; gap:14px; }
.result-head .big{ font-size:34px; font-weight:800; color:var(--arancio); }
.result-head .big.neg{ color:var(--neg); }
.pill{ font-size:13px; font-weight:700; padding:7px 14px; border-radius:999px; }
.pill.ok{ background:rgba(31,138,82,.12); color:var(--ok); } .pill.no{ background:rgba(178,59,59,.10); color:var(--neg); }

.pdfwrap{ border:1px solid var(--line); border-radius:10px; overflow:hidden; background:#525659; }
.pdfwrap iframe{ width:100%; height:560px; border:0; display:block; background:#fff; }
.muted{ color:var(--muted); font-size:13px; }

/* ---------- area admin ---------- */
.adminhead{ margin-bottom:16px; }
.adminhead h1{ font-size:22px; color:var(--blu); margin:0 0 4px; }
.adminhead p{ margin:0; max-width:760px; }
.banner.ok-b{ background:rgba(31,138,82,.10); border-left:3px solid var(--ok); color:#1a6b41; }
.card h3{ font-size:14px; margin:0 0 12px; color:var(--ink); }
.subcard{ border:1px solid var(--line); border-radius:10px; padding:16px 18px; background:var(--soft); }
.grid2 .subcard{ margin-bottom:0; }
.drop.sm{ padding:14px; }
.chk{ display:flex; align-items:center; gap:8px; height:40px; font-size:13px; color:var(--ink);
  text-transform:none; font-weight:500; letter-spacing:0; }
.chk input{ width:auto; height:auto; }

.tablewrap{ overflow-x:auto; border:1px solid var(--line); border-radius:10px; }
.tbl{ width:100%; border-collapse:collapse; font-size:13px; background:#fff; }
.tbl th{ text-align:left; background:var(--soft); color:var(--muted); font-weight:600; font-size:11px;
  text-transform:uppercase; letter-spacing:.3px; padding:9px 12px; border-bottom:1px solid var(--line); white-space:nowrap; }
.tbl td{ padding:9px 12px; border-bottom:1px solid var(--line); white-space:nowrap; }
.tbl tr:last-child td{ border-bottom:0; }
.tbl .r{ text-align:right; font-variant-numeric:tabular-nums; }
.tbl tr.rowsel{ background:rgba(242,190,65,.12); }
.mono{ font-family:ui-monospace,SFMono-Regular,Menlo,monospace; font-size:12px; color:var(--muted); }

.tag{ display:inline-block; font-size:11px; font-weight:700; padding:2px 8px; border-radius:999px;
  background:#eef1f5; color:var(--muted); }
.tag.fixed-t{ background:rgba(31,138,82,.12); color:var(--ok); }
.tag.warn-t{ background:rgba(242,190,65,.18); color:#7a5b12; }

.actcell{ display:flex; gap:8px; align-items:center; }
.actcell form{ margin:0; }
.mini{ display:inline-block; font-size:12px; font-weight:600; padding:5px 10px; border-radius:7px;
  border:1px solid var(--line); background:#fff; color:var(--blu); text-decoration:none; cursor:pointer; }
.mini:hover{ border-color:var(--blu); }
.mini.danger{ color:var(--neg); }
.mini.danger:hover{ border-color:var(--neg); background:rgba(178,59,59,.06); }
