/* Estilos principales compartidos */
:root{
  --bg:#0b1020; --card:#101935; --muted:#9097b1; --txt:#e8ecff; --acc:#6edff6; --accent2:#8fff9f; --danger:#ff6b6b;
  --shadow: 0 10px 30px rgba(0,0,0,.25);
  --splash-cyan: rgba(110,223,246,.22);
  --splash-green: rgba(143,255,159,.20);
  --splash-cyan-soft: rgba(110,223,246,.12);
  --splash-green-soft: rgba(143,255,159,.1);
}
*{box-sizing:border-box}
html,body{margin:0;padding:0;background:linear-gradient(180deg,#060a17,#0b1020 30%, #0b1020);color:var(--txt);font-family:Inter,system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;scroll-behavior:smooth}
a{color:var(--acc);text-decoration:none}
a:hover{text-decoration:underline}
.container{max-width:1200px;margin:0 auto;padding:0 20px}
header{position:sticky;top:0;z-index:50;background:rgba(11,16,32,.7);backdrop-filter:blur(12px);border-bottom:1px solid rgba(255,255,255,.06)}
nav{display:flex;align-items:center;justify-content:space-between;height:66px}
.brand{display:flex;align-items:center;gap:.75rem;font-weight:800;letter-spacing:.3px}
.logo{width:36px;height:36px;border-radius:10px;background:conic-gradient(from 210deg at 50% 50%, #6edff6, #8fff9f, #6edff6);box-shadow:0 0 0 3px rgba(255,255,255,.06), var(--shadow)}
.brand-logo{height:48px;width:auto;display:block}
.brand-text{font-size:1.25rem;font-weight:800;letter-spacing:.2px;display:inline-flex;align-items:center}
.brand-ai{background:linear-gradient(90deg,#ff8a1f,#ff6b00);-webkit-background-clip:text;background-clip:text;color:transparent}
.navlinks{display:flex;gap:1rem;flex-wrap:wrap}
/* Mobile nav */
.menu-toggle{display:none;position:relative;border:1px solid rgba(255,255,255,.18);background:rgba(255,255,255,.05);color:var(--txt);width:46px;height:46px;border-radius:14px;align-items:center;justify-content:center;gap:4px;cursor:pointer;transition:.25s background,.25s border}
.menu-toggle:hover{background:rgba(255,255,255,.1);border-color:rgba(255,255,255,.3)}
.menu-toggle .bar{display:block;width:20px;height:2px;background:linear-gradient(90deg,#6edff6,#8fff9f);border-radius:2px;transition:.35s transform,.35s opacity}
@media (max-width:760px){
  nav{flex-wrap:wrap;row-gap:10px;height:auto;padding:10px 0}
  .menu-toggle{display:flex;order:2}
  .navlinks{order:3;flex-direction:column;align-items:stretch;width:100%;background:rgba(15,22,40,.9);border:1px solid rgba(255,255,255,.08);border-radius:18px;padding:12px 14px;display:none;position:relative;box-shadow:0 18px 36px -14px rgba(0,0,0,.6)}
  .navlinks.open{display:flex}
  .navlinks a.btn{width:100%;justify-content:flex-start}
  .brand{order:1}
  body.nav-open header{box-shadow:0 10px 28px -12px rgba(0,0,0,.6)}
}
body.nav-open{overflow:hidden}
@media (max-width:760px){
  html.no-js .navlinks{display:flex !important}
  html.no-js .menu-toggle{display:none !important}
}
.ai-glow{background:linear-gradient(90deg,#6edff6,#8fff9f,#6edff6);background-size:200% 100%;-webkit-background-clip:text;background-clip:text;color:transparent;animation:aiGlow 3.2s linear infinite;position:relative;filter:drop-shadow(0 0 2px rgba(110,223,246,.85)) drop-shadow(0 0 6px rgba(110,223,246,.55))}
@keyframes aiGlow{0%{background-position:0 0;filter:drop-shadow(0 0 2px #6edff6) drop-shadow(0 0 8px rgba(110,223,246,.55))}25%{filter:drop-shadow(0 0 2px #8fff9f) drop-shadow(0 0 9px rgba(143,255,159,.5))}50%{background-position:100% 0;filter:drop-shadow(0 0 3px #ffb347) drop-shadow(0 0 10px rgba(255,179,71,.55))}75%{filter:drop-shadow(0 0 2px #8fff9f) drop-shadow(0 0 9px rgba(143,255,159,.5))}100%{background-position:0 0;filter:drop-shadow(0 0 2px #6edff6) drop-shadow(0 0 8px rgba(110,223,246,.55))}}
@media (prefers-reduced-motion:reduce){.ai-glow{animation:none;filter:none}}
.btn{display:inline-flex;align-items:center;gap:.5rem;padding:.8rem 1rem;border-radius:12px;border:1px solid rgba(255,255,255,.12);background:rgba(255,255,255,.04);color:var(--txt);font-weight:600;transition:.2s background,.2s filter}
.btn:hover{background:rgba(255,255,255,.08)}
.btn.primary{background:linear-gradient(135deg,#6edff6,#8fff9f);color:#0b1020;border:none}
.btn.primary:hover{filter:brightness(1.05)}
.btn[aria-current="page"]{background:rgba(255,255,255,.14);cursor:default}
.hero{position:relative;overflow:hidden;padding:80px 0}
.hero .bg{position:absolute;inset:-10% -10% auto -10%;height:120%;background:radial-gradient(60vw 60vw at 80% -10%, rgba(110,223,246,.25), transparent 60%), radial-gradient(50vw 50vw at -10% 20%, rgba(143,255,159,.18), transparent 55%)}
.hero-grid{position:relative;display:grid;grid-template-columns:1.2fr .8fr;gap:32px;align-items:start}
.kicker{display:inline-block; padding:.35rem .6rem;border:1px solid rgba(255,255,255,.2);border-radius:999px;color:var(--muted);font-weight:600;font-size:.85rem;letter-spacing:.2px}
.ods-pill{background:rgba(255,255,255,.08);border-color:rgba(255,255,255,.28);color:#d4ecff;transition:.25s background,.25s color,.25s border}
.ods-pill:hover{background:linear-gradient(90deg,#6edff6,#8fff9f);color:#05202a;border-color:transparent;text-decoration:none}
h1{font-size:clamp(2rem,4.5vw,3.2rem);line-height:1.1;margin:.6rem 0}
.lead{font-size:1.1rem;color:#cdd6ff;max-width:58ch}
.hero-cta{display:flex;gap:12px;flex-wrap:wrap;margin-top:20px}
.card{background:linear-gradient(180deg,rgba(255,255,255,.06),rgba(255,255,255,.03));border:1px solid rgba(255,255,255,.08);border-radius:18px;box-shadow:var(--shadow)}
.illus{padding:20px}
.illus-inner{aspect-ratio:4/3;border-radius:14px;background:
  radial-gradient(220px 220px at 30% 30%, rgba(110,223,246,.22), transparent 60%),
  radial-gradient(180px 180px at 80% 40%, rgba(143,255,159,.18), transparent 60%),
  linear-gradient(135deg, rgba(255,255,255,.06), rgba(255,255,255,.02));
  border:1px dashed rgba(255,255,255,.14);display:grid;place-items:center;color:var(--muted);font-weight:600}
section{padding:72px 0}
h1:not(.no-decor),h2:not(.no-decor){position:relative}
h1:not(.no-decor)::after, h2:not(.no-decor)::after{content:"";display:block;width:68px;height:3px;margin-top:14px;border-radius:3px;background:linear-gradient(90deg,#6edff6,#8fff9f);box-shadow:0 0 0 1px rgba(255,255,255,.08),0 4px 18px -4px rgba(110,223,246,.55)}
h1.no-underline::after, h2.no-underline::after{display:none}
/* Color splash section */
.splash-section{position:relative;overflow:hidden}
.splash-section:before{content:"";position:absolute;inset:0;background:
  radial-gradient(600px 600px at 12% 25%, var(--splash-cyan), transparent 70%),
  radial-gradient(540px 540px at 88% 70%, var(--splash-green), transparent 72%),
  radial-gradient(800px 800px at 50% 120%, rgba(110,223,246,.12), transparent 75%),
  linear-gradient(180deg, rgba(255,255,255,.02), transparent);
  pointer-events:none;mix-blend-mode:screen;opacity:.9}
.splash-section.alt:before{background:
  radial-gradient(540px 540px at 18% 60%, var(--splash-green), transparent 72%),
  radial-gradient(600px 600px at 90% 25%, var(--splash-cyan), transparent 70%),
  radial-gradient(800px 800px at 50% 120%, rgba(143,255,159,.12), transparent 75%),
  linear-gradient(180deg, rgba(255,255,255,.02), transparent)}
h2{font-size:clamp(1.4rem,2.6vw,2rem);margin:0 0 16px}
.sub{color:var(--muted);max-width:85ch}
.grid{display:grid;gap:16px}
.grid.cols-3{grid-template-columns:repeat(3,1fr)}
.grid.cols-2{grid-template-columns:repeat(2,1fr)}
.feature{padding:18px}
.feature h3{margin:.2rem 0 .25rem;font-size:1.05rem}
.tag{display:inline-block;font-size:.75rem;color:#0b1020;background:linear-gradient(135deg,#6edff6,#8fff9f);padding:.2rem .5rem;border-radius:999px;font-weight:700}
.pill{display:inline-block;border:1px solid rgba(255,255,255,.14);border-radius:999px;padding:.25rem .6rem;color:#cde3ff;font-size:.8rem}
.table{overflow:auto;border-radius:14px;border:1px solid rgba(255,255,255,.1)}
table{width:100%;border-collapse:collapse;min-width:720px}
th,td{padding:12px 14px;border-bottom:1px solid rgba(255,255,255,.06)}
th{background:rgba(255,255,255,.04);text-align:left;color:#d7e2ff}
tr:hover td{background:rgba(255,255,255,.03)}
.team{grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:18px}
.member{padding:18px;display:flex;flex-direction:column;gap:10px}
.avatar{width:56px;height:56px;border-radius:14px;background:linear-gradient(135deg,#6edff6,#8fff9f)}
.role{color:#b9c3ff;font-size:.9rem}
/* Team expanded */
.team.large{display:grid;grid-template-columns:repeat(3,1fr);gap:28px;margin-top:34px}
.member.large{padding:0;border:1px solid rgba(255,255,255,.1);background:linear-gradient(180deg,rgba(255,255,255,.07),rgba(255,255,255,.02));overflow:hidden;border-radius:20px;display:flex;flex-direction:column}
.member-photo{position:relative;width:100%;aspect-ratio:4/3;overflow:hidden;background:radial-gradient(circle at 30% 40%,rgba(110,223,246,.25),transparent 60%),radial-gradient(circle at 80% 70%,rgba(143,255,159,.18),transparent 65%),linear-gradient(135deg,#1a2338,#101a30)}
.member-photo img{width:100%;height:100%;object-fit:contain;display:block}
.member-body{display:flex;flex-direction:column;gap:8px;padding:18px 18px 20px}
.member-body strong{font-size:1.05rem}
.social-link{display:inline-flex;align-items:center;gap:6px;font-size:.8rem;font-weight:600;padding:6px 10px;border-radius:10px;text-decoration:none;position:relative}
.social-link.linkedin{background:rgba(10,102,194,.15);color:#5fb3ff;border:1px solid rgba(10,102,194,.35)}
.social-link.linkedin:hover{background:rgba(10,102,194,.25)}
.social-link svg{width:16px;height:16px;fill:#5fb3ff}
.team-mission{margin-top:50px;padding:42px 36px;display:grid;gap:28px;border:1px solid rgba(255,255,255,.08);background:linear-gradient(180deg,rgba(255,255,255,.05),rgba(255,255,255,.015));border-radius:28px;position:relative;overflow:hidden}
.team-mission:before{content:"";position:absolute;inset:0;background:radial-gradient(400px 400px at 18% 25%,rgba(110,223,246,.18),transparent 70%),radial-gradient(360px 360px at 85% 70%,rgba(143,255,159,.16),transparent 72%);mix-blend-mode:screen;pointer-events:none;opacity:.55}
.team-mission h2{margin:0}
.mission-content{display:grid;grid-template-columns:1.1fr .9fr;gap:40px;align-items:start}
.info-block{padding:42px 36px;border:1px solid rgba(255,255,255,.08);border-radius:28px;position:relative;overflow:hidden;display:block}
.gradient-box{background:linear-gradient(180deg,rgba(255,255,255,.05),rgba(255,255,255,.015))}
.values-ods-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:40px;align-items:start}
@media (max-width:1000px){.values-ods-grid{grid-template-columns:1fr;gap:34px}}
.info-block[id], .team-mission[id]{scroll-margin-top:90px}
@media (max-width:760px){.info-block[id], .team-mission[id]{scroll-margin-top:20px}}
/* Secciones independientes de valores y ODS (sin tarjeta de fondo) */
.values-section, .ods-section{margin-top:40px;padding:0}
.mission-section{padding:0}
/* Eliminar padding vertical grande heredado de section para secciones internas dentro de splash */
.splash-section .mission-section, .splash-section .values-section, .splash-section .ods-section{padding:0}
.values-section h2, .ods-section h2{margin:0 0 20px}
.values-section .about-values-grid{margin-top:26px}
.ods-section .ods-points{margin-top:24px}
/* Espaciado específico entre valores y ODS */
.mission-section + .values-section{margin-top:40px}
.values-section + .ods-section{margin-top:40px}
.values-section[id], .ods-section[id]{scroll-margin-top:90px}
@media (max-width:760px){
  .values-section, .ods-section{margin-top:40px}
  .mission-section + .values-section{margin-top:40px}
  .values-section + .ods-section{margin-top:40px}
  .values-section[id], .ods-section[id]{scroll-margin-top:20px}
}
/* Nueva sección misión sin tarjeta */
.mission-section{margin-top:40px}
.mission-section h2{margin:0 0 26px}
.mission-section .mission-content{padding:0;display:grid;grid-template-columns:1.1fr .9fr;gap:46px;align-items:start}
.mission-section .mission-text p{margin:0 0 18px;max-width:68ch;line-height:1.55;color:#d5def0}
.mission-section .mission-text p:last-child{margin-bottom:0}
.mission-section .mission-image{border-radius:26px;overflow:hidden;min-height:260px;background:radial-gradient(circle at 25% 30%,rgba(110,223,246,.25),transparent 60%),radial-gradient(circle at 80% 70%,rgba(143,255,159,.2),transparent 65%),linear-gradient(135deg,#1a2338,#101a30);border:1px solid rgba(255,255,255,.18);box-shadow:0 14px 38px -10px rgba(0,0,0,.5);display:grid;place-items:center}
.mission-section .mission-image img{width:100%;height:100%;object-fit:contain;display:block}
.mission-vision-grid{display:grid;grid-template-columns:1.15fr .85fr;gap:54px;align-items:start}
.mission-vision-grid.no-illustration{grid-template-columns:1fr;gap:38px}
.mission-vision-grid.no-illustration .mv-left{max-width:none}
.mv-left{display:flex;flex-direction:column;gap:34px}
.mv-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(380px,1fr));gap:30px}
.mv-card{background:linear-gradient(135deg,#151e30,#101726);padding:22px 22px 20px;border:1px solid rgba(255,255,255,.08);border-radius:18px;position:relative;overflow:hidden}
.mv-card:before{content:"";position:absolute;inset:0;background:radial-gradient(circle at 85% 20%,rgba(110,223,246,.18),transparent 60%),radial-gradient(circle at 15% 85%,rgba(143,255,159,.15),transparent 60%);pointer-events:none;mix-blend-mode:screen}
.mv-card h3{margin:0 0 14px;font-size:1.08rem;letter-spacing:.6px;display:inline-flex;align-items:center;gap:10px}
.mv-icon{display:inline-flex;width:26px;height:26px;border-radius:8px;padding:5px;background:linear-gradient(135deg,#6edff6,#8fff9f);color:#05202a;box-shadow:0 4px 12px -6px rgba(0,0,0,.55)}
.mv-icon svg{width:100%;height:100%;display:block}
.mv-card p{margin:0 0 14px;font-size:.92rem;line-height:1.55;color:#d7e0ef}
.mv-card p:last-child{margin-bottom:0}
.mv-illustration{margin:0}
.mv-illustration img{object-fit:cover}
@media (max-width:1100px){.mission-vision-grid{grid-template-columns:1fr;gap:40px}.mv-illustration{order:-1}}
@media (max-width:600px){.mv-cards{grid-template-columns:1fr}}
.mission-section[id]{scroll-margin-top:90px}
@media (max-width:1000px){
  .mission-section .mission-content{grid-template-columns:1fr;gap:34px}
}
@media (max-width:760px){
  .mission-section[id]{scroll-margin-top:20px}
}
/* Valores reestructurados */
.about-values-grid{margin:28px 0 4px;display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:18px 20px}
.values-block{overflow:visible !important}
.about-values-grid{grid-auto-rows:1fr}
.about-value{height:100%}
.about-value{display:flex;align-items:flex-start;gap:14px;padding:16px 16px 16px 16px;border:1px solid rgba(255,255,255,.09);border-radius:22px;background:linear-gradient(180deg,rgba(255,255,255,.07),rgba(255,255,255,.02));position:relative;min-height:110px}
.about-value-icon{width:46px;height:46px;border-radius:15px;background:linear-gradient(135deg,#6edff6,#8fff9f);display:grid;place-items:center;color:#05202a;box-shadow:0 6px 18px -6px rgba(0,0,0,.55);flex-shrink:0}
.about-value-icon svg{width:26px;height:26px;display:block}
.about-value-text{display:flex;flex-direction:column;gap:6px;font-size:.78rem;line-height:1.35;color:#cad3e6}
.about-value-text strong{font-size:.85rem;letter-spacing:.3px;color:#f6f9ff}
.values-intro{margin:0;font-size:.9rem;line-height:1.45;color:#cdd6ec}
@media (max-width:700px){
  .about-values-grid{grid-template-columns:1fr}
}
/* ODS 12 lista icónica */
.ods-block{display:flex;flex-direction:column}
.ods-intro{margin:0;font-size:.9rem;line-height:1.45;color:#cdd6ec}
/* Anchos completos para intros específicas (evita cortes tempranos) */
.section-intro .sub, .flow-e2e .sub{max-width:none}
.ods-points{list-style:none;margin:26px 0 14px;padding:0;display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:14px 18px}
.ods-points li{display:flex;align-items:flex-start;gap:12px;padding:16px;border:1px solid rgba(255,255,255,.09);background:linear-gradient(180deg,rgba(255,255,255,.07),rgba(255,255,255,.02));border-radius:22px;min-height:110px;position:relative}
.point-icon{width:18px;height:18px;margin-top:4px;border-radius:6px;background:linear-gradient(135deg,#6edff6,#8fff9f);box-shadow:0 0 0 3px rgba(255,255,255,.08),0 4px 14px -4px rgba(110,223,246,.55);flex-shrink:0}
.ods-points li div{display:flex;flex-direction:column;gap:4px;font-size:.78rem;line-height:1.35;color:#cfd7ec}
.ods-points li div strong{font-size:.82rem;letter-spacing:.3px;color:#f4f8ff}
.ods-foot{margin:4px 0 0;font-size:.75rem;letter-spacing:.3px;color:#b6c0d6;opacity:.9}
@media (min-width:1100px){
  .ods-points{grid-template-columns:repeat(2,1fr)}
}
/* Purpose layout */
.purpose-wrap{margin-top:0;margin-bottom:0px}
.purpose-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:46px;align-items:start}
.purpose-text h1{margin:0 0 8px}
.purpose-chips{display:grid;grid-template-columns:repeat(2,auto);justify-content:center;justify-items:center;gap:12px 18px;margin:16px 0 10px}
@media (max-width:520px){.purpose-chips{grid-template-columns:1fr;justify-items:center}}
.purpose-note{font-size:.9rem;max-width:860px;color:#9fb1c9;margin-top:0;margin-bottom:0}
.purpose-wrap + .section-intro{margin-top:4px !important}
.purpose-chips .chip{font-size:.95rem;padding:.65rem 1.15rem;font-weight:600;letter-spacing:.25px;line-height:1.15}
.purpose-media{margin:0;position:relative;display:block;align-self:start;padding:0;background:transparent;border:none;border-radius:0;overflow:visible;max-width:460px;width:100%}
.purpose-media img{width:100%;height:auto;display:block;object-fit:contain}
.visually-hidden{position:absolute !important;width:1px !important;height:1px !important;padding:0 !important;margin:-1px !important;overflow:hidden !important;clip:rect(0 0 0 0) !important;white-space:nowrap !important;border:0 !important}
@media (max-width:1000px){
  .purpose-grid{grid-template-columns:1fr;gap:34px}
  .purpose-media{max-width:100%}
}
@media (max-width:640px){
  .purpose-chips{gap:8px}
  .purpose-grid{gap:28px}
}
.mission-text{display:flex;flex-direction:column;gap:18px}
.mission-image{position:relative;border-radius:22px;overflow:hidden;min-height:260px;background:radial-gradient(circle at 25% 30%,rgba(110,223,246,.25),transparent 60%),radial-gradient(circle at 80% 70%,rgba(143,255,159,.2),transparent 65%),linear-gradient(135deg,#1a2338,#101a30);border:1px solid rgba(255,255,255,.18);box-shadow:0 14px 38px -10px rgba(0,0,0,.5);display:grid;place-items:center}
.mission-image img{width:100%;height:100%;object-fit:cover;display:block}
@media (max-width:1000px){.team.large{grid-template-columns:repeat(2,1fr)}.mission-content{grid-template-columns:1fr}}
@media (max-width:640px){.team.large{grid-template-columns:1fr}}
.contact{display:grid;grid-template-columns:1.1fr .9fr;gap:24px}
form{display:grid;gap:10px}
input,textarea{width:100%;padding:12px 14px;border-radius:12px;border:1px solid rgba(255,255,255,.12);background:rgba(255,255,255,.03);color:var(--txt)}
textarea{min-height:140px;resize:vertical}
footer{padding:36px 0;color:#9aa4c7;border-top:1px solid rgba(255,255,255,.08)}
footer{position:relative}
footer:before{content:"";position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,#6edff6,#8fff9f,#6edff6);opacity:.9}
/* Footer enhanced */
.site-footer-inner{display:grid;grid-template-columns:1.1fr auto auto;gap:46px;align-items:start}
.footer-brand{display:flex;flex-direction:column;gap:10px;max-width:340px}
.footer-brand small{color:var(--muted);font-size:.7rem;letter-spacing:.4px}
.footer-social{display:flex;flex-direction:column;gap:14px}
.footer-social strong{font-size:.75rem;letter-spacing:.6px;font-weight:700;color:#dbe7ff}
.social-links-row{display:flex;gap:10px;flex-wrap:wrap}
.social-icon{width:42px;height:42px;border-radius:14px;display:grid;place-items:center;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.14);transition:.25s background,.25s border}
.social-icon:hover{background:rgba(255,255,255,.12);border-color:rgba(255,255,255,.28)}
.social-icon svg{width:20px;height:20px;fill:#e5f6ff}
.fair-badge{display:flex;flex-direction:column;gap:10px;align-items:flex-start}
.fair-logo{width:160px;display:block}
.fair-logo img{width:100%;height:auto;display:block;border-radius:0px;box-shadow:0 8px 22px -10px rgba(0,0,0,.55);background:#0b1020;padding:4px}
.fair-caption{font-size:.65rem;line-height:1.3;color:var(--muted);max-width:160px}
@media (max-width:900px){
  .site-footer-inner{grid-template-columns:1fr 1fr;gap:34px}
  .fair-badge{grid-column:span 2;flex-direction:row;align-items:center;gap:20px}
  .fair-caption{max-width:none}
}
@media (max-width:560px){
  .site-footer-inner{grid-template-columns:1fr;gap:30px}
  .fair-badge{grid-column:span 1;flex-direction:row;align-items:center}
}
.badges{display:flex;gap:8px;flex-wrap:wrap}
.chip{border:1px solid rgba(255,255,255,.16);border-radius:999px;padding:.35rem .6rem;color:#cde3ff;font-size:.78rem}
@media (max-width:960px){.hero-grid{grid-template-columns:1fr}.grid.cols-3{grid-template-columns:repeat(2,1fr)}.grid.cols-2{grid-template-columns:1fr}.contact{grid-template-columns:1fr}}
.section-intro{max-width:860px}
.split{display:grid;grid-template-columns:1.1fr 0.9fr;gap:42px;align-items:start}
.split.reverse{grid-template-columns:0.9fr 1.1fr}
.stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:14px;margin-top:32px}
.stat{padding:18px 16px;border:1px solid rgba(255,255,255,.08);border-radius:16px;background:linear-gradient(180deg,rgba(255,255,255,.07),rgba(255,255,255,.02));text-align:center}
.stat strong{display:block;font-size:1.6rem;line-height:1.1;background:linear-gradient(135deg,#6edff6,#8fff9f);-webkit-background-clip:text;background-clip:text;color:transparent}
.values{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:18px;margin-top:28px}
.value{padding:20px 18px;border:1px solid rgba(255,255,255,.08);border-radius:18px;background:linear-gradient(180deg,rgba(255,255,255,.05),rgba(255,255,255,.02));display:flex;gap:14px;align-items:flex-start}
.value-icon{width:40px;height:40px;border-radius:12px;background:linear-gradient(135deg,#6edff6,#8fff9f);display:grid;place-items:center;color:#0b1020;font-weight:700;font-size:.9rem;flex-shrink:0}
.timeline{position:relative;margin:40px 0 10px;padding-left:18px}
.timeline:before{content:"";position:absolute;left:4px;top:0;bottom:0;width:2px;background:linear-gradient(#6edff6,#8fff9f)}
.milestone{position:relative;margin:0 0 26px;padding-left:26px}
.milestone:before{content:"";position:absolute;left:-2px;top:4px;width:12px;height:12px;border:2px solid #0b1020;background:linear-gradient(135deg,#6edff6,#8fff9f);border-radius:50%;box-shadow:0 0 0 3px rgba(110,223,246,.35)}
.cta-stripe{margin:70px 0 10px;padding:46px 32px;border:1px solid rgba(255,255,255,.1);background:linear-gradient(120deg,rgba(110,223,246,.18),rgba(143,255,159,.12) 45%,rgba(255,255,255,.04));border-radius:26px;display:grid;gap:18px;text-align:center}
.cta-stripe h2{margin:0;font-size:clamp(1.6rem,3.2vw,2.2rem)}
.feature-grid-balanced{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:22px;margin-top:34px}
.deep-card{padding:26px 22px;display:flex;flex-direction:column;gap:14px;position:relative;background:linear-gradient(150deg,rgba(255,255,255,.11),rgba(255,255,255,.05));border:1px solid rgba(255,255,255,.16)}
.deep-card:before{content:"";position:absolute;inset:0;background:radial-gradient(circle at 85% 15%,rgba(110,223,246,.22),transparent 65%),radial-gradient(circle at 20% 85%,rgba(143,255,159,.18),transparent 70%);pointer-events:none;mix-blend-mode:overlay}
.deep-card h3{margin:0;font-size:1.15rem}
.badge-inline{display:inline-flex;align-items:center;gap:6px;font-size:.78rem;font-weight:700;letter-spacing:.5px;padding:.55rem .9rem;border-radius:14px;background:linear-gradient(90deg,#6edff6,#8fff9f);color:#05202a;box-shadow:0 4px 14px -4px rgba(0,0,0,.55)}
.deep-card .badge-inline{margin-bottom:4px}
.grid.auto{grid-template-columns:repeat(auto-fit,minmax(220px,1fr))}
.map-wrapper{position:relative;border-radius:18px;overflow:hidden;box-shadow:0 10px 28px -6px rgba(0,0,0,.45);border:1px solid rgba(255,255,255,.12);height:100%}
.map-wrapper iframe{display:block;width:100%;height:100%;min-height:0}
/* Sobre CubicAI */
.big-feature-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:28px}
.bf-card{padding:28px 24px;border:1px solid rgba(255,255,255,.1);border-radius:24px;background:linear-gradient(180deg,rgba(255,255,255,.07),rgba(255,255,255,.02));display:flex;flex-direction:column;gap:12px;position:relative;overflow:hidden}
.bf-card:before{content:"";position:absolute;inset:0;background:radial-gradient(circle at 85% 20%,rgba(255,255,255,.15),transparent 60%);pointer-events:none}
.bf-icon{width:58px;height:58px;border-radius:16px;background:linear-gradient(135deg,#6edff6,#8fff9f);display:grid;place-items:center;font-size:1.9rem;color:#0b1020;box-shadow:0 8px 24px -8px rgba(0,0,0,.5)}
.architecture-block{margin-top:90px;display:grid;gap:46px;grid-template-columns:1.1fr 0.9fr;align-items:start}
.arch-diagram{display:flex;flex-direction:column;gap:10px}
.arch-layer{padding:14px 16px;border:1px solid rgba(255,255,255,.12);background:linear-gradient(135deg,rgba(255,255,255,.06),rgba(255,255,255,.02));border-radius:14px;font-size:.85rem;display:flex;align-items:center;gap:10px}
.arch-text ul{list-style:disc;padding-left:18px;color:#cdd6ff;font-size:.85rem;line-height:1.5;margin:0}
.risk-grid{margin-top:80px;display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:24px}
.risk-card{padding:22px 20px;border:1px solid rgba(255,255,255,.1);background:linear-gradient(180deg,rgba(255,255,255,.06),rgba(255,255,255,.02));border-radius:20px;display:flex;flex-direction:column;gap:8px}
.risk-icon{width:46px;height:46px;border-radius:14px;background:linear-gradient(135deg,#6edff6,#8fff9f);display:grid;place-items:center;font-size:1.4rem;color:#0b1020;box-shadow:0 6px 18px -6px rgba(0,0,0,.5)}
@media (max-width:1000px){.architecture-block{grid-template-columns:1fr}}
/* Flujo end to end */
.flow-e2e{margin-top:40px;display:flex;flex-direction:column;gap:40px}
.flow-header h2{margin:0}
.flow-steps{display:grid;grid-template-columns:repeat(3,1fr);gap:30px;counter-reset:flow;position:relative}
@media (max-width:1100px){.flow-steps{grid-template-columns:repeat(2,1fr)}}
@media (max-width:640px){.flow-steps{grid-template-columns:1fr}}
.flow-step:after{content:"";position:absolute;top:50%;right:-15px;width:30px;height:2px;background:linear-gradient(90deg,#6edff6,#8fff9f);opacity:.55;pointer-events:none}
.flow-step:nth-child(3n):after{display:none}
@media (max-width:1100px){.flow-step:nth-child(3n):after{display:block}.flow-step:nth-child(2n):after{display:none}}
@media (max-width:640px){.flow-step:after{display:none}}

@media (min-width:1101px){
  .flow-steps{grid-template-columns:repeat(6,1fr)}
  .flow-step{grid-column:span 2}
  .flow-step:nth-child(1){grid-column:1 / span 2}
  .flow-step:nth-child(2){grid-column:3 / span 2}
  .flow-step:nth-child(3){grid-column:5 / span 2}
  .flow-step:nth-child(4){grid-column:2 / span 2}
  .flow-step:nth-child(5){grid-column:4 / span 2}
  .flow-step:nth-child(6){grid-column:3 / span 2}
  .flow-step:after{display:none}
}
/* Divisor del flujo (se reemplaza pseudo-elemento por elemento real para control fiable) */
.flow-step{--hover-bg:linear-gradient(180deg,rgba(255,255,255,.1),rgba(255,255,255,.04))}
.flow-step:nth-child(n+4){margin-top:18px}
.flow-step:nth-child(odd){background:linear-gradient(180deg,rgba(255,255,255,.085),rgba(255,255,255,.025))}
.flow-step:hover{background:var(--hover-bg)}
.flow-step{position:relative;padding:26px 22px 24px;border:1px solid rgba(255,255,255,.1);border-radius:24px;background:linear-gradient(180deg,rgba(255,255,255,.07),rgba(255,255,255,.02));display:flex;flex-direction:column;gap:14px;min-height:340px;overflow:hidden}
.flow-step:after{content:"";position:absolute;top:50%;right:-15px;width:30px;height:2px;background:linear-gradient(90deg,#6edff6,#8fff9f);opacity:.55;pointer-events:none}
.flow-step:nth-child(3n):after{display:none}
@media (max-width:1100px){.flow-step:nth-child(3n):after{display:block}.flow-step:nth-child(2n):after{display:none}}
@media (max-width:640px){.flow-step:after{display:none}}
.flow-step h3{margin:0;font-size:1.05rem}
.flow-badge{width:38px;height:38px;border-radius:14px;background:linear-gradient(135deg,#6edff6,#8fff9f);display:grid;place-items:center;font-weight:700;color:#0b1020;font-size:.95rem;box-shadow:0 8px 24px -8px rgba(0,0,0,.55)}
.flow-desc{color:var(--muted);font-size:.84rem;line-height:1.45;margin:0}
.flow-media{margin-top:auto;aspect-ratio:4/3;border:1px solid rgba(255,255,255,.14);border-radius:16px;display:grid;place-items:center;font-size:.7rem;letter-spacing:.5px;color:var(--muted);background:radial-gradient(circle at 30% 30%,rgba(110,223,246,.18),transparent 60%),radial-gradient(circle at 80% 60%,rgba(143,255,159,.15),transparent 60%);overflow:hidden}
/* Contenedor con imagen real: quitar aspect-ratio fijo para no recortar */
.flow-media.media-img{aspect-ratio:auto;display:block;padding:0}
.flow-media img{width:100%;height:auto;display:block;background:#0b1020}
.flow-step:hover{border-color:rgba(255,255,255,.18);background:linear-gradient(180deg,rgba(255,255,255,.1),rgba(255,255,255,.03))}
.channel-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:28px;margin-top:28px}
.channel{position:relative;padding:26px 24px 22px;border:1px solid rgba(255,255,255,.12);border-radius:26px;display:flex;flex-direction:column;gap:12px;align-items:flex-start;overflow:hidden;background:linear-gradient(145deg,rgba(255,255,255,.06),rgba(255,255,255,.02));min-height:240px}
.channel:hover{border-color:rgba(255,255,255,.22);background:linear-gradient(145deg,rgba(255,255,255,.1),rgba(255,255,255,.03))}
.channel:before{content:"";position:absolute;inset:0;pointer-events:none;background:radial-gradient(circle at 85% 15%,rgba(255,255,255,.18),transparent 55%)}
.channel-logo{width:58px;height:58px;border-radius:16px;display:grid;place-items:center;box-shadow:0 6px 18px -6px rgba(0,0,0,.5);background:#121a2e}
.channel svg{width:34px;height:34px}
.channel p{margin:0;color:var(--muted);font-size:.85rem;line-height:1.4}
.channel a.btn{margin-top:auto}
.channel.youtube{background:linear-gradient(150deg,rgba(255,0,0,.22),rgba(255,255,255,.03));}
.channel.linkedin{background:linear-gradient(150deg,rgba(14,118,168,.28),rgba(255,255,255,.03));}
.channel.instagram{background:linear-gradient(150deg,rgba(193,53,132,.35),rgba(255,255,255,.02));}
.channel.youtube .channel-logo{background:#ff0000}
.channel.linkedin .channel-logo{background:#0a66c2}
.channel.instagram .channel-logo{background:linear-gradient(135deg,#feda75,#d62976,#962fbf,#4f5bd5)}
.email-box{padding:22px 20px;border:1px dashed rgba(255,255,255,.25);border-radius:16px;display:flex;flex-direction:column;gap:8px}
.email-box code{background:rgba(255,255,255,.1);padding:4px 8px;border-radius:8px;font-size:.85rem}
.two-col{display:grid;grid-template-columns:1fr 1fr;gap:42px;align-items:start}
@media (max-width:960px){.split,.two-col{grid-template-columns:1fr}.feature-grid-balanced{grid-template-columns:1fr}}
/* Evento (Feria) - layout mapa izquierda */
.fair-layout{display:grid;grid-template-columns:1.25fr .75fr;gap:48px;margin-top:28px;align-items:start}
.fair-layout{align-items:stretch}
.fair-map{height:100%;min-height:340px}
.event-side{display:flex;flex-direction:column;gap:46px}
.event-location-block{display:flex;gap:22px;align-items:flex-start}
.event-location-text{font-size:1.15rem;line-height:1.45;font-weight:600}
.event-location-text span{font-weight:400;color:var(--muted)}
.event-meta-row{display:flex;gap:48px;flex-wrap:wrap;align-items:flex-start}
.event-item{display:flex;flex-direction:row;align-items:flex-start;gap:18px;text-align:left;min-width:260px}
.event-item.location .event-item-text{max-width:340px}
.event-item-text{display:flex;flex-direction:column;gap:6px}
.event-item-label{font-size:.65rem;letter-spacing:.55px;color:var(--muted);text-transform:uppercase;font-weight:600}
.event-item-value{font-size:1.15rem;font-weight:600;line-height:1.25}
.event-icon{width:62px;height:62px;border-radius:18px;background:linear-gradient(135deg,#6edff6,#8fff9f);display:grid;place-items:center;font-size:1.55rem;color:#0b1020;box-shadow:0 10px 26px -8px rgba(0,0,0,.55)}
.event-icon svg{width:34px;height:34px;display:block}
.event-icon svg{width:30px;height:30px}
/* Normalización iconos feria y ajuste de texto largo */
.event-icon{line-height:1}
.event-item-value{word-break:break-word}
.event-item.location .event-item-value{max-width:300px}
/* Ajuste específico mobile: mejorar alineación de ubicación para que no parezca distinta */
@media (max-width:640px){
  .event-meta-row{flex-direction:column;gap:28px}
  .event-item{display:grid;grid-template-columns:58px 1fr;min-width:0;width:100%;align-items:start}
  .event-item .event-icon{width:58px;height:58px;margin-top:2px}
  .event-item .event-item-text{max-width:100%}
  .event-item .event-item-value{max-width:100%;line-height:1.25}
  .event-item.location .event-item-value{font-size:1.05rem}
}
@media (max-width:960px){
  .fair-layout{grid-template-columns:1fr;gap:40px}
  .fair-map{min-height:0;height:auto}
  .event-side{gap:38px}
  .event-meta-row{justify-content:center;gap:40px}
  .event-item{min-width:220px}
  .event-icon{width:54px;height:54px;font-size:1.35rem}
  .event-item-value{font-size:1.05rem}
}
/* Enlace Feria oficial */
.fair-link{display:inline-flex;align-items:center;gap:6px;margin-top:4px;font-size:.63rem;font-weight:600;letter-spacing:.55px;padding:.45rem .7rem;border-radius:10px;text-transform:uppercase;background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.15);color:#cfe9ff;text-decoration:none;transition:.2s background,.2s border,.2s color}
.fair-link:hover{background:linear-gradient(90deg,#6edff6,#8fff9f);color:#05202a;border-color:transparent;text-decoration:none}
.fair-link svg{width:12px;height:12px;fill:currentColor}
.fair-poster-wrapper{margin-top:70px;position:relative;display:block;padding:0;background:none;border:none;border-radius:0;box-shadow:none}
.fair-poster-wrapper:before{content:none}
.fair-poster{width:100%;max-width:1200px;margin:0 auto;display:block;background:none;border:none;padding:0;box-shadow:none}
.fair-poster img{display:block;width:100%;height:auto;max-height:80vh;object-fit:contain;border-radius:18px;border:1px solid rgba(255,255,255,.15);box-shadow:0 12px 36px -14px rgba(0,0,0,.6)}
.fair-event-info{margin:16px auto 0;max-width:780px;font-size:.99rem;line-height:1.45;color:var(--muted);text-align:center}
.fair-event-info a{color:var(--acc);font-weight:600;text-decoration:none}
.fair-event-info a:hover{text-decoration:underline}
@media (max-width:860px){
  .fair-poster-wrapper{padding:38px 24px;margin-top:60px}
  .fair-poster{padding:10px}
}
.video-section{padding:72px 0 90px}
.video-header{max-width:820px;margin:0 auto 34px}
.video-wrapper{display:flex;flex-direction:column;gap:22px;max-width:860px;margin:0 auto}
.video-aspect{position:relative;width:100%;aspect-ratio:16/9;border-radius:24px;overflow:hidden;border:1px solid rgba(255,255,255,.12);background:radial-gradient(circle at 35% 30%,rgba(110,223,246,.22),transparent 60%),radial-gradient(circle at 80% 65%,rgba(143,255,159,.2),transparent 60%),linear-gradient(135deg,#1a2338,#101a30);box-shadow:0 14px 34px -10px rgba(0,0,0,.55)}
.video-aspect iframe{position:absolute;inset:0;width:100%;height:100%;border:0}
.video-meta{display:flex;flex-direction:column;gap:12px}
.video-tags{display:flex;gap:8px;flex-wrap:wrap}
.video-note{margin:0;font-size:.78rem;color:var(--muted);letter-spacing:.3px}
.video-grid{display:grid;grid-template-columns:1.1fr .9fr;gap:48px;align-items:start}
.video-left{position:relative}
.video-right{display:flex;flex-direction:column;gap:16px}
.video-points{margin:1px 0 0;padding-left:18px;font-size:.85rem;line-height:1.5;color:#cfd8ef}
.video-points li{margin:0 0 6px}
@media (max-width:1000px){
  .video-grid{grid-template-columns:1fr;gap:34px}
}
@media (max-width:960px){
  .video-wrapper{max-width:100%}
  .video-aspect{border-radius:20px}
}
