/* =========================================================
   Santuario de Nuestra Señora de Guadalupe — Carson, CA
   Estética clásica (inspirada en vatican.va):
   pergamino, tipografía con serifas, dorado y verde litúrgico.
   ========================================================= */

:root {
  /* Colores */
  --tinta:        #26231c;   /* texto */
  --tinta-suave:  #5d564a;
  --pergamino:    #f6f1e7;   /* fondo */
  --pergamino-osc:#efe7d4;
  --blanco:       #fffdf8;
  --verde:        #1d5a4e;   /* manto guadalupano / litúrgico */
  --verde-osc:    #143f37;
  --verde-claro:  #2e7367;
  --oro:          #9c7c33;
  --oro-claro:    #c2a04e;
  --vino:         #6e1f2a;   /* acento solemne */
  --linea:        #ddd1b6;
  --linea-suave:  #e8dfca;

  /* Tipografía con serifas */
  --serif-display: "Cormorant Garamond", Georgia, "Times New Roman", serif;
  --serif-texto: "EB Garamond", Georgia, "Times New Roman", serif;

  --ancho: 1140px;
  --ancho-lectura: 760px;
  --sombra: 0 8px 26px rgba(20, 63, 55, 0.08);
  --transicion: 0.25s ease;
}

/* ---------- Reset ---------- */
*, *::before, *::after { box-sizing: border-box; }
html { scroll-behavior: smooth; -webkit-text-size-adjust: 100%; }
body {
  margin: 0;
  font-family: var(--serif-texto);
  color: var(--tinta);
  background: var(--pergamino);
  line-height: 1.7;
  font-size: 19px;
}
img { max-width: 100%; display: block; }
a { color: var(--verde); text-decoration: none; transition: color var(--transicion); }
a:hover { color: var(--oro); }

h1, h2, h3, h4 { font-family: var(--serif-display); font-weight: 600; line-height: 1.12; color: var(--verde-osc); margin: 0 0 .5em; }
h1 { font-size: clamp(2.6rem, 5.5vw, 4.4rem); font-weight: 700; letter-spacing: .5px; }
h2 { font-size: clamp(2rem, 3.8vw, 3rem); }
h3 { font-size: 1.7rem; }
h4 { font-size: 1.3rem; }
p { margin: 0 0 1.1em; }

/* ---------- Utilidades ---------- */
.contenedor { width: min(100% - 2.6rem, var(--ancho)); margin-inline: auto; }
.seccion { padding: clamp(3.5rem, 7vw, 6.5rem) 0; }
.seccion--pergamino { background: var(--pergamino-osc); }
.seccion--verde { background: var(--verde-osc); color: var(--pergamino); }
.seccion--verde h2, .seccion--verde h3, .seccion--verde h4 { color: var(--blanco); }
.centrado { text-align: center; }

/* Etiqueta de sección en versalitas con filetes dorados */
.eyebrow {
  display: inline-flex; align-items: center; gap: .9rem;
  font-family: var(--serif-texto);
  text-transform: uppercase; letter-spacing: .28em;
  font-size: .82rem; font-weight: 600; color: var(--oro);
  margin-bottom: 1rem;
}
.eyebrow::before, .eyebrow::after { content: ""; width: 34px; height: 1px; background: var(--oro); opacity: .7; }
.seccion--verde .eyebrow { color: var(--oro-claro); }
.seccion--verde .eyebrow::before, .seccion--verde .eyebrow::after { background: var(--oro-claro); }

.lead { font-size: 1.25rem; color: var(--tinta-suave); max-width: 64ch; font-style: italic; }
.centrado .lead { margin-inline: auto; }
.seccion--verde .lead { color: rgba(255,253,248,.9); }

/* Ornamento: cruz dorada entre filetes */
.adorno { display: flex; align-items: center; justify-content: center; gap: 1rem; margin: 1.2rem 0 2.2rem; color: var(--oro); }
.adorno::before, .adorno::after { content: ""; height: 1px; width: 70px; background: linear-gradient(90deg, transparent, var(--oro)); }
.adorno::after { background: linear-gradient(90deg, var(--oro), transparent); }
.adorno span { font-size: 1.05rem; }

/* Filete superior decorativo para secciones */
.filete-oro { height: 3px; background: linear-gradient(90deg, var(--oro-claro), var(--oro), var(--oro-claro)); }

/* ---------- Botones ---------- */
.btn {
  display: inline-flex; align-items: center; gap: .5rem;
  font-family: var(--serif-texto); font-weight: 600; font-size: 1rem;
  text-transform: uppercase; letter-spacing: .12em;
  padding: .8rem 1.8rem; border: 1px solid transparent; cursor: pointer;
  transition: all var(--transicion);
}
.btn--primario { background: var(--verde); color: var(--pergamino); border-color: var(--verde); }
.btn--primario:hover { background: var(--verde-osc); color: var(--blanco); border-color: var(--verde-osc); }
.btn--oro { background: var(--oro); color: #2a200a; border-color: var(--oro); }
.btn--oro:hover { background: var(--oro-claro); color: #2a200a; }
.btn--linea { border-color: var(--verde); color: var(--verde); background: transparent; }
.btn--linea:hover { background: var(--verde); color: var(--pergamino); }
.seccion--verde .btn--linea { color: var(--pergamino); border-color: rgba(255,253,248,.6); }
.seccion--verde .btn--linea:hover { background: var(--pergamino); color: var(--verde-osc); border-color: var(--pergamino); }

/* ---------- Encabezado / navegación ---------- */
.cabecera { position: sticky; top: 0; z-index: 100; background: var(--pergamino); border-bottom: 1px solid var(--linea); }
/* Dentro de un iframe (Wix): encabezado no fijo, para un scroll fluido */
.embedded .cabecera { position: static; }
.embedded { scroll-behavior: auto; }
.barra-aviso { background: var(--verde-osc); color: var(--pergamino); font-family: var(--serif-texto); font-size: .9rem; text-align: center; padding: .5rem 1rem; letter-spacing: .02em; }
.barra-aviso a { color: var(--oro-claro); font-weight: 600; }
.cabecera__filete { height: 3px; background: linear-gradient(90deg, var(--oro-claro), var(--oro), var(--oro-claro)); }

.nav { display: flex; align-items: center; justify-content: space-between; padding: .8rem 0; gap: 1rem; position: relative; z-index: 2; }
.cabecera .nav { width: min(100% - 2rem, 1300px); }
.marca { display: flex; align-items: center; gap: .7rem; flex-shrink: 0; }
.marca img { width: 48px; height: auto; }
.marca-texto { display: flex; flex-direction: column; line-height: 1.08; }
.marca-texto strong { font-family: var(--serif-display); font-size: 1.25rem; font-weight: 700; color: var(--verde-osc); letter-spacing: .3px; white-space: nowrap; }
.marca-texto small { font-size: .68rem; letter-spacing: .2em; text-transform: uppercase; color: var(--oro); white-space: nowrap; }

.menu { display: flex; align-items: center; gap: .85rem; list-style: none; margin: 0; padding: 0; flex-wrap: nowrap; }
.menu > li { position: relative; }
.menu a { font-family: var(--serif-texto); font-weight: 600; font-size: .76rem; text-transform: uppercase; letter-spacing: .07em; color: var(--tinta); padding: .4rem 0; white-space: nowrap; }
.menu a:hover, .menu a[aria-current="page"] { color: var(--verde); }
.menu a[aria-current="page"] { border-bottom: 2px solid var(--oro); }

.tiene-sub > .submenu {
  position: absolute; top: 100%; left: 50%; transform: translateX(-50%) translateY(8px);
  background: var(--blanco); border: 1px solid var(--linea); box-shadow: var(--sombra);
  padding: .5rem; min-width: 230px; list-style: none; margin: 0; z-index: 60;
  opacity: 0; visibility: hidden; transition: all var(--transicion);
}
/* Puente invisible que cubre el hueco para que el menú no se cierre al bajar el cursor */
.tiene-sub > .submenu::before { content: ""; position: absolute; left: -10px; right: -10px; top: -16px; height: 18px; }
.tiene-sub:hover > .submenu, .tiene-sub:focus-within > .submenu { opacity: 1; visibility: visible; transform: translateX(-50%) translateY(4px); }
.submenu a { display: block; padding: .55rem .9rem; font-size: .78rem; }
.submenu a:hover { background: var(--pergamino-osc); }

.nav-cta { display: flex; align-items: center; gap: 1rem; }
.login-link { font-family: var(--serif-texto); font-weight: 600; font-size: .82rem; text-transform: uppercase; letter-spacing: .1em; color: var(--tinta); white-space: nowrap; }
.login-link::before { content: "\1F464"; margin-right: .35rem; font-size: .9em; }
.login-link:hover { color: var(--verde); }

/* Selector de idioma EN/ES */
.lang-switch { display: flex; align-items: center; gap: .35rem; font-family: var(--serif-texto); font-size: .78rem; font-weight: 700; letter-spacing: .06em; }
.lang-switch a, .lang-switch .lang-active { color: var(--tinta-suave); text-transform: uppercase; text-decoration: none; padding: .15rem .1rem; }
.lang-switch a:hover { color: var(--verde); }
.lang-switch .lang-active { color: var(--verde); border-bottom: 2px solid var(--oro); cursor: default; }
.lang-switch .lang-sep { color: var(--linea); }

/* Ventana de inicio de sesión */
.modal-login { position: fixed; inset: 0; z-index: 200; display: flex; align-items: center; justify-content: center; padding: 1.5rem; }
.modal-login[hidden] { display: none; }
.modal-login__fondo { position: absolute; inset: 0; background: rgba(20,63,55,.55); backdrop-filter: blur(3px); }
.modal-login__caja { position: relative; background: var(--blanco); border: 1px solid var(--linea); box-shadow: var(--sombra-fuerte, 0 18px 50px rgba(13,74,67,.25)); max-width: 420px; width: 100%; padding: 2.6rem 2.2rem; text-align: center; border-radius: 4px; }
.modal-login__caja::before { content: ""; position: absolute; top: 0; left: 0; right: 0; height: 4px; background: linear-gradient(90deg, var(--oro-claro), var(--oro), var(--oro-claro)); }
.modal-login__cerrar { position: absolute; top: .6rem; right: .9rem; background: none; border: 0; font-size: 1.8rem; line-height: 1; color: var(--tinta-suave); cursor: pointer; }
.modal-login__cerrar:hover { color: var(--vino); }
.modal-login__logo { width: 64px; margin: 0 auto 1rem; }
.modal-login__caja h2 { margin-bottom: .4rem; }
.modal-login__caja p { color: var(--tinta-suave); font-size: 1rem; margin-bottom: 1.4rem; }
.modal-login__nota { font-size: .85rem !important; color: var(--oro-osc, #a8842f) !important; margin: 1.2rem 0 0 !important; font-style: italic; }
.btn-google { display: inline-flex; align-items: center; justify-content: center; gap: .7rem; width: 100%; padding: .85rem 1.4rem; background: #fff; border: 1px solid #dadce0; border-radius: 6px; font-family: "Inter", var(--serif-texto); font-size: 1rem; font-weight: 600; color: #3c4043; cursor: pointer; transition: all var(--transicion); }
.btn-google:hover { background: #f7f8f8; box-shadow: 0 1px 3px rgba(60,64,67,.2); }
.hamburguesa { display: none; background: none; border: 0; cursor: pointer; padding: .4rem; }
.hamburguesa span { display: block; width: 26px; height: 2px; background: var(--verde-osc); margin: 5px 0; transition: var(--transicion); }

/* ---------- Hero ---------- */
.hero { position: relative; color: var(--pergamino); text-align: center; overflow: hidden; }
.hero__fondo { position: absolute; inset: 0; z-index: -2; }
.hero__fondo img { width: 100%; height: 100%; object-fit: cover; animation: kenburns 26s ease-out infinite alternate; }
.hero::after { content: ""; position: absolute; inset: 0; z-index: -1;
  background: linear-gradient(180deg, rgba(20,63,55,.74), rgba(20,63,55,.6) 45%, rgba(20,63,55,.86)); }
.hero__contenido { padding: clamp(5.5rem, 15vw, 10rem) 0; }
.hero h1 { color: var(--blanco); text-shadow: 0 2px 24px rgba(0,0,0,.35); }
.hero .eyebrow { color: var(--oro-claro); }
.hero .eyebrow::before, .hero .eyebrow::after { background: var(--oro-claro); }
.hero p { font-size: 1.35rem; max-width: 60ch; margin-inline: auto; color: rgba(255,253,248,.94); font-style: italic; }
.hero__botones { display: flex; gap: 1rem; justify-content: center; flex-wrap: wrap; margin-top: 2.2rem; }
.hero__regla { width: 90px; height: 2px; background: var(--oro-claro); margin: 1.4rem auto 0; }
.hero__botones { justify-content: center; }
.hero .btn--linea { color: #fffdf8; background: rgba(13,74,67,.5); border-color: rgba(255,253,248,.85); }
.hero .btn--linea:hover { background: var(--pergamino); color: var(--verde-osc); border-color: var(--pergamino); }

/* Estado de la Misa (en curso / próximas) */
.mass-status { background: var(--blanco); border: 1px solid var(--linea); border-left: 4px solid var(--oro); padding: 1.2rem 1.5rem; box-shadow: var(--sombra); }
.mass-status__title { font-family: var(--serif-display); font-size: 1.25rem; font-weight: 600; color: var(--verde-osc); margin: 0 0 .7rem; }
.mass-status__list { list-style: none; margin: 0; padding: 0; }
.mass-row { display: flex; align-items: center; gap: .7rem; padding: .6rem 0; border-bottom: 1px solid var(--linea-suave); flex-wrap: wrap; }
.mass-row:last-child { border-bottom: 0; }
.mass-status__dot { width: 12px; height: 12px; border-radius: 50%; background: var(--oro); flex-shrink: 0; }
.mass-status__dot--live { background: #2e8b57; animation: pulso 1.8s infinite; }
.mass-row__when { font-weight: 600; color: var(--verde-osc); }
.mass-row__label { color: var(--tinta-suave); }
.mass-row__tag { margin-left: auto; font-size: .72rem; text-transform: uppercase; letter-spacing: .08em; padding: .18rem .55rem; border: 1px solid var(--linea); color: var(--tinta-suave); white-space: nowrap; }
.mass-row.is-live .mass-row__tag { background: #2e8b57; color: #fff; border-color: #2e8b57; }
.mass-row.is-live .mass-row__when { color: #1f6e44; }
@keyframes pulso { 0% { box-shadow: 0 0 0 0 rgba(46,139,87,.55); } 70% { box-shadow: 0 0 0 9px rgba(46,139,87,0); } 100% { box-shadow: 0 0 0 0 rgba(46,139,87,0); } }

/* ---------- Tarjetas / grids ---------- */
.grid { display: grid; gap: 1.6rem; }
.grid--3 { grid-template-columns: repeat(3, 1fr); }
.grid--2 { grid-template-columns: repeat(2, 1fr); }
.grid--4 { grid-template-columns: repeat(4, 1fr); }

.tarjeta {
  background: var(--blanco); border: 1px solid var(--linea); padding: 2rem 1.9rem;
  height: 100%; position: relative; transition: border-color var(--transicion), box-shadow var(--transicion), transform var(--transicion);
}
.tarjeta::before { content: ""; position: absolute; top: 0; left: 0; right: 0; height: 3px; background: var(--oro); transform: scaleX(0); transform-origin: left; transition: transform var(--transicion); }
.tarjeta:hover { box-shadow: var(--sombra-fuerte, 0 18px 50px rgba(13,74,67,.16)); transform: translateY(-5px); }
.tarjeta:hover::before { transform: scaleX(1); }
.tarjeta h3 { color: var(--verde); margin-bottom: .4rem; }
.tarjeta p { color: var(--tinta-suave); font-size: 1.02rem; margin-bottom: .8rem; }
.tarjeta a.mas { font-weight: 600; font-size: .8rem; text-transform: uppercase; letter-spacing: .1em; }
.tarjeta__num { font-family: var(--serif-display); font-size: 2.4rem; color: var(--oro-claro); line-height: 1; display: block; margin-bottom: .4rem; }

/* Bloque imagen + texto */
.bloque { display: grid; grid-template-columns: 1fr 1fr; gap: clamp(2rem, 5vw, 4.5rem); align-items: center; }
.bloque--inv .bloque__media { order: 2; }
.bloque__media img { width: 100%; box-shadow: var(--sombra); border: 1px solid var(--linea); }
.bloque__media--marco { position: relative; padding: 14px; }
.bloque__media--marco::after { content: ""; position: absolute; inset: 0; border: 1px solid var(--oro); pointer-events: none; }

/* Horarios */
.horario { background: var(--blanco); border: 1px solid var(--linea); }
.horario__fila { display: flex; justify-content: space-between; gap: 1rem; padding: 1rem 1.4rem; border-bottom: 1px solid var(--linea-suave); }
.horario__fila:last-child { border-bottom: 0; }
.horario__dia { font-weight: 600; color: var(--verde-osc); font-family: var(--serif-display); font-size: 1.2rem; }
.horario__hora { color: var(--tinta-suave); text-align: right; }
.badge { display: inline-block; font-family: var(--serif-texto); font-size: .72rem; font-weight: 600; text-transform: uppercase; letter-spacing: .08em; padding: .12rem .55rem; border: 1px solid; margin-left: .35rem; }
.badge--es { color: var(--vino); border-color: var(--vino); }
.badge--en { color: var(--verde); border-color: var(--verde); }

/* Lista con cruces doradas */
.lista-check { list-style: none; padding: 0; margin: 0; }
.lista-check li { position: relative; padding-left: 1.9rem; margin-bottom: .7rem; color: var(--tinta-suave); }
.lista-check li::before { content: "✠"; position: absolute; left: 0; color: var(--oro); }

/* FAQ acordeón */
.faq { max-width: var(--ancho-lectura); margin-inline: auto; }
.faq__item { border-bottom: 1px solid var(--linea); }
.faq__pregunta { width: 100%; text-align: left; background: none; border: 0; cursor: pointer; font-family: var(--serif-display); font-size: 1.4rem; font-weight: 600; color: var(--verde-osc); padding: 1.2rem 2.5rem 1.2rem 0; position: relative; }
.faq__pregunta::after { content: "+"; position: absolute; right: .4rem; top: 50%; transform: translateY(-50%); font-size: 1.7rem; color: var(--oro); transition: var(--transicion); }
.faq__item.abierto .faq__pregunta::after { transform: translateY(-50%) rotate(45deg); }
.faq__respuesta { max-height: 0; overflow: hidden; transition: max-height var(--transicion); }
.faq__respuesta p { padding-bottom: 1.2rem; color: var(--tinta-suave); margin: 0; }

/* Contacto rápido */
.contacto-rapido { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1.2rem; }
.contacto-rapido a { display: flex; flex-direction: column; align-items: center; gap: .35rem; padding: 1.8rem 1rem; background: rgba(255,253,248,.06); border: 1px solid rgba(255,253,248,.22); color: var(--pergamino); text-align: center; transition: var(--transicion); }
.contacto-rapido a:hover { background: rgba(255,253,248,.12); color: var(--blanco); border-color: var(--oro-claro); }
.contacto-rapido strong { font-family: var(--serif-display); font-size: 1.3rem; }
.contacto-rapido small { opacity: .8; text-transform: uppercase; letter-spacing: .1em; font-size: .72rem; }
.contacto-rapido .etiqueta { color: var(--oro-claro); text-transform: uppercase; letter-spacing: .14em; font-size: .72rem; }

/* Formulario */
.formulario { background: var(--blanco); border: 1px solid var(--linea); padding: 2.2rem; }
.campo { margin-bottom: 1.1rem; }
.campo label { display: block; font-weight: 600; font-size: .82rem; text-transform: uppercase; letter-spacing: .08em; margin-bottom: .35rem; color: var(--verde-osc); }
.campo input, .campo textarea { width: 100%; padding: .8rem 1rem; border: 1px solid var(--linea); font-family: var(--serif-texto); font-size: 1.05rem; background: var(--pergamino); transition: var(--transicion); }
.campo input:focus, .campo textarea:focus { outline: none; border-color: var(--verde-claro); box-shadow: 0 0 0 3px rgba(46,115,103,.12); background: var(--blanco); }
.fila-2 { display: grid; grid-template-columns: 1fr 1fr; gap: 1rem; }

/* Mapa */
.mapa { overflow: hidden; border: 1px solid var(--linea); }
.mapa iframe { width: 100%; height: 100%; min-height: 360px; border: 0; display: block; filter: grayscale(.2) sepia(.08); }

/* Cita / versículo */
.cita { max-width: var(--ancho-lectura); margin-inline: auto; text-align: center; font-family: var(--serif-display); font-size: clamp(1.6rem, 3vw, 2.3rem); font-style: italic; color: var(--verde-osc); line-height: 1.3; }
.cita cite { display: block; font-family: var(--serif-texto); font-style: normal; font-size: 1rem; text-transform: uppercase; letter-spacing: .16em; color: var(--oro); margin-top: 1.2rem; }
.seccion--verde .cita, .seccion--verde .cita { color: var(--blanco); }
.seccion--verde .cita cite { color: var(--oro-claro); }

/* Artículos del blog */
.articulo { background: var(--blanco); border: 1px solid var(--linea); display: flex; flex-direction: column; height: 100%; }
.articulo__cuerpo { padding: 1.8rem; display: flex; flex-direction: column; flex: 1; }
.articulo__fecha { font-size: .76rem; text-transform: uppercase; letter-spacing: .14em; color: var(--oro); margin-bottom: .6rem; }
.articulo h3 { font-size: 1.45rem; margin-bottom: .6rem; }
.articulo p { color: var(--tinta-suave); font-size: 1rem; flex: 1; }
.articulo .mas { margin-top: .8rem; font-weight: 600; font-size: .8rem; text-transform: uppercase; letter-spacing: .1em; }

/* Galería */
.galeria { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1rem; }
.galeria a { display: block; overflow: hidden; border: 1px solid var(--linea); position: relative; }
.galeria img { width: 100%; height: 260px; object-fit: cover; transition: transform .5s ease; display: block; }
.galeria a:hover img { transform: scale(1.05); }
.galeria-videos { display: grid; grid-template-columns: repeat(2, 1fr); gap: 1.4rem; }
.galeria-videos video { width: 100%; border: 1px solid var(--linea); box-shadow: var(--sombra); background: #000; }
@media (max-width: 820px) { .galeria { grid-template-columns: repeat(2, 1fr); } .galeria-videos { grid-template-columns: 1fr; } }

/* Texto largo de lectura */
.prosa { max-width: var(--ancho-lectura); margin-inline: auto; }
.prosa h2 { margin-top: 2rem; }
.prosa h3 { color: var(--verde); margin-top: 1.6rem; }

/* Verse of the Day */
.verso { max-width: 760px; margin-inline: auto; background: var(--blanco); border: 1px solid var(--linea); padding: 2.6rem 2.2rem; text-align: center; position: relative; }
.verso::before { content: ""; position: absolute; top: 0; left: 0; right: 0; height: 4px; background: linear-gradient(90deg, var(--oro-claro), var(--oro), var(--oro-claro)); }
.verso__text { font-family: var(--serif-display); font-size: clamp(1.5rem, 3vw, 2.1rem); font-style: italic; color: var(--verde-osc); line-height: 1.35; margin: .4rem 0 1rem; }
.verso__ref { display: inline-block; font-weight: 600; text-transform: uppercase; letter-spacing: .16em; font-size: .85rem; color: var(--oro); }
.verso__btn { margin-top: 1.4rem; }

/* Prayers (accordion reuses .faq) */
.oracion-texto { white-space: pre-line; }

/* Partner logos (Agreements) */
.logos-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 1.2rem; }
.logo-tile { aspect-ratio: 3 / 2; background: var(--blanco); border: 1px solid var(--linea); display: flex; flex-direction: column; align-items: center; justify-content: center; gap: .45rem; color: var(--tinta-suave); text-align: center; padding: 1rem; transition: border-color var(--transicion), box-shadow var(--transicion); }
.logo-tile:hover { border-color: var(--oro); box-shadow: var(--sombra); }
.logo-tile img { max-width: 82%; max-height: 70%; object-fit: contain; filter: grayscale(1); opacity: .85; transition: filter .25s, opacity .25s; }
.logo-tile:hover img { filter: none; opacity: 1; }
.logo-tile__ph { font-size: 1.9rem; color: var(--oro-claro); line-height: 1; }
.logo-tile small { font-size: .72rem; text-transform: uppercase; letter-spacing: .12em; }
@media (max-width: 820px) { .logos-grid { grid-template-columns: repeat(2, 1fr); } }

/* Convenio (partner) cards */
.convenios { display: grid; grid-template-columns: repeat(2, 1fr); gap: 1.6rem; align-items: start; }
.convenio { background: var(--blanco); border: 1px solid var(--linea); padding: 1.8rem; display: flex; flex-direction: column; position: relative; }
.convenio::before { content: ""; position: absolute; top: 0; left: 0; right: 0; height: 3px; background: var(--oro); transform: scaleX(0); transform-origin: left; transition: transform .25s; }
.convenio:hover::before { transform: scaleX(1); }
.convenio:hover { box-shadow: var(--sombra); }
.convenio__head { display: flex; gap: 1.1rem; align-items: center; margin-bottom: 1.1rem; }
.convenio__logo { width: 88px; height: 88px; object-fit: contain; border: 1px solid var(--linea); background: #fff; padding: 6px; flex-shrink: 0; }
.convenio__logo--text { display: flex; align-items: center; justify-content: center; text-align: center; background: #6e1f2a; color: #fff; font-family: var(--serif-display); font-weight: 700; font-size: .8rem; line-height: 1.15; letter-spacing: .03em; padding: 8px; }
.convenio__title h3 { margin: 0 0 .15rem; font-size: 1.4rem; }
.convenio__tag { color: #a8842f; font-size: .92rem; }
.convenio__body { color: var(--tinta-suave); }
.convenio__meta { list-style: none; padding: 0; margin: .7rem 0 0; font-size: .96rem; }
.convenio__meta li { margin-bottom: .3rem; }
.convenio__meta strong { color: var(--verde-osc); }
.convenio__foot { display: flex; justify-content: space-between; align-items: center; gap: 1rem; margin-top: 1.4rem; flex-wrap: wrap; }
.convenio__city { color: var(--tinta-suave); font-size: .85rem; font-style: italic; }
@media (max-width: 820px) { .convenios { grid-template-columns: 1fr; } }

/* Bible Quiz */
.quiz { max-width: 760px; margin-inline: auto; }
.quiz-q { border: 1px solid var(--linea); background: var(--blanco); padding: 1.2rem 1.4rem; margin: 0 0 1rem; border-radius: 2px; transition: border-color var(--transicion); }
.quiz-q legend { font-family: var(--serif-display); font-size: 1.25rem; font-weight: 600; color: var(--verde-osc); padding: 0 .4rem; }
.quiz-opt { display: flex; align-items: center; gap: .6rem; padding: .45rem .2rem; cursor: pointer; font-size: 1.02rem; }
.quiz-opt input { width: auto; accent-color: var(--verde); }
.quiz-q--ok { border-color: #2e8b57; box-shadow: inset 4px 0 0 #2e8b57; }
.quiz-q--bad { border-color: var(--vino); box-shadow: inset 4px 0 0 var(--vino); }
.quiz-result { margin-top: 1.2rem; padding: 1rem 1.3rem; background: #fff8e7; border-left: 4px solid var(--oro); font-size: 1.15rem; font-weight: 600; color: var(--verde-osc); }
#bible-quiz .btn--primario { margin-top: .4rem; }

/* ---------- Pie ---------- */
.pie { background: var(--verde-osc); color: rgba(255,253,248,.82); padding: 4rem 0 1.6rem; }
.pie a { color: rgba(255,253,248,.82); }
.pie a:hover { color: var(--oro-claro); }
.pie__grid { display: grid; grid-template-columns: 1.5fr 1fr 1fr; gap: 2.6rem; margin-bottom: 2.6rem; }
.pie__marca { display: flex; align-items: center; gap: .8rem; margin-bottom: 1rem; }
.pie__marca img { width: 58px; }
.pie__marca strong { font-family: var(--serif-display); font-size: 1.5rem; color: var(--blanco); }
.pie h4 { color: var(--blanco); font-family: var(--serif-texto); text-transform: uppercase; letter-spacing: .14em; font-size: .82rem; margin-bottom: 1rem; }
.pie ul { list-style: none; padding: 0; margin: 0; }
.pie ul li { margin-bottom: .55rem; font-size: .98rem; }
.pie__abajo { border-top: 1px solid rgba(255,253,248,.16); padding-top: 1.6rem; display: flex; justify-content: space-between; flex-wrap: wrap; gap: 1rem; font-size: .85rem; }
.pie__abajo nav a { margin-left: 1.3rem; }

/* Banner de página interna */
.banner { position: relative; background: var(--verde-osc); color: var(--pergamino); text-align: center; padding: clamp(3.5rem, 8vw, 6rem) 0; overflow: hidden; }
.banner::after { content: ""; position: absolute; inset: 0; background-image: radial-gradient(circle at 50% 0, rgba(194,160,78,.16), transparent 60%); pointer-events: none; }
.banner h1 { color: var(--blanco); }
.banner p { color: rgba(255,253,248,.9); max-width: 62ch; margin-inline: auto; font-style: italic; font-size: 1.2rem; }
.banner .eyebrow { color: var(--oro-claro); }
.banner .eyebrow::before, .banner .eyebrow::after { background: var(--oro-claro); }
.miga { font-size: .78rem; text-transform: uppercase; letter-spacing: .14em; color: rgba(255,253,248,.7); margin-bottom: 1.2rem; }
.miga a { color: var(--oro-claro); }

/* Nota / aviso */
.nota { background: #fbf4e2; border-left: 3px solid var(--oro); padding: 1rem 1.3rem; color: var(--tinta-suave); font-size: 1rem; }

/* ---------- Responsivo ---------- */

/* Tablets y pantallas medianas: menú hamburguesa (el menú es largo) */
@media (max-width: 1180px) {
  .hamburguesa { display: block; }
  .menu {
    position: fixed; inset: 0 0 0 auto; width: min(88%, 360px);
    flex-direction: column; align-items: flex-start; gap: .1rem;
    background: var(--pergamino); padding: 5rem 1.6rem 2rem; box-shadow: -10px 0 40px rgba(0,0,0,.2);
    transform: translateX(100%); transition: transform var(--transicion); overflow-y: auto;
  }
  .menu.abierto { transform: translateX(0); }
  .menu > li { width: 100%; border-bottom: 1px solid var(--linea); }
  .menu a { display: block; padding: .95rem 0; font-size: .95rem; }
  .menu a[aria-current="page"] { border-bottom: 1px solid var(--linea); color: var(--verde); }
  .tiene-sub > .submenu { position: static; transform: none; opacity: 1; visibility: visible; box-shadow: none; border: 0; padding: 0 0 .6rem 1rem; min-width: 0; background: transparent; }
  .tiene-sub > .submenu::before { display: none; }
}

/* Tablet: rejillas a 2 columnas, bloques apilados */
@media (max-width: 980px) {
  .grid--3, .grid--4 { grid-template-columns: repeat(2, 1fr); }
  .bloque, .bloque--inv .bloque__media { grid-template-columns: 1fr; order: initial; }
  .pie__grid { grid-template-columns: 1fr 1fr; }
}

/* Teléfono */
@media (max-width: 680px) {
  body { font-size: 17px; }
  .nav { padding: .6rem 0; }
  .nav-cta { gap: .7rem; }
  .nav-cta .btn { display: none; }                 /* ocultar "Reservar" */
  .login-link { font-size: 0; padding: .3rem; }     /* dejar solo el ícono */
  .login-link::before { font-size: 1.4rem; margin: 0; }
  .marca img { width: 40px; }
  .marca-texto strong { font-size: 1.1rem; }
  .marca-texto small { font-size: .62rem; letter-spacing: .14em; }
  h1 { font-size: clamp(2.1rem, 8.5vw, 2.9rem); }
  .seccion { padding: 2.8rem 0; }
  .grid--3, .grid--4, .grid--2, .contacto-rapido, .fila-2, .galeria-videos { grid-template-columns: 1fr; }
  .galeria { grid-template-columns: repeat(2, 1fr); gap: .6rem; }
  .galeria img { height: 170px; }
  .pie__grid { grid-template-columns: 1fr; gap: 1.8rem; }
  .pie__abajo { flex-direction: column; align-items: flex-start; }
  .pie__abajo nav a { margin: .4rem 1.4rem 0 0; }
  .horario__fila { flex-direction: column; gap: .2rem; }
  .horario__hora { text-align: left; }
  .modal-login__caja { padding: 2.2rem 1.5rem; }
  .lead { font-size: 1.12rem; }
}

/* Teléfonos pequeños */
@media (max-width: 380px) {
  .galeria { grid-template-columns: 1fr; }
  .galeria img { height: 220px; }
}

/* Animación de entrada */
.reveal { opacity: 0; transform: translateY(22px); transition: opacity .7s ease, transform .7s ease; }
.reveal.visible { opacity: 1; transform: none; }
@media (prefers-reduced-motion: reduce) { .reveal { opacity: 1; transform: none; transition: none; } }

/* ---------- Pulido visual ---------- */
/* Acercamiento suave (cine) en el hero */
@keyframes kenburns { from { transform: scale(1); } to { transform: scale(1.07); } }

/* Botones con leve elevación al pasar el mouse */
.btn { transition: all var(--transicion), transform var(--transicion); }
.btn:hover { transform: translateY(-2px); }

/* Las anclas (#baptism, etc.) no quedan tapadas por el encabezado fijo */
:target { scroll-margin-top: 100px; }
.embedded :target { scroll-margin-top: 20px; }

/* Foto de los bloques: leve zoom al pasar el mouse */
.bloque__media { overflow: hidden; }
.bloque__media img { transition: transform .6s ease; }
.bloque__media:hover img { transform: scale(1.03); }

/* Enlaces de texto con subrayado elegante */
.prosa a, .articulo p a { text-decoration: underline; text-underline-offset: 3px; text-decoration-color: var(--oro-claro); }

@media (prefers-reduced-motion: reduce) {
  .hero__fondo img { animation: none; }
  .tarjeta:hover, .btn:hover { transform: none; }
  .bloque__media:hover img { transform: none; }
}

/* ====== Burbuja flotante de contacto rápido (FAB) ====== */
.fab {
  position: fixed;
  right: 22px;
  bottom: 22px;
  z-index: 60;
  display: flex;
  flex-direction: column;
  align-items: flex-end;
  gap: 12px;
}
.fab__btn {
  width: 58px;
  height: 58px;
  border-radius: 50%;
  border: 2px solid var(--oro);
  background: var(--verde);
  color: #fff;
  display: grid;
  place-items: center;
  cursor: pointer;
  box-shadow: 0 6px 20px rgba(0,0,0,.28);
  transition: transform .2s ease, background .2s ease;
}
.fab__btn:hover { transform: translateY(-2px) scale(1.04); background: var(--verde-osc); }
.fab__btn .fab__ic-close { display: none; }
.fab.abierto .fab__btn { background: var(--verde-osc); }
.fab.abierto .fab__ic-open { display: none; }
.fab.abierto .fab__ic-close { display: block; }

.fab__panel {
  display: flex;
  flex-direction: column;
  gap: 10px;
  align-items: flex-end;
}
.fab__panel[hidden] { display: none; }
.fab__item {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  padding: 9px 15px 9px 12px;
  border-radius: 30px;
  background: var(--blanco);
  color: var(--tinta);
  font-family: var(--serif-texto);
  font-size: .98rem;
  font-weight: 600;
  text-decoration: none;
  box-shadow: 0 4px 14px rgba(0,0,0,.2);
  border: 1px solid var(--linea);
  white-space: nowrap;
  transform: translateY(8px);
  opacity: 0;
  animation: fab-in .25s ease forwards;
}
.fab__panel:not([hidden]) .fab__item:nth-child(1) { animation-delay: .03s; }
.fab__panel:not([hidden]) .fab__item:nth-child(2) { animation-delay: .08s; }
.fab__panel:not([hidden]) .fab__item:nth-child(3) { animation-delay: .13s; }
.fab__item:hover { transform: translateY(0) scale(1.03); }
.fab__ic {
  width: 34px;
  height: 34px;
  border-radius: 50%;
  display: grid;
  place-items: center;
  color: #fff;
  flex: none;
}
.fab__item--wa  .fab__ic { background: #25d366; }
.fab__item--tel .fab__ic { background: var(--verde); }
.fab__item--mail .fab__ic { background: var(--oro); }
@keyframes fab-in { to { transform: translateY(0); opacity: 1; } }

@media (max-width: 680px) {
  .fab { right: 16px; bottom: 16px; }
  .fab__btn { width: 54px; height: 54px; }
}
@media (prefers-reduced-motion: reduce) {
  .fab__item { animation: none; opacity: 1; transform: none; }
  .fab__btn:hover, .fab__item:hover { transform: none; }
}
