/*
Theme Name: Digitrix Media
Theme URI: https://digitrix.co.za/
Author: Digitrix Media
Author URI: https://digitrix.co.za/
Description: Honest digital-marketing theme for Digitrix Media - web design & Google Ads in Johannesburg. Elementor-compatible, with a built-in quote builder. Black + lime brand system, Poppins type, scroll animations.
Version: 1.0.0
Requires at least: 6.0
Tested up to: 6.5
Requires PHP: 7.4
License: GNU General Public License v2 or later
Text Domain: digitrix
Tags: business, elementor, custom-colors, custom-logo, custom-menu, featured-images, full-width-template, threaded-comments, translation-ready
*/


:root{
  --ink:#181818;
  --black:#161616;
  --black-deep:#0E0E0E;
  --lime:#C2E84F;
  --lime-bright:#D2F26B;
  --lime-dim:#AAD83A;
  --bg:#F7F7F2;
  --bg-soft:#EFEFE8;
  --white:#FFFFFF;
  --muted:#6B6B66;
  --line:rgba(24,24,24,.10);
  --radius:18px;
  --maxw:1280px;
  --ease:cubic-bezier(.16,1,.3,1);
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-font-smoothing:antialiased}
body{
  font-family:"Poppins",sans-serif;
  background:var(--bg);
  color:var(--ink);
  font-size:17px;
  line-height:1.6;
  overflow-x:hidden;
}
::selection{background:var(--lime);color:var(--ink)}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}

body::after{
  content:"";position:fixed;inset:0;pointer-events:none;z-index:9999;opacity:.04;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='3'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}

.wrap{max-width:var(--maxw);margin:0 auto;padding:0 32px}
.eyebrow{
  font-size:12.5px;font-weight:700;letter-spacing:.2em;text-transform:uppercase;
  color:var(--ink);display:inline-flex;align-items:center;gap:10px;
}
.eyebrow::before{content:"";width:26px;height:2px;background:var(--lime-dim)}

h1,h2,h3{font-family:"Poppins",sans-serif;font-weight:700;line-height:1.06;letter-spacing:-.03em}
.display{font-size:clamp(2.5rem,6.8vw,6.4rem);font-weight:700}
.display em{font-style:italic;font-weight:500;color:var(--lime-dim)}

/* Buttons */
.btn{
  display:inline-flex;align-items:center;gap:11px;font-weight:600;font-size:15px;
  padding:15px 27px;border-radius:100px;border:1.5px solid transparent;cursor:pointer;
  transition:transform .5s var(--ease),background .35s,color .35s,box-shadow .5s,border-color .35s;
  position:relative;overflow:hidden;font-family:inherit;
}
.btn .arrow{transition:transform .5s var(--ease)}
.btn:hover .arrow{transform:translateX(5px)}
.btn-lime{background:var(--lime);color:var(--ink)}
.btn-lime:hover{transform:translateY(-3px);box-shadow:0 16px 36px -14px rgba(170,216,58,.85)}
.btn-dark{background:var(--ink);color:var(--white)}
.btn-dark:hover{background:#000;transform:translateY(-3px);box-shadow:0 16px 38px -16px rgba(0,0,0,.55)}
.btn-ghost{border-color:rgba(24,24,24,.25);color:var(--ink)}
.btn-ghost:hover{border-color:var(--ink);background:var(--ink);color:var(--white)}
.btn-wa{background:#25D366;color:#fff}
.btn-wa:hover{transform:translateY(-3px);box-shadow:0 16px 36px -14px rgba(37,211,102,.7)}

/* Nav */
header{position:fixed;top:0;left:0;right:0;z-index:1000}
.nav{
  display:flex;align-items:center;justify-content:space-between;
  margin:16px auto 0;max-width:var(--maxw);padding:11px 16px 11px 22px;
  background:rgba(247,247,242,.72);backdrop-filter:blur(14px);
  border:1px solid var(--line);border-radius:100px;
  width:calc(100% - 64px);transition:box-shadow .4s,background .4s;
}
.nav.scrolled{box-shadow:0 12px 36px -22px rgba(0,0,0,.4);background:rgba(247,247,242,.93)}
.logo-img{height:32px;width:auto}
.nav-links{display:flex;gap:30px;list-style:none}
.nav-links a{font-size:15px;font-weight:500;color:var(--ink);position:relative;opacity:.82;transition:opacity .3s}
.nav-links a::after{content:"";position:absolute;left:0;bottom:-5px;height:2px;width:0;background:var(--lime-dim);transition:width .4s var(--ease)}
.nav-links a:hover{opacity:1}
.nav-links a:hover::after{width:100%}
.nav-cta{display:flex;align-items:center;gap:12px}
.burger{display:none;flex-direction:column;gap:5px;cursor:pointer;background:none;border:none;padding:6px}
.burger span{width:24px;height:2px;background:var(--ink);border-radius:2px;transition:.3s}

/* Hero */
.hero{position:relative;padding:170px 0 80px;overflow:hidden}
.hero-bg{position:absolute;inset:0;z-index:0;pointer-events:none}
.blob{position:absolute;border-radius:50%;filter:blur(72px);opacity:.5}
.blob.b1{width:600px;height:600px;background:radial-gradient(circle,var(--lime),transparent 64%);top:-180px;right:-140px;animation:float 16s var(--ease) infinite}
.blob.b2{width:460px;height:460px;background:radial-gradient(circle,var(--lime-bright),transparent 62%);bottom:-160px;left:-120px;animation:float 19s var(--ease) infinite reverse}
@keyframes float{0%,100%{transform:translate(0,0) scale(1)}50%{transform:translate(28px,-28px) scale(1.08)}}
.grid-lines{position:absolute;inset:0;background-image:linear-gradient(rgba(24,24,24,.045) 1px,transparent 1px),linear-gradient(90deg,rgba(24,24,24,.045) 1px,transparent 1px);background-size:62px 62px;mask-image:radial-gradient(ellipse 80% 60% at 50% 35%,#000,transparent)}
.hero-inner{position:relative;z-index:2}
.hero-tag{margin-bottom:26px}
.hero h1{margin-bottom:26px;max-width:15ch}
.hero-sub{font-size:clamp(1rem,1.5vw,1.2rem);max-width:52ch;color:#3a3a36;margin-bottom:36px}
.hero-actions{display:flex;gap:14px;flex-wrap:wrap;align-items:center;margin-bottom:58px}

.reveal{opacity:0;transform:translateY(32px);transition:opacity .9s var(--ease),transform .9s var(--ease)}
.reveal.in{opacity:1;transform:none}
.d1{transition-delay:.05s}.d2{transition-delay:.15s}.d3{transition-delay:.25s}.d4{transition-delay:.35s}.d5{transition-delay:.45s}.d6{transition-delay:.55s}

.trusted{border-top:1px solid var(--line);border-bottom:1px solid var(--line);padding:20px 0;position:relative;z-index:2}
.trusted-label{font-size:12px;letter-spacing:.16em;text-transform:uppercase;color:var(--muted);font-weight:600;margin-bottom:13px}
.marquee{display:flex;overflow:hidden;mask-image:linear-gradient(90deg,transparent,#000 8%,#000 92%,transparent)}
.marquee-track{display:flex;gap:54px;padding-right:54px;animation:scroll 26s linear infinite;white-space:nowrap}
.marquee:hover .marquee-track{animation-play-state:paused}
@keyframes scroll{to{transform:translateX(-50%)}}
.mq-item{font-size:22px;font-weight:700;color:var(--ink);opacity:.5;display:flex;align-items:center;gap:11px;letter-spacing:-.02em}
.mq-item::before{content:"";width:9px;height:9px;background:var(--lime-dim);transform:rotate(45deg)}

section{position:relative}
.sec{padding:110px 0}
.sec-head{max-width:680px;margin-bottom:58px}
.sec-head h2{font-size:clamp(1.9rem,4.2vw,3.4rem);margin:16px 0 18px}
.sec-head p{font-size:1.08rem;color:#42423c}

/* dark band */
.band{background:var(--black);color:var(--bg);border-radius:34px;margin:0 16px;overflow:hidden;position:relative}
.band-inner{display:grid;grid-template-columns:1.1fr .9fr;gap:56px;padding:88px 60px;align-items:center}
.band .eyebrow{color:var(--lime)}.band .eyebrow::before{background:var(--lime)}
.band h2{font-size:clamp(1.8rem,3.3vw,2.9rem);color:var(--white);margin:16px 0 22px}
.band h2 em{color:var(--lime);font-style:italic}
.band p{color:#bdbdb6;margin-bottom:16px}
.band-side{display:grid;gap:16px}
.band-stat{border:1px solid rgba(255,255,255,.13);border-radius:15px;padding:22px 24px;background:rgba(255,255,255,.025);transition:transform .5s var(--ease),background .4s,border-color .4s}
.band-stat:hover{transform:translateX(8px);background:rgba(194,232,79,.08);border-color:rgba(194,232,79,.4)}
.band-stat .num{font-size:1.4rem;font-weight:700;color:var(--lime);line-height:1.1}
.band-stat .lbl{font-size:13.5px;color:#a6a69e;margin-top:5px}
.band-deco{position:absolute;right:-60px;top:-60px;width:230px;height:230px;border:1.5px solid rgba(194,232,79,.16);border-radius:50%}
.band-deco::after{content:"";position:absolute;inset:32px;border:1.5px solid rgba(194,232,79,.1);border-radius:50%}

/* services */
.services{display:grid;grid-template-columns:repeat(2,1fr);gap:20px}
.card{
  position:relative;background:var(--white);border:1px solid var(--line);
  border-radius:var(--radius);padding:38px 36px 34px;overflow:hidden;
  transition:transform .6s var(--ease),box-shadow .6s var(--ease),border-color .4s;
}
.card::before{content:"";position:absolute;left:0;top:0;height:100%;width:4px;background:var(--lime);transform:scaleY(0);transform-origin:bottom;transition:transform .6s var(--ease)}
.card:hover{transform:translateY(-8px);box-shadow:0 28px 56px -34px rgba(0,0,0,.4);border-color:transparent}
.card:hover::before{transform:scaleY(1)}
.card-num{font-size:13px;color:var(--lime-dim);font-weight:700;letter-spacing:.04em}
.card-ico{width:54px;height:54px;border-radius:14px;background:var(--ink);color:var(--lime);display:grid;place-items:center;margin:18px 0 22px;transition:transform .6s var(--ease)}
.card:hover .card-ico{transform:rotate(-8deg) scale(1.06)}
.card-ico svg{width:25px;height:25px}
.card h3{font-size:1.5rem;margin-bottom:6px}
.card .price{font-size:.95rem;font-weight:700;color:var(--ink);margin-bottom:12px}
.card .price span{color:var(--muted);font-weight:500;font-size:.82rem}
.card p{font-size:.98rem;color:#4a4a44;margin-bottom:20px}
.card-link{font-weight:600;font-size:14.5px;color:var(--ink);display:inline-flex;gap:8px;align-items:center}
.card-link .arrow{transition:transform .4s var(--ease)}
.card:hover .card-link .arrow{transform:translateX(5px)}
.card.wide{grid-column:span 2;display:flex;justify-content:space-between;align-items:center;gap:40px;background:var(--ink);color:var(--bg);border:none}
.card.wide::before{display:none}
.card.wide h3{color:var(--white);font-size:1.85rem}
.card.wide p{color:rgba(255,255,255,.82);max-width:48ch;margin-bottom:0}
.card.wide .card-num{color:var(--lime)}

/* pricing */
.price-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;align-items:stretch}
.tier{position:relative;background:var(--white);border:1px solid var(--line);border-radius:var(--radius);padding:38px 34px;display:flex;flex-direction:column;transition:transform .5s var(--ease),box-shadow .5s,border-color .4s}
.tier:hover{transform:translateY(-8px);box-shadow:0 28px 56px -34px rgba(0,0,0,.4)}
.tier.feat{background:var(--ink);color:var(--bg);border-color:var(--ink)}
.tier.feat .t-name,.tier.feat .t-sub{color:#bdbdb6}
.tier.feat .t-sub{color:var(--white)}
.t-badge{position:absolute;top:-12px;left:34px;background:var(--lime);color:var(--ink);font-size:11.5px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;padding:6px 14px;border-radius:100px}
.t-name{font-size:13px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--muted)}
.t-price{font-size:2.6rem;font-weight:700;letter-spacing:-.03em;margin:14px 0 2px;line-height:1}
.t-price .once{font-size:.9rem;font-weight:500;color:var(--muted);letter-spacing:0}
.tier.feat .t-price .once{color:#9a9a92}
.t-sub{font-size:1.05rem;font-weight:600;color:var(--ink);margin-bottom:12px}
.t-desc{font-size:.96rem;color:#4a4a44;margin-bottom:26px;flex:1}
.tier.feat .t-desc{color:#bdbdb6}
.tier .btn{width:100%;justify-content:center}

/* stats */
.stats{background:var(--black-deep);color:var(--bg);padding:100px 0}
.stats .eyebrow{color:var(--lime)}.stats .eyebrow::before{background:var(--lime)}
.stats h2{font-size:clamp(1.8rem,3.6vw,2.8rem);color:var(--white);max-width:20ch;margin:16px 0 64px}
.stats h2 em{font-style:italic;color:var(--lime)}
.stat-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.stat{border-top:2px solid rgba(194,232,79,.35);padding-top:24px}
.stat .val{font-size:clamp(2.6rem,4.6vw,3.9rem);font-weight:700;line-height:1;color:var(--white);letter-spacing:-.03em}
.stat .val .suf,.stat .val .pre{color:var(--lime)}
.stat .desc{font-size:14px;color:#9a9a92;margin-top:13px;max-width:24ch}

/* results */
.result-inner{display:grid;grid-template-columns:.95fr 1.05fr;gap:60px;align-items:center}
.result-card{background:var(--ink);border-radius:26px;padding:48px 44px;color:var(--bg);position:relative;overflow:hidden}
.result-card .glow{position:absolute;width:300px;height:300px;border-radius:50%;background:radial-gradient(circle,var(--lime),transparent 70%);filter:blur(46px);opacity:.4;bottom:-100px;right:-80px}
.result-big{font-size:clamp(3.6rem,8vw,6.2rem);font-weight:700;line-height:.9;color:var(--lime);position:relative;letter-spacing:-.04em}
.result-card .rlabel{font-size:1.15rem;margin-top:12px;color:var(--white);position:relative;max-width:24ch}
.result-meta{display:flex;gap:28px;margin-top:34px;position:relative;flex-wrap:wrap}
.result-meta .k{font-size:12px;letter-spacing:.12em;text-transform:uppercase;color:#9a9a92;display:block}
.result-meta .v{font-weight:700;font-size:1.15rem;margin-top:4px;display:block}
.result-copy h2{font-size:clamp(1.8rem,3.6vw,2.9rem);margin:14px 0 18px}
.result-copy h2 em{font-style:italic;color:var(--lime-dim)}
.result-copy p{color:#42423c;margin-bottom:20px}
.tick-list{list-style:none;display:grid;gap:13px;margin-bottom:28px}
.tick-list li{display:flex;gap:12px;align-items:flex-start;font-size:1rem;color:#33332c}
.tick-list .tk{flex:none;width:23px;height:23px;border-radius:50%;background:var(--lime);color:var(--ink);display:grid;place-items:center;font-size:12px;font-weight:800;margin-top:2px}

/* industries */
.ind-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.ind{position:relative;border:1px solid var(--line);border-radius:15px;padding:32px 28px;background:var(--white);overflow:hidden;transition:transform .5s var(--ease),background .5s,color .5s}
.ind:hover{transform:translateY(-6px);background:var(--ink);color:var(--bg)}
.ind-no{font-size:13px;color:var(--lime-dim);font-weight:700}
.ind h3{font-size:1.3rem;margin:14px 0 8px}
.ind p{font-size:.94rem;color:#4a4a44;transition:color .5s}
.ind:hover p{color:#bdbdb6}
.ind:hover .ind-no{color:var(--lime)}

/* why / process */
.process{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;counter-reset:step}
.step{position:relative;padding-top:38px}
.step::before{counter-increment:step;content:"0" counter(step);font-size:3rem;font-weight:800;color:var(--bg-soft);position:absolute;top:-12px;left:0;z-index:0;letter-spacing:-.04em}
.step-body{position:relative;z-index:1}
.step h3{font-size:1.22rem;margin-bottom:9px}
.step p{font-size:.96rem;color:#4a4a44}
.step .line{height:2px;background:var(--lime-dim);width:34px;margin-bottom:16px}

/* testimonials */
.testi-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.testi{background:var(--white);border:1px solid var(--line);border-radius:var(--radius);padding:34px 32px;transition:transform .5s var(--ease),box-shadow .5s}
.testi:hover{transform:translateY(-6px);box-shadow:0 24px 50px -34px rgba(0,0,0,.4)}
.stars{color:var(--lime-dim);letter-spacing:2px;margin-bottom:16px;font-size:15px}
.testi blockquote{font-size:1.1rem;line-height:1.5;font-weight:500;margin-bottom:24px;color:var(--ink)}
.testi .hc-num{font-size:13px;font-weight:800;color:var(--lime-dim);letter-spacing:.04em;margin-bottom:12px}
.testi h3{font-size:1.28rem;margin-bottom:10px}
.testi p{font-size:.98rem;color:#4a4a44;line-height:1.55}
.testi .who{display:flex;align-items:center;gap:13px}
.avatar{width:44px;height:44px;border-radius:50%;background:var(--ink);color:var(--lime);display:grid;place-items:center;font-weight:700;font-size:1.05rem}
.who .n{font-weight:600;font-size:14.5px}
.who .r{font-size:12.5px;color:var(--muted)}

/* cta */
.cta{margin:0 16px 16px}
.cta-inner{background:var(--black);border-radius:34px;padding:96px 48px;text-align:center;position:relative;overflow:hidden}
.cta .blob{opacity:.35}
.cta h2{font-size:clamp(2rem,5.2vw,4.2rem);color:var(--white);position:relative;margin-bottom:20px}
.cta h2 em{font-style:italic;color:var(--lime)}
.cta p{color:#bdbdb6;max-width:50ch;margin:0 auto 34px;position:relative;font-size:1.08rem}
.cta-actions{display:flex;gap:14px;justify-content:center;flex-wrap:wrap;position:relative}

/* footer */
footer{background:var(--black-deep);color:var(--bg);padding:74px 0 34px}
.foot-top{display:grid;grid-template-columns:1.6fr 1fr 1fr 1.2fr;gap:40px;padding-bottom:50px;border-bottom:1px solid rgba(255,255,255,.1)}
.foot-brand .logo-img{height:40px;margin-bottom:18px}
.foot-brand p{color:#9a9a92;max-width:34ch;font-size:14.5px}
.foot-col h4{font-size:12px;letter-spacing:.14em;text-transform:uppercase;color:var(--lime);margin-bottom:16px;font-weight:700}
.foot-col ul{list-style:none;display:grid;gap:10px}
.foot-col a,.foot-col li{color:#c4c4bc;font-size:14.5px;transition:color .3s,padding-left .3s}
.foot-col a:hover{color:var(--lime);padding-left:5px}
.foot-bottom{display:flex;justify-content:space-between;align-items:center;padding-top:26px;flex-wrap:wrap;gap:14px}
.foot-bottom p{font-size:13.5px;color:#7d7d76}
.foot-bottom .links{display:flex;gap:20px}
.foot-bottom .links a{font-size:13.5px;color:#9a9a92;transition:color .3s}
.foot-bottom .links a:hover{color:var(--lime)}

@media(max-width:1024px){
  .band-inner,.result-inner{grid-template-columns:1fr;gap:42px}
  .stat-grid{grid-template-columns:repeat(2,1fr);gap:38px 24px}
  .process,.ind-grid,.testi-grid,.price-grid{grid-template-columns:1fr 1fr}
  .foot-top{grid-template-columns:1fr 1fr;gap:32px}
}
@media(max-width:720px){
  .wrap{padding:0 22px}
  .nav-links{display:none}
  .nav-cta .btn-ghost{display:none}
  .burger{display:flex}
  .nav{width:calc(100% - 36px)}
  .hero{padding:140px 0 64px}
  .services,.ind-grid,.testi-grid,.stat-grid,.process,.price-grid{grid-template-columns:1fr}
  .card.wide{flex-direction:column;align-items:flex-start}
  .band-inner,.cta-inner{padding:60px 26px}
  .band,.cta{margin:0 8px}
  .result-card{padding:38px 28px}
  .sec{padding:78px 0}
  .foot-top{grid-template-columns:1fr 1fr}
  .foot-brand{grid-column:span 2}
}
.mobile-menu{position:fixed;inset:0;background:var(--black);z-index:999;display:flex;flex-direction:column;justify-content:center;align-items:center;gap:26px;transform:translateY(-100%);transition:transform .6s var(--ease)}
.mobile-menu.open{transform:none}
.mobile-menu a{font-size:1.9rem;font-weight:700;color:var(--white)}
.mobile-menu a:hover{color:var(--lime)}

/* white WhatsApp button */
.btn-white{background:var(--white);color:var(--ink)}
.btn-white:hover{transform:translateY(-3px);box-shadow:0 16px 36px -14px rgba(0,0,0,.45)}

/* quote builder */
.quote-grid{display:grid;grid-template-columns:1.15fr .85fr;gap:26px;align-items:start}
.quote-options{display:grid;gap:26px}
.q-block .q-h{font-size:13px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--ink);margin-bottom:14px;display:flex;align-items:center;gap:10px}
.q-block .q-h span{font-size:10.5px;background:var(--bg-soft);color:var(--muted);padding:3px 9px;border-radius:100px;letter-spacing:.08em}
.opt-row{display:grid;gap:12px}
.opt-row.cols{grid-template-columns:1fr 1fr}
.opt{position:relative;text-align:left;background:var(--white);border:1.5px solid var(--line);border-radius:14px;padding:15px 17px;cursor:pointer;font-family:inherit;transition:border-color .3s,transform .3s var(--ease),box-shadow .3s;display:flex;justify-content:space-between;align-items:center;gap:14px}
.opt:hover{transform:translateY(-2px);box-shadow:0 14px 30px -22px rgba(0,0,0,.4)}
.opt>span:first-child{display:flex;flex-direction:column}
.opt .o-name{font-weight:600;font-size:14.5px;color:var(--ink)}
.opt .o-desc{font-size:12px;color:var(--muted);margin-top:2px}
.opt .o-amt{font-weight:700;font-size:14.5px;color:var(--ink);white-space:nowrap}
.opt .o-amt small{font-weight:500;color:var(--muted);font-size:11px}
.opt .o-check{position:absolute;top:-9px;right:-9px;width:24px;height:24px;border-radius:50%;background:var(--lime);color:var(--ink);display:grid;place-items:center;font-size:13px;font-weight:800;opacity:0;transform:scale(.4);transition:.3s var(--ease)}
.opt.sel{border-color:var(--ink)}
.opt.sel .o-check{opacity:1;transform:scale(1)}
.qs-card{background:var(--ink);color:var(--bg);border-radius:20px;padding:30px 28px;position:sticky;top:96px}
.qs-card h4{color:#fff;font-size:1.15rem;margin-bottom:16px}
.qs-lines{display:grid;gap:9px;min-height:46px;margin-bottom:4px}
.qs-empty{color:#8d8d86;font-size:14px}
.qs-line{display:flex;justify-content:space-between;gap:12px;font-size:13.5px;color:#d9d9d2;border-bottom:1px dashed rgba(255,255,255,.12);padding-bottom:8px}
.qs-line .ql-amt{color:#fff;font-weight:600;white-space:nowrap}
.qs-line .ql-amt small{color:#9a9a92;font-weight:500}
.qs-tot{margin:16px 0 18px;border-top:1px solid rgba(255,255,255,.18);padding-top:14px;display:grid;gap:9px}
.qs-row{display:flex;justify-content:space-between;align-items:baseline;font-size:13.5px;color:#b6b6ae}
.qs-row strong{font-size:1.5rem;color:var(--lime);font-weight:700;letter-spacing:-.02em}
.qs-row.month strong{font-size:1.1rem;color:#fff}
.qs-fields{display:grid;gap:9px;margin-bottom:14px}
.qs-fields input{width:100%;background:rgba(255,255,255,.06);border:1.5px solid rgba(255,255,255,.14);border-radius:10px;padding:12px 14px;color:#fff;font-family:inherit;font-size:14px;transition:border-color .3s}
.qs-fields input::placeholder{color:#9a9a92}
.qs-fields input:focus{outline:none;border-color:var(--lime)}
.qs-note{font-size:12.5px;margin-top:12px;text-align:center;min-height:16px;line-height:1.45}
.qs-note.ok{color:var(--lime)}
.qs-note.err{color:#ff9b7a}
.qs-fine{font-size:11px;color:#8d8d86;margin-top:14px;line-height:1.5}
@media(max-width:860px){.quote-grid{grid-template-columns:1fr}.qs-card{position:static}.opt-row.cols{grid-template-columns:1fr}}


/* nav services dropdown */
.nav-links li.has-drop{position:relative}
.nav-links .drop-toggle{display:inline-flex;align-items:center;gap:7px}
.nav-links .drop-toggle::after{content:"";width:6px;height:6px;border-right:2px solid currentColor;border-bottom:2px solid currentColor;transform:rotate(45deg);margin-top:-3px;opacity:.55;transition:transform .3s,margin .3s}
.nav-links li.has-drop:hover .drop-toggle::after{transform:rotate(225deg);margin-top:2px}
.dropdown{position:absolute;top:100%;left:50%;transform:translateX(-50%) translateY(8px);margin-top:14px;background:var(--white);border:1px solid var(--line);border-radius:16px;padding:10px;min-width:246px;box-shadow:0 22px 54px -26px rgba(0,0,0,.55);opacity:0;visibility:hidden;transition:.32s var(--ease);display:grid;gap:2px;z-index:60}
.dropdown::before{content:"";position:absolute;top:-16px;left:0;right:0;height:16px}
.nav-links li.has-drop:hover .dropdown{opacity:1;visibility:visible;transform:translateX(-50%) translateY(0)}
.dropdown a{padding:11px 14px;border-radius:10px;font-size:14.5px;font-weight:600;color:var(--ink);opacity:1;display:flex;flex-direction:column;gap:1px;transition:background .25s,padding .25s}
.dropdown a::after{display:none}
.dropdown a span{font-size:12px;color:var(--muted);font-weight:500}
.dropdown a:hover{background:var(--bg-soft);padding-left:18px}
@media(max-width:720px){.mobile-menu{gap:18px}.mobile-menu a{font-size:1.45rem}}

/* mobile column fixes */
.process.cols-4{grid-template-columns:repeat(4,1fr)}@media(max-width:1024px){.process.cols-4{grid-template-columns:repeat(2,1fr)}}@media(max-width:720px){.process.cols-4{grid-template-columns:1fr}}.tick-list.cols-2{grid-template-columns:1fr 1fr;gap:16px 34px;max-width:none}@media(max-width:560px){.tick-list.cols-2{grid-template-columns:1fr}}
@media(max-width:720px){.sec{padding:64px 0}.band-inner{padding:42px 24px;gap:28px}.band{margin:0 12px;border-radius:24px}.tier{margin-top:10px}}@media(max-width:720px){.card.wide{grid-column:auto}}
/* faq */
.faq{display:grid;max-width:840px}.faq-item{border-bottom:1px solid var(--line);padding:22px 0}.faq-item:first-child{border-top:1px solid var(--line)}.faq-item h3{font-size:1.12rem;margin-bottom:8px}.faq-item p{color:#4a4a44;font-size:1rem}

/* case studies */
.cases{display:grid;gap:64px}.case{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:center}.case:nth-child(even) .case-media{order:2}.case-media{position:relative;border-radius:20px;overflow:hidden;border:1px solid var(--line);aspect-ratio:4/3;background:var(--bg-soft)}.case-media img{width:100%;height:100%;object-fit:cover;display:block}.case-tag{display:inline-flex;align-items:center;gap:9px;font-size:12px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--lime-dim)}.case-tag::before{content:"";width:9px;height:9px;background:var(--lime-dim);transform:rotate(45deg)}.case-body h3{font-size:clamp(1.5rem,3vw,2.2rem);margin:14px 0 14px}.case-body p{color:#42423c;margin-bottom:22px}.case-stats{display:flex;gap:30px;flex-wrap:wrap;margin-bottom:24px}.case-stat .v{font-size:1.7rem;font-weight:700;color:var(--ink);line-height:1;letter-spacing:-.02em}.case-stat .k{font-size:12.5px;color:var(--muted);margin-top:5px}@media(max-width:860px){.case{grid-template-columns:1fr;gap:24px}.case:nth-child(even) .case-media{order:0}}
