/* EUBudget — Bold institutional design system. */
/* Self-hosted fonts (no external CDN). */

@font-face {
  font-family: 'Inter';
  font-style: normal;
  font-weight: 100 900;
  font-display: swap;
  src: url('/fonts/inter-latin.woff2') format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
@font-face {
  font-family: 'Inter';
  font-style: normal;
  font-weight: 100 900;
  font-display: swap;
  src: url('/fonts/inter-latin-ext.woff2') format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
@font-face {
  font-family: 'JetBrains Mono';
  font-style: normal;
  font-weight: 100 800;
  font-display: swap;
  src: url('/fonts/jetbrains-mono-latin.woff2') format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
@font-face {
  font-family: 'JetBrains Mono';
  font-style: normal;
  font-weight: 100 800;
  font-display: swap;
  src: url('/fonts/jetbrains-mono-latin-ext.woff2') format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}

:root {
  /* ── BRAND ── */
  --eu-blue: #0a3d91;
  --eu-blue-deep: #062866;
  --eu-blue-soft: #e8eef9;
  --eu-yellow: #ffcc00;

  /* ── SEMANTIC FLOWS ── */
  --out: #c8102e;
  --out-deep: #9a0c23;
  --out-soft: #fdecef;
  --in: #1f8a4c;
  --in-deep: #146435;
  --in-soft: #e6f3ec;

  /* ── SURFACES ── */
  --bg: #ffffff;
  --bg-card: #ffffff;
  --bg-soft: #f5f6f8;
  --bg-inset: #ebedf1;
  --ink: #0e1116;
  --ink-2: #2c313a;
  --ink-3: #5b626d;
  --ink-4: #8b919c;
  --rule: #e3e6ec;
  --rule-strong: #0e1116;

  --pos: var(--in);
  --neg: var(--out);

  --sans: 'Inter', system-ui, -apple-system, BlinkMacSystemFont, 'Helvetica Neue', sans-serif;
  --mono: 'JetBrains Mono', ui-monospace, Menlo, Consolas, monospace;

  --radius: 4px;
  --radius-lg: 8px;
}

/* ── BASE ── */
html { scroll-behavior: smooth; }
body {
  font-family: var(--sans);
  background: var(--bg);
  color: var(--ink);
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
  font-feature-settings: 'ss01', 'cv11';
}

/* numerals */
.num { font-family: var(--mono); font-feature-settings: 'tnum'; letter-spacing: -0.01em; }
.mono { font-family: var(--mono); }

/* skip link */
.skip-link {
  position: absolute; left: 8px; top: -100px;
  background: var(--ink); color: #fff;
  padding: 10px 16px; border-radius: 6px;
  font-weight: 600; font-size: 14px;
  z-index: 100; transition: top .2s; text-decoration: none;
}
.skip-link:focus { top: 8px; outline: 3px solid var(--eu-blue); outline-offset: 2px; }
:focus-visible { outline: 3px solid var(--eu-blue); outline-offset: 2px; border-radius: 4px; }
@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after { animation-duration: 0.01ms !important; transition-duration: 0.01ms !important; }
}

/* ── HEADER (negative blue) ── */
.eu-header {
  background: var(--eu-blue);
  color: #fff;
  border-bottom: 1px solid var(--eu-blue-deep);
}
.eu-header-inner {
  display: flex; align-items: center; justify-content: space-between;
  padding: 12px 16px; gap: 12px;
  max-width: 1440px; margin: 0 auto;
}
@media (min-width: 768px) {
  .eu-header-inner { padding: 14px 32px; gap: 24px; }
}
.eu-brand {
  display: flex; align-items: center; gap: 10px;
  font-family: var(--sans); font-size: 20px; font-weight: 800;
  letter-spacing: -0.025em; color: #fff; text-decoration: none;
}
.eu-brand-mark {
  display: inline-flex; align-items: center; justify-content: center;
  width: 28px; height: 28px;
  background: #fff; color: var(--eu-blue);
  font-family: var(--mono); font-weight: 700; font-size: 13px;
  border-radius: 4px;
}
.eu-brand em { color: var(--eu-yellow); font-style: normal; }
.eu-nav-links { display: flex; gap: 4px; font-size: 13px; }
.eu-nav-links a {
  color: rgba(255,255,255,0.78); text-decoration: none;
  padding: 8px 12px; border-radius: 4px; font-weight: 500;
  transition: background .15s, color .15s;
}
.eu-nav-links a:hover { background: rgba(255,255,255,0.1); color: #fff; }
.eu-nav-links a.active { color: #fff; background: rgba(255,255,255,0.14); font-weight: 600; }

.eu-lang {
  display: flex; gap: 2px;
  font-family: var(--mono); font-size: 11px; text-transform: uppercase;
  border: 1px solid rgba(255,255,255,0.25);
  border-radius: 4px; padding: 2px;
}
.eu-lang a {
  padding: 3px 8px; border-radius: 3px;
  color: rgba(255,255,255,0.65); text-decoration: none;
}
.eu-lang a.active { background: #fff; color: var(--eu-blue); }
.eu-lang a:hover:not(.active) { color: #fff; }

.verified-badge {
  display: inline-flex; align-items: center; gap: 6px;
  font-family: var(--mono); font-size: 10px; text-transform: uppercase;
  letter-spacing: 0.08em; color: rgba(255,255,255,0.85);
  border: 1px solid rgba(255,255,255,0.25);
  padding: 5px 10px; border-radius: 4px;
  background: rgba(255,255,255,0.08);
}
.verified-badge .dot {
  width: 6px; height: 6px; border-radius: 50%;
  background: var(--eu-yellow);
  box-shadow: 0 0 0 3px rgba(255,204,0,0.2);
}

/* ── HERO (negative blue) ── */
.hero-blue {
  background: var(--eu-blue);
  color: #fff;
  padding: 48px 20px 56px;
  overflow: hidden;
}
@media (min-width: 768px) {
  .hero-blue { padding: 56px 32px 64px; }
}
.hero-blue .hero-inner {
  max-width: 1440px; margin: 0 auto;
  display: grid; grid-template-columns: 1fr;
  gap: 32px; align-items: end;
}
@media (min-width: 1100px) {
  .hero-blue .hero-inner { grid-template-columns: 1.25fr 1fr; gap: 56px; }
}
.hero-blue .eyebrow { color: rgba(255,255,255,0.7); }
.hero-blue .lead { color: rgba(255,255,255,0.85); max-width: 60ch; }
.hero-blue h1 em { color: var(--eu-yellow); font-style: normal; font-weight: inherit; }
.hero-blue .hero-card {
  background: rgba(255,255,255,0.08);
  border: 1px solid rgba(255,255,255,0.18);
  border-radius: 8px; padding: 18px;
  backdrop-filter: blur(4px);
  overflow: hidden;
}
@media (min-width: 768px) {
  .hero-blue .hero-card { padding: 22px; }
}
.hero-blue .hero-card dl { grid-template-columns: 1fr 1fr; }
.hero-blue .hero-card dd { white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
@media (max-width: 600px) {
  .hero-blue .hero-card dl { grid-template-columns: 1fr !important; gap: 14px !important; }
  .hero-blue .hero-card dd { font-size: 26px !important; }
}

/* ── TYPE ── */
.eyebrow, .kicker {
  font-family: var(--mono); font-size: 11px; font-weight: 500;
  text-transform: uppercase; letter-spacing: 0.14em;
  color: var(--ink-3);
}
.kicker-light { color: rgba(255,255,255,0.7); }
.h-display {
  font-family: var(--sans); font-weight: 800;
  font-size: 26px;
  line-height: 1.1; letter-spacing: -0.02em;
  color: var(--ink); margin: 0;
  overflow-wrap: break-word; word-break: normal;
  hyphens: auto;
}
@media (min-width: 480px) {
  .h-display { font-size: 32px; line-height: 1.05; letter-spacing: -0.025em; }
}
@media (min-width: 640px) {
  .h-display {
    font-size: clamp(40px, 6.5vw, 88px);
    line-height: 1.0; letter-spacing: -0.04em;
    text-wrap: balance;
  }
}
.h-display em { font-style: normal; color: var(--eu-yellow); font-weight: inherit; }
.h-1 {
  font-family: var(--sans); font-weight: 800;
  font-size: clamp(28px, 5vw, 56px);
  line-height: 1.05; letter-spacing: -0.025em; margin: 0;
  text-wrap: balance; overflow-wrap: break-word;
}
.h-1 em { font-style: normal; color: var(--eu-blue); font-weight: inherit; }
.h-2 {
  font-family: var(--sans); font-weight: 700;
  font-size: clamp(24px, 2.6vw, 36px);
  line-height: 1.1; letter-spacing: -0.02em; margin: 0;
}
.h-3 {
  font-family: var(--sans); font-weight: 600;
  font-size: 18px; line-height: 1.2; letter-spacing: -0.01em; margin: 0;
}
.h-section {
  font-family: var(--mono); font-size: 11px; font-weight: 500;
  text-transform: uppercase; letter-spacing: 0.16em;
  color: var(--ink-3);
  border-top: 2px solid var(--rule-strong); padding-top: 12px;
  display: flex; align-items: baseline; justify-content: space-between;
  gap: 16px;
}
.lead { font-size: 18px; line-height: 1.55; color: var(--ink-2); max-width: 60ch; margin: 0; }
.h-display, .h-1, .h-2, .h-3 { margin: 0; display: block; }
.h-display + .lead, .h-display + p,
.h-1 + .lead, .h-1 + p,
.h-2 + .lead, .h-2 + p,
.h-3 + .lead, .h-3 + p { margin-top: 20px; }
.eyebrow + .h-display, .eyebrow + .h-1, .eyebrow + .h-2,
.kicker + .h-display, .kicker + .h-1, .kicker + .h-2 { margin-top: 8px; }
.body-t { font-size: 14px; line-height: 1.6; color: var(--ink-2); }
.small { font-size: 12px; line-height: 1.5; color: var(--ink-3); }

/* ── BUTTONS ── */
.btn {
  display: inline-flex; align-items: center; gap: 8px;
  padding: 12px 18px; border-radius: var(--radius);
  font-family: var(--sans); font-size: 14px; font-weight: 600;
  border: 1px solid transparent; cursor: pointer; text-decoration: none;
  transition: background .15s, color .15s, border-color .15s, transform .1s;
  white-space: nowrap; min-height: 42px;
}
.btn:active { transform: translateY(1px); }
.btn-primary { background: var(--eu-blue); color: #fff; border-color: var(--eu-blue); }
.btn-primary:hover { background: var(--eu-blue-deep); border-color: var(--eu-blue-deep); }
.btn-ghost { background: transparent; color: var(--ink); border-color: var(--rule-strong); }
.btn-ghost:hover { background: var(--ink); color: var(--bg); }
.btn-on-blue { background: #fff; color: var(--eu-blue); border-color: #fff; }
.btn-on-blue:hover { background: var(--eu-blue-soft); }
.btn-on-blue.ghost { background: transparent; color: #fff; border-color: rgba(255,255,255,0.5); }
.btn-on-blue.ghost:hover { background: rgba(255,255,255,0.12); border-color: #fff; }

/* ── METRIC ── */
.metric { display: flex; flex-direction: column; gap: 6px; }
.metric-val {
  font-family: var(--mono); font-weight: 600;
  font-size: 36px; line-height: 1; letter-spacing: -0.02em; color: var(--ink);
}
.metric-lbl {
  font-family: var(--mono); font-size: 10px;
  text-transform: uppercase; letter-spacing: 0.12em; color: var(--ink-3);
}

/* ── TABLE ── */
.eu-table { width: 100%; border-collapse: collapse; font-size: 14px; }
.eu-table th {
  text-align: left; font-family: var(--mono); font-size: 10px; font-weight: 500;
  text-transform: uppercase; letter-spacing: 0.12em; color: var(--ink-3);
  padding: 12px 14px; border-bottom: 1px solid var(--rule-strong);
  background: var(--bg-soft);
}
.eu-table td {
  padding: 14px; border-bottom: 1px solid var(--rule);
  color: var(--ink-2); vertical-align: middle;
}
.eu-table tr:hover td { background: var(--bg-soft); }
.eu-table .country-name { color: var(--ink); font-weight: 600; }
.eu-table td.num-c { font-family: var(--mono); text-align: right; font-feature-settings: 'tnum'; }
.pos, .text-pos, .text-in { color: var(--in); }
.neg, .text-neg, .text-out { color: var(--out); }
.text-eub, .text-primary { color: var(--eu-blue); }

/* ── BAR ROW ── */
.bar-row {
  display: grid; grid-template-columns: 28px 140px 1fr 90px;
  align-items: center; gap: 14px; padding: 9px 0;
}
.bar-row .rank { font-family: var(--mono); color: var(--ink-4); font-size: 11px; }
.bar-row .label { display: flex; align-items: center; gap: 8px; font-size: 13px; color: var(--ink); font-weight: 500; }
.bar-row .label .flag { font-size: 16px; }
.bar-row .val { font-family: var(--mono); font-size: 13px; font-weight: 600; text-align: right; font-feature-settings: 'tnum'; }
.bar-track { height: 8px; background: var(--bg-inset); border-radius: 2px; overflow: hidden; }
.bar-fill { height: 100%; }
.bar-fill.out-fill { background: var(--out); }
.bar-fill.in-fill { background: var(--in); }
.bar-fill.blue-fill { background: var(--eu-blue); }
.bar-fill.ink-fill { background: var(--ink); }

/* ── CARDS ── */
.card {
  background: var(--bg-card); border: 1px solid var(--rule);
  border-radius: var(--radius-lg); padding: 24px;
}
.card-flat {
  background: var(--bg-card); border: 1px solid var(--rule);
  border-radius: var(--radius); padding: 22px;
}

/* ── COUNTRY CHIP ── */
.chip {
  display: grid; grid-template-columns: auto 1fr auto;
  align-items: center; gap: 10px;
  padding: 12px 14px;
  border: 1px solid var(--rule);
  border-left: 3px solid var(--rule);
  border-radius: var(--radius);
  background: var(--bg-card);
  text-decoration: none; color: inherit;
  cursor: pointer;
  transition: border-color .15s, transform .12s, box-shadow .15s;
}
.chip:hover { border-color: var(--ink); transform: translateY(-1px); box-shadow: 0 2px 8px rgba(14,17,22,0.06); }
.chip.chip-out { border-left-color: var(--out); }
.chip.chip-in { border-left-color: var(--in); }
.chip-flag { font-size: 20px; line-height: 1; }
.chip-name { font-size: 12px; color: var(--ink); font-weight: 600; line-height: 1.2; }
.chip-val { font-family: var(--mono); font-size: 12px; line-height: 1; font-weight: 600; font-feature-settings: 'tnum'; }

/* ── PILLS ── */
.pill {
  display: inline-flex; align-items: center; gap: 6px;
  padding: 4px 10px; border-radius: 999px;
  font-family: var(--mono); font-size: 11px; font-weight: 500;
  text-transform: uppercase; letter-spacing: 0.06em;
}
.pill-out { background: var(--out-soft); color: var(--out-deep); }
.pill-in { background: var(--in-soft); color: var(--in-deep); }
.pill-blue { background: var(--eu-blue-soft); color: var(--eu-blue); }
.pill .dot { width: 6px; height: 6px; border-radius: 50%; }
.pill-out .dot { background: var(--out); }
.pill-in .dot { background: var(--in); }
.pill-blue .dot { background: var(--eu-blue); }

/* ── TABS ── */
.tabs { display: flex; gap: 0; border-bottom: 1px solid var(--rule-strong); }
.tab {
  padding: 10px 18px; cursor: pointer; font-size: 13px;
  color: var(--ink-3); background: transparent;
  border: none; border-bottom: 2px solid transparent;
  margin-bottom: -1px; font-family: var(--sans); font-weight: 500;
}
.tab.active { color: var(--ink); border-bottom-color: var(--eu-blue); font-weight: 600; }
.tab:hover { color: var(--ink); }

/* ── INPUT ── */
.eu-input {
  width: 100%; padding: 10px 14px;
  border: 1px solid var(--rule); border-radius: var(--radius);
  background: var(--bg-card); color: var(--ink);
  font-family: var(--sans); font-size: 13px;
  min-height: 42px;
}
.eu-input:focus { outline: none; border-color: var(--eu-blue); box-shadow: 0 0 0 3px var(--eu-blue-soft); }

/* ── FOOTER (dark) ── */
.eu-foot {
  background: var(--ink); color: #fff;
  padding: 44px 32px 24px; font-size: 13px;
}
.eu-foot-inner { max-width: 1440px; margin: 0 auto; }
.eu-foot-grid {
  display: grid; grid-template-columns: 2fr 1fr 1fr 1fr;
  gap: 48px; padding-bottom: 28px;
  border-bottom: 1px solid rgba(255,255,255,0.12);
}
.eu-foot h3 {
  font-family: var(--mono); font-size: 10px; font-weight: 500;
  text-transform: uppercase; letter-spacing: 0.12em;
  color: rgba(255,255,255,0.5); margin: 0 0 14px;
}
.eu-foot ul { list-style: none; padding: 0; margin: 0; display: grid; gap: 9px; }
.eu-foot a {
  color: rgba(255,255,255,0.85); text-decoration: none;
  border-bottom: 1px solid transparent;
}
.eu-foot a:hover { color: #fff; border-bottom-color: rgba(255,255,255,0.5); }
.eu-foot-tag { color: rgba(255,255,255,0.65); margin-top: 10px; line-height: 1.55; max-width: 340px; }
.eu-foot-bottom {
  padding-top: 16px;
  display: flex; flex-wrap: wrap; justify-content: space-between; gap: 12px;
  color: rgba(255,255,255,0.45);
  font-size: 11px; font-family: var(--mono);
}

/* ── RESPONSIVE ── */
@media (max-width: 1100px) {
  .verified-badge { display: none; }
}
@media (max-width: 900px) {
  .eu-foot-grid { grid-template-columns: 1fr 1fr; }
  .bar-row { grid-template-columns: 24px 100px 1fr 72px; gap: 10px; }
}
@media (max-width: 768px) {
  .eu-nav-links { display: none; }
  .eu-lang { display: none; }
  .eu-foot-bottom { font-size: 10px; }
}
@media (max-width: 640px) {
  .eu-foot-grid { grid-template-columns: 1fr; gap: 28px; }
  .eu-foot { padding: 32px 20px 20px; }
  .bar-row { grid-template-columns: 22px 90px 1fr 68px; gap: 8px; padding: 8px 0; }
  .bar-row .label { font-size: 12px; gap: 6px; }
  .bar-row .label .flag { font-size: 14px; }
  .bar-row .val { font-size: 11px; }
  .bar-row .rank { font-size: 10px; }
  .h-section { gap: 8px; flex-wrap: wrap; }
  .eu-table th, .eu-table td { padding: 10px 8px; font-size: 12px; }
  .card-flat { padding: 16px; }
}
