/* ============================================================
   Radley's Tree Service — Incline Sites
   2026 arborist-premium · deep forest + wood + cream
   ============================================================ */

:root{
  --forest-dk:#13201a;
  --forest:#1c2b22;
  --forest-2:#24382b;
  --olive:#4d6b3e;
  --leaf:#a7c08a;
  --leaf-lt:#c9dcb1;
  --leaf-dk:#6f8f56;
  --wood:#8a6a45;
  --wood-dk:#5e472e;
  --gold:#d8b15f;
  --cream:#f4efe4;
  --cream-2:#e9e2d2;
  --ink:#1a1f1a;
  --muted:#5d6a59;

  --bg:#f4efe4;
  --card:#ffffff;

  --radius:20px;
  --radius-sm:13px;
  --maxw:1180px;
  --ease:cubic-bezier(.2,.7,.2,1);
  --shadow:0 18px 50px -22px rgba(19,32,26,.45);
  --shadow-sm:0 8px 24px -12px rgba(19,32,26,.4);

  --font:'Inter',-apple-system,BlinkMacSystemFont,'Segoe UI',Roboto,Helvetica,Arial,sans-serif;
  --serif:'Georgia','Times New Roman',serif;
}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  font-family:var(--font);
  background:var(--bg);
  color:var(--ink);
  line-height:1.6;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
}
img{max-width:100%;display:block;height:auto}
a{color:inherit;text-decoration:none}
svg{display:block}

.wrap{width:100%;max-width:var(--maxw);margin:0 auto;padding:0 22px}
.section{padding:clamp(64px,11vw,128px) 0}

/* ---- accessibility ---- */
.skip-link{
  position:fixed;left:14px;top:-60px;z-index:200;
  background:var(--forest);color:var(--cream);
  padding:11px 18px;border-radius:10px;font-weight:600;
  transition:top .25s var(--ease);
}
.skip-link:focus{top:14px;outline:3px solid var(--gold)}
:focus-visible{outline:3px solid var(--olive);outline-offset:3px;border-radius:6px}

/* ---- type ---- */
.kicker{
  font-size:.78rem;font-weight:700;letter-spacing:.16em;text-transform:uppercase;
  color:var(--olive);margin-bottom:14px;display:inline-flex;align-items:center;gap:8px;
}
.section-title{
  font-size:clamp(1.9rem,5.2vw,3.4rem);
  line-height:1.05;font-weight:800;letter-spacing:-.02em;
  color:var(--forest);
}
.section-lede{
  font-size:clamp(1rem,2.3vw,1.16rem);
  color:var(--muted);max-width:60ch;margin-top:18px;
}
.section-head{max-width:780px;margin-bottom:clamp(36px,6vw,64px)}
.grad{
  background:linear-gradient(100deg,var(--olive),var(--leaf-dk) 55%,var(--gold));
  -webkit-background-clip:text;background-clip:text;color:transparent;
}

/* ---- buttons ---- */
.btn{
  --p:14px 22px;
  display:inline-flex;align-items:center;justify-content:center;gap:9px;
  padding:var(--p);border-radius:13px;font-weight:700;font-size:.98rem;
  cursor:pointer;border:none;min-height:48px;position:relative;overflow:hidden;
  transition:transform .3s var(--ease),box-shadow .3s var(--ease),background .3s var(--ease);
  -webkit-tap-highlight-color:transparent;
}
.btn::after{
  content:"";position:absolute;inset:0;
  background:linear-gradient(120deg,transparent 30%,rgba(255,255,255,.35) 50%,transparent 70%);
  transform:translateX(-130%);transition:transform .7s var(--ease);
}
.btn:hover::after{transform:translateX(130%)}
.btn:hover{transform:translateY(-2px)}
.btn:active{transform:translateY(0) scale(.98)}
.btn-primary{background:linear-gradient(135deg,var(--olive),var(--forest-2));color:var(--cream);box-shadow:var(--shadow-sm)}
.btn-primary:hover{box-shadow:0 16px 36px -14px rgba(28,43,34,.6)}
.btn-ghost{background:rgba(244,239,228,.1);color:var(--cream);border:1.5px solid rgba(244,239,228,.4);backdrop-filter:blur(8px)}
.btn-ghost:hover{background:rgba(244,239,228,.18)}
.btn-call{background:var(--gold);color:var(--forest-dk)}
.btn-block{width:100%}

.link-underline{
  position:relative;font-weight:700;color:var(--olive);display:inline-block;
}
.link-underline::after{
  content:"";position:absolute;left:0;bottom:-2px;width:100%;height:2px;
  background:var(--olive);transform:scaleX(0);transform-origin:left;
  transition:transform .35s var(--ease);
}
.link-underline:hover::after{transform:scaleX(1)}

/* ============================================================
   HEADER
   ============================================================ */
.site-header{
  position:fixed;top:0;left:0;right:0;z-index:100;
  padding:18px 0;
  transition:padding .35s var(--ease),background .35s var(--ease),box-shadow .35s var(--ease);
}
.site-header.scrolled{
  padding:9px 0;
  background:rgba(244,239,228,.82);
  backdrop-filter:saturate(180%) blur(16px);
  -webkit-backdrop-filter:saturate(180%) blur(16px);
  box-shadow:0 1px 0 rgba(19,32,26,.08),0 14px 30px -22px rgba(19,32,26,.5);
}
.header-inner{display:flex;align-items:center;justify-content:space-between;gap:18px}
.brand{display:flex;align-items:center;gap:11px;transition:transform .3s var(--ease)}
.brand:hover{transform:translateY(-1px)}
.brand-mark{
  display:grid;place-items:center;width:44px;height:44px;border-radius:13px;
  background:linear-gradient(150deg,var(--forest),var(--forest-2));
  box-shadow:inset 0 0 0 1px rgba(167,192,138,.25);
}
.brand-text{display:flex;flex-direction:column;line-height:1}
.brand-name{font-weight:800;font-size:1.18rem;letter-spacing:-.01em;color:var(--forest)}
.scrolled .brand-name{color:var(--forest)}
.brand-sub{font-size:.66rem;letter-spacing:.22em;text-transform:uppercase;color:var(--olive);margin-top:3px;font-weight:600}
/* header over hero (not scrolled) = light text */
.site-header:not(.scrolled) .brand-name{color:var(--cream)}
.site-header:not(.scrolled) .brand-sub{color:var(--leaf)}
.site-header:not(.scrolled) .nav a{color:rgba(244,239,228,.9)}

.nav{display:none;gap:30px}
.nav a{font-weight:600;font-size:.95rem;color:var(--forest);position:relative;padding:4px 0}
.nav a::after{content:"";position:absolute;left:0;bottom:-3px;width:100%;height:2px;background:var(--olive);transform:scaleX(0);transform-origin:center;transition:transform .3s var(--ease)}
.nav a:hover::after{transform:scaleX(1)}
.header-call{display:none;font-size:.9rem;padding:11px 17px;min-height:44px}

@media(min-width:920px){
  .nav{display:flex}
  .header-call{display:inline-flex}
}

/* ============================================================
   HERO
   ============================================================ */
.hero{
  position:relative;min-height:100svh;
  display:flex;align-items:flex-end;
  padding:120px 0 92px;
  background:
    radial-gradient(120% 80% at 80% 0%,rgba(77,107,62,.35),transparent 60%),
    radial-gradient(130% 90% at 10% 100%,rgba(19,32,26,.5),transparent 55%),
    linear-gradient(160deg,var(--forest) 0%,var(--forest-dk) 55%,#0e1813 100%);
  overflow:hidden;
}
.hero::before{ /* subtle desert horizon glow */
  content:"";position:absolute;inset:0;
  background:radial-gradient(60% 40% at 70% 18%,rgba(216,177,95,.18),transparent 60%);
  pointer-events:none;
}
.leaf-canvas{position:absolute;inset:0;width:100%;height:100%;z-index:1;pointer-events:none}
.hero-tree{
  position:absolute;right:-6%;bottom:0;height:88%;width:auto;max-width:62%;
  z-index:1;opacity:.92;transform-origin:bottom center;
  filter:drop-shadow(0 30px 40px rgba(0,0,0,.35));
}
.hero-inner{position:relative;z-index:3;max-width:680px}
.hero-eyebrow{
  display:inline-flex;align-items:center;gap:10px;
  color:var(--leaf);font-weight:600;font-size:.86rem;letter-spacing:.04em;
  padding:8px 15px;border-radius:999px;
  background:rgba(167,192,138,.1);border:1px solid rgba(167,192,138,.28);
  backdrop-filter:blur(6px);margin-bottom:24px;
}
.hero-eyebrow .dot{width:8px;height:8px;border-radius:50%;background:var(--gold);box-shadow:0 0 0 0 rgba(216,177,95,.6);animation:pulse 2.4s infinite}
.hero-title{
  font-size:clamp(2.5rem,9vw,5.2rem);line-height:.98;font-weight:800;
  letter-spacing:-.03em;color:var(--cream);margin-bottom:22px;
}
.hero-lede{font-size:clamp(1.05rem,2.6vw,1.32rem);color:rgba(244,239,228,.82);max-width:54ch;margin-bottom:32px}
.hero-cta{display:flex;flex-wrap:wrap;gap:13px;margin-bottom:30px}
.hero-trust{list-style:none;display:flex;flex-wrap:wrap;gap:10px 22px}
.hero-trust li{display:flex;align-items:center;gap:7px;color:var(--leaf-lt);font-size:.9rem;font-weight:500}
.hero-trust svg{color:var(--gold)}

.scroll-hint{position:absolute;left:50%;bottom:22px;transform:translateX(-50%);z-index:3;width:26px;height:42px;border:2px solid rgba(244,239,228,.4);border-radius:14px;display:grid;place-items:start center;padding-top:7px}
.scroll-hint span{width:4px;height:8px;border-radius:3px;background:var(--leaf);animation:scrolldot 1.8s infinite}
@keyframes scrolldot{0%{opacity:0;transform:translateY(-2px)}40%{opacity:1}80%{opacity:0;transform:translateY(12px)}}
@keyframes pulse{0%{box-shadow:0 0 0 0 rgba(216,177,95,.5)}70%{box-shadow:0 0 0 12px rgba(216,177,95,0)}100%{box-shadow:0 0 0 0 rgba(216,177,95,0)}}

/* swaying tree */
.tree-trunk{transform-origin:300px 700px;animation:sway 7s ease-in-out infinite}
.branch-1{transform-origin:300px 360px;animation:sway 6s ease-in-out infinite}
.branch-2{transform-origin:300px 340px;animation:sway 6.6s ease-in-out infinite reverse}
.branch-3{transform-origin:300px 300px;animation:sway-top 8s ease-in-out infinite}
@keyframes sway{0%,100%{transform:rotate(-1.1deg)}50%{transform:rotate(1.1deg)}}
@keyframes sway-top{0%,100%{transform:rotate(-1.8deg)}50%{transform:rotate(1.8deg)}}

/* ============================================================
   MARQUEE
   ============================================================ */
.marquee{
  background:var(--forest);color:var(--cream);
  padding:18px 0;overflow:hidden;white-space:nowrap;
  border-top:1px solid rgba(167,192,138,.15);border-bottom:1px solid rgba(167,192,138,.15);
}
.marquee-track{display:inline-flex;align-items:center;gap:30px;animation:scroll-x 26s linear infinite;will-change:transform}
.marquee-track span{font-size:clamp(1rem,2.4vw,1.5rem);font-weight:800;letter-spacing:-.01em;text-transform:uppercase}
.marquee-track .sep{color:var(--gold)}
@keyframes scroll-x{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* ============================================================
   STATS
   ============================================================ */
.stats{background:linear-gradient(180deg,var(--bg),var(--cream-2));padding:clamp(48px,8vw,80px) 0}
.stats-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:18px}
.stat{
  background:var(--card);border-radius:var(--radius);padding:26px 22px;text-align:center;
  box-shadow:var(--shadow-sm);border:1px solid rgba(19,32,26,.05);
  transition:transform .4s var(--ease),box-shadow .4s var(--ease);
}
.stat:hover{transform:translateY(-4px);box-shadow:var(--shadow)}
.stat-num{display:block;font-size:clamp(2.1rem,7vw,3rem);font-weight:800;letter-spacing:-.03em;color:var(--olive);line-height:1}
.stat-label{display:block;margin-top:8px;font-size:.86rem;color:var(--muted);font-weight:600}
@media(min-width:760px){.stats-grid{grid-template-columns:repeat(4,1fr)}}

/* ============================================================
   SERVICES
   ============================================================ */
.cards{display:grid;grid-template-columns:1fr;gap:18px}
.card{
  background:var(--card);border-radius:var(--radius);padding:30px 26px;
  border:1px solid rgba(19,32,26,.06);box-shadow:var(--shadow-sm);
  transition:transform .45s var(--ease),box-shadow .45s var(--ease);
  position:relative;overflow:hidden;
}
.card::before{content:"";position:absolute;inset:0;background:linear-gradient(135deg,rgba(167,192,138,.12),transparent 60%);opacity:0;transition:opacity .4s var(--ease)}
.card:hover{transform:translateY(-6px);box-shadow:var(--shadow)}
.card:hover::before{opacity:1}
.card-ico{
  width:54px;height:54px;border-radius:15px;display:grid;place-items:center;
  background:linear-gradient(150deg,var(--forest),var(--forest-2));color:var(--leaf);
  margin-bottom:18px;transition:transform .4s var(--ease);
}
.card:hover .card-ico{transform:rotate(-6deg) scale(1.06)}
.card h3{font-size:1.22rem;font-weight:800;color:var(--forest);margin-bottom:9px;letter-spacing:-.01em}
.card p{color:var(--muted);font-size:.97rem}
.card-cta-tile{background:linear-gradient(150deg,var(--forest),var(--forest-dk));color:var(--cream);display:flex;flex-direction:column;justify-content:center;gap:10px}
.card-cta-tile h3{color:var(--cream)}
.card-cta-tile p{color:rgba(244,239,228,.78)}
.card-cta-tile .link-underline{color:var(--leaf);margin-top:4px}
.card-cta-tile .link-underline::after{background:var(--leaf)}
@media(min-width:680px){.cards{grid-template-columns:repeat(2,1fr)}}
@media(min-width:1000px){.cards{grid-template-columns:repeat(3,1fr)}}

/* ============================================================
   ARBORIST
   ============================================================ */
.arborist{background:linear-gradient(165deg,var(--forest) 0%,var(--forest-dk) 100%);color:var(--cream);position:relative;overflow:hidden}
.arborist::before{content:"";position:absolute;top:-30%;right:-10%;width:60%;height:140%;background:radial-gradient(circle,rgba(77,107,62,.4),transparent 65%);pointer-events:none}
.arborist-grid{display:grid;grid-template-columns:1fr;gap:44px;align-items:center;position:relative}
.arborist .kicker{color:var(--gold)}
.arborist .section-title{color:var(--cream)}
.arborist-copy p{color:rgba(244,239,228,.84);margin-bottom:16px;max-width:54ch}
.arborist-copy strong{color:var(--leaf-lt)}
.arborist-copy .btn{margin-top:12px}
.arborist-badge-col{display:grid;place-items:center}
.badge{width:min(300px,78vw);aspect-ratio:1;display:grid;place-items:center;filter:drop-shadow(0 24px 40px rgba(0,0,0,.4))}
.badge-svg{width:100%;height:100%}
.seal-tree{transform-origin:110px 110px}
@media(min-width:880px){.arborist-grid{grid-template-columns:.9fr 1.1fr;gap:60px}.arborist-badge-col{order:0}}

/* badge draw animation */
.seal-draw{stroke-dasharray:541;stroke-dashoffset:541}
.seal-ring{opacity:0;transform:scale(.6);transform-origin:110px 110px}
.seal-text,.seal-tree{opacity:0}
.badge.sealed .seal-draw{animation:draw 1.4s var(--ease) forwards}
.badge.sealed .seal-ring{animation:popring .7s var(--ease) .3s forwards}
.badge.sealed .seal-text{animation:fadein .6s ease .9s forwards}
.badge.sealed .seal-tree{animation:stamp .6s var(--ease) 1.1s forwards}
@keyframes draw{to{stroke-dashoffset:0}}
@keyframes popring{0%{opacity:0;transform:scale(.6)}60%{opacity:1;transform:scale(1.05)}100%{opacity:1;transform:scale(1)}}
@keyframes fadein{to{opacity:1}}
@keyframes stamp{0%{opacity:0;transform:scale(1.5)}100%{opacity:1;transform:scale(1)}}

/* ============================================================
   WHY US
   ============================================================ */
.why-grid{display:grid;grid-template-columns:1fr;gap:14px}
.why-item{
  padding:26px 24px;border-radius:var(--radius);background:var(--card);
  border:1px solid rgba(19,32,26,.06);box-shadow:var(--shadow-sm);
  transition:transform .4s var(--ease),box-shadow .4s var(--ease);
}
.why-item:hover{transform:translateY(-4px);box-shadow:var(--shadow)}
.why-no{font-size:.82rem;font-weight:800;letter-spacing:.1em;color:var(--gold)}
.why-item h3{font-size:1.18rem;font-weight:800;color:var(--forest);margin:8px 0 7px;letter-spacing:-.01em}
.why-item p{color:var(--muted);font-size:.96rem}
@media(min-width:680px){.why-grid{grid-template-columns:repeat(2,1fr)}}
@media(min-width:1000px){.why-grid{grid-template-columns:repeat(4,1fr)}}

/* ============================================================
   GALLERY
   ============================================================ */
.gallery{background:linear-gradient(180deg,var(--cream-2),var(--bg))}
.gallery-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:14px;grid-auto-flow:dense}
.g-item{border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-sm);position:relative;background:var(--forest)}
.g-item img{width:100%;height:100%;object-fit:cover;aspect-ratio:4/5;transition:transform .9s var(--ease)}
.g-item::after{content:"";position:absolute;inset:0;background:linear-gradient(to top,rgba(19,32,26,.28),transparent 50%);opacity:0;transition:opacity .4s var(--ease)}
.g-item:hover img{transform:scale(1.07)}
.g-item:hover::after{opacity:1}
.g-tall{grid-row:span 2}
.g-tall img{aspect-ratio:4/7}
@media(min-width:760px){.gallery-grid{grid-template-columns:repeat(3,1fr)}}

/* ============================================================
   ABOUT
   ============================================================ */
.about-grid{display:grid;grid-template-columns:1fr;gap:42px;align-items:center}
.about-media{position:relative;border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow)}
.about-media img{width:100%;aspect-ratio:4/5;object-fit:cover}
.about-badge{
  position:absolute;left:18px;bottom:18px;
  background:rgba(19,32,26,.82);backdrop-filter:blur(10px);
  color:var(--cream);padding:16px 20px;border-radius:15px;
  border:1px solid rgba(167,192,138,.3);
}
.ab-num{display:block;font-size:1.7rem;font-weight:800;color:var(--gold);line-height:1}
.ab-lbl{display:block;font-size:.78rem;color:var(--leaf-lt);margin-top:4px}
.about-copy p{color:var(--muted);margin-bottom:15px;max-width:56ch}
.about-copy strong{color:var(--forest)}
.about-signers{display:flex;flex-wrap:wrap;gap:10px;margin-top:22px}
.signer{font-size:.84rem;font-weight:700;color:var(--olive);padding:9px 15px;border-radius:999px;background:rgba(77,107,62,.1);border:1px solid rgba(77,107,62,.2)}
@media(min-width:880px){.about-grid{grid-template-columns:.85fr 1.15fr;gap:60px}}

/* ============================================================
   REVIEWS
   ============================================================ */
.reviews{background:linear-gradient(165deg,var(--forest-2),var(--forest-dk));color:var(--cream)}
.reviews .kicker{color:var(--gold)}
.reviews .section-title{color:var(--cream)}
.reviews .section-lede{color:rgba(244,239,228,.7)}
.review-cards{display:grid;grid-template-columns:1fr;gap:18px}
.review{
  background:rgba(244,239,228,.06);border:1px solid rgba(167,192,138,.18);
  border-radius:var(--radius);padding:28px 24px;backdrop-filter:blur(6px);
  transition:transform .4s var(--ease),background .4s var(--ease);
}
.review:hover{transform:translateY(-5px);background:rgba(244,239,228,.1)}
.stars{color:var(--gold);font-size:1.15rem;letter-spacing:2px;margin-bottom:12px}
.review p{color:rgba(244,239,228,.9);font-size:1rem}
.review-tag{display:inline-block;margin-top:16px;font-size:.75rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--leaf);padding:6px 12px;border-radius:999px;background:rgba(167,192,138,.12)}
.review-note{margin-top:26px;font-size:.82rem;color:rgba(244,239,228,.55);text-align:center}
@media(min-width:760px){.review-cards{grid-template-columns:repeat(3,1fr)}}

/* ============================================================
   SERVICE AREA
   ============================================================ */
.area-grid{display:grid;grid-template-columns:1fr;gap:40px;align-items:center}
.area-copy p{color:var(--muted);margin-bottom:18px;max-width:54ch}
.area-list{list-style:none;display:flex;flex-wrap:wrap;gap:10px;margin:6px 0 18px}
.area-list li{font-size:.9rem;font-weight:700;color:var(--forest);padding:9px 16px;border-radius:999px;background:var(--card);box-shadow:var(--shadow-sm);border:1px solid rgba(19,32,26,.06);transition:transform .3s var(--ease),color .3s var(--ease)}
.area-list li:hover{transform:translateY(-3px);color:var(--olive)}
.area-note{font-size:.95rem}
.map-svg{width:100%;height:auto;border-radius:var(--radius);box-shadow:var(--shadow)}
.map-pulse{transform-origin:195px 180px;animation:mappulse 2.6s ease-out infinite}
@keyframes mappulse{0%{opacity:.7;transform:scale(.4)}100%{opacity:0;transform:scale(1.3)}}
@media(min-width:880px){.area-grid{grid-template-columns:1.1fr .9fr;gap:60px}}

/* ============================================================
   FAQ
   ============================================================ */
.faq-list{display:grid;gap:13px;max-width:840px}
.faq-item{
  background:var(--card);border-radius:var(--radius-sm);
  border:1px solid rgba(19,32,26,.07);box-shadow:var(--shadow-sm);overflow:hidden;
  transition:box-shadow .3s var(--ease);
}
.faq-item[open]{box-shadow:var(--shadow)}
.faq-item summary{
  list-style:none;cursor:pointer;padding:20px 22px;
  font-weight:700;font-size:1.04rem;color:var(--forest);
  display:flex;align-items:center;justify-content:space-between;gap:16px;
}
.faq-item summary::-webkit-details-marker{display:none}
.chev{width:13px;height:13px;border-right:2.5px solid var(--olive);border-bottom:2.5px solid var(--olive);transform:rotate(45deg);transition:transform .3s var(--ease);flex-shrink:0}
.faq-item[open] .chev{transform:rotate(-135deg)}
.faq-item p{padding:0 22px 22px;color:var(--muted);font-size:.97rem;max-width:62ch}

/* ============================================================
   CONTACT
   ============================================================ */
.contact{background:linear-gradient(180deg,var(--bg),var(--cream-2))}
.contact-grid{display:grid;grid-template-columns:1fr;gap:40px}
.contact-copy p{color:var(--muted);margin-bottom:22px;max-width:48ch}
.contact-copy strong{color:var(--forest)}
.contact-phone{display:inline-flex;align-items:center;gap:11px;font-size:clamp(1.4rem,5vw,1.9rem);font-weight:800;color:var(--olive);letter-spacing:-.01em;margin-bottom:26px}
.contact-meta{list-style:none;display:grid;gap:13px}
.contact-meta li{font-size:.95rem;color:var(--muted)}
.contact-meta strong{display:block;font-size:.74rem;letter-spacing:.1em;text-transform:uppercase;color:var(--olive);margin-bottom:2px}

.contact-form{background:var(--card);border-radius:var(--radius);padding:clamp(24px,5vw,34px);box-shadow:var(--shadow);border:1px solid rgba(19,32,26,.06)}
.field{margin-bottom:16px}
.field-row{display:grid;grid-template-columns:1fr;gap:0}
.field label{display:block;font-size:.82rem;font-weight:700;color:var(--forest);margin-bottom:7px}
.field input,.field select,.field textarea{
  width:100%;padding:13px 15px;border-radius:12px;border:1.5px solid rgba(19,32,26,.13);
  font:inherit;font-size:.96rem;color:var(--ink);background:#fcfbf7;
  transition:border-color .25s var(--ease),box-shadow .25s var(--ease);
  min-height:48px;
}
.field textarea{min-height:88px;resize:vertical}
.field input:focus,.field select:focus,.field textarea:focus{
  outline:none;border-color:var(--olive);box-shadow:0 0 0 4px rgba(77,107,62,.13);
}
.form-msg{margin-top:14px;font-weight:700;font-size:.93rem;color:var(--olive);min-height:1px}
.form-fine{margin-top:14px;font-size:.85rem;color:var(--muted);text-align:center}
.form-fine a{color:var(--olive);font-weight:700}
@media(min-width:560px){.field-row{grid-template-columns:1fr 1fr;gap:14px}}
@media(min-width:880px){.contact-grid{grid-template-columns:1fr 1fr;gap:54px}}

/* ============================================================
   FOOTER
   ============================================================ */
.site-footer{background:var(--forest-dk);color:var(--cream);padding:56px 0 26px}
.footer-inner{display:grid;grid-template-columns:1fr;gap:34px;padding-bottom:34px;border-bottom:1px solid rgba(167,192,138,.16)}
.footer-brand .brand-name{color:var(--cream)}
.footer-brand .brand-sub{color:var(--leaf)}
.footer-brand p{color:rgba(244,239,228,.65);font-size:.92rem;margin-top:14px;max-width:42ch}
.footer-nav{display:flex;flex-direction:column;gap:11px}
.footer-nav a{color:rgba(244,239,228,.8);font-weight:600;font-size:.95rem;transition:color .25s var(--ease)}
.footer-nav a:hover{color:var(--leaf)}
.footer-contact{display:flex;flex-direction:column;gap:6px}
.footer-phone{font-size:1.4rem;font-weight:800;color:var(--gold)}
.footer-contact p{color:rgba(244,239,228,.65);font-size:.9rem}
.footer-base{display:flex;flex-wrap:wrap;justify-content:space-between;gap:8px;padding-top:22px;color:rgba(244,239,228,.5);font-size:.82rem}
@media(min-width:760px){.footer-inner{grid-template-columns:1.6fr 1fr 1fr}}

/* ============================================================
   STICKY MOBILE CALL BAR
   ============================================================ */
.call-bar{
  position:fixed;left:12px;right:12px;bottom:12px;z-index:90;
  display:flex;align-items:center;gap:13px;
  background:linear-gradient(135deg,var(--olive),var(--forest-2));
  color:var(--cream);padding:13px 18px;border-radius:16px;
  box-shadow:0 14px 34px -10px rgba(19,32,26,.7);
  transform:translateY(140%);transition:transform .5s var(--ease);
  border:1px solid rgba(167,192,138,.3);min-height:60px;
}
.call-bar.show{transform:translateY(0)}
.cb-pulse{position:absolute;left:18px;width:20px;height:20px;border-radius:50%;background:var(--gold);opacity:.4;animation:cbpulse 2s infinite;z-index:-1}
@keyframes cbpulse{0%{transform:scale(1);opacity:.4}70%{transform:scale(2.6);opacity:0}100%{opacity:0}}
.call-bar svg{flex-shrink:0;color:var(--gold)}
.cb-text{display:flex;flex-direction:column;line-height:1.2}
.cb-text strong{font-size:.98rem;font-weight:800}
.cb-text span{font-size:.78rem;color:var(--leaf-lt)}
.call-bar:active{transform:scale(.99)}
@media(min-width:920px){.call-bar{display:none}}
body{padding-bottom:0}
@media(max-width:919px){body{scroll-padding-bottom:90px}}

/* ============================================================
   SCROLL REVEAL
   ============================================================ */
.reveal{opacity:0;transform:translateY(28px);transition:opacity .8s var(--ease),transform .8s var(--ease)}
.reveal.in{opacity:1;transform:none}

/* tilt cards default no-transform on touch */
@media(hover:none){.tilt{transform:none!important}}

/* ============================================================
   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;
  }
  html{scroll-behavior:auto}
  .reveal{opacity:1!important;transform:none!important}
  .marquee-track{animation:none}
  .tree-trunk,.branch-1,.branch-2,.branch-3{animation:none}
  .leaf-canvas{display:none}
  .seal-draw{stroke-dashoffset:0}
  .seal-ring,.seal-text,.seal-tree{opacity:1;transform:none}
  .call-bar{transform:translateY(0)}
  .scroll-hint{display:none}
}
