/* ===== Fuente de marca: Gadugi (manual Prokap) ===== */
@font-face{
  font-family:'Gadugi';
  src:url('../assets/fonts/gadugi.woff2') format('woff2');
  font-weight:400 700;
  font-style:normal;
  font-display:swap;
}

/* ===== Variables (Manual de marca Prokap IB) ===== */
:root{
  --plum:#3B0640;
  --plum2:#4A0652;
  --purple:#6A1F86;
  --purple-light:#8a2ba6;
  --magenta:#900999;
  --magenta-light:#B11C97;
  --indigo:#171A4A;
  --ink:#241726;
  --muted:#5e5266;
  --line:#ece4f0;
  --bg:#ffffff;
  --bg-alt:#f7f2fa;
  --radius:16px;
  --shadow:0 10px 30px rgba(59,6,64,.08);
  --shadow-lg:0 24px 60px rgba(35,4,40,.18);
  --maxw:1160px;
  --font:'Gadugi','Segoe UI',system-ui,-apple-system,Roboto,Helvetica,Arial,sans-serif;
  --display:'Gadugi','Segoe UI',system-ui,sans-serif;
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;scroll-padding-top:84px;-webkit-text-size-adjust:100%}
body{font-family:var(--font);color:var(--ink);background:var(--bg);line-height:1.65;font-size:17px;overflow-x:hidden}
img,svg{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
ul{list-style:none}
h1,h2{font-family:var(--display);line-height:1.14;font-weight:700;letter-spacing:-.01em;color:var(--ink)}
h3,h4{line-height:1.2;font-weight:700;letter-spacing:-.01em;color:var(--ink)}
h2{font-size:clamp(1.7rem,3.4vw,2.55rem)}
h3{font-size:1.3rem}
section{scroll-margin-top:80px}

.container{width:100%;max-width:var(--maxw);margin:0 auto;padding:0 24px}
.skip-link{position:absolute;left:-999px;top:0;background:var(--magenta);color:#fff;padding:10px 16px;z-index:200;border-radius:0 0 8px 0;font-weight:700}
.skip-link:focus{left:0}

/* ===== Brand lockup ===== */
.brand{display:inline-flex;align-items:center;gap:11px}
.brand__img{height:46px;width:auto;display:block}
.brand__img--footer{height:50px;margin-bottom:14px}
.brand__mark{display:flex;flex:0 0 auto}
.brand__mark svg{display:block}
.brand__text{display:flex;flex-direction:column;line-height:1}
.brand__name{font-family:var(--display);font-weight:700;font-size:1.24rem;color:#fff;letter-spacing:.005em}
.brand__tag{font-size:.6rem;letter-spacing:.22em;text-transform:uppercase;color:rgba(255,255,255,.62);margin-top:4px}

/* ===== Buttons ===== */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:14px 26px;border-radius:999px;font-weight:700;font-size:1rem;cursor:pointer;border:2px solid transparent;transition:transform .18s ease,box-shadow .18s ease,filter .18s ease,background .18s ease,color .18s ease}
.btn--accent{background:linear-gradient(135deg,var(--magenta-light),var(--purple));color:#fff;box-shadow:0 8px 22px rgba(144,9,153,.38)}
.btn--accent:hover{filter:brightness(1.08);transform:translateY(-2px)}
.btn--purple{background:var(--purple);color:#fff}
.btn--purple:hover{background:var(--magenta);transform:translateY(-2px)}
.btn--ghost{background:transparent;color:#fff;border-color:rgba(255,255,255,.5)}
.btn--ghost:hover{background:rgba(255,255,255,.12);border-color:#fff}
.btn--ghost-dark{background:transparent;color:var(--purple);border-color:var(--purple)}
.btn--ghost-dark:hover{background:var(--purple);color:#fff}
.btn--block{width:100%}

/* ===== Header ===== */
.site-header{position:fixed;top:0;left:0;right:0;z-index:100;transition:background .3s ease,box-shadow .3s ease,padding .3s ease;padding:13px 0}
.site-header.scrolled{background:rgba(35,4,40,.96);backdrop-filter:saturate(160%) blur(10px);box-shadow:0 6px 24px rgba(0,0,0,.2);padding:7px 0}
.header__inner{display:flex;align-items:center;justify-content:space-between;gap:20px}
.nav{display:flex;align-items:center;gap:26px}
.nav a{color:#fff;font-weight:600;font-size:.98rem;opacity:.9;transition:opacity .2s,color .2s}
.nav a:hover{opacity:1}
.nav__icon{display:inline-flex;opacity:.82}
.nav__icon:hover{color:var(--magenta-light);opacity:1}
.nav__cta{background:linear-gradient(135deg,var(--magenta-light),var(--purple));color:#fff!important;padding:9px 20px;border-radius:999px;opacity:1!important}
.nav__cta:hover{filter:brightness(1.08)}
.nav-toggle{display:none;flex-direction:column;gap:5px;background:none;border:0;cursor:pointer;padding:8px}
.nav-toggle span{width:26px;height:3px;background:#fff;border-radius:3px;transition:.3s}
.nav-toggle[aria-expanded="true"] span:nth-child(1){transform:translateY(8px) rotate(45deg)}
.nav-toggle[aria-expanded="true"] span:nth-child(2){opacity:0}
.nav-toggle[aria-expanded="true"] span:nth-child(3){transform:translateY(-8px) rotate(-45deg)}

/* ===== Hero ===== */
.hero{position:relative;background:radial-gradient(1100px 560px at 82% -10%,var(--purple),transparent),linear-gradient(155deg,var(--plum2) 0%,var(--plum) 55%,var(--indigo) 145%);color:#fff;padding:150px 0 80px;overflow:hidden}
.hero__grid{position:relative;display:grid;grid-template-columns:1.15fr .85fr;gap:40px;align-items:center}
.hero__eyebrow{color:#E9A6E4;font-weight:700;letter-spacing:.16em;text-transform:uppercase;font-size:.8rem;margin-bottom:16px}
.hero__title{font-size:clamp(2.2rem,5vw,3.6rem);color:#fff;margin-bottom:18px}
.hero__title span{background:linear-gradient(90deg,#f0b6ec,#c98ff0);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}
.hero__lead{font-size:1.1rem;color:rgba(255,255,255,.85);max-width:560px;margin-bottom:30px}
.hero__actions{display:flex;gap:14px;flex-wrap:wrap;margin-bottom:42px}
.hero__stats{display:flex;gap:40px;flex-wrap:wrap;border-top:1px solid rgba(255,255,255,.15);padding-top:28px}
.hero__stats>div{max-width:190px}
.hero__stats strong{display:block;font-size:2.1rem;color:#fff;font-family:var(--display);margin-bottom:10px;line-height:1}
.hero__stats .stat-label{font-size:.86rem;color:rgba(255,255,255,.72);line-height:1.5}
.count{font:inherit;color:inherit;vertical-align:baseline}
.hero__media{display:flex;justify-content:center}
.hero__photo-wrap{position:relative;display:flex;justify-content:center;align-items:flex-end}
.hero__photo-wrap::before{content:"";position:absolute;left:50%;top:46%;transform:translate(-50%,-50%);width:380px;height:380px;background:radial-gradient(circle,rgba(177,28,151,.30),transparent 70%);filter:blur(10px);pointer-events:none}
.hero__photo{position:relative;width:100%;max-width:360px;height:auto;filter:drop-shadow(0 22px 34px rgba(0,0,0,.4))}

/* ===== Sections ===== */
.section{padding:88px 0}
.section--alt{background:var(--bg-alt)}
.section__head{max-width:740px;margin:0 auto 48px;text-align:center}
.section__sub{color:var(--muted);font-size:1.08rem;margin-top:14px}
.eyebrow{color:var(--magenta);font-weight:700;letter-spacing:.06em;text-transform:uppercase;font-size:.8rem;margin-bottom:10px}
.eyebrow--light{color:#E9A6E4}
.section__head--light h2{color:#fff}

/* ===== Cards ===== */
.cards{display:grid;grid-template-columns:repeat(3,1fr);gap:26px}
.card{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:34px 28px;box-shadow:var(--shadow);transition:transform .25s ease,box-shadow .25s ease}
.card:hover{transform:translateY(-6px);box-shadow:var(--shadow-lg)}
.card__icon{width:64px;height:64px;margin-bottom:18px}
.card__ic{width:54px;height:54px;margin-bottom:20px;fill:none;stroke:var(--purple);stroke-width:1.6;stroke-linecap:round;stroke-linejoin:round}
.card h3{margin-bottom:12px;color:var(--plum)}
.card p{color:var(--muted);font-size:1rem}
.card--edu{background:var(--bg-alt);border-color:transparent}
.section--alt .card{background:#fff}
.edu__cta{text-align:center;margin-top:42px}

/* ===== About ===== */
.about__grid{display:grid;grid-template-columns:.85fr 1.15fr;gap:50px;align-items:start}
.about__media{display:flex;justify-content:center;position:sticky;top:90px}
.about__photo-wrap{position:relative;display:flex;justify-content:center;width:100%;max-width:360px}
.about__photo-wrap::before{content:"";position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);width:330px;height:330px;background:radial-gradient(circle,rgba(177,28,151,.16),transparent 70%);filter:blur(8px);pointer-events:none}
.about__photo{position:relative;width:100%;height:auto;filter:drop-shadow(0 18px 30px rgba(35,4,40,.22))}
.about__content h2{margin-bottom:4px}
.about__role{color:var(--magenta);font-weight:700;margin-bottom:18px}
.about__content p{color:var(--muted);margin-bottom:16px}
.about__linkedin{display:inline-flex;align-items:center;gap:8px;margin-top:8px;color:var(--purple);font-weight:700}
.about__linkedin:hover{color:var(--magenta)}

/* ===== Trayectoria (oscuro) ===== */
.section--navy{background:linear-gradient(155deg,var(--plum2) 0%,var(--plum) 60%,var(--indigo) 155%);color:#fff}
.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:20px}
.stat{background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.12);border-radius:var(--radius);padding:30px 20px;text-align:center}
.stat strong{display:block;font-family:var(--display);font-size:2.2rem;color:#E9A6E4;margin-bottom:12px;line-height:1}
.stat .stat-label{color:rgba(255,255,255,.78);font-size:.95rem;line-height:1.45}

/* ===== Bloques de logos / cintas ===== */
.logos-block{max-width:var(--maxw);margin:54px auto 0;padding:0 24px}
.logos-block__title{text-align:center;font-size:1.05rem;margin-bottom:24px;color:var(--ink)}
.logos-block__title--light{color:#fff}
.sectores{margin-top:54px}

.marquee{position:relative;overflow:hidden;-webkit-mask-image:linear-gradient(90deg,transparent,#000 7%,#000 93%,transparent);mask-image:linear-gradient(90deg,transparent,#000 7%,#000 93%,transparent)}
.marquee__track{display:flex;gap:18px;width:max-content;animation:scroll-x 40s linear infinite}
.marquee__track--slow{animation-duration:52s}
.marquee__track--rev{animation-duration:60s;animation-direction:reverse}
.marquee:hover .marquee__track{animation-play-state:paused}
@keyframes scroll-x{to{transform:translateX(-50%)}}

.sct{display:inline-flex;align-items:center;gap:10px;white-space:nowrap;background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.14);color:#fff;padding:12px 20px;border-radius:999px;font-weight:600;font-size:.95rem}
.sct svg{width:22px;height:22px;fill:none;stroke:#E9A6E4;stroke-width:1.7;stroke-linejoin:round;stroke-linecap:round;flex:0 0 auto}

.logo-chip{flex:0 0 auto;display:flex;align-items:center;justify-content:center;width:190px;height:90px;background:#fff;border-radius:14px;padding:16px 24px;box-shadow:0 10px 26px rgba(35,4,40,.16);transition:transform .2s ease}
.logo-chip:hover{transform:translateY(-4px)}
.logo-chip img{max-width:100%;max-height:100%;width:auto;height:auto;object-fit:contain}

/* ===== Contacto ===== */
.contact__grid{display:grid;grid-template-columns:1fr 1fr;gap:50px;align-items:start}
.contact__info h2{margin-bottom:16px}
.contact__info p{color:var(--muted);margin-bottom:26px}
.contact__list{margin-bottom:24px;display:grid;gap:18px}
.contact__item{display:flex;gap:14px;align-items:flex-start}
.contact__ic{width:26px;height:26px;fill:none;stroke:var(--purple);stroke-width:1.7;stroke-linecap:round;stroke-linejoin:round;flex:0 0 auto;margin-top:3px}
.contact__text{display:flex;flex-direction:column}
.contact__label{display:block;font-size:.78rem;text-transform:uppercase;letter-spacing:.05em;color:var(--muted);font-weight:700;margin-bottom:2px}
.contact__list a{font-size:1.12rem;font-weight:700;color:var(--purple)}
.contact__list a:hover{color:var(--magenta)}
.contact__actions{display:flex;gap:12px;flex-wrap:wrap}
.contact__form{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:32px;box-shadow:var(--shadow)}
.field{margin-bottom:16px}
.field label{display:block;font-weight:600;font-size:.9rem;margin-bottom:6px}
.field input,.field textarea{width:100%;padding:13px 15px;border:1.5px solid var(--line);border-radius:10px;font-family:inherit;font-size:1rem;color:var(--ink);transition:border-color .2s,box-shadow .2s;background:#fcfbfe}
.field input:focus,.field textarea:focus{outline:none;border-color:var(--purple);box-shadow:0 0 0 3px rgba(106,31,134,.14)}
.form__legal{font-size:.78rem;color:var(--muted);margin-top:14px;text-align:center}
.contact__media{display:flex;justify-content:center;align-items:flex-end}
.contact__photo-wrap{position:relative;display:flex;justify-content:center;width:100%;max-width:380px}
.contact__photo-wrap::before{content:"";position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);width:360px;height:360px;background:radial-gradient(circle,rgba(177,28,151,.16),transparent 70%);filter:blur(8px);pointer-events:none}
.contact__photo{position:relative;width:100%;height:auto;filter:drop-shadow(0 18px 30px rgba(35,4,40,.22))}

/* ===== Footer ===== */
.footer{background:var(--plum);color:rgba(255,255,255,.8)}
.footer__grid{display:grid;grid-template-columns:1.6fr 1fr 1fr;gap:40px;padding:56px 0 40px}
.brand--footer{margin-bottom:14px}
.footer__brand p{font-size:.95rem;max-width:360px}
.footer__social{display:inline-flex;margin-top:16px;color:#fff;opacity:.85}
.footer__social:hover{color:var(--magenta-light);opacity:1}
.footer__col h4{color:#fff;margin-bottom:16px;font-size:1.05rem;font-weight:700;letter-spacing:.01em}
.footer__nav li{margin-bottom:11px}
.footer__nav a{display:inline-flex;align-items:center;gap:9px}
.footer__nav svg{width:16px;height:16px;fill:var(--magenta-light);flex:0 0 auto;opacity:.9}
.footer__nav a:hover{color:#fff}
.footer__bottom{border-top:1px solid rgba(255,255,255,.1);padding:18px 0;font-size:.85rem;text-align:center}

/* ===== WhatsApp float ===== */
.wa-float{position:fixed;right:20px;bottom:20px;width:56px;height:56px;border-radius:50%;background:#25D366;color:#fff;display:flex;align-items:center;justify-content:center;box-shadow:0 8px 24px rgba(37,211,102,.45);z-index:90;transition:transform .2s}
.wa-float:hover{transform:scale(1.08)}

/* ===== Reveal ===== */
.js .reveal{opacity:0;transform:translateY(24px);transition:opacity .7s ease,transform .7s ease}
.js .reveal.in{opacity:1;transform:none}
@media (prefers-reduced-motion:reduce){.js .reveal{opacity:1;transform:none;transition:none}html{scroll-behavior:auto}.marquee__track{animation:none}}

/* ===== Responsive ===== */
@media(max-width:900px){
  .hero__grid{grid-template-columns:1fr;text-align:center}
  .hero__content{order:2}
  .hero__media{order:1}
  .hero__actions,.hero__stats{justify-content:center}
  .hero__lead{margin-left:auto;margin-right:auto}
  .hero__stats>div{max-width:140px}
  .about__grid{grid-template-columns:1fr;gap:34px}
  .about__media{order:2;position:static}
  .contact__grid{grid-template-columns:1fr;gap:34px}
  .stats{grid-template-columns:repeat(2,1fr)}
  .cards{grid-template-columns:1fr 1fr}
  .footer__grid{grid-template-columns:1fr 1fr}
}
@media(max-width:720px){
  .nav-toggle{display:flex}
  .nav{position:fixed;inset:0 0 0 auto;width:min(78vw,320px);flex-direction:column;align-items:flex-start;gap:6px;background:var(--plum);padding:90px 28px 28px;transform:translateX(100%);transition:transform .32s ease;box-shadow:-10px 0 40px rgba(0,0,0,.3)}
  .nav.open{transform:translateX(0)}
  .nav a{font-size:1.1rem;padding:10px 0;width:100%;border-bottom:1px solid rgba(255,255,255,.08)}
  .nav__icon{padding:12px 0}
  .nav__cta{margin-top:10px;border-bottom:0!important}
  body.menu-open{overflow:hidden}
  .brand__img{height:38px}
}
@media(max-width:560px){
  .container{padding:0 28px}
  .section{padding:60px 0}
  .cards{grid-template-columns:1fr}
  .footer__grid{grid-template-columns:1fr}
  .hero{padding:120px 0 60px}
  /* Stats hero: apiladas, centradas */
  .hero__stats{flex-direction:column;align-items:center;gap:26px}
  .hero__stats>div{max-width:100%;text-align:center}
  .hero__stats strong{font-size:1.9rem}
  /* Trayectoria: una columna (evita overflow) */
  .stats{grid-template-columns:1fr;gap:14px}
  .stat{padding:24px 18px}
  .stat strong{font-size:1.7rem}
  .contact__actions .btn{flex:1}
  .logo-chip{width:150px;height:76px;padding:14px 18px}
}
