
*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{margin:0;font-family:-apple-system,BlinkMacSystemFont,'Segoe UI',system-ui,Roboto,Helvetica,Arial,sans-serif;font-size:16px;line-height:1.6;color:#1a1a1a;background:#ffffff;-webkit-font-smoothing:antialiased}
img{max-width:100%;height:auto;display:block}
a{color:#0E5DAA;text-decoration:none}
a:hover{color:#062744}
h1,h2,h3,h4{font-family:-apple-system,BlinkMacSystemFont,'Segoe UI',system-ui,Roboto,Helvetica,Arial,sans-serif;font-weight:800;line-height:1.15;letter-spacing:-0.02em;color:#0a0a0a;margin:0 0 16px}
h1{font-size:clamp(40px,6vw,76px);font-weight:800;letter-spacing:-0.03em}
h2{font-size:clamp(30px,4vw,48px)}
h3{font-size:clamp(22px,2.4vw,28px)}
h4{font-size:18px;letter-spacing:-0.01em}
p{margin:0 0 16px}
.container{max-width:1240px;margin:0 auto;padding:0 24px}
.btn{display:inline-flex;align-items:center;gap:10px;padding:16px 28px;border-radius:999px;font-weight:600;font-size:15px;border:0;cursor:pointer;text-decoration:none;transition:transform .15s ease,background .2s ease,color .2s ease}
.btn-primary{background:#0a0a0a;color:#fff}
.btn-primary:hover{background:#0E5DAA;color:#fff;transform:translateY(-1px)}
.btn-secondary{background:#fff;color:#0a0a0a;border:1.5px solid rgba(10,10,10,.15)}
.btn-secondary:hover{background:#0a0a0a;color:#fff}
.btn-brand{background:#0E5DAA;color:#fff}
.btn-brand:hover{background:#062744;color:#fff}
.btn .arrow{display:inline-flex;align-items:center;justify-content:center;width:26px;height:26px;border-radius:50%;background:rgba(255,255,255,.15)}
.btn-secondary .arrow{background:rgba(10,10,10,.08)}
.kicker{display:inline-block;font-size:12px;font-weight:600;letter-spacing:.18em;text-transform:uppercase;color:#5b6470;margin-bottom:14px}

/* ────────  Header / Pill nav (G20, G36)  ──────── */
.site-header{position:fixed;top:18px;left:0;right:0;z-index:100;display:flex;justify-content:center;pointer-events:none}
.nav-pill{display:inline-flex;align-items:center;gap:32px;width:fit-content;margin:0 auto;padding:9px 9px 9px 22px;background:rgba(255,255,255,.78);backdrop-filter:saturate(180%) blur(16px);-webkit-backdrop-filter:saturate(180%) blur(16px);border:1px solid rgba(10,10,10,.06);border-radius:999px;box-shadow:0 4px 18px rgba(0,0,0,.05);pointer-events:auto}
.brand{display:inline-flex;align-items:center;gap:10px;color:#0a0a0a;font-weight:800;font-size:17px;letter-spacing:-.01em}
.brand img{width:32px;height:32px;object-fit:contain}
.brand .brand-name{display:inline-block}
.nav-links{display:flex;gap:22px;margin:0;padding:0;list-style:none}
.nav-links a{color:#0a0a0a;font-size:14px;font-weight:500;padding:8px 4px}
.nav-links a:hover{color:#0E5DAA}
.nav-cta{display:inline-flex;align-items:center;padding:11px 22px;border-radius:999px;background:#0a0a0a;color:#fff;font-weight:600;font-size:14px}
.nav-cta:hover{background:#0E5DAA;color:#fff}
.mobile-menu-toggle{display:inline-flex;align-items:center;justify-content:center;width:42px;height:42px;border-radius:999px;background:#0a0a0a;color:#fff;border:0;cursor:pointer;margin-left:8px}
.mobile-menu-toggle svg{width:20px;height:20px}

/* Mobile drawer */
.mobile-drawer{position:fixed;top:0;right:-340px;width:320px;max-width:90%;height:100vh;background:#0a0a0a;z-index:200;padding:80px 28px 28px;transition:right .35s cubic-bezier(.2,.8,.2,1);box-shadow:-12px 0 44px rgba(0,0,0,.25);overflow-y:auto}
.mobile-drawer.open{right:0}
.mobile-drawer .close{position:absolute;top:24px;right:24px;width:42px;height:42px;border-radius:50%;background:rgba(255,255,255,.1);border:0;color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center}
.mobile-drawer ul{list-style:none;padding:0;margin:0 0 32px}
.mobile-drawer li{border-bottom:1px solid rgba(255,255,255,.08)}
.mobile-drawer a{display:block;padding:16px 0;color:#fff;font-size:18px;font-weight:500}
.mobile-drawer a:hover{color:#F4B400}
.mobile-drawer .drawer-cta{margin-top:18px;display:block;text-align:center;padding:16px;background:#0E5DAA;color:#fff;border-radius:999px;font-weight:600}
.mobile-drawer .drawer-phone{display:flex;align-items:center;gap:10px;color:#fff;font-size:18px;font-weight:600;margin-top:24px;padding:16px;background:rgba(255,255,255,.05);border-radius:14px}
.drawer-overlay{position:fixed;inset:0;background:rgba(0,0,0,.5);z-index:150;opacity:0;pointer-events:none;transition:opacity .25s}
.drawer-overlay.open{opacity:1;pointer-events:auto}

/* ────────  Hero  ──────── */
.hero{position:relative;min-height:100vh;background:#0a0a0a;display:flex;align-items:flex-end;padding:160px 0 120px;overflow:hidden}
.hero-bg{position:absolute;inset:0;z-index:0}
.hero-bg img{width:100%;height:100%;object-fit:cover;opacity:.55}
.hero-bg::after{content:'';position:absolute;inset:0;background:linear-gradient(180deg,rgba(0,0,0,.2) 0%,rgba(0,0,0,.6) 70%,rgba(0,0,0,.85) 100%)}
.hero-inner{position:relative;z-index:2;width:100%}
.hero h1{color:#fff;max-width:880px}
.hero p.lead{color:rgba(255,255,255,.85);font-size:clamp(18px,2vw,22px);max-width:620px;margin:0 0 36px;line-height:1.5}
.hero-actions{display:flex;flex-wrap:wrap;gap:14px;align-items:center}
.hero-actions .btn-primary{background:#fff;color:#0a0a0a}
.hero-actions .btn-primary:hover{background:#0E5DAA;color:#fff}
.hero-actions .phone-link{display:inline-flex;align-items:center;gap:10px;color:#fff;font-weight:600;padding:14px 8px;font-size:15px}
.hero-actions .phone-link svg{width:18px;height:18px}
.hero-actions .phone-link:hover{color:#F4B400}
.hero-eyebrow{display:inline-flex;align-items:center;gap:10px;padding:8px 16px;border-radius:999px;background:rgba(255,255,255,.12);backdrop-filter:blur(10px);color:#fff;font-size:13px;font-weight:500;letter-spacing:.05em;margin-bottom:24px}
.hero-eyebrow .dot{width:8px;height:8px;border-radius:50%;background:#34d399;box-shadow:0 0 0 4px rgba(52,211,153,.25)}

/* ────────  Stats overlay (tradie5-style) ──────── */
.stats-section{background:#fff;padding:0;margin-top:-100px;position:relative;z-index:5}
.stats-card{background:#fff;border-radius:24px;padding:48px clamp(24px,4vw,64px);box-shadow:0 24px 60px rgba(0,0,0,.12);max-width:1180px;margin:0 auto}
.stats-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:32px}
.stat .num{font-size:clamp(34px,4.5vw,52px);font-weight:800;color:#0a0a0a;letter-spacing:-.03em;line-height:1;margin-bottom:8px}
.stat .label{font-size:13px;color:#5b6470;font-weight:500}

/* ────────  Section base  ──────── */
section{padding:96px 0}
.section-head{text-align:center;max-width:780px;margin:0 auto 56px}
.section-head h2{margin-bottom:16px}
.section-head p{color:#5b6470;font-size:18px}

/* ────────  Why us / feature grid  ──────── */
.why-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:24px}
.why-card{padding:32px 28px;background:#fafafa;border-radius:20px;transition:transform .2s,background .2s}
.why-card:hover{background:#0a0a0a;transform:translateY(-4px)}
.why-card:hover h4,.why-card:hover p{color:#fff}
.why-card .icon{width:56px;height:56px;border-radius:14px;background:#0E5DAA;color:#fff;display:flex;align-items:center;justify-content:center;margin-bottom:24px}
.why-card .icon svg{width:26px;height:26px;stroke:currentColor;fill:none;stroke-width:2}
.why-card h4{margin-bottom:8px;font-size:18px;font-weight:700}
.why-card p{color:#5b6470;font-size:14.5px;margin:0}

/* ────────  Services grid  ──────── */
.services-section{background:#f7f7f5}
.services-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.service-card{background:#fff;border-radius:18px;padding:32px;transition:transform .2s,box-shadow .2s;border:1px solid rgba(10,10,10,.04)}
.service-card:hover{transform:translateY(-4px);box-shadow:0 12px 32px rgba(0,0,0,.08)}
.service-card .num{display:inline-flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:50%;background:rgba(14,93,170,.08);color:#0E5DAA;font-weight:700;font-size:14px;margin-bottom:20px}
.service-card h3{font-size:21px;margin-bottom:10px}
.service-card p{color:#5b6470;font-size:14.5px;margin:0 0 22px}
.service-card .more{display:inline-flex;align-items:center;gap:6px;color:#0a0a0a;font-weight:600;font-size:14px}
.service-card .more svg{width:16px;height:16px;transition:transform .2s}
.service-card:hover .more svg{transform:translateX(3px)}

/* ────────  Process (3-photo row tradie5-style) ──────── */
.process-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}
.process-card{position:relative;border-radius:18px;overflow:hidden;aspect-ratio:3/4;background:#0E5DAA}
.process-card.has-photo{background:#1a1a1a}
.process-card .photo{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;opacity:.85}
.process-card .body{position:relative;z-index:2;height:100%;display:flex;flex-direction:column;justify-content:flex-end;padding:24px;color:#fff;background:linear-gradient(180deg,transparent 40%,rgba(0,0,0,.85) 100%)}
.process-card .step-num{font-size:13px;color:rgba(255,255,255,.7);margin-bottom:8px;font-weight:500;letter-spacing:.05em}
.process-card h4{color:#fff;margin-bottom:8px;font-size:20px}
.process-card p{color:rgba(255,255,255,.85);margin:0;font-size:13.5px;line-height:1.5}
.process-card.text-only .body{background:#0E5DAA;justify-content:center;padding:40px 28px}
.process-card.text-only h4{font-size:24px;margin-bottom:10px}
.process-card.text-only p{font-size:14px}

/* ────────  Reviews carousel (G4 Tier 1)  ──────── */
.gr-section{background:#0a0a0a;color:#fff;padding:96px 0;overflow:hidden}
.gr-section .section-head h2{color:#fff}
.gr-section .section-head p{color:rgba(255,255,255,.7)}
.gr-marquee{position:relative;overflow:hidden;mask-image:linear-gradient(90deg,transparent,#000 8%,#000 92%,transparent)}
.gr-track{display:flex;gap:18px;animation:gr-scroll 40s linear infinite}
.gr-track:hover{animation-play-state:paused}
.gr-marquee-reverse .gr-track{animation-direction:reverse;animation-duration:55s;margin-top:18px}
.gr-card{flex:0 0 380px;max-width:380px;padding:28px;background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.06);border-radius:20px;backdrop-filter:blur(8px)}
.gr-card .stars{color:#F4B400;font-size:16px;margin-bottom:16px;letter-spacing:2px}
.gr-card .text{color:rgba(255,255,255,.92);font-size:15px;line-height:1.6;margin:0 0 22px;font-style:italic}
.gr-card .meta{display:flex;align-items:center;gap:12px}
.gr-card .avatar{width:42px;height:42px;border-radius:50%;background:linear-gradient(135deg,#0E5DAA,#062744);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:15px}
.gr-card .meta-name{color:#fff;font-weight:600;font-size:14px;line-height:1.2}
.gr-card .meta-date{color:rgba(255,255,255,.55);font-size:12px}
@keyframes gr-scroll{0%{transform:translateX(0)}100%{transform:translateX(-50%)}}

.gr-aggregate-card{max-width:520px;margin:0 auto;text-align:center;padding:48px;background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.08);border-radius:24px}
.gr-aggregate-card .rating{font-size:60px;font-weight:800;color:#F4B400;line-height:1;margin-bottom:8px}
.gr-aggregate-card .stars{color:#F4B400;font-size:22px;letter-spacing:4px;margin-bottom:14px}
.gr-aggregate-card .count{color:rgba(255,255,255,.7);margin-bottom:28px;font-size:15px}

/* ────────  Service areas  ──────── */
.areas-section{background:#fff}
.areas-grid{columns:4;column-gap:32px;max-width:1100px;margin:0 auto}
.areas-grid .area{padding:8px 0;border-bottom:1px solid rgba(10,10,10,.06);font-size:14.5px;color:#1a1a1a;display:flex;align-items:center;gap:8px;break-inside:avoid}
.areas-grid .area::before{content:'';width:5px;height:5px;border-radius:50%;background:#0E5DAA;flex-shrink:0}

/* ────────  About preview / split  ──────── */
.about-preview{background:#fff;padding:96px 0}
.about-preview .grid{display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:center}
.about-preview .photo{aspect-ratio:4/5;border-radius:24px;overflow:hidden;background:#0a0a0a}
.about-preview .photo img{width:100%;height:100%;object-fit:cover}
.about-preview .content h2{margin-bottom:24px}
.about-preview .content p{color:#5b6470;font-size:17px;margin-bottom:22px}
.about-preview .content .signature{display:flex;gap:14px;align-items:center;margin-top:28px;padding:20px;background:#fafafa;border-radius:14px}
.about-preview .content .signature .avatar{width:52px;height:52px;border-radius:50%;background:linear-gradient(135deg,#0E5DAA,#062744);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:18px}
.about-preview .content .signature .label{font-size:12px;color:#5b6470;letter-spacing:.05em;margin-bottom:2px}
.about-preview .content .signature .name{font-weight:700;color:#0a0a0a}

/* ────────  Partners strip  ──────── */
.partners-section{padding:48px 0;background:#f7f7f5;border-top:1px solid rgba(10,10,10,.04);border-bottom:1px solid rgba(10,10,10,.04)}
.partners-strip{display:flex;justify-content:center;align-items:center;gap:48px;flex-wrap:wrap;opacity:.7}
.partners-strip img{height:42px;width:auto;object-fit:contain;filter:grayscale(1);transition:filter .2s,opacity .2s}
.partners-strip img:hover{filter:none}

/* ────────  CTA banner  ──────── */
.cta-banner{background:#0E5DAA;color:#fff;text-align:center;padding:80px 0}
.cta-banner h2{color:#fff;margin-bottom:14px}
.cta-banner p{color:rgba(255,255,255,.85);font-size:18px;margin-bottom:32px;max-width:620px;margin-left:auto;margin-right:auto}
.cta-banner .btn-primary{background:#fff;color:#0a0a0a}
.cta-banner .btn-primary:hover{background:#0a0a0a;color:#fff}

/* ────────  Footer  ──────── */
.site-footer{background:#0a0a0a;color:#fff;padding:80px 0 40px}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1.2fr;gap:48px;margin-bottom:64px}
.footer-grid h5{color:#fff;font-size:13px;letter-spacing:.18em;text-transform:uppercase;font-weight:600;margin-bottom:20px}
.footer-grid p,.footer-grid a,.footer-grid li{color:rgba(255,255,255,.65);font-size:14px;line-height:1.7}
.footer-grid a:hover{color:#fff}
.footer-grid ul{list-style:none;padding:0;margin:0}
.footer-grid li{margin-bottom:8px}
.footer-brand .logo-row{display:flex;align-items:center;gap:14px;margin-bottom:18px}
.footer-brand .logo-row img{width:48px;height:48px;object-fit:contain;background:#fff;padding:4px;border-radius:10px}
.footer-brand .name{color:#fff;font-weight:800;font-size:20px;letter-spacing:-.01em}
.footer-brand p{max-width:420px;margin-bottom:22px}
.footer-nap{font-style:normal}
.footer-nap .row{margin-bottom:10px;display:flex;align-items:flex-start;gap:10px}
.footer-nap svg{width:16px;height:16px;flex-shrink:0;color:#0E5DAA;margin-top:3px}
.footer-nap a{color:rgba(255,255,255,.85)}
.footer-nap a:hover{color:#fff}
.socials{display:flex;gap:10px;margin-top:18px}
.socials a{display:inline-flex;align-items:center;justify-content:center;width:38px;height:38px;border-radius:50%;background:rgba(255,255,255,.08);color:#fff;transition:background .2s}
.socials a:hover{background:#0E5DAA}
.socials svg{width:16px;height:16px}
.footer-bottom{display:flex;justify-content:space-between;align-items:center;padding-top:32px;border-top:1px solid rgba(255,255,255,.08);font-size:13px;color:rgba(255,255,255,.5);flex-wrap:wrap;gap:16px}
.footer-credit a{color:rgba(255,255,255,.85);font-weight:500}
.footer-credit a:hover{color:#0E5DAA}

/* ────────  Mobile sticky CTA (G8)  ──────── */
.mobile-cta{display:none;position:fixed;bottom:0;left:0;right:0;z-index:80}
.mobile-cta a{flex:1;display:flex;align-items:center;justify-content:center;gap:8px;padding:18px 12px;color:#fff;font-weight:700;font-size:15px}
.mobile-cta .call-btn{background:#0E5DAA}
.mobile-cta .msg-btn{background:#0a0a0a}
.mobile-cta svg{width:18px;height:18px}

/* ────────  Inner-page hero (about/contact/services etc)  ──────── */
.page-hero{background:#0a0a0a;color:#fff;padding:200px 0 96px;position:relative;overflow:hidden}
.page-hero::before{content:'';position:absolute;inset:0;background:radial-gradient(circle at 20% 100%,rgba(14,93,170,.4) 0%,transparent 50%)}
.page-hero .container{position:relative;z-index:2}
.page-hero .crumbs{font-size:12px;letter-spacing:.18em;text-transform:uppercase;color:rgba(255,255,255,.6);margin-bottom:18px}
.page-hero .crumbs a{color:rgba(255,255,255,.6)}
.page-hero .crumbs a:hover{color:#fff}
.page-hero h1{color:#fff;max-width:900px;font-size:clamp(36px,5vw,64px)}
.page-hero p.subtitle{color:rgba(255,255,255,.75);font-size:18px;max-width:680px;margin-top:20px}

/* ────────  Service-detail layout  ──────── */
.detail-section{background:#fff;padding:80px 0}
.detail-grid{display:grid;grid-template-columns:1fr 360px;gap:64px;align-items:start}
.detail-content h2{margin-bottom:24px;margin-top:0}
.detail-content h2:not(:first-child){margin-top:48px}
.detail-content p{color:#3a3f47;font-size:17px;line-height:1.7;margin-bottom:18px}
.detail-content ul{padding-left:0;list-style:none;margin:0 0 24px}
.detail-content li{padding:10px 0 10px 32px;position:relative;font-size:16px;color:#3a3f47}
.detail-content li::before{content:'';position:absolute;left:0;top:18px;width:18px;height:2px;background:#0E5DAA}
.detail-aside{position:sticky;top:120px;background:#fafafa;border-radius:20px;padding:32px}
.detail-aside h4{margin-bottom:16px;font-size:17px}
.detail-aside p{color:#5b6470;font-size:14.5px}
.detail-aside .btn{width:100%;justify-content:center}
.detail-aside .quick-call{display:flex;align-items:center;gap:12px;padding:16px;background:#fff;border-radius:14px;margin-bottom:18px;border:1px solid rgba(10,10,10,.06)}
.detail-aside .quick-call .icon{width:42px;height:42px;border-radius:50%;background:#0E5DAA;color:#fff;display:flex;align-items:center;justify-content:center}
.detail-aside .quick-call .icon svg{width:18px;height:18px}
.detail-aside .quick-call .label{font-size:12px;color:#5b6470;letter-spacing:.05em;margin-bottom:2px}
.detail-aside .quick-call .num{font-weight:700;color:#0a0a0a;font-size:17px}

/* ────────  FAQ <details>  ──────── */
.faq-list details{border-top:1px solid rgba(10,10,10,.08);padding:22px 0}
.faq-list details:last-child{border-bottom:1px solid rgba(10,10,10,.08)}
.faq-list summary{cursor:pointer;list-style:none;display:flex;justify-content:space-between;align-items:flex-start;gap:24px;font-size:18px;font-weight:600;color:#0a0a0a}
.faq-list summary::-webkit-details-marker{display:none}
.faq-list summary::after{content:'+';font-size:24px;color:#0E5DAA;font-weight:300;flex-shrink:0;transition:transform .2s}
.faq-list details[open] summary::after{transform:rotate(45deg)}
.faq-list details p{margin-top:14px;color:#5b6470;font-size:16px;line-height:1.65}

/* ────────  Contact form  ──────── */
.contact-grid{display:grid;grid-template-columns:1.1fr 1fr;gap:64px;align-items:start}
.contact-form{background:#fafafa;padding:36px;border-radius:20px}
.contact-form .row{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-bottom:14px}
.contact-form label{display:block;font-size:13px;font-weight:600;color:#0a0a0a;margin-bottom:6px}
.contact-form input,.contact-form textarea,.contact-form select{width:100%;padding:14px 16px;border-radius:12px;border:1px solid rgba(10,10,10,.1);background:#fff;font-family:inherit;font-size:15px;color:#0a0a0a;transition:border-color .2s}
.contact-form input:focus,.contact-form textarea:focus,.contact-form select:focus{outline:none;border-color:#0E5DAA;box-shadow:0 0 0 3px rgba(14,93,170,.1)}
.contact-form textarea{min-height:120px;resize:vertical}
.contact-form .form-row{margin-bottom:14px}
.contact-form .btn{width:100%;justify-content:center;margin-top:10px}
.contact-form .form-msg{margin-top:14px;padding:12px 16px;border-radius:10px;font-size:14px;display:none}
.contact-form .form-msg.ok{display:block;background:#dcfce7;color:#0f5132}
.contact-form .form-msg.err{display:block;background:#fef2f2;color:#991b1b}
.contact-info{display:flex;flex-direction:column;gap:18px}
.contact-info .row{display:flex;gap:16px;padding:22px;background:#fafafa;border-radius:16px}
.contact-info .icon{flex-shrink:0;width:46px;height:46px;border-radius:12px;background:#0E5DAA;color:#fff;display:flex;align-items:center;justify-content:center}
.contact-info .icon svg{width:20px;height:20px}
.contact-info .label{font-size:12px;color:#5b6470;letter-spacing:.06em;text-transform:uppercase;margin-bottom:4px}
.contact-info .val{color:#0a0a0a;font-weight:600;font-size:16px;line-height:1.4}
.contact-info .val a{color:#0a0a0a}
.contact-info .val a:hover{color:#0E5DAA}

/* ────────  Mobile (must come BEFORE desktop @media so cascade is correct, G17)  ──────── */
@media (max-width:1023px){
  .nav-pill{padding:8px 8px 8px 16px;gap:12px}
  .nav-links,.nav-cta{display:none}
  .brand .brand-name{font-size:15px}
  .stats-grid{grid-template-columns:repeat(2,1fr);gap:24px}
  .stats-card{padding:32px 24px}
  .why-grid{grid-template-columns:repeat(2,1fr)}
  .services-grid{grid-template-columns:1fr;gap:14px}
  .process-grid{grid-template-columns:1fr 1fr;gap:12px}
  .areas-grid{columns:2}
  .about-preview .grid{grid-template-columns:1fr;gap:48px}
  .about-preview .photo{aspect-ratio:4/3}
  .footer-grid{grid-template-columns:1fr 1fr;gap:36px}
  .footer-bottom{flex-direction:column;text-align:center}
  .gr-card{flex:0 0 290px;max-width:290px;padding:22px}
  .detail-grid{grid-template-columns:1fr;gap:32px}
  .detail-aside{position:static}
  .contact-grid{grid-template-columns:1fr;gap:32px}
  .contact-form .row{grid-template-columns:1fr}
  .mobile-cta{display:flex}
  body{padding-bottom:64px}
  section{padding:64px 0}
  .hero{padding:140px 0 100px;min-height:auto}
  .page-hero{padding:160px 0 64px}
}
@media (max-width:600px){
  .partners-strip{gap:24px}
  .partners-strip img{height:32px}
  .footer-grid{grid-template-columns:1fr;gap:32px}
  .areas-grid{columns:1}
  .stats-grid{grid-template-columns:1fr 1fr;gap:20px}
  .stats-card{padding:28px 20px}
  .why-grid{grid-template-columns:1fr}
  .services-grid{grid-template-columns:1fr}
  .process-grid{grid-template-columns:1fr;gap:14px}
  .process-card{aspect-ratio:16/10}
}

/* ────────  Desktop overrides (G17 — hamburger MUST be display:none here)  ──────── */
@media (min-width:1024px){
  .mobile-menu-toggle{display:none !important}
  .mobile-drawer{display:none}
  .mobile-cta{display:none !important}
}

/* ────────  Reduce motion / a11y  ──────── */
@media (prefers-reduced-motion:reduce){
  *{animation-duration:.01ms !important;transition-duration:.01ms !important}
  .gr-track{animation:none}
}
