/* Impleia demo kit — shared clean styles (themed via CSS vars set per demo) */
.ico{display:inline-block;vertical-align:middle;flex:0 0 auto}
svg.ico{stroke-width:1.75}

/* ===== AUTH PAGES (login / signup) ===== */
.auth-page{min-height:100vh;display:grid;grid-template-columns:1.05fr .95fr}
.auth-aside{position:relative;overflow:hidden;background:
  radial-gradient(900px 600px at 20% 10%,color-mix(in srgb,var(--accent) 18%,transparent),transparent 60%),
  linear-gradient(160deg,var(--panel),var(--bg));border-right:1px solid var(--line);
  display:flex;flex-direction:column;justify-content:space-between;padding:46px 52px}
.auth-aside .a-top{display:flex;align-items:center;gap:13px}
.auth-aside .a-logo{width:46px;height:46px;border-radius:12px;display:flex;align-items:center;justify-content:center;font-weight:800;font-size:19px}
.auth-aside h2{font-family:var(--font-head);font-size:30px;font-weight:800;line-height:1.18;margin-top:30px;max-width:440px}
.auth-aside p.lead{font-size:14px;color:var(--muted);margin-top:14px;max-width:430px;line-height:1.6}
.auth-feats{display:flex;flex-direction:column;gap:14px;margin-top:30px}
.auth-feat{display:flex;align-items:flex-start;gap:12px;font-size:13.5px;color:var(--muted);max-width:430px;line-height:1.5}
.auth-feat .fi{width:34px;height:34px;border-radius:9px;display:flex;align-items:center;justify-content:center;background:color-mix(in srgb,var(--accent) 14%,transparent);color:var(--accent);flex:0 0 auto}
.auth-feat b{color:var(--ink);font-weight:700}
.auth-aside .a-foot{font-size:11px;color:var(--faint);letter-spacing:.02em}

.auth-main{display:flex;align-items:center;justify-content:center;padding:40px 28px;background:var(--bg)}
.auth-card{width:100%;max-width:392px}
.auth-card .h{font-family:var(--font-head);font-size:25px;font-weight:800}
.auth-card .sh{font-size:13.5px;color:var(--muted);margin-top:7px;margin-bottom:26px;line-height:1.5}
.auth-field{margin-bottom:16px}
.auth-field label{display:block;font-size:12px;font-weight:600;color:var(--muted);margin-bottom:7px}
.auth-input{position:relative;display:flex;align-items:center}
.auth-input .ii{position:absolute;left:13px;color:var(--faint);display:flex}
.auth-input input{width:100%;font-family:inherit;font-size:14px;color:var(--ink);background:var(--panel);border:1px solid var(--line);border-radius:11px;padding:12px 14px 12px 40px;outline:none;transition:border-color .15s,box-shadow .15s}
.auth-input input::placeholder{color:var(--faint)}
.auth-input input:focus{border-color:var(--accent);box-shadow:0 0 0 3px color-mix(in srgb,var(--accent) 22%,transparent)}
.auth-btn{width:100%;font-family:inherit;font-size:14.5px;font-weight:700;color:var(--accent-ink);background:var(--accent);border:none;border-radius:11px;padding:13px;cursor:pointer;transition:filter .15s;margin-top:6px;display:flex;align-items:center;justify-content:center;gap:8px}
.auth-btn:hover{filter:brightness(1.07)}
.auth-err{font-size:12.5px;color:#ff6a6e;background:rgba(255,90,90,.08);border:1px solid rgba(255,90,90,.25);border-radius:9px;padding:9px 12px;margin-bottom:16px;display:none}
.auth-err.show{display:block}
.auth-alt{font-size:13px;color:var(--muted);text-align:center;margin-top:22px}
.auth-alt a{color:var(--accent);font-weight:700;text-decoration:none;cursor:pointer}
.auth-hint{font-size:11.5px;color:var(--faint);background:var(--panel);border:1px dashed var(--line2);border-radius:9px;padding:9px 12px;margin-top:18px;line-height:1.5}
.auth-hint b{color:var(--muted)}
.auth-powered{font-size:11px;color:var(--faint);text-align:center;margin-top:26px}
.auth-powered b{color:var(--muted)}
@media(max-width:880px){.auth-page{grid-template-columns:1fr}.auth-aside{display:none}}

/* ===== APP TOP BAR ===== */
.appbar{display:flex;align-items:center;justify-content:space-between;padding:11px 0 11px;border-bottom:1px solid var(--line);margin-bottom:14px}
.ab-l{display:flex;align-items:center;gap:12px;min-width:0}
.ab-logo{width:36px;height:36px;border-radius:9px;display:flex;align-items:center;justify-content:center;font-weight:800;font-size:16px;flex:0 0 auto}
.ab-name{font-family:var(--font-head);font-size:15px;font-weight:800;line-height:1.1;white-space:nowrap}
.ab-name small{display:block;font-size:9px;letter-spacing:.16em;text-transform:uppercase;color:var(--accent);font-weight:700;font-family:var(--font,'sans-serif')}
.ab-r{display:flex;align-items:center;gap:10px}
.ab-live{display:flex;align-items:center;gap:7px;font-size:11.5px;color:var(--muted);white-space:nowrap}
.ab-dot{width:8px;height:8px;border-radius:50%;background:var(--green);box-shadow:0 0 0 0 color-mix(in srgb,var(--green) 50%,transparent);animation:abp 2s infinite}
@keyframes abp{0%{box-shadow:0 0 0 0 color-mix(in srgb,var(--green) 45%,transparent)}70%{box-shadow:0 0 0 7px transparent}100%{box-shadow:0 0 0 0 transparent}}
.ab-tour{display:flex;align-items:center;gap:7px;font-family:inherit;font-size:12px;font-weight:600;color:var(--muted);background:var(--panel);border:1px solid var(--line);border-radius:9px;padding:7px 11px;cursor:pointer;transition:.15s}
.ab-tour:hover{color:var(--ink);border-color:var(--line2)}
.ab-user{position:relative}
.ab-userbtn{display:flex;align-items:center;gap:9px;background:var(--panel);border:1px solid var(--line);border-radius:10px;padding:5px 6px 5px 11px;cursor:pointer}
.ab-userbtn:hover{border-color:var(--line2)}
.ab-av{width:28px;height:28px;border-radius:7px;display:flex;align-items:center;justify-content:center;font-weight:800;font-size:12px;background:var(--accent);color:var(--accent-ink)}
.ab-uinfo{display:flex;flex-direction:column;text-align:left;line-height:1.2;max-width:160px;overflow:hidden}
.ab-uinfo .n{display:block;font-size:12.5px;font-weight:700;white-space:nowrap;text-overflow:ellipsis;overflow:hidden}
.ab-uinfo .e{display:block;font-size:10.5px;color:var(--faint);white-space:nowrap;text-overflow:ellipsis;overflow:hidden}
.ab-menu{position:absolute;right:0;top:calc(100% + 7px);background:var(--panel);border:1px solid var(--line2);border-radius:11px;box-shadow:0 16px 40px rgba(0,0,0,.5);padding:6px;min-width:180px;display:none;z-index:40}
.ab-menu.open{display:block}
.ab-menu .mi{display:flex;align-items:center;gap:9px;font-size:12.5px;color:var(--ink);padding:9px 10px;border-radius:8px;cursor:pointer}
.ab-menu .mi:hover{background:var(--panel2)}
.ab-menu .mi.danger{color:#ff6a6e}
.ab-menu .sep{height:1px;background:var(--line);margin:5px 2px}
@media(max-width:720px){.ab-live,.ab-uinfo{display:none}}

/* ===== GUIDED TOUR ===== */
#tourOverlay{position:fixed;inset:0;z-index:5000;display:none}
#tourHole{position:absolute;border-radius:12px;box-shadow:0 0 0 9999px rgba(4,8,12,.72);transition:all .3s cubic-bezier(.3,.8,.3,1);pointer-events:none}
#tourPop{position:absolute;width:340px;background:var(--panel);border:1px solid var(--line2);border-radius:14px;box-shadow:0 24px 60px rgba(0,0,0,.6);padding:17px 18px;transition:top .25s ease,left .25s ease}
#tourStepNo{font-size:10px;letter-spacing:.12em;text-transform:uppercase;color:var(--accent);font-weight:800;margin-bottom:8px}
#tourTitle{font-family:var(--font-head);font-size:16.5px;font-weight:800;margin-bottom:7px}
#tourBody{font-size:13px;color:var(--muted);line-height:1.55}
#tourBody b{color:var(--ink)}
#tourCtl{display:flex;align-items:center;justify-content:space-between;margin-top:16px}
.tour-nav{display:flex;gap:8px}
.tour-btn{font-family:inherit;font-size:12.5px;font-weight:700;border-radius:8px;padding:8px 14px;cursor:pointer;border:1px solid var(--line2);background:var(--panel2);color:var(--ink)}
.tour-btn:hover{border-color:var(--accent)}
.tour-btn.tour-pri{background:var(--accent);color:var(--accent-ink);border-color:var(--accent)}
.tour-skip{font-family:inherit;font-size:12px;color:var(--faint);background:none;border:none;cursor:pointer}
.tour-skip:hover{color:var(--muted)}

/* ===================================================================== */
/* PREMIUM SYSTEM v2 — donadoarce-grade (glass · mono · hairline · 4px)   */
/* ===================================================================== */
:root{
  --ease:cubic-bezier(.4,0,.2,1);
  --hair:rgba(255,255,255,.07);
  --hair2:rgba(255,255,255,.09);
  --glass:rgba(0,0,0,.66);
  --mono:'JetBrains Mono',ui-monospace,SFMono-Regular,Menlo,monospace;
  --r:4px;
}
/* numeric + label craft */
.num,.kpi .val,.mkpi .v,.outchip .v,.kpi .value{font-family:var(--mono);font-variant-numeric:tabular-nums;letter-spacing:-.02em}
.mlabel{font-size:9px;font-weight:500;letter-spacing:.18em;text-transform:uppercase;color:rgba(255,255,255,.32)}
.eyebrow-xs{font-size:9.5px;font-weight:500;letter-spacing:.22em;text-transform:uppercase;color:rgba(255,255,255,.3)}
/* glass surfaces */
.glass{background:var(--glass);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border:1px solid var(--hair2);border-radius:var(--r);box-shadow:0 2px 14px rgba(0,0,0,.55)}
.glass-sm{background:rgba(0,0,0,.6);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);border:1px solid var(--hair);border-radius:var(--r)}
/* reveal on mount (staggered) */
@keyframes kitRise{from{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}
.reveal{opacity:0}
.reveal.kin{animation:kitRise .55s var(--ease) both;animation-delay:calc(var(--ri,0)*60ms)}
@media (prefers-reduced-motion:reduce){.reveal{opacity:1!important}.reveal.kin{animation:none}}

/* ---- CINEMATIC PRELOADER (scan-frame) ---- */
#kitPre{position:fixed;inset:0;z-index:9000;background:var(--bg,#070D1A);display:flex;align-items:center;justify-content:center;transition:opacity .6s var(--ease)}
#kitPre.kit-done{opacity:0;pointer-events:none}
#kitPre .kpre-grid{position:absolute;inset:0;opacity:.5;background-image:linear-gradient(var(--hair) 1px,transparent 1px),linear-gradient(90deg,var(--hair) 1px,transparent 1px);background-size:46px 46px;mask-image:radial-gradient(circle at 50% 45%,#000 0%,transparent 72%);-webkit-mask-image:radial-gradient(circle at 50% 45%,#000 0%,transparent 72%)}
#kitPre .kpre-frame{position:absolute;inset:28px;pointer-events:none}
#kitPre .kb{position:absolute;width:26px;height:26px;border:1.5px solid color-mix(in srgb,var(--accent) 70%,transparent);opacity:.65}
#kitPre .kb.tl{top:0;left:0;border-right:none;border-bottom:none}
#kitPre .kb.tr{top:0;right:0;border-left:none;border-bottom:none}
#kitPre .kb.bl{bottom:0;left:0;border-right:none;border-top:none}
#kitPre .kb.br{bottom:0;right:0;border-left:none;border-top:none}
#kitPre .kpre-scan{position:absolute;left:28px;right:28px;height:1px;top:28px;background:linear-gradient(90deg,transparent,color-mix(in srgb,var(--accent) 75%,transparent),transparent);box-shadow:0 0 14px color-mix(in srgb,var(--accent) 60%,transparent);animation:kpreScan 2.4s var(--ease) infinite}
@keyframes kpreScan{0%{top:30px;opacity:0}12%{opacity:1}88%{opacity:1}100%{top:calc(100% - 30px);opacity:0}}
#kitPre .kpre-card{position:relative;text-align:center;display:flex;flex-direction:column;align-items:center;gap:0;animation:kitRise .6s var(--ease) both}
#kitPre .kpre-logo{width:54px;height:54px;border-radius:12px;background:var(--accent);color:var(--accent-ink);display:flex;align-items:center;justify-content:center;font-family:var(--font-head,inherit);font-weight:800;font-size:22px;margin-bottom:20px;box-shadow:0 8px 30px color-mix(in srgb,var(--accent) 30%,transparent)}
#kitPre .kpre-brand{font-family:var(--font-head,inherit);font-size:21px;font-weight:800;color:var(--ink,#fafaf7);letter-spacing:.01em}
#kitPre .kpre-eye{margin-top:9px;font-size:9.5px;font-weight:600;letter-spacing:.24em;text-transform:uppercase;color:color-mix(in srgb,var(--accent) 85%,white 10%)}
#kitPre .kpre-sub{margin-top:5px;font-size:11.5px;color:var(--muted,#8aa)}
#kitPre .kpre-bar{margin-top:22px;width:230px;height:3px;border-radius:9999px;background:var(--hair2);overflow:hidden}
#kitPre .kpre-bar i{display:block;height:100%;width:0;border-radius:9999px;background:linear-gradient(90deg,color-mix(in srgb,var(--accent) 60%,transparent),var(--accent));transition:width .15s linear}
#kitPre .kpre-status{margin-top:13px;font-family:var(--mono);font-size:10px;letter-spacing:.04em;color:rgba(255,255,255,.4);display:flex;gap:9px;align-items:center}
#kitPre .kpre-pct{color:var(--accent)}
#kitPre .kpre-logoimg{height:44px;width:auto;max-width:78vw;margin-bottom:22px;animation:kitRise .6s var(--ease) both;filter:drop-shadow(0 6px 26px color-mix(in srgb,var(--accent) 22%,transparent))}

/* ---- MAP basemap toggle (glass, donadoarce-style) + satellite darkening ---- */
.kit-maptoggle{display:flex;gap:0;background:var(--glass);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border:1px solid var(--hair2);border-radius:var(--r);overflow:hidden;box-shadow:0 2px 12px rgba(0,0,0,.5);font-family:var(--font,inherit)}
.kit-maptoggle button{font-family:inherit;font-size:9.5px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:rgba(255,255,255,.5);background:none;border:none;padding:7px 11px;cursor:pointer;transition:color .15s var(--ease),background .15s var(--ease)}
.kit-maptoggle button:hover{color:rgba(255,255,255,.85)}
.kit-maptoggle button.on{color:var(--accent-ink);background:var(--accent)}
.leaflet-container.kit-sat .leaflet-tile-pane{filter:brightness(.6) saturate(.82) contrast(1.05)}

/* ---- data-table polish (zebra + row hover + tabular mono) ---- */
table.dt tbody tr{transition:background .12s var(--ease)}
table.dt tbody tr:nth-child(even) td{background:rgba(255,255,255,.014)}
table.dt tbody tr:hover td{background:rgba(255,255,255,.045)}
table.dt td.mono,table.dt td .mono{font-variant-numeric:tabular-nums;letter-spacing:-.01em}

/* ---- keyboard focus rings (accessibility + polish) ---- */
button:focus-visible,a:focus-visible,[tabindex]:focus-visible,input:focus-visible,select:focus-visible,.cchip:focus-visible{
  outline:2px solid color-mix(in srgb,var(--accent) 62%,transparent);outline-offset:2px;border-radius:3px}
.auth-input input:focus-visible{outline:none}
