/* ============ DDL — Lighthouse / observatory theme ============ */
:root{
  --bg:#0a0c11; --bg2:#0f131b; --panel:#11151e; --panel2:#141925;
  --ink:#ece4d3; --ink2:#b9b3a6; --muted:#7b8190;
  --beacon:#f5b13c; --beacon2:#ffcf6b; --good:#56d4a6; --risk:#ff6b6b; --info:#74b3ff;
  --line:rgba(236,228,211,.10); --line2:rgba(236,228,211,.06);
  --mono:"JetBrains Mono",ui-monospace,monospace;
  --disp:"Fraunces",Georgia,serif; --body:"Hanken Grotesk",system-ui,sans-serif;
  --rail:120px; --r:16px;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0; background:var(--bg); color:var(--ink); font-family:var(--body);
  font-size:15px; line-height:1.5; letter-spacing:.005em;
  padding-left:var(--rail); -webkit-font-smoothing:antialiased;
}
/* atmosphere: the beacon beam + grain */
.beam{position:fixed; inset:0; pointer-events:none; z-index:0;
  background:
    radial-gradient(120% 80% at 72% -10%, rgba(245,177,60,.16), transparent 55%),
    radial-gradient(90% 60% at 78% -5%, rgba(255,207,107,.10), transparent 45%),
    linear-gradient(180deg,#0c0f16 0%, var(--bg) 60%);}
.grain{position:fixed; inset:0; pointer-events:none; z-index:1; opacity:.05; mix-blend-mode:overlay;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.85' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");}
main,.topbar,.rail{position:relative; z-index:2}

/* ============ rail ============ */
.rail{position:fixed; left:0; top:0; bottom:0; width:var(--rail); display:flex; flex-direction:column;
  gap:14px; padding:18px 0 12px; border-right:1px solid var(--line); overflow-y:auto;
  background:linear-gradient(180deg,#0c0f15,#0a0c11);}
.mark{align-self:center; color:var(--beacon); filter:drop-shadow(0 0 10px rgba(245,177,60,.55)); animation:pulse 4.5s ease-in-out infinite}
@keyframes pulse{0%,100%{filter:drop-shadow(0 0 6px rgba(245,177,60,.35))}50%{filter:drop-shadow(0 0 16px rgba(245,177,60,.8))}}
#nav{display:flex; flex-direction:column; gap:2px; padding:0 8px}
#nav a{display:flex; align-items:baseline; gap:7px; color:var(--muted); text-decoration:none;
  font-size:11.5px; font-weight:600; letter-spacing:.01em; padding:8px 10px; border-radius:9px;
  border-left:2px solid transparent; transition:.18s}
#nav a span{font-family:var(--mono); font-size:9px; opacity:.55}
#nav a:hover{color:var(--ink); background:rgba(255,255,255,.035)}
#nav a.active{color:var(--beacon); border-left-color:var(--beacon); background:rgba(245,177,60,.07)}
.rail-foot{align-self:center; margin-top:auto; font-family:var(--mono); font-size:10px; color:var(--muted); letter-spacing:.1em}

/* ============ topbar ============ */
.topbar{display:flex; justify-content:space-between; align-items:flex-end; padding:34px 44px 22px;}
.brand h1{font-family:var(--disp); font-weight:600; font-size:31px; line-height:1; margin:0; letter-spacing:-.01em;
  background:linear-gradient(92deg,var(--ink),var(--beacon2)); -webkit-background-clip:text; background-clip:text; -webkit-text-fill-color:transparent}
.brand p{margin:8px 0 0; color:var(--muted); font-size:13px; letter-spacing:.02em}
.meta{display:flex; align-items:center; gap:18px}
.span{font-family:var(--mono); font-size:12px; color:var(--ink2); border:1px solid var(--line); padding:7px 12px; border-radius:999px}
.live{display:flex; align-items:center; gap:8px; font-size:12px; color:var(--muted); letter-spacing:.04em}
.live i{width:7px; height:7px; border-radius:50%; background:var(--good); box-shadow:0 0 0 0 rgba(86,212,166,.6); animation:beat 2s infinite}
@keyframes beat{0%{box-shadow:0 0 0 0 rgba(86,212,166,.5)}70%{box-shadow:0 0 0 7px rgba(86,212,166,0)}100%{box-shadow:0 0 0 0 rgba(86,212,166,0)}}

/* ============ sections ============ */
main{padding:0 44px 90px}
.sec{padding:34px 0; border-top:1px solid var(--line2)}
.sec:first-child{border-top:none}
.sec-h{display:flex; align-items:center; gap:16px; margin-bottom:24px}
.sec-h .num{font-family:var(--mono); font-size:12px; color:var(--beacon); opacity:.8}
.sec-h h2{font-family:var(--disp); font-weight:600; font-size:23px; margin:0; letter-spacing:-.01em}
.sec-h .rule{flex:1; height:1px; background:linear-gradient(90deg,var(--line),transparent)}
.note{color:var(--muted); font-size:13px; margin:-6px 0 20px}
.note b{color:var(--beacon2)}

/* reveal */
.reveal{opacity:0; transform:translateY(14px); animation:rise .7s cubic-bezier(.2,.7,.2,1) forwards}
@keyframes rise{to{opacity:1; transform:none}}

/* ============ KPIs ============ */
.kpis{display:grid; grid-template-columns:repeat(5,1fr); gap:14px; margin-bottom:22px}
.kpi{background:linear-gradient(180deg,var(--panel),var(--bg2)); border:1px solid var(--line); border-radius:var(--r);
  padding:18px 18px 16px; position:relative; overflow:hidden}
.kpi::after{content:""; position:absolute; left:0; right:0; top:0; height:2px;
  background:linear-gradient(90deg,transparent,var(--beacon),transparent); opacity:.5}
.kpi .l{font-size:11px; text-transform:uppercase; letter-spacing:.13em; color:var(--muted)}
.kpi .v{font-family:var(--mono); font-weight:700; font-size:28px; margin-top:12px; letter-spacing:-.02em}
.kpi .v small{font-size:14px; color:var(--ink2); font-weight:500}
.kpi .s{margin-top:8px; font-size:12px; color:var(--ink2)}
.kpi.accent .v{color:var(--beacon2)}
.up{color:var(--good)} .down{color:var(--risk)}

/* ============ cards / grids ============ */
.grid2{display:grid; grid-template-columns:1fr 1fr; gap:14px; margin-bottom:14px}
.grid3{display:grid; grid-template-columns:repeat(3,1fr); gap:14px}
.card{background:linear-gradient(180deg,var(--panel),var(--bg2)); border:1px solid var(--line); border-radius:var(--r);
  padding:20px; transition:.3s; }
.card:hover{border-color:rgba(245,177,60,.35); transform:translateY(-2px)}
.card-h{display:flex; justify-content:space-between; align-items:baseline; margin-bottom:16px}
.card-h h3{font-family:var(--disp); font-weight:600; font-size:16px; margin:0}
.hint{font-size:11px; color:var(--muted); font-family:var(--mono); letter-spacing:.03em}
.chart{width:100%}
.legend{display:flex; gap:18px; margin-top:14px; flex-wrap:wrap}
.legend span{font-size:12px; color:var(--ink2); display:flex; align-items:center; gap:7px}
.legend i{width:10px; height:10px; border-radius:3px}

/* ============ plan-fact-forecast hero ============ */
.hero{background:
    radial-gradient(120% 140% at 85% 0%, rgba(245,177,60,.10), transparent 60%),
    linear-gradient(180deg,var(--panel2),var(--bg2));
  border:1px solid var(--line); border-radius:var(--r); padding:26px 28px}
.hero h3{font-family:var(--disp); font-size:17px; margin:0 0 4px}
.hero .sub{color:var(--muted); font-size:12.5px; margin-bottom:24px}
.beam-gauge{position:relative; height:74px; margin:10px 0 6px}
.bg-track{position:absolute; top:30px; left:0; right:0; height:14px; border-radius:999px; background:#0a0d14; border:1px solid var(--line)}
.bg-fact{position:absolute; top:30px; left:0; height:14px; border-radius:999px 0 0 999px;
  background:linear-gradient(90deg,#caa34e,var(--beacon2)); box-shadow:0 0 18px rgba(245,177,60,.45)}
.bg-fc{position:absolute; top:30px; height:14px; background:repeating-linear-gradient(45deg,rgba(116,179,255,.5),rgba(116,179,255,.5) 6px,transparent 6px,transparent 12px); border-top:1px dashed rgba(116,179,255,.6); border-bottom:1px dashed rgba(116,179,255,.6)}
.bg-pi{position:absolute; top:26px; height:22px; border-left:1px solid rgba(116,179,255,.5); border-right:1px solid rgba(116,179,255,.5)}
.bg-plan{position:absolute; top:14px; bottom:14px; width:2px; background:var(--ink); box-shadow:0 0 10px rgba(236,228,211,.6)}
.bg-plan b{position:absolute; top:-20px; left:50%; transform:translateX(-50%); font-size:10px; letter-spacing:.1em; color:var(--ink2); white-space:nowrap; text-transform:uppercase; font-weight:700}
.bg-cap{position:absolute; bottom:-2px; font-family:var(--mono); font-size:11px; color:var(--muted)}
.hero-stats{display:flex; gap:34px; margin-top:26px; flex-wrap:wrap}
.hero-stats div{display:flex; flex-direction:column}
.hero-stats .l{font-size:11px; text-transform:uppercase; letter-spacing:.12em; color:var(--muted)}
.hero-stats .v{font-family:var(--mono); font-weight:700; font-size:22px; margin-top:6px}
.verdict{margin-left:auto; align-self:center; font-family:var(--disp); font-style:italic; font-size:19px}
.verdict.ok{color:var(--good)} .verdict.bad{color:var(--risk)}

/* ============ competitor / forecast cards ============ */
.ccard,.fcard{background:linear-gradient(180deg,var(--panel),var(--bg2)); border:1px solid var(--line); border-radius:var(--r); padding:20px}
.ccard h4{margin:0; font-family:var(--disp); font-size:16px}
.ccard .sub{color:var(--muted); font-size:12px; font-family:var(--mono); margin:3px 0 16px}
.metric{display:flex; justify-content:space-between; align-items:center; padding:10px 0; border-top:1px solid var(--line2)}
.metric .ml{font-size:13px; color:var(--ink2)}
.metric .mv{font-family:var(--mono); font-weight:500}
.badge{font-size:9.5px; text-transform:uppercase; letter-spacing:.1em; padding:3px 7px; border-radius:6px; font-weight:700; margin-left:8px}
.badge.est{background:rgba(245,177,60,.14); color:var(--beacon2); border:1px solid rgba(245,177,60,.3)}
.badge.act{background:rgba(86,212,166,.12); color:var(--good); border:1px solid rgba(86,212,166,.3)}
.range{font-size:10px; color:var(--muted); font-family:var(--mono)}
.fcard .fk{font-size:11px; text-transform:uppercase; letter-spacing:.12em; color:var(--muted)}
.fcard .fv{font-family:var(--mono); font-weight:700; font-size:26px; margin:10px 0 4px; color:var(--beacon2)}
.fcard .fpi{font-family:var(--mono); font-size:12px; color:var(--ink2)}
.fcard .tag{display:inline-block; margin-top:14px; font-size:11px; color:var(--muted); border:1px solid var(--line); padding:4px 9px; border-radius:999px}

/* ============ chips / table ============ */
.chips{display:flex; gap:12px; margin-bottom:16px; flex-wrap:wrap}
.chip{background:var(--panel); border:1px solid var(--line); border-radius:12px; padding:12px 18px}
.chip .l{font-size:11px; text-transform:uppercase; letter-spacing:.12em; color:var(--muted)}
.chip .v{font-family:var(--mono); font-weight:700; font-size:20px; margin-top:4px}
table{width:100%; border-collapse:collapse}
th{text-align:right; font-size:10.5px; text-transform:uppercase; letter-spacing:.12em; color:var(--muted); padding:0 0 12px; font-weight:600}
th:first-child,td:first-child{text-align:left}
td{padding:13px 0; border-top:1px solid var(--line2); font-family:var(--mono); font-size:14px}
td.name{font-family:var(--body); font-weight:600}
.roibar{position:relative; height:6px; background:#0a0d14; border-radius:4px; margin-top:7px; overflow:hidden}
.roibar i{position:absolute; left:0; top:0; bottom:0; border-radius:4px}
.tag-mono{font-family:var(--mono); font-size:11px; color:var(--muted)}

/* top list */
.top-row{display:flex; align-items:center; gap:14px; padding:11px 8px; margin:0 -8px; border-top:1px solid var(--line2); cursor:pointer; border-radius:8px; transition:.15s}
.top-row:hover{background:rgba(245,177,60,.05)}
.top-row:first-child{border-top:none}
.top-row .rk{font-family:var(--mono); font-size:12px; color:var(--beacon); opacity:.7; width:22px}
.top-row .tt{flex:1; font-weight:600; font-size:13.5px; display:flex; flex-direction:column}
.top-row .tt small{font-weight:400; color:var(--muted); font-size:11px; font-family:var(--mono); margin-top:2px}
.top-row .tv{font-family:var(--mono); font-weight:700; color:var(--ink); font-size:15px}

/* filters */
.filters{display:flex; gap:10px}
.filters label{display:flex; flex-direction:column; gap:5px; font-size:9.5px; text-transform:uppercase;
  letter-spacing:.12em; color:var(--muted)}
.filters select{appearance:none; background:var(--panel); color:var(--ink); border:1px solid var(--line);
  border-radius:9px; padding:7px 28px 7px 11px; font-family:var(--mono); font-size:12px; cursor:pointer;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6'%3E%3Cpath d='M1 1l4 4 4-4' stroke='%23f5b13c' fill='none' stroke-width='1.4'/%3E%3C/svg%3E");
  background-repeat:no-repeat; background-position:right 10px center; transition:.2s}
.filters select:hover{border-color:rgba(245,177,60,.5)}
.dates{display:flex; align-items:center; gap:6px}
.dates i{color:var(--muted)}
.filters input[type=date]{background:var(--panel); color:var(--ink); border:1px solid var(--line);
  border-radius:9px; padding:6px 9px; font-family:var(--mono); font-size:11.5px; color-scheme:dark}
.filters input[type=date]:hover{border-color:rgba(245,177,60,.5)}

/* calibration panel */
.calib{margin-top:14px}
.calib h3{font-family:var(--disp); font-size:16px; margin:0 0 4px}
.calib .sub{color:var(--muted); font-size:12px; margin-bottom:20px}
.calib-grid{display:grid; grid-template-columns:repeat(3,1fr); gap:24px; align-items:start}
.cal-block .l{font-size:11px; text-transform:uppercase; letter-spacing:.12em; color:var(--muted)}
.cal-block .v{font-family:var(--mono); font-weight:700; font-size:24px; margin:8px 0 4px}
.gaugeline{position:relative; height:10px; background:#0a0d14; border:1px solid var(--line); border-radius:999px; margin-top:10px}
.gaugeline i{position:absolute; left:0; top:0; bottom:0; border-radius:999px; background:linear-gradient(90deg,#56d4a6,#56d4a6)}
.gaugeline b{position:absolute; top:-6px; bottom:-6px; width:2px; background:var(--ink)}
.cmp{display:flex; flex-direction:column; gap:9px; margin-top:10px}
.cmp .row{display:flex; align-items:center; gap:10px; font-size:12px}
.cmp .bar{flex:1; height:8px; background:#0a0d14; border-radius:6px; overflow:hidden}
.cmp .bar i{display:block; height:100%; border-radius:6px}
.cmp .nm{width:90px; color:var(--ink2)} .cmp .pc{font-family:var(--mono); width:46px; text-align:right}
.win{font-family:var(--disp); font-style:italic; color:var(--good); font-size:14px; margin-top:14px}

/* L3 */
.l3-bar{display:flex; align-items:center; justify-content:space-between; margin-bottom:14px}
.btn{display:inline-flex; align-items:center; gap:8px; background:linear-gradient(180deg,#1a2030,#10141d);
  border:1px solid rgba(245,177,60,.4); color:var(--beacon2); text-decoration:none; font-size:13px; font-weight:600;
  padding:9px 16px; border-radius:10px; transition:.2s}
.btn:hover{border-color:var(--beacon); box-shadow:0 0 18px rgba(245,177,60,.25); transform:translateY(-1px)}
.l3-wrap{max-height:560px; overflow:auto}
.l3-wrap table{font-size:12.5px}
.l3-wrap th{position:sticky; top:0; background:var(--panel); z-index:1; padding:10px 10px 12px; white-space:nowrap}
.l3-wrap td{padding:9px 10px; white-space:nowrap; font-family:var(--mono); font-size:12px}
.l3-wrap td:first-child,.l3-wrap th:first-child{position:sticky; left:0; background:var(--bg2)}
.l3-wrap td.t{font-family:var(--body); font-weight:600; color:var(--ink)}

/* top list */
.top-row{display:flex; align-items:center; gap:14px; padding:11px 8px; margin:0 -8px; border-top:1px solid var(--line2); cursor:pointer; border-radius:8px; transition:.15s}
.top-row:hover{background:rgba(245,177,60,.05)}
.top-row:first-child{border-top:none}
.top-row .rk{font-family:var(--mono); font-size:12px; color:var(--beacon); opacity:.7; width:22px}
.top-row .tt{flex:1; font-weight:600; font-size:13.5px; display:flex; flex-direction:column}
.top-row .tt small{font-weight:400; color:var(--muted); font-size:11px; font-family:var(--mono); margin-top:2px}
.top-row .tv{font-family:var(--mono); font-weight:700; color:var(--ink); font-size:15px}

/* drill-down: clickable + modal */
.drill{cursor:pointer; transition:.18s; text-decoration:none; color:inherit}
.drill:hover{color:var(--beacon2)}
.drill::after{content:"↗"; font-size:10px; opacity:0; margin-left:6px; color:var(--beacon); transition:.18s}
.drill:hover::after{opacity:.8}
.modal{position:fixed; inset:0; z-index:50; display:flex; align-items:center; justify-content:center; padding:40px}
.modal[hidden]{display:none}
.modal-bg{position:absolute; inset:0; background:rgba(5,6,9,.72); backdrop-filter:blur(6px); animation:rise .25s}
.modal-card{position:relative; width:min(880px,94vw); max-height:88vh; overflow:auto;
  background:radial-gradient(120% 100% at 90% 0%,rgba(245,177,60,.10),transparent 55%),linear-gradient(180deg,var(--panel2),var(--bg2));
  border:1px solid rgba(245,177,60,.28); border-radius:20px; padding:30px 32px;
  box-shadow:0 30px 80px rgba(0,0,0,.6); animation:rise .3s cubic-bezier(.2,.7,.2,1)}
.modal-x{position:absolute; top:18px; right:20px; width:34px; height:34px; border-radius:50%;
  background:var(--panel); border:1px solid var(--line); color:var(--ink2); font-size:18px; cursor:pointer; transition:.2s}
.modal-x:hover{border-color:var(--beacon); color:var(--beacon2)}
.md-h{font-family:var(--disp); font-size:24px; margin:0 0 4px}
.md-sub{color:var(--muted); font-size:12px; font-family:var(--mono); margin-bottom:22px}
.md-kpis{display:flex; gap:30px; margin-bottom:24px; flex-wrap:wrap}
.md-kpis .l{font-size:10.5px; text-transform:uppercase; letter-spacing:.12em; color:var(--muted)}
.md-kpis .v{font-family:var(--mono); font-weight:700; font-size:22px; margin-top:6px}
.md-grid{display:grid; grid-template-columns:1fr 1fr; gap:24px}
.md-grid h5{font-family:var(--disp); font-weight:600; font-size:14px; margin:0 0 12px}
.md-pubs table{font-size:12px}
.md-pubs td{padding:8px 0; font-family:var(--mono)} .md-pubs th{padding-bottom:8px}

/* re-optimization */
.reopt{display:flex; flex-direction:column; gap:10px}
.ro{display:flex; align-items:center; gap:18px; background:linear-gradient(180deg,var(--panel),var(--bg2));
  border:1px solid var(--line); border-radius:12px; padding:15px 18px; cursor:pointer; transition:.15s}
.ro:hover{border-color:rgba(245,177,60,.4); transform:translateY(-1px)}
.ro .sc{font-family:var(--mono); font-weight:700; font-size:20px; color:var(--beacon2); width:64px; text-align:center}
.ro .sc small{display:block; font-size:9px; color:var(--muted); letter-spacing:.1em; text-transform:uppercase; font-weight:400}
.ro .info{flex:1}
.ro .tt{font-weight:600; font-size:14px}
.ro .mt{font-family:var(--mono); font-size:11px; color:var(--muted); margin-top:4px}
.ro .acts{display:flex; gap:7px; flex-wrap:wrap}
.ro .act{font-size:11px; background:rgba(245,177,60,.12); color:var(--beacon2); border:1px solid rgba(245,177,60,.28);
  padding:5px 10px; border-radius:8px; white-space:nowrap}

/* channel audit */
.audit-card{background:linear-gradient(180deg,var(--panel),var(--bg2)); border:1px solid var(--line); border-radius:var(--r); padding:20px}
.audit-top{display:flex; align-items:center; gap:16px; margin-bottom:18px}
.ring{position:relative; width:62px; height:62px; flex:0 0 auto}
.ring svg{transform:rotate(-90deg)}
.ring b{position:absolute; inset:0; display:flex; align-items:center; justify-content:center; font-family:var(--mono); font-weight:700; font-size:16px}
.audit-top .nm{font-family:var(--disp); font-size:16px; font-weight:600}
.audit-top .pl{font-size:11px; color:var(--muted); font-family:var(--mono); margin-top:3px}
.st{font-size:9.5px; text-transform:uppercase; letter-spacing:.1em; padding:3px 8px; border-radius:6px; margin-left:auto}
.st.active{background:rgba(86,212,166,.12); color:var(--good)} .st.archived{background:rgba(123,129,144,.15); color:var(--muted)}
.audit-m{display:flex; justify-content:space-between; padding:8px 0; border-top:1px solid var(--line2); font-size:13px}
.audit-m .ml{color:var(--ink2)} .audit-m .mv{font-family:var(--mono)} .audit-m .na{color:var(--muted); font-style:italic; font-size:11px}

/* alerts */
#nav a em{font-style:normal; font-family:var(--mono); font-size:9px; background:var(--risk); color:#fff;
  border-radius:8px; padding:1px 5px; margin-left:2px}
#nav a em:empty{display:none}
.alerts{display:flex; flex-direction:column; gap:10px}
.alert{display:flex; align-items:center; gap:16px; background:linear-gradient(180deg,var(--panel),var(--bg2));
  border:1px solid var(--line); border-left-width:3px; border-radius:12px; padding:14px 18px}
.alert.high{border-left-color:var(--risk)} .alert.medium{border-left-color:var(--beacon)}
.alert .ico{font-size:18px; width:24px; text-align:center}
.alert .body{flex:1}
.alert .at{font-size:10px; text-transform:uppercase; letter-spacing:.12em; color:var(--muted)}
.alert .msg{font-size:13.5px; margin-top:3px}
.alert .ttl{font-family:var(--body); font-weight:600; color:var(--ink2); font-size:12px; margin-left:6px}
.alert .sev{font-family:var(--mono); font-size:10px; text-transform:uppercase; letter-spacing:.1em; padding:4px 9px; border-radius:7px}
.alert.high .sev{background:rgba(255,107,107,.14); color:var(--risk)}
.alert.medium .sev{background:rgba(245,177,60,.14); color:var(--beacon2)}
.alert.drill{cursor:pointer; transition:.15s}
.alert.drill:hover{border-color:rgba(245,177,60,.4)}

/* login */
.login{position:fixed; inset:0; z-index:100; display:flex; align-items:center; justify-content:center;
  background:radial-gradient(120% 90% at 70% -10%,rgba(245,177,60,.14),transparent 55%),var(--bg)}
.login[hidden]{display:none}
.login-card{display:flex; flex-direction:column; gap:13px; width:340px; text-align:center;
  background:linear-gradient(180deg,var(--panel2),var(--bg2)); border:1px solid rgba(245,177,60,.25);
  border-radius:20px; padding:38px 34px; box-shadow:0 30px 80px rgba(0,0,0,.5)}
.login-mark{color:var(--beacon); filter:drop-shadow(0 0 14px rgba(245,177,60,.6)); margin-bottom:2px}
.login-card h2{font-family:var(--disp); font-weight:600; font-size:22px; margin:0}
.login-card p{color:var(--muted); font-size:13px; margin:0 0 8px}
.login-card input{background:#0a0d14; border:1px solid var(--line); border-radius:10px; padding:12px 14px;
  color:var(--ink); font-family:var(--body); font-size:14px}
.login-card input:focus{outline:none; border-color:var(--beacon)}
.login-card button{background:linear-gradient(180deg,var(--beacon2),var(--beacon)); color:#1a1206; border:0;
  border-radius:10px; padding:12px; font-family:var(--body); font-weight:700; font-size:14px; cursor:pointer; transition:.2s}
.login-card button:hover{box-shadow:0 0 22px rgba(245,177,60,.45)}
.lg-err{color:var(--risk); font-size:12px; min-height:14px}
.lg-hint{color:var(--muted); font-size:11px; line-height:1.6} .lg-hint b{color:var(--ink2)}
/* who / logout */
.who{display:flex; align-items:center; gap:10px; font-size:12px; color:var(--ink2)}
.who[hidden]{display:none}
#who-name{font-family:var(--mono); letter-spacing:.02em}
#logout{background:var(--panel); border:1px solid var(--line); color:var(--ink2); width:28px; height:28px;
  border-radius:8px; cursor:pointer; font-size:13px; transition:.2s}
#logout:hover{border-color:var(--beacon); color:var(--beacon2)}
/* role: user hides sensitive */
body[data-role="user"] #monetization, body[data-role="user"] #forecast, body[data-role="user"] #assets,
body[data-role="user"] #reopt, body[data-role="user"] #pff,
body[data-role="user"] #nav a[data-s="monetization"],
body[data-role="user"] #nav a[data-s="forecast"],
body[data-role="user"] #nav a[data-s="assets"],
body[data-role="user"] #nav a[data-s="reopt"],
body[data-role="user"] #chat, body[data-role="user"] #nav a[data-s="chat"],
body[data-role="user"] #l3-export{display:none}
/* AI chat */
.chat-box{background:linear-gradient(180deg,var(--panel),var(--bg2)); border:1px solid var(--line); border-radius:var(--r); padding:20px}
.chat-in{display:flex; gap:10px}
.chat-in input{flex:1; background:#0a0d14; border:1px solid var(--line); border-radius:10px; padding:13px 16px; color:var(--ink); font-family:var(--body); font-size:14px}
.chat-in input:focus{outline:none; border-color:var(--beacon)}
.chat-in button{background:linear-gradient(180deg,var(--beacon2),var(--beacon)); color:#1a1206; border:0; border-radius:10px; padding:0 22px; font-weight:700; cursor:pointer; transition:.2s}
.chat-in button:hover{box-shadow:0 0 20px rgba(245,177,60,.4)}
.chat-chips{display:flex; gap:8px; margin-top:12px; flex-wrap:wrap}
.chat-chips span{font-size:12px; color:var(--ink2); border:1px solid var(--line); border-radius:999px; padding:6px 12px; cursor:pointer; transition:.15s}
.chat-chips span:hover{border-color:var(--beacon); color:var(--beacon2)}
.chat-out{margin-top:18px}
.chat-note{font-size:13.5px; color:var(--ink2); margin-bottom:12px}
.chat-mode{font-family:var(--mono); font-size:10px; color:var(--muted); text-transform:uppercase; letter-spacing:.1em; margin-left:8px}
.chat-sql{font-family:var(--mono); font-size:12px; color:var(--good); background:#0a0d14; border:1px solid var(--line2); border-radius:10px; padding:12px 14px; white-space:pre-wrap; margin-bottom:14px; overflow-x:auto}
.chat-out table{font-size:12.5px} .chat-out td{font-family:var(--mono); padding:8px 10px} .chat-out th{padding-bottom:10px}

@media(max-width:1080px){.kpis{grid-template-columns:repeat(2,1fr)}.grid2,.grid3,.calib-grid,.md-grid{grid-template-columns:1fr}}

/* ============ адаптив ============ */
/* гамбургер — лише мобільний (на десктопі прихований, тож десктоп не змінюється) */
.hamb{display:none; margin-left:auto; flex-direction:column; justify-content:center; gap:5px;
  width:44px; height:38px; padding:9px 11px; background:var(--panel); border:1px solid var(--line);
  border-radius:10px; cursor:pointer; transition:.2s}
.hamb span{display:block; height:2px; width:100%; background:var(--ink2); border-radius:2px; transition:.25s}
.hamb:hover{border-color:var(--beacon)}
body.nav-open .hamb span:nth-child(1){transform:translateY(7px) rotate(45deg); background:var(--beacon2)}
body.nav-open .hamb span:nth-child(2){opacity:0}
body.nav-open .hamb span:nth-child(3){transform:translateY(-7px) rotate(-45deg); background:var(--beacon2)}

/* планшет */
@media(max-width:900px){
  .topbar{padding:24px 24px 18px; flex-wrap:wrap; gap:16px}
  main{padding:0 24px 80px}
  .meta{flex-wrap:wrap; gap:14px}
  .filters{flex-wrap:wrap}
}

/* телефон */
@media(max-width:640px){
  body{padding-left:0; font-size:14.5px}
  html{scroll-padding-top:66px; -webkit-text-size-adjust:100%; text-size-adjust:100%}  /* анкор не ховає заголовок; без авто-інфляції тексту */
  /* рейка → липкий верхній бар; #nav → висувна шторка */
  .rail{position:sticky; top:0; left:auto; bottom:auto; right:auto; width:auto; height:auto;
    flex-direction:row; align-items:center; gap:12px; padding:10px 16px;
    border-right:none; border-bottom:1px solid var(--line); overflow:visible; z-index:40}
  .rail .mark{align-self:center; margin:0}
  .hamb{display:flex}
  .rail-foot{display:none}
  #nav{display:none}
  body.nav-open #nav{display:flex; position:absolute; top:100%; left:0; right:0;
    flex-direction:column; gap:2px; padding:10px 12px 14px;
    background:linear-gradient(180deg,#0c0f15,#0a0c11); border-bottom:1px solid var(--line);
    max-height:74vh; overflow:auto; box-shadow:0 24px 50px rgba(0,0,0,.55); z-index:41}
  body.nav-open #nav a{font-size:14px; padding:12px 12px}

  .topbar{flex-direction:column; align-items:flex-start; padding:18px 16px 14px; gap:14px}
  .brand h1{font-size:23px}
  .brand p{font-size:12px}
  .meta{flex-direction:column; align-items:stretch; gap:12px; width:100%}
  .filters{gap:10px; width:100%}
  .filters label{flex:1 1 132px}
  .filters select,.filters input[type=date]{width:100%}
  .span{align-self:flex-start}

  main{padding:0 16px 70px}
  .sec{padding:24px 0}
  .sec-h h2{font-size:20px}

  /* широкі таблиці → горизонтальний скрол у межах картки */
  .card{padding:16px; overflow-x:auto; -webkit-overflow-scrolling:touch}
  .hero{padding:20px 16px}
  .hero-stats{gap:20px}

  /* ── типографіка під мобілку ── */
  /* інпути ≥16px — інакше iOS зумить сторінку при фокусі (схоже на «стрибок шрифтів») */
  .login-card input,.chat-in input,.filters select,.filters input[type=date]{font-size:16px}
  /* зменшуємо найбільші числа/заголовки, щоб не «розпирали» вузький екран */
  .brand h1{font-size:22px; line-height:1.05}
  .sec-h h2{font-size:19px}
  .kpi .v{font-size:23px}
  .kpi .l,.chip .l,.fcard .fk,.hero-stats .l,.md-kpis .l{letter-spacing:.08em}
  .hero h3{font-size:16px}
  .hero-stats .v{font-size:18px}
  .verdict{font-size:16px}
  .fcard .fv{font-size:22px}
  .chip .v{font-size:18px}
  .cal-block .v{font-size:20px}
  .ring{width:54px; height:54px}
  .ring b{font-size:14px}
  .ro .sc{font-size:18px; width:54px}
  .card-h h3,.ccard h4,.audit-top .nm{font-size:15px}

  /* чат: інпут і кнопка в стовпчик */
  .chat-box{padding:16px}
  .chat-in{flex-direction:column}
  .chat-in button{padding:12px}

  /* модалка */
  .modal{padding:14px}
  .modal-card{padding:22px 18px; border-radius:16px}
  .md-h{font-size:20px}
  .md-kpis{gap:18px}

  .ro{gap:12px; padding:13px 14px}
  .alert{gap:12px; padding:13px 14px}
}

/* дуже вузькі — KPI в одну колонку */
@media(max-width:460px){
  .kpis{grid-template-columns:1fr}
}
