/* ═══════════════════════════════════════════════════════════════
   Cita ITV — hoja única.
   Sin fuentes externas, sin frameworks. Diseño elegante y editorial.
   ═══════════════════════════════════════════════════════════════ */

:root{
  --c-ink:        #0b1220;
  --c-text:       #1f2937;
  --c-soft:       #4b5563;
  --c-muted:      #6b7280;
  --c-line:       #e5e7eb;
  --c-line-soft:  #f1f5f9;
  --c-bg:         #ffffff;
  --c-bg-soft:    #f8fafc;
  --c-bg-warm:    #fbfaf7;
  --c-brand:      #0d9488;          /* teal-600 */
  --c-brand-deep: #0f766e;          /* teal-700 */
  --c-brand-soft: #ccfbf1;          /* teal-100 */
  --c-accent:     #f59e0b;          /* amber-500, calor */
  --c-accent-soft:#fef3c7;
  --c-blue:       #0284c7;
  --c-blue-deep:  #0369a1;
  --c-blue-soft:  #e0f2fe;

  --grad-1: linear-gradient(135deg,#0d9488 0%,#0284c7 100%);
  --grad-2: linear-gradient(135deg,#0f766e 0%,#1e3a8a 100%);
  --grad-warm: linear-gradient(135deg,#f59e0b 0%,#d97706 100%);

  --shadow-sm: 0 1px 2px rgba(15,23,42,.04), 0 1px 3px rgba(15,23,42,.06);
  --shadow-md: 0 4px 6px -1px rgba(15,23,42,.06), 0 8px 24px -8px rgba(15,23,42,.12);
  --shadow-lg: 0 12px 28px -8px rgba(15,23,42,.18), 0 24px 48px -16px rgba(15,23,42,.18);
  --shadow-glow: 0 12px 32px -8px rgba(13,148,136,.32);

  --radius-sm: 8px;
  --radius:    14px;
  --radius-lg: 22px;
  --radius-xl: 28px;

  --t-fast: .14s cubic-bezier(.4,0,.2,1);
  --t-slow: .35s cubic-bezier(.4,0,.2,1);

  --container: 1140px;
  --container-narrow: 780px;
}

*,*::before,*::after{box-sizing:border-box}
html{
  -webkit-text-size-adjust:100%;
  text-rendering:optimizeLegibility;
  scroll-behavior:smooth;
}
body{
  margin:0;
  font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,"Helvetica Neue",Arial,sans-serif;
  font-size:17px;
  line-height:1.65;
  color:var(--c-text);
  background:var(--c-bg);
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
  font-feature-settings:"ss01","cv11";
}
img,svg,video{max-width:100%;height:auto;display:block}
a{color:var(--c-brand-deep);text-decoration:none;transition:color var(--t-fast)}
a:hover{color:var(--c-brand);text-decoration:underline;text-underline-offset:3px}

h1,h2,h3,h4{
  color:var(--c-ink);
  letter-spacing:-.02em;
  line-height:1.18;
  text-wrap:balance;
}
h1{
  font-size:clamp(2rem,4vw + 1rem,3.4rem);
  font-weight:800;
  margin:.2em 0 .5em;
  letter-spacing:-.03em;
}
h2{
  font-size:clamp(1.45rem,1.5vw + 1rem,2.05rem);
  font-weight:700;
  margin:2.5rem 0 1rem;
}
h3{
  font-size:1.2rem;
  font-weight:700;
  margin:1.7rem 0 .55rem;
}
h4{font-size:1.05rem;font-weight:700;margin:1.3rem 0 .35rem}

p{margin:0 0 1rem}
ul,ol{padding-left:1.25rem;margin:.6rem 0 1.2rem}
li{margin:.3rem 0}
hr{border:0;height:1px;background:var(--c-line);margin:2.5rem 0}
::selection{background:var(--c-brand);color:#fff}

.wrap        {max-width:var(--container);margin:0 auto;padding:0 1.2rem}
.wrap-narrow {max-width:var(--container-narrow);margin:0 auto;padding:0 1.2rem}

.skip-link{
  position:absolute;left:-9999px;top:0;background:var(--c-ink);color:#fff;padding:.65rem 1rem;z-index:100;
  border-radius:0 0 var(--radius-sm) 0;font-weight:600;
}
.skip-link:focus{left:0;top:0}
.visually-hidden{position:absolute!important;width:1px;height:1px;overflow:hidden;clip:rect(0 0 0 0);white-space:nowrap}

/* ── Header ───────────────────────────────────────────────────── */
.site-header{
  position:sticky;top:0;z-index:50;
  background:rgba(255,255,255,.85);
  backdrop-filter:saturate(160%) blur(12px);
  -webkit-backdrop-filter:saturate(160%) blur(12px);
  border-bottom:1px solid var(--c-line-soft);
}
.site-header__inner{
  display:flex;align-items:center;justify-content:space-between;
  padding:.85rem 1.2rem;gap:1.5rem;max-width:var(--container);margin:0 auto;
}
.brand{
  display:inline-flex;align-items:center;gap:.6rem;
  font-weight:800;font-size:1.05rem;color:var(--c-ink);
  letter-spacing:-.01em;
}
.brand:hover{text-decoration:none;color:var(--c-ink)}
.brand svg{flex:none;filter:drop-shadow(0 2px 4px rgba(13,148,136,.3))}
.brand__logo{
  height:55px;width:auto;display:block;
  max-width:300px;object-fit:contain;
}
@media(max-width:600px){
  .brand__logo{height:42px;max-width:220px}
}

/* ── Nav de escritorio (enlaces principales SEO) ───────────────── */
.nav-desktop{display:none}
.nav-desktop ul{
  list-style:none;padding:0;margin:0;
  display:flex;align-items:center;gap:.1rem;
}
.nav-desktop a{
  display:inline-block;
  padding:.5rem .85rem;
  border-radius:var(--radius-sm);
  color:var(--c-ink);font-weight:500;font-size:.95rem;
  transition:background var(--t-fast),color var(--t-fast);
}
.nav-desktop a:hover{
  background:var(--c-bg-soft);color:var(--c-brand-deep);
  text-decoration:none;
}
.nav-desktop a[aria-current="page"]{
  background:var(--c-brand-soft);color:var(--c-brand-deep);font-weight:600;
}
.nav-desktop .nav-cta{
  margin-left:.4rem;
  background:var(--c-brand-soft);color:var(--c-brand-deep);font-weight:600;
}
.nav-desktop .nav-cta:hover{
  background:var(--c-brand);color:#fff;
}
@media(min-width:920px){
  .nav-desktop{display:block}
  .nav{display:none}
}

.nav summary{
  list-style:none;cursor:pointer;
  width:44px;height:44px;border-radius:12px;
  display:inline-flex;align-items:center;justify-content:center;
  background:var(--c-bg-soft);border:1px solid var(--c-line);
  transition:background var(--t-fast),border-color var(--t-fast);
}
.nav summary:hover{background:var(--c-line-soft);border-color:#d1d5db}
.nav summary::-webkit-details-marker{display:none}
.nav summary::marker{content:""}
.hamburger,.hamburger::before,.hamburger::after{
  display:block;width:18px;height:2px;background:var(--c-ink);border-radius:2px;
}
.hamburger{position:relative}
.hamburger::before{content:"";position:absolute;top:-6px;left:0}
.hamburger::after {content:"";position:absolute;top: 6px;left:0}
.nav__panel{
  position:absolute;right:1.2rem;top:64px;
  background:#fff;border:1px solid var(--c-line);border-radius:var(--radius);
  box-shadow:var(--shadow-lg);
  padding:.5rem;min-width:280px;max-height:72vh;overflow:auto;
}
.nav__list{list-style:none;padding:0;margin:0}
.nav__list a{
  display:block;padding:.55rem .85rem;border-radius:var(--radius-sm);color:var(--c-ink);
  font-weight:500;
}
.nav__list a:hover{background:var(--c-bg-soft);text-decoration:none}
.nav__list a[aria-current="page"]{background:var(--c-brand-soft);color:var(--c-brand-deep);font-weight:600}

@media(min-width:920px){
  .nav summary{display:none}
  .nav .nav__panel{
    position:static;display:flex;flex-wrap:wrap;gap:.15rem;
    box-shadow:none;border:0;background:transparent;padding:0;min-width:0;max-height:none;
  }
  .nav__list{display:flex;flex-wrap:wrap;gap:.1rem}
  .nav__list a{padding:.45rem .8rem;font-size:.95rem;font-weight:500}
}

/* ── Breadcrumbs ───────────────────────────────────────────────── */
.breadcrumbs{font-size:.92rem;color:var(--c-muted);margin:1.25rem auto 0}
.breadcrumbs ol{list-style:none;padding:0;margin:0;display:flex;flex-wrap:wrap;gap:.3rem .55rem}
.breadcrumbs li{display:inline-flex;align-items:center;gap:.55rem}
.breadcrumbs li + li::before{content:"›";color:#cbd5e1;font-weight:600}
.breadcrumbs a{color:var(--c-soft)}
.breadcrumbs [aria-current]{color:var(--c-ink);font-weight:600}

/* ── Hero (home + secciones) ──────────────────────────────────── */
.hero{
  position:relative;overflow:hidden;
  color:#fff;
  background:var(--grad-2);
  margin-top:0;
}
.hero::before{
  content:"";position:absolute;inset:0;
  background:
    radial-gradient(60% 50% at 90% 0%, rgba(245,158,11,.18), transparent 60%),
    radial-gradient(50% 50% at 0% 100%, rgba(2,132,199,.35), transparent 60%),
    radial-gradient(40% 40% at 50% 0%, rgba(13,148,136,.4), transparent 60%);
  pointer-events:none;
}
.hero::after{
  content:"";position:absolute;inset:0;
  background-image:
    linear-gradient(rgba(255,255,255,.04) 1px,transparent 1px),
    linear-gradient(90deg,rgba(255,255,255,.04) 1px,transparent 1px);
  background-size:42px 42px;
  background-position:center center;
  mask-image:radial-gradient(ellipse at center, #000 30%, transparent 70%);
  -webkit-mask-image:radial-gradient(ellipse at center, #000 30%, transparent 70%);
  pointer-events:none;
}
.hero__inner{
  position:relative;z-index:1;
  padding:clamp(3rem,6vw + 1rem,6rem) 1.2rem clamp(2.5rem,5vw,5rem);
  max-width:var(--container);margin:0 auto;
}
.hero__eyebrow{
  display:inline-flex;align-items:center;gap:.5rem;
  background:rgba(255,255,255,.14);
  border:1px solid rgba(255,255,255,.25);
  color:#fff;padding:.4rem .9rem;border-radius:999px;
  font-size:.82rem;font-weight:600;letter-spacing:.04em;text-transform:uppercase;
  margin-bottom:1.4rem;
}
.hero__eyebrow .pulse{
  width:8px;height:8px;border-radius:999px;background:#34d399;
  box-shadow:0 0 0 0 rgba(52,211,153,.7);
  animation:pulse 2s infinite;
}
@keyframes pulse{
  0%{box-shadow:0 0 0 0 rgba(52,211,153,.7)}
  70%{box-shadow:0 0 0 10px rgba(52,211,153,0)}
  100%{box-shadow:0 0 0 0 rgba(52,211,153,0)}
}
.hero h1{color:#fff;max-width:18ch;margin:0 0 .8rem}
.hero p.lead{
  font-size:clamp(1.1rem,.5vw + 1rem,1.3rem);
  max-width:54ch;color:rgba(255,255,255,.92);margin:0 0 1.8rem;
  line-height:1.55;
}
.hero__actions{display:flex;flex-wrap:wrap;gap:.7rem;margin-top:1.4rem}

.btn{
  display:inline-flex;align-items:center;gap:.5rem;
  padding:.95rem 1.5rem;border-radius:999px;font-weight:600;
  font-size:1rem;border:0;cursor:pointer;
  transition:transform var(--t-fast),box-shadow var(--t-fast),background var(--t-fast),color var(--t-fast);
  white-space:nowrap;line-height:1.1;
}
.btn:hover{text-decoration:none;transform:translateY(-1px)}
.btn-primary{background:#fff;color:var(--c-ink);box-shadow:var(--shadow-md)}
.btn-primary:hover{background:#fff;color:var(--c-ink);box-shadow:var(--shadow-lg)}
.btn-accent{background:var(--c-accent);color:var(--c-ink);box-shadow:var(--shadow-md)}
.btn-accent:hover{background:#fbbf24;color:var(--c-ink)}
.btn-ghost{background:rgba(255,255,255,.12);color:#fff;border:1px solid rgba(255,255,255,.4)}
.btn-ghost:hover{background:rgba(255,255,255,.2);color:#fff}
.btn-large{padding:1.1rem 2rem;font-size:1.05rem}
.btn-block{display:flex;justify-content:center;width:100%}
.btn-brand{
  background:var(--c-ink);color:#fff;box-shadow:var(--shadow-glow);
}
.btn-brand:hover{background:var(--c-brand-deep);color:#fff;box-shadow:var(--shadow-lg)}

/* KPIs en hero */
.hero__kpis{
  display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));
  gap:.8rem;margin-top:2.5rem;list-style:none;padding:0;
}
.hero__kpis li{
  background:rgba(255,255,255,.08);
  border:1px solid rgba(255,255,255,.18);
  border-radius:var(--radius);
  padding:1rem 1.2rem;color:#fff;
  backdrop-filter:blur(8px);
}
.hero__kpis strong{
  display:block;font-size:1.7rem;font-weight:800;letter-spacing:-.02em;line-height:1;
  background:linear-gradient(135deg,#fff 0%,#bae6fd 100%);
  -webkit-background-clip:text;background-clip:text;color:transparent;
  margin-bottom:.3rem;
}
.hero__kpis span{font-size:.88rem;color:rgba(255,255,255,.85);line-height:1.3;display:block}

/* Hero sutil para páginas internas */
.hero-soft{
  background:linear-gradient(180deg, var(--c-bg-warm) 0%, var(--c-bg) 100%);
  padding:clamp(2rem,4vw,3.5rem) 0 1rem;
  border-bottom:1px solid var(--c-line-soft);
}
.hero-soft .hero__inner{padding:0;color:var(--c-ink)}
.hero-soft h1{color:var(--c-ink);max-width:none}
.hero-soft p.lead{color:var(--c-soft)}
.hero-soft__meta{
  display:flex;flex-wrap:wrap;gap:.5rem;margin-top:1.2rem;
}
.chip{
  display:inline-flex;align-items:center;gap:.4rem;
  background:#fff;border:1px solid var(--c-line);color:var(--c-soft);
  padding:.4rem .8rem;border-radius:999px;font-size:.85rem;font-weight:500;
  box-shadow:var(--shadow-sm);
}
.chip-accent{background:var(--c-brand-soft);color:var(--c-brand-deep);border-color:transparent}
.chip-amber{background:var(--c-accent-soft);color:#92400e;border-color:transparent}

/* ── Secciones ─────────────────────────────────────────────────── */
section{position:relative}
.section{padding:clamp(2.5rem,5vw,4.5rem) 0}
.section-soft{background:var(--c-bg-soft)}
.section-warm{background:var(--c-bg-warm)}
.section__head{max-width:var(--container-narrow);margin:0 auto 2rem;text-align:center}
.section__head p{color:var(--c-soft);font-size:1.05rem;max-width:60ch;margin:0 auto}
.section__head .eyebrow{
  color:var(--c-brand-deep);font-weight:700;font-size:.85rem;
  letter-spacing:.12em;text-transform:uppercase;margin-bottom:.8rem;display:block;
}

/* Stepper "Cómo funciona" */
.stepper{
  display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:1.2rem;
  list-style:none;padding:0;margin:0;counter-reset:step;
}
.stepper li{
  background:#fff;border:1px solid var(--c-line);border-radius:var(--radius-lg);
  padding:1.6rem 1.4rem;position:relative;counter-increment:step;
  box-shadow:var(--shadow-sm);transition:transform var(--t-fast),box-shadow var(--t-fast);
}
.stepper li:hover{transform:translateY(-3px);box-shadow:var(--shadow-md)}
.stepper li::before{
  content:counter(step,decimal-leading-zero);
  position:absolute;top:1.4rem;right:1.4rem;
  font-weight:800;font-size:2rem;color:var(--c-brand);opacity:.18;letter-spacing:-.04em;
}
.stepper h3{margin:0 0 .4rem;font-size:1.1rem}
.stepper p{margin:0;color:var(--c-soft);font-size:.95rem}

/* Cards (lista de hijos) */
.cards__grid{
  display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));
  gap:.85rem;list-style:none;padding:0;margin:1.2rem 0 0;
}
.card__link{
  display:flex;align-items:center;gap:.7rem;
  padding:1rem 1.15rem;
  border:1px solid var(--c-line);border-radius:var(--radius);
  background:#fff;color:var(--c-ink);font-weight:600;
  transition:all var(--t-fast);
  position:relative;overflow:hidden;
}
.card__link::before{
  content:"";position:absolute;inset:0;
  background:linear-gradient(135deg,transparent 0%,var(--c-brand-soft) 100%);
  opacity:0;transition:opacity var(--t-fast);pointer-events:none;
}
.card__link:hover{
  text-decoration:none;border-color:var(--c-brand);
  box-shadow:var(--shadow-glow);transform:translateY(-2px);
}
.card__link:hover::before{opacity:.4}
.card__title{flex:1;position:relative;z-index:1}
.card__meta{
  font-size:.74rem;font-weight:600;color:var(--c-brand-deep);
  background:var(--c-brand-soft);padding:.18rem .55rem;border-radius:999px;
  position:relative;z-index:1;
}
.card__arrow{color:var(--c-brand);font-weight:700;font-size:1.1rem;position:relative;z-index:1}

/* Bloque relacionados */
.related{
  background:var(--c-bg-soft);
  border-top:1px solid var(--c-line);
  padding:clamp(2rem,4vw,3rem) 1.2rem;
  margin-top:3rem;
}
.related h2{margin-top:0}
.related__grid{
  display:grid;grid-template-columns:repeat(auto-fill,minmax(230px,1fr));
  gap:.4rem .8rem;list-style:none;padding:0;margin:0;
}
.related__grid a{
  display:flex;justify-content:space-between;align-items:center;gap:.5rem;
  padding:.65rem .25rem;color:var(--c-ink);
  border-bottom:1px dashed var(--c-line);font-weight:500;
  transition:color var(--t-fast),padding var(--t-fast);
}
.related__grid a:hover{color:var(--c-brand-deep);text-decoration:none;padding-left:.4rem}
.related__op{
  font-size:.72rem;color:var(--c-muted);background:#fff;border:1px solid var(--c-line);
  padding:.1rem .42rem;border-radius:999px;font-weight:600;
}

/* ── Contenido editorial ──────────────────────────────────────── */
.prose{max-width:var(--container-narrow);margin:0 auto;padding:1.8rem 1.2rem 0}
.prose h2:first-child{margin-top:0}
.prose ul li{margin:.4rem 0}
.prose blockquote{
  margin:1.8rem 0;padding:1.1rem 1.4rem;
  border-left:4px solid var(--c-brand);
  background:var(--c-brand-soft);
  border-radius:0 var(--radius) var(--radius) 0;
  color:var(--c-brand-deep);font-style:italic;
}
.callout{
  margin:1.8rem 0;padding:1.2rem 1.4rem;
  border:1px solid var(--c-blue-soft);background:#f0f9ff;
  border-radius:var(--radius);color:#0c4a6e;
  display:flex;gap:.9rem;align-items:flex-start;
}
.callout::before{
  content:"💡";flex:none;font-size:1.3rem;line-height:1.2;
}
.callout-warn{
  border-color:var(--c-accent-soft);background:var(--c-accent-soft);color:#92400e;
}
.callout-warn::before{content:"⚠️"}
.callout > div{flex:1}
.callout strong{color:inherit}

/* Tabla de datos */
.data-table{
  width:100%;border-collapse:collapse;margin:1.2rem 0;font-size:.95rem;
  border:1px solid var(--c-line);border-radius:var(--radius);overflow:hidden;
  background:#fff;
}
.data-table th,.data-table td{
  padding:.8rem 1rem;text-align:left;border-bottom:1px solid var(--c-line);
  vertical-align:top;
}
.data-table thead th{background:var(--c-bg-soft);font-weight:600;color:var(--c-ink)}
.data-table tbody th{
  background:var(--c-bg-soft);font-weight:600;color:var(--c-ink);
  width:32%;font-size:.88rem;letter-spacing:.02em;
}
.data-table tr:last-child th,.data-table tr:last-child td{border-bottom:0}

/* CTA inline */
.cta-inline{
  display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:1rem;
  background:var(--grad-1);
  color:#fff;padding:1.4rem 1.6rem;border-radius:var(--radius-lg);
  margin:2.2rem 0;box-shadow:var(--shadow-glow);
  position:relative;overflow:hidden;
}
.cta-inline::before{
  content:"";position:absolute;inset:0;
  background:radial-gradient(40% 80% at 100% 50%,rgba(245,158,11,.25),transparent 60%);
  pointer-events:none;
}
.cta-inline > *{position:relative;z-index:1}
.cta-inline strong{font-weight:700;font-size:1.05rem}
.cta-inline p{margin:0;color:rgba(255,255,255,.9);font-size:.95rem}
.cta-inline .btn{background:#fff;color:var(--c-ink)}
.cta-inline .btn:hover{background:#f8fafc;color:var(--c-ink)}

/* ── FAQ accordion ─────────────────────────────────────────────── */
.faq-list{display:flex;flex-direction:column;gap:.6rem}
.faq-list details{
  border:1px solid var(--c-line);border-radius:var(--radius);
  padding:.2rem 1.2rem;background:#fff;transition:all var(--t-fast);
}
.faq-list details[open]{
  border-color:var(--c-brand);box-shadow:var(--shadow-md);
}
.faq-list summary{
  cursor:pointer;font-weight:600;padding:1rem 0;
  list-style:none;display:flex;justify-content:space-between;align-items:center;gap:1rem;
  color:var(--c-ink);font-size:1.02rem;
}
.faq-list summary::-webkit-details-marker{display:none}
.faq-list summary::after{
  content:"";flex:none;width:22px;height:22px;border-radius:50%;
  background:var(--c-brand-soft) url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 24 24' fill='none' stroke='%230f766e' stroke-width='3' stroke-linecap='round'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E") center/14px no-repeat;
  transition:transform var(--t-fast);
}
.faq-list details[open] summary::after{transform:rotate(180deg)}
.faq-list summary:hover{color:var(--c-brand-deep)}
.faq-list details > *:not(summary){padding-bottom:1rem}
.faq-list p{margin:0 0 .4rem;color:var(--c-soft)}

/* ── Estación: hero + datos ────────────────────────────────────── */
.station-hero{
  position:relative;overflow:hidden;
  background:var(--grad-1);color:#fff;
  border-radius:0;
}
.station-hero::before{
  content:"";position:absolute;inset:0;
  background:
    radial-gradient(45% 45% at 100% 0%,rgba(245,158,11,.35),transparent 60%),
    radial-gradient(50% 50% at 0% 100%,rgba(2,132,199,.35),transparent 60%);
  pointer-events:none;
}
.station-hero__inner{
  position:relative;z-index:1;
  padding:clamp(2.2rem,4vw,3.5rem) 1.2rem;
  max-width:var(--container);margin:0 auto;
  display:grid;grid-template-columns:1fr;gap:2rem;align-items:center;
}
@media(min-width:880px){
  .station-hero__inner{grid-template-columns:1.2fr .9fr;gap:3rem}
}
.station-hero h1{color:#fff;margin:0 0 .5rem;font-size:clamp(1.8rem,3vw + .8rem,2.7rem)}
.station-hero__sub{color:rgba(255,255,255,.92);font-size:1.1rem;margin:0 0 1.4rem;max-width:42ch}
.station-hero__chips{display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:1.6rem}
.station-hero__chips .chip{background:rgba(255,255,255,.16);border-color:rgba(255,255,255,.25);color:#fff}
.station-hero__chips .chip strong{color:#fff;font-weight:700}
.station-hero__cta{display:flex;flex-wrap:wrap;gap:.7rem}

.station-illu{
  position:relative;
  background:rgba(255,255,255,.08);
  border:1px solid rgba(255,255,255,.18);
  border-radius:var(--radius-lg);
  padding:1.8rem;backdrop-filter:blur(10px);
  display:flex;flex-direction:column;gap:1rem;
}
.station-illu__svg{width:100%;height:auto;max-width:340px;margin:0 auto}
.station-illu__op{
  text-align:center;color:rgba(255,255,255,.85);font-size:.9rem;
  letter-spacing:.08em;text-transform:uppercase;font-weight:600;
}
.station-illu__op strong{display:block;color:#fff;font-size:1.1rem;margin-top:.25rem;letter-spacing:0;text-transform:none}

/* Layout 2 columnas en página de estación (info + mapa) */
.station-grid{
  display:grid;grid-template-columns:1fr;gap:1.5rem;
  max-width:var(--container);margin:2.2rem auto 0;padding:0 1.2rem;
}
@media(min-width:920px){
  .station-grid{grid-template-columns:1.15fr 1fr;gap:2.2rem}
}
.station-card{
  background:#fff;border:1px solid var(--c-line);border-radius:var(--radius-lg);
  padding:1.6rem 1.8rem;box-shadow:var(--shadow-sm);
}
.station-card h2{margin-top:0;font-size:1.25rem}

/* Mapa */
.station-map{
  background:#fff;border:1px solid var(--c-line);border-radius:var(--radius-lg);
  overflow:hidden;box-shadow:var(--shadow-sm);
}
.station-map__head{padding:1rem 1.4rem;border-bottom:1px solid var(--c-line-soft)}
.station-map__head h2{margin:0;font-size:1.15rem}
.station-map__head p{margin:.25rem 0 0;color:var(--c-muted);font-size:.9rem}
.station-map iframe{display:block;width:100%;height:340px;border:0}
.station-map__foot{
  display:flex;justify-content:space-between;align-items:center;gap:.5rem;
  padding:.85rem 1.4rem;border-top:1px solid var(--c-line-soft);font-size:.9rem;
}
.station-map__foot a{color:var(--c-brand-deep);font-weight:600}

/* Lista de documentos con icono */
.checklist{list-style:none;padding:0;margin:.8rem 0 1.2rem;display:grid;gap:.6rem}
.checklist li{
  display:flex;align-items:flex-start;gap:.7rem;
  padding:.7rem .9rem;
  background:#fff;border:1px solid var(--c-line);border-radius:var(--radius);
}
.checklist li::before{
  content:"";flex:none;width:22px;height:22px;border-radius:50%;
  background:var(--c-brand-soft) url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 24 24' fill='none' stroke='%230f766e' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M5 12l5 5L20 7'/%3E%3C/svg%3E") center/14px no-repeat;
  margin-top:1px;
}
.checklist strong{display:block;font-weight:600;color:var(--c-ink);margin-bottom:0}
.checklist span{color:var(--c-soft);font-size:.92rem}

/* Quick facts grid (precio, duración, etc.) */
.quick-facts{
  display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));
  gap:.8rem;list-style:none;padding:0;margin:1.5rem 0;
}
.quick-facts li{
  background:#fff;border:1px solid var(--c-line);border-radius:var(--radius);
  padding:1rem 1.1rem;
}
.quick-facts strong{
  display:block;font-size:1.4rem;font-weight:800;color:var(--c-ink);
  letter-spacing:-.02em;margin-bottom:.15rem;
}
.quick-facts span{font-size:.88rem;color:var(--c-muted)}

/* Operador badge */
.op-badge{
  display:inline-flex;align-items:center;gap:.5rem;
  background:#fff;border:1px solid var(--c-line);border-radius:999px;
  padding:.5rem 1rem;font-weight:600;font-size:.92rem;color:var(--c-ink);
  box-shadow:var(--shadow-sm);
}
.op-badge__dot{width:10px;height:10px;border-radius:50%;background:var(--c-brand);flex:none}
.op-badge[data-op="veiasa"]   .op-badge__dot{background:#0d9488}
.op-badge[data-op="applus"]   .op-badge__dot{background:#0ea5e9}
.op-badge[data-op="sgs"]      .op-badge__dot{background:#fb923c}
.op-badge[data-op="itasua"]   .op-badge__dot{background:#8b5cf6}
.op-badge[data-op="itevelesa"].op-badge__dot{background:#dc2626}
.op-badge[data-op="itvasa"]   .op-badge__dot{background:#10b981}

/* Manual de cita previa - pasos visuales */
.guide-steps{counter-reset:gs;display:flex;flex-direction:column;gap:1.2rem;margin:1.5rem 0}
.guide-steps > div{
  position:relative;padding:1.4rem 1.5rem 1.4rem 4.5rem;counter-increment:gs;
  border:1px solid var(--c-line);border-radius:var(--radius-lg);background:#fff;
  box-shadow:var(--shadow-sm);
}
.guide-steps > div::before{
  content:counter(gs);
  position:absolute;left:1.3rem;top:1.4rem;
  width:36px;height:36px;border-radius:50%;
  background:var(--grad-1);color:#fff;font-weight:800;
  display:flex;align-items:center;justify-content:center;font-size:1.1rem;
  box-shadow:var(--shadow-glow);
}
.guide-steps h3{margin:0 0 .35rem;font-size:1.08rem}
.guide-steps p:last-child{margin-bottom:0}
.guide-steps .step-image{display:block;margin-top:1rem;border:1px solid var(--c-line);border-radius:var(--radius);box-shadow:var(--shadow-sm);max-width:100%;height:auto}

/* ── Footer ───────────────────────────────────────────────────── */
.site-footer{
  background:var(--c-ink);color:#cbd5e1;
  margin-top:4rem;padding:3rem 0 1.5rem;
  font-size:.95rem;position:relative;overflow:hidden;
}
.site-footer::before{
  content:"";position:absolute;inset:0;
  background:radial-gradient(50% 50% at 0% 0%,rgba(13,148,136,.12),transparent 60%),
             radial-gradient(50% 50% at 100% 100%,rgba(2,132,199,.1),transparent 60%);
  pointer-events:none;
}
.site-footer .wrap{position:relative;z-index:1}
.site-footer h2{color:#fff;font-size:1.05rem;margin:0 0 1rem;font-weight:700}
.site-footer__list{
  list-style:none;padding:0;margin:0 0 1.6rem;
  display:grid;grid-template-columns:repeat(auto-fill,minmax(170px,1fr));gap:.3rem .8rem;
}
.site-footer__list a{color:#94a3b8;padding:.25rem 0;display:inline-block;font-size:.92rem}
.site-footer__list a:hover{color:#5eead4;text-decoration:none}
.site-footer__bottom{
  border-top:1px solid #1e293b;padding-top:1.2rem;margin-top:1.5rem;
  display:flex;flex-wrap:wrap;justify-content:space-between;align-items:center;gap:.8rem;
  font-size:.85rem;color:#94a3b8;
}
.site-footer__bottom p{margin:0;max-width:60ch}
.site-footer__legal{list-style:none;padding:0;margin:0;display:flex;gap:1.2rem;flex-wrap:wrap}
.site-footer__legal a{color:#cbd5e1}

/* Responsive afino */
@media (max-width:600px){
  body{font-size:16px;line-height:1.6}
  .hero__inner{padding-top:2.5rem;padding-bottom:2rem}
  .station-hero__inner{padding-top:2rem;padding-bottom:2rem;gap:1.5rem}
  .station-illu{padding:1.4rem}
  .station-card{padding:1.3rem 1.4rem}
  .station-map iframe{height:280px}
  .data-table th,.data-table td{padding:.65rem .7rem}
  .data-table tbody th{width:38%;font-size:.82rem}
  .cta-inline{padding:1.2rem 1.3rem;flex-direction:column;align-items:flex-start}
  .cta-inline .btn{width:100%;justify-content:center}
  .hero__kpis{grid-template-columns:repeat(2,1fr)}
  .hero__kpis strong{font-size:1.4rem}
}

/* Animaciones de entrada */
@media (prefers-reduced-motion: no-preference){
  .stepper li,.card__link,.station-card{
    animation:fade-up .6s var(--t-slow) backwards;
  }
}
@keyframes fade-up{
  from{opacity:0;transform:translateY(10px)}
  to{opacity:1;transform:none}
}

/* ── Blog ────────────────────────────────────────────────────────── */
.blog-intro{padding:3rem 1.2rem 1rem}
.blog-intro h1{margin:0 0 .8rem;font-size:clamp(1.9rem,5vw,2.6rem);letter-spacing:-.02em}
.blog-intro .lead{color:var(--c-soft);max-width:62ch}

.blog-list-section{padding:1rem 1.2rem 4rem}
.blog-list{
  list-style:none;padding:0;margin:0;
  display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));
  gap:2rem;
}
.blog-list--compact{grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:1.5rem}

.blog-card{
  display:flex;flex-direction:column;
  background:#fff;border:1px solid var(--c-line-soft);border-radius:var(--radius);
  overflow:hidden;transition:transform var(--t-fast),box-shadow var(--t-fast),border-color var(--t-fast);
}
.blog-card:hover{transform:translateY(-3px);box-shadow:var(--shadow-md);border-color:var(--c-line)}

.blog-card__image{display:block;background:var(--c-bg-soft);aspect-ratio:16/9;overflow:hidden}
.blog-card__image img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .5s var(--t-slow)}
.blog-card:hover .blog-card__image img{transform:scale(1.04)}

.blog-card__body{padding:1.4rem 1.5rem 1.6rem;display:flex;flex-direction:column;gap:.6rem;flex:1}
.blog-card__body h2,.blog-card__body h3{margin:0;font-size:1.18rem;line-height:1.35;letter-spacing:-.01em}
.blog-card__body h2 a,.blog-card__body h3 a{color:var(--c-ink)}
.blog-card__body h2 a:hover,.blog-card__body h3 a:hover{color:var(--c-brand-deep);text-decoration:none}
.blog-card__body p{margin:0;color:var(--c-soft);font-size:.95rem;line-height:1.55}
.blog-card__meta{
  display:flex;flex-wrap:wrap;gap:.4rem .6rem;align-items:center;
  font-size:.82rem;color:var(--c-muted);margin:0;
  text-transform:uppercase;letter-spacing:.04em;font-weight:600;
}
.blog-card__cta{
  margin-top:auto;color:var(--c-brand-deep);font-weight:600;font-size:.92rem;
  align-self:flex-start;
}
.blog-card__cta:hover{color:var(--c-brand)}

@media(min-width:780px){
  .blog-card--featured{
    grid-column:1/-1;flex-direction:row;
  }
  .blog-card--featured .blog-card__image{flex:1.3;aspect-ratio:auto;min-height:320px}
  .blog-card--featured .blog-card__body{flex:1;padding:2rem 2.4rem;justify-content:center}
  .blog-card--featured .blog-card__body h2{font-size:1.6rem;line-height:1.25}
  .blog-card--featured .blog-card__body p{font-size:1rem}
}

.blog-post{padding-bottom:3rem}
.blog-post__head{padding:2.5rem 1.2rem 1.5rem}
.blog-post__head h1{margin:0;font-size:clamp(1.85rem,4.6vw,2.6rem);letter-spacing:-.02em;line-height:1.2}
.blog-post__lead{margin-top:1rem;font-size:1.1rem;color:var(--c-soft)}
.blog-post__meta{
  display:flex;flex-wrap:wrap;gap:.4rem .6rem;align-items:center;
  font-size:.85rem;color:var(--c-muted);margin:0 0 1rem;
}
.blog-post__back{color:var(--c-brand-deep);font-weight:600}
.blog-post__tags{display:inline-flex;flex-wrap:wrap;gap:.3rem}
.blog-post__hero{
  margin:0 auto 2rem;max-width:1080px;padding:0 1.2rem;
}
.blog-post__hero img{
  width:100%;height:auto;border-radius:var(--radius);
  box-shadow:var(--shadow-md);display:block;
}
.blog-post__hero figcaption{
  margin-top:.7rem;text-align:center;
  font-size:.85rem;color:var(--c-muted);font-style:italic;
}
.blog-post__body{padding:0 1.2rem}
.blog-post__body h2{
  margin:2.4rem 0 .9rem;font-size:1.45rem;letter-spacing:-.01em;
  border-left:4px solid var(--c-brand);padding-left:.7rem;
}
.blog-post__body h3{margin:1.6rem 0 .6rem;font-size:1.15rem;color:var(--c-ink)}
.blog-post__body p,.blog-post__body ul,.blog-post__body ol{font-size:1.02rem;line-height:1.7}
.blog-post__body strong{color:var(--c-ink)}
.blog-post__source{
  font-size:.85rem;color:var(--c-muted);
  border-top:1px solid var(--c-line-soft);padding-top:1.2rem;margin-top:2.2rem;
}
.blog-post__related{padding:0 1.2rem;margin-top:3rem;border-top:1px solid var(--c-line-soft);padding-top:2rem}
.blog-post__related h2{margin:0 0 1.5rem;font-size:1.4rem}

/* Home: bloque de últimas entradas del blog */
.home-blog{padding:0 0 1rem}
.home-blog .section__head{margin-bottom:1.6rem}
.home-blog__list{
  list-style:none;padding:0;margin:0;
  display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1.4rem;
}
.home-blog__list a{display:block;color:var(--c-ink)}
.home-blog__item{
  display:flex;flex-direction:column;gap:.4rem;
  padding:1.1rem 1.2rem;border-radius:var(--radius);
  background:#fff;border:1px solid var(--c-line-soft);
  transition:transform var(--t-fast),box-shadow var(--t-fast),border-color var(--t-fast);
}
.home-blog__item:hover{transform:translateY(-2px);box-shadow:var(--shadow-md);border-color:var(--c-line);text-decoration:none}
.home-blog__item h3{margin:0;font-size:1.05rem;line-height:1.3;letter-spacing:-.005em;color:var(--c-ink)}
.home-blog__item time{font-size:.78rem;color:var(--c-muted);text-transform:uppercase;letter-spacing:.04em;font-weight:600}
.home-blog__cta{margin-top:1.5rem;text-align:center}
