/* =========================================================
   Agile Insurance Analytics — shared stylesheet
   Aesthetic: editorial / authoritative. Deep ink + parchment,
   burnished gold accent, fine data-grid motif.
   Type: Fraunces (display serif), Hanken Grotesk (body),
   IBM Plex Mono (labels).
   ========================================================= */

:root{
  --ink:#0F1620;
  --ink-2:#161F2C;
  --ink-3:#1E2937;
  --paper:#F4EFE4;
  --paper-2:#EAE3D3;
  --paper-3:#DED5C0;
  --gold:#C2902F;
  --gold-bright:#D8A63F;
  --teal:#1F6E68;
  --teal-bright:#2A8A82;
  --text:#1A222E;
  --text-soft:#4A5260;
  --text-paper:#F4EFE4;
  --text-paper-soft:#B7BBC4;
  --line:rgba(26,34,46,.14);
  --line-strong:rgba(26,34,46,.28);
  --line-paper:rgba(244,239,228,.16);
  --maxw:1240px;
  --gut:clamp(20px,5vw,72px);
  --r:4px;
  --ease:cubic-bezier(.2,.7,.2,1);
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  font-family:"Hanken Grotesk",system-ui,sans-serif;
  background:var(--paper);
  color:var(--text);
  line-height:1.6;
  font-size:17px;
  font-weight:400;
  letter-spacing:-.005em;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
::selection{background:var(--gold);color:var(--ink)}

/* ---------- typography ---------- */
.display{
  font-family:"Fraunces",Georgia,serif;
  font-weight:430;
  line-height:.99;
  letter-spacing:-.02em;
  font-optical-sizing:auto;
}
h1.display{font-size:clamp(2.7rem,7.2vw,6rem)}
h2.display{font-size:clamp(2rem,4.6vw,3.7rem);line-height:1.02}
h3.display{font-size:clamp(1.5rem,2.6vw,2.2rem);line-height:1.05}
em.gold,.fr-italic{font-style:italic;font-weight:380}
.gold{color:var(--gold)}

.eyebrow{
  font-family:"IBM Plex Mono",monospace;
  font-size:.72rem;
  letter-spacing:.26em;
  text-transform:uppercase;
  font-weight:500;
  color:var(--gold);
  display:inline-flex;
  align-items:center;
  gap:.7em;
}
.eyebrow::before{
  content:"";
  width:26px;height:1px;
  background:var(--gold);
  display:inline-block;
}
.eyebrow.center::before{display:none}

.lead{font-size:clamp(1.05rem,1.5vw,1.32rem);line-height:1.55;color:var(--text-soft)}
.muted{color:var(--text-soft)}

/* ---------- layout ---------- */
.wrap{max-width:var(--maxw);margin:0 auto;padding-inline:var(--gut)}
section{position:relative}
.pad{padding-block:clamp(72px,11vw,140px)}
.pad-sm{padding-block:clamp(56px,8vw,96px)}
.center{text-align:center}
.divider{height:1px;background:var(--line);border:0;margin:0}

/* ---------- buttons ---------- */
.btn{
  display:inline-flex;align-items:center;gap:.7em;white-space:nowrap;
  font-family:"Hanken Grotesk",sans-serif;
  font-weight:600;font-size:.95rem;letter-spacing:.01em;
  padding:.95em 1.5em;
  border-radius:var(--r);
  border:1px solid transparent;
  cursor:pointer;
  transition:transform .25s var(--ease),background .25s var(--ease),color .25s var(--ease),box-shadow .25s var(--ease);
  position:relative;
}
.btn .arrow{transition:transform .3s var(--ease)}
.btn:hover .arrow{transform:translateX(4px)}
.btn-gold{background:var(--gold);color:var(--ink);box-shadow:0 1px 0 rgba(0,0,0,.04)}
.btn-gold:hover{background:var(--gold-bright);transform:translateY(-2px);box-shadow:0 12px 28px -12px rgba(194,144,47,.7)}
.btn-ghost{border-color:var(--line-strong);color:var(--text)}
.btn-ghost:hover{border-color:var(--ink);background:var(--ink);color:var(--paper);transform:translateY(-2px)}
.btn-ghost-light{border-color:var(--line-paper);color:var(--paper)}
.btn-ghost-light:hover{background:var(--paper);color:var(--ink);transform:translateY(-2px)}

/* ---------- header ---------- */
.site-head{
  position:sticky;top:0;z-index:50;
  background:rgba(244,239,228,.78);
  backdrop-filter:blur(14px) saturate(1.4);
  -webkit-backdrop-filter:blur(14px) saturate(1.4);
  border-bottom:1px solid transparent;
  transition:border-color .3s,background .3s;
}
.site-head.scrolled{border-bottom-color:var(--line);background:rgba(244,239,228,.9)}
.site-head.on-dark{background:rgba(15,22,32,.5);}
.site-head.on-dark.scrolled{background:rgba(15,22,32,.86);border-bottom-color:var(--line-paper)}
.nav{display:flex;align-items:center;justify-content:space-between;height:74px}
.brand{display:flex;align-items:center;gap:.7em;font-weight:700;letter-spacing:-.01em}
.brand .mark{
  width:34px;height:34px;flex:none;border-radius:6px;
  background:linear-gradient(145deg,var(--gold),var(--teal));
  display:grid;place-items:center;color:var(--ink);
  font-family:"Fraunces",serif;font-weight:600;font-size:1.05rem;
  box-shadow:inset 0 0 0 1px rgba(0,0,0,.15);
}
.brand .bt{display:flex;flex-direction:column;line-height:1}
.brand .bt b{font-size:1.02rem}
.brand .bt span{font-family:"IBM Plex Mono",monospace;font-size:.58rem;letter-spacing:.2em;text-transform:uppercase;color:var(--text-soft);margin-top:3px}
.on-dark .brand,.on-dark .brand .bt b{color:var(--paper)}
.on-dark .brand .bt span{color:var(--text-paper-soft)}

.nav-links{display:flex;align-items:center;gap:clamp(13px,1.7vw,28px)}
.nav-links a.nlink{
  font-weight:500;font-size:.95rem;position:relative;padding:4px 0;
  color:var(--text-soft);transition:color .2s;
}
.on-dark .nav-links a.nlink{color:var(--text-paper-soft)}
.nav-links a.nlink::after{
  content:"";position:absolute;left:0;bottom:-2px;height:1.5px;width:0;background:var(--gold);transition:width .3s var(--ease);
}
.nav-links a.nlink:hover,.nav-links a.nlink.active{color:var(--gold)}
.nav-links a.nlink:hover::after,.nav-links a.nlink.active::after{width:100%}
.nav-cta{margin-left:6px}
.burger{display:none;flex-direction:column;gap:5px;background:none;border:0;cursor:pointer;padding:8px}
.burger span{width:24px;height:2px;background:currentColor;display:block;transition:.3s}
.on-dark .burger{color:var(--paper)}

/* ---------- hero ---------- */
.hero{
  background:var(--ink);color:var(--text-paper);
  position:relative;overflow:hidden;
  padding-block:clamp(90px,15vw,180px) clamp(80px,12vw,150px);
}
.hero .grid-tex{
  position:absolute;inset:0;pointer-events:none;opacity:.5;
  background-image:linear-gradient(var(--line-paper) 1px,transparent 1px),linear-gradient(90deg,var(--line-paper) 1px,transparent 1px);
  background-size:64px 64px;
  mask-image:radial-gradient(120% 90% at 70% 10%,#000 25%,transparent 78%);
  -webkit-mask-image:radial-gradient(120% 90% at 70% 10%,#000 25%,transparent 78%);
}
.hero .glow{
  position:absolute;width:60vw;height:60vw;max-width:760px;max-height:760px;
  right:-10%;top:-22%;border-radius:50%;pointer-events:none;
  background:radial-gradient(circle,rgba(194,144,47,.30),rgba(194,144,47,0) 62%);
  filter:blur(8px);
}
.hero .glow.teal{left:-16%;top:auto;bottom:-30%;right:auto;
  background:radial-gradient(circle,rgba(31,110,104,.32),rgba(31,110,104,0) 62%)}
.hero .wrap{position:relative;z-index:2}
.hero-eyebrow{color:var(--gold)}
.hero h1{margin:.5em 0 .55em;max-width:16ch}
.hero h1 .line{display:block;overflow:hidden}
.hero h1 .line i{display:inline-block;font-style:normal}
.hero-sub{max-width:50ch;color:var(--text-paper-soft);font-size:clamp(1.05rem,1.5vw,1.3rem);line-height:1.55}
.hero-sub b{color:var(--paper);font-weight:600}
.hero-cta{display:flex;flex-wrap:wrap;gap:14px;margin-top:38px}
.hero-flow{
  display:flex;flex-wrap:wrap;align-items:center;gap:clamp(10px,1.6vw,22px);
  margin-top:clamp(48px,7vw,86px);padding-top:30px;border-top:1px solid var(--line-paper);
  font-family:"IBM Plex Mono",monospace;font-size:.8rem;letter-spacing:.12em;text-transform:uppercase;
  color:var(--text-paper-soft);
}
.hero-flow b{color:var(--gold);font-weight:500}
.hero-flow .step{color:var(--paper);font-weight:500}
.hero-flow .ar{color:var(--gold);font-size:1.1em}

/* ---------- generic section head ---------- */
.shead{max-width:760px;margin-bottom:clamp(40px,6vw,68px)}
.shead.center{margin-inline:auto}
.shead h2{margin:.45em 0 .4em}
.snum{font-family:"IBM Plex Mono",monospace;font-size:.78rem;letter-spacing:.22em;color:var(--gold);font-weight:500}

/* ---------- statement band ---------- */
.band{background:var(--ink);color:var(--text-paper)}
.band .lead{color:var(--text-paper-soft)}
.band-quote{
  font-family:"Fraunces",serif;font-weight:400;font-size:clamp(1.7rem,3.4vw,2.9rem);
  line-height:1.16;letter-spacing:-.02em;max-width:20ch;
}
.band-quote .gold{font-style:italic}

/* ---------- outcomes grid ---------- */
.grid-outcomes{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--line);border:1px solid var(--line);border-radius:var(--r);overflow:hidden}
.ocard{background:var(--paper);padding:clamp(26px,3vw,40px);display:flex;flex-direction:column;gap:14px;transition:background .3s var(--ease)}
.ocard:hover{background:var(--paper-2)}
.ocard .ico{width:30px;height:30px;color:var(--teal)}
.ocard h4{font-family:"Hanken Grotesk",sans-serif;font-weight:700;font-size:1.12rem;letter-spacing:-.01em}
.ocard p{font-size:.97rem;color:var(--text-soft);line-height:1.55}
.ocard .oi{font-family:"IBM Plex Mono",monospace;font-size:.72rem;color:var(--gold);letter-spacing:.18em}

/* ---------- questions list ---------- */
.qlist{display:grid;gap:0;border-top:1px solid var(--line)}
.qrow{
  display:flex;align-items:baseline;gap:clamp(16px,3vw,40px);
  padding:clamp(20px,2.6vw,30px) 0;border-bottom:1px solid var(--line);
  transition:padding-left .3s var(--ease);
}
.qrow:hover{padding-left:14px}
.qrow .qn{font-family:"IBM Plex Mono",monospace;font-size:.8rem;color:var(--gold);flex:none;width:2.4em;padding-top:.3em}
.qrow .qt{font-family:"Fraunces",serif;font-weight:400;font-size:clamp(1.15rem,2vw,1.6rem);line-height:1.2;letter-spacing:-.01em}
.qrow:hover .qt{color:var(--teal)}

/* ---------- shifts ---------- */
.shifts{display:grid;gap:18px}
.shift{
  display:grid;grid-template-columns:1fr auto 1fr;align-items:center;gap:clamp(14px,3vw,40px);
  background:var(--paper);border:1px solid var(--line);border-radius:var(--r);
  padding:clamp(20px,2.5vw,30px) clamp(22px,3vw,40px);
  transition:transform .3s var(--ease),border-color .3s,box-shadow .3s;
}
.shift:hover{transform:translateY(-3px);border-color:var(--line-strong);box-shadow:0 18px 40px -28px rgba(15,22,32,.5)}
.shift .from{color:var(--text-soft);font-size:1.05rem}
.shift .to{font-family:"Fraunces",serif;font-size:clamp(1.2rem,2vw,1.6rem);font-weight:430;text-align:right;letter-spacing:-.01em}
.shift .arr{color:var(--gold);font-size:1.4rem;flex:none}

/* ---------- pillars ---------- */
.pillars-wrap{background:var(--ink);color:var(--text-paper);position:relative;overflow:hidden}
.pillars-wrap .grid-tex{position:absolute;inset:0;opacity:.4;pointer-events:none;
  background-image:linear-gradient(var(--line-paper) 1px,transparent 1px),linear-gradient(90deg,var(--line-paper) 1px,transparent 1px);
  background-size:72px 72px;mask-image:radial-gradient(120% 120% at 50% 0%,#000 30%,transparent 80%);
  -webkit-mask-image:radial-gradient(120% 120% at 50% 0%,#000 30%,transparent 80%);}
.pillars-wrap .shead h2{color:var(--paper)}
.pillars-wrap .lead{color:var(--text-paper-soft)}
.pillars{display:grid;grid-template-columns:repeat(2,1fr);gap:1px;background:var(--line-paper);border:1px solid var(--line-paper);border-radius:var(--r);overflow:hidden;position:relative;z-index:2}
.pillar{
  background:var(--ink);padding:clamp(30px,3.6vw,52px);position:relative;overflow:hidden;
  transition:background .4s var(--ease);
}
.pillar::before{content:"";position:absolute;left:0;top:0;height:100%;width:3px;background:var(--gold);transform:scaleY(0);transform-origin:top;transition:transform .4s var(--ease)}
.pillar:hover{background:var(--ink-2)}
.pillar:hover::before{transform:scaleY(1)}
.pillar .pn{font-family:"IBM Plex Mono",monospace;font-size:.8rem;letter-spacing:.22em;color:var(--gold)}
.pillar .pico{width:38px;height:38px;color:var(--gold-bright);margin:20px 0 18px}
.pillar h3{font-family:"Fraunces",serif;font-weight:440;font-size:clamp(1.5rem,2.4vw,2rem);letter-spacing:-.01em;color:var(--paper)}
.pillar p{color:var(--text-paper-soft);margin-top:12px;font-size:1rem;line-height:1.6}
.pillar .ptag{margin-top:18px;font-family:"IBM Plex Mono",monospace;font-size:.72rem;letter-spacing:.14em;text-transform:uppercase;color:var(--teal-bright)}

/* ---------- who we are ---------- */
.who{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(20px,2.5vw,34px)}
.wcard{border-top:2px solid var(--gold);padding-top:24px}
.wcard .wn{font-family:"IBM Plex Mono",monospace;font-size:.74rem;letter-spacing:.2em;color:var(--text-soft)}
.wcard h3{font-family:"Fraunces",serif;font-weight:440;font-size:clamp(1.4rem,2vw,1.85rem);margin:10px 0 12px;letter-spacing:-.01em}
.wcard p{color:var(--text-soft);font-size:1rem}

/* ---------- do list ---------- */
.dolist{display:grid;gap:0;counter-reset:do}
.dorow{display:flex;gap:clamp(16px,2.4vw,34px);align-items:flex-start;padding:clamp(20px,2.5vw,28px) 0;border-bottom:1px solid var(--line)}
.dorow:first-child{border-top:1px solid var(--line)}
.dorow .dn{counter-increment:do;font-family:"IBM Plex Mono",monospace;color:var(--gold);font-size:.85rem;flex:none;width:2.6em;padding-top:.3em}
.dorow .dn::before{content:"0" counter(do)}
.dorow .dt h4{font-family:"Fraunces",serif;font-weight:450;font-size:clamp(1.2rem,1.9vw,1.5rem);letter-spacing:-.01em}
.dorow .dt p{color:var(--text-soft);margin-top:6px;font-size:1rem}

/* ---------- team ---------- */
.team{display:grid;gap:1px;background:var(--line);border:1px solid var(--line);border-radius:var(--r);overflow:hidden}
.member{background:var(--paper);padding:clamp(30px,4vw,56px);display:grid;grid-template-columns:auto 1fr;gap:clamp(24px,4vw,52px);align-items:start}
.member:hover{background:var(--paper-2)}
.mono-av{
  width:108px;height:108px;flex:none;border-radius:50%;
  display:grid;place-items:center;color:var(--paper);
  font-family:"Fraunces",serif;font-weight:500;font-size:2rem;letter-spacing:.02em;
  background:linear-gradient(150deg,var(--ink-2),var(--ink));
  box-shadow:inset 0 0 0 1px var(--line-strong),0 14px 30px -18px rgba(15,22,32,.6);
  position:relative;
}
.mono-av::after{content:"";position:absolute;inset:4px;border-radius:50%;border:1px solid var(--gold);opacity:.5}
.member .mhead .mname{font-family:"Fraunces",serif;font-weight:480;font-size:clamp(1.5rem,2.4vw,2.05rem);letter-spacing:-.01em}
.member .mhead .mrole{font-family:"IBM Plex Mono",monospace;font-size:.76rem;letter-spacing:.16em;text-transform:uppercase;color:var(--gold);margin-top:8px}
.member .mbody{margin-top:20px;display:grid;gap:14px;color:var(--text-soft);font-size:1rem;line-height:1.68}
.member .mbody strong{color:var(--text);font-weight:600}
.member .creds{margin-top:20px;display:flex;flex-wrap:wrap;gap:8px}
.cred{font-family:"IBM Plex Mono",monospace;font-size:.7rem;letter-spacing:.1em;padding:.45em .8em;border:1px solid var(--line-strong);border-radius:100px;color:var(--text-soft)}

/* ---------- CTA band ---------- */
.cta{background:var(--ink);color:var(--text-paper);position:relative;overflow:hidden}
.cta .glow{position:absolute;width:50vw;height:50vw;max-width:620px;max-height:620px;border-radius:50%;
  background:radial-gradient(circle,rgba(194,144,47,.26),transparent 64%);right:-8%;top:-30%;pointer-events:none}
.cta .wrap{position:relative;z-index:2;text-align:center}
.cta h2{margin:.5em auto .4em;max-width:18ch}
.cta .lead{color:var(--text-paper-soft);max-width:48ch;margin-inline:auto}
.cta .hero-cta{justify-content:center}

/* ---------- contact ---------- */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(36px,5vw,80px);align-items:start}
.field{display:flex;flex-direction:column;gap:8px;margin-bottom:20px}
.field label{font-family:"IBM Plex Mono",monospace;font-size:.72rem;letter-spacing:.16em;text-transform:uppercase;color:var(--text-soft)}
.field input,.field textarea,.field select{
  font-family:"Hanken Grotesk",sans-serif;font-size:1rem;color:var(--text);
  background:var(--paper);border:1px solid var(--line-strong);border-radius:var(--r);
  padding:.85em 1em;transition:border-color .25s,box-shadow .25s;width:100%;
}
.field input:focus,.field textarea:focus,.field select:focus{outline:0;border-color:var(--gold);box-shadow:0 0 0 3px rgba(194,144,47,.18)}
.field textarea{resize:vertical;min-height:130px}
.field .err{font-family:"Hanken Grotesk",sans-serif;font-size:.82rem;color:#B23A2E;letter-spacing:0;text-transform:none;display:none}
.field.invalid input,.field.invalid textarea{border-color:#B23A2E}
.field.invalid .err{display:block}
.form-note{font-size:.86rem;color:var(--text-soft);margin-top:10px}
.form-success{
  display:none;background:var(--ink);color:var(--paper);border-radius:var(--r);
  padding:clamp(28px,4vw,44px);
}
.form-success.show{display:block;animation:rise .5s var(--ease) both}
.form-success h3{font-family:"Fraunces",serif;font-weight:460;font-size:1.6rem;margin-bottom:10px}
.form-success p{color:var(--text-paper-soft)}
.contact-aside .info-row{padding:20px 0;border-bottom:1px solid var(--line)}
.contact-aside .info-row:first-child{border-top:1px solid var(--line)}
.contact-aside .info-row .k{font-family:"IBM Plex Mono",monospace;font-size:.72rem;letter-spacing:.16em;text-transform:uppercase;color:var(--gold)}
.contact-aside .info-row .v{font-size:1.08rem;margin-top:6px}
.contact-aside .info-row .v a:hover{color:var(--teal)}

/* ---------- page hero (interior) ---------- */
.phero{background:var(--ink);color:var(--text-paper);position:relative;overflow:hidden;padding-block:clamp(90px,13vw,150px) clamp(56px,8vw,90px)}
.phero .grid-tex{position:absolute;inset:0;opacity:.42;pointer-events:none;
  background-image:linear-gradient(var(--line-paper) 1px,transparent 1px),linear-gradient(90deg,var(--line-paper) 1px,transparent 1px);
  background-size:64px 64px;mask-image:radial-gradient(110% 100% at 80% 0%,#000 25%,transparent 78%);
  -webkit-mask-image:radial-gradient(110% 100% at 80% 0%,#000 25%,transparent 78%)}
.phero .wrap{position:relative;z-index:2}
.phero h1{margin:.4em 0 .35em;max-width:18ch}
.phero p{color:var(--text-paper-soft);max-width:54ch;font-size:clamp(1.05rem,1.5vw,1.28rem)}

/* ---------- footer ---------- */
.site-foot{background:var(--ink-2);color:var(--text-paper-soft);padding-block:clamp(56px,7vw,84px) 36px}
.foot-top{display:grid;grid-template-columns:1.5fr 1fr 1fr;gap:40px;padding-bottom:48px;border-bottom:1px solid var(--line-paper)}
.foot-brand .brand .bt b{color:var(--paper)}
.foot-brand p{margin-top:18px;max-width:34ch;font-size:.96rem}
.foot-col h5{font-family:"IBM Plex Mono",monospace;font-size:.72rem;letter-spacing:.18em;text-transform:uppercase;color:var(--gold);margin-bottom:18px}
.foot-col a,.foot-col span{display:block;margin-bottom:11px;font-size:.96rem;transition:color .2s}
.foot-col a:hover{color:var(--paper)}
.foot-pillars{display:flex;flex-wrap:wrap;gap:8px;margin-top:6px}
.foot-pillars span{font-family:"IBM Plex Mono",monospace;font-size:.68rem;letter-spacing:.1em;padding:.4em .7em;border:1px solid var(--line-paper);border-radius:100px;margin:0}
.foot-bottom{display:flex;justify-content:space-between;flex-wrap:wrap;gap:14px;padding-top:28px;font-size:.84rem}
.foot-bottom .em{font-family:"IBM Plex Mono",monospace;letter-spacing:.1em}

/* ---------- reveal animation ---------- */
.reveal{opacity:0;transform:translateY(26px);transition:opacity .8s var(--ease),transform .8s var(--ease)}
.reveal.in{opacity:1;transform:none}
.reveal[data-d="1"]{transition-delay:.08s}
.reveal[data-d="2"]{transition-delay:.16s}
.reveal[data-d="3"]{transition-delay:.24s}
.reveal[data-d="4"]{transition-delay:.32s}
@keyframes rise{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:none}}

/* hero load animation */
.hero .anim{opacity:0;transform:translateY(28px);animation:rise .9s var(--ease) forwards}
.hero .anim.d1{animation-delay:.05s}
.hero .anim.d2{animation-delay:.18s}
.hero .anim.d3{animation-delay:.32s}
.hero .anim.d4{animation-delay:.46s}
.hero .anim.d5{animation-delay:.6s}

@media (prefers-reduced-motion:reduce){
  *{animation:none!important;transition:none!important}
  .reveal{opacity:1;transform:none}
  html{scroll-behavior:auto}
}

/* ---------- responsive ---------- */
@media(max-width:980px){
  .foot-top{grid-template-columns:1fr 1fr}
  .foot-brand{grid-column:1/-1}
}
@media(max-width:1080px){
  .nav-links{
    position:fixed;inset:74px 0 auto 0;flex-direction:column;align-items:flex-start;gap:0;
    background:var(--ink);padding:10px var(--gut) 26px;
    transform:translateY(-130%);transition:transform .4s var(--ease);
    border-bottom:1px solid var(--line-paper);box-shadow:0 30px 50px -30px rgba(0,0,0,.6);
  }
  .nav-links.open{transform:none}
  .nav-links a.nlink{color:var(--text-paper-soft);width:100%;padding:16px 0;border-bottom:1px solid var(--line-paper);font-size:1.05rem}
  .nav-links .nav-cta{margin:18px 0 0;width:100%;justify-content:center}
  .burger{display:flex}
  .grid-outcomes{grid-template-columns:1fr 1fr}
  .pillars{grid-template-columns:1fr}
  .who{grid-template-columns:1fr;gap:28px}
  .contact-grid{grid-template-columns:1fr}
  .shift{grid-template-columns:1fr;text-align:left;gap:8px}
  .shift .to{text-align:left}
  .shift .arr{transform:rotate(90deg)}
}
@media(max-width:560px){
  body{font-size:16px}
  .grid-outcomes{grid-template-columns:1fr}
  .member{grid-template-columns:1fr;gap:20px}
  .mono-av{width:84px;height:84px;font-size:1.6rem}
  .foot-top{grid-template-columns:1fr}
  .hero-flow{font-size:.7rem}
}

/* =========================================================
   DECORATIVE GRAPHICS (custom SVG, no external assets)
   ========================================================= */

/* --- subtle film grain for atmosphere --- */
body::after{
  content:"";position:fixed;inset:0;pointer-events:none;z-index:45;opacity:.05;
  mix-blend-mode:soft-light;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='140' height='140'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
  background-size:140px 140px;
}

/* --- hero signal art (home) --- */
.hero-art{
  position:absolute;z-index:1;pointer-events:none;
  right:max(var(--gut),calc((100vw - var(--maxw)) / 2 + var(--gut)));
  top:50%;transform:translateY(-50%);
  width:min(46%,520px);height:auto;
}
@media(max-width:1080px){.hero-art{display:none}}
.ha-curve{stroke-dasharray:1;stroke-dashoffset:1;animation:haDraw 2s var(--ease) .5s forwards}
.ha-area{opacity:0;animation:haFade 1.3s var(--ease) 1.5s forwards}
.ha-dot{opacity:.5;transform-box:fill-box;transform-origin:center;animation:haTwinkle 4.5s ease-in-out infinite}
.ha-dots .ha-dot:nth-child(2n){animation-duration:5.6s;animation-delay:.6s}
.ha-dots .ha-dot:nth-child(3n){animation-delay:1.4s}
.ha-dots .ha-dot:nth-child(4n){animation-delay:2.2s;animation-duration:6s}
.ha-dots .ha-dot:nth-child(5n){animation-delay:.9s}
.ha-node{transform-box:fill-box;transform-origin:center;animation:haNodePulse 3.2s ease-in-out 2.2s infinite}
.ha-node-glow{transform-box:fill-box;transform-origin:center;animation:haGlow 3.2s ease-in-out 2.2s infinite}

/* --- interior page-hero art (rising performance bars) --- */
.phero-art{
  position:absolute;z-index:1;pointer-events:none;
  right:max(var(--gut),calc((100vw - var(--maxw)) / 2 + var(--gut)));
  bottom:clamp(-8px,0vw,16px);
  width:min(40%,360px);height:auto;
}
@media(max-width:980px){.phero-art{display:none}}
.pa-bar{transform-box:fill-box;transform-origin:bottom;transform:scaleY(0);animation:paGrow .85s var(--ease) forwards}
.pa-bar:nth-of-type(1){animation-delay:.30s}
.pa-bar:nth-of-type(2){animation-delay:.42s}
.pa-bar:nth-of-type(3){animation-delay:.54s}
.pa-bar:nth-of-type(4){animation-delay:.66s}
.pa-bar:nth-of-type(5){animation-delay:.78s}
.pa-bar:nth-of-type(6){animation-delay:.90s}
.pa-bar:nth-of-type(7){animation-delay:1.02s}
.pa-cap{transform-box:fill-box;transform-origin:center;animation:haGlow 3s ease-in-out 1.4s infinite}

/* --- four-pillars hub diagram (approach) --- */
.pillar-system{display:block;width:100%;max-width:520px;height:auto;margin:0 auto clamp(40px,6vw,66px);position:relative;z-index:2}
.ps-num{font-family:"IBM Plex Mono",monospace;font-size:13px;fill:var(--gold);letter-spacing:1px}
.ps-name{font-family:"Hanken Grotesk",sans-serif;font-size:12px;font-weight:600;fill:#F4EFE4}
.ps-hub-label{font-family:"Fraunces",serif;font-size:16px;fill:#D8A63F;letter-spacing:1.5px}
.ps-hub-sub{font-family:"IBM Plex Mono",monospace;font-size:9px;fill:#B7BBC4;letter-spacing:2.5px}
.ps-link{stroke-dasharray:1;stroke-dashoffset:1}
.ps-node{opacity:0;transform-box:fill-box;transform-origin:center}
.ps-hub{transform-box:fill-box;transform-origin:center}
.ps-reveal.in .ps-link{animation:haDraw 1s var(--ease) forwards}
.ps-reveal.in .ps-link:nth-of-type(1){animation-delay:.10s}
.ps-reveal.in .ps-link:nth-of-type(2){animation-delay:.22s}
.ps-reveal.in .ps-link:nth-of-type(3){animation-delay:.34s}
.ps-reveal.in .ps-link:nth-of-type(4){animation-delay:.46s}
.ps-reveal.in .ps-node{animation:psNodeIn .55s var(--ease) forwards}
.ps-reveal.in .ps-node:nth-of-type(1){animation-delay:.5s}
.ps-reveal.in .ps-node:nth-of-type(2){animation-delay:.62s}
.ps-reveal.in .ps-node:nth-of-type(3){animation-delay:.74s}
.ps-reveal.in .ps-node:nth-of-type(4){animation-delay:.86s}
.ps-reveal.in .ps-hub{animation:psPulse 3.6s ease-in-out 1s infinite}

@keyframes haDraw{to{stroke-dashoffset:0}}
@keyframes haFade{to{opacity:1}}
@keyframes haTwinkle{0%,100%{opacity:.22}50%{opacity:.72}}
@keyframes haGlow{0%,100%{opacity:.4;transform:scale(.9)}50%{opacity:.95;transform:scale(1.15)}}
@keyframes haNodePulse{0%,100%{transform:scale(1)}50%{transform:scale(1.16)}}
@keyframes paGrow{to{transform:scaleY(1)}}
@keyframes psNodeIn{from{opacity:0;transform:scale(.6)}to{opacity:1;transform:scale(1)}}
@keyframes psPulse{0%,100%{transform:scale(1)}50%{transform:scale(1.04)}}

@media (prefers-reduced-motion:reduce){
  .ha-curve,.ps-link{stroke-dashoffset:0!important}
  .ha-area,.ps-node{opacity:1!important}
  .pa-bar{transform:none!important}
}

/* ---------- accordion (outcomes) ---------- */
.acc{border-top:1px solid var(--line)}
.acc-item{border-bottom:1px solid var(--line)}
.acc-head{
  width:100%;display:flex;align-items:center;gap:clamp(14px,2.4vw,26px);
  background:none;border:0;cursor:pointer;text-align:left;color:var(--text);
  font-family:inherit;padding:clamp(20px,2.6vw,28px) 2px;
  transition:padding-left .3s var(--ease);
}
.acc-head:hover{padding-left:12px}
.acc-head:focus-visible{outline:2px solid var(--gold);outline-offset:3px;border-radius:3px}
.acc-num{font-family:"IBM Plex Mono",monospace;font-size:.74rem;letter-spacing:.16em;color:var(--gold);flex:none;width:2.6em;padding-top:.15em}
.acc-ico{width:24px;height:24px;color:var(--teal);flex:none;transition:transform .3s var(--ease)}
.acc-item.open .acc-ico{transform:scale(1.06)}
.acc-title{flex:1;font-family:"Fraunces",serif;font-weight:450;font-size:clamp(1.18rem,2vw,1.55rem);line-height:1.12;letter-spacing:-.01em;color:var(--text);transition:color .25s}
.acc-head:hover .acc-title,.acc-item.open .acc-title{color:var(--teal)}
.acc-toggle{position:relative;flex:none;width:30px;height:30px;border:1px solid var(--line-strong);border-radius:50%;transition:background .3s var(--ease),border-color .3s,transform .3s var(--ease)}
.acc-head:hover .acc-toggle{border-color:var(--gold)}
.acc-toggle::before,.acc-toggle::after{content:"";position:absolute;top:50%;left:50%;width:11px;height:1.6px;background:var(--text);transform:translate(-50%,-50%);transition:transform .35s var(--ease),opacity .3s,background .3s}
.acc-toggle::after{transform:translate(-50%,-50%) rotate(90deg)}
.acc-item.open .acc-toggle{background:var(--gold);border-color:var(--gold);transform:rotate(180deg)}
.acc-item.open .acc-toggle::before{background:var(--ink)}
.acc-item.open .acc-toggle::after{opacity:0}
.acc-panel{display:grid;grid-template-rows:0fr;transition:grid-template-rows .4s var(--ease)}
.acc-item.open .acc-panel{grid-template-rows:1fr}
.acc-inner{overflow:hidden;min-height:0}
.acc-inner p{
  margin:0;padding:0 clamp(8px,2vw,30px) clamp(22px,3vw,30px) clamp(48px,8.5vw,112px);
  color:var(--text-soft);font-size:1.04rem;line-height:1.62;max-width:74ch;
}
@media(max-width:560px){
  .acc-ico{display:none}
  .acc-inner p{padding-left:clamp(36px,11vw,48px)}
}

/* =========================================================
   CASE STUDIES
   ========================================================= */
/* index cards */
.cs-cards{display:grid;gap:clamp(22px,3vw,34px)}
.cs-card{
  display:grid;grid-template-columns:minmax(0,440px) 1fr;gap:clamp(24px,4vw,56px);align-items:center;
  background:var(--paper);border:1px solid var(--line);border-radius:var(--r);
  padding:clamp(22px,3vw,38px);transition:transform .35s var(--ease),border-color .3s,box-shadow .35s;
}
.cs-card:hover{transform:translateY(-4px);border-color:var(--line-strong);box-shadow:0 26px 60px -36px rgba(15,22,32,.5)}
.cs-thumb{border-radius:var(--r);overflow:hidden;background:var(--ink);aspect-ratio:16/11;width:100%}
.cs-thumb svg{display:block;width:100%;height:100%}
.cs-tag{font-family:"IBM Plex Mono",monospace;font-size:.7rem;letter-spacing:.18em;text-transform:uppercase;color:var(--gold)}
.cs-card h3{font-family:"Fraunces",serif;font-weight:450;font-size:clamp(1.4rem,2.4vw,2rem);letter-spacing:-.01em;margin:12px 0;line-height:1.07}
.cs-card .cs-sum{color:var(--text-soft);font-size:1.02rem}
.cs-hi{list-style:none;margin:18px 0 22px;display:grid;gap:9px}
.cs-hi li{position:relative;padding-left:22px;color:var(--text);font-size:.97rem}
.cs-hi li::before{content:"";position:absolute;left:0;top:.5em;width:8px;height:8px;border:1.5px solid var(--teal);border-radius:50%}
.cs-link{display:inline-flex;align-items:center;gap:.6em;font-weight:600;color:var(--gold);font-size:.98rem}
.cs-link .arrow{transition:transform .3s var(--ease)}
.cs-card:hover .cs-link .arrow{transform:translateX(5px)}
@media(max-width:820px){.cs-card{grid-template-columns:1fr}}

/* result line in hero */
.cs-result{border-left:2px solid var(--gold);padding:4px 0 4px 16px;color:var(--text-paper-soft);max-width:58ch;margin-top:26px}
.cs-result b{color:var(--paper)}

/* numbered grid */
.num-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1px;background:var(--line);border:1px solid var(--line);border-radius:var(--r);overflow:hidden}
.num-grid.cols-3{grid-template-columns:repeat(3,1fr)}
.num-cell{background:var(--paper);padding:clamp(22px,2.8vw,34px);transition:background .3s}
.num-cell:hover{background:var(--paper-2)}
.num-cell .nn{font-family:"IBM Plex Mono",monospace;font-size:.78rem;letter-spacing:.18em;color:var(--gold)}
.num-cell h4{font-family:"Fraunces",serif;font-weight:460;font-size:clamp(1.12rem,1.8vw,1.4rem);letter-spacing:-.01em;margin:13px 0 8px}
.num-cell p{color:var(--text-soft);font-size:.97rem;line-height:1.55}
@media(max-width:760px){.num-grid,.num-grid.cols-3{grid-template-columns:1fr}}

/* two-column lists */
.cs-two{display:grid;grid-template-columns:1fr 1fr;gap:clamp(28px,5vw,64px)}
@media(max-width:760px){.cs-two{grid-template-columns:1fr}}
.cs-two h3{font-family:"Fraunces",serif;font-weight:460;font-size:clamp(1.2rem,2vw,1.55rem);letter-spacing:-.01em;margin-bottom:6px}
.cs-list{list-style:none;display:grid;gap:11px;margin-top:14px}
.cs-list li{position:relative;padding-left:24px;color:var(--text-soft)}
.cs-list li::before{content:"";position:absolute;left:0;top:.62em;width:11px;height:1.5px;background:var(--gold)}

/* stats */
.stats{display:grid;grid-template-columns:repeat(2,1fr);gap:clamp(20px,3vw,44px)}
.stat{border-top:2px solid var(--gold);padding-top:18px}
.stat .fig{font-family:"Fraunces",serif;font-weight:480;font-size:clamp(2.6rem,6vw,4.4rem);line-height:1;letter-spacing:-.02em;color:var(--gold-bright)}
.stat .cap{margin-top:10px;color:var(--text-paper-soft);font-size:1rem;max-width:28ch}
@media(max-width:560px){.stats{grid-template-columns:1fr}}

/* quote */
.cs-quote{border-left:2px solid var(--gold);padding-left:clamp(20px,3vw,36px);max-width:64ch}
.cs-quote blockquote{font-family:"Fraunces",serif;font-weight:400;font-size:clamp(1.25rem,2.2vw,1.8rem);line-height:1.34;letter-spacing:-.01em;color:var(--text)}
.band .cs-quote blockquote{color:var(--paper)}
.cs-quote .by{margin-top:24px;display:flex;align-items:center;gap:14px}
.cs-quote .by .av{width:48px;height:48px;border-radius:50%;flex:none;display:grid;place-items:center;font-family:"Fraunces",serif;font-size:1.05rem;color:var(--paper);background:linear-gradient(150deg,var(--ink-2),var(--ink));box-shadow:inset 0 0 0 1px var(--line-strong)}
.band .cs-quote .by .av{box-shadow:inset 0 0 0 1px var(--line-paper)}
.cs-quote .by .nm{font-weight:700}
.band .cs-quote .by .nm{color:var(--paper)}
.cs-quote .by .rl{font-family:"IBM Plex Mono",monospace;font-size:.72rem;letter-spacing:.12em;text-transform:uppercase;color:var(--gold);margin-top:3px}

/* roadmap stepper */
.roadmap{display:grid;grid-template-columns:repeat(4,1fr);gap:0;position:relative}
.rm-line{position:absolute;left:7px;right:7px;top:34px;height:1px;background:var(--line-strong)}
.rm-phase{padding-right:clamp(14px,2vw,28px);position:relative;z-index:1}
.rm-phase .rmn{font-family:"IBM Plex Mono",monospace;font-size:.74rem;letter-spacing:.16em;color:var(--gold)}
.rm-dot{width:14px;height:14px;border-radius:50%;background:var(--paper);border:2px solid var(--gold);margin:12px 0 18px}
.rm-phase h4{font-family:"Fraunces",serif;font-weight:460;font-size:1.1rem;letter-spacing:-.01em;margin-bottom:7px}
.rm-phase p{color:var(--text-soft);font-size:.93rem;line-height:1.5}
@media(max-width:760px){.roadmap{grid-template-columns:1fr;gap:22px}.rm-line{display:none}.rm-dot{margin:10px 0 12px}}

/* small link-card (related case study) */
.cs-related{display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:18px;
  border:1px solid var(--line);border-radius:var(--r);padding:clamp(22px,3vw,34px);background:var(--paper);transition:border-color .3s,transform .3s}
.cs-related:hover{border-color:var(--line-strong);transform:translateY(-3px)}
.cs-related .ct{max-width:60ch}
.cs-related h4{font-family:"Fraunces",serif;font-weight:460;font-size:clamp(1.2rem,2vw,1.55rem);letter-spacing:-.01em;margin-bottom:6px}
.cs-related p{color:var(--text-soft);font-size:.97rem}

/* measured-results layout (QA case study) */
.cs-results-grid{display:grid;grid-template-columns:1.6fr 1fr;gap:clamp(30px,5vw,64px);align-items:center}
.cs-chart{width:100%;border:1px solid var(--line-paper);border-radius:var(--r);padding:clamp(12px,2vw,22px);background:rgba(244,239,228,.02)}
.cs-chart svg{display:block;width:100%;height:auto}
@media(max-width:760px){.cs-results-grid{grid-template-columns:1fr}}

/* =========================================================
   WHO WE ARE + TESTIMONIALS
   ========================================================= */
/* interview Q&A */
.qa{display:grid;gap:0;border-top:1px solid var(--line)}
.qa-item{padding:clamp(24px,3.5vw,40px) 0;border-bottom:1px solid var(--line)}
.qa-q{display:flex;gap:16px;align-items:baseline}
.qa-q .ql{font-family:"IBM Plex Mono",monospace;font-size:.8rem;letter-spacing:.16em;color:var(--gold);flex:none;width:2.2em;padding-top:.3em}
.qa-q h3{font-family:"Fraunces",serif;font-weight:450;font-size:clamp(1.22rem,2.3vw,1.8rem);letter-spacing:-.01em;line-height:1.12}
.qa-a{margin:14px 0 0 calc(16px + 2.2em);color:var(--text-soft);font-size:1.05rem;line-height:1.62;max-width:66ch}
@media(max-width:560px){.qa-a{margin-left:0}}

/* story / history */
.story{display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(32px,6vw,80px);align-items:start}
@media(max-width:1024px){.story{grid-template-columns:1fr}}
.story .prose p{font-size:1.08rem;line-height:1.7;color:var(--text-soft);margin-bottom:18px}
.story .prose p strong{color:var(--text);font-weight:600}
.band .story .prose p{color:var(--text-paper-soft)}
.band .story .prose p strong{color:var(--paper)}
.timeline{border-left:2px solid var(--line-strong);padding-left:0;margin-top:6px}
.band .timeline{border-left-color:var(--line-paper)}
.tl{position:relative;padding:0 0 26px 28px}
.tl:last-child{padding-bottom:0}
.tl::before{content:"";position:absolute;left:-7px;top:3px;width:12px;height:12px;border-radius:50%;background:var(--paper);border:2px solid var(--gold)}
.band .tl::before{background:var(--ink)}
.tl .ty{font-family:"IBM Plex Mono",monospace;font-size:.74rem;letter-spacing:.16em;color:var(--gold)}
.tl h4{font-family:"Fraunces",serif;font-weight:460;font-size:1.16rem;margin:6px 0 5px;letter-spacing:-.01em}
.band .tl h4{color:var(--paper)}
.tl p{font-size:.97rem;color:var(--text-soft);margin:0;line-height:1.55}
.band .tl p{color:var(--text-paper-soft)}

/* differentiator cards */
.diff{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(20px,2.5vw,34px)}
@media(max-width:760px){.diff{grid-template-columns:1fr}}
.diff-card{border-top:2px solid var(--gold);padding-top:24px}
.diff-card .di{width:34px;height:34px;color:var(--teal);margin-bottom:16px}
.diff-card h3{font-family:"Fraunces",serif;font-weight:460;font-size:clamp(1.3rem,2vw,1.6rem);letter-spacing:-.01em;margin-bottom:10px}
.diff-card p{color:var(--text-soft);font-size:1rem;line-height:1.6}

/* testimonials grid (home) */
.tgrid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(20px,3vw,32px)}
@media(max-width:760px){.tgrid{grid-template-columns:1fr}}
.tcard{background:var(--paper);border:1px solid var(--line);border-radius:var(--r);padding:clamp(26px,3vw,40px);display:flex;flex-direction:column;transition:transform .35s var(--ease),border-color .3s,box-shadow .35s}
.tcard:hover{transform:translateY(-3px);border-color:var(--line-strong);box-shadow:0 22px 50px -34px rgba(15,22,32,.5)}
.tcard blockquote{font-family:"Fraunces",serif;font-weight:400;font-size:clamp(1.1rem,1.7vw,1.38rem);line-height:1.42;letter-spacing:-.01em;color:var(--text);flex:1}
.tcard .by{margin-top:22px;display:flex;align-items:center;gap:13px}
.tcard .by .av{width:44px;height:44px;border-radius:50%;flex:none;display:grid;place-items:center;font-family:"Fraunces",serif;color:var(--paper);background:linear-gradient(150deg,var(--ink-2),var(--ink));box-shadow:inset 0 0 0 1px var(--line-strong);font-size:1rem}
.tcard .by .nm{font-weight:700;font-size:.97rem}
.tcard .by .rl{font-family:"IBM Plex Mono",monospace;font-size:.67rem;letter-spacing:.1em;text-transform:uppercase;color:var(--gold);margin-top:3px}
.tcard .src{margin-top:16px;font-size:.9rem;font-weight:600;color:var(--gold);display:inline-flex;align-items:center;gap:.5em}
.tcard:hover .src .arrow{transform:translateX(4px)}
.tcard .src .arrow{transition:transform .3s var(--ease)}

/* draft placeholder note */
.draft-note{display:inline-block;font-family:"IBM Plex Mono",monospace;font-size:.68rem;letter-spacing:.14em;text-transform:uppercase;color:var(--ink);background:var(--gold);padding:.3em .7em;border-radius:100px;margin-bottom:10px}

/* ---------- home brand bar (compact name + tagline) ---------- */
.ppp-strip{background:var(--ink-2);border-block:1px solid var(--line-paper)}
.ppp-strip .wrap{display:flex;align-items:center;justify-content:center;flex-wrap:wrap;gap:clamp(14px,2.5vw,34px);padding-block:clamp(22px,3.2vw,34px)}
.ppp-strip-name{font-family:"Fraunces",serif;font-weight:500;font-size:clamp(1.2rem,2vw,1.55rem);letter-spacing:-.01em;color:var(--paper)}
.ppp-strip-sep{width:1px;height:26px;background:var(--line-paper)}
.ppp-strip-tag{font-family:"Fraunces",serif;font-weight:460;font-size:clamp(1.15rem,2vw,1.5rem);letter-spacing:-.01em;color:var(--paper);display:inline-flex;align-items:center;gap:.34em}
.ppp-strip-tag i{color:var(--gold);font-style:normal;font-size:.7em;transform:translateY(-.05em)}
.ppp-strip-tag em{font-style:italic;color:var(--gold);font-weight:430}
@media(max-width:560px){.ppp-strip-sep{display:none}}
