/* =========================================================
   HST INDONESIA · Air Mineral
   Cinematic premium website
   ========================================================= */

@import url('https://fonts.googleapis.com/css2?family=Cormorant+Garamond:ital,wght@0,300;0,400;0,500;0,600;0,700;1,300;1,400;1,500;1,600;1,700&family=Manrope:wght@200;300;400;500;600;700&family=JetBrains+Mono:wght@400;500&display=swap');

/* ---------- Tokens ---------- */
:root{
  /* Deep forest · sekarang body default (Fase 1+2 dark cinematic) */
  --forest-deep: oklch(0.18 0.04 155);
  --forest: oklch(0.16 0.04 155);
  /* Hijau segar (fresh leaf) · aksen di section terang */
  --green: oklch(0.62 0.17 145);
  --green-bright: oklch(0.76 0.18 142);
  --green-deep: oklch(0.30 0.08 153);
  --leaf: oklch(0.68 0.18 142);
  /* Mint terang */
  --mint: oklch(0.92 0.07 158);
  --mint-pale: oklch(0.96 0.03 158);
  --mint-deep: oklch(0.82 0.10 156);
  /* Biru air */
  --water: oklch(0.78 0.11 220);
  --water-pale: oklch(0.94 0.045 220);
  --sky: oklch(0.96 0.02 215);
  /* Netral */
  --cream: oklch(0.97 0.012 95);
  --off-white: oklch(0.99 0.004 100);
  --paper: oklch(0.99 0.004 100);
  --ink: oklch(0.20 0.04 155);
  --ink-soft: oklch(0.45 0.03 155);
  --line: oklch(0.88 0.012 155);

  --serif: 'Cormorant Garamond', 'Times New Roman', serif;
  --sans: 'Manrope', system-ui, sans-serif;
  --mono: 'JetBrains Mono', ui-monospace, monospace;

  /* Fraunces optical sizing helper · dipakai di display sizes */
  --display: 'Cormorant Garamond', 'Times New Roman', serif;

  --ease-cinema: cubic-bezier(0.16, 1, 0.3, 1);
  --ease-cine:   cubic-bezier(0.16, 1, 0.3, 1); /* alias used by Fase 1+2 spec */
  --ease-soft:   cubic-bezier(0.22, 0.61, 0.36, 1);
  --ease-deep:   cubic-bezier(0.65, 0, 0.35, 1);

  --pad-x: clamp(20px, 5vw, 80px);
  --max-w: 1480px;
}

/* ---------- Reset ---------- */
*,*::before,*::after{ box-sizing: border-box; }
html,body{ margin:0; padding:0; }
/* JANGAN aktifkan `html { scroll-behavior: smooth }` — bentrok dengan Lenis
   (Lenis programmatic scrollTo + native smooth-scroll saling cancel,
   bikin wheel/trackpad terasa "mati" walau scrollbar drag jalan). */
body{
  font-family: var(--sans);
  font-size: 17px;
  line-height: 1.6;
  color: var(--paper);
  background: var(--forest);
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
  overflow-x: hidden;
}
/* Cegah body lebih lebar dari viewport di mobile (marquee/hero parallax/
   transform bisa bikin halaman bisa di-swipe kiri-kanan). `overflow: clip`
   tidak membuat scroll container baru (beda dengan `hidden`), aman utk Lenis. */
html { overflow-x: hidden; }
@supports (overflow: clip) {
  html, body { overflow-x: clip; }
}
img{ display:block; max-width:100%; height:auto; }
a{ color: inherit; text-decoration: none; }
button{ font-family: inherit; cursor: pointer; border: none; background: none; color: inherit; }
::selection{ background: var(--green); color: var(--cream); }

/* ---------- Utility ---------- */
.container{ max-width: var(--max-w); margin: 0 auto; padding-inline: var(--pad-x); }
.eyebrow{
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--ink-soft);
  display: inline-flex;
  align-items: center;
  gap: 10px;
}
.eyebrow::before{
  content: "";
  width: 24px;
  height: 1px;
  background: currentColor;
  opacity: 0.6;
}
.display{
  font-family: var(--serif);
  font-weight: 400;
  line-height: 0.96;
  letter-spacing: -0.015em;
  text-wrap: balance;
}
.italic{ font-style: italic; }

/* =========================================================
   PRE-LOADER
   ========================================================= */
.loader{
  position: fixed; inset: 0;
  background: var(--forest-deep);
  color: var(--cream);
  z-index: 200;
  display: flex; align-items: center; justify-content: center;
  flex-direction: column; gap: 28px;
  transition: opacity 0.9s var(--ease-cinema), visibility 0.9s;
}
.loader.done{ opacity: 0; visibility: hidden; pointer-events: none; }
.loader-mono{ font-family: var(--mono); font-size: 11px; letter-spacing: 0.25em; opacity: 0.7; text-transform: uppercase; }
.loader-mark{
  font-family: var(--serif);
  font-style: italic;
  font-size: clamp(48px, 8vw, 96px);
  line-height: 1;
}
.loader-bar{
  width: 220px; height: 1px;
  background: oklch(0.40 0.04 155);
  position: relative; overflow: hidden;
}
.loader-bar::after{
  content:""; position: absolute; inset: 0;
  background: var(--mint);
  transform-origin: left;
  animation: loaderfill 1.6s var(--ease-cinema) forwards;
}
@keyframes loaderfill { from { transform: scaleX(0); } to { transform: scaleX(1); } }

/* =========================================================
   NAV
   ========================================================= */
.nav{
  position: fixed; top: 0; left: 0; right: 0;
  z-index: 90;
  padding: 18px var(--pad-x);
  display: flex; align-items: center; justify-content: space-between;
  transition: background 0.4s var(--ease-soft), color 0.4s, padding 0.4s, backdrop-filter 0.4s;
  /* Hero sekarang bright · nav default ink color */
  color: var(--ink);
}
.nav.scrolled{
  background: rgba(255, 253, 248, 0.78);
  backdrop-filter: blur(18px) saturate(140%);
  -webkit-backdrop-filter: blur(18px) saturate(140%);
  color: var(--ink);
  padding-block: 14px;
  border-bottom: 1px solid var(--line);
}
.nav-logo{
  display: inline-flex; align-items: center; gap: 12px;
  font-family: var(--serif); font-size: 22px; letter-spacing: -0.01em;
}
/* Logo HST asli sebagai mark di nav */
.nav-logo .real-mark{
  width: 44px; height: 44px;
  display: inline-flex; align-items: center; justify-content: center;
  flex-shrink: 0;
}
.nav-logo .real-mark img{
  width: 100%; height: 100%;
  object-fit: contain;
  filter: drop-shadow(0 2px 6px rgba(0,0,0,0.25));
  /* Saat nav transparent di hero gelap, logo asli sudah hijau di lingkaran putih,
     beri sedikit cerah supaya pop */
  transition: filter 0.4s;
}
.nav.scrolled .nav-logo .real-mark img{
  filter: none;
}
.nav-logo .mark{
  width: 36px; height: 36px; border-radius: 50%;
  border: 1.5px solid currentColor;
  display: inline-flex; align-items: center; justify-content: center;
  font-family: var(--serif); font-style: italic; font-size: 16px;
  letter-spacing: 0;
}
.nav-logo .name{ display: inline-flex; flex-direction: column; line-height: 1; gap: 3px; }
.nav-logo .name b{ font-weight: 400; font-size: 19px; }
.nav-logo .name span{ font-family: var(--mono); font-size: 9px; letter-spacing: 0.25em; opacity: 0.7; text-transform: uppercase; }

/* Logo brand wide (Air Mineral) di nav header. Footer tetap pakai .nav-logo lama. */
.nav-brand-img{
  height: 56px;
  width: auto;
  display: block;
  filter: drop-shadow(0 2px 6px rgba(0,0,0,0.25));
  transition: filter 0.4s, height 0.4s;
}
.nav.scrolled .nav-brand-img{
  height: 48px;
  filter: none;
}
@media (max-width: 640px){
  .nav-brand-img{ height: 44px; }
  .nav.scrolled .nav-brand-img{ height: 38px; }
}

.nav-menu{
  display: flex; gap: 38px; align-items: center;
}
.nav-menu a{
  font-size: 14px; font-weight: 400; opacity: 0.85;
  transition: opacity 0.3s;
  position: relative;
}
.nav-menu a::after{
  content:""; position:absolute; left:0; right:0; bottom:-6px;
  height: 1px; background: currentColor;
  transform: scaleX(0); transform-origin: left;
  transition: transform 0.4s var(--ease-cinema);
}
.nav-menu a:hover{ opacity: 1; }
.nav-menu a:hover::after{ transform: scaleX(1); }

.nav-cta{
  border: 1px solid currentColor;
  padding: 10px 20px;
  border-radius: 999px;
  font-size: 13px;
  letter-spacing: 0.02em;
  display: inline-flex; align-items: center; gap: 8px;
  transition: background 0.3s, color 0.3s, border-color 0.3s;
}
.nav-cta:hover{ background: var(--green); border-color: var(--green); color: var(--cream); }
.nav.scrolled .nav-cta:hover{ background: var(--green); color: var(--cream); }
.nav-cta .dot{
  width: 6px; height: 6px; border-radius: 50%; background: var(--green-bright);
  box-shadow: 0 0 0 0 currentColor;
  animation: pulse 2.4s infinite;
}
@keyframes pulse{
  0%{ box-shadow: 0 0 0 0 oklch(0.70 0.16 148 / 0.5); }
  70%{ box-shadow: 0 0 0 10px oklch(0.70 0.16 148 / 0); }
  100%{ box-shadow: 0 0 0 0 oklch(0.70 0.16 148 / 0); }
}

/* scroll progress */
.scroll-progress{
  position: fixed; top:0; left:0; right:0; height: 2px; z-index: 110;
  background: transparent;
}
.scroll-progress > i{
  display: block; height: 100%; width: 0;
  background: linear-gradient(90deg, var(--green) 0%, var(--mint) 100%);
  transition: width 0.05s linear;
}

/* =========================================================
   HERO · BRIGHT-AIRY AQUVIVA-INSPIRED
   ========================================================= */
.hero{
  position: relative;
  min-height: 100vh;
  /* Bright sky gradient · dari biru muda ke cream */
  background:
    linear-gradient(180deg,
      oklch(0.96 0.025 220) 0%,
      oklch(0.985 0.012 200) 35%,
      var(--off-white) 70%,
      var(--cream) 100%);
  color: var(--ink);
  overflow: hidden;
  isolation: isolate;
}
/* Pancaran cahaya halus dari atas */
.hero::before{
  content:""; position: absolute; inset: 0;
  background:
    radial-gradient(70% 50% at 50% 0%, oklch(0.95 0.04 215 / 0.7), transparent 70%),
    radial-gradient(40% 40% at 85% 30%, oklch(0.90 0.08 142 / 0.18), transparent 70%),
    radial-gradient(45% 45% at 15% 70%, oklch(0.90 0.05 220 / 0.20), transparent 70%);
  z-index: -2;
  pointer-events: none;
}
/* Grain tipis */
.hero::after{
  content:""; position: absolute; inset: 0;
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='200' height='200'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2'/><feColorMatrix values='0 0 0 0 0  0 0 0 0 0  0 0 0 0 0  0 0 0 0.04 0'/></filter><rect width='100%' height='100%' filter='url(%23n)'/></svg>");
  opacity: 0.6;
  mix-blend-mode: multiply;
  pointer-events: none;
  z-index: -1;
}
/* Awan SVG / aliran lembut */
.hero-clouds{
  position: absolute; inset: 0;
  pointer-events: none;
  z-index: 0;
  overflow: hidden;
}
.hero-clouds svg{
  position: absolute;
  animation: cloud-drift 60s linear infinite;
}
@keyframes cloud-drift{
  from{ transform: translateX(-10%); }
  to{ transform: translateX(110%); }
}
/* Video slot di hero · fade ke putih di semua tepi */
.hero-video-slot{
  position: absolute;
  inset: 0;
  z-index: 0;
  overflow: hidden;
  pointer-events: none;
  /* Mask untuk fade ke putih (efek AQUVIVA) */
  -webkit-mask-image:
    radial-gradient(ellipse 90% 80% at 50% 50%, #000 30%, transparent 80%);
  mask-image:
    radial-gradient(ellipse 90% 80% at 50% 50%, #000 30%, transparent 80%);
}
.hero-video-slot video,
.hero-video-slot img{
  width: 100%; height: 100%;
  object-fit: cover;
  opacity: 0.35;
  mix-blend-mode: multiply;
  filter: saturate(0.7) contrast(0.9) brightness(1.05);
}

.hero-inner{
  position: relative;
  padding-top: 160px;
  padding-bottom: 80px;
  min-height: 100vh;
  display: grid;
  grid-template-columns: 1.05fr 0.95fr;
  gap: 60px;
  align-items: center;
  z-index: 2;
}

.hero-left .eyebrow{ color: var(--green); margin-bottom: 32px; }
.hero-left .eyebrow::before{ background: var(--green); opacity: 0.7; }

.hero-headline{
  font-family: var(--display);
  font-size: clamp(56px, 8.2vw, 140px);
  line-height: 0.92;
  letter-spacing: -0.025em;
  margin: 0 0 32px;
  font-weight: 300;
  color: var(--ink);
}
.hero-headline .it{
  font-style: italic;
  color: var(--green);
  font-weight: 300;
}
.hero-headline span{ display: block; }

.hero-sub{
  max-width: 480px;
  font-size: 17px;
  line-height: 1.6;
  color: var(--ink-soft);
  margin-bottom: 40px;
}

.hero-cta-row{
  display: flex; gap: 16px; align-items: center;
}
.btn-primary{
  background: var(--ink);
  color: var(--cream);
}
.btn-primary:hover{ background: var(--green); color: var(--cream); transform: translateY(-1px); }
.btn-ghost{
  border: 1px solid var(--ink);
  color: var(--ink);
  opacity: 0.85;
}
.btn-ghost:hover{
  border-color: var(--green);
  color: var(--green);
  opacity: 1;
}

.hero-meta{
  position: absolute;
  left: var(--pad-x);
  bottom: 40px;
  display: flex; gap: 40px;
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--ink-soft);
}
.hero-meta b{ display: block; color: var(--green); font-weight: 500; margin-bottom: 6px; }

.hero-scroll{
  position: absolute;
  right: var(--pad-x);
  bottom: 40px;
  display: flex; align-items: center; gap: 12px;
  font-family: var(--mono); font-size: 11px; letter-spacing: 0.2em; text-transform: uppercase;
  color: var(--ink-soft);
}
.hero-scroll .line{
  width: 1px; height: 36px;
  background: linear-gradient(180deg, transparent, var(--green), transparent);
  background-size: 100% 200%;
  animation: scrollline 2s infinite;
}
@keyframes scrollline{
  0%{ background-position: 0 -100%; }
  100%{ background-position: 0 200%; }
}

/* Right column · bottle stage */
.hero-stage{
  position: relative;
  height: 70vh;
  min-height: 540px;
  z-index: 3;
}
.hero-bottle{
  position: absolute;
  inset: 0;
  display: flex; align-items: center; justify-content: center;
}
.hero-bottle img{
  max-height: 100%;
  width: auto;
  /* PNG cutout di atas background bright · shadow dramatis tapi lembut */
  filter:
    drop-shadow(0 50px 60px rgba(50, 90, 60, 0.20))
    drop-shadow(0 20px 30px rgba(50, 90, 60, 0.15))
    drop-shadow(0 0 60px oklch(0.76 0.18 142 / 0.18));
  animation: floaty 7s ease-in-out infinite, swayslight 11s ease-in-out infinite;
  transform-origin: 50% 90%;
}
@keyframes floaty{
  0%, 100%{ transform: translateY(0); }
  50%{ transform: translateY(-14px); }
}
@keyframes swayslight{
  0%, 100%{ transform: rotate(-1.2deg); }
  50%{ transform: rotate(1.2deg); }
}

/* Orbs sekarang sangat lembut, fresh */
.orb{
  position: absolute;
  border-radius: 50%;
  filter: blur(50px);
  pointer-events: none;
  opacity: 0.45;
}
.orb-1{ width: 380px; height: 380px; background: oklch(0.85 0.12 142 / 0.4); top: 5%; right: -10%; }
.orb-2{ width: 260px; height: 260px; background: oklch(0.85 0.09 220 / 0.5); bottom: 5%; left: -8%; animation: floaty 9s ease-in-out infinite reverse; }

.hero-badges{
  position: absolute;
  right: var(--pad-x);
  top: 50%;
  transform: translateY(-50%);
  display: flex; flex-direction: column; gap: 14px;
  font-family: var(--mono); font-size: 10px; letter-spacing: 0.18em;
  color: var(--ink-soft);
  text-transform: uppercase;
  text-align: right;
  z-index: 5;
}
.hero-badges span{ position: relative; padding-right: 18px; }
.hero-badges span::after{
  content:""; position: absolute; right: 0; top: 50%;
  width: 8px; height: 1px; background: var(--green);
}

/* Tetesan kondensasi (drift) */
.droplets{
  position: absolute; inset: 0;
  pointer-events: none;
  overflow: hidden;
  z-index: 1;
}
.droplets i{
  position: absolute;
  display: block;
  width: 4px; height: 4px;
  border-radius: 50%;
  background: oklch(0.85 0.10 220);
  opacity: 0;
  animation: drift 12s linear infinite;
}
@keyframes drift{
  0%{ transform: translateY(100vh) scale(0.5); opacity: 0; }
  10%{ opacity: 0.5; }
  90%{ opacity: 0.3; }
  100%{ transform: translateY(-10vh) scale(1); opacity: 0; }
}
/* === replaced by AQUVIVA-inspired hero above === */

/* Btn base · dipakai global */
.btn{
  display: inline-flex; align-items: center; gap: 12px;
  padding: 16px 28px;
  border-radius: 999px;
  font-size: 14px; letter-spacing: 0.01em;
  transition: all 0.4s var(--ease-cinema);
  position: relative;
  overflow: hidden;
  border: none;
  cursor: pointer;
  font-family: inherit;
}
.btn .arrow{ transition: transform 0.4s var(--ease-cinema); }
.btn:hover .arrow{ transform: translateX(4px); }

/* =========================================================
   VIDEO SLOT UTILITIES · fade ke putih di tepi (AQUVIVA style)
   ========================================================= */
.video-fade{
  position: relative;
  overflow: hidden;
  isolation: isolate;
}
.video-fade video,
.video-fade img.video-placeholder{
  width: 100%; height: 100%;
  object-fit: cover;
  display: block;
}
/* Variants of fade mask */
.video-fade.fade-all{
  -webkit-mask-image: radial-gradient(ellipse 75% 70% at 50% 50%, #000 0%, #000 40%, transparent 95%);
  mask-image: radial-gradient(ellipse 75% 70% at 50% 50%, #000 0%, #000 40%, transparent 95%);
}
.video-fade.fade-bottom{
  -webkit-mask-image: linear-gradient(180deg, #000 0%, #000 60%, transparent 100%);
  mask-image: linear-gradient(180deg, #000 0%, #000 60%, transparent 100%);
}
.video-fade.fade-top-bottom{
  -webkit-mask-image: linear-gradient(180deg, transparent 0%, #000 30%, #000 70%, transparent 100%);
  mask-image: linear-gradient(180deg, transparent 0%, #000 30%, #000 70%, transparent 100%);
}
.video-fade.fade-sides{
  -webkit-mask-image: linear-gradient(90deg, transparent 0%, #000 20%, #000 80%, transparent 100%);
  mask-image: linear-gradient(90deg, transparent 0%, #000 20%, #000 80%, transparent 100%);
}
/* Tint overlay variants */
.video-fade.tint-cream::after{
  content:""; position: absolute; inset: 0;
  background: var(--cream);
  mix-blend-mode: lighten;
  opacity: 0.35;
  pointer-events: none;
}
.video-fade.tint-mint::after{
  content:""; position: absolute; inset: 0;
  background: var(--mint);
  mix-blend-mode: multiply;
  opacity: 0.18;
  pointer-events: none;
}
.video-fade.desat video{
  filter: saturate(0.6) brightness(1.08) contrast(0.92);
}

/* =========================================================
   SUMBER · nature reveal section (between filosofi & process)
   ========================================================= */
.sumber{
  position: relative;
  padding: 0;
  background: var(--off-white);
  overflow: hidden;
}
.sumber-video{
  position: relative;
  width: 100%;
  aspect-ratio: 21 / 9;
  min-height: 460px;
  overflow: hidden;
  isolation: isolate;
}
.sumber-video video,
.sumber-video .video-placeholder{
  position: absolute;
  inset: 0;
  width: 100%; height: 100%;
  object-fit: cover;
  z-index: 0;
}
.sumber-video::before{
  content:""; position: absolute; inset: 0;
  /* Fade ke putih di atas & bawah seperti AQUVIVA */
  background:
    linear-gradient(180deg,
      var(--off-white) 0%,
      transparent 22%,
      transparent 78%,
      var(--off-white) 100%);
  z-index: 2;
  pointer-events: none;
}
.sumber-video::after{
  content:""; position: absolute; inset: 0;
  /* Fade samping */
  background:
    linear-gradient(90deg,
      var(--off-white) 0%,
      transparent 18%,
      transparent 82%,
      var(--off-white) 100%);
  z-index: 2;
  pointer-events: none;
}
.sumber-content{
  position: absolute;
  inset: 0;
  z-index: 3;
  display: flex;
  align-items: center;
  justify-content: center;
  text-align: center;
  padding: var(--pad-x);
}
.sumber-content h2{
  font-family: var(--display);
  font-size: clamp(44px, 7vw, 120px);
  line-height: 0.96;
  letter-spacing: -0.025em;
  font-weight: 300;
  margin: 0;
  max-width: 1100px;
  color: var(--ink);
  text-shadow: 0 2px 30px oklch(0.99 0.004 100 / 0.5);
}
.sumber-content h2 .it{ font-style: italic; color: var(--green); }
.sumber-content .eyebrow{ justify-content: center; margin-bottom: 24px; color: var(--green); }
.sumber-caption{
  position: absolute;
  bottom: 32px; left: 50%;
  transform: translateX(-50%);
  z-index: 3;
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--ink-soft);
  text-align: center;
}

/* =========================================================
   MARQUEE
   ========================================================= */
.marquee{
  /* Marquee diberi hijau-segar lembut, bukan forest-deep, agar terasa hidup */
  background: linear-gradient(90deg, var(--green) 0%, var(--leaf) 50%, var(--green) 100%);
  color: var(--cream);
  border-top: 1px solid oklch(0.55 0.10 145);
  border-bottom: 1px solid oklch(0.55 0.10 145);
  padding: 24px 0;
  overflow: hidden;
  position: relative;
  z-index: 2;
}
.marquee-track{
  display: flex;
  gap: 60px;
  animation: marqueescroll 35s linear infinite;
  white-space: nowrap;
  width: max-content;
}
.marquee-track span{
  display: inline-flex; align-items: center; gap: 28px;
  font-family: var(--serif);
  font-size: clamp(28px, 4vw, 56px);
  letter-spacing: -0.02em;
}
.marquee-track span em{
  font-family: var(--mono);
  font-style: normal;
  font-size: 14px;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--cream);
  opacity: 0.85;
}
.marquee-track .dot{
  width: 8px; height: 8px;
  background: var(--mint);
  border-radius: 50%;
  display: inline-block;
}
@keyframes marqueescroll{
  from{ transform: translateX(0); }
  to{ transform: translateX(-50%); }
}

/* =========================================================
   MANIFESTO / FILOSOFI
   ========================================================= */
.manifesto{
  background: var(--cream);
  padding: clamp(70px, 8vw, 110px) 0;
  position: relative;
  overflow: hidden;
}
.manifesto-eyebrow{
  display: flex; justify-content: space-between; align-items: center;
  margin-bottom: 80px;
  flex-wrap: wrap; gap: 20px;
}
.manifesto-eyebrow .right{
  font-family: var(--mono); font-size: 11px; letter-spacing: 0.18em;
  text-transform: uppercase; color: var(--ink-soft);
}
.manifesto-grid{
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: clamp(48px, 7vw, 120px);
  align-items: start;
}
.manifesto-heading{
  font-family: var(--serif);
  font-size: clamp(48px, 6.5vw, 110px);
  line-height: 0.96;
  letter-spacing: -0.025em;
  margin: 0;
  font-weight: 400;
}
.manifesto-heading .it{ font-style: italic; color: var(--green); }
.manifesto-body{
  font-size: 19px; line-height: 1.7;
  color: var(--ink-soft);
  max-width: 520px;
}
.manifesto-body p{ margin: 0 0 22px; }
.manifesto-body p:first-child{
  font-size: 21px; color: var(--ink); line-height: 1.55;
}
/* values strip below manifesto */
.values{
  margin-top: 100px;
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 16px;
}
.value{
  background: var(--cream);
  padding: 56px 36px;
  position: relative;
  border-bottom: 1px solid var(--line);
  box-shadow: 0 0 0 0 rgba(50,90,60,0);
  transition: background 0.4s cubic-bezier(0.16, 1, 0.3, 1),
              transform 0.4s cubic-bezier(0.16, 1, 0.3, 1),
              box-shadow 0.4s cubic-bezier(0.16, 1, 0.3, 1);
}
.value:hover{
  background: var(--mint-pale);
  transform: translateY(-3px);
  box-shadow: 0 12px 24px -8px rgba(50,90,60,0.12);
}
.value .num{
  font-family: var(--mono); font-size: 11px; letter-spacing: 0.18em;
  color: var(--green); margin-bottom: 28px;
}
.value .name{
  font-family: var(--serif); font-size: 36px; line-height: 1;
  margin-bottom: 14px;
}
.value .desc{ font-size: 14px; color: var(--ink-soft); line-height: 1.5; }

/* =========================================================
   POSTER MOMENT
   ========================================================= */
.poster{
  position: relative;
  min-height: 100vh;
  overflow: hidden;
  background: var(--forest-deep);
  color: var(--cream);
}
.poster-bg{
  position: absolute; inset: 0;
  background-image: url('images/poster-frame.jpg');
  background-size: cover;
  background-position: center;
  z-index: 0;
}
/* Saat .poster-bg berupa <video> (bukan div bg-image) */
video.poster-bg{
  width: 100%; height: 100%;
  object-fit: cover;
  object-position: center;
}
.poster::after{
  content:""; position: absolute; inset: 0;
  /* Gradient sinematik kuat · gelap di area teks (atas & bawah) supaya kontras tinggi */
  background:
    linear-gradient(180deg,
      oklch(0.16 0.04 155 / 0.70) 0%,
      oklch(0.16 0.04 155 / 0.30) 18%,
      oklch(0.16 0.04 155 / 0.05) 38%,
      oklch(0.16 0.04 155 / 0.45) 62%,
      oklch(0.14 0.03 155 / 0.88) 88%,
      oklch(0.12 0.03 155 / 0.96) 100%),
    radial-gradient(80% 50% at 50% 100%, oklch(0.14 0.03 155 / 0.55), transparent 70%);
  z-index: 1;
}
.poster-inner{
  position: relative;
  z-index: 2;
  min-height: 100vh;
  display: flex; flex-direction: column; justify-content: flex-end;
  padding: 100px 0;
}
/* Frosted backing panel khusus untuk blok teks supaya tetap terbaca di komposisi gambar yang ramai */
.poster-textwrap{
  position: relative;
  padding: 36px 0 8px;
  isolation: isolate;
}
.poster-textwrap::before{
  content:"";
  position: absolute;
  inset: 0 -40px -10px -40px;
  background: linear-gradient(180deg,
    oklch(0.12 0.03 155 / 0) 0%,
    oklch(0.12 0.03 155 / 0.35) 30%,
    oklch(0.10 0.03 155 / 0.65) 100%);
  backdrop-filter: blur(2px);
  -webkit-backdrop-filter: blur(2px);
  border-radius: 6px;
  z-index: -1;
}
.poster-headline{
  text-shadow: 0 2px 24px oklch(0.10 0.03 155 / 0.55), 0 1px 0 oklch(0.10 0.03 155 / 0.3);
}
.poster-sub{ text-shadow: 0 1px 12px oklch(0.10 0.03 155 / 0.6); }
.poster-line1{
  font-family: var(--mono); font-size: 12px; letter-spacing: 0.25em;
  text-transform: uppercase; color: var(--cream);
  display: flex; align-items: center; gap: 16px;
  margin-bottom: 28px;
}
.poster-line1::before{
  content:""; width: 50px; height: 1px; background: currentColor;
}
.poster-headline{
  font-family: var(--serif);
  font-size: clamp(40px, 6vw, 88px);
  line-height: 1.02;
  letter-spacing: -0.02em;
  max-width: 900px;
  margin: 0 0 30px;
  font-weight: 400;
}
.poster-headline .it{ font-style: italic; color: var(--mint); }
.poster-row{
  display: flex; justify-content: space-between; align-items: flex-end;
  flex-wrap: wrap; gap: 24px;
}
.poster-sub{ max-width: 440px; color: oklch(0.92 0.02 100); }
.poster-stats{
  display: flex; gap: 50px;
  font-family: var(--mono); font-size: 11px; letter-spacing: 0.16em;
  text-transform: uppercase;
  color: oklch(0.86 0.02 100 / 0.85);
}
.poster-stats b{
  font-family: var(--serif); font-style: italic;
  font-size: 42px; display: block; letter-spacing: -0.02em;
  margin-bottom: 4px; color: var(--mint); font-weight: 400;
}

/* =========================================================
   PROCESS · 4 Pillars
   ========================================================= */
.process{
  background: var(--off-white);
  padding: clamp(70px, 8vw, 110px) 0;
  position: relative;
}
.process-head{
  display: grid; grid-template-columns: 1fr 1fr;
  gap: 60px; align-items: end;
  margin-bottom: 80px;
}
.process-head h2{
  font-family: var(--serif);
  font-size: clamp(40px, 5.5vw, 84px);
  line-height: 0.98;
  letter-spacing: -0.02em;
  margin: 20px 0 0;
  font-weight: 400;
}
.process-head h2 .it{ font-style: italic; color: var(--green); }
.process-head p{
  font-size: 17px; color: var(--ink-soft);
  max-width: 460px; line-height: 1.6;
}

.pillars{
  display: grid;
  grid-template-columns: 1fr;
  gap: 30px;
}
.pillar{
  display: grid;
  grid-template-columns: 80px 0.8fr 1.2fr;
  gap: 50px;
  align-items: stretch;
  padding: 50px 0;
  border-top: 1px solid var(--line);
  position: relative;
  transition: background 0.5s var(--ease-cinema);
}
.pillar:last-child{ border-bottom: 1px solid var(--line); }
.pillar:hover{ background: var(--mint-pale); padding-inline: 30px; }
.pillar-num{
  font-family: var(--mono);
  font-size: 12px;
  letter-spacing: 0.16em;
  color: var(--green);
  align-self: start;
  padding-top: 10px;
}
.pillar-text h3{
  font-family: var(--serif);
  font-size: clamp(28px, 3vw, 44px);
  line-height: 1.02;
  margin: 0 0 18px;
  letter-spacing: -0.015em;
  font-weight: 400;
}
.pillar-text h3 .it{ font-style: italic; color: var(--green); }
.pillar-text p{
  font-size: 16px; color: var(--ink-soft);
  line-height: 1.6; max-width: 380px; margin: 0;
}
.pillar-img{
  position: relative;
  aspect-ratio: 16 / 10;
  overflow: hidden;
  border-radius: 4px;
  background: var(--mint-pale);
}
.pillar-img img,
.pillar-img video{
  width: 100%; height: 100%; object-fit: cover;
  transition: transform 1.4s var(--ease-cinema), filter 0.6s;
  filter: saturate(0.95);
}
.pillar:hover .pillar-img video{
  transform: scale(1.04);
  filter: saturate(1.1);
}
/* Variant untuk PNG cutout botol · bukan dipotong, tapi dipajang di atas stage */
.pillar-img.cutout{
  background:
    radial-gradient(60% 80% at 50% 60%, oklch(0.85 0.10 158 / 0.55), oklch(0.97 0.03 158) 70%),
    var(--mint-pale);
}
.pillar-img.cutout::after{
  content:"";
  position: absolute; left: 50%; bottom: 14%;
  transform: translateX(-50%);
  width: 60%; height: 14px;
  background: radial-gradient(50% 100% at 50% 0%, rgba(0,0,0,0.22), transparent 80%);
  filter: blur(4px);
  z-index: 1;
}
.pillar-img.cutout img{
  object-fit: contain;
  object-position: center;
  padding: 24px 0;
  filter:
    drop-shadow(0 22px 28px rgba(0,0,0,0.25))
    drop-shadow(0 8px 14px rgba(0,0,0,0.18));
  background: none;
}
.pillar:hover .pillar-img.cutout img{
  transform: scale(1.04) translateY(-4px);
  filter:
    drop-shadow(0 30px 36px rgba(0,0,0,0.30))
    drop-shadow(0 10px 16px rgba(0,0,0,0.22));
}
.pillar:hover .pillar-img img{ transform: scale(1.05); filter: saturate(1.1); }
/* Pillar video = dekoratif: sembunyikan native controls + non-interaktif */
.pillar-img video{ pointer-events: none; }
.pillar-img video::-webkit-media-controls,
.pillar-img video::-webkit-media-controls-enclosure{ display: none !important; }
.pillar-img::before{
  content: attr(data-label);
  position: absolute; top: 16px; left: 16px;
  font-family: var(--mono); font-size: 10px; letter-spacing: 0.16em;
  color: var(--cream);
  background: oklch(0.20 0.04 155 / 0.7);
  backdrop-filter: blur(8px);
  padding: 6px 12px;
  border-radius: 999px;
  text-transform: uppercase;
  z-index: 2;
}

/* =========================================================
   PRODUCT
   ========================================================= */
.product{
  background: linear-gradient(180deg, var(--mint-pale) 0%, oklch(0.96 0.035 200) 100%);
  padding: clamp(70px, 8vw, 110px) 0;
  position: relative;
  overflow: hidden;
}
.product-grid{
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 80px;
  align-items: center;
}
.product-img-wrap{
  position: relative;
  /* Stage panjang untuk dua botol cutout berdampingan */
  aspect-ratio: 4 / 5;
  max-width: 560px;
  display: flex; align-items: center; justify-content: center;
}
.product-img-wrap::before{
  content:""; position: absolute; inset: -10% -5%;
  background:
    radial-gradient(45% 55% at 40% 55%, oklch(0.70 0.16 148 / 0.22), transparent 70%),
    radial-gradient(45% 55% at 65% 60%, oklch(0.78 0.11 220 / 0.18), transparent 70%);
  z-index: 0;
  border-radius: 50%;
  filter: blur(4px);
}
/* Ground reflection / bayangan jatuh */
.product-img-wrap::after{
  content:"";
  position: absolute; left: 12%; right: 12%;
  bottom: 4%;
  height: 36px;
  background: radial-gradient(50% 100% at 50% 0%, rgba(0, 0, 0, 0.28), transparent 75%);
  filter: blur(6px);
  z-index: 0;
}
.product-img-wrap img{
  position: absolute;
  z-index: 1;
  height: 95%;
  width: auto;
  object-fit: contain;
  border-radius: 0;
  filter:
    drop-shadow(0 40px 40px rgba(0,0,0,0.30))
    drop-shadow(0 14px 20px rgba(0,0,0,0.22))
    drop-shadow(0 0 50px oklch(0.76 0.18 142 / 0.12));
  transition: transform 1.2s var(--ease-cinema), filter 0.6s;
  animation: bottle-float 8s ease-in-out infinite;
  transform-origin: 50% 90%;
}
.product-img-wrap .bottle-front{
  left: 18%;
  z-index: 2;
  animation-delay: 0s;
}
.product-img-wrap .bottle-back{
  right: 14%;
  height: 88%;
  opacity: 0.95;
  z-index: 1;
  animation-delay: 1.5s;
}
@keyframes bottle-float{
  0%, 100%{ transform: translateY(0) rotate(-1deg); }
  50%{ transform: translateY(-10px) rotate(1.2deg); }
}
.product-img-wrap:hover .bottle-front{ transform: translateY(-8px) rotate(-2deg) scale(1.02); }
.product-img-wrap:hover .bottle-back{ transform: translateY(-4px) rotate(1.8deg); }
.product-img-wrap .float-tag{
  position: absolute;
  background: var(--off-white);
  color: var(--ink);
  padding: 14px 18px;
  border-radius: 999px;
  font-family: var(--mono); font-size: 11px; letter-spacing: 0.16em;
  text-transform: uppercase;
  box-shadow: 0 20px 40px -10px rgba(0,0,0,0.12);
  z-index: 2;
  display: flex; align-items: center; gap: 10px;
}
.float-tag .pip{
  width: 6px; height: 6px; border-radius: 50%; background: var(--green);
}
.float-tag.t1{ top: 10%; left: -10%; }
.float-tag.t2{ bottom: 18%; right: -8%; }

.product-info .eyebrow{ margin-bottom: 28px; color: var(--green); }
.product-info h2{
  color: var(--ink);
  font-family: var(--serif);
  font-size: clamp(40px, 5vw, 76px);
  line-height: 0.98;
  letter-spacing: -0.02em;
  margin: 0 0 30px;
  font-weight: 400;
}
.product-info h2 .it{ font-style: italic; color: var(--green); }
.product-info > p{
  font-size: 17px; line-height: 1.65;
  color: var(--ink);
  max-width: 480px;
  margin-bottom: 50px;
}
.product-specs{
  display: grid; grid-template-columns: 1fr 1fr;
  gap: 30px 50px;
  margin-bottom: 40px;
}
.spec{ border-top: 1px solid var(--line); padding-top: 18px; }
.spec .k{
  font-family: var(--mono); font-size: 10px; letter-spacing: 0.18em;
  color: var(--ink-soft); text-transform: uppercase;
  margin-bottom: 10px;
}
.spec .v{
  font-family: var(--serif); font-size: 28px; line-height: 1;
  color: var(--ink);
}
.spec .v small{
  font-family: var(--sans); font-size: 13px;
  color: var(--ink-soft); margin-left: 4px;
}

/* =========================================================
   CERTIFICATIONS
   ========================================================= */
.certifications{
  background: var(--forest-deep);
  color: var(--cream);
  padding: clamp(90px, 10vw, 140px) 0;
  position: relative;
  overflow: hidden;
}
.certifications::before{
  content:""; position: absolute; inset: 0;
  background:
    radial-gradient(40% 60% at 80% 20%, oklch(0.45 0.10 152 / 0.4), transparent 70%);
  pointer-events: none;
}
.cert-head{
  display: grid; grid-template-columns: 1fr 1fr;
  gap: 60px; align-items: end; margin-bottom: 80px;
  position: relative;
}
.cert-head .eyebrow{ color: var(--mint); }
.cert-head h2{
  font-family: var(--serif);
  font-size: clamp(40px, 5vw, 84px);
  line-height: 1;
  letter-spacing: -0.02em;
  margin: 24px 0 0; font-weight: 400;
}
.cert-head h2 .it{ font-style: italic; color: var(--mint); }
.cert-head p{
  color: oklch(0.82 0.02 100);
  max-width: 460px;
  font-size: 16px; line-height: 1.6;
}

.cert-grid{
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1px;
  background: oklch(0.30 0.04 155);
  border: 1px solid oklch(0.30 0.04 155);
  position: relative;
}
.cert{
  background: var(--forest-deep);
  padding: 50px 40px;
  transition: background 0.5s;
  position: relative;
  min-height: 320px;
  display: flex; flex-direction: column; justify-content: space-between;
}
.cert:hover{ background: oklch(0.22 0.05 155); }
.cert-mark{
  width: 56px; height: 56px; border-radius: 50%;
  border: 1px solid var(--mint);
  display: flex; align-items: center; justify-content: center;
  font-family: var(--serif); font-style: italic; font-size: 24px;
  color: var(--mint);
  margin-bottom: 50px;
}
.cert h3{
  font-family: var(--serif); font-size: 32px;
  margin: 0 0 14px; font-weight: 400; line-height: 1.05;
}
.cert p{
  font-size: 14px; color: oklch(0.78 0.02 100);
  line-height: 1.55; margin: 0;
}
.cert .code{
  font-family: var(--mono); font-size: 10px; letter-spacing: 0.18em;
  color: var(--mint); text-transform: uppercase;
  margin-top: 24px;
}

/* =========================================================
   TEAM & DISTRIBUTION
   ========================================================= */
.team{
  background: var(--off-white);
  padding: clamp(70px, 8vw, 110px) 0;
  /* position+overflow: kurung bokeh aksen (right:-150px) supaya ter-clip di
     batas section, bukan bocor ke body (penyebab overflow horizontal mobile). */
  position: relative;
  overflow: hidden;
}
.team-head{
  text-align: center;
  margin-bottom: 80px;
  max-width: 920px;
  margin-inline: auto;
}
.team-head h2{
  font-family: var(--serif);
  font-size: clamp(44px, 5.5vw, 88px);
  line-height: 1;
  letter-spacing: -0.02em;
  margin: 24px 0 0; font-weight: 400;
}
.team-head h2 .it{ font-style: italic; color: var(--green); }

.team-grid{
  display: grid;
  grid-template-columns: 1.2fr 0.8fr 1fr;
  grid-template-rows: 360px 360px;
  gap: 16px;
}
.tg-item{
  position: relative;
  border-radius: 4px;
  overflow: hidden;
  background: var(--mint-pale);
}
.tg-item img{
  width: 100%; height: 100%; object-fit: cover;
  transition: transform 1.4s var(--ease-cinema);
}
.tg-item:hover img{ transform: scale(1.04); }
.tg-item .caption{
  position: absolute; left: 20px; bottom: 20px;
  font-family: var(--mono); font-size: 10px; letter-spacing: 0.18em;
  color: var(--cream); text-transform: uppercase;
  background: oklch(0.18 0.04 155 / 0.6);
  backdrop-filter: blur(8px);
  padding: 8px 14px; border-radius: 999px;
}
.tg-item.tall{ grid-row: span 2; }
.tg-item.wide{ grid-column: span 1; }

.team-blocks{
  margin-top: 100px;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 60px 80px;
  border-top: 1px solid var(--line);
  padding-top: 60px;
}
.team-block .label{
  font-family: var(--mono); font-size: 11px; letter-spacing: 0.18em;
  color: var(--green); text-transform: uppercase;
  margin-bottom: 18px;
}
.team-block h3{
  font-family: var(--serif); font-size: 32px;
  margin: 0 0 14px; font-weight: 400; letter-spacing: -0.01em;
}
.team-block p{
  font-size: 16px; color: var(--ink-soft); line-height: 1.6;
  margin: 0;
}

/* =========================================================
   PARTNERSHIP CTA
   ========================================================= */
.partner{
  background: var(--cream);
  padding: clamp(70px, 8vw, 110px) 0;
  position: relative;
  overflow: hidden;
}
.partner-inner{
  display: grid; grid-template-columns: 1fr 1fr;
  gap: 80px;
  align-items: center;
}
.partner h2{
  font-family: var(--serif);
  font-size: clamp(48px, 6.5vw, 108px);
  line-height: 0.96;
  letter-spacing: -0.025em;
  margin: 24px 0 0;
  font-weight: 400;
}
.partner h2 .it{ font-style: italic; color: var(--green); }
.partner-right p{
  font-size: 17px; line-height: 1.65; color: var(--ink-soft);
  margin: 0 0 40px;
}
.partner-form{
  display: flex; flex-direction: column; gap: 14px;
}
.partner-field{
  display: flex; align-items: center; gap: 14px;
  border-bottom: 1px solid var(--line);
  padding: 16px 0;
  transition: border-color 0.3s;
}
.partner-field:focus-within{ border-color: var(--green); }
.partner-field label{
  font-family: var(--mono); font-size: 10px; letter-spacing: 0.18em;
  color: var(--ink-soft); text-transform: uppercase;
  min-width: 70px;
}
.partner-field input, .partner-field select{
  flex: 1;
  border: none; background: transparent;
  font-family: var(--sans); font-size: 16px;
  color: var(--ink);
  outline: none;
}
.partner-field input::placeholder{ color: oklch(0.65 0.02 155); }
.partner-submit{
  margin-top: 24px;
  align-self: flex-start;
  background: var(--ink);
  color: var(--cream);
  padding: 18px 32px;
  border-radius: 999px;
  font-size: 14px; letter-spacing: 0.02em;
  display: inline-flex; align-items: center; gap: 12px;
  transition: background 0.4s, transform 0.4s var(--ease-cinema);
}
.partner-submit:hover{ background: var(--green); transform: translateY(-2px); }
.partner-submit .arrow{ transition: transform 0.4s var(--ease-cinema); }
.partner-submit:hover .arrow{ transform: translateX(4px); }

/* =========================================================
   FOOTER
   ========================================================= */
.footer{
  background: var(--forest-deep);
  color: var(--cream);
  padding: 100px 0 40px;
  position: relative;
  overflow: hidden;
}
.footer-top{
  display: grid;
  grid-template-columns: 1.4fr 0.8fr 0.8fr 0.8fr;
  gap: 50px;
  padding-bottom: 80px;
  border-bottom: 1px solid oklch(0.30 0.04 155);
}
.footer-brand .nav-logo{ color: var(--cream); }
.footer-brand p{
  margin-top: 30px; color: oklch(0.82 0.02 100);
  font-size: 15px; max-width: 380px; line-height: 1.6;
}
.footer-col h4{
  font-family: var(--mono); font-size: 11px; letter-spacing: 0.18em;
  color: var(--mint); text-transform: uppercase;
  margin: 0 0 22px;
}
.footer-col ul{
  list-style: none; padding: 0; margin: 0;
  display: flex; flex-direction: column; gap: 14px;
}
.footer-col a{
  font-size: 15px; opacity: 0.85;
  transition: opacity 0.3s, color 0.3s;
}
.footer-col a:hover{ opacity: 1; color: var(--mint); }

.footer-mega{
  /* Logo HST asli sebagai penutup, raksasa & terang */
  margin: 60px 0 30px;
  text-align: center;
  position: relative;
}
.footer-mega img{
  width: 100%;
  max-width: 480px;
  height: auto;
  margin: 0 auto;
  display: block;
  /* Bersihkan teks hijau "Air Mineral" supaya tetap kontras dengan latar deep forest ·
     kita pakai brightness boost + drop-shadow halus mint */
  filter:
    brightness(1.1)
    drop-shadow(0 20px 40px oklch(0.30 0.10 145 / 0.5))
    drop-shadow(0 0 60px oklch(0.76 0.18 142 / 0.25));
  opacity: 0.95;
}
.footer-bottom{
  display: flex; justify-content: space-between; align-items: center;
  font-family: var(--mono); font-size: 11px; letter-spacing: 0.16em;
  color: oklch(0.72 0.02 100); text-transform: uppercase;
  flex-wrap: wrap; gap: 16px;
}

/* =========================================================
   REVEAL ANIMATIONS
   ========================================================= */
[data-reveal]{
  opacity: 0;
  transform: translateY(40px);
  transition: opacity 1s var(--ease-cinema), transform 1.2s var(--ease-cinema);
}
[data-reveal].in{
  opacity: 1; transform: translateY(0);
}
[data-reveal="fade"]{ transform: none; }
[data-reveal="left"]{ transform: translateX(-50px); }
[data-reveal="left"].in{ transform: translateX(0); }
[data-reveal="scale"]{ transform: scale(0.96); }
[data-reveal="scale"].in{ transform: scale(1); }

[data-stagger] > *{
  opacity: 0; transform: translateY(30px);
  transition: opacity 0.9s var(--ease-cinema), transform 1s var(--ease-cinema);
}
[data-stagger].in > *{
  opacity: 1; transform: translateY(0);
}
[data-stagger].in > *:nth-child(1){ transition-delay: 0.05s; }
[data-stagger].in > *:nth-child(2){ transition-delay: 0.15s; }
[data-stagger].in > *:nth-child(3){ transition-delay: 0.25s; }
[data-stagger].in > *:nth-child(4){ transition-delay: 0.35s; }
[data-stagger].in > *:nth-child(5){ transition-delay: 0.45s; }
[data-stagger].in > *:nth-child(6){ transition-delay: 0.55s; }

/* mask reveal for images */
.mask-reveal{
  position: relative;
  overflow: hidden;
}
.mask-reveal::after{
  content:"";
  position: absolute; inset: 0;
  background: var(--cream);
  transform: scaleX(1);
  transform-origin: right;
  transition: transform 1.2s var(--ease-cinema);
  z-index: 5;
}
.mask-reveal.in::after{ transform: scaleX(0); }

/* split text */
.split-line{ display: block; overflow: hidden; }
.split-line > span{
  display: inline-block;
  transform: translateY(110%);
  transition: transform 1.1s var(--ease-cinema);
}
.split-line.in > span{ transform: translateY(0); }

/* =========================================================
   SVG ATMOSPHERIC DECORATIONS · air, gunung, gelombang, gelembung
   Semua vektor / CSS murni. Siap dianimasikan.
   ========================================================= */

/* ---- Wave dividers antar-section ----
   Pemakaian: <svg class="section-wave wave-down"> di bagian ATAS section,
   fill diisi warna section itu sendiri (CSS var). Wave akan "naik" ke
   section sebelumnya sehingga peralihan terasa mengalir.
*/
.section-wave{
  position: absolute;
  left: 0; right: 0;
  width: 100%;
  height: 70px;
  pointer-events: none;
  z-index: 3;
  display: block;
}
.section-wave.wave-top{
  top: 0;
  transform: translateY(-99%);
}
.section-wave.wave-bottom{
  bottom: 0;
  transform: translateY(99%) scaleY(-1);
}
@media (max-width: 700px){
  .section-wave{ height: 40px; }
}

/* ---- Floating bubbles (gelembung air) ----
   Bisa di-spawn sebagai dekorasi di section yang sesuai.
   Animasi naik perlahan (siap di-customize).
*/
.bubbles{
  position: absolute;
  inset: 0;
  overflow: hidden;
  pointer-events: none;
  z-index: 1;
}
.bubbles svg{
  position: absolute;
  display: block;
  animation: bubble-rise var(--dur, 14s) ease-in-out infinite;
  animation-delay: var(--delay, 0s);
  opacity: 0;
}
@keyframes bubble-rise{
  0%{ transform: translateY(20px) scale(0.6); opacity: 0; }
  15%{ opacity: 0.45; }
  85%{ opacity: 0.25; }
  100%{ transform: translateY(-120vh) scale(1); opacity: 0; }
}

/* ---- Water ripple rings (riak air) ----
   Konsentrik, lambat · biasanya di sudut section sebagai aksen.
*/
.ripple{
  position: absolute;
  width: 360px;
  height: 360px;
  pointer-events: none;
  opacity: 0.55;
  z-index: 0;
}
.ripple svg{ width: 100%; height: 100%; }
.ripple circle{
  fill: none;
  stroke: currentColor;
  stroke-width: 1;
  transform-origin: center;
  animation: ripple-out 6s var(--ease-cinema) infinite;
}
.ripple circle:nth-child(1){ animation-delay: 0s; }
.ripple circle:nth-child(2){ animation-delay: 1.2s; }
.ripple circle:nth-child(3){ animation-delay: 2.4s; }
.ripple circle:nth-child(4){ animation-delay: 3.6s; }
@keyframes ripple-out{
  0%{ transform: scale(0.3); opacity: 0.8; }
  100%{ transform: scale(1); opacity: 0; }
}

/* ---- Droplets / butir air kecil sebagai SVG ----
   Bentuk tetes air klasik (path teardrop). Bisa diberi animasi jatuh.
*/
.water-droplet{
  position: absolute;
  width: 16px; height: 22px;
  pointer-events: none;
  opacity: 0.5;
  animation: droplet-fall 8s linear infinite;
  animation-delay: var(--delay, 0s);
}
@keyframes droplet-fall{
  0%{ transform: translateY(-20px); opacity: 0; }
  10%{ opacity: 0.55; }
  90%{ opacity: 0.4; }
  100%{ transform: translateY(50vh); opacity: 0; }
}

/* ---- Atmospheric light orbs / bokeh ----
   Untuk dipasang di section terang sebagai aksen "aura".
*/
.bokeh{
  position: absolute;
  border-radius: 50%;
  pointer-events: none;
  filter: blur(60px);
  z-index: 0;
}
.bokeh.green{  background: oklch(0.76 0.18 142 / 0.18); }
.bokeh.mint{   background: oklch(0.85 0.10 158 / 0.30); }
.bokeh.water{  background: oklch(0.78 0.11 220 / 0.18); }
.bokeh.cream{  background: oklch(0.90 0.04 100 / 0.4); }

/* ---- Soft floating leaf (daun, sebagai vektor) ----
   Hanya bentuk geometris halus, bukan ilustrasi penuh.
*/
.float-leaf{
  position: absolute;
  pointer-events: none;
  opacity: 0.55;
  animation: leaf-drift 18s ease-in-out infinite;
  animation-delay: var(--delay, 0s);
  transform-origin: center;
}
@keyframes leaf-drift{
  0%, 100%{ transform: translate(0,0) rotate(-8deg); }
  50%{ transform: translate(20px, -16px) rotate(8deg); }
}

/* ---- Stream lines (aliran air halus) ---- */
.stream{
  position: absolute;
  pointer-events: none;
  opacity: 0.5;
  z-index: 0;
}
.stream path{
  stroke-dasharray: 200;
  stroke-dashoffset: 0;
  animation: stream-flow 6s linear infinite;
}
@keyframes stream-flow{
  to{ stroke-dashoffset: -400; }
}

/* ---- Container utility: section perlu position relative untuk dekorasi ---- */
.manifesto, .process, .product, .team, .partner, .poster{
  position: relative;
}

/* lebih dramatis: scale up bokeh slightly */
.bokeh.lg{ width: 480px; height: 480px; }
.bokeh.md{ width: 320px; height: 320px; }
.bokeh.sm{ width: 200px; height: 200px; }

/* SVG ripple inside team grid emphasises water connection */

/* =========================================================
   NATURE BACKDROP (AQUVIVA-style fade-to-white)
   Gambar nature/air/pegunungan ditampilkan SAMAR & FADE ke putih
   di semua tepi. Memberi suasana, bukan jadi pusat perhatian.
   ========================================================= */
.nature-bg{
  position: absolute;
  inset: 0;
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
  pointer-events: none;
  z-index: 0;
  /* Fade ke transparan di SEMUA tepi (radial) supaya menyatu dengan latar */
  -webkit-mask-image: radial-gradient(ellipse 70% 80% at center, black 0%, rgba(0,0,0,0.4) 55%, transparent 88%);
  mask-image: radial-gradient(ellipse 70% 80% at center, black 0%, rgba(0,0,0,0.4) 55%, transparent 88%);
  opacity: 0.32;
  /* Wash ke putih: brightness boost + desaturate + low contrast */
  filter: brightness(1.35) saturate(0.55) contrast(0.82);
  mix-blend-mode: multiply;
}
/* Saat .nature-bg berupa <video> (bukan div bg-image) */
video.nature-bg{
  width: 100%; height: 100%;
  object-fit: cover;
  object-position: center;
}
/* Variant: fade arah bawah saja (untuk hero bottom) */
.nature-bg.fade-down{
  -webkit-mask-image: linear-gradient(to bottom, black 0%, rgba(0,0,0,0.6) 50%, transparent 95%);
  mask-image: linear-gradient(to bottom, black 0%, rgba(0,0,0,0.6) 50%, transparent 95%);
}
.nature-bg.fade-up{
  -webkit-mask-image: linear-gradient(to top, black 0%, rgba(0,0,0,0.6) 50%, transparent 95%);
  mask-image: linear-gradient(to top, black 0%, rgba(0,0,0,0.6) 50%, transparent 95%);
}
.nature-bg.fade-side{
  -webkit-mask-image: linear-gradient(90deg, transparent 0%, black 25%, black 75%, transparent 100%);
  mask-image: linear-gradient(90deg, transparent 0%, black 25%, black 75%, transparent 100%);
}
/* Variant: lebih kuat (untuk section sumber yang memang ingin gambar terlihat) */
.nature-bg.strong{
  opacity: 0.55;
  filter: brightness(1.2) saturate(0.7) contrast(0.88);
  mix-blend-mode: normal;
  -webkit-mask-image: radial-gradient(ellipse 75% 85% at center, black 0%, rgba(0,0,0,0.5) 60%, transparent 92%);
  mask-image: radial-gradient(ellipse 75% 85% at center, black 0%, rgba(0,0,0,0.5) 60%, transparent 92%);
}
.nature-bg.subtle{
  opacity: 0.18;
}
/* Video subtle (hero underwater / manifesto cascade) sedikit lebih terlihat */
video.nature-bg.subtle{
  opacity: 0.35;
}
/* Gentle slow ken-burns zoom on nature backdrops */
.nature-bg.zoom{
  animation: nature-zoom 40s ease-in-out infinite alternate;
  transform-origin: center;
}
@keyframes nature-zoom{
  0%{   transform: scale(1.0);   }
  100%{ transform: scale(1.08);  }
}

/* =========================================================
   RESPONSIVE
   ========================================================= */
@media (max-width: 1100px){
  .nav-menu{ display: none; }
  .hero-inner{ grid-template-columns: 1fr; gap: 40px; padding-top: 130px; padding-bottom: 60px; }
  .hero-stage{ height: 460px; min-height: auto; }
  .manifesto-grid{ grid-template-columns: 1fr; gap: 40px; }
  .process-head{ grid-template-columns: 1fr; gap: 30px; }
  .pillar{ grid-template-columns: 60px 1fr; gap: 20px; }
  .pillar-img{ grid-column: span 2; margin-top: 20px; }
  .pillar:hover{ padding-inline: 0; }
  .product-grid{ grid-template-columns: 1fr; gap: 60px; }
  .product-img-wrap{ max-width: 100%; }
  .cert-head{ grid-template-columns: 1fr; gap: 30px; }
  .cert-grid{ grid-template-columns: 1fr; }
  .team-grid{
    grid-template-columns: 1fr 1fr;
    grid-template-rows: 280px 280px 280px;
  }
  .tg-item.tall{ grid-row: span 1; }
  .team-blocks{ grid-template-columns: 1fr; }
  .partner-inner{ grid-template-columns: 1fr; gap: 40px; }
  .footer-top{ grid-template-columns: 1fr 1fr; gap: 40px; }
  .values{ grid-template-columns: 1fr 1fr; }
  .hero-badges{ display: none; }
  .hero-meta{ display: none; }
}
@media (max-width: 640px){
  .values{ grid-template-columns: 1fr; }
  .team-grid{ grid-template-columns: 1fr; grid-template-rows: repeat(5, 260px); }
  .product-specs{ grid-template-columns: 1fr; }
  .footer-top{ grid-template-columns: 1fr; }
  .footer-bottom{ flex-direction: column; align-items: flex-start; }
  .poster-stats{ flex-direction: column; gap: 20px; }
}

/* =========================================================
   MOBILE NAV · hamburger toggle
   ========================================================= */
.nav-actions{ display: inline-flex; align-items: center; gap: 14px; }
.nav-toggle{
  display: none;
  width: 42px; height: 42px;
  border: 1px solid currentColor;
  border-radius: 999px;
  background: transparent;
  color: inherit;
  flex-shrink: 0;
  flex-direction: column;
  align-items: center; justify-content: center;
  gap: 5px;
}
.nav-toggle span{
  display: block;
  width: 18px; height: 1.5px;
  background: currentColor;
  transition: transform 0.35s var(--ease-cinema), opacity 0.25s;
}
.nav.open .nav-toggle span:nth-child(1){ transform: translateY(6.5px) rotate(45deg); }
.nav.open .nav-toggle span:nth-child(2){ opacity: 0; }
.nav.open .nav-toggle span:nth-child(3){ transform: translateY(-6.5px) rotate(-45deg); }

@media (max-width: 1100px){
  .nav-toggle{ display: inline-flex; }
  .nav.open{
    background: rgba(255, 253, 248, 0.96);
    backdrop-filter: blur(18px) saturate(140%);
    -webkit-backdrop-filter: blur(18px) saturate(140%);
    border-bottom: 1px solid var(--line);
  }
  /* Higher specificity than the `.nav-menu{display:none}` rule above,
     so the panel shows only when the nav is toggled open. */
  .nav.open .nav-menu{
    display: flex;
    position: fixed;
    left: 0; right: 0;
    top: var(--nav-h, 64px);
    flex-direction: column;
    align-items: flex-start;
    gap: 2px;
    padding: 22px var(--pad-x) 30px;
    background: rgba(255, 253, 248, 0.98);
    backdrop-filter: blur(18px) saturate(140%);
    -webkit-backdrop-filter: blur(18px) saturate(140%);
    border-bottom: 1px solid var(--line);
    box-shadow: 0 30px 50px -20px rgba(0, 0, 0, 0.18);
  }
  .nav.open .nav-menu a{
    font-family: var(--serif);
    font-size: 22px;
    padding: 12px 0;
    opacity: 1;
  }
  .nav.open .nav-menu a::after{ display: none; }
}

/* =========================================================
   REDUCED MOTION · hormati preferensi aksesibilitas
   Animasi & transisi dipangkas; reveal tetap muncul (snap, bukan fade).
   ========================================================= */
@media (prefers-reduced-motion: reduce){
  *, *::before, *::after{
    animation-duration: 0.001ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.001ms !important;
    scroll-behavior: auto !important;
  }
  html{ scroll-behavior: auto; }
}

/* =====================================================================
   FASE 1 + 2 — DARK FOREST CINEMATIC OVERRIDES
   Append-only, last-wins via source order.
   Overrides earlier .nav / .hero / .btn rules.
   ===================================================================== */

/* ---------- Global: hide native video controls ---------- */
video::-webkit-media-controls,
video::-webkit-media-controls-enclosure { display: none !important; }
video { pointer-events: none; }

/* ============ GLASS NAV + HAMBURGER + MOBILE MENU ============ */
.nav {
  position: fixed; top: 24px; left: 50%;
  transform: translateX(-50%);
  z-index: 100;
  display: flex; align-items: center; gap: 8px;
  padding: 8px 8px 8px 24px;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.06);
  backdrop-filter: blur(24px) saturate(160%);
  -webkit-backdrop-filter: blur(24px) saturate(160%);
  border: 1px solid rgba(255, 255, 255, 0.14);
  box-shadow: 0 12px 40px -12px rgba(0, 0, 0, 0.5);
  transition: background 0.5s var(--ease-soft), border-color 0.5s, top 0.4s;
  width: auto; max-width: none; height: auto; /* override earlier nav width rules */
}
.nav.scrolled {
  background: rgba(20, 35, 28, 0.55);
  border-color: rgba(255, 255, 255, 0.18);
}
.nav-brand {
  display: flex; align-items: center; gap: 10px;
  font-family: var(--serif); font-size: 18px; letter-spacing: 0.02em;
  color: var(--paper);
  text-decoration: none;
}
.nav-brand em { font-style: italic; color: var(--mint); }
.nav-brand .dot {
  width: 8px; height: 8px; border-radius: 50%;
  background: var(--green-bright);
  box-shadow: 0 0 12px var(--green-bright);
  animation: pulse 2.4s ease-in-out infinite;
}
@keyframes pulse {
  0%, 100% { opacity: 0.8; transform: scale(1); }
  50% { opacity: 1; transform: scale(1.2); }
}
.nav-links {
  display: flex; gap: 4px; margin-left: 24px;
  list-style: none; padding: 0; margin-bottom: 0; margin-top: 0;
}
.nav-links a {
  font-size: 13px; padding: 8px 16px; border-radius: 99px;
  color: rgba(255,255,255,0.78);
  transition: color 0.3s, background 0.3s;
  text-decoration: none;
}
.nav-links a:hover { color: var(--paper); background: rgba(255,255,255,0.08); }
.nav-cta {
  margin-left: 14px;
  padding: 10px 20px;
  background: var(--mint);
  color: var(--ink);
  border-radius: 99px;
  font-size: 13px; font-weight: 500;
  transition: transform 0.3s var(--ease-cine), background 0.3s;
  display: inline-flex; align-items: center; gap: 8px;
  text-decoration: none;
}
.nav-cta:hover { transform: translateY(-1px); background: var(--paper); }

.nav-toggle {
  display: none;
  width: 40px; height: 40px;
  border-radius: 99px;
  background: rgba(255,255,255,0.06);
  border: 1px solid rgba(255,255,255,0.18);
  align-items: center; justify-content: center;
  margin-left: 8px;
  cursor: pointer;
}
.nav-toggle span {
  width: 18px; height: 1.5px;
  background: var(--paper);
  border-radius: 2px;
  position: relative;
  transition: transform 0.4s var(--ease-cine), opacity 0.3s, background 0.3s;
}
.nav-toggle span::before,
.nav-toggle span::after {
  content: "";
  position: absolute;
  left: 0; width: 18px; height: 1.5px;
  background: var(--paper);
  border-radius: 2px;
  transition: transform 0.4s var(--ease-cine), top 0.3s, opacity 0.3s;
}
.nav-toggle span::before { top: -6px; }
.nav-toggle span::after { top: 6px; }
body.menu-open .nav-toggle span { background: transparent; }
body.menu-open .nav-toggle span::before { top: 0; transform: rotate(45deg); }
body.menu-open .nav-toggle span::after { top: 0; transform: rotate(-45deg); }

.mobile-menu {
  position: fixed; inset: 0;
  z-index: 95;
  background: rgba(8, 18, 14, 0.94);
  backdrop-filter: blur(28px) saturate(160%);
  -webkit-backdrop-filter: blur(28px) saturate(160%);
  display: flex; flex-direction: column;
  justify-content: center; align-items: center;
  gap: 28px;
  opacity: 0; visibility: hidden;
  transition: opacity 0.5s var(--ease-cine), visibility 0.5s;
}
body.menu-open .mobile-menu { opacity: 1; visibility: visible; }
.mobile-menu a {
  font-family: var(--serif);
  font-style: italic;
  font-size: clamp(32px, 8vw, 56px);
  font-weight: 300;
  color: var(--paper);
  letter-spacing: -0.02em;
  opacity: 0.8;
  transform: translateY(20px);
  transition: transform 0.6s var(--ease-cine), color 0.3s, opacity 0.3s;
  text-decoration: none;
}
body.menu-open .mobile-menu a { transform: translateY(0); }
body.menu-open .mobile-menu a:nth-child(1) { transition-delay: 0.1s; }
body.menu-open .mobile-menu a:nth-child(2) { transition-delay: 0.18s; }
body.menu-open .mobile-menu a:nth-child(3) { transition-delay: 0.26s; }
body.menu-open .mobile-menu a:nth-child(4) { transition-delay: 0.34s; }
body.menu-open .mobile-menu a:nth-child(5) { transition-delay: 0.42s; }
.mobile-menu a:hover { color: var(--mint); opacity: 1; }
.mobile-menu-footer {
  position: absolute; bottom: 36px;
  font-family: var(--mono);
  font-size: 10px; letter-spacing: 0.24em;
  text-transform: uppercase;
  color: rgba(255,255,255,0.45);
}
body.menu-open { overflow: hidden; }

@media (max-width: 880px) {
  .nav-links { display: none; }
  .nav-toggle { display: flex; }
  .nav { padding: 8px 8px 8px 20px; }
  .nav-brand { font-size: 16px; }
  .nav-cta { padding: 8px 14px; font-size: 12px; margin-left: 6px; }
}

/* ============ MAGNETIC CUSTOM CURSOR ============ */
@media (pointer: fine) {
  body,
  a, button, input, select, textarea, label,
  .panel, .value-card, .cert-card { cursor: none; }
}
.cursor-dot {
  position: fixed; top: 0; left: 0;
  width: 8px; height: 8px;
  border-radius: 50%;
  background: var(--mint);
  pointer-events: none;
  z-index: 10001;
  transition:
    width 0.35s var(--ease-cine),
    height 0.35s var(--ease-cine),
    background 0.35s, border-color 0.35s, backdrop-filter 0.35s;
  mix-blend-mode: difference;
  will-change: transform;
  border: 1px solid transparent;
  display: none;
}
.cursor-ring {
  position: fixed; top: 0; left: 0;
  width: 38px; height: 38px;
  border: 1px solid rgba(180, 230, 200, 0.45);
  border-radius: 50%;
  pointer-events: none;
  z-index: 10000;
  transition:
    width 0.45s var(--ease-cine),
    height 0.45s var(--ease-cine),
    opacity 0.35s, border-color 0.35s;
  will-change: transform;
  display: none;
}
@media (pointer: fine) {
  .cursor-dot, .cursor-ring { display: block; }
}
.cursor-dot.hover {
  width: 68px; height: 68px;
  background: rgba(180, 230, 200, 0.12);
  -webkit-backdrop-filter: blur(8px) saturate(140%);
  backdrop-filter: blur(8px) saturate(140%);
  border-color: rgba(180, 230, 200, 0.6);
  mix-blend-mode: normal;
}
.cursor-ring.hover { opacity: 0; }
.cursor-dot.text { width: 4px; height: 4px; background: var(--mint); }
.cursor-ring.text {
  width: 64px; height: 64px;
  border-color: rgba(180, 230, 200, 0.25);
}
@media (max-width: 900px), (pointer: coarse) {
  .cursor-dot, .cursor-ring { display: none !important; }
}

/* ============ HERO 3D SCENE (dark forest) ============ */
.hero {
  position: relative;
  min-height: 100vh;
  overflow: hidden;
  isolation: isolate;
  display: grid;
  place-items: center;
  color: var(--paper);
  background: var(--forest);
  /* override old hero padding/center rules */
  padding: 0;
}
.hero-video {
  position: absolute; inset: 0;
  width: 100%; height: 100%;
  object-fit: cover;
  z-index: -2;
  transform: scale(1.05);
  will-change: transform;
}
.hero::before {
  content: ""; position: absolute; inset: 0;
  background:
    radial-gradient(70% 80% at 50% 30%, transparent 0%, rgba(15,28,22,0.55) 65%, rgba(10,20,16,0.92) 100%),
    linear-gradient(180deg, rgba(0,0,0,0.3) 0%, rgba(0,0,0,0) 30%, rgba(0,0,0,0.55) 100%);
  z-index: -1;
}
.hero-inner {
  position: relative;
  z-index: 2;
  width: 100%;
  max-width: 1480px;
  padding: 140px clamp(20px, 5vw, 80px) 100px;
  display: grid;
  grid-template-columns: 1.1fr 0.9fr;
  gap: 60px;
  align-items: center;
}
.eyebrow {
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: 0.28em;
  text-transform: uppercase;
  color: var(--mint);
  display: inline-flex; align-items: center; gap: 14px;
  margin-bottom: 36px;
}
.eyebrow::before { content: ""; width: 32px; height: 1px; background: currentColor; }
.hero-headline {
  font-family: var(--serif);
  font-size: clamp(56px, 8.4vw, 156px);
  line-height: 0.94;
  letter-spacing: -0.02em;
  font-weight: 300;
  margin-bottom: 36px;
  color: var(--paper);
}
.hero-headline .it { font-style: italic; color: var(--mint); }
.hero-headline .word { display: inline-block; overflow: hidden; vertical-align: top; }
.hero-headline .word-inner {
  display: inline-block;
  transform: translateY(110%);
  animation: wordRise 1.1s var(--ease-cine) forwards;
}
.hero-headline .word:nth-child(1) .word-inner { animation-delay: 0.5s; }
.hero-headline .word:nth-child(2) .word-inner { animation-delay: 0.65s; }
.hero-headline .word:nth-child(3) .word-inner { animation-delay: 0.8s; }
.hero-headline .word:nth-child(4) .word-inner { animation-delay: 0.95s; }
.hero-headline .word:nth-child(5) .word-inner { animation-delay: 1.1s; }
@keyframes wordRise { to { transform: translateY(0); } }

.hero-sub {
  font-size: 17px; max-width: 460px; line-height: 1.7;
  color: rgba(255,255,255,0.82);
  margin-bottom: 44px;
  opacity: 0;
  animation: fadeIn 1s var(--ease-cine) 1.5s forwards;
}
@keyframes fadeIn { to { opacity: 1; } }

.hero-actions {
  display: flex; gap: 14px; align-items: center;
  opacity: 0;
  animation: fadeIn 1s var(--ease-cine) 1.7s forwards;
}
.btn {
  display: inline-flex; align-items: center; gap: 12px;
  padding: 18px 28px;
  border-radius: 99px;
  font-size: 14px; font-weight: 500; letter-spacing: 0.01em;
  transition: all 0.4s var(--ease-cine);
  cursor: pointer; text-decoration: none;
  border: none;
}
.btn-primary { background: var(--mint); color: var(--ink); }
.btn-primary:hover {
  background: var(--paper);
  transform: translateY(-2px);
  box-shadow: 0 20px 40px -16px rgba(120,180,140, 0.55);
}
.btn-glass {
  background: rgba(255,255,255,0.06);
  backdrop-filter: blur(12px) saturate(140%);
  -webkit-backdrop-filter: blur(12px) saturate(140%);
  border: 1px solid rgba(255,255,255,0.18);
  color: var(--paper);
}
.btn-glass:hover {
  background: rgba(255,255,255,0.12);
  border-color: rgba(255,255,255,0.3);
}
.btn .arrow { transition: transform 0.4s var(--ease-cine); }
.btn:hover .arrow { transform: translateX(4px); }

.hero-stage {
  position: relative;
  height: 70vh;
  display: grid;
  place-items: center;
  perspective: 1400px;
  transform-style: preserve-3d;
}
.hero-glow {
  position: absolute;
  inset: 0;
  pointer-events: none;
  background: radial-gradient(40% 45% at 50% 50%, rgba(150,220,180,0.45), transparent 70%);
  filter: blur(48px);
  z-index: -1;
  animation: glowPulse 6s ease-in-out infinite;
}
@keyframes glowPulse {
  0%, 100% { opacity: 0.75; transform: scale(1); }
  50% { opacity: 1; transform: scale(1.12); }
}
.hero-bottle-wrap {
  position: relative;
  height: 100%;
  display: grid; place-items: center;
  transform-style: preserve-3d;
  transition: transform 0.6s var(--ease-cine);
  will-change: transform;
}
.hero-bottle {
  position: relative;
  height: 100%;
  max-height: 700px;
  /* Asset baru (3 botol + splash air biru) sudah punya grounding & highlight
     natural di dalam image. Drop-shadow dijaga lembut supaya tidak bentrok
     dengan refleksi splash di bagian bawah. */
  filter:
    drop-shadow(0 30px 40px rgba(0, 0, 0, 0.35))
    drop-shadow(0 0 80px rgba(180, 230, 200, 0.22));
  animation: bottleFloat 6s ease-in-out infinite;
  will-change: transform;
  /* override earlier .hero-bottle wrapper styles */
  width: auto;
  /* Aspect-lock: width+height auto + object-fit contain = TIDAK PERNAH
     stretch/lonjong walau ke-clamp dua sisi. max-width jaga tak overflow. */
  max-width: 100%;
  object-fit: contain;
}
@keyframes bottleFloat {
  0%, 100% { transform: translateY(0) rotate(-0.6deg); }
  50% { transform: translateY(-18px) rotate(0.6deg); }
}
/* Ellipse-shadow lama dihapus: image baru sudah berisi water-splash di bawah
   sebagai grounding alami; menambah blob gelap blur di belakang justru bikin
   splash terlihat kotor. */
.hero-mist {
  position: absolute; inset: 0;
  pointer-events: none;
  z-index: 2;
  overflow: hidden;
}
.mist-particle {
  position: absolute;
  display: block;
  width: var(--size, 10px);
  height: var(--size, 10px);
  border-radius: 50%;
  background: radial-gradient(circle, rgba(220, 245, 235, 0.85) 0%, rgba(180, 220, 200, 0.3) 60%, transparent 100%);
  filter: blur(2px);
  animation: mistDrift var(--dur, 14s) ease-in-out infinite;
  animation-delay: var(--delay, 0s);
  opacity: 0;
  will-change: transform, opacity;
}
@keyframes mistDrift {
  0% { transform: translate(0, 80px) scale(0.4); opacity: 0; }
  15% { opacity: 0.85; }
  85% { opacity: 0.6; }
  100% { transform: translate(var(--dx, 30px), -140px) scale(1.1); opacity: 0; }
}

.hero-meta {
  position: absolute;
  left: clamp(20px, 5vw, 80px);
  bottom: 40px;
  display: flex; gap: 40px;
  font-family: var(--mono);
  font-size: 10px; letter-spacing: 0.22em;
  text-transform: uppercase;
  color: rgba(255,255,255,0.55);
  z-index: 2;
  opacity: 0;
  animation: fadeIn 1s var(--ease-cine) 2s forwards;
}
.hero-meta b {
  display: block;
  color: var(--mint);
  font-family: var(--serif); font-style: italic;
  font-size: 14px; letter-spacing: 0;
  text-transform: none;
  font-weight: 400; margin-bottom: 4px;
}
.hero-scroll-cue {
  position: absolute;
  right: clamp(20px, 5vw, 80px);
  bottom: 40px;
  display: flex; align-items: center; gap: 12px;
  font-family: var(--mono); font-size: 10px;
  letter-spacing: 0.28em; text-transform: uppercase;
  color: rgba(255,255,255,0.6);
  z-index: 2;
}
.hero-scroll-cue .line {
  width: 1px; height: 36px;
  background: linear-gradient(to bottom, transparent, var(--mint), transparent);
  background-size: 100% 200%;
  animation: scrollLine 2s linear infinite;
}
@keyframes scrollLine {
  0% { background-position: 0 -100%; }
  100% { background-position: 0 200%; }
}

@media (max-width: 900px) {
  .hero-inner { grid-template-columns: 1fr; padding-top: 120px; }
  .hero-stage { height: auto; min-height: 42vh; }
  /* Mobile: ukur botol pakai LEBAR (bukan tinggi) supaya proporsi natural &
     tidak terlihat lonjong. width+height auto → aspect terkunci; max-width &
     max-height membatasi tanpa distorsi. */
  .hero-bottle {
    position: relative;
    height: auto;
    width: auto;
    max-width: 86%;
    max-height: 52vh;
    object-fit: contain;
  }
  .hero-meta, .hero-scroll-cue { display: none; }
  .hero-headline { font-size: clamp(44px, 11vw, 68px); }
  .hero-sub { font-size: 15px; margin-bottom: 32px; }
}

/* =====================================================================
   FASE 3 + 4 + 5 — Values glass / Sumber scroll-zoom / Stack horizontal
   / Liquid bottle reveal. Append-only, source order overrides earlier
   .manifesto/.values/.sumber/.process/.pillar rules.
   ===================================================================== */

/* ============ GLASSMORPHISM VALUES SECTION ============ */
.values-section {
  position: relative;
  min-height: 100vh;
  overflow: hidden;
  isolation: isolate;
  padding: 140px clamp(20px, 5vw, 80px);
  display: grid;
  place-items: center;
  background: var(--forest);
}
.values-bg {
  position: absolute; inset: 0;
  width: 100%; height: 100%;
  object-fit: cover;
  object-position: center top; /* prioritize top crop, hide bottle outline at bottom */
  z-index: -2;
  transform: scale(1.05);
  filter: brightness(0.6) saturate(1.1);
  /* mask fade-to-dark di bottom 45% supaya outline gelas tersembunyi */
  -webkit-mask-image: linear-gradient(to bottom, black 0%, black 55%, rgba(0,0,0,0.3) 80%, transparent 100%);
          mask-image: linear-gradient(to bottom, black 0%, black 55%, rgba(0,0,0,0.3) 80%, transparent 100%);
}
.values-section::before {
  content: ""; position: absolute; inset: 0;
  background:
    radial-gradient(80% 70% at 50% 50%, transparent 0%, rgba(10,18,14,0.7) 100%),
    linear-gradient(to bottom, transparent 0%, transparent 50%, rgba(8,14,10,0.85) 100%);
  z-index: -1;
}
.values-inner {
  max-width: 1480px; width: 100%;
  display: grid;
  grid-template-columns: 0.85fr 1.15fr;
  gap: 80px;
  align-items: center;
}
.values-intro h2 {
  font-family: var(--serif);
  font-size: clamp(40px, 5.5vw, 88px);
  line-height: 0.98;
  letter-spacing: -0.02em;
  font-weight: 300;
  margin-bottom: 28px;
  color: var(--paper);
}
.values-intro h2 .it { font-style: italic; color: var(--mint); }
.values-intro p {
  font-size: 18px; line-height: 1.7;
  color: rgba(255,255,255,0.78);
  max-width: 460px;
}
.values-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 16px;
}
.value-card {
  position: relative;
  padding: 36px 28px;
  border-radius: 20px;
  background: rgba(255,255,255,0.06);
  backdrop-filter: blur(24px) saturate(160%);
  -webkit-backdrop-filter: blur(24px) saturate(160%);
  border: 1px solid rgba(255,255,255,0.14);
  box-shadow: 0 16px 48px -16px rgba(0,0,0,0.4), inset 0 1px 0 rgba(255,255,255,0.12);
  transition: transform 0.5s var(--ease-cine), background 0.5s, border-color 0.5s;
}
.value-card:hover {
  transform: translateY(-6px);
  background: rgba(255,255,255,0.10);
  border-color: rgba(150,220,180,0.35);
}
.value-card .num {
  font-family: var(--mono);
  font-size: 11px; letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--mint);
  margin-bottom: 20px;
}
.value-card .name {
  font-family: var(--serif);
  font-style: italic;
  font-size: 40px; line-height: 1;
  color: var(--paper);
  margin-bottom: 14px;
}
.value-card .desc {
  font-size: 14px; line-height: 1.6;
  color: rgba(255,255,255,0.72);
}
@media (max-width: 900px) {
  .values-inner { grid-template-columns: 1fr; gap: 50px; }
  .values-grid { grid-template-columns: 1fr; }
}

/* ============ SCROLL-ZOOM DRAMATIC SUMBER ============ */
.zoom-sumber {
  position: relative;
  height: 160vh; /* trimmed from 320vh — less wheel fatigue */
  background: var(--forest);
}
.zoom-stage {
  position: sticky;
  top: 0;
  height: 100vh;
  overflow: hidden;
  isolation: isolate;
}
.zoom-video {
  position: absolute; inset: 0;
  width: 100%; height: 100%;
  object-fit: cover;
  z-index: -2;
  transform-origin: center 55%;
  will-change: transform;
  transform: scale(1);
}
.zoom-stage::before {
  content: ""; position: absolute; inset: 0;
  background:
    radial-gradient(75% 100% at 50% 50%, transparent 25%, rgba(8,16,12,0.45) 70%, rgba(8,16,12,0.92) 100%),
    linear-gradient(180deg, rgba(15,28,22,0.55) 0%, transparent 25%, rgba(8,14,10,0.7) 100%);
  z-index: -1;
}
.zoom-content {
  position: relative;
  z-index: 2;
  height: 100%;
  display: grid;
  place-items: center;
  text-align: center;
  padding: 0 clamp(20px, 5vw, 80px);
}
.zoom-headline {
  font-family: var(--serif);
  font-size: clamp(54px, 9vw, 180px);
  line-height: 0.94;
  letter-spacing: -0.025em;
  font-weight: 300;
  color: var(--paper);
  position: relative;
  width: 100%; max-width: 1200px;
  text-shadow: 0 4px 40px rgba(0,0,0,0.5);
}
.zoom-line {
  position: absolute; inset: 0;
  display: grid; place-items: center;
  opacity: 0;
  transform: translateY(60px) scale(0.94);
  transition: opacity 0.9s var(--ease-cine), transform 0.9s var(--ease-cine);
  pointer-events: none;
}
.zoom-line.active { opacity: 1; transform: translateY(0) scale(1); }
.zoom-line.passed { opacity: 0; transform: translateY(-50px) scale(1.04); }
.zoom-line .it { font-style: italic; color: var(--mint); }
.zoom-eyebrow {
  position: absolute;
  top: 80px; left: 50%;
  transform: translateX(-50%);
  font-family: var(--mono);
  font-size: 11px; letter-spacing: 0.32em;
  text-transform: uppercase;
  color: var(--mint);
  display: inline-flex; align-items: center; gap: 14px;
  z-index: 3;
  opacity: 0.85;
}
.zoom-eyebrow::before, .zoom-eyebrow::after {
  content: ""; width: 32px; height: 1px;
  background: currentColor;
  opacity: 0.6;
}
.zoom-caption {
  position: absolute;
  bottom: 60px; left: 50%;
  transform: translateX(-50%);
  font-family: var(--mono);
  font-size: 11px; letter-spacing: 0.28em;
  text-transform: uppercase;
  color: rgba(255,255,255,0.65);
  display: inline-flex; align-items: center; gap: 14px;
  z-index: 3;
}
.zoom-caption::before, .zoom-caption::after {
  content: ""; width: 28px; height: 1px;
  background: currentColor;
  opacity: 0.5;
}
.zoom-progress {
  position: absolute;
  top: 50%; right: clamp(20px, 4vw, 60px);
  transform: translateY(-50%);
  z-index: 3;
  display: flex; flex-direction: column; gap: 10px;
}
.zoom-progress-dot {
  width: 2px; height: 28px;
  background: rgba(255,255,255,0.18);
  transition: background 0.5s, height 0.5s;
  display: block;
}
.zoom-progress-dot.active {
  background: var(--mint);
  height: 56px;
}
.zoom-vignette {
  position: absolute; inset: 0;
  background: radial-gradient(50% 50% at 50% 50%, transparent 30%, rgba(0,0,0,0.45) 80%, rgba(0,0,0,0.85) 100%);
  pointer-events: none;
  z-index: 1;
  opacity: 0;
  transition: opacity 0.8s var(--ease-cine);
}
.zoom-stage[data-depth="3"] .zoom-vignette { opacity: 1; }
@media (max-width: 900px) {
  .zoom-sumber { height: 150vh; } /* trimmed from 280vh */
  .zoom-headline { font-size: clamp(40px, 12vw, 80px); }
}

/* ============ HORIZONTAL SCROLL PILLARS "Empat Tahap" ============ */
.stack {
  position: relative;
  height: 280vh; /* trimmed from 500vh — 4 panels still pace well */
  background: var(--forest);
}
.stack-stage {
  position: sticky;
  top: 0;
  height: 100vh;
  overflow: hidden;
  isolation: isolate;
}
.stack-track {
  display: flex;
  flex-wrap: nowrap;
  width: 400%;
  height: 100%;
  will-change: transform;
  transform: translateX(0);
}
.panel {
  flex: 0 0 25%;
  height: 100%;
  position: relative;
  display: grid;
  grid-template-columns: 1.05fr 0.95fr; /* sedikit lebih untuk teks */
  gap: clamp(72px, 7vw, 120px);          /* lebar dari 60px ke 72–120px */
  padding: 140px clamp(28px, 5.5vw, 96px) 100px;
  align-items: center;
  overflow: hidden;
}
.panel-bg {
  position: absolute; inset: 0;
  z-index: -2;
}
.panel-bg img, .panel-bg video {
  width: 100%; height: 100%;
  object-fit: cover;
  filter: brightness(0.55) saturate(1.05) blur(2px);
  transform: scale(1.08);
}
.panel-bg::after {
  content: ""; position: absolute; inset: 0;
  background:
    linear-gradient(135deg, rgba(8,18,14,0.85) 0%, rgba(8,18,14,0.5) 50%, rgba(8,18,14,0.92) 100%),
    radial-gradient(60% 80% at 40% 50%, transparent 0%, rgba(8,18,14,0.55) 100%);
  z-index: 1;
}
.panel-num-big {
  position: absolute;
  right: -3%; bottom: -22%;
  font-family: var(--serif);
  font-style: italic;
  font-size: 56vw;
  line-height: 0.85;
  color: rgba(255,255,255,0.045);
  pointer-events: none;
  user-select: none;
  z-index: -1;
  letter-spacing: -0.02em;
}
.panel-text {
  position: relative;
  z-index: 2;
  max-width: 540px;       /* dari 480 — kasih breathing room */
  padding-right: 16px;    /* jarak ekstra ke gap */
}
.panel-num {
  font-family: var(--mono);
  font-size: 11px; letter-spacing: 0.24em;
  color: var(--mint);
  margin-bottom: 28px;
  display: inline-flex; align-items: center; gap: 14px;
}
.panel-num::before {
  content: ""; width: 32px; height: 1px;
  background: var(--mint);
}
.panel-title {
  font-family: var(--serif);
  font-size: clamp(44px, 6.5vw, 110px);
  line-height: 0.94;
  letter-spacing: -0.025em;
  font-weight: 300;
  margin-bottom: 32px;
  color: var(--paper);
}
.panel-title .it { font-style: italic; color: var(--mint); }
.panel-body {
  font-size: 17px; line-height: 1.7;
  color: rgba(255,255,255,0.82);
  margin-bottom: 36px;
}
.panel-meta {
  display: inline-flex; align-items: center; gap: 12px;
  font-family: var(--mono);
  font-size: 11px; letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--paper);
  padding: 12px 22px;
  border: 1px solid rgba(255,255,255,0.2);
  border-radius: 99px;
  background: rgba(255,255,255,0.04);
  backdrop-filter: blur(14px) saturate(140%);
  -webkit-backdrop-filter: blur(14px) saturate(140%);
}
.panel-meta::before {
  content: ""; width: 6px; height: 6px; border-radius: 50%;
  background: var(--green-bright);
  box-shadow: 0 0 10px var(--green-bright);
}
.panel-visual {
  position: relative;
  z-index: 2;
  aspect-ratio: 4/5;
  max-height: 62vh;       /* dari 70vh — visual tidak terlalu dominan */
  max-width: 100%;
  justify-self: end;      /* anchor ke kanan kolom, jauhi teks */
  border-radius: 24px;
  overflow: hidden;
  background: rgba(255,255,255,0.04);
  border: 1px solid rgba(255,255,255,0.16);
  backdrop-filter: blur(20px) saturate(160%);
  -webkit-backdrop-filter: blur(20px) saturate(160%);
  box-shadow: 0 32px 80px -20px rgba(0,0,0,0.6);
}
.panel-visual img, .panel-visual video {
  width: 100%; height: 100%;
  object-fit: cover;
}
.stack-overlay {
  position: absolute;
  top: 0; left: 0; right: 0;
  z-index: 5;
  padding: 90px clamp(20px, 5vw, 80px) 30px;
  display: flex; justify-content: space-between; align-items: baseline;
  pointer-events: none;
  gap: 24px;
  flex-wrap: wrap;
}
.stack-overlay h2 {
  font-family: var(--serif);
  font-size: clamp(28px, 3.4vw, 52px);
  line-height: 1;
  letter-spacing: -0.02em;
  font-weight: 300;
  color: var(--paper);
}
.stack-overlay h2 .it { font-style: italic; color: var(--mint); }
.stack-overlay .counter {
  font-family: var(--mono);
  font-size: 12px; letter-spacing: 0.24em;
  color: rgba(255,255,255,0.6);
}
.stack-overlay .counter b {
  color: var(--mint);
  font-family: var(--serif);
  font-style: italic;
  font-weight: 400;
  font-size: 32px;
  letter-spacing: 0;
  margin-right: 8px;
}
.stack-rail {
  position: absolute;
  bottom: 36px; left: clamp(20px, 5vw, 80px); right: clamp(20px, 5vw, 80px);
  height: 2px;
  background: rgba(255,255,255,0.12);
  z-index: 5;
  pointer-events: none;
}
.stack-rail-fill {
  height: 100%;
  background: linear-gradient(90deg, var(--green), var(--mint));
  width: 25%;
  transition: width 0.5s var(--ease-cine);
}
.stack-hint {
  position: absolute;
  bottom: 50px; right: clamp(20px, 5vw, 80px);
  font-family: var(--mono);
  font-size: 10px; letter-spacing: 0.28em;
  text-transform: uppercase;
  color: rgba(255,255,255,0.45);
  z-index: 6;
  pointer-events: none;
}
.stack-hint::before {
  content: "↓ ";
  color: var(--mint);
  margin-right: 6px;
}
@media (max-width: 900px) {
  .stack { height: auto; }
  .stack-stage { position: relative; height: auto; overflow: visible; }
  .stack-track {
    flex-direction: column; width: 100%;
    transform: none !important; height: auto;
  }
  .panel {
    flex: 0 0 auto;
    grid-template-columns: 1fr;
    gap: 24px;
    padding: 90px clamp(20px, 5vw, 80px) 70px;
    min-height: 90vh;
  }
  .panel-num-big { font-size: 110vw; bottom: -8%; right: -10%; }
  .panel-visual { max-height: 50vh; aspect-ratio: 4/3; }
  .stack-overlay {
    position: relative; padding: 60px clamp(20px, 5vw, 80px) 0;
    background: var(--forest);
  }
  .stack-overlay h2 { font-size: clamp(28px, 7vw, 44px); }
  .stack-rail, .stack-hint { display: none; }
}

/* ============ LIQUID BOTTLE REVEAL ============ */
.reveal-bottle {
  position: relative;
  height: 140vh; /* trimmed from 240vh */
  background:
    radial-gradient(circle at 25% 35%, rgba(120,180,220,0.10) 0%, transparent 55%),
    radial-gradient(circle at 75% 65%, rgba(180,230,200,0.08) 0%, transparent 55%),
    var(--forest);
}
.reveal-stage {
  position: sticky;
  top: 0;
  height: 100vh;
  overflow: hidden;
  isolation: isolate;
}
.reveal-bg-video {
  position: absolute; inset: 0;
  width: 100%; height: 100%;
  object-fit: cover;
  z-index: -2;
  opacity: 0.35;
  filter: brightness(0.65) saturate(0.9);
}
.reveal-bg-overlay {
  position: absolute; inset: 0;
  z-index: -1;
  background: radial-gradient(60% 80% at 50% 50%, transparent 30%, rgba(8,14,10,0.6) 100%);
}
.reveal-text {
  position: absolute;
  top: 14%; left: 50%;
  transform: translateX(-50%);
  z-index: 6;
  text-align: center;
  font-family: var(--serif);
  font-size: clamp(34px, 4.5vw, 76px);
  line-height: 1.1;
  font-weight: 300;
  letter-spacing: -0.02em;
  color: var(--paper);
  width: 92%; max-width: 920px;
  text-shadow: 0 4px 30px rgba(0,0,0,0.4);
}
.reveal-text .line {
  display: block;
  opacity: 0;
  transform: translateY(36px);
  transition: opacity 0.85s var(--ease-cine), transform 0.85s var(--ease-cine);
  margin-bottom: 6px;
}
.reveal-text .line.in { opacity: 1; transform: translateY(0); }
.reveal-text .it { font-style: italic; color: var(--mint); }
.reveal-droplets {
  position: absolute; inset: 0;
  pointer-events: none;
  z-index: 2;
}
.droplet {
  position: absolute;
  width: var(--size, 22px);
  height: var(--size, 22px);
  border-radius: 50%;
  background: radial-gradient(circle at 30% 30%, rgba(220,245,235,0.95) 0%, rgba(160,210,200,0.55) 50%, rgba(110,170,200,0.22) 100%);
  box-shadow:
    inset -2px -3px 6px rgba(40,90,80,0.32),
    inset 2px 2px 4px rgba(255,255,255,0.45),
    0 6px 24px rgba(120,180,200,0.3);
  left: var(--from-x);
  top: var(--from-y);
  transform: translate(-50%, -50%) scale(1);
  will-change: left, top, transform, opacity;
  transition:
    left 1.6s cubic-bezier(0.6, 0, 0.4, 1),
    top 1.6s cubic-bezier(0.6, 0, 0.4, 1),
    transform 0.6s var(--ease-cine),
    opacity 0.6s var(--ease-cine);
  animation: dropletBob 4s ease-in-out infinite;
  animation-delay: var(--bob-delay, 0s);
}
@keyframes dropletBob {
  0%, 100% { transform: translate(-50%, calc(-50% + 0px)) scale(1); }
  50%      { transform: translate(-50%, calc(-50% - 6px)) scale(1); }
}
.reveal-stage.converged .droplet {
  left: 50% !important; top: 50% !important;
  opacity: 0.4;
  transform: translate(-50%, -50%) scale(0.5) !important;
  animation: none;
}
.reveal-stage.merged .droplet {
  opacity: 0;
  transform: translate(-50%, -50%) scale(0) !important;
}
.reveal-orb {
  position: absolute;
  left: 50%; top: 50%;
  transform: translate(-50%, -50%) scale(0);
  width: 100px; height: 100px;
  border-radius: 50%;
  background: radial-gradient(circle at 30% 30%, rgba(240,255,250,1) 0%, rgba(170,220,210,0.85) 45%, rgba(120,180,200,0.4) 100%);
  box-shadow:
    inset -8px -10px 18px rgba(40,90,80,0.4),
    inset 6px 8px 12px rgba(255,255,255,0.6),
    0 0 80px rgba(150,220,180,0.55),
    0 30px 80px rgba(80,140,170,0.5);
  z-index: 3;
  opacity: 0;
  transition:
    transform 1.1s var(--ease-cine),
    opacity 0.7s var(--ease-cine),
    width 1.2s cubic-bezier(0.7, 0, 0.3, 1),
    height 1.2s cubic-bezier(0.7, 0, 0.3, 1),
    border-radius 1.4s cubic-bezier(0.7, 0, 0.3, 1);
}
.reveal-stage.merged .reveal-orb {
  opacity: 1;
  transform: translate(-50%, -50%) scale(1);
}
.reveal-stage.morphing .reveal-orb {
  opacity: 1;
  width: 170px;
  height: 480px;
  border-radius: 28% 28% 38% 38% / 18% 18% 5% 5%;
  transform: translate(-50%, -50%) scale(1);
  background: linear-gradient(180deg, rgba(220,245,235,0.85) 0%, rgba(160,210,200,0.6) 100%);
}
.reveal-stage.bottle .reveal-orb { opacity: 0; transform: translate(-50%, -50%) scale(0.7); }
.reveal-bottle-img {
  position: absolute;
  left: 50%; top: 50%;
  transform: translate(-50%, -50%) scale(0.85);
  height: 78vh; max-height: 720px;
  width: auto;
  z-index: 4;
  opacity: 0;
  filter:
    drop-shadow(0 60px 60px rgba(0,0,0,0.55))
    drop-shadow(0 0 100px rgba(180,230,200,0.4));
  transition:
    opacity 1.1s var(--ease-cine),
    transform 1.4s var(--ease-cine);
}
.reveal-stage.bottle .reveal-bottle-img {
  opacity: 1;
  transform: translate(-50%, -50%) scale(1);
}
.reveal-splash {
  position: absolute;
  left: 50%; top: 50%;
  transform: translate(-50%, -50%) scale(0);
  width: 600px; height: 600px;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(180,230,200,0.45) 0%, transparent 70%);
  z-index: 1;
  opacity: 0;
  transition: transform 1.2s var(--ease-cine), opacity 1s;
  pointer-events: none;
}
.reveal-stage.merged .reveal-splash {
  opacity: 1;
  transform: translate(-50%, -50%) scale(2);
}
.reveal-stage.bottle .reveal-splash { opacity: 0.4; }
@media (max-width: 900px) {
  .reveal-bottle { height: 120vh; } /* trimmed from 200vh */
  .reveal-bottle-img { height: 60vh; }
  .reveal-orb { width: 70px; height: 70px; }
  .reveal-stage.morphing .reveal-orb { width: 120px; height: 340px; }
  .reveal-text { font-size: clamp(28px, 6vw, 52px); top: 12%; }
}

/* =====================================================================
   FIX PASS — Tim & Kemitraan dark forest override
   Sections below still used cream/light bg from the earlier design; body
   now defaults to dark forest + paper text, so existing rules clashed.
   Surgical !important overrides only; structural layout untouched.
   ===================================================================== */
.team {
  background: var(--forest) !important;
  color: var(--paper);
}
.team h2,
.team-head h2 {
  color: var(--paper) !important;
}
.team h2 .it,
.team-head h2 .it,
.team-head h2 em {
  color: var(--mint) !important;
}
.team .eyebrow {
  color: var(--mint) !important;
}
.team p,
.team-block p {
  color: rgba(255,255,255,0.78) !important;
}
.team-block h3 {
  color: var(--paper) !important;
}
.team-block .label {
  color: var(--mint) !important;
}

.partner {
  background: var(--forest) !important;
  color: var(--paper);
}
.partner h2 {
  color: var(--paper) !important;
}
.partner h2 .it,
.partner h2 em {
  color: var(--mint) !important;
}
.partner .eyebrow {
  color: var(--mint) !important;
}
.partner-right p {
  color: rgba(255,255,255,0.78) !important;
}
.partner-field {
  border-bottom-color: rgba(255,255,255,0.18) !important;
}
.partner-field label {
  color: rgba(255,255,255,0.55) !important;
}
.partner-field input,
.partner-field select {
  color: var(--paper) !important;
  background: transparent !important;
}
.partner-field input::placeholder {
  color: rgba(255,255,255,0.4) !important;
}
.partner-field select option {
  /* dropdown native pakai ink di paper supaya readable di OS native menu */
  color: var(--ink);
  background: var(--paper);
}
.partner-field:focus-within {
  border-bottom-color: var(--mint) !important;
}
.partner-submit {
  background: var(--mint) !important;
  color: var(--ink) !important;
}
.partner-submit:hover {
  background: var(--paper) !important;
}
.partner .float-leaf,
.partner svg[class*="leaf"] {
  opacity: 0.3 !important;
  filter: brightness(1.2);
}
