/* ==========================================================================
   CYS — Hoja de estilos global
   Paleta: blanco + azul + naranja  ·  Tipos: Elza (texto) / GT America Exp (display)
   ========================================================================== */

/* ---------- Fuentes ---------- */
@font-face{font-family:'Elza';src:url('../fonts/Elza-Thin.woff2') format('woff2');font-weight:300;font-display:swap}
@font-face{font-family:'Elza';src:url('../fonts/Elza-Medium.woff2') format('woff2');font-weight:500;font-display:swap}
@font-face{font-family:'Elza';src:url('../fonts/Elza-Bold.woff2') format('woff2');font-weight:700;font-display:swap}
@font-face{font-family:'GT America Expanded';src:url('../fonts/GT-America-Expanded-Regular.woff2') format('woff2');font-weight:400 800;font-display:swap}

/* ---------- Variables ---------- */
:root{
  --azul:#1257A6;
  --azul-claro:#2E83D8;
  --azul-osc:#0A2E5C;
  --naranja:#F2701D;
  --naranja-osc:#D85E12;
  --magenta:#8B2FC9;
  --blanco:#ffffff;
  --gris:#F4F7FB;
  --gris-2:#E7EDF5;
  --texto:#1d2733;
  --texto-suave:#5a6675;
  --sombra:0 14px 40px rgba(10,46,92,.10);
  --sombra-fuerte:0 22px 60px rgba(10,46,92,.18);
  --radio:22px;
  --ancho:1180px;
  --display:'Elza',sans-serif;
}

/* ---------- Base ---------- */
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;scroll-padding-top:90px}
body{font-family:'Elza',system-ui,sans-serif;color:var(--texto);background:var(--blanco);line-height:1.6;-webkit-font-smoothing:antialiased}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
.wrap{width:100%;max-width:var(--ancho);margin:0 auto;padding:0 24px}
.display{font-family:var(--display);font-weight:700;letter-spacing:.01em;line-height:1.02;text-transform:uppercase}

.t-naranja{color:var(--naranja)}
.t-azul{color:var(--azul)}

/* ---------- Iconos SVG (Bootstrap Icons) ---------- */
.bi{display:inline-block;vertical-align:-.125em;fill:currentColor;width:1em;height:1em}

/* Encabezado de sección */
.sec{padding:84px 0}
.sec-cabeza{max-width:780px;margin:0 auto 50px;text-align:center}
.sec-cabeza .sobre{font-family:var(--display);font-weight:700;font-size:.78rem;letter-spacing:.22em;text-transform:uppercase;color:var(--naranja);display:block;margin-bottom:14px}
.sec-cabeza h2{font-family:var(--display);font-weight:700;text-transform:uppercase;font-size:clamp(1.8rem,4.5vw,3rem);color:var(--azul-osc)}
.sec-cabeza p{color:var(--texto-suave);margin-top:14px;font-size:1.05rem}
.bg-gris{background:var(--gris)}

/* ---------- Botones ---------- */
.btn{display:inline-flex;align-items:center;gap:10px;font-weight:700;font-size:.96rem;letter-spacing:.02em;padding:15px 30px;border-radius:60px;border:2px solid transparent;cursor:pointer;transition:transform .25s,box-shadow .25s,background .25s;text-transform:uppercase}
.btn:hover{transform:translateY(-3px)}
.btn-naranja{background:var(--naranja);color:#fff;box-shadow:0 12px 26px rgba(242,112,29,.35)}
.btn-naranja:hover{background:var(--naranja-osc)}
.btn-azul{background:var(--azul);color:#fff;box-shadow:0 12px 26px rgba(18,87,166,.32)}
.btn-azul:hover{background:var(--azul-osc)}
.btn-ghost{background:transparent;border-color:#fff;color:#fff}
.btn-ghost:hover{background:#fff;color:var(--azul-osc)}
.btn-blanco{background:#fff;color:var(--azul-osc)}
.btn-blanco:hover{background:#f0f4fa}

/* ==========================================================================
   HEADER — barra de color con logo blanco CYS
   ========================================================================== */
.topbar{position:sticky;top:0;z-index:90;background:linear-gradient(90deg,var(--azul-osc),var(--azul));box-shadow:0 6px 24px rgba(10,46,92,.22)}
.nav{display:flex;align-items:center;justify-content:space-between;height:78px}
.brand img{height:40px;width:auto;display:block}
.nav-links{display:flex;align-items:center;gap:30px;list-style:none}
.nav-links a{font-weight:500;color:#dbe7f5;font-size:.97rem;transition:color .2s;position:relative}
.nav-links a:hover,.nav-links a.activo{color:#fff}
.nav-links a.activo::after{content:'';position:absolute;left:0;right:0;bottom:-8px;height:3px;background:var(--naranja);border-radius:3px}
.nav-cta .btn{padding:11px 22px;font-size:.82rem}
.burger{display:none;background:none;border:0;cursor:pointer;flex-direction:column;gap:5px}
.burger span{width:26px;height:3px;background:#fff;border-radius:3px;transition:.3s}
/* Botón X de cierre del menú móvil (creado por JS) */
.nav-close{display:none;position:fixed;top:16px;right:18px;z-index:130;width:48px;height:48px;border:0;border-radius:50%;
  background:rgba(255,255,255,.14);color:#fff;cursor:pointer;place-items:center;transition:background .2s,transform .3s}
.nav-close:hover{background:rgba(255,255,255,.26);transform:rotate(90deg)}
.nav-close svg{width:22px;height:22px;fill:#fff}
body.menu-open{overflow:hidden}
.solo-movil{display:none}

/* ==========================================================================
   HERO CINEMATOGRÁFICO — fondo full-bleed + contenido a la izquierda
   ========================================================================== */
.hero-cine{position:relative;overflow:hidden;color:#fff;min-height:90vh;display:flex;align-items:center}
.hero-cine .bg{position:absolute;inset:0;z-index:0}
.hero-cine .bg img,.hero-cine .bg .ph{width:100%;height:100%;object-fit:cover;object-position:center}
.hero-cine .bg .ph{border:0}
/* Scrim cinematográfico: oscurece solo la IZQUIERDA (donde va el texto) y deja
   la imagen en su máximo esplendor a la derecha */
.hero-cine::after{content:'';position:absolute;inset:0;z-index:1;
  background:linear-gradient(90deg,rgba(5,18,38,.94) 0%,rgba(5,18,38,.80) 26%,rgba(5,18,38,.40) 50%,rgba(5,18,38,.06) 72%,transparent 100%)}
/* Fondo de color vibrante por defecto (solo si faltara la imagen) */
.hero-cine.azul .bg{background:linear-gradient(115deg,#06203f,#1257A6 52%,#2E83D8 78%,#7bb7ef)}
.hero-cine.calido .bg{background:linear-gradient(115deg,#0A2E5C,#1257A6 40%,#F2701D 120%)}
.hero-cine.teal .bg{background:linear-gradient(115deg,#06203f,#0a6b86 55%,#1aa6b7 90%)}
.hero-cine .wrap{position:relative;z-index:2;width:100%;padding:120px 24px}
.hero-cine .panel{max-width:600px}
.hero-cine .sobre{font-family:var(--display);font-weight:700;letter-spacing:.2em;font-size:.82rem;text-transform:uppercase;color:var(--naranja);display:block;margin-bottom:18px;text-shadow:0 2px 14px rgba(0,0,0,.5)}
.hero-cine h1{font-family:var(--display);font-weight:800;text-transform:uppercase;font-size:clamp(2.4rem,6vw,4.6rem);margin-bottom:20px;text-shadow:0 6px 30px rgba(0,0,0,.55)}
.hero-cine p{font-size:1.18rem;color:#eaf2fd;max-width:540px;margin-bottom:16px;text-shadow:0 2px 14px rgba(0,0,0,.5)}
.hero-cine .tagline{display:inline-flex;align-items:baseline;gap:10px;margin:8px 0 30px;font-weight:700}
.hero-cine .tagline .precio{font-family:var(--display);font-weight:800;font-size:2.4rem;color:#fff;text-shadow:0 4px 18px rgba(0,0,0,.5)}
.hero-cine .tagline .txt{font-size:1.05rem;color:#ffd9bd}
.hero-acciones{display:flex;gap:14px;flex-wrap:wrap;position:relative}
/* Indicador de scroll */
.hero-cine .scroll-cue{position:absolute;left:50%;bottom:26px;transform:translateX(-50%);z-index:2;
  width:26px;height:42px;border:2px solid rgba(255,255,255,.6);border-radius:16px;display:grid;justify-items:center}
.hero-cine .scroll-cue::before{content:'';width:4px;height:8px;border-radius:3px;background:#fff;margin-top:7px;animation:cue 1.5s ease-in-out infinite}
@keyframes cue{0%,100%{transform:translateY(0);opacity:1}60%{transform:translateY(12px);opacity:.2}}

/* ==========================================================================
   SLIDER genérico (crossfade minimalista, loop)
   ========================================================================== */
.slide{position:absolute;inset:0;opacity:0;transition:opacity 1.2s ease;z-index:0}
.slide.is-active{opacity:1;z-index:1}
.slide img{width:100%;height:100%;object-fit:cover;display:block}
.dots{display:flex;gap:10px}
.dots button{width:10px;height:10px;padding:0;border:0;border-radius:50%;background:rgba(255,255,255,.45);
  cursor:pointer;transition:width .3s,background .3s}
.dots button.on{background:#fff;width:28px;border-radius:6px}

/* ---------- HERO SLIDER (Home) ---------- */
.hero-slider{position:relative;overflow:hidden;color:#fff;min-height:92vh;display:flex;align-items:center}
.hero-slider .slide img{object-position:center}
.hero-slider .slide.pos-bee img{object-position:75% center}
.hero-slider::after{content:'';position:absolute;inset:0;z-index:2;pointer-events:none;
  background:linear-gradient(90deg,rgba(5,18,38,.92) 0%,rgba(5,18,38,.74) 28%,rgba(5,18,38,.35) 52%,rgba(5,18,38,.05) 74%,transparent 100%)}
.hero-slider .hm-content{position:relative;z-index:3;width:50%;
  padding-left:max(24px,calc((100vw - 1180px)/2 + 12px));padding-right:24px}
.hero-slider .sobre{font-family:var(--display);font-weight:700;letter-spacing:.2em;font-size:.85rem;
  text-transform:uppercase;color:var(--naranja);display:block;margin-bottom:16px;text-shadow:0 2px 12px rgba(0,0,0,.5)}
.hero-slider h1{font-family:var(--display);font-weight:800;text-transform:uppercase;
  font-size:clamp(2.2rem,5vw,4rem);line-height:1;margin-bottom:18px;text-shadow:0 5px 26px rgba(0,0,0,.55)}
.hero-slider p{font-size:clamp(1rem,1.5vw,1.2rem);max-width:460px;margin-bottom:24px;color:#eaf2fd;text-shadow:0 2px 14px rgba(0,0,0,.5)}
.hero-slider .hero-acciones{display:flex;gap:14px;flex-wrap:wrap}
.hero-slider .dots{position:absolute;bottom:28px;left:50%;transform:translateX(-50%);z-index:4}

/* ---------- EXP SLIDER (ancho completo, loop) ---------- */
.exp-slider{position:relative;overflow:hidden;width:100%;min-height:64vh;color:#fff}
.exp-slider .slide::after{content:'';position:absolute;inset:0;
  background:linear-gradient(0deg,rgba(5,18,38,.9) 0%,rgba(5,18,38,.3) 45%,transparent 72%)}
.exp-slider .es-cap{position:absolute;left:0;right:0;bottom:0;z-index:2;
  padding:0 24px 56px;text-align:center}
.exp-slider .es-cap .n{font-family:var(--display);font-weight:800;font-size:1.4rem;opacity:.55}
.exp-slider .es-cap h3{font-family:var(--display);text-transform:uppercase;font-size:clamp(1.4rem,3.4vw,2.4rem);
  text-shadow:0 3px 18px rgba(0,0,0,.55);margin-top:6px}
.exp-slider .dots{position:absolute;bottom:24px;left:50%;transform:translateX(-50%);z-index:3}

/* ==========================================================================
   HERO MASCOTA (Home) — el personaje en su máximo esplendor, sin recorte
   ========================================================================== */
.hero-mascota{position:relative;overflow:hidden;color:#fff;
  background:linear-gradient(120deg,#f4a01d 0%,#f6a922 55%,#f7b53d 100%)}
.hero-mascota .hm-bg{display:block;width:100%;height:auto}        /* imagen completa, sin recortar */
.hero-mascota .hm-content{position:absolute;top:0;bottom:0;left:0;z-index:2;
  width:50%;display:flex;flex-direction:column;justify-content:center;
  padding-left:max(24px,calc((100vw - 1180px)/2 + 12px));padding-right:24px}
.hero-mascota .sobre{font-family:var(--display);font-weight:700;letter-spacing:.2em;font-size:.85rem;
  text-transform:uppercase;color:var(--azul-osc);display:block;margin-bottom:16px}
.hero-mascota h1{font-family:var(--display);font-weight:800;text-transform:uppercase;
  font-size:clamp(2.2rem,4.8vw,4rem);line-height:1;margin-bottom:18px;color:#fff;
  text-shadow:0 4px 22px rgba(120,60,0,.45)}
.hero-mascota p{font-size:clamp(1rem,1.5vw,1.2rem);max-width:440px;margin-bottom:24px;color:#3a2400;font-weight:500}
.hero-mascota .hero-acciones{display:flex;gap:14px;flex-wrap:wrap}

/* ==========================================================================
   Banda mascota de ancho completo (transición impactante con el personaje)
   ========================================================================== */
.mascota-banner{position:relative;overflow:hidden;background:#2c1c8f}
.mascota-banner .mb-bg{display:block;width:100%;height:auto}
.mascota-banner .mb-content{position:absolute;top:0;bottom:0;right:0;z-index:2;width:52%;
  display:flex;flex-direction:column;justify-content:center;
  padding-right:max(24px,calc((100vw - 1180px)/2 + 12px));padding-left:24px}
.mascota-banner h3{font-family:var(--display);text-transform:uppercase;color:#fff;
  font-size:clamp(1.5rem,3.4vw,2.6rem);line-height:1.02;margin-bottom:14px;text-shadow:0 3px 16px rgba(0,0,0,.4)}
.mascota-banner p{color:rgba(255,255,255,.92);max-width:460px;margin-bottom:22px;font-size:1.05rem;text-shadow:0 2px 12px rgba(0,0,0,.35)}
.mascota-banner .redes-cta{display:flex;gap:12px;flex-wrap:wrap}

/* ==========================================================================
   Bloque visual de plan (impactante SIN imagen, como las cards de color)
   ========================================================================== */
.plan-visual{border-radius:20px;color:#fff;padding:48px;display:flex;flex-direction:column;justify-content:center;
  gap:16px;min-height:320px;position:relative;overflow:hidden}
.plan-visual.azul{background:linear-gradient(150deg,var(--azul),var(--azul-osc))}
.plan-visual.naranja{background:linear-gradient(150deg,var(--naranja),var(--naranja-osc))}
.plan-visual::before{content:'';position:absolute;width:340px;height:340px;border-radius:50%;
  background:rgba(255,255,255,.10);right:-120px;top:-120px}
.plan-visual::after{content:'';position:absolute;width:200px;height:200px;border-radius:50%;
  background:rgba(255,255,255,.07);left:-70px;bottom:-70px}
.plan-visual>*{position:relative;z-index:1}
.plan-visual .pv-ico .bi{width:48px;height:48px;fill:#fff;opacity:.95}
.plan-visual .pv-num{font-family:var(--display);font-weight:800;font-size:clamp(3.4rem,7vw,5rem);line-height:.9}
.plan-visual .pv-num small{font-size:1.5rem;margin-left:8px;font-weight:700}
.plan-visual .pv-feat{font-family:var(--display);text-transform:uppercase;letter-spacing:.05em;font-size:.92rem;opacity:.95}

/* ==========================================================================
   Banda de ancho completo con imagen de fondo (divisor cinematográfico)
   ========================================================================== */
.feature-band{position:relative;min-height:62vh;display:flex;align-items:center;color:#fff;overflow:hidden}
.feature-band.full{min-height:100vh}
.feature-band .bg{position:absolute;inset:0;z-index:0}
.feature-band .bg img{width:100%;height:100%;object-fit:cover}
.feature-band::after{content:'';position:absolute;inset:0;z-index:1;
  background:linear-gradient(90deg,rgba(5,18,38,.92) 0%,rgba(5,18,38,.62) 38%,rgba(5,18,38,.12) 70%,transparent 100%)}
.feature-band.centro::after{background:linear-gradient(0deg,rgba(5,18,38,.85),rgba(5,18,38,.45))}
.feature-band .wrap{position:relative;z-index:2;width:100%;padding:80px 24px}
.feature-band.centro .wrap{text-align:center}
.feature-band .sobre{font-family:var(--display);font-weight:700;letter-spacing:.2em;font-size:.8rem;text-transform:uppercase;color:var(--naranja);display:block;margin-bottom:14px}
.feature-band h2{font-family:var(--display);font-weight:800;text-transform:uppercase;font-size:clamp(1.9rem,4.5vw,3.2rem);max-width:640px;text-shadow:0 5px 26px rgba(0,0,0,.5);margin-bottom:16px}
.feature-band.centro h2{margin-left:auto;margin-right:auto}
.feature-band p{font-size:1.12rem;color:#eaf2fd;max-width:520px;margin-bottom:24px;text-shadow:0 2px 14px rgba(0,0,0,.5)}
.feature-band.centro p{margin-left:auto;margin-right:auto}

/* ==========================================================================
   Tira cinematográfica de ancho completo (3 paneles edge-to-edge)
   ========================================================================== */
.tira-full{display:grid;grid-template-columns:repeat(3,1fr);width:100%}
.tira-full.dos{grid-template-columns:repeat(2,1fr)}
.tira-full .panel-img{position:relative;min-height:48vh;overflow:hidden}
.tira-full .panel-img img{width:100%;height:100%;object-fit:cover;transition:transform .6s ease}
.tira-full .panel-img:hover img{transform:scale(1.06)}
.tira-full .panel-img::after{content:'';position:absolute;inset:0;
  background:linear-gradient(0deg,rgba(5,18,38,.92) 0%,rgba(5,18,38,.35) 45%,transparent 75%)}
.tira-full .cap{position:absolute;left:0;right:0;bottom:0;z-index:2;padding:30px;color:#fff}
.tira-full .cap .n{font-family:var(--display);font-weight:800;font-size:1.6rem;opacity:.4;line-height:1}
.tira-full .cap h3{font-family:var(--display);text-transform:uppercase;font-size:1.15rem;margin-top:8px;text-shadow:0 2px 12px rgba(0,0,0,.5)}

/* ==========================================================================
   Transición con mascota (puente entre secciones)
   ========================================================================== */
.mascota-trans{position:relative;background:linear-gradient(180deg,var(--azul-osc),var(--azul));overflow:visible;padding:0}
.mascota-trans .wrap{display:flex;align-items:center;justify-content:center;gap:40px;min-height:160px;position:relative}
.mascota-trans .mt-bee{flex:0 0 auto;width:230px;margin-top:-70px;margin-bottom:-4px;align-self:flex-end}
.mascota-trans .mt-bee img{width:100%;display:block;filter:drop-shadow(0 18px 28px rgba(0,0,0,.35));animation:flotar 4s ease-in-out infinite}
.mascota-trans .mt-txt{color:#fff;max-width:520px}
.mascota-trans .mt-txt h3{font-family:var(--display);text-transform:uppercase;font-size:clamp(1.3rem,3vw,2rem);margin-bottom:8px}
.mascota-trans .mt-txt p{color:#cfe0f2}
.mascota-trans .mt-cta{display:flex;gap:12px;margin-top:16px;flex-wrap:wrap}

/* ==========================================================================
   HERO PARTIDO — mitad mensaje / mitad panel destacado
   ========================================================================== */
.hero-split{display:grid;grid-template-columns:1.05fr .95fr;min-height:520px}
.hero-split .lado{padding:70px 60px;display:flex;flex-direction:column;justify-content:center}
.hero-msg{background:linear-gradient(135deg,var(--azul-osc),var(--azul) 70%,var(--azul-claro));color:#fff;position:relative;overflow:hidden}
.hero-msg::after{content:'';position:absolute;width:420px;height:420px;border-radius:50%;background:radial-gradient(circle,rgba(242,112,29,.35),transparent 70%);right:-120px;top:-120px}
.hero-msg .sobre{font-family:var(--display);font-weight:700;letter-spacing:.2em;font-size:.78rem;text-transform:uppercase;color:#ffd9bd;display:block;margin-bottom:18px;position:relative}
.hero-msg h1{font-family:var(--display);font-weight:700;text-transform:uppercase;font-size:clamp(2rem,4.4vw,3.2rem);margin-bottom:20px;position:relative}
.hero-msg p{font-size:1.1rem;color:#e7f0fb;max-width:520px;margin-bottom:16px;position:relative}
.hero-msg .destacado{font-weight:700;color:#fff;font-size:1.15rem;margin:6px 0 26px;position:relative}
.hero-acciones{display:flex;gap:14px;flex-wrap:wrap;position:relative}

/* Panel destacado derecho (precio gigante o stat) */
.hero-panel{background:linear-gradient(135deg,var(--naranja),#b94d8f 55%,var(--magenta));color:#fff;text-align:center;position:relative;overflow:hidden}
.hero-panel::before{content:'';position:absolute;inset:0;background:radial-gradient(circle at 30% 20%,rgba(255,255,255,.25),transparent 50%)}
.hero-panel .etq{position:relative;font-family:var(--display);text-transform:uppercase;letter-spacing:.16em;font-size:.8rem;opacity:.95}
.hero-panel .giga{position:relative;font-family:var(--display);font-weight:800;font-size:clamp(3.5rem,10vw,6.5rem);line-height:.9;margin:8px 0;text-shadow:0 8px 30px rgba(0,0,0,.18)}
.hero-panel .sub{position:relative;font-family:var(--display);text-transform:uppercase;font-size:1.3rem;letter-spacing:.08em}
.hero-panel .nota{position:relative;margin-top:14px;font-size:1rem;opacity:.95}
.hero-panel .panel-img{position:relative;max-height:240px;width:auto;margin:18px auto 0;object-fit:contain}

/* Hero simple a pantalla (cuando no aplica el partido) */
.hero{position:relative;overflow:hidden;color:#fff;background:linear-gradient(120deg,var(--azul-osc),var(--azul) 55%,var(--azul-claro))}
.hero::after{content:'';position:absolute;inset:0;background:radial-gradient(circle at 80% 20%,rgba(242,112,29,.40),transparent 45%);pointer-events:none}
.hero .wrap{position:relative;z-index:2;display:grid;grid-template-columns:1.1fr .9fr;gap:40px;align-items:center;padding:80px 24px 90px}
.hero .sobre{font-family:var(--display);font-weight:700;letter-spacing:.2em;font-size:.78rem;text-transform:uppercase;color:#ffd9bd;display:block;margin-bottom:18px}
.hero h1{font-family:var(--display);font-weight:700;text-transform:uppercase;font-size:clamp(2rem,5vw,3.4rem);margin-bottom:20px}
.hero p{font-size:1.1rem;color:#e7f0fb;max-width:520px;margin-bottom:16px}
.hero .destacado{font-weight:700;font-size:1.15rem;margin:6px 0 26px}
.hero-media{aspect-ratio:4/3;border-radius:24px;overflow:hidden;box-shadow:var(--sombra-fuerte);background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.25)}
.hero-media img{width:100%;height:100%;object-fit:contain;background:#fff;padding:22px}

/* ---------- Banner promo de imagen (ancho completo) ---------- */
.promo-banner{display:block;border-radius:24px;overflow:hidden;box-shadow:var(--sombra);margin:0 auto}
.promo-banner img{width:100%;height:auto;display:block}

/* ---------- Fila de entretenimiento ---------- */
.pelis{display:grid;grid-template-columns:repeat(4,1fr);gap:20px}
.peli{border-radius:18px;overflow:hidden;box-shadow:var(--sombra);aspect-ratio:3/4;background:#0a1f3a;transition:transform .3s,box-shadow .3s}
.peli:hover{transform:translateY(-8px) scale(1.02);box-shadow:var(--sombra-fuerte)}
.peli img{width:100%;height:100%;object-fit:cover;display:block}

/* ---------- Showcase de imagen única (multipantalla / banner) ---------- */
.showcase{border-radius:24px;overflow:hidden;box-shadow:var(--sombra-fuerte);max-width:880px;margin:0 auto}
.showcase img{width:100%;height:auto;display:block}

/* ---------- Mascota CYS flotante ---------- */
.mascota-flota{position:relative}
.mascota-flota img{filter:drop-shadow(0 18px 30px rgba(10,46,92,.30));animation:flotar 4s ease-in-out infinite}
@keyframes flotar{0%,100%{transform:translateY(0)}50%{transform:translateY(-14px)}}

/* ---------- Banda "Síguenos" con mascota ---------- */
.redes-band{position:relative;overflow:hidden;border-radius:26px;
  background:linear-gradient(120deg,var(--azul-osc),var(--azul) 60%,var(--azul-claro));color:#fff;
  display:grid;grid-template-columns:.8fr 1.2fr;align-items:end;gap:0}
.redes-band .rb-img{align-self:end}
.redes-band .rb-img img{width:100%;max-width:340px;display:block}
.redes-band .rb-txt{padding:46px 46px 46px 0}
.redes-band h3{font-family:var(--display);text-transform:uppercase;font-size:clamp(1.5rem,3vw,2.2rem);margin-bottom:12px}
.redes-band .redes-cta{display:flex;gap:14px;margin-top:22px;flex-wrap:wrap}

/* ---------- Placeholder ---------- */
.ph{position:relative;background:repeating-linear-gradient(45deg,var(--gris) 0 14px,var(--gris-2) 14px 28px);display:flex;align-items:center;justify-content:center;color:var(--azul);font-family:var(--display);font-weight:700;text-transform:uppercase;letter-spacing:.06em;font-size:.78rem;text-align:center;padding:18px}
.ph::before{content:'IMG';position:absolute;top:10px;left:12px;font-size:.6rem;background:var(--azul);color:#fff;padding:2px 8px;border-radius:20px;letter-spacing:.1em}
.ph span{opacity:.75;max-width:80%}

/* ==========================================================================
   Bandas de color diagonales
   ========================================================================== */
.banda-color{height:14px;background:linear-gradient(90deg,#37d6a0,#2E83D8 35%,var(--azul) 60%,var(--magenta) 80%,var(--naranja));transform:skewY(-1.2deg);margin:-7px 0}

/* ---------- Grids ---------- */
.grid{display:grid;gap:26px}
.g-2{grid-template-columns:repeat(2,1fr)}
.g-3{grid-template-columns:repeat(3,1fr)}
.g-4{grid-template-columns:repeat(4,1fr)}

/* ==========================================================================
   Tarjetas-servicio de COLOR
   ========================================================================== */
.serv-color{display:flex;flex-direction:column;gap:12px;padding:30px;border-radius:var(--radio);color:#fff;position:relative;overflow:hidden;min-height:210px;box-shadow:var(--sombra);transition:transform .3s,box-shadow .3s}
.serv-color:hover{transform:translateY(-8px);box-shadow:var(--sombra-fuerte)}
.serv-color.azul{background:linear-gradient(150deg,var(--azul),var(--azul-osc))}
.serv-color.naranja{background:linear-gradient(150deg,var(--naranja),var(--naranja-osc))}
.serv-color.magenta{background:linear-gradient(150deg,var(--magenta),#5a1f8c)}
.serv-color.cian{background:linear-gradient(150deg,#1aa6b7,#0a6b86)}
.serv-color .ico .bi{width:42px;height:42px;fill:#fff}
.serv-color h3{font-family:var(--display);font-weight:700;text-transform:uppercase;font-size:1.15rem}
.serv-color p{font-size:.94rem;opacity:.95}
.serv-color .mas{margin-top:auto;font-weight:700;font-size:.9rem}

/* Servicio claro (icono azul / título naranja) */
.serv{display:flex;flex-direction:column;gap:14px;padding:30px;background:#fff;border-radius:var(--radio);border:1px solid var(--gris-2);box-shadow:var(--sombra);transition:transform .3s,box-shadow .3s}
.serv:hover{transform:translateY(-8px);box-shadow:var(--sombra-fuerte)}
.serv .ico{width:62px;height:62px;border-radius:16px;display:grid;place-items:center;background:rgba(18,87,166,.10);color:var(--azul)}
.serv .ico .bi{width:30px;height:30px}
.serv h3{font-family:var(--display);font-weight:700;text-transform:uppercase;font-size:1.05rem;color:var(--naranja)}
.serv p{color:var(--texto-suave);font-size:.95rem}

/* Tarjeta de producto (imagen SIN recorte) */
.card{background:#fff;border:1px solid var(--gris-2);border-radius:var(--radio);overflow:hidden;box-shadow:var(--sombra);transition:transform .3s,box-shadow .3s;display:flex;flex-direction:column}
.card:hover{transform:translateY(-8px);box-shadow:var(--sombra-fuerte)}
.card-media{aspect-ratio:16/11;background:#fff;display:grid;place-items:center;padding:20px;border-bottom:1px solid var(--gris-2)}
.card-media img{width:100%;height:100%;object-fit:contain}
.card-body{padding:24px}
.card-body h3{font-family:var(--display);font-weight:700;text-transform:uppercase;font-size:1.1rem;color:var(--azul);margin-bottom:10px}
.card-body p{color:var(--texto-suave);font-size:.96rem}

/* Lista de beneficios */
.benef{list-style:none;display:grid;gap:10px;margin:18px 0}
.benef li{position:relative;padding-left:30px;color:var(--texto-suave)}
.benef li::before{content:'';position:absolute;left:0;top:5px;width:18px;height:18px;
  background:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' fill='%231257A6' viewBox='0 0 16 16'%3E%3Cpath d='M13.854 3.646a.5.5 0 0 1 0 .708l-7 7a.5.5 0 0 1-.708 0l-3.5-3.5a.5.5 0 1 1 .708-.708L6.5 10.293l6.646-6.647a.5.5 0 0 1 .708 0z'/%3E%3C/svg%3E") center/contain no-repeat}

/* ==========================================================================
   Pastillas de color — zonas / categorías
   ========================================================================== */
.pills{display:flex;flex-wrap:wrap;gap:14px;justify-content:center}
.pill{font-family:var(--display);font-weight:700;text-transform:uppercase;font-size:.85rem;letter-spacing:.04em;color:#fff;padding:14px 26px;border-radius:14px;box-shadow:var(--sombra);transition:transform .25s}
.pill:hover{transform:translateY(-4px)}
.pill.azul{background:var(--azul)}.pill.naranja{background:var(--naranja)}
.pill.magenta{background:var(--magenta)}.pill.cian{background:#1aa6b7}
.pill.verde{background:#2faa6a}.pill.osc{background:var(--azul-osc)}

/* ==========================================================================
   Aliados — logos en pastillas blancas, SIN recorte
   ========================================================================== */
.aliados{overflow:hidden;padding:12px 0;-webkit-mask-image:linear-gradient(90deg,transparent,#000 7%,#000 93%,transparent);mask-image:linear-gradient(90deg,transparent,#000 7%,#000 93%,transparent)}
.aliados-track{display:flex;gap:70px;width:max-content;animation:scrollx 45s linear infinite;align-items:center}
.aliados:hover .aliados-track{animation-play-state:paused}
.aliados-track .chip{flex:0 0 auto;height:80px;width:170px;display:grid;place-items:center}
.aliados-track .chip img{max-height:48px;max-width:100%;width:auto;height:auto;object-fit:contain;filter:grayscale(1);opacity:.5;transition:filter .3s,opacity .3s}
.aliados-track .chip:hover img{filter:none;opacity:1}
.aliados-track .chip.vert img{max-height:74px}
@keyframes scrollx{to{transform:translateX(-50%)}}

/* ==========================================================================
   MÓDULO 2 — Planes
   ========================================================================== */
.planes{display:grid;grid-template-columns:repeat(4,1fr);gap:22px}
.plan{position:relative;border-radius:22px;padding:32px 26px;color:#fff;overflow:hidden;box-shadow:var(--sombra);transition:transform .3s,box-shadow .3s;border:1px solid rgba(255,255,255,.18)}
.plan:hover{transform:translateY(-10px);box-shadow:var(--sombra-fuerte)}
.plan.azul{background:linear-gradient(160deg,var(--azul),var(--azul-osc))}
.plan.naranja{background:linear-gradient(160deg,var(--naranja),var(--naranja-osc))}
.plan .nombre{font-family:var(--display);text-transform:uppercase;font-size:.85rem;letter-spacing:.12em;opacity:.92}
.plan .mb{font-family:var(--display);font-weight:800;font-size:2.8rem;line-height:1;margin:12px 0 4px}
.plan .precio{font-size:1.5rem;font-weight:700}
.plan .precio small{font-size:.85rem;font-weight:500;opacity:.85}
.plan .desc{font-size:.92rem;opacity:.92;margin:14px 0 22px;min-height:60px}
.plan .btn{background:#fff;color:var(--azul-osc);width:100%;justify-content:center;padding:12px;font-size:.82rem}
.plan.naranja .btn{color:var(--naranja-osc)}

.plan-detalle{display:grid;grid-template-columns:1fr 1fr;gap:40px;align-items:center;padding:38px;border-radius:24px;background:#fff;border:1px solid var(--gris-2);box-shadow:var(--sombra);margin-bottom:30px}
.plan-detalle:nth-child(even){direction:rtl}
.plan-detalle:nth-child(even)>*{direction:ltr}
.plan-detalle .pd-media{aspect-ratio:4/3;border-radius:18px;overflow:hidden;background:#fff;display:grid;place-items:center;padding:22px;border:1px solid var(--gris-2)}
.plan-detalle .pd-media img{width:100%;height:100%;object-fit:contain}
.plan-detalle .pd-media .ph{width:100%;height:100%}
.plan-detalle h3{font-family:var(--display);text-transform:uppercase;color:var(--azul-osc);font-size:1.6rem}
.plan-detalle .precio-chip{display:inline-block;background:var(--naranja);color:#fff;font-weight:700;padding:6px 18px;border-radius:40px;margin:12px 0;font-size:1.05rem}

/* ==========================================================================
   Secciones oscuras (azul oscuro)
   ========================================================================== */
.modulo-osc{background:var(--azul-osc);color:#e7f0fb;position:relative;overflow:hidden}
.modulo-osc::before{content:'';position:absolute;inset:0;background:radial-gradient(circle at 15% 20%,rgba(46,131,216,.30),transparent 40%),radial-gradient(circle at 85% 70%,rgba(242,112,29,.22),transparent 40%);pointer-events:none}
.modulo-osc .wrap{position:relative;z-index:2}
.modulo-osc .sec-cabeza h2{color:#fff}

/* ==========================================================================
   MÓDULO 4 — Newsletter
   ========================================================================== */
.news-hero{background:#fff;color:var(--azul-osc);padding:80px 0 0;position:relative;overflow:hidden}
.news-hero .wrap{display:grid;grid-template-columns:1.15fr .85fr;gap:40px;align-items:center}
.news-hero .sobre{font-family:var(--display);font-weight:700;letter-spacing:.2em;font-size:.8rem;text-transform:uppercase;color:var(--naranja);display:block;margin-bottom:14px}
.news-hero h1{font-family:var(--display);font-weight:800;text-transform:uppercase;font-size:clamp(2.6rem,7vw,5rem);color:var(--azul-osc);line-height:.95;margin-bottom:18px}
.news-hero p{color:var(--texto-suave);font-size:1.1rem;max-width:520px;margin-bottom:26px}
.news-hero .foto{aspect-ratio:1/1;border-radius:0 120px 0 120px;overflow:hidden;box-shadow:var(--sombra-fuerte)}
.news-hero .foto .ph,.news-hero .foto img{width:100%;height:100%;object-fit:cover}

/* Tarjeta promo de color con imagen */
.promo{display:grid;grid-template-columns:1.05fr .95fr;border-radius:26px;overflow:hidden;box-shadow:var(--sombra-fuerte);margin-bottom:26px}
.promo .promo-txt{padding:46px;color:#fff;display:flex;flex-direction:column;justify-content:center}
.promo.magenta .promo-txt{background:linear-gradient(135deg,var(--magenta),#4d1a7d)}
.promo.azul .promo-txt{background:linear-gradient(135deg,var(--azul),var(--azul-osc))}
.promo .badge{display:inline-block;background:rgba(255,255,255,.18);color:#fff;font-family:var(--display);text-transform:uppercase;font-size:.72rem;letter-spacing:.1em;padding:6px 16px;border-radius:40px;margin-bottom:16px;align-self:flex-start}
.promo .promo-txt h3{font-family:var(--display);text-transform:uppercase;font-size:clamp(1.4rem,3vw,2rem);margin-bottom:14px;line-height:1.05}
.promo .promo-txt p{color:rgba(255,255,255,.92);margin-bottom:10px}
.promo .promo-img{position:relative;min-height:300px;background:#0a1f3a}
.promo .promo-img img,.promo .promo-img .ph{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}

.noticia{display:grid;grid-template-columns:1fr 1fr;gap:30px;align-items:center;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.14);border-radius:24px;overflow:hidden;padding:34px}
.noticia .badge{display:inline-block;background:var(--naranja);color:#fff;font-family:var(--display);text-transform:uppercase;font-size:.72rem;letter-spacing:.1em;padding:6px 16px;border-radius:40px;margin-bottom:16px}
.noticia h3{font-family:var(--display);text-transform:uppercase;color:#fff;font-size:1.5rem;margin-bottom:14px}
.noticia .nt-media{aspect-ratio:16/10;border-radius:16px;overflow:hidden}
.noticia .nt-media .ph,.noticia .nt-media img{width:100%;height:100%;object-fit:cover}

/* Testimonios */
.reviews{display:grid;grid-template-columns:repeat(4,1fr);gap:22px}
.review{background:#fff;border-radius:18px;padding:26px;box-shadow:var(--sombra);color:var(--texto);transition:transform .3s,box-shadow .3s}
.review:hover{transform:translateY(-8px);box-shadow:var(--sombra-fuerte)}
.review .estrellas{color:#FFC107;font-size:1.05rem;margin-bottom:10px}
.review h4{font-family:var(--display);text-transform:uppercase;font-size:.95rem;color:var(--azul);margin-bottom:8px}
.review p{font-size:.92rem;color:var(--texto-suave);font-style:italic;margin-bottom:16px}
.review .autor{display:flex;align-items:center;gap:10px}
.review .avatar{width:42px;height:42px;border-radius:50%;background:var(--gris-2);display:grid;place-items:center;color:var(--azul);font-weight:700}
.review .autor b{font-style:normal;color:var(--texto)}

/* Newsletter form (banda con gradiente) */
.newsletter{background:linear-gradient(120deg,var(--magenta),var(--azul) 55%,var(--azul-claro));color:#fff;border-radius:24px;padding:48px;text-align:center}
.newsletter h3{font-family:var(--display);text-transform:uppercase;font-size:1.9rem;margin-bottom:10px}
.newsletter form{display:flex;gap:12px;max-width:560px;margin:24px auto 0;flex-wrap:wrap}
.newsletter input{flex:1;min-width:180px;padding:15px 20px;border-radius:60px;border:0;font-family:inherit;font-size:1rem}
.newsletter .nota{margin-top:16px;font-size:.85rem;opacity:.88}

/* Cobertura zonas (legacy, ahora usamos .pills) */
.cobertura{display:flex;flex-wrap:wrap;gap:16px;justify-content:center;margin-top:30px}

/* ==========================================================================
   Mapa de cobertura SVG interactivo (municipios que se pintan al pasar el mouse)
   ========================================================================== */
.mapa-cob{position:relative;max-width:720px;margin:0 auto 26px;background:#fff;border-radius:24px;padding:30px}
.mapa-cob svg{width:100%;height:auto;display:block;overflow:visible}
.muni{fill:var(--azul);stroke:#fff;stroke-width:1.6px;cursor:pointer;transition:fill .2s ease}
.muni:hover{fill:var(--naranja)}
.munilbl{font-family:'Elza',sans-serif;font-weight:700;font-size:17px;fill:#fff;text-anchor:middle;dominant-baseline:middle;
  pointer-events:none;paint-order:stroke;stroke:rgba(10,46,92,.45);stroke-width:3.5px;stroke-linejoin:round}
.mapa-tip{position:absolute;pointer-events:none;background:var(--azul-osc);color:#fff;padding:8px 13px;border-radius:10px;
  font-size:.82rem;font-weight:700;transform:translate(-50%,calc(-100% - 12px));white-space:nowrap;z-index:5;box-shadow:var(--sombra)}
.mapa-tip::after{content:'';position:absolute;left:50%;bottom:-6px;transform:translateX(-50%);
  border:6px solid transparent;border-top-color:var(--azul-osc)}
.mapa-tip[hidden]{display:none}
.mapa-leyenda{display:flex;gap:24px;justify-content:center;margin-top:18px;color:var(--texto-suave);font-size:.9rem;font-weight:700}
.mapa-leyenda i{display:inline-block;width:14px;height:14px;border-radius:4px;margin-right:7px;vertical-align:-2px}
.mapa-leyenda .cov{background:var(--azul)}

/* ==========================================================================
   Footer / Contacto
   ========================================================================== */
.footer{background:var(--azul-osc);color:#dbe7f5;padding:70px 0 30px;position:relative}
.footer .sec-cabeza h2{color:#fff}
.footer .sec-cabeza .sobre{color:var(--naranja)}
.contacto-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-bottom:46px}
.contacto-card{background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.12);border-radius:var(--radio);padding:26px;text-align:center}
.contacto-card .ico{color:var(--azul-claro);margin-bottom:10px}
.contacto-card .ico .bi{width:30px;height:30px}
.pill .bi{width:1em;height:1em;vertical-align:-.15em;margin-right:6px}
.estrellas{display:inline-flex;gap:2px;color:#FFC107;margin-bottom:10px}
.estrellas .bi{width:18px;height:18px}
.contacto-card h4{font-family:var(--display);text-transform:uppercase;color:var(--naranja);font-size:.95rem;margin-bottom:6px}
.contacto-card p{color:#cfe0f2;font-size:.95rem;word-break:break-word}
.footer-acciones{display:flex;gap:12px;flex-wrap:wrap;justify-content:center;margin-bottom:40px}
.footer-bottom{border-top:1px solid rgba(255,255,255,.12);padding-top:26px;display:flex;justify-content:space-between;align-items:center;gap:18px;flex-wrap:wrap}
.footer-bottom .flogo{height:38px;width:auto}
.redes{display:flex;gap:14px}
.redes a{width:42px;height:42px;border-radius:50%;display:grid;place-items:center;background:rgba(255,255,255,.10);transition:.25s}
.redes a:hover{background:var(--naranja);transform:translateY(-3px)}
.redes svg{width:20px;height:20px;fill:#fff}

/* WhatsApp flotante */
.wa{position:fixed;right:22px;bottom:22px;z-index:80;width:60px;height:60px;border-radius:50%;background:#25D366;display:grid;place-items:center;box-shadow:0 12px 28px rgba(37,211,102,.45);transition:transform .25s}
.wa:hover{transform:scale(1.08)}
.wa svg{width:32px;height:32px;fill:#fff}

/* ==========================================================================
   Responsive
   ========================================================================== */
@media(max-width:980px){
  .hero-split{grid-template-columns:1fr}
  .hero-split .lado{padding:56px 32px}
  .hero .wrap{grid-template-columns:1fr}
  .hero-media{order:-1;max-height:320px}
  .news-hero .wrap{grid-template-columns:1fr}
  .news-hero .foto{order:-1;max-height:340px;border-radius:0 70px 0 70px}
  .planes{grid-template-columns:repeat(2,1fr)}
  .reviews{grid-template-columns:repeat(2,1fr)}
  .g-3,.g-4{grid-template-columns:repeat(2,1fr)}
  .pelis{grid-template-columns:repeat(2,1fr)}
  .redes-band{grid-template-columns:1fr}
  .redes-band .rb-img{justify-self:center}
  .redes-band .rb-txt{padding:0 32px 40px;text-align:center}
  .redes-band .redes-cta{justify-content:center}
  .plan-detalle,.noticia,.promo{grid-template-columns:1fr}
  .promo .promo-img{min-height:240px;order:-1}
  .plan-detalle:nth-child(even){direction:ltr}
  .hero-cine .wrap{min-height:480px}
}
@media(max-width:760px){
  .nav-cta .btn{display:none}
  .burger{display:flex}
  /* Menú móvil a pantalla completa, fluido */
  .nav-links{position:fixed;inset:0;z-index:120;background:linear-gradient(160deg,var(--azul-osc),var(--azul) 70%,var(--azul-claro));
    flex-direction:column;align-items:center;justify-content:center;gap:8px;padding:24px;margin:0;
    opacity:0;visibility:hidden;transform:translateY(-10px);transition:opacity .35s ease,transform .45s ease,visibility .35s}
  .nav-links.abierto{opacity:1;visibility:visible;transform:none}
  .nav-links li{opacity:0;transform:translateY(16px);transition:opacity .45s ease,transform .45s ease}
  .nav-links.abierto li{opacity:1;transform:none}
  .nav-links.abierto li:nth-child(1){transition-delay:.10s}
  .nav-links.abierto li:nth-child(2){transition-delay:.16s}
  .nav-links.abierto li:nth-child(3){transition-delay:.22s}
  .nav-links.abierto li:nth-child(4){transition-delay:.28s}
  .nav-links.abierto li:nth-child(5){transition-delay:.34s}
  .nav-links a:not(.btn){color:#fff;font-family:var(--display);font-weight:800;text-transform:uppercase;font-size:1.8rem;letter-spacing:.04em;padding:10px 0;display:block}
  .nav-links a.activo:not(.btn){color:var(--naranja)}
  .nav-links a.activo::after{display:none}
  .nav-links .btn{font-size:1.05rem;padding:16px 40px;margin-top:14px}
  .solo-movil{display:block}
  .nav-close{display:grid}
  .g-2,.g-3,.g-4,.planes,.reviews,.contacto-grid{grid-template-columns:1fr}
  .sec{padding:60px 0}
  .footer-bottom{flex-direction:column;text-align:center}
  /* Hero móvil: imagen full a TODO el alto + scrim desde abajo */
  .hero-cine{min-height:100vh;min-height:100dvh;align-items:flex-end}
  .hero-cine::after{background:linear-gradient(0deg,rgba(5,18,38,.95) 0%,rgba(5,18,38,.78) 30%,rgba(5,18,38,.35) 58%,rgba(5,18,38,.08) 100%)}
  .hero-cine .wrap{padding:0 22px 64px}
  .hero-cine .bg img{object-position:60% center}
  /* Bandas full-width móvil */
  .feature-band{min-height:auto;align-items:flex-end}
  .feature-band::after{background:linear-gradient(0deg,rgba(5,18,38,.94) 0%,rgba(5,18,38,.6) 55%,rgba(5,18,38,.25) 100%)}
  .feature-band .wrap{padding:60vh 22px 40px}
  .feature-band.compacta .wrap{padding:46vh 22px 36px}
  /* Banda inmersiva en móvil: más cuadrada, sujeto encuadrado, texto al pie */
  .feature-band.full{min-height:0;aspect-ratio:4/5}
  .feature-band.full .bg img{object-position:70% 28%}
  .feature-band.full::after{background:linear-gradient(0deg,rgba(5,18,38,.96) 0%,rgba(5,18,38,.82) 26%,rgba(5,18,38,.3) 52%,transparent 80%)}
  .feature-band.full .wrap{padding:0 22px 34px}
  /* Mascota transición: apilada y centrada */
  .mascota-trans .wrap{flex-direction:column;text-align:center;gap:0;padding-top:0}
  .mascota-trans .mt-bee{width:170px;margin-top:-60px}
  .plan-visual{min-height:240px;padding:36px}
  .tira-full{grid-template-columns:1fr}
  .tira-full .panel-img{min-height:42vh}
  /* Hero slider móvil: a TODO el alto, scrim desde abajo y texto al pie */
  .hero-slider{min-height:100vh;min-height:100dvh;align-items:flex-end}
  .hero-slider::after{background:linear-gradient(0deg,rgba(5,18,38,.95) 0%,rgba(5,18,38,.7) 32%,rgba(5,18,38,.3) 60%,transparent 100%)}
  .hero-slider .hm-content{width:100%;padding:0 22px 70px;text-align:center}
  .hero-slider .hm-content .hero-acciones{justify-content:center}
  .hero-slider .slide img{object-position:60% center}
  /* la mascota centrada y completa de arriba abajo */
  .hero-slider .slide.pos-bee img{object-position:55% top}
  /* Exp slider móvil */
  .exp-slider{min-height:54vh}
  /* Banda mascota móvil */
  .mascota-banner{background:linear-gradient(160deg,#3a1d9e,#7b4be6)}
  .mascota-banner::after{display:none}
  .mascota-banner .mb-bg{height:340px;object-fit:cover;object-position:2% center}
  .mascota-banner .mb-content{position:static;width:100%;padding:28px 22px 40px;text-align:center}
  .mascota-banner .mb-content h3,.mascota-banner .mb-content p{color:#fff}
  .mascota-banner .mb-content p{margin-left:auto;margin-right:auto;opacity:.9}
  .mascota-banner .mb-content .redes-cta{justify-content:center}
}

/* Los títulos/textos antes en fuente display ahora usan Elza (Bold para destacar),
   para un acabado más armonioso y legible. */

/* ==========================================================================
   Títulos estilo editorial: mayúscula solo inicial + interlineado compacto.
   (Los rótulos pequeños, botones, pastillas y nombres de plan siguen en MAYÚSCULAS.)
   ========================================================================== */
.sec-cabeza h2,
.hero-cine h1, .hero-slider h1, .hero h1, .hero-mascota h1, .hero-msg h1, .news-hero h1,
.feature-band h2, .mascota-banner h3, .mascota-trans .mt-txt h3, .redes-band h3,
.serv h3, .serv-color h3, .card-body h3, .plan-detalle h3,
.promo .promo-txt h3, .noticia h3, .review h4, .contacto-card h4,
.exp-slider .es-cap h3, .tira-full .cap h3, .newsletter h3{
  text-transform:none;
  letter-spacing:0;
  line-height:1.04;
}
