/* SoulEQ - Two-sided platform layer.
   Listener surfaces lean sapphire/blue; Creator surfaces lean violet.
   Builds on phones.css device frame + screen atmosphere. */

/* ============ SIDE-LEAN TEXT HELPERS ============ */
.violet-grad-text {
  background: linear-gradient(120deg, #C4B5FD 0%, #A78BFA 38%, #8B5CF6 68%, #C084FC 100%);
  -webkit-background-clip: text; background-clip: text; color: transparent;
}
.sapphire-grad-text {
  background: linear-gradient(120deg, #BFE0FF 0%, #93C5FD 38%, #60A5FA 70%, #3B82F6 100%);
  -webkit-background-clip: text; background-clip: text; color: transparent;
}

/* an eyebrow tinted per side */
.eyebrow.listener { color: rgba(96,165,250,0.85); }
.eyebrow.listener::before { background: #60A5FA; box-shadow: 0 0 8px #60A5FA; }
.eyebrow.creator { color: rgba(167,139,250,0.85); }
.eyebrow.creator::before { background: #A78BFA; box-shadow: 0 0 8px #A78BFA; }

/* =========================================================
   PLATFORM CENTERPIECE - dual phones + gold mode switch
   ========================================================= */
.platform-stage {
  position: relative;
  margin-top: 30px;
  display: flex;
  flex-direction: column;
  align-items: center;
}
.platform-stage::before {
  content: ''; position: absolute; z-index: 0;
  top: 4%; left: 50%; transform: translateX(-50%);
  width: 760px; height: 420px; max-width: 92vw;
  background:
    radial-gradient(circle at 30% 50%, rgba(59,130,246,0.34) 0%, transparent 58%),
    radial-gradient(circle at 70% 50%, rgba(139,92,246,0.36) 0%, transparent 58%);
  filter: blur(60px);
  pointer-events: none;
}
.dual {
  position: relative; z-index: 2;
  display: flex; align-items: flex-start; justify-content: center;
  gap: clamp(20px, 5vw, 70px);
}
.dual-col { display: flex; flex-direction: column; align-items: center; gap: 18px; }
.dual-col .device { --dw: 250px; }
.dual-col.l .device { transform: rotate(-3deg); }
.dual-col.r .device { transform: rotate(3deg); }
.dual-label {
  font-family: 'JetBrains Mono', monospace;
  font-size: 10px; letter-spacing: 0.34em; text-transform: uppercase;
  display: inline-flex; align-items: center; gap: 9px;
  padding: 8px 16px; border-radius: 999px;
}
.dual-label::before { content: ''; width: 6px; height: 6px; border-radius: 50%; }
.dual-label.listener {
  color: #BFE0FF; border: 1px solid rgba(96,165,250,0.42); background: rgba(59,130,246,0.10);
}
.dual-label.listener::before { background: #60A5FA; box-shadow: 0 0 8px #60A5FA; }
.dual-label.creator {
  color: #DDD0FF; border: 1px solid rgba(167,139,250,0.42); background: rgba(139,92,246,0.10);
}
.dual-label.creator::before { background: #A78BFA; box-shadow: 0 0 8px #A78BFA; }

.mode-switch {
  position: relative; z-index: 3;
  margin-top: 38px;
  display: inline-flex; align-items: center; gap: 12px;
  padding: 15px 28px; border-radius: 999px; cursor: default;
  font-family: 'JetBrains Mono', monospace;
  font-size: 12px; letter-spacing: 0.2em; text-transform: uppercase; font-weight: 600;
  color: #1c1402;
  background: linear-gradient(135deg, #F3DD9A 0%, #E8C766 45%, #C9A24B 100%);
  border: 1px solid rgba(232,201,122,0.7);
  box-shadow: 0 0 36px rgba(201,162,75,0.45), inset 0 1px 0 rgba(255,255,255,0.5);
}
.mode-switch svg { width: 16px; height: 16px; }
.platform-note {
  margin-top: 18px;
  font-family: 'JetBrains Mono', monospace;
  font-size: 10.5px; letter-spacing: 0.22em; text-transform: uppercase;
  color: var(--text-lo);
}

/* =========================================================
   SIDE SECTIONS - two-column copy + phone cluster
   ========================================================= */
.side-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 70px;
  align-items: center;
}
.side-grid.flip .side-copy { order: 2; }
.side-grid.flip .side-phones { order: 1; }
.side-copy .eyebrow { justify-content: flex-start; }
.side-copy h2 {
  font-family: 'Cormorant', Georgia, serif; font-weight: 500;
  font-size: clamp(38px, 4.4vw, 62px); line-height: 1.04;
  color: var(--text-hi); letter-spacing: -0.015em; text-wrap: balance; margin: 0;
}
.side-copy .body { margin-top: 22px; max-width: 480px; }

/* listener: 6-state compact list */
.states-list {
  margin-top: 34px;
  display: grid; grid-template-columns: 1fr 1fr; gap: 22px 30px;
  max-width: 520px;
}
.state-item { border-left: 1px solid rgba(96,165,250,0.28); padding-left: 16px; }
.state-item .nm {
  font-family: 'Cormorant', Georgia, serif; font-weight: 500;
  font-size: 22px; color: var(--text-hi); line-height: 1.1; margin-bottom: 5px;
}
.state-item .ds { font-family: 'Inter', sans-serif; font-size: 13px; line-height: 1.5; color: var(--text-mid); }

/* creator: 4-step numbered flow */
.creator-steps {
  margin-top: 34px;
  display: flex; flex-direction: column; gap: 4px;
  max-width: 520px;
}
.cstep { display: flex; gap: 18px; padding: 14px 0; position: relative; }
.cstep:not(:last-child) { border-bottom: 1px solid rgba(167,139,250,0.13); }
.cstep .cn {
  flex-shrink: 0; width: 34px; height: 34px; border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  font-family: 'JetBrains Mono', monospace; font-size: 12px; font-weight: 600;
  color: #DDD0FF;
  background: rgba(139,92,246,0.12); border: 1px solid rgba(167,139,250,0.4);
}
.cstep .ct { padding-top: 3px; }
.cstep .ct .h {
  font-family: 'Cormorant', Georgia, serif; font-weight: 500; font-size: 21px;
  color: var(--text-hi); line-height: 1.15; margin-bottom: 4px;
}
.cstep .ct .p { font-family: 'Inter', sans-serif; font-size: 13.5px; line-height: 1.5; color: var(--text-mid); }
.cstep .ct .pay {
  font-family: 'JetBrains Mono', monospace; font-size: 12px; letter-spacing: 0.02em;
  color: #9CE0B4; margin-left: 4px;
}

/* phone cluster (two devices fanned) */
.side-phones { position: relative; display: flex; justify-content: center; align-items: center; min-height: 560px; }
.side-phones .glow { position: absolute; z-index: 0; width: 420px; height: 420px; border-radius: 50%; filter: blur(70px); pointer-events: none; }
.side-phones.listener .glow { background: radial-gradient(circle, rgba(59,130,246,0.42) 0%, rgba(45,212,191,0.10) 50%, transparent 72%); }
.side-phones.creator .glow { background: radial-gradient(circle, rgba(139,92,246,0.46) 0%, rgba(124,58,237,0.12) 50%, transparent 72%); }
.phone-pair { position: relative; z-index: 2; display: flex; align-items: center; }
.phone-pair .device { --dw: 240px; }
.phone-pair .device.front { z-index: 3; }
.phone-pair .device.back { z-index: 2; }
.side-phones.listener .phone-pair .device.back { transform: translateX(34px) rotate(5deg) scale(0.9); }
.side-phones.listener .phone-pair .device.front { transform: translateX(-18px) rotate(-3deg); }
.side-phones.creator .phone-pair .device.back { transform: translateX(-34px) rotate(-5deg) scale(0.9); }
.side-phones.creator .phone-pair .device.front { transform: translateX(18px) rotate(3deg); }

/* =========================================================
   CREATOR SCREEN: VAULT (violet)
   ========================================================= */
.scr-vault { background: radial-gradient(ellipse at 50% 0%, #1B1140 0%, #120B2E 42%, #07040F 80%, #000 100%); }
.scr-vault .top { display: flex; align-items: center; justify-content: space-between; padding: 22px 18px 6px; }
.scr-vault .top .eyb { font-size: 8px; letter-spacing: 0.32em; }
.scr-vault .top .av {
  width: 24px; height: 24px; border-radius: 50%;
  background: linear-gradient(135deg, #A78BFA, #7C3AED);
  box-shadow: 0 0 12px rgba(139,92,246,0.5);
}
.scr-vault .ttl { padding: 22px 18px 16px; }
.scr-vault .ttl .eyb { font-size: 8.5px; letter-spacing: 0.4em; margin-bottom: 11px; }
.scr-vault .ttl h3 { font-family: 'Fraunces', serif; font-weight: 300; font-size: 24px; line-height: 1.1; color: #F4F0FF; letter-spacing: -0.5px; margin: 0; }
.scr-vault .ttl .vault-stat { font-family: 'JetBrains Mono', monospace; font-size: 8px; letter-spacing: 0.08em; color: rgba(167,139,250,0.72); margin-top: 9px; }
.scr-vault .upload {
  margin: 0 18px 16px; padding: 16px; border-radius: 16px; text-align: center;
  border: 1px dashed rgba(167,139,250,0.45);
  background: linear-gradient(180deg, rgba(139,92,246,0.10) 0%, rgba(124,58,237,0.03) 100%);
}
.scr-vault .upload .ic {
  width: 30px; height: 30px; margin: 0 auto 8px; border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  background: rgba(167,139,250,0.16); border: 1px solid rgba(167,139,250,0.4); color: #DDD0FF;
}
.scr-vault .upload .ic svg { width: 14px; height: 14px; }
.scr-vault .upload .u1 { font-family: 'Inter', sans-serif; font-size: 12.5px; color: #F4F0FF; font-weight: 500; }
.scr-vault .upload .u2 { font-size: 9px; color: rgba(221,208,255,0.6); margin-top: 3px; font-family: 'Inter', sans-serif; }
.scr-vault .feed-lbl {
  display: flex; align-items: center; justify-content: space-between; padding: 0 18px 10px;
}
.scr-vault .feed-lbl .t { font-family: 'JetBrains Mono', monospace; font-size: 8.5px; letter-spacing: 0.26em; text-transform: uppercase; color: rgba(167,139,250,0.78); }
.scr-vault .feed-lbl .c { font-family: 'JetBrains Mono', monospace; font-size: 8px; color: rgba(221,208,255,0.5); }
.scr-vault .feed { padding: 0 18px; display: flex; flex-direction: column; gap: 8px; }
.sub-row {
  display: flex; align-items: center; justify-content: space-between; gap: 10px;
  padding: 12px 13px; border-radius: 14px;
  background: linear-gradient(135deg, rgba(255,255,255,0.04), rgba(255,255,255,0.012));
  border: 1px solid rgba(167,139,250,0.16);
}
.sub-row .l .nm { font-family: 'Fraunces', serif; font-weight: 300; font-size: 15px; color: rgba(244,240,255,0.95); letter-spacing: -0.2px; }
.sub-row .l .mt { font-family: 'JetBrains Mono', monospace; font-size: 8px; color: rgba(167,139,250,0.7); margin-top: 3px; }
.sub-row .r { display: flex; flex-direction: column; align-items: flex-end; gap: 5px; flex-shrink: 0; }
.badge { font-family: 'JetBrains Mono', monospace; font-size: 7.5px; letter-spacing: 0.12em; text-transform: uppercase; padding: 3px 9px; border-radius: 999px; white-space: nowrap; }
.badge.ok { color: #9CE0B4; background: rgba(156,224,180,0.10); border: 1px solid rgba(156,224,180,0.32); }
.badge.rev { color: #E8C766; background: rgba(232,201,122,0.10); border: 1px solid rgba(232,201,122,0.32); }
.badge.no { color: rgba(248,180,180,0.85); background: rgba(248,140,140,0.08); border: 1px solid rgba(248,140,140,0.26); }
.sub-row .amt { font-family: 'JetBrains Mono', monospace; font-size: 11px; color: #fff; font-weight: 600; }
.sub-row .amt.dim { color: rgba(221,208,255,0.35); }
.scr-vault .vault-foot {
  margin-top: auto; padding: 14px 18px 18px; text-align: center;
  font-family: 'JetBrains Mono', monospace; font-size: 7.5px; letter-spacing: 0.3em; text-transform: uppercase; color: rgba(221,208,255,0.5);
}

/* =========================================================
   CREATOR SCREEN: EARNINGS + IMPACT (violet)
   ========================================================= */
.scr-impact { background: radial-gradient(ellipse at top, #170E38 0%, #0C0722 46%, #000 86%); }
.scr-impact .top { display: flex; align-items: center; justify-content: space-between; padding: 22px 18px 6px; }
.scr-impact .top .eyb { font-size: 8px; letter-spacing: 0.32em; }
.scr-impact .top .range { font-family: 'JetBrains Mono', monospace; font-size: 8px; letter-spacing: 0.14em; color: rgba(221,208,255,0.6); }
.scr-impact .earn { text-align: center; padding: 26px 18px 22px; }
.scr-impact .earn .eyb { font-size: 8.5px; letter-spacing: 0.4em; margin-bottom: 12px; }
.scr-impact .earn .big { font-family: 'Fraunces', serif; font-weight: 300; font-size: 58px; line-height: 0.95; letter-spacing: -2px; }
.scr-impact .earn .cap { font-family: 'JetBrains Mono', monospace; font-size: 8.5px; letter-spacing: 0.16em; text-transform: uppercase; color: rgba(156,224,180,0.85); margin-top: 12px; }
.scr-impact .istats { display: grid; grid-template-columns: repeat(3, 1fr); gap: 8px; padding: 0 18px 18px; }
.scr-impact .istats .cell { border-radius: 14px; padding: 13px 10px; text-align: center;
  background: linear-gradient(135deg, rgba(167,139,250,0.10), rgba(124,58,237,0.03)); border: 1px solid rgba(167,139,250,0.2); }
.scr-impact .istats .v { font-family: 'Fraunces', serif; font-weight: 300; font-size: 24px; color: #fff; line-height: 1; }
.scr-impact .istats .k { font-family: 'JetBrains Mono', monospace; font-size: 6.8px; letter-spacing: 0.1em; text-transform: uppercase; color: rgba(167,139,250,0.75); margin-top: 7px; }
.scr-impact .moments { padding: 0 18px; }
.scr-impact .moments .mlbl { font-family: 'JetBrains Mono', monospace; font-size: 8.5px; letter-spacing: 0.26em; text-transform: uppercase; color: rgba(167,139,250,0.78); margin-bottom: 11px; }
.scr-impact .mrow { display: flex; align-items: center; justify-content: space-between; gap: 10px; padding: 11px 0; border-top: 1px solid rgba(167,139,250,0.12); }
.scr-impact .mrow:first-of-type { border-top: none; }
.scr-impact .mrow .nm { font-family: 'Fraunces', serif; font-weight: 300; font-size: 14px; color: rgba(244,240,255,0.92); letter-spacing: -0.2px; }
.scr-impact .mrow .mt { font-family: 'JetBrains Mono', monospace; font-size: 8px; color: rgba(221,208,255,0.55); margin-top: 2px; }
.scr-impact .mrow .pct { font-family: 'JetBrains Mono', monospace; font-size: 11px; color: #C4B5FD; font-weight: 600; }
.scr-impact .impact-foot { margin-top: auto; padding: 16px 18px 18px; text-align: center;
  font-family: 'JetBrains Mono', monospace; font-size: 7.5px; letter-spacing: 0.3em; text-transform: uppercase; color: rgba(221,208,255,0.5); }

/* =========================================================
   DENSE CREATOR SCREENS - scroll + soft bottom fade
   (matches the Human Record phone: clip gracefully, never hard-cut)
   ========================================================= */
.scr-vault .scr-content,
.scr-impact .scr-content {
  overflow-y: auto; overflow-x: hidden;
  scrollbar-width: none;
}
.scr-vault .scr-content::-webkit-scrollbar,
.scr-impact .scr-content::-webkit-scrollbar { display: none; }
.scr-vault::after,
.scr-impact::after {
  content: ''; position: absolute; left: 0; right: 0; bottom: 0;
  height: 48px; z-index: 28; pointer-events: none;
}
.scr-vault::after { background: linear-gradient(0deg, #050310 0%, rgba(5,3,16,0) 100%); }
.scr-impact::after { background: linear-gradient(0deg, #000 0%, rgba(0,0,0,0) 100%); }

/* =========================================================
   NEW NARRATIVE WRAPPERS (what-it-is states band, vision)
   ========================================================= */
/* states band sits beneath the centered hero copy */
.states-band { margin-top: clamp(64px, 9vw, 120px); }
/* the single hero screenshot gets more presence than the fanned pairs */
.states-band .phone-pair .device { --dw: min(300px, 86vw); }
.states-list.states-7 { max-width: 540px; }

/* vision: domain chips + compact, sourced market block */
.vision-domains { margin-top: 44px; }
.market-mini { margin-top: 88px; text-align: center; }
.market-mini > .eyebrow { display: inline-flex; margin-bottom: 22px; }
.market-mini .market-intro { max-width: 580px; margin: 0 auto; font-family: 'Inter', sans-serif; font-size: 15px; line-height: 1.6; color: var(--text-mid); }

/* ============ RESPONSIVE ============ */
@media (max-width: 920px) {
  .side-grid { grid-template-columns: 1fr; gap: 44px; }
  .side-grid.flip .side-copy { order: 1; }
  .side-grid.flip .side-phones { order: 2; }
  .side-copy { text-align: center; }
  .side-copy .eyebrow { justify-content: center; }
  .side-copy .body, .states-list, .creator-steps, .concierge-mock, .states-or { margin-left: auto; margin-right: auto; }
  .states-list { text-align: left; }
  .side-phones { min-height: 0; }
  .dual { gap: 16px; }
  .dual-col .device { --dw: 200px; }
}
@media (max-width: 560px) {
  .states-list { grid-template-columns: 1fr; }
  .dual { flex-direction: column; align-items: center; gap: 30px; }
  .dual-col .device { --dw: 248px; }
  .dual-col.l .device, .dual-col.r .device { transform: none; }
  .phone-pair .device.back { display: none; }
  .side-phones.listener .phone-pair .device.front,
  .side-phones.creator .phone-pair .device.front { transform: none; }
  .phone-pair .device { --dw: 250px; }
}


/* Concierge (free-text) lead + 5 real states on the What-it-is section */
.concierge-mock { margin-top: 30px; max-width: 440px; padding: 20px 22px; border-radius: 20px;
  border: 1px solid rgba(167,139,250,0.28); background: linear-gradient(135deg, rgba(124,95,207,0.15), rgba(59,130,246,0.05)); }
.concierge-mock .cm-lbl { font-family: 'JetBrains Mono', monospace; font-size: 10px; letter-spacing: 0.28em; text-transform: uppercase; color: #E8C97A; margin-bottom: 14px; }
.concierge-mock .cm-field { display: flex; align-items: center; gap: 12px; padding: 11px 11px 11px 20px; border-radius: 999px; background: rgba(5,8,26,0.4); border: 1px solid rgba(167,139,250,0.32); }
.concierge-mock .cm-ph { flex: 1; font-family: 'Cormorant', Georgia, serif; font-style: italic; font-size: 19px; color: rgba(244,240,255,0.62); }
.concierge-mock .cm-go { width: 34px; height: 34px; flex-shrink: 0; border-radius: 50%; display: flex; align-items: center; justify-content: center; color: #fff; background: var(--accent-grad); box-shadow: 0 0 16px rgba(96,165,250,0.4); }
.concierge-mock .cm-sub { font-family: 'Inter', sans-serif; font-size: 13px; color: var(--text-mid); margin-top: 14px; }
.states-or { margin-top: 34px; margin-bottom: 0; display: flex; align-items: center; gap: 14px; font-family: 'JetBrains Mono', monospace; font-size: 9.5px; letter-spacing: 0.32em; text-transform: uppercase; color: rgba(191,224,255,0.5); }
.states-or::after { content: ''; flex: 1; height: 1px; background: linear-gradient(90deg, rgba(167,139,250,0.32), transparent); }

/* editorial "index" treatment: serif name + italic descriptor on hairlines */
.states-list.states-5 {
  display: flex; flex-direction: column; gap: 0;
  max-width: 470px; margin-top: 16px;
  border-top: 1px solid rgba(167,139,250,0.16);
}
.states-list.states-5 .state-item {
  border-left: none; padding: 15px 2px;
  display: flex; align-items: baseline; gap: 20px;
  border-bottom: 1px solid rgba(167,139,250,0.16);
  transition: padding-left .3s cubic-bezier(.4,0,.2,1), border-color .3s ease;
}
.states-list.states-5 .state-item:hover { padding-left: 9px; border-bottom-color: rgba(201,162,75,0.5); }
.states-list.states-5 .state-item .nm {
  font-family: 'Cormorant', Georgia, serif; font-weight: 500; font-size: 25px;
  line-height: 1; color: var(--text-hi); letter-spacing: -0.01em; margin-bottom: 0;
  flex: 0 0 112px;
}
.states-list.states-5 .state-item .ds {
  font-family: 'Cormorant', Georgia, serif; font-style: italic; font-weight: 400;
  font-size: 16.5px; line-height: 1.35; color: rgba(232,236,255,0.56);
}

/* Why-it's-different: force an even 3 + 3 pill grid */
#different .layers-visual { display: grid; grid-template-columns: repeat(3, max-content); justify-content: center; align-items: center; gap: 14px; }
@media (max-width: 600px) { #different .layers-visual { grid-template-columns: repeat(2, max-content); } }
