/* ============================================================
   Pascal Design Group — Marketing site
   Three art directions via [data-theme]: atelier | schematic | monolith
   ============================================================ */

/* ---- Brand constants (shared across all themes) ---- */
:root{
  --purple:        #561269;
  --purple-700:    #420d52;
  --purple-900:    #2a0735;
  --purple-tint:   #f3ecf5;
  --gold:          #a17503;
  --gold-600:      #8a6202;
  --gold-bright:   #c9a24b;
  --gold-soft:     #e7d9b2;

  --maxw: 1240px;
  --gutter: clamp(20px, 5vw, 64px);

  --ease: cubic-bezier(.22,.61,.36,1);
}

/* ============================================================
   THEME: ATELIER  (editorial / quiet luxury) — DEFAULT
   ============================================================ */
:root,
[data-theme="atelier"]{
  --bg:        #f7f4ef;
  --surface:   #ffffff;
  --surface-2: #f1ece4;
  --ink:       #221b23;
  --ink-soft:  #6c6168;
  --ink-faint: #a89ea4;
  --line:      #e4ddd2;
  --line-strong:#d6cbbb;

  --accent:    var(--purple);
  --accent-2:  var(--gold);
  --on-accent: #ffffff;

  --font-display: "Cormorant Garamond", Georgia, serif;
  --font-body:    "Libre Franklin", system-ui, sans-serif;
  --font-mono:    "Libre Franklin", system-ui, sans-serif;

  --display-weight: 600;
  --display-tracking: -0.01em;
  --display-lh: 1.02;
  --display-scale: 1.18;

  --eyebrow-weight: 600;
  --eyebrow-tracking: 0.26em;
  --eyebrow-size: 12px;

  --radius: 3px;
  --radius-lg: 4px;
  --btn-radius: 2px;
  --shadow: 0 1px 2px rgba(34,27,35,.04), 0 18px 40px -28px rgba(34,27,35,.28);
}

/* ============================================================
   THEME: SCHEMATIC (technical / blueprint)
   ============================================================ */
[data-theme="schematic"]{
  --bg:        #eef0f2;
  --surface:   #ffffff;
  --surface-2: #e4e7 ;
  --surface-2: #e6e9ec;
  --ink:       #1b1f24;
  --ink-soft:  #5c636c;
  --ink-faint: #98a0a9;
  --line:      #d3d8de;
  --line-strong:#bcc3cb;

  --accent:    var(--purple);
  --accent-2:  var(--gold);
  --on-accent: #ffffff;

  --font-display: "Space Grotesk", system-ui, sans-serif;
  --font-body:    "Space Grotesk", system-ui, sans-serif;
  --font-mono:    "JetBrains Mono", ui-monospace, monospace;

  --display-weight: 600;
  --display-tracking: -0.02em;
  --display-lh: 1.04;
  --display-scale: 0.92;

  --eyebrow-weight: 500;
  --eyebrow-tracking: 0.18em;
  --eyebrow-size: 11px;

  --radius: 2px;
  --radius-lg: 2px;
  --btn-radius: 2px;
  --shadow: 0 1px 0 var(--line-strong);
}

/* ============================================================
   THEME: MONOLITH (bold premium / dark-forward)
   ============================================================ */
[data-theme="monolith"]{
  --bg:        #f4f1ec;
  --surface:   #ffffff;
  --surface-2: #ece6dc;
  --ink:       #1a141c;
  --ink-soft:  #655a67;
  --ink-faint: #9b909c;
  --line:      #e0d8cc;
  --line-strong:#cfc4b4;

  --accent:    var(--purple);
  --accent-2:  var(--gold);
  --on-accent: #ffffff;

  --font-display: "Archivo", system-ui, sans-serif;
  --font-body:    "Archivo", system-ui, sans-serif;
  --font-mono:    "JetBrains Mono", ui-monospace, monospace;

  --display-weight: 800;
  --display-tracking: -0.03em;
  --display-lh: 0.96;
  --display-scale: 1.0;

  --eyebrow-weight: 600;
  --eyebrow-tracking: 0.22em;
  --eyebrow-size: 12px;

  --radius: 4px;
  --radius-lg: 8px;
  --btn-radius: 3px;
  --shadow: 0 2px 4px rgba(26,20,28,.05), 0 30px 60px -40px rgba(42,7,53,.45);
}

/* ============================================================
   BASE
   ============================================================ */
*{ box-sizing:border-box; }
html{ scroll-behavior:smooth; }
body{
  margin:0;
  background:var(--bg);
  color:var(--ink);
  font-family:var(--font-body);
  font-size:17px;
  line-height:1.65;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  transition:background .4s var(--ease), color .4s var(--ease);
}
img{ max-width:100%; display:block; }
a{ color:inherit; text-decoration:none; }

.wrap{ max-width:var(--maxw); margin:0 auto; padding-inline:var(--gutter); }
section{ position:relative; }

/* display type */
.display{
  font-family:var(--font-display);
  font-weight:var(--display-weight);
  letter-spacing:var(--display-tracking);
  line-height:var(--display-lh);
}

/* eyebrow / micro-label */
.eyebrow{
  font-family:var(--font-mono);
  font-weight:var(--eyebrow-weight);
  letter-spacing:var(--eyebrow-tracking);
  font-size:var(--eyebrow-size);
  text-transform:uppercase;
  color:var(--accent);
  display:inline-flex;
  align-items:center;
  gap:10px;
}
.eyebrow::before{
  content:"";
  width:24px;height:1px;
  background:var(--accent-2);
  display:inline-block;
}
[data-theme="schematic"] .eyebrow{ color:var(--ink-soft); }
[data-theme="schematic"] .eyebrow::before{ background:var(--gold); width:14px; }

.section-label{
  font-family:var(--font-mono);
  font-size:11px;
  letter-spacing:.22em;
  text-transform:uppercase;
  color:var(--ink-faint);
}

/* buttons */
.btn{
  display:inline-flex; align-items:center; gap:10px;
  font-family:var(--font-body);
  font-weight:600;
  font-size:14px;
  letter-spacing:.01em;
  padding:14px 24px;
  border-radius:var(--btn-radius);
  border:1px solid transparent;
  cursor:pointer;
  transition:all .25s var(--ease);
  white-space:nowrap;
}
.btn .arrow{ transition:transform .25s var(--ease); }
.btn:hover .arrow{ transform:translateX(4px); }
.btn-primary{ background:var(--accent); color:var(--on-accent); }
.btn-primary:hover{ background:var(--purple-700); }
.btn-gold{ background:var(--gold); color:#fff; }
.btn-gold:hover{ background:var(--gold-600); }
.btn-ghost{
  background:transparent; color:var(--ink);
  border-color:var(--line-strong);
}
.btn-ghost:hover{ border-color:var(--ink); }
[data-theme="schematic"] .btn{ font-family:var(--font-mono); font-size:12px; letter-spacing:.06em; text-transform:uppercase; }
[data-theme="monolith"] .btn{ font-weight:700; text-transform:uppercase; letter-spacing:.04em; font-size:13px; }

/* image placeholder / slot styling */
.slot, .ph{
  --stripe: color-mix(in srgb, var(--ink) 7%, transparent);
  background:
    repeating-linear-gradient(135deg,
      transparent 0 16px,
      var(--stripe) 16px 17px),
    var(--surface-2);
  border:1px solid var(--line);
}
.ph{
  display:flex; align-items:center; justify-content:center;
  font-family:var(--font-mono); font-size:11px; letter-spacing:.14em;
  text-transform:uppercase; color:var(--ink-faint);
  text-align:center; padding:18px;
}

/* ============================================================
   HEADER
   ============================================================ */
.site-header{
  position:sticky; top:0; z-index:50;
  background:color-mix(in srgb, var(--bg) 86%, transparent);
  backdrop-filter:blur(14px);
  border-bottom:1px solid var(--line);
  transition:background .4s var(--ease), border-color .4s var(--ease);
}
.nav{
  display:flex; align-items:center; gap:clamp(16px,2vw,30px);
  height:92px;
}
.nav .logo{ height:48px; width:auto; display:block; }
.nav > a:first-child{ flex:0 0 auto; }
.nav .logo, .nav .logo-light{ flex:none; max-width:none; }
.nav .logo-light{ display:none; }
.nav-links{
  display:flex; gap:clamp(14px,1.7vw,26px); margin-left:auto;
  font-size:14px; font-weight:500;
  list-style:none; padding:0; margin-block:0; margin-left:auto;
  flex-shrink:1; min-width:0;
}
.nav-links a{ color:var(--ink-soft); transition:color .2s; position:relative; }
.nav-links a:hover{ color:var(--ink); }
.nav-cta{ display:flex; align-items:center; gap:16px; flex:none; }
.nav-phone{ font-family:var(--font-mono); font-size:12.5px; color:var(--ink-soft); letter-spacing:.02em; white-space:nowrap; }
.nav-links a{ white-space:nowrap; }
[data-theme="schematic"] .nav-links{ font-family:var(--font-mono); font-size:12.5px; text-transform:uppercase; letter-spacing:.04em; }

@media (max-width:1000px){
  .nav-phone{ display:none; }
}
@media (max-width:880px){
  .nav-links{ display:none; }
  .nav-phone{ display:none; }
}

/* ============================================================
   HERO
   ============================================================ */
.hero{ padding:clamp(56px,8vw,104px) 0 clamp(40px,6vw,72px); overflow:hidden; }
.hero-grid{
  display:grid;
  grid-template-columns:1fr 1.02fr;
  gap:clamp(32px,5vw,72px);
  align-items:stretch;
}
.hero-eyebrow{ display:flex; width:fit-content; line-height:1; margin-bottom:26px; }
.hero h1{
  margin:0 0 26px;
  font-size:clamp(40px, calc(5.4vw * var(--display-scale)), 78px);
}
.hero h1 .accent{ color:var(--accent); }
.hero h1 em{ font-style:italic; color:var(--accent-2); }
.hero-sub{
  font-size:clamp(17px,1.4vw,20px);
  color:var(--ink-soft);
  max-width:46ch;
  margin:0 0 36px;
}
.hero-actions{ display:flex; gap:14px; flex-wrap:wrap; align-items:center; }

/* WOSB credential */
.wosb-pill{
  display:inline-flex; align-items:center; gap:8px;
  font-family:var(--font-mono); font-size:11px; letter-spacing:.1em; text-transform:uppercase;
  font-weight:500; color:#1c0524;
  background:linear-gradient(180deg, var(--gold-bright) 0%, var(--gold) 100%);
  padding:7px 13px; border-radius:2px;
}
.wosb-pill::before{ content:""; width:5px; height:5px; border-radius:50%; background:#1c0524; }
.hero-cred{ display:flex; align-items:center; gap:14px; margin-top:24px; flex-wrap:wrap; }
.hero-cred-note{ font-family:var(--font-mono); font-size:12px; letter-spacing:.04em; color:var(--ink-soft); }
[data-theme="monolith"] .hero-cred-note{ color:#cdbcd2; }
.trust-mark.wosb{ color:var(--gold-600); }
[data-theme="monolith"] .trust-mark.wosb b{ color:var(--gold-600); }
.foot-wosb{ margin:2px 0 18px; }
.hero-media{ position:relative; display:flex; }
.hero-media .slot{ width:100%; height:100%; aspect-ratio:auto; min-height:0; align-self:stretch; border-radius:var(--radius-lg); }
.hero-media .caption{
  position:absolute; left:16px; bottom:16px;
  font-family:var(--font-mono); font-size:10.5px; letter-spacing:.16em;
  text-transform:uppercase; color:#fff;
  background:color-mix(in srgb, var(--purple-900) 78%, transparent);
  padding:7px 12px; border-radius:2px; backdrop-filter:blur(4px);
}
.hero-tag{
  position:absolute; top:18px; right:18px;
  background:var(--gold); color:#fff;
  font-family:var(--font-mono); font-size:10.5px; letter-spacing:.12em;
  text-transform:uppercase; padding:8px 12px; border-radius:2px; white-space:nowrap;
}

@media (max-width:860px){
  .hero-grid{ grid-template-columns:1fr; align-items:stretch; }
  .hero-media{ order:-1; }
  .hero-media .slot{ aspect-ratio:16/10; height:auto; min-height:0; }
}

/* atelier hero rule */
[data-theme="atelier"] .hero h1{ font-weight:500; }
[data-theme="atelier"] .hero h1 .accent{ font-style:italic; }

/* schematic hero — measured grid frame */
[data-theme="schematic"] .hero-text{
  border-left:1px solid var(--line-strong);
  padding-left:clamp(20px,3vw,40px);
  position:relative;
}
[data-theme="schematic"] .hero-text::before{
  content:"N 35°";
  position:absolute; top:0; left:clamp(20px,3vw,40px);
  font-family:var(--font-mono); font-size:10px; color:var(--ink-faint);
  letter-spacing:.1em;
}
[data-theme="schematic"] .hero{ padding-top:clamp(40px,6vw,72px); }

/* monolith hero — dark bleed */
[data-theme="monolith"] .hero{
  background:
    radial-gradient(120% 90% at 80% 10%, var(--purple-700) 0%, var(--purple-900) 55%, #1c0524 100%);
  color:#f4eef6;
  padding-bottom:clamp(56px,8vw,96px);
}
[data-theme="monolith"] .hero .hero-sub{ color:#cdbcd2; }
[data-theme="monolith"] .hero h1 .accent{ color:var(--gold-bright); }
[data-theme="monolith"] .hero h1 em{ color:var(--gold-bright); font-style:normal; }
[data-theme="monolith"] .hero .eyebrow{ color:var(--gold-bright); }
[data-theme="monolith"] .hero .eyebrow::before{ background:var(--gold-bright); }
[data-theme="monolith"] .hero .btn-ghost{ color:#f4eef6; border-color:rgba(255,255,255,.32); }
[data-theme="monolith"] .hero .btn-ghost:hover{ border-color:#fff; }
[data-theme="monolith"] .hero-media .slot{ border-color:rgba(255,255,255,.16); }

/* ============================================================
   TRUST STRIP
   ============================================================ */
.trust{ border-block:1px solid var(--line); background:var(--surface); }
.trust-inner{ display:flex; align-items:center; gap:clamp(24px,5vw,64px); padding:30px var(--gutter); flex-wrap:wrap; }
.trust-lead{ font-size:13px; color:var(--ink-soft); max-width:18ch; line-height:1.4; }
.trust-marks{ display:flex; gap:clamp(20px,4vw,52px); flex-wrap:wrap; align-items:center; flex:1; }
.trust-mark{
  font-family:var(--font-mono); font-size:12px; letter-spacing:.08em;
  color:var(--ink-soft); text-transform:uppercase;
  display:flex; align-items:center; gap:9px;
}
.trust-mark b{ color:var(--ink); font-weight:600; }
.trust-mark .dot{ width:6px;height:6px;border-radius:50%; background:var(--gold); }

/* ============================================================
   SECTION SCAFFOLD
   ============================================================ */
.section{ padding:clamp(64px,9vw,128px) 0; }
.section-head{
  display:grid; grid-template-columns:auto 1fr; gap:clamp(24px,5vw,72px);
  align-items:end; margin-bottom:clamp(40px,5vw,68px);
}
.section-head .head-left{ max-width:34ch; }
.section-head h2{
  font-size:clamp(30px, calc(3.4vw * var(--display-scale)), 50px);
  margin:14px 0 0;
}
.section-head .head-right{ color:var(--ink-soft); font-size:16px; max-width:42ch; padding-bottom:6px; }
@media (max-width:760px){
  .section-head{ grid-template-columns:1fr; }
}

/* ============================================================
   CAPABILITIES
   ============================================================ */
.caps{ display:grid; grid-template-columns:repeat(6,1fr); gap:1px; background:var(--line); border:1px solid var(--line); border-radius:var(--radius-lg); overflow:hidden; }
.cap{
  background:var(--surface); padding:34px 30px 30px;
  display:flex; flex-direction:column; min-height:300px;
  transition:background .3s var(--ease);
  position:relative;
}
.cap:hover{ background:var(--surface-2); }
.cap.span3{ grid-column:span 3; }
.cap.span2{ grid-column:span 2; }
.cap .cap-no{ font-family:var(--font-mono); font-size:11px; color:var(--ink-faint); letter-spacing:.14em; }
.cap .cap-icon{
  width:42px;height:42px;margin:6px 0 22px;
  display:flex;align-items:center;justify-content:center;
  color:var(--accent);
}
.cap h3{ font-family:var(--font-display); font-weight:var(--display-weight); letter-spacing:var(--display-tracking);
  font-size:clamp(21px,1.7vw,26px); margin:0 0 12px; line-height:1.1; }
.cap p{ color:var(--ink-soft); font-size:14.5px; margin:0 0 18px; }
.cap ul{ list-style:none; padding:0; margin:auto 0 0; display:flex; flex-direction:column; gap:7px; }
.cap li{ font-size:13px; color:var(--ink); display:flex; gap:10px; align-items:baseline; }
.cap li::before{ content:""; width:5px;height:5px;flex:none; margin-top:7px; background:var(--gold); border-radius:1px; }
.cap .tag{ position:absolute; top:30px; right:28px; font-family:var(--font-mono); font-size:10px; letter-spacing:.12em; text-transform:uppercase; color:var(--accent); }
@media (max-width:980px){ .caps{ grid-template-columns:repeat(2,1fr); } .cap.span3,.cap.span2{ grid-column:span 1; } }
@media (max-width:560px){ .caps{ grid-template-columns:1fr; } }

[data-theme="monolith"] .cap .cap-no{ color:var(--gold-600); }
[data-theme="schematic"] .cap{ min-height:280px; }
[data-theme="schematic"] .cap h3{ font-size:clamp(19px,1.5vw,23px); }

/* ============================================================
   SECTORS
   ============================================================ */
.sectors{ background:var(--surface); border-block:1px solid var(--line); }
.sector-row{ display:grid; grid-template-columns:repeat(5,1fr); }
.sector{
  padding:40px 26px; border-right:1px solid var(--line);
  transition:background .3s var(--ease);
}
.sector:last-child{ border-right:none; }
.sector:hover{ background:var(--surface-2); }
.sector .s-no{ font-family:var(--font-mono); font-size:11px; color:var(--gold); letter-spacing:.1em; }
.sector h4{ font-family:var(--font-display); font-weight:var(--display-weight); font-size:clamp(18px,1.5vw,22px); letter-spacing:var(--display-tracking); margin:18px 0 10px; line-height:1.12; }
.sector p{ font-size:13px; color:var(--ink-soft); margin:0; }
@media (max-width:900px){ .sector-row{ grid-template-columns:repeat(2,1fr); } .sector:nth-child(2n){ border-right:none; } .sector{ border-bottom:1px solid var(--line); } }
@media (max-width:520px){ .sector-row{ grid-template-columns:1fr; } .sector{ border-right:none; } }

/* ============================================================
   PROCESS
   ============================================================ */
.process{ position:relative; }
.proc-steps{ display:grid; grid-template-columns:repeat(5,1fr); gap:0; counter-reset:step; }
.proc-step{ padding-right:28px; position:relative; }
.proc-step::before{
  content:""; position:absolute; top:9px; left:0; right:14px; height:1px; background:var(--line-strong);
}
.proc-step .pip{ width:12px;height:12px;border-radius:50%; background:var(--accent); position:relative; z-index:2; margin-bottom:24px; }
.proc-step .pip.gold{ background:var(--gold); }
.proc-step .p-no{ font-family:var(--font-mono); font-size:11px; color:var(--ink-faint); letter-spacing:.14em; }
.proc-step h4{ font-family:var(--font-display); font-weight:var(--display-weight); font-size:clamp(18px,1.4vw,22px); letter-spacing:var(--display-tracking); margin:8px 0 10px; }
.proc-step p{ font-size:13.5px; color:var(--ink-soft); margin:0; padding-right:8px; }
@media (max-width:900px){ .proc-steps{ grid-template-columns:1fr 1fr; gap:36px 0; } .proc-step::before{ display:none; } }
@media (max-width:520px){ .proc-steps{ grid-template-columns:1fr; } }

/* ============================================================
   WORK / CASE STUDIES
   ============================================================ */
.work{ background:var(--surface); border-block:1px solid var(--line); }
.work-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:clamp(20px,2.5vw,34px); }
.work-card{ display:flex; flex-direction:column; }
.work-card .slot{ width:100%; aspect-ratio:4/3; border-radius:var(--radius-lg); margin-bottom:20px; }
.work-card .w-meta{ display:flex; gap:12px; font-family:var(--font-mono); font-size:11px; letter-spacing:.08em; text-transform:uppercase; color:var(--ink-faint); margin-bottom:12px; }
.work-card .w-meta .pill{ color:var(--accent); }
.work-card h3{ font-family:var(--font-display); font-weight:var(--display-weight); font-size:clamp(20px,1.6vw,25px); letter-spacing:var(--display-tracking); margin:0 0 10px; line-height:1.12; }
.work-card p{ font-size:14px; color:var(--ink-soft); margin:0; }
@media (max-width:860px){ .work-grid{ grid-template-columns:1fr; max-width:480px; } }

/* ============================================================
   WHY / DIFFERENTIATORS
   ============================================================ */
.why-grid{ display:grid; grid-template-columns:1fr 1fr; gap:clamp(40px,6vw,96px); align-items:start; }
.why-list{ display:flex; flex-direction:column; }
.why-item{ display:grid; grid-template-columns:auto 1fr; gap:24px; padding:26px 0; border-top:1px solid var(--line); align-items:start; }
.why-item:last-child{ border-bottom:1px solid var(--line); }
.why-item .why-no{ font-family:var(--font-mono); font-size:12px; color:var(--gold); letter-spacing:.1em; padding-top:4px; }
.why-item h4{ font-family:var(--font-display); font-weight:var(--display-weight); font-size:clamp(19px,1.5vw,23px); letter-spacing:var(--display-tracking); margin:0 0 8px; }
.why-item p{ font-size:14.5px; color:var(--ink-soft); margin:0; }
.why-aside{ position:sticky; top:108px; }
.why-aside .stat-card{ background:var(--surface); border:1px solid var(--line); border-radius:var(--radius-lg); padding:34px; box-shadow:var(--shadow); }
.why-aside h3{ font-family:var(--font-display); font-weight:var(--display-weight); font-size:clamp(24px,2.2vw,32px); letter-spacing:var(--display-tracking); line-height:1.1; margin:0 0 26px; }
.stat-row{ display:grid; grid-template-columns:1fr 1fr; gap:26px 20px; }
.stat .num{ font-family:var(--font-display); font-weight:var(--display-weight); font-size:clamp(30px,3vw,42px); color:var(--accent); line-height:1; letter-spacing:var(--display-tracking); }
.stat .lbl{ font-size:12.5px; color:var(--ink-soft); margin-top:8px; }
[data-theme="monolith"] .stat .num{ color:var(--purple); }
@media (max-width:860px){ .why-grid{ grid-template-columns:1fr; } .why-aside{ position:static; } }

/* ============================================================
   CTA BAND
   ============================================================ */
.cta-band{
  background:radial-gradient(120% 140% at 15% 0%, var(--purple-700) 0%, var(--purple-900) 70%, #1c0524 100%);
  color:#f4eef6;
}
.cta-inner{ padding:clamp(64px,8vw,108px) var(--gutter); display:grid; grid-template-columns:1.2fr .8fr; gap:48px; align-items:center; }
.cta-inner .eyebrow{ color:var(--gold-bright); }
.cta-inner .eyebrow::before{ background:var(--gold-bright); }
.cta-inner h2{ font-family:var(--font-display); font-weight:var(--display-weight); letter-spacing:var(--display-tracking); font-size:clamp(32px,3.6vw,54px); line-height:1.04; margin:18px 0 0; }
.cta-inner .cta-sub{ color:#cdbcd2; font-size:17px; margin:20px 0 0; max-width:40ch; }
.cta-actions{ display:flex; flex-direction:column; gap:14px; align-items:stretch; }
.cta-actions .btn{ justify-content:space-between; padding:18px 24px; font-size:15px; }
.cta-actions .btn-ghost{ color:#f4eef6; border-color:rgba(255,255,255,.3); }
.cta-actions .btn-ghost:hover{ border-color:#fff; }
.cta-contact{ font-family:var(--font-mono); font-size:12.5px; color:#b9a7bf; letter-spacing:.04em; margin-top:6px; text-align:center; }
@media (max-width:760px){ .cta-inner{ grid-template-columns:1fr; } }

/* ============================================================
   FOOTER
   ============================================================ */
.site-footer{ background:#16101a; color:#c9bfcd; }
.foot-top{ display:grid; grid-template-columns:1.4fr 1fr 1fr 1fr; gap:40px; padding:clamp(56px,6vw,80px) var(--gutter) 48px; }
.foot-brand .logo-light{ height:38px; margin-bottom:22px; }
.foot-brand p{ font-size:14px; color:#998ea0; max-width:34ch; margin:0 0 18px; }
.foot-addr{ font-style:normal; font-family:var(--font-mono); font-size:12px; line-height:1.7; letter-spacing:.02em; color:#7c7184; }
.foot-col h5{ font-family:var(--font-mono); font-size:11px; letter-spacing:.16em; text-transform:uppercase; color:#7c7184; margin:0 0 18px; font-weight:500; }
.foot-col ul{ list-style:none; padding:0; margin:0; display:flex; flex-direction:column; gap:11px; }
.foot-col a{ font-size:14px; color:#c9bfcd; transition:color .2s; }
.foot-col a:hover{ color:#fff; }
.foot-bottom{ border-top:1px solid rgba(255,255,255,.09); padding:24px var(--gutter); display:flex; justify-content:space-between; gap:16px; flex-wrap:wrap; font-family:var(--font-mono); font-size:11.5px; letter-spacing:.04em; color:#7c7184; }
@media (max-width:760px){ .foot-top{ grid-template-columns:1fr 1fr; } .foot-brand{ grid-column:1/-1; } }

/* ============================================================
   REVEAL ANIMATION
   ============================================================ */
/* ============================================================
   REVEAL — handled inline-safe; entrance is transform-only & opt-in
   (kept minimal to avoid renderer getComputedStyle quirks)
   ============================================================ */

/* ============================================================
   ICONS (simple stroke glyphs, geometric only)
   ============================================================ */
.ico{ width:100%; height:100%; stroke:currentColor; stroke-width:1.4; fill:none; stroke-linecap:round; stroke-linejoin:round; }

/* ============================================================
   DYNAMICS — hero animation layer, reveals, interactions
   ============================================================ */

/* ---- Hero canvas layering ---- */
.hero{ position:relative; isolation:isolate; }
.hero-bg{
  position:absolute; inset:0; z-index:0; pointer-events:none;
  display:block;
}
.hero > .wrap{ position:relative; z-index:1; }

/* ---- JS-driven reveals (only armed when JS can animate) ---- */
.js-reveal-ready .reveal{
  opacity:0; transform:translateY(22px);
  transition:opacity .8s var(--ease), transform .8s var(--ease);
}
.js-reveal-ready .reveal.in{ opacity:1; transform:none; }

.js-reveal-ready .stag{
  opacity:0; transform:translateY(20px);
  transition:opacity .7s var(--ease), transform .7s var(--ease);
}
.js-reveal-ready .stag.in{ opacity:1; transform:none; }

/* hero text gets a slightly longer, more cinematic settle */
.js-reveal-ready .hero-text.reveal{ transform:translateY(26px); transition-duration:1s; }
.js-reveal-ready .hero-media.reveal{ transition-delay:.12s; }

@media (prefers-reduced-motion: reduce){
  .js-reveal-ready .reveal,
  .js-reveal-ready .stag{ opacity:1 !important; transform:none !important; }
}
body.no-reveal .reveal,
body.no-reveal .stag{ opacity:1 !important; transform:none !important; transition:none !important; }

/* ---- Cursor-reactive capability cards ---- */
.cap > *{ position:relative; z-index:1; }
.cap::after{
  content:""; position:absolute; inset:0; z-index:0; pointer-events:none;
  background:radial-gradient(260px circle at var(--mx,50%) var(--my,0%),
            color-mix(in srgb, var(--accent) 10%, transparent), transparent 62%);
  opacity:0; transition:opacity .45s var(--ease);
}
.cap:hover::after{ opacity:1; }
/* energy bar that runs along the bottom edge on hover */
.cap::before{
  content:""; position:absolute; left:0; right:0; bottom:0; height:2px; z-index:2;
  background:linear-gradient(90deg, var(--accent), var(--gold));
  transform:scaleX(0); transform-origin:left;
  transition:transform .55s var(--ease);
}
.cap:hover::before{ transform:scaleX(1); }
.cap .cap-icon{ transition:transform .5s var(--ease), color .3s var(--ease); }
.cap:hover .cap-icon{ transform:translateY(-3px); }
[data-theme="monolith"] .cap::after{
  background:radial-gradient(260px circle at var(--mx,50%) var(--my,0%),
            color-mix(in srgb, var(--gold) 14%, transparent), transparent 62%);
}

/* ---- Sector hover lift ---- */
.sector{ transition:background .35s var(--ease); }
.sector .s-no{ transition:color .3s var(--ease); }
.sector:hover .s-no{ color:var(--accent); }

/* ---- Process line draw-in + pip pop ---- */
.js-reveal-ready .proc-step::before{
  transform:scaleX(0); transform-origin:left;
  transition:transform .7s var(--ease);
}
.js-reveal-ready .proc-steps.in .proc-step::before{ transform:scaleX(1); }
.js-reveal-ready .proc-step:nth-child(2)::before{ transition-delay:.12s; }
.js-reveal-ready .proc-step:nth-child(3)::before{ transition-delay:.24s; }
.js-reveal-ready .proc-step:nth-child(4)::before{ transition-delay:.36s; }
.js-reveal-ready .proc-step:nth-child(5)::before{ transition-delay:.48s; }

.js-reveal-ready .proc-step .pip{
  transform:scale(0); transition:transform .5s var(--ease);
}
.js-reveal-ready .proc-steps.in .proc-step .pip{ transform:scale(1); }
.js-reveal-ready .proc-step:nth-child(2) .pip{ transition-delay:.14s; }
.js-reveal-ready .proc-step:nth-child(3) .pip{ transition-delay:.26s; }
.js-reveal-ready .proc-step:nth-child(4) .pip{ transition-delay:.38s; }
.js-reveal-ready .proc-step:nth-child(5) .pip{ transition-delay:.5s; }

/* gold pips gently pulse to read as "energised" nodes */
@media (prefers-reduced-motion: no-preference){
  .proc-step .pip.gold{ position:relative; }
  .proc-step .pip.gold::after{
    content:""; position:absolute; inset:0; border-radius:50%;
    box-shadow:0 0 0 0 color-mix(in srgb, var(--gold) 70%, transparent);
    animation:pipPulse 2.6s var(--ease) infinite;
  }
  @keyframes pipPulse{
    0%{ box-shadow:0 0 0 0 color-mix(in srgb, var(--gold) 55%, transparent); }
    70%{ box-shadow:0 0 0 9px color-mix(in srgb, var(--gold) 0%, transparent); }
    100%{ box-shadow:0 0 0 0 color-mix(in srgb, var(--gold) 0%, transparent); }
  }
}

/* ---- Stat numbers ---- */
.stat .num{ font-variant-numeric:tabular-nums; }

/* ---- Buttons get a touch more life ---- */
.btn-primary, .btn-gold{ position:relative; overflow:hidden; }
.btn-primary::after, .btn-gold::after{
  content:""; position:absolute; top:0; left:-130%; width:60%; height:100%;
  background:linear-gradient(100deg, transparent, rgba(255,255,255,.28), transparent);
  transform:skewX(-18deg); transition:none;
}
@media (prefers-reduced-motion: no-preference){
  .btn-primary:hover::after, .btn-gold:hover::after{
    animation:btnSheen .8s var(--ease) forwards;
  }
  @keyframes btnSheen{ to{ left:130%; } }
}

/* ---- Work cards: image zoom on hover ---- */
.work-card .slot{ overflow:hidden; }
.work-card{ }
.work-card h3{ transition:color .3s var(--ease); }
.work-card:hover h3{ color:var(--accent); }

/* ============================================================
   ABOUT
   ============================================================ */
.about-grid{
  display:grid; grid-template-columns:1.15fr .85fr;
  gap:clamp(40px,6vw,80px); align-items:stretch;
  margin-top:clamp(18px,2.5vw,28px);
}
.about-narrative{ display:flex; flex-direction:column; }
.about-lead{
  font-family:var(--font-display); font-weight:500;
  font-size:clamp(23px,2.2vw,32px); line-height:1.28; letter-spacing:-.005em;
  color:var(--ink); margin:0;
}
.about-lead strong{ color:var(--accent); font-weight:600; }
.about-lead em{ font-style:italic; color:var(--accent-2); }
.about-body{ font-size:16.5px; color:var(--ink-soft); margin:22px 0 0; max-width:50ch; }
.founders-sig{ display:flex; align-items:center; gap:20px; margin-top:auto; padding-top:36px; }
.sig-rule{
  width:54px; height:2px; background:var(--gold); flex:none; transform-origin:left;
}
.js-reveal-ready .about-narrative .sig-rule{ transform:scaleX(0); transition:transform .8s var(--ease) .25s; }
.js-reveal-ready .about-narrative.in .sig-rule{ transform:scaleX(1); }
.sig-name{ font-family:var(--font-display); font-style:italic; font-weight:600; font-size:23px; color:var(--ink); line-height:1.1; }
.sig-role{ font-family:var(--font-mono); font-size:11px; letter-spacing:.14em; text-transform:uppercase; color:var(--ink-faint); margin-top:6px; }

.about-media{ position:relative; display:flex; }
.about-media .slot{
  width:100%; height:100%; aspect-ratio:auto;
  min-height:clamp(360px,48vh,540px); border-radius:var(--radius-lg);
}
.about-loc{
  position:absolute; left:16px; bottom:16px;
  font-family:var(--font-mono); font-size:10.5px; letter-spacing:.16em;
  text-transform:uppercase; color:#fff;
  background:color-mix(in srgb, var(--purple-900) 78%, transparent);
  padding:7px 12px; border-radius:2px; backdrop-filter:blur(4px);
}
.about-vlabel{
  position:absolute; top:18px; right:-2px;
  writing-mode:vertical-rl; text-orientation:mixed;
  font-family:var(--font-mono); font-size:10px; letter-spacing:.28em;
  text-transform:uppercase; color:var(--gold);
  background:var(--surface); padding:12px 6px; border-radius:2px;
  box-shadow:var(--shadow);
}

.about-stats{
  display:grid; grid-template-columns:repeat(3,1fr); gap:1px;
  background:var(--line); border:1px solid var(--line);
  border-radius:var(--radius-lg); overflow:hidden;
  margin-top:clamp(40px,5vw,66px);
}
.astat{ background:var(--surface); padding:36px 32px; position:relative; transition:background .35s var(--ease); }
.astat:hover{ background:var(--surface-2); }
.astat::before{
  content:""; position:absolute; left:0; right:0; bottom:0; height:2px;
  background:linear-gradient(90deg, var(--accent), var(--gold));
  transform:scaleX(0); transform-origin:left; transition:transform .55s var(--ease);
}
.astat:hover::before{ transform:scaleX(1); }
.astat-num{
  font-family:var(--font-display); font-weight:var(--display-weight);
  letter-spacing:var(--display-tracking); font-size:clamp(28px,3.2vw,44px);
  color:var(--accent); line-height:1; font-variant-numeric:tabular-nums;
}
[data-theme="monolith"] .astat-num{ color:var(--purple); }
.astat-lbl{ font-size:13.5px; color:var(--ink-soft); margin-top:16px; max-width:28ch; }

@media (max-width:860px){
  .about-grid{ grid-template-columns:1fr; }
  .about-media{ order:-1; }
  .about-media .slot{ aspect-ratio:16/10; height:auto; min-height:0; }
  .about-stats{ grid-template-columns:1fr; }
}


/* ============================================================
   PRODUCTION: baked photo slots (replaces <image-slot> tooling)
   ============================================================ */
.slot{ overflow:hidden; position:relative; }
.slot-img{ width:100%; height:100%; object-fit:cover; object-position:50% 50%; display:block; }
#hero-photo{ object-position:23% 50%; }
.work-card .slot-img{ transition:transform .65s var(--ease); will-change:transform; }
@media (hover:hover){ .work-card:hover .slot-img{ transform:scale(1.06); } }


/* ============================================================
   MOBILE NAV + RESPONSIVE POLISH  (added for go-live)
   ============================================================ */
.nav-toggle{ display:none; }
.mobile-menu{ display:none; }

/* hamburger button */
.nav-toggle{
  width:44px; height:44px; padding:0; flex:none;
  background:transparent; border:1px solid var(--line-strong);
  border-radius:var(--btn-radius); cursor:pointer;
  align-items:center; justify-content:center; flex-direction:column; gap:5px;
}
.nav-toggle span{
  display:block; width:18px; height:2px; background:var(--ink);
  transition:transform .3s var(--ease), opacity .2s var(--ease);
}
.site-header.menu-open .nav-toggle span:nth-child(1){ transform:translateY(3.5px) rotate(45deg); }
.site-header.menu-open .nav-toggle span:nth-child(2){ transform:translateY(-3.5px) rotate(-45deg); }

@media (max-width:880px){
  .nav{ height:68px; }
  .nav .logo{ height:38px; }
  .nav-cta{ margin-left:auto; gap:12px; }
  .nav-toggle{ display:flex; }

  .mobile-menu{
    display:flex; flex-direction:column;
    max-height:0; overflow:hidden;
    padding:0 var(--gutter);
    background:color-mix(in srgb, var(--bg) 97%, transparent);
    transition:max-height .42s var(--ease), padding .42s var(--ease);
  }
  .site-header.menu-open .mobile-menu{
    max-height:600px; padding:6px var(--gutter) 24px;
    border-top:1px solid var(--line);
  }
  .mobile-menu a{
    font-size:17px; font-weight:500; color:var(--ink);
    padding:15px 2px; border-bottom:1px solid var(--line);
  }
  .mobile-menu .mobile-menu-cta{
    margin-top:18px; justify-content:center; border-bottom:none;
    color:var(--on-accent); padding:16px 24px; font-size:15px;
  }
  .mobile-menu .mobile-menu-phone{
    font-family:var(--font-mono); font-size:14px; color:var(--ink-soft);
    border-bottom:none; padding:18px 0 2px; text-align:center; letter-spacing:.04em;
  }

  /* lead with the value prop, not a full-height photo */
  .hero-media{ order:0; }
  .hero-media .slot, .hero-media image-slot{ height:380px !important; }
}

@media (max-width:560px){
  .nav-cta-btn{ display:none; }              /* CTA lives in the menu now */
  .hero-actions{ flex-direction:column; align-items:stretch; }
  .hero-actions .btn{ width:100%; justify-content:center; }
  .hero-media .slot, .hero-media image-slot{ height:300px !important; }
  .section{ padding:clamp(48px,13vw,72px) 0; }
}


/* ============================================================
   MOBILE HERO OVERFLOW FIX  (real-device correction)
   ============================================================ */
@media (max-width:860px){
  /* stop the long headline from blowing out the grid track */
  .hero-grid{ min-width:0; }
  .hero-grid > *{ min-width:0; }
  .hero-text{ min-width:0; }
  .hero h1{ overflow-wrap:break-word; }
  .hero-sub{ max-width:none; }
}
@media (max-width:560px){
  .hero h1{ font-size:clamp(31px,8.4vw,42px); line-height:1.06; }
  .hero-sub{ font-size:16px; }
  .hero .eyebrow{ font-size:11px; letter-spacing:.18em; }
  .hero-tag{ font-size:9.5px; top:12px; right:12px; padding:6px 9px; }
  .hero-media .caption{ font-size:9.5px; left:12px; bottom:12px; }
  .hero-cred{ flex-wrap:wrap; gap:10px; }
}
