@import url('../assets/fonts/fonts.css');
/* ============================================================
   Ruibal's — Plants of Texas · 2026 design system
   Brand: forest #0d3529 + sage #76925b (from the logo), warm cream paper
   Type: DM Serif Display (headlines) + DM Sans (body) — self-hosted
   ============================================================ */
:root{
  --forest:#0d3529;
  --forest-2:#12463540;
  --sage:#76925b;
  --sage-deep:#5b7544;
  --sage-soft:#e7eddd;
  --gold:#e0a92e;
  --bloom:#d6608f;
  --paper:#faf7ef;
  --paper-2:#f2ecde;
  --ink:#1c2620;
  --muted:#5d6b60;
  --line:#e2dcca;
  --white:#fff;
  --radius:18px;
  --radius-lg:26px;
  --shadow:0 1px 2px rgba(13,53,41,.05), 0 14px 40px -18px rgba(13,53,41,.28);
  --shadow-lg:0 30px 70px -30px rgba(13,53,41,.45);
  --maxw:1240px;
  --serif:"DM Serif Display", Georgia, "Times New Roman", serif;
  --sans:"DM Sans", system-ui, -apple-system, "Segoe UI", Roboto, sans-serif;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;font-family:var(--sans);color:var(--ink);background:var(--paper);
  font-size:16px;line-height:1.6;-webkit-font-smoothing:antialiased;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer}
h1,h2,h3,h4{font-family:var(--serif);font-weight:400;line-height:1.08;letter-spacing:-.015em;margin:0}
h1{font-size:clamp(2.6rem,6vw,5rem);font-weight:400}
h2{font-size:clamp(2rem,3.6vw,3.2rem)}
h3{font-size:1.4rem}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 24px}
.eyebrow{font-family:var(--sans);text-transform:uppercase;letter-spacing:.22em;font-size:.72rem;font-weight:700;color:var(--sage-deep)}
.lede{font-size:1.18rem;color:var(--muted);max-width:60ch}
section{position:relative}
.section-pad{padding:clamp(60px,9vw,120px) 0}

/* ---- buttons ---- */
.btn{display:inline-flex;align-items:center;gap:.55em;border:none;border-radius:999px;
  padding:.95em 1.7em;font-weight:600;font-size:.96rem;transition:.25s ease;white-space:nowrap}
.btn svg{width:1.05em;height:1.05em}
.btn-primary{background:var(--forest);color:#f4f1e6}
.btn-primary:hover{background:#16513d;transform:translateY(-2px);box-shadow:0 16px 30px -14px rgba(13,53,41,.6)}
.btn-gold{background:var(--gold);color:#3a2a05}
.btn-gold:hover{transform:translateY(-2px);box-shadow:0 16px 30px -14px rgba(224,169,46,.6)}
.btn-ghost{background:transparent;color:var(--forest);border:1.5px solid var(--forest-2)}
.btn-ghost:hover{background:var(--sage-soft);border-color:var(--sage)}
.btn-ghost.light{color:#f1efe4;border-color:rgba(255,255,255,.45)}
.btn-ghost.light:hover{background:rgba(255,255,255,.18);border-color:#fff;color:#fff}
.btn-sage{background:var(--sage);color:#fff}
.btn-sage:hover{background:var(--sage-deep)}
.btn-sm{padding:.6em 1.1em;font-size:.85rem}

/* ============================================================ HEADER */
.topbar{background:var(--forest);color:#cfe0cf;font-size:.74rem;line-height:1}
.topbar .wrap{display:flex;justify-content:space-between;align-items:center;gap:18px;padding:5px 24px;flex-wrap:nowrap;white-space:nowrap;overflow:hidden}
.topbar a{color:#e7efe3;font-weight:600}
.topbar .tb-right{display:flex;gap:18px;align-items:center}
.topbar .pin{display:inline-flex;gap:5px;align-items:center;opacity:.85}
.topbar .pin svg{width:13px;height:13px}
@media(max-width:680px){ .topbar .pin:first-child{display:none} }

header.site{position:sticky;top:0;z-index:60;background:rgba(250,247,239,.82);
  backdrop-filter:blur(14px);border-bottom:1px solid var(--line);transition:.3s}
header.site .bar{display:flex;align-items:center;justify-content:space-between;gap:24px;padding:11px 24px;max-width:var(--maxw);margin:0 auto}
.brand{display:flex;align-items:center;gap:12px}
.brand .emblem{width:42px;height:42px;flex:0 0 auto}
.brand .logo-img{height:38px;width:auto}
nav.main{display:flex;gap:4px;align-items:center}
nav.main>div{position:relative}
nav.main a.nav-link, nav.main button.nav-link{background:none;border:none;font-size:.93rem;font-weight:600;color:var(--ink);
  padding:.6em .85em;border-radius:10px;display:inline-flex;align-items:center;gap:5px;transition:.18s}
nav.main a.nav-link:hover,nav.main button.nav-link:hover{background:var(--sage-soft);color:var(--forest)}
nav.main .caret{width:9px;height:9px;opacity:.5}
.dropdown{position:absolute;top:calc(100% + 8px);left:0;background:#fff;border:1px solid var(--line);
  border-radius:16px;box-shadow:var(--shadow);padding:8px;min-width:210px;opacity:0;visibility:hidden;
  transform:translateY(6px);transition:.2s}
nav.main>div:hover .dropdown{opacity:1;visibility:visible;transform:none}
.dropdown a{display:block;padding:.6em .8em;border-radius:10px;font-size:.9rem;font-weight:500}
.dropdown a:hover{background:var(--sage-soft);color:var(--forest)}
.header-cta{display:flex;gap:10px;align-items:center}
.menu-toggle{display:none;background:none;border:none}

/* ============================================================ HERO */
.hero{position:relative;overflow:hidden;background:var(--forest);color:#f3f0e4}
.hero .wrap{position:relative;z-index:2;display:grid;grid-template-columns:1.05fr .95fr;gap:50px;align-items:center;
  padding-top:clamp(50px,7vw,90px);padding-bottom:clamp(50px,7vw,90px)}
.hero h1{color:#fbf8ee}
.hero h1 em{font-style:italic;color:var(--gold)}
.hero p{color:#cdd9c8;font-size:1.2rem;max-width:46ch;margin:22px 0 30px}
.hero .hero-cta{display:flex;gap:14px;flex-wrap:wrap}
.hero .stats{display:flex;gap:34px;margin-top:42px}
.hero .stats b{font-family:var(--serif);font-size:1.9rem;display:block;color:#fff;font-weight:400}
.stats b{font-weight:400}
.hero .stats span{font-size:.82rem;color:#a9bca5;text-transform:uppercase;letter-spacing:.1em}
.hero-art{position:relative;height:520px}
.hero-art .tile{position:absolute;border-radius:22px;overflow:hidden;box-shadow:var(--shadow-lg);border:4px solid rgba(255,255,255,.08)}
.hero-art .tile img{width:100%;height:100%;object-fit:cover}
.hero-art .t1{width:60%;height:64%;top:0;right:0;z-index:2}
.hero-art .t2{width:46%;height:50%;bottom:0;left:0;z-index:3}
.hero-art .t3{width:38%;height:40%;bottom:6%;right:8%;z-index:4}
.hero-blob{position:absolute;inset:auto -10% -40% auto;width:60%;height:120%;background:radial-gradient(circle,#1c5b41,transparent 70%);opacity:.6;filter:blur(20px)}
.leaf-band{position:absolute;inset:0;background:
  radial-gradient(140px 140px at 12% 88%,rgba(118,146,91,.25),transparent 70%),
  radial-gradient(180px 180px at 90% 10%,rgba(224,169,46,.12),transparent 70%)}

/* ============================================================ SEARCH STRIP */
.searchstrip{margin-top:-40px;position:relative;z-index:20}
.searchstrip .card{background:#fff;border-radius:var(--radius-lg);box-shadow:var(--shadow);padding:26px;
  display:grid;grid-template-columns:1fr 1fr 1fr auto;gap:14px;align-items:end;border:1px solid var(--line)}
.searchstrip label{font-size:.74rem;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:var(--muted);display:block;margin-bottom:6px}
.searchstrip select,.searchstrip input{width:100%;padding:.8em .9em;border:1.5px solid var(--line);border-radius:12px;font-size:.95rem;background:var(--paper);color:var(--ink)}

/* ============================================================ CARD GRID */
.grid{display:grid;gap:22px}
.grid.cols-4{grid-template-columns:repeat(4,1fr)}
.grid.cols-3{grid-template-columns:repeat(3,1fr)}
.plant-card{background:#fff;border-radius:var(--radius);overflow:hidden;border:1px solid var(--line);
  box-shadow:var(--shadow);transition:.28s;cursor:pointer;display:flex;flex-direction:column}
.plant-card:hover{transform:translateY(-6px);box-shadow:var(--shadow-lg)}
.plant-card .ph{position:relative;aspect-ratio:1/1;overflow:hidden;background:var(--sage-soft)}
.plant-card .ph img{width:100%;height:100%;object-fit:cover;transition:transform .6s cubic-bezier(.2,.7,.2,1)}
.plant-card:hover .ph img{transform:scale(1.07)}
.plant-card .cat-tag{position:absolute;top:12px;left:12px;background:rgba(13,53,41,.86);color:#eef3e8;
  font-size:.68rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;padding:.4em .7em;border-radius:999px;backdrop-filter:blur(4px)}
.plant-card .swatches{position:absolute;bottom:12px;right:12px;display:flex;gap:4px}
.plant-card .swatches i{width:14px;height:14px;border-radius:50%;border:1.5px solid #fff;box-shadow:0 1px 3px rgba(0,0,0,.3)}
.plant-card .body{padding:16px 16px 18px}
.plant-card .body h3{font-size:1.05rem;line-height:1.2}
.plant-card .body .bot{font-style:italic;color:var(--muted);font-size:.85rem;margin-top:3px;font-family:var(--serif)}
.plant-card .meta{display:flex;gap:12px;margin-top:12px;flex-wrap:wrap;font-size:.78rem;color:var(--sage-deep);font-weight:600}
.plant-card .meta span{display:inline-flex;align-items:center;gap:4px}
.plant-card .acts{display:flex;gap:8px;margin-top:14px}
.plant-card .acts .btn{flex:1;justify-content:center}

/* ============================================================ CATALOG */
.catalog{display:grid;grid-template-columns:300px 1fr;gap:32px;align-items:start}
.filters{position:sticky;top:96px;background:#fff;border:1px solid var(--line);border-radius:var(--radius);
  box-shadow:var(--shadow);max-height:calc(100vh - 120px);overflow:auto}
.filters .fhead{display:flex;justify-content:space-between;align-items:center;padding:18px 18px 10px;position:sticky;top:0;background:#fff;z-index:2;border-bottom:1px solid var(--line)}
.filters .fhead h3{font-size:1.1rem}
.filters .fhead{gap:10px}
.filters .fhead h3{margin-right:auto}
.filters .fhead button{font-size:.8rem;color:var(--bloom);background:none;border:none;font-weight:700}
.filters .fhead button.filters-close{display:none;background:var(--forest);color:#fff;border-radius:999px;padding:.55em 1.1em;font-size:.85rem}
body.filters-lock{overflow:hidden}
@media(max-width:860px){ .filters .fhead button.filters-close{display:inline-flex;align-items:center;gap:5px} }
.filters-foot{position:sticky;bottom:0;background:#fff;border-top:1px solid var(--line);padding:13px 16px;border-radius:0 0 var(--radius) var(--radius);box-shadow:0 -8px 16px -8px rgba(13,53,41,.12);z-index:3}
.fgroup{border-bottom:1px solid var(--line)}
.fgroup>summary{list-style:none;cursor:pointer;padding:14px 18px;font-weight:700;font-size:.82rem;
  text-transform:uppercase;letter-spacing:.08em;color:var(--forest);display:flex;justify-content:space-between;align-items:center}
.fgroup>summary::-webkit-details-marker{display:none}
.fgroup>summary .chev{transition:.2s}
.fgroup[open]>summary .chev{transform:rotate(180deg)}
.fgroup .fbody{padding:4px 18px 16px}
.chk{display:flex;align-items:center;gap:9px;padding:5px 0;font-size:.9rem;cursor:pointer}
.chk input{accent-color:var(--sage);width:16px;height:16px}
.chk .count{margin-left:auto;color:var(--muted);font-size:.78rem}
.color-grid{display:flex;flex-wrap:wrap;gap:8px;padding-top:6px}
.color-chip{width:30px;height:30px;border-radius:50%;border:2px solid #fff;box-shadow:0 0 0 1.5px var(--line);cursor:pointer;position:relative;transition:.15s}
.color-chip:hover{transform:scale(1.12)}
.color-chip.on{box-shadow:0 0 0 2.5px var(--forest);transform:scale(1.1)}
.color-chip.on::after{content:"✓";position:absolute;inset:0;display:grid;place-items:center;color:#fff;font-size:.8rem;text-shadow:0 1px 2px rgba(0,0,0,.6)}
.range-row{display:flex;align-items:center;gap:10px;font-size:.85rem;color:var(--muted)}
.range-row input[type=range]{flex:1;accent-color:var(--sage)}

.catalog-main .cat-toolbar{display:flex;justify-content:space-between;align-items:center;gap:16px;margin-bottom:20px;flex-wrap:wrap}
.catalog-main .cat-toolbar .count{font-weight:600;color:var(--muted)}
.catalog-main .cat-toolbar .count b{color:var(--forest)}
.searchbox{display:flex;align-items:center;gap:8px;background:#fff;border:1.5px solid var(--line);border-radius:999px;padding:.5em 1em;min-width:240px}
.searchbox input{border:none;outline:none;background:none;font-size:.95rem;width:100%}
.toolbar-right{display:flex;gap:10px;align-items:center}
.toolbar-right select{padding:.6em .9em;border:1.5px solid var(--line);border-radius:999px;background:#fff;font-size:.88rem;font-weight:600}
.activechips{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:18px}
.activechips .chip{background:var(--sage-soft);color:var(--forest);border-radius:999px;padding:.35em .8em;font-size:.8rem;font-weight:600;display:inline-flex;gap:6px;align-items:center;cursor:pointer}
.activechips .chip:hover{background:#d8e3c6}
.filter-toggle{display:none}
.empty{text-align:center;padding:80px 20px;color:var(--muted)}

/* ============================================================ MODAL / PROFILE */
.modal-back{position:fixed;inset:0;background:rgba(13,28,21,.6);backdrop-filter:blur(6px);z-index:200;
  display:none;align-items:center;justify-content:center;padding:24px}
.modal-back.show{display:flex}
.modal{background:var(--paper);border-radius:var(--radius-lg);max-width:920px;width:100%;max-height:90vh;overflow:auto;box-shadow:var(--shadow-lg);position:relative}
.modal .mclose{position:absolute;top:16px;right:16px;z-index:5;background:#fff;border:1px solid var(--line);width:40px;height:40px;border-radius:50%;font-size:1.2rem;display:grid;place-items:center;box-shadow:var(--shadow)}
.profile{display:grid;grid-template-columns:1fr 1fr}
.profile .pimg{position:relative;min-height:340px;background:var(--sage-soft)}
.profile .pimg img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.profile .pinfo{padding:34px}
.profile .pinfo .eyebrow{margin-bottom:10px}
.profile .pinfo h2{font-size:2rem}
.profile .pinfo .bot{font-style:italic;font-family:var(--serif);color:var(--muted);font-size:1.05rem;margin-top:4px}
.spec-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin:22px 0}
.spec{background:#fff;border:1px solid var(--line);border-radius:14px;padding:12px 14px}
.spec .k{font-size:.7rem;text-transform:uppercase;letter-spacing:.08em;color:var(--muted);font-weight:700}
.spec .v{font-weight:600;margin-top:3px;font-size:.95rem;color:var(--forest)}
.tagrow{display:flex;flex-wrap:wrap;gap:7px;margin:6px 0 16px}
.tag{background:var(--sage-soft);color:var(--sage-deep);border-radius:999px;padding:.32em .75em;font-size:.78rem;font-weight:600}
.tag.gold{background:#f7eccf;color:#8a6912}
.tag.bloom{background:#f8dde8;color:#a23866}
.profile .care{font-size:.95rem;color:var(--muted);border-top:1px solid var(--line);padding-top:16px}
.funfact{background:var(--sage-soft);border-radius:12px;padding:12px 14px;font-size:.9rem;color:var(--sage-deep);margin:14px 0;font-weight:500}
.know-head{font-family:var(--serif);font-size:1.15rem;color:var(--forest);margin:18px 0 8px}
.know-grid{display:grid;gap:0}
.know-row{display:grid;grid-template-columns:128px 1fr;gap:14px;padding:9px 0;border-bottom:1px solid var(--line);font-size:.9rem}
.know-row .kk{color:var(--muted);font-weight:700;font-size:.74rem;text-transform:uppercase;letter-spacing:.06em;padding-top:1px}
.know-row .kv{color:var(--ink)}
.know-label{font-size:.7rem;text-transform:uppercase;letter-spacing:.08em;color:var(--muted);font-weight:700;margin-top:16px}
.sources{font-size:.78rem;color:var(--muted);margin-top:16px}
.sources a{color:var(--sage-deep);text-decoration:underline;text-underline-offset:2px}
.profile .pacts{display:flex;gap:10px;margin-top:20px;flex-wrap:wrap}

/* ============================================================ AI ASSISTANT */
.ai-launch{position:fixed;bottom:24px;right:24px;z-index:150;display:flex;align-items:center;gap:10px;
  background:var(--forest);color:#f2efe2;border:none;border-radius:999px;padding:14px 20px 14px 16px;
  box-shadow:var(--shadow-lg);font-weight:700;font-size:.95rem}
.ai-launch:hover{background:#16513d;transform:translateY(-2px)}
.ai-launch .dot{width:38px;height:38px;border-radius:50%;background:var(--sage);display:grid;place-items:center}
.ai-launch .dot svg{width:22px;height:22px}
.ai-panel{position:fixed;bottom:24px;right:24px;width:420px;max-width:calc(100vw - 32px);height:min(680px,calc(100vh - 48px));
  background:var(--paper);border-radius:24px;box-shadow:var(--shadow-lg);z-index:200;display:none;flex-direction:column;overflow:hidden;border:1px solid var(--line)}
.ai-panel.show{display:flex}
.ai-head{background:var(--forest);color:#f2efe2;padding:16px 18px;display:flex;align-items:center;gap:12px}
.ai-head .av{width:42px;height:42px;border-radius:50%;background:var(--sage);display:grid;place-items:center;flex:0 0 auto}
.ai-head .av svg{width:24px;height:24px}
.ai-head h4{font-family:var(--serif);font-size:1.1rem;margin:0;color:#fff}
.ai-head p{margin:0;font-size:.76rem;color:#a9bca5;display:flex;align-items:center;gap:6px}
.ai-head .online{width:8px;height:8px;border-radius:50%;background:#7ed957;box-shadow:0 0 0 3px rgba(126,217,87,.3)}
.ai-head .x{margin-left:auto;background:rgba(255,255,255,.12);border:none;color:#fff;width:32px;height:32px;border-radius:50%;font-size:1.1rem}
.ai-body{flex:1;overflow-y:auto;padding:18px;display:flex;flex-direction:column;gap:14px;background:
  radial-gradient(120px 120px at 100% 0,rgba(118,146,91,.08),transparent 70%)}
.ai-disclaimer{font-size:.66rem;color:var(--muted);text-align:center;padding:0 12px 6px;opacity:.75;line-height:1.35}
.msg{max-width:84%;padding:11px 15px;border-radius:18px;font-size:.92rem;line-height:1.5;animation:pop .25s ease}
@keyframes pop{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}
.msg.bot{background:#fff;border:1px solid var(--line);border-bottom-left-radius:5px;align-self:flex-start;box-shadow:0 2px 8px rgba(13,53,41,.05)}
.msg.user{background:var(--forest);color:#f1efe4;border-bottom-right-radius:5px;align-self:flex-end}
.typing{display:flex;gap:4px;padding:14px 16px;background:#fff;border:1px solid var(--line);border-radius:18px;border-bottom-left-radius:5px;align-self:flex-start;width:fit-content}
.typing i{width:7px;height:7px;border-radius:50%;background:var(--sage);animation:blink 1.2s infinite}
.typing i:nth-child(2){animation-delay:.2s}.typing i:nth-child(3){animation-delay:.4s}
@keyframes blink{0%,60%,100%{opacity:.3;transform:translateY(0)}30%{opacity:1;transform:translateY(-3px)}}
.quick{display:flex;flex-wrap:wrap;gap:8px;padding:0 18px 8px}
.quick button{background:#fff;border:1.5px solid var(--sage);color:var(--sage-deep);border-radius:999px;padding:.5em 1em;font-size:.85rem;font-weight:600;transition:.15s}
.quick button:hover{background:var(--sage);color:#fff}
.ai-input{display:flex;gap:8px;padding:12px 14px;border-top:1px solid var(--line);background:#fff}
.ai-input input{flex:1;border:1.5px solid var(--line);border-radius:999px;padding:.7em 1.1em;font-size:.92rem;outline:none}
.ai-input input:focus{border-color:var(--sage)}
.ai-input button{background:var(--forest);border:none;color:#fff;width:44px;height:44px;border-radius:50%;display:grid;place-items:center;flex:0 0 auto}
.ai-input button svg{width:20px;height:20px}
/* AI plan card */
.plan{background:#fff;border:1px solid var(--line);border-radius:16px;padding:0;overflow:hidden;align-self:stretch;max-width:100%;box-shadow:0 6px 18px rgba(13,53,41,.08)}
.plan .ph{background:var(--forest);color:#f1efe4;padding:13px 16px;font-weight:700;font-size:.9rem;display:flex;align-items:center;gap:8px}
.plan .pb{padding:14px 16px}
.plan .step{display:flex;gap:11px;margin-bottom:11px;font-size:.88rem}
.plan .step .n{flex:0 0 auto;width:22px;height:22px;border-radius:50%;background:var(--sage-soft);color:var(--sage-deep);font-weight:700;font-size:.78rem;display:grid;place-items:center}
.plan .recs{display:flex;gap:10px;overflow-x:auto;padding:4px 0 8px}
.plan .rec{flex:0 0 108px;width:108px;cursor:pointer}
.plan .rec img{width:108px;height:84px;object-fit:cover;border-radius:10px;border:1px solid var(--line)}
.plan .rec span{display:block;font-size:.74rem;font-weight:600;margin-top:5px;line-height:1.2}
.plan .pacts{display:flex;gap:8px;margin-top:6px}
.plan .pacts .btn{flex:1;justify-content:center}

/* ============================================================ GENERIC SECTIONS */
.split{display:grid;grid-template-columns:1fr 1fr;gap:54px;align-items:center}
.imground{border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-lg);aspect-ratio:5/4}
.imground img{width:100%;height:100%;object-fit:cover}
.tone-sage{background:var(--sage-soft)}
.tone-forest{background:var(--forest);color:#eef3e8}
.tone-forest .lede,.tone-forest p{color:#c2d2bd}
.tone-forest h2{color:#fff}

.feature-row{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.feature{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:28px;box-shadow:var(--shadow);transition:.25s}
.feature:hover{transform:translateY(-5px);box-shadow:var(--shadow-lg)}
.feature .ic{width:54px;height:54px;border-radius:14px;background:var(--sage-soft);display:grid;place-items:center;margin-bottom:16px}
.feature .ic svg{width:28px;height:28px;color:var(--sage-deep)}
.feature h3{font-size:1.25rem;margin-bottom:8px}
.feature p{color:var(--muted);font-size:.95rem;margin:0 0 14px}
.feature a{color:var(--sage-deep);font-weight:700;font-size:.9rem;display:inline-flex;gap:5px;align-items:center}

/* real-photo band (authentic Ruibal's photography) */
.photo-band{position:relative;height:clamp(280px,40vw,440px);overflow:hidden}
.photo-band img{width:100%;height:100%;object-fit:cover;object-position:center}
.photo-band .pb-overlay{position:absolute;inset:0;background:linear-gradient(90deg,rgba(13,53,41,.82),rgba(13,53,41,.3) 58%,rgba(13,53,41,.05));display:flex;align-items:center}
.photo-band .pb-inner{max-width:var(--maxw);margin:0 auto;padding:0 24px;width:100%}
.photo-band .pb-inner .eyebrow{color:var(--gold)}
.photo-band h2{color:#fff;max-width:18ch;margin:8px 0 14px}
.photo-band p{color:#e7efe3;max-width:44ch;margin-bottom:20px}
@media(max-width:600px){ .photo-band .pb-overlay{background:linear-gradient(180deg,rgba(13,53,41,.45),rgba(13,53,41,.85))} }

/* garden shop gallery (real Ruibal's photos) */
.shop-gallery{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}
.shop-gallery figure{margin:0;border-radius:14px;overflow:hidden;border:1px solid var(--line);box-shadow:var(--shadow);background:#fff;transition:.25s}
.shop-gallery figure:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg)}
.shop-gallery img{width:100%;height:230px;object-fit:cover;display:block}
.shop-gallery figcaption{padding:11px 14px;font-weight:600;font-size:.85rem;color:var(--forest)}
@media(max-width:860px){.shop-gallery{grid-template-columns:repeat(2,1fr)}}
@media(max-width:420px){.shop-gallery img{height:180px}}

/* testimonials */
.tgrid{display:grid;grid-template-columns:repeat(2,1fr);gap:22px}
.tcard{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:26px 28px;box-shadow:var(--shadow)}
.tcard .stars{color:var(--gold);letter-spacing:3px;font-size:.9rem;margin-bottom:12px}
.tcard .quote{font-family:var(--serif);font-size:1.12rem;line-height:1.45;color:var(--ink)}
.tcard .who{margin-top:16px;font-weight:700;color:var(--sage-deep);font-size:.9rem}
.tcard .who span{color:var(--muted);font-weight:500}
@media(max-width:760px){ .tgrid{grid-template-columns:1fr} }

.cta-band{background:var(--forest);color:#f2efe4;border-radius:var(--radius-lg);padding:clamp(40px,6vw,72px);text-align:center;
  background-image:radial-gradient(300px 300px at 10% 120%,rgba(118,146,91,.3),transparent 70%),radial-gradient(280px 280px at 95% -20%,rgba(224,169,46,.18),transparent 70%)}
.cta-band.cta-photo{background-image:linear-gradient(rgba(13,53,41,.86),rgba(13,53,41,.74)), url('../assets/photos/shrub-lot.jpg');background-size:cover;background-position:center}
.cta-band h2{color:#fff;margin-bottom:14px}
.cta-band p{color:#cdd9c8;max-width:54ch;margin:0 auto 26px}
.cta-band .row{display:flex;gap:14px;justify-content:center;flex-wrap:wrap}

/* ============================================================ COLOR CHART */
.season-tabs{display:flex;gap:10px;justify-content:center;margin-bottom:34px}
.season-tabs button{background:#fff;border:1.5px solid var(--line);border-radius:999px;padding:.8em 1.7em;font-weight:700;color:var(--muted);transition:.2s}
.season-tabs button.on{background:var(--forest);color:#fff;border-color:var(--forest)}
.chart-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.chart-page{border-radius:14px;overflow:hidden;border:1px solid var(--line);box-shadow:var(--shadow);cursor:zoom-in;background:#fff;transition:.25s;position:relative}
.chart-page:hover{transform:translateY(-5px);box-shadow:var(--shadow-lg)}
.chart-page img{width:100%;display:block}
.chart-page .pg{position:absolute;bottom:10px;left:10px;background:rgba(13,53,41,.82);color:#fff;font-size:.72rem;font-weight:700;padding:.3em .7em;border-radius:999px}
.lightbox{position:fixed;inset:0;background:rgba(8,18,13,.92);z-index:300;display:none;align-items:center;justify-content:center;padding:24px;flex-direction:column;gap:16px}
.lightbox.show{display:flex}
.lightbox img{max-width:94vw;max-height:82vh;border-radius:8px;box-shadow:var(--shadow-lg)}
.lightbox .lb-nav{display:flex;gap:14px;align-items:center;color:#fff}
.lightbox .lb-nav button{background:rgba(255,255,255,.14);border:none;color:#fff;width:46px;height:46px;border-radius:50%;font-size:1.3rem}
.lightbox .lb-close{position:absolute;top:20px;right:24px;background:rgba(255,255,255,.14);border:none;color:#fff;width:46px;height:46px;border-radius:50%;font-size:1.4rem}

/* ============================================================ LOCATIONS */
.loc-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:22px}
.loc{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:26px;box-shadow:var(--shadow);display:flex;gap:18px}
.loc .pin{flex:0 0 auto;width:46px;height:46px;border-radius:12px;background:var(--sage-soft);display:grid;place-items:center}
.loc .pin svg{width:24px;height:24px;color:var(--sage-deep)}
.loc h3{font-size:1.2rem;margin-bottom:6px}
.loc p{margin:2px 0;color:var(--muted);font-size:.92rem}
.loc .phones{margin-top:8px;font-size:.86rem}
.loc .phones b{color:var(--forest)}

/* ============================================================ TIMELINE */
.timeline{position:relative;margin-top:40px;padding-left:0}
.timeline .ev{display:grid;grid-template-columns:120px 1fr;gap:24px;padding:18px 0;border-top:1px solid var(--line)}
.timeline .ev .yr{font-family:var(--serif);font-size:1.7rem;color:var(--sage-deep);font-weight:400}
.timeline .ev p{margin:0;color:var(--muted)}
.timeline .ev h3{font-size:1.15rem;margin-bottom:4px}

/* ============================================================ FOOTER */
footer.site{background:var(--forest);color:#bccdb8;margin-top:60px;padding-bottom:118px}
footer.site .top{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:34px;padding:64px 0 44px}
footer.site h5{color:#fff;font-size:.78rem;text-transform:uppercase;letter-spacing:.14em;margin:0 0 16px}
footer.site a{display:block;padding:4px 0;color:#bccdb8;font-size:.92rem}
footer.site a:hover{color:#fff}
footer.site .flogo{height:46px;margin-bottom:16px}
footer.site .fdesc{font-size:.92rem;color:#a9bca5;max-width:34ch}
footer.site .social{display:flex;gap:10px;margin-top:16px}
footer.site .social a{width:40px;height:40px;border-radius:50%;background:rgba(255,255,255,.1);display:grid;place-items:center}
footer.site .social a:hover{background:var(--sage)}
footer.site .social svg{width:20px;height:20px}
footer.site .bottom{border-top:1px solid rgba(255,255,255,.12);padding:18px 0;display:flex;justify-content:space-between;font-size:.82rem;color:#8ea389;flex-wrap:wrap;gap:10px}

/* ============================================================ PAGE HEADER */
.pagehead{background:var(--forest);color:#f1efe4;padding:clamp(48px,7vw,90px) 0 clamp(40px,6vw,70px);
  background-image:radial-gradient(280px 280px at 88% -10%,rgba(224,169,46,.16),transparent 70%),radial-gradient(260px 260px at 4% 120%,rgba(118,146,91,.3),transparent 70%)}
.pagehead .eyebrow{color:var(--gold)}
.pagehead h1{color:#fff;font-size:clamp(2.4rem,5vw,3.8rem);margin:12px 0}
.pagehead p{color:#cdd9c8;max-width:60ch;font-size:1.1rem}
.crumbs{font-size:.85rem;color:#a9bca5;margin-bottom:10px}
.crumbs a:hover{color:#fff}

/* ============================================================ RESPONSIVE */
@media(max-width:1080px){
  .grid.cols-4{grid-template-columns:repeat(3,1fr)}
  .hero .wrap{grid-template-columns:1fr;gap:30px}
  .hero-art{height:380px}
  footer.site .top{grid-template-columns:1fr 1fr}
}
@media(max-width:860px){
  nav.main,.header-cta .btn span{display:none}
  .menu-toggle{display:grid;place-items:center}
  .catalog{grid-template-columns:1fr}
  .filters{position:fixed;inset:0;z-index:210;max-height:100vh;border-radius:0;transform:translateX(-100%);transition:.3s}
  .filters.open{transform:none}
  .filter-toggle{display:inline-flex}
  .split,.searchstrip .card{grid-template-columns:1fr}
  .profile{grid-template-columns:1fr}
  .feature-row,.chart-grid,.loc-grid{grid-template-columns:1fr}
  .grid.cols-4,.grid.cols-3{grid-template-columns:repeat(2,1fr)}
  .spec-grid{grid-template-columns:1fr}
}
@media(max-width:520px){
  .grid.cols-4,.grid.cols-3{grid-template-columns:1fr 1fr}
  .timeline .ev{grid-template-columns:70px 1fr;gap:14px}
  .hero .stats{gap:20px}
}
/* grid items must be allowed to shrink, or wide content forces horizontal overflow */
.grid>*{min-width:0}
.plant-card{min-width:0}
@media(max-width:600px){
  .plant-card .acts{flex-direction:column}   /* stack buttons so narrow cards don't overflow */
  .plant-card .body h3{font-size:1rem}
  .catalog-main .cat-toolbar .toolbar-right{width:100%;flex-wrap:wrap}
  .catalog-main .searchbox{min-width:0;flex:1 1 160px}
  .catalog-main .toolbar-right select{flex:1 1 auto}
}
/* ============================================================ MOTION
   Scroll-reveal as content enters + gentle ambient hero motion.
   Replaces the cursor-sway. All disabled for reduced-motion. */
.has-reveal .reveal{opacity:0;transform:translateY(22px);transition:opacity .7s ease, transform .8s cubic-bezier(.2,.75,.25,1)}
.has-reveal .reveal.in{opacity:1;transform:none}
@media (prefers-reduced-motion:no-preference){
  .hero-art .tile img{animation:kenburns 20s ease-in-out infinite alternate}
  .hero-art .t1{animation:floaty 7.5s ease-in-out infinite}
  .hero-art .t2{animation:floaty 9.5s ease-in-out infinite reverse}
  .hero-art .t3{animation:floaty 8.5s ease-in-out infinite .6s}
  .brand .emblem{animation:spin-slow 26s linear infinite}
}
@media (prefers-reduced-motion:reduce){ .has-reveal .reveal{opacity:1;transform:none} }
@keyframes kenburns{from{transform:scale(1)}to{transform:scale(1.09)}}
@keyframes floaty{0%,100%{transform:translateY(0)}50%{transform:translateY(-14px)}}
@keyframes spin-slow{to{transform:rotate(360deg)}}

.mobile-drawer{display:none;flex-direction:column;padding:8px 16px 18px;border-top:1px solid var(--line);background:var(--paper)}
.mobile-drawer a{padding:.7em 0;font-weight:600;border-bottom:1px solid var(--line)}
body.nav-open .mobile-drawer{display:flex}
