/* ============================================================
   PYVOT CONSTRUCTION GROUP — COMPONENTS
   Token-driven. All colors/type/spacing come from tokens.css.
   Edit tokens.css (or add a [data-theme]) to restyle — not here.
   ============================================================ */

*{box-sizing:border-box}
html{scroll-behavior:smooth;overflow-x:hidden}
body{margin:0;background:var(--surface-darker);color:var(--text-on-light);font-family:var(--font-body);font-size:var(--fs-body);line-height:var(--lh-ui);overflow-x:hidden}
a{color:inherit;text-decoration:none}
img{display:block;width:100%;height:100%;object-fit:cover}
svg{fill:none;stroke:currentColor;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}

/* ── NAV ───────────────────────────────────────────── */
.topbar{background:var(--surface-dark);min-height:var(--nav-h);padding:0 var(--pad);display:grid;grid-template-columns:auto 1fr auto;gap:32px;align-items:center;border-bottom:var(--hairline) solid var(--border-on-dark-soft)}
.brand{display:flex;align-items:center;gap:12px;color:var(--text-on-dark)}
.brand-logo{height:46px;width:auto;display:block;object-fit:contain;flex-shrink:0}
.brand-name{font-family:var(--font-display);text-transform:uppercase;line-height:var(--lh-tight)}
.brand-name span{display:block;font-size:var(--fs-brand);letter-spacing:.04em}
.brand-name b{display:block;font-size:var(--fs-micro);font-weight:400;letter-spacing:var(--ls-label);color:var(--brand);font-family:var(--font-mono)}
.topbar nav{display:flex;justify-content:center;gap:clamp(20px,2.8vw,44px)}
.topbar nav a{color:var(--text-on-dark-3);font:var(--fw-label) var(--fs-2xs)/1 var(--font-mono);text-transform:uppercase;letter-spacing:var(--ls-nav);padding:8px 0;transition:color var(--dur-fast)}
.topbar nav a:hover,.topbar nav a.nav-active{color:var(--brand)}
.top-actions{display:flex;gap:10px;align-items:center}
.btn{display:inline-flex;align-items:center;justify-content:center;gap:10px;padding:11px 20px;font:var(--fw-label) var(--fs-2xs) var(--font-mono);letter-spacing:.1em;text-transform:uppercase;border:var(--border-w-btn) solid transparent;cursor:pointer;white-space:nowrap;transition:opacity var(--dur-fast),transform .1s}
.btn:hover{opacity:.88;transform:translateY(-1px)}
.btn-accent{background:var(--brand);color:var(--brand-contrast);border-color:var(--brand)}
.btn-outline-light{background:transparent;color:var(--text-on-dark);border-color:var(--text-on-dark-5)}
.btn-outline-light:hover{border-color:var(--text-on-dark)}
.btn-outline-dark{background:transparent;color:var(--text-on-light);border-color:var(--text-on-light)}
.btn-orange{background:var(--brand-2);color:var(--c-white);border-color:var(--brand-2)}
.btn-lg{min-height:52px;padding:14px 28px;font-size:12px}

/* ── HERO ──────────────────────────────────────────── */
.hero{position:relative;min-height:680px;display:flex;align-items:flex-end;overflow:hidden}
.hero-bg{position:absolute;inset:0;z-index:0}
.hero-bg img{object-position:center 30%}
.hero-bg:after{content:"";position:absolute;inset:0;background:linear-gradient(105deg,rgba(var(--ch-dark),.82) 0%,rgba(var(--ch-dark),.6) 55%,rgba(var(--ch-dark),.45) 100%)}
.hero-inner{position:relative;z-index:2;width:100%;max-width:var(--max);margin:0 auto;padding:60px var(--pad) 64px;display:grid;grid-template-columns:1fr 280px;gap:32px;align-items:end}
.hero-tag{display:inline-block;background:var(--surface-brand);color:var(--text-on-brand);font:var(--fw-label) var(--fs-label) var(--font-mono);letter-spacing:.16em;text-transform:uppercase;padding:5px 10px;margin:0 0 20px}
.hero h1{font-family:var(--font-display);font-size:var(--fs-hero);line-height:var(--lh-display);letter-spacing:var(--ls-display);text-transform:uppercase;color:var(--text-on-dark);margin:0 0 22px}
.hero-sub{color:var(--text-on-dark-2);font-size:var(--fs-body);max-width:580px;margin:0 0 32px;line-height:var(--lh-body)}
.hero-actions{display:flex;gap:12px;flex-wrap:wrap}
.hero-panel{background:var(--surface-brand);padding:28px 24px;align-self:center}
.hero-panel-label{font:var(--fw-label) var(--fs-label) var(--font-mono);letter-spacing:.14em;text-transform:uppercase;color:var(--text-on-brand);opacity:.6;margin:0 0 14px}
.hero-panel ul{margin:0;padding:0;list-style:none;display:flex;flex-direction:column;gap:10px}
.hero-panel li{font-family:var(--font-display);font-size:20px;line-height:.92;text-transform:uppercase;letter-spacing:-.01em;color:var(--text-on-brand);display:flex;align-items:center;gap:8px}
.hero-panel li:before{content:"→";font-size:14px;font-family:var(--font-mono);font-weight:900;flex-shrink:0;color:var(--text-on-brand);opacity:.7}

/* ── CREDS BAR ─────────────────────────────────────── */
.creds{background:var(--surface-mid);border-top:var(--hairline) solid var(--border-on-dark-soft);border-bottom:var(--hairline) solid var(--border-on-dark-soft)}
.creds-inner{max-width:var(--max);margin:0 auto;padding:0 var(--pad);display:grid;grid-template-columns:repeat(6,1fr)}
.cred{padding:20px 16px;display:flex;flex-direction:column;align-items:center;text-align:center;gap:8px;border-right:var(--hairline) solid var(--border-on-dark-soft)}
.cred:last-child{border-right:0}
.cred svg{width:28px;height:28px;stroke:var(--brand)}
.cred-title{font:var(--fw-label) var(--fs-2xs) var(--font-mono);letter-spacing:.1em;text-transform:uppercase;color:var(--text-on-dark)}
.cred-val{font-size:var(--fs-label);color:var(--text-on-dark-5);font-family:var(--font-mono);text-transform:uppercase;letter-spacing:.06em;line-height:1.4}

/* ── SECTIONS BASE ─────────────────────────────────── */
.section{max-width:var(--max);margin:0 auto;padding:var(--space-section) var(--pad)}
.section-tag{font:var(--fw-label) var(--fs-label) var(--font-mono);letter-spacing:var(--ls-label-wide);text-transform:uppercase;color:var(--text-on-light-muted);margin:0 0 12px;display:flex;align-items:center;gap:12px}
.section-tag:before{content:"";width:24px;height:1.5px;background:var(--brand);flex-shrink:0}
.section-rule{height:1px;background:var(--border-on-light);margin:0 var(--pad) 0}
.on-dark .section-rule{background:var(--border-on-dark-strong)}

/* ── CAPABILITIES ──────────────────────────────────── */
.capabilities-wrap{background:var(--surface-light)}
.capabilities-wrap .section{padding-bottom:0}
.cap-head{display:grid;grid-template-columns:1fr auto;align-items:center;margin:0 0 40px;gap:24px}
.cap-headline{font-family:var(--font-display);font-size:var(--fs-h3);line-height:var(--lh-display);text-transform:uppercase;letter-spacing:var(--ls-display);margin:0}
.cap-headline .hi{color:var(--brand)}
.cap-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--hairline);background:var(--border-on-light-gap)}
.cap-card{background:var(--surface-light);padding:30px var(--space-card) 26px;display:flex;flex-direction:column;gap:0;min-height:190px}
.cap-icon{width:44px;height:44px;margin:0 0 16px;stroke:var(--text-on-light);opacity:.75}
.cap-card h3{font-family:var(--font-display);font-size:var(--fs-h6);line-height:.94;text-transform:uppercase;letter-spacing:-.015em;margin:0 0 10px}
.cap-card p{font-size:var(--fs-sm);color:var(--text-on-light-soft);margin:0;line-height:1.55;flex:1}
.cap-card-arrow{display:none}

/* ── WHY ───────────────────────────────────────────── */
.why-wrap{background:var(--surface-dark)}
.why-inner{max-width:var(--max);margin:0 auto;padding:var(--space-section) var(--pad)}
.why-headline{font-family:var(--font-display);font-size:var(--fs-h1);line-height:var(--lh-tight);text-transform:uppercase;letter-spacing:var(--ls-display-tight);color:var(--text-on-dark);margin:0 0 48px}
.why-headline .hi{color:var(--brand)}
.why-grid{display:grid;grid-template-columns:repeat(6,1fr);gap:0;border-top:var(--hairline) solid var(--border-on-dark)}
.why-card{padding:24px 20px;border-right:var(--hairline) solid var(--border-on-dark);border-bottom:var(--hairline) solid var(--border-on-dark)}
.why-card:last-child{border-right:0}
.why-num{font:var(--fw-label) var(--fs-label) var(--font-mono);letter-spacing:.14em;color:var(--brand);margin:0 0 14px}
.why-card h3{font-family:var(--font-display);font-size:var(--fs-card-title-sm);text-transform:uppercase;letter-spacing:-.01em;line-height:var(--lh-snug);color:var(--text-on-dark);margin:0 0 10px}
.why-card p{font-size:var(--fs-xs);color:var(--text-on-dark-4);margin:0;line-height:var(--lh-body)}

/* ── EXPERIENCE ────────────────────────────────────── */
.experience-wrap{background:var(--surface-light)}
.exp-subhead{font-family:var(--font-display);font-size:var(--fs-h4);text-transform:uppercase;letter-spacing:var(--ls-display);line-height:.92;color:var(--text-on-light);margin:0 0 28px}
.exp-subhead em{display:block;color:var(--text-on-light-muted);font-style:normal;font-size:.72em}
.exp-head{display:flex;align-items:flex-start;justify-content:space-between;margin:0 0 24px}
.exp-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--hairline);background:var(--border-on-light-gap)}
.exp-card{background:var(--surface-light);overflow:hidden;display:flex;flex-direction:column}
.exp-photo{height:210px;position:relative;overflow:hidden;flex-shrink:0}
.exp-photo img{filter:saturate(.2) contrast(1.25) brightness(.85);transition:filter .3s}
.exp-card:hover .exp-photo img{filter:saturate(.5) contrast(1.15) brightness(.9)}
.exp-badge{position:absolute;top:0;left:0;background:var(--surface-dark);color:var(--brand);font:var(--fw-label) var(--fs-micro) var(--font-mono);letter-spacing:.1em;text-transform:uppercase;padding:6px 10px}
.exp-body{padding:20px 20px 0;flex:1}
.exp-body h3{font-family:var(--font-display);font-size:var(--fs-card-title);text-transform:uppercase;letter-spacing:-.01em;line-height:var(--lh-snug);margin:0 0 8px}
.exp-body p{font-size:var(--fs-sm);color:var(--text-on-light-soft);margin:0 0 14px}
.exp-meta{border-top:var(--hairline) solid var(--border-on-light);padding-top:10px;display:grid;grid-template-columns:auto 1fr;gap:3px 12px;font:var(--fw-label) 9.5px var(--font-mono);text-transform:uppercase;letter-spacing:.06em}
.exp-meta dt{color:var(--text-on-light-muted)}
.exp-meta dd{margin:0;color:var(--text-on-light)}
.exp-mentor-label{font:var(--fw-label) var(--fs-micro) var(--font-mono);letter-spacing:.14em;text-transform:uppercase;color:var(--brand);padding:10px 20px;margin-top:auto}
.exp-strip{height:var(--strip-w);background:var(--brand)}

/* ── PROOF BAND (procurement | JV | difference) ─────── */
.proof-band{background:var(--surface-dark);border-top:var(--hairline) solid var(--border-on-dark-soft)}
.proof-inner{max-width:var(--max);margin:0 auto;padding:var(--space-section) var(--pad);display:grid;grid-template-columns:1.1fr 1fr 1fr;gap:clamp(28px,4vw,56px)}
.proof-col{position:relative}
.proof-col+.proof-col{padding-left:clamp(28px,4vw,56px);border-left:var(--hairline) solid var(--border-on-dark)}
.proof-col .section-tag{color:var(--text-on-dark-5)}
.check-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:10px}
.check-list li{display:flex;gap:10px;align-items:flex-start;font-size:var(--fs-sm);color:var(--text-on-dark-2);line-height:1.5}
.check-list li:before{content:"";width:8px;height:8px;border-radius:50%;background:var(--brand);flex-shrink:0;margin-top:5px}
.mentor-label{font:var(--fw-label) var(--fs-label) var(--font-mono);letter-spacing:.16em;text-transform:uppercase;color:var(--brand)}
.proof-col--mentor h3{font-family:var(--font-display);font-size:var(--fs-h5);text-transform:uppercase;letter-spacing:var(--ls-display);line-height:var(--lh-snug);color:var(--text-on-dark);margin:12px 0 12px}
.proof-col--mentor p{font-size:var(--fs-sm);color:var(--text-on-dark-3);line-height:var(--lh-body);margin:0 0 14px}
.mentor-divider{height:1px;background:var(--border-on-dark-strong);margin:6px 0 14px}
.mentor-name{font-family:var(--font-display);font-size:var(--fs-card-title);text-transform:uppercase;letter-spacing:-.01em;color:var(--text-on-dark);margin:0}
.mentor-sub{font:var(--fw-label) var(--fs-label) var(--font-mono);letter-spacing:.1em;text-transform:uppercase;color:var(--text-on-dark-5);margin:2px 0 18px}
.diff-quote{font-family:var(--font-body);font-weight:700;font-size:clamp(18px,1.5vw,23px);line-height:1.3;color:var(--text-on-dark);margin:12px 0 14px;border-left:var(--strip-w) solid var(--brand);padding-left:16px;font-style:italic}
.diff-body{font-size:var(--fs-xs);color:var(--text-on-dark-4);line-height:var(--lh-body);margin:0 0 24px}
.diff-mark{width:180px;height:180px;position:relative;display:grid;place-items:center;margin-top:8px}
.diff-mark-ring{width:180px;height:180px;position:absolute;inset:0}
.diff-mark-ring text{font:var(--fw-label) var(--fs-label) var(--font-mono);letter-spacing:var(--ls-label-wide);fill:var(--brand);stroke:none;text-transform:uppercase}
.diff-mark-glyph{position:relative;z-index:1}

/* ── FOOTER CTA ────────────────────────────────────── */
.footer-cta{background:var(--surface-dark);border-top:var(--strip-w) solid var(--brand);padding:var(--space-section) var(--pad) 48px;display:grid;grid-template-columns:1fr auto;gap:40px;align-items:center;max-width:100%}
.footer-cta-text h2{font-family:var(--font-display);font-size:var(--fs-h2);text-transform:uppercase;letter-spacing:var(--ls-display-tight);line-height:var(--lh-display);color:var(--text-on-dark);margin:0 0 10px}
.footer-cta-text h2 span{color:var(--brand)}
.footer-cta-text p{color:var(--text-on-dark-5);font-size:14px;margin:0}
.footer-cta-btn{flex-shrink:0}

/* ── FOOTER CONTACT STRIP ──────────────────────────── */
.footer-strip{background:var(--surface-darker);border-top:var(--hairline) solid var(--border-on-dark-faint);padding:0 var(--pad)}
.footer-strip-inner{max-width:var(--max);margin:0 auto;display:grid;grid-template-columns:1fr repeat(3,auto);gap:0;border-bottom:var(--hairline) solid var(--border-on-dark-faint)}
.footer-brand-col{padding:28px 40px 28px 0;border-right:var(--hairline) solid var(--border-on-dark-faint)}
.footer-brand-col b{font-family:var(--font-display);text-transform:uppercase;font-size:var(--fs-card-title-sm);line-height:var(--lh-display);color:var(--text-on-dark);display:block}
.footer-brand-col small{font-family:var(--font-mono);font-size:var(--fs-micro);font-weight:400;letter-spacing:.12em;color:var(--text-on-dark-faint);display:block;margin-top:6px;text-transform:uppercase}
.footer-info-col{padding:28px 32px;border-right:var(--hairline) solid var(--border-on-dark-faint);display:flex;flex-direction:column;gap:4px}
.footer-info-col:last-child{border-right:0}
.footer-info-label{font:var(--fw-label) var(--fs-micro) var(--font-mono);letter-spacing:.14em;text-transform:uppercase;color:var(--brand)}
.footer-info-val{font-size:var(--fs-sm);color:var(--text-on-dark-1)}
.footer-info-val a{color:inherit}
.footer-legal{max-width:var(--max);margin:0 auto;padding:14px 0;font:400 var(--fs-micro) var(--font-mono);letter-spacing:.1em;text-transform:uppercase;color:var(--text-on-dark-ghost);display:flex;justify-content:space-between}

/* ── RESPONSIVE ────────────────────────────────────── */
@media(max-width:1100px){
  .hero-inner{grid-template-columns:1fr}
  .hero-panel{display:none}
  .cap-grid{grid-template-columns:repeat(2,1fr)}
  .markets-grid{grid-template-columns:repeat(2,1fr)}
  .why-grid{grid-template-columns:repeat(3,1fr)}
  .exp-grid{grid-template-columns:repeat(2,1fr)}
  .partner-inner,.dataplate-inner{grid-template-columns:1fr}
  .partner-inner .proof-col+.proof-col{padding-left:0;border-left:0;border-top:var(--hairline) solid var(--border-on-dark);padding-top:32px}
  .footer-cta{grid-template-columns:1fr}
  .footer-strip-inner{grid-template-columns:1fr 1fr}
  .footer-brand-col{grid-column:1/-1;border-right:0;border-bottom:var(--hairline) solid var(--border-on-dark-faint)}
}
@media(max-width:720px){
  :root{--space-section:48px;--pad:18px}
  .topbar{grid-template-columns:auto 1fr auto;gap:16px;padding:0 18px;min-height:60px}
  .topbar nav{display:none}
  .top-actions{display:none}
  .nav-hamburger{display:flex}
  .hero{min-height:520px}
  .hero-inner{padding:40px 18px 48px;gap:28px}
  .hero h1{font-size:clamp(46px,12vw,68px)}
  .hero-actions{flex-direction:column}
  .stats-inner{grid-template-columns:repeat(2,1fr)}
  .stat-item:nth-child(2){border-right:0}
  .creds-inner{grid-template-columns:repeat(3,1fr)}
  .cred:nth-child(3){border-right:0}
  .cap-grid{grid-template-columns:1fr}
  .markets-grid{grid-template-columns:1fr}
  .why-grid{grid-template-columns:repeat(2,1fr)}
  .why-card{border-right:0}
  .exp-grid{grid-template-columns:1fr}
  .footer-strip-inner{grid-template-columns:1fr}
  .footer-info-col{border-right:0}
  .footer-legal{flex-direction:column;gap:4px}
}

/* ── NAV SCROLL STATE ──────────────────────────────── */
.topbar{transition:background .3s,backdrop-filter .3s,border-color .3s}
.topbar.scrolled{background:rgba(var(--ch-dark),.97);backdrop-filter:blur(12px);border-bottom-color:var(--accent-wash-2)}
.topbar.scrolled .topbar nav a{color:var(--text-on-dark-1)}

/* ── MOBILE HAMBURGER ──────────────────────────────── */
.nav-hamburger{display:none;flex-direction:column;justify-content:center;gap:5px;background:none;border:none;cursor:pointer;padding:8px;z-index:200}
.nav-hamburger span{display:block;width:22px;height:2px;background:var(--text-on-dark);border-radius:var(--radius-sm);transition:transform .25s,opacity .25s}
.nav-hamburger[aria-expanded="true"] span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.nav-hamburger[aria-expanded="true"] span:nth-child(2){opacity:0}
.nav-hamburger[aria-expanded="true"] span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
.nav-drawer{position:fixed;inset:0;top:60px;background:rgba(var(--ch-dark),.97);backdrop-filter:blur(16px);z-index:150;display:flex;flex-direction:column;padding:32px 24px;gap:0;transform:translateX(100%);transition:transform .3s var(--ease);pointer-events:none}
.nav-drawer.open{transform:none;pointer-events:auto}
.nav-drawer-links{display:flex;flex-direction:column;gap:2px}
.nav-drawer-links a{font:var(--fw-label) var(--fs-sm) var(--font-mono);letter-spacing:.14em;text-transform:uppercase;color:var(--text-on-dark-1);padding:14px 0;border-bottom:var(--hairline) solid var(--border-on-dark-faint);transition:color var(--dur-fast)}
.nav-drawer-links a:hover{color:var(--brand)}

/* ── STATS BAR ─────────────────────────────────────── */
.stats-bar{background:var(--surface-brand);padding:0}
.stats-inner{max-width:var(--max);margin:0 auto;display:grid;grid-template-columns:repeat(4,1fr)}
.stat-item{display:flex;flex-direction:column;align-items:center;padding:22px 16px;border-right:var(--hairline) solid rgba(var(--ch-black),.15);gap:2px}
.stat-item:last-child{border-right:0}
.stat-num{font-family:var(--font-display);font-size:clamp(36px,3.5vw,54px);line-height:1;color:var(--text-on-brand);letter-spacing:var(--ls-display)}
.stat-unit{font-family:var(--font-display);font-size:clamp(20px,2vw,32px);line-height:1;color:var(--text-on-brand);margin-left:2px;display:inline}
.stat-label{font:700 var(--fs-label)/1.3 var(--font-mono);letter-spacing:.12em;text-transform:uppercase;color:var(--text-on-brand-soft);text-align:center}

/* ── SCROLL REVEAL ─────────────────────────────────── */
@media(prefers-reduced-motion:no-preference){
  .reveal{opacity:0;transform:translateY(28px);transition:opacity var(--dur-reveal) var(--ease),transform var(--dur-reveal) var(--ease)}
  .reveal.visible{opacity:1;transform:none}
  .reveal-child{opacity:0;transform:translateY(20px);transition:opacity .6s var(--ease),transform .6s var(--ease)}
  .reveal-child.visible{opacity:1;transform:none}
  .reveal-child:nth-child(2){transition-delay:.08s}
  .reveal-child:nth-child(3){transition-delay:.16s}
  .reveal-child:nth-child(4){transition-delay:.08s}
  .reveal-child:nth-child(5){transition-delay:.16s}
  .reveal-child:nth-child(6){transition-delay:.24s}
}

/* ── HERO DEPTH ────────────────────────────────────── */
.hero-bg img{will-change:transform;transition:transform .1s linear}
.hero-copy{animation:heroIn .9s var(--ease) both}
.hero-panel{animation:heroIn 1.1s .2s var(--ease) both}
@keyframes heroIn{from{opacity:0;transform:translateY(24px)}to{opacity:1;transform:none}}
.hero h1{text-shadow:var(--shadow-hero-text)}

/* ── CARD DEPTH + HOVER ────────────────────────────── */
.cap-card{transition:box-shadow .2s,border-color .2s;border-top:var(--strip-w) solid transparent;position:relative;overflow:hidden}
.cap-card::before{content:"";position:absolute;inset:0;background:linear-gradient(135deg,var(--accent-wash) 0%,transparent 60%);opacity:0;transition:opacity .25s}
.cap-card:hover{box-shadow:var(--shadow-card-hover);border-top-color:var(--brand)}
.cap-card:hover::before{opacity:1}
.cap-card:hover .cap-icon{stroke:var(--brand);opacity:1;transform:scale(1.08);transition:stroke .2s,opacity .2s,transform .2s}
.cap-icon{transition:stroke .2s,opacity .2s,transform .2s;transform-origin:center}

/* ── WHY CARD HOVER ────────────────────────────────── */
.why-card{transition:background .2s;position:relative}
.why-card::after{content:"";position:absolute;inset:0;border-bottom:2px solid var(--brand);opacity:0;transition:opacity .2s}
.why-card:hover{background:var(--accent-wash)}
.why-card:hover::after{opacity:1}
.why-card:hover .why-num{letter-spacing:var(--ls-label-wide)}
.why-num{transition:letter-spacing .2s}

/* ── BUTTON RIPPLE + DEPTH ─────────────────────────── */
.btn{position:relative;overflow:hidden;transition:opacity var(--dur-fast),transform var(--dur-fast),box-shadow var(--dur-fast)}
.btn:hover{transform:translateY(-2px);box-shadow:var(--shadow-btn-hover)}
.btn:active{transform:translateY(0);box-shadow:none}
.btn-accent:hover{box-shadow:var(--shadow-accent-glow)}
.btn::after{content:"";position:absolute;inset:50%;background:rgba(var(--ch-light),.25);border-radius:50%;transform:translate(-50%,-50%) scale(0);opacity:0;transition:transform .5s,opacity .4s}
.btn.rippling::after{transform:translate(-50%,-50%) scale(4);opacity:0}

/* ── EXP CARD HOVER ────────────────────────────────── */
.exp-card{transition:transform .25s,box-shadow .25s}
.exp-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-exp-hover)}

/* ── SECTION GRAIN + DEPTH ─────────────────────────── */
.why-wrap,.partner-band,.dataplate-band,.footer-cta,.hero{position:relative}
.why-wrap::before,.partner-band::before,.dataplate-band::before{content:"";position:absolute;inset:0;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='200' height='200'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='200' height='200' filter='url(%23n)' opacity='0.04'/%3E%3C/svg%3E");pointer-events:none;z-index:0}
.why-inner,.proof-inner{position:relative;z-index:1}

/* ── ACCENT LINE PULSE (hero tag) ──────────────────── */
.hero-tag{animation:tagIn .6s .4s both}
@keyframes tagIn{from{opacity:0;transform:translateX(-12px)}to{opacity:1;transform:none}}

/* ── SECTION NUMBER WATERMARKS ─────────────────────── */
.capabilities-wrap{counter-increment:section}
.why-wrap .why-inner::before{content:"02";position:absolute;right:var(--pad);top:-10px;font-family:var(--font-display);font-size:clamp(80px,10vw,160px);color:rgba(var(--ch-light),.03);line-height:1;pointer-events:none;user-select:none}
.experience-wrap .section::before{content:"03";position:absolute;right:var(--pad);top:-10px;font-family:var(--font-display);font-size:clamp(80px,10vw,160px);color:rgba(var(--ch-black),.04);line-height:1;pointer-events:none;user-select:none}
.experience-wrap .section{position:relative}

/* ── HERO PANEL ACCENT ─────────────────────────────── */
.hero-panel{border-left:var(--strip-w) solid var(--accent-wash-2)}

/* ── FOOTER CTA HEADLINE ACCENT ────────────────────── */
.footer-cta-text h2{text-shadow:var(--glow-cta)}

/* ── THEME-AWARE BRAND MARKS ───────────────────────── */
/* Shield "Y" brand mark: shield stays light for legibility on dark
   surfaces; funnel carries the brand accent. Theme-driven via tokens. */
.mark-shield{fill:var(--text-on-dark);stroke:none}
.mark-funnel{fill:var(--brand);stroke:none}
.diff-mark-ring circle{stroke:var(--brand)}

/* ============================================================
   RESTRUCTURE: varied macrostructures + connective tissue
   ============================================================ */

/* ── CAPABILITIES: BENTO ───────────────────────────── */
.bento-grid{max-width:var(--max);margin:0 auto;padding:0 var(--pad) var(--space-section);display:grid;grid-template-columns:repeat(4,1fr);grid-auto-rows:210px;gap:12px;
  grid-template-areas:
    "big big steel steel"
    "big big db civil"
    "renov renov marine marine";}
.b-big{grid-area:big}.b-steel{grid-area:steel}.b-db{grid-area:db}.b-civil{grid-area:civil}.b-renov{grid-area:renov}.b-marine{grid-area:marine}
.bento-tile{position:relative;overflow:hidden;display:flex;flex-direction:column;justify-content:flex-end;padding:24px;transition:transform .3s var(--ease),box-shadow .3s var(--ease)}
.bento-tile:hover{transform:translateY(-4px);box-shadow:var(--shadow-card-hover)}
.bento-content{position:relative;z-index:2}
.bento-code{font:var(--fw-label) var(--fs-micro) var(--font-mono);letter-spacing:.14em;color:var(--brand);display:block;margin:0 0 8px}
.bento-tile h3{font-family:var(--font-display);text-transform:uppercase;letter-spacing:-.015em;line-height:.94;margin:0 0 8px;font-size:var(--fs-h6)}
.bento-tile p{font-size:var(--fs-sm);line-height:1.5;margin:0}
.bento-text{background:var(--surface-paper);border-top:var(--strip-w) solid transparent;justify-content:space-between}
.bento-text .cap-icon{width:40px;height:40px;stroke:var(--text-on-light);opacity:.7;margin:0;transition:stroke .2s,transform .2s}
.bento-text h3{color:var(--text-on-light)}
.bento-text p{color:var(--text-on-light-soft)}
.bento-text:hover{border-top-color:var(--brand)}
.bento-text:hover .cap-icon{stroke:var(--brand);transform:scale(1.08)}
.bento-photo{background:var(--surface-dark)}
.bento-photo::before{content:"";position:absolute;inset:0;background-image:var(--img);background-size:cover;background-position:center;filter:saturate(.4) contrast(1.1) brightness(.68);transition:transform .6s var(--ease),filter .3s}
.bento-photo::after{content:"";position:absolute;inset:0;background:linear-gradient(to top,rgba(var(--ch-dark),.92) 0%,rgba(var(--ch-dark),.35) 55%,transparent 100%)}
.bento-photo:hover::before{transform:scale(1.06);filter:saturate(.6) contrast(1.1) brightness(.76)}
.bento-photo h3{color:var(--text-on-dark)}
.bento-photo p{color:var(--text-on-dark-2)}
.b-big h3{font-size:var(--fs-h4)}

/* ── MARKETS: STICKY SPLIT ─────────────────────────── */
.markets-split{max-width:var(--max);margin:0 auto;padding:var(--space-section) var(--pad);display:grid;grid-template-columns:380px 1fr;gap:clamp(32px,5vw,80px);align-items:start}
.markets-aside{position:sticky;top:100px}
.markets-headline{font-family:var(--font-display);font-size:var(--fs-h3);line-height:.9;text-transform:uppercase;letter-spacing:var(--ls-display);margin:0 0 18px;color:var(--text-on-light)}
.markets-headline .hi{color:var(--brand)}
.markets-lede{font-size:var(--fs-body);line-height:1.65;color:var(--text-on-light-soft);margin:0 0 24px;font-weight:300}
.markets-list{list-style:none;margin:0;padding:0;border-top:var(--hairline) solid var(--border-on-light)}
.market-row{display:grid;grid-template-columns:64px 1fr;gap:20px;align-items:baseline;padding:24px 8px;border-bottom:var(--hairline) solid var(--border-on-light);transition:padding-left .25s var(--ease),background .2s}
.market-row:hover{padding-left:20px;background:var(--accent-wash)}
.market-row .market-code{font:var(--fw-label) var(--fs-sm) var(--font-mono);letter-spacing:.1em;color:var(--text-on-light-muted);transition:color .2s}
.market-row:hover .market-code{color:var(--brand)}
.market-row h3{font-family:var(--font-display);font-size:var(--fs-h6);text-transform:uppercase;letter-spacing:-.01em;line-height:1;margin:0 0 6px;color:var(--text-on-light)}
.market-row p{font-size:var(--fs-sm);color:var(--text-on-light-soft);margin:0;line-height:1.5}

/* ── PROCESS SPINE ─────────────────────────────────── */
.process-wrap{background:var(--surface-mid)}
.process-wrap .section-tag{color:var(--text-on-dark-5)}
.process-headline{font-family:var(--font-display);font-size:var(--fs-h4);text-transform:uppercase;letter-spacing:var(--ls-display);line-height:.9;color:var(--text-on-dark);margin:0 0 44px}
.process-headline .hi{color:var(--brand)}
.process-spine{list-style:none;margin:0;padding:0;display:grid;grid-template-columns:repeat(4,1fr);gap:0;position:relative}
.process-spine::before{content:"";position:absolute;top:18px;left:0;right:24px;height:2px;background:linear-gradient(to right,var(--brand),rgba(var(--ch-accent),.12))}
.process-step{position:relative;padding:0 28px 0 0}
.process-num{display:grid;place-items:center;width:38px;height:38px;border-radius:50%;background:var(--surface-mid);border:2px solid var(--brand);color:var(--brand);font:var(--fw-label) var(--fs-sm) var(--font-mono);position:relative;z-index:1;margin:0 0 22px}
.process-step h3{font-family:var(--font-display);font-size:var(--fs-card-title);text-transform:uppercase;letter-spacing:-.01em;color:var(--text-on-dark);margin:0 0 10px}
.process-step p{font-size:var(--fs-sm);color:var(--text-on-dark-3);line-height:1.55;margin:0}

/* ── WHY: ASYMMETRIC ───────────────────────────────── */
.why-grid{grid-template-columns:repeat(4,1fr)}
.why-feature{grid-column:span 2;grid-row:span 2;display:flex;flex-direction:column;justify-content:center;background:var(--accent-wash)}
.why-feature .why-num{font-size:var(--fs-card-title);margin-bottom:18px}
.why-feature h3{font-size:var(--fs-h5);margin-bottom:16px}
.why-feature p{font-size:var(--fs-body);color:var(--text-on-dark-2);line-height:1.6}
.why-wide{grid-column:1/-1}
.why-wide h3{font-size:var(--fs-card-title)}

/* ── FULL-BLEED IMAGE BREAK ────────────────────────── */
.break-band{position:relative;min-height:400px;display:flex;align-items:center;background:var(--surface-dark);overflow:hidden}
.break-band::before{content:"";position:absolute;inset:0;background-image:var(--img);background-size:cover;background-position:center 35%;filter:saturate(.3) contrast(1.15) brightness(.5)}
.break-band::after{content:"";position:absolute;inset:0;background:linear-gradient(105deg,rgba(var(--ch-dark),.86) 0%,rgba(var(--ch-dark),.5) 70%,rgba(var(--ch-dark),.35) 100%)}
.break-inner{position:relative;z-index:2;max-width:var(--max);margin:0 auto;padding:72px var(--pad);width:100%}
.break-eyebrow{font:var(--fw-label) var(--fs-label) var(--font-mono);letter-spacing:.18em;text-transform:uppercase;color:var(--brand);margin:0 0 16px}
.break-headline{font-family:var(--font-display);font-size:var(--fs-h2);text-transform:uppercase;letter-spacing:var(--ls-display-tight);line-height:.9;color:var(--text-on-dark);margin:0 0 16px;text-shadow:var(--shadow-hero-text)}
.break-headline .hi{color:var(--brand)}
.break-sub{font-size:var(--fs-body);color:var(--text-on-dark-2);max-width:520px;margin:0;font-weight:300}

/* ── EXPERIENCE: EDITORIAL ─────────────────────────── */
.exp-editorial{display:grid;grid-template-columns:1fr;gap:24px}
.exp-feature{display:grid;grid-template-columns:1.25fr 1fr;background:var(--surface-paper);overflow:hidden;transition:box-shadow .25s}
.exp-feature:hover{box-shadow:var(--shadow-exp-hover)}
.exp-feature-photo{position:relative;min-height:340px;overflow:hidden}
.exp-feature-photo img{filter:saturate(.3) contrast(1.2) brightness(.9);transition:transform .5s var(--ease)}
.exp-feature:hover .exp-feature-photo img{transform:scale(1.04)}
.exp-feature-body{padding:clamp(28px,3vw,52px);display:flex;flex-direction:column;justify-content:center}
.exp-feature-tag{font:var(--fw-label) var(--fs-micro) var(--font-mono);letter-spacing:.16em;text-transform:uppercase;color:var(--brand);margin:0 0 12px}
.exp-feature-body h3{font-family:var(--font-display);font-size:var(--fs-h5);text-transform:uppercase;letter-spacing:-.01em;line-height:.95;color:var(--text-on-light);margin:0 0 12px}
.exp-feature-body>p{font-size:var(--fs-body);color:var(--text-on-light-soft);line-height:1.6;margin:0 0 18px}
.exp-pair{display:grid;grid-template-columns:1fr 1fr;gap:24px}

/* ── RESTRUCTURE RESPONSIVE ────────────────────────── */
@media(max-width:1100px){
  .bento-grid{grid-template-columns:repeat(2,1fr);grid-template-areas:"big big" "steel steel" "db civil" "renov marine"}
  .why-grid{grid-template-columns:repeat(2,1fr)}
  .why-feature{grid-column:span 2;grid-row:auto}
  .hero-panel.hero-badge{display:none}
  .dataplate-inner,.partner-inner{grid-template-columns:1fr}
  .partner-inner .proof-col+.proof-col{padding-left:0;border-left:0;border-top:var(--hairline) solid var(--border-on-dark);padding-top:32px}
}
@media(max-width:900px){
  .markets-split{grid-template-columns:1fr;gap:32px}
  .markets-aside{position:static}
  .process-spine{grid-template-columns:repeat(2,1fr);gap:36px 24px}
  .process-spine::before{display:none}
  .exp-feature{grid-template-columns:1fr}
  .exp-feature-photo{min-height:240px}
  .exp-pair{grid-template-columns:1fr}
}
@media(max-width:720px){
  .bento-grid{grid-template-columns:1fr;grid-auto-rows:190px;grid-template-areas:"big" "steel" "db" "civil" "renov" "marine"}
  .why-grid{grid-template-columns:1fr}
  .why-feature{grid-column:1/-1}
  .process-spine{grid-template-columns:1fr;gap:28px}
  .break-band{min-height:320px}
  .cap-head{grid-template-columns:1fr;gap:18px;justify-items:start}
  .exp-head{flex-direction:column;gap:18px}
  .nav-hamburger{display:flex}
}

/* Grain on new dark bands */
.process-wrap{position:relative}
.process-wrap::before{content:"";position:absolute;inset:0;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='200' height='200'%3E%3Cfilter id='n2'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='200' height='200' filter='url(%23n2)' opacity='0.035'/%3E%3C/svg%3E");pointer-events:none;z-index:0}
.process-wrap .section{position:relative;z-index:1}

/* ── HERO BADGE (circular P mark) ──────────────────── */
.hero-panel.hero-badge{background:none;border-left:0;padding:0;place-items:center}
@media(min-width:1101px){.hero-panel.hero-badge{display:grid}}
.hero-mark{width:240px;height:240px}
.hero-mark .diff-mark-ring{width:240px;height:240px}
@media(prefers-reduced-motion:no-preference){
  .hero-mark .diff-mark-ring{animation:badgeSpin 40s linear infinite;transform-origin:center}
}
@keyframes badgeSpin{to{transform:rotate(360deg)}}

/* ── ANDROMEDA JV LOGO LOCKUP ──────────────────────── */
.mentor-lockup{display:flex;align-items:center;gap:14px;margin:0 0 6px}
.mentor-logo{width:52px;height:52px;flex-shrink:0;object-fit:contain;background:var(--c-white);border-radius:50%;padding:7px}
.mentor-lockup .mentor-name{margin:0;line-height:.92}
.mentor-name small{display:block;font-family:var(--font-mono);font-size:var(--fs-micro);font-weight:400;letter-spacing:.08em;color:var(--text-on-dark-5);text-transform:none;margin-top:5px}

/* ── MARKETS SERVED ────────────────────────────────── */
.markets-wrap{background:var(--surface-paper)}
.markets-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--hairline);background:var(--border-on-light-gap)}
.market-card{background:var(--surface-paper);padding:28px var(--space-card);display:flex;flex-direction:column;gap:0;min-height:150px;transition:box-shadow .2s,border-color .2s;border-top:var(--strip-w) solid transparent}
.market-card:hover{box-shadow:var(--shadow-card-hover);border-top-color:var(--brand)}
.market-code{font:var(--fw-label) var(--fs-micro) var(--font-mono);letter-spacing:.14em;color:var(--text-on-light-muted);margin:0 0 14px}
.market-card h3{font-family:var(--font-display);font-size:var(--fs-h6);line-height:.94;text-transform:uppercase;letter-spacing:-.015em;margin:0 0 8px;color:var(--text-on-light)}
.market-card p{font-size:var(--fs-sm);color:var(--text-on-light-soft);margin:0;line-height:1.55;flex:1}

/* ── PARTNERSHIP + DIFFERENCE BAND ─────────────────── */
.partner-band{background:var(--surface-dark);border-top:var(--hairline) solid var(--border-on-dark-soft)}
.partner-inner{max-width:var(--max);margin:0 auto;padding:var(--space-section) var(--pad);display:grid;grid-template-columns:1fr 1fr;gap:clamp(28px,4vw,56px);position:relative;z-index:1}
.partner-inner .proof-col+.proof-col{padding-left:clamp(28px,4vw,56px);border-left:var(--hairline) solid var(--border-on-dark)}

/* ── COMPANY DATA PLATE + SAFETY ───────────────────── */
.dataplate-band{background:var(--surface-dark);border-top:var(--hairline) solid var(--border-on-dark-soft)}
.dataplate-inner{max-width:var(--max);margin:0 auto;padding:var(--space-section) var(--pad);display:grid;grid-template-columns:1.2fr 1fr;gap:clamp(28px,4vw,56px);position:relative;z-index:1}
.dataplate-inner .section-tag{color:var(--text-on-dark-5)}
.dataplate{margin:0;display:grid;grid-template-columns:auto 1fr;gap:0;border-top:var(--hairline) solid var(--border-on-dark)}
.dataplate dt{font:var(--fw-label) var(--fs-micro) var(--font-mono);letter-spacing:.1em;text-transform:uppercase;color:var(--text-on-dark-5);padding:12px 16px 12px 0;border-bottom:var(--hairline) solid var(--border-on-dark);display:flex;align-items:center}
.dataplate dd{margin:0;font-size:var(--fs-sm);color:var(--text-on-dark-1);padding:12px 0;border-bottom:var(--hairline) solid var(--border-on-dark);display:flex;align-items:center}
.dataplate-note{font:400 var(--fs-micro) var(--font-mono);letter-spacing:.04em;text-transform:uppercase;color:var(--text-on-dark-5);margin:18px 0 14px;line-height:1.5}

/* ── FINAL RESPONSIVE OVERRIDES (appended last so they win over base) ── */
@media(max-width:1100px){
  .partner-inner,.dataplate-inner{grid-template-columns:1fr}
  .partner-inner .proof-col+.proof-col{padding-left:0;border-left:0;border-top:var(--hairline) solid var(--border-on-dark);padding-top:32px}
}

/* ============================================================
   MICRO-INTERACTIONS & MOTION POLISH (appended last so it wins)
   Non-essential motion guarded by prefers-reduced-motion.
   ============================================================ */

/* Scroll progress — thin accent bar pinned to the top edge */
.scroll-progress{position:fixed;top:0;left:0;height:2px;width:0;background:var(--brand);z-index:300;pointer-events:none;box-shadow:0 0 8px var(--accent-glow);will-change:width}

/* Hero scroll cue (static styling) */
.scroll-cue{position:absolute;left:var(--pad);bottom:22px;z-index:3;display:flex;align-items:center;gap:12px;opacity:.6;font:var(--fw-label) var(--fs-micro) var(--font-mono);letter-spacing:.2em;text-transform:uppercase;color:var(--text-on-dark-3);pointer-events:none}
.scroll-cue-line{position:relative;display:block;width:1px;height:34px;background:var(--border-on-dark-strong);overflow:hidden}
.scroll-cue-line::after{content:"";position:absolute;inset:0;background:var(--brand)}
@media(max-width:760px){.scroll-cue{display:none}}

@media(prefers-reduced-motion:no-preference){
  /* Nav + drawer links: accent underline draws in from the left */
  .topbar nav a,.nav-drawer-links a{position:relative}
  .topbar nav a::after,.nav-drawer-links a::after{content:"";position:absolute;left:0;bottom:0;height:1.5px;width:100%;background:var(--brand);transform:scaleX(0);transform-origin:left;transition:transform var(--dur) var(--ease)}
  .topbar nav a:hover::after,.topbar nav a.nav-active::after,.nav-drawer-links a:hover::after{transform:scaleX(1)}

  /* Brand mark: funnel resolves to white + lifts a hair on hover */
  .brand{transition:transform var(--dur) var(--ease)}
  .brand:hover{transform:translateY(-1px)}
  .brand-logo{transition:opacity var(--dur) var(--ease)}
  .brand:hover .brand-logo{opacity:.85}

  /* CTA trailing arrow nudges right on hover (arrow wrapped by JS) */
  .btn-arr{display:inline-block;transition:transform var(--dur) var(--ease)}
  .btn:hover .btn-arr{transform:translateX(4px)}

  /* Credentials: staggered entrance + lift/accent on hover */
  .creds.visible .cred{animation:credIn .5s var(--ease) both}
  .creds.visible .cred:nth-child(2){animation-delay:.06s}
  .creds.visible .cred:nth-child(3){animation-delay:.12s}
  .creds.visible .cred:nth-child(4){animation-delay:.18s}
  .creds.visible .cred:nth-child(5){animation-delay:.24s}
  .creds.visible .cred:nth-child(6){animation-delay:.30s}
  @keyframes credIn{from{opacity:0;transform:translateY(12px)}to{opacity:1;transform:none}}
  .cred{transition:transform var(--dur) var(--ease)}
  .cred svg{transition:stroke var(--dur) var(--ease),transform var(--dur) var(--ease);transform-origin:center}
  .cred:hover{transform:translateY(-3px)}
  .cred:hover svg{stroke:var(--brand);transform:scale(1.08)}

  /* Hero headline: subtle clip-wipe reveal layered over the copy fade */
  .hero h1{animation:wipeUp 1s .15s var(--ease) both}
  @keyframes wipeUp{from{opacity:0;clip-path:inset(0 0 100% 0);transform:translateY(10px)}to{opacity:1;clip-path:inset(0 0 0 0);transform:none}}

  /* Hero scroll cue: fades in, accent tick travels down the rule */
  .scroll-cue{animation:cueFade 1s 1.1s var(--ease) both}
  .scroll-cue-line::after{animation:cueLine 1.9s var(--ease) infinite}
  @keyframes cueFade{from{opacity:0}to{opacity:.6}}
  @keyframes cueLine{0%{transform:translateY(-100%)}60%,100%{transform:translateY(100%)}}

  /* Section eyebrows: the existing leading rule grows in on reveal */
  .reveal .section-tag::before{transform:scaleX(0);transform-origin:left;transition:transform .6s .15s var(--ease)}
  .reveal.visible .section-tag::before{transform:scaleX(1)}
}
