:root {
  --bg: #08080a;
  --bg-raised: #0f1013;
  --bg-card: #0c0d10;
  --bg-input: #111216;
  --line: #1d1e22;
  --line-light: #252730;
  --ink: #e6e3db;
  --ink-dim: #8e8a80;
  --ink-faint: #5a5750;
  --accent: #d8c9a3;
  --accent-strong: #f1d6a1;
  --blood: #7a1c1c;
  --blood-glow: #a82828;
  --cope-lucid: #2dd4a8;
  --cope-partial: #6bcc5e;
  --cope-moderate: #e6b422;
  --cope-heavy: #e87722;
  --cope-terminal: #e83030;
  --mono: "JetBrains Mono", ui-monospace, SFMono-Regular, Consolas, monospace;
  --serif: "Cormorant Garamond", "Cormorant", Georgia, serif;
}

* { box-sizing: border-box; }
html, body {
  margin: 0; padding: 0;
  background: var(--bg); color: var(--ink);
  font-family: var(--serif); font-size: 18px; line-height: 1.55;
  -webkit-font-smoothing: antialiased;
}
body::before {
  content: ""; position: fixed; inset: 0; pointer-events: none;
  background: radial-gradient(circle at 20% 10%, rgba(255,255,255,0.015), transparent 55%),
    repeating-linear-gradient(0deg, rgba(255,255,255,0.006) 0 1px, transparent 1px 3px);
  mix-blend-mode: overlay; z-index: 0;
}
.wrap { max-width: 960px; margin: 0 auto; padding: 0 22px; position: relative; z-index: 1; }
a { color: var(--accent); text-decoration: none; border-bottom: 1px solid transparent; transition: color .15s, border-color .15s; }
a:hover { color: var(--accent-strong); border-bottom-color: var(--accent-strong); }

/* HEAD */
.site-head { border-bottom: 1px solid var(--line); padding: 22px 0 18px; background: linear-gradient(180deg, #0a0a0c 0%, var(--bg) 100%); position: relative; z-index: 100; }
.site-head .wrap { display: flex; align-items: baseline; justify-content: space-between; gap: 20px; flex-wrap: wrap; position: relative; }
.brand { font-family: var(--serif); font-weight: 700; font-size: 28px; letter-spacing: -0.01em; color: var(--ink); border: none; }
.brand-mark { color: var(--ink); }
.brand-mark.accent { color: var(--accent); font-style: italic; }
.nav { display: flex; gap: 22px; }
.nav a { font-family: var(--mono); font-size: 11px; letter-spacing: 0.18em; text-transform: uppercase; color: var(--ink-dim); border: none; }
.nav a:hover { color: var(--accent); }

/* MAIN / HERO */
.main { padding: 48px 22px 80px; }
.hero { border-bottom: 1px solid var(--line); padding-bottom: 32px; margin-bottom: 40px; }
.hero h1 { font-family: var(--serif); font-size: clamp(48px, 8vw, 84px); line-height: 0.95; letter-spacing: -0.025em; font-weight: 700; margin: 0 0 16px; }
.hero h1 em { font-style: italic; color: var(--accent); }
.tagline { font-size: 20px; color: var(--ink-dim); max-width: 640px; font-style: italic; margin: 0 0 14px; }
.meter { font-family: var(--mono); font-size: 11px; letter-spacing: 0.25em; text-transform: uppercase; color: var(--ink-dim); margin: 0; }
.section-label { font-family: var(--mono); font-size: 11px; letter-spacing: 0.3em; text-transform: uppercase; color: var(--ink-dim); border-bottom: 1px solid var(--line); padding-bottom: 10px; margin: 0 0 24px; }

/* LEADERBOARD */
.leaderboard { margin-bottom: 64px; }
.lb-grid { display: flex; flex-direction: column; gap: 2px; }
.lb-card { display: grid; grid-template-columns: 42px 64px 1fr auto; gap: 16px; align-items: center; padding: 16px 18px; background: var(--bg-card); border: 1px solid var(--line); border-radius: 4px; text-decoration: none; color: var(--ink); transition: background .15s, border-color .15s; }
.lb-card:hover { background: var(--bg-raised); border-color: var(--line-light); border-bottom-color: var(--line-light); color: var(--ink); }
.lb-rank { font-family: var(--mono); font-size: 13px; font-weight: 700; color: var(--ink-dim); text-align: center; }
.lb-avatar { width: 56px; height: 56px; border-radius: 4px; overflow: hidden; border: 2px solid var(--line); flex-shrink: 0; }
.lb-avatar-placeholder { width: 100%; height: 100%; background: var(--bg-raised); display: flex; align-items: center; justify-content: center; font-family: var(--serif); font-size: 28px; font-weight: 700; color: var(--ink-dim); }
.flag-placeholder { font-size: 32px; }
.lb-info { min-width: 0; }
.lb-name { font-family: var(--serif); font-size: 22px; font-weight: 700; line-height: 1.2; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.lb-title { font-family: var(--mono); font-size: 11px; color: var(--ink-dim); letter-spacing: 0.05em; margin-top: 2px; }
.lb-cope-type { font-family: var(--mono); font-size: 10px; color: var(--accent); letter-spacing: 0.1em; text-transform: uppercase; margin-top: 4px; }
.lb-description { font-size: 13px; color: var(--ink-dim); line-height: 1.5; margin-top: 6px; display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden; }
.lb-score-block { text-align: center; min-width: 80px; }
.lb-score { font-family: var(--mono); font-size: 36px; font-weight: 700; line-height: 1; }
.lb-label { font-family: var(--mono); font-size: 9px; letter-spacing: 0.2em; text-transform: uppercase; margin-top: 4px; color: var(--ink-dim); }
.lb-quotes-count { font-family: var(--mono); font-size: 9px; color: var(--ink-faint); margin-top: 4px; }

/* Cope color classes */
.cope-lucid .lb-score, .cope-lucid .big-score, .cope-lucid .breakdown-score { color: var(--cope-lucid); }
.cope-partial .lb-score, .cope-partial .big-score, .cope-partial .breakdown-score { color: var(--cope-partial); }
.cope-moderate .lb-score, .cope-moderate .big-score, .cope-moderate .breakdown-score { color: var(--cope-moderate); }
.cope-heavy .lb-score, .cope-heavy .big-score, .cope-heavy .breakdown-score { color: var(--cope-heavy); }
.cope-terminal .lb-score, .cope-terminal .big-score, .cope-terminal .breakdown-score { color: var(--cope-terminal); }
.cope-lucid { border-left: 3px solid var(--cope-lucid); }
.cope-partial { border-left: 3px solid var(--cope-partial); }
.cope-moderate { border-left: 3px solid var(--cope-moderate); }
.cope-heavy { border-left: 3px solid var(--cope-heavy); }
.cope-terminal { border-left: 3px solid var(--cope-terminal); }

/* FIGURE/COUNTRY PAGE */
.figure-page { padding-top: 20px; }
.crumbs { font-family: var(--mono); font-size: 11px; letter-spacing: 0.2em; text-transform: uppercase; margin: 0 0 40px; }
.crumbs a { color: var(--ink-dim); border: none; }
.crumbs a:hover { color: var(--accent); }
.figure-header { display: grid; grid-template-columns: 120px 1fr auto; gap: 24px; align-items: start; padding-bottom: 30px; margin-bottom: 30px; border-bottom: 1px solid var(--line); }
.figure-mugshot { width: 120px; height: 140px; border-radius: 4px; overflow: hidden; border: 2px solid var(--line); }
.figure-placeholder { width: 100%; height: 100%; background: var(--bg-raised); display: flex; align-items: center; justify-content: center; font-size: 64px; }
.figure-info h1 { font-family: var(--serif); font-size: clamp(28px, 5vw, 40px); line-height: 1.1; font-weight: 700; margin: 0 0 6px; }
.figure-title { font-family: var(--mono); font-size: 13px; color: var(--ink-dim); }
.figure-category { font-family: var(--mono); font-size: 10px; letter-spacing: 0.2em; text-transform: uppercase; color: var(--accent); margin-top: 4px; }
.figure-bias { font-family: var(--mono); font-size: 12px; color: var(--ink-faint); font-style: italic; margin-top: 12px; padding-left: 12px; border-left: 2px solid var(--blood); }
.figure-score-card { text-align: center; padding: 16px 24px; background: var(--bg-card); border: 1px solid var(--line); border-radius: 4px; min-width: 120px; }
.big-score { font-family: var(--mono); font-size: 56px; font-weight: 700; line-height: 1; }
.score-label { font-family: var(--mono); font-size: 10px; letter-spacing: 0.2em; text-transform: uppercase; margin-top: 6px; color: var(--ink-dim); }

/* SCORE BREAKDOWN */
.score-breakdown { margin-bottom: 40px; }
.breakdown-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 12px; }
.breakdown-card { background: var(--bg-card); border: 1px solid var(--line); border-radius: 4px; padding: 20px; text-align: center; }
.breakdown-score { font-family: var(--mono); font-size: 42px; font-weight: 700; line-height: 1; }
.breakdown-label { font-family: var(--mono); font-size: 11px; letter-spacing: 0.2em; text-transform: uppercase; color: var(--ink-dim); margin-top: 8px; }
.breakdown-desc { font-family: var(--mono); font-size: 10px; color: var(--ink-faint); margin-top: 6px; }

/* SECTORS */
.country-sectors { margin-bottom: 40px; }
.sectors-list { display: flex; flex-wrap: wrap; gap: 8px; }
.sector-tag { font-family: var(--mono); font-size: 11px; letter-spacing: 0.1em; padding: 6px 14px; background: var(--bg-card); border: 1px solid var(--line); border-radius: 3px; color: var(--accent); }

/* POLICY */
.policy-section { margin-bottom: 40px; }

/* QUOTES */
.quotes-section { margin-bottom: 40px; }
.cope-entry { background: var(--bg-card); border: 1px solid var(--line); border-radius: 4px; padding: 16px 18px; margin-bottom: 8px; }
.cope-entry-quote { font-family: var(--mono); font-size: 13px; color: var(--ink); font-style: italic; border-left: 2px solid var(--blood); padding-left: 14px; margin: 8px 0; line-height: 1.5; }
.cope-entry-source { font-family: var(--mono); font-size: 10px; color: var(--ink-faint); margin-top: 8px; }

/* VERDICT BODY (for about/policy text) */
.verdict-body { font-family: var(--mono); font-size: 14px; line-height: 1.72; color: #d6d2c6; }
.verdict-body h2 { font-family: var(--serif); color: var(--ink); font-size: 22px; letter-spacing: -0.01em; line-height: 1.2; margin: 30px 0 12px; font-weight: 700; }
.verdict-body h3 { font-family: var(--serif); color: var(--accent); font-size: 18px; letter-spacing: -0.01em; line-height: 1.2; margin: 24px 0 10px; font-weight: 700; }
.verdict-body p { margin: 0 0 14px; }
.verdict-body strong { color: var(--accent-strong); font-weight: 600; }
.verdict-body code { font-family: var(--mono); background: var(--bg-raised); padding: 2px 6px; font-size: 0.9em; border: 1px solid var(--line); }
.verdict-body hr { border: none; border-top: 1px solid var(--line); margin: 30px 0; }
.verdict-foot { margin-top: 50px; border-top: 1px solid var(--line); padding-top: 18px; }
.stamp { font-family: var(--mono); font-size: 11px; letter-spacing: 0.2em; text-transform: uppercase; color: var(--ink-dim); margin: 0; }

/* DIMENSIONS GRID (homepage) */
.scoring-breakdown { margin-bottom: 64px; }
.dimensions-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 16px; }
.dimension-card { background: var(--bg-card); border: 1px solid var(--line); border-radius: 4px; padding: 24px; }
.dimension-card .dim-icon { font-size: 32px; margin-bottom: 12px; }
.dimension-card h3 { font-family: var(--serif); font-size: 20px; margin: 0 0 8px; color: var(--accent); }
.dimension-card p { font-family: var(--mono); font-size: 12px; color: var(--ink-dim); line-height: 1.6; margin: 0; }

/* FOOTER */
.site-foot { border-top: 1px solid var(--line); padding: 36px 0 48px; margin-top: 80px; background: var(--bg); }
.epitaph { font-style: italic; color: var(--ink-dim); max-width: 640px; margin: 0 0 14px; font-size: 15px; line-height: 1.6; }
.colophon { font-family: var(--mono); font-size: 11px; letter-spacing: 0.2em; text-transform: uppercase; color: var(--ink-dim); margin: 0; }

/* ABOUT */
.about-page .verdict-body p { margin-bottom: 18px; }
.about-link { margin-top: 30px; }
.about-link a { font-family: var(--mono); font-size: 11px; letter-spacing: 0.15em; text-transform: uppercase; color: var(--ink-dim); }
.about-link a:hover { color: var(--accent); }

/* EMPTY STATE */
.empty { color: var(--ink-dim); font-style: italic; text-align: center; padding: 60px 0; }

/* HAMBURGER / MOBILE NAV */
.nav-toggle {
  display: none; background: none; border: none;
  cursor: pointer; padding: 8px; z-index: 1001;
}
.hamburger {
  display: block; width: 22px; height: 2px;
  background: var(--ink-dim); position: relative; transition: background .2s;
}
.hamburger::before, .hamburger::after {
  content: ""; position: absolute; left: 0; width: 22px; height: 2px;
  background: var(--ink-dim); transition: transform .25s ease, top .25s ease;
}
.hamburger::before { top: -7px; }
.hamburger::after { top: 7px; }
.nav-toggle[aria-expanded="true"] .hamburger { background: transparent; }
.nav-toggle[aria-expanded="true"] .hamburger::before { top: 0; transform: rotate(45deg); background: var(--accent); }
.nav-toggle[aria-expanded="true"] .hamburger::after { top: 0; transform: rotate(-45deg); background: var(--accent); }

@media (max-width: 768px) {
  .nav-toggle { display: block; }
  .nav {
    display: flex; flex-direction: column; position: absolute;
    top: 100%; left: 0; right: 0; background: #0f1013;
    border-bottom: 1px solid var(--line); padding: 0 22px;
    max-height: 0; overflow: hidden; transition: max-height .3s ease, padding .3s ease;
    z-index: 1000; gap: 0;
  }
  .nav.nav-open { max-height: 500px; padding: 16px 22px; }
  .nav a { padding: 12px 0; border-bottom: 1px solid var(--line); font-size: 13px; letter-spacing: 0.12em; }
  .nav a:last-child { border-bottom: none; }
  .site-head .wrap { position: relative; }
  .lb-card { grid-template-columns: 32px 48px 1fr; gap: 10px; padding: 12px 14px; }
  .lb-avatar { width: 48px; height: 48px; }
  .lb-name { font-size: 18px; }
  .lb-score-block { grid-column: 1 / -1; display: flex; align-items: center; gap: 12px; text-align: left; }
  .lb-score { font-size: 28px; }
  .lb-description { display: none; }
  .figure-header { grid-template-columns: 80px 1fr; gap: 16px; }
  .figure-mugshot { width: 80px; height: 100px; }
  .figure-score-card { grid-column: 1 / -1; }
  .figure-info h1 { font-size: 26px; }
  .big-score { font-size: 42px; }
  .breakdown-grid { grid-template-columns: 1fr; }
  .dimensions-grid { grid-template-columns: 1fr; }
  .colophon { line-height: 2.2; }
}
@media (max-width: 480px) {
  body { font-size: 16px; }
  .main { padding: 28px 0 50px; }
  .hero { padding-bottom: 22px; margin-bottom: 28px; }
  .brand { font-size: 22px; }
  .lb-card { padding: 10px 12px; }
}

/* ============================================
   SCREWED SCORE STYLES
   ============================================ */
:root {
  --screwed-low: #2dd4a8;
  --screwed-moderate: #e6b422;
  --screwed-high: #e87722;
  --screwed-terminal: #e83030;
}

.lb-screwed {
  font-family: var(--mono);
  font-size: 10px;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  margin-top: 6px;
  padding: 3px 8px;
  border-radius: 3px;
  background: rgba(232, 48, 48, 0.1);
  display: inline-block;
}
.screwed-icon { font-style: normal; }
.screwed-low { color: var(--screwed-low); background: rgba(45, 212, 168, 0.1); }
.screwed-moderate { color: var(--screwed-moderate); background: rgba(230, 180, 34, 0.1); }
.screwed-high { color: var(--screwed-high); background: rgba(232, 119, 34, 0.1); }
.screwed-terminal { color: var(--screwed-terminal); background: rgba(232, 48, 48, 0.15); }

.screwed-card { border-left: 3px solid var(--screwed-terminal) !important; }
.screwed-card .breakdown-score { color: var(--screwed-terminal); }
.screwed-low .breakdown-score { color: var(--screwed-low); }
.screwed-moderate .breakdown-score { color: var(--screwed-moderate); }
.screwed-high .breakdown-score { color: var(--screwed-high); }

.breakdown-grid { grid-template-columns: repeat(4, 1fr); }
@media (max-width: 768px) { .breakdown-grid { grid-template-columns: 1fr 1fr; } }
@media (max-width: 480px) { .breakdown-grid { grid-template-columns: 1fr; } }

.dimensions-grid { grid-template-columns: repeat(4, 1fr); }
@media (max-width: 768px) { .dimensions-grid { grid-template-columns: 1fr 1fr; } }
@media (max-width: 480px) { .dimensions-grid { grid-template-columns: 1fr; } }

/* ============================================
   SCORE FORM + RESULT STYLES
   ============================================ */
.score-form-section { max-width: 560px; margin: 0 auto 64px; }
.score-form { background: var(--bg-card); border: 1px solid var(--line); border-radius: 4px; padding: 32px; }
.form-group { margin-bottom: 20px; }
.form-group label {
  display: block; font-family: var(--mono); font-size: 11px;
  letter-spacing: 0.2em; text-transform: uppercase; color: var(--ink-dim);
  margin-bottom: 8px;
}
.form-group input {
  width: 100%; padding: 12px 16px; background: var(--bg-input);
  border: 1px solid var(--line); border-radius: 3px; color: var(--ink);
  font-family: var(--mono); font-size: 14px; outline: none; transition: border-color .15s;
}
.form-group input:focus { border-color: var(--accent); }
.captcha-group { max-width: 200px; }
.submit-btn {
  width: 100%; padding: 14px; background: var(--accent); color: var(--bg);
  border: none; border-radius: 3px; font-family: var(--mono); font-size: 12px;
  letter-spacing: 0.15em; text-transform: uppercase; cursor: pointer;
  font-weight: 700; transition: background .15s;
}
.submit-btn:hover { background: var(--accent-strong); }
.submit-btn:disabled { opacity: 0.5; cursor: not-allowed; }
.score-status {
  font-family: var(--mono); font-size: 12px; color: var(--ink-dim);
  margin-top: 16px; text-align: center;
}
.score-status.loading { color: var(--accent); }
.score-status.error { color: var(--cope-terminal); }
.score-status.success { color: var(--cope-lucid); }

.score-result { margin-top: 32px; }
.result-card {
  background: var(--bg-card); border: 1px solid var(--line);
  border-radius: 4px; padding: 24px; text-align: center;
}
.result-name { font-family: var(--serif); font-size: 28px; font-weight: 700; margin-bottom: 8px; }
.result-desc { font-family: var(--mono); font-size: 12px; color: var(--ink-dim); font-style: italic; margin-bottom: 16px; }
.result-scores { display: flex; gap: 16px; justify-content: center; margin-bottom: 12px; }
.result-cope {
  font-family: var(--mono); font-size: 14px; font-weight: 700;
  padding: 6px 14px; background: rgba(232, 119, 34, 0.15);
  border-radius: 3px; color: var(--cope-heavy);
}
.result-screwed {
  font-family: var(--mono); font-size: 14px; font-weight: 700;
  padding: 6px 14px; background: rgba(232, 48, 48, 0.15);
  border-radius: 3px; color: var(--cope-terminal);
}
.result-breakdown { font-family: var(--mono); font-size: 11px; color: var(--ink-dim); margin-bottom: 16px; }
.result-link {
  font-family: var(--mono); font-size: 11px; letter-spacing: 0.15em;
  text-transform: uppercase; color: var(--accent);
}

/* CTA */
.cta-section { text-align: center; margin-bottom: 64px; }
.cta-link { font-family: var(--mono); font-size: 13px; letter-spacing: 0.1em; color: var(--accent); }

/* Screwed verdict explanation */
.lb-screwed-verdict {
  font-size: 0.75rem;
  color: rgba(255, 107, 107, 0.6);
  font-style: italic;
  line-height: 1.4;
  margin-top: 0.3rem;
  text-align: right;
}

/* Screwed why explanation on detail page */
.screwed-why {
  font-size: 0.78rem;
  color: rgba(255, 107, 107, 0.55);
  font-style: italic;
  line-height: 1.45;
  margin-top: 0.5rem;
  padding-top: 0.5rem;
  border-top: 1px solid rgba(255, 107, 107, 0.15);
}


/* === Agent-friendly interactivity === */
a, button, [role="button"], input[type="submit"], input[type="button"],
.nav-toggle, .copy-btn, [onclick] {
  cursor: pointer;
}
button, a, input, select, textarea {
  min-height: 8px;
  min-width: 8px;
}
.skip-link {
  position: absolute;
  top: -100%;
  left: 0;
  background: #000;
  color: #fff;
  padding: 8px 16px;
  z-index: 10000;
  font-size: 0.9rem;
  text-decoration: none;
}
.skip-link:focus {
  top: 0;
}


/* ── Pagination ─────────────────────────────────────────── */
.pagination{text-align:center;margin:2rem 0 1rem;}
.pagination-wrap{display:inline-flex;align-items:center;gap:0.3rem;flex-wrap:wrap;justify-content:center;}
.page-link{display:inline-flex;align-items:center;justify-content:center;
  min-width:2.2rem;height:2.2rem;padding:0 0.6rem;
  font-family:'JetBrains Mono',monospace;font-size:0.85rem;
  background:rgba(255,255,255,0.04);border:1px solid rgba(255,255,255,0.1);
  border-radius:6px;color:#8a8d96;text-decoration:none;transition:all .2s;}
.page-link:hover:not(.disabled):not(.current){background:rgba(255,255,255,0.1);color:#c5c7ce;border-color:rgba(255,255,255,0.2);}
.page-link.current{background:rgba(42,157,143,0.2);border-color:rgba(42,157,143,0.4);color:#2a9d8f;font-weight:700;}
.page-link.disabled{opacity:0.3;cursor:default;pointer-events:none;}
.page-ellipsis{color:#555;padding:0 0.2rem;}
.page-link.prev,.page-link.next{padding:0 0.8rem;font-size:0.8rem;}
