/* ===== FUENTES LOCALES =====
 * Descargadas de Google Fonts (Alike v22, Open Sans v44).
 * Solo subsets latin + latin-ext (suficientes para español/peruano).
 * Open Sans es fuente variable: un archivo cubre pesos 400-700.
 */
@font-face {
  font-family: 'Alike';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url('fonts/alike-latin-ext.woff2') format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
@font-face {
  font-family: 'Alike';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url('fonts/alike-latin.woff2') format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
@font-face {
  font-family: 'Open Sans';
  font-style: normal;
  font-weight: 400 700;
  font-stretch: 100%;
  font-display: swap;
  src: url('fonts/open-sans-latin-ext.woff2') format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
@font-face {
  font-family: 'Open Sans';
  font-style: normal;
  font-weight: 400 700;
  font-stretch: 100%;
  font-display: swap;
  src: url('fonts/open-sans-latin.woff2') format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}

/*
 * Midinerope — Global Styles (Tipo A)
 * Vive en: assets/styles.css (junto a 00-MIDINEROPE-MAESTRO.md, index.html, planificador.html)
 * Sincronizado con el maestro v2.1 (Mayo 2026).
 * Referencia canónica Tipo A: index.html · Tipo B: planificador.html (carga también stylesherramienta.css).
 * Tokens, jerarquía de conflictos y reglas técnicas: ver 00-MIDINEROPE-MAESTRO.md §2, §3 y §10.4.
 */
:root{
  --gold:#FFC300; --gold-dark:#D4A000; --gold-light:#FFD700; --gold-very-light:#FFF8DC;
  --gold-dim:rgba(255,195,0,.08);
  --ink:#1A1A1A; --ink-2:#0F0F0F; --muted:#444; --light:#999;
  --white:#fff; --cream:#FAFAF7; --off:#F5F2EA; --section-alt:#EEECEA;
  --gold-line:rgba(255,195,0,.15); --gold-line-strong:rgba(255,195,0,.35);
  --shadow-light:0 2px 8px rgba(0,0,0,.04);
  --shadow-card:0 4px 32px rgba(0,0,0,.06);
  --shadow-gold:0 8px 24px rgba(255,195,0,.25);
  --shadow-gold-lg:0 16px 56px rgba(255,195,0,.20);
  --shadow-gold-hover:0 12px 36px rgba(255,195,0,.18);
  --ff-title:'Alike',Georgia,serif;
  --ff-body:'Open Sans',-apple-system,BlinkMacSystemFont,sans-serif;
  --nav-h:72px; --rad:16px; --rad-sm:8px; --rad-md:12px; --rad-lg:24px; --rad-xl:32px; --rad-pill:50px;
  --T:.28s cubic-bezier(.4,0,.2,1);
  --grid:linear-gradient(rgba(255,195,0,.14) 1px,transparent 1px),linear-gradient(90deg,rgba(255,195,0,.14) 1px,transparent 1px);
  --grid-dark:linear-gradient(rgba(255,195,0,.045) 1px,transparent 1px),linear-gradient(90deg,rgba(255,195,0,.045) 1px,transparent 1px);
  --grid-size:32px 32px;
}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;font-size:16px}
body{font-family:var(--ff-body);background:var(--cream);color:var(--ink);overflow-x:hidden;padding-top:var(--nav-h);-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}
::selection{background:var(--gold);color:var(--ink)}
::-webkit-scrollbar{width:8px}
::-webkit-scrollbar-track{background:var(--cream)}
::-webkit-scrollbar-thumb{background:var(--gold);border-radius:4px}
.container{max-width:1120px;margin:0 auto;padding:0 32px}

/* Typography */
h1,h2,h3,h4{font-family:var(--ff-title);font-weight:700;letter-spacing:-.01em}
em.gold{font-style:normal;color:var(--gold-dark);font-weight:700}

/* ===== NAV ===== */
#nav{position:fixed;top:0;left:0;right:0;z-index:100;height:var(--nav-h);
  background:rgba(255,255,255,.85);backdrop-filter:blur(20px) saturate(180%);
  border-bottom:1px solid transparent;transition:all var(--T)}
#nav.scrolled{background:rgba(255,255,255,.96);border-bottom-color:var(--gold-line);box-shadow:0 4px 24px rgba(0,0,0,.04)}
.nav-inner{max-width:1120px;margin:0 auto;padding:0 32px;height:100%;display:flex;align-items:center;justify-content:space-between;gap:24px}
.nav-logo{display:flex;align-items:center;gap:12px;text-decoration:none}
.nav-logo img{width:38px;height:38px;border-radius:50%}
.nav-logo-text{font-family:var(--ff-title);font-size:1.2rem;color:var(--ink);letter-spacing:.08em;font-weight:500;text-transform:uppercase}
.nav-links{display:flex;align-items:center;gap:2px;list-style:none}
.nav-links a{color:var(--muted);text-decoration:none;font-size:.86rem;font-weight:500;padding:9px 16px;border-radius:10px;transition:all var(--T)}
.nav-links a:hover,.nav-links a.active{color:var(--ink);background:rgba(255,195,0,.12)}
.nav-links a.active{color:var(--gold-dark);font-weight:700}
.nav-cta{background:var(--ink) !important;color:var(--gold) !important;font-weight:600 !important;padding:10px 22px !important;border-radius:var(--rad-pill) !important;display:inline-flex;align-items:center;gap:6px}
.nav-cta:hover{background:var(--gold-dark) !important;color:var(--ink) !important;transform:translateY(-1px);box-shadow:var(--shadow-gold)}
.hamburger{display:none;flex-direction:column;gap:5px;cursor:pointer;padding:8px;background:none;border:none}
.hamburger span{display:block;width:22px;height:2px;background:var(--ink);border-radius:2px;transition:all var(--T)}
.mobile-menu{display:none;position:fixed;top:var(--nav-h);left:0;right:0;background:rgba(255,255,255,.98);backdrop-filter:blur(16px);padding:20px;border-bottom:1px solid var(--gold-line-strong);z-index:99;flex-direction:column;gap:4px}
.mobile-menu.open{display:flex}
.mobile-menu a{color:var(--muted);text-decoration:none;font-size:1rem;font-weight:500;padding:13px 16px;border-radius:10px;transition:all var(--T);display:block}
.mobile-menu a:hover{color:var(--ink);background:rgba(255,195,0,.1)}
.mobile-menu .m-cta{background:var(--gold);color:var(--ink);font-weight:700;text-align:center;margin-top:8px;border-radius:var(--rad-pill)}
@supports not (backdrop-filter:blur(1px)){
  #nav{background:rgba(255,255,255,.98)}
  .mobile-menu{background:rgba(255,255,255,.98)}
}
@media(max-width:880px){.nav-links{display:none}.hamburger{display:flex}}

/* ===== TAG / EYEBROW ===== */
.tag{display:inline-flex;align-items:center;gap:8px;background:rgba(255,195,0,.1);
  box-shadow:0 0 0 2px var(--gold);color:var(--gold-dark);
  font-size:.7rem;letter-spacing:.18em;text-transform:uppercase;font-weight:600;
  padding:5px 14px;border-radius:var(--rad-pill);margin-bottom:20px;width:fit-content}
.tag .dot{width:6px;height:6px;background:var(--gold);border-radius:50%;animation:pulse 2s infinite}
.tag.on-dark{background:rgba(255,195,0,.12);color:var(--gold);box-shadow:0 0 0 2px var(--gold)}
.tag.on-gold{background:rgba(0,0,0,.08);box-shadow:0 0 0 2px rgba(0,0,0,.18);color:rgba(0,0,0,.7)}
@keyframes pulse{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.3;transform:scale(.6)}}

/* ===== BUTTONS ===== */
.btn{display:inline-flex;align-items:center;gap:10px;padding:14px 28px;border-radius:var(--rad-pill);
  font-family:var(--ff-body);font-size:.88rem;font-weight:600;letter-spacing:.01em;
  cursor:pointer;text-decoration:none;transition:all var(--T);border:2px solid transparent;white-space:nowrap}
.btn .arr{transition:transform var(--T);color:var(--gold)}
.btn:hover .arr{transform:translateX(4px)}
.btn-primary{background:var(--ink);color:var(--gold);border-color:var(--ink)}
.btn-primary:hover{background:var(--gold);color:var(--ink);border-color:var(--gold);transform:translateY(-2px);box-shadow:var(--shadow-gold)}
.btn-gold{background:var(--gold);color:var(--ink);border-color:var(--gold)}
.btn-gold:hover{background:var(--gold-dark);transform:translateY(-2px);box-shadow:var(--shadow-gold)}
.btn-outline{background:transparent;color:var(--ink);border-color:var(--ink)}
.btn-outline:hover{background:var(--ink);color:var(--gold);transform:translateY(-2px)}
.btn-outline-gold{background:transparent;color:var(--gold);border-color:rgba(255,195,0,.4)}
.btn-outline-gold:hover{background:var(--gold);color:var(--ink);border-color:var(--gold);transform:translateY(-2px)}
.btn-outline-white{background:transparent;color:#fff;border:2px solid rgba(255,255,255,.35)}
.btn-outline-white:hover{background:rgba(255,255,255,.08);border-color:rgba(255,255,255,.6);transform:translateY(-2px)}

/* ===== HERO ===== */
.hero{position:relative;padding:32px 0 64px;overflow:hidden;
  background:var(--white);
  background-image:var(--grid);background-size:var(--grid-size)}
.hero::before{content:'';position:absolute;inset:0;
  background:radial-gradient(ellipse 60% 70% at 75% 20%,rgba(255,195,0,.10),transparent 60%),
             radial-gradient(ellipse 40% 50% at 5% 90%,rgba(255,195,0,.06),transparent 60%);
  pointer-events:none}
.hero-inner{position:relative;z-index:2;display:grid;grid-template-columns:1.15fr .85fr;gap:64px;align-items:start}
.hero-left h1{font-size:clamp(2.4rem,4.5vw,4rem);line-height:1.18;color:var(--ink);margin:24px 0 24px;letter-spacing:-.02em}
.hero-left h1 em{font-style:normal;color:var(--gold-dark);font-weight:700;display:block}
.hero-lead{font-size:1.00rem;color:var(--muted);line-height:1.7;max-width:520px;margin-bottom:36px}

/* Hero visual */
.hero-visual{position:relative;display:flex;justify-content:center;align-items:center;overflow:hidden}
.coin-stack{position:relative;width:100%;max-width:440px;aspect-ratio:1;display:flex;align-items:center;justify-content:center}
.coin{position:absolute;border-radius:50%;display:flex;align-items:center;justify-content:center}
.coin-big{width:78%;height:78%;background:radial-gradient(circle at 30% 30%,#FFE066,var(--gold) 45%,var(--gold-dark) 100%);
  box-shadow:0 30px 80px rgba(255,195,0,.45),inset 0 -20px 60px rgba(0,0,0,.18),inset 0 20px 40px rgba(255,255,255,.4);
  animation:rollCoin 15s linear infinite;will-change:transform}
.coin-big::before{content:'';position:absolute;inset:14px;border-radius:50%;border:2px dashed rgba(0,0,0,.18)}
.coin-big::after{content:'';position:absolute;inset:34px;border-radius:50%;border:1px solid rgba(0,0,0,.15)}
.coin-logo{position:relative;width:50%;height:50%;border-radius:50%;overflow:hidden;box-shadow:inset 0 0 0 4px rgba(0,0,0,.1)}
.coin-logo img{width:100%;height:100%;object-fit:cover}
@keyframes rollCoin{
  0%{transform:translateX(180%) rotate(720deg)}
  33%{transform:translateX(0) rotate(0deg)}
  67%{transform:translateX(0) rotate(0deg)}
  100%{transform:translateX(-180%) rotate(-720deg)}
}
@media(prefers-reduced-motion:reduce){
  .coin{animation:none}
}

/* ===== AUDIENCE SLIDER ===== */
.aud{position:relative;display:inline-flex;background:var(--gold);border:1px solid var(--gold-dark);border-radius:var(--rad-pill);padding:6px;gap:4px}
.aud-btn{display:inline-flex;align-items:center;gap:8px;padding:8px 20px;background:transparent;border:none;border-radius:var(--rad-pill);font-size:.86rem;font-weight:600;color:var(--ink);cursor:pointer;transition:color .2s ease;z-index:2;position:relative}
.aud-btn.active{color:var(--ink)}
.aud-slider{position:absolute;top:6px;bottom:6px;background:var(--gold-dark);border-radius:var(--rad-pill);box-shadow:var(--shadow-gold);transition:left 0.2s ease, width 0.2s ease;z-index:1}
.aud:has(#tabB2B.active) .aud-slider{background:var(--ink);box-shadow:none}
.aud:has(#tabB2B.active) #tabB2B{color:var(--gold)}



/* ===== SECTION BASICS ===== */
.section{padding:64px 0;position:relative}
/* Separador dorado automático en el tope de cada sección (no aplica al Hero ni a .gold-bg que ya usa ::before para su grid oscuro) */
.section:not(.gold-bg)::before{
  content:'';
  position:absolute;
  top:0;
  left:50%;
  transform:translateX(-50%);
  width:80%;
  max-width:1056px;
  height:2px;
  background:linear-gradient(90deg,transparent,rgba(255,195,0,.6),transparent);
  pointer-events:none;
  z-index:1
}
/* Sección dorada (Herramientas) usa border-top oscuro como separador (su ::before está ocupado por el grid) */
.section.gold-bg{border-top:1px solid rgba(0,0,0,.12)}
.section.grid-bg{background-image:var(--grid);background-size:var(--grid-size);background-color:var(--cream)}
.section.grid-bg-alt{background-image:var(--grid);background-size:var(--grid-size);background-color:var(--off)}
.section.dark{background-color:var(--ink);background-image:var(--grid-dark);background-size:var(--grid-size);color:var(--white)}
.section.dark h2,.section.dark h3,.section.dark h4{color:var(--white)}
.section.dark .section-sub{color:rgba(255,255,255,.6)}
.section-head{text-align:center;max-width:680px;margin:0 auto 56px}
.section-head.left{text-align:left;margin:0 0 56px}
.section-head h2{font-size:clamp(2.2rem,4vw,3.6rem);line-height:1.12;margin:18px 0 16px;letter-spacing:-.015em;font-weight:700}
.section-head.on-dark h2{color:var(--white)}
.section-head.on-dark .section-sub{color:rgba(255,255,255,.55)}
.section-sub{font-size:1.00rem;color:var(--muted);line-height:1.7;max-width:560px;margin:0 auto}
.section-head.left .section-sub{margin:0}

/* ===== PARA TI ===== */
#paraTi .section-head{margin-bottom:28px}
.parati-grid{display:grid;grid-template-columns:1fr 1.15fr 1fr;gap:20px;align-items:stretch}
.parati-card{background:var(--white);border:2px solid var(--gold-line-strong);border-radius:var(--rad-xl);padding:28px 24px 24px;position:relative;overflow:hidden;display:flex;flex-direction:column;gap:0;text-align:center;align-items:center;transition:transform var(--T),box-shadow var(--T),border-color var(--T)}
.parati-card::before{content:'';position:absolute;top:0;left:32px;right:32px;height:2px;background:linear-gradient(90deg,transparent,var(--gold),transparent);opacity:0;transition:opacity var(--T)}
.parati-card:hover{transform:translateY(-6px);box-shadow:0 24px 60px rgba(255,195,0,.12);border-color:var(--gold-line-strong)}
.parati-card:hover::before{opacity:1}
.parati-card-icon{width:44px;height:44px;border-radius:16px;background:rgba(255,195,0,.1);border:1px solid var(--gold-line-strong);display:flex;align-items:center;justify-content:center;color:var(--gold-dark);margin-bottom:18px;flex-shrink:0}
.parati-card-title{font-family:var(--ff-title);font-size:clamp(1.05rem,1.5vw,1.2rem);color:var(--ink);line-height:1.25;letter-spacing:-.01em;margin-bottom:12px;font-weight:700}
.parati-card-body{font-size:.88rem;color:var(--muted);line-height:1.65;flex:1;margin-bottom:20px}
.parati-card--featured{background:var(--ink);border-color:rgba(255,195,0,.25)}
.parati-card--featured::before{background:linear-gradient(90deg,transparent,var(--gold),transparent)}
.parati-card--featured:hover{box-shadow:0 28px 70px rgba(0,0,0,.35);border-color:var(--gold-line-strong);transform:translateY(-6px)}
.parati-featured-bg{position:absolute;width:340px;height:340px;border-radius:50%;background:radial-gradient(circle,rgba(255,195,0,.08),transparent 70%);top:-80px;right:-80px;pointer-events:none}
.parati-card-icon--dark{background:rgba(255,195,0,.12);border-color:rgba(255,195,0,.3);color:var(--gold)}
.parati-card-title--light{color:#ffffff}
.parati-card-body--light{color:rgba(255,255,255,.6)}
@media(max-width:960px){
  .parati-grid{grid-template-columns:1fr 1fr}
  .parati-card--featured{grid-column:1/-1;flex-direction:row;gap:32px}
  .parati-card--featured .parati-card-body{margin-bottom:0}
  .parati-card--featured>*:not(.parati-featured-bg){position:relative;z-index:1}
}
@media(max-width:640px){
  .parati-grid{grid-template-columns:1fr}
  .parati-card--featured{flex-direction:column;gap:0}
}

/* ===== EMPRESAS ===== */
#empresas h2{font-size:clamp(2.1rem,4vw,3rem);line-height:1.12;margin:18px 0 18px;letter-spacing:-.015em}
#empresas h2 em{color:var(--gold)}
#empresas .section-sub{margin:0;font-size:.94rem}
.emp-grid{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:start}
.emp-visual{position:relative;justify-self:center;padding-top:0;align-self:center;display:flex;align-items:center;justify-content:center}
.emp-card{background:rgba(255,255,255,.04);border:1px solid var(--gold-line-strong);border-radius:var(--rad-xl);padding:32px;backdrop-filter:blur(10px);position:relative;overflow:hidden;display:flex;align-items:center;justify-content:center;min-height:280px;max-width:420px}
.emp-card::before{content:'';position:absolute;top:0;left:30px;right:30px;height:2px;background:linear-gradient(90deg,transparent,var(--gold),transparent)}
.emp-chart{width:100%;max-width:400px;margin:0 auto;display:block}
.emp-chart svg{width:100%;height:auto;display:block;filter:drop-shadow(0 6px 24px rgba(255,195,0,.25))}
.emp-bar{transform-origin:bottom center;transform:scaleY(0)}
.emp-trend{stroke-dasharray:260;stroke-dashoffset:260}
.emp-arrow{opacity:0}
.chart-animated .emp-bar{animation:barGrow 1.4s cubic-bezier(.4,0,.2,1) both}
.chart-animated .emp-bar-1{animation-delay:.05s}
.chart-animated .emp-bar-2{animation-delay:.2s}
.chart-animated .emp-bar-3{animation-delay:.35s}
.chart-animated .emp-bar-4{animation-delay:.5s}
.chart-animated .emp-trend{animation:drawLine 1.4s cubic-bezier(.4,0,.2,1) .8s forwards}
.chart-animated .emp-arrow{animation:fadeArrow .4s ease .65s forwards}
@keyframes barGrow{from{transform:scaleY(0)}to{transform:scaleY(1)}}
@keyframes drawLine{to{stroke-dashoffset:0}}
@keyframes fadeArrow{to{opacity:1}}
.check-list{list-style:none;display:flex;flex-direction:column;gap:18px;margin:32px 0}
.check-list li{position:relative;padding-left:42px;color:rgba(255,255,255,.85);font-size:0.94rem;line-height:1.55}
.check-list .ck{position:absolute;left:0;top:0;width:28px;height:28px;border-radius:50%;background:var(--gold);display:flex;align-items:center;justify-content:center;box-shadow:0 0 0 4px rgba(255,195,0,.18)}
.check-list .ck svg{width:14px;height:14px;color:var(--ink);stroke-width:3.5}
@media(max-width:960px){.emp-grid{grid-template-columns:1fr;gap:48px}}

/* ── Catálogo cerrado (Más servicios) ── */
.catalogo-wrap{
  display:grid;grid-template-columns:1.1fr 1fr;gap:64px;align-items:center
}
.catalogo-title{
  font-family:var(--ff-title);font-size:clamp(2rem,3.8vw,3rem);
  line-height:1.1;color:var(--ink);margin:0 0 20px;letter-spacing:-.02em
}
.catalogo-title .ink-italic{font-style:italic;color:var(--ink);position:relative}
.catalogo-title .ink-italic::after{
  content:'';position:absolute;left:0;right:0;bottom:4px;height:10px;
  background:rgba(0,0,0,.12);z-index:-1
}
.catalogo-sub{
  font-size:1rem;color:rgba(0,0,0,.7);line-height:1.7;
  max-width:480px;margin-bottom:32px
}
.btn-dark{
  background:var(--ink);color:var(--gold);border:1px solid var(--ink);
  display:inline-flex;align-items:center;gap:10px;
  padding:14px 26px;border-radius:var(--rad-pill);
  font-weight:600;text-decoration:none;transition:all var(--T)
}
.btn-dark:hover{background:var(--gold);color:var(--ink);border-color:var(--ink)}
.btn-dark .arr{transition:transform var(--T)}
.btn-dark:hover .arr{transform:translateX(3px)}

.catalogo-hints{
  display:grid;grid-template-columns:repeat(2,1fr);gap:12px
}
.catalogo-hint{
  display:flex;align-items:center;gap:14px;
  background:rgba(0,0,0,.04);border:1px solid rgba(0,0,0,.08);
  border-radius:var(--rad-lg);padding:16px 18px;
  transition:all var(--T)
}
.catalogo-hint:hover{background:rgba(0,0,0,.07);border-color:rgba(0,0,0,.15)}
.catalogo-hint-num{
  font-family:var(--ff-title);font-size:1.1rem;font-weight:700;
  color:var(--ink);opacity:.45;flex-shrink:0;min-width:24px
}
.catalogo-hint-text{
  font-size:.88rem;color:var(--ink);font-weight:500;line-height:1.35
}
.catalogo-hint--more{
  background:var(--ink);border-color:var(--ink)
}
.catalogo-hint--more .catalogo-hint-num{color:var(--gold);opacity:1}
.catalogo-hint--more .catalogo-hint-text{color:var(--gold)}

@media(max-width:900px){
  .catalogo-wrap{grid-template-columns:1fr;gap:40px}
  .catalogo-hints{grid-template-columns:1fr}
}

/* ===== HERRAMIENTAS ===== */
.section.gold-bg{background:linear-gradient(145deg,#FFC300,#FFD700 40%,#F5B800 70%,#E6A800);position:relative;overflow:hidden}
.section.gold-bg::before{content:'';position:absolute;inset:0;background-image:linear-gradient(rgba(0,0,0,.05) 1px,transparent 1px),linear-gradient(90deg,rgba(0,0,0,.05) 1px,transparent 1px);background-size:var(--grid-size);pointer-events:none}
.section.gold-bg::after{content:'';position:absolute;width:640px;height:640px;border-radius:50%;background:radial-gradient(circle,rgba(255,255,255,.22),transparent 65%);top:-180px;right:-140px;pointer-events:none}
.section.gold-bg .container{position:relative;z-index:1}
.section.gold-bg h2{color:var(--ink)}
.section.gold-bg .section-sub{color:rgba(0,0,0,.65)}
.hub{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.hub-card{background:var(--white);border:1px solid rgba(0,0,0,.08);border-radius:var(--rad-lg);padding:40px 32px 32px;text-decoration:none;color:inherit;transition:all var(--T);position:relative;overflow:hidden;display:flex;flex-direction:column;min-height:280px;text-align:center;align-items:center}
.hub-card::before{content:'';position:absolute;top:0;left:32px;right:32px;height:2px;background:linear-gradient(90deg,transparent,var(--ink),transparent);opacity:0;transition:opacity var(--T)}
.hub-card:hover{transform:translateY(-6px);box-shadow:0 24px 60px rgba(0,0,0,.18)}
.hub-card:hover::before{opacity:.7}
.hub-tag{font-size:.68rem;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--gold-dark);margin-bottom:16px}
.hub-card h3{font-family:var(--ff-title);font-size:1.42rem;color:var(--ink);line-height:1.35;margin-bottom:28px;flex:1;font-weight:700}
.hub-tool{display:flex;align-items:center;gap:14px;padding-top:22px;border-top:1px dashed rgba(0,0,0,.12)}
.hub-tool-icon{width:40px;height:40px;border-radius:10px;background:var(--ink);color:var(--gold);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.hub-tool-icon svg{width:20px;height:20px}
.hub-tool-meta{flex:1;min-width:0}
.hub-tool-name{font-family:var(--ff-body);color:var(--ink);font-size:1.02rem;line-height:1.2;margin-top:2px;font-weight:500}
.hub-arrow{color:var(--gold);transition:transform var(--T)}
.hub-card:hover .hub-arrow{transform:translateX(4px)}

/* ===== HUB CARDS (dark) ===== */
.hub-flip{display:flex;flex-direction:column;align-items:center;text-align:center;padding:28px 24px 24px;background:var(--ink);border:1px solid rgba(255,195,0,.2);border-radius:var(--rad-lg);min-height:320px}
.hub-flip h3{font-family:var(--ff-title);font-size:1.35rem;color:var(--white);line-height:1.3;font-weight:700;margin:8px 0 0}
.hub-flip-chart{flex:1;display:flex;align-items:center;justify-content:center;width:100%;padding:12px 0}
/* Bar animation */
.hub-flip-bar{transform-box:fill-box;transform-origin:bottom;transform:scaleY(0);animation:hubBarGrow .65s cubic-bezier(.4,0,.2,1) both}
.hub-flip-bar:nth-child(1){animation-delay:0s}
.hub-flip-bar:nth-child(2){animation-delay:.08s}
.hub-flip-bar:nth-child(3){animation-delay:.16s}
.hub-flip-bar:nth-child(4){animation-delay:.24s}
.hub-flip-bar:nth-child(5){animation-delay:.32s}
@keyframes hubBarGrow{from{transform:scaleY(0)}to{transform:scaleY(1)}}
/* Wave animation */
.hub-flip-wave{stroke-dasharray:500;stroke-dashoffset:500;animation:hubWaveDraw 1.1s cubic-bezier(.4,0,.2,1) .2s forwards}
@keyframes hubWaveDraw{to{stroke-dashoffset:0}}
/* Arc animation */
.hub-flip-arc{opacity:0;animation:hubArcFade .45s ease forwards}
.hub-flip-arc:nth-child(2){animation-delay:.1s}
.hub-flip-arc:nth-child(3){animation-delay:.3s}
.hub-flip-arc:nth-child(4){animation-delay:.5s}
@keyframes hubArcFade{to{opacity:1}}
@media(prefers-reduced-motion:reduce){
  .hub-flip-bar{animation:none;transform:scaleY(1)}
  .hub-flip-arc{animation:none;opacity:1}
  .hub-flip-wave{animation:none;stroke-dashoffset:0}
}
@media(max-width:880px){.hub-flip{min-height:280px}}
@media(max-width:880px){.hub{grid-template-columns:1fr}}

/* ===== PROPÓSITO ===== */
.purposes{display:grid;grid-template-columns:repeat(5,1fr);gap:18px}
.purpose{background:var(--white);border:2px solid var(--gold-line-strong);border-radius:var(--rad-lg);padding:30px 22px;transition:all var(--T);position:relative;overflow:hidden;text-align:center}
.purpose::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,transparent,var(--gold),transparent);opacity:0;transition:opacity var(--T)}
.purpose:hover{border-color:var(--gold-line-strong);transform:translateY(-4px);box-shadow:0 14px 36px rgba(255,195,0,.12)}
.purpose:hover::before{opacity:1}
.purpose-icon{width:48px;height:48px;border-radius:14px;background:rgba(255,195,0,.1);border:1px solid var(--gold-line-strong);display:flex;align-items:center;justify-content:center;color:var(--gold-dark);margin:0 auto 20px}
.purpose-icon svg{width:22px;height:22px}
.purpose h4{font-size:1rem;color:var(--ink);line-height:1.3;margin-bottom:8px}
.purpose p{font-size:.84rem;color:var(--muted);line-height:1.6}
@media(max-width:1024px){.purposes{grid-template-columns:repeat(3,1fr)}}
@media(max-width:640px){.purposes{grid-template-columns:1fr 1fr}}

/* ===== WAITLIST ===== */
.wl{position:relative;overflow:hidden;background:linear-gradient(160deg,#0A0A0A,#141007 50%,#0A0A0A)}
.wl::before{content:'';position:absolute;inset:0;background-image:var(--grid-dark);background-size:var(--grid-size);pointer-events:none}
.wl-orb{position:absolute;border-radius:50%;filter:blur(80px);pointer-events:none}
.wl-orb-1{width:480px;height:480px;background:rgba(255,195,0,.08);top:-120px;left:-100px;animation:orbDrift 10s ease-in-out infinite}
.wl-orb-2{width:340px;height:340px;background:rgba(255,195,0,.05);bottom:-80px;right:-60px;animation:orbDrift 12s ease-in-out infinite reverse}
@keyframes orbDrift{0%,100%{transform:translate(0,0)}50%{transform:translate(20px,-20px)}}
.wl-inner{max-width:640px;margin:0 auto;text-align:center;position:relative;z-index:2;padding:0 24px}
.wl h2{color:#fff;font-size:clamp(2.2rem,4vw,3.6rem);line-height:1.12;margin:18px 0 18px;letter-spacing:-.015em}
.wl-topics{display:flex;flex-wrap:wrap;gap:8px;justify-content:center;margin:0 auto 28px}
.wl-topic{cursor:pointer}
.wl-topic input{position:absolute;opacity:0;width:1px;height:1px;overflow:hidden}
.wl-topic span{display:inline-flex;align-items:center;padding:6px 16px;border-radius:var(--rad-pill);border:1px solid rgba(255,255,255,.25);color:rgba(255,255,255,.65);font-size:.68rem;font-weight:700;letter-spacing:.14em;text-transform:uppercase;transition:all var(--T);cursor:pointer;user-select:none}
.wl-topic span:hover{border-color:rgba(255,195,0,.6);color:var(--gold)}
.wl-topic input:checked + span{background:var(--gold);color:var(--ink);border-color:var(--gold)}
.wl-topic input:focus-visible + span{outline:3px solid var(--gold);outline-offset:3px}
.wl h2 em{font-style:normal;color:var(--gold);font-weight:700}
.wl-sub{color:rgba(255,255,255,.6);font-size:1.04rem;line-height:1.75;max-width:520px;margin:0 auto 36px}
.wl-counter{display:inline-flex;align-items:center;gap:24px;background:rgba(255,255,255,.04);border:1px solid var(--gold-line-strong);border-radius:var(--rad-pill);padding:10px 22px;margin-bottom:36px}
.wl-avatars{display:flex}
.wl-av{width:30px;height:30px;border-radius:50%;background:linear-gradient(135deg,var(--gold),var(--gold-dark));display:flex;align-items:center;justify-content:center;font-family:var(--ff-title);font-size:.78rem;color:var(--ink);font-weight:600;border:2px solid #0F0F0F;margin-left:-8px}
.wl-av:first-child{margin-left:0}
.wl-counter-text{font-size:.86rem;color:rgba(255,255,255,.7)}
.wl-counter-text strong{color:var(--gold);font-weight:700}
.wl-form-wrap{background:rgba(255,255,255,.04);border:1px solid var(--gold-line-strong);border-radius:var(--rad-xl);padding:32px;margin-bottom:20px}
.wl-form{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:18px}
.wl-form input[type=email]{flex:1;min-width:220px;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.1);border-radius:var(--rad-pill);padding:14px 22px;color:#fff;font-family:var(--ff-body);font-size:.94rem;outline:none;transition:all var(--T)}
.wl-form input::placeholder{color:rgba(255,255,255,.35)}
.wl-form input:focus{border-color:var(--gold);background:rgba(255,195,0,.06)}
.wl-form button{background:var(--gold);color:var(--ink);border:0;border-radius:var(--rad-pill);padding:14px 28px;font-family:var(--ff-body);font-size:.9rem;font-weight:700;cursor:pointer;transition:all var(--T);display:inline-flex;align-items:center;gap:8px;letter-spacing:.02em}
.wl-form button:hover{background:var(--gold-dark);transform:translateY(-2px);box-shadow:var(--shadow-gold)}
.consent{display:flex;align-items:flex-start;gap:10px;text-align:left;font-size:.78rem;color:rgba(255,255,255,.55);line-height:1.5}
.consent input{margin-top:3px;accent-color:var(--gold)}
.consent a{color:var(--gold);text-decoration:underline}
.wl-note{font-size:.78rem;color:rgba(255,255,255,.6);margin-top:14px}

/* ===== FOOTER ===== */
footer{background:#0F0F0F;color:rgba(255,255,255,.55);position:relative;background-image:var(--grid-dark);background-size:var(--grid-size);border-top:1px solid var(--gold-line)}
.footer-top{max-width:1120px;margin:0 auto;padding:40px 32px 28px;display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:48px}
.footer-brand{display:flex;align-items:center;gap:10px;margin-bottom:12px}
.footer-brand img{width:36px;height:36px;border-radius:50%;object-fit:cover}
.footer-brand span{font-family:var(--ff-title);font-size:1.05rem;color:var(--gold);letter-spacing:.14em;text-transform:uppercase}
.footer-tag{font-size:.83rem;color:rgba(255,255,255,.55);line-height:1.4;max-width:300px;margin-bottom:12px}
.footer-social{display:flex;gap:10px}
.footer-social a{width:38px;height:38px;border-radius:12px;background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.08);display:flex;align-items:center;justify-content:center;color:rgba(255,255,255,.4);transition:all var(--T)}
.footer-social a:hover{background:rgba(255,195,0,.12);border-color:var(--gold-line-strong);color:var(--gold)}
.footer-social svg{width:16px;height:16px}
.footer-col h5{font-size:.67rem;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:rgba(255,255,255,.4);margin-bottom:14px}
.footer-col ul{list-style:none;display:flex;flex-direction:column;gap:6px}
.footer-col a{color:rgba(255,255,255,.72);text-decoration:none;font-size:.83rem;transition:color var(--T);padding:2px 0}
.footer-col a:hover{color:var(--gold)}
.footer-bottom{max-width:1120px;margin:0 auto;padding:12px 32px;border-top:1px solid rgba(255,255,255,.06);display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:12px;flex-direction:column;text-align:center;font-size:.71rem;color:rgba(255,255,255,.65)}
.footer-copy{font-size:.71rem;color:rgba(255,255,255,.6)}
.heart{color:#e63946}
@media(max-width:1024px){.footer-top{grid-template-columns:2fr 1fr 1fr 1fr;gap:32px}}
@media(max-width:900px){.footer-top{grid-template-columns:1fr 1fr 1fr;gap:32px}}
@media(max-width:600px){.footer-top{grid-template-columns:1fr 1fr;gap:24px}}
@media(max-width:420px){.footer-top{grid-template-columns:1fr;gap:24px}}

/* ===== ANIMACIONES GENERALES ===== */
.fade-up{opacity:0;transform:translateY(24px);transition:opacity .7s ease,transform .7s ease}
.fade-up.visible{opacity:1;transform:none}
@media(prefers-reduced-motion:reduce){
  .fade-up{opacity:1;transform:none}
  .wl-orb-1,.wl-orb-2{animation:none}
  .tag .dot{animation:none}
  *,*::before,*::after{animation-duration:.01ms !important;transition-duration:.01ms !important}
}

/* ===== RESPONSIVE ===== */
@media(max-width:880px){.container{padding:0 32px}}
@media(max-width:640px){.container{padding:0 22px}.footer-top{padding:48px 22px 28px}}

/* ===== ACCESIBILIDAD ===== */
.skip-link{position:absolute;top:-100px;left:16px;background:var(--ink);color:var(--gold);padding:12px 20px;border-radius:8px;font-weight:600;text-decoration:none;z-index:200;transition:top .2s}
.skip-link:focus{top:16px}
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}
a:focus-visible,button:focus-visible,input:focus-visible{outline:3px solid var(--gold);outline-offset:3px;border-radius:4px}
.section.gold-bg a:focus-visible,.section.gold-bg button:focus-visible{outline-color:var(--ink)}

.tab-pane{display:none}
.tab-pane.active{display:block}

/* ===== SEP ===== */
.sep{height:1px;background:linear-gradient(90deg,transparent,var(--gold-line-strong),transparent);margin:0}

/* ===== NAV LOGO MARK (SVG inline en lugar de img) ===== */
.nav-logo-mark{width:38px;height:38px;border-radius:50%;border:1px solid var(--gold-line-strong);display:flex;align-items:center;justify-content:center;background:rgba(255,195,0,.06);flex-shrink:0}
.nav-logo-mark svg{width:22px;height:22px}

/* ===== HERO ACTIONS ===== */
.hero-actions{display:flex;gap:16px;flex-wrap:wrap;align-items:center;margin-top:0}

/* ===== HERO RIGHT COLUMNS ===== */
.hero-right,.hero-right-block{display:flex;flex-direction:column;gap:16px}

/* ===== HERO STAT CARDS ===== */
.hero-stat-card{background:var(--white);border:1px solid var(--gold-line);border-radius:var(--rad-lg);padding:24px;box-shadow:var(--shadow-card)}
.hero-stat-card.dark{background:var(--ink);border-color:rgba(255,195,0,.25)}

/* ===== STAT ROW (empresas hero) ===== */
.stat-row{display:flex;gap:24px;flex-wrap:wrap}
.stat-item{display:flex;flex-direction:column;gap:4px}
.stat-num{font-family:var(--ff-title);font-size:2.4rem;font-weight:700;color:var(--ink);line-height:1}
.stat-label{font-size:.78rem;color:var(--muted);font-weight:500;line-height:1.4}

/* ===== IND CHIPS (quiénes somos hero) ===== */
.ind-chips{display:flex;flex-direction:column;gap:8px;margin-top:4px}
.chip{display:inline-flex;align-items:center;gap:6px;background:var(--off);border:1px solid var(--gold-line);border-radius:var(--rad-pill);padding:6px 12px;font-size:.78rem;font-weight:500;color:var(--muted)}
.chip-dot{width:6px;height:6px;border-radius:50%;background:var(--gold-dark);flex-shrink:0}

/* ===== VMP — Visión · Misión · Propósito ===== */
.vmp{background:var(--ink);background-image:var(--grid-dark);background-size:var(--grid-size);padding:64px 0;position:relative}
.vmp-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.vmp-card{background:rgba(255,255,255,.03);border:1px solid rgba(255,195,0,.18);border-radius:var(--rad-lg);padding:32px 28px;position:relative;transition:all var(--T)}
.vmp-card:hover{background:rgba(255,255,255,.05);border-color:var(--gold-line-strong);transform:translateY(-4px)}
.vmp-divider{height:2px;background:linear-gradient(90deg,var(--gold),transparent);border-radius:2px;margin-bottom:20px;width:48px}
.vmp-label{font-size:.7rem;font-weight:700;letter-spacing:.18em;text-transform:uppercase;color:var(--gold);margin-bottom:12px}
.vmp-card h3{font-family:var(--ff-title);font-size:1.1rem;color:var(--white);line-height:1.3;margin-bottom:12px}
.vmp-card p{font-size:.86rem;color:rgba(255,255,255,.6);line-height:1.7}
.vmp-card p em{color:var(--gold-light);font-style:normal}
@media(max-width:880px){.vmp-grid{grid-template-columns:1fr}}

/* ===== PILLARS ===== */
.pillars-section{padding:64px 0;background:var(--cream);background-image:var(--grid);background-size:var(--grid-size)}
.pillars-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.pillar-card{background:var(--white);border:1px solid var(--gold-line);border-radius:var(--rad-lg);padding:28px 24px;transition:all var(--T);position:relative}
.pillar-card:hover{border-color:var(--gold-line-strong);transform:translateY(-4px);box-shadow:0 16px 40px rgba(255,195,0,.1)}
.pillar-num{font-family:var(--ff-title);font-size:2.2rem;font-weight:700;color:rgba(255,195,0,.3);line-height:1;margin-bottom:12px}
.pillar-header{display:flex;flex-direction:column;gap:4px;margin-bottom:12px}
.pillar-header strong{font-family:var(--ff-title);font-size:1rem;color:var(--ink)}
.pillar-card p{font-size:.84rem;color:var(--muted);line-height:1.65}
.pillar-tag{display:inline-flex;align-items:center;font-size:.62rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;background:rgba(255,195,0,.1);color:var(--gold-dark);border:1px solid var(--gold-line-strong);border-radius:var(--rad-pill);padding:3px 10px;margin-top:8px;width:fit-content}
@media(max-width:880px){.pillars-grid{grid-template-columns:1fr 1fr}}
@media(max-width:560px){.pillars-grid{grid-template-columns:1fr}}

/* ===== FOUNDER V2 ===== */
.fnd-v2{padding:80px 0;background:var(--white);position:relative;overflow:hidden}
.fnd-v2-grid{display:grid;grid-template-columns:1.05fr 1fr;gap:72px;align-items:center}
.section-spacer{height:1px;background:linear-gradient(90deg,transparent,var(--gold-line-strong),transparent);margin:0 auto;max-width:1160px;padding:0 24px}
.fnd-name{font-family:var(--ff-title);font-weight:400;color:var(--ink);line-height:1.04;letter-spacing:-.01em;margin:0}
.fnd-name em{font-style:normal;color:var(--gold-dark)}
.fnd-v2-name{font-size:clamp(2.8rem,5vw,4.2rem);margin:18px 0 8px}
.fnd-v2-sub{font-size:.86rem;color:#666;margin:0 0 32px;display:flex;align-items:center;gap:12px}
.fnd-sub-dot{width:5px;height:5px;background:var(--gold);border-radius:50%;flex-shrink:0}
.fnd-v2-sub b{font-weight:600;color:var(--ink)}
/* LinkedIn portrait card */
.fnd-v2-portrait{display:flex;align-items:center;gap:22px;padding:22px 26px;background:var(--white);border:1px solid var(--gold-line);border-radius:20px;box-shadow:var(--shadow-card);margin-bottom:28px;max-width:460px;text-decoration:none;color:inherit;position:relative;transition:transform var(--T),box-shadow var(--T),border-color var(--T);overflow:hidden}
.fnd-v2-portrait::before{content:"";position:absolute;top:0;left:26px;right:26px;height:2px;background:linear-gradient(90deg,transparent,var(--gold),transparent);opacity:0;transition:opacity var(--T)}
.fnd-v2-portrait:hover{border-color:var(--gold-line-strong);transform:translateY(-3px);box-shadow:0 4px 32px rgba(0,0,0,.06),0 12px 32px rgba(255,195,0,.18)}
.fnd-v2-portrait:hover::before{opacity:1}
.fnd-v2-portrait:hover .fnd-li{color:var(--ink)}
.fnd-v2-portrait:focus-visible{outline:2px solid var(--gold);outline-offset:3px}
/* Photo circle */
.fnd-v2-portrait-photo{width:88px;height:88px;border-radius:50%;border:2px solid var(--gold);box-shadow:0 6px 20px rgba(255,195,0,.25);flex-shrink:0;position:relative;background:linear-gradient(160deg,#FFF1B8 0%,#FFE38A 40%,#F5C24A 100%)}
.fnd-v2-portrait-photo img{width:100%;height:100%;object-fit:cover;border-radius:50%;display:block}
/* LinkedIn blue badge */
.fnd-v2-portrait-badge{position:absolute;right:-4px;bottom:-4px;width:28px;height:28px;background:#0A66C2;color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;border:2px solid var(--white);box-shadow:0 2px 6px rgba(0,0,0,.18);z-index:2}
/* Card meta text */
.fnd-v2-portrait-meta .nm{font-family:var(--ff-title);font-size:1.15rem;color:var(--ink)}
.fnd-v2-portrait-meta .rl{font-size:.78rem;color:#666;margin-top:2px}
.fnd-li{display:inline-flex;align-items:center;gap:6px;margin-top:10px;font-size:.72rem;font-weight:600;color:var(--gold-dark);text-transform:uppercase;letter-spacing:.1em;transition:color var(--T)}
/* Pull quote and body */
.fnd-v2-pull{font-family:var(--ff-title);font-size:1.6rem;line-height:1.4;color:var(--ink);margin:32px 0 24px;max-width:540px}
.fnd-v2-pull em{font-style:normal;color:var(--gold-dark)}
.fnd-v2-body p{font-size:.86rem;line-height:1.78;color:#666;margin:0 0 14px;max-width:540px}
/* Right column: timeline card */
.fnd-v2-right{background:var(--white);border:1px solid var(--gold-line);border-radius:20px;padding:36px 36px 28px;box-shadow:var(--shadow-card);position:relative}
.fnd-v2-right::before{content:"";position:absolute;top:0;left:36px;right:36px;height:2px;background:linear-gradient(90deg,transparent,var(--gold),transparent)}
.fnd-v2-exp-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:28px}
.fnd-v2-exp-head h4{margin:0;font-family:var(--ff-title);font-size:1.35rem;color:var(--ink)}
.fnd-years{font-size:.72rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--gold-dark);background:rgba(255,195,0,.1);border:1px solid var(--gold-line-strong);padding:5px 12px;border-radius:var(--rad-pill)}
/* Timeline */
.fnd-v2-timeline{position:relative;padding-left:28px}
.fnd-v2-timeline::before{content:"";position:absolute;left:7px;top:8px;bottom:8px;width:2px;background:linear-gradient(180deg,var(--gold) 0%,var(--gold) 70%,transparent)}
.fnd-v2-item{position:relative;padding:0 0 26px}
.fnd-v2-item:last-child{padding-bottom:0}
.fnd-v2-item::before{content:"";position:absolute;left:-28px;top:4px;width:16px;height:16px;background:var(--white);border:3px solid var(--gold);border-radius:50%;box-shadow:0 0 0 4px var(--white)}
.fnd-v2-item .yr{font-size:.7rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--gold-dark);margin-bottom:4px}
.fnd-v2-item .ttl{font-family:var(--ff-title);font-size:1.08rem;line-height:1.35;color:var(--ink);margin-bottom:4px}
.fnd-v2-item .org{font-size:.86rem;color:#666;display:flex;align-items:center;gap:8px}
.fnd-v2-item .org-mark{width:18px;height:18px;border-radius:4px;background:var(--gold-very-light);border:1px solid var(--gold-line-strong);display:inline-flex;align-items:center;justify-content:center;font-family:var(--ff-title);font-size:.6rem;color:var(--gold-dark);font-weight:700;flex-shrink:0}
/* Responsive */
@media(max-width:900px){.fnd-v2-grid{grid-template-columns:1fr;gap:48px}.fnd-v2-portrait{max-width:100%}}
@media(max-width:600px){.fnd-v2{padding:56px 0}}

/* ===== FOOTER EXTRAS ===== */
.footer-logo-mark{width:36px;height:36px;border-radius:50%;border:1px solid rgba(255,195,0,.25);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.footer-logo-mark svg{width:22px;height:22px}
.footer-brand-name,.footer-brand-text{font-family:var(--ff-title);font-size:1.05rem;color:var(--gold);letter-spacing:.14em;text-transform:uppercase}
.footer-tagline{font-size:.83rem;color:rgba(255,255,255,.55);line-height:1.4;max-width:300px;margin:8px 0 4px}
.footer-sub{font-size:.78rem;color:rgba(255,255,255,.35);line-height:1.4;margin-bottom:12px}
.footer-legal{display:flex;gap:16px;flex-wrap:wrap}
.footer-legal a{color:rgba(255,255,255,.65);text-decoration:none;font-size:.71rem;transition:color var(--T)}
.footer-legal a:hover{color:var(--gold)}

/* ===== PROCESO (sección oculta en empresas) ===== */
.proceso-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:24px}
.paso{text-align:center}
.paso-num{width:48px;height:48px;border-radius:50%;background:var(--gold);color:var(--ink);font-family:var(--ff-title);font-size:1.2rem;font-weight:700;display:flex;align-items:center;justify-content:center;margin:0 auto 16px}
.paso h4{font-family:var(--ff-title);font-size:1rem;color:var(--white);margin-bottom:8px}
.paso p{font-size:.84rem;color:rgba(255,255,255,.6);line-height:1.6}
@media(max-width:880px){.proceso-grid{grid-template-columns:1fr 1fr}}
@media(max-width:560px){.proceso-grid{grid-template-columns:1fr}}

/* ===== TESTIMONIOS (sección oculta en empresas) ===== */
.clientes-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.cliente-card{background:rgba(255,255,255,.04);border:1px solid var(--gold-line-strong);border-radius:var(--rad-lg);padding:28px 24px;display:flex;flex-direction:column;gap:16px}
.cliente-stars{color:var(--gold);font-size:1rem;letter-spacing:2px}
.cliente-text{font-size:.86rem;color:rgba(255,255,255,.75);line-height:1.7;flex:1}
.cliente-autor{display:flex;align-items:center;gap:12px}
.cliente-avatar{width:40px;height:40px;border-radius:50%;background:var(--gold);color:var(--ink);font-family:var(--ff-title);font-size:.88rem;font-weight:700;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.cliente-name{font-size:.88rem;font-weight:600;color:var(--white)}
.cliente-role{font-size:.75rem;color:rgba(255,255,255,.5)}
@media(max-width:880px){.clientes-grid{grid-template-columns:1fr}}

/* ===== HERO INNER RESPONSIVE (solo quienes-somos y empresas) ===== */
@media(max-width:880px){
  .qs-hero .hero-inner,
  .hero--empresas .hero-inner{grid-template-columns:1fr;gap:40px}
  .hero-right,.hero-right-block{max-width:560px}
}

/* ===== PILLAR CARD — mejoras hover ===== */
.pillar-card::before{content:'';position:absolute;top:0;left:24px;right:24px;height:2px;
  background:linear-gradient(90deg,transparent,var(--gold),transparent);opacity:0;transition:opacity var(--T)}
.pillar-card:hover::before{opacity:1}
.pillar-card:hover .pillar-num{color:rgba(255,195,0,.5)}

/* ===== PILLAR CARD — variante wide (featured en empresas) ===== */
.pillar-card--wide{grid-column:span 2;border-color:var(--gold-line-strong);background:rgba(255,195,0,.02)}
.pillar-card--wide::before{opacity:1}

/* ===== PAGE-SPECIFIC: quienes-somos hero ===== */
.qs-hero{padding-top:32px}

.servicios-extra{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-top:24px}
@media(max-width:880px){.servicios-extra{grid-template-columns:repeat(2,1fr)}}
@media(max-width:480px){.servicios-extra{grid-template-columns:1fr}}

/* ===== PAGE-SPECIFIC: empresas hero — fondo oscuro ===== */
.hero--empresas{background:var(--ink);background-image:var(--grid-dark)}
.hero--empresas::before{background:
  radial-gradient(ellipse 55% 65% at 80% 15%,rgba(255,195,0,.13),transparent 60%),
  radial-gradient(ellipse 35% 45% at 5% 90%,rgba(255,195,0,.07),transparent 60%)}
.hero--empresas .hero-left h1{color:var(--white)}
.hero--empresas .hero-left h1 em{color:var(--gold)}
.hero--empresas .hero-lead{color:rgba(255,255,255,.6)}
.hero--empresas .tag{background:rgba(255,195,0,.1);color:var(--gold);box-shadow:0 0 0 2px var(--gold)}
.hero--empresas .btn-outline{color:var(--white);border-color:rgba(255,255,255,.3)}
.hero--empresas .btn-outline:hover{background:rgba(255,255,255,.08);border-color:rgba(255,255,255,.55);color:var(--white);transform:translateY(-2px)}

/* ===== STAT FLIP CARDS ===== */
.stat-card{perspective:900px;cursor:pointer}
.stat-card-inner{
  position:relative;width:100%;height:148px;
  transition:transform .55s cubic-bezier(.4,0,.2,1);
  transform-style:preserve-3d}
.stat-card:hover .stat-card-inner,
.stat-card.flipped .stat-card-inner{transform:rotateY(180deg)}
.stat-card-front,
.stat-card-back{
  position:absolute;inset:0;
  border-radius:var(--rad-lg);
  padding:18px 20px;
  backface-visibility:hidden;
  -webkit-backface-visibility:hidden;
  display:flex;flex-direction:column;justify-content:flex-end}
.stat-card-front{
  background:rgba(255,255,255,.05);
  border:1px solid rgba(255,255,255,.1);
  border-top:2px solid var(--gold);
  justify-content:flex-end}
.stat-card-back{
  transform:rotateY(180deg);
  background:var(--gold);
  border:1px solid var(--gold-dark);
  justify-content:space-between}
.stat-card .stat-num{font-family:var(--ff-title);font-size:2.4rem;font-weight:700;color:var(--gold);line-height:1}
.stat-card .stat-label{font-size:.78rem;color:rgba(255,255,255,.75);font-weight:600;line-height:1.35;margin-top:6px}
.stat-card-back p{font-size:.86rem;color:var(--ink);line-height:1.65;font-weight:500;flex:1}
.stat-source{font-size:.7rem;color:rgba(0,0,0,.55);padding-top:10px;border-top:1px solid rgba(0,0,0,.12);line-height:1.4}

/* ===== PAGE-SPECIFIC: pillars grid ===== */
/* quienes-somos — 5 pilares en una fila, contenido centrado */
.pillars-section .pillars-grid{grid-template-columns:repeat(5,1fr);gap:16px}
.pillars-section .pillar-card{text-align:center}
.pillars-section .pillar-header{align-items:center}
/* empresas — 4 cols para acomodar el card featured span-2 en 1 fila */
#servicios .pillars-grid{grid-template-columns:repeat(4,1fr)}

@media(max-width:1100px){
  .pillars-section .pillars-grid{grid-template-columns:repeat(3,1fr)}
}
@media(max-width:880px){
  .pillars-section .pillars-grid{grid-template-columns:1fr 1fr}
  #servicios .pillars-grid{grid-template-columns:1fr 1fr}
  .pillar-card--wide{grid-column:span 1}
}
@media(max-width:560px){
  .pillars-section .pillars-grid{grid-template-columns:1fr}
  #servicios .pillars-grid{grid-template-columns:1fr}
}

/* ══════════════════════════════════════════════════════
   SISTEMA DE COOKIES — Modal + Banner
   ══════════════════════════════════════════════════════ */

/* Modal base (reutilizable para modal de cookies) */
.privacy-modal-overlay{
  display:none;position:fixed;inset:0;z-index:2000;
  background:rgba(0,0,0,.55);backdrop-filter:blur(6px);
  align-items:center;justify-content:center;padding:24px;
}
.privacy-modal-overlay.open{display:flex;}
.privacy-modal{
  background:var(--white);border-radius:20px;
  padding:44px 40px 36px;max-width:640px;width:100%;
  max-height:85vh;overflow-y:auto;position:relative;
  border:1px solid rgba(255,195,0,.25);
  box-shadow:0 24px 80px rgba(0,0,0,.15);
}
.privacy-modal::before{
  content:'';position:absolute;top:0;left:40px;right:40px;height:2px;
  background:linear-gradient(90deg,transparent,var(--gold),transparent);
}
.privacy-modal-close{
  position:absolute;top:14px;right:18px;
  background:none;border:none;color:var(--light);
  font-size:1.8rem;cursor:pointer;line-height:1;transition:color var(--T);
}
.privacy-modal-close:hover{color:var(--ink);}
.privacy-modal-badge{
  display:inline-block;background:rgba(255,195,0,.1);
  border:1px solid rgba(255,195,0,.3);color:var(--gold-dark);
  font-size:.68rem;font-weight:700;letter-spacing:.12em;
  text-transform:uppercase;padding:4px 14px;border-radius:50px;margin-bottom:14px;
}
.privacy-modal h2{
  font-family:var(--ff-title);font-size:1.7rem;
  color:var(--ink);margin-bottom:6px;line-height:1.2;
}
.privacy-modal h2 em{font-style:normal;color:var(--gold-dark);}
.privacy-modal-date{font-size:.78rem;color:var(--light);margin-bottom:26px;}
.privacy-modal-body{border-top:1px solid rgba(0,0,0,.1);padding-top:22px;}
.privacy-modal-body h3{font-family:var(--ff-title);font-size:1rem;color:var(--ink);margin:20px 0 8px;}
.privacy-modal-body h4{font-family:var(--ff-body);font-size:.87rem;font-weight:700;color:var(--ink);margin:14px 0 6px;}
.privacy-modal-body p,.privacy-modal-body li{font-size:.87rem;color:var(--muted);line-height:1.7;}
.privacy-modal-body ul{padding-left:20px;margin:8px 0;}
.privacy-modal-body strong{color:var(--ink);}
.privacy-modal-body a{color:var(--gold-dark);}
.pm-highlight{
  background:var(--gold-very-light);
  border:1px solid rgba(255,195,0,.35);border-left:4px solid var(--gold);
  border-radius:10px;padding:14px 18px;margin:16px 0;
}
.pm-highlight p{color:var(--ink);font-size:.86rem;line-height:1.7;}
.pm-highlight strong{color:var(--ink);}
.pm-warning{background:var(--ink);border-radius:10px;padding:14px 18px;margin:16px 0;}
.pm-warning p{color:rgba(255,255,255,.9);font-size:.86rem;line-height:1.7;}
.pm-warning strong{color:var(--gold);}
.pm-table{width:100%;border-collapse:collapse;margin:12px 0 8px;font-size:.8rem;}
.pm-table th,.pm-table td{border:1px solid rgba(0,0,0,.1);padding:8px 10px;text-align:left;vertical-align:top;line-height:1.5;}
.pm-table th{background:var(--gold);color:var(--ink);font-weight:700;font-size:.75rem;text-transform:uppercase;letter-spacing:.04em;}
.pm-table td{color:var(--muted);}
.pm-table td strong{color:var(--ink);}
.privacy-modal-footer{
  margin-top:28px;padding-top:18px;border-top:1px solid rgba(0,0,0,.1);
  display:flex;flex-wrap:wrap;gap:10px;justify-content:space-between;align-items:center;
}
.privacy-modal-footer-links{font-size:.78rem;color:var(--light);}
.privacy-modal-footer-links a{color:var(--gold-dark);text-decoration:none;margin-right:10px;}
.privacy-modal-footer-links a:hover{text-decoration:underline;}
.privacy-modal-accept{
  background:var(--gold);color:var(--ink);
  border:2px solid var(--gold);border-radius:50px;padding:11px 26px;
  font-family:var(--ff-body);font-size:.86rem;font-weight:700;
  cursor:pointer;transition:all var(--T);
}
.privacy-modal-accept:hover{background:var(--gold-dark);border-color:var(--gold-dark);box-shadow:var(--shadow-gold);}

/* Banner de cookies */
.ck-banner{
  position:fixed;left:20px;bottom:20px;right:20px;
  max-width:460px;background:var(--ink);color:#fff;
  border-radius:14px;border:1px solid rgba(255,195,0,.3);
  padding:22px 24px;z-index:1900;
  box-shadow:0 12px 40px rgba(0,0,0,.35);
  transform:translateY(140%);
  transition:transform .4s cubic-bezier(.4,0,.2,1);
}
.ck-banner.open{transform:translateY(0);}
.ck-banner-title{font-family:var(--ff-title);font-size:1.08rem;margin-bottom:6px;color:#fff;}
.ck-dot{display:inline-block;width:8px;height:8px;background:var(--gold);border-radius:50%;margin-right:8px;vertical-align:middle;}
.ck-banner-text{font-size:.8rem;color:rgba(255,255,255,.7);line-height:1.6;margin-bottom:16px;}
.ck-banner-text a{color:var(--gold);text-decoration:underline;text-underline-offset:2px;}
.ck-banner-actions{display:flex;flex-wrap:wrap;gap:8px;}
.ck-btn{
  flex:1 1 auto;min-width:110px;padding:10px 14px;
  border-radius:50px;border:1px solid transparent;
  font-family:var(--ff-body);font-size:.8rem;font-weight:600;
  cursor:pointer;transition:all var(--T);white-space:nowrap;
}
.ck-btn-primary{background:var(--gold);color:var(--ink);border-color:var(--gold);}
.ck-btn-primary:hover{background:var(--gold-dark);border-color:var(--gold-dark);}
.ck-btn-secondary{background:transparent;color:rgba(255,255,255,.9);border-color:rgba(255,255,255,.3);}
.ck-btn-secondary:hover{border-color:var(--gold);color:var(--gold);}
.ck-btn-tertiary{
  background:transparent;color:rgba(255,255,255,.55);
  border-color:transparent;text-decoration:underline;
  text-underline-offset:3px;padding:10px 4px;
  flex:0 0 auto;min-width:0;
}
.ck-btn-tertiary:hover{color:var(--gold);}
.ck-prefs{display:none;margin-top:18px;padding-top:16px;border-top:1px solid rgba(255,255,255,.15);}
.ck-banner.show-prefs .ck-prefs{display:block;}
.ck-pref-row{display:flex;align-items:flex-start;gap:12px;padding:10px 0;border-bottom:1px solid rgba(255,255,255,.08);}
.ck-pref-row:last-child{border-bottom:none;}
.ck-pref-info{flex:1;}
.ck-pref-name{font-size:.84rem;color:#fff;font-weight:600;margin-bottom:2px;}
.ck-pref-desc{font-size:.72rem;color:rgba(255,255,255,.55);line-height:1.5;}
.ck-pref-toggle{
  width:38px;height:22px;background:rgba(255,255,255,.15);
  border-radius:50px;position:relative;flex-shrink:0;
  cursor:pointer;transition:background .2s;margin-top:2px;
}
.ck-pref-toggle::after{
  content:'';position:absolute;top:2px;left:2px;
  width:18px;height:18px;background:#fff;
  border-radius:50%;transition:transform .2s;
}
.ck-pref-toggle.on{background:var(--gold);}
.ck-pref-toggle.on::after{transform:translateX(16px);}
.ck-pref-toggle.locked{background:rgba(42,125,79,.4);cursor:not-allowed;}
.ck-pref-toggle.locked::after{transform:translateX(16px);background:#2A7D4F;}
.ck-prefs-actions{display:flex;gap:8px;margin-top:14px;}
@media(max-width:520px){
  .ck-banner{left:12px;right:12px;bottom:12px;padding:18px 20px;}
  .ck-btn{min-width:0;flex:1 1 100%;}
}

/* ============================================================
   Refactor v2.2 — reglas extraídas de inline styles.
   Aplicables a todas las páginas Tipo A que usen estos componentes.
   ============================================================ */

/* VMP — título dorado y subtítulo sobre fondo oscuro */
.vmp h2{color:var(--gold);font-size:clamp(2rem,3.5vw,2.625rem)}
.vmp-sub{font-size:.95rem;color:rgba(255,255,255,.6);margin-top:20px;font-weight:500}

/* Hero stat-card — etiquetas de categoría (¿Qué NO / Qué SÍ hacemos?) */
.hero-stat-card__label{font-size:.72rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--gold-dark);margin-bottom:12px}
.hero-stat-card.dark .hero-stat-card__label{color:rgba(255,195,0,.6)}
.hero-stat-card__text{font-size:.92rem;color:rgba(255,255,255,.85);line-height:1.6;margin:0}

/* Pillar — hint secundario bajo el título del pilar */
.pillar-header__hint{font-size:.72rem;color:var(--gold-dark);font-weight:700;margin-top:6px;display:block}

/* Hero — etiqueta de fecha "Actualizado:" */
.qs-hero time.updated{display:block;margin-top:14px;font-size:.75rem;color:var(--light)}