/* Atlas - shared styles for both themes
   Each artboard root carries .theme-celestial or .theme-sanctuary.
   All values flow through CSS custom properties so components are theme-agnostic. */

@import url('https://fonts.googleapis.com/css2?family=Cormorant+Garamond:ital,wght@0,300;0,400;0,500;0,600;1,300;1,400&family=EB+Garamond:ital,wght@0,400;0,500;0,600;1,400&family=Inter:wght@300;400;500;600&family=Manrope:wght@300;400;500;600&family=JetBrains+Mono:wght@300;400&display=swap');

.atlas-root {
  width: 100%;
  min-height: 100%;
  font-family: var(--font-body);
  color: var(--text);
  background: var(--bg);
  line-height: 1.55;
  font-size: 16px;
  letter-spacing: 0.005em;
  -webkit-font-smoothing: antialiased;
  position: relative;
  overflow: hidden;
}
.atlas-root * { box-sizing: border-box; }

/* ───── DIRECTION A - CELESTIAL EDITORIAL ───── */
.theme-celestial {
  --bg: #0d1230;
  --bg-alt: #161b3d;
  --bg-soft: #1c2249;
  --card: rgba(255,255,255,0.04);
  --card-hover: rgba(255,255,255,0.07);
  --text: #f3eee0;
  --text-dim: rgba(243,238,224,0.62);
  --text-mute: rgba(243,238,224,0.4);
  --accent: #b5a4d9;
  --accent-2: #d4b788;
  --accent-soft: rgba(181,164,217,0.18);
  --border: rgba(243,238,224,0.1);
  --border-strong: rgba(243,238,224,0.22);
  --orb-1: #6b5fa3;
  --orb-2: #2c3674;
  --orb-3: #b89770;
  --orb-4: #4a3d7a;
  --font-display: 'Cormorant Garamond', Georgia, serif;
  --font-body: 'Inter', system-ui, sans-serif;
  --font-mono: 'JetBrains Mono', ui-monospace, monospace;
}

/* ───── DIRECTION B - DAWN SANCTUARY ───── */
.theme-sanctuary {
  --bg: #f5efe3;
  --bg-alt: #ebe3d2;
  --bg-soft: #f9f4ea;
  --card: rgba(255,255,255,0.55);
  --card-hover: rgba(255,255,255,0.8);
  --text: #1f244a;
  --text-dim: rgba(31,36,74,0.65);
  --text-mute: rgba(31,36,74,0.4);
  --accent: #6b5fa3;
  --accent-2: #b89770;
  --accent-soft: rgba(107,95,163,0.13);
  --border: rgba(31,36,74,0.12);
  --border-strong: rgba(31,36,74,0.25);
  --orb-1: #d6c9ec;
  --orb-2: #f0d4c0;
  --orb-3: #c3b6e0;
  --orb-4: #e8d8c0;
  --font-display: 'EB Garamond', Georgia, serif;
  --font-body: 'Manrope', system-ui, sans-serif;
  --font-mono: 'JetBrains Mono', ui-monospace, monospace;
}

/* ───── Type ───── */
.atlas-root h1, .atlas-root h2, .atlas-root h3 {
  font-family: var(--font-display);
  font-weight: 400;
  letter-spacing: -0.01em;
  line-height: 1.05;
  margin: 0;
  text-wrap: balance;
}
.atlas-root h1 { font-size: clamp(56px, 7.5vw, 112px); }
.atlas-root h2 { font-size: clamp(36px, 4.5vw, 64px); line-height: 1.08; }
.atlas-root h3 { font-size: clamp(24px, 2.4vw, 34px); line-height: 1.15; }
.atlas-root p  { margin: 0; text-wrap: pretty; }
.atlas-root .lede {
  font-family: var(--font-display);
  font-weight: 300;
  font-size: clamp(20px, 2vw, 28px);
  line-height: 1.35;
  color: var(--text);
  font-style: italic;
  letter-spacing: 0;
}
.atlas-root .eyebrow {
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--text-dim);
}
.atlas-root .display-italic { font-style: italic; }
.atlas-root .accent { color: var(--accent); }
.atlas-root .dim { color: var(--text-dim); }

/* lowercase site (matches the Atlas of You voice) */
.atlas-root h1, .atlas-root h2, .atlas-root h3, .atlas-root p, .atlas-root button, .atlas-root a, .atlas-root li {
  text-transform: none;
}

/* ───── Layout ───── */
.atlas-root .wrap { width: 100%; max-width: 1180px; margin: 0 auto; padding: 0 64px; }
.atlas-root section { position: relative; }

/* ───── Nav ───── */
.atlas-nav {
  position: sticky; top: 0; z-index: 50;
  display: flex; align-items: center; justify-content: space-between;
  padding: 20px 64px;
  backdrop-filter: blur(20px);
  -webkit-backdrop-filter: blur(20px);
  background: color-mix(in srgb, var(--bg) 75%, transparent);
  border-bottom: 1px solid var(--border);
}
.atlas-nav .brand {
  font-family: var(--font-display);
  font-size: 22px;
  letter-spacing: -0.01em;
}
.atlas-nav .brand em { font-style: italic; color: var(--accent); }
.atlas-nav ul { display: flex; gap: 32px; list-style: none; padding: 0; margin: 0; }
.atlas-nav a {
  color: var(--text-dim); text-decoration: none; font-size: 13px; letter-spacing: 0.04em;
  transition: color .25s;
}
.atlas-nav a:hover { color: var(--text); }
.atlas-nav .nav-cta {
  background: transparent; border: 1px solid var(--border-strong);
  color: var(--text); padding: 9px 18px; border-radius: 999px;
  font-family: var(--font-body); font-size: 13px; cursor: pointer;
  transition: all .25s;
}
.atlas-nav .nav-cta:hover { background: var(--text); color: var(--bg); }

/* ───── Buttons ───── */
.btn {
  display: inline-flex; align-items: center; gap: 10px;
  padding: 16px 28px;
  font-family: var(--font-body); font-size: 14px; letter-spacing: 0.02em;
  border-radius: 999px; border: 1px solid var(--border-strong);
  background: transparent; color: var(--text);
  cursor: pointer; transition: all .3s ease;
  text-decoration: none;
}
.btn:hover { background: var(--text); color: var(--bg); border-color: var(--text); }
.btn.primary {
  background: var(--text); color: var(--bg); border-color: var(--text);
}
.btn.primary:hover { background: var(--accent); border-color: var(--accent); color: var(--bg); }
.btn.ghost { border-color: var(--border); color: var(--text-dim); }
.btn.ghost:hover { color: var(--text); border-color: var(--border-strong); background: transparent; }
.btn .arrow { transition: transform .3s; }
.btn:hover .arrow { transform: translateX(4px); }

/* ───── Orbs (celestial graphics) ───── */
.orbs { position: absolute; inset: 0; overflow: hidden; pointer-events: none; z-index: 0; }
.orb {
  position: absolute; border-radius: 50%;
  filter: blur(60px); opacity: 0.55;
  animation:
    orbDrift 22s ease-in-out infinite alternate,
    orbGlow 9s ease-in-out infinite;
  will-change: transform, filter, opacity;
}
.theme-sanctuary .orb { opacity: 0.7; filter: blur(80px); }
.orb.a { width: 520px; height: 520px; background: var(--orb-1); top: -120px; left: -100px; }
.orb.b { width: 420px; height: 420px; background: var(--orb-2); top: 30%; right: -120px; animation-delay: -7s, -3s; }
.orb.c { width: 360px; height: 360px; background: var(--orb-3); bottom: -100px; left: 20%; animation-delay: -14s, -6s; }
.orb.d { width: 300px; height: 300px; background: var(--orb-4); top: 50%; left: 40%; animation-delay: -3s, -1s; opacity: 0.3; }
@keyframes orbDrift {
  0%   { transform: translate(0,0) scale(1); }
  50%  { transform: translate(40px,-30px) scale(1.08); }
  100% { transform: translate(-30px,20px) scale(0.95); }
}
@keyframes orbGlow {
  0%, 100% { filter: blur(60px) brightness(1); opacity: 0.45; }
  50%      { filter: blur(90px) brightness(1.3); opacity: 0.75; }
}
.theme-sanctuary .orb { animation-name: orbDrift, orbGlowLight; }
@keyframes orbGlowLight {
  0%, 100% { filter: blur(80px) brightness(1); opacity: 0.55; }
  50%      { filter: blur(110px) brightness(1.15); opacity: 0.85; }
}

/* ───── Hero ───── */
.hero {
  padding: 120px 0 140px;
  position: relative;
  overflow: hidden;
  min-height: 92vh;
  display: flex; align-items: center;
  text-align: center;
}
.hero .wrap { position: relative; z-index: 2; will-change: transform, opacity; }
.hero .eyebrow { display: block; }
.hero h1 {
  text-align: center;
  font-size: clamp(48px, 6.4vw, 96px);
  line-height: 1.08;
}
.hero h1 .hero-line {
  display: block;
}
.hero h1 .hero-line.iam {
  font-style: italic;
  color: var(--accent);
  margin-top: 0.06em;
}
.hero .hero-sub {
  margin-left: auto;
  margin-right: auto;
}
.hero .hero-ctas {
  justify-content: center;
}

/* ─ Glowing gradient backdrop behind orbs ─ */
.hero::before {
  content: '';
  position: absolute; inset: 0;
  background:
    radial-gradient(ellipse 60% 50% at 30% 40%, var(--accent-soft) 0%, transparent 60%),
    radial-gradient(ellipse 70% 60% at 70% 65%, color-mix(in srgb, var(--orb-1) 35%, transparent) 0%, transparent 65%);
  z-index: 0;
  pointer-events: none;
  animation: heroGlow 14s ease-in-out infinite alternate;
}
@keyframes heroGlow {
  0%   { opacity: 0.45; transform: scale(1) rotate(0deg); }
  50%  { opacity: 0.75; transform: scale(1.04) rotate(0.5deg); }
  100% { opacity: 0.55; transform: scale(0.98) rotate(-0.5deg); }
}

/* ─ Hero text entrance animation (staggered) ─ */
.hero .eyebrow,
.hero h1,
.hero .hero-sub,
.hero .hero-ctas,
.hero .hero-testimonials {
  opacity: 0;
  transform: translateY(22px);
  animation: heroEnter 1.3s cubic-bezier(.16,.84,.3,1) forwards;
}
.hero .eyebrow            { animation-delay: 0.15s; }
.hero h1                  { animation-delay: 0.30s; }
.hero .hero-sub           { animation-delay: 0.85s; }
.hero .hero-ctas          { animation-delay: 1.10s; }
.hero .hero-testimonials  { animation-delay: 1.40s; }
@keyframes heroEnter {
  to { opacity: 1; transform: translateY(0); }
}

/* ─ Auto-rotating testimonials under the hero CTAs ─ */
.hero-testimonials {
  margin: 56px auto 0;
  max-width: 560px;
  text-align: center;
}
.hero-testimonial-stage {
  position: relative;
  min-height: 110px;
}
.hero-testimonial {
  position: absolute;
  inset: 0;
  margin: 0;
  display: flex; flex-direction: column;
  align-items: center;
  gap: 14px;
  opacity: 0;
  transform: translateY(8px);
  transition: opacity .9s ease, transform .9s ease;
  pointer-events: none;
}
.hero-testimonial.on {
  opacity: 1;
  transform: translateY(0);
  pointer-events: auto;
}
.hero-testimonial blockquote {
  font-family: var(--font-display);
  font-style: italic;
  font-size: 22px;
  line-height: 1.35;
  color: var(--text);
  margin: 0;
  text-wrap: balance;
  letter-spacing: -0.005em;
  text-align: center;
}
.hero-testimonial figcaption {
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--text-mute);
}
.hero-testimonial-dots {
  margin-top: 18px;
  display: flex; gap: 8px;
  justify-content: center;
}
.hero-testimonial-dots button {
  width: 24px; height: 2px;
  background: var(--border-strong);
  border: 0; padding: 0;
  cursor: pointer;
  transition: background .3s, width .3s;
  border-radius: 2px;
}
.hero-testimonial-dots button:hover { background: var(--text-dim); }
.hero-testimonial-dots button.on {
  background: var(--accent);
  width: 40px;
}

/* ─ Scroll cue at bottom of hero ─ */
.scroll-cue {
  position: absolute;
  bottom: 48px; left: 50%;
  transform: translateX(-50%);
  display: flex; flex-direction: column; align-items: center; gap: 12px;
  font-family: var(--font-mono); font-size: 10px;
  letter-spacing: 0.3em; text-transform: uppercase;
  color: var(--text-mute);
  z-index: 3;
  opacity: 0;
  animation: heroEnter 1.4s cubic-bezier(.16,.84,.3,1) 1.6s forwards;
}
.scroll-cue .line {
  display: block; width: 1px; height: 48px;
  background: linear-gradient(to bottom, var(--text-mute), transparent);
  animation: scrollPulse 2.2s ease-in-out infinite;
  transform-origin: top;
}
@keyframes scrollPulse {
  0%, 100% { transform: scaleY(0.4); opacity: 0.4; }
  50%      { transform: scaleY(1);   opacity: 1; }
}
.hero h1 .iam {
  display: inline-block;
  font-style: italic;
  color: var(--accent);
}
.hero .hero-sub {
  margin-top: 36px;
  max-width: 540px;
  font-size: 18px;
  line-height: 1.6;
  color: var(--text-dim);
}
.hero .hero-ctas {
  margin-top: 48px;
  display: flex; gap: 14px; flex-wrap: wrap;
}
.hero .hero-meta {
  margin-top: 64px;
  display: flex; gap: 48px;
  font-family: var(--font-mono); font-size: 11px;
  color: var(--text-mute); letter-spacing: 0.15em;
  text-transform: uppercase;
}
.hero .hero-meta span strong {
  display: block;
  font-family: var(--font-display);
  font-style: italic;
  color: var(--text);
  font-size: 22px;
  text-transform: none;
  letter-spacing: 0;
  margin-top: 4px;
  font-weight: 400;
}

/* ───── Section frame ───── */
.section {
  padding: 140px 0;
  position: relative;
}
.section + .section { border-top: 1px solid var(--border); }
.section-head { max-width: 720px; margin-bottom: 80px; }
.section-head .eyebrow { display: block; margin-bottom: 20px; }
.section-head h2 + p { margin-top: 24px; max-width: 580px; color: var(--text-dim); font-size: 17px; line-height: 1.55; }
.split { display: grid; grid-template-columns: 1fr 1fr; gap: 80px; align-items: start; }
.split.wide { grid-template-columns: 1.1fr 1fr; }

/* ───── Offering card ───── */
.offering {
  padding: 48px 40px;
  border: 1px solid var(--border);
  border-radius: 4px;
  background: var(--card);
  display: flex; flex-direction: column; gap: 24px;
  transition: all .35s;
  position: relative;
  overflow: hidden;
}
.offering:hover { border-color: var(--border-strong); background: var(--card-hover); }
.offering .num {
  font-family: var(--font-mono); font-size: 11px; letter-spacing: 0.2em;
  color: var(--text-mute); text-transform: uppercase;
}
.offering h3 { font-family: var(--font-display); font-style: italic; }
.offering p { color: var(--text-dim); font-size: 15px; line-height: 1.6; }
.offering .price {
  margin-top: auto; padding-top: 20px;
  font-family: var(--font-display); font-size: 26px; font-style: italic;
  color: var(--text); display: flex; align-items: baseline; gap: 8px;
}
.offering .price small { font-family: var(--font-mono); font-size: 11px; color: var(--text-mute); letter-spacing: 0.1em; text-transform: uppercase; }
.offering .badge {
  position: absolute; top: 24px; right: 24px;
  font-family: var(--font-mono); font-size: 10px; letter-spacing: 0.2em;
  text-transform: uppercase; color: var(--accent);
  padding: 4px 10px; border: 1px solid var(--accent); border-radius: 999px;
}

/* ───── Body·Mind·Soul interactive explorer ───── */
.bms {
  position: relative;
  height: 540px;
  display: flex; align-items: center; justify-content: center;
}
.bms-stage {
  position: relative;
  width: 480px; height: 480px;
}
.bms-svg {
  position: absolute; inset: 0;
  width: 100%; height: 100%;
  pointer-events: none;
  overflow: visible;
}

/* glow orbs behind each label */
.bms-orb {
  opacity: 0.5;
  transform-origin: center;
  transform-box: fill-box;
  animation: bmsOrbBreathe 7s ease-in-out infinite;
  transition: opacity .6s ease;
}
.bms-orb.lit {
  opacity: 1;
  animation: bmsOrbBreathe 4s ease-in-out infinite, bmsOrbLit .6s ease forwards;
}
@keyframes bmsOrbBreathe {
  0%, 100% { transform: scale(1); }
  50%      { transform: scale(1.12); }
}
@keyframes bmsOrbLit {
  from { transform: scale(1); }
  to   { transform: scale(1.18); }
}

/* triangle edges: draw-on + pulse */
.bms-edge {
  fill: none;
  stroke: var(--accent);
  stroke-width: 1;
  stroke-dasharray: var(--len) var(--len);
  stroke-dashoffset: var(--len);
  opacity: 0.45;
  animation:
    bmsEdgeDraw 1.6s cubic-bezier(.16,.84,.3,1) forwards,
    bmsEdgePulse 5s ease-in-out infinite 2s;
}
@keyframes bmsEdgeDraw {
  to { stroke-dashoffset: 0; }
}
@keyframes bmsEdgePulse {
  0%, 100% { opacity: 0.3; stroke-width: 1; }
  50%      { opacity: 0.7; stroke-width: 1.2; }
}

.bms-node {
  opacity: 0;
  animation: bmsNodeIn .8s ease 1.8s forwards, bmsNodePulse 3.5s ease-in-out infinite 2.5s;
  transform-box: fill-box;
  transform-origin: center;
}
@keyframes bmsNodeIn { to { opacity: 1; } }
@keyframes bmsNodePulse {
  0%, 100% { transform: scale(1); opacity: 0.9; }
  50%      { transform: scale(1.4); opacity: 0.5; }
}

.bms-spark {
  filter: drop-shadow(0 0 4px var(--accent));
}

/* tiny chakra-color dots inside each label circle */
.bms-mini-chakra {
  transform-origin: center;
  transform-box: fill-box;
  animation: bmsMiniChakra 3.5s ease-in-out infinite;
  filter: drop-shadow(0 0 3px currentColor);
}
@keyframes bmsMiniChakra {
  0%, 100% { opacity: 0.55; transform: scale(1); }
  50%      { opacity: 1;    transform: scale(1.4); }
}

/* the labelled circles sit on top */
.bms-circle {
  position: absolute;
  width: 200px; height: 200px;
  border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  font-family: var(--font-display); font-style: italic;
  font-size: 28px;
  cursor: pointer;
  border: 1px solid var(--border-strong);
  background: color-mix(in srgb, var(--card) 80%, transparent);
  backdrop-filter: blur(10px);
  transition: all .45s cubic-bezier(.2,.7,.3,1);
  user-select: none;
  z-index: 2;
}
.bms-circle:hover { border-color: var(--accent); }
.bms-circle.active {
  background: var(--accent-soft);
  border-color: var(--accent);
  color: var(--accent);
  transform: scale(1.08);
  box-shadow: 0 0 60px var(--accent-soft);
}
.bms-circle.body { top: 0; left: 50%; transform: translateX(-50%); }
.bms-circle.body.active { transform: translateX(-50%) scale(1.08); }
.bms-circle.mind { bottom: 40px; left: 0; }
.bms-circle.soul { bottom: 40px; right: 0; }
.bms-content {
  max-width: 360px;
}
.bms-content .eyebrow { margin-bottom: 14px; display: block; }
.bms-content h3 { font-style: italic; margin-bottom: 16px; }
.bms-content ul {
  list-style: none; padding: 0; margin: 24px 0 0;
}
.bms-content li {
  padding: 12px 0;
  border-bottom: 1px solid var(--border);
  font-size: 14px; color: var(--text-dim);
  display: flex; align-items: center; gap: 12px;
}
.bms-content li::before {
  content: ''; width: 6px; height: 6px; border-radius: 50%;
  background: var(--accent); flex: 0 0 auto;
}

/* ───── E-book flip preview ───── */
.ebook-wrap {
  --eb-bg: #272340;
  --eb-bg-2: #2f2b4a;
  --eb-text: #ece5d4;
  --eb-text-soft: #c9c1d6;
  --eb-muted: #8e87a8;
  --eb-accent: #e88a6f;
  --eb-accent-soft: #f0a48d;
  --eb-line: rgba(255,255,255,0.09);
  --eb-line-strong: rgba(255,255,255,0.18);
  --eb-serif: 'Cormorant Garamond', 'EB Garamond', Georgia, serif;
  --eb-sans: 'Manrope', 'Inter', system-ui, sans-serif;
  --eb-mono: 'JetBrains Mono', ui-monospace, monospace;
  position: relative;
  width: 100%;
  max-width: 980px;
  margin: 0 auto;
  padding: 40px 0 20px;
  perspective: 2400px;
}
.ebook-stage {
  position: relative;
  width: 100%;
  aspect-ratio: 1.5 / 1;
  display: flex; justify-content: center;
  transform-style: preserve-3d;
}
.ebook-spine {
  position: absolute;
  left: 50%; top: 2%; bottom: 2%;
  width: 6px;
  transform: translateX(-50%);
  background: linear-gradient(to right, rgba(0,0,0,0.25), rgba(0,0,0,0.5), rgba(0,0,0,0.25));
  z-index: 1; border-radius: 2px; pointer-events: none;
}
.ebook-page {
  position: absolute;
  top: 0; bottom: 0;
  width: 50%;
  background:
    radial-gradient(ellipse 80% 60% at 90% -10%, rgba(232,138,111,0.10), transparent 60%),
    radial-gradient(ellipse 60% 50% at -5% 110%, rgba(199,156,232,0.07), transparent 60%),
    var(--eb-bg);
  border: 1px solid var(--eb-line);
  overflow: hidden;
}
.ebook-page.left  { left: 0; border-right: 0; box-shadow: inset -16px 0 24px -16px rgba(0,0,0,0.45); }
.ebook-page.right { right: 0; border-left: 0; box-shadow: inset 16px 0 24px -16px rgba(0,0,0,0.45); }

.ebook-leaf {
  position: absolute;
  top: 0; bottom: 0; right: 0;
  width: 50%;
  transform-style: preserve-3d;
  transform-origin: left center;
  transition: transform 1.2s cubic-bezier(.45,.05,.25,1);
  will-change: transform; pointer-events: none;
}
.ebook-face {
  position: absolute; inset: 0;
  padding: 44px 48px 36px;
  display: flex; flex-direction: column;
  background:
    radial-gradient(ellipse 80% 60% at 90% -10%, rgba(232,138,111,0.10), transparent 60%),
    radial-gradient(ellipse 60% 50% at -5% 110%, rgba(199,156,232,0.07), transparent 60%),
    var(--eb-bg);
  border: 1px solid var(--eb-line);
  color: var(--eb-text);
  font-family: var(--eb-sans);
  overflow: hidden;
  -webkit-backface-visibility: hidden;
  backface-visibility: hidden;
}
.ebook-face.front {
  border-left: 0;
  box-shadow: inset 16px 0 24px -16px rgba(0,0,0,0.45);
  transform: rotateY(0deg);
}
.ebook-face.back {
  border-right: 0;
  box-shadow: inset -16px 0 24px -16px rgba(0,0,0,0.45);
  transform: rotateY(180deg);
}

.ebook-face .page-eyebrow {
  display: flex; justify-content: space-between; align-items: center;
  font-family: var(--eb-mono); font-size: 9px;
  letter-spacing: 0.22em; text-transform: uppercase;
  color: var(--eb-muted);
  padding-bottom: 16px;
  border-bottom: 1px solid var(--eb-line);
  margin-bottom: 28px;
}
.ebook-face .chapter-num { color: var(--eb-accent); }

.ebook-face h4 {
  font-family: var(--eb-serif);
  font-weight: 400; font-style: italic;
  font-size: 30px; line-height: 1.1;
  letter-spacing: -0.005em;
  color: var(--eb-text);
  margin: 0 0 20px;
  text-wrap: balance;
}
.ebook-face .chapter-lead {
  font-family: var(--eb-serif);
  font-size: 16px; line-height: 1.55;
  color: var(--eb-text-soft);
  margin: 0;
  font-weight: 300;
  text-wrap: pretty;
}
.ebook-face .signature {
  margin-top: auto;
  padding-top: 20px;
  border-top: 1px solid var(--eb-line);
  display: flex; justify-content: space-between; align-items: center;
  font-family: var(--eb-mono); font-size: 9px;
  letter-spacing: 0.22em; text-transform: uppercase;
  color: var(--eb-muted);
}

.chapter-orb {
  position: absolute;
  width: 200px; height: 200px;
  right: -40px; bottom: 56px;
  opacity: 0.6; pointer-events: none;
}
.chapter-orb svg { width: 100%; height: 100%; display: block; }

.ebook-cover {
  padding: 38px 44px;
  background:
    radial-gradient(ellipse 80% 60% at 90% -10%, rgba(232,138,111,0.18), transparent 60%),
    radial-gradient(ellipse 60% 50% at -5% 110%, rgba(199,156,232,0.12), transparent 60%),
    var(--eb-bg);
  display: flex; flex-direction: column;
  align-items: stretch; text-align: left;
  justify-content: space-between;
  position: relative;
}
.ebook-cover .cover-mark {
  display: flex; align-items: center; gap: 10px;
  font-family: var(--eb-serif);
  font-size: 16px;
  color: var(--eb-text);
  letter-spacing: 0.02em;
}
.ebook-cover .cover-mark em {
  color: var(--eb-muted); font-style: italic;
}
.ebook-cover .cover-mark .dot {
  width: 7px; height: 7px; border-radius: 50%;
  background: var(--eb-accent);
  box-shadow: 0 0 12px var(--eb-accent);
}
.ebook-cover .cover-tag {
  position: absolute; top: 38px; right: 44px;
  font-family: var(--eb-mono); font-size: 9px;
  letter-spacing: 0.22em; text-transform: uppercase;
  color: var(--eb-muted);
}
.ebook-cover .cover-orb-stack {
  position: absolute; inset: 0;
  display: flex; align-items: center; justify-content: center;
  pointer-events: none;
}
.ebook-cover .cover-orb-blur {
  position: absolute;
  width: 280px; height: 280px;
  border-radius: 50%;
  background: radial-gradient(circle at 50% 45%,
    rgba(240,164,141,0.6) 0%,
    rgba(232,138,111,0.35) 30%,
    rgba(184,90,64,0.15) 60%,
    transparent 78%);
  filter: blur(2px);
  animation: ebookOrbPulse 6s ease-in-out infinite;
}
.ebook-cover .cover-rings {
  position: relative;
  width: 280px; height: 280px;
  animation: ebookRingsRotate 80s linear infinite;
}
@keyframes ebookOrbPulse {
  0%, 100% { transform: scale(1);    opacity: 1; }
  50%      { transform: scale(1.06); opacity: 0.85; }
}
@keyframes ebookRingsRotate {
  to { transform: rotate(360deg); }
}
.ebook-cover .cover-hero {
  position: relative; z-index: 2;
  margin-top: auto;
}
.ebook-cover .cover-hero h1 {
  font-family: var(--eb-serif);
  font-weight: 400; font-style: italic;
  font-size: clamp(40px, 4.6vw, 56px);
  line-height: 1.0;
  letter-spacing: -0.01em;
  color: var(--eb-text);
  margin: 0;
}
.ebook-cover .cover-hero h1 em {
  color: var(--eb-accent); font-style: italic;
}
.ebook-cover .cover-quote {
  margin-top: 18px;
  font-family: var(--eb-serif);
  font-size: 14px; line-height: 1.5;
  font-style: italic;
  color: var(--eb-text-soft);
  max-width: 380px;
  font-weight: 300;
}
.ebook-cover .cover-foot {
  margin-top: 32px;
  padding-top: 18px;
  border-top: 1px solid var(--eb-line);
  display: flex; justify-content: space-between;
  font-family: var(--eb-mono); font-size: 9px;
  letter-spacing: 0.22em; text-transform: uppercase;
  color: var(--eb-muted);
  position: relative; z-index: 2;
}

.ebook-controls {
  display: flex; align-items: center; justify-content: space-between;
  margin-top: 28px; gap: 24px;
}
.ebook-meta {
  flex: 1;
  display: flex; flex-direction: column;
  align-items: center; gap: 12px;
}
.ebook-chapter-tag {
  font-family: var(--font-mono); font-size: 10px;
  letter-spacing: 0.22em; text-transform: uppercase;
  color: var(--text-dim);
}
.ebook-controls .dots { display: flex; gap: 6px; }
.ebook-controls .dots i {
  width: 5px; height: 5px; border-radius: 50%;
  background: var(--border-strong);
  display: block;
  transition: all .3s;
  cursor: pointer;
}
.ebook-controls .dots i.on {
  background: var(--accent);
  transform: scaleX(3);
  border-radius: 3px;
}
.ebook-arrow {
  width: 44px; height: 44px;
  border-radius: 50%;
  border: 1px solid var(--border-strong);
  background: transparent;
  color: var(--text);
  cursor: pointer;
  font-size: 18px;
  display: flex; align-items: center; justify-content: center;
  transition: all .25s;
  flex: 0 0 auto;
}
.ebook-arrow:hover { background: var(--text); color: var(--bg); border-color: var(--text); }
.ebook-arrow:disabled { opacity: 0.3; cursor: default; }

/* ── Embedded full reading (penelope sample) ── */
.ebook-embed {
  width: 100%;
  max-width: 1080px;
  margin: 0 auto;
  position: relative;
}
/* Decorative bezel framing the iframe - gives it a "book on a table" feel
   that ties back to the cream + lavender website palette. */
.ebook-embed::before,
.ebook-embed::after {
  content: '';
  position: absolute;
  pointer-events: none;
  border-radius: 50%;
  filter: blur(60px);
  opacity: 0.6;
  z-index: 0;
}
.ebook-embed::before {
  width: 280px; height: 280px;
  background: var(--orb-1);
  top: -60px; left: -80px;
}
.ebook-embed::after {
  width: 240px; height: 240px;
  background: var(--orb-2);
  bottom: -40px; right: -60px;
}
.ebook-embed-frame {
  position: relative;
  width: 100%;
  aspect-ratio: 16 / 11;
  border-radius: 10px;
  overflow: hidden;
  background: var(--bg-alt);
  border: 1px solid var(--border-strong);
  padding: 14px;
  box-shadow:
    0 30px 80px color-mix(in srgb, var(--accent) 18%, transparent),
    0 12px 32px rgba(31,36,74,0.18),
    inset 0 0 0 1px var(--card);
  z-index: 1;
}
.ebook-embed-frame::before {
  content: '';
  position: absolute;
  inset: 14px;
  border-radius: 6px;
  border: 1px solid var(--border);
  pointer-events: none;
  z-index: 2;
}
.ebook-embed-frame iframe {
  position: absolute;
  top: 14px; left: 14px;
  width: 1280px;
  height: 880px;
  border: 0;
  display: block;
  background: #272340;
  border-radius: 5px;
  transform-origin: top left;
}
.ebook-embed-note {
  margin-top: 28px;
  display: flex; align-items: center; justify-content: space-between;
  gap: 24px; flex-wrap: wrap;
  font-family: var(--font-mono); font-size: 10px;
  letter-spacing: 0.22em; text-transform: uppercase;
  color: var(--text-mute);
  position: relative; z-index: 1;
}
.ebook-embed-note .btn { font-family: var(--font-body); }

/* ───── Questionnaire preview ───── */
.questionnaire {
  background: var(--bg-alt);
  border: 1px solid var(--border);
  border-radius: 6px;
  padding: 40px;
  font-family: var(--font-body);
  position: relative;
  overflow: hidden;
}
.questionnaire .q-meta {
  display: flex; justify-content: space-between; align-items: center;
  font-family: var(--font-mono); font-size: 10px; letter-spacing: 0.2em;
  color: var(--text-mute); text-transform: uppercase;
  margin-bottom: 24px;
}
.questionnaire .q-progress {
  height: 1px; background: var(--border); margin-bottom: 36px;
  position: relative; overflow: hidden;
}
.questionnaire .q-progress::after {
  content: ''; position: absolute; inset: 0 auto 0 0;
  width: var(--p, 33%); background: var(--accent);
  transition: width .5s ease;
}
.questionnaire h3 { font-style: italic; margin-bottom: 8px; }
.questionnaire .q-hint { color: var(--text-dim); font-size: 14px; margin-bottom: 24px; }
.q-options { display: flex; flex-direction: column; gap: 8px; }
.q-opt {
  padding: 14px 18px;
  border: 1px solid var(--border);
  border-radius: 3px;
  font-size: 14px; color: var(--text-dim);
  cursor: pointer; transition: all .2s;
  font-family: var(--font-body);
  background: transparent;
  text-align: left;
  display: flex; align-items: center; gap: 14px;
}
.q-opt:hover { color: var(--text); border-color: var(--border-strong); }
.q-opt.selected {
  border-color: var(--accent); color: var(--text);
  background: var(--accent-soft);
}
.q-opt .check {
  width: 16px; height: 16px; border-radius: 50%;
  border: 1px solid var(--border-strong);
  flex: 0 0 auto; position: relative;
}
.q-opt.selected .check { border-color: var(--accent); background: var(--accent); }
.q-opt.selected .check::after {
  content: ''; position: absolute; inset: 4px; background: var(--bg); border-radius: 50%;
}
.q-chakra-grid { display: grid; grid-template-columns: repeat(7, 1fr); gap: 6px; margin-top: 12px; }

/* ── Body diagram + symptoms multi-select (step 1) ── */
.q-body-layout { display: grid; grid-template-columns: 220px 1fr; gap: 40px; align-items: start; margin-top: 14px; }
.q-body-svg { width: 100%; height: auto; display: block; }
.q-body-svg text { font-family: var(--font-mono); font-size: 9px; letter-spacing: 0.14em; fill: var(--text-mute); text-transform: uppercase; transition: fill .25s; }
.q-body-svg text.on { fill: var(--text); }
.q-symptoms { display: grid; grid-template-columns: 1fr 1fr; gap: 28px; }
.q-symptoms .col-head {
  font-family: var(--font-mono); font-size: 10px; letter-spacing: 0.22em;
  color: var(--text-mute); text-transform: uppercase;
  margin: 0 0 12px 0; padding-bottom: 10px;
  border-bottom: 1px solid var(--border);
}
.q-symptoms .col { display: flex; flex-direction: column; gap: 6px; }
.q-symptom {
  padding: 11px 14px;
  border: 1px solid var(--border);
  border-radius: 3px;
  font-size: 13px; color: var(--text-dim);
  cursor: pointer; background: transparent;
  transition: all .2s;
  font-family: var(--font-body); text-align: left;
  display: flex; align-items: center; gap: 10px; width: 100%;
}
.q-symptom:hover { color: var(--text); border-color: var(--border-strong); }
.q-symptom.on { color: var(--text); border-color: var(--accent); background: var(--accent-soft); }
.q-symptom .swatch { width: 8px; height: 8px; border-radius: 50%; flex: 0 0 auto; opacity: 0.45; transition: all .2s; }
.q-symptom.on .swatch { opacity: 1; box-shadow: 0 0 0 3px var(--accent-soft); }

.chakra-pill {
  padding: 10px 6px;
  border: 1px solid var(--border);
  border-radius: 3px;
  background: transparent;
  font-family: var(--font-body); font-size: 11px;
  color: var(--text-dim); cursor: pointer;
  transition: all .2s;
  display: flex; flex-direction: column; align-items: center; gap: 8px;
}
.chakra-pill .dot {
  width: 14px; height: 14px; border-radius: 50%; opacity: 0.55;
}
.chakra-pill:hover { border-color: var(--border-strong); color: var(--text); }
.chakra-pill.on { border-color: var(--accent); color: var(--text); background: var(--accent-soft); }
.chakra-pill.on .dot { opacity: 1; }

.q-controls { display: flex; justify-content: space-between; margin-top: 32px; }
.q-controls .q-step { font-family: var(--font-mono); font-size: 11px; color: var(--text-mute); letter-spacing: 0.15em; text-transform: uppercase; }

/* ───── Atlas App showcase (5 features · phone in the middle) ───── */
.app-showcase {
  margin-top: 72px;
  display: grid;
  grid-template-columns: 1fr 320px 1fr;
  gap: 64px;
  align-items: center;
}
.app-features {
  list-style: none; padding: 0; margin: 0;
  display: flex; flex-direction: column;
  gap: 4px;
  justify-self: end;
  width: 100%; max-width: 360px;
}
.app-feature {
  display: flex; align-items: flex-start; gap: 18px;
  padding: 16px 14px;
  border-radius: 10px;
  cursor: pointer;
  transition: all .35s cubic-bezier(.2,.7,.3,1);
  font-family: var(--font-display);
  font-style: italic;
  font-size: 20px;
  line-height: 1.2;
  color: var(--text-dim);
  position: relative;
  border: 1px solid transparent;
}
.app-feature:hover {
  color: var(--text);
  background: var(--card);
}
.app-feature .app-num {
  flex: 0 0 auto;
  width: 28px; height: 28px;
  border-radius: 50%;
  border: 1px solid var(--border-strong);
  display: flex; align-items: center; justify-content: center;
  font-family: var(--font-mono);
  font-style: normal;
  font-size: 11px;
  letter-spacing: 0.05em;
  color: var(--text-dim);
  margin-top: 2px;
  background: var(--bg);
  transition: all .3s;
}
.app-feature.on {
  color: var(--text);
  background: linear-gradient(90deg, var(--card-hover), transparent 70%);
  border-color: var(--border);
}
.app-feature.on .app-num {
  background: var(--accent);
  border-color: var(--accent);
  color: #fff;
  box-shadow: 0 6px 18px color-mix(in srgb, var(--accent) 40%, transparent);
}
.app-feature-name { display: block; }

.app-phone-wrap {
  display: flex; justify-content: center;
}
.app-phone {
  width: 320px; height: 660px;
  border-radius: 42px;
  padding: 12px;
  position: relative;
  background: #1a1c30;
  border-color: rgba(255,255,255,0.18);
}
.app-phone::before {
  /* halo behind phone */
  content: '';
  position: absolute;
  inset: -40px;
  border-radius: 50%;
  background: radial-gradient(ellipse at center,
    var(--accent-soft) 0%, transparent 60%);
  filter: blur(40px);
  z-index: -1;
  opacity: 0.7;
}
.app-iframe-screen {
  position: relative;
  border-radius: 30px;
  overflow: hidden;
  background: #4a5070;
  padding: 0;
}
.app-iframe {
  position: absolute;
  top: 50%; left: 50%;
  width: 390px;
  height: 844px;
  border: 0;
  background: #4a5070;
  /* 296 / 390 ≈ 0.759 (inner phone screen is 296×636 after 12px padding) */
  transform: translate(-50%, -50%) scale(0.759);
  transform-origin: center center;
  pointer-events: auto;
}

/* ───── Now-playing app screen (native, lightweight) ───── */
.phone-screen.np-screen {
  position: absolute; inset: 0;
  border-radius: 30px;
  overflow: hidden;
  padding: 14px 20px 18px;
  display: flex; flex-direction: column;
  background:
    radial-gradient(120% 70% at 50% 34%, #3a3a64 0%, #2b2c52 38%, #1d1e3d 72%, #16172f 100%);
  color: #ece6dc;
  font-family: var(--font-body);
  isolation: isolate;
}
/* faint concentric backdrop rings */
.np-screen::before {
  content: ''; position: absolute; left: 50%; top: 40%;
  width: 460px; height: 460px; transform: translate(-50%,-50%);
  border-radius: 50%;
  background:
    radial-gradient(circle, transparent 26%, rgba(255,255,255,0.025) 27%, transparent 28%),
    radial-gradient(circle, transparent 40%, rgba(255,255,255,0.02) 41%, transparent 42%),
    radial-gradient(circle, transparent 54%, rgba(255,255,255,0.018) 55%, transparent 56%);
  pointer-events: none; z-index: 0;
}
.np-screen > * { position: relative; z-index: 1; }

.np-status {
  display: flex; align-items: center; justify-content: space-between;
  padding: 2px 2px 0;
}
.np-time { font-weight: 600; font-size: 14px; color: #fff; letter-spacing: 0.01em; }
.np-island {
  width: 70px; height: 18px; border-radius: 12px; background: #000;
}
.np-signal { color: #fff; display: flex; align-items: center; }

.np-top {
  display: flex; align-items: center; justify-content: space-between;
  margin-top: 14px;
}
.np-iconbtn {
  width: 38px; height: 38px; border-radius: 50%;
  background: rgba(255,255,255,0.08);
  border: 1px solid rgba(255,255,255,0.12);
  color: #d7d0e4; display: flex; align-items: center; justify-content: center;
  cursor: pointer; transition: background .2s;
}
.np-iconbtn:hover { background: rgba(255,255,255,0.16); }
.np-now {
  font-family: var(--font-mono); font-size: 10px; letter-spacing: 0.32em;
  text-transform: uppercase; color: rgba(236,230,220,0.5);
}

/* ── orb ── */
.np-orb-stage {
  position: relative; flex: 1;
  display: flex; align-items: center; justify-content: center;
  min-height: 0;
}
.np-halo {
  position: absolute; width: 230px; height: 230px; border-radius: 50%;
  background: radial-gradient(circle, rgba(224,160,138,0.30) 0%, rgba(224,160,138,0.10) 45%, transparent 70%);
  filter: blur(6px);
  animation: npHalo 6s ease-in-out infinite;
}
.np-ring {
  position: absolute; border-radius: 50%;
  border: 1px solid rgba(224,160,138,0.35);
  width: 150px; height: 150px;
  opacity: 0;
  animation: npRipple 6s ease-out infinite;
}
.np-ring.r2 { animation-delay: 2s; }
.np-ring.r3 { animation-delay: 4s; }
.np-orb {
  position: relative;
  width: 150px; height: 150px; border-radius: 50%;
  background:
    radial-gradient(circle at 42% 38%, #f0c3b1 0%, #e3a087 42%, #cf8067 78%, #bf7059 100%);
  box-shadow:
    0 0 50px rgba(224,160,138,0.45),
    inset 0 0 40px rgba(255,255,255,0.18),
    inset -8px -10px 30px rgba(120,60,45,0.4);
  display: flex; align-items: center; justify-content: center;
  animation: npBreathe 6s ease-in-out infinite;
}
.np-orb-core {
  width: 46px; height: 46px; border-radius: 50%;
  background: radial-gradient(circle at 45% 40%, rgba(255,245,238,0.95), rgba(243,200,182,0.65));
  filter: blur(0.5px);
  animation: npCore 6s ease-in-out infinite;
}
@keyframes npBreathe {
  0%, 100% { transform: scale(0.92); }
  45%      { transform: scale(1.06); }
  55%      { transform: scale(1.06); }
}
@keyframes npCore {
  0%, 100% { transform: scale(0.85); opacity: 0.8; }
  50%      { transform: scale(1.1); opacity: 1; }
}
@keyframes npHalo {
  0%, 100% { transform: scale(0.9); opacity: 0.7; }
  50%      { transform: scale(1.12); opacity: 1; }
}
@keyframes npRipple {
  0%   { transform: scale(0.92); opacity: 0; }
  15%  { opacity: 0.5; }
  100% { transform: scale(2.1); opacity: 0; }
}
.np-breath {
  text-align: center;
  font-family: var(--font-mono); font-size: 10px; letter-spacing: 0.34em;
  text-transform: uppercase; color: rgba(236,230,220,0.55);
  margin: 6px 0 2px;
  animation: npBreathText 6s ease-in-out infinite;
}
@keyframes npBreathText {
  0%, 100% { opacity: 0.35; }
  50%      { opacity: 0.75; }
}

/* ── track ── */
.np-track { margin-top: 14px; }
.np-eyebrow {
  font-family: var(--font-mono); font-size: 8.5px; letter-spacing: 0.2em;
  text-transform: uppercase; color: rgba(236,230,220,0.45);
}
.np-title-row {
  display: flex; align-items: flex-start; justify-content: space-between; gap: 10px;
  margin-top: 8px;
}
.np-title {
  font-family: var(--font-display); font-style: italic; font-weight: 500;
  font-size: 23px; line-height: 1.12; color: #fff; margin: 0;
  letter-spacing: -0.005em;
}
.np-edit { color: rgba(236,230,220,0.4); flex: 0 0 auto; margin-top: 5px; }
.np-scrub { margin-top: 16px; }
.np-bar {
  position: relative; display: block;
  height: 3px; border-radius: 2px;
  background: rgba(255,255,255,0.16);
}
.np-fill {
  position: absolute; left: 0; top: 0; bottom: 0; width: 22%;
  background: linear-gradient(90deg, #e3a087, #f0c3b1);
  border-radius: 2px;
}
.np-knob {
  position: absolute; left: 22%; top: 50%; transform: translate(-50%,-50%);
  width: 11px; height: 11px; border-radius: 50%; background: #f3e9e2;
  box-shadow: 0 0 8px rgba(224,160,138,0.7);
}
.np-times {
  display: flex; justify-content: space-between; margin-top: 9px;
  font-family: var(--font-mono); font-size: 9px; letter-spacing: 0.08em;
  color: rgba(236,230,220,0.5);
}
.np-controls {
  display: flex; align-items: center; justify-content: center; gap: 26px;
  margin-top: 14px;
}
.np-skip {
  background: transparent; border: 0; color: rgba(236,230,220,0.7);
  cursor: pointer; display: flex; transition: color .2s;
}
.np-skip:hover { color: #fff; }
.np-play {
  width: 58px; height: 58px; border-radius: 50%; border: 0; cursor: pointer;
  background: radial-gradient(circle at 42% 38%, #f0c3b1, #e0a08a 70%, #d18b72);
  color: #2b2c52;
  display: flex; align-items: center; justify-content: center;
  box-shadow: 0 8px 24px rgba(224,160,138,0.4);
  transition: transform .2s;
}
.np-play:hover { transform: scale(1.05); }
.np-nav {
  display: flex; justify-content: space-between; align-items: center;
  margin-top: 16px; padding-top: 14px;
  border-top: 1px solid rgba(255,255,255,0.08);
}
.np-navitem {
  display: flex; flex-direction: column; align-items: center; gap: 6px;
  font-family: var(--font-mono); font-size: 8px; letter-spacing: 0.14em;
  text-transform: uppercase; color: rgba(236,230,220,0.5);
  cursor: pointer; transition: color .2s; flex: 1;
}
.np-navitem:hover { color: rgba(236,230,220,0.85); }
.no-imagery .np-halo, .no-imagery .np-ring { display: none; }
.app-screen {
  border-radius: 30px;
  background: var(--bg-soft);
  padding: 28px 18px 22px;
  display: flex; flex-direction: column;
  overflow: hidden;
}
.app-statusbar {
  display: flex; justify-content: space-between; align-items: center;
  font-family: var(--font-mono); font-size: 10px;
  letter-spacing: 0.18em; text-transform: uppercase;
  color: var(--text-mute);
  margin-top: 2px;
  margin-bottom: 18px;
}
.app-greet {
  margin-bottom: 18px;
  padding-bottom: 14px;
  border-bottom: 1px solid var(--border);
}
.app-greet small {
  display: block;
  font-family: var(--font-mono); font-size: 9px;
  letter-spacing: 0.22em; text-transform: uppercase;
  color: var(--text-mute);
  margin-bottom: 6px;
}
.app-greet em {
  font-family: var(--font-display); font-style: italic;
  font-size: 17px;
  line-height: 1.15;
  color: var(--text);
  display: block;
  text-wrap: balance;
}

.app-cards {
  display: flex; flex-direction: column;
  gap: 10px;
  overflow-y: auto;
}
.app-card {
  position: relative;
  display: flex; align-items: center; gap: 12px;
  padding: 12px 14px 12px 12px;
  border-radius: 12px;
  background: linear-gradient(135deg,
    color-mix(in srgb, var(--app-card-color) 14%, var(--bg-soft)) 0%,
    color-mix(in srgb, var(--app-card-color) 4%, var(--bg-soft)) 100%);
  border: 1px solid color-mix(in srgb, var(--app-card-color) 28%, var(--border));
  overflow: hidden;
  transition: transform .25s;
}
.app-card.muted {
  opacity: 0.55;
  background: var(--bg-soft);
  border-color: var(--border);
}
.app-card-glyph {
  flex: 0 0 auto;
  width: 38px; height: 38px;
}
.app-card-glyph svg { width: 100%; height: 100%; display: block; }
.app-card-body { flex: 1; min-width: 0; }
.app-card-tag {
  font-family: var(--font-mono); font-size: 9px;
  letter-spacing: 0.22em; text-transform: uppercase;
  color: color-mix(in srgb, var(--app-card-color) 80%, var(--text-dim));
  margin-bottom: 3px;
}
.app-card-title {
  font-family: var(--font-display); font-style: italic;
  font-size: 14px; line-height: 1.2;
  color: var(--text);
  text-wrap: balance;
}

/* ── chat (journal feature) ── */
.app-chat {
  display: flex; flex-direction: column; gap: 10px;
  padding-top: 4px;
}
.chat-msg {
  max-width: 88%;
  padding: 10px 14px;
  border-radius: 14px;
  font-size: 12px;
  line-height: 1.4;
  position: relative;
}
.chat-msg.you {
  align-self: flex-end;
  background: var(--bg-alt);
  color: var(--text);
  border-bottom-right-radius: 4px;
}
.chat-msg.atlas {
  align-self: flex-start;
  background: var(--accent-soft);
  color: var(--text);
  border-bottom-left-radius: 4px;
  display: flex; gap: 8px;
  font-family: var(--font-display);
  font-style: italic;
}
.chat-msg p { margin: 0; }
.chat-msg.atlas p { font-size: 13px; }
.chat-mark {
  flex: 0 0 auto;
  width: 20px; height: 20px; border-radius: 50%;
  background: var(--accent);
  color: #fff;
  font-family: var(--font-mono);
  font-style: normal;
  font-size: 10px;
  display: flex; align-items: center; justify-content: center;
}
.chat-input {
  margin-top: auto;
  padding: 12px 14px;
  border-radius: 12px;
  background: var(--bg-alt);
  border: 1px solid var(--border);
  display: flex; align-items: center; justify-content: space-between;
  color: var(--text-mute);
  font-size: 12px;
  font-style: italic;
}
.chat-input i {
  width: 8px; height: 14px;
  background: var(--accent);
  border-radius: 2px;
  animation: chatCaret 1s ease-in-out infinite;
}
@keyframes chatCaret { 50% { opacity: 0; } }

/* ── right column detail ── */
.app-detail {
  max-width: 360px;
}
.app-detail h3 {
  font-family: var(--font-display);
  font-style: italic;
  font-weight: 400;
  font-size: clamp(28px, 2.6vw, 36px);
  line-height: 1.1;
  color: var(--text);
  margin: 0;
  text-wrap: balance;
}
.app-detail p {
  margin-top: 22px;
  color: var(--text-dim);
  font-size: 16px;
  line-height: 1.65;
}
.app-detail-cta {
  margin-top: 32px;
  display: flex; align-items: center; gap: 16px;
  flex-wrap: wrap;
}

@media (max-width: 1080px) {
  .app-showcase {
    grid-template-columns: 1fr;
    justify-items: center;
    gap: 48px;
  }
  .app-features { justify-self: stretch; max-width: 540px; }
  .app-detail { text-align: center; }
  .app-detail-cta { justify-content: center; }
}

/* ───── Reading showcase (01 - phone with sample reading) ───── */
.reading-showcase {
  display: grid;
  grid-template-columns: 360px 1fr;
  gap: 72px;
  align-items: center;
}
.reading-phone-wrap {
  display: flex; flex-direction: column; align-items: center; gap: 16px;
}
.phone.reading-phone {
  width: 340px; height: 700px;
  border-radius: 44px;
  padding: 13px;
  position: relative;
  background: #14141f;
  border-color: rgba(255,255,255,0.16);
}
.phone.reading-phone::before {
  content: '';
  position: absolute;
  inset: -40px;
  border-radius: 50%;
  background: radial-gradient(ellipse at center, var(--accent-soft) 0%, transparent 60%);
  filter: blur(40px);
  z-index: -1;
  opacity: 0.7;
}
.reading-screen {
  border-radius: 32px;
  overflow: hidden;
  padding: 0;
  background: #1c1b2e;
  position: relative;
}
/* thin safe-margin ring (matches the atlas/reading purple bg) so the reading
   covers the screen but text never touches the bezel */
.reading-clip {
  position: absolute;
  inset: 3px;
  overflow: hidden;
  border-radius: 30px;
  background: #1c1b2e;
}
.phone.reading-phone-lg .reading-clip { inset: 3px; border-radius: 38px; }
/* force the dark ring even though .phone-screen would otherwise paint it cream */
.phone-screen.reading-screen { background: #1c1b2e; }
/* Reading iframe: sized to the reading's native 440x860 deck and scaled via
   JS (ReadingPhonePreview) so the layout renders exactly as designed. */
.reading-iframe {
  position: absolute;
  top: 50%; left: 50%;
  width: 440px;
  height: 860px;
  border: 0;
  display: block;
  background: #1c1c2e;
  transform-origin: center center;
  transform: translate(-50%, -50%);
}
.phone.reading-phone .phone-bar {
  position: absolute;
  top: 8px; left: 50%; transform: translateX(-50%);
  width: 96px; height: 6px; border-radius: 4px;
  background: rgba(0,0,0,0.4);
  z-index: 3; pointer-events: none;
}
.reading-detail { max-width: 440px; }
.reading-detail h3 {
  font-family: var(--font-display); font-style: italic;
  font-size: clamp(28px, 3vw, 38px);
  line-height: 1.1; color: var(--text);
  margin-top: 14px;
}
@media (max-width: 900px) {
  .reading-showcase { grid-template-columns: 1fr; justify-items: center; gap: 48px; }
  .reading-detail { text-align: center; }
  .reading-detail ul { text-align: left; max-width: 360px; margin-left: auto; margin-right: auto; }
}

/* ───── Large reading phone (product page preview) ───── */
.reading-phone-showcase {
  display: flex; flex-direction: column; align-items: center;
  gap: 36px;
}
.phone.reading-phone-lg {
  width: min(390px, 90vw);
  height: min(800px, 168vw);
  border-radius: 52px;
  padding: 14px;
  position: relative;
  background: #14141f;
  border: 1px solid rgba(255,255,255,0.16);
  box-shadow:
    0 40px 100px rgba(31,36,74,0.28),
    0 12px 32px rgba(31,36,74,0.16);
}
.phone.reading-phone-lg::before {
  content: '';
  position: absolute;
  inset: -60px;
  border-radius: 50%;
  background:
    radial-gradient(ellipse 60% 50% at 30% 20%, var(--orb-1), transparent 60%),
    radial-gradient(ellipse 60% 50% at 75% 80%, var(--orb-2), transparent 60%);
  filter: blur(60px);
  z-index: -1;
  opacity: 0.6;
}
.phone.reading-phone-lg .reading-screen {
  border-radius: 40px;
}
/* The preview iframe is sized to the reading's native 440x860 deck and scaled
   via JS (ReadingPhonePreview) so the layout renders exactly as designed. */
.phone.reading-phone-lg .reading-iframe {
  width: 440px;
  height: 860px;
}
.phone.reading-phone-lg .phone-bar {
  position: absolute;
  top: 9px; left: 50%; transform: translateX(-50%);
  width: 110px; height: 7px; border-radius: 4px;
  background: rgba(0,0,0,0.4);
  z-index: 3;
  pointer-events: none;
}
.reading-phone-caption {
  max-width: 420px;
  text-align: center;
  font-family: var(--font-display);
  font-style: italic;
  font-size: 18px;
  line-height: 1.45;
  color: var(--text-dim);
}

/* ───── App / phone mockup ───── */
/* (legacy single-phone styles, retained for backward compat) */
.phone {
  width: 280px; height: 580px;
  border-radius: 38px;
  background: linear-gradient(160deg, var(--bg-alt), var(--bg-soft));
  border: 1px solid var(--border-strong);
  padding: 16px;
  position: relative;
  box-shadow: 0 30px 80px rgba(0,0,0,0.3);
}
.theme-sanctuary .phone { box-shadow: 0 30px 80px rgba(31,36,74,0.12); }
.phone-screen {
  width: 100%; height: 100%;
  background: var(--bg);
  border-radius: 26px;
  padding: 28px 22px;
  display: flex; flex-direction: column;
  position: relative;
  overflow: hidden;
}
.phone-notch {
  position: absolute; top: 8px; left: 50%; transform: translateX(-50%);
  width: 80px; height: 6px; border-radius: 3px;
  background: rgba(0,0,0,0.25);
}
.phone .time { font-family: var(--font-mono); font-size: 10px; color: var(--text-dim); letter-spacing: 0.15em; }
.phone .greet { font-family: var(--font-display); font-style: italic; font-size: 28px; margin-top: 32px; line-height: 1.1; }
.phone .greet small { display: block; font-family: var(--font-body); font-size: 11px; font-style: normal; color: var(--text-dim); letter-spacing: 0.18em; text-transform: uppercase; margin-bottom: 8px; }
.phone .audio-card {
  margin-top: 28px;
  padding: 22px 18px;
  border-radius: 18px;
  background: linear-gradient(140deg, var(--orb-1), var(--orb-2));
  position: relative; overflow: hidden;
  color: #fff;
  min-height: 180px;
  display: flex; flex-direction: column; justify-content: space-between;
}
.theme-sanctuary .phone .audio-card { color: var(--text); }
.phone .audio-card .label { font-family: var(--font-mono); font-size: 9px; letter-spacing: 0.2em; text-transform: uppercase; opacity: 0.8; }
.phone .audio-card .title { font-family: var(--font-display); font-style: italic; font-size: 22px; line-height: 1.1; margin-top: 8px; }
.phone .audio-card .controls { display: flex; align-items: center; gap: 12px; margin-top: auto; }
.phone .play-btn {
  width: 38px; height: 38px; border-radius: 50%; background: rgba(255,255,255,0.25);
  border: 1px solid rgba(255,255,255,0.4);
  display: flex; align-items: center; justify-content: center;
  cursor: pointer; color: inherit;
}
.theme-sanctuary .phone .play-btn { background: rgba(255,255,255,0.6); border-color: rgba(255,255,255,0.8); }
.phone .wave { display: flex; align-items: center; gap: 2px; height: 24px; flex: 1; }
.phone .wave i {
  display: block; width: 2px; background: currentColor; opacity: 0.7; border-radius: 1px;
  animation: wave 1.2s ease-in-out infinite;
}
@keyframes wave { 0%,100% { height: 4px } 50% { height: 18px } }
.phone .session-list { margin-top: 24px; display: flex; flex-direction: column; gap: 10px; }
.phone .session-row {
  display: flex; align-items: center; gap: 12px;
  padding: 10px 0; border-bottom: 1px solid var(--border);
  font-size: 12px;
}
.phone .session-row .pill {
  width: 32px; height: 32px; border-radius: 10px;
  background: var(--accent-soft);
  display: flex; align-items: center; justify-content: center;
  font-family: var(--font-display); font-style: italic; font-size: 16px; color: var(--accent);
}
.phone .session-row .meta { font-family: var(--font-mono); font-size: 9px; color: var(--text-mute); letter-spacing: 0.1em; text-transform: uppercase; }

/* ───── Booking ───── */
.booking {
  display: grid; grid-template-columns: 1fr 1fr; gap: 0;
  border: 1px solid var(--border);
  border-radius: 6px; overflow: hidden;
  background: var(--card);
  backdrop-filter: blur(10px);
}
.booking-cal { padding: 32px; border-right: 1px solid var(--border); position: relative; }
.booking-times { padding: 32px; background: var(--bg-alt); position: relative; overflow: hidden; }
.booking-month {
  display: flex; justify-content: space-between; align-items: center;
  font-family: var(--font-display); font-style: italic; font-size: 24px;
  margin-bottom: 16px;
}
.booking-month button {
  background: transparent; border: 1px solid var(--border);
  color: var(--text-dim);
  width: 28px; height: 28px; border-radius: 50%;
  font-size: 14px; cursor: pointer; padding: 0;
  display: flex; align-items: center; justify-content: center;
  transition: all .2s;
}
.booking-month button:hover { color: var(--text); border-color: var(--border-strong); background: var(--accent-soft); }
.booking-legend {
  display: flex; gap: 14px; flex-wrap: wrap;
  font-family: var(--font-mono); font-size: 9px;
  letter-spacing: 0.18em; text-transform: uppercase;
  color: var(--text-mute);
  margin-bottom: 18px;
}
.booking-legend span { display: flex; align-items: center; gap: 6px; }
.booking-legend i {
  width: 8px; height: 8px; border-radius: 50%;
  display: inline-block;
}
.booking-grid { display: grid; grid-template-columns: repeat(7, 1fr); gap: 4px; }
.booking-grid .dow {
  font-family: var(--font-mono); font-size: 9px; letter-spacing: 0.15em; text-transform: uppercase;
  color: var(--text-mute); text-align: center; padding: 8px 0;
}
.booking-grid .day {
  position: relative;
  aspect-ratio: 1;
  display: flex; align-items: center; justify-content: center;
  border-radius: 6px; cursor: pointer; font-size: 13px;
  color: var(--text-dim);
  border: 1px solid transparent;
  transition: all .2s;
  background: transparent;
  padding: 0;
  overflow: hidden;
}
.booking-grid .day.empty { cursor: default; pointer-events: none; }
.booking-grid .day .day-num {
  position: relative; z-index: 2;
  font-family: var(--font-body);
  transition: color .2s;
}
.booking-grid .day .day-dot {
  position: absolute;
  bottom: 5px; left: 50%; transform: translateX(-50%);
  width: 4px; height: 4px; border-radius: 50%;
  background: var(--dot, var(--accent));
  opacity: 0.6; z-index: 1;
  transition: opacity .25s, transform .25s;
}
.booking-grid .day .day-moon {
  position: absolute;
  top: 4px; right: 5px;
  width: 6px; height: 6px;
  border-radius: 50%;
  border: 1px solid var(--border-strong);
  background: transparent;
  z-index: 1;
}
.booking-grid .day:not(.disabled):hover {
  color: var(--text);
  border-color: var(--dot, var(--border-strong));
  background: color-mix(in srgb, var(--dot, var(--accent)) 12%, transparent);
}
.booking-grid .day:not(.disabled):hover .day-dot {
  opacity: 1;
  transform: translateX(-50%) scale(1.4);
}
.booking-grid .day.disabled { color: var(--text-mute); opacity: 0.32; cursor: default; }
.booking-grid .day.today {
  color: var(--accent);
  border-color: var(--accent);
  background: var(--accent-soft);
}
.booking-grid .day.today .day-num { font-weight: 600; }
.booking-grid .day.selected {
  background: linear-gradient(135deg, var(--accent), color-mix(in srgb, var(--accent) 60%, #e88a6f));
  color: var(--bg);
  border-color: transparent;
  box-shadow: 0 4px 16px color-mix(in srgb, var(--accent) 35%, transparent);
}
.booking-grid .day.selected .day-num { color: var(--bg); }
.booking-grid .day.selected .day-dot { display: none; }

/* booking-times */
.b-side-glyph {
  position: absolute;
  right: -14px; top: 32px;
  width: 60px; height: 200px;
  opacity: 0.5;
  pointer-events: none;
}
.b-side-glyph svg { width: 100%; height: 100%; display: block; animation: bookingGlyphPulse 6s ease-in-out infinite; }
@keyframes bookingGlyphPulse {
  0%, 100% { opacity: 0.5; }
  50%      { opacity: 0.9; }
}
.booking-times h4 {
  font-family: var(--font-display); font-style: italic; font-size: 22px; margin: 0 0 8px;
  position: relative; z-index: 1;
}
.booking-times .b-date {
  font-family: var(--font-mono); font-size: 10px; letter-spacing: 0.2em;
  color: var(--text-mute); text-transform: uppercase; margin-bottom: 22px;
  position: relative; z-index: 1;
}

.b-slots-by-time {
  display: flex; flex-direction: column; gap: 14px;
  position: relative; z-index: 1;
}
.b-slot-group {}
.b-slot-grouphead {
  display: flex; align-items: center; gap: 8px;
  font-family: var(--font-mono); font-size: 9px;
  letter-spacing: 0.22em; text-transform: uppercase;
  color: var(--text-mute);
  margin-bottom: 8px;
}
.b-slot-dot {
  width: 8px; height: 8px; border-radius: 50%;
  box-shadow: 0 0 8px currentColor;
}
.b-slots { display: grid; grid-template-columns: 1fr 1fr; gap: 6px; }
.b-slot {
  position: relative;
  padding: 12px;
  border: 1px solid var(--border);
  border-radius: 6px;
  font-family: var(--font-body); font-size: 13px;
  color: var(--text-dim); cursor: pointer; background: transparent;
  transition: all .2s;
  overflow: hidden;
}
.b-slot::before {
  content: '';
  position: absolute; left: 0; top: 0; bottom: 0;
  width: 3px;
  background: var(--slot-color);
  opacity: 0;
  transition: opacity .25s;
}
.b-slot:hover { color: var(--text); border-color: var(--slot-color); }
.b-slot:hover::before { opacity: 1; }
.b-slot.picked {
  border-color: var(--slot-color);
  background: color-mix(in srgb, var(--slot-color) 14%, transparent);
  color: var(--text);
  font-weight: 500;
}
.b-slot.picked::before { opacity: 1; }
.b-confirm {
  margin-top: 24px; padding-top: 22px; border-top: 1px solid var(--border);
  display: flex; justify-content: space-between; align-items: center;
  position: relative; z-index: 1;
}

/* ───── Session packages ───── */
.package-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 24px;
  align-items: stretch;
}
.package-grid .package-card {
  flex-direction: column;
  gap: 18px;
  padding: 36px 30px;
}
.package-grid .package-glyph { width: 56px; height: 56px; }
.package-grid .package-cta { margin-top: auto; align-self: flex-start; }
.package-tag {
  position: absolute; top: 20px; right: 20px;
  font-family: var(--font-mono); font-size: 9px; letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--pkg-accent);
  padding: 4px 10px;
  border: 1px solid color-mix(in srgb, var(--pkg-accent) 55%, transparent);
  border-radius: 999px;
  background: color-mix(in srgb, var(--pkg-accent) 10%, transparent);
}
.package-cta {
  background: var(--pkg-accent) !important;
  border-color: var(--pkg-accent) !important;
  color: #fff !important;
}
.package-cta:hover {
  filter: brightness(1.07);
  transform: translateX(2px);
}
@media (max-width: 920px) {
  .package-grid { grid-template-columns: 1fr; }
}

.package-card {
  position: relative;
  display: flex; gap: 22px;
  padding: 28px 26px;
  border: 1px solid var(--border);
  border-radius: 8px;
  background: var(--card);
  backdrop-filter: blur(10px);
  transition: all .35s cubic-bezier(.2,.7,.3,1);
  overflow: hidden;
}
.package-card::before {
  content: '';
  position: absolute; left: 0; top: 0; bottom: 0;
  width: 3px;
  background: var(--pkg-accent);
  opacity: 0.75;
}
.package-card::after {
  content: '';
  position: absolute; right: -40px; top: -40px;
  width: 160px; height: 160px;
  border-radius: 50%;
  background: radial-gradient(circle,
    color-mix(in srgb, var(--pkg-accent) 50%, transparent) 0%,
    transparent 70%);
  opacity: 0.25;
  pointer-events: none;
  transition: opacity .35s, transform .35s;
}
.package-card:hover {
  border-color: color-mix(in srgb, var(--pkg-accent) 50%, var(--border-strong));
  transform: translateY(-2px);
  box-shadow: 0 12px 32px color-mix(in srgb, var(--pkg-accent) 18%, transparent);
}
.package-card:hover::after {
  opacity: 0.5;
  transform: scale(1.15);
}
.package-glyph {
  flex: 0 0 auto;
  width: 64px; height: 64px;
  display: flex; align-items: center; justify-content: center;
  position: relative;
}
.package-glyph svg { width: 100%; height: 100%; display: block; animation: packageGlyph 8s ease-in-out infinite; }
@keyframes packageGlyph {
  0%, 100% { transform: scale(1) rotate(0deg); }
  50%      { transform: scale(1.06) rotate(8deg); }
}
.package-body { flex: 1; min-width: 0; }
.package-body h3 {
  font-family: var(--font-display); font-style: italic;
  font-size: 22px; line-height: 1.2;
  color: var(--text);
  margin: 0;
}
.package-meta {
  display: flex; align-items: center; gap: 10px;
  font-family: var(--font-mono); font-size: 10px;
  letter-spacing: 0.22em; text-transform: uppercase;
  color: var(--text-mute);
  margin-top: 10px;
}
.package-dot {
  width: 6px; height: 6px; border-radius: 50%;
  background: var(--pkg-accent);
  box-shadow: 0 0 8px var(--pkg-accent);
}
.package-body p {
  margin-top: 14px;
  color: var(--text-dim);
  font-size: 14px; line-height: 1.6;
}

/* ───── White label preview ───── */
.wl-preview {
  border: 1px solid var(--border);
  border-radius: 6px;
  background: var(--bg-alt);
  overflow: hidden;
}
.wl-bar {
  padding: 12px 18px;
  border-bottom: 1px solid var(--border);
  display: flex; align-items: center; gap: 8px;
  font-family: var(--font-mono); font-size: 10px;
  letter-spacing: 0.15em; text-transform: uppercase;
  color: var(--text-mute);
}
.wl-bar .dots { display: flex; gap: 5px; }
.wl-bar .dots i { width: 8px; height: 8px; border-radius: 50%; background: var(--border-strong); display: block; }
.wl-bar .url { margin-left: auto; }
.wl-stage { padding: 56px 48px; min-height: 360px; position: relative; }
.wl-stage .wl-brand {
  font-family: var(--font-display); font-style: italic; font-size: 26px;
  color: var(--wl-color, var(--accent));
  margin-bottom: 16px;
}
.wl-stage h3 { color: var(--wl-color, var(--text)); margin-bottom: 14px; }
.wl-stage p { color: var(--text-dim); font-size: 14px; max-width: 420px; }
.wl-stage .wl-cta {
  margin-top: 28px;
  padding: 12px 22px;
  background: var(--wl-color, var(--accent));
  color: #fff; border-radius: 999px;
  display: inline-block; font-size: 13px;
  cursor: pointer;
}
.wl-controls {
  margin-top: 24px;
  display: flex; gap: 12px; align-items: center;
  font-family: var(--font-mono); font-size: 11px; letter-spacing: 0.15em; text-transform: uppercase; color: var(--text-mute);
}
.wl-swatch {
  width: 28px; height: 28px; border-radius: 50%;
  cursor: pointer; border: 2px solid transparent;
  transition: border-color .2s;
}
.wl-swatch.on { border-color: var(--text); }

.wl-form { display: flex; flex-direction: column; gap: 16px; }
.wl-form label { font-family: var(--font-mono); font-size: 10px; letter-spacing: 0.18em; text-transform: uppercase; color: var(--text-mute); display: block; margin-bottom: 6px; }
.wl-form input, .wl-form textarea, .wl-form select {
  width: 100%;
  background: transparent;
  border: 0; border-bottom: 1px solid var(--border);
  padding: 10px 0;
  font-family: var(--font-body); font-size: 15px;
  color: var(--text);
  transition: border-color .2s;
}
.wl-form textarea { min-height: 80px; resize: vertical; font-family: var(--font-body); }
.wl-form input:focus, .wl-form textarea:focus, .wl-form select:focus {
  outline: 0; border-color: var(--accent);
}
.wl-form input::placeholder, .wl-form textarea::placeholder { color: var(--text-mute); }

/* ───── Testimonials ───── */
.t-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 24px; }
.testimonial {
  padding: 36px 32px;
  border: 1px solid var(--border);
  border-radius: 4px;
  background: var(--card);
  display: flex; flex-direction: column; gap: 20px;
}
.testimonial blockquote {
  font-family: var(--font-display); font-style: italic; font-size: 22px;
  line-height: 1.3; margin: 0; color: var(--text);
  letter-spacing: -0.005em;
}
.testimonial .who { font-family: var(--font-mono); font-size: 10px; letter-spacing: 0.2em; color: var(--text-mute); text-transform: uppercase; }
.testimonial .who strong { color: var(--text-dim); font-weight: 400; }

/* ───── About ───── */
.about-portrait {
  width: 100%;
  aspect-ratio: 4 / 5;
  border-radius: 4px;
  background:
    repeating-linear-gradient(135deg, var(--card) 0 16px, var(--bg-soft) 16px 32px),
    var(--bg-alt);
  border: 1px solid var(--border);
  display: flex; align-items: flex-end; justify-content: flex-start; padding: 24px;
  position: relative; overflow: hidden;
}
.about-portrait .ph-label {
  font-family: var(--font-mono); font-size: 10px; letter-spacing: 0.2em; text-transform: uppercase;
  color: var(--text-mute);
}
.no-imagery .orbs,
.no-imagery .about-portrait,
.no-imagery .phone .audio-card { display: none !important; }
.no-imagery .phone { background: var(--bg-alt); }
.no-imagery .booking { background: var(--bg-alt); }

/* ───── FAQ ───── */
.faq-item {
  border-bottom: 1px solid var(--border);
  padding: 28px 0;
  cursor: pointer;
}
.faq-item:first-child { border-top: 1px solid var(--border); }
.faq-q { display: flex; justify-content: space-between; align-items: center; gap: 24px; }
.faq-q h3 {
  font-family: var(--font-display); font-style: italic; font-size: 22px;
  line-height: 1.2; color: var(--text); margin: 0;
}
.faq-toggle {
  font-family: var(--font-mono); font-size: 18px; color: var(--text-dim); transition: transform .3s;
}
.faq-item.open .faq-toggle { transform: rotate(45deg); }
.faq-a {
  max-height: 0; overflow: hidden;
  transition: max-height .4s, margin .4s, opacity .4s;
  opacity: 0;
  color: var(--text-dim);
  font-size: 15px; max-width: 680px;
}
.faq-item.open .faq-a {
  max-height: 200px; opacity: 1;
  margin-top: 16px;
}

/* ───── Journal ───── */
.j-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 24px; }
.j-card {
  padding: 32px 24px;
  border: 1px solid var(--border); border-radius: 4px;
  background: var(--card);
  transition: all .3s;
  cursor: pointer;
}
.j-card:hover { background: var(--card-hover); border-color: var(--border-strong); }
.j-card .j-meta { font-family: var(--font-mono); font-size: 10px; letter-spacing: 0.2em; color: var(--text-mute); text-transform: uppercase; margin-bottom: 18px; }
.j-card h3 { font-family: var(--font-display); font-style: italic; font-size: 22px; line-height: 1.2; margin-bottom: 12px; }
.j-card p { color: var(--text-dim); font-size: 14px; line-height: 1.55; }

/* ───── Newsletter band ───── */
.nl {
  padding: 100px 0;
  background: var(--bg-alt);
  border-top: 1px solid var(--border);
  border-bottom: 1px solid var(--border);
}
.nl-form {
  display: flex; gap: 0; max-width: 540px; margin-top: 28px;
  border-bottom: 1px solid var(--border-strong);
}
.nl-form input {
  flex: 1; background: transparent; border: 0; padding: 14px 0;
  color: var(--text); font-family: var(--font-body); font-size: 16px;
}
.nl-form input::placeholder { color: var(--text-mute); }
.nl-form input:focus { outline: 0; }
.nl-form button {
  background: transparent; border: 0;
  color: var(--text); font-family: var(--font-body); font-size: 13px;
  letter-spacing: 0.04em; cursor: pointer;
  display: flex; align-items: center; gap: 8px;
}

/* ───── Footer ───── */
.footer {
  padding: 80px 0 48px;
  background: var(--bg);
  position: relative;
}
.footer-grid {
  display: grid; grid-template-columns: 2fr 1fr 1fr; gap: 48px;
  padding-bottom: 56px;
  border-bottom: 1px solid var(--border);
}
.footer h4 {
  font-family: var(--font-mono); font-size: 10px; letter-spacing: 0.2em;
  text-transform: uppercase; color: var(--text-mute);
  margin: 0 0 18px;
}
.footer ul { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: 10px; }
.footer a { color: var(--text-dim); text-decoration: none; font-size: 14px; transition: color .2s; }
.footer a:hover { color: var(--text); }
.footer-brand { font-family: var(--font-display); font-style: italic; font-size: 32px; margin-bottom: 14px; }
.footer-brand em { color: var(--accent); }
.footer-tag { color: var(--text-dim); font-size: 14px; max-width: 320px; line-height: 1.55; }
.footer-bottom {
  margin-top: 28px;
  display: flex; justify-content: space-between; align-items: center;
  font-family: var(--font-mono); font-size: 10px; letter-spacing: 0.15em;
  text-transform: uppercase; color: var(--text-mute);
}

/* ───── Scroll-triggered reveal for sections ─────
   Gated behind .js-reveal so sections are VISIBLE by default and only
   hide-then-animate once JS confirms it will reveal them. This guarantees
   content can never be stuck invisible if the observer/timeline misbehaves. */
.atlas-root.js-reveal section:not(.hero):not(.product-hero),
.atlas-root.js-reveal .nl {
  opacity: 0;
  transform: translateY(40px);
  transition: opacity 1.1s cubic-bezier(.16,.84,.3,1), transform 1.1s cubic-bezier(.16,.84,.3,1);
  will-change: opacity, transform;
}
.atlas-root.js-reveal section:not(.hero):not(.product-hero).in-view,
.atlas-root.js-reveal .nl.in-view {
  opacity: 1;
  transform: translateY(0);
}

/* ───── Misc ───── */
/* ───── Session checkout page ───── */
.co-hero {
  padding: 40px 0 36px;
  position: relative; overflow: hidden;
  text-align: center;
}
.co-hero .wrap { position: relative; z-index: 2; }
.co-title { font-size: clamp(40px, 5vw, 72px); margin-top: 8px; }
.co-rail {
  margin: 40px auto 0;
  display: flex; justify-content: center; gap: 8px; flex-wrap: wrap;
}
.co-step {
  display: flex; align-items: center; gap: 10px;
  padding: 10px 18px;
  border: 1px solid var(--border);
  border-radius: 999px;
  font-family: var(--font-mono); font-size: 10px; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--text-mute);
  transition: all .3s;
}
.co-step.on { border-color: var(--accent); color: var(--text); background: var(--accent-soft); }
.co-step.done { color: var(--text-dim); border-color: var(--border-strong); }
.co-step-num {
  width: 20px; height: 20px; border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  border: 1px solid currentColor; font-size: 9px;
}
.co-step.on .co-step-num { background: var(--accent); color: #fff; border-color: var(--accent); }

.co-body { padding: 60px 0 120px; }
.co-layout {
  display: grid; grid-template-columns: 1fr 340px; gap: 32px;
  align-items: start;
}
.co-panel {
  border: 1px solid var(--border); border-radius: 10px;
  background: var(--card); backdrop-filter: blur(10px);
  padding: 36px;
}
.co-panel-head {
  display: flex; align-items: center; justify-content: space-between; gap: 16px;
  margin-bottom: 28px; flex-wrap: wrap;
}
.co-panel-head h2 { font-size: clamp(26px, 3vw, 36px); }
.co-gcal {
  display: flex; align-items: center; gap: 8px;
  font-family: var(--font-mono); font-size: 10px; letter-spacing: 0.1em;
  text-transform: uppercase; color: var(--text-dim);
  padding: 7px 12px; border: 1px solid var(--border); border-radius: 999px;
  background: var(--bg-soft);
}
.co-gcal span { display: flex; align-items: center; gap: 7px; }
.co-live-dot {
  width: 6px; height: 6px; border-radius: 50%; background: #34A853;
  box-shadow: 0 0 0 0 rgba(52,168,83,0.5);
  animation: coLive 2s ease-out infinite;
}
@keyframes coLive {
  0% { box-shadow: 0 0 0 0 rgba(52,168,83,0.5); }
  70% { box-shadow: 0 0 0 6px rgba(52,168,83,0); }
  100% { box-shadow: 0 0 0 0 rgba(52,168,83,0); }
}
.co-back {
  background: transparent; border: 0; cursor: pointer;
  font-family: var(--font-mono); font-size: 11px; letter-spacing: 0.1em;
  text-transform: uppercase; color: var(--text-dim);
  transition: color .2s;
}
.co-back:hover { color: var(--text); }

.co-booking { display: grid; grid-template-columns: 1fr 1fr; gap: 36px; }
.co-cal-head {
  display: flex; align-items: center; justify-content: space-between;
  margin-bottom: 18px;
}
.co-cal-month { font-family: var(--font-display); font-style: italic; font-size: 22px; }
.co-cal-nav {
  width: 34px; height: 34px; border-radius: 50%;
  border: 1px solid var(--border); background: transparent;
  color: var(--text-dim); font-size: 18px; cursor: pointer;
  transition: all .2s;
}
.co-cal-nav:hover:not(:disabled) { color: var(--text); border-color: var(--border-strong); }
.co-cal-nav:disabled { opacity: 0.3; cursor: default; }
.co-cal-grid { display: grid; grid-template-columns: repeat(7, 1fr); gap: 4px; }
.co-dow {
  font-family: var(--font-mono); font-size: 9px; letter-spacing: 0.1em;
  text-transform: uppercase; color: var(--text-mute);
  text-align: center; padding: 6px 0;
}
.co-day {
  aspect-ratio: 1; display: flex; align-items: center; justify-content: center;
  border-radius: 8px; border: 1px solid transparent; background: transparent;
  font-family: var(--font-body); font-size: 14px; color: var(--text);
  cursor: pointer; transition: all .18s;
}
.co-day.empty { cursor: default; }
.co-day:not(.disabled):not(.empty):hover { border-color: var(--accent); }
.co-day.disabled { color: var(--text-mute); opacity: 0.35; cursor: default; }
.co-day.today { box-shadow: inset 0 0 0 1px var(--border-strong); }
.co-day.sel { background: var(--accent); color: #fff; }
.co-legend {
  display: flex; gap: 16px; margin-top: 20px;
  font-family: var(--font-mono); font-size: 9px; letter-spacing: 0.08em;
  text-transform: uppercase; color: var(--text-mute);
}
.co-legend span { display: flex; align-items: center; gap: 6px; }
.co-legend .lg { width: 9px; height: 9px; border-radius: 3px; }
.co-legend .lg.sel { background: var(--accent); }
.co-legend .lg.open { border: 1px solid var(--border-strong); }
.co-legend .lg.off { background: var(--border); }

.co-timecol { border-left: 1px solid var(--border); padding-left: 36px; }
.co-slots-empty {
  color: var(--text-mute); font-size: 14px; font-style: italic;
  font-family: var(--font-display); padding-top: 8px;
}
.co-slots-date { font-family: var(--font-display); font-style: italic; font-size: 20px; white-space: nowrap; }
.co-tz {
  font-family: var(--font-mono); font-size: 9px; letter-spacing: 0.12em;
  text-transform: uppercase; color: var(--text-mute); margin: 6px 0 20px;
}
.co-slots { display: grid; gap: 8px; }
.co-slot {
  position: relative;
  padding: 14px 16px; border: 1px solid var(--border); border-radius: 8px;
  background: transparent; cursor: pointer;
  font-family: var(--font-body); font-size: 14px; color: var(--text);
  text-align: left; transition: all .18s;
  display: flex; align-items: center; justify-content: space-between;
}
.co-slot:not(.taken):hover { border-color: var(--accent); }
.co-slot.sel { background: var(--accent-soft); border-color: var(--accent); }
.co-slot.taken { color: var(--text-mute); opacity: 0.5; cursor: default; text-decoration: line-through; }
.co-slot-tag {
  font-family: var(--font-mono); font-size: 8px; letter-spacing: 0.14em;
  text-transform: uppercase; text-decoration: none;
}
.co-panel-foot {
  display: flex; align-items: center; justify-content: space-between; gap: 16px;
  margin-top: 32px; padding-top: 24px; border-top: 1px solid var(--border);
  flex-wrap: wrap;
}
.co-foot-pick {
  font-family: var(--font-mono); font-size: 11px; letter-spacing: 0.08em;
  color: var(--text-dim);
}

/* ── payment ── */
.co-when-strip {
  display: flex; align-items: center; gap: 10px;
  padding: 14px 18px; border-radius: 8px; background: var(--bg-soft);
  border: 1px solid var(--border);
  font-family: var(--font-mono); font-size: 11px; letter-spacing: 0.06em;
  color: var(--text-dim); margin-bottom: 28px;
}
.co-when-strip svg { color: var(--accent); flex: 0 0 auto; }
.co-field-group { margin-bottom: 28px; }
.co-group-label {
  display: flex; align-items: center; justify-content: space-between;
  font-family: var(--font-mono); font-size: 10px; letter-spacing: 0.18em;
  text-transform: uppercase; color: var(--text-mute); margin-bottom: 16px;
}
.co-secure { color: var(--text-dim); letter-spacing: 0.08em; }
.co-field { margin-bottom: 16px; }
.co-field label {
  display: block;
  font-family: var(--font-mono); font-size: 10px; letter-spacing: 0.12em;
  text-transform: uppercase; color: var(--text-mute); margin-bottom: 7px;
}
.co-field input {
  width: 100%; background: var(--bg-soft);
  border: 1px solid var(--border); border-radius: 8px;
  padding: 13px 15px; font-family: var(--font-body); font-size: 15px;
  color: var(--text); transition: border-color .2s;
}
.co-field input:focus { outline: 0; border-color: var(--accent); }
.co-field input::placeholder { color: var(--text-mute); }
.co-field-row { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; }
.co-paybtn { width: 100%; justify-content: center; margin-top: 8px; }
.co-paybtn:disabled { opacity: 0.45; cursor: default; }
.co-pay-fine {
  margin-top: 16px; text-align: center;
  font-family: var(--font-mono); font-size: 10px; letter-spacing: 0.04em;
  color: var(--text-mute); line-height: 1.5;
}

/* ── order summary ── */
.co-summary {
  border: 1px solid var(--border); border-radius: 10px;
  background: var(--bg-alt); padding: 30px 26px;
  position: sticky; top: 90px;
}
.co-sum-glyph { width: 52px; height: 52px; margin-bottom: 18px; }
.co-sum-glyph .package-glyph { width: 52px; height: 52px; }
.co-summary h3 {
  font-family: var(--font-display); font-style: italic; font-size: 24px;
  margin: 8px 0 20px; color: var(--text);
}
.co-sum-row {
  display: flex; justify-content: space-between; gap: 12px;
  padding: 11px 0; border-bottom: 1px solid var(--border);
  font-size: 13px; color: var(--text-dim);
}
.co-sum-row span:first-child {
  font-family: var(--font-mono); font-size: 10px; letter-spacing: 0.12em;
  text-transform: uppercase; color: var(--text-mute);
}
.co-sum-row span:last-child { color: var(--text); text-align: right; }
.co-sum-total {
  display: flex; justify-content: space-between; align-items: baseline;
  margin-top: 18px; padding-top: 16px; border-top: 1px solid var(--border-strong);
}
.co-sum-total span {
  font-family: var(--font-mono); font-size: 11px; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--text-mute);
}
.co-sum-total strong {
  font-family: var(--font-display); font-style: italic; font-weight: 500;
  font-size: 32px; color: var(--text);
}
.co-sum-total small { font-family: var(--font-mono); font-size: 11px; letter-spacing: 0.08em; }
.co-sum-note {
  margin-top: 18px; font-size: 12px; line-height: 1.55; color: var(--text-mute);
}

.cal-embed {
  width: 100%;
  min-height: 720px;
  overflow: auto;
  border-radius: 10px;
  border: 1px solid var(--border);
  background: #fff;
}
.co-step-note {
  font-size: 14px; line-height: 1.55; color: var(--text-dim);
  margin: -8px 0 24px;
}
.co-availability {
  margin-top: 24px; padding-top: 22px;
  border-top: 1px solid var(--border);
}
.co-avail-label {
  display: block;
  font-family: var(--font-mono); font-size: 10px; letter-spacing: 0.18em;
  text-transform: uppercase; color: var(--text-mute); margin-bottom: 8px;
}
.co-avail-note {
  font-size: 14px; line-height: 1.55; color: var(--text-dim); margin: 0 0 12px;
}
.co-avail-field {
  width: 100%; background: #fff;
  border: 1px solid var(--border-strong); border-radius: 8px;
  padding: 13px 15px; font-family: var(--font-body); font-size: 15px;
  color: var(--text); resize: vertical; min-height: 80px;
  transition: border-color .2s;
}
.co-avail-field:focus { outline: 0; border-color: var(--accent); }
.co-avail-field::placeholder { color: var(--text-mute); }
.co-paid-note {
  display: flex; align-items: center; gap: 10px;
  padding: 14px 18px; margin-bottom: 22px;
  border-radius: 10px;
  background: var(--accent-soft);
  border: 1px solid color-mix(in srgb, var(--accent) 40%, transparent);
  font-family: var(--font-display); font-style: italic; font-size: 16px;
  color: var(--text);
}
.co-paid-mark {
  width: 28px; height: 28px; flex: 0 0 auto; border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  background: var(--accent); color: #fff; font-size: 14px; font-style: normal;
}
@media (max-width: 720px) {
  .cal-embed { min-height: 560px; }
}

/* ── confirmation ── */
.co-confirm { max-width: 620px; margin: 0 auto; text-align: center; }
.co-confirm-orb { width: 88px; height: 88px; margin: 0 auto 28px; }
.co-confirm-orb .package-glyph { width: 88px; height: 88px; }
.co-confirm h2 { font-size: clamp(34px, 4.5vw, 56px); margin-top: 14px; }
.co-confirm > p {
  margin: 22px auto 0; max-width: 480px;
  color: var(--text-dim); font-size: 16px; line-height: 1.6;
}
.co-confirm-card {
  margin: 36px auto 0; max-width: 460px; text-align: left;
  border: 1px solid var(--border); border-radius: 10px;
  background: var(--card); padding: 24px 28px;
}
.co-confirm-cta {
  margin-top: 32px; display: flex; gap: 14px; justify-content: center; flex-wrap: wrap;
}
@media (max-width: 920px) {
  .co-layout { grid-template-columns: 1fr; }
  .co-booking { grid-template-columns: 1fr; }
  .co-timecol { border-left: 0; padding-left: 0; border-top: 1px solid var(--border); padding-top: 24px; }
  .co-summary { position: static; }
}

/* ───── Contact page ───── */
.contact-hero {
  padding: 60px 0 20px; position: relative; z-index: 1; text-align: center;
}
.contact-hero .eyebrow { display: block; margin-bottom: 18px; }
.contact-hero h1 { font-size: clamp(44px, 5.5vw, 84px); }
.contact-hero .contact-lede {
  margin: 28px auto 0; max-width: 560px;
  font-size: 17px; line-height: 1.6; color: var(--text-dim);
  text-align: center;
}
.contact-body { padding: 56px 0 110px; position: relative; z-index: 1; }
.contact-body .contact-grid {
  display: block;
  max-width: 620px; margin: 0 auto;
}
/* clean, un-greyed fields on the contact form */
.contact-form .co-field input,
.contact-form textarea {
  background: #ffffff;
  border-color: var(--border-strong);
}
.contact-form-wrap {
  border: 1px solid var(--border); border-radius: 12px;
  background: var(--card); backdrop-filter: blur(10px);
  padding: 40px;
}
.contact-form .co-field { margin-bottom: 20px; }
.contact-form textarea {
  width: 100%; background: #ffffff;
  border: 1px solid var(--border-strong); border-radius: 8px;
  padding: 13px 15px; font-family: var(--font-body); font-size: 15px;
  color: var(--text); resize: vertical; min-height: 120px;
  transition: border-color .2s;
}
.contact-form textarea:focus { outline: 0; border-color: var(--accent); }
.contact-form textarea::placeholder { color: var(--text-mute); }
.contact-submit { margin-top: 8px; }
.contact-submit:disabled { opacity: 0.45; cursor: default; }
.contact-fine {
  margin-top: 16px;
  font-family: var(--font-mono); font-size: 10px; letter-spacing: 0.06em;
  color: var(--text-mute); line-height: 1.5;
}
.contact-done { text-align: center; padding: 30px 10px; }
.contact-done-mark {
  width: 56px; height: 56px; margin: 0 auto 22px; border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  background: var(--accent-soft); color: var(--accent); font-size: 22px;
}
.contact-done h3 { font-family: var(--font-display); font-style: italic; font-size: 32px; }
.contact-done p { margin: 14px auto 26px; max-width: 400px; color: var(--text-dim); font-size: 15px; }
.contact-aside { position: sticky; top: 88px; }
.contact-card {
  border: 1px solid var(--border); border-radius: 12px;
  background: var(--bg-alt); padding: 30px 28px;
}
.contact-card .eyebrow { display: block; margin-bottom: 18px; }
.contact-list { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: 16px; }
.contact-list li { display: flex; flex-direction: column; gap: 4px; }
.contact-list-label {
  font-family: var(--font-mono); font-size: 10px; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--text-mute);
}
.contact-list-val { font-size: 15px; color: var(--text); }
.contact-divider { height: 1px; background: var(--border); margin: 24px 0; }
.contact-note { font-size: 13px; line-height: 1.55; color: var(--text-dim); }
@media (max-width: 860px) {
  .contact-grid { grid-template-columns: 1fr; }
  .contact-aside { position: static; }
}

/* ───── Mobile sticky buy bar (product page, phones only) ───── */
.mobile-buybar { display: none; }
@media (max-width: 720px) {
  .mobile-buybar {
    display: flex; align-items: center; justify-content: space-between; gap: 14px;
    position: fixed; left: 0; right: 0; bottom: 0; z-index: 90;
    padding: 11px 18px calc(11px + env(safe-area-inset-bottom, 0px));
    background: color-mix(in srgb, var(--bg) 92%, transparent);
    -webkit-backdrop-filter: blur(16px); backdrop-filter: blur(16px);
    border-top: 1px solid var(--border-strong);
  }
  .mobile-buybar .mb-info { display: flex; flex-direction: column; gap: 1px; line-height: 1.1; }
  .mobile-buybar .mb-label {
    font-family: var(--font-mono); font-size: 9px; letter-spacing: 0.16em;
    text-transform: uppercase; color: var(--text-mute);
  }
  .mobile-buybar .mb-price {
    font-family: var(--font-display); font-style: italic; font-size: 22px; color: var(--text);
  }
  .mobile-buybar .mb-price small {
    font-family: var(--font-mono); font-size: 9px; letter-spacing: 0.14em;
    text-transform: uppercase; color: var(--text-mute); font-style: normal;
  }
  .mobile-buybar .btn { flex: 0 0 auto; padding: 12px 18px; font-size: 13px; }
  /* keep page content clear of the fixed bar */
  .product-page .product-shell { padding-bottom: 110px; }
}

/* ───── Waitlist modal ───── */
.wl-overlay {
  position: fixed; inset: 0; z-index: 200;
  display: flex; align-items: center; justify-content: center;
  padding: 24px;
  background: color-mix(in srgb, var(--bg) 55%, rgba(13,18,48,0.55));
  backdrop-filter: blur(8px);
  animation: wlFade .3s ease;
}
@keyframes wlFade { from { opacity: 0; } to { opacity: 1; } }
.wl-modal {
  position: relative;
  width: 100%; max-width: 480px;
  background: var(--bg-alt);
  border: 1px solid var(--border-strong);
  border-radius: 14px;
  overflow: hidden;
  box-shadow: 0 40px 100px rgba(13,18,48,0.35);
  animation: wlRise .4s cubic-bezier(.16,.84,.3,1);
}
@keyframes wlRise { from { transform: translateY(20px) scale(.98); opacity: 0; } to { transform: none; opacity: 1; } }
.wl-modal .orbs { opacity: 0.5; }
.wl-modal-inner { position: relative; z-index: 2; padding: 48px 44px 40px; }
.wl-close {
  position: absolute; top: 16px; right: 18px; z-index: 3;
  width: 34px; height: 34px; border-radius: 50%;
  border: 1px solid var(--border); background: transparent;
  color: var(--text-dim); font-size: 22px; line-height: 1; cursor: pointer;
  transition: all .2s;
}
.wl-close:hover { color: var(--text); border-color: var(--border-strong); }
.wl-modal-inner .eyebrow { display: block; margin-bottom: 16px; }
.wl-modal-inner h3 {
  font-family: var(--font-display); font-style: italic;
  font-size: clamp(28px, 4vw, 38px); line-height: 1.1; color: var(--text);
}
.wl-modal-inner > p {
  margin-top: 16px; color: var(--text-dim); font-size: 15px; line-height: 1.6;
}
.wl-modal-form { margin-top: 28px; display: flex; flex-direction: column; gap: 12px; }
.wl-modal-form input {
  width: 100%; background: var(--bg-soft);
  border: 1px solid var(--border); border-radius: 8px;
  padding: 14px 16px; font-family: var(--font-body); font-size: 15px;
  color: var(--text); transition: border-color .2s;
}
.wl-modal-form input:focus { outline: 0; border-color: var(--accent); }
.wl-modal-form input::placeholder { color: var(--text-mute); }
.wl-modal-form .btn { justify-content: center; }
.wl-modal-form .btn:disabled { opacity: 0.5; cursor: default; }
.wl-fine {
  display: block; margin-top: 16px;
  font-family: var(--font-mono); font-size: 10px; letter-spacing: 0.14em;
  text-transform: uppercase; color: var(--text-mute);
}
.wl-done { text-align: center; }
.wl-done-mark {
  width: 56px; height: 56px; margin: 0 auto 20px; border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  background: var(--accent-soft); color: var(--accent); font-size: 22px;
}
.wl-done h3 { font-family: var(--font-display); font-style: italic; font-size: 32px; }
.wl-done p { margin: 14px 0 26px; color: var(--text-dim); font-size: 15px; }

/* ───── Product page (the atlas of you) ───── */
/* sticky buy-box rail + scrolling content stream */
.atlas-root.product-page { overflow: visible; }
/* stack the body·mind·soul explorer: diagram on top, content below */
.product-page .prod-block .split.wide {
  grid-template-columns: 1fr;
  gap: 8px;
  justify-items: center;
}
.product-page .prod-block .bms-content {
  text-align: center;
  max-width: 560px;
  margin: 0 auto;
}
.product-page .prod-block .bms-content ul {
  display: inline-flex; flex-direction: column; text-align: left;
}
.product-shell {
  display: grid;
  grid-template-columns: minmax(0, 1fr) clamp(260px, 30vw, 380px);
  gap: clamp(28px, 4vw, 60px);
  align-items: start;
  padding-top: 40px;
  padding-bottom: 100px;
  position: relative;
  z-index: 1;
}
.product-aside {
  grid-column: 2; grid-row: 1;
  position: sticky; top: 88px;
  align-self: start;
}
.product-stream {
  grid-column: 1; grid-row: 1;
  min-width: 0;
  display: flex; flex-direction: column;
  gap: 110px;
}
.product-aside .buybox { max-width: 100%; }
.product-stream .shop-visual { align-items: flex-start; }
.product-stream .shop-visual .reading-phone-lg { margin: 0 auto; }
@media (max-width: 720px) {
  .product-shell { grid-template-columns: 1fr; gap: 40px; }
  .product-aside, .product-stream { grid-column: 1; grid-row: auto; }
  .product-aside { position: static; }
  .product-stream { gap: 64px; }
  .product-stream .shop-visual { align-items: center; }
}

/* shop-style product hero: visual + buy box */
.shop-hero { padding: 28px 0 80px; }
.shop-hero-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 72px;
  align-items: center;
}
.shop-visual {
  display: flex; flex-direction: column; align-items: center; gap: 18px;
}
.shop-visual-cap {
  font-family: var(--font-mono); font-size: 10px;
  letter-spacing: 0.22em; text-transform: uppercase; color: var(--text-mute);
}
.buybox { max-width: 480px; text-align: left; }
.buybox .eyebrow { display: block; margin-bottom: 16px; }
.buybox h1 {
  font-size: clamp(40px, 4.6vw, 64px);
  line-height: 1.04;
  text-align: left;
  margin-bottom: 6px;
}
.buybox-stars {
  display: flex; align-items: center; gap: 12px;
  margin-top: 18px;
}
.buybox-stars .stars { color: var(--accent-2); letter-spacing: 2px; font-size: 15px; }
.buybox-stars small {
  font-family: var(--font-mono); font-size: 10px;
  letter-spacing: 0.16em; text-transform: uppercase; color: var(--text-mute);
}
.buybox-desc {
  margin-top: 20px;
  font-size: 16px; line-height: 1.6; color: var(--text-dim);
}
.buybox-price {
  margin-top: 28px;
  display: flex; align-items: baseline; gap: 10px; flex-wrap: wrap;
}
.buybox-price .amt {
  font-family: var(--font-display); font-style: italic;
  font-size: 52px; line-height: 1; color: var(--text);
}
.buybox-price .cur {
  font-family: var(--font-mono); font-size: 12px;
  letter-spacing: 0.2em; text-transform: uppercase; color: var(--text-mute);
}
.buybox-price .once {
  margin-left: auto;
  font-family: var(--font-mono); font-size: 10px;
  letter-spacing: 0.16em; text-transform: uppercase; color: var(--text-mute);
}
.buybox-includes {
  list-style: none; padding: 0;
  margin: 26px 0 0;
  display: flex; flex-direction: column; gap: 12px;
}
.buybox-includes li {
  display: flex; align-items: flex-start; gap: 12px;
  font-size: 15px; color: var(--text-dim); line-height: 1.45;
}
.buybox-includes li::before {
  content: '✦';
  color: var(--accent);
  font-size: 13px;
  line-height: 1.5;
  flex: 0 0 auto;
}
.buybox-cta {
  margin-top: 30px;
  width: 100%;
  justify-content: center;
  font-size: 15px;
  padding: 18px 28px;
}
.buybox-trust {
  margin-top: 18px;
  display: flex; gap: 22px; flex-wrap: wrap;
  font-family: var(--font-mono); font-size: 10px;
  letter-spacing: 0.16em; text-transform: uppercase; color: var(--text-mute);
}
.buybox-trust span { display: flex; align-items: center; gap: 7px; }
.buybox-trust span::before {
  content: ''; width: 5px; height: 5px; border-radius: 50%;
  background: var(--accent); opacity: 0.7;
}

/* sticky buy bar */
.buybar {
  position: fixed; left: 0; right: 0; bottom: 0;
  z-index: 60;
  transform: translateY(110%);
  transition: transform .4s cubic-bezier(.2,.7,.3,1);
  background: color-mix(in srgb, var(--bg) 88%, transparent);
  backdrop-filter: blur(20px); -webkit-backdrop-filter: blur(20px);
  border-top: 1px solid var(--border);
}
.buybar.show { transform: translateY(0); }
.buybar-inner {
  max-width: 1180px; margin: 0 auto;
  padding: 14px 64px;
  display: flex; align-items: center; justify-content: space-between; gap: 20px;
}
.buybar-info { display: flex; align-items: baseline; gap: 16px; }
.buybar-name {
  font-family: var(--font-display); font-style: italic; font-size: 22px;
  color: var(--text);
}
.buybar-price {
  font-family: var(--font-display); font-style: italic; font-size: 22px;
  color: var(--accent);
}
.buybar-price small {
  font-family: var(--font-mono); font-size: 10px;
  letter-spacing: 0.18em; text-transform: uppercase; color: var(--text-mute);
  font-style: normal; margin-left: 4px;
}
@media (max-width: 900px) {
  .shop-hero-grid { grid-template-columns: 1fr; gap: 40px; }
  .buybox { max-width: 100%; }
  .buybar-inner { padding: 12px 24px; }
  .buybar-name { font-size: 18px; }
}


.product-hero {
  padding: 24px 0 70px;
  position: relative;
  overflow: hidden;
  text-align: center;
}
.product-hero .wrap { position: relative; z-index: 2; }
.product-hero .eyebrow { display: block; margin-bottom: 22px; }
.product-hero h1 {
  font-size: clamp(48px, 6vw, 92px);
}
.product-hero .product-lede {
  margin: 32px auto 0;
  max-width: 620px;
  font-family: var(--font-display);
  font-style: italic;
  font-size: clamp(20px, 2vw, 26px);
  line-height: 1.4;
  color: var(--text);
}
.product-hero .product-sub {
  margin: 24px auto 0;
  max-width: 560px;
  font-size: 16px;
  line-height: 1.65;
  color: var(--text-dim);
}
.product-price-row {
  margin-top: 44px;
  display: flex; flex-direction: column; align-items: center; gap: 18px;
}
.product-price {
  font-family: var(--font-display);
  font-style: italic;
  font-size: 40px;
  color: var(--text);
  display: flex; align-items: baseline; gap: 12px;
}
.product-price small {
  font-family: var(--font-mono); font-size: 11px;
  letter-spacing: 0.2em; text-transform: uppercase;
  color: var(--text-mute); font-style: normal;
}
.product-meta-row {
  margin-top: 8px;
  display: flex; gap: 28px; flex-wrap: wrap; justify-content: center;
  font-family: var(--font-mono); font-size: 10px;
  letter-spacing: 0.2em; text-transform: uppercase; color: var(--text-mute);
}
.product-meta-row span { display: flex; align-items: center; gap: 8px; }
.product-meta-row span::before {
  content: ''; width: 5px; height: 5px; border-radius: 50%;
  background: var(--accent); opacity: 0.7;
}

/* lenses grid */
.lens-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 16px;
  margin-top: 8px;
}
.lens-card {
  padding: 28px 24px;
  border: 1px solid var(--border);
  border-radius: 6px;
  background: var(--card);
  transition: all .3s;
}
.lens-card:hover { border-color: var(--border-strong); background: var(--card-hover); transform: translateY(-2px); }
.lens-card .lens-num {
  font-family: var(--font-mono); font-size: 10px; letter-spacing: 0.2em;
  text-transform: uppercase; color: var(--accent);
}
.lens-card h4 {
  font-family: var(--font-display); font-style: italic;
  font-size: 22px; line-height: 1.15;
  color: var(--text);
  margin: 12px 0 0;
}

/* inside-your-atlas list */
/* colored pill cards */
.inside-pill-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 16px;
  margin-top: 8px;
}
.inside-pill {
  position: relative;
  padding: 26px 26px 26px 28px;
  border-radius: 14px;
  background:
    linear-gradient(135deg,
      color-mix(in srgb, var(--c) 16%, var(--bg-soft)) 0%,
      color-mix(in srgb, var(--c) 5%, var(--bg-soft)) 100%);
  border: 1px solid color-mix(in srgb, var(--c) 30%, var(--border));
  overflow: hidden;
  transition: transform .3s, box-shadow .3s;
}
.inside-pill::before {
  content: '';
  position: absolute; left: 0; top: 0; bottom: 0;
  width: 4px; background: var(--c);
}
.inside-pill:hover {
  transform: translateY(-3px);
  box-shadow: 0 14px 34px color-mix(in srgb, var(--c) 22%, transparent);
}
.inside-pill-tag {
  display: inline-flex; align-items: center; justify-content: center;
  min-width: 30px; height: 24px; padding: 0 9px;
  border-radius: 999px;
  background: var(--c);
  color: #fff;
  font-family: var(--font-mono); font-size: 11px;
  letter-spacing: 0.06em;
  margin-bottom: 14px;
}
.inside-pill h4 {
  font-family: var(--font-display); font-style: italic;
  font-size: 21px; line-height: 1.15;
  color: var(--text);
  margin: 0 0 8px;
}
.inside-pill p {
  font-size: 14px; color: var(--text-dim); line-height: 1.55; margin: 0;
}

/* per-section CTA */
.section-cta {
  display: flex; justify-content: center;
  margin-top: 48px;
}

.inside-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 0 56px;
  margin-top: 8px;
}
.inside-item {
  display: flex; gap: 18px; align-items: flex-start;
  padding: 22px 0;
  border-bottom: 1px solid var(--border);
}
.inside-item .inside-num {
  font-family: var(--font-display); font-style: italic;
  font-size: 22px; color: var(--accent);
  flex: 0 0 auto; min-width: 32px;
}
.inside-item .inside-body h4 {
  font-family: var(--font-body); font-weight: 500;
  font-size: 15px; color: var(--text);
  margin: 0 0 4px;
}
.inside-item .inside-body p {
  font-size: 13px; color: var(--text-dim); line-height: 1.5; margin: 0;
}

/* who it's for */
.who-grid {
  display: grid; grid-template-columns: repeat(3, 1fr); gap: 20px;
  margin-top: 8px;
}
.who-card {
  padding: 32px 28px;
  border: 1px solid var(--border);
  border-radius: 6px;
  background: var(--card);
  font-family: var(--font-display);
  font-style: italic;
  font-size: 19px; line-height: 1.35;
  color: var(--text);
  position: relative;
}
.who-card::before {
  content: '✦';
  display: block;
  color: var(--accent);
  font-size: 16px;
  margin-bottom: 16px;
  font-style: normal;
}

/* delivery row */
.delivery-row {
  display: grid; grid-template-columns: repeat(3, 1fr); gap: 24px;
  margin-top: 8px;
}
.delivery-card {
  padding: 30px 26px;
  border: 1px solid color-mix(in srgb, var(--c, var(--accent)) 35%, var(--border));
  border-radius: 14px;
  background:
    radial-gradient(120% 90% at 0% 0%, color-mix(in srgb, var(--c, var(--accent)) 16%, transparent), transparent 60%),
    var(--card);
  position: relative; overflow: hidden;
  transition: transform .3s, box-shadow .3s;
}
.delivery-card::before {
  content: ''; position: absolute; left: 0; top: 0; right: 0; height: 3px;
  background: var(--c, var(--accent));
}
.delivery-card:hover {
  transform: translateY(-3px);
  box-shadow: 0 14px 34px color-mix(in srgb, var(--c, var(--accent)) 22%, transparent);
}
.delivery-top {
  display: flex; align-items: center; justify-content: space-between;
  margin-bottom: 16px;
}
.delivery-top .package-glyph { width: 44px; height: 44px; }
.delivery-num {
  font-family: var(--font-display); font-style: italic; font-size: 30px;
  color: color-mix(in srgb, var(--c, var(--accent)) 70%, var(--text));
  line-height: 1;
}
.delivery-eyebrow {
  display: block;
  font-family: var(--font-mono); font-size: 10px; letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--c, var(--accent));
  margin-bottom: 8px;
}
.delivery-title {
  font-family: var(--font-display); font-style: italic;
  font-size: 22px; line-height: 1.15; color: var(--text);
  margin: 0 0 10px;
}
.delivery-card p {
  font-size: 14px; line-height: 1.6; color: var(--text-dim); margin: 0;
}

/* final checkout band */
.checkout-band {
  margin-top: 40px;
  padding: 56px 48px;
  border-radius: 8px;
  border: 1px solid var(--border-strong);
  background:
    radial-gradient(ellipse 70% 90% at 80% 10%, var(--accent-soft), transparent 60%),
    var(--bg-alt);
  text-align: center;
  position: relative;
  overflow: hidden;
}
.checkout-band h2 { font-size: clamp(32px, 4vw, 52px); }
.checkout-band .price-line {
  margin-top: 20px;
  font-family: var(--font-display); font-style: italic; font-size: 30px;
  color: var(--text);
}
.checkout-band .btn { margin-top: 28px; }
.checkout-band .fine {
  margin-top: 18px;
  font-family: var(--font-mono); font-size: 10px;
  letter-spacing: 0.18em; text-transform: uppercase; color: var(--text-mute);
}
.product-disclaimer {
  max-width: 680px; margin: 56px auto 0;
  text-align: center;
  font-size: 12px; line-height: 1.6; color: var(--text-mute);
  font-style: italic;
  font-family: var(--font-display);
}
@media (max-width: 860px) {
  .lens-grid, .who-grid, .delivery-row { grid-template-columns: 1fr; }
  .inside-grid, .inside-pill-grid { grid-template-columns: 1fr; }
}

.divider {
  height: 1px; background: var(--border); margin: 32px 0;
}
.icon-arrow { display: inline-block; width: 14px; height: 14px; }

/* Special: hero floating text */
.hero h1 .word {
  display: inline-block;
  animation: heroFloat 8s ease-in-out infinite;
}
.hero h1 .word.b { animation-delay: -2s; }
.hero h1 .word.c { animation-delay: -4s; }
@keyframes heroFloat {
  0%,100% { transform: translateY(0); }
  50%     { transform: translateY(-6px); }
}

/* twinkle stars (celestial only) */
.theme-celestial .stars {
  position: absolute; inset: 0; pointer-events: none;
  background-image:
    radial-gradient(1px 1px at 20% 30%, rgba(255,255,255,.6), transparent),
    radial-gradient(1px 1px at 80% 70%, rgba(255,255,255,.5), transparent),
    radial-gradient(1px 1px at 50% 50%, rgba(255,255,255,.4), transparent),
    radial-gradient(1.5px 1.5px at 70% 20%, rgba(255,255,255,.5), transparent),
    radial-gradient(1px 1px at 30% 80%, rgba(255,255,255,.4), transparent),
    radial-gradient(1px 1px at 90% 90%, rgba(255,255,255,.5), transparent),
    radial-gradient(1px 1px at 10% 60%, rgba(255,255,255,.4), transparent),
    radial-gradient(1.5px 1.5px at 60% 10%, rgba(255,255,255,.6), transparent);
  background-size: 100% 100%;
  opacity: 0.9;
  z-index: 1;
  animation: twinkle 6s ease-in-out infinite alternate;
}
@keyframes twinkle { 0% { opacity: 0.5; } 100% { opacity: 1; } }

/* asterisk wordmark */
.wordmark-ast {
  display: inline-block; color: var(--accent);
  font-style: italic;
}

/* ════════════════════════════════════════════════════════════
   MOBILE OPTIMISATION — phones (≤600px)
   One responsive system: every page reflows for small screens.
   ════════════════════════════════════════════════════════════ */
@media (max-width: 600px) {
  .atlas-root { font-size: 15px; }
  .atlas-root .wrap { padding: 0 20px; }

  /* nav: brand + CTA only (full nav lives in the footer) */
  .atlas-nav { padding: 13px 20px; }
  .atlas-nav ul { display: none; }
  .atlas-nav .brand { font-size: 19px; }
  .atlas-nav .nav-cta { padding: 8px 14px; font-size: 12px; }

  /* hero */
  .hero { min-height: auto; padding: 64px 0 72px; }
  .hero .hero-meta { margin-top: 40px; gap: 22px 28px; flex-wrap: wrap; justify-content: center; }
  .hero .hero-meta span strong { font-size: 19px; }
  .scroll-cue { display: none; }

  /* generic section rhythm */
  .section { padding: 64px 0; }
  .section-head { margin-bottom: 40px; }
  .split, .split.wide { grid-template-columns: 1fr; gap: 40px; }

  /* body · mind · soul explorer scales to fit */
  .bms { height: 300px; }
  .bms-stage { transform: scale(0.56); transform-origin: center; }
  .bms-content { text-align: center; }

  /* offerings / grids already stack via wider queries; tighten here */
  .t-grid { grid-template-columns: 1fr; }
  .package-grid { gap: 18px; }
  .package-grid .package-card { padding: 26px 22px; }
  .package-grid .package-cta { align-self: center; }

  /* app section */
  .app-detail h3 { font-size: 24px; }
  .app-phone { width: 256px; height: 528px; }

  /* reading preview phones — minimised, with breathing room */
  .phone.reading-phone-lg { width: min(248px, 66vw); height: min(508px, 135vw); border-radius: 40px; padding: 11px; }
  .phone.reading-phone-lg .reading-screen { border-radius: 30px; }
  .phone.reading-phone { width: min(248px, 66vw); height: min(508px, 135vw); }
  .reading-clip { inset: 3px; }
  .reading-phone-lg { transform: none; }

  /* product page */
  .product-shell { padding-top: 20px; padding-bottom: 64px; }
  .product-stream { gap: 56px; }
  .buybox h1 { font-size: clamp(36px, 11vw, 48px); }
  .buybox { text-align: center; }
  .buybox .buybox-stars, .buybox .buybox-price, .buybox .buybox-trust { justify-content: center; }
  .buybox-includes { display: inline-flex; text-align: left; }

  /* every primary CTA centered on phones */
  .hero-ctas, .section-cta, .reading-buy-row, .co-confirm-cta { justify-content: center; text-align: center; }
  .reading-buy-row { flex-direction: column; }

  /* checkout */
  .co-hero { padding: 28px 0 24px; }
  .co-rail { gap: 6px; }
  .co-step { padding: 8px 12px; font-size: 9px; gap: 7px; }
  .co-body { padding: 36px 0 80px; }
  .co-panel { padding: 22px 18px; }
  .co-field-row { grid-template-columns: 1fr; }
  .co-summary { padding: 22px 18px; }
  .co-when-strip { flex-wrap: wrap; }
  .co-booking { grid-template-columns: 1fr; }

  /* contact */
  .contact-hero { padding: 40px 0 12px; }
  .contact-body { padding: 36px 0 80px; }
  .contact-form-wrap { padding: 24px 18px; }

  /* phone: centre headings, titles & section copy */
  .section-head { text-align: center; margin-left: auto; margin-right: auto; }
  .reading-detail, .app-detail, .inside-pill, .delivery-card, .co-confirm { text-align: center; }
  .reading-detail ul, .app-detail ul { align-items: center; }
  .reading-detail ul li, .app-detail ul li { justify-content: center; }

  /* questionnaire preview — minimised, nothing cut off */
  .questionnaire { padding: 22px 16px; }
  .questionnaire h3 { font-size: 18px; line-height: 1.25; }
  .questionnaire .q-hint { font-size: 13px; }
  .q-options, .q-chakra-grid { width: 100%; }
  .q-opt { font-size: 13px; padding: 11px 12px; }
  .q-chakra-grid { grid-template-columns: repeat(4, 1fr); gap: 6px; }
  .chakra-pill { font-size: 10px; padding: 8px 4px; }
  .q-controls { flex-wrap: wrap; gap: 12px; }
  .q-controls .btn { padding: 12px 18px; }

  /* footer: brand full width, links two-up */
  .footer { padding: 56px 0 36px; }
  .footer-grid { grid-template-columns: 1fr 1fr; gap: 30px 24px; padding-bottom: 40px; }
  .footer-grid > div:first-child { grid-column: 1 / -1; }
  .footer-bottom { flex-direction: column; gap: 10px; align-items: flex-start; }

  /* buttons: comfortable touch targets, full-width primary CTAs in flows */
  .btn { padding: 14px 22px; font-size: 13px; }
  .buybox-cta, .co-paybtn, .contact-submit { width: 100%; justify-content: center; }

  /* waitlist modal */
  .wl-modal-inner { padding: 40px 26px 32px; }
}

/* very small phones */
@media (max-width: 380px) {
  .atlas-root .wrap { padding: 0 16px; }
  .app-phone { width: 232px; height: 480px; }
  .phone.reading-phone-lg, .phone.reading-phone { width: 74vw; height: 152vw; }
  .q-chakra-grid { grid-template-columns: repeat(4, 1fr); }
}
