/* tweaks.css — UNIFICADO (aprobado)
   Objetivo:
   - Mantener ajustes validados (chips, quitar “ojos” en cards, etc.)
   - Nav: hover pastel + activo discreto + aire
   - Botones: unificar altura/padding/hover/focus
   Nota: no toca layout global (eso vive en system.css)
*/


/* =========================
   NAV — fijo (no desaparece al hacer scroll)
   ========================= */
:root{ --nav-reserve: 0px; }
nav{
  position: sticky;
  top: 0;
  z-index: 1000;
  margin-bottom: 0;
  box-shadow: 0 8px 24px rgba(15,23,42,0.06);

  /* Fondo glass */
  background: rgba(15,23,42,0.72);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  border-bottom: 1px solid rgba(148,163,184,0.18);
}


/* ✅ FIX robusto: asegurar que la barra NUNCA se queda “clara” en modo oscuro */
@media (prefers-color-scheme: dark){
  html:not([data-theme="light"]) nav{
    background: rgba(15,23,42,0.72) !important;
    border-bottom-color: rgba(148,163,184,0.14) !important;
    box-shadow: 0 10px 30px rgba(0,0,0,0.28) !important;
  }
  html:not([data-theme="light"]) nav a[aria-current="page"]{
    background: rgba(255,255,255,0.08) !important;
    border-color: rgba(148,163,184,0.22) !important;
    box-shadow: 0 1px 2px rgba(0,0,0,0.18) !important;
  }
}

html[data-theme="dark"] nav{
  background: rgba(15,23,42,0.72) !important;
  border-bottom-color: rgba(148,163,184,0.14) !important;
  box-shadow: 0 10px 30px rgba(0,0,0,0.28) !important;
}

html[data-theme="dark"] nav a[aria-current="page"]{
  background: rgba(255,255,255,0.08) !important;
  border-color: rgba(148,163,184,0.22) !important;
  box-shadow: 0 1px 2px rgba(0,0,0,0.18) !important;
}
/* Reservamos espacio para que el contenido no quede debajo de la barra */
@media (max-width: 520px){
  :root{ --nav-reserve: 0px; }
}
/* =========================
   NAV (hover pastel + activo)
   ========================= */

nav{ margin-bottom: 0 !important; }

nav ul{
  padding: 0 !important;
  gap: 0.55rem !important;
}

nav .navInner{
  /* Alineación con el contenido (.container):
     .navInner ya aplica el mismo ancho que .container
     (calc(100% - --content-pad*2)), así que NO añadimos padding horizontal.
     Solo ajustamos el padding vertical.
  */
  padding: 0.65rem 0 !important;
  gap: 1rem !important;
}

nav a{
  padding: 0.46rem 0.95rem !important;
  border-radius: 999px !important;
  line-height: 1 !important;
  font-weight: 500 !important;
  text-decoration: none !important;
}

nav a:hover{
  background: rgba(var(--accent-warm-rgb) / 0.24) !important;
}

nav a:focus-visible{
  outline: 2px solid rgba(var(--accent-warm-rgb) / 0.55) !important;
  outline-offset: 2px !important;
  background: rgba(var(--accent-warm-rgb) / 0.18) !important;
}

nav a[aria-current="page"]{
  background: rgba(255,255,255,0.82) !important;
  border: 1px solid rgba(148, 163, 184, 0.25) !important;
  box-shadow: 0 1px 2px rgba(15,23,42,0.06) !important;
}

/* =========================
   NAV — móvil (hamburguesa + fixed)
   Motivo: en iOS/Safari, sticky a veces se rompe con blur/backdrop.
   ========================= */

nav .navRight{
  display:flex;
  align-items:center;
  gap:0.55rem;
}

.navToggle{
  display:none;
  align-items:center;
  justify-content:center;
  width:42px;
  height:42px;
  border-radius:12px;
  border:1px solid rgba(148,163,184,0.22);
  background: rgba(255,255,255,0.06);
  color: var(--text-main);
}


/* Icono hamburguesa consistente (3 líneas, CSS) */
.burger{
  width:18px;
  height:2px;
  background: currentColor;
  border-radius:999px;
  display:inline-block;
  position:relative;
  opacity:0.92;
}
.burger::before,
.burger::after{
  content:"";
  position:absolute;
  left:0;
  right:0;
  height:2px;
  background: currentColor;
  border-radius:999px;
  opacity:0.92;
}
.burger::before{ top:-6px; }
.burger::after{ top:6px; }

/* Estado abierto: se transforma en X */
nav[data-open] .burger{ background: transparent; }
nav[data-open] .burger::before{ top:0; transform: rotate(45deg); }
nav[data-open] .burger::after{ top:0; transform: rotate(-45deg); }

@media (max-width: 820px){
  /* Barra fija para que no “baje” por bugs de sticky en móvil */
  nav{ position:fixed !important; left:0; right:0; top:0; }
  body{ padding-top: var(--nav-reserve, 64px); }

  nav .navInner{
    flex-wrap:nowrap !important;
    align-items:center !important;
  }

  /* Mostrar hamburguesa */
  .navToggle{ display:inline-flex; }

  /* Menú colapsado por defecto */
  nav ul#primaryNav{
    display:none !important;
    width:100%;
    flex-direction:column;
    align-items:stretch;
    justify-content:flex-start;
    gap:0.35rem !important;
    padding:0.25rem 0 0.75rem !important;
  }

  nav.is-open ul#primaryNav{ display:flex !important; }

  nav ul#primaryNav a{
    width:100%;
    justify-content:flex-start;
    padding:0.72rem 0.95rem !important;
    border-radius:14px !important;
  }
}

@media (max-width: 520px){
  nav .navInner{ padding: 0.6rem 0 !important; }
  nav a{ padding: 0.44rem 0.85rem !important; }
}

/* =========================
   BOTONES (unificar)
   ========================= */

.btn{
  display: inline-flex;
  vertical-align: middle;
  align-items: center;
  justify-content: center;
  gap: 0.5rem;

  min-height: 44px;
  padding: 0.60rem 1.05rem;

  /* Menos “pastilla” = más serio */
  border-radius: 10px;

  font-weight: 600;
  line-height: 1.05;
  cursor: pointer;

  border: 1px solid rgba(148,163,184,0.55);
  background: rgba(255,255,255,0.92);

  /* Sombra muy sutil + brillo interno (look más “premium”) */
  box-shadow:
    0 1px 0 rgba(255,255,255,0.75) inset,
    0 1px 2px rgba(15,23,42,0.06);

  text-decoration: none;
  transition:
    transform 180ms ease,
    box-shadow 180ms ease,
    background-color 140ms ease,
    border-color 140ms ease,
    filter 140ms ease;
}

.btn:hover{
  transform: translateY(-1px);
  border-color: rgba(148,163,184,0.70);
  box-shadow:
    0 1px 0 rgba(255,255,255,0.78) inset,
    0 6px 18px rgba(15,23,42,0.10);
}

.btn:active{
  transform: translateY(0);
  box-shadow:
    0 1px 0 rgba(255,255,255,0.70) inset,
    0 3px 12px rgba(15,23,42,0.10);
}

.btn:focus-visible{
  outline: 2px solid rgba(var(--accent-rgb) / 0.35);
  outline-offset: 4px;
}

/* Primary (más contraste, menos “pastel”) */
.btn--primary{
  background: color-mix(in srgb, rgb(var(--accent-rgb)) 86%, #000 14%) !important;
  border-color: rgba(var(--accent-rgb) / 0.52) !important;
  color: #fff !important;

  box-shadow:
    0 1px 0 rgba(255,255,255,0.18) inset,
    0 8px 22px rgba(15,23,42,0.14) !important;
}

.btn--primary:hover{
  filter: brightness(0.98) saturate(1.06);
  box-shadow:
    0 1px 0 rgba(255,255,255,0.20) inset,
    0 10px 26px rgba(15,23,42,0.16) !important;
}

/* Ghost (más “serio”: sin cajita blanca) */
.btn--ghost{
  background: transparent !important;
  border-color: rgba(var(--accent-rgb) / 0.45) !important;
  color: rgb(var(--accent-rgb)) !important;
  box-shadow: none !important;
}

.btn--ghost:hover{
  background: rgba(var(--accent-rgb) / 0.08) !important;
  border-color: rgba(var(--accent-rgb) / 0.55) !important;
  box-shadow: none !important;
}

/* WhatsApp (visible pero sobrio) */
.btn--whatsapp{
  /* Un poco de fondo para que no “desaparezca” */
  background: rgba(37, 211, 102, 0.08) !important;
  border-color: rgba(37, 211, 102, 0.70) !important;

  /* Verde más “WhatsApp” y más legible */
  color: rgb(20, 120, 67) !important;

  box-shadow: none !important;
}

.btn--whatsapp:hover{
  background: rgba(37, 211, 102, 0.12) !important;
  border-color: rgba(37, 211, 102, 0.82) !important;
  filter: saturate(1.05);
  box-shadow: none !important;
}


/* =========================
   CHIPS (Motivos de consulta)
   ========================= */

/* Objetivo:
   - Que se vean “clicables” incluso sin sombras (móvil)
   - Más aire entre chips
   - Borde/acento cálido (pastel) + feedback claro al tocar
*/

.chips{
  justify-content: center;
  gap: 1rem;
  row-gap: 0.9rem;
  margin-top: 1.25rem;
  margin-bottom: 1.25rem;
}

.chips li{ margin: 0; }

.chips a{
  padding: 0.6rem 1.15rem;
  padding-right: 1.65rem; /* espacio para el chevron › */
  border-radius: 14px;

  background: color-mix(in srgb, white 88%, rgb(var(--accent-warm-rgb)) 12%) !important;
  border: 1px solid rgba(var(--accent-warm-rgb) / 0.34) !important;

  /* “botón” suave, sin ruido */
  box-shadow:
    0 1px 0 rgba(255,255,255,0.80) inset,
    0 1px 2px rgba(15,23,42,0.06) !important;

  transition: transform 140ms ease, background-color 160ms ease, border-color 160ms ease, box-shadow 160ms ease;
}

@supports not (color-mix(in srgb, white 50%, black 50%)){
  .chips a{
    background: rgba(255,255,255,0.92) !important;
  }
}

.chips a:hover,
.chips a:focus-visible{
  background: rgba(var(--accent-warm-rgb) / 0.18) !important;
  border-color: rgba(var(--accent-warm-rgb) / 0.52) !important;
  box-shadow:
    0 1px 0 rgba(255,255,255,0.72) inset,
    0 3px 10px rgba(15,23,42,0.10) !important;
  transform: translateY(-1px);
}

.chips a:active{
  background: rgba(var(--accent-warm-rgb) / 0.24) !important;
  border-color: rgba(var(--accent-warm-rgb) / 0.62) !important;
  transform: translateY(0);
  box-shadow:
    0 1px 0 rgba(255,255,255,0.60) inset,
    0 1px 2px rgba(15,23,42,0.08) !important;
}

.chips a::before{ display: none !important; }

.chips + p{ margin-top: 0.75rem; }



/* =========================
   MOTIVOS / CONSULTAS — lista (cards-link)
   ========================= */

.motivos-links{
  display: grid;
  gap: 1rem;
  margin-top: 1rem;
}

/* En móvil, un pelín menos de aire */
@media (max-width: 520px){
  .motivos-links{ gap: 0.85rem; }
}

/* =========================
   TARJETAS (Terapias) — quitar “ojos”
   ========================= */

.card-icon,
.card-icon::after{
  display: none !important;
}

/* Acento lateral más sutil */
.card-link::before{
  opacity: 0.25 !important;
}

/* =========================
   HERO — seguridad si quedasen marcadores
   ========================= */

.hero__noteIcon,
.hero__dot{
  display: none !important;
}

/* =========================
   RAIL UNIVERSAL (aire + evitar colapso)
   ========================= */

main.container.sectionSpacing{
  padding-top: calc(1.25rem + var(--nav-reserve)) !important;
  padding-bottom: 1.25rem !important;
  display: grid !important;
  gap: var(--section-gap) !important;
}

main.container.sectionSpacing > section:first-child{
  margin-top: 0 !important;
}

/* =========================
   PAGE HERO — aire entre texto y botones
   (en algunas páginas se veía “apretado”)
   ========================= */

.pageHero__cta{
  margin-top: 1.15rem !important;
  margin-bottom: 0 !important;
}

/* En móviles un pelín más de aire */
@media (max-width: 520px){
  .pageHero__cta{ margin-top: 1.25rem !important; }
}

/* =========================
   BACK LINK — “Volver” en páginas internas (Motivos)
   ========================= */

.back-link{
  display: inline-flex;
  align-items: center;
  gap: 0.45rem;

  padding: 0.45rem 0.75rem;
  border-radius: 999px;
  line-height: 1;
  font-weight: 500;

  background: rgba(255,255,255,0.92);
  border: 1px solid rgba(148,163,184,0.30);
  color: var(--text-main);
  text-decoration: none;

  box-shadow: 0 1px 2px rgba(15,23,42,0.06);
  transition: background-color 180ms ease, border-color 180ms ease, box-shadow 180ms ease, transform 140ms ease;
}

.back-link:hover{
  background: rgba(255,255,255,0.98);
  border-color: rgba(148,163,184,0.46);
  box-shadow: 0 3px 10px rgba(15,23,42,0.10);
  transform: translateY(-1px);
}

.back-link:active{
  transform: translateY(0);
  box-shadow: 0 2px 8px rgba(15,23,42,0.10);
}

.back-link:focus-visible{
  outline: 2px solid rgba(var(--accent-rgb) / 0.55) !important;
  outline-offset: 2px !important;
}

/* =========================
   NAV (dark override)
   Evita que el “activo” se vea claro y cambie el tono del texto entre Auto/Noche
   ========================= */

/* Auto (sigue el sistema oscuro) */
@media (prefers-color-scheme: dark){
  html:not([data-theme="light"]) nav a{
    color: rgba(226,232,240,0.88) !important;
  }
  html:not([data-theme="light"]) nav a:hover{
    background: rgba(244,176,138,0.16) !important;
  }
  html:not([data-theme="light"]) nav a[aria-current="page"]{
    background: rgba(2,6,23,0.34) !important;
    border: 1px solid rgba(148,163,184,0.18) !important;
    box-shadow: none !important;
    color: rgba(226,232,240,0.96) !important;
  }
}

/* Forzado noche */
html[data-theme="dark"] nav a{
  color: rgba(226,232,240,0.88) !important;
}
html[data-theme="dark"] nav a:hover{
  background: rgba(244,176,138,0.16) !important;
}
html[data-theme="dark"] nav a[aria-current="page"]{
  background: rgba(2,6,23,0.34) !important;
  border: 1px solid rgba(148,163,184,0.18) !important;
  box-shadow: none !important;
  color: rgba(226,232,240,0.96) !important;
}

/* --- FIX móvil (iOS/Safari): backdrop-filter en nav fixed puede bloquear taps en el resto de la página --- */
@media (hover: none) and (pointer: coarse){
  nav{
    -webkit-backdrop-filter: none !important;
    backdrop-filter: none !important;
  }
  /* Mantén fondo sólido para evitar “glass” raro sin blur */
  html[data-theme="light"] nav{ background: rgba(242,244,248,0.98) !important; }
  html[data-theme="dark"]  nav{ background: rgba(15,23,42,0.88) !important; }
  @media (prefers-color-scheme: dark){
    html:not([data-theme="light"]) nav{ background: rgba(15,23,42,0.88) !important; }
  }
}

/* --- Click affordance: modalidad cards (siempre visible) --- */
/* En móvil no existe hover, así que el indicador debe verse siempre. */
.modalityCard{ position: relative; }

.modalityCard::after{
  content:"→";
  position:absolute;
  top:1rem;
  right:1rem;
  font-size:1.05rem;
  line-height:1;
  opacity:.62;
  transform: translateX(0);
  transition: opacity .15s ease, transform .15s ease;
  pointer-events:none;

  color: var(--modality-arrow-color);
}

@media (hover:hover){
  .modalityCard:hover::after{
    opacity:.88;
    transform: translateX(2px);
  }
}

@media (hover:none){
  .modalityCard::after{
    opacity:.78; /* más visible en táctil */
  }
}


/* =========================
   Modality arrow colors (claro/noche/auto)
   - Claro: azul (--accent)
   - Noche: naranja (--accent-warm)
   - Auto: depende de prefers-color-scheme
   ========================= */
:root{
  --modality-arrow-color: var(--accent);
}
html[data-theme="light"]{
  --modality-arrow-color: var(--accent);
}
html[data-theme="dark"]{
  --modality-arrow-color: var(--accent-warm);
}
/* Auto (si el sistema está en oscuro → naranja) */
@media (prefers-color-scheme: dark){
  html[data-theme="auto"], html:not([data-theme]){
    --modality-arrow-color: var(--accent-warm);
  }
}
@media (prefers-color-scheme: light){
  html[data-theme="auto"], html:not([data-theme]){
    --modality-arrow-color: var(--accent);
  }
}



/* NAV fijo SOLO en escritorio (evita solapar en móvil) */
@media (min-width: 960px){
  :root{ --nav-reserve: 64px; }
  nav{
    position: fixed;
    left: 0;
    right: 0;
    width: 100%;
  }
  main.container.sectionSpacing{
    padding-top: calc(var(--space-7) + var(--nav-reserve));
  }
}
/* ===== NAV DESKTOP: mostrar menú en línea, ocultar hamburguesa ===== */ /* HOTFIX (2025-12-29): Desktop nav forced inline because mobile popover CSS hides links on ≥821px */

@media (min-width: 821px) {
  .navToggle { display: none !important; }
  .navOverlay { display: none !important; }

  /* El menú deja de ser popover y pasa a barra horizontal */
  .navMenu {
    position: static !important;
    display: flex !important;
    align-items: center;
    gap: 10px;

    width: auto !important;
    padding: 0 !important;

    background: transparent !important;
    border: 0 !important;
    box-shadow: none !important;
    backdrop-filter: none !important;
    -webkit-backdrop-filter: none !important;

    transform: none !important;
    opacity: 1 !important;
    pointer-events: auto !important;
  }

  .navMenu__item {
    padding: 10px 12px;
    border-radius: 999px;
    text-decoration: none;
    color: var(--text-muted);
  }

  .navMenu__item:hover {
    color: var(--text-bright);
    background: rgba(255,255,255,0.05);
  }

  .navMenu__item--cta {
    border: 1px solid rgba(255,255,255,0.10);
    background: rgba(255,255,255,0.03);
    color: var(--text-bright);
  }
}
