

:root{
  --c1: rgb(0,61,165);
  --c2: rgb(24,35,137);

  --bg: #ffffff;
  --panel: rgba(255,255,255,.78);
  --panel2: rgba(245,247,255,.9);
  --text: #0b1020;
  --muted: rgba(11,16,32,.68);
  --border: rgba(11,16,32,.12);

  --shadow: 0 18px 60px rgba(0,0,0,.12);
  --shadow2: 0 12px 40px rgba(0,0,0,.16);

  --glow: rgba(0, 136, 255, .25);
  --glow2: rgba(64, 140, 255, .30);

  --radius: 18px;
  --radius2: 22px;

  --container: 1160px;
  --gutter: 20px; /* ✅ para padding lateral consistente */
  --header-h: 74px;

  --section-pad: 88px;
  --section-pad-lg: 110px;

  --ease: cubic-bezier(.2,.8,.2,1);

  /* Z (overlay/menú sobre header) */
  --z-header: 120;
  --z-overlay: 220;
  --z-menu: 230;
}

html[data-theme="dark"]{
  --bg: #060812;
  --panel: rgba(10,14,28,.68);
  --panel2: rgba(12,18,36,.78);
  --text: rgba(255,255,255,.92);
  --muted: rgba(255,255,255,.68);
  --border: rgba(255,255,255,.12);

  --shadow: 0 24px 80px rgba(0,0,0,.55);
  --shadow2: 0 18px 60px rgba(0,0,0,.55);

  --glow: rgba(0, 136, 255, .35);
  --glow2: rgba(100, 170, 255, .32);
}

/* =========================
   Reset / Base
========================= */
*,
*::before,
*::after{ box-sizing:border-box; }

html{ height:100%; -webkit-text-size-adjust: 100%; }
body{
  height:100%;
  margin:0;
  font-family: ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Arial, "Noto Sans", "Helvetica Neue", sans-serif;
  background: var(--bg);
  color: var(--text);
  overflow-x:hidden;
}

a{ color: inherit; text-decoration:none; }
img, svg, video{ max-width:100%; height:auto; display:block; }

.no-js .mobile-menu{ display:none; }

.container{
  width: min(var(--container), calc(100% - (var(--gutter) * 2)));
  margin-inline:auto;
}

/* =========================
   Header
========================= */
.site-header{
  position: sticky;
  top: 0;
  z-index: var(--z-header);
  height: var(--header-h);
  background: linear-gradient(180deg, rgba(0,0,0,.32), rgba(0,0,0,0));
  backdrop-filter: blur(16px);
  border-bottom: 1px solid rgba(255,255,255,.08);
  isolation: isolate;
}

html[data-theme="light"] .site-header{
  background: linear-gradient(180deg, rgba(255,255,255,.82), rgba(255,255,255,.55));
  border-bottom: 1px solid rgba(11,16,32,.08);
}

.header__inner{
  height:100%;
  display:flex;
  align-items:center;
  gap:14px;
  min-width: 0;
}

.brand{
  display:flex;
  align-items:center;
  min-width: 160px;
  flex: 0 0 auto;
}

/* NO tocamos logo */
.brand__logo{
  height:32px;
  width:auto;
  display:block;
  object-fit:contain;
}

.nav{
  display:flex;
  align-items:center;
  gap:10px;
  margin-left:auto;
  margin-right: 10px;
  min-width: 0;
}

.nav__link{
  padding: 10px 12px;
  border-radius: 999px;
  font-weight: 600;
  font-size: 14px;
  color: var(--muted);
  transition: transform .18s var(--ease), background .18s var(--ease), color .18s var(--ease);
  white-space: nowrap;
}

.nav__link:hover{
  background: rgba(255,255,255,.06);
  color: var(--text);
  transform: translateY(-1px);
}
html[data-theme="light"] .nav__link:hover{ background: rgba(11,16,32,.06); }

.nav__link.is-active,
.nav__link.active,
.nav__link[aria-current="page"]{
  color: var(--text);
  background: rgba(255,255,255,.08);
  box-shadow: 0 0 0 1px rgba(255,255,255,.10) inset;
}
html[data-theme="light"] .nav__link.is-active,
html[data-theme="light"] .nav__link.active,
html[data-theme="light"] .nav__link[aria-current="page"]{
  background: rgba(11,16,32,.06);
  box-shadow: 0 0 0 1px rgba(11,16,32,.08) inset;
}

.header__actions{
  display:flex;
  align-items:center;
  gap:10px;
  flex: 0 0 auto;
}

/* =========================
   Idiomas
========================= */
.lang{ position:relative; min-width: 0; }

.lang__btn{
  display:flex;
  align-items:center;
  gap:8px;
  border:1px solid rgba(255,255,255,.14);
  background: rgba(255,255,255,.06);
  color: var(--text);
  border-radius: 999px;
  padding: 10px 12px;
  font-weight: 700;
  cursor:pointer;
  transition: transform .18s var(--ease), background .18s var(--ease);
}

html[data-theme="light"] .lang__btn{
  border:1px solid rgba(11,16,32,.12);
  background: rgba(11,16,32,.04);
}

.lang__btn:hover{ transform: translateY(-1px); }

.lang__tag{
  font-size: 13px;
  letter-spacing:.02em;
  white-space: nowrap;
}

.lang__list{
  position:absolute;
  top: calc(100% + 10px);
  left:0;
  width: 220px;
  padding: 8px;
  margin:0;
  list-style:none;
  border-radius: 14px;
  border:1px solid var(--border);
  background: var(--panel2);
  box-shadow: var(--shadow2);
  backdrop-filter: blur(12px);
  display:none;
  z-index: 20;
}

.lang__list li{
  padding:10px 10px;
  border-radius: 12px;
  cursor:pointer;
  color: var(--muted);
  font-weight: 650;
}

.lang__list li:hover{
  background: rgba(255,255,255,.08);
  color: var(--text);
}
html[data-theme="light"] .lang__list li:hover{ background: rgba(11,16,32,.06); }

.lang.is-open .lang__list{ display:block; }

/* =========================
   Botones
========================= */
.btn{
  display:inline-flex;
  align-items:center;
  gap:10px;
  padding: 11px 14px;
  border-radius: 14px;
  border: 1px solid transparent;
  font-weight: 800;
  font-size: 14px;
  cursor:pointer;
  transition: transform .18s var(--ease), box-shadow .18s var(--ease), background .18s var(--ease);
}

.btn--pill{ border-radius: 999px; }
.btn--block{ width:100%; justify-content:center; }

.btn--primary{
  background: linear-gradient(135deg, var(--c1), var(--c2));
  color: white;
  box-shadow: 0 18px 60px rgba(0,61,165,.35);
}
.btn--primary:hover{
  transform: translateY(-1px);
  box-shadow: 0 22px 80px rgba(0,61,165,.42);
}
/* Collab CTA parity (look + size) */
.btn--collab{
  padding: 10px 14px;
  font-size: 13px;
}

.btn--collab.btn--primary{
  background: linear-gradient(90deg, var(--primary), var(--primary-2));
  box-shadow: 0 16px 34px rgba(31,94,255,0.24);
}

html[data-theme="light"] .btn--collab.btn--primary{
  box-shadow: 0 16px 34px rgba(31,94,255,0.22);
}

.btn--collab.btn--primary:hover{
  box-shadow: 0 20px 42px rgba(31,94,255,0.28);
}


.btn--ghost{
  background: rgba(255,255,255,.06);
  color: var(--text);
  border-color: rgba(255,255,255,.14);
}
html[data-theme="light"] .btn--ghost{
  background: rgba(11,16,32,.04);
  border-color: rgba(11,16,32,.12);
}
.btn--ghost:hover{ transform: translateY(-1px); }

/* Theme button */
.theme-toggle{
  width: 42px;
  height: 42px;
  border-radius: 999px;
  border: 1px solid rgba(255,255,255,.14);
  background: rgba(255,255,255,.06);
  color: var(--text);
  display:grid;
  place-items:center;
  cursor:pointer;
  transition: transform .18s var(--ease), background .18s var(--ease);
  flex: 0 0 auto;
}

/* Language selector */
.language-selector{ position:relative; }
.language-btn{
  display:flex;
  align-items:center;
  gap: 8px;
  padding: 10px 12px;
  border-radius: 999px;
  background: color-mix(in srgb, var(--bg) 86%, var(--primary) 14%);
  border: 1px solid color-mix(in srgb, var(--primary) 16%, var(--border));
  color: var(--text);
  cursor:pointer;
  transition: transform var(--t-fast), box-shadow var(--t-fast), background var(--t-fast);
}
body:not(.theme-dark) .language-btn{
  box-shadow: 0 12px 26px rgba(19,33,68,0.10);
}
.language-btn:hover{ transform: translateY(-1px); }
.language-btn i{ font-size: 12px; transition: transform var(--t-fast); }
.language-btn[aria-expanded="true"] i{ transform: rotate(180deg); }

.language-flag{
  width: 18px;
  height: 18px;
  border-radius: 6px;
  background: linear-gradient(135deg, rgba(31,94,255,0.35), rgba(43,140,255,0.25));
  box-shadow: 0 10px 22px rgba(31,94,255,0.12);
}

.language-dropdown{
  position:absolute;
  right:0;
  top: calc(100% + 10px);
  list-style:none;
  background: var(--bg);
  border: 1px solid var(--border);
  border-radius: 16px;
  box-shadow: var(--shadow);
  min-width: 230px;
  padding: 8px;
  opacity:0;
  visibility:hidden;
  transform: translateY(-8px);
  transition: opacity var(--t-fast), transform var(--t-fast), visibility var(--t-fast);
  z-index: calc(var(--z-header) + 30);
}
body:not(.theme-dark) .language-dropdown{
  box-shadow: var(--shadow-lg);
}
.language-dropdown.show{
  opacity:1;
  visibility:visible;
  transform: translateY(0);
}
.language-option{
  width:100%;
  display:flex;
  align-items:center;
  gap: 10px;
  padding: 10px 10px;
  background: transparent;
  border:none;
  border-radius: 12px;
  cursor:pointer;
  color: var(--text);
  font-weight: 900;
  transition: background var(--t-fast);
}
.language-option:hover{
  background: color-mix(in srgb, var(--primary) 10%, transparent);
}
.lang-option-flag{
  width: 18px;
  height: 18px;
  border-radius: 6px;
  background: linear-gradient(135deg, rgba(31,94,255,0.35), rgba(43,140,255,0.25));
}

.lang-option-flag svg,
.language-flag svg { display: block; width: 18px; height: 18px; }

html[data-theme="light"] .theme-toggle{
  border-color: rgba(11,16,32,.12);
  background: rgba(11,16,32,.04);
}
.theme-toggle:hover{ transform: translateY(-1px); }

/* =========================
   Hamburger + Mobile Menu
========================= */
.menu-toggle{
  width: 44px;
  height: 44px;
  border-radius: 14px;
  border: 1px solid rgba(255,255,255,.14);
  background: rgba(255,255,255,.06);
  display:grid;
  place-items:center;
  cursor:pointer;
  transition: transform .18s var(--ease), background .18s var(--ease), border-color .18s var(--ease);
  box-shadow: 0 10px 26px rgba(0,0,0,.18);
  flex: 0 0 auto;
}

.menu-toggle:hover{ transform: translateY(-1px); }

html[data-theme="light"] .menu-toggle{
  border-color: rgba(11,16,32,.12);
  background: rgba(11,16,32,.04);
  box-shadow: 0 10px 26px rgba(0,0,0,.10);
}

.menu-toggle span{
  display:block;
  width:20px;
  height:2px;
  background: var(--text);
  border-radius:999px;
  margin: 1px 0 !important; /* compact */
  opacity:.95;
}

/* Overlay */
.overlay{
  position:fixed;
  inset:0;
  background: rgba(0,0,0,.55);
  opacity:0;
  pointer-events:none;
  transition: opacity .22s var(--ease);
  z-index: var(--z-overlay);
  backdrop-filter: blur(8px);
}
.overlay.show{ opacity:1; pointer-events:auto; }

/* Drawer */
.mobile-menu{
  position: fixed;
  top: 12px;
  right: 12px;
  bottom: 12px;
  width: min(390px, calc(100% - 24px));
  border-radius: 22px;
  border: 1px solid var(--border);
  background: linear-gradient(180deg, rgba(12,18,36,.92), rgba(10,14,28,.86));
  box-shadow: var(--shadow2);
  transform: translateY(-10px) scale(.985);
  opacity: 0;
  pointer-events: none;
  transition: transform .22s var(--ease), opacity .22s var(--ease);
  z-index: var(--z-menu);
  overflow:hidden;
  display:flex;
  flex-direction:column;
}

html[data-theme="light"] .mobile-menu{ background: var(--panel2); }

.mobile-menu.open{
  opacity:1;
  pointer-events:auto;
  transform: translateY(0) scale(1);
}

.mobile-menu__head{
  display:flex;
  justify-content:space-between;
  align-items:center;
  padding: 14px 14px 12px;
  border-bottom: 1px solid rgba(255,255,255,.10);
}
/* Logo dentro del menú móvil (paridad con referencia) */
.mobile-menu__head .logo{
  display: flex;
  align-items: center;
}

.mobile-menu__head .logo-img{
  width: 140px;
  height: auto;
  display: block;
  object-fit: contain;
  max-width: 180px;
  filter: drop-shadow(0 8px 18px rgba(19,33,68,0.10));
}

/* Ajuste mínimo en pantallas muy pequeñas */
@media (max-width: 420px){
  .mobile-menu__head .logo-img{ width: 120px; }
}
html[data-theme="light"] .mobile-menu__head{ border-bottom: 1px solid var(--border); }

.mobile-menu__title{
  font-weight: 950;
  letter-spacing: .01em;
}

.mobile-menu__close{
  width: 40px;
  height: 40px;
  border-radius: 14px;
  border: 1px solid rgba(255,255,255,.14);
  background: rgba(255,255,255,.06);
  color: var(--text);
  cursor:pointer;
  transition: transform .18s var(--ease), background .18s var(--ease);
}
.mobile-menu__close:hover{ transform: translateY(-1px); }
html[data-theme="light"] .mobile-menu__close{
  border-color: rgba(11,16,32,.12);
  background: rgba(11,16,32,.03);
}

/* Links */
.mobile-nav{
  display:grid;
  padding: 12px;
  gap: 10px;
  overflow:auto;
  -webkit-overflow-scrolling: touch;
}

.mobile-nav-link{
  padding: 14px 14px;
  border-radius: 16px;
  color: rgba(255,255,255,.78);
  font-weight: 900;
  background: rgba(255,255,255,.05);
  border: 1px solid rgba(255,255,255,.08);
  box-shadow: 0 10px 26px rgba(0,0,0,.18);
  transition: transform .18s var(--ease), background .18s var(--ease), color .18s var(--ease), box-shadow .18s var(--ease);
}

html[data-theme="light"] .mobile-nav-link{
  color: var(--muted);
  background: rgba(11,16,32,.03);
  border: 1px solid rgba(11,16,32,.06);
  box-shadow: 0 10px 26px rgba(0,0,0,.08);
}

.mobile-nav-link:hover{
  color: var(--text);
  transform: translateY(-1px);
}

.mobile-nav-link.is-active,
.mobile-nav-link.active,
.mobile-nav-link[aria-current="page"]{
  color: rgba(255,255,255,.96);
  background: linear-gradient(135deg, rgba(0,61,165,.42), rgba(24,35,137,.28));
  border-color: rgba(120,180,255,.24);
  box-shadow:
    0 0 0 1px rgba(120,180,255,.14) inset,
    0 18px 50px rgba(0,0,0,.22);
}
html[data-theme="light"] .mobile-nav-link.is-active,
html[data-theme="light"] .mobile-nav-link.active,
html[data-theme="light"] .mobile-nav-link[aria-current="page"]{
  color: var(--text);
  background: rgba(0,61,165,.08);
  border-color: rgba(0,61,165,.14);
  box-shadow: 0 0 0 1px rgba(0,61,165,.10) inset;
}

.mobile-menu__footer{
  margin-top:auto;
  padding: 12px;
  border-top: 1px solid rgba(255,255,255,.10);
  display:grid;
  gap: 10px;
}
html[data-theme="light"] .mobile-menu__footer{ border-top: 1px solid var(--border); }

/* Selector idioma dentro del menú (inyectado por JS) */
.mobile-lang{
  width: 100%;
  position:relative;
}

.mobile-lang select{
  width: 100%;
  appearance: none;
  -webkit-appearance: none;
  border: 1px solid rgba(255,255,255,.14);
  background: rgba(255,255,255,.06);
  color: var(--text);
  border-radius: 999px;
  padding: 12px 44px 12px 14px;
  font-weight: 850;
  cursor:pointer;
  outline:none;
  box-shadow: 0 10px 26px rgba(0,0,0,.14);
}

html[data-theme="light"] .mobile-lang select{
  border-color: rgba(11,16,32,.12);
  background: rgba(11,16,32,.04);
}

.mobile-lang::after{
  content:"";
  position:absolute;
  right: 16px;
  top: 50%;
  width: 10px;
  height: 10px;
  transform: translateY(-50%) rotate(45deg);
  border-right: 2px solid rgba(255,255,255,.72);
  border-bottom: 2px solid rgba(255,255,255,.72);
  pointer-events:none;
  opacity: .9;
}
html[data-theme="light"] .mobile-lang::after{
  border-right-color: rgba(11,16,32,.55);
  border-bottom-color: rgba(11,16,32,.55);
}

/* =========================
   Page / Hero
========================= */
.page{ padding-top: 0; }

.hero{
  position:relative;
  padding-top: calc(var(--header-h) + 42px);
  padding-bottom: 54px;
  overflow:hidden;
}

.hero__bg{
  position:absolute;
  inset:0;
  background:
    radial-gradient(900px 420px at 20% 30%, rgba(0,61,165,.45), transparent 60%),
    radial-gradient(700px 380px at 80% 20%, rgba(24,35,137,.45), transparent 65%),
    linear-gradient(180deg, rgba(0,61,165,.65), rgba(6,8,18,0) 65%);
  opacity: .95;
  filter: saturate(1.05);
}

html[data-theme="light"] .hero__bg{
  background:
    radial-gradient(900px 420px at 20% 30%, rgba(0,61,165,.32), transparent 60%),
    radial-gradient(700px 380px at 80% 20%, rgba(24,35,137,.30), transparent 65%),
    linear-gradient(180deg, rgba(0,61,165,.35), rgba(255,255,255,0) 65%);
}

.hero__grid{
  position:relative;
  display:grid;
  grid-template-columns: 1.1fr .9fr;
  gap: 26px;
  align-items: start;
  min-width: 0;
}

.hero__copy{ padding-top: 8px; min-width: 0; }

.pill{
  display:inline-flex;
  align-items:center;
  gap:10px;
  padding: 8px 12px;
  border-radius: 999px;
  background: rgba(255,255,255,.10);
  border: 1px solid rgba(255,255,255,.14);
  color: rgba(255,255,255,.92);
  font-weight: 850;
  font-size: 12px;
}

html[data-theme="light"] .pill{
  background: rgba(11,16,32,.05);
  border-color: rgba(11,16,32,.10);
  color: rgba(11,16,32,.82);
}

.pill--soft{
  color: var(--text);
  background: var(--panel);
  border-color: var(--border);
}

.hero__title{
  margin: 14px 0 10px;
  font-size: clamp(42px, 4.4vw, 58px);
  line-height: 1.02;
  letter-spacing: -0.02em;
  font-weight: 950;
  color: rgba(255,255,255,.96);
}

html[data-theme="light"] .hero__title{ color: #0b1020; }

.hero__subtitle{
  margin: 0;
  max-width: 54ch;
  color: rgba(255,255,255,.78);
  font-weight: 650;
  line-height: 1.55;
}

html[data-theme="light"] .hero__subtitle{ color: rgba(11,16,32,.70); }

.hero__cta{
  margin-top: 18px;
  display:flex;
  flex-wrap:wrap;
  gap: 10px;
}

.kpis{
  margin-top: 18px;
  display:grid;
  grid-template-columns: repeat(4, minmax(0,1fr));
  gap: 12px;
}

.kpi{
  padding: 14px 14px;
  border-radius: 16px;
}

.kpi__value{
  font-weight: 950;
  font-size: 18px;
  color: rgba(255,255,255,.96);
}

html[data-theme="light"] .kpi__value{ color: #0b1020; }

.kpi__label{
  margin-top: 6px;
  font-weight: 750;
  font-size: 12px;
  color: rgba(255,255,255,.72);
}

html[data-theme="light"] .kpi__label{ color: rgba(11,16,32,.64); }

.hero__panel{
  border-radius: var(--radius2);
  border: 1px solid rgba(255,255,255,.14);
  background: rgba(255,255,255,.06);
  box-shadow: 0 30px 90px rgba(0,0,0,.35);
  overflow:hidden;
  min-height: 250px;
  min-width: 0;
}

html[data-theme="light"] .hero__panel{
  background: rgba(255,255,255,.65);
  border-color: rgba(11,16,32,.10);
  box-shadow: var(--shadow2);
}

.hero__panel-top{
  display:flex;
  justify-content:space-between;
  align-items:center;
  padding: 16px 16px 10px;
  color: rgba(255,255,255,.86);
}

html[data-theme="light"] .hero__panel-top{ color: rgba(11,16,32,.78); }

.chip{
  display:inline-flex;
  align-items:center;
  padding: 7px 12px;
  border-radius: 999px;
  background: rgba(255,255,255,.12);
  border: 1px solid rgba(255,255,255,.14);
  font-weight: 850;
  font-size: 12px;
}

html[data-theme="light"] .chip{
  background: rgba(11,16,32,.05);
  border-color: rgba(11,16,32,.10);
}

.hero__panel-mid{
  position:relative;
  padding: 28px 16px 30px;
  display:grid;
  place-items:center;
  text-align:center;
  min-height: 190px;
  color: rgba(255,255,255,.82);
  font-weight: 850;
}

html[data-theme="light"] .hero__panel-mid{ color: rgba(11,16,32,.74); }

.float-orb{
  position:absolute;
  width: 120px;
  height: 120px;
  border-radius: 999px;
  opacity: .45;
  mix-blend-mode: screen;
  animation: float 8s var(--ease) infinite;
}

.orb1{ background: radial-gradient(circle at 30% 30%, rgba(255,255,255,.65), rgba(0,61,165,.15)); left: 18px; top: 18px; }
.orb2{ background: radial-gradient(circle at 30% 30%, rgba(255,255,255,.55), rgba(24,35,137,.18)); right: 18px; top: 44px; animation-duration: 10s; }
.orb3{ background: radial-gradient(circle at 30% 30%, rgba(255,255,255,.45), rgba(0,61,165,.12)); left: 50%; bottom: 16px; transform: translateX(-50%); animation-duration: 12s; }

@keyframes float{
  0%,100%{ transform: translateY(0) translateX(0) scale(1); }
  50%{ transform: translateY(-10px) translateX(6px) scale(1.03); }
}

/* =========================
   Divider 3D
========================= */
.divider-3d{
  position:absolute;
  left:0; right:0;
  bottom:-1px;
  height: 120px;
  pointer-events:none;
  overflow:hidden;
  background: linear-gradient(180deg, rgba(0,0,0,0), var(--bg) 82%);
}

.divider-3d__glow{
  position:absolute;
  left:50%;
  bottom:-70px;
  width: 900px;
  height: 220px;
  transform: translateX(-50%);
  background:
    radial-gradient(circle at 30% 30%, rgba(0,61,165,.26), transparent 60%),
    radial-gradient(circle at 70% 60%, rgba(24,35,137,.22), transparent 62%),
    radial-gradient(circle at 50% 50%, rgba(255,255,255,.08), transparent 65%);
  filter: blur(10px);
  opacity: .95;
}

.divider-3d__orbs{
  position:absolute;
  inset: 0;
  display:block;
}

.orb{
  position:absolute;
  border-radius: 999px;
  background:
    radial-gradient(circle at 28% 28%, rgba(255,255,255,.70), rgba(255,255,255,.18) 35%, rgba(0,0,0,0) 62%),
    radial-gradient(circle at 65% 70%, rgba(0,61,165,.28), rgba(24,35,137,.16) 55%, rgba(0,0,0,0) 78%),
    radial-gradient(circle at 50% 50%, rgba(255,255,255,.12), rgba(0,0,0,0) 70%);
  border: 1px solid rgba(255,255,255,.10);
  box-shadow:
    0 18px 50px rgba(0,0,0,.32),
    0 0 28px rgba(0,136,255,.12);
  filter: saturate(1.05);
  opacity: .85;
  animation: orbFloat 10s var(--ease) infinite;
}

html[data-theme="light"] .orb{
  border: 1px solid rgba(11,16,32,.10);
  box-shadow:
    0 14px 40px rgba(0,0,0,.12),
    0 0 24px rgba(0,61,165,.10);
  opacity: .75;
}

.orb--a{ width: 120px; height:120px; left: 6%;  bottom: -32px; animation-duration: 12s; }
.orb--b{ width: 180px; height:180px; left: 22%; bottom: -68px; animation-duration: 14s; }
.orb--c{ width: 140px; height:140px; left: 52%; bottom: -56px; animation-duration: 13s; }
.orb--d{ width: 220px; height:220px; left: 70%; bottom: -96px; animation-duration: 16s; }
.orb--e{ width: 110px; height:110px; left: 90%; bottom: -44px; animation-duration: 11s; }

@keyframes orbFloat{
  0%,100%{ transform: translateY(0) translateX(0) scale(1); }
  50%{ transform: translateY(-10px) translateX(-6px) scale(1.02); }
}

/* =========================
   Sections
========================= */
.section{ padding: var(--section-pad-lg) 0 var(--section-pad); }

.section__head{
  text-align:center;
  margin-bottom: 26px;
}

.section__title{
  margin: 12px 0 10px;
  font-size: clamp(28px, 2.8vw, 38px);
  letter-spacing: -0.02em;
  font-weight: 950;
}

.section__subtitle{
  margin: 0 auto;
  max-width: 70ch;
  color: var(--muted);
  font-weight: 650;
  line-height: 1.6;
}

.grad{
  background: linear-gradient(135deg, var(--c1), var(--c2));
  -webkit-background-clip: text;
  background-clip:text;
  color: transparent;
}

/* =========================
   Filters
========================= */
.filters{
  display:grid;
  grid-template-columns: 1fr 220px;
  gap: 12px;
  align-items:center;
  margin: 24px auto 18px;
  max-width: 980px;
}

.search,
.select{
  display:flex;
  align-items:center;
  gap:10px;
  padding: 12px 14px;
  border-radius: 16px;
  border: 1px solid var(--border);
  background: var(--panel2);
  box-shadow: 0 10px 26px rgba(0,0,0,.08);
  min-width: 0;
}

.search input{
  width:100%;
  border:0;
  outline:none;
  background: transparent;
  color: var(--text);
  font-weight: 700;
  min-width: 0;
}

.select select{
  width:100%;
  border:0;
  outline:none;
  background: transparent;
  color: var(--text);
  font-weight: 800;
  cursor:pointer;
  min-width: 0;
}

/* =========================
   Press grid
========================= */
.press-grid{
  display:grid;
  grid-template-columns: repeat(12, 1fr);
  gap: 16px;
  margin-top: 12px;
  min-height: 180px;
}

.press-card{
  grid-column: span 6;
  border-radius: var(--radius2);
  border: 1px solid var(--border);
  background: var(--panel);
  box-shadow: var(--shadow);
  overflow:hidden;
  position:relative;
  transform-style: preserve-3d;
  transition: transform .22s var(--ease), box-shadow .22s var(--ease);
  min-width: 0;
}

.press-card:hover{
  box-shadow: 0 0 0 1px rgba(120,180,255,.22) inset, 0 26px 90px rgba(0,0,0,.25);
}

html[data-theme="dark"] .press-card:hover{
  box-shadow:
    0 0 0 1px rgba(120,180,255,.22) inset,
    0 0 40px rgba(0,136,255,.18),
    0 26px 90px rgba(0,0,0,.55);
}

.press-card__top{
  padding: 14px 16px 12px;
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap: 12px;
  min-width: 0;
}

.badge{
  display:inline-flex;
  align-items:center;
  gap:8px;
  padding: 7px 10px;
  border-radius: 999px;
  font-weight: 900;
  font-size: 11px;
  border: 1px solid var(--border);
  background: var(--panel2);
  white-space: nowrap;
}

.badge--featured{
  border-color: rgba(120,180,255,.35);
  background: rgba(0,61,165,.08);
  box-shadow: 0 0 0 1px rgba(120,180,255,.18) inset;
}

.press-card__date{
  color: var(--muted);
  font-weight: 800;
  font-size: 12px;
  white-space: nowrap;
}

.press-card__body{ padding: 0 16px 16px; min-width: 0; }

.press-card__title{
  margin: 6px 0 8px;
  font-weight: 950;
  font-size: 18px;
  letter-spacing: -0.01em;
}

.press-card__excerpt{
  margin:0;
  color: var(--muted);
  line-height: 1.55;
  font-weight: 650;
}

.press-card__footer{
  padding: 14px 16px 16px;
  display:flex;
  gap:10px;
  flex-wrap:wrap;
  align-items:center;
}

.tag{
  font-size: 12px;
  font-weight: 900;
  color: rgba(0,61,165,.95);
  background: rgba(0,61,165,.08);
  border: 1px solid rgba(0,61,165,.18);
  padding: 7px 10px;
  border-radius: 999px;
}

html[data-theme="dark"] .tag{
  color: rgba(200,230,255,.92);
  background: rgba(0,136,255,.10);
  border-color: rgba(0,136,255,.22);
}

.micro{
  text-align:center;
  color: var(--muted);
  font-weight: 750;
  margin-top: 16px;
}

/* =========================
   Empty State
========================= */
.empty-state{
  margin: 26px auto 0;
  max-width: 980px;
  border-radius: var(--radius2);
  border: 1px dashed var(--border);
  background: var(--panel2);
  padding: 34px 20px 20px;
  text-align:center;
  box-shadow: 0 16px 50px rgba(0,0,0,.10);
}

.empty-state__icon{
  width: 56px;
  height: 56px;
  border-radius: 18px;
  display:grid;
  place-items:center;
  margin: 0 auto 12px;
  background: rgba(0,61,165,.10);
  border: 1px solid rgba(0,61,165,.18);
}

.empty-state h3{
  margin: 8px 0 6px;
  font-weight: 950;
}

.empty-state p{
  margin: 0 auto;
  max-width: 62ch;
  color: var(--muted);
  font-weight: 650;
  line-height:1.6;
}

.empty-state__placeholder{
  margin-top: 18px;
  height: 220px;
  border-radius: 18px;
  border: 1px solid rgba(120,180,255,.18);
  background:
    radial-gradient(700px 250px at 30% 30%, rgba(0,61,165,.12), transparent 60%),
    radial-gradient(600px 220px at 70% 70%, rgba(24,35,137,.12), transparent 60%),
    linear-gradient(180deg, rgba(255,255,255,.06), rgba(255,255,255,0));
  display:grid;
  place-items:center;
  color: var(--muted);
  font-weight: 900;
}

html[data-theme="light"] .empty-state__placeholder{
  background:
    radial-gradient(700px 250px at 30% 30%, rgba(0,61,165,.10), transparent 60%),
    radial-gradient(600px 220px at 70% 70%, rgba(24,35,137,.08), transparent 60%),
    linear-gradient(180deg, rgba(11,16,32,.03), rgba(11,16,32,0));
}

/* =========================
   CTA
========================= */
.cta{
  padding: var(--section-pad) 0 var(--section-pad-lg);
  background:
    radial-gradient(900px 420px at 30% 30%, rgba(0,61,165,.22), transparent 60%),
    radial-gradient(700px 360px at 80% 60%, rgba(24,35,137,.18), transparent 60%),
    linear-gradient(180deg, rgba(0,61,165,.18), rgba(0,0,0,0));
}

.cta__inner{
  border-radius: var(--radius2);
  border: 1px solid var(--border);
  background: var(--panel);
  box-shadow: var(--shadow);
  padding: 28px 22px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap: 18px;
  min-width: 0;
}

.cta__copy{ min-width: 0; }

.cta__copy h3{
  margin:0 0 8px;
  font-size: 24px;
  font-weight: 950;
  letter-spacing: -0.02em;
}

.cta__copy p{
  margin:0;
  max-width: 72ch;
  color: var(--muted);
  font-weight: 650;
  line-height: 1.6;
}

.cta__actions{
  display:flex;
  gap: 10px;
  flex-wrap:wrap;
  justify-content:flex-end;
  flex: 0 0 auto;
}

/* Card neon */
.card-neo{
  border: 1px solid rgba(255,255,255,.14);
  background: rgba(255,255,255,.06);
  box-shadow:
    0 0 0 1px rgba(120,180,255,.12) inset,
    0 0 30px rgba(0,136,255,.08);
}

html[data-theme="light"] .card-neo{
  border-color: rgba(11,16,32,.10);
  background: rgba(255,255,255,.55);
  box-shadow:
    0 0 0 1px rgba(0,61,165,.08) inset,
    0 14px 40px rgba(0,0,0,.10);
}

/* =========================
   Footer
========================= */
.site-footer{
  padding: 56px 0 26px;
  border-top: 1px solid var(--border);
  background:
    radial-gradient(900px 420px at 20% 0%, rgba(0,61,165,.16), transparent 60%),
    radial-gradient(700px 360px at 80% 10%, rgba(24,35,137,.14), transparent 60%);
}

.footer__grid{
  display:grid;
  grid-template-columns: 1.3fr 1fr 1fr 1.2fr;
  gap: 18px;
  min-width: 0;
}

.footer__logo-img{
  height:34px;
  width:auto;
  display:block;
  object-fit:contain;
}

.footer__text{
  color: var(--muted);
  line-height:1.6;
  font-weight: 650;
  margin: 12px 0 0;
}

.footer__title{
  margin:0 0 12px;
  font-weight: 950;
  letter-spacing:.02em;
  font-size: 12px;
  color: var(--muted);
}

.footer__link{
  display:block;
  padding: 8px 0;
  color: var(--text);
  opacity: .85;
  font-weight: 750;
}

.footer__link:hover{ opacity: 1; text-decoration: underline; }
.footer__link--map{ margin-top: 10px; }

.meta-row{
  display:flex;
  gap: 10px;
  margin-top: 14px;
  align-items:flex-start;
}

.meta-ico{
  width: 34px;
  height: 34px;
  border-radius: 12px;
  display:grid;
  place-items:center;
  border: 1px solid var(--border);
  background: rgba(255,255,255,.04);
}

html[data-theme="light"] .meta-ico{ background: rgba(11,16,32,.03); }

/* --- Footer Social Row --- */
.footer__social .footer-social-row {
  display: flex;
  flex-direction: column;
  gap: 10px;
}

.footer__social .label {
  font-weight: 600;
  line-height: 1.2;
}

.footer__social .icons {
  display: flex;
  align-items: center;
  gap: 10px;
  flex-wrap: wrap;
}

.footer__social .social-mini {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 38px;
  height: 38px;
  border-radius: 10px;
  color: inherit;
  text-decoration: none;
  border: 1px solid rgba(255,255,255,.18); /* ajusta según tu theme */
  transition: transform .12s ease, background-color .12s ease, border-color .12s ease;
}

.footer__social .social-mini:hover {
  transform: translateY(-1px);
  background: rgba(255,255,255,.08);
  border-color: rgba(255,255,255,.28);
}

.footer__social .social-mini svg {
  display: block;
  fill: currentColor; /* X usa fill */
}

.footer__social .social-mini i {
  font-size: 18px;
  line-height: 1;
}

/* Responsive: si tu grid en móvil apila columnas, esto se verá bien igual */
.social{ display:flex; gap:10px; flex-wrap:wrap; }

.social__btn{
  width: 40px;
  height: 40px;
  border-radius: 14px;
  display:grid;
  place-items:center;
  border: 1px solid var(--border);
  background: rgba(255,255,255,.04);
  transition: transform .18s var(--ease);
}

html[data-theme="light"] .social__btn{ background: rgba(11,16,32,.03); }
.social__btn:hover{ transform: translateY(-2px); }

.contact-mini{ margin-top: 8px; }
.contact-mini__row{
  display:flex;
  gap:10px;
  margin: 10px 0;
  align-items:flex-start;
}

.footer__bottom{
  margin-top: 26px;
  padding-top: 18px;
  border-top: 1px solid var(--border);
  display:flex;
  gap: 14px;
  justify-content:space-between;
  align-items:center;
  color: var(--muted);
  font-weight: 700;
}

.footer__legal{
  display:flex;
  gap: 14px;
  flex-wrap:wrap;
  justify-content:flex-end;
}

.footer__legal-link{ color: var(--muted); }
.footer__legal-link:hover{ color: var(--text); text-decoration: underline; }

/* =========================
   Reveal animations
========================= */
.reveal{
  opacity: 0;
  transform: translateY(10px);
  transition: opacity .55s var(--ease), transform .55s var(--ease);
}
.reveal.in-view{
  opacity: 1;
  transform: translateY(0);
}

/* =========================
   Responsive
========================= */
@media (max-width: 980px){
  .hero__grid{ grid-template-columns: 1fr; }
  .kpis{ grid-template-columns: repeat(2, minmax(0,1fr)); }
  .press-card{ grid-column: span 12; }
  .footer__grid{ grid-template-columns: 1fr 1fr; }
}

/* === Mobile header like reference (<= 980px) === */
@media (max-width: 980px){
  /* Igual que referencia: hamburguesa visible, nav desktop oculto */
  .menu-toggle{ display:block; }
  .nav{ display:none; }

  /* Importante: NO forzar altura en móvil (la referencia no lo hace) */
  .site-header{ height: auto !important; }

  /* Header layout: 2 filas (grid) como referencia */
  .header__inner{
    height: auto;
    padding: 12px 0;
    display: grid;
    grid-template-columns: 1fr auto;
    grid-template-rows: auto auto;
    row-gap: 10px;
    align-items: center;
  }

  /* Controles a la derecha */
  .header__actions{
    width: auto;
    justify-content: flex-end;
  }

  /* Si en tu header hay CTA primaria, en referencia se oculta en móvil */
  .header__actions .btn-primary,
  .header__actions .btn.btn-primary{
    display:none !important;
  }
/* Ocultar "¿Eres colaborador?" en el header en móvil (ya está dentro del menú) */
.header__actions a[href="#contacto-prensa"][data-i18n-text="header.collab"]{
  display:none !important;
}

  /* Selector de idioma ocupa toda la fila como referencia */
  .lang{
    grid-column: 1 / -1;
    width: 100%;
  }

  /* Botón idioma full width + spacing como referencia */
  .lang__btn{
    width: 100%;
    justify-content: space-between;
    padding: 0 14px;
  }

  /* En tu CSS móvil agregaste un “dot” decorativo (:before).
     La referencia NO lo usa así, por eso se ve distinto. */
  .lang__btn::before{ display:none !important; }

  /* En tu CSS lo pones absoluto a la derecha.
     En referencia va “natural” dentro del layout */
  .lang__btn i{
    position: static !important;
    margin-left: auto;
  }

  /* Mantén tu ajuste útil: filtros en 1 columna */
  .filters{
    grid-template-columns: 1fr;
  }
}


@media (max-width: 520px){
  .header__inner{ gap:10px; }
  .brand{ min-width: 140px; }
  .brand__logo{ height: 30px; }

  .kpis{ grid-template-columns: 1fr; }

  .cta__inner{
    flex-direction: column;
    align-items: flex-start;
  }
  .cta__actions{ width: 100%; justify-content: flex-start; }

  .footer__grid{ grid-template-columns: 1fr; }
  .footer__bottom{
    flex-direction:column;
    align-items:flex-start;
  }
}

/* Desktop: ocultar SOLO el botón hamburguesa (>= 981px) */
@media (min-width: 981px){
  .menu-toggle{ display: none !important; }
}


/* =========================================================
   Reference parity patch (ONLY header/nav/services + hamburger)
   Goal: match index.html + stylebeca.css visuals WITHOUT touching i18n logic.
   ========================================================= */

/* Primary color used by reference hover states */
:root{
  --primary: rgb(31,94,255);
  --primary-2: rgb(43,140,255);
  --t-fast: .18s;
}

/* Desktop nav links: match reference (.nav-link) look */
.site-header .nav__link{
  text-decoration:none;
  color: var(--text);
  opacity: 0.92;
  font-weight: 900;
  font-size: 14px;
  padding: 10px 10px;
  border-radius: 12px;
  letter-spacing: -0.01em;
  transition: background var(--t-fast) var(--ease), opacity var(--t-fast) var(--ease),
              transform var(--t-fast) var(--ease), box-shadow var(--t-fast) var(--ease), color var(--t-fast) var(--ease);
}
.site-header .nav__link:hover,
.site-header .nav__link:focus-visible{
  background: color-mix(in srgb, var(--primary) 10%, transparent);
  opacity: 1;
  color: var(--text);
  transform: translateY(-1px);
  box-shadow: 0 10px 22px rgba(31,94,255,0.08);
  outline:none;
}
.site-header .nav__link.is-active,
.site-header .nav__link[aria-current="page"]{
  opacity: 1;
  color: var(--text);
  background: color-mix(in srgb, var(--primary) 13%, transparent);
  box-shadow: inset 0 0 0 1px rgba(31,94,255,0.14);
}

/* Hamburger: match reference (.menu-toggle + .bar) exactly */
.menu-toggle{
  display:none; /* reference hides on desktop */
  width: 46px;
  height: 44px;
  border-radius: 14px;
  background: color-mix(in srgb, var(--bg) 84%, var(--primary) 16%);
  border: 1px solid color-mix(in srgb, var(--primary) 14%, var(--border));
  cursor:pointer;
  padding: 10px 10px;
  -webkit-tap-highlight-color: transparent;
  transition: transform var(--t-fast) var(--ease), box-shadow var(--t-fast) var(--ease), background var(--t-fast) var(--ease), border-color var(--t-fast) var(--ease);
  box-shadow: none; /* reference: shadow only in light */
}
html[data-theme="light"] .menu-toggle{
  box-shadow: 0 12px 26px rgba(19,33,68,0.10);
}
.menu-toggle:hover{ transform: translateY(-1px); }

/* destination uses <span> bars; reference uses .bar -> support both */
.menu-toggle span,
.menu-toggle .bar{
  display:block;
  height: 3px;
  border-radius: 99px;
  background: color-mix(in srgb, var(--text) 82%, transparent);
  margin: 5px 0 !important;
  width: 100%;
  opacity: 1;
}

/* Mobile menu links: match reference */
.mobile-nav-link{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap: 12px;
  padding: 14px 14px;
  border-radius: 16px;
  text-decoration:none;
  color: var(--text);
  font-weight: 950;
  background: color-mix(in srgb, var(--bg) 92%, #0b1220 8%);
  border: 1px solid var(--border);
  transition: transform var(--t-fast) var(--ease), background var(--t-fast) var(--ease),
              border-color var(--t-fast) var(--ease), opacity var(--t-fast) var(--ease), box-shadow var(--t-fast) var(--ease);
  opacity: 0.95;
}
html[data-theme="dark"] .mobile-nav-link{
  background: rgba(255,255,255,0.03);
  border: 1px solid rgba(255,255,255,0.06);
}
.mobile-nav-link:hover,
.mobile-nav-link.is-active{
  transform: translateY(-1px);
  background: color-mix(in srgb, var(--primary) 10%, transparent);
  border-color: rgba(31,94,255,0.18);
  box-shadow: 0 14px 34px rgba(19,33,68,0.14);
  opacity: 1;
}

/* IMPORTANT: breakpoint parity with reference */
@media (max-width: 980px){
  .menu-toggle{ display:block; }
  .nav{ display:none; }
}
@media (max-width: 768px){
  .mobile-menu{ width: min(85vw, 420px); }
}

@media (max-width: 420px){
  .mobile-menu{ width: 100vw; border-left: 0; }
}
/* =====================================================
   DEFINITIVO: Active state visible in MOBILE drawer
   - Fuerza el resaltado del link activo en resolución móvil
   - No toca JS ni HTML (solo CSS)
   ===================================================== */
@media (max-width: 980px){
  .mobile-nav-link.is-active,
  .mobile-nav-link.active,
  .mobile-nav-link[aria-current="page"]{
    background: rgba(31,94,255,0.18) !important;
    border-color: rgba(31,94,255,0.38) !important;
    color: rgba(255,255,255,0.98) !important;
    box-shadow: 0 14px 34px rgba(19,33,68,0.14) !important;
    opacity: 1 !important;
    transform: translateY(-1px) !important;
  }

  /* Modo claro */
  html[data-theme="light"] .mobile-nav-link.is-active,
  html[data-theme="light"] .mobile-nav-link.active,
  html[data-theme="light"] .mobile-nav-link[aria-current="page"]{
    background: rgba(31,94,255,0.12) !important;
    border-color: rgba(31,94,255,0.26) !important;
    color: rgba(11,16,32,0.96) !important;
    box-shadow: 0 12px 26px rgba(19,33,68,0.10) !important;
  }
}

/* =========================
   LIGHT-ONLY SAFEGUARD
   If any script accidentally sets data-theme="dark", keep the light tokens.
========================= */
html[data-theme="dark"]{
  --bg: #ffffff;
  --panel: rgba(255,255,255,.78);
  --panel2: rgba(245,247,255,.9);
  --text: #0b1020;
  --muted: rgba(11,16,32,.68);
  --border: rgba(11,16,32,.12);

  --shadow: 0 18px 60px rgba(0,0,0,.12);
  --shadow2: 0 12px 40px rgba(0,0,0,.16);

  --glow: rgba(0, 136, 255, .25);
  --glow2: rgba(64, 140, 255, .30);
}
body.theme-dark{ background: var(--bg); color: var(--text); }


/* =========================================================
   PATCH — Mobile servicios submenu (prensa) + reveal alias
   - Replica la UX del menú hamburguesa de la referencia
   - Adaptado a IDs/clases existentes en prensa
   - No rompe menú actual: solo añade estilos para <details>
========================================================= */
@media (max-width: 980px){
  .mobile-nav .mobile-nav-item{
    display: block;
    width: 100%;
  }

  /* El <summary> usa la base visual de .mobile-nav-link ya existente */
  .mobile-nav details.menu-details{
    width: 100%;
  }

  .mobile-nav details.menu-details > summary{
    list-style: none;
  }
  .mobile-nav details.menu-details > summary::-webkit-details-marker{
    display: none;
  }

  .mobile-nav .mobile-nav-summary{
    display:flex;
    align-items:center;
    justify-content:space-between;
    gap: 10px;
    cursor: pointer;
    user-select: none;
  }

  .mobile-nav .mobile-summary-link{
    flex: 1 1 auto;
    min-width: 0;
    color: inherit;
    text-decoration: none !important;
    display: inline-flex;
    align-items: center;
    font: inherit;
    font-weight: inherit;
  }

  .mobile-nav .mobile-nav-summary i{
    flex: 0 0 auto;
    font-size: 12px;
    line-height: 1;
    opacity: .75;
    transition: transform .22s var(--ease), opacity .22s var(--ease);
    pointer-events: none; /* el tap/click cae al summary */
  }

  .mobile-nav details.menu-details[open] > .mobile-nav-summary i{
    transform: rotate(90deg);
    opacity: .95;
  }

  .mobile-nav .mobile-submenu{
    margin: 8px 0 6px;
    padding: 0 0 0 8px;
    list-style: none;
    border-left: 1px solid rgba(31,94,255,0.12);
    display: grid;
    gap: 6px;
    animation: prensaSubmenuIn .18s ease-out;
  }

  html[data-theme="light"] .mobile-nav .mobile-submenu{
    border-left-color: rgba(11,16,32,0.10);
  }

  .mobile-nav .mobile-submenu li{
    margin: 0;
    padding: 0;
  }

  .mobile-nav .mobile-sub-link{
    display: flex;
    align-items: center;
    gap: 10px;
    min-height: 38px;
    padding: 10px 12px;
    margin-left: 6px;
    border-radius: 12px;
    text-decoration: none !important;
    color: var(--muted);
    font-weight: 800;
    line-height: 1.2;
    background: transparent;
    border: 1px solid transparent;
    transition: background var(--t-fast) var(--ease),
                border-color var(--t-fast) var(--ease),
                color var(--t-fast) var(--ease),
                transform var(--t-fast) var(--ease);
  }

  .mobile-nav .mobile-sub-link:hover,
  .mobile-nav .mobile-sub-link:focus-visible{
    color: var(--text);
    background: rgba(31,94,255,0.06);
    border-color: rgba(31,94,255,0.10);
    transform: translateY(-1px);
    outline: none;
  }

  html[data-theme="light"] .mobile-nav .mobile-sub-link:hover,
  html[data-theme="light"] .mobile-nav .mobile-sub-link:focus-visible{
    background: rgba(31,94,255,0.045);
    border-color: rgba(11,16,32,0.08);
  }

  .mobile-nav .mobile-sub-link.active,
  .mobile-nav .mobile-sub-link.is-active,
  .mobile-nav .mobile-sub-link[aria-current="page"]{
    color: var(--text);
    background: rgba(31,94,255,0.08);
    border-color: rgba(31,94,255,0.12);
  }

  /* Mantener compatibilidad con tu padding del CTA al final */
  .mobile-nav > .btn--collab{
    margin-top: 2px;
  }
}

@keyframes prensaSubmenuIn{
  from { opacity: 0; transform: translateY(-3px); }
  to   { opacity: 1; transform: translateY(0); }
}

/* Reveal: compatibilidad si otro JS usa .is-in (como noticias.js) */
.reveal.is-in{
  opacity: 1;
  transform: translateY(0);
}

/* =========================================================
   PATCH v2 — PC usa mismo menú hamburguesa (como móvil)
   + Servicios submenu con estilo también en desktop drawer
   + No toca IDs ni lógica de idiomas
========================================================= */

/* En PC: usar el mismo drawer/hamburguesa que en móvil */
@media (min-width: 981px){
  .nav{ display:none !important; }
  .menu-toggle{ display:grid !important; }

  /* Mantener drawer usable en desktop (paridad con móvil/reference) */
  .mobile-menu{
    width: min(420px, calc(100% - 24px));
  }
}

/* Submenú de Servicios dentro del drawer: estilos válidos en móvil y PC */
.mobile-nav .mobile-nav-item{
  display:block;
  width:100%;
}

.mobile-nav details.menu-details{
  width:100%;
}

.mobile-nav details.menu-details > summary{
  list-style:none;
}
.mobile-nav details.menu-details > summary::-webkit-details-marker{
  display:none;
}

.mobile-nav .mobile-nav-summary{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:10px;
  cursor:pointer;
  user-select:none;
}

.mobile-nav .mobile-summary-link{
  flex: 1 1 auto;
  min-width: 0;
  color: inherit;
  text-decoration: none !important;
  display:inline-flex;
  align-items:center;
  font: inherit;
  font-weight: inherit;
}

.mobile-nav .mobile-nav-summary i{
  flex:0 0 auto;
  font-size:12px;
  line-height:1;
  opacity:.75;
  transition: transform .22s var(--ease), opacity .22s var(--ease);
  pointer-events:none;
}

.mobile-nav details.menu-details[open] > .mobile-nav-summary i,
.mobile-nav details.menu-details:hover > .mobile-nav-summary i{
  transform: rotate(90deg);
  opacity:.95;
}

.mobile-nav .mobile-submenu{
  margin: 8px 0 6px;
  padding: 0 0 0 8px;
  list-style:none;
  border-left: 1px solid rgba(31,94,255,0.12);
  display:grid;
  gap:6px;
  animation: prensaSubmenuIn .18s ease-out;
}
html[data-theme="light"] .mobile-nav .mobile-submenu{
  border-left-color: rgba(11,16,32,0.10);
}

.mobile-nav .mobile-submenu li{
  margin:0;
  padding:0;
}

.mobile-nav .mobile-sub-link{
  display:flex;
  align-items:center;
  gap:10px;
  min-height:38px;
  padding: 10px 12px;
  margin-left:6px;
  border-radius:12px;
  text-decoration:none !important;
  color: var(--muted);
  font-weight:800;
  line-height:1.2;
  background: transparent;
  border:1px solid transparent;
  transition: background var(--t-fast, .18s) var(--ease),
              border-color var(--t-fast, .18s) var(--ease),
              color var(--t-fast, .18s) var(--ease),
              transform var(--t-fast, .18s) var(--ease);
}

.mobile-nav .mobile-sub-link:hover,
.mobile-nav .mobile-sub-link:focus-visible{
  color: var(--text);
  background: rgba(31,94,255,0.06);
  border-color: rgba(31,94,255,0.10);
  transform: translateY(-1px);
  outline:none;
}

html[data-theme="light"] .mobile-nav .mobile-sub-link:hover,
html[data-theme="light"] .mobile-nav .mobile-sub-link:focus-visible{
  background: rgba(31,94,255,0.045);
  border-color: rgba(11,16,32,0.08);
}

.mobile-nav .mobile-sub-link.active,
.mobile-nav .mobile-sub-link.is-active,
.mobile-nav .mobile-sub-link[aria-current="page"]{
  color: var(--text);
  background: rgba(31,94,255,0.08);
  border-color: rgba(31,94,255,0.12);
}

/* Desktop pointer: apertura visual del submenú por hover (sin romper <details> touch) */
@media (hover: hover) and (pointer: fine){
  .mobile-nav details.menu-details:not([open]) > .mobile-submenu{ display:none; }
  .mobile-nav details.menu-details:hover > .mobile-submenu,
  .mobile-nav details.menu-details:focus-within > .mobile-submenu{ display:grid; }
}

/* Compatibilidad reveal con scripts que usan .is-visible */
.reveal.is-visible{
  opacity:1;
  transform: translateY(0);
}

/* =========================================================
   PATCH FINAL — PRNSA header/menu desktop + submenus + reveal compat
   - Mantiene IDs existentes y lógica actual
   - Fuerza PC con hamburguesa (como referencia)
   - Ajusta posición derecha de CTA/idioma/hamburguesa
   - Añade ramas de Servicios y Noticias en drawer
========================================================= */

/* 1) PC: ocultar nav horizontal y dejar acciones en la esquina derecha */
@media (min-width: 981px){
  .site-header .nav{
    display: none !important;
  }

  .site-header .header__inner{
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
  }

  .site-header .brand{
    margin-right: auto;
    flex: 0 0 auto;
  }

  .site-header .header__actions{
    margin-left: auto !important;
    display: flex !important;
    align-items: center;
    justify-content: flex-end;
    gap: 8px;
    flex: 0 0 auto;
  }

  /* CTA + idioma + menú pegados a la derecha como referencia */
  .site-header .header__actions .btn--collab{
    margin: 0 !important;
    padding: 10px 12px !important;
    min-height: 42px;
    border-radius: 10px !important;
    white-space: nowrap;
  }

  .site-header .language-selector{
    margin: 0 !important;
  }

  .site-header .language-btn{
    min-height: 42px;
    border-radius: 10px !important;
    padding: 10px 12px !important;
  }

  /* Mostrar hamburguesa también en PC */
  .site-header .menu-toggle{
    display: grid !important;
  }
}

/* 2) Botón hamburguesa estilo referencia (más rectangular / limpio) */
.menu-toggle{
  width: 42px !important;
  height: 42px !important;
  min-width: 42px !important;
  border-radius: 10px !important;
  padding: 0 !important;
  box-shadow: none !important;
  border: 1px solid rgba(11,16,32,.12) !important;
  background: rgba(11,16,32,.04) !important;
  display: grid;
  place-items: center;
}

html[data-theme="dark"] .menu-toggle{
  border-color: rgba(255,255,255,.14) !important;
  background: rgba(255,255,255,.06) !important;
  box-shadow: none !important;
}

.menu-toggle:hover{
  transform: translateY(-1px);
  box-shadow: none !important;
}

.menu-toggle span{
  width: 18px !important;
  height: 2px !important;
  margin: 2px 0 !important;
  border-radius: 2px !important;
}

/* Close btn del drawer con mismo look */
.mobile-menu__close{
  border-radius: 10px !important;
  box-shadow: none !important;
}

/* 3) Drawer: mismo comportamiento visual en móvil y PC */
.mobile-menu{
  z-index: 230;
}

@media (min-width: 981px){
  .mobile-menu{
    width: min(400px, calc(100vw - 24px));
    right: 12px;
    top: 12px;
    bottom: 12px;
    border-radius: 18px;
  }
}

/* Links del drawer menos ovalados (más como referencia) */
.mobile-nav-link{
  border-radius: 12px !important;
  min-height: 46px;
  display: flex;
  align-items: center;
}

/* Resumen con chevron (Servicios / Noticias) */
.mobile-nav .mobile-nav-item{
  display: block;
  width: 100%;
}
.mobile-nav details.menu-details{
  width: 100%;
}
.mobile-nav details.menu-details > summary{
  list-style: none;
}
.mobile-nav details.menu-details > summary::-webkit-details-marker{
  display: none;
}
.mobile-nav .mobile-nav-summary{
  justify-content: space-between;
  cursor: pointer;
  user-select: none;
  gap: 10px;
}
.mobile-nav .mobile-summary-link{
  display: inline-flex;
  align-items: center;
  flex: 1 1 auto;
  min-width: 0;
  color: inherit;
  text-decoration: none !important;
  font: inherit;
  font-weight: inherit;
}
.mobile-nav .mobile-nav-summary > i{
  flex: 0 0 auto;
  font-size: 12px;
  opacity: .78;
  transition: transform .18s ease, opacity .18s ease;
  pointer-events: none;
}
.mobile-nav details.menu-details[open] > .mobile-nav-summary > i{
  transform: rotate(90deg);
  opacity: .98;
}

/* Submenú */
.mobile-nav .mobile-submenu{
  list-style: none;
  margin: 8px 0 6px;
  padding: 0 0 0 8px;
  border-left: 1px solid rgba(31,94,255,.14);
  display: grid;
  gap: 6px;
}
html[data-theme="light"] .mobile-nav .mobile-submenu{
  border-left-color: rgba(11,16,32,.10);
}
.mobile-nav .mobile-submenu li{
  margin: 0;
  padding: 0;
}
.mobile-nav .mobile-sub-link{
  display: flex;
  align-items: center;
  min-height: 38px;
  margin-left: 6px;
  padding: 10px 12px;
  border-radius: 10px;
  text-decoration: none !important;
  font-weight: 800;
  color: var(--muted);
  background: transparent;
  border: 1px solid transparent;
  transition: background .16s ease, border-color .16s ease, color .16s ease, transform .16s ease;
}
.mobile-nav .mobile-sub-link:hover,
.mobile-nav .mobile-sub-link:focus-visible{
  color: var(--text);
  background: rgba(31,94,255,.05);
  border-color: rgba(31,94,255,.12);
  transform: translateY(-1px);
  outline: none;
}
.mobile-nav .mobile-sub-link.active,
.mobile-nav .mobile-sub-link.is-active,
.mobile-nav .mobile-sub-link[aria-current="page"]{
  color: var(--text);
  background: rgba(31,94,255,.08);
  border-color: rgba(31,94,255,.14);
}

/* Contacto cerca del final (visual spacing antes del CTA) */
.mobile-nav .menu-news-branch + .mobile-nav-link[data-i18n-text="nav.contact"]{
  margin-top: 2px;
}
.mobile-nav > .btn--collab{
  margin-top: 4px;
  border-radius: 10px !important;
  min-height: 44px;
}

/* 4) Reveal compat (si el JS usa .is-in/.in-view) */
.reveal{
  will-change: transform, opacity;
}
.reveal.in-view,
.reveal.is-in,
.reveal.is-visible{
  opacity: 1;
  transform: translateY(0);
}


/* =========================================================
   PATCH FINAL ABSOLUTO — Ajuste hamburguesa + orden visual prensa
   - Corrige separación interna de las 3 líneas del botón hamburguesa
   - Mantiene IDs y estructura existente
   - Prensa queda como item top-level (HTML), este bloque solo ajusta estética/espaciado
========================================================= */

/* El problema era display:grid en .menu-toggle (separaba demasiado las barras).
   Lo cambiamos a flex en columna para que quede compacto como la referencia. */
.site-header .menu-toggle,
.menu-toggle{
  display: inline-flex !important;
  flex-direction: column !important;
  align-items: center !important;
  justify-content: center !important;
  align-content: center !important;
  gap: 3px !important;
  width: 42px !important;
  height: 42px !important;
  min-width: 42px !important;
  min-height: 42px !important;
  padding: 0 !important;
  border-radius: 10px !important;
  box-shadow: none !important;
  line-height: 0 !important;
}

.site-header .menu-toggle span,
.menu-toggle span{
  display: block !important;
  width: 18px !important;
  height: 2px !important;
  margin: 0 !important;
  border-radius: 2px !important;
  transform: none !important;
}

/* Mantener acciones del header más compactas en PC (como referencia) */
@media (min-width: 981px){
  .site-header .header__actions{
    gap: 6px !important;
  }

  .site-header .header__actions .menu-toggle{
    margin-left: 0 !important;
  }

  .site-header .header__actions .language-btn{
    padding-inline: 10px !important;
  }
}

/* Espaciado de ramas en drawer: Noticias > Prensa > Contacto (como referencia) */
.mobile-nav .menu-news-branch + .mobile-nav-link[data-i18n-text="nav.press"]{
  margin-top: 2px;
}
.mobile-nav .mobile-nav-link[data-i18n-text="nav.press"] + .mobile-nav-link[data-i18n-text="nav.contact"]{
  margin-top: 0;
}

/* =========================================================
   PATCH FINAL (solo estética)
   1) Títulos divididos azul rey / negro (Sala de Prensa, Nuestros Comunicados, ¿Eres medio de comunicación?)
   2) Base del sitio (LIGHT) en Morning Cloud #DCE2EF (excepto menú hamburguesa/drawer)
   3) Compat: si llega texto con <span class="grad"> lo forzamos a negro (sin gradiente)
   ========================================================= */

:root{
  --royal-blue: #182389; /* azul rey */
  --cloud: #DCE2EF;      /* Morning cloud */
}

/* 3) Si el HTML/idiomas inyecta .grad, aquí NO queremos gradiente: lo queremos negro */
.grad{
  background: none !important;
  -webkit-background-clip: initial !important;
  background-clip: initial !important;
  color: #0b1020 !important;
}

/* Clases para split */
.t-royal{ color: var(--royal-blue) !important; }
.t-black{ color: #0b1020 !important; }

/* 3) Fondo base en LIGHT: Morning Cloud */
html[data-theme="light"]{
  --bg: var(--cloud) !important; /* body usa var(--bg) */
}

/* Importante: NO tocar el drawer del menú hamburguesa (sigue usando var(--panel2) / etc.) */
html[data-theme="light"] .mobile-menu{
  /* se mantiene como está (panel2) */
}

/* Para que secciones que usan fondos/gradientes no “ensucien” el cloud: las hacemos transparentes
   (mantiene cards/paneles porque usan --panel/--panel2) */
html[data-theme="light"] .cta,
html[data-theme="light"] .site-footer{
  background: transparent !important;
}

/* =========================================================
   PATCH FINAL — Botones como referencia + quitar círculos grises
   Requisitos:
   1) Botones: Contacto de Prensa, Ver Comunicados (hero),
      Ver comunicado (cards), contacto@bausen.mx + Ver comunicados (CTA)
      -> cuadrados, base #5B75B6, texto blanco
   2) Header: ¿Eres colaborador? azul #5B75B6 + texto blanco + más cuadrado;
      Idiomas + Hamburguesa: más rectangulares/cuadrados (SIN cambiar posicionamiento)
   3) Quitar círculos grises (orbes/divider/float-orb) sin tocar lógica
========================================================= */

:root{
  --silver: #5B75B6; /* Silver lake blue */
}

/* ---------- 1) Botones de la página Prensa (sólidos, cuadrados) ---------- */
html[data-theme="light"] .hero__cta .btn,
html[data-theme="light"] .cta__actions .btn,
html[data-theme="light"] .press-card__footer a:not(.tag),
html[data-theme="light"] .press-card__footer button{
  background: var(--silver) !important;
  color: #FFFFFF !important;
  border: 1px solid rgba(11,16,32,.12) !important;
  border-radius: 8px !important;           /* más cuadrado (no pill) */
  box-shadow: none !important;              /* sin 3D */
  transform: none !important;               /* evita “flotar” */
  text-decoration: none !important;
  padding: 11px 16px !important;
  min-height: 42px !important;
  font-weight: 900 !important;
}

/* Iconos en blanco dentro de esos botones */
html[data-theme="light"] .hero__cta .btn i,
html[data-theme="light"] .cta__actions .btn i,
html[data-theme="light"] .press-card__footer a:not(.tag) i{
  color: #FFFFFF !important;
}

/* Hover: mismo color (sin cambio de tamaño ni sombra) */
html[data-theme="light"] .hero__cta .btn:hover,
html[data-theme="light"] .cta__actions .btn:hover,
html[data-theme="light"] .press-card__footer a:not(.tag):hover,
html[data-theme="light"] .press-card__footer button:hover{
  background: var(--silver) !important;
  box-shadow: none !important;
  transform: none !important;
}

/* ---------- 2) Header: CTA colaborador azul + botones más cuadrados ---------- */
html[data-theme="light"] .site-header .btn--collab{
  background: var(--silver) !important;
  color: #FFFFFF !important;
  border: 1px solid rgba(11,16,32,.12) !important;
  border-radius: 8px !important;           /* quita pill visual */
  box-shadow: none !important;
  transform: none !important;
}
html[data-theme="light"] .site-header .btn--collab:hover{
  background: var(--silver) !important;
  box-shadow: none !important;
  transform: none !important;
}

/* Idiomas (language-btn) más rectangular/cuadrado sin cambiar colores actuales */
.language-btn{
  border-radius: 10px !important;
  box-shadow: none !important;
  transform: none !important;
}
.language-btn:hover{ transform: none !important; }

/* Hamburguesa más rectangular/cuadrado sin cambiar colores actuales */
.menu-toggle{
  border-radius: 10px !important;
  box-shadow: none !important;
  transform: none !important;
}
.menu-toggle:hover{ transform: none !important; }

/* ---------- 3) Quitar círculos grises (orbes/divider) ---------- */
.float-orb,
.divider-3d__orbs,
.divider-3d__glow{
  display: none !important;
}

/* =========================================================
   PATCH FINAL — X como LinkedIn/Instagram + logo PC más grande + tipografía base
   Requisitos:
   1) Botón X (footer) con misma estética que LinkedIn/Instagram
   2) Logo Bausen en header (PC) 20–30% más grande
   3) Tipografía: ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, ...
   Nota: SOLO estética. No toca IDs ni lógica.
========================================================= */

/* 3) Tipografía global (HTML + BODY + controles) */
html, body{
  font-family: ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Arial, "Noto Sans", "Helvetica Neue", sans-serif !important;
}
button, input, select, textarea{
  font-family: inherit !important;
}

/* 2) Logo header (solo PC) */
@media (min-width: 981px){
  .brand__logo{
    height: 42px !important; /* ~+30% vs 32px */
    width: auto !important;
  }
}

/* 1) Botón X del footer: igual que .social__btn (LinkedIn/Instagram) */
.social .social-mini{
  width: 40px !important;
  height: 40px !important;
  border-radius: 14px !important;
  display: grid !important;
  place-items: center !important;
  border: 1px solid var(--border) !important;
  background: rgba(255,255,255,.04) !important;
  transition: transform .18s var(--ease) !important;
  color: var(--text) !important;
}
html[data-theme="light"] .social .social-mini{
  background: rgba(11,16,32,.03) !important;
}
.social .social-mini:hover{
  transform: translateY(-2px) !important;
}

/* SVG del botón X: hereda color como los iconos FA */
.social .social-mini svg path{
  fill: currentColor !important;
}

/* =========================================================
   PATCH FINAL — Ajustes solicitados (solo estética/estructura visual)
   1) Ocultar botón duplicado "¿Eres colaborador?" dentro del menú hamburguesa SOLO en PC
   2) Tarjetas más cuadradas: KPIs (50+, 38+, 100+, ∞) y tarjetas de comunicados (press-card)
   Nota: NO toca IDs ni lógica JS.
========================================================= */

/* 2) Tarjetas más cuadradas */
.kpi{ border-radius: 12px !important; }
.press-card{ border-radius: 14px !important; }

/* 1) En PC, quitar el CTA "¿Eres colaborador?" que está dentro del drawer */
@media (min-width: 981px){
  #mobileMenu .btn--collab{ display: none !important; }
}
