/* ============================================================
   M'AKOMA — The People You Carry
   Design system: warm gold on deep black, jewelry-luxury + warm tech
   ============================================================ */

:root{
  --black:        #060607;
  --black-2:      #0b0b0d;
  --panel:        #111114;
  --panel-2:      #16151a;
  --line:         rgba(201,160,78,.16);
  --line-soft:    rgba(237,231,218,.08);

  --gold:         #c9a04e;
  --gold-bright:  #e8c57a;
  --gold-pale:    #f1e6cb;
  --gold-deep:    #9b7a36;

  --ink:          #ece6d8;       /* primary text */
  --ink-soft:     #b7b0a1;       /* secondary    */
  --ink-mute:     #9a9285;       /* tertiary (lightened for WCAG AA on dark panels) */

  --maxw: 1180px;
  --ease: cubic-bezier(.22,.61,.36,1);
  --ease-out: cubic-bezier(.16,1,.3,1);

  --serif: "Cormorant Garamond", Georgia, "Times New Roman", serif;
  --sans: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  --mono: "JetBrains Mono", ui-monospace, "SF Mono", Menlo, monospace;
}

*{ box-sizing:border-box; margin:0; padding:0; }
html{ scroll-behavior:smooth; -webkit-text-size-adjust:100%; }
body{
  background:var(--black);
  color:var(--ink);
  font-family:var(--sans);
  font-weight:300;
  line-height:1.6;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
img{ display:block; max-width:100%; }
a{ color:inherit; text-decoration:none; }
button{ font-family:inherit; cursor:pointer; color:inherit; background:none; border:none; }
em{ font-style:italic; color:var(--gold-bright); }
::selection{ background:rgba(201,160,78,.3); color:#fff; }

/* ---------- a11y utilities ---------- */
.sr-only{ position:absolute !important; width:1px; height:1px; padding:0; margin:-1px; overflow:hidden; clip:rect(0,0,0,0); white-space:nowrap; border:0; }
a:focus-visible, button:focus-visible, input:focus-visible, summary:focus-visible, [tabindex]:focus-visible{
  outline:2px solid var(--gold-bright); outline-offset:3px; border-radius:3px;
}

.wrap{ width:100%; max-width:var(--maxw); margin:0 auto; padding:0 28px; }

/* ---------- ambient texture / glow ---------- */
.grain{
  position:fixed; inset:0; z-index:1; pointer-events:none; opacity:.05; mix-blend-mode:overlay;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.85' numOctaves='3'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}
.cursor-glow{
  position:fixed; top:0; left:0; width:480px; height:480px; z-index:0; pointer-events:none;
  border-radius:50%; transform:translate(-50%,-50%); opacity:0; transition:opacity .5s;
  background:radial-gradient(circle, rgba(201,160,78,.10), transparent 62%);
}

/* ============ typography helpers ============ */
.gold-ink{
  background:linear-gradient(100deg, var(--gold-deep), var(--gold-bright) 45%, var(--gold-pale) 70%, var(--gold) 100%);
  -webkit-background-clip:text; background-clip:text; -webkit-text-fill-color:transparent;
}
.muted{ color:var(--ink-mute); }
.eyebrow, .section-tag{
  font-size:.74rem; letter-spacing:.32em; text-transform:uppercase; font-weight:500;
  color:var(--gold); font-family:var(--sans);
}
.section-tag{ display:inline-block; margin-bottom:22px; position:relative; padding-left:36px; }
.section-tag::before{ content:""; position:absolute; left:0; top:50%; width:26px; height:1px; background:var(--gold); opacity:.6; }

h1,h2,h3{ font-family:var(--serif); font-weight:500; line-height:1.04; letter-spacing:-.01em; }

/* ============ buttons ============ */
.btn{
  display:inline-flex; align-items:center; gap:.6em; justify-content:center;
  padding:.95em 1.7em; border-radius:100px; font-size:.86rem; font-weight:500;
  letter-spacing:.02em; transition:all .4s var(--ease); white-space:nowrap;
}
.btn-gold{
  background:linear-gradient(120deg, var(--gold-deep), var(--gold-bright));
  color:#1a1407; box-shadow:0 10px 36px -10px rgba(201,160,78,.55);
}
.btn-gold:hover{ transform:translateY(-2px); box-shadow:0 16px 46px -10px rgba(232,197,122,.7); }
.btn-line{ border:1px solid var(--line); color:var(--ink-soft); }
.btn-line:hover{ border-color:var(--gold); color:var(--gold-bright); }
.btn-ghost{ font-size:.8rem; padding:.6em 1.2em; border:1px solid var(--line); }
.btn-ghost:hover{ border-color:var(--gold); color:var(--gold-bright); }

/* ============ NAV ============ */
.nav{
  position:fixed; top:0; left:0; right:0; z-index:60;
  display:flex; align-items:center; justify-content:space-between;
  padding:20px clamp(20px,4vw,46px);
  transition:background .5s, backdrop-filter .5s, padding .5s, border-color .5s;
  border-bottom:1px solid transparent;
}
.nav.scrolled{
  background:rgba(7,7,8,.72); backdrop-filter:blur(18px) saturate(140%);
  border-bottom-color:var(--line-soft); padding-top:14px; padding-bottom:14px;
}
.brand{ display:inline-flex; align-items:center; gap:11px; }
.brand-ico{ width:25px; height:auto; display:block; flex:0 0 auto; }
.brand-mark{
  font-family:var(--sans); font-weight:600; letter-spacing:.42em; font-size:.95rem;
  color:var(--gold-pale); padding-left:.42em;
}
.brand-mark.small{ font-size:.8rem; }
.brand-mark .tm{ font-size:.46em; letter-spacing:0; vertical-align:.62em; margin-left:-.2em; font-weight:500; opacity:.9; }
.nav-links{ display:flex; gap:30px; }
.nav-links a{ font-size:.82rem; color:var(--ink-soft); letter-spacing:.04em; position:relative; transition:color .3s; }
.nav-links a::after{ content:""; position:absolute; left:0; bottom:-6px; width:0; height:1px; background:var(--gold); transition:width .35s var(--ease); }
.nav-links a:hover{ color:var(--gold-bright); }
.nav-links a:hover::after{ width:100%; }

/* ============ reveal animation ============ */
.reveal{ opacity:0; transform:translateY(34px); transition:opacity 1s var(--ease-out), transform 1s var(--ease-out); }
.reveal.in{ opacity:1; transform:none; }
@media (prefers-reduced-motion: reduce){
  .reveal{ opacity:1; transform:none; transition:none; }
  html{ scroll-behavior:auto !important; }
  /* neutralize looping/decorative animations (beadPulse, hubPing, blink, usPulse,
     scrollDot, ringPulse, spin…) and make transitions instant — state still changes,
     so bead glow & menu still respond, just without motion. */
  *, *::before, *::after{
    animation-duration:.001ms !important; animation-iteration-count:1 !important;
    transition-duration:.001ms !important;
  }
}

/* ============ HERO — scroll-driven 3D ============ */
.hero3d{ position:relative; height:560vh; background:var(--black); }
.hero3d.no3d{ height:100svh; }
.hero3d-sticky{ position:sticky; top:0; height:100svh; height:100dvh; overflow:hidden;
  /* a focused warm POOL behind the bracelet + a darker vignette frame, so the bracelet pops off the page
     without brightening the beads themselves (extra rim light just washed them out / "sun-bleached"). */
  background:
    radial-gradient(62% 50% at 50% 42%, #3a2a12 0%, #1c140b 45%, transparent 72%),
    radial-gradient(130% 105% at 50% 40%, #110c07 0%, #070605 58%, #030303 100%); }
#heroCanvas{ position:absolute; inset:0; width:100%; height:100%; display:block; z-index:1; }
.hero3d.no3d #heroCanvas{ display:none; }
.hero3d-poster{
  position:absolute; inset:0; width:100%; height:100%; object-fit:cover; object-position:center;
  z-index:0; opacity:0; transition:opacity 1.1s var(--ease);   /* hidden during 3D load (no render flash); only shown as the no-WebGL fallback */
}
.hero3d.no3d .hero3d-poster{ opacity:1; }
.hero3d-veil{
  position:absolute; inset:0; z-index:2; pointer-events:none;
  background:
    radial-gradient(120% 86% at 50% 4%, transparent 46%, rgba(6,6,7,.5) 90%, var(--black) 100%),
    linear-gradient(180deg, rgba(6,6,7,.5) 0%, transparent 20%, transparent 72%, var(--black) 100%);
}
.hero3d-overlay{ position:absolute; inset:0; z-index:3; pointer-events:none; }
.hero3d-overlay a{ pointer-events:auto; }

.hero-intro{ position:absolute; left:clamp(22px,7vw,96px); top:50%; transform:translateY(-50%); max-width:560px; }
.hero3d.no3d .hero-intro{ top:auto; bottom:11vh; transform:none; }
.hero-intro .eyebrow{ display:block; margin-bottom:24px; }
.hero-title{ font-size:clamp(3rem, 8vw, 6.4rem); line-height:.95; margin-bottom:24px; }
.hero-sub{ font-size:clamp(1.02rem,1.6vw,1.25rem); color:var(--ink-soft); max-width:480px; margin-bottom:26px; font-weight:300; }
.hero-actions{ display:flex; flex-wrap:wrap; gap:14px; margin-bottom:30px; }
.hero-foot{ font-family:var(--serif); font-style:italic; font-size:1.12rem; color:var(--gold-pale); opacity:.82; max-width:460px; }

.hero-caption{ position:absolute; left:clamp(22px,7vw,96px); bottom:14vh; max-width:440px; opacity:0; will-change:opacity; }
.hero-caption .hc-kicker{ font-size:.72rem; letter-spacing:.28em; text-transform:uppercase; color:var(--gold); display:block; margin-bottom:12px; }
.hero-caption .hc-title{ font-size:clamp(1.8rem,3.6vw,2.8rem); margin-bottom:14px; color:var(--ink); }
.hero-caption .hc-line{ color:var(--ink-soft); font-size:1.02rem; line-height:1.5; }

/* exploded-diagram callouts for the hub components (positions set per-frame in hero3d.js) */
.hub-labels{ position:absolute; inset:0; z-index:3; pointer-events:none; overflow:hidden; }
.hub-label{ position:absolute; transform:translateY(-50%); opacity:0; white-space:nowrap; display:flex; align-items:center; gap:8px;
  font-size:.64rem; letter-spacing:.14em; text-transform:uppercase; font-weight:500; color:var(--gold-pale);
  text-shadow:0 1px 12px rgba(0,0,0,.92), 0 0 2px rgba(0,0,0,.8); will-change:left,top,opacity; }
.hub-label i{ width:5px; height:5px; border-radius:50%; background:var(--gold); box-shadow:0 0 10px 1px rgba(201,160,78,.85); flex:0 0 auto; }
.hub-label.flip{ flex-direction:row-reverse; transform:translate(-100%,-50%); }
@media(max-width:820px){ .hub-label{ font-size:.55rem; letter-spacing:.1em; gap:6px; } }

.hero-outro{ position:absolute; left:0; right:0; top:72%; transform:translateY(-50%); text-align:center; opacity:0; padding:0 24px; }
.hero-outro h2{ font-size:clamp(2.4rem,6vw,4.4rem); margin-bottom:30px; }
.hero-outro .hero-actions{ justify-content:center; margin-bottom:0; }

.hero3d.no3d .hero-caption,
.hero3d.no3d .hero-outro,
.hero3d.no3d .hero-progress,
.hero3d.no3d .scroll-cue{ display:none; }
@media (max-width: 820px){
  .hero3d.no3d .hero-intro{ top:auto; bottom:7vh; transform:none; max-width:none; padding-right:16px; }
  .hero3d.no3d .hero-title{ font-size:clamp(2.6rem, 11vw, 4rem); margin-bottom:16px; }
  .hero3d.no3d .hero-sub{ font-size:1rem; margin-bottom:20px; }
  .hero3d.no3d .hero-foot{ display:none; }
  .hero3d.no3d .hero3d-poster{ object-position:center 38%; }

  /* active 3D bead scroll on phones: keep the overlay text inside the viewport and clear of the centered bracelet */
  .hero3d:not(.no3d) .hero-intro{ left:22px; right:22px; max-width:none; top:auto; bottom:15vh; transform:none; }
  .hero3d:not(.no3d) .hero-title{ font-size:clamp(2.3rem, 9vw, 3.2rem); margin-bottom:18px; }
  .hero3d:not(.no3d) .hero-caption{ left:22px; right:22px; max-width:none; bottom:9vh; }
  .hero3d:not(.no3d) .hero-caption .hc-title{ font-size:clamp(1.45rem, 6vw, 2rem); }
  .hero3d:not(.no3d) .hero-caption .hc-line{ font-size:.92rem; line-height:1.45; }
  .hero3d:not(.no3d) .hero-outro h2{ font-size:clamp(1.9rem, 7.5vw, 3rem); margin-bottom:22px; }
}

.hero-progress{ position:absolute; left:0; right:0; bottom:0; height:2px; z-index:4; background:rgba(237,231,218,.07); }
.hero-progress span{ display:block; height:100%; width:100%; transform-origin:left; transform:scaleX(0); background:linear-gradient(90deg,var(--gold-deep),var(--gold-bright)); box-shadow:0 0 12px var(--gold); }

.hero-loader{ position:absolute; left:50%; bottom:44px; transform:translateX(-50%); z-index:4; display:flex; align-items:center; gap:12px; color:var(--ink-mute); font-size:.74rem; letter-spacing:.16em; text-transform:uppercase; transition:opacity .6s; }
.hero-loader.hide{ opacity:0; pointer-events:none; }
.hero-loader i{ width:14px; height:14px; border:2px solid rgba(201,160,78,.28); border-top-color:var(--gold); border-radius:50%; animation:spin .9s linear infinite; }
@keyframes spin{ to{ transform:rotate(360deg); } }

.scroll-cue{ position:absolute; bottom:30px; left:50%; transform:translateX(-50%); z-index:4; width:26px; height:42px; border:1px solid var(--line); border-radius:14px; display:flex; justify-content:center; padding-top:8px; transition:opacity .5s; }
.scroll-cue span{ width:3px; height:8px; border-radius:2px; background:var(--gold); animation:scrollDot 1.8s var(--ease) infinite; }
@keyframes scrollDot{ 0%{opacity:0; transform:translateY(0);} 30%{opacity:1;} 70%{opacity:1; transform:translateY(12px);} 100%{opacity:0; transform:translateY(16px);} }

/* ============ section rhythm ============ */
section{ position:relative; z-index:2; }
.manifesto,.shift,.beads,.how,.circle,.symbols,.tech,.position,.platform{ padding:clamp(90px,12vw,160px) 0; }

/* ============ MANIFESTO ============ */
.manifesto{ background:linear-gradient(180deg, var(--black), var(--black-2)); }
.big-statement{ font-size:clamp(2.2rem,5.2vw,4.2rem); max-width:14ch; margin-bottom:40px; }
.big-statement .muted{ display:block; font-size:.62em; margin-top:.25em; color:var(--ink-soft); }
.strike{ position:relative; color:var(--ink-mute); }
.strike::after{ content:""; position:absolute; left:-2%; top:54%; width:0; height:2px; background:linear-gradient(90deg,var(--gold),var(--gold-bright)); transition:width 1.1s var(--ease-out) .2s; box-shadow:0 0 12px var(--gold); }
.in .strike::after, .strike.cut::after{ width:104%; }
.lede{ font-size:clamp(1.05rem,1.6vw,1.3rem); color:var(--ink-soft); max-width:60ch; margin-bottom:54px; }
.refusals{ list-style:none; display:flex; flex-wrap:wrap; gap:12px; margin-bottom:24px; }
.refusals li{
  font-family:var(--serif); font-size:clamp(1.1rem,2.4vw,1.7rem); color:var(--ink-mute);
  padding:.18em .7em; border:1px solid var(--line-soft); border-radius:100px; position:relative; transition:.5s var(--ease);
}
.refusals li::before{ content:""; position:absolute; left:12%; right:12%; top:52%; height:1.5px; background:var(--gold); transform:scaleX(0); transform-origin:left; transition:transform .5s var(--ease); box-shadow:0 0 8px var(--gold); }
.refusals.in li::before{ transform:scaleX(1); }
.refusals.in li{ transition-delay:calc(var(--i,0) * 70ms); }
.refusals-note{ font-family:var(--serif); font-style:italic; font-size:1.35rem; color:var(--gold-pale); }

/* ============ SHIFT ============ */
.shift{ background:var(--black-2); }
.shift-grid{ display:grid; gap:60px; align-items:center; }
@media(min-width:900px){ .shift-grid{ grid-template-columns:1.05fr .95fr; gap:80px; } }
.shift-line h2{ font-size:clamp(2rem,4.4vw,3.4rem); margin-bottom:26px; }
.shift-line p{ color:var(--ink-soft); font-size:1.1rem; max-width:46ch; }
.shift-cards{ display:flex; align-items:stretch; gap:18px; flex-wrap:wrap; }
.shift-card{ flex:1 1 200px; background:var(--panel); border:1px solid var(--line-soft); border-radius:18px; padding:28px 24px; transition:.5s var(--ease); }
.shift-card.on{ border-color:var(--line); background:linear-gradient(160deg, rgba(201,160,78,.08), var(--panel)); box-shadow:0 20px 60px -28px rgba(201,160,78,.4); }
.sc-label{ font-size:.72rem; letter-spacing:.26em; text-transform:uppercase; color:var(--gold); display:block; margin-bottom:12px; }
.shift-card p{ font-family:var(--serif); font-size:1.25rem; line-height:1.32; color:var(--ink); }
.shift-card.on p{ color:var(--gold-pale); }
.shift-arrow{ align-self:center; color:var(--gold); font-size:1.5rem; }
@media(max-width:560px){ .shift-arrow{ transform:rotate(90deg); } }

/* ============ INTERACTIVE BEADS ============ */
.beads{ background:radial-gradient(120% 80% at 50% 0%, var(--black-2), var(--black)); text-align:center; }
.beads .section-tag{ padding-left:0; } .beads .section-tag::before{ display:none; }
.beads-title{ font-size:clamp(2.2rem,5vw,3.8rem); margin-bottom:10px; }
.bracelet-stage{ margin:54px 0 10px; padding:30px 0; }
.bracelet{
  display:flex; align-items:center; justify-content:center; gap:clamp(6px,1.4vw,16px);
  flex-wrap:nowrap; max-width:980px; margin:0 auto; padding:36px 10px;
  overflow-x:auto; scrollbar-width:none;
}
.bracelet::-webkit-scrollbar{ display:none; }

.hub{ position:relative; flex:0 0 auto; width:clamp(60px,7vw,78px); height:clamp(46px,5.4vw,58px);
  border-radius:18px; background:linear-gradient(155deg,#202024,#0c0c0e);
  box-shadow:0 14px 34px -12px #000, inset 0 1px 1px rgba(255,255,255,.06); margin:0 6px;
  display:flex; align-items:center; justify-content:center; transition:.4s var(--ease); }
.hub-disc{ width:42%; height:62%; border-radius:50%/40%; background:radial-gradient(circle at 38% 32%, var(--gold-bright), var(--gold-deep) 75%); box-shadow:0 0 16px rgba(201,160,78,.5); }
.hub:hover{ transform:translateY(-3px); }
.hub.pinging{ animation:hubPing 1.2s var(--ease); }
@keyframes hubPing{ 50%{ box-shadow:0 0 0 14px rgba(201,160,78,.0), 0 14px 34px -12px #000; } }

.bead{
  position:relative; flex:0 0 auto; width:clamp(50px,6.6vw,74px); height:clamp(50px,6.6vw,74px);
  border-radius:50%; cursor:pointer; transition:transform .45s var(--ease);
  background:
    radial-gradient(circle at 34% 28%, #34343a, #131316 38%, #08080a 72%);
  box-shadow:0 12px 26px -10px #000, inset 0 -6px 12px rgba(0,0,0,.7), inset 0 3px 6px rgba(255,255,255,.07);
}
.bead::after{ /* specular highlight */
  content:""; position:absolute; left:24%; top:16%; width:26%; height:20%; border-radius:50%;
  background:radial-gradient(circle, rgba(255,255,255,.5), transparent 70%); filter:blur(1px);
}
.bead .glyph{ position:absolute; inset:18%; z-index:2; }
.bead .glyph svg{ width:100%; height:100%; }
.bead .glyph path{ fill:var(--g, var(--gold)); transition:filter .5s, fill .5s; filter:drop-shadow(0 0 0 transparent); opacity:.9; }
.bead:hover{ transform:translateY(-6px) scale(1.04); }
.bead.lit .glyph path{
  fill:var(--g); opacity:1;
  filter:drop-shadow(0 0 5px var(--g)) drop-shadow(0 0 14px var(--g));
}
.bead.lit{ box-shadow:0 0 0 1px color-mix(in srgb, var(--g) 40%, transparent), 0 0 28px -2px var(--g), 0 12px 26px -10px #000, inset 0 -6px 12px rgba(0,0,0,.7); }
.bead.selected{ transform:translateY(-8px) scale(1.08); }
.bead.pulsing{ animation:beadPulse .8s var(--ease); }
@keyframes beadPulse{ 0%,100%{ } 30%{ transform:translateY(-8px) scale(1.16); } }
.bead .halo{ position:absolute; inset:-30%; border-radius:50%; z-index:0; opacity:0; background:radial-gradient(circle, var(--g), transparent 60%); transition:opacity .5s; }
.bead.lit .halo{ opacity:.4; }
.bead .ring-pulse{ position:absolute; inset:0; border-radius:50%; z-index:1; pointer-events:none; }
.bead.pulsing .ring-pulse{ animation:ringPulse .8s var(--ease-out); border:1.5px solid var(--g); }
@keyframes ringPulse{ from{ inset:0; opacity:.8; } to{ inset:-40%; opacity:0; } }

.bracelet-hint{ color:var(--ink-mute); font-size:.82rem; letter-spacing:.14em; text-transform:uppercase; margin-top:14px; }

/* bead detail panel */
.bead-panel{
  display:grid; grid-template-columns:auto 1fr; gap:32px; align-items:center; text-align:left;
  max-width:760px; margin:46px auto 0; padding:34px; border-radius:24px;
  background:linear-gradient(160deg, var(--panel-2), var(--panel)); border:1px solid var(--line-soft);
  box-shadow:0 30px 80px -40px #000; transition:box-shadow .6s, border-color .6s;
}
.bp-glyph{ width:120px; height:120px; border-radius:24px; display:flex; align-items:center; justify-content:center;
  background:radial-gradient(circle at 40% 30%, #1b1b1f, #0a0a0c); box-shadow:inset 0 0 30px rgba(0,0,0,.6); }
.bp-glyph svg{ width:74%; height:74%; }
.bp-glyph path{ transition:fill .5s, filter .5s; }
.bp-person{ font-size:.74rem; letter-spacing:.26em; text-transform:uppercase; color:var(--gold); margin-bottom:8px; }
.bp-symbol{ font-size:2rem; margin-bottom:10px; }
.bp-meaning{ color:var(--ink); font-size:1.05rem; margin-bottom:8px; }
.bp-proverb{ color:var(--ink-mute); font-family:var(--serif); font-style:italic; font-size:1.05rem; margin-bottom:22px; }
.bp-actions{ display:flex; gap:12px; flex-wrap:wrap; }
.act{ display:flex; align-items:center; gap:10px; padding:11px 16px; border-radius:14px; border:1px solid var(--line-soft); background:rgba(255,255,255,.02); transition:.35s var(--ease); }
.act:hover{ border-color:var(--gold); transform:translateY(-2px); background:rgba(201,160,78,.06); }
.act:active{ transform:translateY(0) scale(.97); }
.act-ico{ width:22px; height:22px; flex:0 0 auto; }
.act-ico path, .act-ico circle{ stroke:var(--gold-bright); stroke-width:1.7; fill:none; stroke-linecap:round; stroke-linejoin:round; }
.act-pulse .act-ico circle:first-child{ fill:var(--gold-bright); stroke:none; }
.act-glow .act-ico circle{ fill:var(--gold-bright); stroke:none; }
.act span{ display:flex; flex-direction:column; line-height:1.15; text-align:left; }
.act b{ font-weight:500; font-size:.92rem; }
.act small{ color:var(--ink-mute); font-size:.7rem; }
@media(max-width:600px){
  .bead-panel{ grid-template-columns:1fr; text-align:center; padding:26px 22px; }
  .bp-glyph{ margin:0 auto; }
  .bp-actions{ justify-content:center; }
}

/* ============ HOW IT WORKS ============ */
.how{ background:var(--black-2); }
.how-title{ font-size:clamp(2.2rem,5vw,3.6rem); margin-bottom:18px; }
.how-lede{ color:var(--ink-soft); max-width:52ch; margin-bottom:60px; font-size:1.1rem; }
.how-grid{ display:grid; gap:26px; grid-template-columns:1fr; }
@media(min-width:760px){ .how-grid{ grid-template-columns:repeat(3,1fr); } }
.how-card{
  background:linear-gradient(170deg, var(--panel), var(--black-2)); border:1px solid var(--line-soft);
  border-radius:22px; padding:34px 30px; transition:.5s var(--ease); position:relative; overflow:hidden;
}
.how-card:hover{ border-color:var(--line); transform:translateY(-6px); box-shadow:0 30px 70px -40px rgba(201,160,78,.4); }
.how-card h3{ font-size:1.6rem; margin:22px 0 12px; }
.how-card p{ color:var(--ink-soft); font-size:.98rem; margin-bottom:22px; }
.hc-visual{ height:84px; display:flex; align-items:center; justify-content:center; position:relative; }

.hc-echo .wave{ width:160px; height:54px; }
.hc-echo .wave path{ stroke:var(--gold-bright); stroke-width:2; fill:none; stroke-linecap:round; filter:drop-shadow(0 0 6px rgba(201,160,78,.5)); }
.hc-echo .rec-dot{ position:absolute; right:14px; top:10px; width:9px; height:9px; border-radius:50%; background:#e05050; opacity:0; transition:opacity .3s; }
.how-card.recording .hc-echo .rec-dot{ opacity:1; animation:blink 1s infinite; }
@keyframes blink{ 50%{ opacity:.25; } }

.hc-pulse .ripple-core{ width:24px; height:24px; border-radius:50%; background:radial-gradient(circle,var(--gold-bright),var(--gold-deep)); box-shadow:0 0 18px var(--gold); position:relative; }
.hc-pulse .ripple-core::before, .hc-pulse .ripple-core::after{ content:""; position:absolute; inset:0; border-radius:50%; border:1.5px solid var(--gold); opacity:0; }
.how-card.tapped .hc-pulse .ripple-core::before{ animation:rip 1s var(--ease-out); }
.how-card.tapped .hc-pulse .ripple-core::after{ animation:rip 1s var(--ease-out) .18s; }
@keyframes rip{ from{ inset:0; opacity:.85; } to{ inset:-32px; opacity:0; } }

.hc-glow .glow-bead{ width:46px; height:46px; border-radius:50%; background:radial-gradient(circle at 36% 30%,#2a2a30,#0a0a0c 70%); box-shadow:0 0 26px -2px var(--gc,var(--gold)); position:relative; transition:box-shadow .5s; }
.hc-glow .glow-bead::after{ content:""; position:absolute; inset:30%; border-radius:50%; background:var(--gc,var(--gold)); filter:blur(3px) drop-shadow(0 0 8px var(--gc,var(--gold))); transition:background .5s; }

.mini-btn{ font-size:.78rem; letter-spacing:.08em; text-transform:uppercase; color:var(--gold-bright);
  border:1px solid var(--line); border-radius:100px; padding:.6em 1.2em; transition:.35s var(--ease); user-select:none; }
.mini-btn:hover{ background:var(--gold); color:#1a1407; border-color:var(--gold); }

/* ============ CIRCLE / APP ============ */
.circle{ background:linear-gradient(180deg, var(--black-2), var(--black)); }
.circle-grid{ display:grid; gap:60px; align-items:center; }
@media(min-width:920px){ .circle-grid{ grid-template-columns:1fr .8fr; gap:80px; } }
.circle-copy h2{ font-size:clamp(2rem,4.4vw,3.2rem); margin:18px 0 22px; }
.circle-lede{ color:var(--ink-soft); font-size:1.1rem; margin-bottom:34px; max-width:48ch; }
.tiers{ list-style:none; display:flex; flex-direction:column; gap:22px; }
.tiers li{ display:flex; gap:18px; align-items:flex-start; }
.tier-dot{ flex:0 0 auto; width:14px; height:14px; border-radius:50%; margin-top:6px; border:1px solid var(--gold); position:relative; }
.tier-dot.on{ background:radial-gradient(circle,var(--gold-bright),var(--gold-deep)); box-shadow:0 0 16px var(--gold); border:none; }
.tiers b{ font-weight:500; color:var(--ink); font-size:1.08rem; }
.tiers p{ color:var(--ink-mute); font-size:.95rem; }

.phone-frame{
  width:min(300px,80vw); margin:0 auto; border-radius:42px; padding:10px;
  background:linear-gradient(160deg,#1b1b1f,#070708); border:1px solid var(--line-soft);
  box-shadow:0 50px 120px -50px #000, 0 0 60px -30px rgba(201,160,78,.4); position:relative;
}
.phone-frame img{ border-radius:34px; width:100%; display:block; }
.phone-cap{ text-align:center; color:var(--ink-mute); font-style:italic; font-family:var(--serif); font-size:1.05rem; margin-top:30px; }

/* fanned trio of real app screens */
.app-trio{ display:flex; align-items:center; justify-content:center; padding-top:14px; }
.app-trio .phone-frame{ width:42%; margin:0; padding:6px; border-radius:24px;
  box-shadow:0 26px 60px -36px #000, 0 0 30px -22px rgba(201,160,78,.3); transition:transform .5s var(--ease); }
.app-trio .phone-frame img{ border-radius:19px; }
.app-trio .phone-frame.side{ z-index:1; opacity:.94; }
.app-trio .phone-frame.side:first-child{ transform:rotate(-7deg) translateX(24%); transform-origin:bottom right; }
.app-trio .phone-frame.side:last-child{ transform:rotate(7deg) translateX(-24%); transform-origin:bottom left; }
.app-trio .phone-frame.lead{ width:48%; z-index:3; transform:translateY(-16px);
  box-shadow:0 44px 96px -44px #000, 0 0 56px -26px rgba(201,160,78,.55); }
.circle-phone:hover .app-trio .phone-frame.side:first-child{ transform:rotate(-9deg) translateX(16%); }
.circle-phone:hover .app-trio .phone-frame.side:last-child{ transform:rotate(9deg) translateX(-16%); }
@media(max-width:600px){
  .app-trio .phone-frame{ width:46%; }
  .app-trio .phone-frame.lead{ width:52%; }
}

/* ============ SYMBOLS ============ */
.symbols{ background:var(--black); }
.symbols-title{ font-size:clamp(2.2rem,5vw,3.6rem); margin-bottom:18px; }
.symbols-lede{ color:var(--ink-soft); max-width:60ch; margin-bottom:56px; font-size:1.1rem; }
.symbol-grid{ display:grid; gap:18px; grid-template-columns:repeat(2,1fr); }
@media(min-width:680px){ .symbol-grid{ grid-template-columns:repeat(4,1fr); } }
.sym-card{
  background:linear-gradient(170deg, var(--panel), var(--black-2)); border:1px solid var(--line-soft);
  border-radius:18px; padding:26px 22px; text-align:center; transition:.5s var(--ease); cursor:default;
}
.sym-card:hover{ transform:translateY(-6px); border-color:var(--line); box-shadow:0 26px 60px -36px var(--g); }
.sym-ico{ width:70px; height:70px; margin:0 auto 18px; display:flex; align-items:center; justify-content:center;
  border-radius:50%; background:radial-gradient(circle at 38% 30%, #1a1a1e, #08080a); box-shadow:inset 0 0 24px rgba(0,0,0,.6); }
.sym-ico svg{ width:62%; height:62%; }
.sym-ico path{ fill:var(--g); opacity:.85; transition:.5s; }
.sym-card:hover .sym-ico path{ opacity:1; filter:drop-shadow(0 0 4px var(--g)) drop-shadow(0 0 12px var(--g)); }
.sym-name{ font-family:var(--serif); font-size:1.4rem; color:var(--gold-pale); margin-bottom:6px; }
.sym-lit{ font-size:.74rem; letter-spacing:.16em; text-transform:uppercase; color:var(--gold); margin-bottom:12px; }
.sym-desc{ color:var(--ink-mute); font-size:.9rem; line-height:1.5; }

/* ============ TECH ============ */
.tech{ background:linear-gradient(180deg, var(--black), var(--black-2)); }
.tech-title{ font-size:clamp(2.2rem,5vw,3.6rem); margin-bottom:20px; }
.tech-lede{ color:var(--ink-soft); max-width:62ch; margin-bottom:54px; font-size:1.1rem; }
.tech-showcase{ display:grid; gap:22px; grid-template-columns:1fr; margin-bottom:54px; }
@media(min-width:740px){ .tech-showcase{ grid-template-columns:1fr 1fr; } }
.ts-fig{ border-radius:20px; overflow:hidden; border:1px solid var(--line-soft); background:var(--panel); position:relative; }
.ts-fig img{ width:100%; aspect-ratio:16/10; object-fit:cover; transition:transform .8s var(--ease); }
.ts-fig:hover img{ transform:scale(1.05); }
.ts-fig figcaption{ position:absolute; left:0; right:0; bottom:0; padding:18px 20px; font-size:.84rem; color:var(--ink-soft);
  background:linear-gradient(transparent, rgba(6,6,7,.92)); }

.stats{ display:grid; grid-template-columns:repeat(2,1fr); gap:1px; background:var(--line-soft); border:1px solid var(--line-soft); border-radius:20px; overflow:hidden; margin-bottom:56px; }
@media(min-width:760px){ .stats{ grid-template-columns:repeat(4,1fr); } }
.stat{ background:var(--black-2); padding:34px 24px; text-align:center; }
.stat-num{ font-family:var(--mono); font-size:clamp(2rem,4vw,2.8rem); color:var(--gold-bright); display:block; letter-spacing:-.02em; }
.stat-lab{ color:var(--ink-mute); font-size:.84rem; margin-top:8px; display:block; }

.ladder{ background:var(--panel); border:1px solid var(--line-soft); border-radius:22px; padding:clamp(28px,4vw,48px); }
.ladder-head{ font-family:var(--serif); font-size:1.5rem; color:var(--gold-pale); margin-bottom:24px; }
.ladder-list{ list-style:none; display:grid; gap:14px; grid-template-columns:1fr; }
@media(min-width:700px){ .ladder-list{ grid-template-columns:1fr 1fr; gap:14px 40px; } }
.ladder-list li{ color:var(--ink-soft); font-size:.98rem; padding-left:8px; border-left:2px solid var(--line); }
.ladder-list b{ color:var(--gold-bright); font-family:var(--mono); font-size:.85rem; margin-right:10px; }
.ladder-note{ margin-top:26px; color:var(--ink-mute); font-style:italic; font-family:var(--serif); font-size:1.1rem; }
.tech-founder{ margin-top:40px; max-width:64ch; color:var(--ink-soft); font-size:1rem; line-height:1.6; border-left:2px solid var(--line); padding-left:18px; }
.tech-founder strong{ color:var(--gold-bright); font-weight:500; }

/* ============ PLATFORM / BEADED TECHNOLOGY ============ */
.platform{ background:linear-gradient(180deg, var(--black-2), var(--black)); }
.platform-title{ font-size:clamp(2.2rem,5vw,3.6rem); margin-bottom:20px; }
.platform-lede{ color:var(--ink-soft); max-width:64ch; margin-bottom:54px; font-size:1.1rem; }
.platform-lede strong{ color:var(--gold-pale); font-weight:500; }
.plat-grid{ display:grid; gap:22px; grid-template-columns:1fr; }
@media(min-width:760px){ .plat-grid{ grid-template-columns:repeat(3,1fr); } }
.plat-card{ position:relative; display:flex; flex-direction:column; align-items:flex-start;
  background:linear-gradient(170deg, var(--panel), var(--black-2)); border:1px solid var(--line-soft);
  border-radius:22px; padding:34px 30px; transition:.5s var(--ease); overflow:hidden; }
.plat-card:hover{ border-color:var(--line); transform:translateY(-6px); box-shadow:0 30px 70px -40px rgba(201,160,78,.4); }
.plat-no{ font-family:var(--mono); font-size:.78rem; letter-spacing:.12em; color:var(--gold); }
.plat-card h3{ font-size:1.5rem; margin:14px 0 12px; }
.plat-card p{ color:var(--ink-soft); font-size:.98rem; margin-bottom:22px; }
.plat-tag{ margin-top:auto; font-size:.66rem; letter-spacing:.22em; text-transform:uppercase; color:var(--gold);
  border:1px solid var(--line); border-radius:100px; padding:.4em .95em; }
.platform-foot{ margin-top:48px; text-align:center; font-family:var(--serif); font-style:italic;
  font-size:clamp(1.2rem,2.4vw,1.5rem); color:var(--gold-pale); }

/* ============ POSITION MAP ============ */
.position{ background:var(--black-2); }
.position-title{ font-size:clamp(2rem,4.6vw,3.4rem); margin-bottom:46px; }
.map{ position:relative; aspect-ratio:16/10; max-width:820px; margin:0 auto; border:1px solid var(--line-soft); border-radius:20px;
  background:
    linear-gradient(transparent 49.6%, var(--line-soft) 49.6%, var(--line-soft) 50.4%, transparent 50.4%),
    linear-gradient(90deg, transparent 49.6%, var(--line-soft) 49.6%, var(--line-soft) 50.4%, transparent 50.4%),
    radial-gradient(circle at 88% 12%, rgba(201,160,78,.10), transparent 50%);
}
.map-axes span{ position:absolute; font-size:.72rem; letter-spacing:.14em; text-transform:uppercase; color:var(--ink-mute); }
.ax-y-top{ top:12px; left:50%; transform:translateX(-50%); }
.ax-y-bot{ bottom:12px; left:50%; transform:translateX(-50%); }
.ax-x-left{ left:14px; top:50%; transform:translateY(-50%) rotate(-90deg); transform-origin:left; }
.ax-x-right{ right:14px; top:50%; transform:translateY(-50%) rotate(90deg); transform-origin:right; }
.map-plot{ position:absolute; inset:0; }
.dot{ position:absolute; transform:translate(-50%,50%); text-align:center; }
.dot i{ display:block; width:13px; height:13px; border-radius:50%; margin:0 auto 7px; background:var(--ink-mute); }
.dot span{ font-size:.8rem; color:var(--ink-soft); white-space:nowrap; }
.dot.us i{ width:20px; height:20px; background:radial-gradient(circle,var(--gold-bright),var(--gold-deep)); box-shadow:0 0 24px var(--gold); animation:usPulse 2.4s var(--ease) infinite; }
.dot.us span{ color:var(--gold-bright); font-weight:500; letter-spacing:.04em; }
@keyframes usPulse{ 0%,100%{ box-shadow:0 0 18px var(--gold);} 50%{ box-shadow:0 0 34px var(--gold-bright);} }
.position-foot{ color:var(--ink-soft); max-width:64ch; margin:46px auto 0; text-align:center; font-size:1.05rem; }

/* ============ VISION / FOOTER ============ */
.vision{ position:relative; padding:clamp(110px,16vw,200px) 0 0; text-align:center; overflow:hidden; background:var(--black); }
.vision-glow{ position:absolute; top:-10%; left:50%; transform:translateX(-50%); width:900px; height:600px; max-width:140vw;
  background:radial-gradient(ellipse at center, rgba(201,160,78,.18), transparent 62%); filter:blur(20px); }
.vision-wrap{ position:relative; z-index:2; max-width:820px; }
.vision-logo{ width:104px; height:auto; margin:0 auto 32px; display:block; filter:drop-shadow(0 10px 34px rgba(201,160,78,.38)); }
.vision-title{ font-size:clamp(2.2rem,5.4vw,4rem); margin-bottom:26px; }
.vision-sub{ color:var(--ink-soft); font-size:1.15rem; max-width:54ch; margin:0 auto 40px; }
/* founding-circle callout */
.founding{ max-width:560px; margin:0 auto 30px; padding:22px 26px; border:1px solid var(--line); border-radius:18px;
  background:linear-gradient(160deg, rgba(201,160,78,.09), var(--panel)); text-align:left;
  box-shadow:0 24px 70px -44px rgba(201,160,78,.5); }
.founding-kicker{ font-size:.72rem; letter-spacing:.26em; text-transform:uppercase; color:var(--gold); margin-bottom:10px; }
.founding-copy{ color:var(--ink-soft); font-size:1rem; line-height:1.62; }
.founding-copy strong{ color:var(--gold-pale); font-weight:500; }

/* join form (stacked: intent · row · note) */
.join-form{ display:flex; flex-direction:column; align-items:center; gap:16px; max-width:480px; margin:0 auto; }
.join-intent{ display:inline-flex; gap:6px; padding:5px; border:1px solid var(--line-soft); border-radius:100px; background:var(--panel); }
.intent-pill{ position:relative; display:inline-flex; align-items:center; gap:6px; padding:.5em 1.15em; border-radius:100px;
  font-size:.82rem; color:var(--ink-soft); cursor:pointer; transition:.3s var(--ease); }
.intent-pill input{ position:absolute; opacity:0; width:0; height:0; }
.intent-pill.is-on{ background:linear-gradient(120deg,var(--gold-deep),var(--gold-bright)); color:#1a1407; font-weight:500; }
.intent-pill:not(.is-on):hover{ color:var(--gold-bright); }
.join-row{ display:flex; gap:10px; justify-content:center; flex-wrap:wrap; width:100%; }
.join-row input{ flex:1 1 240px; background:var(--panel); border:1px solid var(--line); border-radius:100px; padding:.95em 1.4em;
  color:var(--ink); font-family:var(--sans); font-size:.92rem; transition:border-color .3s; }
.join-row input:focus{ outline:none; border-color:var(--gold); }
.join-row input:focus-visible{ outline:2px solid var(--gold-bright); outline-offset:2px; }
.join-row input::placeholder{ color:var(--ink-mute); }
.btn[disabled]{ opacity:.55; cursor:default; transform:none; box-shadow:none; }
.join-note{ color:var(--ink-mute); font-size:.8rem; }
.join-note a{ color:var(--gold); border-bottom:1px solid var(--line); }
.join-note a:hover{ color:var(--gold-bright); }
.join-status{ margin-top:18px; color:var(--gold-bright); font-size:.92rem; min-height:1.2em; font-style:italic; font-family:var(--serif); }
.join-status.is-error{ color:#f0a36b; }

/* FAQ */
.faq-wrap{ position:relative; z-index:2; max-width:760px; margin:clamp(60px,9vw,104px) auto 0; }
.faq-title{ font-family:var(--serif); font-size:1.8rem; color:var(--gold-pale); text-align:center; margin-bottom:26px; }
.faq-list{ display:grid; gap:12px; }
.faq-item{ border:1px solid var(--line-soft); border-radius:14px; background:var(--panel); padding:0 22px; transition:border-color .3s; text-align:left; }
.faq-item[open]{ border-color:var(--line); }
.faq-item summary{ list-style:none; cursor:pointer; padding:18px 0; font-size:1.05rem; color:var(--ink);
  display:flex; align-items:center; justify-content:space-between; gap:16px; }
.faq-item summary::-webkit-details-marker{ display:none; }
.faq-item summary::after{ content:"+"; color:var(--gold); font-size:1.4rem; line-height:1; transition:transform .3s; flex:0 0 auto; }
.faq-item[open] summary::after{ transform:rotate(45deg); }
.faq-item p{ color:var(--ink-soft); font-size:.98rem; line-height:1.62; padding:0 0 20px; max-width:66ch; }
.faq-item a{ color:var(--gold); border-bottom:1px solid var(--line); }
.faq-item a:hover{ color:var(--gold-bright); }

.footer{ margin-top:clamp(80px,12vw,140px); border-top:1px solid var(--line-soft); padding:40px 0; }
.footer-row{ display:flex; flex-wrap:wrap; gap:14px 30px; align-items:center; justify-content:center; text-align:center; }
.footer-tag{ font-family:var(--serif); font-style:italic; color:var(--gold-pale); }
.footer-meta{ color:var(--ink-mute); font-size:.82rem; flex-basis:100%; }

/* ============ responsive nav + mobile menu ============ */
.nav-right{ display:flex; align-items:center; gap:12px; }
.nav-link-cta{ display:none; }            /* mobile-only CTA inside the dropdown */
.nav-burger{ display:none; }              /* desktop: no burger */

@media(max-width:820px){
  .nav-burger{
    display:inline-flex; flex-direction:column; justify-content:center; gap:5px;
    width:44px; height:44px; border:1px solid var(--line); border-radius:12px;
  }
  .nav-burger span{ display:block; width:18px; height:1.6px; margin:0 auto; background:var(--gold-bright);
    transition:transform .3s var(--ease), opacity .2s var(--ease); }
  .nav-burger[aria-expanded="true"] span:nth-child(1){ transform:translateY(6.6px) rotate(45deg); }
  .nav-burger[aria-expanded="true"] span:nth-child(2){ opacity:0; }
  .nav-burger[aria-expanded="true"] span:nth-child(3){ transform:translateY(-6.6px) rotate(-45deg); }

  .nav-links{
    position:absolute; top:100%; left:0; right:0; flex-direction:column; gap:0;
    padding:6px clamp(20px,5vw,46px) 18px;
    background:rgba(7,7,8,.97); backdrop-filter:blur(18px) saturate(140%);
    border-bottom:1px solid var(--line-soft);
    transform:translateY(-10px); opacity:0; visibility:hidden; pointer-events:none;
    transition:transform .3s var(--ease), opacity .3s var(--ease), visibility .3s;
  }
  .nav.menu-open .nav-links{ transform:none; opacity:1; visibility:visible; pointer-events:auto; }
  .nav-links a{ padding:15px 2px; border-bottom:1px solid var(--line-soft); font-size:1.02rem; }
  .nav-links a:last-child{ border-bottom:none; }
  .nav-links a::after{ display:none; }
  .nav-link-cta{ display:block; color:var(--gold-bright) !important; font-weight:500; }
}
@media(max-width:520px){
  .nav-cta{ display:none; }
  .wrap{ padding:0 20px; }
}

/* ============================================================
   v2 REDESIGN — appended components
   ============================================================ */
/* ----- CAROUSEL (Circle Mode) ----- */
/* ======================================================================
   M'AKOMA — CIRCLE MODE CAROUSEL  (all classes prefixed .car-)
   Uses global brand vars: --black --panel --gold --gold-bright --ink etc.
   ====================================================================== */

.car-section{
  position:relative;
  padding:clamp(4rem,10vw,8rem) 1.25rem clamp(4.5rem,10vw,8rem);
  overflow:hidden;
}
.car-wrap{
  max-width:760px;
  margin:0 auto;
  display:flex;
  flex-direction:column;
  align-items:center;
  text-align:center;
}

/* ---- heading ---- */
.car-head{ margin-bottom:clamp(1.5rem,4vw,2.75rem); }
.car-eyebrow{
  font-family:var(--sans);
  font-size:.74rem;
  letter-spacing:.32em;
  text-transform:uppercase;
  color:var(--gold);
  margin:0 0 .9rem;
}
.car-headline{
  font-family:var(--serif);
  font-weight:500;
  font-size:clamp(1.7rem,4.4vw,2.7rem);
  line-height:1.12;
  color:var(--ink);
  margin:0;
  letter-spacing:.005em;
}

/* ---- identity (name + presence pill) ---- */
.car-identity{
  display:flex;
  flex-direction:column;
  align-items:center;
  gap:.6rem;
  min-height:4.6rem;
  margin-bottom:.25rem;
}
.car-name{
  font-family:var(--serif);
  font-weight:500;
  font-size:clamp(2rem,6vw,3.1rem);
  line-height:1;
  color:var(--gold-pale);
  margin:0;
  transition:opacity .45s var(--ease), transform .45s var(--ease);
}
.car-presence{
  display:inline-flex;
  align-items:center;
  gap:.55rem;
  padding:.4rem .9rem .4rem .7rem;
  border:1px solid var(--line);
  border-radius:999px;
  background:rgba(255,255,255,.012);
  color:var(--ink-soft);
  font-family:var(--sans);
  font-size:.8rem;
  letter-spacing:.04em;
  cursor:pointer;
  transition:border-color .3s var(--ease), background .3s var(--ease), color .3s var(--ease);
}
.car-presence:hover{ border-color:rgba(201,160,78,.32); color:var(--ink); }
.car-presence-dot{
  width:.62rem; height:.62rem; border-radius:50%;
  background:var(--car-presence-color,#B77AF4);
  box-shadow:0 0 10px 1px var(--car-presence-color,#B77AF4);
  transition:background .4s var(--ease), box-shadow .4s var(--ease);
}

/* ---- stage / cord / track ---- */
.car-stage{
  position:relative;
  width:100%;
  height:clamp(190px,34vw,250px);
  margin:clamp(.5rem,2vw,1.25rem) 0 clamp(1rem,3vw,1.75rem);
  display:flex;
  align-items:center;
  justify-content:center;
  touch-action:pan-y;
  -webkit-user-select:none; user-select:none;
}
.car-cord{
  position:absolute; inset:0;
  width:100%; height:100%;
  z-index:1;
  pointer-events:none;
  opacity:.9;
}
.car-track{
  position:relative;
  list-style:none;
  margin:0; padding:0;
  width:100%; height:100%;
  z-index:3;
}

/* focal glow halo behind centre bead */
.car-focusglow{
  position:absolute;
  top:50%; left:50%;
  width:clamp(180px,30vw,230px);
  height:clamp(180px,30vw,230px);
  transform:translate(-50%,-50%);
  border-radius:50%;
  z-index:2;
  pointer-events:none;
  background:radial-gradient(circle, var(--car-presence-color,#B77AF4) 0%, transparent 62%);
  opacity:.16;
  filter:blur(8px);
  transition:opacity .5s var(--ease), background .5s var(--ease);
}

/* ---- a single bead ---- */
.car-bead{
  position:absolute;
  top:50%; left:50%;
  width:clamp(78px,15vw,116px);
  aspect-ratio:1;
  margin:0; padding:0;
  border:0; background:transparent;
  cursor:pointer;
  transform:translate(-50%,-50%) translateX(var(--car-x,0)) translateY(var(--car-y,0)) scale(var(--car-scale,.6));
  opacity:var(--car-op,.4);
  transition:transform .5s var(--ease), opacity .5s var(--ease), filter .5s var(--ease);
  will-change:transform,opacity;
  -webkit-tap-highlight-color:transparent;
}
.car-bead-inner{
  position:relative;
  width:100%; height:100%;
  display:block;
}
.car-bead-glow,
.car-bead-img,
.car-bead-avatar{
  position:absolute; inset:0;
  width:100%; height:100%;
  object-fit:contain;
  pointer-events:none;
}
/* coloured glow layer — tinted to the live presence colour via blend */
.car-bead-glow{
  opacity:0;
  transition:opacity .5s var(--ease);
  filter:drop-shadow(0 0 14px var(--car-presence-color,#B77AF4));
}
.car-bead-img{
  filter:drop-shadow(0 14px 22px rgba(0,0,0,.55));
}
/* avatar peeks above the bead like a little portrait */
.car-bead-avatar{
  inset:auto 0 56% 0;
  height:58%;
  object-fit:contain;
  opacity:0;
  transform:translateY(6px);
  transition:opacity .5s var(--ease), transform .5s var(--ease);
  filter:drop-shadow(0 6px 12px rgba(0,0,0,.5));
}
.car-bead.is-focused{ z-index:5; }
.car-bead.is-focused .car-bead-glow{ opacity:.9; }
.car-bead.is-focused .car-bead-avatar{ opacity:1; transform:translateY(0); }

/* echo: held-down recording state */
.car-bead.is-echoing .car-bead-glow{ opacity:1; }
.car-bead.is-echoing{ filter:brightness(1.18); }

/* pulse ripple ring */
.car-ripple{
  position:absolute;
  top:50%; left:50%;
  width:clamp(78px,15vw,116px);
  aspect-ratio:1;
  border-radius:50%;
  transform:translate(-50%,-50%) scale(.55);
  border:2px solid var(--car-presence-color,#B77AF4);
  opacity:0;
  z-index:4;
  pointer-events:none;
}
.car-ripple.is-go{ animation:car-ripple .8s var(--ease) forwards; }
@keyframes car-ripple{
  0%{ transform:translate(-50%,-50%) scale(.55); opacity:.7; }
  100%{ transform:translate(-50%,-50%) scale(1.9); opacity:0; }
}
/* quick scale pop on focused bead */
.car-bead.is-popping{ animation:car-pop .42s var(--ease); }
@keyframes car-pop{
  0%{ transform:translate(-50%,-50%) translateX(var(--car-x,0)) scale(var(--car-scale,1)); }
  45%{ transform:translate(-50%,-50%) translateX(var(--car-x,0)) scale(calc(var(--car-scale,1) * 1.09)); }
  100%{ transform:translate(-50%,-50%) translateX(var(--car-x,0)) scale(var(--car-scale,1)); }
}

/* echo waveform ring (animated stroke around focused bead while holding) */
.car-wave{
  position:absolute;
  top:50%; left:50%;
  width:clamp(96px,18vw,140px);
  aspect-ratio:1;
  transform:translate(-50%,-50%);
  z-index:4;
  pointer-events:none;
  opacity:0;
  transition:opacity .25s var(--ease);
}
.car-wave.is-on{ opacity:1; }
.car-wave circle{
  fill:none;
  stroke:var(--car-presence-color,#B77AF4);
  stroke-width:2;
  stroke-linecap:round;
  transform-origin:center;
  animation:car-wave-spin 2.4s linear infinite;
}
@keyframes car-wave-spin{ to{ transform:rotate(360deg); } }

/* ---- meaning block ---- */
.car-meaning{
  min-height:6.2rem;
  margin-bottom:clamp(1.25rem,3vw,1.75rem);
  max-width:30rem;
}
.car-symbolname{
  font-family:var(--sans);
  font-size:.72rem;
  letter-spacing:.28em;
  text-transform:uppercase;
  color:var(--gold);
  margin:0 0 .55rem;
  transition:opacity .4s var(--ease);
}
.car-meaningline{
  font-family:var(--serif);
  font-style:italic;
  font-size:clamp(1.05rem,2.6vw,1.4rem);
  line-height:1.4;
  color:var(--ink);
  margin:0 0 .5rem;
  transition:opacity .4s var(--ease);
}
.car-phrase{
  font-family:var(--sans);
  font-size:.82rem;
  letter-spacing:.06em;
  color:var(--ink-mute);
  margin:0;
  transition:opacity .4s var(--ease);
}
.car-fading .car-name,
.car-fading .car-symbolname,
.car-fading .car-meaningline,
.car-fading .car-phrase{ opacity:0; }

/* ---- dot indicators ---- */
.car-dots{
  display:flex;
  align-items:center;
  justify-content:center;
  gap:.55rem;
  margin-bottom:clamp(2rem,5vw,2.75rem);
}
.car-dot{
  width:7px; height:7px;
  padding:0; border:0;
  border-radius:50%;
  background:rgba(237,231,218,.22);
  cursor:pointer;
  transition:background .3s var(--ease), transform .3s var(--ease), width .3s var(--ease);
}
.car-dot:hover{ background:rgba(237,231,218,.42); }
.car-dot.is-active{
  width:20px;
  border-radius:999px;
  background:var(--gold);
}

/* ---- action buttons ---- */
.car-actions{
  display:flex;
  flex-wrap:wrap;
  align-items:stretch;
  justify-content:center;
  gap:.75rem;
  width:100%;
}
.car-btn{
  flex:1 1 9rem;
  max-width:12rem;
  display:flex;
  flex-direction:column;
  align-items:center;
  gap:.3rem;
  padding:.95rem 1rem 1.05rem;
  border:1px solid var(--line);
  border-radius:14px;
  background:linear-gradient(180deg, rgba(255,255,255,.02), rgba(255,255,255,0));
  color:var(--ink);
  cursor:pointer;
  transition:border-color .3s var(--ease), background .3s var(--ease), transform .2s var(--ease);
  -webkit-tap-highlight-color:transparent;
}
.car-btn:hover{
  border-color:rgba(201,160,78,.4);
  background:linear-gradient(180deg, rgba(201,160,78,.06), rgba(201,160,78,.01));
}
.car-btn:active{ transform:translateY(1px); }
.car-btn.is-active{
  border-color:var(--gold);
  background:linear-gradient(180deg, rgba(201,160,78,.12), rgba(201,160,78,.02));
}
.car-btn-label{
  font-family:var(--serif);
  font-weight:500;
  font-size:1.15rem;
  color:var(--gold-pale);
  letter-spacing:.01em;
}
.car-btn-hint{
  font-family:var(--sans);
  font-size:.7rem;
  letter-spacing:.05em;
  color:var(--ink-mute);
}
.car-btn:focus-visible,
.car-presence:focus-visible,
.car-dot:focus-visible,
.car-bead:focus-visible{
  outline:1px solid var(--gold-bright);
  outline-offset:3px;
  border-radius:8px;
}

@media (max-width:480px){
  .car-btn-hint{ display:none; }
  .car-btn{ flex-direction:row; gap:.4rem; padding:.8rem 1rem; }
}

@media (prefers-reduced-motion: reduce){
  .car-bead,.car-name,.car-meaningline,.car-symbolname,.car-phrase,
  .car-presence-dot,.car-focusglow{ transition-duration:.001ms !important; }
  .car-ripple.is-go,.car-bead.is-popping,.car-wave circle{ animation:none !important; }
}

/* ----- POSITIONING (Where we live, 2D→3D) ----- */
/* ============================================================
   M'AKOMA — "Where we live"  (prefix: wl-)
   2D -> 3D presence-axis stage. Uses global brand variables.
   ============================================================ */

.wl-section{
  position:relative;
  padding:clamp(5rem,12vh,9rem) 1.25rem clamp(6rem,14vh,10rem);
  background:
    radial-gradient(120% 80% at 50% 0%, rgba(201,160,78,.05), transparent 60%),
    var(--black);
  color:var(--ink);
  overflow:hidden;
}
.wl-wrap{
  max-width:1040px;
  margin:0 auto;
  display:flex;
  flex-direction:column;
  align-items:center;
}

/* ---- eyebrow ---- */
.wl-eyebrow{
  margin:0 0 clamp(2.5rem,6vh,4.5rem);
  font-family:var(--sans);
  font-size:.74rem;
  letter-spacing:.32em;
  text-transform:uppercase;
  color:var(--gold);
}

/* ---- stage: the 3D viewport ---- */
.wl-stage{
  position:relative;
  width:min(92vw,820px);
  height:clamp(360px,52vh,560px);
  perspective:1200px;
  perspective-origin:50% 42%;
}
.wl-scene{
  position:absolute;
  inset:0;
  transform-style:preserve-3d;
}

/* The ground plane. Stage 1 = flat (facing viewer). Stage 2/3 = tilted.
   JS sets --tilt (deg) and --rise via the data-stage tweener. */
.wl-plane{
  --tilt:0deg;
  position:absolute;
  left:50%; top:50%;
  width:min(86vw,720px);
  height:min(60vw,420px);
  margin-left:calc(min(86vw,720px) / -2);
  margin-top:calc(min(60vw,420px) / -2);
  transform-style:preserve-3d;
  transform:translateZ(0) rotateX(var(--tilt));
  transition:transform 1.1s var(--ease);
}

/* grid drawn on the plane surface */
.wl-grid{
  position:absolute; inset:0;
  border:1px solid var(--line);
  border-radius:6px;
  background:
    linear-gradient(var(--line-soft) 1px,transparent 1px) 0 0/100% 12.5%,
    linear-gradient(90deg,var(--line-soft) 1px,transparent 1px) 0 0/12.5% 100%,
    radial-gradient(120% 120% at 50% 30%, rgba(201,160,78,.04), transparent 70%);
  box-shadow:inset 0 0 60px rgba(0,0,0,.5);
  opacity:.9;
}

/* vertical presence axis — sits at back-left of the plane, stands UP off it */
.wl-axis{
  position:absolute;
  left:6%; bottom:8%;
  width:1px; height:0;             /* height grown by JS via --axis */
  height:var(--axis,0px);
  transform-origin:bottom center;
  transform:rotateX(calc(-1 * var(--tilt))) translateZ(.5px);
  background:linear-gradient(to top,var(--gold-deep),rgba(201,160,78,0));
  opacity:0;
  transition:opacity .8s var(--ease);
}
.wl-axis-tick{
  position:absolute; top:-3px; left:-2px;
  width:5px; height:5px; border-radius:50%;
  background:var(--gold-bright);
  box-shadow:0 0 8px rgba(232,197,122,.7);
}
.wl-axis-label{
  position:absolute; top:-1.55rem; left:7px;
  font-family:var(--sans);
  font-size:.6rem; letter-spacing:.26em; text-transform:uppercase;
  color:var(--ink-mute);
  white-space:nowrap;
}
.wl-stage[data-stage="2"] .wl-axis,
.wl-stage[data-stage="3"] .wl-axis{ opacity:1; }

/* ---- nodes ---- */
.wl-nodes{ position:absolute; inset:0; transform-style:preserve-3d; }

.wl-node{
  --lift:0px;                       /* vertical presence, set by JS */
  position:absolute;
  left:var(--nx,50%); top:var(--ny,50%);
  transform-style:preserve-3d;
  /* lift the node UP off the plane along its local -Y/Z; counter-rotate so
     the dot+label always face the camera */
  transform:translate(-50%,-50%) translateZ(var(--lift)) rotateX(calc(-1 * var(--tilt)));
  transition:transform 1.1s var(--ease);
  background:none; border:0; padding:0; margin:0;
  cursor:pointer;
  font:inherit; color:inherit;
}
.wl-node:focus-visible{ outline:none; }
.wl-node:focus-visible .wl-dot{
  box-shadow:0 0 0 3px rgba(201,160,78,.45), 0 0 14px rgba(232,197,122,.5);
}

/* the point on the plane */
.wl-dot{
  display:block;
  width:9px; height:9px; border-radius:50%;
  background:var(--ink-soft);
  box-shadow:0 0 0 4px rgba(11,11,13,.6);
  transition:background .6s var(--ease), box-shadow .6s var(--ease), transform .6s var(--ease);
}

/* the dropped stem that visually anchors a lifted node to the plane.
   It hangs DOWN to the surface; only meaningful once tilted. */
.wl-stem{
  position:absolute;
  left:50%; top:50%;
  width:1px;
  height:var(--lift);
  transform:translate(-50%,0) rotateX(calc(var(--tilt))); /* lay back toward plane */
  transform-origin:top center;
  background:linear-gradient(to bottom,rgba(201,160,78,.45),rgba(201,160,78,0));
  opacity:0;
  transition:opacity .7s var(--ease);
}
.wl-stage[data-stage="2"] .wl-stem,
.wl-stage[data-stage="3"] .wl-stem{ opacity:.65; }

/* label */
.wl-label{
  position:absolute;
  left:50%; top:14px;
  transform:translateX(-50%);
  font-family:var(--sans);
  font-size:.66rem; letter-spacing:.12em;
  color:var(--ink-soft);
  white-space:nowrap;
  text-shadow:0 1px 8px rgba(0,0,0,.8);
  transition:color .6s var(--ease);
}

/* flat / screen-bound nodes read as muted */
.wl-node--hub .wl-dot{
  width:13px; height:13px;
  background:radial-gradient(circle at 38% 34%, var(--gold-pale), var(--gold) 60%, var(--gold-deep));
  box-shadow:0 0 0 4px rgba(11,11,13,.6), 0 0 16px rgba(201,160,78,.5);
}
.wl-node--hub .wl-label{ color:var(--ink); }

/* ---- M'AKOMA: a short STRING of distinct beads ---- */
.wl-node--beads .wl-label--apex{
  top:18px;
  font-size:.7rem; letter-spacing:.18em;
  color:var(--gold-bright);
  text-shadow:0 1px 10px rgba(0,0,0,.9), 0 0 18px rgba(201,160,78,.35);
}
.wl-string{
  position:relative;
  display:flex; align-items:center; gap:5px;
  /* in flat stage it reads as a single cluster; spacing animates open */
}
.wl-cord{
  position:absolute;
  left:3px; right:3px; top:50%;
  height:1px;
  transform:translateY(-50%);
  background:linear-gradient(90deg,rgba(201,160,78,0),var(--gold-deep) 18%,var(--gold-deep) 82%,rgba(201,160,78,0));
  opacity:0;
  transition:opacity .7s var(--ease) .15s;
}
.wl-bead{
  position:relative; z-index:1;
  width:9px; height:9px; border-radius:50%;
  background:radial-gradient(circle at 36% 32%, var(--gold-pale), var(--gold) 58%, var(--gold-deep));
  box-shadow:0 0 0 3px rgba(11,11,13,.55), 0 0 9px rgba(201,160,78,.5);
  /* beads collapsed onto each other until stage 3 */
  margin-left:-9px;
  transition:margin-left .8s var(--ease);
}
.wl-bead:first-child{ margin-left:0; }

/* center bead slightly larger — the apex glow */
.wl-node--beads .wl-dot{ display:none; }

/* STAGE 3: open the string + emphasize the contrast */
.wl-stage[data-stage="3"] .wl-bead{ margin-left:0; }
.wl-stage[data-stage="3"] .wl-cord{ opacity:1; }
.wl-stage[data-stage="3"] .wl-node--beads{ z-index:5; }
.wl-stage[data-stage="3"] .wl-node--beads .wl-bead{
  box-shadow:0 0 0 3px rgba(11,11,13,.55), 0 0 12px rgba(232,197,122,.65);
}
/* in stage 3, let the screen-bound crowd recede */
.wl-stage[data-stage="3"] .wl-node--flat{ opacity:.45; }
.wl-node--flat{ transition:transform 1.1s var(--ease), opacity .8s var(--ease); }

/* ---- progress / stage controls ---- */
.wl-steps{
  display:flex; gap:.7rem;
  margin-top:clamp(2.25rem,6vh,3.75rem);
}
.wl-step{
  width:30px; height:3px; border-radius:2px;
  background:var(--line);
  border:0; padding:0; cursor:pointer;
  transition:background .5s var(--ease), width .5s var(--ease);
}
.wl-step:hover{ background:rgba(201,160,78,.4); }
.wl-step.is-on{ background:var(--gold); width:44px; }
.wl-step:focus-visible{ outline:2px solid var(--gold); outline-offset:3px; }

/* ---- reduced motion: jump straight to the tilted 3D end-state ---- */
@media (prefers-reduced-motion: reduce){
  .wl-plane,.wl-node,.wl-stem,.wl-axis,.wl-bead,.wl-cord,.wl-dot,.wl-node--flat{
    transition:none !important;
  }
}

/* ----- INFOGRAPHICS ----- */
  /* ---- shared infographic frame (namespaced ig-) ---- */
  .ig-fig{
    margin:0;
    width:100%;
    max-width:760px;
  }
  .ig-fig svg{ width:100%; height:auto; display:block; }

  .ig-cap{
    font-family:"JetBrains Mono",monospace;
    font-size:.62rem;
    letter-spacing:.18em;
    text-transform:uppercase;
    fill:#9a9285;
  }
  .ig-label{
    font-family:"Cormorant Garamond",Georgia,serif;
    font-weight:500;
    fill:#f1e6cb;
  }
  .ig-num{
    font-family:"Cormorant Garamond",Georgia,serif;
    font-weight:500;
    fill:#e8c57a;
  }

  /* ---- D: live pulse on the current milestone ---- */
  @keyframes ig-pulse{
    0%   { r:7;  opacity:.55; }
    70%  { r:18; opacity:0;   }
    100% { r:18; opacity:0;   }
  }
  @keyframes ig-glow{
    0%,100% { opacity:.9; }
    50%     { opacity:.45; }
  }
  .ig-pulse-ring{
    transform-origin:center;
    animation:ig-pulse 2.6s ease-out infinite;
  }
  .ig-pulse-core{
    animation:ig-glow 2.6s ease-in-out infinite;
  }
  @media (prefers-reduced-motion: reduce){
    .ig-pulse-ring{ animation:none; opacity:0; }
    .ig-pulse-core{ animation:none; opacity:1; }
  }

/* ----- v2: still-photo hero (shown FIRST, before the 3D anatomy) ----- */
.hero-still{ position:relative; height:100svh; min-height:600px; overflow:hidden; display:flex; align-items:flex-end; }
.hero-still-img{ position:absolute; inset:0; width:100%; height:100%; object-fit:cover; object-position:center 42%; z-index:0; }
.hero-still-veil{ position:absolute; inset:0; z-index:1; pointer-events:none;
  background:linear-gradient(180deg, rgba(6,6,7,.5) 0%, transparent 24%, transparent 40%, rgba(6,6,7,.78) 88%, var(--black) 100%); }
.hero-still-inner{ position:relative; z-index:2; padding-bottom:13vh; }
.hero-still .eyebrow{ display:block; margin-bottom:18px; }
.hero-still-title{ font-family:var(--serif); font-weight:500; font-size:clamp(3rem,8vw,6.6rem); line-height:.95; letter-spacing:-.01em; margin-bottom:18px; }
.hero-still-sub{ font-family:var(--serif); font-style:italic; font-size:clamp(1.1rem,1.9vw,1.5rem); color:var(--gold-pale); opacity:.9; max-width:36ch; margin-bottom:30px; }
.hero-still .hero-actions{ display:flex; gap:14px; flex-wrap:wrap; }
.hero-still .scroll-cue{ position:absolute; bottom:26px; left:50%; transform:translateX(-50%); z-index:3; }
/* the 3D bead scroll runs on mobile now; only if it FALLS BACK (no WebGL / reduced-motion / data-saver) do we
   hide the section on small screens, so the poster doesn't duplicate the bracelet shot in the hero above it */
@media(max-width:820px){ #hero.no3d{ display:none; } }

/* ============================================================
   v2 REFINEMENT PASS
   ============================================================ */

/* ----- hero: split (text left, full render right) ----- */
.hero-still{ align-items:center; height:auto; min-height:88svh; padding:104px 0 48px; overflow:visible; }
.hero-split{ display:grid; grid-template-columns:1fr; gap:32px; align-items:center; width:100%; }
@media(min-width:880px){ .hero-split{ grid-template-columns:1.02fr 1.12fr; gap:50px; } }
.hero-copy{ position:relative; z-index:2; }
.hero-copy .eyebrow{ display:block; margin-bottom:18px; }
.hero-shot img{ width:100%; height:auto; display:block; border-radius:16px;
  -webkit-mask-image:radial-gradient(125% 120% at 58% 50%, #000 58%, transparent 100%);
          mask-image:radial-gradient(125% 120% at 58% 50%, #000 58%, transparent 100%); }
@media(max-width:879px){
  .hero-shot{ order:-1; }
  .hero-shot img{ max-height:40vh; width:auto; max-width:100%; margin:0 auto; }
  .hero-still{ min-height:0; padding-top:120px; }
}

/* ----- reachable → present (contacts phone → bracelet, no bg) ----- */
.rp{ display:flex; align-items:center; justify-content:center; gap:clamp(18px,5vw,56px);
  flex-wrap:wrap; max-width:760px; margin:46px auto 38px; }
.rp-side{ display:flex; flex-direction:column; align-items:center; gap:16px; margin:0; }
.rp-side figcaption{ font-family:var(--serif); font-size:1.3rem; color:var(--gold-pale); letter-spacing:.01em; }
.rp-phone{ width:clamp(116px,28vw,158px); }
.rp-phone svg{ width:100%; height:auto; display:block; filter:drop-shadow(0 22px 44px rgba(0,0,0,.55)); }
.rp-arrow{ color:var(--gold); font-size:1.9rem; opacity:.75; }
.rp-bracelet{ display:flex; align-items:center; justify-content:center;
  width:clamp(190px,42vw,270px); padding:14px 0; }
.rp-bead{ width:clamp(46px,9.5vw,66px); height:auto; margin:0 -7px;
  filter:drop-shadow(0 10px 20px rgba(0,0,0,.6)); }
.rp-bead:nth-child(1){ transform:translateY(22px) rotate(-9deg); }
.rp-bead:nth-child(2){ transform:translateY(7px)  rotate(-4deg); }
.rp-bead:nth-child(3){ transform:translateY(0)    scale(1.14); z-index:2; }
.rp-bead:nth-child(4){ transform:translateY(7px)  rotate(4deg); }
.rp-bead:nth-child(5){ transform:translateY(22px) rotate(9deg); }
@media(max-width:560px){ .rp-arrow{ transform:rotate(90deg); } }

/* ===== Why M'AKOMA: phone-of-noise → five pinned people → beads (autoplay, js/why.js) ===== */
.why-stage{ position:relative; width:100%; max-width:480px; height:clamp(470px,74vh,600px); margin:26px auto 0; }

/* the phone */
.wp-phone{ position:absolute; left:50%; top:1%; width:clamp(232px,62vw,268px); aspect-ratio:1 / 2.04;
  transform:translateX(-50%); transform-origin:50% 30%; transition:opacity .9s var(--ease), transform .9s var(--ease); z-index:1; }
.wp-screen{ position:absolute; inset:0; border-radius:36px; background:#0a0a0c; border:1px solid #2a2823;
  box-shadow:0 32px 70px rgba(0,0,0,.6), inset 0 0 0 4px #161518; overflow:hidden; }
.wp-island{ position:absolute; top:11px; left:50%; transform:translateX(-50%); width:62px; height:17px; border-radius:10px; background:#000; z-index:6; }
.wp-bar{ position:absolute; top:10px; left:0; right:0; display:flex; justify-content:space-between; align-items:center; padding:0 22px; font-size:11px; font-weight:600; color:#ece6d8; z-index:5; }
.wp-bar-i{ display:flex; gap:3px; align-items:center; }
.wp-bar-i i{ width:4px; height:9px; border-radius:1px; background:#ece6d8; opacity:.9; }

/* lock screen + notification pile */
.wp-lock{ position:absolute; inset:0; padding:44px 12px 12px; display:flex; flex-direction:column; gap:9px; z-index:2;
  transition:opacity .55s, filter .55s; }
.wp-clock{ text-align:center; color:#fff; margin-bottom:2px; }
.wp-clock .wp-t{ font-size:44px; font-weight:300; letter-spacing:-.02em; line-height:1; }
.wp-clock .wp-d{ font-size:12px; color:#b7b0a1; margin-top:3px; }
.wp-notifs{ display:flex; flex-direction:column; gap:7px; overflow:hidden; }
.wp-notif{ background:rgba(42,40,44,.86); -webkit-backdrop-filter:blur(6px); backdrop-filter:blur(6px); border-radius:14px; padding:8px 12px;
  display:flex; flex-direction:column; gap:1px; color:#ece6d8;
  opacity:0; transform:translateY(-12px) scale(.95); transition:opacity .45s, transform .45s; transition-delay:calc(var(--k) * .12s); }
.wp-notif b{ font-size:10.5px; font-weight:700; }
.wp-notif span{ font-size:10.5px; color:#b3ac9f; }

/* messages view — header + a 3+2 pinned-chats grid (avatars overlay it) + faded threads + search */
.wp-msgs{ position:absolute; inset:0; padding:40px 13px 12px; opacity:0; pointer-events:none; transition:opacity .6s; z-index:1; display:flex; flex-direction:column; }
.wp-msgs-top{ display:flex; align-items:center; justify-content:space-between; margin-bottom:8px; }
.wp-edit{ font-size:12px; color:#cdb06a; }
.wp-mtitle{ font-size:15px; font-weight:700; color:#fff; }
.wp-filter{ display:flex; flex-direction:column; gap:2px; width:23px; height:23px; border-radius:50%; background:#1b1a1e; align-items:center; justify-content:center; }
.wp-filter i{ width:9px; height:1.5px; border-radius:1px; background:#cdb06a; }
.wp-filter i:nth-child(2){ width:6px; } .wp-filter i:nth-child(3){ width:3px; }
.wp-pingrid{ height:172px; flex:0 0 auto; }   /* reserves the grid space; the real avatars are positioned over it */
.wp-threads{ display:flex; flex-direction:column; gap:1px; flex:1 1 auto; }
.wp-thread{ display:flex; align-items:center; gap:9px; padding:5px 2px; opacity:.5; }
.wp-th-av{ width:30px; height:30px; border-radius:50%; background:#2a2830; flex:0 0 auto; }
.wp-th-g{ background:radial-gradient(circle at 35% 32%, #3c3944, #221f27); }
.wp-th-tx{ display:flex; flex-direction:column; gap:1px; min-width:0; }
.wp-th-tx b{ font-size:11px; color:#ece6d8; font-weight:600; }
.wp-th-tx i{ font-size:10px; color:#8a8478; font-style:normal; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; max-width:178px; }
.wp-search{ display:flex; align-items:center; gap:7px; height:30px; border-radius:9px; background:#1b1a1e; color:#8a8478; font-size:12px; padding:0 11px; margin-top:5px; }
.wp-search-mag{ width:11px; height:11px; border:1.6px solid #8a8478; border-radius:50%; position:relative; flex:0 0 auto; }
.wp-search-mag::after{ content:""; position:absolute; right:-3px; bottom:-3px; width:5px; height:1.6px; background:#8a8478; transform:rotate(45deg); border-radius:1px; }

/* the five people overlay — hidden until Messages opens (phase 3), then they lift out */
.wp-people{ position:absolute; inset:0; z-index:4; opacity:0; transition:opacity .55s; }
#whyStage[data-phase="3"] .wp-people, #whyStage[data-phase="4"] .wp-people, #whyStage[data-phase="5"] .wp-people{ opacity:1; }
.wp-person{ position:absolute; width:58px; height:58px; transform:translate(-50%,-50%);
  transition:left 1.05s var(--ease), top 1.05s var(--ease), width 1.05s var(--ease), height 1.05s var(--ease); }
/* pinned 3+2 grid (phase ≤3): row 1 = three across, row 2 = two left-aligned, like the screenshot */
.wp-person:nth-child(1){ left:31%; top:21.5%; }
.wp-person:nth-child(2){ left:50%; top:21.5%; }
.wp-person:nth-child(3){ left:69%; top:21.5%; }
.wp-person:nth-child(4){ left:31%; top:34.5%; }
.wp-person:nth-child(5){ left:50%; top:34.5%; }
.wp-person img{ position:absolute; inset:0; width:100%; height:100%; }
.wp-face{ object-fit:cover; border-radius:50%; box-shadow:0 0 0 1px rgba(255,255,255,.1); opacity:1; transition:opacity .7s; }
.wp-bead{ object-fit:contain; opacity:0; transition:opacity .7s, filter .7s; }
.wp-person b{ position:absolute; left:50%; bottom:-15px; transform:translateX(-50%); font-size:9.5px; font-weight:500; color:#c8c2b4; white-space:nowrap; opacity:0; transition:opacity .5s; }
.wp-udot{ position:absolute; left:calc(50% - 30px); bottom:-13px; width:7px; height:7px; border-radius:50%; background:#3b82f6; opacity:0; transition:opacity .4s; }
.wp-bubble{ position:absolute; left:-8px; top:-26px; width:118px; background:#2c2a30; color:#d7d2c6; font-size:9px; line-height:1.3; padding:5px 8px; border-radius:12px 12px 12px 3px; opacity:0; transition:opacity .4s; z-index:3; pointer-events:none; }

/* caption */
.wp-cap{ position:absolute; left:0; right:0; bottom:0; text-align:center; font-family:var(--serif); font-size:clamp(1.05rem,2.6vw,1.5rem); color:var(--gold-pale); height:1.6em; }
.wp-cap span{ position:absolute; left:0; right:0; transition:opacity .7s; }
.wp-cap-b{ opacity:0; }

/* ---- phase states ---- */
#whyStage[data-phase="1"] .wp-notif, #whyStage[data-phase="2"] .wp-notif{ opacity:1; transform:none; }
#whyStage[data-phase="2"] .wp-notif{ opacity:0; transform:translateX(135%); transition-duration:.5s; transition-delay:calc(var(--k) * .05s); }
#whyStage[data-phase="2"] .wp-lock{ opacity:0; filter:blur(2px); }
#whyStage[data-phase="3"] .wp-lock, #whyStage[data-phase="4"] .wp-lock, #whyStage[data-phase="5"] .wp-lock{ opacity:0; pointer-events:none; }
#whyStage[data-phase="3"] .wp-msgs, #whyStage[data-phase="4"] .wp-msgs{ opacity:1; }
/* peel: each avatar, once "departed", flies to the bracelet arc and cross-fades into its Adinkra bead */
.wp-person.departed{ width:60px; height:60px; left:calc(50% + (var(--i) - 2) * 20.5%); }
.wp-person.departed:nth-child(1){ top:50%; }
.wp-person.departed:nth-child(2){ top:57.5%; }
.wp-person.departed:nth-child(3){ top:60%; }
.wp-person.departed:nth-child(4){ top:57.5%; }
.wp-person.departed:nth-child(5){ top:50%; }
.wp-person.departed .wp-face{ opacity:0; }
.wp-person.departed .wp-bead{ opacity:1; filter:drop-shadow(0 6px 14px rgba(0,0,0,.55)) drop-shadow(0 0 13px color-mix(in srgb, var(--hue) 62%, transparent)); }
#whyStage .wp-person.departed .wp-udot, #whyStage .wp-person.departed .wp-bubble{ opacity:0; }
.wp-person.departed b{ opacity:.85; }
/* names + pinned details appear once Messages is open */
#whyStage[data-phase="3"] .wp-person b{ opacity:.88; }
#whyStage[data-phase="3"] .wp-udot, #whyStage[data-phase="3"] .wp-bubble{ opacity:1; }
#whyStage.cap-b .wp-cap-a{ opacity:0; }
#whyStage.cap-b .wp-cap-b{ opacity:1; }
@media (prefers-reduced-motion: reduce){ .wp-person, .wp-phone, .wp-notif, .wp-lock, .wp-msgs, .wp-cap span{ transition:none !important; } }

/* ===== MERGE: the phone is an AUTOPLAY overlay above the (untouched) carousel, in one centered stage ===== */
.circle-merge{ position:relative; }
.circle-sticky{ position:relative; display:flex; align-items:center; justify-content:center; min-height:660px; padding:24px 16px; }
.circle-merge .car-wrap{ transition:opacity .7s ease; }
.circle-merge #whyStage{ display:none; position:absolute; left:50%; top:50%; transform:translate(-50%,-50%); margin:0; z-index:5; transition:opacity .7s ease; }
.circle-merge.circle-anim #whyStage{ display:block; }
.circle-merge.circle-anim:not(.is-handoff) .car-wrap{ opacity:0; pointer-events:none; }   /* carousel hidden during the phone intro */
.circle-merge.is-handoff #whyStage{ opacity:0; pointer-events:none; }                       /* phone gone, carousel takes over */
#whyStage.phone-out .wp-phone{ opacity:0; }   /* fade the device once the beads have formed, before the carousel reveal */
@media (prefers-reduced-motion: reduce){ .circle-sticky{ min-height:0; } }

/* ----- carousel: avatar in the header (app-style), not on the bead ----- */
.car-avatarwrap{ width:clamp(60px,12vw,78px); height:clamp(60px,12vw,78px); border-radius:50%;
  margin:0 auto 14px; padding:3px; box-sizing:border-box;
  border:1.5px solid color-mix(in srgb, var(--car-presence-color, var(--gold)) 55%, transparent);
  box-shadow:0 0 26px -6px var(--car-presence-color, var(--gold)); transition:border-color .45s, box-shadow .45s; }
.car-avatar{ width:100%; height:100%; border-radius:50%; object-fit:cover; display:block; background:#16151a; }

/* ----- positioning: real icons for the screen-bound options + bigger stage ----- */
.wl-ico{ display:flex; align-items:center; justify-content:center; width:30px; height:30px; margin:0 auto; color:var(--ink-mute); }
.wl-ico svg{ width:24px; height:24px; }
.wl-stage{ min-height:560px; overflow:visible; }
@media(max-width:680px){ .wl-stage{ min-height:440px; } }
/* headroom so the lifted M'AKOMA apex clears the eyebrow */
.wl-stage{ min-height:600px; margin-top:72px; }
@media(max-width:680px){ .wl-stage{ min-height:460px; margin-top:48px; } }

/* ----- v2: logo trace-out (draws itself on scroll) ----- */
.lt-draw{ stroke-dasharray:2000; stroke-dashoffset:2000; }   /* hidden until JS measures real length */
.lt-fill{ opacity:0; }
#logoTrace.vision-logo{ width:clamp(124px,14vw,170px); height:auto; overflow:visible; }
@media (prefers-reduced-motion: reduce){ .lt-draw{ stroke-dashoffset:0 !important; } .lt-fill{ opacity:1 !important; } }

/* ----- v2: real app-logo tiles on the positioning plane ----- */
.wl-logo{ display:flex; align-items:center; justify-content:center; width:38px; height:38px;
  border-radius:10px; box-shadow:0 7px 18px -6px rgba(0,0,0,.75); margin:0 auto; }
.wl-logo img{ width:22px; height:22px; display:block; }

/* ============================================================
   v2 polish round 2
   ============================================================ */

/* the app-logo tiles lie FLAT in the plane (no billboard counter-rotation) */
.wl-node--logo{ transform: translate(-50%,-50%) translateZ(var(--lift)) !important; }

/* M'AKOMA apex = a string of REAL bead renders (not gold balls) */
.wl-node--beads .wl-string{ display:flex; align-items:center; justify-content:center; }
.wl-beadimg{ width:clamp(22px,3vw,30px); height:auto; margin:0 -2px; filter:drop-shadow(0 4px 9px rgba(0,0,0,.55)); }

/* Where we live — quadrant edge labels (mounted on the stage so they DON'T tilt with the plane) */
.wl-edge{ position:absolute; z-index:7; font-family:var(--sans); font-size:.72rem; letter-spacing:.02em; color:var(--ink-soft); white-space:nowrap; pointer-events:none; }
.wl-edge--t{ top:-6px; left:50%; transform:translateX(-50%); }
.wl-edge--b{ bottom:-6px; left:50%; transform:translateX(-50%); }
.wl-edge--l{ left:0; top:50%; transform:translate(calc(-100% - 8px),-50%); }
.wl-edge--r{ right:0; top:50%; transform:translate(calc(100% + 8px),-50%); }
.wl-logo svg{ width:22px; height:22px; display:block; }
@media(max-width:860px){
  .wl-edge{ font-size:.56rem; letter-spacing:0; }
  .wl-edge--l{ left:1px; transform:translateY(-50%); writing-mode:vertical-rl; }
  .wl-edge--r{ right:1px; transform:translateY(-50%); writing-mode:vertical-rl; }
}

/* ===== How it begins — two animated panels (bundle/gift + reach via the app) ===== */
.hib-grid{ display:grid; grid-template-columns:1fr; gap:26px; max-width:940px; margin:42px auto 0; }
@media(min-width:780px){ .hib-grid{ grid-template-columns:1fr 1fr; gap:30px; } }
.hib-panel{ margin:0; background:var(--black-2); border:1px solid var(--line); border-radius:20px; padding:26px 26px 30px; overflow:hidden; }
.hib-scene{ position:relative; height:206px; display:flex; flex-direction:column; align-items:center; justify-content:center; gap:16px; }
.hib-cap{ text-align:left; margin-top:16px; }
.hib-cap h3{ font-family:var(--serif); font-size:1.45rem; font-weight:500; color:var(--ink); margin:0 0 8px; }
.hib-cap p{ color:var(--ink-soft); font-size:1rem; line-height:1.55; margin:0; }
/* mini-bracelet: a gentle arc of bead renders */
.hib-brace{ display:inline-flex; align-items:center; }
.hib-brace img{ width:34px; height:auto; margin:0 -5px; filter:drop-shadow(0 6px 12px rgba(0,0,0,.55)); }
.hib-brace > img:nth-child(1), .hib-brace > img:nth-child(5){ transform:translateY(9px); }
.hib-brace > img:nth-child(2), .hib-brace > img:nth-child(4){ transform:translateY(3px); }
/* panel 1: bundle + gift */
.hib-badge{ font-family:var(--sans); font-size:.66rem; letter-spacing:.16em; text-transform:uppercase; color:var(--gold-pale); border:1px solid rgba(201,160,78,.4); border-radius:20px; padding:5px 13px; }
.hib-pair{ display:flex; gap:22px; align-items:center; }
.hib-note{ font-family:var(--serif); font-style:italic; color:var(--gold-pale); opacity:.85; font-size:1.02rem; }
.hib-brace.b1{ animation:hib-bob 3.4s ease-in-out infinite; }
.hib-brace.b2{ position:relative; animation:hib-bob 3.4s ease-in-out infinite .5s; }
@keyframes hib-bob{ 0%,100%{ transform:translateY(0); } 50%{ transform:translateY(-7px); } }
.hib-spark{ position:absolute; top:-8px; right:-4px; width:10px; height:10px; border-radius:50%; background:var(--gold); box-shadow:0 0 12px 3px rgba(201,160,78,.7); animation:hib-spark 3.4s ease-in-out infinite .5s; }
@keyframes hib-spark{ 0%,40%,100%{ opacity:0; transform:scale(.4); } 60%,82%{ opacity:1; transform:scale(1); } }
/* panel 2: app → glow travels → bracelet bead lights up */
.hib-scene--app{ flex-direction:row; gap:4px; }
.hib-phone{ position:relative; width:82px; flex:0 0 auto; border-radius:14px; overflow:hidden; border:1px solid #2a2823; box-shadow:0 10px 26px rgba(0,0,0,.5); }
.hib-phone img{ width:100%; display:block; }
.hib-tap{ position:absolute; left:50%; top:46%; width:14px; height:14px; margin:-7px 0 0 -7px; border-radius:50%; border:2px solid var(--gold); animation:hib-tap 3s ease-out infinite; }
@keyframes hib-tap{ 0%{ opacity:.9; transform:scale(.3); } 55%,100%{ opacity:0; transform:scale(2.4); } }
.hib-link{ width:104px; height:60px; flex:0 0 auto; }
.hib-link path{ animation:hib-flow 3s linear infinite; }
@keyframes hib-flow{ to{ stroke-dashoffset:-40; } }
.hib-lit{ position:relative; display:inline-block; width:34px; margin:0 -5px; filter:drop-shadow(0 6px 12px rgba(0,0,0,.55)); }
.hib-lit img{ width:34px !important; height:auto; margin:0 !important; display:block; }
.hib-lit .hib-glow{ position:absolute; inset:0; opacity:0; animation:hib-light 3s ease-in-out infinite; }
@keyframes hib-light{ 0%,45%{ opacity:0; } 70%,90%{ opacity:1; } 100%{ opacity:0; } }
@media (prefers-reduced-motion: reduce){ .hib-brace.b1,.hib-brace.b2,.hib-spark,.hib-tap,.hib-link path,.hib-lit .hib-glow{ animation:none !important; } .hib-lit .hib-glow{ opacity:.9; } }

/* theme toggle */
.theme-toggle{ display:inline-flex; align-items:center; justify-content:center; width:38px; height:38px;
  border-radius:50%; border:1px solid var(--line); color:var(--ink-soft); transition:border-color .3s, color .3s; flex:0 0 auto; }
.theme-toggle:hover{ border-color:var(--gold); color:var(--gold-bright); }
.theme-toggle svg{ width:18px; height:18px; }
.theme-toggle .ic-sun{ display:none; }
:root[data-theme="light"] .theme-toggle .ic-moon{ display:none; }
:root[data-theme="light"] .theme-toggle .ic-sun{ display:block; }

/* ===== LIGHT THEME ===== */
:root[data-theme="light"]{
  --black:#f4efe4; --black-2:#ece4d3; --panel:#e8dfcd; --panel-2:#e1d7c2;
  --line:rgba(155,122,54,.34); --line-soft:rgba(40,33,18,.12);
  --gold:#8a6a2c; --gold-bright:#6f5420; --gold-pale:#5b4719; --gold-deep:#9b7a36;
  --ink:#221e16; --ink-soft:#4b4537; --ink-mute:#6e6753;
}
:root[data-theme="light"] body{ background:var(--black); }
:root[data-theme="light"] ::selection{ background:rgba(155,122,54,.28); color:#1a1407; }
:root[data-theme="light"] .grain{ opacity:.03; }
:root[data-theme="light"] .nav.scrolled{ background:rgba(244,239,228,.82); border-bottom-color:var(--line-soft); }
:root[data-theme="light"] .hero3d-sticky{ background:radial-gradient(120% 95% at 50% 38%, #fffaef 0%, #efe6d4 55%, var(--black) 100%); }
:root[data-theme="light"] .hero-still-veil{ background:linear-gradient(180deg, rgba(244,239,228,.5) 0%, transparent 26%, transparent 62%, rgba(244,239,228,.85) 100%); }
:root[data-theme="light"] .vision-glow{ background:radial-gradient(ellipse at center, rgba(155,122,54,.16), transparent 62%); }
:root[data-theme="light"] .btn-gold{ color:#fff; }
:root[data-theme="light"] .hero-shot img{ -webkit-mask-image:none; mask-image:none; box-shadow:0 30px 80px -40px rgba(40,30,10,.4); }
:root[data-theme="light"] .car-bead-img, :root[data-theme="light"] .wl-beadimg, :root[data-theme="light"] .rp-bead{ filter:drop-shadow(0 8px 18px rgba(60,45,15,.3)); }

/* ============================================================
   v2 fix: positioning lift in SCREEN space (no perspective magnification)
   ============================================================ */
/* flat app logos lie ON the plane (no lift, no billboard) */
.wl-node--logo{ transform: translate(-50%,-50%) !important; }
/* risen nodes: face the camera (cancel tilt) then lift straight UP the screen by --lift px,
   so they grow a gap WITHOUT getting closer/bigger */
.wl-node--hub,
.wl-node--beads{ transform: translate(-50%,-50%) rotateX(calc(-1 * var(--tilt))) translateY(calc(-1 * var(--lift))) !important; }
/* the stem now hangs straight down (screen-vertical) from the risen node to its plane spot */
.wl-stem{ transform: translateX(-50%) !important; }
/* keep the bead string compact + a sane size */
.wl-node--beads .wl-string{ gap:0; }
.wl-beadimg{ width:26px !important; margin:0 -3px; }
