:root{
  --ink:#0B0B0C;
  --ink-soft:#16161A;
  --paper:#FAFAF7;
  --paper-2:#F0EDE5;
  --red:#E8402A;
  --red-deep:#B82E1A;
  --steel:#6B6F76;
  --steel-light:#9A9DA3;
  --line:#E2DFD6;
  --line-dark:rgba(255,255,255,.14);
  --shadow:0 1px 0 rgba(11,11,12,.04);
  --radius:2px;
  --ff-display:'Fraunces', serif;
  --ff-body:'Inter', sans-serif;
  --ff-mono:'JetBrains Mono', monospace;
  --container:1180px;
}

*{box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{
  margin:0;
  font-family:var(--ff-body);
  background:var(--paper);
  color:var(--ink);
  -webkit-font-smoothing:antialiased;
  line-height:1.5;
}
img,svg{display:block;max-width:100%;}
a{color:inherit;text-decoration:none;}
ul{margin:0;padding:0;}
h1,h2,h3,h4{margin:0;font-family:var(--ff-display);font-weight:500;letter-spacing:-0.005em;}
p{margin:0;}
button{font-family:inherit;cursor:pointer;}

.wrap{
  width:100%;
  max-width:var(--container);
  margin:0 auto;
  padding:0 28px;
}

.mono-label{
  font-family:var(--ff-mono);
  font-size:.72rem;
  letter-spacing:.14em;
  text-transform:uppercase;
  color:var(--red);
  display:inline-flex;
  align-items:center;
  gap:8px;
}
.mono-label::before{
  content:'';
  width:6px;height:6px;
  background:var(--red);
  border-radius:50%;
  flex:none;
}

a:focus-visible, button:focus-visible{
  outline:2px solid var(--red);
  outline-offset:3px;
}

/* ---------- NAV ---------- */
header{
  position:fixed;
  top:0;left:0;right:0;
  z-index:100;
  padding:18px 0;
  transition:background .3s ease, padding .3s ease, border-color .3s ease;
  border-bottom:1px solid transparent;
  --hdr-text:var(--paper);
  --hdr-text-soft:#C9C7C2;
  --hdr-mark-edge:rgba(255,255,255,.16);
}
header.scrolled{
  background:rgba(250,250,247,.86);
  backdrop-filter:blur(10px);
  border-bottom:1px solid var(--line);
  padding:13px 0;
  --hdr-text:var(--ink);
  --hdr-text-soft:var(--steel);
  --hdr-mark-edge:rgba(11,11,12,.08);
}
nav{
  display:flex;
  align-items:center;
  justify-content:space-between;
}
.brand{
  display:flex;
  align-items:center;
  gap:11px;
}
.brand-mark{
  height:34px;
  display:flex;
  align-items:center;
  flex:none;
}
.mark-img{height:34px;width:auto;display:block;}
.brand-mark .mark-dark{display:none;}
.brand-mark .mark-light{display:block;}
header.scrolled .brand-mark .mark-dark{display:block;}
header.scrolled .brand-mark .mark-light{display:none;}
.brand-text{display:flex;flex-direction:column;line-height:1.1;}
.brand-text .name{
  font-family:var(--ff-display);
  font-weight:600;
  font-size:1.05rem;
  letter-spacing:-0.005em;
  color:var(--hdr-text);
}
.brand-text .name span{color:var(--red);}
.brand-text .sub{
  font-family:var(--ff-mono);
  font-size:.62rem;
  letter-spacing:.18em;
  color:var(--hdr-text-soft);
  text-transform:uppercase;
  margin-top:2px;
}
.nav-links{
  display:flex;
  align-items:center;
  gap:34px;
  list-style:none;
}
.nav-links a{
  font-size:.9rem;
  font-weight:500;
  color:var(--hdr-text);
  position:relative;
  padding:4px 0;
}
.nav-links a::after{
  content:'';
  position:absolute;
  left:0;bottom:0;
  width:0;height:1px;
  background:var(--red);
  transition:width .25s ease;
}
.nav-links a:hover::after, .nav-links a.active::after{width:100%;}

.btn{
  font-family:var(--ff-body);
  font-weight:600;
  font-size:.88rem;
  padding:11px 22px;
  border-radius:2px;
  border:1px solid var(--ink);
  background:var(--ink);
  color:var(--paper);
  display:inline-flex;
  align-items:center;
  gap:8px;
  transition:background .2s ease, color .2s ease, border-color .2s ease, transform .15s ease;
}
.btn:hover{background:var(--red);border-color:var(--red);transform:translateY(-1px);}
.btn-outline{
  background:transparent;
  color:var(--ink);
  border:1px solid var(--ink);
}
.btn-outline:hover{background:var(--ink);color:var(--paper);}
.btn-on-dark{border-color:var(--paper);background:var(--paper);color:var(--ink);}
.btn-on-dark:hover{background:var(--red);border-color:var(--red);color:var(--paper);}
.btn-outline-on-dark{border-color:rgba(255,255,255,.4);color:var(--paper);background:transparent;}
.btn-outline-on-dark:hover{border-color:var(--red);background:var(--red);}

.nav-toggle{
  display:none;
  flex-direction:column;
  gap:5px;
  background:none;
  border:none;
  padding:8px;
}
.nav-toggle span{width:22px;height:2px;background:var(--hdr-text);}

.nav-cta-mobile{display:none;}

.nav-cta{
  background:var(--paper);
  color:var(--ink);
  border-color:var(--paper);
}
.nav-cta:hover{background:var(--red);border-color:var(--red);color:var(--paper);}
header.scrolled .nav-cta{
  background:var(--ink);
  color:var(--paper);
  border-color:var(--ink);
}
header.scrolled .nav-cta:hover{background:var(--red);border-color:var(--red);}

/* ---------- HERO ---------- */
.hero{
  background:var(--ink);
  color:var(--paper);
  padding:168px 0 96px;
  position:relative;
  overflow:hidden;
}
.hero::before{
  content:'';
  position:absolute;
  inset:0;
  background-image:
    linear-gradient(rgba(255,255,255,.05) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,.05) 1px, transparent 1px);
  background-size:64px 64px;
  mask-image:radial-gradient(ellipse 90% 70% at 50% 0%, rgba(0,0,0,.9), transparent 75%);
  pointer-events:none;
}
.hero-inner{position:relative;z-index:1;}
.hero.hero-compact{padding:148px 0 76px;}
.hero .mono-label{color:var(--red);margin-bottom:22px;}
.hero h1{
  font-size:clamp(2.5rem, 1.4rem + 4vw, 4.4rem);
  line-height:1.04;
  max-width:880px;
}
.hero h1 em{color:var(--red);font-style:normal;}
.hero .lede{
  margin-top:26px;
  max-width:560px;
  font-size:1.08rem;
  color:#D7D6D2;
  line-height:1.6;
}
.hero-ctas{
  display:flex;
  gap:14px;
  margin-top:38px;
  flex-wrap:wrap;
}
.hero-banner{
  margin-top:64px;
  border:1px solid var(--line-dark);
  border-left:3px solid var(--red);
  background:rgba(255,255,255,.03);
  padding:22px 26px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:20px;
  flex-wrap:wrap;
}
.hero-banner p{
  font-family:var(--ff-display);
  font-size:1.02rem;
  font-weight:600;
  max-width:640px;
}
.hero-banner .tag{
  font-family:var(--ff-mono);
  font-size:.72rem;
  color:var(--steel-light);
  letter-spacing:.1em;
  text-transform:uppercase;
  white-space:nowrap;
}

section{padding:108px 0;}
.section-head{
  max-width:620px;
  margin-bottom:56px;
}
.section-head.center{margin-left:auto;margin-right:auto;text-align:center;}
.section-head .mono-label{margin-bottom:16px;}
.section-head h2{
  font-size:clamp(1.9rem, 1.2rem + 2vw, 2.7rem);
  line-height:1.12;
}
.section-head p{
  margin-top:16px;
  color:var(--steel);
  font-size:1.02rem;
  line-height:1.6;
}

/* ---------- STATS BAND ---------- */
.stats-band{background:var(--ink-soft);}
.stats-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:1px;
  background:var(--line-dark);
  border:1px solid var(--line-dark);
}
.stat{
  background:var(--ink-soft);
  padding:36px 28px;
  text-align:center;
}
.stat .num{
  font-family:var(--ff-display);
  font-size:2.6rem;
  font-weight:600;
  color:var(--paper);
}
.stat .num span{color:var(--red);}
.stat .label{
  margin-top:8px;
  font-family:var(--ff-mono);
  font-size:.74rem;
  letter-spacing:.1em;
  text-transform:uppercase;
  color:var(--steel-light);
}

/* ---------- PROCESS / PIPELINE (signature) ---------- */
.process{background:var(--paper);}
.pipeline{
  position:relative;
  margin-top:24px;
  padding-top:6px;
}
.pipeline-track{
  position:relative;
  height:2px;
  background:var(--line);
  margin:0 0 0 0;
}
.pipeline-track .cursor{
  position:absolute;
  top:50%;
  left:0;
  width:10px;height:10px;
  background:var(--red);
  border-radius:1px;
  transform:translate(-50%,-50%) rotate(45deg);
  animation:travel 9s linear infinite;
  box-shadow:0 0 0 6px rgba(232,64,42,.12);
}
@keyframes travel{
  0%{left:0%;}
  100%{left:100%;}
}
.pipeline-stages{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  margin-top:0;
}
.stage{
  position:relative;
  padding-top:28px;
  padding-right:24px;
}
.stage::before{
  content:'';
  position:absolute;
  top:-2px;left:0;
  width:10px;height:10px;
  border-radius:50%;
  background:var(--paper);
  border:2px solid var(--line);
  transform:translateY(-50%);
  animation:pulse 9s linear infinite;
}
.stage:nth-child(1)::before{animation-delay:0s;}
.stage:nth-child(2)::before{animation-delay:2.25s;}
.stage:nth-child(3)::before{animation-delay:4.5s;}
.stage:nth-child(4)::before{animation-delay:6.75s;}
@keyframes pulse{
  0%, 96%, 100%{border-color:var(--line);background:var(--paper);}
  2%, 10%{border-color:var(--red);background:var(--red);}
}
.stage .num{
  font-family:var(--ff-mono);
  font-size:.72rem;
  color:var(--red);
  letter-spacing:.08em;
}
.stage h4{
  font-size:1.05rem;
  margin-top:10px;
}
.stage p{
  margin-top:10px;
  font-size:.88rem;
  color:var(--steel);
  line-height:1.55;
}

/* ---------- WHY / FEATURES ---------- */
.why{background:var(--paper-2);}
.feature-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:1px;
  background:var(--line);
  border:1px solid var(--line);
}
.feature{
  background:var(--paper-2);
  padding:36px 32px;
  transition:background .2s ease;
}
.feature:hover{background:var(--paper);}
.feature .icon{
  width:38px;height:38px;
  color:var(--red);
  margin-bottom:20px;
}
.feature h3{font-size:1.08rem;}
.feature p{
  margin-top:10px;
  font-size:.9rem;
  color:var(--steel);
  line-height:1.6;
}

/* ---------- CARDS (services / case studies) ---------- */
.card-grid{
  display:grid;
  grid-template-columns:repeat(2,1fr);
  gap:20px;
}
.card{
  border:1px solid var(--line);
  background:var(--paper);
  padding:34px 30px;
  display:flex;
  flex-direction:column;
  gap:14px;
}
.card .badge{
  font-family:var(--ff-mono);
  font-size:.7rem;
  letter-spacing:.1em;
  text-transform:uppercase;
  color:var(--red);
}
.card h3{font-size:1.3rem;}
.card p{color:var(--steel);font-size:.95rem;line-height:1.6;}
.card .tags{display:flex;gap:8px;flex-wrap:wrap;margin-top:auto;}
.card .tags span{
  font-family:var(--ff-mono);
  font-size:.68rem;
  letter-spacing:.06em;
  text-transform:uppercase;
  padding:5px 9px;
  border:1px solid var(--line);
  color:var(--steel);
}

.case-figure{
  height:180px;
  background:linear-gradient(135deg, var(--ink) 0%, var(--ink-soft) 60%, var(--red-deep) 130%);
  position:relative;
  overflow:hidden;
}
.case-figure::after{
  content:'';
  position:absolute;
  inset:0;
  background-image:linear-gradient(rgba(255,255,255,.06) 1px, transparent 1px), linear-gradient(90deg, rgba(255,255,255,.06) 1px, transparent 1px);
  background-size:28px 28px;
}

/* ---------- CHIPS (platforms) ---------- */
.chip-row{display:flex;gap:12px;flex-wrap:wrap;}
.chip{
  font-family:var(--ff-mono);
  font-size:.78rem;
  letter-spacing:.06em;
  padding:10px 18px;
  border:1px solid var(--line);
  background:var(--paper);
}

/* ---------- QUOTE ---------- */
.quote{background:var(--ink);color:var(--paper);}
.quote blockquote{
  font-family:var(--ff-display);
  font-size:clamp(1.3rem,1rem + 1.4vw,2rem);
  line-height:1.4;
  max-width:840px;
  margin:0 auto;
  text-align:center;
}
.quote .cite{
  display:block;
  margin-top:24px;
  font-family:var(--ff-mono);
  font-size:.78rem;
  letter-spacing:.1em;
  text-transform:uppercase;
  color:var(--steel-light);
  text-align:center;
}

/* ---------- CONTACT ---------- */
.contact-grid{
  display:grid;
  grid-template-columns:1fr 1.2fr;
  gap:48px;
  align-items:start;
}
.contact-info{border:1px solid var(--line);padding:34px 30px;background:var(--paper-2);}
.contact-info h3{font-size:1.2rem;}
.contact-info .role{
  margin-top:6px;
  font-family:var(--ff-mono);
  font-size:.74rem;
  letter-spacing:.1em;
  text-transform:uppercase;
  color:var(--red);
}
.contact-info p{margin-top:16px;color:var(--steel);font-size:.95rem;line-height:1.6;}
.contact-detail{margin-top:24px;display:flex;flex-direction:column;gap:12px;}
.contact-detail div{display:flex;flex-direction:column;}
.contact-detail .k{font-family:var(--ff-mono);font-size:.68rem;letter-spacing:.1em;text-transform:uppercase;color:var(--steel-light);}
.contact-detail .v{margin-top:4px;font-size:.96rem;}

.form-group{margin-bottom:20px;}
.form-group label{
  display:block;
  font-family:var(--ff-mono);
  font-size:.72rem;
  letter-spacing:.08em;
  text-transform:uppercase;
  color:var(--steel);
  margin-bottom:8px;
}
.form-group input, .form-group textarea{
  width:100%;
  font-family:var(--ff-body);
  font-size:.96rem;
  padding:13px 14px;
  border:1px solid var(--line);
  background:var(--paper);
  color:var(--ink);
}
.form-group input:focus, .form-group textarea:focus{
  outline:none;
  border-color:var(--red);
}
.form-group textarea{resize:vertical;min-height:120px;}
.form-note{
  margin-top:6px;
  font-family:var(--ff-mono);
  font-size:.76rem;
  padding:12px 14px;
  border-left:3px solid var(--red);
  background:var(--paper-2);
}

/* ---------- CTA ---------- */
.cta{
  background:var(--paper);
  text-align:center;
}
.cta-box{
  border:1px solid var(--line);
  border-top:3px solid var(--red);
  padding:72px 40px;
  max-width:760px;
  margin:0 auto;
}
.cta h2{font-size:clamp(2rem,1.2rem + 2.4vw,3rem);}
.cta p{
  margin-top:16px;
  color:var(--steel);
  font-size:1.05rem;
  max-width:480px;
  margin-left:auto;
  margin-right:auto;
}
.cta-actions{
  margin-top:34px;
  display:flex;
  justify-content:center;
  gap:14px;
  flex-wrap:wrap;
}
.cta-note{
  margin-top:22px;
  font-family:var(--ff-mono);
  font-size:.78rem;
  color:var(--steel);
}

/* ---------- FOOTER ---------- */
footer{
  background:var(--ink);
  color:var(--paper);
  padding:48px 0 32px;
  position:relative;
  overflow:hidden;
}
.footer-watermark{
  position:absolute;
  right:-30px;
  bottom:-70px;
  width:320px;
  opacity:.05;
  z-index:0;
  pointer-events:none;
}
footer .wrap{
  position:relative;
  z-index:1;
}
.footer-top{
  display:flex;
  justify-content:space-between;
  align-items:flex-start;
  flex-wrap:wrap;
  gap:30px;
  padding-bottom:32px;
  border-bottom:1px solid var(--line-dark);
}
.footer-links{
  display:flex;
  gap:28px;
  list-style:none;
  flex-wrap:wrap;
}
.footer-links a{font-size:.88rem;color:#C9C7C2;}
.footer-links a:hover{color:var(--red);}
.footer-bottom{
  margin-top:24px;
  display:flex;
  justify-content:space-between;
  flex-wrap:wrap;
  gap:10px;
  font-family:var(--ff-mono);
  font-size:.72rem;
  color:var(--steel-light);
  letter-spacing:.04em;
}

/* ---------- REVEAL ---------- */
.reveal{opacity:0;transform:translateY(18px);transition:opacity .6s ease, transform .6s ease;}
.reveal.in-view{opacity:1;transform:translateY(0);}

@media (prefers-reduced-motion: reduce){
  .pipeline-track .cursor{animation:none;left:0;}
  .stage::before{animation:none;}
  .reveal{transition:none;opacity:1;transform:none;}
  html{scroll-behavior:auto;}
}

/* ---------- RESPONSIVE ---------- */
@media (max-width:900px){
  .feature-grid{grid-template-columns:repeat(2,1fr);}
  .card-grid{grid-template-columns:1fr;}
  .stats-grid{grid-template-columns:1fr;}
  .contact-grid{grid-template-columns:1fr;}
  .pipeline-stages{grid-template-columns:repeat(2,1fr);row-gap:30px;}
  .pipeline-track{display:none;}
  .stage{padding-right:16px;}
  .stage::before{display:none;}
}
@media (max-width:760px){
  .nav-links{
    position:absolute;
    top:100%;left:0;right:0;
    background:var(--paper);
    border-bottom:1px solid var(--line);
    flex-direction:column;
    align-items:flex-start;
    gap:0;
    padding:0;
    max-height:0;
    overflow:hidden;
    transition:max-height .3s ease;
  }
  .nav-links.open{max-height:380px;}
  .nav-links li{width:100%;}
  .nav-links a{display:block;padding:16px 28px;width:100%;color:var(--ink);}
  .nav-links a::after{display:none;}
  .nav-cta{display:none;}
  .nav-cta-mobile{display:list-item;}
  .nav-toggle{display:flex;}
  .hero{padding-top:140px;}
  .feature-grid{grid-template-columns:1fr;}
  .footer-top{flex-direction:column;}
}
