/* =====================================================================
   ECOSABOR TROPICAL — Cinematic Agro-Industrial Experience
   Brand palette: Ecosabor greens · mango gold · avocado · export blue
   Grounded-cinematic (Apple · John Deere · Tesla · Nat Geo)
   ===================================================================== */

:root{
  /* ---- Ink / surface scale (deep green-charcoal) ---- */
  --ink-1000:#070b09;
  --ink-900:#0a0f0c;
  --ink-850:#0d1310;
  --ink-800:#111814;
  --ink-700:#18211c;
  --ink-600:#212c26;
  --ink-500:#2d3a32;

  /* ---- Text ---- */
  --paper:#f8f8f5;
  --text:#e8ece7;
  --muted:#9aa69d;
  --muted-2:#6c776f;
  --faint:rgba(248,248,245,.06);
  --hair:rgba(248,248,245,.12);
  --hair-strong:rgba(248,248,245,.22);

  /* ---- Brand greens ---- */
  --green-deep:#0D5C3B;     /* ecosabor green */
  --green:#1D7A46;          /* tropical green */
  --leaf:#3FAE5A;           /* leaf green */
  --leaf-bright:#5ed079;
  --green-glow:rgba(63,174,90,.5);

  /* ---- Mango (gold) ---- */
  --mango:#F4B400;
  --mango-bright:#ffcd3d;
  --mango-deep:#b98400;
  --mango-glow:rgba(244,180,0,.5);

  /* ---- Avocado ---- */
  --avocado:#7A9E3A;
  --avocado-bright:#a6c95a;
  --avocado-deep:#2b3d16;
  --avocado-glow:rgba(122,158,58,.5);

  /* ---- Export blue (tech / data) ---- */
  --blue:#0EA5E9;
  --blue-bright:#48c4ff;
  --blue-deep:#0c5f86;
  --blue-glow:rgba(14,165,233,.5);

  /* ---- Live accent (scene-themeable) · default = brand green ---- */
  --accent:var(--leaf);
  --accent-bright:var(--leaf-bright);
  --accent-deep:var(--green-deep);
  --accent-glow:var(--green-glow);

  /* ---- Tweakable knobs (set via JS) ---- */
  --fog:0.8;           /* 0..1.4 */
  --particles-vis:1;   /* opacity multiplier for canvas */
  --motion:0.65;       /* 0..1 */

  --maxw:1320px;
  --radius:16px;   /* unified editorial card radius */
  --gut:clamp(20px,5vw,72px);

  --font-display:"Archivo",-apple-system,system-ui,sans-serif;
  --font-mono:"Space Mono","SFMono-Regular",ui-monospace,monospace;
}

/* Scene themes flip the accent set */
[data-theme="green"]{--accent:var(--leaf);--accent-bright:var(--leaf-bright);--accent-deep:var(--green-deep);--accent-glow:var(--green-glow);}
[data-theme="mango"]{--accent:var(--mango);--accent-bright:var(--mango-bright);--accent-deep:var(--mango-deep);--accent-glow:var(--mango-glow);}
[data-theme="avocado"]{--accent:var(--avocado-bright);--accent-bright:var(--avocado-bright);--accent-deep:var(--avocado-deep);--accent-glow:var(--avocado-glow);}
[data-theme="export"]{--accent:var(--blue);--accent-bright:var(--blue-bright);--accent-deep:var(--blue-deep);--accent-glow:var(--blue-glow);}

*{margin:0;padding:0;box-sizing:border-box}
html{-webkit-text-size-adjust:100%;overflow-x:clip}
body{
  background:var(--ink-1000);
  color:var(--text);
  font-family:var(--font-display);
  font-weight:400;
  line-height:1.5;
  letter-spacing:-0.01em;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
img{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
::selection{background:var(--accent);color:var(--ink-1000)}

/* lenis */
html.lenis,html.lenis body{height:auto}
.lenis.lenis-smooth{scroll-behavior:auto!important}

/* =================== Typography =================== */
.eyebrow{
  font-family:var(--font-mono);
  font-size:clamp(11px,.78vw,13px);
  letter-spacing:.32em;
  text-transform:uppercase;
  color:var(--accent);
  font-weight:400;
}
.kicker{
  font-family:var(--font-mono);
  font-size:12px;letter-spacing:.28em;text-transform:uppercase;
  color:var(--muted);
}
h1,h2,h3{
  font-family:var(--font-display);
  font-weight:800;
  line-height:.96;
  letter-spacing:-0.035em;
  font-stretch:118%;
  text-wrap:balance;
}
.display{
  font-size:clamp(44px,8.4vw,148px);
  font-weight:900;
  line-height:.9;
  letter-spacing:-0.045em;
  font-stretch:120%;
}
.h-xl{font-size:clamp(34px,5.6vw,86px)}
.h-lg{font-size:clamp(28px,3.8vw,58px)}
.h-md{font-size:clamp(22px,2.4vw,34px);font-weight:700;letter-spacing:-0.02em}
.lede{
  font-size:clamp(16px,1.45vw,22px);
  line-height:1.5;color:var(--muted);
  font-weight:400;max-width:46ch;letter-spacing:-0.01em;
}
.mono{font-family:var(--font-mono);font-size:13px;letter-spacing:.04em}
em.accent{font-style:normal;color:var(--accent)}

/* gradient text */
.grad{
  background:linear-gradient(98deg,var(--paper) 16%,var(--accent-bright) 92%);
  -webkit-background-clip:text;background-clip:text;color:transparent;
}

/* =================== Layout helpers =================== */
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 var(--gut)}
.stage{position:relative}
section{position:relative}

/* sticky scene scaffold */
.scene{position:relative}
.scene-pin{position:sticky;top:0;height:100vh;overflow:hidden}
.pin-layer{position:relative;height:100vh;overflow:hidden}
.scene-track{position:relative}

/* =================== Atmosphere layers =================== */
.atmos{position:absolute;inset:0;pointer-events:none;overflow:hidden}
.fog{
  position:absolute;inset:-20%;
  background:
    radial-gradient(60% 50% at 22% 18%,rgba(63,174,90,calc(.14*var(--fog))),transparent 70%),
    radial-gradient(70% 60% at 84% 12%,rgba(120,150,160,calc(.10*var(--fog))),transparent 75%),
    radial-gradient(90% 70% at 50% 108%,rgba(7,11,9,.9),transparent 60%);
  mix-blend-mode:screen;opacity:var(--fog);
}
.vignette{
  position:absolute;inset:0;pointer-events:none;
  background:radial-gradient(120% 90% at 50% 36%,transparent 42%,rgba(4,5,6,.62) 88%,rgba(4,5,6,.92) 100%);
}
.grain{
  position:absolute;inset:0;pointer-events:none;opacity:.05;mix-blend-mode:overlay;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='120' height='120'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='2'/></filter><rect width='100%25' height='100%25' filter='url(%23n)' opacity='.5'/></svg>");
}
canvas.fx{position:absolute;inset:0;width:100%;height:100%;display:block;opacity:var(--particles-vis)}

/* image placeholder = stand-in for real plantation renders */
.ph{
  position:relative;overflow:hidden;background:var(--ink-850);
  --p1:#0e1a12;--p2:#0a0f0c;
}
.ph::before{
  content:"";position:absolute;inset:0;
  background:
    radial-gradient(80% 60% at 30% 18%,rgba(244,180,0,.16),transparent 60%),
    radial-gradient(70% 80% at 78% 96%,rgba(29,122,70,.45),transparent 60%),
    linear-gradient(160deg,var(--p1),var(--p2));
}
.ph::after{
  content:"";position:absolute;inset:0;
  background-image:linear-gradient(var(--hair) 1px,transparent 1px),linear-gradient(90deg,var(--hair) 1px,transparent 1px);
  background-size:46px 46px;mask-image:radial-gradient(120% 90% at 50% 30%,#000,transparent 78%);
  opacity:.35;
}
.ph-tag{
  position:absolute;left:14px;bottom:12px;z-index:2;
  font-family:var(--font-mono);font-size:10.5px;letter-spacing:.18em;text-transform:uppercase;
  color:var(--muted-2);display:flex;gap:7px;align-items:center;
}
.ph-tag::before{content:"";width:7px;height:7px;border:1px solid var(--accent);transform:rotate(45deg)}

/* =================== Buttons =================== */
.btn{
  display:inline-flex;align-items:center;gap:.7em;cursor:pointer;
  font-family:var(--font-mono);font-size:13px;letter-spacing:.12em;text-transform:uppercase;
  padding:1.05em 1.7em;border-radius:2px;border:1px solid transparent;
  transition:.5s cubic-bezier(.16,1,.3,1);position:relative;overflow:hidden;
  background:transparent;color:var(--ink-1000);
}
.btn-primary{background:var(--accent);color:var(--ink-1000);font-weight:700}
.btn-primary:hover{background:var(--accent-bright);transform:translateY(-2px);box-shadow:0 14px 40px -12px var(--accent-glow)}
.btn-ghost{border-color:var(--hair-strong);color:var(--text)}
.btn-ghost:hover{border-color:var(--accent);color:var(--accent);transform:translateY(-2px)}
.btn .arr{display:inline-block;transition:transform .5s cubic-bezier(.16,1,.3,1)}
.btn:hover .arr{transform:translateX(5px)}

/* =================== Nav =================== */
.nav{
  position:fixed;top:0;left:0;right:0;z-index:80;
  display:flex;align-items:center;justify-content:space-between;
  padding:18px var(--gut);
  transition:background .5s,backdrop-filter .5s,border-color .5s,padding .5s;
  border-bottom:1px solid transparent;
}
.nav.solid{
  background:rgba(7,8,9,.72);backdrop-filter:blur(18px) saturate(1.2);
  border-bottom:1px solid var(--hair);padding-top:13px;padding-bottom:13px;
}
.brand{display:flex;align-items:center;gap:11px;font-weight:800;letter-spacing:-0.02em;font-size:17px}
.brand .mark{width:24px;height:24px;flex:none}
.brand small{display:block;font-family:var(--font-mono);font-size:8.5px;letter-spacing:.34em;color:var(--muted);font-weight:400;text-transform:uppercase;margin-top:1px}
.nav-links{display:flex;gap:30px;align-items:center}
.nav-links a{font-family:var(--font-mono);font-size:12px;letter-spacing:.14em;text-transform:uppercase;color:var(--muted);transition:.3s;position:relative}
.nav-links a:hover{color:var(--text)}
.nav-right{display:flex;gap:16px;align-items:center}
.lang{
  display:flex;border:1px solid var(--hair);border-radius:2px;overflow:hidden;font-family:var(--font-mono);
}
.lang button{
  background:transparent;border:0;color:var(--muted);cursor:pointer;
  font-family:inherit;font-size:11px;letter-spacing:.1em;padding:7px 11px;transition:.3s;
}
.lang button.on{background:var(--accent);color:var(--ink-1000);font-weight:700}
@media(max-width:880px){.nav-links{display:none}}

/* =================== Preloader =================== */
#preloader{
  position:fixed;inset:0;z-index:200;background:var(--ink-1000);
  display:flex;flex-direction:column;align-items:center;justify-content:center;gap:30px;
  transition:opacity 1s ease,visibility 1s;
}
#preloader.done{opacity:0;visibility:hidden}
.pl-mark{width:64px;height:64px;opacity:.95}
.pl-bar{width:min(320px,60vw);height:1px;background:var(--hair);position:relative;overflow:hidden}
.pl-bar i{position:absolute;left:0;top:0;height:100%;width:0;background:var(--accent);box-shadow:0 0 14px var(--accent-glow)}
.pl-meta{display:flex;justify-content:space-between;width:min(320px,60vw);font-family:var(--font-mono);font-size:11px;letter-spacing:.2em;color:var(--muted)}
.pl-count{color:var(--accent)}

/* =================== Hero =================== */
.hero{height:100vh;min-height:640px;overflow:hidden}
.hero .layer{position:absolute;inset:0;will-change:transform}
.hero-bg{z-index:1}
.hero-mid{z-index:2}
.hero-content{
  position:relative;z-index:6;height:100%;
  display:flex;flex-direction:column;justify-content:flex-end;
  padding:0 var(--gut) clamp(46px,8vh,96px);
}
.hero h1{max-width:14ch}
.hero .lede{margin-top:22px}
.hero-cta{margin-top:34px;display:flex;gap:14px;flex-wrap:wrap}
.hero-foot{
  position:absolute;left:var(--gut);right:var(--gut);bottom:20px;z-index:6;
  display:flex;justify-content:space-between;align-items:flex-end;gap:20px;
  font-family:var(--font-mono);font-size:11px;letter-spacing:.16em;color:var(--muted);text-transform:uppercase;
}
.scroll-cue{display:flex;flex-direction:column;align-items:center;gap:8px}
.scroll-cue .line{width:1px;height:42px;background:linear-gradient(var(--accent),transparent);position:relative;overflow:hidden}
.scroll-cue .line::after{content:"";position:absolute;top:-50%;left:0;width:100%;height:50%;background:var(--accent-bright);animation:cue 1.9s cubic-bezier(.7,0,.3,1) infinite}
@keyframes cue{0%{top:-50%}60%,100%{top:130%}}

/* =================== Data overlays / glass =================== */
.glass{
  background:rgba(16,19,21,.42);
  backdrop-filter:blur(20px) saturate(1.3);
  border:1px solid var(--hair);
  border-radius:4px;
  position:relative;overflow:hidden;
}
.glass::before{content:"";position:absolute;inset:0;background:linear-gradient(135deg,rgba(255,255,255,.06),transparent 42%);pointer-events:none}
.stat{padding:22px 22px 20px}
.stat .num{font-size:clamp(30px,3.4vw,50px);font-weight:900;line-height:1;letter-spacing:-0.04em;font-stretch:120%}
.stat .num em{font-style:normal;color:var(--accent)}
.stat .lbl{font-family:var(--font-mono);font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--muted);margin-top:9px}
.stat .sub{font-size:13px;color:var(--muted-2);margin-top:6px;line-height:1.45}
.corner{position:absolute;width:9px;height:9px;border:1px solid var(--accent);opacity:.7}
.corner.tl{top:8px;left:8px;border-right:0;border-bottom:0}
.corner.tr{top:8px;right:8px;border-left:0;border-bottom:0}
.corner.bl{bottom:8px;left:8px;border-right:0;border-top:0}
.corner.br{bottom:8px;right:8px;border-left:0;border-top:0}

/* readout chip floating */
.chip{
  display:inline-flex;align-items:center;gap:9px;
  font-family:var(--font-mono);font-size:11px;letter-spacing:.12em;text-transform:uppercase;
  padding:8px 13px;border:1px solid var(--hair);border-radius:100px;
  background:rgba(10,12,14,.5);backdrop-filter:blur(10px);color:var(--text);
}
.chip .dot{width:6px;height:6px;border-radius:50%;background:var(--accent);box-shadow:0 0 10px var(--accent-glow)}

/* =================== Generic section header =================== */
.sec{padding:clamp(60px,8vh,104px) 0}
.sec-head{display:flex;flex-direction:column;gap:18px;max-width:60ch}
.sec-num{font-family:var(--font-mono);font-size:12px;letter-spacing:.3em;color:var(--accent)}

/* feature list */
.flist{list-style:none;display:flex;flex-direction:column}
.flist li{
  display:flex;gap:18px;align-items:baseline;padding:18px 0;border-top:1px solid var(--hair);
}
.flist li:last-child{border-bottom:1px solid var(--hair)}
.flist .fi{font-family:var(--font-mono);font-size:12px;color:var(--accent);min-width:34px}
.flist .ft{font-size:clamp(17px,1.5vw,21px);font-weight:600;letter-spacing:-0.01em}
.flist .fd{font-size:14px;color:var(--muted);margin-top:4px;line-height:1.5}
.flist .fcol{flex:1}

/* =================== Network canvas section =================== */
.net-wrap{position:relative;height:100vh;min-height:620px}
.net-legend{position:absolute;right:var(--gut);top:clamp(96px,15vh,156px);z-index:5;display:flex;flex-direction:column;gap:9px;align-items:flex-start;padding:13px 15px;border:1px solid var(--hair);border-radius:8px;background:rgba(10,12,14,.42);backdrop-filter:blur(12px) saturate(1.4);-webkit-backdrop-filter:blur(12px) saturate(1.4)}
.leg{display:flex;align-items:center;gap:10px;font-family:var(--font-mono);font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--muted)}
.leg b{width:9px;height:9px;border-radius:50%;display:inline-block}

/* =================== OS / innovation grid =================== */
.os{
  display:grid;grid-template-columns:repeat(12,1fr);gap:14px;
}
.os-card{
  grid-column:span 4;min-height:184px;padding:22px;
  border:1px solid var(--hair);border-radius:5px;background:linear-gradient(180deg,rgba(20,24,26,.6),rgba(10,12,14,.4));
  position:relative;overflow:hidden;transition:.5s cubic-bezier(.16,1,.3,1);
}
.os-card:hover{border-color:var(--accent);transform:translateY(-4px)}
.os-card .ic{width:30px;height:30px;color:var(--accent);margin-bottom:auto}
.os-card .ttl{font-weight:700;font-size:19px;letter-spacing:-0.01em;margin-top:18px}
.os-card .dsc{font-size:13.5px;color:var(--muted);margin-top:7px;line-height:1.5}
.os-card .idx{position:absolute;top:18px;right:20px;font-family:var(--font-mono);font-size:11px;color:var(--muted-2)}
.os-core{
  grid-column:span 4;display:flex;flex-direction:column;justify-content:center;align-items:center;text-align:center;
  border:1px solid var(--accent);border-radius:5px;background:radial-gradient(circle at 50% 40%,var(--accent-glow),rgba(10,14,12,.5));
  min-height:184px;gap:10px;
}
@media(max-width:900px){.os-card,.os-core{grid-column:span 6}}
@media(max-width:620px){.os-card,.os-core{grid-column:span 12}}

/* =================== Products marquee =================== */
.marquee{overflow:hidden;border-top:1px solid var(--hair);border-bottom:1px solid var(--hair);padding:26px 0}
.marquee-row{display:flex;gap:54px;width:max-content;will-change:transform}
.marquee-row span{font-size:clamp(26px,3vw,44px);font-weight:800;letter-spacing:-0.02em;color:var(--muted-2);font-stretch:118%;display:flex;align-items:center;gap:54px}
.marquee-row span::after{content:"";width:9px;height:9px;background:var(--accent);transform:rotate(45deg);display:inline-block}
.marquee-row .lit{color:var(--text)}

/* =================== Certs / credibility =================== */
.cred{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--hair);border:1px solid var(--hair)}
.cred>div{background:var(--ink-900);padding:30px 26px;display:flex;flex-direction:column;gap:8px}
.cred .cnum{font-size:clamp(28px,3.2vw,46px);font-weight:900;letter-spacing:-0.04em;font-stretch:120%;color:var(--paper)}
.cred .clbl{font-family:var(--font-mono);font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--muted)}
@media(max-width:760px){.cred{grid-template-columns:repeat(2,1fr)}}

.badges{display:flex;flex-wrap:wrap;gap:12px}
.badge{
  display:flex;align-items:center;gap:10px;padding:12px 16px;border:1px solid var(--hair);border-radius:3px;
  font-family:var(--font-mono);font-size:12px;letter-spacing:.08em;color:var(--text);background:rgba(16,19,21,.4);
}
.badge svg{width:18px;height:18px;color:var(--avocado-bright)}

/* =================== Final CTA =================== */
.final{height:100vh;min-height:640px;display:flex;align-items:center;justify-content:center;text-align:center;overflow:hidden}
.final .inner{position:relative;z-index:6;padding:0 var(--gut);max-width:1000px}
.final h2{margin-bottom:22px}

/* =================== Footer =================== */
footer{border-top:1px solid var(--hair);padding:56px 0 40px;background:var(--ink-1000)}
.foot-grid{display:grid;grid-template-columns:1.5fr 1fr 1fr 1fr;gap:30px}
.foot-grid h4{font-family:var(--font-mono);font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--muted);margin-bottom:16px;font-weight:400}
.foot-grid a{display:block;color:var(--text);font-size:14px;padding:5px 0;transition:.3s}
.foot-grid a:hover{color:var(--accent)}
.foot-bottom{display:flex;justify-content:space-between;align-items:center;margin-top:48px;padding-top:24px;border-top:1px solid var(--hair);font-family:var(--font-mono);font-size:11px;letter-spacing:.1em;color:var(--muted-2);flex-wrap:wrap;gap:14px}
@media(max-width:760px){.foot-grid{grid-template-columns:1fr 1fr}}

/* =================== Reveal animation primitives =================== */
.rv{opacity:0;transform:translateY(34px);transition:opacity 1s cubic-bezier(.16,1,.3,1),transform 1s cubic-bezier(.16,1,.3,1)}
.rv.in{opacity:1;transform:none}
.rv-2{transition-delay:.1s}.rv-3{transition-delay:.2s}.rv-4{transition-delay:.3s}.rv-5{transition-delay:.4s}
@media(prefers-reduced-motion:reduce){.rv{opacity:1;transform:none;transition:none}}

/* =================== Tweaks panel =================== */
#tweaks{
  position:fixed;right:18px;bottom:18px;z-index:150;width:288px;
  background:rgba(10,12,14,.86);backdrop-filter:blur(22px) saturate(1.3);
  border:1px solid var(--hair-strong);border-radius:10px;
  font-family:var(--font-mono);color:var(--text);
  box-shadow:0 24px 70px -20px rgba(0,0,0,.8);
  transform:translateY(14px) scale(.98);opacity:0;visibility:hidden;
  transition:.4s cubic-bezier(.16,1,.3,1);overflow:hidden;
}
#tweaks.open{transform:none;opacity:1;visibility:visible}
.tw-head{display:flex;align-items:center;justify-content:space-between;padding:13px 15px;border-bottom:1px solid var(--hair);cursor:grab}
.tw-head b{font-size:12px;letter-spacing:.18em;text-transform:uppercase;font-weight:700}
.tw-head .x{background:none;border:0;color:var(--muted);cursor:pointer;font-size:16px;line-height:1;padding:4px}
.tw-body{padding:14px 15px 18px;display:flex;flex-direction:column;gap:16px;max-height:74vh;overflow:auto}
.tw-sec{font-size:10px;letter-spacing:.22em;text-transform:uppercase;color:var(--muted-2);margin-bottom:-6px}
.tw-row{display:flex;flex-direction:column;gap:7px}
.tw-row label{font-size:11px;letter-spacing:.06em;color:var(--muted);display:flex;justify-content:space-between}
.tw-row label span{color:var(--accent)}
.tw-swatches{display:flex;gap:8px}
.tw-swatches button{width:30px;height:30px;border-radius:50%;border:2px solid transparent;cursor:pointer;transition:.25s}
.tw-swatches button.on{border-color:var(--paper);transform:scale(1.08)}
.tw-seg{display:flex;border:1px solid var(--hair);border-radius:4px;overflow:hidden}
.tw-seg button{flex:1;background:none;border:0;color:var(--muted);cursor:pointer;font-family:inherit;font-size:11px;padding:7px 4px;transition:.25s;letter-spacing:.04em}
.tw-seg button.on{background:var(--accent);color:var(--ink-1000);font-weight:700}
.tw-body input[type=range]{-webkit-appearance:none;width:100%;height:2px;background:var(--hair-strong);border-radius:2px;outline:none}
.tw-body input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;width:14px;height:14px;border-radius:50%;background:var(--accent);cursor:pointer;box-shadow:0 0 0 3px var(--accent-glow)}
.tw-body input[type=range]::-moz-range-thumb{width:14px;height:14px;border:0;border-radius:50%;background:var(--accent);cursor:pointer}

/* utility */
.center{display:flex;align-items:center;justify-content:center}
.col{display:flex;flex-direction:column}
.muted{color:var(--muted)}
.nowrap{white-space:nowrap}
[hidden]{display:none!important}

/* =================== About =================== */
.about-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:30px;margin-top:48px}
.about-item{padding-top:20px;border-top:1px solid var(--hair-strong);position:relative}
.about-item .ai-bar{position:absolute;top:-1px;left:0;width:42px;height:2px;background:var(--accent)}
.about-item .ai-t{font-weight:700;font-size:clamp(17px,1.5vw,21px);letter-spacing:-0.01em}
.about-item .ai-d{font-size:14.5px;color:var(--muted);margin-top:8px;line-height:1.55;max-width:34ch}
@media(max-width:760px){.about-grid{grid-template-columns:1fr;gap:20px}}

/* =================== Products =================== */
.products-layout{display:grid;grid-template-columns:.82fr 1.18fr;gap:clamp(24px,3.5vw,56px);align-items:start}
#productList{list-style:none}
#productList li{
  display:flex;align-items:center;gap:18px;padding:18px 6px;border-top:1px solid var(--hair);
  cursor:pointer;transition:.4s cubic-bezier(.16,1,.3,1);position:relative;
}
#productList li:last-child{border-bottom:1px solid var(--hair)}
#productList .pl-i{font-family:var(--font-mono);font-size:12px;color:var(--muted-2);transition:.3s}
#productList .pl-n{flex:1;font-size:clamp(20px,2vw,30px);font-weight:800;letter-spacing:-0.02em;color:var(--muted-2);font-stretch:115%;transition:.3s}
#productList .pl-x{font-family:var(--font-mono);color:var(--accent);opacity:0;transform:translateX(-6px);transition:.3s}
#productList li:hover .pl-n{color:var(--muted)}
#productList li.on .pl-n{color:var(--text)}
#productList li.on .pl-i{color:var(--accent)}
#productList li.on .pl-x{opacity:1;transform:none}
#productList li.on::before{content:"";position:absolute;left:0;top:-1px;width:30px;height:2px;background:var(--accent)}
#productPanel{padding:0;overflow:hidden}
#productPanel .pp-img{aspect-ratio:16/11;width:100%}
#productPanel .pp-body{padding:26px 28px 30px}
#productPanel .pp-idx{font-family:var(--font-mono);font-size:11px;letter-spacing:.18em;color:var(--accent);margin-bottom:12px}
#productPanel .pp-name{font-size:clamp(26px,2.6vw,40px)}
#productPanel .pp-var-wrap{margin:18px 0 14px}
#productPanel .pp-var-wrap .kicker{display:block;margin-bottom:6px}
#productPanel .pp-var{font-family:var(--font-mono);font-size:15px;color:var(--accent-bright);letter-spacing:.02em}
#productPanel .pp-desc{font-size:15.5px;color:var(--muted);line-height:1.6;max-width:52ch}
@media(max-width:820px){.products-layout{grid-template-columns:1fr}}

/* =================== Certifications wall =================== */
.cert-wall{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}
.cert-card{
  border:1px solid var(--hair);border-radius:var(--radius);padding:28px 24px;min-height:200px;
  display:flex;flex-direction:column;background:linear-gradient(180deg,rgba(20,28,22,.5),rgba(10,15,12,.3));
  transition:.5s cubic-bezier(.16,1,.3,1);position:relative;overflow:hidden;
}
.cert-card:hover{border-color:var(--accent);transform:translateY(-4px)}
.cert-card svg{width:34px;height:34px;color:var(--accent);margin-bottom:auto}
.cert-card .cc-t{font-family:var(--font-mono);font-size:17px;font-weight:700;letter-spacing:.02em;margin-top:24px}
.cert-card .cc-d{font-size:13px;color:var(--muted);margin-top:7px;line-height:1.45}
@media(max-width:820px){.cert-wall{grid-template-columns:1fr 1fr}}

/* =================== Tag pill =================== */
.tag-pill{
  display:inline-flex;align-self:flex-start;align-items:center;gap:8px;
  font-family:var(--font-mono);font-size:11px;letter-spacing:.2em;text-transform:uppercase;
  padding:8px 14px;border:1px solid var(--accent);border-radius:100px;color:var(--accent);
}
.tag-pill::before{content:"";width:6px;height:6px;border-radius:50%;background:var(--accent);box-shadow:0 0 10px var(--accent-glow)}

/* =================== Industrialization =================== */
.ind-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}
.ind-card{
  border:1px solid var(--hair);border-radius:var(--radius);padding:24px;min-height:210px;
  display:flex;flex-direction:column;background:linear-gradient(180deg,rgba(28,24,14,.45),rgba(12,12,10,.3));
  transition:.5s cubic-bezier(.16,1,.3,1);position:relative;overflow:hidden;
}
.ind-card:hover{border-color:var(--accent);transform:translateY(-4px)}
.ind-card .idx{position:absolute;top:18px;right:20px;font-family:var(--font-mono);font-size:11px;color:var(--muted-2)}
.ind-card .ic{width:32px;height:32px;color:var(--accent);margin-bottom:auto}
.ind-card .ttl{font-weight:700;font-size:19px;margin-top:20px;letter-spacing:-0.01em}
.ind-card .dsc{font-size:13.5px;color:var(--muted);margin-top:8px;line-height:1.5}
@media(max-width:820px){.ind-grid{grid-template-columns:1fr 1fr}}
@media(max-width:520px){.ind-grid{grid-template-columns:1fr}}

/* =================== Family =================== */
.fam-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(16px,2.5vw,30px)}
.fam-card{display:flex;flex-direction:column}
.fam-portrait{aspect-ratio:4/5;border-radius:6px;width:100%}
.fam-card .fam-name{font-weight:800;font-size:clamp(20px,1.8vw,26px);letter-spacing:-0.02em;margin-top:18px}
.fam-card .fam-role{font-family:var(--font-mono);font-size:12px;letter-spacing:.06em;color:var(--accent);margin-top:6px}
.fam-note{font-size:11px;color:var(--muted-2);margin-top:26px;letter-spacing:.04em}
@media(max-width:760px){.fam-grid{grid-template-columns:1fr;max-width:420px}}

/* =====================================================================
   THEME SYSTEM — Light mode + Liquid Glass  (toggle via Tweaks)
   The immersive scenes (hero, twin, network, final) + nav keep their
   cinematic dark treatment; editorial sections flip to light.
   ===================================================================== */

/* ---- Liquid-glass tokens (dark defaults; over dark surfaces) ---- */
:root{
  --glass-fill:rgba(255,255,255,.07);
  --glass-fill-2:rgba(255,255,255,.13);
  --glass-stroke:rgba(255,255,255,.28);
  --glass-hi:rgba(255,255,255,.55);
  --glass-shadow:rgba(0,0,0,.5);
  --btn-text:var(--text);
  --surface-glass:rgba(16,19,21,.42);
  --surface-card:linear-gradient(180deg,rgba(20,24,26,.6),rgba(10,12,14,.4));
}
body{transition:background .6s ease,color .6s ease}

/* ---- Liquid Glass buttons (all buttons) ---- */
.btn{
  border-radius:14px;
  border:1px solid var(--glass-stroke);
  background:var(--glass-fill);
  -webkit-backdrop-filter:blur(16px) saturate(1.7);
  backdrop-filter:blur(16px) saturate(1.7);
  color:var(--btn-text);
  box-shadow:inset 0 1px 0 var(--glass-hi),inset 0 -10px 20px rgba(255,255,255,.05),0 10px 26px -12px var(--glass-shadow);
  isolation:isolate;
}
.btn::before{
  content:"";position:absolute;inset:0;border-radius:inherit;pointer-events:none;z-index:-1;
  background:linear-gradient(157deg,var(--glass-hi),rgba(255,255,255,0) 42%);
  opacity:.7;mix-blend-mode:screen;
}
.btn::after{
  content:"";position:absolute;left:-30%;top:-120%;width:60%;height:240%;border-radius:50%;
  background:radial-gradient(closest-side,rgba(255,255,255,.5),transparent);
  opacity:0;transform:translateX(0);transition:opacity .5s,transform .9s cubic-bezier(.16,1,.3,1);
  pointer-events:none;z-index:-1;filter:blur(6px);
}
.btn:hover{transform:translateY(-2px)}
.btn:hover::after{opacity:.5;transform:translateX(220%)}
.btn-primary{
  background:color-mix(in srgb,var(--accent) 78%,transparent);
  border-color:color-mix(in srgb,var(--accent) 60%,var(--glass-stroke));
  color:#06140d;font-weight:700;
  box-shadow:inset 0 1px 0 rgba(255,255,255,.55),0 12px 30px -12px var(--accent-glow);
}
.btn-primary:hover{background:color-mix(in srgb,var(--accent-bright) 86%,transparent);transform:translateY(-2px);box-shadow:0 16px 42px -14px var(--accent-glow)}
.btn-ghost{color:var(--btn-text)}
.btn-ghost:hover{border-color:color-mix(in srgb,var(--accent) 55%,var(--glass-stroke));color:var(--accent)}

/* glassy language switch */
.lang{
  border-color:var(--glass-stroke);border-radius:11px;
  background:var(--glass-fill);
  -webkit-backdrop-filter:blur(14px) saturate(1.6);backdrop-filter:blur(14px) saturate(1.6);
  box-shadow:inset 0 1px 0 var(--glass-hi);
}
.lang button{color:var(--btn-text);opacity:.7}
.lang button.on{opacity:1}

/* glassy chips */
.chip{
  background:var(--surface-glass);
  border-color:var(--glass-stroke);
  -webkit-backdrop-filter:blur(14px) saturate(1.5);backdrop-filter:blur(14px) saturate(1.5);
  box-shadow:inset 0 1px 0 var(--glass-hi);
}
.glass{background:var(--surface-glass)}

/* =================== LIGHT MODE =================== */
html[data-mode="light"]{
  --ink-1000:#f3f6f0;
  --ink-900:#eef2e9;
  --ink-850:#e8ede1;
  --ink-800:#e1e7d8;
  --ink-700:#d6ddcb;
  --ink-600:#c7d1b9;
  --ink-500:#b2bfa1;

  --paper:#0b1410;
  --text:#15211a;
  --muted:#566256;
  --muted-2:#6e7c6e;   /* darkened for AA contrast on the off-white */
  --faint:rgba(15,33,24,.05);
  --hair:rgba(15,33,24,.12);
  --hair-strong:rgba(15,33,24,.20);

  /* glass tokens tuned for light surfaces */
  --glass-fill:rgba(255,255,255,.5);
  --glass-fill-2:rgba(255,255,255,.72);
  --glass-stroke:rgba(15,33,24,.14);
  --glass-hi:rgba(255,255,255,.95);
  --glass-shadow:rgba(20,45,32,.22);
  --surface-glass:rgba(255,255,255,.55);
  --surface-card:linear-gradient(180deg,rgba(255,255,255,.7),rgba(255,255,255,.42));

  background:var(--ink-1000);color:var(--text);
}
html[data-mode="light"] body{background:var(--ink-1000);color:var(--text)}
html[data-mode="light"] ::selection{background:var(--accent);color:#fff}

/* editorial cards & surfaces in light */
html[data-mode="light"] .os-card,
html[data-mode="light"] .cert-card,
html[data-mode="light"] .ind-card{
  background:var(--surface-card);
  box-shadow:0 14px 40px -26px var(--glass-shadow);
}
html[data-mode="light"] .cred>div{background:var(--ink-900)}
html[data-mode="light"] footer{background:var(--ink-900)}
html[data-mode="light"] .badge{background:var(--surface-glass)}

/* flatten the dark inline section gradients to clean light */
html[data-mode="light"] #seq04,
html[data-mode="light"] #packing,
html[data-mode="light"] #industrial{
  background:var(--ink-1000)!important;
}
/* soften atmosphere overlays so they don't darken light sections */
html[data-mode="light"] .sec .vignette{
  background:radial-gradient(120% 90% at 50% 36%,transparent 50%,rgba(30,50,38,.06) 100%);
  opacity:.5;
}
html[data-mode="light"] .sec .fog{opacity:calc(.35*var(--fog))}
/* hide full-bleed dark "photo" backdrops inside editorial sections
   (content photo cards keep their imagery) */
html[data-mode="light"] .sec .atmos .ph{display:none}

/* =================== KEEP CINEMATIC DARK =================== */
/* hero, twin, network, final CTA + the nav retain the dark token set so
   their canvases / imagery / glass never wash out on a light page. */
html[data-mode="light"] .cinematic,
html[data-mode="light"] .nav{
  --ink-1000:#070b09;--ink-900:#0a0f0c;--ink-850:#0d1310;--ink-800:#111814;
  --ink-700:#18211c;--ink-600:#212c26;--ink-500:#2d3a32;
  --paper:#f8f8f5;--text:#e8ece7;--muted:#9aa69d;--muted-2:#6c776f;
  --faint:rgba(248,248,245,.06);--hair:rgba(248,248,245,.12);--hair-strong:rgba(248,248,245,.22);
  --glass-fill:rgba(255,255,255,.07);--glass-fill-2:rgba(255,255,255,.13);
  --glass-stroke:rgba(255,255,255,.28);--glass-hi:rgba(255,255,255,.55);
  --glass-shadow:rgba(0,0,0,.5);--surface-glass:rgba(16,19,21,.42);
}
html[data-mode="light"] .cinematic{background:#070b09}
html[data-mode="light"] .nav.solid{
  background:rgba(7,8,9,.66);border-bottom-color:rgba(248,248,245,.12);
}

/* theme segmented control in tweaks */
#tw-theme button{text-transform:none;letter-spacing:.02em}

/* =====================================================================
   RESPONSIVE / MOBILE  — iPhone + small devices
   ===================================================================== */

/* iOS Safari: use small-viewport-height so the address bar can't crop full
   screens (avoids the classic 100vh jump/cutoff). */
@supports (height:100svh){
  .hero,.final{height:100svh}
  .scene-pin,.pin-layer,.net-wrap{height:100svh}
}

/* mobile nav: hamburger (button injected by main.js) + dropdown panel */
.nav-toggle{display:none}
.lang-menu,.btn-menu{display:none}   /* clones only appear inside the mobile menu */

/* skip-to-content link (keyboard a11y) */
.skip-link{position:fixed;left:12px;top:-64px;z-index:300;background:var(--accent);color:#fff;padding:10px 16px;border-radius:8px;font-family:var(--font-mono);font-size:13px;letter-spacing:.08em;transition:top .25s ease}
.skip-link:focus{top:12px;outline:2px solid #fff;outline-offset:2px}
@media(max-width:880px){
  .nav{padding-left:16px;padding-right:16px}
  .nav-right{gap:10px}
  .nav-right .lang,.nav-right .btn{display:none}   /* top-bar lang + Partner hidden on mobile… */
  .nav-links .lang-menu{display:inline-flex;align-self:flex-start;margin-top:16px}  /* …shown inside the menu */
  .nav-links .btn-menu{display:inline-flex;width:100%;justify-content:center;margin-top:14px}
  .nav-toggle{
    position:relative;display:inline-flex;align-items:center;justify-content:center;
    width:44px;height:44px;border:1px solid var(--hair);border-radius:11px;flex:none;cursor:pointer;
    background:rgba(10,12,14,.4);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);
  }
  .nav-toggle span{position:relative;display:block;width:19px;height:2px;border-radius:2px;background:var(--text);transition:.3s cubic-bezier(.16,1,.3,1)}
  .nav-toggle span::before,.nav-toggle span::after{
    content:"";position:absolute;left:0;width:19px;height:2px;border-radius:2px;background:var(--text);transition:.3s cubic-bezier(.16,1,.3,1);
  }
  .nav-toggle span::before{top:-6px}
  .nav-toggle span::after{top:6px}
  .nav.nav-open .nav-toggle span{background:transparent}
  .nav.nav-open .nav-toggle span::before{top:0;transform:rotate(45deg)}
  .nav.nav-open .nav-toggle span::after{top:0;transform:rotate(-45deg)}

  .nav-links{
    display:flex;flex-direction:column;align-items:stretch;gap:0;
    position:absolute;top:100%;left:0;right:0;
    padding:6px var(--gut) 20px;
    background:rgba(7,9,8,.97);-webkit-backdrop-filter:blur(20px) saturate(1.2);backdrop-filter:blur(20px) saturate(1.2);
    border-bottom:1px solid var(--hair);
    transform:translateY(-14px);opacity:0;visibility:hidden;
    transition:.42s cubic-bezier(.16,1,.3,1);
  }
  .nav.nav-open .nav-links{transform:none;opacity:1;visibility:visible}
  .nav-links a{padding:16px 2px;border-bottom:1px solid var(--hair);font-size:14px;color:var(--text)}
}

/* stack the inline two-column sections on phones */
@media(max-width:760px){
  #seq02 .wrap{grid-template-columns:1fr!important;gap:24px!important}
  #seq04 .wrap>div,#packing .wrap>div{grid-template-columns:1fr!important;gap:30px!important}
  /* floating data overlays shouldn't spill off the screen */
  #seq02 .glass.stat{position:static!important;width:auto!important;margin-top:14px}
  #seq02 .chip,#packing .chip{top:14px!important;left:14px!important}
  /* digital-twin (03): heading to the top, hide side readouts so the fruit
     has room and reads clearly on phones */
  #seq03 .wrap{justify-content:flex-start!important;padding-top:92px}
  #seq03 .twin-read{display:none}
}

/* buttons: comfortable touch targets; full-width CTAs on small phones */
@media(max-width:480px){
  .hero-cta{flex-direction:column;align-items:stretch}
  .hero-cta .btn{width:100%;justify-content:center}
  .btn{padding:1.1em 1.5em}
}

/* tighter vertical rhythm on small screens */
@media(max-width:600px){
  .sec{padding:clamp(30px,5vh,46px) 0}
  .hero-foot{display:none}   /* hide coords + scroll cue on mobile (was overlapping the CTA) */
}

/* Products ("Ocho cultivos") — mobile-first: panel on top, compact crop list */
@media(max-width:820px){
  .products-layout{display:flex!important;flex-direction:column;gap:22px!important}
  #productPanel{order:-1}                       /* show the selected crop first */
  #productPanel .pp-img{aspect-ratio:16/10}
  #productPanel .pp-body{padding:20px 20px 24px}
  #productList{display:grid;grid-template-columns:1fr 1fr;gap:0 14px}
  #productList li{padding:13px 4px}
  #productList li:nth-child(2){border-top:1px solid var(--hair)}  /* keep top borders tidy in 2-col */
  #productList .pl-n{font-size:18px}
  #productList .pl-x{display:none}              /* arrow is noise on touch */
}
@media(max-width:430px){
  #productList{grid-template-columns:1fr}        /* single column on small phones */
}

/* avocado (04) stat pair: stack on small phones */
@media(max-width:430px){
  #seq04 .wrap>div>div:last-child{grid-template-columns:1fr!important}
}

/* =====================================================================
   ABOUT — editorial 2-col (text + photo), clean points, stat band
   ===================================================================== */
.about-top{display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(28px,5vw,72px);align-items:center}
.about-intro .lede{margin-top:18px;max-width:48ch}
.about-photo-img{width:100%;aspect-ratio:4/5;border-radius:var(--radius);background-size:cover;background-position:center;box-shadow:0 34px 74px -36px rgba(20,45,32,.5)}
.about-points{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(22px,3vw,48px);margin-top:clamp(42px,6vw,74px)}
.ap-ic{width:30px;height:30px;color:var(--accent)}
.ap-t{font-weight:700;font-size:clamp(17px,1.5vw,20px);letter-spacing:-.01em;margin-top:14px}
.ap-d{font-size:14.5px;color:var(--muted);margin-top:8px;line-height:1.55;max-width:36ch}
.about-stats{display:grid;grid-template-columns:repeat(4,1fr);margin-top:clamp(44px,6vw,74px);border-top:1px solid var(--hair-strong)}
.ast{padding:26px 24px 0;border-left:1px solid var(--hair)}
.ast:first-child{border-left:0;padding-left:0}
.ast-n{display:block;font-size:clamp(34px,4vw,54px);font-weight:900;letter-spacing:-.04em;font-stretch:120%;line-height:1}
.ast-n em{font-style:normal;color:var(--accent)}
.ast-l{display:block;font-family:var(--font-mono);font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--muted);margin-top:12px}
.ast-s{display:block;font-size:13px;color:var(--muted-2);margin-top:5px}
@media(max-width:860px){.about-top{grid-template-columns:1fr;gap:26px}.about-photo{order:-1}.about-photo-img{aspect-ratio:16/10}}
@media(max-width:720px){
  .about-points{grid-template-columns:1fr;gap:24px}
  .about-stats{grid-template-columns:1fr 1fr}
  .ast{border-left:0;border-top:1px solid var(--hair);padding:20px 0 0}
  .ast:first-child{border-top:0}
}

/* =====================================================================
   SERVICES — mixed-model badges + connected process flow (maquila)
   ===================================================================== */
.svc-models{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-top:clamp(34px,4vw,48px);max-width:820px}
.svc-model{border:1px solid var(--hair);border-radius:var(--radius);padding:22px 24px;background:linear-gradient(180deg,rgba(255,255,255,.022),transparent);transition:border-color .45s,transform .55s cubic-bezier(.16,1,.3,1)}
.svc-model:hover{border-color:color-mix(in srgb,var(--accent) 45%,var(--hair));transform:translateY(-3px)}
.smk{font-family:var(--font-mono);font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--accent);display:inline-flex;align-items:center;gap:8px}
.smk::before{content:"";width:7px;height:7px;border:1px solid var(--accent);transform:rotate(45deg)}
.smt{font-weight:700;font-size:clamp(18px,1.6vw,21px);letter-spacing:-.01em;margin-top:13px}
.smd{font-size:14px;color:var(--muted);margin-top:8px;line-height:1.55}

.svc-flow{margin-top:clamp(48px,6vw,76px)}
.svc-track{display:grid;grid-template-columns:repeat(4,1fr)}
.svc-step{position:relative;padding-right:clamp(18px,2.2vw,34px)}
.svc-step .sn{position:relative;z-index:2;display:inline-flex;align-items:center;justify-content:center;width:44px;height:44px;border:1px solid var(--accent);color:var(--accent);border-radius:50%;font-family:var(--font-mono);font-size:13px;background:var(--ink-1000);transition:background .4s ease,color .4s ease,transform .55s cubic-bezier(.16,1,.3,1)}
/* connector line between step badges */
.svc-step::before{content:"";position:absolute;top:21.5px;left:44px;right:0;height:1px;background:var(--hair-strong);z-index:1}
.svc-step:last-child::before{display:none}
.svc-step .sic{width:26px;height:26px;color:var(--accent);margin-top:24px}
.svc-step .st{font-weight:700;font-size:clamp(16px,1.4vw,19px);letter-spacing:-.01em;margin-top:14px}
.svc-step .sd{font-size:13.5px;color:var(--muted);margin-top:8px;line-height:1.5;max-width:32ch}
.svc-step:hover .sn{background:var(--accent);color:#fff;transform:translateY(-2px)}
@media(max-width:760px){
  .svc-models{grid-template-columns:1fr}
  .svc-track{grid-template-columns:1fr}
  .svc-step{padding:0 0 30px 62px;min-height:54px}
  .svc-step .sn{position:absolute;left:0;top:0}
  .svc-step::before{top:44px;bottom:0;left:21.5px;right:auto;width:1px;height:auto}
  .svc-step:last-child{padding-bottom:0}
  .svc-step .sic{margin-top:0}
  .svc-step .st{margin-top:2px}
}
@media(prefers-reduced-motion:reduce){.svc-model,.svc-step .sn{transition:none}}

/* =====================================================================
   MARKETS / trust strip (under certifications) + form success line
   ===================================================================== */
.markets-strip{
  display:flex;flex-wrap:wrap;align-items:center;gap:12px 14px;
  margin-top:clamp(34px,4vw,50px);padding-top:clamp(26px,3vw,38px);
  border-top:1px solid var(--hair);
}
.ms-label{font-family:var(--font-mono);font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--muted)}
.ms-chip{
  display:inline-flex;align-items:center;gap:7px;
  font-size:14px;font-weight:600;letter-spacing:-.01em;
  padding:7px 14px;border:1px solid var(--hair-strong);border-radius:999px;
}
.ms-sep{flex:1 1 24px;height:1px;background:var(--hair);min-width:12px}
.ms-note{font-size:13.5px;color:var(--muted);max-width:44ch}
.pf-sent{text-align:center;font-size:16px;color:#fff;padding:18px 4px;letter-spacing:-.01em}
@media(max-width:600px){.ms-sep{display:none}.markets-strip{gap:10px}}

/* =====================================================================
   Industrialization cards flagged "coming soon" (pulp & juices not live yet)
   — replace the index number with a bright pill, dim only the content.
   ===================================================================== */
.ind-card .soon{display:none}
/* whole card greyed out (desaturated + dimmed); the grayscale also neutralizes
   the accent hover glow so it stays grey on hover */
.ind-card.is-soon{filter:grayscale(.9);opacity:.5;transition:opacity .45s ease,filter .45s ease}
.ind-card.is-soon:hover{opacity:.72;filter:grayscale(.55)}
.ind-card.is-soon .idx{display:none}
.ind-card.is-soon .soon{
  display:inline-block;position:absolute;top:15px;right:16px;z-index:2;
  font-family:var(--font-mono);font-size:9.5px;letter-spacing:.14em;text-transform:uppercase;
  color:#fff;padding:4px 10px;border-radius:999px;
  border:1px solid var(--hair-strong);background:rgba(255,255,255,.08);
}
