/* ============================ TOKENS ============================ */
:root{
  --navy:#13273c;
  --navy-2:#1a334d;
  --navy-3:#22405f;

  --stone:#f5f3ee;
  --stone-2:#ece8df;
  --stone-card:#fbf9f4;

  --ink:#13273c;
  --ink-2:#455563;
  --ink-muted:#3a4d5c;
  --on-dark:#eef1f5;
  --on-dark-2:#b6c6d6;

  --gold:#b8883a;
  --gold-d:#8a6424;
  --gold-light:#d4b56a;
  --champagne:#d4b56a;
  --gold-grad:linear-gradient(115deg,#8a6424 0%,#c2974a 46%,#d4b56a 70%,#a87c2c 100%);

  --text-placeholder:#9aacbc;

  --hair-d:rgba(210,173,92,.22);
  --hair-d2:rgba(238,241,245,.12);
  --hair-l:rgba(19,39,60,.14);
  --hair-l2:rgba(19,39,60,.08);

  --f-serif:"Cormorant Garamond",Georgia,"Times New Roman",serif;
  --f-sans:"Inter",system-ui,-apple-system,sans-serif;
  --f-logo:"Montserrat",system-ui,sans-serif;

  --wrap:1180px;

  /* Spacing — mobile first */
  --gut:1.25rem;
  --sec-py:2.6rem;
  --block-gap:2rem;
  --card-gap:1.125rem;
  --stack-sm:1rem;
  --stack-md:1.5rem;
  --stack-lg:2.25rem;
  --scroll-offset:5rem;

  --text-min:.95rem;
}

/* ============================ RESET ============================ */
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{font-family:var(--f-sans);background:var(--stone);color:var(--ink);line-height:1.65;font-size:clamp(var(--text-min),1.04vw,1.03125rem);overflow-x:hidden;-webkit-font-smoothing:antialiased}
img,svg{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
::selection{background:rgba(210,173,92,.3);color:#13273c}

/* ============================ HELPERS ============================ */
.wrap{max-width:var(--wrap);margin:0 auto;padding-inline:var(--gut)}
.sec{padding-block:var(--sec-py);position:relative;scroll-margin-top:var(--scroll-offset)}
.eyebrow{font-family:var(--f-sans);font-size:var(--text-min);font-weight:600;letter-spacing:.24em;text-transform:uppercase;color:var(--gold-light);display:inline-flex;align-items:center;gap:.8em}
.eyebrow::before{content:"";width:30px;height:1px;background:var(--gold-light);opacity:.85}
.sec--light .eyebrow,.sec--stone2 .eyebrow{color:var(--gold-d)}
.sec--light .eyebrow::before,.sec--stone2 .eyebrow::before{background:var(--gold-d);opacity:1}
.h2{font-family:var(--f-serif);font-weight:600;letter-spacing:-.01em;font-size:clamp(2rem,4.3vw,3.4rem);line-height:1.08;margin-top:var(--stack-sm);max-width:20ch}
.lead{font-size:clamp(1.04rem,1.4vw,1.22rem);line-height:1.7;max-width:62ch;margin-top:var(--stack-md)}
.serif-em{font-family:var(--f-serif);font-style:italic;font-weight:500}
.metric-val{font-size:calc(1em * 1.15);font-weight:inherit;white-space:nowrap;line-height:1}
.metric-u{font-size:calc(1em * .65);font-weight:inherit;line-height:1}

.sec--dark{background:var(--navy);color:var(--on-dark)}
.sec--dark .lead{color:var(--on-dark-2)}
.sec--light{background:var(--stone);color:var(--ink)}
.sec--light .lead{color:var(--ink-2)}
.sec--stone2{background:var(--stone-2)}

.sec--alliances{background:var(--navy);color:var(--on-dark);position:relative;isolation:isolate}
.sec--alliances::before{content:"";position:absolute;inset:0;z-index:0;background:radial-gradient(95% 70% at 50% 0%,rgba(210,173,92,.14),transparent 58%),radial-gradient(80% 60% at 100% 100%,rgba(210,173,92,.08),transparent 50%);pointer-events:none}
.sec--alliances .wrap{position:relative;z-index:1}
.sec--alliances .h2{max-width:22ch;color:var(--on-dark)}
.sec--alliances .lead{color:var(--on-dark-2);max-width:58ch}

.reveal{opacity:0;transform:translateY(18px);transition:opacity 1s ease,transform 1s cubic-bezier(.2,.7,.2,1)}
.reveal.in{opacity:1;transform:none}
.reveal.reveal-stagger{opacity:1;transform:none}
.reveal.reveal-stagger>*{opacity:0;transform:translateY(30px) scale(.965)}
.reveal.reveal-stagger.in>*{animation:box-in .85s cubic-bezier(.22,.75,.2,1) both}
.reveal.reveal-stagger.in>*:nth-child(1){animation-delay:0s}
.reveal.reveal-stagger.in>*:nth-child(2){animation-delay:.1s}
.reveal.reveal-stagger.in>*:nth-child(3){animation-delay:.2s}
.reveal.reveal-stagger.in>*:nth-child(4){animation-delay:.3s}
.reveal.reveal-stagger.in>*:nth-child(5){animation-delay:.4s}
.reveal.reveal-stagger.in>*:nth-child(6){animation-delay:.5s}
@keyframes box-in{from{opacity:0;transform:translateY(30px) scale(.965)}to{opacity:1;transform:none}}
.box{opacity:0;transform:translateY(24px) scale(.97);transition:transform .4s cubic-bezier(.2,.7,.2,1),box-shadow .4s ease,border-color .35s ease}
.box.box-in,.reveal-stagger.in>.box{opacity:1;transform:none}
.box.box-in{animation:box-in .85s cubic-bezier(.22,.75,.2,1) both}
.box:hover{transform:translateY(-4px) scale(1.01)}
.reveal-stagger.in>.box:hover{transform:translateY(-4px) scale(1.01)}

/* ============================ BUTTONS ============================ */
.btn{font-family:var(--f-sans);font-weight:600;font-size:var(--text-min);letter-spacing:.01em;display:inline-flex;align-items:center;gap:.6em;padding:.85em 1.55em;border-radius:1px;cursor:pointer;border:1px solid transparent;transition:transform .3s ease,background .3s ease,color .3s ease,border-color .3s ease}
.btn .ar{transition:transform .3s ease}
.btn:hover .ar{transform:translateX(4px)}
.btn--primary{background:var(--gold);color:#13273c}
.btn--primary:hover{background:var(--gold-d);color:#fff;transform:translateY(-2px)}
.btn--ghost-d{border-color:var(--hair-d);color:var(--on-dark)}
.btn--ghost-d:hover{border-color:var(--gold-light);color:var(--gold-light)}

/* ============================ HEADER ============================ */
.hdr{position:fixed;inset:0 0 auto 0;z-index:60;transition:background .45s ease,border-color .45s ease,backdrop-filter .45s ease,border-bottom-color .45s ease;border-bottom:1px solid transparent}
.hdr.scrolled{background:rgba(245,243,238,.88);backdrop-filter:blur(16px) saturate(115%);-webkit-backdrop-filter:blur(16px) saturate(115%);border-bottom-color:var(--hair-l)}
.hdr.on-dark-bg.scrolled{background:rgba(245,243,238,.94);box-shadow:0 4px 24px rgba(8,20,32,.12)}
.hdr__in{display:flex;align-items:center;justify-content:space-between;height:80px}
.brand{display:flex;flex-direction:column;line-height:1;gap:4px}
.brand__mark{display:flex;align-items:flex-end}
.brand__txt{font-family:var(--f-logo);font-weight:800;font-size:1.34rem;letter-spacing:-.01em;color:var(--gold-light)}
.hdr.scrolled .brand__txt{color:var(--gold-d)}
@supports ((-webkit-background-clip:text) or (background-clip:text)){
  .brand__txt{background:var(--gold-grad);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;color:transparent}
  .hdr.scrolled .brand__txt{background:linear-gradient(115deg,#8a6424 0%,#b8883a 50%,#8a6424 100%);-webkit-background-clip:text;background-clip:text}
}
.brand__arrow{width:1.0em;height:1.34em;margin:0 -.05em 0 -.03em;align-self:flex-end;position:relative;top:-.04em}
.brand__sub{font-family:var(--f-serif);font-weight:500;font-size:var(--text-min);letter-spacing:.2em;text-transform:uppercase;padding-left:.2em;transition:color .4s ease}
.hdr .brand__sub{color:var(--on-dark-2)}
.hdr.scrolled .brand__sub{color:var(--ink-2)}
.nav{display:flex;align-items:center;gap:clamp(16px,2.1vw,32px)}
.nav a:not(.btn){font-size:var(--text-min);font-weight:500;position:relative;padding:.3em 0;transition:color .3s ease;white-space:nowrap}
.hdr .nav a:not(.btn){color:var(--on-dark-2)}
.hdr.scrolled .nav a:not(.btn){color:var(--ink-muted)}
.nav a:not(.btn)::after{content:"";position:absolute;left:0;bottom:-3px;height:1px;width:0;background:var(--gold);transition:width .35s ease}
.hdr .nav a:not(.btn):hover{color:var(--on-dark)}
.hdr.scrolled .nav a:not(.btn):hover{color:var(--ink)}
.nav a:not(.btn):hover::after{width:100%}
.burger{display:none;background:none;border:0;cursor:pointer;width:42px;height:42px;position:relative}
.burger span{position:absolute;left:9px;right:9px;height:1.5px;transition:.3s;border-radius:2px}
.hdr .burger span{background:var(--on-dark)}
.hdr.scrolled .burger span{background:var(--ink)}
.burger span:nth-child(1){top:16px}.burger span:nth-child(2){top:21px}.burger span:nth-child(3){top:26px}
.burger.open span:nth-child(1){top:21px;transform:rotate(45deg)}
.burger.open span:nth-child(2){opacity:0}
.burger.open span:nth-child(3){top:21px;transform:rotate(-45deg)}

/* ============================ HERO ============================ */
.hero{position:relative;min-height:100svh;display:flex;align-items:center;background:var(--navy);color:var(--on-dark);overflow:hidden;isolation:isolate;scroll-margin-top:var(--scroll-offset)}
.hero__veil{position:absolute;inset:0;z-index:1;background:radial-gradient(115% 90% at 80% 16%,rgba(210,173,92,.13),transparent 50%),linear-gradient(180deg,rgba(19,39,60,.15) 0%,rgba(19,39,60,.5) 72%,var(--navy) 100%)}
.hero__in{position:relative;z-index:2;width:100%;padding-top:calc(var(--scroll-offset) + 1.75rem);padding-bottom:7.5rem}
.hero h1{font-family:var(--f-serif);font-weight:600;letter-spacing:-.012em;font-size:clamp(2.7rem,6.2vw,5.2rem);line-height:1.03;margin-top:var(--stack-md);max-width:18ch}
.hero h1 .serif-em{color:var(--gold-light)}
@supports ((-webkit-background-clip:text) or (background-clip:text)){.hero h1 .serif-em{background:var(--gold-grad);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;color:transparent}}
.hero__sub{font-size:clamp(1.05rem,1.55vw,1.3rem);line-height:1.65;color:var(--on-dark-2);max-width:52ch;margin-top:var(--stack-md);font-weight:400}
.hero__cta{display:flex;flex-wrap:wrap;gap:.875rem;margin-top:var(--stack-lg)}
.hero__stats{display:grid;grid-template-columns:1fr;gap:0;margin-top:var(--stack-lg);border-top:1px solid var(--hair-d2);padding-top:var(--stack-md)}
.hstat{padding:var(--stack-md) 0;border-bottom:1px solid var(--hair-d2)}
.hstat.box-in:last-child,.hstat:last-child{border-bottom:0;padding-bottom:0}
.hstat b{font-family:var(--f-serif);font-weight:600;font-size:clamp(1.7rem,2.6vw,2.4rem);line-height:1.1;display:flex;align-items:baseline;flex-wrap:nowrap;gap:.15em;color:var(--gold-light)}
.hstat b .metric-u{flex-shrink:0;white-space:nowrap}
.hstat__label{display:block;margin-top:.55em;font-size:var(--text-min);letter-spacing:.08em;text-transform:uppercase;color:var(--on-dark-2);line-height:1.45;max-width:24ch}
.hero__line{position:absolute;right:0;bottom:8%;width:min(46%,560px);height:auto;z-index:1;opacity:.5;pointer-events:none}
.hline-path{fill:none;stroke:var(--gold-light);stroke-width:1.4;stroke-linecap:round;stroke-linejoin:round;stroke-dasharray:900;stroke-dashoffset:900;opacity:.85}
.hline-head{fill:none;stroke:var(--gold-light);stroke-width:1.4;stroke-linecap:round;stroke-linejoin:round;opacity:0}
@media (prefers-reduced-motion:no-preference){
  .loaded .hline-path{animation:draw 3s cubic-bezier(.5,.05,.2,1) .6s forwards}
  .loaded .hline-head{animation:fadeIn .6s ease 3s forwards}
}
@keyframes draw{to{stroke-dashoffset:0}}
@keyframes fadeIn{to{opacity:.85}}

.partners{position:absolute;left:0;right:0;bottom:0;z-index:2;border-top:1px solid var(--hair-d2);background:rgba(14,26,40,.35);backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px)}
.partners__in{display:flex;flex-wrap:wrap;align-items:center;gap:.75rem clamp(1.25rem,4vw,4rem);padding-block:1rem}
.partners__label{font-size:var(--text-min);letter-spacing:.22em;text-transform:uppercase;color:var(--on-dark-2)}
.plogo{display:flex;flex-direction:column;line-height:1.15}
.plogo b{font-family:var(--f-sans);font-weight:700;font-size:calc(var(--text-min) * 1.3);letter-spacing:.14em;color:var(--on-dark)}
.plogo span{font-family:var(--f-serif);font-style:italic;font-size:calc(var(--text-min) * 1.3);color:var(--on-dark-2)}

/* ============================ NOSOTROS ============================ */
.about__grid{display:grid;grid-template-columns:1fr;gap:var(--block-gap);align-items:start}
.about p+p{margin-top:1.15em}
.about .body{max-width:60ch}
.tags{display:flex;flex-wrap:wrap;gap:.625rem;margin-top:var(--stack-lg)}
.tag{font-family:var(--f-sans);font-size:var(--text-min);font-weight:500;letter-spacing:.12em;text-transform:uppercase;color:var(--ink-muted);border:1px solid var(--hair-l);border-radius:1px;padding:.62em 1em}
.tag.box:hover{border-color:var(--gold-d);box-shadow:0 6px 16px rgba(19,39,60,.06)}
.quote{margin-top:var(--stack-lg);padding-left:1.6rem;border-left:2px solid var(--gold-d)}
.quote p{font-family:var(--f-serif);font-style:italic;font-weight:500;font-size:clamp(1.25rem,1.9vw,1.6rem);line-height:1.4;color:var(--ink)}
.quote cite{display:block;margin-top:.8em;font-family:var(--f-sans);font-style:normal;font-size:var(--text-min);letter-spacing:.14em;text-transform:uppercase;color:var(--ink-muted)}

/* ============================ ALIANZAS ============================ */
.allies{display:grid;grid-template-columns:1fr;gap:clamp(1.25rem,2.5vw,2rem);margin-top:clamp(2.5rem,5vw,4rem)}
.ally{background:var(--stone-card);border:1px solid var(--hair-l);border-top:3px solid var(--gold);padding:clamp(2rem,4vw,3.25rem);display:flex;flex-direction:column;box-shadow:0 20px 50px rgba(8,20,32,.22)}
.ally.box:hover{box-shadow:0 28px 60px rgba(8,20,32,.3)}
.ally__kind{font-family:var(--f-sans);font-size:var(--text-min);font-weight:600;letter-spacing:.2em;text-transform:uppercase;color:var(--gold-d)}
.ally h3{font-family:var(--f-serif);font-weight:600;font-size:clamp(1.75rem,2.6vw,2.35rem);line-height:1.08;margin:1rem 0 .35rem;color:var(--ink)}
.ally__who{font-family:var(--f-serif);font-style:italic;color:var(--ink-2);font-size:clamp(1.02rem,1.2vw,1.12rem);margin-bottom:1.35rem}
.ally p{color:var(--ink-2);font-size:var(--text-min);line-height:1.66}
.ally p+p{margin-top:.9em}
.ally__link{margin-top:auto;padding-top:1.75rem;font-size:var(--text-min);font-weight:600;letter-spacing:.06em;color:var(--gold-d);display:inline-flex;align-items:center;gap:.5em}
.ally__link .ar{transition:transform .3s ease}
.ally__link:hover .ar{transform:translateX(4px)}
.together{margin-top:clamp(2rem,4vw,3.25rem);border:1px solid var(--hair-d);border-top:2px solid var(--gold-light);background:rgba(14,26,40,.55);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);color:var(--on-dark);padding:clamp(1.75rem,3.5vw,3rem);display:grid;grid-template-columns:1fr;gap:var(--stack-md);align-items:center;transition:box-shadow .45s ease,border-color .45s ease,transform .4s ease}
.together.box-in{box-shadow:0 16px 40px rgba(8,20,32,.2)}
.together.box:hover{transform:translateY(-3px);box-shadow:0 20px 48px rgba(8,20,32,.28)}
.together__label{font-family:var(--f-serif);font-weight:600;font-size:clamp(1.55rem,2.2vw,2rem);color:var(--gold-light);white-space:nowrap}
.together__items{display:flex;flex-wrap:wrap;gap:10px 0;align-items:center}
.titem{font-size:var(--text-min);color:var(--on-dark-2)}
.titem b{color:var(--on-dark);font-weight:600}
.tsep{margin-inline:clamp(14px,1.6vw,22px);color:var(--gold-light)}

/* ============================ QUÉ HACEMOS ============================ */
.svc__head{max-width:none}
.svc__lead{color:var(--on-dark-2);max-width:62ch}
.layers{display:grid;grid-template-columns:1fr;gap:0;margin-top:var(--block-gap)}
.layer{padding:var(--stack-lg) 0;transition:background .35s ease,transform .4s ease}
.layer.box:hover{background:rgba(238,241,245,.04)}
.layer:not(:first-child){border-top:1px solid var(--hair-d2)}
.layer__n{font-family:var(--f-serif);font-weight:500;font-size:2.6rem;line-height:1;color:var(--gold-light);transition:transform .5s cubic-bezier(.2,.7,.2,1),opacity .5s ease}
.reveal-stagger.in .layer__n{transition-delay:inherit}
.reveal-stagger.in .layer:nth-child(1) .layer__n{transition-delay:.1s}
.reveal-stagger.in .layer:nth-child(2) .layer__n{transition-delay:.2s}
.reveal-stagger.in .layer:nth-child(3) .layer__n{transition-delay:.3s}
.reveal-stagger.in .layer__n{transform:scale(1);opacity:1}
.reveal-stagger .layer__n{transform:scale(.88);opacity:.6}
.layer h3{font-family:var(--f-serif);font-weight:600;font-size:1.55rem;line-height:1.12;margin:1.1rem 0 .3rem}
.layer__role{font-family:var(--f-serif);font-style:italic;font-weight:500;color:var(--gold-light);font-size:1rem;margin-bottom:1.4rem}
.layer ul{list-style:none;display:flex;flex-direction:column;gap:.85em;margin-bottom:1.6rem}
.layer li{position:relative;padding-left:1.3em;font-size:var(--text-min);color:var(--on-dark-2);line-height:1.5}
.layer li::before{content:"";position:absolute;left:0;top:.62em;width:5px;height:5px;background:var(--gold-light);transform:rotate(45deg)}
.layer__model{padding-top:1rem;border-top:1px solid var(--hair-d2);font-size:var(--text-min);letter-spacing:.04em;color:var(--on-dark-2)}
.layer__model b{color:var(--on-dark);font-weight:600}

/* ============================ PORTAFOLIO ============================ */
.port__meta{display:flex;flex-wrap:wrap;gap:.625rem .875rem;margin-top:var(--stack-md)}
.chip{font-family:var(--f-sans);font-size:var(--text-min);font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--ink);border:1px solid var(--hair-l);background:var(--stone-card);padding:.6em 1em;transition:transform .3s ease,border-color .3s ease,box-shadow .3s ease}
.chip:hover{transform:translateY(-2px);border-color:var(--gold);box-shadow:0 6px 16px rgba(19,39,60,.06)}
.chip b{color:var(--gold-d);display:inline-flex;align-items:baseline;gap:.12em;font-size:inherit}
.plant__cap .metric-u{flex-shrink:0}
.plants{display:grid;grid-template-columns:1fr;gap:var(--card-gap);margin-top:var(--block-gap)}
.plant{background:var(--stone-card);border:1px solid var(--hair-l);padding:clamp(1.5rem,3vw,2.5rem);position:relative;overflow:hidden}
.plant.box:hover{box-shadow:0 14px 36px rgba(19,39,60,.09);border-color:rgba(194,151,74,.35)}
.plant::before{content:"";position:absolute;top:0;left:0;width:0;height:2px;background:var(--gold);transition:width .75s cubic-bezier(.2,.7,.2,1)}
.reveal-stagger.in .plant::before{width:44px}
.reveal-stagger.in .plant:nth-child(1)::before{transition-delay:.12s}
.reveal-stagger.in .plant:nth-child(2)::before{transition-delay:.22s}
.reveal-stagger.in .plant:nth-child(3)::before{transition-delay:.32s}
.plant__loc{font-family:var(--f-sans);font-size:var(--text-min);font-weight:600;letter-spacing:.18em;text-transform:uppercase;color:var(--ink-muted)}
.plant h3{font-family:var(--f-serif);font-weight:600;font-size:clamp(1.45rem,2vw,1.8rem);line-height:1.1;margin:.7rem 0 1.2rem}
.plant__cap{font-family:var(--f-serif);font-weight:600;font-size:clamp(1.7rem,2.4vw,2.2rem);line-height:1.1;color:var(--gold-d);display:flex;align-items:baseline;flex-wrap:wrap;gap:.15em}
.plant__cap small{flex-basis:100%;display:block;font-family:var(--f-sans);font-weight:500;font-size:var(--text-min);letter-spacing:.1em;text-transform:uppercase;color:var(--ink-muted);margin-top:.6em}
.plant__tech{margin-top:1.3rem;padding-top:1.1rem;border-top:1px solid var(--hair-l2);font-size:var(--text-min);color:var(--ink-2);line-height:1.55}
.port__note{margin-top:var(--stack-md);font-size:var(--text-min);letter-spacing:.03em;color:var(--ink-muted);}

/* ============================ TRAYECTORIA ============================ */
.stats{display:grid;grid-template-columns:1fr;gap:0;margin-top:var(--block-gap);border-top:1px solid var(--hair-l)}
.stat{padding:var(--stack-lg) 0;border-bottom:1px solid var(--hair-l);transition:background .35s ease,transform .35s ease}
.stat:not(:nth-child(3n)){border-right:0}
.stat:not(:nth-child(3n+1)) > span{padding-left:0}
.stat.box:hover{background:rgba(194,151,74,.04);transform:translateX(4px)}
.stat b{font-family:var(--f-serif);font-weight:600;font-size:clamp(1.9rem,3.6vw,2.9rem);line-height:1.1;letter-spacing:-.01em;display:flex;align-items:baseline;flex-wrap:nowrap;gap:.15em;color:var(--ink);transition:color .35s ease}
.stat > span{display:block;margin-top:.7em;color:var(--ink-2);font-size:var(--text-min);line-height:1.45;max-width:28ch}
.stat b .metric-u{white-space:nowrap;flex-shrink:0}
.stat--accent b{color:var(--gold-d)}
.stat--accent:hover b{color:var(--gold)}
.exp__note{margin-top:var(--stack-md);font-size:var(--text-min);letter-spacing:.04em;color:var(--ink-muted)}

/* ============================ EQUIPO ============================ */
.team__grid{display:grid;grid-template-columns:1fr;gap:var(--card-gap);margin-top:var(--block-gap)}
.member{background:var(--stone-card);border:1px solid var(--hair-l);border-radius:2px;padding:clamp(1.625rem,3vw,3rem);display:flex;flex-direction:column}
.member.box:hover{box-shadow:0 14px 36px rgba(19,39,60,.08);border-color:rgba(194,151,74,.3)}
.member__top{display:flex;align-items:center;gap:20px;margin-bottom:1.6rem}
.mono{width:60px;height:60px;flex:none;display:grid;place-items:center;border:1px solid var(--gold-d);border-radius:50%;font-family:var(--f-serif);font-weight:600;font-size:1.35rem;color:var(--gold-d);transition:transform .4s cubic-bezier(.2,.7,.2,1),border-color .35s ease,background .35s ease}
.box:hover .mono{transform:scale(1.05);border-color:var(--gold);background:rgba(194,151,74,.06)}
.member h3{font-family:var(--f-serif);font-weight:600;font-size:1.55rem;line-height:1.1}
.member__role{font-family:var(--f-sans);font-size:var(--text-min);font-weight:600;letter-spacing:.12em;text-transform:uppercase;color:var(--gold-d);margin-top:.5em}
.member p{color:var(--ink-2);font-size:var(--text-min);line-height:1.66}
.member p+p{margin-top:.85em}
.member__edu{margin-top:1.2rem;padding-top:1.1rem;border-top:1px solid var(--hair-l2);font-size:var(--text-min);color:var(--ink-muted);line-height:1.6}
.member__links{margin-top:auto;padding-top:1.4rem}
.lnk{display:inline-flex;align-items:center;gap:.55em;font-size:var(--text-min);font-weight:600;letter-spacing:.05em;color:var(--ink-muted);border:1px solid var(--hair-l);padding:.55em 1em;transition:color .3s ease,border-color .3s ease}
.lnk svg{width:14px;height:14px}
.lnk:hover{color:var(--gold-d);border-color:var(--gold-d)}
.team__foot{margin-top:var(--stack-lg);text-align:center;font-family:var(--f-serif);font-style:italic;font-size:1.85rem;color:var(--ink-2)}

/* ============================ CONTACTO ============================ */
.cta{position:relative;overflow:hidden;isolation:isolate;color:var(--on-dark)}
.cta__bg{position:absolute;inset:0;z-index:-1;background:radial-gradient(80% 130% at 12% 0%,rgba(210,173,92,.16),transparent 54%),radial-gradient(90% 130% at 100% 100%,rgba(210,173,92,.10),transparent 54%),var(--navy)}
.cta__grid{display:grid;grid-template-columns:1fr;gap:var(--block-gap);align-items:center}
.cta h2{font-family:var(--f-serif);font-weight:600;font-size:clamp(2rem,4.2vw,3.4rem);line-height:1.07;letter-spacing:-.01em;max-width:16ch;color:var(--on-dark)}
.cta .lead{color:var(--on-dark-2)}
.cta__info{margin-top:var(--stack-lg);display:flex;flex-direction:column;gap:var(--stack-md)}
.cta__row{display:flex;align-items:center;gap:14px;font-size:1.05rem;color:var(--on-dark)}
.cta__row .ic{width:20px;height:20px;color:var(--gold-light);flex:none}
.cta__row a:hover{color:var(--gold-light)}
.form{background:rgba(238,241,245,.04);border:1px solid var(--hair-d);border-radius:3px;padding:clamp(28px,3vw,42px);transition:transform .5s cubic-bezier(.2,.7,.2,1),box-shadow .5s ease,border-color .4s ease}
.form.box-in{box-shadow:0 12px 40px rgba(8,20,32,.18)}
.form.box:hover{transform:translateY(-3px);border-color:rgba(212,181,106,.45);box-shadow:0 16px 48px rgba(8,20,32,.22)}
.field{margin-bottom:1.15rem}
.field label{display:block;font-family:var(--f-sans);font-size:var(--text-min);font-weight:600;letter-spacing:.14em;text-transform:uppercase;color:var(--on-dark-2);margin-bottom:.55em}
.field input,.field textarea{width:100%;background:rgba(8,20,32,.55);border:1px solid var(--hair-d);border-radius:2px;color:var(--on-dark);font-family:var(--f-sans);font-size:var(--text-min);padding:.85em .95em;transition:border-color .3s ease,box-shadow .3s ease}
.field input::placeholder,.field textarea::placeholder{color:var(--text-placeholder)}
.field input:focus,.field textarea:focus{outline:none;border-color:var(--gold);box-shadow:0 0 0 3px rgba(210,173,92,.16)}
.field textarea{resize:vertical;min-height:108px}
.form .btn--primary{width:100%;justify-content:center}
.form__hint{font-size:var(--text-min);color:var(--on-dark-2);margin-top:.9rem;text-align:center}

/* ============================ FOOTER ============================ */
.foot{background:#0e1f31;border-top:1px solid var(--hair-d);color:var(--on-dark);padding-block:var(--stack-lg) 1.75rem}
.foot__top{display:flex;justify-content:space-between;gap:var(--stack-lg);flex-wrap:wrap;align-items:flex-start}
.foot__brand{max-width:38ch}
.foot__brand .brand{margin-bottom:1.1rem}
.foot__brand .brand__sub{color:var(--on-dark-2)}
.foot__brand p{color:var(--on-dark-2);font-size:var(--text-min);line-height:1.55}
.foot__nav{display:flex;gap:clamp(28px,4vw,60px);flex-wrap:wrap}
.foot__col h4{font-family:var(--f-sans);font-size:var(--text-min);font-weight:600;letter-spacing:.16em;text-transform:uppercase;color:var(--gold-light);margin-bottom:1.1em}
.foot__col a,.foot__col span{display:block;color:var(--on-dark-2);font-size:var(--text-min);margin-bottom:.65em;transition:color .25s ease}
.foot__col a:hover{color:var(--on-dark)}
.foot__bottom{margin-top:var(--stack-lg);padding-top:var(--stack-md);border-top:1px solid var(--hair-d2)}
.foot__bottom small{color:var(--on-dark-2);font-size:var(--text-min);line-height:1.6;max-width:100%;display:block}
.foot__bottom .disc{display:block;margin-top:.5em;color:var(--on-dark-2);opacity:1}

/* ============================ REDUCED MOTION ============================ */
@media (prefers-reduced-motion:reduce){
  *{animation-duration:.001ms !important;transition-duration:.001ms !important}
  html{scroll-behavior:auto}
  .hline-path{stroke-dashoffset:0 !important}
  .hline-head{opacity:.85 !important}
  .reveal{opacity:1 !important;transform:none !important}
  .reveal-stagger>*{opacity:1 !important;transform:none !important;animation:none !important}
  .box{opacity:1 !important;transform:none !important;animation:none !important}
  .reveal-stagger .layer__n{opacity:1 !important;transform:none !important}
  .plant::before{width:44px !important;transition-delay:0s !important}
  .box:hover,.reveal-stagger.in>.box:hover,.stat.box:hover{transform:none !important}
}

/* ============================ TABLET (768px+) ============================ */
@media (min-width:768px){
  :root{
    --gut:2rem;
    --sec-py:3.6rem;
    --block-gap:2.75rem;
    --card-gap:1.375rem;
    --stack-sm:1.125rem;
    --stack-md:1.75rem;
    --stack-lg:2.75rem;
    --scroll-offset:5rem;
  }

  .hero__in{padding-top:calc(var(--scroll-offset) + 2.25rem);padding-bottom:8.5rem}
  .hero__stats{grid-template-columns:repeat(3,1fr);gap:clamp(1rem,2.5vw,2.5rem);align-items:start;width:100%}
  .hstat{padding:0;border-bottom:0;border-right:1px solid var(--hair-d2);padding-right:clamp(1rem,2vw,2rem)}
  .hstat:last-child{border-right:0;padding-right:0}
  .partners__in{padding-block:1.125rem}
  .about__grid{grid-template-columns:.92fr 1.08fr;gap:clamp(2.125rem,4vw,5.625rem)}
  .allies{grid-template-columns:1fr 1fr}
  .together{grid-template-columns:auto 1fr;gap:clamp(1.5rem,3vw,3rem);padding:clamp(2rem,3.5vw,3rem)}
  .stats{grid-template-columns:repeat(2,1fr)}
  .stat{padding:clamp(1.625rem,3vw,2.5rem) clamp(.5rem,2vw,1.875rem) clamp(1.625rem,3vw,2.5rem) 0}
  .stat:not(:nth-child(2n)){border-right:1px solid var(--hair-l)}
  .stat:nth-child(2n+1) > span{padding-left:0}
  .stat:nth-child(2n) > span{padding-left:clamp(1.25rem,2vw,1.875rem)}
  .stat:nth-child(2n) b{padding-left:clamp(1.25rem,2vw,1.875rem)}
  .team__grid{grid-template-columns:repeat(2,1fr)}
  .plants{grid-template-columns:repeat(2,1fr)}
  .cta__grid{grid-template-columns:1fr 1fr;gap:clamp(2.5rem,4vw,5.625rem)}
}

/* ============================ DESKTOP (1024px+) ============================ */
@media (min-width:1024px){
  :root{
    --gut:clamp(2.5rem,5vw,5rem);
    --sec-py:clamp(4.4rem,5.6vw,6rem);
    --block-gap:clamp(3rem,4.5vw,5rem);
    --card-gap:clamp(1.375rem,2vw,2.375rem);
    --stack-lg:clamp(2.25rem,3vw,3rem);
  }

  .hero__in{padding-top:calc(var(--scroll-offset) + 2.75rem);padding-bottom:9.5rem}
  .layers{grid-template-columns:repeat(3,1fr);gap:0}
  .layer{padding:clamp(.5rem,1.4vw,1.125rem) clamp(1.25rem,2.4vw,2.5rem)}
  .layer:not(:first-child){border-top:0;border-left:1px solid var(--hair-d2)}
  .layer:hover{background:rgba(238,241,245,.04)}
  .plants{grid-template-columns:repeat(3,1fr)}
  .stats{grid-template-columns:repeat(3,1fr)}
  .stat:not(:nth-child(3n)){border-right:1px solid var(--hair-l)}
  .stat:nth-child(3n){border-right:0}
  .stat:nth-child(3n+1) > span{padding-left:0}
  .stat:not(:nth-child(3n+1)) > span{padding-left:clamp(1.25rem,2vw,1.875rem)}
  .stat:not(:nth-child(3n+1)) b{padding-left:clamp(1.25rem,2vw,1.875rem)}
  .cta__grid{grid-template-columns:1.05fr .95fr}
}

/* ============================ MOBILE NAV ============================ */
@media (max-width:680px){
  .nav{position:fixed;inset:80px 0 auto 0;flex-direction:column;align-items:stretch;gap:0;background:rgba(14,26,40,.97);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border-bottom:1px solid var(--hair-d);padding:8px var(--gut) var(--stack-md);transform:translateY(-12px);opacity:0;pointer-events:none;transition:.3s}
  .nav.open{transform:none;opacity:1;pointer-events:auto}
  .nav a:not(.btn){padding:1.05em 0;border-bottom:1px solid var(--hair-d2);color:var(--on-dark-2) !important}
  .nav a:not(.btn):hover{color:var(--on-dark) !important}
  .nav .btn{margin-top:var(--stack-md);justify-content:center}
  .burger{display:block}
  .hero__in{padding-bottom:9rem}
  .hero__line{display:none}
}
