/* ── TOKENS ─────────────────────────────────────────────── */
:root{
  --ink:#08080F;
  --ink2:#0F0F1C;
  --ink3:#171726;
  --ink4:#1F1F32;
  --paper:#EDEDF2;
  --paper-dim:rgba(237,237,242,.72);
  --paper-faint:rgba(237,237,242,.42);
  --rule:rgba(237,237,242,.08);
  --rule-mid:rgba(237,237,242,.12);
  --charge:#DD2818;
  --charge-dim:rgba(221,40,24,.12);
  --charge-glow:rgba(221,40,24,.18);
  --glass:rgba(237,237,242,.04);
  --glass-border:rgba(237,237,242,.09);
  --f-display:-apple-system,BlinkMacSystemFont,'Helvetica Neue',Arial,sans-serif;
  --f-mono:'Courier New',Courier,monospace;
  --ease:.32s cubic-bezier(.16,1,.3,1);
  --radius:6px;
  --radius-lg:14px;
}

/* ── RESET ───────────────────────────────────────────────── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{font-size:16px;scroll-behavior:smooth}
body{
  font-family:var(--f-display);
  background:var(--ink);
  color:var(--paper);
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
a{text-decoration:none;color:inherit}
button{border:none;background:none;font:inherit;color:inherit;cursor:pointer}

/* ── NOISE OVERLAY ───────────────────────────────────────── */
#noise{
  position:fixed;inset:0;pointer-events:none;z-index:9990;
  opacity:.028;mix-blend-mode:screen;
}

/* ── NAV ─────────────────────────────────────────────────── */
nav{
  position:fixed;top:0;left:0;right:0;z-index:500;
  padding:1.5rem 0;
  transition:padding var(--ease),background var(--ease),backdrop-filter var(--ease);
}
nav.scrolled{
  padding:1rem 0;
  background:rgba(8,8,15,.88);
  backdrop-filter:blur(20px);
  -webkit-backdrop-filter:blur(20px);
  border-bottom:1px solid var(--rule);
}
.nav-i{
  display:flex;align-items:center;justify-content:space-between;
  max-width:1360px;margin:0 auto;padding:0 2.5rem;
}
.logo{display:flex;align-items:center}
.logo-img{height:52px;width:auto;display:block}
.ft-logo{height:44px;width:auto;display:block;margin-bottom:1.25rem}
.nav-links{display:flex;align-items:center;gap:2rem;list-style:none}
.nav-links a{
  font-size:.78rem;letter-spacing:.05em;text-transform:uppercase;
  color:var(--paper-dim);transition:color .2s;
}
.nav-links a:hover{color:var(--paper)}
.nav-cta{
  font-size:.78rem;font-weight:600;letter-spacing:.05em;text-transform:uppercase;
  padding:.6rem 1.4rem;border:1px solid var(--rule-mid);
  color:var(--paper);border-radius:var(--radius);
  transition:background .2s,border-color .2s,color .2s;
}
.nav-cta:hover{border-color:var(--charge);background:var(--charge-dim);color:var(--paper)}

/* ── HERO ────────────────────────────────────────────────── */
#hero{
  min-height:100svh;display:flex;flex-direction:column;
  justify-content:center;padding:140px 0 6rem;
  position:relative;overflow:hidden;
}
.hero-wrap{max-width:1360px;margin:0 auto;padding:0 2.5rem;width:100%}
.hero-content{
  display:grid;grid-template-columns:1fr 1fr;
  gap:4rem;align-items:center;
}
.hero-eyebrow{
  font-family:var(--f-mono);font-size:.75rem;letter-spacing:.1em;
  text-transform:uppercase;color:var(--paper-faint);
  display:flex;align-items:center;gap:.75rem;
  margin-bottom:2rem;
}
.hero-eyebrow::before{content:'';width:20px;height:1px;background:var(--charge);display:inline-block}
.hero-headline{
  font-size:clamp(2.8rem,5.5vw,6.5rem);font-weight:700;
  letter-spacing:-.04em;line-height:.96;margin-bottom:2rem;
  text-wrap:balance;
}
.hero-headline em{font-style:normal;color:var(--charge)}
.hero-desc{
  font-family:var(--f-display);font-size:1rem;
  color:var(--paper-dim);max-width:440px;line-height:1.75;
  margin-bottom:2.5rem;
}
.hero-actions{display:flex;gap:1rem;align-items:center;flex-wrap:wrap}

/* ── HERO VISUAL ─────────────────────────────────────────── */
.hero-visual{
  position:relative;height:480px;
  display:flex;align-items:center;justify-content:center;
}
.hero-dot-grid{
  position:absolute;inset:0;
  background-image:radial-gradient(circle,rgba(237,237,242,.1) 1px,transparent 1px);
  background-size:28px 28px;
  -webkit-mask-image:radial-gradient(ellipse 80% 80% at 50% 50%,black 30%,transparent 75%);
  mask-image:radial-gradient(ellipse 80% 80% at 50% 50%,black 30%,transparent 75%);
}
.hero-glow{
  position:absolute;border-radius:50%;
  pointer-events:none;filter:blur(72px);
}
.hero-glow-1{
  width:320px;height:320px;
  background:rgba(221,40,24,.18);
  top:10%;left:20%;
  animation:glow-drift 7s ease-in-out infinite alternate;
}
.hero-glow-2{
  width:220px;height:220px;
  background:rgba(80,60,200,.12);
  bottom:15%;right:15%;
  animation:glow-drift 9s ease-in-out infinite alternate-reverse;
}
@keyframes glow-drift{
  from{transform:translate(0,0) scale(1)}
  to{transform:translate(18px,-12px) scale(1.06)}
}
.hero-card{
  position:relative;z-index:2;
  background:rgba(23,23,38,.85);
  backdrop-filter:blur(20px);
  -webkit-backdrop-filter:blur(20px);
  border:1px solid var(--glass-border);
  border-radius:var(--radius-lg);
  padding:1.75rem;
  width:260px;
}
.hero-card-sm{
  position:absolute;bottom:10%;left:5%;
  width:200px;padding:1.25rem;
  background:rgba(15,15,28,.9);
}
.hero-card-label{
  font-family:var(--f-mono);font-size:.65rem;letter-spacing:.1em;
  text-transform:uppercase;color:var(--paper-faint);margin-bottom:.75rem;
}
.hero-card-metric{
  font-size:2.8rem;font-weight:700;letter-spacing:-.04em;line-height:1;
  color:var(--paper);margin-bottom:.4rem;
}
.hero-card-metric-sm{font-size:1.75rem}
.hero-card-sub{
  font-size:.825rem;color:var(--paper-dim);line-height:1.4;
}
.hero-card-divider{height:1px;background:var(--rule);margin:1.25rem 0}
.hero-card-tags{display:flex;flex-wrap:wrap;gap:.375rem}
.hero-card-tags span{
  font-family:var(--f-mono);font-size:.62rem;letter-spacing:.06em;
  text-transform:uppercase;padding:.3rem .65rem;
  border:1px solid var(--rule-mid);border-radius:4px;
  color:var(--paper-dim);
}

/* ── BUTTONS ─────────────────────────────────────────────── */
.btn{
  display:inline-flex;align-items:center;gap:.5rem;
  font-size:.78rem;font-weight:600;letter-spacing:.05em;text-transform:uppercase;
  padding:.8rem 1.75rem;border-radius:var(--radius);
  transition:all .2s var(--ease);
}
.btn-solid{background:var(--paper);color:var(--ink)}
.btn-solid:hover{background:var(--charge);color:#fff}
.btn-line{border:1px solid var(--rule-mid);color:var(--paper-dim)}
.btn-line:hover{border-color:var(--paper-dim);color:var(--paper)}
.btn-ghost{
  border:1px solid var(--charge-dim);color:var(--charge);
  background:var(--charge-dim);
}
.btn-ghost:hover{background:var(--charge);color:#fff;border-color:var(--charge)}

/* ── MARQUEE ─────────────────────────────────────────────── */
.marquee-wrap{
  overflow:hidden;
  border-top:1px solid var(--rule);
  border-bottom:1px solid var(--rule);
  padding:.85rem 0;
  background:var(--ink2);
}
.marquee-track{
  display:flex;gap:0;width:max-content;
  animation:roll 40s linear infinite;
  white-space:nowrap;
}
.marquee-track span{
  font-family:var(--f-mono);font-size:.72rem;letter-spacing:.06em;
  text-transform:uppercase;color:var(--paper-dim);
  padding:0 2.5rem;
}
.marquee-track .sep{color:var(--charge);padding:0;font-size:.6rem}
@keyframes roll{from{transform:translateX(0)}to{transform:translateX(-50%)}}
.marquee-wrap:hover .marquee-track{animation-play-state:paused}

/* ── SECTION LAYOUT ──────────────────────────────────────── */
.wrap{max-width:1360px;margin:0 auto;padding:0 2.5rem}
section{padding:8rem 0}
section.tight{padding:5rem 0}

/* ── MONO LABEL ─────────────────────────────────────────── */
.mlabel{
  font-family:var(--f-mono);font-size:.75rem;letter-spacing:.08em;
  text-transform:uppercase;color:var(--paper);
  display:inline-flex;align-items:center;gap:.75rem;
  margin-bottom:2rem;
}
.mlabel::before{content:'';width:20px;height:1px;background:currentColor;display:inline-block}

/* ── SECTION HEADER SHARED ───────────────────────────────── */
.section-header{display:flex;flex-wrap:wrap;margin-bottom:4rem;gap:0}
.section-header>.mlabel{flex:0 0 100%;margin-bottom:1.5rem}
.section-header h2{
  flex:0 0 100%;
  font-size:clamp(2rem,4vw,4rem);font-weight:700;
  letter-spacing:-.03em;line-height:1.05;text-wrap:balance;
  margin-bottom:1rem;
}
.section-header p{
  font-family:var(--f-display);font-size:.95rem;color:var(--paper-dim);
  max-width:520px;line-height:1.7;
}

/* ── DIVIDER ─────────────────────────────────────────────── */
#divider{
  position:relative;overflow:hidden;
  min-height:42vh;display:flex;align-items:center;
  background:#1A0A0A;
  border-top:1px solid var(--rule);border-bottom:1px solid var(--rule);
}
#divider2{
  position:relative;overflow:hidden;
  min-height:42vh;display:flex;align-items:center;
  background:#180A08;
  border-top:1px solid var(--rule);border-bottom:1px solid var(--rule);
}
.div-inner{max-width:1360px;margin:0 auto;padding:0 2.5rem;width:100%}
.div-statement{
  font-size:clamp(2.2rem,5vw,5.5rem);font-weight:700;
  letter-spacing:-.04em;line-height:1.05;text-wrap:balance;
  position:relative;z-index:1;
}
.div-statement em{font-style:normal;color:var(--charge)}

/* ── SERVICES ────────────────────────────────────────────── */
#services{padding:8rem 0}
.svc-header{display:flex;flex-wrap:wrap;margin-bottom:3rem;gap:0}
.svc-header>.mlabel{flex:0 0 100%;margin-bottom:1.5rem}
.svc-header h2{
  flex:0 0 100%;
  font-size:clamp(2rem,4vw,4rem);font-weight:700;
  letter-spacing:-.03em;line-height:1.05;text-wrap:balance;
  margin-bottom:1rem;
}
.svc-header p{
  font-family:var(--f-display);font-size:.95rem;color:var(--paper-dim);
  max-width:520px;line-height:1.7;
}

/* Pillar tabs */
.pillar-tabs{
  display:flex;gap:0;
  border:1px solid var(--rule);
  margin-bottom:0;
  overflow:hidden;
  border-radius:var(--radius);
}
.pillar-tab{
  flex:1;padding:1rem 1.25rem;
  font-family:var(--f-mono);font-size:.72rem;letter-spacing:.08em;
  text-transform:uppercase;color:var(--paper-dim);
  border-right:1px solid var(--rule);
  transition:background .2s,color .2s;
  position:relative;
}
.pillar-tab:last-child{border-right:none}
.pillar-tab:hover{background:var(--ink3);color:var(--paper)}
.pillar-tab.active{
  background:var(--ink3);color:var(--paper);
}
.pillar-tab.active::after{
  content:'';position:absolute;bottom:0;left:0;right:0;height:2px;
  background:var(--charge);
}

/* Pillar panels */
.pillar-panels{border:1px solid var(--rule);border-top:none}
.pillar-panel{display:none}
.pillar-panel.active{display:block}

.svc-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:0;
  border-top:none;
  border-left:1px solid var(--rule);
}
.svc-block{
  padding:2.5rem;
  display:flex;flex-direction:column;gap:1.25rem;
  border-right:1px solid var(--rule);
  border-bottom:1px solid var(--rule);
  transition:background .2s;
}
.svc-block:hover{background:var(--ink3)}
.svc-block-idx{
  font-family:var(--f-mono);font-size:.68rem;letter-spacing:.08em;
  color:var(--paper-faint);
}
.svc-block-name{
  font-size:1.15rem;font-weight:700;
  letter-spacing:-.02em;line-height:1.2;
  transition:color .2s;
}
.svc-block:hover .svc-block-name{color:var(--charge)}
.svc-block-desc{
  font-family:var(--f-display);font-size:.875rem;color:var(--paper-dim);
  line-height:1.7;margin-top:auto;
}

/* ── PROCESS ─────────────────────────────────────────────── */
#process{background:var(--ink2);padding:8rem 0}
.proc-header{display:flex;flex-wrap:wrap;margin-bottom:4rem;gap:0}
.proc-header>.mlabel{flex:0 0 100%;margin-bottom:1.5rem}
.proc-header h2{
  flex:0 0 100%;
  font-size:clamp(2rem,4vw,4rem);font-weight:700;
  letter-spacing:-.03em;line-height:1.05;text-wrap:balance;
  margin-bottom:1rem;
}
.proc-header p{font-family:var(--f-display);font-size:.95rem;color:var(--paper-dim);line-height:1.7;max-width:520px;}

.proc-track{
  display:grid;grid-template-columns:repeat(6,1fr);
  gap:0;border-top:1px solid var(--rule);border-left:1px solid var(--rule);
}
.proc-step{
  padding:2rem 1.75rem;border-right:1px solid var(--rule);border-bottom:1px solid var(--rule);
  position:relative;transition:background .2s;
}
.proc-step:hover{background:var(--ink3)}
.proc-step-num{
  font-family:var(--f-mono);font-size:.65rem;letter-spacing:.08em;
  text-transform:uppercase;color:var(--paper);margin-bottom:2.5rem;
}
.proc-step-title{
  font-size:1.1rem;font-weight:700;letter-spacing:-.02em;
  color:var(--paper);margin-bottom:.625rem;
}
.proc-step-desc{
  font-family:var(--f-display);font-size:.875rem;
  color:var(--paper-dim);line-height:1.65;
}
.proc-step:hover .proc-step-title{color:var(--charge)}

/* ── WORK ────────────────────────────────────────────────── */
#work{padding:8rem 0}
.work-header{display:flex;flex-wrap:wrap;margin-bottom:4rem;gap:0}
.work-header>.mlabel{flex:0 0 100%;margin-bottom:1.5rem}
.work-header h2{
  flex:0 0 100%;
  font-size:clamp(2rem,4vw,4rem);font-weight:700;
  letter-spacing:-.03em;line-height:1.05;text-wrap:balance;
  margin-bottom:1rem;
}
.work-header p{
  font-family:var(--f-display);font-size:.95rem;color:var(--paper-dim);
  max-width:520px;line-height:1.7;
}
.case-item{
  display:grid;grid-template-columns:1fr 1fr;
  border:1px solid var(--rule);margin-bottom:1.5rem;
  transition:border-color .2s;
}
.case-item:hover{border-color:var(--rule-mid)}
.case-visual{
  background:var(--ink2);min-height:360px;
  display:flex;align-items:flex-end;justify-content:flex-start;
  padding:2.5rem;position:relative;overflow:hidden;
}
.case-body{
  padding:2.5rem;display:flex;flex-direction:column;justify-content:space-between;
  background:var(--ink3);
}
.case-ind{
  font-family:var(--f-mono);font-size:.68rem;letter-spacing:.1em;
  text-transform:uppercase;color:var(--paper-faint);margin-bottom:1.25rem;display:block;
}
.case-title{
  font-size:clamp(1.25rem,2vw,1.75rem);font-weight:700;
  letter-spacing:-.02em;line-height:1.2;margin-bottom:1rem;text-wrap:balance;
}
.case-body p{
  font-size:.9rem;color:var(--paper-dim);line-height:1.72;margin-bottom:1.25rem;
}
.case-link{
  color:var(--paper);border-bottom:1px solid rgba(237,237,242,.2);
  transition:color .2s,border-color .2s;
}
.case-link:hover{color:var(--charge);border-color:var(--charge)}
.case-meta{
  display:grid;grid-template-columns:repeat(3,1fr);gap:1rem;
  padding-top:1.5rem;border-top:1px solid var(--rule);
}
.case-meta dt{
  font-family:var(--f-mono);font-size:.62rem;letter-spacing:.08em;
  text-transform:uppercase;color:var(--paper-faint);margin-bottom:.35rem;
}
.case-meta dd{font-size:.85rem;font-weight:600;color:var(--paper)}

/* ── WHY ─────────────────────────────────────────────────── */
#why{background:var(--ink2);padding:8rem 0}
.why-grid{
  display:grid;grid-template-columns:1fr 1fr;gap:6rem;align-items:start;
}
.why-left h2{
  font-size:clamp(2rem,4vw,4rem);font-weight:700;
  letter-spacing:-.03em;line-height:1.05;text-wrap:balance;margin-bottom:1.5rem;
}
.why-left p{font-size:.975rem;color:var(--paper-dim);line-height:1.75;margin-bottom:2rem}
.why-outcomes{
  display:grid;grid-template-columns:1fr 1fr;gap:2.5rem;align-items:start;
}
.why-col-label{
  font-family:var(--f-mono);font-size:.65rem;letter-spacing:.1em;
  text-transform:uppercase;color:var(--paper-faint);
  margin-bottom:1.25rem;padding-bottom:1rem;
  border-bottom:1px solid var(--rule);
}
.why-items{list-style:none;display:flex;flex-direction:column}
.why-items li{
  padding:.9rem 0;border-bottom:1px solid var(--rule);
  font-size:.925rem;line-height:1.4;
  display:flex;align-items:center;gap:.75rem;
}
.why-items-not li{color:var(--paper-faint);text-decoration:line-through;text-decoration-color:rgba(237,237,242,.15)}
.why-items-not li::before{content:'×';color:var(--paper-faint);font-size:.8rem;flex-shrink:0;text-decoration:none;display:inline-block}
.why-items-yes li{color:var(--paper);font-weight:500}
.why-items-yes li::before{content:'→';color:var(--charge);font-size:.8rem;flex-shrink:0}

/* ── PRICING ─────────────────────────────────────────────── */
#pricing{padding:8rem 0;background:var(--ink)}
.pricing-header{display:flex;flex-wrap:wrap;margin-bottom:4rem;gap:0}
.pricing-header>.mlabel{flex:0 0 100%;margin-bottom:1.5rem}
.pricing-header h2{
  flex:0 0 100%;
  font-size:clamp(2rem,4vw,4rem);font-weight:700;
  letter-spacing:-.03em;line-height:1.05;text-wrap:balance;
  margin-bottom:1rem;
}
.pricing-header p{
  font-family:var(--f-display);font-size:.95rem;color:var(--paper-dim);
  max-width:480px;line-height:1.7;
}
.pricing-grid{
  display:grid;grid-template-columns:repeat(3,1fr);
  gap:1.5rem;align-items:stretch;
}
.pricing-card{
  border:1px solid var(--rule);
  padding:2.5rem;
  display:flex;flex-direction:column;gap:0;
  transition:border-color .25s;
  border-radius:var(--radius-lg);
  background:var(--ink2);
}
.pricing-card:hover{border-color:var(--rule-mid)}
.pricing-featured{
  border-color:rgba(221,40,24,.35);
  background:linear-gradient(160deg,rgba(221,40,24,.06) 0%,var(--ink2) 60%);
  position:relative;
}
.pricing-featured:hover{border-color:rgba(221,40,24,.55)}
.pricing-badge{
  display:inline-flex;align-self:flex-start;
  font-family:var(--f-mono);font-size:.62rem;letter-spacing:.1em;
  text-transform:uppercase;color:var(--charge);
  background:var(--charge-dim);
  padding:.3rem .75rem;border-radius:4px;
  margin-bottom:1.5rem;
}
.pricing-tier{
  font-family:var(--f-mono);font-size:.72rem;letter-spacing:.1em;
  text-transform:uppercase;color:var(--paper-faint);
  margin-bottom:1rem;
}
.pricing-price{
  font-size:clamp(2.2rem,4vw,3.2rem);font-weight:700;
  letter-spacing:-.04em;line-height:1;color:var(--paper);
  margin-bottom:.5rem;
}
.pricing-timeline{
  font-family:var(--f-mono);font-size:.72rem;letter-spacing:.06em;
  text-transform:uppercase;color:var(--charge);
  margin-bottom:1.25rem;
}
.pricing-desc{
  font-size:.9rem;color:var(--paper-dim);line-height:1.65;
  padding-bottom:1.5rem;margin-bottom:1.5rem;
  border-bottom:1px solid var(--rule);
}
.pricing-features{
  list-style:none;display:flex;flex-direction:column;gap:.875rem;
  margin-bottom:2.5rem;flex:1;
}
.pricing-features li{
  font-size:.875rem;color:var(--paper-dim);line-height:1.4;
  display:flex;align-items:flex-start;gap:.75rem;
}
.pricing-features li::before{
  content:'→';color:var(--charge);font-size:.75rem;flex-shrink:0;margin-top:2px;
}
.pricing-cta{width:100%;justify-content:center;text-align:center;display:flex}

/* ── TESTIMONIALS ────────────────────────────────────────── */
#testimonials{padding:8rem 0;background:var(--ink2)}
.testimonials-header{display:flex;flex-wrap:wrap;margin-bottom:4rem;gap:0}
.testimonials-header>.mlabel{flex:0 0 100%;margin-bottom:1.5rem}
.testimonials-header h2{
  flex:0 0 100%;
  font-size:clamp(2rem,4vw,4rem);font-weight:700;
  letter-spacing:-.03em;line-height:1.05;text-wrap:balance;
}
.testimonials-grid{
  display:grid;grid-template-columns:repeat(3,1fr);
  gap:1.5rem;
}
.quote-card{
  background:var(--ink3);border:1px solid var(--rule);
  border-radius:var(--radius-lg);padding:2.25rem;
  display:flex;flex-direction:column;gap:1.5rem;
  transition:border-color .2s,transform .2s var(--ease);
}
.quote-card:hover{border-color:var(--rule-mid);transform:translateY(-3px)}
.quote-mark{
  font-size:3rem;line-height:1;color:var(--charge);
  font-family:Georgia,serif;opacity:.6;
}
.quote-text{
  font-size:.95rem;color:var(--paper);line-height:1.75;
  font-style:italic;flex:1;
}
.quote-author{
  display:flex;flex-direction:column;gap:.25rem;
  padding-top:1.25rem;border-top:1px solid var(--rule);
}
.quote-author-name{
  font-size:.875rem;font-weight:700;color:var(--paper);
}
.quote-author-role{
  font-family:var(--f-mono);font-size:.65rem;letter-spacing:.06em;
  text-transform:uppercase;color:var(--paper-faint);
}

/* ── ABOUT ───────────────────────────────────────────────── */
#about{background:var(--ink2);padding:8rem 0}
.about-header{display:flex;flex-wrap:wrap;margin-bottom:4rem;gap:0}
.about-header>.mlabel{flex:0 0 100%;margin-bottom:1.5rem}
.about-header h2{
  flex:0 0 100%;
  font-size:clamp(2rem,4vw,4rem);font-weight:700;
  letter-spacing:-.03em;line-height:1.05;text-wrap:balance;
  margin-bottom:1rem;
}
.about-header p{
  font-family:var(--f-display);font-size:.95rem;color:var(--paper-dim);
  max-width:520px;line-height:1.7;
}
.about-cols{
  display:grid;grid-template-columns:1fr 1fr;gap:4rem;
  border-top:1px solid var(--rule);padding-top:3rem;margin-bottom:3rem;
}
.about-col p{
  font-size:.975rem;color:var(--paper-dim);line-height:1.75;margin-bottom:1.25rem;
}
.about-col p:last-child{margin-bottom:0}
.about-family{border-top:1px solid var(--rule);padding-top:1.25rem;margin-top:1.5rem !important;font-size:.85rem !important;color:var(--paper-faint) !important}
.about-family strong{color:var(--paper);font-weight:600}
.about-family-link{border-bottom:1px solid rgba(237,237,242,.2);transition:border-color .2s,color .2s}
.about-family-link:hover{border-color:var(--charge)}
.about-family-link:hover strong{color:var(--charge)}
.about-pills{display:flex;flex-wrap:wrap;gap:.625rem;border-top:1px solid var(--rule);padding-top:2.5rem}
.pill{
  font-family:var(--f-mono);font-size:.68rem;letter-spacing:.06em;
  text-transform:uppercase;padding:.45rem 1rem;
  border:1px solid var(--rule);border-radius:4px;color:var(--paper-dim);
  transition:all .2s;
}
.pill:hover{border-color:var(--charge);color:var(--charge)}

/* ── FINAL CTA ───────────────────────────────────────────── */
#fcta{
  padding:10rem 0;
  background:var(--ink);border-top:1px solid var(--rule);
}
.fcta-headline{
  font-size:clamp(3rem,8vw,9rem);font-weight:700;
  letter-spacing:-.04em;line-height:.95;margin-bottom:3.5rem;
  text-wrap:balance;
}
.fcta-headline span{color:var(--charge)}
.fcta-sub{
  font-size:1rem;color:var(--paper-dim);
  line-height:1.7;max-width:440px;margin-bottom:3.5rem;
}
.fcta-actions{display:flex;gap:1rem;flex-wrap:wrap}

/* ── FOOTER ──────────────────────────────────────────────── */
footer{
  background:var(--ink);
  border-top:1px solid var(--rule);
  padding:4rem 0 2.5rem;
}
.ft-top{
  display:grid;grid-template-columns:2fr 1fr 1fr 1fr;
  gap:4rem;margin-bottom:4rem;
}
.ft-brand-desc{
  font-family:var(--f-display);font-size:.9rem;color:var(--paper-dim);
  line-height:1.7;max-width:260px;
}
.ft-col h4{
  font-family:var(--f-mono);font-size:.62rem;letter-spacing:.1em;
  text-transform:uppercase;color:var(--paper-faint);margin-bottom:1.5rem;
}
.ft-col ul{list-style:none;display:flex;flex-direction:column;gap:.75rem}
.ft-col ul a{
  font-size:.875rem;color:var(--paper-dim);
  transition:color .2s;
}
.ft-col ul a:hover{color:var(--paper)}
.ft-bottom{
  display:flex;justify-content:space-between;align-items:center;
  border-top:1px solid var(--rule);padding-top:2rem;flex-wrap:wrap;gap:1rem;
}
.ft-copy{
  font-family:var(--f-mono);font-size:.7rem;letter-spacing:.04em;
  color:var(--paper-faint);
}

/* ── REVEAL ──────────────────────────────────────────────── */
.rv{opacity:0;transform:translateY(24px);transition:opacity .75s var(--ease),transform .75s var(--ease)}
.rv.vis{opacity:1;transform:none}
.rv.d1{transition-delay:.1s}.rv.d2{transition-delay:.2s}.rv.d3{transition-delay:.3s}

/* ── RESPONSIVE ──────────────────────────────────────────── */
@media(max-width:1100px){
  .hero-content{grid-template-columns:1fr;gap:3rem}
  .hero-visual{display:none}
  .proc-track{grid-template-columns:repeat(3,1fr)}
  .case-item{grid-template-columns:1fr}
  .case-visual{min-height:260px}
  .why-grid{grid-template-columns:1fr;gap:3rem}
  .pricing-grid{grid-template-columns:1fr}
  .testimonials-grid{grid-template-columns:1fr}
  .ft-top{grid-template-columns:1fr 1fr}
  .svc-grid{grid-template-columns:repeat(2,1fr)}
}
@media(max-width:768px){
  .nav-links{display:none}
  section{padding:5rem 0}
  .hero-headline{letter-spacing:-.035em}
  .proc-track{grid-template-columns:repeat(2,1fr)}
  .ft-top{grid-template-columns:1fr;gap:2.5rem}
  .pillar-tabs{flex-wrap:wrap}
  .pillar-tab{flex:0 0 50%}
  .svc-grid{grid-template-columns:1fr}
}
@media(prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.01ms!important;transition-duration:.01ms!important}
  html{scroll-behavior:auto}
}
