/* ============================================================
   YY TILE — shared stylesheet
   Palette: deep pine green / near-black / warm paper-white
   Signature: tile-grid + grout-line motif, spec-style mono labels
   ============================================================ */

:root{
  --ink:#15181B;
  --ink-soft:#454C52;
  --ink-faint:#717981;
  --paper:#FFFFFF;
  --paper-2:#F4F4F0;
  --paper-3:#EAEBE4;
  --green:#15603A;
  --green-600:#12522F;
  --green-700:#0E3D25;
  --green-800:#0A2E1C;
  --green-tint:#E6EFE9;
  --line:#E2E3DC;
  --line-2:#D2D4CB;

  --radius:3px;
  --radius-lg:5px;
  --container:1200px;
  --grout:6px;

  --shadow-sm:0 1px 2px rgba(21,24,27,.06), 0 1px 1px rgba(21,24,27,.04);
  --shadow-md:0 10px 30px -18px rgba(21,24,27,.35);

  --font-display:"Bricolage Grotesque", system-ui, sans-serif;
  --font-body:"Hanken Grotesk", system-ui, sans-serif;
  --font-mono:"IBM Plex Mono", ui-monospace, monospace;

  --fs-hero:clamp(2.55rem, 1.4rem + 4.6vw, 4.7rem);
  --fs-h2:clamp(1.85rem, 1.2rem + 2.4vw, 3rem);
  --fs-h3:clamp(1.18rem, 1rem + .6vw, 1.45rem);
  --fs-body:1.0625rem;
}

*{box-sizing:border-box;}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%;}
body{
  margin:0;
  font-family:var(--font-body);
  font-size:var(--fs-body);
  line-height:1.62;
  color:var(--ink);
  background:var(--paper);
  -webkit-font-smoothing:antialiased;
}
img{max-width:100%;display:block;}
a{color:inherit;text-decoration:none;}
h1,h2,h3,h4{font-family:var(--font-display);font-weight:700;line-height:1.05;margin:0;letter-spacing:-.01em;}
p{margin:0 0 1rem;}
ul{margin:0;padding:0;list-style:none;}

.container{width:100%;max-width:var(--container);margin:0 auto;padding:0 clamp(1.1rem,4vw,2.5rem);}
.section{padding:clamp(3.4rem,7vw,6rem) 0;}
.section--tight{padding:clamp(2.6rem,5vw,4rem) 0;}
.section--paper2{background:var(--paper-2);}

/* ---- shared bits ---- */
.eyebrow{
  font-family:var(--font-mono);
  font-size:.72rem;
  font-weight:600;
  letter-spacing:.18em;
  text-transform:uppercase;
  color:var(--green);
  display:inline-flex;
  align-items:center;
  gap:.6rem;
  margin:0 0 1rem;
}
.eyebrow::before{
  content:"";
  width:9px;height:9px;
  background:var(--green);
  display:inline-block;
}
.eyebrow--light{color:#bfe6cf;}
.eyebrow--light::before{background:#8fd3a9;}

.lead{font-size:clamp(1.08rem,1rem + .4vw,1.28rem);color:var(--ink-soft);max-width:60ch;}

.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:.5rem;
  font-family:var(--font-body);font-weight:600;font-size:.98rem;
  padding:.8rem 1.45rem;border-radius:var(--radius);
  border:1.5px solid transparent;cursor:pointer;
  transition:background .2s ease, color .2s ease, border-color .2s ease, transform .15s ease;
}
.btn-lg{padding:1rem 1.7rem;font-size:1.03rem;}
.btn-solid{background:var(--green);color:#fff;border-color:var(--green);}
.btn-solid:hover{background:var(--green-700);border-color:var(--green-700);}
.btn-outline{background:transparent;color:var(--green);border-color:var(--line-2);}
.btn-outline:hover{border-color:var(--green);background:var(--green-tint);}
.btn-ghost-light{background:transparent;color:#fff;border-color:rgba(255,255,255,.45);}
.btn-ghost-light:hover{background:rgba(255,255,255,.12);border-color:#fff;}
.btn:focus-visible,a:focus-visible,button:focus-visible{
  outline:3px solid var(--green);outline-offset:2px;
}

/* tile-field grid motif (faint grout lines) */
.tilefield{
  background-image:
    linear-gradient(rgba(255,255,255,.06) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,.06) 1px, transparent 1px);
  background-size:46px 46px;
}

/* ============================================================
   HEADER
   ============================================================ */
.site-header{
  position:sticky;top:0;z-index:60;
  background:rgba(255,255,255,.92);
  backdrop-filter:saturate(140%) blur(8px);
  border-bottom:1px solid var(--line);
  transition:box-shadow .25s ease, background .25s ease;
}
.site-header.scrolled{box-shadow:var(--shadow-sm);}
.header-inner{display:flex;align-items:center;gap:1.5rem;min-height:72px;}

.brand{display:inline-flex;align-items:center;gap:.65rem;font-family:var(--font-display);}
.brand-mark{
  display:grid;grid-template-columns:repeat(2,11px);grid-template-rows:repeat(2,11px);
  gap:2.5px;flex:0 0 auto;
}
.brand-mark span{background:var(--ink);display:block;border-radius:1px;}
.brand-mark span:first-child{background:var(--green);}
.brand-text{font-weight:800;font-size:1.32rem;letter-spacing:.02em;color:var(--ink);line-height:1;}
.brand-text-2{color:var(--green);margin-left:.18em;}

.nav{display:flex;gap:.35rem;margin-left:auto;}
.nav a{
  font-weight:500;font-size:.97rem;color:var(--ink-soft);
  padding:.55rem .85rem;border-radius:var(--radius);position:relative;
  transition:color .18s ease, background .18s ease;
}
.nav a:hover{color:var(--ink);background:var(--paper-2);}
.nav a[aria-current="page"]{color:var(--green);font-weight:600;}
.nav a[aria-current="page"]::after{
  content:"";position:absolute;left:.85rem;right:.85rem;bottom:.28rem;height:2px;background:var(--green);
}

.header-cta{display:flex;align-items:center;gap:1rem;}
.phone-link{
  display:inline-flex;align-items:center;gap:.45rem;font-weight:600;font-size:.95rem;color:var(--ink);
  white-space:nowrap;transition:color .18s ease;
}
.phone-link:hover{color:var(--green);}
.phone-link svg{width:16px;height:16px;color:var(--green);}

.nav-toggle{
  display:none;flex-direction:column;gap:5px;width:44px;height:44px;
  align-items:center;justify-content:center;background:transparent;border:1px solid var(--line);
  border-radius:var(--radius);margin-left:auto;cursor:pointer;
}
.nav-toggle span{width:22px;height:2px;background:var(--ink);transition:transform .25s ease, opacity .2s ease;}
.nav-open .nav-toggle span:nth-child(1){transform:translateY(7px) rotate(45deg);}
.nav-open .nav-toggle span:nth-child(2){opacity:0;}
.nav-open .nav-toggle span:nth-child(3){transform:translateY(-7px) rotate(-45deg);}

@media (max-width:980px){
  .header-cta .btn{display:none;}
}
@media (max-width:780px){
  .nav-toggle{display:flex;}
  .header-cta{display:none;}
  .nav{
    position:absolute;left:0;right:0;top:100%;
    flex-direction:column;gap:0;margin:0;
    background:var(--paper);border-bottom:1px solid var(--line);
    padding:.5rem clamp(1.1rem,4vw,2.5rem) 1.1rem;
    box-shadow:var(--shadow-md);
    transform:translateY(-12px);opacity:0;pointer-events:none;
    transition:transform .22s ease, opacity .22s ease;
  }
  .nav-open .nav{transform:translateY(0);opacity:1;pointer-events:auto;}
  .nav a{padding:.9rem .25rem;border-bottom:1px solid var(--line);border-radius:0;}
  .nav a[aria-current="page"]::after{display:none;}
  .nav-mobile-cta{display:flex !important;gap:.75rem;margin-top:1rem;}
  .nav-mobile-cta .btn{flex:1;}
}
.nav-mobile-cta{display:none;}

/* ============================================================
   HERO (home)
   ============================================================ */
.hero{position:relative;min-height:clamp(560px,86vh,820px);display:flex;align-items:flex-end;overflow:hidden;}
.hero-slides{position:absolute;inset:0;}
.hero-slide{
  position:absolute;inset:0;background-size:cover;background-position:center;
  opacity:0;transition:opacity 1.4s ease;transform:scale(1.04);
}
.hero-slide.is-active{opacity:1;animation:heroZoom 7s ease forwards;}
@keyframes heroZoom{from{transform:scale(1.04);}to{transform:scale(1.12);}}
.hero-overlay{
  position:absolute;inset:0;
  background:
    linear-gradient(180deg, rgba(10,46,28,.34) 0%, rgba(10,46,28,.30) 40%, rgba(8,30,19,.86) 100%),
    linear-gradient(90deg, rgba(10,30,20,.55) 0%, rgba(10,30,20,0) 60%);
}
.hero-content{position:relative;z-index:2;padding-top:7rem;padding-bottom:clamp(2.6rem,5vw,4rem);color:#fff;}
.hero h1{font-size:var(--fs-hero);font-weight:800;color:#fff;max-width:16ch;letter-spacing:-.02em;}
.hero-sub{color:rgba(255,255,255,.9);font-size:clamp(1.05rem,1rem + .4vw,1.3rem);max-width:54ch;margin-top:1.25rem;}
.hero-actions{display:flex;flex-wrap:wrap;gap:.85rem;margin-top:2rem;}
.hero-dots{display:flex;gap:.5rem;margin-top:2.4rem;}
.hero-dots button{
  width:34px;height:4px;border:0;padding:0;background:rgba(255,255,255,.35);cursor:pointer;border-radius:2px;
  transition:background .2s ease;
}
.hero-dots button.active{background:#fff;}

/* ============================================================
   INNER PAGE HEADER BAND
   ============================================================ */
.page-band{background:var(--green-700);color:#fff;position:relative;overflow:hidden;}
.page-band .container{position:relative;z-index:2;padding-top:clamp(3rem,6vw,4.6rem);padding-bottom:clamp(3rem,6vw,4.6rem);}
.page-band h1{font-size:clamp(2.2rem,1.6rem + 3vw,3.6rem);font-weight:800;color:#fff;}
.page-band p{color:rgba(255,255,255,.82);max-width:56ch;margin-top:.85rem;margin-bottom:0;}
.crumbs{font-family:var(--font-mono);font-size:.72rem;letter-spacing:.14em;text-transform:uppercase;color:#9fd6b6;margin-bottom:1rem;}
.crumbs a{color:#9fd6b6;}
.crumbs a:hover{color:#fff;}

/* ============================================================
   TRUST BAND
   ============================================================ */
.trust{background:var(--ink);color:#fff;}
.trust-grid{display:grid;grid-template-columns:repeat(4,1fr);}
.trust-item{padding:1.8rem 1.4rem;border-left:1px solid rgba(255,255,255,.1);}
.trust-item:first-child{border-left:0;}
.trust-num{font-family:var(--font-display);font-weight:800;font-size:1.9rem;color:#fff;line-height:1;}
.trust-num span{color:#7fd2a1;}
.trust-label{font-family:var(--font-mono);font-size:.72rem;letter-spacing:.13em;text-transform:uppercase;color:rgba(255,255,255,.65);margin-top:.55rem;}
@media (max-width:680px){.trust-grid{grid-template-columns:repeat(2,1fr);}
  .trust-item:nth-child(3){border-left:0;}
  .trust-item:nth-child(odd){border-left:0;}
  .trust-item{border-top:1px solid rgba(255,255,255,.1);}
  .trust-item:nth-child(1),.trust-item:nth-child(2){border-top:0;}
}

/* ============================================================
   SECTION HEADINGS
   ============================================================ */
.section-head{max-width:62ch;margin-bottom:clamp(2rem,4vw,3rem);}
.section-head h2{font-size:var(--fs-h2);font-weight:800;}
.section-head p{margin-top:1rem;color:var(--ink-soft);font-size:1.1rem;}
.section-head--center{margin-left:auto;margin-right:auto;text-align:center;}
.section-head--center .eyebrow{justify-content:center;}

/* ============================================================
   INTRO / ABOUT
   ============================================================ */
.intro-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(2rem,5vw,4rem);align-items:center;}
.intro-copy h2{font-size:var(--fs-h2);font-weight:800;margin-bottom:1.2rem;}
.intro-copy p{color:var(--ink-soft);}
.intro-points{display:grid;grid-template-columns:1fr 1fr;gap:1rem 1.5rem;margin-top:1.6rem;}
.intro-point{display:flex;gap:.7rem;align-items:flex-start;}
.intro-point svg{width:20px;height:20px;color:var(--green);flex:0 0 auto;margin-top:3px;}
.intro-point b{font-weight:600;display:block;}
.intro-point span{color:var(--ink-soft);font-size:.95rem;}
.intro-media{position:relative;}
.intro-media img{width:100%;height:100%;object-fit:cover;border-radius:var(--radius-lg);aspect-ratio:4/5;}
.intro-badge{
  position:absolute;left:-14px;bottom:24px;background:var(--green);color:#fff;
  padding:1rem 1.2rem;border-radius:var(--radius);box-shadow:var(--shadow-md);
}
.intro-badge b{font-family:var(--font-display);font-weight:800;font-size:1.8rem;display:block;line-height:1;}
.intro-badge span{font-family:var(--font-mono);font-size:.68rem;letter-spacing:.13em;text-transform:uppercase;}
@media (max-width:820px){.intro-grid{grid-template-columns:1fr;}.intro-media{order:-1;}.intro-media img{aspect-ratio:16/10;}}
@media (max-width:480px){.intro-points{grid-template-columns:1fr;}}

/* ============================================================
   SERVICES GRID
   ============================================================ */
.svc-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--grout);}
.svc-grid--3{grid-template-columns:repeat(3,1fr);}
.svc-card{
  position:relative;display:block;background:var(--ink);overflow:hidden;border-radius:var(--radius);
  min-height:230px;color:#fff;isolation:isolate;
}
.svc-card img{
  position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:-2;
  transition:transform .55s ease;
}
.svc-card::after{
  content:"";position:absolute;inset:0;z-index:-1;
  background:linear-gradient(180deg, rgba(10,30,20,.05) 0%, rgba(8,28,18,.55) 55%, rgba(7,24,15,.9) 100%);
}
.svc-card:hover img{transform:scale(1.07);}
.svc-card-body{position:absolute;left:0;right:0;bottom:0;padding:1.2rem 1.25rem;}
.svc-card h3{font-size:1.18rem;font-weight:700;color:#fff;}
.svc-card p{font-size:.9rem;color:rgba(255,255,255,.82);margin:.4rem 0 0;line-height:1.45;}
.svc-card .svc-corner{
  position:absolute;top:0;right:0;width:0;height:0;
  border-style:solid;border-width:0 38px 38px 0;border-color:transparent var(--green) transparent transparent;
  opacity:0;transform:translate(8px,-8px);transition:opacity .25s ease, transform .25s ease;
}
.svc-card:hover .svc-corner{opacity:1;transform:translate(0,0);}
@media (max-width:980px){.svc-grid,.svc-grid--3{grid-template-columns:repeat(2,1fr);}}
@media (max-width:540px){.svc-grid,.svc-grid--3{grid-template-columns:1fr;}}

/* detailed service rows (services page) */
.svc-detail{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--grout);}
.svc-detail-card{
  background:var(--paper);border:1px solid var(--line);border-radius:var(--radius-lg);overflow:hidden;
  display:flex;flex-direction:column;transition:border-color .25s ease, transform .25s ease, box-shadow .25s ease;
}
.svc-detail-card:hover{border-color:var(--line-2);transform:translateY(-3px);box-shadow:var(--shadow-md);}
.svc-detail-media{aspect-ratio:16/10;overflow:hidden;}
.svc-detail-media img{width:100%;height:100%;object-fit:cover;transition:transform .5s ease;}
.svc-detail-card:hover .svc-detail-media img{transform:scale(1.05);}
.svc-detail-body{padding:1.5rem 1.5rem 1.7rem;}
.svc-detail-body .svc-no{font-family:var(--font-mono);font-size:.72rem;letter-spacing:.13em;color:var(--green);}
.svc-detail-body h3{font-size:1.35rem;font-weight:700;margin:.4rem 0 .6rem;}
.svc-detail-body p{color:var(--ink-soft);font-size:.97rem;margin:0;}
@media (max-width:760px){.svc-detail{grid-template-columns:1fr;}}

/* ============================================================
   PROCESS (numbered, true sequence)
   ============================================================ */
.process-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--grout);}
.process-step{background:var(--paper);border:1px solid var(--line);border-radius:var(--radius-lg);padding:1.6rem 1.4rem;}
.process-step .step-no{
  font-family:var(--font-mono);font-weight:600;font-size:.8rem;letter-spacing:.1em;color:var(--green);
  display:inline-flex;align-items:center;gap:.5rem;margin-bottom:1rem;
}
.process-step .step-no::before{content:"";width:26px;height:26px;background:var(--green-tint);border:1px solid var(--green);
  display:inline-flex;align-items:center;justify-content:center;border-radius:2px;}
.process-step h3{font-size:1.15rem;font-weight:700;margin-bottom:.5rem;}
.process-step p{color:var(--ink-soft);font-size:.94rem;margin:0;}
@media (max-width:920px){.process-grid{grid-template-columns:repeat(2,1fr);}}
@media (max-width:480px){.process-grid{grid-template-columns:1fr;}}

/* ============================================================
   GALLERY (tile grid + lightbox)
   ============================================================ */
.gallery{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--grout);}
.gallery-item{
  position:relative;overflow:hidden;border-radius:var(--radius);cursor:pointer;
  aspect-ratio:1/1;background:var(--paper-3);border:0;padding:0;
}
.gallery-item img{width:100%;height:100%;object-fit:cover;transition:transform .5s ease;}
.gallery-item::after{
  content:"";position:absolute;inset:0;background:rgba(10,46,28,0);transition:background .25s ease;
}
.gallery-item:hover img{transform:scale(1.06);}
.gallery-item:hover::after{background:rgba(10,46,28,.18);}
.gallery-item .zoom{
  position:absolute;top:.6rem;right:.6rem;width:30px;height:30px;background:rgba(255,255,255,.9);
  border-radius:2px;display:flex;align-items:center;justify-content:center;opacity:0;transform:scale(.8);
  transition:opacity .2s ease, transform .2s ease;
}
.gallery-item:hover .zoom{opacity:1;transform:scale(1);}
.gallery-item .zoom svg{width:15px;height:15px;color:var(--green);}
@media (max-width:820px){.gallery{grid-template-columns:repeat(3,1fr);}}
@media (max-width:520px){.gallery{grid-template-columns:repeat(2,1fr);}}

.lightbox{
  position:fixed;inset:0;z-index:120;background:rgba(8,18,12,.92);
  display:none;align-items:center;justify-content:center;padding:1.5rem;
}
.lightbox.open{display:flex;}
.lightbox img{max-width:90vw;max-height:84vh;border-radius:var(--radius);box-shadow:0 30px 80px -20px rgba(0,0,0,.7);}
.lb-btn{
  position:absolute;background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.3);color:#fff;
  width:48px;height:48px;border-radius:var(--radius);cursor:pointer;display:flex;align-items:center;justify-content:center;
  transition:background .2s ease;
}
.lb-btn:hover{background:rgba(255,255,255,.25);}
.lb-btn svg{width:22px;height:22px;}
.lb-close{top:1.2rem;right:1.2rem;}
.lb-prev{left:1.2rem;top:50%;transform:translateY(-50%);}
.lb-next{right:1.2rem;top:50%;transform:translateY(-50%);}
.lb-count{position:absolute;bottom:1.3rem;left:50%;transform:translateX(-50%);color:rgba(255,255,255,.8);
  font-family:var(--font-mono);font-size:.8rem;letter-spacing:.1em;}
@media (max-width:560px){.lb-prev{left:.5rem;}.lb-next{right:.5rem;}}

/* ============================================================
   CTA BAND
   ============================================================ */
.cta-band{background:var(--green-700);color:#fff;position:relative;overflow:hidden;}
.cta-band .container{position:relative;z-index:2;padding-top:clamp(3rem,6vw,4.5rem);padding-bottom:clamp(3rem,6vw,4.5rem);
  display:flex;align-items:center;justify-content:space-between;gap:2rem;flex-wrap:wrap;}
.cta-band h2{font-size:clamp(1.7rem,1.3rem + 1.8vw,2.6rem);font-weight:800;color:#fff;max-width:18ch;}
.cta-band p{color:rgba(255,255,255,.82);margin:.7rem 0 0;}
.cta-actions{display:flex;gap:.85rem;flex-wrap:wrap;}

/* ============================================================
   SERVICE AREAS
   ============================================================ */
.areas-grid{display:grid;grid-template-columns:1.1fr .9fr;gap:clamp(2rem,5vw,3.5rem);align-items:start;}
.map-frame{border:1px solid var(--line);border-radius:var(--radius-lg);overflow:hidden;background:var(--paper-2);}
.map-frame iframe{display:block;width:100%;height:440px;border:0;}
.area-list{display:grid;grid-template-columns:1fr 1fr;gap:var(--grout);}
.area-pill{
  display:flex;align-items:center;gap:.6rem;background:var(--paper);border:1px solid var(--line);
  border-radius:var(--radius);padding:.8rem 1rem;font-weight:500;transition:border-color .2s ease, background .2s ease;
}
.area-pill:hover{border-color:var(--green);background:var(--green-tint);}
.area-pill .dot{width:8px;height:8px;background:var(--green);flex:0 0 auto;}
@media (max-width:860px){.areas-grid{grid-template-columns:1fr;}}
@media (max-width:420px){.area-list{grid-template-columns:1fr;}}

/* ============================================================
   CONTACT
   ============================================================ */
.contact-grid{display:grid;grid-template-columns:1fr .8fr;gap:clamp(2rem,5vw,3.5rem);align-items:start;}
.form-card{background:var(--paper);border:1px solid var(--line);border-radius:var(--radius-lg);padding:clamp(1.5rem,3vw,2.2rem);}
.field{margin-bottom:1.1rem;}
.field label{display:block;font-weight:600;font-size:.9rem;margin-bottom:.4rem;}
.field label .req{color:var(--green);}
.field input,.field select,.field textarea{
  width:100%;font-family:var(--font-body);font-size:1rem;color:var(--ink);
  padding:.8rem .9rem;border:1px solid var(--line-2);border-radius:var(--radius);background:var(--paper);
  transition:border-color .18s ease, box-shadow .18s ease;
}
.field input:focus,.field select:focus,.field textarea:focus{
  outline:none;border-color:var(--green);box-shadow:0 0 0 3px var(--green-tint);
}
.field textarea{resize:vertical;min-height:120px;}
.field-row{display:grid;grid-template-columns:1fr 1fr;gap:1.1rem;}
.form-note{font-size:.85rem;color:var(--ink-faint);margin-top:.2rem;}
.form-success{
  display:none;align-items:flex-start;gap:.7rem;background:var(--green-tint);border:1px solid var(--green);
  border-radius:var(--radius);padding:1rem 1.1rem;color:var(--green-700);margin-bottom:1.2rem;font-size:.95rem;
}
.form-success.show{display:flex;}
.form-success svg{width:20px;height:20px;flex:0 0 auto;color:var(--green);margin-top:2px;}

.contact-info{display:flex;flex-direction:column;gap:var(--grout);}
.info-card{background:var(--paper-2);border:1px solid var(--line);border-radius:var(--radius-lg);padding:1.4rem 1.5rem;}
.info-card .ico{width:38px;height:38px;background:var(--green);border-radius:var(--radius);display:flex;align-items:center;justify-content:center;margin-bottom:.9rem;}
.info-card .ico svg{width:18px;height:18px;color:#fff;}
.info-card h3{font-size:1.05rem;font-weight:700;margin-bottom:.25rem;}
.info-card a,.info-card p{color:var(--ink-soft);margin:0;font-size:.98rem;}
.info-card a:hover{color:var(--green);}
@media (max-width:860px){.contact-grid{grid-template-columns:1fr;}.field-row{grid-template-columns:1fr;}}

/* ============================================================
   FOOTER
   ============================================================ */
.site-footer{background:var(--green-800);color:rgba(255,255,255,.78);padding-top:clamp(3rem,6vw,4.5rem);}
.footer-grid{display:grid;grid-template-columns:1.4fr .8fr 1fr 1.2fr;gap:clamp(1.6rem,4vw,3rem);padding-bottom:3rem;}
.footer-brand .brand-text,.footer-brand .brand-text-2{color:#fff;}
.footer-brand .brand-mark span{background:rgba(255,255,255,.85);}
.footer-brand .brand-mark span:first-child{background:#7fd2a1;}
.footer-brand p{margin:1rem 0 1.2rem;font-size:.95rem;max-width:34ch;}
.footer-google{display:inline-flex;align-items:center;gap:.4rem;color:#9fd6b6;font-weight:600;font-size:.92rem;}
.footer-google:hover{color:#fff;}
.footer-col h4{font-family:var(--font-mono);font-size:.74rem;font-weight:600;letter-spacing:.14em;text-transform:uppercase;color:#fff;margin-bottom:1rem;}
.footer-col a,.footer-contact a,.footer-contact span{display:block;color:rgba(255,255,255,.75);font-size:.95rem;padding:.28rem 0;}
.footer-col a:hover,.footer-contact a:hover{color:#fff;}
.footer-bottom{display:flex;justify-content:space-between;align-items:center;gap:1rem;flex-wrap:wrap;
  border-top:1px solid rgba(255,255,255,.12);padding-top:1.4rem;padding-bottom:1.6rem;
  font-size:.85rem;color:rgba(255,255,255,.6);font-family:var(--font-mono);letter-spacing:.04em;}
.footer-credit{display:inline-flex;align-items:center;gap:0.4rem;background:rgba(255,255,255,0.05);border:1px solid rgba(255,255,255,0.08);padding:0.35rem 0.8rem;border-radius:30px;font-size:0.8rem;font-family:var(--font-body);transition:background .25s ease, border-color .25s ease, box-shadow .25s ease;}
.footer-credit:hover{background:rgba(255,255,255,0.09);border-color:rgba(127,210,161,0.4);box-shadow:0 0 10px rgba(127,210,161,0.15);}
.footer-credit-link{color:#7fd2a1;font-weight:600;display:inline-flex;align-items:center;gap:0.15rem;transition:color .2s ease;}
.footer-credit-link:hover{color:#fff;}
.footer-credit-arrow{display:inline-block;transition:transform .2s ease;}
.footer-credit-link:hover .footer-credit-arrow{transform:translate(2px,-2px);}
@media (max-width:820px){.footer-grid{grid-template-columns:1fr 1fr;}}
@media (max-width:480px){.footer-grid{grid-template-columns:1fr;}}

/* ============================================================
   SCROLL REVEAL
   ============================================================ */
.reveal{opacity:0;transform:translateY(18px);transition:opacity .6s ease, transform .6s ease;}
.reveal.in{opacity:1;transform:none;}
.reveal[data-d="1"]{transition-delay:.08s;}
.reveal[data-d="2"]{transition-delay:.16s;}
.reveal[data-d="3"]{transition-delay:.24s;}

@media (prefers-reduced-motion:reduce){
  *{animation:none !important;scroll-behavior:auto !important;}
  .reveal{opacity:1;transform:none;transition:none;}
  .hero-slide.is-active{animation:none;transform:none;}
}
