:root{
  /* Ecuagarden corporate brand: black + magenta (#E80088) + silver.
     Legacy var names kept (green-*) and remapped to the real palette so the
     whole variable-driven UI recolors at once. */
  --green:#E80088;        /* primary magenta */
  --green-mid:#F4309E;    /* lighter magenta — hover / accents */
  --green-dark:#C2006F;   /* deeper magenta — links / button text on light */
  --green-ink:#17141A;    /* near-black — headings, footer, hero base */
  --tint:#FCE7F2;         /* light magenta tint */
  --tint-border:#F6C2DD;
  --cream:#F7F4F1;        /* soft off-white — text on dark / light buttons */
  --cream-deep:#ECE4E9;
  --ink:#1E1B20;          /* body text near-black */
  --muted:#6E6A72;        /* muted gray */
  --line:#E9E4E8;         /* light divider */
  --white:#ffffff;
  --silver:#9C99A3;       /* metallic silver — the "Ecua" wordmark */
  --silver-light:#C8C5CE;
  --gold:#B0006A;         /* repurposed: magenta-dark accent for pending labels */
  --radius:14px;
  --radius-sm:8px;
  --radius-lg:20px;
  --maxw:1140px;
  --shadow:0 1px 2px rgba(23,20,26,.05),0 8px 30px rgba(23,20,26,.07);
}
/* two-tone wordmark: "Ecua" silver + "garden" magenta */
.brand-eg .eg-1{color:var(--silver)}
.brand-eg .eg-2{color:var(--green)}
.footer .brand-eg .eg-1{color:var(--silver-light)}
.footer .brand-eg .eg-2{color:var(--green-mid)}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:'Inter',system-ui,-apple-system,Segoe UI,Roboto,sans-serif;
  color:var(--ink);
  background:var(--white);
  line-height:1.65;
  -webkit-font-smoothing:antialiased;
}
img{max-width:100%;display:block}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 24px}
.wrap-narrow{max-width:820px;margin:0 auto;padding:0 24px}
h1,h2,h3,h4{line-height:1.18;font-weight:600;letter-spacing:-.012em}
h1{font-size:2.9rem;color:var(--green-ink)}
h2{font-size:2rem;color:var(--green-ink)}
h3{font-size:1.08rem}
h4{font-size:.95rem}
p{overflow-wrap:break-word}
a{color:var(--green-dark);text-decoration:none}
a:hover{text-decoration:underline}
.serif{font-family:'Cormorant Garamond',serif;font-style:italic;font-weight:600}

/* ---------- nav ---------- */
.nav{
  position:sticky;top:0;z-index:50;
  display:flex;align-items:center;justify-content:space-between;
  padding:14px 24px;background:rgba(255,255,255,.92);
  backdrop-filter:saturate(160%) blur(8px);
  border-bottom:1px solid var(--line);
}
.brand{display:flex;align-items:center;gap:10px}
.brand:hover{text-decoration:none}
.brand-mark{display:flex}
.brand-name{display:flex;flex-direction:column;line-height:1}
.brand-eg{font-size:1.12rem;font-weight:600;color:var(--green);letter-spacing:.01em}
.brand-sub{font-family:'Cormorant Garamond',serif;font-style:italic;font-weight:600;font-size:.92rem;color:var(--green-mid);margin-top:2px;letter-spacing:.02em}
.nav-links{display:flex;align-items:center;gap:20px;font-size:.92rem}
.nav-links a{color:var(--muted)}
.nav-links a:hover{color:var(--green-dark);text-decoration:none}
.nav-links a.active{color:var(--green-dark);font-weight:600}
.nav-tools{display:flex;align-items:center;gap:16px}

/* language switcher */
.lang{display:flex;align-items:center;gap:4px;font-size:.82rem;font-weight:500;letter-spacing:.04em}
.lang a{color:var(--muted);padding:2px 4px;border-radius:4px}
.lang a:hover{color:var(--green-dark);text-decoration:none}
.lang a.on{color:var(--green-dark);font-weight:600}
.lang .sep{color:var(--line)}

/* mobile menu (CSS-only) */
.nav-toggle{display:none}
.nav-burger{display:none;cursor:pointer;border:1px solid var(--line);border-radius:8px;padding:7px 9px;background:var(--white);line-height:0}
.nav-burger span{display:block;width:18px;height:2px;background:var(--green-ink);margin:3px 0;border-radius:2px}

/* ---------- buttons ---------- */
.btn{display:inline-block;border-radius:var(--radius-sm);font-weight:500;font-size:.95rem;padding:13px 24px;cursor:pointer;border:1px solid transparent;transition:transform .05s ease,opacity .15s ease,background .15s ease;text-align:center}
.btn:hover{text-decoration:none;opacity:.92}
.btn:active{transform:scale(.985)}
.btn-sm{padding:9px 16px;font-size:.9rem}
.btn-solid{background:var(--green);color:var(--cream)}
.btn-cream{background:var(--cream);color:var(--green-dark)}
.btn-ghost{background:transparent;color:var(--cream);border-color:rgba(255,255,255,.45)}
.btn-outline{background:transparent;color:var(--green-dark);border-color:var(--tint-border)}
.btn-outline:hover{background:var(--tint)}

/* ---------- hero ---------- */
.hero{position:relative;background:var(--green-ink);color:var(--cream);padding:96px 0 86px;overflow:hidden}
.hero::before{content:"";position:absolute;inset:0;
  background:
    radial-gradient(120% 90% at 80% -10%,rgba(232,0,136,.45),transparent 60%),
    linear-gradient(160deg,#241f29 0%,#17141A 55%,#100e13 100%);
  z-index:0}
.hero .wrap{position:relative;z-index:1}
.eyebrow{font-size:.78rem;letter-spacing:.16em;text-transform:uppercase;color:#F0A8CE;margin-bottom:18px;font-weight:500}
.hero h1{font-size:3.1rem;color:#FBFAF3;max-width:760px;letter-spacing:-.02em}
.hero h1 .accent{color:#FF6FB6}
.lede{font-size:1.22rem;color:#E7E0E6;max-width:620px;margin:22px 0 30px}
.hero-cta{display:flex;gap:14px;flex-wrap:wrap}
.hero-meta{margin-top:34px;display:flex;gap:26px;flex-wrap:wrap;font-size:.9rem;color:#F0A8CE}
.hero-meta span{display:flex;align-items:center;gap:7px}

/* page hero (inner pages, lighter) */
.pagehero{background:var(--tint);border-bottom:1px solid var(--tint-border);padding:60px 0 54px}
.pagehero .eyebrow{color:var(--green-mid)}
.pagehero h1{font-size:2.6rem;max-width:780px}
.pagehero p{color:var(--muted);max-width:640px;margin-top:16px;font-size:1.12rem}
.crumb{font-size:.82rem;color:var(--muted);margin-bottom:14px;letter-spacing:.02em}
.crumb a{color:var(--green-dark)}

/* ---------- stats ---------- */
.stats{display:grid;grid-template-columns:repeat(4,1fr);border-bottom:1px solid var(--line);background:var(--white)}
.stat{padding:30px 16px;text-align:center;border-right:1px solid var(--line)}
.stat:last-child{border-right:none}
.stat-num{display:block;font-size:2.1rem;font-weight:600;color:var(--green)}
.stat-lbl{display:block;font-size:.84rem;color:var(--muted);margin-top:3px;line-height:1.35}

/* ---------- sections ---------- */
.section{padding:74px 0}
.section-tight{padding:52px 0}
.section-alt{background:#FAFBF7;border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.section-cream{background:var(--cream);border-top:1px solid var(--cream-deep);border-bottom:1px solid var(--cream-deep)}
.section-head{max-width:680px}
.section-head.center{margin:0 auto;text-align:center}
.section-sub{color:var(--muted);max-width:640px;margin:12px 0 36px;font-size:1.08rem}
.section-head.center .section-sub{margin-left:auto;margin-right:auto}
.kicker{font-size:.76rem;letter-spacing:.16em;text-transform:uppercase;color:var(--green-mid);font-weight:600;margin-bottom:12px}

/* ---------- image placeholders ---------- */
.ph{position:relative;background:linear-gradient(135deg,#efe7ec,#dcc9d6);border-radius:var(--radius);overflow:hidden;display:flex;align-items:center;justify-content:center;color:#8a6378;min-height:200px}
.ph::after{content:attr(data-label);position:absolute;bottom:10px;left:12px;font-size:.7rem;letter-spacing:.08em;text-transform:uppercase;color:rgba(30,27,32,.42);font-weight:600}
.ph svg{width:46px;height:46px;opacity:.5}
.ph-tall{min-height:340px}
.ph-wide{aspect-ratio:16/10}
.ph-andes{background:linear-gradient(180deg,#bcd0d8 0%,#cdd9c2 48%,#9fb37f 100%)}
.ph-warm{background:linear-gradient(135deg,#e7d9c4,#d8c19c)}

/* color-keyed variety placeholders (so the gallery reads even without photos) */
.ph-red{background:radial-gradient(circle at 50% 42%,#c0455a 0%,#9b3147 60%,#7a2438 100%)}
.ph-white{background:radial-gradient(circle at 50% 42%,#fbfaf6 0%,#e9eadf 60%,#d7dccb 100%)}
.ph-pink{background:radial-gradient(circle at 50% 42%,#e89bb0 0%,#d97e98 60%,#c46781 100%)}
.ph-yellow{background:radial-gradient(circle at 50% 42%,#f1cf6a 0%,#e6b94c 60%,#cf9f34 100%)}
.ph-orange{background:radial-gradient(circle at 50% 42%,#ef9f5e 0%,#e2823c 60%,#c96a26 100%)}
.ph-lavender{background:radial-gradient(circle at 50% 42%,#b9a6d6 0%,#a48cc7 60%,#8b72b3 100%)}
.ph-bicolor{background:radial-gradient(circle at 50% 42%,#f0c66a 0%,#e08a6a 55%,#c95d6e 100%)}
.ph-green{background:radial-gradient(circle at 50% 42%,#bcd49a 0%,#9fc079 60%,#83a85f 100%)}

/* ---------- generic card grids ---------- */
.cards-3{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.cards-4{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}
.cards-2{display:grid;grid-template-columns:repeat(2,1fr);gap:24px}
.card{background:#FAFBF7;border:1px solid var(--line);border-radius:var(--radius);padding:28px 24px}
.card .ico{font-size:1.7rem;display:block;margin-bottom:14px}
.card h3{color:var(--green-ink);margin-bottom:7px}
.card p{color:var(--muted);font-size:.96rem}

/* split: text + image */
.split{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:center}
.split.rev .split-media{order:-1}
.split-media .ph{min-height:360px}
.split-body h2{margin-bottom:14px}
.split-body p{color:var(--muted);margin-bottom:14px}

/* feature list */
.flist{list-style:none;margin-top:8px}
.flist li{padding:12px 0 12px 28px;position:relative;color:var(--muted);border-bottom:1px solid var(--line)}
.flist li:last-child{border-bottom:none}
.flist li::before{content:"";position:absolute;left:0;top:19px;width:8px;height:8px;border-radius:50%;background:var(--green-mid)}
.flist strong{color:var(--ink);font-weight:600}

/* checks */
.checks{list-style:none;display:grid;grid-template-columns:repeat(2,1fr);gap:12px 24px}
.checks li{position:relative;padding-left:28px;color:var(--green-ink);font-size:.98rem}
.checks li::before{content:"✓";position:absolute;left:0;top:0;color:var(--green-mid);font-weight:700}

/* quote/pull */
.pull{background:var(--green);color:var(--cream);border-radius:var(--radius);padding:34px 30px}
.pull .quote{font-family:'Cormorant Garamond',serif;font-style:italic;font-size:1.5rem;line-height:1.4;color:#FBFAF3}
.pull .quote-by{margin-top:16px;font-size:.85rem;color:#FBD3E8}

/* ---------- band / cta ---------- */
.band{background:var(--tint);border-top:1px solid var(--tint-border);border-bottom:1px solid var(--tint-border);padding:54px 0}
.band-flex{display:flex;align-items:center;justify-content:space-between;gap:30px;flex-wrap:wrap}
.band h2{color:var(--green-dark)}
.band p{color:var(--green-ink);margin-top:6px;max-width:560px}
.cta-dark{background:var(--green-ink);color:var(--cream)}
.cta-dark h2{color:#FBFAF3}
.cta-dark p{color:#F0A8CE}

/* ---------- catalog / varieties ---------- */
.catalog-controls{display:flex;flex-wrap:wrap;gap:22px;align-items:flex-end;padding:24px 0 8px;border-bottom:1px solid var(--line);margin-bottom:30px}
.filter-group{display:flex;flex-direction:column;gap:9px}
.filter-label{font-size:.72rem;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);font-weight:600}
.chips{display:flex;flex-wrap:wrap;gap:8px}
.chip{font:inherit;font-size:.86rem;padding:7px 14px;border-radius:999px;border:1px solid var(--tint-border);background:var(--white);color:var(--green-ink);cursor:pointer;transition:all .12s ease;display:inline-flex;align-items:center;gap:7px}
.chip:hover{border-color:var(--green-mid)}
.chip.active{background:var(--green);color:var(--cream);border-color:var(--green)}
.chip .dot{width:11px;height:11px;border-radius:50%;border:1px solid rgba(0,0,0,.12)}
.catalog-count{margin-left:auto;font-size:.88rem;color:var(--muted)}
.select{font:inherit;font-size:.9rem;padding:9px 12px;border:1px solid var(--tint-border);border-radius:var(--radius-sm);background:var(--white);color:var(--green-ink);cursor:pointer}

.variety-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px}
.variety{border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;background:var(--white);box-shadow:var(--shadow);transition:transform .15s ease,box-shadow .15s ease;cursor:pointer}
.variety:hover{transform:translateY(-3px);box-shadow:0 10px 34px rgba(47,61,36,.12)}
.variety .ph{min-height:200px;border-radius:0}
.variety-body{padding:16px 16px 18px}
.variety-name{font-size:1.02rem;font-weight:600;color:var(--green-ink);display:flex;align-items:center;justify-content:space-between;gap:8px}
.variety-name .dot{width:13px;height:13px;border-radius:50%;flex:none;border:1px solid rgba(0,0,0,.12)}
.variety-meta{margin-top:8px;display:flex;flex-wrap:wrap;gap:6px}
.tag{font-size:.74rem;padding:3px 9px;border-radius:999px;background:var(--tint);color:var(--green-dark);border:1px solid var(--tint-border)}
.variety-specs{margin-top:12px;font-size:.84rem;color:var(--muted);display:grid;grid-template-columns:1fr 1fr;gap:5px}
.variety-specs b{color:var(--ink);font-weight:600;display:block;font-size:.78rem}
.no-results{text-align:center;color:var(--muted);padding:50px 0;display:none}

/* color dots */
.c-red{background:#b1394e}.c-white{background:#f3f1e8}.c-pink{background:#dd86a0}
.c-yellow{background:#e8bd50}.c-orange{background:#e2823c}.c-lavender{background:#a48cc7}
.c-bicolor{background:linear-gradient(90deg,#e8bd50 50%,#c95d6e 50%)}.c-green{background:#9fc079}

/* ---------- modal (variety detail) ---------- */
.modal{position:fixed;inset:0;z-index:100;display:none;align-items:center;justify-content:center;padding:24px;background:rgba(38,49,28,.55);backdrop-filter:blur(3px)}
.modal.open{display:flex}
.modal-card{position:relative;background:var(--white);border-radius:var(--radius-lg);max-width:680px;width:100%;max-height:88vh;overflow:auto;box-shadow:0 30px 80px rgba(0,0,0,.3)}
.modal-media .ph{min-height:280px;border-radius:0}
.modal-body{padding:28px 30px 32px}
.modal-close{position:absolute;top:18px;right:22px;background:rgba(255,255,255,.9);border:none;width:38px;height:38px;border-radius:50%;font-size:1.2rem;cursor:pointer;color:var(--green-ink);line-height:1;z-index:2}
.modal-body h3{font-size:1.7rem;color:var(--green-ink)}
.modal-specs{display:grid;grid-template-columns:repeat(2,1fr);gap:14px;margin:20px 0}
.modal-spec{background:#FAFBF7;border:1px solid var(--line);border-radius:var(--radius-sm);padding:12px 14px}
.modal-spec b{display:block;font-size:.72rem;letter-spacing:.06em;text-transform:uppercase;color:var(--muted);font-weight:600;margin-bottom:3px}
.modal-spec span{color:var(--ink);font-weight:500}

/* ---------- timeline (farm) ---------- */
.timeline{position:relative;margin-top:18px;padding-left:30px}
.timeline::before{content:"";position:absolute;left:8px;top:6px;bottom:6px;width:2px;background:var(--tint-border)}
.tl-item{position:relative;padding:0 0 30px 24px}
.tl-item::before{content:"";position:absolute;left:-30px;top:4px;width:16px;height:16px;border-radius:50%;background:var(--white);border:3px solid var(--green-mid)}
.tl-year{font-size:.82rem;letter-spacing:.08em;font-weight:700;color:var(--green);text-transform:uppercase}
.tl-item h3{margin:4px 0 5px;color:var(--green-ink)}
.tl-item p{color:var(--muted);font-size:.97rem}

/* ---------- certifications ---------- */
.cert-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}
.cert{border:1px solid var(--line);border-radius:var(--radius);padding:24px 20px;text-align:center;background:var(--white)}
.cert-badge{width:64px;height:64px;border-radius:50%;background:var(--tint);border:1px solid var(--tint-border);display:flex;align-items:center;justify-content:center;margin:0 auto 14px;font-size:1.6rem}
.cert h3{color:var(--green-ink);font-size:1rem}
.cert p{color:var(--muted);font-size:.86rem;margin-top:5px}
.cert .pend{font-size:.7rem;color:var(--gold);letter-spacing:.06em;text-transform:uppercase;font-weight:600;margin-top:8px;display:block}

/* ---------- logistics ---------- */
.flow{display:grid;grid-template-columns:repeat(4,1fr);gap:0;margin-top:10px}
.flow-step{position:relative;padding:24px 18px;text-align:center;border:1px solid var(--line);border-right:none;background:var(--white)}
.flow-step:last-child{border-right:1px solid var(--line);border-radius:0 var(--radius) var(--radius) 0}
.flow-step:first-child{border-radius:var(--radius) 0 0 var(--radius)}
.flow-step .n{width:34px;height:34px;border-radius:50%;background:var(--green);color:var(--cream);display:flex;align-items:center;justify-content:center;font-weight:600;margin:0 auto 12px}
.flow-step h3{color:var(--green-ink);font-size:1rem;margin-bottom:5px}
.flow-step p{color:var(--muted);font-size:.88rem}
.hub-callout{display:flex;gap:18px;align-items:flex-start;background:var(--tint);border:1px solid var(--tint-border);border-radius:var(--radius);padding:24px 26px;margin-top:8px}
.hub-callout .flag{font-size:1.8rem;line-height:1}
.hub-callout h3{color:var(--green-dark);margin-bottom:6px}
.hub-callout p{color:var(--green-ink);font-size:.97rem}
.region-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-top:6px}
.region{border:1px solid var(--line);border-radius:var(--radius);padding:20px 22px;background:#FAFBF7}
.region h3{color:var(--green-ink);font-size:1rem;display:flex;gap:8px;align-items:center}
.region p{color:var(--muted);font-size:.9rem;margin-top:6px}

/* ---------- forms ---------- */
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:44px;align-items:start}
.contact-list{list-style:none;margin-top:22px}
.contact-list li{padding:9px 0;color:var(--muted);display:flex;gap:11px;align-items:flex-start}
.contact-list li span.ico{flex:none}
.std-form{display:flex;flex-direction:column;gap:15px;background:#FAFBF7;border:1px solid var(--line);border-radius:var(--radius);padding:30px}
.std-form h3{color:var(--green-ink);margin-bottom:2px}
.std-form label{display:flex;flex-direction:column;font-size:.84rem;color:var(--muted);gap:6px;font-weight:500}
.std-form input,.std-form textarea,.std-form select{font:inherit;color:var(--ink);padding:12px 13px;border:1px solid var(--line);border-radius:var(--radius-sm);background:var(--white)}
.std-form input:focus,.std-form textarea:focus,.std-form select:focus{outline:none;border-color:var(--green-mid);box-shadow:0 0 0 3px rgba(232,0,136,.18)}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:13px}
.form-row-3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:13px}
.std-form .btn{margin-top:6px}
.form-note{font-size:.8rem;color:var(--muted);text-align:center}
.req{color:var(--green-mid)}

/* download card */
.dl-card{display:flex;gap:18px;align-items:center;background:var(--tint);border:1px solid var(--tint-border);border-radius:var(--radius);padding:22px 24px}
.dl-card .ico{font-size:2rem}
.dl-card h3{color:var(--green-dark);margin-bottom:3px}
.dl-card p{color:var(--green-ink);font-size:.9rem}
.dl-card .btn{margin-left:auto;flex:none}

/* ---------- footer ---------- */
.footer{background:var(--green-ink);color:#C7C4CD;padding:56px 0 34px}
.footer-grid{display:grid;grid-template-columns:1.5fr 1fr 1fr 1fr;gap:34px}
.footer .brand-eg{color:#E6E3EA}
.footer .brand-sub{color:#FF6FB6}
.footer-about{font-size:.92rem;color:#9C99A3;margin-top:14px;max-width:300px}
.footer h4{color:#E6E3EA;font-size:.82rem;letter-spacing:.08em;text-transform:uppercase;margin-bottom:14px}
.footer-col a{display:block;color:#C2BFC8;font-size:.92rem;padding:5px 0}
.footer-col a:hover{color:#fff;text-decoration:none}
.footer-bottom{border-top:1px solid #2c2832;margin-top:40px;padding-top:22px;display:flex;justify-content:space-between;gap:16px;flex-wrap:wrap}
.footer-tag{font-size:.92rem;color:#C2BFC8}
.footer-legal{font-size:.8rem;color:#807D87}

/* ---------- thank you ---------- */
.ty{min-height:62vh;display:flex;align-items:center;justify-content:center;text-align:center;padding:60px 24px}
.ty .ico{font-size:3rem;margin-bottom:18px}
.ty h1{font-size:2.2rem;margin-bottom:12px}
.ty p{color:var(--muted);max-width:480px;margin:0 auto 26px}

/* ---------- responsive ---------- */
@media(max-width:960px){
  .footer-grid{grid-template-columns:1fr 1fr}
  .variety-grid,.cert-grid{grid-template-columns:repeat(3,1fr)}
}
@media(max-width:860px){
  .nav-links{position:fixed;inset:64px 0 auto 0;flex-direction:column;align-items:flex-start;gap:0;background:var(--white);border-bottom:1px solid var(--line);padding:8px 24px 18px;display:none}
  .nav-toggle:checked ~ .nav-links{display:flex}
  .nav-links a:not(.btn){width:100%;padding:12px 0;border-bottom:1px solid var(--line)}
  .nav-links .btn{margin-top:12px}
  .nav-burger{display:block}
  .hero{padding:72px 0 64px}
  .hero h1{font-size:2.2rem}
  .pagehero h1{font-size:2rem}
  h1{font-size:2.2rem}h2{font-size:1.7rem}
  .stats{grid-template-columns:repeat(2,1fr)}
  .stat:nth-child(2){border-right:none}
  .stat:nth-child(1),.stat:nth-child(2){border-bottom:1px solid var(--line)}
  .cards-3,.cards-4,.cards-2{grid-template-columns:1fr 1fr}
  .split,.form-grid{grid-template-columns:1fr;gap:28px}
  .split.rev .split-media{order:0}
  .variety-grid,.cert-grid{grid-template-columns:repeat(2,1fr)}
  .flow{grid-template-columns:1fr 1fr}
  .flow-step{border-right:1px solid var(--line)!important;border-radius:0!important}
  .region-grid{grid-template-columns:1fr}
}
@media(max-width:520px){
  .hero h1{font-size:1.85rem}
  .lede{font-size:1.05rem}
  .cards-3,.cards-4,.cards-2,.checks,.form-row,.form-row-3{grid-template-columns:1fr}
  .variety-grid{grid-template-columns:1fr 1fr}
  .cert-grid{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr}
  .catalog-count{margin-left:0;width:100%}
}

/* ============================================================
   EDITORIAL REFINEMENT — photographic, less boxy (v2)
   ============================================================ */

/* full-bleed photo hero (home). url() resolves from styles.css at root,
   so it works for both / and /es/ pages. */
.hero{
  background:#100e13 url("assets/img/hero-greenhouse.jpg") center 40%/cover no-repeat;
  padding:120px 0 110px;
}
.hero::before{
  background:
    radial-gradient(120% 95% at 78% -10%,rgba(232,0,136,.32),transparent 58%),
    linear-gradient(180deg,rgba(16,14,19,.55) 0%,rgba(16,14,19,.40) 38%,rgba(16,14,19,.86) 100%);
}
.hero h1{font-size:3.4rem;text-shadow:0 2px 30px rgba(0,0,0,.35)}
.lede{text-shadow:0 1px 14px rgba(0,0,0,.3)}
.hero-meta{margin-top:38px;gap:30px}
.hero-meta span{background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.14);padding:8px 14px;border-radius:999px;backdrop-filter:blur(4px)}

/* real images replacing flat placeholders */
.media-img{width:100%;height:100%;min-height:380px;object-fit:cover;border-radius:var(--radius-lg);display:block;box-shadow:0 18px 50px rgba(23,20,26,.16)}
.split-media{position:relative}
.split-media .media-img{min-height:420px}
.media-frame{position:relative;border-radius:var(--radius-lg);overflow:hidden;box-shadow:0 18px 50px rgba(23,20,26,.16)}
.media-frame .media-img{border-radius:0;box-shadow:none}
.media-cap{position:absolute;left:18px;bottom:16px;color:#fff;font-size:.82rem;letter-spacing:.04em;text-shadow:0 1px 10px rgba(0,0,0,.6);background:rgba(16,14,19,.35);padding:5px 12px;border-radius:999px;backdrop-filter:blur(4px)}

/* softer, rounder, shadow-led cards (kill the "boxy robotic" feel) */
.card{background:#fff;border:1px solid #efeaee;border-radius:var(--radius-lg);box-shadow:0 1px 2px rgba(23,20,26,.04),0 10px 34px rgba(23,20,26,.05);padding:30px 26px;transition:transform .16s ease,box-shadow .16s ease}
.card:hover{transform:translateY(-4px);box-shadow:0 16px 44px rgba(23,20,26,.10)}
.card .ico{font-size:1.9rem}
.section{padding:88px 0}
h2{font-size:2.15rem;letter-spacing:-.02em}
.section-sub{font-size:1.1rem}
.split{gap:56px}

/* full-bleed image band for rhythm */
.imgband{position:relative;min-height:440px;display:flex;align-items:center;background-size:cover;background-position:center;color:#fff}
.imgband::before{content:"";position:absolute;inset:0;background:linear-gradient(90deg,rgba(16,14,19,.82) 0%,rgba(16,14,19,.55) 45%,rgba(16,14,19,.15) 100%)}
.imgband .wrap{position:relative;z-index:1}
.imgband h2{color:#fff}
.imgband p{color:#EDE6EA;max-width:520px;margin-top:10px}
.imgband .kicker{color:#FF8FC6}
.band-rose{background-image:linear-gradient(0deg,rgba(0,0,0,.1),rgba(0,0,0,.1)),url("assets/img/rose-macro.jpg")}

/* gentler stat row */
.stat{padding:34px 16px}
.stat-num{font-size:2.3rem;letter-spacing:-.02em}

/* rounder buttons for a softer feel */
.btn{border-radius:999px;padding:14px 28px}
.btn-sm{padding:10px 18px}

/* refine pagehero into a softer banner */
.pagehero{padding:72px 0 64px;background:linear-gradient(180deg,#FCEFF6 0%,#FCE7F2 100%)}

@media(max-width:860px){
  .hero{padding:84px 0 72px}
  .hero h1{font-size:2.3rem}
  .imgband{min-height:360px}
  .imgband::before{background:linear-gradient(180deg,rgba(16,14,19,.55),rgba(16,14,19,.8))}
}

/* variety card real photo */
.variety-photo{height:215px;overflow:hidden;background:#1a1a1f}
.variety-photo img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .4s ease}
.variety:hover .variety-photo img{transform:scale(1.05)}
.modal-media .ph{min-height:300px}

/* photographic page hero (inner pages) */
.pagehero-photo{position:relative;background-color:#17141A;background-size:cover;background-position:center;border-bottom:none}
.pagehero-photo::before{content:"";position:absolute;inset:0;
  background:radial-gradient(120% 95% at 80% -10%,rgba(232,0,136,.30),transparent 58%),
            linear-gradient(180deg,rgba(16,14,19,.50) 0%,rgba(16,14,19,.78) 100%)}
.pagehero-photo .wrap{position:relative;z-index:1}
.pagehero-photo h1{color:#fff;text-shadow:0 2px 24px rgba(0,0,0,.35)}
.pagehero-photo p{color:#EFE6EC}
.pagehero-photo .eyebrow{color:#FF8FC6}
.pagehero-photo .crumb,.pagehero-photo .crumb a{color:#E7D7E2}
