@import url('fonts.css');

:root{
  --bg:#FBF8F1; --surface:#FFFFFF; --surface-2:#F5F1E8;
  --ink:#1B2A4A; --text:#1B2A4A; --text-2:#3B4A63; --muted:#8A93A6;
  --border:#E4E0D6; --border-strong:#CFC9BB;
  --accent:#C2410C; --accent-tint:#F3E4DB; --on-accent:#FBF8F1;
  --nodata:#E7E2D6;
  --r0:#F0E5D8; --r1:#E9A97E; --r2:#D8703F; --r3:#B24417; --r4:#7A2C0E;
  --shadow:0 1px 2px rgba(27,42,74,.06),0 6px 24px rgba(27,42,74,.05);
  --maxw:1120px; --font-ui:'Inter',system-ui,sans-serif; --font-display:'Fraunces',Georgia,serif;
}
[data-theme="dark"]{
  --bg:#141B2E; --surface:#1C2439; --surface-2:#232C44;
  --ink:#F7F1E6; --text:#F7F1E6; --text-2:#AEB8CC; --muted:#6B7590;
  --border:#2A344F; --border-strong:#3A466690;
  --accent:#E4703F; --accent-tint:#33261F; --on-accent:#141B2E;
  --nodata:#28324C;
  --r0:#33261F; --r1:#7A3E24; --r2:#C2531F; --r3:#E4703F; --r4:#F4A06A;
  --shadow:0 1px 2px rgba(0,0,0,.3),0 8px 30px rgba(0,0,0,.25);
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;background:var(--bg);color:var(--text);font-family:var(--font-ui);font-size:17px;line-height:1.65;-webkit-font-smoothing:antialiased;transition:background .25s,color .25s}
h1,h2,h3,h4{font-family:var(--font-display);font-weight:600;color:var(--ink);line-height:1.12;margin:0 0 .4em}
h1{font-size:clamp(2rem,4.5vw,3.5rem)}
h2{font-size:clamp(1.5rem,3vw,1.9rem)}
h3{font-size:1.25rem;font-family:var(--font-ui);font-weight:600}
p{margin:0 0 1rem}
a{color:var(--accent);text-decoration:none}
a:hover{text-decoration:underline}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 24px}
.overline{font-size:12px;font-weight:500;letter-spacing:.07em;text-transform:uppercase;color:var(--muted)}
.tnum{font-variant-numeric:tabular-nums}
.muted{color:var(--muted)}
.small{font-size:14px}

/* header */
header.site{position:sticky;top:0;z-index:50;background:color-mix(in srgb,var(--bg) 88%,transparent);backdrop-filter:blur(10px);border-bottom:1px solid var(--border)}
.nav{display:flex;align-items:center;justify-content:space-between;height:64px}
.brand{font-family:var(--font-ui);font-weight:600;font-size:22px;letter-spacing:-.02em;color:var(--ink)}
.brand:hover{text-decoration:none}
.brand .dot{color:var(--accent)}
.nav-links{display:flex;align-items:center;gap:22px}
.nav-links a{color:var(--text-2);font-size:14px}
.nav-links a:hover{color:var(--ink);text-decoration:none}
.btn{display:inline-flex;align-items:center;gap:8px;font-size:14px;font-weight:500;padding:8px 15px;border-radius:8px;border:1px solid var(--ink);background:var(--ink);color:var(--bg);cursor:pointer;transition:.15s}
.btn:hover{text-decoration:none;opacity:.9}
.btn.ghost{background:transparent;color:var(--text);border-color:var(--border-strong)}
.btn.accent{background:var(--accent);border-color:var(--accent);color:var(--on-accent)}
.toggle{width:38px;height:38px;border-radius:8px;border:1px solid var(--border-strong);background:transparent;color:var(--text);cursor:pointer;display:inline-flex;align-items:center;justify-content:center}
.toggle:hover{background:var(--surface-2)}
.toggle svg{width:18px;height:18px}
.mobile-only{display:none}

/* hero */
.hero{background:#141B2E;color:#F7F1E6;padding:46px 0 30px;border-bottom:1px solid #2A344F}
[data-theme="dark"] .hero{background:#10162610}
.hero h1{color:#F7F1E6;max-width:16ch}
.hero .lede{color:#AEB8CC;font-size:19px;max-width:52ch;margin-top:.2em}
.hero .stamp{color:#8A93A6;font-size:13px;margin-top:14px}
.hero .stamp b{color:#E4703F;font-weight:500}

/* metric switch */
.controls{display:flex;flex-wrap:wrap;gap:18px;align-items:end;margin:22px 0 8px}
.field label{display:block;font-size:12px;letter-spacing:.06em;text-transform:uppercase;color:var(--muted);margin-bottom:6px}
select,.pillbar{font-family:var(--font-ui);font-size:14px}
select{appearance:none;background:var(--surface);color:var(--text);border:1px solid var(--border-strong);border-radius:8px;padding:9px 34px 9px 12px;cursor:pointer;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%238A93A6' stroke-width='2'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center}
.pillbar{display:inline-flex;gap:4px;background:var(--surface-2);border:1px solid var(--border);border-radius:9px;padding:4px}
.pill{border:0;background:transparent;color:var(--text-2);padding:6px 12px;border-radius:6px;font-size:13px;cursor:pointer;white-space:nowrap}
.pill[aria-pressed="true"]{background:var(--surface);color:var(--ink);box-shadow:var(--shadow);font-weight:500}

/* layout: map + rail */
.grid{display:grid;grid-template-columns:1fr 300px;gap:28px;align-items:stretch;margin-top:14px}
.card{background:var(--surface);border:1px solid var(--border);border-radius:14px;box-shadow:var(--shadow)}
.map-card{padding:10px 12px 6px;display:flex;flex-direction:column;height:100%}
.map-holder{flex:1;position:relative;min-height:300px}
#worldmap{position:absolute;inset:0;width:100%;height:100%;display:block}
#worldmap path.cc{stroke:var(--bg);stroke-width:.5;cursor:pointer;transition:opacity .1s}
#worldmap path.cc:hover{opacity:.75}
#worldmap path.cc:focus{outline:none;stroke:var(--ink);stroke-width:1.2}
.legend{display:flex;align-items:center;gap:8px;padding:6px 6px 8px;font-size:12px;color:var(--muted)}
.legend .sw{width:22px;height:12px;border-radius:2px}
.rail .card{padding:0!important;overflow:hidden}
.rail-head{display:flex;align-items:center;gap:8px;padding:15px 18px;border-bottom:1px solid var(--border);font-family:var(--font-ui);font-weight:600;font-size:15px;color:var(--ink)}
.rail-head svg{width:16px;height:16px;stroke:var(--accent)}
.filter-group{padding:15px 18px;border-bottom:1px solid var(--border)}
.filter-group .overline{display:block;margin-bottom:10px}
.chips{display:flex;flex-wrap:wrap;gap:7px}
.chip{border:1px solid var(--border);background:var(--surface-2);color:var(--text-2);font-size:12.5px;padding:6px 12px;border-radius:20px;cursor:pointer;transition:.12s;line-height:1.2}
.chip:hover{border-color:var(--accent);color:var(--ink)}
.chip[aria-pressed="true"]{background:var(--accent);border-color:var(--accent);color:var(--on-accent);font-weight:500}
.rail-foot{display:flex;justify-content:space-between;align-items:center;padding:13px 18px;background:var(--surface-2)}
.rail .result-count{font-size:13px;color:var(--text-2);font-weight:500}
.clearlink{background:none;border:0;color:var(--accent);font-size:13px;cursor:pointer;padding:0;font-weight:500}
.clearlink:hover{text-decoration:underline}

/* table */
.tablewrap{margin-top:34px}
table.rank{width:100%;border-collapse:collapse;font-size:15px;position:relative}
table.rank th,table.rank td{text-align:left;padding:12px 12px;border-bottom:1px solid var(--border)}
table.rank thead th{position:sticky;top:63px;z-index:20;background:var(--bg);box-shadow:inset 0 -1px 0 var(--border-strong);font-family:var(--font-ui);font-size:12px;letter-spacing:.05em;text-transform:uppercase;color:var(--muted);font-weight:500;cursor:pointer;white-space:nowrap}
table.rank thead th.num,table.rank td.num{text-align:right}
table.rank tbody tr:hover{background:var(--surface-2)}
table.rank td a{color:var(--ink);font-weight:500}
.flag{width:22px;height:16px;border-radius:2px;object-fit:cover;vertical-align:-2px;margin-right:9px;box-shadow:0 0 0 1px rgba(0,0,0,.08)}
.rankn{color:var(--muted);font-variant-numeric:tabular-nums;width:34px}
.trend{font-variant-numeric:tabular-nums;font-size:13px}
.trend.up{color:#1D9E75}.trend.down{color:#D8703F}.trend.flat{color:var(--muted)}
[data-theme="dark"] .trend.up{color:#5DCAA5}

/* tooltip */
#tip{position:fixed;pointer-events:none;z-index:80;background:var(--ink);color:var(--bg);font-size:12.5px;padding:7px 10px;border-radius:7px;box-shadow:var(--shadow);opacity:0;transition:opacity .1s;max-width:220px}
#tip b{font-weight:600}
#tip .v{color:var(--r3)}
[data-theme="dark"] #tip .v{color:var(--r4)}

/* country page */
.cprofile{padding:34px 0}
.chead{display:flex;align-items:center;gap:16px;margin-bottom:6px}
.chead h1{margin:0;line-height:1}
.chead img{width:54px;height:40px;border-radius:4px;box-shadow:0 0 0 1px rgba(0,0,0,.1);flex-shrink:0;position:relative;top:1px}
.meta-row{display:flex;flex-wrap:wrap;gap:8px;margin:10px 0 26px}
.tag{font-size:12.5px;border:1px solid var(--border);background:var(--surface-2);color:var(--text-2);padding:4px 10px;border-radius:20px}
.statgrid{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:14px;margin:8px 0 30px}
.stat{background:var(--surface-2);border-radius:12px;padding:16px}
.stat .k{font-size:12px;letter-spacing:.05em;text-transform:uppercase;color:var(--muted)}
.stat .v{font-family:var(--font-display);font-size:30px;color:var(--ink);font-variant-numeric:tabular-nums;line-height:1.1;margin-top:4px}
.stat .s{font-size:13px;color:var(--text-2)}
.chart-card{padding:20px 22px;margin-bottom:26px}
.chart-card svg{width:100%;height:auto;display:block}
.srcs{font-size:13px;color:var(--muted)}
.srcs a{color:var(--text-2)}
.backlink{font-size:14px}
.crumbs{font-size:13px;color:var(--muted);margin-bottom:14px}
.crumbs a{color:var(--text-2)}
.crumbs span{color:var(--text-2)}

/* generic content pages */
.content{padding:40px 0;max-width:760px}
.content h2{margin-top:1.6em}
.content ul{padding-left:1.2em}
.content li{margin-bottom:.4em}
.cmp-pickers{display:flex;flex-wrap:wrap;gap:10px;margin:18px 0 24px}
.cmp-sel{min-width:200px;flex:1}
.cmp-table th:first-child,.cmp-table td.cmp-metric{text-align:left;color:var(--text-2)}
.cmp-table .flag{margin-right:6px}
.cmp-bars{display:flex;flex-direction:column;gap:10px;margin-top:12px}
.cmp-bar{display:grid;grid-template-columns:150px 1fr 90px;align-items:center;gap:12px;font-size:14px}
.cmp-bar-track{background:var(--surface-2);border-radius:6px;height:16px;overflow:hidden}
.cmp-bar-fill{display:block;height:100%;background:var(--accent);border-radius:6px}
.cmp-bar-val{text-align:right;font-weight:500}
.embedbox{margin:30px 0 10px;border:1px solid var(--border);border-radius:12px;padding:14px 18px;background:var(--surface-2)}
.embedbox summary{cursor:pointer;font-weight:500;color:var(--ink)}
.embed-code{width:100%;min-height:70px;margin:10px 0;font-family:var(--font-mono,monospace);font-size:12.5px;padding:10px 12px;border:1px solid var(--border-strong);border-radius:8px;background:var(--bg);color:var(--text);resize:vertical}
@media(max-width:560px){.cmp-bar{grid-template-columns:100px 1fr 70px}}
.linklist{list-style:none;padding:0;margin:12px 0 8px}
.linklist li{padding:10px 0;border-bottom:1px solid var(--border)}
.linklist.cols{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:0 24px}
.linklist a{font-size:16px}
.explore-band{margin:40px 0 8px}
.explore-band h2{font-size:1.3rem;margin-bottom:12px}
.explore-links{display:flex;flex-wrap:wrap;gap:8px}
.explore-links a{font-size:14px;border:1px solid var(--border-strong);border-radius:20px;padding:7px 14px;color:var(--text-2)}
.explore-links a:hover{border-color:var(--accent);color:var(--accent);text-decoration:none}
.pricegrid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:16px;margin:22px 0}
.price{background:var(--surface);border:1px solid var(--border);border-radius:14px;padding:22px;box-shadow:var(--shadow)}
.price.feat{border:2px solid var(--accent)}
.price .amt{font-family:var(--font-display);font-size:34px;color:var(--ink)}
.price .amt small{font-family:var(--font-ui);font-size:14px;color:var(--muted);font-weight:400}
.price ul{list-style:none;padding:0;font-size:14.5px}
.price li{padding:6px 0;border-bottom:1px solid var(--border)}
.price li:last-child{border-bottom:0}
.badge{display:inline-block;background:var(--accent-tint);color:var(--accent);font-size:11px;font-weight:500;letter-spacing:.05em;text-transform:uppercase;padding:3px 9px;border-radius:20px;margin-bottom:10px}
[data-theme="dark"] .badge{color:var(--r4)}
form.reqform{background:var(--surface);border:1px solid var(--border);border-radius:14px;padding:26px;box-shadow:var(--shadow);margin-top:20px}
.formrow{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.formfield{margin-bottom:14px;display:flex;flex-direction:column}
.formfield.full{grid-column:1 / -1}
.formfield label{font-size:13px;font-weight:500;color:var(--text-2);margin-bottom:6px}
.formfield input,.formfield select,.formfield textarea{font-family:var(--font-ui);font-size:15px;padding:10px 12px;border:1px solid var(--border-strong);border-radius:8px;background:var(--bg);color:var(--text)}
.formfield textarea{min-height:96px;resize:vertical}
.formfield input:focus,.formfield select:focus,.formfield textarea:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-tint)}
@media(max-width:620px){.formrow{grid-template-columns:1fr}}

/* footer */
footer.site{border-top:1px solid var(--border);margin-top:60px;padding:36px 0;color:var(--text-2);font-size:14px}
.foot-grid{display:flex;flex-wrap:wrap;justify-content:space-between;gap:24px}
footer .brand{font-size:18px}
footer a{color:var(--text-2)}

@media(max-width:860px){
  .grid{grid-template-columns:1fr}
  .rail{order:2}
  .map-card{height:auto}
  .map-holder{min-height:0;aspect-ratio:1000/430}
  .nav-links a:not(.btn):not(.toggle){display:none}
  .mobile-only{display:inline-flex}
  .tablewrap{overflow-x:auto}
  table.rank thead th{top:0}
}
@media(prefers-reduced-motion:reduce){*{transition:none!important;scroll-behavior:auto}}
