
/* Editorial Alpine — design tokens (frontend-design skill) */
@import url('https://fonts.googleapis.com/css2?family=Fraunces:opsz,wght,SOFT,WONK@9..144,300..900,0..100,0..1&family=Manrope:wght@300..800&family=JetBrains+Mono:wght@400;600&display=swap');

:root{
  /* Paleta Alpine Editorial */
  --ink:#1a1612;            /* texto principal, casi negro cálido */
  --ink-mut:#5a5248;        /* texto secundario */
  --ink-soft:#8a8072;       /* texto terciario */
  --paper:#f8f3ea;          /* fondo principal crema tipo papel */
  --paper-warm:#f1e9d8;     /* fondo cálido (secciones) */
  --card:#fffdf8;           /* tarjetas */
  --line:#d9cfbc;           /* líneas finas */
  --line-soft:#ebe3d1;      /* líneas muy finas */

  --ember:#b8552b;          /* naranja térmica primario, menos saturado */
  --ember-hot:#d4692f;      /* hover */
  --ember-soft:#f4d4b8;     /* backgrounds ember */

  --forest:#2d3a2e;         /* verde bosque (acento oscuro) */
  --sky:#7fa5c7;            /* azul cielo suave */
  --ochre:#c49a4a;           /* dorado */

  /* Estados */
  --good:#557755;
  --warn:#c88a3a;
  --bad:#a44848;

  /* Compat con código anterior */
  --fg:var(--ink);
  --fg-mut:var(--ink-mut);
  --fg-soft:var(--ink-soft);
  --bg:var(--paper);
  --border:var(--line);
  --border-strong:var(--line);
  --brand:var(--ember);
  --brand2:var(--ember-hot);
  --brand-light:var(--ember-soft);
  --brand-dark:#8e3f1d;
  --link:var(--ember);

  /* Sombras suaves, editoriales */
  --shadow-sm:0 1px 2px rgba(26,22,18,0.04);
  --shadow-md:0 6px 24px rgba(26,22,18,0.08);
  --shadow-lg:0 20px 60px rgba(26,22,18,0.12);

  --radius:6px;
  --radius-lg:12px;

  /* Tipografía */
  --font-display:'Fraunces', Georgia, serif;
  --font-body:'Manrope', -apple-system, system-ui, sans-serif;
  --font-mono:'JetBrains Mono', Consolas, monospace;
}
*{box-sizing:border-box}
html{margin:0;padding:0;scroll-behavior:smooth}
body{font-family:var(--font-body);color:var(--ink);background:var(--paper);margin:0;padding:0;line-height:1.65;font-size:16.5px;font-weight:400;-webkit-font-smoothing:antialiased;letter-spacing:-0.005em}
body.home{background:var(--paper)}
body::before{content:"";position:fixed;inset:0;pointer-events:none;z-index:1;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='noiseFilter'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='3' stitchTiles='stitch'/%3E%3CfeColorMatrix values='0 0 0 0 0.1 0 0 0 0 0.08 0 0 0 0 0.06 0 0 0 0.08 0'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23noiseFilter)'/%3E%3C/svg%3E");opacity:0.5;mix-blend-mode:multiply}
main{margin:0;padding:0;position:relative;z-index:2}
.site-header,main,footer{position:relative;z-index:3}
img{max-width:100%;height:auto}
a{color:var(--ember);transition:color 0.2s ease;text-decoration:none}
a:hover{color:var(--ember-hot)}
.container{max-width:1280px;margin:0 auto;padding:24px}
.container-narrow{max-width:980px;margin:0 auto;padding:24px}
section{padding:96px 0}
section.compact{padding:48px 0}

/* Scroll reveal (CSS only) */
@keyframes rise{from{opacity:0;transform:translateY(24px)}to{opacity:1;transform:translateY(0)}}
.reveal{animation:rise 0.8s cubic-bezier(.22,.61,.36,1) both}
.reveal-1{animation-delay:0.05s}
.reveal-2{animation-delay:0.15s}
.reveal-3{animation-delay:0.25s}
.reveal-4{animation-delay:0.4s}
.reveal-5{animation-delay:0.55s}

/* Header editorial */
.site-header{background:rgba(248,243,234,0.88);backdrop-filter:blur(14px) saturate(120%);-webkit-backdrop-filter:blur(14px) saturate(120%);border-bottom:1px solid var(--line);padding:18px 0;position:sticky;top:0;z-index:50}
.site-header .bar{display:flex;align-items:center;justify-content:space-between;max-width:1280px;margin:0 auto;padding:0 32px;gap:16px}
.site-header .bar .left,.site-header .bar .right{display:flex;align-items:center;gap:32px}
.brand-link{font-family:var(--font-display);font-weight:800;color:var(--ink);text-decoration:none;font-size:22px;letter-spacing:0.5px;display:flex;align-items:center;gap:10px;font-variation-settings:"opsz" 144}
.brand-link:hover{color:var(--ember)}
.brand-link::before{content:"";width:28px;height:28px;border-radius:50%;background:radial-gradient(circle at 35% 35%,var(--ember) 0%,var(--ember-hot) 40%,var(--forest) 100%);display:inline-block;box-shadow:0 0 0 2px var(--paper),0 0 0 3px var(--line)}
.site-nav{display:flex;gap:28px;align-items:center}
.site-nav a{color:var(--ink-mut);text-decoration:none;font-size:14px;font-weight:500;padding:6px 0;border-bottom:1px solid transparent;transition:all 0.2s;letter-spacing:0.02em;position:relative}
.site-nav a:hover{color:var(--ink)}
.site-nav a::after{content:"";position:absolute;left:0;bottom:-1px;width:0;height:1px;background:var(--ember);transition:width 0.3s ease}
.site-nav a:hover::after{width:100%}
.cta-btn{background:var(--ink);color:var(--paper)!important;padding:10px 20px;border-radius:999px;text-decoration:none;font-weight:600;font-size:13px;letter-spacing:0.05em;transition:all 0.2s;box-shadow:var(--shadow-sm);border:none!important;text-transform:uppercase}
.cta-btn:hover{background:var(--ember);transform:translateY(-1px);color:var(--paper)!important}
.site-nav .lang-toggle{display:inline-flex;align-items:center;gap:6px;padding:5px 12px;border:1px solid var(--line);border-radius:999px;color:var(--ink-mut)!important;background:transparent;font-size:12px;font-weight:600;letter-spacing:0.06em;text-transform:uppercase;transition:all 0.2s;margin-left:8px}
.site-nav .lang-toggle::before{content:"";display:none}
.site-nav .lang-toggle::after{content:"↺";display:inline-block;font-size:13px;opacity:0.6}
.site-nav .lang-toggle:hover{border-color:var(--ember);color:var(--ember)!important;background:rgba(184,85,43,0.06)}
.site-nav .lang-toggle:hover::after{opacity:1;color:var(--ember)}
@media(max-width:720px){
  .site-nav{display:none}
  .site-header .bar{padding:0 16px}
  section{padding:40px 0}
}

/* Tipografía editorial */
h1,h2,h3,h4{color:var(--ink);margin:0}
h1{font-family:var(--font-display);font-size:clamp(44px,7vw,96px);font-weight:300;line-height:1.0;letter-spacing:-0.025em;font-variation-settings:"opsz" 144,"SOFT" 40}
h2{font-family:var(--font-display);font-size:clamp(32px,4vw,52px);font-weight:400;line-height:1.1;letter-spacing:-0.015em;margin:0 0 20px;padding:0;border:none;font-variation-settings:"opsz" 72}
h3{font-family:var(--font-display);font-size:clamp(22px,2.4vw,32px);font-weight:500;line-height:1.2;letter-spacing:-0.01em;font-variation-settings:"opsz" 48}
h4{font-family:var(--font-body);font-size:14px;font-weight:700;text-transform:uppercase;letter-spacing:0.12em;color:var(--ink-mut)}
p{margin:0 0 16px;line-height:1.7;color:var(--ink);font-size:17px}
.lead{font-size:clamp(19px,2vw,23px);line-height:1.5;color:var(--ink);font-weight:300;font-family:var(--font-display);font-variation-settings:"opsz" 72}

/* Eyebrow — etiqueta editorial encima de títulos */
.eyebrow{font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:0.2em;color:var(--ember);margin-bottom:16px;display:flex;align-items:center;gap:12px;font-family:var(--font-body)}
.eyebrow::before{content:"";width:32px;height:1px;background:var(--ember);display:inline-block}

/* Divisores editoriales */
.rule{border:0;border-top:1px solid var(--line);margin:48px 0}
.rule-thick{border:0;border-top:2px solid var(--ink);width:48px;margin:24px 0}

.brand-mini{font-weight:800;color:var(--brand);text-decoration:none;font-size:18px;letter-spacing:1px}

/* Controles: arriba-izquierda del hero, tamaño mínimo compacto */
.hero-controls{position:absolute;top:10px;left:10px;display:flex;flex-direction:column;align-items:flex-start;gap:4px;width:auto;min-width:110px;z-index:5}
.country-select{padding:3px 6px;border-radius:4px;border:1px solid #fff;background:#fff;color:var(--fg);font-size:9px;cursor:pointer;font-weight:600;box-shadow:0 2px 6px rgba(0,0,0,0.12);min-width:110px}
.country-select:hover,.country-select:focus{outline:none;box-shadow:0 3px 8px rgba(0,0,0,0.16)}
.menu-btn{background:#fff;color:var(--brand);text-decoration:none;padding:3px 6px;border-radius:4px;font-weight:700;font-size:9px;display:flex;align-items:center;justify-content:space-between;border:1px solid #fff;box-shadow:0 2px 6px rgba(0,0,0,0.12);cursor:pointer;letter-spacing:0.3px;min-width:110px;gap:4px}
.menu-btn:hover{box-shadow:0 3px 8px rgba(0,0,0,0.16)}
@media(max-width:720px){
  .hero-controls{top:8px;left:8px}
  .country-select,.menu-btn{font-size:9px}
}

/* Menú inline desplegable (details/summary — sin JS) */
details.inline-menu{width:100%}
details.inline-menu summary{list-style:none;cursor:pointer}
details.inline-menu summary::-webkit-details-marker{display:none}
details.inline-menu summary .chev{transition:transform 0.2s;font-size:20px}
details.inline-menu[open] summary .chev{transform:rotate(180deg)}
details.inline-menu .menu-panel{background:#fff;border:3px solid #fff;border-radius:14px;margin-top:10px;padding:10px 0;box-shadow:0 8px 24px rgba(0,0,0,0.25),0 0 0 4px rgba(255,255,255,0.3)}
details.inline-menu .menu-panel a{display:block;padding:4px 8px;color:var(--fg);text-decoration:none;font-size:9.5px;font-weight:600;border-bottom:1px solid rgba(0,0,0,0.06);white-space:nowrap}
details.inline-menu .menu-panel a:last-child{border-bottom:none}
details.inline-menu .menu-panel a:hover{background:rgba(255,107,53,0.1);color:var(--brand)}
details.inline-menu .menu-panel .sep{height:1px;background:rgba(0,0,0,0.08);margin:6px 16px}

/* Menú lateral (solo para páginas internas) */
#menu{position:fixed;top:0;right:-320px;width:300px;height:100vh;background:var(--card);box-shadow:-4px 0 20px rgba(0,0,0,0.15);z-index:100;padding:24px 20px;transition:right 0.25s;overflow-y:auto}
#menu:target{right:0}
#menu h3{margin-top:0;color:var(--brand);font-size:18px}
#menu a{display:block;padding:10px 0;color:var(--fg);text-decoration:none;border-bottom:1px solid #eee;font-size:15px}
#menu a:hover{color:var(--brand)}
#menu .close{position:absolute;top:12px;right:16px;font-size:22px;text-decoration:none;color:var(--mut)}
#menu-backdrop{display:none;position:fixed;inset:0;background:rgba(0,0,0,0.3);z-index:99}
#menu:target ~ #menu-backdrop{display:block}
nav a{color:var(--mut);text-decoration:none;margin-left:16px}
nav a:hover{color:var(--link)}
h1{font-size:clamp(28px,4vw,40px);margin:16px 0 8px}
h2{font-size:24px;margin:32px 0 12px;border-bottom:2px solid var(--brand);padding-bottom:4px}
h3{font-size:18px;margin:16px 0 8px}
/* Hero editorial asimétrico */
.hero{background:var(--paper);padding:72px 0 64px;position:relative;overflow:hidden}
.hero .container{position:relative;z-index:2}
.hero-grid{display:grid;grid-template-columns:1.3fr 1fr;gap:48px;align-items:end}
.hero-text{padding-top:32px}
.hero-title{margin:0;font-family:var(--font-display);font-weight:300;font-variation-settings:"opsz" 144,"SOFT" 30}
.hero-title .line-1{font-size:clamp(34px,5vw,58px);display:block;color:var(--ink);letter-spacing:-0.02em;line-height:1}
.hero-title .line-2{font-size:clamp(34px,5vw,58px);display:block;color:var(--ink-mut);font-style:italic;font-weight:300;line-height:1;margin-top:6px}
.hero-brand{display:block;font-family:var(--font-display);color:var(--ember);font-size:clamp(88px,14vw,180px);font-weight:200;letter-spacing:-0.04em;line-height:0.85;margin:24px 0 8px;font-variation-settings:"opsz" 144,"SOFT" 60,"WONK" 1}
.hero-tagline{font-family:var(--font-display);font-weight:300;font-size:clamp(18px,1.8vw,22px);color:var(--ink-mut);line-height:1.45;max-width:540px;margin:28px 0 0;font-variation-settings:"opsz" 72}
.hero-ctas{display:flex;gap:12px;margin-top:40px;flex-wrap:wrap}
.btn-primary{background:var(--ink);color:var(--paper);text-decoration:none;padding:14px 28px;border-radius:999px;font-weight:600;font-size:14px;display:inline-flex;align-items:center;gap:8px;transition:all 0.25s;border:none;cursor:pointer;letter-spacing:0.04em;text-transform:uppercase}
.btn-primary:hover{background:var(--ember);color:var(--paper);transform:translateY(-2px);box-shadow:0 12px 24px rgba(184,85,43,0.25)}
.btn-ghost{background:transparent;color:var(--ink);text-decoration:none;padding:14px 28px;border-radius:999px;font-weight:600;font-size:14px;display:inline-flex;align-items:center;gap:8px;border:1.5px solid var(--ink);transition:all 0.25s;letter-spacing:0.04em;text-transform:uppercase}
.btn-ghost:hover{background:var(--ink);color:var(--paper)}

.hero-visual{position:relative;max-width:720px;margin-left:auto;margin-right:-24px}
.hero-photo{width:100%;display:block;border-radius:2px;box-shadow:0 32px 64px rgba(26,22,18,0.22),0 8px 16px rgba(26,22,18,0.1);aspect-ratio:1600/902;object-fit:cover}
.hero-illust{width:100%;display:block;filter:drop-shadow(0 24px 48px rgba(26,22,18,0.18))}
.hero-caption{font-family:var(--font-body);font-size:11px;color:var(--ink-soft);letter-spacing:0.1em;text-transform:uppercase;margin-top:14px;text-align:right;display:flex;justify-content:flex-end;align-items:center;gap:12px}
.hero-caption::before{content:"";width:24px;height:1px;background:var(--ink-soft)}
.hero-caption a{color:var(--ink-soft);text-decoration:underline;text-decoration-color:var(--line);text-underline-offset:3px}
.hero-caption a:hover{color:var(--ember);text-decoration-color:var(--ember)}

@media(max-width:900px){
  .hero-grid{grid-template-columns:1fr;gap:32px}
  .hero-visual{max-width:560px;margin:0 auto}
  .hero-caption{text-align:center;justify-content:center}
}

/* Stats editoriales tipo revista */
.stats-band{border-top:1px solid var(--line);border-bottom:1px solid var(--line);padding:32px 0;margin-top:56px}
.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:0}
.stat{padding:0 32px;border-right:1px solid var(--line-soft);text-align:left}
.stat:last-child{border-right:none}
.stat:first-child{padding-left:0}
.stat-value{font-family:var(--font-display);font-size:clamp(36px,4vw,56px);font-weight:300;color:var(--ink);line-height:1;letter-spacing:-0.02em;font-variation-settings:"opsz" 144}
.stat-label{font-size:11px;color:var(--ink-mut);margin-top:10px;text-transform:uppercase;letter-spacing:0.18em;font-weight:600}
@media(max-width:720px){
  .stats{grid-template-columns:repeat(2,1fr);gap:24px 0}
  .stat{padding:16px;border:none}
}

/* Secciones editoriales */
section.bg-white{background:var(--card)}
section.bg-cream{background:var(--paper-warm)}
section.bg-ink{background:var(--ink);color:var(--paper)}
section.bg-ink h2,section.bg-ink h3{color:var(--paper)}
section.bg-ink p{color:rgba(248,243,234,0.75)}

/* Section header editorial */
.section-header{display:grid;grid-template-columns:1fr 2fr;gap:48px;margin-bottom:64px;align-items:start}
.section-header .meta{padding-top:6px}
.section-header .meta .eyebrow{margin-bottom:0}
.section-header .content h2{margin:0 0 16px}
.section-header .content p{font-size:20px;color:var(--ink-mut);max-width:640px;margin:0;line-height:1.5;font-family:var(--font-display);font-weight:300;font-variation-settings:"opsz" 72}
@media(max-width:720px){
  .section-header{grid-template-columns:1fr;gap:12px}
}

/* Countries grid editorial */
.countries-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:1px;background:var(--line);border:1px solid var(--line)}
.country-card{background:var(--card);padding:24px 20px;text-decoration:none;color:var(--ink);transition:all 0.3s ease;display:flex;align-items:center;gap:16px;position:relative}
.country-card:hover{background:var(--paper-warm);color:var(--ink)}
.country-card:hover .name{color:var(--ember)}
.country-card .flag{font-size:36px;line-height:1;filter:saturate(0.85)}
.country-card .info{flex:1;min-width:0}
.country-card .name{font-family:var(--font-display);font-weight:500;font-size:18px;margin:0 0 2px;letter-spacing:-0.01em;transition:color 0.2s;font-variation-settings:"opsz" 48}
.country-card .count{font-size:13px;color:var(--ink-mut);font-variant-numeric:tabular-nums}
.country-card::after{content:"→";position:absolute;right:20px;top:50%;transform:translateY(-50%);color:var(--ink-soft);opacity:0;transition:all 0.2s}
.country-card:hover::after{opacity:1;transform:translateY(-50%) translateX(4px);color:var(--ember)}

/* Site cards editoriales estilo "dispatch" */
.sites-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:32px 28px}
.site-card{background:transparent;border:none;text-decoration:none;color:var(--ink);transition:all 0.3s ease;display:flex;flex-direction:column;position:relative;padding-top:16px;border-top:1px solid var(--ink)}
.site-card:hover{color:var(--ink);transform:translateY(-2px)}
.site-card:hover .site-card-body h3{color:var(--ember)}
.site-card-header{padding:0 0 12px;display:flex;align-items:center;justify-content:space-between;gap:12px}
.site-card-header .flag-row{display:flex;align-items:center;gap:8px}
.site-card-header .flag{font-size:18px;filter:saturate(0.85)}
.site-card-header .site-country{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:0.14em;color:var(--ink-mut)}
.site-card-header .score-badge{background:transparent;color:var(--ember);padding:0;border-radius:0;font-weight:700;font-size:13px;font-family:var(--font-mono);letter-spacing:0.02em}
.site-card-header .score-badge::before{content:"SCORE ";opacity:0.5;font-weight:500;font-size:10px;letter-spacing:0.1em}
.site-card-body{padding:6px 0 0;flex:1;display:flex;flex-direction:column;gap:10px}
.site-card-body h3{font-family:var(--font-display);font-size:26px;margin:0;color:var(--ink);line-height:1.1;letter-spacing:-0.015em;font-weight:400;transition:color 0.2s;font-variation-settings:"opsz" 48}
.site-card-body .site-meta{font-size:12px;color:var(--ink-mut);display:flex;gap:16px;text-transform:uppercase;letter-spacing:0.08em;font-weight:500}
.site-card-body .meta-item{display:flex;align-items:center;gap:4px}
.site-card-body .site-location{font-size:14px;color:var(--ink-mut);margin:0;font-style:italic;font-family:var(--font-display);font-weight:400;font-variation-settings:"opsz" 24}

/* Region sections editoriales */
.region-section{margin:56px 0}
.region-header{display:flex;align-items:baseline;justify-content:space-between;gap:12px;padding:20px 0 16px;border-bottom:1px solid var(--ink);margin-bottom:32px}
.region-header h3{margin:0;font-family:var(--font-display);font-size:clamp(28px,3vw,40px);color:var(--ink);display:flex;align-items:baseline;gap:14px;font-weight:400;letter-spacing:-0.015em;font-variation-settings:"opsz" 72}
.region-header .region-flag{font-size:18px;opacity:0.7}
.region-header .region-count{color:var(--ink-soft);font-size:12px;text-transform:uppercase;letter-spacing:0.14em;font-weight:600;font-family:var(--font-body)}

/* Features editoriales */
.features{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:48px 40px}
.feature{padding:0;text-align:left;position:relative}
.feature .feature-num{font-family:var(--font-display);font-size:40px;font-weight:300;color:var(--ember);line-height:1;margin-bottom:8px;font-variation-settings:"opsz" 144}
.feature-icon{display:none}
.feature h3{font-family:var(--font-display);font-size:22px;margin:0 0 12px;font-weight:500;letter-spacing:-0.01em;font-variation-settings:"opsz" 48}
.feature p{font-size:15px;color:var(--ink-mut);margin:0;line-height:1.65}
.feature .feature-divider{width:32px;height:1px;background:var(--line);margin:16px 0}

/* Footer editorial oscuro */
footer{background:var(--ink);color:rgba(248,243,234,0.7);padding:80px 0 32px;margin-top:120px;position:relative}
footer::before{content:"";position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,var(--ember),transparent)}
footer .footer-grid{display:grid;grid-template-columns:1.5fr 1fr 1fr 1fr;gap:48px;max-width:1280px;margin:0 auto;padding:0 32px}
footer .footer-brand{font-family:var(--font-display);font-size:32px;font-weight:300;color:var(--paper);margin:0 0 16px;letter-spacing:-0.02em;font-variation-settings:"opsz" 144}
footer h4{font-family:var(--font-body);color:var(--paper);font-size:11px;margin:0 0 16px;text-transform:uppercase;letter-spacing:0.18em;font-weight:700}
footer a{color:rgba(248,243,234,0.7);text-decoration:none;display:block;padding:6px 0;font-size:14px;transition:color 0.2s}
footer a:hover{color:var(--ember)}
footer .footer-bottom{border-top:1px solid rgba(248,243,234,0.15);padding:24px 32px 0;margin-top:56px;font-size:12px;color:rgba(248,243,234,0.45);text-align:left;max-width:1280px;margin-left:auto;margin-right:auto;display:flex;justify-content:space-between;gap:16px;flex-wrap:wrap}
footer .footer-bottom p{margin:0;color:inherit;font-size:12px}
@media(max-width:900px){
  footer .footer-grid{grid-template-columns:1fr 1fr;gap:32px}
}
@media(max-width:600px){
  footer .footer-grid{grid-template-columns:1fr;gap:32px}
}

/* Old placeholder keeps existing pages working */
header.internal{background:var(--card);border-bottom:1px solid #e5e5e5;padding:10px 0;position:sticky;top:0;z-index:10}
header.internal .bar{display:flex;align-items:center;max-width:1080px;margin:0 auto;padding:0 16px;gap:10px}
header.internal .bar .left{display:flex;align-items:center;gap:10px;flex:1}
header.internal .bar .right{display:flex;align-items:center}

.hero-content{display:flex;flex-direction:column;align-items:center;justify-content:flex-start;text-align:center;width:100%;padding:60px 24px 40px 24px}
.hero h1{color:#fff;font-size:clamp(34px,6vw,64px);margin:0;font-weight:300;letter-spacing:0.5px;text-shadow:0 2px 8px rgba(0,0,0,0.25)}
.hero h2.subtitle{color:#fff;font-weight:600;font-size:clamp(20px,3vw,32px);letter-spacing:3px;margin:10px 0 0;text-shadow:0 1px 4px rgba(0,0,0,0.2)}
.hero .tagline{font-size:14px;color:#444;max-width:520px;margin:16px auto 0}
.hero-illust{width:100%;max-width:820px;margin:40px auto 0;display:block;filter:drop-shadow(0 8px 20px rgba(0,0,0,0.15))}
@media(max-width:720px){
  .hero-content{padding-top:340px}
  .hero h1{font-size:clamp(26px,7vw,40px)}
  .hero h2.subtitle{font-size:clamp(18px,4vw,22px);letter-spacing:2px}
}
.btn{display:inline-block;background:var(--card);color:var(--brand);padding:10px 20px;border-radius:6px;text-decoration:none;font-weight:600;margin-top:16px}
details.country-accordion{background:var(--card);border:1px solid #e5e5e5;border-radius:8px;margin:8px 0;padding:0}
details.country-accordion summary{padding:12px 16px;cursor:pointer;font-weight:600;display:flex;justify-content:space-between;align-items:center;list-style:none}
details.country-accordion summary::-webkit-details-marker{display:none}
details.country-accordion summary::after{content:"▼";font-size:12px;color:var(--mut)}
details.country-accordion[open] summary::after{content:"▲"}
details.country-accordion summary:hover{background:#f9f9f9}
details.country-accordion .sites-list{padding:4px 16px 12px;border-top:1px solid #eee}
details.country-accordion .sites-list a{display:flex;justify-content:space-between;padding:8px 0;color:var(--fg);text-decoration:none;border-bottom:1px solid #f5f5f5}
details.country-accordion .sites-list a:hover{color:var(--brand)}
details.country-accordion .sites-list a:last-child{border-bottom:none}
.site-name{flex:1}
.site-meta{color:var(--mut);font-size:13px;margin-right:8px}
.grid{display:grid;gap:12px;grid-template-columns:repeat(auto-fill,minmax(260px,1fr))}
.card{background:var(--card);border:1px solid #e5e5e5;border-radius:8px;padding:16px;text-decoration:none;color:var(--fg);transition:transform .1s}
.card:hover{transform:translateY(-2px);border-color:var(--brand)}
.card h3{margin:0 0 6px}
.card .meta{font-size:13px;color:var(--mut)}
.score{display:inline-block;background:var(--brand);color:#fff;padding:2px 8px;border-radius:4px;font-weight:600;font-size:13px}
.badges{display:flex;gap:6px;flex-wrap:wrap;margin-top:8px}
.badge{font-size:11px;padding:2px 6px;border-radius:3px;background:#eef2f7;color:var(--mut)}
.ori{display:inline-block;width:24px;height:24px;border-radius:4px;margin:2px;text-align:center;line-height:24px;font-size:11px;font-weight:600}
.ori-0{background:#f5f5f5;color:#999}
.ori-1{background:#ffe08a}
.ori-2{background:#9fd396;color:#fff}
.breadcrumb{font-size:13px;color:var(--mut);margin:8px 0}
.breadcrumb a{color:var(--mut);text-decoration:none}
footer{background:#222;color:#aaa;padding:24px 0;margin-top:48px;font-size:13px;text-align:center}
footer a{color:#ddd}
table{width:100%;border-collapse:collapse;margin:16px 0}
th,td{padding:8px;text-align:left;border-bottom:1px solid #e5e5e5}
th{background:#f5f5f5}
.disclaimer{font-size:12px;color:var(--mut);background:#fff8e1;padding:12px;border-radius:6px;margin:16px 0}
