/* Cappelli Green Services — reference: service/service3 */
:root{
  --green:#2f4a26; --green-d:#22381c; --green-dd:#1a2a14;
  --cream:#f4f1e8; --cream-d:#ece7d8;
  --accent:#7ba62f;
  --ink:#1c2419; --ink-soft:#43503c; --mute:#717b67;
  --hair:#e4e1d3; --hair-d:#d8d3c2;
  --white:#fff;
  --shadow-soft:0 1px 2px rgba(28,36,25,.04),0 12px 30px -16px rgba(28,36,25,.18);
  --shadow-lift:0 1px 2px rgba(28,36,25,.05),0 26px 50px -20px rgba(28,36,25,.30);
  --r:18px; --r-lg:26px;
  --f:'Hanken Grotesk',-apple-system,BlinkMacSystemFont,'Segoe UI',Roboto,sans-serif;
  --mono:'JetBrains Mono',ui-monospace,SFMono-Regular,Menlo,monospace;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{font-family:var(--f);background:#fff;color:var(--ink);font-size:16px;line-height:1.6;-webkit-font-smoothing:antialiased;overflow-x:hidden}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
h1,h2,h3,h4{line-height:1.08;letter-spacing:-.03em;font-weight:800;color:var(--ink)}
h2{font-size:clamp(2rem,4.4vw,3.4rem)}
h3{font-size:1.5rem;letter-spacing:-.02em}
p{color:var(--ink-soft)}
.wrap{max-width:1200px;margin:0 auto;padding:0 28px}
.sect{padding:96px 0}
.sect-sm{padding:66px 0}
.cream{background:var(--cream)}
.dark{background:var(--green);color:#fff}
.dark h1,.dark h2,.dark h3{color:#fff}
.dark p{color:rgba(255,255,255,.78)}
.eyebrow{font-size:12.5px;font-weight:600;letter-spacing:.14em;text-transform:uppercase;color:var(--accent);display:inline-flex;align-items:center;gap:8px}
.eyebrow::before{content:'';width:22px;height:1.5px;background:var(--accent);display:inline-block}
.dark .eyebrow{color:#a9c47e}
.dark .eyebrow::before{background:#a9c47e}
.shead{max-width:680px}
.shead.center{margin:0 auto;text-align:center}
.shead.center .eyebrow{justify-content:center}
.shead h2{margin:16px 0 14px}
.shead .lead{font-size:1.075rem;color:var(--mute)}
.dark .shead .lead{color:rgba(255,255,255,.72)}
.thin{font-weight:300;color:var(--mute)}
.dark .thin{color:rgba(255,255,255,.55)}

/* buttons */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:9px;padding:15px 26px;border-radius:999px;font-weight:600;font-size:14.5px;border:1.5px solid transparent;cursor:pointer;transition:transform .22s,background .22s,color .22s,border-color .22s;letter-spacing:-.01em;white-space:nowrap;text-align:center}
.btn:hover{transform:translateY(-2px)}
.btn svg{width:17px;height:17px;flex-shrink:0}
.svc-num svg{width:20px;height:20px;stroke:#fff}
.btn-primary{background:var(--green);color:#fff}
.btn-primary:hover{background:var(--green-d)}
.btn-accent{background:var(--accent);color:#16210a}
.btn-accent:hover{background:#8cb83c}
.btn-light{background:#fff;color:var(--ink);border-color:var(--hair)}
.btn-light:hover{background:var(--ink);color:#fff;border-color:var(--ink)}
.btn-outline{background:transparent;color:#fff;border-color:rgba(255,255,255,.4)}
.btn-outline:hover{background:#fff;color:var(--green-d);border-color:#fff}
.btn-ghost{background:transparent;color:var(--green);border-color:var(--green)}
.btn-ghost:hover{background:var(--green);color:#fff}

/* ===== NAV (glass pill) ===== */
.nav-wrap{position:fixed;top:18px;left:0;right:0;z-index:90;display:flex;justify-content:center;padding:0 16px}
.nav-pill{display:inline-flex;align-items:center;gap:30px;width:fit-content;margin:0 auto;
  background:rgba(244,241,232,.86);backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);
  border:1px solid rgba(255,255,255,.5);border-radius:999px;padding:9px 9px 9px 22px;box-shadow:0 10px 34px -14px rgba(28,36,25,.4)}
.nav-brand{display:flex;align-items:center;gap:10px;flex-shrink:0}
.nav-brand img{height:38px;width:auto}
.nav-links{display:flex;gap:24px;margin:0;list-style:none}
.nav-links a{font-size:14px;font-weight:600;color:var(--ink);transition:color .2s}
.nav-links a:hover{color:var(--accent)}
.nav-cta{display:inline-flex;align-items:center;gap:7px;background:var(--green);color:#fff;padding:11px 20px;border-radius:999px;font-size:13.5px;font-weight:600;transition:background .2s,transform .2s}
.nav-cta:hover{background:var(--green-d);transform:translateY(-1px)}
.mobile-menu-toggle{display:inline-flex;align-items:center;justify-content:center;width:44px;height:44px;border-radius:999px;background:var(--green);border:none;cursor:pointer}
.mobile-menu-toggle span{width:18px;height:2px;background:#fff;position:relative;display:block}
.mobile-menu-toggle span::before,.mobile-menu-toggle span::after{content:'';position:absolute;left:0;width:18px;height:2px;background:#fff}
.mobile-menu-toggle span::before{top:-6px}.mobile-menu-toggle span::after{top:6px}
@media(min-width:1024px){.mobile-menu-toggle{display:none!important}}
@media(max-width:1023px){.nav-links,.nav-cta{display:none}.nav-pill{gap:14px;padding:8px 8px 8px 18px}}

/* mobile drawer */
.drawer{position:fixed;inset:0;z-index:120;background:rgba(26,42,20,.45);backdrop-filter:blur(3px);opacity:0;pointer-events:none;transition:opacity .25s}
.drawer.open{opacity:1;pointer-events:auto}
.drawer-panel{position:absolute;top:0;right:0;bottom:0;width:min(86vw,360px);background:var(--cream);padding:26px 24px;display:flex;flex-direction:column;gap:6px;transform:translateX(100%);transition:transform .3s cubic-bezier(.4,0,.2,1)}
.drawer.open .drawer-panel{transform:translateX(0)}
.drawer-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:18px}
.drawer-head img{height:42px}
.drawer-close{width:42px;height:42px;border-radius:999px;border:1px solid var(--hair);background:#fff;font-size:20px;cursor:pointer;color:var(--ink)}
.drawer a.dl{padding:14px 12px;border-radius:12px;font-weight:600;font-size:16px;color:var(--ink);border-bottom:1px solid var(--hair)}
.drawer a.dl:hover{background:#fff}
.drawer-phone{margin-top:18px;display:flex;flex-direction:column;gap:10px}
.drawer-phone .btn{justify-content:center}
.drawer-phone .dp-num{font-size:13px;color:var(--mute);text-align:center}

/* ===== HERO ===== */
.hero{position:relative;min-height:94vh;display:flex;align-items:flex-end;overflow:hidden;background:var(--green-d)}
.hero-bg{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.hero::after{content:'';position:absolute;inset:0;background:linear-gradient(180deg,rgba(26,42,20,.30) 0%,rgba(26,42,20,.10) 42%,rgba(26,42,20,.78) 100%)}
.hero-inner{position:relative;z-index:2;width:100%;max-width:1200px;margin:0 auto;padding:0 28px 72px;display:flex;align-items:flex-end;justify-content:space-between;gap:40px}
.hero-copy{max-width:680px}
.hero-tag{display:inline-flex;align-items:center;gap:8px;background:rgba(255,255,255,.16);border:1px solid rgba(255,255,255,.28);color:#fff;padding:8px 16px;border-radius:999px;font-size:12.5px;font-weight:600;letter-spacing:.04em;backdrop-filter:blur(6px);margin-bottom:22px;white-space:nowrap}
.hero-tag svg{width:15px;height:15px;flex-shrink:0}
.hero h1{color:#fff;font-size:clamp(2.9rem,6.6vw,5.4rem);letter-spacing:-.04em;line-height:.98}
.hero h1 em{font-style:normal;color:#bcd591}
.hero-sub{color:rgba(255,255,255,.86);font-size:1.12rem;margin:22px 0 30px;max-width:480px}
.hero-actions{display:flex;gap:14px;flex-wrap:wrap}
.hero-card{flex-shrink:0;width:320px;background:rgba(26,42,20,.82);backdrop-filter:blur(12px);border:1px solid rgba(255,255,255,.16);border-radius:var(--r-lg);padding:26px;color:#fff;margin-bottom:6px}
.hero-card h4{color:#fff;font-size:13px;letter-spacing:.1em;text-transform:uppercase;font-weight:700;color:#bcd591}
.hero-card ul{list-style:none;margin:16px 0 0;display:flex;flex-direction:column;gap:13px}
.hero-card li{display:flex;align-items:center;gap:11px;font-size:14.5px;color:rgba(255,255,255,.92);font-weight:500}
.hero-card li svg{flex-shrink:0;width:20px;height:20px;stroke:#bcd591}
.hero-card .hc-foot{margin-top:20px;padding-top:18px;border-top:1px solid rgba(255,255,255,.16);font-size:13px;color:rgba(255,255,255,.7)}
@media(max-width:980px){.hero-card{display:none}.hero-inner{padding-bottom:130px}}

/* trust strip */
.trust{background:var(--green-d);padding:20px 0}
.trust-row{display:flex;justify-content:center;flex-wrap:wrap;gap:14px 38px}
.trust-row .ti{display:flex;align-items:center;gap:9px;color:rgba(255,255,255,.9);font-size:13.5px;font-weight:600}
.trust-row .ti svg{width:18px;height:18px;stroke:#bcd591;flex-shrink:0}
.trust-row .ti strong{color:#fff}

/* about teaser */
.about-grid{display:grid;grid-template-columns:1.05fr 1fr;gap:64px;align-items:center}
.about-figure{position:relative}
.about-figure>img{width:100%;border-radius:var(--r-lg);aspect-ratio:4/3;object-fit:cover}
.about-stat{position:absolute;left:-26px;bottom:-26px;background:#fff;border:1px solid var(--hair);border-radius:var(--r);padding:20px 24px;box-shadow:var(--shadow-lift);max-width:230px}
.about-stat .as-stars{color:#fbbc05;font-size:16px;letter-spacing:1px}
.about-stat .as-num{font-size:2.4rem;font-weight:800;letter-spacing:-.03em;line-height:1;margin-top:4px}
.about-stat .as-lbl{font-size:12.5px;color:var(--mute);margin-top:6px}
.about-copy h2{margin:14px 0 16px}
.about-copy .lead{color:var(--mute);font-size:1.06rem}
.about-points{margin:24px 0 28px;display:flex;flex-direction:column;gap:13px;list-style:none}
.about-points li{display:flex;gap:12px;align-items:flex-start;font-size:15px;color:var(--ink-soft)}
.about-points li svg{flex-shrink:0;width:22px;height:22px;stroke:var(--green);margin-top:1px}
@media(max-width:860px){.about-grid{grid-template-columns:1fr;gap:60px}.about-stat{left:16px;bottom:-22px}}

/* services rows */
.svc-row{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:center;background:#fff;border:1px solid var(--hair);border-radius:var(--r-lg);padding:36px;margin-bottom:24px;transition:box-shadow .3s,transform .3s,border-color .3s}
.svc-row:hover{box-shadow:var(--shadow-lift);transform:translateY(-3px);border-color:var(--hair-d)}
.svc-row:last-child{margin-bottom:0}
.svc-row.flip .svc-media{order:2}
.svc-media{border-radius:var(--r);overflow:hidden;aspect-ratio:4/3}
.svc-media img{width:100%;height:100%;object-fit:cover}
.svc-num{display:inline-flex;align-items:center;justify-content:center;width:44px;height:44px;border-radius:999px;background:var(--green);color:#fff;font-weight:700;font-size:15px;font-family:var(--mono)}
.svc-body h3{font-size:1.6rem;margin:16px 0 10px}
.svc-body p{font-size:15px;color:var(--ink-soft)}
.svc-tags{display:flex;flex-wrap:wrap;gap:8px;margin:18px 0 20px}
.svc-tags span{font-size:12.5px;font-weight:600;color:var(--green-d);background:var(--cream);border:1px solid var(--hair);padding:6px 13px;border-radius:999px}
.svc-link{display:inline-flex;align-items:center;gap:8px;font-weight:700;font-size:14px;color:var(--green)}
.svc-link svg{width:15px;height:15px;transition:transform .25s}
.svc-link:hover svg{transform:translate(3px,-3px)}
@media(max-width:780px){.svc-row{grid-template-columns:1fr;gap:26px;padding:24px}.svc-row.flip .svc-media{order:0}}

/* why / feature band */
.feat-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:22px;margin-top:48px}
.feat-card{background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.14);border-radius:var(--r);padding:26px}
.feat-card .fi{width:46px;height:46px;border-radius:12px;background:#bcd591;display:flex;align-items:center;justify-content:center;margin-bottom:16px}
.feat-card .fi svg{width:24px;height:24px;stroke:var(--green-dd)}
.feat-card h3{font-size:1.12rem;color:#fff;margin-bottom:8px}
.feat-card p{font-size:13.8px;color:rgba(255,255,255,.74)}
@media(max-width:880px){.feat-grid{grid-template-columns:1fr 1fr}}
@media(max-width:520px){.feat-grid{grid-template-columns:1fr}}

/* gallery */
.gallery{display:grid;grid-template-columns:repeat(4,1fr);grid-auto-rows:200px;gap:16px;margin-top:48px}
.gallery figure{border-radius:var(--r);overflow:hidden;position:relative}
.gallery figure img{width:100%;height:100%;object-fit:cover;transition:transform .5s}
.gallery figure:hover img{transform:scale(1.06)}
.gallery .tall{grid-row:span 2}
.gallery .wide{grid-column:span 2}
@media(max-width:820px){.gallery{grid-template-columns:1fr 1fr;grid-auto-rows:160px}.gallery .wide{grid-column:span 2}}

/* ===== GOOGLE REVIEWS (template1 design) ===== */
.gr-summary{display:flex;align-items:center;justify-content:space-between;gap:32px;padding:24px 28px;background:#fff;border:1px solid var(--hair);border-radius:18px;margin-bottom:40px;flex-wrap:wrap;box-shadow:var(--shadow-soft)}
.gr-sum-left{display:flex;align-items:center;gap:20px}
.gr-logo{width:48px;height:48px;border-radius:999px;background:#f8f9fa;border:1px solid var(--hair);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.gr-meta-top{display:flex;align-items:baseline;gap:10px}
.gr-score{font-size:28px;font-weight:700;letter-spacing:-.03em;color:var(--ink)}
.gr-stars{display:inline-flex;gap:1px;color:#fbbc05;font-size:17px;letter-spacing:-1px}
.gr-sub{font-size:13px;color:var(--mute);margin-top:2px}
.gr-sub strong{color:var(--ink);font-weight:600}
.gr-cta{display:inline-flex;align-items:center;gap:8px;padding:11px 18px;border-radius:999px;font-size:13px;font-weight:600;color:var(--ink);border:1px solid var(--hair);background:#fff;transition:background .25s,transform .25s,border-color .25s}
.gr-cta:hover{background:var(--ink);color:#fff;border-color:var(--ink);transform:translateY(-1px)}
.gr-cta svg{width:12px;height:12px}
.gr-marquee{position:relative;overflow:hidden;margin:0 -32px 16px;padding:8px 0;min-height:184px;isolation:isolate;contain:layout}
.gr-marquee::before,.gr-marquee::after{content:'';position:absolute;top:0;bottom:0;width:60px;z-index:2;pointer-events:none}
.gr-marquee::before{left:0;background:linear-gradient(90deg,#fff,transparent)}
.gr-marquee::after{right:0;background:linear-gradient(-90deg,#fff,transparent)}
.gr-marquee:last-child{margin-bottom:0}
.gr-track{display:flex;gap:20px;width:max-content;will-change:transform}
.gr-card{flex:0 0 360px;background:#fff;border:1px solid var(--hair);border-radius:16px;padding:20px 22px;display:flex;flex-direction:column;gap:12px;box-shadow:var(--shadow-soft);transition:transform .3s,box-shadow .3s,border-color .3s}
.gr-card:hover{transform:translateY(-2px);border-color:var(--hair-d);box-shadow:var(--shadow-lift)}
.gr-card-head{display:flex;align-items:center;gap:12px}
.gr-avatar{width:40px;height:40px;border-radius:999px;color:#fff;font-weight:700;font-size:14px;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.gr-who{flex:1;min-width:0}
.gr-name{font-size:14px;font-weight:700;letter-spacing:-.01em;color:var(--ink);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.gr-date{font-size:11.5px;color:var(--mute);margin-top:2px;font-family:var(--mono)}
.gr-g-mark{flex-shrink:0}
.gr-stars-row{display:flex;gap:2px}
.gr-s{width:15px;height:15px;fill:#e7e7e7}
.gr-s.on{fill:#fbbc05}
.gr-text{font-size:13.5px;line-height:1.55;color:var(--ink-soft);display:-webkit-box;-webkit-line-clamp:6;-webkit-box-orient:vertical;overflow:hidden}
@media(max-width:768px){.gr-card{flex:0 0 280px;padding:18px}.gr-summary{padding:18px 20px}.gr-score{font-size:24px}.gr-marquee-reverse{display:none}.gr-marquee{margin:0 -20px 16px}}
@media(prefers-reduced-motion:reduce){.gr-track{transform:none!important}}

/* service areas */
.area-grid{display:grid;grid-template-columns:.92fr 1.08fr;gap:56px;align-items:center}
.area-card{background:var(--green);border-radius:var(--r-lg);padding:42px;color:#fff;position:relative;overflow:hidden}
.area-card .ac-leaf{position:absolute;right:-30px;bottom:-30px;width:200px;height:200px;opacity:.14}
.area-card .ac-leaf svg{width:100%;height:100%}
.area-card .ac-pin{font-size:2.6rem;font-weight:800;letter-spacing:-.03em;color:#fff;line-height:1}
.area-card .ac-cap{color:rgba(255,255,255,.78);font-size:14px;margin-top:10px;position:relative}
.area-chips{display:flex;flex-wrap:wrap;gap:10px}
.area-chips a{display:inline-flex;align-items:center;gap:7px;font-size:13.5px;font-weight:600;color:var(--ink);background:#fff;border:1px solid var(--hair);padding:9px 15px;border-radius:999px;transition:background .2s,color .2s,transform .2s}
.area-chips a:hover{background:var(--green);color:#fff;transform:translateY(-2px)}
.area-chips a svg{width:13px;height:13px;stroke:var(--accent)}
.area-chips a:hover svg{stroke:#bcd591}
@media(max-width:820px){.area-grid{grid-template-columns:1fr;gap:36px}}

/* CTA band */
.cta-band{background:var(--green);border-radius:var(--r-lg);padding:58px;display:grid;grid-template-columns:1.1fr .9fr;gap:48px;align-items:center;position:relative;overflow:hidden}
.cta-band h2{color:#fff;font-size:clamp(2rem,3.8vw,3rem)}
.cta-tags{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:18px}
.cta-tags span{font-size:12px;font-weight:600;color:#fff;background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.22);padding:6px 13px;border-radius:999px}
.cta-band p{color:rgba(255,255,255,.8);margin:14px 0 26px}
.cta-figure{border-radius:var(--r);overflow:hidden;aspect-ratio:1/1;box-shadow:var(--shadow-lift);transform:rotate(2.5deg)}
.cta-figure img{width:100%;height:100%;object-fit:cover}
@media(max-width:820px){.cta-band{grid-template-columns:1fr;padding:36px}.cta-figure{display:none}}

/* ===== FOOTER ===== */
.foot{background:#16201a;color:rgba(255,255,255,.7);padding:64px 0 0}
.foot-top{display:grid;grid-template-columns:1.5fr 1fr 1fr 1.2fr;gap:44px;padding-bottom:48px;border-bottom:1px solid rgba(255,255,255,.1)}
.foot-brand img{height:54px;margin-bottom:16px}
.foot-brand p{font-size:14px;color:rgba(255,255,255,.62);max-width:300px}
.foot-col h4{font-size:13px;letter-spacing:.08em;text-transform:uppercase;color:#bcd591;margin-bottom:16px}
.foot-col a,.foot-col p{display:block;font-size:14px;color:rgba(255,255,255,.7);margin-bottom:10px;transition:color .2s}
.foot-col a:hover{color:#fff}
.foot-nap strong{color:#fff;font-weight:600}
.foot-hours{display:flex;justify-content:space-between;font-size:13.5px;margin-bottom:7px;color:rgba(255,255,255,.7)}
.foot-hours span:last-child{color:#fff;font-weight:600}
.foot-bottom{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:14px;padding:24px 0}
.foot-bottom p{font-size:12.5px;color:rgba(255,255,255,.5)}
.footer-credit{font-size:12.5px;color:rgba(255,255,255,.5)}
.footer-credit a{color:#bcd591;font-weight:600}
.foot-legal a{color:rgba(255,255,255,.5);font-size:12.5px;margin-left:16px}
.foot-legal a:hover{color:#fff}
@media(max-width:880px){.foot-top{grid-template-columns:1fr 1fr;gap:34px}}
@media(max-width:520px){.foot-top{grid-template-columns:1fr}}

/* ===== MOBILE STICKY CTA ===== */
.sticky-cta{position:fixed;left:0;right:0;bottom:0;z-index:80;display:none;grid-template-columns:1fr 1fr}
.sticky-cta a{display:flex;align-items:center;justify-content:center;gap:8px;padding:15px;font-weight:700;font-size:15px;color:#fff}
.sticky-cta .sc-call{background:var(--green)}
.sticky-cta .sc-msg{background:#0a0a0a}
.sticky-cta svg{width:17px;height:17px}
@media(max-width:980px){.sticky-cta{display:grid}body{padding-bottom:54px}}

/* page hero (interior) */
.page-hero{background:var(--green);padding:150px 0 70px;position:relative;overflow:hidden}
.page-hero .crumb{font-size:12.5px;color:rgba(255,255,255,.6);margin-bottom:16px;font-family:var(--mono)}
.page-hero .crumb a{color:#bcd591}
.page-hero h1{color:#fff;font-size:clamp(2.4rem,5vw,3.8rem);max-width:760px}
.page-hero p{color:rgba(255,255,255,.78);font-size:1.08rem;max-width:560px;margin-top:16px}
.page-hero .ph-leaf{position:absolute;right:-40px;top:40px;width:280px;opacity:.12}

/* content blocks */
.prose{max-width:720px}
.prose p{margin-bottom:16px;font-size:1.04rem}
.prose h3{margin:30px 0 12px}
.split{display:grid;grid-template-columns:1fr 1fr;gap:54px;align-items:center}
.split img{width:100%;border-radius:var(--r-lg);object-fit:cover}
@media(max-width:820px){.split{grid-template-columns:1fr;gap:34px}}

/* faq / details */
.qa{max-width:780px;margin:0 auto}
.qa details{background:#fff;border:1px solid var(--hair);border-radius:14px;margin-bottom:12px;overflow:hidden}
.qa details[open]{box-shadow:var(--shadow-soft)}
.qa summary{padding:20px 24px;font-weight:700;font-size:15.5px;cursor:pointer;list-style:none;display:flex;justify-content:space-between;gap:16px;align-items:center;color:var(--ink)}
.qa summary::-webkit-details-marker{display:none}
.qa summary::after{content:'+';font-size:22px;font-weight:400;color:var(--accent);flex-shrink:0}
.qa details[open] summary::after{content:'\2013'}
.qa details p{padding:0 24px 22px;font-size:14.8px;color:var(--ink-soft)}
.faq-group{margin-bottom:44px}
.faq-group>h3{margin-bottom:16px;font-size:1.3rem}

/* contact */
.contact-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:54px;align-items:start}
.form-card{background:#fff;border:1px solid var(--hair);border-radius:var(--r-lg);padding:34px;box-shadow:var(--shadow-soft)}
.form-card .fc-tag{font-size:12.5px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--accent);margin-bottom:18px}
.form-card label{display:block;font-size:13px;font-weight:600;color:var(--ink);margin:14px 0 6px}
.form-card input,.form-card select,.form-card textarea{width:100%;padding:13px 15px;border:1px solid var(--hair);border-radius:11px;font-family:var(--f);font-size:15px;color:var(--ink);background:#fdfdfb;transition:border-color .2s}
.form-card input:focus,.form-card select:focus,.form-card textarea:focus{outline:none;border-color:var(--green)}
.form-card textarea{min-height:110px;resize:vertical}
.form-card button{width:100%;margin-top:22px;justify-content:center}
.form-note{font-size:12.5px;color:var(--mute);text-align:center;margin-top:12px}
.form-ok{display:none;background:var(--green);color:#fff;border-radius:var(--r-lg);padding:34px;text-align:center}
.form-ok h3{color:#fff;margin-bottom:10px}
.form-ok p{color:rgba(255,255,255,.85)}
.form-ok a{color:#bcd591;font-weight:700}
.contact-aside{display:flex;flex-direction:column;gap:14px}
.ci-card{background:var(--cream);border:1px solid var(--hair);border-radius:var(--r);padding:24px;display:flex;gap:15px;align-items:flex-start}
.ci-card .ci-ic{width:44px;height:44px;border-radius:12px;background:var(--green);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.ci-card .ci-ic svg{width:21px;height:21px;stroke:#fff}
.ci-card h4{font-size:15px;margin-bottom:3px}
.ci-card p,.ci-card a{font-size:14px;color:var(--ink-soft)}
.ci-card a{font-weight:700;color:var(--green)}
.hours-card{background:var(--green);color:#fff;border-radius:var(--r);padding:24px}
.hours-card h4{color:#fff;font-size:15px;margin-bottom:14px}
.hours-card .hr{display:flex;justify-content:space-between;font-size:13.7px;padding:6px 0;border-bottom:1px solid rgba(255,255,255,.12)}
.hours-card .hr:last-child{border:0}
.hours-card .hr span:last-child{color:#bcd591;font-weight:600}
@media(max-width:820px){.contact-grid{grid-template-columns:1fr;gap:34px}}

/* misc */
.reveal{opacity:1;transform:none}
html.js .reveal{opacity:0;transform:translateY(20px);transition:opacity .7s ease,transform .7s ease}
html.js .reveal.in{opacity:1;transform:none}
@media(prefers-reduced-motion:reduce){html.js .reveal{opacity:1;transform:none;transition:none}}
.center-btn{display:flex;justify-content:center;margin-top:40px}
.err-wrap{min-height:70vh;display:flex;align-items:center;justify-content:center;text-align:center;padding:120px 24px 80px}
.err-wrap .e-code{font-size:6rem;font-weight:800;color:var(--green);letter-spacing:-.04em;line-height:1}
.err-wrap h1{margin:10px 0 12px}
.err-wrap p{color:var(--mute);margin-bottom:24px}
