/* =========================================================
   GRUPO JUINSA — Sistema de diseño compartido
   Estética: corporativo limpio y sobrio.
   ========================================================= */

@import url('../fonts/plus-jakarta-sans/plus-jakarta-sans.css');

/* ---------- Accesibilidad ---------- */
/* Skip link */
.skip-link{position:absolute;top:-100%;left:1rem;z-index:200;padding:10px 20px;
  background:var(--ink);color:#fff;font-size:14px;font-weight:700;
  border-radius:0 0 8px 8px;text-decoration:none;}
.skip-link:focus{top:0;}

/* Focus visible — todos los elementos interactivos */
:focus-visible{outline:2px solid var(--ink);outline-offset:3px;border-radius:3px;}
:focus:not(:focus-visible){outline:none;}

/* prefers-reduced-motion — anula transiciones y animaciones */
@media(prefers-reduced-motion:reduce){
  *,*::before,*::after{
    animation-duration:.01ms !important;
    animation-iteration-count:1 !important;
    transition-duration:.01ms !important;
    scroll-behavior:auto !important;
  }
  .reveal,.js .reveal:not(.in){transition:none !important;opacity:1 !important;transform:none !important;}
}

:root{
  /* Color */
  --bg:#ffffff;
  --bg-soft:#f4f5f6;
  --bg-soft-2:#eef0f1;
  --ink:#141414;          /* titulares casi negro */
  --ink-2:#414a5c;        /* cuerpo, slate */
  --muted:#8b909a;        /* subtítulos / inactivo */
  --line:#e4e6e9;         /* hairlines */
  --line-2:#d6d9dd;
  --dark:#141414;         /* secciones oscuras (logos blancos) */
  --dark-2:#1c1c1e;

  /* Tipografía */
  --font:'Plus Jakarta Sans', system-ui, -apple-system, 'Segoe UI', sans-serif;

  /* Medidas */
  --container:1240px;
  --container-wide:1400px;
  --radius:14px;
  --radius-lg:22px;
  --pad-x:clamp(20px,5vw,48px);
  --section-y:clamp(72px,9vw,128px);

  /* Sombra muy sutil */
  --shadow:0 1px 2px rgba(20,20,20,.04), 0 18px 40px -28px rgba(20,20,20,.18);
}

*{box-sizing:border-box;}
html{scroll-behavior:smooth;overflow-x:clip;}
body{
  margin:0;
  font-family:var(--font);
  color:var(--ink-2);
  background:var(--bg);
  font-size:17px;
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
  overscroll-behavior-x:none;
}
img{display:block;max-width:100%;}
figure{margin:0;}
a{color:inherit;text-decoration:none;}
ul{margin:0;padding:0;list-style:none;}

/* ---------- Tipografía ---------- */
h1,h2,h3,h4{
  color:var(--ink);
  font-weight:800;
  line-height:1.04;
  letter-spacing:-.02em;
  margin:0;
  text-wrap:balance;
}
.display{
  font-size:clamp(44px,8vw,104px);
  letter-spacing:-.035em;
}
.display em, .accent-italic{font-style:italic;font-weight:800;}
h2.section-title{font-size:clamp(30px,4.4vw,52px);letter-spacing:-.03em;}
h3{font-size:clamp(22px,2.4vw,30px);letter-spacing:-.02em;}
p{margin:0 0 1.1em;}
.lead{font-size:clamp(18px,1.6vw,21px);color:var(--ink-2);}

/* ---------- Layout ---------- */
.container{width:100%;max-width:var(--container);margin:0 auto;padding-inline:var(--pad-x);}
.container.wide{max-width:var(--container-wide);}
section{position:relative;}
.section-pad{padding-block:var(--section-y);}

/* Etiqueta superior tipo "ojo" */
.eyebrow{
  display:inline-flex;align-items:center;gap:.6em;
  font-size:12.5px;font-weight:700;letter-spacing:.22em;text-transform:uppercase;
  color:var(--ink);
}
.badge-pill{
  display:inline-flex;align-items:center;
  padding:9px 20px;border:1.5px solid var(--ink);border-radius:999px;
  font-size:12.5px;font-weight:700;letter-spacing:.2em;text-transform:uppercase;
  color:var(--ink);background:transparent;
}

/* ---------- Botones ---------- */
.btn{
  display:inline-flex;align-items:center;gap:.7em;cursor:pointer;
  padding:14px 30px;border-radius:999px;
  font-family:var(--font);font-size:13px;font-weight:700;
  letter-spacing:.16em;text-transform:uppercase;
  border:1.5px solid var(--ink);background:transparent;color:var(--ink);
  transition:background .25s ease,color .25s ease,transform .25s ease;
}
.btn:hover{background:var(--ink);color:#fff;}
.btn:active{transform:translateY(1px);}
.btn--light{border-color:#fff;color:#fff;}
.btn--light:hover{background:#fff;color:var(--ink);}
.btn--solid{background:var(--ink);color:#fff;}
.btn--solid:hover{background:#000;}
.btn .arrow{transition:transform .25s ease;}
.btn:hover .arrow{transform:translateX(4px);}

/* ---------- Header ---------- */
.site-header{
  position:sticky;top:0;z-index:50;
  background:rgba(255,255,255,.86);
  backdrop-filter:saturate(140%) blur(10px);
  border-bottom:1px solid transparent;
  transition:border-color .3s ease, box-shadow .3s ease;
}
.site-header.scrolled{border-bottom-color:var(--line);box-shadow:0 1px 0 rgba(20,20,20,.02);}
.header-inner{
  max-width:var(--container-wide);margin:0 auto;padding:18px var(--pad-x);
  display:flex;align-items:center;justify-content:space-between;gap:32px;
}
.brand{display:flex;align-items:center;flex-shrink:0;}
.brand img{height:52px;width:auto;}
.brand .wordmark{
  font-weight:800;line-height:.92;letter-spacing:-.02em;color:var(--ink);
  font-size:21px;text-transform:uppercase;
}
.nav{display:flex;align-items:center;gap:clamp(18px,2.4vw,42px);}
.nav a, .nav-toggle{
  font-size:16px;font-weight:700;color:var(--ink);letter-spacing:-.01em;
  position:relative;padding:6px 0;white-space:nowrap;transition:color .2s ease;
}
.nav-toggle{font-family:var(--font);background:none;border:none;cursor:pointer;display:inline-flex;align-items:center;}
.nav a:hover, .nav-toggle:hover{color:var(--ink-2);}
.nav a.active, .nav-toggle.active{color:var(--muted);}
.nav-item{position:relative;}
.nav-item.has-sub>a::after, .nav-item.has-sub>.nav-toggle::after{content:"▾";font-size:11px;margin-left:6px;color:var(--muted);}
.subnav{
  position:absolute;top:calc(100% + 10px);left:50%;transform:translateX(-50%) translateY(6px);
  background:#fff;border:1px solid var(--line);border-radius:14px;
  padding:8px;min-width:200px;box-shadow:var(--shadow);
  opacity:0;visibility:hidden;transition:opacity .2s ease,transform .2s ease;
}
/* Puente invisible que cubre el hueco entre el menú y el desplegable */
.nav-item.has-sub::after{content:"";position:absolute;left:0;right:0;top:100%;height:16px;}
.nav-item.has-sub:hover .subnav, .nav-item.has-sub.open .subnav{opacity:1;visibility:visible;transform:translateX(-50%) translateY(0);}
.subnav a{display:block;padding:10px 14px;border-radius:9px;font-size:15px;}
.subnav a:hover{background:var(--bg-soft);}

/* Botón menú móvil */
.menu-toggle{display:none;background:none;border:none;cursor:pointer;padding:8px;}
.menu-toggle span{display:block;width:26px;height:2px;background:var(--ink);margin:5px 0;transition:.3s;}

/* ---------- Hero genérico (páginas interiores) ---------- */
.page-hero{
  position:relative;overflow:hidden;background:var(--bg-soft);
  border-bottom:1px solid var(--line);
}
.page-hero .hex-bg{position:absolute;inset:0;width:100%;height:100%;z-index:0;pointer-events:none;}
.page-hero .container{position:relative;z-index:1;text-align:center;
  padding-block:clamp(64px,10vw,120px);}
.page-hero .badge-pill{margin-bottom:26px;}
.page-hero p.lead{max-width:720px;margin:22px auto 0;color:var(--ink-2);}

/* Patrón hexagonal reutilizable */
.hex-pattern{
  position:absolute;inset:0;z-index:0;pointer-events:none;
  background-image:url("hex.svg");
  background-repeat:repeat;background-size:280px auto;opacity:.5;
}

/* ---------- Footer (compacto) ---------- */
.site-footer{background:var(--dark);color:#aeb2ba;padding-block:48px 22px;font-size:14.5px;}
.footer-main{
  display:grid;grid-template-columns:1.5fr 1fr 1fr;gap:clamp(28px,5vw,64px);
  padding-bottom:30px;border-bottom:1px solid rgba(255,255,255,.1);align-items:start;
}
.site-footer .f-brand .wordmark{color:#fff;font-size:19px;font-weight:800;letter-spacing:-.01em;}
.site-footer .f-tag{margin:12px 0 0;max-width:320px;color:#8b909a;font-size:14px;line-height:1.55;}
.site-footer h4{color:#fff;font-size:12px;letter-spacing:.16em;text-transform:uppercase;margin:0 0 14px;font-weight:700;}
.site-footer a{color:#aeb2ba;transition:color .2s ease;}
.site-footer a:hover{color:#fff;}
.f-col{display:flex;flex-direction:column;gap:9px;}
.f-col .big{color:#fff;font-size:16px;font-weight:600;letter-spacing:-.01em;}
.footer-bottom{
  display:flex;align-items:center;justify-content:space-between;gap:14px;flex-wrap:wrap;
  padding-top:18px;font-size:12.5px;letter-spacing:.03em;color:#71767f;
}
.footer-bottom .f-legal{display:flex;gap:20px;}
.footer-bottom .f-legal a{color:#8b909a;}

/* CTA LinkedIn (compacto) */
.li-cta{
  display:inline-flex;align-items:center;gap:9px;margin-top:20px;
  padding:9px 18px 9px 12px;border-radius:999px;
  background:#0A66C2;color:#fff !important;font-weight:700;font-size:14px;letter-spacing:-.01em;
  transition:background .25s ease,transform .25s ease;
}
.li-cta svg{width:20px;height:20px;fill:#fff;flex-shrink:0;}
.li-cta:hover{background:#0958a8;transform:translateY(-1px);}
.li-cta:active{transform:translateY(0);}

@media(max-width:760px){
  .footer-main{grid-template-columns:1fr 1fr;gap:32px;}
  .site-footer .f-brand{grid-column:1 / -1;}
}
@media(max-width:480px){
  .footer-main{grid-template-columns:1fr;}
  .footer-bottom{flex-direction:column;align-items:flex-start;gap:10px;}
}

/* ---------- Utilidades ---------- */
.grid{display:grid;gap:clamp(24px,3vw,48px);}
.muted{color:var(--muted);}
.center{text-align:center;}
.reveal{transition:opacity .8s cubic-bezier(.2,.7,.2,1),transform .8s cubic-bezier(.2,.7,.2,1);}
.js .reveal:not(.in){opacity:0;transform:translateY(26px);}
.reveal.in{opacity:1;transform:none;}

/* Logos monocromos robustos (sirve para logos blancos o de color) */
.logo-mono{filter:brightness(0);opacity:.62;transition:filter .3s ease,opacity .3s ease;}
.logo-mono:hover{filter:none;opacity:1;}
.logo-mono--light{filter:brightness(0) invert(1);opacity:.85;}
.logo-mono--light:hover{filter:none;opacity:1;}

/* ---------- Responsive ---------- */
@media (max-width:1080px){
  .nav{gap:18px;}
  .nav a{font-size:15px;}
  .nav-toggle{font-size:15px;}
}
@media (max-width:900px){
  .menu-toggle{display:block;position:relative;z-index:72;}
  #hexCanvas{opacity:.22;}
  .nav{
    position:fixed;top:0;right:0;bottom:0;left:auto;
    width:min(86vw,360px);height:100vh;height:100dvh;
    flex-direction:column;align-items:stretch;gap:2px;
    background:#ffffff;padding:84px 26px calc(40px + env(safe-area-inset-bottom));
    transform:translateX(100%);transition:transform .35s cubic-bezier(.2,.7,.2,1);
    box-shadow:-20px 0 60px -30px rgba(0,0,0,.45);z-index:70;
    overflow-y:auto;-webkit-overflow-scrolling:touch;overscroll-behavior:contain;
  }
  .nav.open{transform:none;}
  .nav a{font-size:19px;padding:13px 0;}
  .nav-toggle{font-size:19px;padding:13px 0;width:100%;text-align:left;}
  .nav-item{width:100%;border-bottom:1px solid var(--line);}
  .nav-item:last-child{border-bottom:none;}
  .subnav{position:static;opacity:1;visibility:visible;transform:none;box-shadow:none;border:none;padding:0;min-width:0;max-height:0;overflow:hidden;transition:max-height .28s ease,padding .28s ease;}
  .nav-item.has-sub.open .subnav{max-height:260px;padding:0 0 8px 14px;transform:none;}
  .nav-item.has-sub.open .subnav a{color:var(--ink);opacity:1;visibility:visible;}
  .nav-item.has-sub>a::after, .nav-item.has-sub>.nav-toggle::after{display:inline-block;transition:transform .2s ease;}
  .nav-item.has-sub.open>a::after, .nav-item.has-sub.open>.nav-toggle::after{transform:rotate(180deg);}
  /* Botón cerrar */
  .nav-close{display:flex;align-items:center;justify-content:center;
    position:absolute;top:18px;right:20px;width:40px;height:40px;
    border:1px solid var(--line);border-radius:999px;background:#fff;
    font-size:24px;line-height:1;color:var(--ink);cursor:pointer;padding:0;}
  .nav-close:hover{background:var(--bg-soft);}
  /* Fondo oscuro detrás del menú */
  .nav-backdrop{position:fixed;inset:0;background:rgba(15,15,18,.5);
    -webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);
    opacity:0;visibility:hidden;transition:opacity .35s ease,visibility .35s ease;z-index:65;}
  .nav-backdrop.open{opacity:1;visibility:visible;}
  .footer-top{grid-template-columns:1fr;gap:32px;}
}
/* Bloqueo del scroll de fondo con el menú abierto */
html.menu-open, body.menu-open{overflow:hidden;}
/* El botón cerrar solo existe en móvil */
@media (min-width:901px){.nav-close{display:none;}}
@media (max-width:560px){
  .footer-bottom{flex-direction:column;align-items:flex-start;}
}

/* =========================================================
   PÁGINAS INTERIORES (estilos compartidos)
   ========================================================= */
/* Bloque de texto introductorio */
.intro{max-width:820px;}
.intro h2{font-size:clamp(28px,3.6vw,46px);margin-bottom:22px;}
.intro p{font-size:19px;color:var(--ink-2);}
.prose p{font-size:18px;color:var(--ink-2);margin-bottom:1.2em;max-width:760px;}
.prose p:last-child{margin-bottom:0;}

/* Filas alternas imagen + texto (Empresa) */
.feature{display:grid;grid-template-columns:1fr 1fr;gap:clamp(30px,5vw,80px);align-items:center;}
.feature + .feature{margin-top:clamp(64px,8vw,120px);}
.feature.reverse .feature-media{order:2;}
.feature-media{border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow);aspect-ratio:4/3;background:var(--bg-soft-2);}
.feature-media img{width:100%;height:100%;object-fit:cover;}
.feature-body .brand-logo{margin-bottom:24px;display:flex;align-items:center;min-height:46px;}
.feature-body .brand-logo img{width:auto;height:auto;display:block;}
.feature-body .brand-logo img.brand-logo--ixia{height:46px;}
.feature-body .brand-logo img.brand-logo--unimasa{height:50px;}
.feature-body .brand-logo img.brand-logo--juinsa{height:78px;}
.feature-body .brand-logo img.brand-logo--mom{height:42px;}
.feature-body h3{font-size:clamp(22px,2.4vw,30px);margin-bottom:16px;}
.feature-body .btn{margin-top:24px;}
.feature-body strong{color:var(--ink);font-weight:700;}
@media(max-width:820px){
  .feature{grid-template-columns:1fr;gap:28px;}
  .feature.reverse .feature-media{order:0;}
}

/* Rejilla de marcas (página Marcas) */
.brand-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(20px,2.4vw,30px);}
.brand-card{position:relative;display:flex;flex-direction:column;border-radius:var(--radius);
  overflow:hidden;background:var(--dark);box-shadow:var(--shadow);text-decoration:none;}
.brand-card .bc-media{position:relative;aspect-ratio:4/3;overflow:hidden;}
.brand-card .bc-media img{width:100%;height:100%;object-fit:cover;
  transition:transform .7s cubic-bezier(.2,.7,.2,1);filter:brightness(.66);}
.brand-card:hover .bc-media img{transform:scale(1.06);}
.brand-card .bc-logo{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;z-index:2;padding:24px;}
.brand-card .bc-logo img{max-height:64px;max-width:62%;width:auto;object-fit:contain;filter:brightness(0) invert(1);
  transition:transform .5s ease;}
.brand-card:hover .bc-logo img{transform:scale(1.04);}
.brand-card .bc-foot{display:flex;align-items:center;justify-content:space-between;gap:14px;
  padding:20px 24px;background:var(--dark);}
.brand-card .bc-title{color:#fff;font-weight:700;font-size:16px;letter-spacing:-.01em;}
.brand-card .bc-cta{color:rgba(255,255,255,.66);font-size:11.5px;font-weight:700;letter-spacing:.18em;
  text-transform:uppercase;display:inline-flex;gap:.5em;white-space:nowrap;transition:color .2s ease;}
.brand-card:hover .bc-cta{color:#fff;}
@media(max-width:880px){.brand-grid{grid-template-columns:repeat(2,1fr);}}
@media(max-width:540px){.brand-grid{grid-template-columns:1fr;}}

/* Contacto */
.contact-grid{display:grid;grid-template-columns:0.85fr 1.15fr;gap:clamp(30px,5vw,72px);align-items:start;}
.contact-block + .contact-block{margin-top:44px;}
.contact-block h3{font-size:22px;margin-bottom:14px;}
.contact-block p{color:var(--ink-2);margin-bottom:8px;}
.contact-block .big{font-size:clamp(24px,2.6vw,34px);font-weight:800;letter-spacing:-.02em;color:var(--ink);}
.contact-block a.big:hover{color:var(--ink-2);}
.embed-frame{border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow);border:1px solid var(--line);background:var(--bg-soft);}
.embed-frame iframe{display:block;width:100%;border:0;}
.embed-frame.map iframe{height:clamp(360px,52vh,560px);}
.embed-frame.jobs iframe{height:min(78vh,900px);}
.embed-frame.video{position:relative;aspect-ratio:16/9;}
.embed-frame.video iframe{position:absolute;inset:0;width:100%;height:100%;}
@media(max-width:820px){.contact-grid{grid-template-columns:1fr;gap:36px;}}

/* CTA final reutilizable */
.cta-band{background:var(--dark);color:#fff;border-radius:var(--radius-lg);
  padding:clamp(40px,5vw,68px);display:flex;align-items:center;justify-content:space-between;gap:28px;flex-wrap:wrap;}
.cta-band h2{color:#fff;font-size:clamp(26px,3vw,40px);}
.cta-band p{color:rgba(255,255,255,.7);margin:10px 0 0;max-width:520px;}

/* Chips de enlace */
.chip{display:inline-flex;align-items:center;padding:9px 16px;border:1px solid var(--line-2);
  border-radius:999px;font-size:13.5px;font-weight:600;color:var(--ink-2);transition:border-color .2s ease,color .2s ease;}
.chip:hover{border-color:var(--ink);color:var(--ink);}

/* Tarjetas de noticias / RSC */
.news-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:26px;}
.news-card{display:flex;flex-direction:column;background:#fff;border:1px solid var(--line);
  border-radius:var(--radius);overflow:hidden;text-decoration:none;
  transition:transform .3s ease,box-shadow .3s ease,border-color .3s ease;}
.news-card:hover{transform:translateY(-4px);box-shadow:var(--shadow);border-color:var(--line-2);}
.news-thumb{aspect-ratio:16/10;overflow:hidden;background:var(--bg-soft);border-bottom:1px solid var(--line);}
.news-thumb img{width:100%;height:100%;object-fit:cover;transition:transform .6s cubic-bezier(.2,.7,.2,1);}
.news-card:hover .news-thumb img{transform:scale(1.05);}
/* Banners apaisados (logos): mostrar completos sobre fondo a juego, sin recortar */
.news-thumb--contain img{object-fit:contain;padding:18px;}
.news-thumb--contain.bg-dark{background:#1f3a5f;}
.news-thumb--contain.bg-light{background:#fff;}
.news-card:hover .news-thumb--contain img{transform:scale(1.03);}
.news-body{display:flex;flex-direction:column;flex:1;padding:28px 30px 30px;}
.news-card .date{font-size:12px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--muted);margin-bottom:14px;}
.news-card h3{font-size:20px;line-height:1.22;margin-bottom:12px;}
.news-card p{font-size:15.5px;color:var(--ink-2);margin:0 0 22px;flex:1;}
.news-card .more{font-size:12px;font-weight:700;letter-spacing:.16em;text-transform:uppercase;color:var(--ink);display:inline-flex;gap:.5em;transition:gap .25s ease;}
.news-card:hover .more{gap:.85em;}
@media(max-width:980px){.news-grid{grid-template-columns:repeat(2,1fr);}}
@media(max-width:620px){.news-grid{grid-template-columns:1fr;}}

/* Asociaciones */
.assoc-item{display:grid;grid-template-columns:210px 1fr;gap:clamp(24px,4vw,56px);align-items:start;
  padding:clamp(30px,4vw,48px) 0;border-bottom:1px solid var(--line);}
.assoc-item:first-child{padding-top:0;}
.assoc-logo{display:flex;align-items:center;justify-content:center;height:104px;padding:20px;
  background:var(--bg-soft);border:1px solid var(--line);border-radius:var(--radius);}
.assoc-logo img{max-width:100%;max-height:100%;object-fit:contain;}
/* Logo que ya trae su propio fondo oscuro: celda a juego, logo completo */
.assoc-logo.assoc-logo--full{background:#3f3f42;border:none;padding:14px 18px;}
.assoc-logo.assoc-logo--full img{width:100%;height:100%;object-fit:contain;}
.assoc-body h3{font-size:22px;margin-bottom:8px;}
.assoc-body .assoc-sub{font-weight:600;color:var(--ink);margin-bottom:14px;font-size:16.5px;}
.assoc-body p{font-size:16px;color:var(--ink-2);margin:0 0 14px;}
.assoc-body .more{font-size:12px;font-weight:700;letter-spacing:.16em;text-transform:uppercase;color:var(--ink);display:inline-flex;gap:.5em;}
.assoc-body .more:hover{color:var(--ink-2);}
@media(max-width:680px){.assoc-item{grid-template-columns:1fr;gap:18px;}.assoc-logo{width:210px;max-width:100%;}}

/* Certificados */
.cert-item{display:grid;grid-template-columns:280px 1fr;gap:clamp(24px,4vw,56px);align-items:start;
  padding:clamp(30px,4vw,48px) 0;border-bottom:1px solid var(--line);}
.cert-item:first-child{padding-top:0;}
.cert-seal{display:flex;align-items:center;justify-content:center;background:var(--bg-soft);
  border:1px solid var(--line);border-radius:var(--radius);padding:24px;min-height:200px;}
.cert-seal img{max-width:100%;max-height:220px;width:auto;object-fit:contain;}
.cert-body .eyebrow{margin-bottom:14px;}
.cert-body h3{font-size:clamp(21px,2.2vw,27px);margin-bottom:14px;}
.cert-body p{font-size:16.5px;color:var(--ink-2);margin:0 0 20px;max-width:640px;}
.cert-body p a{color:var(--ink);text-decoration:underline;text-underline-offset:3px;}
.cert-downloads{display:flex;flex-direction:column;gap:8px;}
.cert-dl{display:inline-flex;align-items:center;gap:12px;padding:13px 18px;background:#fff;
  border:1px solid var(--line);border-radius:11px;font-size:14.5px;font-weight:600;color:var(--ink-2);
  transition:border-color .25s ease,transform .25s ease,color .25s ease;}
.cert-dl:hover{border-color:var(--ink);color:var(--ink);transform:translateX(3px);}
.cert-dl svg{flex-shrink:0;width:20px;height:20px;stroke:var(--muted);fill:none;stroke-width:1.6;}
.cert-dl:hover svg{stroke:var(--ink);}
.cert-dl .ext{margin-left:auto;font-size:11px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);}
@media(max-width:680px){.cert-item{grid-template-columns:1fr;gap:18px;}.cert-seal{max-width:280px;}}

/* Páginas legales / prosa larga */
.legal{max-width:820px;}
.legal .updated{font-size:13px;letter-spacing:.06em;color:var(--muted);text-transform:uppercase;font-weight:700;margin-bottom:34px;}
.legal h2{font-size:clamp(22px,2.4vw,30px);margin:44px 0 16px;}
.legal h2:first-of-type{margin-top:0;}
.legal h3{font-size:19px;margin:28px 0 10px;}
.legal p,.legal li{font-size:17px;color:var(--ink-2);line-height:1.7;}
.legal p{margin:0 0 1.1em;}
.legal ul{margin:0 0 1.2em;padding-left:1.2em;list-style:disc;}
.legal li{margin-bottom:.5em;}
.legal a{color:var(--ink);text-decoration:underline;text-underline-offset:3px;text-decoration-thickness:1px;}
.legal a:hover{color:var(--ink-2);}
.notice{display:flex;gap:14px;padding:20px 22px;background:var(--bg-soft);border:1px dashed var(--line-2);
  border-radius:var(--radius);margin:0 0 28px;font-size:15px;color:var(--ink-2);}
.notice strong{color:var(--ink);}
.legal-table{width:100%;border-collapse:collapse;margin:0 0 1.4em;font-size:16px;}
.legal-table th,.legal-table td{text-align:left;vertical-align:top;padding:13px 16px;border:1px solid var(--line);}
.legal-table th{width:200px;font-weight:700;color:var(--ink);background:var(--bg-soft);white-space:nowrap;}
.legal-table td{color:var(--ink-2);}
.legal-table a{color:var(--ink);}
@media(max-width:560px){.legal-table th{width:130px;}.legal-table th,.legal-table td{padding:10px 12px;font-size:14.5px;}}
.legal-table.cookies th{width:auto;background:var(--ink);color:#fff;white-space:nowrap;font-size:13px;letter-spacing:.04em;}
.legal-table.cookies td{font-size:15px;}
@media(max-width:680px){.legal-table.cookies{display:block;overflow-x:auto;white-space:nowrap;}}

/* Enlaces recomendados */
.links-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:18px;}
.link-row{display:flex;align-items:center;justify-content:space-between;gap:16px;
  padding:22px 26px;background:#fff;border:1px solid var(--line);border-radius:var(--radius);
  transition:border-color .25s ease,transform .25s ease;}
.link-row:hover{border-color:var(--ink);transform:translateX(3px);}
.link-row .lr-name{font-weight:700;color:var(--ink);font-size:17px;}
.link-row .lr-url{font-size:13.5px;color:var(--muted);}
.link-row .arrow{color:var(--ink);font-size:18px;}
@media(max-width:680px){.links-grid{grid-template-columns:1fr;}}

/* Artículo de noticia */
.article{max-width:820px;margin:0 auto;}
.article .back{display:inline-flex;align-items:center;gap:.5em;font-size:12.5px;font-weight:700;
  letter-spacing:.16em;text-transform:uppercase;color:var(--muted);margin-bottom:28px;transition:color .2s ease;}
.article .back:hover{color:var(--ink);}
.article-figure{border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow);
  background:var(--bg-soft);margin:0 0 clamp(32px,5vw,52px);aspect-ratio:16/9;}
.article-figure img{width:100%;height:100%;object-fit:cover;}
.article-figure--contain img{object-fit:contain;padding:clamp(18px,4vw,40px);}
.article-figure--contain.bg-dark{background:#1f3a5f;}
.article-figure--contain.bg-light{background:#fff;}
.article-body{max-width:760px;}
.article-body p{font-size:18px;color:var(--ink-2);line-height:1.7;margin:0 0 1.2em;}
.article-body h2{font-size:clamp(22px,2.4vw,28px);margin:38px 0 14px;}
.article-body strong{color:var(--ink);font-weight:700;}
.article-body a{color:var(--ink);text-decoration:underline;text-underline-offset:3px;text-decoration-thickness:1px;}
.article-body a:hover{color:var(--ink-2);}
.article-source{margin-top:40px;padding-top:24px;border-top:1px solid var(--line);}
.article-meta{display:flex;align-items:center;gap:14px;flex-wrap:wrap;margin-bottom:18px;}
.article-meta .cat{font-size:12px;font-weight:700;letter-spacing:.18em;text-transform:uppercase;
  color:var(--ink);border:1.5px solid var(--ink);border-radius:999px;padding:6px 16px;}
.article-meta .date{font-size:13px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);}

/* Cifras (compartido) */
.stats{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(24px,3vw,40px);
  padding-top:44px;border-top:1px solid var(--line-2);}
.stats.cols-4{grid-template-columns:repeat(4,1fr);}
.stat .num{font-size:clamp(46px,6vw,78px);font-weight:800;letter-spacing:-.04em;color:var(--ink);line-height:1;}
.stat .num em{font-style:normal;font-size:.5em;font-weight:700;vertical-align:baseline;}
.stat .lbl{margin-top:16px;color:var(--ink-2);font-size:16px;max-width:280px;}
.cifras-intro{max-width:780px;margin-bottom:clamp(36px,5vw,56px);}
.cifras-intro p{font-size:20px;color:var(--ink-2);}
@media(max-width:900px){.stats.cols-4{grid-template-columns:repeat(2,1fr);gap:34px;}}
@media(max-width:760px){.stats{grid-template-columns:1fr;gap:34px;}}
@media(max-width:520px){.stats.cols-4{grid-template-columns:1fr;}}

/* ---------- Banner de consentimiento de cookies ---------- */
.cookie-banner{position:fixed;left:0;right:0;bottom:0;z-index:55;
  width:100%;max-width:100%;overflow:hidden;
  padding:0 16px 16px;pointer-events:none;
  transform:translateY(120%);transition:transform .4s cubic-bezier(.2,.7,.2,1);}
.cookie-banner.open{transform:none;pointer-events:auto;}
.cookie-banner-inner{max-width:var(--container-wide);margin:0 auto;
  background:#fff;border:1px solid var(--line);border-radius:var(--radius);
  box-shadow:0 24px 60px -24px rgba(20,20,20,.4);
  padding:20px 24px;display:flex;align-items:center;gap:24px;flex-wrap:wrap;justify-content:space-between;}
.cookie-banner-text{flex:1;min-width:0;}
.cookie-banner-text strong{display:block;font-size:12.5px;letter-spacing:.18em;text-transform:uppercase;margin-bottom:5px;color:var(--ink);}
.cookie-banner-text p{margin:0;font-size:14.5px;line-height:1.5;color:var(--ink-2);max-width:760px;}
.cookie-banner-text a{color:var(--ink);text-decoration:underline;text-underline-offset:2px;}
.cookie-banner-actions{display:flex;gap:12px;flex-shrink:0;}
.cookie-banner-actions .btn{padding:12px 28px;}
@media(max-width:560px){
  .cookie-banner-inner{padding:16px;gap:12px;flex-wrap:wrap;}
  .cookie-banner-text{min-width:0;width:100%;}
  .cookie-banner-actions{width:100%;}
  .cookie-banner-actions .btn{flex:1;justify-content:center;text-align:center;}
}
/* Enlace «Configurar cookies» del pie */
.footer-bottom .f-legal-btn{background:none;border:none;padding:0;margin:0;cursor:pointer;
  font:inherit;color:#8b909a;}
.footer-bottom .f-legal-btn:hover{color:#fff;}
