/* ============================================================
   DIMON · Premium homepage
   Línea gráfica: Azul Montoya + oro de obra · Archivo Expanded
   ============================================================ */

:root{
  --navy:#0E2D52;
  --navy-2:#0A2342;
  --navy-3:#06182F;        /* casi negro azulado */
  --navy-soft:#16406d;
  --gold:#F5B81B;
  --gold-2:#E0A312;
  --gold-soft:#fbcf5a;
  --white:#ffffff;
  --paper:#F7F5F1;
  --paper-2:#EFEBE3;
  --ink:#11161E;
  --gray:#5C6573;
  --gray-2:#8A93A1;
  --line:#E3DED4;
  --line-dark:rgba(255,255,255,.12);

  --maxw:1240px;
  --ease:cubic-bezier(.22,.68,0,1);
  --ease-soft:cubic-bezier(.4,0,.1,1);

  --shadow-card:0 24px 60px -22px rgba(8,24,47,.45);
  --shadow-soft:0 18px 50px -28px rgba(8,24,47,.4);
}

*{box-sizing:border-box;}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%;overflow-x:hidden;}
body{
  margin:0;background:var(--paper);color:var(--ink);
  font-family:'Archivo',system-ui,-apple-system,sans-serif;
  font-size:17px;line-height:1.62;font-weight:400;
  -webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;
  overflow-x:visible;
}
img{max-width:100%;display:block;}
a{color:inherit;text-decoration:none;}
button{font-family:inherit;}
::selection{background:var(--gold);color:var(--navy);}

.wrap{max-width:var(--maxw);margin:0 auto;padding:0 32px;}

/* Display / title type — Poppins */
.exp{font-family:'Poppins',sans-serif;font-weight:700;letter-spacing:-.01em;line-height:1.05;}
h1,h2,h3,h4{margin:0;}
h2{font-size:min(40px, 100%);}

/* Eyebrow */
.eyebrow{
  font-weight:700;font-size:12.5px;letter-spacing:.26em;text-transform:uppercase;
  color:var(--gold-2);display:inline-flex;align-items:center;gap:12px;
}
.eyebrow::before{content:"";width:30px;height:2px;background:var(--gold);border-radius:2px;}
.eyebrow.on-dark{color:var(--gold);}
.eyebrow.center{justify-content:center;}

/* Buttons */
.btn{
  display:inline-flex;align-items:center;gap:11px;cursor:pointer;white-space:nowrap;
  font-weight:700;font-size:15px;letter-spacing:.01em;
  padding:16px 28px;border-radius:100px;border:1.5px solid transparent;
  transition:transform .35s var(--ease), background .3s, color .3s, border-color .3s, box-shadow .3s;
}
.btn svg{width:17px;height:17px;transition:transform .35s var(--ease);}
.btn:hover svg{transform:translateX(4px);}
.btn-gold{background:var(--gold);color:var(--navy);box-shadow:0 10px 30px -8px rgba(245,184,27,.6);}
.btn-gold:hover{background:var(--gold-soft);transform:translateY(-2px);box-shadow:0 16px 38px -10px rgba(245,184,27,.7);}
.btn-light{background:var(--white);color:var(--navy);}
.btn-light:hover{transform:translateY(-2px);box-shadow:0 16px 34px -14px rgba(8,24,47,.5);}
.btn-navy{background:var(--navy);color:var(--white);}
.btn-navy:hover{background:var(--navy-soft);transform:translateY(-2px);}
.btn-ghost{border-color:rgba(255,255,255,.34);color:var(--white);backdrop-filter:blur(4px);}
.btn-ghost:hover{border-color:var(--gold);color:var(--gold);transform:translateY(-2px);}
.btn-outline{border-color:rgba(14,45,82,.28);color:var(--navy);}
.btn-outline:hover{border-color:var(--navy);background:var(--navy);color:var(--white);transform:translateY(-2px);}
.cta-short{display:none;}

/* ============================================================
   FLOATING GLASS NAV
   ============================================================ */
.navbar{position:fixed;top:18px;left:0;right:0;z-index:100;display:flex;justify-content:center;
  padding:0 20px;transition:top .4s var(--ease);pointer-events:none;}
.nav-shell{
  pointer-events:auto;width:100%;max-width:1180px;
  display:flex;align-items:center;justify-content:space-between;gap:24px;
  padding:11px 14px 11px 22px;border-radius:100px;
  background:rgba(247,245,241,.72);
  backdrop-filter:blur(18px) saturate(160%);-webkit-backdrop-filter:blur(18px) saturate(160%);
  border:1px solid rgba(255,255,255,.6);
  box-shadow:0 14px 40px -18px rgba(8,24,47,.4), inset 0 1px 0 rgba(255,255,255,.7);
  transition:background .4s var(--ease), box-shadow .4s, border-color .4s, transform .4s var(--ease);
}
.navbar.on-dark .nav-shell{
  background:rgba(10,35,66,.4);border-color:rgba(255,255,255,.16);
  box-shadow:0 14px 40px -18px rgba(0,0,0,.5), inset 0 1px 0 rgba(255,255,255,.16);
}
.navbar.hidden{top:-90px;}
.brand{display:flex;align-items:center;gap:12px;}
.brand .mk{width:34px;height:34px;flex-shrink:0;color:var(--navy);transition:color .4s;}
.navbar.on-dark .brand .mk{color:var(--gold);}
.brand .wm{display:flex;flex-direction:column;line-height:1;}
.brand .wm b{font-family:'Archivo',sans-serif;font-stretch:125%;font-weight:700;font-size:19px;letter-spacing:.04em;color:var(--navy);text-transform:uppercase;transition:color .4s;}
.brand .wm span{font-weight:600;font-size:7.5px;letter-spacing:.32em;color:var(--gold-2);text-transform:uppercase;margin-top:4px;}
.navbar.on-dark .brand .wm b{color:var(--white);}
.nav-links{display:flex;align-items:center;gap:6px;}
.nav-links a{position:relative;font-weight:600;font-size:14.5px;color:var(--navy);padding:9px 15px;border-radius:100px;transition:background .25s, color .4s;}
.navbar.on-dark .nav-links a{color:rgba(255,255,255,.86);}
.nav-links a:hover{background:rgba(14,45,82,.08);}
.navbar.on-dark .nav-links a:hover{background:rgba(255,255,255,.1);}
.nav-right{display:flex;align-items:center;gap:8px;}
.nav-cta{font-weight:700;font-size:14.5px;padding:11px 22px;border-radius:100px;background:var(--navy);color:var(--white);white-space:nowrap;transition:background .3s, transform .3s var(--ease), color .4s;}
.nav-cta:hover{background:var(--gold);color:var(--navy);transform:translateY(-1px);}
.navbar.on-dark .nav-cta{background:var(--gold);color:var(--navy);}
.navbar.on-dark .nav-cta:hover{background:var(--gold-soft);}
.nav-burger{display:none;flex-direction:column;gap:5px;background:none;border:0;cursor:pointer;padding:10px;}
.nav-burger span{width:22px;height:2px;background:var(--navy);border-radius:2px;transition:transform .3s var(--ease),opacity .2s,background .4s;}
.navbar.on-dark .nav-burger span{background:var(--white);}
.nav-mobile{display:none;}

/* ============================================================
   HERO
   ============================================================ */
.hero{position:relative;min-height:80svh;height:80svh;display:flex;align-items:center;justify-content:center;text-align:center;overflow:hidden;
  background:var(--navy-3);color:var(--white);isolation:isolate;}
.hero-bg{position:absolute;inset:-8% 0 0 0;height:116%;z-index:-3;will-change:transform;}
.hero-bg img{width:100%;height:100%;object-fit:cover;object-position:center 92%;filter:brightness(.62) contrast(1.08) saturate(.92);}
.hero-split-line{position:absolute;left:50%;top:0;bottom:0;width:1px;transform:translateX(-50%);z-index:1;
  background:linear-gradient(180deg,rgba(255,255,255,0),rgba(255,255,255,.32) 38%,rgba(255,255,255,.32) 62%,rgba(255,255,255,0));}
.hero::before{content:"";position:absolute;inset:0;z-index:-2;
  background:
    linear-gradient(180deg,rgba(6,24,47,.7) 0%,rgba(6,24,47,.52) 34%,rgba(6,24,47,.68) 72%,rgba(6,24,47,.95) 100%),
    radial-gradient(82% 64% at 50% 43%,rgba(6,24,47,.74) 0%,rgba(6,24,47,.42) 48%,rgba(6,24,47,.72) 100%);}
.hero-particles{position:absolute;inset:0;z-index:-1;pointer-events:none;}
.hero-in{padding:160px 0 120px;max-width:920px;margin:0 auto;position:relative;}
.hero .eyebrow{margin-bottom:26px;opacity:0;animation:rise .9s var(--ease) .2s forwards;}
.hero h1{font-size:clamp(36px,5vw,52px);text-transform:uppercase;letter-spacing:0;line-height:1;
  text-wrap:balance;text-shadow:0 4px 18px rgba(0,0,0,.78),0 18px 60px rgba(0,0,0,.5);}
.hero h1 .ln{display:block;opacity:0;transform:translateY(40px);animation:rise 1s var(--ease) forwards;}
.hero h1 .ln:nth-child(1){animation-delay:.32s;}
.hero h1 .ln:nth-child(2){animation-delay:.46s;}
.hero h1 em{font-style:normal;color:var(--gold-soft);}
.hero .lead{font-size:clamp(17px,1.9vw,21px);line-height:1.55;color:rgba(255,255,255,.85);
  max-width:660px;margin:30px auto 0;font-weight:500;opacity:0;animation:rise 1s var(--ease) .66s forwards;
  text-shadow:0 2px 14px rgba(0,0,0,.72);}
.hero .cta-row{display:flex;gap:14px;margin-top:42px;flex-wrap:wrap;justify-content:center;opacity:0;animation:rise 1s var(--ease) .82s forwards;}
.hero-meta{position:absolute;left:0;right:0;bottom:38px;display:flex;justify-content:space-between;
  align-items:flex-end;gap:24px;flex-wrap:wrap;opacity:0;animation:rise 1s var(--ease) 1s forwards;}
.hero-partner{display:flex;align-items:center;gap:13px;font-size:13px;color:rgba(255,255,255,.7);font-weight:500;}
.hero-partner b{color:var(--white);font-weight:700;}
.hero-partner .dot{width:8px;height:8px;border-radius:50%;background:var(--gold);box-shadow:0 0 0 4px rgba(245,184,27,.22);}
.scroll-cue{display:flex;align-items:center;gap:11px;font-size:11.5px;letter-spacing:.22em;text-transform:uppercase;color:rgba(255,255,255,.66);font-weight:600;}
.scroll-cue .line{width:46px;height:1px;background:rgba(255,255,255,.4);position:relative;overflow:hidden;}
.scroll-cue .line::after{content:"";position:absolute;inset:0;width:40%;background:var(--gold);animation:slide 2.4s var(--ease) infinite;}

@keyframes rise{to{opacity:1;transform:none;}}
@keyframes slide{0%{transform:translateX(-100%);}60%,100%{transform:translateX(260%);}}

/* ============================================================
   MANIFESTO
   ============================================================ */
.manifesto{padding:140px 0;background:var(--paper);text-align:center;position:relative;}
.manifesto .wrap{max-width:1000px;}
.manifesto .kicker{font-size:13px;letter-spacing:.3em;text-transform:uppercase;color:var(--gray-2);font-weight:700;margin-bottom:40px;}
.manifesto h2{font-size:clamp(30px,5vw,40px);text-transform:uppercase;color:var(--navy);line-height:1.04;letter-spacing:-.005em;}
.manifesto h2.manifesto-title{font-size:clamp(27px,4.2vw,40px);}
.manifesto h2 .mute{color:var(--gray-2);}
.manifesto h2 em{font-style:normal;color:var(--gold-2);}
.manifesto p{font-size:clamp(17px,1.7vw,20px);color:var(--gray);max-width:680px;margin:38px auto 0;line-height:1.6;}

/* ============================================================
   STATS / COUNTERS
   ============================================================ */
.stats{background:var(--navy);color:var(--white);padding:84px 0;}
.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:30px;}
.stat{text-align:center;position:relative;padding:0 14px;}
.stat::after{content:"";position:absolute;right:0;top:14%;height:72%;width:1px;background:rgba(255,255,255,.12);}
.stat:last-child::after{display:none;}
.stat b{font-family:'Archivo',sans-serif;font-stretch:125%;font-weight:800;font-size:clamp(40px,5vw,62px);color:var(--gold);line-height:1;display:block;letter-spacing:-.01em;}
.stat .suf{color:var(--gold);}
.stat span{display:block;font-weight:600;font-size:13px;letter-spacing:.1em;text-transform:uppercase;color:rgba(255,255,255,.7);margin-top:14px;}

/* ============================================================
   DREAMS / PROJECT CATEGORIES
   ============================================================ */
.section{padding:130px 0;}
.section-head{max-width:760px;margin-bottom:64px;}
.section-head.center{margin-inline:auto;text-align:center;}
.section-head h2{font-size:clamp(32px,4.6vw,40px);text-transform:uppercase;color:var(--navy);margin-top:20px;letter-spacing:-.005em;line-height:1.02;}
.section-head p{font-size:19px;color:var(--gray);margin-top:22px;line-height:1.55;}

.dreams-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;}
.dream{position:relative;border-radius:24px;overflow:hidden;min-height:460px;display:flex;align-items:flex-end;
  isolation:isolate;box-shadow:var(--shadow-card);}
.dream.tall{min-height:560px;}
.dream img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:-2;
  transition:transform 1s var(--ease);}
.dream:hover img{transform:scale(1.06);}
.dream::after{content:"";position:absolute;inset:0;z-index:-1;
  background:linear-gradient(180deg,rgba(6,24,47,0) 30%,rgba(6,24,47,.5) 62%,rgba(6,24,47,.95) 100%);}
.dream-body{padding:38px 36px 36px;color:var(--white);width:100%;}
.dream .idx{font-weight:700;font-size:12.5px;letter-spacing:.22em;color:var(--gold);}
.dream h3{font-family:'Poppins',sans-serif;font-weight:700;font-size:clamp(24px,2.4vw,32px);text-transform:uppercase;margin:14px 0 0;letter-spacing:-.005em;}
.dream p{font-size:15px;color:rgba(255,255,255,.82);margin:14px 0 0;max-width:420px;
  max-height:0;opacity:0;overflow:hidden;transition:max-height .5s var(--ease), opacity .4s, margin .5s var(--ease);}
.dream:hover p{max-height:140px;opacity:1;}
.dream .tagline{display:inline-flex;align-items:center;gap:9px;margin-top:20px;font-weight:700;font-size:13.5px;color:var(--gold);}
.dream .tagline svg{width:15px;height:15px;transition:transform .35s var(--ease);}
.dream:hover .tagline svg{transform:translateX(5px);}

/* ============================================================
   MATERIALES EN VENTA — product cards
   ============================================================ */
.materials-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:26px;}
.matcard{background:var(--white);border:1px solid var(--line);border-radius:24px;overflow:hidden;
  display:flex;flex-direction:column;box-shadow:var(--shadow-soft);
  transition:transform .5s var(--ease),box-shadow .5s var(--ease),border-color .4s;}
.matcard:hover{transform:translateY(-6px);box-shadow:var(--shadow-card);}
.matcard.featured{border-color:rgba(245,184,27,.55);box-shadow:0 26px 60px -24px rgba(245,184,27,.45);}
.matcard-media{position:relative;aspect-ratio:4/3;overflow:hidden;}
.matcard-media.is-product{background:radial-gradient(120% 100% at 50% 12%,#16406d,#0A2342 80%);}
.matcard-media.is-product img{object-fit:contain;padding:22px 22px 16px;filter:drop-shadow(0 16px 24px rgba(0,0,0,.45));}
.matcard:hover .matcard-media.is-product img{transform:scale(1.04);}
.matcard-media img{width:100%;height:100%;object-fit:cover;transition:transform 1s var(--ease);}
.matcard:hover .matcard-media img{transform:scale(1.06);}
.matcard-tag{position:absolute;top:16px;left:16px;background:var(--gold);color:var(--navy);
  font-weight:700;font-size:11.5px;letter-spacing:.12em;text-transform:uppercase;padding:7px 14px;border-radius:100px;}
.matcard-body{padding:30px 30px 32px;display:flex;flex-direction:column;flex:1;}
.matcard-body .idx{font-weight:700;font-size:12px;letter-spacing:.22em;text-transform:uppercase;color:var(--gold-2);}
.matcard-body h3{font-family:'Poppins',sans-serif;font-weight:700;font-size:23px;text-transform:uppercase;
  color:var(--navy);margin:12px 0 0;letter-spacing:-.005em;line-height:1.1;}
.matcard-body p{font-size:15px;color:var(--gray);margin:14px 0 0;line-height:1.55;flex:1;}
.matcard-link{display:inline-flex;align-items:center;gap:9px;margin-top:22px;font-weight:700;font-size:14px;color:var(--navy);
  transition:gap .35s var(--ease),color .3s;}
.matcard-link svg{width:15px;height:15px;transition:transform .35s var(--ease);}
.matcard-link:hover{color:var(--gold-2);}
.matcard-link:hover svg{transform:translateX(5px);}
.matcard.featured .matcard-link{color:var(--gold-2);}

/* ============================================================
   A QUIÉN ABASTECEMOS — audience cards
   ============================================================ */
.audience{background:var(--paper);}
.aud-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:26px;}
.audcard{background:var(--white);border:1px solid var(--line);border-radius:24px;overflow:hidden;
  box-shadow:var(--shadow-soft);transition:transform .5s var(--ease),box-shadow .5s var(--ease),border-color .4s;}
.audcard:hover{transform:translateY(-6px);box-shadow:var(--shadow-card);border-color:rgba(245,184,27,.4);}
.aud-media{position:relative;aspect-ratio:16/10;overflow:hidden;}
.aud-media img{width:100%;height:100%;object-fit:cover;transition:transform 1s var(--ease);}
.audcard:hover .aud-media img{transform:scale(1.06);}
.audcard-body{padding:30px 32px 36px;}
.audcard h3{font-family:'Poppins',sans-serif;font-weight:700;font-size:23px;text-transform:uppercase;
  color:var(--navy);letter-spacing:-.005em;}
.audcard p{font-size:15px;color:var(--gray);margin:14px 0 0;line-height:1.55;}
.aud-list{list-style:none;margin:22px 0 0;padding:22px 0 0;border-top:1px solid var(--line);
  display:flex;flex-direction:column;gap:11px;}
.aud-list li{position:relative;padding-left:26px;font-size:14.5px;color:var(--navy-2);font-weight:500;}
.aud-list li::before{content:"";position:absolute;left:0;top:7px;width:14px;height:14px;border-radius:50%;
  background:rgba(245,184,27,.2);
  -webkit-mask:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23000' stroke-width='3.4' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M5 12l5 5 9-10'/%3E%3C/svg%3E") center/10px no-repeat;
          mask:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23000' stroke-width='3.4' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M5 12l5 5 9-10'/%3E%3C/svg%3E") center/10px no-repeat;
  background:var(--gold-2);}
.aud-cta{display:flex;justify-content:center;margin-top:44px;}

/* ============================================================
   BUILDING POSSIBILITIES — interactive showcase
   ============================================================ */
.showcase{background:var(--paper-2);overflow:hidden;}
.showcase-grid{display:grid;grid-template-columns:.85fr 1.15fr;gap:60px;align-items:center;}
.showcase-list{display:flex;flex-direction:column;gap:6px;}
.sc-item{text-align:left;background:none;border:0;cursor:pointer;padding:24px 26px;border-radius:18px;
  display:block;position:relative;transition:background .4s var(--ease);border:1px solid transparent;}
.sc-item .sc-step{font-weight:700;font-size:12px;letter-spacing:.2em;color:var(--gray-2);transition:color .3s;}
.sc-item h4{font-family:'Poppins',sans-serif;font-weight:700;font-size:22px;text-transform:uppercase;color:var(--navy);margin:10px 0 0;transition:color .3s;}
.sc-item p{font-size:15px;color:var(--gray);margin:0;max-height:0;opacity:0;overflow:hidden;transition:max-height .5s var(--ease),opacity .4s,margin .4s;}
.sc-item.active{background:var(--white);border-color:var(--line);box-shadow:var(--shadow-soft);}
.sc-item.active p{max-height:120px;opacity:1;margin-top:12px;}
.sc-item.active h4{color:var(--navy);}
.sc-item .bar{position:absolute;left:0;top:50%;transform:translateY(-50%);width:4px;height:0;background:var(--gold);border-radius:4px;transition:height .4s var(--ease);}
.sc-item.active .bar{height:62%;}
.showcase-stage{position:relative;border-radius:24px;overflow:hidden;aspect-ratio:4/3.4;box-shadow:var(--shadow-card);background:var(--navy-3);}
.showcase-stage .frame{position:absolute;inset:0;opacity:0;transition:opacity .8s var(--ease);}
.showcase-stage .frame.active{opacity:1;}
.showcase-stage .frame img{width:100%;height:100%;object-fit:cover;}
.showcase-stage .frame::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(6,24,47,0) 50%,rgba(6,24,47,.78) 100%);}
.showcase-stage .cap{position:absolute;left:30px;bottom:28px;right:30px;z-index:2;color:var(--white);}
.showcase-stage .cap .mat{font-weight:700;font-size:12.5px;letter-spacing:.18em;text-transform:uppercase;color:var(--gold);}
.showcase-stage .cap b{display:block;font-family:'Poppins',sans-serif;font-weight:700;font-size:24px;text-transform:uppercase;margin-top:8px;}

/* ============================================================
   COVERAGE — El Salvador map
   ============================================================ */
.coverage{background:var(--navy);color:var(--white);position:relative;overflow:hidden;}
.coverage::before{content:"";position:absolute;inset:0;
  background:radial-gradient(120% 90% at 78% 30%,rgba(245,184,27,.12),transparent 55%);pointer-events:none;}
.coverage-grid{display:grid;grid-template-columns:.82fr 1.18fr;gap:56px;align-items:center;position:relative;}
.coverage-head h2{font-size:clamp(32px,4.4vw,40px);text-transform:uppercase;color:var(--white);margin-top:20px;line-height:1.02;}
.coverage-head p{color:rgba(255,255,255,.74);font-size:18px;margin-top:22px;line-height:1.6;}
.coverage-pills{display:flex;flex-wrap:wrap;gap:10px;margin-top:30px;}
.coverage-pills .pill{font-size:13px;font-weight:600;color:rgba(255,255,255,.85);padding:9px 16px;border-radius:100px;
  background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.12);}
.coverage-pills .pill b{color:var(--gold);}
.map-wrap{position:relative;width:100%;}
.map-wrap svg{width:100%;height:auto;overflow:visible;}
.map-dot{fill:rgba(255,255,255,.16);}
.route{fill:none;stroke:var(--gold);stroke-width:1.6;stroke-linecap:round;opacity:.5;
  stroke-dasharray:6 8;animation:dash 1.6s linear infinite;}
@keyframes dash{to{stroke-dashoffset:-28;}}
.city{fill:var(--gold);}
.city-pulse{fill:var(--gold);opacity:.5;transform-origin:center;animation:pulse 2.6s var(--ease) infinite;}
@keyframes pulse{0%{transform:scale(1);opacity:.5;}70%,100%{transform:scale(3.4);opacity:0;}}
.city-label{font-size:13px;font-weight:600;fill:rgba(255,255,255,.9);font-family:'Archivo',sans-serif;}
.hub-label{fill:var(--gold);font-weight:700;}
.hub-sub{font-size:10.5px;font-weight:600;letter-spacing:.04em;fill:rgba(255,255,255,.55);text-transform:uppercase;}

/* ============================================================
   PARTNERSHIP — Wanpeng
   ============================================================ */
.partner{background:var(--paper-2);color:var(--ink);position:relative;overflow:hidden;}
.partner::before{content:"";position:absolute;top:-30%;right:-10%;width:680px;height:680px;
  background:radial-gradient(circle,rgba(245,184,27,.1),transparent 62%);pointer-events:none;}
.partner-grid{display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:center;position:relative;}
.partner-badge{display:inline-flex;align-items:center;gap:11px;padding:10px 18px;border-radius:100px;
  background:rgba(245,184,27,.1);border:1px solid rgba(245,184,27,.3);color:var(--gold);font-weight:700;font-size:13px;letter-spacing:.06em;}
.partner-badge svg{width:16px;height:16px;}
/* Wanpeng section sits on light paper-2 → blue badge */
.partner .partner-badge{background:var(--navy);border-color:var(--navy);color:var(--white);}
.partner .partner-badge svg{color:var(--gold);}
.partner h2{font-size:clamp(32px,4.4vw,40px);text-transform:uppercase;margin:26px 0 0;line-height:1.02;letter-spacing:-.005em;color:var(--navy);}
.partner h2 em{font-style:normal;color:var(--gold);}
.partner p{color:var(--gray);font-size:18px;margin:24px 0 0;line-height:1.6;max-width:520px;}
.partner-feats{display:grid;grid-template-columns:1fr 1fr;gap:24px 30px;margin-top:40px;}
.pf{display:flex;gap:14px;align-items:flex-start;}
.pf .ic{width:44px;height:44px;border-radius:12px;background:rgba(245,184,27,.16);display:flex;align-items:center;justify-content:center;flex-shrink:0;}
.pf .ic svg{width:22px;height:22px;color:var(--gold);}
.pf b{display:block;font-family:'Poppins',sans-serif;font-weight:700;font-size:15px;text-transform:uppercase;color:var(--navy);}
.pf span{font-size:14px;color:var(--gray);}
.partner-visual{position:relative;border-radius:24px;overflow:hidden;aspect-ratio:4/4.6;box-shadow:0 40px 80px -30px rgba(0,0,0,.7);}
.partner-visual img{width:100%;height:100%;object-fit:cover;}
.partner-visual.is-product{background:radial-gradient(120% 90% at 50% 16%,#16406d,#0A2342 80%);}
.partner-visual.is-product::before{content:"";position:absolute;top:-12%;left:50%;transform:translateX(-50%);
  width:74%;height:74%;background:radial-gradient(circle,rgba(245,184,27,.26),transparent 64%);pointer-events:none;z-index:0;}
.partner-visual.is-product img{position:absolute;z-index:1;width:72%;height:auto;max-height:80%;top:50%;left:50%;
  transform:translate(-50%,-50%);object-fit:contain;filter:drop-shadow(0 30px 44px rgba(0,0,0,.55));}
.partner-visual.is-product .ovl{background:linear-gradient(180deg,transparent 55%,rgba(6,24,47,.78));}
.partner-visual .ovl{position:absolute;inset:0;background:linear-gradient(180deg,rgba(6,24,47,.1),rgba(6,24,47,.7));}
.partner-quote{position:absolute;left:30px;right:30px;bottom:30px;color:var(--white);}
.partner-quote .q{font-family:'Poppins',sans-serif;font-weight:700;font-size:22px;line-height:1.2;letter-spacing:-.005em;}
.partner-quote .by{font-size:13px;color:rgba(255,255,255,.7);margin-top:12px;}

/* ============================================================
   JOURNEY TIMELINE
   ============================================================ */
.journey{background:var(--paper);overflow:hidden;}
.journey-track{position:relative;margin-top:30px;}
.journey-line{position:absolute;top:34px;left:6%;right:6%;height:2px;background:var(--line);}
.journey-line .fill{position:absolute;inset:0;width:0;background:var(--gold);transition:width 1.4s var(--ease);}
.journey-steps{display:grid;grid-template-columns:repeat(5,1fr);gap:18px;position:relative;}
.jstep{text-align:center;padding:0 8px;}
.jstep .node{width:68px;height:68px;margin:0 auto;border-radius:50%;background:var(--white);border:2px solid var(--line);
  display:flex;align-items:center;justify-content:center;position:relative;z-index:2;transition:border-color .5s var(--ease),background .5s,transform .5s var(--ease);}
.jstep .node svg{width:28px;height:28px;color:var(--gray-2);transition:color .5s;}
.jstep .num{position:absolute;top:-8px;right:-8px;width:24px;height:24px;border-radius:50%;background:var(--navy);color:var(--white);
  font-size:12px;font-weight:700;display:flex;align-items:center;justify-content:center;}
.jstep.lit .node{border-color:var(--gold);background:var(--gold);transform:translateY(-4px);}
.jstep.lit .node svg{color:var(--navy);}
.jstep h4{font-family:'Poppins',sans-serif;font-weight:700;font-size:17px;text-transform:uppercase;color:var(--navy);margin:22px 0 0;}
.jstep p{font-size:14px;color:var(--gray);margin:10px 0 0;line-height:1.5;}

/* ============================================================
   FINAL CTA
   ============================================================ */
.final-cta{position:relative;color:var(--white);overflow:hidden;isolation:isolate;text-align:center;
  padding:160px 0;background:var(--navy-3);}
.final-cta .bg{position:absolute;inset:0;z-index:-2;}
.final-cta .bg img{width:100%;height:100%;object-fit:cover;opacity:.32;}
.final-cta::after{content:"";position:absolute;inset:0;z-index:-1;
  background:radial-gradient(80% 80% at 50% 30%,rgba(10,35,66,.5),rgba(6,24,47,.92));}
.final-cta .wrap{max-width:1100px;}
.final-cta h2{font-size:clamp(32px,4.6vw,40px);text-transform:uppercase;line-height:1.02;letter-spacing:-.01em;text-wrap:balance;margin:20px 0 0;}
.final-cta h2 em{font-style:normal;color:var(--gold);}
.final-cta p{font-size:clamp(16px,1.7vw,19px);color:rgba(255,255,255,.82);max-width:520px;margin:24px 0 0;line-height:1.6;}
.cta-panel{display:grid;grid-template-columns:1.35fr 1fr;gap:30px;align-items:stretch;text-align:left;
  background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.14);border-radius:28px;
  padding:54px 54px 56px;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);}
.cta-lead .btn{margin-top:38px;}
.cta-points{border-left:1px solid rgba(255,255,255,.14);padding-left:36px;display:flex;flex-direction:column;}
.cta-points-label{font-size:12px;font-weight:700;letter-spacing:.22em;text-transform:uppercase;color:var(--gold);}
.cta-point{display:flex;align-items:center;gap:15px;margin-top:22px;padding:14px 16px;border-radius:16px;
  background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.1);transition:background .3s,border-color .3s,transform .3s var(--ease);}
.cta-point:hover{background:rgba(245,184,27,.1);border-color:rgba(245,184,27,.4);transform:translateX(4px);}
.cta-point .ic{width:42px;height:42px;flex-shrink:0;border-radius:12px;background:rgba(245,184,27,.16);
  display:flex;align-items:center;justify-content:center;}
.cta-point .ic svg{width:21px;height:21px;color:var(--gold);}
.cta-point .txt{display:flex;flex-direction:column;line-height:1.2;}
.cta-point .txt b{font-family:'Poppins',sans-serif;font-weight:700;font-size:17px;text-transform:uppercase;color:var(--white);}
.cta-point .txt span{font-size:13px;color:rgba(255,255,255,.6);margin-top:3px;}
.cta-contact{margin-top:auto;padding-top:26px;display:flex;flex-direction:column;gap:6px;}
.cta-contact a{font-family:'Poppins',sans-serif;font-weight:700;font-size:20px;color:var(--white);transition:color .3s;}
.cta-contact a:hover{color:var(--gold);}
.cta-contact span{font-size:13.5px;color:rgba(255,255,255,.6);}

/* ============================================================
   FOOTER
   ============================================================ */
.footer{background:var(--navy-3);color:rgba(255,255,255,.66);padding:80px 0 34px;border-top:1px solid rgba(255,255,255,.08);}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr;gap:44px;padding-bottom:48px;border-bottom:1px solid rgba(255,255,255,.1);}
.footer .brand .mk{color:var(--gold);}
.footer .brand .wm b{color:var(--white);}
.footer-brand p{font-size:14.5px;margin:22px 0 0;max-width:320px;line-height:1.65;}
.footer-col h4{font-family:'Poppins',sans-serif;font-weight:700;font-size:13px;color:var(--white);letter-spacing:.08em;text-transform:uppercase;margin:0 0 18px;}
.footer-col a{display:block;font-size:14.5px;margin-bottom:13px;color:rgba(255,255,255,.66);transition:color .25s, padding-left .25s var(--ease);}
.footer-col a:hover{color:var(--gold);padding-left:5px;}
.footer-meta{display:block;font-size:14.5px;color:rgba(255,255,255,.66);}
.footer-bottom{display:flex;justify-content:space-between;align-items:center;padding-top:28px;font-size:13px;flex-wrap:wrap;gap:12px;}

/* ============================================================
   REVEAL
   ============================================================ */
[data-reveal]{opacity:0;transform:translateY(28px);transition:opacity .8s var(--ease),transform .8s var(--ease);}
[data-reveal].in{opacity:1;transform:none;}
[data-reveal][data-delay="1"]{transition-delay:.08s;}
[data-reveal][data-delay="2"]{transition-delay:.16s;}
[data-reveal][data-delay="3"]{transition-delay:.24s;}
[data-reveal][data-delay="4"]{transition-delay:.32s;}

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width:1000px){
  .showcase-grid,.coverage-grid,.partner-grid{grid-template-columns:1fr;gap:44px;}
  .partner-visual{aspect-ratio:16/10;order:-1;}
  .partner-visual.is-product img{width:58%;max-height:58%;top:39%;}
  .partner-visual.is-product .ovl{background:linear-gradient(180deg,transparent 42%,rgba(6,24,47,.84));}
  .partner-quote{left:26px;right:26px;bottom:24px;}
  .partner-quote .q{font-size:19px;max-width:420px;}
  .dreams-grid{grid-template-columns:repeat(2,1fr);gap:18px;}
  .dream,.dream.tall{min-height:400px;}
  .materials-grid{grid-template-columns:1fr;max-width:520px;margin:0 auto;}
  .aud-grid{grid-template-columns:1fr;max-width:520px;margin:0 auto;}
}
@media (max-width:820px){
  .nav-links{display:none;}
  .nav-burger{display:flex;}
  .nav-mobile{position:fixed;top:84px;left:16px;right:16px;z-index:99;
    background:rgba(247,245,241,.95);backdrop-filter:blur(20px);border-radius:24px;
    border:1px solid rgba(255,255,255,.6);box-shadow:0 30px 60px -20px rgba(8,24,47,.4);
    padding:16px;display:none;flex-direction:column;gap:4px;}
  .nav-mobile.open{display:flex;}
  .nav-mobile a{font-weight:600;font-size:16px;color:var(--navy);padding:14px 16px;border-radius:14px;}
  .nav-mobile a:hover{background:rgba(14,45,82,.06);}
  body.menu-open .nav-burger span:nth-child(1){transform:translateY(7px) rotate(45deg);}
  body.menu-open .nav-burger span:nth-child(2){opacity:0;}
  body.menu-open .nav-burger span:nth-child(3){transform:translateY(-7px) rotate(-45deg);}
  .stats-grid{grid-template-columns:1fr 1fr;gap:48px 20px;}
  .stat:nth-child(2)::after{display:none;}
  .dreams-grid{grid-template-columns:1fr;}
  .journey-steps{grid-template-columns:1fr;gap:34px;}
  .journey-line{display:none;}
  .jstep{display:grid;grid-template-columns:68px minmax(0,1fr);column-gap:22px;row-gap:6px;text-align:left;align-items:start;padding:0;}
  .jstep .node{grid-row:1 / span 2;margin:0;}
  .jstep h4{grid-column:2;margin-top:2px;}
  .jstep p{grid-column:2;margin-top:0;max-width:360px;}
  .partner-feats{grid-template-columns:1fr;}
  .cta-panel{grid-template-columns:1fr;gap:0;padding:40px 30px 42px;}
  .cta-points{border-left:none;padding-left:0;border-top:1px solid rgba(255,255,255,.14);margin-top:36px;padding-top:32px;}
  .cta-contact{margin-top:28px;}
  .footer-grid{grid-template-columns:1fr 1fr;gap:36px;}
  .section{padding:90px 0;}
  .manifesto{padding:100px 0;}
  .hero .wrap{padding-left:36px;padding-right:36px;}
  .hero h1{font-size:clamp(34px,9.2vw,52px);}
  .hero .lead{max-width:560px;padding:0 10px;}
}
@media (max-width:540px){
  .wrap{padding:0 22px;}
  .stats-grid{grid-template-columns:1fr;gap:40px;}
  .stat::after{display:none;}
  .footer-grid{grid-template-columns:1fr;}
  .hero .wrap{padding-left:30px;padding-right:30px;}
  .hero-in{padding:140px 0 110px;}
  .hero h1{font-size:clamp(35px,10.8vw,48px);line-height:1.04;}
  .hero .lead{font-size:16.5px;line-height:1.58;margin-top:24px;padding:0 14px;}
  .hero .cta-row{margin-top:34px;}
  .hero-quote-btn .cta-full{display:none;}
  .hero-quote-btn .cta-short{display:inline;}
  .manifesto h2.manifesto-title{font-size:clamp(25px,7.2vw,32px);line-height:1.08;}
  .partner-grid{gap:34px;}
  .partner-visual{aspect-ratio:4/4.2;}
  .partner-visual.is-product img{width:66%;max-height:56%;top:36%;}
  .partner-quote{left:20px;right:20px;bottom:20px;}
  .partner-quote .q{font-size:17px;line-height:1.18;}
  .partner-quote .by{font-size:12px;margin-top:8px;}
  .nav-shell{padding:10px 12px 10px 18px;}
  .brand .wm span{display:none;}
}

@media (prefers-reduced-motion:reduce){
  *{animation-duration:.001ms!important;animation-iteration-count:1!important;transition-duration:.001ms!important;scroll-behavior:auto!important;}
  [data-reveal]{opacity:1;transform:none;}
  .hero .eyebrow,.hero h1 .ln,.hero .lead,.hero .cta-row,.hero-meta{opacity:1;transform:none;animation:none;}
}
