:root {
  --ink: #0a1714;
  --ink-2: #14241f;
  --forest: #0b2d25;
  --forest-2: #0e4635;
  --green: #8cce63;
  --acid: #d7f06c;
  --teal: #24a6ae;
  --sky: #b8e2e4;
  --cream: #f4f0e6;
  --paper: #faf8f2;
  --white: #fff;
  --muted: #66716b;
  --line: rgba(10, 23, 20, .16);
  --serif: "DM Serif Display", Georgia, serif;
  --sans: "Manrope", Arial, sans-serif;
  --radius: 1.5rem;
  --shadow: 0 24px 80px rgba(6, 28, 22, .14);
  --scroll-progress: 0;
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; background: var(--ink); }
body { margin: 0; font-family: var(--sans); color: var(--ink); background: var(--paper); overflow-x: hidden; }
body.menu-open { overflow: hidden; }
img { display: block; max-width: 100%; }
a { color: inherit; text-decoration: none; }
button, input, textarea, select { font: inherit; }
button, a { -webkit-tap-highlight-color: transparent; }
::selection { color: var(--ink); background: var(--acid); }
.sr-only { position: absolute; width: 1px; height: 1px; padding: 0; margin: -1px; overflow: hidden; clip: rect(0,0,0,0); border: 0; }
.skip-link { position: fixed; left: 1rem; top: -4rem; z-index: 9999; padding: .8rem 1rem; color: var(--ink); background: var(--acid); border-radius: .5rem; transition: top .2s; }
.skip-link:focus { top: 1rem; }
.page-noise { position: fixed; inset: 0; z-index: 1000; pointer-events: none; opacity: .035; background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='3' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='.7'/%3E%3C/svg%3E"); }
.fui-webgl { position: fixed; inset: 0; z-index: 1; width: 100vw; height: 100vh; pointer-events: none; opacity: .72; mix-blend-mode: screen; }
.site-header, main, .site-footer { position: relative; z-index: 2; }
.home-page::before, .inner-page::before { content: ""; position: fixed; inset: 0; z-index: 1; pointer-events: none; opacity: .22; background-image: linear-gradient(rgba(215,240,108,.08) 1px, transparent 1px), linear-gradient(90deg, rgba(36,166,174,.08) 1px, transparent 1px); background-size: 68px 68px; transform: translateY(calc(var(--scroll-progress) * -90px)); mask-image: radial-gradient(circle at 70% 20%, #000 0, transparent 64%); }
.home-page::after, .inner-page::after { content: ""; position: fixed; inset: -14vh -10vw; z-index: 1; pointer-events: none; opacity: .2; background-image: radial-gradient(circle at 18% 24%, rgba(215,240,108,.48) 0 2px, transparent 3px), radial-gradient(circle at 68% 32%, rgba(36,166,174,.5) 0 2px, transparent 3px), radial-gradient(circle at 78% 74%, rgba(215,240,108,.42) 0 2px, transparent 3px), linear-gradient(115deg, transparent 0 42%, rgba(36,166,174,.18) 42.2% 42.7%, transparent 43%), linear-gradient(29deg, transparent 0 51%, rgba(215,240,108,.12) 51.2% 51.7%, transparent 52%); background-size: 820px 520px, 760px 560px, 920px 620px, 940px 680px, 880px 620px; filter: drop-shadow(0 0 14px rgba(36,166,174,.26)); transform: translate3d(calc(var(--scroll-progress) * -34px), calc(var(--scroll-progress) * 48px), 0); animation: tacticalMapDrift 18s linear infinite; mask-image: radial-gradient(circle at 50% 42%, #000 0, transparent 72%); }
@keyframes tacticalMapDrift { from { background-position: 0 0, 0 0, 0 0, 0 0, 0 0; } to { background-position: 120px -80px, -90px 100px, 80px 120px, 180px 90px, -160px -60px; } }
.cursor-orbit { position: fixed; top: 0; left: 0; z-index: 999; width: 40px; height: 40px; margin: -20px 0 0 -20px; border: 1px solid rgba(140, 206, 99, .65); border-radius: 50%; pointer-events: none; transition: width .25s, height .25s, margin .25s, background .25s; transform: translate3d(-100px, -100px, 0); mix-blend-mode: difference; }
.cursor-orbit span { position: absolute; left: 50%; top: 50%; width: 4px; height: 4px; transform: translate(-50%, -50%); border-radius: 50%; background: var(--white); }
.cursor-orbit.is-hovering { width: 64px; height: 64px; margin: -32px 0 0 -32px; background: rgba(255,255,255,.08); }

.site-header { position: fixed; top: 0; left: 0; right: 0; z-index: 100; display: flex; align-items: center; justify-content: space-between; min-height: 88px; padding: 1rem 4vw; color: var(--white); transition: background .35s, min-height .35s, border-color .35s, box-shadow .35s; border-bottom: 1px solid transparent; }
.site-header.is-scrolled, .inner-page .site-header { min-height: 70px; background: rgba(7, 27, 23, .72); backdrop-filter: blur(22px) saturate(150%); border-color: rgba(215,240,108,.14); box-shadow: 0 18px 70px rgba(0,0,0,.22); }
.brand { display: inline-flex; align-items: center; gap: .7rem; position: relative; z-index: 2; }
.brand-mark { display: grid; place-items: center; width: 42px; height: 42px; overflow: visible; background: transparent; }
.brand-mark img { width: 100%; height: 100%; object-fit: contain; filter: drop-shadow(0 4px 12px rgba(0,0,0,.16)); }
.brand-name { font-size: .68rem; line-height: 1.05; font-weight: 800; letter-spacing: .14em; text-transform: uppercase; }
.primary-nav { counter-reset: navquest; display: flex; align-items: center; gap: .45rem; padding: .42rem; border: 1px solid rgba(255,255,255,.1); border-radius: 999px; background: rgba(255,255,255,.055); box-shadow: inset 0 0 0 1px rgba(215,240,108,.05), 0 14px 44px rgba(0,0,0,.12); backdrop-filter: blur(18px); font-size: .68rem; font-weight: 800; letter-spacing: .04em; }
.primary-nav > a:not(.nav-cta) { counter-increment: navquest; position: relative; padding: .72rem .9rem; color: rgba(255,255,255,.76); border-radius: 999px; text-transform: uppercase; }
.primary-nav > a:not(.nav-cta)::before { content: "Q" counter(navquest, decimal-leading-zero); margin-right: .45rem; color: var(--acid); font-size: .52rem; letter-spacing: .12em; }
.primary-nav > a:not(.nav-cta)::after { content: ""; position: absolute; left: 0; right: 100%; bottom: .4rem; height: 1px; background: var(--acid); transition: right .3s; }
.primary-nav > a:hover, .primary-nav > a.is-active { color: var(--white); }
.primary-nav > a:hover::after, .primary-nav > a.is-active::after { right: 0; }
.nav-cta { display: inline-flex; align-items: center; gap: .8rem; padding: .8rem 1.1rem; color: var(--ink); background: linear-gradient(135deg, var(--acid), #fff); border-radius: 999px; box-shadow: 0 0 30px rgba(215,240,108,.22); transition: transform .3s, background .3s; }
.nav-cta:hover { transform: translateY(-2px); background: var(--white); }
.nav-toggle { display: none; color: inherit; background: transparent; border: 0; padding: .6rem; }
.nav-toggle > span:not(.sr-only) { display: block; width: 26px; height: 1px; margin: 6px 0; background: currentColor; transition: transform .3s, opacity .3s; }

.section-pad { padding: clamp(5rem, 10vw, 9rem) 6vw; }
.eyebrow { display: flex; align-items: center; gap: 1rem; margin: 0 0 1.5rem; font-size: .66rem; font-weight: 800; letter-spacing: .18em; text-transform: uppercase; color: rgba(255,255,255,.75); }
.eyebrow-dark { color: var(--forest); }
.eyebrow-line { width: 46px; height: 1px; background: currentColor; opacity: .55; }
.display-title { margin: 0; font-family: var(--serif); font-size: clamp(3.5rem, 7.5vw, 8.8rem); line-height: .87; letter-spacing: -.04em; font-weight: 400; }
.display-title span { color: var(--forest-2); font-style: italic; }
.display-title.light { color: var(--white); }
.display-title.light span { color: var(--green); }
.section-kicker { display: flex; justify-content: space-between; gap: 1rem; padding-bottom: 1rem; margin-bottom: clamp(3rem, 6vw, 6rem); color: var(--muted); border-bottom: 1px solid var(--line); font-size: .68rem; font-weight: 800; letter-spacing: .16em; text-transform: uppercase; }
.section-heading { display: grid; grid-template-columns: minmax(0, 1.5fr) minmax(260px, .5fr); gap: 4rem; align-items: end; margin-bottom: clamp(3rem, 7vw, 7rem); }
.section-heading > p { max-width: 35rem; margin: 0 0 .5rem; line-height: 1.8; color: var(--muted); }
.section-heading.light > p { color: rgba(255,255,255,.62); }
.button { display: inline-flex; align-items: center; justify-content: center; gap: 1rem; min-height: 52px; padding: .9rem 1.25rem; border: 1px solid transparent; border-radius: 999px; font-weight: 800; font-size: .76rem; letter-spacing: .02em; cursor: pointer; transition: transform .25s, background .25s, color .25s, border-color .25s; }
.button:hover { transform: translateY(-3px); }
.button-primary { color: var(--ink); background: var(--acid); }
.button-primary:hover { background: var(--white); }
.button-ghost { color: var(--white); border-color: rgba(255,255,255,.35); background: transparent; }
.button-ghost:hover { color: var(--ink); background: var(--white); }
.text-link { display: inline-flex; align-items: center; gap: .8rem; padding: .4rem 0; color: var(--white); border-bottom: 1px solid rgba(255,255,255,.36); font-size: .78rem; font-weight: 700; }
.text-link.dark { color: var(--ink); border-color: var(--line); }
.text-link span { transition: transform .25s; }
.text-link:hover span { transform: translate(3px, -3px); }

/* Home hero */
.hero { position: relative; min-height: 100svh; overflow: hidden; color: var(--white); background: var(--forest); }
.hero-home { display: flex; align-items: flex-end; padding: 11rem 6vw 7rem; }
.hero-backdrop { position: absolute; inset: 0; overflow: hidden; }
.hero-backdrop::after { content: ""; position: absolute; inset: 0; background: radial-gradient(circle at 72% 45%, transparent 0, rgba(5,24,19,.06) 25%, rgba(5,24,19,.65) 70%), linear-gradient(90deg, rgba(5,24,19,.86) 0%, rgba(5,24,19,.2) 68%, rgba(5,24,19,.54) 100%); }
.hero-image { position: absolute; inset: -4%; background: linear-gradient(rgba(0,0,0,.1), rgba(0,0,0,.1)), url("../img/legacy-hero.webp") center / cover; animation: heroDrift 18s ease-in-out infinite alternate; }
@keyframes heroDrift { from { transform: scale(1.02) translate3d(0,0,0); } to { transform: scale(1.1) translate3d(-1.5%, -1%, 0); } }
.route-line { position: absolute; z-index: 2; width: 44vw; height: 44vw; border: 1px solid rgba(215,240,108,.32); border-radius: 50%; transform: rotate(-18deg); }
.route-line::after { content: ""; position: absolute; inset: 11%; border: 1px dashed rgba(255,255,255,.16); border-radius: inherit; }
.route-one { right: -10vw; top: -18vw; }
.route-two { right: 8vw; bottom: -34vw; width: 70vw; height: 70vw; }
.route-dot { position: absolute; z-index: 3; width: 10px; height: 10px; border: 2px solid var(--forest); border-radius: 50%; background: var(--acid); box-shadow: 0 0 0 8px rgba(215,240,108,.18); animation: pulse 2.2s infinite; }
.dot-one { right: 17%; top: 20%; }
.dot-two { right: 34%; bottom: 16%; animation-delay: 1s; }
@keyframes pulse { 50% { box-shadow: 0 0 0 17px rgba(215,240,108,0); } }
.hero-copy { position: relative; z-index: 5; width: 100%; max-width: 1500px; }
.hero-copy, .hero-bottom > * { min-width: 0; }
.hero h1 { max-width: 1200px; margin: 0; font-family: var(--serif); font-size: clamp(4.2rem, 10.2vw, 11rem); line-height: .79; font-weight: 400; letter-spacing: -.055em; text-shadow: 0 8px 50px rgba(0,0,0,.18); }
.hero h1 em { color: var(--acid); font-weight: 400; }
.kinetic-type { text-wrap: balance; }
.kinetic-type span, .kinetic-type em { display: inline-block; animation: kineticRise .9s cubic-bezier(.2,.8,.2,1) both; }
.kinetic-type span:nth-child(2), .kinetic-type em { animation-delay: .12s; }
@keyframes kineticRise { from { opacity: 0; filter: blur(12px); transform: translateY(28px) skewY(3deg); } to { opacity: 1; filter: blur(0); transform: none; } }
.fui-panel { position: relative; display: flex; flex-wrap: wrap; gap: .5rem; width: min(720px, 100%); margin: 1.2rem 0 0; padding: .65rem; color: rgba(221,255,244,.82); border: 1px solid rgba(215,240,108,.24); background: linear-gradient(90deg, rgba(36,166,174,.16), rgba(215,240,108,.07)); clip-path: polygon(0 0, calc(100% - 18px) 0, 100% 18px, 100% 100%, 18px 100%, 0 calc(100% - 18px)); backdrop-filter: blur(14px); }
.fui-panel::before { content: ""; position: absolute; inset: 6px; pointer-events: none; border: 1px solid rgba(36,166,174,.18); }
.fui-panel span { position: relative; padding: .42rem .62rem; color: var(--acid); border: 1px solid rgba(215,240,108,.22); border-radius: 999px; font-size: .52rem; font-weight: 800; letter-spacing: .12em; text-transform: uppercase; }
.quest-menu { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: .75rem; width: min(980px, 100%); margin-top: clamp(1rem, 2vw, 1.6rem); perspective: 1200px; }
.quest-menu a { position: relative; min-height: 132px; padding: 1rem; overflow: hidden; color: var(--white); border: 1px solid rgba(215,240,108,.2); border-radius: 1rem; background: linear-gradient(145deg, rgba(255,255,255,.11), rgba(255,255,255,.035)); box-shadow: inset 0 0 0 1px rgba(36,166,174,.12), 0 22px 70px rgba(0,0,0,.2); backdrop-filter: blur(18px) saturate(150%); transform-style: preserve-3d; transition: transform .35s, border-color .35s, background .35s; }
.quest-menu a::before { content: ""; position: absolute; inset: 0; background: linear-gradient(115deg, transparent 0 28%, rgba(215,240,108,.18) 45%, transparent 62%); transform: translateX(-120%); transition: transform .8s; }
.quest-menu a::after { content: ""; position: absolute; right: .8rem; top: .8rem; width: 46px; height: 46px; border: 1px solid rgba(36,166,174,.45); border-radius: 50%; background: radial-gradient(circle, rgba(215,240,108,.26), transparent 58%); }
.quest-menu a:hover { border-color: rgba(215,240,108,.55); background: linear-gradient(145deg, rgba(36,166,174,.18), rgba(215,240,108,.08)); transform: translateY(-6px) rotateX(3deg); }
.quest-menu a:hover::before { transform: translateX(120%); }
.quest-menu span { display: block; margin-bottom: 1.2rem; color: var(--acid); font-size: .56rem; font-weight: 900; letter-spacing: .14em; text-transform: uppercase; }
.quest-menu strong { display: block; margin-bottom: .45rem; font-family: var(--serif); font-size: clamp(1.55rem, 2vw, 2.15rem); line-height: .95; font-weight: 400; }
.quest-menu small { display: block; max-width: 16rem; color: rgba(255,255,255,.68); line-height: 1.5; font-size: .68rem; }
.hero-bottom { display: grid; grid-template-columns: minmax(260px, .8fr) minmax(280px, 1.4fr); align-items: end; gap: 5vw; max-width: 870px; margin: clamp(2.4rem, 4vw, 4rem) 0 0 auto; }
.hero-intro { margin: 0; line-height: 1.7; color: rgba(255,255,255,.8); font-size: clamp(.95rem, 1.15vw, 1.15rem); }
.hero-actions { display: flex; align-items: center; gap: 1.5rem; flex-wrap: wrap; }
.hero-index { position: absolute; right: 2.4vw; top: 48%; z-index: 4; display: flex; align-items: center; gap: .8rem; transform: rotate(90deg) translateX(50%); transform-origin: right center; font-size: .58rem; letter-spacing: .14em; text-transform: uppercase; color: rgba(255,255,255,.55); }
.scroll-cue { position: absolute; left: 2vw; bottom: 2rem; z-index: 5; display: flex; align-items: center; gap: .8rem; transform: rotate(-90deg) translateY(100%); transform-origin: left bottom; color: rgba(255,255,255,.52); font-size: .55rem; letter-spacing: .18em; text-transform: uppercase; }
.scroll-cue span { display: block; width: 46px; height: 1px; overflow: hidden; background: rgba(255,255,255,.2); }
.scroll-cue span::before { content: ""; display: block; width: 50%; height: 100%; background: var(--acid); animation: scrollCue 2s ease-in-out infinite; }
@keyframes scrollCue { from { transform: translateX(-110%); } to { transform: translateX(210%); } }

/* Manifesto */
.manifesto { background: var(--cream); }
.manifesto-grid { display: grid; grid-template-columns: 1.3fr .7fr; gap: 8vw; align-items: end; }
.manifesto-copy { max-width: 37rem; padding-bottom: .6rem; }
.manifesto-copy p { color: var(--muted); line-height: 1.8; }
.manifesto-copy .lead { color: var(--ink); font-size: clamp(1.2rem, 1.7vw, 1.7rem); line-height: 1.45; }
.manifesto-copy .text-link { margin-top: 1.2rem; }
.signal-board { display: grid; grid-template-columns: repeat(3, 1fr); gap: .9rem; margin-top: clamp(3rem, 6vw, 5rem); }
.signal-board article { position: relative; min-height: 240px; overflow: hidden; padding: 1.4rem; border: 1px solid rgba(10,23,20,.14); border-radius: 1.1rem; background: linear-gradient(145deg, rgba(255,255,255,.72), rgba(255,255,255,.34)); box-shadow: inset 0 0 0 1px rgba(36,166,174,.08), 0 20px 80px rgba(10,23,20,.08); backdrop-filter: blur(18px) saturate(140%); }
.signal-board article::before { content: ""; position: absolute; inset: 0; background: radial-gradient(circle at 75% 10%, rgba(36,166,174,.18), transparent 32%), linear-gradient(135deg, transparent, rgba(215,240,108,.12)); opacity: .9; }
.signal-board article > * { position: relative; }
.signal-board span { display: inline-flex; margin-bottom: 4rem; padding: .42rem .58rem; color: var(--forest-2); border: 1px solid rgba(14,70,53,.18); border-radius: 999px; font-size: .52rem; font-weight: 900; letter-spacing: .12em; text-transform: uppercase; }
.signal-board strong { display: block; margin-bottom: .6rem; font-family: var(--serif); color: var(--ink); font-size: 2rem; line-height: .95; font-weight: 400; }
.signal-board p { margin: 0; color: var(--muted); line-height: 1.65; font-size: .74rem; }
.stat-ribbon { display: grid; grid-template-columns: repeat(3, 1fr); margin-top: clamp(4rem, 8vw, 8rem); border-top: 1px solid var(--line); border-bottom: 1px solid var(--line); }
.stat-ribbon > div { min-height: 150px; padding: 1.8rem; border-right: 1px solid var(--line); }
.stat-ribbon > div:last-child { border-right: 0; }
.stat-ribbon strong { display: block; margin-bottom: 1.6rem; font-family: var(--serif); color: var(--forest-2); font-size: 3rem; font-weight: 400; }
.stat-ribbon span { display: block; max-width: 13rem; color: var(--muted); font-size: .72rem; line-height: 1.5; }
.stat-ribbon span b { display: block; margin-bottom: .35rem; color: var(--ink); font-size: .76rem; }

/* Media proof */
.media-proof { background: var(--paper); }
.media-grid { display: grid; grid-template-columns: 1.1fr .9fr .9fr 1.05fr; gap: 1rem; margin-top: 4rem; }
.media-card { position: relative; min-height: 480px; display: flex; flex-direction: column; justify-content: flex-end; overflow: hidden; padding: 1.8rem; color: var(--white); border-radius: var(--radius); background-position: center; background-size: cover; isolation: isolate; }
.media-card::before { content: ""; position: absolute; inset: 0; z-index: -1; background: linear-gradient(180deg, rgba(4,21,17,.05), rgba(4,21,17,.88)); }
.media-card span { margin-bottom: auto; align-self: flex-start; padding: .45rem .65rem; border: 1px solid rgba(255,255,255,.45); border-radius: 999px; font-size: .54rem; font-weight: 800; letter-spacing: .12em; text-transform: uppercase; }
.media-card h3 { max-width: 16rem; margin: 0; font-family: var(--serif); font-size: clamp(2.4rem, 3.8vw, 4.4rem); line-height: .9; font-weight: 400; }
.media-card p { max-width: 18rem; color: rgba(255,255,255,.7); line-height: 1.65; font-size: .72rem; }
.media-card a { display: inline-flex; margin: 1rem .6rem 0 0; color: var(--acid); font-size: .68rem; font-weight: 800; text-transform: uppercase; letter-spacing: .08em; }
.media-export { background-image: url("../img/legacy-hero.webp"); }
.media-plantasy { background-image: url("../img/plants-owned/calathea-orbifolia.jpg"); }
.media-harvest { background-image: url("https://images.unsplash.com/photo-1596040033229-a9821ebd058d?auto=format&fit=crop&w=1200&q=86"); }
.media-reels { background: radial-gradient(circle at 70% 16%, rgba(215,240,108,.24), transparent 32%), linear-gradient(145deg, #071b17, #123f35); }
.media-reels::after { content: "▶"; position: absolute; right: 1.5rem; top: 1.3rem; display: grid; place-items: center; width: 62px; height: 62px; color: var(--acid); border: 1px solid rgba(215,240,108,.5); border-radius: 50%; font-size: 1rem; }

/* Units */
.units { background: var(--paper); }
.unit-stack { display: grid; gap: 1rem; }
.unit-card { position: relative; overflow: hidden; min-height: min(72vh, 760px); border-radius: 1.8rem; box-shadow: var(--shadow); }
.unit-card:nth-child(2), .unit-card:nth-child(3) { top: auto; }
.unit-card > a { display: grid; grid-template-columns: 1.25fr .75fr; min-height: inherit; }
.unit-visual { position: relative; overflow: hidden; background-position: center; background-size: cover; }
.unit-visual::after { content: ""; position: absolute; inset: 0; background: linear-gradient(110deg, transparent 45%, rgba(7,27,23,.15)); transition: background .5s; }
.unit-card:hover .unit-visual::after { background: linear-gradient(110deg, transparent 25%, rgba(7,27,23,.28)); }
.unit-plantasy .unit-visual { background-image: url("../img/plants-owned/calathea-orbifolia.jpg"); }
.unit-harvest .unit-visual { background-image: url("https://images.unsplash.com/photo-1596040033229-a9821ebd058d?auto=format&fit=crop&w=1600&q=86"); }
.unit-custom .unit-visual { background-image: url("https://images.unsplash.com/photo-1532996122724-e3c354a0b15b?auto=format&fit=crop&w=1600&q=86"); }
.unit-number { position: absolute; left: 2rem; top: 2rem; z-index: 2; display: grid; place-items: center; width: 58px; height: 58px; color: var(--white); border: 1px solid rgba(255,255,255,.6); border-radius: 50%; font-size: .7rem; }
.unit-content { display: flex; flex-direction: column; align-items: flex-start; justify-content: center; padding: clamp(2.5rem, 5vw, 6rem); background: var(--forest); color: var(--white); }
.unit-harvest .unit-content { background: #653e24; }
.unit-custom .unit-content { background: #1a4f55; }
.unit-label { margin-bottom: auto; color: rgba(255,255,255,.66); font-size: .65rem; font-weight: 800; letter-spacing: .12em; text-transform: uppercase; }
.unit-icon { margin-right: .6rem; color: var(--acid); }
.unit-content h3 { margin: 1rem 0 1.2rem; font-family: var(--serif); font-size: clamp(3.6rem, 6vw, 7rem); font-weight: 400; line-height: .85; }
.unit-content p { max-width: 29rem; margin: 0; color: rgba(255,255,255,.7); line-height: 1.7; }
.inline-list { display: flex; gap: .5rem; flex-wrap: wrap; margin: 2rem 0; padding: 0; list-style: none; }
.inline-list li { padding: .45rem .7rem; border: 1px solid rgba(255,255,255,.22); border-radius: 999px; color: rgba(255,255,255,.72); font-size: .61rem; }
.circle-link { display: inline-flex; align-items: center; gap: 1rem; margin-top: auto; font-size: .73rem; font-weight: 800; }
.circle-link b { display: grid; place-items: center; width: 42px; height: 42px; color: var(--ink); background: var(--acid); border-radius: 50%; transition: transform .3s; }
.unit-card:hover .circle-link b { transform: rotate(45deg) scale(1.08); }

/* Why */
.why-us { display: grid; grid-template-columns: .72fr 1.28fr; gap: 7vw; min-height: 100vh; color: var(--white); background: var(--ink); }
.why-visual { position: relative; min-height: 760px; overflow: hidden; border-radius: var(--radius); background: linear-gradient(180deg, rgba(9,35,29,.08), rgba(9,35,29,.82)), url("../img/plants-owned/kimeng-bonsai.jpg") center / cover; }
.vertical-copy { position: absolute; top: 2rem; left: 1.8rem; writing-mode: vertical-rl; font-size: .62rem; letter-spacing: .16em; text-transform: uppercase; color: rgba(255,255,255,.65); }
.stamp { position: absolute; right: 2rem; bottom: 2rem; display: grid; place-items: center; width: 170px; height: 170px; border: 1px solid rgba(255,255,255,.5); border-radius: 50%; backdrop-filter: blur(8px); transform: rotate(-7deg); }
.stamp span { font-family: var(--serif); font-size: 3rem; }
.stamp small { max-width: 100px; text-align: center; color: rgba(255,255,255,.7); font-size: .55rem; letter-spacing: .12em; text-transform: uppercase; }
.why-content { padding: 4rem 0; }
.reason-list { margin-top: 5rem; border-top: 1px solid rgba(255,255,255,.15); }
.reason-list article { display: grid; grid-template-columns: 60px 1fr; gap: 1.5rem; padding: 2rem 0; border-bottom: 1px solid rgba(255,255,255,.15); }
.reason-list article > span { color: var(--green); font-size: .65rem; }
.reason-list h3 { margin: 0 0 .7rem; font-family: var(--serif); font-size: clamp(1.7rem, 2.5vw, 2.6rem); font-weight: 400; }
.reason-list p { max-width: 40rem; margin: 0; color: rgba(255,255,255,.6); line-height: 1.7; }

/* Two-sided empathy */
.two-sides { background: #efe8da; }
.two-sides-head { display: grid; grid-template-columns: 1.3fr .7fr; gap: 7vw; align-items: end; }
.two-sides-head > p { margin: 0 0 .5rem; color: var(--muted); line-height: 1.85; }
.empathy-grid { display: grid; grid-template-columns: 1fr 180px 1fr; gap: 1rem; align-items: stretch; margin-top: clamp(4rem, 8vw, 8rem); }
.empathy-card { position: relative; min-height: 460px; display: flex; flex-direction: column; padding: clamp(2rem, 4vw, 4rem); overflow: hidden; border-radius: var(--radius); }
.empathy-card > span { font-size: .6rem; font-weight: 800; letter-spacing: .14em; text-transform: uppercase; }
.empathy-card h3 { margin: auto 0 1.2rem; font-family: var(--serif); font-size: clamp(2.5rem, 4.5vw, 5rem); line-height: .92; font-weight: 400; }
.empathy-card p { max-width: 35rem; margin: 0 0 2rem; line-height: 1.75; }
.empathy-card small { display: block; padding-top: 1rem; border-top: 1px solid currentColor; opacity: .62; line-height: 1.6; }
.buyer-card { color: var(--white); background: var(--forest); }
.supplier-card { color: var(--ink); background: var(--acid); }
.empathy-bridge { display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 1.1rem; color: var(--forest); border: 1px solid var(--line); border-radius: 999px; }
.empathy-bridge strong { display: grid; place-items: center; width: 82px; height: 82px; color: var(--white); background: var(--forest); border-radius: 50%; font-family: var(--serif); font-size: 2rem; font-weight: 400; }
.empathy-bridge span { font-size: .56rem; font-weight: 800; letter-spacing: .13em; text-transform: uppercase; }

/* Custom needs */
.custom-needs { overflow: hidden; background: var(--cream); }
.custom-head { display: grid; grid-template-columns: 1.35fr .65fr; gap: 5vw; align-items: end; }
.custom-head h2 { margin: 0; font-family: var(--serif); font-size: clamp(3.6rem, 7vw, 8rem); line-height: .88; font-weight: 400; letter-spacing: -.04em; }
.custom-head h2 em { color: var(--forest-2); font-weight: 400; }
.custom-head p { margin: 0 0 .5rem; color: var(--muted); line-height: 1.8; }
.material-marquee { width: 112%; margin: 6rem -6% 4rem; padding: 1.1rem 0; overflow: hidden; color: var(--acid); background: var(--forest); transform: rotate(-1.6deg); }
.marquee-track { display: flex; width: max-content; align-items: center; gap: 2rem; animation: marquee 28s linear infinite; font-family: var(--serif); font-size: 1.45rem; }
.marquee-track i { font-style: normal; font-size: .8rem; }
@keyframes marquee { to { transform: translateX(-50%); } }
.custom-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1rem; }
.material-card { position: relative; min-height: 430px; display: flex; flex-direction: column; justify-content: flex-end; overflow: hidden; padding: 2rem; color: var(--white); border-radius: var(--radius); background-position: center; background-size: cover; }
.material-card::before { content: ""; position: absolute; inset: 0; background: linear-gradient(180deg, rgba(6,25,21,.12), rgba(6,25,21,.92)); }
.material-card > * { position: relative; z-index: 1; }
.material-card.aqua { background-image: url("https://images.unsplash.com/photo-1530053969600-caed2596d242?auto=format&fit=crop&w=1100&q=85"); }
.material-card.resin { background-image: url("https://images.unsplash.com/photo-1523712999610-f77fbcfc3843?auto=format&fit=crop&w=1100&q=85"); }
.material-card.recycle { background-image: url("../img/catalogs/pet-flakes-catalog.png"); }
.material-card > span { align-self: flex-start; margin-bottom: auto; padding: .45rem .65rem; border: 1px solid rgba(255,255,255,.45); border-radius: 999px; font-size: .56rem; letter-spacing: .12em; text-transform: uppercase; }
.material-card h3 { margin: 0 0 .8rem; font-family: var(--serif); font-size: 2.7rem; font-weight: 400; }
.material-card p { margin: 0; color: rgba(255,255,255,.72); line-height: 1.65; font-size: .84rem; }
.mini-cta { display: inline-flex; align-items: center; align-self: flex-start; margin-top: 1.2rem; padding: .62rem .8rem; color: var(--acid); border: 1px solid rgba(215,240,108,.55); border-radius: 999px; font-size: .58rem; font-weight: 800; letter-spacing: .08em; text-transform: uppercase; backdrop-filter: blur(8px); }
.mini-cta:hover { color: var(--ink); background: var(--acid); }
.hud-card { position: relative; }
.hud-card::after { content: ""; position: absolute; inset: .75rem; pointer-events: none; border: 1px solid rgba(215,240,108,.16); border-radius: inherit; opacity: 0; transform: scale(.985); transition: .35s; }
.hud-card:hover::after { opacity: 1; transform: none; }

/* Process */
.process { overflow: hidden; color: var(--white); background: var(--forest); }
.process-scroll { display: flex; gap: 1rem; overflow-x: auto; overscroll-behavior-inline: contain; padding: 0 0 2.5rem; cursor: grab; scrollbar-color: rgba(215,240,108,.65) rgba(255,255,255,.08); scrollbar-width: thin; scroll-padding-inline: 6vw; scroll-snap-type: x mandatory; -webkit-overflow-scrolling: touch; }
.process-scroll.is-dragging { cursor: grabbing; scroll-snap-type: none; user-select: none; }
.process-scroll::-webkit-scrollbar { height: 8px; }
.process-scroll::-webkit-scrollbar-track { background: rgba(255,255,255,.08); border-radius: 999px; }
.process-scroll::-webkit-scrollbar-thumb { background: linear-gradient(90deg, var(--cyan), var(--acid)); border-radius: 999px; }
.process-step { flex: 0 0 min(360px, 80vw); min-height: 390px; padding: 2rem; border: 1px solid rgba(255,255,255,.16); border-radius: var(--radius); scroll-snap-align: start; transition: background .3s, color .3s, transform .3s; }
.process-step:hover, .process-step.is-current { color: var(--ink); background: var(--acid); transform: translateY(-8px); }
.process-step > span { display: grid; place-items: center; width: 45px; height: 45px; margin-bottom: 8rem; border: 1px solid currentColor; border-radius: 50%; font-size: .65rem; }
.process-step h3 { margin: 0 0 .8rem; font-family: var(--serif); font-size: 2.2rem; font-weight: 400; }
.process-step p { margin: 0; color: rgba(255,255,255,.58); line-height: 1.65; font-size: .82rem; }
.process-step:hover p, .process-step.is-current p { color: rgba(10,23,20,.68); }
.process-controls { display: flex; align-items: center; justify-content: space-between; gap: 1rem; margin: -.7rem 0 1.4rem; color: rgba(255,255,255,.54); font-size: .62rem; font-weight: 800; letter-spacing: .1em; text-transform: uppercase; }
.process-button { min-width: 106px; padding: .72rem 1rem; color: var(--white); border: 1px solid rgba(215,240,108,.28); border-radius: 999px; background: rgba(255,255,255,.055); box-shadow: inset 0 0 0 1px rgba(36,166,174,.12); cursor: pointer; font: inherit; transition: background .25s, color .25s, border-color .25s, transform .25s; }
.process-button:hover { color: var(--ink); border-color: var(--acid); background: var(--acid); transform: translateY(-2px); }
.process-progress { height: 2px; overflow: hidden; background: rgba(255,255,255,.15); }
.process-progress span { display: block; width: 12%; height: 100%; background: var(--acid); transition: width .2s; }

/* Impact */
.impact { display: grid; grid-template-columns: .85fr 1.15fr; align-items: center; gap: 4vw; min-height: 850px; background: var(--sky); }
.impact-statement { max-width: 38rem; margin: 2.2rem 0 0; color: rgba(10,23,20,.66); line-height: 1.85; }
.impact-orbit { position: relative; aspect-ratio: 1; width: min(100%, 720px); margin-left: auto; border: 1px solid rgba(10,23,20,.18); border-radius: 50%; animation: orbitFloat 7s ease-in-out infinite alternate; }
.impact-orbit::before, .impact-orbit::after { content: ""; position: absolute; inset: 13%; border: 1px dashed rgba(10,23,20,.2); border-radius: inherit; }
.impact-orbit::after { inset: 30%; border-style: solid; }
@keyframes orbitFloat { to { transform: rotate(2deg) translateY(-6px); } }
.orbit-center { position: absolute; left: 50%; top: 50%; display: grid; place-items: center; width: 32%; aspect-ratio: 1; transform: translate(-50%, -50%); border-radius: 50%; color: var(--white); background: var(--forest); font-family: var(--serif); font-size: clamp(2rem, 5vw, 4rem); }
.orbit-center small { font-family: var(--sans); font-size: .48rem; letter-spacing: .14em; text-transform: uppercase; color: var(--green); }
.orbit-item { position: absolute; max-width: 150px; padding: .75rem 1rem; text-align: center; border: 1px solid rgba(10,23,20,.2); border-radius: 999px; background: rgba(255,255,255,.4); backdrop-filter: blur(5px); font-size: .62rem; font-weight: 800; }
.item-1 { left: 5%; top: 16%; }
.item-2 { right: 5%; top: 22%; }
.item-3 { right: -3%; bottom: 28%; }
.item-4 { left: 7%; bottom: 10%; }
.item-5 { left: -5%; top: 49%; }

/* Contact */
.contact { display: grid; grid-template-columns: .85fr 1.15fr; gap: 8vw; color: var(--white); background: var(--ink); }
.contact-copy { position: relative; align-self: start; }
.contact h2 { margin: 0; font-family: var(--serif); font-size: clamp(4rem, 7vw, 8rem); line-height: .85; font-weight: 400; letter-spacing: -.04em; color: var(--acid); }
.contact-copy > p:not(.eyebrow) { max-width: 34rem; margin-top: 2rem; color: rgba(255,255,255,.62); line-height: 1.75; }
.direct-contact { display: grid; gap: .8rem; margin-top: 3rem; }
.direct-contact a { display: flex; justify-content: space-between; padding: .8rem 0; border-bottom: 1px solid rgba(255,255,255,.18); font-size: .74rem; }
.inquiry-form { display: grid; gap: 1.5rem; padding: clamp(1.8rem, 4vw, 4rem); border: 1px solid rgba(255,255,255,.15); border-radius: var(--radius); background: rgba(255,255,255,.035); }
.form-row { display: grid; grid-template-columns: 1fr 1fr; gap: 1rem; }
.inquiry-form label { display: grid; gap: .65rem; }
.inquiry-form label > span { font-size: .63rem; font-weight: 800; letter-spacing: .08em; color: rgba(255,255,255,.65); text-transform: uppercase; }
.inquiry-form input, .inquiry-form select, .inquiry-form textarea { width: 100%; padding: 1rem 0; color: var(--white); background: transparent; border: 0; border-bottom: 1px solid rgba(255,255,255,.25); border-radius: 0; outline: 0; }
.inquiry-form select option { color: var(--ink); }
.inquiry-form textarea { resize: vertical; }
.inquiry-form input:focus, .inquiry-form select:focus, .inquiry-form textarea:focus { border-color: var(--acid); }
.inquiry-form .button { justify-self: start; margin-top: 1rem; border: 0; }
.form-note { margin: 0; color: rgba(255,255,255,.38); font-size: .6rem; }
.location-card { grid-column: 1 / -1; display: grid; grid-template-columns: .75fr 1.25fr; min-height: 430px; margin-top: 2rem; overflow: hidden; border: 1px solid rgba(255,255,255,.15); border-radius: var(--radius); background: var(--forest); }
.location-copy { display: flex; flex-direction: column; justify-content: center; padding: clamp(2rem, 5vw, 5rem); }
.location-copy h3 { margin: 0 0 1.2rem; font-family: var(--serif); font-size: clamp(2.5rem, 4vw, 4.8rem); line-height: .92; font-weight: 400; }
.location-copy > p:not(.eyebrow) { margin: 0 0 2rem; color: rgba(255,255,255,.62); line-height: 1.75; }
.location-copy .text-link { align-self: flex-start; }
.map-hologram { position: relative; min-height: 430px; display: flex; flex-direction: column; justify-content: flex-end; overflow: hidden; padding: clamp(2rem, 4vw, 4rem); color: var(--white); background: radial-gradient(circle at 55% 42%, rgba(215,240,108,.2), transparent 11%), radial-gradient(circle at 58% 45%, rgba(36,166,174,.28), transparent 18%), linear-gradient(145deg, rgba(5,24,19,.92), rgba(9,58,62,.78)); isolation: isolate; }
.map-hologram::before { content: ""; position: absolute; inset: 0; z-index: -1; background-image: linear-gradient(rgba(215,240,108,.1) 1px, transparent 1px), linear-gradient(90deg, rgba(36,166,174,.13) 1px, transparent 1px); background-size: 46px 46px; transform: perspective(600px) rotateX(62deg) translateY(28%); transform-origin: center bottom; opacity: .8; }
.map-hologram::after { content: ""; position: absolute; inset: 1rem; border: 1px solid rgba(215,240,108,.28); border-radius: calc(var(--radius) - .45rem); pointer-events: none; }
.map-ping { position: absolute; left: 55%; top: 43%; width: 18px; height: 18px; border-radius: 50%; background: var(--acid); box-shadow: 0 0 0 12px rgba(215,240,108,.16), 0 0 45px rgba(215,240,108,.65); animation: pulse 2.2s infinite; }
.map-gridline { position: absolute; left: 12%; right: 12%; height: 1px; background: linear-gradient(90deg, transparent, rgba(215,240,108,.5), transparent); opacity: .75; }
.map-gridline-a { top: 34%; transform: rotate(-12deg); }
.map-gridline-b { top: 58%; transform: rotate(14deg); }
.map-hologram strong { max-width: 28rem; margin-bottom: .8rem; font-family: var(--serif); font-size: clamp(2.4rem, 4vw, 4.8rem); line-height: .9; font-weight: 400; }
.map-hologram small { color: rgba(255,255,255,.72); font-size: .82rem; }
.map-hologram em { align-self: flex-start; margin-top: 1.4rem; padding: .68rem .9rem; color: var(--ink); border-radius: 999px; background: var(--acid); font-style: normal; font-size: .7rem; font-weight: 900; letter-spacing: .08em; text-transform: uppercase; }

/* Footer */
.site-footer { padding: 5rem 6vw 2rem; color: var(--white); background: #050e0c; }
.footer-top { display: grid; grid-template-columns: .7fr 1.2fr .6fr; align-items: center; gap: 4rem; padding-bottom: 4rem; border-bottom: 1px solid rgba(255,255,255,.13); }
.footer-top > p { max-width: 36rem; margin: 0; color: rgba(255,255,255,.55); line-height: 1.7; }
.footer-top .button { justify-self: end; }
.footer-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 3rem; padding: 4rem 0; }
.footer-grid > div { display: flex; flex-direction: column; gap: .75rem; }
.footer-grid span { margin-bottom: .4rem; color: var(--green); font-size: .58rem; font-weight: 800; letter-spacing: .14em; text-transform: uppercase; }
.footer-grid a, .footer-grid p { margin: 0; color: rgba(255,255,255,.62); font-size: .76rem; line-height: 1.7; }
.footer-grid a:hover { color: var(--white); }
.footer-bottom { display: flex; justify-content: space-between; gap: 1rem; padding-top: 1.5rem; border-top: 1px solid rgba(255,255,255,.13); color: rgba(255,255,255,.36); font-size: .58rem; }

/* Reveal */
[data-reveal] { opacity: 0; transform: translateY(35px); transition: opacity .8s cubic-bezier(.2,.75,.2,1), transform .8s cubic-bezier(.2,.75,.2,1); }
[data-reveal].is-visible { opacity: 1; transform: none; }

/* Inner pages */
.inner-page { background: var(--paper); }
.inner-hero { min-height: 88svh; display: grid; align-items: end; padding: 11rem 6vw 6rem; }
.inner-hero::after { content: ""; position: absolute; inset: 0; background: linear-gradient(90deg, rgba(4,23,17,.85), rgba(4,23,17,.18)), linear-gradient(0deg, rgba(4,23,17,.78), transparent 60%); }
.inner-hero .inner-hero-bg { position: absolute; inset: 0; background-position: center; background-size: cover; }
.plantasy-hero .inner-hero-bg { background-image: url("../img/plants-owned/calathea-orbifolia.jpg"); }
.harvest-hero .inner-hero-bg { background-image: url("https://images.unsplash.com/photo-1596040033229-a9821ebd058d?auto=format&fit=crop&w=2200&q=88"); }
.inner-hero-content { position: relative; z-index: 2; display: grid; grid-template-columns: 1fr .42fr; align-items: end; gap: 4rem; }
.inner-hero h1 { margin: 0; font-family: var(--serif); font-size: clamp(5rem, 12vw, 13rem); line-height: .72; font-weight: 400; letter-spacing: -.06em; }
.inner-hero h1 em { display: block; padding-left: 14vw; color: var(--acid); font-weight: 400; }
.inner-hero-side { padding-bottom: .5rem; }
.inner-hero-side p { color: rgba(255,255,255,.75); line-height: 1.7; }
.inner-hero-logo { width: 150px; max-height: 150px; margin-bottom: 2rem; object-fit: contain; border-radius: 0; }
.plantasy-brand-logo { width: 190px; max-height: 180px; filter: drop-shadow(0 10px 28px rgba(0,0,0,.22)); }
.harvest-brand-logo { width: 230px; max-height: 150px; object-position: left center; filter: drop-shadow(0 10px 30px rgba(0,0,0,.25)); }
.inner-hero-meta { display: flex; gap: 1rem; flex-wrap: wrap; margin-top: 2rem; }
.inner-hero-meta span { padding: .5rem .75rem; border: 1px solid rgba(255,255,255,.28); border-radius: 999px; font-size: .58rem; letter-spacing: .09em; text-transform: uppercase; }
.subnav { position: sticky; top: 69px; z-index: 50; display: flex; justify-content: center; gap: .6rem; padding: .75rem 4vw; overflow-x: auto; color: var(--ink); background: rgba(250,248,242,.92); backdrop-filter: blur(16px); border-bottom: 1px solid var(--line); scrollbar-width: none; }
.subnav::-webkit-scrollbar { display: none; }
.subnav a { flex: 0 0 auto; padding: .6rem .9rem; border-radius: 999px; font-size: .64rem; font-weight: 800; }
.subnav a:hover { background: var(--acid); }
.catalog-intro { display: grid; grid-template-columns: 1fr 1fr; gap: 8vw; align-items: end; }
.catalog-intro > p { margin: 0; color: var(--muted); line-height: 1.8; }
.catalog-shell { padding: 0 6vw 8rem; }
.catalog-toolbar { position: sticky; top: 120px; z-index: 40; display: grid; grid-template-columns: minmax(240px, 1.2fr) repeat(3, minmax(150px, .45fr)); gap: .7rem; margin-bottom: 2rem; padding: .8rem; border: 1px solid var(--line); border-radius: 1rem; background: rgba(250,248,242,.94); backdrop-filter: blur(16px); box-shadow: 0 10px 40px rgba(5,25,20,.06); }
.search-field { position: relative; }
.search-field span { position: absolute; left: 1rem; top: 50%; transform: translateY(-50%); }
.catalog-toolbar input, .catalog-toolbar select { width: 100%; height: 48px; padding: 0 1rem; color: var(--ink); background: var(--cream); border: 0; border-radius: .7rem; outline: 0; font-size: .73rem; }
.catalog-toolbar input { padding-left: 2.5rem; }
.catalog-toolbar input:focus, .catalog-toolbar select:focus { box-shadow: inset 0 0 0 1px var(--forest-2); }
.result-line { display: flex; justify-content: space-between; align-items: center; gap: 1rem; margin-bottom: 1rem; color: var(--muted); font-size: .66rem; }
.catalog-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 1rem; }
.product-card { position: relative; overflow: hidden; border-radius: 1.2rem; background: var(--white); box-shadow: 0 10px 35px rgba(8,28,23,.07); transition: transform .35s, box-shadow .35s; }
.product-card:hover { transform: translateY(-8px); box-shadow: 0 24px 60px rgba(8,28,23,.13); }
.product-image { position: relative; aspect-ratio: 4 / 4.5; overflow: hidden; background: #dde8df; }
.product-image img { width: 100%; height: 100%; object-fit: cover; transition: transform .65s cubic-bezier(.2,.7,.2,1); }
.product-card:hover .product-image img { transform: scale(1.07); }
.product-badges { position: absolute; left: .8rem; top: .8rem; display: flex; gap: .4rem; flex-wrap: wrap; }
.product-badges span { padding: .38rem .55rem; border-radius: 999px; color: var(--white); background: rgba(7,27,23,.76); backdrop-filter: blur(8px); font-size: .5rem; font-weight: 800; letter-spacing: .05em; text-transform: uppercase; }
.product-content { padding: 1.2rem; }
.product-family { color: var(--forest-2); font-size: .53rem; font-weight: 800; letter-spacing: .12em; text-transform: uppercase; }
.product-card h3 { margin: .5rem 0 .2rem; font-family: var(--serif); font-size: 1.45rem; font-weight: 400; line-height: 1.05; }
.product-scientific { min-height: 2.3em; margin: 0; color: var(--muted); font-size: .63rem; font-style: italic; line-height: 1.45; }
.product-meta { display: flex; gap: .45rem; flex-wrap: wrap; margin: 1rem 0; }
.product-meta span { padding: .35rem .52rem; border: 1px solid var(--line); border-radius: 999px; color: var(--muted); font-size: .5rem; }
.product-actions { display: flex; justify-content: space-between; align-items: center; padding-top: .8rem; border-top: 1px solid var(--line); }
.product-actions button { padding: 0; border: 0; color: var(--ink); background: transparent; cursor: pointer; font-size: .61rem; font-weight: 800; }
.product-actions .add-inquiry { display: grid; place-items: center; width: 34px; height: 34px; border-radius: 50%; color: var(--ink); background: var(--acid); font-size: 1rem; transition: transform .25s; }
.product-actions .add-inquiry:hover { transform: rotate(90deg); }
.empty-state { display: none; grid-column: 1 / -1; padding: 5rem 2rem; text-align: center; color: var(--muted); border: 1px dashed var(--line); border-radius: var(--radius); }
.load-more-wrap { display: flex; justify-content: center; margin-top: 2.5rem; }
.load-more-wrap .button { color: var(--white); background: var(--forest); }
.load-more-wrap .button[hidden] { display: none; }
.inquiry-dock { position: fixed; right: 1.2rem; bottom: 1.2rem; z-index: 80; display: flex; align-items: center; gap: .8rem; padding: .7rem .8rem .7rem 1rem; color: var(--white); background: var(--ink); border: 1px solid rgba(255,255,255,.14); border-radius: 999px; box-shadow: var(--shadow); transform: translateY(160%); transition: transform .45s cubic-bezier(.2,.8,.2,1); }
.inquiry-dock.is-visible { transform: none; }
.inquiry-dock strong { font-size: .65rem; }
.inquiry-dock button { width: 36px; height: 36px; border: 0; border-radius: 50%; color: var(--ink); background: var(--acid); cursor: pointer; }
.inquiry-panel { position: fixed; inset: 0; z-index: 150; display: grid; grid-template-columns: 1fr min(520px, 100%); visibility: hidden; background: rgba(5,20,17,.65); opacity: 0; transition: opacity .3s, visibility .3s; }
.inquiry-panel.is-open { visibility: visible; opacity: 1; }
.inquiry-panel-card { grid-column: 2; padding: 2rem; color: var(--white); background: var(--ink); transform: translateX(100%); transition: transform .45s cubic-bezier(.2,.8,.2,1); overflow-y: auto; }
.inquiry-panel.is-open .inquiry-panel-card { transform: none; }
.panel-head { display: flex; justify-content: space-between; align-items: center; padding-bottom: 1.5rem; border-bottom: 1px solid rgba(255,255,255,.15); }
.panel-head h2 { margin: 0; font-family: var(--serif); font-size: 2rem; font-weight: 400; }
.panel-close { display: grid; place-items: center; width: 40px; height: 40px; color: var(--white); border: 1px solid rgba(255,255,255,.3); border-radius: 50%; background: transparent; cursor: pointer; }
.inquiry-items { display: grid; gap: .7rem; padding: 1.5rem 0; }
.inquiry-item { display: flex; justify-content: space-between; gap: 1rem; padding: 1rem; border-radius: .8rem; background: rgba(255,255,255,.06); }
.inquiry-item span { font-size: .72rem; }
.inquiry-item button { color: var(--green); border: 0; background: transparent; cursor: pointer; font-size: .6rem; }
.panel-empty { color: rgba(255,255,255,.5); font-size: .75rem; }
.panel-form { display: grid; gap: 1rem; margin-top: 1rem; }
.panel-form input, .panel-form textarea { width: 100%; padding: 1rem; color: var(--white); border: 1px solid rgba(255,255,255,.18); border-radius: .7rem; background: rgba(255,255,255,.05); outline: 0; }
.panel-form input:focus, .panel-form textarea:focus { border-color: var(--acid); }
.product-modal { position: fixed; inset: 0; z-index: 140; display: grid; place-items: center; padding: 2rem; visibility: hidden; opacity: 0; background: rgba(5,20,17,.7); backdrop-filter: blur(8px); transition: opacity .3s, visibility .3s; }
.product-modal.is-open { visibility: visible; opacity: 1; }
.modal-card { position: relative; display: grid; grid-template-columns: .9fr 1.1fr; width: min(980px, 100%); max-height: 86vh; overflow: auto; border-radius: var(--radius); background: var(--paper); box-shadow: var(--shadow); }
.modal-image { min-height: 520px; background: #dce8df; }
.modal-image img { width: 100%; height: 100%; object-fit: cover; }
.modal-content { padding: clamp(2rem, 5vw, 4rem); }
.modal-content h2 { margin: .6rem 0 .3rem; font-family: var(--serif); font-size: clamp(2.5rem, 5vw, 5rem); line-height: .9; font-weight: 400; }
.modal-content .scientific { color: var(--muted); font-style: italic; }
.modal-content .description { margin: 2rem 0; color: var(--muted); line-height: 1.8; }
.modal-specs { display: grid; grid-template-columns: 1fr 1fr; border-top: 1px solid var(--line); border-left: 1px solid var(--line); }
.modal-specs div { padding: 1rem; border-right: 1px solid var(--line); border-bottom: 1px solid var(--line); }
.modal-specs span { display: block; margin-bottom: .35rem; color: var(--muted); font-size: .5rem; font-weight: 800; letter-spacing: .1em; text-transform: uppercase; }
.modal-specs strong { font-size: .7rem; }
.modal-close { position: absolute; right: 1rem; top: 1rem; z-index: 2; width: 40px; height: 40px; border: 0; border-radius: 50%; background: var(--acid); cursor: pointer; }

.category-panels { background: var(--cream); }
.category-panel { display: grid; grid-template-columns: .72fr 1.28fr; gap: 6vw; align-items: center; padding: 6rem 0; border-bottom: 1px solid var(--line); }
.category-panel:last-child { border-bottom: 0; }
.category-panel:nth-child(even) .category-panel-media { order: 2; }
.category-panel-media { min-height: 560px; overflow: hidden; border-radius: var(--radius); background-position: center; background-size: cover; }
.flowers-media { display: grid; align-content: end; padding: 1rem; background-image: radial-gradient(circle at 24% 18%, rgba(215,240,108,.32), transparent 24%), linear-gradient(160deg, rgba(7,27,23,.05), rgba(7,27,23,.52)), url("../img/plants-owned/orchid.jpg"); }
.flower-photo-grid { display: grid; grid-template-columns: 1fr 1fr; gap: .75rem; }
.flower-photo-grid img { width: 100%; aspect-ratio: 1 / .78; object-fit: cover; border: 1px solid rgba(255,255,255,.34); border-radius: 1rem; box-shadow: 0 18px 46px rgba(0,0,0,.2); }
.flower-photo-grid img:nth-child(1) { transform: translateY(-18px); }
.flower-photo-grid img:nth-child(2) { transform: translateY(16px); }
.flower-photo-grid img:nth-child(3) { transform: translateY(-6px); }
.flower-photo-grid img:nth-child(4) { transform: translateY(26px); }
.landscape-media { background-image: url("../img/plants/kimeng-bonsai.jpg"); }
.custom-plant-media { background-image: url("../img/plants-owned/prayer-plant.jpg"); }
.category-panel-copy .eyebrow { color: var(--forest-2); }
.category-panel-copy h2 { margin: 0 0 1.5rem; font-family: var(--serif); font-size: clamp(3.4rem, 6vw, 6rem); line-height: .9; font-weight: 400; }
.category-panel-copy > p { color: var(--muted); line-height: 1.8; }
.flower-availability { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: .8rem; margin: 2rem 0; }
.flower-card { position: relative; overflow: hidden; min-height: 176px; padding: 1.1rem; border: 1px solid var(--line); border-radius: 1.2rem; background: rgba(255,255,255,.5); }
.flower-card::before { content: ""; position: absolute; inset: 0; pointer-events: none; background: radial-gradient(circle at 90% 10%, rgba(140,206,99,.18), transparent 34%); }
.flower-card span { position: relative; display: inline-flex; margin-bottom: 1rem; color: var(--forest-2); font-size: .56rem; font-weight: 900; letter-spacing: .12em; text-transform: uppercase; }
.flower-card p { position: relative; margin: 0; color: rgba(42,58,53,.72); font-size: .72rem; line-height: 1.7; }
.flower-card:nth-child(5) { grid-column: 1 / -1; min-height: auto; }
.feature-list { display: grid; gap: .8rem; margin: 2rem 0; padding: 0; list-style: none; }
.feature-list li { display: flex; justify-content: space-between; gap: 1rem; padding-bottom: .8rem; border-bottom: 1px solid var(--line); font-size: .75rem; }
.feature-list li span { color: var(--muted); }
.flower-notes { margin-top: 1rem; }
.client-cloud { display: flex; gap: .6rem; flex-wrap: wrap; margin-top: 2rem; }
.client-cloud span { padding: .6rem .8rem; border: 1px solid var(--line); border-radius: 999px; font-size: .62rem; }
.coming-soon { position: relative; overflow: hidden; min-height: 520px; display: grid; place-items: center; text-align: center; color: var(--white); background: var(--ink); }
.coming-soon::before { content: ""; position: absolute; width: 70vw; height: 70vw; border: 1px solid rgba(140,206,99,.28); border-radius: 50%; box-shadow: 0 0 0 9vw rgba(140,206,99,.04), 0 0 0 18vw rgba(140,206,99,.025); }
.coming-soon > div { position: relative; z-index: 1; }
.coming-soon h2 { margin: 0; font-family: var(--serif); font-size: clamp(4rem, 9vw, 10rem); line-height: .8; font-weight: 400; }
.coming-soon h2 em { display: block; color: var(--green); }

/* Harvest page */
.harvest-intro { background: #f2eadb; }
.commodity-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 1rem; margin-top: 5rem; }
.commodity-card { position: relative; min-height: 500px; display: flex; flex-direction: column; justify-content: flex-end; overflow: hidden; padding: 2rem; color: var(--white); border-radius: var(--radius); background-position: center; background-size: cover; }
.commodity-card::before { content: ""; position: absolute; inset: 0; background: linear-gradient(180deg, rgba(20,10,5,.05), rgba(35,18,8,.9)); }
.commodity-card > * { position: relative; }
.commodity-card.cinnamon { background-image: url("https://images.unsplash.com/photo-1596040033229-a9821ebd058d?auto=format&fit=crop&w=1200&q=86"); }
.commodity-card.candlenut { background-image: url("https://images.unsplash.com/photo-1599599810769-bcde5a160d32?auto=format&fit=crop&w=1200&q=86"); }
.commodity-card.coconut { background-image: url("https://images.unsplash.com/photo-1580984969071-a8da5656c2fb?auto=format&fit=crop&w=1200&q=86"); }
.commodity-card.fruits { background-image: url("https://images.unsplash.com/photo-1619566636858-adf3ef46400b?auto=format&fit=crop&w=1200&q=86"); }
.commodity-card span { margin-bottom: auto; font-size: .55rem; font-weight: 800; letter-spacing: .13em; text-transform: uppercase; }
.commodity-card h3 { margin: 0 0 .7rem; font-family: var(--serif); font-size: 2.8rem; font-weight: 400; }
.commodity-card p { margin: 0; color: rgba(255,255,255,.7); line-height: 1.65; font-size: .78rem; }
.harvest-catalogs { display: grid; gap: 1.2rem; background: var(--paper); }
.product-showcase { display: grid; grid-template-columns: .82fr 1.18fr; gap: clamp(2rem, 5vw, 5rem); align-items: center; padding: clamp(1rem, 2vw, 2rem); border: 1px solid var(--line); border-radius: var(--radius); background: var(--cream); }
.product-showcase.reverse { grid-template-columns: 1fr 1fr; }
.product-showcase.reverse .showcase-media { order: 2; }
.showcase-media { overflow: hidden; border-radius: calc(var(--radius) - .45rem); box-shadow: var(--shadow); background: #fff; }
.showcase-media img { display: block; width: 100%; height: 100%; max-height: 760px; object-fit: cover; object-position: top center; }
.showcase-copy p:not(.eyebrow) { color: var(--muted); line-height: 1.8; }
.detail-tags { display: flex; flex-wrap: wrap; gap: .65rem; margin: 1.6rem 0; }
.detail-tags span { padding: .55rem .75rem; color: var(--forest); border: 1px solid var(--line); border-radius: 999px; background: rgba(255,255,255,.58); font-size: .62rem; font-weight: 800; letter-spacing: .06em; text-transform: uppercase; }
.button-row { display: flex; flex-wrap: wrap; gap: .75rem; }
.button-ghost.dark { color: var(--forest); border-color: var(--line); }
.cinnamon-story { color: var(--white); background: #432718; }
.cinnamon-lead { display: grid; grid-template-columns: 1fr .8fr; gap: 7vw; align-items: end; }
.cinnamon-lead p { color: rgba(255,255,255,.65); line-height: 1.8; }
.grade-switcher { display: flex; gap: .6rem; margin: 4rem 0 2rem; flex-wrap: wrap; }
.grade-switcher button { padding: .7rem 1rem; color: rgba(255,255,255,.65); border: 1px solid rgba(255,255,255,.2); border-radius: 999px; background: transparent; cursor: pointer; font-size: .65rem; font-weight: 800; }
.grade-switcher button.is-active, .grade-switcher button:hover { color: var(--ink); background: var(--acid); border-color: var(--acid); }
.grade-table { display: grid; grid-template-columns: repeat(5, 1fr); border-top: 1px solid rgba(255,255,255,.18); border-left: 1px solid rgba(255,255,255,.18); }
.grade-card { min-height: 310px; padding: 1.4rem; border-right: 1px solid rgba(255,255,255,.18); border-bottom: 1px solid rgba(255,255,255,.18); transition: background .3s; }
.grade-card:hover { background: rgba(255,255,255,.06); }
.grade-card > span { color: var(--green); font-size: .55rem; letter-spacing: .12em; text-transform: uppercase; }
.grade-card h3 { margin: 2rem 0 1rem; font-family: var(--serif); font-size: 2rem; font-weight: 400; }
.grade-card ul { margin: 0; padding-left: 1rem; color: rgba(255,255,255,.6); font-size: .68rem; line-height: 1.8; }
.grade-card p { color: rgba(255,255,255,.68); font-size: .7rem; line-height: 1.7; }
.quality-grid { display: grid; grid-template-columns: repeat(4, 1fr); margin-top: 5rem; border-top: 1px solid var(--line); border-left: 1px solid var(--line); }
.quality-grid article { min-height: 250px; padding: 2rem; border-right: 1px solid var(--line); border-bottom: 1px solid var(--line); }
.quality-grid span { color: var(--forest-2); font-size: .55rem; font-weight: 800; letter-spacing: .12em; text-transform: uppercase; }
.quality-grid h3 { margin: 3rem 0 .8rem; font-family: var(--serif); font-size: 2rem; font-weight: 400; }
.quality-grid p { color: var(--muted); font-size: .72rem; line-height: 1.7; }
.spec-note { margin-top: 2rem; color: var(--muted); font-size: .66rem; line-height: 1.7; }

@media (max-width: 1100px) {
  .cursor-orbit { display: none; }
  .manifesto-grid, .custom-head, .inner-hero-content { grid-template-columns: 1fr; }
  .hero-bottom { margin-left: 0; }
  .unit-card > a { grid-template-columns: 1fr 1fr; }
  .why-us { grid-template-columns: 1fr; }
  .empathy-grid { grid-template-columns: 1fr 120px 1fr; }
  .why-visual { min-height: 620px; }
  .quest-menu, .signal-board { grid-template-columns: 1fr; }
  .media-grid { grid-template-columns: 1fr 1fr; }
  .custom-grid, .commodity-grid { grid-template-columns: 1fr 1fr; }
  .custom-grid > :last-child { grid-column: 1 / -1; }
  .impact { grid-template-columns: 1fr; }
  .impact-orbit { margin: 4rem auto 0; }
  .catalog-grid { grid-template-columns: repeat(3, 1fr); }
  .catalog-toolbar { grid-template-columns: 1fr 1fr; }
  .grade-table { grid-template-columns: repeat(3, 1fr); }
  .product-showcase, .product-showcase.reverse { grid-template-columns: 1fr; }
  .product-showcase.reverse .showcase-media { order: 0; }
}

@media (max-width: 820px) {
  .site-header { min-height: 70px; padding: .8rem 5vw; }
  .nav-toggle { display: block; z-index: 3; }
  .nav-toggle[aria-expanded="true"] > span:nth-child(1) { transform: translateY(7px) rotate(45deg); }
  .nav-toggle[aria-expanded="true"] > span:nth-child(2) { opacity: 0; }
  .nav-toggle[aria-expanded="true"] > span:nth-child(3) { transform: translateY(-7px) rotate(-45deg); }
  .primary-nav { position: fixed; inset: 0; display: flex; flex-direction: column; align-items: flex-start; justify-content: center; gap: .4rem; padding: 7rem 8vw 3rem; border: 0; border-radius: 0; background: radial-gradient(circle at 80% 20%, rgba(36,166,174,.22), transparent 35%), linear-gradient(145deg, rgba(7,27,23,.96), rgba(5,18,22,.98)); transform: translateX(100%); transition: transform .45s cubic-bezier(.2,.8,.2,1); }
  .primary-nav.is-open { transform: none; }
  .primary-nav > a:not(.nav-cta) { font-family: var(--serif); font-size: clamp(2.6rem, 10vw, 4.6rem); font-weight: 400; }
  .nav-cta { margin-top: 2rem; }
  .section-pad { padding-left: 5vw; padding-right: 5vw; }
  .section-heading { grid-template-columns: 1fr; gap: 2rem; }
  .hero-home { padding: 9rem 5vw 5rem; }
  .hero h1 { font-size: clamp(4rem, 18vw, 8rem); line-height: .82; }
  .quest-menu { grid-template-columns: 1fr; }
  .quest-menu a { min-height: 112px; }
  .hero-bottom { grid-template-columns: 1fr; gap: 1.5rem; }
  .hero-index, .scroll-cue { display: none; }
  .manifesto-grid { gap: 3rem; }
  .two-sides-head { grid-template-columns: 1fr; gap: 2rem; }
  .empathy-grid { grid-template-columns: 1fr; }
  .empathy-bridge { min-height: 110px; flex-direction: row; border-radius: var(--radius); }
  .empathy-bridge strong { width: 64px; height: 64px; font-size: 1.5rem; }
  .stat-ribbon { grid-template-columns: 1fr; }
  .stat-ribbon > div { border-right: 0; border-bottom: 1px solid var(--line); }
  .stat-ribbon > div:last-child { border-bottom: 0; }
  .media-grid { grid-template-columns: 1fr; }
  .media-card { min-height: 380px; }
  .unit-card { position: relative; top: auto !important; min-height: 720px; }
  .unit-card > a { grid-template-columns: 1fr; grid-template-rows: .75fr 1.25fr; }
  .unit-content { padding: 2rem; }
  .unit-content h3 { font-size: 4rem; }
  .why-us { padding-top: 2rem; }
  .why-visual { min-height: 520px; }
  .custom-grid, .commodity-grid { grid-template-columns: 1fr; }
  .custom-grid > :last-child, .commodity-grid > :last-child { grid-column: auto; }
  .process-scroll { display: grid; grid-template-columns: 1fr; overflow: visible; padding-bottom: 1.2rem; cursor: default; scroll-snap-type: none; }
  .process-step { min-height: auto; }
  .process-step > span { margin-bottom: 3rem; }
  .process-controls { display: none; }
  .process-progress { display: none; }
  .contact { grid-template-columns: 1fr; }
  .contact-copy { position: static; }
  .location-card { grid-template-columns: 1fr; }
  .footer-top { grid-template-columns: 1fr; gap: 2rem; }
  .footer-top .button { justify-self: start; }
  .footer-grid { grid-template-columns: 1fr 1fr; }
  .inner-hero { padding-left: 5vw; padding-right: 5vw; }
  .inner-hero h1 em { padding-left: 0; }
  .subnav { justify-content: flex-start; }
  .catalog-intro, .category-panel, .cinnamon-lead { grid-template-columns: 1fr; }
  .catalog-toolbar { position: relative; top: auto; }
  .catalog-grid { grid-template-columns: 1fr 1fr; }
  .flower-availability { grid-template-columns: 1fr; }
  .flower-card:nth-child(5) { grid-column: auto; }
  .category-panel:nth-child(even) .category-panel-media { order: 0; }
  .category-panel-media { min-height: 430px; }
  .modal-card { grid-template-columns: 1fr; }
  .modal-image { min-height: 330px; }
  .grade-table { grid-template-columns: 1fr 1fr; }
  .quality-grid { grid-template-columns: 1fr 1fr; }
  .showcase-media img { max-height: 620px; }
}

@media (max-width: 560px) {
  .brand-name { display: none; }
  .hero h1 { font-size: 18vw; }
  .hero-home .eyebrow { max-width: 100%; flex-wrap: wrap; gap: .6rem; font-size: .52rem; }
  .hero-home .eyebrow span:last-child { display: none; }
  .hero-home .hero-copy, .hero-home .hero-bottom, .hero-home .hero-intro { width: 100%; max-width: 90vw; }
  .hero-home .hero-intro { inline-size: calc(100vw - 48px) !important; max-inline-size: calc(100vw - 48px) !important; overflow-wrap: break-word; }
  .hero-home .hero-intro span { display: block; }
  .hero-actions { align-items: flex-start; flex-direction: column; }
  .fui-panel { clip-path: none; border-radius: 1rem; }
  .fui-panel span { font-size: .48rem; }
  .signal-board article { min-height: 210px; }
  .media-card { min-height: 340px; }
  .display-title { font-size: 14vw; }
  .stat-ribbon { grid-template-columns: 1fr; }
  .stat-ribbon > div { min-height: 120px; border-right: 0; border-bottom: 1px solid var(--line); }
  .stat-ribbon > div:last-child { border-bottom: 0; }
  .custom-head h2 { font-size: 14vw; }
  .material-card { min-height: 390px; }
  .impact { min-height: 720px; }
  .impact-orbit { width: 110%; margin-left: -5%; }
  .orbit-item { max-width: 120px; padding: .55rem .7rem; font-size: .5rem; }
  .form-row { grid-template-columns: 1fr; }
  .footer-grid { grid-template-columns: 1fr; }
  .footer-bottom { flex-direction: column; }
  .inner-hero { min-height: 96svh; }
  .inner-hero h1 { font-size: 22vw; }
  .catalog-toolbar { grid-template-columns: 1fr; }
  .catalog-grid { grid-template-columns: 1fr; }
  .product-image { aspect-ratio: 4 / 3.8; }
  .category-panel-media { min-height: 360px; }
  .flower-photo-grid { gap: .45rem; }
  .flower-photo-grid img { border-radius: .75rem; }
  .flower-card { padding: 1rem; }
  .product-modal { padding: .5rem; }
  .modal-card { max-height: 96vh; }
  .modal-content { padding: 1.5rem; }
  .grade-table, .quality-grid { grid-template-columns: 1fr; }
  .button-row { flex-direction: column; align-items: flex-start; }
}

@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after { scroll-behavior: auto !important; animation-duration: .01ms !important; animation-iteration-count: 1 !important; transition-duration: .01ms !important; }
  [data-reveal] { opacity: 1; transform: none; }
  .fui-webgl { display: none; }
  .kinetic-type { transform: none; }
}

/* Final polish: readable proof cards + lighter motion */
.media-grid {
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: clamp(1rem, 2vw, 1.4rem);
}
.media-card {
  min-height: clamp(360px, 42vw, 520px);
  padding: clamp(1.35rem, 2vw, 2.2rem);
  justify-content: space-between;
  transform: translateZ(0);
}
.media-card::before {
  background:
    linear-gradient(180deg, rgba(4,21,17,.32), rgba(4,21,17,.9) 70%),
    radial-gradient(circle at 24% 18%, rgba(215,240,108,.18), transparent 32%);
}
.media-card span {
  margin-bottom: 2rem;
  max-width: 100%;
  color: rgba(255,255,255,.92);
  background: rgba(7,27,23,.34);
  backdrop-filter: blur(8px);
}
.media-card h3 {
  width: min(100%, 24rem);
  max-width: none;
  overflow-wrap: normal;
  text-wrap: balance;
  font-size: clamp(2.3rem, 3.2vw, 4.2rem);
  line-height: .94;
  letter-spacing: -.035em;
}
.media-card p {
  max-width: 25rem;
  margin-top: .95rem;
  color: rgba(255,255,255,.76);
  font-size: .78rem;
}
.media-card a { margin-top: .9rem; }
.media-harvest { background-image: url("../img/catalogs/harvest-fruits-documentation-page.png"); background-position: center top; }
.media-reels { min-height: clamp(340px, 38vw, 500px); }
.media-reels div { display: flex; flex-wrap: wrap; gap: .55rem; }

@media (min-width: 1180px) {
  .media-export { grid-row: span 2; min-height: 650px; }
  .media-reels { grid-row: span 2; min-height: 650px; }
}

@media (max-width: 820px) {
  .fui-webgl,
  .home-page::after,
  .inner-page::after,
  .cursor-orbit { display: none !important; }
  .home-page::before,
  .inner-page::before { opacity: .13; transform: none; }
  .page-noise { opacity: .018; }
  .media-grid { grid-template-columns: 1fr; }
  .media-card { min-height: 360px; }
  .media-card h3 { width: min(100%, 21rem); font-size: clamp(2.35rem, 10vw, 3.8rem); }
}

@media (max-width: 560px) {
  .media-card { min-height: 320px; padding: 1.25rem; border-radius: 1.25rem; }
  .media-card h3 { font-size: clamp(2.15rem, 11vw, 3.2rem); line-height: .96; }
  .media-card span { margin-bottom: 1.2rem; font-size: .5rem; }
}

/* Harvest Green rebuild: categorized, lighter, readable */
.harvest-page .fui-webgl { display: none; }
.harvest-page::after { display: none; }
.harvest-page .inner-hero,
.harvest-page .inner-hero-content,
.harvest-page .inner-hero-side { min-width: 0; }
.harvest-page .inner-hero-bg { opacity: .7; }
.harvest-hero .inner-hero-bg { background-image: url("../img/catalogs/harvest-fruits-thumb.webp"); }
.harvest-page .inner-hero-side p {
  max-width: min(100%, 34rem);
  overflow-wrap: break-word;
}
.harvest-hero-copy span { display: block; }
.harvest-page .display-title { text-wrap: balance; }
.harvest-route-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: clamp(.9rem, 1.6vw, 1.2rem);
  margin-top: clamp(3rem, 5vw, 5rem);
}
.harvest-route-card {
  position: relative;
  min-height: 360px;
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  overflow: hidden;
  padding: clamp(1.25rem, 2vw, 1.8rem);
  color: var(--white);
  border: 1px solid rgba(67,39,24,.16);
  border-radius: var(--radius);
  background:
    radial-gradient(circle at 84% 12%, rgba(215,240,108,.24), transparent 28%),
    linear-gradient(145deg, rgba(67,39,24,.92), rgba(12,42,32,.92));
  box-shadow: 0 18px 60px rgba(67,39,24,.14);
}
.harvest-route-card::before {
  content: "";
  position: absolute;
  inset: 0;
  opacity: .42;
  background-image: linear-gradient(rgba(255,255,255,.08) 1px, transparent 1px), linear-gradient(90deg, rgba(255,255,255,.07) 1px, transparent 1px);
  background-size: 34px 34px;
  mask-image: linear-gradient(180deg, transparent, #000 42%);
}
.harvest-route-card > * { position: relative; }
.harvest-route-card > span {
  margin-bottom: auto;
  color: var(--green);
  font-size: .55rem;
  font-weight: 900;
  letter-spacing: .13em;
  text-transform: uppercase;
}
.harvest-route-card h3 {
  max-width: 100%;
  margin: 0 0 .8rem;
  font-family: var(--serif);
  font-size: clamp(2rem, 2.6vw, 3.2rem);
  line-height: .96;
  font-weight: 400;
  letter-spacing: -.025em;
  text-wrap: balance;
}
.harvest-route-card p {
  min-height: 4.8rem;
  margin: 0;
  color: rgba(255,255,255,.74);
  font-size: .78rem;
  line-height: 1.65;
}
.route-coconut { background-image: linear-gradient(180deg, rgba(20,10,5,.15), rgba(4,21,17,.88)), url("../img/catalogs/semi-husked-coconut-thumb.webp"); background-position: center; background-size: cover; }
.route-fruits { background-image: linear-gradient(180deg, rgba(20,10,5,.1), rgba(4,21,17,.88)), url("../img/catalogs/harvest-fruits-catalog-thumb.webp"); background-position: center top; background-size: cover; }
.harvest-dossier {
  background: var(--paper);
}
.harvest-dossier.soft {
  background: #f2eadb;
}
.dossier-head {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(280px, .72fr);
  gap: clamp(2rem, 5vw, 5rem);
  align-items: end;
  margin-bottom: clamp(2rem, 4vw, 4rem);
}
.dossier-head .eyebrow { grid-column: 1 / -1; margin-bottom: -1rem; }
.dossier-head h2 { margin: 0; }
.dossier-head p:not(.eyebrow) {
  margin: 0;
  color: var(--muted);
  line-height: 1.85;
}
.educational-split {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 1rem;
  margin-bottom: 2.2rem;
}
.education-card,
.fruit-catalog-card,
.catalog-reference,
.product-spec-grid article,
.fruit-grid article {
  border: 1px solid var(--line);
  border-radius: calc(var(--radius) - .35rem);
  background: rgba(255,255,255,.52);
}
.education-card {
  min-height: 300px;
  padding: clamp(1.35rem, 2vw, 2rem);
}
.education-card.wide { min-height: auto; max-width: 920px; }
.education-card span,
.product-spec-grid span,
.fruit-grid span,
.catalog-copy h3 {
  color: var(--forest-2);
}
.education-card span,
.product-spec-grid span,
.fruit-grid span {
  display: inline-flex;
  margin-bottom: 1.2rem;
  font-size: .56rem;
  font-weight: 900;
  letter-spacing: .13em;
  text-transform: uppercase;
}
.education-card h3,
.catalog-copy h3,
.product-spec-grid h3,
.fruit-catalog-card h3 {
  margin: 0 0 .9rem;
  font-family: var(--serif);
  font-size: clamp(2rem, 3vw, 3rem);
  line-height: .98;
  font-weight: 400;
}
.education-card p,
.catalog-copy p,
.fruit-catalog-card p,
.product-spec-grid p,
.fruit-grid p {
  margin: 0;
  color: var(--muted);
  line-height: 1.72;
  font-size: .82rem;
}
.education-card ul {
  margin: 1.4rem 0 0;
  padding-left: 1.1rem;
  color: rgba(42,58,53,.72);
  line-height: 1.8;
  font-size: .78rem;
}
.harvest-grade-table {
  grid-template-columns: repeat(5, minmax(0, 1fr));
  border-radius: var(--radius);
  overflow: hidden;
}
.harvest-grade-table.oil-table {
  grid-template-columns: repeat(4, minmax(0, 1fr));
}
.harvest-grade-table .grade-card {
  min-height: 290px;
}
.harvest-grade-table .grade-card h3 {
  margin-top: 1.4rem;
  font-size: clamp(1.8rem, 2.2vw, 2.4rem);
}
.catalog-reference {
  display: grid;
  grid-template-columns: minmax(260px, .62fr) minmax(0, 1fr);
  gap: clamp(1.4rem, 3vw, 3rem);
  align-items: center;
  padding: clamp(1rem, 2vw, 1.5rem);
  margin-bottom: 1rem;
}
.catalog-thumb {
  overflow: hidden;
  max-height: 420px;
  border-radius: calc(var(--radius) - .65rem);
  background: #fff;
  box-shadow: 0 16px 46px rgba(67,39,24,.14);
}
.catalog-thumb img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: top center;
}
.product-spec-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 1rem;
}
.product-spec-grid article {
  min-height: 230px;
  padding: 1.35rem;
}
.fruit-catalog-card {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1.5rem;
  padding: clamp(1.35rem, 2.2vw, 2rem);
  margin-bottom: 1rem;
}
.fruit-catalog-card > div { max-width: 720px; }
.fruit-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: .85rem;
}
.fruit-grid article {
  min-height: 168px;
  padding: 1.15rem;
}
.fruit-grid span {
  margin-bottom: .8rem;
  font-size: .54rem;
}
.harvest-quality-grid {
  margin-top: 0;
}
.harvest-quality-grid article {
  min-height: 230px;
}

@media (max-width: 1100px) {
  .harvest-route-grid,
  .fruit-grid,
  .product-spec-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .harvest-grade-table,
  .harvest-grade-table.oil-table { grid-template-columns: repeat(2, minmax(0, 1fr)); }
}

@media (max-width: 820px) {
  .harvest-page .inner-hero-content { gap: 2rem; }
  .harvest-page .inner-hero-side {
    width: 100%;
    max-width: calc(100vw - 48px);
    inline-size: calc(100vw - 48px) !important;
    max-inline-size: calc(100vw - 48px) !important;
  }
  .harvest-page .inner-hero-side p {
    width: 100%;
    max-width: 100%;
    inline-size: calc(100vw - 48px) !important;
    max-inline-size: calc(100vw - 48px) !important;
    white-space: normal;
    overflow-wrap: break-word;
  }
  .harvest-hero-copy span { display: block; }
  .harvest-page .harvest-brand-logo { max-width: min(230px, 68vw); }
  .dossier-head,
  .educational-split,
  .catalog-reference { grid-template-columns: 1fr; }
  .dossier-head .eyebrow { margin-bottom: 0; }
  .harvest-route-card { min-height: 300px; }
  .fruit-catalog-card { align-items: flex-start; flex-direction: column; }
  .catalog-thumb { max-height: 360px; }
}

@media (max-width: 560px) {
  .harvest-route-grid,
  .fruit-grid,
  .product-spec-grid,
  .harvest-grade-table,
  .harvest-grade-table.oil-table { grid-template-columns: 1fr; }
  .harvest-route-card,
  .education-card,
  .product-spec-grid article,
  .fruit-grid article { min-height: auto; }
  .harvest-route-card p { min-height: 0; }
  .catalog-reference { padding: .85rem; }
  .catalog-thumb { max-height: 300px; }
}

/* Final Harvest Green readability pass */
.harvest-page .route-cinnamon {
  background-image: linear-gradient(180deg, rgba(22,10,4,.08), rgba(20,10,4,.88)), url("../img/catalogs/cinnamon-photo.webp");
  background-position: center;
  background-size: cover;
}

.harvest-page .route-custom {
  background-image: linear-gradient(180deg, rgba(22,10,4,.08), rgba(4,21,17,.88)), url("../img/catalogs/candlenut-photo.webp");
  background-position: center;
  background-size: cover;
}

.harvest-page .cinnamon-dossier {
  position: relative;
  overflow: hidden;
  background:
    radial-gradient(circle at 15% 5%, rgba(216,142,68,.36), transparent 34%),
    linear-gradient(135deg, #2b1409 0%, #4a2512 43%, #110806 100%);
  color: #fff8ec;
}

.harvest-page .cinnamon-dossier::before {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  background-image:
    linear-gradient(rgba(255,255,255,.045) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,.035) 1px, transparent 1px);
  background-size: 44px 44px;
  mask-image: linear-gradient(180deg, rgba(0,0,0,.85), rgba(0,0,0,.14));
}

.harvest-page .cinnamon-dossier > * { position: relative; }
.harvest-page .cinnamon-dossier .display-title,
.harvest-page .cinnamon-dossier .display-title span,
.harvest-page .cinnamon-dossier .dossier-head p:not(.eyebrow) {
  color: #fff8ec;
}

.harvest-page .cinnamon-dossier .display-title span { opacity: .78; }
.harvest-page .eyebrow-light { color: #f4c27e; }

.product-photo-grid {
  display: grid;
  grid-template-columns: minmax(280px, .95fr) minmax(280px, .75fr);
  gap: clamp(1rem, 2.4vw, 2rem);
  align-items: stretch;
  margin: 0 0 clamp(1.2rem, 3vw, 2.2rem);
}

.product-photo-grid.reverse {
  grid-template-columns: minmax(280px, .72fr) minmax(280px, .9fr);
}

.product-photo-card,
.harvest-proof-card {
  overflow: hidden;
  min-height: 360px;
  border: 1px solid rgba(255,255,255,.2);
  border-radius: calc(var(--radius) - .35rem);
  box-shadow: 0 28px 70px rgba(39,20,9,.22);
}

.product-photo-card {
  position: relative;
  margin: 0;
  background: #170a05;
}

.product-photo-card img {
  display: block;
  width: 100%;
  height: 100%;
  min-height: 360px;
  object-fit: cover;
  transform: scale(1.01);
}

.product-photo-card figcaption {
  position: absolute;
  right: 1rem;
  bottom: 1rem;
  left: 1rem;
  padding: 1rem;
  border: 1px solid rgba(255,255,255,.24);
  border-radius: 1.1rem;
  background: rgba(10,18,14,.72);
  color: #fff;
  -webkit-backdrop-filter: blur(14px);
  backdrop-filter: blur(14px);
}

.product-photo-card figcaption span,
.proof-kicker {
  display: block;
  margin-bottom: .45rem;
  color: #b7ff5f;
  font-size: .58rem;
  font-weight: 900;
  letter-spacing: .13em;
  text-transform: uppercase;
}

.product-photo-card figcaption strong {
  display: block;
  font-family: var(--serif);
  font-size: clamp(1.35rem, 2.2vw, 2rem);
  line-height: .98;
}

.product-photo-card figcaption small {
  display: block;
  margin-top: .55rem;
  color: rgba(255,255,255,.76);
  line-height: 1.55;
}

.harvest-proof-card {
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  padding: clamp(1.25rem, 3vw, 2rem);
  background:
    linear-gradient(135deg, rgba(255,255,255,.13), rgba(255,255,255,.04)),
    rgba(20,10,4,.58);
  color: #fff8ec;
}

.harvest-proof-card.light {
  border-color: rgba(67,39,24,.14);
  background: #fffaf0;
  color: #1e130b;
}

.harvest-proof-card h3 {
  margin: 0 0 1rem;
  font-family: var(--serif);
  font-size: clamp(2rem, 3.4vw, 3.9rem);
  line-height: .92;
  font-weight: 400;
  letter-spacing: -.025em;
}

.harvest-proof-card p,
.harvest-proof-card li {
  color: rgba(255,248,236,.78);
  line-height: 1.75;
}

.harvest-proof-card.light p,
.harvest-proof-card.light li {
  color: rgba(30,19,11,.72);
}

.harvest-proof-card ul {
  margin: 0 0 1rem;
  padding-left: 1.1rem;
}

.harvest-page .cinnamon-dossier .education-card,
.harvest-page .cinnamon-dossier .grade-card {
  border: 1px solid rgba(255,255,255,.18);
  background: rgba(255,252,244,.96);
  color: #1e130b;
  box-shadow: 0 18px 44px rgba(14,7,2,.16);
}

.harvest-page .cinnamon-dossier .education-card span,
.harvest-page .cinnamon-dossier .grade-card > span {
  color: #8b3f12;
}

.harvest-page .cinnamon-dossier .education-card h3,
.harvest-page .cinnamon-dossier .grade-card h3 {
  color: #1e130b;
}

.harvest-page .cinnamon-dossier .education-card p,
.harvest-page .cinnamon-dossier .education-card li,
.harvest-page .cinnamon-dossier .grade-card p,
.harvest-page .cinnamon-dossier .grade-card li,
.harvest-page .cinnamon-dossier .grade-card ul {
  color: rgba(30,19,11,.72);
}

.harvest-page .cinnamon-dossier .grade-switcher {
  border: 1px solid rgba(255,255,255,.18);
  background: rgba(255,248,236,.14);
}

.harvest-page .cinnamon-dossier .grade-switcher button {
  color: rgba(255,248,236,.76);
}

.harvest-page .cinnamon-dossier .grade-switcher button.is-active,
.harvest-page .cinnamon-dossier .grade-switcher button[aria-selected="true"] {
  background: #fff8ec;
  color: #2b1409;
}

.harvest-page .cinnamon-dossier .spec-note {
  color: rgba(255,248,236,.78);
}

@media (max-width: 900px) {
  .product-photo-grid,
  .product-photo-grid.reverse {
    grid-template-columns: 1fr;
  }

  .product-photo-card,
  .harvest-proof-card,
  .product-photo-card img {
    min-height: 300px;
  }
}
