/* ============================================================
   DOMINATE SOLUTIONS — Tampa Web Design
   Shared design system. Edit phone + colors in :root below.
   ============================================================ */
:root{
  /* ⬇⬇⬇ EDIT PHONE HERE — one place, every page updates ⬇⬇⬇ */
  --phone-display:"(813) 336-3190";
  --phone-link:"+18133363190";

  /* ⬇⬇⬇ EDIT COLORS HERE ⬇⬇⬇ */
  --bg:#0D0F0E;--bg-2:#121514;--bg-3:#171B19;
  --card:rgba(255,255,255,.028);--card-2:rgba(255,255,255,.045);
  --line:rgba(255,255,255,.09);--line-2:rgba(255,255,255,.14);
  --green:#1FC168;--green-2:#3BE089;--green-dp:#0E7C4A;--green-wash:#EAF4EE;
  --gold:#D3A747;--gold-2:#F0D08A;          /* brand gold from logo */
  --white:#F4F7F5;--muted:#9AA39E;--muted-2:#6C756F;
  --maxw:1200px;--sh:0 24px 60px rgba(0,0,0,.5);
  --grad-g:linear-gradient(135deg,var(--green-2),var(--green-dp));
  --grad-mix:linear-gradient(135deg,var(--green-2) 0%,var(--green) 45%,var(--gold) 100%);
  --display:'Fraunces',Georgia,serif;
  --body:'Inter',system-ui,sans-serif;
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{font-family:var(--body);background:var(--bg);color:var(--white);line-height:1.6;overflow-x:hidden;-webkit-font-smoothing:antialiased}
h1,h2,h3,h4{font-family:var(--display);line-height:1.06;letter-spacing:-.015em;font-weight:600;color:#fff}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
.wrap{width:100%;max-width:var(--maxw);margin:0 auto;padding:0 20px}
.phone-text::after{content:var(--phone-display)}

/* ambient background */
body::before{content:"";position:fixed;inset:0;z-index:-2;background:
  radial-gradient(60vw 60vw at 78% -8%,rgba(31,193,104,.13),transparent 60%),
  radial-gradient(55vw 55vw at 8% 12%,rgba(211,167,71,.08),transparent 60%),
  radial-gradient(50vw 50vw at 50% 108%,rgba(31,193,104,.1),transparent 60%);pointer-events:none}
body::after{content:"";position:fixed;inset:0;z-index:-1;opacity:.5;pointer-events:none;
  background-image:linear-gradient(var(--line) 1px,transparent 1px),linear-gradient(90deg,var(--line) 1px,transparent 1px);
  background-size:64px 64px;-webkit-mask-image:radial-gradient(ellipse 80% 60% at 50% 0%,#000,transparent 75%);mask-image:radial-gradient(ellipse 80% 60% at 50% 0%,#000,transparent 75%)}

.eyebrow{font-family:var(--body);font-size:.72rem;font-weight:700;letter-spacing:.16em;text-transform:uppercase;color:var(--green-2);display:inline-flex;align-items:center;gap:8px}
.eyebrow::before{content:"";width:20px;height:1.5px;background:var(--gold)}
.eyebrow.c{justify-content:center}
.eyebrow.gold{color:var(--gold-2)}
.italic{font-style:italic;font-weight:400;color:var(--green-2)}
.gg{color:transparent;background:linear-gradient(135deg,var(--gold-2),var(--gold));-webkit-background-clip:text;background-clip:text}
.gmix{color:transparent;background:var(--grad-mix);-webkit-background-clip:text;background-clip:text}

/* buttons */
.btn{font-family:var(--body);font-weight:600;font-size:.98rem;padding:15px 24px;border-radius:100px;transition:transform .22s cubic-bezier(.2,.8,.2,1),box-shadow .22s,background .22s;display:inline-flex;align-items:center;justify-content:center;gap:9px;cursor:pointer;border:0;white-space:nowrap;text-align:center;min-height:48px}
.btn svg{transition:transform .25s}
.btn:hover svg{transform:translateX(4px)}
.btn-green{background:var(--grad-g);color:#04250F;box-shadow:0 10px 30px rgba(31,193,104,.32),inset 0 1px 0 rgba(255,255,255,.3)}
.btn-green:hover{transform:translateY(-2px);box-shadow:0 16px 40px rgba(31,193,104,.45)}
.btn-glass{background:rgba(255,255,255,.06);color:#fff;border:1px solid var(--line-2);backdrop-filter:blur(8px)}
.btn-glass:hover{background:rgba(255,255,255,.11);transform:translateY(-2px)}
.btn-gold{background:linear-gradient(135deg,var(--gold-2),var(--gold));color:#3A2C05;box-shadow:0 10px 30px rgba(211,167,71,.3)}
.btn-gold:hover{transform:translateY(-2px);box-shadow:0 16px 40px rgba(211,167,71,.45)}
.btn.lg{padding:17px 30px;font-size:1.05rem}
.btn.full{width:100%}

/* ===== HEADER / NAV (injected by nav.js) ===== */
.site-head{position:sticky;top:0;z-index:100;transition:.3s}
.site-head.scrolled{background:rgba(13,15,14,.72);backdrop-filter:blur(18px);border-bottom:1px solid var(--line)}
.nav{display:flex;align-items:center;justify-content:space-between;height:82px}
.logo{display:flex;align-items:center;gap:9px}
.logo img{height:46px;width:auto}
.navlinks{display:none}
.nav-actions{display:flex;align-items:center;gap:12px}
.nav-cta{display:none}
.nav-toggle{display:flex;flex-direction:column;gap:5px;background:rgba(255,255,255,.05);border:1px solid var(--line);cursor:pointer;padding:12px;border-radius:11px}
.nav-toggle span{width:20px;height:2px;background:#fff;border-radius:2px;transition:.2s}

/* mobile drawer */
.mobile-nav{position:fixed;inset:0;transform:translateX(100%);background:var(--bg);z-index:200;padding:80px 24px 24px;overflow-y:auto;transition:transform .32s cubic-bezier(.2,.8,.2,1)}
.mobile-nav.open{transform:translateX(0)}
.mobile-nav-close{background:rgba(255,255,255,.05);border:1px solid var(--line);color:#fff;font-size:1.5rem;position:absolute;top:20px;right:20px;cursor:pointer;width:44px;height:44px;border-radius:11px;display:grid;place-items:center;line-height:1}
.m-group{border-bottom:1px solid var(--line)}
.m-item{border-bottom:1px solid var(--line)}
.m-item>a{display:block;font-family:var(--display);font-weight:600;color:#fff;font-size:1.12rem;padding:16px 0}
.mobile-nav-grouptrigger{width:100%;display:flex;align-items:center;justify-content:space-between;background:none;border:0;color:#fff;font-family:var(--display);font-weight:600;font-size:1.12rem;padding:16px 0;cursor:pointer}
.mobile-nav-grouptrigger .chev{transition:.25s;color:var(--green-2)}
.m-group.open .mobile-nav-grouptrigger .chev{transform:rotate(180deg)}
.m-sub{max-height:0;overflow:hidden;transition:max-height .3s ease}
.m-group.open .m-sub{max-height:600px}
.m-sub a{display:block;color:var(--muted);padding:9px 0 9px 14px;font-size:.98rem}
.m-drawer-cta{margin-top:22px}
body.nav-open{overflow:hidden}

/* ===== reveal ===== */
.reveal{opacity:0;transform:translateY(26px);transition:opacity .75s cubic-bezier(.2,.7,.2,1),transform .75s cubic-bezier(.2,.7,.2,1)}
.reveal.in{opacity:1;transform:none}
.d1{transition-delay:.07s}.d2{transition-delay:.14s}.d3{transition-delay:.21s}.d4{transition-delay:.28s}

/* ===== breadcrumbs ===== */
.crumbs{padding:18px 0 0;font-size:.82rem;color:var(--muted-2)}
.crumbs a{color:var(--muted)}
.crumbs a:hover{color:var(--green-2)}
.crumbs span{margin:0 8px;opacity:.5}

/* ===== hero (shared) ===== */
.hero{position:relative;padding:44px 0 34px}
.hero.center{text-align:center}
.rating-chip{display:inline-flex;align-items:center;gap:9px;background:var(--card-2);border:1px solid var(--line);padding:8px 16px;border-radius:100px;font-size:.82rem;font-weight:600;margin-bottom:24px;backdrop-filter:blur(8px)}
.rating-chip .st{color:var(--gold);letter-spacing:1px}
.hero h1{font-size:clamp(2.35rem,8.5vw,4.4rem);font-weight:600;letter-spacing:-.03em;margin-bottom:18px}
.hero p.lede{font-size:1.06rem;color:var(--muted);max-width:600px;margin-bottom:28px}
.hero.center p.lede{margin-left:auto;margin-right:auto}
.hero .cta-row{display:flex;flex-direction:column;gap:12px;align-items:stretch}
.hero.center .cta-row{align-items:center}
.hero .cta-row .btn{width:100%;max-width:340px}
.page-hero{padding:46px 0 10px;text-align:center}
.page-hero h1{font-size:clamp(2.3rem,7.5vw,3.8rem);margin-bottom:16px}
.page-hero p{color:var(--muted);font-size:1.06rem;max-width:600px;margin:0 auto}

/* glass + hero rank card */
.glass{background:linear-gradient(160deg,var(--card-2),var(--card));border:1px solid var(--line);border-radius:22px;backdrop-filter:blur(14px);position:relative;overflow:hidden}
.glass::before{content:"";position:absolute;inset:0;border-radius:22px;padding:1px;background:linear-gradient(160deg,rgba(59,224,137,.4),transparent 40%);-webkit-mask:linear-gradient(#000 0 0) content-box,linear-gradient(#000 0 0);-webkit-mask-composite:xor;mask-composite:exclude;pointer-events:none}
.hero-card{margin:36px auto 0;max-width:520px;position:relative}
.rankcard{padding:20px}
.rc-head{display:flex;align-items:center;justify-content:space-between;padding-bottom:14px;border-bottom:1px solid var(--line);margin-bottom:14px}
.rc-head .u{display:flex;align-items:center;gap:9px;font-size:.82rem;color:var(--muted)}
.rc-head .u b{color:#fff;font-weight:600}
.rc-head .g{width:19px;height:19px;border-radius:50%;background:conic-gradient(from 0deg,#EA4335,#FBBC05,#34A853,#4285F4,#EA4335);flex-shrink:0}
.rc-live{font-size:.7rem;color:var(--green-2);font-weight:700;display:flex;align-items:center;gap:6px}
.rc-live .d{width:6px;height:6px;border-radius:50%;background:var(--green);animation:pulse 2s infinite}
.serp{display:flex;flex-direction:column;gap:8px;text-align:left}
.serp-row{display:flex;align-items:center;gap:12px;padding:12px;border-radius:13px;background:rgba(255,255,255,.03);border:1px solid transparent;transition:.5s cubic-bezier(.2,.8,.2,1)}
.serp-row.dim{opacity:.4}
.serp-row.you{background:linear-gradient(90deg,rgba(31,193,104,.16),rgba(255,255,255,.03));border-color:rgba(31,193,104,.35)}
.rank-n{font-family:var(--display);font-weight:700;font-size:1.1rem;width:22px;color:var(--muted);text-align:center}
.serp-row.you .rank-n{color:var(--green-2)}
.serp-body{flex:1}
.serp-body .t1{height:9px;border-radius:5px;background:rgba(255,255,255,.16);width:66%;margin-bottom:6px}
.serp-body .t2{height:6px;border-radius:4px;background:rgba(255,255,255,.09);width:90%}
.serp-row.you .t1{background:var(--green-2);width:56%}
.serp-row.you .t2{background:rgba(59,224,137,.4);width:76%}
.you-tag{font-size:.62rem;font-weight:800;color:#04250F;background:var(--green-2);padding:4px 8px;border-radius:6px;letter-spacing:.04em}
.rc-foot{margin-top:14px;display:flex;justify-content:space-between;align-items:center;font-size:.8rem;color:var(--muted)}
.rc-foot b{color:var(--green-2);font-weight:700;display:inline-flex;align-items:center;gap:5px}
.float-stat{position:absolute;background:linear-gradient(160deg,#1a1f1c,#141715);border:1px solid var(--line-2);border-radius:15px;padding:12px 15px;box-shadow:var(--sh);z-index:3}
.float-stat .n{font-family:var(--display);font-weight:700;font-size:1.45rem;line-height:1}
.float-stat .l{font-size:.62rem;color:var(--muted);text-transform:uppercase;letter-spacing:.09em;margin-top:4px;font-weight:600}
.fs1{bottom:-20px;left:-8px;animation:bob 5.5s ease-in-out infinite}.fs1 .n{color:var(--green-2)}
.fs2{top:-16px;right:-6px;animation:bob 5.5s ease-in-out infinite .9s}.fs2 .n{color:var(--gold-2)}
@keyframes bob{0%,100%{transform:translateY(0)}50%{transform:translateY(-10px)}}
@keyframes pulse{0%{box-shadow:0 0 0 0 rgba(31,193,104,.5)}70%{box-shadow:0 0 0 8px transparent}100%{box-shadow:0 0 0 0 transparent}}

/* marquee — full-width, seamless infinite scroll (no edge fade, all items visible) */
.marquee-sec{padding:44px 0 8px}
.marquee-lbl{text-align:center;font-size:.72rem;color:var(--muted-2);letter-spacing:.15em;text-transform:uppercase;font-weight:700;margin-bottom:22px}
.marquee{position:relative;overflow:hidden;width:100%}
.mtrack{display:flex;gap:42px;width:max-content;flex-wrap:nowrap;will-change:transform;animation:scroll 34s linear infinite}
.marquee:hover .mtrack{animation-play-state:paused}
/* translate exactly one copy-width (-50% of the 2x track) for a gapless loop */
@keyframes scroll{from{transform:translateX(0)}to{transform:translateX(calc(-50% - 21px))}}
.mtrack .brand{font-family:var(--display);font-weight:600;font-size:1.25rem;color:var(--muted-2);white-space:nowrap;transition:.3s;flex:0 0 auto}
.mtrack .brand:hover{color:var(--gold-2)}

/* sections */
section.blk{padding:70px 0;position:relative}
.sec-head{max-width:640px;margin:0 auto 44px;text-align:center}
.sec-head h2{font-size:clamp(1.9rem,6vw,2.9rem);font-weight:600;margin:14px 0 14px;letter-spacing:-.02em}
.sec-head p{color:var(--muted);font-size:1.02rem}

/* stat strip */
.stat-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.stat{background:linear-gradient(160deg,var(--card-2),var(--card));border:1px solid var(--line);border-radius:18px;padding:24px 18px;text-align:center;position:relative;overflow:hidden}
.stat::before{content:"";position:absolute;top:0;left:22%;right:22%;height:2px;background:linear-gradient(90deg,transparent,var(--gold),transparent);opacity:.7}
.stat .n{font-family:var(--display);font-weight:700;font-size:clamp(2.1rem,9vw,3rem);line-height:1;background:var(--grad-mix);-webkit-background-clip:text;background-clip:text;color:transparent;display:inline-block}
.stat .l{color:var(--muted);font-size:.82rem;margin-top:8px;font-weight:500}

/* services grid + cards */
.svc-grid{display:grid;grid-template-columns:1fr;gap:16px}
.svc{background:linear-gradient(160deg,var(--card-2),var(--card));border:1px solid var(--line);border-radius:20px;padding:26px;transition:.32s cubic-bezier(.2,.8,.2,1);position:relative;overflow:hidden;display:block}
.svc::after{content:"";position:absolute;inset:0;border-radius:20px;padding:1px;background:linear-gradient(160deg,rgba(59,224,137,.5),transparent 45%);-webkit-mask:linear-gradient(#000 0 0) content-box,linear-gradient(#000 0 0);-webkit-mask-composite:xor;mask-composite:exclude;opacity:0;transition:.32s}
.svc:hover{transform:translateY(-5px);border-color:transparent;background:linear-gradient(160deg,rgba(31,193,104,.08),var(--card))}
.svc:hover::after{opacity:1}
.svc .ic{width:56px;height:56px;border-radius:16px;background:var(--grad-g);display:grid;place-items:center;color:#04250F;margin-bottom:20px;box-shadow:0 10px 24px rgba(31,193,104,.3),inset 0 1px 0 rgba(255,255,255,.4);transition:.32s}
.svc.gold .ic{background:linear-gradient(135deg,var(--gold-2),var(--gold));color:#3A2C05;box-shadow:0 10px 24px rgba(211,167,71,.32),inset 0 1px 0 rgba(255,255,255,.45)}
.svc.gold::after{background:linear-gradient(160deg,rgba(240,208,138,.55),transparent 45%)}
.svc.gold:hover{background:linear-gradient(160deg,rgba(211,167,71,.09),var(--card))}
.svc.gold .more{color:var(--gold-2)}
.svc:hover .ic{transform:rotate(-6deg) scale(1.06)}
.svc .no{position:absolute;top:24px;right:26px;font-family:var(--display);font-size:.95rem;color:var(--muted-2);font-weight:600}
.svc h3{font-size:1.28rem;margin-bottom:9px;font-weight:600}
.svc p{color:var(--muted);font-size:.94rem}
.svc .more{display:inline-flex;align-items:center;gap:7px;margin-top:16px;font-weight:600;font-size:.86rem;color:var(--green-2);transition:gap .25s}
.svc:hover .more{gap:12px}

/* showcase scroller — real website screenshots in a browser frame, seamless infinite */
.showcase{overflow:hidden;width:100%}
.show-track{display:flex;gap:22px;width:max-content;flex-wrap:nowrap;will-change:transform;animation:showscroll 60s linear infinite}
.showcase:hover .show-track{animation-play-state:paused}
@keyframes showscroll{from{transform:translateX(0)}to{transform:translateX(calc(-50% - 11px))}}
.mock{flex:0 0 auto;width:330px;border-radius:16px;overflow:hidden;border:1px solid var(--line);background:var(--bg-3);box-shadow:var(--sh)}
.mock .bar{height:34px;display:flex;align-items:center;gap:6px;padding:0 13px;background:rgba(255,255,255,.05);border-bottom:1px solid var(--line)}
.mock .bar i{width:9px;height:9px;border-radius:50%;background:rgba(255,255,255,.2)}
.mock .bar i:nth-child(1){background:#ff5f57}.mock .bar i:nth-child(2){background:#febc2e}.mock .bar i:nth-child(3){background:#28c840}
.mock .bar .u{margin-left:10px;flex:1;height:16px;border-radius:5px;background:rgba(255,255,255,.08);display:flex;align-items:center;padding:0 9px;font-size:.62rem;color:var(--muted-2);font-weight:500;overflow:hidden;white-space:nowrap}
.mock .shot{display:block;width:100%;height:210px;object-fit:cover;object-position:top center;background:linear-gradient(160deg,#171B19,#0E7C4A)}
.mock .cap{padding:13px 15px;display:flex;align-items:center;justify-content:space-between;border-top:1px solid var(--line)}
.mock .cap .nm{font-size:.85rem;font-weight:600;color:#fff}
.mock .cap .tg{font-size:.68rem;color:var(--muted-2);text-transform:uppercase;letter-spacing:.06em;font-weight:600}

/* results */
.res-grid{display:grid;grid-template-columns:1fr;gap:16px}
.res{background:linear-gradient(160deg,var(--card-2),var(--card));border:1px solid var(--line);border-radius:20px;padding:28px;position:relative;overflow:hidden}
.res .tag{font-size:.7rem;color:var(--gold);font-weight:700;letter-spacing:.08em;text-transform:uppercase}
.res .big{font-family:var(--display);font-weight:700;font-size:3rem;line-height:1;margin:14px 0 4px;background:var(--grad-mix);-webkit-background-clip:text;background-clip:text;color:transparent;display:inline-block}
.res .metric{font-size:.92rem;color:#fff;font-weight:600}
.res .transform{display:flex;align-items:center;gap:10px;margin-top:16px;font-size:.84rem;color:var(--muted)}
.res .transform .from{color:var(--muted-2);text-decoration:line-through}
.res .transform .to{color:var(--green-2);font-weight:600}
.res .transform svg{color:var(--gold)}

/* testimonial streams */
.tsurf{overflow:hidden;-webkit-mask-image:linear-gradient(90deg,transparent,#000 8%,#000 92%,transparent);mask-image:linear-gradient(90deg,transparent,#000 8%,#000 92%,transparent)}
.tstream{display:flex;gap:16px;width:max-content;animation:scroll 40s linear infinite}
.tstream.rev{animation-direction:reverse;animation-duration:48s}
.tsurf:hover .tstream{animation-play-state:paused}
.tcard{flex:0 0 auto;width:300px;background:linear-gradient(160deg,var(--card-2),var(--card));border:1px solid var(--line);border-radius:18px;padding:22px}
.tcard .st{color:var(--gold);letter-spacing:1px;font-size:.85rem;margin-bottom:12px}
.tcard p{font-size:.92rem;color:var(--white);line-height:1.55;margin-bottom:16px}
.tcard .who{display:flex;align-items:center;gap:11px}
.tcard .who .av{width:38px;height:38px;border-radius:50%;background:var(--grad-g);display:grid;place-items:center;color:#04250F;font-weight:700;font-size:.8rem}
.tcard .who .nm{font-size:.86rem;font-weight:600;color:#fff}
.tcard .who .ro{font-size:.74rem;color:var(--muted-2)}

/* why + compare */
.why-list{display:flex;flex-direction:column;max-width:640px;margin:0 auto 40px}
.why-item{display:flex;gap:16px;padding:20px 0;border-top:1px solid var(--line)}
.why-item:first-child{border-top:0}
.why-item .ck{flex-shrink:0;width:42px;height:42px;border-radius:12px;background:var(--grad-g);display:grid;place-items:center;color:#04250F;box-shadow:0 8px 20px rgba(31,193,104,.28)}
.why-item h4{font-size:1.14rem;margin-bottom:5px;font-weight:600;color:#fff}
.why-item p{color:var(--muted);font-size:.94rem}
.compare{max-width:720px;margin:0 auto;background:linear-gradient(160deg,var(--card-2),var(--card));border:1px solid var(--line);border-radius:20px;overflow:hidden}
.crow{display:grid;grid-template-columns:1.6fr 1fr 1fr;align-items:center;padding:15px 16px;border-top:1px solid var(--line);font-size:.86rem}
.crow:first-child{border-top:0}
.crow.hd{background:rgba(255,255,255,.03);font-weight:600}
.crow.hd .us{color:var(--green-2);font-family:var(--display)}
.crow .lbl{color:var(--white);font-weight:500}
.crow .c{text-align:center}
.crow .yes{color:var(--green-2)}
.crow .no{color:var(--muted-2)}
.crow .us-col{text-align:center}

/* process */
.proc-list{max-width:640px;margin:0 auto;display:flex;flex-direction:column}
.proc{display:flex;gap:18px;padding:22px 0;border-top:1px solid var(--line)}
.proc:first-child{border-top:0}
.proc .dot{flex-shrink:0;width:48px;height:48px;border-radius:14px;border:1px solid var(--line-2);background:var(--card-2);display:grid;place-items:center;font-family:var(--display);font-weight:700;font-size:1.15rem;color:var(--green-2)}
.proc h4{font-size:1.16rem;margin-bottom:6px;font-weight:600;color:#fff}
.proc p{color:var(--muted);font-size:.93rem}

/* faq */
.faq-list{max-width:720px;margin:0 auto}
.faq-item{border:1px solid var(--line);border-radius:15px;margin-bottom:11px;background:var(--card);overflow:hidden;transition:.25s}
.faq-item.open{border-color:rgba(31,193,104,.4);background:var(--card-2)}
.faq-q{width:100%;list-style:none;cursor:pointer;padding:19px 20px;font-family:var(--display);font-weight:600;font-size:1.06rem;color:#fff;display:flex;justify-content:space-between;align-items:center;gap:14px;background:none;border:0;text-align:left}
.faq-q-icon{flex-shrink:0;width:28px;height:28px;border-radius:50%;border:1.5px solid var(--line-2);color:var(--green-2);display:grid;place-items:center;font-size:1.2rem;line-height:1;transition:.3s}
.faq-item.open .faq-q-icon{transform:rotate(135deg);background:var(--green);color:#04250F;border-color:var(--green)}
.faq-a{max-height:0;overflow:hidden;transition:max-height .3s ease}
.faq-item.open .faq-a{max-height:400px}
.faq-a p{padding:0 20px 20px;color:var(--muted);font-size:.95rem}

/* content prose (service/city/about/blog) */
.prose{max-width:760px;margin:0 auto}
.prose h2{font-size:clamp(1.6rem,4.5vw,2.2rem);margin:36px 0 14px}
.prose h3{font-size:1.28rem;margin:28px 0 10px;color:#fff}
.prose p{color:var(--muted);margin-bottom:14px}
.prose ul{list-style:none;margin:0 0 18px}
.prose li{color:var(--muted);padding:9px 0 9px 28px;position:relative;border-bottom:1px solid var(--line)}
.prose li::before{content:"";position:absolute;left:0;top:17px;width:14px;height:8px;border-left:2px solid var(--green-2);border-bottom:2px solid var(--green-2);transform:rotate(-45deg)}
.prose li strong{color:var(--white)}
.prose a{color:var(--green-2);text-decoration:underline}

/* two-col content on services/city */
.content-split{display:grid;grid-template-columns:1fr;gap:32px}
.sidebar{display:flex;flex-direction:column;gap:16px}
.side-card{background:linear-gradient(160deg,var(--card-2),var(--card));border:1px solid var(--line);border-radius:18px;padding:24px}
.side-card h4{font-size:1.1rem;margin-bottom:12px}
.side-card p{color:var(--muted);font-size:.9rem;margin-bottom:14px}

/* related grid */
.related-grid{display:grid;grid-template-columns:1fr;gap:14px;margin-top:20px}
.related-card{background:linear-gradient(160deg,var(--card-2),var(--card));border:1px solid var(--line);border-radius:16px;padding:22px;transition:.28s;display:block}
.related-card:hover{transform:translateY(-4px);border-color:transparent;background:linear-gradient(160deg,rgba(31,193,104,.08),var(--card))}
.related-card-eyebrow{font-size:.68rem;color:var(--gold);font-weight:700;letter-spacing:.08em;text-transform:uppercase}
.related-card h4{font-size:1.1rem;margin:8px 0 6px}
.related-card p{color:var(--muted);font-size:.88rem;margin-bottom:10px}
.related-card-link{color:var(--green-2);font-weight:600;font-size:.85rem}

/* quote form */
.quote-form{max-width:560px;margin:0 auto;background:linear-gradient(160deg,var(--card-2),var(--card));border:1px solid var(--line);border-radius:22px;padding:28px 24px}
.quote-form .fg{margin-bottom:16px}
.quote-form label{display:block;font-size:.84rem;font-weight:600;color:#fff;margin-bottom:7px}
.quote-form input,.quote-form select,.quote-form textarea{width:100%;padding:14px 15px;background:rgba(255,255,255,.04);border:1px solid var(--line-2);border-radius:12px;color:#fff;font-family:var(--body);font-size:.98rem;transition:.2s}
.quote-form input:focus,.quote-form select:focus,.quote-form textarea:focus{outline:0;border-color:var(--green);background:rgba(31,193,104,.06)}
.quote-form textarea{resize:vertical;min-height:100px}
.quote-form .hp{position:absolute;left:-9999px}
.form-note{font-size:.78rem;color:var(--muted-2);text-align:center;margin-top:12px}
.form-msg{display:none;padding:16px;border-radius:12px;margin-bottom:16px;font-size:.92rem}
.form-msg.ok{display:block;background:rgba(31,193,104,.12);border:1px solid rgba(31,193,104,.4);color:var(--green-2)}
.form-msg.err{display:block;background:rgba(255,90,90,.1);border:1px solid rgba(255,90,90,.35);color:#ff8a8a}

/* booking CTA */
.cta-band{position:relative;border-radius:28px;padding:36px 22px;overflow:hidden;background:linear-gradient(160deg,#12332390,#0d1a14 60%),radial-gradient(circle at 50% -20%,rgba(31,193,104,.28),transparent 60%);border:1px solid var(--line-2)}
.cta-band::before{content:"";position:absolute;inset:0;border-radius:28px;padding:1.5px;background:linear-gradient(135deg,var(--gold-2),var(--green-2) 45%,transparent 75%);-webkit-mask:linear-gradient(#000 0 0) content-box,linear-gradient(#000 0 0);-webkit-mask-composite:xor;mask-composite:exclude;pointer-events:none}
.cta-band::after{content:"";position:absolute;bottom:-40%;right:-10%;width:60%;height:100%;background:radial-gradient(circle,rgba(211,167,71,.16),transparent 62%);pointer-events:none}
.cta-inner{position:relative;z-index:2;display:flex;flex-direction:column;gap:28px}
.cta-copy .eyebrow{color:var(--gold-2)}.cta-copy .eyebrow::before{background:var(--gold-2)}
.cta-copy h2{font-size:clamp(2rem,7vw,3rem);font-weight:600;margin:14px 0 14px;color:#fff}
.cta-copy p{font-size:1.02rem;color:var(--muted);max-width:460px}
.cta-checks{list-style:none;margin:22px 0 0;display:flex;flex-direction:column;gap:12px}
.cta-checks li{display:flex;align-items:center;gap:11px;font-size:.94rem;color:var(--white);font-weight:500}
.cta-checks .ck{flex-shrink:0;width:24px;height:24px;border-radius:7px;background:var(--grad-g);display:grid;place-items:center;color:#04250F}
.cta-copy .rating{margin-top:24px;display:flex;align-items:center;gap:12px}
.cta-copy .rating .st{color:var(--gold);letter-spacing:1px;font-size:.9rem}
.cta-copy .rating small{display:block;color:var(--muted);font-size:.78rem;margin-top:1px}
.book-card{background:linear-gradient(160deg,#ffffff,#f4f7f4);border-radius:22px;padding:26px 22px;box-shadow:var(--sh);position:relative}
.book-card .bc-head{display:flex;align-items:center;gap:12px;padding-bottom:18px;border-bottom:1px solid #E7EAE7;margin-bottom:18px}
.book-card .bc-ic{width:46px;height:46px;border-radius:13px;background:var(--grad-g);display:grid;place-items:center;color:#04250F;box-shadow:0 8px 20px rgba(31,193,104,.3)}
.book-card .bc-head .t{font-family:var(--display);font-weight:600;font-size:1.14rem;color:#0D0F0E;line-height:1.15}
.book-card .bc-head .s{font-size:.8rem;color:#6C756F;margin-top:2px}
.book-card .slots{display:flex;flex-direction:column;gap:9px;margin-bottom:18px}
.book-card .slot{display:flex;align-items:center;justify-content:space-between;padding:13px 15px;border:1px solid #E4E7E3;border-radius:12px;background:#fff;cursor:pointer;transition:.18s}
.book-card .slot:hover{border-color:var(--green);background:#F1FAF4;transform:translateY(-1px)}
.book-card .slot .day{font-weight:600;font-size:.9rem;color:#0D0F0E}
.book-card .slot .day span{display:block;font-size:.74rem;color:#6C756F;font-weight:500;margin-top:1px}
.book-card .slot .time{font-size:.82rem;font-weight:600;color:var(--green-dp);background:var(--green-wash);padding:5px 10px;border-radius:7px}
.book-card .slot.soon .time{color:#8a6f2c;background:#F7F0DE}
.book-card .bc-btn{width:100%;justify-content:center}
.book-card .bc-foot{text-align:center;font-size:.78rem;color:#6C756F;margin-top:13px;display:flex;align-items:center;justify-content:center;gap:7px}
.book-card .bc-foot .d{width:6px;height:6px;border-radius:50%;background:var(--green);animation:pulse 2s infinite}

/* footer (injected) */
.site-foot{background:var(--bg-2);border-top:1px solid var(--line);padding:50px 0 30px}
.foot-grid{display:grid;grid-template-columns:1fr;gap:30px;margin-bottom:36px}
.foot-brand img{height:60px;width:auto;margin-bottom:16px}
.foot-brand p{font-size:.92rem;color:var(--muted);max-width:300px}
.foot-col h5{font-family:var(--body);font-size:.74rem;letter-spacing:.12em;text-transform:uppercase;color:#fff;margin-bottom:14px;font-weight:700}
.foot-col a{display:block;font-size:.92rem;color:var(--muted);padding:6px 0;transition:.15s}
.foot-col a:hover{color:var(--green-2)}
.foot-phone{color:var(--gold-2)!important;font-weight:600}
.foot-bot{border-top:1px solid var(--line);padding-top:24px;display:flex;flex-direction:column;gap:10px;font-size:.82rem;color:var(--muted-2);text-align:center}

/* sticky call bar */
.call-bar{display:flex;position:fixed;bottom:0;left:0;right:0;z-index:99;background:rgba(13,15,14,.9);backdrop-filter:blur(16px);border-top:1px solid var(--line);padding:10px 14px;gap:10px}
.call-bar a{flex:1;text-align:center;font-family:var(--body);font-weight:600;padding:14px;border-radius:100px;font-size:.9rem;min-height:48px;display:flex;align-items:center;justify-content:center;gap:8px}
.cb-call{background:rgba(255,255,255,.06);color:#fff;border:1px solid var(--line-2)}
.cb-quote{background:var(--grad-g);color:#04250F}
body{padding-bottom:70px}

/* ===== TABLET ===== */
@media(min-width:700px){
  .wrap{padding:0 32px}
  .hero{padding:64px 0 44px}
  .hero.split .hero-inner{display:grid;grid-template-columns:1.05fr .95fr;gap:48px;align-items:center}
  .hero .cta-row{flex-direction:row;align-items:center}
  .hero .cta-row .btn{width:auto}
  .hero.split .hero-card{margin:0}
  .stat-grid{grid-template-columns:repeat(4,1fr)}
  .svc-grid{grid-template-columns:1fr 1fr}
  .res-grid{grid-template-columns:1fr 1fr}
  .related-grid{grid-template-columns:1fr 1fr}
  .mock{width:340px}
  .foot-grid{grid-template-columns:1.6fr 1fr 1fr 1fr;gap:40px}
  .foot-bot{flex-direction:row;justify-content:space-between;text-align:left}
  .content-split{grid-template-columns:1.7fr 1fr;gap:44px;align-items:start}
  .sidebar{position:sticky;top:90px}
  .cta-band{padding:56px 52px}
  .cta-inner{flex-direction:row;align-items:center;gap:52px}
  .cta-copy{flex:1}.book-card{flex:0 0 380px}
  section.blk{padding:92px 0}
}
/* ===== DESKTOP ===== */
@media(min-width:900px){
  .nav-toggle,.mobile-nav{display:none!important}
  .call-bar{display:none}
  body{padding-bottom:0}
}
@media(min-width:980px){
  .nav{height:94px}
  .logo img{height:56px}
  .navlinks{display:flex;align-items:center;gap:2px;list-style:none}
  .navlinks>li{position:relative}
  .navlinks>li>a,.nav-dropdown-trigger{display:flex;align-items:center;gap:6px;padding:10px 14px;font-weight:500;font-size:.92rem;color:var(--muted);border-radius:10px;transition:.18s;background:none;border:0;cursor:pointer;font-family:var(--body)}
  .navlinks>li>a:hover,.nav-dropdown-trigger:hover{color:#fff;background:rgba(255,255,255,.05)}
  .navlinks>li>a.active,.nav-dropdown.active .nav-dropdown-trigger{color:var(--green-2)}
  .caret{width:7px;height:7px;border-right:2px solid var(--muted-2);border-bottom:2px solid var(--muted-2);transform:rotate(45deg);margin-top:-3px;transition:.25s}
  .nav-dropdown.open .caret{transform:rotate(-135deg);margin-top:2px;border-color:var(--green-2)}
  .nav-dropdown-menu{position:absolute;top:calc(100% + 14px);left:50%;transform:translateX(-50%) translateY(8px);background:var(--bg-2);border:1px solid var(--line);border-radius:18px;padding:12px;box-shadow:var(--sh);opacity:0;visibility:hidden;transition:opacity .22s,visibility .22s,transform .22s;z-index:50}
  .nav-dropdown.open .nav-dropdown-menu{opacity:1;visibility:visible;transform:translateX(-50%) translateY(0)}
  .nav-dropdown-menu::before{content:"";position:absolute;top:-14px;left:0;right:0;height:14px}
  .nav-dropdown-menu.services{width:540px;display:grid;grid-template-columns:1fr 1fr;gap:4px}
  .nav-dropdown-menu.areas{width:480px;display:grid;grid-template-columns:1fr 1fr 1fr;gap:4px}
  .nav-dropdown-menu a{display:flex;gap:11px;padding:12px;border-radius:12px;transition:.16s;align-items:center}
  .nav-dropdown-menu a:hover{background:rgba(31,193,104,.08)}
  .nav-dropdown-menu .mi-t{font-weight:600;font-size:.88rem;color:#fff}
  .nav-dropdown-menu .mi-d{font-size:.76rem;color:var(--muted-2);margin-top:2px;line-height:1.35}
  .nav-dropdown-menu .foot{grid-column:1/-1;margin-top:6px;padding:14px;border-radius:13px;background:rgba(255,255,255,.04);display:flex;align-items:center;justify-content:space-between;gap:14px}
  .nav-dropdown-menu .foot span{font-size:.84rem;color:var(--muted)}
  .nav-dropdown-menu .foot .lk{color:var(--gold-2);font-weight:600;font-size:.84rem;white-space:nowrap}
  .nav-cta{display:inline-flex}
  .svc-grid{grid-template-columns:repeat(3,1fr)}
  .res-grid{grid-template-columns:repeat(4,1fr)}
  .res .big{font-size:2.5rem}
  .related-grid{grid-template-columns:repeat(3,1fr)}
  .hero h1{font-size:clamp(3rem,4.6vw,4.4rem)}
}
@media(prefers-reduced-motion:reduce){*,*::before,*::after{animation-duration:.01ms!important;transition-duration:.01ms!important}.reveal{opacity:1;transform:none}.mtrack,.show-track,.tstream{animation:none}}
:focus-visible{outline:2px solid var(--green-2);outline-offset:3px}

/* ===== portfolio screenshot cards ===== */
.pf-grid{display:grid;grid-template-columns:1fr;gap:20px}
.pf-card{background:linear-gradient(160deg,var(--card-2),var(--card));border:1px solid var(--line);border-radius:20px;overflow:hidden;transition:.3s;display:flex;flex-direction:column}
.pf-card:hover{transform:translateY(-5px);border-color:rgba(31,193,104,.4)}
.pf-frame{background:var(--bg-3);border-bottom:1px solid var(--line)}
.pf-frame .bar{height:34px;display:flex;align-items:center;gap:6px;padding:0 13px}
.pf-frame .bar i{width:9px;height:9px;border-radius:50%}
.pf-frame .bar i:nth-child(1){background:#ff5f57}.pf-frame .bar i:nth-child(2){background:#febc2e}.pf-frame .bar i:nth-child(3){background:#28c840}
.pf-frame .bar .u{margin-left:10px;flex:1;height:16px;border-radius:5px;background:rgba(255,255,255,.08);display:flex;align-items:center;padding:0 9px;font-size:.62rem;color:var(--muted-2);font-weight:500;overflow:hidden;white-space:nowrap}
.pf-shot{display:block;width:100%;height:200px;object-fit:cover;object-position:top center;background:linear-gradient(135deg,#0E7C4A,#0a4d30)}
.pf-body{padding:22px;flex:1;display:flex;flex-direction:column}
.pf-body .top{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-bottom:6px}
.pf-body h3{font-size:1.2rem}
.pf-body .badge{font-size:.62rem;font-weight:800;letter-spacing:.05em;text-transform:uppercase;color:#04250F;background:var(--green-2);padding:5px 9px;border-radius:6px;white-space:nowrap}
.pf-body .ind{font-size:.76rem;color:var(--muted-2);text-transform:uppercase;letter-spacing:.06em;font-weight:600;margin-bottom:12px}
.pf-body p{color:var(--muted);font-size:.9rem;margin-bottom:16px;flex:1}
.pf-body .pf-links{display:flex;gap:10px;align-items:center}
.pf-result{display:inline-flex;align-items:center;gap:7px;font-size:.82rem;font-weight:600;color:var(--green-2);background:rgba(31,193,104,.1);padding:7px 11px;border-radius:8px}

/* ===== case study detail ===== */
.cs-hero-shot{max-width:900px;margin:26px auto 0;border-radius:18px;overflow:hidden;border:1px solid var(--line);box-shadow:var(--sh);background:var(--bg-3)}
.cs-hero-shot .bar{height:38px;display:flex;align-items:center;gap:7px;padding:0 15px;border-bottom:1px solid var(--line)}
.cs-hero-shot .bar i{width:10px;height:10px;border-radius:50%}
.cs-hero-shot .bar i:nth-child(1){background:#ff5f57}.cs-hero-shot .bar i:nth-child(2){background:#febc2e}.cs-hero-shot .bar i:nth-child(3){background:#28c840}
.cs-hero-shot .bar .u{margin-left:12px;flex:1;height:18px;border-radius:6px;background:rgba(255,255,255,.08);display:flex;align-items:center;padding:0 11px;font-size:.68rem;color:var(--muted-2);font-weight:500}
.cs-hero-shot img{display:block;width:100%;height:auto;object-fit:cover;object-position:top center}
.cs-meta{display:grid;grid-template-columns:1fr 1fr;gap:14px;max-width:760px;margin:34px auto 0}
.cs-meta .m{background:linear-gradient(160deg,var(--card-2),var(--card));border:1px solid var(--line);border-radius:14px;padding:16px 18px}
.cs-meta .m .l{font-size:.68rem;color:var(--muted-2);text-transform:uppercase;letter-spacing:.08em;font-weight:700}
.cs-meta .m .v{font-weight:600;color:#fff;margin-top:4px;font-size:.98rem}
.cs-meta .m .v.g{color:var(--green-2)}

/* ===== HighLevel booking embed ===== */
.booking-wrap{max-width:680px;margin:0 auto;background:linear-gradient(160deg,var(--card-2),var(--card));border:1px solid var(--line);border-radius:22px;padding:14px;overflow:hidden}
.booking-wrap iframe{width:100%;min-height:720px;border:none;border-radius:14px;background:#fff;display:block}
.book-split{display:flex;flex-direction:column;gap:28px}
@media(min-width:920px){.book-split{flex-direction:row;align-items:flex-start;gap:44px}.book-split .bs-copy{flex:0 0 340px}.book-split .booking-wrap{flex:1;margin:0}}

@media(min-width:700px){.pf-grid{grid-template-columns:1fr 1fr}.cs-meta{grid-template-columns:repeat(4,1fr)}}
@media(min-width:980px){.pf-grid{grid-template-columns:repeat(3,1fr)}}


/* ===== contact page split layout ===== */
.contact-split{display:grid;grid-template-columns:1fr;gap:28px}
.contact-sidebar{display:flex;flex-direction:column;gap:0}
.contact-main .booking-wrap{max-width:100%;margin:0}
.contact-main .booking-wrap iframe{min-height:680px}
@media(min-width:920px){
  .contact-split{grid-template-columns:320px 1fr;gap:44px;align-items:start}
  .contact-sidebar{position:sticky;top:90px}
}

/* ===== dual-row testimonial stream ===== */
.tstream{display:flex;gap:16px;width:max-content;animation:scroll 55s linear infinite}
.tstream.rev{animation-direction:reverse;animation-duration:65s}


/* ===== free website audit page ===== */
.audit-grid{display:grid;grid-template-columns:1fr;gap:16px;margin-bottom:40px}
.audit-check{display:flex;gap:14px;padding:20px;background:linear-gradient(160deg,var(--card-2),var(--card));border:1px solid var(--line);border-radius:16px;align-items:flex-start}
.audit-check .ck{flex-shrink:0;width:34px;height:34px;border-radius:10px;background:var(--grad-g);display:grid;place-items:center;color:#04250F;margin-top:2px}
.audit-check strong{display:block;color:#fff;font-size:1rem;margin-bottom:5px}
.audit-check p{color:var(--muted);font-size:.88rem;margin:0}
.audit-cta-grid{display:grid;grid-template-columns:1fr;gap:32px}
.audit-copy{display:flex;flex-direction:column;gap:0}
.audit-embed .booking-wrap{max-width:100%;margin:0}
.audit-embed .booking-wrap iframe{min-height:680px}
@media(min-width:700px){
  .audit-grid{grid-template-columns:1fr 1fr}
}
@media(min-width:920px){
  .audit-cta-grid{grid-template-columns:1fr 1fr;gap:52px;align-items:start}
  .audit-grid{grid-template-columns:repeat(3,1fr)}
}


/* ===== blog post layout fixes ===== */
/* Override article-hero-img: hide the gradient placeholder, it adds unnecessary bulk */
.article-hero-img{display:none}
/* Tighten blog post header section */
section.blk:has(.article-head){padding-top:28px;padding-bottom:0}
/* Blog post content section */
section.blk:has(.article-body){padding-top:32px}
/* Blog article content prose styles */
.article-body{max-width:760px;margin:0 auto}
.article-body h2{font-size:clamp(1.5rem,4vw,2rem);margin:36px 0 14px;color:#fff}
.article-body h3{font-size:1.2rem;margin:26px 0 10px;color:#fff}
.article-body p{color:var(--muted);margin-bottom:14px;line-height:1.75;font-size:1rem}
.article-body ul{list-style:none;margin:0 0 18px}
.article-body li{color:var(--muted);padding:9px 0 9px 28px;position:relative;border-bottom:1px solid var(--line)}
.article-body li::before{content:"";position:absolute;left:0;top:17px;width:14px;height:8px;border-left:2px solid var(--green-2);border-bottom:2px solid var(--green-2);transform:rotate(-45deg)}
.article-body strong{color:var(--white)}
/* Blog post article-head improvements */
.article-head{max-width:760px;margin:0 auto;text-align:center;padding:10px 0 28px}
.article-head h1{font-size:clamp(2rem,5.5vw,3rem);margin-bottom:14px;color:#fff}
.article-head .cat{font-size:.7rem;font-weight:800;letter-spacing:.08em;text-transform:uppercase;color:#04250F;background:var(--gold-2);padding:6px 12px;border-radius:6px;display:inline-block;margin-bottom:18px}
.article-meta{font-size:.84rem;color:var(--muted-2)}
/* Blog index card color banner (gradient top of card) */
.pf-card>[style*="height:150px"]{border-radius:0}
