/* ============================================================
   NBH Summer Camp Bali 2026 — shared design system
   Frozen after Wave 0. Page-specific CSS goes in the page's
   own <style> block, NOT here.
   ============================================================ */

:root {
  /* ── palette — off the 2022 camp deck ── */
  --sand:        oklch(0.943 0.024 92);
  --sand-2:      oklch(0.915 0.030 90);
  --sand-3:      oklch(0.965 0.014 92);
  --ink:         oklch(0.318 0.030 248);
  --ink-2:       oklch(0.372 0.034 246);
  --ink-line:    oklch(0.318 0.030 248 / 0.16);
  --ink-faint:   oklch(0.318 0.030 248 / 0.62);
  --cream-on-ink:      oklch(0.943 0.024 92);
  --cream-on-ink-soft: oklch(0.943 0.024 92 / 0.74);
  --cream-line:        oklch(0.943 0.024 92 / 0.18);
  --ochre:       oklch(0.745 0.124 76);
  --ochre-deep:  oklch(0.675 0.118 70);
  --terracotta:  oklch(0.700 0.140 52);

  --tracking-label: 0.16em;
  --tracking-tight: -0.018em;
  --tracking-tighter: -0.03em;

  /* 4pt spacing scale, semantic */
  --space-3xs: 4px;  --space-2xs: 8px;  --space-xs: 12px; --space-sm: 16px;
  --space-md: 24px;  --space-lg: 32px;  --space-xl: 48px; --space-2xl: 64px;
  --space-3xl: 96px; --space-4xl: 128px; --space-5xl: 160px;

  --r-sm: 10px; --r-md: 16px; --r-lg: 22px; --r-xl: 30px;

  --shell: 1240px;
  --nav-h: 64px;

  /* easing — overwritten by CustomEase in site.js if available */
  --ease-out: cubic-bezier(.16,1,.3,1);
}

* { box-sizing: border-box; margin: 0; padding: 0; }

html { scroll-behavior: smooth; }
@media (prefers-reduced-motion: reduce) { html { scroll-behavior: auto; } }

body {
  font-family: "Hanken Grotesk", -apple-system, BlinkMacSystemFont, system-ui, sans-serif;
  background: var(--sand);
  color: var(--ink);
  font-weight: 450;
  line-height: 1.62;
  font-size: clamp(0.975rem, 0.93rem + 0.2vw, 1.0625rem);
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  overflow-x: hidden;
}
::selection { background: var(--ink); color: var(--sand); }

img { max-width: 100%; height: auto; }
a { color: inherit; }
button { font: inherit; color: inherit; cursor: pointer; }

.skip-link {
  position: absolute; left: -9999px; top: 0; z-index: 2000;
  background: var(--ink); color: var(--sand); padding: 10px 16px; border-radius: 0 0 var(--r-sm) 0;
  font-size: 0.8rem; font-weight: 700;
}
.skip-link:focus { left: 0; }

:focus-visible { outline: 2px solid var(--ochre); outline-offset: 2px; border-radius: 2px; }

/* ── layout ── */
.shell { max-width: var(--shell); margin: 0 auto; padding-inline: clamp(20px, 5vw, 56px); }
section { position: relative; }
.pad-block { padding-block: clamp(56px, 7.5vw, 96px); }
.pad-block.tight { padding-block: clamp(36px, 5vw, 64px); }
.pad-block.roomy { padding-block: clamp(72px, 10vw, 128px); }
/* a section that sits directly above a wave divider needs less of its own bottom padding —
   the wave does the visual separating. Same the other way around. Keeps transitions from
   doubling into a dead band. */
section:has(+ .wave) { padding-bottom: clamp(28px, 4vw, 56px); }
.wave + section { padding-top: clamp(28px, 4vw, 56px); }
.bg-sand2 { background: var(--sand-2); }
.bg-ink { background: var(--ink); color: var(--cream-on-ink); }
.stacklg > * + * { margin-top: clamp(28px, 4vw, 44px); }
.stackmd > * + * { margin-top: var(--space-md); }
.stacksm > * + * { margin-top: var(--space-sm); }
.flow-row { display: flex; gap: var(--space-md); flex-wrap: wrap; align-items: center; }

/* ── typography ── */
h1, h2, h3 { font-family: "Zilla Slab", Georgia, serif; font-weight: 700; line-height: 1.02; letter-spacing: var(--tracking-tighter); }
.display {
  font-family: "Zilla Slab", Georgia, serif; font-weight: 700;
  font-size: clamp(3.1rem, 1.6rem + 8vw, 7.4rem);
  line-height: 0.96; letter-spacing: var(--tracking-tighter); text-transform: uppercase;
}
.display .it { font-style: italic; font-weight: 700; text-transform: none; }
.display .ochre, .h-xl .ochre, .h-lg .ochre { color: var(--ochre); }
.h-xl { font-family: "Zilla Slab", serif; font-weight: 700; font-size: clamp(2.4rem, 1.5rem + 4.4vw, 4.6rem); line-height: 0.98; letter-spacing: var(--tracking-tighter); text-transform: uppercase; }
.h-lg { font-family: "Zilla Slab", serif; font-weight: 700; font-size: clamp(2rem, 1.4rem + 2.8vw, 3.2rem); line-height: 1.0; letter-spacing: var(--tracking-tight); }
.h-md { font-family: "Zilla Slab", serif; font-weight: 700; font-size: clamp(1.45rem, 1.2rem + 1.2vw, 2rem); line-height: 1.08; letter-spacing: var(--tracking-tight); }
.h-sm { font-family: "Zilla Slab", serif; font-weight: 700; font-size: clamp(1.18rem, 1.05rem + 0.5vw, 1.45rem); line-height: 1.12; letter-spacing: var(--tracking-tight); }

.eyebrow {
  font-family: "Hanken Grotesk", sans-serif; font-size: 0.7rem; font-weight: 800;
  letter-spacing: var(--tracking-label); text-transform: uppercase;
  display: inline-flex; align-items: center; gap: var(--space-2xs);
}
.eyebrow::before { content: ""; width: 22px; height: 2px; background: var(--ochre); display: inline-block; flex: none; }
.eyebrow.on-ink { color: var(--cream-on-ink-soft); }
.eyebrow.no-rule::before { display: none; }
.eyebrow.block { display: flex; }

.lede { font-size: clamp(1.05rem, 0.98rem + 0.5vw, 1.28rem); line-height: 1.5; max-width: 62ch; color: var(--ink-faint); }
.lede.on-ink { color: var(--cream-on-ink-soft); }
.measure { max-width: 64ch; }
.measure-sm { max-width: 50ch; }

.section-head { display: flex; flex-direction: column; gap: var(--space-sm); margin-bottom: clamp(36px, 5vw, 64px); }
.section-head .eyebrow { margin-bottom: var(--space-3xs); }
.section-head .row-end { display: flex; justify-content: space-between; align-items: flex-end; flex-wrap: wrap; gap: var(--space-md); }

/* ── buttons ── */
.btn {
  display: inline-flex; align-items: center; gap: 8px; text-decoration: none;
  font-family: "Hanken Grotesk", sans-serif; font-weight: 800; font-size: 0.78rem;
  letter-spacing: 0.06em; text-transform: uppercase;
  padding: 11px 18px; border-radius: 999px; border: 1px solid transparent;
  transition: transform .25s var(--ease-out), background-color .2s, color .2s, border-color .2s;
  white-space: nowrap;
}
.btn:hover { transform: translateY(-1px); }
.btn-primary { background: var(--ink); color: var(--sand); }
.btn-primary:hover { background: var(--ink-2); }
.btn-ochre { background: var(--ochre); color: var(--ink); }
.btn-ochre:hover { background: var(--ochre-deep); }
.btn-ghost { background: transparent; border-color: currentColor; }
.btn-ghost:hover { background: var(--ink); color: var(--sand); border-color: var(--ink); }
.btn-text { padding: 4px 0; border-radius: 0; background: none; }
.btn-text::after { content: "→"; transition: transform .25s var(--ease-out); }
.btn-text:hover::after { transform: translateX(4px); }
.btn.lg { padding: 14px 24px; font-size: 0.84rem; }

/* ── site nav ── */
.site-nav {
  position: fixed; top: 0; left: 0; right: 0; z-index: 100; height: var(--nav-h);
  display: flex; align-items: center;
  background: transparent; color: var(--cream-on-ink);
  transition: background-color .35s ease, color .35s ease, box-shadow .35s ease, backdrop-filter .35s ease;
}
.site-nav.on-cream { color: var(--ink); }
.site-nav.scrolled { background: var(--ink); color: var(--cream-on-ink); box-shadow: 0 1px 0 var(--cream-line); }
.site-nav .nav-inner { width: 100%; max-width: var(--shell); margin: 0 auto; padding-inline: clamp(20px, 5vw, 56px); display: flex; align-items: center; gap: var(--space-md); }
.site-nav .brand { display: inline-flex; align-items: center; gap: 10px; text-decoration: none; font-family: "Zilla Slab", serif; font-weight: 700; font-size: 1rem; letter-spacing: var(--tracking-tight); white-space: nowrap; }
.site-nav .brand img { width: 24px; height: 24px; display: block; transition: filter .35s; }
.site-nav.scrolled .brand img, .site-nav:not(.on-cream) .brand img { filter: brightness(0) invert(1) opacity(0.92); }
.site-nav .nav-links { display: flex; gap: clamp(14px, 1.8vw, 26px); margin-left: auto; align-items: center; }
.site-nav .nav-links a { text-decoration: none; font-weight: 700; font-size: 0.82rem; opacity: 0.78; transition: opacity .2s; padding: 6px 0; position: relative; }
.site-nav .nav-links a:hover { opacity: 1; }
.site-nav .nav-links a[aria-current="page"] { opacity: 1; }
.site-nav .nav-links a[aria-current="page"]::after { content: ""; position: absolute; left: 0; right: 0; bottom: -2px; height: 2px; background: var(--ochre); }
.site-nav .nav-cta { display: flex; align-items: center; gap: var(--space-sm); }
.countdown-chip { font-family: "Hanken Grotesk", sans-serif; font-weight: 800; font-size: 0.7rem; letter-spacing: 0.08em; text-transform: uppercase; padding: 7px 12px; border-radius: 999px; border: 1px solid currentColor; font-variant-numeric: tabular-nums; white-space: nowrap; }
.nav-burger { display: none; margin-left: auto; width: 40px; height: 40px; border: none; background: none; position: relative; }
.nav-burger span { position: absolute; left: 8px; right: 8px; height: 2px; background: currentColor; transition: transform .3s var(--ease-out), opacity .2s; }
.nav-burger span:nth-child(1) { top: 14px; } .nav-burger span:nth-child(2) { top: 19px; } .nav-burger span:nth-child(3) { top: 24px; }
body.menu-open .nav-burger span:nth-child(1) { transform: translateY(5px) rotate(45deg); }
body.menu-open .nav-burger span:nth-child(2) { opacity: 0; }
body.menu-open .nav-burger span:nth-child(3) { transform: translateY(-5px) rotate(-45deg); }
.nav-overlay { position: fixed; inset: 0; z-index: 99; background: var(--ink); color: var(--cream-on-ink); display: flex; flex-direction: column; justify-content: center; padding: clamp(24px,8vw,80px); gap: var(--space-md); transform: translateY(-100%); transition: transform .4s var(--ease-out); }
body.menu-open .nav-overlay { transform: none; }
.nav-overlay a { text-decoration: none; font-family: "Zilla Slab", serif; font-weight: 700; font-size: clamp(1.6rem, 1rem + 4vw, 2.6rem); letter-spacing: var(--tracking-tight); text-transform: uppercase; opacity: .85; }
.nav-overlay a[aria-current="page"] { opacity: 1; color: var(--ochre); }
.nav-overlay .nav-cta { margin-top: var(--space-lg); }
@media (max-width: 920px) {
  .site-nav .nav-links { display: none; }
  .site-nav .nav-cta .countdown-chip { display: none; }
  .nav-burger { display: block; }
  .site-nav.scrolled .nav-burger, body.menu-open .nav-burger { color: var(--cream-on-ink); }
}
@media (min-width: 921px) { .nav-overlay, .nav-burger { display: none !important; } }
body { padding-top: var(--nav-h); }
/* Every hero is navy. The body's top strip (the nav-height of space the fixed nav floats over)
   would otherwise be cream — cream-on-cream nav text at rest. Paint that strip navy so the nav
   reads at scroll 0; once scrolled, the opaque nav covers it. */
body::before { content: ""; position: fixed; inset: 0 0 auto 0; height: var(--nav-h); background: var(--ink); z-index: 1; pointer-events: none; }

/* ── site footer ── */
.site-footer { background: var(--ink); color: var(--cream-on-ink-soft); }
.site-footer .foot-inner { display: grid; gap: var(--space-lg); padding-block: clamp(32px, 5vw, 56px); }
.site-footer .foot-top { display: flex; justify-content: space-between; align-items: flex-start; flex-wrap: wrap; gap: var(--space-lg); }
.site-footer .brand { display: inline-flex; align-items: center; gap: 12px; color: var(--cream-on-ink); font-family: "Zilla Slab", serif; font-weight: 700; }
.site-footer .brand img { width: 26px; height: 26px; filter: brightness(0) invert(1); }
.site-footer .foot-links { display: flex; flex-wrap: wrap; gap: var(--space-md); }
.site-footer .foot-links a { text-decoration: none; font-size: 0.72rem; font-weight: 800; letter-spacing: var(--tracking-label); text-transform: uppercase; opacity: .8; }
.site-footer .foot-links a:hover { opacity: 1; }
.site-footer .foot-note { font-size: 0.78rem; opacity: .7; max-width: 50ch; }
.site-footer .foot-bottom { display: flex; justify-content: space-between; flex-wrap: wrap; gap: var(--space-md); font-size: 0.66rem; font-weight: 700; letter-spacing: var(--tracking-label); text-transform: uppercase; opacity: .55; padding-top: var(--space-md); border-top: 1px solid var(--cream-line); }

/* ── linocut palms (decoration) ── */
.palm { position: absolute; pointer-events: none; user-select: none; bottom: 0; opacity: 0.92; z-index: 0; }
.palm-l { left: clamp(-130px, -6vw, -40px); width: clamp(150px, 22vw, 320px); transform: scaleX(-1); }
.palm-r { right: clamp(-130px, -6vw, -40px); width: clamp(150px, 22vw, 320px); }
.palm-tuck-r { right: clamp(-50px, -3vw, -10px); width: clamp(150px, 16vw, 250px); }
.palm-watermark { opacity: 0.07; }
@media (max-width: 720px) { .palm-l, .palm-r { width: 110px; opacity: 0.65; } .palm-tuck-r { display: none; } }

/* ── wavy beach divider ──
   Model: a horizontal band between two sections. The <div> background is the colour of the
   section ABOVE; the <path> fill is the colour of the section BELOW. The default path is
   "filled at the bottom" so the wavy edge reads as a beach crest. Compose the classes:
     (default)            navy above → cream below
     .from-sand           cream above
     .from-sand2          cream-2 above
     .to-ink              navy below
     .to-sand2            cream-2 below
   e.g. cream above, navy below = `class="wave from-sand to-ink"`. */
.wave { display: block; width: 100%; height: clamp(40px, 5vw, 64px); line-height: 0; position: relative; z-index: 1; background: var(--ink); }
.wave svg { display: block; width: 100%; height: 100%; }
.wave svg path { fill: var(--sand); }
.wave.from-sand  { background: var(--sand); }
.wave.from-sand2 { background: var(--sand-2); }
.wave.to-sand2 svg path { fill: var(--sand-2); }
.wave.to-ink   svg path { fill: var(--ink); }

/* ── pills / chips ── */
.pill {
  display: inline-flex; align-items: center; gap: 7px; font-size: 0.64rem; font-weight: 800;
  letter-spacing: 0.13em; text-transform: uppercase; padding: 7px 13px; border-radius: 999px;
  border: 1px solid currentColor; width: fit-content;
}
.pill.solid-ink { background: var(--ink); color: var(--sand); border-color: var(--ink); }
.pill.solid-ochre { background: var(--ochre); color: var(--ink); border-color: var(--ochre); }
.tag { font-size: 0.6rem; font-weight: 800; letter-spacing: 0.1em; text-transform: uppercase; padding: 5px 10px; border-radius: 999px; background: oklch(0.318 0.030 248 / 0.08); white-space: nowrap; }
.tag.ochre { background: var(--ochre); color: var(--ink); }
.tag.ink { background: var(--ink); color: var(--sand); }
.chips { display: flex; flex-wrap: wrap; gap: 8px; }
.chips .chip { font-size: 0.82rem; font-weight: 600; padding: 7px 13px; border-radius: 999px; }
.chips.on-paper .chip { background: var(--sand-2); }
.chips.on-ink .chip { background: oklch(0.943 0.024 92 / 0.13); color: var(--cream-on-ink); }
.chips.on-ochre .chip { background: oklch(0.318 0.030 248 / 0.12); }

/* ── tiles & panels ── */
.tile-grid-3 { display: grid; grid-template-columns: repeat(3, 1fr); gap: var(--space-sm); }
@media (max-width: 860px) { .tile-grid-3 { grid-template-columns: 1fr; } }
.tile { border-radius: var(--r-lg); padding: clamp(24px, 3vw, 36px); display: flex; flex-direction: column; gap: var(--space-sm); justify-content: space-between; min-height: clamp(220px, 26vw, 280px); }
.tile.ink { background: var(--ink); color: var(--cream-on-ink); }
.tile.ink-2 { background: var(--ink-2); color: var(--cream-on-ink); }
.tile.ochre { background: var(--ochre); color: var(--ink); }
.tile.paper { background: var(--sand-3); border: 1px solid var(--ink-line); }
.tile .tile-no { font-size: 0.66rem; font-weight: 800; letter-spacing: 0.13em; text-transform: uppercase; opacity: 0.72; }
.tile.ink .tile-no, .tile.ink-2 .tile-no { color: var(--ochre); opacity: 1; }
.tile .tile-t { font-family: "Zilla Slab", serif; font-weight: 700; font-size: clamp(1.35rem, 1.1rem + 1vw, 1.85rem); line-height: 1.05; letter-spacing: var(--tracking-tight); }
.tile .tile-b { font-size: 0.96em; line-height: 1.5; opacity: 0.92; }
.tile.ink .tile-b, .tile.ink-2 .tile-b { color: var(--cream-on-ink-soft); }

.panel { border-radius: var(--r-lg); padding: clamp(26px, 3vw, 38px); }
.panel.ink { background: var(--ink); color: var(--cream-on-ink); }
.panel.ink-2 { background: var(--ink-2); color: var(--cream-on-ink); }
.panel.ochre { background: var(--ochre); color: var(--ink); }
.panel.paper { background: var(--sand-3); border: 1px solid var(--ink-line); }
.panel > .eyebrow { margin-bottom: var(--space-md); }
.panel.ink > .eyebrow, .panel.ink-2 > .eyebrow { color: var(--cream-on-ink-soft); }
.panel h3 { margin-bottom: var(--space-sm); }
.panel.ink h3, .panel.ink-2 h3 { color: var(--cream-on-ink); }
.panel .panel-cap { margin-top: var(--space-md); font-size: 0.92em; color: var(--ink-faint); }
.panel.ink .panel-cap, .panel.ink-2 .panel-cap { color: var(--cream-on-ink-soft); }
.duo-grid { display: grid; grid-template-columns: 1.15fr 1fr; gap: var(--space-sm); align-items: start; }
@media (max-width: 860px) { .duo-grid { grid-template-columns: 1fr; } }

.pull { font-family: "Zilla Slab", serif; font-weight: 700; font-size: clamp(1.7rem, 1.2rem + 3vw, 3.4rem); line-height: 1.1; letter-spacing: var(--tracking-tight); text-transform: uppercase; max-width: 18ch; }
.pull .hl { background: var(--ochre); color: var(--ink); padding: 0.04em 0.22em 0.06em; border-radius: 4px; box-decoration-break: clone; -webkit-box-decoration-break: clone; }
.pull.on-ink { color: var(--cream-on-ink); }

/* ── numbered list (deck "Camp Rules" style) ── */
.numlist { list-style: none; counter-reset: nl; display: grid; grid-template-columns: 1fr 1fr; gap: clamp(22px, 3vw, 40px) clamp(40px, 5vw, 72px); }
.numlist.one-col { grid-template-columns: 1fr; max-width: 70ch; }
.numlist > li { counter-increment: nl; display: grid; grid-template-columns: 3.4rem 1fr; gap: var(--space-md); align-items: start; }
.numlist > li::before { content: counter(nl, decimal-leading-zero); font-family: "Zilla Slab", serif; font-weight: 700; font-size: 1.55rem; line-height: 1; color: var(--ochre); font-variant-numeric: tabular-nums; padding-top: 1px; }
.numlist .t { font-weight: 750; display: block; margin-bottom: 3px; }
.numlist .d { color: var(--ink-faint); font-size: 0.96em; line-height: 1.5; }
.numlist.on-ink .d { color: var(--cream-on-ink-soft); }
@media (max-width: 720px) { .numlist { grid-template-columns: 1fr; } .numlist > li { grid-template-columns: 2.6rem 1fr; gap: var(--space-sm);} .numlist > li::before { font-size: 1.25rem; } }

/* ── stats ── */
.statrow { display: grid; grid-template-columns: repeat(4, 1fr); gap: var(--space-sm); }
@media (max-width: 720px) { .statrow { grid-template-columns: repeat(2, 1fr); } }
.stat { background: var(--sand-3); border: 1px solid var(--ink-line); border-radius: var(--r-md); padding: clamp(20px, 2.5vw, 30px); }
.stat.ochre { background: var(--ochre); border-color: var(--ochre); }
.stat.ink { background: var(--ink); border-color: var(--ink); color: var(--cream-on-ink); }
.stat .sv { font-family: "Zilla Slab", serif; font-weight: 700; font-size: clamp(2.2rem, 1.6rem + 2vw, 3.1rem); line-height: 0.95; letter-spacing: -0.03em; font-variant-numeric: tabular-nums; }
.stat .sl { margin-top: 8px; font-size: 0.64rem; font-weight: 800; letter-spacing: 0.13em; text-transform: uppercase; color: var(--ink-faint); }
.stat.ochre .sl { color: oklch(0.318 0.030 248 / 0.7); }
.stat.ink .sl { color: var(--cream-on-ink-soft); }

/* ── checklist / distlist ── */
.checklist { list-style: none; display: grid; grid-template-columns: 1fr 1fr; gap: 9px 26px; }
@media (max-width: 540px) { .checklist { grid-template-columns: 1fr; } }
.checklist li { position: relative; padding-left: 18px; font-size: 0.96em; line-height: 1.45; }
.checklist li::before { content: ""; position: absolute; left: 0; top: 0.62em; width: 9px; height: 2px; background: var(--ochre); }
.distlist { list-style: none; }
.distlist li { display: flex; justify-content: space-between; align-items: baseline; gap: var(--space-sm); padding: 11px 0; border-bottom: 1px solid var(--ink-line); }
.distlist li:last-child { border-bottom: none; }
.distlist .place { font-weight: 600; }
.distlist .min { font-variant-numeric: tabular-nums; font-weight: 700; font-size: 0.86rem; color: var(--ink-faint); flex: none; }

/* ── accordion (agenda + FAQ) ── */
details.acc { background: var(--sand-3); border: 1px solid var(--ink-line); border-radius: var(--r-lg); overflow: hidden; transition: background .25s ease, border-color .25s ease; }
details.acc + details.acc { margin-top: var(--space-xs); }
details.acc[open] { background: var(--sand-2); border-color: var(--sand-2); }
details.acc summary { list-style: none; cursor: pointer; padding: clamp(18px, 2.5vw, 26px) clamp(20px, 3vw, 32px); display: grid; align-items: center; gap: clamp(14px, 2.5vw, 28px); }
details.acc summary::-webkit-details-marker { display: none; }
details.acc summary:hover { background: oklch(0.318 0.030 248 / 0.04); }
details.acc.day summary { grid-template-columns: 4.5rem 1fr auto auto; }
details.acc.faq summary { grid-template-columns: 1fr auto; }
.acc-title { font-family: "Zilla Slab", serif; font-weight: 700; font-size: clamp(1.05rem, 1rem + 0.6vw, 1.45rem); letter-spacing: var(--tracking-tight); }
.acc-meta { font-size: 0.64rem; font-weight: 800; letter-spacing: 0.13em; text-transform: uppercase; color: var(--ink-faint); }
.chev { width: 12px; height: 12px; border-right: 2.5px solid var(--ink); border-bottom: 2.5px solid var(--ink); transform: rotate(45deg); transition: transform .25s ease; flex: none; }
details.acc[open] .chev { transform: rotate(-135deg); }
.acc-reveal { display: grid; grid-template-rows: 0fr; transition: grid-template-rows .3s ease; }
details.acc[open] .acc-reveal { grid-template-rows: 1fr; }
.acc-reveal > .inner { overflow: hidden; }
.acc-body { padding: 0 clamp(20px, 3vw, 32px) clamp(22px, 3vw, 32px); }
@media (prefers-reduced-motion: reduce) { .acc-reveal, details.acc, .chev { transition: none; } }

/* ── callout bar ── */
.callout-bar { background: var(--ink-2); color: var(--cream-on-ink); border-radius: var(--r-md); padding: clamp(18px, 2.5vw, 26px) clamp(22px, 3vw, 32px); display: flex; align-items: center; gap: var(--space-md); flex-wrap: wrap; font-size: 0.95em; }
.callout-bar strong { color: var(--ochre); font-weight: 800; }
.callout-bar.sand { background: var(--sand-3); color: var(--ink); border: 1px solid var(--ink-line); }
.callout-bar.sand strong { color: var(--ochre-deep); }

/* ── verified stamp ── */
.verify-stamp { display: inline-flex; align-items: center; gap: 8px; font-size: 0.66rem; font-weight: 800; letter-spacing: 0.1em; text-transform: uppercase; padding: 7px 14px; border: 1.5px dashed var(--ochre-deep); border-radius: var(--r-sm); color: var(--ochre-deep); width: fit-content; }

/* ── quick-link cards (Home) — 6 cards: 3×2 on desktop, 2×3 on tablet, stacked on mobile ── */
.quick-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: var(--space-sm); }
@media (max-width: 880px) { .quick-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 540px) { .quick-grid { grid-template-columns: 1fr; } }
.quick-card { display: flex; flex-direction: column; justify-content: space-between; gap: var(--space-lg); padding: clamp(26px, 3vw, 36px); border-radius: var(--r-lg); text-decoration: none; min-height: 220px; position: relative; overflow: hidden; transition: transform .3s var(--ease-out); }
.quick-card:hover { transform: translateY(-3px); }
.quick-card.ink { background: var(--ink); color: var(--cream-on-ink); }
.quick-card.ink-2 { background: var(--ink-2); color: var(--cream-on-ink); }
.quick-card.ochre { background: var(--ochre); color: var(--ink); }
.quick-card.paper { background: var(--sand-3); border: 1px solid var(--ink-line); }
.quick-card .qc-no { font-size: 0.66rem; font-weight: 800; letter-spacing: 0.13em; text-transform: uppercase; opacity: 0.7; }
.quick-card .qc-t { font-family: "Zilla Slab", serif; font-weight: 700; font-size: clamp(1.4rem, 1.2rem + 1vw, 2rem); line-height: 1.05; letter-spacing: var(--tracking-tight); }
.quick-card .qc-go { font-size: 0.78rem; font-weight: 800; text-transform: uppercase; letter-spacing: 0.06em; display: inline-flex; align-items: center; gap: 8px; }
.quick-card .qc-go::after { content: "→"; transition: transform .25s var(--ease-out); }
.quick-card:hover .qc-go::after { transform: translateX(5px); }

/* ── countdown (Home big version) ── */
.countdown { display: flex; gap: clamp(12px, 3vw, 32px); flex-wrap: wrap; justify-content: center; font-variant-numeric: tabular-nums; }
.countdown .cu { text-align: center; }
.countdown .cu-v { font-family: "Zilla Slab", serif; font-weight: 700; font-size: clamp(2.6rem, 1.5rem + 5vw, 6rem); line-height: 1; letter-spacing: -0.02em; }
.countdown .cu-l { margin-top: 6px; font-size: 0.62rem; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; opacity: 0.7; }
.countdown.on-ink .cu-v { color: var(--cream-on-ink); }
.countdown .cu.go .cu-v { color: var(--ochre); }

/* milestone bar */
.milestones { position: relative; display: grid; gap: var(--space-md); }
.milestone-track { position: relative; height: 4px; border-radius: 4px; background: var(--ink-line); overflow: hidden; }
.milestones.on-ink .milestone-track { background: var(--cream-line); }
.milestone-fill { position: absolute; left: 0; top: 0; bottom: 0; background: var(--ochre); border-radius: 4px; width: 0; }
.milestone-pts { display: flex; justify-content: space-between; flex-wrap: wrap; gap: var(--space-sm); }
.milestone-pt { font-size: 0.7rem; font-weight: 700; max-width: 22ch; opacity: 0.55; transition: opacity .3s; position: relative; padding-top: 14px; flex: 1; min-width: 120px; }
.milestone-pt::before { content: ""; position: absolute; top: 0; left: 0; width: 9px; height: 9px; border-radius: 50%; background: var(--ink-line); transition: background .3s; }
.milestones.on-ink .milestone-pt { color: var(--cream-on-ink-soft); }
.milestones.on-ink .milestone-pt::before { background: var(--cream-line); }
.milestone-pt.passed { opacity: 1; }
.milestone-pt.passed::before { background: var(--ochre); }

/* ── gallery + lightbox (villa + crew) ── */
.gallery { display: grid; grid-template-columns: repeat(auto-fill, minmax(220px, 1fr)); gap: var(--space-xs); }
.gallery .g-item { position: relative; overflow: hidden; border-radius: var(--r-md); cursor: pointer; aspect-ratio: 4/3; background: var(--sand-2); }
.gallery .g-item.tall { aspect-ratio: 3/4; grid-row: span 2; }
.gallery .g-item.wide { grid-column: span 2; aspect-ratio: 16/9; }
.gallery .g-item img { width: 100%; height: 100%; object-fit: cover; display: block; transition: transform .5s var(--ease-out); }
.gallery .g-item:hover img { transform: scale(1.04); }
.gallery .g-ph { width: 100%; height: 100%; display: flex; align-items: center; justify-content: center; text-align: center; font-size: 0.7rem; font-weight: 800; letter-spacing: 0.1em; text-transform: uppercase; color: var(--ink-faint); background: repeating-linear-gradient(45deg, var(--sand-2), var(--sand-2) 14px, var(--sand-3) 14px, var(--sand-3) 28px); padding: 16px; }
.lightbox { position: fixed; inset: 0; z-index: 1000; background: oklch(0.22 0.02 248 / 0.96); display: none; align-items: center; justify-content: center; padding: clamp(16px, 4vw, 56px); }
.lightbox.open { display: flex; }
.lightbox img { max-width: 100%; max-height: 82vh; border-radius: var(--r-md); display: block; box-shadow: 0 30px 80px rgba(0,0,0,.5); }
.lightbox .lb-cap { position: absolute; bottom: clamp(16px,3vw,32px); left: 0; right: 0; text-align: center; color: var(--cream-on-ink-soft); font-size: 0.85rem; }
.lightbox button { position: absolute; background: none; border: none; color: var(--cream-on-ink); font-size: 2rem; line-height: 1; padding: 16px; opacity: .7; transition: opacity .2s; }
.lightbox button:hover { opacity: 1; }
.lightbox .lb-close { top: clamp(8px,2vw,20px); right: clamp(8px,2vw,20px); }
.lightbox .lb-prev { left: clamp(4px,2vw,20px); top: 50%; transform: translateY(-50%); }
.lightbox .lb-next { right: clamp(4px,2vw,20px); top: 50%; transform: translateY(-50%); }

/* ── map (Leaflet overrides) ── */
.map-wrap { border-radius: var(--r-lg); overflow: hidden; border: 1px solid var(--ink-line); }
.map-wrap .leaflet-container { height: clamp(360px, 50vw, 540px); background: var(--sand-2); font-family: "Hanken Grotesk", sans-serif; }
.map-wrap .leaflet-tile-pane { filter: grayscale(1) brightness(1.05) sepia(0.18) saturate(0.7) hue-rotate(-8deg); }
.map-wrap .leaflet-popup-content-wrapper { background: var(--ink); color: var(--cream-on-ink); border-radius: var(--r-sm); }
.map-wrap .leaflet-popup-tip { background: var(--ink); }
.map-wrap .leaflet-popup-content { margin: 12px 14px; font-size: 0.85rem; }
.map-wrap .leaflet-popup-content b { font-family: "Zilla Slab", serif; }
.map-wrap .leaflet-popup-close-button { color: var(--cream-on-ink-soft); }
.map-pin { width: 26px; height: 26px; border-radius: 50% 50% 50% 0; background: var(--ink); transform: rotate(-45deg); border: 2px solid var(--sand); box-shadow: 0 2px 6px rgba(0,0,0,.3); }
.map-pin.villa { background: var(--ochre); width: 32px; height: 32px; }
.map-pin span { display: block; width: 8px; height: 8px; border-radius: 50%; background: var(--sand); position: absolute; left: 50%; top: 50%; transform: translate(-50%,-50%) rotate(45deg); }
.map-pin.villa span { background: var(--ink); width: 10px; height: 10px; }

/* ── holding form ── */
.holding-form { display: grid; gap: var(--space-md); }
.holding-form .field { display: grid; gap: 6px; }
.holding-form label { font-size: 0.72rem; font-weight: 800; letter-spacing: 0.1em; text-transform: uppercase; color: var(--ink-faint); }
.holding-form input[type=text], .holding-form input[type=email], .holding-form textarea, .holding-form select { font: inherit; padding: 12px 14px; border-radius: var(--r-sm); border: 1px solid var(--ink-line); background: var(--sand-3); color: var(--ink); }
.holding-form textarea { min-height: 90px; resize: vertical; }
.holding-form .radios, .holding-form .checks { display: flex; flex-wrap: wrap; gap: 10px; }
.holding-form .radios label, .holding-form .checks label { display: inline-flex; align-items: center; gap: 8px; text-transform: none; letter-spacing: 0; font-size: 0.92rem; font-weight: 500; color: var(--ink); padding: 9px 14px; border: 1px solid var(--ink-line); border-radius: 999px; cursor: pointer; background: var(--sand-3); transition: background .2s, border-color .2s; }
.holding-form .radios input, .holding-form .checks input { accent-color: var(--ochre); }
.holding-form .radios label:has(input:checked), .holding-form .checks label:has(input:checked) { background: var(--ochre); border-color: var(--ochre); color: var(--ink); }
.holding-form .form-note { font-size: 0.78rem; color: var(--ink-faint); }
.holding-success { display: none; padding: clamp(24px,3vw,32px); border-radius: var(--r-lg); background: var(--ink); color: var(--cream-on-ink); }
.holding-success.show { display: block; }
.holding-form.hidden { display: none; }

/* ── reveal (GSAP animates these in; this is the resting hidden state) ── */
[data-reveal] { opacity: 0; transform: translateY(22px); }
[data-reveal].is-in, .reduced-motion [data-reveal] { opacity: 1; transform: none; }
@media (prefers-reduced-motion: reduce) { [data-reveal] { opacity: 1 !important; transform: none !important; } }
.no-js [data-reveal] { opacity: 1; transform: none; }

/* ── closer (Terima Kasih) ── */
.closer { text-align: center; overflow: hidden; }
.closer-art { position: relative; display: inline-block; max-width: min(560px, 86vw); margin-bottom: clamp(8px, 2vw, 20px); }
.closer-art img { width: 100%; display: block; }
.closer-art .ttl { position: absolute; top: 46%; left: 7%; transform: translateY(-50%); font-family: "Zilla Slab", serif; font-weight: 700; color: var(--cream-on-ink); font-size: clamp(2rem, 1.2rem + 4.6vw, 3.6rem); line-height: 0.94; letter-spacing: var(--tracking-tight); text-transform: uppercase; text-align: left; }
.closer .c-sub { font-size: clamp(1.1rem, 1rem + 0.6vw, 1.4rem); color: var(--ink-faint); }
.closer .c-sub-2 { margin-top: var(--space-2xs); font-size: 0.78rem; font-weight: 800; letter-spacing: var(--tracking-label); text-transform: uppercase; color: var(--ink-faint); }

/* ── easter egg reveal ── */
.egg { display: none; }
.egg.show { display: block; }

/* ── flight cards (Plan) ── */
.flight-stack { display: grid; gap: var(--space-sm); }
.flight-card { background: var(--sand-3); border-radius: var(--r-lg); padding: clamp(24px, 3vw, 36px); border: 1px solid var(--ink-line); color: var(--ink); }
.flight-card .fc-top { display: flex; justify-content: space-between; align-items: baseline; flex-wrap: wrap; gap: var(--space-2xs); margin-bottom: var(--space-lg); font-size: 0.66rem; font-weight: 800; letter-spacing: 0.13em; text-transform: uppercase; }
.flight-card .fc-top .code { font-family: "Zilla Slab", serif; font-size: 1.05rem; font-weight: 700; letter-spacing: 0.02em; text-transform: none; }
.flight-route { display: grid; grid-template-columns: 1fr auto 1fr; align-items: center; gap: clamp(16px, 3vw, 36px); }
.flight-route .stop .iata { font-family: "Zilla Slab", serif; font-weight: 700; font-size: clamp(1.9rem, 1.3rem + 2.2vw, 3rem); line-height: 1; letter-spacing: var(--tracking-tight); }
.flight-route .stop .when { margin-top: 6px; font-size: 0.84rem; font-variant-numeric: tabular-nums; color: var(--ink-faint); font-weight: 600; }
.flight-route .stop.r { text-align: right; }
.flight-route .mid { text-align: center; font-size: 0.62rem; font-weight: 800; letter-spacing: 0.13em; text-transform: uppercase; color: var(--ink-faint); }
.flight-route .mid .arr { display: block; margin: 5px auto; width: 64px; height: 1px; background: currentColor; opacity: 0.5; position: relative; }
.flight-route .mid .arr::after { content: ""; position: absolute; right: -1px; top: -3px; width: 7px; height: 7px; border-top: 1px solid currentColor; border-right: 1px solid currentColor; transform: rotate(45deg); }
.flight-card .fc-foot { margin-top: var(--space-lg); padding-top: var(--space-md); border-top: 1px solid var(--ink-line); }
.deetrow { display: flex; flex-wrap: wrap; gap: 8px; }
.deet { font-size: 0.8rem; font-weight: 600; padding: 6px 12px; border-radius: 999px; background: var(--sand-2); }
.deet strong { font-weight: 800; }
@media (max-width: 620px) { .flight-route { grid-template-columns: 1fr; gap: var(--space-sm); } .flight-route .stop.r, .flight-route .mid { text-align: left; } .flight-route .mid .arr { margin-left: 0; } }

/* ── agenda day body (Plan) ── */
.day-body { display: grid; grid-template-columns: 1fr 280px; gap: clamp(28px, 4vw, 56px); }
@media (max-width: 760px) { .day-body { grid-template-columns: 1fr; gap: var(--space-lg); } details.acc.day summary { grid-template-columns: 1fr auto; } details.acc.day .acc-meta.dayno, details.acc.day .tag { display: none; } }
.timeline .tl-row { display: grid; grid-template-columns: 6rem 1fr; gap: var(--space-md); padding: 14px 0; border-top: 1px solid var(--ink-line); }
.timeline .tl-row:first-child { border-top: none; padding-top: 4px; }
.timeline .tl-time { font-size: 0.82rem; font-weight: 800; font-variant-numeric: tabular-nums; letter-spacing: 0.03em; padding-top: 2px; text-transform: uppercase; }
.timeline .tl-what strong { font-weight: 750; }
.timeline .tl-what .why { display: block; font-size: 0.9rem; color: var(--ink-faint); margin-top: 3px; line-height: 1.45; }
.meals { background: var(--sand-3); border: 1px solid var(--ink-line); border-radius: var(--r-md); padding: clamp(18px, 2vw, 24px); align-self: start; }
details.acc.day[open] .meals { background: var(--sand); }
.meals h4 { font-size: 0.62rem; font-weight: 800; letter-spacing: 0.14em; text-transform: uppercase; margin-bottom: var(--space-sm); color: var(--ink-faint); }
.meals .mr { display: grid; grid-template-columns: 5.4rem 1fr; gap: var(--space-2xs); padding: 9px 0; font-size: 0.88rem; }
.meals .mr + .mr { border-top: 1px solid var(--ink-line); }
.meals .mr .mw { font-weight: 800; text-transform: uppercase; font-size: 0.66rem; letter-spacing: 0.08em; padding-top: 2px; }
.meals .mr .md { color: var(--ink-faint); }

/* ── bahasa table (Know) ── */
.table-card { border: 1px solid var(--ink-line); border-radius: var(--r-md); overflow: hidden; }
table.bahasa { width: 100%; border-collapse: collapse; font-size: 0.95rem; }
table.bahasa thead { background: var(--ink); color: var(--cream-on-ink); }
table.bahasa thead th { text-align: left; padding: 14px 18px; font-size: 0.62rem; font-weight: 800; letter-spacing: 0.14em; text-transform: uppercase; }
table.bahasa tbody td { padding: 13px 18px; border-top: 1px solid var(--ink-line); background: var(--sand-3); color: var(--ink); }
table.bahasa tbody tr:nth-child(even) td { background: var(--sand-2); }
table.bahasa tbody td:nth-child(1) { color: var(--ink-faint); }
table.bahasa tbody td:nth-child(2) { font-weight: 700; font-family: "Zilla Slab", serif; color: var(--ink); }
table.bahasa tbody td:nth-child(3) { font-size: 0.84rem; color: var(--ink-faint); font-variant-numeric: tabular-nums; }
@media (max-width: 540px) {
  table.bahasa, table.bahasa tbody, table.bahasa tr, table.bahasa td { display: block; }
  table.bahasa thead { display: none; }
  table.bahasa tbody td { border: none; }
  table.bahasa tbody tr { padding: 12px 16px; border-top: 1px solid var(--ink-line); }
  table.bahasa tbody tr:first-child { border-top: none; }
  table.bahasa tbody td:nth-child(1) { font-size: 0.7rem; text-transform: uppercase; letter-spacing: 0.1em; font-weight: 800; }
  table.bahasa tbody td:nth-child(2) { font-size: 1.1rem; }
}

/* ── basics grid (Know) ── */
.basics { display: grid; grid-template-columns: repeat(6, 1fr); gap: var(--space-sm); grid-auto-rows: minmax(150px, auto); }
.basics .b { border-radius: var(--r-md); padding: clamp(20px, 2.5vw, 30px); display: flex; flex-direction: column; gap: var(--space-2xs); justify-content: space-between; background: var(--sand-3); border: 1px solid var(--ink-line); }
.basics .b.span2 { grid-column: span 2; } .basics .b.span3 { grid-column: span 3; } .basics .b.span6 { grid-column: span 6; }
.basics .b.ink { background: var(--ink); color: var(--cream-on-ink); border-color: var(--ink); }
.basics .b.ochre { background: var(--ochre); border-color: var(--ochre); }
.basics .b .b-lab { font-size: 0.62rem; font-weight: 800; letter-spacing: 0.13em; text-transform: uppercase; color: var(--ink-faint); }
.basics .b.ink .b-lab { color: var(--cream-on-ink-soft); } .basics .b.ochre .b-lab { color: oklch(0.318 0.030 248 / 0.66); }
.basics .b .b-big { font-family: "Zilla Slab", serif; font-weight: 700; font-size: clamp(1.9rem, 1.4rem + 1.7vw, 2.6rem); line-height: 0.95; letter-spacing: -0.03em; font-variant-numeric: tabular-nums; }
.basics .b h4 { font-family: "Zilla Slab", serif; font-weight: 700; font-size: clamp(1.15rem, 1.05rem + 0.5vw, 1.4rem); line-height: 1.1; letter-spacing: var(--tracking-tight); }
.basics .b p { font-size: 0.92em; line-height: 1.45; color: var(--ink-faint); }
.basics .b.ink p { color: var(--cream-on-ink-soft); }
.basics .b.span6 { flex-direction: row; align-items: center; gap: clamp(20px, 4vw, 48px); flex-wrap: wrap; }
.basics .b.span6 h4 { font-size: clamp(1.4rem, 1.1rem + 1.2vw, 2rem); flex: 1; min-width: 260px; }
.basics .b.span6 p { font-size: 1rem; flex: 1.4; min-width: 260px; }
@media (max-width: 860px) { .basics { grid-template-columns: repeat(2, 1fr); } .basics .b.span2, .basics .b.span3, .basics .b.span6 { grid-column: span 2; } .basics .b.span6 { flex-direction: column; align-items: flex-start; } }
@media (max-width: 480px) { .basics { grid-template-columns: 1fr; } .basics .b.span2, .basics .b.span3, .basics .b.span6 { grid-column: span 1; } }

/* ── print (offline one-pager hook) ── */
@media print {
  .site-nav, .nav-overlay, .site-footer, .palm, .wave, .lightbox, [data-noprint] { display: none !important; }
  body::before { display: none !important; }
  body { padding-top: 0; background: #fff; color: #000; }
  [data-reveal] { opacity: 1 !important; transform: none !important; }
  .print-only { display: block !important; }
}
.print-only { display: none; }
