:root{
  --rail:#0a1530; --rail2:#0d1c40; --rail-ink:#9fb0d4; --rail-active:#ffffff;
  --canvas:#f4f6fb; --panel:#ffffff; --panel2:#fbfcfe;
  --ink:#0e1a33; --ink2:#3a4767; --muted:#7c89a6; --faint:#aab4cc;
  --hair:#e9edf6; --hair2:#eef1f8;
  --accent:#2456e8; --accent2:#5b86ff; --accent-soft:#eef3ff; --accent-soft2:#e1eaff;
  --A:#10a36a; --B:#2456e8; --C:#d39a12; --D:#ec6f2c; --E:#df3950;
  --A-s:#e6f6ee; --B-s:#eaf0ff; --C-s:#fbf2dd; --D-s:#fdede2; --E-s:#fcebee;
  --s1:0 1px 2px rgba(15,28,64,.05);
  --s2:0 1px 2px rgba(15,28,64,.05), 0 4px 14px rgba(15,28,64,.05);
  --s3:0 8px 18px rgba(15,28,64,.07), 0 24px 48px rgba(20,38,90,.09);
  --r:16px;
}
*{box-sizing:border-box;margin:0;padding:0}
body{font-family:'Inter',system-ui,sans-serif;color:var(--ink);font-size:14px;background:var(--canvas);-webkit-font-smoothing:antialiased;letter-spacing:-.1px}
.num,.mono{font-family:'Space Grotesk','Inter',sans-serif;font-variant-numeric:tabular-nums;font-feature-settings:"tnum"}
button{font-family:inherit;cursor:pointer;border:none;background:none;color:inherit}
input{font-family:inherit}
.hidden{display:none!important}
svg.ic{width:18px;height:18px;stroke:currentColor;fill:none;stroke-width:1.7;stroke-linecap:round;stroke-linejoin:round;flex:none}
.cap{font-size:11px;font-weight:700;letter-spacing:.7px;text-transform:uppercase;color:var(--muted)}

/* ===== LOGIN ===== */
#login{position:fixed;inset:0;display:flex;align-items:center;justify-content:center;z-index:60;
  background:radial-gradient(1100px 650px at 50% -10%,#dde8ff 0,transparent 62%),linear-gradient(180deg,#eef2fb,#e6ecf7)}
.login-card{width:392px;max-width:92vw;background:var(--panel);border:1px solid #fff;border-radius:22px;padding:40px 34px;box-shadow:var(--s3)}
.brand{display:flex;align-items:center;gap:12px}
.brand-mark{width:40px;height:40px;border-radius:12px;color:#fff;display:flex;align-items:center;justify-content:center;
  background:linear-gradient(145deg,#3a6bff,#1b3fc4);box-shadow:0 8px 18px rgba(36,86,232,.4)}
.brand-mark svg{width:21px;height:21px;stroke:#fff;stroke-width:2}
.brand-name{font-size:21px;font-weight:800;letter-spacing:-.3px}
.brand-name b{color:var(--accent)}
.login-sub{color:var(--muted);font-size:12.5px;margin:16px 0 26px;font-weight:500}
.field{margin-bottom:14px}
.field label{display:block;font-size:11.5px;color:var(--muted);margin-bottom:7px;font-weight:600}
.field input{width:100%;padding:13px 15px;border-radius:12px;background:#f6f8fc;border:1px solid var(--hair);color:var(--ink);font-size:15px;transition:.18s}
.field input:focus{outline:none;border-color:var(--accent);background:#fff;box-shadow:0 0 0 4px var(--accent-soft)}
.btn{width:100%;padding:13px;border-radius:12px;color:#fff;font-weight:700;font-size:15px;transition:.18s;
  background:linear-gradient(145deg,#3a6bff,#2456e8);box-shadow:0 8px 18px rgba(36,86,232,.32)}
.btn:hover{transform:translateY(-1px);box-shadow:0 12px 24px rgba(36,86,232,.4)}
.btn:active{transform:translateY(0)}
.btn:disabled{opacity:.5;cursor:not-allowed}
.err{color:var(--E);font-size:13px;margin-top:11px;min-height:18px}
.auth-toggle{text-align:center;margin-top:16px;font-size:13px;color:var(--muted)}
.auth-toggle a{color:var(--accent);font-weight:700;cursor:pointer}
.auth-toggle a:hover{text-decoration:underline}

/* ===== SHELL ===== */
#app{display:flex;min-height:100vh}
.rail{width:230px;flex:none;position:sticky;top:0;height:100vh;display:flex;flex-direction:column;padding:22px 16px;color:var(--rail-ink);
  background:linear-gradient(180deg,var(--rail2),var(--rail));box-shadow:inset -1px 0 0 rgba(255,255,255,.04)}
.rail .brand{padding:6px 10px 4px}
.rail .brand-name{color:#fff;font-size:19px}
.rail .brand-mark{width:34px;height:34px;border-radius:10px}
.rail-cap{font-size:10px;letter-spacing:1px;color:#5e6f96;font-weight:700;text-transform:uppercase;padding:24px 12px 8px}
.nav{display:flex;flex-direction:column;gap:3px}
.nav a{display:flex;align-items:center;gap:12px;padding:11px 12px;border-radius:11px;color:var(--rail-ink);font-weight:600;font-size:13.5px;cursor:pointer;transition:.16s}
.nav a:hover{background:rgba(255,255,255,.06);color:#fff}
.nav a.active{color:#fff;background:linear-gradient(90deg,rgba(58,107,255,.9),rgba(36,86,232,.55));box-shadow:0 6px 16px rgba(20,40,110,.45)}
.rail .sp{flex:1}
.rail-foot{border-top:1px solid rgba(255,255,255,.07);padding-top:12px}

.main{flex:1;min-width:0;display:flex;flex-direction:column}
.topbar{display:flex;align-items:center;gap:16px;padding:15px 28px;position:sticky;top:0;z-index:20;
  background:rgba(244,246,251,.85);backdrop-filter:blur(14px);border-bottom:1px solid var(--hair)}
.search{flex:1;max-width:500px;display:flex;align-items:center;gap:11px;background:#fff;border:1px solid var(--hair);border-radius:12px;padding:11px 15px;transition:.18s;box-shadow:var(--s1)}
.search:focus-within{border-color:var(--accent);box-shadow:0 0 0 4px var(--accent-soft)}
.search svg{color:var(--muted)}
.search input{flex:1;border:none;background:none;font-size:15px;color:var(--ink);letter-spacing:1.5px;font-weight:600}
.search input:focus{outline:none}
.search input::placeholder{letter-spacing:0;font-weight:500;color:var(--faint)}
.search .go{padding:8px 18px;border-radius:9px;color:#fff;font-weight:700;font-size:13px;background:var(--accent);transition:.16s}
.search .go:hover{background:#1d49d0}
.search .go:disabled{opacity:.5;cursor:not-allowed}
.spacer{flex:1}
.statuschip{display:inline-flex;align-items:center;gap:7px;font-size:12px;font-weight:600;color:var(--ink2);background:#fff;border:1px solid var(--hair);padding:7px 12px;border-radius:999px;box-shadow:var(--s1)}
.statuschip .dot{width:7px;height:7px;border-radius:50%;background:var(--A);box-shadow:0 0 0 3px var(--A-s)}
.exports{display:flex;gap:8px}
.exbtn{display:inline-flex;align-items:center;gap:6px;font-size:12.5px;font-weight:700;color:var(--ink2);background:#fff;border:1px solid var(--hair);padding:8px 13px;border-radius:10px;box-shadow:var(--s1);transition:.16s;cursor:pointer}
.exbtn:hover{border-color:var(--accent);color:var(--accent);box-shadow:0 0 0 4px var(--accent-soft)}
.exbtn svg{width:15px;height:15px}
.exbtn:disabled{opacity:.5;cursor:wait}
.cjoint{background:#fff4e0;color:#b9750a;margin-left:6px}
.user{display:flex;align-items:center;gap:9px;font-weight:600;font-size:13px}
.av{width:34px;height:34px;border-radius:10px;color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:13px;background:linear-gradient(145deg,#3a6bff,#1b3fc4);box-shadow:var(--s1)}
.content{padding:26px 28px;max-width:1280px;width:100%}

/* empty + progress */
.empty{text-align:center;padding:92px 20px;color:var(--muted)}
.empty .ring{width:72px;height:72px;border-radius:20px;color:var(--accent);background:var(--accent-soft);display:flex;align-items:center;justify-content:center;margin:0 auto 20px;box-shadow:var(--s2)}
.empty .ring svg{width:32px;height:32px}
.empty h2{color:var(--ink);font-size:22px;font-weight:800;margin-bottom:9px;letter-spacing:-.3px}
.progress-card{max-width:540px;margin:46px auto;background:var(--panel);border:1px solid var(--hair);border-radius:var(--r);padding:26px;box-shadow:var(--s2)}
.pmsg{display:flex;align-items:center;gap:12px;font-weight:600}
.spin{width:16px;height:16px;border:2.5px solid var(--accent-soft2);border-top-color:var(--accent);border-radius:50%;animation:sp .8s linear infinite}
@keyframes sp{to{transform:rotate(360deg)}}
.pbar{height:7px;border-radius:999px;background:#e9edf6;overflow:hidden;margin:16px 0 8px}
.pbar i{display:block;height:100%;width:0;border-radius:999px;transition:width .4s ease;background:linear-gradient(90deg,var(--accent),#56b6f7)}

/* cards / grid */
.stack{display:flex;flex-direction:column;gap:18px}
.card{background:var(--panel);border:1px solid var(--hair);border-radius:var(--r);padding:22px;box-shadow:var(--s2)}
.card-h{display:flex;align-items:center;justify-content:space-between;margin-bottom:18px}
.card-h h3{font-size:12px;font-weight:700;letter-spacing:.6px;text-transform:uppercase;color:var(--muted)}
.reveal{animation:rise .55s cubic-bezier(.2,.7,.2,1) both}
@keyframes rise{from{opacity:0;transform:translateY(12px)}to{opacity:1;transform:none}}

/* ===== HERO ===== */
.hero{display:grid;grid-template-columns:360px 1fr;gap:8px;align-items:stretch}
.hero-l{padding:24px;border-right:1px solid var(--hair)}
.hero-r{padding:24px;display:flex;flex-direction:column;justify-content:center;gap:18px}
@media(max-width:1080px){.hero{grid-template-columns:1fr}.hero-l{border-right:none;border-bottom:1px solid var(--hair)}}
.gauge{position:relative;width:230px;height:230px;margin:0 auto}
.gauge svg{width:100%;height:100%;display:block}
.g-track{fill:none;stroke:#e9eef7;stroke-width:12;stroke-linecap:round}
.g-arc{fill:none;stroke:var(--A);stroke-width:12;stroke-linecap:round;transition:stroke-dashoffset 1.05s cubic-bezier(.2,.75,.2,1),stroke .4s}
.g-tick{stroke:#cfd8ea;stroke-width:1.5}
.g-tick.maj{stroke:#9fadc9;stroke-width:2}
.g-dot{stroke:#fff;stroke-width:3;transition:fill .4s}
.g-center{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1px}
.g-cap{font-size:10px;letter-spacing:1.4px;color:var(--muted);font-weight:700}
.g-num{font-family:'Space Grotesk';font-size:58px;font-weight:700;line-height:1;color:var(--ink);letter-spacing:-1px}
.verdict{text-align:center;margin-top:4px}
.segpill{display:inline-flex;align-items:center;gap:7px;padding:7px 15px;border-radius:999px;font-weight:700;font-size:13.5px;box-shadow:var(--s1)}
.segpill .sd{width:8px;height:8px;border-radius:50%}
.penalty{display:none;align-items:center;gap:6px;justify-content:center;font-size:11.5px;color:var(--E);font-weight:600;margin-top:10px}
.penalty svg{width:14px;height:14px}

/* risk spectrum */
.spectrum{margin-top:0}
.sp-head{display:flex;justify-content:space-between;margin-bottom:9px}
.sp-zones{display:flex;height:9px;border-radius:999px;overflow:hidden;gap:2px}
.sp-zones i{display:block;border-radius:2px;opacity:.85}
.sp-rail{position:relative;height:14px;margin-top:2px}
.sp-marker{position:absolute;top:-12px;width:3px;height:20px;border-radius:3px;background:var(--ink);transform:translateX(-50%);transition:left 1s cubic-bezier(.2,.75,.2,1)}
.sp-marker::after{content:"";position:absolute;top:-5px;left:50%;transform:translateX(-50%);width:9px;height:9px;border-radius:50%;background:var(--ink);box-shadow:0 0 0 3px #fff}
.sp-scale{display:flex;justify-content:space-between;font-size:10px;color:var(--faint);font-weight:600;margin-top:6px}

.kvs{display:grid;grid-template-columns:1fr 1fr;gap:2px 22px}
.kv{display:flex;align-items:center;justify-content:space-between;padding:11px 0;border-bottom:1px solid var(--hair2);font-size:13px}
.kv:last-child,.kv:nth-last-child(2){border-bottom:none}
.kv .l{display:flex;align-items:center;gap:9px;color:var(--muted);font-weight:500}
.kv .l .mi{width:28px;height:28px;border-radius:8px;background:var(--accent-soft);color:var(--accent);display:flex;align-items:center;justify-content:center}
.kv .l .mi svg{width:14px;height:14px}
.kv .v{font-weight:700;color:var(--ink)}

/* ===== KPI TILES ===== */
.tiles{display:grid;grid-template-columns:repeat(auto-fit,minmax(184px,1fr));gap:14px}
.tile{background:var(--panel);border:1px solid var(--hair);border-radius:14px;padding:17px 18px;box-shadow:var(--s2);transition:transform .2s,box-shadow .2s;position:relative;overflow:hidden}
.tile:hover{transform:translateY(-3px);box-shadow:var(--s3)}
.tile .t-top{display:flex;align-items:center;justify-content:space-between;margin-bottom:13px}
.tile .t-ico{width:34px;height:34px;border-radius:10px;color:var(--accent);background:var(--accent-soft);display:flex;align-items:center;justify-content:center}
.tile .t-ico svg{width:17px;height:17px}
.tile .t-k{font-size:11.5px;color:var(--muted);font-weight:600}
.tile .t-v{font-family:'Space Grotesk';font-size:23px;font-weight:600;margin-top:3px;letter-spacing:-.5px}
.badge{font-size:10.5px;font-weight:700;padding:4px 9px;border-radius:7px}
.b-A{background:var(--A-s);color:var(--A)} .b-B{background:var(--B-s);color:var(--B)}
.b-C{background:var(--C-s);color:var(--C)} .b-D{background:var(--D-s);color:var(--D)} .b-E{background:var(--E-s);color:var(--E)}
.tile .t-bar{height:4px;border-radius:999px;background:var(--hair);margin-top:13px;overflow:hidden}
.tile .t-bar i{display:block;height:100%;border-radius:999px;background:linear-gradient(90deg,var(--accent),#56b6f7)}

/* ===== COLUMNS ===== */
.cols{display:grid;grid-template-columns:1.45fr 1fr;gap:18px;align-items:start}
@media(max-width:1040px){.cols{grid-template-columns:1fr}}

/* table */
table{width:100%;border-collapse:collapse}
th{text-align:left;font-size:10.5px;text-transform:uppercase;letter-spacing:.5px;color:var(--muted);font-weight:700;padding:0 10px 12px}
th.r,td.r{text-align:right}
td{padding:13px 10px;border-top:1px solid var(--hair);font-size:13px}
tbody tr{transition:background .14s}
tbody tr:hover{background:var(--panel2)}
.tdot{width:8px;height:8px;border-radius:50%;display:inline-block;margin-right:8px;vertical-align:middle}
.ttype{font-weight:600}
.tnum{font-family:'Space Grotesk';font-variant-numeric:tabular-nums;font-weight:500}
.chip{display:inline-block;font-size:11px;font-weight:700;padding:3px 9px;border-radius:7px}
.c-h{background:var(--A-s);color:var(--A)} .c-m{background:var(--C-s);color:var(--C)} .c-l{background:var(--E-s);color:var(--E)}
.flag{display:inline-flex;align-items:center;gap:4px;font-size:10px;font-weight:700;padding:2px 7px;border-radius:6px;background:var(--E-s);color:var(--E);margin-left:6px}
.trow-tot td{border-top:2px solid var(--hair);font-weight:800;background:var(--panel2)}

/* factors */
.frow{padding:13px 0;border-bottom:1px solid var(--hair2)}
.frow:last-child{border-bottom:none}
.frow .ft{display:flex;align-items:center;justify-content:space-between;margin-bottom:9px}
.fname{display:flex;align-items:center;font-weight:600;font-size:13.5px}
.fdot{width:8px;height:8px;border-radius:50%;margin-right:10px;background:var(--accent)}
.fsub{font-size:11px;color:var(--faint);margin-left:18px;font-weight:500}
.fright{display:flex;align-items:center;gap:16px}
.fweight{font-family:'Space Grotesk';color:var(--accent);font-weight:600;min-width:46px;text-align:right;font-size:13px}
.fscore{font-family:'Space Grotesk';font-weight:600;min-width:54px;text-align:right;font-size:13px;color:var(--ink2)}
.fbar{height:7px;border-radius:999px;background:var(--hair);overflow:hidden;margin-left:18px}
.fbar i{display:block;height:100%;border-radius:999px;background:linear-gradient(90deg,var(--accent2),var(--accent));transition:width .5s cubic-bezier(.2,.75,.2,1)}
input[type=range]{-webkit-appearance:none;appearance:none;width:100%;height:5px;border-radius:999px;outline:none;margin-top:11px;background:var(--hair)}
input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;width:16px;height:16px;border-radius:50%;border:3px solid #fff;cursor:pointer;transition:.15s;background:var(--accent);box-shadow:0 1px 5px rgba(36,86,232,.5)}
input[type=range]::-webkit-slider-thumb:hover{transform:scale(1.2)}
input[type=range]::-moz-range-thumb{width:13px;height:13px;border:3px solid #fff;border-radius:50%;background:var(--accent);cursor:pointer}
.bk-foot{display:flex;align-items:center;justify-content:space-between;margin-top:16px;padding-top:14px;border-top:1px solid var(--hair)}
.link{color:var(--accent);font-weight:700;font-size:12.5px;padding:7px 12px;border-radius:9px;transition:.15s}
.link:hover{background:var(--accent-soft)}

/* narrative */
.narr h4{font-size:16px;font-weight:800;margin-bottom:11px;letter-spacing:-.2px}
.narr p{color:var(--ink2);line-height:1.72;font-size:13.6px;margin-bottom:12px}
.risk{display:flex;gap:10px;align-items:flex-start;margin:8px 0;color:var(--ink2);font-size:13px}
.risk svg{width:15px;height:15px;color:var(--C);flex:none;margin-top:2px}
.reco{background:var(--accent-soft);border:1px solid var(--accent-soft2);border-radius:12px;padding:13px 15px;color:#1c3aa8;font-size:13.4px;margin-top:6px}
.foot{text-align:center;color:var(--faint);font-size:11.5px;padding:24px}
.muted{color:var(--muted)}
