/* ══════════════════════════════════════════════════════
   WOLFPACK AI — main.css
   Shared styles for all pages
══════════════════════════════════════════════════════ */

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;}
html{scroll-behavior:auto;}
html,body{overflow-x:hidden;max-width:100vw;}

:root{
  --near-black:#0a0a0a;
  --gold:#C4A35A;
  --text-primary:#f0ece4;
  --text-muted:#999999;
  --bp-grid:rgba(240,236,228,0.035);
  --bp-construction:rgba(240,236,228,0.10);
  --bp-primary:rgba(240,236,228,0.70);
  --bp-annotation:rgba(240,236,228,0.38);
  --bp-dimension:rgba(196,163,90,0.25);
  --ease-precise:cubic-bezier(0.16,1,0.3,1);
}

body{
  font-family:'DM Sans',-apple-system,sans-serif;
  font-weight:300;
  background:var(--near-black);
  color:var(--text-primary);
  -webkit-font-smoothing:antialiased;
}

h1,h2,h3{font-family:'Lora',Georgia,serif;}

/* Blueprint grid — global utility */
.bp-grid-bg{
  position:absolute;inset:0;
  background-image:
    linear-gradient(var(--bp-grid) 1px,transparent 1px),
    linear-gradient(90deg,var(--bp-grid) 1px,transparent 1px);
  background-size:48px 48px;
  pointer-events:none;z-index:0;
}

/* Corner marks */
.cm{position:absolute;width:14px;height:14px;border-color:rgba(196,163,90,0.45);border-style:solid;}
.cm-tl{top:18px;left:18px;border-width:1px 0 0 1px;}
.cm-tr{top:18px;right:18px;border-width:1px 1px 0 0;}
.cm-bl{bottom:18px;left:18px;border-width:0 0 1px 1px;}
.cm-br{bottom:18px;right:18px;border-width:0 1px 1px 0;}

/* Reveal — JS adds .hidden, never CSS-init */
.reveal{transition:opacity 0.7s var(--ease-precise),transform 0.7s var(--ease-precise);}
.reveal.hidden{opacity:0;transform:translateY(20px);}
.reveal.visible{opacity:1;transform:none;}

/* Section label */
.sec-label{
  font-family:'DM Sans',sans-serif;font-size:0.7rem;
  letter-spacing:0.22em;text-transform:uppercase;
  color:var(--text-muted);text-align:center;margin-bottom:60px;
  display:block;
}
.sec-label::before{content:'—— ';color:var(--gold);}

/* ══════════════════════════════
   NAVIGATION
══════════════════════════════ */
#site-nav{
  position:fixed;top:0;left:0;right:0;z-index:1000;
  padding:20px 40px;
  display:flex;align-items:center;justify-content:space-between;
  transition:background 0.35s ease, padding 0.35s ease;
}
#site-nav.scrolled{
  background:rgba(10,10,10,0.92);
  backdrop-filter:blur(12px);
  -webkit-backdrop-filter:blur(12px);
  padding:14px 40px;
  border-bottom:1px solid rgba(240,236,228,0.06);
}
.nav-logo{
  font-family:'Lora',Georgia,serif;font-size:1rem;font-style:italic;
  color:var(--text-primary);text-decoration:none;
  transition:color 0.2s;
}
.nav-logo span{color:var(--gold);}
.nav-logo:hover{color:var(--gold);}
.nav-links{
  display:flex;align-items:center;gap:36px;list-style:none;
}
.nav-links a{
  font-family:'DM Sans',sans-serif;font-size:0.75rem;
  letter-spacing:0.1em;text-transform:uppercase;
  color:var(--text-muted);text-decoration:none;
  transition:color 0.2s;
}
.nav-links a:hover{color:var(--text-primary);}
.nav-links a.active{color:var(--text-primary);}
.nav-cta{
  padding:9px 22px !important;
  border:1px solid rgba(196,163,90,0.45) !important;
  color:var(--gold) !important;
  position:relative;overflow:hidden;
  transition:color 0.3s !important;
}
.nav-cta::before{
  content:'';position:absolute;inset:0;background:var(--gold);
  transform:scaleX(0);transform-origin:left;
  transition:transform 0.3s var(--ease-precise);z-index:-1;
}
.nav-cta:hover::before{transform:scaleX(1);}
.nav-cta:hover{color:var(--near-black) !important;}
.nav-toggle{
  display:none;background:none;border:none;cursor:pointer;
  width:28px;height:20px;flex-direction:column;justify-content:space-between;
  padding:0;
}
.nav-toggle span{
  display:block;width:100%;height:1px;
  background:var(--text-primary);
  transition:transform 0.3s ease,opacity 0.3s ease;
}
.nav-toggle.open span:first-child{transform:translateY(9.5px) rotate(45deg);}
.nav-toggle.open span:last-child{transform:translateY(-9.5px) rotate(-45deg);}

/* ══════════════════════════════
   1. HERO
══════════════════════════════ */
#hero{
  position:relative;min-height:100vh;overflow:hidden;
  display:flex;align-items:center;justify-content:center;
  background-color:var(--near-black);
  background-image:url('../assets/sky-assets/sky-bg.jpg');
  background-size:cover;
  background-position:center;
}
#hero-canvas{position:absolute;inset:0;width:100%;height:100%;z-index:1;opacity:0.35;}
.hero-content{position:relative;z-index:3;text-align:center;padding:0 24px;max-width:860px;}

.hero-hl{
  font-family:'Lora',Georgia,serif;
  font-size:clamp(2.8rem,6vw,5rem);
  font-weight:400;font-style:italic;
  line-height:1.18;color:var(--text-primary);
  letter-spacing:-0.02em;margin-bottom:32px;
  min-height:2.4em;
}

.hero-sub{
  font-family:'DM Sans',sans-serif;font-weight:300;
  font-size:clamp(0.9rem,1.8vw,1.1rem);
  color:var(--text-muted);letter-spacing:0.1em;
  text-transform:uppercase;margin-bottom:52px;
}

.hero-cta{
  display:inline-block;padding:14px 44px;
  border:1px solid var(--gold);color:var(--gold);
  font-family:'DM Sans',sans-serif;font-weight:400;
  font-size:0.8rem;letter-spacing:0.14em;text-transform:uppercase;
  text-decoration:none;position:relative;overflow:hidden;
  transition:color 0.3s;
}
.hero-cta::before{
  content:'';position:absolute;inset:0;background:var(--gold);
  transform:scaleX(0);transform-origin:left;
  transition:transform 0.3s var(--ease-precise);z-index:-1;
}
.hero-cta:hover::before{transform:scaleX(1);}
.hero-cta:hover{color:var(--near-black);}

.scroll-ind{
  position:absolute;bottom:36px;left:50%;
  transform:translateX(-50%);z-index:4;
  display:flex;flex-direction:column;align-items:center;gap:6px;opacity:0.3;
}
.scroll-ind span{display:block;width:1px;height:44px;background:var(--text-primary);animation:spulse 2s ease-in-out infinite;}
@keyframes spulse{0%,100%{transform:scaleY(1);opacity:1;}50%{transform:scaleY(0.35);opacity:0.2;}}

/* Page hero (non-home pages) */
.page-hero{
  position:relative;padding:160px 40px 100px;text-align:center;
  background:var(--near-black);overflow:hidden;
}
.page-hero-label{
  font-family:'DM Sans',sans-serif;font-size:0.68rem;
  letter-spacing:0.22em;text-transform:uppercase;
  color:var(--gold);margin-bottom:20px;display:block;
}
.page-hero-title{
  font-family:'Lora',serif;font-size:clamp(2.4rem,5vw,4rem);
  font-style:italic;font-weight:400;color:var(--text-primary);
  line-height:1.15;margin-bottom:20px;
}
.page-hero-sub{
  font-family:'DM Sans',sans-serif;font-size:0.95rem;
  color:var(--text-muted);max-width:520px;margin:0 auto;
  line-height:1.75;
}

/* ══════════════════════════════
   2. BLUEPRINT REVEAL
══════════════════════════════ */
#blueprint{position:relative;background:#0f0f0f;overflow:hidden;}
.bp-pin{position:relative;height:300vh;}
.bp-sticky{
  position:sticky;top:0;height:100vh;
  display:flex;align-items:center;justify-content:center;overflow:hidden;
}
.bp-inner{position:relative;width:100%;height:100%;display:flex;align-items:center;justify-content:center;}
#bp-svg-wrap{position:relative;width:min(680px,88vw);}
#bp-svg{width:100%;height:auto;}

.bp-copy{
  position:absolute;bottom:9vh;left:50%;transform:translateX(-50%);
  text-align:center;z-index:10;width:100%;pointer-events:none;
}
.bp-line{
  display:block;font-family:'Lora',serif;
  font-size:clamp(1.3rem,2.8vw,2rem);font-style:italic;
  color:var(--text-primary);opacity:0;transform:translateY(14px);
  transition:opacity 0.5s ease,transform 0.5s ease;
}
.bp-line.sec{color:var(--text-muted);font-size:clamp(1rem,2vw,1.4rem);margin-top:10px;}
.bp-ann{font-family:'DM Sans',sans-serif;font-size:8px;letter-spacing:0.14em;text-transform:uppercase;fill:rgba(196,163,90,0.45);}

/* ══════════════════════════════
   3. SERVICES
══════════════════════════════ */
#services{position:relative;padding:140px 0;background:var(--near-black);overflow:hidden;background-image:url('../assets/sky-assets/sky-blue-hour.jpg');background-size:cover;background-position:center;}
#services::before{content:'';position:absolute;inset:0;background:rgba(10,10,10,0.72);z-index:0;}
.svc-grid{
  display:grid;grid-template-columns:repeat(3,1fr);
  max-width:1100px;margin:0 auto;padding:0 40px;
  position:relative;z-index:1;gap:0;
}
.svc-card{
  position:relative;padding:48px 40px;
  border:1px solid rgba(240,236,228,0.08);
  transition:border-color 0.35s;overflow:hidden;
}
.svc-card::before,.svc-card::after{
  content:'';position:absolute;width:10px;height:10px;
  border-color:rgba(196,163,90,0.25);border-style:solid;
  transition:border-color 0.35s;
}
.svc-card::before{top:12px;left:12px;border-width:1px 0 0 1px;}
.svc-card::after{bottom:12px;right:12px;border-width:0 1px 1px 0;}
.svc-card:hover{border-color:var(--gold);}
.svc-card:hover::before,.svc-card:hover::after{border-color:var(--gold);}
.svc-bp{width:100%;height:110px;margin-bottom:32px;opacity:0.55;}
.svc-tier{font-family:'DM Sans',sans-serif;font-size:0.68rem;letter-spacing:0.2em;text-transform:uppercase;color:var(--text-muted);margin-bottom:10px;}
.svc-name{font-family:'Lora',serif;font-size:1.5rem;font-style:italic;font-weight:400;color:var(--text-primary);margin-bottom:24px;}
.svc-price{font-family:'DM Sans',sans-serif;font-size:2rem;font-weight:300;color:var(--gold);margin-bottom:4px;letter-spacing:-0.02em;}
.svc-unit{font-family:'DM Sans',sans-serif;font-size:0.78rem;color:var(--text-muted);letter-spacing:0.08em;margin-bottom:32px;}
.svc-feats{list-style:none;padding:0;}
.svc-feats li{font-family:'DM Sans',sans-serif;font-size:0.86rem;color:var(--text-muted);padding:8px 0;border-bottom:1px solid rgba(240,236,228,0.06);display:flex;align-items:flex-start;gap:10px;}
.svc-feats li::before{content:'—';color:rgba(196,163,90,0.35);flex-shrink:0;}
.svc-card.featured{border-color:rgba(196,163,90,0.3);}
.svc-badge{
  display:inline-block;font-family:'DM Sans',sans-serif;font-size:0.62rem;
  letter-spacing:0.16em;text-transform:uppercase;
  background:rgba(196,163,90,0.12);color:var(--gold);
  padding:4px 10px;margin-bottom:10px;border:1px solid rgba(196,163,90,0.2);
}
.svc-cta-wrap{margin-top:32px;}
.svc-btn{
  display:inline-block;width:100%;text-align:center;
  padding:13px 20px;border:1px solid rgba(240,236,228,0.15);
  color:var(--text-muted);
  font-family:'DM Sans',sans-serif;font-weight:400;
  font-size:0.76rem;letter-spacing:0.12em;text-transform:uppercase;
  text-decoration:none;position:relative;overflow:hidden;
  transition:color 0.3s,border-color 0.3s;
}
.svc-btn::before{
  content:'';position:absolute;inset:0;background:rgba(196,163,90,0.08);
  transform:scaleX(0);transform-origin:left;
  transition:transform 0.3s var(--ease-precise);z-index:-1;
}
.svc-btn:hover::before{transform:scaleX(1);}
.svc-btn:hover{color:var(--text-primary);border-color:rgba(196,163,90,0.4);}
.svc-btn.gold{
  border-color:rgba(196,163,90,0.5);color:var(--gold);
}
.svc-btn.gold::before{background:var(--gold);}
.svc-btn.gold:hover{color:var(--near-black);}

/* SDR Math block */
.sdr-math{
  max-width:860px;margin:80px auto 0;padding:56px 60px;
  border:1px solid rgba(240,236,228,0.08);
  position:relative;
}
.sdr-math::before,.sdr-math::after{
  content:'';position:absolute;width:12px;height:12px;
  border-color:rgba(196,163,90,0.4);border-style:solid;
}
.sdr-math::before{top:14px;left:14px;border-width:1px 0 0 1px;}
.sdr-math::after{bottom:14px;right:14px;border-width:0 1px 1px 0;}
.sdr-math-label{font-family:'DM Sans',sans-serif;font-size:0.65rem;letter-spacing:0.22em;text-transform:uppercase;color:var(--gold);margin-bottom:24px;display:block;}
.sdr-math-row{display:flex;align-items:baseline;gap:20px;margin-bottom:16px;}
.sdr-math-row:last-of-type{margin-bottom:0;}
.sdr-num{font-family:'Lora',serif;font-size:clamp(1.8rem,3.5vw,2.8rem);font-style:italic;color:var(--text-primary);line-height:1;letter-spacing:-0.02em;}
.sdr-num.crossed{text-decoration:line-through;color:var(--text-muted);font-size:clamp(1.2rem,2.5vw,2rem);}
.sdr-num.gold{color:var(--gold);}
.sdr-desc{font-family:'DM Sans',sans-serif;font-size:0.82rem;color:var(--text-muted);line-height:1.6;}
.sdr-vs{font-family:'DM Sans',sans-serif;font-size:0.7rem;letter-spacing:0.14em;text-transform:uppercase;color:rgba(196,163,90,0.4);padding:8px 0;}
.sdr-ratio{
  margin-top:32px;padding-top:28px;
  border-top:1px solid rgba(240,236,228,0.07);
  font-family:'Lora',serif;font-size:clamp(1.1rem,2vw,1.5rem);
  font-style:italic;color:var(--text-primary);
}

/* ══════════════════════════════
   4. PROCESS
══════════════════════════════ */
#process{position:relative;padding:140px 0;overflow:hidden;background:#070707;}
.proc-inner{max-width:860px;margin:0 auto;padding:0 40px;position:relative;z-index:1;}
.proc-hdr{text-align:center;margin-bottom:96px;}
.proc-title{font-family:'Lora',serif;font-size:clamp(1.8rem,3.5vw,2.8rem);font-style:italic;font-weight:400;color:var(--text-primary);line-height:1.25;}
.proc-steps{position:relative;}
.proc-connector{position:absolute;left:32px;top:32px;bottom:32px;width:2px;}
#proc-line{stroke:rgba(240,236,228,0.1);stroke-width:1;}
.proc-step{display:flex;align-items:flex-start;gap:44px;padding:52px 0;position:relative;}
.step-mk{flex-shrink:0;width:64px;height:64px;position:relative;display:flex;align-items:center;justify-content:center;}
.step-mk svg{position:absolute;inset:0;width:100%;height:100%;}
.step-num{font-family:'Lora',serif;font-size:0.95rem;font-style:italic;color:var(--gold);position:relative;z-index:1;}
.step-body{padding-top:10px;}
.step-title{font-family:'Lora',serif;font-size:1.4rem;font-style:italic;font-weight:400;color:var(--text-primary);margin-bottom:12px;}
.step-desc{font-family:'DM Sans',sans-serif;font-size:0.9rem;color:var(--text-muted);line-height:1.75;max-width:480px;}

/* ══════════════════════════════
   5. PROOF
══════════════════════════════ */
#proof{position:relative;padding:140px 0;background:#111111;overflow:hidden;}
.proof-inner{max-width:1100px;margin:0 auto;padding:0 40px;position:relative;z-index:1;}
.stats-row{
  display:grid;grid-template-columns:repeat(3,1fr);
  border:1px solid rgba(240,236,228,0.07);
  margin-bottom:96px;
}
.stat-block{
  padding:60px 48px;background:var(--near-black);
  position:relative;border-right:1px solid rgba(240,236,228,0.07);
}
.stat-block:last-child{border-right:none;}
.stat-block::after{content:'';position:absolute;bottom:0;left:48px;right:48px;height:1px;background:var(--bp-dimension);}
.stat-num{font-family:'Lora',serif;font-size:clamp(2.2rem,5vw,3.6rem);font-style:italic;font-weight:400;color:var(--text-primary);line-height:1;margin-bottom:12px;letter-spacing:-0.03em;}
.stat-lbl{font-family:'DM Sans',sans-serif;font-size:0.75rem;letter-spacing:0.16em;text-transform:uppercase;color:var(--text-muted);}
.proof-cols{display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:center;}
.proof-q{position:relative;padding-left:28px;}
.proof-q::before{content:'';position:absolute;left:0;top:0;bottom:0;width:1px;background:var(--gold);}
blockquote{font-family:'Lora',serif;font-size:clamp(1.05rem,2vw,1.35rem);font-style:italic;color:var(--text-primary);line-height:1.65;margin-bottom:20px;}
.q-attr{font-family:'DM Sans',sans-serif;font-size:0.75rem;letter-spacing:0.12em;text-transform:uppercase;color:var(--text-muted);}
.proof-body{font-family:'DM Sans',sans-serif;font-size:0.9rem;color:var(--text-muted);line-height:1.85;}
.proof-body strong{color:var(--text-primary);font-weight:400;}

/* ══════════════════════════════
   6. DEMOS
══════════════════════════════ */
#demos{position:relative;padding:140px 0;background:#070707;overflow:hidden;}
.demos-inner{max-width:1100px;margin:0 auto;padding:0 40px;position:relative;z-index:1;}
.demos-title{font-family:'Lora',serif;font-style:italic;font-size:clamp(1.6rem,3vw,2.4rem);font-weight:400;color:var(--text-primary);text-align:center;margin-bottom:8px;}
.demos-sub{text-align:center;font-family:'DM Sans',sans-serif;font-size:0.84rem;color:var(--text-muted);font-style:italic;margin-bottom:0;}
.demos-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-top:60px;}
.demo-card{
  position:relative;border:1px solid rgba(240,236,228,0.08);
  overflow:hidden;text-decoration:none;display:block;
  transition:border-color 0.35s,box-shadow 0.35s;
}
.demo-card:hover{border-color:var(--gold);box-shadow:0 0 28px rgba(196,163,90,0.07);}
.demo-thumb{position:relative;height:190px;background:#0d0d0d;overflow:hidden;}
.demo-thumb-in{position:absolute;inset:0;}
.demo-body{padding:26px 26px 32px;}
.demo-name{font-family:'Lora',serif;font-size:1.15rem;font-style:italic;color:var(--text-primary);margin-bottom:8px;}
.demo-desc{font-family:'DM Sans',sans-serif;font-size:0.8rem;color:var(--text-muted);line-height:1.65;margin-bottom:18px;}
.demo-lnk{font-family:'DM Sans',sans-serif;font-size:0.7rem;letter-spacing:0.14em;text-transform:uppercase;color:var(--gold);display:flex;align-items:center;gap:6px;}
.demo-lnk::after{content:'→';transition:transform 0.25s;}
.demo-card:hover .demo-lnk::after{transform:translateX(4px);}

/* ══════════════════════════════
   7. CTA
══════════════════════════════ */
#cta-sec{position:relative;padding:180px 0;background:var(--near-black);overflow:hidden;text-align:center;}
.cta-inner{position:relative;z-index:2;max-width:700px;margin:0 auto;padding:0 40px;}
.cta-hl{font-family:'Lora',serif;font-size:clamp(2rem,5vw,3.4rem);font-style:italic;font-weight:400;color:var(--text-primary);line-height:1.2;margin-bottom:44px;}
.cta-btn{
  display:inline-block;padding:15px 52px;border:1px solid var(--gold);color:var(--gold);
  font-family:'DM Sans',sans-serif;font-weight:400;font-size:0.8rem;
  letter-spacing:0.14em;text-transform:uppercase;text-decoration:none;
  position:relative;overflow:hidden;transition:color 0.3s;
}
.cta-btn::before{content:'';position:absolute;inset:0;background:var(--gold);transform:scaleX(0);transform-origin:left;transition:transform 0.3s var(--ease-precise);z-index:-1;}
.cta-btn:hover::before{transform:scaleX(1);}
.cta-btn:hover{color:var(--near-black);}
.cta-geo{display:block;font-family:'DM Sans',sans-serif;font-size:0.72rem;letter-spacing:0.18em;text-transform:uppercase;color:var(--text-muted);margin-top:28px;}

/* ══════════════════════════════
   8. FOOTER
══════════════════════════════ */
#footer{background:#050505;border-top:1px solid rgba(240,236,228,0.06);padding:52px 0;}
.foot-inner{max-width:1100px;margin:0 auto;padding:0 40px;display:flex;align-items:center;justify-content:space-between;gap:40px;}
.foot-logo{font-family:'Lora',serif;font-size:1rem;font-style:italic;color:var(--text-primary);}
.foot-logo span{color:var(--gold);}
.foot-tag{font-family:'DM Sans',sans-serif;font-size:0.68rem;color:var(--text-muted);letter-spacing:0.12em;text-transform:uppercase;margin-top:4px;}
.foot-links{display:flex;gap:36px;list-style:none;}
.foot-links a{font-family:'DM Sans',sans-serif;font-size:0.75rem;letter-spacing:0.1em;text-transform:uppercase;color:var(--text-muted);text-decoration:none;transition:color 0.2s;}
.foot-links a:hover{color:var(--text-primary);}

/* ══════════════════════════════
   ABOUT PAGE
══════════════════════════════ */
#about-story{position:relative;padding:120px 0;background:var(--near-black);overflow:hidden;}
.about-inner{max-width:900px;margin:0 auto;padding:0 40px;position:relative;z-index:1;}
.about-lead{
  font-family:'Lora',serif;font-size:clamp(1.4rem,2.8vw,2rem);
  font-style:italic;font-weight:400;color:var(--text-primary);
  line-height:1.45;margin-bottom:56px;
}
.about-body{font-family:'DM Sans',sans-serif;font-size:0.92rem;color:var(--text-muted);line-height:1.9;max-width:680px;}
.about-body p{margin-bottom:24px;}
.about-body strong{color:var(--text-primary);font-weight:400;}
.about-pull{
  margin:60px 0;padding-left:28px;
  border-left:1px solid var(--gold);
}
.about-pull blockquote{font-size:clamp(1.05rem,2vw,1.3rem);}

.stack-grid{
  display:grid;grid-template-columns:repeat(3,1fr);
  gap:1px;background:rgba(240,236,228,0.07);
  border:1px solid rgba(240,236,228,0.07);
  margin-top:80px;
}
.stack-item{
  background:var(--near-black);padding:36px 32px;
  position:relative;
}
.stack-item::before,.stack-item::after{
  content:'';position:absolute;width:8px;height:8px;
  border-color:rgba(196,163,90,0.2);border-style:solid;
}
.stack-item::before{top:8px;left:8px;border-width:1px 0 0 1px;}
.stack-item::after{bottom:8px;right:8px;border-width:0 1px 1px 0;}
.stack-name{font-family:'DM Sans',sans-serif;font-size:0.65rem;letter-spacing:0.18em;text-transform:uppercase;color:var(--gold);margin-bottom:10px;}
.stack-val{font-family:'Lora',serif;font-size:1.1rem;font-style:italic;color:var(--text-primary);line-height:1.35;}

/* ══════════════════════════════
   MEETING PAGE
══════════════════════════════ */
#meeting-sec{position:relative;padding:120px 0 160px;background:var(--near-black);overflow:hidden;}
.meeting-inner{max-width:660px;margin:0 auto;padding:0 40px;position:relative;z-index:1;}
.meeting-form{margin-top:48px;}
.form-group{margin-bottom:28px;}
.form-label{
  display:block;font-family:'DM Sans',sans-serif;
  font-size:0.68rem;letter-spacing:0.18em;text-transform:uppercase;
  color:var(--text-muted);margin-bottom:10px;
}
.form-input,.form-select,.form-textarea{
  width:100%;background:rgba(240,236,228,0.03);
  border:1px solid rgba(240,236,228,0.1);
  color:var(--text-primary);
  font-family:'DM Sans',sans-serif;font-size:0.9rem;font-weight:300;
  padding:14px 16px;outline:none;
  transition:border-color 0.25s;
  -webkit-appearance:none;appearance:none;
}
.form-input:focus,.form-select:focus,.form-textarea:focus{
  border-color:rgba(196,163,90,0.5);
}
.form-textarea{resize:vertical;min-height:120px;}
.form-select{
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6'%3E%3Cpath d='M0 0l5 6 5-6z' fill='rgba(196,163,90,0.5)'/%3E%3C/svg%3E");
  background-repeat:no-repeat;background-position:right 16px center;
  background-color:rgba(240,236,228,0.03);
  cursor:pointer;
}
.form-select option{background:#0a0a0a;color:var(--text-primary);}
.form-submit{
  display:inline-block;width:100%;text-align:center;
  padding:16px 40px;border:1px solid var(--gold);color:var(--gold);
  font-family:'DM Sans',sans-serif;font-weight:400;font-size:0.8rem;
  letter-spacing:0.14em;text-transform:uppercase;
  background:none;cursor:pointer;
  position:relative;overflow:hidden;transition:color 0.3s;
}
.form-submit::before{content:'';position:absolute;inset:0;background:var(--gold);transform:scaleX(0);transform-origin:left;transition:transform 0.3s var(--ease-precise);z-index:-1;}
.form-submit:hover::before{transform:scaleX(1);}
.form-submit:hover{color:var(--near-black);}
.form-note{
  margin-top:20px;font-family:'DM Sans',sans-serif;font-size:0.72rem;
  color:var(--text-muted);text-align:center;letter-spacing:0.08em;
}
.form-success{
  display:none;text-align:center;padding:40px;
  border:1px solid rgba(196,163,90,0.3);
}
.form-success.visible{display:block;}
.form-success-hl{font-family:'Lora',serif;font-size:1.4rem;font-style:italic;color:var(--text-primary);margin-bottom:12px;}
.form-success-txt{font-family:'DM Sans',sans-serif;font-size:0.85rem;color:var(--text-muted);}

/* ══════════════════════════════
   MOBILE
══════════════════════════════ */
@media(max-width:767px){
  #site-nav{padding:16px 24px;}
  #site-nav.scrolled{padding:12px 24px;}
  .nav-links{
    display:none;flex-direction:column;gap:0;
    position:fixed;top:0;left:0;right:0;bottom:0;
    background:rgba(10,10,10,0.98);
    align-items:center;justify-content:center;z-index:999;
  }
  .nav-links.open{display:flex;}
  .nav-links li{width:100%;text-align:center;}
  .nav-links a{
    display:block;padding:18px 40px;font-size:1rem;
    letter-spacing:0.08em;
  }
  .nav-toggle{display:flex;}
  .svc-grid,.stats-row,.proof-cols,.demos-grid,.stack-grid{grid-template-columns:1fr!important;}
  .svc-grid,.demos-inner,.proof-inner,.proc-inner{padding:0 20px;}
  .proc-connector{display:none;}
  .foot-inner{flex-direction:column;align-items:flex-start;gap:28px;}
  .foot-links{flex-wrap:wrap;gap:20px;}
  .bp-pin{height:200vh;}
  #hero{min-height:100svh;}
  .svc-card{padding:36px 24px;}
  .stat-block{padding:44px 28px;border-right:none;border-bottom:1px solid rgba(240,236,228,0.07);}
  #services,#process,#proof,#demos,#cta-sec{padding:96px 0;}
  .page-hero{padding:120px 24px 72px;}
  .about-inner{padding:0 20px;}
  .meeting-inner{padding:0 20px;}
  .sdr-math{padding:36px 24px;margin:40px 20px 0;}
  .sdr-math-row{flex-direction:column;gap:8px;}
}

/* ── FILM GRAIN OVERLAY ── */
.grain-overlay{
  position:fixed;inset:0;z-index:9999;pointer-events:none;
  background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.65' numOctaves='3' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
  opacity:0.018;mix-blend-mode:overlay;
}

/* ── CUSTOM CURSOR ── */
.cursor-outer{
  position:fixed;width:30px;height:30px;
  border:1px solid rgba(196,163,90,0.65);border-radius:50%;
  pointer-events:none;z-index:10000;
  transform:translate(-50%,-50%);
  transition:width 0.25s ease,height 0.25s ease,border-color 0.25s ease;
}
.cursor-dot{
  position:fixed;width:4px;height:4px;background:var(--gold);
  border-radius:50%;pointer-events:none;z-index:10001;
  transform:translate(-50%,-50%);
}
.cursor-outer.is-hover{width:54px;height:54px;border-color:rgba(196,163,90,0.9);}
@media(pointer:coarse){.cursor-outer,.cursor-dot{display:none!important;}}

/* ── MARQUEE TICKER ── */
.marquee-section{
  overflow:hidden;padding:20px 0;
  border-top:1px solid rgba(240,236,228,0.05);
  border-bottom:1px solid rgba(240,236,228,0.05);
  background:#050505;
}
.marquee-track{
  display:flex;width:max-content;
  animation:marquee-scroll 28s linear infinite;
}
.marquee-item{
  white-space:nowrap;font-family:'DM Sans',sans-serif;font-size:0.68rem;
  letter-spacing:0.22em;text-transform:uppercase;color:rgba(196,163,90,0.4);
  padding:0 36px;
}
.marquee-sep{color:rgba(240,236,228,0.15);mix-blend-mode:screen;}
@keyframes marquee-scroll{
  0%{transform:translateX(0);}
  100%{transform:translateX(-50%);}
}

/* ── GLASSMORPHISM ── */
.svc-card{
  backdrop-filter:blur(8px);
  -webkit-backdrop-filter:blur(8px);
  background:rgba(8,8,8,0.85);
}
.stat-block{
  backdrop-filter:blur(10px);
  -webkit-backdrop-filter:blur(10px);
  background:rgba(8,8,8,0.7)!important;
}
.demo-card{
  backdrop-filter:blur(6px);
  -webkit-backdrop-filter:blur(6px);
}

/* ── PAGE LOADER ── */
#page-loader{
  position:fixed;inset:0;z-index:99999;background:#050505;
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  transition:opacity 0.55s ease,visibility 0.55s ease;
  visibility:visible;
}
#page-loader.hidden{opacity:0;visibility:hidden;pointer-events:none;}
.loader-logo{
  font-family:'Lora',Georgia,serif;font-size:1.3rem;font-style:italic;
  color:var(--text-primary);letter-spacing:0.06em;margin-bottom:36px;
  opacity:0;animation:loaderFadeIn 0.5s 0.15s ease forwards;
}
.loader-logo span{color:var(--gold);}
.loader-bar-wrap{
  width:160px;height:1px;background:rgba(240,236,228,0.07);
  position:relative;overflow:hidden;
}
.loader-bar{
  position:absolute;left:0;top:0;height:100%;width:0%;
  background:var(--gold);transition:width 0.08s linear;
}
@keyframes loaderFadeIn{
  0%{opacity:0;transform:translateY(8px);}
  100%{opacity:1;transform:none;}
}

/* ── PARALLAX ── */
#hero .bp-grid-bg{will-change:transform;}

/* ── BLEND MODES on section accents ── */
.sec-label::before{mix-blend-mode:screen;}
.marquee-sep{mix-blend-mode:screen;}

/* ── A11Y — prefers-reduced-motion ── */
@media(prefers-reduced-motion:reduce){
  *,*::before,*::after{
    animation-duration:0.01ms!important;
    animation-iteration-count:1!important;
    transition-duration:0.01ms!important;
    scroll-behavior:auto!important;
  }
  .marquee-track{animation:none!important;}
  #page-loader{display:none!important;}
  .cursor-outer,.cursor-dot{display:none!important;}
}

/* ── SHADER CANVAS ── */
#shader-canvas{position:absolute;inset:0;width:100%;height:100%;z-index:0;display:block;}

/* ── TRANSITION OVERLAY ── */
#section-flash{position:fixed;inset:0;z-index:9998;pointer-events:none;background:var(--gold);opacity:0;}
.transition-overlay{position:fixed;inset:0;z-index:9997;pointer-events:none;background:var(--near-black);opacity:0;}

/* ── SECTION CLIP-PATH BASE ── */
#services,#process,#proof,#demos,#cta-sec{will-change:clip-path;}

/* ══════════════════════════════
   CONTRAST FIXES
══════════════════════════════ */

/* Section dividers — subtle gold lines */
section + section{border-top:1px solid rgba(196,163,90,0.15);}

/* Card backgrounds — visible against sections */
.svc-card{
  background:rgba(255,255,255,0.03)!important;
  border:1px solid rgba(255,255,255,0.06)!important;
}
.demo-card{
  background:rgba(255,255,255,0.03);
  border-color:rgba(255,255,255,0.08);
}
.stat-block{
  background:rgba(255,255,255,0.02)!important;
}

/* CTA buttons — solid gold, dark text, maximum contrast */
.cta-btn,.hero-cta{
  background:var(--gold)!important;
  color:var(--near-black)!important;
  font-weight:600;
  border-color:var(--gold)!important;
}
.cta-btn::before,.hero-cta::before{display:none;}
.cta-btn:hover,.hero-cta:hover{
  background:rgba(196,163,90,0.85)!important;
  color:var(--near-black)!important;
  opacity:1;
}

/* About hero image */
.about-hero-img{
  width:100%;max-height:520px;object-fit:cover;
  display:block;margin-bottom:0;
}

/* Ensure about-story relative for image */
#about-story{position:relative;}

