/* ============================================================
   Calvert Mobile Detailing — shared design system
   Brand: charcoal + hot magenta (from logo)
   ============================================================ */
:root{
  --bg:#1a1a1e; --bg-2:#212127; --bg-3:#27272e; --surface:#2c2c34;
  --line:#3a3a44; --text:#f4f4f6; --muted:#a7a7b3;
  --pink:#7c5cd6; --pink-2:#a78bfa; --pink-deep:#5b3fa6; --gold:#ffd34d;
  --radius:16px; --shadow:0 18px 50px -18px rgba(0,0,0,.7); --maxw:1180px;
}
*{box-sizing:border-box;margin:0;padding:0;}
html{scroll-behavior:smooth;overflow-x:hidden;}
body{font-family:'Saira',-apple-system,Segoe UI,Roboto,Helvetica,Arial,sans-serif;background:var(--bg);color:var(--text);line-height:1.6;-webkit-font-smoothing:antialiased;overflow-x:hidden;}
h1,h2,h3,h4,.brandmark{font-family:'Saira',sans-serif;line-height:1.1;}
a{color:inherit;text-decoration:none;}
img{max-width:100%;display:block;}
.container{max-width:var(--maxw);margin:0 auto;padding:0 22px;}
section{padding:88px 0;position:relative;}
.eyebrow{color:var(--pink-2);font-weight:700;letter-spacing:.18em;text-transform:uppercase;font-size:12.5px;margin-bottom:14px;display:inline-block;}
.section-head{max-width:660px;margin:0 auto 50px;text-align:center;}
.section-head h2{font-size:clamp(28px,4.2vw,44px);font-weight:800;letter-spacing:-.02em;}
.section-head p{color:var(--muted);margin-top:14px;font-size:16px;}
.center{text-align:center;}
.mt{margin-top:34px;}

/* buttons */
.btn{display:inline-flex;align-items:center;gap:9px;font-weight:700;font-family:'Saira',sans-serif;padding:14px 26px;border-radius:999px;border:2px solid transparent;cursor:pointer;font-size:15px;transition:transform .15s ease,box-shadow .2s ease,background .2s ease;white-space:nowrap;}
.btn-primary{background:linear-gradient(135deg,var(--pink),var(--pink-deep));color:#fff;box-shadow:0 12px 30px -8px rgba(124,92,214,.6);}
.btn-primary:hover{transform:translateY(-2px);box-shadow:0 18px 40px -8px rgba(124,92,214,.75);}
.btn-ghost{border-color:var(--line);color:var(--text);background:rgba(255,255,255,.02);}
.btn-ghost:hover{border-color:var(--pink);color:#fff;transform:translateY(-2px);}
.btn-white{background:#fff;color:#1a1a1e;}
.btn-white:hover{transform:translateY(-2px);}
.btn-lg{padding:17px 34px;font-size:16.5px;}

/* ============ HEADER ============ */
.topbar{background:linear-gradient(90deg,var(--pink-deep),var(--pink));color:#fff;font-size:13px;text-align:center;padding:8px 12px;font-weight:600;letter-spacing:.02em;}
.topbar a{text-decoration:underline;text-underline-offset:2px;}
header{position:sticky;top:0;z-index:60;background:rgba(26,26,30,.82);backdrop-filter:blur(14px);border-bottom:1px solid var(--line);}
.nav{display:flex;align-items:center;justify-content:space-between;height:78px;gap:20px;}
.brand{display:flex;align-items:center;gap:12px;}
.brand .badge{height:54px;width:54px;flex:none;object-fit:contain;}
.brand .wordmark{display:flex;flex-direction:column;line-height:1;}
.brand .wordmark b{font-family:'Saira';font-weight:800;font-size:16px;letter-spacing:.04em;}
.brand .wordmark span{font-family:'Saira';font-weight:600;font-size:11px;letter-spacing:.42em;color:var(--pink-2);}
.nav-links{display:flex;align-items:center;gap:26px;}
.nav-links > a,.nav-links .drop > a{font-size:14.5px;font-weight:500;color:var(--muted);transition:color .15s;display:inline-flex;align-items:center;gap:5px;cursor:pointer;}
.nav-links > a:hover,.nav-links .drop:hover > a{color:#fff;}
.nav-links a.cur{color:#fff;}
/* dropdown */
.drop{position:relative;}
.drop-menu{position:absolute;top:130%;left:50%;transform:translateX(-50%) translateY(8px);background:var(--bg-2);border:1px solid var(--line);border-radius:14px;padding:10px;min-width:230px;box-shadow:var(--shadow);opacity:0;visibility:hidden;transition:.18s;display:flex;flex-direction:column;gap:2px;}
.drop:hover .drop-menu,.drop:focus-within .drop-menu{opacity:1;visibility:visible;transform:translateX(-50%) translateY(0);}
.drop-menu a{padding:10px 14px;border-radius:9px;font-size:14px;color:var(--muted);}
.drop-menu a:hover{background:rgba(124,92,214,.12);color:#fff;}
.nav-cta{display:flex;align-items:center;gap:14px;}
.nav-phone{font-family:'Saira';font-weight:700;font-size:15px;color:#fff;display:flex;align-items:center;gap:7px;}
.nav-phone svg{fill:var(--pink-2);}
.hamburger{display:none;background:none;border:0;cursor:pointer;padding:8px;}
.hamburger span{display:block;width:24px;height:2px;background:#fff;margin:5px 0;transition:.25s;}

/* ============ HERO (home) ============ */
.hero{position:relative;min-height:88vh;display:flex;align-items:center;border-bottom:1px solid var(--line);overflow:hidden;}
.hero-bg{position:absolute;inset:0;background-image:linear-gradient(90deg,rgba(16,16,20,.92) 0%,rgba(16,16,20,.72) 42%,rgba(16,16,20,.45) 100%),url('img/hero.webp');background-size:cover;background-position:center;z-index:0;}
.hero-bg::after{content:"";position:absolute;inset:0;background:radial-gradient(900px 500px at 85% 20%,rgba(124,92,214,.22),transparent 60%);}
.hero .container{position:relative;z-index:2;padding-top:60px;padding-bottom:60px;}
.hero-copy{max-width:680px;}
.hero h1{font-size:clamp(36px,6vw,68px);font-weight:800;letter-spacing:-.025em;}
.hero h1 .hl{background:linear-gradient(135deg,var(--pink-2),var(--pink));-webkit-background-clip:text;background-clip:text;color:transparent;}
.hero p.sub{color:#d8d8df;font-size:18px;margin:22px 0 30px;max-width:560px;}
.hero-cta{display:flex;gap:14px;flex-wrap:wrap;}
.hero-trust{display:flex;gap:26px;flex-wrap:wrap;margin-top:38px;padding-top:26px;border-top:1px solid rgba(255,255,255,.14);}
.hero-trust .ht{display:flex;align-items:center;gap:9px;font-size:13.5px;color:#cfcfd6;font-weight:500;}
.hero-trust .ht b{color:#fff;font-family:'Saira';}
.stars{color:var(--gold);letter-spacing:2px;font-size:15px;}

/* ============ SUBPAGE HERO ============ */
.subhero{position:relative;padding:64px 0 54px;border-bottom:1px solid var(--line);background:radial-gradient(900px 460px at 80% -20%,rgba(124,92,214,.20),transparent 60%),var(--bg-2);overflow:hidden;}
.subhero .container{position:relative;z-index:2;}
.crumbs{font-size:13px;color:var(--muted);margin-bottom:16px;}
.crumbs a:hover{color:var(--pink-2);}
.crumbs span{margin:0 7px;opacity:.6;}
.subhero h1{font-size:clamp(30px,5vw,52px);font-weight:800;letter-spacing:-.02em;max-width:760px;}
.subhero p{color:var(--muted);font-size:17px;margin-top:16px;max-width:620px;}
.subhero .hero-cta{margin-top:26px;}

/* ============ TRUST STRIP ============ */
.trustbar{background:var(--bg-2);border-bottom:1px solid var(--line);}
.trustbar .container{display:flex;flex-wrap:wrap;justify-content:center;gap:40px;padding:22px;align-items:center;}
.trustbar .t{display:flex;align-items:center;gap:10px;font-weight:600;font-size:14px;color:var(--muted);}
.trustbar .t svg{fill:var(--pink-2);flex:none;}

/* ============ GENERIC GRIDS / CARDS ============ */
.svc-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;}
.svc{background:linear-gradient(180deg,var(--bg-3),var(--bg-2));border:1px solid var(--line);border-radius:var(--radius);padding:30px 26px;transition:transform .2s,border-color .2s;position:relative;overflow:hidden;}
.svc:hover{transform:translateY(-5px);border-color:var(--pink);}
.svc .ico{width:54px;height:54px;border-radius:14px;background:rgba(124,92,214,.12);display:flex;align-items:center;justify-content:center;margin-bottom:18px;}
.svc .ico svg{stroke:var(--pink-2);width:28px;height:28px;}
.svc h3{font-size:20px;font-weight:700;margin-bottom:8px;}
.svc p{color:var(--muted);font-size:14.5px;margin-bottom:14px;}
.svc a.more{color:var(--pink-2);font-weight:600;font-size:14px;display:inline-flex;gap:6px;align-items:center;}

/* ============ PROSE / ARTICLE (service & info pages) ============ */
.prose{max-width:820px;margin:0 auto;}
.prose h2{font-size:clamp(24px,3.2vw,34px);font-weight:800;margin:38px 0 14px;letter-spacing:-.02em;}
.prose h3{font-size:21px;font-weight:700;margin:26px 0 10px;}
.prose p{color:#d4d4dc;font-size:16px;margin:12px 0;}
.prose ul{margin:14px 0 14px 4px;list-style:none;display:flex;flex-direction:column;gap:10px;}
.prose ul li{position:relative;padding-left:30px;color:#d4d4dc;font-size:15.5px;}
.prose ul li::before{content:"✓";position:absolute;left:0;top:0;color:var(--pink-2);font-weight:800;}
.cols{display:grid;grid-template-columns:1fr 1fr;gap:34px;align-items:center;}
.media-ph{aspect-ratio:4/3;border-radius:18px;border:1px solid var(--line);background:linear-gradient(135deg,#2a2a31,#1b1b21);display:flex;align-items:center;justify-content:center;color:var(--muted);font-size:13px;text-align:center;padding:24px;}

/* ============ ESTIMATOR ============ */
.est-card{max-width:920px;margin:0 auto;background:linear-gradient(180deg,var(--bg-3),var(--bg-2));border:1px solid var(--line);border-radius:24px;padding:38px;box-shadow:var(--shadow);}
.est-step{margin-bottom:26px;}
.est-step .lbl{font-family:'Saira';font-weight:600;font-size:14px;margin-bottom:12px;display:flex;align-items:center;gap:8px;}
.est-step .lbl .n{width:24px;height:24px;border-radius:50%;background:var(--pink);color:#fff;font-size:13px;display:inline-flex;align-items:center;justify-content:center;font-weight:700;}
.opts{display:flex;flex-wrap:wrap;gap:10px;}
.opt{border:1.5px solid var(--line);background:var(--bg);border-radius:12px;padding:12px 18px;cursor:pointer;font-weight:600;font-size:14px;color:var(--muted);transition:.15s;user-select:none;}
.opt:hover{border-color:var(--pink-2);color:#fff;}
.opt.active{border-color:var(--pink);background:rgba(124,92,214,.14);color:#fff;}
.opt small{display:block;font-weight:500;font-size:11.5px;color:var(--muted);margin-top:2px;}
.est-result{margin-top:10px;background:var(--bg);border:1px dashed var(--pink);border-radius:16px;padding:24px;display:flex;align-items:center;justify-content:space-between;gap:18px;flex-wrap:wrap;}
.est-result .price{font-family:'Saira';font-weight:800;font-size:34px;}
.est-result .price small{display:block;font-size:13px;color:var(--muted);font-weight:500;}
.est-note{color:var(--muted);font-size:12.5px;margin-top:14px;text-align:center;}

/* ============ PRICING ============ */
.price-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;align-items:stretch;}
.plan{background:linear-gradient(180deg,var(--bg-3),var(--bg-2));border:1px solid var(--line);border-radius:var(--radius);padding:30px 26px;display:flex;flex-direction:column;}
.plan.feat{border-color:var(--pink);box-shadow:0 0 0 1px var(--pink),var(--shadow);position:relative;}
.plan.feat .tag{position:absolute;top:-13px;left:50%;transform:translateX(-50%);background:var(--pink);color:#fff;font-size:11.5px;font-weight:700;padding:5px 14px;border-radius:999px;letter-spacing:.04em;}
.plan h3{font-size:21px;font-weight:700;}
.plan .from{color:var(--muted);font-size:13px;margin-top:4px;}
.plan .amt{font-family:'Saira';font-weight:800;font-size:38px;margin:12px 0 4px;}
.plan ul{list-style:none;margin:18px 0 24px;display:flex;flex-direction:column;gap:10px;}
.plan li{font-size:14px;color:var(--muted);display:flex;gap:10px;align-items:flex-start;}
.plan li svg{fill:var(--pink-2);flex:none;margin-top:3px;}
.plan .btn{margin-top:auto;justify-content:center;}

/* ============ STEPS ============ */
.steps{display:grid;grid-template-columns:repeat(3,1fr);gap:26px;}
.step{text-align:center;padding:14px;}
.step .num{width:66px;height:66px;margin:0 auto 18px;border-radius:50%;background:rgba(124,92,214,.12);border:1.5px solid var(--pink);color:var(--pink-2);font-family:'Saira';font-weight:800;font-size:26px;display:flex;align-items:center;justify-content:center;}
.step h3{font-size:19px;font-weight:700;margin-bottom:8px;}
.step p{color:var(--muted);font-size:14.5px;}

/* ============ GALLERY ============ */
.gal-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;}
.gal{aspect-ratio:4/3;border-radius:14px;border:1px solid var(--line);position:relative;overflow:hidden;background:linear-gradient(135deg,#2a2a31,#1d1d23);display:flex;align-items:center;justify-content:center;}
.gal span{position:absolute;bottom:10px;left:12px;background:rgba(0,0,0,.55);color:#fff;font-size:11px;font-weight:600;padding:3px 9px;border-radius:6px;}
.gal .ph{color:var(--line);font-size:13px;}

/* ============ REVIEWS ============ */
.rev-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;}
.rev{background:var(--bg-3);border:1px solid var(--line);border-radius:var(--radius);padding:26px;}
.rev .stars{margin-bottom:12px;}
.rev p{font-size:14.5px;margin-bottom:18px;}
.rev .who{display:flex;align-items:center;gap:12px;}
.rev .av{width:42px;height:42px;border-radius:50%;background:linear-gradient(135deg,var(--pink),var(--pink-deep));color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700;font-family:'Saira';}
.rev .who b{font-size:14px;display:block;}
.rev .who small{color:var(--muted);font-size:12px;}

/* ============ AREAS ============ */
.area-wrap{display:grid;grid-template-columns:1fr 1fr;gap:36px;align-items:center;}
.area-list{display:flex;flex-direction:column;gap:18px;}
.area-card{background:var(--bg-3);border:1px solid var(--line);border-radius:14px;padding:20px 22px;}
.area-card h3{font-size:17px;font-weight:700;display:flex;align-items:center;gap:9px;}
.area-card h3 svg{fill:var(--pink-2);}
.area-card p{color:var(--muted);font-size:13.5px;margin-top:6px;}
.map-ph{aspect-ratio:1/1;border-radius:20px;border:1px solid var(--line);background:radial-gradient(400px 300px at 60% 40%,rgba(124,92,214,.18),transparent 60%),linear-gradient(135deg,#26262d,#1b1b21);display:flex;align-items:center;justify-content:center;text-align:center;color:var(--muted);padding:30px;}
.map-embed{border:1px solid var(--line);border-radius:20px;overflow:hidden;line-height:0;background:#1b1b21;box-shadow:var(--shadow);}
.map-embed iframe{width:100%;height:100%;min-height:380px;border:0;display:block;}
.map-cap{margin-top:14px;font-size:13px;color:var(--muted);text-align:center;line-height:1.5;}
.map-cap b{color:var(--text);}
.areas-fullmap{max-width:1000px;margin:0 auto;}
.areas-fullmap .map-embed iframe{min-height:440px;}
.reviews-widget{min-height:120px;}
.widget-ph{max-width:680px;margin:0 auto;text-align:center;border:1px dashed var(--line);border-radius:16px;padding:34px 26px;color:var(--muted);background:linear-gradient(180deg,var(--bg-3),var(--bg-2));}
.widget-ph .g{display:inline-flex;align-items:center;gap:10px;font-family:'Saira';font-weight:700;color:var(--text);font-size:18px;margin-bottom:8px;}
.widget-ph .g .stars{font-size:18px;}

/* ============================================================
   V2 — CINEMATIC DARK-LUXURY AUTOMOTIVE UPGRADE
   (loaded last so it refines the base system site-wide)
   ============================================================ */
:root{
  --bg:#0b0b0f; --bg-2:#101015; --bg-3:#16161d; --surface:#1b1b23;
  --line:rgba(255,255,255,.08); --line-2:rgba(255,255,255,.14);
  --ease:cubic-bezier(.16,1,.3,1);
  --shadow:0 30px 80px -30px rgba(0,0,0,.85);
  --glow:radial-gradient(60% 60% at 70% 20%,rgba(124,92,214,.22),transparent 70%);
}
body{background:
  radial-gradient(900px 500px at 88% -8%,rgba(124,92,214,.10),transparent 60%),
  var(--bg);}
::selection{background:var(--pink);color:#fff;}
.display{font-family:'Saira',sans-serif;font-weight:800;letter-spacing:-.025em;line-height:1.02;}

/* refined buttons */
.btn{border-radius:12px;transition:transform .25s var(--ease),box-shadow .25s var(--ease),background .25s var(--ease),border-color .25s var(--ease);}
.btn-lg{border-radius:14px;}
.btn-primary{box-shadow:0 14px 36px -10px rgba(124,92,214,.55),inset 0 1px 0 rgba(255,255,255,.25);}
.btn-primary:hover{transform:translateY(-3px);box-shadow:0 22px 50px -10px rgba(124,92,214,.75),inset 0 1px 0 rgba(255,255,255,.3);}
.btn-ghost{backdrop-filter:blur(6px);}

/* glass header */
header{background:rgba(11,11,15,.6);backdrop-filter:blur(18px) saturate(140%);border-bottom:1px solid var(--line);}

/* cards: hairline + top highlight + lift */
.svc,.plan,.rev,.area-card,.qa,.est-card,.formwrap{
  border:1px solid var(--line);
  background:linear-gradient(180deg,rgba(255,255,255,.04),rgba(255,255,255,0)) , linear-gradient(180deg,var(--bg-3),var(--bg-2));
  border-radius:18px;transition:transform .35s var(--ease),border-color .3s var(--ease),box-shadow .35s var(--ease);
}
.svc{position:relative;overflow:hidden;}
.svc::before{content:"";position:absolute;inset:0 0 auto 0;height:1px;background:linear-gradient(90deg,transparent,rgba(255,255,255,.25),transparent);opacity:0;transition:opacity .35s var(--ease);}
.svc:hover{transform:translateY(-6px);border-color:var(--line-2);box-shadow:var(--shadow);}
.svc:hover::before{opacity:1;}
.svc .ico{background:linear-gradient(135deg,rgba(124,92,214,.22),rgba(124,92,214,.06));box-shadow:inset 0 0 0 1px rgba(124,92,214,.25);}
.plan.feat{box-shadow:0 0 0 1px var(--pink),0 30px 80px -30px rgba(124,92,214,.5);}

/* eyebrow as a chip */
.eyebrow{display:inline-flex;align-items:center;gap:8px;padding:6px 12px;border:1px solid var(--line-2);border-radius:999px;background:rgba(124,92,214,.08);color:var(--pink-2);}
.section-head h2{letter-spacing:-.03em;}

/* hero: cinematic */
.hero{min-height:92vh;}
.hero-bg{background-image:
  linear-gradient(90deg,rgba(8,8,11,.94) 0%,rgba(8,8,11,.72) 45%,rgba(8,8,11,.35) 100%),
  linear-gradient(0deg,rgba(8,8,11,.85),transparent 55%),
  url('img/hero.webp');}
.hero-bg::after{background:var(--glow);}
.hero h1{letter-spacing:-.035em;text-shadow:0 2px 40px rgba(0,0,0,.5);}
.hero h1.display{letter-spacing:-.025em;font-weight:800;}
.hero .eyebrow{background:rgba(255,255,255,.06);}

/* ambient floating glow blobs */
.blob{position:absolute;border-radius:50%;filter:blur(70px);opacity:.5;z-index:0;pointer-events:none;
  background:radial-gradient(circle,rgba(124,92,214,.5),transparent 70%);animation:float 14s var(--ease) infinite alternate;}
@keyframes float{from{transform:translate(0,0) scale(1)}to{transform:translate(40px,-30px) scale(1.15)}}

/* image slots */
.imgslot{position:relative;border-radius:18px;overflow:hidden;border:1px solid var(--line);
  background:linear-gradient(135deg,#1c1c24,#101014);background-size:cover;background-position:center;
  display:flex;align-items:center;justify-content:center;min-height:220px;}
.imgslot::after{content:attr(data-label);color:rgba(255,255,255,.28);font-size:12px;font-weight:600;letter-spacing:.06em;text-transform:uppercase;padding:8px 12px;border:1px dashed rgba(255,255,255,.18);border-radius:8px;}
.imgslot.has-img::after{display:none;}

/* service card media slot */
.svc-media{height:200px;margin:-30px -26px 20px;border-bottom:1px solid var(--line);background:linear-gradient(135deg,#1d1d25,#101014);background-size:cover;background-position:center;position:relative;}
.svc-media::after{content:"PHOTO";position:absolute;right:10px;bottom:8px;font-size:9.5px;letter-spacing:.1em;color:rgba(255,255,255,.25);}

/* BEFORE / AFTER slider */
.ba{position:relative;border-radius:20px;overflow:hidden;border:1px solid var(--line);aspect-ratio:16/10;box-shadow:var(--shadow);user-select:none;touch-action:none;--pos:50%;}
.ba .layer{position:absolute;inset:0;background-size:cover;background-position:center;display:flex;align-items:center;justify-content:center;}
.ba .after{background:linear-gradient(135deg,#23232c,#15151b);}
.ba .before{background:linear-gradient(135deg,#34343f,#202028);clip-path:inset(0 calc(100% - var(--pos)) 0 0);}
.ba .tag{position:absolute;bottom:14px;padding:5px 12px;border-radius:999px;font-size:11px;font-weight:700;letter-spacing:.06em;background:rgba(0,0,0,.55);color:#fff;backdrop-filter:blur(6px);}
.ba .tag.b{left:14px;} .ba .tag.a{right:14px;}
.ba .ph{color:rgba(255,255,255,.3);font-size:12px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;}
.ba .bar{position:absolute;top:0;bottom:0;left:var(--pos);width:2px;background:#fff;transform:translateX(-1px);box-shadow:0 0 14px rgba(0,0,0,.5);}
.ba .knob{position:absolute;top:50%;left:var(--pos);width:42px;height:42px;margin:-21px 0 0 -21px;border-radius:50%;background:rgba(255,255,255,.95);display:flex;align-items:center;justify-content:center;color:#111;font-weight:800;cursor:ew-resize;box-shadow:0 6px 20px rgba(0,0,0,.5);}

/* scroll reveal — only hides when JS is active (no-JS shows everything) */
.reveal{transition:opacity .7s var(--ease),transform .7s var(--ease);}
.js .reveal{opacity:0;transform:translateY(26px);}
.js .reveal.in{opacity:1;transform:none;}
@media (prefers-reduced-motion:reduce){.js .reveal{opacity:1;transform:none;transition:none;}.blob{animation:none;}}

/* trust marquee polish */
.trustbar{background:rgba(255,255,255,.02);}
.map-embed,.contact-card{border-radius:20px;}

/* ============ FAQ ============ */
.faq-list{max-width:820px;margin:0 auto;}
.qa{border:1px solid var(--line);border-radius:14px;margin-bottom:14px;overflow:hidden;background:var(--bg-3);}
.qa button{width:100%;text-align:left;background:none;border:0;color:#fff;font-family:'Saira';font-weight:600;font-size:16px;padding:20px 22px;cursor:pointer;display:flex;justify-content:space-between;align-items:center;gap:14px;}
.qa button .ic{color:var(--pink-2);font-size:24px;transition:transform .2s;flex:none;}
.qa.open button .ic{transform:rotate(45deg);}
.qa .ans{max-height:0;overflow:hidden;transition:max-height .28s ease;color:var(--muted);font-size:14.5px;}
.qa .ans div{padding:0 22px 20px;}

/* ============ FORMS (low-friction) ============ */
.formwrap{max-width:560px;margin:0 auto;background:var(--bg-2);border:1px solid var(--line);border-radius:22px;padding:34px;box-shadow:var(--shadow);}
.form .row{margin-bottom:16px;}
.form .row2{display:grid;grid-template-columns:1fr 1fr;gap:14px;}
.form label{display:block;font-size:13px;font-weight:600;margin-bottom:7px;color:var(--muted);}
.form input,.form select,.form textarea{width:100%;background:var(--bg);border:1px solid var(--line);border-radius:11px;padding:13px 15px;color:#fff;font-family:inherit;font-size:15px;}
.form input:focus,.form select:focus,.form textarea:focus{outline:none;border-color:var(--pink);}
.form .btn{width:100%;justify-content:center;margin-top:6px;}
.form .fine{color:var(--muted);font-size:12px;margin-top:12px;text-align:center;}

/* contact split card */
.contact-card{display:grid;grid-template-columns:1fr 1fr;gap:0;border:1px solid var(--line);border-radius:24px;overflow:hidden;box-shadow:var(--shadow);}
.contact-card .side{background:linear-gradient(160deg,var(--pink-deep),#7a0a47);padding:44px;display:flex;flex-direction:column;justify-content:center;}
.contact-card .side h2{font-size:30px;font-weight:800;}
.contact-card .side p{margin:14px 0 24px;opacity:.92;}
.contact-card .side .line{display:flex;align-items:center;gap:12px;margin:12px 0;font-weight:600;}
.contact-card .side .line svg{fill:#fff;flex:none;}
.contact-card .form{background:var(--bg-2);padding:44px;}

/* ============ LEAD MAGNET ============ */
.lead-wrap{display:grid;grid-template-columns:1.05fr .95fr;gap:40px;align-items:start;}
/* lead form: left-aligned and full column width so it lines up with the headline/bullets */
.leadform.formwrap,.thankyou.formwrap{max-width:none;margin:0;width:100%;}
.lead-visual{background:linear-gradient(160deg,#2a2a31,#161619);border:1px solid var(--line);border-radius:20px;padding:26px;box-shadow:var(--shadow);position:relative;}
.lead-cover{min-height:440px;border-radius:12px;background:linear-gradient(160deg,#202026,#101013);border:1px solid var(--line);display:flex;flex-direction:column;gap:18px;padding:30px;position:relative;overflow:hidden;}
.lead-cover > small:last-child{margin-top:auto;}
.lead-cover .badge-mini{width:70px;height:70px;}
.lead-cover h3{font-size:24px;font-weight:800;line-height:1.15;}
.lead-cover .accent{height:5px;width:80px;background:var(--pink);border-radius:3px;margin:14px 0;}
.lead-cover small{color:var(--muted);}
.lead-points li{margin:10px 0;}
.thankyou{display:none;text-align:center;padding:10px;}
.thankyou.show{display:block;}
.leadform.hide{display:none;}
.check-circle{width:74px;height:74px;border-radius:50%;background:rgba(46,204,113,.15);border:2px solid #2ecc71;color:#2ecc71;font-size:38px;display:flex;align-items:center;justify-content:center;margin:0 auto 18px;}

/* ============ FOOTER ============ */
footer{background:#141418;border-top:1px solid var(--line);padding:56px 0 30px;}
.foot-grid{display:grid;grid-template-columns:1.5fr 1fr 1fr 1fr;gap:36px;}
.foot-brand .brand{margin-bottom:16px;}
.foot-brand p{color:var(--muted);font-size:14px;max-width:300px;}
.socials{display:flex;gap:12px;margin-top:18px;}
.socials a{width:40px;height:40px;border-radius:10px;border:1px solid var(--line);display:flex;align-items:center;justify-content:center;transition:.15s;}
.socials a:hover{border-color:var(--pink);background:rgba(124,92,214,.12);}
.socials svg{fill:var(--muted);width:18px;height:18px;}
.socials a:hover svg{fill:var(--pink-2);}
.foot-col h4{font-family:'Saira';font-size:14px;font-weight:700;margin-bottom:16px;letter-spacing:.03em;}
.foot-col a,.foot-col p{display:block;color:var(--muted);font-size:13.5px;margin-bottom:10px;transition:.15s;}
.foot-col a:hover{color:var(--pink-2);}
.foot-bottom{border-top:1px solid var(--line);margin-top:40px;padding-top:22px;display:flex;justify-content:space-between;flex-wrap:wrap;gap:10px;color:var(--muted);font-size:12.5px;}

/* ============ MOBILE STICKY BAR ============ */
.mobilebar{display:none;position:fixed;bottom:0;left:0;right:0;z-index:70;background:rgba(20,20,24,.96);backdrop-filter:blur(10px);border-top:1px solid var(--line);padding:10px 12px;gap:10px;}
.mobilebar .btn{flex:1;justify-content:center;padding:14px;}

/* ============ RESPONSIVE ============ */
@media (max-width:980px){
  .hero{min-height:auto;padding:30px 0;}
  .hero .container{min-width:0;width:100%;}              /* fix: flex child must shrink so text wraps (no clipping) */
  .hero-copy,.hero p.sub,.hero h1{max-width:100%;}
  .svc-grid,.price-grid,.steps,.rev-grid{grid-template-columns:1fr 1fr;}
  .gal-grid{grid-template-columns:1fr 1fr;}
  .area-wrap,.contact-card,.cols,.lead-wrap{grid-template-columns:1fr;}
  .foot-grid{grid-template-columns:1fr 1fr;gap:28px;}
  .nav-links,.nav-phone{display:none;}
  .hamburger{display:block;}
  .nav-links.open{display:flex;position:absolute;top:78px;left:0;right:0;flex-direction:column;align-items:flex-start;background:var(--bg-2);padding:18px 22px;gap:6px;border-bottom:1px solid var(--line);max-height:80vh;overflow:auto;}
  .nav-links.open > a,.nav-links.open .drop > a{font-size:16px;padding:10px 0;}
  .nav-links.open .drop-menu{position:static;opacity:1;visibility:visible;transform:none;background:transparent;border:0;box-shadow:none;padding:0 0 8px 14px;min-width:0;}
  .nav-links.open .drop-menu a{padding:7px 0;}
}
@media (max-width:620px){
  section{padding:58px 0;}
  .svc-grid,.price-grid,.steps,.rev-grid,.gal-grid,.foot-grid,.form .row2{grid-template-columns:1fr;}
  .est-card,.contact-card .form,.contact-card .side,.formwrap{padding:26px;}
  .mobilebar{display:flex;}
  body{padding-bottom:70px;}
  .brand .wordmark{display:none;}
  .topbar{font-size:11px;line-height:1.5;}
  .lead-visual{padding:18px;}
  .est-result{flex-direction:column;align-items:flex-start;}
  .est-result .btn{width:100%;justify-content:center;}
  .trustbar .container{gap:18px;}
}
@media (prefers-reduced-motion:reduce){*{scroll-behavior:auto;transition:none!important;}}

/* filled photo slots — COVER so the photo fills the whole box edge-to-edge (no black borders) */
/* min-height:0 + width:100% so an inline aspect-ratio governs sizing (prevents min-height forcing extra width -> mobile overflow) */
.media-ph.has-img{background-size:cover;background-position:center;color:transparent;font-size:0;min-height:0;width:100%;}
.gal.has-img{background-size:cover;background-position:center;}
.gal.has-img .ph{display:none;}
.svc-media.has-img{background-size:cover;background-position:center;}
.svc-media.has-img::after{display:none;}
.imgslot.has-img{background-size:cover;background-position:center;min-height:0;width:100%;}

/* gallery tiles — uniform landscape boxes, photo fills completely, readable label */
.gal.has-img{aspect-ratio:4/3;}
.gal.has-img::after{content:'';position:absolute;left:0;right:0;bottom:0;height:44%;background:linear-gradient(transparent,rgba(0,0,0,.55));pointer-events:none;z-index:1;}
.gal.has-img span{z-index:2;background:rgba(0,0,0,.6);backdrop-filter:blur(4px);font-weight:600;}

/* Yelp text button */
.socials .ylp{font-family:'Saira',sans-serif;font-weight:800;font-size:11px;letter-spacing:.02em;color:var(--muted);}
.socials a:hover .ylp{color:var(--pink-2);}

/* keep brand name pink (matches the pink logo; everything else is purple) */
.brand .wordmark span{color:#ff4dab;}

/* hero stat blocks (big number + small uppercase label, reference style) */
.hero-stats{display:flex;flex-wrap:wrap;gap:40px;margin-top:40px;padding-top:26px;border-top:1px solid rgba(255,255,255,.14);}
.hstat b{display:block;font-family:'Saira',sans-serif;font-weight:800;font-size:32px;line-height:1;letter-spacing:-.01em;color:#fff;}
.hstat span{display:block;margin-top:8px;font-size:11.5px;letter-spacing:.14em;text-transform:uppercase;color:var(--muted);font-weight:600;}
/* pull hero content toward the left on wider screens */
@media (min-width:981px){.hero .container{max-width:none;width:100%;padding-left:clamp(28px,5vw,80px);padding-right:clamp(28px,5vw,80px);}.hero-copy{max-width:640px;}}
@media (max-width:620px){.hero-stats{gap:22px 30px;}.hstat b{font-size:26px;}}


/* Certification trust band (above footer, on every page) */
.cert-band{background:linear-gradient(180deg,var(--bg-2),var(--bg));border-top:1px solid var(--line);}
.cert-band .container{display:grid;grid-template-columns:minmax(0,470px) 1fr;gap:48px;align-items:center;}
.cert-img{width:100%;height:auto;border-radius:14px;border:1px solid rgba(255,255,255,.10);box-shadow:0 34px 80px -24px rgba(0,0,0,.85),0 8px 24px -10px rgba(0,0,0,.6);}
.cert-copy h2{font-size:clamp(24px,3.2vw,36px);font-weight:800;letter-spacing:-.02em;margin:6px 0 12px;}
.cert-copy p{color:var(--muted);font-size:15.5px;margin-bottom:22px;}
@media (max-width:820px){.cert-band .container{grid-template-columns:1fr;gap:26px;}.cert-img{max-width:520px;margin:0 auto;}}

/* moving trust banner (marquee) */
.marquee{overflow:hidden;background:rgba(255,255,255,.02);border-top:1px solid var(--line);border-bottom:1px solid var(--line);padding:15px 0;}
.marquee-track{display:flex;width:max-content;animation:marquee 32s linear infinite;}
.marquee:hover .marquee-track{animation-play-state:paused;}
.marquee-group{display:flex;align-items:center;gap:46px;padding-right:46px;flex:none;}
.marquee .t{display:flex;align-items:center;gap:10px;font-weight:600;font-size:14px;color:var(--muted);white-space:nowrap;flex:none;}
.marquee .t svg{fill:var(--pink-2);width:20px;height:20px;flex:none;}
.marquee .sx{height:30px;width:auto;display:block;flex:none;opacity:.95;}
@keyframes marquee{from{transform:translateX(0)}to{transform:translateX(-50%)}}
@media (prefers-reduced-motion:reduce){.marquee-track{animation:none;flex-wrap:wrap;justify-content:center;gap:28px;}}

/* hero background video */
.hero-video{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:0;}
.hero-bg{z-index:1;background-image:linear-gradient(90deg,rgba(8,8,11,.90) 0%,rgba(8,8,11,.62) 45%,rgba(8,8,11,.42) 100%),linear-gradient(0deg,rgba(8,8,11,.82),transparent 55%);}

/* remove purple tint from hero (video header) */
.hero .hero-bg::after{display:none;}
.hero .blob{display:none;}
