/* =================================================================
   Ellipse Surveying — Website V2
   Shared stylesheet. Built on the Ellipse Surveying brand guidelines.
   Colours, type and components all map to the brand system.
   ================================================================= */

:root{
  /* Brand palette (from guidelines) */
  --navy:#102B43;
  --navy-deep:#07182A;
  --navy-mid:#205685;
  --navy-pale:#CADDE6;
  --green:#0E451E;
  --green-deep:#0C3919;
  --green-mid:#5A956B;
  --green-pale:#B0DCBD;

  --slate:#292F33;        /* body copy */
  --mid-grey:#515E65;     /* secondary text */
  --soft-grey:#9AAEB8;    /* muted UI */
  --stone:#D4D4CF;        /* warm page surface */
  --stone-light:#ECEBE6;
  --off-white:#FAF9F6;
  --white:#FFFFFF;
  --border:#C8C8C2;
  --border-light:#E2E1DC;

  --font-display:'Montserrat', system-ui, -apple-system, sans-serif;
  --font-body:'Barlow', 'Helvetica Neue', Arial, sans-serif;

  --shadow-card:0 1px 3px rgba(16,43,67,0.08), 0 1px 2px rgba(16,43,67,0.04);
  --shadow-card-hover:0 14px 36px rgba(16,43,67,0.13);
  --shadow-header:0 1px 0 rgba(16,43,67,0.08), 0 6px 20px rgba(16,43,67,0.06);

  --maxw:1180px;
  --radius-pill:34px;
}

/* ---------- Reset ---------- */
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  font-family:var(--font-body);
  font-size:17px;
  line-height:1.7;
  color:var(--slate);
  background:var(--stone);
  -webkit-font-smoothing:antialiased;
}
img{max-width:100%;display:block}
a{color:var(--navy-mid);text-decoration:none}
a:hover{color:var(--green)}

/* ---------- Layout helpers ---------- */
.container{max-width:var(--maxw);margin:0 auto;padding:0 28px}
.section{padding:88px 0;background:var(--white)}
.section--stone{background:var(--stone)}
.section--navy{background:var(--navy-deep);color:var(--white)}
.section-head{max-width:760px;margin-bottom:44px}
.section-head.center{margin-left:auto;margin-right:auto;text-align:center}
.eyebrow{font-family:var(--font-display);font-weight:700;font-size:12px;letter-spacing:0.18em;text-transform:uppercase;color:var(--green);margin-bottom:14px}
.section--navy .eyebrow{color:var(--green-pale)}
.rule{width:56px;height:3px;background:var(--green);margin:18px 0 0;border:0}
.section-head.center .rule{margin-left:auto;margin-right:auto}

/* ---------- Typography ---------- */
h1,h2,h3,h4{font-family:var(--font-display);color:var(--navy);letter-spacing:0;line-height:1.12}
h1{font-weight:800;font-size:clamp(34px,5vw,56px);text-transform:uppercase;letter-spacing:0.01em;line-height:1.05}
h2{font-weight:700;font-size:clamp(27px,3.6vw,40px);text-transform:uppercase;letter-spacing:0.01em}
h3{font-weight:700;font-size:20px;text-transform:uppercase;letter-spacing:0.04em}
h4{font-weight:700;font-size:14px;letter-spacing:0.1em;text-transform:uppercase;color:var(--mid-grey)}
p{margin-bottom:14px}
.lede{font-size:clamp(18px,2.1vw,22px);line-height:1.5;color:var(--slate)}
.section--navy h1,.section--navy h2,.section--navy h3{color:var(--white)}
.section--navy p,.section--navy .lede{color:rgba(255,255,255,0.85)}
strong{font-weight:600;color:var(--slate)}

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:9px;
  font-family:var(--font-display);font-weight:600;font-size:14px;
  letter-spacing:0.08em;text-transform:uppercase;
  padding:14px 30px;border-radius:var(--radius-pill);
  border:1.5px solid transparent;cursor:pointer;line-height:1;
  transition:all .2s ease;text-align:center;
}
.btn svg{width:16px;height:16px}
.btn-primary{background:var(--green);border-color:var(--green);color:var(--white)}
.btn-primary:hover{background:var(--green-deep);border-color:var(--green-deep);color:var(--white);transform:translateY(-1px)}
.btn-outline{background:transparent;border-color:var(--navy);color:var(--navy)}
.btn-outline:hover{background:var(--navy);color:var(--white)}
.btn-ghost{background:transparent;border-color:rgba(255,255,255,0.7);color:var(--white)}
.btn-ghost:hover{background:var(--white);border-color:var(--white);color:var(--navy)}
.btn-lg{padding:17px 38px;font-size:15px}
.btn-block{width:100%}

/* ---------- Header ---------- */
.site-header{position:sticky;top:0;z-index:60;background:rgba(255,255,255,0.96);backdrop-filter:saturate(150%) blur(8px);box-shadow:var(--shadow-header)}
.header-inner{display:flex;align-items:center;justify-content:space-between;gap:20px;height:78px}
.brand{display:flex;align-items:center;gap:12px}
.brand img{height:46px;width:auto}
.brand-fallback{font-family:var(--font-display);font-weight:800;font-size:18px;color:var(--navy);text-transform:uppercase;letter-spacing:0.04em;line-height:1}
.brand-fallback small{display:block;font-size:9.5px;letter-spacing:0.22em;color:var(--green);font-weight:700;margin-top:3px}
.nav{display:flex;align-items:center;gap:30px}
.nav-links{display:flex;align-items:center;gap:26px;list-style:none}
.nav-links a{font-family:var(--font-display);font-weight:600;font-size:13.5px;letter-spacing:0.06em;text-transform:uppercase;color:var(--navy);padding:6px 0;position:relative}
.nav-links a:hover{color:var(--green)}
.nav-links a.active{color:var(--green)}
.nav-links a.active::after{content:"";position:absolute;left:0;right:0;bottom:-2px;height:2px;background:var(--green)}
.header-actions{display:flex;align-items:center;gap:14px}
.header-phone{display:inline-flex;align-items:center;gap:8px;font-family:var(--font-display);font-weight:700;font-size:14px;color:var(--navy);letter-spacing:0.02em}
.header-phone svg{width:17px;height:17px;color:var(--green)}
.header-phone:hover{color:var(--green)}
.nav-toggle{display:none;background:none;border:0;cursor:pointer;padding:8px;color:var(--navy)}
.nav-toggle svg{width:26px;height:26px}

/* ---------- Hero ---------- */
.hero{position:relative;background:var(--navy-deep);color:var(--white);overflow:hidden}
.hero-bg{position:absolute;inset:0;pointer-events:none}
.hero-bg svg{position:absolute;width:140%;height:140%;top:-20%;right:-30%;opacity:0.16}
.hero::after{content:"";position:absolute;inset:0;background:radial-gradient(ellipse 1100px 520px at 80% 20%, rgba(32,86,133,0.28), transparent 62%),radial-gradient(ellipse 900px 500px at 0% 100%, rgba(14,69,30,0.30), transparent 68%);pointer-events:none}
.hero-inner{position:relative;z-index:2;max-width:820px;padding:104px 0 96px}
.hero .eyebrow{color:var(--green-pale)}
.hero h1{color:var(--white);margin-bottom:20px}
.hero .lede{color:rgba(255,255,255,0.86);max-width:680px;margin-bottom:32px}
.hero-cta{display:flex;flex-wrap:wrap;gap:14px;margin-bottom:40px}
.hero-trust{display:flex;flex-wrap:wrap;gap:14px 34px;padding-top:30px;border-top:1px solid rgba(255,255,255,0.16)}
.hero-trust-item{display:flex;align-items:center;gap:10px;font-family:var(--font-display);font-weight:600;font-size:13px;letter-spacing:0.04em;color:rgba(255,255,255,0.92);text-transform:uppercase}
.hero-trust-item svg{width:18px;height:18px;color:var(--green-mid);flex-shrink:0}
.hero-stars{color:#F4B740;letter-spacing:2px;font-size:15px}

/* ---------- Trust bar ---------- */
.trustbar{background:var(--navy);color:var(--white)}
.trustbar-inner{display:flex;flex-wrap:wrap;justify-content:space-between;gap:18px 28px;padding:20px 0}
.trustbar-item{display:flex;align-items:center;gap:11px;font-family:var(--font-display);font-weight:600;font-size:13px;letter-spacing:0.04em;text-transform:uppercase;color:rgba(255,255,255,0.9)}
.trustbar-item svg{width:19px;height:19px;color:var(--green-mid);flex-shrink:0}
.trustbar-item .stars{color:#F4B740;letter-spacing:1.5px}

/* ---------- Cards / service routing ---------- */
.grid{display:grid;gap:24px}
.grid-3{grid-template-columns:repeat(3,1fr)}
.grid-2{grid-template-columns:repeat(2,1fr)}
.grid-4{grid-template-columns:repeat(4,1fr)}
.card{background:var(--white);border:1px solid var(--border);border-top:3px solid var(--green);padding:30px 28px;transition:box-shadow .2s,transform .2s;display:flex;flex-direction:column}
.card:hover{box-shadow:var(--shadow-card-hover);transform:translateY(-3px)}
.card .card-icon{width:46px;height:46px;color:var(--green);margin-bottom:18px}
.card h3{margin-bottom:12px;font-size:18px}
.card p{font-size:15.5px;color:var(--mid-grey);margin-bottom:18px}
.card .card-link{margin-top:auto;font-family:var(--font-display);font-weight:700;font-size:12.5px;letter-spacing:0.08em;text-transform:uppercase;color:var(--green);display:inline-flex;align-items:center;gap:7px}
.card .card-link svg{width:15px;height:15px;transition:transform .2s}
.card:hover .card-link svg{transform:translateX(4px)}
.card ul{list-style:none;margin:4px 0 18px}
.card ul li{position:relative;padding:7px 0 7px 26px;font-size:15px;color:var(--slate);border-bottom:1px solid var(--border-light)}
.card ul li:last-child{border-bottom:0}
.card ul li::before{content:"";position:absolute;left:0;top:13px;width:13px;height:8px;border-left:2.5px solid var(--green-mid);border-bottom:2.5px solid var(--green-mid);transform:rotate(-45deg)}

/* ---------- Why-choose pillars ---------- */
.pillar{text-align:left}
.pillar .pillar-icon{width:42px;height:42px;color:var(--green);margin-bottom:16px}
.pillar h3{font-size:17px;margin-bottom:10px}
.pillar p{font-size:15px;color:var(--mid-grey);margin:0}

/* ---------- Process steps ---------- */
.process{counter-reset:step;display:grid;grid-template-columns:repeat(3,1fr);gap:28px}
.step{position:relative;padding-top:14px}
.step-num{font-family:var(--font-display);font-weight:800;font-size:15px;width:42px;height:42px;border-radius:50%;background:var(--green);color:var(--white);display:grid;place-items:center;margin-bottom:18px}
.step h3{font-size:17px;margin-bottom:10px}
.step p{font-size:15px;color:var(--mid-grey);margin:0}
.section--navy .step p{color:rgba(255,255,255,0.8)}

/* ---------- Feature band (subdivision) ---------- */
.feature{position:relative;background:var(--green);color:var(--white);overflow:hidden}
.feature .hero-bg svg{opacity:0.12}
.feature-grid{position:relative;z-index:2;display:grid;grid-template-columns:1.05fr 0.95fr;gap:54px;align-items:center;padding:80px 0}
.feature h2{color:var(--white)}
.feature p{color:rgba(255,255,255,0.88)}
.feature .rule{background:var(--green-pale)}
.feature-list{list-style:none;margin:22px 0 28px;columns:2;column-gap:30px}
.feature-list li{position:relative;padding:8px 0 8px 26px;font-size:15px;color:rgba(255,255,255,0.95);break-inside:avoid}
.feature-list li::before{content:"";position:absolute;left:0;top:14px;width:13px;height:8px;border-left:2.5px solid var(--green-pale);border-bottom:2.5px solid var(--green-pale);transform:rotate(-45deg)}
.feature-photo{aspect-ratio:4/3;border-radius:6px;overflow:hidden;background:rgba(255,255,255,0.08);border:1px solid rgba(255,255,255,0.18);display:grid;place-items:center;text-align:center;padding:20px}
.feature-photo img{width:100%;height:100%;object-fit:cover}
.placeholder-note{font-family:var(--font-display);font-weight:700;font-size:11px;letter-spacing:0.12em;text-transform:uppercase;color:rgba(255,255,255,0.7);line-height:1.6}

/* ---------- Reviews ---------- */
.reviews-head{display:flex;align-items:center;justify-content:space-between;gap:24px;flex-wrap:wrap;margin-bottom:40px}
.reviews-score{display:flex;align-items:center;gap:16px}
.reviews-score .num{font-family:var(--font-display);font-weight:800;font-size:46px;color:var(--navy);line-height:1}
.reviews-score .stars{color:#F4B740;font-size:20px;letter-spacing:2px}
.reviews-score .meta{font-size:14px;color:var(--mid-grey)}
.reviews-score .meta strong{display:block;font-family:var(--font-display);text-transform:uppercase;letter-spacing:0.06em;font-size:12px;color:var(--navy)}
.review-card{background:var(--white);border:1px solid var(--border);padding:26px 26px 24px;display:flex;flex-direction:column;height:100%}
.section--stone .review-card{box-shadow:var(--shadow-card)}
.review-stars{color:#F4B740;letter-spacing:2px;font-size:15px;margin-bottom:12px}
.review-text{font-size:15.5px;color:var(--slate);line-height:1.65;margin-bottom:18px}
.review-meta{margin-top:auto;display:flex;align-items:center;gap:12px}
.review-avatar{width:40px;height:40px;border-radius:50%;background:var(--navy);color:var(--white);font-family:var(--font-display);font-weight:800;display:grid;place-items:center;font-size:16px;flex-shrink:0}
.review-name{font-family:var(--font-display);font-weight:700;font-size:14px;color:var(--navy);letter-spacing:0.02em}
.review-src{font-size:12.5px;color:var(--mid-grey)}

/* ---------- Service area ---------- */
.area-list{display:flex;flex-wrap:wrap;gap:12px;margin-top:8px}
.area-chip{font-family:var(--font-display);font-weight:600;font-size:13px;letter-spacing:0.04em;text-transform:uppercase;color:var(--navy);background:var(--white);border:1px solid var(--border);border-radius:var(--radius-pill);padding:9px 18px}

/* ---------- CTA band ---------- */
.cta-band{position:relative;background:var(--green);color:var(--white);overflow:hidden}
.cta-band .hero-bg svg{opacity:0.12}
.cta-inner{position:relative;z-index:2;text-align:center;max-width:720px;margin:0 auto;padding:78px 0}
.cta-inner h2{color:var(--white);margin-bottom:14px}
.cta-inner p{color:rgba(255,255,255,0.9);margin-bottom:28px;font-size:18px}
.cta-actions{display:flex;flex-wrap:wrap;gap:14px;justify-content:center}

/* ---------- Generic media split ---------- */
.split{display:grid;grid-template-columns:1fr 1fr;gap:54px;align-items:center}
.media-frame{border-radius:6px;overflow:hidden;border:1px solid var(--border);background:var(--stone-light);aspect-ratio:4/3;display:grid;place-items:center;text-align:center;padding:24px}
.media-frame img{width:100%;height:100%;object-fit:cover}
.media-note{font-family:var(--font-display);font-weight:700;font-size:11px;letter-spacing:0.12em;text-transform:uppercase;color:var(--mid-grey);line-height:1.6}

/* ---------- Footer ---------- */
.site-footer{background:var(--navy-deep);color:rgba(255,255,255,0.72);padding:58px 0 0}
.footer-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1.1fr;gap:36px;padding-bottom:42px;border-bottom:1px solid rgba(255,255,255,0.12)}
.footer-brand img{height:48px;margin-bottom:16px;background:#fff;padding:8px 12px;border-radius:6px}
.footer-brand p{font-size:14px;color:rgba(255,255,255,0.66);max-width:300px}
.footer h4{color:#fff;font-size:12px;letter-spacing:0.14em;margin-bottom:16px}
.footer ul{list-style:none}
.footer ul li{margin-bottom:10px}
.footer ul li a,.footer-contact a,.footer-contact span{color:rgba(255,255,255,0.72);font-size:14.5px}
.footer ul li a:hover,.footer-contact a:hover{color:var(--green-pale)}
.footer-contact div{margin-bottom:11px;display:flex;gap:10px;align-items:flex-start}
.footer-contact svg{width:17px;height:17px;color:var(--green-mid);flex-shrink:0;margin-top:3px}
.footer-social{display:flex;gap:12px;margin-top:18px}
.footer-social a{width:38px;height:38px;border:1px solid rgba(255,255,255,0.22);border-radius:50%;display:grid;place-items:center;color:#fff}
.footer-social a:hover{background:var(--green);border-color:var(--green)}
.footer-social svg{width:17px;height:17px}
.footer-bottom{display:flex;justify-content:space-between;gap:18px;flex-wrap:wrap;padding:22px 0 30px;font-size:12.5px;color:rgba(255,255,255,0.5)}
.footer-bottom .subbrands{color:rgba(255,255,255,0.5)}
.footer-bottom .subbrands a{color:rgba(255,255,255,0.62)}

/* ---------- Mobile sticky call bar ---------- */
.mobile-callbar{display:none;position:fixed;bottom:0;left:0;right:0;z-index:70;background:var(--white);box-shadow:0 -2px 16px rgba(16,43,67,0.16);padding:10px 14px;gap:10px}
.mobile-callbar a{flex:1;padding:13px 8px;font-size:13px}

/* ---------- Forms ---------- */
.form-card{background:var(--white);border:1px solid var(--border);border-top:3px solid var(--green);padding:34px}
.field{margin-bottom:18px}
.field label{display:block;font-family:var(--font-display);font-weight:700;font-size:11px;letter-spacing:0.12em;text-transform:uppercase;color:var(--mid-grey);margin-bottom:7px}
.field input,.field select,.field textarea{
  width:100%;padding:13px 15px;border:1px solid var(--border);border-radius:5px;
  font-family:var(--font-body);font-size:15.5px;color:var(--slate);background:var(--white);transition:border-color .15s,box-shadow .15s;
}
.field textarea{min-height:130px;resize:vertical}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--green);box-shadow:0 0 0 3px rgba(14,69,30,0.13)}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.form-note{font-size:13px;color:var(--mid-grey);margin-top:6px}
.form-success{display:none;background:var(--green-pale);border:1px solid var(--green-mid);color:var(--green);padding:16px 18px;border-radius:6px;font-weight:600;margin-bottom:18px}

/* ---------- Contact info cards ---------- */
.contact-card{background:var(--white);border:1px solid var(--border);border-left:3px solid var(--green);padding:22px 24px;margin-bottom:16px;display:flex;gap:15px;align-items:flex-start}
.contact-card svg{width:22px;height:22px;color:var(--green);flex-shrink:0;margin-top:3px}
.contact-card .label{font-family:var(--font-display);font-weight:700;font-size:11px;letter-spacing:0.12em;text-transform:uppercase;color:var(--mid-grey);margin-bottom:5px}
.contact-card .value{font-family:var(--font-display);font-weight:700;font-size:16.5px;color:var(--navy)}
.contact-card .value a{color:var(--navy)}
.contact-card .value a:hover{color:var(--green)}

/* ---------- Team ---------- */
.team-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.team-card{background:var(--white);border:1px solid var(--border);border-top:3px solid var(--green);padding:26px}
.team-top{display:flex;align-items:center;gap:15px;margin-bottom:14px}
.team-avatar{width:56px;height:56px;border-radius:50%;background:var(--navy);color:#fff;font-family:var(--font-display);font-weight:800;font-size:20px;display:grid;place-items:center;flex-shrink:0}
.team-avatar.gold{background:var(--green)}
.team-name{font-family:var(--font-display);font-weight:700;font-size:16px;color:var(--navy);letter-spacing:0.02em}
.team-role{font-family:var(--font-display);font-weight:700;font-size:11px;letter-spacing:0.1em;text-transform:uppercase;color:var(--green);margin-top:3px}
.team-card p{font-size:14.5px;color:var(--mid-grey);margin:0}
.team-badge{display:inline-block;font-family:var(--font-display);font-weight:700;font-size:10px;letter-spacing:0.1em;text-transform:uppercase;color:var(--green);background:rgba(14,69,30,0.10);padding:4px 11px;border-radius:999px;margin-top:12px}

/* ---------- Page hero (inner pages) ---------- */
.page-hero{position:relative;background:var(--navy-deep);color:#fff;overflow:hidden}
.page-hero-inner{position:relative;z-index:2;padding:74px 0 66px;max-width:760px}
.page-hero .eyebrow{color:var(--green-pale)}
.page-hero h1{color:#fff;margin-bottom:16px}
.page-hero p{color:rgba(255,255,255,0.85);font-size:19px;margin:0}
.breadcrumb{font-size:13px;color:rgba(255,255,255,0.6);margin-bottom:18px;font-family:var(--font-display);letter-spacing:0.04em}
.breadcrumb a{color:rgba(255,255,255,0.75)}

/* ---------- Service detail rows ---------- */
.svc-row{display:grid;grid-template-columns:1fr 1fr;gap:50px;align-items:center;padding:64px 0;border-bottom:1px solid var(--border-light)}
.svc-row:last-child{border-bottom:0}
.svc-row.reverse .svc-media{order:2}
.svc-row .eyebrow{margin-bottom:10px}
.svc-list{list-style:none;margin-top:18px;columns:2;column-gap:28px}
.svc-list li{position:relative;padding:7px 0 7px 26px;font-size:15px;color:var(--slate);break-inside:avoid}
.svc-list li::before{content:"";position:absolute;left:0;top:13px;width:13px;height:8px;border-left:2.5px solid var(--green-mid);border-bottom:2.5px solid var(--green-mid);transform:rotate(-45deg)}

/* ---------- Values ---------- */
.value-pill{background:var(--white);border:1px solid var(--border);border-top:3px solid var(--green);padding:24px 20px;text-align:center}
.value-pill .v-name{font-family:var(--font-display);font-weight:800;font-size:13px;letter-spacing:0.1em;text-transform:uppercase;color:var(--navy);margin-bottom:10px}
.value-pill p{font-size:14px;color:var(--mid-grey);margin:0}

/* ---------- Utility ---------- */
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}
.text-center{text-align:center}
.mt-0{margin-top:0}.mb-0{margin-bottom:0}

/* ---------- Responsive ---------- */
@media (max-width:980px){
  .grid-3,.grid-4{grid-template-columns:repeat(2,1fr)}
  .team-grid{grid-template-columns:repeat(2,1fr)}
  .feature-grid,.split,.svc-row{grid-template-columns:1fr;gap:34px}
  .svc-row.reverse .svc-media{order:0}
  .process{grid-template-columns:1fr;gap:22px}
}
@media (max-width:820px){
  .nav-links,.header-phone{display:none}
  .nav-toggle{display:block}
  .nav.open .nav-links{display:flex;flex-direction:column;align-items:flex-start;gap:4px;position:absolute;top:78px;left:0;right:0;background:#fff;padding:14px 28px 22px;box-shadow:var(--shadow-header)}
  .nav.open .nav-links a{padding:12px 0;width:100%;border-bottom:1px solid var(--border-light)}
  .header-cta-btn{display:none}
  .mobile-callbar{display:flex}
  body{padding-bottom:66px}
  .section{padding:62px 0}
  .feature-list,.svc-list{columns:1}
  .footer-grid{grid-template-columns:1fr 1fr}
}
@media (max-width:560px){
  .grid-3,.grid-4,.grid-2,.team-grid{grid-template-columns:1fr}
  .container{padding:0 20px}
  .hero-inner{padding:72px 0 64px}
  .reviews-head{flex-direction:column;align-items:flex-start}
  .footer-grid{grid-template-columns:1fr}
}

@media (prefers-reduced-motion:reduce){
  *{scroll-behavior:auto !important;transition:none !important;animation:none !important}
}

/* ============================================================
   V2.1 — premium + warm refinements
   Warmer light surfaces, softer rounded cards, gentle motion.
   ============================================================ */
.section{background:var(--off-white)}
.card,.review-card,.team-card,.value-pill,.form-card,.feature-photo,.media-frame{border-radius:12px}
.contact-card{border-radius:10px}
.media-frame img,.feature-photo img{transition:transform .6s cubic-bezier(.2,.6,.2,1)}
.media-frame:hover img,.feature-photo:hover img{transform:scale(1.045)}
.card{transition:box-shadow .25s ease,transform .25s ease}
.card:hover{box-shadow:0 18px 44px rgba(16,43,67,0.14);transform:translateY(-4px)}
.review-card{box-shadow:var(--shadow-card)}
.btn-primary{box-shadow:0 6px 18px rgba(14,69,30,0.18)}
.btn-primary:hover{box-shadow:0 12px 28px rgba(12,57,25,0.26)}
.hero-inner{padding-top:112px}
.section-head .lede{color:var(--mid-grey)}

/* Warm homeowner band */
.warm-band{background:var(--stone)}
.warm-grid{display:grid;grid-template-columns:1fr 1fr;gap:54px;align-items:center}
.warm-grid .media-frame{aspect-ratio:5/4}
@media (max-width:980px){.warm-grid{grid-template-columns:1fr;gap:32px}}

/* Locations */
.loc-card{background:var(--white);border:1px solid var(--border);border-top:3px solid var(--green);border-radius:12px;padding:26px 26px 28px}
.loc-card h3{font-size:16px;margin-bottom:14px}
.loc-chips{display:flex;flex-wrap:wrap;gap:8px}
.loc-chips span{font-size:13px;color:var(--mid-grey);background:var(--stone-light);border-radius:var(--radius-pill);padding:6px 13px;font-family:var(--font-body)}

/* ============================================================
   V3 — SIGNATURE PREMIUM LAYER
   Cinematic motion, refined depth, tactile warmth.
   ============================================================ */

/* ---- Global polish ---- */
html{scroll-padding-top:96px}
body{text-rendering:optimizeLegibility}
::selection{background:var(--green);color:#fff}
:focus-visible{outline:2px solid var(--green);outline-offset:3px;border-radius:3px}
.section{padding:108px 0}
@media (max-width:820px){.section{padding:68px 0}}
h2{font-size:clamp(28px,4vw,46px);letter-spacing:-0.01em}
.section-head{margin-bottom:54px}
.eyebrow{display:inline-flex;align-items:center;gap:12px}
.eyebrow::before{content:"";width:26px;height:2px;background:currentColor;opacity:.55;border-radius:2px}
.section-head.center .eyebrow{justify-content:center}

/* ---- Scroll reveal ---- */
.reveal{opacity:0;transform:translateY(26px);transition:opacity .8s cubic-bezier(.16,.7,.2,1),transform .8s cubic-bezier(.16,.7,.2,1);will-change:opacity,transform}
.reveal.is-visible{opacity:1;transform:none}

/* ---- Header: glass + shrink on scroll + animated nav ---- */
.site-header{transition:background .3s ease,box-shadow .3s ease}
.header-inner{transition:height .3s cubic-bezier(.16,.7,.2,1)}
.brand img{transition:height .3s cubic-bezier(.16,.7,.2,1)}
.site-header.scrolled{background:rgba(255,255,255,0.94);box-shadow:0 8px 30px rgba(16,43,67,0.12)}
.site-header.scrolled .header-inner{height:62px}
.site-header.scrolled .brand img{height:38px}
.nav-links a{position:relative}
.nav-links a::after{content:"";position:absolute;left:0;right:100%;bottom:-3px;height:2px;background:var(--green);transition:right .32s cubic-bezier(.16,.7,.2,1)}
.nav-links a:hover::after,.nav-links a.active::after{right:0}
.nav.open .nav-links{animation:menuDrop .3s ease}
@keyframes menuDrop{from{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:none}}

/* ---- Buttons: lift + sheen ---- */
.btn{position:relative;overflow:hidden;isolation:isolate}
.btn-primary{background:linear-gradient(135deg,#13522a,#0b3a18)}
.btn-primary:hover{transform:translateY(-2px)}
.btn-primary::before{content:"";position:absolute;inset:0;z-index:-1;background:linear-gradient(120deg,transparent 30%,rgba(255,255,255,0.22),transparent 70%);transform:translateX(-130%) skewX(-18deg);transition:transform .7s ease}
.btn-primary:hover::before{transform:translateX(130%) skewX(-18deg)}
.btn-outline:hover{transform:translateY(-2px)}
.btn-ghost:hover{transform:translateY(-2px)}

/* ---- Cards: layered depth ---- */
.card,.review-card,.team-card,.loc-card,.value-pill,.form-card{box-shadow:0 1px 2px rgba(16,43,67,.05),0 10px 30px -18px rgba(16,43,67,.25)}
.card:hover{box-shadow:0 24px 50px -22px rgba(16,43,67,.34);transform:translateY(-6px)}
.card .card-icon,.pillar .pillar-icon{transition:transform .3s ease}
.card:hover .card-icon,.pillar:hover .pillar-icon{transform:translateY(-3px) scale(1.06)}

/* ---- Imagery: warm grade + frame ---- */
.media-frame,.feature-photo{position:relative;box-shadow:0 30px 60px -30px rgba(16,43,67,.45)}
.media-frame::after,.feature-photo::after{content:"";position:absolute;inset:0;pointer-events:none;background:linear-gradient(180deg,rgba(7,24,42,0) 55%,rgba(7,24,42,0.22));border-radius:inherit;mix-blend-mode:multiply}
.media-frame img,.feature-photo img{filter:saturate(1.03) contrast(1.02)}

/* ---- Tactile grain on dark bands ---- */
.hero::before,.statband::before,.feature::before,.cta-band::before,.page-hero::after{
  content:"";position:absolute;inset:0;z-index:1;pointer-events:none;opacity:.07;mix-blend-mode:overlay;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.82' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}

/* ---- Hero: cinematic ---- */
.hero{min-height:90vh;display:flex;align-items:center}
.hero-inner{padding:128px 0 104px}
.hero h1{font-size:clamp(42px,6.2vw,72px);line-height:1.01;letter-spacing:-0.015em}
.hero .lede{font-size:clamp(18px,2.2vw,23px)}
.hero .eyebrow,.hero h1,.hero .lede,.hero-cta,.hero-trust{opacity:0;transform:translateY(24px);animation:heroIn 1s cubic-bezier(.16,.7,.2,1) forwards}
.hero .eyebrow{animation-delay:.15s}
.hero h1{animation-delay:.28s}
.hero .lede{animation-delay:.44s}
.hero-cta{animation-delay:.58s}
.hero-trust{animation-delay:.72s}
@keyframes heroIn{to{opacity:1;transform:none}}
.hero .hero-bg path,.page-hero .hero-bg path{stroke-dasharray:1600;stroke-dashoffset:1600;animation:draw 2.8s cubic-bezier(.16,.7,.2,1) forwards}
.hero .hero-bg path:nth-child(2){animation-delay:.15s}
.hero .hero-bg path:nth-child(3){animation-delay:.3s}
.hero .hero-bg path:nth-child(4){animation-delay:.45s}
.hero .hero-bg path:nth-child(5){animation-delay:.6s}
@keyframes draw{to{stroke-dashoffset:0}}
.hero-stars,.trustbar .stars,.review-stars,.reviews-score .stars,.hero-trust .hero-stars{text-shadow:0 1px 6px rgba(244,183,64,.35)}
.scroll-cue{position:absolute;left:50%;bottom:26px;transform:translateX(-50%);z-index:3;display:flex;flex-direction:column;align-items:center;gap:9px;color:rgba(255,255,255,.62);font-family:var(--font-display);font-weight:700;font-size:9.5px;letter-spacing:.22em;text-transform:uppercase;animation:heroIn 1s 1s both}
.scroll-cue .mouse{width:23px;height:36px;border:1.5px solid rgba(255,255,255,.45);border-radius:13px;position:relative}
.scroll-cue .mouse::after{content:"";position:absolute;left:50%;top:7px;width:3px;height:7px;border-radius:2px;background:#fff;transform:translateX(-50%);animation:scrolly 1.7s ease-in-out infinite}
@keyframes scrolly{0%{opacity:0;transform:translate(-50%,0)}40%{opacity:1}80%{opacity:0;transform:translate(-50%,11px)}}

/* ---- Stat band ---- */
.statband{position:relative;background:var(--navy);color:#fff;overflow:hidden}
.statband .container{position:relative;z-index:2}
.stat-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:24px;padding:60px 0}
.stat{text-align:center;position:relative}
.stat:not(:last-child)::after{content:"";position:absolute;right:-12px;top:50%;transform:translateY(-50%);width:1px;height:54px;background:rgba(255,255,255,.14)}
.stat .figure{font-family:var(--font-display);font-weight:800;font-size:clamp(36px,4.6vw,54px);line-height:1;letter-spacing:-.01em;color:#fff}
.stat .figure .unit{color:var(--green-mid)}
.stat .label{margin-top:12px;font-family:var(--font-display);font-weight:700;font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:rgba(255,255,255,.6)}
@media (max-width:680px){.stat-grid{grid-template-columns:1fr 1fr;gap:34px 16px}.stat:nth-child(2)::after{display:none}}

/* ---- Trusted-by strip ---- */
.trusted{background:var(--off-white);border-top:1px solid var(--border-light);border-bottom:1px solid var(--border-light)}
.trusted-row{display:flex;align-items:center;justify-content:center;gap:12px 26px;flex-wrap:wrap;padding:26px 0}
.trusted-row .lab{font-family:var(--font-display);font-weight:700;font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:var(--soft-grey)}
.trusted-row .who{font-family:var(--font-display);font-weight:700;font-size:13.5px;letter-spacing:.05em;text-transform:uppercase;color:var(--navy)}
.trusted-row .dot{width:5px;height:5px;border-radius:50%;background:var(--green-mid)}

/* ---- Reviews: editorial ---- */
.review-card{position:relative;overflow:hidden}
.review-card::before{content:"\201C";position:absolute;top:2px;right:18px;font-family:var(--font-display);font-weight:800;font-size:84px;line-height:1;color:var(--green-pale);opacity:.45}
.reviews-score .num{background:linear-gradient(135deg,var(--navy),var(--navy-mid));-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}

/* ---- Process: connected ---- */
.process{position:relative}
@media (min-width:981px){
  .process::before{content:"";position:absolute;top:20px;left:16%;right:16%;height:2px;background:linear-gradient(90deg,var(--green-pale),var(--green-mid),var(--green-pale))}
  .step{text-align:center}
  .step .step-num{margin-left:auto;margin-right:auto;position:relative;z-index:2;box-shadow:0 0 0 7px var(--off-white)}
}

/* ---- Footer refinement ---- */
.site-footer{position:relative}
.site-footer::before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--green),var(--green-mid),var(--navy-mid))}

/* ---- Section seam softening ---- */
.section--stone+.section,.section+.section--stone{box-shadow:inset 0 1px 0 rgba(16,43,67,.04)}

@media (prefers-reduced-motion:reduce){
  .reveal{opacity:1 !important;transform:none !important}
  .hero .eyebrow,.hero h1,.hero .lede,.hero-cta,.hero-trust,.scroll-cue{opacity:1;transform:none;animation:none}
  .hero .hero-bg path,.page-hero .hero-bg path{stroke-dashoffset:0;animation:none}
  .scroll-cue .mouse::after{animation:none}
  .btn-primary::before{display:none}
}

/* ============================================================
   V4 — BLOC-INSPIRED SLEEK LAYER
   Editorial restraint: sentence-case headings, photographic hero,
   a transparent nav that solidifies on scroll, more air.
   ============================================================ */

/* ---- Refined, sentence-case headings ---- */
h1,h2,h3{text-transform:none}
h1{font-weight:700;letter-spacing:-0.028em;line-height:1.03}
h2{font-weight:700;letter-spacing:-0.02em;line-height:1.08}
h3{letter-spacing:-0.008em}
.eyebrow{font-size:11px;letter-spacing:0.26em}
.rule{height:2px;width:54px}
.lede{font-weight:400}

/* ---- More air ---- */
.section{padding:124px 0}
@media (max-width:820px){.section{padding:74px 0}}
.section-head{margin-bottom:60px}

/* ---- Transparent → solid header (floats over the imagery) ---- */
.site-header{position:fixed;top:0;left:0;right:0;background:transparent;backdrop-filter:none;box-shadow:none;transition:background .4s ease,box-shadow .4s ease}
.site-header .nav-links a,.site-header .header-phone{color:#fff}
.site-header .header-phone svg{color:var(--green-pale)}
.site-header .nav-toggle{color:#fff}
.site-header .brand img{filter:brightness(0) invert(1)}
.site-header.scrolled{background:rgba(252,251,248,0.92);backdrop-filter:saturate(160%) blur(11px);box-shadow:0 1px 0 rgba(16,43,67,.06),0 12px 34px rgba(16,43,67,.09)}
.site-header.scrolled .nav-links a,.site-header.scrolled .header-phone{color:var(--navy)}
.site-header.scrolled .header-phone svg{color:var(--green)}
.site-header.scrolled .nav-toggle{color:var(--navy)}
.site-header.scrolled .brand img{filter:none}
.nav-links a::after{background:currentColor}
.nav.open .nav-links a{color:var(--navy) !important}

/* ---- Cinematic photographic hero ---- */
.hero{min-height:100vh}
.hero-photo{position:absolute;inset:0;z-index:0;overflow:hidden;background:var(--navy-deep)}
.hero-photo img{width:100%;height:100%;object-fit:cover}
.hero::after{background:linear-gradient(180deg,rgba(7,24,42,.74),rgba(7,24,42,.55) 20%,rgba(7,24,42,.62) 55%,rgba(7,24,42,.88)),radial-gradient(ellipse 1000px 480px at 80% 16%,rgba(32,86,133,.26),transparent 60%)}
.hero .hero-bg{opacity:.5}
.hero-inner{padding:128px 0 112px}
.hero .lede{max-width:600px}

/* page heroes clear the fixed header */
.page-hero-inner{padding-top:132px;padding-bottom:80px}

/* ---- Calmer, more refined motion ---- */
.reveal{transform:translateY(18px);transition-duration:.95s}
.card:hover{transform:translateY(-5px)}

/* ---- Team: architectural, portrait-led ---- */
.team-card{padding:30px;border-top-width:2px}
.team-avatar{width:62px;height:62px;font-size:22px;border-radius:14px}
.team-grid{gap:22px}
.team-name{font-size:17px;letter-spacing:-0.005em}

/* ---- Buttons & cards: a touch more minimal ---- */
.card{border-top-width:2px}
.value-pill,.loc-card,.form-card{border-top-width:2px}
.feature-list li,.svc-list li,.card ul li{font-weight:400}

/* ---- Footer: airier ---- */
.site-footer{padding-top:72px}

@media (prefers-reduced-motion:reduce){
  .hero-photo img{transform:none}
}

/* ============================================================
   V5 — RESTRAINT (Bloc-style understatement)
   Smaller, quieter type. Imagery and space lead, not headlines.
   ============================================================ */
h1{font-size:clamp(27px,3vw,40px);font-weight:700;line-height:1.1;letter-spacing:-0.02em}
h2{font-size:clamp(21px,2.2vw,29px);font-weight:600;letter-spacing:-0.012em;line-height:1.18}
h3{font-size:16px;letter-spacing:0;font-weight:700}
.lede{font-size:clamp(15.5px,1.4vw,17.5px);line-height:1.65;font-weight:400}
.eyebrow{font-size:10.5px;letter-spacing:0.28em}
.section-head{margin-bottom:46px}
.stat .figure{font-size:clamp(28px,3vw,38px)}
.reviews-score .num{font-size:38px}

/* Hero: quiet, bottom-anchored, the way Bloc does it */
.hero{align-items:flex-end}
.hero-inner{padding:0 0 92px;max-width:720px}
.hero .eyebrow{margin-bottom:16px}
.hero h1{font-size:clamp(23px,2.7vw,34px);font-weight:600;line-height:1.2;max-width:20ch;margin-bottom:16px}
.hero .lede{font-size:16.5px;max-width:540px;margin-bottom:26px}

/* Inner page heroes: matching restraint */
.page-hero h1{font-size:clamp(25px,2.8vw,36px);font-weight:600}
.page-hero p{font-size:16.5px}
.page-hero-inner{padding-top:124px;padding-bottom:72px}

/* Lighter section labels everywhere */
.feature h2,.cta-inner h2{font-weight:600}
.cta-inner p{font-size:16.5px}

/* ============================================================
   V6 — IMAGE-LED (let the work carry the page, Bloc-style)
   ============================================================ */

/* Selected work gallery */
.gallery{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}
.gallery .tile{position:relative;overflow:hidden;border-radius:10px;aspect-ratio:4/3;background:var(--stone-light);display:block}
.gallery .tile img{width:100%;height:100%;object-fit:cover;transition:transform .8s cubic-bezier(.2,.6,.2,1)}
.gallery .tile:hover img{transform:scale(1.07)}
.gallery .cap{position:absolute;left:0;right:0;bottom:0;padding:16px 18px;background:linear-gradient(180deg,transparent,rgba(7,24,42,.78));color:#fff;font-family:var(--font-display);font-weight:700;font-size:11px;letter-spacing:.12em;text-transform:uppercase;opacity:0;transform:translateY(10px);transition:opacity .35s ease,transform .35s ease}
.gallery .tile:hover .cap{opacity:1;transform:none}
@media (max-width:680px){.gallery{grid-template-columns:1fr 1fr;gap:10px}.gallery .cap{opacity:1;transform:none;font-size:10px}}

/* Full-bleed cinematic image band */
.imageband{position:relative;min-height:62vh;display:flex;align-items:center;color:#fff;overflow:hidden;background:var(--navy-deep) center/cover no-repeat}
.imageband::after{content:"";position:absolute;inset:0;background:linear-gradient(90deg,rgba(7,24,42,.82),rgba(7,24,42,.40) 70%,rgba(7,24,42,.30))}
.imageband .container{position:relative;z-index:2}
.imageband .eyebrow{color:var(--green-pale)}
.imageband h2{color:#fff;max-width:18ch}
.imageband p{color:rgba(255,255,255,.85);max-width:48ch}
.imageband .rule{background:var(--green-pale)}
@media (min-width:981px){.imageband{background-attachment:fixed}}
