/* ===============================================================
   Advantage Lawn Service Plus
   Concept: "Fresh Cut" : mowing stripes as the signature motif
   =============================================================== */

:root{
  /* palette */
  --ink:      #14241B;
  --evergreen:#0E3B2A;
  --evergreen-2:#0A2D20;
  --moss:     #2F6B45;
  --moss-soft:#4C8A63;
  --fresh:    #C4E446;   /* signature fresh-cut lime */
  --fresh-deep:#A9CE2C;
  --paper:    #F4F1E8;
  --paper-2:  #ECE7D8;
  --stone:    #E7E2D4;
  --sand:     #D9CFB8;
  --white:    #FCFBF6;

  /* type */
  --display: "Fraunces", Georgia, serif;
  --body:    "Inter", system-ui, sans-serif;
  --mono:    "Space Mono", ui-monospace, monospace;

  /* layout */
  --maxw: 1200px;
  --gutter: clamp(20px, 5vw, 64px);
  --radius: 18px;
  --radius-lg: 28px;

  --ease: cubic-bezier(.22,.61,.36,1);
  --ease-out: cubic-bezier(.16,1,.3,1);
}

*{ box-sizing:border-box; margin:0; padding:0; }
html{ scroll-behavior:smooth; -webkit-text-size-adjust:100%; }

body{
  font-family:var(--body);
  color:var(--ink);
  background:var(--paper);
  line-height:1.6;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
}
img{ display:block; max-width:100%; }
a{ color:inherit; text-decoration:none; }
button{ font-family:inherit; cursor:pointer; }
::selection{ background:var(--fresh); color:var(--evergreen-2); }

.container{ width:100%; max-width:var(--maxw); margin-inline:auto; padding-inline:var(--gutter); }

/* ---------- Type scale ---------- */
h1,h2,h3{ font-family:var(--display); font-weight:600; line-height:1.04; letter-spacing:-.01em; }
em{ font-style:italic; }

.eyebrow{
  font-family:var(--mono);
  font-size:.72rem; letter-spacing:.18em; text-transform:uppercase;
  color:var(--moss); display:inline-flex; align-items:center; gap:.6em;
  margin-bottom:1.1rem;
}
.eyebrow--light{ color:var(--fresh); }
.eyebrow__dot{ width:7px; height:7px; border-radius:50%; background:var(--fresh); box-shadow:0 0 0 4px rgba(196,228,70,.18); }

.section{ padding-block:clamp(64px, 9vw, 130px); position:relative; }
.section__head{ max-width:760px; margin-bottom:clamp(40px,5vw,68px); }
.section__title{ font-size:clamp(2rem, 4.6vw, 3.5rem); margin-bottom:1rem; }
.section__title em{ color:var(--moss); }
.section--dark .section__title em{ color:var(--fresh); }
.section__intro{ font-size:clamp(1.02rem,1.4vw,1.18rem); color:color-mix(in srgb, var(--ink) 72%, transparent); max-width:62ch; }
.section--dark .section__intro{ color:rgba(255,255,255,.72); }

/* ---------- Buttons ---------- */
.btn{
  --bg: var(--evergreen);
  --fg: var(--white);
  display:inline-flex; align-items:center; justify-content:center; gap:.5em;
  background:var(--bg); color:var(--fg);
  font-weight:600; font-size:.98rem;
  padding:.92em 1.6em; border-radius:100px; border:1.5px solid var(--bg);
  position:relative; overflow:hidden; isolation:isolate;
  transition:transform .35s var(--ease), box-shadow .35s var(--ease), color .35s var(--ease);
  box-shadow:0 1px 0 rgba(0,0,0,.04);
}
/* stripe sweep on hover */
.btn::before{
  content:""; position:absolute; inset:0; z-index:-1;
  background:var(--fresh);
  transform:translateX(-101%) skewX(-12deg); transform-origin:left;
  transition:transform .45s var(--ease-out);
}
.btn:hover{ color:var(--evergreen-2); transform:translateY(-2px); box-shadow:0 12px 26px -12px rgba(14,59,42,.5); }
.btn:hover::before{ transform:translateX(0) skewX(-12deg); }
.btn:active{ transform:translateY(0); }
.btn:focus-visible{ outline:3px solid var(--fresh); outline-offset:3px; }

.btn--ghost{ --bg:transparent; --fg:var(--white); border-color:rgba(255,255,255,.4); }
.btn--ghost:hover{ color:var(--evergreen-2); border-color:var(--fresh); }
.btn--small{ padding:.62em 1.15em; font-size:.86rem; }
.btn--block{ width:100%; padding:1.05em; font-size:1.02rem; }

/* ---------- Loader ---------- */
.loader{
  position:fixed; inset:0; z-index:1000; background:var(--evergreen-2);
  display:grid; place-items:center;
  transition:opacity .6s var(--ease), visibility .6s;
}
.loader.is-done{ opacity:0; visibility:hidden; }
.loader__stripes{
  position:absolute; inset:0;
  background:repeating-linear-gradient(115deg, var(--evergreen-2) 0 60px, var(--evergreen) 60px 120px);
  opacity:.5;
  animation:slide 1.1s linear infinite;
}
@keyframes slide{ to{ background-position:240px 0; } }
.loader__mark{ position:relative; animation:bob 1.1s var(--ease) infinite; }
@keyframes bob{ 0%,100%{ transform:translateY(0); } 50%{ transform:translateY(-9px); } }
.loader__mark svg path{ stroke-dasharray:60; stroke-dashoffset:60; animation:draw 1.1s var(--ease) infinite alternate; }
.loader__mark svg path:nth-child(2){ animation-delay:.12s; }
.loader__mark svg path:nth-child(3){ animation-delay:.24s; }
@keyframes draw{ to{ stroke-dashoffset:0; } }

/* ---------- Nav ---------- */
.nav{
  position:fixed; top:0; left:0; right:0; z-index:100;
  transition:background .4s var(--ease), box-shadow .4s var(--ease), padding .4s var(--ease);
  padding-block:18px;
}
.nav.is-scrolled{
  background:rgba(244,241,232,.86); backdrop-filter:blur(14px) saturate(140%);
  box-shadow:0 1px 0 rgba(20,36,27,.08); padding-block:10px;
}
.nav__inner{
  max-width:var(--maxw); margin-inline:auto; padding-inline:var(--gutter);
  display:flex; align-items:center; gap:24px;
}
.brand{ display:flex; align-items:center; gap:12px; margin-right:auto; }
.brand__mark{ background:var(--evergreen); border-radius:11px; padding:5px; display:grid; place-items:center; box-shadow:0 6px 18px -8px rgba(14,59,42,.6); }
.brand__text{ display:flex; flex-direction:column; line-height:1; }
.brand__name{ font-family:var(--display); font-weight:600; font-size:1.18rem; color:var(--evergreen); transition:color .3s; }
.brand__sub{ font-family:var(--mono); font-size:.6rem; letter-spacing:.16em; text-transform:uppercase; color:var(--moss); margin-top:3px; }

.nav:not(.is-scrolled) .brand__name{ color:var(--white); }
.nav:not(.is-scrolled) .brand__sub{ color:var(--fresh); }
.nav:not(.is-scrolled) .nav__links a{ color:rgba(255,255,255,.9); }
.nav:not(.is-scrolled) .phone-link{ color:var(--white); }

.nav__links{ display:flex; gap:28px; }
.nav__links a{ font-size:.95rem; font-weight:500; color:var(--ink); position:relative; padding-block:4px; }
.nav__links a::after{
  content:""; position:absolute; left:0; bottom:-2px; height:2px; width:0; background:var(--fresh);
  transition:width .3s var(--ease);
}
.nav__links a:hover::after, .nav__links a.is-active::after{ width:100%; }

.nav__cta{ display:flex; align-items:center; gap:18px; }
.phone-link{ display:inline-flex; align-items:center; gap:.5em; font-weight:600; font-size:.9rem; color:var(--evergreen); transition:color .3s; }
.phone-link:hover{ color:var(--moss); }

.nav__toggle{ display:none; flex-direction:column; gap:5px; background:none; border:0; padding:8px; }
.nav__toggle span{ width:24px; height:2px; background:currentColor; border-radius:2px; transition:.3s var(--ease); display:block; }
.nav:not(.is-scrolled) .nav__toggle{ color:var(--white); }
.nav.is-scrolled .nav__toggle{ color:var(--ink); }

.nav__mobile{
  display:none; flex-direction:column; gap:2px;
  position:absolute; top:100%; left:var(--gutter); right:var(--gutter);
  background:var(--white); border-radius:var(--radius); padding:14px;
  box-shadow:0 24px 60px -20px rgba(14,59,42,.4);
  transform:translateY(-12px); opacity:0; pointer-events:none;
  transition:.32s var(--ease);
}
.nav__mobile.is-open{ transform:translateY(8px); opacity:1; pointer-events:auto; }
.nav__mobile a{ padding:12px 14px; border-radius:10px; font-weight:500; transition:background .2s; }
.nav__mobile a:hover{ background:var(--paper-2); }
.nav__mobile-phone{ background:var(--evergreen); color:var(--white); text-align:center; margin-top:6px; font-weight:600; }

/* ---------- Hero ---------- */
.hero{
  position:relative; min-height:100svh; display:flex; align-items:flex-end;
  padding:0 var(--gutter) clamp(48px,8vh,96px);
  color:var(--white); overflow:hidden;
}
.hero__media{ position:absolute; inset:0; z-index:-2; }
.hero__img{
  width:100%; height:100%; object-fit:cover; object-position:center 62%;
  transform:scale(1.12); animation:heroZoom 9s var(--ease-out) forwards;
}
@keyframes heroZoom{ to{ transform:scale(1); } }
.hero__veil{
  position:absolute; inset:0;
  background:linear-gradient(180deg, rgba(10,45,32,.55) 0%, rgba(10,45,32,.2) 38%, rgba(10,45,32,.78) 100%);
}
/* animated mowing-stripe overlay sweeping across hero */
.hero__stripes{ position:absolute; inset:0; display:flex; }
.hero__stripes span{
  flex:1; background:rgba(8,40,28,.001);
  transform:translateY(102%);
  animation:stripeIn .9s var(--ease-out) forwards;
}
.hero__stripes span:nth-child(odd){ background:rgba(8,40,28,.16); }
.hero__stripes span:nth-child(1){ animation-delay:.15s; }
.hero__stripes span:nth-child(2){ animation-delay:.25s; }
.hero__stripes span:nth-child(3){ animation-delay:.35s; }
.hero__stripes span:nth-child(4){ animation-delay:.45s; }
.hero__stripes span:nth-child(5){ animation-delay:.55s; }
.hero__stripes span:nth-child(6){ animation-delay:.65s; }
@keyframes stripeIn{ to{ transform:translateY(0); } }

.hero__content{ position:relative; max-width:880px; }
.hero__title{
  font-size:clamp(2.7rem, 8vw, 6.2rem); font-weight:600; letter-spacing:-.025em;
  margin-bottom:1.4rem;
}
.hero__title .line{ display:block; overflow:hidden; }
.hero__title .line span{
  display:block; transform:translateY(110%);
  animation:lineUp .9s var(--ease-out) forwards;
}
.hero__title .line:nth-child(1) span{ animation-delay:1.0s; }
.hero__title .line:nth-child(2) span{ animation-delay:1.12s; }
.hero__title em{ color:var(--fresh); font-style:italic; }
@keyframes lineUp{ to{ transform:translateY(0); } }

.hero__lead{ font-size:clamp(1.05rem,1.6vw,1.3rem); max-width:54ch; color:rgba(255,255,255,.9); margin-bottom:2rem; }
.hero__actions{ display:flex; gap:14px; flex-wrap:wrap; margin-bottom:2.6rem; }

.hero__stats{ display:flex; align-items:center; gap:clamp(18px,4vw,42px); flex-wrap:wrap; }
.stat{ display:flex; flex-direction:column; gap:2px; }
.stat__num{ font-family:var(--display); font-size:clamp(1.8rem,3.4vw,2.7rem); font-weight:600; color:var(--fresh); line-height:1; }
.stat__label{ font-family:var(--mono); font-size:.66rem; letter-spacing:.14em; text-transform:uppercase; color:rgba(255,255,255,.75); }
.stat__div{ width:1px; height:40px; background:rgba(255,255,255,.25); }

.hero__scroll{ position:absolute; bottom:24px; left:50%; transform:translateX(-50%); width:26px; height:42px; border:2px solid rgba(255,255,255,.5); border-radius:14px; display:grid; justify-items:center; padding-top:7px; }
.hero__scroll span{ width:4px; height:9px; border-radius:3px; background:var(--fresh); animation:scrolldot 1.5s var(--ease) infinite; }
@keyframes scrolldot{ 0%{ transform:translateY(0); opacity:1; } 70%{ transform:translateY(12px); opacity:0; } 100%{ opacity:0; } }

/* ---------- Trust bar ---------- */
.trust{ background:var(--evergreen); color:var(--white); }
.trust__inner{
  max-width:var(--maxw); margin-inline:auto; padding:22px var(--gutter);
  display:flex; flex-wrap:wrap; align-items:center; justify-content:space-between; gap:18px 30px;
}
.trust__item{ display:flex; align-items:center; gap:11px; font-size:.92rem; font-weight:500; }
.trust__item svg{ width:22px; height:22px; color:var(--fresh); flex:none; }
.stars{ display:inline-flex; gap:2px; }
.stars svg{ width:17px; height:17px; fill:var(--fresh); }

/* ---------- Services ---------- */
.svc-grid{ display:grid; grid-template-columns:repeat(4,1fr); gap:20px; }
.svc{
  background:var(--white); border:1px solid var(--paper-2); border-radius:var(--radius);
  padding:28px 24px 30px; position:relative; overflow:hidden;
  transition:transform .4s var(--ease), box-shadow .4s var(--ease), border-color .4s var(--ease);
}
/* stripe reveal on hover */
.svc::before{
  content:""; position:absolute; left:0; right:0; bottom:0; height:0;
  background:
    repeating-linear-gradient(125deg, rgba(47,107,69,.10) 0 14px, transparent 14px 28px),
    var(--evergreen);
  transition:height .4s var(--ease); z-index:0;
}
.svc > *{ position:relative; z-index:1; transition:color .4s var(--ease); }
.svc:hover{ transform:translateY(-6px); box-shadow:0 26px 50px -24px rgba(14,59,42,.45); border-color:transparent; }
.svc:hover::before{ height:100%; }
.svc:hover, .svc:hover .svc__desc, .svc:hover .svc__list li{ color:var(--white); }
.svc:hover .svc__no{ color:var(--fresh); }
.svc:hover .svc__ico{ background:var(--fresh); color:var(--evergreen); border-color:var(--fresh); }
.svc:hover .svc__list li::before{ background:var(--fresh); }

.svc__top{ display:flex; align-items:center; justify-content:space-between; margin-bottom:20px; }
.svc__no{ font-family:var(--mono); font-size:.82rem; color:var(--moss); letter-spacing:.05em; }
.svc__ico{ width:46px; height:46px; border-radius:13px; display:grid; place-items:center; background:var(--paper); border:1px solid var(--paper-2); color:var(--evergreen); transition:.4s var(--ease); }
.svc__ico svg{ width:24px; height:24px; }
.svc__name{ font-size:1.32rem; margin-bottom:.5rem; }
.svc__desc{ font-size:.94rem; color:color-mix(in srgb, var(--ink) 70%, transparent); margin-bottom:16px; }
.svc__list{ list-style:none; display:flex; flex-direction:column; gap:8px; }
.svc__list li{ font-size:.86rem; padding-left:18px; position:relative; color:color-mix(in srgb, var(--ink) 78%, transparent); }
.svc__list li::before{ content:""; position:absolute; left:0; top:.55em; width:8px; height:2px; background:var(--moss); border-radius:2px; }

/* ---------- Dark sections ---------- */
.section--dark{ background:var(--evergreen-2); color:var(--white); }
.section--dark::before{
  content:""; position:absolute; inset:0; pointer-events:none; opacity:.5;
  background:repeating-linear-gradient(118deg, transparent 0 70px, rgba(255,255,255,.018) 70px 140px);
}
.section--dark > *{ position:relative; }

/* ---------- Work / gallery ---------- */
.gallery{ display:grid; grid-template-columns:repeat(3,1fr); gap:18px; }
.gallery__item{ position:relative; border-radius:var(--radius); overflow:hidden; aspect-ratio:4/3; }
.gallery__item--tall{ grid-row:span 2; aspect-ratio:auto; }
.gallery__item img{ width:100%; height:100%; object-fit:cover; transition:transform .7s var(--ease-out); }
.gallery__item:hover img{ transform:scale(1.06); }
.gallery__item figcaption{
  position:absolute; inset:auto 0 0 0; padding:18px 18px 16px;
  display:flex; align-items:flex-end; justify-content:space-between; gap:10px;
  color:var(--white); font-weight:600; font-size:1rem;
  background:linear-gradient(transparent, rgba(8,40,28,.85));
}
.gallery__tag{ font-family:var(--mono); font-size:.62rem; letter-spacing:.12em; text-transform:uppercase; color:var(--evergreen); background:var(--fresh); padding:4px 9px; border-radius:100px; flex:none; }

/* ---------- About ---------- */
.about__grid{ display:grid; grid-template-columns:1.05fr .95fr; gap:clamp(36px,5vw,72px); align-items:center; }
.about__text p{ margin-bottom:1.1rem; color:color-mix(in srgb, var(--ink) 76%, transparent); }
.about__text .section__title{ margin-bottom:1.4rem; }
.about__points{ display:grid; grid-template-columns:1fr 1fr; gap:18px 26px; margin:1.8rem 0 2rem; }
.point{ border-left:2px solid var(--fresh); padding-left:14px; }
.point__k{ display:block; font-weight:600; font-family:var(--display); font-size:1.06rem; color:var(--evergreen); }
.point__v{ display:block; font-size:.88rem; color:color-mix(in srgb, var(--ink) 68%, transparent); margin-top:2px; }

.about__media{ position:relative; }
.about__photo{ position:relative; border-radius:var(--radius-lg); overflow:hidden; box-shadow:0 30px 60px -30px rgba(14,59,42,.5); }
.about__photo img{ width:100%; height:100%; object-fit:cover; }
.about__photo figcaption{ position:absolute; left:14px; bottom:14px; font-family:var(--mono); font-size:.66rem; letter-spacing:.1em; text-transform:uppercase; color:var(--evergreen); background:var(--fresh); padding:5px 11px; border-radius:100px; }
.about__photo--main{ aspect-ratio:4/3; }
.about__photo--sub{ width:52%; aspect-ratio:1/1; margin-top:-22%; margin-left:auto; border:6px solid var(--paper); }
.about__badge{
  position:absolute; top:-22px; left:-14px; background:var(--evergreen); color:var(--white);
  border-radius:16px; padding:14px 18px; display:flex; align-items:center; gap:12px; max-width:230px;
  box-shadow:0 20px 40px -18px rgba(14,59,42,.6);
}
.about__badge-num{ font-family:var(--display); font-size:2.1rem; font-weight:600; color:var(--fresh); line-height:1; }
.about__badge-text{ font-size:.78rem; color:rgba(255,255,255,.85); line-height:1.35; }

/* ---------- Reviews ---------- */
.section--paper{ background:linear-gradient(180deg, var(--paper) 0%, var(--paper-2) 100%); }
.reviews__grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:20px; }
.review{
  background:var(--white); border:1px solid var(--paper-2); border-radius:var(--radius);
  padding:26px 26px 24px; display:flex; flex-direction:column; gap:14px;
  transition:transform .4s var(--ease), box-shadow .4s var(--ease);
}
.review:hover{ transform:translateY(-5px); box-shadow:0 24px 46px -26px rgba(14,59,42,.4); }
.review__stars{ color:var(--fresh-deep); letter-spacing:2px; font-size:1.05rem; }
.review blockquote{ font-size:.96rem; color:color-mix(in srgb, var(--ink) 82%, transparent); line-height:1.62; }
.review figcaption{ margin-top:auto; padding-top:8px; border-top:1px solid var(--paper-2); display:flex; flex-direction:column; }
.review__name{ font-weight:600; font-family:var(--display); color:var(--evergreen); }
.review__meta{ font-family:var(--mono); font-size:.68rem; letter-spacing:.08em; text-transform:uppercase; color:var(--moss); }
.review--cta{ background:var(--evergreen); color:var(--white); align-items:flex-start; justify-content:center; }
.review--cta p{ color:rgba(255,255,255,.85); }
.review__cta-num{ font-family:var(--display); font-size:3rem; font-weight:600; color:var(--fresh); line-height:1; }

/* ---------- Contact ---------- */
.contact__grid{ display:grid; grid-template-columns:1fr 1.05fr; gap:clamp(36px,5vw,64px); align-items:start; }
.contact__details{ list-style:none; display:flex; flex-direction:column; gap:18px; margin:2rem 0; }
.contact__details li{ display:flex; gap:14px; align-items:flex-start; }
.contact__ico{ width:42px; height:42px; flex:none; border-radius:12px; display:grid; place-items:center; background:rgba(196,228,70,.1); border:1px solid rgba(196,228,70,.25); color:var(--fresh); }
.contact__ico svg{ width:20px; height:20px; }
.contact__k{ display:block; font-family:var(--mono); font-size:.64rem; letter-spacing:.14em; text-transform:uppercase; color:var(--fresh); margin-bottom:3px; }
.contact__details a{ color:rgba(255,255,255,.92); font-weight:500; transition:color .25s; }
.contact__details a:hover{ color:var(--fresh); }

.hours{ background:rgba(255,255,255,.04); border:1px solid rgba(255,255,255,.1); border-radius:var(--radius); padding:20px 22px; max-width:380px; }
.hours__title{ font-family:var(--display); font-size:1.12rem; margin-bottom:12px; color:var(--white); }
.hours__list{ list-style:none; display:flex; flex-direction:column; gap:7px; }
.hours__list li{ display:flex; justify-content:space-between; gap:14px; font-size:.86rem; color:rgba(255,255,255,.8); padding-bottom:7px; border-bottom:1px dashed rgba(255,255,255,.1); }
.hours__list li:last-child{ border-bottom:0; padding-bottom:0; }
.hours__list span:last-child{ font-family:var(--mono); font-size:.78rem; color:var(--fresh); }

/* form */
.contact__form-wrap{ background:var(--white); border-radius:var(--radius-lg); padding:clamp(24px,3vw,40px); box-shadow:0 40px 80px -40px rgba(0,0,0,.5); }
.form__row{ display:grid; grid-template-columns:1fr 1fr; gap:16px; }
.field{ margin-bottom:16px; display:flex; flex-direction:column; }
.field label{ font-size:.82rem; font-weight:600; color:var(--ink); margin-bottom:7px; }
.field input, .field textarea, .field select{
  font-family:inherit; font-size:.95rem; color:var(--ink);
  padding:.82em .95em; border:1.5px solid var(--paper-2); border-radius:12px; background:var(--paper);
  transition:border-color .25s, box-shadow .25s, background .25s; width:100%;
}
.field textarea{ resize:vertical; min-height:96px; }
.field input::placeholder, .field textarea::placeholder{ color:color-mix(in srgb, var(--ink) 40%, transparent); }
.field input:focus, .field textarea:focus, .field select:focus{
  outline:none; border-color:var(--moss); background:var(--white);
  box-shadow:0 0 0 4px rgba(47,107,69,.12);
}
.field.has-error input, .field.has-error select, .field.has-error textarea{ border-color:#c0392b; box-shadow:0 0 0 4px rgba(192,57,43,.1); }
.field__err{ color:#c0392b; font-size:.76rem; margin-top:5px; min-height:0; opacity:0; transition:opacity .2s; }
.field.has-error .field__err{ opacity:1; }
.select-wrap{ position:relative; }
.select-wrap::after{ content:""; position:absolute; right:16px; top:50%; width:9px; height:9px; border-right:2px solid var(--moss); border-bottom:2px solid var(--moss); transform:translateY(-70%) rotate(45deg); pointer-events:none; }
select{ appearance:none; cursor:pointer; }

.form__note{ font-size:.76rem; color:color-mix(in srgb, var(--ink) 55%, transparent); margin-top:10px; text-align:center; }
.form__success[hidden]{ display:none; }
.form__success{ display:flex; gap:14px; align-items:center; background:rgba(47,107,69,.08); border:1px solid rgba(47,107,69,.25); border-radius:14px; padding:16px 18px; margin-top:16px; }
.form__success-mark{ width:38px; height:38px; flex:none; border-radius:50%; display:grid; place-items:center; background:var(--moss); color:var(--white); }
.form__success-mark svg{ width:20px; height:20px; }
.form__success strong{ display:block; font-family:var(--display); color:var(--evergreen); font-size:1.05rem; }
.form__success span{ font-size:.88rem; color:color-mix(in srgb, var(--ink) 70%, transparent); }

/* map */
.map{ margin-top:clamp(40px,5vw,64px); border-radius:var(--radius-lg); overflow:hidden; height:clamp(280px,40vw,440px); position:relative; box-shadow:0 30px 60px -30px rgba(0,0,0,.6); border:1px solid rgba(255,255,255,.1); }
.map iframe{ width:100%; height:100%; border:0; filter:saturate(.92) contrast(1.02); }

/* ---------- Footer ---------- */
.footer{ background:var(--ink); color:rgba(255,255,255,.78); position:relative; padding-top:54px; }
.footer__stripes{ position:absolute; top:0; left:0; right:0; height:6px; background:repeating-linear-gradient(90deg, var(--evergreen) 0 40px, var(--moss) 40px 56px, var(--fresh) 56px 60px); }
.footer__inner{ display:grid; grid-template-columns:1.4fr 1fr 1fr; gap:36px; padding-bottom:40px; }
.footer__brand{ display:flex; gap:14px; align-items:flex-start; }
.footer__brand .brand__mark{ background:var(--evergreen); }
.footer__name{ font-family:var(--display); font-size:1.25rem; font-weight:600; color:var(--white); }
.footer__tag{ font-size:.9rem; margin-top:6px; max-width:34ch; }
.footer__nav{ display:flex; flex-direction:column; gap:10px; }
.footer__nav a, .footer__contact a, .footer__contact span{ font-size:.92rem; transition:color .25s; }
.footer__nav a:hover, .footer__contact a:hover{ color:var(--fresh); }
.footer__contact{ display:flex; flex-direction:column; gap:10px; }
.footer__bottom{ display:flex; flex-wrap:wrap; justify-content:space-between; gap:10px; padding:22px 0; border-top:1px solid rgba(255,255,255,.1); font-size:.8rem; color:rgba(255,255,255,.55); }

/* ---------- Reveal animation ---------- */
.reveal{ opacity:0; transform:translateY(26px); transition:opacity .8s var(--ease-out), transform .8s var(--ease-out); }
.reveal.is-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; }

/* ---------- Responsive ---------- */
@media (max-width:1024px){
  .svc-grid{ grid-template-columns:1fr 1fr; }
  .gallery{ grid-template-columns:1fr 1fr; }
  .gallery__item--tall{ grid-row:span 1; aspect-ratio:4/3; }
  .reviews__grid{ grid-template-columns:1fr 1fr; }
  .about__grid{ grid-template-columns:1fr; }
  .about__media{ max-width:520px; }
}
@media (max-width:860px){
  .nav__links, .nav__cta .btn{ display:none; }
  .nav__cta{ margin-left:auto; }
  .nav__toggle{ display:flex; }
  .nav__mobile{ display:flex; }
  .contact__grid{ grid-template-columns:1fr; }
  .footer__inner{ grid-template-columns:1fr 1fr; }
}
@media (max-width:600px){
  .svc-grid, .gallery, .reviews__grid{ grid-template-columns:1fr; }
  .form__row{ grid-template-columns:1fr; }
  .about__points{ grid-template-columns:1fr; }
  .hero__stats{ gap:16px; }
  .stat__div{ display:none; }
  .footer__inner{ grid-template-columns:1fr; }
  .trust__inner{ flex-direction:column; align-items:flex-start; }
  .nav__cta .phone-link{ display:none; }
}

/* ---------- Reduced motion ---------- */
@media (prefers-reduced-motion:reduce){
  *, *::before, *::after{ animation-duration:.001ms !important; animation-iteration-count:1 !important; transition-duration:.001ms !important; scroll-behavior:auto !important; }
  .reveal{ opacity:1; transform:none; }
  .hero__img{ transform:none; }
  .hero__title .line span, .hero__stripes span{ transform:none; }
  .loader{ display:none; }
}
