/* ============================================================
   Common Works — design system
   Cream paper · warm ink · forest accent · serif/sans/mono
   ============================================================ */

:root{
  /* paper + ink */
  --cream:      #F4F1EA;
  --cream-2:    #EEE9DD;   /* recessed panel */
  --cream-3:    #E6E0D1;   /* deeper panel / lines on cream */
  --paper-edge: #DED7C6;

  --ink:        #16140F;   /* near-black, warm */
  --ink-2:      #4A4639;   /* muted body */
  --ink-3:      #837C68;   /* captions / mono labels */

  /* accent */
  --forest:     #1B3A2F;
  --forest-2:   #234C3D;   /* hover */
  --forest-ink: #0F241C;   /* deepest */
  --forest-tint:#E4E8E1;   /* faint green wash on cream */

  --line:       rgba(22,20,15,0.14);
  --line-soft:  rgba(22,20,15,0.08);
  --line-strong:rgba(22,20,15,0.26);

  --cream-on-forest: #EDEAE0;
  --mute-on-forest:  rgba(237,234,224,0.62);
  --line-on-forest:  rgba(237,234,224,0.18);

  /* type */
  --serif: "Source Serif 4", Georgia, "Times New Roman", serif;
  --sans:  "IBM Plex Sans", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  --mono:  "IBM Plex Sans", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;

  --maxw: 1200px;
  --gut: 40px;

  --ease: cubic-bezier(.2,.7,.2,1);
}

/* ---------- reset ---------- */
*{ box-sizing:border-box; }
html{ -webkit-text-size-adjust:100%; scroll-behavior:smooth; }
body{
  margin:0;
  background:var(--cream);
  color:var(--ink);
  font-family:var(--sans);
  font-size:17px;
  line-height:1.62;
  font-weight:400;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  font-feature-settings:"kern" 1, "liga" 1;
}
/* faint paper grain */
body::before{
  content:"";
  position:fixed; inset:0; z-index:0; pointer-events:none;
  opacity:.5;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='2' stitchTiles='stitch'/%3E%3CfeColorMatrix type='saturate' values='0'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.035'/%3E%3C/svg%3E");
  mix-blend-mode:multiply;
}
#root{ position:relative; z-index:1; }

h1,h2,h3,h4,p{ margin:0; }
a{ color:inherit; text-decoration:none; }
img{ display:block; max-width:100%; }
button{ font-family:inherit; cursor:pointer; }
::selection{ background:var(--forest); color:var(--cream-on-forest); }

/* ---------- layout ---------- */
.wrap{ max-width:var(--maxw); margin:0 auto; padding:0 var(--gut); }
.wrap-wide{ max-width:1360px; margin:0 auto; padding:0 var(--gut); }
section{ position:relative; }

/* ---------- type primitives ---------- */
.display{
  font-family:var(--serif);
  font-weight:400;
  letter-spacing:-0.018em;
  line-height:1.04;
  text-wrap:balance;
}
.serif{ font-family:var(--serif); }
.eyebrow{
  font-family:var(--serif);
  font-style:italic;
  font-size:18px;
  letter-spacing:0;
  text-transform:none;
  color:var(--forest);
  font-weight:400;
  display:inline-flex; align-items:center; gap:13px;
}
.eyebrow::before{
  content:""; width:26px; height:1px; background:var(--forest); display:inline-block; flex:none;
}
.eyebrow.no-rule::before{ display:none; }
.lead{
  font-size:21px; line-height:1.58; color:var(--ink-2); font-weight:400;
  text-wrap:pretty;
}
.muted{ color:var(--ink-2); }
.kicker{
  font-family:var(--mono); font-size:11.5px; letter-spacing:.02em;
  text-transform:none; color:var(--ink-3);
}

/* ---------- buttons ---------- */
.btn{
  display:inline-flex; align-items:center; gap:10px;
  font-family:var(--sans); font-size:15px; font-weight:500;
  padding:13px 22px; border-radius:2px;
  border:1px solid transparent; cursor:pointer;
  transition:transform .25s var(--ease), background .25s var(--ease), color .25s var(--ease), border-color .25s var(--ease);
  letter-spacing:.005em; white-space:nowrap;
}
.btn .arr{ transition:transform .3s var(--ease); }
.btn:hover .arr{ transform:translateX(4px); }
.btn-primary{ background:var(--forest); color:var(--cream-on-forest); }
.btn-primary:hover{ background:var(--forest-2); }
.btn-ghost{ background:transparent; color:var(--ink); border-color:var(--line-strong); }
.btn-ghost:hover{ border-color:var(--ink); background:rgba(22,20,15,.03); }
.btn-on-forest{ background:var(--cream-on-forest); color:var(--forest-ink); }
.btn-on-forest:hover{ background:#fff; }
.btn-ghost-forest{ background:transparent; color:var(--cream-on-forest); border-color:var(--line-on-forest); }
.btn-ghost-forest:hover{ border-color:var(--cream-on-forest); }

/* text link with animated underline */
.tlink{
  position:relative; display:inline-flex; align-items:center; gap:8px;
  font-weight:500; color:var(--ink);
  font-size:15px;
}
.tlink::after{
  content:""; position:absolute; left:0; bottom:-3px; height:1px; width:100%;
  background:currentColor; transform:scaleX(0); transform-origin:left;
  transition:transform .35s var(--ease);
}
.tlink:hover::after{ transform:scaleX(1); }
.tlink .arr{ transition:transform .3s var(--ease); }
.tlink:hover .arr{ transform:translateX(3px); }

/* ---------- reveal ---------- */
.reveal{ opacity:0; transform:translateY(16px); transition:opacity .8s var(--ease), transform .8s var(--ease); }
.reveal.in{ opacity:1; transform:none; }
/* frozen-frame / no-animation escape hatch: show everything instantly */
html.no-anim .reveal,
html.no-anim .stagger > *{ opacity:1 !important; transform:none !important; transition:none !important; }
@media (prefers-reduced-motion: reduce){
  .reveal{ opacity:1; transform:none; transition:none; }
  .stagger > *{ opacity:1; transform:none; }
  html{ scroll-behavior:auto; }
}

/* ============================================================
   NAV
   ============================================================ */
.nav{
  position:sticky; top:0; z-index:50;
  background:rgba(244,241,234,0.82);
  backdrop-filter:saturate(1.2) blur(10px);
  border-bottom:1px solid var(--line-soft);
}
.nav.scrolled{ border-bottom-color:var(--line); }
.nav-in{ display:flex; align-items:center; justify-content:space-between; height:68px; }
.brand{ display:flex; align-items:center; gap:11px; }
.brand-mark{
  width:18px; height:18px; position:relative; flex:none;
}
.brand-mark span{ position:absolute; background:var(--forest); }
.wordmark{
  font-family:var(--serif); font-size:20px; font-weight:500; letter-spacing:-0.01em;
  color:var(--ink); white-space:nowrap;
}
.wordmark b{ font-weight:500; }
.nav-links{ display:flex; align-items:center; gap:34px; }
.nav-link{
  font-size:15px; color:var(--ink-2); font-weight:450;
  position:relative; padding:4px 0; transition:color .2s var(--ease);
}
.nav-link:hover{ color:var(--ink); }
.nav-link.active{ color:var(--ink); }
.nav-link.active::after{
  content:""; position:absolute; left:0; right:0; bottom:-2px; height:2px; background:var(--forest);
}
.nav-cta{ display:flex; align-items:center; gap:18px; }
.nav-burger{
  display:none; background:none; border:none; padding:8px; margin:-8px;
  color:var(--ink); cursor:pointer; align-items:center; justify-content:center;
  flex:none; line-height:0;
}

/* ============================================================
   FOOTER
   ============================================================ */
.footer{ background:var(--forest); color:var(--cream-on-forest); margin-top:0; position:relative; z-index:1; }
.footer a{ color:var(--cream-on-forest); }
.footer-top{ padding-top:84px; padding-bottom:60px; border-bottom:1px solid var(--line-on-forest); }
.footer-grid{ display:grid; grid-template-columns:1.6fr 1fr 1fr 1fr; gap:40px; align-items:start; }
.footer .wordmark{ color:var(--cream-on-forest); font-size:24px; }
.footer-desc{ color:var(--mute-on-forest); max-width:36ch; margin-top:18px; font-size:15px; line-height:1.6; }
.footer-location{ color:var(--mute-on-forest); font-size:14px; margin-top:10px; opacity:0.7; }
.footer-col h4{ font-family:var(--mono); font-size:12px; letter-spacing:.02em; text-transform:none; color:var(--mute-on-forest); font-weight:500; margin-bottom:18px; }
.footer-col ul{ list-style:none; margin:0; padding:0; display:flex; flex-direction:column; gap:12px; }
.footer-col a{ font-size:15px; color:rgba(237,234,224,.86); transition:color .2s; }
.footer-col a:hover{ color:#fff; }
.footer-bottom{ padding-top:26px; padding-bottom:26px; display:flex; justify-content:space-between; align-items:center; gap:20px; }
.footer-bottom span{ font-family:var(--mono); font-size:11.5px; letter-spacing:.06em; color:var(--mute-on-forest); }

/* ============================================================
   GENERIC SECTION SHELL
   ============================================================ */
.sec{ padding:104px 0; }
.sec-sm{ padding:72px 0; }
.sec-head{ max-width:760px; }
.sec-head .display{ font-size:clamp(30px,3.4vw,44px); margin-top:20px; }
.sec-head .lead{ margin-top:22px; }

.rule{ height:1px; background:var(--line); border:0; margin:0; }

/* ---------- hairline list ---------- */
.hl-list{ border-top:1px solid var(--line); }
.hl-row{
  display:grid; grid-template-columns:54px 1fr auto; gap:24px; align-items:baseline;
  padding:30px 0; border-bottom:1px solid var(--line);
  transition:background .3s var(--ease), padding .3s var(--ease);
}
.hl-row:hover{ background:var(--cream-2); }
.hl-num{ font-family:var(--mono); font-size:13px; color:var(--forest); letter-spacing:.04em; }
.hl-title{ font-family:var(--serif); font-size:23px; letter-spacing:-.01em; }
.hl-desc{ color:var(--ink-2); font-size:15.5px; margin-top:8px; max-width:62ch; }
.hl-aside{ font-family:var(--mono); font-size:12px; color:var(--ink-3); text-transform:uppercase; letter-spacing:.1em; white-space:nowrap; }

/* ---------- phase / arc ---------- */
.arc{ display:grid; grid-template-columns:repeat(3,1fr); gap:0; border:1px solid var(--line); }
.arc-step{ padding:38px 34px; border-right:1px solid var(--line); position:relative; transition:background .3s var(--ease); }
.arc-step:last-child{ border-right:0; }
.arc-step:hover{ background:var(--cream-2); }
.arc-idx{ display:flex; align-items:center; gap:12px; margin-bottom:22px; }
.arc-dot{ width:10px; height:10px; border-radius:50%; background:var(--forest); flex:none; }
.arc-stage{ font-family:var(--mono); font-size:12px; letter-spacing:.02em; text-transform:none; color:var(--ink-3); }
.arc-step h3{ font-family:var(--serif); font-size:26px; letter-spacing:-.01em; margin-bottom:12px; }
.arc-step p{ color:var(--ink-2); font-size:15.5px; }
.arc-verb{ font-family:var(--mono); font-size:12px; color:var(--forest); letter-spacing:.04em; margin-top:18px; }

/* ---------- cards grid ---------- */
.cards{ display:grid; grid-template-columns:repeat(3,1fr); gap:1px; background:var(--line); border:1px solid var(--line); }
.card{ background:var(--cream); padding:34px 30px 36px; min-height:180px; display:flex; flex-direction:column; transition:background .3s var(--ease); }
.card:hover{ background:var(--cream-2); }
.card .card-tick{ width:8px; height:8px; background:var(--forest); border-radius:50%; margin-bottom:24px; opacity:.9; }
.card h3{ font-family:var(--serif); font-size:22px; letter-spacing:-.01em; margin:0 0 10px; }
.card p{ color:var(--ink-2); font-size:14.5px; line-height:1.55; }

/* ---------- pill / tag ---------- */
.tag{
  display:inline-flex; align-items:center; gap:7px;
  font-family:var(--mono); font-size:12px; letter-spacing:.01em; text-transform:none;
  color:var(--forest); background:var(--forest-tint); padding:5px 11px; border-radius:2px;
}

/* ---------- placeholder image ---------- */
.ph{
  position:relative; overflow:hidden; background:var(--cream-2);
  border:1px solid var(--line);
  background-image:repeating-linear-gradient(135deg, transparent 0 11px, rgba(22,20,15,.045) 11px 12px);
  display:flex; align-items:flex-end; justify-content:flex-start;
}
.ph::after{
  content:attr(data-label);
  font-family:var(--mono); font-size:11.5px; letter-spacing:.01em; text-transform:none;
  color:var(--ink-3); background:var(--cream); border:1px solid var(--line);
  padding:5px 9px; margin:12px;
}

/* ============================================================
   HERO — shared + direction-specific
   ============================================================ */
.hero{ padding:84px 0 64px; }

/* DIR 1 — Editorial */
.hero-ed .h-eyebrow{ margin-bottom:28px; }
.hero-ed h1{ font-size:clamp(40px,6.0vw,80px); max-width:16ch; }
.hero-ed .hero-sub{ margin-top:30px; max-width:60ch; }
.hero-ed .hero-cta{ margin-top:40px; display:flex; gap:14px; flex-wrap:wrap; }
.hero-ed .hero-meta{
  margin-top:64px; padding-top:28px; border-top:1px solid var(--line);
  display:grid; grid-template-columns:repeat(3,1fr); gap:24px; max-width:760px;
}
.hero-meta .hm-k{ font-family:var(--mono); font-size:11px; letter-spacing:.14em; text-transform:uppercase; color:var(--ink-3); margin-bottom:6px; }
.hero-meta .hm-v{ font-family:var(--serif); font-size:18px; color:var(--ink); }

/* DIR 2 — Technical / structured */
.hero-tech{ border-top:1px solid var(--line); }
.hero-tech .ht-grid{ display:grid; grid-template-columns:1.1fr .9fr; gap:56px; align-items:center; padding-top:18px; }
.hero-tech h1{ font-size:clamp(30px,3.3vw,44px); max-width:17ch; line-height:1.08; }
.hero-tech .hero-sub{ margin-top:24px; max-width:46ch; }
.hero-tech .hero-cta{ margin-top:34px; display:flex; gap:14px; flex-wrap:wrap; }
.hero-tech .ht-side{ border:1px solid var(--line); background:var(--cream-2); padding:30px; }

/* DIR 3 — Statement (forest block) */
.hero-stmt{ background:var(--forest); color:var(--cream-on-forest); padding:0; margin:0; }
.hero-stmt .hs-in{ padding-top:110px; padding-bottom:96px; position:relative; }
.hero-stmt .eyebrow{ color:var(--mute-on-forest); }
.hero-stmt .eyebrow::before{ background:var(--cream-on-forest); }
.hero-tagline{ display:block; max-width:68ch; font-size:21px; line-height:1.42; color:var(--cream-on-forest); margin-bottom:6px; }
.hero-stmt h1{ font-size:clamp(36px,5.2vw,72px); max-width:none; color:var(--cream-on-forest); margin-top:8px; }
.hero-stmt .hero-sub{ margin-top:30px; max-width:68ch; color:rgba(237,234,224,.82); font-size:21px; line-height:1.55; }
.hero-stmt .hero-cta{ margin-top:42px; display:flex; gap:14px; flex-wrap:wrap; }
.hero-stmt .hs-flow{
  margin-top:70px; padding-top:30px; border-top:1px solid var(--line-on-forest);
  display:flex; align-items:center; gap:18px; flex-wrap:wrap;
}
.hs-flow .fl{ font-family:var(--mono); font-size:13px; letter-spacing:.01em; text-transform:none; color:var(--cream-on-forest); }
.hs-flow .fl-arr{ color:var(--mute-on-forest); }
.hero-stmt::after{
  content:""; position:absolute; inset:0; pointer-events:none; opacity:.5;
  background-image:repeating-linear-gradient(90deg, transparent 0 79px, rgba(237,234,224,.05) 79px 80px);
}

/* ---------- diagram motif (thesis -> plan -> deploy) ---------- */
.motif{ width:100%; }
.motif .ln{ stroke:var(--line-strong); stroke-width:1; }
.motif .nd{ fill:var(--cream); stroke:var(--forest); stroke-width:1.4; }
.motif .nd-fill{ fill:var(--forest); }
.motif text{ font-family:var(--mono); font-size:10px; letter-spacing:.1em; text-transform:uppercase; fill:var(--ink-3); }
.motif .pulse{ animation:pulse 3s var(--ease) infinite; transform-origin:center; }
@keyframes pulse{ 0%,100%{ opacity:1 } 50%{ opacity:.35 } }
@media (prefers-reduced-motion: reduce){ .motif .pulse{ animation:none; } }

/* ============================================================
   DIRECTION OVERRIDES on the whole home (data-dir)
   ============================================================ */
/* dir 2 — technical: mono indices, denser */
[data-dir="2"] .sec-head .display{ letter-spacing:-.015em; }
[data-dir="2"] .arc{ border-color:var(--line); }

/* dir 3 — statement: bigger type, more drama on a couple sections */
[data-dir="3"] .sec-head .display{ font-size:clamp(32px,3.8vw,50px); }

/* ============================================================
   PANELS / bands
   ============================================================ */
.band-forest{ background:var(--forest); color:var(--cream-on-forest); }
.band-forest .eyebrow{ color:var(--mute-on-forest); }
.band-forest .eyebrow::before{ background:var(--cream-on-forest); }
.band-forest .muted{ color:rgba(237,234,224,.78); }
.band-cream2{ background:var(--cream-2); }

.cta-band{ padding:96px 0; }
.cta-grid{ display:grid; grid-template-columns:1.3fr auto; gap:48px; align-items:center; }
.cta-band h2{ font-family:var(--serif); font-size:clamp(30px,3.6vw,46px); letter-spacing:-.018em; line-height:1.06; max-width:18ch; }

/* ---------- differentiator split ---------- */
.split{ display:grid; grid-template-columns:1fr 1fr; gap:64px; align-items:center; }
.split-points{ display:flex; flex-direction:column; gap:0; border-top:1px solid var(--line); margin-top:8px; }
.split-point{ padding:22px 0; border-bottom:1px solid var(--line); display:grid; grid-template-columns:26px 1fr; gap:16px; }
.split-point .sp-mark{ color:var(--forest); font-family:var(--mono); font-size:14px; }
.split-point h4{ font-family:var(--serif); font-size:20px; margin-bottom:4px; }
.split-point p{ color:var(--ink-2); font-size:15px; }


/* ============================================================
   DIRECTION SWITCHER
   ============================================================ */
.dirsw{
  position:fixed; right:22px; bottom:22px; z-index:60;
  background:var(--cream); border:1px solid var(--line-strong);
  border-radius:3px; padding:10px 12px 12px;
  box-shadow:0 14px 40px rgba(22,20,15,.14);
  width:268px;
}
.dirsw-head{ display:flex; align-items:center; justify-content:space-between; margin-bottom:10px; }
.dirsw-head .lbl{ font-family:var(--mono); font-size:10.5px; letter-spacing:.14em; text-transform:uppercase; color:var(--ink-3); }
.dirsw-head .dot{ width:7px; height:7px; border-radius:50%; background:var(--forest); }
.dirsw-opts{ display:flex; flex-direction:column; gap:6px; }
.dirsw-opt{
  display:flex; align-items:center; gap:11px; width:100%;
  background:transparent; border:1px solid var(--line); border-radius:2px;
  padding:9px 11px; text-align:left; transition:border-color .2s, background .2s;
}
.dirsw-opt:hover{ border-color:var(--line-strong); background:var(--cream-2); }
.dirsw-opt.on{ border-color:var(--forest); background:var(--forest-tint); }
.dirsw-opt .n{ font-family:var(--mono); font-size:11px; color:var(--forest); width:22px; flex:none; }
.dirsw-opt .t{ display:flex; flex-direction:column; }
.dirsw-opt .t b{ font-size:13.5px; font-weight:600; color:var(--ink); }
.dirsw-opt .t i{ font-style:normal; font-size:11.5px; color:var(--ink-3); }

/* ============================================================
   CAREERS — values + roles + form
   ============================================================ */
.careers-eyebrow{ color:var(--cream-on-forest); }
.careers-eyebrow::before{ background:var(--mute-on-forest); }
.careers-values{
  display:grid; grid-template-columns:repeat(3,1fr);
  gap:1px; background:var(--line-on-forest); border:1px solid var(--line-on-forest);
}
.careers-value{ padding:36px 32px; }
.cv-label{ font-family:var(--serif); font-size:24px; letter-spacing:-.015em; color:var(--cream-on-forest); margin-bottom:12px; }
.careers-value p{ color:var(--mute-on-forest); font-size:15px; line-height:1.62; margin:0; }
.role-row{
  display:grid; grid-template-columns:1fr auto; gap:28px; align-items:center;
  padding:28px 26px; border-bottom:1px solid var(--line); cursor:pointer;
  transition:background .3s var(--ease); background:var(--cream);
}
.role-row:hover{ background:var(--cream-2); }
.role-row.open{ background:var(--cream-2); }
.role-main h3{ font-family:var(--serif); font-size:23px; letter-spacing:-.01em; }
.role-meta{ display:flex; gap:10px; flex-wrap:wrap; }
.role-right{ display:flex; align-items:center; gap:22px; }
.role-toggle{
  width:34px; height:34px; border-radius:50%; border:1px solid var(--line-strong);
  display:flex; align-items:center; justify-content:center; flex:none;
  transition:background .25s, border-color .25s, transform .25s;
}
.role-row:hover .role-toggle{ border-color:var(--ink); }
.role-row.open .role-toggle{ background:var(--forest); border-color:var(--forest); transform:rotate(45deg); }
.role-row.open .role-toggle svg path{ stroke:var(--cream-on-forest); }
.role-detail{ overflow:hidden; border-bottom:1px solid var(--line); background:var(--cream-2); }
.role-detail-in{ padding:8px 26px 34px; display:grid; grid-template-columns:1.5fr 1fr; gap:40px; }
.role-detail h5{ font-family:var(--mono); font-size:12px; letter-spacing:.02em; text-transform:none; color:var(--ink-3); margin:0 0 12px; }
.role-detail ul{ margin:0; padding-left:18px; color:var(--ink-2); font-size:15px; display:flex; flex-direction:column; gap:8px; }
.role-detail p{ color:var(--ink-2); font-size:15px; }

/* ============================================================
   MODAL
   ============================================================ */
.modal-overlay{
  position:fixed; inset:0; z-index:1000;
  background:rgba(22,20,15,.62);
  overflow-y:auto;
  padding:40px 24px;
  display:flex; justify-content:center; align-items:flex-start;
}
.modal{
  position:relative; background:var(--cream); width:100%; max-width:1080px;
  border:1px solid var(--line); margin:auto;
}
.modal-close{
  position:absolute; top:20px; right:20px;
  width:36px; height:36px; border-radius:50%;
  border:1px solid var(--line-strong); background:none; cursor:pointer;
  display:flex; align-items:center; justify-content:center;
  transition:background .2s, border-color .2s;
}
.modal-close:hover{ background:var(--cream-2); border-color:var(--ink); }
.modal-body{ padding:52px 56px; }
.modal-head{ margin-bottom:40px; padding-right:40px; }
.modal-head h2{ font-family:var(--serif); font-size:clamp(26px,3vw,38px); letter-spacing:-.02em; margin:0; }
.modal-meta-row{ display:flex; align-items:center; justify-content:space-between; gap:10px; margin:16px 0 22px; }
.modal-section{ margin-bottom:36px; }
.modal-section h5{ font-family:var(--sans); font-size:15px; font-weight:600; letter-spacing:0; color:var(--ink); margin:0 0 12px; }
.modal-section ul{ margin:0; padding-left:18px; color:var(--ink-2); font-size:15px; display:flex; flex-direction:column; gap:8px; }
.modal-section p{ color:var(--ink-2); font-size:15px; margin:0; }
.modal-subhead{ font-family:var(--mono); font-size:11px; letter-spacing:.06em; text-transform:uppercase; color:var(--ink-3); margin:0 0 10px; }
.modal-apply{ border-top:1px solid var(--line); padding-top:48px; }
.share-btn{
  display:inline-flex; align-items:center; justify-content:center;
  font-family:var(--mono); font-size:12px; letter-spacing:.02em;
  width:32px; height:32px; padding:0; flex:none;
  color:var(--ink-2); background:none; border:1px solid var(--line-strong);
  border-radius:50%; cursor:pointer; transition:color .2s, border-color .2s, background .2s;
}
.share-btn:hover{ color:var(--ink); border-color:var(--ink); background:var(--cream-2); }
.share-btn.copied{ width:auto; padding:0 12px; border-radius:2px; color:var(--forest); border-color:var(--forest); white-space:nowrap; }
body.modal-open{ overflow:hidden; }
@media(max-width:600px){
  .modal-overlay{ padding:0; align-items:flex-start; }
  .modal-body{ padding:36px 20px 48px; }
}

/* form */
.form-card{ background:var(--cream); border:1px solid var(--line); padding:42px 40px; }
.form-grid{ display:grid; grid-template-columns:1fr 1fr; gap:22px 26px; }
.field{ display:flex; flex-direction:column; gap:8px; }
.field.full{ grid-column:1 / -1; }
.field label{ font-family:var(--mono); font-size:12px; letter-spacing:.01em; text-transform:none; color:var(--ink-3); }
.field label .opt{ color:var(--ink-3); opacity:.7; text-transform:none; letter-spacing:0; }
.field input{
  font-family:var(--sans); font-size:16px; color:var(--ink);
  background:var(--cream-2); border:1px solid var(--line); border-radius:2px;
  padding:13px 14px; transition:border-color .2s, background .2s;
}
.field input::placeholder{ color:var(--ink-3); }
.field input:focus{ outline:none; border-color:var(--forest); background:var(--cream); }
.field input.err{ border-color:#7A1F1F; }
.field .errmsg{ font-family:var(--mono); font-size:11px; color:#7A1F1F; letter-spacing:.02em; }
.dropzone{
  grid-column:1 / -1; border:1.5px dashed var(--line-strong); border-radius:3px;
  padding:30px; text-align:center; background:var(--cream-2);
  transition:border-color .2s, background .2s; cursor:pointer;
}
.dropzone:hover{ border-color:var(--forest); }
.dropzone.has{ border-style:solid; border-color:var(--forest); background:var(--forest-tint); }
.dropzone .dz-title{ font-family:var(--serif); font-size:18px; margin-bottom:6px; }
.dropzone .dz-sub{ font-size:13.5px; color:var(--ink-3); font-family:var(--mono); letter-spacing:.02em; }
.form-actions{ display:flex; align-items:center; justify-content:space-between; gap:20px; margin-top:30px; flex-wrap:wrap; }
.form-note{ font-size:13px; color:var(--ink-3); max-width:42ch; }
.form-success{ text-align:center; padding:64px 30px; }
.form-success .fs-mark{ width:56px; height:56px; border-radius:50%; background:var(--forest); display:flex; align-items:center; justify-content:center; margin:0 auto 24px; }
.roles-chips{ display:flex; flex-wrap:wrap; gap:8px; }
.role-chip{
  font-family:var(--mono); font-size:12px; letter-spacing:.01em;
  padding:6px 13px; border-radius:2px; border:1px solid var(--line-strong);
  background:transparent; color:var(--ink-2); cursor:pointer; transition:border-color .15s, background .15s, color .15s;
}
.role-chip:hover:not(.selected){ border-color:var(--forest); color:var(--forest); }
.role-chip.selected{ background:var(--forest); border-color:var(--forest); color:#fff; }

/* ---------- team ---------- */
.team-grid{ display:grid; grid-template-columns:1fr 1fr; gap:56px 48px; }
.person{ display:flex; gap:28px; align-items:flex-start; }
.person-photo{ width:172px; flex:none; aspect-ratio:4/5; object-fit:cover; border-radius:2px; background:var(--cream-2); }
.person-body{ padding-top:2px; flex:1; min-width:0; }
.person-name{ font-family:var(--serif); font-size:27px; letter-spacing:-.015em; }
.person-role{ font-family:var(--mono); font-size:12.5px; letter-spacing:.01em; text-transform:none; color:var(--forest); margin-top:10px; }
.person-bio{ color:var(--ink-2); font-size:15px; margin-top:16px; line-height:1.6; }
.person-bio p + p{ margin-top:12px; }
.person-links{ display:flex; gap:12px; margin-top:20px; }
.iconbtn{
  width:40px; height:40px; border:1px solid var(--line-strong); border-radius:2px;
  display:flex; align-items:center; justify-content:center; color:var(--ink);
  transition:background .2s, border-color .2s, color .2s;
}
.iconbtn:hover{ background:var(--forest); border-color:var(--forest); color:var(--cream-on-forest); }

/* ---------- page hero (interior) ---------- */
.page-hero{ padding:76px 0 56px; border-bottom:1px solid var(--line); }
.page-hero h1{ font-family:var(--serif); font-size:clamp(38px,5vw,68px); letter-spacing:-.02em; line-height:1.02; margin-top:22px; max-width:32ch; }
.page-hero .lead{ margin-top:26px; max-width:72ch; }
.legal-updated{ font-family:var(--mono); font-size:12px; letter-spacing:.04em; color:var(--ink-3); margin-top:18px; }

/* ---------- legal prose ---------- */
.legal-prose{ max-width:74ch; }
.legal-block + .legal-block{ margin-top:40px; padding-top:40px; border-top:1px solid var(--line); }
.legal-block h2{ font-family:var(--serif); font-size:24px; letter-spacing:-.01em; margin-bottom:16px; }
.legal-block p{ color:var(--ink-2); font-size:16.5px; line-height:1.66; text-wrap:pretty; }
.legal-block p + p{ margin-top:14px; }

/* ---------- misc reveal stagger ---------- */
.stagger > *{ opacity:0; transform:translateY(14px); }
.stagger.in > *{ opacity:1; transform:none; transition:opacity .7s var(--ease), transform .7s var(--ease); }
.stagger.in > *:nth-child(1){ transition-delay:.04s; }
.stagger.in > *:nth-child(2){ transition-delay:.10s; }
.stagger.in > *:nth-child(3){ transition-delay:.16s; }
.stagger.in > *:nth-child(4){ transition-delay:.22s; }
.stagger.in > *:nth-child(5){ transition-delay:.28s; }
.stagger.in > *:nth-child(6){ transition-delay:.34s; }

/* ============================================================
   RESPONSIVE
   ============================================================ */
/* ---------- mobile menu ---------- */
.mobile-menu{
  position:fixed; top:68px; left:0; right:0; bottom:0;
  z-index:49; background:var(--cream);
  border-top:1px solid var(--line);
  display:flex; flex-direction:column;
  padding:28px var(--gut) 48px;
  overflow-y:auto;
}
.mobile-nav-link{
  display:block; font-family:var(--serif);
  font-size:clamp(26px,7vw,36px); letter-spacing:-.02em;
  color:var(--ink-2); padding:16px 0; border-bottom:1px solid var(--line);
  transition:color .2s var(--ease);
}
.mobile-nav-link:first-child{ border-top:1px solid var(--line); }
.mobile-nav-link.active,.mobile-nav-link:hover{ color:var(--ink); }
.mobile-menu-cta{ margin-top:32px; align-self:flex-start; }

.offers-cols{ display:grid; grid-template-columns:1fr 2fr; gap:48px; align-items:stretch; }
.offers-cols > *{ display:flex; flex-direction:column; min-width:0; }
.offers-cards{ flex:1; display:grid; gap:1px; background:var(--line); border:1px solid var(--line); }
.offers-cards--pre{ grid-template-rows:1fr 1fr; }
.offers-cards--post{ grid-template-columns:1fr 1fr; }

@media (max-width: 980px){
  :root{ --gut:26px; }
  .nav-links{ display:none; }
  .nav-burger{ display:flex; }
  .arc{ grid-template-columns:1fr; }
  .arc-step{ border-right:0; border-bottom:1px solid var(--line); }
  .arc-step:last-child{ border-bottom:0; }
  .cards{ grid-template-columns:1fr 1fr; }
  .split{ grid-template-columns:1fr; gap:36px; }
  .case{ grid-template-columns:1fr; }
  .case-media{ min-height:280px; }
  .hero-tech .ht-grid{ grid-template-columns:1fr; gap:40px; }
  .team-grid{ grid-template-columns:1fr; gap:40px; }
  .footer-grid{ grid-template-columns:1fr 1fr; gap:36px; }
  .cta-grid{ grid-template-columns:1fr; gap:28px; }
  .form-grid{ grid-template-columns:1fr; }
  .role-detail-in{ grid-template-columns:1fr; gap:24px; }
  .careers-values{ grid-template-columns:1fr; }
}
@media (max-width: 600px){
  body{ font-size:16px; }
  .offers-cols{ grid-template-columns:1fr; }
  .offers-cards--post{ grid-template-columns:1fr; }
  .nav-talk{ display:none; }
  .hero-stmt .hs-in{ padding-top:72px; padding-bottom:60px; }
  .sec{ padding:72px 0; }
  .cards{ grid-template-columns:1fr; }
  .hero-meta, .hero-ed .hero-meta{ grid-template-columns:1fr; }
  .case-metrics{ grid-template-columns:1fr; gap:18px; }
  .footer-grid{ grid-template-columns:1fr; }
  .role-row{ grid-template-columns:1fr; gap:16px; }
  .role-right{ justify-content:space-between; }
  .person{ flex-direction:column; gap:18px; }
  .person-photo{ width:150px; }
  .footer-loc-sep{ display:none; }
  .footer-loc{ display:block; }
}
