:root{
  /* Official Santen + HIKARI tokens */
  --bg:#E9EEF3; --panel:#FFFFFF; --ink:#122033; --body:#3C4A5C; --muted:#748094;
  --rule:#DDE7F0; --rule2:#EBEFF5; --hair:rgba(18,32,51,.08); --border-strong:#B8C7D6;
  --primary:#004098; --primary-hover:#003778; --primary-bg:#EAF7FE; --santen:#00A1E9; --deep:#04246A;
  --ok:#067647; --ok-bg:#E6F4EC;
  --prog:#A15C07; --prog-bg:#F7EEE0;
  --idle:#748094; --idle-bg:#EDEFF4;
  --late:#B42318; --late-bg:#FBEAE8;
  --tag:#3C4A5C; --tag-bg:#EAF1F7;
}
*{box-sizing:border-box;}
html,body{margin:0;padding:0;background:var(--bg);color:var(--body);
  font-family:Inter,"Noto Sans","Helvetica Neue",Arial,system-ui,-apple-system,sans-serif;font-size:14px;line-height:1.5;}
h1,h2,h3,h4{font-family:inherit;color:var(--ink);font-weight:650;margin:0;letter-spacing:-.01em;}
button{font-family:inherit;cursor:pointer;}
.hidden{display:none !important;}

/* ---------------- PIN gate (brandless) ---------------- */
#pin-screen{position:fixed;inset:0;display:grid;place-items:center;padding:clamp(24px,5vw,64px);
  background:radial-gradient(circle at 50% 0%, rgba(0,161,233,.12), transparent 34rem),
             linear-gradient(180deg,#f7fbff 0%,#edf6fb 100%);}
.pin-card{width:min(100%,440px);padding:clamp(28px,5vw,44px);border:1px solid rgba(184,199,214,.62);
  border-radius:12px;background:rgba(255,255,255,.86);backdrop-filter:blur(18px) saturate(150%);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.88), 0 20px 70px rgba(18,32,51,.10);}
.pin-eyebrow{display:flex;align-items:center;gap:7px;font-size:11px;letter-spacing:.12em;
  text-transform:uppercase;color:var(--muted);font-weight:700;margin-bottom:8px;}
.pin-card h1{font-size:32px;letter-spacing:-.01em;margin-bottom:8px;color:var(--ink);}
.pin-card .sub{font-size:14px;color:var(--body);margin-bottom:22px;}
.pin-label{display:block;font-size:11px;letter-spacing:.06em;text-transform:uppercase;color:var(--muted);font-weight:700;margin-bottom:8px;}
.pin-boxes{display:flex;gap:12px;}
.pin-boxes input{width:62px;height:70px;border:1.5px solid var(--border-strong);border-radius:8px;
  text-align:center;font-size:30px;color:var(--ink);background:#fff;outline:none;transition:.15s;}
.pin-boxes input:focus{border-color:var(--santen);box-shadow:0 0 0 4px rgba(0,161,233,.18);}
.pin-help{font-size:12px;color:var(--muted);margin-top:16px;}
.pin-help.err{color:var(--late);}

/* ---------------- app shell (light, Santen + HIKARI) ---------------- */
.app{display:grid;grid-template-columns:236px 1fr;min-height:100vh;align-items:start;}
.side{background:var(--panel);color:var(--body);padding:20px 16px;display:flex;flex-direction:column;
  position:sticky;top:0;height:100vh;overflow-y:auto;border-right:1px solid var(--rule);}
.brand{display:flex;flex-direction:column;align-items:flex-start;gap:2px;text-decoration:none;}
.brand-logo{display:block;width:108px;height:auto;object-fit:contain;}
.brand-sub{font-size:11px;font-weight:700;letter-spacing:.22em;color:var(--muted);margin-left:1px;}
.appname{font-size:12px;color:var(--muted);margin-top:12px;letter-spacing:.02em;}
.nav{margin-top:22px;display:flex;flex-direction:column;gap:2px;}
.nav a{color:var(--body);text-decoration:none;padding:9px 12px;border-radius:6px;font-size:13.5px;cursor:pointer;}
.nav a:hover{background:var(--primary-bg);}
.nav a.on{background:var(--primary-bg);color:var(--primary);font-weight:600;box-shadow:inset 2px 0 0 var(--primary);}
.side .rolebox{margin-top:auto;font-size:11.5px;color:var(--muted);padding-top:16px;border-top:1px solid var(--rule);}
.side .rolebox label{display:block;text-transform:uppercase;letter-spacing:.08em;font-size:10px;margin-bottom:6px;color:var(--muted);}
.side select{width:100%;background:#fff;color:var(--ink);border:1px solid var(--rule);border-radius:6px;
  padding:8px 9px;font-size:12.5px;font-family:inherit;}
.side .logout{margin-top:12px;color:var(--primary);font-size:11.5px;background:none;border:none;padding:0;text-align:left;cursor:pointer;}

.main{padding:0;min-width:0;}
.topbar{display:flex;align-items:center;justify-content:space-between;
  padding:16px 30px;border-bottom:1px solid var(--rule);background:var(--panel);}
.topbar .crumb{font-size:12px;color:var(--muted);letter-spacing:.04em;text-transform:uppercase;}
.topbar h2{font-size:20px;margin-top:2px;color:var(--ink);}
.user{display:flex;align-items:center;gap:10px;font-size:13px;color:var(--body);}
.avatar{width:32px;height:32px;border-radius:50%;background:var(--primary-bg);color:var(--primary);
  display:flex;align-items:center;justify-content:center;font-weight:700;font-size:13px;}
.view{padding:26px 30px;}

/* kpis */
.kpis{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:24px;}
.kpi{background:var(--panel);border:1px solid var(--rule);border-radius:8px;padding:16px 18px;}
.kpi .lbl{font-size:11.5px;color:var(--muted);text-transform:uppercase;letter-spacing:.06em;}
.kpi .num{font-size:30px;color:var(--ink);margin-top:6px;line-height:1;}
.kpi .sub{font-size:12px;margin-top:6px;color:var(--body);}
.kpi .sub.ok{color:var(--ok);} .kpi .sub.late{color:var(--late);}
.kpi.clickable{cursor:pointer;transition:.12s;}
.kpi.clickable:hover{border-color:var(--santen);box-shadow:0 2px 10px rgba(43,87,167,.08);}
.kpi.active{border-color:var(--santen);background:var(--primary-bg);}

/* filter bar */
.filterbar{display:flex;align-items:center;gap:18px;flex-wrap:wrap;background:var(--panel);
  border:1px solid var(--rule);border-radius:8px;padding:12px 16px;margin-bottom:16px;font-size:12.5px;}
.filterbar .grp{display:flex;align-items:center;gap:8px;}
.filterbar .grp b{color:var(--muted);text-transform:uppercase;font-size:10.5px;letter-spacing:.05em;font-weight:700;}
.chip{border:1px solid var(--rule);background:#fff;color:var(--body);border-radius:16px;
  padding:4px 11px;font-size:12px;cursor:pointer;user-select:none;}
.chip.on{background:var(--santen);border-color:var(--santen);color:#fff;}
.filterbar .clear{margin-left:auto;color:var(--primary);background:none;border:none;font-size:12.5px;cursor:pointer;}
/* sortable headers */
th.sortable{cursor:pointer;user-select:none;white-space:nowrap;}
th.sortable:hover{color:var(--ink);}
th .arrow{opacity:.5;font-size:10px;margin-left:3px;}
th.sorted .arrow{opacity:1;color:var(--santen);}
/* expandable resourcing */
tr.func{cursor:pointer;}
tr.func:hover{background:var(--primary-bg);}
tr.func .caret{display:inline-block;width:12px;color:var(--muted);transition:.12s;}
tr.func.open .caret{transform:rotate(90deg);color:var(--santen);}
tr.sub td{background:var(--bg);font-size:12.5px;color:var(--body);}
tr.sub td .pname{padding-left:18px;}
/* download */
.dl{background:#fff;border:1px solid var(--rule);color:var(--body);padding:7px 14px;border-radius:8px;font-size:12.5px;cursor:pointer;}
.dl:hover{border-color:var(--santen);color:var(--primary);}
.panel-narrative{font-size:13px;color:var(--body);line-height:1.5;margin:4px 0 10px;}
.refinebar{display:flex;align-items:center;gap:8px;flex-wrap:wrap;margin:16px 0 4px;}
.refinebar .rl{font-size:11.5px;color:var(--muted);text-transform:uppercase;letter-spacing:.05em;font-weight:700;}
.refinebar .rf{background:var(--primary-bg);border:1px solid #D6E0F2;color:var(--primary);border-radius:16px;padding:5px 12px;font-size:12.5px;cursor:pointer;}
.refinebar .rf:hover{background:#dde7f8;}
.refinebar .newrep{background:none;border:none;color:var(--muted);font-size:12.5px;cursor:pointer;text-decoration:underline;}
.savemsg{font-size:12px;color:var(--ok);}
.lnk{background:none;border:none;color:var(--primary);font-size:12.5px;cursor:pointer;padding:0 5px;}
.lnk.del{color:var(--late);}
.dash{display:grid;grid-template-columns:repeat(2,1fr);gap:18px;}
.dashtile{cursor:pointer;margin-bottom:0;transition:.12s;}
.dashtile:hover{border-color:var(--santen);box-shadow:0 3px 14px rgba(43,87,167,.1);}
.dashtile .dnar{font-size:12px;color:var(--body);line-height:1.4;margin-bottom:10px;}
.dashtile .dchart{min-height:60px;}
.dashtile .kpicard{padding:10px 4px;}
.dashtile .kpicard .big{font-size:34px;}
.vtick{color:var(--ok);font-weight:700;} .vtick.no{color:var(--late);}

.card{background:var(--panel);border:1px solid var(--rule);border-radius:8px;padding:18px 20px;margin-bottom:18px;}
.card h3{font-size:15px;margin-bottom:14px;}
.card .hint{font-size:12px;color:var(--muted);font-weight:400;font-family:"Helvetica Neue",Arial,sans-serif;}
.row2{display:grid;grid-template-columns:1.6fr 1fr;gap:18px;}

table{width:100%;border-collapse:collapse;font-size:13px;}
th{text-align:left;font-weight:600;color:var(--muted);font-size:11px;text-transform:uppercase;
  letter-spacing:.05em;padding:8px 10px;border-bottom:1px solid var(--rule);}
td{padding:10px;border-bottom:1px solid var(--rule2);color:var(--body);vertical-align:middle;}
tr:last-child td{border-bottom:none;}
tbody tr.clickable:hover{background:var(--primary-bg);cursor:pointer;}
td .prod{font-weight:600;color:var(--ink);}
.pill{display:inline-block;padding:2.5px 9px;border-radius:20px;font-size:11.5px;font-weight:600;}
.pill.ok{background:var(--ok-bg);color:var(--ok);}
.pill.prog{background:var(--prog-bg);color:var(--prog);}
.pill.idle{background:var(--idle-bg);color:#5d6671;}
.pill.late{background:var(--late-bg);color:var(--late);}
.tag{display:inline-block;font-size:10.5px;padding:1.5px 7px;border-radius:5px;background:var(--tag-bg);color:var(--tag);font-weight:600;}
.tag.tt{background:#EAF0EC;color:#3E7C6B;}
.dot{display:inline-block;width:9px;height:9px;border-radius:50%;margin-right:6px;}
.dot.ok{background:var(--ok);} .dot.prog{background:var(--prog);} .dot.late{background:var(--late);}
.prog-wrap{display:flex;align-items:center;gap:8px;}
.bar{flex:1;height:7px;background:#ECEFF6;border-radius:6px;overflow:hidden;min-width:70px;}
.bar i{display:block;height:100%;background:var(--primary);border-radius:6px;}
.prog-wrap span{font-size:11.5px;color:var(--muted);min-width:34px;}

/* milestone timeline */
.gates{display:flex;justify-content:space-between;position:relative;margin:22px 4px 8px;}
.gates:before{content:"";position:absolute;top:11px;left:14px;right:14px;height:2px;background:var(--rule);}
.gate{position:relative;text-align:center;width:8.6%;z-index:1;}
.gate .gd{width:24px;height:24px;border-radius:50%;margin:0 auto 8px;border:2px solid var(--rule);
  background:#fff;display:flex;align-items:center;justify-content:center;font-size:11px;color:var(--muted);cursor:pointer;}
.gate.done .gd{background:var(--ok);border-color:var(--ok);color:#fff;}
.gate.now .gd{background:#fff;border-color:var(--prog);color:var(--prog);box-shadow:0 0 0 4px var(--prog-bg);}
.gate .gl{font-size:10.5px;color:var(--body);line-height:1.25;}
.gate .gdate{font-size:10px;color:var(--muted);margin-top:3px;}

.chk{list-style:none;padding:0;margin:0;}
.chk li{display:flex;align-items:center;gap:10px;padding:8px 0;border-bottom:1px solid var(--rule2);font-size:13px;cursor:pointer;}
.chk li:last-child{border:none;}
.tick{width:18px;height:18px;border-radius:5px;display:flex;align-items:center;justify-content:center;font-size:11px;color:#fff;}
.tick.y{background:var(--ok);} .tick.n{background:#fff;border:1.5px solid var(--rule);color:var(--muted);}
.fig{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;}
.fig div{background:var(--bg);border:1px solid var(--rule);border-radius:8px;padding:12px 14px;}
.fig .fl{font-size:11px;color:var(--muted);text-transform:uppercase;letter-spacing:.05em;}
.fig .fv{font-size:21px;color:var(--ink);margin-top:4px;}
.fig .fv.pos{color:var(--ok);}
.note{font-size:12px;color:var(--muted);margin-top:10px;}
.back{background:none;border:none;color:var(--primary);font-size:13px;padding:0;margin-bottom:14px;}

/* heatmap */
.heat{width:100%;border-collapse:separate;border-spacing:4px;}
.heat th{font-size:10.5px;text-align:center;padding:4px;border:none;color:var(--muted);}
.heat td{padding:0;border:none;}
.heat .name{text-align:left;font-size:12.5px;color:var(--ink);font-weight:600;padding-right:8px;white-space:nowrap;}
.heat .name.over{color:var(--late);}
.cell{height:30px;border-radius:5px;display:flex;align-items:center;justify-content:center;font-size:11px;}
.legend{display:flex;align-items:center;gap:14px;font-size:11.5px;color:var(--muted);margin-top:14px;}
.legend i{display:inline-block;width:16px;height:12px;border-radius:3px;margin-right:5px;}

/* reporting */
.prompt{display:flex;gap:10px;align-items:center;background:var(--panel);border:1px solid var(--rule);
  border-radius:8px;padding:6px 6px 6px 16px;}
.prompt .ai{font-size:11px;color:var(--primary);background:var(--primary-bg);padding:4px 9px;border-radius:6px;font-weight:600;}
.prompt input{flex:1;border:none;font-size:14px;color:var(--ink);background:transparent;outline:none;}
.prompt button{background:var(--primary);color:#fff;border:none;padding:9px 18px;border-radius:8px;font-size:13px;}
.examples{margin-top:10px;display:flex;gap:8px;flex-wrap:wrap;}
.examples button{background:#fff;border:1px solid var(--rule);color:var(--body);padding:5px 11px;border-radius:16px;font-size:12px;}
.twocol{display:grid;grid-template-columns:1fr 1fr;gap:18px;margin-top:18px;}
.chart{display:flex;align-items:flex-end;gap:24px;height:250px;padding:14px 6px 0;border-bottom:1px solid var(--rule);}
.col{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:flex-end;height:100%;}
.col .b{width:60%;background:var(--primary);border-radius:5px 5px 0 0;min-height:2px;}
.col .stack{width:54%;display:flex;flex-direction:column;border-radius:4px 4px 0 0;overflow:hidden;}
.col .stack > div{width:100%;}
.col .v{font-size:11px;color:var(--body);margin-bottom:5px;}
.xlbl{display:flex;gap:20px;padding-top:8px;}
.xlbl div{flex:1;text-align:center;font-size:11.5px;color:var(--muted);}
.kpicard{padding:26px 8px;text-align:center;}
.kpicard .big{font-size:46px;color:var(--ink);line-height:1;}
.kpicard .cap{font-size:13px;color:var(--muted);margin-top:8px;}
.hbar{display:flex;flex-direction:column;gap:9px;padding:6px 0;}
.hrow{display:flex;align-items:center;gap:10px;font-size:12.5px;}
.hlbl{width:160px;text-align:right;color:var(--body);flex-shrink:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.htrack{flex:1;height:20px;background:#ECEFF6;border-radius:4px;overflow:hidden;}
.hfill{height:100%;background:var(--primary);border-radius:4px;min-width:2px;}
.hval{width:92px;color:var(--ink);font-weight:600;flex-shrink:0;}
.verified{display:inline-flex;align-items:center;gap:7px;background:var(--ok-bg);color:var(--ok);
  padding:6px 12px;border-radius:20px;font-size:12px;font-weight:600;}
.verified.no{background:var(--late-bg);color:var(--late);}
.query{background:var(--deep);color:#CBD8F0;border-radius:8px;padding:14px 16px;
  font-family:"SF Mono",Menlo,Consolas,monospace;font-size:12px;line-height:1.6;white-space:pre-wrap;}
.spinner{color:var(--muted);font-size:13px;}

/* PPT-style report panels (chart is the hero; query collapsed) */
.report-panel{background:var(--panel);border:1px solid var(--rule);border-radius:8px;padding:22px 24px;margin-top:16px;box-shadow:0 1px 1px rgba(16,24,40,.04);}
.rp-head{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:4px;}
.rp-head h3{font-size:16px;color:var(--ink);}
.report-panel .panel-narrative{margin:0 0 4px;color:var(--body);font-size:13.5px;}
.rp-chart{margin:18px 0 16px;}
.rp-foot{border-top:1px solid var(--rule2);padding-top:12px;}
.rp-foot .rp-def{margin:0 0 8px;}
.rp-sql{font-size:12.5px;}
.rp-sql summary{cursor:pointer;color:var(--primary);font-weight:600;list-style:none;display:inline-flex;align-items:center;gap:6px;width:max-content;}
.rp-sql summary::-webkit-details-marker{display:none;}
.rp-sql summary::before{content:"\25B8";font-size:10px;}
.rp-sql[open] summary::before{content:"\25BE";}
.rp-sql .query{margin-top:10px;}

/* ---------------- map view ---------------- */
.mapview h3{display:flex;align-items:center;flex-wrap:wrap;gap:8px;}
.metricseg{margin-left:auto;display:inline-flex;border:1px solid var(--rule);border-radius:8px;overflow:hidden;}
.mseg{background:#fff;border:none;color:var(--body);padding:6px 13px;font-size:12px;border-left:1px solid var(--rule);}
.mseg:first-child{border-left:none;}
.mseg.on{background:var(--primary);color:#fff;}
.echart{width:100%;height:min(64vh,620px);min-height:460px;
  background:radial-gradient(120% 120% at 50% 0%, #F2F7FC 0%, #E7EFF6 60%, #E1EBF4 100%);
  border:1px solid var(--rule);border-radius:12px;}
.mapfooter{display:flex;align-items:center;gap:12px;margin-top:16px;padding-top:16px;border-top:1px solid var(--rule2);}
.mapfooter .msel{display:flex;align-items:center;gap:5px;flex-wrap:wrap;flex:1;min-height:18px;}
.mapfooter .dl[disabled]{opacity:.5;cursor:default;}
.flag{width:24px;height:16px;border-radius:2px;border:1px solid rgba(18,32,51,.14);display:inline-block;vertical-align:middle;}
.flag.fmini{width:21px;height:14px;}
.flag.fhead{width:34px;height:23px;border-radius:3px;}
/* country drill-down */
.chead{padding:16px 20px;}
.chead-in{display:flex;align-items:center;gap:12px;flex-wrap:wrap;}
.chead-in b{font-size:18px;color:var(--ink);}
.chead-in .csub{display:block;font-size:12.5px;color:var(--muted);margin-top:2px;}
.kpis6{grid-template-columns:repeat(6,1fr);}
.kpis6 .kpi{padding:14px 15px;}
.kpis6 .num{font-size:24px;}
.statusbar{display:flex;height:20px;border-radius:6px;overflow:hidden;background:#EEF1F6;}
.statusbar .ssg{height:100%;}
@media(max-width:1100px){.kpis6{grid-template-columns:repeat(3,1fr);}}

/* ---------------- mobile nav drawer + responsive ---------------- */
/* hamburger and scrim exist always but only show on small screens */
.navtoggle{display:none;width:40px;height:40px;border-radius:8px;border:none;background:none;
  flex-direction:column;align-items:center;justify-content:center;gap:4px;flex:0 0 auto;padding:0;}
.navtoggle:hover{background:var(--primary-bg);}
.navtoggle span{display:block;width:20px;height:2px;border-radius:2px;background:var(--ink);transition:.2s;}
.navscrim{display:none;}
.tb-title{min-width:0;}

@media(max-width:820px){
  .app{grid-template-columns:minmax(0,1fr);}
  /* sidebar becomes an off-canvas drawer */
  .side{position:fixed;top:0;left:0;height:100vh;width:272px;max-width:84vw;z-index:60;
    transform:translateX(-100%);transition:transform .26s ease;will-change:transform;}
  .app.nav-open .side{transform:translateX(0);box-shadow:0 18px 60px rgba(18,32,51,.30);}
  .navscrim{display:block;position:fixed;inset:0;background:rgba(18,32,51,.42);z-index:55;
    opacity:0;visibility:hidden;transition:opacity .26s, visibility .26s;}
  .app.nav-open .navscrim{opacity:1;visibility:visible;}
  .navtoggle{display:flex;}
  .topbar{position:sticky;top:0;z-index:30;padding:10px 14px;gap:10px;}
  .tb-title{flex:1;}
  .topbar h2{font-size:16px;line-height:1.25;}
  .topbar .crumb{font-size:10.5px;}
  .user span{display:none;}
  .view{padding:16px 14px;}
  .kpis{grid-template-columns:repeat(2,1fr);gap:12px;margin-bottom:18px;}
  .kpis6{grid-template-columns:repeat(2,1fr);}
  .kpi{padding:13px 14px;}
  .kpi .num{font-size:24px;}
  .kpis6 .num{font-size:20px;}
  .row2{grid-template-columns:1fr;}
  .dash{grid-template-columns:1fr;}
  .twocol,.fig{grid-template-columns:1fr;}
  .card{padding:14px 14px;overflow-x:auto;}
  .card h3{font-size:14px;}
  /* keep table column layout, scroll horizontally inside the card */
  .view td,.view th{white-space:nowrap;}
  .legend{flex-wrap:wrap;}
  /* milestone gates: scroll inside their own strip so the card text still
     wraps to the viewport (the card itself stays viewport width) */
  .gates{justify-content:flex-start;overflow-x:auto;-webkit-overflow-scrolling:touch;padding-bottom:6px;}
  .gate{flex:0 0 62px;width:62px;}
  /* reporting */
  .prompt{flex-wrap:wrap;padding:8px 10px;}
  .prompt input{flex:1 1 60%;min-width:0;}
  .prompt button{flex:1 1 100%;}
  .examples{flex-direction:column;align-items:stretch;}
  .examples button{white-space:normal;text-align:left;}
  .refinebar{row-gap:6px;}
  .chart{gap:12px;height:210px;}
  .hlbl{width:108px;}
  /* map */
  .echart{height:min(56vh,440px);min-height:340px;}
  .mapview h3{gap:6px 10px;align-items:flex-start;}
  .mapview h3 .hint{flex:1 1 100%;min-width:0;}
  .metricseg{margin-left:0;width:100%;}
  .metricseg .mseg{flex:1;text-align:center;min-width:0;padding:7px 4px;font-size:11.5px;}
  .mapfooter{flex-wrap:wrap;}
  .mapfooter .hint{flex:1 1 100%;}
}

@media(max-width:420px){
  .kpis,.kpis6{grid-template-columns:1fr 1fr;}
  .pin-boxes{gap:9px;}
  .pin-boxes input{width:54px;height:62px;font-size:26px;}
  .pin-card h1{font-size:27px;}
}
