/* ===========================================================
   Top to Bottom Pressure Washing — site styles
   Brand: navy #1D3E8C / sky #22A1F2 / orange #F29100 / yellow #FFD200
   Fonts: Oswald (display), Roboto Condensed (sub), Inter (body)
=========================================================== */

:root{
  --navy:#1D3E8C;
  --navy-dk:#0a1f5a;
  --navy-ink:#091434;
  --sky:#22A1F2;
  --orange:#F29100;
  --orange-dk:#b56c00;
  --yellow:#FFD200;
  --ice:#F4F9FF;
  --ink:#0E1A33;
  --text:#1a2950;
  --muted:#41506e;
  --line:rgba(29,62,140,.12);
  --line-dk:rgba(29,62,140,.22);
}

*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth}
html,body{margin:0;padding:0}
body{
  background:#fff;color:var(--ink);
  font:400 16px/1.6 Inter,system-ui,-apple-system,Segoe UI,Helvetica,Arial,sans-serif;
  -webkit-font-smoothing:antialiased;
}
img,svg{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
button{font:inherit;cursor:pointer}

/* skip link for a11y */
.skip{position:absolute;left:-9999px;top:0;background:var(--navy);color:#fff;padding:10px 14px;z-index:9999}
.skip:focus{left:8px;top:8px}

:focus-visible{outline:3px solid var(--sky);outline-offset:2px;border-radius:4px}

.container{max-width:1680px;margin:0 auto;padding:0 clamp(40px,5vw,72px)}

/* ---------- TOP BAR ---------- */
.topbar{background:var(--navy-ink);color:#dfe9ff;font:500 13px/1 Inter;padding:9px 0}
.topbar .row{display:flex;justify-content:space-between;align-items:center;gap:16px;flex-wrap:wrap}
.topbar b{color:var(--yellow)}
.topbar a{color:#dfe9ff}
.topbar a:hover{color:#fff}

/* phone icon helpers (inline contexts) */
.ic-phone,.ic-phone-sm{display:inline-block;vertical-align:middle;flex-shrink:0}
.topbar .ic-phone-sm,.footer .ic-phone-sm{vertical-align:-2px;margin-right:3px}

/* ---------- NAV ---------- */
.nav{background:#fff;border-bottom:3px solid var(--orange);position:sticky;top:0;z-index:100}
.nav .row{display:flex;align-items:center;gap:24px;padding-top:14px;padding-bottom:14px}
.logo{display:inline-flex;align-items:center;gap:12px;font:800 18px/1 Oswald;text-transform:uppercase;color:var(--navy);letter-spacing:.04em}
.logo-img{height:110px;width:auto;display:block;flex-shrink:0}
.logo-img-footer{height:180px}
.nav nav{display:flex;gap:26px;margin-left:auto;font:600 15px/1 Inter;text-transform:uppercase;letter-spacing:.08em;color:var(--navy)}
.nav nav a{padding:8px 0;border-bottom:2px solid transparent;transition:.15s}
.nav nav a:hover{border-color:var(--orange)}
.nav .phone{display:inline-flex;align-items:center;gap:8px;background:var(--navy);color:#fff;padding:13px 18px;border-radius:6px;font:800 15px/1 Inter;white-space:nowrap}
.nav-toggle{display:none;background:transparent;border:0;color:var(--navy);font-size:24px;padding:6px;margin-left:auto}

/* ---------- BUTTONS ---------- */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:10px;padding:14px 22px;border-radius:8px;font:800 14px/1 Inter;letter-spacing:.08em;text-transform:uppercase;border:0;cursor:pointer;text-align:center;transition:transform .1s,box-shadow .15s}
.btn-orange{background:var(--orange);color:#fff;box-shadow:0 5px 0 var(--orange-dk)}
.btn-orange:hover{transform:translateY(-1px);box-shadow:0 6px 0 var(--orange-dk)}
.btn-orange:active{transform:translateY(3px);box-shadow:0 2px 0 var(--orange-dk)}
.btn-navy{background:var(--navy);color:#fff}
.btn-navy:hover{background:var(--navy-dk)}
.btn-outline{background:#fff;color:var(--navy);border:2px solid var(--navy)}
.btn-outline:hover{background:var(--navy);color:#fff}
.btn-ghost{background:transparent;color:#fff;border:2px solid rgba(255,255,255,.7)}
.btn-ghost:hover{background:rgba(255,255,255,.1);border-color:#fff}

/* ---------- HERO ---------- */
.hero{background:linear-gradient(135deg,#0a1f5a 0%,#1D3E8C 55%,#22A1F2 130%);color:#fff;position:relative;overflow:hidden}
.hero::before,.hero::after{content:"";position:absolute;border-radius:50%;background:rgba(255,255,255,.04);pointer-events:none}
.hero::before{width:520px;height:520px;top:-180px;right:-160px}
.hero::after{width:340px;height:340px;bottom:-140px;left:-100px}
.hero .row{display:grid;grid-template-columns:1.1fr .9fr;gap:50px;padding-top:56px;padding-bottom:64px;align-items:center;position:relative;z-index:1}
.hero .eye{display:inline-flex;align-items:center;gap:8px;background:rgba(255,210,0,.18);color:var(--yellow);border:1px solid rgba(255,210,0,.4);padding:7px 13px;border-radius:999px;font:700 11px/1 Inter;letter-spacing:.18em;text-transform:uppercase;margin-bottom:18px}
.hero h1{font:800 60px/1 Oswald;text-transform:uppercase;letter-spacing:.005em;margin:0 0 18px;font-size:clamp(36px,4.4vw,60px)}
.hero h1 .y{color:var(--yellow)}
.hero .brand-sub{font:700 14px/1.3 Inter;letter-spacing:.18em;text-transform:uppercase;color:var(--yellow);margin:-6px 0 18px;opacity:.95}
.hero .tag{font:500 18px/1.45 Roboto Condensed;max-width:520px;color:#dfe9ff;margin:0 0 24px}
.hero ul{margin:0 0 30px;padding:0;list-style:none;display:grid;grid-template-columns:1fr 1fr;gap:10px 20px;max-width:540px}
.hero ul li{font:600 14px/1.3 Inter;display:flex;align-items:center;gap:10px}
.hero ul li::before{content:"";width:22px;height:22px;background:var(--orange);color:#fff;display:grid;place-items:center;border-radius:50%;font:800 12px/1 Inter;flex-shrink:0;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='white' stroke-width='4'%3E%3Cpath d='M5 12l5 5L20 7'/%3E%3C/svg%3E");background-size:14px;background-repeat:no-repeat;background-position:center}
.hero .ctas{display:flex;gap:12px;align-items:center;flex-wrap:wrap}
.hero .ctas .btn{padding:14px 22px}
.hero .ctas .btn-ghost{font-family:Oswald;font-size:18px;letter-spacing:.04em}

/* hero quote form */
.quote-card{background:#fff;color:var(--ink);border-radius:16px;padding:26px;box-shadow:0 30px 60px rgba(0,0,0,.25);border-top:6px solid var(--orange)}
.quote-card h2{font:800 24px/1.1 Oswald;color:var(--navy);text-transform:uppercase;margin:0 0 4px;letter-spacing:.01em}
.quote-card .sub{font:500 13px/1.4 Roboto Condensed;color:var(--muted);margin:0 0 18px}
.quote-card form{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.quote-card .full{grid-column:1/-1}
.quote-card input,.quote-card select,.quote-card textarea{
  border:1px solid var(--line);background:#fff;
  padding:12px 14px;border-radius:8px;
  font:500 14px/1.3 Inter;color:var(--ink);
  width:100%;transition:border-color .15s,box-shadow .15s
}
.quote-card input:focus,.quote-card select:focus,.quote-card textarea:focus{border-color:var(--sky);box-shadow:0 0 0 3px rgba(34,161,242,.15);outline:none}
.quote-card textarea{resize:vertical;min-height:90px;font-family:Inter}
.quote-card .check{grid-column:1/-1;display:flex;gap:10px;align-items:flex-start;font:500 12px/1.5 Inter;color:var(--muted)}
.quote-card .check input{width:18px;height:18px;flex-shrink:0;margin-top:2px}
.quote-card button{grid-column:1/-1;background:var(--orange);color:#fff;border:0;padding:15px;border-radius:8px;font:800 14px/1 Inter;letter-spacing:.1em;text-transform:uppercase;cursor:pointer;box-shadow:0 4px 0 var(--orange-dk);margin-top:4px}
.quote-card button:hover{transform:translateY(-1px);box-shadow:0 5px 0 var(--orange-dk)}
.quote-card .fine{grid-column:1/-1;font:500 11px/1.5 Inter;color:#6c7a99;margin:6px 0 0}

/* honeypot — hide from real users, keep visible to bots */
.gotcha{position:absolute;left:-9999px;top:-9999px;width:1px;height:1px;opacity:0}

/* ---------- MARQUEE ---------- */
.marquee{background:var(--yellow);padding:18px 0;overflow:hidden}
.marquee .row{display:flex;gap:14px;justify-content:center;flex-wrap:wrap}
.marquee span{
  display:inline-flex;align-items:center;gap:8px;
  padding:10px 20px;
  background:rgba(29,62,140,.08);
  border:1.5px solid rgba(29,62,140,.4);
  border-radius:999px;
  font:800 12px/1 Inter;letter-spacing:.16em;text-transform:uppercase;
  color:var(--navy)
}
.marquee span::before{content:"★";color:var(--navy)}

/* ---------- SECTION HEADINGS ---------- */
.section{padding:80px 0}
.section.tight{padding:60px 0}
.section h2.heading{font:800 38px/1.05 Oswald;text-transform:uppercase;color:var(--navy);text-align:center;margin:0 0 10px;letter-spacing:.005em}
.section .lede{text-align:center;font:500 16px/1.55 Roboto Condensed;color:var(--muted);margin:0 auto 44px;max-width:640px}

/* ---------- SERVICE GRID ---------- */
.section.services-grid{background:var(--ice)}
.grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.tile{position:relative;border-radius:14px;overflow:hidden;aspect-ratio:5/4;color:#fff;background:#0a1a3d;display:block}
.tile img{width:100%;height:100%;object-fit:cover;transition:.3s;opacity:.55}
.tile:hover img{opacity:.4;transform:scale(1.05)}
.tile .body{position:absolute;inset:0;padding:22px;display:flex;flex-direction:column;justify-content:space-between;background:linear-gradient(180deg,rgba(0,0,0,.1) 0%,rgba(10,26,61,.7) 100%)}
.tile .tag{align-self:flex-start;background:var(--orange);color:#fff;padding:7px 12px;border-radius:6px;font:800 11px/1 Inter;text-transform:uppercase;letter-spacing:.12em}
.tile h3{font:800 22px/1.1 Oswald;text-transform:uppercase;margin:0;letter-spacing:.02em;text-shadow:0 2px 12px rgba(0,0,0,.5)}

/* ---------- DEEP SERVICE BLOCKS ---------- */
.service-block{padding:64px 0;border-bottom:1px solid var(--line)}
.service-block .inner{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center}
.service-block:nth-of-type(even) .inner > .copy{order:2}
.service-block .photo{aspect-ratio:16/9;border-radius:14px;overflow:hidden;background:var(--ice);box-shadow:0 25px 50px rgba(29,62,140,.15)}
.service-block .photo img{width:100%;height:100%;object-fit:cover;display:block}
.service-block .eye{font:700 12px/1 Inter;letter-spacing:.24em;text-transform:uppercase;color:var(--sky);margin-bottom:10px}
.service-block h2{font:800 36px/1.05 Oswald;text-transform:uppercase;color:var(--navy);margin:0 0 14px;letter-spacing:.005em}
.service-block p{font:500 16px/1.65 Inter;color:var(--muted);margin:0 0 18px}
.service-block ul{margin:0 0 22px;padding:0;list-style:none;display:grid;grid-template-columns:1fr 1fr;gap:8px 18px}
.service-block ul li{font:600 14px/1.4 Inter;color:var(--text);padding-left:22px;position:relative}
.service-block ul li::before{content:"";position:absolute;left:0;top:7px;width:12px;height:7px;border:2px solid var(--sky);border-right:0;border-top:0;transform:rotate(-45deg)}
.service-block .row-cta{display:flex;gap:12px;align-items:center;flex-wrap:wrap}
.service-block .row-cta .btn-outline{font-family:Oswald;font-size:16px;letter-spacing:.04em;padding:13px 20px}

/* ---------- BEFORE / AFTER ---------- */
.ba-section{background:var(--ice);text-align:center}
.ba-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:28px;margin-top:36px;text-align:left}
.ba-pair{margin:0;border-radius:14px;overflow:hidden;background:var(--navy-ink);box-shadow:0 20px 40px rgba(29,62,140,.18)}
.ba-pair-imgs{display:grid;grid-template-columns:1fr 1fr;gap:2px;background:#fff}
.ba-pair-img{position:relative;aspect-ratio:4/3;overflow:hidden;background:#0a1a3d}
.ba-pair-img img{width:100%;height:100%;object-fit:cover;display:block}
.ba-pair-img .lab{position:absolute;top:12px;padding:6px 12px;border-radius:4px;font:800 10px/1 Inter;letter-spacing:.16em;text-transform:uppercase;color:#fff;z-index:2}
.ba-pair-img .lab.b{left:12px;background:rgba(14,26,51,.85)}
.ba-pair-img .lab.a{right:12px;background:var(--orange)}
.ba-pair figcaption{padding:14px 18px;color:#fff;font:700 13px/1.4 Roboto Condensed;background:var(--navy-ink);letter-spacing:.04em;text-transform:uppercase}
.ba-pair.hidden-pair{display:none}
.ba-pair.revealed{display:block}
.ba-more{text-align:center;margin-top:36px}
.ba-more .btn{font-family:Oswald;font-size:16px;letter-spacing:.04em;padding:14px 26px}

/* ---------- EXPLAINER (PRESSURE vs SOFT) ---------- */
.section.explain{background:#fff}
.cards{display:grid;grid-template-columns:1fr 1fr;gap:24px;max-width:1080px;margin:0 auto}
.card{background:var(--ice);padding:30px;border-radius:14px;border:1px solid var(--line)}
.card .pill{font:800 11px/1 Inter;letter-spacing:.2em;text-transform:uppercase;padding:6px 11px;border-radius:4px;display:inline-block;margin-bottom:14px;color:#fff}
.card.h .pill{background:var(--orange)}
.card.s .pill{background:var(--sky)}
.card h3{font:700 22px/1.2 Oswald;color:var(--navy);text-transform:uppercase;letter-spacing:.02em;margin:0 0 10px}
.card p{font:400 15px/1.65 Inter;color:var(--muted);margin:0 0 12px}
.card .uses{font:600 13px/1.5 Inter;color:var(--navy);margin:0}
.card .uses b{display:block;letter-spacing:.12em;text-transform:uppercase;font-size:11px;color:var(--sky);margin-bottom:4px}

/* ---------- ABOUT ---------- */
.section.about{background:var(--ice);padding-top:80px;padding-bottom:80px}
.about-inner{display:grid;grid-template-columns:minmax(280px,440px) 1fr;gap:60px;align-items:center}
.about-inner .photo{aspect-ratio:1/1;border-radius:18px;overflow:hidden;box-shadow:0 30px 60px rgba(29,62,140,.22);background:#0a1a3d;position:relative}
.about-inner .photo img{width:100%;height:100%;object-fit:cover;object-position:right center}
.about-inner .photo .pull{position:absolute;left:20px;right:20px;bottom:20px;background:rgba(14,26,51,.86);color:#fff;padding:14px 16px;border-radius:10px;font:600 14px/1.4 Roboto Condensed;border-left:4px solid var(--orange)}
.about-inner .eye{font:700 12px/1 Inter;letter-spacing:.24em;text-transform:uppercase;color:var(--sky);margin-bottom:12px}
.about-inner h2{font:800 38px/1.05 Oswald;text-transform:uppercase;color:var(--navy);margin:0 0 16px}
.about-inner p{font:500 16px/1.65 Inter;color:var(--muted);margin:0 0 14px}
.about-inner .badges{display:flex;gap:10px;flex-wrap:wrap;margin-top:20px}
.about-inner .badges span{padding:9px 14px;background:#fff;border:1px solid var(--line);border-radius:8px;font:600 13px/1 Inter;color:var(--navy);display:inline-flex;gap:8px;align-items:center}
.about-inner .badges span::before{content:"";width:8px;height:8px;background:var(--sky);border-radius:50%}

/* ---------- WHY (PILLARS) ---------- */
.section.why{background:linear-gradient(135deg,var(--navy-dk) 0%,var(--navy) 60%,#0e2a73 100%);color:#fff;position:relative;overflow:hidden}
.section.why::before{content:"";position:absolute;width:480px;height:480px;border-radius:50%;background:rgba(34,161,242,.08);top:-180px;left:-140px;pointer-events:none}
.section.why::after{content:"";position:absolute;width:340px;height:340px;border-radius:50%;background:rgba(255,210,0,.05);bottom:-160px;right:-100px;pointer-events:none}
.section.why .container{position:relative;z-index:1;text-align:center}
.section.why .heading{color:#fff}
.section.why .lede{color:#dfe9ff}
.why-eye{display:inline-flex;align-items:center;gap:8px;background:rgba(255,210,0,.16);color:var(--yellow);border:1px solid rgba(255,210,0,.4);padding:7px 14px;border-radius:999px;font:700 11px/1 Inter;letter-spacing:.18em;text-transform:uppercase;margin-bottom:18px}

.pillars{display:grid;grid-template-columns:repeat(4,1fr);gap:22px;text-align:left;margin-top:14px}
.pill-card{
  background:rgba(255,255,255,.05);
  border:1px solid rgba(255,255,255,.16);
  border-radius:16px;
  padding:30px 26px 28px;
  transition:transform .2s,background .2s,border-color .2s,box-shadow .2s;
  position:relative;
  overflow:hidden;
}
.pill-card::before{content:"";position:absolute;left:0;top:0;right:0;height:4px;background:linear-gradient(90deg,var(--orange),var(--yellow));opacity:.85}
.pill-card:hover{transform:translateY(-4px);background:rgba(255,255,255,.09);border-color:rgba(255,255,255,.32);box-shadow:0 20px 40px rgba(0,0,0,.3)}

.pill-card .ic{
  width:64px;height:64px;
  background:var(--orange);
  border-radius:14px;
  display:grid;place-items:center;
  color:#fff;
  margin-bottom:20px;
  box-shadow:0 10px 24px rgba(242,145,0,.35);
}
.pill-card .ic svg{width:30px;height:30px}

.pill-card .tag-line{
  font:700 11px/1 Inter;
  letter-spacing:.18em;
  text-transform:uppercase;
  color:var(--yellow);
  margin:0 0 12px;
}

.pill-card h4{
  font:800 18px/1.2 Oswald;
  text-transform:uppercase;
  letter-spacing:.02em;
  color:#fff;
  margin:6px 0 10px;
}

.pill-card p{
  font:500 14px/1.55 Inter;
  color:#cfdcf2;
  margin:0;
}

/* ---------- GALLERY ---------- */
.section.gallery{background:var(--ice)}
.filters{display:flex;justify-content:center;gap:10px;flex-wrap:wrap;margin-bottom:28px}
.filters button{background:#fff;color:var(--navy);border:1px solid var(--line-dk);padding:9px 16px;border-radius:999px;font:700 12px/1 Inter;text-transform:uppercase;letter-spacing:.1em;cursor:pointer;transition:.15s}
.filters button:hover{border-color:var(--navy)}
.filters button.on{background:var(--navy);color:#fff;border-color:var(--navy)}
.masonry{display:grid;grid-template-columns:repeat(4,1fr);grid-auto-rows:180px;gap:14px}
.masonry .item{overflow:hidden;border-radius:10px;background:#0a1a3d;position:relative;cursor:zoom-in;border:0;padding:0}
.masonry .item img{width:100%;height:100%;object-fit:cover;transition:transform .35s}
.masonry .item:hover img{transform:scale(1.06)}
.masonry .item.tall{grid-row:span 2}
.masonry .item.wide{grid-column:span 2}
.masonry .item.hidden{display:none}

/* lightbox */
.lightbox{position:fixed;inset:0;background:rgba(7,12,28,.92);z-index:2000;display:none;align-items:center;justify-content:center;padding:30px}
.lightbox.on{display:flex}
.lightbox img{max-width:92vw;max-height:88vh;border-radius:8px;box-shadow:0 30px 60px rgba(0,0,0,.6)}
.lightbox .close{position:absolute;top:18px;right:22px;background:#fff;color:var(--navy);border:0;width:42px;height:42px;border-radius:50%;font:800 20px/1 Inter;cursor:pointer}

/* ---------- SERVICE AREA ---------- */
.section.area{background:#fff}
.area-inner{display:grid;grid-template-columns:1fr 1.2fr;gap:40px;align-items:center}
.area-inner .copy h2{font:800 36px/1.05 Oswald;text-transform:uppercase;color:var(--navy);margin:0 0 14px}
.area-inner .copy p{font:500 16px/1.6 Inter;color:var(--muted)}
.area-inner .cities{display:flex;flex-wrap:wrap;gap:8px;margin-top:18px}
.area-inner .cities span{background:var(--ice);color:var(--navy);padding:8px 13px;border-radius:6px;font:700 12px/1 Inter;letter-spacing:.04em}
.area-inner .map{border-radius:14px;overflow:hidden;box-shadow:0 25px 50px rgba(29,62,140,.18);border:1px solid var(--line)}
.area-inner .map iframe{width:100%;height:420px;border:0;display:block}

/* ---------- FAQ ---------- */
.section.faq{background:var(--ice)}
.faq-wrap{max-width:1280px;margin:0 auto;display:grid;grid-template-columns:1fr 1fr;gap:14px 24px;align-items:start}
.faq-item{background:#fff;border:1px solid var(--line);border-radius:10px;overflow:hidden;transition:border-color .15s}
.faq-item .q{width:100%;background:transparent;border:0;text-align:left;padding:18px 22px;display:flex;justify-content:space-between;align-items:center;gap:14px;font:700 15px/1.4 Inter;color:var(--navy)}
.faq-item .q .plus{width:30px;height:30px;background:var(--navy);color:#fff;border-radius:50%;display:grid;place-items:center;font:800 18px/1 Inter;flex-shrink:0;transition:transform .2s}
.faq-item .a{max-height:0;overflow:hidden;transition:max-height .25s ease;padding:0 22px}
.faq-item .a p{font:400 15px/1.65 Inter;color:var(--muted);margin:0 0 18px}
.faq-item.open{border-color:var(--orange);border-left:5px solid var(--orange)}
.faq-item.open .plus{transform:rotate(45deg);background:var(--orange)}
.faq-item.open .a{max-height:500px}

/* ---------- CONCLUSION / CONTACT (bottom) ---------- */
.section.quote-big{background:linear-gradient(135deg,var(--navy),var(--navy-dk));color:#fff;position:relative;overflow:hidden}
.section.quote-big::before{content:"";position:absolute;width:520px;height:520px;border-radius:50%;background:rgba(255,255,255,.04);top:-200px;right:-160px;pointer-events:none}
.section.quote-big::after{content:"";position:absolute;width:340px;height:340px;border-radius:50%;background:rgba(255,255,255,.04);bottom:-160px;left:-120px;pointer-events:none}
.quote-big-inner{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center;position:relative;z-index:1}

.quote-copy .eye{display:inline-flex;align-items:center;gap:8px;background:rgba(255,210,0,.16);color:var(--yellow);border:1px solid rgba(255,210,0,.4);padding:7px 13px;border-radius:999px;font:700 11px/1 Inter;letter-spacing:.18em;text-transform:uppercase;margin-bottom:18px}
.quote-copy h2{color:#fff;font:800 44px/1.05 Oswald;text-transform:uppercase;margin:0 0 16px;letter-spacing:.005em}
.quote-copy p{color:#dfe9ff;font:500 17px/1.55 Roboto Condensed;margin:0 0 28px;max-width:540px}

.quote-direct{display:flex;flex-direction:column;gap:14px}
.qd-row{display:flex;align-items:center;gap:14px;padding:14px 18px;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.16);border-radius:10px;color:#fff;text-decoration:none;transition:background .15s,border-color .15s}
a.qd-row:hover{background:rgba(255,255,255,.12);border-color:rgba(255,255,255,.32)}
.qd-ic{width:42px;height:42px;border-radius:8px;background:var(--orange);display:grid;place-items:center;flex-shrink:0;color:#fff}
.qd-text{display:flex;flex-direction:column;gap:3px}
.qd-text .lbl{font:600 11px/1 Inter;letter-spacing:.16em;text-transform:uppercase;color:#9ab0d8}
.qd-text .val{font:700 17px/1 Oswald;letter-spacing:.02em;color:#fff}
a.qd-row .val{font-size:22px;color:var(--yellow);letter-spacing:.04em}

.form-wrap{background:#fff;color:var(--ink);padding:32px;border-radius:16px;box-shadow:0 30px 60px rgba(0,0,0,.3);border-top:6px solid var(--orange)}
.form-wrap .qf-h{font:800 26px/1.1 Oswald;color:var(--navy);text-transform:uppercase;letter-spacing:.005em;margin:0 0 4px}
.form-wrap .qf-sub{font:500 14px/1.4 Roboto Condensed;color:var(--muted);margin:0 0 20px}
.form-wrap form{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.form-wrap input,.form-wrap select,.form-wrap textarea{background:#fff;color:var(--ink);border:1px solid var(--line);padding:13px 15px;border-radius:8px;font:500 14px/1.3 Inter;width:100%;transition:border-color .15s,box-shadow .15s}
.form-wrap input:focus,.form-wrap select:focus,.form-wrap textarea:focus{outline:none;border-color:var(--sky);box-shadow:0 0 0 3px rgba(34,161,242,.15)}
.form-wrap .full{grid-column:1/-1}
.form-wrap textarea{resize:vertical;min-height:80px;font-family:Inter}
.form-wrap .check{grid-column:1/-1;display:flex;gap:10px;align-items:flex-start;font:500 12px/1.5 Inter;color:var(--muted)}
.form-wrap .check input{width:18px;height:18px;flex-shrink:0;margin-top:2px}
.form-wrap button{grid-column:1/-1;background:var(--orange);color:#fff;border:0;padding:16px;border-radius:8px;font:800 14px/1 Inter;letter-spacing:.1em;text-transform:uppercase;cursor:pointer;box-shadow:0 5px 0 var(--orange-dk);margin-top:4px}
.form-wrap button:hover{transform:translateY(-1px);box-shadow:0 6px 0 var(--orange-dk)}

/* ---------- FOOTER ---------- */
footer.footer{background:var(--navy-ink);color:#9ab0d8;padding:50px 0 24px;font:400 14px/1.6 Inter}
.footer a{color:#cfdcf2}
.footer a:hover{color:#fff}

/* Top: brand block — logo left, info right */
.footer-top{
  display:grid;
  grid-template-columns:auto 1fr;
  gap:40px;
  align-items:center;
  padding-bottom:36px;
  margin-bottom:36px;
  border-bottom:1px solid rgba(255,255,255,.08);
}
.footer-logo{display:block;flex-shrink:0;line-height:0}
.footer-logo .logo-img-footer{height:130px}
.footer-brand-info{min-width:0}
.footer-brand-info .bi-line{margin:0 0 6px;color:#b9c8e6;font:500 15px/1.5 Inter}
.footer-brand-info .bi-row{display:flex;align-items:center;gap:20px;flex-wrap:wrap;margin-top:18px}

.footer .socials{display:flex;gap:10px;flex-wrap:wrap}
.footer .socials a{display:inline-flex;align-items:center;gap:10px;padding:9px 14px;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.16);border-radius:8px;color:#fff;font:700 12px/1 Inter;letter-spacing:.08em;text-transform:uppercase;white-space:nowrap;transition:background .15s,border-color .15s}
.footer .socials a:hover{background:#1877F2;border-color:#1877F2;color:#fff}
.footer .socials a svg{flex-shrink:0}
.footer .mark{display:inline-flex;align-items:center;gap:10px;color:#7a8cb0;font:500 12px/1.4 Roboto Condensed}
.footer .mark svg{flex-shrink:0;opacity:.6}

/* Mid: 3 info columns */
.footer-cols{display:grid;grid-template-columns:1fr 1fr 1fr;gap:40px;margin-bottom:36px;align-items:start}
.footer strong{color:#fff;display:block;font:800 14px/1 Oswald;text-transform:uppercase;letter-spacing:.08em;margin-bottom:14px}
.footer ul{list-style:none;margin:0;padding:0}
.footer ul li{margin:0 0 6px;overflow-wrap:anywhere}

/* Bottom: legal */
.footer .legal{border-top:1px solid rgba(255,255,255,.08);padding-top:20px;font:500 12px/1.6 Inter;color:#7a8cb0;display:flex;justify-content:space-between;gap:20px;flex-wrap:wrap}
.footer .legal .runoff{max-width:760px}
.footer .legal a{color:#9ab0d8;text-decoration:underline;text-underline-offset:3px}

/* ---------- COOKIE BANNER ---------- */
.cookie{position:fixed;left:16px;right:16px;bottom:16px;max-width:560px;margin:0 auto;background:#fff;color:var(--ink);padding:16px 20px;border-radius:12px;box-shadow:0 24px 60px rgba(0,0,0,.3);display:flex;gap:14px;align-items:center;z-index:1500;border:1px solid var(--line);font:500 13px/1.5 Inter}
.cookie p{margin:0}
.cookie a{color:var(--navy);font-weight:700;border-bottom:1px solid var(--orange)}
.cookie button{background:var(--navy);color:#fff;border:0;padding:10px 16px;border-radius:6px;font:700 12px/1 Inter;text-transform:uppercase;letter-spacing:.06em;cursor:pointer;flex-shrink:0}
.cookie button:hover{background:var(--navy-dk)}
.cookie.hidden{display:none}

/* ---------- STICKY MOBILE CALL BAR ---------- */
.mob-bar{display:none;position:fixed;bottom:0;left:0;right:0;background:var(--navy);z-index:1400;padding:10px 12px;gap:8px;box-shadow:0 -8px 24px rgba(0,0,0,.25)}
.mob-bar a{flex:1;display:inline-flex;align-items:center;justify-content:center;padding:13px;border-radius:8px;font:800 13px/1 Inter;letter-spacing:.06em;text-transform:uppercase;gap:8px}
.mob-bar .call{background:#fff;color:var(--navy)}
.mob-bar .quote{background:var(--orange);color:#fff}

/* =========================================================
   RESPONSIVE
========================================================= */
@media (max-width:980px){
  .nav nav{display:none}
  .nav-toggle{display:inline-block}
  .nav.open nav{display:flex;position:absolute;top:100%;left:0;right:0;background:#fff;flex-direction:column;border-bottom:3px solid var(--orange);padding:14px 24px;gap:14px}
  .hero .row{grid-template-columns:1fr;gap:36px;padding-top:44px;padding-bottom:50px}
  .hero ul{grid-template-columns:1fr}
  .grid{grid-template-columns:repeat(2,1fr)}
  .service-block .inner{grid-template-columns:1fr;gap:30px}
  .service-block:nth-of-type(even) .inner > .copy{order:0}
  .service-block ul{grid-template-columns:1fr}
  .cards{grid-template-columns:1fr}
  .about-inner{grid-template-columns:1fr;gap:32px}
  .pillars{grid-template-columns:repeat(2,1fr)}
  .masonry{grid-template-columns:repeat(2,1fr);grid-auto-rows:140px}
  .masonry .item.wide{grid-column:span 1}
  .area-inner{grid-template-columns:1fr;gap:30px}
  .ba-grid{grid-template-columns:1fr}
  .faq-wrap{grid-template-columns:1fr}
  .area-inner .map iframe{height:340px}
  .footer-top{grid-template-columns:1fr;gap:20px;text-align:center;padding-bottom:28px;margin-bottom:28px}
  .footer-logo{margin:0 auto}
  .footer-brand-info .bi-row{justify-content:center;flex-direction:column;gap:14px}
  .footer-cols{grid-template-columns:1fr 1fr;gap:28px}
  .footer .legal{flex-direction:column}
  .mob-bar{display:flex}
  body{padding-bottom:72px}
  .section{padding:60px 0}
  .quote-big-inner{grid-template-columns:1fr;gap:40px}
  .form-wrap form,.quote-card form{grid-template-columns:1fr}
  .quote-card .full,.form-wrap .full{grid-column:auto}
  .quote-copy h2{font-size:34px}
}

@media (max-width:720px){
  .logo-img{height:80px}
  .logo-img-footer{height:130px}
}

@media (max-width:600px){
  .section h2.heading{font-size:30px}
  .grid{grid-template-columns:1fr}
  .pillars{grid-template-columns:1fr}
  .topbar .row{justify-content:center;text-align:center;font-size:12px}
}

/* reduced motion */
@media (prefers-reduced-motion:reduce){
  html{scroll-behavior:auto}
  *{transition:none!important;animation:none!important}
}
