@import url('https://fonts.googleapis.com/css2?family=Roboto:ital,wght@0,300;0,400;0,500;0,700;0,900;1,400&family=Roboto+Mono:wght@400;500&display=swap');

:root{
  --navy:#0E2350;        /* brand navy */
  --navy-2:#15306b;
  --navy-3:#1d3f86;
  --ink:#0b1a3a;
  --yellow:#FDB913;      /* brand yellow */
  --yellow-soft:#FFE9A8;
  --paper:#f6f8fc;
  --card:#ffffff;
  --line:#e3e9f4;
  --muted:#5b6b8c;
  --green:#1f9d62;
  --green-bg:#e4f6ec;
  --amber:#c08a00;
  --amber-bg:#fdf2cf;
  --red:#cc2f3b;
  --red-bg:#fbe6e8;
  --grey-map:#c9d2e2;
  --mono:'Roboto Mono',monospace;
  --shadow:0 1px 2px rgba(14,35,80,.05),0 8px 24px rgba(14,35,80,.06);
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;font-family:'Roboto',system-ui,sans-serif;color:var(--ink);
  background:var(--paper);font-size:14px;line-height:1.5;-webkit-font-smoothing:antialiased;
}
h1,h2,h3,h4{font-weight:700;letter-spacing:-.01em;margin:0}
a{color:inherit}

/* ---------- top bar ---------- */
.topbar{position:sticky;top:0;z-index:40;background:rgba(255,255,255,.86);backdrop-filter:blur(10px);
  border-bottom:1px solid var(--line);display:flex;align-items:center;gap:22px;padding:0 26px;height:60px}
.brand{display:flex;align-items:center;gap:11px;font-weight:900;font-size:19px;color:var(--navy);letter-spacing:-.02em}
.brand .mark{width:34px;height:34px;border-radius:9px;background:var(--navy);display:grid;place-items:center;flex:0 0 auto}
.brand .mark svg{width:21px;height:21px}
.topnav{display:flex;gap:2px;margin-left:auto;flex-wrap:wrap}
.topnav a{font-size:12.5px;font-weight:500;color:var(--muted);padding:8px 12px;border-radius:8px;text-decoration:none;white-space:nowrap}
.topnav a:hover{color:var(--navy);background:var(--paper)}
.report-period{font-size:12px;color:var(--muted);font-weight:500;border-left:1px solid var(--line);padding-left:18px;margin-left:4px}
.report-period b{color:var(--navy);font-weight:700}

/* ---------- hero ---------- */
.hero{position:relative;overflow:hidden;background:
  radial-gradient(1100px 460px at 88% -10%,rgba(253,185,19,.20),transparent 60%),
  linear-gradient(135deg,var(--navy) 0%,#0a1b40 60%,#0a1733 100%);color:#fff;padding:54px 26px 60px}
.hero:after{content:"";position:absolute;inset:0;background-image:
  linear-gradient(rgba(255,255,255,.04) 1px,transparent 1px),
  linear-gradient(90deg,rgba(255,255,255,.04) 1px,transparent 1px);
  background-size:34px 34px;mask:linear-gradient(180deg,#000,transparent);pointer-events:none}
.hero-inner{max-width:1240px;margin:0 auto;position:relative;z-index:1}
.hero .kicker{font-size:12px;letter-spacing:.22em;text-transform:uppercase;color:var(--yellow);font-weight:700}
.hero h1{font-size:40px;line-height:1.05;margin:14px 0 0;max-width:760px;font-weight:900}
.hero p.sub{margin:16px 0 0;max-width:640px;color:#c4d0ec;font-size:15px}
.hero-meta{display:flex;gap:34px;margin-top:34px;flex-wrap:wrap}
.hero-meta .it .l{font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:#8ea3d4}
.hero-meta .it .v{font-size:22px;font-weight:700;margin-top:3px}
.hero-meta .it .v small{font-size:12px;color:#9fb2dd;font-weight:400}

/* ---------- layout ---------- */
main{max-width:1240px;margin:0 auto;padding:18px 26px 90px}
section.block{margin-top:46px;scroll-margin-top:74px}
.sec-head{display:flex;align-items:baseline;gap:14px;margin-bottom:20px}
.sec-head .num{font-family:var(--mono);font-size:12px;color:var(--yellow);font-weight:500;
  background:var(--navy);padding:4px 8px;border-radius:6px;letter-spacing:.05em}
.sec-head .num-toggle{cursor:pointer;user-select:none;transition:background .15s,transform .15s}
.sec-head .num-toggle:hover{background:var(--navy-3)}
.sec-collapsed .sec-head .num-toggle{background:var(--muted)}
.sec-collapsed .sec-head .num-toggle:after{content:" +";font-size:10px}
.sec-head h2{font-size:22px;color:var(--navy)}
.sec-head .desc{color:var(--muted);font-size:13px;margin-left:auto;max-width:430px;text-align:right}

/* ---------- variance legend ---------- */
.legend{display:flex;gap:8px;align-items:center;flex-wrap:wrap;font-size:11.5px;color:var(--muted);
  background:var(--card);border:1px solid var(--line);border-radius:10px;padding:9px 14px;margin-top:14px}
.legend .chip{display:inline-flex;align-items:center;gap:6px;font-weight:500}
.legend .dot{width:11px;height:11px;border-radius:3px}
.legend .sep{width:1px;height:14px;background:var(--line)}

/* ---------- KPI cards ---------- */
.kpi-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:16px}
.kpi{background:var(--card);border:1px solid var(--line);border-radius:14px;padding:20px 20px 16px;box-shadow:var(--shadow);position:relative;overflow:hidden}
.kpi:before{content:"";position:absolute;left:0;top:0;bottom:0;width:4px;background:var(--yellow)}
.kpi .head{display:flex;justify-content:space-between;align-items:flex-start;gap:10px}
.kpi .title{font-size:13px;font-weight:700;color:var(--navy);text-transform:uppercase;letter-spacing:.04em}
.kpi .big{font-size:30px;font-weight:900;color:var(--ink);margin-top:8px;font-variant-numeric:tabular-nums}
.kpi .big .u{font-size:13px;font-weight:500;color:var(--muted);margin-left:4px}
.var-row{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-top:14px}
.var{background:var(--paper);border-radius:9px;padding:8px 11px}
.var .lab{font-size:10.5px;letter-spacing:.08em;text-transform:uppercase;color:var(--muted);font-weight:500}
.var .val{font-size:14px;font-weight:700;margin-top:3px;font-variant-numeric:tabular-nums;display:flex;align-items:baseline;gap:7px}
.var .pct{font-size:11.5px;font-weight:600;padding:1px 6px;border-radius:5px}
.subkpis{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-top:14px;padding-top:14px;border-top:1px dashed var(--line)}
.subkpi{padding:0 11px}
.subkpi .l{font-size:11px;color:var(--muted)}
.subkpi .v{font-size:17px;font-weight:700;margin-top:2px;font-variant-numeric:tabular-nums}
.subkpi .m{font-size:10.5px;font-weight:600;margin-top:2px}

/* colour states */
.s-green{color:var(--green)}.bg-green{background:var(--green-bg);color:var(--green)}
.s-amber{color:var(--amber)}.bg-amber{background:var(--amber-bg);color:var(--amber)}
.s-red{color:var(--red)}.bg-red{background:var(--red-bg);color:var(--red)}
.s-flat{color:var(--muted)}.bg-flat{background:#eef2f9;color:var(--muted)}

/* ---------- charts ---------- */
.chart-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:16px}
.panel{background:var(--card);border:1px solid var(--line);border-radius:14px;padding:18px 18px 8px;box-shadow:var(--shadow)}
.panel h3{font-size:14px;color:var(--navy)}
.panel .ph-sub{font-size:11.5px;color:var(--muted);margin:2px 0 8px}
.chart{width:100%;height:300px}
.toggle{display:inline-flex;background:var(--paper);border:1px solid var(--line);border-radius:8px;padding:2px;float:right;margin-top:-2px}
.toggle button{border:0;background:transparent;font:inherit;font-size:11px;font-weight:600;color:var(--muted);padding:4px 10px;border-radius:6px;cursor:pointer}
.toggle button.on{background:var(--navy);color:#fff}

/* ---------- map ---------- */
.map-wrap{display:grid;grid-template-columns:1.4fr 1fr;gap:16px;align-items:stretch}
#geo{width:100%;height:520px}
.map-side{display:flex;flex-direction:column;gap:12px}
.country-card{background:var(--card);border:1px solid var(--line);border-radius:14px;padding:18px;box-shadow:var(--shadow);flex:1}
.country-card .cc-head{display:flex;align-items:center;gap:10px;border-bottom:1px solid var(--line);padding-bottom:12px}
.country-card .flag{font-size:26px;line-height:1}
.country-card .cc-name{font-size:17px;font-weight:700;color:var(--navy)}
.country-card .cc-share{font-size:11.5px;color:var(--muted)}
.cc-metrics{margin-top:6px}
.cc-row{display:grid;grid-template-columns:1.1fr .9fr .9fr .7fr;gap:8px;align-items:center;padding:9px 0;border-bottom:1px solid var(--line);font-variant-numeric:tabular-nums}
.cc-row:last-child{border-bottom:0}
.cc-row .ml{font-size:12px;color:var(--muted);font-weight:500}
.cc-row .mc{font-size:14px;font-weight:700;text-align:right}
.cc-row .mp{font-size:13px;text-align:right;color:var(--muted)}
.cc-row .mv{font-size:12px;font-weight:700;text-align:right;padding:2px 6px;border-radius:5px}
.cc-head-lbl{display:grid;grid-template-columns:1.1fr .9fr .9fr .7fr;gap:8px;font-size:9.5px;letter-spacing:.06em;text-transform:uppercase;color:var(--muted);padding-bottom:2px}
.cc-head-lbl span:not(:first-child){text-align:right}
.map-note{font-size:11px;color:var(--muted)}
.geo-tip{font-family:'Roboto',sans-serif !important;padding:10px 12px;min-width:210px}
.geo-tip .gt-h{font-weight:700;color:#0E2350;font-size:14px;margin-bottom:6px}
.geo-tip table{border-collapse:collapse;width:100%;font-size:11.5px}
.geo-tip td{padding:2px 4px;font-variant-numeric:tabular-nums}
.geo-tip td.l{color:#5b6b8c}.geo-tip td.n{text-align:right;font-weight:700}

/* ---------- P&L table ---------- */
.tbl-wrap{background:var(--card);border:1px solid var(--line);border-radius:14px;box-shadow:var(--shadow);overflow:hidden}
.tbl-tools{display:flex;gap:10px;align-items:center;padding:12px 16px;border-bottom:1px solid var(--line);font-size:12px;color:var(--muted)}
.tbl-tools button{font:inherit;font-size:11.5px;font-weight:600;border:1px solid var(--line);background:var(--paper);color:var(--navy);border-radius:7px;padding:5px 11px;cursor:pointer}
.tbl-tools button:hover{border-color:var(--navy-3)}
table.pl{width:100%;border-collapse:collapse;font-variant-numeric:tabular-nums}
table.pl thead th{position:sticky;top:60px;background:var(--navy);color:#fff;font-size:10.5px;font-weight:600;
  letter-spacing:.04em;text-transform:uppercase;padding:11px 10px;text-align:right;z-index:5}
table.pl thead th:first-child{text-align:left}
table.pl thead th.grp{background:var(--navy-2)}
table.pl td.grp{background:#eef4ff;color:var(--ink)}
table.pl tr.section td.grp{background:var(--navy);color:#fff}
table.pl thead th.lineitem-th{vertical-align:top}
table.pl thead th.lineitem-th .unit-note{display:block;font-weight:400;font-style:italic;
  font-size:9.5px;letter-spacing:.01em;text-transform:none;color:#b9c6e6;margin-top:3px}
.scroller{max-height:none;overflow:visible}
table.pl td{padding:9px 10px;border-bottom:1px solid var(--line);font-size:13px;text-align:right;white-space:nowrap}
table.pl td.lab{text-align:left;white-space:normal}
table.pl tr.section td{background:var(--navy);color:#fff;font-weight:700;text-transform:uppercase;
  font-size:11px;letter-spacing:.08em;padding:10px 12px;border-bottom:1px solid var(--navy)}
table.pl tr.lvl2 td.lab{font-weight:700;color:var(--ink)}
table.pl tr.lvl3 td.lab{padding-left:30px;color:#33476f}
table.pl tr.lvl4 td.lab{padding-left:48px;color:var(--muted);font-size:12.5px}
table.pl tr.lvl5 td.lab{padding-left:64px;color:var(--muted);font-size:12px}
table.pl td.num{font-weight:500}
table.pl td.cur{font-weight:700}
table.pl td.pct{font-size:11.5px;font-weight:600}
.cell-pct{padding:1px 6px;border-radius:5px}
.exp-tog{display:inline-flex;width:15px;height:15px;border-radius:4px;border:1px solid var(--line);
  align-items:center;justify-content:center;font-size:10px;color:var(--muted);margin-right:8px;cursor:pointer;user-select:none;vertical-align:middle}
.exp-tog:hover{border-color:var(--navy-3);color:var(--navy)}
.exp-tog.leaf{opacity:0;cursor:default}
.note-ref{font-size:9.5px;color:var(--yellow);font-weight:700;vertical-align:super;margin-left:4px;cursor:pointer;background:var(--navy);padding:1px 4px;border-radius:4px}
tr.hidden-row{display:none}

/* ---------- notes ---------- */
.notes{margin-top:18px;background:var(--card);border:1px solid var(--line);border-radius:14px;padding:8px 20px 18px;box-shadow:var(--shadow)}
.notes h3{font-size:13px;color:var(--navy);text-transform:uppercase;letter-spacing:.05em;margin:14px 0 6px}
.note{display:flex;gap:12px;padding:11px 0;border-bottom:1px solid var(--line);font-size:12.5px;color:#33476f;line-height:1.55}
.note:last-child{border-bottom:0}
.note .nn{flex:0 0 auto;width:22px;height:22px;border-radius:6px;background:var(--navy);color:var(--yellow);
  font-weight:700;font-size:11px;display:grid;place-items:center;font-family:var(--mono)}
.note .nb{flex:1}
.note .nl{font-weight:700;color:var(--navy);margin-bottom:2px;font-size:12.5px}
.note p{margin:0;white-space:pre-line}
.note .nb p + p{margin-top:7px}
.note-ul{margin:6px 0 2px;padding-left:18px}
.note-ul li{margin:3px 0;line-height:1.5}
.note-ul-nested{margin:3px 0 4px;padding-left:20px;list-style-type:circle}
.note-ul-nested li{color:var(--muted)}
.note-italic{font-style:italic;color:var(--muted)}

/* ---------- bridge / deviation ---------- */
.two-col{display:grid;grid-template-columns:1.5fr 1fr;gap:16px;align-items:start}
table.dev{width:100%;border-collapse:collapse;font-variant-numeric:tabular-nums}
table.dev th{background:var(--navy);color:#fff;font-size:10.5px;font-weight:600;text-transform:uppercase;
  letter-spacing:.04em;padding:10px;text-align:right}
table.dev th:first-child{text-align:left}
table.dev td{padding:8px 10px;border-bottom:1px solid var(--line);text-align:right;font-size:13px}
table.dev td.lab{text-align:left}
table.dev tr.t-group td{background:#eef2f9;font-weight:700;color:var(--navy)}
table.dev tr.t-sub td{background:var(--paper)}
table.dev tr.t-sub td.lab{padding-left:24px;font-weight:600;color:var(--navy)}
table.dev tr.t-leaf td.lab{padding-left:48px;color:#33476f;font-weight:400}

footer{border-top:1px solid var(--line);margin-top:60px;padding:26px;text-align:center;color:var(--muted);font-size:11.5px}
footer .disc{max-width:760px;margin:8px auto 0;line-height:1.6}

@media(max-width:980px){
  .kpi-grid,.chart-grid{grid-template-columns:1fr}
  .map-wrap,.two-col{grid-template-columns:1fr}
  .hero h1{font-size:30px}
  .sec-head .desc{display:none}
  table.pl thead th{top:0}
}

/* ---------- appendix ---------- */
.appx-link{color:var(--navy);font-weight:700;text-decoration:underline;text-decoration-color:var(--yellow);text-underline-offset:2px;cursor:pointer}
.appx-link:hover{color:var(--navy-3)}
.appx-intro{font-size:13px;color:#33476f;line-height:1.6}
.appx-intro p{margin:0}
.appx-intro p + p{margin-top:10px}
.appx-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-top:16px}
.appx-stat{background:var(--card);border:1px solid var(--line);border-radius:14px;padding:16px 16px 14px;box-shadow:var(--shadow);position:relative;overflow:hidden}
.appx-stat:before{content:"";position:absolute;left:0;top:0;bottom:0;width:4px;background:var(--yellow)}
.appx-stat .v{font-size:24px;font-weight:900;color:var(--navy);font-variant-numeric:tabular-nums;line-height:1}
.appx-stat .l{font-size:12px;font-weight:700;color:var(--ink);margin-top:8px;text-transform:uppercase;letter-spacing:.03em}
.appx-stat .s{font-size:11.5px;color:var(--muted);margin-top:4px;line-height:1.45}
table.appx-comp{width:100%;border-collapse:collapse;margin-top:10px;font-variant-numeric:tabular-nums}
table.appx-comp th{font-size:11px;font-weight:700;color:var(--navy);text-transform:uppercase;letter-spacing:.03em;text-align:right;padding:8px 10px;border-bottom:2px solid var(--line)}
table.appx-comp th:first-child{text-align:left}
table.appx-comp th.opt,table.appx-comp td.opt{background:var(--yellow-soft);color:var(--ink)}
table.appx-comp td{font-size:13px;text-align:right;padding:9px 10px;border-bottom:1px solid var(--line)}
table.appx-comp td.lab{text-align:left;color:var(--muted);font-weight:500}
table.appx-comp tr:last-child td{border-bottom:0;font-weight:700;color:var(--navy)}
@media(max-width:980px){ .appx-stats{grid-template-columns:repeat(2,1fr)} }

/* ---------- glossary ---------- */
.gloss-tables{display:grid;grid-template-columns:repeat(2,1fr);gap:18px 28px;align-items:start}
.gloss-table{width:100%;border-collapse:collapse;background:var(--card);border:1px solid var(--line);
  border-radius:12px;overflow:hidden;box-shadow:var(--shadow)}
.gloss-table thead th{background:var(--navy);color:#fff;text-align:left;font-size:11px;font-weight:700;
  text-transform:uppercase;letter-spacing:.06em;padding:9px 12px;white-space:nowrap}
.gloss-table thead th.gt-full{width:auto}
.gloss-table td{padding:8px 12px;border-bottom:1px solid var(--line);font-size:13px;vertical-align:top}
.gloss-table tbody tr:last-child td{border-bottom:0}
.gloss-table td.gt-term{font-weight:700;color:var(--navy);white-space:nowrap;width:90px}
.gloss-table td.gt-full{color:var(--ink)}
.gloss-def{display:block;color:var(--muted);font-size:12px;margin-top:2px}
@media(max-width:980px){ .gloss-tables{grid-template-columns:1fr} }
