/* ============================================================
   Comminxy — Where Love Learns to Stay
   Design system. Voice: Warm · Grounded · Reflective · Hopeful.
   Motif: The Embrace — two curves holding a central orb.
   ============================================================ */

/* ---- Fonts ---- */
@import url('https://fonts.googleapis.com/css2?family=DM+Sans:opsz,wght@9..40,400;9..40,500;9..40,600;9..40,700&family=Inter:wght@400;450;500;600&display=swap');
@import url('https://api.fontshare.com/v2/css?f[]=satoshi@500,700&display=swap');

/* ---- Tokens ---- */
:root {
  /* Ink — the app-icon world */
  --ink:        #18131C;   /* warm near-black */
  --ink-2:      #241C2B;   /* charcoal violet */
  --ink-3:      #322839;

  /* Paper — the home */
  --paper:      #F5F1EA;   /* warm off-white */
  --paper-2:    #FBF8F2;   /* lighter card */
  --paper-3:    #EFE8DD;   /* warm sand */

  /* Brand hues (logo + guidelines + bible) */
  --mauve:      #B294A6;   /* dusty rose — the embrace */
  --mauve-deep: #8A6E80;   /* deeper, for type on light */
  --mauve-soft: #E3D6E0;
  --lilac:      #D9C9E7;   /* pale lilac */
  --lilac-soft: #EAE1EF;

  --gold:       #E0AC68;   /* the orb — amber */
  --gold-deep:  #C99248;
  --gold-soft:  #F3D9A8;
  --peach:      #F7E0CC;   /* soft beige */
  --cream:      #FAF1E2;

  /* Text */
  --text:        #5E5660;  /* warm grey body */
  --text-strong: #2C2430;  /* headings on light */
  --text-mute:   #938A95;
  --text-on-ink: #EDE6E9;  /* body on dark */
  --mute-on-ink: #A99FAA;

  --line:       rgba(44,36,48,0.10);
  --line-ink:   rgba(255,255,255,0.10);

  --shadow-sm:  0 2px 10px rgba(44,30,48,0.05);
  --shadow:     0 24px 60px -28px rgba(60,40,70,0.30);
  --shadow-lg:  0 50px 110px -40px rgba(40,24,52,0.45);

  --r-sm: 16px;
  --r:    24px;
  --r-lg: 34px;
  --r-xl: 44px;

  --maxw: 1180px;
  --ease: cubic-bezier(0.22, 1, 0.36, 1);

  --font-body: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
  --font-head: 'DM Sans', 'Inter', sans-serif;
  --font-mark: 'Satoshi', 'DM Sans', sans-serif;
}

/* ---- Reset ---- */
*, *::before, *::after { margin: 0; padding: 0; box-sizing: border-box; }
html { scroll-behavior: smooth; -webkit-text-size-adjust: 100%; }
body {
  font-family: var(--font-body);
  background: var(--paper);
  color: var(--text);
  line-height: 1.65;
  font-size: 17px;
  letter-spacing: -0.005em;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
  overflow-x: hidden;
}
img { max-width: 100%; display: block; }
a { color: inherit; text-decoration: none; }
::selection { background: var(--mauve); color: #fff; }

/* ---- Type ---- */
h1, h2, h3, h4 {
  font-family: var(--font-head);
  color: var(--text-strong);
  font-weight: 600;
  line-height: 1.06;
  letter-spacing: -0.025em;
  text-wrap: balance;
}
h1 { font-size: clamp(2.6rem, 6vw, 4.7rem); }
h2 { font-size: clamp(2rem, 4.2vw, 3.25rem); }
h3 { font-size: clamp(1.35rem, 2.2vw, 1.75rem); }
p { text-wrap: pretty; }

.eyebrow {
  font-family: var(--font-body);
  font-size: 0.74rem;
  font-weight: 600;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--mauve-deep);
  display: inline-flex;
  align-items: center;
  gap: 0.6rem;
}
.eyebrow::before {
  content: "";
  width: 22px; height: 1.5px;
  background: var(--mauve);
  display: inline-block;
}
.eyebrow.center { justify-content: center; }
.lead {
  font-size: clamp(1.12rem, 1.7vw, 1.4rem);
  line-height: 1.6;
  color: var(--text);
}
.serif-quote {
  font-family: var(--font-head);
  font-weight: 500;
  letter-spacing: -0.02em;
}

/* ---- Layout ---- */
.wrap { width: 100%; max-width: var(--maxw); margin: 0 auto; padding: 0 28px; }
.wrap-narrow { max-width: 860px; }
section { position: relative; }
.section { padding: clamp(80px, 11vw, 150px) 0; }
.section-tight { padding: clamp(60px, 8vw, 100px) 0; }
.center { text-align: center; }
.mx-auto { margin-left: auto; margin-right: auto; }

/* ---- Buttons ---- */
.btn {
  --bg: var(--ink-2); --fg: #fff;
  font-family: var(--font-body);
  font-weight: 600;
  font-size: 0.98rem;
  letter-spacing: -0.01em;
  background: var(--bg);
  color: var(--fg);
  padding: 0.95rem 1.7rem;
  border-radius: 999px;
  border: 1px solid transparent;
  display: inline-flex; align-items: center; gap: 0.6rem;
  cursor: pointer;
  transition: transform .35s var(--ease), box-shadow .35s var(--ease), background .3s, color .3s;
  will-change: transform;
}
.btn:hover { transform: translateY(-2px); box-shadow: var(--shadow); }
.btn:active { transform: translateY(0) scale(.98); }
.btn-lg { padding: 1.15rem 2.1rem; font-size: 1.05rem; }
.btn-gold { --bg: var(--gold); --fg: #3a2a16; box-shadow: 0 14px 40px -16px rgba(224,172,104,.7); }
.btn-light { --bg: var(--paper-2); --fg: var(--text-strong); border-color: var(--line); }
.btn-ghost {
  --bg: transparent; --fg: var(--text-strong);
  border-color: var(--line);
}
.btn-ghost:hover { background: rgba(44,36,48,.04); }
.on-ink .btn-ghost, .btn-ghost.on-ink { --fg: var(--text-on-ink); border-color: var(--line-ink); }
.btn .arrow { transition: transform .35s var(--ease); }
.btn:hover .arrow { transform: translateX(4px); }

/* ---- Nav ---- */
.nav {
  position: fixed; top: 0; left: 0; width: 100%; z-index: 100;
  display: flex; align-items: center; justify-content: space-between;
  padding: 18px clamp(20px, 4vw, 44px);
  transition: background .5s var(--ease), backdrop-filter .5s, border-color .5s, padding .4s;
  border-bottom: 1px solid transparent;
}
.nav.solid {
  background: var(--nav-bg, rgba(245,241,234,0.82));
  backdrop-filter: saturate(140%) blur(18px);
  -webkit-backdrop-filter: saturate(140%) blur(18px);
  border-bottom-color: var(--line);
  padding-top: 13px; padding-bottom: 13px;
}
.nav-brand { display: flex; align-items: center; gap: 11px; }
.nav-brand img { width: 34px; height: 34px; object-fit: contain; }
.nav-brand .name {
  font-family: var(--font-mark);
  font-weight: 700; font-size: 1.32rem;
  letter-spacing: -0.02em; color: var(--text-strong);
}
.nav-links { display: flex; gap: 34px; align-items: center; }
.nav-links a {
  font-size: 0.94rem; font-weight: 500; color: var(--text);
  opacity: .82; transition: opacity .25s, color .25s; position: relative;
}
.nav-links a::after {
  content:""; position:absolute; left:0; bottom:-5px; height:1.5px; width:0;
  background: var(--mauve); transition: width .3s var(--ease);
}
.nav-links a:hover { opacity: 1; color: var(--text-strong); }
.nav-links a:hover::after { width: 100%; }
/* nav over the light hero (before scroll) — keep dark text, transparent bg */
.nav.on-hero .name { color: var(--text-strong); }
.nav.on-hero .nav-links a { color: var(--text); }
.nav-menu-btn { display: none; }

@media (max-width: 860px) {
  .nav-links { display: none; }
  .nav-cta { display: none; }
}

/* ---- The Embrace / orb ---- */
.orb-wrap { position: relative; display: inline-grid; place-items: center; }
.orb-glow {
  position: absolute; inset: -40% ; border-radius: 50%;
  background: radial-gradient(circle at 50% 50%, rgba(224,172,104,.55), rgba(178,148,166,.22) 38%, transparent 66%);
  filter: blur(26px);
  animation: breathe 7s var(--ease) infinite;
  z-index: 0; pointer-events: none;
}
.orb-mark { position: relative; z-index: 1; animation: bob 9s ease-in-out infinite; }
@keyframes breathe {
  0%,100% { transform: scale(1); opacity: .85; }
  50%     { transform: scale(1.12); opacity: 1; }
}
@keyframes bob {
  0%,100% { transform: translateY(0); }
  50%     { transform: translateY(-12px); }
}

/* soft floating accent orb (decorative) */
.accent-orb {
  position: absolute; border-radius: 50%; pointer-events: none; z-index: 0;
  background: radial-gradient(circle at 38% 35%, var(--gold-soft), var(--gold) 65%, var(--gold-deep));
  box-shadow: 0 30px 70px -20px rgba(224,172,104,.6);
}

/* ---- Hero (light) ---- */
.hero {
  position: relative; background: var(--paper); color: var(--text);
  padding: 168px 0 clamp(90px, 13vw, 170px);
  overflow: hidden;
  text-align: center;
}
.hero::before { /* warm light wash */
  content:""; position: absolute; inset: 0; z-index: 0; pointer-events: none;
  background:
    radial-gradient(56% 46% at 50% 4%, rgba(224,172,104,.20), transparent 70%),
    radial-gradient(46% 42% at 15% 76%, rgba(217,201,231,.34), transparent 72%),
    radial-gradient(50% 46% at 86% 70%, rgba(247,224,204,.42), transparent 72%);
}
.hero::after { /* soft fade into the next section */
  content:""; position:absolute; left:0; right:0; bottom:0; height:160px; z-index:0; pointer-events:none;
  background: linear-gradient(transparent, var(--paper));
}
.hero .wrap { position: relative; z-index: 2; }
.hero h1 { color: var(--text-strong); }
.hero .lead { color: var(--text); }
.hero-orb { width: clamp(120px, 16vw, 188px); margin: 0 auto 38px; }
.hero-orb img { width: 100%; }

.triad {
  display: flex; align-items: center; justify-content: center;
  gap: clamp(14px, 3vw, 34px); flex-wrap: wrap;
  margin: 40px auto 0;
}
.triad .word { font-family: var(--font-head); font-weight: 600; font-size: clamp(1.05rem,1.7vw,1.4rem); color: var(--text-strong); letter-spacing: -.02em; }
.triad .dot { width: 5px; height: 5px; border-radius: 50%; background: var(--gold); }
.hero-cta { display: flex; gap: 14px; justify-content: center; flex-wrap: wrap; margin-top: 46px; }
.hero-note { margin-top: 20px; font-size: .9rem; color: var(--text-mute); }

/* scroll cue */
.scroll-cue {
  position: absolute; bottom: 26px; left: 50%; transform: translateX(-50%);
  z-index: 3; display: grid; place-items: center; gap: 9px;
  font-size: .68rem; letter-spacing: .2em; text-transform: uppercase; color: var(--text-mute);
}
.scroll-cue .rail { width: 1px; height: 42px; background: linear-gradient(var(--mauve), transparent); position: relative; overflow: hidden; }
.scroll-cue .rail::after { content:""; position:absolute; top:-50%; left:0; width:100%; height:50%; background: var(--gold); animation: drip 2.4s var(--ease) infinite; }
@keyframes drip { 0%{ top:-50%; } 60%,100%{ top:100%; } }

/* ---- Arc divider between ink and paper ---- */
.arc-top { display:none; }

/* ---- Cards ---- */
.card {
  background: var(--paper-2);
  border: 1px solid var(--line);
  border-radius: var(--r-lg);
  padding: clamp(26px, 3vw, 40px);
  box-shadow: var(--shadow-sm);
  transition: transform .5s var(--ease), box-shadow .5s var(--ease), border-color .5s;
}
.card.hover:hover { transform: translateY(-6px); box-shadow: var(--shadow); border-color: rgba(178,148,166,.4); }

/* circular-motif icon */
.ic {
  width: 54px; height: 54px; border-radius: 16px;
  display: grid; place-items: center; flex: none;
  background: var(--lilac-soft); color: var(--mauve-deep);
}
.ic.gold { background: var(--gold-soft); color: var(--gold-deep); }
.ic.peach { background: var(--peach); color: #b27a52; }
.ic.sand { background: var(--paper-3); color: var(--mauve-deep); }
.ic svg { width: 26px; height: 26px; }

/* feature list with check */
.flist { list-style: none; display: grid; gap: 13px; margin-top: 4px; }
.flist li { display: flex; align-items: center; gap: 11px; font-size: .98rem; color: var(--text); }
.flist .chk {
  width: 21px; height: 21px; border-radius: 50%; flex: none;
  display: grid; place-items: center;
  background: rgba(178,148,166,.16); color: var(--mauve-deep);
}
.flist .chk svg { width: 12px; height: 12px; }

/* pill / tag */
.pill {
  display: inline-flex; align-items: center; gap: 7px;
  font-size: .72rem; font-weight: 600; letter-spacing: .12em; text-transform: uppercase;
  padding: 7px 14px; border-radius: 999px;
}
.pill.mauve { background: var(--mauve-soft); color: var(--mauve-deep); }
.pill.gold  { background: var(--gold-soft); color: var(--gold-deep); }
.pill.sand  { background: var(--paper-3); color: var(--text); }
.pill .glyph { width:7px; height:7px; border-radius:50%; background: currentColor; }

/* ---- Demo (tone softening) ---- */
.demo-stage {
  background: linear-gradient(180deg, var(--ink-2), var(--ink));
  border-radius: var(--r-xl);
  padding: clamp(26px, 4vw, 54px);
  color: var(--text-on-ink);
  position: relative; overflow: hidden;
  box-shadow: var(--shadow-lg);
}
.demo-stage::before {
  content:""; position:absolute; inset:0;
  background: radial-gradient(50% 40% at 78% 18%, rgba(224,172,104,.18), transparent 70%),
              radial-gradient(46% 40% at 12% 92%, rgba(178,148,166,.20), transparent 70%);
  pointer-events:none;
}
.demo-grid { position: relative; display: grid; grid-template-columns: 1.05fr 0.95fr; gap: clamp(28px, 4vw, 60px); align-items: center; }
.phone {
  background: rgba(255,255,255,.04);
  border: 1px solid var(--line-ink);
  border-radius: 30px; padding: 22px 20px 26px;
  backdrop-filter: blur(6px);
  display: grid; gap: 14px;
}
.phone .ph-head { display:flex; align-items:center; gap:10px; padding-bottom: 12px; border-bottom: 1px solid var(--line-ink); margin-bottom: 4px; }
.phone .ph-ava { width: 32px; height: 32px; border-radius: 50%; background: linear-gradient(135deg, var(--mauve), var(--gold)); flex:none; }
.phone .ph-name { font-weight: 600; color: #fff; font-size: .92rem; }
.phone .ph-sub { font-size: .72rem; color: var(--mute-on-ink); }
.bubble {
  max-width: 86%; padding: 13px 16px; border-radius: 18px; font-size: .96rem; line-height: 1.5;
}
.bubble.them { background: rgba(255,255,255,.08); border-top-left-radius: 6px; align-self: flex-start; color: var(--text-on-ink); }
.bubble.harsh { color: #E9CFD4; }
.row-l { display:flex; }
.row-r { display:flex; justify-content:flex-end; }
.bubble.you { background: var(--gold); color: #3a2a16; border-top-right-radius: 6px; font-weight: 500; }

.intercept {
  margin-top: 4px;
  border: 1px dashed rgba(224,172,104,.5);
  background: rgba(224,172,104,.08);
  border-radius: 18px; padding: 14px 16px;
  display: grid; gap: 8px;
  opacity: 0; transform: translateY(8px);
  transition: all .8s var(--ease);
}
.intercept.show { opacity: 1; transform: none; }
.intercept .tag { display:flex; align-items:center; gap:8px; font-size:.7rem; letter-spacing:.14em; text-transform:uppercase; color: var(--gold); font-weight:600; }
.intercept .soft { font-family: var(--font-head); font-weight:500; font-size: 1.04rem; color:#fff; letter-spacing:-.01em; }

.demo-copy h2 { color: #fff; }
.demo-copy .lead { color: var(--mute-on-ink); }
.demo-toggle { display:flex; align-items:center; gap:12px; margin-top: 22px; font-size:.9rem; color: var(--text-on-ink); }
.demo-toggle .led { width:9px; height:9px; border-radius:50%; background: var(--gold); box-shadow:0 0 0 0 rgba(224,172,104,.6); animation: pulse 2.2s infinite; }
@keyframes pulse { 0%{ box-shadow:0 0 0 0 rgba(224,172,104,.55);} 70%{ box-shadow:0 0 0 12px rgba(224,172,104,0);} 100%{ box-shadow:0 0 0 0 rgba(224,172,104,0);} }

/* ---- Quote band ---- */
.band { background: var(--ink); color: var(--text-on-ink); }
.band h2 { color: #fff; }
.quote-xl {
  font-family: var(--font-head); font-weight: 500;
  font-size: clamp(1.7rem, 3.6vw, 3rem); line-height: 1.18; letter-spacing: -.025em;
  color: #fff; text-wrap: balance;
}
.quote-xl .accent { color: var(--gold); }

/* signature phrases */
.phrases { display: grid; gap: 14px; }
.phrase {
  display: flex; align-items: center; gap: 16px;
  padding: 20px 24px; border: 1px solid var(--line-ink); border-radius: var(--r);
  font-family: var(--font-head); font-weight: 500; font-size: clamp(1.05rem,1.8vw,1.35rem);
  color: #fff; letter-spacing: -.01em;
  background: rgba(255,255,255,.02);
  transition: background .4s, border-color .4s, transform .4s var(--ease);
}
.phrase:hover { background: rgba(178,148,166,.10); border-color: rgba(178,148,166,.4); transform: translateX(6px); }
.phrase .n { font-family: var(--font-body); font-size: .8rem; color: var(--gold); font-weight: 600; flex:none; width: 28px; }

/* ---- Stats ---- */
.stat { }
.stat .num { font-family: var(--font-head); font-weight: 600; font-size: clamp(2.6rem, 5vw, 3.6rem); color: var(--text-strong); letter-spacing: -.03em; line-height: 1; }
.stat .num .accent { color: var(--mauve-deep); }
.stat .lbl { margin-top: 14px; font-size: .96rem; color: var(--text); }
.stat .src { margin-top: 10px; font-size: .76rem; color: var(--text-mute); }

/* ---- Forms ---- */
.form { display: grid; gap: 12px; max-width: 460px; margin: 0 auto; }
.field {
  width: 100%; padding: 1.05rem 1.4rem; font-size: 1.02rem; font-family: var(--font-body);
  border-radius: 999px; border: 1px solid var(--line); background: var(--paper-2); color: var(--text-strong);
  outline: none; transition: border-color .25s, box-shadow .25s;
}
.field::placeholder { color: var(--text-mute); }
.field:focus { border-color: var(--mauve); box-shadow: 0 0 0 4px rgba(178,148,166,.16); }
.on-ink .field { background: rgba(255,255,255,.06); border-color: var(--line-ink); color:#fff; }
.on-ink .field::placeholder { color: var(--mute-on-ink); }

/* ---- Footer ---- */
.footer { background: var(--ink); color: var(--mute-on-ink); padding: 74px 0 48px; }
.footer .top { display:flex; justify-content: space-between; gap: 40px; flex-wrap: wrap; align-items: flex-start; }
.footer .brand { display:flex; align-items:center; gap:11px; }
.footer .brand img { width: 30px; height: 30px; }
.footer .brand .name { font-family: var(--font-mark); font-weight:700; font-size:1.2rem; color:#fff; letter-spacing:-.02em; }
.footer .tagline { max-width: 320px; margin-top: 16px; font-size:.95rem; line-height:1.6; color: var(--mute-on-ink); }
.footer-cols { display:flex; gap: clamp(40px, 8vw, 96px); flex-wrap: wrap; }
.footer-col h5 { font-family: var(--font-body); font-size:.74rem; letter-spacing:.16em; text-transform:uppercase; color: var(--text-mute); margin-bottom: 16px; font-weight:600; }
.footer-col a { display:block; font-size:.95rem; color: var(--text-on-ink); opacity:.78; margin-bottom: 11px; transition: opacity .2s, color .2s; }
.footer-col a:hover { opacity:1; color: var(--gold); }
.footer .rule { height:1px; background: var(--line-ink); margin: 44px 0 24px; }
.footer .legal { display:flex; justify-content: space-between; gap: 18px; flex-wrap: wrap; font-size:.84rem; }
.footer .legal .made em { color: var(--mauve); font-style: normal; }

/* ---- Reveal (gated on .js so content is always visible without JS) ---- */
html.js .reveal { opacity: 0; transform: translateY(26px); transition: opacity .9s var(--ease), transform .9s var(--ease); }
html.js .reveal.in { opacity: 1; transform: none; }
.reveal.d1 { transition-delay: .08s; }
.reveal.d2 { transition-delay: .16s; }
.reveal.d3 { transition-delay: .24s; }
.reveal.d4 { transition-delay: .32s; }

/* ---- Grids ---- */
.g3 { display: grid; grid-template-columns: repeat(3, 1fr); gap: 26px; }
.g4 { display: grid; grid-template-columns: repeat(4, 1fr); gap: 22px; }
.g2 { display: grid; grid-template-columns: 1fr 1fr; gap: clamp(36px, 6vw, 84px); align-items: center; }
.stack-lg > * + * { margin-top: 26px; }
.stack > * + * { margin-top: 16px; }

@media (max-width: 980px) {
  .g3 { grid-template-columns: 1fr; }
  .g4 { grid-template-columns: 1fr 1fr; }
  .g2 { grid-template-columns: 1fr; }
  .demo-grid { grid-template-columns: 1fr; }
}
@media (max-width: 560px) {
  .g4 { grid-template-columns: 1fr; }
  body { font-size: 16px; }
}

/* ---- Image placeholder (app screenshots later) ---- */
.shot {
  position: relative; border-radius: 30px; overflow: hidden;
  background:
    repeating-linear-gradient(135deg, rgba(178,148,166,.10) 0 14px, rgba(178,148,166,.04) 14px 28px),
    var(--paper-3);
  border: 1px solid var(--line);
  display: grid; place-items: center;
  min-height: 320px;
}
.shot .tag {
  font-family: ui-monospace, 'SF Mono', Menlo, monospace;
  font-size: .78rem; letter-spacing: .04em; color: var(--mauve-deep);
  background: var(--paper-2); border: 1px solid var(--line);
  padding: 8px 14px; border-radius: 999px;
}
.shot.dark {
  background:
    repeating-linear-gradient(135deg, rgba(255,255,255,.05) 0 14px, rgba(255,255,255,.015) 14px 28px),
    var(--ink-2);
  border-color: var(--line-ink);
}
.shot.dark .tag { color: var(--gold-soft); background: rgba(255,255,255,.05); border-color: var(--line-ink); }

/* ---- Prose (privacy / terms) ---- */
.prose-page { background: var(--paper); }
.doc { max-width: 780px; margin: 0 auto; padding: 150px 28px 110px; }
.doc .eyebrow { margin-bottom: 18px; }
.prose h1 { font-size: clamp(2.2rem,4vw,3rem); margin-bottom: 10px; }
.prose .meta { font-size:.86rem; color: var(--text-mute); margin-bottom: 40px; }
.prose h2 { font-size: 1.4rem; margin: 44px 0 14px; color: var(--text-strong); letter-spacing:-.02em; }
.prose h3 { font-size: 1.06rem; margin: 26px 0 8px; color: var(--mauve-deep); font-family: var(--font-body); font-weight:600; letter-spacing: 0; }
.prose p { margin-bottom: 14px; line-height: 1.75; }
.prose ul { margin: 12px 0 16px 4px; display: grid; gap: 8px; }
.prose ul li { display:flex; gap: 12px; line-height: 1.6; }
.prose ul li::before { content:""; width:6px; height:6px; border-radius:50%; background: var(--mauve); margin-top:11px; flex:none; }
.prose a { color: var(--mauve-deep); text-decoration: underline; text-underline-offset: 3px; }
.prose strong { color: var(--text-strong); }
.toc {
  border: 1px solid var(--line); border-radius: var(--r); padding: 22px 24px;
  background: var(--paper-2); margin-bottom: 40px;
}
.toc h4 { font-family: var(--font-body); font-size:.74rem; letter-spacing:.16em; text-transform:uppercase; color: var(--text-mute); margin-bottom: 12px; }
.toc-grid { columns: 2; column-gap: 28px; }
.toc-grid a { display:block; font-size:.9rem; padding: 4px 0; color: var(--text); }
.toc-grid a:hover { color: var(--mauve-deep); }
@media (max-width: 560px){ .toc-grid { columns: 1; } }

/* ---- Theme toggle ---- */
.nav-right { display: flex; align-items: center; gap: 12px; }
.theme-toggle {
  width: 40px; height: 40px; border-radius: 50%; flex: none;
  border: 1px solid var(--line); background: transparent; color: var(--text);
  display: grid; place-items: center; cursor: pointer;
  transition: background .25s, color .25s, border-color .25s, transform .3s var(--ease);
}
.theme-toggle:hover { background: rgba(120,100,130,.10); color: var(--text-strong); transform: translateY(-1px); }
.theme-toggle svg { width: 18px; height: 18px; }
.theme-toggle .sun { display: none; }
.nav.on-hero .theme-toggle { color: var(--text); border-color: var(--line); }
html[data-theme="dark"] .theme-toggle .moon { display: none; }
html[data-theme="dark"] .theme-toggle .sun { display: block; }

/* ============ Dark mode ============ */
html[data-theme="dark"] {
  --paper:   #17131B;
  --paper-2: #221B29;
  --paper-3: #1D1724;
  --ink:     #0E0B13;
  --ink-2:   #2A2233;
  --cream:   #221B29;
  --text:        #C8BFD0;
  --text-strong: #F4EFF5;
  --text-mute:   #8C8398;
  --mauve-deep:  #CBA9C0;
  --gold-deep:   #E7B777;
  --line:        rgba(255,255,255,0.10);
  --nav-bg:      rgba(18,14,22,0.84);
  --shadow-sm: 0 2px 12px rgba(0,0,0,.35);
  --shadow:    0 26px 64px -30px rgba(0,0,0,.7);
  --shadow-lg: 0 50px 110px -40px rgba(0,0,0,.82);
}
html[data-theme="dark"] body { background: var(--paper); }
html[data-theme="dark"] .ic { background: rgba(178,148,166,.16); color: #d6b6ca; }
html[data-theme="dark"] .ic.gold { background: rgba(224,172,104,.18); color: #ecc187; }
html[data-theme="dark"] .ic.peach { background: rgba(224,150,110,.16); color: #e6ad84; }
html[data-theme="dark"] .ic.sand { background: rgba(255,255,255,.06); color: #d6b6ca; }
html[data-theme="dark"] .pill.mauve { background: rgba(178,148,166,.18); color: #d6b6ca; }
html[data-theme="dark"] .pill.gold  { background: rgba(224,172,104,.18); color: #ecc187; }
html[data-theme="dark"] .pill.sand  { background: rgba(255,255,255,.06); color: var(--text); }
html[data-theme="dark"] .card.hover:hover { border-color: rgba(178,148,166,.35); }
html[data-theme="dark"] .shot { background: repeating-linear-gradient(135deg, rgba(255,255,255,.05) 0 14px, rgba(255,255,255,.015) 14px 28px), var(--paper-3); border-color: var(--line); }
html[data-theme="dark"] .shot .tag { color: var(--gold-soft); background: rgba(255,255,255,.05); border-color: var(--line); }
html[data-theme="dark"] .field { background: rgba(255,255,255,.05); border-color: var(--line); color: #fff; }

/* ---- Reduced motion ---- */
@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after { animation: none !important; transition: none !important; }
  .reveal { opacity: 1 !important; transform: none !important; }
  html { scroll-behavior: auto; }
}


/* =============================================================
   Ported 5-feature interactive demo — fully namespaced under .cx5
   Replaces the old tone-check demo. Tokens are re-pinned here so the
   demo renders identically in both light and dark site themes.
   ============================================================= */
.cx5 {
  --ink:#18131C; --ink-2:#241C2B; --ink-3:#322839;
  --paper:#F5F1EA; --paper-2:#FBF8F2; --paper-3:#EFE8DD;
  --mauve:#B294A6; --mauve-deep:#8A6E80; --mauve-soft:#E3D6E0;
  --lilac:#D9C9E7; --lilac-soft:#EAE1EF;
  --gold:#E0AC68; --gold-deep:#C99248; --gold-soft:#F3D9A8;
  --peach:#F7E0CC; --cream:#FAF1E2;
  --text:#5E5660; --text-strong:#2C2430; --text-mute:#938A95;
  --text-on-ink:#EDE6E9; --mute-on-ink:#A99FAA;
  --line:rgba(44,36,48,0.10); --line-ink:rgba(255,255,255,0.10);
  --shadow-sm:0 2px 10px rgba(44,30,48,0.05);
  --shadow:0 24px 60px -28px rgba(60,40,70,0.30);
  --shadow-lg:0 50px 110px -40px rgba(40,24,52,0.45);
  --r-sm:16px; --r:24px; --r-lg:34px; --r-xl:44px;
  --ease:cubic-bezier(0.22,1,0.36,1);
  --express:#B294A6; --express-soft:#F4E3EE; --express-deep:#8A6E80;
  --solve:#8FB98A; --solve-soft:#E4F0E2; --solve-deep:#5C7E58;
  position:relative; overflow:hidden; color:var(--text-on-ink);
  background:linear-gradient(180deg,var(--ink-2),var(--ink));
  border-radius:var(--r-xl);
  padding:clamp(40px,7vw,90px) clamp(20px,4vw,44px);
  box-shadow:var(--shadow-lg);
}
/* specificity guards: neutralize the 3 places the site's bare rules would
   bleed into the namespaced demo */
.cx5 .eyebrow::before { display:none; }            /* site eyebrow draws a line */
.cx5 .phone { display:block; gap:0; }              /* site .phone forces grid */
html[data-theme="dark"] .cx5 .field { background:var(--paper-2); color:var(--text-strong); border-color:var(--line); }
html[data-theme="dark"] .cx5 .field::placeholder { color:var(--text-mute); }

.cx5 .eyebrow { display:inline-flex;align-items:center;gap:9px;font-size:.74rem;letter-spacing:.16em;text-transform:uppercase;color:var(--gold);font-weight:600;margin-bottom:18px }
.cx5 .eyebrow .led { width:8px;height:8px;border-radius:50%;background:var(--gold);box-shadow:0 0 0 0 rgba(224,172,104,.6);animation:pulse 2.2s infinite }
.cx5 .head { text-align:center;max-width:40ch;margin:0 auto }
.cx5 .head h2 { font-family:var(--font-head);font-weight:600;color:#fff;font-size:clamp(1.9rem,4vw,3rem);line-height:1.1;letter-spacing:-.025em;text-wrap:balance }
.cx5 .head .lead { color:var(--mute-on-ink);font-size:clamp(1rem,1.6vw,1.15rem);margin-top:16px;line-height:1.6 }
.cx5 .spine { display:flex;justify-content:center;align-items:center;flex-wrap:wrap;gap:10px;margin:clamp(28px,4vw,42px) auto 0;max-width:760px }
.cx5 .spine .seg { font-family:var(--font-head);font-weight:500;color:var(--mute-on-ink);font-size:clamp(.92rem,1.5vw,1.18rem);letter-spacing:-.01em }
.cx5 .spine .seg .hl { color:var(--gold) }
.cx5 .spine .sep { color:var(--line-ink);font-size:1rem }
.cx5 .tabs { display:flex;justify-content:center;flex-wrap:wrap;gap:8px;margin:clamp(30px,4vw,46px) auto 0 }
.cx5 .tab { display:inline-flex;align-items:center;gap:8px;border:1px solid var(--line-ink);background:rgba(255,255,255,.02);color:var(--mute-on-ink);border-radius:99px;padding:9px 17px;font-family:var(--font-body);font-size:.86rem;font-weight:500;cursor:pointer;transition:all .3s var(--ease) }
.cx5 .tab .tn { width:20px;height:20px;border-radius:50%;background:rgba(255,255,255,.06);display:flex;align-items:center;justify-content:center;font-size:.7rem;color:var(--mute-on-ink) }
.cx5 .tab:hover { color:#fff;border-color:rgba(178,148,166,.4) }
.cx5 .tab.on { background:var(--gold);color:#3a2a16;border-color:transparent }
.cx5 .tab.on .tn { background:rgba(58,42,22,.18);color:#3a2a16 }
.cx5 .grid { display:grid;grid-template-columns:0.92fr 1.08fr;gap:clamp(30px,5vw,70px);align-items:center;margin-top:clamp(34px,5vw,52px) }
@media(max-width:860px) { .cx5 .grid { grid-template-columns:1fr;gap:34px } }
.cx5 .phone-shell { display:flex;justify-content:center }
.cx5 .phone { width:330px;max-width:100%;background:rgba(255,255,255,.035);border:1px solid var(--line-ink);border-radius:38px;padding:14px;backdrop-filter:blur(6px);box-shadow:var(--shadow-lg) }
.cx5 .screen { background:var(--paper);border-radius:26px;overflow:hidden;height:586px;position:relative;display:flex;flex-direction:column }
.cx5 .statusbar { display:flex;align-items:center;justify-content:space-between;padding:14px 20px 8px;font-size:.72rem;color:var(--text-strong);font-weight:600;flex:none }
.cx5 .statusbar .dots { opacity:.6;font-size:.66rem }
.cx5 .sb-head { padding:16px 20px;display:flex;align-items:center;gap:12px;flex:none;transition:background .5s var(--ease) }
.cx5 .sb-head .ic { width:30px;height:30px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:14px;flex:none }
.cx5 .sb-head .ttl { font-family:var(--font-head);font-weight:600;font-size:1.02rem;letter-spacing:-.01em }
.cx5 .sb-head .sub { font-size:.72rem;margin-top:1px }
.cx5 .sb-body { flex:1;padding:18px 20px;overflow:hidden;position:relative }
.cx5 .view { position:absolute;inset:0;padding:18px 20px;opacity:0;transform:translateY(10px);pointer-events:none;transition:opacity .5s var(--ease),transform .5s var(--ease);overflow-y:auto }
.cx5 .view.active { opacity:1;transform:none;pointer-events:auto }
.cx5 .sb-foot { padding:14px 20px 20px;flex:none }
.cx5 .cta { width:100%;border:none;border-radius:99px;padding:14px;font-family:var(--font-body);font-weight:600;font-size:.96rem;cursor:pointer;transition:all .25s var(--ease);background:var(--express);color:#fff;letter-spacing:-.01em }
.cx5 .cta:hover { transform:translateY(-2px);box-shadow:var(--shadow) }
.cx5 .cta:active { transform:translateY(0) scale(.98) }
.cx5 .cta.solve { background:var(--solve) }
.cx5 .cta.gold { background:var(--gold);color:#3a2a16 }
.cx5 .cta.ghost { background:transparent;border:1.5px solid var(--line);color:var(--text-strong) }
.cx5 .cta:disabled { opacity:.45;cursor:not-allowed;transform:none;box-shadow:none }
.cx5 .foot-note { text-align:center;font-size:.74rem;color:var(--text-mute);margin-top:10px }
.cx5 .steps { display:flex;gap:6px;margin-bottom:18px }
.cx5 .steps i { height:4px;flex:1;border-radius:99px;background:var(--paper-3);transition:background .4s }
.cx5 .steps i.on { background:var(--express) }
.cx5 .qlabel { font-size:.72rem;letter-spacing:.04em;color:var(--text-mute);margin-bottom:4px;font-weight:500 }
.cx5 .qtitle { font-family:var(--font-head);font-weight:600;color:var(--text-strong);font-size:1.18rem;line-height:1.25;letter-spacing:-.01em;margin-bottom:16px }
.cx5 .field { width:100%;background:var(--paper-2);border:1.5px solid var(--line);border-radius:16px;padding:13px 15px;font-size:.9rem;color:var(--text-strong);font-family:var(--font-body);min-height:84px;line-height:1.5;resize:none }
.cx5 .field::placeholder { color:var(--text-mute) }
.cx5 .tip { display:flex;gap:9px;background:var(--gold-soft);border-radius:14px;padding:11px 13px;margin-top:12px;font-size:.8rem;color:var(--gold-deep);line-height:1.4 }
.cx5 .tip i { flex:none;font-style:normal }
.cx5 .chips { display:flex;flex-wrap:wrap;gap:8px }
.cx5 .chip { padding:9px 15px;border-radius:99px;border:1.5px solid var(--line);background:var(--paper-2);font-size:.88rem;color:var(--text-strong);cursor:pointer;transition:all .2s }
.cx5 .chip:hover { border-color:var(--express) }
.cx5 .chip.sel { background:var(--express-soft);border-color:var(--express);color:var(--express-deep);font-weight:500 }
.cx5 .take-moment { text-align:center;padding:8px 0 18px }
.cx5 .take-moment .orb { width:58px;height:58px;border-radius:50%;background:var(--mauve-soft);display:flex;align-items:center;justify-content:center;margin:0 auto 14px;font-size:24px;color:var(--mauve-deep) }
.cx5 .take-moment h3 { font-family:var(--font-head);font-weight:600;color:var(--text-strong);font-size:1.25rem }
.cx5 .take-moment p { font-size:.86rem;color:var(--text);margin-top:6px;max-width:24ch;margin-inline:auto;line-height:1.45 }
.cx5 .intent { background:var(--paper-2);border:1.5px solid var(--line);border-radius:var(--r);padding:18px;margin-bottom:12px;cursor:pointer;transition:all .3s var(--ease);display:flex;gap:13px;align-items:flex-start }
.cx5 .intent:hover { transform:translateY(-2px);box-shadow:var(--shadow-sm) }
.cx5 .intent .ig { width:38px;height:38px;border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:17px;flex:none }
.cx5 .intent.express .ig { background:var(--express-soft);color:var(--express-deep) }
.cx5 .intent.solve .ig { background:var(--solve-soft);color:var(--solve-deep) }
.cx5 .intent .ih { font-family:var(--font-head);font-weight:600;color:var(--text-strong);font-size:1rem }
.cx5 .intent .is { font-size:.82rem;color:var(--text);margin-top:2px;line-height:1.4 }
.cx5 .intent.express:hover { border-color:var(--express) }
.cx5 .intent.solve:hover { border-color:var(--solve) }
.cx5 .composed { background:var(--paper-2);border:1px solid var(--line);border-radius:var(--r);padding:16px;display:grid;gap:12px }
.cx5 .composed .crow { display:flex;gap:11px;align-items:flex-start }
.cx5 .composed .ci { width:26px;height:26px;border-radius:8px;background:var(--express-soft);color:var(--express-deep);display:flex;align-items:center;justify-content:center;font-size:12px;flex:none }
.cx5 .composed .ck { font-size:.7rem;letter-spacing:.04em;text-transform:uppercase;color:var(--text-mute);font-weight:600;margin-bottom:1px }
.cx5 .composed .cv { font-size:.9rem;color:var(--text-strong);line-height:1.4 }
.cx5 .lock-wrap { text-align:center;padding:8px 0 }
.cx5 .lock-badge { width:60px;height:60px;border-radius:50%;background:var(--ink-2);display:flex;align-items:center;justify-content:center;margin:0 auto 14px;font-size:24px;color:var(--gold) }
.cx5 .lock-wrap h3 { font-family:var(--font-head);font-weight:600;color:var(--text-strong);font-size:1.28rem;letter-spacing:-.01em }
.cx5 .lock-wrap .lsub { font-size:.86rem;color:var(--text);margin-top:8px;max-width:26ch;margin-inline:auto;line-height:1.5 }
.cx5 .lock-shared { background:var(--paper-2);border:1px solid var(--line);border-radius:18px;padding:13px 15px;margin-top:16px;text-align:left }
.cx5 .lock-shared .lk { font-size:.66rem;letter-spacing:.1em;text-transform:uppercase;color:var(--mauve-deep);font-weight:600;margin-bottom:6px }
.cx5 .lock-shared .lv { font-size:.88rem;color:var(--text-strong);line-height:1.45;font-style:italic }
.cx5 .valid, .cx5 .aligned { text-align:center;padding:14px 0 }
.cx5 .valid .vcheck { width:62px;height:62px;border-radius:50%;background:var(--solve-soft);display:flex;align-items:center;justify-content:center;margin:0 auto 14px;font-size:27px;color:var(--solve-deep) }
.cx5 .valid h3, .cx5 .aligned h3 { font-family:var(--font-head);font-weight:600;color:var(--text-strong);font-size:1.28rem;letter-spacing:-.01em }
.cx5 .valid p, .cx5 .aligned p { font-size:.88rem;color:var(--text);margin-top:8px;line-height:1.5;max-width:26ch;margin-inline:auto }
.cx5 .aligned .avs { display:flex;align-items:center;justify-content:center;margin:8px 0 16px }
.cx5 .aligned .av { width:54px;height:54px;border-radius:50%;border:3px solid var(--paper) }
.cx5 .aligned .av.a { background:linear-gradient(135deg,var(--mauve),var(--lilac));margin-right:-10px;z-index:1 }
.cx5 .aligned .av.b { background:linear-gradient(135deg,var(--gold),var(--peach));margin-left:-10px }
.cx5 .aligned .hrt { font-size:18px;color:var(--mauve);margin:0 4px;z-index:2 }
.cx5 .screen[data-mode="idle"] .sb-head { background:var(--mauve-soft) }
.cx5 .screen[data-mode="idle"] .sb-head .ic { background:#fff;color:var(--mauve-deep) }
.cx5 .screen[data-mode="idle"] .sb-head .ttl { color:var(--mauve-deep) }
.cx5 .screen[data-mode="idle"] .sb-head .sub { color:var(--mauve) }
.cx5 .screen[data-mode="express"] .sb-head { background:var(--express-soft) }
.cx5 .screen[data-mode="express"] .sb-head .ic { background:#fff;color:var(--express-deep) }
.cx5 .screen[data-mode="express"] .sb-head .ttl { color:var(--express-deep) }
.cx5 .screen[data-mode="express"] .sb-head .sub { color:var(--express) }
.cx5 .screen[data-mode="receive"] .sb-head { background:var(--ink-2) }
.cx5 .screen[data-mode="receive"] .sb-head .ic { background:rgba(224,172,104,.2);color:var(--gold) }
.cx5 .screen[data-mode="receive"] .sb-head .ttl { color:#fff }
.cx5 .screen[data-mode="receive"] .sb-head .sub { color:var(--mute-on-ink) }
.cx5 .screen[data-mode="aligned"], .cx5 .screen[data-mode="care"] .sb-head {  }
.cx5 .screen[data-mode="aligned"] .sb-head, .cx5 .screen[data-mode="green"] .sb-head { background:var(--solve-soft) }
.cx5 .screen[data-mode="aligned"] .sb-head .ic, .cx5 .screen[data-mode="green"] .sb-head .ic { background:#fff;color:var(--solve-deep) }
.cx5 .screen[data-mode="aligned"] .sb-head .ttl, .cx5 .screen[data-mode="green"] .sb-head .ttl { color:var(--solve-deep) }
.cx5 .screen[data-mode="aligned"] .sb-head .sub, .cx5 .screen[data-mode="green"] .sb-head .sub { color:var(--solve) }
.cx5 .screen[data-mode="care"] .sb-head { background:var(--mauve-soft) }
.cx5 .screen[data-mode="care"] .sb-head .ic { background:#fff;color:var(--mauve-deep) }
.cx5 .screen[data-mode="care"] .sb-head .ttl { color:var(--mauve-deep) }
.cx5 .screen[data-mode="care"] .sb-head .sub { color:var(--mauve) }
.cx5 .screen[data-mode="garden"] .sb-head { background:var(--gold-soft) }
.cx5 .screen[data-mode="garden"] .sb-head .ic { background:#fff;color:var(--gold-deep) }
.cx5 .screen[data-mode="garden"] .sb-head .ttl { color:var(--gold-deep) }
.cx5 .screen[data-mode="garden"] .sb-head .sub { color:var(--gold-deep) }
.cx5 .nudge-card { background:var(--paper-2);border:1px solid var(--line);border-radius:var(--r);padding:22px 20px;text-align:center;margin-top:10px;box-shadow:var(--shadow-sm) }
.cx5 .nudge-card .ntag { display:inline-block;font-size:.66rem;letter-spacing:.1em;text-transform:uppercase;font-weight:600;padding:5px 12px;border-radius:99px;background:var(--peach);color:var(--gold-deep);margin-bottom:16px }
.cx5 .nudge-card .nq { font-family:var(--font-head);font-weight:600;color:var(--text-strong);font-size:1.32rem;line-height:1.3;letter-spacing:-.01em }
.cx5 .nudge-card .nh { font-size:.82rem;color:var(--text-mute);margin-top:12px }
.cx5 .nudge-done { text-align:center;padding:24px 0 }
.cx5 .nudge-done .nd-ic { width:62px;height:62px;border-radius:50%;background:var(--mauve-soft);display:flex;align-items:center;justify-content:center;margin:0 auto 14px;font-size:26px;color:var(--mauve-deep) }
.cx5 .nudge-done h3 { font-family:var(--font-head);font-weight:600;color:var(--text-strong);font-size:1.28rem }
.cx5 .nudge-done p { font-size:.88rem;color:var(--text);margin-top:8px;max-width:24ch;margin-inline:auto;line-height:1.5 }
.cx5 .nudge-done .tick { display:inline-flex;align-items:center;gap:8px;margin-top:16px;font-size:.84rem;color:var(--mauve-deep);font-weight:500;background:var(--mauve-soft);padding:8px 16px;border-radius:99px }
.cx5 .care-card { background:var(--paper-2);border:1px solid var(--line);border-radius:var(--r);padding:18px;text-align:center;margin-bottom:12px }
.cx5 .care-card .cl { font-family:var(--font-head);color:var(--mauve-deep);font-weight:600;font-size:.96rem }
.cx5 .care-card .cv { font-family:var(--font-head);font-weight:700;color:var(--mauve-deep);font-size:2rem;letter-spacing:-.02em;margin-top:2px }
.cx5 .care-card .cv .hh { font-size:1.3rem;color:var(--mauve) }
.cx5 .care-card .cs { font-size:.78rem;color:var(--text-mute);font-style:italic;margin-top:2px }
.cx5 .care-explain { background:var(--paper-2);border:1px solid var(--line);border-radius:var(--r);padding:16px 18px;margin-top:4px }
.cx5 .care-explain .ce-h { font-weight:600;color:var(--text-strong);font-size:.94rem;margin-bottom:10px }
.cx5 .care-explain ul { list-style:none;display:grid;gap:8px }
.cx5 .care-explain li { font-size:.86rem;color:var(--text);display:flex;align-items:center;gap:9px }
.cx5 .care-explain li .cd { width:6px;height:6px;border-radius:50%;background:var(--mauve);flex:none }
.cx5 .garden-sky { position:relative;height:208px;border-radius:var(--r);overflow:hidden;margin-bottom:14px;transition:background 1.1s var(--ease) }
.cx5 .garden-sky.sprout { background:linear-gradient(180deg,#EFE6E9 0%,#EDE2DF 50%,#E4C99E 50%,#DBBC8A 100%) }
.cx5 .garden-sky.flourish { background:linear-gradient(180deg,#FBEAD0 0%,#F7DEB6 50%,#E4C99E 50%,#DBBC8A 100%) }
.cx5 .garden-soil { position:absolute;left:0;right:0;bottom:0;height:50%;background:linear-gradient(180deg,#E4C99E,#D6B07A) }
.cx5 .g-art { position:absolute;inset:0 }
.cx5 .plant { position:absolute;transition:opacity 1s var(--ease),transform 1s var(--ease);transform-origin:bottom center }
.cx5 .plant.seed { font-size:22px;bottom:46%;opacity:.9 }
.cx5 .plant.s1 { left:16% }
.cx5 .plant.s2 { left:38% }
.cx5 .plant.s3 { left:60% }
.cx5 .plant.s4 { left:80% }
.cx5 .plant.grown { opacity:0;transform:translateY(16px) scale(.4) }
.cx5 .g-art.grown-on .plant.seed { opacity:0;transform:translateY(8px) scale(.5) }
.cx5 .g-art.grown-on .plant.grown { opacity:1;transform:translateY(0) scale(1) }
.cx5 .plant.tree { font-size:48px;bottom:42% }
.cx5 .plant.t1 { left:6% }
.cx5 .plant.t2 { right:6%;left:auto }
.cx5 .plant.flower { font-size:30px;bottom:44% }
.cx5 .plant.f1 { left:30% }
.cx5 .plant.f2 { left:46% }
.cx5 .plant.f3 { left:62% }
.cx5 .plant.bf { font-size:22px }
.cx5 .plant.bf1 { left:34%;top:24% }
.cx5 .plant.bf2 { right:28%;left:auto;top:16%;transition-delay:.15s }
.cx5 .plant.sun { font-size:26px;right:12%;top:14px }
.cx5 .g-art.grown-on .plant.bf { animation:flutter 3s ease-in-out infinite 1s }
@keyframes flutter { 0%,100%{transform:translateY(0) translateX(0)}50%{transform:translateY(-8px) translateX(6px)} }
.cx5 .garden-status { position:absolute;top:12px;left:14px;font-family:var(--font-mark);font-weight:700;letter-spacing:.1em;text-transform:uppercase;font-size:.58rem;color:var(--gold-deep);background:rgba(255,255,255,.78);padding:5px 11px;border-radius:99px;transition:color .5s }
.cx5 .garden-h { font-family:var(--font-head);font-weight:700;color:var(--text-strong);font-size:1.4rem;letter-spacing:-.02em }
.cx5 .garden-sub { font-size:.78rem;color:var(--text-mute);margin-top:1px;margin-bottom:14px }
.cx5 .gstats { display:grid;grid-template-columns:repeat(3,1fr);gap:8px;background:var(--paper-2);border:1px solid var(--line);border-radius:var(--r);padding:14px 10px;margin-bottom:12px }
.cx5 .gstat { text-align:center }
.cx5 .gnum { font-family:var(--font-head);font-weight:700;color:var(--text-strong);font-size:1.5rem;letter-spacing:-.02em;line-height:1 }
.cx5 .glbl { font-size:.62rem;letter-spacing:.06em;text-transform:uppercase;color:var(--text-mute);margin-top:4px }
.cx5 .gjourney { margin-bottom:6px }
.cx5 .gj-row { display:flex;justify-content:space-between;font-size:.78rem;color:var(--text);margin-bottom:6px }
.cx5 .gj-row b { color:var(--mauve-deep) }
.cx5 .gj-track { height:7px;border-radius:99px;background:var(--paper-3);overflow:hidden }
.cx5 .gj-fill { height:100%;border-radius:99px;background:linear-gradient(90deg,var(--mauve),var(--gold));transition:width 1.4s var(--ease) }
.cx5 .garden-tap { margin-top:14px;background:var(--gold-soft);border-radius:16px;padding:12px 14px;text-align:center }
.cx5 .garden-tap .gt-h { font-size:.78rem;color:var(--gold-deep);font-weight:600;margin-bottom:8px;transition:all .3s }
.cx5 .garden-tap .gt-opts { display:flex;gap:6px;flex-wrap:wrap;justify-content:center }
.cx5 .gt-opt { font-size:.74rem;background:#fff;border:1px solid var(--line);border-radius:99px;padding:7px 12px;cursor:pointer;color:var(--text-strong);transition:all .2s }
.cx5 .gt-opt:hover:not(:disabled) { border-color:var(--gold);transform:translateY(-1px) }
.cx5 .gt-opt:disabled { opacity:.4;cursor:default }
.cx5 .mem-tabs { display:flex;gap:20px;border-bottom:1px solid var(--line);margin-bottom:16px }
.cx5 .mem-tab { font-family:var(--font-head);font-weight:600;font-size:1rem;padding-bottom:10px;color:var(--text-mute);position:relative }
.cx5 .mem-tab.on { color:var(--mauve-deep) }
.cx5 .mem-tab.on::after { content:"";position:absolute;left:0;right:0;bottom:-1px;height:2px;background:var(--mauve) }
.cx5 .mem-card { background:var(--paper-2);border:1px solid var(--line);border-radius:var(--r);padding:16px;display:flex;gap:13px;align-items:center;margin-bottom:10px }
.cx5 .mem-card .mi { width:44px;height:44px;border-radius:13px;display:flex;align-items:center;justify-content:center;font-size:19px;flex:none }
.cx5 .mem-card .mh { font-family:var(--font-head);font-weight:600;color:var(--text-strong);font-size:.96rem }
.cx5 .mem-card .ms { font-size:.78rem;color:var(--text-mute);margin-top:2px }
.cx5 .mem-resurface { background:var(--mauve-soft);border-radius:var(--r);padding:16px 18px;margin-top:4px }
.cx5 .mem-resurface .mr-k { font-size:.66rem;letter-spacing:.1em;text-transform:uppercase;color:var(--mauve-deep);font-weight:600;margin-bottom:6px }
.cx5 .mem-resurface .mr-v { font-size:.92rem;color:var(--text-strong);line-height:1.45 }
.cx5 .copy .ctitle { font-family:var(--font-head);font-weight:600;color:#fff;font-size:clamp(1.6rem,3vw,2.3rem);line-height:1.12;letter-spacing:-.02em;margin-bottom:14px;text-wrap:balance }
.cx5 .copy .clead { color:var(--mute-on-ink);font-size:1.04rem;line-height:1.65 }
.cx5 .moat { margin-top:26px;border:1px solid var(--line-ink);border-left:3px solid var(--gold);border-radius:0 var(--r) var(--r) 0;padding:20px 22px;background:rgba(255,255,255,.02) }
.cx5 .moat .mt { font-size:.72rem;letter-spacing:.14em;text-transform:uppercase;color:var(--gold);font-weight:600;margin-bottom:10px }
.cx5 .moat .mq { font-family:var(--font-head);font-weight:500;color:#fff;font-size:1.1rem;line-height:1.4;letter-spacing:-.01em }
.cx5 .moat .mn { color:var(--mute-on-ink);font-size:.9rem;margin-top:10px;line-height:1.55 }
.cx5 .tag-row { display:flex;flex-wrap:wrap;gap:8px;margin-top:20px }
.cx5 .trow { display:inline-flex;align-items:center;gap:7px;font-size:.8rem;color:var(--mute-on-ink);border:1px solid var(--line-ink);border-radius:99px;padding:7px 14px }
.cx5 .trow .d { width:7px;height:7px;border-radius:50%;background:var(--gold) }
.cx5 .restart { margin-top:22px;display:inline-flex;align-items:center;gap:8px;background:none;border:none;color:var(--gold);font-family:var(--font-body);font-size:.86rem;font-weight:600;cursor:pointer;padding:0 }
.cx5 .restart:hover { text-decoration:underline }


/* ---- Live signup counter (social proof) ---- */
.cx-count-num { font-family: var(--font-head); font-weight: 600; font-size: clamp(3rem, 8vw, 5rem); line-height: 1; letter-spacing: -.03em; color: var(--mauve-deep); }
.cx-count-lbl { margin-top: 12px; font-size: 1rem; color: var(--text); max-width: 32ch; margin-inline: auto; }


/* ---- FAQ details (expandable questions) ---- */
details { transition: background .3s, border-color .3s; }
details:hover { background: rgba(178,148,166,.04); border-color: rgba(178,148,166,.25); }
summary { outline: none; user-select: none; }
summary:focus-visible { outline: 2px solid var(--mauve); outline-offset: 2px; }


/* ---- Sticky mobile CTA bar (shown on small screens only) ---- */
.sticky-cta { display: none; }
@media (max-width: 860px) {
  .sticky-cta {
    position: fixed; left: 12px; right: 12px; bottom: 12px; z-index: 90;
    display: flex; align-items: center; justify-content: space-between; gap: 12px;
    padding: 13px 18px; border-radius: 999px;
    background: var(--gold); color: #3a2a16;
    font-family: var(--font-body); font-weight: 600; font-size: .92rem;
    box-shadow: 0 14px 40px -12px rgba(224,172,104,.75);
    border: 1px solid rgba(58,42,22,.10);
  }
  .sticky-cta:active { transform: scale(.985); }
  .sticky-cta .sticky-cta-go { white-space: nowrap; opacity: .9; }
  html[data-theme="dark"] .sticky-cta { box-shadow: 0 14px 40px -12px rgba(0,0,0,.6); }
}


/* ---- Tone-detection demo, redesigned in the current system (lives in the problem section) ---- */
.tone-demo { background: var(--paper-2); border: 1px solid var(--line); border-radius: var(--r-lg); padding: clamp(20px,3vw,28px); box-shadow: var(--shadow-sm); }
.tone-head { display: flex; align-items: center; gap: 12px; padding-bottom: 16px; border-bottom: 1px solid var(--line); margin-bottom: 18px; }
.tone-ava { width: 42px; height: 42px; border-radius: 50%; background: linear-gradient(135deg, var(--lilac), var(--mauve-soft)); flex: none; }
.tone-name { font-weight: 600; color: var(--text-strong); font-size: .98rem; }
.tone-sub { font-size: .82rem; color: var(--text-mute); }
.tone-row { display: flex; margin-bottom: 12px; }
.tone-row.them { justify-content: flex-start; }
.tone-row.you { justify-content: flex-end; }
.tone-bubble { max-width: 82%; padding: 12px 16px; border-radius: 18px; font-size: .96rem; line-height: 1.45; }
.tone-bubble.harsh { background: var(--paper-3); color: var(--text-strong); border-bottom-left-radius: 6px; }
.tone-send { background: var(--mauve); color: #fff; font-weight: 600; border-bottom-right-radius: 6px; }
.tone-soft { overflow: hidden; max-height: 0; opacity: 0; transform: translateY(-6px); margin: 0; transition: max-height .7s var(--ease), opacity .6s var(--ease), transform .6s var(--ease), margin .7s var(--ease); }
.tone-soft.show { max-height: 220px; opacity: 1; transform: translateY(0); margin: 0 0 12px; }
.tone-soft-inner { background: rgba(224,172,104,.10); border: 1px solid var(--gold-soft); border-radius: 16px; padding: 14px 16px; }
.tone-tag { display: inline-flex; align-items: center; gap: 7px; font-size: .72rem; letter-spacing: .04em; text-transform: uppercase; color: var(--gold-deep); font-weight: 600; margin-bottom: 8px; }
.tone-tag svg { width: 15px; height: 15px; flex: none; }
.tone-soft-text { color: var(--text-strong); font-size: .98rem; line-height: 1.45; font-style: italic; }
.tone-note { margin-top: 16px; font-size: .9rem; color: var(--text-mute); text-align: center; line-height: 1.5; }
