/* ===== Flushing Water Damage Restoration — "Response Console" Design System ===== */
:root{
  --storm:#0a1a2f;       /* deep storm navy */
  --storm-2:#0f2742;
  --ink:#0c1420;
  --flood:#19c3e6;       /* flood cyan */
  --flood-deep:#0f8fb0;
  --alert:#ff5a47;       /* urgency coral */
  --alert-deep:#e8412e;
  --mist:#eef6fb;        /* pale mist bg */
  --paper:#ffffff;
  --slate:#5d6b80;
  --line:#dde7f0;
  --ok:#2bb673;
  --maxw:1200px;
  --r:14px; --r-lg:22px; --r-pill:100px;
  --shadow:0 14px 40px rgba(10,26,47,.12);
  --shadow-lg:0 30px 70px rgba(10,26,47,.28);
  --fdisp:"Archivo",-apple-system,system-ui,sans-serif;
  --fbody:"Inter",-apple-system,system-ui,sans-serif;
  --fmono:"Space Mono","SF Mono",ui-monospace,monospace;
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
html,body{max-width:100%;overflow-x:hidden}
body{font-family:var(--fbody);color:var(--ink);background:var(--paper);line-height:1.6;-webkit-font-smoothing:antialiased}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 22px}
section{position:relative}
h1,h2,h3{font-family:var(--fdisp);font-weight:800;line-height:1.04;letter-spacing:-.02em}
h2{font-size:clamp(1.9rem,4vw,3rem)}
h3{font-size:1.3rem}
.eyebrow{font-family:var(--fmono);font-size:.78rem;letter-spacing:.22em;text-transform:uppercase;color:var(--flood-deep);font-weight:700}
.lead{font-size:1.12rem;color:var(--slate)}

/* ---------- Buttons (shining CTA) ---------- */
.btn{position:relative;display:inline-flex;align-items:center;justify-content:center;gap:10px;font-family:var(--fdisp);font-weight:800;font-size:1.02rem;line-height:1;padding:16px 26px;border-radius:var(--r-pill);border:none;cursor:pointer;white-space:nowrap;overflow:hidden;transition:transform .16s,box-shadow .16s;letter-spacing:.01em}
.btn svg{width:19px;height:19px}
.btn-alert{background:linear-gradient(135deg,var(--alert),var(--alert-deep));color:#fff;box-shadow:0 10px 26px rgba(255,90,71,.42)}
.btn-alert:hover{transform:translateY(-2px);box-shadow:0 16px 36px rgba(255,90,71,.55)}
.btn-ghost{background:rgba(255,255,255,.08);color:#fff;border:1.5px solid rgba(255,255,255,.32)}
.btn-ghost:hover{background:rgba(255,255,255,.16);transform:translateY(-2px)}
.btn-flood{background:linear-gradient(135deg,var(--flood),var(--flood-deep));color:#04222b;box-shadow:0 10px 26px rgba(25,195,230,.4)}
.btn-flood:hover{transform:translateY(-2px);box-shadow:0 16px 36px rgba(25,195,230,.55)}
/* shine sweep on all CTAs */
.btn::after{content:"";position:absolute;top:0;left:-75%;width:45%;height:100%;background:linear-gradient(120deg,transparent,rgba(255,255,255,.55),transparent);transform:skewX(-20deg);animation:sweep 4.5s ease-in-out infinite}
@keyframes sweep{0%,100%{left:-75%}55%{left:135%}}
@media(prefers-reduced-motion:reduce){.btn::after{display:none}}

/* ---------- Topbar ---------- */
.topbar{background:var(--ink);color:#cfe0ef;font-size:.84rem}
.topbar .wrap{display:flex;justify-content:center;align-items:center;gap:10px;padding:9px 22px;text-align:center}
.topbar b{color:#fff}
.topbar .ping{width:8px;height:8px;border-radius:50%;background:var(--ok);box-shadow:0 0 0 0 rgba(43,182,115,.7);animation:ping 1.8s infinite;flex-shrink:0}
@keyframes ping{0%{box-shadow:0 0 0 0 rgba(43,182,115,.6)}70%{box-shadow:0 0 0 9px rgba(43,182,115,0)}100%{box-shadow:0 0 0 0 rgba(43,182,115,0)}}

/* ---------- Header ---------- */
.hdr{position:sticky;top:0;z-index:60;background:rgba(255,255,255,.86);backdrop-filter:blur(14px);border-bottom:1px solid var(--line)}
.hdr .wrap{display:flex;align-items:center;justify-content:space-between;gap:20px;height:72px}
.brand{display:flex;align-items:center;gap:12px;flex-shrink:0}
.brand .mark{width:44px;height:44px;flex-shrink:0}
.brand .bt{font-family:var(--fdisp);font-weight:800;font-size:1.04rem;color:var(--storm);line-height:1.02;letter-spacing:-.01em}
.brand .bt small{display:block;font-family:var(--fmono);font-size:.62rem;letter-spacing:.16em;color:var(--flood-deep);font-weight:700;margin-top:2px}
.nav{display:flex;align-items:center;gap:22px}
.nav a:not(.btn){font-weight:600;font-size:.95rem;color:var(--storm);white-space:nowrap;position:relative;padding:4px 0}
.nav a:not(.btn)::after{content:"";position:absolute;left:0;bottom:-2px;width:0;height:2px;background:var(--flood);transition:width .22s}
.nav a:not(.btn):hover::after{width:100%}
.nav .btn-call{padding:12px 20px;font-size:.95rem}
.burger{display:none;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer;padding:8px}
.burger span{width:26px;height:2.5px;background:var(--storm);border-radius:2px;transition:.3s}
.burger.x span:nth-child(1){transform:translateY(7.5px) rotate(45deg)}
.burger.x span:nth-child(2){opacity:0}
.burger.x span:nth-child(3){transform:translateY(-7.5px) rotate(-45deg)}

/* ---------- Floating background (ambient water) ---------- */
.ambient{position:absolute;inset:0;overflow:hidden;pointer-events:none;z-index:0}
.ambient .bubble{position:absolute;bottom:-60px;border-radius:50%;background:radial-gradient(circle at 35% 30%,rgba(255,255,255,.22),rgba(25,195,230,.08));border:1px solid rgba(255,255,255,.1);animation:rise linear infinite}
@keyframes rise{0%{transform:translateY(0) scale(.6);opacity:0}10%{opacity:.7}90%{opacity:.5}100%{transform:translateY(-115vh) scale(1.1);opacity:0}}
@media(prefers-reduced-motion:reduce){.ambient{display:none}}

/* ---------- HERO + Response Console ---------- */
.hero{position:relative;background:radial-gradient(120% 90% at 80% 0,#13335a 0,var(--storm) 55%,#06101f 100%);color:#fff;overflow:hidden;padding:46px 0 70px}
.hero .wrap{position:relative;z-index:2;display:grid;grid-template-columns:1.05fr .95fr;gap:48px;align-items:center}
.hero-status{display:inline-flex;align-items:center;gap:9px;font-family:var(--fmono);font-size:.76rem;letter-spacing:.12em;text-transform:uppercase;color:#bfe6f2;background:rgba(25,195,230,.1);border:1px solid rgba(25,195,230,.3);padding:7px 14px;border-radius:var(--r-pill)}
.hero-status .ping{width:8px;height:8px;border-radius:50%;background:var(--alert);box-shadow:0 0 0 0 rgba(255,90,71,.7);animation:ping 1.6s infinite}
.hero h1{font-size:clamp(2.5rem,5.4vw,4.4rem);margin:20px 0 0}
.hero h1 .hl{color:var(--flood)}
.hero-sub{font-size:1.18rem;color:#c2d4e6;margin:18px 0 26px;max-width:42ch}
.hero-cta{display:flex;gap:14px;flex-wrap:wrap}
.hero-assure{display:flex;gap:22px;flex-wrap:wrap;margin-top:24px;font-size:.9rem;color:#9fb6cd}
.hero-assure span{display:inline-flex;align-items:center;gap:8px}
.hero-assure svg{width:17px;height:17px;color:var(--flood)}

/* The Response Console card */
.console{position:relative;background:linear-gradient(160deg,rgba(255,255,255,.07),rgba(255,255,255,.02));border:1px solid rgba(255,255,255,.14);border-radius:var(--r-lg);padding:26px;backdrop-filter:blur(8px);box-shadow:var(--shadow-lg)}
.console::before{content:"";position:absolute;inset:0;border-radius:var(--r-lg);padding:1px;background:linear-gradient(140deg,rgba(25,195,230,.6),transparent 40%,transparent 60%,rgba(255,90,71,.4));-webkit-mask:linear-gradient(#000 0 0) content-box,linear-gradient(#000 0 0);-webkit-mask-composite:xor;mask-composite:exclude;pointer-events:none}
.console-top{display:flex;justify-content:space-between;align-items:center;font-family:var(--fmono);font-size:.72rem;letter-spacing:.14em;text-transform:uppercase;color:#8fb0c9;margin-bottom:18px}
.console-top .live{display:inline-flex;align-items:center;gap:7px;color:var(--flood)}
.console-top .live .ping{width:7px;height:7px;border-radius:50%;background:var(--flood);box-shadow:0 0 0 0 rgba(25,195,230,.7);animation:ping 1.6s infinite}
.console-timer{text-align:center;padding:8px 0 18px}
.console-timer .t{font-family:var(--fdisp);font-weight:800;font-size:4.6rem;line-height:.9;color:#fff;letter-spacing:-.03em;font-variant-numeric:tabular-nums}
.console-timer .t .unit{font-size:1.5rem;color:var(--flood);margin-left:6px}
.console-timer .lbl{font-family:var(--fmono);font-size:.74rem;letter-spacing:.16em;text-transform:uppercase;color:#8fb0c9;margin-top:8px}
.console-rows{display:grid;gap:12px;margin-top:6px}
.crow{display:flex;align-items:center;gap:12px;font-size:.9rem}
.crow .ci{width:34px;height:34px;border-radius:9px;background:rgba(25,195,230,.12);display:grid;place-items:center;color:var(--flood);flex-shrink:0}
.crow .ci svg{width:18px;height:18px}
.crow .cm{color:#cfe0ef;flex:1}
.crow .cv{font-family:var(--fmono);color:#fff;font-weight:700}
.crow .bar{height:6px;border-radius:6px;background:rgba(255,255,255,.1);overflow:hidden;flex:1;max-width:120px}
.crow .bar i{display:block;height:100%;border-radius:6px;background:linear-gradient(90deg,var(--flood),var(--flood-deep));width:0;animation:fillbar 2s ease forwards}
@keyframes fillbar{to{width:var(--w,90%)}}
.console-foot{margin-top:18px}
.console-foot .btn{width:100%}

/* ---------- Marquee coverage strip ---------- */
.cov-strip{background:var(--ink);color:#8fb0c9;font-family:var(--fmono);font-size:.82rem;letter-spacing:.1em;text-transform:uppercase;overflow:hidden;max-width:100vw;border-bottom:1px solid rgba(255,255,255,.06)}
.cov-track{display:flex;gap:42px;white-space:nowrap;padding:13px 0;animation:marq 28s linear infinite;width:max-content}
.cov-track span{display:inline-flex;align-items:center;gap:42px}
.cov-track b{color:var(--flood)}
@keyframes marq{to{transform:translateX(-50%)}}

/* ---------- Stat band (animated counters) ---------- */
.stats{background:var(--mist);padding:54px 0}
.stats .grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}
.stat{background:#fff;border:1px solid var(--line);border-radius:var(--r);padding:26px 22px;position:relative;overflow:hidden}
.stat::before{content:"";position:absolute;left:0;top:0;bottom:0;width:4px;background:linear-gradient(var(--flood),var(--flood-deep))}
.stat .n{font-family:var(--fdisp);font-weight:800;font-size:2.6rem;color:var(--storm);line-height:1;font-variant-numeric:tabular-nums}
.stat .n .u{color:var(--flood);font-size:1.5rem}
.stat .l{color:var(--slate);font-size:.95rem;margin-top:7px}
@media(max-width:780px){.stats .grid{grid-template-columns:repeat(2,1fr)}}

/* ---------- Section scaffolding ---------- */
.sec{padding:78px 0}
.sec-head{max-width:680px;margin-bottom:42px}
.sec-head.ctr{margin-left:auto;margin-right:auto;text-align:center}
.sec-head h2{margin-top:12px}
.sec-head p{margin-top:14px}

/* ---------- Services (water-fill cards) ---------- */
.svc-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.svc{position:relative;background:#fff;border:1px solid var(--line);border-radius:var(--r-lg);padding:28px;overflow:hidden;transition:transform .2s,box-shadow .2s,border-color .2s;z-index:0}
.svc::before{content:"";position:absolute;left:0;right:0;bottom:0;height:0;background:linear-gradient(180deg,rgba(25,195,230,.08),rgba(25,195,230,.16));transition:height .35s ease;z-index:-1}
.svc:hover{transform:translateY(-6px);box-shadow:var(--shadow);border-color:var(--flood)}
.svc:hover::before{height:100%}
.svc .ic{width:54px;height:54px;border-radius:14px;background:linear-gradient(140deg,var(--storm),var(--storm-2));display:grid;place-items:center;color:var(--flood);margin-bottom:18px}
.svc .ic svg{width:27px;height:27px}
.svc h3{color:var(--storm)}
.svc p{color:var(--slate);font-size:.96rem;margin-top:9px}
.svc .more{display:inline-flex;align-items:center;gap:7px;margin-top:16px;font-family:var(--fmono);font-size:.78rem;letter-spacing:.08em;text-transform:uppercase;color:var(--flood-deep);font-weight:700}
.svc .more svg{width:15px;height:15px;transition:transform .2s}
.svc:hover .more svg{transform:translateX(4px)}
@media(max-width:900px){.svc-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:600px){.svc-grid{grid-template-columns:1fr}}

/* ---------- Split (image + text) ---------- */
.split{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:center}
.split.flip .split-media{order:2}
.split-media{position:relative;border-radius:var(--r-lg);overflow:hidden;box-shadow:var(--shadow)}
.split-media{height:380px}
.split-media img{width:100%;height:100%;object-fit:cover;object-position:center;display:block}
.split-media .tag{position:absolute;left:16px;bottom:16px;background:rgba(10,26,47,.82);backdrop-filter:blur(6px);color:#fff;font-family:var(--fmono);font-size:.74rem;letter-spacing:.08em;padding:8px 13px;border-radius:9px;border:1px solid rgba(25,195,230,.3)}
.split-body h2{color:var(--storm)}
.split-body p{color:var(--slate);margin-top:14px}
.split-body ul{list-style:none;margin:20px 0 0;display:grid;gap:12px}
.split-body li{display:flex;gap:11px;align-items:flex-start}
.split-body li svg{width:21px;height:21px;color:var(--flood-deep);flex-shrink:0;margin-top:3px}
.split-body li b{color:var(--storm)}
@media(max-width:860px){.split{grid-template-columns:1fr;gap:28px}.split.flip .split-media{order:0}}

/* ---------- Process (rising water timeline) ---------- */
.proc{background:linear-gradient(180deg,var(--storm),#06101f);color:#fff;overflow:hidden}
.proc .eyebrow{color:var(--flood)}
.proc h2{color:#fff}
.proc-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;margin-top:42px;counter-reset:step}
.pstep{position:relative;background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.1);border-radius:var(--r-lg);padding:26px 22px}
.pstep .pn{font-family:var(--fmono);font-size:.78rem;letter-spacing:.1em;color:var(--flood);font-weight:700}
.pstep h3{margin:12px 0 8px;font-size:1.18rem}
.pstep p{color:#a8c0d4;font-size:.92rem}
.pstep .wl{position:absolute;left:0;right:0;bottom:0;height:3px;background:linear-gradient(90deg,var(--flood),var(--alert));border-radius:3px;transform:scaleX(0);transform-origin:left;transition:transform .6s ease}
.pstep.in .wl{transform:scaleX(1)}
@media(max-width:900px){.proc-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:520px){.proc-grid{grid-template-columns:1fr}}

/* ---------- Coverage map band ---------- */
.cov{background:var(--mist);overflow:hidden}
.cov-inner{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:center}
.radar{position:relative;aspect-ratio:1;max-width:440px;margin:0 auto;border-radius:50%;background:radial-gradient(circle,#0f2742,#0a1a2f);border:1px solid var(--line);box-shadow:var(--shadow);overflow:hidden}
.radar .ring{position:absolute;border:1px solid rgba(25,195,230,.2);border-radius:50%;inset:0;margin:auto}
.radar .sweep{position:absolute;inset:0;border-radius:50%;background:conic-gradient(from 0deg,rgba(25,195,230,.32),transparent 70deg);animation:radar 4.5s linear infinite}
@keyframes radar{to{transform:rotate(360deg)}}
.radar-lines{position:absolute;inset:0;width:100%;height:100%;pointer-events:none}
.radar-lines line{stroke:rgba(25,195,230,.22);stroke-width:.4}
.radar .dot{position:absolute;width:10px;height:10px;border-radius:50%;background:var(--flood);box-shadow:0 0 0 0 rgba(25,195,230,.6);transform:translate(-50%,-50%);animation:blip 2.8s ease-out infinite}
@keyframes blip{0%{box-shadow:0 0 0 0 rgba(25,195,230,.55)}60%{box-shadow:0 0 0 12px rgba(25,195,230,0)}100%{box-shadow:0 0 0 0 rgba(25,195,230,0)}}
.radar .dot.hub{width:16px;height:16px;background:var(--alert);box-shadow:0 0 18px var(--alert);animation:blip 1.8s ease-out infinite;z-index:3}
.radar .dot.hub{--c:var(--alert)}
.radar .dlabel{position:absolute;font-family:var(--fmono);font-size:.6rem;letter-spacing:.02em;color:#bfe6f2;transform:translate(-50%,0);white-space:nowrap;text-shadow:0 1px 4px rgba(0,0,0,.6);pointer-events:none}
.radar .dlabel.hub-lbl{color:#ffd0c8;font-weight:700;font-size:.66rem}
@media(prefers-reduced-motion:reduce){.radar .sweep,.radar .dot{animation:none}}
@media(max-width:520px){.radar .dlabel{font-size:.52rem}}
.cov-list{columns:2;column-gap:18px}
.cov-list a{display:block;padding:9px 0;border-bottom:1px solid var(--line);font-weight:600;color:var(--storm);font-size:.96rem;transition:color .15s,padding .15s}
.cov-list a:hover{color:var(--flood-deep);padding-left:6px}
@media(max-width:860px){.cov-inner{grid-template-columns:1fr;gap:30px}}

/* ---------- FAQ ---------- */
.faq{max-width:780px;margin:0 auto}
.faq details{border:1px solid var(--line);border-radius:var(--r);margin-bottom:12px;background:#fff;overflow:hidden}
.faq summary{list-style:none;cursor:pointer;padding:20px 22px;font-family:var(--fdisp);font-weight:700;color:var(--storm);display:flex;justify-content:space-between;align-items:center;gap:14px}
.faq summary::-webkit-details-marker{display:none}
.faq summary .pl{font-family:var(--fmono);color:var(--flood-deep);font-size:1.3rem;transition:transform .25s;flex-shrink:0}
.faq details[open] summary .pl{transform:rotate(45deg)}
.faq .a{padding:0 22px 20px;color:var(--slate)}

/* ---------- CTA band ---------- */
.cta-band{position:relative;background:linear-gradient(135deg,var(--alert),var(--alert-deep));color:#fff;border-radius:var(--r-lg);padding:54px 44px;text-align:center;overflow:hidden}
.cta-band h2{color:#fff;position:relative;z-index:1}
.cta-band p{margin:14px auto 26px;max-width:48ch;color:#ffe2dd;position:relative;z-index:1}
.cta-band .btn{position:relative;z-index:1}
.cta-band .ripple{position:absolute;border-radius:50%;border:2px solid rgba(255,255,255,.3);left:50%;top:50%;transform:translate(-50%,-50%);animation:ripple 4s ease-out infinite}
@keyframes ripple{0%{width:60px;height:60px;opacity:.8}100%{width:760px;height:760px;opacity:0}}

/* ---------- Footer ---------- */
.ft{background:var(--ink);color:#9fb6cd;padding:60px 0 26px}
.ft-grid{display:grid;grid-template-columns:1.5fr 1fr 1fr 1fr;gap:32px}
.ft h4{font-family:var(--fdisp);color:#fff;font-size:1rem;margin-bottom:16px}
.ft a{display:block;color:#9fb6cd;padding:5px 0;font-size:.93rem;transition:color .15s}
.ft a:hover{color:var(--flood)}
.ft .ft-brand .bt{font-family:var(--fdisp);font-weight:800;color:#fff;font-size:1.2rem}
.ft p{font-size:.92rem;margin-top:12px;max-width:34ch}
.ft .nap{margin-top:16px;font-size:.9rem;line-height:1.9}
.ft .nap b{color:#fff}
.ft-crawl{margin-top:30px;border-top:1px solid rgba(255,255,255,.08)}
.ft-crawl summary{cursor:pointer;padding:16px 0;font-family:var(--fmono);font-size:.78rem;letter-spacing:.1em;text-transform:uppercase;color:#7e95ab}
.ft-crawl .lk{display:flex;flex-wrap:wrap;gap:6px 18px;padding-bottom:16px}
.ft-crawl .lk a{font-size:.86rem;padding:3px 0}
.ft-bottom{border-top:1px solid rgba(255,255,255,.08);margin-top:14px;padding-top:20px;display:flex;justify-content:space-between;flex-wrap:wrap;gap:10px;font-size:.84rem}
.ft-legal{text-align:center;font-size:.72rem;color:#5f748c;margin-top:14px;letter-spacing:.02em}
@media(max-width:860px){.ft-grid{grid-template-columns:1fr 1fr}}
@media(max-width:520px){.ft-grid{grid-template-columns:1fr}}

/* ---------- Floating tap-to-call ---------- */
.tapcall{position:fixed;right:18px;bottom:18px;z-index:120;display:inline-flex;align-items:center;gap:11px;background:linear-gradient(135deg,var(--alert),var(--alert-deep));color:#fff;font-family:var(--fdisp);font-weight:800;font-size:1.08rem;padding:16px 26px;border-radius:var(--r-pill);box-shadow:0 14px 40px rgba(255,90,71,.5);overflow:hidden;border:2px solid rgba(255,255,255,.45);animation:bob 3s ease-in-out infinite}
.tapcall .ring{position:absolute;inset:0;border-radius:var(--r-pill);box-shadow:0 0 0 0 rgba(255,90,71,.6);animation:ping 2s infinite}
.tapcall svg{width:23px;height:23px;flex-shrink:0;animation:wiggle 2.4s ease-in-out infinite;transform-origin:center}
.tapcall::after{content:"";position:absolute;top:0;left:-75%;width:45%;height:100%;background:linear-gradient(120deg,transparent,rgba(255,255,255,.6),transparent);transform:skewX(-20deg);animation:sweep 3.6s ease-in-out infinite}
@keyframes bob{0%,100%{transform:translateY(0)}50%{transform:translateY(-6px)}}
@keyframes wiggle{0%,88%,100%{transform:rotate(0)}92%{transform:rotate(-13deg)}96%{transform:rotate(13deg)}}
@media(prefers-reduced-motion:reduce){.tapcall{animation:none}.tapcall .ring,.tapcall::after{display:none}}

/* ---------- Reveal on scroll ---------- */
.reveal{opacity:0;transform:translateY(26px);transition:opacity .7s ease,transform .7s ease}
.reveal.in{opacity:1;transform:none}
@media(prefers-reduced-motion:reduce){.reveal{opacity:1;transform:none}}

/* ---------- Subpage hero ---------- */
.subhero{background:radial-gradient(120% 90% at 80% 0,#13335a 0,var(--storm) 60%,#06101f 100%);color:#fff;padding:40px 0 56px;overflow:hidden}
.subhero .wrap{position:relative;z-index:2}
.crumbs{font-family:var(--fmono);font-size:.76rem;letter-spacing:.06em;color:#8fb0c9;margin-bottom:14px}
.crumbs a{color:#bfe6f2}
.subhero h1{font-size:clamp(2.1rem,4.4vw,3.3rem);margin:10px 0 0}
.subhero p{color:#c2d4e6;margin-top:14px;max-width:60ch}
.subhero .hero-cta{margin-top:24px}

/* ---------- Mobile nav ---------- */
@media(max-width:1180px){
  .burger{display:flex}
  .nav{position:fixed;inset:72px 0 auto 0;flex-direction:column;background:#fff;gap:0;padding:10px 0 18px;border-bottom:1px solid var(--line);box-shadow:var(--shadow);transform:translateY(-130%);transition:transform .34s cubic-bezier(.4,0,.2,1);z-index:55}
  .nav.open{transform:translateY(0)}
  .nav a:not(.btn){width:100%;padding:15px 24px;border-bottom:1px solid var(--mist)}
  .nav a:not(.btn)::after{display:none}
  .nav .btn-call{margin:14px 24px 4px}
}
@media(max-width:980px){.hero .wrap{grid-template-columns:1fr;gap:34px}.console{order:2}}
@media(max-width:600px){
  .hero{padding:30px 0 54px}
  .console-timer .t{font-size:3.6rem}
  .cta-band{padding:40px 24px}
  .sec{padding:54px 0}
}

/* ---------- Areas grid + contact cards ---------- */
.area-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:12px}
.acard{display:flex;align-items:center;gap:10px;background:#fff;border:1px solid var(--line);border-radius:var(--r);padding:16px 16px;font-weight:600;color:var(--storm);transition:transform .16s,box-shadow .16s,border-color .16s}
.acard:hover{transform:translateY(-3px);box-shadow:var(--shadow);border-color:var(--flood)}
.acard svg{width:20px;height:20px;color:var(--flood-deep);flex-shrink:0}
@media(max-width:780px){.area-grid{grid-template-columns:repeat(2,1fr)}}

.contact-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;max-width:1000px;margin:0 auto}
.ccard{background:#fff;border:1px solid var(--line);border-radius:var(--r-lg);padding:30px 26px;text-align:center}
.ccard .ic{width:58px;height:58px;border-radius:15px;background:linear-gradient(140deg,var(--storm),var(--storm-2));display:grid;place-items:center;color:var(--flood);margin:0 auto 16px}
.ccard .ic svg{width:27px;height:27px}
.ccard h3{color:var(--storm)}
.ccard p{color:var(--slate);font-size:.95rem;margin-top:8px}
@media(max-width:780px){.contact-grid{grid-template-columns:1fr}}

/* ---------- Hero visual: team photo + console stacked ---------- */
.hero-visual{position:relative;display:flex;flex-direction:column;gap:18px;align-self:start}
.hero-photo{border-radius:var(--r-lg);overflow:hidden;box-shadow:var(--shadow-lg);border:1px solid rgba(255,255,255,.12);position:relative;height:420px}
.hero-photo img{width:100%;height:100%;object-fit:cover;object-position:center 30%;display:block}
.hero-photo::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 62%,rgba(10,26,47,.4));pointer-events:none}

/* ---------- Photo service cards ---------- */
.svc-photo{padding:0;overflow:hidden}
.svc-photo .svc-img{display:block;position:relative;overflow:hidden}
.svc-photo .svc-img{height:210px}
.svc-photo .svc-img img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .4s ease}
.svc-photo:hover .svc-img img{transform:scale(1.06)}
.svc-photo .svc-ic-badge{position:absolute;left:16px;bottom:-22px;width:48px;height:48px;border-radius:13px;background:linear-gradient(140deg,var(--storm),var(--storm-2));border:2px solid #fff;display:grid;place-items:center;color:var(--flood);box-shadow:var(--shadow)}
.svc-photo .svc-ic-badge svg{width:23px;height:23px}
.svc-photo .svc-pad{padding:32px 26px 28px}
.svc-photo .svc-pad h3{color:var(--storm)}
.svc-photo .svc-pad p{color:var(--slate);font-size:.96rem;margin-top:9px}
.svc-photo:hover::before{height:0}

/* ---------- Coverage van banner (16:9 natural, no overlap) ---------- */
.cov-van{position:relative;margin:40px auto 0;max-width:900px;border-radius:var(--r-lg);overflow:hidden;box-shadow:var(--shadow)}
.cov-van{height:420px}
.cov-van img{width:100%;height:100%;object-fit:cover;object-position:center 58%;display:block}
.cov-van .tag{position:absolute;left:16px;bottom:16px;background:rgba(10,26,47,.82);backdrop-filter:blur(6px);color:#fff;font-family:var(--fmono);font-size:.74rem;letter-spacing:.08em;padding:8px 13px;border-radius:9px;border:1px solid rgba(25,195,230,.3)}

/* ---------- Responsive image heights ---------- */
@media(max-width:860px){
  .split-media{height:300px}
  .cov-van{height:300px}
}
@media(max-width:600px){
  .split-media{height:240px}
  .cov-van{height:200px}
  .svc-photo .svc-img{height:190px}
  .hero-photo{height:300px}
}

/* ---------- Icon-tile service card (no-photo services) ---------- */
.svc-iconwrap{display:grid;place-items:center;height:210px;background:linear-gradient(150deg,var(--storm),var(--storm-2));position:relative;overflow:hidden}
.svc-iconwrap::before{content:"";position:absolute;inset:0;background:radial-gradient(circle at 70% 20%,rgba(25,195,230,.25),transparent 60%)}
.svc-iconwrap::after{content:"";position:absolute;left:-40%;right:-40%;bottom:-30%;height:80%;background:radial-gradient(ellipse at 50% 100%,rgba(25,195,230,.18),transparent 70%);animation:mpFloat 9s ease-in-out infinite}
@keyframes mpFloat{0%,100%{transform:translateY(0)}50%{transform:translateY(-12px)}}
.svc-bigicon{position:relative;z-index:1;width:78px;height:78px;border-radius:20px;background:rgba(255,255,255,.06);border:1px solid rgba(25,195,230,.4);display:grid;place-items:center;color:var(--flood)}
.svc-bigicon svg{width:38px;height:38px}
@media(max-width:600px){.svc-iconwrap{height:190px}}

/* ---------- Work gallery (service pages) ---------- */
.gallery{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}
.gallery figure{position:relative;border-radius:var(--r-lg);overflow:hidden;box-shadow:var(--shadow);margin:0;height:240px}
.gallery figure img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .5s ease}
.gallery figure:hover img{transform:scale(1.07)}
.gallery figcaption{position:absolute;left:12px;bottom:12px;background:rgba(10,26,47,.82);backdrop-filter:blur(6px);color:#fff;font-family:var(--fmono);font-size:.7rem;letter-spacing:.06em;padding:7px 12px;border-radius:8px;border:1px solid rgba(25,195,230,.3)}
@media(max-width:900px){.gallery{grid-template-columns:repeat(2,1fr)}.gallery figure{height:200px}}
@media(max-width:520px){.gallery{grid-template-columns:1fr 1fr;gap:10px}.gallery figure{height:150px}}
