/*
  ============================================================
  viajes.css — El Mundo de Manu / Viajes y Aventura
  ============================================================
  Estilos propios de la sección de Viajes. Heredan variables
  globales de style.css y añaden la identidad de este mundo.

  Dirección estética: cálida, aventurera, de atardecer.
  Paleta naranja-coral (#FF7E47) que evoca atardeceres,
  horizontes y la calidez de descubrir lugares nuevos.
  Verifiqué que no choca con los mundos existentes — es más
  cálido y saturado que el coral de Sobre Mí (#FF7F50),
  tirando a naranja terracota de aventura.

  Prefijo: vj- (viajes)

  Estructura:
  01. Variables locales
  02. Breadcrumb
  03. Hero (canvas de rutas + brújula)
  04. Por qué viajar
  05. Estilos de viaje
  06. Guías prácticas
  07. Checklist
  08. Herramientas
  09. Nota de seguridad
  10. CTA final
  11. Botones propios
  12. Responsive

  Autor: Carlos Manuel Turizo Hernández
  Versión: 1.0.0
  ============================================================
*/


/* ============================================================
  01. VARIABLES LOCALES
  Naranja atardecer como color principal. El gradiente del
  hero combina coral cálido con un toque dorado para evocar
  literalmente la luz de un atardecer sobre el horizonte.
  ============================================================ */
.page-viajes {
  --vj-sunset:       #FF7E47;
  --vj-sunset-light: #FFB088;
  --vj-sunset-deep:  #E85D2C;
  --vj-amber:        #FFA94D;
  --vj-dim:          rgba(255, 126, 71, 0.10);
  --vj-glow:         rgba(255, 126, 71, 0.28);
  --vj-warm-bg:      #0F0A08;   /* Fondo oscuro con calidez terracota */
}


/* ============================================================
  02. BREADCRUMB
  ============================================================ */
.breadcrumb {
  padding: calc(var(--space-4) + 70px) 0 var(--space-4);
  border-bottom: 1px solid rgba(255, 126, 71, 0.12);
  background: var(--color-bg);
}
.breadcrumb__nav { display: flex; align-items: center; gap: var(--space-2); }
.breadcrumb__link {
  font-size: var(--text-sm);
  color: var(--color-text-muted);
  transition: color var(--transition-base);
}
.breadcrumb__link:hover { color: var(--vj-sunset); }
.breadcrumb__sep { font-size: var(--text-sm); color: var(--color-text-muted); opacity: 0.4; }
.breadcrumb__current { font-size: var(--text-sm); color: var(--vj-sunset); font-weight: 500; }

.vj-tag {
  background: var(--vj-dim);
  border-color: rgba(255, 126, 71, 0.22);
  color: var(--vj-sunset-light);
}


/* ============================================================
  03. HERO DE VIAJES
  El canvas dibuja un mapa con rutas que se trazan solas —
  puntos (destinos) conectados por arcos curvos que se
  dibujan progresivamente. El fondo cálido evoca el atardecer.
  ============================================================ */
.vj-hero {
  position: relative;
  min-height: 100vh;
  display: flex;
  align-items: center;
  overflow: hidden;
  padding: var(--space-32) 0 var(--space-20);
  background:
    radial-gradient(ellipse 120% 80% at 50% 0%, rgba(255, 126, 71, 0.06) 0%, transparent 55%),
    var(--vj-warm-bg);
}

.vj-hero__canvas {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  pointer-events: none;
  opacity: 0.85;
}

.vj-hero__light {
  position: absolute;
  border-radius: 50%;
  filter: blur(120px);
  pointer-events: none;
  animation: vjLightDrift 9s ease-in-out infinite;
}
.vj-hero__light--1 {
  width: 560px; height: 320px;
  top: -60px; left: 50%;
  transform: translateX(-50%);
  background: radial-gradient(ellipse, rgba(255, 126, 71, 0.14) 0%, transparent 70%);
}
.vj-hero__light--2 {
  width: 280px; height: 280px;
  bottom: 12%; right: 8%;
  background: radial-gradient(circle, rgba(255, 169, 77, 0.09) 0%, transparent 70%);
  animation-delay: 3s;
  animation-name: vjLightDriftSimple;
}
.vj-hero__light--3 {
  width: 220px; height: 220px;
  top: 28%; left: 5%;
  background: radial-gradient(circle, rgba(232, 93, 44, 0.07) 0%, transparent 70%);
  animation-delay: 5s;
  animation-name: vjLightDriftSimple;
}
@keyframes vjLightDrift {
  0%, 100% { opacity: 1;    transform: scale(1) translateX(-50%); }
  50%       { opacity: 0.6;  transform: scale(1.1) translateX(-50%); }
}
@keyframes vjLightDriftSimple {
  0%, 100% { opacity: 1;    transform: scale(1); }
  50%       { opacity: 0.55; transform: scale(1.12); }
}

.vj-hero__symbol-wrap {
  position: absolute;
  top: 50%; left: 50%;
  transform: translate(-50%, -50%);
  pointer-events: none;
  opacity: 0.03;
  animation: vjCompassSpin 60s linear infinite;
}
.vj-hero__symbol { width: 360px; height: 360px; color: var(--vj-sunset-light); }
/* La brújula gira muy lentamente — detalle sutil de movimiento */
@keyframes vjCompassSpin {
  from { transform: translate(-50%, -50%) rotate(0deg); }
  to   { transform: translate(-50%, -50%) rotate(360deg); }
}

.vj-hero__inner { position: relative; z-index: 1; display: flex; justify-content: center; }

.vj-hero__content {
  max-width: 760px;
  text-align: center;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--space-8);
  padding: 0 var(--space-6);
}

.vj-hero__tag-row { display: flex; justify-content: center; }

/* Título con gradiente de atardecer */
.vj-hero__title {
  font-size: clamp(3.2rem, 11vw, 8rem);
  font-weight: 800;
  letter-spacing: -0.04em;
  line-height: 0.95;
  color: transparent;
  background: linear-gradient(135deg, var(--vj-sunset-light) 0%, var(--vj-sunset) 50%, var(--vj-sunset-deep) 100%);
  -webkit-background-clip: text;
  background-clip: text;
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  align-items: center;
  gap: 0.1em;
}
/* El ampersand decorativo más pequeño y elegante */
.vj-hero__title-amp {
  font-size: 0.5em;
  font-weight: 400;
  opacity: 0.7;
  margin: 0 0.1em;
}

.vj-hero__phrase {
  max-width: 560px;
  padding: var(--space-7) var(--space-9);
  border: 1px solid rgba(255, 126, 71, 0.18);
  border-left: 3px solid var(--vj-sunset);
  border-radius: var(--radius-xl);
  background: rgba(255, 126, 71, 0.04);
  position: relative;
  text-align: left;
}
.vj-hero__phrase::before {
  content: '"';
  position: absolute;
  top: -14px; left: 20px;
  font-size: 6rem;
  color: var(--vj-sunset);
  opacity: 0.10;
  line-height: 1;
  pointer-events: none;
}
.vj-hero__phrase-text {
  font-weight: 300;
  font-size: clamp(var(--text-base), 2vw, var(--text-md));
  line-height: 1.7;
  color: var(--color-text-primary);
  font-style: italic;
}
.vj-hero__phrase-ref {
  display: block;
  margin-top: var(--space-4);
  font-size: var(--text-sm);
  font-weight: 500;
  color: var(--vj-sunset);
  font-style: normal;
}

.vj-hero__desc {
  font-size: var(--text-base);
  line-height: 1.8;
  color: var(--color-text-secondary);
  max-width: 510px;
}

.vj-hero__actions { display: flex; gap: var(--space-4); justify-content: center; flex-wrap: wrap; }

.vj-hero__scroll {
  position: absolute;
  bottom: var(--space-8);
  left: 50%;
  transform: translateX(-50%);
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--space-2);
  color: var(--color-text-muted);
  font-size: var(--text-xs);
  letter-spacing: 0.1em;
  text-transform: uppercase;
  animation: vjScrollBounce 2.5s ease-in-out infinite;
  z-index: 1;
}
.vj-hero__scroll-line {
  width: 1px; height: 40px;
  background: linear-gradient(to bottom, var(--vj-sunset), transparent);
  order: -1;
}
@keyframes vjScrollBounce {
  0%, 100% { transform: translateX(-50%) translateY(0); }
  50%       { transform: translateX(-50%) translateY(8px); }
}


/* ============================================================
  04. POR QUÉ VIAJAR
  ============================================================ */
.vj-why {
  padding: var(--space-24) 0;
  background: var(--color-surface);
  border-top: 1px solid rgba(255, 126, 71, 0.10);
  border-bottom: 1px solid rgba(255, 126, 71, 0.10);
}
.vj-why__inner {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-12);
  align-items: center;
}
@media (min-width: 900px) {
  .vj-why__inner { grid-template-columns: 1.4fr 1fr; gap: var(--space-16); }
}
.vj-why__title {
  font-size: clamp(var(--text-2xl), 4vw, var(--text-3xl));
  font-weight: 800;
  letter-spacing: -0.02em;
  color: var(--color-text-primary);
  margin: var(--space-4) 0;
  line-height: 1.15;
}
.vj-why__desc {
  font-size: var(--text-base);
  line-height: 1.8;
  color: var(--color-text-secondary);
  margin-bottom: var(--space-4);
}
.vj-why__desc:last-child { margin-bottom: 0; }

.vj-why__card {
  position: relative;
  padding: var(--space-10) var(--space-8);
  background: linear-gradient(135deg, rgba(255, 126, 71, 0.07) 0%, var(--color-bg) 100%);
  border: 1px solid rgba(255, 126, 71, 0.20);
  border-radius: var(--radius-xl);
  overflow: hidden;
  display: flex;
  flex-direction: column;
  gap: var(--space-6);
}
.vj-why__card-icon { font-size: 2.25rem; line-height: 1; }
.vj-why__card-title {
  font-size: var(--text-lg);
  font-weight: 700;
  color: var(--color-text-primary);
}
.vj-why__card-list {
  list-style: none; padding: 0; margin: 0;
  display: flex; flex-direction: column; gap: var(--space-5);
}
.vj-why__card-item {
  display: flex; gap: var(--space-3); align-items: flex-start;
  font-size: var(--text-sm); line-height: 1.7;
  color: var(--color-text-secondary);
}
.vj-why__card-bullet {
  color: var(--vj-sunset-light);
  flex-shrink: 0; margin-top: 1px;
}
.vj-why__card-item strong { color: var(--color-text-primary); }
.vj-why__card-glow {
  position: absolute; inset: 0;
  background: radial-gradient(ellipse 70% 60% at 50% 110%, var(--vj-dim) 0%, transparent 100%);
  pointer-events: none;
}


/* ============================================================
  05. ESTILOS DE VIAJE
  Grid de 6 tarjetas. El elemento diferenciador es el "meta"
  al pie: tag de presupuesto con color semántico + para quién.
  El hover eleva la tarjeta y revela un acento naranja arriba.
  ============================================================ */
.vj-styles { padding: var(--space-24) 0; }

.vj-styles__grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-5);
}
@media (min-width: 640px)  { .vj-styles__grid { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 1024px) { .vj-styles__grid { grid-template-columns: repeat(3, 1fr); } }

.vj-style-card {
  position: relative;
  padding: var(--space-8);
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-xl);
  display: flex;
  flex-direction: column;
  gap: var(--space-4);
  overflow: hidden;
  transition: transform var(--transition-slow), border-color var(--transition-base),
              box-shadow var(--transition-base);
}
/* Línea de acento superior que se revela en hover */
.vj-style-card::before {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 3px;
  background: linear-gradient(90deg, var(--vj-sunset), var(--vj-amber));
  transform: scaleX(0);
  transform-origin: left;
  transition: transform var(--transition-slow);
}
.vj-style-card:hover {
  transform: translateY(-6px);
  border-color: rgba(255, 126, 71, 0.38);
  box-shadow: 0 12px 40px rgba(0,0,0,0.35), 0 0 22px var(--vj-dim);
}
.vj-style-card:hover::before { transform: scaleX(1); }

.vj-style-card__icon-wrap {
  width: 52px; height: 52px;
  display: flex; align-items: center; justify-content: center;
  background: var(--vj-dim);
  border: 1px solid rgba(255, 126, 71, 0.18);
  border-radius: var(--radius-md);
  color: var(--vj-sunset-light);
  flex-shrink: 0;
  transition: transform var(--transition-spring);
}
.vj-style-card:hover .vj-style-card__icon-wrap {
  transform: rotate(-8deg) scale(1.08);
}

.vj-style-card__title {
  font-size: var(--text-lg);
  font-weight: 700;
  color: var(--color-text-primary);
}
.vj-style-card__desc {
  font-size: var(--text-sm);
  line-height: 1.78;
  color: var(--color-text-secondary);
  flex: 1;
}

.vj-style-card__meta {
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
  padding-top: var(--space-4);
  border-top: 1px solid var(--color-border);
}
/* Tag de presupuesto con color semántico */
.vj-style-card__budget {
  width: fit-content;
  padding: 3px var(--space-3);
  border-radius: var(--radius-full);
  font-size: var(--text-xs);
  font-weight: 700;
  letter-spacing: 0.03em;
}
.vj-style-card__budget--low  { background: rgba(56,181,151,0.14);  color: #5DD9B4; border: 1px solid rgba(56,181,151,0.25); }
.vj-style-card__budget--mid  { background: rgba(255,169,77,0.14);  color: var(--vj-amber); border: 1px solid rgba(255,169,77,0.25); }
.vj-style-card__budget--high { background: rgba(255,126,71,0.14);  color: var(--vj-sunset-light); border: 1px solid rgba(255,126,71,0.25); }

.vj-style-card__ideal {
  font-size: var(--text-xs);
  color: var(--color-text-muted);
  line-height: 1.5;
}


/* ============================================================
  06. GUÍAS PRÁCTICAS
  Tarjetas tipo artículo con recuadro de tips y un highlight.
  La primera es featured (ancho completo en desktop).
  ============================================================ */
.vj-guides {
  padding: var(--space-24) 0;
  background: var(--color-surface);
  border-top: 1px solid var(--color-border);
  border-bottom: 1px solid var(--color-border);
}
.vj-guides__grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-6);
}
@media (min-width: 900px) {
  .vj-guides__grid { grid-template-columns: repeat(2, 1fr); }
  .vj-guide-card--featured { grid-column: span 2; }
}

.vj-guide-card {
  padding: var(--space-8);
  background: var(--color-bg);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-xl);
  display: flex;
  flex-direction: column;
  gap: var(--space-5);
  transition: transform var(--transition-slow), border-color var(--transition-base);
}
.vj-guide-card:hover {
  transform: translateY(-3px);
  border-color: rgba(255, 126, 71, 0.30);
}
.vj-guide-card--featured { border-top: 3px solid var(--vj-sunset); }

.vj-guide-card__header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: var(--space-2);
}
.vj-guide-card__tag {
  padding: var(--space-1) var(--space-3);
  background: var(--vj-dim);
  border: 1px solid rgba(255, 126, 71, 0.22);
  border-radius: var(--radius-full);
  font-size: var(--text-xs);
  font-weight: 700;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--vj-sunset-light);
}
.vj-guide-card__read { font-size: var(--text-xs); color: var(--color-text-muted); }

.vj-guide-card__title {
  font-size: clamp(var(--text-lg), 2.2vw, var(--text-xl));
  font-weight: 700;
  line-height: 1.3;
  color: var(--color-text-primary);
  letter-spacing: -0.01em;
}
.vj-guide-card__body {
  font-size: var(--text-sm);
  line-height: 1.82;
  color: var(--color-text-secondary);
}

.vj-guide-card__inset {
  padding: var(--space-6);
  background: var(--vj-dim);
  border: 1px solid rgba(255, 126, 71, 0.18);
  border-radius: var(--radius-lg);
}
.vj-guide-card__inset-title {
  font-size: var(--text-sm);
  font-weight: 700;
  color: var(--vj-sunset-light);
  margin-bottom: var(--space-4);
}
.vj-guide-card__list {
  list-style: none; padding: 0; margin: 0;
  display: flex; flex-direction: column; gap: var(--space-3);
}
.vj-guide-card__list li {
  font-size: var(--text-sm);
  line-height: 1.7;
  color: var(--color-text-secondary);
  padding-left: var(--space-5);
  position: relative;
}
.vj-guide-card__list li::before {
  content: '→';
  position: absolute; left: 0; top: 2px;
  color: var(--vj-sunset);
  font-weight: 700;
  font-size: var(--text-xs);
}
.vj-guide-card__list li strong { color: var(--color-text-primary); }

.vj-guide-card__highlight {
  font-size: var(--text-sm);
  line-height: 1.7;
  color: var(--color-text-secondary);
  padding: var(--space-5) var(--space-6);
  border-left: 2px solid var(--vj-sunset);
  border-radius: 0 var(--radius-sm) var(--radius-sm) 0;
  background: rgba(255, 126, 71, 0.04);
  font-style: italic;
}


/* ============================================================
  07. CHECKLIST PRE-VIAJE
  4 columnas de listas con encabezado de categoría.
  Cada item tiene un checkbox decorativo (CSS puro).
  ============================================================ */
.vj-checklist { padding: var(--space-24) 0; }

.vj-checklist__grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-5);
}
@media (min-width: 600px)  { .vj-checklist__grid { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 1024px) { .vj-checklist__grid { grid-template-columns: repeat(4, 1fr); } }

.vj-checklist__col {
  padding: var(--space-7) var(--space-6);
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-xl);
  transition: transform var(--transition-slow), border-color var(--transition-base);
}
.vj-checklist__col:hover {
  transform: translateY(-4px);
  border-color: rgba(255, 126, 71, 0.30);
}
.vj-checklist__col-head {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  margin-bottom: var(--space-5);
  padding-bottom: var(--space-4);
  border-bottom: 1px solid var(--color-border);
}
.vj-checklist__col-icon { font-size: 1.6rem; line-height: 1; }
.vj-checklist__col-title {
  font-size: var(--text-md);
  font-weight: 700;
  color: var(--color-text-primary);
}
.vj-checklist__items {
  list-style: none; padding: 0; margin: 0;
  display: flex; flex-direction: column; gap: var(--space-3);
}
.vj-checklist__items li {
  font-size: var(--text-sm);
  line-height: 1.5;
  color: var(--color-text-secondary);
  padding-left: var(--space-6);
  position: relative;
}
/* Checkbox decorativo — cuadrito con check naranja */
.vj-checklist__items li::before {
  content: '';
  position: absolute;
  left: 0; top: 3px;
  width: 14px; height: 14px;
  border: 1.5px solid rgba(255, 126, 71, 0.4);
  border-radius: 3px;
  background: var(--vj-dim);
}
.vj-checklist__items li::after {
  content: '✓';
  position: absolute;
  left: 2px; top: 0;
  font-size: 11px;
  color: var(--vj-sunset);
  font-weight: 700;
}


/* ============================================================
  08. HERRAMIENTAS
  Grid de 3 columnas con tarjetas verticales (ícono arriba).
  Diferente layout al de recursos de otras secciones —
  aquí van en grid de 3 y centradas para variar.
  ============================================================ */
.vj-tools {
  padding: var(--space-24) 0;
  background: var(--color-surface);
  border-top: 1px solid var(--color-border);
  border-bottom: 1px solid var(--color-border);
}
.vj-tools__grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-5);
}
@media (min-width: 640px)  { .vj-tools__grid { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 1024px) { .vj-tools__grid { grid-template-columns: repeat(3, 1fr); } }

.vj-tool-card {
  display: flex;
  gap: var(--space-5);
  padding: var(--space-6);
  background: var(--color-bg);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-xl);
  transition: transform var(--transition-slow), border-color var(--transition-base);
}
.vj-tool-card:hover {
  transform: translateY(-4px);
  border-color: rgba(255, 126, 71, 0.30);
}
.vj-tool-card__icon {
  font-size: 2rem;
  width: 48px; height: 48px;
  display: flex; align-items: center; justify-content: center;
  background: var(--color-surface);
  border-radius: var(--radius-md);
  flex-shrink: 0;
}
.vj-tool-card__info { flex: 1; }
.vj-tool-card__type {
  display: block;
  font-size: var(--text-xs);
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--vj-sunset-light);
  margin-bottom: var(--space-1);
}
.vj-tool-card__title {
  font-size: var(--text-base);
  font-weight: 700;
  color: var(--color-text-primary);
  margin-bottom: var(--space-2);
  line-height: 1.3;
}
.vj-tool-card__desc {
  font-size: var(--text-sm);
  line-height: 1.7;
  color: var(--color-text-secondary);
}


/* ============================================================
  09. NOTA DE SEGURIDAD
  ============================================================ */
.vj-note { padding: var(--space-10) 0; border-top: 1px solid var(--color-border); }
.vj-note__inner {
  display: flex;
  gap: var(--space-4);
  align-items: flex-start;
  padding: var(--space-6) var(--space-8);
  background: rgba(255, 126, 71, 0.04);
  border: 1px solid rgba(255, 126, 71, 0.14);
  border-radius: var(--radius-xl);
}
.vj-note__icon { color: var(--vj-sunset); flex-shrink: 0; opacity: 0.8; margin-top: 2px; }
.vj-note__text {
  font-size: var(--text-sm);
  line-height: 1.75;
  color: var(--color-text-muted);
}
.vj-note__text strong { color: var(--vj-sunset-light); }


/* ============================================================
  10. CTA FINAL
  ============================================================ */
.vj-cta { padding: var(--space-24) 0; }
.vj-cta__inner {
  position: relative;
  max-width: 640px;
  margin: 0 auto;
  text-align: center;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--space-6);
  padding: var(--space-14) var(--space-10);
  background: var(--color-surface);
  border: 1px solid rgba(255, 126, 71, 0.18);
  border-radius: var(--radius-xl);
  overflow: hidden;
}
.vj-cta__glow {
  position: absolute; inset: 0;
  background: radial-gradient(ellipse 65% 65% at 50% 50%, rgba(255, 126, 71, 0.07) 0%, transparent 100%);
  pointer-events: none;
}
.vj-cta__icon {
  font-size: 3rem;
  position: relative;
  animation: vjIconFloat 4s ease-in-out infinite;
}
/* El globo flota suavemente arriba y abajo */
@keyframes vjIconFloat {
  0%, 100% { transform: translateY(0); }
  50%       { transform: translateY(-8px); }
}
.vj-cta__title {
  font-size: clamp(var(--text-2xl), 4vw, var(--text-3xl));
  font-weight: 800;
  letter-spacing: -0.02em;
  line-height: 1.2;
  color: var(--color-text-primary);
  position: relative;
}
.vj-cta__highlight {
  color: transparent;
  background: linear-gradient(135deg, var(--vj-sunset-light), var(--vj-sunset));
  -webkit-background-clip: text;
  background-clip: text;
}
.vj-cta__desc {
  font-size: var(--text-base);
  line-height: 1.75;
  color: var(--color-text-secondary);
  max-width: 490px;
  position: relative;
}
.vj-cta__actions {
  display: flex; gap: var(--space-4);
  flex-wrap: wrap; justify-content: center;
  position: relative;
}


/* ============================================================
  11. BOTONES PROPIOS
  ============================================================ */
.vj-btn--primary {
  background: var(--vj-sunset);
  color: #2A1206;
  font-weight: 700;
  box-shadow: 0 4px 20px var(--vj-glow);
}
.vj-btn--primary:hover {
  background: var(--vj-sunset-light);
  box-shadow: 0 6px 28px rgba(255, 126, 71, 0.45);
  transform: translateY(-2px);
  color: #2A1206;
}
.vj-btn--ghost {
  border-color: rgba(255, 126, 71, 0.28);
  color: var(--vj-sunset-light);
}
.vj-btn--ghost:hover {
  border-color: var(--vj-sunset);
  background: var(--vj-dim);
  color: var(--vj-sunset-light);
}


/* ============================================================
  12. RESPONSIVE
  ============================================================ */
@media (max-width: 640px) {
  .vj-hero { padding: var(--space-20) 0 var(--space-16); min-height: auto; }
  .vj-hero__title { font-size: clamp(2.6rem, 15vw, 4.5rem); }
  .vj-hero__phrase { padding: var(--space-6) var(--space-5); }
  .vj-hero__phrase::before { font-size: 4rem; }
  .vj-hero__actions { flex-direction: column; align-items: center; width: 100%; }
  .vj-hero__actions .btn { width: 100%; justify-content: center; }

  .vj-cta__inner { padding: var(--space-10) var(--space-6); }
  .vj-cta__actions { flex-direction: column; align-items: center; width: 100%; }
  .vj-cta__actions .btn { width: 100%; justify-content: center; }

  .vj-note__inner { flex-direction: column; padding: var(--space-5) var(--space-6); }
}

@media (max-width: 480px) {
  .vj-why__card { padding: var(--space-7) var(--space-6); }
  .vj-style-card { padding: var(--space-6); }
  .vj-guide-card { padding: var(--space-6); }
  .vj-guide-card__inset { padding: var(--space-5); }
}

/* Footer link activo */
.footer__link--active { color: var(--vj-sunset-light); }
