/* ======================== */
/* BASE GLOBAL */
/* ======================== */
:root { --white: #fff; --cyber-blue: #0400BE; --cyber-darkblue: #16145D; --cyber-dark: #080826; --cyber-sky: #00CBFF; --cyber-lima: #B8FF00; --cyber-grey: #F5F9FF; --text-color-dark: #2D2D40; --text-color-grey: #434357; --text-color-light: #6B6B75; --grey-dark: #2D2D40; --grey: #434357; --grey-light: #6B6B75; --shadow-light: #0000001a; --shadow-dark: #0003 }

/* ======================== */
/* RESET GENERAL Y BASE */
/* ======================== */
* { margin: 0; padding: 0; box-sizing: border-box; }

:focus-visible { outline: 2px solid rgba(4,0,190,.35); outline-offset: 3px; }

:focus:not(:focus-visible) { outline: none; }

html { line-height: 1.15; -webkit-text-size-adjust: 100%; background: var(--white); }

body { font-family: 'Montserrat', Arial, sans-serif; font-size: 16px; line-height: 1.5; color: var(--text-color-dark); background-color: var(--white); margin: 0; }

main { display: block; }

h1, h2, h3, h4, h5, h6 { margin: 0; color: var(--cyber-darkblue); }
h1 { font-size: clamp(2.2rem, 3.6vw, 3.2rem); font-weight: 700; line-height: 1.15; }
h2 { font-size: clamp(1.8rem, 2.6vw, 2.4rem); font-weight: 300; line-height: 1.2; text-align: left; }
h3 { font-size: 1.25rem; font-weight: 600; line-height: 1.35; }
h4 { font-size: 1.1rem; font-weight: 600; line-height: 1.4; }
h5 { font-size: 1rem; font-weight: 600; line-height: 1.4; }
h6 { font-size: .95rem; font-weight: 600; line-height: 1.4; }

p { font-weight: 400; font-size: 1rem; line-height: 1.6; color: var(--text-color-grey); }

ul, ol { list-style: none; margin: 0; padding: 0; }

a { color: var(--cyber-sky); text-decoration: none; transition: color .3s ease; }

a:hover { color: var(--cyber-darkblue); }

img { max-width: 100%; height: auto; display: block; }

button, input, select, textarea { font-family: inherit; font-size: 100%; margin: 0; }

textarea { resize: vertical; }

[type="checkbox"], [type="radio"] { box-sizing: border-box; padding: 0; }

[hidden] { display: none; }

fieldset, legend { border: 0; padding: 0; }

/* ======================== */
/* FUENTES */
/* ======================== */
@font-face { font-family:'Montserrat'; font-style:normal; font-weight:400; font-display:swap; src:url('../fonts/montserrat-v29-latin-regular.woff2') format('woff2'); }

@font-face { font-family:'Montserrat'; font-style:normal; font-weight:500; font-display:swap; src:url('../fonts/montserrat-v29-latin-500.woff2') format('woff2'); }

@font-face { font-family:'Montserrat'; font-style:normal; font-weight:700; font-display:swap; src:url('../fonts/montserrat-v29-latin-700.woff2') format('woff2'); }

@font-face { font-family:'Montserrat'; font-style:normal; font-weight:900; font-display:swap; src:url('../fonts/montserrat-v29-latin-900.woff2') format('woff2'); }

/* ======================== */
/* TIPOGRAFIA */
/* ======================== */
h2 strong { color: var(--cyber-blue); font-weight: 700; }

h2.text-center { text-align: left; }


.text-center { text-align: center; }

.t-card-title { font-size: 1.15rem; font-weight: 600; line-height: 1.35; color: var(--cyber-darkblue); }

.t-card-body { font-size: .95rem; line-height: 1.55; color: var(--text-color-grey); }

/* Tipografía Hero */
.t-hero-title { font-size: clamp(1.95rem, 3.6vw, 3.1rem); line-height: 1.1; font-weight: 600; color: var(--cyber-darkblue); letter-spacing: -0.012em; }
.t-hero-subtitle { font-size: clamp(1rem, 1.45vw, 1.12rem); line-height: 1.55; color: var(--text-color-grey); }
.t-hero-highlight-title { font-size: 1rem; font-weight: 700; color: var(--cyber-darkblue); }
.t-hero-highlight-text { font-size: .84rem; color: var(--text-color-grey); }

/* Texto acentuado global */
.t-text-accent { color: var(--cyber-blue); font-weight: 700; }

/* Texto micro (cupones / legal) */
.t-text-micro { font-size: .75rem; line-height: 1.4; color: var(--text-color-light); }

/* Tipografía Universal */
.t-title-xl { font-size: 2rem; font-weight: 700; line-height: 1.1; }
.t-title-xl strong { color: var(--cyber-blue); font-weight: 700; }
.t-title-lg { font-size: 1.25rem; font-weight: 400; line-height: 1.3; color: var(--cyber-darkblue); }
.t-title-lg strong { color: var(--cyber-blue); font-weight: 700; }
.t-title-lg strong { font-size: 1.8rem; font-weight: 700; letter-spacing: -0.02em; }
.t-body { font-size: .95rem; line-height: 1.55; color: var(--text-color-grey); }
.t-price-lg { font-size: 1.5rem; font-weight: 700; }
.t-price-xl { font-size: 1.6rem; font-weight: 700; color: var(--cyber-sky); }
.t-price-sm { font-size: .85rem; color: var(--cyber-darkblue); }
.t-meta { font-size: .8rem; font-weight: 400; color: var(--text-color-light); }
.t-tab { font-size: 1rem; font-weight: 700; color: var(--cyber-blue); }
.t-link-strong { font-size: .9rem; font-weight: 700; color: var(--cyber-sky); }
.t-badge { font-size: .75rem; font-weight: 700; letter-spacing: .08em; text-transform: uppercase; }
.t-text-sky { color: var(--cyber-sky); }
.t-text-light { color: var(--white); }

/* Recurso reutilizable para flags en lima */
.flag-lima {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: fit-content;
  min-height: 30px;
  padding: 6px 14px;
  border-radius: 999px;
  background: var(--cyber-lima);
  color: var(--cyber-darkblue);
  font-size: .75rem;
  font-weight: 700;
  letter-spacing: .06em;
  line-height: 1;
  text-transform: uppercase;
}

.flag-lima--center { margin-left: auto; margin-right: auto; }

.flag-lima--left { margin-left: 0; margin-right: auto; }

/* ======================== */
/* EFECTOS */
/* ======================== */
.fade-in { opacity: 0; transform: translateY(20px); transition: opacity 0.6s ease-out, transform 0.6s ease-out; }

.fade-in.visible { opacity: 1; transform: translateY(0); }

body.no-scroll { overflow: hidden; height: 100vh; }

/* ======================== */
/* COMPONENTE CARRUSEL */
/* ======================== */
.mod-carousel { position:relative; }

.mod-carousel__track { position:relative; overflow:hidden; padding:0 40px; }

.mod-carousel__wrapper { }

.mod-carousel__slide { }

.mod-carousel__prev, .mod-carousel__next { position:absolute; top:50%; transform:translateY(-50%); z-index:10; width:48px; height:48px; background:transparent; color:var(--cyber-sky); border:2px solid var(--cyber-sky); border-radius:50%; box-shadow:none; display:flex; align-items:center; justify-content:center; padding:0; cursor:pointer; transition:border-color .2s ease, color .2s ease, background-color .2s ease; }

.mod-carousel__prev:hover, .mod-carousel__next:hover { border-color: var(--cyber-blue); color: var(--cyber-blue); background: transparent; }

.mod-carousel__prev::before, .mod-carousel__next::before { display:block; font-size:34px; font-weight:700; line-height:1; transform: translateY(-1px); }
.mod-carousel__prev::before { content:'‹'; }
.mod-carousel__next::before { content:'›'; }

.mod-carousel__prev { left:8px; }

.mod-carousel__next { right:8px; }

.mod-carousel__pagination { margin-top:20px; text-align:center; }

.mod-carousel__pagination .swiper-pagination-bullet { background:rgba(4,0,190,.35); opacity:1; width:10px; height:10px; border:1px solid rgba(4,0,190,.42); border-radius:50%; display:inline-block; margin:0 5px; }

.mod-carousel__pagination .swiper-pagination-bullet-active { background:var(--cyber-blue); opacity:1; }
.gradient-lineal { background:linear-gradient(180deg,var(--cyber-grey) 0%,#fff 100%); }

.gradient-radient { background:radial-gradient(1100px 520px at 60% 20%,rgba(0,203,255,.22) 0%,rgba(4,0,190,.10) 38%,rgba(255,255,255,0) 72%),linear-gradient(135deg,var(--cyber-grey) 0%,var(--cyber-grey) 100%) !important; }
/* ======================== */
/* HEADER / FOOTER BASE */
/* ======================== */

header { background-color: var(--cyber-blue); position: relative; height: 60px; }

footer { background-color: var(--cyber-darkblue); color: var(--text-color-dark); padding: 1rem 0; position: relative; }

/* ======================== */
/*  */
/* ======================== */

/* TOP TOOLBAR */
/* ======================== */
/*  */
/* ======================== */

.mod-header__toolbar { background-color: #0400BE; color: var(--white); font-size: 12px; font-weight: 400; line-height: 1.35; transition: transform 0.5s ease-out; position: sticky; top: 0; z-index: 100; }
.mod-header__toolbar .container { display: flex; justify-content: space-between; align-items: center; min-height: 30px; padding-left: 23px; padding-right: 23px; }
.mod-header__toolbar-left, .mod-header__toolbar-right { display: flex; align-items: center; }
.mod-header__toolbar-left strong { font-weight: 700; }
.mod-header__toolbar-right a { color: var(--white); text-decoration: none; margin-left: 20px; display: inline-flex; align-items: center; font-weight: 600; }
.mod-header__toolbar-right img { width: 16px; height: 16px; margin-right: 6px; vertical-align: middle; }

/* TOOLBAR EN MÓVIL */
@media (max-width: 1024px) { .mod-header__toolbar {display: none; } }

/* SUBMENÚ DINÁMICO */

/* BOTÓN DE MENÚ (ESCRITORIO) */
.mod-header__trigger { display: flex; align-items: center; gap: 8px; background: none; border: none; color: var(--cyber-blue); font-weight: 600; cursor: pointer; font-size: 14px; padding: 10px 20px; }
.mod-header__icon { width: 20px; height: 20px; display: inline-block; }

/* NAVBAR / ESTRUCTURA */
.mod-header__nav { overflow: hidden; }
.mod-header__group { overflow: hidden; }
.mod-header__group .mod-header__trigger { border: none; outline: none; color: var(--cyber-blue); padding: 20px 10px 20px 20px; background: inherit; cursor: pointer; transition: color .3s ease; }
.mod-header__group .mod-header__trigger:hover { color: var(--cyber-sky); }
.mod-header__panel { display: none; position: absolute; background: var(--cyber-dark); width: 100%; left: 0; z-index: 10; padding: 10px 0 40px; opacity: 0; transform: translateY(-10px); transition: opacity .3s ease, transform .3s ease; }
.mod-header__group:hover .mod-header__panel { display: block; opacity: 1; transform: translateY(0); }

/* ======================== */
/*  */
/* ======================== */

/* BLOQUE CABECERA ESCRITORIO */
/* ======================== */
/*  */
/* ======================== */

#escritorio { position: relative; top: 0; z-index: 1100; transition: top 0.3s ease, position 0.3s ease; background: var(--white); width: 100%; box-shadow: 0 2px 5px rgba(150, 150, 200, 0.1); }
body.scrolled #escritorio { box-shadow: 0 2px 5px rgba(150, 150, 200, 0.1); }
#escritorio.fixed { position: fixed !important; top: 0; left: 0; right: 0; z-index: 1500; box-shadow: 0 6px 12px rgba(0, 0, 0, 0.15); transition: box-shadow 0.3s ease; }

/* ======================== */
/*  */
/* ======================== */

/* ANIMACIÓN ENTRADA */
/* ======================== */
/*  */
/* ======================== */

@keyframes fadeInUp { from {opacity: 0; transform: translateY(20px); }to { opacity: 1; transform: translateY(0); }}

/* ======================== */
/*  */
/* ======================== */

/* MENÚ SECUNDARIO CLIENTES */
/* ======================== */
/*  */
/* ======================== */

.mod-header__secondary { margin-left: auto; display: flex; align-items: center; justify-content: flex-end; }

/* ======================== */
/*  */
/* ======================== */

/* DROPDOWN BOTÓN Y MENÚ */
/* ======================== */
/*  */
/* ======================== */

.mod-header__dropdown { position: relative; display: inline-block; }
.mod-header__dropdown-btn { color: var(--cyber-blue); padding: 5px 15px; border: 2px solid var(--cyber-blue); border-radius: 100px; cursor: pointer; font-size: 14px; transition: background-color .3s ease; background-color: var(--white); }
.mod-header__dropdown-btn:hover { border: 2px solid var(--cyber-blue); background-color: var(--cyber-blue); color: var(--cyber-sky); }
.mod-header__dropdown-content { display: none; position: absolute; background-color: var(--text-color-dark); box-shadow: 0 4px 6px var(--shadow-light); padding: 10px; border-radius: 10px; z-index: 10; opacity: 0; transform: translateY(-10px); transition: opacity .3s ease, transform .3s ease; width: 100%; }
.mod-header__dropdown:hover .mod-header__dropdown-content { display: block; opacity: 1; transform: translateY(0); }
.mod-header__dropdown-content a { color: var(--cyber-sky); padding: 5px 10px; text-decoration: none; display: block; font-size: 14px; }
.mod-header__dropdown-content a:hover { background-color: var(--cyber-sky); color: var(--white); border-radius: 3px; }

/* ======================== */
/*  */
/* ======================== */

/* COLUMNAS Y FILAS MENU DESPLEGABLE */
/* ======================== */
/*  */
/* ======================== */

.column { float: left; width: 25%; }
.column h3 { color: var(--cyber-sky); font-size: 12px; float: left; width: 100%; text-align: left; font-weight: 100; }
.column a { display: block; float: none; color: var(--white); text-align: left; padding: 0; }
.column a:hover { color: var(--cyber-sky); }
.row:after { content: ''; display: table; clear: both; }
@media (max-width: 650px) { .column {width: 100%; height: auto; }
}

/* ======================== */
/*  */
/* ======================== */

/* PROMO BANNER MENU DESPLEGABLE */
/* ======================== */
/*  */
/* ======================== */

/* ——— Megamenú: respiración general ——— */
.mod-header__panel { padding: 18px 20px; }
.mod-header__panel .row.container { display: flex; flex-wrap: nowrap; align-items: flex-start; gap: 28px; }
#escritorio .mod-header__panel .row.container { align-items: flex-start; }
.mod-header__panel .mod-header__column { float: none; width: auto; flex: 1 1 0; min-width: 0; }
.mod-header__panel .mod-header__promo--aniversario { flex: 0 0 auto; }
.mod-header__panel .mod-header__column h3 { margin: 0 0 10px; color: var(--white); font-size: 12px; font-weight: 100; text-align: left; }
.mod-header__item { margin: 10px 0 14px; }
.mod-header__item .mod-header__link { display:block; font-weight:700; color:#fff; float:none; margin-bottom: 2px; }
.mod-header__item .mod-header__link:hover { color: var(--cyber-sky); }
.mod-header__item .mod-header__desc { display:block; font-size: .72rem; line-height: 1.4; color: rgba(255,255,255,.75); margin-top: 4px; float:none; }

/* ——— Banner promo minimal (megamenu) ——— */
.mod-header__promo--aniversario { display: flex; flex-direction: column; width: 100%; max-width: 380px; margin-left: auto; padding: 16px 18px; border: 1px solid rgba(255,255,255,.14); border-radius: 14px; background: rgba(255,255,255,.02); box-shadow: none; }
.mod-header__promo--aniversario .mod-header__promo-text { color: var(--white); }
.mod-header__promo--aniversario .mod-header__promo-eyebrow { margin: 0 0 6px; color: rgba(255,255,255,.65); text-transform: uppercase; letter-spacing: .06em; }
.mod-header__promo--aniversario .mod-header__promo-text h4 { margin: 0 0 8px; color: var(--white); font-size: 1.55rem; line-height: 1.2; font-weight: 600; }
.mod-header__promo--aniversario .mod-header__promo-text .t-body { margin: 0 0 12px; color: rgba(255,255,255,.88); }
.mod-header__promo--aniversario .mod-header__promo-coupon { display: inline-flex; align-items: center; justify-content: center; width: fit-content; min-height: 38px; padding: 0 14px; border: 1px solid rgba(0,203,255,.45); border-radius: 999px; background: transparent; color: var(--cyber-sky); font-size: .98rem; font-weight: 700; letter-spacing: .03em; cursor: pointer; transition: border-color .2s ease, color .2s ease, background-color .2s ease; }
.mod-header__promo--aniversario .mod-header__promo-coupon:hover { border-color: var(--white); color: var(--white); background: rgba(255,255,255,.08); }
.mod-header__promo--aniversario .mod-header__promo-coupon:focus-visible { outline: 2px solid rgba(0,203,255,.5); outline-offset: 2px; }
.mod-header__promo--aniversario .mod-header__promo-coupon.is-copied { border-color: var(--cyber-lima); color: var(--cyber-lima); background: rgba(184,255,0,.08); }
.mod-header__promo--aniversario .mod-header__promo-feedback { display: block; min-height: 1.1em; margin-top: 6px; font-size: .72rem; color: var(--cyber-sky); }
.mod-header__promo--aniversario .mod-header__promo-note { margin-top: 4px; color: rgba(255,255,255,.7); }

/* ======================== */
/*  */
/* ======================== */

/* BLOQUES GENERALES */
/* ======================== */
/*  */
/* ======================== */

/* ======================== */
/*  */
/* ======================== */

/* BOTÓN HAMBURGUESA */
/* ======================== */
/*  */
/* ======================== */

.mod-header__hamburger { position: absolute; top: 50%; right: 16px; width: 30px; height: 30px; display: flex; flex-direction: column; justify-content: center; align-items: center; gap: 6px; cursor: pointer; z-index: 10000; transform: translateY(-50%); }
.mod-header__hamburger span { position: absolute; width: 24px; height: 3px; background-color: var(--cyber-sky); border-radius: 2px; transition: transform 0.3s ease, opacity 0.3s ease; }
.mod-header__hamburger span:first-child { transform: translateY(-6px); }
.mod-header__hamburger span:last-child { transform: translateY(6px); }
.mod-header__hamburger.active span:first-child { transform: rotate(45deg); }
.mod-header__hamburger.active span:last-child { transform: rotate(-45deg); }

/* Alternativa si se usan <div> en lugar de <span> */
.mod-header__hamburger div { background-color: var(--cyber-blue); height: 3px; width: 100%; border-radius: 3px; transition: transform .3s ease, opacity .3s ease; }
.mod-header__hamburger div:nth-child(2) { position: absolute; top: 20px; }
.mod-header__hamburger.active div:nth-child(1) { transform: rotate(45deg) translate(5px, 5px); }
.mod-header__hamburger.active div:nth-child(2) { transform: rotate(-45deg) translate(5px, -5px); }

/* ======================== */
/*  */
/* ======================== */

/* MENU MÓVIL: OVERLAY */
/* ======================== */
/*  */
/* ======================== */

@supports (-webkit-touch-callout: none) { .mod-header__overlay { height: 100%; min-height: -webkit-fill-available; } }

/* Flechita solo en los enlaces principales del megamenú */
.mod-header__item { padding-bottom: 20px; }
.mod-header__panel .mod-header__item .mod-header__link { position: relative; display: inline-flex; align-items: center; gap: 6px; padding-right: 0; font-weight: 600; color: var(--cyber-sky); transition: color .25s ease; float:none; }
.mod-header__panel .mod-header__item .mod-header__link::after { content: "›"; position: static; transform: none; font-size: 1rem; color: var(--cyber-sky); transition: transform .25s ease, color .25s ease, opacity .25s ease; }
.mod-header__panel .mod-header__item .mod-header__link:hover { color: var(--white); }
.mod-header__panel .mod-header__item .mod-header__link:hover::after,
.mod-header__panel .mod-header__item .mod-header__link:focus-visible::after { transform: translateX(3px); color: var(--cyber-sky); }

/* Descripción pequeña y legible debajo (no clicable) */
.mod-header__panel .mod-header__item .mod-header__desc { display:block; font-size: .74rem; line-height: 1.35; margin-top: 2px; color: rgba(255,255,255,.85); pointer-events: none; float:none; }

/* BOTÓN VOLVER SUBMENÚ    */

/* ======================== */
/*  */
/* ======================== */

/* ANIMACIÓN FADE IN UP */
/* ======================== */
/*  */
/* ======================== */

@keyframes fadeInUp { from {opacity: 0; transform: translateY(20px); }
to { opacity: 1; transform: translateY(0); }
}
/* Mostrar solo en ESCRITORIO */

/* ======================== */
/*  */
/* ======================== */

/* MENÚ MÓVIL - VISIBILIDAD */
/* ======================== */
/*  */
/* ======================== */

#movil,
.mod-header__mobile { display: none; }
.scroll-up .mod-header__toolbar { transform: translateY(-100%); }

#escritorio .mod-header__logo { width: 200px; height: auto; display:block; }
#escritorio > .container > .row { align-items:center; }
#escritorio > .container > .row > .col-3 { display:flex; align-items:center; flex:0 0 auto; width:auto; margin-right:14px; }
#escritorio > .container > .row > .mod-header__nav { display:flex; align-items:center; justify-content:flex-start; gap:0; flex:1 1 auto; }
#escritorio > .container > .row > .mod-header__nav .mod-header__group { margin-right:0; }
#escritorio > .container > .row > .mod-header__nav .mod-header__group .mod-header__trigger { padding:12px 10px; }

/* ======================== */
/*  */
/* ======================== */

/* MENÚ MÓVIL - SOLO EN MÓVIL */
/* ======================== */
/*  */
/* ======================== */

@media (max-width: 1024px) { #escritorio {display: none !important; }
#movil, .mod-header__mobile { display: block !important; }
.mod-header { background-color: var(--cyber-darkblue); color: var(--text-color-dark); padding: 10px 0; box-shadow: 0 2px 4px var(--shadow-light); height: 60px; position: fixed; top: 0; left: 0; width: 100%; z-index: 9998; }
#movil { position: relative; display: flex !important; align-items: center; height: 100%; }
#movil .mod-header__logo { margin: 0; width: 160px !important; max-width: 55vw !important; height: auto; }
}

/* ======================== */
/*  */
/* ======================== */

/* CONTENEDOR GENERAL DEL MENÚ MÓVIL */
/* ======================== */
/*  */
/* ======================== */

#menu-movil { z-index: 9999; }

/* ======================== */
/*  */
/* ======================== */

/* OVERLAY OSCURO DE FONDO */
/* ======================== */
/*  */
/* ======================== */

.mod-header__overlay { position: fixed; inset: 0; background-color: var(--cyber-darkblue); display: none; flex-direction: column; justify-content: flex-start; opacity: 0; transform: translateY(-20px); transition: opacity 0.4s ease, transform 0.4s ease; }
.mod-header__overlay.active { display: flex; opacity: 1; transform: translateY(0); }

/* ======================== */
/*  */
/* ======================== */

/* MENÚ PRINCIPAL MÓVIL */
/* ======================== */
/*  */
/* ======================== */

.mod-header__menu,
.mod-header__submenu { display: flex; flex-direction: column; gap: 25px; padding: 40px; transition: transform 0.3s ease; transform: translateX(0); }
.mod-header__menu.hidden { display: none; }
.mod-header__menu ul,
.mod-header__submenu ul { margin: 0; padding: 0; list-style: none; }
.mod-header__menu ul li,
.mod-header__submenu ul li { display: block; font-size: 22px; margin: 15px 0; opacity: 0; transform: translateY(20px); animation: fadeInUp 0.3s forwards; }
.mod-header__menu-link,
.mod-header__menu-link--back { font-size: 22px; color: var(--white); font-weight: 700; text-transform: uppercase; text-decoration: none; display: inline-flex; align-items: center; line-height: 1.15; padding: 0; margin: 0; border: 0; background: none; }
.mod-header__menu-link { gap: 0.35em; transition: color 0.3s ease; align-items: center; cursor: pointer; }
.mod-header__menu-link::after { content: '›'; position: relative; top: -1px; font-size: 1em; font-weight: 700; line-height: 1; color: var(--cyber-sky); display: inline-flex; align-items: center; justify-content: center; width: 1em; height: 1em; }
.mod-header__menu-link--back { color: var(--cyber-sky); text-transform: none; line-height: 1; position: absolute; top: -34px; left: 0; z-index: 1; font-size: 44px; width: 44px; height: 44px; justify-content: flex-start; cursor: pointer; }
.mod-header__menu-link--back::after { content: none; }
.mod-header__menu-link:hover { color: var(--cyber-sky); }
.mod-header__menu.active ul li,
.mod-header__submenu.active ul li { opacity: 0; transform: translateY(5px); animation: fadeSlideDown 0.4s ease forwards; }
.mod-header__menu.active ul li:nth-child(1),
.mod-header__submenu.active ul li:nth-child(1) { animation-delay: 0.05s; }
.mod-header__menu.active ul li:nth-child(2),
.mod-header__submenu.active ul li:nth-child(2) { animation-delay: 0.1s; }
.mod-header__menu.active ul li:nth-child(3),
.mod-header__submenu.active ul li:nth-child(3) { animation-delay: 0.15s; }
.mod-header__menu.active ul li:nth-child(4),
.mod-header__submenu.active ul li:nth-child(4) { animation-delay: 0.2s; }
.mod-header__menu.active ul li:nth-child(5),
.mod-header__submenu.active ul li:nth-child(5) { animation-delay: 0.25s; }
.mod-header__menu.active ul li:nth-child(6),
.mod-header__submenu.active ul li:nth-child(6) { animation-delay: 0.3s; }

/* ======================== */
/*  */
/* ======================== */

/* ANIMACIÓN ENTRADA MENÚ */
/* ======================== */
/*  */
/* ======================== */

@keyframes fadeSlideDown { from {opacity: 0; transform: translateY(5px); }
to { opacity: 1; transform: translateY(0); }
}

/* ======================== */
/*  */
/* ======================== */

/* SUBMENÚ DESLIZANTE */
/* ======================== */
/*  */
/* ======================== */

/* ======================== */
/*  */
/* ======================== */

/* ======================== */
/* FOOTER */
/* ======================== */
.footer { background-color:var(--cyber-darkblue); color:var(--white); padding:2rem 0; text-align:left; position:relative; border-radius:40px 40px 0 0; overflow:hidden; }
.footer--main { }
.footer__top { width: 100%; display: grid; grid-template-columns: repeat(5, minmax(0, 1fr)); gap: 26px; }
.footer__title { color:var(--white); font-weight:700; font-size:14px; margin-bottom:10px; }
.footer__link { font-size:12px; color:var(--cyber-sky); text-decoration:none; transition:color 0.3s ease; }
.footer__link:hover { color:var(--white); }

.footer__center { display:flex; flex-direction:column; align-items:center; justify-content:center; gap:20px; margin-top:20px; }
.footer__logos { display:flex; justify-content:center; align-items:center; width:100%; }
.footer__logos img { max-width:100%; height:auto; }
.footer__logo--mobile { display:block; }
.footer__logo--desktop { display:none; }

.footer__socials { text-align:center; margin:0; }
.footer__social-list { display:inline-flex; gap:10px; padding:0; margin:10px auto 0; list-style:none; justify-content:center; align-items:center; }
.footer__social-item { display:inline-block; }
.footer__social-link { display:inline-flex; }
.footer__social-icon { padding:5px; float:left; width:40px; height:40px; transition:transform 0.3s ease; }
.footer__social-icon:hover { transform:scale(1.1); }

.footer__legal-row { width: 100%; }
.footer__legal-links { text-align:center; font-size:12px; margin:20px 0; padding-top:20px; border-top:1px solid rgba(255,255,255,0.2); }
.footer__legal-link { color:var(--white); margin:0 8px; transition:color 0.3s ease; }
.footer__legal-link:hover { color:var(--cyber-sky); }

.footer__copyright-row { text-align:center; font-size:12px; color:rgba(255,255,255,.5); }
.footer__copyright-row p { color:rgba(255,255,255,.5); margin:0 0 6px; line-height:1.45; font-size:12px; }
.footer__copyright-row p:last-child { margin-bottom:0; }

.footer__col { min-width: 0; }
.footer__list { margin:0; padding:0; list-style:none; }
.footer__item { margin-bottom:1rem; display:block; }
.footer__item .footer__link { display:block; }

@media (min-width:1025px) { .footer__logo--mobile { display:none; }
 .footer__logo--desktop { display:block; }
 }

@media (max-width:1024px) { .footer__copyright { padding:0 15px; }
 .footer__top { grid-template-columns:repeat(2, minmax(0, 1fr)); gap:20px 16px; }
 .footer__col { text-align:center; }
 .footer__item .footer__link { text-align:center; }
 }

@media (max-width:1024px) { .footer__link { font-size:14px; }
 .footer__legal-links { font-size:12px; }
 }

@media (max-width:560px) {
 .footer__top { grid-template-columns:1fr; }
}

/* Textos LEGALES */
/* ======================== */
/*  */
/* ======================== */

/* ======================== */
/* HEADER BEM (PARALELO) */
/* ======================== */
@media (min-width: 1025px) { .mod-header { background-color:var(--cyber-blue); position:relative; height:60px; }
}

/* Mapeo visual a legacy (sin cambiar comportamiento) */
.mod-header__toolbar { background-color:#0400BE; color:var(--white); font-size:12px; font-weight:400; line-height:1.35; transition:transform 0.5s ease-out; position:sticky; top:0; z-index:100; }
.mod-header__toolbar .container { display:flex; justify-content:space-between; align-items:center; min-height:30px; padding-left:23px; padding-right:23px; }
.mod-header__phone img, .mod-header__ticket img { width:16px; height:16px; }
.mod-header__nav { overflow:hidden; }
.mod-header__trigger { display:flex; align-items:center; gap:8px; background:none; border:none; color:var(--cyber-blue); font-weight:600; cursor:pointer; font-size:14px; padding:10px 20px; }
.mod-header__panel { display:none; position:absolute; background:var(--cyber-dark); width:100%; left:0; z-index:10; padding:10px 0 40px; opacity:0; transform:translateY(-10px); transition:opacity .3s ease, transform .3s ease; }
.mod-header__group:hover .mod-header__panel { display:block; opacity:1; transform:translateY(0); }
.mod-header__link { position:relative; display:inline-flex; align-items:center; gap:6px; padding-right:0; font-weight:600; color:var(--cyber-sky); transition:color .25s ease; }
.mod-header__link::after { content:"›"; position:static; transform:none; font-size:1rem; color:var(--cyber-sky); transition:transform .25s ease, color .25s ease, opacity .25s ease; }
.mod-header__link:hover { color:var(--white); }
.mod-header__link:hover::after, .mod-header__link:focus-visible::after { transform:translateX(3px); color:var(--cyber-sky); }
.mod-header__desc { display:block; font-size:.74rem; line-height:1.35; margin-top:2px; color:rgba(255,255,255,.85); pointer-events:none; }
.mod-header__dropdown { position:relative; display:inline-block; }
.mod-header__dropdown-btn { color:var(--cyber-blue); padding:5px 15px; border:2px solid var(--cyber-blue); border-radius:100px; cursor:pointer; font-size:14px; transition:background-color .3s ease; background-color:var(--white); }
.mod-header__dropdown-btn:hover { border:2px solid var(--cyber-blue); background-color:var(--cyber-blue); color:var(--cyber-sky); }
.mod-header__dropdown-content { display:none; position:absolute; background-color:var(--text-color-dark); box-shadow:0 4px 6px var(--shadow-light); padding:10px; border-radius:10px; z-index:10; opacity:0; transform:translateY(-10px); transition:opacity .3s ease, transform .3s ease; width:100%; }
.mod-header__dropdown:hover .mod-header__dropdown-content { display:block; opacity:1; transform:translateY(0); }
.mod-header__dropdown-content a { color:var(--cyber-sky); padding:5px 10px; text-decoration:none; display:block; font-size:14px; }
.mod-header__dropdown-content a:hover { background-color:var(--cyber-sky); color:var(--white); border-radius:3px; }

@media (max-width:1024px) { .mod-header__desktop { display:none !important; }
 .mod-header__mobile { display:block !important; }
 .mod-header__toolbar { display:none; }
 }

/* ======================== */
/* Button system (standardized) */
/* ======================== */

.btn { --btn-bg: var(--cyber-blue); --btn-fg: var(--white); --btn-border: var(--cyber-blue); --btn-bg-hover: var(--cyber-blue); --btn-fg-hover: var(--cyber-sky); --btn-border-hover: var(--cyber-blue); --btn-bg-active: var(--cyber-sky); --btn-fg-active: var(--cyber-darkblue); --btn-border-active: var(--cyber-sky); display: inline-block; border: 3px solid var(--btn-border); background: var(--btn-bg); color: var(--btn-fg); text-decoration: none; cursor: pointer; transition: all 0.3s ease-in-out; box-sizing: border-box; font-size: 16px; font-weight: 700; padding: 12px 24px; border-radius: 100px; text-transform: uppercase; text-align: center; }

.btn:hover { background: var(--btn-bg-hover); color: var(--btn-fg-hover); border-color: var(--btn-border-hover); }
.btn:active { background: var(--btn-bg-active); color: var(--btn-fg-active); border-color: var(--btn-border-active); }

/* Solid */
.btn-primary { --btn-bg: var(--cyber-blue); --btn-fg: var(--white); --btn-border: var(--cyber-blue); --btn-bg-hover: var(--cyber-blue); --btn-fg-hover: var(--cyber-sky); --btn-border-hover: var(--cyber-blue); --btn-bg-active: var(--cyber-sky); --btn-fg-active: var(--cyber-darkblue); --btn-border-active: var(--cyber-sky); }

/* Outline (light backgrounds) */
.btn-outline { --btn-bg: transparent; --btn-fg: var(--cyber-blue); --btn-border: var(--cyber-blue); --btn-bg-hover: transparent; --btn-fg-hover: var(--cyber-sky); --btn-border-hover: var(--cyber-sky); --btn-bg-active: var(--cyber-sky); --btn-fg-active: var(--white); --btn-border-active: var(--cyber-sky); }

/* Invert (dark backgrounds) */
.btn-invert { --btn-bg: transparent; --btn-fg: var(--cyber-sky); --btn-border: var(--cyber-sky); --btn-bg-hover: transparent; --btn-fg-hover: var(--white); --btn-border-hover: var(--white); --btn-bg-active: var(--white); --btn-fg-active: var(--cyber-blue); --btn-border-active: var(--white); }

/* Light (dark backgrounds) */
.btn-light { --btn-bg: transparent; --btn-fg: var(--white); --btn-border: var(--white); --btn-bg-hover: transparent; --btn-fg-hover: var(--cyber-sky); --btn-border-hover: var(--cyber-sky); --btn-bg-active: var(--white); --btn-fg-active: var(--cyber-blue); --btn-border-active: var(--white); }

/* Size/utility tweaks */
.btn-search { font-size: 18px; padding: 5px 20px; text-transform: none; }
.btn-register { margin-top:auto; text-align:center; }

/* ======================== */
/*  */
/* ======================== */

/* ESTRUCTURA Y GRID */
/* ======================== */
/*  */
/* ======================== */

.container { max-width: 1250px; margin: 0 auto; padding: 0 15px; }
.fullwidth { width: 100%; margin: 0 auto; box-sizing: border-box; }
.slider { background: linear-gradient(135deg, var(--cyber-grey), var(--cyber-grey)); }
.row { display: flex; flex-wrap: wrap; }
.row>div { padding: .5rem; }
.col-12 { flex: 0 0 100%; max-width: 100%; }
.col-6 { flex: 0 0 50%; max-width: 50%; }
.col-4 { flex: 0 0 33.33%; max-width: 33.33%; }
.col-3 { flex: 0 0 25%; max-width: 25%; }
.col-2 { flex: 0 0 16.6667%; max-width: 16.6667%; }

/* ======================== */
/*  */
/* ======================== */

/* GRID UTILITIES */
/* ======================== */
/*  */
/* ======================== */

.card { --card-bg: #fff; --card-radius: 22px; --card-pad: 24px; --card-shadow: 0 10px 24px rgba(8,8,38,.08); --card-transition: transform .25s ease, box-shadow .25s ease; --card-text-align: inherit; --card-display: block; --card-align: stretch; --card-justify: flex-start; background: var(--card-bg); border-radius: var(--card-radius); padding: var(--card-pad); box-shadow: var(--card-shadow); transition: var(--card-transition); text-align: var(--card-text-align); display: var(--card-display); align-items: var(--card-align); justify-content: var(--card-justify); box-sizing: border-box; }
.card:hover { transform: translateY(-4px); box-shadow: 0 14px 28px rgba(8,8,38,.12); }

.grid,
.mod-cms-logos__grid,
.mod-directadmin__grid,
.mod-advantages__grid,
.mod-protection__grid,
.mod-tools__grid,
.mod-domain-benefits__grid,
.mod-domain-grid__grid,
.mod-about-overview__grid { display:grid; gap: var(--grid-gap, 1.5rem); grid-template-columns: var(--grid-template, repeat(var(--grid-cols, 1), minmax(0, 1fr))); }

.grid-2 { --grid-cols: 2; --grid-cols-md: 1; --grid-cols-sm: 1; }
.grid-3 { --grid-cols: 3; --grid-cols-md: 2; --grid-cols-sm: 1; }
.grid-4 { --grid-cols: 4; --grid-cols-md: 2; --grid-cols-sm: 1; }

.grid > * { padding: .5rem; }
.grid > [class*="col-"] { max-width: none; width: auto; flex: none; }

@media (max-width: 1024px) { .grid,
  .mod-cms-logos__grid,
  .mod-directadmin__grid,
  .mod-advantages__grid,
  .mod-protection__grid,
  .mod-tools__grid,
  .mod-domain-benefits__grid,
  .mod-domain-grid__grid,
  .mod-about-overview__grid { grid-template-columns: var(--grid-template-md, repeat(var(--grid-cols-md, var(--grid-cols, 1)), minmax(0, 1fr))); }
 }

@media (max-width: 640px) { .grid,
  .mod-cms-logos__grid,
  .mod-directadmin__grid,
  .mod-advantages__grid,
  .mod-protection__grid,
  .mod-tools__grid,
  .mod-domain-benefits__grid,
  .mod-domain-grid__grid,
  .mod-about-overview__grid { grid-template-columns: var(--grid-template-sm, repeat(var(--grid-cols-sm, 1), minmax(0, 1fr))); }
 }

/* Hace que todos los textos dentro salgan blancos */
.text-white,
.text-white p,
.text-white h1,
.text-white h2,
.text-white h3,
.text-white h4,
.text-white h5,
.text-white h6,
.text-white li,
.text-white span { color: var(--white) !important; }

/* RESPONSIVE COLUMNAS      */
@media (max-width: 1024px) { .col-4 {flex: 0 0 100%; max-width: 100%; }
.col-3 { flex: 0 0 50%; max-width: 50%; }
.col-2 { flex: 0 0 100%; max-width: 100%; }
}
/* Margin eje Y (arriba + abajo) */
.my-1 { margin-top: 0.5rem !important; margin-bottom: 0.5rem !important; }
.my-2 { margin-top: 1rem   !important; margin-bottom: 1rem   !important; }
.my-3 { margin-top: 1.5rem !important; margin-bottom: 1.5rem !important; }
.space-100 { padding: 100px 0 0 0; }
.space-40 { padding: 40px 0; }
.center { text-align: center; }

/* ======================== */
/*  */
/* ======================== */

/* SPACING UTILITIES */
/* ======================== */
/*  */
/* ======================== */

:root { --space-xs: 0.5rem; --space-sm: 1rem; --space-md: 1.5rem; --space-lg: 2.5rem; --space-xl: 6.25rem; }

.space-xs { padding: var(--space-xs) 0; }
.space-sm { padding: var(--space-sm) 0; }
.space-md { padding: var(--space-md) 0; }
.space-lg { padding: var(--space-lg) 0; }
.space-xl { padding: var(--space-xl) 0; }

.my-xs { margin-top: var(--space-xs) !important; margin-bottom: var(--space-xs) !important; }
.my-sm { margin-top: var(--space-sm) !important; margin-bottom: var(--space-sm) !important; }
.my-md { margin-top: var(--space-md) !important; margin-bottom: var(--space-md) !important; }
.my-lg { margin-top: var(--space-lg) !important; margin-bottom: var(--space-lg) !important; }
.my-xl { margin-top: var(--space-xl) !important; margin-bottom: var(--space-xl) !important; }

/* Compatibilidad: mapeo de utilidades antiguas */
.space-40 { padding: var(--space-lg) 0; }
.space-100 { padding: var(--space-xl) 0 0 0; }
.my-1 { margin-top: var(--space-xs) !important; margin-bottom: var(--space-xs) !important; }
.my-2 { margin-top: var(--space-sm) !important; margin-bottom: var(--space-sm) !important; }
.my-3 { margin-top: var(--space-md) !important; margin-bottom: var(--space-md) !important; }

/* Centrado global de un bloque */
.content-center { text-align:center; display:flex; flex-direction:column; align-items:center; justify-content:center; }

/* Asegura que las imágenes y títulos dentro se centren también */
.content-center img { display:block; margin:0 auto; }
.content-center h2,
.content-center h3,
.content-center p { margin-left:auto; margin-right:auto; }

.two-col-centered .row { display:flex; flex-wrap:wrap; justify-content:center; gap:1.5rem; text-align:center; }
.two-col-centered .col-6 { flex:0 0 48%; max-width:48%; display:flex; flex-direction:column; align-items:center; }
.two-col-centered .col-6 img { max-width:40%; margin-bottom:1rem; }
.two-col-centered .col-6 h2 { margin-bottom:.5rem; color:var(--cyber-blue); }
.two-col-centered .col-6 p { max-width:400px; color:var(--text-color-grey); line-height:1.6; }
.two-col-centered .grid { gap:1.5rem; text-align:center; }
.two-col-centered .grid .col-6 { max-width:100%; flex:none; }
@media(max-width:768px) { .two-col-centered .col-6 {flex:0 0 100%; max-width:100%; }}

/* ======================== */
/*  */
/* ======================== */

.block { padding: 40px; background-color: var(--cyber-blue); }

.mod-header__submenu { position: absolute; top: 0; left: 100%; width: 100%; height: 100%; align-items: flex-start; background-color: var(--cyber-darkblue); opacity: 0; transform: translateX(10px); transition: opacity 0.4s ease, transform 0.4s ease; z-index: 9999; }
.mod-header__submenu.active { left: 0; opacity: 1; transform: translateX(0); }
.mod-header__submenu.exiting { left: 100%; }
.mod-header__submenu ul { position: relative; }
.mod-header__submenu ul li:first-child { margin: 0; height: 0; }
.mod-header__menu-link--back:active { transform: scale(0.96); }

/* ======================== */
/*  */
/* ======================== */

/* BLOQUEAR SCROLL (CUANDO ACTIVO) */
/* ======================== */
/*  */
/* ======================== */

body.no-scroll { overflow: hidden; height: 100vh; }
