/* ===================================================================
   GUIZAR HONEY BEES — ethereal system
   Light & dark themes · luminous atmosphere · gossamer surfaces
=================================================================== */

/* ---------- TOKENS ---------- */
:root{
  /* LIGHT — sun through haze */
  --bg:#F4ECDC;
  --bg-2:#FBF5E9;
  --ink:#2B2117;
  --muted:#73664F;
  --muted-2:#A99A82;
  --gold-pure:#EBA834;
  --gold-soft-pure:#FAD681;
  --accent-pure:#9A5E12;
  --teal-base:#2C9FB8;
  --teal-soft:#86D8E8;
  --teal-deep:#0C6175;
  --teal-amt:0.25;
  /* TEAL SPREAD — one 0..1 slider sweeps teal across the whole site, with NO
     dead zone: every drag visibly recolors something.
     ramp-core: dedicated teal accents reach full teal by .10 (instant feedback).
     ramp-min : small accents (eyebrows, bullets, accent text) convert .10 -> .40.
     ramp-maj : major fills (buttons, brand, hero/honey gradients) convert .25 -> 1.
     ~.25 = the legacy "teal only on accents" look; push toward 1 for a fully
     teal-forward site. Below .25 the big elements stay gold. */
  --ramp-core:clamp(0,calc(var(--teal-amt)/0.1),1);
  --ramp-min:clamp(0,calc((var(--teal-amt) - 0.1)/0.3),1);
  --ramp-maj:clamp(0,calc((var(--teal-amt) - 0.25)/0.75),1);
  --teal:color-mix(in oklch,var(--teal-base) calc(var(--ramp-core)*100%),var(--gold-pure));
  --gold:color-mix(in oklch,var(--teal-base) calc(var(--ramp-maj)*100%),var(--gold-pure));
  --gold-soft:color-mix(in oklch,var(--teal-soft) calc(var(--ramp-maj)*100%),var(--gold-soft-pure));
  --accent-strong:color-mix(in oklch,var(--teal-deep) calc(var(--ramp-min)*100%),var(--accent-pure));
  /* window trim / casing around photo portals */
  --trim:color-mix(in oklab,var(--gold-pure) 15%,var(--bg-2));
  --trim-line:color-mix(in oklab,var(--gold-pure) 45%,var(--hair));
  --glass:rgba(255,253,247,.50);
  --glass-2:rgba(255,253,247,.32);
  --hair:rgba(120,90,40,.18);
  --edge-hi:rgba(255,255,255,.65);
  --shadow:42px 60px 90px -50px rgba(120,80,20,.40);
  --nav-bg:rgba(244,236,220,.66);
  --scrim:rgba(244,236,220,.95);
  --chip-bg:rgba(255,253,247,.62);
  --img-grad:radial-gradient(120% 95% at 70% 8%,rgba(244,184,68,.88),transparent 56%),
             radial-gradient(90% 90% at 14% 104%,rgba(120,182,92,.32),transparent 62%),
             linear-gradient(165deg,#F3CE72,#FAEDC4 76%);

  --atmos:1;
  --glow:1;
  --font-display:'Cormorant Garamond',Georgia,serif;
  --font-body:'Space Grotesk',system-ui,sans-serif;
  --font-mono:'JetBrains Mono',ui-monospace,monospace;
  --maxw:1240px;
  --pad:clamp(22px,5vw,52px);
}
html[data-theme="dark"]{
  /* DARK — red-lit night work */
  --bg:#0B0A09;
  --bg-2:#120E0A;
  --ink:#F2ECDF;
  --muted:#A99E8C;
  --muted-2:#6E6557;
  --gold-pure:#FF5347;
  --gold-soft-pure:#FF9C8F;
  --accent-pure:#FF8B7B;
  --teal-base:#36D6EE;
  --teal-soft:#8BE7F5;
  --teal-deep:#5FE0F2;
  --trim:color-mix(in oklab,var(--gold-pure) 16%,#14100C);
  --trim-line:color-mix(in oklab,var(--gold-pure) 30%,var(--hair));
  --glass:rgba(28,25,22,.46);
  --glass-2:rgba(28,25,22,.30);
  --hair:rgba(255,228,170,.13);
  --edge-hi:rgba(255,238,205,.10);
  --shadow:42px 60px 100px -50px rgba(0,0,0,.75);
  --nav-bg:rgba(11,10,9,.66);
  --scrim:rgba(11,10,9,.95);
  --chip-bg:rgba(11,10,9,.55);
  --img-grad:radial-gradient(58% 44% at 70% 32%,rgba(255,83,71,.32),transparent 56%),
             radial-gradient(130% 100% at 16% 104%,rgba(54,214,238,.10),transparent 62%),
             linear-gradient(165deg,#160C0B,#0A0B0E 74%);
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  background:
    radial-gradient(140% 80% at 50% -10%,var(--bg-2),transparent 60%),
    var(--bg);
  color:var(--ink);
  font-family:var(--font-body);
  font-weight:300;
  line-height:1.65;
  letter-spacing:.005em;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
  transition:background .6s ease,color .6s ease;
}
@media (prefers-reduced-motion:reduce){html{scroll-behavior:auto}}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
::selection{background:var(--gold);color:#1A1206}

/* ---------- ATMOSPHERE LAYERS ---------- */
.atmos{position:fixed;inset:0;z-index:0;pointer-events:none}
.atmos::before{
  content:"";position:absolute;inset:-10%;
  background:
    radial-gradient(46% 42% at 78% 6%,color-mix(in oklab,var(--gold) 46%,transparent),transparent 70%),
    radial-gradient(44% 40% at 8% 26%,color-mix(in oklab,var(--teal) 16%,transparent),transparent 72%),
    radial-gradient(70% 58% at 52% 116%,color-mix(in oklab,var(--gold) 30%,transparent),transparent 72%);
  opacity:calc(.55*var(--atmos));
  filter:blur(28px);
  animation:breathe 16s ease-in-out infinite;
}
.atmos::after{ /* faint hex constellation */
  content:"";position:absolute;inset:0;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='180' height='312' viewBox='0 0 180 312'%3E%3Cg fill='none' stroke='%23C9912E' stroke-width='1'%3E%3Cpath d='M90 4l74 43v86l-74 43-74-43V47z'/%3E%3C/g%3E%3C/svg%3E");
  background-size:300px 520px;
  opacity:calc(.05*var(--atmos));
}
@keyframes breathe{0%,100%{opacity:calc(.5*var(--atmos))}50%{opacity:calc(.66*var(--atmos))}}

.motes{position:fixed;inset:0;z-index:1;pointer-events:none;overflow:hidden}
.mote{
  position:absolute;border-radius:50%;
  background:radial-gradient(circle,var(--gold-soft),transparent 68%);
  filter:blur(.5px);opacity:0;
  animation:drift linear infinite;
}
@keyframes drift{
  0%{transform:translateY(40px) translateX(0) scale(.8);opacity:0}
  12%{opacity:.55}
  55%{opacity:.42}
  88%{opacity:.18}
  100%{transform:translateY(-160px) translateX(34px) scale(1);opacity:0}
}

.grain{
  position:fixed;inset:0;z-index:2;pointer-events:none;
  opacity:.42;mix-blend-mode:soft-light;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='220' height='220'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.82' numOctaves='2' stitchTiles='stitch'/%3E%3CfeColorMatrix type='saturate' values='0'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}
html[data-theme="dark"] .grain{opacity:.30}

@media (prefers-reduced-motion:reduce){
  .atmos::before{animation:none}
  .mote{animation:none;opacity:0}
}

/* ---------- SHELL ---------- */
.wrap{max-width:var(--maxw);margin:0 auto;padding-inline:var(--pad)}
section{position:relative;z-index:3}
footer{position:relative;z-index:3}
.section-pad{padding-block:clamp(92px,15vw,168px)}

/* ---------- TYPE ---------- */
.eyebrow{
  font-family:var(--font-mono);font-size:11.5px;letter-spacing:.32em;
  text-transform:uppercase;color:var(--accent-strong);
  display:inline-flex;align-items:center;gap:11px;font-weight:400;
}
.eyebrow::before{
  content:"";width:18px;height:1px;background:currentColor;opacity:.55;
}
.eyebrow.teal{color:var(--teal)}

h1,h2,h3{font-family:var(--font-display);font-weight:400;letter-spacing:-.012em;line-height:1.02}
h2{font-size:clamp(36px,7vw,68px);font-weight:400}
.lead{
  font-size:clamp(17px,2.3vw,21px);color:var(--muted);
  max-width:56ch;line-height:1.72;font-weight:300;
}
.sec-head{max-width:64ch}
.sec-head h2{margin:20px 0 22px}

/* ---------- GLASS UTILITY ---------- */
.glass{
  position:relative;border-radius:20px;
  background:
    linear-gradient(var(--glass),var(--glass)) padding-box,
    linear-gradient(160deg,var(--edge-hi),transparent 40%,transparent 70%,var(--hair)) border-box;
  border:1px solid transparent;
  backdrop-filter:blur(14px) saturate(118%);
  -webkit-backdrop-filter:blur(14px) saturate(118%);
  box-shadow:var(--shadow);
}

/* ---------- BUTTONS ---------- */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:11px;
  font-family:var(--font-body);font-weight:400;font-size:15.5px;letter-spacing:.01em;
  padding:16px 30px;border-radius:999px;cursor:pointer;
  color:#34230A;border:1px solid rgba(255,255,255,.30);
  background:linear-gradient(135deg,var(--gold-soft),var(--gold));
  box-shadow:0 14px 40px -16px color-mix(in oklab,var(--gold) 80%,transparent),
             inset 0 1px 0 rgba(255,255,255,.5);
  transition:transform .35s cubic-bezier(.2,.8,.2,1),box-shadow .45s ease;
  min-height:54px;
}
.btn:hover{transform:translateY(-2px);
  box-shadow:0 22px 56px -16px color-mix(in oklab,var(--gold) 90%,transparent),
             inset 0 1px 0 rgba(255,255,255,.6);}
.btn:active{transform:translateY(0)}
.btn .arr{transition:transform .35s ease}
.btn:hover .arr{transform:translate(3px,-3px)}
.btn.ghost{
  background:var(--glass-2);color:var(--ink);
  border:1px solid var(--hair);backdrop-filter:blur(10px);
  box-shadow:inset 0 1px 0 var(--edge-hi);
}
.btn.ghost:hover{border-color:color-mix(in oklab,var(--gold) 60%,transparent);
  box-shadow:inset 0 1px 0 var(--edge-hi),0 14px 36px -20px color-mix(in oklab,var(--gold) 70%,transparent);}

/* ---------- NAV ---------- */
header.nav{position:fixed;top:0;left:0;right:0;z-index:50;
  transition:background .4s ease,backdrop-filter .4s ease,border-color .4s ease;
  border-bottom:1px solid transparent;}
header.nav.scrolled{
  background:var(--nav-bg);
  backdrop-filter:blur(18px) saturate(135%);
  -webkit-backdrop-filter:blur(18px) saturate(135%);
  border-bottom-color:var(--hair);
}
.nav-inner{display:flex;align-items:center;justify-content:space-between;height:78px}
.brand{display:flex;align-items:center;gap:13px;font-family:var(--font-display);
  font-weight:500;font-size:21px;letter-spacing:.005em;white-space:nowrap}
.brand .mark{width:24px;height:28px;flex:none;position:relative;
  background:linear-gradient(150deg,var(--gold-soft),var(--gold));
  clip-path:polygon(50% 0,100% 25%,100% 75%,50% 100%,0 75%,0 25%);
  box-shadow:0 0 calc(18px*var(--glow)) -2px color-mix(in oklab,var(--gold) 70%,transparent);}
.brand .mark::after{content:"";position:absolute;inset:5px;background:var(--bg);
  clip-path:polygon(50% 0,100% 25%,100% 75%,50% 100%,0 75%,0 25%)}
.brand .mark::before{content:"";position:absolute;inset:9px;z-index:1;
  background:linear-gradient(150deg,var(--gold-soft),var(--gold));
  clip-path:polygon(50% 0,100% 25%,100% 75%,50% 100%,0 75%,0 25%)}
.nav-links{display:flex;align-items:center;gap:34px;list-style:none}
.nav-links a{font-size:14.5px;color:var(--muted);transition:color .3s ease;position:relative;font-weight:400}
.nav-links a::after{content:"";position:absolute;left:0;right:100%;bottom:-6px;height:1px;
  background:var(--gold);transition:right .35s ease;opacity:.8}
.nav-links a:hover{color:var(--ink)}
.nav-links a:hover::after{right:0}
.nav-right{display:flex;align-items:center;gap:16px}
.nav-cta .btn{padding:12px 24px;min-height:0;font-size:14px}

/* theme toggle */
.theme-toggle{position:relative;width:62px;height:30px;border-radius:999px;
  border:1px solid var(--hair);background:var(--glass-2);cursor:pointer;flex:none;padding:0;
  backdrop-filter:blur(8px);transition:border-color .3s ease}
.theme-toggle:hover{border-color:color-mix(in oklab,var(--gold) 55%,transparent)}
.theme-toggle .ti{position:absolute;top:50%;transform:translateY(-50%);width:11px;height:11px;z-index:1}
.theme-toggle .sun{left:10px;border-radius:50%;background:var(--accent-strong);
  box-shadow:0 0 6px color-mix(in oklab,var(--gold) 60%,transparent)}
.theme-toggle .moon{right:10px;border-radius:50%;box-shadow:inset -3px -1px 0 0 var(--muted)}
.theme-toggle .knob{position:absolute;top:3px;left:3px;width:24px;height:24px;border-radius:50%;
  background:linear-gradient(150deg,var(--gold-soft),var(--gold));
  box-shadow:0 2px 10px color-mix(in oklab,var(--gold) 60%,transparent);
  transition:transform .4s cubic-bezier(.3,1.2,.4,1);z-index:2}
html[data-theme="dark"] .theme-toggle .knob{transform:translateX(32px)}

.burger{display:none;width:46px;height:46px;align-items:center;justify-content:center;
  background:var(--glass-2);border:1px solid var(--hair);border-radius:13px;cursor:pointer;backdrop-filter:blur(8px)}
.burger span{display:block;width:18px;height:1.5px;background:var(--ink);position:relative;transition:.3s}
.burger span::before,.burger span::after{content:"";position:absolute;left:0;width:18px;height:1.5px;background:var(--ink);transition:.3s}
.burger span::before{top:-6px}.burger span::after{top:6px}
body.menu-open .burger span{background:transparent}
body.menu-open .burger span::before{top:0;transform:rotate(45deg)}
body.menu-open .burger span::after{top:0;transform:rotate(-45deg)}

.drawer{position:fixed;inset:0;z-index:45;background:var(--scrim);
  backdrop-filter:blur(12px);display:flex;flex-direction:column;justify-content:center;gap:6px;
  padding:0 var(--pad);opacity:0;visibility:hidden;transition:opacity .4s ease,visibility .4s}
body.menu-open .drawer{opacity:1;visibility:visible}
.drawer a{font-family:var(--font-display);font-weight:400;font-size:clamp(32px,9vw,46px);
  padding:16px 0;border-bottom:1px solid var(--hair);color:var(--ink);
  display:flex;align-items:baseline;justify-content:space-between}
.drawer a .idx{font-family:var(--font-mono);font-size:12px;color:var(--accent-strong);font-weight:400;letter-spacing:.2em}
.drawer .btn{margin-top:30px;align-self:flex-start;
  font-family:var(--font-body);font-size:16px;font-weight:400;
  padding:16px 30px;border-bottom:none;white-space:nowrap;
  display:inline-flex;justify-content:center;}

/* ---------- IMAGE PLACEHOLDERS ---------- */
.ph{position:relative;border-radius:22px;overflow:hidden;isolation:isolate;
  box-shadow:var(--shadow),0 0 0 1px var(--trim-line)}
.ph::after{content:"";position:absolute;inset:0;z-index:1;background:var(--img-grad);
  border-radius:inherit;box-shadow:inset 0 0 0 1px var(--trim-line)}
.ph::before{content:"";position:absolute;inset:0;z-index:2;
  background:repeating-linear-gradient(135deg,rgba(255,255,255,.05) 0 1px,transparent 1px 13px);
  mix-blend-mode:overlay}
.ph .tag{position:absolute;left:16px;bottom:16px;z-index:3;font-family:var(--font-mono);
  font-size:10.5px;letter-spacing:.06em;color:var(--ink);background:var(--chip-bg);
  padding:6px 12px;border-radius:8px;border:1px solid var(--hair);backdrop-filter:blur(6px)}
.ph .tag.t-dark{display:none}
html[data-theme="dark"] .ph .tag.t-light{display:none}
html[data-theme="dark"] .ph .tag.t-dark{display:block}
/* inner light bloom inside portals */
.ph .bloom{position:absolute;inset:0;z-index:2;pointer-events:none;transform:translateZ(0);
  background:radial-gradient(42% 34% at 50% 30%,rgba(255,238,198,.26),transparent 72%);
  mix-blend-mode:screen}
html[data-theme="dark"] .ph .bloom{background:radial-gradient(46% 38% at 50% 30%,rgba(255,150,140,.28),transparent 72%)}
/* real photo dropped into a portal — keeps frame, glow & atmosphere, drops the striped fill */
.ph--photo img{position:absolute;inset:0;z-index:0;width:100%;height:100%;object-fit:cover;display:block;
  opacity:0;transition:opacity 1.2s ease}
.ph--photo img.is-active{opacity:1}
@media (prefers-reduced-motion:reduce){.ph--photo img{transition:none}}
.ph--photo::before{display:none}
.ph--photo::after{background:
  radial-gradient(120% 80% at 50% -8%,rgba(255,238,198,.18),transparent 60%),
  linear-gradient(180deg,transparent 52%,rgba(20,14,6,.34))}
html[data-theme="dark"] .ph--photo::after{background:
  radial-gradient(120% 80% at 50% -8%,rgba(255,150,140,.10),transparent 58%),
  linear-gradient(180deg,transparent 40%,rgba(6,5,4,.55))}

/* ---------- HERO ---------- */
.hero{padding-top:clamp(150px,22vw,210px);overflow:visible}
.hero-grid{display:grid;gap:clamp(40px,7vw,72px);grid-template-columns:1fr;align-items:center}
.hero-copy h1{
  font-size:clamp(56px,13.5vw,128px);font-weight:300;line-height:.9;
  letter-spacing:-.025em;margin:22px 0 0;
}
.hero-copy h1 .it{
  display:block;font-style:italic;font-weight:500;line-height:1.04;padding-bottom:.09em;
  background:linear-gradient(102deg,var(--gold) 0%,var(--gold-soft) 45%,var(--gold) 90%);
  background-size:220% 100%;-webkit-background-clip:text;background-clip:text;color:transparent;
  filter:drop-shadow(0 4px calc(30px*var(--glow)) color-mix(in oklab,var(--gold) 45%,transparent));
  animation:sheen 9s ease-in-out infinite;
}
@keyframes sheen{0%,100%{background-position:0% 50%}50%{background-position:100% 50%}}
.hero-sub{margin-top:30px;font-size:clamp(18px,2.7vw,23px);color:var(--muted);
  max-width:34ch;line-height:1.62;font-weight:300}
.hero-actions{display:flex;flex-wrap:wrap;gap:14px;margin-top:38px}
.hero-stats{display:flex;flex-wrap:wrap;gap:0;margin-top:52px;border-top:1px solid var(--hair)}
.stat{padding:26px 30px 0 0}
.stat:not(:last-child){border-right:1px solid var(--hair);margin-right:30px}
.stat .num{font-family:var(--font-display);font-weight:400;font-size:clamp(26px,4vw,34px);
  color:var(--ink);letter-spacing:-.01em;line-height:1}
.stat .num em{font-style:italic;color:var(--accent-strong)}
.stat .lab{font-family:var(--font-mono);font-size:10px;letter-spacing:.18em;
  text-transform:uppercase;color:var(--muted-2);margin-top:9px}
.hero-media{position:relative}
.hero-media .ph{aspect-ratio:4/5;min-height:380px;animation:floaty 9s ease-in-out infinite;
  will-change:transform;transform:translateZ(0);backface-visibility:hidden}
@keyframes floaty{0%,100%{transform:translateY(0)}50%{transform:translateY(-14px)}}
.hero-media .float{position:absolute;right:-10px;bottom:34px;z-index:4;
  padding:15px 18px;display:flex;align-items:center;gap:13px;max-width:236px;border-radius:16px}
.hero-media .float .dot{width:9px;height:9px;border-radius:50%;background:var(--teal);
  box-shadow:0 0 0 5px color-mix(in oklab,var(--teal) 20%,transparent);flex:none;
  animation:pulse 2.6s ease-in-out infinite}
.hero-media .float .t{font-family:var(--font-mono);font-size:10px;letter-spacing:.08em;color:var(--muted);text-transform:uppercase}
.hero-media .float .t b{display:block;font-family:var(--font-display);font-weight:500;font-size:16px;
  letter-spacing:0;text-transform:none;color:var(--ink);margin-top:3px}
@media (prefers-reduced-motion:reduce){
  .hero-media .ph,.hero-copy h1 .it{animation:none}
}

/* ---------- POLLINATION ---------- */
.crops{display:grid;gap:18px;margin-top:56px;grid-template-columns:repeat(2,1fr)}
.crop{padding:30px 26px 32px;transition:transform .45s cubic-bezier(.2,.8,.2,1),box-shadow .45s ease}
.crop:hover{transform:translateY(-6px)}
.crop .ix{width:42px;height:48px;margin-bottom:20px;position:relative;
  display:flex;align-items:center;justify-content:center}
.crop .ix::before{content:"";position:absolute;inset:0;
  background:linear-gradient(150deg,var(--gold-soft),var(--gold));
  clip-path:polygon(50% 0,100% 25%,100% 75%,50% 100%,0 75%,0 25%)}
.crop .ix::after{content:"";position:absolute;inset:1.5px;background:var(--glass);
  backdrop-filter:blur(4px);clip-path:polygon(50% 0,100% 25%,100% 75%,50% 100%,0 75%,0 25%)}
.crop .ix span{position:relative;z-index:1;font-family:var(--font-mono);font-size:12px;color:var(--accent-strong)}
.crop h3{font-size:25px;font-weight:500;margin-bottom:9px}
.crop p{font-size:14.5px;color:var(--muted);line-height:1.6;font-weight:300}
.crop .k{font-family:var(--font-mono);font-size:9.5px;letter-spacing:.16em;color:var(--muted-2);
  text-transform:uppercase;margin-top:18px;display:flex;align-items:center;gap:8px}
.crop .go{margin-left:auto;color:var(--accent-strong);opacity:0;transform:translate(-4px,4px);
  font-size:13px;transition:opacity .35s ease,transform .35s ease}
.crop:hover{transform:translateY(-6px)}
.crop:hover .go{opacity:1;transform:none}
.crop:focus-visible{outline:2px solid var(--accent-strong);outline-offset:3px}
.reliability{display:flex;flex-wrap:wrap;gap:20px;margin-top:30px;padding:30px 34px;align-items:center}
.reliability .big{font-family:var(--font-display);font-weight:400;font-size:clamp(20px,2.7vw,26px);
  flex:1;min-width:260px;line-height:1.4}
.reliability .big em{font-style:italic;color:var(--accent-strong)}

/* ---------- HONEY ---------- */
.honey{border-block:1px solid var(--hair);overflow:hidden}
.honey-grid{display:grid;gap:clamp(40px,7vw,80px);grid-template-columns:1fr;align-items:center}
.honey-media{position:relative;order:-1}
.honey-media .ph{aspect-ratio:1/1;min-height:340px}
.honey-media .ph::after{background:
  radial-gradient(95% 72% at 50% 10%,rgba(242,176,46,.96),transparent 62%),
  radial-gradient(80% 64% at 50% 104%,rgba(196,118,18,.62),transparent 72%),
  linear-gradient(165deg,#E9A930,#C7821A 82%)}
html[data-theme="dark"] .honey-media .ph::after{background:
  radial-gradient(62% 48% at 50% 28%,rgba(255,83,71,.42),transparent 58%),
  radial-gradient(120% 100% at 16% 108%,rgba(54,214,238,.10),transparent 60%),
  linear-gradient(165deg,#170D0A,#0B0A0A 76%)}
/* real photo in the honey portal — keep the soft vignette, drop the golden fill */
.honey-media .ph--photo::after{background:
  radial-gradient(120% 80% at 50% -8%,rgba(255,238,198,.18),transparent 60%),
  linear-gradient(180deg,transparent 52%,rgba(20,14,6,.34))}
html[data-theme="dark"] .honey-media .ph--photo::after{background:
  radial-gradient(120% 80% at 50% -8%,rgba(255,150,140,.10),transparent 58%),
  linear-gradient(180deg,transparent 40%,rgba(6,5,4,.55))}
.honey-media .jars{position:absolute;inset:0;z-index:3;display:flex;align-items:flex-end;
  justify-content:center;gap:16px;padding:42px}
.jar{width:78px;border-radius:8px 8px 12px 12px;position:relative;
  background:linear-gradient(180deg,#FCD980,#D9920A 78%);
  box-shadow:inset 0 0 22px rgba(120,60,0,.45),0 26px 40px -18px rgba(60,30,0,.6);}
.jar::before{content:"";position:absolute;left:15px;right:15px;top:-10px;height:12px;
  border-radius:5px;background:#3A332C;border:1px solid #4A423A}
.jar .lbl{position:absolute;left:8px;right:8px;bottom:16px;background:rgba(250,246,236,.94);
  border-radius:4px;padding:6px 3px;text-align:center}
.jar .lbl b{display:block;font-family:var(--font-display);font-size:9px;color:#5A3A0A;font-weight:600;letter-spacing:.04em}
.jar .lbl span{font-family:var(--font-mono);font-size:6px;color:#8A6A2A;letter-spacing:.06em}
.jar.s1{height:138px}.jar.s2{height:184px}.jar.s3{height:114px}
.honey-copy h2{margin:20px 0 4px;font-size:clamp(40px,8.5vw,78px);line-height:.95}
.honey-copy h2 .sig{display:block;font-style:italic;font-weight:500;line-height:1.04;padding-bottom:.07em;
  background:linear-gradient(102deg,var(--gold),var(--gold-soft) 60%,var(--gold));
  background-size:200% 100%;-webkit-background-clip:text;background-clip:text;color:transparent;
  filter:drop-shadow(0 4px calc(26px*var(--glow)) color-mix(in oklab,var(--gold) 40%,transparent));
  animation:sheen 9s ease-in-out infinite}
.honey-facts{display:grid;margin:30px 0 32px;border-top:1px solid var(--hair)}
.fact{display:flex;gap:20px;padding:20px 0;border-bottom:1px solid var(--hair);align-items:baseline}
.fact .ft{font-family:var(--font-mono);font-size:10px;letter-spacing:.18em;text-transform:uppercase;
  color:var(--accent-strong);flex:none;width:128px;padding-top:4px}
.fact .fv{font-size:16px;color:var(--ink);line-height:1.55;font-weight:300}
.fact .fv small{color:var(--muted);font-size:14px}
.honey-cta{display:flex;flex-wrap:wrap;gap:14px;align-items:center}
.honey-note{font-family:var(--font-mono);font-size:11px;color:var(--muted-2);letter-spacing:.04em}

/* ---------- STORY ---------- */
.story{overflow:hidden}
.story-inner{display:grid;gap:clamp(34px,6vw,64px);grid-template-columns:1fr;align-items:center}
.story blockquote{font-family:var(--font-display);font-weight:300;
  font-size:clamp(28px,5.2vw,46px);line-height:1.24;letter-spacing:-.012em}
.story blockquote em{font-style:italic;color:var(--accent-strong);font-weight:400}
.story .by{font-family:var(--font-mono);font-size:11px;letter-spacing:.2em;
  text-transform:uppercase;color:var(--muted-2);margin-top:28px}
.story-media .ph{aspect-ratio:5/4;min-height:260px}

/* ---------- STEWARDSHIP ---------- */
.panel{margin-top:50px;display:grid;grid-template-columns:1fr;overflow:hidden;border-radius:24px}
.panel-viz{padding:32px}
.dash-row{display:flex;justify-content:space-between;align-items:center;
  font-family:var(--font-mono);font-size:10px;letter-spacing:.16em;text-transform:uppercase;color:var(--muted);margin-bottom:18px}
.dash-row .live{display:flex;align-items:center;gap:8px;color:var(--teal)}
.dash-row .live .d{width:6px;height:6px;border-radius:50%;background:var(--teal);
  box-shadow:0 0 calc(8px*var(--glow)) var(--teal);animation:pulse 2.2s infinite}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.35}}
.bars{display:flex;align-items:flex-end;gap:7px;height:104px;margin:8px 0 4px}
.bars i{flex:1;background:linear-gradient(180deg,var(--teal),color-mix(in oklab,var(--teal) 20%,transparent));
  border-radius:4px 4px 0 0;min-height:10px;box-shadow:0 0 calc(14px*var(--glow)) -4px var(--teal)}
.metrics{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin-top:22px}
.metric{background:var(--glass-2);border:1px solid var(--hair);border-radius:14px;padding:15px;backdrop-filter:blur(6px)}
.metric .mv{font-family:var(--font-display);font-weight:500;font-size:24px;color:var(--ink);line-height:1}
.metric .mv.good{color:var(--teal)}
.metric .ml{font-family:var(--font-mono);font-size:9px;letter-spacing:.12em;text-transform:uppercase;color:var(--muted-2);margin-top:6px}
.panel-copy{padding:32px}
.stew-list{list-style:none;margin-top:22px;display:grid}
.stew-list li{display:flex;gap:16px;padding:17px 0;border-top:1px solid var(--hair);align-items:flex-start}
.stew-list li:first-child{border-top:none}
.stew-list .hx{width:10px;height:12px;margin-top:7px;flex:none;background:var(--teal);
  clip-path:polygon(50% 0,100% 25%,100% 75%,50% 100%,0 75%,0 25%);box-shadow:0 0 calc(10px*var(--glow)) -2px var(--teal)}
.stew-list b{font-family:var(--font-display);font-weight:500;font-size:19px;display:block;margin-bottom:3px}
.stew-list span{font-size:14.5px;color:var(--muted);line-height:1.6;font-weight:300}

/* ---------- CONTACT ---------- */
.contact-grid{display:grid;gap:clamp(36px,6vw,64px);grid-template-columns:1fr}
.form{display:grid;gap:18px;margin-top:36px}
.field{display:grid;gap:9px}
.field label{font-family:var(--font-mono);font-size:10px;letter-spacing:.18em;text-transform:uppercase;color:var(--muted)}
.field input,.field textarea{width:100%;background:var(--glass-2);border:1px solid var(--hair);
  border-radius:14px;padding:16px 17px;color:var(--ink);font-family:var(--font-body);
  font-size:16px;font-weight:300;resize:vertical;backdrop-filter:blur(6px);
  transition:border-color .3s ease,box-shadow .3s ease}
.field input::placeholder,.field textarea::placeholder{color:var(--muted-2)}
.field input:focus,.field textarea:focus{outline:none;
  border-color:color-mix(in oklab,var(--gold) 60%,transparent);
  box-shadow:0 0 0 4px color-mix(in oklab,var(--gold) 14%,transparent)}
.field.err input,.field.err textarea{border-color:#D9603E}
.field .msg{font-family:var(--font-mono);font-size:10.5px;color:#D9603E;min-height:13px;letter-spacing:.03em}
.form .btn{margin-top:6px;width:100%}
.form-success{display:none;text-align:center;padding:48px 28px;border-radius:22px;margin-top:36px}
.form-success.show{display:block;animation:rise .6s ease both}
.form-success .check{width:58px;height:64px;margin:0 auto 22px;
  background:linear-gradient(150deg,var(--gold-soft),var(--gold));
  clip-path:polygon(50% 0,100% 25%,100% 75%,50% 100%,0 75%,0 25%);
  display:flex;align-items:center;justify-content:center;color:#34230A;font-size:24px;
  box-shadow:0 0 calc(30px*var(--glow)) -6px color-mix(in oklab,var(--gold) 70%,transparent)}
.form-success h3{font-size:28px;font-weight:500;margin-bottom:10px}
.form-success p{color:var(--muted);font-size:15px;font-weight:300;max-width:42ch;margin:0 auto}

.contact-side{display:flex;flex-direction:column;gap:24px}
.cline{display:flex;align-items:center;gap:16px;padding:20px 22px;border-radius:18px;transition:transform .35s ease}
.cline:hover{transform:translateY(-3px)}
.cline .ci{width:42px;height:48px;flex:none;position:relative;display:flex;align-items:center;justify-content:center}
.cline .ci::before{content:"";position:absolute;inset:0;background:color-mix(in oklab,var(--gold) 16%,transparent);
  border:1px solid color-mix(in oklab,var(--gold) 40%,transparent);
  clip-path:polygon(50% 0,100% 25%,100% 75%,50% 100%,0 75%,0 25%)}
.cline .ci span{position:relative;z-index:1;font-family:var(--font-mono);font-size:16px;color:var(--accent-strong)}
.cline .cc small{font-family:var(--font-mono);font-size:9.5px;letter-spacing:.16em;text-transform:uppercase;color:var(--muted-2);display:block;margin-bottom:3px}
.cline .cc b{font-family:var(--font-display);font-weight:500;font-size:18px;color:var(--ink)}
.socials{display:flex;gap:12px;flex-wrap:wrap;margin-top:16px}
.socials a{flex:1;min-width:130px;display:flex;align-items:center;gap:11px;padding:16px 18px;
  border-radius:14px;font-size:14px;color:var(--muted);transition:.35s;
  background:var(--glass-2);border:1px solid var(--hair);backdrop-filter:blur(8px)}
.socials a:hover{color:var(--ink);transform:translateY(-3px);
  border-color:color-mix(in oklab,var(--gold) 50%,transparent)}
.socials a .sd{width:9px;height:10px;flex:none;background:var(--gold);
  clip-path:polygon(50% 0,100% 25%,100% 75%,50% 100%,0 75%,0 25%)}

/* ---------- FOOTER ---------- */
footer{border-top:1px solid var(--hair);padding-block:48px}
/* crop-page footer: extra breathing room above the line */
main + footer{margin-top:clamp(40px,6vw,72px)}
/* relocated colony-health badge, stamped on the stewardship dashboard */
.stewardship .panel{position:relative}
.stew-badge{position:absolute;top:-20px;right:26px;z-index:5;
  padding:15px 18px;display:flex;align-items:center;gap:13px;max-width:236px;border-radius:16px}
.stew-badge .dot{width:9px;height:9px;border-radius:50%;background:var(--teal);
  box-shadow:0 0 0 5px color-mix(in oklab,var(--teal) 20%,transparent);flex:none;animation:pulse 2.6s ease-in-out infinite}
.stew-badge .t{font-family:var(--font-mono);font-size:10px;letter-spacing:.08em;color:var(--muted);text-transform:uppercase}
.stew-badge .t b{display:block;font-family:var(--font-display);font-weight:500;font-size:16px;letter-spacing:0;text-transform:none;color:var(--ink);margin-top:3px}
@media (max-width:560px){.stew-badge{position:static;margin-bottom:18px;max-width:none}}
.foot-inner{display:flex;flex-wrap:wrap;gap:18px;align-items:center;justify-content:space-between}
.foot-brand{display:flex;align-items:center;gap:12px;font-family:var(--font-display);font-weight:500;font-size:18px}
.foot-meta{font-family:var(--font-mono);font-size:11px;color:var(--muted-2);letter-spacing:.05em;line-height:1.9;margin-top:12px}
.to-top{font-family:var(--font-mono);font-size:11px;letter-spacing:.12em;color:var(--muted);
  display:inline-flex;align-items:center;gap:9px;transition:color .3s}
.to-top:hover{color:var(--accent-strong)}

/* ---------- REVEAL ---------- */
.reveal{opacity:0;transform:translateY(26px);filter:blur(10px);
  transition:opacity 1.1s cubic-bezier(.2,.7,.2,1),transform 1.1s cubic-bezier(.2,.7,.2,1),filter 1.1s ease}
.reveal.in{opacity:1;transform:none;filter:none}
@media (prefers-reduced-motion:reduce){
  .reveal{opacity:1;transform:none;filter:none;transition:none}
  .form-success.show{animation:none}
}
@keyframes rise{from{opacity:0;transform:translateY(16px)}to{opacity:1;transform:none}}

/* ---------- TWEAKS PANEL ---------- */
#tweaks{position:fixed;right:18px;bottom:18px;z-index:90;width:268px;display:none;
  border-radius:18px;padding:6px 18px 18px;color:var(--ink);
  background:var(--scrim);border:1px solid var(--hair);
  backdrop-filter:blur(20px) saturate(140%);box-shadow:var(--shadow);
  font-family:var(--font-body);font-weight:300}
#tweaks.show{display:block;animation:rise .4s ease both}
.tw-head{display:flex;align-items:center;justify-content:space-between;padding:12px 0 14px;
  border-bottom:1px solid var(--hair);margin-bottom:14px}
.tw-head h4{font-family:var(--font-mono);font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:var(--muted);font-weight:400}
.tw-x{width:26px;height:26px;border-radius:8px;border:1px solid var(--hair);background:transparent;
  color:var(--muted);cursor:pointer;font-size:14px;line-height:1}
.tw-x:hover{color:var(--ink)}
.tw-row{margin-bottom:16px}
.tw-row>label{display:block;font-family:var(--font-mono);font-size:9.5px;letter-spacing:.14em;
  text-transform:uppercase;color:var(--muted-2);margin-bottom:9px}
.tw-seg{display:flex;gap:5px;background:var(--glass-2);border:1px solid var(--hair);border-radius:11px;padding:4px}
.tw-seg button{flex:1;border:none;background:transparent;color:var(--muted);cursor:pointer;
  padding:8px 6px;border-radius:8px;font-family:var(--font-body);font-size:12.5px;font-weight:300;transition:.25s}
.tw-seg button.on{background:linear-gradient(135deg,var(--gold-soft),var(--gold));color:#34230A;font-weight:400}
.tw-range{width:100%;-webkit-appearance:none;appearance:none;height:4px;border-radius:3px;
  background:var(--hair);outline:none}
.tw-range::-webkit-slider-thumb{-webkit-appearance:none;width:17px;height:17px;border-radius:50%;
  background:linear-gradient(150deg,var(--gold-soft),var(--gold));cursor:pointer;
  box-shadow:0 0 10px color-mix(in oklab,var(--gold) 60%,transparent)}
.tw-range::-moz-range-thumb{width:17px;height:17px;border:none;border-radius:50%;
  background:var(--gold);cursor:pointer}
.tw-toggle{display:flex;align-items:center;justify-content:space-between}
.tw-sw{width:42px;height:24px;border-radius:999px;border:1px solid var(--hair);background:var(--glass-2);
  position:relative;cursor:pointer;flex:none;transition:.3s}
.tw-sw::after{content:"";position:absolute;top:2px;left:2px;width:18px;height:18px;border-radius:50%;
  background:var(--muted-2);transition:.3s}
.tw-sw.on{background:linear-gradient(135deg,var(--gold-soft),var(--gold))}
.tw-sw.on::after{transform:translateX(18px);background:#fff}
.tw-swatches{display:flex;gap:9px}
.tw-swatch{width:30px;height:30px;border-radius:9px;cursor:pointer;border:2px solid transparent;transition:.2s}
.tw-swatch.on{border-color:var(--ink)}

/* ---------- RESPONSIVE ---------- */
@media (min-width:720px){
  .crops{grid-template-columns:repeat(4,1fr);gap:18px}
}
@media (min-width:960px){
  .nav-links{display:flex}
  .hero-grid{grid-template-columns:1.08fr .92fr}
  .honey-grid{grid-template-columns:.92fr 1.08fr}
  .honey-media{order:0}
  .story-inner{grid-template-columns:1.45fr 1fr}
  .panel{grid-template-columns:1fr 1fr}
  .panel-viz{border-right:1px solid var(--hair)}
  .contact-grid{grid-template-columns:1.08fr .92fr}
}
@media (max-width:959px){
  .nav-links,.nav-cta{display:none}
  .burger{display:flex}
}
@media (max-width:520px){
  .crops{grid-template-columns:1fr 1fr}
  .jar{width:60px}.jar.s1{height:112px}.jar.s2{height:148px}.jar.s3{height:94px}
  .fact{flex-direction:column;gap:6px}.fact .ft{width:auto}
  .hero-stats{gap:0}.stat{padding:22px 18px 0 0}.stat:not(:last-child){margin-right:18px}
  .brand{font-size:17px;gap:10px}.nav-right{gap:10px}.nav-inner{height:70px}
}

/* =================================================================
   CROP PAGES — pollination strategy per crop
================================================================= */
.cp-main{padding-top:clamp(120px,18vw,168px);position:relative;z-index:3}
.cp-section{padding-bottom:clamp(20px,4vw,40px)}

.crumb{display:flex;align-items:center;gap:11px;font-family:var(--font-mono);font-size:11px;
  letter-spacing:.16em;text-transform:uppercase;color:var(--muted-2)}
.crumb a{color:var(--muted);transition:color .3s}
.crumb a:hover{color:var(--accent-strong)}
.crumb .sep{opacity:.45}
.crumb .cur{color:var(--accent-strong)}

.cp-hero{display:grid;gap:clamp(20px,4vw,44px);grid-template-columns:1fr;align-items:end;margin-top:28px}
.season-chip{display:inline-flex;align-items:center;gap:9px;font-family:var(--font-mono);
  font-size:10.5px;letter-spacing:.16em;text-transform:uppercase;color:var(--accent-strong);
  background:var(--chip-bg);border:1px solid var(--hair);padding:8px 15px;border-radius:999px;
  backdrop-filter:blur(6px);width:fit-content}
.season-chip .hx{width:9px;height:11px;flex:none;background:linear-gradient(150deg,var(--gold-soft),var(--gold));
  clip-path:polygon(50% 0,100% 25%,100% 75%,50% 100%,0 75%,0 25%)}
.cp-hero h1{font-family:var(--font-display);font-weight:300;font-size:clamp(50px,11vw,104px);
  line-height:.92;letter-spacing:-.022em;margin:22px 0 0}
.cp-hero h1 .it{font-style:italic;font-weight:500;padding-bottom:.08em;
  background:linear-gradient(102deg,var(--gold),var(--gold-soft) 55%,var(--gold));
  -webkit-background-clip:text;background-clip:text;color:transparent;
  filter:drop-shadow(0 4px calc(26px*var(--glow)) color-mix(in oklab,var(--gold) 40%,transparent))}
.cp-hero .lead{margin-top:26px}
.cp-num{font-family:var(--font-display);font-style:italic;font-weight:500;
  font-size:clamp(70px,13vw,150px);color:var(--gold-soft);opacity:.55;line-height:.74;
  filter:drop-shadow(0 4px calc(30px*var(--glow)) color-mix(in oklab,var(--gold) 30%,transparent))}

.gallery{display:grid;gap:15px;grid-template-columns:repeat(2,1fr);margin-top:clamp(40px,6vw,64px)}
.gallery .ph{aspect-ratio:4/3;min-height:170px}
.gallery .ph:first-child{grid-column:1/-1;aspect-ratio:16/9}

.strategy{margin-top:clamp(64px,9vw,112px)}
.rate-wrap{margin-top:34px;border-radius:20px;overflow:hidden}
table.rate{width:100%;border-collapse:collapse;font-family:var(--font-body)}
table.rate th,table.rate td{text-align:left;padding:18px 24px;border-bottom:1px solid var(--hair);vertical-align:middle}
table.rate thead th{font-family:var(--font-mono);font-size:9.5px;letter-spacing:.16em;text-transform:uppercase;
  color:var(--muted);font-weight:400;background:var(--glass-2)}
table.rate tbody tr:last-child td{border-bottom:none}
table.rate td .lab{font-family:var(--font-display);font-size:21px;font-weight:500;color:var(--ink);display:block}
table.rate td .sub{font-size:13px;color:var(--muted);font-weight:300}
table.rate td.rate-val{font-family:var(--font-display);font-weight:500;font-size:clamp(26px,4vw,38px);
  color:var(--accent-strong);white-space:nowrap;text-align:right}
table.rate td.rate-val small{font-family:var(--font-mono);font-size:9.5px;letter-spacing:.1em;color:var(--muted-2);
  display:block;text-transform:uppercase;font-weight:400;margin-top:3px}
.rate-context{font-size:16.5px;color:var(--muted);line-height:1.72;max-width:66ch;margin-top:26px;font-weight:300}
.rate-context b{color:var(--ink);font-weight:400}

.specs{display:grid;grid-template-columns:repeat(2,1fr);gap:13px;margin-top:30px}
.spec{padding:22px 22px 24px}
.spec .sv{font-family:var(--font-display);font-weight:500;font-size:27px;color:var(--ink);line-height:1}
.spec .sv em{font-style:italic;color:var(--accent-strong)}
.spec .sl{font-family:var(--font-mono);font-size:9px;letter-spacing:.13em;text-transform:uppercase;color:var(--muted-2);margin-top:9px}

.notes{margin-top:clamp(56px,8vw,96px)}
.notes-list{list-style:none;display:grid;margin-top:28px}
.notes-list li{display:flex;gap:17px;padding:20px 0;border-top:1px solid var(--hair);align-items:flex-start}
.notes-list li:first-child{border-top:none}
.notes-list .hx{width:11px;height:13px;margin-top:6px;flex:none;background:var(--gold);
  clip-path:polygon(50% 0,100% 25%,100% 75%,50% 100%,0 75%,0 25%);box-shadow:0 0 calc(10px*var(--glow)) -2px color-mix(in oklab,var(--gold) 65%,transparent)}
.notes-list b{font-family:var(--font-display);font-weight:500;font-size:19.5px;display:block;margin-bottom:4px}
.notes-list span{font-size:14.5px;color:var(--muted);line-height:1.62;font-weight:300}

.research{margin-top:clamp(64px,9vw,112px)}
.research-list{display:grid;gap:13px;margin-top:30px}
.rl{display:flex;gap:18px;align-items:flex-start;padding:22px 26px;border-radius:16px;
  transition:transform .35s ease,border-color .35s ease}
.rl:hover{transform:translateY(-3px)}
.rl .rli{font-family:var(--font-mono);font-size:10px;color:var(--accent-strong);letter-spacing:.1em;flex:none;padding-top:6px;width:30px}
.rl .rlt{flex:1}
.rl .rlt b{font-family:var(--font-display);font-weight:500;font-size:18.5px;display:block;margin-bottom:5px;color:var(--ink);line-height:1.25}
.rl .rlt span{font-size:13.5px;color:var(--muted);line-height:1.55;font-weight:300}
.rl .rlt .src{font-family:var(--font-mono);font-size:9.5px;letter-spacing:.08em;color:var(--muted-2);text-transform:uppercase;margin-top:9px;display:block}
.rl .arr{margin-left:8px;color:var(--muted-2);transition:transform .35s ease,color .35s ease;flex:none;align-self:center;font-size:18px}
.rl:hover .arr{color:var(--accent-strong);transform:translate(3px,-3px)}
.research-note{font-family:var(--font-mono);font-size:11px;color:var(--muted-2);line-height:1.75;margin-top:24px;letter-spacing:.02em;max-width:72ch}

.cropnav{display:flex;justify-content:space-between;gap:16px;margin-top:clamp(56px,8vw,92px);
  border-top:1px solid var(--hair);padding-top:32px}
.cropnav a{display:flex;flex-direction:column;gap:6px;color:var(--muted);transition:color .3s;max-width:48%}
.cropnav a .d{font-family:var(--font-mono);font-size:9.5px;letter-spacing:.16em;text-transform:uppercase;color:var(--muted-2)}
.cropnav a .n{font-family:var(--font-display);font-size:25px;font-weight:500;color:var(--ink);transition:color .3s;line-height:1.1}
.cropnav a:hover .n{color:var(--accent-strong)}
.cropnav a.next{text-align:right;align-items:flex-end;margin-left:auto}

.cta-band{margin-top:clamp(72px,10vw,120px);padding:clamp(38px,6vw,60px);border-radius:24px;
  display:flex;flex-wrap:wrap;gap:26px;align-items:center;justify-content:space-between}
.cta-band .ct{flex:1;min-width:280px}
.cta-band h2{font-size:clamp(30px,4.5vw,46px);font-weight:400;line-height:1.04}
.cta-band h2 em{font-style:italic;color:var(--accent-strong)}
.cta-band p{color:var(--muted);margin-top:14px;font-weight:300;max-width:46ch;font-size:16px}

@media (min-width:760px){
  .cp-hero{grid-template-columns:1fr auto}
  .cp-hero .cp-num{padding-bottom:8px}
  .gallery{grid-template-columns:repeat(3,1fr)}
  .gallery .ph:first-child{grid-column:1/-1;aspect-ratio:21/9}
  .specs{grid-template-columns:repeat(4,1fr)}
}
@media (max-width:520px){
  table.rate th,table.rate td{padding:15px 16px}
  table.rate td.rate-val{font-size:24px}
}

/* split gallery — one tall portrait left, two stacked landscapes right */
.gallery--split{grid-template-columns:1fr}
.gallery--split .ph,
.gallery--split .ph:first-child{grid-column:auto;aspect-ratio:16/9}
.gallery--split .ph.tall{aspect-ratio:3/4}
@media (min-width:760px){
  .gallery--split{grid-template-columns:0.82fr 1.18fr;align-items:stretch}
  .gallery--split .ph.tall,
  .gallery--split .ph:first-child{grid-column:1;grid-row:1/3;aspect-ratio:auto}
  .gallery--split .ph.wide{grid-column:2;aspect-ratio:16/9}
}
