/* SewerScopeInspectionMN — Premium edition. Dark editorial + copper accents. */
:root{
  --bg:#0a0c10;
  --bg-2:#11141a;
  --bg-3:#171b22;
  --bg-4:#1f242d;
  --ink:#f5f1e8;
  --ink-2:#d9d3c5;
  --ink-dim:#9a9588;
  --line:#262b34;
  --line-2:#343a45;
  --accent:#c2693a;
  --accent-2:#e6a972;
  --accent-3:#f4cba0;
  --accent-soft:rgba(194,105,58,.12);
  --warn:#d97757;
  --ok:#7bb27b;
  --radius:16px;
  --radius-sm:10px;
  --maxw:1280px;
  --font-display:"Fraunces","Source Serif Pro",Georgia,serif;
  --font-body:"Inter","Helvetica Neue",system-ui,sans-serif;
  --font-mono:"JetBrains Mono",ui-monospace,monospace;
  --ease:cubic-bezier(.2,.7,.2,1);
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{background:var(--bg);color:var(--ink);font-family:var(--font-body);font-size:17px;line-height:1.65;-webkit-font-smoothing:antialiased;overflow-x:hidden}
img{max-width:100%;display:block}
a{color:var(--accent-2);text-decoration:none;transition:color .2s var(--ease)}
a:hover{color:var(--accent-3)}
::selection{background:var(--accent);color:#1a0f08}

body::before{content:"";position:fixed;inset:0;pointer-events:none;z-index:1;opacity:.04;mix-blend-mode:overlay;background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='200' height='200'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='3'/></filter><rect width='100%25' height='100%25' filter='url(%23n)'/></svg>")}

.wrap{max-width:var(--maxw);margin:0 auto;padding:0 32px;position:relative;z-index:2}
.eyebrow{font-family:var(--font-mono);text-transform:uppercase;letter-spacing:.22em;font-size:11px;color:var(--accent);font-weight:600;display:inline-flex;align-items:center;gap:10px}
.eyebrow::before{content:"";width:24px;height:1px;background:var(--accent)}
h1,h2,h3,h4{font-family:var(--font-display);font-weight:400;letter-spacing:-.018em;line-height:1.05;color:var(--ink)}
h1{font-size:clamp(2.6rem,6vw,5.4rem)}
h2{font-size:clamp(2rem,3.6vw,3.4rem);margin-bottom:.5em}
h3{font-size:1.5rem;margin-bottom:.4em;letter-spacing:-.01em}
h1 em,h2 em,h3 em{font-style:italic;color:var(--accent-2);font-weight:400}
p{color:var(--ink-2);max-width:65ch}
p.lead{font-size:1.22rem;color:var(--ink);line-height:1.55;font-weight:300}

.announce{background:linear-gradient(90deg,var(--accent),var(--accent-2));color:#1a0f08;text-align:center;padding:10px 20px;font-size:13px;font-weight:600;letter-spacing:.03em;position:relative;z-index:60}
.announce b{font-family:var(--font-mono);text-transform:uppercase;letter-spacing:.15em;font-size:11px}

.nav{position:sticky;top:0;z-index:50;background:rgba(10,12,16,.78);backdrop-filter:blur(20px) saturate(140%);border-bottom:1px solid var(--line)}
.nav-inner{display:flex;align-items:center;justify-content:space-between;padding:18px 32px;max-width:var(--maxw);margin:0 auto;gap:24px}
.brand{display:flex;align-items:center;gap:10px;font-family:var(--font-display);font-size:1.3rem;color:var(--ink);letter-spacing:-.01em}
.brand-mark{width:34px;height:34px;background:var(--bg-3);border:1px solid var(--line-2);border-radius:50%;display:grid;place-items:center;position:relative}
.brand-mark::before{content:"";width:14px;height:14px;border:2px solid var(--accent);border-radius:50%}
.brand-mark::after{content:"";position:absolute;width:5px;height:5px;background:var(--accent-2);border-radius:50%}
.brand b{color:var(--accent)}
.nav-links{display:flex;gap:30px;align-items:center}
.nav-links a{color:var(--ink-2);font-size:14px;font-weight:500;position:relative}
.nav-links a::after{content:"";position:absolute;left:0;right:0;bottom:-4px;height:1px;background:var(--accent);transform:scaleX(0);transform-origin:right;transition:transform .3s var(--ease)}
.nav-links a:hover{color:var(--ink)}
.nav-links a:hover::after{transform:scaleX(1);transform-origin:left}

.btn{display:inline-flex;align-items:center;gap:10px;padding:15px 24px;border-radius:999px;font-weight:600;font-size:14px;letter-spacing:.02em;border:1px solid transparent;cursor:pointer;transition:all .25s var(--ease);font-family:var(--font-body);position:relative;overflow:hidden}
.btn-primary{background:var(--accent);color:#1a0f08}
.btn-primary::after{content:"→";transition:transform .25s var(--ease)}
.btn-primary:hover{background:var(--accent-2);transform:translateY(-2px);box-shadow:0 14px 30px -10px rgba(194,105,58,.5)}
.btn-primary:hover::after{transform:translateX(4px)}
.btn-ghost{border-color:var(--line-2);color:var(--ink);background:transparent}
.btn-ghost:hover{border-color:var(--accent);color:var(--accent-2)}

.hero{padding:80px 0 100px;position:relative;overflow:hidden}
.hero::before{content:"";position:absolute;top:-100px;right:-200px;width:900px;height:900px;background:radial-gradient(circle,rgba(194,105,58,.14),transparent 65%);pointer-events:none}
.hero::after{content:"";position:absolute;bottom:-300px;left:-200px;width:700px;height:700px;background:radial-gradient(circle,rgba(120,180,200,.06),transparent 65%);pointer-events:none}
.hero-grid{display:grid;grid-template-columns:1.2fr .9fr;gap:72px;align-items:center;position:relative}
.hero h1{margin:22px 0 26px}
.hero-lead{max-width:560px}
.hero-cta-row{margin-top:38px;display:flex;gap:14px;flex-wrap:wrap;align-items:center}
.hero-rating{display:flex;align-items:center;gap:10px;font-size:13px;color:var(--ink-dim);margin-left:8px}
.hero-rating .stars{color:var(--accent-2);letter-spacing:2px}

.hero-meta{display:grid;grid-template-columns:repeat(3,1fr);gap:0;margin-top:56px;border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.hero-meta div{padding:22px 0;border-right:1px solid var(--line)}
.hero-meta div:last-child{border-right:0}
.hero-meta small{font-family:var(--font-mono);font-size:11px;letter-spacing:.15em;text-transform:uppercase;color:var(--ink-dim)}
.hero-meta strong{display:block;color:var(--ink);font-size:1.9rem;font-family:var(--font-display);font-weight:400;letter-spacing:-.02em;margin-top:6px}

.hero-card{background:linear-gradient(165deg,var(--bg-2),var(--bg-3) 60%,var(--bg-4));border:1px solid var(--line-2);border-radius:var(--radius);padding:36px;position:relative;box-shadow:0 30px 80px -30px rgba(0,0,0,.7),inset 0 1px 0 rgba(255,255,255,.04)}
.hero-card::before{content:"";position:absolute;inset:-1px;border-radius:var(--radius);padding:1px;background:linear-gradient(180deg,rgba(194,105,58,.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-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:18px}
.hero-card .liveDot{width:8px;height:8px;background:var(--ok);border-radius:50%;box-shadow:0 0 12px var(--ok);animation:pulse 1.6s infinite}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.4}}

.scope-anim{position:relative;border-radius:var(--radius-sm);overflow:hidden;background:#05080b;margin-top:6px}
.scope-svg{width:100%;height:auto;display:block}
.scope-anim .pipe-tunnel ellipse{transform-origin:200px 120px;animation:pipe-tunnel 4s linear infinite}
.scope-anim .pipe-tunnel ellipse:nth-child(2){animation-delay:-1s}
.scope-anim .pipe-tunnel ellipse:nth-child(3){animation-delay:-2s}
.scope-anim .pipe-tunnel ellipse:nth-child(4){animation-delay:-3s}
@keyframes pipe-tunnel{0%{transform:scale(.25);opacity:0}30%{opacity:.55}100%{transform:scale(1.4);opacity:0}}
.scope-anim .crosshair{animation:crosshair-jitter 1.6s ease-in-out infinite}
@keyframes crosshair-jitter{0%,100%{transform:translate(0,0)}50%{transform:translate(2px,-1px)}}
.scope-anim .scanline{animation:scan 3.2s linear infinite}
@keyframes scan{0%{transform:translateY(-60px)}100%{transform:translateY(240px)}}
.scope-anim .roots{animation:roots-pulse 2.4s ease-in-out infinite}
@keyframes roots-pulse{0%,100%{opacity:1}50%{opacity:.55}}
@media (prefers-reduced-motion:reduce){.scope-anim *{animation:none!important}}

/* Anatomy interactive cross-section */
.anatomy-svg-wrap{background:var(--bg-2);border:1px solid var(--line);border-radius:var(--radius);padding:24px;position:relative}
.anatomy-svg-wrap svg{width:100%;height:auto;display:block;cursor:crosshair}
.anatomy-svg-wrap .zone{cursor:pointer;transition:opacity .25s}
.anatomy-svg-wrap .zone:hover rect{opacity:.18}
.anatomy-svg-wrap .zone:hover .pulse{stroke-width:3}
.anatomy-svg-wrap .pulse{animation:pulse-glow 2s ease-in-out infinite}
@keyframes pulse-glow{0%,100%{opacity:.7}50%{opacity:1;filter:drop-shadow(0 0 6px currentColor)}}
.anatomy-info{margin-top:18px;padding:18px 22px;background:var(--bg-3);border:1px solid var(--line);border-radius:10px;min-height:60px;display:flex;flex-direction:column;gap:6px}
.anatomy-info strong{font-family:var(--font-display);color:var(--accent-2);font-size:1.05rem;font-weight:400}
.anatomy-info span{font-size:14px;color:var(--ink-dim)}
@media (prefers-reduced-motion:reduce){.anatomy-svg-wrap .pulse{animation:none}}
.scope-meta{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin-top:14px;font-family:var(--font-mono);font-size:11px;color:var(--ink-dim);letter-spacing:.1em}
.scope-meta span b{display:block;color:var(--accent-2);font-size:14px;letter-spacing:0;margin-top:3px}

.trustbar{margin-top:64px;display:grid;grid-template-columns:repeat(4,1fr);gap:0;padding:30px 0;border-top:1px solid var(--line);border-bottom:1px solid var(--line);align-items:center}
.trustbar div{padding:0 28px;border-right:1px solid var(--line);display:flex;align-items:center;gap:12px}
.trustbar div:last-child{border-right:0}
.trustbar div:first-child{padding-left:0}
.trustbar svg{flex-shrink:0;color:var(--accent)}
.trustbar span{font-size:13px;color:var(--ink-2);line-height:1.4}
.trustbar b{color:var(--ink);font-weight:600}

section{padding:120px 0;border-top:1px solid var(--line);position:relative}
.section-head{max-width:780px;margin-bottom:64px}
.section-head h2{margin-top:18px}
.section-head .lead{margin-top:18px}

.svc-list{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.svc{background:linear-gradient(180deg,var(--bg-2),var(--bg-3));border:1px solid var(--line);border-radius:var(--radius);padding:36px;transition:all .35s var(--ease);position:relative;overflow:hidden}
.svc::before{content:"";position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,var(--accent),transparent);opacity:0;transition:opacity .3s}
.svc:hover{border-color:var(--accent);transform:translateY(-4px);background:linear-gradient(180deg,var(--bg-3),var(--bg-4))}
.svc:hover::before{opacity:1}
.svc-icon{width:48px;height:48px;border-radius:12px;background:var(--accent-soft);display:grid;place-items:center;margin-bottom:24px;color:var(--accent)}
.svc h3{color:var(--ink)}
.svc p{margin-top:10px;font-size:15px;color:var(--ink-dim)}
.svc-cta{display:inline-flex;align-items:center;gap:8px;margin-top:24px;padding-top:24px;border-top:1px solid var(--line);font-family:var(--font-body);font-size:14px;font-weight:600;color:var(--accent-2);transition:gap .25s var(--ease)}
.svc-cta:hover{color:var(--accent-3);gap:14px}

.process{display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:start}
.process-steps{position:relative}
.process-steps::before{content:"";position:absolute;left:23px;top:18px;bottom:18px;width:1px;background:linear-gradient(180deg,var(--accent),var(--line) 80%)}
.step{display:grid;grid-template-columns:48px 1fr;gap:24px;padding:18px 0;position:relative}
.step-num{width:48px;height:48px;border-radius:50%;background:var(--bg-3);border:1px solid var(--line-2);display:grid;place-items:center;font-family:var(--font-display);color:var(--accent-2);font-size:1.1rem;position:relative;z-index:1}
.step:hover .step-num{background:var(--accent-soft);border-color:var(--accent);color:var(--accent)}
.step h3{font-size:1.2rem;margin-bottom:6px}
.step p{font-size:14px;color:var(--ink-dim)}
.process-visual{background:var(--bg-2);border:1px solid var(--line);border-radius:var(--radius);padding:32px;position:sticky;top:120px}
.process-visual h4{font-family:var(--font-mono);font-size:11px;color:var(--ink-dim);letter-spacing:.15em;text-transform:uppercase;margin-bottom:18px}

.eeat{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;margin-top:48px}
.eeat .card{padding:32px;background:var(--bg-2);border:1px solid var(--line);border-radius:var(--radius);transition:all .3s var(--ease)}
.eeat .card:hover{border-color:var(--accent);transform:translateY(-3px)}
.eeat .card .badge{width:36px;height:36px;border-radius:8px;background:var(--accent-soft);color:var(--accent);display:grid;place-items:center;font-family:var(--font-display);font-size:1.1rem;margin-bottom:18px}
.eeat .card h3{font-size:1.15rem;color:var(--ink)}
.eeat .card p{font-size:14px;margin-top:8px;color:var(--ink-dim)}

.context{display:grid;grid-template-columns:1.1fr .9fr;gap:80px;align-items:start}
.context-side{background:var(--bg-2);border:1px solid var(--line);border-radius:var(--radius);padding:36px;position:sticky;top:120px}
.context-side h3{font-family:var(--font-display);color:var(--ink);font-size:1.3rem;margin-bottom:18px}
.context-side ul{list-style:none}
.context-side li{padding:16px 0;border-bottom:1px solid var(--line);color:var(--ink);font-size:14px;display:flex;justify-content:space-between;gap:20px;font-family:var(--font-mono)}
.context-side li span{color:var(--ink-dim);text-transform:uppercase;letter-spacing:.1em;font-size:11px}
.context-side li b{font-family:var(--font-display);font-weight:400;color:var(--accent-2);font-size:1.05rem}

.defects{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-top:48px}
.defect{background:var(--bg-2);border:1px solid var(--line);border-radius:var(--radius-sm);padding:24px;transition:all .3s var(--ease)}
.defect:hover{border-color:var(--accent);transform:translateY(-3px)}
.defect-vis{height:120px;border-radius:8px;margin-bottom:18px;background:#05080b;display:grid;place-items:center;overflow:hidden;position:relative}
.defect h4{font-size:.95rem;color:var(--ink);margin-bottom:6px;font-family:var(--font-body);font-weight:600}
.defect p{font-size:13px;color:var(--ink-dim);line-height:1.5}
.defect .severity{font-family:var(--font-mono);font-size:10px;letter-spacing:.1em;text-transform:uppercase;padding:3px 8px;border-radius:4px;display:inline-block;margin-top:10px}
.sev-high{background:rgba(217,119,87,.12);color:var(--warn)}
.sev-med{background:rgba(230,169,114,.12);color:var(--accent-2)}
.sev-low{background:rgba(123,178,123,.12);color:var(--ok)}

.chips{display:flex;flex-wrap:wrap;gap:8px;margin-top:24px}
.chip{padding:10px 16px;border:1px solid var(--line);border-radius:999px;font-size:13px;color:var(--ink-2);background:var(--bg-2);transition:all .2s var(--ease)}
.chip:hover{border-color:var(--accent);color:var(--accent-2);background:var(--accent-soft)}

.pricing{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-top:48px}
.tier{background:var(--bg-2);border:1px solid var(--line);border-radius:var(--radius);padding:40px 32px;position:relative;transition:all .3s var(--ease)}
.tier.featured{border-color:var(--accent);background:linear-gradient(180deg,var(--bg-3),var(--bg-2));transform:scale(1.02)}
.tier.featured::before{content:"Most Booked";position:absolute;top:-14px;right:24px;background:var(--accent);color:#1a0f08;font-size:11px;font-family:var(--font-mono);letter-spacing:.15em;text-transform:uppercase;padding:5px 12px;border-radius:999px}
.tier:hover{transform:translateY(-3px)}
.tier.featured:hover{transform:scale(1.02) translateY(-3px)}
.tier h3{font-size:1.3rem;color:var(--ink)}
.tier .amount{font-family:var(--font-display);font-size:2.8rem;color:var(--accent-2);margin:18px 0 6px;font-weight:400;letter-spacing:-.02em}
.tier .amount small{font-size:1rem;color:var(--ink-dim)}
.tier ul{list-style:none;margin-top:24px;padding-top:24px;border-top:1px solid var(--line)}
.tier li{padding:8px 0;font-size:14px;color:var(--ink-2);display:flex;gap:10px;align-items:flex-start}
.tier li::before{content:"✓";color:var(--accent);font-weight:700;flex-shrink:0}

.faq{max-width:880px}
.faq details{border-bottom:1px solid var(--line);padding:26px 0;transition:padding .25s var(--ease)}
.faq summary{cursor:pointer;list-style:none;display:flex;justify-content:space-between;align-items:center;gap:24px;color:var(--ink);font-family:var(--font-display);font-size:1.3rem;font-weight:400;line-height:1.3}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"";width:26px;height:26px;border:1px solid var(--line-2);border-radius:50%;flex-shrink:0;background-image:linear-gradient(currentColor,currentColor),linear-gradient(currentColor,currentColor);background-size:10px 1px,1px 10px;background-position:center;background-repeat:no-repeat;color:var(--ink-dim);transition:transform .3s var(--ease),border-color .3s,color .3s}
.faq details[open] summary::after{transform:rotate(45deg);border-color:var(--accent);color:var(--accent)}
.faq details[open]{padding:36px 0}
.faq details p{margin-top:18px;color:var(--ink-dim);line-height:1.7;max-width:78ch}

.quotes-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-top:48px}
.quote{background:var(--bg-2);border:1px solid var(--line);border-radius:var(--radius);padding:36px;position:relative;transition:all .3s var(--ease)}
.quote::before{content:"\201C";font-family:var(--font-display);position:absolute;top:6px;left:24px;font-size:5rem;color:var(--accent);opacity:.3;line-height:1}
.quote:hover{border-color:var(--line-2);transform:translateY(-3px)}
.quote p{color:var(--ink);font-size:1.05rem;font-family:var(--font-display);font-weight:400;line-height:1.55;position:relative;z-index:1;padding-top:18px}
.quote cite{display:flex;align-items:center;gap:12px;margin-top:24px;padding-top:20px;border-top:1px solid var(--line);font-style:normal;color:var(--ink-dim);font-size:13px}
.quote cite .avi{width:36px;height:36px;border-radius:50%;background:linear-gradient(135deg,var(--accent),var(--accent-2));flex-shrink:0;display:grid;place-items:center;color:#1a0f08;font-weight:700;font-size:14px}
.quote cite b{display:block;color:var(--ink);font-weight:600;margin-bottom:2px}

.calc-section{background:linear-gradient(180deg,var(--bg-2),var(--bg) 70%);padding:120px 0;position:relative;overflow:hidden}
.calc-section::before{content:"";position:absolute;inset:0;background:radial-gradient(800px 400px at 50% 0%,rgba(194,105,58,.1),transparent 70%);pointer-events:none}
.calc-wrap{max-width:920px;margin:0 auto;text-align:center;position:relative;z-index:1}
.calc-wrap .badge{display:inline-flex;align-items:center;gap:10px;background:var(--accent-soft);border:1px solid var(--accent);color:var(--accent-2);padding:8px 16px;border-radius:999px;font-family:var(--font-mono);font-size:11px;letter-spacing:.15em;text-transform:uppercase;margin-bottom:20px}
.calc-wrap .badge .liveDot{width:6px;height:6px;background:var(--ok);border-radius:50%;animation:pulse 1.6s infinite}
.calc-wrap iframe{margin-top:42px;display:block;border:1px solid var(--line-2)!important;border-radius:var(--radius)!important;box-shadow:0 40px 100px -30px rgba(0,0,0,.8)!important}

.nearby-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-top:32px}
.nearby-grid a{padding:22px;border:1px solid var(--line);border-radius:var(--radius-sm);background:var(--bg-2);color:var(--ink);display:block;transition:all .25s var(--ease);position:relative}
.nearby-grid a:hover{border-color:var(--accent);background:var(--bg-3);transform:translateY(-3px)}
.nearby-grid a b{font-family:var(--font-display);font-weight:400;font-size:1.15rem;color:var(--ink)}
.nearby-grid a:hover b{color:var(--accent-2)}
.nearby-grid a small{display:block;color:var(--ink-dim);font-size:11px;margin-top:6px;font-family:var(--font-mono);letter-spacing:.1em;text-transform:uppercase}

.cities-full{display:grid;grid-template-columns:repeat(5,1fr);gap:10px;margin-top:32px}
.cities-full a{padding:18px;border:1px solid var(--line);border-radius:var(--radius-sm);background:var(--bg-2);color:var(--ink);transition:all .25s var(--ease)}
.cities-full a:hover{border-color:var(--accent);color:var(--accent-2);transform:translateY(-2px)}
.cities-full a b{display:block;font-family:var(--font-display);font-weight:400;font-size:1rem}
.cities-full a small{font-family:var(--font-mono);font-size:10px;color:var(--ink-dim);letter-spacing:.1em;text-transform:uppercase}

.long-form{max-width:780px}
.long-form h3{font-family:var(--font-display);font-size:1.6rem;margin-top:48px;margin-bottom:14px;color:var(--ink)}
.long-form p{color:var(--ink-2);font-size:17px;margin-bottom:18px;line-height:1.75}
.long-form blockquote{border-left:3px solid var(--accent);padding:14px 0 14px 24px;margin:32px 0;font-family:var(--font-display);font-style:italic;font-size:1.25rem;color:var(--ink)}
.long-form ul{padding-left:0;list-style:none;margin:18px 0}
.long-form ul li{padding:10px 0 10px 32px;position:relative;color:var(--ink-2)}
.long-form ul li::before{content:"";position:absolute;left:0;top:18px;width:18px;height:1px;background:var(--accent)}

footer{padding:96px 0 36px;border-top:1px solid var(--line);background:#070a0d}
.foot{display:grid;grid-template-columns:2.5fr 1fr 1fr 1fr 1fr;gap:48px}
.foot h4{font-family:var(--font-mono);font-size:11px;text-transform:uppercase;letter-spacing:.18em;color:var(--accent);margin-bottom:18px}
.foot a{display:block;color:var(--ink-dim);font-size:14px;padding:5px 0}
.foot a:hover{color:var(--ink)}
.foot .brand{margin-bottom:18px}
.legal{margin-top:64px;padding-top:28px;border-top:1px solid var(--line);color:var(--ink-dim);font-size:12px;display:flex;justify-content:space-between;flex-wrap:wrap;gap:14px;font-family:var(--font-mono);letter-spacing:.05em;text-transform:uppercase}

.float-cta{position:fixed;bottom:24px;right:24px;z-index:40;display:flex;align-items:center;gap:10px;padding:14px 22px;background:var(--accent);color:#1a0f08;border-radius:999px;font-weight:600;font-size:14px;box-shadow:0 18px 40px -10px rgba(194,105,58,.5);transition:all .3s var(--ease);opacity:0;transform:translateY(20px);pointer-events:none}
.float-cta.show{opacity:1;transform:translateY(0);pointer-events:auto}
.float-cta:hover{background:var(--accent-2);transform:translateY(-2px)}

.reveal{opacity:0;transform:translateY(24px);transition:opacity .8s var(--ease),transform .8s var(--ease)}
.reveal.in{opacity:1;transform:translateY(0)}

@media (max-width:1000px){
  .hero-grid,.context,.process{grid-template-columns:1fr!important;gap:48px}
  .svc-list,.eeat,.pricing,.quotes-grid{grid-template-columns:1fr 1fr!important}
  .defects,.nearby-grid{grid-template-columns:1fr 1fr!important}
  .cities-full{grid-template-columns:1fr 1fr 1fr!important}
  .foot{grid-template-columns:1fr 1fr!important}
  .trustbar,.hero-meta{grid-template-columns:1fr 1fr!important}
  .trustbar div,.hero-meta div{border-right:0;border-bottom:1px solid var(--line);padding:18px 0}
  .nav-links{display:none}
  section{padding:72px 0}
  .hero{padding:48px 0 64px}
  .tier.featured{transform:none}
  /* About + Sample-Report header split layouts */
  header.hero .wrap[style*="grid-template-columns:1.2fr"]{grid-template-columns:1fr!important}
  /* Anatomy SVG wrap shouldn't overflow */
  .anatomy-svg-wrap{padding:14px;overflow-x:auto}
}
@media (max-width:640px){
  .svc-list,.eeat,.pricing,.quotes-grid,.defects,.nearby-grid,.cities-full,.foot,.trustbar,.hero-meta{grid-template-columns:1fr!important}
  .wrap{padding:0 20px}
  h1{font-size:2.4rem}
  .float-cta{bottom:14px;right:14px}
  /* Force any inline 2/3-col grid inside .wrap to single column on small phones */
  section [style*="grid-template-columns"]{grid-template-columns:1fr!important}
  .announce{font-size:11px;padding:8px 14px}
  .nav-inner{padding:14px 18px}
  .hero-meta{margin-top:32px}
  .hero-meta strong{font-size:1.5rem}
  .svc{padding:24px}
  section{padding:48px 0}
}

/* =============================
   EDITORIAL UPGRADES
   ============================= */

/* Numbered section kicker (eyebrow with data-num) */
.eyebrow[data-num]::before{content:attr(data-num) " ";color:var(--ink-dim);font-weight:500;letter-spacing:.18em;margin-right:6px}

/* Drop cap on long-form lead */
.long-form .lead:first-of-type::first-letter,
.has-dropcap::first-letter{
  font-family:var(--font-display);
  font-size:5.4rem;
  line-height:.85;
  float:left;
  padding:6px 14px 4px 0;
  color:var(--accent);
  font-weight:500;
  font-style:normal;
}

/* Visible breadcrumbs */
.breadcrumbs{display:flex;flex-wrap:wrap;align-items:center;gap:8px;padding:18px 0;font-family:var(--font-mono);font-size:11px;color:var(--ink-dim);letter-spacing:.12em;text-transform:uppercase;border-bottom:1px solid var(--line);margin-bottom:8px}
.breadcrumbs a{color:var(--ink-dim);transition:color .2s var(--ease)}
.breadcrumbs a:hover{color:var(--accent-2)}
.breadcrumbs .sep{color:var(--line-2);font-size:9px}
.breadcrumbs [aria-current]{color:var(--ink);font-weight:600}

/* Hover transforms on cards (tilt + outline) */
.svc{transition:transform .4s var(--ease),box-shadow .4s var(--ease),border-color .25s,background .35s var(--ease)}
.svc:hover{transform:translateY(-4px) rotateX(2deg) rotateY(-1deg);box-shadow:0 30px 60px -30px rgba(194,105,58,.35),0 14px 30px -10px rgba(0,0,0,.6)}
.tier{transition:transform .35s var(--ease),box-shadow .35s var(--ease),border-color .25s}
.tier:hover{transform:translateY(-3px);box-shadow:0 20px 40px -20px rgba(0,0,0,.6)}

/* Magazine pull quote (sidebar callout) */
.pullquote{position:relative;margin:48px 0;padding:32px 28px 32px 80px;border-left:0;background:linear-gradient(180deg,var(--bg-2),var(--bg-3));border:1px solid var(--line);border-radius:14px}
.pullquote::before{content:"\201C";font-family:var(--font-display);position:absolute;top:-12px;left:18px;font-size:6.5rem;color:var(--accent);line-height:1;opacity:.95}
.pullquote p{font-family:var(--font-display);font-style:italic;color:var(--ink);font-size:1.45rem;line-height:1.4;max-width:none;margin:0}
.pullquote cite{display:block;margin-top:14px;font-style:normal;font-family:var(--font-mono);font-size:11px;letter-spacing:.15em;text-transform:uppercase;color:var(--ink-dim)}
@media (max-width:640px){
  .pullquote{padding:24px 20px 24px 20px}
  .pullquote::before{position:relative;top:0;left:0;font-size:3.5rem;display:block;margin-bottom:-22px}
  .pullquote p{font-size:1.15rem}
}

/* Animated section divider */
.section-divider{height:1px;margin:0;background:linear-gradient(90deg,transparent,var(--line-2),var(--accent),var(--line-2),transparent);position:relative;overflow:hidden}
.section-divider::after{content:"";position:absolute;top:0;left:0;height:100%;width:80px;background:linear-gradient(90deg,transparent,var(--accent-2),transparent);animation:slide-sep 6s ease-in-out infinite}
@keyframes slide-sep{0%,100%{transform:translateX(-100px);opacity:0}50%{opacity:1}100%{transform:translateX(calc(100vw + 100px))}}
@media (prefers-reduced-motion:reduce){.section-divider::after{animation:none}}

/* Reading time badge */
.read-time{display:inline-flex;align-items:center;gap:6px;font-family:var(--font-mono);font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--ink-dim);padding:5px 12px;border:1px solid var(--line);border-radius:999px;background:var(--bg-2);margin-left:10px;vertical-align:middle}
.read-time::before{content:"";width:6px;height:6px;border-radius:50%;background:var(--accent)}

/* Asymmetric grid-breaking hero accent */
.hero{position:relative}
.hero-accent{position:absolute;top:80px;right:-40px;font-family:var(--font-mono);font-size:9px;letter-spacing:.4em;color:var(--accent);text-transform:uppercase;writing-mode:vertical-rl;transform:rotate(180deg);opacity:.5;pointer-events:none}
@media (max-width:1000px){.hero-accent{display:none}}

/* Interactive process step illustration */
.process-pipeline{display:grid;grid-template-columns:repeat(6,1fr);gap:8px;margin-top:36px;position:relative}
.process-pipeline .node{position:relative;background:var(--bg-2);border:1px solid var(--line);border-radius:12px;padding:18px 14px;text-align:center;cursor:pointer;transition:all .3s var(--ease)}
.process-pipeline .node:hover,.process-pipeline .node.active{border-color:var(--accent);background:var(--bg-3);transform:translateY(-3px)}
.process-pipeline .node-num{font-family:var(--font-mono);font-size:11px;color:var(--accent);letter-spacing:.1em}
.process-pipeline .node-h{display:block;font-family:var(--font-display);font-size:.9rem;color:var(--ink);margin-top:6px;line-height:1.2}
.process-pipeline .node::after{content:"→";position:absolute;right:-12px;top:50%;transform:translateY(-50%);color:var(--line-2);font-size:14px;z-index:1}
.process-pipeline .node:last-child::after{display:none}
@media (max-width:900px){.process-pipeline{grid-template-columns:repeat(2,1fr)}.process-pipeline .node::after{display:none}}
