/*
 Theme Name:   Bricks Child Theme
 Theme URI:    https://bricksbuilder.io/
 Description:  Use this child theme to extend Bricks.
 Author:       Bricks
 Author URI:   https://bricksbuilder.io/
 Template:     bricks
 Version:      1.1
 Text Domain:  bricks
*/
/* ============================================================
   SWIFT MOVERS — site stylesheet
   Headings : system sans      -> var(--font-head)
   Body / UI: Inter             -> var(--font-body)
   Colour + type tokens: see :root below.

   Organised top-to-bottom into labelled sections:
     Tokens & base . Buttons . Header & nav . Hero + trust bar .
     Homepage sections . Responsive . Inner pages (page hero,
     reservation, reviews, contact) . Shared components
     (hero intro, service cards, rates, areas, CTA, logo,
     breadcrumb, feature-icon chips).
   ============================================================ */

:root{
  /* ---------- Brand green (lime primary / teal secondary) ---------- */
  --gold:#4BE200;          /* primary brand lime-green — CTA buttons, check badges, key accents */
  --gold-dark:#3cb400;     /* deeper lime — CTA hover, logo */
  --gold-deep:#1f7a3d;     /* dark, readable green — links, accents, step numbers (legible on white) */
  --gold-deeper:#155a2c;   /* darkest green — hover state for links and accent fills */
  --gold-pale:#e4fcd9;     /* pale lime tint — soft section, badge and pill backgrounds */

  /* ---------- Secondary teal-green ---------- */
  --teal:#00E2B0;          /* secondary brand teal-green — secondary accents */
  --teal-dark:#00b48d;     /* deeper teal — hover */
  --teal-deep:#0a7a63;     /* dark, readable teal — text/links on white */
  --teal-pale:#d6fbf2;     /* pale teal tint — soft backgrounds */

  /* ---------- Neutrals ---------- */
  --black:#0c0a0a;         /* near-black — body text, dark sections, footer */
  --gray-bg:#efeef1;       /* light grey — alternating section background */
  --border:#d2cfd7;        /* hairline borders */
  --muted-soft:#b0adb4;    /* lightest muted grey — placeholders, subtle text */
  --muted:#88868a;         /* default muted grey — secondary text */
  --muted-dark:#5b5a5b;    /* darker muted grey */
  --muted-darker:#3d3b3b;  /* darkest muted grey — near body text */

  /* ---------- Feedback ---------- */
  --error:#ff8676;         /* form error red */

  /* ---------- Tokens ---------- */
  --radius:.7rem;
  --shadow:0 4px 16px rgba(12,10,10,.08);
  --max:73.75rem;

  /* ---------- Typography ---------- */
  --font-head:ui-sans-serif,system-ui,sans-serif;  /* all headings (system sans) */
  --font-body:"Inter",sans-serif;  /* body & UI */
}
*,:after,:before{box-sizing:border-box;margin:0;outline:none}
html{scroll-behavior:smooth;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-size:100%;}
body{
  font-family:var(--font-body);
  font-size:1rem;font-weight:500;letter-spacing:-.02em;line-height:1.4;
  background:#fff;color:var(--black);margin:0;padding:0;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
ul,ol{list-style:none;margin:0;padding:0}
.container{margin:0 auto;max-width:var(--max);padding:0 2rem;width:100%}
@media (max-width:992px){.container{padding:0 1.5rem}}
@media (max-width:576px){.container{padding:0 1rem}}
section{padding:4.5rem 0}
@media (max-width:992px){section{padding:3rem 0}}
@media (max-width:576px){section{padding:2.5rem 0}}

/* ---------- Headings (system sans) ---------- */
h1,.h1{font-family:var(--font-head);font-size:3rem;font-weight:900;letter-spacing:normal;line-height:1.08;text-transform:uppercase}
h2,.h2{font-family:var(--font-head);font-size:3rem;font-weight:900;letter-spacing:-.02em;line-height:1;margin:0 0 1.5rem}
h3,.h3{font-family:var(--font-head);font-weight:800;letter-spacing:-.02em;line-height:1;text-transform:uppercase;margin:0 0 .75rem}
h4,h5,h6{font-family:var(--font-head)}
@media (max-width:992px){
  h1,.h1{font-size:2.7rem}
  h2,.h2{font-size:2.5rem}
}
@media (max-width:576px){
  h1,.h1{font-size:2rem}
  h2,.h2{font-size:2rem}
}
.center{text-align:center}
.subtitle-green{color:var(--gold);font-size:1.5rem;font-weight:800;line-height:1;margin:.75rem 0 0}
@media (max-width:576px){.subtitle-green{font-size:1.375rem}}

/* ---------- Buttons (40px pill, 800 uppercase) ---------- */
.button{
  display:inline-flex;align-items:center;justify-content:center;gap:.625rem;
  background:var(--gold-deep);border:none;border-radius:40px;color:#fff;cursor:pointer;
  font-family:inherit;font-size:1rem;font-weight:800;letter-spacing:0;line-height:1.25;
  padding:.625rem 1.25rem;text-align:center;text-transform:uppercase;
  transition:background .4s ease-out,color .4s ease-out,outline .4s ease-out;
}
.button:hover{background:var(--gold-deeper);color:#fff}
.button:focus-visible{outline:4px solid var(--gold-pale)}
.button__green{background:var(--gold);color:var(--black)}
.button__green:hover{background:var(--gold-dark);color:var(--black)}
.button__black{background:var(--black);color:#fff}
.button__black:hover{background:var(--gold-deeper)}
.button__white-border{background:#fff;border:1px solid var(--border);color:var(--black)}
.button__white-border:hover{background:var(--gold-deeper);border-color:var(--gold-deeper);color:#fff}
.button__instagram{
  background:linear-gradient(90deg,#7017ff -3.76%,#c500e9 18.95%,#ed00c0 41.56%,#ff1b90 63.36%,#ff6930 85.96%,#ffd000 106.39%);
}
.button__instagram:hover{opacity:.9;background:linear-gradient(90deg,#7017ff -3.76%,#c500e9 18.95%,#ed00c0 41.56%,#ff1b90 63.36%,#ff6930 85.96%,#ffd000 106.39%)}

/* ---------- Header ---------- */
.site-header{
  background:#fff;box-shadow:0 0 .5rem rgba(12,10,10,.1);
  padding:.75rem 0 .5rem;position:sticky;top:0;z-index:10;
}
.site-header .inner{display:flex;align-items:center;gap:1.5rem}
.logo{display:flex;flex-direction:column;line-height:1;flex-shrink:0}
.logo strong{font-size:1.5rem;font-weight:900;letter-spacing:-.03em;text-transform:uppercase}
.logo strong span{color:var(--gold-dark)}
.logo small{font-size:.6rem;font-weight:800;letter-spacing:.42em;text-transform:uppercase;color:var(--muted)}
.header-menu{display:flex;align-items:center;gap:1.2rem;flex:1;justify-content:center}
.menu-item{position:relative}
.menu-item>button,.menu-item>a,.menu-item>.brxe-text-basic{
  display:flex;align-items:center;gap:.4rem;background:none;border:0;cursor:pointer;
  font-family:inherit;font-size:.875rem;font-weight:800;letter-spacing:0;line-height:1.25;
  text-transform:uppercase;color:var(--black);padding:.5rem 0;transition:color .4s ease-out;
}
.menu-item>button:hover,.menu-item>a:hover,.menu-item>.brxe-text-basic:hover,.menu-item.open>button,.menu-item.open>.brxe-text-basic{color:var(--gold-deep)}

/* ---------- Dropdown caret (.car) — CSS triangle, hardened against Bricks base styles ---------- */
.menu-item .car,
.menu-item i.car{
  display:inline-block;
  width:0 !important;
  height:0 !important;
  background:none !important;
  border-style:solid !important;
  border-width:.4rem .35rem 0 .35rem !important;
  border-color:var(--muted-darker) transparent transparent transparent !important;
  border-radius:0;
  transition:transform .3s ease-out, border-color .3s ease-out;
}
.menu-item.open .car,
.menu-item.open i.car{
  border-color:var(--gold-deep) transparent transparent transparent !important;
  transform:rotate(180deg);
}
.drop{
  position:absolute;top:calc(100% + .75rem);left:50%;transform:translateX(-30%) translateY(.5rem);
  background:#fff;border-radius:var(--radius);box-shadow:var(--shadow);min-width:max-content;
  padding:1.5rem;display:grid;gap:.75rem;opacity:0;visibility:hidden;
  transition:opacity .4s ease-out,transform .4s ease-out,visibility .4s;z-index:2;
}
.menu-item.open .drop{opacity:1;visibility:visible;transform:translateX(-30%) translateY(0)}
.drop a{font-size:1rem;font-weight:500;letter-spacing:-.02em;transition:color .4s ease-out;display:block}
.drop a:hover{color:var(--gold-deep)}

/* ---------- Desktop cascade dropdown (Services) ---------- */
.drop--cascade{grid-template-columns:1fr;gap:.15rem;min-width:16.5rem;padding:.75rem}
.cas-item{position:relative;display:flex;align-items:center;border-radius:.5rem;transition:background .25s ease-out}
.cas-item>a{flex:1;padding:.6rem .75rem;font-weight:600}
.cas-item:hover{background:var(--gold-pale)}
.cas-item:hover>a{color:var(--gold-deep)}
.cas-arrow{padding:0 .75rem 0 .25rem;color:var(--muted);font-weight:800;font-size:1.1rem;line-height:1}
.cas-item:hover .cas-arrow{color:var(--gold-deep)}
.cas-sub{
  position:absolute;left:calc(100% + .35rem);top:-.35rem;background:#fff;border-radius:var(--radius);
  box-shadow:var(--shadow);padding:.75rem;min-width:17rem;display:grid;gap:.1rem;
  opacity:0;visibility:hidden;transform:translateX(.4rem);
  transition:opacity .25s ease-out,transform .25s ease-out,visibility .25s;z-index:3;
}
.cas-item:hover .cas-sub{opacity:1;visibility:visible;transform:none}
.cas-sub a{padding:.5rem .75rem;border-radius:.5rem;font-size:.95rem}
.cas-sub a:hover{background:var(--gold-pale);color:var(--gold-deep)}

/* ---------- Mobile drill-down menu ---------- */
.mnav{position:fixed;inset:0;z-index:200;pointer-events:none}
.mnav__overlay{position:absolute;inset:0;background:rgba(12,10,10,.4);opacity:0;transition:opacity .3s ease}
.mnav__drawer{
  position:absolute;top:0;right:0;bottom:0;width:min(26rem,100%);background:#fff;
  transform:translateX(100%);transition:transform .35s ease;overflow:hidden;
  box-shadow:-8px 0 30px rgba(12,10,10,.18);
}
.mnav.open{pointer-events:auto}
.mnav.open .mnav__overlay{opacity:1}
.mnav.open .mnav__drawer{transform:none}
.mnav__panels{position:relative;height:100%}
.mnav__panel{
  position:absolute;inset:0;background:#fff;display:flex;flex-direction:column;overflow-y:auto;
  transform:translateX(100%);visibility:hidden;
  transition:transform .3s ease,visibility .3s;
}
.mnav__panel.is-active{transform:none;visibility:visible}
.mnav__panel.is-left{transform:translateX(-30%)}
.mnav__bar{display:flex;align-items:stretch;min-height:3.6rem;border-bottom:1px solid var(--gray-bg);flex:none}
.mnav__bar--root{justify-content:space-between}
.mnav__logo{font-weight:900;font-size:1.15rem;text-transform:uppercase;letter-spacing:-.02em;align-self:center;padding:0 1.25rem}
.mnav__logo span{color:var(--gold-dark)}
.mnav__title{flex:1;display:flex;align-items:center;justify-content:center;font-weight:800;text-transform:uppercase;font-size:.95rem}
.mnav__back,.mnav__close,.mnav__next{
  background:none;border:0;cursor:pointer;font-family:inherit;line-height:1;
  display:flex;align-items:center;justify-content:center;color:var(--black);
  transition:color .25s ease-out,background .25s ease-out;
}
.mnav__back{width:3.6rem;border-right:1px solid var(--gray-bg);font-size:1.6rem;color:var(--gold-deep)}
.mnav__close{width:3.6rem;font-size:1.6rem}
.mnav__back:active,.mnav__close:active{background:var(--gray-bg)}
.mnav__list{flex:1}
.mnav__list li{display:flex;align-items:stretch;border-bottom:1px solid var(--gray-bg)}
.mnav__list li>a{flex:1;display:flex;align-items:center;padding:1.1rem 1.25rem;font-weight:600;font-size:1.05rem}
.mnav__list li>a:active{color:var(--gold-deep);background:#fafafa}
.mnav__next{width:3.6rem;border-left:1px solid var(--gray-bg);font-size:1.5rem;font-weight:800;color:var(--gold-deep);flex:none}
.mnav__next:active{background:var(--gold-pale)}
.mnav__cta{padding:1.25rem;display:grid;gap:.6rem;flex:none}
.mnav__cta .button{width:100%}
@media (min-width:993px){.mnav{display:none}}
.header-phone{text-align:center;flex-shrink:0}
.header-phone a{font-weight:800;font-size:1.05rem}
.header-phone a:hover{color:var(--gold-deep)}
.phone-work,.cta-box-info{color:var(--muted-darker);display:block;font-size:.75rem;font-weight:500;margin:.25rem 0 0;text-align:center}
.header-cta{flex-shrink:0;text-align:center}
.button-menu{
  display:none;background:none;border:1px solid var(--border);border-radius:50%;cursor:pointer;
  height:2.5rem;width:2.5rem;flex-direction:column;align-items:center;justify-content:center;gap:2.5px;
}
.button-menu .line{background:var(--black);border-radius:2px;height:5px;width:16px;transition:transform .4s ease-out}
.button-menu.active .line:first-child{transform:rotate(45deg) translate(2px,2px)}
.button-menu.active .line:nth-child(2){transform:rotate(-45deg) translate(1.5px,-1.5px)}

/* ---------- Hero (layout per approved mockup: text left, enquiry form right) ---------- */
.section-hero{background:linear-gradient(180deg,#eafce0 0%,#fff 100%);overflow:hidden;padding:4rem 0 2.5rem;position:relative}
.hero-row{display:grid;grid-template-columns:1.05fr .95fr;gap:3.5rem;align-items:center}
.hero-content h1{font-size:1.4rem;text-transform:uppercase;line-height:1.05;margin:0 0 1rem}
@media (max-width:992px){.hero-content h1{font-size:1.2rem}}
@media (max-width:576px){.hero-content h1{font-size:1rem}}
.hero-sub{font-size:1.35rem;font-weight:700;line-height:1.35;margin:0 0 1.75rem;max-width:32rem}
@media (max-width:576px){.hero-sub{font-size:1.15rem}}
.hero-split{display:grid;grid-template-columns:1fr auto;gap:1.5rem 2rem;align-items:center;margin:.5rem 0 0}
.hero-tagline{margin:0 0 1.25rem;max-width:30rem}
.hero-content .boxes{display:block;width:10rem;justify-self:end;filter:drop-shadow(0 14px 24px rgba(0,0,0,.18));animation:float 5s ease-in-out infinite}
@media (max-width:576px){.hero-content .boxes{width:8rem}}
@media (max-width:768px){
  .hero-split{grid-template-columns:1fr}
  .hero-content .boxes{display:none}
}
/* ---------- Hero checklist ---------- */
.hero-checklist{margin:0 0 1.5rem;max-width:34rem}
.hero-checklist__lead{
  font-family:var(--font-head);font-size:1.15rem;font-weight:800;
  letter-spacing:-.01em;line-height:1.3;color:var(--black);margin:0 0 1.1rem;
}
.hero-checklist__list{display:flex;flex-direction:column;gap:.85rem}
.hero-checklist__list li{
  display:flex;align-items:flex-start;gap:.85rem;
  font-size:1.02rem;line-height:1.4;color:var(--muted-darker);
}
.hero-checklist__list b{color:var(--black);font-weight:700}
.hero-checklist__tick{
  flex:none;width:1.6rem;height:1.6rem;border-radius:50%;
  background:var(--gold-pale);color:var(--gold-deep);
  display:inline-flex;align-items:center;justify-content:center;
  font-size:.85rem;font-weight:800;margin-top:.05rem;
}
@media (max-width:576px){
  .hero-checklist__list li{font-size:.95rem;gap:.65rem}
}
.hero-form-card{
  background:#fff;border-radius:var(--radius);box-shadow:var(--shadow);
  padding:1.5rem;margin:1.5rem 0 0;max-width:36rem;
}
.hero-form-card h2.form-title{font-size:1.25rem;font-weight:800;letter-spacing:-.02em;line-height:1;margin:0 0 1rem}
.form-group{display:grid;grid-template-columns:1fr 1fr;gap:.75rem 1rem;margin:0 0 .75rem}
.form-group.one{grid-template-columns:1fr}
.form-field label{color:var(--muted-darker);font-size:.875rem;font-weight:500;letter-spacing:-.02em;display:block;margin:0 0 .25rem}
.form-field input,.form-field select,.form-field textarea{
  width:100%;background:#fff;border:1px solid var(--border);border-radius:.5rem;
  color:var(--black);font-family:inherit;font-size:1rem;font-weight:500;letter-spacing:-.02em;
  line-height:1.4;padding:.625rem .75rem;transition:border .4s ease-out;
}
.form-field input::placeholder,.form-field textarea::placeholder{color:var(--muted-soft)}
.form-field input:focus,.form-field select:focus,.form-field textarea:focus{border-color:var(--gold-deeper)}
.form-field textarea{height:5rem;resize:vertical}
.form-field select{appearance:none;cursor:pointer;background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6'%3E%3Cpath fill='%233d3b3b' d='M0 0l5 6 5-6z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 1rem center}
.hero-form-card .button{margin:0;width:100%}
.form-disclaimer{color:var(--muted);font-size:.75rem;font-weight:500;margin:.75rem 0 0;line-height:1.5}
.form-success{display:none;text-align:center;padding:1.5rem .5rem}
.form-success img{width:8rem;margin:0 auto 1rem}
.form-success h3{font-size:1.25rem;font-weight:800;line-height:1;text-transform:uppercase;margin:0 0 .5rem}
.form-success p{color:var(--muted);font-size:.875rem}
.sent form{display:none}
.sent .form-success{display:block}

.hero-form-wrap{position:relative}
.hero-form-wrap .hero-form-card{margin:0;max-width:none}
@keyframes float{0%,100%{transform:translateY(0)}50%{transform:translateY(-10px)}}
@media (prefers-reduced-motion:reduce){
  .hero-animation .boxes{animation:none}
  html{scroll-behavior:auto}
  *{transition:none!important}
}

/* ---------- Hero reviews / trust bar ---------- */
.hero-reviews{
  display:flex;flex-direction:row;align-items:center;justify-content:space-between;
  gap:1rem;margin:3rem 0 0;
}
.hero-reviews-info{
  flex:none;font-size:1.25rem;font-weight:900;line-height:1.2;max-width:15rem;text-transform:uppercase;
}
.review-box{
  flex:1;display:flex;flex-direction:row;align-items:center;gap:.7rem;
  background:#fff;border-radius:var(--radius);box-shadow:var(--shadow);padding:.8rem 1rem;
  transition:box-shadow .4s ease;
}
.review-box:hover{box-shadow:0 4px 16px rgba(12,10,10,.16)}
.review-box__icon{flex:none;display:flex;align-items:center;justify-content:center}
.review-box__icon img{height:auto;width:auto;max-width:4.5rem}
.review-box__title{display:flex;flex-direction:column;align-items:flex-start;line-height:1.15;gap:.12rem}
.review-box__title b{font-size:1rem;font-weight:800;line-height:1.1;color:var(--black)}
.review-box__title span{font-size:.78rem;color:var(--muted-dark)}

/* ---------- Video strip ---------- */

/* ---------- Google reviews strip ---------- */
.greviews{position:relative;margin:0 0 2.5rem}
.greviews-track{
  display:flex;gap:1rem;overflow-x:auto;scroll-snap-type:x mandatory;scroll-behavior:smooth;
  padding:.25rem;-ms-overflow-style:none;scrollbar-width:none;
}
.greviews-track::-webkit-scrollbar{display:none}
.greview{
  flex:0 0 calc(25% - .75rem);scroll-snap-align:start;background:#fff;
  border:1px solid var(--gray-bg);border-radius:var(--radius);padding:1.25rem;
  box-shadow:0 2px 10px rgba(12,10,10,.04);display:flex;flex-direction:column;align-items:flex-start;
}
.greview__head{display:flex;align-items:flex-start;gap:.75rem;margin:0 0 .75rem;width:100%}
.greview__avatar{
  width:2.75rem;height:2.75rem;border-radius:50%;flex:none;color:#fff;
  display:flex;align-items:center;justify-content:center;font-weight:800;font-size:1.1rem;
}
.greview__meta{flex:1;line-height:1.25}
.greview__meta b{display:block;font-weight:800}
.greview__meta small{color:var(--muted);font-size:.8rem}
.greview__glogo{width:1.4rem;height:1.4rem;flex:none}
.greview__stars{display:flex;align-items:center;gap:.5rem;margin:0 0 .6rem}
.greview__stars .st{color:#fbbc04;letter-spacing:2px;font-size:1.05rem;line-height:1}
.greview__verified{
  width:1.05rem;height:1.05rem;border-radius:50%;background:#4285f4;color:#fff;
  display:inline-flex;align-items:center;justify-content:center;font-size:.62rem;font-weight:800;
}
.greview__text{
  font-size:.92rem;color:var(--muted-darker);
  display:-webkit-box;-webkit-line-clamp:4;-webkit-box-orient:vertical;overflow:hidden;
}
.greview.expanded .greview__text{-webkit-line-clamp:unset;display:block}
.greview__more{
  background:none;border:0;color:var(--muted);font-family:inherit;font-size:.85rem;
  cursor:pointer;padding:0;margin:.6rem 0 0;transition:color .4s ease-out;
}
.greview__more:hover{color:var(--gold-deep)}
.greviews-arrow{
  position:absolute;top:50%;transform:translateY(-50%);width:2.75rem;height:2.75rem;border-radius:50%;
  background:#fff;border:1px solid var(--gray-bg);box-shadow:var(--shadow);cursor:pointer;z-index:2;
  display:flex;align-items:center;justify-content:center;font-size:1.4rem;line-height:1;font-family:inherit;
  transition:background .4s ease-out,color .4s ease-out,border-color .4s ease-out;
}
.greviews-arrow:hover{background:var(--gold-deeper);border-color:var(--gold-deeper);color:#fff}
.greviews-arrow.prev{left:-1.25rem}
.greviews-arrow.next{right:-1.25rem}
@media (max-width:992px){.greview{flex:0 0 calc(50% - .5rem)}}
@media (max-width:576px){
  .greview{flex:0 0 100%}
  .greviews-arrow.prev{left:-.4rem}
  .greviews-arrow.next{right:-.4rem}
}

.stories-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem}
.story-video{position:relative;border-radius:var(--radius);overflow:hidden;aspect-ratio:9/13;cursor:pointer;background:var(--gray-bg)}
.story-video img{width:100%;height:100%;object-fit:cover;transition:transform .4s ease-out}
.story-video:hover img{transform:scale(1.05)}
.story-video .play{
  position:absolute;inset:0;margin:auto;width:3.5rem;height:3.5rem;border-radius:50%;
  background:rgba(255,255,255,.92);display:flex;align-items:center;justify-content:center;box-shadow:var(--shadow);
}
.story-video .play:after{content:"";border-style:solid;border-width:10px 0 10px 16px;border-color:transparent transparent transparent var(--gold-deep);margin-left:4px}

/* ---------- Why people love us (section-icons) ---------- */
.section-icons{background:var(--gray-bg)}
.icons-list{display:grid;grid-template-columns:repeat(3,1fr);gap:1.25rem;margin:2.5rem 0 0}
.icon-box{background:#fff;border-radius:var(--radius);padding:1.75rem 1.5rem;transition:transform .3s ease,box-shadow .3s ease}
.icon-box:hover{transform:translateY(-4px);box-shadow:var(--shadow)}
.icon-box h3{font-size:1.5rem;margin:0 0 .75rem}
@media (max-width:992px){.icon-box h3{font-size:1.375rem}}
.icon-box .brxe-text {font-size:.875rem;font-weight:500;color:var(--muted-dark)}

/* ---------- Truck banner ---------- */
.section-truck{padding:6rem 0 4rem;text-align:center}
@media (max-width:576px){.section-truck{padding:4rem 0 3rem}}
.section-truck img{margin:0 auto;max-width:55rem;width:100%}
.section-truck__text{font-size:2.5rem;font-weight:900;line-height:1;margin:1.25rem 0 0;text-transform:uppercase}
@media (max-width:992px){.section-truck__text{font-size:2rem}}
@media (max-width:576px){.section-truck__text{font-size:1.75rem}}

/* ---------- Reviews slider ---------- */
.section-reviews{background:var(--gray-bg)}
.rev-shell{position:relative;margin-top:2.5rem}
.rev-track{overflow:hidden;border-radius:var(--radius)}
.rev-row{display:flex;transition:transform .45s ease}
.rev{flex:0 0 100%;background:#fff;border-radius:var(--radius);padding:2.5rem;box-shadow:var(--shadow)}
@media (max-width:576px){.rev{padding:1.5rem}}
.rev p{color:var(--muted-darker);margin:0 0 1.25rem}
.rev .stars{color:var(--gold-deeper);letter-spacing:2px;margin:0 0 .75rem;font-size:1.05rem}
.rev .who{display:flex;align-items:center;gap:.75rem}
.rev .av{width:3rem;height:3rem;border-radius:50%;background:var(--gold-pale);color:var(--gold-deep);display:flex;align-items:center;justify-content:center;font-weight:900;flex:none}
.rev .who b{display:block;font-weight:800}
.rev .who small{color:var(--muted-dark);font-size:.875rem}
.rev-nav{display:flex;gap:.5rem;justify-content:center;margin-top:1.5rem;align-items:center}
.rev-btn{width:2.75rem;height:2.75rem;border-radius:50%;border:1px solid var(--border);background:#fff;cursor:pointer;font-size:1.05rem;font-weight:800;display:flex;align-items:center;justify-content:center;transition:background .4s ease-out,color .4s ease-out,border-color .4s ease-out;font-family:inherit}
.rev-btn:hover{background:var(--gold-deeper);border-color:var(--gold-deeper);color:#fff}
.dots{display:flex;gap:.5rem;margin:0 .5rem}
.dot{width:.5rem;height:.5rem;border-radius:50%;background:var(--border);border:0;cursor:pointer;padding:0}
.dot.on{background:var(--gold-deep)}

/* ---------- Services we offer ---------- */
.services-list{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem;margin:2.5rem 0 0}
.service-box{background:var(--gray-bg);border-radius:var(--radius);padding:.5rem;display:flex;flex-direction:column;transition:transform .3s ease,box-shadow .3s ease}
.service-box:hover{transform:translateY(-4px);box-shadow:var(--shadow)}
.service-box__image{background:#fff;border-radius:.5rem;padding:2rem;display:flex;align-items:center;justify-content:space-between}
.service-box__image img{width:3.5rem;height:3.5rem}
.service-box__tag{background:var(--gold-pale);border-radius:.25rem;color:var(--gold-deep);font-size:.875rem;font-weight:500;letter-spacing:0;line-height:1.2;padding:.188rem .375rem;text-transform:uppercase}
.service-box__content{padding:1.5rem;display:flex;flex-direction:column;flex:1}
.service-box__content h3{font-size:1.25rem;margin:0 0 .75rem}
.service-box__content p{font-size:.875rem;color:var(--muted-dark);flex:1;margin:0 0 1.2rem}
.service-box__link{color:var(--gold-deep);font-weight:800;text-transform:uppercase;display:inline-flex;align-items:center;gap:.25rem;width:fit-content}
.service-box__link:after{content:"→";transition:transform .4s ease-out}
.service-box__link:hover:after{transform:translateX(.5rem)}

/* ---------- Our services include (benefits) ---------- */
.section-benefits{background:var(--gray-bg)}
.benefits-list{display:grid;gap:1rem;margin:2.5rem 0 0}
.benefit-box{display:grid;grid-template-columns:4.5rem 1fr;gap:1.25rem;align-items:start;background:#fff;border-radius:var(--radius);padding:1.5rem}
.benefit-box h3{font-size:1.25rem;margin:0 0 .75rem;text-transform:none;font-weight:700}
.benefit-box p{font-size:.875rem;color:var(--muted-dark)}

/* ---------- About ---------- */
.section-about-grid{display:grid;grid-template-columns:.9fr 1.1fr;gap:3rem;align-items:start}
.section-about-grid .eyebrow{color:var(--muted-darker);font-size:1rem;font-weight:800;letter-spacing:0;text-transform:uppercase;display:block;margin:0 0 .75rem}
.section-about-grid p{color:var(--muted-dark);margin:0 0 1rem;font-size:.95rem}

/* ---------- Clients (dark logo band) ---------- */
.section-clients{background:var(--black);color:#fff;padding:4rem 0}
.section-clients h2{text-align:center}
.clients-list{display:flex;gap:1rem;flex-wrap:wrap;align-items:center;justify-content:space-between}
.clogo{flex:1 1 9rem;height:3.75rem;border:1px dashed var(--muted-darker);border-radius:.5rem;display:flex;align-items:center;justify-content:center;color:var(--muted);font-weight:800;font-size:.7rem;letter-spacing:.08em;text-transform:uppercase}

/* ---------- Blog ---------- */
.recent-blog__list{display:grid;grid-template-columns:1fr 1fr .85fr;gap:1rem;margin:2.5rem 0 0}
.blog-item{background:#fff;border-radius:var(--radius);overflow:hidden;display:flex;flex-direction:column;border:1px solid var(--gray-bg);transition:transform .3s ease,box-shadow .3s ease}
.blog-item:hover{transform:translateY(-4px);box-shadow:var(--shadow)}
.blog-item__image{height:11rem;overflow:hidden}
.blog-item__image img{height:100%;width:100%;object-fit:cover;transition:transform .4s ease-out}
.blog-item:hover img{transform:scale(1.02)}
.blog-item .bd{padding:1.25rem 1.5rem;display:flex;flex-direction:column;flex:1}
.blog-item__category{background:var(--gold-pale);border-radius:.25rem;color:var(--gold-dark);font-size:.875rem;font-weight:500;letter-spacing:0;line-height:1.2;padding:.188rem .375rem;text-transform:uppercase;width:fit-content;margin:0 0 .5rem}
.blog-item__title{font-size:1.2rem;font-weight:800;line-height:1.1;text-transform:uppercase;margin:0 0 1rem;flex:1}
.blog-item__info{color:var(--muted);font-size:.875rem;font-weight:500}
.blog-item.last{align-items:center;justify-content:center;text-align:center;gap:1.25rem;background:var(--gray-bg);padding:1.5rem;border:0}
.blog-item.last h4{font-size:2rem;font-weight:900;line-height:1;text-transform:uppercase}

/* ---------- FAQ ---------- */
.section-faq{background:var(--gray-bg)}
.faq-row{display:grid;grid-template-columns:5fr 7fr;gap:3rem;align-items:start}
.faq-info .subtitle{color:var(--muted);font-size:1rem;font-weight:800;letter-spacing:0;text-transform:uppercase;margin:.75rem 0 1.5rem;display:block}
.faq-callme{background:#fff;border-radius:var(--radius);padding:1.5rem;font-weight:500}
.faq-callme a{display:block;font-size:1.5rem;font-weight:900;color:var(--gold-deep);margin:.4rem 0 0}
.faq-content__item{background:#fff;border-radius:var(--radius);margin:0 0 .5rem;overflow:hidden}
.faq-content__item-title{
  width:100%;display:flex;justify-content:space-between;align-items:center;gap:1.5rem;
  padding:1.5rem;background:none;border:0;cursor:pointer;font-family:inherit;text-align:left;color:var(--black);
}
.faq-content__item-title h3{font-size:1.375rem;margin:0}
@media (max-width:576px){.faq-content__item-title h3{font-size:1.15rem}}
.faq-content__item .icons{
  flex:none;width:2.5rem;height:2.5rem;border:1px solid var(--gray-bg);border-radius:50%;
  display:flex;align-items:center;justify-content:center;font-size:1.3rem;font-weight:800;color:var(--gold-deep);
  transition:transform .4s linear,background .4s ease-out;
}
.faq-content__item.active .icons{transform:rotate(45deg);background:var(--gold-pale)}
.faq-content__item-content{max-height:0;overflow:hidden;transition:max-height .4s ease}
.faq-content__item-content p{padding:0 1.5rem 1.5rem;color:var(--muted-dark);font-size:.95rem}

/* ---------- Feature rows ---------- */
.text-box{display:grid;grid-template-columns:1fr 1fr;gap:3.5rem;align-items:center;padding:2rem 0}
.text-box img{border-radius:var(--radius);width:100%;object-fit:cover;box-shadow:var(--shadow)}
.text-box h3{font-size:1.5rem;margin:0 0 .75rem}
@media (max-width:992px){.text-box h3{font-size:1.375rem}}
.text-box p{color:var(--muted-dark);font-size:.95rem}
.text-box.flip .img{order:2}

/* ---------- Instagram ---------- */
.section-instagram h2{text-align:center}
.instagram-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:.75rem}
.instagram-grid a{border-radius:.5rem;overflow:hidden;aspect-ratio:1;display:block}
.instagram-grid img{width:100%;height:100%;object-fit:cover;transition:transform .4s ease-out}
.instagram-grid a:hover img{transform:scale(1.06)}
.section-instagram .center{margin-top:2rem}

/* ---------- Footer (dark) ---------- */
.section-footer{background:var(--black);color:#fff;padding:3rem 0 2rem}
.footer-grid{display:grid;grid-template-columns:repeat(4,1fr) 1.3fr;gap:2rem}
.footer-menu__title{color:var(--gold);font-size:1rem;font-weight:800;letter-spacing:0;line-height:1.25;text-transform:uppercase;margin:0 0 1rem}
.footer-menu ul li a{display:block;font-size:1.05rem;font-weight:500;margin:.5rem 0;transition:color .4s ease-in-out;width:fit-content}
.footer-menu ul li a:hover{color:var(--gold-deeper)}
.footer-info__email{display:block;font-weight:800;text-transform:uppercase;margin:.75rem 0 0;border-bottom:1px solid #fff;width:fit-content}
.footer-info__email:hover{border-color:transparent}
.footer-info .tel{font-size:1.2rem;font-weight:900}
.footer-info__box{color:var(--muted-soft);font-size:.875rem;font-weight:500;margin:1rem 0 0}
.footer-follow{display:flex;gap:.6rem;margin:1.25rem 0 0}
.footer-follow a{
  width:2.5rem;height:2.5rem;border:1px solid var(--muted-darker);border-radius:50%;
  display:flex;align-items:center;justify-content:center;font-weight:800;font-size:.7rem;
  transition:background .4s ease-in-out,border-color .4s ease-in-out;
}
.footer-follow a:hover{background:var(--gold-deeper);border-color:var(--gold-deeper)}
.footer-license{font-size:.875rem;color:var(--muted-soft);margin:2rem 0 0;display:flex;align-items:center;gap:.6rem}
.footer-license img{max-width:3rem}
.footer-copyright{
  display:flex;justify-content:space-between;align-items:center;gap:1rem;flex-wrap:wrap;
  color:var(--muted-darker);font-size:.875rem;font-weight:500;margin:2rem 0 0;border-top:1px solid #1d1b1b;padding:1.5rem 0 0;
}
.footer-copyright nav{display:flex;gap:1.25rem}
.footer-copyright a{border-bottom:1px solid var(--muted-darker)}
.footer-copyright a:hover{border-color:transparent}

/* ---------- Mobile sticky bar ---------- */
.header-fix{
  display:none;position:fixed;bottom:0;left:0;right:0;z-index:9;background:#fff;
  box-shadow:-.5rem 0 .5rem rgba(12,10,10,.1);gap:.25rem;padding:.5rem 1rem;
}
.header-fix a{flex:1;text-align:center;padding:.625rem .25rem;font-weight:800;font-size:.8rem;text-transform:uppercase;border-radius:40px}
.header-fix a.mid{background:var(--gold);color:var(--black)}

/* ---------- Responsive ---------- */
@media (max-width:992px){
  .site-header .inner{flex-wrap:wrap}
  .header-phone,.header-cta{display:none}
  .button-menu{display:flex;margin-left:auto}
  .header-menu{display:none}
  .hero-row,.section-about-grid,.faq-row{grid-template-columns:1fr;gap:2.5rem}
  .icons-list{grid-template-columns:repeat(2,1fr)}
  .services-list{grid-template-columns:repeat(2,1fr)}
  .stories-grid,.instagram-grid{grid-template-columns:repeat(2,1fr)}
  .recent-blog__list{grid-template-columns:1fr 1fr}
  .blog-item.last{grid-column:span 2}
  .text-box{grid-template-columns:1fr}
  .text-box.flip .img{order:0}
  .footer-grid{grid-template-columns:1fr 1fr}
  .hero-reviews{display:grid;grid-template-columns:repeat(2,1fr)}
  .hero-reviews-info{max-width:none;grid-column:span 2;text-align:center}
}
@media (max-width:576px){
  .icons-list,.services-list,.form-group,.recent-blog__list{grid-template-columns:1fr}
  .blog-item.last{grid-column:auto}
  .hero-reviews{grid-template-columns:1fr;gap:.5rem}
  .hero-reviews-info{grid-column:auto;margin:0 0 .5rem}
  .header-fix{display:flex}
  body{padding-bottom:3.4rem}
  .footer-grid{grid-template-columns:1fr}
  .clients-list{justify-content:center}
}

/* ============================================================
   Inner pages
   ============================================================ */

/* ---------- Page hero ---------- */
.page-hero{background:var(--gray-bg);padding:3.5rem 0;text-align:center}
.page-hero h1{font-size:2.6rem;max-width:58rem;margin:0 auto}
@media (max-width:992px){.page-hero h1{font-size:2.2rem}}
@media (max-width:576px){.page-hero h1{font-size:1.7rem}}
.page-hero .subtitle-green{font-size:1.35rem}
.page-hero .hero-reviews{margin-top:2.5rem;text-align:left}
.page-hero--mint{background:linear-gradient(180deg,#eafce0 0%,#fff 100%)}
.page-hero .lead{color:var(--muted-dark);max-width:40rem;margin:1rem auto 0}

/* ---------- Reservation ---------- */
.res-benefits{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem;margin:2.5rem 0 0;text-align:left}
@media (max-width:992px){.res-benefits{grid-template-columns:repeat(2,1fr)}}
@media (max-width:576px){.res-benefits{grid-template-columns:1fr}}
.res-benefit{background:#fff;border-radius:.5rem;box-shadow:var(--shadow);padding:1.25rem}
.res-benefit img{width:3.25rem;height:3.25rem;margin:0 0 .6rem}
.res-benefit b{display:block;font-size:.92rem;font-weight:800;text-transform:uppercase;line-height:1.2}
.section-resform{background:var(--gray-bg)}
.res-card{max-width:44rem;margin:0 auto;background:#fff;border-radius:var(--radius);padding:2.5rem;box-shadow:var(--shadow)}
@media (max-width:576px){.res-card{padding:1.5rem}}
.res-box{margin:0 0 2.25rem}
.res-box>h3{font-size:1.3rem;margin:0 0 .25rem}
.res-box>.hint{color:var(--muted);font-size:.9rem;margin:0 0 1rem}
.pick{position:relative}
.pick-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:.5rem}
.pick-grid--2{grid-template-columns:repeat(2,1fr)}
@media (max-width:576px){.pick-grid{grid-template-columns:repeat(2,1fr)}.pick-grid--2{grid-template-columns:1fr}}
.pick input{position:absolute;opacity:0;pointer-events:none}
.pick label{
  display:flex;flex-direction:column;justify-content:center;gap:.15rem;height:100%;
  background:#fff;border:1px solid var(--border);border-radius:.5rem;cursor:pointer;
  padding:.75rem .9rem;text-align:center;
  transition:border-color .3s ease-out,color .3s ease-out,background .3s ease-out;
}
.pick label b{font-size:1rem;font-weight:600;text-transform:none}
.pick label small{color:var(--muted);font-size:.75rem;transition:color .3s ease-out}
.pick label:hover{border-color:var(--gold-deeper);color:var(--gold-deeper)}
.pick input:checked+label{background:var(--gold-pale);border-color:var(--gold-deep);color:var(--gold-deep)}
.pick input:checked+label small{color:var(--gold-deeper)}
.pick input:focus-visible+label{outline:3px solid var(--gold-pale)}
.switch-row{display:flex;align-items:center;gap:.8rem;margin:.6rem 0 0;font-size:.9rem;color:var(--muted-dark)}
.switch{
  position:relative;width:2.75rem;height:1.5rem;appearance:none;-webkit-appearance:none;
  background:var(--border);border-radius:var(--radius);cursor:pointer;border:0;flex:none;transition:background .3s;
}
.switch:after{content:"";position:absolute;top:.25rem;left:.25rem;width:1rem;height:1rem;border-radius:50%;background:#fff;transition:left .3s}
.switch:checked{background:var(--gold-deep)}
.switch:checked:after{left:1.5rem}
.kit-box{display:none;margin:1.1rem 0 0}
.kit-box.show{display:block}
.kit-box>b{display:block;font-weight:800;margin:0 0 .6rem}
.res-card .button{width:100%}

/* ---------- Reviews archive ---------- */
.filter-pills{display:flex;gap:.4rem;flex-wrap:wrap;justify-content:center;margin:0 0 2rem}
.filter-pill{
  background:#fff;border:1px solid var(--border);border-radius:2rem;cursor:pointer;
  font-family:inherit;font-size:.95rem;font-weight:500;padding:.5rem 1rem;
  transition:color .3s ease-out,background .3s ease-out,border-color .3s ease-out;
}
.filter-pill:hover{background:var(--gold-deeper);border-color:var(--gold-deeper);color:#fff}
.filter-pill.active{background:var(--black);border-color:var(--black);color:#fff}
.rarchive{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem;margin:0 0 2.5rem}
@media (max-width:992px){.rarchive{grid-template-columns:repeat(2,1fr)}}
@media (max-width:576px){.rarchive{grid-template-columns:1fr}}
.rarchive-item{background:var(--gray-bg);border-radius:var(--radius);padding:1.75rem;display:flex;flex-direction:column}
.rarchive-item .stars{color:#fbbc04;letter-spacing:2px;margin:0 0 .6rem}
.rarchive-item p{font-size:.92rem;color:var(--muted-darker);flex:1;margin:0 0 1.5rem}
.rarchive-item .who{display:flex;align-items:center;gap:.7rem}
.rarchive-item .av{width:2.75rem;height:2.75rem;border-radius:50%;flex:none;display:flex;align-items:center;justify-content:center;font-weight:800;color:#fff}
.rarchive-item .who b{display:block;font-size:.95rem;line-height:1.2}
.rarchive-item .who small{color:var(--muted);font-size:.8rem}
.rarchive-item.hidden{display:none}
.pagination{display:flex;gap:1rem;justify-content:center;align-items:center;font-weight:600}
.pagination span{color:var(--black)}
.pagination a{color:var(--muted);transition:color .3s ease-out}
.pagination a:hover{color:var(--gold-deep)}

/* ---------- Contact ---------- */
.contact-grid{display:grid;grid-template-columns:.9fr 1.1fr;gap:3rem;align-items:start}
@media (max-width:992px){.contact-grid{grid-template-columns:1fr;gap:2rem}}
.contact-card{
  display:flex;gap:1rem;align-items:flex-start;background:#fff;border:1px solid var(--gray-bg);
  border-radius:var(--radius);padding:1.25rem;box-shadow:0 2px 10px rgba(12,10,10,.04);margin:0 0 .75rem;
}
.contact-card .ic{
  width:2.75rem;height:2.75rem;border-radius:50%;background:var(--gold-pale);color:var(--gold-deep);
  display:flex;align-items:center;justify-content:center;font-size:1.15rem;font-weight:800;flex:none;
}
.contact-card b{display:block;font-size:.78rem;font-weight:800;text-transform:uppercase;color:var(--muted-dark);margin:0 0 .15rem}
.contact-card a{font-weight:700}
.contact-card a:hover{color:var(--gold-deep)}
.contact-card p{font-size:.95rem}
.contact-form-card{background:#fff;border-radius:var(--radius);box-shadow:var(--shadow);padding:2rem}
@media (max-width:576px){.contact-form-card{padding:1.5rem}}
.contact-form-card .button{width:100%}
.map-stub{
  background:var(--gray-bg);border:1px dashed var(--border);border-radius:var(--radius);min-height:18rem;
  display:flex;align-items:center;justify-content:center;color:var(--muted);text-align:center;padding:2rem;
}
.cta-band{
  background:var(--black);color:#fff;border-radius:var(--radius);padding:2.5rem;
  display:flex;align-items:center;justify-content:space-between;gap:1.5rem;flex-wrap:wrap;
}
.cta-band h3{font-size:1.6rem}
.cta-band .row-btns{display:flex;gap:.75rem;flex-wrap:wrap}

/* ---------- About licence list ---------- */
.lic-list{margin:1.25rem 0 0;display:grid;gap:.6rem}
.lic-list li{position:relative;padding:0 0 0 1.4rem;font-size:.95rem;color:var(--muted-dark)}
.lic-list li:before{content:"";position:absolute;left:.2rem;top:.45rem;width:.5rem;height:.5rem;border-radius:50%;background:var(--gold)}
.lic-list b{color:var(--black)}

/* ============================================================
   Homepage content blocks (hero intro, services, rates, areas)
   ============================================================ */

/* ---------- Hero intro + CTA note + trust badges ---------- */
.hero-intro{margin:0 0 1.5rem;max-width:34rem;color:var(--muted-darker);font-size:1.05rem;line-height:1.55}
.hero-cta-note{margin:.75rem 0 0;font-size:.9rem;font-weight:600;color:var(--muted-dark)}
.trust-badge{
  flex:1;display:flex;flex-direction:row;align-items:center;gap:.7rem;
  background:#fff;border-radius:var(--radius);box-shadow:var(--shadow);padding:.8rem 1rem;
  transition:box-shadow .4s ease;
}
.trust-badge:hover{box-shadow:0 4px 16px rgba(12,10,10,.16)}
.trust-badge__ic{
  width:1.9rem;height:1.9rem;border-radius:50%;background:var(--gold);color:var(--black);
  display:inline-flex;align-items:center;justify-content:center;font-size:.95rem;font-weight:800;flex:none;
}
.trust-badge__text{display:flex;flex-direction:column;line-height:1.15;gap:.12rem;text-align:left}
.trust-badge__text b{font-size:1rem;font-weight:800;line-height:1.1;color:var(--black)}
.trust-badge__text small{font-size:.78rem;color:var(--muted-dark)}

/* ---------- Section lead paragraph ---------- */
.section-lead{max-width:46rem;margin:0 auto 2.5rem;color:var(--muted-dark);font-size:1.05rem;line-height:1.55}

/* ---------- Services (Auckland) cards ---------- */
.section-services-au h2{max-width:52rem;margin-inline:auto}
.svc-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem;margin:0 0 2.25rem}
@media (max-width:992px){.svc-grid{grid-template-columns:repeat(2,1fr)}}
@media (max-width:576px){.svc-grid{grid-template-columns:1fr}}
.svc-card{
  display:flex;flex-direction:column;background:#fff;border:1px solid var(--border);border-radius:var(--radius);
  padding:1.5rem;text-align:left;
  transition:border-color .3s ease-out,box-shadow .3s ease-out,transform .3s ease-out;
}
.svc-card:hover{border-color:var(--gold-deep);box-shadow:0 10px 28px rgba(12,10,10,.10);transform:translateY(-3px)}
.svc-card h3{font-size:1.2rem;font-weight:800;text-transform:none;letter-spacing:-.01em;margin:0 0 .75rem}
.svc-card p{font-size:.92rem;color:var(--muted-darker);line-height:1.5;flex:1;margin:0 0 1rem}
.svc-card__more{font-weight:800;color:var(--gold-deep);font-size:.9rem;transition:color .3s ease-out}
.svc-card:hover .svc-card__more{color:var(--gold-deeper)}

/* ---------- Rates ---------- */
.section-rates{background:var(--gray-bg)}
.rate-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem;margin:0 0 3rem}
@media (max-width:768px){.rate-cards{grid-template-columns:1fr}}
.rate-card{background:#fff;border-radius:var(--radius);box-shadow:var(--shadow);padding:1.75rem;text-align:center}
.rate-card__fig{font-size:2.5rem;font-weight:900;color:var(--gold-deep);line-height:1;letter-spacing:-.02em;margin:0 0 .75rem}
.rate-card__fig span{font-size:1.1rem;font-weight:800;color:var(--muted-dark)}
.rate-card p{font-size:.95rem;color:var(--muted-darker);line-height:1.5;margin:0}
.rate-table-head{font-size:1.5rem;margin:0 0 1.25rem}
.rate-table-wrap{overflow-x:auto;margin:0 0 1rem}
.rate-table{width:100%;border-collapse:collapse;background:#fff;border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow);min-width:34rem}
.rate-table th,.rate-table td{padding:1rem 1.25rem;text-align:left;border-bottom:1px solid var(--gray-bg)}
.rate-table thead th{background:var(--black);color:#fff;font-size:.8rem;font-weight:800;text-transform:uppercase;letter-spacing:.02em}
.rate-table tbody tr:last-child td{border-bottom:0}
.rate-table tbody tr:nth-child(even){background:#faf9fb}
.rate-table td:last-child{font-weight:800;color:var(--gold-deep);white-space:nowrap}
.rate-table td:first-child{font-weight:600}
.rate-note{font-size:.9rem;color:var(--muted);max-width:48rem;margin:0 0 2rem}
.rate-incl{display:grid;gap:.85rem;margin:0 0 2rem}
.rate-incl p{margin:0;font-size:.98rem;color:var(--muted-darker);line-height:1.55}
.rate-incl b{color:var(--black)}
.rate-fixed{max-width:46rem;margin:0 auto 1.5rem;font-size:1.05rem;color:var(--black);font-weight:600}

/* ---------- Service areas ---------- */
.section-areas h2{max-width:48rem;margin-inline:auto}
.area-pills{display:flex;flex-wrap:wrap;justify-content:center;gap:.6rem;margin:0 auto 2rem;max-width:48rem}
.area-pills span{
  background:var(--gold-pale);color:var(--gold-deep);border-radius:2rem;
  padding:.55rem 1.1rem;font-weight:700;font-size:.95rem;
}
.area-note{max-width:44rem;margin:0 auto;color:var(--muted-dark);font-size:1rem;line-height:1.55}

/* ---------- Home call-to-action band ---------- */
.section-cta{background:var(--black);color:#fff;text-align:center}
.cta-inner{max-width:46rem;margin:0 auto}
.section-cta h2{color:#fff}
.section-cta p{color:rgba(255,255,255,.82);font-size:1.05rem;line-height:1.55;margin:0 0 2rem}
.cta-actions{display:flex;gap:.75rem;justify-content:center;flex-wrap:wrap}

/* ============================================================
   Service page (House / Residential Moving)
   ============================================================ */
.section-alt{background:var(--gray-bg)}

.breadcrumb{font-size:.85rem;color:var(--muted)}
.breadcrumb a{color:var(--muted);transition:color .3s ease-out}
.breadcrumb a:hover{color:var(--gold-deep)}
.breadcrumb span{color:var(--muted-darker);font-weight:600}

.prose{max-width:48rem;margin:0 auto}
.prose p{color:var(--muted-darker);font-size:1.02rem;line-height:1.6;margin:0 0 1.1rem}
.prose p:last-child{margin-bottom:0}
.prose .founder{background:var(--gold-pale);border-radius:var(--radius);padding:1.25rem 1.5rem;font-size:.96rem;color:var(--muted-dark)}

.info-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(15.5rem,1fr));gap:1rem;margin:0 0 2.25rem}
.info-card{background:#fff;border:1px solid var(--border);border-radius:var(--radius);padding:1.5rem}
.info-card h3{font-size:1.15rem;font-weight:800;text-transform:none;letter-spacing:-.01em;margin:0 0 .75rem}
.info-card p{font-size:.93rem;color:var(--muted-darker);line-height:1.55;margin:0}
.info-card a{color:var(--gold-deep);font-weight:700}
.info-card a:hover{color:var(--gold-deeper)}

.steps{display:grid;grid-template-columns:repeat(3,1fr);gap:1.25rem;margin:0 0 2rem}
@media (max-width:768px){.steps{grid-template-columns:1fr}}
.step{background:#fff;border:1px solid var(--border);border-radius:var(--radius);padding:1.5rem}
.step__n{width:2.5rem;height:2.5rem;border-radius:50%;background:var(--gold-deep);color:#fff;font-weight:900;display:flex;align-items:center;justify-content:center;font-size:1.1rem;margin:0 0 .9rem}
.step h3{font-size:1.1rem;font-weight:800;text-transform:none;margin:0 0 .75rem}
.step p{font-size:.92rem;color:var(--muted-darker);line-height:1.55;margin:0}
.included{max-width:48rem;margin:0 auto;background:var(--gold-pale);border-radius:var(--radius);padding:1.5rem 1.75rem}
.included p{margin:0;color:var(--muted-darker);line-height:1.6;font-size:.98rem}
.included p+p{margin-top:.8rem}
.included b{color:var(--black)}

.check-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.75rem;max-width:62rem;margin:0 auto}
@media (max-width:768px){.check-grid{grid-template-columns:1fr}}
.check-col h3{font-size:.95rem;font-weight:800;text-transform:uppercase;letter-spacing:.04em;color:var(--gold-deep);margin:0 0 1rem;padding:0 0 .6rem;border-bottom:1px solid var(--border)}

.related-links{display:flex;flex-wrap:wrap;justify-content:center;gap:.6rem;margin:0 auto;max-width:52rem}
.related-links a{
  background:#fff;border:1px solid var(--border);border-radius:2rem;padding:.55rem 1.1rem;
  font-weight:700;font-size:.92rem;color:var(--black);
  transition:color .3s ease-out,border-color .3s ease-out,background .3s ease-out;
}
.related-links a:hover{background:var(--gold-deeper);border-color:var(--gold-deeper);color:#fff}

/* ---------- Brand logo (image) ---------- */
.logo img{height:44px;width:auto;display:block;align-self:flex-start}
.mnav__logo img{height:38px;width:auto;display:block}
.footer-brand{display:inline-block;margin:0 0 2.25rem}
.footer-brand img{height:48px;width:auto;display:block}

/* ---------- Breadcrumb inside hero ---------- */
.section-hero--inner{padding-top:0}
.section-hero .breadcrumb{padding:15px 0}

/* ---------- Common-items multi-column list ---------- */
.item-cols{columns:3;column-gap:2.5rem;max-width:60rem;margin:0 auto}
.item-cols li{break-inside:avoid}
@media (max-width:768px){.item-cols{columns:2}}
@media (max-width:480px){.item-cols{columns:1}}
.list-narrow{max-width:46rem;margin:0 auto}

/* ---------- Feature icon chips (why-us, services, blog) ---------- */
.feat-ic{display:inline-flex;align-items:center;justify-content:center;width:3.5rem;height:3.5rem;border-radius:.9rem;background:var(--gold-pale);color:var(--gold-dark);flex:none}
.feat-ic svg{width:1.85rem;height:1.85rem;display:block}
.icon-box .feat-ic{margin:0 0 1rem}
.blog-item.last .feat-ic{width:4.25rem;height:4.25rem;border-radius:1.1rem}
.blog-item.last .feat-ic svg{width:2.2rem;height:2.2rem}