:root{
  --brand-primary: #22b14b;
  --brand-primary-dark: #1a8a39;
  --brand-accent: #0a0a0a;
  --ink: #0a0a0a;
  --mute: #5b5b5b;
  --soft: #f4f9f5;
  --line: rgba(10,10,10,0.10);
}
*,*::before,*::after{box-sizing:border-box}
html,body{margin:0;padding:0;background:#fff;color:var(--ink);font-family:-apple-system,BlinkMacSystemFont,"Inter","Segoe UI",Roboto,Helvetica,Arial,sans-serif;-webkit-font-smoothing:antialiased;line-height:1.55;font-size:16px}
img{max-width:100%;height:auto;display:block}
a{color:var(--brand-primary);text-decoration:none;transition:color .15s}
a:hover{color:var(--brand-primary-dark)}
.container{max-width:1200px;margin:0 auto;padding:0 24px}
section{padding:96px 0}
.section-eyebrow{font-family:'SF Mono','Menlo',monospace;font-size:12px;letter-spacing:.06em;text-transform:uppercase;color:var(--mute);display:block;margin-bottom:14px}
h1,h2,h3,h4{font-weight:700;line-height:1.05;letter-spacing:-.02em;margin:0}
h2{font-size:clamp(36px,5vw,72px)}
h3{font-size:clamp(22px,2.4vw,32px)}
p{margin:0 0 14px}

/* ============== NAV (glass pill) — G20 ============== */
.site-nav{position:fixed;top:16px;left:50%;transform:translateX(-50%);display:flex;align-items:center;gap:24px;padding:10px 20px;background:rgba(255,255,255,0.78);backdrop-filter:blur(20px) saturate(180%);-webkit-backdrop-filter:blur(20px) saturate(180%);border:1px solid rgba(255,255,255,0.7);border-radius:9999px;box-shadow:0 1px 0 rgba(255,255,255,0.8) inset,0 0 0 1px rgba(10,10,10,0.06),0 8px 24px -8px rgba(10,10,10,0.16),0 20px 40px -16px rgba(10,10,10,0.10);z-index:100;max-width:calc(100vw - 32px)}
.nav-logo{display:flex;align-items:center;height:32px}
.nav-logo img{max-height:32px;width:auto}
.desktop-nav{display:flex;gap:20px;align-items:center}
.desktop-nav a{font-size:14px;font-weight:500;color:var(--ink);padding:6px 8px;border-radius:6px}
.desktop-nav a:hover{background:rgba(10,10,10,0.06);color:var(--ink)}
.desktop-nav a.active{color:var(--brand-primary)}
.nav-contact-btn{display:inline-block;padding:9px 18px;background:var(--brand-primary);color:#fff;font-size:14px;font-weight:600;border-radius:9999px;border:none;letter-spacing:.01em}
.nav-contact-btn:hover{background:var(--brand-primary-dark);color:#fff}
.mobile-menu-toggle{display:none;background:transparent;border:none;cursor:pointer;padding:6px;color:var(--ink)}
@media (max-width:1023px){
  .desktop-nav,.nav-contact-btn{display:none !important}
  .mobile-menu-toggle{display:flex !important}
  .site-nav{padding:8px 14px;gap:12px}
}
/* Mobile menu panel */
.mobile-menu{display:none;position:fixed;top:0;left:0;right:0;bottom:0;background:#fff;z-index:200;padding:80px 24px 32px;overflow-y:auto;flex-direction:column}
.mobile-menu.open{display:flex}
.mobile-menu-close{position:absolute;top:18px;right:18px;background:transparent;border:none;cursor:pointer;padding:8px;color:var(--ink)}
.mobile-menu nav{display:flex;flex-direction:column;gap:12px;margin-bottom:32px}
.mobile-menu nav a{font-size:24px;font-weight:600;color:var(--ink);padding:12px 0;border-bottom:1px solid var(--line)}
.mobile-menu .menu-contact{display:flex;flex-direction:column;gap:14px;padding-top:24px;border-top:1px solid var(--line)}
.mobile-menu .menu-contact a{display:flex;flex-direction:column;color:var(--ink);text-decoration:none}
.mobile-menu .menu-contact .label{font-size:11px;text-transform:uppercase;letter-spacing:.08em;color:var(--mute)}
.mobile-menu .menu-contact .val{font-size:20px;font-weight:700;color:var(--brand-primary)}
.mobile-menu .menu-address{color:var(--mute);font-size:14px;padding-top:6px}
body.menu-open{overflow:hidden}

/* ============== HERO (full-bleed, G16, G18, G32) ============== */
.hero-fullbleed{position:relative;min-height:100vh;margin:0;padding:0;isolation:isolate;overflow:hidden}
.hero-fullbleed picture,.hero-fullbleed picture img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:65% center;z-index:0}
.hero-fullbleed::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(0,0,0,0.42) 0%,rgba(0,0,0,0.18) 30%,rgba(0,0,0,0.50) 65%,rgba(0,0,0,0.78) 100%);z-index:1;pointer-events:none}
.hero-fullbleed > .container{position:relative;z-index:2;display:flex;flex-direction:column;justify-content:flex-end;min-height:100vh;padding-top:140px;padding-bottom:96px;color:#fff}
.hero-eyebrow{font-family:'SF Mono','Menlo',monospace;font-size:12px;letter-spacing:.08em;text-transform:uppercase;color:#fff;opacity:.92;margin-bottom:24px;display:flex;align-items:center;gap:10px}
.hero-eyebrow::before{content:"";display:inline-block;width:24px;height:1px;background:var(--brand-accent)}
.hero-headline{font-size:clamp(48px,8vw,128px);line-height:.96;font-weight:800;letter-spacing:-.025em;color:#fff;text-shadow:0 2px 12px rgba(0,0,0,0.35);margin-bottom:24px;text-transform:uppercase}
.hero-sub{font-size:clamp(17px,1.4vw,21px);max-width:640px;color:#fff;opacity:.92;text-shadow:0 1px 8px rgba(0,0,0,0.5);margin-bottom:40px;line-height:1.55}
.hero-ctas{display:flex;gap:14px;flex-wrap:wrap;margin-bottom:48px}
.btn-primary{display:inline-flex;align-items:center;gap:10px;padding:16px 28px;background:var(--brand-primary);color:#fff;border-radius:9999px;font-size:15px;font-weight:700;letter-spacing:.01em;text-decoration:none;border:none;cursor:pointer;transition:transform .15s,filter .15s}
.btn-primary:hover{filter:brightness(1.08);transform:translateY(-1px);color:#fff}
.btn-secondary{display:inline-flex;align-items:center;gap:10px;padding:16px 28px;background:rgba(255,255,255,0.14);backdrop-filter:blur(10px);color:#fff;border:1px solid rgba(255,255,255,0.3);border-radius:9999px;font-size:15px;font-weight:600;text-decoration:none;cursor:pointer;transition:background .15s}
.btn-secondary:hover{background:rgba(255,255,255,0.22);color:#fff}
.hero-stats{display:flex;gap:32px;flex-wrap:wrap;padding:24px 0 0;border-top:1px solid rgba(255,255,255,0.18);max-width:840px}
.hero-stat{display:flex;flex-direction:column;gap:4px;color:#fff;text-shadow:0 1px 6px rgba(0,0,0,0.5)}
.hero-stat .num{font-size:28px;font-weight:800;letter-spacing:-.02em;line-height:1}
.hero-stat .lbl{font-size:12px;text-transform:uppercase;letter-spacing:.06em;opacity:.78}
@media(max-width:640px){
  .hero-fullbleed > .container{padding-top:110px;padding-bottom:120px}
  .hero-headline{font-size:46px;line-height:1}
  .hero-stats{gap:18px}
  .hero-stat{flex:1 1 calc(50% - 9px)}
  .hero-stat .num{font-size:22px}
}

/* ============== INNER PAGE HERO (smaller) ============== */
.inner-hero{padding:160px 0 64px;background:#fff;border-bottom:1px solid var(--line)}
.inner-hero h1{font-size:clamp(40px,6vw,84px);line-height:1.0;letter-spacing:-.025em;text-transform:uppercase;font-weight:800;margin-bottom:18px}
.inner-hero h1 .accent{color:var(--brand-primary)}
.inner-hero p{font-size:clamp(17px,1.3vw,20px);color:var(--mute);max-width:640px}

/* ============== SERVICES (numbered rows) ============== */
.services-section{background:#fff;padding:120px 0}
.services-head{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:end;margin-bottom:64px}
.services-head h2{max-width:520px}
.services-head p{color:var(--mute);max-width:520px;font-size:17px}
@media(max-width:900px){.services-head{grid-template-columns:1fr;gap:24px}}
.service-row{display:grid;grid-template-columns:60px 1fr 1.4fr 40px;align-items:center;gap:32px;padding:32px 0;border-top:1px solid var(--line);text-decoration:none;color:var(--ink);transition:transform .15s}
.service-row:last-child{border-bottom:1px solid var(--line)}
.service-row:hover{transform:translateX(4px);color:var(--ink)}
.service-num{font-family:'SF Mono','Menlo',monospace;font-size:14px;color:var(--mute)}
.service-name{font-size:clamp(22px,2.4vw,34px);font-weight:700;letter-spacing:-.015em}
.service-blurb{font-size:15px;color:var(--mute);line-height:1.55;max-width:540px}
.service-arrow{justify-self:end;width:36px;height:36px;border-radius:9999px;background:var(--soft);display:flex;align-items:center;justify-content:center;color:var(--ink);transition:background .15s,color .15s}
.service-row:hover .service-arrow{background:var(--brand-accent);color:#fff}
@media(max-width:640px){
  .service-row{grid-template-columns:32px 1fr 24px;gap:8px 16px;padding:22px 0}
  .service-blurb{grid-column:1 / -1;padding-left:48px;padding-top:6px;font-size:14px;max-width:none}
}

/* ============== ABOUT TEASE ============== */
.about-band{background:var(--soft);padding:120px 0}
.about-grid{display:grid;grid-template-columns:1.2fr 1fr;gap:80px;align-items:center}
.about-grid img{border-radius:14px;width:100%;height:auto;aspect-ratio:4/5;object-fit:cover}
.about-grid h2{margin-bottom:24px}
.about-grid p{color:var(--mute);font-size:17px;margin-bottom:18px;max-width:560px}
.about-grid .creds{display:flex;flex-wrap:wrap;gap:10px;margin-top:24px}
.about-grid .cred-pill{font-family:'SF Mono',monospace;font-size:12px;padding:8px 14px;background:#fff;border:1px solid var(--line);border-radius:9999px;color:var(--ink)}
@media(max-width:900px){.about-grid{grid-template-columns:1fr;gap:40px}}

/* ============== WHY-CHOOSE-US ============== */
.why-section{padding:120px 0;background:#fff}
.why-section h2{margin-bottom:64px;max-width:780px}
.why-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:32px}
.why-card{padding:32px 28px;border:1px solid var(--line);border-radius:16px;display:flex;flex-direction:column;gap:14px;background:#fff;transition:border-color .2s,transform .2s}
.why-card:hover{border-color:var(--brand-primary);transform:translateY(-4px)}
.why-num{font-family:'SF Mono',monospace;font-size:13px;color:var(--brand-accent)}
.why-card h3{font-size:22px;letter-spacing:-.01em;line-height:1.15}
.why-card p{font-size:15px;color:var(--mute);line-height:1.55;margin:0}
@media(max-width:900px){.why-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:520px){.why-grid{grid-template-columns:1fr}}

/* ============== CTA BAND ============== */
.cta-band{background:var(--brand-primary);padding:120px 0;color:#fff;margin:0}
.cta-grid{display:grid;grid-template-columns:1.2fr 1fr;gap:64px;align-items:center}
.cta-band h2{color:#fff;margin-bottom:18px}
.cta-band p{color:rgba(255,255,255,.85);font-size:18px;max-width:520px}
.cta-band .cta-actions{display:flex;flex-direction:column;gap:14px}
.cta-band .btn-primary{background:#fff;color:var(--brand-primary);justify-content:center}
.cta-band .btn-primary:hover{background:#f4f6f9;color:var(--brand-primary)}
.cta-band .btn-secondary{background:rgba(255,255,255,0.16);color:#fff;border-color:rgba(255,255,255,0.32);justify-content:center}
@media(max-width:900px){.cta-grid{grid-template-columns:1fr;gap:32px}}

/* ============== LOCATION SECTION (G24 — graphic, no iframe) ============== */
.location-section{padding:120px 0;background:#fff;margin:0}
.location-grid{display:grid;grid-template-columns:1.1fr 1fr;gap:64px;align-items:center}
.location-grid h2{margin-bottom:18px}
.location-grid > div > p{color:var(--mute);font-size:17px;max-width:520px;margin-bottom:18px}
.suburb-pills{display:flex;flex-wrap:wrap;gap:8px;margin-top:24px;max-width:520px}
.suburb-pill{font-size:13px;padding:8px 14px;background:var(--soft);border:1px solid var(--line);border-radius:9999px;color:var(--ink)}
.location-graphic{display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#f8f9fb,#eaeef5);border-radius:24px;padding:48px;aspect-ratio:1.1/1}
.location-graphic svg{width:100%;height:100%;max-width:480px}
@media(max-width:900px){.location-grid{grid-template-columns:1fr;gap:40px}.location-graphic{aspect-ratio:1.4/1;padding:24px}}

/* ============== CONTACT SECTION ============== */
.contact-section{padding:120px 0;background:var(--soft);margin:0}
.contact-grid{display:grid;grid-template-columns:1fr 1.1fr;gap:64px;align-items:start}
.contact-grid h2{margin-bottom:24px}
.contact-grid > div > p{color:var(--mute);font-size:17px;max-width:480px;margin-bottom:32px}
.contact-block{margin-bottom:24px}
.contact-block .label{font-family:'SF Mono',monospace;font-size:12px;color:var(--mute);text-transform:uppercase;letter-spacing:.06em;display:block;margin-bottom:6px}
.contact-block .val{font-size:18px;color:var(--ink);font-weight:600;text-decoration:none}
.contact-block .val:hover{color:var(--brand-primary)}
.contact-form{background:#fff;padding:40px;border-radius:16px;border:1px solid var(--line);display:flex;flex-direction:column;gap:18px}
.contact-form label{display:flex;flex-direction:column;gap:6px;font-size:13px;font-weight:600;color:var(--ink)}
.contact-form input,.contact-form textarea,.contact-form select{padding:12px 14px;border:1px solid var(--line);border-radius:9px;font-size:15px;font-family:inherit;background:#fff;transition:border-color .15s}
.contact-form input:focus,.contact-form textarea:focus,.contact-form select:focus{outline:none;border-color:var(--brand-primary)}
.contact-form textarea{resize:vertical;min-height:110px}
.contact-form .submit-btn{padding:16px 28px;background:var(--brand-primary);color:#fff;border:none;border-radius:9999px;font-size:15px;font-weight:700;cursor:pointer;letter-spacing:.01em;transition:background .15s}
.contact-form .submit-btn:hover{background:var(--brand-primary-dark)}
.contact-disclaimer{font-size:13px;color:var(--mute);text-align:center}
@media(max-width:900px){.contact-grid{grid-template-columns:1fr;gap:40px}.contact-form{padding:28px}}

/* ============== FAQ <details> (G27) ============== */
.faq-section{padding:120px 0;background:#fff;margin:0}
.faq-section h2{margin-bottom:48px;max-width:780px}
.faq-list{display:flex;flex-direction:column;max-width:880px}
.faq-item{border-top:1px solid var(--line);padding:24px 0}
.faq-item:last-child{border-bottom:1px solid var(--line)}
.faq-item summary{cursor:pointer;font-weight:600;font-size:clamp(17px,1.3vw,20px);list-style:none;display:flex;justify-content:space-between;gap:24px;color:var(--ink)}
.faq-item summary::-webkit-details-marker{display:none}
.faq-item summary::after{content:"+";font-weight:300;font-size:24px;line-height:1;color:var(--brand-accent);flex-shrink:0;transition:transform .15s}
.faq-item[open] summary::after{content:"−"}
.faq-answer{padding:18px 0 0;max-width:760px}
.faq-answer p{color:var(--mute);font-size:16px;line-height:1.65;margin:0}

/* ============== FOOTER ============== */
.site-footer{background:#0a0a0a;color:rgba(255,255,255,0.7);padding:80px 0 28px;margin:0}
.site-footer .container{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:48px}
.site-footer .brand h3{color:#fff;font-size:22px;margin-bottom:12px;letter-spacing:-.01em}
.site-footer .brand p{font-size:14px;line-height:1.6;color:rgba(255,255,255,0.65);max-width:320px}
.site-footer h4{color:#fff;font-size:13px;font-weight:700;text-transform:uppercase;letter-spacing:.08em;margin-bottom:20px}
.site-footer ul{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:10px}
.site-footer ul a{color:rgba(255,255,255,0.7);font-size:14px;text-decoration:none}
.site-footer ul a:hover{color:#fff}
.site-footer .nap{font-size:14px;line-height:1.7;color:rgba(255,255,255,0.7);font-style:normal}
.site-footer .nap strong{color:#fff;font-weight:600;display:block;margin-bottom:4px}
.site-footer .nap a{color:rgba(255,255,255,0.7)}
.footer-bottom{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:18px;padding-top:32px;margin-top:64px;border-top:1px solid rgba(255,255,255,0.12);font-size:13px;color:rgba(255,255,255,0.55)}
.footer-bottom a{color:rgba(255,255,255,0.55)}
.footer-bottom a:hover{color:#fff}
.footer-credit a{color:rgba(255,255,255,0.85);font-weight:600}
@media(max-width:900px){.site-footer .container{grid-template-columns:1fr 1fr;gap:40px}}
@media(max-width:520px){.site-footer .container{grid-template-columns:1fr}}

/* ============== MOBILE STICKY CTA (G8) ============== */
.mobile-sticky-cta{display:none;position:fixed;left:0;right:0;bottom:0;height:60px;z-index:90;box-shadow:0 -4px 20px rgba(0,0,0,0.18)}
.mobile-sticky-cta a{flex:1;display:flex;align-items:center;justify-content:center;gap:8px;text-decoration:none;font-weight:700;font-size:16px;letter-spacing:.01em}
.mobile-sticky-cta .call-btn{background:var(--brand-primary);color:#fff}
.mobile-sticky-cta .msg-btn{background:#0a0a0a;color:#fff}
.mobile-sticky-cta svg{width:20px;height:20px}
@media(max-width:639px){.mobile-sticky-cta{display:flex}body{padding-bottom:60px}}

/* ============== REVIEWS SECTION (G4 — auto-marquee, no user scroll) ============== */
.reviews-section{padding:120px 0;background:#fff;margin:0;content-visibility:auto;contain-intrinsic-size:auto 800px}
.reviews-header{margin-bottom:32px}
.reviews-header h2{margin-bottom:18px}
.reviews-sub{color:var(--mute);font-size:17px;max-width:640px;line-height:1.65}
.reviews-summary-card{display:flex;align-items:center;gap:24px;padding:20px 28px;border:1px solid var(--line);border-radius:16px;margin-bottom:48px;flex-wrap:wrap;background:var(--soft)}
.aggregate-info{display:flex;align-items:center;gap:14px;flex-wrap:wrap}
.rating-num{font-size:36px;font-weight:800;color:var(--ink);line-height:1}
.stars-large{color:#fbbc04;font-size:22px;letter-spacing:.05em}
.reviews-meta{color:var(--mute);font-size:14px;margin-left:8px}
.see-all-pill{display:inline-flex;align-items:center;gap:6px;padding:10px 18px;border:1px solid rgba(10,10,10,0.16);border-radius:9999px;font-size:14px;text-decoration:none;color:var(--ink);background:#fff;font-weight:600;margin-left:auto}
.see-all-pill:hover{background:#f4f6f9;color:var(--ink)}
@media(max-width:640px){.see-all-pill{margin-left:0;width:100%;justify-content:center}}
.reviews-carousel{overflow:hidden;position:relative;padding-bottom:8px;mask-image:linear-gradient(to right, transparent 0, #000 64px, #000 calc(100% - 64px), transparent 100%);-webkit-mask-image:linear-gradient(to right, transparent 0, #000 64px, #000 calc(100% - 64px), transparent 100%)}
.reviews-track{display:flex;gap:16px;width:max-content;animation:reviews-marquee 80s linear infinite;will-change:transform}
.reviews-track:hover,.reviews-track:focus-within{animation-play-state:paused}
@keyframes reviews-marquee{from{transform:translateX(0)}to{transform:translateX(-50%)}}
@media (prefers-reduced-motion: reduce){.reviews-track{animation:none;flex-wrap:wrap;width:100%}}
.review-card{flex:0 0 380px;background:#fff;border:1px solid var(--line);border-radius:14px;padding:28px;box-shadow:0 1px 2px rgba(10,10,10,0.04)}
.review-head{display:flex;align-items:flex-start;gap:14px;margin-bottom:14px}
.avatar{width:42px;height:42px;border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;font-weight:600;font-size:14px;flex-shrink:0}
.review-meta{flex:1;display:flex;flex-direction:column;gap:2px}
.reviewer-name{font-size:15px;color:var(--ink)}
.review-time{font-size:12px;color:var(--mute)}
.stars-row{color:#fbbc04;font-size:14px;margin-bottom:12px;letter-spacing:.05em}
.review-text{color:#3a3a3a;line-height:1.6;font-size:14.5px;margin:0}
@media(max-width:640px){.review-card{flex:0 0 calc(100vw - 64px)}.reviews-track{animation-duration:90s}}

/* ============== RECENT WORK BAND (responsive grid) ============== */
@media(max-width:900px){.recent-work-band > .container > div:first-child{grid-template-columns:1fr !important;gap:24px !important}.recent-work-band > .container > div:first-child p{justify-self:start !important}}
@media(max-width:640px){.recent-work-band > .container > div:last-child{grid-template-columns:repeat(2, 1fr) !important}}
.recent-work-band{content-visibility:auto;contain-intrinsic-size:auto 600px}
.about-band{content-visibility:auto;contain-intrinsic-size:auto 600px}
.location-section{content-visibility:auto;contain-intrinsic-size:auto 600px}

/* ============== UTILITY ============== */
.text-mute{color:var(--mute)}
.divider{height:1px;background:var(--line);margin:0;border:0}

/* ============== 404 ============== */
.not-found{padding:200px 0 120px;background:#fff;text-align:center}
.not-found .error-eyebrow{color:var(--brand-accent);font-family:'SF Mono',monospace;font-size:14px;text-transform:uppercase;letter-spacing:.08em;margin-bottom:18px}
.not-found h1{font-size:clamp(48px,8vw,96px);text-transform:uppercase;line-height:1;margin-bottom:24px}
.not-found p{color:var(--mute);font-size:18px;max-width:560px;margin:0 auto 36px}
.not-found-cta{display:flex;gap:12px;justify-content:center;flex-wrap:wrap}
.not-found .btn-primary{background:var(--brand-primary);color:#fff}
.not-found .btn-secondary{background:#fff;border:1px solid var(--line);color:var(--ink)}

/* ============== ABOUT PAGE STORY ============== */
.about-story{padding:120px 0;background:#fff;margin:0}
.about-story-grid{display:grid;grid-template-columns:1.4fr 1fr;gap:80px;align-items:start}
.about-story-grid h2{margin-bottom:32px}
.about-story-grid p{color:var(--mute);font-size:17px;line-height:1.7;margin-bottom:18px;max-width:600px}
.about-story-aside{position:sticky;top:120px}
.about-story-aside img{width:100%;border-radius:16px;aspect-ratio:4/5;object-fit:cover}
@media(max-width:900px){.about-story-grid{grid-template-columns:1fr;gap:40px}.about-story-aside{position:static}}

/* ============== SERVICE-DETAIL PAGE ============== */
.service-hero{padding:160px 0 64px;background:var(--soft);border-bottom:1px solid var(--line)}
.service-hero .container{display:grid;grid-template-columns:1.3fr 1fr;gap:48px;align-items:end}
.service-hero h1{font-size:clamp(48px,7vw,96px);line-height:.98;letter-spacing:-.025em;text-transform:uppercase;margin-bottom:18px}
.service-hero img{border-radius:14px;aspect-ratio:5/4;object-fit:cover;width:100%}
.service-hero .lead{color:var(--mute);font-size:17px;max-width:540px;margin:0}
@media(max-width:900px){.service-hero .container{grid-template-columns:1fr;gap:32px}}
.service-detail{padding:120px 0;background:#fff}
.service-detail-grid{display:grid;grid-template-columns:1fr 1.4fr;gap:80px;align-items:start}
.service-detail-grid aside{position:sticky;top:120px}
.service-detail-grid aside h4{font-family:'SF Mono',monospace;font-size:12px;color:var(--mute);text-transform:uppercase;letter-spacing:.06em;margin-bottom:12px}
.service-detail-grid aside ul{list-style:none;padding:0;margin:0 0 32px;display:flex;flex-direction:column;gap:8px}
.service-detail-grid aside li{color:var(--ink);font-size:15px;padding-left:20px;position:relative}
.service-detail-grid aside li::before{content:"→";position:absolute;left:0;color:var(--brand-accent);font-weight:700}
.service-detail-grid main h2{font-size:clamp(28px,3vw,44px);margin-bottom:20px}
.service-detail-grid main p{color:var(--mute);font-size:17px;line-height:1.7;margin-bottom:16px}
.service-detail-grid main ul{padding-left:22px;margin-bottom:20px}
.service-detail-grid main ul li{color:var(--ink);margin-bottom:8px}
@media(max-width:900px){.service-detail-grid{grid-template-columns:1fr;gap:40px}.service-detail-grid aside{position:static}}

/* ============== LOCATION-PAGE STYLES ============== */
.location-hero{padding:160px 0 64px;background:#fff;border-bottom:1px solid var(--line)}
.location-hero h1{font-size:clamp(44px,7vw,96px);line-height:.98;letter-spacing:-.025em;text-transform:uppercase;margin-bottom:18px}
.location-hero h1 .city{color:var(--brand-primary)}
.location-hero p{color:var(--mute);font-size:18px;max-width:600px}

/* ============== QUOTE FORM PAGE ============== */
.quote-section{padding:160px 0 120px;background:var(--soft);margin:0}
.quote-section h1{font-size:clamp(44px,7vw,84px);line-height:1;text-transform:uppercase;letter-spacing:-.025em;margin-bottom:18px}
.quote-grid{display:grid;grid-template-columns:1fr 1.2fr;gap:64px;align-items:start;max-width:1100px;margin:48px auto 0}
.quote-grid > div > p{color:var(--mute);font-size:17px;margin-bottom:24px}
@media(max-width:900px){.quote-grid{grid-template-columns:1fr;gap:32px}}

/* ============== FAQ HUB PAGE ============== */
.faq-hub{display:grid;grid-template-columns:240px 1fr;gap:64px;padding:160px 24px 96px;max-width:1200px;margin:0 auto}
.faq-toc{position:sticky;top:120px;align-self:start;font-family:'SF Mono','Menlo',monospace;font-size:13px}
.faq-toc h4{font-size:11px;text-transform:uppercase;letter-spacing:.08em;color:var(--mute);margin-bottom:14px}
.faq-toc ol{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:6px}
.faq-toc a{color:var(--ink);text-decoration:none;padding:6px 14px;display:block;border-left:2px solid transparent}
.faq-toc a:hover{color:var(--brand-primary);border-left-color:var(--brand-primary)}
.faq-hub-content > h1{font-size:clamp(36px,5vw,68px);line-height:1.05;text-transform:uppercase;letter-spacing:-.02em;margin-bottom:24px}
.faq-hub-content > .lead{color:var(--mute);font-size:17px;max-width:660px;margin-bottom:48px}
.faq-hub-content section{padding:48px 0;border-top:1px solid var(--line)}
.faq-hub-content section h2{font-size:clamp(26px,2.6vw,38px);margin-bottom:24px}
@media(max-width:900px){.faq-hub{grid-template-columns:1fr;gap:32px}.faq-toc{position:static}.faq-toc ol{flex-direction:row;flex-wrap:wrap;gap:8px}.faq-toc a{border-left:none;background:var(--soft);border-radius:9999px;padding:8px 14px}}
