/* self-hosted fonts (GDPR: no third-party font CDNs) */
@font-face{font-family:'Clash Display';font-style:normal;font-weight:400;font-display:swap;src:url('fonts/ClashDisplay-400.woff2') format('woff2')}
@font-face{font-family:'Clash Display';font-style:normal;font-weight:500;font-display:swap;src:url('fonts/ClashDisplay-500.woff2') format('woff2')}
@font-face{font-family:'Clash Display';font-style:normal;font-weight:600;font-display:swap;src:url('fonts/ClashDisplay-600.woff2') format('woff2')}
@font-face{font-family:'Clash Display';font-style:normal;font-weight:700;font-display:swap;src:url('fonts/ClashDisplay-700.woff2') format('woff2')}
@font-face{font-family:'Satoshi';font-style:normal;font-weight:400;font-display:swap;src:url('fonts/Satoshi-400.woff2') format('woff2')}
@font-face{font-family:'Satoshi';font-style:normal;font-weight:500;font-display:swap;src:url('fonts/Satoshi-500.woff2') format('woff2')}
@font-face{font-family:'Satoshi';font-style:normal;font-weight:700;font-display:swap;src:url('fonts/Satoshi-700.woff2') format('woff2')}
@font-face{font-family:'Satoshi';font-style:normal;font-weight:900;font-display:swap;src:url('fonts/Satoshi-900.woff2') format('woff2')}
@font-face{font-family:'JetBrains Mono';font-style:normal;font-weight:400;font-display:swap;src:url('fonts/JetBrainsMono-400.woff2') format('woff2')}
@font-face{font-family:'JetBrains Mono';font-style:normal;font-weight:500;font-display:swap;src:url('fonts/JetBrainsMono-500.woff2') format('woff2')}
@font-face{font-family:'JetBrains Mono';font-style:normal;font-weight:600;font-display:swap;src:url('fonts/JetBrainsMono-600.woff2') format('woff2')}

:root{
  --bg:#080D0D;
  --surface:#0F1A1A;
  --surface-2:#0C1414;
  --deep:#002f2a;
  --teal:#1fa79a;
  --gold:#C9A227;
  --gold-light:#E8C84A;
  --text:#F0F0EE;
  --muted:#8A9090;
  --green:#28d943;
  --line:rgba(31,167,154,.14);
  --gold-line:rgba(201,162,39,.25);
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth;color-scheme:dark}
body{
  background:var(--bg);
  color:var(--text);
  font-family:'Satoshi',Helvetica,Arial,sans-serif;
  font-weight:400;
  line-height:1.6;
  overflow-x:hidden;
}
::selection{background:var(--gold);color:#080D0D}

/* ---------- grain + atmosphere ---------- */
body::before{
  content:"";position:fixed;inset:0;z-index:1000;pointer-events:none;opacity:.05;
  background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2'/%3E%3C/filter%3E%3Crect width='200' height='200' filter='url(%23n)' opacity='1'/%3E%3C/svg%3E");
}

h1,h2,h3{font-family:'Clash Display','Satoshi',Helvetica,sans-serif;font-weight:600;line-height:1.06;letter-spacing:.025em;color:var(--text)}
.serif{font-family:'Clash Display',Helvetica,sans-serif;font-style:normal;font-weight:400;color:var(--gold);letter-spacing:0}
.mono{font-family:'JetBrains Mono',monospace;font-size:.72rem;letter-spacing:.22em;text-transform:uppercase;color:var(--teal);font-weight:500}
.container{max-width:1240px;margin:0 auto;padding:0 36px}
section{position:relative}

/* ---------- reveal ---------- */
.reveal{opacity:0;transform:translateY(28px);transition:opacity .9s cubic-bezier(.16,1,.3,1),transform .9s cubic-bezier(.16,1,.3,1)}
.reveal.in{opacity:1;transform:none}

/* ---------- nav ---------- */
nav{
  position:fixed;top:0;left:0;right:0;z-index:900;
  padding:20px 0;transition:all .35s ease;
}
nav.scrolled{background:rgba(8,13,13,.82);backdrop-filter:blur(14px);border-bottom:1px solid var(--line);padding:12px 0}
.nav-inner{display:flex;align-items:center;justify-content:space-between}
.brand{display:flex;align-items:center;gap:12px;text-decoration:none}
.brand img{height:42px;width:auto;display:block}
.brand-name{font-weight:800;font-size:1.05rem;color:var(--text);letter-spacing:-.01em}
.brand-name span{color:var(--teal)}
.nav-links{display:flex;align-items:center;gap:34px;list-style:none}
.nav-links a{color:var(--muted);text-decoration:none;font-size:.88rem;font-weight:500;transition:color .25s}
.nav-links a:hover{color:var(--gold)}
.nav-links a.active{color:var(--gold)}
.nav-links a.btn{color:#080D0D}
.nav-links a.btn:hover{color:#080D0D;background:var(--gold-light);border-color:var(--gold-light);transform:scale(1.06)}
.btn{
  display:inline-flex;align-items:center;gap:10px;
  background:var(--gold);color:#080D0D;text-decoration:none;
  font-weight:700;font-size:.78rem;letter-spacing:.1em;text-transform:uppercase;
  padding:15px 28px;border-radius:0;
  transition:all .25s ease;border:1px solid var(--gold);white-space:nowrap;
}
.btn:hover{background:var(--gold-light);border-color:var(--gold-light);transform:translateY(-2px);box-shadow:0 8px 30px rgba(201,162,39,.25)}
.btn-ghost{background:transparent;color:var(--text);border:1px solid rgba(138,144,144,.55)}
.btn-ghost:hover{background:rgba(31,167,154,.08);border-color:var(--teal);color:var(--text);box-shadow:none;transform:translateY(-2px)}
.btn-sm{padding:11px 20px;font-size:.72rem}
.burger{display:none;background:none;border:none;cursor:pointer;flex-direction:column;gap:5px;padding:6px}
.burger span{width:24px;height:2px;background:var(--text);display:block;transition:.3s}

/* ---------- services dropdown ---------- */
.dd{position:relative}
.dd>a{display:inline-flex;align-items:center;gap:7px}
.dd .caret{font-size:.6rem;color:var(--muted);transition:transform .25s}
.dd:hover .caret{transform:rotate(180deg);color:var(--gold)}
.dd-menu{
  position:absolute;top:100%;left:50%;transform:translateX(-50%);
  padding-top:18px;opacity:0;visibility:hidden;transition:opacity .25s ease,visibility .25s;
}
.dd:hover .dd-menu,.dd:focus-within .dd-menu{opacity:1;visibility:visible}
.dd-card{
  background:rgba(12,20,20,.97);backdrop-filter:blur(16px);
  border:1px solid var(--line);border-radius:2px;padding:10px;min-width:240px;
  box-shadow:0 24px 60px rgba(0,0,0,.55);
}
.dd-card a{
  display:flex;align-items:center;justify-content:space-between;gap:18px;
  padding:12px 16px;border-radius:0;color:var(--muted);font-size:.88rem;
}
.dd-card a:hover{background:rgba(201,162,39,.07);color:var(--gold)}
.dd-card a .tagline{font-family:'JetBrains Mono',monospace;font-size:.58rem;letter-spacing:.12em;text-transform:uppercase;color:var(--teal);opacity:.8}
.dd-card .dd-all{
  border-top:1px solid var(--line);margin-top:8px;padding-top:14px;
  color:var(--gold);font-weight:600;
}
.dd-card .dd-all:hover{color:var(--gold-light);background:transparent}

/* ---------- hero (home) ---------- */
.hero{min-height:100vh;display:flex;flex-direction:column;justify-content:center;padding:170px 0 60px;overflow:hidden;position:relative}
.hero-glow{position:absolute;inset:0;pointer-events:none;z-index:0}
.hero-glow::before{
  content:"";position:absolute;top:-30%;right:-15%;width:65vw;height:65vw;border-radius:50%;
  background:radial-gradient(circle,rgba(0,47,42,.55) 0%,rgba(31,167,154,.07) 38%,transparent 70%);
  filter:blur(10px);
}
.hero-glow::after{
  content:"";position:absolute;bottom:-45%;left:-12%;width:50vw;height:50vw;border-radius:50%;
  background:radial-gradient(circle,rgba(201,162,39,.16) 0%,transparent 65%);
}
.hero-grid{
  position:absolute;inset:0;z-index:0;opacity:.5;
  background-image:linear-gradient(rgba(31,167,154,.05) 1px,transparent 1px),linear-gradient(90deg,rgba(31,167,154,.05) 1px,transparent 1px);
  background-size:72px 72px;
  mask-image:radial-gradient(ellipse 90% 80% at 50% 30%,black 30%,transparent 75%);
}
.hero .container{position:relative;z-index:2}
.hero h1{
  font-size:clamp(3rem,7.4vw,6.4rem);
  
  max-width:13ch;
}
.hero h1 .serif{font-size:1.02em}
.hero-sub{margin-top:32px;max-width:520px;color:var(--muted);font-size:1.12rem;font-weight:400}
.hero-sub strong{color:var(--text);font-weight:600}
.hero-ctas{display:flex;gap:16px;margin-top:44px;flex-wrap:wrap}
.hero-meta{display:flex;gap:48px;margin-top:72px;padding-top:28px;border-top:1px solid var(--line);flex-wrap:wrap}
.hero-meta .item .mono{color:var(--muted);display:block;margin-bottom:6px;font-size:.64rem}
.hero-meta .item .val{font-weight:700;font-size:1rem;color:var(--text)}
.hero-meta .item .val em{color:var(--gold);font-style:normal}

/* growth line */
.growth-line{
  position:absolute;right:3vw;bottom:16%;width:38vw;max-width:640px;z-index:1;opacity:.8;pointer-events:none;
  mask-image:linear-gradient(90deg,transparent 0%,black 18%);
}
@media(max-width:1080px){.growth-line{display:none}}
.growth-line path.gl{stroke-dasharray:1600;stroke-dashoffset:1600;animation:draw 2.8s 1.2s cubic-bezier(.5,0,.2,1) forwards}
.growth-line circle{opacity:0;animation:pop .5s 3.6s ease forwards}
@keyframes draw{to{stroke-dashoffset:0}}
@keyframes pop{to{opacity:1}}

/* ---------- page hero (subpages) ---------- */
.page-hero{padding:210px 0 90px;overflow:hidden;position:relative}
.page-hero .crumb{display:flex;align-items:center;gap:14px;margin-bottom:30px}
.page-hero .crumb a{color:var(--teal);text-decoration:none;transition:color .25s}
.page-hero .crumb a:hover{color:var(--gold)}
.page-hero .crumb .sep{color:var(--muted);padding:0 6px}
.page-hero .crumb .here{color:var(--gold-light)}
.page-hero h1{font-size:clamp(2.7rem,6.2vw,5.2rem);max-width:16ch}
.page-hero .lead{margin-top:28px;max-width:560px;color:var(--muted);font-size:1.1rem}
.page-hero .lead strong{color:var(--text);font-weight:600}
.page-hero .hero-ctas{margin-top:40px}

/* ---------- marquee ---------- */
.marquee{border-top:1px solid var(--line);border-bottom:1px solid var(--line);padding:26px 0;overflow:hidden;background:var(--surface-2)}
.marquee-track{display:flex;gap:0;width:max-content;animation:scroll 36s linear infinite}
.marquee-track span{font-family:'JetBrains Mono',monospace;font-size:1.05rem;font-weight:600;letter-spacing:.26em;text-transform:uppercase;color:var(--text);padding:0 32px;white-space:nowrap}
.marquee-track span i{color:var(--gold);font-style:normal;padding-right:56px}
@keyframes scroll{to{transform:translateX(-50%)}}

/* ---------- section headers ---------- */
.sec{padding:130px 0}
.sec-head{display:flex;align-items:flex-end;justify-content:space-between;gap:40px;margin-bottom:70px;flex-wrap:wrap}
.sec-head h2{font-size:clamp(2.1rem,4.4vw,3.6rem);max-width:18ch}
.sec-head .kick{display:flex;align-items:center;gap:12px;margin-bottom:18px}
.sec-head p{color:var(--muted);max-width:380px;font-size:.98rem}

/* ---------- pillars ---------- */
.pillars{background:var(--surface-2);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.pillar-list{border-top:1px solid var(--line)}
.pillar{
  display:grid;grid-template-columns:1fr 1.2fr 40px;gap:28px;align-items:center;
  padding:34px 10px;border-bottom:1px solid var(--line);cursor:default;
  transition:background .3s,padding-left .3s;
}
.pillar:hover{background:rgba(201,162,39,.03);padding-left:22px}
.pillar h3{font-size:1.35rem;font-weight:700;transition:color .3s}
.pillar:hover h3{color:var(--gold-light)}
.pillar p{color:var(--muted);font-size:.93rem}
.pillar .arrow{color:var(--gold);opacity:0;transform:translateX(-8px);transition:.3s;font-size:1.2rem}
.pillar:hover .arrow{opacity:1;transform:none}

/* ---------- services ---------- */
.svc-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.svc{
  background:var(--surface);border:1px solid var(--line);border-radius:2px;
  padding:42px 34px;display:flex;flex-direction:column;position:relative;overflow:hidden;
  transition:transform .35s ease,border-color .35s ease,box-shadow .35s ease;
}
.svc::before{content:"";position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,var(--gold),transparent 65%);opacity:0;transition:opacity .35s}
.svc:hover{transform:translateY(-6px);border-color:var(--gold-line);box-shadow:0 24px 60px rgba(0,0,0,.45)}
.svc:hover::before{opacity:1}
.svc.feature{background:linear-gradient(160deg,#03332d 0%,var(--surface) 60%);border-color:rgba(31,167,154,.3)}
.svc .mono{margin-bottom:22px;display:block}
.svc h3{font-size:1.5rem;margin-bottom:14px}
.svc>p{color:var(--muted);font-size:.94rem;margin-bottom:26px}
.svc ul{list-style:none;margin-bottom:34px;flex:1}
.svc li{padding:9px 0 9px 24px;position:relative;color:var(--text);font-size:.9rem;border-bottom:1px dashed rgba(138,144,144,.14)}
.svc li::before{content:"+";position:absolute;left:2px;color:var(--gold);font-weight:700}
.svc .price{font-family:'JetBrains Mono',monospace;font-size:.78rem;color:var(--gold-light);margin-bottom:20px;letter-spacing:.08em}
.svc a{align-self:flex-start}

/* secondary offers */
.offers{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-top:22px}
.offer{
  border:1px solid var(--line);border-radius:2px;padding:26px 24px;background:var(--surface-2);
  transition:border-color .3s,background .3s;display:block;text-decoration:none;
}
.offer:hover{border-color:var(--gold-line);background:var(--surface)}
.offer h4{font-size:1rem;font-weight:700;margin-bottom:8px;color:var(--text)}
.offer h4 span{color:var(--gold)}
.offer p{color:var(--muted);font-size:.82rem;line-height:1.5}

/* ---------- process steps ---------- */
.steps{display:grid;grid-template-columns:repeat(3,1fr);gap:0;border:1px solid var(--line);border-radius:2px;overflow:hidden}
.step{padding:52px 40px;background:var(--surface-2);border-right:1px solid var(--line);position:relative;transition:background .35s}
.step:last-child{border-right:none}
.step:hover{background:var(--surface)}
.step .big{
  font-family:'Clash Display',Helvetica,sans-serif;font-weight:500;
  font-size:4.6rem;line-height:1;color:transparent;-webkit-text-stroke:1px var(--gold);
  display:block;margin-bottom:26px;transition:color .35s;
}
.step:hover .big{color:var(--gold)}
.step h3{font-size:1.25rem;margin-bottom:12px}
.step p{color:var(--muted);font-size:.92rem}
.steps.four{grid-template-columns:repeat(4,1fr)}

/* ---------- detail features (service pages) ---------- */
.detail-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.detail{
  background:var(--surface);border:1px solid var(--line);border-radius:2px;padding:34px 30px;
  transition:transform .3s,border-color .3s;
}
.detail:hover{transform:translateY(-4px);border-color:var(--gold-line)}
.detail .num{font-family:'JetBrains Mono',monospace;font-size:.68rem;color:var(--gold);letter-spacing:.18em;display:block;margin-bottom:18px}
.detail h3{font-size:1.12rem;margin-bottom:10px}
.detail p{color:var(--muted);font-size:.88rem}

/* split block */
.split{display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:start}
.split .body p:first-child{margin-top:10px}
.split .sticky{position:sticky;top:140px}
.split h2{font-size:clamp(2rem,4vw,3.2rem);font-stretch:112%}
.split .body p{color:var(--muted);margin-bottom:22px;font-size:1rem}
.split .body p strong{color:var(--text)}

/* pricing band on service pages */
.price-band{
  border:1px solid var(--gold-line);border-radius:2px;padding:54px;display:flex;align-items:center;
  justify-content:space-between;gap:40px;background:linear-gradient(135deg,rgba(201,162,39,.06),transparent 55%),var(--surface);flex-wrap:wrap;
}
.price-band .label{font-family:'JetBrains Mono',monospace;font-size:.66rem;letter-spacing:.22em;text-transform:uppercase;color:var(--muted);display:block;margin-bottom:12px}
.price-band .amount{font-size:clamp(2.2rem,4.4vw,3.4rem);font-weight:800;color:var(--text);line-height:1}
.price-band .amount em{color:var(--gold);font-style:normal}
.price-band .amount .per{font-size:1rem;color:var(--muted);font-weight:500}
.price-band .note{color:var(--muted);font-size:.88rem;max-width:340px}

/* FAQ */
.faq{max-width:780px}
.faq details{border-bottom:1px solid var(--line)}
.faq summary{
  cursor:pointer;list-style:none;display:flex;justify-content:space-between;align-items:center;gap:20px;
  padding:26px 4px;font-weight:700;font-size:1.05rem;transition:color .25s;
}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"+";color:var(--gold);font-size:1.4rem;font-weight:400;transition:transform .3s}
.faq details[open] summary::after{transform:rotate(45deg)}
.faq summary:hover{color:var(--gold-light)}
.faq .a{padding:0 4px 28px;color:var(--muted);font-size:.94rem;max-width:62ch}

/* ---------- results / cases ---------- */
.results{background:var(--surface-2);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.case-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.case{
  background:var(--surface);border:1px solid var(--line);border-radius:2px;padding:36px 32px;
  transition:transform .35s,border-color .35s;position:relative;overflow:hidden;
  display:flex;flex-direction:column;
}
.case:hover{transform:translateY(-6px);border-color:rgba(31,167,154,.35)}
.case .tag{
  display:inline-block;font-family:'JetBrains Mono',monospace;font-size:.64rem;letter-spacing:.18em;text-transform:uppercase;
  border:1px solid rgba(31,167,154,.4);color:var(--teal);padding:5px 12px;border-radius:99px;margin-bottom:24px;
}
.case .tag.gold{border-color:var(--gold-line);color:var(--gold-light)}
.case h3{font-size:1.15rem;margin-bottom:10px}
.case>p{color:var(--muted);font-size:.88rem;margin-bottom:30px;flex:1}
.case .metrics{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;border-top:1px solid var(--line);padding-top:24px;margin-bottom:26px}
.case .m .v{font-size:1.7rem;font-weight:800;color:var(--gold)}
.case .m .l{font-family:'JetBrains Mono',monospace;font-size:.6rem;letter-spacing:.12em;text-transform:uppercase;color:var(--muted);margin-top:6px;min-height:2em;line-height:1.5}
.case .pending{font-family:'JetBrains Mono',monospace;font-size:.62rem;color:var(--muted);letter-spacing:.1em;margin-top:18px;display:block}
.case .cs-btn{
  display:inline-flex;align-items:center;gap:8px;align-self:flex-start;margin-top:auto;
  font-family:'JetBrains Mono',monospace;font-size:.68rem;letter-spacing:.12em;text-transform:uppercase;
  color:var(--gold);text-decoration:none;border:1px solid var(--gold-line);padding:12px 20px;
  transition:all .25s ease;
}
.case .cs-btn:hover{background:var(--gold);color:#080D0D;border-color:var(--gold)}

/* ---------- case study filters ---------- */
.filters{display:flex;gap:10px;margin:-26px 0 34px;flex-wrap:wrap}
.fbtn{
  font-family:'JetBrains Mono',monospace;font-size:.7rem;letter-spacing:.14em;text-transform:uppercase;
  padding:11px 24px;border:1px solid var(--line);background:transparent;color:var(--muted);cursor:pointer;transition:.25s;
}
.fbtn:hover{color:var(--gold);border-color:var(--gold-line)}
.fbtn.on{border-color:var(--gold);color:var(--gold);background:rgba(201,162,39,.06)}

/* ---------- case study detail pages ---------- */
.stat-row{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.stat{border:1px solid var(--gold-line);border-radius:2px;padding:36px 32px;background:var(--surface)}
.stat .v{font-family:'Clash Display',Helvetica,sans-serif;font-weight:600;font-size:2.4rem;color:var(--gold);line-height:1.1}
.stat .l{font-family:'JetBrains Mono',monospace;font-size:.64rem;letter-spacing:.16em;text-transform:uppercase;color:var(--muted);margin-top:10px}
.ba{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.ba .col{border:1px solid var(--line);border-radius:2px;padding:38px 34px;background:var(--surface-2)}
.ba .col.after{border-color:var(--gold-line);background:var(--surface)}
.ba ul{list-style:none}
.ba li{display:flex;justify-content:space-between;gap:20px;padding:13px 0;border-bottom:1px dashed rgba(138,144,144,.16);font-size:.94rem;color:var(--muted)}
.ba li strong{color:var(--text);font-weight:700;text-align:right}
.ba .col.after li strong{color:var(--gold-light)}
@media(max-width:760px){.stat-row,.ba{grid-template-columns:1fr}}

/* ---------- blog cards ---------- */
.blog-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.post{
  background:var(--surface);border:1px solid var(--line);border-radius:2px;overflow:hidden;text-decoration:none;
  transition:transform .35s,border-color .35s;display:flex;flex-direction:column;
}
.post:hover{transform:translateY(-6px);border-color:var(--gold-line)}
.post .thumb{height:180px;background:linear-gradient(135deg,var(--deep),var(--surface-2));position:relative}
.post .thumb::after{content:"";position:absolute;inset:0;background:radial-gradient(circle at 70% 30%,rgba(201,162,39,.18),transparent 60%)}
.post .body{padding:28px 28px 32px;display:flex;flex-direction:column;flex:1}
.post .cat{font-family:'JetBrains Mono',monospace;font-size:.6rem;letter-spacing:.18em;text-transform:uppercase;color:var(--teal);margin-bottom:14px}
.post h3{color:var(--text);font-size:1.12rem;margin-bottom:10px;line-height:1.3}
.post p{color:var(--muted);font-size:.86rem;flex:1}
.post .date{font-family:'JetBrains Mono',monospace;font-size:.62rem;color:var(--muted);margin-top:20px;letter-spacing:.1em}

/* ---------- forms ---------- */
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.form-grid .full{grid-column:1/-1}
.field label{font-family:'JetBrains Mono',monospace;font-size:.62rem;letter-spacing:.18em;text-transform:uppercase;color:var(--muted);display:block;margin-bottom:9px}
.field input,.field select,.field textarea{
  width:100%;background:var(--surface);border:1px solid var(--line);border-radius:0;
  padding:14px 16px;color:var(--text);font-family:'Satoshi',Helvetica,sans-serif;font-size:.95rem;
  transition:border-color .25s,box-shadow .25s;appearance:none;
}
.field textarea{min-height:130px;resize:vertical}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--gold);box-shadow:0 0 0 3px rgba(201,162,39,.12)}
.field select{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6'%3E%3Cpath d='M1 1l4 4 4-4' stroke='%23C9A227' fill='none'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 16px center}
.form-note{font-family:'JetBrains Mono',monospace;font-size:.62rem;color:var(--muted);letter-spacing:.08em;margin-top:16px}
.form-success{
  display:none;border:1px solid rgba(40,217,67,.35);background:rgba(40,217,67,.06);border-radius:2px;
  padding:28px;margin-top:24px;
}
.form-success.show{display:block}
.form-success h4{color:var(--green);margin-bottom:6px}
.form-success p{color:var(--muted);font-size:.9rem}

/* contact info cards */
.contact-cards{display:grid;grid-template-columns:1fr;gap:16px}
.ccard{border:1px solid var(--line);border-radius:2px;padding:26px;background:var(--surface-2)}
.ccard .mono{display:block;margin-bottom:10px;font-size:.62rem}
.ccard a{color:var(--text);text-decoration:none;font-weight:600}
.ccard a:hover{color:var(--gold-light)}
.ccard p{color:var(--muted);font-size:.88rem}

/* ---------- cta band ---------- */
.cta-band{
  background:linear-gradient(135deg,var(--deep) 0%,#01211d 100%);
  border-top:1px solid rgba(31,167,154,.25);border-bottom:1px solid rgba(31,167,154,.25);
  padding:120px 0;text-align:center;position:relative;overflow:hidden;
}
.cta-band::before{
  content:"";position:absolute;top:-60%;left:50%;transform:translateX(-50%);width:70vw;height:70vw;border-radius:50%;
  background:radial-gradient(circle,rgba(201,162,39,.12) 0%,transparent 60%);
}
.cta-band .container{position:relative;z-index:2}
.cta-band h2{font-size:clamp(2.4rem,5.4vw,4.4rem);max-width:20ch;margin:0 auto 22px}
.cta-band p{color:rgba(240,240,238,.6);max-width:480px;margin:0 auto 44px;font-size:1.05rem}
.cta-band .mono{display:block;margin-bottom:26px}

/* ---------- footer ---------- */
footer{padding:80px 0 40px;border-top:1px solid var(--line)}
.foot-grid{display:grid;grid-template-columns:1.5fr 1fr 1fr 1fr 1fr;gap:40px;margin-bottom:64px}
.foot-grid .brand img{height:52px}
.foot-grid .blurb{color:var(--muted);font-size:.86rem;margin-top:18px;max-width:280px}
.foot-grid h5{font-family:'JetBrains Mono',monospace;font-size:.66rem;letter-spacing:.2em;text-transform:uppercase;color:var(--gold);margin-bottom:20px;font-weight:500}
.foot-grid ul{list-style:none}
.foot-grid li{margin-bottom:11px}
.foot-grid a{color:var(--muted);text-decoration:none;font-size:.88rem;transition:color .25s}
.foot-grid a:hover{color:var(--gold-light)}
.foot-bottom{
  border-top:1px solid var(--line);padding-top:28px;display:flex;justify-content:space-between;gap:20px;flex-wrap:wrap;
  color:var(--muted);font-size:.78rem;font-family:'JetBrains Mono',monospace;letter-spacing:.04em;
}
.foot-bottom a{color:inherit;text-decoration:none}
.foot-bottom a:hover{color:var(--gold-light)}

/* ---------- responsive ---------- */
@media(max-width:1024px){
  .svc-grid,.case-grid,.blog-grid,.detail-grid{grid-template-columns:1fr 1fr !important}
  .offers{grid-template-columns:1fr 1fr !important}
  .steps,.steps.four{grid-template-columns:1fr}
  .step{border-right:none;border-bottom:1px solid var(--line)}
  .step:last-child{border-bottom:none}
  .split{grid-template-columns:1fr !important;gap:40px}
  .split .sticky{position:static}
  .foot-grid{grid-template-columns:1fr 1fr}
  .growth-line{display:none}
}
/* nav collapses earlier than 760: full link row + CTA needs ~870px */
@media(max-width:920px){
  .nav-links{
    display:none;position:absolute;top:100%;left:0;right:0;background:rgba(8,13,13,.97);
    flex-direction:column;padding:28px 22px;gap:22px;border-bottom:1px solid var(--line);backdrop-filter:blur(16px);
    align-items:flex-start;
  }
  .nav-links.open{display:flex}
  .burger{display:flex}
  /* dropdown becomes inline list on mobile */
  .dd-menu{position:static;transform:none;opacity:1;visibility:visible;padding-top:12px}
  .dd-card{background:transparent;border:none;box-shadow:none;padding:0 0 0 14px;border-left:1px solid var(--line);border-radius:0;min-width:0}
  .dd .caret{display:none}
}
@media(max-width:760px){
  .container{padding:0 22px}
  .sec{padding:90px 0}
  .page-hero{padding:160px 0 70px}
  .svc-grid,.case-grid,.blog-grid,.offers,.detail-grid,.form-grid{grid-template-columns:1fr !important}
  .form-grid .full{grid-column:1}
  .pillar{grid-template-columns:1fr;grid-template-rows:auto auto;gap:10px}
  .pillar p{grid-column:1}
  .pillar .arrow{display:none}
  .hero-meta{gap:28px}
  .foot-grid{grid-template-columns:1fr}
  .price-band{padding:36px 28px}
}
@media(max-width:480px){
  /* long CTA labels can exceed the viewport when nowrap */
  .btn{white-space:normal;text-align:center;justify-content:center;max-width:100%;padding:14px 22px}
  .hero{padding-top:140px}
  .marquee-track span{font-size:.88rem}
}

/* ---------- FAQ hub blocks ---------- */
.faq-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:18px}
.faq-block{
  background:var(--surface);border:1px solid var(--line);border-radius:2px;padding:34px 32px;
  transition:border-color .3s,transform .3s;display:flex;flex-direction:column;
}
.faq-block:hover{border-color:var(--gold-line);transform:translateY(-3px)}
.faq-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px;gap:14px}
.faq-icon{
  width:40px;height:40px;border:1px solid var(--gold-line);border-radius:2px;flex:none;
  background:radial-gradient(circle at 30% 30%,rgba(201,162,39,.22),rgba(31,167,154,.08) 70%);
}
.faq-block .tag{
  font-family:'JetBrains Mono',monospace;font-size:.6rem;letter-spacing:.16em;text-transform:uppercase;
  border:1px solid rgba(31,167,154,.4);color:var(--teal);padding:5px 12px;border-radius:99px;white-space:nowrap;
}
.faq-block h3{font-size:1.12rem;margin-bottom:12px;line-height:1.3}
.faq-block .fa{color:var(--muted);font-size:.9rem;line-height:1.65;margin-bottom:24px}
.faq-block .fa strong{color:var(--text)}
.faq-block .fa ul{margin:12px 0 0 18px}
.faq-block .fa li{margin-bottom:7px}
.faq .a ul{margin:10px 0 0 18px}
.faq .a li{margin-bottom:6px;max-width:60ch}
@media(max-width:860px){.faq-grid{grid-template-columns:1fr}}

}

/* ---------- article pages (FAQ + pillars) ---------- */
.article{max-width:780px}
.article h2{font-size:1.5rem;margin:44px 0 16px}
.article h2:first-child{margin-top:0}
.article p{color:var(--muted);font-size:1rem;line-height:1.75;margin-bottom:16px}
.article p strong{color:var(--text)}
.article ul{margin:0 0 16px 20px;color:var(--muted)}
.article li{margin-bottom:8px;line-height:1.65}
.article li strong{color:var(--text)}
.faq-block .cs-btn{
  display:inline-flex;align-items:center;gap:8px;align-self:flex-start;margin-top:auto;
  font-family:'JetBrains Mono',monospace;font-size:.68rem;letter-spacing:.12em;text-transform:uppercase;
  color:var(--gold);text-decoration:none;border:1px solid var(--gold-line);padding:12px 20px;
  transition:all .25s ease;
}
.faq-block .cs-btn:hover{background:var(--gold);color:#080D0D;border-color:var(--gold)}
a.pillar{text-decoration:none;color:inherit;cursor:pointer}

/* ---------- FAQ theme icons (generated) ---------- */
.faq-block[data-theme="google-ads"] .faq-icon{background:url("icons/google-ads.png") center/68% no-repeat}
.faq-block[data-theme="seo"] .faq-icon{background:url("icons/seo.png") center/68% no-repeat}
.faq-block[data-theme="pricing"] .faq-icon{background:url("icons/pricing.png") center/68% no-repeat}
.faq-block[data-theme="tracking"] .faq-icon{background:url("icons/tracking.png") center/68% no-repeat}
.faq-block[data-theme="working-together"] .faq-icon{background:url("icons/working-together.png") center/68% no-repeat}
.faq-block[data-theme="ecommerce"] .faq-icon{background:url("icons/ecommerce.png") center/68% no-repeat}
.about-visual{
  width:100%;max-width:380px;aspect-ratio:1;object-fit:cover;display:block;margin-top:34px;
  border:1px solid var(--gold-line);border-radius:2px;
}

/* ---------- subscribe: the operator's letter (blog only) ---------- */
.sub-panel{
  max-width:720px;margin:0 auto;text-align:center;
  background:var(--surface);border:1px solid var(--gold-line);border-radius:2px;
  padding:54px 44px 44px;
}
.sub-panel h2{font-size:clamp(1.5rem,3.2vw,2.1rem);margin:14px 0 12px}
.sub-panel>p{color:var(--muted);max-width:520px;margin:0 auto 26px;line-height:1.65}
.sub-form{display:flex;gap:12px;max-width:480px;margin:0 auto}
.sub-form input[type="email"]{
  flex:1;min-width:0;background:var(--surface-2);border:1px solid var(--line);border-radius:2px;
  color:var(--text);font-family:'Satoshi',sans-serif;font-size:.95rem;padding:14px 16px;
}
.sub-form input[type="email"]:focus{outline:none;border-color:var(--gold);box-shadow:0 0 0 3px rgba(201,162,39,.12)}
.sub-form .btn{cursor:pointer}
.sub-note{display:block;font-family:'JetBrains Mono',monospace;font-size:.6rem;letter-spacing:.14em;text-transform:uppercase;color:var(--muted);margin-top:16px}
.sub-done{display:none;color:var(--gold-light);font-size:1.02rem;padding:14px 0 2px}
.sub-panel.done .sub-form,.sub-panel.done .sub-note{display:none}
.sub-panel.done .sub-done{display:block}
@media (max-width:560px){
  .sub-panel{padding:40px 22px 34px}
  .sub-form{flex-direction:column}
  .sub-form .btn{justify-content:center}
}

/* ---------- sticky WhatsApp button ---------- */
.wa-btn{
  position:fixed;right:22px;bottom:22px;z-index:950;
  width:54px;height:54px;border-radius:2px;
  display:flex;align-items:center;justify-content:center;
  background:var(--surface);color:var(--teal);text-decoration:none;
  border:1px solid rgba(31,167,154,.45);
  box-shadow:0 8px 28px rgba(0,0,0,.5);
  transition:all .25s ease;
}
.wa-btn:hover{background:var(--teal);color:#080D0D;border-color:var(--teal);transform:translateY(-3px);box-shadow:0 12px 36px rgba(31,167,154,.3)}
@media(max-width:760px){.wa-btn{right:16px;bottom:16px;width:52px;height:52px}}

/* ---------- booking embed ---------- */
.booking-embed{
  background:var(--surface);border:1px solid var(--line);border-top:2px solid var(--gold);
  border-radius:2px;padding:18px;
}
.booking-frame-label{margin-bottom:14px}
.booking-frame-label .mono{font-size:.62rem;color:var(--muted)}

@media(max-width:760px){}

/* ---------- contextual internal links ---------- */
a.il{color:var(--teal);text-decoration:none;border-bottom:1px solid rgba(31,167,154,.35);transition:color .25s,border-color .25s}
a.il:hover{color:var(--gold);border-bottom-color:var(--gold-line)}

/* secondary-page hero variant: teal accent instead of gold */
.page-hero.alt h1 .serif{color:var(--teal)}

/* ---------- consent banner ---------- */
.consent{
  position:fixed;left:22px;bottom:22px;z-index:960;max-width:380px;
  background:var(--surface);border:1px solid var(--line);border-top:2px solid var(--gold);
  border-radius:2px;padding:22px;box-shadow:0 16px 48px rgba(0,0,0,.55);
}
.consent p{font-size:.85rem;color:var(--muted);margin-bottom:16px;line-height:1.55}
.consent p strong{color:var(--text)}
.consent-actions{display:flex;gap:10px;align-items:center;flex-wrap:wrap}
.consent-actions a{font-family:'JetBrains Mono',monospace;font-size:.62rem;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);text-decoration:none;margin-left:auto}
.consent-actions a:hover{color:var(--gold)}
@media(max-width:760px){.consent{left:12px;right:12px;bottom:80px;max-width:none}}

/* ---------- footer v2 ---------- */
.foot-grid h5 a{color:var(--gold);text-decoration:none;transition:color .25s}
.foot-grid h5 a:hover{color:var(--gold-light)}
.foot-social{display:flex;gap:10px;margin:20px 0 22px}
.foot-social a{
  width:36px;height:36px;display:flex;align-items:center;justify-content:center;
  border:1px solid var(--line);border-radius:2px;color:var(--muted);transition:all .25s;
}
.foot-social a:hover{color:var(--gold);border-color:var(--gold-line);transform:translateY(-2px)}
.foot-cta{margin-top:2px}
.foot-grid a.btn{color:#080D0D}
.foot-grid a.btn:hover{color:#080D0D}
@media(max-width:1024px){.foot-grid{grid-template-columns:1fr 1fr 1fr}.foot-brand{grid-column:1/-1}}
@media(max-width:760px){.foot-grid{grid-template-columns:1fr 1fr}.foot-brand{grid-column:1/-1}}

/* post-submit confirmation strip */
.sent-strip{
  border:1px solid rgba(40,217,67,.35);background:rgba(40,217,67,.07);border-radius:2px;
  padding:16px 20px;margin-bottom:28px;color:var(--muted);font-size:.92rem;max-width:560px;
}
.sent-strip strong{color:var(--green)}

/* ---------- blog articles ---------- */
.blog-hero{width:100%;max-height:480px;object-fit:cover;border:1px solid var(--line);border-radius:2px;display:block}
.article .blog-img{width:100%;border:1px solid var(--line);border-radius:2px;display:block;margin:36px 0}
.article-lead{font-size:1.15rem;color:var(--text)!important;line-height:1.7}
.post-meta{margin-top:22px}
.post .thumb{background-size:cover;background-position:center}
.post.featured{display:grid;grid-template-columns:1.2fr 1fr;min-height:300px}
.post.featured .thumb{height:auto;min-height:300px}
.post.featured .body{padding:40px}
.post.featured h3{font-size:1.6rem}
@media(max-width:860px){.post.featured{display:flex;flex-direction:column}.post.featured .thumb{height:220px;min-height:0}}

/* calendar click-to-load facade */
.cal-facade{padding:48px 32px;text-align:center;background:var(--surface-2);border-radius:2px}
.cal-facade p{color:var(--muted);max-width:46ch;margin:0 auto 22px;font-size:.95rem}
.cal-facade p strong{color:var(--text)}
.booking-embed iframe{width:100%;height:660px;border:none;border-radius:2px;background:#fff;display:block}

/* HARD RULE: gold buttons always have dark text, no matter the container's link color */
a.btn:not(.btn-ghost),button.btn:not(.btn-ghost){color:#080D0D !important}
a.btn:not(.btn-ghost):hover,button.btn:not(.btn-ghost):hover{color:#080D0D !important}

/* CLS guards */
.blog-hero{aspect-ratio:3/2;object-fit:cover}
.article .blog-img{aspect-ratio:3/2;object-fit:cover}
/* compact consent */
.consent{max-width:320px;padding:16px}
.consent p{font-size:.78rem;margin-bottom:12px}
/* footer headings (p, correct heading order) */
.foot-grid .foot-h{font-family:'JetBrains Mono',monospace;font-size:.66rem;letter-spacing:.2em;text-transform:uppercase;color:var(--gold);margin-bottom:20px;font-weight:500}
.foot-grid .foot-h a{color:var(--gold);text-decoration:none}
.foot-grid .foot-h a:hover{color:var(--gold-light)}
