/*  Silvera Landscaping v4 — Luxury Minimal  */

:root{
  --bg:#ffffff;--bg-warm:#fafaf7;--bg-sand:#f3f0ea;
  --ink:#1a1a18;--ink-light:#4a4a42;--muted:#9a9a90;--border:rgba(0,0,0,.07);
  --bronze:#BF894F;--bronze-light:#d4a76a;--sage:#6b8f5e;--sage-light:#8aad7a;
  --white:#fff;--black:#111;
  --ff-h:'Cormorant Garamond',Georgia,serif;
  --ff-b:'Jost',system-ui,sans-serif;
  --ff-s:'Libre Baskerville',Georgia,serif;
  --ease:cubic-bezier(.16,1,.3,1);
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-font-smoothing:antialiased}
body{font-family:var(--ff-b);background:var(--bg);color:var(--ink);overflow-x:hidden}
img{display:block;max-width:100%}
::selection{background:var(--bronze);color:var(--white)}

/* ── NAV ─────────────────────────────────── */
.nav{position:fixed;top:0;left:0;right:0;z-index:100;display:flex;align-items:center;justify-content:space-between;padding:24px 48px;transition:all .5s var(--ease)}
.nav.scrolled{background:rgba(255,255,255,.95);backdrop-filter:blur(20px);padding:14px 48px;box-shadow:0 1px 0 var(--border)}
.nav-logo{font-family:var(--ff-h);font-size:1.5rem;font-weight:600;color:var(--white);text-decoration:none;letter-spacing:.02em;transition:color .4s}
.nav-logo em{font-style:italic;color:var(--bronze-light)}
.nav.scrolled .nav-logo{color:var(--ink)}
.nav-mid{display:flex;gap:32px;list-style:none}
.nav-mid a{font-size:.7rem;font-weight:400;letter-spacing:.18em;text-transform:uppercase;color:rgba(255,255,255,.8);text-decoration:none;transition:color .3s}
.nav-mid a:hover{color:var(--white)}
.nav.scrolled .nav-mid a{color:var(--muted)}
.nav.scrolled .nav-mid a:hover{color:var(--ink)}
.nav-cta{font-size:.65rem;font-weight:500;letter-spacing:.12em;text-transform:uppercase;color:var(--white);text-decoration:none;border:1px solid rgba(255,255,255,.3);padding:10px 20px;transition:all .3s var(--ease)}
.nav-cta:hover{background:rgba(255,255,255,.12);border-color:rgba(255,255,255,.5)}
.nav.scrolled .nav-cta{color:var(--ink);border-color:var(--border)}
.nav.scrolled .nav-cta:hover{background:var(--bg-sand);border-color:var(--bronze)}
.ham{display:none;background:none;border:none;cursor:pointer;padding:4px;flex-direction:column;gap:5px}
.ham span{width:22px;height:1.5px;background:var(--white);display:block;transition:all .3s}
.nav.scrolled .ham span{background:var(--ink)}
.mob{display:none;position:fixed;inset:0;background:var(--white);z-index:99;flex-direction:column;align-items:center;justify-content:center;gap:28px}
.mob.open{display:flex}
.mob a{font-family:var(--ff-h);font-size:2.2rem;font-weight:300;color:var(--ink);text-decoration:none;transition:color .3s}
.mob a:hover{color:var(--bronze)}
.mob-x{position:absolute;top:20px;right:24px;font-size:1.6rem;color:var(--ink);background:none;border:none;cursor:pointer}

/* ── HERO ────────────────────────────────── */
.hero{position:relative;height:100vh;min-height:640px;display:flex;align-items:center;justify-content:center;text-align:center;overflow:hidden}
.hero-bg{position:absolute;inset:-2px;background:url('https://st.hzcdn.com/fimgs/8621e1e804b97cc6_2893-w1600-h1000-b0-p0---.jpg') center/cover no-repeat;transform:scale(1.06);animation:heroZoom 20s ease-out forwards}
@keyframes heroZoom{to{transform:scale(1)}}
.hero-bg::after{content:'';position:absolute;inset:0;background:linear-gradient(180deg,rgba(0,0,0,.15) 0%,rgba(0,0,0,.4) 100%)}
.hero-content{position:relative;z-index:2;max-width:700px;padding:0 24px}
.hero-eyebrow{font-size:.62rem;font-weight:400;letter-spacing:.35em;text-transform:uppercase;color:var(--bronze-light);margin-bottom:22px;opacity:0;animation:fadeUp .8s .3s var(--ease) forwards}
.hero h1{font-family:var(--ff-h);font-size:clamp(2.8rem,7vw,5.5rem);font-weight:300;color:var(--white);line-height:1.05;letter-spacing:-.01em;margin-bottom:22px;opacity:0;animation:fadeUp 1s .5s var(--ease) forwards}
.hero h1 em{font-style:italic}
.hero-sub{font-family:var(--ff-s);font-size:.95rem;font-style:italic;color:rgba(255,255,255,.65);line-height:1.75;margin-bottom:40px;opacity:0;animation:fadeUp .8s .8s var(--ease) forwards}
.hero-btns{display:flex;gap:14px;justify-content:center;flex-wrap:wrap;opacity:0;animation:fadeUp .8s 1s var(--ease) forwards}
@keyframes fadeUp{to{opacity:1;transform:translateY(0)}from{transform:translateY(20px)}}
.btn-primary{display:inline-block;background:var(--bronze);color:var(--white);font-size:.68rem;font-weight:500;letter-spacing:.16em;text-transform:uppercase;padding:16px 36px;text-decoration:none;transition:all .3s var(--ease)}
.btn-primary:hover{background:var(--bronze-light);transform:translateY(-2px);box-shadow:0 10px 30px rgba(191,137,79,.25)}
.btn-outline{display:inline-block;color:var(--white);font-size:.68rem;font-weight:500;letter-spacing:.16em;text-transform:uppercase;padding:15px 32px;text-decoration:none;border:1px solid rgba(255,255,255,.35);transition:all .3s var(--ease)}
.btn-outline:hover{background:rgba(255,255,255,.1);border-color:rgba(255,255,255,.6)}
.scroll-hint{position:absolute;bottom:32px;left:50%;transform:translateX(-50%);display:flex;flex-direction:column;align-items:center;gap:8px;color:rgba(255,255,255,.35);font-size:.55rem;letter-spacing:.22em;text-transform:uppercase;z-index:2}
.scroll-hint span{width:1px;height:40px;background:linear-gradient(to bottom,rgba(255,255,255,.35),transparent);animation:pulse 2.5s ease-in-out infinite}
@keyframes pulse{0%,100%{opacity:.3}50%{opacity:1}}

/* ── TRUST BAR ───────────────────────────── */
.trust-bar{display:flex;justify-content:center;gap:48px;padding:24px 48px;background:var(--bg-warm);border-bottom:1px solid var(--border);flex-wrap:wrap}
.trust-item{font-size:.68rem;font-weight:400;letter-spacing:.1em;text-transform:uppercase;color:var(--muted)}
.trust-item strong{color:var(--ink);font-weight:600}

/* ── SECTIONS ────────────────────────────── */
.section{padding:120px 48px}
.section-label{font-size:.6rem;font-weight:400;letter-spacing:.3em;text-transform:uppercase;color:var(--bronze);margin-bottom:16px}
.section-title{font-family:var(--ff-h);font-size:clamp(1.8rem,4vw,3rem);font-weight:300;color:var(--ink);line-height:1.15;margin-bottom:20px}
.section-title em{font-style:italic;color:var(--sage)}
.section-desc{font-family:var(--ff-s);font-size:.92rem;font-style:italic;line-height:1.8;color:var(--muted);max-width:520px}
.center{text-align:center;margin-left:auto;margin-right:auto}
.center .section-desc{margin-left:auto;margin-right:auto}

/* ── ABOUT ───────────────────────────────── */
.about-grid{display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:center;max-width:1200px;margin:0 auto}
.about-img{position:relative;overflow:hidden}
.about-img img{width:100%;aspect-ratio:4/5;object-fit:cover;transition:transform .8s var(--ease)}
.about-img:hover img{transform:scale(1.03)}
.about-img .badge{position:absolute;bottom:24px;right:24px;background:var(--bronze);color:var(--white);padding:20px 24px;text-align:center}
.badge-num{font-family:var(--ff-h);font-size:2.4rem;font-weight:300;line-height:1}
.badge-label{font-size:.52rem;letter-spacing:.16em;text-transform:uppercase;opacity:.8;margin-top:3px}
.about-text p{font-family:var(--ff-s);font-size:.92rem;line-height:1.9;color:var(--ink-light);margin-bottom:14px}
.about-stats{display:flex;gap:36px;margin-top:36px;padding-top:28px;border-top:1px solid var(--border)}
.stat-n{font-family:var(--ff-h);font-size:2.4rem;font-weight:300;color:var(--ink)}
.stat-l{font-size:.58rem;letter-spacing:.14em;text-transform:uppercase;color:var(--muted);margin-top:2px}

/* ── SERVICES ────────────────────────────── */
.svc-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--border);max-width:1200px;margin:48px auto 0}
.svc-card{background:var(--bg);padding:44px 32px;position:relative;transition:background .4s}
.svc-card:hover{background:var(--bg-warm)}
.svc-num{font-family:var(--ff-h);font-size:.72rem;font-weight:600;color:var(--bronze);letter-spacing:.15em;margin-bottom:16px}
.svc-card h3{font-family:var(--ff-h);font-size:1.25rem;font-weight:400;color:var(--ink);margin-bottom:10px}
.svc-card p{font-size:.8rem;line-height:1.75;color:var(--muted);margin-bottom:18px}
.svc-link{font-size:.6rem;font-weight:500;letter-spacing:.15em;text-transform:uppercase;color:var(--bronze);text-decoration:none;display:inline-flex;align-items:center;gap:6px;transition:gap .3s var(--ease)}
.svc-link:hover{gap:12px}
.svc-bar{position:absolute;bottom:0;left:0;width:0;height:2px;background:var(--bronze);transition:width .5s var(--ease)}
.svc-card:hover .svc-bar{width:100%}

/* ── PORTFOLIO ───────────────────────────── */
.port-grid{display:grid;grid-template-columns:2fr 1fr 1fr;grid-template-rows:350px 300px;gap:4px;max-width:1200px;margin:48px auto 0}
.port-item{position:relative;overflow:hidden}
.port-item:first-child{grid-row:span 2}
.port-item img{width:100%;height:100%;object-fit:cover;transition:transform .8s var(--ease)}
.port-item:hover img{transform:scale(1.05)}
.port-overlay{position:absolute;inset:0;background:linear-gradient(to top,rgba(0,0,0,.65) 0%,transparent 50%);opacity:0;transition:opacity .4s;display:flex;flex-direction:column;justify-content:flex-end;padding:24px}
.port-item:hover .port-overlay{opacity:1}
.port-name{font-family:var(--ff-h);font-size:1.15rem;font-style:italic;color:var(--white)}
.port-sub{font-size:.58rem;letter-spacing:.12em;text-transform:uppercase;color:var(--bronze-light);margin-top:4px}

/* ── PROCESS ─────────────────────────────── */
.proc-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--border);max-width:1200px;margin:48px auto 0}
.proc-step{background:var(--bg);padding:44px 28px;text-align:center}
.proc-num{font-family:var(--ff-h);font-size:2.8rem;font-weight:300;color:var(--bg-sand);margin-bottom:16px}
.proc-step h3{font-family:var(--ff-h);font-size:1.12rem;font-weight:400;color:var(--ink);margin-bottom:10px}
.proc-step p{font-size:.78rem;line-height:1.75;color:var(--muted)}

/* ── TESTIMONIALS ────────────────────────── */
.testi-section{background:var(--bg-sand)}
.testi-grid{display:grid;grid-template-columns:1fr 1fr;gap:24px;max-width:1000px;margin:48px auto 0}
.testi-card{padding:36px;border:1px solid var(--border);background:var(--bg);position:relative}
.testi-card::before{content:'\201C';position:absolute;top:10px;right:20px;font-family:var(--ff-h);font-size:4rem;color:var(--bg-sand);line-height:1}
.testi-stars{color:var(--bronze);font-size:.78rem;letter-spacing:2px;margin-bottom:14px}
.testi-quote{font-family:var(--ff-s);font-size:.88rem;font-style:italic;line-height:1.85;color:var(--ink-light);margin-bottom:20px}
.testi-author{font-size:.78rem;font-weight:500;color:var(--ink)}
.testi-loc{font-size:.62rem;color:var(--muted);margin-top:2px}

/* ── CTA BAND ────────────────────────────── */
.cta-band{padding:80px 48px;background:var(--ink);text-align:center}
.cta-band h2{font-family:var(--ff-h);font-size:clamp(1.6rem,3vw,2.6rem);font-weight:300;color:var(--white);margin-bottom:10px}
.cta-band h2 em{font-style:italic;color:var(--bronze-light)}
.cta-band p{font-size:.82rem;color:rgba(255,255,255,.35);margin-bottom:28px}

/* ── FAQ ─────────────────────────────────── */
.faq-list{max-width:700px;margin:0 auto}
.faq-item{border-bottom:1px solid var(--border)}
.faq-q{display:flex;align-items:center;justify-content:space-between;padding:22px 0;cursor:pointer;border:none;background:none;width:100%;text-align:left;font-family:var(--ff-h);font-size:1.08rem;font-weight:400;color:var(--ink);gap:16px}
.faq-q:hover{color:var(--bronze)}
.faq-q span{font-size:1rem;transition:transform .4s var(--ease);color:var(--bronze)}
.faq-item.open .faq-q span{transform:rotate(45deg)}
.faq-a{max-height:0;overflow:hidden;transition:max-height .5s var(--ease)}
.faq-a-inner{padding:0 0 22px;font-family:var(--ff-s);font-size:.84rem;line-height:1.85;color:var(--muted)}
.faq-item.open .faq-a{max-height:300px}

/* ── CONTACT ─────────────────────────────── */
.contact-grid{display:grid;grid-template-columns:1fr 1.1fr;gap:80px;max-width:1100px;margin:0 auto}
.contact-info p{font-family:var(--ff-s);font-size:.88rem;line-height:1.85;color:var(--muted);margin-bottom:24px}
.cd{display:flex;gap:12px;align-items:flex-start;margin-bottom:14px}
.cl{font-size:.56rem;letter-spacing:.16em;text-transform:uppercase;color:var(--muted)}
.cv{font-family:var(--ff-s);font-size:.86rem;color:var(--ink)}
.cv a{color:inherit;text-decoration:none}.cv a:hover{color:var(--bronze)}
.contact-form{display:flex;flex-direction:column;gap:16px}
.fr{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.fg{display:flex;flex-direction:column;gap:5px}
.flbl{font-size:.56rem;letter-spacing:.15em;text-transform:uppercase;color:var(--muted)}
.contact-form input,.contact-form select,.contact-form textarea{font-family:var(--ff-b);font-size:.84rem;color:var(--ink);background:var(--bg-warm);border:1px solid var(--border);padding:13px 16px;outline:none;width:100%;transition:all .3s var(--ease)}
.contact-form input:focus,.contact-form select:focus,.contact-form textarea:focus{border-color:var(--bronze);background:var(--bg)}
.contact-form textarea{resize:vertical;min-height:100px}
.contact-form select{appearance:none}
.fsub{align-self:flex-start;background:var(--bronze);color:var(--white);font-size:.66rem;font-weight:500;letter-spacing:.14em;text-transform:uppercase;padding:16px 40px;border:none;cursor:pointer;transition:all .3s var(--ease)}
.fsub:hover{background:var(--bronze-light);transform:translateY(-1px)}
.form-note{font-size:.66rem;color:var(--muted)}
.fsuc{display:none;padding:14px 18px;background:rgba(107,143,94,.08);border:1px solid rgba(107,143,94,.2);font-size:.84rem;color:var(--sage)}

/* ── MAP STRIP ───────────────────────────── */
.map-strip{display:flex;justify-content:space-between;align-items:center;padding:28px 48px;background:var(--bg-sand);border-top:1px solid var(--border);flex-wrap:wrap;gap:16px}
.map-strip strong{font-size:.84rem;color:var(--ink)}
.map-strip p{font-size:.7rem;color:var(--muted)}
.area-tags{display:flex;gap:8px;flex-wrap:wrap}
.area-tag{font-size:.56rem;letter-spacing:.1em;text-transform:uppercase;padding:6px 14px;border:1px solid var(--border);color:var(--muted)}

/* ── FOOTER ──────────────────────────────── */
.site-footer{background:var(--ink);padding:64px 48px 36px;color:rgba(255,255,255,.3)}
.fg2{display:grid;grid-template-columns:1.5fr 1fr 1fr 1fr;gap:48px;padding-bottom:40px;border-bottom:1px solid rgba(255,255,255,.06);margin-bottom:28px}
.fl{font-family:var(--ff-h);font-size:1.5rem;font-weight:600;color:var(--white);text-decoration:none;display:block;margin-bottom:12px}
.fl em{font-style:italic;color:var(--bronze-light)}
.fb>p{font-size:.76rem;line-height:1.75;margin-bottom:16px}
.fph{font-size:.84rem;color:var(--white);text-decoration:none;display:block;margin-bottom:4px}.fph:hover{color:var(--bronze-light)}
.fadr{font-size:.72rem;color:rgba(255,255,255,.2)}
.fc2 h4{font-size:.56rem;font-weight:500;letter-spacing:.2em;text-transform:uppercase;color:rgba(255,255,255,.45);margin-bottom:16px}
.fc2 ul{list-style:none;display:flex;flex-direction:column;gap:8px}
.fc2 ul a{font-size:.76rem;color:rgba(255,255,255,.28);text-decoration:none;transition:color .3s}
.fc2 ul a:hover{color:var(--white)}
.fbot{display:flex;justify-content:space-between;flex-wrap:wrap;gap:12px;font-size:.62rem}
.fbot p,.fbot a{color:rgba(255,255,255,.15)}
.fbot a{text-decoration:none}.fbot a:hover{color:var(--bronze-light)}

/* ── BACK TO TOP ─────────────────────────── */
.back-top{position:fixed;bottom:24px;right:24px;width:40px;height:40px;border:1px solid var(--border);background:var(--bg);color:var(--ink);display:flex;align-items:center;justify-content:center;cursor:pointer;z-index:90;opacity:0;transform:translateY(10px);transition:all .3s var(--ease);pointer-events:none;font-size:.9rem}
.back-top.show{opacity:1;transform:translateY(0);pointer-events:auto}
.back-top:hover{background:var(--bronze);color:var(--white);border-color:var(--bronze)}

/* ── SCROLL PROGRESS ─────────────────────── */
.scroll-progress{position:fixed;top:0;left:0;height:2px;background:var(--bronze);z-index:200;width:0}

/* ── REVEAL ──────────────────────────────── */
.rv{opacity:0;transform:translateY(24px);transition:opacity .8s var(--ease),transform .8s var(--ease)}
.rv.in{opacity:1;transform:translateY(0)}

/* ── SUB-PAGES ───────────────────────────── */
.page-hero{min-height:340px;display:flex;align-items:flex-end;position:relative;overflow:hidden}
.page-hero-bg{position:absolute;inset:0;background-size:cover;background-position:center}
.page-hero-bg::after{content:'';position:absolute;inset:0;background:linear-gradient(180deg,rgba(0,0,0,.1) 0%,rgba(0,0,0,.45) 100%)}
.page-hero-content{position:relative;z-index:2;padding:0 48px 48px;max-width:700px}
.page-hero-content .section-label{color:var(--bronze-light)}
.page-hero-content .section-title{color:var(--white);margin-bottom:10px}
.page-hero-content .section-title em{color:var(--bronze-light)}
.page-hero-content p{color:rgba(255,255,255,.6);font-family:var(--ff-s);font-size:.9rem;font-style:italic}
.service-content{max-width:720px;margin:0 auto}
.service-content h3{font-family:var(--ff-h);font-size:1.25rem;font-weight:400;color:var(--ink);margin:30px 0 12px}
.service-content p{font-family:var(--ff-s);font-size:.9rem;line-height:1.88;color:var(--ink-light);margin-bottom:12px}
.service-content ul{list-style:none;margin:14px 0 22px}
.service-content li{padding:9px 0 9px 20px;font-size:.84rem;line-height:1.7;color:var(--ink-light);border-bottom:1px solid var(--border);position:relative}
.service-content li::before{content:'';position:absolute;left:0;top:17px;width:5px;height:5px;border-radius:50%;background:var(--bronze)}
.service-content li strong{color:var(--ink)}
.legal-content h3{font-family:var(--ff-h);font-size:1.2rem;font-weight:400;color:var(--ink);margin:26px 0 10px}
.legal-content p{font-size:.84rem;line-height:1.85;color:var(--ink-light);margin-bottom:10px}
.legal-content ul{margin:10px 0 16px 18px}
.legal-content li{font-size:.82rem;line-height:1.75;color:var(--ink-light);margin-bottom:4px}
.legal-content a{color:var(--bronze)}.legal-content a:hover{color:var(--bronze-light)}
.breadcrumb{padding:14px 48px;background:var(--bg-warm);font-size:.58rem;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);border-bottom:1px solid var(--border)}
.breadcrumb a{color:var(--muted);text-decoration:none}.breadcrumb a:hover{color:var(--bronze)}
.page-404{min-height:70vh;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:80px 24px}
.page-404 h1{font-family:var(--ff-h);font-size:clamp(5rem,14vw,10rem);font-weight:300;color:var(--bg-sand);line-height:1}
.page-404 h2{font-family:var(--ff-h);font-size:1.6rem;font-weight:300;margin-bottom:12px}
.page-404 p{font-size:.84rem;color:var(--muted);margin-bottom:28px}
.page-404 a{background:var(--bronze);color:var(--white);font-size:.66rem;letter-spacing:.14em;text-transform:uppercase;padding:14px 28px;text-decoration:none}

/* ── RESPONSIVE ──────────────────────────── */
@media(max-width:1080px){
  .nav{padding:18px 24px}.nav.scrolled{padding:12px 24px}
  .nav-mid{display:none}.ham{display:flex}
  .section{padding:80px 24px}
  .about-grid,.contact-grid{grid-template-columns:1fr;gap:48px}
  .svc-grid,.proc-grid{grid-template-columns:1fr 1fr}
  .port-grid{grid-template-columns:1fr 1fr;grid-template-rows:auto}
  .port-item:first-child{grid-row:auto;grid-column:span 2}
  .testi-grid{grid-template-columns:1fr}
  .fg2{grid-template-columns:1fr 1fr}
  .map-strip,.trust-bar{padding:18px 24px}
  .page-hero-content,.breadcrumb{padding-left:24px;padding-right:24px}
}
@media(max-width:640px){
  .svc-grid,.proc-grid{grid-template-columns:1fr}
  .port-grid{grid-template-columns:1fr}.port-item:first-child{grid-column:auto}
  .fg2{grid-template-columns:1fr}.fr{grid-template-columns:1fr}
  .trust-bar{flex-direction:column;gap:10px;text-align:center}
  .hero h1{font-size:clamp(2.2rem,9vw,3.5rem)}
  .about-stats{flex-direction:column;gap:20px}
  .cta-band{padding:60px 24px}
}

/* ── ESTIMATE BUILDER ────────────────────────── */
.est-cats{display:flex;gap:8px;flex-wrap:wrap;justify-content:center;margin-bottom:40px}
.est-cat{font-size:.65rem;letter-spacing:.12em;text-transform:uppercase;padding:9px 20px;border:1px solid var(--border);background:var(--bg);color:var(--muted);cursor:pointer;transition:all .3s var(--ease)}
.est-cat.active,.est-cat:hover{background:var(--bronze);color:var(--white);border-color:var(--bronze)}
.est-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;max-width:1100px;margin:0 auto}
.est-card{border:1px solid var(--border);background:var(--bg);overflow:hidden;transition:all .3s var(--ease);position:relative}
.est-card:hover{box-shadow:0 8px 30px rgba(0,0,0,.06);transform:translateY(-2px)}
.est-card.added{border-color:var(--bronze)}
.est-card.added::after{content:'Added';position:absolute;top:12px;right:12px;background:var(--bronze);color:var(--white);font-size:.55rem;letter-spacing:.1em;text-transform:uppercase;padding:4px 10px;z-index:2}
.est-card img{width:100%;aspect-ratio:4/3;object-fit:cover}
.est-card-body{padding:20px}
.est-card h3{font-family:var(--ff-h);font-size:1.1rem;font-weight:400;color:var(--ink);margin-bottom:6px}
.est-card p{font-size:.78rem;line-height:1.65;color:var(--muted);margin-bottom:14px}
.est-add{width:100%;padding:10px;border:1px solid var(--border);background:var(--bg);font-size:.62rem;letter-spacing:.14em;text-transform:uppercase;color:var(--bronze);cursor:pointer;transition:all .3s var(--ease);font-family:var(--ff-b)}
.est-add:hover{background:var(--bronze);color:var(--white);border-color:var(--bronze)}
.est-card.added .est-add{background:var(--bg-sand);color:var(--muted);border-color:var(--border)}
/* Floating Cart */
.est-cart{position:fixed;bottom:0;left:0;right:0;background:rgba(26,26,24,.95);backdrop-filter:blur(16px);color:var(--white);z-index:80;transform:translateY(100%);transition:transform .4s var(--ease);border-top:1px solid rgba(191,137,79,.2)}
.est-cart.show{transform:translateY(0)}
.est-cart-bar{display:flex;align-items:center;justify-content:space-between;padding:14px 48px;gap:20px}
.est-cart-count{font-size:.85rem;font-weight:500}
.est-cart-count strong{color:var(--bronze-light)}
.est-cart-items{display:flex;gap:8px;flex:1;overflow-x:auto;padding:0 12px}
.est-cart-chip{font-size:.65rem;padding:5px 12px;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.1);white-space:nowrap;display:flex;align-items:center;gap:6px}
.est-cart-chip button{background:none;border:none;color:rgba(255,255,255,.4);cursor:pointer;font-size:.8rem;padding:0}
.est-cart-submit{background:var(--bronze);color:var(--white);border:none;font-size:.65rem;letter-spacing:.14em;text-transform:uppercase;padding:12px 28px;cursor:pointer;font-family:var(--ff-b);transition:all .3s var(--ease);white-space:nowrap}
.est-cart-submit:hover{background:var(--bronze-light)}
/* Estimate Form Modal */
.est-modal{display:none;position:fixed;inset:0;z-index:90;background:rgba(0,0,0,.5);backdrop-filter:blur(4px);align-items:center;justify-content:center;padding:24px}
.est-modal.open{display:flex}
.est-modal-box{background:var(--bg);max-width:540px;width:100%;max-height:90vh;overflow-y:auto;padding:40px}
.est-modal-box h2{font-family:var(--ff-h);font-size:1.6rem;font-weight:300;margin-bottom:8px}
.est-modal-box .section-label{margin-bottom:16px}
.est-modal-list{margin:16px 0 24px;padding:16px;background:var(--bg-warm);border:1px solid var(--border);max-height:200px;overflow-y:auto}
.est-modal-list li{font-size:.82rem;padding:6px 0;border-bottom:1px solid var(--border);color:var(--ink-light);list-style:none}
.est-modal-close{position:absolute;top:16px;right:16px;background:none;border:none;font-size:1.4rem;color:var(--muted);cursor:pointer}
@media(max-width:1080px){.est-grid{grid-template-columns:1fr 1fr}}
@media(max-width:640px){.est-grid{grid-template-columns:1fr}.est-cart-bar{padding:12px 16px;flex-direction:column;gap:10px}.est-cart-items{display:none}}

/* ── BEFORE/AFTER SLIDER ─────────────────────── */
.ba-container{position:relative;max-width:900px;margin:0 auto;overflow:hidden;aspect-ratio:16/9;cursor:ew-resize;user-select:none}
.ba-container img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.ba-after{clip-path:inset(0 50% 0 0)}
.ba-handle{position:absolute;top:0;bottom:0;left:50%;width:3px;background:var(--bronze);z-index:3;transform:translateX(-50%)}
.ba-handle::after{content:'';position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:36px;height:36px;border-radius:50%;background:var(--bronze);border:2px solid var(--white);box-shadow:0 2px 8px rgba(0,0,0,.2)}
.ba-label{position:absolute;bottom:12px;font-size:.58rem;letter-spacing:.14em;text-transform:uppercase;color:var(--white);background:rgba(0,0,0,.5);padding:5px 12px;z-index:4}
.ba-label.before{left:12px}.ba-label.after{right:12px}

/* ── NOISE OVERLAY ───────────────────────────── */
.noise{position:fixed;inset:0;z-index:9000;pointer-events:none;opacity:.02;
  background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
  background-repeat:repeat;background-size:256px 256px}

/* ── ANIMATED GRADIENT DIVIDER ───────────────── */
.gradient-divider{height:2px;background:linear-gradient(90deg,transparent,var(--bronze),transparent);opacity:.2}

/* ── LEAF CURSOR ──────────────────────────────── */
.leaf-cursor{position:fixed;width:24px;height:24px;pointer-events:none;z-index:9999;transform:translate(-50%,-50%) rotate(-30deg);transition:transform .15s ease;opacity:.85}
.leaf-cursor svg{width:100%;height:100%}
.leaf-cursor.click{transform:translate(-50%,-50%) rotate(-30deg) scale(.8)}
body{cursor:none}
a,button,input,select,textarea,.svc-card,.port-item,.faq-q{cursor:none}
@media(max-width:640px){body,a,button,input,select,textarea{cursor:auto}.leaf-cursor{display:none}}
