/* Flawless Carpet Cleaning & Pest Control — Gold Coast
   Art direction: light direct-response, real brand blue (#165ca4) + red (#e01b18) punch,
   Archivo display / General Sans body. White base (G1). */
@font-face{font-family:'Archivo';src:url('/clients/flawless-carpet-cleaning/fonts/archivo.woff2') format('woff2');font-weight:100 900;font-style:normal;font-display:swap}
@font-face{font-family:'General Sans';src:url('/clients/flawless-carpet-cleaning/fonts/general-sans-400.woff2') format('woff2');font-weight:400;font-style:normal;font-display:swap}
@font-face{font-family:'General Sans';src:url('/clients/flawless-carpet-cleaning/fonts/general-sans-500.woff2') format('woff2');font-weight:500;font-style:normal;font-display:swap}
@font-face{font-family:'General Sans';src:url('/clients/flawless-carpet-cleaning/fonts/general-sans-600.woff2') format('woff2');font-weight:600;font-style:normal;font-display:swap}
@font-face{font-family:'Archivo Fallback';src:local('Arial'),local('Helvetica Neue'),local('Liberation Sans');size-adjust:115%;ascent-override:95.7%;descent-override:35.7%;line-gap-override:0%}
:root{
  --ink:#0e1c2e;--ink-2:#16263b;--ink-soft:#42505f;--muted:#69788a;--faint:#9aa7b5;
  --blue:#165ca4;--blue-d:#114a85;--blue-2:#3f8bd9;--blue-tint:#e9f1fb;--blue-band:#f1f7fd;--blue-line:rgba(22,92,164,.4);
  --red:#e01b18;--red-d:#bd1310;--red-tint:#fdecec;
  --paper:#f5f8fc;--paper-2:#eef3f9;--line:#e2e8f0;--hair:#eaeff5;--white:#fff;
  --glass:rgba(255,255,255,.72);--glass-brd:rgba(255,255,255,.6);
  --shadow:0 28px 70px rgba(14,28,46,.18);--shadow-soft:0 16px 40px rgba(14,28,46,.08);
  --shadow-card:0 20px 48px rgba(14,28,46,.10);--glow:0 18px 50px rgba(22,92,164,.32);
  --r:18px;--r-lg:24px;--r-pill:999px;
  --f-display:'Archivo','Archivo Fallback',-apple-system,BlinkMacSystemFont,'Segoe UI',Arial,sans-serif;
  --f-sans:'General Sans',-apple-system,BlinkMacSystemFont,'Segoe UI',Roboto,'Helvetica Neue',Arial,sans-serif;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{margin:0;background:#fff;color:var(--ink-soft);font-family:var(--f-sans);line-height:1.62;font-size:17px;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}
body.menu-open{overflow:hidden}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
p{margin:0 0 16px}
h1,h2,h3,h4{font-family:var(--f-display);font-weight:700;color:var(--ink);margin:0;letter-spacing:-.02em;line-height:1.02}
.hl{color:var(--red)}
.hl-b{color:var(--blue)}
.wrap{width:min(1200px,calc(100% - 44px));margin:0 auto}
.eyebrow,.kicker{display:inline-flex;align-items:center;gap:9px;margin:0 0 18px;font-family:var(--f-sans);font-size:12px;font-weight:600;letter-spacing:.16em;text-transform:uppercase;color:var(--blue-d)}
.eyebrow::before,.kicker::before{content:"";width:8px;height:8px;border-radius:50%;background:var(--red);box-shadow:0 0 0 4px var(--red-tint)}
.section{padding:104px 0;background:#fff;position:relative}
.section.soft{background:var(--paper)}
.section.mist{background:var(--blue-band)}
.section.tan-band{background:var(--paper-2)}
.section-head{max-width:800px;margin-bottom:8px}
.section-title{font-size:clamp(34px,4.8vw,60px);line-height:1.0;margin:0 0 18px;font-weight:800;text-transform:uppercase;letter-spacing:-.025em}
.lead{font-size:19px;color:var(--muted);max-width:680px;margin:0}

/* scroll reveal */
.reveal{opacity:0;transform:translateY(26px);transition:opacity .7s cubic-bezier(.16,1,.3,1),transform .7s cubic-bezier(.16,1,.3,1)}
.reveal.in{opacity:1;transform:none}
@media(prefers-reduced-motion:reduce){.reveal{opacity:1!important;transform:none!important;transition:none}}

/* ---------- header / glass nav ---------- */
.site-header{position:fixed;inset:18px 0 auto;z-index:80;pointer-events:none}
.nav-shell{display:flex;justify-content:center;padding:0 16px}
.nav-pill{pointer-events:auto;display:inline-flex;align-items:center;gap:6px;width:fit-content;max-width:calc(100vw - 32px);
  padding:7px 7px 7px 14px;background:var(--glass);backdrop-filter:blur(20px) saturate(170%);-webkit-backdrop-filter:blur(20px) saturate(170%);
  border:1px solid var(--glass-brd);box-shadow:0 14px 40px rgba(14,28,46,.16);border-radius:var(--r-pill)}
.nav-logo{display:flex;align-items:center;gap:11px;white-space:nowrap;padding-right:6px}
.nav-logo img{height:40px;width:auto;display:block}
.nav-logo .nm{font-family:var(--f-display);font-weight:700;font-size:18px;color:var(--ink);letter-spacing:-.02em}
.nav-links{display:flex;gap:2px;align-items:center}
.nav-links a{padding:9px 14px;border-radius:var(--r-pill);font-size:14.5px;font-weight:500;color:var(--ink);opacity:.92;transition:background .2s,color .2s,opacity .2s}
.nav-links a:hover{background:var(--blue-tint);color:var(--blue-d);opacity:1}
.nav-cta{display:inline-flex;align-items:center;gap:8px;min-height:42px;padding:0 18px;border-radius:var(--r-pill);background:var(--blue);color:#fff;font-weight:600;font-size:14px;white-space:nowrap;box-shadow:0 8px 22px rgba(22,92,164,.34);transition:background .2s,transform .2s,box-shadow .2s}
.nav-cta:hover{background:var(--blue-d);transform:translateY(-1px);box-shadow:var(--glow)}
.nav-cta svg{width:15px;height:15px}
.nav-toggle{display:none;align-items:center;justify-content:center;width:42px;height:42px;border-radius:var(--r-pill);background:var(--blue);border:0;cursor:pointer;color:#fff;margin-left:2px;flex-shrink:0}
.nav-toggle svg{width:20px;height:20px}
.nav-toggle .line{stroke:currentColor;stroke-width:2;stroke-linecap:round}

/* full-screen mobile menu (witness pattern) */
.mobile-menu,.mobile-panel{position:fixed;inset:0;z-index:95;background:#fff;display:flex;flex-direction:column;opacity:0;pointer-events:none;visibility:hidden;transition:opacity .32s cubic-bezier(.16,1,.3,1),visibility .32s}
.mobile-menu.open{opacity:1;pointer-events:auto;visibility:visible}
.mobile-menu-head{display:flex;align-items:center;justify-content:space-between;padding:18px 22px;border-bottom:1px solid var(--hair);flex-shrink:0}
.mobile-menu-logo img{height:42px;width:auto}
.mobile-menu-close{display:flex;align-items:center;justify-content:center;width:42px;height:42px;border-radius:var(--r-pill);background:var(--blue-tint);border:0;cursor:pointer;color:var(--blue-d)}
.mobile-menu-close svg{width:16px;height:16px}
.mobile-menu-body{flex:1;display:flex;flex-direction:column;padding:26px 24px 26px;overflow-y:auto}
.mobile-menu-links{display:flex;flex-direction:column;list-style:none;margin:0 0 28px;padding:0;flex:1}
.mobile-menu-links li{border-bottom:1px solid var(--hair)}
.mobile-menu-links li:first-child{border-top:1px solid var(--hair)}
.mobile-menu-links a{display:flex;align-items:center;justify-content:space-between;padding:21px 4px;font-family:var(--f-display);font-size:30px;font-weight:700;letter-spacing:-.02em;color:var(--ink);line-height:1;transition:padding .25s,color .2s;text-transform:uppercase}
.mobile-menu-links a .idx{font-family:var(--f-sans);font-size:12px;color:var(--faint);font-weight:500;letter-spacing:.04em}
.mobile-menu-links a:hover,.mobile-menu-links a:focus-visible{padding-left:10px;color:var(--blue-d);outline:none}
.mobile-menu-foot{margin-top:auto;padding-top:22px;border-top:1px solid var(--hair);display:flex;flex-direction:column;gap:10px}
.mobile-menu-cta{display:flex;align-items:center;justify-content:space-between;padding:16px 18px;border-radius:14px;background:var(--paper-2);transition:background .2s;font-size:15px;font-weight:600;color:var(--ink)}
.mobile-menu-cta.primary{background:var(--blue);color:#fff}
.mobile-menu-cta.primary:hover{background:var(--blue-d)}
.mobile-menu-cta.red{background:var(--red);color:#fff}
.mobile-menu-cta.red:hover{background:var(--red-d)}
.mobile-menu-cta:not(.primary):not(.red):hover{background:var(--blue-tint)}
.mobile-menu-cta .l{display:flex;flex-direction:column;gap:3px;text-align:left}
.mobile-menu-cta .s{font-size:12px;font-weight:400;color:var(--muted)}
.mobile-menu-cta.primary .s,.mobile-menu-cta.red .s{color:rgba(255,255,255,.82)}
.mobile-menu-cta svg{width:14px;height:14px;opacity:.7;flex-shrink:0}

/* ---------- buttons ---------- */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:9px;min-height:52px;padding:0 26px;border-radius:var(--r-pill);font-family:var(--f-sans);font-weight:600;font-size:15.5px;border:1.5px solid transparent;cursor:pointer;transition:transform .2s,background .2s,box-shadow .2s,color .2s,border-color .2s}
.btn svg{width:17px;height:17px}
.btn-primary{background:var(--blue);color:#fff;box-shadow:0 12px 28px rgba(22,92,164,.32)}
.btn-primary:hover{background:var(--blue-d);transform:translateY(-2px);box-shadow:var(--glow)}
.btn-red{background:var(--red);color:#fff;box-shadow:0 12px 28px rgba(224,27,24,.30)}
.btn-red:hover{background:var(--red-d);transform:translateY(-2px);box-shadow:0 18px 50px rgba(224,27,24,.34)}
.btn-light{background:#fff;color:var(--ink);border-color:var(--line);box-shadow:var(--shadow-soft)}
.btn-light:hover{border-color:var(--blue);color:var(--blue-d);transform:translateY(-2px)}
.btn-outline{background:transparent;color:var(--ink);border-color:var(--blue-line)}
.btn-outline:hover{background:var(--blue);color:#fff;border-color:var(--blue)}
.btn-dark{background:var(--ink);color:#fff;width:100%;box-shadow:0 12px 26px rgba(14,28,46,.30)}
.btn-dark:hover{background:#000;transform:translateY(-2px)}
.text-link{display:inline-flex;align-items:center;gap:7px;font-weight:600;color:var(--blue-d);padding-bottom:2px;border-bottom:2px solid var(--blue-line);transition:gap .2s,border-color .2s}
.text-link:hover{gap:11px;border-color:var(--blue)}
.text-link.red{color:var(--red-d);border-color:rgba(224,27,24,.4)}
.text-link.red:hover{border-color:var(--red)}
.hero-actions,.actions{display:flex;gap:13px;flex-wrap:wrap;margin-top:30px;align-items:center}

/* ---------- hero (LIGHT direct-response) ---------- */
.hero{position:relative;padding:152px 0 84px;overflow:hidden;background:linear-gradient(180deg,#fff 0%,var(--blue-band) 100%);color:var(--ink);isolation:isolate}
.hero::before{content:"";position:absolute;top:-180px;right:-160px;width:620px;height:620px;border-radius:50%;background:radial-gradient(closest-side,rgba(22,92,164,.14),transparent 70%);z-index:-1}
.hero-grid{position:relative;display:grid;grid-template-columns:minmax(0,1.06fr) minmax(360px,.82fr);gap:56px;align-items:center}
.hero-copy{max-width:680px}
.hero h1{font-size:clamp(46px,6.6vw,88px);line-height:.92;margin:0 0 22px;color:var(--ink);font-weight:800;letter-spacing:-.03em;text-transform:uppercase}
.hero-sub{font-size:20px;line-height:1.55;color:var(--ink-soft);max-width:560px;margin:0}
.hero-call{display:inline-flex;flex-direction:column;gap:1px;margin-top:30px}
.hero-call .lab{font-size:12px;font-weight:600;letter-spacing:.14em;text-transform:uppercase;color:var(--muted)}
.hero-call a{font-family:var(--f-display);font-weight:800;font-size:clamp(30px,4vw,40px);color:var(--red);letter-spacing:-.02em;line-height:1.05}
.hero-trust{display:flex;align-items:center;gap:12px;margin-top:24px;flex-wrap:wrap}
.hero-trust .stars{color:#f6a609;font-size:18px;letter-spacing:1px}
.hero-trust b{color:var(--ink);font-weight:700}
.hero-trust .gm{display:inline-flex;align-items:center;justify-content:center;width:26px;height:26px;border-radius:50%;background:#fff;border:1px solid var(--line);font-weight:800;color:#4285f4;font-size:14px;flex-shrink:0}
/* hero photo card with tilt + offset accent + floating rating */
.hero-figure{position:relative;justify-self:center;width:100%;max-width:440px}
.hero-figure::before{content:"";position:absolute;inset:26px -22px -26px 24px;border-radius:var(--r-lg);background:linear-gradient(150deg,var(--blue),var(--blue-d));z-index:-1;transform:rotate(3deg)}
.hero-figure::after{content:"";position:absolute;width:96px;height:96px;border-radius:20px;background:var(--red);bottom:-26px;left:-26px;z-index:-1;opacity:.9}
.hero-photo{position:relative;border-radius:var(--r-lg);overflow:hidden;box-shadow:var(--shadow);transform:rotate(-2deg);background:#dce6f0}
.hero-photo img{width:100%;height:100%;object-fit:cover;aspect-ratio:3/4}
.hero-badge{position:absolute;left:-18px;bottom:30px;display:flex;align-items:center;gap:12px;background:#fff;border-radius:16px;padding:13px 18px;box-shadow:var(--shadow-card);border:1px solid var(--hair)}
.hero-badge .gm{width:40px;height:40px;border-radius:50%;background:#fff;border:1px solid var(--line);display:inline-flex;align-items:center;justify-content:center;font-weight:800;color:#4285f4;font-size:20px}
.hero-badge strong{font-family:var(--f-display);font-size:22px;color:var(--ink);line-height:1;font-weight:800}
.hero-badge .stars{color:#f6a609;font-size:13px;letter-spacing:1px;display:block;margin-top:3px}
.hero-badge small{color:var(--muted);font-size:12px}

/* ---------- feature pill strip (under hero) ---------- */
.feature-strip{background:#fff;padding:24px 0;border-bottom:1px solid var(--hair);position:relative;z-index:2;overflow:hidden}
.feature-pills{list-style:none;margin:0;padding:0;display:flex;justify-content:space-between;align-items:center;gap:18px;flex-wrap:wrap}
.feature-pills li{display:inline-flex;align-items:center;gap:10px;color:var(--ink-soft);font-size:.96rem;white-space:nowrap;font-weight:500}
.feature-pills strong{color:var(--ink);font-weight:700}
.feature-pills .fp-icon{display:inline-flex;align-items:center;justify-content:center;width:30px;height:30px;border-radius:9px;background:var(--blue-tint);color:var(--blue-d);flex-shrink:0}
.feature-pills .fp-icon svg{width:17px;height:17px}
.feature-marquee{display:none}
@media (max-width:880px){
  .feature-pills{display:none}
  .feature-marquee{display:block;position:relative;overflow:hidden;
    -webkit-mask-image:linear-gradient(90deg,transparent 0,#000 6%,#000 94%,transparent 100%);mask-image:linear-gradient(90deg,transparent 0,#000 6%,#000 94%,transparent 100%);
    width:100vw;margin-left:calc(50% - 50vw)}
  .feature-marquee-track{display:flex;gap:26px;align-items:center;width:max-content;will-change:transform;animation:fp-marquee 30s linear infinite}
  .feature-marquee-track li{display:inline-flex;align-items:center;gap:9px;color:var(--ink-soft);font-size:.92rem;white-space:nowrap;flex-shrink:0;font-weight:500}
  .feature-marquee-track strong{color:var(--ink);font-weight:700}
  .feature-marquee-track .fp-icon{display:inline-flex;align-items:center;justify-content:center;width:28px;height:28px;border-radius:8px;background:var(--blue-tint);color:var(--blue-d)}
  .feature-marquee-track .fp-icon svg{width:16px;height:16px}
  .feature-marquee:hover .feature-marquee-track{animation-play-state:paused}
  @keyframes fp-marquee{from{transform:translate3d(0,0,0)}to{transform:translate3d(-50%,0,0)}}
  @media (prefers-reduced-motion:reduce){.feature-marquee-track{animation:none;transform:none}}
}

/* ---------- quote form card ---------- */
.contact-card{background:#fff;color:var(--ink-soft);padding:30px;border-radius:var(--r-lg);box-shadow:var(--shadow);border:1px solid var(--hair)}
.contact-card h2{font-size:27px;margin:0 0 6px;color:var(--ink);font-weight:700}
.contact-card .cc-sub{font-size:14px;color:var(--muted);margin:0 0 18px}
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.full{grid-column:1/-1}
label{display:block;font-size:12.5px;font-weight:600;margin-bottom:6px;color:var(--ink);letter-spacing:.01em}
input,select,textarea{width:100%;border:1.5px solid var(--line);border-radius:12px;padding:13px 14px;font:inherit;font-size:15px;background:#fbfcfe;color:var(--ink);transition:border-color .2s,box-shadow .2s,background .2s}
input:focus,select:focus,textarea:focus{outline:none;border-color:var(--blue);background:#fff;box-shadow:0 0 0 4px var(--blue-tint)}
textarea{min-height:108px;resize:vertical}
.hp-field{position:absolute;left:-9999px;width:1px;height:1px;overflow:hidden}

/* ---------- proof strip ---------- */
.proof-wrap{margin-top:54px;position:relative;z-index:3}
.proof-strip{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:0;margin:0 auto;max-width:1200px;background:#fff;border-radius:var(--r-lg);box-shadow:var(--shadow-card);overflow:hidden;border:1px solid var(--hair)}
.proof-strip>div{padding:28px 26px;display:flex;flex-direction:column;gap:4px}
.proof-strip>div:not(:last-child){border-right:1px solid var(--hair)}
.proof-strip strong{font-family:var(--f-display);font-size:42px;line-height:1;color:var(--blue);font-weight:800;letter-spacing:-.02em}
.proof-strip .lab{font-size:14px;color:var(--muted);font-weight:500}
.proof-strip .gstars{color:#f6a609;font-size:15px;letter-spacing:1px}

/* ---------- splits ---------- */
.split{display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:center}
.proof-list{display:grid;gap:14px;margin-top:28px}
.proof-list div{display:grid;grid-template-columns:30px 1fr;gap:14px;align-items:start}
.proof-list div::before{content:"";grid-row:1;width:27px;height:27px;border-radius:9px;background:var(--blue-tint);background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23165ca4' stroke-width='3.2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='20 6 9 17 4 12'/%3E%3C/svg%3E");background-size:15px;background-repeat:no-repeat;background-position:center;margin-top:2px}
.proof-list p{margin:0;color:var(--ink);font-weight:500;align-self:center}
.image-stack{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.image-stack img,.photo-panel img{border-radius:var(--r);box-shadow:var(--shadow-card);width:100%;height:100%;object-fit:cover}
.image-stack img:first-child{grid-column:1/-1;aspect-ratio:16/9}
.image-stack img:not(:first-child){aspect-ratio:1/1}
.photo-panel{min-height:440px}
.photo-panel img{aspect-ratio:4/5}

/* ---------- service cards (numbered, blue-glow hover) ---------- */
.grid{display:grid;gap:22px}
.cards-3{grid-template-columns:repeat(3,minmax(0,1fr));margin-top:42px}
.card{background:#fff;border:1px solid var(--hair);border-radius:var(--r-lg);box-shadow:var(--shadow-card);overflow:hidden}
.service-card{display:flex;flex-direction:column;transition:transform .28s,box-shadow .28s,border-color .28s;position:relative}
.service-card::after{content:"";position:absolute;inset:0;border-radius:var(--r-lg);box-shadow:inset 0 0 0 2px transparent;transition:box-shadow .28s;pointer-events:none}
.service-card:hover{transform:translateY(-7px);box-shadow:0 30px 60px rgba(22,92,164,.18)}
.service-card:hover::after{box-shadow:inset 0 0 0 2px var(--blue)}
.service-card .thumb-wrap{position:relative;overflow:hidden}
.service-card .thumb{width:100%;aspect-ratio:4/3;object-fit:cover;transition:transform .5s cubic-bezier(.16,1,.3,1)}
.service-card:hover .thumb{transform:scale(1.05)}
.service-card .num{position:absolute;top:14px;left:14px;display:inline-flex;align-items:center;justify-content:center;min-width:38px;height:38px;padding:0 10px;border-radius:var(--r-pill);background:rgba(14,28,46,.78);backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);color:#fff;font-family:var(--f-display);font-weight:700;font-size:15px}
.service-card .body{padding:24px;display:flex;flex-direction:column;flex:1}
.service-card h3{font-size:22px;line-height:1.08;margin:0 0 10px;font-weight:700}
.service-card p{color:var(--muted);font-size:15.5px;margin:0 0 18px}
.service-card .text-link{margin-top:auto;align-self:flex-start}

/* ---------- process steps ---------- */
.steps{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:20px;margin-top:46px;position:relative}
.steps::before{content:"";position:absolute;top:59px;left:14%;right:14%;height:2px;background:linear-gradient(90deg,var(--blue),var(--blue-tint));transform:scaleX(0);transform-origin:left;transition:transform 1.1s cubic-bezier(.16,1,.3,1) .25s;z-index:0}
.steps.in::before{transform:scaleX(1)}
.step{background:#fff;border:1px solid var(--hair);border-radius:var(--r-lg);padding:36px 30px;box-shadow:var(--shadow-soft);position:relative;z-index:1;transition:opacity .6s cubic-bezier(.16,1,.3,1),transform .6s cubic-bezier(.16,1,.3,1),box-shadow .25s}
.js .step{opacity:0;transform:translateY(30px) scale(.98)}
.steps.in .step{opacity:1;transform:none}
.steps.in .step:nth-child(1){transition-delay:.1s}
.steps.in .step:nth-child(2){transition-delay:.26s}
.steps.in .step:nth-child(3){transition-delay:.42s}
.step:hover{box-shadow:0 26px 54px rgba(22,92,164,.16);border-color:var(--blue-line)}
.step span{display:inline-flex;align-items:center;justify-content:center;width:52px;height:52px;border-radius:16px;background:var(--blue);color:#fff;font-family:var(--f-display);font-weight:700;font-size:22px;margin-bottom:20px;box-shadow:0 10px 24px rgba(22,92,164,.34)}
.step h3{font-size:21px;margin:0 0 10px;font-weight:700}
.step p{color:var(--muted);margin:0;font-size:15.5px}

/* ---------- gallery (before/after proof feel) ---------- */
.gallery-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-top:42px}
.gallery-grid figure{margin:0;position:relative;border-radius:var(--r);overflow:hidden;box-shadow:var(--shadow-card);background:#dce6f0}
.gallery-grid img{width:100%;height:100%;object-fit:cover;aspect-ratio:4/3;transition:transform .55s cubic-bezier(.16,1,.3,1)}
.gallery-grid figure:hover img{transform:scale(1.06)}
.gallery-grid figcaption{position:absolute;left:12px;bottom:12px;background:rgba(14,28,46,.78);backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);color:#fff;font-size:12.5px;font-weight:500;padding:7px 12px;border-radius:var(--r-pill)}
.gallery-grid figure.tall img{aspect-ratio:3/4}

/* ---------- reviews (WHITE bg, dual marquee) ---------- */
.reviews-section{background:#fff}
.reviews-intro{max-width:720px;margin-bottom:8px}
.gr-summary{margin:30px 0 12px;display:flex;align-items:center;gap:24px;border:1px solid var(--hair);border-radius:var(--r-lg);padding:24px 28px;background:#fff;box-shadow:var(--shadow-soft);flex-wrap:wrap}
.gr-summary>div:not(.g-mark){display:flex;flex-direction:column;gap:2px}
.g-mark{display:inline-flex;align-items:center;justify-content:center;width:38px;height:38px;border-radius:50%;background:#fff;color:#4285f4;font-weight:800;border:1px solid var(--line);flex-shrink:0}
.g-mark.big{width:64px;height:64px;font-size:30px;box-shadow:var(--shadow-soft)}
.stars{color:#f6a609;letter-spacing:1px;font-size:17px}
.gr-summary strong{font-family:var(--f-display);font-size:34px;line-height:1;color:var(--ink);font-weight:800}
.gr-summary p{margin:0;color:var(--muted);font-size:14px}
.pill-link{margin-left:auto;display:inline-flex;align-items:center;gap:8px;min-height:46px;border-radius:var(--r-pill);background:var(--blue);color:#fff;padding:0 20px;font-weight:600;font-size:14.5px;box-shadow:0 10px 24px rgba(22,92,164,.3);transition:background .2s,transform .2s}
.pill-link:hover{background:var(--blue-d);transform:translateY(-1px)}
.gr-marquee{position:relative;overflow:hidden;margin-top:18px;padding:6px 0;-webkit-mask-image:linear-gradient(90deg,transparent,#000 6%,#000 94%,transparent);mask-image:linear-gradient(90deg,transparent,#000 6%,#000 94%,transparent)}
.gr-track{display:flex;gap:18px;width:max-content;animation:gr-scroll 52s linear infinite}
.gr-marquee:hover .gr-track{animation-play-state:paused}
.gr-marquee-reverse .gr-track{animation-direction:reverse}
.review-card{width:392px;flex-shrink:0;border:1px solid var(--hair);border-radius:var(--r-lg);background:#fff;padding:24px;box-shadow:var(--shadow-soft)}
.review-head{display:flex;gap:13px;align-items:center;margin-bottom:14px}
.avatar{display:inline-flex;align-items:center;justify-content:center;width:46px;height:46px;border-radius:50%;background:var(--blue);color:#fff;font-weight:700;font-size:18px;flex-shrink:0}
.review-head strong{font-size:15.5px;color:var(--ink);font-weight:600}
.review-head .sub{font-size:12.5px;color:var(--muted)}
.review-head .stars{font-size:13px}
.review-head .g-mark{margin-left:auto;width:30px;height:30px;font-size:14px}
.review-card p{color:var(--ink-soft);font-size:14.5px;line-height:1.6;margin:0}
@keyframes gr-scroll{from{transform:translateX(0)}to{transform:translateX(-50%)}}
@media(prefers-reduced-motion:reduce){.gr-track{animation:none}}

/* ---------- dark feature / CTA band ---------- */
.section.dark{background:var(--ink);color:#fff;overflow:hidden}
.section.dark::before{content:"";position:absolute;inset:0;background:radial-gradient(70% 80% at 85% 12%,rgba(63,139,217,.26),transparent 60%);pointer-events:none}
.section.dark .wrap{position:relative;z-index:1}
.section.dark h2,.section.dark .section-title{color:#fff}
.section.dark .lead{color:rgba(255,255,255,.8)}
.section.dark .kicker{color:var(--blue-2)}
.section.dark .photo-panel img{box-shadow:0 30px 60px rgba(0,0,0,.4)}

/* ---------- contact panel ---------- */
.contact-panel{display:grid;grid-template-columns:.82fr 1fr;gap:48px;align-items:center}
.contact-details{display:grid;gap:8px;margin-top:24px;padding:22px;border-radius:var(--r);background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.16)}
.contact-details a,.contact-details span{color:#fff}
.cd-row{display:flex;gap:12px;align-items:flex-start;font-size:15px}
.cd-row svg{width:18px;height:18px;color:var(--blue-2);flex-shrink:0;margin-top:3px}
.cd-row .v{color:rgba(255,255,255,.85)}
.cd-row b{color:#fff;font-weight:600}

/* ---------- subpage / inner ---------- */
.subhero{background:var(--ink);color:#fff;padding:172px 0 92px;position:relative;overflow:hidden}
.subhero::after{content:"";position:absolute;inset:0;background:radial-gradient(900px 380px at 86% -10%,rgba(63,139,217,.3),transparent 60%)}
.subhero .wrap{position:relative;z-index:1}
.subhero .eyebrow{color:var(--blue-2)}
.subhero .eyebrow::before{background:var(--red)}
.subhero h1{font-size:clamp(42px,5.8vw,74px);max-width:920px;color:#fff;font-weight:800;margin:0 0 18px;letter-spacing:-.03em;text-transform:uppercase}
.subhero p{font-size:19px;color:rgba(255,255,255,.82);max-width:660px;margin:0}
.crumb{display:flex;gap:8px;align-items:center;font-size:13px;color:rgba(255,255,255,.6);margin-bottom:20px}
.crumb a{color:rgba(255,255,255,.8)}.crumb a:hover{color:#fff}
.wide-list{display:grid;gap:24px}
.wide-service{display:grid;grid-template-columns:380px 1fr;gap:36px;padding:26px;border:1px solid var(--hair);border-radius:var(--r-lg);background:#fff;box-shadow:var(--shadow-card);align-items:center;transition:transform .25s,box-shadow .25s}
.wide-service:hover{transform:translateY(-4px);box-shadow:0 26px 54px rgba(22,92,164,.14)}
.wide-service img{aspect-ratio:4/3;border-radius:var(--r);object-fit:cover;width:100%}
.wide-service h2{margin:0 0 12px;font-size:29px;font-weight:700}
.wide-service .ov{font-size:12px;font-weight:600;letter-spacing:.12em;text-transform:uppercase;color:var(--blue-d);margin-bottom:8px;display:block}
.wide-service ul,.tick-list{margin:14px 0 22px;padding:0;list-style:none;display:grid;gap:9px;color:var(--muted)}
.wide-service li,.tick-list li{position:relative;padding-left:28px;font-size:15.5px}
.wide-service li::before,.tick-list li::before{content:"";position:absolute;left:0;top:3px;width:18px;height:18px;border-radius:6px;background:var(--blue-tint);background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23165ca4' stroke-width='3.4' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='20 6 9 17 4 12'/%3E%3C/svg%3E");background-size:11px;background-repeat:no-repeat;background-position:center}
.service-hero{padding:172px 0 86px;background:var(--paper);color:var(--ink)}
.service-hero-grid{display:grid;grid-template-columns:.92fr 1fr;gap:54px;align-items:center}
.service-hero h1{font-size:clamp(38px,5vw,62px);line-height:1;margin:0 0 20px;font-weight:800;letter-spacing:-.03em;text-transform:uppercase}
.service-hero p{font-size:19px;color:var(--muted);margin:0}
.service-hero img{aspect-ratio:16/11;border-radius:var(--r-lg);box-shadow:var(--shadow);object-fit:cover;width:100%}
.faq-grid{display:grid;grid-template-columns:.66fr 1fr;gap:54px;align-items:start}
.faq-list{display:grid;gap:12px}
details{border:1px solid var(--hair);background:#fff;border-radius:var(--r);padding:2px 22px;box-shadow:var(--shadow-soft);transition:box-shadow .2s,border-color .2s}
details[open]{box-shadow:var(--shadow-card);border-color:var(--blue-line)}
summary{cursor:pointer;font-weight:600;padding:19px 0;color:var(--ink);list-style:none;font-size:16.5px;position:relative;padding-right:30px;font-family:var(--f-display)}
summary::-webkit-details-marker{display:none}
summary::after{content:"+";position:absolute;right:2px;top:13px;font-size:26px;color:var(--blue);font-weight:400;transition:transform .2s;line-height:1}
details[open] summary::after{transform:rotate(45deg)}
details p{padding:0 0 20px;color:var(--muted);margin:0}
.related{display:flex;justify-content:space-between;gap:30px;align-items:center;flex-wrap:wrap}
.related h2{font-size:34px;font-weight:700;text-transform:uppercase}
.related div{display:flex;gap:11px;flex-wrap:wrap}
.related a{background:#fff;border:1px solid var(--line);border-radius:var(--r-pill);padding:11px 18px;font-weight:600;color:var(--ink);transition:border-color .2s,background .2s,color .2s}
.related a:hover{border-color:var(--blue);background:var(--blue-tint);color:var(--blue-d)}
.map-panel{display:grid;grid-template-columns:.82fr 1fr;gap:36px;align-items:center;padding:32px;border:1px solid var(--hair);border-radius:var(--r-lg);background:#fff;box-shadow:var(--shadow-card);margin-bottom:30px}
.map-graphic{min-height:340px;border-radius:var(--r-lg);background:linear-gradient(135deg,#16263b,#0e1c2e 60%);position:relative;overflow:hidden}
.map-graphic::before{content:"";position:absolute;inset:44px;border:2px dashed rgba(63,139,217,.45);border-radius:48% 52% 43% 57%}
.map-graphic::after{content:"";position:absolute;inset:0;background:radial-gradient(60% 60% at 50% 50%,rgba(63,139,217,.24),transparent 65%)}
.map-graphic span{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);font-family:var(--f-display);font-size:34px;color:#fff;font-weight:700;text-align:center;width:80%;z-index:1;text-transform:uppercase}
.area-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:16px}
.area-card{border:1px solid var(--hair);border-radius:var(--r);padding:22px;background:#fff;box-shadow:var(--shadow-soft);transition:transform .2s,box-shadow .2s,border-color .2s}
.area-card:hover{transform:translateY(-4px);box-shadow:0 22px 44px rgba(22,92,164,.14);border-color:var(--blue-line)}
.area-card h3{margin:0 0 8px;font-size:19px;font-weight:700}
.area-card p{margin:0;color:var(--muted);font-size:14.5px}

/* ---------- about ---------- */
.about-grid{display:grid;grid-template-columns:.85fr 1fr;gap:56px;align-items:center}
.owner-card{position:relative;border-radius:var(--r-lg);overflow:hidden;box-shadow:var(--shadow);background:#dce6f0}
.owner-card img{width:100%;aspect-ratio:4/5;object-fit:cover}
.owner-tag{position:absolute;left:18px;bottom:18px;background:#fff;border-radius:14px;padding:12px 16px;box-shadow:var(--shadow-card)}
.owner-tag b{display:block;font-family:var(--f-display);color:var(--ink);font-size:18px;font-weight:700}
.owner-tag span{font-size:13px;color:var(--blue-d);font-weight:600}

/* ---------- footer ---------- */
.site-footer{background:var(--ink);color:#c7d0db;padding:74px 0 30px;position:relative;overflow:hidden}
.site-footer::before{content:"";position:absolute;inset:0;background:radial-gradient(60% 70% at 10% 0%,rgba(63,139,217,.16),transparent 55%);pointer-events:none}
.footer-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1.1fr;gap:40px;position:relative;z-index:1}
.footer-brand .nm{font-family:var(--f-display);font-weight:800;font-size:22px;color:#fff;letter-spacing:-.02em;text-transform:uppercase;display:block;margin-bottom:14px}
.footer-brand .nm .hl{color:var(--red)}
.site-footer p{color:#aab3c0;font-size:15px}
.site-footer h3{margin:0 0 16px;color:#fff;font-size:14px;font-family:var(--f-sans);font-weight:600;letter-spacing:.04em;text-transform:uppercase}
.site-footer a{display:block;color:#c7d0db;margin:9px 0;font-size:14.5px;transition:color .2s}
.site-footer a:hover{color:var(--blue-2)}
.nap{color:#c7d0db;font-size:14.5px}
.nap strong{color:#fff}
.area-mini{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:12px}
.area-mini span{display:inline-block;background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.13);border-radius:var(--r-pill);padding:5px 12px;font-size:12.5px;color:#c7d0db;margin:0}
.footer-bottom{display:flex;justify-content:space-between;gap:20px;border-top:1px solid rgba(255,255,255,.14);margin-top:46px;padding-top:24px;flex-wrap:wrap;position:relative;z-index:1}
.footer-bottom span{display:block;color:#8b94a3;font-size:13.5px;margin:0}
.footer-credit a{display:inline;color:#c7d0db;text-decoration:underline}

/* ---------- sticky CTA (G8) ---------- */
.sticky-cta{display:none}

/* ---------- responsive ---------- */
@media (max-width:1023px){
  .nav-links,.nav-cta{display:none}
  .nav-toggle{display:flex}
  .nav-pill{padding:6px 6px 6px 14px;background:rgba(255,255,255,.96);backdrop-filter:none;-webkit-backdrop-filter:none}
  .hero{padding:124px 0 56px}
  .hero-grid,.split,.contact-panel,.service-hero-grid,.faq-grid,.map-panel,.about-grid{grid-template-columns:1fr;gap:40px}
  .hero-figure{order:-1;max-width:360px}
  .cards-3,.gallery-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
  .proof-strip{grid-template-columns:repeat(2,minmax(0,1fr))}
  .proof-strip>div:nth-child(2){border-right:0}
  .proof-strip>div:nth-child(1),.proof-strip>div:nth-child(2){border-bottom:1px solid var(--hair)}
  .steps{grid-template-columns:1fr}
  .steps::before{display:none}
  .area-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
  .wide-service{grid-template-columns:1fr;gap:22px}
  .footer-grid{grid-template-columns:1fr 1fr}
  .subhero{padding:140px 0 70px}
  .service-hero{padding:140px 0 64px}
  .related{flex-direction:column;align-items:flex-start}
  .section{padding:78px 0}
  .sticky-cta{position:fixed;left:0;right:0;bottom:0;z-index:70;display:grid;grid-template-columns:1fr 1fr;box-shadow:0 -8px 30px rgba(0,0,0,.18);padding-bottom:env(safe-area-inset-bottom)}
  .sticky-cta a{min-height:60px;display:flex;align-items:center;justify-content:center;color:#fff;font-weight:600;font-size:16px;gap:8px}
  .sc-call{background:var(--red)}
  .sc-msg{background:#0e1c2e}
  body{padding-bottom:60px}
}
@media (min-width:1024px){
  .nav-toggle,.mobile-menu-toggle{display:none!important}
  .mobile-menu{display:none}
}
@media (max-width:640px){
  .wrap{width:min(100% - 32px,1200px)}
  .nav-logo .nm{display:none}
  .hero h1{font-size:40px}
  .hero-sub{font-size:17px}
  .hero-grid{gap:30px}
  .proof-strip{grid-template-columns:1fr}
  .proof-strip>div{padding:22px 24px}
  .proof-strip>div:not(:last-child){border-right:0;border-bottom:1px solid var(--hair)}
  .form-grid{grid-template-columns:1fr}
  .cards-3,.area-grid,.gallery-grid{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr}
  .contact-card{padding:22px}
  .image-stack{grid-template-columns:1fr}
  .image-stack img:first-child,.image-stack img:not(:first-child){grid-column:auto;aspect-ratio:16/10}
  .gr-summary{gap:16px}
  .pill-link{margin-left:0;width:100%;justify-content:center}
  .review-card{width:300px}
  .section-title{font-size:32px}
  .related h2{font-size:28px}
  .hero-badge{left:8px}
}
