/* ============================================================================
   Klepsia · onboarding dinamico + avviso completamento (overlay additivo).
   Caricato da web/index.html DOPO app.js. Non tocca il bundle React: opera
   sopra l'app via window.storage (/api/kv) come lo shell-bridge.
   Namespace classi: .klo-*  (Klepsia Onboarding) per non collidere col bundle.
   ============================================================================ */
:root{
  --klo-slate:#212F49; --klo-ink:#16223B; --klo-indigo:#4F46E5; --klo-indigo-soft:#EEF0FE;
  --klo-green:#16A34A; --klo-green-soft:#E8F6EE; --klo-amber:#B45309; --klo-amber-soft:#FEF3E2;
  --klo-bg:#EEF1F5; --klo-surface:#FFFFFF; --klo-line:#E6E9EF; --klo-mut:#6B7280; --klo-faint:#9AA3B2;
  --klo-shadow:0 18px 50px rgba(20,32,46,.22); --klo-radius:18px;
}
.klo-root, .klo-root *{ box-sizing:border-box; }
.klo-root{ font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Helvetica,Arial,sans-serif; }

/* ---- overlay scrim + wizard ---- */
.klo-scrim{ position:fixed; inset:0; background:rgba(15,23,40,.46); backdrop-filter:blur(3px);
  z-index:2147483000; display:grid; place-items:center; padding:20px; animation:klo-fade .18s ease; }
@keyframes klo-fade{ from{opacity:0} to{opacity:1} }
@keyframes klo-pop{ from{opacity:0; transform:translateY(10px) scale(.985)} to{opacity:1; transform:none} }
.klo-card{ width:100%; max-width:660px; max-height:92vh; background:var(--klo-surface);
  border-radius:22px; box-shadow:var(--klo-shadow); overflow:hidden; display:flex; flex-direction:column;
  animation:klo-pop .22s cubic-bezier(.2,.8,.2,1); }

/* header w/ progress */
.klo-head{ padding:20px 24px 16px; background:linear-gradient(155deg,#1B2740,#0E1626); color:#fff; position:relative; }
.klo-head h2{ margin:0; font-size:19px; font-weight:800; letter-spacing:-.2px; }
.klo-head p{ margin:4px 0 0; font-size:13px; color:rgba(255,255,255,.72); }
.klo-x{ position:absolute; top:16px; right:16px; width:32px; height:32px; border:0; border-radius:9px;
  background:rgba(255,255,255,.12); color:#fff; cursor:pointer; font-size:17px; line-height:1; }
.klo-x:hover{ background:rgba(255,255,255,.22); }
.klo-prog{ margin-top:14px; height:6px; border-radius:999px; background:rgba(255,255,255,.16); overflow:hidden; }
.klo-prog > i{ display:block; height:100%; border-radius:999px; background:linear-gradient(90deg,#6EA8FE,#4F46E5);
  transition:width .35s cubic-bezier(.2,.8,.2,1); }
.klo-steps{ display:flex; gap:6px; margin-top:12px; flex-wrap:wrap; }
.klo-chip{ font-size:11px; font-weight:700; padding:4px 9px; border-radius:999px; background:rgba(255,255,255,.12); color:rgba(255,255,255,.8); }
.klo-chip.done{ background:rgba(110,231,183,.2); color:#A7F3D0; }
.klo-chip.cur{ background:#fff; color:var(--klo-slate); }

/* body */
.klo-body{ padding:22px 24px; overflow-y:auto; }
.klo-stepicon{ width:46px; height:46px; border-radius:13px; background:var(--klo-indigo-soft); color:var(--klo-indigo);
  display:grid; place-items:center; margin-bottom:12px; }
.klo-stepicon svg{ width:24px; height:24px; }
.klo-h3{ font-size:18px; font-weight:800; color:var(--klo-ink); margin:0 0 4px; }
.klo-sub{ font-size:13.5px; color:var(--klo-mut); margin:0 0 18px; line-height:1.5; }
.klo-badge-fond{ display:inline-block; font-size:10.5px; font-weight:800; text-transform:uppercase; letter-spacing:.4px;
  color:var(--klo-amber); background:var(--klo-amber-soft); padding:2px 8px; border-radius:6px; vertical-align:middle; margin-left:8px; }
.klo-badge-opt{ color:var(--klo-mut); background:var(--klo-bg); }

.klo-field{ margin-bottom:13px; }
.klo-field > label{ display:block; font-size:12px; font-weight:700; color:var(--klo-slate); margin-bottom:5px; }
.klo-field input, .klo-field select, .klo-field textarea{ width:100%; font:inherit; font-size:14px; color:var(--klo-ink);
  padding:10px 12px; border:1.5px solid var(--klo-line); border-radius:11px; background:#fff; outline:none; transition:border .15s; }
.klo-field input:focus, .klo-field select:focus, .klo-field textarea:focus{ border-color:var(--klo-indigo); }
.klo-grid2{ display:grid; grid-template-columns:1fr 1fr; gap:0 14px; }
.klo-grid3{ display:grid; grid-template-columns:1fr 1fr 1fr; gap:0 12px; }
.klo-hint{ font-size:12px; color:var(--klo-faint); margin-top:-6px; margin-bottom:12px; }
.klo-rows{ display:flex; flex-direction:column; gap:8px; margin-bottom:10px; }
.klo-rowitem{ display:flex; align-items:center; gap:10px; padding:10px 12px; border:1px solid var(--klo-line);
  border-radius:11px; background:#FBFCFE; font-size:13.5px; }
.klo-rowitem b{ color:var(--klo-ink); } .klo-rowitem .klo-mut{ color:var(--klo-mut); font-size:12.5px; }
.klo-rowitem button{ margin-left:auto; border:0; background:transparent; color:#DC2626; cursor:pointer; font-size:12.5px; font-weight:700; }
.klo-addbtn{ border:1.5px dashed var(--klo-line); background:#fff; color:var(--klo-indigo); font-weight:700; font-size:13px;
  padding:10px; border-radius:11px; cursor:pointer; width:100%; }
.klo-addbtn:hover{ border-color:var(--klo-indigo); background:var(--klo-indigo-soft); }

/* segmented choice */
.klo-seg{ display:flex; gap:8px; flex-wrap:wrap; }
.klo-seg label{ flex:1; min-width:120px; border:1.5px solid var(--klo-line); border-radius:13px; padding:12px; cursor:pointer; transition:.15s; }
.klo-seg label:hover{ border-color:var(--klo-indigo); }
.klo-seg input{ display:none; }
.klo-seg input:checked + .klo-segbox{ }
.klo-seg label:has(input:checked){ border-color:var(--klo-indigo); background:var(--klo-indigo-soft); }
.klo-seg .klo-segt{ font-weight:800; font-size:13.5px; color:var(--klo-ink); }
.klo-seg .klo-segd{ font-size:12px; color:var(--klo-mut); margin-top:2px; }

/* optional cards (last screen) */
.klo-optgrid{ display:grid; grid-template-columns:1fr 1fr; gap:12px; }
.klo-opt{ border:1px solid var(--klo-line); border-radius:14px; padding:14px; background:#FBFCFE; }
.klo-opt .klo-optt{ font-weight:800; font-size:14px; color:var(--klo-ink); display:flex; align-items:center; gap:8px; }
.klo-opt .klo-optd{ font-size:12.5px; color:var(--klo-mut); margin:6px 0 10px; line-height:1.45; }
.klo-opt .klo-optgo{ font-size:12.5px; font-weight:700; color:var(--klo-indigo); background:transparent; border:0; cursor:pointer; padding:0; }
.klo-optdone{ font-size:12px; font-weight:700; color:var(--klo-green); }

/* footer */
.klo-foot{ display:flex; align-items:center; gap:10px; padding:16px 24px; border-top:1px solid var(--klo-line); background:#FCFDFE; }
.klo-foot .klo-spacer{ flex:1; }
.klo-btn{ border:0; border-radius:11px; padding:11px 18px; font:inherit; font-size:14px; font-weight:700; cursor:pointer; }
.klo-btn-primary{ background:var(--klo-indigo); color:#fff; } .klo-btn-primary:hover{ filter:brightness(1.07); }
.klo-btn-primary:disabled{ opacity:.5; cursor:not-allowed; }
.klo-btn-green{ background:var(--klo-green); color:#fff; } .klo-btn-green:hover{ filter:brightness(1.07); }
.klo-btn-ghost{ background:transparent; color:var(--klo-mut); } .klo-btn-ghost:hover{ color:var(--klo-ink); }
.klo-skip{ background:transparent; border:0; color:var(--klo-mut); font:inherit; font-size:13px; font-weight:700; cursor:pointer; }
.klo-skip:hover{ color:var(--klo-ink); text-decoration:underline; }

/* checkbox row */
.klo-check{ display:flex; align-items:flex-start; gap:9px; cursor:pointer; font-size:13px; color:var(--klo-ink); margin-top:8px; }
.klo-check input{ width:17px; height:17px; margin-top:1px; accent-color:var(--klo-indigo); flex-shrink:0; }

/* ---- floating completion notice (homepage) ---- */
.klo-fab{ position:fixed; right:18px; bottom:18px; z-index:2147482000; width:330px; max-width:calc(100vw - 28px);
  background:var(--klo-surface); border:1px solid var(--klo-line); border-radius:16px; box-shadow:var(--klo-shadow);
  overflow:hidden; animation:klo-pop .25s ease; }
.klo-fab-head{ display:flex; align-items:center; gap:12px; padding:14px 15px; cursor:pointer; }
.klo-ring{ position:relative; width:42px; height:42px; flex-shrink:0; }
.klo-ring svg{ transform:rotate(-90deg); } .klo-ring .klo-pct{ position:absolute; inset:0; display:grid; place-items:center;
  font-size:12px; font-weight:800; color:var(--klo-slate); }
.klo-fab-head .klo-ft{ font-weight:800; font-size:14px; color:var(--klo-ink); }
.klo-fab-head .klo-fd{ font-size:12px; color:var(--klo-mut); margin-top:1px; }
.klo-fab-head .klo-caret{ margin-left:auto; color:var(--klo-faint); transition:transform .2s; }
.klo-fab.open .klo-caret{ transform:rotate(180deg); }
.klo-fab-list{ display:none; border-top:1px solid var(--klo-line); padding:8px; }
.klo-fab.open .klo-fab-list{ display:block; }
.klo-fab-item{ display:flex; align-items:center; gap:10px; padding:9px 9px; border-radius:10px; font-size:13px; cursor:pointer; }
.klo-fab-item:hover{ background:var(--klo-bg); }
.klo-fab-tick{ width:20px; height:20px; border-radius:50%; flex-shrink:0; display:grid; place-items:center; border:1.5px solid var(--klo-line); color:transparent; }
.klo-fab-tick.on{ background:var(--klo-green); border-color:var(--klo-green); color:#fff; }
.klo-fab-item .klo-lbl{ color:var(--klo-ink); font-weight:600; } .klo-fab-item.on .klo-lbl{ color:var(--klo-mut); text-decoration:line-through; }
.klo-fab-item .klo-fond{ margin-left:auto; font-size:10px; font-weight:800; color:var(--klo-amber); }
.klo-fab-foot{ display:flex; gap:8px; padding:10px; border-top:1px solid var(--klo-line); }
.klo-fab-foot .klo-btn{ flex:1; padding:9px; font-size:13px; }
.klo-fab-foot .klo-dismiss{ background:transparent; border:0; color:var(--klo-faint); font:inherit; font-size:12px; cursor:pointer; }

/* success banner */
.klo-done-banner{ display:flex; align-items:center; gap:12px; background:var(--klo-green-soft); border:1px solid #BBE7CB;
  border-radius:14px; padding:14px 16px; }
.klo-done-banner svg{ color:var(--klo-green); flex-shrink:0; }
.klo-done-banner b{ color:#14532D; } .klo-done-banner span{ color:#3F6B4E; font-size:13px; }

@media(max-width:560px){ .klo-grid2,.klo-grid3,.klo-optgrid{ grid-template-columns:1fr; } .klo-fab{ width:calc(100vw - 28px); } }
