/* =====================================================================
   Spanish TV Abroad — Homepage design system  "Broadcast at night"
   Dark, cinematic. Amber broadcast glow = home; midnight = abroad.
   Display: Bricolage Grotesque · Body: Hanken Grotesk · Data: Space Mono
   ===================================================================== */

:root {
  --ink:    #0B0F1D;   /* midnight base — abroad, at night */
  --ink-2:  #121829;   /* raised surfaces / panels */
  --ink-3:  #1A2238;   /* hairlines / borders on dark */
  --glow:   #F2B441;   /* broadcast amber — home, TV light, warmth */
  --glow-2: #FFD27A;   /* lighter amber for highlights */
  --ember:  #FF5343;   /* EN DIRECTO live signal — used sparingly */
  --paper:  #F4EFE3;   /* warm off-white — the light a TV throws */
  --mute:   #8B93AC;   /* secondary text on dark */
  --mute-2: #58607A;   /* faint text / captions */

  --radius: 16px;
  --max: 1160px;
  --display: "Bricolage Grotesque", "Hanken Grotesk", sans-serif;
  --body: "Hanken Grotesk", system-ui, sans-serif;
  --mono: "Space Mono", ui-monospace, monospace;
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  margin: 0;
  background: var(--ink);
  color: var(--paper);
  font-family: var(--body);
  font-size: 17px;
  line-height: 1.65;
  -webkit-font-smoothing: antialiased;
  overflow-x: hidden;
}

/* Faint CRT scanline + grain texture, fixed behind everything */
body::before {
  content: "";
  position: fixed; inset: 0; z-index: 0; pointer-events: none;
  background-image: repeating-linear-gradient(
    to bottom, rgba(255,255,255,.020) 0 1px, transparent 1px 4px);
  mix-blend-mode: overlay;
}

img { max-width: 100%; display: block; }
a { color: var(--glow); text-decoration: none; }
a:hover { color: var(--glow-2); }

:focus-visible { outline: 2px solid var(--glow); outline-offset: 3px; border-radius: 4px; }

.wrap { max-width: var(--max); margin: 0 auto; padding: 0 24px; position: relative; z-index: 1; }
.mono { font-family: var(--mono); }
.muted { color: var(--mute); }

/* ---- type ---- */
h1, h2, h3 { font-family: var(--display); font-weight: 800; line-height: 1.0; letter-spacing: -.02em; margin: 0; }
h2 { font-size: clamp(1.7rem, 3.4vw, 2.8rem); letter-spacing: -.025em; }
h3 { font-size: 1.25rem; letter-spacing: -.01em; }

.eyebrow {
  font-family: var(--mono); font-size: .72rem; letter-spacing: .22em;
  text-transform: uppercase; color: var(--glow);
}
.section-eyebrow {
  font-family: var(--mono); font-size: .7rem; letter-spacing: .24em;
  text-transform: uppercase; color: var(--mute);
  display: inline-flex; align-items: center; gap: 10px; margin-bottom: 14px;
}
.section-eyebrow::before { content: ""; width: 26px; height: 1px; background: var(--glow); }

/* ---- buttons ---- */
.btn {
  display: inline-flex; align-items: center; gap: 8px;
  font-family: var(--mono); font-weight: 700; font-size: .82rem;
  letter-spacing: .04em; text-transform: uppercase;
  padding: 15px 26px; border-radius: 999px; cursor: pointer;
  border: 1px solid transparent; transition: transform .15s ease, box-shadow .25s ease, background .2s ease;
}
.btn:hover { transform: translateY(-2px); }
.btn-primary {
  background: var(--glow); color: #1A1304;
  box-shadow: 0 10px 30px -8px rgba(242,180,65,.55);
}
.btn-primary:hover { background: var(--glow-2); box-shadow: 0 14px 38px -8px rgba(242,180,65,.7); color:#1A1304; }
.btn-ghost { background: transparent; color: var(--paper); border-color: var(--ink-3); }
.btn-ghost:hover { border-color: var(--glow); color: var(--glow); }
.btn-block { display: flex; width: 100%; justify-content: center; }

/* =====================================================================
   NAV
   ===================================================================== */
.nav {
  position: sticky; top: 0; z-index: 50;
  background: rgba(11,15,29,.72); backdrop-filter: blur(14px) saturate(160%);
  border-bottom: 1px solid var(--ink-3);
}
.nav-inner { display: flex; align-items: center; justify-content: space-between; height: 70px; }
.brand { display: flex; align-items: center; gap: 11px; font-family: var(--display); font-weight: 800; font-size: 1.18rem; color: var(--paper); letter-spacing: -.02em; }
.brand:hover { color: var(--paper); }
.on-air { width: 10px; height: 10px; border-radius: 50%; background: var(--ember); box-shadow: 0 0 10px rgba(255,83,67,.8); flex: none; }
.nav-links { display: flex; align-items: center; gap: 30px; }
.nav-links a { font-family: var(--mono); font-size: .78rem; letter-spacing: .08em; text-transform: uppercase; color: var(--mute); }
.nav-links a:hover { color: var(--paper); }
.nav-links .btn { color: #1A1304; }
.nav-toggle { display: none; background: none; border: 0; color: var(--paper); font-size: 1.5rem; cursor: pointer; }

@keyframes pulse {
  0%   { box-shadow: 0 0 0 0 rgba(255,83,67,.55); }
  70%  { box-shadow: 0 0 0 9px rgba(255,83,67,0); }
  100% { box-shadow: 0 0 0 0 rgba(255,83,67,0); }
}

/* =====================================================================
   HERO
   ===================================================================== */
.hero { position: relative; padding: 90px 0 80px; overflow: hidden; }
.hero::before {  /* the signal glow — amber light source, top right */
  content: ""; position: absolute; top: -180px; right: -120px; width: 720px; height: 720px;
  background: radial-gradient(circle, rgba(242,180,65,.28), rgba(242,180,65,.06) 38%, transparent 64%);
  filter: blur(8px); z-index: 0; pointer-events: none;
}
.hero-grid { display: grid; grid-template-columns: 1.05fr .95fr; gap: 56px; align-items: center; }

.hero h1 {
  font-size: clamp(2.9rem, 6.6vw, 5.4rem);
  margin: 20px 0 0; line-height: .96;
}
.hero h1 .glow-word { color: var(--glow); }
.hero .lead { font-size: clamp(1.05rem, 1.5vw, 1.28rem); color: #C9CEDD; max-width: 30ch; margin: 26px 0 0; line-height: 1.55; }
.hero .lead b { color: var(--paper); font-weight: 600; }
.hero-cta { display: flex; flex-wrap: wrap; gap: 14px; margin-top: 34px; }
.trust { margin-top: 26px; font-family: var(--mono); font-size: .72rem; letter-spacing: .12em; text-transform: uppercase; color: var(--mute-2); display: flex; flex-wrap: wrap; gap: 8px 16px; }
.trust span { display: inline-flex; align-items: center; gap: 7px; }
.trust span::before { content: ""; width: 5px; height: 5px; border-radius: 50%; background: var(--glow); }

/* ---- Hero visual: Fire Stick (links to Amazon) ---- */
.hero-visual {
  position: relative; display: block; border: 1px solid var(--ink-3);
  border-radius: 20px; overflow: hidden; background: linear-gradient(160deg, #141B2E, #0C1120);
  box-shadow: 0 40px 90px -30px rgba(0,0,0,.8); transition: transform .2s ease, border-color .2s ease;
}
.hero-visual:hover { transform: translateY(-4px); border-color: rgba(242,180,65,.55); text-decoration: none; }
.hero-visual .art { display: block; width: 100%; height: auto; background: #fff; }
.hero-visual .cap { display: flex; align-items: center; justify-content: space-between; gap: 14px; padding: 18px 22px; border-top: 1px solid var(--ink-3); }
.hero-visual .cap .lbl { display: block; }
.hero-visual .cap .ribbon { font-family: var(--mono); font-size: .64rem; letter-spacing: .14em; text-transform: uppercase; color: var(--glow); }
.hero-visual .cap .name { font-family: var(--display); font-weight: 700; font-size: 1.05rem; color: var(--paper); margin-top: 3px; }
.hero-visual .cap .go { font-family: var(--mono); font-size: .74rem; letter-spacing: .04em; text-transform: uppercase; color: var(--glow); white-space: nowrap; }

/* ---- Signature: live broadcast panel ---- */
.broadcast {
  position: relative; background: linear-gradient(160deg, #141B2E, #0C1120);
  border: 1px solid var(--ink-3); border-radius: 20px; padding: 26px;
  box-shadow: 0 40px 90px -30px rgba(0,0,0,.8);
}
.broadcast::after {  /* inner amber bloom */
  content: ""; position: absolute; inset: 0; border-radius: 20px; pointer-events: none;
  background: radial-gradient(120% 80% at 80% 0%, rgba(242,180,65,.10), transparent 55%);
}
.bc-top { display: flex; align-items: center; justify-content: space-between; }
.live { display: inline-flex; align-items: center; gap: 9px; font-family: var(--mono); font-size: .74rem; letter-spacing: .2em; color: var(--ember); font-weight: 700; }
.live .dot { width: 9px; height: 9px; border-radius: 50%; background: var(--ember); box-shadow: 0 0 12px var(--ember); animation: pulse 2.4s infinite; }
.bc-ch { font-family: var(--mono); font-size: .74rem; letter-spacing: .12em; color: var(--mute); }

.bc-screen {
  margin: 20px 0; padding: 30px 22px; border-radius: 12px;
  background: linear-gradient(180deg, rgba(242,180,65,.07), rgba(242,180,65,.02));
  border: 1px solid var(--ink-3); text-align: left;
}
.bc-channel { font-family: var(--mono); font-size: .8rem; letter-spacing: .16em; color: var(--glow); }
.bc-prog { font-family: var(--display); font-weight: 800; font-size: 1.9rem; letter-spacing: -.02em; margin-top: 8px; line-height: 1.05; }
.bc-tag { color: var(--mute); font-size: .92rem; margin-top: 8px; }

.bc-clocks { display: grid; grid-template-columns: 1fr 1fr; gap: 1px; background: var(--ink-3); border: 1px solid var(--ink-3); border-radius: 10px; overflow: hidden; }
.bc-clock { background: var(--ink-2); padding: 14px 16px; }
.bc-clock .lbl { font-family: var(--mono); font-size: .64rem; letter-spacing: .18em; text-transform: uppercase; color: var(--mute-2); }
.bc-clock .time { font-family: var(--mono); font-size: 1.5rem; font-weight: 700; margin-top: 4px; letter-spacing: .02em; }
.bc-clock.home .time { color: var(--glow); }
.bc-foot { margin-top: 16px; font-family: var(--mono); font-size: .68rem; letter-spacing: .1em; text-transform: uppercase; color: var(--mute-2); text-align: center; }

/* =====================================================================
   SECTIONS
   ===================================================================== */
.band { padding: 84px 0; position: relative; }
.band-line { border-top: 1px solid var(--ink-3); }

/* ---- Channel lineup ---- */
.lineup-head { display: flex; align-items: flex-end; justify-content: space-between; gap: 24px; flex-wrap: wrap; margin-bottom: 34px; }
.lineup-head p { color: var(--mute); max-width: 42ch; margin: 10px 0 0; }
.group-label { font-family: var(--mono); font-size: .7rem; letter-spacing: .18em; text-transform: uppercase; color: var(--mute); margin: 32px 0 16px; display: flex; align-items: center; gap: 14px; }
.group-label::after { content: ""; flex: 1; height: 1px; background: var(--ink-3); }
.group-label .free-dot { width: 6px; height: 6px; border-radius: 50%; background: var(--good); }
.group-label .sub-dot { width: 6px; height: 6px; border-radius: 50%; background: var(--glow); }
.channels { display: grid; grid-template-columns: repeat(3, 1fr); gap: 14px; }
.ch-foot { display: flex; align-items: center; gap: 14px; margin-top: 16px; flex-wrap: wrap; }
.ch-foot .badge { margin-top: 0; }
.install { font-family: var(--mono); font-size: .64rem; letter-spacing: .1em; text-transform: uppercase; color: var(--mute); }
.install:hover { color: var(--glow); }
.channel {
  background: var(--ink-2); border: 1px solid var(--ink-3); border-radius: 12px;
  padding: 20px; transition: border-color .2s ease, transform .2s ease;
}
.channel:hover { border-color: rgba(242,180,65,.5); transform: translateY(-3px); }
.channel .num { font-family: var(--mono); font-size: .7rem; letter-spacing: .12em; color: var(--mute-2); }
.channel .name { font-family: var(--display); font-weight: 700; font-size: 1.15rem; margin: 6px 0 4px; }
.channel .desc { color: var(--mute); font-size: .9rem; }
.badge { display: inline-block; margin-top: 14px; font-family: var(--mono); font-size: .64rem; letter-spacing: .12em; text-transform: uppercase; padding: 4px 10px; border-radius: 999px; }
.badge.free { color: #7BE0A0; background: rgba(123,224,160,.1); border: 1px solid rgba(123,224,160,.25); }
.badge.sub  { color: var(--glow); background: rgba(242,180,65,.1); border: 1px solid rgba(242,180,65,.25); }

/* ---- VPN ranked list ---- */
.vpn-list { display: grid; gap: 14px; margin-top: 38px; }
.vpn {
  display: grid; grid-template-columns: 56px 1.4fr 1fr auto; align-items: center; gap: 22px;
  background: var(--ink-2); border: 1px solid var(--ink-3); border-radius: 14px; padding: 22px 26px;
  transition: border-color .2s ease, transform .2s ease;
}
.vpn:hover { border-color: rgba(242,180,65,.45); transform: translateY(-2px); }
.vpn.top { border-color: rgba(242,180,65,.55); background: linear-gradient(120deg, rgba(242,180,65,.07), var(--ink-2) 60%); }
.vpn .rank { font-family: var(--display); font-weight: 800; font-size: 2.1rem; color: var(--glow); line-height: 1; }
.vpn .name { font-family: var(--display); font-weight: 700; font-size: 1.3rem; }
.vpn .tagline { color: var(--mute); font-size: .9rem; margin-top: 2px; }
.vpn .pick { font-family: var(--mono); font-size: .62rem; letter-spacing: .12em; text-transform: uppercase; color: var(--glow); border: 1px solid rgba(242,180,65,.4); border-radius: 999px; padding: 3px 9px; margin-left: 10px; vertical-align: middle; }
.vpn .spec { font-family: var(--mono); font-size: .8rem; color: var(--mute); }
.vpn .spec b { color: var(--paper); font-weight: 400; }
.vpn-foot { margin-top: 28px; text-align: center; }

/* ---- Guides ---- */
.guides { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; margin-top: 36px; }
.guide {
  display: block; background: var(--ink-2); border: 1px solid var(--ink-3);
  border-radius: 14px; padding: 30px; color: var(--paper); transition: border-color .2s, transform .2s;
}
.guide:hover { border-color: rgba(242,180,65,.5); transform: translateY(-3px); color: var(--paper); }
.guide .gtag { font-family: var(--mono); font-size: .68rem; letter-spacing: .16em; text-transform: uppercase; color: var(--glow); }
.guide h3 { margin: 14px 0 8px; }
.guide p { color: var(--mute); margin: 0; font-size: .96rem; }
.guide .go { font-family: var(--mono); font-size: .78rem; color: var(--glow); margin-top: 16px; display: inline-block; }

/* ---- Device ---- */
.device {
  display: grid; grid-template-columns: 150px 1fr auto; gap: 30px; align-items: center;
  background: linear-gradient(120deg, var(--ink-2), #0E1422); border: 1px solid var(--ink-3);
  border-radius: 18px; padding: 30px 34px; margin-top: 34px;
}
.device .stick {
  width: 150px; height: 150px; border-radius: 14px; display: grid; place-items: center; text-align: center;
  font-family: var(--mono); font-weight: 700; font-size: .82rem; letter-spacing: .06em; color: var(--ink);
  background: linear-gradient(150deg, var(--glow), var(--glow-2));
}
.device .ribbon { font-family: var(--mono); font-size: .66rem; letter-spacing: .16em; text-transform: uppercase; color: var(--glow); }
.device h3 { margin: 8px 0 8px; font-size: 1.5rem; }
.device p { color: var(--mute); margin: 0; max-width: 52ch; }

/* ---- FAQ accordion ---- */
.faq { display: grid; gap: 12px; margin-top: 30px; }
.faq details { background: var(--ink-2); border: 1px solid var(--ink-3); border-radius: 12px; padding: 2px 20px; }
.faq summary { cursor: pointer; padding: 18px 0; font-family: var(--display); font-weight: 700; font-size: 1.04rem; color: var(--paper); list-style: none; display: flex; justify-content: space-between; align-items: center; gap: 16px; }
.faq summary::-webkit-details-marker { display: none; }
.faq summary::after { content: "+"; color: var(--glow); font-family: var(--mono); font-size: 1.5rem; line-height: 1; flex: none; }
.faq details[open] summary::after { content: "\2013"; }
.faq details[open] .a { border-top: 1px solid var(--ink-3); }
.faq .a { padding: 16px 0 18px; color: var(--mute); margin: 0; }
.faq .a a { color: var(--glow); }

/* ---- Legal note ---- */
.legal { border: 1px solid var(--ink-3); border-left: 3px solid var(--glow); border-radius: 0 14px 14px 0; padding: 24px 28px; background: var(--ink-2); }
.legal p { margin: 0; color: var(--mute); }
.legal b { color: var(--paper); }

/* ---- Disclosure inline ---- */
.disc { font-family: var(--mono); font-size: .72rem; letter-spacing: .04em; color: var(--mute-2); margin-top: 26px; }
.disc a { color: var(--mute); text-decoration: underline; }

/* =====================================================================
   FOOTER
   ===================================================================== */
.footer { border-top: 1px solid var(--ink-3); padding: 60px 0 34px; margin-top: 30px; }
.foot-grid { display: grid; grid-template-columns: 2fr 1fr 1fr; gap: 40px; }
.foot-grid h4 { font-family: var(--mono); font-size: .7rem; letter-spacing: .16em; text-transform: uppercase; color: var(--mute-2); margin: 0 0 16px; }
.foot-grid p { color: var(--mute); margin: 0; font-size: .95rem; max-width: 40ch; }
.foot-grid ul { list-style: none; padding: 0; margin: 0; }
.foot-grid li { margin: 10px 0; }
.foot-grid a { color: var(--mute); font-size: .95rem; }
.foot-grid a:hover { color: var(--glow); }
.foot-brand { display: flex; align-items: center; gap: 11px; font-family: var(--display); font-weight: 800; font-size: 1.1rem; margin-bottom: 14px; }
.foot-bottom { border-top: 1px solid var(--ink-3); margin-top: 44px; padding-top: 24px; font-family: var(--mono); font-size: .7rem; letter-spacing: .04em; color: var(--mute-2); text-align: center; }

/* =====================================================================
   RESPONSIVE
   ===================================================================== */
@media (max-width: 920px) {
  .hero-grid { grid-template-columns: 1fr; gap: 44px; }
  .hero .lead { max-width: 46ch; }
  .channels { grid-template-columns: 1fr 1fr; }
  .foot-grid { grid-template-columns: 1fr; gap: 28px; }
}
@media (max-width: 680px) {
  .nav-links { display: none; position: absolute; top: 70px; left: 0; right: 0; flex-direction: column; align-items: flex-start; gap: 20px; background: var(--ink); border-bottom: 1px solid var(--ink-3); padding: 24px; }
  .nav-links.open { display: flex; }
  .nav-toggle { display: block; }
  .channels { grid-template-columns: 1fr; }
  .vpn { grid-template-columns: 44px 1fr; grid-template-areas: "rank name" "spec1 spec1" "cta cta"; gap: 12px 16px; }
  .vpn .rank { grid-area: rank; } .vpn .name-cell { grid-area: name; }
  .vpn .spec { grid-area: spec1; } .vpn .cta-cell { grid-area: cta; }
  .vpn .btn { width: 100%; justify-content: center; }
  .guides { grid-template-columns: 1fr; }
  .device { grid-template-columns: 1fr; text-align: center; }
  .device .stick { margin: 0 auto; }
  .band { padding: 60px 0; }
}

@media (prefers-reduced-motion: reduce) {
  * { animation: none !important; scroll-behavior: auto !important; transition: none !important; }
}
