/* =====================================================================
   Alpha Environmental Services — Design System
   A1A Marketing & Consulting · brand: eco-green, polished from logo
   ===================================================================== */

/* ---------- Tokens ---------- */
:root{
  --green-700:#0e2a4e;
  --green-600:#1c4e87;
  --green-500:#2a5e9e;
  --eco-400:#5b9bd5;
  --eco-300:#9cc3ea;
  --sand-300:#D9C7A3;
  --sand-100:#F1EADB;
  --ink:#18212e;
  --muted:#5a6675;
  --paper:#f4f7fb;
  --sand-50:#FBF7EF;
  --warm-line:#E7DECB;
  --white:#FFFFFF;
  --line:#e2e8f0;
  --ring:rgba(28,78,135,.40);
  --shadow-sm:0 1px 2px rgba(16,33,55,.05),0 2px 4px rgba(16,33,55,.06);
  --shadow-md:0 4px 6px rgba(16,33,55,.05),0 12px 24px rgba(14,42,78,.10),0 2px 6px rgba(14,42,78,.06);
  --shadow-lg:0 8px 16px rgba(12,30,58,.08),0 30px 60px rgba(12,30,58,.16);
  --shadow-hover:0 6px 10px rgba(16,33,55,.06),0 20px 40px rgba(14,42,78,.16);
  --r-sm:10px; --r-md:16px; --r-lg:24px; --r-pill:999px;
  --container:1180px;
  --ease:cubic-bezier(.22,.61,.36,1);
}

/* ---------- Reset ---------- */
*,*::before,*::after{box-sizing:border-box}
*{margin:0}
html{-webkit-text-size-adjust:100%;scroll-behavior:smooth}
body{
  font-family:"Lato",system-ui,-apple-system,Segoe UI,Roboto,sans-serif;
  color:var(--ink);background:var(--paper);
  font-size:1.0625rem;line-height:1.7;-webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;overflow-x:hidden;
}
img,svg,video{display:block;max-width:100%}
img{height:auto}
a{color:var(--green-600);text-decoration:none}
a:hover{color:var(--green-700)}
ul{list-style:none;padding:0}
button{font:inherit;cursor:pointer}
:focus-visible{outline:3px solid var(--ring);outline-offset:2px;border-radius:6px}
h1,h2,h3,h4{font-family:"Roboto Slab",Georgia,serif;line-height:1.12;color:var(--green-700);font-weight:700;letter-spacing:-.01em}

/* ---------- Layout ---------- */
.container{width:100%;max-width:var(--container);margin-inline:auto;padding-inline:clamp(1.1rem,4vw,2rem)}
.section{padding-block:clamp(3.4rem,7vw,6rem)}
.section--alt{background:linear-gradient(180deg,var(--sand-50), var(--sand-100))}
.section--tint{background:var(--white)}
.section--dark{background:var(--green-700);color:#e7eff8}
.section--dark h1,.section--dark h2,.section--dark h3{color:#fff}
.section--dark .lead{color:#cfdef2}
.center{text-align:center}
.measure{max-width:62ch}
.measure-center{max-width:64ch;margin-inline:auto}
.grid{display:grid;gap:clamp(1rem,2.4vw,1.7rem)}
.grid--2{grid-template-columns:repeat(2,1fr)}
.grid--3{grid-template-columns:repeat(3,1fr)}
.grid--4{grid-template-columns:repeat(4,1fr)}
.split{display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(1.6rem,4vw,3.4rem);align-items:stretch}
.split--center{align-items:center}
.split--start{align-items:start}

/* ---------- Type helpers ---------- */
.eyebrow{display:inline-flex;align-items:center;gap:.55rem;padding:.34rem .8rem;border-radius:var(--r-pill);background:var(--green-600);border:1px solid var(--green-600);font-family:"Lato";font-weight:700;text-transform:uppercase;letter-spacing:.12em;font-size:.74rem;color:#fff}
.section--dark .eyebrow{background:var(--green-600);border-color:rgba(255,255,255,.5);color:#fff}
.eyebrow::before{content:none}
h1{font-size:clamp(2.2rem,5.2vw,3.6rem)}
h2{font-size:clamp(1.7rem,3.6vw,2.55rem)}
h3{font-size:clamp(1.18rem,1.9vw,1.4rem)}
.lead{font-size:clamp(1.08rem,1.6vw,1.28rem);color:var(--muted);line-height:1.65}
.muted{color:var(--muted)}
.text-stack > * + *{margin-top:1rem}
.text-stack > p{max-width:66ch}

/* ---------- Buttons ---------- */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:.6rem;
  font-family:"Lato";font-weight:700;font-size:1rem;line-height:1;
  padding:.95rem 1.5rem;border-radius:var(--r-pill);border:2px solid transparent;
  transition:transform .18s var(--ease),box-shadow .18s var(--ease),background .18s,color .18s,border-color .18s;
  white-space:nowrap;cursor:pointer}
.btn svg{width:20px;height:20px;flex:none}
/* Solid NAVY buttons — white text (black on navy fails contrast) */
.btn--primary{background:var(--green-600);color:#fff;box-shadow:var(--shadow-sm)}
.btn--primary:hover{background:var(--green-700);color:#fff;transform:translateY(-2px);box-shadow:var(--shadow-md)}
.btn--accent{background:var(--green-600);color:#fff;box-shadow:var(--shadow-md)}
.btn--accent:hover{background:var(--green-700);color:#fff;transform:translateY(-2px);box-shadow:var(--shadow-lg)}
/* WHITE buttons — black text, navy border */
.btn--ghost{background:#fff;color:#111;border-color:var(--green-600)}
.btn--ghost:hover{background:var(--paper);color:#111;border-color:var(--green-700);transform:translateY(-2px)}
.btn--on-dark{background:#fff;color:#111}
.btn--on-dark:hover{background:#eef2f8;color:#111;transform:translateY(-2px)}
/* Secondary on dark navy bands — navy fill, white text, white outline for visibility */
.btn--ghost-light{background:var(--green-600);color:#fff;border-color:#fff}
.btn--ghost-light:hover{background:#fff;color:#111;border-color:#fff;transform:translateY(-2px)}
.btn--lg{padding:1.1rem 1.9rem;font-size:1.08rem}
.btn--block{width:100%}

/* ---------- Header ---------- */
.topbar{background:var(--green-700);color:#d6e6f3;color:#d7e6f5;font-size:.86rem}
.topbar .container{display:flex;align-items:center;justify-content:space-between;gap:1rem;padding-block:.5rem}
.topbar a{color:#fff}
.topbar__left{display:flex;gap:1.4rem;align-items:center;flex-wrap:wrap}
.topbar__item{display:inline-flex;align-items:center;gap:.45rem;color:#d7e6f5}
.topbar__item svg{width:15px;height:15px;color:var(--eco-300)}
.topbar__phone{font-weight:700;color:#fff}
.topbar__phone:hover{color:var(--eco-300)}
.topbar__badges{display:inline-flex;gap:.6rem;align-items:center}
.topbar__badge{display:inline-flex;align-items:center;gap:.35rem;font-weight:700;color:#fff}
.topbar__badge svg{color:var(--eco-300)}

.site-header{position:sticky;top:0;z-index:60;background:rgba(255,255,255,.92);
  backdrop-filter:saturate(140%) blur(10px);border-bottom:1px solid var(--line);
  transition:box-shadow .2s}
.site-header.is-stuck{box-shadow:var(--shadow-md)}
.site-header .container{display:flex;align-items:center;justify-content:space-between;gap:1.2rem;min-height:74px}
.brand{display:inline-flex;align-items:center;gap:.7rem;flex:none}
.brand svg,.brand img{height:46px;width:auto}
.brand__txt{display:flex;flex-direction:column;line-height:1}
.brand__name{font-family:"Roboto Slab";font-weight:800;font-size:1.32rem;color:var(--green-600);letter-spacing:-.02em}
.brand__sub{font-family:"Lato";font-weight:700;font-size:.58rem;letter-spacing:.13em;color:var(--muted);text-transform:uppercase;margin-top:2px;white-space:nowrap}

.nav{display:flex;align-items:center;gap:.18rem}
.nav a{font-family:"Lato";font-weight:700;color:var(--ink);padding:.55rem .66rem;border-radius:8px;font-size:.95rem;position:relative;white-space:nowrap}
.nav a:hover{color:var(--green-600);background:rgba(91,155,213,.14)}
.nav a[aria-current="page"]{color:var(--green-600)}
.nav a[aria-current="page"]::after{content:"";position:absolute;left:.8rem;right:.8rem;bottom:.28rem;height:2px;background:var(--eco-400);border-radius:2px}
.header-cta{display:flex;align-items:center;gap:.6rem;flex:none}
.nav-toggle{display:none;width:46px;height:46px;border:1px solid var(--line);background:#fff;border-radius:10px;align-items:center;justify-content:center}
.nav-toggle svg{width:24px;height:24px;color:var(--green-700)}

/* ---------- Hero ---------- */
.hero{position:relative;overflow:hidden;color:#fff;background:#0e2a4e url("../images/hero-truck-v3.jpg") center right/cover no-repeat}
.hero::after{content:"";position:absolute;inset:0;pointer-events:none;z-index:1;background:linear-gradient(90deg,rgba(7,15,26,.93) 0%,rgba(7,15,26,.74) 30%,rgba(7,15,26,.36) 55%,rgba(7,15,26,0) 80%),linear-gradient(0deg,rgba(7,15,26,.5),transparent 45%)}
.hero__inner{position:relative;z-index:2;display:grid;grid-template-columns:1.08fr .92fr;
  gap:clamp(1.5rem,4vw,3.2rem);align-items:center;padding-block:clamp(3rem,7vw,5.4rem)}
.hero__copy{position:relative;z-index:2}
.hero h1{color:#fff;max-width:16ch}
.hero .lead{color:#cfe0f2;max-width:54ch}
.hero__cta{display:flex;flex-wrap:wrap;gap:.8rem;margin-top:1.7rem}
.hero__trust{display:flex;flex-wrap:wrap;gap:1.1rem 1.6rem;margin-top:1.9rem;padding-top:1.5rem;border-top:1px solid rgba(255,255,255,.16)}
.hero__trust-item{display:flex;align-items:center;gap:.5rem;font-weight:700;font-size:.95rem;color:#e6eff7}
.hero__trust-item svg{width:20px;height:20px;color:var(--eco-400);flex:none}
.hero__media{position:relative}
.hero-card{background:rgba(255,255,255,.97);color:var(--ink);border-radius:var(--r-lg);
  box-shadow:var(--shadow-lg);padding:clamp(1.3rem,2.4vw,1.9rem)}
.hero-card h3{color:var(--green-700)}
.hero-photo{border-radius:var(--r-lg);box-shadow:var(--shadow-lg);overflow:hidden;aspect-ratio:4/3;position:relative}
.hero-photo img{width:100%;height:100%;object-fit:cover}
.hero-photo::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 50%,rgba(14,42,78,.35))}

/* ---------- Trust bar ---------- */
.trust-bar{background:var(--white);border-bottom:1px solid var(--line)}
.trust-bar .container{display:flex;flex-wrap:wrap;justify-content:center;gap:1rem 2.4rem;padding-block:1.1rem}
.trust-bar__item{display:inline-flex;align-items:center;gap:.55rem;font-weight:700;color:var(--green-700);font-size:.96rem}
.trust-bar__item svg{width:22px;height:22px;color:var(--green-600)}

/* ---------- Section headers ---------- */
.section-head{max-width:64ch;margin-inline:auto;text-align:center;margin-bottom:clamp(1.8rem,4vw,2.8rem)}
.section-head .lead{margin-top:.8rem}
.section-head--left{margin-inline:0;text-align:left}

/* ---------- Cards / services ---------- */
.card{position:relative;background:#fff;overflow:hidden;border:1px solid var(--line);border-radius:var(--r-md);padding:clamp(1.6rem,2.6vw,2.1rem);box-shadow:var(--shadow-sm);transition:transform .2s var(--ease),box-shadow .2s,border-color .2s}
.card > * + *{margin-top:.9rem}
.card h3{color:var(--green-700);font-size:1.2rem}
.card p{color:var(--muted);font-size:1rem;line-height:1.6}
.card::before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--eco-400),var(--green-500));transform:scaleX(0);transform-origin:left;transition:transform .35s var(--ease)}
.card:hover::before{transform:scaleX(1)}
.card:hover{transform:translateY(-6px);box-shadow:var(--shadow-hover),inset 0 1px 0 rgba(255,255,255,.7);border-color:var(--eco-300)}
.service-card--cta::before{display:none}
.service-card{display:flex;flex-direction:column;gap:.85rem;height:100%}
.card__icon{width:54px;height:54px;border-radius:15px;display:flex;align-items:center;justify-content:center;
  background:linear-gradient(150deg,var(--green-500),var(--green-700));color:#fff;box-shadow:0 6px 14px rgba(28,78,135,.20);position:relative;transition:transform .25s var(--ease),box-shadow .25s var(--ease)}
.card__icon::after{display:none}
.card:hover .card__icon{transform:translateY(-2px);box-shadow:0 9px 18px rgba(28,78,135,.26)}
.card__icon svg{width:28px;height:28px;color:#fff}
.service-card h3{color:var(--green-700)}
.service-card p{color:var(--muted);font-size:1rem}
.service-card .more{margin-top:auto;font-weight:700;color:var(--green-600);display:inline-flex;align-items:center;gap:.4rem}
.service-card .more svg{width:16px;height:16px;transition:transform .2s}
.service-card:hover .more svg{transform:translateX(4px)}
.service-card--cta{background:linear-gradient(150deg,var(--green-600),var(--green-700));color:#fff;border:none}
.service-card--cta h3{color:#fff}
.service-card--cta p{color:#d6e6f5}
.service-card--cta .card__icon{background:rgba(255,255,255,.16);box-shadow:none}
.service-card--cta .btn{margin-top:auto}

/* feature row (why us) */
.feature{display:flex;gap:1rem;align-items:flex-start}
.feature__ic{width:48px;height:48px;border-radius:12px;flex:none;display:flex;align-items:center;justify-content:center;background:rgba(91,155,213,.18);color:var(--green-600);transition:background .25s var(--ease),transform .25s var(--ease)}
.feature__ic svg{width:25px;height:25px}
.feature h3{font-size:1.12rem;margin-bottom:.25rem;color:var(--green-700)}
.feature p{color:var(--muted);font-size:.98rem}
.feature:hover .feature__ic{background:rgba(91,155,213,.30);transform:translateY(-2px)}
.section--dark .feature__ic{background:rgba(255,255,255,.1);color:var(--eco-300)}
.section--dark .feature p{color:#c6d8ee}

/* stats */
.stat{ text-align:center;padding:1.2rem}
.stat__n{font-family:"Roboto Slab";font-weight:800;font-size:clamp(2.2rem,4.5vw,3rem);color:var(--green-600);line-height:1}
.section--dark .stat__n{color:var(--eco-400)}
.stat__l{font-weight:700;color:var(--muted);margin-top:.35rem;font-size:.95rem}
.section--dark .stat__l{color:#cfdef2}

/* check list */
.check-list{display:grid;gap:.7rem}
.check-list li{display:flex;gap:.7rem;align-items:flex-start;color:var(--ink)}
.check-list li svg{width:22px;height:22px;color:var(--green-600);flex:none;margin-top:1px}
.section--dark .check-list li{color:#e5eef8}
.section--dark .check-list li svg{color:var(--eco-400)}

/* area cards */
.area-card{background:#fff;border:1px solid var(--line);border-radius:var(--r-md);padding:1.5rem;box-shadow:var(--shadow-sm)}
.area-card h3{display:flex;align-items:center;gap:.55rem;color:var(--green-700)}
.area-card h3 svg{width:22px;height:22px;color:var(--green-600)}
.area-card ul{display:flex;flex-wrap:wrap;gap:.4rem;margin-top:.9rem}
.area-card li{background:var(--sand-100);border:1px solid var(--warm-line);color:var(--green-700);font-weight:700;font-size:.88rem;padding:.32rem .7rem;border-radius:var(--r-pill)}

/* steps */
.steps{counter-reset:step;display:grid;gap:1.2rem}
.step{display:flex;gap:1.1rem;align-items:flex-start}
.step__n{counter-increment:step;flex:none;width:46px;height:46px;border-radius:50%;background:var(--green-600);color:#fff;font-family:"Roboto Slab";font-weight:800;display:flex;align-items:center;justify-content:center}
.step__n::before{content:counter(step)}

/* ---------- FAQ ---------- */
.faq{background:#fff;border:1px solid var(--line);border-radius:var(--r-md);overflow:hidden;box-shadow:var(--shadow-sm)}
.faq + .faq{margin-top:.7rem}
.faq summary{display:flex;justify-content:space-between;align-items:center;gap:1rem;cursor:pointer;
  padding:1.15rem 1.35rem;font-family:"Roboto Slab";font-weight:600;color:var(--green-700);font-size:1.06rem;list-style:none;transition:background .2s var(--ease),color .2s var(--ease)}
.faq summary::-webkit-details-marker{display:none}
.faq summary:hover{background:rgba(91,155,213,.08)}
.faq summary:hover .chev{transform:translateY(1px)}
.faq summary .chev{flex:none;width:24px;height:24px;color:var(--green-600);transition:transform .25s}
.faq[open] summary .chev{transform:rotate(180deg) scale(1.05)}
.faq[open] .faq__body{animation:faqIn .28s var(--ease)}
@keyframes faqIn{from{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:none}}
.faq__body{padding:0 1.35rem 1.25rem;color:var(--muted)}

/* ---------- CTA band ---------- */
.cta-band{position:relative;overflow:hidden;background:linear-gradient(120deg,var(--green-600),var(--green-700));color:#fff}
.cta-band::after{content:"";position:absolute;right:-60px;top:-40px;width:280px;height:280px;border-radius:50%;background:radial-gradient(circle,rgba(91,155,213,.35),transparent 70%)}
.cta-band .container{position:relative;z-index:2;display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:1.4rem;padding-block:clamp(2.2rem,4vw,3rem)}
.cta-band h2{color:#fff;max-width:22ch}
.cta-band p{color:#d6e6f5;margin-top:.4rem}
.cta-band__actions{display:flex;flex-wrap:wrap;gap:.8rem}

/* ---------- Forms ---------- */
.form{background:#fff;border:1px solid var(--line);border-radius:var(--r-lg);padding:clamp(1.4rem,3vw,2.2rem);box-shadow:var(--shadow-md)}
.form .row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
.field{display:flex;flex-direction:column;gap:.4rem;margin-bottom:1rem}
.field label{font-weight:700;color:var(--green-700);font-size:.92rem}
.field input,.field select,.field textarea{
  font:inherit;font-size:1rem;color:var(--ink);background:var(--paper);
  border:1.5px solid var(--line);border-radius:var(--r-sm);padding:.8rem .9rem;width:100%;transition:border-color .15s,box-shadow .15s}
.field input:hover,.field select:hover,.field textarea:hover{border-color:var(--eco-300)}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--green-600);box-shadow:0 0 0 3px var(--ring)}
.field textarea{min-height:120px;resize:vertical}
.form__note{font-size:.85rem;color:var(--muted);margin-top:.3rem}
.form__status{padding:.7rem .9rem;border-radius:var(--r-sm);font-size:.9rem;font-weight:700;margin-top:.8rem}
.form__status.is-success{background:rgba(91,155,213,.20);color:var(--green-700);border:1px solid var(--eco-400)}
.form__status.is-error{background:rgba(192,57,43,.10);color:#C0392B;border:1px solid rgba(192,57,43,.35)}

/* contact info list */
.info-list{display:grid;gap:1.1rem}
.info-list li{display:flex;gap:.9rem;align-items:flex-start}
.info-list .ic{width:46px;height:46px;border-radius:12px;flex:none;display:flex;align-items:center;justify-content:center;background:rgba(91,155,213,.18);color:var(--green-600)}
.info-list .ic svg{width:23px;height:23px}
.info-list b{display:block;color:var(--green-700)}
.info-list a{font-weight:700}
.hours-table{width:100%;border-collapse:collapse}
.hours-table td{padding:.5rem 0;border-bottom:1px solid var(--line);color:var(--ink)}
.hours-table td:last-child{text-align:right;font-weight:700;color:var(--green-700)}
.hours-table tr.today td{color:var(--green-600)}

/* map frame */
.map-embed{border-radius:var(--r-md);overflow:hidden;box-shadow:var(--shadow-sm);border:1px solid var(--line);background:#e7ecf2}
.map-embed iframe{display:block;width:100%;height:320px;border:0}

/* page hero (interior) */
.page-hero{position:relative;background:radial-gradient(60% 90% at 10% -20%,rgba(91,155,213,.28),transparent 60%),radial-gradient(70% 120% at 100% 0%,rgba(28,78,135,.55),transparent 60%),linear-gradient(120deg,#0e2a4e,#1c4e87);color:#fff;overflow:hidden;border-bottom:3px solid rgba(217,199,163,.35)}
.page-hero::before{content:"";position:absolute;inset:0;z-index:1;pointer-events:none;background:radial-gradient(120% 70% at 50% 130%,rgba(6,18,40,.45),transparent 55%)}
.page-hero::after{content:"";position:absolute;inset:0;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='80' height='80'%3E%3Cpath d='M0 60 Q20 40 40 60 T80 60' fill='none' stroke='%235B9BD5' stroke-opacity='.12' stroke-width='1.3'/%3E%3C/svg%3E")}
.page-hero .container{position:relative;z-index:2;padding-block:clamp(3rem,7vw,4.8rem)}
.page-hero h1{color:#fff;max-width:20ch}
.page-hero .lead{color:#cfe0f2;max-width:56ch;margin-top:.7rem}
.page-hero .eyebrow{background:var(--green-600);border-color:rgba(255,255,255,.5);color:#fff}
.page-hero__cta{display:flex;flex-wrap:wrap;gap:.8rem;margin-top:1.4rem}
.crumbs{font-size:.85rem;color:#b8d0ec;margin-bottom:.7rem}
.crumbs a{color:#d8e8f6}
.crumbs span{opacity:.6}

/* eco divider */
.leaf-bullet{color:var(--green-600)}

/* badges */
.badge{display:inline-flex;align-items:center;gap:.4rem;background:rgba(91,155,213,.18);color:var(--green-700);font-weight:700;font-size:.82rem;padding:.3rem .7rem;border-radius:var(--r-pill)}
.badge svg{width:15px;height:15px}

/* ---------- Footer ---------- */
.site-footer{background:var(--green-700);color:#cdd9ea;padding-block:clamp(2.6rem,5vw,3.6rem) 0}
.site-footer a{color:#cdd9ea}
.site-footer a:hover{color:#fff}
.footer-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1.2fr;gap:2rem}
.footer-brand .brand__name{color:#fff}
.footer-brand .brand__sub{color:var(--eco-300)}
.footer-brand p{margin-top:.9rem;font-size:.95rem;color:#b6cae6;max-width:34ch}
.footer-col h4{color:#fff;font-family:"Roboto Slab";font-size:1.02rem;margin-bottom:.9rem}
.footer-col ul{display:grid;gap:.5rem}
.footer-col li{font-size:.96rem}
.footer-contact li{display:flex;gap:.6rem;align-items:flex-start;margin-bottom:.6rem;font-size:.95rem}
.footer-contact svg{width:18px;height:18px;color:var(--eco-300);flex:none;margin-top:2px}
.footer-bottom{border-top:1px solid rgba(255,255,255,.14);margin-top:2.4rem;padding-block:1.3rem;
  display:flex;flex-wrap:wrap;justify-content:space-between;gap:.6rem;font-size:.85rem;color:#9cb4d2}
.footer-bottom a{color:#cdd9ea}

/* ---------- Sticky mobile call bar ---------- */
.callbar{position:fixed;left:0;right:0;bottom:0;z-index:70;display:none;
  background:var(--green-700);box-shadow:0 -6px 20px rgba(0,0,0,.18);padding:.55rem .8rem;
  gap:.6rem;align-items:center}
.callbar a{flex:1;justify-content:center}
.callbar .btn{padding:.8rem 1rem}

/* ---------- Reveal animation ---------- */
.reveal{opacity:0;transform:translateY(18px);transition:opacity .6s var(--ease),transform .6s var(--ease)}
.reveal.in{opacity:1;transform:none}

/* ---------- Utilities ---------- */
.mt-0{margin-top:0}.mt-1{margin-top:.6rem}.mt-2{margin-top:1.2rem}.mt-3{margin-top:1.8rem}.mt-4{margin-top:2.4rem}
.flex{display:flex}.wrap{flex-wrap:wrap}.gap{gap:1rem}.gap-sm{gap:.6rem}.items-center{align-items:center}.justify-center{justify-content:center}
.hide{display:none}
.skip-link{position:absolute;left:-999px;top:0;background:#fff;color:var(--green-700);padding:.6rem 1rem;z-index:200;border-radius:0 0 8px 0;font-weight:700}
.skip-link:focus{left:0}

/* ---------- Responsive ---------- */
@media (max-width:1240px){
  /* free up header room: phone lives in topbar + mobile call bar */
  .btn--phone-text{display:none}
  .nav a{padding:.55rem .62rem}
}
@media (max-width:1024px){
  .hero__inner{grid-template-columns:1fr;gap:2rem}
  .hero__media{max-width:560px;width:100%}
  .split{grid-template-columns:1fr;gap:2rem}
  .grid--3{grid-template-columns:repeat(2,1fr)}
  .grid--4{grid-template-columns:repeat(2,1fr)}
  .footer-grid{grid-template-columns:1fr 1fr;gap:1.6rem}
  .footer-brand{grid-column:1 / -1}
  /* header simplifies to hamburger as soon as the layout stacks */
  .nav,.header-cta .btn--phone-text,.header-cta .btn--accent{display:none}
  .nav-toggle{display:inline-flex}
  .site-header .container{min-height:64px}
  .nav.open{display:flex;position:absolute;top:100%;left:0;right:0;flex-direction:column;align-items:stretch;
    background:#fff;border-bottom:1px solid var(--line);padding:.6rem;gap:.2rem;box-shadow:var(--shadow-md)}
  .nav.open a{padding:.85rem 1rem;border-radius:8px;min-height:44px;display:flex;align-items:center}
  .cta-band .container{flex-direction:column;align-items:flex-start}
  .callbar{display:flex}
  body{padding-bottom:64px}
}
@media (max-width:860px){
  .topbar__left{gap:1rem}
  .form .row{grid-template-columns:1fr}
}
@media (max-width:600px){
  .grid--2,.grid--3,.grid--4{grid-template-columns:1fr}
  .topbar .container{justify-content:center}
  .topbar__badges{display:none}
  .cta-band .container{flex-direction:column;align-items:flex-start}
  .footer-grid{grid-template-columns:1fr}
  .hero__cta{flex-direction:column;align-items:stretch}
  .hero__cta .btn{width:100%}
}
@media (prefers-reduced-motion:reduce){
  *{scroll-behavior:auto!important}
  .reveal{opacity:1;transform:none;transition:none}
  .btn:hover,.btn:active,.card:hover,.card:hover .card__icon,.feature:hover .feature__ic,.service-card:hover .more svg,.faq summary:hover .chev{transform:none!important}
  .faq[open] .faq__body{animation:none}
}

/* ---------- Real logo + Get Ready to Sell page ---------- */
.brand__logo{height:46px;width:auto;display:block}
.pricing-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(1rem,2.4vw,1.6rem)}
.price-card{background:#fff;border:1px solid var(--line);border-radius:var(--r-lg);padding:1.9rem 1.5rem;box-shadow:var(--shadow-sm);text-align:center;display:flex;flex-direction:column;gap:.35rem;transition:transform .2s var(--ease),box-shadow .2s,border-color .2s}
.price-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-md);border-color:var(--eco-300)}
.price-card__tier{font-family:"Lato";font-weight:700;text-transform:uppercase;letter-spacing:.1em;font-size:.78rem;color:var(--green-600)}
.price-card__amount{font-family:"Roboto Slab";font-weight:800;font-size:clamp(2.1rem,4vw,2.7rem);color:var(--green-700);line-height:1;margin:.25rem 0}
.price-card__meta{color:var(--muted);font-size:.96rem}
.price-card__driveway{font-weight:700;color:var(--ink)}
.includes-card{background:#fff;border:1px solid var(--line);border-radius:var(--r-lg);padding:clamp(1.4rem,3vw,2.3rem);box-shadow:var(--shadow-sm)}
.check-list.cols-2{grid-template-columns:1fr 1fr;gap:.85rem 1.8rem}
.check-list strong{color:var(--green-700)}
.price-note{text-align:center;color:var(--muted);margin-top:1.4rem}
.gallery{display:grid;grid-template-columns:repeat(4,1fr);gap:.8rem}
.gallery figure{margin:0;overflow:hidden;border-radius:var(--r-md);box-shadow:var(--shadow-sm)}
.gallery img{width:100%;aspect-ratio:4/3;object-fit:cover;display:block;transition:transform .3s var(--ease)}
.gallery figure:hover img{transform:scale(1.04)}
@media (max-width:860px){.pricing-grid{grid-template-columns:1fr}.check-list.cols-2{grid-template-columns:1fr}.gallery{grid-template-columns:1fr 1fr}}
@media (max-width:600px){.brand__logo{height:40px}}
@media (prefers-reduced-motion:reduce){.gallery figure:hover img{transform:none}}

/* ---------- Page-hero with media (services / areas / contact) ---------- */
.page-hero--split .container{display:grid;grid-template-columns:1.12fr .88fr;gap:clamp(1.6rem,4vw,3.2rem);align-items:center}
.page-hero__copy{position:relative;z-index:2}
.page-hero__media{position:relative;z-index:2}
.page-hero__photo{border-radius:var(--r-lg);overflow:hidden;box-shadow:var(--shadow-lg);aspect-ratio:4/3;border:1px solid rgba(255,255,255,.16)}
.page-hero__photo img{width:100%;height:100%;object-fit:cover;display:block}
.page-hero__media--sm{max-width:340px;margin-left:auto}
.page-hero__map img{width:100%;display:block;filter:drop-shadow(0 18px 40px rgba(6,18,40,.45))}
@keyframes floaty{0%,100%{transform:translateY(0)}50%{transform:translateY(-12px)}}
.float-anim{animation:floaty 6.5s ease-in-out infinite}
@media (max-width:860px){
  .page-hero--split .container{grid-template-columns:1fr}
  .page-hero__media{max-width:480px}
  .page-hero__media--sm{max-width:300px;margin:0 auto}
}
@media (prefers-reduced-motion:reduce){.float-anim{animation:none}}
/* service-area map blend + float */
.page-hero__map{position:relative;z-index:2}
.page-hero__map img{-webkit-mask-image:radial-gradient(ellipse 74% 74% at 50% 47%,#000 56%,transparent 80%);mask-image:radial-gradient(ellipse 74% 74% at 50% 47%,#000 56%,transparent 80%)}
/* transparent pre-faded map png renders without extra mask/shadow */
.page-hero__map img{-webkit-mask-image:none;mask-image:none;filter:none}


/* balanced multi-line headings */
h1,h2{text-wrap:balance}
/* static reviews */
.review-card{display:flex;flex-direction:column;gap:.85rem;height:100%}
.review-quote{width:38px;height:38px;color:var(--eco-400);flex:none}
.review-card blockquote{font-size:1.06rem;color:var(--ink);line-height:1.6;margin:0}
.review-card figcaption{margin-top:auto;display:flex;flex-direction:column;gap:.1rem;padding-top:.4rem}
.review-name{font-family:"Roboto Slab";font-weight:700;color:var(--green-700)}
.review-meta{font-size:.85rem;color:var(--muted)}
/* sky-blue backlight so the navy map reads on the navy hero (keeps the seamless blend) */
.page-hero__map{position:relative}
.page-hero__map::before{content:"";position:absolute;inset:-8%;z-index:0;pointer-events:none;
  background:radial-gradient(circle at 50% 47%, rgba(91,155,213,.34), rgba(91,155,213,.08) 52%, transparent 70%)}
.page-hero__map img{position:relative;z-index:1}
/* footer: real logo on a white chip (visible on dark footer) */
.footer-brand-logo{background:#fff;padding:.5rem .7rem;border-radius:12px;display:inline-block;line-height:0}
.footer-brand-logo img{height:44px;width:auto;display:block}
/* compact topbar trust badges: equal small icons, one line each */
.topbar__badge{white-space:nowrap}
.topbar__badge svg{width:14px;height:14px;flex:none;color:var(--eco-300)}

/* truck-photo hero sizing + mobile scrim */
.hero__inner{min-height:clamp(460px,54vh,560px);align-content:center}
.hero__copy{max-width:36rem}
@media (max-width:760px){
  .hero{background-position:center}
  .hero::after{background:linear-gradient(180deg,rgba(7,15,26,.86),rgba(7,15,26,.7) 60%,rgba(7,15,26,.82))}
}

/* On dark/navy sections, solid CTAs are white (restored) */
.hero .btn--primary,.hero .btn--accent,.page-hero .btn--primary,.page-hero .btn--accent,.section--dark .btn--primary,.section--dark .btn--accent,.cta-band .btn--primary,.cta-band .btn--accent,.service-card--cta .btn--primary,.service-card--cta .btn--accent{background:#fff;color:#111;border-color:#fff}
.hero .btn--primary:hover,.hero .btn--accent:hover,.page-hero .btn--primary:hover,.page-hero .btn--accent:hover,.section--dark .btn--primary:hover,.section--dark .btn--accent:hover,.cta-band .btn--primary:hover,.cta-band .btn--accent:hover,.service-card--cta .btn--primary:hover,.service-card--cta .btn--accent:hover{background:#e9eef6;color:#111;border-color:#fff}
/* eyebrow chip readable on dark photo/hero */
.hero .eyebrow{border-color:rgba(255,255,255,.5)}/* ---------- Large-desktop fill: HOME PAGE ONLY (all other pages keep the standard 1180px container) ---------- */
@media (min-width:1280px){
  body[data-page="home"] .container{max-width:min(94vw, 2040px)}
  body[data-page="home"] .hero .lead{max-width:60ch}
}
/* contact form: lift the submit button off the fields above it */
#leadForm button[type="submit"]{margin-top:1.6rem}
/* Why-us: stretch the stats into filled 2x2 tiles so the column fills its height (no bottom-right gap) */
/* ---------- Consistent section fill: stretch split columns, fill secondary content ---------- */
.split > .grid{height:100%;grid-template-rows:1fr 1fr}
.split > .grid > .stat{border-radius:var(--r-md);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.15rem}
.section--dark .split > .grid > .stat{background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.14)}
.section:not(.section--dark) .split > .grid > .stat{background:var(--white);border:1px solid var(--line);box-shadow:var(--shadow-sm)}
.split .area-card{height:100%}
.split .hero-photo{height:100%;aspect-ratio:auto}
.split .map-embed{height:100%}
.split .map-embed iframe{height:100%;min-height:340px}
.split > .reveal:has(> .card){display:grid;align-content:center}

/* ---------- Meeting revisions: header sizing + footer readability ---------- */
/* Services page: enlarge & bold the navy service-section headers, keep them uniform */
body[data-page="services"] .split .text-stack > h2{font-size:clamp(2rem,4.2vw,2.95rem);font-weight:800;letter-spacing:-.015em}
/* Footer: underline the column headers, bolder & brighter text for readability */
.site-footer{color:#dbe7f7}
.footer-col h4{text-decoration:underline;text-underline-offset:5px;text-decoration-thickness:2px;font-size:1.12rem}
.footer-col li{font-size:1.02rem}
.footer-col a,.footer-contact a,.footer-contact li{color:#eef4fd;font-weight:700}
.footer-col a:hover{color:#fff}
.footer-brand p{color:#d6e3f5;font-weight:600}
.footer-bottom{color:#bcccea}
/* ---------- Meeting revisions: mobile map placement + CTA breathing room ---------- */
@media (max-width:760px){
  .page-hero--split .page-hero__media{max-width:400px;margin:.6rem auto 0}
  .page-hero__map img{margin:0 auto}
  .float-anim{animation:none}
}
.includes-card + .pricing-grid, .includes-card{margin-top:.4rem}
/* ---------- Client revision: raise booking / CTA buttons higher off the text above them ---------- */
.hero__cta{margin-top:2rem}
.page-hero__cta{margin-top:2rem}
.btn.mt-1{margin-top:1.6rem}
.btn.mt-2{margin-top:2rem}
.center.mt-2{margin-top:2.1rem}
.center.mt-3{margin-top:2.7rem}
/* ---------- Homepage 3D system graphic ---------- */
.system-graphic{margin:2.2rem auto 0;max-width:1040px}
.system-graphic img{width:100%;height:auto;display:block;border-radius:18px;background:#fff;box-shadow:0 24px 60px -24px rgba(14,42,78,.4)}
