/*
 * premium.css — SnowBreak visual upgrade layer
 * Se carga como último stylesheet. Overrides cosméticos únicamente.
 * No rompe IDs ni funciones JS. Solo CSS.
 */

/* ─── 0. Inter font (body premium) ────────────────────────────────────────── */
@import url('https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800&display=swap');

/* ─── 1. Token overrides — paleta nieve premium ────────────────────────────── */
:root {
  /* Snow palette */
  --p-white:      #ffffff;
  --p-snow:       #f7f9fc;
  --p-ice:        #eaf4fd;
  --p-mist:       #d6eaf8;

  /* Navy */
  --p-navy-deep:  #06152b;
  --p-navy:       #0d2444;
  --p-navy-mid:   #1a3a6b;

  /* Ice blue brand */
  --p-blue:       #1b6fe8;
  --p-blue-hover: #1559c7;
  --p-blue-light: #e8f2ff;
  --p-sky:        #38bdf8;
  --p-sky-light:  #e0f5ff;

  /* Accent — warm gold for contrast */
  --p-gold:       #f59e0b;
  --p-gold-light: #fef3c7;

  /* Shadows premium */
  --p-sh-xs:  0 1px 3px rgba(6,21,43,.06);
  --p-sh-sm:  0 4px 16px rgba(6,21,43,.08);
  --p-sh-md:  0 8px 32px rgba(6,21,43,.11);
  --p-sh-lg:  0 16px 48px rgba(6,21,43,.14);
  --p-sh-xl:  0 28px 72px rgba(6,21,43,.18);
  --p-sh-blue: 0 8px 28px rgba(27,111,232,.32);

  /* Radii premium */
  --p-r-sm:   6px;
  --p-r-md:   12px;
  --p-r-lg:   18px;
  --p-r-xl:   24px;
  --p-r-card: 20px;

  /* Timing */
  --p-ease:   cubic-bezier(.16,1,.3,1);
  --p-fast:   .16s;
  --p-base:   .24s;
  --p-slow:   .42s;
}

/* ─── 2. Body & base ───────────────────────────────────────────────────────── */
body {
  font-family: 'Inter', 'Segoe UI', system-ui, sans-serif;
  background: var(--p-snow);
  color: var(--p-navy);
  -webkit-font-smoothing: antialiased;
}

h1, h2, h3, h4 {
  font-family: 'Space Grotesk', 'Inter', system-ui, sans-serif;
  letter-spacing: -0.02em;
}

/* ─── 3. Navbar premium ────────────────────────────────────────────────────── */
.navbar {
  background: rgba(255,255,255,.94);
  backdrop-filter: blur(20px) saturate(180%);
  -webkit-backdrop-filter: blur(20px) saturate(180%);
  border-bottom: 1px solid rgba(6,21,43,.07);
  box-shadow: 0 2px 20px rgba(6,21,43,.06);
  transition: box-shadow var(--p-base) var(--p-ease),
              background var(--p-base) var(--p-ease);
}

.navbar.scrolled {
  box-shadow: 0 4px 28px rgba(6,21,43,.12);
  background: rgba(255,255,255,.98);
}

.navbar__container {
  padding: 0.65rem 1.5rem;
}

.navbar__link {
  font-weight: 500;
  font-size: .9rem;
  color: var(--p-navy-mid);
  padding: .4rem .5rem;
  border-radius: var(--p-r-sm);
  transition: color var(--p-fast), background var(--p-fast);
  letter-spacing: -.01em;
}

.navbar__link:hover {
  color: var(--p-blue);
  background: var(--p-blue-light);
}

.navbar__link--active {
  color: var(--p-blue) !important;
  font-weight: 600;
}

/* Botón CTA "Reservar" en navbar */
.navbar__btn {
  background: var(--p-blue);
  color: #fff !important;
  padding: .52rem 1.15rem;
  border-radius: var(--p-r-sm);
  font-weight: 600;
  font-size: .88rem;
  letter-spacing: -.01em;
  box-shadow: var(--p-sh-blue);
  transition: background var(--p-fast), transform var(--p-fast), box-shadow var(--p-fast);
  display: inline-flex;
  align-items: center;
  gap: .4rem;
}

.navbar__btn:hover {
  background: var(--p-blue-hover);
  transform: translateY(-1px);
  box-shadow: 0 10px 32px rgba(27,111,232,.38);
}

.navbar__btn:active {
  transform: translateY(0);
}

.navbar__btn--ghost {
  background: transparent;
  color: var(--p-navy-mid) !important;
  box-shadow: none;
  border: 1px solid rgba(6,21,43,.14);
}

.navbar__btn--ghost:hover {
  background: var(--p-snow);
  box-shadow: none;
  transform: none;
}

.navbar__btn--link {
  background: var(--p-blue);
  color: #fff !important;
  box-shadow: var(--p-sh-blue);
}

.navbar__welcome {
  font-size: .85rem;
  color: var(--p-navy-mid);
}

/* Carrito badge premium */
.cart-button {
  position: relative;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 40px;
  height: 40px;
  border-radius: var(--p-r-sm);
  color: var(--p-navy-mid);
  transition: background var(--p-fast), color var(--p-fast);
}

.cart-button:hover {
  background: var(--p-blue-light);
  color: var(--p-blue);
}

.cart-button__badge {
  position: absolute;
  top: 3px;
  right: 3px;
  min-width: 18px;
  height: 18px;
  background: var(--p-blue);
  color: #fff;
  font-size: .68rem;
  font-weight: 700;
  border-radius: 999px;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 0 4px;
  border: 2px solid #fff;
}

/* ─── 4. Hero premium-v2 upgrade ───────────────────────────────────────────── */
.hero--premium-v2 {
  background:
    radial-gradient(ellipse at 15% 40%, rgba(56,189,248,.22) 0%, transparent 45%),
    radial-gradient(ellipse at 85% 60%, rgba(27,111,232,.18) 0%, transparent 40%),
    radial-gradient(ellipse at 50% 100%, rgba(6,21,43,.4) 0%, transparent 60%),
    linear-gradient(150deg, #06152b 0%, #0d2444 40%, #1a3a6b 75%, #1b6fe8 130%);
  position: relative;
  overflow: hidden;
  min-height: 90vh;
  display: flex;
  align-items: center;
}

/* Snowflake particle overlay */
.hero--premium-v2::before {
  content: '';
  position: absolute;
  inset: 0;
  background-image:
    radial-gradient(circle, rgba(255,255,255,.12) 1px, transparent 1px),
    radial-gradient(circle, rgba(255,255,255,.07) 1px, transparent 1px);
  background-size: 60px 60px, 30px 30px;
  background-position: 0 0, 15px 15px;
  pointer-events: none;
  animation: snowShift 20s linear infinite;
}

.hero--premium-v2::after {
  content: '';
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  height: 140px;
  background: linear-gradient(to top, var(--p-snow) 0%, transparent 100%);
  pointer-events: none;
}

@keyframes snowShift {
  0%   { background-position: 0 0, 15px 15px; }
  100% { background-position: 60px 60px, 75px 75px; }
}

.hero__premium-v2-inner {
  position: relative;
  z-index: 2;
  padding: 5rem 1.5rem 7rem;
  max-width: 1100px;
  margin: 0 auto;
  width: 100%;
}

.hero__eyebrow-pill {
  display: inline-flex;
  align-items: center;
  gap: .5rem;
  background: rgba(56,189,248,.18);
  border: 1px solid rgba(56,189,248,.35);
  color: #93d9f8;
  font-size: .78rem;
  font-weight: 600;
  letter-spacing: .08em;
  text-transform: uppercase;
  padding: .35rem .9rem;
  border-radius: 999px;
  margin-bottom: 1.5rem;
  backdrop-filter: blur(8px);
}

.hero__title-v2 {
  font-size: clamp(2.6rem, 7vw, 5.2rem);
  font-weight: 800;
  line-height: 1.0;
  letter-spacing: -.04em;
  color: #fff;
  margin-bottom: 1.25rem;
  max-width: 720px;
}

.hero__subtitle-v2 {
  font-size: clamp(1rem, 2vw, 1.2rem);
  color: rgba(255,255,255,.72);
  max-width: 560px;
  line-height: 1.65;
  margin-bottom: 2.5rem;
}

/* Buscador premium */
.hero__search-v2 {
  background: rgba(255,255,255,.98);
  border-radius: var(--p-r-xl);
  box-shadow: var(--p-sh-xl), 0 0 0 1px rgba(255,255,255,.2);
  padding: .5rem;
  display: flex;
  align-items: stretch;
  gap: 0;
  max-width: 820px;
  margin-bottom: 2rem;
  backdrop-filter: blur(12px);
}

.hero__sv2-field {
  flex: 1;
  padding: .6rem 1rem;
  min-width: 0;
}

.hero__sv2-label {
  display: block;
  font-size: .72rem;
  font-weight: 700;
  letter-spacing: .06em;
  text-transform: uppercase;
  color: var(--p-navy);
  margin-bottom: .2rem;
}

.hero__sv2-input,
.hero__sv2-select {
  width: 100%;
  background: transparent;
  border: none;
  outline: none;
  font-size: .95rem;
  font-weight: 500;
  color: var(--p-navy);
  padding: 0;
  line-height: 1.4;
}

.hero__sv2-input::placeholder { color: #94a3b8; }

.hero__sv2-sep {
  width: 1px;
  background: rgba(6,21,43,.1);
  margin: .75rem 0;
  flex-shrink: 0;
}

.hero__sv2-btn {
  background: var(--p-blue);
  color: #fff;
  border-radius: var(--p-r-lg);
  padding: .85rem 1.75rem;
  font-weight: 700;
  font-size: .95rem;
  letter-spacing: -.01em;
  display: inline-flex;
  align-items: center;
  gap: .5rem;
  white-space: nowrap;
  box-shadow: var(--p-sh-blue);
  transition: background var(--p-fast), transform var(--p-fast), box-shadow var(--p-fast);
  flex-shrink: 0;
  cursor: pointer;
  border: none;
}

.hero__sv2-btn:hover {
  background: var(--p-blue-hover);
  transform: translateY(-1px);
  box-shadow: 0 12px 36px rgba(27,111,232,.42);
}

/* Hero metrics strip */
.hero__metrics-v2 {
  display: flex;
  flex-wrap: wrap;
  gap: .5rem 2rem;
  align-items: center;
  list-style: none;
  padding: 0;
}

.hero__mv2-value {
  display: block;
  font-size: 1.35rem;
  font-weight: 800;
  color: #fff;
  line-height: 1;
  letter-spacing: -.03em;
}

.hero__mv2-label {
  display: block;
  font-size: .75rem;
  color: rgba(255,255,255,.58);
  margin-top: .2rem;
  font-weight: 500;
}

.hero__mv2-sep {
  width: 1px;
  height: 32px;
  background: rgba(255,255,255,.2);
  flex-shrink: 0;
}

/* ─── 5. Stats grid premium ────────────────────────────────────────────────── */
.stats-grid {
  background: var(--p-white);
  border: 1px solid rgba(6,21,43,.07);
  border-radius: var(--p-r-lg);
  box-shadow: var(--p-sh-sm);
  overflow: hidden;
}

.stats__item {
  padding: 1.5rem 2rem;
  border-right: 1px solid rgba(6,21,43,.07);
  position: relative;
  transition: background var(--p-fast);
}

.stats__item:last-child { border-right: none; }
.stats__item:hover { background: var(--p-snow); }

.stats__title {
  font-size: .78rem;
  font-weight: 600;
  letter-spacing: .06em;
  text-transform: uppercase;
  color: var(--p-navy-mid);
  opacity: .65;
  margin-bottom: .5rem;
}

.stats__value {
  font-size: 1.5rem;
  font-weight: 800;
  color: var(--p-navy);
  letter-spacing: -.03em;
}

.stats__value a {
  color: var(--p-blue);
  transition: opacity var(--p-fast);
}

.stats__value a:hover { opacity: .78; }

/* ─── 6. Station cards premium ─────────────────────────────────────────────── */
.station-card,
.panel {
  background: var(--p-white);
  border: 1px solid rgba(6,21,43,.07);
  border-radius: var(--p-r-card);
  box-shadow: var(--p-sh-sm);
  transition:
    transform var(--p-base) var(--p-ease),
    box-shadow var(--p-base) var(--p-ease),
    border-color var(--p-base) var(--p-ease);
  overflow: hidden;
}

.station-card:hover {
  transform: translateY(-6px);
  box-shadow: var(--p-sh-lg);
  border-color: rgba(27,111,232,.15);
}

.station-card__figure {
  height: 200px;
  background: linear-gradient(135deg, var(--p-navy) 0%, var(--p-navy-mid) 100%);
  position: relative;
  overflow: hidden;
}

.station-card__image {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform var(--p-slow) var(--p-ease);
}

.station-card:hover .station-card__image {
  transform: scale(1.06);
}

.station-card__badge {
  position: absolute;
  top: .85rem;
  left: .85rem;
  background: rgba(6,21,43,.65);
  backdrop-filter: blur(8px);
  color: #fff;
  font-size: .75rem;
  font-weight: 700;
  padding: .3rem .75rem;
  border-radius: 999px;
  letter-spacing: .02em;
  border: 1px solid rgba(255,255,255,.15);
}

/* Status badge */
.status-badge {
  font-size: .7rem;
  font-weight: 700;
  letter-spacing: .04em;
  text-transform: uppercase;
  padding: .25rem .7rem;
  border-radius: 999px;
}

.status-badge--abierta,
.status-badge--open,
.status-badge--abierto {
  background: #dcfce7;
  color: #15803d;
}

.status-badge--cerrada,
.status-badge--closed,
.status-badge--cerrado {
  background: #fee2e2;
  color: #b91c1c;
}

.status-badge--parcial {
  background: #fef3c7;
  color: #b45309;
}

/* Dificultad label premium */
.station-card__dificultad {
  font-size: .7rem;
  font-weight: 600;
  color: var(--p-blue);
  letter-spacing: .03em;
  margin-top: .25rem;
  opacity: .9;
}

.station-card__content {
  padding: 1.1rem 1.15rem 0;
}

.station-card__name {
  font-size: 1.05rem;
  font-weight: 700;
  color: var(--p-navy);
  letter-spacing: -.02em;
  line-height: 1.25;
}

.station-card__location {
  font-size: .8rem;
  color: var(--p-navy-mid);
  opacity: .7;
  display: flex;
  align-items: center;
  gap: .25rem;
  margin-top: .3rem;
}

.station-metrics {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: .6rem;
  margin-top: .85rem;
  padding-top: .85rem;
  border-top: 1px solid rgba(6,21,43,.07);
}

.station-metric__label {
  font-size: .7rem;
  text-transform: uppercase;
  letter-spacing: .05em;
  font-weight: 600;
  color: var(--p-navy-mid);
  opacity: .6;
}

.station-metric__value {
  font-size: .95rem;
  font-weight: 700;
  color: var(--p-navy);
  letter-spacing: -.02em;
}

/* Footer bar de tarjeta */
.station-card__footer-bar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: .85rem 1.15rem;
  margin-top: .85rem;
  border-top: 1px solid rgba(6,21,43,.06);
  background: var(--p-snow);
}

.station-card__price-label {
  font-size: .72rem;
  color: var(--p-navy-mid);
  opacity: .65;
  font-weight: 500;
  display: block;
}

.station-card__price-value {
  font-size: 1.25rem;
  font-weight: 800;
  color: var(--p-navy);
  letter-spacing: -.03em;
  line-height: 1;
}

.station-card__cta {
  background: var(--p-blue);
  color: #fff !important;
  padding: .5rem 1.05rem;
  border-radius: var(--p-r-sm);
  font-size: .82rem;
  font-weight: 700;
  display: inline-flex;
  align-items: center;
  gap: .35rem;
  box-shadow: 0 4px 14px rgba(27,111,232,.3);
  transition: background var(--p-fast), transform var(--p-fast), box-shadow var(--p-fast);
  letter-spacing: -.01em;
}

.station-card__cta:hover {
  background: var(--p-blue-hover);
  transform: translateY(-1px);
  box-shadow: 0 6px 20px rgba(27,111,232,.4);
}

/* Favorito button */
.station-card__favorite {
  background: rgba(255,255,255,.88);
  backdrop-filter: blur(8px);
  border-radius: 999px;
  width: 36px;
  height: 36px;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: background var(--p-fast), transform var(--p-fast);
  border: none;
  cursor: pointer;
}

.station-card__favorite:hover {
  background: #fff;
  transform: scale(1.1);
}

/* ─── 7. Grid cards ────────────────────────────────────────────────────────── */
.grid-cards {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(295px, 1fr));
  gap: 1.35rem;
  padding: 0;
  list-style: none;
}

/* ─── 8. Panel premium ─────────────────────────────────────────────────────── */
.panel {
  background: var(--p-white);
  border: 1px solid rgba(6,21,43,.08);
  border-radius: var(--p-r-xl);
  padding: 2rem;
  box-shadow: var(--p-sh-md);
}

.panel--form {
  max-width: 460px;
  margin: 0 auto;
  border-radius: var(--p-r-xl);
}

/* ─── 9. Formularios premium ────────────────────────────────────────────────── */
.form-label {
  font-size: .8rem;
  font-weight: 600;
  letter-spacing: .03em;
  color: var(--p-navy);
  text-transform: uppercase;
  margin-bottom: .4rem;
  display: block;
}

.form-input {
  width: 100%;
  background: var(--p-snow);
  border: 1.5px solid rgba(6,21,43,.12);
  border-radius: var(--p-r-md);
  padding: .78rem 1rem;
  font-size: .95rem;
  font-weight: 400;
  color: var(--p-navy);
  transition: border-color var(--p-fast), box-shadow var(--p-fast), background var(--p-fast);
  outline: none;
}

.form-input:focus {
  border-color: var(--p-blue);
  background: #fff;
  box-shadow: 0 0 0 3px rgba(27,111,232,.12);
}

.form-input::placeholder {
  color: #94a3b8;
  font-weight: 400;
}

.form-submit {
  width: 100%;
  background: var(--p-blue);
  color: #fff;
  border: none;
  border-radius: var(--p-r-md);
  padding: .9rem 1.5rem;
  font-size: 1rem;
  font-weight: 700;
  letter-spacing: -.01em;
  cursor: pointer;
  box-shadow: var(--p-sh-blue);
  transition: background var(--p-fast), transform var(--p-fast), box-shadow var(--p-fast);
}

.form-submit:hover {
  background: var(--p-blue-hover);
  transform: translateY(-1px);
  box-shadow: 0 10px 32px rgba(27,111,232,.42);
}

.form-submit:active { transform: translateY(0); }

.form-help {
  font-size: .78rem;
  color: var(--p-navy-mid);
  opacity: .7;
  margin-top: .3rem;
  display: block;
}

.form-footnote {
  text-align: center;
  font-size: .85rem;
  color: var(--p-navy-mid);
  opacity: .75;
  margin-top: 1.25rem;
}

.form-stack {
  display: flex;
  flex-direction: column;
  gap: 1rem;
}

.form-field {
  display: flex;
  flex-direction: column;
}

/* Auth divider */
.auth-divider {
  display: flex;
  align-items: center;
  gap: .75rem;
  margin: 1.25rem 0;
  color: var(--p-navy-mid);
  font-size: .82rem;
  opacity: .55;
}

.auth-divider::before,
.auth-divider::after {
  content: '';
  flex: 1;
  height: 1px;
  background: rgba(6,21,43,.1);
}

/* Google button */
.auth-google-btn {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: .6rem;
  border: 1.5px solid rgba(6,21,43,.12);
  border-radius: var(--p-r-md);
  padding: .78rem 1rem;
  font-weight: 600;
  font-size: .92rem;
  color: var(--p-navy);
  background: var(--p-white);
  transition: border-color var(--p-fast), background var(--p-fast), box-shadow var(--p-fast);
}

.auth-google-btn:hover {
  border-color: rgba(27,111,232,.3);
  background: var(--p-blue-light);
  box-shadow: var(--p-sh-sm);
}

/* Alert blocks */
.alert {
  border-radius: var(--p-r-md);
  padding: .85rem 1.1rem;
  font-size: .88rem;
  font-weight: 500;
  border: 1px solid transparent;
}

.alert--success {
  background: #f0fdf4;
  color: #15803d;
  border-color: #bbf7d0;
}

.alert--error {
  background: #fef2f2;
  color: #b91c1c;
  border-color: #fecaca;
}

/* ─── 10. Trust signals ─────────────────────────────────────────────────────── */
.auth-trust-signals {
  display: flex;
  flex-wrap: wrap;
  gap: .4rem 1rem;
  justify-content: center;
  margin-top: 1.1rem;
  padding-top: .9rem;
  border-top: 1px solid rgba(6,21,43,.07);
}

.trust-item {
  display: flex;
  align-items: center;
  gap: .3rem;
  font-size: .72rem;
  font-weight: 500;
  color: var(--p-navy-mid);
  opacity: .65;
  letter-spacing: .02em;
}

/* ─── 11. Home planner CTA ─────────────────────────────────────────────────── */
.home-planner-cta {
  background: linear-gradient(135deg, var(--p-navy-deep) 0%, var(--p-navy) 55%, #102e58 100%);
  border: 1px solid rgba(255,255,255,.07);
  border-radius: var(--p-r-xl);
  padding: 3rem 3rem 3rem 3rem;
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 2.5rem;
  align-items: center;
  box-shadow: 0 20px 60px rgba(6,21,43,.35);
  margin: 2.5rem 0;
  position: relative;
  overflow: hidden;
}

/* Glow azul arriba-derecha */
.home-planner-cta::before {
  content: '';
  position: absolute;
  top: -100px;
  right: -80px;
  width: 320px;
  height: 320px;
  background: radial-gradient(circle, rgba(27,111,232,.22) 0%, transparent 65%);
  pointer-events: none;
}

/* Glow celeste abajo-izquierda */
.home-planner-cta::after {
  content: '';
  position: absolute;
  bottom: -60px;
  left: -60px;
  width: 220px;
  height: 220px;
  background: radial-gradient(circle, rgba(56,189,248,.12) 0%, transparent 65%);
  pointer-events: none;
}

.home-planner-cta__eyebrow {
  font-size: .68rem;
  font-weight: 700;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: var(--p-sky);
  margin-bottom: .65rem;
  display: flex;
  align-items: center;
  gap: .5rem;
}

.home-planner-cta__eyebrow::before {
  content: '';
  display: inline-block;
  width: 22px;
  height: 2px;
  background: var(--p-sky);
  border-radius: 2px;
  flex-shrink: 0;
}

.home-planner-cta__title {
  font-size: clamp(1.55rem, 3.2vw, 2.1rem);
  font-weight: 800;
  color: #fff;
  letter-spacing: -.04em;
  line-height: 1.05;
  margin-bottom: .7rem;
}

.home-planner-cta__lede {
  color: rgba(255,255,255,.6);
  font-size: .92rem;
  max-width: 430px;
  line-height: 1.65;
}

/* Pasos numerados en grid 2×2 */
.home-planner-cta__bullets {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: .55rem;
  margin-top: 1.5rem;
  list-style: none;
  padding: 0;
  counter-reset: steps;
}

.home-planner-cta__bullets li {
  counter-increment: steps;
  font-size: .78rem;
  font-weight: 500;
  color: rgba(255,255,255,.75);
  background: rgba(255,255,255,.06);
  border: 1px solid rgba(255,255,255,.1);
  border-radius: var(--p-r-md);
  padding: .6rem .85rem .6rem .75rem;
  display: flex;
  align-items: flex-start;
  gap: .55rem;
  line-height: 1.35;
  transition: background var(--p-fast), border-color var(--p-fast);
}

.home-planner-cta__bullets li:hover {
  background: rgba(255,255,255,.1);
  border-color: rgba(255,255,255,.18);
}

.home-planner-cta__bullets li::before {
  content: counter(steps);
  min-width: 19px;
  height: 19px;
  background: var(--p-blue);
  color: #fff;
  font-size: .62rem;
  font-weight: 800;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  margin-top: .06rem;
}

/* Panel de acción */
.home-planner-cta__action {
  display: flex;
  flex-direction: column;
  align-items: flex-end;
  gap: .75rem;
  min-width: 210px;
}

.home-planner-cta__btn {
  background: #fff;
  color: var(--p-navy) !important;
  border-radius: var(--p-r-md);
  padding: 1rem 2.2rem;
  font-weight: 800;
  font-size: .98rem;
  letter-spacing: -.01em;
  display: inline-flex;
  align-items: center;
  gap: .5rem;
  box-shadow: 0 8px 32px rgba(0,0,0,.28);
  transition: transform var(--p-fast), box-shadow var(--p-fast);
  white-space: nowrap;
  width: 100%;
  justify-content: center;
}

.home-planner-cta__btn svg { transition: transform var(--p-fast); }

.home-planner-cta__btn:hover {
  transform: translateY(-3px);
  box-shadow: 0 16px 48px rgba(0,0,0,.38);
}

.home-planner-cta__btn:hover svg { transform: translateX(3px); }

.home-planner-cta__note {
  font-size: .73rem;
  color: rgba(255,255,255,.38);
  text-align: center;
  font-weight: 500;
  width: 100%;
}

/* ─── 12. Home bottom CTA ──────────────────────────────────────────────────── */
.home-bottom-cta {
  background: linear-gradient(135deg, var(--p-navy-deep) 0%, var(--p-navy) 50%, var(--p-navy-mid) 100%);
  padding: 4rem 1.5rem;
  margin-top: 4rem;
  position: relative;
  overflow: hidden;
}

.home-bottom-cta::before {
  content: '';
  position: absolute;
  top: -50%;
  right: -10%;
  width: 500px;
  height: 500px;
  background: radial-gradient(circle, rgba(56,189,248,.12) 0%, transparent 65%);
  pointer-events: none;
}

.home-bottom-cta__inner {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-between;
  gap: 2rem;
  position: relative;
  z-index: 1;
}

.home-bottom-cta__text h2 {
  font-size: clamp(1.8rem, 4vw, 2.4rem);
  font-weight: 800;
  color: #fff;
  letter-spacing: -.04em;
  margin-bottom: .5rem;
}

.home-bottom-cta__text p {
  color: rgba(255,255,255,.65);
  font-size: .95rem;
  max-width: 440px;
  line-height: 1.6;
}

.home-bottom-cta__btn--primary {
  background: #fff;
  color: var(--p-blue) !important;
  font-weight: 700;
  border-radius: var(--p-r-md);
  padding: .9rem 2rem;
  font-size: 1rem;
  display: inline-flex;
  align-items: center;
  gap: .5rem;
  box-shadow: 0 8px 28px rgba(0,0,0,.2);
  transition: transform var(--p-fast), box-shadow var(--p-fast);
}

.home-bottom-cta__btn--primary:hover {
  transform: translateY(-2px);
  box-shadow: 0 14px 40px rgba(0,0,0,.25);
}

.home-bottom-cta__btn--secondary {
  background: rgba(255,255,255,.1);
  border: 1.5px solid rgba(255,255,255,.3);
  color: #fff !important;
  font-weight: 600;
  border-radius: var(--p-r-md);
  padding: .9rem 1.75rem;
  font-size: .95rem;
  transition: background var(--p-fast), border-color var(--p-fast);
}

.home-bottom-cta__btn--secondary:hover {
  background: rgba(255,255,255,.18);
  border-color: rgba(255,255,255,.5);
}

/* ─── 13. Forfaits page premium ────────────────────────────────────────────── */
.forfait-configurador {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 1.5rem;
  align-items: start;
}

.forfait-configurador__opciones,
.forfait-configurador__resumen {
  background: var(--p-white);
  border: 1px solid rgba(6,21,43,.08);
  border-radius: var(--p-r-xl);
  padding: 1.75rem;
  box-shadow: var(--p-sh-md);
}

.forfait-configurador__titulo {
  font-size: 1rem;
  font-weight: 700;
  color: var(--p-navy);
  letter-spacing: -.02em;
  margin-bottom: 1.25rem;
  padding-bottom: .85rem;
  border-bottom: 1px solid rgba(6,21,43,.08);
}

.forfait-radio {
  display: flex;
  cursor: pointer;
  border-radius: var(--p-r-md);
  border: 1.5px solid rgba(6,21,43,.1);
  padding: .85rem 1rem;
  margin-bottom: .6rem;
  transition: border-color var(--p-fast), background var(--p-fast), box-shadow var(--p-fast);
  gap: .75rem;
  align-items: flex-start;
}

.forfait-radio:hover {
  border-color: rgba(27,111,232,.3);
  background: var(--p-blue-light);
}

.forfait-radio--selected,
.forfait-radio:has(input:checked) {
  border-color: var(--p-blue) !important;
  background: var(--p-blue-light) !important;
  box-shadow: 0 0 0 3px rgba(27,111,232,.1);
}

.forfait-radio__box strong {
  font-size: .9rem;
  font-weight: 700;
  color: var(--p-navy);
  letter-spacing: -.01em;
}

.forfait-radio__box small {
  display: block;
  font-size: .78rem;
  color: var(--p-navy-mid);
  opacity: .75;
  margin-top: .2rem;
  line-height: 1.4;
}

.btn-forfait-guardar {
  background: var(--p-blue);
  color: #fff;
  border-radius: var(--p-r-md);
  padding: .8rem 1.5rem;
  font-weight: 700;
  font-size: .9rem;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: .5rem;
  box-shadow: var(--p-sh-blue);
  border: none;
  cursor: pointer;
  width: 100%;
  margin-top: 1rem;
  transition: background var(--p-fast), transform var(--p-fast);
}

.btn-forfait-guardar:hover {
  background: var(--p-blue-hover);
  transform: translateY(-1px);
}

.btn-forfait-reservar {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: .5rem;
  background: var(--p-blue);
  color: #fff !important;
  border-radius: var(--p-r-md);
  padding: .9rem 1.5rem;
  font-weight: 700;
  font-size: .95rem;
  box-shadow: var(--p-sh-blue);
  transition: background var(--p-fast), transform var(--p-fast);
}

.btn-forfait-reservar:hover {
  background: var(--p-blue-hover);
  transform: translateY(-1px);
}

.forfait-resumen__row--total dt,
.forfait-resumen__row--total dd {
  font-size: 1.15rem;
  font-weight: 800;
  color: var(--p-blue);
}

/* Forfait station card */
.forfait-station-card {
  background: var(--p-white);
  border: 1px solid rgba(6,21,43,.08);
  border-radius: var(--p-r-card);
  overflow: hidden;
  box-shadow: var(--p-sh-sm);
  transition: transform var(--p-base) var(--p-ease), box-shadow var(--p-base) var(--p-ease);
}

.forfait-station-card:hover {
  transform: translateY(-5px);
  box-shadow: var(--p-sh-lg);
}

.forfait-station-card__cta {
  background: var(--p-blue);
  color: #fff !important;
  border-radius: var(--p-r-sm);
  padding: .55rem 1.1rem;
  font-size: .85rem;
  font-weight: 700;
  display: inline-flex;
  align-items: center;
  gap: .35rem;
  box-shadow: 0 4px 14px rgba(27,111,232,.3);
  transition: background var(--p-fast), transform var(--p-fast);
}

.forfait-station-card__cta:hover {
  background: var(--p-blue-hover);
  transform: translateY(-1px);
}

.forfait-station-card__price-tag {
  background: var(--p-blue);
  color: #fff;
  font-size: .75rem;
  font-weight: 700;
  padding: .3rem .8rem;
  border-radius: 999px;
}

/* ─── 14. Login/registro premium ────────────────────────────────────────────── */
.hero--home {
  background: linear-gradient(160deg, var(--p-navy-deep) 0%, var(--p-navy) 60%, var(--p-navy-mid) 100%);
  padding: 3.5rem 1.5rem;
  text-align: center;
  position: relative;
  overflow: hidden;
}

.hero--home::before {
  content: '';
  position: absolute;
  inset: 0;
  background-image: radial-gradient(circle, rgba(255,255,255,.08) 1px, transparent 1px);
  background-size: 40px 40px;
  pointer-events: none;
}

.hero--home .hero__title,
.hero--home .hero__subtitle {
  position: relative;
  z-index: 1;
}

.hero--home .hero__title { color: #fff; }
.hero--home .hero__subtitle { color: rgba(255,255,255,.7); }

/* ─── 15. Navbar items section ──────────────────────────────────────────────── */
@media (min-width: 900px) {
  .navbar__nav {
    position: static;
    display: flex !important;
    background: transparent;
    border: none;
    padding: 0;
    box-shadow: none;
    border-radius: 0;
    flex-direction: row;
    align-items: center;
    gap: .5rem;
  }

  .navbar__list {
    flex-direction: row;
    align-items: center;
    gap: .15rem;
  }

  .navbar__actions {
    flex-direction: row;
    align-items: center;
    gap: .5rem;
  }
}

/* ─── 16. Section headers ───────────────────────────────────────────────────── */
.filters__header > div > h2,
.forfait-grid-header h2,
.pistas-home__header h2 {
  font-size: clamp(1.4rem, 3vw, 1.9rem);
  font-weight: 800;
  color: var(--p-navy);
  letter-spacing: -.04em;
}

.filters__header > div > p,
.forfait-grid-header p,
.pistas-home__aviso {
  color: var(--p-navy-mid);
  opacity: .7;
  font-size: .9rem;
}

/* ─── 17. Pistas dashboard cards ────────────────────────────────────────────── */
.pista-card,
.pistas-home__item {
  background: var(--p-white);
  border: 1px solid rgba(6,21,43,.08);
  border-radius: var(--p-r-lg);
  padding: 1.1rem 1.25rem;
  box-shadow: var(--p-sh-xs);
  transition: box-shadow var(--p-fast), transform var(--p-fast);
}

.pista-card:hover,
.pistas-home__item:hover {
  transform: translateY(-2px);
  box-shadow: var(--p-sh-sm);
}

/* ─── 18. Microinteracciones globales ──────────────────────────────────────── */
/* Hover en links de texto */
.text-link {
  color: var(--p-blue);
  font-weight: 600;
  transition: opacity var(--p-fast);
}

.text-link:hover { opacity: .75; }

/* Botones genéricos */
button, a[class*="btn"], a[class*="cta"] {
  transition:
    background var(--p-fast) var(--p-ease),
    color var(--p-fast) var(--p-ease),
    transform var(--p-fast) var(--p-ease),
    box-shadow var(--p-fast) var(--p-ease),
    border-color var(--p-fast) var(--p-ease);
}

/* Filter buttons */
.filters__btn {
  font-size: .82rem;
  font-weight: 600;
  padding: .4rem .9rem;
  border-radius: 999px;
  border: 1.5px solid rgba(6,21,43,.12);
  background: var(--p-white);
  color: var(--p-navy-mid);
  cursor: pointer;
  transition: all var(--p-fast) var(--p-ease);
}

.filters__btn:hover {
  border-color: var(--p-blue);
  color: var(--p-blue);
  background: var(--p-blue-light);
}

.filters__btn--active {
  background: var(--p-blue);
  border-color: var(--p-blue);
  color: #fff;
  box-shadow: 0 4px 12px rgba(27,111,232,.25);
}

/* ─── 19. Footer premium ────────────────────────────────────────────────────── */
.footer {
  background: var(--p-navy-deep);
  color: rgba(255,255,255,.72);
  padding: 3rem 1.5rem 1.5rem;
  margin-top: 0;
}

.footer__grid {
  display: grid;
  grid-template-columns: 1.8fr 1fr 1fr;
  gap: 2.5rem;
  max-width: 1200px;
  margin: 0 auto 2rem;
  padding-bottom: 2rem;
  border-bottom: 1px solid rgba(255,255,255,.1);
}

.footer__title {
  font-size: .75rem;
  font-weight: 700;
  letter-spacing: .1em;
  text-transform: uppercase;
  color: rgba(255,255,255,.5);
  margin-bottom: 1rem;
}

.footer__link {
  font-size: .88rem;
  color: rgba(255,255,255,.65);
  transition: color var(--p-fast);
  display: block;
  padding: .2rem 0;
}

.footer__link:hover { color: #fff; }

.footer__list { display: flex; flex-direction: column; gap: .1rem; }

.footer__legal {
  text-align: center;
  font-size: .78rem;
  color: rgba(255,255,255,.35);
  max-width: 1200px;
  margin: 0 auto;
}

.footer p {
  font-size: .88rem;
  line-height: 1.65;
  color: rgba(255,255,255,.55);
}

/* ─── 20. Toolbar premium ───────────────────────────────────────────────────── */
.estaciones-toolbar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: .75rem 0;
  margin-bottom: 1rem;
  gap: 1rem;
  flex-wrap: wrap;
}

.estaciones-toolbar__contador {
  font-size: .85rem;
  font-weight: 600;
  color: var(--p-navy-mid);
  opacity: .7;
}

.estaciones-toolbar__select {
  font-size: .85rem;
  font-weight: 500;
  border: 1.5px solid rgba(6,21,43,.12);
  border-radius: var(--p-r-sm);
  padding: .4rem .8rem;
  color: var(--p-navy);
  background: var(--p-white);
  outline: none;
  transition: border-color var(--p-fast);
}

.estaciones-toolbar__select:focus {
  border-color: var(--p-blue);
}

.estaciones-toolbar__btn {
  font-size: .82rem;
  font-weight: 600;
  color: var(--p-blue);
  transition: opacity var(--p-fast);
}

.estaciones-toolbar__btn:hover { opacity: .7; }

/* ─── 21. Pago premium ──────────────────────────────────────────────────────── */
.pago-block__title {
  font-size: .9rem;
  font-weight: 700;
  letter-spacing: -.01em;
  color: var(--p-navy);
  margin-bottom: 1.1rem;
  padding-bottom: .85rem;
  border-bottom: 1px solid rgba(6,21,43,.07);
}

.pago-field__label {
  font-size: .75rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .06em;
  color: var(--p-navy);
  display: block;
  margin-bottom: .35rem;
}

.pago-field__input {
  width: 100%;
  border: 1.5px solid rgba(6,21,43,.12);
  border-radius: var(--p-r-md);
  padding: .75rem 1rem;
  font-size: .95rem;
  background: var(--p-snow);
  color: var(--p-navy);
  outline: none;
  transition: border-color var(--p-fast), box-shadow var(--p-fast), background var(--p-fast);
}

.pago-field__input:focus {
  border-color: var(--p-blue);
  background: #fff;
  box-shadow: 0 0 0 3px rgba(27,111,232,.12);
}

.pago-metodo {
  border: 1.5px solid rgba(6,21,43,.1);
  border-radius: var(--p-r-md);
  transition: border-color var(--p-fast), background var(--p-fast);
}

.pago-metodo--selected {
  border-color: var(--p-blue) !important;
  background: var(--p-blue-light) !important;
  box-shadow: 0 0 0 3px rgba(27,111,232,.1);
}

.pago-ssl {
  font-size: .78rem;
  color: #15803d;
  display: flex;
  align-items: center;
  gap: .35rem;
  font-weight: 500;
}

.pago-btn-pagar {
  width: 100%;
  background: var(--p-blue);
  color: #fff;
  border: none;
  border-radius: var(--p-r-md);
  padding: .95rem 1.5rem;
  font-size: 1rem;
  font-weight: 700;
  cursor: pointer;
  box-shadow: var(--p-sh-blue);
  transition: background var(--p-fast), transform var(--p-fast), box-shadow var(--p-fast);
  letter-spacing: -.01em;
}

.pago-btn-pagar:hover:not(:disabled) {
  background: var(--p-blue-hover);
  transform: translateY(-1px);
  box-shadow: 0 10px 32px rgba(27,111,232,.42);
}

.pago-btn-pagar:disabled {
  opacity: .45;
  cursor: not-allowed;
}

/* ─── 22. Responsive ────────────────────────────────────────────────────────── */
@media (max-width: 760px) {
  .hero__search-v2 {
    flex-direction: column;
    border-radius: var(--p-r-lg);
    gap: .5rem;
    padding: .75rem;
  }

  .hero__sv2-sep { display: none; }
  .hero__sv2-btn { border-radius: var(--p-r-md); padding: .8rem 1.25rem; width: 100%; justify-content: center; }

  .stats-grid {
    grid-template-columns: 1fr 1fr;
  }

  .stats__item {
    border-right: none;
    border-bottom: 1px solid rgba(6,21,43,.07);
  }

  .stats__item:nth-child(odd) { border-right: 1px solid rgba(6,21,43,.07); }
  .stats__item:last-child { border-bottom: none; }

  .home-planner-cta {
    grid-template-columns: 1fr;
    padding: 1.75rem;
  }

  .home-planner-cta__bullets { grid-template-columns: 1fr; }
  .home-planner-cta__action { width: 100%; align-items: stretch; }
  .home-planner-cta__btn { width: 100%; justify-content: center; }
  .home-planner-cta__note { text-align: center; }

  .footer__grid {
    grid-template-columns: 1fr;
    gap: 1.75rem;
  }

  .forfait-configurador {
    grid-template-columns: 1fr;
  }

  .home-bottom-cta__inner {
    flex-direction: column;
    text-align: center;
  }

  .home-bottom-cta__actions {
    flex-direction: column;
    width: 100%;
  }

  .home-bottom-cta__btn--primary,
  .home-bottom-cta__btn--secondary {
    width: 100%;
    justify-content: center;
  }

  .grid-cards {
    grid-template-columns: 1fr;
  }

  .panel--form {
    padding: 1.5rem;
  }
}

@media (max-width: 480px) {
  .hero__premium-v2-inner {
    padding: 3.5rem 1rem 5rem;
  }

  .hero__title-v2 {
    font-size: 2.4rem;
  }
}

/* ─── 22a. Estaciones destacadas (home) ─────────────────────────────────────── */
.home-destacadas__header {
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  gap: 1.5rem;
  flex-wrap: wrap;
  margin-bottom: 1.75rem;
}

.home-destacadas__eyebrow {
  display: block;
  font-size: .72rem;
  font-weight: 700;
  letter-spacing: .1em;
  text-transform: uppercase;
  color: var(--p-blue);
  margin-bottom: .4rem;
}

.home-destacadas__header h2 {
  font-size: clamp(1.4rem, 3vw, 1.9rem);
  font-weight: 800;
  color: var(--p-navy);
  letter-spacing: -.04em;
  margin-bottom: .35rem;
}

.home-destacadas__header p {
  font-size: .88rem;
  color: var(--p-navy-mid);
  opacity: .7;
  max-width: 480px;
}

.home-destacadas__ver-todas-header {
  white-space: nowrap;
  font-size: .88rem;
  font-weight: 600;
  color: var(--p-blue);
  transition: opacity var(--p-fast);
  flex-shrink: 0;
}

.home-destacadas__ver-todas-header:hover { opacity: .7; }

/* Grid de 3 tarjetas en la home */
.grid-cards--destacadas {
  grid-template-columns: repeat(3, 1fr);
}

/* CTA "Ver todas" centrado */
.home-destacadas__cta-wrap {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: .65rem;
  margin-top: 2.5rem;
  padding-top: 2rem;
  border-top: 1px solid rgba(6,21,43,.07);
}

.home-destacadas__cta-btn {
  display: inline-flex;
  align-items: center;
  gap: .5rem;
  background: var(--p-blue);
  color: #fff !important;
  padding: .85rem 2rem;
  border-radius: var(--p-r-md);
  font-weight: 700;
  font-size: 1rem;
  letter-spacing: -.01em;
  box-shadow: var(--p-sh-blue);
  transition: background var(--p-fast), transform var(--p-fast), box-shadow var(--p-fast);
}

.home-destacadas__cta-btn:hover {
  background: var(--p-blue-hover);
  transform: translateY(-2px);
  box-shadow: 0 12px 36px rgba(27,111,232,.42);
}

.home-destacadas__cta-nota {
  font-size: .8rem;
  color: var(--p-navy-mid);
  opacity: .55;
  font-weight: 500;
}

/* Responsive: 1 columna en móvil */
@media (max-width: 760px) {
  .grid-cards--destacadas {
    grid-template-columns: 1fr;
  }

  .home-destacadas__header {
    flex-direction: column;
    align-items: flex-start;
    gap: .5rem;
  }

  .home-destacadas__cta-btn {
    width: 100%;
    justify-content: center;
  }
}

@media (min-width: 761px) and (max-width: 1024px) {
  .grid-cards--destacadas {
    grid-template-columns: repeat(2, 1fr);
  }
}

/* ─── 22b. Hero CTA pills ───────────────────────────────────────────────────── */
.hero__cta-pill {
  display: inline-flex;
  align-items: center;
  gap: .45rem;
  background: rgba(255,255,255,.12);
  border: 1.5px solid rgba(255,255,255,.25);
  color: rgba(255,255,255,.88) !important;
  padding: .55rem 1.1rem;
  border-radius: 999px;
  font-size: .85rem;
  font-weight: 600;
  letter-spacing: -.01em;
  backdrop-filter: blur(8px);
  transition: background var(--p-fast), border-color var(--p-fast), transform var(--p-fast);
}

.hero__cta-pill:hover {
  background: rgba(255,255,255,.2);
  border-color: rgba(255,255,255,.45);
  transform: translateY(-1px);
  color: #fff !important;
}

.hero__cta-pill--primary {
  background: rgba(27,111,232,.7);
  border-color: rgba(27,111,232,.5);
  color: #fff !important;
  box-shadow: 0 4px 16px rgba(27,111,232,.35);
}

.hero__cta-pill--primary:hover {
  background: rgba(27,111,232,.9);
  border-color: var(--p-blue);
}

/* ─── 23. Skeleton loading premium ──────────────────────────────────────────── */
.skeleton {
  background: linear-gradient(90deg, #eef2f7 25%, #f5f7fa 50%, #eef2f7 75%);
  background-size: 200% 100%;
  animation: shimmer 1.6s ease-in-out infinite;
  border-radius: var(--p-r-md);
}

@keyframes shimmer {
  0%   { background-position: 200% 0; }
  100% { background-position: -200% 0; }
}

/* ─── 24. Focus visible mejorado ────────────────────────────────────────────── */
:focus-visible {
  outline: 2.5px solid var(--p-blue);
  outline-offset: 3px;
  border-radius: var(--p-r-sm);
}

/* ─── 25. Scroll reveal (opt-in, via JS) ────────────────────────────────────── */
[data-reveal] {
  opacity: 0;
  transform: translateY(18px);
  transition: opacity var(--p-slow) var(--p-ease), transform var(--p-slow) var(--p-ease);
}

[data-reveal].is-visible {
  opacity: 1;
  transform: none;
}

/* ─── 26. Password toggle ───────────────────────────────────────────────────── */
.form-field--password-wrap { position: relative; }
.form-field--password-wrap .form-input { padding-right: 3rem; }

.password-toggle {
  position: absolute;
  right: .85rem;
  top: 50%;
  transform: translateY(-50%);
  background: none;
  border: none;
  cursor: pointer;
  color: var(--p-navy-mid);
  opacity: .5;
  padding: .25rem;
  line-height: 0;
  transition: opacity var(--p-fast);
}

.password-toggle:hover { opacity: 1; }

/* ─── 27. Noticias cards ────────────────────────────────────────────────────── */
.news-card {
  background: var(--p-white);
  border: 1px solid rgba(6,21,43,.08);
  border-radius: var(--p-r-card);
  overflow: hidden;
  box-shadow: var(--p-sh-xs);
  transition: transform var(--p-base) var(--p-ease), box-shadow var(--p-base) var(--p-ease);
}

.news-card:hover {
  transform: translateY(-4px);
  box-shadow: var(--p-sh-md);
}

.news-card__image {
  width: 100%;
  height: 200px;
  object-fit: cover;
  transition: transform var(--p-slow) var(--p-ease);
}

.news-card:hover .news-card__image {
  transform: scale(1.04);
}

.news-card__content {
  padding: 1.2rem;
}

.news-card__tag {
  font-size: .68rem;
  font-weight: 700;
  letter-spacing: .08em;
  text-transform: uppercase;
  padding: .25rem .65rem;
  border-radius: 999px;
}

.news-card__tag--nevada  { background: #e0f5ff; color: #0369a1; }
.news-card__tag--evento  { background: #ede9fe; color: #7c3aed; }
.news-card__tag--consejos { background: #fef3c7; color: #b45309; }
.news-card__tag--general  { background: #f1f5f9; color: #475569; }

.news-card__title {
  font-size: 1rem;
  font-weight: 700;
  color: var(--p-navy);
  line-height: 1.35;
  letter-spacing: -.02em;
  margin-top: .5rem;
}

.news-card__excerpt {
  font-size: .85rem;
  color: var(--p-navy-mid);
  opacity: .75;
  line-height: 1.55;
  margin-top: .4rem;
}

.news-card__more {
  font-size: .82rem;
  font-weight: 600;
  color: var(--p-blue);
  margin-top: .75rem;
  display: inline-block;
  transition: opacity var(--p-fast);
}

.news-card__more:hover { opacity: .7; }

.news-card__date {
  display: flex;
  align-items: center;
  gap: .3rem;
  font-size: .75rem;
  color: var(--p-navy-mid);
  opacity: .6;
  font-weight: 500;
}

/* ─── 28. Hero centrado ──────────────────────────────────────────────────────── */
/* Centra el bloque de contenido dentro del hero para dar aspecto premium. */
.hero__premium-v2-inner {
  text-align: center;
}

/* Centrar bloques con max-width (no se centran solo con text-align) */
.hero__title-v2,
.hero__subtitle-v2 {
  margin-left: auto;
  margin-right: auto;
}

/* El buscador se centra dentro del inner */
.hero__search-v2 {
  margin-left: auto;
  margin-right: auto;
}

/* Alinear los CTA pills al centro */
.hero__cta-secondary {
  justify-content: center;
}

/* Métricas centradas */
.hero__metrics-v2 {
  justify-content: center;
}

/* Selector de ubicación centrado */
.hero__ubic {
  display: flex;
  justify-content: center;
  margin-bottom: 1.5rem;
}

/* ─── 29. Espaciado entre secciones de la home ─────────────────────────────── */
/* La sección de stats (sin contenedor en la plantilla original) necesita
   padding vertical explícito para que no colisione visualmente con el hero. */
.stats-section {
  padding-top: 3rem;
  padding-bottom: 2rem;
}

/* Más aire entre la sección de pistas en directo y la anterior */
.pistas-home {
  padding-top: 3.5rem;
  padding-bottom: 3.5rem;
}

/* Destacadas: espacio superior consistente */
.home-destacadas__header {
  margin-top: .5rem;
}

/* ─── 30. CTA planner — evitar texto cortado ─────────────────────────────── */
/* El eyebrow "Snowbreak Trip · Ticket vivo" con letter-spacing .1em en
   uppercase puede superar el ancho del contenedor en pantallas < 420px. */
.home-planner-cta__eyebrow {
  overflow-wrap: break-word;
  word-break: break-word;
  max-width: 100%;
}

@media (max-width: 520px) {
  .home-planner-cta {
    padding: 1.5rem 1.25rem;
  }
  .home-planner-cta__eyebrow {
    letter-spacing: .04em;
  }
}

@media (max-width: 420px) {
  .home-planner-cta {
    padding: 1.25rem 1rem;
  }
  .home-planner-cta__eyebrow {
    letter-spacing: 0;
    font-size: .68rem;
  }
}

/* ─── 31. Mobile 360–420px — ajustes finos ──────────────────────────────────── */
@media (max-width: 420px) {
  /* Ocultar separadores verticales entre métricas del hero cuando el flex
     rompe a múltiples filas (quedan flotando sueltos). */
  .hero__mv2-sep {
    display: none;
  }

  /* Más gap entre items de métricas al estar en varias líneas */
  .hero__metrics-v2 {
    gap: .75rem 1rem;
  }

  /* Evitar desbordamiento horizontal en el buscador */
  .hero__search-v2 {
    max-width: 100%;
  }

  /* Menos padding interno del hero para que quede más aireado */
  .hero__premium-v2-inner {
    padding: 3rem 1rem 4.5rem;
  }

  /* Stats grid: una sola columna en móvil muy pequeño */
  .stats-grid {
    grid-template-columns: 1fr;
  }
  .home-bottom-cta {
    padding: 2.5rem 1rem;
  }
}

/* --- 32. Prevencion de scroll horizontal global -------------------------------- */
main#contenido-principal {
  overflow-x: hidden;
}
