/* Cormorant Garamond — self-hosted */
@font-face {
  font-family: 'Cormorant Garamond';
  font-style: normal;
  font-weight: 400 600;
  font-display: swap;
  src: url('/fonts/cormorant-garamond.woff2') format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
@font-face {
  font-family: 'Cormorant Garamond';
  font-style: italic;
  font-weight: 400 500;
  font-display: swap;
  src: url('/fonts/cormorant-garamond-italic.woff2') format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
/* DM Sans — self-hosted */
@font-face {
  font-family: 'DM Sans';
  font-style: normal;
  font-weight: 300 500;
  font-display: swap;
  src: url('/fonts/dm-sans.woff2') format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}

:root{
  --gd:#1b3826;--gm:#2a5c3f;--gl:#eaf2ec;
  --cr:#f8f4ee;--sd:#ede8de;
  --td:#1a1c18;--tm:#525850;--tl:#8a8c80;
  --brd:rgba(26,28,24,0.1);--wh:#ffffff;
  --max:1060px;--px:32px;
}
*{box-sizing:border-box;margin:0;padding:0}
body{font-family:'DM Sans',-apple-system,system-ui,sans-serif;background:var(--cr);color:var(--td);font-size:15px;line-height:1.6}

/* SKIP LINK — WCAG 2.4.1 Bypass Blocks. Hidden until keyboard focus. */
.skip-link{position:absolute;left:-9999px;top:auto;width:1px;height:1px;overflow:hidden;z-index:10000}
.skip-link:focus{position:fixed;left:12px;top:12px;width:auto;height:auto;padding:10px 16px;background:var(--gd);color:#fff;text-decoration:none;border-radius:6px;font-weight:500;font-size:14px;outline:2px solid #fff;outline-offset:2px}
main:focus{outline:none}

/* NAV */
nav{background:var(--cr);border-bottom:1px solid var(--brd);padding:0 var(--px);height:60px;display:flex;align-items:center;justify-content:space-between;position:sticky;top:0;z-index:200}
.nav-inner{width:100%;max-width:calc(var(--max) + var(--px)*2);margin:0 auto;display:flex;align-items:center;justify-content:space-between}
.logo{font-family:'Cormorant Garamond',Georgia,serif;font-size:20px;font-weight:600;letter-spacing:-.02em;color:var(--gd);text-decoration:none}
.logo em{font-style:italic;font-weight:400}
.nav-links{display:flex;align-items:center;gap:4px;list-style:none}
.nav-links>li>a{font-size:13px;color:var(--tm);text-decoration:none;transition:color .15s;display:flex;align-items:center;gap:4px;padding:8px 12px;border-radius:5px}
.nav-links>li>a:hover,.nav-links>li.active>a{color:var(--td);background:rgba(26,28,24,.05)}
.nav-links>li.has-dropdown>a::after{content:'';display:inline-block;width:6px;height:6px;border-right:1.5px solid currentColor;border-bottom:1.5px solid currentColor;transform:rotate(45deg) translateY(-2px);transition:transform .2s;opacity:.5}
.nav-links>li.has-dropdown:hover>a::after{transform:rotate(225deg) translateY(-2px);opacity:.8}
.nav-cta{background:var(--gd) !important;color:#fff !important;padding:8px 18px !important;border-radius:4px;font-weight:500 !important}
.nav-cta:hover{background:var(--gm) !important}
.nav-cta::after{display:none !important}
.has-dropdown{position:relative}
.has-dropdown::after{content:'';position:absolute;top:100%;left:0;right:0;height:8px}
.dropdown{position:absolute;top:calc(100% + 4px);left:50%;transform:translateX(-50%) translateY(6px);background:var(--wh);border:.5px solid rgba(26,28,24,.12);border-radius:10px;padding:6px;min-width:210px;opacity:0;pointer-events:none;transition:opacity .18s,transform .18s;box-shadow:0 8px 32px rgba(26,28,24,.1),0 2px 8px rgba(26,28,24,.06)}
.has-dropdown:hover .dropdown{opacity:1;pointer-events:all;transform:translateX(-50%) translateY(0)}
.dropdown::before{content:'';display:block;height:2px;background:var(--gd);margin:-6px -6px 6px;border-radius:10px 10px 0 0;opacity:.7}
.dropdown-label{font-size:9px;letter-spacing:.1em;text-transform:uppercase;color:var(--tl);padding:8px 10px 4px;font-weight:500}
.dropdown a{display:block;padding:8px 10px;font-size:13px;color:var(--tm);text-decoration:none;border-radius:6px;transition:background .12s,color .12s;line-height:1.3}
.dropdown a:hover{background:var(--gl);color:var(--gd);font-weight:500}
.dropdown hr{border:none;border-top:.5px solid var(--brd);margin:4px 0}
.dropdown .view-all{color:var(--gm);font-weight:500;display:flex;align-items:center;justify-content:space-between}
.dropdown .view-all::after{content:'→';font-size:12px}
.dropdown-wide{min-width:230px}
.hamburger{display:none;flex-direction:column;gap:5px;cursor:pointer;padding:8px;border:none;background:none;border-radius:4px}
.hamburger span{display:block;width:22px;height:1.5px;background:var(--td);transition:transform .25s,opacity .25s}
.hamburger.open span:nth-child(1){transform:translateY(6.5px) rotate(45deg)}
.hamburger.open span:nth-child(2){opacity:0}
.hamburger.open span:nth-child(3){transform:translateY(-6.5px) rotate(-45deg)}
.mobile-nav{display:none;position:fixed;inset:60px 0 0 0;background:var(--cr);z-index:199;overflow-y:auto;border-top:1px solid var(--brd);padding:12px 0 40px}
.mobile-nav.open{display:block}
.mobile-nav a{display:block;padding:12px 24px;font-size:15px;color:var(--td);text-decoration:none;border-bottom:.5px solid var(--brd);transition:background .12s}
.mobile-nav a:hover{background:var(--gl)}
.mobile-nav .mob-section{font-size:10px;letter-spacing:.1em;text-transform:uppercase;color:var(--tl);padding:16px 24px 6px;font-weight:500}
.mobile-nav .mob-sub{padding-left:36px;font-size:14px;color:var(--tm)}
.mobile-nav .mob-cta{background:var(--gd);color:#fff !important;margin:16px 24px 0;border-radius:6px;text-align:center;border-bottom:none}
.mobile-nav .mob-cta:hover{background:var(--gm) !important}

/* TRUST BAR */
.trust-bar{background:var(--sd);border-bottom:1px solid var(--brd);padding:12px var(--px)}
.trust-bar-inner{max-width:var(--max);margin:0 auto;display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap}
.trust-item{font-size:11px;color:var(--tm);letter-spacing:.04em;padding:4px 16px;border-right:1px solid var(--brd);white-space:nowrap}
.trust-item:last-child{border-right:none}
.trust-item strong{color:var(--td);font-weight:500}

/* SPECIALS STRIP */
.specials-strip{background:#162e1f;border-bottom:1px solid rgba(255,255,255,.06)}
.specials-inner{max-width:var(--max);margin:0 auto;padding:0 var(--px);display:flex;align-items:stretch}
.spec-label{padding:16px 22px 16px 0;display:flex;align-items:center;gap:8px;flex-shrink:0;border-right:1px solid rgba(255,255,255,.07);margin-right:22px}
.spec-live-dot{width:6px;height:6px;border-radius:50%;background:#5dca99;animation:pulse 2s ease-in-out infinite}
.spec-label span{font-size:10px;letter-spacing:.1em;text-transform:uppercase;color:rgba(255,255,255,.35);font-weight:500;white-space:nowrap}
.spec-items{display:flex;align-items:center;flex:1;min-width:0}
.spec-item{padding:16px 20px;border-right:1px solid rgba(255,255,255,.06);flex:1;min-width:0}
.spec-item:last-child{border-right:none}
.spec-name{font-size:13px;color:rgba(255,255,255,.85);font-weight:500}
.spec-meta{font-size:11px;color:rgba(255,255,255,.38);margin-top:2px}
.spec-badge{display:inline-block;font-size:10px;padding:1px 6px;border-radius:3px;font-weight:500;margin-left:6px}
.badge-rdy{background:rgba(93,202,153,.18);color:#5dca99}
.badge-spl{background:rgba(200,140,60,.2);color:#dea050}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.35}}

/* LAYOUT */
.section{padding:72px var(--px)}
.section-inner{max-width:var(--max);margin:0 auto}
.eyebrow{font-size:10px;letter-spacing:.13em;text-transform:uppercase;color:var(--tl);margin-bottom:10px;font-weight:500}
.sec-title{font-family:'Cormorant Garamond',Georgia,serif;font-size:38px;font-weight:500;line-height:1.15;letter-spacing:-.02em;color:var(--td)}
.sec-sub{font-size:15px;color:var(--tm);margin-top:12px;max-width:500px;line-height:1.7;font-weight:300}
.dark-section{background:var(--gd);padding:72px var(--px)}
.dark-section .eyebrow{color:rgba(255,255,255,.3)}
.dark-section .sec-title{color:#f6f2ea}
.dark-section .sec-sub{color:rgba(255,255,255,.5)}
.sand-section{background:var(--sd);border-top:1px solid var(--brd);border-bottom:1px solid var(--brd);padding:72px var(--px)}

/* HERO */
.hero{background:var(--gd);padding:72px var(--px) 64px}
.hero-inner{max-width:var(--max);margin:0 auto;display:grid;grid-template-columns:1.1fr 1fr;gap:56px;align-items:center}
.hero-eyebrow{font-size:10px;letter-spacing:.14em;text-transform:uppercase;color:rgba(255,255,255,.4);margin-bottom:18px;font-weight:500}
.hero h1{font-family:'Cormorant Garamond',Georgia,serif;font-size:58px;font-weight:500;line-height:1.05;color:#f6f2ea;letter-spacing:-.025em}
.hero h1 em{font-style:italic;color:rgba(246,242,234,.6)}
.hero-sub{margin-top:22px;font-size:15px;line-height:1.7;color:rgba(255,255,255,.58);max-width:440px;font-weight:300}
.hero-ctas{display:flex;gap:10px;margin-top:32px;flex-wrap:wrap}
.btn-cream{background:#f6f2ea;color:var(--gd);padding:12px 24px;border-radius:4px;font-size:13px;font-weight:500;text-decoration:none;transition:background .15s;white-space:nowrap}
.btn-cream:hover{background:#fff}
.btn-ghost{border:1px solid rgba(255,255,255,.2);color:rgba(255,255,255,.75);padding:12px 24px;border-radius:4px;font-size:13px;text-decoration:none;transition:border-color .15s,color .15s;white-space:nowrap}
.btn-ghost:hover{border-color:rgba(255,255,255,.4);color:#fff}
.btn-green{background:var(--gd);color:#fff;padding:12px 24px;border-radius:4px;font-size:13px;font-weight:500;text-decoration:none;display:inline-block;transition:background .15s}
.btn-green:hover{background:var(--gm)}
.btn-green-full{display:block;background:var(--gd);color:#fff;padding:13px 24px;border-radius:4px;font-size:13px;font-weight:500;text-decoration:none;transition:background .15s;text-align:center}
.btn-green-full:hover{background:var(--gm)}
.btn-outline{border:1px solid var(--brd);color:var(--td);padding:11px 22px;border-radius:4px;font-size:13px;text-decoration:none;display:inline-block;transition:border-color .15s,color .15s}
.btn-outline:hover{border-color:var(--gm);color:var(--gd)}
.hero-right{display:flex;flex-direction:column;gap:10px}
.stat-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.hstat{background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.09);border-radius:7px;padding:18px 20px}
.hstat-n{font-family:'Cormorant Garamond',Georgia,serif;font-size:38px;font-weight:500;color:#f6f2ea;line-height:1;letter-spacing:-.02em}
.hstat-l{font-size:11px;color:rgba(255,255,255,.42);margin-top:5px;line-height:1.4}
.accred-bar{display:flex;align-items:center;gap:10px;padding:13px 18px;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.09);border-radius:7px}
.accred-dot{width:7px;height:7px;border-radius:50%;background:#5dca99;flex-shrink:0;animation:pulse 2.5s ease-in-out infinite}
.accred-text{font-size:12px;color:rgba(255,255,255,.5);line-height:1.4}
.accred-text strong{color:rgba(255,255,255,.75);font-weight:500}

/* PAGE HERO (non-homepage) */
.page-hero{background:var(--gd);padding:56px var(--px) 52px}
.page-hero-inner{max-width:var(--max);margin:0 auto}
.page-hero .eyebrow{color:rgba(255,255,255,.35)}
.page-hero h1{font-family:'Cormorant Garamond',Georgia,serif;font-size:48px;font-weight:500;line-height:1.1;color:#f6f2ea;letter-spacing:-.025em;margin-top:8px}
.page-hero h1 em{font-style:italic;color:rgba(246,242,234,.65)}
.page-hero p{margin-top:14px;font-size:15px;color:rgba(255,255,255,.52);max-width:560px;line-height:1.75;font-weight:300}

/* BREADCRUMB */
.breadcrumb{padding:14px var(--px);background:var(--sd);border-bottom:1px solid var(--brd)}
.breadcrumb-inner{max-width:var(--max);margin:0 auto;display:flex;align-items:center;gap:8px;font-size:12px;color:var(--tl)}
.breadcrumb a{color:var(--tm);text-decoration:none;transition:color .15s}
.breadcrumb a:hover{color:var(--gd)}
.breadcrumb .sep{opacity:.4}
.breadcrumb .current{color:var(--td)}

/* CATEGORY CARDS */
.cat-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin-top:36px}
.cat-card{background:var(--wh);border:1px solid var(--brd);border-radius:8px;padding:26px;cursor:pointer;transition:border-color .2s,transform .2s;text-decoration:none;display:block}
.cat-card:hover{border-color:rgba(42,92,63,.4);transform:translateY(-2px)}
.cat-n{font-size:11px;color:var(--tl);margin-bottom:12px}
.cat-name{font-size:16px;font-weight:500;color:var(--td);margin-bottom:7px;line-height:1.25}
.cat-name span{float:right;color:var(--tl);font-size:14px;transition:transform .2s,color .2s}
.cat-card:hover .cat-name span{transform:translateX(3px);color:var(--gm)}
.cat-desc{font-size:13px;color:var(--tm);line-height:1.55;font-weight:300}
.cat-examples{margin-top:14px;padding-top:14px;border-top:1px solid var(--brd);font-size:11px;color:var(--tl);line-height:1.5}

/* HOMEPAGE SPEC-SECTION (available now / dark cards) */
.spec-section{background:var(--gd);padding:72px var(--px)}
.spec-section .eyebrow{color:rgba(255,255,255,.3)}
.spec-section .sec-title{color:#f6f2ea}
.spec-section .sec-sub{color:rgba(255,255,255,.5)}
.species-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin-top:36px}
.sp-img{height:120px;background:rgba(255,255,255,.04);display:flex;align-items:center;justify-content:center;border-bottom:1px solid rgba(255,255,255,.07)}
.sp-img-label{font-family:'Cormorant Garamond',Georgia,serif;font-size:13px;color:rgba(255,255,255,.2);font-style:italic;text-align:center;padding:0 20px;line-height:1.4}
.sp-body{padding:18px 20px}
.sp-bot{font-size:11px;color:rgba(255,255,255,.35);font-style:italic;margin-bottom:3px}
.sp-com{font-size:15px;font-weight:500;color:rgba(255,255,255,.88);margin-bottom:7px}
.sp-desc{font-size:12px;color:rgba(255,255,255,.45);line-height:1.55;font-weight:300}
.spec-section .sp-tags{display:flex;flex-wrap:wrap;gap:6px;margin-top:10px}
.spec-section .sp-tag{font-size:10px;padding:2px 8px;border-radius:3px;border:1px solid rgba(255,255,255,.12);color:rgba(255,255,255,.4)}
.spec-section .sp-tag.avail{background:rgba(93,202,153,.15);border-color:rgba(93,202,153,.25);color:#5dca99;font-weight:500}
.spec-section .sp-tag.spl{background:rgba(200,140,60,.15);border-color:rgba(200,140,60,.25);color:#dea050}

/* SPECIES CARDS (catalogue) */
.filter-bar{display:flex;align-items:center;gap:8px;flex-wrap:wrap;margin-top:32px;padding-bottom:24px;border-bottom:1px solid var(--brd)}
.filter-btn{padding:7px 14px;border-radius:20px;border:1px solid var(--brd);background:transparent;font-size:12px;color:var(--tm);cursor:pointer;transition:all .15s;font-family:inherit}
.filter-btn:hover,.filter-btn.active{background:var(--gd);color:#fff;border-color:var(--gd)}
.sp-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:10px;margin-top:24px}
/* sp-card: dark by default (matches homepage spec-section context) */
.sp-card{background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.09);border-radius:8px;overflow:hidden;cursor:pointer;transition:background .2s;text-decoration:none;display:block;padding:0}
.sp-card:hover{background:rgba(255,255,255,.1)}
/* Catalogue/category context — light override scoped to .sp-grid parent */
.sp-grid .sp-card{background:var(--wh);border:1px solid var(--brd);padding:20px;transition:border-color .2s,transform .2s;overflow:visible}
.sp-grid .sp-card:hover{border-color:rgba(42,92,63,.4);transform:translateY(-2px);background:var(--wh)}
.sp-cat-tag{font-size:10px;color:var(--tl);letter-spacing:.06em;text-transform:uppercase;margin-bottom:10px;display:flex;align-items:center;gap:6px}
.avail-dot{width:5px;height:5px;border-radius:50%;background:var(--tl)}
.avail-dot.on{background:#5dca99}
.sp-bot-name{font-size:13px;font-weight:500;color:var(--td);line-height:1.3;margin-bottom:3px;font-style:italic}
.sp-common{font-size:12px;color:var(--tm);margin-bottom:10px;font-weight:300}
.sp-sizes{font-size:11px;color:var(--tl);border-top:1px solid var(--brd);padding-top:10px;margin-top:10px}
.sp-price{font-size:11px;color:var(--gm);font-weight:500;margin-top:3px}

/* SPECIES DETAIL PAGE */
.species-layout{max-width:var(--max);margin:0 auto;padding:56px var(--px);display:grid;grid-template-columns:1.4fr 1fr;gap:56px;align-items:start}
.sp-plant-img{aspect-ratio:1/1;background:var(--gd);border-radius:12px;overflow:hidden;margin-bottom:24px;width:100%;display:block;position:relative}.sp-plant-img picture{position:absolute;inset:0;width:100%;height:100%}.sp-plant-img img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:center;display:block}
.sp-plant-img-text{font-family:'Cormorant Garamond',Georgia,serif;font-size:18px;font-style:italic;color:rgba(255,255,255,.2);text-align:center;padding:24px;line-height:1.5}
.article-body a,.sp-desc-text a,.editorial-body a,.pillar-body a,.coastal-right a,.why-body a,.page-hero a,.section a:not(.btn-green):not(.btn-outline):not(.btn-cream):not(.btn-ghost),.section-inner a:not([class]){color:#4a8c66;text-decoration:underline;text-decoration-color:rgba(74,140,102,.3);text-underline-offset:2px}
.article-body a:hover,.sp-desc-text a:hover,.editorial-body a:hover,.pillar-body a:hover,.coastal-right a:hover,.why-body a:hover{color:#2a5c3f;text-decoration-color:rgba(42,92,63,.5)}
.sp-detail-name{font-family:'Cormorant Garamond',Georgia,serif;font-size:44px;font-weight:500;line-height:1.1;color:var(--td);letter-spacing:-.02em;margin-bottom:6px}
.sp-detail-common{font-size:18px;color:var(--tm);font-weight:300;margin-bottom:20px}
.sp-avail-badge{display:inline-flex;align-items:center;gap:6px;padding:5px 12px;border-radius:4px;font-size:11px;font-weight:500;margin-bottom:24px}
.sp-avail-badge.on{background:rgba(93,202,153,.15);color:#2a7a52;border:1px solid rgba(93,202,153,.3)}
.sp-avail-badge.off{background:var(--sd);color:var(--tl);border:1px solid var(--brd)}
.sp-avail-badge .dot{width:6px;height:6px;border-radius:50%}
.sp-avail-badge.on .dot{background:#5dca99}
.sp-avail-badge.off .dot{background:var(--tl)}
.sp-desc-text{font-size:15px;color:var(--tm);line-height:1.8;font-weight:300;margin-bottom:24px}
.sp-spec-notes{font-family:inherit}
.sp-spec-notes .eyebrow{color:var(--gd);font-size:12px;letter-spacing:.08em;text-transform:uppercase;font-weight:500}
.sp-spec-para{font-family:inherit;font-size:15px;color:var(--tm);line-height:1.8;font-weight:300;margin:0 0 22px 0}
.sp-spec-para:last-child{margin-bottom:0}
.sp-spec-para strong{color:var(--td);font-weight:500}
/* ── Tools bento (used on homepage and /tools/) ── */
.home-tools-section{background:var(--cr);border-top:1px solid var(--brd);border-bottom:1px solid var(--brd)}
.tools-bento{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-top:32px}
.tools-bento .tool-card.wide{grid-column:span 2}
.tool-card{position:relative;background:var(--wh);border:1px solid var(--brd);border-radius:14px;padding:40px 36px;text-decoration:none;color:inherit;transition:border-color .2s,transform .2s;overflow:hidden;display:flex;flex-direction:column;min-height:320px}
.tool-card:hover{border-color:rgba(42,92,63,.4);transform:translateY(-3px)}
.tool-card-eyebrow{font-size:10px;letter-spacing:.13em;text-transform:uppercase;color:var(--tl);font-weight:500;margin-bottom:14px}
.tool-card h2{font-family:'Cormorant Garamond',Georgia,serif;font-size:36px;font-weight:500;color:var(--td);letter-spacing:-.02em;line-height:1.1;margin-bottom:12px}
.tool-card h2 em{font-style:italic;color:var(--gm)}
.tool-card p{font-size:14px;color:var(--tm);line-height:1.7;font-weight:300;margin-bottom:20px;max-width:440px}
.tool-card .tool-features{list-style:none;display:flex;flex-direction:column;gap:6px;margin-bottom:24px;padding:0}
.tool-card .tool-features li{font-size:12px;color:var(--tm);padding-left:18px;position:relative;font-weight:300;list-style:none}
.tool-card .tool-features li::before{content:'';position:absolute;left:0;top:7px;width:8px;height:8px;border-radius:50%;background:rgba(42,92,63,.2)}
.tool-card .tool-go{margin-top:auto;font-size:13px;color:var(--gm);font-weight:500;display:inline-flex;align-items:center;gap:8px}
.tool-card .tool-go::after{content:'→';transition:transform .2s}
.tool-card:hover .tool-go::after{transform:translateX(4px)}
.tool-card.dark{background:var(--gd);border-color:transparent;color:rgba(255,255,255,.85)}
.tool-card.dark .tool-card-eyebrow{color:rgba(255,255,255,.35)}
.tool-card.dark h2{color:#f6f2ea}
.tool-card.dark h2 em{color:rgba(246,242,234,.65)}
.tool-card.dark p{color:rgba(255,255,255,.6)}
.tool-card.dark .tool-features li{color:rgba(255,255,255,.55)}
.tool-card.dark .tool-features li::before{background:rgba(93,202,153,.4)}
.tool-card.dark .tool-go{color:#9dd8b7}
@media (max-width:900px){
  .tools-bento{grid-template-columns:1fr;gap:10px}
  .tools-bento .tool-card.wide{grid-column:span 1}
  .tool-card{padding:32px 28px;min-height:260px}
  .tool-card h2{font-size:30px}
}
/* ── Nursery photo gallery (used on /about, /coastal-advantage, /careers, regional landing) ── */
.nursery-gallery{background:var(--cr);border-top:1px solid var(--brd);border-bottom:1px solid var(--brd)}
/* Hero variant: lighter vertical padding but the same horizontal page gutters
   as every other section, so the image always sits inside the page borders. */
.nursery-hero-img{padding:40px var(--px);background:var(--cr)}
.nursery-hero-img .section-inner{max-width:var(--max);margin:0 auto}
.ng-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-top:32px;width:100%}
.ng-grid.ng-pair{margin-top:24px}
.ng-cell{margin:0;overflow:hidden;border-radius:10px;background:var(--brd);max-width:100%}
.ng-cell.ng-wide{grid-column:span 2}
.ng-cell img{display:block;width:100%;max-width:100%;height:auto;object-fit:cover;aspect-ratio:16/9;transition:transform .4s ease-out}
.ng-cell.ng-wide img{aspect-ratio:21/9}
.ng-cell:hover img{transform:scale(1.02)}
.nursery-hero-img .ng-cell{max-width:var(--max);margin:0 auto}
@media (max-width:760px){
  .ng-grid{grid-template-columns:1fr;gap:8px}
  .ng-cell.ng-wide{grid-column:span 1}
}

/* ── Self-hosted video (replaces YouTube iframe on the homepage) ── */
.video-self{background:#000;outline:none}
.video-self::-webkit-media-controls-panel{background-color:rgba(0,0,0,.55)}

.article-feature-image{display:block;width:100%;height:auto;border-radius:8px;margin-bottom:36px;border:1px solid var(--brd)}
@media(max-width:640px){.article-feature-image{margin-bottom:24px;border-radius:6px}}
.article-table{width:100%;border-collapse:collapse;margin:24px 0;font-size:14px;background:var(--cr)}
.article-table th,.article-table td{padding:10px 14px;text-align:left;border-bottom:1px solid var(--brd);vertical-align:top}
.article-table th{background:var(--sd);color:var(--td);font-weight:500;font-size:12px;text-transform:uppercase;letter-spacing:.04em}
.article-table tr:last-child td{border-bottom:none}
.article-table strong{color:var(--td);font-weight:500}
@media (max-width:600px){.article-table{font-size:13px}.article-table th,.article-table td{padding:8px 10px}}
.sp-tags{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:32px}
.sp-tag{font-size:11px;padding:4px 10px;border-radius:4px;border:1px solid var(--brd);color:var(--tm);background:var(--wh)}
a.sp-tag{text-decoration:none;transition:background .15s,color .15s,border-color .15s;cursor:pointer;display:inline-block}
a.sp-tag:hover{background:var(--gd);color:#fff;border-color:var(--gd)}
.tag-index-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:8px;margin-top:32px}
.tag-pill{display:flex;padding:10px 16px;border:1px solid var(--brd);border-radius:6px;font-size:13px;color:var(--tm);text-decoration:none;background:var(--wh);transition:all .15s;align-items:center;justify-content:space-between;gap:8px}
.tag-pill:hover{border-color:var(--gd);color:var(--gd);background:var(--gl)}
.tag-pill-count{font-size:10px;color:var(--tl);background:var(--sd);padding:2px 7px;border-radius:10px;flex-shrink:0}
@media(max-width:960px){.tag-index-grid{grid-template-columns:repeat(3,1fr)}}
@media(max-width:640px){.tag-index-grid{grid-template-columns:repeat(2,1fr)}}
.sp-sidebar{position:sticky;top:80px}
.sp-size-box{background:var(--wh);border:1px solid var(--brd);border-radius:10px;overflow:hidden}
.sp-size-head{padding:14px 20px;background:var(--gd);color:rgba(255,255,255,.85);font-size:11px;font-weight:500;letter-spacing:.06em;text-transform:uppercase;display:flex;align-items:center;justify-content:space-between;gap:12px}
.sp-size-head-sub{font-size:10px;font-weight:400;color:rgba(255,255,255,.5);letter-spacing:.04em;text-transform:uppercase;white-space:nowrap}
.sp-size-table{width:100%;border-collapse:collapse}
.sp-size-table th{padding:10px 16px;font-size:11px;color:var(--tl);text-align:left;font-weight:400;border-bottom:1px solid var(--brd);background:var(--sd)}
.sp-size-table td{padding:11px 16px;font-size:13px;color:var(--td);border-bottom:1px solid var(--brd)}
.sp-size-table tr:last-child td{border-bottom:none}
.sp-size-table td.price{font-weight:500;color:var(--gd)}
.sp-size-table tr.avail-row td{background:rgba(93,202,153,.05)}
.sp-size-table td.avail-qty{font-size:11px;color:#2a7a52;font-weight:500}
.sp-order-box{background:var(--gl);border:1px solid rgba(42,92,63,.15);border-radius:10px;padding:22px;margin-top:12px}
.sp-order-box p{font-size:13px;color:var(--tm);line-height:1.65;margin-bottom:14px;font-weight:300}
.sp-order-box strong{color:var(--td);font-weight:500}

/* WHY / EDITORIAL PAGES */
.editorial-grid{max-width:var(--max);margin:0 auto;display:grid;grid-template-columns:1fr 1.4fr;gap:72px;align-items:start;padding:72px var(--px)}
.editorial-stat-list{display:flex;flex-direction:column;margin-top:28px}
.ed-stat{display:flex;align-items:baseline;gap:16px;padding:18px 0;border-bottom:1px solid var(--brd)}
.ed-stat:last-child{border-bottom:none}
.ed-stat-n{font-family:'Cormorant Garamond',Georgia,serif;font-size:36px;font-weight:500;color:var(--gd);min-width:96px;line-height:1;letter-spacing:-.02em}
.ed-stat-d{font-size:13px;color:var(--tm);line-height:1.55;font-weight:300}
.editorial-body p{font-size:15px;color:var(--tm);line-height:1.85;margin-bottom:22px;font-weight:300}
.editorial-body p strong{color:var(--td);font-weight:500}
.editorial-body p:last-child{margin-bottom:0}
.editorial-body h2{font-family:'Cormorant Garamond',Georgia,serif;font-size:28px;font-weight:500;color:var(--td);letter-spacing:-.02em;margin:36px 0 14px}
.editorial-body ul{padding-left:18px;margin-bottom:20px}
.editorial-body li{font-size:14px;color:var(--tm);line-height:1.75;font-weight:300;margin-bottom:6px}
.pillar-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:10px;margin-top:36px}
.pillar-card{background:var(--wh);border:1px solid var(--brd);border-radius:8px;padding:26px}
.pillar-ico{font-size:20px;margin-bottom:14px}
.pillar-ttl{font-size:14px;font-weight:500;color:var(--td);margin-bottom:8px}
.pillar-body{font-size:13px;color:var(--tm);line-height:1.65;font-weight:300}

/* ORDER PAGE */
.steps-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin-top:36px}
.step-card{background:var(--wh);border:1px solid var(--brd);border-radius:8px;padding:28px}
.step-n{font-family:'Cormorant Garamond',Georgia,serif;font-size:36px;font-weight:500;color:var(--gd);line-height:1;margin-bottom:14px;letter-spacing:-.02em}
.step-ttl{font-size:14px;font-weight:500;color:var(--td);margin-bottom:8px}
.step-body{font-size:13px;color:var(--tm);line-height:1.65;font-weight:300}
.evg-hero{background:var(--gd);border-radius:10px;padding:40px;margin-top:16px}
.evg-hero h3{font-family:'Cormorant Garamond',Georgia,serif;font-size:28px;font-weight:500;color:#f6f2ea;margin-bottom:10px;letter-spacing:-.02em}
.evg-hero p{font-size:14px;color:rgba(255,255,255,.55);margin-bottom:20px;line-height:1.7;font-weight:300}

/* CONTACT PAGE */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:40px;margin-top:36px}
.contact-info-card{background:var(--gd);border-radius:10px;padding:36px}
.contact-info-card .eyebrow{color:rgba(255,255,255,.3)}
.contact-row{display:flex;gap:14px;padding:12px 0;border-bottom:1px solid rgba(255,255,255,.07)}
.contact-row:last-child{border-bottom:none}
.c-lbl{font-size:10px;color:rgba(255,255,255,.3);letter-spacing:.08em;text-transform:uppercase;width:58px;flex-shrink:0;padding-top:2px}
.c-val{font-size:14px;color:rgba(255,255,255,.78);line-height:1.55}
.c-val a{color:rgba(255,255,255,.78);text-decoration:none}
.contact-form-card{background:var(--wh);border:1px solid var(--brd);border-radius:10px;padding:36px}
.form-group{margin-bottom:18px}
.form-label{display:block;font-size:12px;font-weight:500;color:var(--td);margin-bottom:6px;letter-spacing:.02em}
.form-input,.form-textarea,.form-select{width:100%;padding:10px 14px;border:1px solid var(--brd);border-radius:6px;font-size:14px;color:var(--td);background:var(--cr);font-family:inherit;transition:border-color .15s;outline:none}
.form-input:focus,.form-textarea:focus,.form-select:focus{border-color:var(--gm)}
.form-textarea{resize:vertical;min-height:120px}
.form-submit{background:var(--gd);color:#fff;padding:12px 28px;border:none;border-radius:4px;font-size:13px;font-weight:500;cursor:pointer;font-family:inherit;transition:background .15s;width:100%}
.form-submit:hover{background:var(--gm)}
.form-submit:disabled{opacity:.6;cursor:wait}
.form-status{margin:14px 0 0;font-size:13px;line-height:1.55;min-height:1em}
.form-status:empty{margin:0}
.form-status-info{color:var(--td)}
.form-status-success{color:#1f6b3f}
.form-status-error{color:#a8323a}
.map-wrap{border-radius:10px;overflow:hidden;border:1px solid var(--brd);margin-top:16px}
.map-link{display:flex;align-items:center;gap:14px;padding:18px 20px;background:var(--cr);color:var(--td);text-decoration:none;transition:background .15s}
.map-link:hover{background:var(--brd)}
.map-link-pin{font-size:24px;line-height:1;color:var(--gd)}
.map-link-label{display:flex;flex-direction:column;gap:2px;font-size:13px}
.map-link-label strong{color:var(--td);font-weight:600}
.map-link-label em{font-style:normal;color:var(--gm);font-size:12px}

/* SPECIALS */
.avail-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin-top:36px}
.avail-card{background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.09);border-radius:8px;overflow:hidden;text-decoration:none;display:block;transition:background .2s}
.avail-card:hover{background:rgba(255,255,255,.1)}
.avail-card-img{height:100px;background:rgba(255,255,255,.04);display:flex;align-items:center;justify-content:center;border-bottom:1px solid rgba(255,255,255,.07)}
.avail-card-img span{font-family:'Cormorant Garamond',Georgia,serif;font-size:13px;color:rgba(255,255,255,.2);font-style:italic;text-align:center;padding:0 16px;line-height:1.4}
.avail-card-body{padding:16px 18px}
.avail-bot{font-size:11px;color:rgba(255,255,255,.3);margin-bottom:2px;font-style:italic}
.avail-name{font-size:14px;font-weight:500;color:rgba(255,255,255,.88);margin-bottom:6px}
.avail-tags{display:flex;flex-wrap:wrap;gap:5px;margin-top:10px;padding-top:10px;border-top:1px solid rgba(255,255,255,.07)}
.avail-tag{font-size:10px;padding:2px 8px;border-radius:3px}
.avail-tag.qty{background:rgba(93,202,153,.15);border:1px solid rgba(93,202,153,.25);color:#5dca99;font-weight:500}
.avail-tag.size{border:1px solid rgba(255,255,255,.12);color:rgba(255,255,255,.4)}
.avail-tag.price{border:1px solid rgba(255,255,255,.12);color:rgba(255,255,255,.55);font-weight:500}
.avail-tag.spl{background:rgba(200,140,60,.15);border:1px solid rgba(200,140,60,.25);color:#dea050}

/* ABOUT */
.about-grid{max-width:var(--max);margin:0 auto;padding:72px var(--px);display:grid;grid-template-columns:1fr 1.35fr;gap:72px}
.timeline{margin-top:28px;display:flex;flex-direction:column}
.tl-item{display:flex;gap:20px;padding:16px 0;border-bottom:1px solid var(--brd)}
.tl-item:last-child{border-bottom:none}
.tl-year{font-family:'Cormorant Garamond',Georgia,serif;font-size:22px;font-weight:500;color:var(--gd);min-width:56px;line-height:1.2;letter-spacing:-.02em}
.tl-desc{font-size:13px;color:var(--tm);line-height:1.6;font-weight:300}
.tl-desc strong{color:var(--td);font-weight:500}

/* FOOTER */
footer{background:#111f17;padding:48px var(--px) 28px}
.foot-inner{max-width:var(--max);margin:0 auto}
.foot-top{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:36px;padding-bottom:36px;border-bottom:1px solid rgba(255,255,255,.07)}
.foot-logo{font-family:'Cormorant Garamond',Georgia,serif;font-size:20px;font-weight:600;color:rgba(246,242,234,.85);letter-spacing:-.02em;margin-bottom:10px}
.foot-logo em{font-style:italic;font-weight:400}
.foot-tag{font-size:13px;color:rgba(255,255,255,.32);line-height:1.65;max-width:220px;font-weight:300}
.foot-addr{margin-top:18px;font-size:12px;color:rgba(255,255,255,.25);line-height:1.8}
.foot-socials{display:flex;gap:10px;margin-top:20px}
.soc-btn{width:34px;height:34px;border-radius:6px;border:1px solid rgba(255,255,255,.12);display:flex;align-items:center;justify-content:center;text-decoration:none;transition:border-color .15s,background .15s;flex-shrink:0}
.soc-btn:hover{border-color:rgba(255,255,255,.3);background:rgba(255,255,255,.06)}
.soc-btn svg{width:15px;height:15px;fill:rgba(255,255,255,.45);transition:fill .15s}
.soc-btn:hover svg{fill:rgba(255,255,255,.8)}
.foot-col-h{font-size:10px;letter-spacing:.1em;text-transform:uppercase;color:rgba(255,255,255,.28);margin-bottom:14px;font-weight:500}
.foot-links{list-style:none;display:flex;flex-direction:column;gap:8px}
.foot-links a{font-size:13px;color:rgba(255,255,255,.45);text-decoration:none;font-weight:300;transition:color .15s}
.foot-links a:hover{color:rgba(255,255,255,.8)}
.foot-bottom{display:flex;justify-content:space-between;align-items:center;padding-top:24px;flex-wrap:wrap;gap:10px}
.foot-copy{font-size:11px;color:rgba(255,255,255,.2)}
.foot-copy a{color:rgba(255,255,255,.3);text-decoration:none}
.foot-accred{display:flex;align-items:center;gap:7px;font-size:11px;color:rgba(255,255,255,.25)}
.fa-dot{width:5px;height:5px;border-radius:50%;background:#5dca99}

/* PRIVACY / TERMS */
.legal-body{max-width:680px;margin:0 auto;padding:56px var(--px)}
.legal-body h2{font-family:'Cormorant Garamond',Georgia,serif;font-size:26px;font-weight:500;color:var(--td);letter-spacing:-.02em;margin:36px 0 12px}
.legal-body h2:first-child{margin-top:0}
.legal-body p{font-size:14px;color:var(--tm);line-height:1.8;margin-bottom:14px;font-weight:300}
.legal-body ul{padding-left:18px;margin-bottom:14px}
.legal-body li{font-size:14px;color:var(--tm);line-height:1.75;font-weight:300;margin-bottom:4px}

/* 404 */
.err-page{max-width:var(--max);margin:0 auto;padding:120px var(--px);text-align:center}
.err-code{font-family:'Cormorant Garamond',Georgia,serif;font-size:96px;font-weight:500;color:var(--gd);line-height:1;letter-spacing:-.04em;opacity:.25;margin-bottom:8px}
.err-title{font-family:'Cormorant Garamond',Georgia,serif;font-size:36px;font-weight:500;color:var(--td);letter-spacing:-.02em;margin-bottom:12px}
.err-sub{font-size:15px;color:var(--tm);font-weight:300;max-width:400px;margin:0 auto 32px}

/* WHY CARDS on homepage */
.why-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:10px;margin-top:36px}
.why-card{background:var(--wh);border:1px solid var(--brd);border-radius:8px;padding:26px;transition:border-color .2s}
.why-card:hover{border-color:rgba(42,92,63,.3)}
.why-ico{width:34px;height:34px;border:1px solid var(--brd);border-radius:6px;display:flex;align-items:center;justify-content:center;margin-bottom:18px;font-size:15px}
.why-ttl{font-size:14px;font-weight:500;color:var(--td);margin-bottom:8px}
.why-body{font-size:13px;color:var(--tm);line-height:1.6;font-weight:300}

/* COASTAL SECTION */
.why-section{background:var(--sd);border-top:1px solid var(--brd);border-bottom:1px solid var(--brd);padding:72px var(--px)}
.coastal{padding:72px var(--px);background:var(--cr);border-bottom:1px solid var(--brd)}
.coastal-inner{max-width:var(--max);margin:0 auto;display:grid;grid-template-columns:1fr 1.35fr;gap:72px;align-items:start}
.coastal-stats{margin-top:32px;display:flex;flex-direction:column}
.c-stat{display:flex;align-items:baseline;gap:16px;padding:16px 0;border-bottom:1px solid var(--brd)}
.c-stat:last-child{border-bottom:none}
.c-stat-n{font-family:'Cormorant Garamond',Georgia,serif;font-size:34px;font-weight:500;color:var(--gd);min-width:90px;line-height:1;letter-spacing:-.02em}
.c-stat-desc{font-size:13px;color:var(--tm);line-height:1.5;font-weight:300}
.coastal-right p{font-size:15px;color:var(--tm);line-height:1.8;margin-bottom:20px;font-weight:300}
.coastal-right p strong{color:var(--td);font-weight:500}
.coastal-right p:last-child{margin-bottom:0}

/* VIDEO */
/* "The nursery" video section — generous breathing room on every breakpoint
   and a guaranteed gutter on the video itself so it never kisses the
   viewport edges on tablet/phone. */
.video-section{padding:96px 48px 80px;background:var(--cr);border-top:1px solid var(--brd);border-bottom:1px solid var(--brd)}
.video-section .section-inner{max-width:var(--max);margin:0 auto;padding:0}
.video-wrap{max-width:var(--max);margin:48px auto 0;position:relative;aspect-ratio:16/9;padding-bottom:56.25%;height:0;border-radius:10px;overflow:hidden;border:1px solid rgba(0,0,0,.06)}
@supports (aspect-ratio:16/9){.video-wrap{padding-bottom:0;height:auto}}
.video-wrap iframe,.video-wrap .video-self{position:absolute;top:0;left:0;width:100%;height:100%;border:0;object-fit:cover}
@media (max-width:960px){.video-section{padding:80px 36px 64px}}
@media (max-width:760px){.video-section{padding:64px 28px 48px}.video-wrap{margin-top:36px}}
@media (max-width:480px){.video-section{padding:56px 22px 44px}.video-wrap{margin-top:28px;border-radius:8px}}

/* CTA SECTION */
.cta-section{padding:72px var(--px);background:var(--cr)}
.cta-section-inner{max-width:var(--max);margin:0 auto}
.cta-header{margin-bottom:36px}
.cta-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.cta-left{background:var(--gd);border-radius:10px;padding:40px}
.cta-left .eyebrow{color:rgba(255,255,255,.3)}
.cta-left .sec-title{color:#f6f2ea;font-size:34px}
.cta-contact{margin-top:28px;display:flex;flex-direction:column}
.cta-row{display:flex;align-items:baseline;gap:14px;padding:11px 0;border-bottom:1px solid rgba(255,255,255,.07)}
.cta-row:last-child{border-bottom:none}
.cta-lbl{font-size:10px;color:rgba(255,255,255,.3);letter-spacing:.08em;text-transform:uppercase;width:58px;flex-shrink:0}
.cta-val{font-size:14px;color:rgba(255,255,255,.78);line-height:1.4}
.cta-right{display:flex;flex-direction:column;gap:16px}
.evg-card{background:var(--wh);border:1px solid var(--brd);border-radius:10px;padding:28px;text-align:center}
.evg-ttl{font-size:15px;font-weight:500;color:var(--td);margin-bottom:8px}
.evg-sub{font-size:13px;color:var(--tm);line-height:1.6;margin-bottom:20px;font-weight:300}
.evg-note{font-size:11px;color:var(--tl);margin-top:10px;line-height:1.5}
.map-embed{border-radius:10px;overflow:hidden;border:1px solid var(--brd);min-height:220px;flex:1}
.map-embed iframe{display:block;width:100%;height:100%;min-height:220px}

/* RESPONSIVE */
@media (max-width:960px){
  :root{--px:24px}
  .nav-links{display:none}
  .hamburger{display:flex}
  .hero-inner{grid-template-columns:1fr;gap:36px}
  .hero h1{font-size:48px}
  .hero-right{display:flex;flex-direction:column;gap:10px}
  .stat-grid{grid-template-columns:1fr 1fr}
  .trust-bar-inner{justify-content:center}
  .trust-item{padding:4px 12px}
  .cat-grid{grid-template-columns:repeat(2,1fr)}
  .species-grid{grid-template-columns:repeat(2,1fr)}
  .sp-grid{grid-template-columns:repeat(3,1fr)}
  .why-grid{grid-template-columns:repeat(2,1fr)}
  .editorial-grid{grid-template-columns:1fr;gap:40px}
  .coastal-inner{grid-template-columns:1fr;gap:40px}
  .cta-grid{grid-template-columns:1fr}
  .contact-grid{grid-template-columns:1fr}
  .steps-grid{grid-template-columns:1fr 1fr}
  .foot-top{grid-template-columns:1fr 1fr;gap:28px}
  .species-layout{grid-template-columns:1fr;gap:36px}
  .sp-sidebar{position:static}
  .about-grid{grid-template-columns:1fr;gap:36px}
  .pillar-grid{grid-template-columns:1fr 1fr}
  .avail-grid{grid-template-columns:repeat(2,1fr)}
  .page-hero h1{font-size:38px}
}
@media (max-width:640px){
  :root{--px:20px}
  nav{height:56px}
  .mobile-nav{inset:56px 0 0 0}
  .logo{font-size:18px}
  .hero{padding:48px var(--px) 40px}
  .hero h1{font-size:38px}
  .hero-sub{font-size:14px}
  .hero-ctas{margin-top:24px}
  .hstat{padding:16px}
  .hstat-n{font-size:30px}
  .trust-bar{padding:10px var(--px)}
  .trust-item{padding:5px 10px;font-size:10px;border-right:1px solid var(--brd)}
  .trust-item:nth-child(even){border-right:none}
  .trust-item:nth-child(n+3){border-top:.5px solid var(--brd)}
  .specials-inner{flex-direction:column}
  .spec-label{border-right:none;border-bottom:1px solid rgba(255,255,255,.07);margin-right:0;padding:12px 0 10px}
  .spec-items{flex-direction:column}
  .spec-item{border-right:none;border-bottom:1px solid rgba(255,255,255,.06);flex:none;padding:12px 0}
  .spec-item:last-child{border-bottom:none}
  .section{padding:48px var(--px)}
  .dark-section{padding:48px var(--px)}
  .sand-section{padding:48px var(--px)}
  .sec-title{font-size:30px}
  .cat-grid{grid-template-columns:1fr}
  .sp-grid{grid-template-columns:repeat(2,1fr)}
  .why-grid{grid-template-columns:1fr 1fr}
  .steps-grid{grid-template-columns:1fr}
  .foot-top{grid-template-columns:1fr}
  .foot-bottom{flex-direction:column;align-items:flex-start;gap:8px}
  .cta-left{padding:28px 24px}
  .cta-left .sec-title{font-size:26px}
  .editorial-grid{padding:48px var(--px)}
  .about-grid{padding:48px var(--px)}
  .avail-grid{grid-template-columns:1fr}
  .species-layout{padding:40px var(--px)}
  .page-hero{padding:40px var(--px) 36px}
  .page-hero h1{font-size:32px}
  .contact-form-card,.contact-info-card{padding:24px 20px}
  .pillar-grid{grid-template-columns:1fr}
}
@media (max-width:380px){
  .hero h1{font-size:32px}
  .accred-bar{display:none}
  .why-grid{grid-template-columns:1fr}
  .btn-cream,.btn-ghost{width:100%;text-align:center}
  .sp-grid{grid-template-columns:1fr}
}

/* COOKIE CONSENT BANNER */
#cn-cookie{position:fixed;left:16px;right:16px;bottom:16px;z-index:300;background:var(--wh);border:.5px solid rgba(26,28,24,.12);border-radius:10px;box-shadow:0 12px 40px rgba(26,28,24,.14),0 2px 8px rgba(26,28,24,.06);opacity:0;transform:translateY(16px);transition:opacity .28s ease,transform .28s ease;max-width:calc(var(--max) + var(--px)*2);margin:0 auto}
#cn-cookie.cn-cookie-visible{opacity:1;transform:translateY(0)}
.cn-cookie-inner{display:flex;align-items:center;gap:24px;padding:18px 22px}
.cn-cookie-text{flex:1;min-width:0}
#cn-cookie h2{font-family:'Cormorant Garamond',Georgia,serif;font-size:18px;font-weight:600;color:var(--gd);margin:0 0 4px;letter-spacing:-.01em}
#cn-cookie h2 em{font-style:italic;font-weight:400}
#cn-cookie p{font-size:13px;color:var(--tm);line-height:1.55;margin:0}
#cn-cookie p a{color:var(--gd);text-decoration:underline;text-underline-offset:2px;text-decoration-thickness:.5px}
#cn-cookie p a:hover{color:var(--gm)}
.cn-cookie-actions{display:flex;gap:8px;flex-shrink:0}
.cn-cookie-btn{font-family:inherit;font-size:13px;font-weight:500;padding:10px 20px;border-radius:4px;border:1px solid transparent;cursor:pointer;transition:background .15s,border-color .15s,color .15s;white-space:nowrap}
.cn-cookie-btn:focus-visible{outline:2px solid var(--gm);outline-offset:2px}
.cn-cookie-decline{background:transparent;border-color:var(--brd);color:var(--td)}
.cn-cookie-decline:hover{border-color:var(--gm);color:var(--gd)}
.cn-cookie-accept{background:var(--gd);color:#fff}
.cn-cookie-accept:hover{background:var(--gm)}
@media (max-width:640px){
  #cn-cookie{left:12px;right:12px;bottom:12px}
  .cn-cookie-inner{flex-direction:column;align-items:stretch;gap:14px;padding:16px 18px}
  .cn-cookie-actions{justify-content:flex-end}
  .cn-cookie-btn{padding:10px 16px}
}
@media (prefers-reduced-motion:reduce){
  #cn-cookie{transition:opacity .1s linear;transform:none}
}

/* ── Plant size carousel ─────────────────────────────────────── */
.sp-carousel{position:relative;overflow:hidden}
.sp-carousel-track{position:absolute;inset:0;width:100%;height:100%}
.sp-carousel-slide{position:absolute;inset:0;width:100%;height:100%;opacity:0;transition:opacity .35s ease;pointer-events:none}
.sp-carousel-slide.active{opacity:1;pointer-events:auto;z-index:1}
.sp-carousel-slide picture{position:absolute;inset:0;width:100%;height:100%}
.sp-carousel-slide img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:center;display:block}
.sp-carousel-caption{position:absolute;left:14px;top:14px;background:rgba(20,20,20,.78);color:#f6f2ea;font-size:14px;font-weight:500;letter-spacing:.04em;padding:8px 14px;border-radius:999px;backdrop-filter:blur(6px);z-index:3;text-transform:uppercase;box-shadow:0 2px 12px rgba(0,0,0,.18)}
.sp-carousel-slide.active .sp-carousel-caption{animation:cn-pulse-cap .42s ease-out}
@keyframes cn-pulse-cap{0%{transform:scale(.92);opacity:.6}60%{transform:scale(1.05);opacity:1}100%{transform:scale(1);opacity:1}}
.sp-carousel-nav{position:absolute;top:50%;transform:translateY(-50%);width:42px;height:42px;border-radius:50%;border:none;background:rgba(20,20,20,.55);color:#f6f2ea;font-size:24px;line-height:1;font-weight:300;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .2s ease;backdrop-filter:blur(4px);z-index:4;padding:0}
.sp-carousel-nav:hover{background:rgba(20,20,20,.78)}
.sp-carousel-nav:focus-visible{outline:2px solid #f6f2ea;outline-offset:2px}
.sp-carousel-prev{left:12px}
.sp-carousel-next{right:12px}
.sp-carousel-dots{position:absolute;left:0;right:0;bottom:14px;display:flex;justify-content:center;gap:6px;z-index:3}
.sp-carousel-dot{width:8px;height:8px;border-radius:50%;border:none;padding:0;background:rgba(255,255,255,.5);cursor:pointer;transition:background .2s ease,transform .2s ease}
.sp-carousel-dot.active{background:#f6f2ea;transform:scale(1.2)}
.sp-carousel-dot:focus-visible{outline:2px solid #f6f2ea;outline-offset:2px}
.sp-carousel[data-count="1"] .sp-carousel-nav,
.sp-carousel[data-count="1"] .sp-carousel-dots{display:none}
@media (max-width:600px){
  .sp-carousel-nav{width:36px;height:36px;font-size:20px}
  .sp-carousel-prev{left:8px}.sp-carousel-next{right:8px}
}
@media (prefers-reduced-motion:reduce){
  .sp-carousel-slide{transition:opacity .01s linear}
}
