
:root{
  --blue:#0b63b2; --blue-dark:#08518f; --gold:#f5b800; --red:#c8102e;
  --ink:#0f1b2d; --muted:#5a6473; --line:#e6ebf2; --tint:#f1f6fc; --tint2:#eaf2fb;
  --white:#ffffff; --shadow:0 18px 48px rgba(15,27,45,.12); --shadow-sm:0 6px 20px rgba(15,27,45,.08);
  --radius:18px; --radius-lg:26px; --maxw:1180px;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;background:var(--white);color:var(--ink);font-family:'Inter',system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;font-size:17px;line-height:1.65;-webkit-font-smoothing:antialiased}
img{max-width:100%;display:block}
a{color:var(--blue);text-decoration:none}
h1,h2,h3,h4{font-family:'Fraunces',Georgia,'Times New Roman',serif;line-height:1.08;margin:0;color:var(--ink);font-weight:600}
h1{font-size:clamp(2.3rem,5.4vw,4rem);letter-spacing:-.01em}
h2{font-size:clamp(1.9rem,3.6vw,2.8rem);letter-spacing:-.01em}
h3{font-size:1.3rem}
p{margin:0 0 1rem}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 22px}
.accent{color:var(--blue);font-style:italic}
.eyebrow{display:inline-block;font-family:'Inter',sans-serif;font-weight:700;font-size:.78rem;letter-spacing:.16em;text-transform:uppercase;color:var(--blue);margin-bottom:14px}
.btn{display:inline-flex;align-items:center;gap:9px;font-weight:700;font-size:1rem;padding:15px 28px;border-radius:999px;border:0;cursor:pointer;transition:transform .15s ease,box-shadow .15s ease,background .15s ease;font-family:inherit}
.btn-primary{background:var(--blue);color:#fff;box-shadow:0 10px 26px rgba(11,99,178,.34)}
.btn-primary:hover{background:var(--blue-dark);transform:translateY(-2px)}
.btn-gold{background:var(--gold);color:#1a1400}
.btn-gold:hover{transform:translateY(-2px);box-shadow:0 12px 28px rgba(245,184,0,.42)}
.btn-ghost{background:rgba(255,255,255,.14);color:#fff;border:1.5px solid rgba(255,255,255,.55);backdrop-filter:blur(4px)}
.btn-ghost:hover{background:rgba(255,255,255,.24)}
.btn-outline{background:#fff;color:var(--blue);border:1.6px solid var(--line)}
.btn-outline:hover{border-color:var(--blue);transform:translateY(-2px)}

/* ---------- header / glass-pill nav (G20) ---------- */
.header{position:fixed;top:0;left:0;right:0;z-index:90;display:flex;justify-content:center;padding:18px 16px}
.nav-pill{display:inline-flex;align-items:center;gap:30px;width:fit-content;margin:0 auto;background:rgba(255,255,255,.82);backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);border:1px solid rgba(255,255,255,.6);box-shadow:0 10px 34px rgba(15,27,45,.14);border-radius:999px;padding:10px 14px 10px 20px}
.nav-logo{display:flex;align-items:center}
.nav-logo img{height:38px;width:auto}
.nav-links{display:flex;gap:24px;margin:0;list-style:none;padding:0}
.nav-links a{color:var(--ink);font-weight:600;font-size:.96rem}
.nav-links a:hover{color:var(--blue)}
.nav-cta{display:inline-flex;align-items:center;gap:8px;background:var(--blue);color:#fff;padding:11px 20px;border-radius:999px;font-weight:700;font-size:.92rem}
.nav-cta:hover{background:var(--blue-dark)}
.mobile-menu-toggle{display:none;background:rgba(11,99,178,.1);border:0;border-radius:12px;width:46px;height:46px;align-items:center;justify-content:center;cursor:pointer}
.mobile-menu-toggle span{display:block;width:20px;height:2px;background:var(--ink);position:relative}
.mobile-menu-toggle span::before,.mobile-menu-toggle span::after{content:"";position:absolute;left:0;width:20px;height:2px;background:var(--ink)}
.mobile-menu-toggle span::before{top:-6px}.mobile-menu-toggle span::after{top:6px}
.mobile-panel{display:none}

/* ---------- hero (G16 full-bleed photo + scrim) ---------- */
.hero{position:relative;min-height:88vh;display:flex;align-items:center;color:#fff;overflow:hidden}
.hero picture,.hero img.hero-img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.hero::after{content:"";position:absolute;inset:0;background:linear-gradient(105deg,rgba(8,20,40,.86) 0%,rgba(8,40,80,.66) 46%,rgba(8,20,40,.34) 100%)}
.hero-inner{position:relative;z-index:3;padding:150px 0 80px;max-width:720px}
.hero h1{color:#fff}
.hero h1 .accent{color:var(--gold);font-style:italic}
.hero .lede{font-size:1.18rem;color:rgba(255,255,255,.92);margin:18px 0 28px;max-width:560px}
.hero-cta{display:flex;flex-wrap:wrap;gap:14px;margin-bottom:30px}
.trust-chips{display:flex;flex-wrap:wrap;gap:10px}
.trust-chips span{display:inline-flex;align-items:center;gap:7px;background:rgba(255,255,255,.13);border:1px solid rgba(255,255,255,.28);backdrop-filter:blur(4px);padding:8px 15px;border-radius:999px;font-size:.85rem;font-weight:600}
.trust-chips span svg{flex:0 0 auto}

/* ---------- quote card overlap ---------- */
.quote-band{background:var(--tint);padding:0 0 70px;position:relative}
.quote-card{position:relative;margin-top:-64px;z-index:6;background:#fff;border-radius:var(--radius-lg);box-shadow:var(--shadow);padding:34px;display:grid;grid-template-columns:1.1fr 1fr;gap:36px;align-items:center;border:1px solid var(--line)}
.quote-card .qc-copy h2{font-size:1.9rem}
.quote-card .qc-copy p{color:var(--muted);margin-bottom:0}
.mini-form{display:grid;gap:12px}
.mini-form .row{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.mini-form input,.mini-form select,.mini-form textarea{width:100%;padding:13px 15px;border:1.4px solid var(--line);border-radius:12px;font-family:inherit;font-size:.95rem;background:#fbfdff}
.mini-form input:focus,.mini-form select:focus,.mini-form textarea:focus{outline:none;border-color:var(--blue);box-shadow:0 0 0 3px rgba(11,99,178,.12)}
.mini-form button{width:100%;justify-content:center}
.form-note{font-size:.8rem;color:var(--muted);text-align:center;margin:0}

/* ---------- sections ---------- */
section{padding:84px 0}
.sec-head{max-width:680px;margin:0 auto 52px;text-align:center}
.sec-head p{color:var(--muted);margin-top:14px;margin-bottom:0}
.bg-tint{background:var(--tint)}
.bg-tint2{background:var(--tint2)}
.bg-ink{background:var(--ink);color:#fff}
.bg-ink h2,.bg-ink h3{color:#fff}
.bg-blue{background:linear-gradient(135deg,var(--blue) 0%,var(--blue-dark) 100%);color:#fff}
.bg-blue h2{color:#fff}

/* why choose us stat rail */
.why{display:grid;grid-template-columns:1fr 1fr;gap:54px;align-items:center}
.why-media{position:relative;border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow);aspect-ratio:1/1}
.why-media img{width:100%;height:100%;object-fit:cover}
.why-list{display:grid;gap:18px;margin-top:24px}
.why-item{display:flex;gap:15px;align-items:flex-start}
.why-ico{flex:0 0 auto;width:46px;height:46px;border-radius:13px;background:var(--tint2);display:flex;align-items:center;justify-content:center;color:var(--blue)}
.why-item h3{font-family:'Inter',sans-serif;font-size:1.05rem;font-weight:700;margin-bottom:3px}
.why-item p{margin:0;color:var(--muted);font-size:.95rem}

/* services grid */
.svc-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:26px}
.svc-card{background:#fff;border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-sm);border:1px solid var(--line);display:flex;flex-direction:column;transition:transform .18s ease,box-shadow .18s ease}
.svc-card:hover{transform:translateY(-5px);box-shadow:var(--shadow)}
.svc-card .ph{aspect-ratio:3/2;overflow:hidden}
.svc-card .ph img{width:100%;height:100%;object-fit:cover;transition:transform .4s ease}
.svc-card:hover .ph img{transform:scale(1.05)}
.svc-body{padding:24px 24px 26px;display:flex;flex-direction:column;flex:1}
.svc-ico{width:48px;height:48px;border-radius:13px;background:var(--tint2);color:var(--blue);display:flex;align-items:center;justify-content:center;margin:-46px 0 16px;position:relative;z-index:2;box-shadow:var(--shadow-sm);background:#fff}
.svc-body h3{margin-bottom:8px}
.svc-body p{color:var(--muted);font-size:.95rem;flex:1}
.svc-link{font-weight:700;color:var(--blue);font-size:.92rem;display:inline-flex;align-items:center;gap:6px;margin-top:8px}

/* process timeline */
.steps{display:grid;grid-template-columns:repeat(4,1fr);gap:24px;counter-reset:step}
.step{position:relative;padding-top:8px}
.step .num{width:52px;height:52px;border-radius:50%;background:var(--blue);color:#fff;display:flex;align-items:center;justify-content:center;font-family:'Fraunces',serif;font-size:1.4rem;font-weight:600;margin-bottom:16px}
.step h3{font-family:'Inter',sans-serif;font-size:1.08rem;font-weight:700;margin-bottom:6px}
.step p{color:var(--muted);font-size:.93rem;margin:0}

/* reviews (G4 tier-2 .gr-summary) */
.gr-summary{max-width:560px;margin:0 auto;background:#fff;border:1px solid var(--line);border-radius:var(--radius-lg);box-shadow:var(--shadow);padding:38px 34px;text-align:center}
.gr-g{width:46px;height:46px;margin:0 auto 14px}
.gr-score{font-family:'Fraunces',serif;font-size:3.4rem;font-weight:600;line-height:1;color:var(--ink)}
.gr-stars{display:flex;gap:4px;justify-content:center;margin:12px 0 8px}
.gr-count{color:var(--muted);font-size:.98rem;margin-bottom:22px}
.gr-cta{display:inline-flex;align-items:center;gap:9px;background:#fff;border:1.5px solid var(--line);color:var(--ink);padding:12px 22px;border-radius:999px;font-weight:700;font-size:.92rem;transition:border-color .15s,transform .15s}
.gr-cta:hover{border-color:var(--blue);transform:translateY(-2px)}

/* service areas (G24 graphic, no iframe) */
.areas-wrap{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:center}
.areas-map{position:relative;border-radius:var(--radius-lg);overflow:hidden;background:linear-gradient(135deg,var(--blue-dark),var(--blue));aspect-ratio:4/3;display:flex;align-items:center;justify-content:center;box-shadow:var(--shadow)}
.area-chips{display:flex;flex-wrap:wrap;gap:10px;margin-top:24px}
.area-chips span{background:#fff;border:1px solid var(--line);padding:9px 16px;border-radius:999px;font-weight:600;font-size:.9rem;color:var(--ink)}

/* faq accordion */
.faq-list{max-width:820px;margin:0 auto;display:grid;gap:14px}
details.qa{background:#fff;border:1px solid var(--line);border-radius:14px;padding:0;overflow:hidden}
.bg-blue details.qa,.bg-ink details.qa{background:rgba(255,255,255,.07);border-color:rgba(255,255,255,.18)}
details.qa summary{list-style:none;cursor:pointer;padding:20px 24px;font-weight:700;font-size:1.05rem;display:flex;justify-content:space-between;align-items:center;gap:16px;font-family:'Inter',sans-serif}
details.qa summary::-webkit-details-marker{display:none}
details.qa summary::after{content:"+";font-size:1.5rem;color:var(--blue);font-weight:400;transition:transform .2s}
.bg-blue details.qa summary::after,.bg-ink details.qa summary::after{color:var(--gold)}
details.qa[open] summary::after{transform:rotate(45deg)}
details.qa .ans{padding:0 24px 20px;color:var(--muted);font-size:.97rem}
.bg-blue details.qa .ans,.bg-ink details.qa .ans{color:rgba(255,255,255,.85)}

/* cta band */
.cta-band{text-align:center}
.cta-band h2{max-width:680px;margin:0 auto 14px}
.cta-band p{max-width:560px;margin:0 auto 28px;color:rgba(255,255,255,.9)}
.cta-band .hero-cta{justify-content:center}

/* page hero (interior) */
.page-hero{position:relative;color:#fff;padding:160px 0 70px;overflow:hidden;background:var(--ink)}
.page-hero picture,.page-hero img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.page-hero::after{content:"";position:absolute;inset:0;background:linear-gradient(100deg,rgba(8,20,40,.9),rgba(8,40,80,.6))}
.page-hero .wrap{position:relative;z-index:3}
.page-hero h1{color:#fff;max-width:760px}
.page-hero .lede{color:rgba(255,255,255,.9);max-width:600px;margin-top:14px}
.crumb{position:relative;z-index:3;font-size:.85rem;color:rgba(255,255,255,.75);margin-bottom:14px}
.crumb a{color:rgba(255,255,255,.9)}

/* article / service detail */
.detail{display:grid;grid-template-columns:1.6fr 1fr;gap:48px;align-items:start}
.detail .body p{color:#3a4250}
.detail-media{border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow)}
.points{display:grid;gap:12px;margin:24px 0;padding:0;list-style:none}
.points li{display:flex;gap:12px;align-items:flex-start;color:var(--ink);font-weight:500}
.points li svg{flex:0 0 auto;color:var(--blue);margin-top:3px}
.sidecard{background:var(--tint);border:1px solid var(--line);border-radius:var(--radius-lg);padding:28px;position:sticky;top:100px}
.sidecard h3{margin-bottom:8px}
.sidecard .ph{font-family:'Fraunces',serif;font-size:1.5rem;color:var(--blue);font-weight:600}
.sidecard .btn{width:100%;justify-content:center;margin-top:14px}
.other-svc{display:grid;gap:8px;margin-top:8px}
.other-svc a{display:block;padding:11px 14px;background:#fff;border:1px solid var(--line);border-radius:11px;font-weight:600;color:var(--ink);font-size:.92rem}
.other-svc a:hover{border-color:var(--blue);color:var(--blue)}

/* full contact form */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:start}
.full-form{display:grid;gap:14px;background:#fff;border:1px solid var(--line);border-radius:var(--radius-lg);padding:32px;box-shadow:var(--shadow-sm)}
.full-form .row{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.full-form label{font-weight:600;font-size:.88rem;margin-bottom:5px;display:block}
.full-form input,.full-form select,.full-form textarea{width:100%;padding:13px 15px;border:1.4px solid var(--line);border-radius:12px;font-family:inherit;font-size:.95rem;background:#fbfdff}
.full-form input:focus,.full-form select:focus,.full-form textarea:focus{outline:none;border-color:var(--blue);box-shadow:0 0 0 3px rgba(11,99,178,.12)}
.full-form textarea{min-height:120px;resize:vertical}
.contact-info{display:grid;gap:18px}
.ci-item{display:flex;gap:14px;align-items:flex-start}
.ci-ico{flex:0 0 auto;width:48px;height:48px;border-radius:13px;background:var(--tint2);color:var(--blue);display:flex;align-items:center;justify-content:center}
.ci-item h3{font-family:'Inter',sans-serif;font-size:1rem;font-weight:700;margin-bottom:2px}
.ci-item p,.ci-item a{margin:0;color:var(--muted);font-size:.95rem}
.hours-table{width:100%;border-collapse:collapse;margin-top:6px}
.hours-table td{padding:7px 0;border-bottom:1px solid var(--line);font-size:.93rem}
.hours-table td:last-child{text-align:right;font-weight:600;color:var(--ink)}
.form-success{display:none;background:#eafaf0;border:1px solid #b6e6c6;color:#1b6e3a;padding:14px 16px;border-radius:12px;font-weight:600}

/* footer */
.footer{background:var(--ink);color:rgba(255,255,255,.72);padding:70px 0 28px}
.footer-grid{display:grid;grid-template-columns:1.6fr 1fr 1fr 1.2fr;gap:40px;margin-bottom:44px}
.footer h4{color:#fff;font-family:'Inter',sans-serif;font-size:.92rem;letter-spacing:.05em;text-transform:uppercase;margin-bottom:18px}
.footer a{color:rgba(255,255,255,.72)}
.footer a:hover{color:#fff}
.footer ul{list-style:none;padding:0;margin:0;display:grid;gap:10px;font-size:.93rem}
.footer .flogo img{height:46px;margin-bottom:16px}
.footer .fabout{font-size:.93rem;max-width:300px}
.nap{font-size:.92rem;display:grid;gap:8px}
.nap a{color:rgba(255,255,255,.72)}
.footer-bottom{border-top:1px solid rgba(255,255,255,.12);padding-top:22px;display:flex;justify-content:space-between;flex-wrap:wrap;gap:12px;font-size:.85rem}
.footer-credit a{color:var(--gold);font-weight:600}

/* mobile sticky CTA (G8) */
.sticky-cta{display:none;position:fixed;bottom:0;left:0;right:0;z-index:95}
.sticky-cta a{flex:1;display:flex;align-items:center;justify-content:center;gap:8px;padding:15px 0;font-weight:700;color:#fff;font-size:1rem}
.sticky-cta .call{background:var(--blue)}
.sticky-cta .msg{background:#0a0a0a}

/* ---------- responsive ---------- */
@media(max-width:1023px){
  .nav-links,.nav-cta{display:none}
  .mobile-menu-toggle{display:flex}
  .nav-pill{width:auto;justify-content:space-between;padding:10px 12px 10px 18px;flex:1;max-width:560px}
  .mobile-panel{display:block;position:fixed;inset:0;z-index:120;background:rgba(8,20,40,.6);backdrop-filter:blur(4px);opacity:0;pointer-events:none;transition:opacity .25s}
  .mobile-panel.open{opacity:1;pointer-events:auto}
  .mobile-panel .sheet{position:absolute;top:0;right:0;bottom:0;width:min(82%,360px);background:#fff;padding:28px 26px;display:flex;flex-direction:column;gap:6px;transform:translateX(100%);transition:transform .28s ease;box-shadow:-20px 0 50px rgba(0,0,0,.2)}
  .mobile-panel.open .sheet{transform:translateX(0)}
  .mobile-panel .sheet .top{display:flex;justify-content:space-between;align-items:center;margin-bottom:18px}
  .mobile-panel .sheet .top img{height:38px}
  .mobile-panel .close{background:none;border:0;font-size:1.8rem;line-height:1;cursor:pointer;color:var(--ink)}
  .mobile-panel .sheet a{padding:14px 4px;border-bottom:1px solid var(--line);font-weight:600;color:var(--ink);font-size:1.05rem}
  .mobile-panel .sheet .mcall{margin-top:18px;background:var(--blue);color:#fff;border-radius:12px;text-align:center;border:0;justify-content:center;display:flex}
  .mobile-panel .sheet .mphone{color:var(--blue);font-weight:700;text-align:center;border:0;padding-top:12px}
  .why,.areas-wrap,.detail,.contact-grid{grid-template-columns:1fr;gap:34px}
  .quote-card{grid-template-columns:1fr;gap:24px}
  .svc-grid{grid-template-columns:repeat(2,1fr);gap:20px}
  .steps{grid-template-columns:repeat(2,1fr);gap:28px}
  .footer-grid{grid-template-columns:1fr 1fr;gap:30px}
  .sidecard{position:static}
}
@media(max-width:600px){
  body{font-size:16px}
  section{padding:60px 0}
  .hero-inner{padding:128px 0 64px}
  .hero{min-height:78vh}
  .svc-grid{grid-template-columns:1fr}
  .steps{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr}
  .mini-form .row,.full-form .row{grid-template-columns:1fr}
  .sticky-cta{display:flex}
  body{padding-bottom:54px}
}
@media(prefers-reduced-motion:reduce){*{scroll-behavior:auto;transition:none!important;animation:none!important}}
