/* ============================================
   OTM REMOVALS: V3 CONVERSION-OPTIMIZED
   Pure HTML/CSS. No frameworks
   ============================================ */
/* Fonts: Fraunces (headings) + Inter (body) loaded via <link> in HTML */

:root {
  /* Brand */
  --navy: #1A2B4A;
  --navy-light: #243756;
  --navy-dark: #111D33;
  --amber: #E8913A;
  --amber-hover: #D4822E;
  --amber-light: #F5A953;
  --amber-glow: rgba(232,145,58,0.15);
  /* Brand red sampled from the OTM van logo (public/images/on-the-move-removals-logo.png).
     Reserved for phone-related UI so "red" consistently means "call action."
     --red-bright is a slightly lifted shade used on dark backgrounds (top bar, hero
     phone link) so small text meets WCAG AA contrast (4.5:1). */
  --red: #F13029;
  --red-hover: #D62420;
  --red-bright: #FF5A4D;
  --teal: #2AA876;
  --teal-light: #D1FAE5;

  /* Neutrals */
  --white: #FEFDFB;
  --pure-white: #FFFFFF;
  --cream: #F9F7F4;
  --gray-50: #F4F2EF;
  --gray-100: #E8E5E0;
  --gray-200: #D1CEC8;
  --gray-400: #9B978F;
  --gray-500: #706C65;
  --gray-600: #524F49;
  --gray-700: #3D3A35;
  --gray-800: #292723;
  --text: #3D4555;
  --text-light: #6B7280;
  --heading: #1A2B4A;

  /* System */
  --font-body: 'Inter', system-ui, -apple-system, sans-serif;
  --font-display: 'Fraunces', Georgia, serif;
  --max-w: 1200px;
  --max-w-narrow: 720px;
  --radius: 10px;
  --radius-lg: 16px;
  --radius-xl: 24px;
  --radius-full: 9999px;
  --shadow-sm: 0 1px 3px rgba(26,43,74,0.06);
  --shadow: 0 4px 16px rgba(26,43,74,0.08);
  --shadow-lg: 0 12px 40px rgba(26,43,74,0.1);
  --shadow-xl: 0 24px 64px rgba(26,43,74,0.12);
  --ease: cubic-bezier(0.4,0,0.2,1);
}

/* Reset */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%;overflow-x:clip}
body{font-family:var(--font-body);color:var(--text);background:var(--white);line-height:1.65;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;overflow-x:clip}
a{text-decoration:none;color:inherit;transition:.3s var(--ease)}
ul,ol{list-style:none}
img{max-width:100%;height:auto;display:block}
button{cursor:pointer;font-family:inherit;border:none;background:none}
h1,h2,h3,h4,h5,h6{font-family:var(--font-display);color:var(--heading);line-height:1.15;font-weight:400;letter-spacing:-0.02em}

/* Utility */
.container{max-width:var(--max-w);margin:0 auto;padding:0 24px}
.accent{color:var(--amber)}
.sr-only{position:absolute;width:1px;height:1px;overflow:hidden;clip:rect(0,0,0,0)}
.desktop-only{display:inline}
@media (max-width:960px){.desktop-only{display:none}}

/* ============================================
   BUTTONS
   ============================================ */
.btn{display:inline-flex;align-items:center;gap:8px;font-family:var(--font-body);font-weight:600;font-size:15px;border-radius:var(--radius);transition:.3s var(--ease);cursor:pointer;border:none;text-align:center;justify-content:center}
.btn svg{width:16px;height:16px;fill:currentColor;flex-shrink:0}
.btn-amber{background:var(--amber);color:var(--white);padding:14px 28px;box-shadow:0 2px 12px rgba(232,145,58,0.3)}
.btn-amber:hover{background:var(--amber-hover);transform:translateY(-1px);box-shadow:0 4px 20px rgba(232,145,58,0.4)}
.btn-amber svg{transition:transform .2s var(--ease)}
.btn-amber:hover svg{transform:translateX(2px)}
/* WhatsApp-brand green, used exclusively for buttons linking to wa.me.
   Green is a platform colour here, not a brand colour — it tells users
   at a glance that the button opens WhatsApp. */
/* WhatsApp button: bright brand green (#25D366) with navy text. Navy on
   bright green gives ~9:1 contrast (well above WCAG AA 4.5:1) while
   preserving the full brand energy of the WhatsApp green that white text
   could not pass against. Modern dark-on-bright button pattern (Stripe,
   Linear). */
.btn-whatsapp{background:#25D366;color:var(--navy-dark);padding:14px 28px;box-shadow:0 2px 12px rgba(37,211,102,0.3)}
.btn-whatsapp:hover{background:#1FBE5A;transform:translateY(-1px);box-shadow:0 4px 20px rgba(37,211,102,0.4)}
.btn-whatsapp svg{transition:transform .2s var(--ease)}
.btn-whatsapp:hover svg{transform:translateX(2px)}
.btn-navy{background:var(--navy);color:var(--white);padding:14px 28px}
.btn-navy:hover{background:var(--navy-light);transform:translateY(-1px);box-shadow:var(--shadow)}
.btn-white{background:var(--white);color:var(--navy);padding:14px 28px;box-shadow:var(--shadow)}
.btn-white:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg)}
.btn-ghost{background:transparent;color:var(--white);padding:14px 28px;border:2px solid rgba(255,255,255,0.3)}
.btn-ghost:hover{border-color:var(--white);background:rgba(255,255,255,0.08)}
.btn-lg{padding:18px 36px;font-size:16px;border-radius:var(--radius-lg)}
.btn-sm{padding:10px 20px;font-size:14px}
.btn-pill{border-radius:var(--radius-full)}
/* Use .btn-solo on any standalone button (one that isn't inside .hero-btns,
   .cta-btns, .page-hero-btns, or similar pair-wrapper). On desktop the button
   keeps its natural inline-flex position. On mobile it becomes a centered
   block so a single button never sits awkwardly hugging the left edge. */
@media(max-width:1024px){
  .btn-solo{display:flex;width:fit-content;margin-left:auto;margin-right:auto}
}

/* ============================================
   MOBILE STICKY CTA
   ============================================ */
.mobile-cta{display:none;position:fixed;bottom:0;left:0;right:0;z-index:1000;background:var(--navy);padding:12px 16px;box-shadow:0 -4px 20px rgba(0,0,0,0.15)}
.mobile-cta-inner{display:flex;gap:10px}
.mobile-cta .btn{flex:1;font-size:14px;padding:14px 12px;border-radius:var(--radius);justify-content:center}
/* Asymmetric flex so the longer primary label ("WhatsApp Quote") gets more
   width than the shorter secondary ("Call Now"). Keeps both on one line at
   375px and above without shrinking typography or tap targets. */
.mobile-cta .btn-navy{flex:0.85;box-shadow:inset 0 0 0 1.5px rgba(255,255,255,0.45)}
.mobile-cta .btn-whatsapp{flex:1.15}

/* ============================================
   TOP BAR
   ============================================ */
.top-bar{background:var(--navy-dark);color:rgba(255,255,255,0.7);font-size:13px;padding:10px 0;font-weight:500}
.top-bar .container{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:8px}
.top-bar a{color:rgba(255,255,255,0.7)}
.top-bar a:hover{color:var(--amber-light)}
.top-bar-left{display:flex;gap:24px;align-items:center}
.top-bar-item{display:flex;align-items:center;gap:6px}
.top-bar-item svg{width:12px;height:12px;fill:var(--amber);flex-shrink:0}
.top-bar-right{display:flex;align-items:center;gap:12px}
.top-bar-stars{color:var(--amber);letter-spacing:1px}
.top-bar .btn{padding:8px 20px;font-size:13px;border-radius:var(--radius-full)}

/* ============================================
   HEADER
   ============================================ */
.header{background:var(--white);position:sticky;top:0;z-index:900;border-bottom:1px solid var(--gray-100)}
.header-inner{display:flex;align-items:center;justify-content:space-between;height:72px;padding:0 24px;max-width:var(--max-w);margin:0 auto}
.logo{margin-right:24px;transition:.2s var(--ease)}
.logo:hover{opacity:0.8}
.logo img{height:44px;width:auto}
.nav{display:flex;align-items:center;gap:2px;flex:1;justify-content:center}
.nav a{font-size:14px;font-weight:600;color:var(--text);padding:8px 10px;border-radius:var(--radius);transition:.2s var(--ease);white-space:nowrap;position:relative}
.nav a::after{content:'';position:absolute;bottom:0;left:50%;width:0;height:2px;background:var(--amber);transition:all .25s var(--ease);transform:translateX(-50%)}
.nav a:hover::after,.nav a.active::after{width:60%}
.nav a:hover{background:transparent;color:var(--navy)}
.nav-home{display:none}
.nav a.active{color:var(--amber);background:transparent}
.header-cta-desktop{display:inline-flex;margin-left:auto;flex-shrink:0}
.header-cta-desktop .btn{padding:9px 20px;font-size:13px;border-radius:var(--radius-full)}
.menu-toggle{display:none;width:40px;height:40px;align-items:center;justify-content:center;border-radius:var(--radius);transition:.2s}
.menu-toggle:hover{background:var(--cream)}
.menu-toggle span{display:block;width:20px;height:2px;background:var(--navy);position:relative;transition:.3s}
.menu-toggle span::before,.menu-toggle span::after{content:'';position:absolute;width:20px;height:2px;background:var(--navy);transition:.3s}
.menu-toggle span::before{top:-6px}
.menu-toggle span::after{top:6px}
.nav-dropdown{position:relative}
.nav-dropdown-trigger{display:inline-flex;align-items:center;gap:6px;font-family:inherit;font-size:14px;font-weight:600;color:var(--text);padding:8px 10px;border-radius:var(--radius);border:none;background:transparent;cursor:pointer;white-space:nowrap;position:relative;transition:.2s var(--ease)}
.nav-dropdown-trigger:hover{color:var(--navy)}
.nav-dropdown-trigger .nav-chevron{width:10px;height:10px;fill:currentColor;transition:transform .2s var(--ease)}
.nav-dropdown:hover .nav-chevron,.nav-dropdown.open .nav-chevron,.nav-dropdown:focus-within .nav-chevron{transform:rotate(180deg)}
.nav-dropdown-trigger::after{content:'';position:absolute;bottom:0;left:50%;width:0;height:2px;background:var(--amber);transition:all .25s var(--ease);transform:translateX(-50%)}
.nav-dropdown:hover .nav-dropdown-trigger::after,.nav-dropdown.active .nav-dropdown-trigger::after,.nav-dropdown:focus-within .nav-dropdown-trigger::after{width:60%}
.nav-dropdown.active .nav-dropdown-trigger{color:var(--amber)}
.nav-dropdown-menu{position:absolute;top:100%;left:50%;transform:translateX(-50%);min-width:210px;background:var(--white);border:1px solid var(--gray-100);border-radius:var(--radius);box-shadow:var(--shadow-lg);padding:8px;display:none;flex-direction:column;gap:2px;z-index:1000}
.nav-dropdown:hover .nav-dropdown-menu,.nav-dropdown:focus-within .nav-dropdown-menu,.nav-dropdown.open .nav-dropdown-menu{display:flex}
.nav-dropdown-menu a{padding:10px 14px;font-size:14px;font-weight:600;color:var(--text);border-radius:var(--radius);white-space:nowrap;width:100%;display:block}
.nav-dropdown-menu a::after{display:none}
.nav-dropdown-menu a:hover{background:var(--cream);color:var(--navy)}
.nav-dropdown-menu a.active{color:var(--amber);background:var(--amber-glow)}
/* Services dropdown with icons */
.nav-dropdown-menu-icons{min-width:240px;padding:10px}
.nav-dropdown-menu-icons .nav-dropdown-link{display:flex;align-items:center;gap:12px;padding:10px 12px;font-size:14px;font-weight:600;color:var(--text);border-radius:var(--radius);width:100%;text-decoration:none;transition:.15s var(--ease)}
.nav-dropdown-menu-icons .nav-dropdown-link::after{display:none}
.nav-dropdown-menu-icons .nav-dropdown-link:hover{background:var(--cream);color:var(--navy)}
.nav-dropdown-menu-icons .nav-dropdown-link:hover .nav-dropdown-icon{background:var(--amber-glow)}
.nav-dropdown-menu-icons .nav-dropdown-link:hover .nav-dropdown-icon svg{fill:var(--amber)}
.nav-dropdown-menu-icons .nav-dropdown-link.active{color:var(--amber);background:var(--amber-glow)}
.nav-dropdown-menu-icons .nav-dropdown-link.active .nav-dropdown-icon{background:var(--amber)}
.nav-dropdown-menu-icons .nav-dropdown-link.active .nav-dropdown-icon svg{fill:var(--white)}
.nav-dropdown-icon{flex-shrink:0;width:32px;height:32px;border-radius:8px;background:var(--cream);display:inline-flex;align-items:center;justify-content:center;transition:.15s var(--ease)}
.nav-dropdown-icon svg{width:15px;height:15px;fill:var(--navy);transition:.15s var(--ease)}
.nav-dropdown-label{display:inline-block}
/* Areas dropdown with regional grouping */
.nav-dropdown-menu-areas{min-width:240px;padding:12px;gap:4px}
.nav-dropdown-group{display:flex;flex-direction:column;gap:1px;margin-bottom:8px}
.nav-dropdown-group:last-of-type{margin-bottom:0}
.nav-dropdown-group-label{font-size:10px;font-weight:700;color:var(--amber);text-transform:uppercase;letter-spacing:0.08em;padding:6px 12px 4px}
.nav-dropdown-menu-areas .nav-dropdown-link{display:block;padding:8px 12px;font-size:14px;font-weight:600;color:var(--text);border-radius:var(--radius);text-decoration:none;transition:.15s var(--ease)}
.nav-dropdown-menu-areas .nav-dropdown-link::after{display:none}
.nav-dropdown-menu-areas .nav-dropdown-link:hover{background:var(--cream);color:var(--navy)}
.nav-dropdown-menu-areas .nav-dropdown-link.active{color:var(--amber);background:var(--amber-glow)}
.nav-dropdown-divider{height:1px;background:var(--gray-100);margin:6px 8px}
.nav-dropdown-link-wide{color:var(--amber) !important;font-weight:700 !important}
.nav-dropdown-link-wide:hover{background:var(--amber-glow) !important}

/* ============================================
   HERO: Angled split layout
   ============================================ */
.hero{position:relative;overflow:hidden;background:var(--navy);min-height:600px;display:flex;align-items:center}
.hero-bg{position:absolute;inset:0;clip-path:polygon(55% 0,100% 0,100% 100%,45% 100%)}
.hero-bg img{width:100%;height:100%;object-fit:cover}
.hero-gradient{position:absolute;inset:0;background:linear-gradient(90deg,var(--navy) 0%,var(--navy) 48%,rgba(26,43,74,0.4) 58%,transparent 70%);z-index:1}
.hero .container{position:relative;z-index:2;display:grid;grid-template-columns:1.15fr 0.85fr;gap:60px;align-items:center;padding-top:80px;padding-bottom:80px}
.hero-badge{display:inline-flex;align-items:center;gap:8px;background:rgba(42,168,118,0.15);border:1px solid rgba(42,168,118,0.25);color:var(--teal);padding:8px 16px;border-radius:var(--radius-full);font-size:13px;font-weight:600;margin-bottom:20px}
.hero-badge svg{width:14px;height:14px;fill:currentColor}
.hero-business-name{display:block;font-size:clamp(38px, 5vw, 56px);color:var(--amber-light);letter-spacing:-0.04em;margin-bottom:4px}
.hero h1{font-size:clamp(30px, 4vw, 44px);color:var(--white);margin-bottom:20px;letter-spacing:-0.03em}
.hero h1 .accent{color:var(--amber-light)}
.hero-sub{font-size:18px;color:rgba(255,255,255,0.7);line-height:1.7;margin-bottom:32px;max-width:500px;text-wrap:pretty}
.hero-btns{display:flex;gap:12px;margin-bottom:48px}
.hero-btns>.btn,.page-hero-btns>.btn,.cta-btns>.btn{white-space:nowrap}
.phone-link{color:var(--red);font-weight:700;text-decoration:none;white-space:nowrap}
.phone-link:hover{text-decoration:underline}
.hero .phone-link,.cta .phone-link{color:var(--red)}
/* Top-bar phone link: icon + text red to mirror the van's phone-number livery.
   Location pin stays amber (informational, not an action). */
a.top-bar-item[href^="tel"]{color:var(--red-bright);font-weight:600}
a.top-bar-item[href^="tel"] svg{fill:var(--red-bright)}
.top-bar a[href^="tel"]:hover{color:var(--red)}
.hero-proof{display:flex;gap:40px;padding-top:32px}
.hero-proof-item{display:flex;gap:12px;align-items:center}
.hero-proof-icon{width:44px;height:44px;border-radius:50%;background:rgba(232,145,58,0.12);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.hero-proof-icon svg{width:18px;height:18px;fill:var(--amber-light)}
.hero-proof-text{font-size:13px;color:rgba(255,255,255,0.55);line-height:1.4}
.hero-proof-text strong{color:var(--white);display:block;font-weight:700;font-family:var(--font-body)}
.hero-visual{position:relative}
.hero-img{border-radius:var(--radius-xl);overflow:hidden;box-shadow:var(--shadow-xl);border:4px solid rgba(255,255,255,0.1)}
.hero-img img{width:100%;display:block}
.hero-float{position:absolute;bottom:-20px;left:-20px;background:var(--white);border-radius:var(--radius-lg);padding:16px 20px;box-shadow:var(--shadow-lg);display:flex;align-items:center;gap:12px}
.hero-float-number{font-family:var(--font-display);font-size:36px;color:var(--amber);line-height:1}
.hero-float-text{font-size:12px;color:var(--text-light);line-height:1.3}
.hero-float-text strong{color:var(--navy);display:block;font-size:14px}
.hero-mini-review{position:absolute;bottom:40px;right:0;background:var(--white);border-radius:var(--radius-lg);padding:20px 24px;box-shadow:var(--shadow-xl);max-width:320px;z-index:3}
.hero-mini-review-stars{color:var(--amber);font-size:14px;letter-spacing:1px;margin-bottom:6px}
.hero-mini-review p{font-size:13px;line-height:1.6;color:var(--text);font-style:italic;margin-bottom:10px}
.hero-mini-review-author{display:flex;align-items:center;gap:8px}
.hero-mini-review-author img{width:32px;height:32px;border-radius:50%;object-fit:cover}
.hero-mini-review-author span{font-size:12px;font-weight:600;color:var(--navy)}
.hero-mini-review-author small{font-size:11px;color:var(--text-light)}
.hero-photo-mobile{display:none}

/* ============================================
   PAGE HERO (Service Pages)
   ============================================ */
.page-hero{background:var(--cream);padding:64px 0 80px;position:relative;overflow:hidden}
.page-hero::after{content:'';position:absolute;top:-200px;right:-200px;width:600px;height:600px;background:radial-gradient(circle,var(--amber-glow) 0%,transparent 70%);border-radius:50%;pointer-events:none}
.page-hero-grid{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center}
.page-hero-content .section-label{margin-bottom:12px}
.page-hero-content h1{font-size:clamp(28px, 4vw, 46px);margin-bottom:20px}
.page-hero-text{font-size:16px;line-height:1.7;color:var(--text);margin-bottom:8px}
.page-hero-text:last-of-type{margin-bottom:28px}
.page-hero-btns{display:flex;gap:12px}
.page-hero-img{border-radius:var(--radius-xl);overflow:hidden;box-shadow:var(--shadow-xl)}
.page-hero-img img{width:100%;max-height:500px;object-fit:cover;object-position:center;display:block}

/* ============================================
   SECTIONS
   ============================================ */
.section{position:relative}
.s-pad{padding:100px 0}
.s-pad-lg{padding:120px 0}
.s-pad-md{padding:80px 0}
.s-pad-sm{padding:60px 0}
.bg-cream{background:var(--cream)}
.bg-white{background:var(--white)}
.bg-navy{background:var(--navy);color:var(--white)}
/* Amber section uses navy text (not white) so contrast passes WCAG AA.
   Navy on amber gives ~7.5:1 vs white on amber which fails at ~2.4:1. */
.bg-amber{background:var(--amber);color:var(--navy-dark)}

/* Angled section dividers - subtle 15px diagonal slope */
.angle-bottom{position:relative;z-index:2}
.angle-bottom::after{content:'';position:absolute;bottom:-14px;left:0;right:0;height:16px;z-index:3;clip-path:polygon(0 0, 50% 100%, 100% 0)}
.bg-white.angle-bottom::after{background:var(--white)}
.bg-cream.angle-bottom::after{background:var(--cream)}
.bg-navy.angle-bottom::after{background:var(--navy)}
.bg-amber.angle-bottom::after{background:var(--amber)}
.stats.angle-bottom::after{background:var(--navy)}

/* Section Header */
.s-header{margin-bottom:56px}
.s-header.centered{text-align:center;max-width:620px;margin-left:auto;margin-right:auto}
.section-label{display:inline-flex;align-items:center;gap:6px;font-family:var(--font-body);font-size:13px;font-weight:700;text-transform:uppercase;letter-spacing:0.12em;color:var(--amber);margin-bottom:14px}
.section-label::before{content:'';width:20px;height:2px;background:var(--amber);display:inline-block}
.bg-navy .section-label{color:var(--amber-light)}
.bg-navy .section-label::before{background:var(--amber-light)}
.bg-amber .section-label{color:var(--navy-dark);opacity:0.85}
.bg-amber .section-label::before{background:rgba(17,29,51,0.5)}
.s-title{font-size:clamp(28px, 3.5vw, 44px);margin-bottom:16px}
.bg-navy .s-title{color:var(--white)}
.bg-amber .s-title{color:var(--navy-dark)}
.s-subtitle{font-size:17px;line-height:1.7;color:var(--text-light);max-width:540px}
.s-header.centered .s-subtitle{margin:0 auto}
.bg-navy .s-subtitle{color:rgba(255,255,255,0.6)}
.bg-amber .s-subtitle{color:rgba(17,29,51,0.8)}

/* ============================================
   TRUST BADGE STRIP
   ============================================ */
.trust-strip{background:var(--white);border-bottom:1px solid var(--gray-100);padding:18px 0}
.trust-strip .container{display:flex;justify-content:center;align-items:center;gap:40px;flex-wrap:wrap}
.trust-strip-item{display:flex;align-items:center;gap:10px;font-size:13px;font-weight:600;color:var(--navy);white-space:nowrap}
.trust-strip-icon{width:40px;height:40px;border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.trust-strip-icon.google{background:#F1F3F4}
.trust-strip-icon.insured{background:var(--teal-light)}
.trust-strip-icon.award{background:var(--amber-glow)}
.trust-strip-icon.est{background:rgba(26,43,74,0.08)}
.trust-strip-icon svg{width:18px;height:18px}
.trust-strip-icon.google svg{fill:#FBBC04}
.trust-strip-icon.insured svg{fill:var(--teal)}
.trust-strip-icon.award svg{fill:var(--amber)}
.trust-strip-icon.est svg{fill:var(--navy)}
.trust-strip-text{line-height:1.3}
.trust-strip-text span{display:block;font-size:11px;font-weight:400;color:var(--text-light)}
.trust-strip-divider{width:1px;height:32px;background:var(--gray-100)}
@media (max-width:960px){
  .trust-strip{padding:14px 0}
  .trust-strip .container{display:grid;grid-template-columns:1fr 1fr;gap:10px 16px}
  .trust-strip-item{width:100%;font-size:12px;gap:8px;white-space:normal;line-height:1.2}
  .trust-strip-icon{width:32px;height:32px}
  .trust-strip-icon svg{width:14px;height:14px}
  .trust-strip-text span{font-size:10px}
  .trust-strip-divider{display:none}
}
@media (max-width:339.98px){
  .trust-strip .container{grid-template-columns:1fr;gap:10px}
}

/* ============================================
   SERVICE CARDS
   ============================================ */
.services-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.services-grid-4{display:grid;grid-template-columns:repeat(2,1fr);gap:24px}
.svc-card{background:var(--white);border:1px solid var(--gray-100);border-radius:var(--radius-lg);padding:32px;transition:.35s var(--ease);position:relative;display:flex;flex-direction:column}
.svc-card::after{content:'';position:absolute;bottom:0;left:24px;right:24px;height:3px;background:var(--amber);border-radius:0 0 var(--radius-lg) var(--radius-lg);opacity:0;transition:.35s var(--ease)}
.svc-card:hover{transform:translateY(-6px);box-shadow:var(--shadow-lg);border-color:transparent}
.svc-card:hover::after{opacity:1}
.svc-icon{width:48px;height:48px;border-radius:var(--radius);background:var(--amber-glow);display:flex;align-items:center;justify-content:center;margin-bottom:20px}
.svc-icon svg{width:22px;height:22px;fill:var(--amber)}
.svc-card h3{font-family:var(--font-body);font-size:18px;font-weight:700;color:var(--navy);margin-bottom:8px}
.svc-card p{font-size:14px;line-height:1.6;color:var(--text-light);margin-bottom:20px;flex:1}
.svc-link{font-size:14px;font-weight:600;color:var(--amber);display:inline-flex;align-items:center;gap:6px}
.svc-link svg{width:14px;height:14px;fill:currentColor;transition:.2s var(--ease)}
.svc-card:hover .svc-link svg{transform:translateX(4px)}

/* ============================================
   WHY CHOOSE US / BENEFITS
   ============================================ */
.benefits-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:32px}
.benefit{text-align:center;padding:40px 24px}
.benefit-icon{width:64px;height:64px;border-radius:50%;background:var(--amber-glow);display:flex;align-items:center;justify-content:center;margin:0 auto 20px}
.benefit-icon svg{width:28px;height:28px;fill:var(--amber)}
.benefit h3{font-family:var(--font-body);font-size:18px;font-weight:700;color:var(--navy);margin-bottom:8px}
.benefit p{font-size:14px;line-height:1.7;color:var(--text-light)}

/* ============================================
   TRUST / ABOUT
   ============================================ */
.trust-grid{display:grid;grid-template-columns:1.1fr 0.9fr;gap:60px;align-items:center}
.trust-content .s-title{font-size:clamp(26px, 3.2vw, 40px)}
.trust-content>p{font-size:16px;line-height:1.8;margin-bottom:24px}
.trust-list{display:flex;flex-direction:column;gap:16px;margin-bottom:32px}
.trust-item{display:flex;gap:14px;align-items:flex-start}
.trust-check{width:28px;height:28px;border-radius:50%;background:var(--teal-light);display:flex;align-items:center;justify-content:center;flex-shrink:0;margin-top:2px}
.trust-check svg{width:14px;height:14px;fill:var(--teal)}
.trust-item-text{font-size:15px;line-height:1.6}
.trust-item-text strong{color:var(--navy);display:block;margin-bottom:2px}
.trust-visual{position:relative}
.trust-visual img{border-radius:var(--radius-xl);box-shadow:var(--shadow-xl);width:100%;max-height:520px;object-fit:cover;object-position:center}
.trust-badge{position:absolute;bottom:24px;left:24px;background:var(--white);border-radius:var(--radius-lg);padding:16px 20px;box-shadow:var(--shadow-lg);display:flex;align-items:center;gap:12px}
.trust-badge-num{font-family:var(--font-display);font-size:40px;color:var(--amber);line-height:1}
.trust-badge-text{font-size:12px;color:var(--text-light);line-height:1.3}
.trust-badge-text strong{color:var(--navy);display:block;font-size:14px;font-family:var(--font-body);font-weight:700}

/* ============================================
   STATS
   ============================================ */
.stats{background:var(--navy);padding:56px 0}
.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:32px;text-align:center}
.stat{position:relative}
.stat+.stat::before{content:'';position:absolute;left:-16px;top:10%;height:80%;width:1px;background:rgba(255,255,255,0.08)}
.stat-num{font-family:var(--font-display);font-size:48px;color:var(--amber-light);line-height:1;margin-bottom:4px}
.stat-label{font-size:14px;color:rgba(255,255,255,0.5);font-weight:500}

/* ============================================
   PROCESS / HOW IT WORKS
   ============================================ */
.process-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:32px;position:relative;counter-reset:step}
.process-grid::before{content:'';position:absolute;top:44px;left:calc(16.67% + 12px);right:calc(16.67% + 12px);height:2px;background:rgba(255,255,255,0.1)}
.bg-amber .process-grid::before{background:rgba(17,29,51,0.18)}
.step{text-align:center;position:relative;z-index:2;counter-increment:step}
.step-num{width:88px;height:88px;border-radius:50%;background:rgba(255,255,255,0.08);border:2px solid rgba(255,255,255,0.15);display:flex;align-items:center;justify-content:center;margin:0 auto 24px;font-family:var(--font-display);font-size:32px;color:var(--amber-light)}
.bg-amber .step-num{background:rgba(17,29,51,0.12);border-color:rgba(17,29,51,0.25);color:var(--navy-dark)}
.step h3{font-family:var(--font-body);font-size:18px;font-weight:700;margin-bottom:8px}
.bg-navy .step h3{color:var(--white)}
.bg-amber .step h3{color:var(--navy-dark)}
.step p{font-size:14px;line-height:1.7;max-width:280px;margin:0 auto}
.bg-navy .step p{color:rgba(255,255,255,0.55)}
.bg-amber .step p{color:rgba(17,29,51,0.8)}

/* ============================================
   REVIEWS
   ============================================ */
.reviews-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.reviews-more{text-align:center;margin:28px 0 0;font-weight:600}
.reviews-more a{color:var(--navy);text-decoration:none;border-bottom:2px solid var(--amber);padding-bottom:2px;transition:.2s var(--ease)}
.reviews-more a:hover{color:var(--amber)}

/* Customer themes: themed verbatim-quote cards organised by behaviour
   (punctuality, quote-honesty, no-drama, lovely lads). Replaces the
   generic 6-card review grid on the homepage with a structure that pairs
   each customer-language behaviour with 3 supporting verbatim quotes. */
.customer-themes{display:grid;grid-template-columns:repeat(2,1fr);gap:28px;max-width:1100px;margin:0 auto}
.theme-card{background:var(--white);border-radius:var(--radius-lg);padding:32px;box-shadow:var(--shadow);display:flex;flex-direction:column;gap:14px;transition:.2s var(--ease)}
.theme-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg)}
.theme-card h3{font-family:var(--font-display);font-size:22px;font-weight:600;color:var(--navy);margin:0 0 8px;line-height:1.3}
.theme-card blockquote{margin:0;padding:0 0 0 16px;border-left:3px solid var(--amber);font-style:italic;color:var(--text);font-size:14px;line-height:1.6}
.theme-card cite{display:block;font-style:normal;font-size:12px;color:var(--text-light);margin-top:6px;font-weight:600;letter-spacing:0.02em}
@media(max-width:1024px){
  .customer-themes{grid-template-columns:1fr;gap:18px;max-width:560px}
  .theme-card{padding:24px}
  .theme-card h3{font-size:20px}
}
.cross-links{background:var(--cream);padding:48px 0;border-top:1px solid var(--gray-100)}
.cross-links h2{font-family:var(--font-display);font-size:22px;font-weight:600;color:var(--navy);margin-bottom:20px;text-align:center}
.cross-links ul{list-style:none;padding:0;margin:0;display:flex;flex-wrap:wrap;gap:10px 14px;justify-content:center}
.cross-links li a{display:inline-block;padding:10px 18px;background:var(--white);color:var(--navy);border:1px solid var(--gray-100);border-radius:var(--radius-full);font-size:14px;font-weight:500;text-decoration:none;transition:.2s var(--ease)}
.cross-links li a:hover{border-color:var(--amber);color:var(--amber);transform:translateY(-1px)}
.rev-card{background:var(--white);border:1px solid var(--gray-100);border-radius:var(--radius-lg);padding:32px;transition:.3s var(--ease)}
.rev-card:hover{box-shadow:0 14px 30px rgba(26,43,74,0.08);border-color:var(--amber);transform:translateY(-2px)}
.rev-stars{color:var(--amber);font-size:16px;letter-spacing:2px;margin-bottom:16px}
.rev-text{font-size:15px;line-height:1.7;color:var(--text);margin-bottom:24px;font-style:italic}
.rev-footer{display:flex;align-items:center;gap:12px;padding-top:16px;border-top:1px solid var(--gray-100)}
.rev-footer img{width:44px;height:44px;border-radius:50%;object-fit:cover}
.rev-name{font-family:var(--font-body);font-weight:700;font-size:14px;color:var(--navy)}
.rev-source{font-size:12px;color:var(--text-light)}

/* Carousel variant for subpages */
.reviews-scroll{display:flex;gap:24px;overflow-x:auto;scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch;scrollbar-width:none;padding-bottom:4px}
.reviews-scroll::-webkit-scrollbar{display:none}
.reviews-scroll .rev-card{flex:0 0 360px;scroll-snap-align:start}

/* ============================================
   CTA
   ============================================ */
.cta{background:var(--navy);padding:80px 0;position:relative;overflow:hidden}
.cta::before{content:'';position:absolute;top:-100px;right:-80px;width:400px;height:400px;background:radial-gradient(circle,rgba(232,145,58,0.1) 0%,transparent 70%);border-radius:50%}
.cta-inner{text-align:center;position:relative;z-index:2;max-width:600px;margin:0 auto}
.cta-inner h2{font-size:42px;color:var(--white);margin-bottom:16px}
.cta-inner h2 .accent{color:var(--amber-light)}
.cta-inner p{font-size:18px;color:rgba(255,255,255,0.6);margin-bottom:36px;line-height:1.7}
.cta-btns{display:flex;justify-content:center;gap:12px}
.cta-note{margin-top:16px;font-size:13px;color:rgba(255,255,255,0.4)}

/* ============================================
   AWARDS
   ============================================ */
.awards-marquee{
  overflow:hidden;
  width:100%;
  position:relative;
  -webkit-mask-image:linear-gradient(to right, transparent 0, #000 8%, #000 92%, transparent 100%);
          mask-image:linear-gradient(to right, transparent 0, #000 8%, #000 92%, transparent 100%);
}
.awards-track{
  display:flex;
  align-items:center;
  width:max-content;
  animation:awards-scroll 30s linear infinite;
}
.awards-track .award-icon{
  flex:0 0 auto;
  width:200px;
  height:auto;
  margin:0 5rem;
  object-fit:contain;
}
.awards-marquee:hover .awards-track{animation-play-state:paused}
@keyframes awards-scroll{
  from{transform:translateX(0)}
  to{transform:translateX(-50%)}
}
@media (prefers-reduced-motion: reduce){
  .awards-track{animation:none}
}

/* ============================================
   WHAT'S INCLUDED
   ============================================ */
.included-grid{display:grid;grid-template-columns:1.1fr 0.9fr;gap:60px;align-items:center}
.inc-list ul{list-style:none;padding:0}
.inc-list li{display:flex;gap:12px;padding:13px 0;border-bottom:1px solid var(--gray-100);font-size:15px;line-height:1.5;align-items:flex-start}
.inc-list li:last-child{border-bottom:none}
.inc-check{width:22px;height:22px;border-radius:50%;background:var(--teal-light);display:flex;align-items:center;justify-content:center;flex-shrink:0;margin-top:2px}
.inc-check svg{width:11px;height:11px;fill:var(--teal)}
.inc-img{border-radius:var(--radius-xl);overflow:hidden;box-shadow:var(--shadow-lg)}
.inc-img img{width:100%;max-height:480px;object-fit:cover;object-position:center;display:block}

/* ============================================
   AREAS
   ============================================ */
.area-tags{display:flex;flex-wrap:wrap;gap:10px;justify-content:center;margin-top:24px}
.area-tag{background:var(--white);border:1px solid var(--gray-100);padding:10px 22px;border-radius:var(--radius-full);font-size:14px;font-weight:500;color:var(--navy);transition:.2s var(--ease)}
.area-tag:hover{border-color:var(--amber);color:var(--amber)}

/* ============================================
   DISCLAIMER
   ============================================ */
.disclaimer{background:var(--gray-50);border-top:1px solid var(--gray-100);border-bottom:1px solid var(--gray-100);padding:16px 0;text-align:center}
.disclaimer p{font-size:13px;color:var(--gray-500);font-style:italic}

/* ============================================
   FAQ
   ============================================ */
.faq-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.faq-card{background:var(--white);border:1px solid var(--gray-100);border-radius:var(--radius);overflow:hidden;transition:.2s var(--ease)}
.faq-card:hover{border-color:var(--amber)}
.faq-card[open]{border-color:var(--amber);box-shadow:0 2px 12px rgba(232,145,58,0.08)}
.faq-card summary{padding:18px 20px;font-family:var(--font-body);font-size:15px;font-weight:600;color:var(--navy);cursor:pointer;list-style:none;display:flex;justify-content:space-between;align-items:center;gap:12px}
.faq-card summary::-webkit-details-marker{display:none}
.faq-card summary::after{content:'+';font-size:18px;font-weight:400;width:28px;height:28px;display:flex;align-items:center;justify-content:center;border-radius:50%;background:var(--amber-glow);color:var(--amber);flex-shrink:0;transition:.2s var(--ease)}
.faq-card[open] summary::after{content:'\2212';background:var(--amber);color:var(--white)}
.faq-answer{padding:0 20px 18px;font-size:15px;line-height:1.7;color:var(--text)}
.faq-single{max-width:var(--max-w-narrow);margin:0 auto}
.faq-single .faq-card{margin-bottom:12px}

/* ============================================
   LOCAL GRID
   ============================================ */
.local-grid{display:grid;grid-template-columns:1fr 1fr;gap:24px}
.local-card{background:var(--white);border:1px solid var(--gray-100);border-radius:var(--radius-lg);padding:40px}
.local-card h3{font-family:var(--font-body);font-size:20px;font-weight:700;color:var(--navy);margin-bottom:10px}
.local-card p{font-size:15px;line-height:1.7;color:var(--text-light)}

/* ============================================
   GALLERY
   ============================================ */
/* Filter tabs */
.gallery-filters{display:flex;justify-content:center;gap:8px;margin-bottom:40px;flex-wrap:wrap}
@media (max-width:960px){
  .gallery-filters{flex-wrap:nowrap;overflow-x:auto;overflow-y:hidden;justify-content:flex-start;scrollbar-width:none;-ms-overflow-style:none;-webkit-overflow-scrolling:touch;padding-bottom:4px}
  .gallery-filters::-webkit-scrollbar{display:none}
  .gallery-filter{flex-shrink:0}
}
.gallery-filter{padding:10px 24px;border-radius:var(--radius-full);font-size:14px;font-weight:600;color:var(--text);background:var(--white);border:1px solid var(--gray-100);cursor:pointer;transition:.2s var(--ease);font-family:var(--font-body)}
.gallery-filter:hover{border-color:var(--amber);color:var(--amber)}
.gallery-filter.active{background:var(--navy);color:var(--white);border-color:var(--navy)}
/* Photo count badge */
.gallery-count{text-align:center;margin-bottom:32px;font-size:13px;color:var(--text-light);font-weight:500}
.gallery-count strong{color:var(--navy)}
/* Masonry grid */
.gallery-grid{display:grid;grid-template-columns:repeat(3,1fr);grid-auto-rows:200px;gap:12px}
.gallery-item{border-radius:var(--radius);overflow:hidden;position:relative;cursor:pointer;transition:opacity .35s var(--ease),transform .35s var(--ease)}
.gallery-item img{width:100%;height:100%;object-fit:cover;transition:transform .5s var(--ease)}
.gallery-item:hover img{transform:scale(1.05)}
/* Hover overlay with caption */
.gallery-item::after{content:attr(data-caption);position:absolute;inset:0;background:linear-gradient(to top,rgba(26,43,74,0.75) 0%,rgba(26,43,74,0.15) 40%,transparent 100%);opacity:0;transition:.3s var(--ease);display:flex;align-items:flex-end;padding:16px;font-size:13px;font-weight:500;color:var(--white);letter-spacing:0.02em}
.gallery-item:hover::after{opacity:1}
/* Masonry spans - hero + tall items */
.gallery-hero{grid-column:span 2;grid-row:span 2}
.gallery-tall{grid-row:span 2}
/* Filter animation */
.gallery-item.hidden{display:none}

/* Contact page */
.contact-methods{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.contact-method{display:flex;flex-direction:column;background:var(--white);border:1px solid var(--gray-100);border-radius:var(--radius-lg);padding:36px 28px;text-decoration:none;color:inherit;transition:.2s var(--ease);text-align:left}
.contact-method:hover{border-color:var(--amber);box-shadow:0 20px 50px rgba(26,43,74,0.08);transform:translateY(-3px)}
.contact-method--primary{border-color:var(--amber);background:var(--amber-glow)}
.contact-method-icon{width:56px;height:56px;border-radius:50%;display:flex;align-items:center;justify-content:center;margin-bottom:18px}
.contact-method-icon svg{width:24px;height:24px}
.contact-method-wa{background:#25D36615;color:#25D366}
.contact-method-wa svg{fill:#25D366}
.contact-method-phone{background:var(--amber-glow);color:var(--amber)}
.contact-method-phone svg{fill:var(--amber)}
.contact-method-email{background:var(--teal-light);color:var(--teal)}
.contact-method-email svg{fill:var(--teal)}
.contact-method h2{font-family:var(--font-display);font-size:24px;color:var(--navy);line-height:1.15;margin:0 0 4px}
.contact-method-tag{font-size:12px;font-weight:600;color:var(--amber);text-transform:uppercase;letter-spacing:0.08em;margin:0 0 14px}
.contact-method p{color:var(--text);font-size:15px;line-height:1.55;margin:0 0 20px;flex:1}
.contact-method-link{font-weight:600;color:var(--amber);font-size:14px;letter-spacing:0.02em;margin-top:auto}
.contact-method:hover .contact-method-link{text-decoration:underline}
.contact-map-grid{display:grid;grid-template-columns:1fr 1.3fr;gap:48px;align-items:center}
.contact-map-info h2{margin-bottom:16px}
.contact-address{font-style:normal;margin-top:24px;line-height:1.7;color:var(--navy);font-size:16px}
.contact-map-embed{border-radius:var(--radius-lg);overflow:hidden;box-shadow:0 20px 50px rgba(26,43,74,0.08);aspect-ratio:4/3}
.contact-map-embed iframe{width:100%;height:100%;border:0;display:block}
@media (max-width:960px){
  .contact-methods{grid-template-columns:1fr;gap:16px}
  .contact-map-grid{grid-template-columns:1fr;gap:28px}
  .contact-method{padding:28px 22px}
}
.gallery-item.fading{opacity:0;transform:scale(0.95)}

/* ============================================
   MOVING TIPS (blog): index cards + article
   ============================================ */
.tip-featured{display:grid;grid-template-columns:1.1fr 1fr;gap:32px;align-items:center;background:var(--white);border:1px solid var(--gray-100);border-radius:var(--radius-lg);overflow:hidden;margin-bottom:48px;text-decoration:none;color:inherit;transition:.25s var(--ease)}
.tip-featured:hover{border-color:var(--amber);box-shadow:0 20px 50px rgba(26,43,74,0.08);transform:translateY(-2px)}
.tip-featured-img{height:100%;overflow:hidden}
.tip-featured-img img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .45s var(--ease)}
.tip-featured:hover .tip-featured-img img{transform:scale(1.03)}
.tip-featured-body{padding:40px}
.tip-featured-body h2{font-family:var(--font-display);font-size:30px;color:var(--navy);line-height:1.15;margin:10px 0 12px}
.tip-featured-body p{color:var(--text);line-height:1.6;margin-bottom:16px}
.tip-featured-link{font-weight:600;color:var(--amber);font-size:14px;letter-spacing:0.02em}
.tip-card-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.tip-card{display:flex;flex-direction:column;background:var(--white);border:1px solid var(--gray-100);border-radius:var(--radius);overflow:hidden;text-decoration:none;color:inherit;transition:.2s var(--ease)}
.tip-card:hover{border-color:var(--amber);box-shadow:0 18px 36px rgba(26,43,74,0.09);transform:translateY(-3px)}
.tip-card.hidden,.tip-card-grid .tip-card.hidden,.tip-card-grid.single .tip-card.hidden,.tip-featured.hidden{display:none}
.tip-card-img{aspect-ratio:16/10;overflow:hidden;background:var(--cream)}
.tip-card-img img{width:100%;height:100%;object-fit:cover;object-position:center top;display:block;transition:transform .45s var(--ease)}
.tip-card:hover .tip-card-img img{transform:scale(1.04)}
.tip-card-body{padding:22px;display:flex;flex-direction:column;gap:10px;flex:1}
.tip-card-meta{font-size:12px;font-weight:600;color:var(--amber);text-transform:uppercase;letter-spacing:0.08em;display:flex;gap:8px;align-items:center}
.tip-card-meta time{color:var(--gray-400);text-transform:none;letter-spacing:0}
.tip-card-body h3{font-family:var(--font-display);font-size:20px;color:var(--navy);line-height:1.25;margin:0}
.tip-card-body p{font-size:14px;color:var(--text);line-height:1.55;margin:0}
.tip-card-grid.single{display:block}
.tip-card-grid.single .tip-card{display:grid;grid-template-columns:1.1fr 1fr;gap:32px;align-items:center;border-radius:var(--radius-lg)}
.tip-card-grid.single .tip-card-img{aspect-ratio:auto;height:100%;overflow:hidden;position:static}
.tip-card-grid.single .tip-card-img img{position:static;inset:auto;width:100%;height:100%;object-fit:cover;display:block}
.tip-card-grid.single .tip-card-body{padding:40px;display:block}
.tip-card-grid.single .tip-card-body h3{font-family:var(--font-display);font-size:30px;color:var(--navy);line-height:1.15;margin:10px 0 12px}
.tip-card-grid.single .tip-card-body p{color:var(--text);font-size:15px;line-height:1.6;margin-bottom:16px}
.tip-card-grid.single .tip-card-body::after{content:"Read the guide \2192";font-weight:600;color:var(--amber);font-size:14px;letter-spacing:0.02em}

.tip-pagination{margin-top:48px;padding-top:32px;border-top:1px solid var(--gray-100);display:flex;align-items:center;justify-content:space-between;gap:16px;flex-wrap:wrap}
.tip-pagination-info{font-size:14px;color:var(--text-light);font-weight:500}
.tip-pagination-prev,.tip-pagination-next{white-space:nowrap}
.tip-pagination .btn-navy{padding:12px 22px;font-size:14px}
@media (max-width:640px){
  .tip-pagination{flex-direction:column;align-items:stretch;text-align:center}
  .tip-pagination .btn{width:100%}
}

.tip-article{background:var(--white)}
.tip-article-header{background:var(--navy);color:var(--white);padding:56px 0 96px;position:relative;overflow:hidden}
.tip-article-header::after{content:'';position:absolute;left:0;right:0;bottom:-1px;height:64px;background:var(--white);clip-path:polygon(0 100%,100% 40%,100% 100%)}
.tip-article-header .container{position:relative;z-index:1;max-width:820px}
.tip-article-header .section-label{color:var(--amber)}
.tip-article-header h1{font-family:var(--font-display);font-size:42px;line-height:1.15;color:var(--white);margin:12px 0 16px;max-width:740px}
.breadcrumbs{display:flex;gap:8px;font-size:13px;color:rgba(255,255,255,0.7);margin-bottom:18px;flex-wrap:wrap}
.breadcrumbs a{color:rgba(255,255,255,0.85);text-decoration:none;transition:.2s var(--ease)}
.breadcrumbs a:hover{color:var(--amber)}
.breadcrumbs .breadcrumb-current{color:var(--amber)}
.tip-article-meta{display:flex;gap:10px;font-size:14px;color:rgba(255,255,255,0.8);flex-wrap:wrap;align-items:center}
.tip-article-hero{margin-top:-64px;margin-bottom:40px;position:relative;z-index:2}
.tip-article-hero .container{max-width:960px}
.tip-article-hero img{width:100%;height:auto;aspect-ratio:4/3;object-fit:cover;object-position:center top;border-radius:var(--radius-lg);box-shadow:0 24px 60px rgba(26,43,74,0.18);display:block}
.tip-article-body{max-width:760px;padding-bottom:80px}
.prose{font-family:var(--font-body);color:var(--text);line-height:1.75;font-size:17px}
.prose > *+*{margin-top:20px}
.prose h2{font-family:var(--font-display);font-size:28px;color:var(--navy);line-height:1.25;margin-top:48px}
.prose h3{font-family:var(--font-display);font-size:22px;color:var(--navy);line-height:1.3;margin-top:36px}
.prose p{color:var(--text)}
.prose ul,.prose ol{padding-left:24px}
.prose li{margin-top:8px}
.prose li::marker{color:var(--amber)}
.prose a{color:var(--amber);font-weight:600;text-decoration:underline;text-decoration-thickness:1px;text-underline-offset:3px;transition:.2s var(--ease)}
.prose a:hover{color:var(--navy)}
.prose strong{color:var(--navy)}
.prose blockquote{border-left:3px solid var(--amber);padding:4px 20px;margin:28px 0;color:var(--navy);font-style:italic;background:var(--amber-glow)}
.prose hr{border:none;border-top:1px solid var(--gray-100);margin:48px 0}
.prose code{background:var(--cream);padding:2px 6px;border-radius:4px;font-size:15px}

.tip-article-faqs{margin-top:56px}
.tip-article-faqs h2{font-family:var(--font-display);font-size:26px;color:var(--navy);margin-bottom:20px}
.tip-article-cta{margin-top:56px;padding:28px 32px;background:var(--cream);border-radius:var(--radius-lg);display:flex;justify-content:space-between;align-items:center;gap:24px;flex-wrap:wrap}
.tip-article-cta h3{font-family:var(--font-display);font-size:22px;color:var(--navy);margin-bottom:4px}
.tip-article-cta p{color:var(--text);font-size:14px}
.tip-article-cta-btns{display:flex;gap:10px;flex-wrap:wrap}
.tip-article-related{margin-top:64px}
.tip-article-related h2{font-family:var(--font-display);font-size:26px;color:var(--navy);margin-bottom:20px}
.tip-article-related .tip-card-grid{grid-template-columns:repeat(2,1fr)}

@media (max-width:960px){
  .tip-featured{grid-template-columns:1fr}
  .tip-featured-img{aspect-ratio:16/10}
  .tip-featured-body{padding:28px}
  .tip-card-grid{grid-template-columns:repeat(2,1fr)}
  .tip-card-grid.single{display:grid;grid-template-columns:1fr;gap:24px}
  .tip-card-grid.single .tip-card{display:flex;flex-direction:column;grid-template-columns:none;gap:0;border-radius:var(--radius)}
  .tip-card-grid.single .tip-card-img{position:static;aspect-ratio:16/10;height:auto;min-height:0}
  .tip-card-grid.single .tip-card-img img{position:static;inset:auto;width:100%;height:100%;object-fit:cover}
  .tip-card-grid.single .tip-card-body{padding:28px;display:block}
  .tip-card-grid.single .tip-card-body h3{font-family:var(--font-display);font-size:30px;color:var(--navy);line-height:1.15;margin:10px 0 12px}
  .tip-card-grid.single .tip-card-body p{color:var(--text);font-size:15px;line-height:1.6;margin-bottom:16px}
  .tip-card-grid.single .tip-card-body::after{content:"Read the guide \2192";font-weight:600;color:var(--amber);font-size:14px;letter-spacing:0.02em}
  .tip-article-related .tip-card-grid{grid-template-columns:1fr}
  .tip-article-header{padding:40px 0 80px}
  .tip-article-header h1{font-size:30px}
  .tip-article-hero{margin-top:-48px}
  .prose{font-size:16px}
  .prose h2{font-size:24px}
  .prose h3{font-size:20px}
}
@media (max-width:640px){
  .tip-card-grid{grid-template-columns:1fr}
  .tip-card-grid .tip-card-body{padding:28px;gap:12px}
  .tip-card-grid .tip-card-body h3{font-size:30px;line-height:1.15}
  .tip-card-grid .tip-card-body p{font-size:15px;line-height:1.6}
  .tip-article-cta{flex-direction:column;align-items:flex-start}
}
/* Lightbox */
.lightbox{position:fixed;inset:0;z-index:2000;background:rgba(17,24,39,0.92);display:none;align-items:center;justify-content:center;padding:24px;cursor:zoom-out}
.lightbox.open{display:flex}
.lightbox img{max-width:90vw;max-height:85vh;object-fit:contain;border-radius:var(--radius-lg);box-shadow:var(--shadow-xl)}
.lightbox-close{position:absolute;top:20px;right:24px;width:44px;height:44px;border-radius:50%;background:rgba(255,255,255,0.1);border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:.2s var(--ease)}
.lightbox-close:hover{background:rgba(255,255,255,0.2)}
.lightbox-close svg{width:20px;height:20px;fill:var(--white)}
/* Inline CTA banner after gallery */
.gallery-cta{background:var(--cream);border-radius:var(--radius-lg);padding:40px 48px;margin-top:48px;display:flex;align-items:center;justify-content:space-between;gap:32px;flex-wrap:wrap}
.gallery-cta-text h3{font-family:var(--font-display);font-size:24px;color:var(--navy);margin-bottom:6px}
.gallery-cta-text p{font-size:15px;color:var(--text-light);line-height:1.6}
.gallery-cta-btns{display:flex;gap:12px;flex-shrink:0;flex-wrap:wrap}

/* ============================================
   ABOUT PAGE
   ============================================ */
.about-intro{display:grid;grid-template-columns:1fr 1fr;gap:56px;align-items:center}
.about-intro-img{border-radius:var(--radius-lg);overflow:hidden;box-shadow:0 20px 50px rgba(26,43,74,0.12)}
.about-intro-img img{width:100%;height:auto;display:block}
.about-intro-body .section-label{margin-bottom:12px}
.about-intro-body h2{font-family:var(--font-display);font-size:36px;color:var(--navy);line-height:1.15;margin-bottom:20px}
.about-intro-body p{color:var(--text);font-size:16px;line-height:1.7;margin-bottom:16px}
.about-intro-body .btn{margin-top:12px}
.about-values{display:grid;grid-template-columns:repeat(3,1fr);gap:28px;margin-top:48px}
.about-value{background:var(--white);border:1px solid var(--gray-100);border-radius:var(--radius-lg);padding:36px 28px;transition:.25s var(--ease)}
.about-value:hover{border-color:var(--amber);box-shadow:0 14px 30px rgba(26,43,74,0.08);transform:translateY(-2px)}
.about-value-icon{width:52px;height:52px;border-radius:14px;background:var(--cream);display:flex;align-items:center;justify-content:center;margin-bottom:20px}
.about-value-icon svg{width:22px;height:22px;fill:var(--amber)}
.about-value h3{font-family:var(--font-display);font-size:22px;color:var(--navy);line-height:1.2;margin-bottom:10px}
.about-value p{color:var(--text);font-size:15px;line-height:1.65;margin:0}
.about-team-hero{border-radius:var(--radius-lg);overflow:hidden;margin-bottom:48px;box-shadow:0 20px 50px rgba(26,43,74,0.1)}
.about-team-hero img{width:100%;height:auto;display:block;aspect-ratio:16/9;object-fit:cover}
.about-team-intro{max-width:760px;margin:0 auto;text-align:center}
.about-team-intro .section-label{margin-bottom:12px}
.about-team-intro h2{font-family:var(--font-display);font-size:36px;color:var(--navy);line-height:1.15;margin-bottom:20px}
.about-team-intro p{color:var(--text);font-size:16px;line-height:1.7;margin-bottom:14px}
.about-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:24px;text-align:center}
.about-stat{background:var(--white);border:1px solid var(--gray-100);border-radius:var(--radius-lg);padding:36px 20px}
.about-stat-num{font-family:var(--font-display);font-size:44px;font-weight:700;color:var(--navy);line-height:1;margin-bottom:8px}
.about-stat-label{font-size:13px;font-weight:600;color:var(--text-light);text-transform:uppercase;letter-spacing:0.06em}
@media (max-width:960px){
  .about-intro{grid-template-columns:1fr;gap:32px}
  .about-intro-body h2{font-size:28px}
  .about-values{grid-template-columns:repeat(2,1fr);gap:20px;margin-top:32px}
  .about-value{padding:28px 22px}
  .about-team-intro h2{font-size:28px}
  .about-stats{grid-template-columns:repeat(2,1fr);gap:16px}
  .about-stat{padding:24px 16px}
  .about-stat-num{font-size:36px}
}
@media (max-width:640px){
  .about-values{grid-template-columns:1fr}
}

/* ============================================
   404 PAGE
   ============================================ */
.error-page{min-height:60vh;display:flex;align-items:center;padding:80px 0;background:var(--cream)}
.error-page-inner{max-width:620px;margin:0 auto;text-align:center}
.error-page-num{font-family:var(--font-display);font-size:120px;font-weight:700;color:var(--navy);line-height:1;margin-bottom:8px}
.error-page h1{font-family:var(--font-display);font-size:36px;color:var(--navy);line-height:1.15;margin-bottom:16px}
.error-page p{color:var(--text);font-size:16px;line-height:1.7;margin-bottom:24px}
.error-page-btns{display:flex;gap:12px;justify-content:center;flex-wrap:wrap;margin-top:28px}
.error-page-links{margin-top:40px;padding-top:32px;border-top:1px solid var(--gray-100)}
.error-page-links h3{font-family:var(--font-display);font-size:18px;color:var(--navy);margin-bottom:14px}
.error-page-links-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:10px}
.error-page-links-grid a{color:var(--text);font-size:14px;text-decoration:none;padding:10px 14px;border-radius:var(--radius);background:var(--white);border:1px solid var(--gray-100);transition:.2s var(--ease)}
.error-page-links-grid a:hover{border-color:var(--amber);color:var(--navy)}
@media (max-width:640px){
  .error-page-num{font-size:80px}
  .error-page h1{font-size:26px}
  .error-page-links-grid{grid-template-columns:repeat(2,1fr)}
}

/* ============================================
   COOKIE BANNER
   ============================================ */
.cookie-banner{position:fixed;left:16px;right:16px;bottom:16px;z-index:3000;background:var(--navy-dark);color:rgba(255,255,255,0.9);border-radius:var(--radius-lg);padding:20px 24px;box-shadow:0 20px 60px rgba(17,24,39,0.35);display:none;align-items:center;gap:20px;max-width:820px;margin:0 auto;flex-wrap:wrap}
.cookie-banner.show{display:flex}
.cookie-banner p{font-size:14px;line-height:1.55;flex:1;min-width:240px;margin:0}
.cookie-banner a{color:var(--amber-light);text-decoration:underline}
.cookie-banner-btns{display:flex;gap:8px;flex-shrink:0;flex-wrap:wrap}
.cookie-btn{font-family:var(--font-body);font-size:13px;font-weight:600;padding:10px 18px;border-radius:999px;border:none;cursor:pointer;transition:.2s var(--ease);white-space:nowrap}
.cookie-btn-accept{background:var(--amber);color:var(--navy-dark)}
.cookie-btn-accept:hover{background:var(--amber-light)}
.cookie-btn-reject{background:transparent;color:rgba(255,255,255,0.85);border:1px solid rgba(255,255,255,0.25)}
.cookie-btn-reject:hover{background:rgba(255,255,255,0.08)}
@media (max-width:640px){
  .cookie-banner{flex-direction:column;align-items:stretch;text-align:left;padding:18px 20px}
  .cookie-banner-btns{justify-content:stretch}
  .cookie-btn{flex:1}
}

/* ============================================
   LEGAL
   ============================================ */
.legal{max-width:var(--max-w-narrow);margin:0 auto}
.legal h1{font-size:40px;margin-bottom:8px}
.legal-date{font-size:14px;color:var(--text-light);margin-bottom:40px}
.legal h2{font-family:var(--font-body);font-size:20px;font-weight:700;color:var(--navy);margin-top:40px;margin-bottom:12px}
.legal p{font-size:15px;line-height:1.8;margin-bottom:14px}
.legal ul{list-style:disc;padding-left:24px;margin-bottom:14px}
.legal li{font-size:15px;line-height:1.8;margin-bottom:4px}

/* ============================================
   ANSWER SNAPSHOT
   ============================================ */
.answer-snapshot{background:var(--white);padding:28px 0;border-top:1px solid var(--gray-100);border-bottom:1px solid var(--gray-100)}
.answer-snapshot-inner{display:grid;grid-template-columns:minmax(0,1.35fr) minmax(280px,0.65fr);gap:32px;align-items:start;padding:26px 30px;background:var(--cream);border:1px solid var(--gray-100);border-radius:var(--radius-lg)}
.answer-snapshot-copy h2{font-family:var(--font-body);font-size:24px;line-height:1.25;margin:0 0 10px;color:var(--navy);letter-spacing:0}
.answer-snapshot-copy p{font-size:16px;line-height:1.75;margin:0;color:var(--text)}
.answer-snapshot-facts{display:grid;grid-template-columns:1fr;gap:10px;margin:0}
.answer-snapshot-facts div{padding:12px 14px;background:var(--white);border:1px solid var(--gray-100);border-radius:var(--radius)}
.answer-snapshot-facts dt{font-size:12px;text-transform:uppercase;letter-spacing:.06em;font-weight:700;color:var(--text-light);margin-bottom:4px}
.answer-snapshot-facts dd{font-size:15px;font-weight:700;color:var(--navy);margin:0;line-height:1.35}

/* ============================================
   FOOTER
   ============================================ */
.footer{background:var(--navy-dark);color:rgba(255,255,255,0.6);padding:80px 0 0}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:48px;margin-bottom:56px}
.footer-brand img{max-width:160px;margin-bottom:16px}
.footer-brand>p{font-size:14px;line-height:1.8;margin-bottom:16px;color:rgba(255,255,255,0.6)}
.footer-contact{display:flex;align-items:center;gap:8px;font-size:14px;margin-bottom:8px}
.footer-contact svg{width:13px;height:13px;fill:var(--amber);flex-shrink:0}
.footer-contact a{color:rgba(255,255,255,0.6)}
.footer-contact a:hover{color:var(--amber-light)}
.footer-col h3{color:var(--white);font-family:var(--font-body);font-size:14px;font-weight:700;text-transform:uppercase;letter-spacing:0.08em;margin-bottom:20px}
.footer-col a{display:block;font-size:14px;color:rgba(255,255,255,0.6);padding:4px 0;transition:.2s var(--ease)}
.footer-col a:hover{color:var(--amber-light);transform:translateX(3px)}
.footer-bottom{border-top:1px solid rgba(255,255,255,0.06);padding:24px 0;display:flex;justify-content:space-between;align-items:center}
.footer-bottom p{font-size:13px;color:rgba(255,255,255,0.6)}
.btt{width:40px;height:40px;border-radius:50%;background:rgba(255,255,255,0.06);display:flex;align-items:center;justify-content:center;transition:.2s var(--ease)}
.btt:hover{background:var(--amber);color:var(--white)}
.btt svg{width:14px;height:14px;fill:currentColor;color:rgba(255,255,255,0.4)}
.btt:hover svg{fill:var(--white);color:var(--white)}

/* ============================================
   NOISE OVERLAY
   ============================================ */
.noise-overlay{position:absolute;inset:0;z-index:1;opacity:0.035;pointer-events:none;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E")}

/* ============================================
   DECORATIVE ACCENTS
   ============================================ */
.deco-dots{position:absolute;width:120px;height:120px;background-image:radial-gradient(circle,var(--amber) 1.5px,transparent 1.5px);background-size:16px 16px;opacity:0.08;pointer-events:none;z-index:0}
.deco-line{position:absolute;width:60px;height:3px;background:var(--amber);opacity:0.15;pointer-events:none;border-radius:2px;z-index:0}

/* ============================================
   ACCESSIBILITY
   ============================================ */
:focus-visible{outline:2px solid var(--amber);outline-offset:3px;border-radius:4px;box-shadow:0 0 0 5px rgba(232,145,58,0.18)}
.sr-only:focus{position:static;width:auto;height:auto;overflow:visible;clip:auto}
a:focus-visible{outline:2px solid var(--amber);outline-offset:2px}
button:focus-visible{outline:2px solid var(--amber);outline-offset:2px}
/* Amber outline would be invisible on amber buttons themselves, so give
   them a navy ring instead for contrast. WhatsApp-green buttons work fine
   with amber (complementary colours). */
.btn-amber:focus-visible,a.btn-amber:focus-visible{outline-color:var(--navy);box-shadow:0 0 0 5px rgba(26,43,74,0.2)}

/* ============================================
   SEMANTIC ELEMENTS
   ============================================ */
figure{margin:0}
figcaption{font-size:13px;color:var(--text-light);margin-top:8px;font-style:italic}
address{font-style:normal}

/* ============================================
   SCROLL REVEAL ANIMATIONS
   ============================================ */
.reveal{opacity:0;transform:translateY(24px);transition:opacity 0.6s var(--ease),transform 0.6s var(--ease)}
.reveal.visible{opacity:1;transform:translateY(0)}
.reveal-left{opacity:0;transform:translateX(-24px);transition:opacity 0.6s var(--ease),transform 0.6s var(--ease)}
.reveal-left.visible{opacity:1;transform:translateX(0)}
.reveal-right{opacity:0;transform:translateX(24px);transition:opacity 0.6s var(--ease),transform 0.6s var(--ease)}
.reveal-right.visible{opacity:1;transform:translateX(0)}
.reveal-delay-1{transition-delay:0.1s}
.reveal-delay-2{transition-delay:0.2s}
.reveal-delay-3{transition-delay:0.3s}
.reveal-delay-4{transition-delay:0.4s}
.reveal-delay-5{transition-delay:0.5s}

/* ============================================
   GOOGLE MAP FOOTER
   ============================================ */
.footer-map{margin-bottom:48px;border-radius:var(--radius-lg);overflow:hidden;border:1px solid rgba(255,255,255,0.06)}
.footer-map iframe{width:100%;height:240px;border:none;filter:brightness(0.85) contrast(1.1);transition:.3s var(--ease)}
.footer-map iframe:hover{filter:brightness(1)}
.footer-google-link{display:inline-flex;align-items:center;gap:8px;margin-top:16px;padding:8px 16px;background:rgba(255,255,255,0.06);border-radius:var(--radius-full);font-size:13px;color:rgba(255,255,255,0.6);transition:.2s var(--ease)}
.footer-google-link:hover{background:rgba(255,255,255,0.1);color:var(--amber-light)}
.footer-google-link svg{width:14px;height:14px;fill:currentColor}

/* ============================================
   FLOATING BACK TO TOP
   ============================================ */
.scroll-top{position:fixed;bottom:96px;right:28px;z-index:801;width:44px;height:44px;border-radius:50%;background:var(--navy);display:flex;align-items:center;justify-content:center;box-shadow:0 4px 16px rgba(26,43,74,0.25);transition:.3s var(--ease);opacity:0;visibility:hidden;transform:translateY(12px);cursor:pointer;border:none}
.scroll-top.visible{opacity:1;visibility:visible;transform:translateY(0)}
.scroll-top:hover{background:var(--amber);box-shadow:0 4px 20px rgba(232,145,58,0.35);transform:translateY(-2px)}
.scroll-top svg{width:16px;height:16px;fill:var(--white)}

/* ============================================
   WHATSAPP FLOAT
   ============================================ */
.wa-float{position:fixed;bottom:24px;right:24px;z-index:800;width:60px;height:60px;border-radius:50%;background:#25D366;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 20px rgba(37,211,102,0.4);transition:.3s var(--ease)}
/* On mobile the sticky bottom bar already carries the WhatsApp CTA,
   so the float is redundant visual clutter. Keep it on desktop where
   the sticky bar is hidden. */
@media(max-width:1024px){.wa-float{display:none}}
.wa-float:hover{transform:scale(1.1);box-shadow:0 6px 28px rgba(37,211,102,0.5)}
.wa-float svg{width:28px;height:28px;fill:var(--white)}

/* ============================================
   RESPONSIVE
   ============================================ */
@media(max-width:1024px){
  .services-grid,.reviews-grid,.benefits-grid{grid-template-columns:repeat(2,1fr)}
  .footer-grid{grid-template-columns:1fr 1fr;gap:32px}
  .hero .container{grid-template-columns:1fr}
  .hero-visual{display:none}
  .hero-mini-review{display:none}
  .hero-bg{clip-path:none}
  .hero-bg img{opacity:0.45}
  .hero-gradient{background:linear-gradient(180deg,rgba(26,43,74,0.9) 0%,rgba(26,43,74,0.6) 100%)}
  .hero-photo-mobile{display:block;position:relative;z-index:2;margin:20px 0 24px;border-radius:var(--radius-lg);overflow:hidden;box-shadow:0 10px 30px rgba(0,0,0,0.25)}
  .hero-photo-mobile img{width:100%;aspect-ratio:16/10;object-fit:cover;display:block;opacity:1}
}
@media(max-width:768px){
  .top-bar{padding:8px 0}
  .top-bar .container{justify-content:center}
  .top-bar-left{justify-content:center;gap:0}
  .top-bar-left > :not(a){display:none}
  .top-bar-right{display:none}
  .nav{display:none;position:absolute;top:72px;left:0;right:0;background:var(--white);border-top:1px solid var(--gray-100);box-shadow:var(--shadow-lg);flex-direction:column;padding:12px;z-index:999}
  .nav.open{display:flex}
  .nav a{padding:12px 16px;width:100%;border-radius:0;border-bottom:1px solid var(--gray-50)}
  .nav .nav-home{display:block}
  .nav-dropdown{width:100%}
  .nav-dropdown-trigger{display:flex;width:100%;justify-content:space-between;padding:12px 16px;border-bottom:1px solid var(--gray-50);border-radius:0}
  .nav-dropdown-trigger::after{display:none}
  .nav-dropdown-menu{position:static;transform:none;display:none;box-shadow:none;border:none;border-bottom:1px solid var(--gray-50);border-radius:0;padding:4px 0;background:var(--cream);min-width:0}
  .nav-dropdown:hover .nav-dropdown-menu,.nav-dropdown:focus-within .nav-dropdown-menu{display:none}
  .nav-dropdown.open .nav-dropdown-menu{display:flex}
  .nav-dropdown-menu a{padding:10px 32px;border-bottom:none;font-size:13px}
  .nav-dropdown-menu-icons{padding:6px 0}
  .nav-dropdown-menu-icons .nav-dropdown-link{padding:10px 20px;gap:12px}
  .nav-dropdown-icon{width:28px;height:28px;border-radius:6px}
  .nav-dropdown-icon svg{width:13px;height:13px}
  .nav-dropdown-menu-areas{padding:8px 0}
  .nav-dropdown-group{margin-bottom:8px;gap:0}
  .nav-dropdown-group-label{padding:8px 20px 4px;font-size:9px}
  .nav-dropdown-menu-areas .nav-dropdown-link{padding:8px 28px;font-size:13px}
  .nav-dropdown-divider{margin:4px 20px}
  .menu-toggle{display:flex}
  .header-cta-desktop{display:none}
  .header-phone{display:none}
  .mobile-cta{display:block}

  .hero .container{padding-top:48px;padding-bottom:32px}
  .hero h1{font-size:32px}
  .hero-proof{
    display:flex;flex-direction:column;gap:14px;
    padding-top:16px;
  }
  .hero-proof-icon{width:36px;height:36px}
  .hero-proof-icon svg{width:15px;height:15px}
  .hero-proof-text{font-size:12px}
  .hero-btns{flex-direction:column;align-items:center}
  .hero-btns>.btn{width:100%;max-width:360px}
  .hero-sub{font-size:16px}

  .page-hero-grid{grid-template-columns:1fr;gap:32px}
  .page-hero-content h1{font-size:30px}

  .s-title{font-size:30px}
  .s-pad{padding:64px 0}

  .services-grid,.reviews-grid,.benefits-grid{grid-template-columns:1fr}
  .trust-grid,.included-grid{grid-template-columns:1fr;gap:40px}
  .process-grid{grid-template-columns:1fr}
  .process-grid::before{display:none}
  .stats-grid{grid-template-columns:repeat(2,1fr)}
  .stat+.stat::before{display:none}
  .faq-grid,.local-grid,.services-grid-4{grid-template-columns:1fr}
  .answer-snapshot-inner{grid-template-columns:1fr;padding:22px 20px;gap:22px}
  .answer-snapshot-copy h2{font-size:21px}
  .gallery-grid{grid-template-columns:repeat(2,1fr);grid-auto-rows:180px}
  .gallery-hero{grid-column:span 2;grid-row:span 1}
  .gallery-tall{grid-row:span 1}
  .gallery-cta{padding:28px 24px;flex-direction:column;text-align:center}
  .gallery-cta-btns{justify-content:center}

  .cta-btns,.page-hero-btns{flex-direction:column;align-items:center}
  .cta-btns>.btn,.page-hero-btns>.btn{width:100%;max-width:360px}
  .footer-grid{grid-template-columns:1fr;gap:32px}
  .footer-bottom{flex-direction:column;gap:12px;text-align:center}
  .wa-float{bottom:80px}
  .scroll-top{bottom:88px;right:24px}
}
@media(max-width:480px){
  .hero h1{font-size:28px}
  .hero-business-name{font-size:34px}
  .gallery-grid{grid-template-columns:1fr;grid-auto-rows:220px}
  .gallery-hero{grid-column:span 1}
  .stat-num{font-size:36px}
  .reviews-scroll .rev-card{flex:0 0 300px}
}

/* ============================================
   PRINT STYLESHEET
   ============================================ */
@media print{
  .top-bar,.header,.mobile-cta,.wa-float,.scroll-top,.footer-map,.noise-overlay{display:none!important}
  body{color:#000;background:#fff;font-size:12pt}
  .hero{min-height:auto;background:#fff;color:#000}
  .hero-bg,.hero-gradient,.hero-mini-review{display:none}
  .hero h1{color:#000;font-size:24pt}
  .hero-proof,.hero-btns{display:none}
  a{color:#000}
  a[href]::after{content:" (" attr(href) ")";font-size:9pt;color:#666}
  .footer{background:#fff;color:#000;padding:20px 0}
}
