
@font-face {
  font-family: 'BicycleDay';
  src: url('/BicycleDay.otf') format('opentype');
  font-weight: normal;
  font-style: normal;
  font-display: swap;
}
*, *::before, *::after { margin: 0; padding: 0; box-sizing: border-box; }

:root {
  /* ── Portal Brand Colors ── */
 --portal-orange: #ffa300;
 --portal-pink: #ff629a;
 --portal-teal: #84cfc3;
 --portal-dark: #252525;
 --portal-darker: #1a1818;
 --portal-grad: linear-gradient(135deg, #ffa300 0%, #ff629a 50%, #84cfc3 100%);
 --portal-grad-h: linear-gradient(90deg, #ffa300 0%, #ff629a 50%, #84cfc3 100%);
 --portal-orange-soft: rgba(255, 163, 0, 0.08);
 --portal-orange-border: rgba(255, 163, 0, 0.22);
 --portal-pink-soft: rgba(255, 98, 154, 0.08);
 --portal-teal-soft: rgba(132, 207, 195, 0.08);
  /* ── Legacy aliases (mapped to brand) ── */
 --bg-deep: #252525;
 --bg-glass: rgba(37,37,37,0.85);
 --bg-glass-solid: rgba(26,24,24,0.92);
 --bg-card: rgba(30,28,28,0.9);
 --cyan: #84cfc3;
 --cyan-dim: rgba(132,207,195,0.15);
 --cyan-glow: rgba(132,207,195,0.4);
 --magenta: #ff629a;
 --magenta-dim: rgba(255,98,154,0.15);
 --magenta-glow: rgba(255,98,154,0.4);
 --orange: #ffa300;
 --orange-dim: rgba(255,163,0,0.15);
 --portal-gold: #ffa300;
 --warm-white: #F0E8FF;
 --text-primary: #F0E8FF;
 --text-secondary: rgba(240,232,255,0.6);
 --text-dim: rgba(240,232,255,0.35);
 --border-glass: rgba(255,255,255,0.08);
 --radius-sm: 8px;
 --radius-md: 12px;
 --radius-lg: 20px;
 --radius-xl: 28px;
 --gradient-portal: linear-gradient(135deg, var(--orange), var(--magenta), var(--cyan));
 --gradient-warm: linear-gradient(135deg, var(--magenta), var(--orange), var(--portal-gold));
 --safe-bottom: env(safe-area-inset-bottom, 0px);
 --text-muted: rgba(240,232,255,0.45);
 --bg-elevated: rgba(45,42,42,0.9);
 --font-heading: 'Oswald', sans-serif;
 --font-body: 'Inter', -apple-system, BlinkMacSystemFont, sans-serif;
}

html, body { height: 100%; overflow: hidden; background: var(--portal-dark); margin: 0; padding: 0; }

body {
  font-family: 'Inter', -apple-system, BlinkMacSystemFont, sans-serif;
  background: var(--bg-deep);
  color: var(--text-primary);
 -webkit-text-size-adjust: 100%;
}

/* ── PORTAL SPECKLE TEXTURE (from brand guide) ── */
#starfield {
  position: fixed;
  top: 0; left: 0;
  width: 100%; height: 100%;
  z-index: 0;
  pointer-events: none;
}

/* Brand speckle overlay - teal + pink + orange particles on dark bg */
body::before {
  content: '';
  position: fixed;
  top: 0; left: 0;
  width: 100%; height: 100%;
  z-index: 0;
  pointer-events: none;
  opacity: 0.65;
  background-image:
    radial-gradient(1.5px 1.5px at 10% 15%, #84cfc3 50%, transparent 100%),
    radial-gradient(1.5px 1.5px at 20% 35%, #ff629a 50%, transparent 100%),
    radial-gradient(2px 2px at 30% 8%, #84cfc3 50%, transparent 100%),
    radial-gradient(1.5px 1.5px at 45% 22%, #ff629a 40%, transparent 100%),
    radial-gradient(1.5px 1.5px at 55% 45%, #84cfc3 50%, transparent 100%),
    radial-gradient(2px 2px at 65% 12%, #ffa300 50%, transparent 100%),
    radial-gradient(1.5px 1.5px at 75% 38%, #ff629a 50%, transparent 100%),
    radial-gradient(1.5px 1.5px at 85% 55%, #84cfc3 50%, transparent 100%),
    radial-gradient(1.5px 1.5px at 5% 60%, #ff629a 40%, transparent 100%),
    radial-gradient(2px 2px at 15% 78%, #84cfc3 50%, transparent 100%),
    radial-gradient(1.5px 1.5px at 28% 65%, #ffa300 50%, transparent 100%),
    radial-gradient(1.5px 1.5px at 38% 82%, #ff629a 50%, transparent 100%),
    radial-gradient(1.5px 1.5px at 50% 70%, #84cfc3 50%, transparent 100%),
    radial-gradient(2px 2px at 62% 58%, #ff629a 50%, transparent 100%),
    radial-gradient(1.5px 1.5px at 72% 75%, #84cfc3 50%, transparent 100%),
    radial-gradient(1.5px 1.5px at 82% 68%, #ffa300 50%, transparent 100%),
    radial-gradient(1.5px 1.5px at 92% 85%, #ff629a 50%, transparent 100%),
    radial-gradient(1.5px 1.5px at 8% 92%, #84cfc3 50%, transparent 100%),
    radial-gradient(2px 2px at 35% 95%, #ff629a 50%, transparent 100%),
    radial-gradient(1.5px 1.5px at 58% 88%, #84cfc3 50%, transparent 100%),
    radial-gradient(1.5px 1.5px at 78% 92%, #ffa300 50%, transparent 100%),
    radial-gradient(1.5px 1.5px at 95% 18%, #84cfc3 50%, transparent 100%),
    radial-gradient(1.5px 1.5px at 42% 48%, #ff629a 40%, transparent 100%),
    radial-gradient(2px 2px at 88% 42%, #84cfc3 50%, transparent 100%),
    /* Extra density layer for signature look */
    radial-gradient(1px 1px at 3% 28%, #84cfc3 50%, transparent 100%),
    radial-gradient(1px 1px at 17% 52%, #ffa300 40%, transparent 100%),
    radial-gradient(1.5px 1.5px at 33% 42%, #ff629a 50%, transparent 100%),
    radial-gradient(1px 1px at 48% 8%, #84cfc3 50%, transparent 100%),
    radial-gradient(1px 1px at 68% 32%, #ff629a 40%, transparent 100%),
    radial-gradient(1.5px 1.5px at 80% 15%, #ffa300 50%, transparent 100%),
    radial-gradient(1px 1px at 93% 62%, #84cfc3 50%, transparent 100%),
    radial-gradient(1px 1px at 12% 45%, #ff629a 50%, transparent 100%),
    radial-gradient(1px 1px at 52% 32%, #ffa300 40%, transparent 100%),
    radial-gradient(1.5px 1.5px at 73% 52%, #84cfc3 50%, transparent 100%),
    radial-gradient(1px 1px at 25% 18%, #ff629a 50%, transparent 100%),
    radial-gradient(1px 1px at 60% 72%, #ffa300 40%, transparent 100%);
  background-size: 100% 100%;
}

/* ── Portal speckle overlay for high-z panels ── */
.portal-speckle { background-color: #131212 !important; }
.portal-speckle::after {
  content: '';
  position: absolute;
  top: 0; left: 0; width: 100%; height: 100%;
  pointer-events: none;
  z-index: 0;
  opacity: 0.5;
  background-image:
    radial-gradient(1.5px 1.5px at 12% 18%, #84cfc3 50%, transparent 100%),
    radial-gradient(1.5px 1.5px at 25% 40%, #ff629a 50%, transparent 100%),
    radial-gradient(2px 2px at 38% 10%, #84cfc3 50%, transparent 100%),
    radial-gradient(1.5px 1.5px at 50% 28%, #ff629a 40%, transparent 100%),
    radial-gradient(1.5px 1.5px at 60% 50%, #84cfc3 50%, transparent 100%),
    radial-gradient(2px 2px at 70% 15%, #ffa300 50%, transparent 100%),
    radial-gradient(1.5px 1.5px at 80% 42%, #ff629a 50%, transparent 100%),
    radial-gradient(1.5px 1.5px at 90% 60%, #84cfc3 50%, transparent 100%),
    radial-gradient(1.5px 1.5px at 8% 65%, #ff629a 40%, transparent 100%),
    radial-gradient(2px 2px at 18% 82%, #84cfc3 50%, transparent 100%),
    radial-gradient(1.5px 1.5px at 32% 70%, #ffa300 50%, transparent 100%),
    radial-gradient(1.5px 1.5px at 45% 85%, #ff629a 50%, transparent 100%),
    radial-gradient(1.5px 1.5px at 55% 75%, #84cfc3 50%, transparent 100%),
    radial-gradient(2px 2px at 68% 62%, #ff629a 50%, transparent 100%),
    radial-gradient(1.5px 1.5px at 78% 80%, #84cfc3 50%, transparent 100%),
    radial-gradient(1.5px 1.5px at 88% 72%, #ffa300 50%, transparent 100%),
    radial-gradient(1.5px 1.5px at 95% 88%, #ff629a 50%, transparent 100%),
    radial-gradient(1px 1px at 5% 32%, #84cfc3 50%, transparent 100%),
    radial-gradient(1px 1px at 22% 55%, #ffa300 40%, transparent 100%),
    radial-gradient(1.5px 1.5px at 40% 45%, #ff629a 50%, transparent 100%),
    radial-gradient(1px 1px at 52% 12%, #84cfc3 50%, transparent 100%),
    radial-gradient(1px 1px at 72% 35%, #ff629a 40%, transparent 100%),
    radial-gradient(1.5px 1.5px at 85% 18%, #ffa300 50%, transparent 100%),
    radial-gradient(1px 1px at 96% 65%, #84cfc3 50%, transparent 100%);
  background-size: 100% 100%;
}

/* ── Portal four-point star decorators ── */
.portal-star {
  display: inline-block;
  color: var(--cyan);
  font-size: 12px;
  letter-spacing: 6px;
  opacity: 0.5;
}
.portal-star::before { content: '✦ ✦ ✦'; }

.section-title::before {
  content: '✦';
  margin-right: 8px;
  color: var(--cyan);
  opacity: 0.5;
  font-size: 10px;
}

/* Brand accent divider - gradient line */
.portal-divider {
  height: 2px;
  background: var(--gradient-portal);
  border: none;
  border-radius: 1px;
  margin: 20px 0;
  opacity: 0.4;
}

/* ── SCREENS ── */
.screen {
  position: fixed;
  top: 0; left: 0; right: 0; bottom: 0;
  display: none;
  z-index: 1;
  overflow-y: auto;
 -webkit-overflow-scrolling: touch;
}
.screen.active { display: flex; flex-direction: column; }
.portal-speckle > .app-header,
.portal-speckle > .screen-content,
.portal-speckle > div,
.portal-speckle > section,
.portal-speckle > form,
.portal-speckle > button { position: relative; z-index: 1; }
#screen-map.active { display: block; overflow: hidden; }

/* Hide map fixed elements when map screen is not active */
body:not(:has(#screen-map.active)) .map-profile-card { display: none !important; }
/* Android fallback: map-profile-card hidden by default, shown via JS .show class */
.map-profile-card { display: none !important; }
.map-profile-card.show { display: block !important; }

/* ── AUTH SCREEN ── */
.auth-screen {
  align-items: center;
  justify-content: flex-start;
  padding: 56px 24px 40px;
  text-align: center;
  background: #131212;
  overflow-y: auto;
  z-index: 200000;
}
.auth-speckle {
  position: absolute;
  top: 0; left: 0; width: 100%; height: 100%;
  pointer-events: none;
  z-index: 0;
  opacity: 0.5;
  background-image:
    radial-gradient(1.5px 1.5px at 12% 18%, #84cfc3 50%, transparent 100%),
    radial-gradient(1.5px 1.5px at 25% 40%, #ff629a 50%, transparent 100%),
    radial-gradient(2px 2px at 38% 10%, #84cfc3 50%, transparent 100%),
    radial-gradient(1.5px 1.5px at 50% 28%, #ff629a 40%, transparent 100%),
    radial-gradient(1.5px 1.5px at 60% 50%, #84cfc3 50%, transparent 100%),
    radial-gradient(2px 2px at 70% 15%, #ffa300 50%, transparent 100%),
    radial-gradient(1.5px 1.5px at 80% 42%, #ff629a 50%, transparent 100%),
    radial-gradient(1.5px 1.5px at 90% 60%, #84cfc3 50%, transparent 100%),
    radial-gradient(1.5px 1.5px at 8% 65%, #ff629a 40%, transparent 100%),
    radial-gradient(2px 2px at 18% 82%, #84cfc3 50%, transparent 100%),
    radial-gradient(1.5px 1.5px at 32% 70%, #ffa300 50%, transparent 100%),
    radial-gradient(1.5px 1.5px at 45% 85%, #ff629a 50%, transparent 100%),
    radial-gradient(1.5px 1.5px at 55% 75%, #84cfc3 50%, transparent 100%),
    radial-gradient(2px 2px at 68% 62%, #ff629a 50%, transparent 100%),
    radial-gradient(1.5px 1.5px at 78% 80%, #84cfc3 50%, transparent 100%),
    radial-gradient(1.5px 1.5px at 88% 72%, #ffa300 50%, transparent 100%),
    radial-gradient(1.5px 1.5px at 95% 88%, #ff629a 50%, transparent 100%),
    radial-gradient(1px 1px at 5% 32%, #84cfc3 50%, transparent 100%),
    radial-gradient(1px 1px at 22% 55%, #ffa300 40%, transparent 100%),
    radial-gradient(1.5px 1.5px at 40% 45%, #ff629a 50%, transparent 100%),
    radial-gradient(1px 1px at 52% 12%, #84cfc3 50%, transparent 100%),
    radial-gradient(1px 1px at 72% 35%, #ff629a 40%, transparent 100%),
    radial-gradient(1.5px 1.5px at 85% 18%, #ffa300 50%, transparent 100%),
    radial-gradient(1px 1px at 96% 65%, #84cfc3 50%, transparent 100%);
}
.auth-screen > *:not(.auth-speckle) { position: relative; z-index: 1; }
.onboarding-screen > *:not(.auth-speckle) { position: relative; z-index: 1; }

/* Portal brand ray burst corners on auth screen */
.auth-screen::before,
.auth-screen::after {
  content: '';
  position: absolute;
  width: 200px;
  height: 200px;
  opacity: 0.08;
  pointer-events: none;
}
.auth-screen::before {
  top: -60px;
  left: -60px;
  background:
    conic-gradient(from 0deg at 100% 100%,
      transparent 0deg, #84cfc3 1deg, transparent 2deg,
      transparent 8deg, #ff629a 9deg, transparent 10deg,
      transparent 16deg, #ffa300 17deg, transparent 18deg,
      transparent 24deg, #84cfc3 25deg, transparent 26deg,
      transparent 32deg, #ff629a 33deg, transparent 34deg,
      transparent 40deg, #ffa300 41deg, transparent 42deg,
      transparent 48deg, #84cfc3 49deg, transparent 50deg,
      transparent 56deg, #ff629a 57deg, transparent 58deg,
      transparent 64deg, #ffa300 65deg, transparent 66deg,
      transparent 72deg, #84cfc3 73deg, transparent 74deg,
      transparent 80deg, #ff629a 81deg, transparent 82deg,
      transparent 88deg, transparent 360deg
    );
}
.auth-screen::after {
  bottom: -60px;
  right: -60px;
  background:
    conic-gradient(from 180deg at 0% 0%,
      transparent 0deg, #84cfc3 1deg, transparent 2deg,
      transparent 8deg, #ff629a 9deg, transparent 10deg,
      transparent 16deg, #ffa300 17deg, transparent 18deg,
      transparent 24deg, #84cfc3 25deg, transparent 26deg,
      transparent 32deg, #ff629a 33deg, transparent 34deg,
      transparent 40deg, #ffa300 41deg, transparent 42deg,
      transparent 48deg, #84cfc3 49deg, transparent 50deg,
      transparent 56deg, #ff629a 57deg, transparent 58deg,
      transparent 64deg, #ffa300 65deg, transparent 66deg,
      transparent 72deg, #84cfc3 73deg, transparent 74deg,
      transparent 80deg, #ff629a 81deg, transparent 82deg,
      transparent 88deg, transparent 360deg
    );
}

.auth-logo {
  width: 260px !important;
  max-width: 260px !important;
  margin-bottom: 24px;
  filter: brightness(0) invert(1);
}

.auth-title {
  font-family: 'Oswald', sans-serif;
  font-size: 28px;
  font-weight: 600;
  letter-spacing: 2px;
  text-transform: uppercase;
  margin-bottom: 8px;
  background: var(--gradient-portal);
 -webkit-background-clip: text;
 -webkit-text-fill-color: transparent;
  background-clip: text;
}

.auth-subtitle {
  font-size: 15px;
  color: var(--text-secondary);
  margin-bottom: 12px;
  max-width: 300px;
  line-height: 1.5;
}

.auth-form {
  width: 100%;
  max-width: 360px;
}

.auth-input {
  width: 100%;
  padding: 16px 20px;
  background: rgba(255,255,255,0.06);
  border: 1px solid var(--border-glass);
  border-radius: var(--radius-md);
  color: var(--text-primary);
  font-size: 16px;
  font-family: inherit;
  outline: none;
  transition: border-color 0.3s, box-shadow 0.3s;
  margin-bottom: 16px;
}
.auth-input:focus {
  border-color: var(--cyan);
  box-shadow: 0 0 20px rgba(132,207,195,0.15);
}
.auth-input::placeholder { color: var(--text-dim); }

.auth-btn {
  width: 100%;
  padding: 16px;
  background: var(--gradient-portal);
  border: none;
  border-radius: var(--radius-md);
  color: #252525;
  font-size: 16px;
  font-weight: 700;
  font-family: 'Oswald', sans-serif;
  letter-spacing: 1.5px;
  text-transform: uppercase;
  cursor: pointer;
  transition: transform 0.2s, box-shadow 0.3s;
}
.auth-btn:hover { transform: translateY(-1px); box-shadow: 0 8px 30px rgba(132,207,195,0.3); }
@media (min-width: 768px) {
  .auth-form { max-width: 260px; }
  .auth-input { padding: 10px 14px; font-size: 14px; }
  .auth-btn { padding: 11px; font-size: 13px; }
}
.auth-btn:active { transform: scale(0.98); }
.auth-btn:disabled {
  opacity: 0.5;
  cursor: not-allowed;
  transform: none;
}

.auth-msg {
  margin-top: 20px;
  font-size: 14px;
  color: var(--text-secondary);
  min-height: 20px;
}
.auth-msg.error { color: var(--magenta); }
.auth-msg.success { color: var(--cyan); }

.auth-footer {
  margin-top: 12px;
  font-size: 13px;
  color: var(--text-dim);
}
.auth-footer a {
  color: var(--cyan);
  text-decoration: none;
}

/* ── OTP CODE ENTRY STATE ── */
.auth-otp {
  display: none;
  flex-direction: column;
  align-items: center;
  width: 100%;
  max-width: 360px;
}
.auth-otp.visible { display: flex; }

.auth-sent-icon {
  font-size: 48px;
  margin-bottom: 20px;
}
.auth-sent-text {
  font-size: 18px;
  font-weight: 600;
  margin-bottom: 8px;
}
.auth-sent-sub {
  font-size: 14px;
  color: var(--text-secondary);
  margin-bottom: 24px;
}

.otp-inputs {
  display: flex;
  gap: 8px;
  margin: 20px 0 16px;
  justify-content: center;
}
.otp-digit {
  width: 46px;
  height: 56px;
  text-align: center;
  font-size: 24px;
  font-weight: 700;
  font-family: 'Oswald', sans-serif;
  background: rgba(255,255,255,0.06);
  border: 1px solid var(--border-glass);
  border-radius: var(--radius-md);
  color: var(--text-primary);
  outline: none;
  transition: border-color 0.3s, box-shadow 0.3s;
  caret-color: var(--cyan);
}
.otp-digit:focus {
  border-color: var(--cyan);
  box-shadow: 0 0 20px rgba(132,207,195,0.15);
}
.otp-digit.filled {
  border-color: var(--cyan);
  background: rgba(132,207,195,0.08);
}
.otp-digit.error {
  border-color: var(--magenta);
  animation: shake 0.4s ease;
}

.otp-actions {
  display: flex;
  gap: 12px;
  margin-top: 16px;
}

@keyframes shake {
  0%, 100% { transform: translateX(0); }
  25% { transform: translateX(-4px); }
  75% { transform: translateX(4px); }
}

.auth-resend {
  background: none;
  border: 1px solid var(--border-glass);
  border-radius: var(--radius-md);
  padding: 12px 24px;
  color: var(--text-secondary);
  font-size: 14px;
  font-family: inherit;
  cursor: pointer;
}
.auth-resend:hover { border-color: var(--cyan); color: var(--cyan); }
.auth-resend:disabled { opacity: 0.4; cursor: default; pointer-events: none; }

/* ── Auth Divider ── */
.auth-divider {
  display: flex;
  align-items: center;
  width: 100%;
  max-width: 320px;
  margin: 16px 0;
  gap: 12px;
}
.auth-divider::before, .auth-divider::after {
  content: '';
  flex: 1;
  height: 1px;
  background: var(--border-glass);
}
.auth-divider span {
  font-size: 12px;
  color: var(--text-dim);
  text-transform: uppercase;
  letter-spacing: 1px;
}

/* ── Google OAuth Button ── */
.auth-google-btn {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  width: 100%;
  max-width: 320px;
  padding: 14px 24px;
  background: rgba(255,255,255,0.06);
  border: 1px solid var(--border-glass);
  border-radius: var(--radius-lg);
  color: var(--text-primary);
  font-size: 15px;
  font-weight: 500;
  font-family: inherit;
  cursor: pointer;
  transition: background 0.2s, border-color 0.2s;
}
.auth-google-btn:hover { background: rgba(255,255,255,0.1); border-color: rgba(255,255,255,0.2); }
.auth-google-btn:active { transform: scale(0.98); }
.auth-google-btn svg { flex-shrink: 0; }

/* ── Auth Step Transition ── */
.auth-otp { transition: opacity 0.3s, transform 0.3s; }
.auth-otp:not(.visible) { opacity: 0; transform: translateY(10px); pointer-events: none; }
.auth-otp.visible { opacity: 1; transform: translateY(0); }
.auth-form { transition: opacity 0.3s; }

/* ── ONBOARDING SCREEN ── */
.onboarding-screen {
  align-items: center;
  justify-content: center;
  padding: 24px;
  background: #131212;
}

/* ── Onboarding intro screen ── */
.onboard-intro {
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  max-width: 420px;
  padding: 20px 12px;
  animation: fadeIn 0.5s ease both;
}
.onboard-intro.hidden { display: none; }
.onboard-intro-mark {
  margin-bottom: 14px;
}
.onboard-intro-eyebrow {
  font-family: 'Oswald', sans-serif;
  font-size: 11px;
  letter-spacing: 3px;
  text-transform: uppercase;
  color: #ff629a;
  font-weight: 700;
  margin-bottom: 10px;
}
.onboard-intro-headline {
  font-family: 'Oswald', sans-serif;
  font-size: 32px;
  font-weight: 700;
  color: #fff;
  line-height: 1.1;
  letter-spacing: -0.5px;
  margin: 0 0 18px;
  background: linear-gradient(90deg, #84cfc3, #ff629a, #ffa300);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}
.onboard-intro-body {
  font-size: 15px;
  color: rgba(240,232,255,0.82);
  line-height: 1.55;
  margin-bottom: 24px;
}
.onboard-intro-body p { margin: 0 0 10px; }
.onboard-intro-body p:last-child { margin-bottom: 0; }
.onboard-intro .onboard-btn {
  min-width: 200px;
  margin-top: 8px;
}
/* Hide the step flow (progress dots + steps) while intro is visible. */
.onboarding-screen.intro-mode .onboard-progress,
.onboarding-screen.intro-mode .onboard-step { display: none !important; }

@media (prefers-reduced-motion: reduce) {
  .onboard-intro { animation: none; }
}

.onboard-progress {
  display: flex;
  gap: 8px;
  margin-bottom: 40px;
}
.onboard-dot {
  width: 10px; height: 10px;
  border-radius: 50%;
  background: var(--border-glass);
  transition: background 0.3s, transform 0.3s;
}
.onboard-dot.active {
  background: var(--cyan);
  transform: scale(1.3);
}
.onboard-dot.done { background: var(--cyan); }

.onboard-step {
  display: none;
  flex-direction: column;
  align-items: center;
  width: 100%;
  max-width: 400px;
  animation: fadeUp 0.4s ease;
}
.onboard-step.active { display: flex; }

.onboard-pills {
  display: flex; flex-wrap: wrap; gap: 8px; justify-content: center;
  max-width: 360px; margin-top: 16px;
}
.onboard-pill {
  padding: 8px 16px; border-radius: 20px; font-size: 13px; font-weight: 500;
  background: rgba(255,255,255,0.06); border: 1px solid rgba(255,255,255,0.12);
  color: rgba(255,255,255,0.7); cursor: pointer; transition: all 0.2s;
  user-select: none; -webkit-user-select: none;
}
.onboard-pill:hover { border-color: var(--cyan); color: #fff; }
.onboard-pill.selected {
  background: rgba(132,207,195,0.15); border-color: var(--cyan); color: var(--cyan); font-weight: 600;
}
.onboard-pill.maxed:not(.selected) { opacity: 0.3; pointer-events: none; }

@keyframes fadeUp {
  from { opacity: 0; transform: translateY(20px); }
  to { opacity: 1; transform: translateY(0); }
}

.onboard-label {
  font-family: 'Oswald', sans-serif;
  font-size: 22px;
  font-weight: 600;
  letter-spacing: 1px;
  text-transform: uppercase;
  margin-bottom: 8px;
  text-align: center;
}

.onboard-hint {
  font-size: 14px;
  color: var(--text-secondary);
  margin-bottom: 24px;
  text-align: center;
  line-height: 1.5;
}

.onboard-input {
  width: 100%;
  padding: 14px 18px;
  background: rgba(255,255,255,0.06);
  border: 1px solid var(--border-glass);
  border-radius: var(--radius-md);
  color: var(--text-primary);
  font-size: 16px;
  font-family: inherit;
  outline: none;
  transition: border-color 0.3s;
  margin-bottom: 12px;
}
.onboard-input:focus { border-color: var(--cyan); }
.onboard-input::placeholder { color: var(--text-dim); }

.onboard-row {
  display: flex;
  gap: 12px;
  width: 100%;
}
.onboard-row .onboard-input { flex: 1; }

/* Location autocomplete */
.location-search-wrap {
  position: relative;
  width: 100%;
}
.location-results {
  position: absolute;
  top: 100%;
  left: 0;
  right: 0;
  background: var(--bg-card);
  border: 1px solid var(--border-glass);
  border-radius: 12px;
  margin-top: 4px;
  max-height: 240px;
  overflow-y: auto;
  z-index: 100;
  display: none;
  backdrop-filter: blur(20px);
 -webkit-backdrop-filter: blur(20px);
}
.location-results.show { display: block; }
.location-result-item {
  padding: 14px 16px;
  cursor: pointer;
  border-bottom: 1px solid rgba(255,255,255,0.05);
  transition: background 0.2s;
  text-align: left;
}
.location-result-item:last-child { border-bottom: none; }
.location-result-item:hover { background: rgba(132,207,195,0.1); }
.location-result-city {
  font-weight: 600;
  color: var(--text-primary);
  font-size: 15px;
}
.location-result-detail {
  font-size: 13px;
  color: var(--text-dim);
  margin-top: 2px;
}
.location-selected {
  display: flex;
  align-items: center;
  gap: 12px;
  background: rgba(132,207,195,0.08);
  border: 1px solid rgba(132,207,195,0.3);
  border-radius: 12px;
  padding: 14px 16px;
  width: 100%;
  margin-bottom: 8px;
}
.location-selected-text {
  flex: 1;
  text-align: left;
  font-size: 15px;
  color: var(--text-primary);
}
.location-change {
  background: none;
  border: 1px solid rgba(132,207,195,0.4);
  color: var(--cyan);
  padding: 6px 14px;
  border-radius: 100px;
  font-size: 13px;
  cursor: pointer;
  white-space: nowrap;
}
.location-change:hover { background: rgba(132,207,195,0.1); }

/* Avatar upload */
.avatar-upload {
  width: 100px;
  height: 100px;
  border-radius: 50%;
  border: 2px dashed var(--border-glass);
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  margin-bottom: 16px;
  background: rgba(255,255,255,0.03);
  overflow: hidden;
  transition: border-color 0.3s;
  position: relative;
}
.avatar-upload:hover { border-color: var(--cyan); }
.avatar-upload img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.avatar-upload-placeholder {
  font-size: 32px;
  color: var(--text-dim);
}
.avatar-upload input { display: none; }

/* Interest tags */
.interest-grid {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  justify-content: center;
  margin-bottom: 24px;
}
.interest-tag {
  padding: 10px 18px;
  border-radius: 100px;
  border: 1px solid var(--border-glass);
  background: rgba(255,255,255,0.04);
  color: var(--text-secondary);
  font-size: 14px;
  cursor: pointer;
  transition: all 0.2s;
  user-select: none;
}
.interest-tag.selected {
  background: var(--cyan-dim);
  border-color: var(--cyan);
  color: var(--cyan);
}
.interest-tag:hover { border-color: rgba(132,207,195,0.4); }

/* Open to connect toggle */
.toggle-row {
  display: flex;
  align-items: center;
  gap: 16px;
  padding: 20px;
  background: var(--bg-card);
  border: 1px solid var(--border-glass);
  border-radius: var(--radius-md);
  width: 100%;
  margin-bottom: 16px;
}
.toggle-label { flex: 1; }
.toggle-label-title { font-weight: 600; font-size: 15px; margin-bottom: 4px; }
.toggle-label-sub { font-size: 13px; color: var(--text-secondary); line-height: 1.4; }

.toggle-switch {
  width: 52px;
  height: 28px;
  background: rgba(255,255,255,0.1);
  border-radius: 14px;
  cursor: pointer;
  position: relative;
  transition: background 0.3s;
  flex-shrink: 0;
}
.toggle-switch.on { background: var(--cyan); }
.toggle-switch::after {
  content: '';
  position: absolute;
  top: 3px; left: 3px;
  width: 22px; height: 22px;
  background: white;
  border-radius: 50%;
  transition: transform 0.3s;
}
.toggle-switch.on::after { transform: translateX(24px); }

.onboard-bio {
  width: 100%;
  min-height: 80px;
  padding: 14px 18px;
  background: rgba(255,255,255,0.06);
  border: 1px solid var(--border-glass);
  border-radius: var(--radius-md);
  color: var(--text-primary);
  font-size: 14px;
  font-family: inherit;
  outline: none;
  resize: vertical;
  margin-bottom: 16px;
}
.onboard-bio:focus { border-color: var(--cyan); }
.onboard-bio::placeholder { color: var(--text-dim); }

.onboard-nav {
  display: flex;
  gap: 12px;
  width: 100%;
  margin-top: 12px;
}
.onboard-btn {
  flex: 1;
  padding: 14px;
  border-radius: var(--radius-md);
  font-size: 15px;
  font-weight: 600;
  font-family: 'Oswald', sans-serif;
  letter-spacing: 1px;
  text-transform: uppercase;
  cursor: pointer;
  transition: all 0.2s;
  border: none;
}
.onboard-btn.secondary {
  background: rgba(255,255,255,0.06);
  color: var(--text-secondary);
  border: 1px solid var(--border-glass);
}
.onboard-btn.primary {
  background: var(--gradient-portal);
  color: #252525;
}
.onboard-btn:disabled { opacity: 0.4; cursor: not-allowed; }

/* ── TOP PROFILE AVATAR ── */
.top-profile-btn {
  position: fixed; top: max(12px, env(safe-area-inset-top)); right: 16px;
  z-index: 1001; cursor: pointer; -webkit-tap-highlight-color: transparent;
  width: 36px; height: 36px; border-radius: 50%;
  border: 2px solid var(--cyan); overflow: hidden;
  box-shadow: 0 2px 12px rgba(0,0,0,0.4);
  transition: transform 0.2s, box-shadow 0.2s;
  display: none;
}
.top-profile-btn:active { transform: scale(0.92); }
.top-profile-btn img {
  width: 100%; height: 100%; object-fit: cover;
}

/* ── BOTTOM NAV ── */
.bottom-nav {
  position: fixed;
  bottom: 0; left: 0; right: 0;
  z-index: 99990;
  display: flex;
  background: var(--bg-glass-solid);
  backdrop-filter: blur(24px);
 -webkit-backdrop-filter: blur(24px);
  border-top: 1px solid var(--border-glass);
  padding-bottom: calc(var(--safe-bottom) + 4px);
  isolation: isolate;
  -webkit-transform: translateZ(0);
  transform: translateZ(0);
}
.nav-tab {
  flex: 1;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  padding: 12px 0 10px;
  cursor: pointer;
  color: var(--text-dim);
  transition: color 0.2s;
  text-decoration: none;
 -webkit-tap-highlight-color: transparent;
  user-select: none;
  touch-action: manipulation;
  position: relative;
  z-index: 1;
}
.nav-tab.active { color: var(--cyan); }
.nav-tab.active .nav-tab-icon svg {
  stroke: url(#portal-icon-grad);
}
.nav-tab.active .nav-tab-icon img {
  opacity: 1 !important;
  filter: none !important;
}
.nav-tab.active .nav-tab-label {
  background: linear-gradient(90deg, var(--orange), var(--magenta), var(--cyan));
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}
/* Nav icon animations (active only) */
@keyframes nav-spiral { from { transform: rotate(0deg); } to { transform: rotate(360deg); } }
@keyframes nav-star-spin { 0% { transform: rotate(0deg) scale(1); } 25% { transform: rotate(90deg) scale(1.12); } 50% { transform: rotate(180deg) scale(1); } 75% { transform: rotate(270deg) scale(1.12); } 100% { transform: rotate(360deg) scale(1); } }
@keyframes nav-ufo-hover { 0%,100% { transform: translateY(0) rotate(0deg); } 25% { transform: translateY(-2px) rotate(1.5deg); } 50% { transform: translateY(0.5px) rotate(0deg); } 75% { transform: translateY(-1.5px) rotate(-1.5deg); } }
@keyframes nav-chat-bounce { 0%,100% { transform: translateY(0) scale(1); } 15% { transform: translateY(-2.5px) scale(1.05); } 30% { transform: translateY(0) scale(1); } 45% { transform: translateY(-1.5px) scale(1.03); } 60% { transform: translateY(0) scale(1); } }
#nav-circles.active .nav-tab-icon img.nav-glyph { animation: nav-spiral 8s linear infinite; }
#nav-events.active .nav-tab-icon img.nav-glyph { animation: nav-star-spin 6s ease-in-out infinite; }
#nav-journey.active .nav-tab-icon img.nav-glyph { animation: nav-ufo-hover 3s ease-in-out infinite; }
/* Brandt nav icons: dim inactive, full + animated when active (mobile + desktop) */
.nav-tab-icon img.nav-glyph { width: 24px; height: 24px; opacity: 0.5; transition: opacity 0.15s; }
.nav-tab.active .nav-tab-icon img.nav-glyph { opacity: 1; }
.ds-nav-item img.nav-glyph { width: 22px; height: 22px; opacity: 0.55; transition: opacity 0.15s; }
.ds-nav-item.active img.nav-glyph { opacity: 1; }
.ds-nav-item[data-screen="circles"].active img.nav-glyph { animation: nav-spiral 8s linear infinite; }
.ds-nav-item[data-screen="events"].active img.nav-glyph { animation: nav-star-spin 6s ease-in-out infinite; }
.ds-nav-item[data-screen="journey"].active img.nav-glyph { animation: nav-ufo-hover 3s ease-in-out infinite; }
@keyframes nav-watch-pulse { 0%,100% { transform: scale(1); } 50% { transform: scale(1.08); } }
#nav-watch.active .nav-tab-icon svg { animation: nav-watch-pulse 2s ease-in-out infinite; }
#nav-messages.active .nav-tab-icon svg { animation: nav-chat-bounce 2.5s ease-in-out infinite; }
.nav-tab-icon { font-size: 22px; margin-bottom: 3px; display: flex; align-items: center; justify-content: center; }
.nav-tab-icon svg { width: 24px; height: 24px; }
.nav-tab-label { font-size: 11px; font-weight: 500; letter-spacing: 0.5px; }
.nav-tab .nav-badge {
  position: absolute;
  top: 4px;
  right: calc(50% - 18px);
  width: 8px; height: 8px;
  background: var(--magenta);
  border-radius: 50%;
  display: none;
}

/* ── HEADER BAR ── */
.app-header {
  position: fixed;
  top: 0; left: 0; right: 0;
  z-index: 900;
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 12px 16px;
  padding-top: max(12px, env(safe-area-inset-top));
  background: var(--bg-glass-solid);
  backdrop-filter: blur(24px);
 -webkit-backdrop-filter: blur(24px);
  border-bottom: 1px solid var(--border-glass);
}
.app-header-logo {
  height: 36px;
  /* Uses portal-logo-white.png — a pre-rendered version of the logo where
     every partially-transparent pixel has been slammed to 100% opacity white.
     Bigger render size gives subpixel rendering more to work with on thin
     strokes; no CSS filter needed. */
  opacity: 1;
}
.app-header-right {
  display: flex;
  align-items: center;
  gap: 12px;
}
.avatar-ring {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 36px;
  height: 36px;
  border-radius: 50%;
  background: linear-gradient(135deg, var(--cyan), var(--magenta), var(--orange));
  padding: 2px;
  cursor: pointer;
}
.header-avatar {
  width: 32px;
  height: 32px;
  border-radius: 50%;
  border: none;
  cursor: pointer;
  object-fit: cover;
  background: var(--bg-card);
}

/* ── MAP SCREEN ── */
#screen-map {
  position: fixed !important;
  top: 0; left: 0; right: 0; bottom: 0;
  display: none;
  overflow: hidden;
}
#screen-map.active { display: block !important; }
#map-container {
  position: absolute;
  top: 0; left: 0;
  width: 100%;
  height: 100%;
  z-index: 1;
}
#screen-map .app-header { z-index: 500; }

.map-near-me {
  position: fixed;
  bottom: calc(70px + var(--safe-bottom));
  right: 16px;
  z-index: 499;
  width: 44px;
  height: 44px;
  border-radius: 50%;
  background: var(--bg-glass-solid);
  border: 1px solid var(--border-glass);
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  font-size: 20px;
  color: var(--cyan);
  box-shadow: 0 4px 20px rgba(0,0,0,0.4);
  transition: all 0.2s;
}
.map-near-me:hover { border-color: var(--cyan); box-shadow: 0 0 20px rgba(132,207,195,0.2); }

/* Leaflet dark overrides */
.leaflet-container { background: #252525 !important; }
.leaflet-control-zoom { display: none !important; }
.leaflet-tile-pane { filter: brightness(0.85) contrast(1.1); }

/* Member marker */
.member-marker {
  width: 36px;
  height: 36px;
  border-radius: 50%;
  border: 2px solid var(--cyan);
  box-shadow: 0 0 12px rgba(132,207,195,0.4);
  background: var(--bg-deep);
  overflow: hidden;
}
.member-marker img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.member-marker.no-photo {
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 16px;
  color: var(--cyan);
}
.member-cluster {
  display: flex;
  align-items: center;
  justify-content: center;
}
.cluster-ring {
  width: 100%; height: 100%;
  border-radius: 50%;
  background: linear-gradient(135deg, var(--cyan), var(--magenta));
  display: flex;
  align-items: center;
  justify-content: center;
  box-shadow: 0 0 16px rgba(132,207,195,0.5);
}
.cluster-ring span {
  font-size: 13px;
  font-weight: 700;
  color: var(--bg-deep);
  font-family: var(--font-body);
  background: var(--cyan-dim);
}

/* Member popup */
.member-popup .leaflet-popup-content-wrapper {
  background: var(--bg-glass-solid) !important;
  color: var(--text-primary) !important;
  border: 1px solid var(--border-glass);
  border-radius: var(--radius-md) !important;
  box-shadow: 0 8px 40px rgba(0,0,0,0.6) !important;
  padding: 0 !important;
}
.member-popup .leaflet-popup-tip {
  background: var(--bg-glass-solid) !important;
  border: 1px solid var(--border-glass);
}
.member-popup .leaflet-popup-content { margin: 0 !important; width: auto !important; }

.popup-card {
  padding: 16px;
  min-width: 220px;
}
.popup-header {
  display: flex;
  align-items: center;
  gap: 12px;
  margin-bottom: 12px;
}
.popup-avatar {
  width: 44px;
  height: 44px;
  border-radius: 50%;
  object-fit: cover;
  border: 2px solid var(--cyan-dim);
  background: var(--bg-card);
}
.popup-name { font-weight: 600; font-size: 15px; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; max-width: 200px; }
.popup-city { font-size: 13px; color: var(--text-secondary); }
.popup-interests {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  margin-bottom: 12px;
}
.popup-interest {
  padding: 4px 10px;
  border-radius: 100px;
  background: var(--cyan-dim);
  color: var(--cyan);
  font-size: 11px;
  font-weight: 500;
}
.popup-action {
  display: block;
  width: 100%;
  padding: 10px;
  background: var(--cyan-dim);
  border: 1px solid rgba(132,207,195,0.2);
  border-radius: var(--radius-sm);
  color: var(--cyan);
  font-size: 13px;
  font-weight: 600;
  text-align: center;
  cursor: pointer;
  transition: all 0.2s;
}
.popup-action:hover { background: rgba(132,207,195,0.25); }

/* Cluster override */
.marker-cluster-small, .marker-cluster-medium, .marker-cluster-large {
  background: rgba(132,207,195,0.15) !important;
}
.marker-cluster-small div, .marker-cluster-medium div, .marker-cluster-large div {
  background: rgba(132,207,195,0.6) !important;
  color: #252525 !important;
  font-family: 'Oswald', sans-serif !important;
  font-weight: 600 !important;
}

/* ── CIRCLES SCREEN ── */
.circles-screen {
  padding-bottom: calc(60px + var(--safe-bottom));
  background: var(--bg-deep);
}
.circles-screen .app-header {
  position: relative;
  flex-shrink: 0;
}
.circles-screen .circles-list {
  flex: 1;
  overflow-y: auto;
 -webkit-overflow-scrolling: touch;
}

.circles-list {
  padding: 16px;
}

.section-title {
  font-family: 'Oswald', sans-serif;
  font-size: 13px;
  font-weight: 600;
  letter-spacing: 2px;
  text-transform: uppercase;
  color: var(--text-dim);
  margin-bottom: 12px;
  padding: 0 4px;
}

/* ── Collapsible sections ── */
.section-title.collapsible {
  display: flex;
  align-items: center;
  cursor: pointer;
  -webkit-tap-highlight-color: transparent;
  user-select: none;
}
.section-title.collapsible .section-chevron {
  margin-left: auto;
  font-size: 14px;
  color: var(--text-dim);
  transition: transform 0.25s ease;
  display: inline-flex;
  line-height: 1;
}
.section-title.collapsible .section-chevron::before { content: ''; }
.section-title.collapsible.collapsed .section-chevron {
  transform: rotate(-90deg);
}
.section-body {
  overflow: hidden;
  transition: max-height 0.3s ease, opacity 0.25s ease;
  max-height: 2000px;
  opacity: 1;
}
.section-body.collapsed {
  max-height: 0;
  opacity: 0;
  margin-bottom: 0;
}

.circle-card {
  display: flex;
  align-items: center;
  gap: 14px;
  padding: 16px;
  background: var(--bg-card);
  border: 1px solid var(--border-glass);
  border-radius: var(--radius-md);
  margin-bottom: 10px;
  cursor: pointer;
  transition: all 0.2s;
}
.circle-card:hover { border-color: rgba(132,207,195,0.2); }
.circle-card.my-circle { border-color: rgba(132,207,195,0.3); }

.circle-icon {
  width: 44px;
  height: 44px;
  border-radius: 50%;
  background: var(--cyan-dim);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 20px;
  flex-shrink: 0;
}
.circle-info { flex: 1; min-width: 0; }
.circle-name { font-weight: 600; font-size: 15px; margin-bottom: 2px; }
.circle-meta { font-size: 13px; color: var(--text-secondary); }
.circle-preview { font-size: 12px; color: var(--text-dim); margin-top: 4px; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.circle-badge {
  background: var(--magenta);
  color: white;
  font-size: 11px;
  font-weight: 700;
  padding: 2px 8px;
  border-radius: 100px;
  flex-shrink: 0;
}
.circle-badge.home-badge { background: var(--cyan-dim); color: var(--cyan); font-size: 10px; letter-spacing: 0.5px; }
.circle-badge.following-badge { background: rgba(255,163,0,0.12); color: #ffa300; font-size: 10px; }
.circle-unread-dot { width: 8px; height: 8px; border-radius: 50%; background: var(--cyan); flex-shrink: 0; }
.following-empty { font-size: 13px; color: var(--text-dim); padding: 12px 4px; line-height: 1.5; }
.circle-follow-btn { padding: 6px 16px; border-radius: 100px; font-size: 13px; font-weight: 600; cursor: pointer; transition: all 0.2s; border: 1.5px solid #ffa300; background: transparent; color: #ffa300; flex-shrink: 0; }
.circle-follow-btn:active { transform: scale(0.95); }
.circle-follow-btn.following { background: rgba(255,163,0,0.12); border-color: rgba(255,163,0,0.25); color: var(--text-secondary); }
.circle-follow-btn.home-btn { background: var(--cyan-dim); border-color: var(--cyan); color: var(--cyan); pointer-events: none; }
.chat-follow-prompt { padding: 12px 20px; text-align: center; font-size: 13px; color: var(--text-secondary); background: var(--bg-card); border-top: 1px solid var(--border-glass); }
.chat-follow-prompt button { margin-top: 8px; padding: 8px 20px; border-radius: 100px; border: 1.5px solid #ffa300; background: transparent; color: #ffa300; font-size: 13px; font-weight: 600; cursor: pointer; }
.chat-follow-prompt button:active { transform: scale(0.95); background: rgba(255,163,0,0.15); }

/* ── IDENTITY CIRCLE CARDS ── */
.identity-circle-card {
  display: flex;
  align-items: center;
  gap: 14px;
  padding: 16px;
  background: var(--bg-card);
  border: 1px solid var(--border-glass);
  border-left: 3px solid #ffa300;
  border-radius: var(--radius-md);
  margin-bottom: 10px;
  cursor: pointer;
  transition: all 0.2s;
}
.identity-circle-card:active { transform: scale(0.97); }
.identity-circle-card:hover { border-color: rgba(255,163,0,0.25); }
.identity-circle-card.joined { border-left-color: var(--cyan); }
.identity-circle-icon {
  width: 44px;
  height: 44px;
  border-radius: 12px;
  background: rgba(255,163,0,0.15);
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  color: #ffa300;
}
.identity-circle-icon svg { width: 22px; height: 22px; stroke: url(#portal-icon-grad); }
.identity-circle-icon img.circle-glyph { width: 28px; height: 28px; }
.edit-interest-chip img.circle-glyph { width: 17px; height: 17px; vertical-align: -3px; margin-right: 1px; }
.profile-row-icon img.row-glyph { width: 22px; height: 22px; display:block; }
.identity-circle-card.joined .identity-circle-icon { background: var(--cyan-dim); }
.identity-circle-card.joined .identity-circle-icon svg { stroke: url(#portal-icon-grad); }
.identity-circle-info { flex: 1; min-width: 0; }
.identity-circle-name { font-weight: 600; font-size: 15px; margin-bottom: 2px; }
.identity-circle-desc {
  font-size: 12px;
  color: var(--text-dim);
  margin-top: 2px;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}
.identity-circle-badge {
  background: var(--cyan-dim);
  color: var(--cyan);
  font-size: 10px;
  font-weight: 700;
  padding: 2px 8px;
  border-radius: 100px;
  flex-shrink: 0;
  letter-spacing: 0.5px;
}
/* ── ORG PARTNER CARDS ── */
.org-chip {
  flex-shrink: 0;
  padding: 10px 14px;
  background: var(--bg-card);
  border: 1px solid var(--border-glass);
  border-radius: var(--radius-sm);
  min-width: 160px;
  max-width: 200px;
  cursor: pointer;
  transition: all 0.2s;
}
.org-chip:active { transform: scale(0.97); }
.org-chip:hover { border-color: rgba(255,163,0,0.2); }
.org-join-btn {
  padding: 5px 14px;
  border-radius: 100px;
  font-size: 12px;
  font-weight: 600;
  cursor: pointer;
  border: 1.5px solid var(--orange);
  background: transparent;
  color: var(--orange);
  flex-shrink: 0;
}
.org-join-btn.joined { background: var(--orange-dim, rgba(255,163,0,0.1)); border-color: rgba(255,163,0,0.25); color: var(--text-secondary); }
.org-join-btn:active { transform: scale(0.95); }
/* ── CIRCLES ENTRY CARD (Community Tab) ── */
.circles-entry-card {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 16px;
  margin-top: 20px;
  background: var(--bg-card);
  border: 1px solid var(--border-glass);
  border-left: 3px solid #ffa300;
  border-radius: var(--radius-md);
  cursor: pointer;
  transition: all 0.2s;
}
.circles-entry-card:active { transform: scale(0.97); }
.circles-entry-left { flex: 1; min-width: 0; }
.circles-entry-title { font-weight: 700; font-size: 15px; color: var(--text-primary); margin-bottom: 3px; }
.circles-entry-subtitle { font-size: 12px; color: var(--text-dim); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.circles-entry-arrow { font-size: 18px; color: #ffa300; flex-shrink: 0; }

/* ── YOUR CIRCLES compact rows ── */
.your-circle-row {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 12px 0;
  border-bottom: 1px solid var(--border-glass);
  cursor: pointer;
  transition: all 0.15s;
}
.your-circle-row:last-child { border-bottom: none; }
.your-circle-row:active { opacity: 0.7; }
.your-circle-row-emoji { font-size: 20px; flex-shrink: 0; width: 32px; text-align: center; }
.your-circle-row-info { flex: 1; min-width: 0; }
.your-circle-row-name { font-weight: 600; font-size: 14px; }
.your-circle-row-meta { font-size: 12px; color: var(--text-dim); }
.your-circle-row-arrow { font-size: 14px; color: var(--text-dim); flex-shrink: 0; }

.chat-input-bar.disabled { opacity: 0.4; pointer-events: none; }
.unfollow-sheet-bg { position: fixed; inset: 0; background: rgba(0,0,0,0.5); z-index: 99998; display: none; }
.unfollow-sheet-bg.show { display: block; }
.unfollow-sheet { position: fixed; bottom: 0; left: 0; right: 0; background: var(--bg-card); border-radius: 16px 16px 0 0; padding: 20px 20px calc(20px + env(safe-area-inset-bottom)); z-index: 99999; transform: translateY(100%); transition: transform 0.3s ease; }
.unfollow-sheet-bg.show .unfollow-sheet { transform: translateY(0); }
.unfollow-sheet-action { padding: 14px 0; text-align: center; font-size: 16px; font-weight: 500; cursor: pointer; border-bottom: 1px solid var(--border-glass); }
.unfollow-sheet-action.danger { color: #ff5555; }
.unfollow-sheet-action:last-child { border-bottom: none; color: var(--text-secondary); }
.home-city-field { margin-top: 16px; }
.home-city-cooldown { font-size: 12px; color: var(--text-dim); margin-top: 4px; }
/* Notification permission sheet */
.notif-ask-bg { position: fixed; inset: 0; background: rgba(0,0,0,0.5); z-index: 99998; display: none; }
.notif-ask-bg.show { display: block; }
.notif-ask-sheet { position: fixed; bottom: 0; left: 0; right: 0; background: var(--bg-card); border-radius: 20px 20px 0 0; padding: 32px 24px calc(24px + env(safe-area-inset-bottom)); z-index: 99999; transform: translateY(100%); transition: transform 0.35s cubic-bezier(0.32, 0.72, 0, 1); text-align: center; }
.notif-ask-bg.show .notif-ask-sheet { transform: translateY(0); }
.notif-ask-icon { font-size: 36px; margin-bottom: 12px; }
.notif-ask-title { font-size: 20px; font-weight: 700; margin-bottom: 8px; }
.notif-ask-body { font-size: 14px; color: var(--text-secondary); line-height: 1.55; margin-bottom: 24px; max-width: 320px; margin-left: auto; margin-right: auto; }
.notif-ask-btns { display: flex; gap: 12px; justify-content: center; }
.notif-ask-btn { padding: 12px 28px; border-radius: 100px; font-size: 15px; font-weight: 600; cursor: pointer; border: none; transition: all 0.2s; }
.notif-ask-btn:active { transform: scale(0.95); }
.notif-ask-btn.primary { background: var(--cyan); color: var(--bg-deep); }
.notif-ask-btn.secondary { background: rgba(255,255,255,0.08); color: var(--text-secondary); }
/* Notification settings in profile edit */
.pe-notif-section { margin-top: 24px; border-top: 1px solid var(--border-glass); padding-top: 20px; }
.pe-notif-label { font-size: 10px; font-weight: 600; letter-spacing: 1.5px; text-transform: uppercase; color: var(--text-dim); margin-bottom: 12px; }
.pe-notif-row { display: flex; align-items: flex-start; justify-content: space-between; gap: 12px; padding: 10px 0; }
.pe-notif-row-info { flex: 1; min-width: 0; }
.pe-notif-row-title { font-size: 14px; font-weight: 500; }
.pe-notif-row-desc { font-size: 12px; color: var(--text-dim); margin-top: 2px; line-height: 1.4; }
.pe-notif-cap { font-size: 11px; color: var(--text-dim); text-align: center; margin-top: 16px; line-height: 1.5; }

/* ── CIRCLES SEARCH ── */
.circles-search {
  position: relative;
  margin-bottom: 16px;
}
.circles-search input {
  width: 100%;
  padding: 12px 16px 12px 40px;
  background: var(--bg-card);
  border: 1px solid var(--border-glass);
  border-radius: var(--radius-md);
  color: var(--warm-white);
  font-family: 'Inter', sans-serif;
  font-size: 14px;
  outline: none;
  transition: border-color 0.2s;
  box-sizing: border-box;
}
.circles-search input::placeholder { color: var(--text-dim); }
.circles-search input:focus { border-color: rgba(132,207,195,0.3); }
.circles-search-icon {
  position: absolute;
  left: 14px;
  top: 50%;
  transform: translateY(-50%);
  color: var(--text-dim);
  font-size: 14px;
  pointer-events: none;
}

.circles-view-all {
  text-align: center;
  padding: 12px 0;
  margin-bottom: 8px;
}
.circles-view-all a {
  color: var(--cyan);
  font-size: 13px;
  font-weight: 600;
  text-decoration: none;
  letter-spacing: 0.5px;
  cursor: pointer;
}
.circles-view-all a:hover { text-decoration: underline; }

.request-city-card {
  display: flex;
  align-items: center;
  gap: 14px;
  padding: 16px;
  background: transparent;
  border: 1px dashed rgba(132,207,195,0.25);
  border-radius: var(--radius-md);
  margin-bottom: 10px;
  cursor: pointer;
  transition: all 0.2s;
}
.request-city-card:hover { border-color: rgba(132,207,195,0.4); background: rgba(132,207,195,0.05); }
.request-city-icon {
  width: 44px;
  height: 44px;
  border-radius: 50%;
  background: rgba(132,207,195,0.1);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 20px;
  flex-shrink: 0;
  color: var(--cyan);
}
.request-city-text {
  flex: 1;
}
.request-city-text .circle-name { color: var(--cyan); }
.request-city-text .circle-meta { color: var(--text-dim); }

/* ── REQUEST CITY SHEET ── */
.request-city-overlay {
  position: fixed;
  top: 0; left: 0; right: 0; bottom: 0;
  background: rgba(0,0,0,0.7);
  z-index: 99995;
  display: flex;
  align-items: flex-end;
  justify-content: center;
  opacity: 0; visibility: hidden; pointer-events: none;
  transition: opacity 0.3s ease, visibility 0.3s ease;
}
.request-city-overlay.show { opacity: 1; visibility: visible; pointer-events: auto; }
.request-city-sheet {
  width: 100%;
  max-width: 480px;
  background: var(--bg-glass-solid);
  border: 1px solid var(--border-glass);
  border-radius: var(--radius-xl) var(--radius-xl) 0 0;
  transform: translateY(100%);
  transition: transform 0.35s cubic-bezier(0.32,0.72,0,1);
  padding: 24px 20px calc(24px + var(--safe-bottom));
}
.request-city-overlay.show .request-city-sheet { transform: translateY(0); }
.request-city-sheet h3 {
  font-family: 'Oswald', sans-serif;
  font-size: 18px;
  font-weight: 600;
  margin: 0 0 4px;
  color: var(--warm-white);
}
.request-city-sheet p {
  font-size: 13px;
  color: var(--text-secondary);
  margin: 0 0 20px;
}
.request-city-sheet label {
  display: block;
  font-size: 12px;
  font-weight: 600;
  color: var(--text-secondary);
  margin-bottom: 6px;
  letter-spacing: 0.5px;
  text-transform: uppercase;
}
.request-city-sheet input,
.request-city-sheet textarea {
  width: 100%;
  padding: 12px 14px;
  background: var(--bg-card);
  border: 1px solid var(--border-glass);
  border-radius: var(--radius-md);
  color: var(--warm-white);
  font-family: 'Inter', sans-serif;
  font-size: 14px;
  outline: none;
  margin-bottom: 16px;
  box-sizing: border-box;
  transition: border-color 0.2s;
}
.request-city-sheet input:focus,
.request-city-sheet textarea:focus { border-color: rgba(132,207,195,0.3); }
.request-city-sheet input::placeholder,
.request-city-sheet textarea::placeholder { color: var(--text-dim); }
.request-city-sheet textarea { resize: none; height: 60px; }
.request-city-sheet .btn-submit {
  width: 100%;
  padding: 14px;
  background: var(--gradient-portal);
  border: none;
  border-radius: var(--radius-md);
  color: white;
  font-family: 'Inter', sans-serif;
  font-size: 15px;
  font-weight: 700;
  cursor: pointer;
  transition: opacity 0.2s;
}
.request-city-sheet .btn-submit:disabled { opacity: 0.5; cursor: not-allowed; }
.request-city-sheet .btn-cancel {
  width: 100%;
  padding: 12px;
  background: transparent;
  border: none;
  color: var(--text-secondary);
  font-family: 'Inter', sans-serif;
  font-size: 13px;
  cursor: pointer;
  margin-top: 8px;
}

/* ── MEMBERS SHEET (shared: cluster explore + circle member count) ── */
.members-sheet-overlay {
  position: fixed; inset: 0; z-index: 99992;
  background: rgba(0,0,0,0.6); backdrop-filter: blur(6px);
  display: flex; align-items: flex-end; justify-content: center;
  opacity: 0; visibility: hidden; pointer-events: none;
  transition: opacity 0.3s ease, visibility 0.3s ease;
}
.members-sheet-overlay.show { opacity: 1; visibility: visible; pointer-events: auto; }
.members-sheet {
  width: 100%; max-width: 500px; max-height: 70vh;
  background: var(--bg-card); border-radius: 20px 20px 0 0;
  padding: 0 0 calc(16px + var(--safe-bottom)); transform: translateY(100%);
  transition: transform 0.35s cubic-bezier(0.32,0.72,0,1);
  display: flex; flex-direction: column;
}
.members-sheet-overlay.show .members-sheet { transform: translateY(0); }
.members-sheet-handle { width: 36px; height: 4px; background: var(--border-glass); border-radius: 2px; margin: 12px auto 0; flex-shrink: 0; }
.members-sheet-header {
  display: flex; align-items: center; justify-content: space-between;
  padding: 16px 20px 12px; flex-shrink: 0;
}
.members-sheet-title { font-family: var(--font-heading); font-size: 18px; font-weight: 700; color: var(--warm-white); }
.members-sheet-close {
  width: 32px; height: 32px; border-radius: 50%; border: none;
  background: var(--bg-elevated); color: var(--text-secondary);
  font-size: 16px; cursor: pointer; display: flex; align-items: center; justify-content: center;
}
.members-sheet-list {
  flex: 1; overflow-y: auto; padding: 0 20px 16px;
  -webkit-overflow-scrolling: touch;
}
.members-sheet-row {
  display: flex; align-items: center; gap: 12px;
  padding: 12px 0; border-bottom: 1px solid var(--border-glass);
  cursor: pointer; transition: opacity 0.15s;
}
.members-sheet-row:last-child { border-bottom: none; }
.members-sheet-row:active { opacity: 0.7; }
.members-sheet-avatar {
  width: 44px; height: 44px; border-radius: 50%; object-fit: cover;
  background: var(--bg-elevated); flex-shrink: 0;
}
.members-sheet-info { flex: 1; min-width: 0; }
.members-sheet-name { font-size: 15px; font-weight: 600; color: var(--warm-white); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.members-sheet-detail { font-size: 12px; color: var(--text-secondary); margin-top: 2px; }
.members-sheet-badge {
  font-size: 10px; font-weight: 600; color: var(--cyan);
  background: rgba(132,207,195,0.1); border: 1px solid rgba(132,207,195,0.2);
  padding: 3px 8px; border-radius: 10px; white-space: nowrap;
}
.members-sheet-empty {
  text-align: center; padding: 40px 20px; color: var(--text-dim); font-size: 14px;
}

/* ── CHAT VIEW ── */
.chat-view {
  position: fixed;
  top: 0; left: 0; right: 0; bottom: 0;
  z-index: 99991;
  background: var(--bg-deep);
  display: flex;
  flex-direction: column;
  transform: translateX(100%);
  transition: transform 0.3s cubic-bezier(0.32,0.72,0,1);
  pointer-events: none;
}
.chat-view.visible { transform: translateX(0); pointer-events: auto; }

.chat-header {
  position: relative; z-index: 2;
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 12px 16px;
  padding-top: max(12px, env(safe-area-inset-top));
  background: var(--bg-glass-solid);
  backdrop-filter: blur(24px);
  border-bottom: 1px solid var(--border-glass);
}
.chat-back {
  width: 36px;
  height: 36px;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 50%;
  background: rgba(255,255,255,0.06);
  cursor: pointer;
  font-size: 18px;
  color: var(--text-secondary);
  flex-shrink: 0;
}
.chat-back:hover { color: var(--text-primary); }
.chat-title { font-weight: 600; font-size: 16px; }
.chat-members { font-size: 12px; color: var(--text-secondary); cursor: pointer; text-decoration: underline; text-decoration-color: rgba(132,207,195,0.3); text-underline-offset: 2px; }
.chat-members:active { opacity: 0.6; }

.chat-messages {
  position: relative; z-index: 1;
  flex: 1;
  overflow-y: auto;
  padding: 16px;
  display: flex;
  flex-direction: column;
  gap: 12px;
}

.chat-msg {
  display: flex;
  gap: 10px;
  max-width: 85%;
  animation: fadeUp 0.3s ease;
}
.chat-msg.mine { align-self: flex-end; flex-direction: row-reverse; }

.chat-msg-avatar {
  width: 32px;
  height: 32px;
  border-radius: 50%;
  object-fit: cover;
  flex-shrink: 0;
  background: var(--bg-card);
}
.chat-msg-bubble {
  padding: 10px 14px;
  background: var(--bg-card);
  border: 1px solid var(--border-glass);
  border-radius: 16px 16px 16px 4px;
  font-size: 14px;
  line-height: 1.5;
}
.chat-msg.mine .chat-msg-bubble {
  background: var(--cyan-dim);
  border-color: rgba(132,207,195,0.2);
  border-radius: 16px 16px 4px 16px;
}
.chat-reply-bar {
  display: none;
  align-items: center;
  gap: 8px;
  padding: 10px 14px;
  background: rgba(132,207,195,0.08);
  border-left: 3px solid var(--portal-accent, #84cfc3);
  border-radius: 8px;
  margin: 0 12px 6px;
  font-size: 13px;
  color: rgba(255,255,255,0.7);
  animation: slideUp 0.2s ease;
}
.chat-reply-bar.active { display: flex; }
.chat-reply-bar .reply-preview { flex: 1; min-width: 0; }
.chat-reply-bar .reply-label { font-size: 10px; text-transform: uppercase; letter-spacing: 1px; color: var(--portal-accent, #84cfc3); font-weight: 600; display: block; margin-bottom: 2px; }
.chat-reply-bar .reply-name { color: var(--warm-white, #fff); font-weight: 600; margin-right: 4px; }
.chat-reply-bar .reply-text-preview { display: block; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; font-size: 12px; color: rgba(255,255,255,0.5); }
.chat-reply-bar .reply-close { background: none; border: none; color: rgba(255,255,255,0.5); font-size: 18px; cursor: pointer; padding: 0 4px; }
.chat-msg-reply-ref {
  font-size: 12px;
  color: rgba(255,255,255,0.45);
  padding: 4px 10px 2px;
  border-left: 2px solid rgba(132,207,195,0.3);
  margin-bottom: 4px;
  cursor: pointer;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.chat-msg-reply-ref .reply-ref-name { color: var(--portal-accent, #84cfc3); font-weight: 600; }
@keyframes slideUp { from { transform: translateY(8px); opacity: 0; } to { transform: translateY(0); opacity: 1; } }
.chat-msg-name { font-size: 12px; font-weight: 600; color: var(--cyan); margin-bottom: 2px; cursor: pointer; display: flex; align-items: center; gap: 6px; flex-wrap: wrap; }
.chat-msg-name:active { opacity: 0.7; }
.portal-tier-badge { font-size: 9px; font-weight: 700; letter-spacing: 0.5px; padding: 1px 6px; border-radius: 10px; display: inline-flex; align-items: center; gap: 2px; flex-shrink: 0; line-height: 1.4; }
.portal-tier-badge.founder { background: linear-gradient(135deg, rgba(255,163,0,0.15), rgba(255,98,154,0.15)); color: #ffa300; border: 1px solid rgba(255,163,0,0.25); }
.portal-tier-badge.member { background: rgba(132,207,195,0.1); color: #84cfc3; border: 1px solid rgba(132,207,195,0.2); }
.chat-msg-time { font-size: 11px; color: var(--text-dim); margin-top: 4px; display: flex; align-items: center; gap: 8px; }
.chat-msg-heart:active { opacity: 1 !important; transform: scale(1.3); }
.chat-msg-more { display: inline-flex; align-items: center; justify-content: center; min-width: 36px; min-height: 32px; font-size: 20px; letter-spacing: 2px; color: rgba(255,255,255,0.4); cursor: pointer; padding: 4px 8px; border-radius: 8px; line-height: 1; -webkit-tap-highlight-color: rgba(132,207,195,0.2); background: none; border: none; -webkit-appearance: none; appearance: none; }
.chat-msg-more:active { background: rgba(255,255,255,0.1); color: rgba(255,255,255,0.7); }
/* Reaction pill (shows under bubble when message has reactions) */
.chat-msg-react-pill {
  display: none; align-items: center; gap: 2px;
  position: absolute; bottom: -10px; right: 8px;
  background: rgba(30,30,40,0.92); border: 1px solid rgba(255,255,255,0.1);
  border-radius: 10px; padding: 2px 6px; cursor: pointer;
  font-size: 13px; z-index: 2; backdrop-filter: blur(8px);
}
.chat-msg-react-pill.visible { display: inline-flex; }
.chat-msg-react-pill .react-count { font-size: 11px; font-weight: 600; color: rgba(255,255,255,0.7); margin-left: 1px; }
.chat-msg .chat-msg-bubble { position: relative; }
.chat-msg.has-reactions { margin-bottom: 12px; }

/* Message inline actions (no overlay — just expands below message) */
.msg-inline-actions { padding: 8px 16px; background: rgba(255,255,255,0.03); border-radius: 12px; margin: 4px 0; }
.msg-inline-emojis { display: flex; justify-content: center; gap: 4px; padding: 6px 0; }
.msg-inline-emoji { font-size: 24px; padding: 4px 6px; cursor: pointer; border-radius: 8px; }
.msg-inline-emoji:active { background: rgba(255,255,255,0.1); transform: scale(1.2); }
.msg-inline-btns { display: flex; gap: 8px; justify-content: center; padding-top: 8px; border-top: 1px solid rgba(255,255,255,0.06); }
.msg-inline-btn { background: rgba(255,255,255,0.06); border: none; color: rgba(255,255,255,0.7); font-size: 13px; padding: 8px 14px; border-radius: 8px; cursor: pointer; }
.msg-inline-btn:active { background: rgba(255,255,255,0.12); }
.msg-inline-danger { color: #ff6464; }
.msg-inline-cancel { color: rgba(255,255,255,0.4); }

/* Message action sheet (absolute inside chat-view, not fixed — iOS transform compat) */
.msg-sheet-active { position: absolute; inset: 0; z-index: 200; }
.msg-sheet-backdrop { position: absolute; inset: 0; background: rgba(0,0,0,0.4); }
.msg-sheet-panel { position: absolute; bottom: 0; left: 0; right: 0; background: #1e1e2e; border-radius: 16px 16px 0 0; padding: 12px 16px; padding-bottom: max(16px, env(safe-area-inset-bottom)); animation: sheetSlideUp 0.25s ease; }
@keyframes sheetSlideUp { 0% { transform: translateY(100%); } 100% { transform: translateY(0); } }
.msg-sheet-emojis { display: flex; justify-content: center; gap: 6px; padding: 10px 0 14px; border-bottom: 1px solid rgba(255,255,255,0.06); }
.msg-sheet-emoji { font-size: 28px; padding: 6px 8px; cursor: pointer; border-radius: 50%; }
.msg-sheet-emoji:active { background: rgba(255,255,255,0.1); transform: scale(1.2); }
.msg-sheet-btn { display: block; width: 100%; background: none; border: none; color: rgba(255,255,255,0.9); font-size: 16px; padding: 14px 16px; text-align: left; cursor: pointer; }
.msg-sheet-btn:active { background: rgba(255,255,255,0.06); }
.msg-sheet-danger { color: #ff6464; }
.msg-sheet-cancel { color: rgba(255,255,255,0.4); text-align: center !important; font-size: 14px; margin-top: 4px; border-top: 1px solid rgba(255,255,255,0.06); }

/* WhatsApp-style reaction bar (floating above message on long-press) */
.react-bar-overlay {
  position: fixed; inset: 0; z-index: 9998;
  background: rgba(0,0,0,0.4);
  backdrop-filter: blur(2px);
  animation: reactDimIn 0.15s ease;
}
@keyframes reactDimIn { 0% { opacity: 0; } 100% { opacity: 1; } }
.react-bar {
  position: fixed; z-index: 9999;
  display: flex; align-items: center; gap: 2px;
  background: #1e1e2e; border: 1px solid rgba(255,255,255,0.1);
  border-radius: 28px; padding: 4px 6px;
  box-shadow: 0 8px 32px rgba(0,0,0,0.6);
  animation: reactBarIn 0.2s cubic-bezier(0.34,1.56,0.64,1);
}
@keyframes reactBarIn { 0% { transform: scale(0.6); opacity: 0; } 100% { transform: scale(1); opacity: 1; } }
.react-bar-emoji {
  font-size: 28px; cursor: pointer; padding: 6px 7px; border-radius: 50%;
  transition: transform 0.12s; line-height: 1; user-select: none;
}
.react-bar-emoji:active { transform: scale(1.4); }
.react-bar-emoji.selected { background: rgba(255,255,255,0.1); }

/* Action row below reaction bar */
.react-bar-actions {
  position: fixed; z-index: 9999;
  display: flex; flex-direction: column;
  background: #1e1e2e; border: 1px solid rgba(255,255,255,0.08);
  border-radius: 14px; overflow: hidden; min-width: 180px;
  box-shadow: 0 8px 32px rgba(0,0,0,0.6);
  animation: reactBarIn 0.2s cubic-bezier(0.34,1.56,0.64,1) 0.04s both;
}
.react-bar-action {
  padding: 14px 18px; font-size: 15px; color: rgba(255,255,255,0.9);
  cursor: pointer; background: none; border: none; text-align: left;
  display: flex; align-items: center; gap: 12px;
  border-bottom: 1px solid rgba(255,255,255,0.04);
}
.react-bar-action:last-child { border-bottom: none; }
.react-bar-action:active { background: rgba(255,255,255,0.06); }
.react-bar-action.danger { color: #ff6464; }
.chat-date-divider {
  text-align: center;
  font-size: 11px;
  color: var(--text-dim);
  padding: 16px 0 8px;
  font-weight: 500;
  letter-spacing: 0.5px;
}
/* ── Message Delete Action ── */
.chat-msg { position: relative; }
.chat-msg-delete-action {
  position: absolute;
  top: -6px;
  right: 0;
  background: rgba(255,70,70,0.9);
  color: #fff;
  border: none;
  border-radius: 14px;
  padding: 5px 12px;
  font-size: 11px;
  font-weight: 600;
  font-family: 'Inter', sans-serif;
  cursor: pointer;
  z-index: 10;
  backdrop-filter: blur(8px);
  animation: fadeUp 0.15s ease;
  box-shadow: 0 2px 8px rgba(0,0,0,0.3);
}
.chat-msg.mine .chat-msg-delete-action { right: auto; left: 0; }
.chat-msg-delete-action:active { transform: scale(0.95); }

/* Inline delete × button (visible for admin, own messages) */
.chat-msg-x {
  background: rgba(255,255,255,0.06);
  border: 1px solid rgba(255,255,255,0.08);
  border-radius: 50%;
  color: rgba(255,255,255,0.4);
  font-size: 14px;
  width: 26px;
  height: 26px;
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  opacity: 0;
  transition: opacity 0.2s, background 0.15s;
  align-self: flex-start;
  margin-top: 2px;
  flex-shrink: 0;
}
.chat-msg:hover .chat-msg-x,
.chat-msg:active .chat-msg-x { opacity: 1; }
.chat-msg-x:active { background: rgba(255,70,70,0.2); color: #ff4646; }
/* On mobile, always show — no hover state */
@media (hover: none) {
  .chat-msg .chat-msg-x { opacity: 0.7; }
  .chat-msg-x:active { opacity: 1; color: #ff4646; }
}

.chat-empty {
  flex: 1;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  color: var(--text-dim);
  text-align: center;
  padding: 40px;
}
.chat-empty-icon { font-size: 48px; margin-bottom: 16px; }
.chat-empty-text { font-size: 15px; line-height: 1.5; }

.chat-input-bar {
  position: relative; z-index: 2;
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 12px 16px;
  padding-bottom: max(12px, var(--safe-bottom));
  background: var(--bg-glass-solid);
  border-top: 1px solid var(--border-glass);
}
.chat-input {
  flex: 1;
  padding: 12px 16px;
  background: rgba(255,255,255,0.06);
  border: 1px solid var(--border-glass);
  border-radius: 100px;
  color: var(--text-primary);
  font-size: 15px;
  font-family: inherit;
  outline: none;
}
.chat-input:focus { border-color: var(--cyan); }
.chat-input::placeholder { color: var(--text-dim); }

.chat-send {
  width: 42px;
  height: 42px;
  border-radius: 50%;
  background: var(--gradient-portal);
  border: none;
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  font-size: 18px;
  color: #252525;
  flex-shrink: 0;
  transition: transform 0.2s;
}
.chat-send:hover { transform: scale(1.05); }

/* ── MENTION DROPDOWN ── */
.mention-dropdown {
  display: none;
  position: absolute;
  bottom: 100%;
  left: 16px;
  right: 16px;
  max-height: 200px;
  overflow-y: auto;
  background: var(--bg-glass-solid);
  border: 1px solid var(--border-glass);
  border-radius: 12px;
  z-index: 10;
  padding: 4px 0;
  box-shadow: 0 -4px 20px rgba(0,0,0,0.3);
  backdrop-filter: blur(20px);
  -webkit-backdrop-filter: blur(20px);
}
.mention-dropdown.show { display: block; }
.mention-item {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 10px 14px;
  cursor: pointer;
  transition: background 0.15s;
}
.mention-item:hover, .mention-item.active {
  background: rgba(132,207,195,0.1);
}
.mention-item-avatar {
  width: 28px;
  height: 28px;
  border-radius: 50%;
  background: var(--cyan-dim);
  flex-shrink: 0;
  object-fit: cover;
}
.mention-item-name {
  font-size: 14px;
  font-weight: 500;
  color: var(--warm-white);
}
.mention-item-city {
  font-size: 12px;
  color: var(--text-dim);
}
.chat-mention {
  color: var(--cyan);
  font-weight: 500;
}
.chat-mention-link {
  cursor: pointer;
  text-decoration: underline;
  text-decoration-color: rgba(132,207,195,0.3);
  text-underline-offset: 2px;
}
.chat-mention-link:active {
  opacity: 0.7;
}
.chat-send:disabled { opacity: 0.4; cursor: not-allowed; transform: none; }

/* ── EVENTS SCREEN ── */
.events-screen {
  background: var(--bg-deep);
  overflow: hidden;
}
.events-screen .app-header {
  position: relative;
  flex-shrink: 0;
}
.events-screen .events-filters {
  flex-shrink: 0;
}
.events-screen .events-list {
  flex: 1;
  overflow-y: auto;
 -webkit-overflow-scrolling: touch;
}

.events-header-bar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 16px 16px 0;
}

/* Events search bar */
.events-search-bar {
  padding: 12px 16px 0;
  flex-shrink: 0;
}
.events-search-wrap {
  position: relative;
}
.events-search-input {
  width: 100%;
  background: rgba(255,255,255,0.06);
  border: 1px solid var(--border-glass);
  border-radius: 12px;
  padding: 10px 14px 10px 36px;
  color: var(--warm-white);
  font-size: 14px;
  font-family: 'Inter', sans-serif;
  outline: none;
  transition: border-color 0.2s;
}
.events-search-input::placeholder { color: var(--text-dim); }
.events-search-input:focus { border-color: var(--cyan); }
.events-search-icon {
  position: absolute;
  left: 12px;
  top: 50%;
  transform: translateY(-50%);
  color: var(--text-dim);
  pointer-events: none;
}
.events-search-clear {
  position: absolute;
  right: 10px;
  top: 50%;
  transform: translateY(-50%);
  background: none;
  border: none;
  color: var(--text-dim);
  font-size: 18px;
  cursor: pointer;
  padding: 4px;
  display: none;
}
.events-result-count {
  padding: 6px 16px 0;
  font-size: 11px;
  color: var(--text-dim);
  font-family: 'Inter', sans-serif;
}

/* City filter bar */
.events-city-bar {
  padding: 10px 16px 0;
  flex-shrink: 0;
}
.events-city-pills {
  display: flex;
  gap: 8px;
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
  padding-bottom: 2px;
}
.events-city-pills::-webkit-scrollbar { display: none; }
.events-city-pill {
  padding: 7px 14px;
  border-radius: 100px;
  border: 1px solid var(--border-glass);
  background: rgba(255,255,255,0.04);
  color: var(--text-secondary);
  font-size: 12px;
  font-weight: 500;
  white-space: nowrap;
  cursor: pointer;
  transition: all 0.2s;
  -webkit-tap-highlight-color: transparent;
}
.events-city-pill.active {
  background: var(--magenta-dim);
  border-color: var(--magenta);
  color: var(--magenta);
}
.events-city-pill.more-pill {
  border-color: rgba(255,255,255,0.15);
  color: var(--text-dim);
  font-style: italic;
}
/* City dropdown */
.city-dropdown-overlay {
  position: fixed;
  inset: 0;
  background: rgba(0,0,0,0.6);
  z-index: 5000;
  display: flex;
  align-items: flex-end;
  justify-content: center;
  backdrop-filter: blur(4px);
  -webkit-backdrop-filter: blur(4px);
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
  transition: opacity 0.3s ease, visibility 0.3s ease;
}
.city-dropdown-overlay.show { opacity: 1; visibility: visible; pointer-events: auto; }
.city-dropdown {
  width: 100%;
  max-width: 480px;
  max-height: 60vh;
  background: var(--bg-glass-solid);
  border-top-left-radius: 20px;
  border-top-right-radius: 20px;
  border: 1px solid var(--border-glass);
  border-bottom: none;
  overflow: hidden;
  display: flex;
  flex-direction: column;
  transform: translateY(100%);
  transition: transform 0.35s cubic-bezier(0.32,0.72,0,1);
}
.city-dropdown-overlay.show .city-dropdown { transform: translateY(0); }
.city-dropdown-header {
  padding: 16px;
  border-bottom: 1px solid var(--border-glass);
  flex-shrink: 0;
}
.city-dropdown-header input {
  width: 100%;
  background: rgba(255,255,255,0.06);
  border: 1px solid var(--border-glass);
  border-radius: 10px;
  padding: 10px 14px;
  color: var(--warm-white);
  font-size: 14px;
  font-family: 'Inter', sans-serif;
  outline: none;
}
.city-dropdown-header input::placeholder { color: var(--text-dim); }
.city-dropdown-header input:focus { border-color: var(--cyan); }
.city-dropdown-list {
  overflow-y: auto;
  -webkit-overflow-scrolling: touch;
  padding: 8px 0;
  flex: 1;
}
.city-dropdown-item {
  padding: 12px 20px;
  color: var(--warm-white);
  font-size: 14px;
  font-family: 'Inter', sans-serif;
  cursor: pointer;
  display: flex;
  justify-content: space-between;
  align-items: center;
  -webkit-tap-highlight-color: transparent;
}
.city-dropdown-item:active { background: rgba(255,255,255,0.06); }
.city-dropdown-item.active { color: var(--magenta); font-weight: 600; }
.city-dropdown-item .city-count {
  font-size: 11px;
  color: var(--text-dim);
  background: rgba(255,255,255,0.06);
  padding: 2px 8px;
  border-radius: 10px;
}

.events-filters {
  display: flex;
  gap: 8px;
  padding: 8px 16px;
  overflow-x: auto;
 -webkit-overflow-scrolling: touch;
  flex-shrink: 0;
}
.events-filters::-webkit-scrollbar { display: none; }

.event-filter {
  padding: 8px 16px;
  border-radius: 100px;
  border: 1px solid var(--border-glass);
  background: rgba(255,255,255,0.04);
  color: var(--text-secondary);
  font-size: 13px;
  white-space: nowrap;
  cursor: pointer;
  transition: all 0.2s;
}
.event-filter.active {
  background: var(--cyan-dim);
  border-color: var(--cyan);
  color: var(--cyan);
}
.event-filter[data-cat="bicycle-day"].active {
  background: rgba(151,116,181,0.15);
  border-color: #9774B5;
  color: #9774B5;
}
.event-filter[data-cat="my-events"].active {
  background: rgba(255,163,0,0.15);
  border-color: var(--orange);
  color: var(--orange);
}

.bicycle-day-banner {
  margin: 0 16px 12px;
  padding: 22px 160px 22px 20px;
  min-height: 170px;
  border-radius: var(--radius-lg);
  background: linear-gradient(135deg, #9b6fb5 0%, #8a5da8 40%, #7b4f9a 100%);
  border: 1px solid rgba(180,150,210,0.4);
  cursor: pointer;
  transition: all 0.3s;
  position: relative;
  overflow: hidden;
  box-shadow: 0 4px 24px rgba(65,43,81,0.3), inset 0 1px 0 rgba(151,116,181,0.15);
  color: #fff;
}
.bicycle-day-banner::before {
  content: '';
  position: absolute;
  inset: 0;
  background:
    radial-gradient(circle at 15% 30%, rgba(132,207,195,0.1), transparent 50%),
    radial-gradient(circle at 85% 60%, rgba(255,98,154,0.08), transparent 50%),
    radial-gradient(circle at 50% 80%, rgba(255,163,0,0.06), transparent 40%);
  pointer-events: none;
}
.bicycle-day-banner::after { display: none; }
.bd-banner-albert {
  position: absolute;
  right: 5px;
  top: 5px;
  bottom: 5px;
  width: 150px;
  pointer-events: none;
  overflow: hidden;
}
.bd-banner-albert svg {
  width: 100% !important;
  height: 100% !important;
}
.bicycle-day-banner:hover {
  border-color: rgba(151,116,181,0.5);
  transform: translateY(-1px);
  box-shadow: 0 4px 20px rgba(65,43,81,0.2);
}
.bicycle-day-banner-tag {
  display: inline-block;
  font-size: 13px;
  font-weight: 900;
  letter-spacing: 2.5px;
  text-transform: uppercase;
  color: #E07040;
  margin-bottom: 6px;
}
.bicycle-day-banner-title {
  font-size: 18px;
  font-weight: 700;
  color: #F5E6C8;
  margin-bottom: 4px;
  position: relative;
}
.bicycle-day-banner-sub {
  font-size: 13px;
  font-weight: 600;
  color: #F5E6C8;
  opacity: 0.85;
  position: relative;
}
.bicycle-day-banner-count {
  display: inline-block;
  background: #E07040;
  color: #F5E6C8;
  font-size: 10px;
  font-weight: 600;
  padding: 2px 8px;
  border-radius: 10px;
  margin-left: 8px;
}
/* Hide the orange chip when we blank the text (recap mode). Otherwise the
   padding alone paints a tiny orange dash next to the Bicycle Day logo. */
.bicycle-day-banner-count:empty { display: none !important; }

/* ── BICYCLE DAY CITY LIST & DETAIL ── */
.bd-city-overlay {
  position: fixed;
  top: 0; left: 0; right: 0; bottom: 0;
  z-index: 100000;
  background: linear-gradient(180deg, #412B51 0%, #2a1a38 40%, #1a0e2e 100%);
  display: flex;
  flex-direction: column;
  overflow-y: auto;
  -webkit-overflow-scrolling: touch;
  overscroll-behavior: contain;
  transform: translateX(100%);
  transition: transform 0.3s cubic-bezier(0.32,0.72,0,1);
  pointer-events: none;
}
.bd-city-overlay.visible { transform: translateX(0); pointer-events: auto; }

.bd-header {
  display: flex;
  align-items: center;
  padding: 16px;
  gap: 12px;
  flex-shrink: 0;
  background: rgba(65,43,81,0.95);
  border-bottom: 1px solid rgba(151,116,181,0.25);
  padding-top: calc(16px + var(--safe-top, 0px));
}
.bd-header-back {
  font-size: 20px;
  cursor: pointer;
  color: #F4F4BE;
  -webkit-tap-highlight-color: transparent;
}
.bd-header-title {
  flex: 1;
  font-size: 17px;
  font-weight: 700;
  color: #F4F4BE;
}
.bd-header-sub {
  font-size: 12px;
  color: #85ACB5;
  font-weight: 600;
}

/* Desktop-only BD hero */
.bd-desktop-hero {
  display: none; /* hidden on mobile */
}

/* City list hero */
.bd-list-hero-img {
  width: 100%;
  height: auto;
  display: block;
}
.bd-list-hero {
  padding: 16px 16px 12px;
  text-align: center;
}
.bd-list-hero-label {
  font-size: 1.4rem;
  color: #E28861;
  text-transform: uppercase;
  letter-spacing: 0.15em;
  font-weight: 700;
  margin-bottom: 4px;
  margin-top: 0;
}
.bd-list-hero-title {
  font-size: 28px;
  font-weight: 800;
  color: #F4F4BE;
  margin-bottom: 6px;
  text-shadow: 0 2px 12px rgba(0,0,0,0.4);
}
.bd-list-hero-sub {
  font-size: 14px;
  color: rgba(244,244,190,0.75);
  line-height: 1.5;
  max-width: 320px;
  margin: 0 auto;
}

/* City search */
.bd-search-wrap {
  padding: 8px 16px 12px;
}
.bd-search-input {
  width: 100%;
  padding: 10px 14px;
  background: rgba(65,43,81,0.3);
  border: 1px solid rgba(151,116,181,0.25);
  border-radius: var(--radius-md);
  color: #F4F4BE;
  font-size: 14px;
  outline: none;
}
.bd-search-input::placeholder { color: rgba(133,172,181,0.5); }
.bd-search-input:focus { border-color: #85ACB5; }

/* City grid */
.bd-city-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 12px;
  padding: 0 16px 120px;
}
/* Skeleton loading cards */
.bd-skeleton-card {
  border-radius: 16px;
  overflow: hidden;
  position: relative;
  background: linear-gradient(135deg, rgba(65,43,81,0.5) 0%, rgba(90,61,110,0.35) 50%, rgba(133,172,181,0.2) 100%);
}
.bd-skeleton-card.bd-skel-featured { grid-column: 1 / -1; height: 220px; }
.bd-skeleton-card.bd-skel-regular { height: 180px; }
.bd-skeleton-card::after {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(90deg, transparent 0%, rgba(255,255,255,0.06) 40%, rgba(255,255,255,0.1) 50%, rgba(255,255,255,0.06) 60%, transparent 100%);
  animation: bdShimmer 1.5s infinite;
}
.bd-skeleton-label {
  position: absolute;
  bottom: 12px; left: 12px; right: 12px;
  z-index: 2;
}
.bd-skeleton-line {
  height: 14px;
  border-radius: 7px;
  background: rgba(255,255,255,0.12);
  margin-bottom: 6px;
}
.bd-skeleton-line.skel-title { width: 65%; height: 18px; border-radius: 9px; }
.bd-skeleton-line.skel-sub { width: 45%; }
.bd-skeleton-status {
  position: absolute;
  top: 10px; left: 10px;
  width: 70px; height: 22px;
  border-radius: 11px;
  background: rgba(255,255,255,0.1);
}
@keyframes bdShimmer {
  0% { transform: translateX(-100%); }
  100% { transform: translateX(100%); }
}
.bd-city-card {
  border-radius: 16px;
  overflow: hidden;
  cursor: pointer;
  position: relative;
  height: 180px;
  transition: all 0.2s;
  -webkit-tap-highlight-color: transparent;
}
.bd-city-card.bd-card-featured {
  grid-column: 1 / -1;
  height: 220px;
}
.bd-city-card:active { transform: scale(0.97); }
.bd-city-card-img {
  position: absolute;
  inset: 0;
  background: linear-gradient(135deg, rgba(65,43,81,0.7) 0%, rgba(90,61,110,0.5) 50%, rgba(133,172,181,0.3) 100%);
  display: flex;
  align-items: center;
  justify-content: center;
}
.bd-city-card-img img {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.bd-city-card-img .bd-city-card-emoji {
  font-size: 28px;
  opacity: 0.4;
  color: #fff;
}
.bd-city-card-gradient {
  position: absolute;
  inset: 0;
  background: linear-gradient(to bottom, rgba(0,0,0,0) 0%, rgba(0,0,0,0.3) 40%, rgba(0,0,0,0.85) 85%, rgba(0,0,0,0.95) 100%);
  z-index: 1;
}
.bd-city-card-overlay {
  position: absolute;
  bottom: 0; left: 0; right: 0;
  padding: 12px;
  z-index: 2;
}
.bd-city-card-name {
  font-family: 'BicycleDay', var(--font-heading), sans-serif;
  font-size: 20px;
  font-weight: 400;
  color: #fff;
  text-shadow: 0 1px 4px rgba(0,0,0,0.8);
  line-height: 1.2;
  letter-spacing: 1px;
}
.bd-card-featured .bd-city-card-name { font-size: 28px; }
.bd-city-card-riders {
  font-size: 12px;
  color: rgba(255,255,255,0.8);
  margin-top: 2px;
}
.bd-city-card-closest {
  font-size: 10px;
  color: #2dd4bf;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.5px;
  margin-bottom: 2px;
}
/* Status badge — top-left */
.bd-city-card-status {
  position: absolute;
  top: 10px;
  left: 10px;
  z-index: 3;
  display: inline-block;
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.5px;
  text-transform: uppercase;
  padding: 3px 8px;
  border-radius: 8px;
  background: rgba(0,0,0,0.55);
  backdrop-filter: blur(4px);
  -webkit-backdrop-filter: blur(4px);
}
.bd-status-needs { color: #F59E0B; }
.bd-status-organizing { color: #2dd4bf; }
.bd-status-confirmed { color: #10B981; }
.bd-status-riding { color: #c4a5e0; }
.bd-status-yours {
  background: linear-gradient(135deg, var(--cyan), var(--lavender));
  color: #fff;
}
/* Distance — top-right */
.bd-city-card-distance {
  position: absolute;
  top: 10px;
  right: 10px;
  z-index: 3;
  font-size: 10px;
  color: rgba(255,255,255,0.85);
  background: rgba(0,0,0,0.55);
  backdrop-filter: blur(4px);
  -webkit-backdrop-filter: blur(4px);
  padding: 3px 8px;
  border-radius: 8px;
}
/* Organizer avatars — bottom-right */
.bd-city-card-avatars {
  position: absolute;
  bottom: 12px;
  right: 12px;
  z-index: 3;
  display: flex;
}
.bd-city-card-avatars img {
  width: 20px;
  height: 20px;
  border-radius: 50%;
  object-fit: cover;
  border: 1.5px solid rgba(0,0,0,0.6);
  margin-left: -6px;
}
.bd-city-card-avatars img:first-child { margin-left: 0; }
/* YOUR RIDE section */
.bd-your-ride-label {
  font-size: 11px;
  color: #85ACB5;
  text-transform: uppercase;
  letter-spacing: 1.5px;
  font-weight: 700;
  padding: 4px 16px 8px;
  display: flex;
  align-items: center;
  gap: 6px;
}
.bd-your-ride-label .bd-sparkle-icon {
  width: 14px;
  height: 14px;
  fill: #F4F4BE;
  opacity: 0.8;
  flex-shrink: 0;
}
.bd-grid-divider {
  grid-column: 1 / -1;
  height: 1px;
  background: rgba(151,116,181,0.15);
  margin: 4px 0;
}
/* Countdown chip */
.bd-countdown-chip {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  font-size: 11px;
  font-weight: 700;
  padding: 3px 10px;
  border-radius: 12px;
  background: rgba(45,212,191,0.15);
  color: #2dd4bf;
  margin-top: 6px;
}
.bd-countdown-chip .bd-sparkle-icon {
  width: 12px;
  height: 12px;
  fill: #2dd4bf;
  flex-shrink: 0;
}
.bd-countdown-chip.bd-countdown-soon {
  background: rgba(245,158,11,0.15);
  color: #F59E0B;
}
.bd-countdown-chip.bd-countdown-today {
  background: rgba(245,158,11,0.2);
  color: #F59E0B;
}
.bd-countdown-chip.bd-countdown-recap {
  background: rgba(255,99,154,0.18);
  color: #ff629a;
}
.bd-countdown-chip.bd-countdown-recap .bd-sparkle-icon { fill: #ff629a; }

/* ── Events-tab banner: recap variant (April 20 – May 19) ── */
.bicycle-day-banner.bicycle-day-banner-recap {
  background: linear-gradient(135deg, rgba(255,99,154,0.16), rgba(255,163,0,0.12));
  border-color: rgba(255,99,154,0.35);
}
.bicycle-day-banner.bicycle-day-banner-recap .bicycle-day-banner-tag {
  color: #ff629a;
}

/* ── BD Memories hero (renders inside bd-city-overlay above the cities grid) ── */
.bd-memories-hero {
  margin: 8px 0 20px;
  padding: 20px 18px 22px;
  border-radius: 18px;
  background: linear-gradient(140deg, rgba(255,99,154,0.10) 0%, rgba(132,207,195,0.06) 50%, rgba(255,163,0,0.08) 100%);
  border: 1px solid rgba(255,99,154,0.18);
}
.bd-memories-head { margin-bottom: 16px; }
.bd-memories-eyebrow {
  font-family: 'Oswald', sans-serif;
  font-size: 10px;
  letter-spacing: 2px;
  text-transform: uppercase;
  color: #ff629a;
  font-weight: 700;
  margin-bottom: 8px;
}
.bd-memories-title {
  font-family: 'Oswald', sans-serif;
  font-size: 28px;
  font-weight: 700;
  color: #fff;
  line-height: 1.1;
  margin: 0 0 6px;
  letter-spacing: -0.5px;
}
.bd-memories-sub {
  font-size: 14px;
  color: rgba(255,255,255,0.72);
  line-height: 1.45;
  margin: 0 0 16px;
}
.bd-memories-cta {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 14px 24px;
  border-radius: 999px;
  background: linear-gradient(135deg, #ff629a 0%, #ffa300 100%);
  color: #0a0a0f;
  border: none;
  font-family: 'Oswald', sans-serif;
  font-weight: 700;
  font-size: 13px;
  letter-spacing: 1.5px;
  text-transform: uppercase;
  cursor: pointer;
  box-shadow: 0 4px 20px rgba(255,99,154,0.35);
  transition: transform 0.15s ease, box-shadow 0.15s ease;
  -webkit-tap-highlight-color: transparent;
}
.bd-memories-cta:hover { transform: translateY(-1px); box-shadow: 0 6px 24px rgba(255,99,154,0.45); }
.bd-memories-cta:active { transform: scale(0.98); }
.bd-memories-cta-icon {
  display: inline-block;
  font-size: 16px;
  line-height: 1;
}
.bd-memories-stats {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 8px;
  margin: 14px 0 10px;
}
.bd-memstat {
  padding: 12px 6px;
  border-radius: 12px;
  background: rgba(0,0,0,0.28);
  border: 1px solid rgba(255,255,255,0.06);
  text-align: center;
}
.bd-memstat-num {
  font-family: 'Oswald', sans-serif;
  font-size: 22px;
  font-weight: 700;
  color: #ffa300;
  line-height: 1;
  letter-spacing: -0.5px;
}
.bd-memstat-lbl {
  font-size: 10px;
  color: rgba(255,255,255,0.55);
  text-transform: uppercase;
  letter-spacing: 1px;
  margin-top: 4px;
}
.bd-memories-topcity {
  font-size: 12px;
  color: rgba(255,255,255,0.6);
  margin: 4px 0 14px;
}
.bd-memories-topcity strong { color: #84cfc3; font-weight: 600; }

/* My Ride card */
.bd-myride-card {
  margin: 6px 0 18px;
  padding: 14px;
  border-radius: 14px;
  background: rgba(132,207,195,0.08);
  border: 1px solid rgba(132,207,195,0.22);
}
.bd-myride-label {
  font-family: 'Oswald', sans-serif;
  font-size: 10px;
  letter-spacing: 2px;
  text-transform: uppercase;
  color: #84cfc3;
  font-weight: 700;
  margin-bottom: 10px;
}
.bd-myride-body { display: flex; gap: 12px; align-items: flex-start; }
.bd-myride-media-wrap {
  flex: 0 0 96px;
  width: 96px;
  height: 96px;
  border-radius: 10px;
  overflow: hidden;
  background: rgba(0,0,0,0.4);
}
.bd-myride-media { width: 100%; height: 100%; object-fit: cover; display: block; }
.bd-myride-media.bd-myride-media-empty {
  display: flex; align-items: center; justify-content: center;
  font-size: 36px;
}
.bd-myride-meta { flex: 1; min-width: 0; }
.bd-myride-city {
  font-family: 'Oswald', sans-serif;
  font-size: 18px;
  font-weight: 700;
  color: #fff;
  line-height: 1.2;
  margin-bottom: 6px;
}
.bd-myride-msg {
  font-size: 13px;
  color: rgba(255,255,255,0.72);
  line-height: 1.45;
  font-style: italic;
}
.bd-myride-more {
  margin-top: 8px;
  font-size: 11px;
  color: #84cfc3;
  font-weight: 600;
}

/* Global Feed grid */
.bd-memories-feed-label,
.bd-memories-cities-label {
  font-family: 'Oswald', sans-serif;
  font-size: 11px;
  letter-spacing: 2px;
  text-transform: uppercase;
  color: rgba(255,255,255,0.55);
  font-weight: 600;
  margin: 4px 0 10px;
}
.bd-memories-cities-label { margin-top: 24px; }
.bd-memories-feed {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  /* Automatic row height = column width. Pairs with grid-auto-flow:dense so
     tiles pack around the 2x2 video tiles and don't leave empty squares. */
  grid-auto-rows: 1fr;
  grid-auto-flow: dense;
  gap: 4px;
  margin-bottom: 10px;
}
.bd-memfeed-tile {
  position: relative;
  aspect-ratio: 1 / 1;
  border-radius: 8px;
  overflow: hidden;
  background: rgba(0,0,0,0.3);
  cursor: pointer;
}
/* Featured tiles — span the full 3-column grid and break the square aspect
   ratio so video content renders at its natural size. Used for the BD reel
   and Denver 7 News embed pinned to the top of the Memories feed. */
.bd-memfeed-tile.bd-memfeed-featured {
  grid-column: 1 / -1;
  aspect-ratio: 16 / 9;
  border-radius: 12px;
  margin-bottom: 4px;
}
.bd-memfeed-tile.bd-memfeed-featured.bd-memfeed-featured-portrait {
  aspect-ratio: 9 / 16;
  max-height: 75vh;
}
.bd-memfeed-tile.bd-memfeed-featured iframe,
.bd-memfeed-tile.bd-memfeed-featured video {
  width: 100%;
  height: 100%;
  object-fit: cover;
  border: none;
  display: block;
}
.bd-memfeed-tile.bd-memfeed-featured .bd-memfeed-overlay {
  padding: 10px 14px 12px;
  background: linear-gradient(180deg, transparent 40%, rgba(0,0,0,0.85));
}
.bd-memfeed-tile.bd-memfeed-featured .bd-memfeed-name {
  font-size: 14px;
  font-weight: 700;
  letter-spacing: 0.3px;
}
.bd-memfeed-tile.bd-memfeed-featured .bd-memfeed-city {
  font-size: 12px;
  opacity: 0.85;
}
.bd-memfeed-featured-badge {
  position: absolute;
  top: 10px;
  left: 10px;
  padding: 3px 9px;
  border-radius: 999px;
  background: rgba(0,0,0,0.6);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  color: #fff;
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 1px;
  text-transform: uppercase;
  z-index: 2;
  border: 1px solid rgba(255,255,255,0.15);
}
.bd-memfeed-tile.bd-memfeed-skeleton {
  background: linear-gradient(90deg, rgba(255,255,255,0.04), rgba(255,255,255,0.08), rgba(255,255,255,0.04));
  background-size: 200% 100%;
  animation: skeletonPulse 1.5s ease-in-out infinite;
}
/* Video tiles stand out in the Memories feed: same 1:1 footprint as photos
   so vertical videos don't blow out grid row heights, plus a pink glow ring
   and a play-arrow overlay. Previously these spanned 2x2 with aspect:auto,
   which caused vertical-video tiles to make their row 2-3x as tall as the
   surrounding photo rows and left empty grid cells around them. */
.bd-memfeed-tile.bd-memfeed-video {
  aspect-ratio: 1 / 1;
  box-shadow: 0 0 0 2px rgba(255,99,154,0.45), 0 8px 28px rgba(255,99,154,0.18);
  border-radius: 12px;
}
.bd-memfeed-tile.bd-memfeed-video::after {
  content: '';
  position: absolute;
  inset: 0;
  pointer-events: none;
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='60' height='60' viewBox='0 0 24 24' fill='%23ffffff'><circle cx='12' cy='12' r='11' fill='rgba(0,0,0,0.55)' stroke='rgba(255,255,255,0.75)' stroke-width='1.2'/><path d='M9.5 7.5v9l8-4.5-8-4.5z'/></svg>");
  background-repeat: no-repeat;
  background-position: center;
  background-size: 64px 64px;
  z-index: 1;
}
.bd-memfeed-media {
  width: 100%; height: 100%; object-fit: cover; display: block;
}
.bd-memfeed-overlay {
  position: absolute;
  left: 0; right: 0; bottom: 0;
  padding: 6px 8px 5px;
  background: linear-gradient(180deg, transparent, rgba(0,0,0,0.7));
  color: #fff;
}
.bd-memfeed-name {
  font-size: 11px; font-weight: 600; line-height: 1.2;
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
.bd-memfeed-city {
  font-size: 9px; opacity: 0.78; letter-spacing: 0.5px;
  text-transform: uppercase;
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
.bd-memories-feed-empty {
  grid-column: 1 / -1;
  padding: 20px;
  text-align: center;
  color: rgba(255,255,255,0.55);
  font-size: 13px;
}
.bd-memories-loadmore {
  display: block;
  margin: 10px auto 0;
  padding: 10px 20px;
  border-radius: 999px;
  background: rgba(132,207,195,0.1);
  border: 1px solid rgba(132,207,195,0.3);
  color: #84cfc3;
  font-family: 'Oswald', sans-serif;
  font-size: 11px;
  font-weight: 600;
  letter-spacing: 1.5px;
  text-transform: uppercase;
  cursor: pointer;
}
.bd-memories-loadmore:disabled { opacity: 0.5; cursor: default; }

@media (min-width: 640px) {
  .bd-memories-feed { grid-template-columns: repeat(4, 1fr); }
  .bd-memories-title { font-size: 34px; }
}
@media (min-width: 1024px) {
  .bd-memories-feed { grid-template-columns: repeat(6, 1fr); }
}

/* City suggest FAB — pill style with scroll collapse */
.bd-suggest-fab {
  position: fixed;
  bottom: 24px;
  right: 20px;
  height: 48px;
  padding: 0 20px;
  border-radius: 24px;
  background: #2dd4bf;
  border: none;
  display: none;
  align-items: center;
  justify-content: center;
  gap: 6px;
  cursor: pointer;
  z-index: 100003;
  box-shadow: 0 4px 20px rgba(45,212,191,0.4);
  -webkit-tap-highlight-color: transparent;
  transition: all 0.3s cubic-bezier(0.4,0,0.2,1);
  overflow: hidden;
  white-space: nowrap;
  color: #0a0a0a;
  font-size: 14px;
  font-weight: 600;
}
.bd-suggest-fab.visible { display: flex; }
/* Recap mode: force-hide the "Add Your City" FAB regardless of who added .visible. */
body.bd-recap-mode .bd-suggest-fab,
body.bd-recap-mode .bd-suggest-fab.visible { display: none !important; }
/* Recap mode: swap BD hero image for inline autoplay video via CSS so the
   display toggle doesn't depend on JS firing at the right moment. */
body.bd-recap-mode #bd-hero-picture { display: none !important; }
body.bd-recap-mode #bd-hero-video { display: block !important; }
body.bd-recap-mode #bd-hero-mute { display: flex !important; }
/* Recap / archive mode: drop the "Search cities…" input — the grid is short
   enough post-filter that search is just noise. */
body.bd-recap-mode .bd-search-wrap { display: none !important; }
/* Recap mode: drop the big illustrated BD hero at the top of the overlay.
   Post-event it's empty calories — the featured reel + Denver 7 News tiles
   inside the feed below carry the visual weight. */
body.bd-recap-mode .bd-city-hero-image { display: none !important; }
.bd-suggest-fab:active { transform: scale(0.95); }
.bd-suggest-fab svg { width: 20px; height: 20px; color: #0a0a0a; stroke-width: 2.5; flex-shrink: 0; }
.bd-suggest-fab-label { }
/* City suggest sheet */
/* ── Notifications first-run nudge sheet ── */
.nf-sheet-bg {
  position: fixed;
  inset: 0;
  background: rgba(0,0,0,0.6);
  z-index: 100003;
  opacity: 0;
  pointer-events: none;
  transition: opacity 0.3s;
}
.nf-sheet-bg.visible { opacity: 1; pointer-events: auto; }
.nf-sheet {
  position: fixed;
  bottom: 0; left: 0; right: 0;
  background: #1a1028;
  border-top-left-radius: 20px;
  border-top-right-radius: 20px;
  padding: 10px 20px calc(24px + var(--safe-bottom));
  z-index: 100004;
  transform: translateY(100%);
  transition: transform 0.35s cubic-bezier(0.32,0.72,0,1);
  max-height: 85vh;
  overflow-y: auto;
  -webkit-overflow-scrolling: touch;
}
.nf-sheet.visible { transform: translateY(0); }

/* ── Find the Others (unified discovery) sheet ── */
.fo-sheet-bg {
  position: fixed;
  inset: 0;
  background: rgba(0,0,0,0.6);
  z-index: 100003;
  opacity: 0;
  pointer-events: none;
  transition: opacity 0.3s;
}
.fo-sheet-bg.visible { opacity: 1; pointer-events: auto; }
.fo-sheet {
  position: fixed;
  bottom: 0; left: 0; right: 0;
  background: #1a1028;
  border-top-left-radius: 20px;
  border-top-right-radius: 20px;
  padding: 10px 20px calc(24px + var(--safe-bottom));
  z-index: 100004;
  transform: translateY(100%);
  transition: transform 0.35s cubic-bezier(0.32,0.72,0,1);
  max-height: 85vh;
  overflow-y: auto;
  -webkit-overflow-scrolling: touch;
}
.fo-sheet.visible { transform: translateY(0); }
.fo-sheet-handle {
  width: 36px; height: 4px; border-radius: 2px;
  background: rgba(255,255,255,0.2);
  margin: 0 auto 16px;
}
.fo-sheet-head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 16px;
  margin-bottom: 16px;
}
.fo-sheet-title {
  font-family: 'Oswald', sans-serif;
  font-size: 20px;
  font-weight: 700;
  color: #fff;
  margin: 0 0 4px;
  letter-spacing: 0.3px;
}
.fo-sheet-sub {
  font-size: 13px;
  color: rgba(255,255,255,0.6);
  line-height: 1.45;
  margin: 0;
}
.fo-sheet-close {
  background: rgba(255,255,255,0.06);
  border: 1px solid rgba(255,255,255,0.1);
  color: rgba(255,255,255,0.7);
  width: 32px; height: 32px;
  border-radius: 50%;
  font-size: 20px;
  line-height: 1;
  cursor: pointer;
  flex-shrink: 0;
  -webkit-tap-highlight-color: transparent;
}
.fo-sheet-close:active { transform: scale(0.94); }
.fo-sheet-list {
  display: flex;
  flex-direction: column;
  gap: 8px;
}
.fo-route {
  display: flex;
  align-items: center;
  gap: 14px;
  width: 100%;
  padding: 16px 14px;
  background: rgba(255,255,255,0.04);
  border: 1px solid rgba(255,255,255,0.08);
  border-radius: 14px;
  color: #fff;
  text-align: left;
  cursor: pointer;
  font-family: inherit;
  transition: background 0.18s, border-color 0.18s, transform 0.15s;
  -webkit-tap-highlight-color: transparent;
}
.fo-route:hover { background: rgba(255,255,255,0.07); border-color: rgba(132,207,195,0.3); }
.fo-route:active { transform: scale(0.99); }
.fo-route-icon {
  flex-shrink: 0;
  width: 44px; height: 44px;
  border-radius: 12px;
  background: linear-gradient(135deg, rgba(132,207,195,0.15), rgba(255,99,154,0.12));
  border: 1px solid rgba(132,207,195,0.2);
  display: flex; align-items: center; justify-content: center;
  color: #84cfc3;
}
.fo-route-body {
  flex: 1;
  display: flex;
  flex-direction: column;
  gap: 2px;
  min-width: 0;
}
.fo-route-title {
  font-family: 'Oswald', sans-serif;
  font-size: 15px;
  font-weight: 700;
  letter-spacing: 0.3px;
  color: #fff;
}
.fo-route-sub {
  font-size: 12px;
  color: rgba(255,255,255,0.55);
  line-height: 1.35;
}
.fo-route-arrow {
  font-size: 22px;
  color: rgba(255,255,255,0.4);
  flex-shrink: 0;
}

.bd-suggest-bg {
  position: fixed;
  inset: 0;
  background: rgba(0,0,0,0.6);
  z-index: 100003;
  opacity: 0;
  pointer-events: none;
  transition: opacity 0.3s;
}
.bd-suggest-bg.visible { opacity: 1; pointer-events: auto; }
.bd-suggest-sheet {
  position: fixed;
  bottom: 0; left: 0; right: 0;
  background: #1a1028;
  border-top-left-radius: 20px;
  border-top-right-radius: 20px;
  padding: 24px 20px calc(24px + var(--safe-bottom));
  z-index: 100004;
  transform: translateY(100%);
  transition: transform 0.35s cubic-bezier(0.32,0.72,0,1);
}
.bd-suggest-sheet.visible { transform: translateY(0); }
.bd-suggest-sheet h3 {
  font-size: 18px;
  font-weight: 700;
  color: #F4F4BE;
  margin: 0 0 4px;
}
.bd-suggest-sheet .bd-suggest-sub {
  font-size: 13px;
  color: var(--text-dim);
  margin-bottom: 16px;
  line-height: 1.4;
}
.bd-suggest-sheet input,
.bd-suggest-sheet textarea {
  width: 100%;
  padding: 10px 14px;
  background: rgba(65,43,81,0.3);
  border: 1px solid rgba(151,116,181,0.25);
  border-radius: var(--radius-md);
  color: #F4F4BE;
  font-size: 14px;
  outline: none;
  margin-bottom: 12px;
  font-family: inherit;
}
.bd-suggest-sheet textarea { resize: none; height: 72px; }
.bd-suggest-sheet input:focus,
.bd-suggest-sheet textarea:focus { border-color: #85ACB5; }
.bd-suggest-sheet input::placeholder,
.bd-suggest-sheet textarea::placeholder { color: rgba(133,172,181,0.5); }
.bd-suggest-roles {
  display: flex;
  gap: 8px;
  margin-bottom: 14px;
  flex-wrap: wrap;
}
.bd-suggest-role {
  padding: 8px 14px;
  border-radius: 20px;
  font-size: 13px;
  font-weight: 500;
  cursor: pointer;
  background: rgba(65,43,81,0.3);
  border: 1px solid rgba(151,116,181,0.25);
  color: var(--text-dim);
  transition: all 0.2s;
  -webkit-tap-highlight-color: transparent;
}
.bd-suggest-role.selected {
  background: rgba(45,212,191,0.15);
  border-color: #2dd4bf;
  color: #2dd4bf;
}
.bd-suggest-submit {
  width: 100%;
  padding: 14px;
  border: none;
  border-radius: var(--radius-md);
  background: linear-gradient(135deg, var(--cyan), var(--lavender));
  color: #fff;
  font-size: 15px;
  font-weight: 700;
  cursor: pointer;
  -webkit-tap-highlight-color: transparent;
  margin-top: 4px;
}
.bd-suggest-submit:active { opacity: 0.85; }
/* City suggest toast */
.bd-suggest-toast {
  position: fixed;
  bottom: 100px;
  left: 50%;
  transform: translateX(-50%) translateY(20px);
  background: rgba(20,15,30,0.92);
  border: 1px solid rgba(151,116,181,0.3);
  color: #F4F4BE;
  font-size: 14px;
  padding: 10px 20px;
  border-radius: 24px;
  z-index: 100005;
  opacity: 0;
  pointer-events: none;
  transition: all 0.3s;
  white-space: nowrap;
}
.bd-suggest-toast.visible {
  opacity: 1;
  transform: translateX(-50%) translateY(0);
}

/* ── BD CITY DETAIL ── */
.bd-detail-overlay {
  position: fixed;
  top: 0; left: 0; right: 0; bottom: 0;
  z-index: 100001;
  background: linear-gradient(180deg, #412B51 0%, #2a1a38 40%, #1a0e2e 100%);
  display: flex;
  flex-direction: column;
  overflow-y: auto;
  -webkit-overflow-scrolling: touch;
  overscroll-behavior: contain;
  transform: translateX(100%);
  transition: transform 0.3s cubic-bezier(0.32,0.72,0,1);
  pointer-events: none;
}
.bd-detail-overlay.visible { transform: translateX(0); pointer-events: auto; }

@font-face {
  font-family: 'BicycleDay';
  src: url('/BicycleDay2025.otf') format('opentype');
  font-weight: normal;
  font-style: normal;
  font-display: swap;
}

.bd-detail-hero {
  flex-shrink: 0;
  position: relative;
  height: 200px;
  background: url('/bd-mobile-header.jpeg') center/cover no-repeat;
}
@media (min-width: 768px) {
  .bd-detail-hero {
    height: 300px;
    background-image: url('/bd-desktop-header.jpeg');
  }
}
.bd-detail-hero-img {
  display: none;
}
.bd-detail-hero-back {
  position: absolute;
  top: calc(12px + var(--safe-top, 0px));
  left: 12px;
  width: 36px;
  height: 36px;
  border-radius: 50%;
  background: rgba(0,0,0,0.5);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 18px;
  color: #fff;
  cursor: pointer;
  z-index: 2;
  -webkit-tap-highlight-color: transparent;
}
.bd-detail-hero-info {
  position: relative;
  z-index: 1;
}
.bd-detail-hero-city {
  font-size: 24px;
  font-weight: 800;
  color: #fff;
  text-shadow: 0 2px 8px rgba(0,0,0,0.5);
}
.bd-detail-hero-date {
  font-size: 13px;
  color: rgba(255,255,255,0.8);
  font-weight: 600;
}

/* Detail body */
.bd-detail-body {
  padding: 16px;
  flex: 1;
}
.bd-detail-section {
  margin-bottom: 20px;
}
.bd-detail-section-title {
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 1.5px;
  text-transform: uppercase;
  color: #9774B5;
  margin-bottom: 8px;
}
.bd-detail-info-row {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  margin-bottom: 10px;
  font-size: 14px;
  color: var(--text-secondary);
}
.bd-detail-info-icon {
  font-size: 16px;
  flex-shrink: 0;
  margin-top: 1px;
}
/* Route section */
.bd-route-card {
  background: rgba(15,15,25,0.6);
  border: 1px solid rgba(151,116,181,0.12);
  border-radius: 12px;
  padding: 14px;
  margin-bottom: 10px;
}
.bd-route-card-header {
  display: flex;
  align-items: center;
  gap: 8px;
  margin-bottom: 8px;
}
.bd-route-card-header .bd-route-icon { font-size: 16px; }
.bd-route-card-header .bd-route-stat {
  font-size: 14px;
  font-weight: 600;
  color: #F4F4BE;
}
.bd-route-desc {
  font-size: 15px;
  line-height: 1.5;
  color: var(--text-secondary);
  margin-bottom: 6px;
}
.bd-route-terrain {
  font-size: 13px;
  color: rgba(244,244,190,0.45);
  line-height: 1.4;
}
.bd-route-collapse.open { max-height: 500px !important; }
.bd-route-permit-pill {
  display: inline-block;
  font-size: 10px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.8px;
  color: #10B981;
  background: rgba(16,185,129,0.1);
  border: 1px solid rgba(16,185,129,0.2);
  border-radius: 8px;
  padding: 2px 8px;
  margin-top: 8px;
}
.bd-route-sourced {
  font-size: 11px;
  color: rgba(244,244,190,0.3);
  margin-top: 6px;
}
.bd-route-maps-link {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  font-size: 12px;
  color: #2dd4bf;
  text-decoration: none;
  margin-top: 4px;
}
.bd-route-maps-link:active { opacity: 0.7; }
.bd-route-map-wrap {
  position: relative;
  margin-top: 10px;
  border-radius: 12px;
  overflow: hidden;
  border: 1px solid rgba(151,116,181,0.12);
}
.bd-route-map-wrap .leaflet-container {
  background: #0f0f19 !important;
  border-radius: 12px;
}
.bd-route-map-wrap .leaflet-control-zoom { display: none; }
.bd-route-map-wrap .leaflet-control-attribution { display: none; }
.bd-route-open-btn {
  position: absolute;
  bottom: 10px;
  right: 10px;
  z-index: 800;
  background: rgba(15,15,25,0.85);
  border: 1px solid rgba(132,207,195,0.25);
  color: #84cfc3;
  font-size: 11px;
  font-weight: 600;
  padding: 5px 10px;
  border-radius: 8px;
  cursor: pointer;
  text-decoration: none;
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
}
.bd-route-open-btn:active { opacity: 0.7; }

/* Organizers */
.bd-organizer-row {
  display: flex;
  align-items: center;
  gap: 8px;
  flex-wrap: wrap;
}
.bd-organizer-avatar {
  width: 72px;
  height: 72px;
  border-radius: 50%;
  border: 2px solid #9774B5;
  object-fit: cover;
}
.bd-organizer-name {
  font-size: 13px;
  font-weight: 600;
  color: var(--text-secondary);
  text-align: center;
  max-width: 96px;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.bd-organizer-slot {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 6px;
}
.bd-claim-btn {
  padding: 10px 20px;
  border-radius: var(--radius-md);
  background: linear-gradient(135deg, #412B51, #5a3d6e);
  border: 1.5px solid rgba(151,116,181,0.6);
  color: #F4F4BE;
  font-weight: 700;
  font-size: 14px;
  cursor: pointer;
  transition: all 0.2s;
  -webkit-tap-highlight-color: transparent;
}
.bd-claim-btn:active { transform: scale(0.96); }
.bd-claim-btn.claimed {
  background: rgba(151,116,181,0.15);
  border-color: rgba(151,116,181,0.3);
  color: #9774B5;
}

/* Register button */
.bd-register-bar {
  position: sticky;
  bottom: 0;
  padding: 12px 16px calc(12px + var(--safe-bottom, 0px));
  background: var(--bg-glass-solid);
  border-top: 1px solid var(--border-glass);
  display: flex;
  gap: 10px;
}
.bd-register-btn {
  flex: 1;
  padding: 14px;
  border-radius: var(--radius-md);
  background: linear-gradient(135deg, #9774B5, #85ACB5);
  border: none;
  color: #fff;
  font-weight: 700;
  font-size: 15px;
  cursor: pointer;
  transition: all 0.2s;
}
.bd-register-btn:active { transform: scale(0.97); }
.bd-register-btn.registered {
  background: rgba(132,207,195,0.15);
  color: var(--cyan);
  border: 1.5px solid rgba(132,207,195,0.3);
}

/* Organizer chat */
.bd-chat-section {
  margin-top: 16px;
  border: 1px solid rgba(151,116,181,0.2);
  border-radius: var(--radius-md);
  overflow: hidden;
}
.bd-chat-header {
  padding: 10px 14px;
  background: rgba(65,43,81,0.2);
  font-size: 12px;
  font-weight: 700;
  color: #9774B5;
  letter-spacing: 1px;
  text-transform: uppercase;
}
.bd-chat-messages {
  max-height: 300px;
  overflow-y: auto;
  padding: 8px 12px;
  -webkit-overflow-scrolling: touch;
}
.bd-chat-msg {
  display: flex;
  gap: 8px;
  margin-bottom: 10px;
}
.bd-chat-msg-avatar {
  width: 28px;
  height: 28px;
  border-radius: 50%;
  flex-shrink: 0;
  object-fit: cover;
}
.bd-chat-msg-name {
  font-size: 11px;
  font-weight: 600;
  color: #9774B5;
  margin-bottom: 1px;
}
.bd-chat-msg-text {
  font-size: 13px;
  color: var(--text-secondary);
  line-height: 1.4;
}
.bd-chat-msg-time {
  font-size: 10px;
  color: var(--text-dim);
  margin-top: 2px;
}
.bd-chat-input-bar {
  display: flex;
  gap: 8px;
  padding: 8px 12px;
  border-top: 1px solid rgba(151,116,181,0.15);
}
.bd-chat-input {
  flex: 1;
  padding: 8px 12px;
  background: rgba(255,255,255,0.06);
  border: 1px solid var(--border-glass);
  border-radius: 20px;
  color: var(--text-primary);
  font-size: 13px;
  outline: none;
}
.bd-chat-input::placeholder { color: var(--text-dim); }
.bd-chat-send {
  width: 32px;
  height: 32px;
  border-radius: 50%;
  background: linear-gradient(135deg, #412B51, #5a3d6e);
  border: none;
  color: #F4F4BE;
  font-size: 14px;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
}

/* Edit sheet */
.bd-edit-sheet {
  position: fixed;
  left: 0; right: 0; bottom: 0;
  z-index: 100002;
  background: var(--bg-deep);
  border-radius: 16px 16px 0 0;
  border-top: 1px solid rgba(151,116,181,0.3);
  max-height: 85vh;
  max-height: 85dvh;
  overflow-y: auto;
  transform: translateY(100%);
  transition: transform 0.35s cubic-bezier(0.4,0,0.2,1);
  pointer-events: none;
  padding-bottom: calc(80px + var(--safe-bottom, 0px));
}
.bd-edit-sheet.visible { transform: translateY(0); pointer-events: auto; }
.bd-edit-sheet-handle {
  width: 40px;
  height: 4px;
  border-radius: 2px;
  background: rgba(255,255,255,0.2);
  margin: 10px auto 16px;
}
.bd-edit-sheet-title {
  font-size: 17px;
  font-weight: 700;
  color: var(--text-primary);
  padding: 0 16px 12px;
}
.bd-edit-field {
  padding: 0 16px;
  margin-bottom: 14px;
}
.bd-edit-field label {
  display: block;
  font-size: 12px;
  font-weight: 600;
  color: var(--text-secondary);
  margin-bottom: 4px;
  text-transform: uppercase;
  letter-spacing: 0.5px;
}
.bd-edit-field input,
.bd-edit-field textarea {
  width: 100%;
  padding: 10px 12px;
  background: rgba(255,255,255,0.06);
  border: 1px solid var(--border-glass);
  border-radius: var(--radius-md);
  color: var(--text-primary);
  font-size: 14px;
  outline: none;
}
.bd-edit-field textarea { height: 80px; resize: none; }
.bd-edit-field input:focus,
.bd-edit-field textarea:focus { border-color: #9774B5; }
.bd-edit-save-btn {
  position: sticky;
  bottom: 0;
  z-index: 2;
  margin: 8px 16px;
  width: calc(100% - 32px);
  padding: 14px;
  border-radius: var(--radius-md);
  background: linear-gradient(135deg, #9774B5, #85ACB5);
  border: none;
  color: #fff;
  font-weight: 700;
  font-size: 15px;
  cursor: pointer;
}
.bd-edit-overlay-bg {
  position: fixed;
  inset: 0;
  z-index: 100001;
  background: rgba(0,0,0,0.5);
  opacity: 0;
  visibility: hidden;
  transition: all 0.3s;
}
.bd-edit-overlay-bg.visible { opacity: 1; visibility: visible; }

/* BD Success Sheet */
.bd-success-overlay {
  position: fixed;
  inset: 0;
  z-index: 100004;
  background: rgba(0,0,0,0.7);
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
  transition: all 0.3s;
}
.bd-success-overlay.visible { opacity: 1; visibility: visible; pointer-events: auto; }
.bd-success-sheet {
  position: fixed;
  left: 0; right: 0; bottom: 0;
  z-index: 100005;
  background: var(--bg-deep);
  border-radius: 20px 20px 0 0;
  border-top: 1px solid rgba(151,116,181,0.3);
  max-height: 70vh;
  padding: 20px 20px calc(env(safe-area-inset-bottom, 0px) + 16px);
  transform: translateY(100%);
  transition: transform 0.35s cubic-bezier(0.4,0,0.2,1);
  pointer-events: none;
  text-align: center;
}
.bd-success-sheet.visible { transform: translateY(0); pointer-events: auto; }
.bd-success-header { margin-bottom: 16px; }
.bd-success-title {
  font-size: 22px;
  font-weight: 800;
  color: var(--text);
  margin: 8px 0 4px;
}
.bd-success-sub {
  font-size: 14px;
  color: var(--text-dim);
}
.bd-success-riders {
  display: flex;
  gap: 12px;
  overflow-x: auto;
  padding: 12px 0;
  justify-content: center;
  -webkit-overflow-scrolling: touch;
}
.bd-success-riders::-webkit-scrollbar { display: none; }
.bd-success-rider-av {
  width: 64px;
  height: 64px;
  border-radius: 50%;
  object-fit: cover;
  border: 2px solid rgba(151,116,181,0.4);
  flex-shrink: 0;
}
.bd-success-actions {
  display: flex;
  gap: 10px;
  margin: 12px 0;
}
.bd-success-actions button {
  flex: 1;
  padding: 12px 8px;
  border-radius: 12px;
  border: 1px solid rgba(151,116,181,0.3);
  background: rgba(151,116,181,0.1);
  color: var(--text);
  font-size: 14px;
  font-weight: 600;
  cursor: pointer;
}
.bd-success-done {
  width: 100%;
  padding: 14px;
  border-radius: 14px;
  border: none;
  background: var(--accent);
  color: #252525;
  font-weight: 700;
  font-size: 15px;
  cursor: pointer;
  margin-top: 4px;
}

/* BD Rider List Overlay */
.bd-rider-list-overlay {
  position: fixed;
  inset: 0;
  z-index: 100007;
  background: #252525;
  transform: translateX(100%);
  transition: transform 0.3s cubic-bezier(0.4,0,0.2,1);
  display: flex;
  flex-direction: column;
  pointer-events: none;
}
.bd-rider-list-overlay.visible { transform: translateX(0); pointer-events: auto; }
.bd-rider-list-header {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 16px;
  padding-top: calc(16px + var(--safe-top, 0px));
  border-bottom: 1px solid rgba(132,207,195,0.1);
  background: #252525;
  flex-shrink: 0;
}
.bd-rider-list-header button {
  background: none;
  border: none;
  color: var(--text);
  font-size: 22px;
  cursor: pointer;
  padding: 4px 8px;
}
.bd-rider-list-header span {
  font-size: 17px;
  font-weight: 700;
  color: var(--text);
}
.bd-rider-list-body {
  flex: 1;
  overflow-y: auto;
  padding: 8px 16px;
  -webkit-overflow-scrolling: touch;
}
.bd-rider-item {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 12px 0;
  border-bottom: 1px solid rgba(132,207,195,0.06);
  cursor: pointer;
}
.bd-rider-item-avatar {
  width: 40px;
  height: 40px;
  border-radius: 50%;
  object-fit: cover;
  flex-shrink: 0;
}
.bd-rider-item-info { flex: 1; min-width: 0; }
.bd-rider-item-name {
  font-size: 15px;
  font-weight: 600;
  color: var(--text);
}
.bd-rider-item-time {
  font-size: 12px;
  color: var(--text-dim);
  margin-top: 2px;
}

/* BD Chat Tabs */
.bd-chat-tabs {
  display: flex;
  gap: 0;
  margin-bottom: 8px;
  border-radius: 10px;
  overflow: hidden;
  border: 1px solid rgba(151,116,181,0.2);
}
.bd-chat-tab {
  flex: 1;
  padding: 10px;
  text-align: center;
  font-size: 13px;
  font-weight: 600;
  color: var(--text-dim);
  background: transparent;
  border: none;
  cursor: pointer;
  transition: all 0.2s;
}
.bd-chat-tab.active {
  background: rgba(151,116,181,0.2);
  color: var(--text);
}

/* BD Share Card Preview */
.bd-share-card-preview {
  margin: 16px 0;
  border-radius: 12px;
  overflow: hidden;
  position: relative;
  background: #1a0a2e;
}
.bd-share-card-preview canvas {
  width: 100%;
  display: block;
}
.bd-share-actions {
  display: flex;
  gap: 8px;
  margin-top: 12px;
}
.bd-share-actions button {
  flex: 1;
  padding: 12px;
  border-radius: 12px;
  border: 1px solid rgba(132,207,195,0.2);
  background: rgba(132,207,195,0.08);
  color: var(--cyan);
  font-size: 13px;
  font-weight: 600;
  cursor: pointer;
}
.bd-share-actions button.primary {
  background: linear-gradient(135deg, var(--cyan), var(--green, #84cfc3));
  color: #252525;
  border: none;
}
.bd-share-card-toggle {
  display: flex;
  align-items: center;
  gap: 8px;
  justify-content: center;
  margin-top: 8px;
  font-size: 12px;
  color: var(--text-dim);
}
.bd-share-card-toggle input[type="checkbox"] {
  accent-color: var(--cyan);
}
/* BD Invite Link Row */
.bd-invite-link-row {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 10px 14px;
  background: rgba(132,207,195,0.06);
  border: 1px solid rgba(132,207,195,0.12);
  border-radius: 10px;
  margin: 8px 0;
}
.bd-invite-link-row code {
  flex: 1;
  font-size: 12px;
  color: var(--cyan);
  word-break: break-all;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.bd-invite-link-row button {
  padding: 6px 12px;
  border-radius: 8px;
  border: none;
  background: var(--cyan);
  color: #252525;
  font-size: 12px;
  font-weight: 600;
  cursor: pointer;
  white-space: nowrap;
}
.bd-invite-referral-count {
  font-size: 12px;
  color: var(--text-dim);
  margin-top: 4px;
}
/* BD Progress Milestone */
.bd-progress-milestone {
  margin: 12px 0 8px;
}
.bd-progress-bar {
  height: 4px;
  background: rgba(255,255,255,0.06);
  border-radius: 2px;
  overflow: hidden;
}
.bd-progress-fill {
  height: 100%;
  background: linear-gradient(90deg, var(--cyan), var(--magenta));
  border-radius: 2px;
  transition: width 0.6s cubic-bezier(0.16,1,0.3,1);
}
.bd-progress-label {
  font-size: 11px;
  color: var(--text-dim);
  margin-top: 4px;
  text-align: center;
}
/* BD Circle Share Sheet */
.bd-circle-share-overlay {
  position: fixed;
  inset: 0;
  z-index: 250000;
  background: rgba(0,0,0,0.6);
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
  transition: all 0.3s;
}
.bd-circle-share-overlay.visible { opacity: 1; visibility: visible; pointer-events: auto; }
.bd-circle-share-sheet {
  position: fixed;
  left: 0; right: 0; bottom: 0;
  z-index: 250001;
  background: rgba(30,28,28,0.98);
  border-top: 1px solid rgba(132,207,195,0.15);
  border-radius: 20px 20px 0 0;
  padding: 20px 16px calc(20px + var(--safe-bottom));
  max-height: 60vh;
  overflow-y: auto;
  transform: translateY(100%);
  transition: transform 0.35s cubic-bezier(0.16,1,0.3,1);
  pointer-events: none;
}
.bd-circle-share-sheet.visible { transform: translateY(0); pointer-events: auto; }
.bd-circle-share-title {
  font-size: 16px;
  font-weight: 700;
  color: var(--warm-white);
  margin-bottom: 16px;
  text-align: center;
}
.bd-circle-share-item {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 12px;
  border-radius: 12px;
  cursor: pointer;
  transition: background 0.2s;
}
.bd-circle-share-item:active { background: rgba(132,207,195,0.08); }
.bd-circle-share-item img {
  width: 40px; height: 40px;
  border-radius: 50%;
  object-fit: cover;
}
.bd-circle-share-item-name {
  flex: 1;
  font-size: 14px;
  font-weight: 600;
  color: var(--warm-white);
}
.bd-circle-share-item-count {
  font-size: 12px;
  color: var(--text-dim);
}
.bd-circle-share-item-sent {
  font-size: 12px;
  color: var(--cyan);
  font-weight: 600;
}
/* BD Profile Badge */
.bd-profile-badge {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  padding: 3px 10px;
  border-radius: 20px;
  background: linear-gradient(135deg, rgba(151,116,181,0.2), rgba(132,207,195,0.15));
  border: 1px solid rgba(151,116,181,0.25);
  font-size: 11px;
  font-weight: 600;
  color: var(--cyan);
  margin-top: 6px;
}
/* BD City Count Badge (landing page marquee) */
.bd-city-count-badge {
  font-size: 11px;
  color: var(--text-dim);
  margin-left: 4px;
}
/* BD Share Card Overlay */
.bd-share-overlay {
  position: fixed;
  inset: 0;
  z-index: 300000;
  background: rgba(0,0,0,0.8);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  padding: 20px;
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
  transition: all 0.3s;
}
.bd-share-overlay.visible { opacity: 1; visibility: visible; pointer-events: auto; }

/* BD Organizer Onboarding Sheet */
.bd-onboarding-overlay {
  position: fixed;
  inset: 0;
  z-index: 100005;
  background: rgba(0,0,0,0.7);
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
  transition: all 0.3s;
}
.bd-onboarding-overlay.visible { opacity: 1; visibility: visible; pointer-events: auto; }
.bd-onboarding-sheet {
  position: fixed;
  left: 0; right: 0; bottom: 0;
  z-index: 100006;
  background: var(--bg-deep);
  border-radius: 20px 20px 0 0;
  border-top: 1px solid rgba(151,116,181,0.3);
  max-height: 85vh;
  overflow-y: auto;
  transform: translateY(100%);
  transition: transform 0.35s cubic-bezier(0.4,0,0.2,1);
  pointer-events: none;
  padding: 16px 16px calc(env(safe-area-inset-bottom, 0px) + 16px);
}
.bd-onboarding-sheet.visible { transform: translateY(0); pointer-events: auto; }
.bd-onboarding-sheet::-webkit-scrollbar { display: none; }
.bd-onboarding-header {
  text-align: center;
  margin-bottom: 12px;
}
.bd-onboarding-title {
  font-size: 20px;
  font-weight: 800;
  color: var(--text);
  margin: 6px 0 4px;
}
.bd-onboarding-sub {
  font-size: 13px;
  color: var(--text-dim);
}
.bd-progress-bar {
  height: 4px;
  background: rgba(255,255,255,0.08);
  border-radius: 2px;
  margin: 12px 0 16px;
  overflow: hidden;
}
.bd-progress-bar-fill {
  height: 100%;
  background: linear-gradient(90deg, var(--accent), #85ACB5);
  border-radius: 2px;
  transition: width 0.4s ease;
}
.bd-progress-text {
  font-size: 12px;
  font-weight: 600;
  color: var(--text-dim);
  margin-bottom: 4px;
}
.bd-checklist-item {
  display: flex;
  align-items: flex-start;
  gap: 12px;
  padding: 14px 12px;
  border-radius: 12px;
  background: rgba(255,255,255,0.03);
  border: 1px solid rgba(151,116,181,0.12);
  margin-bottom: 8px;
  cursor: pointer;
  transition: all 0.2s;
}
.bd-checklist-item:active { transform: scale(0.98); }
.bd-checklist-item.completed {
  opacity: 0.5;
  border-color: rgba(132,207,195,0.2);
}
.bd-checklist-check {
  width: 24px;
  height: 24px;
  border-radius: 50%;
  border: 2px solid rgba(151,116,181,0.3);
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  font-size: 13px;
  margin-top: 2px;
  transition: all 0.2s;
}
.bd-checklist-item.completed .bd-checklist-check {
  background: var(--accent);
  border-color: var(--accent);
  color: #252525;
}
.bd-checklist-content { flex: 1; min-width: 0; }
.bd-checklist-label {
  font-size: 14px;
  font-weight: 600;
  color: var(--text);
}
.bd-checklist-item.completed .bd-checklist-label {
  text-decoration: line-through;
  color: var(--text-dim);
}
.bd-checklist-desc {
  font-size: 12px;
  color: var(--text-dim);
  margin-top: 3px;
  line-height: 1.4;
}
.bd-checklist-arrow {
  color: var(--text-dim);
  font-size: 16px;
  flex-shrink: 0;
  margin-top: 4px;
}
.bd-onboarding-guide-link {
  display: block;
  text-align: center;
  font-size: 14px;
  font-weight: 600;
  color: #85ACB5;
  padding: 12px 0 4px;
  cursor: pointer;
}
.bd-onboarding-dismiss {
  width: 100%;
  padding: 14px;
  border-radius: 14px;
  border: none;
  background: linear-gradient(135deg, #9774B5, #85ACB5);
  color: #fff;
  font-weight: 700;
  font-size: 15px;
  cursor: pointer;
  margin-top: 12px;
}

/* BD Checklist Widget (compact, in city detail) */
.bd-checklist-widget {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 10px 14px;
  border-radius: 10px;
  background: rgba(151,116,181,0.08);
  border: 1px solid rgba(151,116,181,0.15);
  cursor: pointer;
  margin-bottom: 12px;
  transition: all 0.2s;
}
.bd-checklist-widget:active { transform: scale(0.98); }
.bd-checklist-widget-left {
  display: flex;
  align-items: center;
  gap: 8px;
}
.bd-checklist-widget-progress {
  width: 60px;
  height: 4px;
  background: rgba(255,255,255,0.08);
  border-radius: 2px;
  overflow: hidden;
}
.bd-checklist-widget-fill {
  height: 100%;
  background: var(--accent);
  border-radius: 2px;
  transition: width 0.3s;
}
.bd-checklist-widget-text {
  font-size: 13px;
  font-weight: 600;
  color: var(--text-dim);
}
.bd-checklist-widget-arrow {
  color: var(--text-dim);
  font-size: 14px;
}

/* BD Organizer Guide Overlay */
.bd-org-guide-overlay {
  position: fixed;
  inset: 0;
  z-index: 100008;
  background: #252525;
  transform: translateX(100%);
  transition: transform 0.3s cubic-bezier(0.4,0,0.2,1);
  display: flex;
  flex-direction: column;
  pointer-events: none;
}
.bd-org-guide-overlay.visible { transform: translateX(0); pointer-events: auto; }
.bd-org-guide-header {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 16px;
  padding-top: calc(16px + var(--safe-top, 0px));
  border-bottom: 1px solid rgba(151,116,181,0.1);
  background: #252525;
  flex-shrink: 0;
}
.bd-org-guide-header button {
  background: none;
  border: none;
  color: var(--text);
  font-size: 22px;
  cursor: pointer;
  padding: 4px 8px;
}
.bd-org-guide-header span {
  font-size: 17px;
  font-weight: 700;
  color: var(--text);
}
.bd-org-guide-body {
  flex: 1;
  overflow-y: auto;
  padding: 20px 16px 40px;
  -webkit-overflow-scrolling: touch;
}
.bd-org-guide-body::-webkit-scrollbar { display: none; }
.bd-org-guide-section {
  margin-bottom: 28px;
}
.bd-org-guide-section h3 {
  font-size: 16px;
  font-weight: 700;
  color: var(--text);
  margin: 0 0 8px;
}
.bd-org-guide-section p {
  font-size: 14px;
  line-height: 1.6;
  color: var(--text-secondary);
  margin: 0;
}

/* BD Organizer Playbook */
.bd-playbook-overlay {
  position: fixed;
  inset: 0;
  z-index: 100009;
  background: #252525;
  transform: translateX(100%);
  transition: transform 0.3s cubic-bezier(0.4,0,0.2,1);
  display: flex;
  flex-direction: column;
  pointer-events: none;
}
.bd-playbook-overlay.visible { transform: translateX(0); pointer-events: auto; }
.bd-playbook-header {
  display: flex;
  align-items: center;
  padding: 16px;
  padding-top: calc(16px + var(--safe-top, 0px));
  border-bottom: 1px solid rgba(151,116,181,0.1);
  background: #252525;
  flex-shrink: 0;
}
.bd-playbook-header button {
  background: none;
  border: none;
  color: var(--text);
  font-size: 22px;
  cursor: pointer;
  padding: 4px 8px;
}
.bd-playbook-header-title {
  flex: 1;
  text-align: center;
  font-size: 14px;
  font-weight: 700;
  color: var(--text);
  letter-spacing: 1.5px;
  text-transform: uppercase;
}
.bd-playbook-header .bd-playbook-share-btn {
  font-size: 16px;
  color: var(--cyan);
}
.bd-playbook-body {
  flex: 1;
  overflow-y: auto;
  padding: 24px 16px calc(env(safe-area-inset-bottom, 0px) + 40px);
  -webkit-overflow-scrolling: touch;
}
.bd-playbook-body::-webkit-scrollbar { display: none; }
.bd-playbook-frame-label {
  font-size: 11px;
  font-weight: 700;
  color: var(--cyan);
  letter-spacing: 2px;
  text-transform: uppercase;
  margin-bottom: 8px;
}
.bd-playbook-frame-body {
  font-size: 14px;
  line-height: 1.7;
  color: var(--text-dim);
  margin-bottom: 32px;
}
.bd-playbook-card {
  background: rgba(255,255,255,0.03);
  border: 1px solid rgba(151,116,181,0.1);
  border-radius: 14px;
  padding: 18px;
  margin-bottom: 16px;
}
.bd-playbook-card-amber {
  background: rgba(251,191,36,0.08);
  border-left: 3px solid #f59e0b;
  border-color: rgba(245,158,11,0.2);
}
.bd-playbook-card-cyan {
  background: rgba(132,207,195,0.06);
  border: 1px solid rgba(132,207,195,0.15);
}
.bd-playbook-card-purple {
  background: rgba(151,116,181,0.06);
  border: 1px solid rgba(151,116,181,0.15);
}
.bd-playbook-card-title {
  font-size: 15px;
  font-weight: 700;
  color: var(--text);
  margin-bottom: 10px;
}
.bd-playbook-card-body {
  font-size: 13.5px;
  line-height: 1.7;
  color: var(--text-secondary);
}
.bd-playbook-card-body ul {
  margin: 10px 0 0;
  padding-left: 18px;
}
.bd-playbook-card-body ul li {
  margin-bottom: 6px;
  line-height: 1.6;
}
.bd-playbook-section-title {
  font-size: 16px;
  font-weight: 700;
  color: var(--text);
  margin: 28px 0 12px;
}
.bd-playbook-progress-note {
  font-size: 12px;
  color: var(--text-dim);
  margin-bottom: 12px;
}
.bd-playbook-checklist-group-label {
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 1.5px;
  text-transform: uppercase;
  color: var(--text-dim);
  margin: 16px 0 8px;
}
.bd-playbook-check-item {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  padding: 10px 0;
  cursor: pointer;
  border-bottom: 1px solid rgba(255,255,255,0.04);
}
.bd-playbook-check-item:last-child { border-bottom: none; }
.bd-playbook-check-box {
  width: 22px;
  height: 22px;
  border-radius: 6px;
  border: 2px solid rgba(255,255,255,0.15);
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  font-size: 13px;
  color: var(--cyan);
  transition: all 0.2s;
  margin-top: 1px;
}
.bd-playbook-check-item.checked .bd-playbook-check-box {
  border-color: var(--cyan);
  background: rgba(132,207,195,0.12);
}
.bd-playbook-check-item.checked .bd-playbook-check-label {
  color: var(--text-dim);
}
.bd-playbook-check-label {
  font-size: 14px;
  line-height: 1.5;
  color: var(--text);
}
.bd-playbook-check-label .pb-tap-link {
  color: var(--cyan);
  opacity: 0.7;
  font-size: 12px;
  margin-left: 4px;
}
.bd-playbook-expand-card {
  background: rgba(255,255,255,0.03);
  border: 1px solid rgba(151,116,181,0.1);
  border-radius: 12px;
  margin-bottom: 8px;
  overflow: hidden;
}
.bd-playbook-expand-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 14px 16px;
  cursor: pointer;
  font-size: 14px;
  font-weight: 600;
  color: var(--text);
}
.bd-playbook-expand-arrow {
  font-size: 12px;
  color: var(--text-dim);
  transition: transform 0.3s;
}
.bd-playbook-expand-card.open .bd-playbook-expand-arrow {
  transform: rotate(180deg);
}
.bd-playbook-expand-content {
  max-height: 0;
  overflow: hidden;
  transition: max-height 0.3s ease-in-out;
}
.bd-playbook-expand-card.open .bd-playbook-expand-content {
  max-height: 600px;
}
.bd-playbook-expand-inner {
  padding: 0 16px 16px;
  font-size: 13.5px;
  line-height: 1.7;
  color: var(--text-secondary);
}
.bd-playbook-caption-box {
  background: rgba(0,0,0,0.3);
  border: 1px solid rgba(132,207,195,0.15);
  border-radius: 10px;
  padding: 14px 16px;
  font-family: 'Inter', monospace;
  font-size: 13.5px;
  line-height: 1.6;
  color: var(--text);
  white-space: pre-wrap;
  margin: 12px 0;
}
.bd-playbook-cause-pills {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  margin: 10px 0;
}
.bd-playbook-cause-pill {
  padding: 6px 12px;
  border-radius: 20px;
  font-size: 12px;
  border: 1px solid rgba(132,207,195,0.2);
  color: var(--cyan);
  background: rgba(132,207,195,0.06);
  cursor: pointer;
  transition: all 0.2s;
}
.bd-playbook-cause-pill.active {
  background: rgba(132,207,195,0.15);
  border-color: var(--cyan);
}
.bd-playbook-editable-field {
  display: inline;
  color: var(--cyan);
  border-bottom: 1px dashed rgba(132,207,195,0.4);
  cursor: pointer;
  padding: 0 2px;
}
.bd-playbook-press-field {
  display: inline;
  color: var(--lavender);
  border-bottom: 1px dashed rgba(151,116,181,0.4);
  cursor: pointer;
  padding: 0 2px;
  min-width: 40px;
}
.bd-playbook-press-field:empty::before {
  content: attr(data-placeholder);
  opacity: 0.5;
}
.bd-playbook-btn {
  width: 100%;
  padding: 13px;
  border-radius: 12px;
  font-size: 14px;
  font-weight: 600;
  cursor: pointer;
  border: none;
  margin-top: 12px;
  transition: opacity 0.2s;
}
.bd-playbook-btn:active { opacity: 0.7; }
.bd-playbook-btn-cyan {
  background: var(--cyan);
  color: #252525;
}
.bd-playbook-btn-purple {
  background: transparent;
  border: 1px solid rgba(151,116,181,0.3);
  color: var(--lavender);
}
.bd-playbook-safety-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 12px;
  margin-top: 12px;
}
@media (max-width: 380px) {
  .bd-playbook-safety-grid { grid-template-columns: 1fr; }
}
.bd-playbook-safety-col h4 {
  font-size: 13px;
  font-weight: 700;
  color: var(--text);
  margin: 0 0 8px;
}
.bd-playbook-safety-col ul {
  list-style: none;
  padding: 0;
  margin: 0;
}
.bd-playbook-safety-col ul li {
  font-size: 12.5px;
  line-height: 1.6;
  color: var(--text-secondary);
  padding: 3px 0;
  padding-left: 12px;
  position: relative;
}
.bd-playbook-safety-col ul li::before {
  content: '·';
  position: absolute;
  left: 0;
  color: var(--text-dim);
}
.bd-playbook-bottom-buttons {
  display: flex;
  gap: 8px;
  margin-top: 16px;
}
.bd-playbook-bottom-buttons button {
  flex: 1;
  padding: 12px;
  border-radius: 12px;
  font-size: 13px;
  font-weight: 600;
  cursor: pointer;
  border: 1px solid rgba(132,207,195,0.2);
  background: rgba(132,207,195,0.06);
  color: var(--cyan);
}
.bd-playbook-bottom-buttons button:active { opacity: 0.7; }
.bd-playbook-muted-tip {
  font-size: 12px;
  color: var(--text-dim);
  margin-top: 10px;
  line-height: 1.5;
}
.bd-playbook-sendoff-overlay {
  position: fixed;
  inset: 0;
  z-index: 100010;
  background: rgba(0,0,0,0.7);
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
  display: flex;
  align-items: flex-end;
  justify-content: center;
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
  transition: all 0.3s;
}
.bd-playbook-sendoff-overlay.visible { opacity: 1; visibility: visible; pointer-events: auto; }
.bd-playbook-sendoff-sheet {
  width: 100%;
  max-height: 80vh;
  overflow-y: auto;
  background: var(--bg-deep);
  border-radius: 20px 20px 0 0;
  border-top: 1px solid rgba(151,116,181,0.2);
  padding: 24px 20px calc(env(safe-area-inset-bottom, 0px) + 20px);
  transform: translateY(100%);
  transition: transform 0.35s cubic-bezier(0.4,0,0.2,1);
}
.bd-playbook-sendoff-overlay.visible .bd-playbook-sendoff-sheet {
  transform: translateY(0);
}
.bd-playbook-sendoff-title {
  font-size: 17px;
  font-weight: 700;
  color: var(--text);
  margin-bottom: 16px;
  text-align: center;
}
.bd-playbook-sendoff-prompt {
  padding: 12px 0;
  border-bottom: 1px solid rgba(255,255,255,0.04);
}
.bd-playbook-sendoff-num {
  font-size: 11px;
  font-weight: 700;
  color: var(--cyan);
  opacity: 0.6;
  margin-bottom: 4px;
}
.bd-playbook-sendoff-text {
  font-size: 14px;
  line-height: 1.7;
  color: var(--text-secondary);
  font-style: italic;
}
.bd-playbook-sendoff-note {
  font-size: 12px;
  color: var(--text-dim);
  margin-top: 16px;
  line-height: 1.5;
  text-align: center;
}

/* BD Inactivity Banner */
.bd-inactivity-banner {
  padding: 10px 14px;
  border-radius: 10px;
  background: rgba(255,180,70,0.08);
  border: 1px solid rgba(255,180,70,0.2);
  margin-bottom: 12px;
  font-size: 13px;
  color: #FFB446;
  line-height: 1.4;
}

/* Waiver sheet */
.bd-waiver-overlay {
  position: fixed;
  inset: 0;
  z-index: 100003;
  background: rgba(0,0,0,0.7);
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
  transition: all 0.3s;
}
.bd-waiver-overlay.visible { opacity: 1; visibility: visible; pointer-events: auto; }
.bd-waiver-sheet {
  position: fixed;
  left: 0; right: 0; bottom: 0;
  z-index: 100004;
  background: var(--bg-deep);
  border-radius: 16px 16px 0 0;
  border-top: 1px solid rgba(151,116,181,0.3);
  max-height: 92vh;
  display: flex;
  flex-direction: column;
  transform: translateY(100%);
  transition: transform 0.35s cubic-bezier(0.4,0,0.2,1);
  pointer-events: none;
}
.bd-waiver-sheet.visible { transform: translateY(0); pointer-events: auto; }
.bd-waiver-handle {
  width: 40px;
  height: 4px;
  border-radius: 2px;
  background: rgba(255,255,255,0.2);
  margin: 10px auto 0;
  flex-shrink: 0;
}
.bd-waiver-platform-note {
  padding: 12px 16px 0;
  font-size: 11px;
  color: #85ACB5;
  line-height: 1.5;
  flex-shrink: 0;
}
.bd-waiver-title {
  padding: 12px 16px 8px;
  font-size: 15px;
  font-weight: 700;
  color: var(--text-primary);
  text-align: center;
  flex-shrink: 0;
}
.bd-waiver-subtitle {
  padding: 0 16px 12px;
  font-size: 12px;
  color: var(--text-dim);
  text-align: center;
  flex-shrink: 0;
}
.bd-waiver-scroll {
  flex: 1;
  overflow-y: auto;
  -webkit-overflow-scrolling: touch;
  padding: 0 16px 12px;
  font-size: 12px;
  color: var(--text-secondary);
  line-height: 1.7;
  max-height: 40vh;
}
.bd-waiver-scroll strong {
  color: var(--text-primary);
  display: block;
  margin-top: 14px;
  margin-bottom: 4px;
}
.bd-waiver-bottom {
  padding: 12px 16px calc(12px + var(--safe-bottom, 0px));
  border-top: 1px solid var(--border-glass);
  flex-shrink: 0;
}
.bd-waiver-check {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  margin-bottom: 12px;
  cursor: pointer;
}
.bd-waiver-check input[type="checkbox"] {
  width: 20px;
  height: 20px;
  margin-top: 1px;
  accent-color: #85ACB5;
  flex-shrink: 0;
}
.bd-waiver-check label {
  font-size: 13px;
  color: var(--text-secondary);
  line-height: 1.4;
  cursor: pointer;
}
.bd-waiver-name-input {
  width: 100%;
  padding: 10px 12px;
  background: rgba(255,255,255,0.06);
  border: 1px solid var(--border-glass);
  border-radius: var(--radius-md);
  color: var(--text-primary);
  font-size: 14px;
  outline: none;
  margin-bottom: 12px;
}
.bd-waiver-name-input::placeholder { color: var(--text-dim); }
.bd-waiver-name-input:focus { border-color: #85ACB5; }
.bd-waiver-confirm-btn {
  width: 100%;
  padding: 14px;
  border-radius: var(--radius-md);
  background: linear-gradient(135deg, #9774B5, #85ACB5);
  border: none;
  color: #fff;
  font-weight: 700;
  font-size: 15px;
  cursor: pointer;
  transition: opacity 0.2s;
}
.bd-waiver-confirm-btn:disabled {
  opacity: 0.35;
  cursor: not-allowed;
}

/* ── RIDE REGISTRATION MODAL ── */
.ride-registration-modal {
  position: fixed;
  inset: 0;
  z-index: 100001;
  background: #252525;
  transform: translateY(100%);
  transition: transform 0.35s cubic-bezier(0.4,0,0.2,1);
  display: flex;
  flex-direction: column;
  overflow: hidden;
  pointer-events: none;
}
.ride-registration-modal.visible { transform: translateY(0); pointer-events: auto; }
.ride-registration-header {
  display: flex;
  align-items: center;
  padding: 16px;
  gap: 12px;
  border-bottom: 1px solid var(--border-glass);
  flex-shrink: 0;
}
.ride-registration-header .chat-back { cursor: pointer; font-size: 20px; }
.ride-registration-header .chat-title {
  font-size: 17px;
  font-weight: 700;
  flex: 1;
}
.ride-registration-body {
  flex: 1;
  overflow-y: auto;
  padding: 20px 16px calc(20px + var(--safe-bottom));
  -webkit-overflow-scrolling: touch;
}
.ride-reg-hero {
  text-align: center;
  padding: 20px 0;
  margin-bottom: 20px;
  position: relative;
}
.ride-reg-hero-icon {
  font-size: 48px;
  margin-bottom: 12px;
  display: block;
}
.ride-reg-hero-title {
  font-size: 22px;
  font-weight: 800;
  background: linear-gradient(135deg, #9774B5, #85ACB5, #E28861);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  margin-bottom: 6px;
}
.ride-reg-hero-sub {
  font-size: 13px;
  color: var(--text-secondary);
  line-height: 1.5;
}
.ride-reg-field {
  margin-bottom: 16px;
}
.ride-reg-field label {
  display: block;
  font-size: 13px;
  font-weight: 600;
  color: var(--text-secondary);
  margin-bottom: 6px;
  letter-spacing: 0.3px;
}
.ride-reg-field input, .ride-reg-field textarea {
  width: 100%;
  padding: 12px 14px;
  border-radius: 12px;
  border: 1px solid var(--border-glass);
  background: var(--bg-card);
  color: var(--text-primary);
  font-size: 15px;
  font-family: inherit;
  outline: none;
  transition: border-color 0.2s;
  box-sizing: border-box;
}
.ride-reg-field input:focus, .ride-reg-field textarea:focus {
  border-color: #9774B5;
}
.ride-reg-waiver {
  background: rgba(65,43,81,0.08);
  border: 1px solid rgba(151,116,181,0.2);
  border-radius: 14px;
  padding: 16px;
  margin: 20px 0;
}
.ride-reg-waiver-title {
  font-size: 14px;
  font-weight: 700;
  color: #9774B5;
  margin-bottom: 8px;
}
.ride-reg-waiver-text {
  font-size: 12px;
  color: var(--text-secondary);
  line-height: 1.6;
  max-height: 120px;
  overflow-y: auto;
  margin-bottom: 12px;
  padding-right: 8px;
}
.ride-reg-waiver-check {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  cursor: pointer;
  /* Expand tap target — the whole row is the target, not just the 20px box. */
  min-height: 44px;
  padding: 8px 4px;
  margin: -8px -4px;
  border-radius: 8px;
  -webkit-tap-highlight-color: transparent;
}
.ride-reg-waiver-check input[type="checkbox"] {
  width: 22px;
  height: 22px;
  accent-color: #9774B5;
  flex-shrink: 0;
  margin-top: 2px;
}
.ride-reg-waiver-check span {
  font-size: 13px;
  color: var(--text-primary);
  line-height: 1.4;
}
.ride-reg-submit {
  width: 100%;
  padding: 16px;
  border-radius: 14px;
  border: none;
  background: linear-gradient(135deg, #412B51, #9774B5);
  color: #F4F4BE;
  font-size: 16px;
  font-weight: 700;
  cursor: pointer;
  transition: all 0.2s;
  margin-top: 8px;
}
.ride-reg-submit:disabled {
  opacity: 0.4;
  cursor: default;
}
.ride-reg-submit:not(:disabled):active {
  transform: scale(0.97);
}
.ride-reg-success {
  text-align: center;
  padding: 40px 20px;
}
.ride-reg-success-icon { font-size: 56px; margin-bottom: 16px; display: block; }
.ride-reg-success-title {
  font-size: 20px;
  font-weight: 800;
  color: var(--text-primary);
  margin-bottom: 8px;
}
.ride-reg-success-sub {
  font-size: 14px;
  color: var(--text-secondary);
  line-height: 1.5;
  margin-bottom: 24px;
}
.ride-reg-msg {
  text-align: center;
  font-size: 13px;
  margin-top: 8px;
  min-height: 20px;
}
.ride-reg-msg.error { color: #ff6b6b; }
.ride-reg-msg.success { color: #84cfc3; }

/* Register to Ride button in event detail */
.event-register-ride-btn {
  display: block;
  width: 100%;
  padding: 14px;
  border-radius: 14px;
  border: none;
  background: linear-gradient(135deg, #412B51, #9774B5);
  color: #F4F4BE;
  font-size: 15px;
  font-weight: 700;
  cursor: pointer;
  margin-top: 16px;
  transition: all 0.2s;
  text-align: center;
}
.event-register-ride-btn:active { transform: scale(0.97); }
.event-register-ride-btn.registered {
  background: linear-gradient(135deg, rgba(133,172,181,0.3), rgba(65,43,81,0.2));
  color: #85ACB5;
  border: 1px solid rgba(133,172,181,0.3);
}

/* Registrant list for creators */
.ride-registrants-section {
  margin-top: 20px;
  padding: 16px;
  background: rgba(65,43,81,0.06);
  border-radius: 14px;
  border: 1px solid rgba(151,116,181,0.15);
}
.ride-registrants-title {
  font-size: 14px;
  font-weight: 700;
  color: #9774B5;
  margin-bottom: 12px;
  display: flex;
  align-items: center;
  justify-content: space-between;
}
.ride-registrants-export {
  font-size: 12px;
  font-weight: 600;
  color: var(--cyan);
  cursor: pointer;
  padding: 4px 10px;
  border-radius: 8px;
  border: 1px solid rgba(132,207,195,0.3);
  background: transparent;
}
.ride-registrant-row {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 8px 0;
  border-bottom: 1px solid rgba(255,255,255,0.05);
}
.ride-registrant-row:last-child { border-bottom: none; }
.ride-registrant-avatar {
  width: 32px;
  height: 32px;
  border-radius: 50%;
  object-fit: cover;
}
.ride-registrant-info {
  flex: 1;
  min-width: 0;
}
.ride-registrant-name {
  font-size: 14px;
  font-weight: 600;
  color: var(--text-primary);
}
.ride-registrant-email {
  font-size: 12px;
  color: var(--text-secondary);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.ride-registrant-date {
  font-size: 11px;
  color: var(--text-dim);
}

.events-list { padding: 0 16px calc(16px + 60px + var(--safe-bottom)); }
.for-you-section div::-webkit-scrollbar { display: none; }

.event-card {
  background: var(--bg-card);
  border: 1px solid var(--border-glass);
  border-radius: var(--radius-md);
  overflow: hidden;
  margin-bottom: 12px;
  cursor: pointer;
  transition: all 0.2s;
}
.event-card:hover { border-color: rgba(132,207,195,0.2); }

.event-card-image {
  height: 140px;
  background: linear-gradient(135deg, rgba(55,65,81,0.5), rgba(75,85,99,0.4));
  display: flex;
  align-items: flex-end;
  padding: 12px;
  position: relative;
  overflow: hidden;
}
.event-card-image[data-cat="music"] { background: linear-gradient(135deg, rgba(168,85,247,0.35), rgba(255,98,154,0.25)); }
.event-card-image[data-cat="wellness"] { background: linear-gradient(135deg, rgba(52,211,153,0.3), rgba(132,207,195,0.25)); }
.event-card-image[data-cat="community"] { background: linear-gradient(135deg, rgba(99,102,241,0.3), rgba(132,207,195,0.25)); }
.event-card-image[data-cat="outdoors"] { background: linear-gradient(135deg, rgba(52,211,153,0.3), rgba(34,197,94,0.25)); }
.event-card-image[data-cat="art & culture"] { background: linear-gradient(135deg, rgba(167,139,250,0.35), rgba(151,116,181,0.25)); }
.event-card-image[data-cat="festival"] { background: linear-gradient(135deg, rgba(251,191,36,0.3), rgba(255,163,0,0.25)); }
.event-card-image[data-cat="nightlife"] { background: linear-gradient(135deg, rgba(151,116,181,0.35), rgba(255,98,154,0.25)); }
.event-card-image[data-cat="ride"] { background: linear-gradient(135deg, rgba(151,116,181,0.35), rgba(65,43,81,0.35)); }
.event-card-image[data-cat="online"] { background: linear-gradient(135deg, rgba(132,207,195,0.25), rgba(99,102,241,0.25)); }
.event-card-image[data-cat="ceremony"] { background: linear-gradient(135deg, rgba(151,116,181,0.35), rgba(255,98,154,0.25)); }
.event-card-image[data-cat="workshop"] { background: linear-gradient(135deg, rgba(255,163,0,0.3), rgba(255,98,154,0.2)); }
.event-card-image[data-cat="gathering"] { background: linear-gradient(135deg, rgba(132,207,195,0.3), rgba(99,102,241,0.2)); }
.event-card-image[data-cat="social"] { background: linear-gradient(135deg, rgba(167,139,250,0.3), rgba(132,207,195,0.2)); }
.event-card-image img {
  position: absolute;
  top: 0; left: 0;
  width: 100%; height: 100%;
  object-fit: cover;
  z-index: 1;
}
/* ── Event fallback art v2 (2026-06-11) ─────────────────────────────────
   Designed stand-in when an event has no image (or its image 404s/expires —
   Eventbrite signed URLs die). Full-opacity composition: category gradient +
   concentric portal rings + speckle field + glyph chip. Replaces the old
   faint 40%-opacity emoji that read as a loading error. */
.event-card-fallback {
  position: absolute; top: 0; left: 0; width: 100%; height: 100%;
  display: flex; align-items: center; justify-content: center;
  overflow: hidden;
}
.event-card-fallback::before { /* concentric portal rings */
  content: ''; position: absolute;
  width: 150px; height: 150px; border-radius: 50%;
  border: 1px solid rgba(255,255,255,0.10);
  box-shadow: 0 0 0 30px rgba(255,255,255,0.05),
              0 0 0 64px rgba(255,255,255,0.03),
              inset 0 0 40px rgba(255,255,255,0.04);
}
.event-card-fallback::after { /* speckle field */
  content: ''; position: absolute; top:0; left:0; width:100%; height:100%;
  background-image:
    radial-gradient(circle, rgba(255,255,255,0.55) 1px, transparent 1.6px),
    radial-gradient(circle, rgba(255,255,255,0.35) 1px, transparent 1.6px);
  background-size: 110px 90px, 70px 130px;
  background-position: 14px 18px, 46px 56px;
  opacity: 0.4;
}
.event-fallback-glyph {
  position: relative; z-index: 1;
  width: 62px; height: 62px; border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  font-size: 28px; line-height: 1;
  color: rgba(255,255,255,0.92);
  background: rgba(26,24,24,0.5);
  border: 1px solid rgba(255,255,255,0.14);
  backdrop-filter: blur(6px);
  -webkit-backdrop-filter: blur(6px);
  text-shadow: 0 2px 18px rgba(0,0,0,0.45);
}
.event-card-fallback.hero-fallback .event-fallback-glyph { width: 84px; height: 84px; font-size: 38px; }
.event-card-fallback.hero-fallback::before { width: 210px; height: 210px; }
.event-card-fallback.mini-fallback::before { width: 56px; height: 56px; box-shadow: 0 0 0 14px rgba(255,255,255,0.05); }
.event-card-fallback.mini-fallback .event-fallback-glyph { width: 34px; height: 34px; font-size: 16px; }
/* Unified category gradients — covers every live DB category (breathwork,
   sound_bath, integration, etc. previously fell to a flat box). Later in the
   sheet than the legacy per-cat rules, so these win at equal specificity. */
.event-card-image, .event-detail-hero, .org-event-thumb-fallback {
  --cat-grad: linear-gradient(135deg, rgba(151,116,181,0.30), rgba(65,43,81,0.32));
}
[data-cat="music"], [data-cat="concert"] { --cat-grad: linear-gradient(135deg, rgba(168,85,247,0.35), rgba(255,98,154,0.25)); }
[data-cat="wellness"] { --cat-grad: linear-gradient(135deg, rgba(52,211,153,0.30), rgba(132,207,195,0.25)); }
[data-cat="community"], [data-cat="gathering"], [data-cat="social"] { --cat-grad: linear-gradient(135deg, rgba(99,102,241,0.30), rgba(132,207,195,0.25)); }
[data-cat="outdoors"], [data-cat="retreat"] { --cat-grad: linear-gradient(135deg, rgba(52,211,153,0.30), rgba(34,197,94,0.25)); }
[data-cat="art & culture"] { --cat-grad: linear-gradient(135deg, rgba(167,139,250,0.35), rgba(151,116,181,0.25)); }
[data-cat="festival"] { --cat-grad: linear-gradient(135deg, rgba(251,191,36,0.30), rgba(255,163,0,0.25)); }
[data-cat="nightlife"], [data-cat="ecstatic_dance"] { --cat-grad: linear-gradient(135deg, rgba(255,98,154,0.32), rgba(255,163,0,0.20)); }
[data-cat="ride"] { --cat-grad: linear-gradient(135deg, rgba(151,116,181,0.35), rgba(65,43,81,0.35)); }
[data-cat="online"] { --cat-grad: linear-gradient(135deg, rgba(132,207,195,0.25), rgba(99,102,241,0.25)); }
[data-cat="ceremony"] { --cat-grad: linear-gradient(135deg, rgba(151,116,181,0.35), rgba(255,98,154,0.25)); }
[data-cat="workshop"], [data-cat="conference"], [data-cat="psychedelic_lecture"] { --cat-grad: linear-gradient(135deg, rgba(167,139,250,0.32), rgba(255,163,0,0.18)); }
[data-cat="breathwork"], [data-cat="meditation"] { --cat-grad: linear-gradient(135deg, rgba(132,207,195,0.30), rgba(99,102,241,0.25)); }
[data-cat="sound_bath"] { --cat-grad: linear-gradient(135deg, rgba(99,102,241,0.30), rgba(168,85,247,0.25)); }
[data-cat="integration"] { --cat-grad: linear-gradient(135deg, rgba(52,211,153,0.28), rgba(99,102,241,0.22)); }
[data-cat="cold_plunge"] { --cat-grad: linear-gradient(135deg, rgba(56,189,248,0.30), rgba(99,102,241,0.22)); }
.event-card-image[data-cat], .event-detail-hero[data-cat], .org-event-thumb-fallback { background: var(--cat-grad); }
.org-event-thumb-fallback {
  display: flex; align-items: center; justify-content: center;
  font-size: 18px; color: rgba(255,255,255,0.85); position: relative; overflow: hidden;
}
.event-card-category {
  position: relative;
  z-index: 2;
  padding: 4px 12px;
  border-radius: 100px;
  background: rgba(26,24,24,0.7);
  backdrop-filter: blur(8px);
  color: var(--cyan);
  font-size: 11px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.5px;
}

.event-card-body { padding: 14px 16px; }
.event-card-date {
  font-size: 12px;
  color: var(--magenta);
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.5px;
  margin-bottom: 6px;
}
.event-card-title {
  font-size: 16px;
  font-weight: 600;
  margin-bottom: 6px;
  line-height: 1.3;
}
.event-card-venue {
  font-size: 13px;
  color: var(--text-secondary);
  margin-bottom: 10px;
}
.event-card-desc {
  display: none; /* hidden on mobile, shown via desktop media query */
}
.event-card-footer {
  display: flex;
  align-items: center;
  justify-content: space-between;
}
.event-card-rsvp {
  font-size: 12px;
  color: var(--text-dim);
}
.event-card-rsvp strong { color: var(--cyan); }
.events-load-more {
  padding: 16px;
  text-align: center;
  color: var(--cyan);
  font-size: 14px;
  font-family: var(--font-body);
  cursor: pointer;
  border: 1px solid rgba(132,207,195,0.2);
  border-radius: 12px;
  margin: 8px 0;
  transition: background 0.2s;
}
.events-load-more:hover { background: rgba(132,207,195,0.08); }
.event-card-going {
  display: flex;
  align-items: center;
}
.event-card-going-avatar {
  width: 24px;
  height: 24px;
  border-radius: 50%;
  border: 2px solid var(--bg-card);
  margin-left: -8px;
  object-fit: cover;
  background: var(--cyan-dim);
}
.event-card-going-avatar:first-child { margin-left: 0; }

.event-submit-fab {
  position: fixed;
  bottom: calc(80px + var(--safe-bottom));
  right: 16px;
  z-index: 499;
  width: 56px;
  height: 56px;
  border-radius: 50%;
  background: var(--gradient-warm);
  border: none;
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  font-size: 24px;
  color: #252525;
  box-shadow: 0 4px 20px rgba(255,98,154,0.3);
  transition: all 0.2s;
}
.event-submit-fab:hover { transform: scale(1.05); box-shadow: 0 6px 30px rgba(255,98,154,0.4); }

/* ── EVENT DETAIL MODAL ── */
.event-detail {
  position: fixed;
  top: 0; left: 0; right: 0; bottom: 0;
  z-index: 100000;
  background: var(--bg-deep);
  display: flex;
  flex-direction: column;
  overflow-y: auto;
  -webkit-overflow-scrolling: touch;
  overscroll-behavior: contain;
  transform: translateX(100%);
  transition: transform 0.3s cubic-bezier(0.32,0.72,0,1);
  pointer-events: none;
}
.event-detail.visible { transform: translateX(0); pointer-events: auto; }

.event-detail-hero {
  height: 220px;
  min-height: 220px;
  flex-shrink: 0;
  background: linear-gradient(135deg, rgba(132,207,195,0.3), rgba(255,98,154,0.3));
  position: relative;
}
.event-detail-hero img {
  width: 100%; height: 100%;
  object-fit: cover;
}
.event-detail-back {
  z-index: 2;
  position: absolute;
  top: max(12px, env(safe-area-inset-top));
  left: 16px;
  width: 36px; height: 36px;
  border-radius: 50%;
  background: rgba(26,24,24,0.6);
  backdrop-filter: blur(8px);
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  color: white;
  font-size: 18px;
}

.event-detail-body {
  flex-shrink: 0;
  padding: 20px 16px;
  padding-bottom: calc(160px + var(--safe-bottom));
}
.event-detail-category {
  display: inline-block;
  padding: 4px 12px;
  border-radius: 100px;
  background: var(--cyan-dim);
  color: var(--cyan);
  font-size: 12px;
  font-weight: 600;
  text-transform: uppercase;
  margin-bottom: 12px;
}
.event-detail-title {
  font-family: 'Oswald', sans-serif;
  font-size: 24px;
  font-weight: 600;
  letter-spacing: 0.5px;
  margin-bottom: 16px;
}
.event-detail-meta {
  display: flex;
  flex-direction: column;
  gap: 10px;
  margin-bottom: 20px;
}
.event-detail-meta-row {
  display: flex;
  align-items: center;
  gap: 10px;
  font-size: 14px;
  color: var(--text-secondary);
}
.event-detail-meta-icon { font-size: 18px; width: 24px; text-align: center; }
.event-detail-desc {
  font-size: 14px;
  line-height: 1.7;
  color: var(--text-secondary);
  margin-bottom: 24px;
}
.event-external-link {
  display: block;
  width: 100%;
  padding: 14px 20px;
  background: var(--cyan-dim);
  border: 1px solid rgba(132,207,195,0.3);
  border-radius: var(--radius-md);
  color: var(--cyan);
  font-family: 'Oswald', sans-serif;
  font-size: 15px;
  font-weight: 600;
  letter-spacing: 1px;
  text-transform: uppercase;
  text-align: center;
  text-decoration: none;
  margin-bottom: 24px;
  transition: all 0.2s;
}
.event-external-link:active {
  background: rgba(132,207,195,0.25);
  transform: scale(0.98);
}
.event-detail-attendees-title {
  font-size: 13px;
  font-weight: 600;
  color: var(--text-dim);
  text-transform: uppercase;
  letter-spacing: 1px;
  margin-bottom: 12px;
}
.event-detail-attendees {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}
.attendee-chip {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 6px 12px 6px 6px;
  background: var(--bg-card);
  border: 1px solid var(--border-glass);
  border-radius: 100px;
  font-size: 13px;
  cursor: pointer;
  transition: all 0.15s;
}
.attendee-chip:active { background: var(--cyan-dim); transform: scale(0.96); }
.attendee-chip img {
  width: 24px; height: 24px;
  border-radius: 50%;
  object-fit: cover;
}
.event-attendees-section {
  margin-top: 20px;
  padding-top: 20px;
  border-top: 1px solid var(--border-glass);
}
.event-attendees-section .event-detail-attendees-title {
  display: flex;
  align-items: center;
  gap: 8px;
}
.attendees-reveal {
  animation: fadeUp 0.3s ease;
}

/* ── EVENT PHOTO ALBUM ── */
.event-photos-section {
  margin-top: 20px;
  padding-top: 20px;
  border-top: 1px solid var(--border-glass);
  animation: fadeUp 0.3s ease;
}
.event-photos-title {
  font-size: 13px;
  font-weight: 600;
  color: var(--text-dim);
  text-transform: uppercase;
  letter-spacing: 1px;
  margin-bottom: 12px;
  display: flex;
  align-items: center;
  gap: 8px;
}
.event-photos-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 4px;
  border-radius: var(--radius-md);
  overflow: hidden;
}
.event-photo-thumb {
  aspect-ratio: 1;
  overflow: hidden;
  cursor: pointer;
  position: relative;
  background: var(--bg-card);
}
.event-photo-thumb img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 0.2s;
}
.event-photo-thumb:active img {
  transform: scale(1.05);
}
.event-photo-add {
  aspect-ratio: 1;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  background: var(--bg-card);
  border: 1px dashed var(--border-glass);
  cursor: pointer;
  color: var(--text-dim);
  font-size: 11px;
  gap: 4px;
  transition: all 0.15s;
}
.event-photo-add:active {
  background: var(--cyan-dim);
  color: var(--cyan);
}
.event-photo-add svg {
  opacity: 0.5;
}
.event-photo-count {
  font-size: 11px;
  color: var(--text-dim);
  text-align: center;
  margin-top: 8px;
}
/* Photo lightbox overlay */
.photo-lightbox {
  position: fixed;
  inset: 0;
  /* Needs to stack above every overlay in the app — BD city/detail overlays
     sit at ~99991. Bumped so tapping a photo from inside those surfaces
     actually shows the zoomed view (was opening behind the BD overlay). */
  z-index: 100100;
  background: rgba(0,0,0,0.95);
  display: flex;
  align-items: center;
  justify-content: center;
  opacity: 0;
  pointer-events: none;
  transition: opacity 0.25s ease;
}
.photo-lightbox.show {
  opacity: 1;
  pointer-events: auto;
}
.photo-lightbox img {
  max-width: 92vw;
  max-height: 85vh;
  object-fit: contain;
  border-radius: var(--radius-md);
}
.photo-lightbox-close {
  position: absolute;
  top: calc(12px + var(--safe-top));
  right: 12px;
  width: 36px; height: 36px;
  border-radius: 50%;
  background: rgba(255,255,255,0.15);
  border: none;
  color: white;
  font-size: 20px;
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
}
.photo-lightbox-nav {
  position: absolute;
  bottom: calc(24px + var(--safe-bottom));
  left: 50%;
  transform: translateX(-50%);
  display: flex;
  gap: 12px;
  align-items: center;
}
.photo-lightbox-nav button {
  width: 40px; height: 40px;
  border-radius: 50%;
  background: rgba(255,255,255,0.1);
  border: none;
  color: white;
  font-size: 18px;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
}
.photo-lightbox-counter {
  font-size: 13px;
  color: rgba(255,255,255,0.6);
  min-width: 60px;
  text-align: center;
}

/* ── INTEREST MATCH SUGGESTIONS ── */
.match-suggestions {
  margin: 0 16px 16px;
  padding: 16px;
  background: var(--bg-card);
  border: 1px solid var(--border-glass);
  border-radius: var(--radius-lg);
}
.match-suggestions-title {
  font-size: 13px;
  font-weight: 600;
  color: var(--text-dim);
  text-transform: uppercase;
  letter-spacing: 1px;
  margin-bottom: 12px;
  display: flex;
  align-items: center;
  gap: 8px;
}
.match-card {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 12px;
  background: var(--bg-elevated);
  border: 1px solid var(--border-glass);
  border-radius: var(--radius-md);
  margin-bottom: 8px;
  cursor: pointer;
  transition: all 0.15s;
}
.match-card:last-child { margin-bottom: 0; }
.match-card:active { transform: scale(0.98); background: var(--cyan-dim); }
.match-card-avatar {
  width: 44px; height: 44px;
  border-radius: 50%;
  object-fit: cover;
  border: 2px solid var(--cyan);
  flex-shrink: 0;
}
.match-card-info { flex: 1; min-width: 0; }
.match-card-name {
  font-size: 14px;
  font-weight: 600;
  color: var(--warm-white);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.match-card-location {
  font-size: 11px;
  color: var(--text-dim);
  margin-top: 2px;
}
.match-card-shared {
  display: flex;
  flex-wrap: wrap;
  gap: 4px;
  margin-top: 6px;
}
.match-tag {
  font-size: 10px;
  padding: 2px 8px;
  border-radius: 100px;
  background: rgba(132,207,195,0.1);
  color: var(--cyan);
  border: 1px solid rgba(132,207,195,0.2);
}
.match-score {
  font-size: 11px;
  font-weight: 700;
  color: var(--cyan);
  background: rgba(132,207,195,0.1);
  padding: 4px 10px;
  border-radius: 100px;
  flex-shrink: 0;
  white-space: nowrap;
}

/* ── INLINE MEMBER DIRECTORY (Community Section) ── */
.member-directory-section {
  margin: 0 16px 20px;
  padding: 16px;
  background: var(--bg-card);
  border: 1px solid var(--border-glass);
  border-radius: var(--radius-lg);
}
.member-directory-header {
  display: flex; align-items: center; justify-content: space-between;
  margin-bottom: 12px;
}
.member-directory-title {
  font-size: 13px; font-weight: 600; color: var(--text-dim);
  text-transform: uppercase; letter-spacing: 1px;
  display: flex; align-items: center; gap: 8px;
}
.member-directory-viewall {
  font-size: 12px; color: var(--cyan); cursor: pointer;
  font-family: var(--font-body); background: none; border: none;
  padding: 4px 0; transition: opacity 0.15s;
}
.member-directory-viewall:active { opacity: 0.6; }
.member-directory-search {
  position: relative; margin-bottom: 12px;
}
.member-directory-search-input {
  width: 100%; padding: 10px 14px 10px 36px; border-radius: var(--radius-md);
  background: var(--bg-elevated); border: 1px solid var(--border-glass);
  color: var(--warm-white); font-size: 14px; font-family: var(--font-body);
  outline: none; transition: border-color 0.2s;
}
.member-directory-search-input::placeholder { color: var(--text-dim); }
.member-directory-search-input:focus { border-color: var(--cyan); }
.member-directory-search-icon {
  position: absolute; left: 12px; top: 50%; transform: translateY(-50%);
  font-size: 14px; color: var(--text-dim); pointer-events: none;
}
.member-directory-filters {
  display: flex; gap: 6px; flex-wrap: wrap; margin-bottom: 12px;
}
.member-directory-chip {
  padding: 5px 12px; border-radius: 100px; font-size: 11px;
  background: var(--bg-elevated); border: 1px solid var(--border-glass);
  color: var(--text-dim); cursor: pointer; font-family: var(--font-body);
  transition: all 0.2s; white-space: nowrap;
}
.member-directory-chip.active {
  background: rgba(132,207,195,0.15); border-color: var(--cyan); color: var(--cyan);
}
.member-directory-chip:active { transform: scale(0.95); }
.member-directory-count {
  font-size: 11px; color: var(--text-dim); margin-bottom: 8px;
}
.member-directory-grid {
  display: flex; flex-direction: column; gap: 0;
}
.md-member {
  display: flex; align-items: center; gap: 12px;
  padding: 10px 0; cursor: pointer;
  border-bottom: 1px solid rgba(255,255,255,0.03);
  transition: background 0.15s;
}
.md-member:last-child { border-bottom: none; }
.md-member:active { background: rgba(255,255,255,0.03); }
.md-member-info { flex: 1; min-width: 0; }
.md-member-name {
  font-size: 14px; font-weight: 600; color: var(--warm-white);
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
  display: flex; align-items: center; gap: 6px;
}
.md-member-connect {
  display: inline-block; width: 6px; height: 6px; border-radius: 50%;
  background: var(--cyan); flex-shrink: 0;
}
.md-member-location {
  font-size: 11px; color: var(--text-dim); margin-top: 1px;
}
.md-member-tags {
  display: flex; flex-wrap: wrap; gap: 4px; margin-top: 4px;
}
.md-member-tag {
  font-size: 10px; padding: 2px 8px; border-radius: 100px;
  background: rgba(132,207,195,0.1); color: var(--cyan);
  border: 1px solid rgba(132,207,195,0.2);
}
.md-member-arrow { color: var(--text-dim); font-size: 16px; flex-shrink: 0; }

/* ── ACTIVE TIMESTAMP BADGE ── */
.active-badge {
  font-size: 11px;
  color: var(--text-dim);
  display: flex;
  align-items: center;
  gap: 4px;
  margin-top: 2px;
}
.active-badge .active-dot {
  width: 6px; height: 6px;
  border-radius: 50%;
  background: var(--cyan);
  flex-shrink: 0;
}
.active-badge.offline .active-dot { background: var(--text-dim); opacity: 0.4; }

/* ── EVENT CARD CATEGORY COLORS ── */
.event-card-category[data-cat="music"] { color: var(--magenta); }
.event-card-category[data-cat="wellness"] { color: var(--cyan); }
.event-card-category[data-cat="community"] { color: var(--orange); }
.event-card-category[data-cat="outdoors"] { color: var(--cyan); }
.event-card-category[data-cat="art & culture"] { color: var(--magenta); }
.event-card-category[data-cat="festival"] { color: var(--orange); }
.event-card-category[data-cat="nightlife"] { color: var(--magenta); }
.event-card-category[data-cat="online"] { color: var(--cyan); }
.event-card-category[data-cat="ceremony"] { color: var(--magenta); }
.event-card-category[data-cat="workshop"] { color: var(--orange); }
.event-card-category[data-cat="gathering"] { color: var(--cyan); }
.event-card-category[data-cat="social"] { color: var(--magenta); }
.event-card-category[data-cat="ride"] { color: #f59e0b; }
.event-card-ride { border: 1px solid rgba(245,158,11,0.3); }
.event-card-ride-badge {
  position: absolute;
  top: 10px; right: 10px;
  background: rgba(245,158,11,0.9);
  color: #252525;
  font-size: 11px;
  font-weight: 800;
  font-family: 'Oswald', sans-serif;
  letter-spacing: 1.5px;
  padding: 4px 10px;
  border-radius: 6px;
  z-index: 2;
}
.event-card-accent[data-cat="ride"] { background: linear-gradient(90deg, #f59e0b, transparent); }
.event-card-accent {
  position: absolute;
  bottom: 0; left: 0; right: 0;
  height: 3px;
}
.event-card-accent[data-cat="music"] { background: linear-gradient(90deg, var(--magenta), transparent); }
.event-card-accent[data-cat="wellness"] { background: linear-gradient(90deg, var(--cyan), transparent); }
.event-card-accent[data-cat="community"] { background: linear-gradient(90deg, var(--orange), transparent); }
.event-card-accent[data-cat="outdoors"] { background: linear-gradient(90deg, var(--cyan), transparent); }
.event-card-accent[data-cat="art & culture"] { background: linear-gradient(90deg, var(--magenta), transparent); }
.event-card-accent[data-cat="festival"] { background: linear-gradient(90deg, var(--orange), transparent); }
.event-card-accent[data-cat="nightlife"] { background: linear-gradient(90deg, var(--magenta), transparent); }
.event-card-accent[data-cat="online"] { background: linear-gradient(90deg, var(--cyan), transparent); }
.event-card-accent[data-cat="ceremony"] { background: linear-gradient(90deg, var(--magenta), transparent); }
.event-card-accent[data-cat="workshop"] { background: linear-gradient(90deg, var(--orange), transparent); }
.event-card-accent[data-cat="gathering"] { background: linear-gradient(90deg, var(--cyan), transparent); }
.event-card-accent[data-cat="social"] { background: linear-gradient(90deg, var(--magenta), transparent); }

/* ── PAST EVENTS SECTION ── */
.past-events-divider {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 18px 4px 10px;
  cursor: pointer;
  color: rgba(255,255,255,0.45);
  font-size: 12px;
  font-weight: 600;
  letter-spacing: 0.8px;
  text-transform: uppercase;
}
.past-events-divider::before,
.past-events-divider::after {
  content: '';
  flex: 1;
  height: 1px;
  background: rgba(255,255,255,0.08);
}
.past-events-divider svg {
  transition: transform 0.3s ease;
  flex-shrink: 0;
}
.past-events-divider.expanded svg {
  transform: rotate(180deg);
}
.past-events-section {
  display: none;
}
.past-events-section.expanded {
  display: block;
}
.past-events-section .event-card {
  opacity: 0.55;
}
.past-events-section .event-card:hover {
  opacity: 0.75;
}

/* ── MAP CLUSTER POPUP ── */
.cluster-preview {
  display: flex;
  flex-direction: column;
  gap: 8px;
  padding: 4px 0;
}
.cluster-preview-avatars {
  display: flex;
  gap: -4px;
}
.cluster-preview-avatars img {
  width: 28px; height: 28px;
  border-radius: 50%;
  border: 2px solid var(--bg-deep);
  object-fit: cover;
  margin-left: -6px;
}
.cluster-preview-avatars img:first-child { margin-left: 0; }
.cluster-preview-text {
  font-size: 12px;
  color: var(--text-secondary);
  text-align: center;
}
.cluster-preview-btn {
  padding: 6px 12px;
  border-radius: var(--radius-md);
  background: var(--cyan-dim);
  color: var(--cyan);
  border: 1px solid rgba(132,207,195,0.3);
  font-size: 11px;
  font-weight: 600;
  cursor: pointer;
  text-align: center;
  font-family: var(--font-body);
}

.event-detail-rsvp-bar {
  position: fixed;
  bottom: 0; left: 0; right: 0;
  padding: 16px;
  padding-bottom: calc(16px + var(--safe-bottom));
  background: var(--bg-glass-solid);
  backdrop-filter: blur(24px);
  -webkit-backdrop-filter: blur(24px);
  border-top: 1px solid var(--border-glass);
  z-index: 100001;
  display: none;
}
.event-detail.visible .event-detail-rsvp-bar { display: flex; gap: 12px; align-items: center; }

.event-share-btn {
  width: 48px; height: 48px; min-width: 48px;
  border-radius: var(--radius-md);
  background: var(--bg-card);
  border: 1px solid var(--border-glass);
  color: var(--text-primary);
  display: flex; align-items: center; justify-content: center;
  cursor: pointer;
  transition: all 0.2s;
}
.event-share-btn:active { transform: scale(0.95); background: var(--cyan-dim); }

.rsvp-btn {
  flex: 1;
  padding: 16px;
  border-radius: var(--radius-md);
  background: var(--gradient-portal);
  border: none;
  color: #252525;
  font-size: 16px;
  font-weight: 700;
  font-family: 'Oswald', sans-serif;
  letter-spacing: 1.5px;
  text-transform: uppercase;
  cursor: pointer;
  transition: all 0.2s;
}
.rsvp-btn:hover { transform: translateY(-1px); }
.rsvp-btn.going {
  background: var(--cyan-dim);
  border: 1px solid var(--cyan);
  color: var(--cyan);
}
.rsvp-btn.interested {
  background: rgba(255,163,0,0.1);
  border: 1px solid var(--orange);
  color: var(--orange);
}
.event-cal-btn {
  width: 48px; height: 48px; min-width: 48px;
  border-radius: var(--radius-md);
  background: var(--bg-card);
  border: 1px solid var(--border-glass);
  color: var(--text-dim);
  display: flex; align-items: center; justify-content: center;
  cursor: pointer; transition: all 0.2s;
}
.event-cal-btn:active { background: var(--cyan-dim); color: var(--cyan); }
.rsvp-btn-group {
  flex: 1; display: flex; gap: 8px;
}
.rsvp-btn-group .rsvp-btn { flex: 1; padding: 14px 8px; font-size: 13px; letter-spacing: 1px; }
.rsvp-btn-group .rsvp-btn.interested { font-size: 12px; }
.rsvp-btn.ride-register {
  background: linear-gradient(135deg, #412B51, #9774B5);
  color: #F4F4BE;
  flex: 1;
}

/* ── EVENT SUBMIT MODAL ── */
.event-submit-modal {
  position: fixed;
  top: 0; left: 0; right: 0; bottom: 0;
  z-index: 970;
  background: var(--bg-deep);
  display: flex;
  flex-direction: column;
  overflow-y: auto;
  transform: translateX(100%);
  transition: transform 0.3s cubic-bezier(0.32,0.72,0,1);
  pointer-events: none;
}
.event-submit-modal.visible { transform: translateX(0); pointer-events: auto; }

.event-submit-header {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 12px 16px;
  padding-top: max(12px, env(safe-area-inset-top));
  background: var(--bg-glass-solid);
  border-bottom: 1px solid var(--border-glass);
}
.event-submit-body {
  padding: 20px 16px;
  padding-bottom: calc(40px + var(--safe-bottom));
}
.event-submit-body .onboard-input { margin-bottom: 16px; }
.event-submit-body .onboard-bio { margin-bottom: 16px; }
.event-submit-body label {
  display: block;
  font-size: 13px;
  font-weight: 600;
  color: var(--text-dim);
  text-transform: uppercase;
  letter-spacing: 1px;
  margin-bottom: 8px;
}
.event-submit-body select {
  width: 100%;
  padding: 14px 18px;
  background: rgba(255,255,255,0.06);
  border: 1px solid var(--border-glass);
  border-radius: var(--radius-md);
  color: var(--text-primary);
  font-size: 16px;
  font-family: inherit;
  outline: none;
  appearance: none;
  margin-bottom: 16px;
}

/* ── ORGANIZER PROFILE ── */
.organizer-profile-overlay, .organizer-claim-overlay {
  position: fixed;
  top: 0; left: 0; right: 0; bottom: 0;
  z-index: 100001;
  background: var(--bg-deep);
  display: flex;
  flex-direction: column;
  overflow-y: auto;
  transform: translateX(100%);
  transition: transform 0.3s cubic-bezier(0.32,0.72,0,1);
  pointer-events: none;
}
.organizer-profile-overlay.visible, .organizer-claim-overlay.visible {
  transform: translateX(0);
  pointer-events: auto;
}
.organizer-profile-header {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 12px 16px;
  padding-top: max(12px, env(safe-area-inset-top));
  background: var(--bg-glass-solid);
  border-bottom: 1px solid var(--border-glass);
  flex-shrink: 0;
}
.organizer-profile-body, .organizer-claim-body {
  padding: 0;
  flex: 1;
  overflow-y: auto;
}
.org-hero {
  text-align: center;
  padding: 32px 20px 24px;
}
.org-avatar {
  width: 80px;
  height: 80px;
  border-radius: 50%;
  object-fit: cover;
  border: 3px solid var(--border-glass);
  margin-bottom: 12px;
  background: var(--cyan-dim);
}
.org-avatar-placeholder {
  width: 80px;
  height: 80px;
  border-radius: 50%;
  background: linear-gradient(135deg, var(--cyan-dim), rgba(255,98,154,0.15));
  border: 3px solid var(--border-glass);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 28px;
  font-weight: 700;
  color: var(--cyan);
  margin: 0 auto 12px;
}
.org-name {
  font-size: 22px;
  font-weight: 700;
  margin-bottom: 4px;
}
.org-type-badge {
  display: inline-block;
  padding: 3px 12px;
  border-radius: 100px;
  font-size: 11px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.5px;
  background: var(--cyan-dim);
  color: var(--cyan);
  margin-bottom: 8px;
}
.org-location {
  font-size: 14px;
  color: var(--text-secondary);
  margin-bottom: 12px;
}
.org-stats {
  display: flex;
  justify-content: center;
  gap: 24px;
  margin-bottom: 16px;
}
.org-stat {
  text-align: center;
}
.org-stat-num {
  font-size: 18px;
  font-weight: 700;
  color: var(--text-primary);
}
.org-stat-label {
  font-size: 11px;
  color: var(--text-dim);
  text-transform: uppercase;
  letter-spacing: 0.5px;
}
.org-follow-btn {
  padding: 10px 32px;
  border-radius: 100px;
  border: 1px solid var(--cyan);
  background: transparent;
  color: var(--cyan);
  font-size: 14px;
  font-weight: 600;
  cursor: pointer;
  transition: all 0.2s;
  font-family: inherit;
}
.org-follow-btn:hover { background: var(--cyan-dim); }
.org-follow-btn.following {
  background: var(--cyan);
  color: #252525;
}
.org-verified-badge {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  padding: 3px 10px;
  border-radius: 100px;
  font-size: 11px;
  font-weight: 600;
  background: rgba(52,211,153,0.12);
  color: #34d399;
  margin-left: 6px;
}
.org-claimed-indicator {
  font-size: 12px;
  color: var(--text-dim);
  margin-top: 8px;
}
.org-section {
  padding: 16px 20px;
  border-top: 1px solid var(--border-glass);
}
.org-section-label {
  font-size: 11px;
  font-weight: 600;
  color: var(--text-dim);
  text-transform: uppercase;
  letter-spacing: 1px;
  margin-bottom: 12px;
}
.org-bio {
  font-size: 14px;
  line-height: 1.6;
  color: var(--text-secondary);
}
.org-link-row {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 10px 0;
  color: var(--text-secondary);
  cursor: pointer;
  font-size: 14px;
}
.org-link-row:hover { color: var(--cyan); }
.org-event-card {
  display: flex;
  gap: 12px;
  padding: 12px 0;
  border-bottom: 1px solid rgba(255,255,255,0.04);
  cursor: pointer;
}
.org-event-card:last-child { border-bottom: none; }
.org-event-thumb {
  width: 60px;
  height: 60px;
  border-radius: 8px;
  object-fit: cover;
  flex-shrink: 0;
  background: var(--cyan-dim);
}
.org-event-info { flex: 1; min-width: 0; }
.org-event-title {
  font-size: 14px;
  font-weight: 600;
  margin-bottom: 2px;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.org-event-date {
  font-size: 12px;
  color: var(--magenta);
  font-weight: 600;
  text-transform: uppercase;
}
.org-claim-btn {
  display: block;
  width: 100%;
  padding: 14px;
  border-radius: var(--radius-md);
  border: 1px dashed var(--border-glass);
  background: transparent;
  color: var(--text-dim);
  font-size: 13px;
  cursor: pointer;
  transition: all 0.2s;
  font-family: inherit;
  text-align: center;
  margin-top: 16px;
}
.org-claim-btn:hover { border-color: var(--cyan); color: var(--cyan); }

/* Claim form */
.claim-step { padding: 24px 20px; }
.claim-step h3 {
  font-size: 18px;
  font-weight: 700;
  margin-bottom: 8px;
}
.claim-step p {
  font-size: 14px;
  color: var(--text-secondary);
  line-height: 1.5;
  margin-bottom: 16px;
}
.claim-field {
  margin-bottom: 16px;
}
.claim-field label {
  display: block;
  font-size: 12px;
  font-weight: 600;
  color: var(--text-dim);
  text-transform: uppercase;
  letter-spacing: 0.5px;
  margin-bottom: 6px;
}
.claim-field input {
  width: 100%;
  padding: 12px 16px;
  background: rgba(255,255,255,0.06);
  border: 1px solid var(--border-glass);
  border-radius: var(--radius-md);
  color: var(--text-primary);
  font-size: 15px;
  font-family: inherit;
  outline: none;
}
.claim-field input:focus { border-color: var(--cyan); }
.claim-submit-btn {
  width: 100%;
  padding: 14px;
  border-radius: var(--radius-md);
  border: none;
  background: var(--gradient-portal);
  color: #252525;
  font-size: 15px;
  font-weight: 600;
  cursor: pointer;
  font-family: inherit;
  margin-top: 8px;
}
.claim-submit-btn:disabled { opacity: 0.5; cursor: default; }
.claim-msg {
  font-size: 13px;
  text-align: center;
  margin-top: 12px;
  color: var(--cyan);
}
.claim-or {
  text-align: center;
  color: var(--text-dim);
  font-size: 13px;
  padding: 12px 0;
  position: relative;
}
.claim-or::before, .claim-or::after {
  content: '';
  position: absolute;
  top: 50%;
  width: 35%;
  height: 1px;
  background: var(--border-glass);
}
.claim-or::before { left: 0; }
.claim-or::after { right: 0; }
.claim-method-btn {
  width: 100%;
  padding: 12px;
  border-radius: var(--radius-md);
  border: 1px solid var(--border-glass);
  background: rgba(255,255,255,0.04);
  color: var(--text-secondary);
  font-size: 14px;
  cursor: pointer;
  font-family: inherit;
  text-align: left;
  display: flex;
  align-items: center;
  gap: 10px;
  margin-bottom: 8px;
  transition: all 0.2s;
}
.claim-method-btn:hover { border-color: var(--cyan); color: var(--text-primary); }

/* ── EVENT EDIT ── */
.event-edit-btn {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 8px 16px;
  border-radius: 100px;
  border: 1px solid var(--border-glass);
  background: rgba(255,255,255,0.04);
  color: var(--text-secondary);
  font-size: 13px;
  font-weight: 500;
  cursor: pointer;
  transition: all 0.2s;
  font-family: inherit;
  margin-top: 16px;
}
.event-edit-btn:hover { border-color: var(--cyan); color: var(--cyan); }
.event-edit-overlay {
  position: fixed;
  top: 0; left: 0; right: 0; bottom: 0;
  z-index: 100002;
  background: var(--bg-deep);
  display: flex;
  flex-direction: column;
  overflow-y: auto;
  transform: translateX(100%);
  transition: transform 0.3s cubic-bezier(0.32,0.72,0,1);
  pointer-events: none;
}
.event-edit-overlay.visible { transform: translateX(0); pointer-events: auto; }
.event-edit-body {
  padding: 20px 16px;
  padding-bottom: calc(40px + var(--safe-bottom));
}
.event-edit-body label {
  display: block;
  font-size: 12px;
  font-weight: 600;
  color: var(--text-dim);
  text-transform: uppercase;
  letter-spacing: 0.5px;
  margin-bottom: 6px;
}
.event-edit-body .onboard-input,
.event-edit-body select,
.event-edit-body .onboard-bio {
  margin-bottom: 16px;
}
.event-edit-body select {
  width: 100%;
  padding: 14px 18px;
  background: rgba(255,255,255,0.06);
  border: 1px solid var(--border-glass);
  border-radius: var(--radius-md);
  color: var(--text-primary);
  font-size: 16px;
  font-family: inherit;
  outline: none;
  appearance: none;
  margin-bottom: 16px;
}
.event-edit-delete {
  display: block;
  width: 100%;
  padding: 12px;
  border-radius: var(--radius-md);
  border: 1px solid rgba(239,68,68,0.3);
  background: transparent;
  color: #ef4444;
  font-size: 14px;
  cursor: pointer;
  font-family: inherit;
  text-align: center;
  margin-top: 24px;
  transition: all 0.2s;
}
.event-edit-delete:hover { background: rgba(239,68,68,0.1); }

/* ── PROFILE SCREEN ── */
.profile-screen {
  padding-bottom: calc(60px + var(--safe-bottom));
  background: var(--bg-deep);
}
.profile-screen .app-header {
  position: relative;
  flex-shrink: 0;
}

.profile-hero {
  display: flex;
  flex-direction: column;
  align-items: center;
  padding: 24px 16px;
  text-align: center;
}
.profile-avatar-large {
  width: 88px;
  height: 88px;
  border-radius: 50%;
  border: 3px solid var(--cyan);
  object-fit: cover;
  margin-bottom: 12px;
  background: var(--bg-card);
}
.profile-name {
  font-size: 20px;
  font-weight: 700;
  margin-bottom: 4px;
}
.profile-location {
  font-size: 14px;
  color: var(--text-secondary);
  margin-bottom: 8px;
}
.profile-member-since {
  font-size: 12px;
  color: var(--text-dim);
  padding: 4px 14px;
  border-radius: 100px;
  background: var(--cyan-dim);
  color: var(--cyan);
  font-weight: 500;
}

.profile-bio-section {
  padding: 0 16px;
  margin-bottom: 20px;
}
.profile-bio-text {
  font-size: 14px;
  line-height: 1.6;
  color: var(--text-secondary);
  text-align: center;
}

.profile-social-links {
  display: flex;
  justify-content: center;
  gap: 12px;
  padding: 0 16px;
  margin-bottom: 16px;
}
.profile-social-link {
  display: flex;
  align-items: center;
  gap: 6px;
  padding: 6px 14px;
  border-radius: 100px;
  background: rgba(255,255,255,0.04);
  border: 1px solid var(--border-glass);
  color: var(--text-secondary);
  font-size: 13px;
  cursor: pointer;
  transition: all 0.2s;
  text-decoration: none;
}
.profile-social-link:hover { border-color: var(--cyan); color: var(--cyan); }
.profile-social-link svg { flex-shrink: 0; }

.profile-interests-section {
  padding: 0 16px;
  margin-bottom: 24px;
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  justify-content: center;
}

.profile-section {
  padding: 0 16px;
  margin-bottom: 16px;
}
.profile-section-card {
  background: var(--bg-card);
  border: 1px solid var(--border-glass);
  border-radius: var(--radius-md);
  overflow: hidden;
}
.profile-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 16px;
  border-bottom: 1px solid var(--border-glass);
  cursor: pointer;
  transition: background 0.2s;
}
.profile-row:last-child { border-bottom: none; }
.profile-row:hover { background: rgba(255,255,255,0.02); }
.profile-row-left {
  display: flex;
  align-items: center;
  gap: 12px;
}
.profile-row-icon { font-size: 18px; width: 24px; text-align: center; }
.profile-row-label { font-size: 15px; }
.profile-row-arrow { color: var(--text-dim); font-size: 14px; }

.profile-logout {
  display: block;
  margin: 24px auto 0;
  padding: 8px 0;
  background: none;
  border: none;
  color: #6B7280;
  font-size: 15px;
  font-weight: 400;
  font-family: 'Inter', sans-serif;
  text-align: center;
  cursor: pointer;
  -webkit-tap-highlight-color: transparent;
}
.profile-logout:active { opacity: 0.6; }

.profile-section-label {
  font-size: 11px;
  font-weight: 600;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: #6B7280;
  padding: 8px 0 4px;
  margin: 0 16px;
}

.profile-row-info {
  display: flex;
  flex-direction: column;
}
.profile-row-subtitle {
  font-size: 12px;
  color: var(--text-dim);
  margin-top: 2px;
}

/* ── MERCH SCROLL ── */
.merch-scroll {
  display: flex;
  flex-shrink: 0;
  gap: 12px;
  overflow-x: auto;
  padding: 0 16px 8px;
  scroll-snap-type: x mandatory;
  -webkit-overflow-scrolling: touch;
  scrollbar-width: none;
}
.merch-scroll::-webkit-scrollbar { display: none; }
.merch-card {
  flex: 0 0 140px;
  scroll-snap-align: start;
  background: var(--bg-card);
  border: 1px solid var(--border-glass);
  border-radius: var(--radius-md);
  overflow: hidden;
  cursor: pointer;
  transition: border-color 0.2s;
}
.merch-card:active { border-color: rgba(132,207,195,0.3); }
.merch-card-img {
  width: 100%;
  height: 140px;
  object-fit: cover;
  background: rgba(255,255,255,0.03);
}
.merch-card-body {
  padding: 8px 10px 10px;
}
.merch-card-name {
  font-size: 12px;
  font-weight: 600;
  color: var(--warm-white);
  line-height: 1.3;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}
.merch-card-price {
  font-size: 12px;
  font-weight: 700;
  color: var(--cyan);
  margin-top: 4px;
}
.merch-card-sold {
  font-size: 10px;
  color: var(--text-dim);
  margin-top: 2px;
  text-transform: uppercase;
  letter-spacing: 0.5px;
}
/* ── PORTAL TV CARDS ── */
.portal-tv-card {
  flex: 0 0 200px;
  scroll-snap-align: start;
  background: var(--bg-card);
  border: 1px solid var(--border-glass);
  border-radius: var(--radius-md);
  overflow: hidden;
  cursor: pointer;
  transition: border-color 0.2s;
}
.portal-tv-card:active { border-color: rgba(255,98,154,0.3); }
.portal-tv-thumb-wrap {
  position: relative;
  width: 100%;
  height: 112px;
  overflow: hidden;
  background: rgba(255,255,255,0.03);
}
.portal-tv-thumb-wrap img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.portal-tv-play {
  position: absolute;
  top: 50%; left: 50%;
  transform: translate(-50%,-50%);
  width: 40px; height: 40px;
  background: rgba(0,0,0,0.6);
  border: 2px solid rgba(255,255,255,0.8);
  border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
}
.portal-tv-play svg { margin-left: 2px; }
.portal-tv-body {
  padding: 8px 10px 10px;
}
.portal-tv-title {
  font-size: 12px;
  font-weight: 600;
  color: var(--warm-white);
  line-height: 1.3;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}
.portal-tv-badge {
  font-size: 10px;
  color: #ff629a;
  margin-top: 4px;
  text-transform: uppercase;
  letter-spacing: 0.5px;
}
.ptv-duration-badge {
  position: absolute; bottom: 6px; right: 6px;
  background: rgba(0,0,0,0.72); color: #fff;
  font-size: 10px; font-weight: 600;
  padding: 2px 5px; border-radius: 4px;
  letter-spacing: 0.2px; pointer-events: none;
}
.ptv-new-badge {
  display: inline-block;
  background: #ff629a; color: #fff;
  font-size: 9px; font-weight: 700;
  text-transform: uppercase; letter-spacing: 0.8px;
  padding: 1px 5px; border-radius: 3px;
  margin-left: 6px; vertical-align: middle;
}
.ptv-views-badge {
  display: flex; align-items: center; gap: 3px;
  font-size: 10px; color: rgba(255,255,255,0.4);
  margin-top: 3px;
}
.ptv-watched-badge {
  font-size: 10px; color: rgba(132,207,195,0.7);
  margin-top: 3px;
}
/* ── PORTAL TV: HERO + COLLAPSIBLE GRID ── */
.portal-tv-hero {
  position: relative;
  width: 100%;
  border-radius: var(--radius-md);
  overflow: hidden;
  cursor: pointer;
  margin-bottom: 10px;
  border: 1px solid var(--border-glass);
}
.portal-tv-hero img {
  width: 100%;
  aspect-ratio: 16/9;
  object-fit: cover;
  display: block;
}
.portal-tv-hero-overlay {
  position: absolute;
  bottom: 0; left: 0; right: 0;
  padding: 16px;
  background: linear-gradient(transparent, rgba(0,0,0,0.85));
  display: flex;
  align-items: flex-end;
  gap: 12px;
}
.portal-tv-hero-info {
  flex: 1;
}
.portal-tv-hero-title {
  font-size: 15px;
  font-weight: 600;
  color: #fff;
  line-height: 1.3;
}
.portal-tv-hero-badge {
  font-size: 10px;
  color: #ff629a;
  text-transform: uppercase;
  letter-spacing: 0.5px;
  margin-top: 3px;
}
.portal-tv-toggle {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 6px;
  padding: 10px;
  font-size: 13px;
  font-weight: 600;
  color: var(--text-dim);
  letter-spacing: 0.5px;
  cursor: pointer;
  border: 1px solid var(--border-glass);
  border-radius: var(--radius-md);
  background: var(--bg-card);
  margin-bottom: 10px;
  transition: color 0.2s, border-color 0.2s;
}
.portal-tv-toggle:active { color: #ff629a; border-color: rgba(255,98,154,0.3); }
.portal-tv-toggle-arrow {
  transition: transform 0.3s;
  display: inline-block;
  font-size: 16px;
}
.portal-tv-toggle-arrow.open { transform: rotate(90deg); }
.portal-tv-grid {
  display: none;
  animation: portalTvFadeIn 0.25s ease;
}
.portal-tv-grid.open { display: block; }
@keyframes portalTvFadeIn { from { opacity: 0; transform: translateY(-8px); } to { opacity: 1; transform: translateY(0); } }
.portal-tv-pills {
  display: flex;
  gap: 8px;
  overflow-x: auto;
  padding-bottom: 10px;
  -webkit-overflow-scrolling: touch;
  scrollbar-width: none;
}
.portal-tv-pills::-webkit-scrollbar { display: none; }
.portal-tv-pill {
  flex: 0 0 auto;
  padding: 6px 14px;
  font-size: 11px;
  font-weight: 600;
  letter-spacing: 0.5px;
  border-radius: 20px;
  border: 1px solid var(--border-glass);
  color: var(--text-dim);
  background: transparent;
  cursor: pointer;
  transition: all 0.2s;
  white-space: nowrap;
  font-family: var(--font-body);
}
.portal-tv-pill.active {
  border-color: #ff629a;
  color: #ff629a;
  background: rgba(255,98,154,0.08);
}
.portal-tv-pill:active { opacity: 0.7; }
.portal-tv-grid-cards {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 10px;
}
.portal-tv-grid-cards .portal-tv-card {
  flex: none;
  width: 100%;
}
/* ── PORTAL TV LIBRARY OVERLAY ── */
.portal-tv-library-overlay {
  position: fixed; top: 0; left: 0; width: 100%; height: 100%;
  background: var(--bg-app, #080810); z-index: 9998;
  display: flex; flex-direction: column;
  opacity: 0; pointer-events: none;
  transition: opacity 0.25s;
}
.portal-tv-library-overlay.show { opacity: 1; pointer-events: auto; }
.portal-tv-library-header {
  display: flex; align-items: center; gap: 12px;
  padding: 16px; padding-top: max(16px, env(safe-area-inset-top));
  border-bottom: 1px solid rgba(255,255,255,0.06);
  flex-shrink: 0;
}
.portal-tv-library-back {
  background: none; border: none; color: #fff; font-size: 28px;
  padding: 0 8px; cursor: pointer; line-height: 1;
}
.portal-tv-library-title {
  font-family: var(--font-heading, 'Oswald', sans-serif);
  font-size: 18px; font-weight: 700; color: #fff;
  letter-spacing: 2px; text-transform: uppercase;
}
.portal-tv-library-pills {
  display: flex; gap: 8px; padding: 12px 16px;
  overflow-x: auto; -webkit-overflow-scrolling: touch;
  scrollbar-width: none; flex-shrink: 0;
}
.portal-tv-library-pills::-webkit-scrollbar { display: none; }
.portal-tv-library-grid {
  display: grid; grid-template-columns: 1fr 1fr;
  gap: 10px; align-content: start;
}
.portal-tv-library-grid .portal-tv-card {
  flex: none; width: 100%;
}
/* ── VIDEO PLAYER OVERLAY ── */
.video-player-overlay {
  position: fixed; top: 0; left: 0; width: 100%; height: 100%;
  background: rgba(0,0,0,0.95); z-index: 99999;
  display: flex; flex-direction: column; align-items: center; justify-content: flex-start;
  padding: 12px 16px 24px; overflow-y: auto; -webkit-overflow-scrolling: touch;
  opacity: 0; pointer-events: none;
  transition: opacity 0.25s ease;
}
.video-player-overlay.show { opacity: 1; pointer-events: auto; }
.video-player-close {
  background: none; border: none;
  color: #fff; font-size: 32px; cursor: pointer;
  padding: 0 6px; line-height: 1; flex-shrink: 0;
}
.video-player-title {
  font-family: 'Oswald', sans-serif; font-size: 14px; font-weight: 600;
  color: rgba(255,255,255,0.8); text-transform: uppercase; letter-spacing: 1px;
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
.video-player-frame {
  width: 100%; max-width: 720px;
  aspect-ratio: 16/9;
}
.video-player-frame iframe {
  width: 100%; height: 100%; border: none; border-radius: 8px;
}
.video-player-desc {
  width: 100%; max-width: 720px; padding: 12px 2px 0;
  font-size: 13px; line-height: 1.6; color: rgba(255,255,255,0.6);
  font-family: 'Inter', sans-serif;
  white-space: pre-line;
}
#video-player-upnext { width: 100%; max-width: 720px; }

.merch-featured {
  margin: 0 16px 14px;
  border-radius: var(--radius-md);
  overflow: hidden;
  background: var(--bg-card);
  border: 1px solid var(--border-glass);
  cursor: pointer;
  transition: border-color 0.2s;
}
.merch-featured:active { border-color: rgba(132,207,195,0.3); }
.merch-featured video {
  width: 100%;
  aspect-ratio: 1 / 1;
  object-fit: cover;
  display: block;
  pointer-events: none;
  background: #151520;
}
.merch-featured-body {
  padding: 12px 14px 14px;
  display: flex;
  align-items: center;
  justify-content: space-between;
}
.merch-featured-info { flex: 1; }
.merch-featured-name {
  font-size: 15px;
  font-weight: 700;
  color: var(--warm-white);
  font-family: var(--font-heading);
  text-transform: uppercase;
  letter-spacing: 0.5px;
}
.merch-featured-price {
  font-size: 14px;
  font-weight: 700;
  color: var(--cyan);
  margin-top: 2px;
}
.merch-featured-sold {
  font-size: 10px;
  color: var(--text-dim);
  text-transform: uppercase;
  letter-spacing: 0.5px;
  margin-top: 2px;
}
.merch-featured-badge {
  background: rgba(132,207,195,0.12);
  border: 1px solid rgba(132,207,195,0.2);
  border-radius: 20px;
  padding: 6px 14px;
  font-size: 11px;
  font-weight: 600;
  color: var(--cyan);
  text-transform: uppercase;
  letter-spacing: 1px;
  white-space: nowrap;
}

/* ── NOTIFICATIONS SUB-PAGE ── */
.notif-settings-overlay {
  position: fixed;
  inset: 0;
  z-index: 99991;
  background: var(--bg-deep);
  transform: translateX(100%);
  transition: transform 0.3s cubic-bezier(0.25,0.46,0.45,0.94);
  display: flex;
  flex-direction: column;
  overflow-y: auto;
  -webkit-overflow-scrolling: touch;
  pointer-events: none;
}
.notif-settings-overlay.show { transform: translateX(0); pointer-events: auto; }

.notif-settings-section { padding: 0 16px; margin-top: 8px; }
.notif-settings-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 16px;
  border-bottom: 1px solid var(--border-glass);
}
.notif-settings-row:last-child { border-bottom: none; }
.notif-settings-row-info { flex: 1; margin-right: 12px; }
.notif-settings-row-info .nsr-title { font-size: 15px; color: var(--warm-white); }
.notif-settings-row-info .nsr-subtitle { font-size: 12px; color: var(--text-dim); margin-top: 2px; }
.notif-settings-footnote {
  text-align: center;
  font-size: 12px;
  color: var(--text-dim);
  font-style: italic;
  padding: 16px 24px 40px;
}

/* Master notification-permission status block (top of Notifications page).
   Surfaces the REAL browser permission state so the category toggles below
   can't lie about being "on" while push is actually off. */
.notif-master-card { display:flex; align-items:center; gap:12px; padding:14px 16px; border-radius:14px; }
.notif-master-card.on  { background: rgba(52,211,153,0.10); border:1px solid rgba(52,211,153,0.25); }
.notif-master-card.off { background: rgba(255,255,255,0.05); border:1px solid rgba(255,255,255,0.10); }
.notif-master-card .nm-text { flex:1; min-width:0; }
.notif-master-card .nm-title { font-size:15px; font-weight:600; color: var(--warm-white); }
.notif-master-card .nm-sub { font-size:12px; color: var(--text-dim); margin-top:3px; line-height:1.45; }
.notif-master-card .nm-check { font-size:20px; color:#34d399; flex-shrink:0; }
.nm-enable-btn { flex-shrink:0; background:linear-gradient(90deg,#f97316,#14b8a6); border:none; color:#fff; font-weight:700; font-size:13px; letter-spacing:0.5px; padding:10px 20px; border-radius:10px; cursor:pointer; }
.nm-enable-btn:active { transform: scale(0.96); }

/* ── PRIVACY & DATA SUB-PAGE ── */
.privacy-overlay {
  position: fixed;
  inset: 0;
  z-index: 99991;
  background: var(--bg-deep);
  transform: translateX(100%);
  transition: transform 0.3s cubic-bezier(0.25,0.46,0.45,0.94);
  display: flex;
  flex-direction: column;
  overflow-y: auto;
  -webkit-overflow-scrolling: touch;
  pointer-events: none;
}
.privacy-overlay.show { transform: translateX(0); pointer-events: auto; }

.privacy-sheet-bg {
  position: fixed; inset: 0; z-index: 99992;
  background: rgba(0,0,0,0.6);
  opacity: 0; pointer-events: none;
  transition: opacity 0.3s;
}
.privacy-sheet-bg.show { opacity: 1; pointer-events: auto; }
.privacy-sheet {
  position: fixed;
  bottom: 0; left: 0; right: 0;
  z-index: 99993;
  background: var(--bg-card);
  border-radius: 20px 20px 0 0;
  max-height: 70vh;
  transform: translateY(100%);
  transition: transform 0.35s cubic-bezier(0.25,0.46,0.45,0.94);
  display: flex;
  flex-direction: column;
}
.privacy-sheet.show { transform: translateY(0); }
.privacy-sheet-title {
  font-size: 17px;
  font-weight: 600;
  text-align: center;
  padding: 20px 16px 12px;
  border-bottom: 1px solid var(--border-glass);
}
.privacy-sheet-body {
  padding: 16px 20px 0;
  overflow-y: auto;
  -webkit-overflow-scrolling: touch;
  font-size: 14px;
  line-height: 1.7;
  color: var(--text-secondary);
}
.privacy-sheet-body p { margin: 0 0 14px; }
.privacy-sheet-body p:last-child { margin-bottom: 8px; }
.privacy-sheet-close {
  display: block;
  width: calc(100% - 32px);
  margin: 12px 16px calc(16px + var(--safe-bottom));
  padding: 14px;
  background: rgba(132,207,195,0.12);
  border: none;
  border-radius: var(--radius-md);
  color: var(--cyan);
  font-size: 15px;
  font-weight: 600;
  cursor: pointer;
  font-family: 'Inter', sans-serif;
}

/* ── LOADING / EMPTY STATES ── */
.loading-spinner {
  width: 32px;
  height: 32px;
  border: 3px solid var(--border-glass);
  border-top: 3px solid var(--cyan);
  border-radius: 50%;
  animation: spin 0.8s linear infinite;
  margin: 40px auto;
}
@keyframes spin { to { transform: rotate(360deg); } }
@keyframes fadeInOut {
  0% { opacity: 0; transform: translateX(-50%) translateY(-10px); }
  15% { opacity: 1; transform: translateX(-50%) translateY(0); }
  80% { opacity: 1; transform: translateX(-50%) translateY(0); }
  100% { opacity: 0; transform: translateX(-50%) translateY(-10px); }
}

.empty-state {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  padding: 60px 24px;
  text-align: center;
  /* When placed inside a grid container (events-list on desktop), span all columns */
  grid-column: 1 / -1;
  width: 100%;
}
.empty-state-icon { font-size: 48px; margin-bottom: 16px; }
.empty-state-title { font-size: 18px; font-weight: 600; margin-bottom: 8px; }
.empty-state-text { font-size: 14px; color: var(--text-secondary); line-height: 1.5; max-width: 280px; }

/* ── WELCOME OVERLAY ── */
.welcome-overlay {
  position: fixed;
  top: 0; left: 0; right: 0; bottom: 0;
  z-index: 99994;
  background: var(--bg-deep);
  display: none;
  flex-direction: column;
  align-items: center;
  justify-content: flex-start;
  padding: max(60px, env(safe-area-inset-top, 60px)) 24px 32px;
  text-align: center;
  overflow-y: auto;
}
.welcome-overlay.show { display: flex; }
.welcome-logo {
  width: 80px;
  height: 80px;
  object-fit: contain;
  margin-bottom: -4px;
  filter: brightness(1.1);
}
.welcome-title {
  font-family: 'Oswald', 'Impact', sans-serif;
  font-weight: 700;
  font-size: clamp(44px, 9vw, 80px);
  line-height: 0.95;
  letter-spacing: -1px;
  text-transform: uppercase;
  color: #fff;
  margin-bottom: 24px;
  text-shadow: 0 4px 40px rgba(0,0,0,0.6), 0 0 80px rgba(132,207,195,0.15);
}
.welcome-card {
  display: flex;
  align-items: flex-start;
  gap: 16px;
  text-align: left;
  background: rgba(255,255,255,0.03);
  border: 1px solid var(--border-glass);
  border-radius: var(--radius-md);
  padding: 16px;
  margin-bottom: 12px;
  max-width: 380px;
  width: 100%;
}
.welcome-card-icon {
  font-size: 22px;
  flex-shrink: 0;
  width: 32px;
  text-align: center;
  padding-top: 2px;
}
.welcome-card-text h4 {
  font-size: 15px;
  font-weight: 600;
  margin-bottom: 4px;
}
.welcome-card-text p {
  font-size: 13px;
  color: var(--text-secondary);
  line-height: 1.5;
}
.welcome-enter-btn {
  margin-top: 28px;
  padding: 16px 48px;
  background: var(--gradient-portal);
  border: none;
  border-radius: var(--radius-md);
  color: #252525;
  font-size: 16px;
  font-weight: 700;
  font-family: 'Oswald', sans-serif;
  letter-spacing: 2px;
  text-transform: uppercase;
  cursor: pointer;
  transition: all 0.2s;
  box-shadow: 0 4px 24px rgba(132,207,195,0.25), 0 2px 12px rgba(255,98,154,0.2);
}
.welcome-enter-btn:hover { opacity: 0.9; transform: translateY(-1px); }
.welcome-enter-btn:active { transform: scale(0.98); }
.welcome-footer {
  margin-top: 20px;
  font-size: 12px;
  color: var(--text-dim);
  max-width: 320px;
  line-height: 1.5;
}

/* ── INSTALL PROMPT ── */
.install-prompt-overlay {
  position: fixed;
  top: 0; left: 0; right: 0; bottom: 0;
  z-index: 99995;
  background: rgba(26,24,24,0.92);
  backdrop-filter: blur(24px); -webkit-backdrop-filter: blur(24px);
  display: none;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  padding: 24px;
  text-align: center;
}
.install-prompt-overlay.show { display: flex; }

.install-prompt-card {
  width: 100%; max-width: 360px;
  background: rgba(30,28,28,0.95);
  border: 1px solid var(--border-glass);
  border-radius: 24px;
  padding: 32px 24px;
  position: relative;
}
.install-prompt-close {
  position: absolute; top: 14px; right: 14px;
  background: rgba(255,255,255,0.06); border: none;
  width: 30px; height: 30px; border-radius: 50%;
  color: var(--text-dim); font-size: 14px;
  cursor: pointer; display: flex; align-items: center; justify-content: center;
}
.install-prompt-close:hover { color: var(--text-primary); }
.install-prompt-icon {
  width: 64px; height: 64px;
  border-radius: 16px;
  margin: 0 auto 16px;
  overflow: hidden;
}
.install-prompt-icon img {
  width: 100%; height: 100%; object-fit: contain;
}
.install-prompt-title {
  font-family: 'Oswald', sans-serif;
  font-size: 22px; font-weight: 600;
  letter-spacing: 1px; text-transform: uppercase;
  margin-bottom: 8px;
  background: var(--gradient-portal);
  -webkit-background-clip: text; -webkit-text-fill-color: transparent;
}
.install-prompt-subtitle {
  font-size: 14px; color: var(--text-secondary);
  line-height: 1.5; margin-bottom: 24px;
}

.install-steps {
  text-align: left;
  margin-bottom: 24px;
}
.install-step {
  display: flex; align-items: flex-start; gap: 14px;
  margin-bottom: 16px;
}
.install-step:last-child { margin-bottom: 0; }
.install-step-num {
  width: 28px; height: 28px; border-radius: 50%;
  background: var(--gradient-portal);
  display: flex; align-items: center; justify-content: center;
  font-family: 'Oswald', sans-serif; font-weight: 700;
  font-size: 14px; color: var(--bg-deep);
  flex-shrink: 0;
}
.install-step-text {
  font-size: 14px; color: var(--text-primary);
  line-height: 1.5; padding-top: 3px;
}
.install-step-text .share-icon {
  display: inline-block; width: 18px; height: 18px;
  background: var(--cyan); border-radius: 4px;
  text-align: center; line-height: 18px; font-size: 11px;
  vertical-align: middle; margin: 0 2px;
  color: var(--bg-deep); font-weight: 700;
}
.install-step-text strong { color: var(--cyan); }

.install-prompt-btn {
  width: 100%;
  padding: 14px;
  background: var(--gradient-portal);
  border: none; border-radius: var(--radius-md);
  color: #252525; font-size: 15px; font-weight: 700;
  font-family: 'Oswald', sans-serif;
  letter-spacing: 1.5px; text-transform: uppercase;
  cursor: pointer; transition: all 0.2s;
}
.install-prompt-btn:hover { opacity: 0.9; }
.install-prompt-btn:active { transform: scale(0.98); }

.install-prompt-skip {
  background: none; border: none;
  color: var(--text-dim); font-size: 13px;
  cursor: pointer; margin-top: 14px;
  padding: 8px;
}
.install-prompt-skip:hover { color: var(--text-secondary); }

/* Android install button (native prompt) */
.install-prompt-android .install-steps { display: none; }

/* ── MEMBERSHIP GATE ── */
.membership-gate-overlay {
  position: fixed;
  top: 0; left: 0; right: 0; bottom: 0;
  z-index: 100001;
  background: var(--bg-deep);
  display: none;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  padding: 32px 24px;
  text-align: center;
}
.membership-gate-overlay.show { display: flex; }
.membership-gate-title {
  font-family: 'Oswald', 'Impact', sans-serif;
  font-weight: 700;
  font-size: clamp(28px, 6vw, 44px);
  line-height: 1;
  letter-spacing: -0.5px;
  text-transform: uppercase;
  color: #fff;
  margin: 16px 0 12px;
}
.membership-gate-body {
  max-width: 360px;
  margin: 0 auto 28px;
}
.membership-gate-body p {
  font-size: 15px;
  color: var(--text-secondary);
  line-height: 1.6;
}
.membership-gate-cta {
  display: inline-block;
  padding: 16px 48px;
  background: var(--gradient-portal);
  border: none;
  border-radius: var(--radius-md);
  color: #252525;
  font-size: 16px;
  font-weight: 700;
  font-family: 'Oswald', sans-serif;
  letter-spacing: 2px;
  text-transform: uppercase;
  cursor: pointer;
  text-decoration: none;
  transition: all 0.2s;
  box-shadow: 0 4px 24px rgba(132,207,195,0.25), 0 2px 12px rgba(255,98,154,0.2);
}
.membership-gate-cta:hover { opacity: 0.9; transform: translateY(-1px); }
.membership-gate-logout {
  margin-top: 16px;
  background: none;
  border: none;
  color: var(--text-dim);
  font-size: 13px;
  font-family: inherit;
  cursor: pointer;
  text-decoration: underline;
}
.membership-gate-logout:hover { color: var(--text-secondary); }

/* Trial badge in profile & nav */
.trial-badge {
  display: inline-block;
  padding: 3px 10px;
  background: linear-gradient(135deg, rgba(255,183,77,0.15), rgba(255,152,0,0.1));
  border: 1px solid rgba(255,183,77,0.3);
  border-radius: 20px;
  font-size: 11px;
  font-weight: 600;
  color: #ffb74d;
  letter-spacing: 0.5px;
}

/* ── EDIT PROFILE MODAL ── */
.edit-profile-overlay {
  position: fixed;
  top: 0; left: 0; right: 0; bottom: 0;
  background: rgba(0,0,0,0.7);
  z-index: 99995;
  display: flex;
  align-items: flex-end;
  justify-content: center;
  opacity: 0; visibility: hidden; pointer-events: none;
  transition: opacity 0.3s ease, visibility 0.3s ease;
}
.edit-profile-overlay.show { opacity: 1; visibility: visible; pointer-events: auto; }
@keyframes slideUpModal {
  from { transform: translateY(100%); opacity: 0; }
  to { transform: translateY(0); opacity: 1; }
}
.edit-profile-sheet {
  width: 100%;
  max-width: 480px;
  max-height: 88vh;
  background: var(--bg-glass-solid);
  border: 1px solid var(--border-glass);
  border-radius: var(--radius-xl) var(--radius-xl) 0 0;
  overflow-y: auto;
  transform: translateY(100%);
  transition: transform 0.35s cubic-bezier(0.32,0.72,0,1);
  padding-bottom: calc(20px + var(--safe-bottom));
}
.edit-profile-overlay.show .edit-profile-sheet { transform: translateY(0); }
.edit-profile-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 20px 20px 12px;
  border-bottom: 1px solid var(--border-glass);
  position: sticky;
  top: 0;
  background: var(--bg-glass-solid);
  z-index: 1;
}
.edit-profile-header h3 {
  font-family: 'Oswald', sans-serif;
  font-size: 18px;
  font-weight: 600;
  letter-spacing: 1px;
  text-transform: uppercase;
}
.edit-profile-close {
  background: none;
  border: none;
  color: var(--text-secondary);
  font-size: 24px;
  cursor: pointer;
  padding: 4px 8px;
  line-height: 1;
}
.edit-profile-close:hover { color: var(--text-primary); }
.edit-profile-body { padding: 20px; }
.edit-profile-avatar-section {
  display: flex;
  flex-direction: column;
  align-items: center;
  margin-bottom: 24px;
}
.edit-profile-avatar-preview {
  width: 80px;
  height: 80px;
  border-radius: 50%;
  border: 3px solid var(--cyan);
  object-fit: cover;
  margin-bottom: 10px;
  background: var(--bg-card);
}
.edit-profile-avatar-hint {
  font-size: 12px;
  color: var(--text-dim);
  text-align: center;
}
.edit-profile-field {
  margin-bottom: 18px;
}
.edit-profile-field label {
  display: block;
  font-size: 11px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 1.5px;
  color: var(--cyan);
  margin-bottom: 6px;
  font-family: 'Oswald', sans-serif;
}
.edit-profile-field input,
.edit-profile-field textarea {
  width: 100%;
  padding: 12px 14px;
  background: rgba(255,255,255,0.04);
  border: 1px solid var(--border-glass);
  border-radius: var(--radius-sm);
  color: var(--text-primary);
  font-size: 15px;
  font-family: 'Inter', sans-serif;
  transition: border-color 0.2s;
}
.edit-profile-field input:focus,
.edit-profile-field textarea:focus {
  outline: none;
  border-color: var(--cyan);
  box-shadow: 0 0 0 3px rgba(132,207,195,0.15);
}
.edit-profile-field textarea {
  resize: vertical;
  min-height: 80px;
  line-height: 1.5;
}
.edit-profile-interests-grid {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}
.edit-interest-chip {
  padding: 6px 14px;
  border-radius: 100px;
  font-size: 13px;
  border: 1px solid var(--border-glass);
  background: rgba(255,255,255,0.03);
  color: var(--text-secondary);
  cursor: pointer;
  transition: all 0.2s;
  user-select: none;
}
.edit-interest-chip.selected {
  background: var(--cyan-dim);
  border-color: var(--cyan);
  color: var(--cyan);
}
.edit-interest-chip:hover { background: rgba(255,255,255,0.06); }
.edit-interest-chip.selected:hover { background: rgba(132,207,195,0.25); }
.edit-interest-chip svg { width: 14px; height: 14px; vertical-align: -2px; margin-right: 2px; }
.edit-profile-save {
  width: 100%;
  padding: 14px;
  margin-top: 24px;
  background: var(--gradient-portal);
  border: none;
  border-radius: var(--radius-md);
  color: #252525;
  font-size: 15px;
  font-weight: 700;
  font-family: 'Oswald', sans-serif;
  letter-spacing: 1.5px;
  text-transform: uppercase;
  cursor: pointer;
  transition: opacity 0.2s, transform 0.1s;
}
.edit-profile-save:hover { opacity: 0.9; }
.edit-profile-save:active { transform: scale(0.98); }
.edit-profile-saved-msg {
  text-align: center;
  color: var(--cyan);
  font-size: 13px;
  margin-top: 10px;
  opacity: 0;
  transition: opacity 0.3s;
}
.edit-profile-saved-msg.show { opacity: 1; }

/* ── SWIPE MEMBER CARD ── */
.swipe-card-overlay {
  position: fixed;
  top: 0; left: 0; right: 0; bottom: 0;
  z-index: 99994;
  background: rgba(26,24,24,0.92);
  backdrop-filter: blur(30px);
 -webkit-backdrop-filter: blur(30px);
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  padding: 16px;
  text-align: center;
  transform: translateX(100%);
  transition: transform 0.3s cubic-bezier(0.32,0.72,0,1);
  pointer-events: none;
}
.swipe-card-overlay.show { transform: translateX(0); pointer-events: auto; }
.swipe-card-close {
  position: absolute;
  top: max(16px, env(safe-area-inset-top));
  right: 16px;
  width: 36px; height: 36px;
  border-radius: 50%;
  background: rgba(255,255,255,0.1);
  border: none;
  color: var(--text-secondary);
  font-size: 20px;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 5;
}
.swipe-card-close:hover { color: var(--text-primary); }

/* Swipeable card */
.swipe-card {
  position: relative;
  width: 100%;
  max-width: 340px;
  border-radius: var(--radius-xl);
  overflow: hidden;
  background: var(--bg-card);
  border: 1px solid var(--border-glass);
  box-shadow: 0 20px 60px rgba(0,0,0,0.5);
  user-select: none;
  cursor: grab;
  will-change: transform;
}
.swipe-card:active { cursor: grabbing; }
.swipe-card.animating {
  transition: transform 0.4s cubic-bezier(0.22, 1, 0.36, 1), opacity 0.4s ease;
}

/* Big photo hero */
.swipe-card-photo-wrap {
  position: relative;
  width: 100%;
  aspect-ratio: 3/4;
  max-height: 380px;
  overflow: hidden;
  background: var(--bg-deep);
}
.swipe-card-photo {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}
.swipe-card-gradient {
  position: absolute;
  bottom: 0; left: 0; right: 0;
  height: 55%;
  background: linear-gradient(transparent, rgba(26,24,24,0.95));
  pointer-events: none;
}
.swipe-card-info {
  position: absolute;
  bottom: 0; left: 0; right: 0;
  padding: 20px;
  z-index: 2;
  text-align: left;
}
.swipe-card-name {
  font-family: 'Oswald', sans-serif;
  font-size: 28px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 1px;
  color: #fff;
  text-shadow: 0 2px 10px rgba(0,0,0,0.5);
}
.swipe-card-location {
  font-size: 14px;
  color: rgba(255,255,255,0.7);
  margin-top: 2px;
}

/* Details below photo */
.swipe-card-details {
  padding: 14px 20px 18px;
  text-align: left;
}
.swipe-card-bio {
  font-size: 13px;
  line-height: 1.6;
  color: var(--text-secondary);
  margin-bottom: 12px;
}
.swipe-card-interests {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
}
.member-profile-interest {
  padding: 5px 12px;
  border-radius: 100px;
  background: var(--cyan-dim);
  color: var(--cyan);
  font-size: 11px;
  font-weight: 500;
}

/* Swipe stamp */
.swipe-stamp {
  position: absolute;
  top: 60px;
  z-index: 10;
  font-family: 'Oswald', sans-serif;
  font-size: 28px;
  font-weight: 700;
  letter-spacing: 3px;
  text-transform: uppercase;
  padding: 6px 16px;
  border-radius: 10px;
  border: 3px solid;
  opacity: 0;
  pointer-events: none;
}
.swipe-stamp.hello {
  left: 50%;
  transform: translateX(-50%) rotate(-5deg);
  color: var(--cyan);
  border-color: var(--cyan);
  white-space: nowrap;
}

/* Action buttons */
.swipe-actions {
  display: flex;
  gap: 16px;
  margin-top: 20px;
  align-items: center;
  justify-content: center;
}
.swipe-btn {
  border-radius: 100px;
  border: 2px solid;
  background: rgba(255,255,255,0.04);
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  cursor: pointer;
  transition: all 0.2s;
  font-family: 'Oswald', sans-serif;
  font-weight: 600;
  letter-spacing: 1px;
  text-transform: uppercase;
}
.swipe-btn.hello-btn {
  padding: 14px 32px;
  border-color: var(--cyan);
  color: var(--cyan);
  font-size: 16px;
}
.swipe-btn.hello-btn:hover { background: var(--cyan-dim); transform: scale(1.05); }
.swipe-btn.hello-btn .btn-icon { font-size: 20px; }
.swipe-btn.circle-btn {
  padding: 14px 20px;
  border-color: var(--orange);
  color: var(--orange);
  font-size: 13px;
}
.swipe-btn.circle-btn:hover { background: var(--orange-dim); transform: scale(1.05); }
.swipe-hint {
  margin-top: 14px;
  font-size: 11px;
  color: var(--text-dim);
  letter-spacing: 1px;
}

/* ── SWIPE-BACK GESTURE ── */
.swipe-back-indicator {
  position: fixed;
  left: 0; top: 0; bottom: 0;
  width: 40px;
  z-index: 99999;
  pointer-events: none;
  opacity: 0;
  background: linear-gradient(90deg, rgba(132,207,195,0.25), transparent);
  transition: opacity 0.15s;
}
.swipe-back-indicator.active { opacity: 1; }
.swipe-back-arrow {
  position: absolute;
  left: 8px;
  top: 50%;
  transform: translateY(-50%);
  font-size: 22px;
  color: var(--cyan);
  opacity: 0;
  transition: opacity 0.15s, transform 0.15s;
}
.swipe-back-indicator.active .swipe-back-arrow {
  opacity: 1;
  transform: translateY(-50%) translateX(4px);
}

/* ── COMMUNITY GUIDELINES MODAL ── */
.guidelines-overlay {
  position: fixed;
  top: 0; left: 0; right: 0; bottom: 0;
  z-index: 99993;
  background: var(--bg-deep);
  display: flex;
  flex-direction: column;
  overflow-y: auto;
 -webkit-overflow-scrolling: touch;
  transform: translateX(100%);
  transition: transform 0.3s cubic-bezier(0.32,0.72,0,1);
  pointer-events: none;
}
.guidelines-overlay.show { transform: translateX(0); pointer-events: auto; }
.guidelines-header {
  position: sticky;
  top: 0;
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 16px 20px;
  padding-top: max(16px, env(safe-area-inset-top));
  background: var(--bg-glass-solid);
  backdrop-filter: blur(20px);
 -webkit-backdrop-filter: blur(20px);
  border-bottom: 1px solid var(--border-glass);
  z-index: 2;
}
.guidelines-header h3 {
  font-family: 'Oswald', sans-serif;
  font-size: 18px;
  font-weight: 600;
  color: var(--text-primary);
}
.guidelines-close {
  background: none;
  border: none;
  color: var(--text-secondary);
  font-size: 28px;
  cursor: pointer;
  padding: 0 4px;
}
.guidelines-body {
  padding: 24px 20px;
  padding-bottom: calc(24px + var(--safe-bottom));
  max-width: 600px;
  margin: 0 auto;
  width: 100%;
}
.guidelines-intro {
  font-size: 14px;
  line-height: 1.7;
  color: rgba(240,232,255,0.92);
  margin-bottom: 28px;
}
.guideline-section {
  margin-bottom: 24px;
}
.guideline-section-title {
  font-family: 'Oswald', sans-serif;
  font-size: 15px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 1px;
  margin-bottom: 12px;
  display: flex;
  align-items: center;
  gap: 8px;
}
.guideline-section-title .gs-icon {
  font-size: 16px;
}
.guideline-rule {
  font-size: 13px;
  line-height: 1.7;
  color: rgba(240,232,255,0.88);
  padding: 10px 14px;
  background: rgba(255,255,255,0.02);
  border: 1px solid var(--border-glass);
  border-radius: var(--radius-sm);
  margin-bottom: 8px;
}
.guideline-rule strong {
  color: var(--text-primary);
  font-weight: 600;
}
.guidelines-footer {
  margin-top: 32px;
  padding-top: 20px;
  border-top: 1px solid var(--border-glass);
  font-size: 12px;
  color: var(--text-dim);
  line-height: 1.7;
  text-align: center;
}
.chat-warning {
  background: rgba(255,163,0,0.12);
  border: 1px solid rgba(255,163,0,0.25);
  border-radius: var(--radius-sm);
  padding: 8px 12px;
  margin: 0 16px 8px;
  font-size: 12px;
  color: var(--orange);
  text-align: center;
  display: none;
}
.chat-warning.show { display: block; }

/* ── CIRCLE INVITE BUTTON ── */
.circle-invite-btn {
  width: 32px; height: 32px; min-width: 32px;
  border-radius: 50%;
  background: rgba(132,207,195,0.12);
  border: 1px solid rgba(132,207,195,0.2);
  color: var(--cyan);
  display: flex; align-items: center; justify-content: center;
  font-size: 18px; font-weight: 300;
  cursor: pointer; align-self: center;
  transition: all 0.2s;
}
.circle-invite-btn:active { transform: scale(0.9); background: rgba(132,207,195,0.25); }

/* ── Digest frequency segmented picker ── */
.digest-freq-opt {
  flex: 1;
  padding: 10px 12px;
  background: rgba(255,255,255,0.04);
  border: 1px solid rgba(255,255,255,0.08);
  color: rgba(255,255,255,0.6);
  font-family: 'Oswald', sans-serif;
  font-size: 11px;
  font-weight: 600;
  letter-spacing: 1.2px;
  text-transform: uppercase;
  cursor: pointer;
  border-radius: 10px;
  -webkit-tap-highlight-color: transparent;
  transition: background 0.15s, border-color 0.15s, color 0.15s;
}
.digest-freq-opt:active { transform: scale(0.98); }
.digest-freq-opt.active {
  background: rgba(132,207,195,0.14);
  border-color: rgba(132,207,195,0.45);
  color: #84cfc3;
}

/* ── CHAT HEADER MUTE BUTTON ── */
.chat-mute-btn {
  transition: color 0.18s;
  position: relative;
}
.chat-mute-btn.muted { color: #ff629a; }
.chat-mute-btn:hover { color: var(--text-primary); }
.chat-mute-btn.muted:hover { color: #ff629a; }
/* Diagonal strike drawn in the button's padding, not inside the SVG. */
.chat-mute-btn.muted::before {
  content: '';
  position: absolute;
  top: 50%; left: 50%;
  width: 26px; height: 2px;
  background: currentColor;
  transform: translate(-50%, -50%) rotate(-45deg);
  border-radius: 2px;
  pointer-events: none;
}

/* ── CHAT HEADER INVITE BUTTON ── */
.chat-invite-btn {
  width: 36px; height: 36px; min-width: 36px;
  border-radius: 50%;
  background: rgba(132,207,195,0.12);
  border: 1px solid rgba(132,207,195,0.2);
  color: var(--cyan);
  display: flex; align-items: center; justify-content: center;
  cursor: pointer; margin-left: auto; flex-shrink: 0;
  transition: all 0.2s;
}
.chat-invite-btn:active { transform: scale(0.9); background: rgba(132,207,195,0.25); }
.chat-invite-btn svg { width: 16px; height: 16px; }

/* ── INVITE TOAST (appears after sharing) ── */
.invite-toast {
  position: fixed; bottom: 100px; left: 50%; transform: translateX(-50%);
  background: var(--bg-elevated); border: 1px solid var(--cyan);
  border-radius: 14px; padding: 12px 20px;
  color: var(--text-primary); font-size: 14px; font-weight: 500;
  z-index: 100010; white-space: nowrap;
  animation: slideUp 0.3s ease, fadeOut 0.3s ease 2.7s forwards;
}

/* ── DESKTOP RESPONSIVENESS ── */
@media (min-width: 600px) {
  .screen, .chat-view, .event-detail, .profile-view, .onboard-screen,
  .bd-city-detail, .bd-city-list, .dm-view, .dm-chat-view {
    max-width: 480px;
    margin: 0 auto;
    border-left: 1px solid var(--border-glass);
    border-right: 1px solid var(--border-glass);
  }
  #bottom-nav {
    max-width: 480px;
    margin: 0 auto;
    left: 50%;
    transform: translateX(-50%);
    border-left: 1px solid var(--border-glass);
    border-right: 1px solid var(--border-glass);
  }
  .auth-screen {
    max-width: none !important;
    border-left: none !important;
    border-right: none !important;
  }
  .onboarding-screen {
    max-width: none !important;
    border-left: none !important;
    border-right: none !important;
  }
  .notif-prompt, .ig-share-modal { max-width: 480px; margin: 0 auto; left: 50%; transform: translateX(-50%); }
  body { background: #1a1818; }
}

/* ── RESPONSIVE ── */
@media (max-width: 480px) {
  .auth-title { font-size: 24px; }
  .event-card-image { height: 120px; }
}

/* ══════════════════════════════════════════════════ */
/* ── DESKTOP LAYOUT (769px+) ──                     */
/* ══════════════════════════════════════════════════ */
.desktop-sidebar { display: none; }

@media (min-width: 769px) {

  /* ── Override the 600px tablet constraint ── */
  .screen, .chat-view, .event-detail, .profile-view, .onboard-screen,
  .bd-city-detail, .bd-city-list, .dm-view, .dm-chat-view {
    max-width: none !important;
    margin: 0 !important;
    border-left: none !important;
    border-right: none !important;
  }
  #bottom-nav { display: none !important; }
  body { background: #1a1818; }

  /* ── Sidebar ── */
  .desktop-sidebar {
    display: flex;
    flex-direction: row;
    align-items: center;
    position: fixed;
    top: 0; left: 0; right: 0;
    height: 56px;
    z-index: 999;
    background: rgba(26,24,24,0.95);
    border-bottom: 1px solid rgba(255,255,255,0.06);
    padding: 0 20px;
    gap: 0;
    backdrop-filter: blur(12px);
    -webkit-backdrop-filter: blur(12px);
  }
  .desktop-sidebar::-webkit-scrollbar { width: 0; }

  /* Hide hamburger, backdrop, vertical layout elements */
  .ds-hamburger { display: none !important; }
  .ds-backdrop { display: none !important; }
  .ds-user-info { display: none !important; }
  .ds-footer { display: none !important; }

  /* Logo in top nav */
  .ds-logo { height: 24px; margin-right: 32px; }

  /* Nav items horizontal */
  .ds-nav {
    display: flex !important;
    flex-direction: row !important;
    gap: 4px !important;
    padding: 0 !important;
    flex: 1;
  }
  .ds-nav-item {
    flex-direction: row !important;
    gap: 8px !important;
    padding: 8px 16px !important;
    border-radius: 8px !important;
    font-size: 14px !important;
  }
  .ds-nav-item::before { display: none !important; }
  .ds-nav-item svg { width: 18px !important; height: 18px !important; }
  .ds-nav-label { font-size: 14px !important; }

  /* Profile avatar in top-right */
  .ds-nav + .ds-footer { display: none !important; }
  .desktop-sidebar .ds-founder-link { display: none !important; }

  .ds-brand { display: none !important; }
  .ds-logo {
    height: 24px;
    filter: brightness(0) invert(1);
    flex-shrink: 0;
  }

  .ds-user {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 0 24px 24px;
    cursor: pointer;
  }
  .ds-user-info {
    min-width: 0;
  }
  .ds-user-name {
    font-size: 14px;
    font-weight: 600;
    color: var(--warm-white);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
  }
  .ds-user-city {
    font-size: 12px;
    color: var(--text-dim);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
  }

  .ds-nav {
    flex: 1;
    padding: 0;
  }
  .ds-nav-item {
    display: flex;
    align-items: center;
    gap: 14px;
    height: 48px;
    padding: 0 24px;
    cursor: pointer;
    color: #666;
    font-size: 15px;
    font-weight: 500;
    transition: color 0.15s, background 0.15s;
    position: relative;
    user-select: none;
  }
  .ds-nav-item:hover {
    color: #999;
    background: rgba(255,255,255,0.02);
  }
  .ds-nav-item.active {
    color: var(--warm-white);
  }
  .ds-nav-item.active::before {
    content: '';
    position: absolute;
    left: 0; top: 8px; bottom: 8px;
    width: 3px;
    background: #ffa300;
    border-radius: 0 3px 3px 0;
  }
  .ds-nav-item svg {
    width: 22px;
    height: 22px;
    flex-shrink: 0;
  }
  .ds-nav-label { flex: 1; }
  .ds-nav-badge {
    background: var(--magenta);
    color: #fff;
    font-size: 11px;
    font-weight: 700;
    min-width: 18px;
    height: 18px;
    border-radius: 9px;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 0 5px;
  }
  .ds-nav-badge:empty { display: none; }

  .ds-footer {
    padding: 20px 24px;
    border-top: 1px solid rgba(255,255,255,0.06);
  }
  .ds-founder-link {
    display: flex;
    align-items: center;
    gap: 8px;
    font-size: 12px;
    color: #555;
    cursor: pointer;
    transition: color 0.15s;
    line-height: 1.4;
  }
  .ds-founder-link:hover { color: #888; }
  .ds-founder-pulse {
    width: 6px; height: 6px;
    border-radius: 50%;
    background: var(--cyan);
    flex-shrink: 0;
    animation: founderPulse 2s infinite;
  }

  /* ── Main content area — full width, below top nav ── */
  .screen {
    left: 0 !important;
    right: 0 !important;
    top: 56px !important;
  }
  .screen.active {
    display: flex;
    flex-direction: column;
    align-items: center;
  }
  /* Community tab: full-width scroll */
  #screen-circles.active {
    align-items: stretch;
  }
  /* Watch tab: full width */
  #screen-watch > * {
    max-width: none !important;
  }

  /* Auth + onboarding: full width, no sidebar offset */
  .auth-screen, .onboarding-screen {
    left: 0 !important;
  }

  /* ── Desktop headers: replace logo + avatar with screen title ── */
  .screen > .app-header {
    position: relative !important;
    background: transparent !important;
    backdrop-filter: none !important;
    -webkit-backdrop-filter: none !important;
    border-bottom: none !important;
    max-width: 680px;
    width: 100%;
    padding: 28px 24px 16px !important;
    justify-content: flex-start !important;
  }
  .screen > .app-header .app-header-logo { display: none !important; }
  .screen > .app-header .app-header-right { display: none !important; }
  .screen > .app-header .header-avatar { display: none !important; }
  .screen > .app-header::after {
    /* Titles are redundant with the top nav label — hidden on desktop */
    display: none !important;
  }
  .screen > .app-header {
    display: none !important;
  }
  #screen-circles > .app-header::after { content: 'Community'; }
  #screen-events > .app-header::after { content: 'Events'; }

  /* Watch tab: fill entire content area edge-to-edge */
  #screen-watch {
    align-items: stretch !important;
    padding: 0 !important;
  }
  #screen-watch > div {
    width: 100% !important;
    max-width: none !important;
    height: 100% !important;
  }
  #screen-watch iframe {
    width: 100% !important;
    height: 100% !important;
  }
  #screen-journey > .app-header::after { content: 'Journey'; }
  #screen-messages > .app-header::after { content: 'Messages'; }
  #screen-profile > .app-header::after { content: 'Profile'; }
  #screen-journal > .app-header::after { content: 'Journal'; }

  .top-profile-btn { display: none !important; }

  /* ── Desktop: disable nested scroll on community tab, let the screen scroll ── */
  .circles-screen .circles-list {
    overflow-y: visible !important;
    flex: none !important;
  }

  /* ── Content centering ── */
  .circles-list {
    max-width: 680px;
    width: 100%;
    margin: 0 auto;
  }
  .events-list {
    max-width: 680px;
    width: 100%;
    margin: 0 auto;
  }

  /* ── Community tab: taller circle cards ── */
  .circle-card {
    min-height: 100px;
  }
  .circle-card .circle-card-photo {
    height: 100px;
  }

  /* ── All screens center their children ── */
  .screen.active {
    align-items: center;
  }
  .screen > * {
    max-width: 680px;
    width: 100%;
  }
  /* Map screen uses the full viewport — override the 680px centered-column cap.
     Scoped to the map container + header only; the floating .map-near-me button
     must keep its 44px square dimensions (not stretch to full width). */
  #screen-map > #map-container,
  #screen-map > .app-header {
    max-width: none !important;
    width: 100% !important;
    left: 0 !important;
    right: 0 !important;
  }

  /* ── Remove bottom-nav padding on desktop ── */
  .circles-screen {
    padding-bottom: 0 !important;
  }
  .events-list {
    padding-bottom: 32px !important;
  }

  /* ── Community: 2-col nearby circles ── */
  #nearby-circles-container {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 12px;
  }

  /* ── Events: 3-col event cards on desktop ── */
  .events-list {
    max-width: 1020px;
    display: grid !important;
    grid-template-columns: repeat(3, 1fr);
    grid-auto-rows: min-content;
    gap: 16px;
    padding-bottom: 32px !important;
  }
  .events-list .event-card {
    margin-bottom: 0;
    min-width: 0;
    overflow: hidden;
  }
  .events-list .event-card .event-card-image {
    height: 160px;
    max-height: 160px;
  }
  /* Description preview — desktop only */
  .events-list .event-card .event-card-desc {
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
    font-size: 12.5px;
    color: var(--text-dim);
    line-height: 1.4;
    margin-bottom: 8px;
  }
  .events-list .past-events-divider,
  .events-list .past-events-section {
    grid-column: 1 / -1;
  }
  .events-list .past-events-section {
    display: none;
    grid-template-columns: repeat(3, 1fr);
    gap: 16px;
  }
  .events-list .past-events-section.expanded {
    display: grid;
  }
  .events-list .past-events-section .event-card {
    margin-bottom: 0;
  }

  /* ── Events screen: scroll entire screen on desktop (not just events-list) ── */
  .events-screen {
    overflow-y: auto !important;
    overflow-x: hidden !important;
  }
  .events-screen .events-list {
    overflow-y: visible !important;
    flex: none !important;
  }

  /* ── Events screen: search + filters match 3-col grid width ── */
  .events-screen .events-search-bar,
  .events-screen .events-city-bar,
  .events-screen .events-result-count,
  .events-screen .events-filters,
  .events-screen .bicycle-day-banner {
    max-width: 1020px;
    width: 100%;
  }
  /* Bigger filter pills on desktop */
  .events-screen .event-filter {
    padding: 10px 20px;
    font-size: 14px;
  }
  .events-screen .events-filters {
    gap: 10px;
    padding: 10px 16px;
  }
  /* BD banner: bigger on desktop */
  .events-screen .bicycle-day-banner {
    min-height: 200px;
    padding-right: 220px;
  }
  .events-screen .bicycle-day-banner img[alt="Bicycle Day"] {
    height: 72px !important;
  }
  .events-screen .bicycle-day-banner-sub {
    font-size: 17px;
    line-height: 1.4;
  }
  .events-screen .bd-banner-albert {
    width: 190px;
    right: 5px;
    top: 5px;
    bottom: 5px;
  }

  /* ── Overlays: span full viewport (over sidebar) ── */
  .chat-view, .dm-chat-view, .member-profile-overlay,
  .directory-overlay, .event-detail, .about-portal-overlay,
  .notif-settings-overlay, .bd-city-detail,
  .organizer-profile-overlay, .organizer-claim-overlay {
    left: 0 !important;
    right: 0 !important;
    max-width: none !important;
  }

  /* ── Event detail hero: contain on desktop with matching bg ── */
  .event-detail-hero {
    height: auto !important;
    min-height: 300px !important;
    max-height: 420px !important;
    background: #2d1b4e !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
  }
  .event-detail-hero img {
    object-fit: contain !important;
    width: auto !important;
    max-width: 100% !important;
    height: auto !important;
    max-height: 420px !important;
  }

  /* ── BD list hero: hide poster on desktop, show custom hero ── */
  .bd-list-hero-img {
    display: none !important;
  }
  .bd-desktop-hero {
    display: flex !important;
    align-items: center;
    justify-content: center;
    gap: 40px;
    padding: 40px 20px 30px;
    position: relative;
  }
  .bd-desktop-hero-lottie {
    width: 180px;
    height: 180px;
    flex-shrink: 0;
  }
  .bd-desktop-hero-center {
    text-align: center;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 8px;
  }
  .bd-desktop-hero-logo {
    height: 160px;
    width: auto;
    filter: brightness(1.1);
  }
  .bd-desktop-hero-date {
    font-family: var(--font-heading);
    font-size: 28px;
    font-weight: 700;
    color: #E28861;
    letter-spacing: 3px;
  }
  .bd-desktop-hero-sub {
    font-family: var(--font-heading);
    font-size: 14px;
    font-weight: 600;
    color: rgba(244,244,190,0.8);
    letter-spacing: 2px;
  }
  /* Hide the duplicate label + title on desktop since desktop hero covers it */
  .bd-list-hero-label,
  .bd-list-hero-title {
    display: none !important;
  }
  .bd-list-hero {
    max-width: 900px !important;
    margin: 0 auto !important;
    text-align: center;
  }
  .bd-list-hero-sub {
    font-size: 18px !important;
    line-height: 1.6 !important;
  }
  /* bd-detail-hero desktop sizing handled in base CSS via media query */

  /* ── Map screen: offset by sidebar ── */
  #screen-map {
    left: 0 !important;
  }

  /* ── Profile: let profile internals fill centered column ── */
  .profile-screen .profile-header,
  .profile-screen .profile-stats,
  .profile-screen .profile-interests,
  .profile-screen .profile-section {
    max-width: 680px;
    width: 100%;
  }

  /* ── Messages: dm-inbox fills centered column ── */
  .messages-screen .dm-inbox {
    max-width: 680px;
    width: 100%;
  }

  /* ── Events FAB: pin to viewport edge on desktop (well clear of the content grid) ── */
  .event-submit-fab {
    right: 40px !important;
    bottom: 40px !important;
  }

  /* ── Submit event form: centered, contained on desktop ── */
  .event-submit-modal {
    display: flex !important;
    flex-direction: column !important;
    align-items: center !important;
    justify-content: flex-start !important;
    padding: 80px 24px 40px !important;
    overflow-y: auto !important;
    backdrop-filter: blur(12px);
    -webkit-backdrop-filter: blur(12px);
    background: rgba(8,8,16,0.85) !important;
  }
  .event-submit-modal .event-submit-header {
    border-radius: 16px 16px 0 0;
    max-width: 540px;
    width: 100%;
    background: var(--bg-card);
    border: 1px solid var(--border-glass);
    border-bottom: 1px solid var(--border-glass);
    position: relative;
  }
  .event-submit-modal .event-submit-header .chat-back {
    font-size: 22px;
    color: var(--text-primary);
    opacity: 1;
  }
  .event-submit-modal .event-submit-body {
    max-width: 540px;
    width: 100%;
    padding: 28px 32px 40px;
    background: var(--bg-card);
    border-radius: 0 0 16px 16px;
    border: 1px solid var(--border-glass);
    border-top: none;
  }
  .event-submit-modal .event-submit-body .onboard-input,
  .event-submit-modal .event-submit-body select,
  .event-submit-modal .event-submit-body .onboard-bio {
    font-size: 15px;
    padding: 12px 16px;
  }
  .event-submit-modal .event-submit-body label {
    font-size: 12px;
    margin-bottom: 6px;
  }

  /* ── Notification prompts: center in content area ── */
  .notif-prompt, .ig-share-modal {
    max-width: 480px !important;
    left: 0 !important;
    right: 0 !important;
    margin: 0 auto !important;
  }

  /* ── Overlays: centered content column on wide screens ── */
  .event-detail .event-detail-content,
  .event-detail .event-detail-body {
    max-width: 760px;
    margin: 0 auto;
  }
  .chat-view .chat-messages {
    max-width: 720px;
    margin: 0 auto;
    width: 100%;
  }
  .chat-view .chat-input-bar {
    max-width: 720px;
    margin: 0 auto;
    width: 100%;
  }
  .chat-view .chat-header {
    max-width: 720px;
    margin: 0 auto;
    width: 100%;
  }

  /* ── Journey screen: center content ── */
  .journey-screen .journey-content,
  .journey-screen .journey-cards,
  #screen-journey > * {
    max-width: 680px;
    width: 100%;
  }

  /* ── Journal screen: center content ── */
  #screen-journal > * {
    max-width: 680px;
    width: 100%;
  }

  /* ── BD City detail: centered column ── */
  .bd-city-detail .bd-city-content {
    max-width: 720px;
    margin: 0 auto;
  }

  /* ── Member profile overlay: centered ── */
  .member-profile-overlay .member-profile-content {
    max-width: 560px;
    margin: 0 auto;
  }

  /* ── Desktop hover polish ── */
  .circle-card:hover {
    border-color: rgba(132,207,195,0.2);
    transform: translateY(-1px);
    transition: all 0.2s;
  }
  .ds-user:hover .ds-user-name {
    color: var(--cyan);
  }
}

/* Desktop event-detail: extra bottom padding so fixed RSVP bar doesn't cover attendees/photos */
@media (min-width: 769px) {
  .event-detail-body {
    padding-bottom: calc(200px + var(--safe-bottom)) !important;
  }
  .event-attendees-section,
  .event-photos-section {
    padding-bottom: 140px !important;
  }
  /* Portal hub: keep the "Become a Member" button compact, not full-width on desktop */
  #screen-portal #portal-hub-member-card button {
    max-width: 320px !important;
    margin: 0 auto !important;
    display: block !important;
  }
}

/* ══════════════════════════════════════════════════ */
/* ── WIDE DESKTOP (1200px+) — more breathing room ── */
/* ══════════════════════════════════════════════════ */
@media (min-width: 1200px) {
  /* Page titles (rendered via ::after on .app-header) match the wider content */
  .screen > .app-header {
    max-width: 1240px !important;
  }
  /* Wider event grid container */
  .events-screen .events-search-bar,
  .events-screen .events-city-bar,
  .events-screen .events-result-count,
  .events-screen .events-filters,
  .events-screen .bicycle-day-banner,
  .events-list {
    max-width: 1240px !important;
  }
  /* 4-column grid on wide screens */
  .events-list {
    grid-template-columns: repeat(4, 1fr) !important;
  }
  .events-list .past-events-section {
    grid-template-columns: repeat(4, 1fr) !important;
  }
  /* Circles list wider too */
  .circles-list {
    max-width: 1120px !important;
  }
  #nearby-circles-container {
    grid-template-columns: repeat(3, 1fr) !important;
  }
  /* Portal hub: remove the 680px/1020px constraint — let content breathe across the viewport */
  .portal-hub-screen .screen-content,
  #screen-portal > .screen-content {
    max-width: 1240px !important;
    padding-left: 24px !important;
    padding-right: 24px !important;
  }
  .portal-hub-screen .screen-content > *,
  #screen-portal > * {
    max-width: 100% !important;
  }
  /* Portal TV grid: 4 columns on wide */
  .portal-tv-grid-cards {
    grid-template-columns: repeat(4, 1fr) !important;
  }
}

/* ══════════════════════════════════════════════════ */
/* ── SIGN IN CHIP: blend into desktop nav ──        */
/* ══════════════════════════════════════════════════ */
@media (min-width: 769px) {
  #public-signin-chip {
    top: 10px !important;
    right: 20px !important;
    padding: 7px 18px !important;
    font-size: 13px !important;
    background: linear-gradient(135deg, var(--cyan), var(--magenta)) !important;
    z-index: 1001 !important;
  }
}
/* Public-mode backdrop: fade the very top strip so the floating sign-in chip
   doesn't visually overlap page content scrolling behind it. Only applied
   when logged out (portal-public-mode) and hidden on desktop where the
   chip lives inside the sidebar. */
body.portal-public-mode::before {
  content: '';
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  height: calc(env(safe-area-inset-top, 0px) + 56px);
  background: linear-gradient(180deg, rgba(8,8,16,0.82) 0%, rgba(8,8,16,0.55) 60%, rgba(8,8,16,0) 100%);
  backdrop-filter: blur(14px) saturate(140%);
  -webkit-backdrop-filter: blur(14px) saturate(140%);
  z-index: 99997;
  pointer-events: none;
}
@media (min-width: 769px) {
  body.portal-public-mode::before { display: none; }
}

/* ══════════════════════════════════════════════════ */
/* ── PUBLIC (LOGGED-OUT) MODE: hide auth-only UI ── */
/* ══════════════════════════════════════════════════ */
/* Signed-out ("public") mode: strip every header affordance that's only
   meaningful once you have an account (DMs, notifications, profile ring).
   The floating Sign In chip lives on top; anything behind it is visual noise. */
body.portal-public-mode .header-dm-btn,
body.portal-public-mode .header-notif-btn,
body.portal-public-mode .ds-topnav-dm,
body.portal-public-mode .ds-topnav-bell,
body.portal-public-mode .ds-topnav-profile,
body.portal-public-mode .app-header .avatar-ring,
body.portal-public-mode .app-header-right .avatar-ring,
body.portal-public-mode .app-header-right,
body.portal-public-mode .journal-header-actions,
body.portal-public-mode #ds-user {
  display: none !important;
  visibility: hidden !important;
}

/* In public mode: fully opaque header, no blur. Use the deep-space color
   (#080810) that matches the Sign In chip's halo ring so the header reads
   as one seamless dark band behind the chip instead of a grey bar. */
body.portal-public-mode .app-header {
  background: #080810 !important;
  backdrop-filter: none !important;
 -webkit-backdrop-filter: none !important;
  border-bottom-color: rgba(255,255,255,0.06) !important;
}
body.portal-public-mode::before { display: none !important; }

/* ── PORTAL BRAND ACCENTS ── */

/* Gradient border accent on the user's own circle card */
.circle-card.my-circle {
  border-image: linear-gradient(135deg, var(--orange), var(--magenta), var(--cyan)) 1;
  border-width: 1px;
  border-style: solid;
  border-radius: 0; /* border-image doesn't work with border-radius */
  position: relative;
}

/* Override: use pseudo-element for gradient border + radius */
.circle-card.my-circle {
  border: none;
  background: var(--bg-card);
  position: relative;
  isolation: isolate;
}
.circle-card.my-circle::before {
  content: '';
  position: absolute;
  inset: -1px;
  border-radius: var(--radius-md);
  background: var(--gradient-portal);
  z-index: -1;
  opacity: 0.85;
}

/* Event cards - subtle gradient top border line */
.event-card::after {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 2px;
  background: var(--gradient-portal);
  opacity: 0;
  transition: opacity 0.3s;
}
.event-card {
  position: relative;
}
.event-card:hover::after {
  opacity: 0.6;
}

/* Category tags - brand color coding */
.event-card-category.ceremony { background: rgba(255,98,154,0.3); color: var(--magenta); }
.event-card-category.gathering { background: rgba(132,207,195,0.3); color: var(--cyan); }
.event-card-category.workshop { background: rgba(255,163,0,0.3); color: var(--orange); }

/* Brand gradient glow on primary buttons */
.auth-btn,
.onboard-btn.primary,
.rsvp-btn:not(.going),
.chat-send {
  box-shadow: 0 4px 20px rgba(132,207,195,0.2), 0 2px 10px rgba(255,98,154,0.15);
}

/* Profile avatar - gradient ring matching brand */
.profile-avatar-large {
  border: 3px solid transparent;
  background-image: linear-gradient(var(--bg-card), var(--bg-card)), var(--gradient-portal);
  background-origin: border-box;
  background-clip: content-box, border-box;
}

/* Member marker glow - updated to brand teal */
.member-marker {
  box-shadow: 0 0 12px rgba(132,207,195,0.4), 0 0 4px rgba(132,207,195,0.2);
}

/* Four-point star keyframe for subtle sparkle */
@keyframes portalSparkle {
  0%, 100% { opacity: 0.3; transform: scale(1); }
  50% { opacity: 0.7; transform: scale(1.2); }
}

/* ── DIRECT MESSAGES ── */

/* Messages Screen (tab content) */
.messages-screen .app-header {
  position: relative;
  flex-shrink: 0;
}
.messages-screen .section-title { padding: 16px 20px 8px; font-family: 'Oswald', sans-serif; font-size: 15px; font-weight: 600; letter-spacing: 1.5px; text-transform: uppercase; color: var(--text-secondary); }
.dm-compose-btn {
  position: absolute; bottom: calc(70px + var(--safe-bottom)); right: 20px;
  width: 52px; height: 52px; border-radius: 50%;
  background: linear-gradient(135deg, var(--cyan), var(--magenta));
  border: none; cursor: pointer;
  display: flex; align-items: center; justify-content: center;
  box-shadow: 0 4px 20px rgba(132,207,195,0.3);
  z-index: 10; transition: transform 0.2s, box-shadow 0.2s;
  -webkit-tap-highlight-color: transparent;
}
.dm-compose-btn:active { transform: scale(0.92); }
.dm-compose-btn svg { width: 24px; height: 24px; stroke: var(--bg-deep); fill: none; stroke-width: 2; }
.dm-compose-overlay {
  position: fixed; top: 0; left: 0; width: 100%; height: 100%;
  background: var(--bg-deep); z-index: 99993;
  display: flex; flex-direction: column;
  transform: translateX(100%);
  transition: transform 0.3s cubic-bezier(0.32,0.72,0,1);
  pointer-events: none;
}
.dm-compose-overlay.visible { transform: translateX(0); pointer-events: auto; }
.dm-compose-search {
  margin: 12px 16px; padding: 11px 16px;
  background: var(--bg-card); border: 1px solid var(--border-glass);
  border-radius: 22px; color: var(--text-primary);
  font-size: 15px; font-family: 'Inter', sans-serif; outline: none;
  transition: border-color 0.2s;
}
.dm-compose-search:focus { border-color: var(--cyan); }
.dm-compose-search::placeholder { color: var(--text-dim); }
.dm-compose-results { flex: 1; overflow-y: auto; padding: 0 16px; }
.dm-compose-member {
  display: flex; align-items: center; gap: 12px;
  padding: 12px 0; border-bottom: 1px solid var(--border-glass);
  cursor: pointer; -webkit-tap-highlight-color: transparent;
}
.dm-compose-member:active { opacity: 0.7; }
.dm-compose-member img { width: 44px; height: 44px; border-radius: 50%; object-fit: cover; }
.dm-compose-member-info { flex: 1; }
.dm-compose-member-name { font-size: 15px; font-weight: 600; color: var(--warm-white); }
.dm-compose-member-loc { font-size: 12px; color: var(--text-dim); margin-top: 2px; }
.dm-empty { text-align: center; padding: 60px 24px; color: var(--text-dim); }
.dm-empty-cta {
  display: inline-block;
  margin-top: 18px;
  padding: 10px 20px;
  border-radius: 999px;
  background: rgba(132,207,195,0.1);
  border: 1px solid rgba(132,207,195,0.35);
  color: #84cfc3;
  font-family: 'Oswald', sans-serif;
  font-size: 11px;
  font-weight: 600;
  letter-spacing: 1.5px;
  text-transform: uppercase;
  cursor: pointer;
  -webkit-tap-highlight-color: transparent;
}
.dm-empty-cta:active { transform: scale(0.98); }
.following-empty-cta {
  display: inline-block;
  margin-top: 10px;
  padding: 6px 14px;
  border-radius: 999px;
  background: rgba(132,207,195,0.08);
  border: 1px solid rgba(132,207,195,0.3);
  color: #84cfc3;
  font-family: 'Oswald', sans-serif;
  font-size: 10px;
  font-weight: 600;
  letter-spacing: 1.5px;
  text-transform: uppercase;
  cursor: pointer;
  -webkit-tap-highlight-color: transparent;
}
.following-empty-cta:active { transform: scale(0.98); }
.dm-empty-icon { font-size: 40px; margin-bottom: 12px; opacity: 0.4; }
.dm-empty-text { font-size: 14px; line-height: 1.6; }
@keyframes dm-shimmer { 0% { background-position: 200% 0; } 100% { background-position: -200% 0; } }
.dm-msg-skel { display:flex; padding:8px 16px; margin-bottom:4px; }
.dm-msg-skel.me { justify-content:flex-end; }
.dm-msg-skel-bubble { height:36px; border-radius:18px; background:linear-gradient(90deg,rgba(255,255,255,0.04),rgba(255,255,255,0.08),rgba(255,255,255,0.04)); background-size:200% 100%; animation:dm-shimmer 1.2s linear infinite; }

/* DM Request Banner */
.dm-requests-banner {
  margin: 8px 16px 4px;
  padding: 14px 18px;
  background: var(--magenta-dim);
  border: 1px solid rgba(255,98,154,0.25);
  border-radius: var(--radius-md);
  display: flex;
  align-items: center;
  gap: 12px;
  cursor: pointer;
  -webkit-tap-highlight-color: transparent;
  transition: background 0.2s;
}
.dm-requests-banner:active { background: rgba(255,98,154,0.25); }
.dm-requests-badge {
  width: 28px; height: 28px;
  background: var(--magenta);
  border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  font-family: 'Oswald', sans-serif;
  font-size: 13px; font-weight: 600;
  color: #fff;
  flex-shrink: 0;
}
.dm-requests-text { font-size: 14px; color: var(--text-primary); font-weight: 500; }
.dm-requests-arrow { margin-left: auto; color: var(--text-dim); font-size: 18px; }

/* ── Outbound pending banner (your sent-but-not-yet-accepted requests) ── */
.dm-pending-banner {
  margin: 4px 16px 4px;
  padding: 12px 16px;
  background: rgba(132,207,195,0.08);
  border: 1px solid rgba(132,207,195,0.22);
  border-radius: var(--radius-md);
  display: flex;
  align-items: center;
  gap: 12px;
  cursor: pointer;
  -webkit-tap-highlight-color: transparent;
  transition: background 0.2s;
}
.dm-pending-banner:active { background: rgba(132,207,195,0.14); }
.dm-pending-badge {
  width: 24px; height: 24px;
  background: rgba(132,207,195,0.25);
  border: 1px solid rgba(132,207,195,0.5);
  border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  font-family: 'Oswald', sans-serif;
  font-size: 12px; font-weight: 700;
  color: #84cfc3;
  flex-shrink: 0;
}
.dm-pending-text {
  font-size: 13px;
  color: rgba(255,255,255,0.72);
  font-weight: 500;
}

/* Conversation List */
.dm-conversation-list { padding: 4px 0; overflow-y: auto; flex: 1; -webkit-overflow-scrolling: touch; }
.dm-convo-item {
  display: flex;
  align-items: center;
  gap: 14px;
  padding: 14px 20px;
  cursor: pointer;
  -webkit-tap-highlight-color: transparent;
  transition: background 0.15s;
  position: relative;
}
.dm-convo-item:active { background: rgba(255,255,255,0.03); }
.dm-convo-avatar {
  width: 50px; height: 50px;
  border-radius: 50%;
  object-fit: cover;
  flex-shrink: 0;
  border: 2px solid var(--border-glass);
}
.dm-convo-avatar.unread { border-color: var(--cyan); }
.dm-convo-info { flex: 1; min-width: 0; }
.dm-convo-name {
  font-size: 15px;
  font-weight: 600;
  color: var(--text-primary);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.dm-convo-preview {
  font-size: 13px;
  color: var(--text-secondary);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  margin-top: 2px;
}
.dm-convo-preview.unread { color: var(--text-primary); font-weight: 500; }
.dm-convo-meta {
  display: flex;
  flex-direction: column;
  align-items: flex-end;
  gap: 6px;
  flex-shrink: 0;
}
.dm-convo-time {
  font-size: 11px;
  color: var(--text-dim);
}
.dm-convo-unread-dot {
  width: 10px; height: 10px;
  background: var(--cyan);
  border-radius: 50%;
  display: none;
}
.dm-convo-item.unread .dm-convo-unread-dot { display: block; }
.dm-convo-item.unread .dm-convo-name { color: var(--cyan); }

/* Skeleton loading rows for DM inbox */
.dm-convo-skeleton {
  display: flex;
  align-items: center;
  gap: 14px;
  padding: 14px 20px;
  position: relative;
  overflow: hidden;
}
.dm-convo-skeleton::after {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(90deg, transparent 0%, rgba(255,255,255,0.04) 40%, rgba(255,255,255,0.08) 50%, rgba(255,255,255,0.04) 60%, transparent 100%);
  animation: bdShimmer 1.5s infinite;
}
.dm-convo-skeleton-avatar {
  width: 50px; height: 50px;
  border-radius: 50%;
  background: rgba(255,255,255,0.06);
  flex-shrink: 0;
}
.dm-convo-skeleton-info { flex: 1; min-width: 0; }
.dm-convo-skeleton-line {
  height: 12px;
  border-radius: 6px;
  background: rgba(255,255,255,0.08);
}
.dm-convo-skeleton-line.skel-name { width: 45%; height: 14px; margin-bottom: 8px; }
.dm-convo-skeleton-line.skel-preview { width: 75%; }

/* DM Chat View (overlays messages screen) */
.dm-chat-view {
  position: fixed;
  top: 0; left: 0; right: 0; bottom: 0;
  z-index: 99991;
  background: var(--bg-deep);
  display: flex;
  flex-direction: column;
  transform: translateX(100%);
  transition: transform 0.3s cubic-bezier(0.32,0.72,0,1);
  pointer-events: none;
}
.dm-chat-view.visible { transform: translateX(0); pointer-events: auto; }
.dm-chat-header {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 12px 16px;
  padding-top: max(12px, env(safe-area-inset-top));
  background: var(--bg-glass-solid);
  backdrop-filter: blur(20px);
  -webkit-backdrop-filter: blur(20px);
  border-bottom: 1px solid var(--border-glass);
  flex-shrink: 0;
}
.dm-chat-back {
  font-size: 22px;
  cursor: pointer;
  padding: 4px 8px;
  color: var(--cyan);
  -webkit-tap-highlight-color: transparent;
}
.dm-chat-header-avatar {
  width: 36px; height: 36px;
  border-radius: 50%;
  object-fit: cover;
  cursor: pointer;
}
.dm-chat-header-info { flex: 1; min-width: 0; }
.dm-chat-header-name {
  font-family: 'Oswald', sans-serif;
  font-size: 16px;
  font-weight: 600;
  color: var(--text-primary);
  cursor: pointer;
}
.dm-chat-header-status {
  font-size: 11px;
  color: var(--text-dim);
}

/* DM Messages */
.dm-messages {
  flex: 1;
  overflow-y: auto;
  -webkit-overflow-scrolling: touch;
  padding: 16px 16px 8px;
  display: flex;
  flex-direction: column;
  gap: 6px;
}
.dm-msg {
  max-width: 78%;
  padding: 10px 14px;
  border-radius: 18px;
  font-size: 15px;
  line-height: 1.45;
  word-wrap: break-word;
  position: relative;
}
.dm-msg.them {
  align-self: flex-start;
  background: var(--bg-card);
  border: 1px solid var(--border-glass);
  color: var(--text-primary);
  border-bottom-left-radius: 6px;
}
.dm-msg.me {
  align-self: flex-end;
  background: linear-gradient(135deg, rgba(132,207,195,0.2), rgba(132,207,195,0.1));
  border: 1px solid rgba(132,207,195,0.25);
  color: var(--text-primary);
  border-bottom-right-radius: 6px;
}
.dm-msg-time {
  font-size: 10px;
  color: var(--text-dim);
  margin-top: 4px;
}
.dm-msg.me .dm-msg-time { text-align: right; }
.dm-msg-delete {
  background: none; border: none; color: var(--text-dim); font-size: 14px; cursor: pointer;
  opacity: 0.3; transition: opacity 0.2s; padding: 0 4px; margin-left: 6px; vertical-align: middle;
}
.dm-msg-delete:hover, .dm-msg-delete:active { opacity: 1; color: #ff4444; }
.dm-date-divider {
  text-align: center;
  font-size: 11px;
  color: var(--text-dim);
  padding: 12px 0 4px;
  font-weight: 500;
  letter-spacing: 0.5px;
}

/* DM Input */
.dm-input-bar {
  display: flex;
  gap: 10px;
  padding: 10px 16px;
  padding-bottom: max(10px, calc(var(--safe-bottom) + 10px));
  background: var(--bg-glass-solid);
  backdrop-filter: blur(20px);
  -webkit-backdrop-filter: blur(20px);
  border-top: 1px solid var(--border-glass);
  flex-shrink: 0;
}
.dm-input {
  flex: 1;
  background: var(--bg-card);
  border: 1px solid var(--border-glass);
  border-radius: 22px;
  padding: 10px 18px;
  color: var(--text-primary);
  font-size: 15px;
  font-family: 'Inter', sans-serif;
  outline: none;
  transition: border-color 0.2s;
}
.dm-input:focus { border-color: var(--cyan); }
.dm-input::placeholder { color: var(--text-dim); }
.dm-send {
  width: 40px; height: 40px;
  border-radius: 50%;
  background: var(--cyan);
  border: none;
  color: var(--bg-deep);
  font-size: 18px;
  font-weight: 700;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  -webkit-tap-highlight-color: transparent;
  transition: transform 0.15s, opacity 0.15s;
}
.dm-send:active { transform: scale(0.9); }

/* DM Request Acceptance Banner */
.dm-accept-bar {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 14px 16px;
  padding-bottom: max(14px, calc(var(--safe-bottom) + 14px));
  background: var(--bg-glass-solid);
  backdrop-filter: blur(20px);
  -webkit-backdrop-filter: blur(20px);
  border-top: 1px solid var(--border-glass);
  flex-shrink: 0;
}
.dm-accept-text {
  flex: 1;
  font-size: 13px;
  color: var(--text-secondary);
  line-height: 1.4;
}
.dm-accept-btn {
  padding: 10px 20px;
  border-radius: 22px;
  font-family: 'Oswald', sans-serif;
  font-size: 13px;
  font-weight: 600;
  letter-spacing: 1px;
  text-transform: uppercase;
  cursor: pointer;
  -webkit-tap-highlight-color: transparent;
  border: none;
  transition: transform 0.15s;
}
.dm-accept-btn:active { transform: scale(0.95); }
.dm-accept-btn.accept { background: var(--cyan); color: var(--bg-deep); }
.dm-accept-btn.decline { background: transparent; border: 1px solid var(--text-dim); color: var(--text-dim); }

/* DM Requests List */
.dm-requests-overlay {
  position: fixed;
  top: 0; left: 0; right: 0; bottom: 0;
  z-index: 99992;
  background: var(--bg-deep);
  display: flex;
  flex-direction: column;
  transform: translateX(100%);
  transition: transform 0.3s cubic-bezier(0.32,0.72,0,1);
  pointer-events: none;
}
.dm-requests-overlay.visible { transform: translateX(0); pointer-events: auto; }

/* ── Notification center overlay ── */
.notifications-overlay {
  position: fixed;
  top: 0; left: 0; right: 0; bottom: 0;
  z-index: 99993;
  background: var(--bg-deep);
  display: flex;
  flex-direction: column;
  transform: translateX(100%);
  transition: transform 0.3s cubic-bezier(0.32,0.72,0,1);
  pointer-events: none;
}
.notifications-overlay.visible { transform: translateX(0); pointer-events: auto; }
.notifications-mark-all {
  background: none;
  border: none;
  color: #84cfc3;
  font-family: 'Oswald', sans-serif;
  font-size: 11px;
  font-weight: 600;
  letter-spacing: 1.2px;
  text-transform: uppercase;
  cursor: pointer;
  padding: 8px 12px;
  margin-right: 4px;
  -webkit-tap-highlight-color: transparent;
}
.notifications-list {
  flex: 1;
  overflow-y: auto;
  -webkit-overflow-scrolling: touch;
  padding: 4px 0;
}
.notif-item {
  display: flex;
  align-items: flex-start;
  gap: 12px;
  padding: 14px 16px;
  border-bottom: 1px solid rgba(255,255,255,0.04);
  cursor: pointer;
  -webkit-tap-highlight-color: transparent;
  transition: background 0.15s;
  position: relative;
}
.notif-item:hover { background: rgba(255,255,255,0.02); }
.notif-item:active { background: rgba(255,255,255,0.04); }
.notif-item.unread { background: rgba(255,99,154,0.04); }
.notif-item.unread::before {
  content: '';
  position: absolute;
  left: 4px;
  top: 50%;
  transform: translateY(-50%);
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: #ff629a;
}
.notif-icon {
  flex: 0 0 40px;
  width: 40px; height: 40px;
  border-radius: 50%;
  overflow: hidden;
  background: rgba(132,207,195,0.1);
  display: flex; align-items: center; justify-content: center;
  color: #84cfc3;
  font-size: 18px;
}
.notif-icon img {
  width: 100%; height: 100%;
  object-fit: cover;
  display: block;
}
.notif-body {
  flex: 1;
  min-width: 0;
}
.notif-title {
  font-size: 14px;
  font-weight: 600;
  color: #fff;
  line-height: 1.3;
  margin-bottom: 2px;
}
.notif-item:not(.unread) .notif-title { font-weight: 500; color: rgba(255,255,255,0.8); }
.notif-sub {
  font-size: 13px;
  color: rgba(255,255,255,0.6);
  line-height: 1.35;
  overflow: hidden;
  text-overflow: ellipsis;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
}
.notif-time {
  font-size: 11px;
  color: rgba(255,255,255,0.4);
  margin-top: 4px;
}
.notif-empty {
  text-align: center;
  padding: 80px 24px;
  color: rgba(255,255,255,0.5);
}
.notif-empty-icon {
  font-size: 48px;
  margin-bottom: 12px;
  opacity: 0.4;
}
.notif-empty-text {
  font-size: 14px;
  line-height: 1.5;
}
.dm-request-card {
  display: flex;
  align-items: center;
  gap: 14px;
  padding: 16px 20px;
  border-bottom: 1px solid var(--border-glass);
}
.dm-request-avatar {
  width: 50px; height: 50px;
  border-radius: 50%;
  object-fit: cover;
  flex-shrink: 0;
  cursor: pointer;
}
.dm-request-info { flex: 1; min-width: 0; }
.dm-request-name {
  font-size: 15px;
  font-weight: 600;
  color: var(--text-primary);
  cursor: pointer;
}
.dm-request-city {
  font-size: 12px;
  color: var(--text-dim);
  margin-top: 2px;
}
.dm-request-msg {
  font-size: 13px;
  color: var(--text-secondary);
  margin-top: 4px;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.dm-request-actions {
  display: flex;
  gap: 8px;
  flex-shrink: 0;
}
.dm-request-accept {
  width: 36px; height: 36px;
  border-radius: 50%;
  background: var(--cyan);
  border: none;
  color: var(--bg-deep);
  font-size: 18px;
  font-weight: 700;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
}
.dm-request-decline {
  width: 36px; height: 36px;
  border-radius: 50%;
  background: transparent;
  border: 1px solid var(--text-dim);
  color: var(--text-dim);
  font-size: 18px;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
}

/* Nav badge for messages */
.nav-tab .nav-badge-count {
  position: absolute;
  top: 2px;
  right: calc(50% - 20px);
  min-width: 18px; height: 18px;
  background: var(--magenta);
  border-radius: 9px;
  display: none;
  align-items: center;
  justify-content: center;
  font-size: 10px;
  font-weight: 700;
  color: #fff;
  padding: 0 5px;
  font-family: 'Inter', sans-serif;
}
/* Journey tab elevated icon */
.nav-tab-journey .nav-tab-icon svg { width: 26px; height: 26px; }
/* Journey tab intro pulse */
@keyframes journeyTabPulse {
  0%, 100% { transform: scale(1); }
  50% { transform: scale(1.2); }
}
.nav-tab-journey.intro-pulse .nav-tab-icon {
  animation: journeyTabPulse 600ms ease 2;
}
/* BD badge on Events tab */
.nav-bd-badge {
  position: absolute; top: 2px; right: calc(50% - 20px);
  font-size: 10px; background: rgba(20,15,30,0.85);
  border-radius: 8px; padding: 1px 4px; line-height: 1.2;
  display: none;
}
/* You tab avatar */
.nav-tab-avatar {
  width: 24px; height: 24px; border-radius: 50%;
  object-fit: cover; border: 1.5px solid transparent;
}
.nav-tab.active .nav-tab-avatar {
  border-color: var(--cyan);
}
/* Map access pill */
.map-access-pill {
  display: inline-flex; align-items: center; gap: 6px;
  padding: 6px 14px; border-radius: 20px; cursor: pointer;
  background: rgba(255,255,255,0.06); color: var(--text-dim);
  font-size: 12px; font-weight: 500; margin: 8px 16px 16px;
  transition: background 0.15s;
  -webkit-tap-highlight-color: transparent;
}
.map-access-pill:active { background: rgba(255,255,255,0.1); }
/* Journey tab quick action sheet */
.journey-quick-sheet-bg {
  position: fixed; inset: 0; z-index: 99999;
  background: rgba(0,0,0,0.4); opacity: 0;
  pointer-events: none; transition: opacity 0.2s;
}
.journey-quick-sheet-bg.show { opacity: 1; pointer-events: auto; }
.journey-quick-sheet {
  position: fixed; bottom: calc(66px + var(--safe-bottom) + 8px);
  left: 50%; transform: translateX(-50%) translateY(20px) scale(0.95);
  min-width: 220px; background: var(--bg-card);
  border: 1px solid var(--border-glass); border-radius: 14px;
  overflow: hidden; z-index: 100000;
  opacity: 0; transition: all 0.2s cubic-bezier(0.32,0.72,0,1);
  pointer-events: none;
}
.journey-quick-sheet.show {
  opacity: 1; transform: translateX(-50%) translateY(0) scale(1);
  pointer-events: auto;
}
.journey-quick-action {
  display: flex; align-items: center; gap: 12px;
  padding: 14px 18px; cursor: pointer; color: var(--warm-white);
  font-size: 15px; font-weight: 500;
  transition: background 0.15s;
  -webkit-tap-highlight-color: transparent;
}
.journey-quick-action:active { background: rgba(255,255,255,0.06); }
.journey-quick-action + .journey-quick-action {
  border-top: 1px solid rgba(255,255,255,0.06);
}
/* Journey screen time-aware header */
.journey-time-header-wrap {
  position: relative;
  overflow: hidden;
}
.journey-time-header-wrap::before {
  content: '';
  position: absolute;
  top: 0; left: 0;
  width: 100%; height: 100%;
  background: url('/assets/illustrations/portal-mushrooms.png') center top / cover no-repeat;
  opacity: 0.3;
  mask-image: linear-gradient(to bottom, rgba(0,0,0,0.8) 0%, rgba(0,0,0,0) 100%);
  -webkit-mask-image: linear-gradient(to bottom, rgba(0,0,0,0.8) 0%, rgba(0,0,0,0) 100%);
  pointer-events: none;
}
.journey-time-header {
  position: relative;
  z-index: 1;
  padding: 20px 20px 16px;
}
.journey-time-title {
  font-size: 22px; font-weight: 700; color: #fff;
}
.journey-time-sub {
  font-size: 14px; color: var(--text-dim); margin-top: 4px;
}

/* ── REFERRAL / INVITE ── */
.referral-card {
  background: var(--bg-card);
  border-radius: 16px;
  padding: 20px;
  margin: 0 16px 16px;
  border: 1px solid rgba(132,207,195,0.12);
}
.referral-header {
  display: flex;
  align-items: center;
  gap: 10px;
  -webkit-tap-highlight-color: transparent;
}
.referral-card.open .referral-header { margin-bottom: 14px; }
.referral-chevron {
  margin-left: auto;
  font-size: 20px;
  color: var(--text-dim);
  transition: transform 0.3s;
}
.referral-card.open .referral-chevron { transform: rotate(90deg); }
.referral-body {
  max-height: 0;
  overflow: hidden;
  transition: max-height 0.35s ease;
}
.referral-card.open .referral-body { max-height: 400px; }
.referral-icon {
  width: 40px; height: 40px;
  border-radius: 12px;
  background: linear-gradient(135deg, var(--cyan-dim), var(--magenta-dim));
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 20px;
}
.referral-header-text h3 {
  font-size: 15px;
  font-weight: 600;
  color: var(--warm-white);
  margin: 0 0 2px;
}
.referral-header-text p {
  font-size: 12px;
  color: var(--text-dim);
  margin: 0;
}
.referral-stats {
  display: flex;
  gap: 8px;
  margin-bottom: 14px;
}
.referral-stat {
  flex: 1;
  background: rgba(255,255,255,0.04);
  border-radius: 10px;
  padding: 10px;
  text-align: center;
}
.referral-stat-num {
  font-size: 22px;
  font-weight: 700;
  color: var(--cyan);
  font-family: 'Oswald', sans-serif;
}
.referral-stat-label {
  font-size: 10px;
  color: var(--text-dim);
  text-transform: uppercase;
  letter-spacing: 0.5px;
  margin-top: 2px;
}
.referral-link-row {
  display: flex;
  align-items: center;
  gap: 8px;
  background: rgba(255,255,255,0.04);
  border-radius: 10px;
  padding: 10px 12px;
  margin-bottom: 10px;
}
.referral-link-url {
  flex: 1;
  font-size: 12px;
  color: var(--cyan);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  font-family: 'Inter', monospace;
}
.referral-copy-btn {
  background: var(--cyan);
  color: var(--bg-deep);
  border: none;
  border-radius: 8px;
  padding: 6px 14px;
  font-size: 12px;
  font-weight: 600;
  cursor: pointer;
  white-space: nowrap;
  font-family: 'Inter', sans-serif;
}
.referral-copy-btn.copied {
  background: var(--magenta);
  color: #fff;
}
.referral-share-row {
  display: flex;
  gap: 8px;
}
.referral-share-btn {
  flex: 1;
  background: rgba(255,255,255,0.06);
  border: 1px solid rgba(255,255,255,0.08);
  border-radius: 10px;
  padding: 10px;
  text-align: center;
  color: var(--warm-white);
  font-size: 12px;
  font-weight: 500;
  cursor: pointer;
  font-family: 'Inter', sans-serif;
  transition: background 0.2s;
}
.referral-share-btn:active { background: rgba(255,255,255,0.1); }
.referral-share-btn svg { display: block; margin: 0 auto 4px; }
.referral-reward-note {
  text-align: center;
  font-size: 11px;
  color: var(--text-dim);
  margin-top: 12px;
  line-height: 1.5;
}
.referral-reward-note span { color: var(--orange); font-weight: 600; }

/* ── SOCIAL SHARE SHEET ── */
.share-sheet-overlay {
  position: fixed; inset: 0; z-index: 200000;
  background: rgba(0,0,0,0.6); backdrop-filter: blur(8px);
  display: none; align-items: flex-end; justify-content: center;
  opacity: 0; transition: opacity 0.25s ease;
}
.share-sheet-overlay.active { display: flex; opacity: 1; }
.share-sheet {
  width: 100%; max-width: 420px;
  background: #1a1a1e; border-radius: 20px 20px 0 0;
  padding: 20px 16px calc(20px + env(safe-area-inset-bottom));
  transform: translateY(100%); transition: transform 0.35s cubic-bezier(0.16,1,0.3,1);
}
.share-sheet-overlay.active .share-sheet { transform: translateY(0); }
.share-sheet-handle { width: 36px; height: 4px; background: rgba(255,255,255,0.2); border-radius: 2px; margin: 0 auto 16px; }
.share-sheet-title { font-family: 'Oswald',sans-serif; font-size: 14px; text-transform: uppercase; letter-spacing: 1.5px; color: var(--text-dim); text-align: center; margin-bottom: 20px; }
.share-sheet-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 12px; margin-bottom: 16px; }
.share-sheet-btn {
  display: flex; flex-direction: column; align-items: center; gap: 8px;
  background: none; border: none; cursor: pointer; padding: 12px 4px;
  border-radius: 12px; transition: background 0.15s;
}
.share-sheet-btn:active { background: rgba(255,255,255,0.08); }
.share-sheet-icon {
  width: 52px; height: 52px; border-radius: 14px;
  display: flex; align-items: center; justify-content: center;
}
.share-sheet-icon.ig { background: linear-gradient(135deg, #f09433, #e6683c, #dc2743, #cc2366, #bc1888); }
.share-sheet-icon.fb { background: #1877F2; }
.share-sheet-icon.x { background: #000; border: 1px solid rgba(255,255,255,0.15); }
.share-sheet-icon.copy { background: rgba(255,255,255,0.1); }
.share-sheet-icon.sms { background: #34C759; }
.share-sheet-icon.more { background: rgba(132,207,195,0.15); }
.share-sheet-icon svg { width: 24px; height: 24px; }
.share-sheet-label { font-size: 11px; color: var(--text-dim); font-family: 'Inter',sans-serif; font-weight: 500; }
.share-sheet-cancel {
  width: 100%; padding: 14px; background: rgba(255,255,255,0.06);
  border: none; border-radius: 12px; color: #fff; font-size: 15px;
  font-family: 'Inter',sans-serif; font-weight: 500; cursor: pointer;
  transition: background 0.15s;
}
.share-sheet-cancel:active { background: rgba(255,255,255,0.12); }

/* ── BIOMETRIC LOCK SCREEN ── */
.bio-lock-overlay {
  position: fixed;
  inset: 0;
  z-index: 100000;
  background: var(--bg-deep);
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  opacity: 1;
  transition: opacity 0.5s ease;
  pointer-events: auto;
}
.bio-lock-overlay.unlocking {
  opacity: 0;
  pointer-events: none;
}
.bio-lock-overlay.hidden { display: none; }

.bio-lock-logo {
  width: 120px;
  height: auto;
  margin-bottom: 32px;
  filter: drop-shadow(0 0 20px rgba(132,207,195,0.3));
}

.bio-lock-ring {
  position: relative;
  width: 120px;
  height: 120px;
  margin-bottom: 32px;
}
.bio-lock-ring-circle {
  position: absolute;
  inset: 0;
  border-radius: 50%;
  border: 2px solid rgba(132,207,195,0.15);
}
.bio-lock-ring-pulse {
  position: absolute;
  inset: 0;
  border-radius: 50%;
  border: 2px solid var(--cyan);
  animation: bioRingPulse 2s ease-in-out infinite;
}
@keyframes bioRingPulse {
  0%, 100% { transform: scale(1); opacity: 0.4; }
  50% { transform: scale(1.08); opacity: 1; }
}
.bio-lock-icon {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  color: var(--cyan);
  opacity: 0.9;
}
.bio-lock-ring.scanning .bio-lock-ring-pulse {
  animation: bioRingScan 0.6s ease-in-out;
  border-color: var(--magenta);
}
@keyframes bioRingScan {
  0% { transform: scale(1); opacity: 1; border-color: var(--cyan); }
  50% { transform: scale(1.15); opacity: 1; border-color: var(--magenta); }
  100% { transform: scale(1); opacity: 1; border-color: var(--cyan); }
}
.bio-lock-ring.success .bio-lock-ring-pulse {
  border-color: var(--cyan);
  animation: bioRingSuccess 0.5s ease forwards;
}
@keyframes bioRingSuccess {
  0% { transform: scale(1); opacity: 1; }
  50% { transform: scale(1.2); opacity: 1; }
  100% { transform: scale(1); opacity: 0; }
}

.bio-lock-text {
  font-family: 'Oswald', sans-serif;
  font-size: 14px;
  font-weight: 500;
  letter-spacing: 2px;
  text-transform: uppercase;
  color: var(--warm-white);
  margin-bottom: 8px;
}
.bio-lock-subtext {
  font-size: 12px;
  color: var(--text-dim);
  margin-bottom: 40px;
}
.bio-lock-tap {
  font-size: 12px;
  color: var(--text-secondary);
  margin-bottom: 24px;
  animation: bioTapPulse 2s ease-in-out infinite;
  cursor: pointer;
  -webkit-tap-highlight-color: transparent;
}
@keyframes bioTapPulse {
  0%, 100% { opacity: 0.5; }
  50% { opacity: 1; }
}
.bio-lock-fallback {
  background: none;
  border: none;
  color: var(--text-dim);
  font-size: 12px;
  font-family: 'Inter', sans-serif;
  cursor: pointer;
  padding: 8px 16px;
  text-decoration: underline;
  text-underline-offset: 3px;
}
.bio-lock-fallback:active { color: var(--cyan); }

/* Biometric enrollment prompt */
.bio-enroll-overlay {
  position: fixed;
  inset: 0;
  z-index: 100001;
  background: rgba(0,0,0,0.7);
  display: flex;
  align-items: center;
  justify-content: center;
  backdrop-filter: blur(8px);
  opacity: 0; visibility: hidden; pointer-events: none;
  transition: opacity 0.3s ease, visibility 0.3s ease;
  -webkit-backdrop-filter: blur(8px);
}
.bio-enroll-overlay.show { opacity: 1; visibility: visible; pointer-events: auto; }
.bio-enroll-card {
  background: var(--bg-glass-solid);
  border: 1px solid var(--border-glass);
  border-radius: 20px;
  padding: 32px 24px;
  max-width: 320px;
  width: 90%;
  text-align: center;
  transform: scale(0.9) translateY(20px);
  transition: transform 0.35s cubic-bezier(0.32,0.72,0,1);
}
.bio-enroll-overlay.show .bio-enroll-card { transform: scale(1) translateY(0); }
.bio-enroll-icon {
  font-size: 48px;
  margin-bottom: 16px;
  color: var(--cyan);
}
.bio-enroll-title {
  font-family: 'Oswald', sans-serif;
  font-size: 20px;
  font-weight: 600;
  color: var(--warm-white);
  text-transform: uppercase;
  letter-spacing: 1px;
  margin-bottom: 8px;
}
.bio-enroll-desc {
  font-size: 13px;
  color: var(--text-secondary);
  line-height: 1.6;
  margin-bottom: 24px;
}
.bio-enroll-btn {
  width: 100%;
  padding: 14px;
  border: none;
  border-radius: 12px;
  font-family: 'Inter', sans-serif;
  font-size: 15px;
  font-weight: 600;
  cursor: pointer;
  margin-bottom: 10px;
  transition: transform 0.15s;
}
.bio-enroll-btn:active { transform: scale(0.97); }
.bio-enroll-enable {
  background: linear-gradient(135deg, var(--cyan), #5eb8a8);
  color: var(--bg-deep);
}
.bio-enroll-skip {
  background: none;
  color: var(--text-dim);
  border: 1px solid var(--border-glass);
}

/* ── PULL TO REFRESH ── */
.ptr-indicator {
  position: fixed; top: 0; left: 50%; transform: translateX(-50%) translateY(-60px);
  z-index: 9999; transition: transform 0.3s ease;
  display: flex; align-items: center; gap: 8px;
  background: var(--bg-card); border: 1px solid var(--border-glass);
  border-radius: 20px; padding: 8px 16px;
  box-shadow: 0 4px 20px rgba(0,0,0,0.4);
}
.ptr-indicator.pulling { transform: translateX(-50%) translateY(20px); }
.ptr-indicator.refreshing { transform: translateX(-50%) translateY(20px); }
.ptr-spinner {
  width: 18px; height: 18px; border: 2px solid var(--border-glass);
  border-top-color: var(--cyan); border-radius: 50%;
}
.ptr-indicator.refreshing .ptr-spinner { animation: spin 0.8s linear infinite; }
@keyframes spin { to { transform: rotate(360deg); } }
.ptr-label { font-size: 12px; color: var(--text-dim); font-family: var(--font-body); }

/* ── TYPING INDICATOR ── */
.typing-indicator {
  display: flex; align-items: center; gap: 8px;
  padding: 8px 16px; font-size: 12px; color: var(--text-dim);
  font-style: italic; font-family: var(--font-body);
}
.typing-dots { display: flex; gap: 3px; }
.typing-dots span {
  width: 5px; height: 5px; border-radius: 50%;
  background: var(--cyan); opacity: 0.4;
  animation: typingDot 1.4s infinite;
}
.typing-dots span:nth-child(2) { animation-delay: 0.2s; }
.typing-dots span:nth-child(3) { animation-delay: 0.4s; }
@keyframes typingDot { 0%,60%,100% { opacity:0.4; transform:translateY(0); } 30% { opacity:1; transform:translateY(-3px); } }

/* ── UNREAD BADGE (CIRCLES) ── */
.circle-unread-badge {
  min-width: 18px; height: 18px; border-radius: 9px;
  background: var(--magenta); color: #fff; font-size: 10px;
  font-weight: 700; display: flex; align-items: center; justify-content: center;
  padding: 0 5px; font-family: var(--font-body);
}

/* ── IMAGE SHARING ── */
.chat-img-btn {
  width: 36px; height: 36px; border-radius: 50%;
  background: var(--bg-elevated); border: 1px solid var(--border-glass);
  display: flex; align-items: center; justify-content: center;
  cursor: pointer; flex-shrink: 0; transition: border-color 0.2s;
}
.chat-img-btn:hover { border-color: var(--cyan); }
.chat-img-btn svg { width: 18px; height: 18px; color: var(--text-dim); }
.chat-image {
  max-width: 240px; max-height: 240px; border-radius: var(--radius-md);
  object-fit: cover; cursor: pointer; transition: opacity 0.2s;
}
.chat-image:hover { opacity: 0.85; }
.chat-image-lightbox {
  position: fixed; top: 0; left: 0; width: 100%; height: 100%;
  background: rgba(0,0,0,0.92); z-index: 100002;
  display: none; align-items: center; justify-content: center;
  opacity: 0; transition: opacity 0.3s; cursor: pointer;
}
.chat-image-lightbox.show { display: flex; opacity: 1; }
.chat-image-lightbox img {
  max-width: 92vw; max-height: 85vh; border-radius: var(--radius-md);
  object-fit: contain;
}

/* ── MAP PROFILE CARD ── */
.map-profile-card {
  position: fixed; bottom: 80px; left: 12px; right: 12px;
  background: var(--bg-card); border: 1px solid var(--border-glass);
  border-radius: var(--radius-lg); padding: 20px;
  z-index: 2000; backdrop-filter: blur(20px);
  transform: translateY(120%); transition: transform 0.35s cubic-bezier(0.32,0.72,0,1);
  box-shadow: 0 -4px 30px rgba(0,0,0,0.5);
  pointer-events: none;
}
.map-profile-card.show { transform: translateY(0); pointer-events: auto; }
.map-profile-header { display: flex; gap: 14px; align-items: center; margin-bottom: 12px; }
.map-profile-avatar {
  width: 56px; height: 56px; border-radius: 50%;
  object-fit: cover; border: 2px solid var(--cyan);
}
.map-profile-info { flex: 1; }
.map-profile-name { font-family: var(--font-heading); font-size: 18px; font-weight: 700; color: var(--warm-white); }
.map-profile-location { font-size: 13px; color: var(--text-dim); margin-top: 2px; }
.map-profile-bio { font-size: 13px; color: var(--text-secondary); line-height: 1.5; margin-bottom: 12px; }
.map-profile-interests { display: flex; flex-wrap: wrap; gap: 6px; margin-bottom: 16px; }
.map-profile-interest {
  padding: 4px 10px; border-radius: 12px; font-size: 11px;
  background: rgba(132,207,195,0.1); color: var(--cyan);
  border: 1px solid rgba(132,207,195,0.15);
}
.map-profile-actions { display: flex; gap: 10px; }
.map-profile-hello {
  flex: 1; padding: 12px; border-radius: var(--radius-md);
  background: linear-gradient(135deg, var(--cyan), var(--magenta));
  color: #fff; font-weight: 600; font-size: 14px; font-family: var(--font-body);
  border: none; cursor: pointer;
}
.map-profile-close {
  padding: 12px 16px; border-radius: var(--radius-md);
  background: var(--bg-elevated); border: 1px solid var(--border-glass);
  color: var(--text-dim); font-size: 14px; cursor: pointer; font-family: var(--font-body);
}

/* ── ONBOARDING TOOLTIPS ── */
.tooltip-overlay {
  position: fixed; top: 0; left: 0; width: 100%; height: 100%;
  background: rgba(0,0,0,0.6); z-index: 99998;
}
.tooltip-bubble {
  position: fixed; z-index: 99999;
  background: var(--bg-card); border: 1px solid var(--cyan);
  border-radius: var(--radius-lg); padding: 16px 20px;
  max-width: 280px; box-shadow: 0 8px 32px rgba(0,0,0,0.5);
  animation: tooltipIn 0.3s ease;
}
@keyframes tooltipIn { from { opacity: 0; transform: scale(0.9) translateY(8px); } to { opacity: 1; transform: scale(1) translateY(0); } }
.tooltip-bubble::after {
  content: ''; position: absolute; width: 12px; height: 12px;
  background: var(--bg-card); border-right: 1px solid var(--cyan);
  border-bottom: 1px solid var(--cyan); transform: rotate(45deg);
}
.tooltip-bubble.arrow-bottom::after { bottom: -7px; left: var(--arrow-left, 50%); margin-left: -6px; }
.tooltip-bubble.arrow-top::after { top: -7px; left: var(--arrow-left, 50%); margin-left: -6px; transform: rotate(-135deg); }
.tooltip-title { font-family: var(--font-heading); font-size: 15px; font-weight: 700; color: var(--cyan); margin-bottom: 6px; }
.tooltip-text { font-size: 13px; color: var(--text-secondary); line-height: 1.5; margin-bottom: 12px; }
.tooltip-actions { display: flex; justify-content: space-between; align-items: center; }
.tooltip-next {
  padding: 8px 16px; border-radius: var(--radius-md);
  background: var(--cyan); color: var(--bg-deep); font-weight: 600;
  font-size: 12px; border: none; cursor: pointer; font-family: var(--font-body);
}
.tooltip-skip { font-size: 12px; color: var(--text-dim); cursor: pointer; background: none; border: none; font-family: var(--font-body); }
.tooltip-dots { display: flex; gap: 5px; }
.tooltip-dot { width: 6px; height: 6px; border-radius: 50%; background: var(--border-glass); }
.tooltip-dot.active { background: var(--cyan); }

/* ── EVENT REMINDER BANNER ── */
.event-reminder-banner {
  margin: 0 16px 12px; padding: 12px 16px;
  background: linear-gradient(135deg, rgba(255,163,0,0.12), rgba(255,98,154,0.08));
  border: 1px solid rgba(255,163,0,0.25); border-radius: var(--radius-md);
  display: flex; align-items: center; gap: 12px; cursor: pointer;
}
.event-reminder-icon { font-size: 20px; flex-shrink: 0; }
.event-reminder-info { flex: 1; }
.event-reminder-title { font-size: 13px; font-weight: 600; color: var(--orange); }
.event-reminder-detail { font-size: 11px; color: var(--text-dim); margin-top: 2px; }
.event-reminder-dismiss {
  width: 24px; height: 24px; border-radius: 50%;
  background: rgba(255,255,255,0.05); border: none;
  color: var(--text-dim); cursor: pointer; font-size: 14px;
  display: flex; align-items: center; justify-content: center;
}

/* ── NEW MEMBER NUDGE ── */
.new-member-nudge {
  position: fixed; top: 12px; left: 16px; right: 16px;
  background: var(--bg-card); border: 1px solid rgba(132,207,195,0.2);
  border-radius: var(--radius-lg); padding: 14px 16px;
  display: flex; align-items: center; gap: 12px; z-index: 5000;
  box-shadow: 0 8px 32px rgba(0,0,0,0.5); backdrop-filter: blur(16px);
  transform: translateY(-150%); transition: transform 0.4s cubic-bezier(0.32,0.72,0,1);
  pointer-events: none;
}
.new-member-nudge.show { transform: translateY(0); pointer-events: auto; }
.nudge-avatars { display: flex; margin-right: 4px; }
.nudge-avatar {
  width: 36px; height: 36px; border-radius: 50%;
  border: 2px solid var(--bg-deep); object-fit: cover;
  margin-left: -10px;
}
.nudge-avatar:first-child { margin-left: 0; }
.nudge-text { flex: 1; font-size: 13px; color: var(--text-secondary); line-height: 1.4; }
.nudge-text strong { color: var(--cyan); }
.nudge-close {
  width: 36px; height: 36px; background: none; border: none;
  color: var(--text-dim); font-size: 20px; cursor: pointer;
  display: flex; align-items: center; justify-content: center;
  flex-shrink: 0; -webkit-tap-highlight-color: transparent;
}

/* ── INTEREST MATCHING ── */
.match-card {
  background: var(--bg-card); border: 1px solid var(--border-glass);
  border-radius: var(--radius-lg); padding: 16px; margin-bottom: 12px;
}
.match-header { display: flex; align-items: center; gap: 12px; margin-bottom: 10px; }
.match-avatar { width: 44px; height: 44px; border-radius: 50%; object-fit: cover; border: 2px solid var(--cyan); }
.match-info { flex: 1; }
.match-name { font-weight: 600; font-size: 14px; color: var(--warm-white); }
.match-location { font-size: 12px; color: var(--text-dim); }
.match-shared { font-size: 12px; color: var(--cyan); margin-bottom: 10px; }
.match-interests { display: flex; flex-wrap: wrap; gap: 5px; margin-bottom: 12px; }
.match-interest {
  padding: 3px 8px; border-radius: 10px; font-size: 10px;
  background: rgba(132,207,195,0.1); color: var(--cyan);
  border: 1px solid rgba(132,207,195,0.15);
}
.match-interest.shared { background: rgba(132,207,195,0.2); border-color: var(--cyan); }
.match-actions { display: flex; gap: 8px; }
.match-hello-btn {
  flex: 1; padding: 10px; border-radius: var(--radius-md);
  background: linear-gradient(135deg, var(--cyan), var(--magenta));
  color: #fff; font-weight: 600; font-size: 13px; border: none;
  cursor: pointer; font-family: var(--font-body);
}
.match-skip-btn {
  padding: 10px 14px; border-radius: var(--radius-md);
  background: var(--bg-elevated); border: 1px solid var(--border-glass);
  color: var(--text-dim); font-size: 13px; cursor: pointer; font-family: var(--font-body);
}

/* ── CHAT REACTIONS ── */
.msg-reactions { display: flex; flex-wrap: wrap; gap: 4px; margin-top: 4px; }
.msg-reaction {
  display: flex; align-items: center; gap: 3px;
  padding: 2px 8px; border-radius: 12px; font-size: 12px;
  background: rgba(132,207,195,0.08); border: 1px solid rgba(132,207,195,0.12);
  cursor: pointer; transition: all 0.2s;
}
.msg-reaction:hover { border-color: var(--cyan); }
.msg-reaction.reacted { background: rgba(132,207,195,0.18); border-color: var(--cyan); }
.msg-reaction-count { font-size: 11px; color: var(--text-dim); }
.reaction-picker {
  position: absolute; bottom: 100%; left: 0;
  background: var(--bg-card); border: 1px solid var(--border-glass);
  border-radius: var(--radius-md); padding: 6px 8px;
  display: flex; gap: 2px; box-shadow: 0 4px 20px rgba(0,0,0,0.5);
  animation: tooltipIn 0.15s ease;
}
.reaction-picker-btn {
  width: 32px; height: 32px; border-radius: 8px;
  background: none; border: none; font-size: 18px;
  cursor: pointer; transition: background 0.15s;
  display: flex; align-items: center; justify-content: center;
}
.reaction-picker-btn:hover { background: rgba(132,207,195,0.1); }

/* ── MEMBER DIRECTORY ── */
.directory-overlay {
  position: fixed; top: 0; left: 0; width: 100%; height: 100%;
  background: var(--bg-deep); z-index: 99992;
  display: flex; flex-direction: column;
  transform: translateX(100%); transition: transform 0.3s cubic-bezier(0.32,0.72,0,1);
  pointer-events: none;
}
.directory-overlay.show { transform: translateX(0); pointer-events: auto; }
.directory-header {
  display: flex; align-items: center; gap: 12px;
  padding: 16px; border-bottom: 1px solid var(--border-glass);
}
.directory-back {
  width: 36px; height: 36px; border-radius: 50%;
  background: var(--bg-elevated); border: 1px solid var(--border-glass);
  display: flex; align-items: center; justify-content: center;
  cursor: pointer; color: var(--text-secondary); font-size: 18px;
}
.directory-title { font-family: var(--font-heading); font-size: 18px; font-weight: 700; color: var(--warm-white); flex: 1; }
.directory-search {
  padding: 10px 16px; border-bottom: 1px solid var(--border-glass);
}
.directory-search-input {
  width: 100%; padding: 10px 14px; border-radius: var(--radius-md);
  background: var(--bg-elevated); border: 1px solid var(--border-glass);
  color: var(--warm-white); font-size: 14px; font-family: var(--font-body);
  outline: none;
}
.directory-search-input::placeholder { color: var(--text-dim); }
.directory-search-input:focus { border-color: var(--cyan); }
.directory-filters {
  padding: 10px 16px; display: flex; gap: 8px;
  overflow-x: auto; border-bottom: 1px solid var(--border-glass);
}
.directory-filter-pill {
  padding: 6px 14px; border-radius: 16px; font-size: 12px;
  background: var(--bg-elevated); border: 1px solid var(--border-glass);
  color: var(--text-dim); white-space: nowrap; cursor: pointer;
  font-family: var(--font-body); transition: all 0.2s;
}
.directory-filter-pill.active { background: rgba(132,207,195,0.15); border-color: var(--cyan); color: var(--cyan); }
.directory-list { flex: 1; overflow-y: auto; padding: 12px 16px; }
.directory-member {
  display: flex; align-items: center; gap: 12px;
  padding: 12px 0; border-bottom: 1px solid rgba(255,255,255,0.03);
  cursor: pointer;
}
.directory-member-avatar {
  width: 44px; height: 44px; border-radius: 50%;
  object-fit: cover; border: 2px solid var(--border-glass);
}
.directory-member-info { flex: 1; }
.directory-member-name { font-weight: 600; font-size: 14px; color: var(--warm-white); }
.directory-member-location { font-size: 12px; color: var(--text-dim); }
.directory-member-interests { font-size: 11px; color: var(--cyan); margin-top: 2px; }
.directory-member-arrow { color: var(--text-dim); font-size: 16px; }
.directory-count { padding: 8px 16px; font-size: 12px; color: var(--text-dim); }

/* ── LIVE ACTIVITY FEED (Supabase-backed) ── */
.activity-feed { padding: 0 16px; margin-bottom: 16px; }
.activity-feed-label {
  font-family: var(--font-heading); font-size: 11px; font-weight: 600;
  color: var(--text-dim); text-transform: uppercase; letter-spacing: 1.8px;
  margin-bottom: 10px; margin-top: 20px; padding: 0 2px;
}
.activity-feed-items { display: flex; flex-direction: column; }
.activity-row {
  display: flex; align-items: center; gap: 12px;
  padding: 8px 0; cursor: pointer;
  border-bottom: 1px solid rgba(255,255,255,0.04);
  transition: background 0.15s;
}
.activity-row:last-child { border-bottom: none; }
.activity-row:active { background: rgba(255,255,255,0.03); }
.activity-row-avatar {
  width: 40px; height: 40px; border-radius: 50%; flex-shrink: 0;
  object-fit: cover; background: rgba(132,207,195,0.12);
}
.activity-row-avatar-fallback {
  width: 40px; height: 40px; border-radius: 50%; flex-shrink: 0;
  display: flex; align-items: center; justify-content: center;
  font-size: 16px; font-weight: 600; color: var(--warm-white);
  background: rgba(132,207,195,0.12);
}
.activity-row-body { flex: 1; min-width: 0; }
.activity-row-text {
  font-size: 13px; color: var(--text-secondary); line-height: 1.4;
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
.activity-row-text strong { color: var(--warm-white); font-weight: 600; }
.activity-row-meta {
  display: flex; align-items: center; gap: 6px;
  margin-top: 2px;
}
.activity-row-city {
  font-size: 10px; color: var(--text-dim); background: rgba(255,255,255,0.04);
  padding: 1px 6px; border-radius: 8px;
}
.activity-row-time { font-size: 10px; color: var(--text-dim); }
.activity-row-new {
  animation: activityFadeIn 0.5s cubic-bezier(0.32,0.72,0,1) both;
}
@keyframes activityFadeIn { from { opacity: 0; transform: translateY(-8px); } to { opacity: 1; transform: translateY(0); } }
.activity-empty {
  text-align: center; padding: 24px 16px; font-size: 13px;
  color: var(--text-dim); line-height: 1.5;
}

/* ── MEMBER PROFILE OVERLAY ── */
.member-profile-overlay {
  position: fixed; top: 0; left: 0; right: 0; bottom: 0;
  z-index: 100010; background-color: #131212;
  transform: translateX(100%); transition: transform 0.32s cubic-bezier(0.32,0.72,0,1);
  overflow-y: auto; -webkit-overflow-scrolling: touch;
  padding-bottom: env(safe-area-inset-bottom);
}
.member-profile-overlay::after {
  content: '';
  position: fixed;
  top: 0; left: 0; width: 100%; height: 100%;
  pointer-events: none;
  z-index: 0;
  opacity: 0.5;
  background-image:
    radial-gradient(1.5px 1.5px at 12% 18%, #84cfc3 50%, transparent 100%),
    radial-gradient(1.5px 1.5px at 25% 40%, #ff629a 50%, transparent 100%),
    radial-gradient(2px 2px at 38% 10%, #84cfc3 50%, transparent 100%),
    radial-gradient(1.5px 1.5px at 50% 28%, #ff629a 40%, transparent 100%),
    radial-gradient(1.5px 1.5px at 60% 50%, #84cfc3 50%, transparent 100%),
    radial-gradient(2px 2px at 70% 15%, #ffa300 50%, transparent 100%),
    radial-gradient(1.5px 1.5px at 80% 42%, #ff629a 50%, transparent 100%),
    radial-gradient(1.5px 1.5px at 90% 60%, #84cfc3 50%, transparent 100%),
    radial-gradient(1.5px 1.5px at 8% 65%, #ff629a 40%, transparent 100%),
    radial-gradient(2px 2px at 18% 82%, #84cfc3 50%, transparent 100%),
    radial-gradient(1.5px 1.5px at 32% 70%, #ffa300 50%, transparent 100%),
    radial-gradient(1.5px 1.5px at 45% 85%, #ff629a 50%, transparent 100%),
    radial-gradient(1.5px 1.5px at 55% 75%, #84cfc3 50%, transparent 100%),
    radial-gradient(2px 2px at 68% 62%, #ff629a 50%, transparent 100%),
    radial-gradient(1.5px 1.5px at 78% 80%, #84cfc3 50%, transparent 100%),
    radial-gradient(1.5px 1.5px at 88% 72%, #ffa300 50%, transparent 100%),
    radial-gradient(1.5px 1.5px at 95% 88%, #ff629a 50%, transparent 100%),
    radial-gradient(1px 1px at 5% 32%, #84cfc3 50%, transparent 100%),
    radial-gradient(1px 1px at 22% 55%, #ffa300 40%, transparent 100%),
    radial-gradient(1.5px 1.5px at 40% 45%, #ff629a 50%, transparent 100%),
    radial-gradient(1px 1px at 52% 12%, #84cfc3 50%, transparent 100%),
    radial-gradient(1px 1px at 72% 35%, #ff629a 40%, transparent 100%),
    radial-gradient(1.5px 1.5px at 85% 18%, #ffa300 50%, transparent 100%),
    radial-gradient(1px 1px at 96% 65%, #84cfc3 50%, transparent 100%);
  background-size: 100% 100%;
}
.member-profile-overlay > .mp-header,
.member-profile-overlay > #member-profile-body { position: relative; z-index: 1; }
.member-profile-overlay.show { transform: translateX(0); }
.mp-header {
  display: flex; align-items: center; justify-content: space-between;
  padding: 16px 16px 8px; position: sticky; top: 0; z-index: 2;
  background: rgba(19,18,18,0.85);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  padding-top: calc(16px + env(safe-area-inset-top));
}
.mp-back {
  width: 36px; height: 36px; display: flex; align-items: center; justify-content: center;
  border-radius: 50%; background: rgba(255,255,255,0.06); color: var(--warm-white);
  font-size: 18px; cursor: pointer; border: none; -webkit-tap-highlight-color: transparent;
}
.mp-back:active { background: rgba(255,255,255,0.12); }
.mp-menu-btn {
  width: 36px; height: 36px; display: flex; align-items: center; justify-content: center;
  border-radius: 50%; background: rgba(255,255,255,0.06); color: var(--text-dim);
  font-size: 18px; cursor: pointer; border: none; -webkit-tap-highlight-color: transparent;
}
.mp-menu-btn:active { background: rgba(255,255,255,0.12); }
.mp-hero { text-align: center; padding: 8px 24px 24px; }
.mp-avatar {
  width: 240px; height: 240px; border-radius: 50%; object-fit: cover;
  margin: 0 auto 20px; display: block;
  border: 4px solid rgba(132,207,195,0.25);
  box-shadow: 0 8px 40px rgba(0,0,0,0.4), 0 0 0 1px rgba(255,255,255,0.04);
}
.mp-avatar-fallback {
  width: 240px; height: 240px; border-radius: 50%;
  margin: 0 auto 20px; display: flex; align-items: center; justify-content: center;
  font-size: 88px; font-weight: 600; color: var(--warm-white);
  background: rgba(132,207,195,0.15);
  border: 4px solid rgba(132,207,195,0.25);
  box-shadow: 0 8px 40px rgba(0,0,0,0.4), 0 0 0 1px rgba(255,255,255,0.04);
}
.mp-name { font-size: 22px; font-weight: 700; color: var(--warm-white); margin-bottom: 4px; }
.mp-location { font-size: 14px; color: var(--text-dim); margin-bottom: 8px; }
.mp-pioneer-badge {
  display: inline-block; background: rgba(126,200,126,0.12); color: #7ec87e;
  font-size: 12px; font-weight: 500; border-radius: 20px; padding: 3px 12px;
  margin-bottom: 4px;
}
.mp-connect-indicator {
  display: flex; align-items: center; justify-content: center; gap: 6px;
  font-size: 12px; color: var(--text-dim); margin-top: 8px;
}
.mp-connect-dot {
  width: 7px; height: 7px; border-radius: 50%;
  background: #7ec87e; animation: pulseDot 2s ease infinite;
}
@keyframes pulseDot { 0%,100% { opacity: 1; box-shadow: 0 0 0 0 rgba(126,200,126,0.4); } 50% { opacity: 0.7; box-shadow: 0 0 0 6px rgba(126,200,126,0); } }
.mp-section { padding: 0 20px 20px; }
.mp-section-label {
  font-family: var(--font-heading); font-size: 10px; font-weight: 600;
  color: var(--text-dim); text-transform: uppercase; letter-spacing: 1.8px;
  margin-bottom: 8px;
}
.mp-bio { font-size: 14px; color: var(--text-secondary); line-height: 1.6; }
.mp-intention {
  font-size: 14px; color: var(--text-secondary); line-height: 1.6;
  font-style: italic; padding-left: 14px;
  border-left: 2px solid rgba(132,207,195,0.25);
}
.mp-practices { display: flex; flex-wrap: wrap; gap: 6px; }
.mp-practice-pill {
  font-size: 12px; color: var(--text-secondary); background: rgba(255,255,255,0.05);
  padding: 4px 12px; border-radius: 14px;
}
.mp-badges { display: flex; flex-direction: column; gap: 6px; }
.mp-link-row {
  display: flex; align-items: center; gap: 10px;
  padding: 10px 0; border-bottom: 1px solid rgba(255,255,255,0.04); cursor: pointer;
}
.mp-link-row:last-child { border-bottom: none; }
.mp-link-icon { width: 20px; text-align: center; font-size: 14px; color: var(--text-dim); }
.mp-link-text { font-size: 14px; color: var(--cyan); }
.mp-activity-row {
  display: flex; align-items: center; gap: 8px;
  padding: 6px 0; font-size: 12px; color: var(--text-secondary);
}
.mp-activity-row .activity-row-time { font-size: 10px; color: var(--text-dim); margin-left: auto; }
.mp-private-msg {
  text-align: center; font-size: 13px; color: var(--text-dim); padding: 20px;
  line-height: 1.5;
}
.mp-edit-btn {
  display: block; width: calc(100% - 40px); margin: 8px auto 0;
  padding: 12px; border-radius: 12px; border: 1px solid rgba(132,207,195,0.2);
  background: rgba(132,207,195,0.06); color: var(--cyan);
  font-size: 14px; font-weight: 600; text-align: center; cursor: pointer;
}
.mp-edit-btn:active { background: rgba(132,207,195,0.12); }
.mp-action-row {
  display: flex; gap: 10px; width: calc(100% - 40px); margin: 12px auto 0;
}
.mp-connect-btn {
  flex: 1; padding: 12px; border-radius: 12px; border: 1px solid rgba(132,207,195,0.25);
  background: rgba(132,207,195,0.1); color: var(--cyan);
  font-size: 14px; font-weight: 600; text-align: center; cursor: pointer;
  font-family: 'Inter', sans-serif; -webkit-tap-highlight-color: transparent;
}
.mp-connect-btn:active { background: rgba(132,207,195,0.18); }
.mp-connect-btn.pending { opacity: 0.5; cursor: default; }
.mp-message-btn {
  flex: 1; padding: 12px; border-radius: 12px; border: 1px solid rgba(255,255,255,0.08);
  background: rgba(255,255,255,0.04); color: var(--warm-white);
  font-size: 14px; font-weight: 600; text-align: center; cursor: pointer;
  font-family: 'Inter', sans-serif; -webkit-tap-highlight-color: transparent;
}
.mp-message-btn:active { background: rgba(255,255,255,0.08); }

/* ── FOUNDER PROFILE ROW ── */
.founder-row {
  display: flex; align-items: center; gap: 12px;
  padding: 14px 16px; cursor: pointer;
  -webkit-tap-highlight-color: transparent;
  border-radius: 12px; margin: 16px 0 0;
  background: rgba(255,163,0,0.06); border: 1px solid rgba(255,163,0,0.12);
}
.founder-row:active { background: rgba(255,163,0,0.12); }
.founder-row-icon {
  width: 36px; height: 36px; border-radius: 50%;
  background: rgba(255,163,0,0.12); display: flex; align-items: center; justify-content: center;
  font-size: 18px; flex-shrink: 0;
}
.founder-row-text { flex: 1; min-width: 0; }
.founder-row-title { font-size: 15px; font-weight: 600; color: var(--warm-white); }
.founder-row-sub { font-size: 12px; color: var(--text-dim); margin-top: 2px; }
.founder-row-arrow { color: var(--text-dim); font-size: 14px; flex-shrink: 0; }
.founder-row.is-founder {
  background: linear-gradient(135deg, rgba(132,207,195,0.08), rgba(255,98,154,0.06), rgba(255,163,0,0.08));
  border: 1px solid rgba(132,207,195,0.2);
  cursor: default;
}
.founder-row.is-founder .founder-row-icon { background: linear-gradient(135deg, rgba(132,207,195,0.15), rgba(255,98,154,0.12)); }
.founder-row.is-founder .founder-row-title {
  background: linear-gradient(90deg, #84cfc3, #ff629a, #ffa300);
  -webkit-background-clip: text; -webkit-text-fill-color: transparent;
  background-clip: text; font-weight: 700;
}
.founder-row.is-founder .founder-row-sub { color: rgba(255,255,255,0.55); }

/* ── FOUNDER COUNT LINE (Community tab footer) ── */
.founder-count-line {
  text-align: center; font-size: 13px; color: #666;
  padding: 20px 16px 8px; cursor: pointer;
  -webkit-tap-highlight-color: transparent;
}
.founder-count-line:active { opacity: 0.7; }
.founder-pulse-dot {
  display: inline-block; width: 6px; height: 6px; border-radius: 50%;
  background: #4ade80; margin-right: 4px; vertical-align: middle;
  animation: founderPulse 2s ease-in-out infinite;
}
@keyframes founderPulse {
  0%, 100% { opacity: 1; } 50% { opacity: 0.4; }
}

/* ── ABOUT PORTAL OVERLAY ── */
/* ── ABOUT PORTAL OVERLAY ── */
.about-portal-overlay {
  position: fixed; top: 0; left: 0; right: 0; bottom: 0;
  z-index: 99995; background: #1a1818;
  transform: translateX(100%); transition: transform 0.32s cubic-bezier(0.32,0.72,0,1);
  display: flex; flex-direction: column;
}
.about-portal-overlay.show { transform: translateX(0); }
.about-portal-header {
  display: flex; align-items: center; justify-content: center; position: relative;
  padding: 16px 16px 12px; flex-shrink: 0;
  padding-top: calc(16px + env(safe-area-inset-top));
}
.about-portal-back {
  position: absolute; left: 12px; top: 50%; transform: translateY(-50%);
  width: 36px; height: 36px; display: flex; align-items: center; justify-content: center;
  border-radius: 50%; background: none; color: #ccc;
  font-size: 22px; font-weight: 300; cursor: pointer; border: none;
  -webkit-tap-highlight-color: transparent;
  margin-top: calc(env(safe-area-inset-top) / 2);
}
.about-portal-title {
  font-size: 17px; font-weight: 400; color: #f0f0f0;
  font-family: 'Inter', sans-serif; letter-spacing: -0.01em;
}
.about-portal-body {
  flex: 1; overflow-y: auto; -webkit-overflow-scrolling: touch;
  padding: 0 20px calc(40px + env(safe-area-inset-bottom));
}
.about-portal-hero {
  display: flex; justify-content: center; padding: 36px 0 40px;
}
.about-portal-hero img {
  height: 48px; filter: brightness(0) invert(1); opacity: 0.9;
}
.about-portal-section { margin-bottom: 24px; }
.about-portal-section-label {
  font-size: 11px; font-weight: 600; color: #555;
  letter-spacing: 0.08em; text-transform: uppercase;
  margin: 0 0 8px; font-family: 'Inter', sans-serif;
}
.about-portal-section p {
  font-size: 15px; color: #ccc; line-height: 1.6;
  margin: 0; font-family: 'Inter', sans-serif;
}
.about-portal-founder-card {
  background: rgba(255,163,0,0.08); border: 1px solid rgba(255,163,0,0.2);
  border-radius: 16px; padding: 20px; margin-top: 24px; cursor: pointer;
  -webkit-tap-highlight-color: transparent;
}
.about-portal-founder-card:active { background: rgba(255,163,0,0.14); }
.about-portal-founder-card .afc-title {
  font-size: 17px; font-weight: 600; color: #f0f0f0; margin-bottom: 6px;
  font-family: 'Inter', sans-serif;
}
.about-portal-founder-card .afc-sub {
  font-size: 13px; color: #888; line-height: 1.5;
  font-family: 'Inter', sans-serif;
}
.about-portal-founder-card .afc-cta {
  font-size: 14px; font-weight: 600; color: #ffa300; margin-top: 14px;
  font-family: 'Inter', sans-serif;
}
.about-portal-footer {
  text-align: center; font-size: 13px; color: #555; margin-top: 24px; padding-bottom: 12px;
  font-family: 'Inter', sans-serif;
}
.about-portal-footer .founder-pulse-dot { margin-right: 4px; }

/* ── FIND CITY BUTTON (Community tab) ── */
.find-city-btn {
  display: flex; align-items: center; gap: 10px;
  background: rgba(132,207,195,0.06); border: 1px solid rgba(132,207,195,0.12);
  border-radius: 14px; padding: 14px 16px; margin: 12px 0 8px;
  cursor: pointer; -webkit-tap-highlight-color: transparent;
}
.find-city-btn:active { background: rgba(132,207,195,0.12); }
.find-city-icon { font-size: 18px; }
.find-city-text { flex: 1; font-size: 14px; font-weight: 600; color: var(--cyan); }
.find-city-arrow { color: var(--cyan); opacity: 0.5; font-size: 14px; }

/* ── CITY DISCOVERY OVERLAY ── */
.city-discovery-overlay {
  position: fixed; top: 0; left: 0; right: 0; bottom: 0;
  z-index: 99992; background: var(--bg-deep);
  transform: translateX(100%); transition: transform 0.32s cubic-bezier(0.32,0.72,0,1);
  display: flex; flex-direction: column;
  overflow: hidden;
}
.city-discovery-overlay.show { transform: translateX(0); }
.city-discovery-header {
  display: flex; align-items: center; justify-content: space-between;
  padding: 16px 16px 8px; flex-shrink: 0;
}
.city-discovery-back {
  width: 36px; height: 36px; display: flex; align-items: center; justify-content: center;
  border-radius: 50%; background: rgba(255,255,255,0.06); color: var(--warm-white);
  font-size: 18px; cursor: pointer; border: none; -webkit-tap-highlight-color: transparent;
}
.city-discovery-title {
  font-size: 17px; font-weight: 600; color: var(--warm-white);
  font-family: 'Inter', sans-serif;
}
.city-discovery-search {
  display: flex; align-items: center; gap: 8px;
  margin: 8px 16px 12px; padding: 10px 14px;
  background: rgba(255,255,255,0.05); border-radius: 12px;
  border: 1px solid rgba(255,255,255,0.06); flex-shrink: 0;
}
.city-discovery-search-icon { font-size: 14px; opacity: 0.5; }
.city-discovery-search input {
  flex: 1; background: none; border: none; color: var(--warm-white);
  font-size: 14px; font-family: 'Inter', sans-serif; outline: none;
}
.city-discovery-search input::placeholder { color: var(--text-dim); }
.city-discovery-list {
  flex: 1; overflow-y: auto; -webkit-overflow-scrolling: touch;
  padding: 0 16px 40px;
}
.cd-region-title {
  font-size: 11px; font-weight: 700; letter-spacing: 0.8px;
  color: var(--text-dim); padding: 16px 0 8px;
  border-top: 1px solid rgba(255,255,255,0.04); text-transform: uppercase;
}
.cd-region-title:first-child { border-top: none; padding-top: 4px; }
.cd-city-row {
  display: flex; align-items: center; gap: 12px;
  padding: 12px 0; border-bottom: 1px solid rgba(255,255,255,0.03);
  cursor: pointer; -webkit-tap-highlight-color: transparent;
}
.cd-city-row:active { opacity: 0.7; }
.cd-city-icon {
  width: 36px; height: 36px; border-radius: 50%;
  background: rgba(132,207,195,0.08); display: flex; align-items: center; justify-content: center;
  flex-shrink: 0;
}
.cd-city-icon img { width: 18px; height: 18px; object-fit: contain; filter: brightness(1.2); }
.cd-city-info { flex: 1; min-width: 0; }
.cd-city-name { font-size: 15px; font-weight: 500; color: var(--warm-white); }
.cd-city-meta { font-size: 12px; color: var(--text-dim); margin-top: 2px; }
.cd-follow-btn {
  padding: 6px 16px; border-radius: 20px; font-size: 12px; font-weight: 600;
  border: 1px solid rgba(132,207,195,0.3); background: rgba(132,207,195,0.08);
  color: var(--cyan); cursor: pointer; flex-shrink: 0;
  font-family: 'Inter', sans-serif; -webkit-tap-highlight-color: transparent;
}
.cd-follow-btn:active { background: rgba(132,207,195,0.15); }
.cd-follow-btn.following {
  background: rgba(132,207,195,0.04); border-color: rgba(255,255,255,0.06);
  color: var(--text-dim);
}
.cd-follow-btn.home {
  background: rgba(132,207,195,0.04); border-color: rgba(132,207,195,0.15);
  color: var(--cyan); opacity: 0.6; cursor: default;
}

/* ── ONBOARD FOUNDER SCREEN ── */
.onboard-founder-screen {
  display: flex; flex-direction: column; align-items: center; justify-content: center;
  text-align: center; padding: 40px 24px; min-height: 100%;
}
.onboard-founder-icon { margin-bottom: 24px; line-height: 1; }
.onboard-founder-headline {
  font-size: 18px; font-weight: 700; color: var(--warm-white);
  margin-bottom: 16px; font-family: 'Oswald', sans-serif;
  text-transform: uppercase; letter-spacing: 1px; white-space: nowrap;
}
.onboard-founder-body {
  font-size: 14px; color: var(--text-secondary); line-height: 1.65;
  max-width: 320px; margin-bottom: 32px;
}
.onboard-founder-body p { margin: 0 0 12px; }
.onboard-founder-body p:last-child { margin-bottom: 0; }
.onboard-founder-learn {
  font-size: 13px; color: var(--text-dim); margin-top: 12px;
  cursor: pointer; -webkit-tap-highlight-color: transparent;
}
.onboard-founder-learn:active { opacity: 0.7; }

/* ── PROFILE EDIT SHEET ── */
.profile-edit-overlay {
  position: fixed; top: 0; left: 0; right: 0; bottom: 0;
  z-index: 99992; background: var(--bg-deep);
  transform: translateX(100%); transition: transform 0.32s cubic-bezier(0.32,0.72,0,1);
  overflow-y: auto; -webkit-overflow-scrolling: touch;
  padding-bottom: calc(20px + env(safe-area-inset-bottom));
}
.profile-edit-overlay.show { transform: translateX(0); }
.pe-header {
  display: flex; align-items: center; justify-content: space-between;
  padding: 16px; position: sticky; top: 0; z-index: 2; background: var(--bg-deep);
}
.pe-title { font-size: 17px; font-weight: 700; color: var(--warm-white); }
.pe-cancel {
  font-size: 14px; color: var(--text-dim); background: none; border: none; cursor: pointer;
  padding: 6px 10px; -webkit-tap-highlight-color: transparent;
}
.pe-avatar-wrap { text-align: center; padding: 8px 0 20px; }
.pe-avatar-edit {
  width: 80px; height: 80px; border-radius: 50%; object-fit: cover;
  margin: 0 auto; display: block; cursor: pointer;
  border: 2px solid rgba(132,207,195,0.3);
}
.pe-avatar-label { font-size: 12px; color: var(--cyan); margin-top: 6px; cursor: pointer; }
.pe-field { padding: 0 20px 16px; }
.pe-field label {
  display: block; font-size: 11px; font-weight: 600; color: var(--text-dim);
  text-transform: uppercase; letter-spacing: 1px; margin-bottom: 6px;
}
.pe-field input, .pe-field textarea {
  width: 100%; background: rgba(255,255,255,0.04); border: 1px solid rgba(255,255,255,0.08);
  border-radius: 10px; color: var(--warm-white); font-size: 14px;
  padding: 10px 12px; font-family: var(--font-body); outline: none;
  transition: border-color 0.2s;
}
.pe-field input:focus, .pe-field textarea:focus { border-color: rgba(132,207,195,0.3); }
.pe-field textarea { resize: none; min-height: 80px; }
.pe-char-count { font-size: 10px; color: var(--text-dim); text-align: right; margin-top: 4px; }
.pe-pills { display: flex; flex-wrap: wrap; gap: 8px; padding: 0 20px 16px; }
.pe-pill {
  font-size: 13px; color: var(--text-secondary); background: rgba(255,255,255,0.05);
  padding: 6px 14px; border-radius: 16px; cursor: pointer; border: 1px solid transparent;
  transition: all 0.15s; -webkit-tap-highlight-color: transparent;
}
.pe-pill.selected { background: rgba(132,207,195,0.15); color: var(--cyan); border-color: rgba(132,207,195,0.3); }
.pe-toggle-row {
  display: flex; align-items: center; justify-content: space-between;
  padding: 12px 20px;
}
.pe-toggle-label { font-size: 14px; color: var(--text-secondary); }
.pe-toggle-sublabel { font-size: 11px; color: var(--text-dim); margin-top: 2px; }
.pe-toggle {
  position: relative; width: 44px; height: 26px; border-radius: 13px;
  background: rgba(255,255,255,0.1); cursor: pointer; transition: background 0.2s;
  flex-shrink: 0;
}
.pe-toggle.on { background: rgba(132,207,195,0.4); }
.pe-toggle::after {
  content: ''; position: absolute; top: 3px; left: 3px;
  width: 20px; height: 20px; border-radius: 50%;
  background: var(--warm-white); transition: transform 0.2s;
}
.pe-toggle.on::after { transform: translateX(18px); }
.pe-save-btn {
  display: block; width: calc(100% - 40px); margin: 20px auto 0;
  padding: 14px; border-radius: 14px; border: none;
  background: var(--cyan); color: var(--bg-deep);
  font-size: 15px; font-weight: 700; cursor: pointer;
  font-family: var(--font-body);
}
.pe-save-btn:active { opacity: 0.85; }
.pe-save-btn:disabled { opacity: 0.5; }



/* ── RESOURCES SECTION ── */
.resources-overlay {
  position: fixed; top: 0; left: 0; width: 100%; height: 100%;
  background: var(--bg-deep); z-index: 99991;
  display: flex; flex-direction: column;
  transform: translateX(100%); transition: transform 0.3s cubic-bezier(0.32,0.72,0,1);
  pointer-events: none;
}
.resources-overlay.show { transform: translateX(0); pointer-events: auto; }
.resources-list { flex: 1; overflow-y: auto; padding: 16px; }

/* ── PAST EVENTS OVERLAY ── */
.past-events-overlay {
  position: fixed; top: 0; left: 0; width: 100%; height: 100%;
  background: var(--bg-deep); z-index: 99991;
  display: flex; flex-direction: column;
  transform: translateX(100%); transition: transform 0.3s cubic-bezier(0.32,0.72,0,1);
  pointer-events: none;
}
.past-events-overlay.show { transform: translateX(0); pointer-events: auto; }
.past-events-list { flex: 1; overflow-y: auto; padding: 12px 16px; }
.past-event-card { opacity: 0.85; position: relative; overflow: hidden; }
.past-event-card .event-card-image::after {
  content: ''; position: absolute; inset: 0;
  background: rgba(26,24,24,0.25); pointer-events: none;
}

/* ── JOURNAL SCREEN ── */
.journal-header-actions { display: flex; gap: 8px; }
.journal-new-btn {
  background: linear-gradient(135deg, #d4a574, #c4956a);
  color: #1a1208; border: none; border-radius: 20px;
  padding: 8px 16px; font-size: 13px; font-weight: 600;
  cursor: pointer; display: flex; align-items: center; gap: 6px;
}
.journal-settings-btn {
  background: rgba(212,165,116,0.12); border: 1px solid rgba(212,165,116,0.2);
  color: #d4a574; border-radius: 50%; width: 36px; height: 36px;
  display: flex; align-items: center; justify-content: center; cursor: pointer;
}
.journal-stats-strip {
  display: flex; gap: 12px; padding: 12px 16px; margin: 8px 16px;
  background: rgba(212,165,116,0.06); border: 1px solid rgba(212,165,116,0.1);
  border-radius: 12px; overflow-x: auto;
}
.journal-stat { text-align: center; min-width: 70px; }
.journal-stat-num { font-size: 18px; font-weight: 700; color: #d4a574; }
.journal-stat-label { font-size: 10px; color: var(--text-dim); margin-top: 2px; }
.journal-list { flex: 1; overflow-y: auto; padding: 8px 16px 120px; }
.journal-entry-card {
  background: rgba(26,18,8,0.6); border: 1px solid rgba(212,165,116,0.1);
  border-radius: 14px; padding: 16px; margin-bottom: 12px; cursor: pointer;
  transition: transform 0.15s, border-color 0.2s;
}
.journal-entry-card:active { transform: scale(0.98); border-color: rgba(212,165,116,0.25); }
.journal-entry-date { font-size: 11px; color: #d4a574; font-weight: 600; letter-spacing: 0.5px; text-transform: uppercase; }
.journal-entry-title { font-size: 16px; font-weight: 600; color: var(--text-primary); margin-top: 4px; line-height: 1.3; }
.journal-entry-preview { font-size: 13px; color: var(--text-secondary); margin-top: 6px; line-height: 1.5; display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden; }
.journal-entry-meta { display: flex; align-items: center; gap: 8px; margin-top: 10px; flex-wrap: wrap; }
.journal-modality-pill {
  font-size: 10px; padding: 3px 10px; border-radius: 10px;
  background: rgba(212,165,116,0.12); color: #d4a574; font-weight: 500;
}
.journal-mood-arc {
  display: flex; align-items: center; gap: 4px; font-size: 11px; color: var(--text-dim);
}
.journal-mood-arc .mood-up { color: #4ade80; }
.journal-mood-arc .mood-down { color: #f87171; }
.journal-mood-arc .mood-neutral { color: var(--orange); }
.journal-reflection-count { font-size: 11px; color: var(--text-dim); }
.journal-empty-state {
  text-align: center; padding: 80px 32px; color: var(--text-secondary);
}
.journal-empty-icon { font-size: 48px; margin-bottom: 16px; opacity: 0.5; }
.journal-empty-title { font-size: 18px; font-weight: 600; color: var(--text-primary); margin-bottom: 8px; }
.journal-empty-text { font-size: 14px; line-height: 1.6; margin-bottom: 24px; }
.journal-empty-cta {
  background: linear-gradient(135deg, #d4a574, #c4956a); color: #1a1208;
  border: none; border-radius: 24px; padding: 14px 32px; font-size: 15px;
  font-weight: 600; cursor: pointer;
}

/* ── JOURNAL COMPOSER ── */
.journal-composer-overlay {
  position: fixed; top: 0; left: 0; width: 100%; height: 100%;
  background: #1a1818; z-index: 99992;
  display: flex; flex-direction: column;
  transform: translateY(100%); transition: transform 0.35s cubic-bezier(0.32,0.72,0,1);
  pointer-events: none;
}
.journal-composer-overlay.show { transform: translateY(0); pointer-events: auto; }
.journal-composer-header {
  display: flex; align-items: center; justify-content: space-between;
  padding: 16px; padding-top: max(16px, env(safe-area-inset-top));
  border-bottom: 1px solid rgba(212,165,116,0.1);
}
.journal-composer-back { background: none; border: none; color: #d4a574; font-size: 22px; cursor: pointer; padding: 4px 8px; }
.journal-composer-title { font-size: 16px; font-weight: 600; color: var(--text-primary); }
.journal-save-btn {
  background: linear-gradient(135deg, #d4a574, #c4956a); color: #1a1208;
  border: none; border-radius: 16px; padding: 8px 20px; font-size: 13px; font-weight: 600; cursor: pointer;
}
.journal-save-btn:disabled { opacity: 0.4; }
.journal-composer-body { flex: 1; overflow-y: auto; padding: 16px 16px 120px; }
.journal-context-strip {
  background: rgba(212,165,116,0.06); border: 1px solid rgba(212,165,116,0.1);
  border-radius: 14px; padding: 16px; margin-bottom: 16px;
}
.journal-context-toggle {
  display: flex; align-items: center; justify-content: space-between;
  cursor: pointer; color: var(--text-secondary); font-size: 14px;
}
.journal-context-toggle .toggle-arrow { transition: transform 0.2s; color: #d4a574; }
.journal-context-toggle.open .toggle-arrow { transform: rotate(90deg); }
.journal-context-fields { display: none; margin-top: 14px; }
.journal-context-fields.show { display: block; }
.journal-field-label { font-size: 12px; color: var(--text-dim); margin-bottom: 6px; margin-top: 14px; font-weight: 500; }
.journal-field-label:first-child { margin-top: 0; }
.journal-pills-row { display: flex; flex-wrap: wrap; gap: 8px; }
.journal-pill {
  padding: 6px 14px; border-radius: 16px; font-size: 12px; cursor: pointer;
  background: rgba(212,165,116,0.08); border: 1px solid rgba(212,165,116,0.15);
  color: var(--text-secondary); transition: all 0.15s;
}
.journal-pill.selected { background: rgba(212,165,116,0.2); border-color: #d4a574; color: #d4a574; }
.journal-mood-slider-wrap { display: flex; align-items: center; gap: 10px; padding: 4px 0; }
.journal-mood-slider {
  flex: 1; -webkit-appearance: none; appearance: none; height: 4px;
  background: rgba(212,165,116,0.15); border-radius: 2px; outline: none;
}
.journal-mood-slider::-webkit-slider-thumb {
  -webkit-appearance: none; width: 22px; height: 22px; border-radius: 50%;
  background: #d4a574; cursor: pointer; border: 2px solid #1a1208;
}
.journal-mood-val { font-size: 18px; min-width: 30px; text-align: center; }
.journal-substance-input {
  width: 100%; background: rgba(212,165,116,0.06); border: 1px solid rgba(212,165,116,0.12);
  border-radius: 10px; padding: 10px 14px; color: var(--text-primary); font-size: 14px;
  font-family: inherit; outline: none;
}
.journal-substance-input::placeholder { color: var(--text-dim); }
.journal-substance-input:focus { border-color: rgba(212,165,116,0.3); }
.journal-substance-note { font-size: 10px; color: var(--text-dim); margin-top: 4px; font-style: italic; }
.journal-prompts-section { margin-bottom: 20px; }
.journal-prompts-header { font-size: 13px; color: var(--text-dim); margin-bottom: 10px; }
.journal-prompt-card {
  background: rgba(212,165,116,0.04); border: 1px solid rgba(212,165,116,0.08);
  border-radius: 12px; padding: 14px; margin-bottom: 10px;
}
.journal-prompt-text { font-size: 14px; color: #d4a574; font-style: italic; line-height: 1.5; margin-bottom: 8px; }
.journal-prompt-response {
  width: 100%; min-height: 60px; background: rgba(0,0,0,0.2); border: 1px solid rgba(212,165,116,0.08);
  border-radius: 8px; padding: 10px; color: var(--text-primary); font-size: 14px;
  font-family: inherit; resize: vertical; outline: none; line-height: 1.6;
}
.journal-prompt-response:focus { border-color: rgba(212,165,116,0.2); }
.journal-freewrite {
  width: 100%; min-height: 200px; background: transparent; border: none;
  color: var(--text-primary); font-size: 16px; font-family: inherit;
  resize: none; outline: none; line-height: 1.8; padding: 0;
}
.journal-freewrite::placeholder { color: rgba(212,165,116,0.3); }
.journal-mood-after-prompt {
  background: rgba(212,165,116,0.06); border: 1px solid rgba(212,165,116,0.1);
  border-radius: 14px; padding: 16px; margin-top: 20px;
  animation: journalFadeIn 0.4s ease;
}
@keyframes journalFadeIn { from { opacity: 0; transform: translateY(8px); } to { opacity: 1; transform: translateY(0); } }
.journal-mood-after-header { font-size: 14px; color: var(--text-secondary); margin-bottom: 10px; display: flex; align-items: center; justify-content: space-between; }
.journal-mood-after-dismiss { background: none; border: none; color: var(--text-dim); cursor: pointer; font-size: 16px; }
.journal-tags-section { margin-top: 20px; }
.journal-tags-input {
  width: 100%; background: rgba(212,165,116,0.06); border: 1px solid rgba(212,165,116,0.1);
  border-radius: 10px; padding: 10px 14px; color: var(--text-primary); font-size: 13px;
  font-family: inherit; outline: none;
}
.journal-tags-input::placeholder { color: var(--text-dim); }
.journal-tag-suggestions { display: flex; flex-wrap: wrap; gap: 6px; margin-top: 6px; }
.journal-tag-pill {
  font-size: 11px; padding: 3px 10px; border-radius: 10px;
  background: rgba(212,165,116,0.1); color: #d4a574; cursor: pointer;
}

/* ── JOURNAL DETAIL VIEW ── */
.journal-detail-overlay {
  position: fixed; top: 0; left: 0; width: 100%; height: 100%;
  background: #1a1818; z-index: 99992;
  display: flex; flex-direction: column;
  transform: translateX(100%); transition: transform 0.3s cubic-bezier(0.32,0.72,0,1);
  pointer-events: none;
}
.journal-detail-overlay.show { transform: translateX(0); pointer-events: auto; }
.journal-detail-body { flex: 1; overflow-y: auto; padding: 20px 16px 120px; }
.journal-detail-date { font-size: 12px; color: #d4a574; font-weight: 600; letter-spacing: 0.5px; text-transform: uppercase; }
.journal-detail-title { font-size: 22px; font-weight: 700; color: var(--text-primary); margin-top: 6px; line-height: 1.3; }
.journal-detail-context { display: flex; flex-wrap: wrap; gap: 8px; margin-top: 14px; }
.journal-detail-mood-arc {
  background: rgba(212,165,116,0.06); border: 1px solid rgba(212,165,116,0.1);
  border-radius: 14px; padding: 16px; margin-top: 20px; text-align: center;
}
.journal-detail-mood-arc .mood-label { font-size: 12px; color: var(--text-dim); }
.journal-detail-mood-arc .mood-values { font-size: 20px; font-weight: 600; margin-top: 4px; color: var(--text-primary); }
.journal-detail-body-text { font-size: 16px; line-height: 1.8; color: var(--text-primary); margin-top: 20px; white-space: pre-wrap; }
.journal-detail-prompts { margin-top: 24px; }
.journal-detail-prompt { margin-bottom: 16px; }
.journal-detail-prompt-q { font-size: 14px; color: #d4a574; font-style: italic; margin-bottom: 4px; }
.journal-detail-prompt-a { font-size: 14px; color: var(--text-primary); line-height: 1.6; }
.journal-detail-tags { display: flex; flex-wrap: wrap; gap: 6px; margin-top: 20px; }
.journal-reflections-section { margin-top: 32px; border-top: 1px solid rgba(212,165,116,0.1); padding-top: 20px; }
.journal-reflections-title { font-size: 16px; font-weight: 600; color: var(--text-primary); margin-bottom: 14px; }
.journal-integration-note {
  background: rgba(212,165,116,0.04); border-left: 2px solid rgba(212,165,116,0.3);
  padding: 12px 14px; margin-bottom: 10px; border-radius: 0 10px 10px 0;
}
.journal-note-days { font-size: 10px; color: #d4a574; font-weight: 600; letter-spacing: 0.5px; }
.journal-note-content { font-size: 14px; color: var(--text-primary); line-height: 1.6; margin-top: 4px; }
.journal-add-reflection {
  background: rgba(212,165,116,0.08); border: 1px dashed rgba(212,165,116,0.2);
  border-radius: 12px; padding: 12px; text-align: center; cursor: pointer;
  color: #d4a574; font-size: 13px; font-weight: 500; margin-top: 10px;
}
.journal-reflection-input-wrap {
  display: none; margin-top: 10px;
}
.journal-reflection-input-wrap.show { display: block; }
.journal-reflection-input {
  width: 100%; min-height: 80px; background: rgba(0,0,0,0.2);
  border: 1px solid rgba(212,165,116,0.12); border-radius: 10px;
  padding: 12px; color: var(--text-primary); font-size: 14px;
  font-family: inherit; resize: vertical; outline: none; line-height: 1.6;
}
.journal-reflection-save {
  background: #d4a574; color: #1a1208; border: none; border-radius: 16px;
  padding: 8px 20px; font-size: 13px; font-weight: 600; cursor: pointer; margin-top: 8px;
}
.journal-detail-actions { display: flex; gap: 10px; margin-top: 24px; }
.journal-detail-actions button {
  flex: 1; padding: 12px; border-radius: 12px; font-size: 13px; font-weight: 500;
  cursor: pointer; border: 1px solid rgba(212,165,116,0.15); background: rgba(212,165,116,0.06);
  color: var(--text-secondary);
}
.journal-delete-btn { border-color: rgba(248,113,113,0.2) !important; color: #f87171 !important; }

/* ── JOURNAL SETTINGS OVERLAY ── */
.journal-settings-overlay {
  position: fixed; top: 0; left: 0; width: 100%; height: 100%;
  background: var(--bg-deep); z-index: 99993;
  display: flex; flex-direction: column;
  transform: translateX(100%); transition: transform 0.3s cubic-bezier(0.32,0.72,0,1);
  pointer-events: none;
}
.journal-settings-overlay.show { transform: translateX(0); pointer-events: auto; }
.journal-settings-body { flex: 1; overflow-y: auto; padding: 16px; }
.journal-setting-row {
  display: flex; align-items: center; justify-content: space-between;
  padding: 16px; background: var(--bg-card); border-radius: 12px; margin-bottom: 10px;
}
.journal-setting-info { flex: 1; }
.journal-setting-label { font-size: 14px; color: var(--text-primary); font-weight: 500; }
.journal-setting-desc { font-size: 12px; color: var(--text-dim); margin-top: 2px; }
.journal-clear-btn {
  width: 100%; padding: 14px; border-radius: 12px; font-size: 14px;
  background: rgba(248,113,113,0.08); border: 1px solid rgba(248,113,113,0.2);
  color: #f87171; font-weight: 500; cursor: pointer; margin-top: 8px;
}

/* ── FIRESIDE PROJECT ── */
.fireside-card {
  display: flex; align-items: center; gap: 12px;
  padding: 12px 14px; margin-bottom: 6px;
  background: var(--bg-card); border: 1px solid var(--border-glass);
  border-radius: var(--radius-md);
}
.fireside-card-icon {
  width: 36px; height: 36px; border-radius: 10px; flex-shrink: 0;
  background: rgba(255,120,50,0.15); display: flex; align-items: center; justify-content: center;
  font-size: 18px; line-height: 1;
}
.fireside-card-info { flex: 1; min-width: 0; }
.fireside-card-title { font-size: 14px; font-weight: 600; color: var(--warm-white); }
.fireside-card-subtitle { font-size: 12px; color: var(--text-dim); margin-top: 2px; }
.fireside-actions { display: flex; gap: 6px; flex-shrink: 0; }
.fireside-action-btn {
  padding: 5px 12px; border-radius: 14px; font-size: 12px; font-weight: 600; height: 28px;
  cursor: pointer; display: flex; align-items: center; gap: 4px; text-decoration: none;
  border: 1px solid rgba(255,160,80,0.25); background: rgba(255,120,50,0.1); color: rgba(255,200,160,0.9);
}
.fireside-action-btn.primary { background: rgba(255,120,50,0.18); border-color: rgba(255,160,80,0.35); }

/* ── DOSAGE & SAFETY SHEET ── */
.dosage-overlay {
  position: fixed; inset: 0; z-index: 99991;
  background: var(--bg-deep);
  transform: translateX(100%);
  transition: transform 0.3s cubic-bezier(0.25,0.46,0.45,0.94);
  display: flex; flex-direction: column;
  overflow-y: auto; -webkit-overflow-scrolling: touch;
  pointer-events: none;
}
.dosage-overlay.show { transform: translateX(0); pointer-events: auto; }
.dosage-content { padding: 16px 20px 40px; }
.dosage-section-title {
  font-size: 11px; font-weight: 600;
  letter-spacing: 0.1em; text-transform: uppercase;
  color: var(--cyan); margin: 20px 0 8px;
}
.dosage-section-title:first-child { margin-top: 8px; }
.dosage-text { font-size: 14px; line-height: 1.7; color: var(--text-secondary); margin: 0; }
.dosage-footer {
  text-align: center; font-size: 12px; font-style: italic;
  color: var(--text-dim); padding: 24px 20px 40px; line-height: 1.5;
}

/* ── SPACE CHECKLIST BOTTOM SHEET ── */
.checklist-sheet-bg {
  position: fixed; inset: 0; z-index: 99992;
  background: rgba(0,0,0,0.6);
  opacity: 0; pointer-events: none; transition: opacity 0.3s;
}
.checklist-sheet-bg.show { opacity: 1; pointer-events: auto; }
.checklist-sheet {
  position: fixed; bottom: 0; left: 0; right: 0;
  z-index: 99993; background: var(--bg-card);
  border-radius: 20px 20px 0 0; max-height: 80vh;
  transform: translateY(100%);
  transition: transform 0.35s cubic-bezier(0.25,0.46,0.45,0.94);
  display: flex; flex-direction: column;
}
.checklist-sheet.show { transform: translateY(0); }
.checklist-sheet-title {
  font-size: 17px; font-weight: 600; text-align: center;
  padding: 20px 16px 12px; border-bottom: 1px solid var(--border-glass);
}
.checklist-body { padding: 8px 0; overflow-y: auto; -webkit-overflow-scrolling: touch; }
.checklist-row {
  display: flex; align-items: center; gap: 14px;
  padding: 14px 20px; cursor: pointer;
  -webkit-tap-highlight-color: transparent;
  transition: background 0.15s;
}
.checklist-row:active { background: rgba(255,255,255,0.03); }
.checklist-check {
  width: 22px; height: 22px; border-radius: 6px;
  border: 2px solid var(--border-glass);
  display: flex; align-items: center; justify-content: center;
  flex-shrink: 0; transition: all 0.2s;
}
.checklist-row.checked .checklist-check {
  background: var(--cyan); border-color: var(--cyan);
}
.checklist-row.checked .checklist-check::after {
  content: '✓'; color: var(--bg-deep); font-size: 13px; font-weight: 700;
}
.checklist-row.checked .checklist-label { opacity: 0.5; text-decoration: line-through; }
.checklist-label { font-size: 14px; color: var(--warm-white); }
.checklist-done {
  text-align: center; padding: 16px 0 8px;
  font-size: 14px; color: var(--orange); opacity: 0.8;
  display: none;
}
.checklist-done.show { display: block; }
.checklist-done-star { font-size: 20px; display: block; margin-bottom: 4px; opacity: 0.6; }
.checklist-close-btn {
  display: block; width: calc(100% - 32px);
  margin: 8px 16px calc(16px + var(--safe-bottom));
  padding: 14px; background: rgba(132,207,195,0.12);
  border: none; border-radius: var(--radius-md);
  color: var(--cyan); font-size: 15px; font-weight: 600;
  cursor: pointer; font-family: 'Inter', sans-serif;
}

/* ── READING LIST PAGE ── */
.reading-overlay {
  position: fixed; inset: 0; z-index: 99991;
  background: var(--bg-deep);
  transform: translateX(100%);
  transition: transform 0.3s cubic-bezier(0.25,0.46,0.45,0.94);
  display: flex; flex-direction: column;
  overflow-y: auto; -webkit-overflow-scrolling: touch;
  pointer-events: none;
}
.reading-overlay.show { transform: translateX(0); pointer-events: auto; }
.reading-item {
  display: flex; align-items: center; gap: 14px;
  padding: 14px 16px;
  border-bottom: 1px solid var(--border-glass);
  cursor: pointer; transition: background 0.15s;
  -webkit-tap-highlight-color: transparent;
}
.reading-item:active { background: rgba(255,255,255,0.03); }
.reading-cover {
  width: 64px; height: 64px; border-radius: 8px;
  object-fit: cover; background: var(--bg-card);
  flex-shrink: 0;
}
.reading-cover-fallback {
  width: 64px; height: 64px; border-radius: 8px;
  background: linear-gradient(135deg, var(--portal-darker), #2d2a2a);
  display: flex; align-items: center; justify-content: center;
  font-size: 24px; flex-shrink: 0;
}
.reading-info { flex: 1; min-width: 0; }
.reading-title { font-size: 15px; font-weight: 600; color: var(--warm-white); }
.reading-author { font-size: 13px; color: var(--text-secondary); margin-top: 2px; }
.reading-note { font-size: 12px; font-style: italic; color: var(--orange); opacity: 0.7; margin-top: 4px; display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden; }
.fireside-contextual-banner {
  display: none; padding: 8px 14px; margin: 0 12px 8px;
  background: rgba(59,130,246,0.06); border: 1px solid rgba(99,102,241,0.1);
  border-radius: 10px; font-size: 12px; color: rgba(147,197,253,0.7);
  align-items: center; gap: 8px;
}
.fireside-contextual-banner.show { display: flex; }
.fireside-banner-text { flex: 1; }
.fireside-banner-actions { display: flex; gap: 6px; }
.fireside-banner-btn {
  padding: 4px 10px; border-radius: 8px; font-size: 11px; font-weight: 600;
  background: rgba(99,102,241,0.15); border: none; color: #93c5fd; cursor: pointer;
}
.fireside-banner-dismiss {
  background: none; border: none; color: var(--text-dim); cursor: pointer; font-size: 14px; padding: 2px;
}
.fireside-journal-link {
  display: block; text-align: center; padding: 12px; margin-top: 20px;
  font-size: 12px; color: rgba(147,197,253,0.5); text-decoration: none;
}
.fireside-journal-link:hover { color: rgba(147,197,253,0.7); }
.past-event-badge {
  position: absolute; top: 8px; right: 8px;
  background: rgba(26,24,24,0.7); color: var(--text-dim);
  font-size: 10px; padding: 3px 8px; border-radius: 6px;
  text-transform: uppercase; letter-spacing: 1px; z-index: 2;
  backdrop-filter: blur(4px); -webkit-backdrop-filter: blur(4px);
}
.resource-category { margin-bottom: 24px; }
.resource-category-title {
  font-family: var(--font-heading); font-size: 14px; font-weight: 700;
  color: var(--cyan); text-transform: uppercase; letter-spacing: 1px;
  margin-bottom: 10px;
}
.resource-item {
  display: flex; align-items: center; gap: 12px;
  padding: 12px 14px; margin-bottom: 6px;
  background: var(--bg-card); border: 1px solid var(--border-glass);
  border-radius: var(--radius-md); cursor: pointer; transition: border-color 0.2s;
}
.resource-item:hover { border-color: var(--magenta); }
.resource-icon { width: 28px; height: 28px; flex-shrink: 0; display: flex; align-items: center; justify-content: center; }
.resource-icon svg { width: 24px; height: 24px; stroke: url(#portal-icon-grad); }
.resource-info { flex: 1; }
.resource-name { font-size: 14px; font-weight: 600; color: var(--warm-white); }
.resource-desc { font-size: 12px; color: var(--text-dim); margin-top: 2px; }
.resource-arrow { color: var(--text-dim); }

/* ── PLAYLISTS SUB-VIEW ── */
.music-overlay {
  position: fixed; top: 0; left: 0; width: 100%; height: 100%;
  background: var(--bg-deep); z-index: 99992;
  display: flex; flex-direction: column;
  transform: translateX(100%); transition: transform 0.3s cubic-bezier(0.32,0.72,0,1);
  pointer-events: none;
}
.music-overlay.show { transform: translateX(0); pointer-events: auto; }
/* ── Section headers (match Journey Companion) ── */
.music-section-hdr {
  padding: 22px 16px 6px;
  font-size: 11px; font-weight: 700; letter-spacing: 1.2px;
  text-transform: uppercase; color: var(--accent-cyan, #84cfc3);
  border-top: 1px solid rgba(255,255,255,0.06);
}
.music-section-hdr:first-child { border-top: none; }
.music-section-ctx {
  padding: 0 16px 10px;
  font-size: 12px; color: var(--text-dim); font-style: italic; line-height: 1.4;
}
/* ── Standard music item (album/playlist) ── */
.music-item {
  display: flex; align-items: center; gap: 14px;
  padding: 10px 16px; cursor: pointer;
  transition: background 0.15s;
}
.music-item:active { background: rgba(255,255,255,0.04); }
.music-art {
  width: 80px; height: 80px; border-radius: 8px;
  background: linear-gradient(135deg, rgba(55,65,81,0.6), rgba(75,85,99,0.4));
  display: flex; align-items: center; justify-content: center;
  flex-shrink: 0; overflow: hidden; position: relative;
}
.music-art img {
  width: 100%; height: 100%; object-fit: cover;
  border-radius: 8px; position: relative; z-index: 1;
}
.music-art-emoji {
  position: absolute; font-size: 32px; opacity: 0.5; z-index: 0;
}
.music-art-skeleton {
  width: 100%; height: 100%; border-radius: 8px;
  background: linear-gradient(135deg, rgba(55,65,81,0.7), rgba(75,85,99,0.5));
  animation: skeletonPulse 1.5s ease-in-out infinite;
}
@keyframes skeletonPulse {
  0%, 100% { opacity: 0.5; }
  50% { opacity: 0.8; }
}
.music-info { flex: 1; min-width: 0; }
.music-title {
  font-size: 15px; font-weight: 700; color: var(--warm-white);
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
.music-subtitle {
  font-size: 12px; color: var(--text-dim); margin-top: 2px;
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
.music-badge {
  display: inline-flex; align-items: center; gap: 4px;
  padding: 2px 8px; border-radius: 12px;
  font-size: 10px; font-weight: 600; margin-top: 5px;
}
.music-badge.spotify {
  background: rgba(29,185,84,0.15); color: #1DB954;
}
.music-badge.external {
  background: rgba(255,255,255,0.08); color: var(--text-dim);
}
.music-context {
  font-size: 11px; color: rgba(255,220,180,0.55); font-style: italic;
  margin-top: 4px; line-height: 1.3;
  display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden;
}
.music-chevron {
  color: var(--text-muted); font-size: 18px; flex-shrink: 0; margin-left: 4px;
}
/* ── MAPS horizontal scroll row ── */
.maps-row-header {
  display: flex; align-items: center; justify-content: space-between;
  padding: 14px 16px 8px;
}
.maps-row-title {
  font-size: 13px; font-weight: 700; color: var(--warm-white);
}
.maps-row-see-all {
  font-size: 12px; color: var(--accent-cyan, #84cfc3); cursor: pointer;
  font-weight: 600;
}
.maps-scroll {
  display: flex; gap: 12px; padding: 0 16px 8px;
  overflow-x: auto; -webkit-overflow-scrolling: touch;
  scrollbar-width: none; position: relative;
}
.maps-scroll::-webkit-scrollbar { display: none; }
.maps-scroll-wrap {
  position: relative;
}
.maps-scroll-wrap::after {
  content: ''; position: absolute; top: 0; right: 0;
  width: 40px; height: 100%; pointer-events: none;
  background: linear-gradient(to right, transparent, var(--bg-deep));
  z-index: 2;
}
.maps-card {
  flex-shrink: 0; width: 108px; cursor: pointer; text-align: center;
}
.maps-card-art {
  width: 100px; height: 100px; border-radius: 10px;
  background: linear-gradient(135deg, rgba(55,65,81,0.6), rgba(75,85,99,0.4));
  display: flex; align-items: center; justify-content: center;
  overflow: hidden; margin: 0 auto; position: relative;
}
.maps-card-art img {
  width: 100%; height: 100%; object-fit: cover; border-radius: 8px;
  position: relative; z-index: 1;
}
.maps-card-art .music-art-skeleton { width: 100%; height: 100%; }
.maps-card-name {
  font-size: 11px; color: var(--text-dim); margin-top: 6px;
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
  line-height: 1.3;
}
/* MAPS expanded full list */
.maps-full-list { display: none; padding: 0 0 8px; }
.maps-full-list.expanded { display: block; }
/* ── MAPS detail sheet ── */
.maps-detail-sheet {
  position: fixed; bottom: 0; left: 0; right: 0;
  background: var(--bg-card); border-top: 1px solid var(--border-glass);
  border-radius: 16px 16px 0 0; z-index: 100001;
  transform: translateY(100%); transition: transform 0.3s cubic-bezier(0.32,0.72,0,1);
  max-height: 60vh; padding: 20px 20px 32px;
}
.maps-detail-sheet.show { transform: translateY(0); }
.maps-detail-sheet-bg {
  position: fixed; inset: 0; background: rgba(0,0,0,0.5);
  z-index: 100000; opacity: 0; pointer-events: none;
  transition: opacity 0.3s;
}
.maps-detail-sheet-bg.show { opacity: 1; pointer-events: auto; }
.maps-detail-content {
  display: flex; gap: 16px; align-items: flex-start;
}
.maps-detail-art {
  width: 80px; height: 80px; border-radius: 8px; flex-shrink: 0;
  overflow: hidden; background: linear-gradient(135deg, rgba(55,65,81,0.6), rgba(75,85,99,0.4));
}
.maps-detail-art img { width: 100%; height: 100%; object-fit: cover; }
.maps-detail-info { flex: 1; }
.maps-detail-name { font-size: 16px; font-weight: 700; color: var(--warm-white); }
.maps-detail-sub { font-size: 12px; color: var(--text-dim); margin-top: 2px; }
.maps-detail-ctx {
  font-size: 13px; color: rgba(255,220,180,0.6); font-style: italic;
  margin-top: 12px; line-height: 1.5;
}
.maps-detail-btn {
  display: flex; align-items: center; justify-content: center; gap: 8px;
  margin-top: 16px; padding: 12px;
  background: #1DB954; color: #000; font-weight: 700; font-size: 14px;
  border: none; border-radius: 24px; cursor: pointer; width: 100%;
}
/* ── Music hero card (first DURING item) ── */
.music-hero {
  position: relative; width: 100%; height: 260px;
  border-radius: 12px; overflow: hidden; cursor: pointer;
  margin: 0 0 6px;
}
.music-hero img {
  width: 100%; height: 100%; object-fit: cover;
}
.music-hero-gradient {
  position: absolute; inset: 0;
  background: linear-gradient(to top, rgba(26,24,24,0.95) 0%, rgba(26,24,24,0.4) 50%, transparent 100%);
}
.music-hero-info {
  position: absolute; bottom: 16px; left: 16px; right: 16px; z-index: 2;
}
.music-hero-title {
  font-size: 18px; font-weight: 700; color: #fff;
}
.music-hero-subtitle {
  font-size: 13px; color: rgba(255,255,255,0.7); margin-top: 3px;
}
.music-hero-badge {
  display: inline-flex; align-items: center; gap: 4px;
  padding: 3px 10px; border-radius: 12px; margin-top: 8px;
  font-size: 10px; font-weight: 600;
  background: rgba(29,185,84,0.2); color: #1DB954;
}
.music-hero-ctx {
  font-size: 11px; color: rgba(255,220,180,0.6); font-style: italic;
  margin-top: 6px; line-height: 1.3;
}
/* ── Binaural footnote ── */
.binaural-footnote {
  padding: 8px 16px 20px; font-size: 11px;
  color: var(--text-muted); font-style: italic;
}

/* ── REPORT / BLOCK ── */
.report-modal {
  position: fixed; top: 0; left: 0; width: 100%; height: 100%;
  background: rgba(0,0,0,0.7); z-index: 100003;
  display: flex; align-items: flex-end; justify-content: center;
  opacity: 0; visibility: hidden; pointer-events: none;
  transition: opacity 0.3s ease, visibility 0.3s ease;
}
.report-modal.show { opacity: 1; visibility: visible; pointer-events: auto; }
.report-sheet {
  width: 100%; max-width: 500px;
  background: var(--bg-card); border-radius: 20px 20px 0 0;
  padding: 24px 20px 40px; transform: translateY(100%);
  transition: transform 0.35s cubic-bezier(0.32,0.72,0,1);
}
.report-modal.show .report-sheet { transform: translateY(0); }
.report-handle { width: 36px; height: 4px; background: var(--border-glass); border-radius: 2px; margin: 0 auto 16px; }
.report-title { font-family: var(--font-heading); font-size: 18px; font-weight: 700; color: var(--warm-white); margin-bottom: 16px; }
.report-option {
  display: flex; align-items: center; gap: 12px;
  padding: 14px; margin-bottom: 8px;
  background: var(--bg-elevated); border: 1px solid var(--border-glass);
  border-radius: var(--radius-md); cursor: pointer; transition: border-color 0.2s;
}
.report-option:hover { border-color: var(--magenta); }
.report-option-icon { font-size: 18px; }
.report-option-label { font-size: 14px; color: var(--warm-white); }
.report-option-desc { font-size: 11px; color: var(--text-dim); margin-top: 2px; }
.report-cancel {
  width: 100%; padding: 14px; margin-top: 8px; border-radius: var(--radius-md);
  background: none; border: 1px solid var(--border-glass);
  color: var(--text-dim); font-size: 14px; cursor: pointer; font-family: var(--font-body);
}

/* ── NOTIFICATION PERMISSION PROMPT ── */
.notif-prompt {
  position: fixed; top: 12px; left: 16px; right: 16px;
  background: var(--bg-card); border: 1px solid rgba(132,207,195,0.2);
  border-radius: var(--radius-lg); padding: 16px; padding-top: 20px;
  z-index: 5001; box-shadow: 0 8px 32px rgba(0,0,0,0.5);
  backdrop-filter: blur(16px);
  transform: translateY(-200%); transition: transform 0.4s cubic-bezier(0.32,0.72,0,1);
  pointer-events: none;
}
.notif-prompt.show { transform: translateY(0); pointer-events: auto; }
.notif-prompt-text { font-size: 14px; color: var(--text-secondary); margin-bottom: 12px; line-height: 1.5; }
.notif-prompt-text strong { color: var(--cyan); }
.notif-prompt-actions { display: flex; gap: 10px; }
.notif-prompt-enable {
  flex: 1; padding: 10px; border-radius: var(--radius-md);
  background: var(--cyan); color: var(--bg-deep); font-weight: 600;
  font-size: 13px; border: none; cursor: pointer; font-family: var(--font-body);
}
.notif-prompt-skip {
  padding: 10px 14px; border-radius: var(--radius-md);
  background: none; border: 1px solid var(--border-glass);
  color: var(--text-dim); font-size: 13px; cursor: pointer; font-family: var(--font-body);
}

/* ── SCREEN TRANSITIONS ── */
.screen { transition: opacity 0.25s ease, transform 0.25s ease; }
.screen.screen-entering { animation: screenSlideIn 0.2s ease-out forwards; }
@keyframes screenSlideIn { from { transform: translateY(6px); } to { transform: translateY(0); } }

/* ── MESSAGE POP-IN ── */
.chat-msg, .dm-msg { animation: msgPopIn 0.3s cubic-bezier(0.34,1.56,0.64,1) both; }
@keyframes msgPopIn { from { opacity: 0; transform: scale(0.92) translateY(8px); } to { opacity: 1; transform: scale(1) translateY(0); } }

/* ── AVATAR ONLINE PULSE ── */
.avatar-online { position: relative; }
.avatar-online::after {
  content: ''; position: absolute; bottom: 2px; right: 2px;
  width: 10px; height: 10px; border-radius: 50%;
  background: #22c55e; border: 2px solid var(--bg-deep);
  animation: onlinePulse 2s ease-in-out infinite;
}
@keyframes onlinePulse { 0%,100% { box-shadow: 0 0 0 0 rgba(34,197,94,0.4); } 50% { box-shadow: 0 0 0 4px rgba(34,197,94,0); } }

/* ── CARD BREATHING ── */
.circle-card, .event-card, .dm-card { transition: transform 0.2s ease, box-shadow 0.2s ease; }
.circle-card:active, .event-card:active, .dm-card:active { transform: scale(0.97); }

/* ── AMBIENT AURORA ── */
.aurora-bg {
  position: fixed; top: 0; left: 0; width: 100%; height: 100%;
  z-index: -1; pointer-events: none; overflow: hidden;
}
.aurora-blob {
  position: absolute; border-radius: 50%; filter: blur(80px); opacity: 0.08;
  animation: auroraFloat 20s ease-in-out infinite alternate;
}
.aurora-blob:nth-child(1) {
  width: 400px; height: 400px; background: var(--cyan);
  top: -100px; left: -50px; animation-duration: 25s;
}
.aurora-blob:nth-child(2) {
  width: 350px; height: 350px; background: var(--magenta);
  top: 30%; right: -80px; animation-duration: 20s; animation-delay: -5s;
}
.aurora-blob:nth-child(3) {
  width: 300px; height: 300px; background: var(--orange);
  bottom: -50px; left: 20%; animation-duration: 22s; animation-delay: -10s;
}
@keyframes auroraFloat {
  0% { transform: translate(0, 0) scale(1); }
  33% { transform: translate(30px, -20px) scale(1.1); }
  66% { transform: translate(-20px, 30px) scale(0.95); }
  100% { transform: translate(10px, -10px) scale(1.05); }
}

/* ── LOADING SKELETONS ── */
.skeleton-screen {
  display: flex; flex-direction: column; align-items: center;
  justify-content: center; padding: 40px 20px; gap: 16px;
}
.skeleton-mushroom {
  width: 48px; height: 48px; opacity: 0.3;
  animation: skeletonPulse 1.5s ease-in-out infinite;
}
@keyframes skeletonPulse { 0%,100% { opacity: 0.15; transform: scale(0.95); } 50% { opacity: 0.35; transform: scale(1.05); } }
.skeleton-bar {
  height: 12px; border-radius: 6px;
  background: linear-gradient(90deg, var(--bg-elevated) 25%, rgba(132,207,195,0.08) 50%, var(--bg-elevated) 75%);
  background-size: 200% 100%; animation: skeletonShimmer 1.8s infinite;
}
@keyframes skeletonShimmer { 0% { background-position: 200% 0; } 100% { background-position: -200% 0; } }
.skeleton-circle {
  border-radius: 50%;
  background: linear-gradient(90deg, var(--bg-elevated) 25%, rgba(132,207,195,0.08) 50%, var(--bg-elevated) 75%);
  background-size: 200% 100%; animation: skeletonShimmer 1.8s infinite;
}
.skeleton-card {
  width: 100%; padding: 16px; border-radius: var(--radius-md);
  background: var(--bg-card); border: 1px solid var(--border-glass);
  display: flex; gap: 12px; align-items: center;
}

/* ── VOICE MESSAGES ── */
.voice-record-btn {
  width: 36px; height: 36px; border-radius: 50%;
  background: var(--bg-elevated); border: 1px solid var(--border-glass);
  display: flex; align-items: center; justify-content: center;
  cursor: pointer; flex-shrink: 0; transition: all 0.2s;
  -webkit-user-select: none; user-select: none;
}
.voice-record-btn:hover { border-color: var(--magenta); }
.voice-record-btn.recording {
  background: var(--magenta); border-color: var(--magenta);
  animation: voiceRecordPulse 1s ease-in-out infinite;
}
.voice-record-btn.recording svg { color: #fff; }
@keyframes voiceRecordPulse { 0%,100% { box-shadow: 0 0 0 0 rgba(255,98,154,0.4); } 50% { box-shadow: 0 0 0 8px rgba(255,98,154,0); } }
.voice-record-indicator {
  position: fixed; bottom: 80px; left: 16px; right: 16px;
  background: var(--bg-card); border: 1px solid var(--magenta);
  border-radius: var(--radius-lg); padding: 14px 20px;
  display: flex; align-items: center; gap: 12px;
  z-index: 5000; box-shadow: 0 8px 32px rgba(0,0,0,0.5);
  animation: tooltipIn 0.2s ease;
}
.voice-record-dot {
  width: 10px; height: 10px; border-radius: 50%; background: var(--magenta);
  animation: voiceRecordPulse 1s ease-in-out infinite;
}
.voice-record-timer { font-size: 16px; font-weight: 600; color: var(--warm-white); font-family: var(--font-body); }
.voice-record-label { flex: 1; font-size: 12px; color: var(--text-dim); }
.voice-record-cancel { font-size: 12px; color: var(--magenta); cursor: pointer; background: none; border: none; font-family: var(--font-body); }

.voice-msg {
  display: flex; align-items: center; gap: 10px;
  padding: 10px 14px; background: rgba(255,98,154,0.08);
  border: 1px solid rgba(255,98,154,0.15); border-radius: var(--radius-md);
  min-width: 180px;
}
.voice-msg-play {
  width: 32px; height: 32px; border-radius: 50%;
  background: var(--magenta); border: none;
  display: flex; align-items: center; justify-content: center;
  cursor: pointer; flex-shrink: 0;
}
.voice-msg-play svg { width: 14px; height: 14px; color: #fff; }
.voice-msg-wave {
  flex: 1; height: 24px; display: flex; align-items: center; gap: 2px;
}
.voice-msg-wave span {
  width: 3px; border-radius: 2px; background: var(--magenta); opacity: 0.5;
}
.voice-msg-duration { font-size: 11px; color: var(--text-dim); white-space: nowrap; }

/* ── PORTAL DAY ── */
.portal-day-overlay {
  position: fixed; top: 0; left: 0; width: 100%; height: 100%;
  background: radial-gradient(ellipse at center, rgba(26,24,24,0.88) 0%, rgba(8,8,16,0.96) 100%);
  z-index: 100004;
  display: flex; align-items: center; justify-content: center;
  opacity: 0; visibility: hidden; pointer-events: none;
  transition: opacity 0.6s ease, visibility 0.6s ease;
}
.portal-day-overlay.show { opacity: 1; visibility: visible; pointer-events: auto; }
.portal-day-card {
  text-align: center; max-width: 340px; padding: 40px 28px;
  animation: portalDayCardIn 0.8s cubic-bezier(0.16,1,0.3,1);
}
@keyframes portalDayCardIn {
  0% { opacity: 0; transform: scale(0.9) translateY(20px); }
  100% { opacity: 1; transform: scale(1) translateY(0); }
}
.portal-day-star-ring {
  position: relative; width: 100px; height: 100px; margin: 0 auto 20px;
}
.portal-day-star-ring::before {
  content: ''; position: absolute; inset: 0; border-radius: 50%;
  border: 1px solid rgba(240,232,255,0.08);
  animation: portalDayRingPulse 3s ease-in-out infinite;
}
.portal-day-star-ring::after {
  content: ''; position: absolute; inset: -8px; border-radius: 50%;
  border: 1px solid rgba(240,232,255,0.04);
  animation: portalDayRingPulse 3s ease-in-out 0.5s infinite;
}
@keyframes portalDayRingPulse {
  0%, 100% { transform: scale(1); opacity: 0.5; }
  50% { transform: scale(1.08); opacity: 1; }
}
.portal-day-star-icon {
  position: absolute; inset: 0; display: flex; align-items: center; justify-content: center;
  font-size: 48px; color: #ffa300;
  animation: portalDayStarSpin 20s linear infinite;
  text-shadow: 0 0 30px rgba(255,163,0,0.3);
}
@keyframes portalDayStarSpin {
  0% { transform: rotate(0deg); }
  100% { transform: rotate(360deg); }
}
.portal-day-number {
  font-family: var(--font-heading); font-size: 56px; font-weight: 700;
  background: linear-gradient(135deg, var(--cyan), var(--magenta), var(--orange));
  -webkit-background-clip: text; -webkit-text-fill-color: transparent;
  background-clip: text; margin-bottom: 4px; letter-spacing: 4px;
}
.portal-day-label {
  font-family: var(--font-heading); font-size: 14px; font-weight: 600;
  color: rgba(240,232,255,0.4); text-transform: uppercase; letter-spacing: 4px;
  margin-bottom: 20px;
}
.portal-day-divider {
  width: 40px; height: 1px; margin: 0 auto 20px;
  background: linear-gradient(90deg, transparent, rgba(255,163,0,0.4), transparent);
}
.portal-day-message {
  font-family: var(--font-body); font-size: 16px; font-weight: 300;
  color: var(--warm-white); line-height: 1.7; margin-bottom: 28px;
  font-style: italic;
}
.portal-day-close {
  padding: 14px 36px; border-radius: 28px;
  background: linear-gradient(90deg, var(--orange), var(--magenta));
  color: #1a1a1a; font-weight: 700; font-size: 14px; border: none;
  cursor: pointer; font-family: var(--font-heading);
  letter-spacing: 1.5px; text-transform: uppercase;
  transition: transform 0.15s;
}
.portal-day-close:active { transform: scale(0.96); }

/* ── IG STORY SHARE ── */
.ig-share-modal {
  position: fixed; top: 0; left: 0; width: 100%; height: 100%;
  background: rgba(0,0,0,0.85); z-index: 100005;
  display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 20px;
  opacity: 0; visibility: hidden; pointer-events: none;
  transition: opacity 0.3s ease, visibility 0.3s ease;
  -webkit-backdrop-filter: blur(20px); backdrop-filter: blur(20px);
}
.ig-share-modal.show { opacity: 1; visibility: visible; pointer-events: auto; }
.ig-share-canvas-wrap {
  border-radius: 20px; overflow: hidden;
  box-shadow: 0 20px 60px rgba(0,0,0,0.6), 0 0 80px rgba(132,207,195,0.08);
}
.ig-share-canvas-wrap canvas { display: block; }
.ig-share-actions { display: flex; gap: 12px; }
.ig-share-btn {
  padding: 14px 28px; border-radius: var(--radius-md);
  font-weight: 600; font-size: 14px; border: none;
  cursor: pointer; font-family: var(--font-body);
  letter-spacing: 0.3px;
}
.ig-share-save { background: linear-gradient(135deg, var(--cyan), var(--magenta)); color: #252525; }
.ig-share-close { background: var(--bg-elevated); border: 1px solid var(--border-glass); color: var(--text-dim); }

/* ── RETURN POPUP ── */
.return-popup-overlay {
  position: fixed; top: 0; left: 0; width: 100%; height: 100%;
  background: rgba(26,24,24,0.85);
  backdrop-filter: blur(12px); -webkit-backdrop-filter: blur(12px);
  z-index: 100010;
  display: flex; align-items: center; justify-content: center;
  opacity: 0; transition: opacity 0.3s;
  pointer-events: none;
}
.return-popup-overlay.show { opacity: 1; pointer-events: auto; }

.return-popup {
  width: calc(100% - 48px); max-width: 380px;
  background: var(--bg-card);
  border: 1px solid var(--border-glass);
  border-radius: var(--radius-xl);
  overflow: hidden;
  transform: translateY(20px) scale(0.95);
  transition: transform 0.4s cubic-bezier(0.32,0.72,0,1);
}
.return-popup-overlay.show .return-popup {
  transform: translateY(0) scale(1);
}

.return-popup-image {
  width: 100%; height: 180px; object-fit: cover;
}
.return-popup-badge {
  display: inline-block;
  padding: 4px 12px; margin: -14px 0 0 16px;
  border-radius: 100px;
  font-size: 11px; font-weight: 700;
  font-family: 'Oswald', sans-serif;
  letter-spacing: 1.5px; text-transform: uppercase;
  position: relative; z-index: 1;
}
.return-popup-badge.event { background: var(--cyan); color: var(--bg-deep); }
.return-popup-badge.news { background: var(--magenta); color: #fff; }
.return-popup-badge.feature { background: var(--orange); color: var(--bg-deep); }
.return-popup-badge.sponsor { background: var(--border-glass); color: var(--text-primary); }

.return-popup-body { padding: 12px 20px 20px; }
.return-popup-title {
  font-family: 'Oswald', sans-serif; font-size: 20px; font-weight: 700;
  color: var(--text-primary); margin-bottom: 8px;
  letter-spacing: 0.5px;
}
.return-popup-desc {
  font-size: 14px; color: var(--text-secondary); line-height: 1.5;
  margin-bottom: 16px;
}
.return-popup-actions { display: flex; gap: 10px; }
.return-popup-cta {
  flex: 1; padding: 12px; border-radius: var(--radius-md);
  border: none; font-family: 'Oswald', sans-serif;
  font-size: 14px; font-weight: 600; letter-spacing: 1px;
  text-transform: uppercase; cursor: pointer; transition: all 0.2s;
}
.return-popup-cta.primary {
  background: var(--gradient-portal); color: var(--bg-deep);
}
.return-popup-cta.secondary {
  background: transparent; border: 1px solid var(--border-glass);
  color: var(--text-dim);
}
.return-popup-cta:active { transform: scale(0.97); }

/* ── UTILITY ── */
.hidden { display: none !important; }

/* ── TAKE ACTION OVERLAY ── */
/* take-action now uses .chat-view pattern — no custom overlay needed */

/* ── PROPELLER-STYLE ACTION CARDS ── */
a.action-card { color: inherit; text-decoration: none; -webkit-tap-highlight-color: rgba(255,28,49,0.15); }
.action-card {
  display: flex;
  align-items: center;
  gap: 14px;
  padding: 16px;
  background: rgba(255,255,255,0.04);
  border: 1px solid rgba(255,255,255,0.08);
  border-radius: 16px;
  margin-bottom: 12px;
  cursor: pointer;
  transition: all 0.2s;
  position: relative;
  overflow: hidden;
  -webkit-tap-highlight-color: rgba(255,28,49,0.1);
  touch-action: manipulation;
  -webkit-user-select: none;
  user-select: none;
}
.action-card:active { transform: scale(0.97); background: rgba(255,255,255,0.06); }
.action-card::before {
  content: '';
  position: absolute;
  top: 0; left: 0; bottom: 0;
  width: 3px;
  background: #FF1C31;
  border-radius: 0 2px 2px 0;
}
.action-card-icon {
  width: 52px; height: 52px;
  border-radius: 14px;
  background: rgba(255,28,49,0.08);
  border: 1px solid rgba(255,28,49,0.12);
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  padding: 10px;
}
.action-card-icon svg { width: 100%; height: 100%; }
.action-card-info { flex: 1; min-width: 0; }
.action-card-name {
  font-family: 'Oswald', sans-serif;
  font-weight: 600;
  font-size: 16px;
  letter-spacing: 0.5px;
  margin-bottom: 4px;
}
.action-card-desc {
  font-size: 13px;
  color: var(--text-dim);
  line-height: 1.4;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}
.action-card-meta {
  display: flex;
  align-items: center;
  gap: 8px;
  margin-top: 6px;
}
.action-card-type {
  font-size: 10px;
  font-weight: 600;
  letter-spacing: 1px;
  text-transform: uppercase;
  color: #FF1C31;
  opacity: 0.8;
}
.action-card-points {
  flex-shrink: 0;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 2px;
}
.action-card-pts-num {
  font-family: 'Oswald', sans-serif;
  font-size: 22px;
  font-weight: 700;
  color: #FF1C31;
  line-height: 1;
}
.action-card-pts-label {
  font-size: 9px;
  font-weight: 600;
  letter-spacing: 1.5px;
  text-transform: uppercase;
  color: rgba(255,255,255,0.4);
}
.action-card.completed::before { background: var(--cyan); }
.action-card.completed .action-card-pts-num { color: var(--cyan); }
.action-card.completed .action-card-pts-num::after { content: ' ✓'; font-size: 14px; }
.action-card.completed .action-card-type { color: var(--cyan); }

/* ══════════════════════════════════════════════════════════════
   LEARN EXPERIENCE — Immersive full-screen action overlay
   ══════════════════════════════════════════════════════════════ */
.learn-overlay {
  position: fixed;
  top: 0; left: 0; right: 0; bottom: 0;
  z-index: 100011;
  background: #080810;
  display: none;
  flex-direction: column;
  overflow: hidden;
  touch-action: pan-y;
}
/* Starfield speckle on learn overlay */
.learn-overlay::after {
  content: '';
  position: fixed;
  top: 0; left: 0; width: 100%; height: 100%;
  pointer-events: none;
  z-index: 0;
  opacity: 0.4;
  background-image:
    radial-gradient(1.5px 1.5px at 12% 18%, #84cfc3 50%, transparent 100%),
    radial-gradient(1.5px 1.5px at 25% 40%, #ff629a 50%, transparent 100%),
    radial-gradient(2px 2px at 38% 10%, #84cfc3 50%, transparent 100%),
    radial-gradient(1.5px 1.5px at 50% 28%, #ff629a 40%, transparent 100%),
    radial-gradient(1.5px 1.5px at 60% 50%, #84cfc3 50%, transparent 100%),
    radial-gradient(2px 2px at 70% 15%, #ffa300 50%, transparent 100%),
    radial-gradient(1.5px 1.5px at 80% 42%, #ff629a 50%, transparent 100%),
    radial-gradient(1.5px 1.5px at 90% 60%, #84cfc3 50%, transparent 100%),
    radial-gradient(1.5px 1.5px at 8% 65%, #ff629a 40%, transparent 100%),
    radial-gradient(2px 2px at 18% 82%, #84cfc3 50%, transparent 100%),
    radial-gradient(1.5px 1.5px at 32% 70%, #ffa300 50%, transparent 100%),
    radial-gradient(1.5px 1.5px at 45% 85%, #ff629a 50%, transparent 100%),
    radial-gradient(1.5px 1.5px at 55% 75%, #84cfc3 50%, transparent 100%),
    radial-gradient(2px 2px at 68% 62%, #ff629a 50%, transparent 100%),
    radial-gradient(1.5px 1.5px at 78% 80%, #84cfc3 50%, transparent 100%),
    radial-gradient(1.5px 1.5px at 88% 72%, #ffa300 50%, transparent 100%),
    radial-gradient(1.5px 1.5px at 95% 88%, #ff629a 50%, transparent 100%),
    radial-gradient(1px 1px at 5% 32%, #84cfc3 50%, transparent 100%),
    radial-gradient(1px 1px at 22% 55%, #ffa300 40%, transparent 100%),
    radial-gradient(1.5px 1.5px at 40% 45%, #ff629a 50%, transparent 100%),
    radial-gradient(1px 1px at 52% 12%, #84cfc3 50%, transparent 100%),
    radial-gradient(1px 1px at 72% 35%, #ff629a 40%, transparent 100%),
    radial-gradient(1.5px 1.5px at 85% 18%, #ffa300 50%, transparent 100%),
    radial-gradient(1px 1px at 96% 65%, #84cfc3 50%, transparent 100%);
}
/* Ensure all learn children sit above starfield */
.learn-overlay > * { position: relative; z-index: 1; }
.learn-overlay.visible { display: flex; animation: learn-fade-in 0.4s ease; }
@keyframes learn-fade-in { from { opacity: 0; } to { opacity: 1; } }
/* Propeller font override — all Oswald inside learn overlay becomes aktiv-grotesk-condensed */
.learn-overlay [style*="Oswald"],
.learn-overlay .learn-ig-heading,
.learn-overlay .learn-ig-timing-val,
.learn-overlay .tm-phase-label,
.learn-overlay .learn-hero-title,
.learn-overlay .learn-content-heading,
.learn-overlay .learn-content-eyebrow,
.learn-overlay .learn-quiz-badge,
.learn-overlay .learn-mq-counter,
.learn-overlay .learn-mq-score,
.learn-overlay .learn-complete-title,
.learn-overlay .learn-complete-points,
.learn-overlay .sd-card .sd-statement,
.learn-overlay .sd-card .sd-prompt,
.learn-overlay .sd-card .sd-label,
.learn-overlay .sd-btn,
.learn-overlay .sd-xp,
.learn-overlay .rc-title,
.learn-overlay .ci-title,
.learn-overlay .learn-check-badge,
.learn-overlay .fc-num,
.learn-overlay .learn-timeline-year,
.learn-overlay .tm-xp-unlocked,
.learn-overlay .learn-risk-xp {
  font-family: 'aktiv-grotesk-condensed', 'Oswald', sans-serif !important;
}
/* Body text inside learn uses aktiv-grotesk */
.learn-overlay .learn-content-body,
.learn-overlay .learn-ig-bullet,
.learn-overlay .learn-ig-note,
.learn-overlay .learn-ig-form-text,
.learn-overlay .rc-preview,
.learn-overlay .rc-detail,
.learn-overlay .ci-desc,
.learn-overlay .tm-desc,
.learn-overlay .sd-verdict,
.learn-overlay .learn-title-desc {
  font-family: 'aktiv-grotesk', 'Inter', sans-serif !important;
}
/* Lores for eyebrow/accent labels */
.learn-overlay .learn-title-eyebrow,
.learn-overlay .learn-quiz-badge,
.learn-overlay .learn-mq-counter {
  font-family: 'lores-12-bold', monospace !important;
}

/* Progress bar */
.learn-progress {
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 3px;
  z-index: 10;
  background: rgba(255,255,255,0.06);
}
.learn-progress-fill {
  height: 100%;
  background: linear-gradient(90deg, var(--cyan), var(--magenta), var(--orange));
  transition: width 0.5s cubic-bezier(0.4, 0, 0.2, 1);
  border-radius: 0 2px 2px 0;
  box-shadow: 0 0 12px rgba(132,207,195,0.5);
}

/* Header */
.learn-header {
  display: flex;
  align-items: center;
  padding: 12px 16px;
  padding-top: calc(12px + env(safe-area-inset-top, 0px));
  z-index: 10;
  position: relative;
}
.learn-close {
  width: 36px; height: 36px;
  display: flex; align-items: center; justify-content: center;
  font-size: 22px; color: var(--text-secondary);
  cursor: pointer; border: none; background: none;
  -webkit-tap-highlight-color: transparent;
}
.learn-close:active { opacity: 0.5; }
.learn-title-bar {
  flex: 1; text-align: center;
  font-family: 'aktiv-grotesk-condensed', 'Oswald', sans-serif;
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 3px;
  text-transform: uppercase;
  color: var(--text-dim);
}
.learn-slide-count {
  width: 36px;
  text-align: right;
  font-size: 12px;
  color: var(--text-dim);
  font-weight: 500;
}

/* Slide viewport */
.learn-viewport {
  flex: 1;
  position: relative;
  overflow: hidden;
}
.learn-slide-track {
  display: flex;
  height: 100%;
  will-change: transform;
  transition: transform 0.55s cubic-bezier(0.22, 0.61, 0.36, 1);
}
.learn-slide-track.swiping { transition: none; }
/* Parallax: slides scale/fade based on visibility */
.learn-slide .learn-content-slide,
.learn-slide .learn-quiz-slide,
.learn-slide .learn-complete-slide {
  transition: transform 0.55s cubic-bezier(0.22, 0.61, 0.36, 1), opacity 0.55s ease;
}
.learn-slide.slide-exiting .learn-content-slide,
.learn-slide.slide-exiting .learn-quiz-slide {
  transform: scale(0.92);
  opacity: 0.4;
}
.learn-slide.slide-entering .learn-content-slide,
.learn-slide.slide-entering .learn-quiz-slide,
.learn-slide.slide-entering .learn-complete-slide {
  animation: learn-parallax-enter 0.5s ease 0.1s both;
}
@keyframes learn-parallax-enter {
  from { transform: scale(0.95) translateY(12px); opacity: 0.5; }
  to { transform: scale(1) translateY(0); opacity: 1; }
}

.learn-slide {
  flex: 0 0 100%;
  width: 100%;
  height: 100%;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: flex-start;
  padding: 20px 28px;
  padding-bottom: 80px;
  position: relative;
  overflow-y: auto;
  -webkit-overflow-scrolling: touch;
}

/* IG image slides — full-bleed background images */
.learn-ig-slide {
  position: absolute;
  top: 0; left: 0;
  width: 100%;
  height: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
}
.learn-ig-slide img {
  width: 100%;
  height: 100%;
  object-fit: contain;
  object-position: top center;
  pointer-events: none;
}
.learn-slide:has(.learn-ig-slide),
.learn-slide.learn-slide--ig {
  padding: 0;
  overflow: hidden;
}

/* Sacred geometry canvas (per-slide background) */
.learn-geo-canvas {
  position: absolute;
  top: 0; left: 0;
  width: 100%; height: 100%;
  pointer-events: none;
  opacity: 0.12;
  z-index: 0;
}

/* Content layering */
.learn-slide > * { position: relative; z-index: 1; }

/* ── Title slide ── */
.learn-title-slide {
  text-align: center;
  position: relative;
  width: 100%;
  height: 100%;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: flex-end;
  padding-bottom: 100px;
}
.learn-title-slide .learn-video-bg {
  position: absolute;
  inset: 0;
  z-index: 0;
}
.learn-title-slide .learn-video-bg::after {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, rgba(8,8,16,0.1) 0%, rgba(8,8,16,0.3) 40%, rgba(8,8,16,0.85) 75%, #080810 100%);
  z-index: 1;
}
.learn-title-eyebrow {
  font-family: 'lores-12-bold', monospace;
  font-size: 10px;
  font-weight: 400;
  letter-spacing: 4px;
  text-transform: uppercase;
  color: var(--cyan);
  opacity: 0.8;
  margin-bottom: 16px;
  position: relative;
  z-index: 2;
  animation: learn-slide-up 0.8s ease 0.3s both;
}
.learn-title-name {
  font-family: 'aktiv-grotesk-condensed', 'Oswald', sans-serif;
  font-size: 56px;
  font-weight: 900;
  letter-spacing: 6px;
  text-transform: uppercase;
  background: linear-gradient(135deg, var(--cyan), var(--magenta), var(--orange));
  -webkit-background-clip: text; -webkit-text-fill-color: transparent; background-clip: text;
  background-size: 200% 200%;
  animation: learn-slide-up 0.8s ease 0.5s both, learn-gradient-shift 4s ease infinite;
  margin-bottom: 8px;
  position: relative;
  z-index: 2;
}
.learn-title-desc {
  font-size: 14px;
  color: var(--text-secondary);
  max-width: 280px;
  line-height: 1.6;
  margin-bottom: 8px;
  position: relative;
  z-index: 2;
  animation: learn-slide-up 0.8s ease 0.7s both;
}
.learn-title-meta {
  display: flex;
  align-items: center;
  gap: 16px;
  font-size: 11px;
  color: var(--text-dim);
  letter-spacing: 1px;
  margin-bottom: 32px;
  position: relative;
  z-index: 2;
  animation: learn-slide-up 0.8s ease 0.9s both;
}
.learn-title-meta span { display: flex; align-items: center; gap: 4px; }
@keyframes learn-slide-up {
  from { opacity: 0; transform: translateY(20px); }
  to { opacity: 1; transform: translateY(0); }
}
/* Floating particles on title */
/* Organic speckle particles (matches Portal starfield) */
.learn-title-particle {
  position: absolute;
  pointer-events: none;
  z-index: 1;
  width: var(--speck-size, 2px);
  height: var(--speck-size, 2px);
  border-radius: 50%;
  background: var(--speck-color, #84cfc3);
  animation: learn-speck-drift var(--speck-dur, 6s) ease-in-out infinite;
  animation-delay: var(--speck-delay, 0s);
}
@keyframes learn-speck-drift {
  0%, 100% { opacity: 0.2; transform: translate(0, 0); }
  50% { opacity: 0.8; transform: translate(var(--drift-x, 3px), var(--drift-y, -5px)); }
}
/* Radiating light rays from behind pill */
.si-title-rays {
  position: absolute;
  top: 50%; left: 50%;
  width: 120vmin; height: 120vmin;
  transform: translate(-50%, -50%);
  pointer-events: none;
  z-index: 0;
  animation: si-rays-rotate 30s linear infinite;
}
@keyframes si-rays-rotate { to { transform: translate(-50%, -50%) rotate(360deg); } }
.si-title-ray {
  position: absolute;
  top: 50%; left: 50%;
  width: 2px;
  height: 50%;
  transform-origin: top center;
  background: linear-gradient(to bottom, transparent 0%, var(--ray-color, rgba(132,207,195,0.15)) 40%, transparent 100%);
  border-radius: 1px;
}
/* Slide entrance animations */
.learn-slide-enter { animation: learn-content-enter 0.6s ease both; }
@keyframes learn-content-enter {
  from { opacity: 0; transform: translateY(30px); }
  to { opacity: 1; transform: translateY(0); }
}
/* Staggered children animation */
.learn-content-slide > *:nth-child(1) { animation: learn-stagger-in 0.5s ease 0.05s both; }
.learn-content-slide > *:nth-child(2) { animation: learn-stagger-in 0.5s ease 0.12s both; }
.learn-content-slide > *:nth-child(3) { animation: learn-stagger-in 0.5s ease 0.19s both; }
.learn-content-slide > *:nth-child(4) { animation: learn-stagger-in 0.5s ease 0.26s both; }
.learn-content-slide > *:nth-child(5) { animation: learn-stagger-in 0.5s ease 0.33s both; }
.learn-content-slide > *:nth-child(6) { animation: learn-stagger-in 0.5s ease 0.40s both; }
.learn-content-slide > *:nth-child(7) { animation: learn-stagger-in 0.5s ease 0.47s both; }
@keyframes learn-stagger-in {
  from { opacity: 0; transform: translateY(16px); }
  to { opacity: 1; transform: translateY(0); }
}
/* XP toast animation */
.learn-xp-toast {
  position: fixed;
  top: 80px;
  left: 50%;
  transform: translateX(-50%) translateY(-20px);
  padding: 10px 24px;
  border-radius: 100px;
  background: rgba(132,207,195,0.15);
  border: 1px solid rgba(132,207,195,0.3);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  font-family: 'Oswald', sans-serif;
  font-size: 14px;
  font-weight: 600;
  letter-spacing: 1px;
  color: var(--cyan);
  z-index: 100020;
  opacity: 0;
  pointer-events: none;
  transition: all 0.4s cubic-bezier(0.34, 1.56, 0.64, 1);
}
.learn-xp-toast.show {
  opacity: 1;
  transform: translateX(-50%) translateY(0);
}
/* Streak/combo counter */
.learn-streak {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 4px 12px;
  border-radius: 100px;
  background: rgba(255,163,0,0.1);
  border: 1px solid rgba(255,163,0,0.2);
  font-family: 'Oswald', sans-serif;
  font-size: 12px;
  font-weight: 600;
  color: var(--orange);
  letter-spacing: 1px;
  animation: learn-streak-pop 0.4s cubic-bezier(0.34, 1.56, 0.64, 1);
}
@keyframes learn-streak-pop {
  0% { transform: scale(0.5); opacity: 0; }
  60% { transform: scale(1.2); }
  100% { transform: scale(1); opacity: 1; }
}
.learn-hero-icon {
  width: 100px; height: 100px;
  margin: 0 auto 28px;
  position: relative;
}
.learn-hero-icon svg {
  width: 100%; height: 100%;
  filter: drop-shadow(0 0 30px rgba(132,207,195,0.3));
}
.learn-hero-title {
  font-family: 'Oswald', sans-serif;
  font-size: 44px;
  font-weight: 700;
  letter-spacing: 3px;
  background: linear-gradient(135deg, var(--cyan) 0%, var(--magenta) 50%, var(--orange) 100%);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  margin-bottom: 12px;
}
.learn-hero-sub {
  font-size: 15px;
  color: var(--text-secondary);
  line-height: 1.6;
  max-width: 300px;
  margin: 0 auto 32px;
}
.learn-hero-meta {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 16px;
  font-size: 12px;
  color: var(--text-dim);
}
.learn-hero-meta-item {
  display: flex;
  align-items: center;
  gap: 5px;
}
.learn-start-btn {
  margin-top: 36px;
  padding: 16px 56px;
  border-radius: 14px;
  border: none;
  background: linear-gradient(90deg, var(--cyan), var(--magenta));
  color: #fff;
  font-family: 'aktiv-grotesk-condensed', 'Oswald', sans-serif;
  font-size: 16px;
  font-weight: 900;
  letter-spacing: 4px;
  text-transform: uppercase;
  cursor: pointer;
  position: relative;
  overflow: hidden;
  box-shadow: 0 4px 24px rgba(132,207,195,0.35);
  -webkit-tap-highlight-color: transparent;
}
.learn-start-btn::after {
  content: '';
  position: absolute;
  top: 0; left: -100%; width: 200%; height: 100%;
  background: linear-gradient(90deg, transparent, rgba(255,255,255,0.2), transparent);
  animation: learn-shimmer 2.5s ease-in-out infinite;
}
@keyframes learn-shimmer {
  0% { transform: translateX(-50%); }
  100% { transform: translateX(50%); }
}
.learn-start-btn:active { transform: scale(0.96); }

/* ── Content slides ── */
.learn-content-slide {
  text-align: left;
  max-width: 380px;
  width: 100%;
}
.learn-content-eyebrow {
  font-family: 'Oswald', sans-serif;
  font-size: 11px;
  font-weight: 600;
  letter-spacing: 2.5px;
  text-transform: uppercase;
  color: var(--orange);
  margin-bottom: 12px;
}
.learn-content-heading {
  font-family: 'Oswald', sans-serif;
  font-size: 28px;
  font-weight: 700;
  letter-spacing: 1px;
  color: var(--text-primary);
  margin-bottom: 20px;
  line-height: 1.15;
}
.learn-content-body {
  font-size: 15px;
  line-height: 1.75;
  color: var(--text-secondary);
  margin-bottom: 20px;
}
.learn-content-body strong {
  color: var(--text-primary);
  font-weight: 600;
}
.learn-highlight-box {
  padding: 16px 20px;
  background: rgba(132,207,195,0.06);
  border: 1px solid rgba(132,207,195,0.15);
  border-left: 3px solid var(--cyan);
  border-radius: 8px;
  margin: 16px 0;
  font-size: 14px;
  line-height: 1.6;
  color: var(--text-secondary);
}
.learn-highlight-box .hl-stat {
  font-size: 32px;
  font-family: 'Oswald', sans-serif;
  font-weight: 700;
  color: var(--cyan);
  display: block;
  margin-bottom: 4px;
}
.learn-highlight-box .hl-label {
  font-size: 13px;
  color: var(--text-dim);
}
.learn-fact-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 10px;
  margin: 16px 0;
}
.learn-fact-cell {
  padding: 14px;
  background: rgba(255,255,255,0.03);
  border: 1px solid var(--border-glass);
  border-radius: 10px;
  text-align: center;
}
.learn-fact-cell .fc-num {
  font-family: 'Oswald', sans-serif;
  font-size: 24px;
  font-weight: 700;
  background: linear-gradient(135deg, var(--cyan), var(--magenta));
  -webkit-background-clip: text; -webkit-text-fill-color: transparent; background-clip: text;
  margin-bottom: 4px;
}
.learn-fact-cell .fc-label {
  font-size: 11px;
  color: var(--text-dim);
  line-height: 1.3;
}
.learn-timeline {
  margin: 16px 0;
  padding-left: 20px;
  border-left: 2px solid rgba(255,163,0,0.2);
}
.learn-timeline-item {
  padding: 10px 0 10px 16px;
  position: relative;
}
.learn-timeline-item::before {
  content: '';
  position: absolute;
  left: -25px; top: 16px;
  width: 8px; height: 8px;
  border-radius: 50%;
  background: var(--orange);
  box-shadow: 0 0 8px rgba(255,163,0,0.4);
}
.learn-timeline-year {
  font-family: 'Oswald', sans-serif;
  font-size: 14px;
  font-weight: 600;
  color: var(--orange);
  margin-bottom: 2px;
}
.learn-timeline-text {
  font-size: 13px;
  color: var(--text-secondary);
  line-height: 1.5;
}

/* ── Quiz slides ── */
.learn-quiz-slide {
  text-align: center;
  max-width: 380px;
  width: 100%;
}
.learn-quiz-badge {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 6px 14px;
  border-radius: 100px;
  background: rgba(255,98,154,0.1);
  border: 1px solid rgba(255,98,154,0.2);
  color: var(--magenta);
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 1.5px;
  text-transform: uppercase;
  margin-bottom: 24px;
}
.learn-quiz-question {
  font-family: 'Oswald', sans-serif;
  font-size: 22px;
  font-weight: 600;
  color: var(--text-primary);
  line-height: 1.35;
  margin-bottom: 28px;
}
.learn-quiz-options {
  display: flex;
  flex-direction: column;
  gap: 10px;
  width: 100%;
}
.learn-quiz-option {
  padding: 16px 20px;
  border-radius: 12px;
  border: 1.5px solid var(--border-glass);
  background: rgba(255,255,255,0.03);
  color: var(--text-primary);
  font-size: 15px;
  text-align: left;
  cursor: pointer;
  transition: all 0.3s;
  position: relative;
  overflow: hidden;
}
.learn-quiz-option:active { transform: scale(0.97); }
.learn-quiz-option.selected {
  border-color: rgba(132,207,195,0.4);
  background: rgba(132,207,195,0.08);
}
.learn-quiz-option.correct {
  border-color: var(--cyan) !important;
  background: rgba(132,207,195,0.12) !important;
  animation: learn-correct-pulse 0.5s ease;
}
.learn-quiz-option.correct::after {
  content: '✓';
  position: absolute;
  right: 16px; top: 50%;
  transform: translateY(-50%);
  color: var(--cyan);
  font-size: 20px;
  font-weight: 700;
}
.learn-quiz-option.wrong {
  border-color: rgba(255,80,80,0.4) !important;
  background: rgba(255,80,80,0.08) !important;
  animation: learn-wrong-shake 0.4s ease;
}
.learn-quiz-option.wrong::after {
  content: '✗';
  position: absolute;
  right: 16px; top: 50%;
  transform: translateY(-50%);
  color: #ff5050;
  font-size: 20px;
  font-weight: 700;
}
@keyframes learn-correct-pulse {
  0% { box-shadow: 0 0 0 0 rgba(132,207,195,0.4); }
  70% { box-shadow: 0 0 0 12px rgba(132,207,195,0); }
  100% { box-shadow: 0 0 0 0 rgba(132,207,195,0); }
}
@keyframes learn-wrong-shake {
  0%, 100% { transform: translateX(0); }
  20% { transform: translateX(-6px); }
  40% { transform: translateX(6px); }
  60% { transform: translateX(-4px); }
  80% { transform: translateX(4px); }
}
.learn-quiz-explanation {
  margin-top: 20px;
  padding: 14px 18px;
  border-radius: 10px;
  background: rgba(132,207,195,0.06);
  border: 1px solid rgba(132,207,195,0.12);
  font-size: 13px;
  line-height: 1.6;
  color: var(--text-secondary);
  opacity: 0;
  transform: translateY(8px);
  transition: all 0.4s ease;
}
.learn-quiz-explanation.visible {
  opacity: 1;
  transform: translateY(0);
}

/* ── Completion slide ── */
.learn-complete-slide {
  text-align: center;
}
.learn-complete-icon {
  width: 80px; height: 80px;
  margin: 0 auto 24px;
  border-radius: 50%;
  background: linear-gradient(135deg, rgba(132,207,195,0.15), rgba(255,98,154,0.15));
  border: 2px solid rgba(132,207,195,0.3);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 36px;
  animation: learn-complete-glow 2s ease infinite;
}
@keyframes learn-complete-glow {
  0%, 100% { box-shadow: 0 0 20px rgba(132,207,195,0.2); }
  50% { box-shadow: 0 0 40px rgba(132,207,195,0.4), 0 0 80px rgba(255,98,154,0.15); }
}
.learn-complete-title {
  font-family: 'Oswald', sans-serif;
  font-size: 28px;
  font-weight: 700;
  color: var(--text-primary);
  margin-bottom: 8px;
}
.learn-complete-sub {
  font-size: 14px;
  color: var(--text-secondary);
  margin-bottom: 28px;
}
.learn-complete-points {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 12px 28px;
  border-radius: 100px;
  background: linear-gradient(90deg, rgba(132,207,195,0.12), rgba(255,98,154,0.12));
  border: 1px solid rgba(132,207,195,0.2);
  font-family: 'Oswald', sans-serif;
  font-size: 22px;
  font-weight: 700;
  color: var(--cyan);
  letter-spacing: 1px;
  margin-bottom: 16px;
}
.learn-complete-code {
  font-family: 'Oswald', sans-serif;
  font-size: 28px;
  font-weight: 700;
  letter-spacing: 4px;
  color: var(--orange);
  margin: 12px 0 4px;
}
.learn-complete-code-label {
  font-size: 11px;
  color: var(--text-dim);
  letter-spacing: 1.5px;
  text-transform: uppercase;
  margin-bottom: 24px;
}
.learn-redeem-btn {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 14px 36px;
  border-radius: 100px;
  border: none;
  background: linear-gradient(90deg, var(--orange), #f97316);
  color: #fff;
  font-family: 'Oswald', sans-serif;
  font-size: 14px;
  font-weight: 600;
  letter-spacing: 1.5px;
  text-transform: uppercase;
  cursor: pointer;
  text-decoration: none;
}
.learn-redeem-btn:active { transform: scale(0.96); }

/* ── Swipe hint animation ── */
.learn-swipe-hint {
  position: absolute;
  bottom: calc(28px + var(--safe-bottom));
  left: 0; right: 0;
  text-align: center;
  z-index: 5;
  pointer-events: none;
}
.learn-swipe-hint-inner {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-size: 12px;
  color: var(--text-dim);
  animation: learn-swipe-bounce 2s ease-in-out infinite;
}
@keyframes learn-swipe-bounce {
  0%, 100% { transform: translateX(0); opacity: 0.5; }
  50% { transform: translateX(8px); opacity: 1; }
}

/* ── Particle burst (quiz correct) ── */
.learn-particle {
  position: absolute;
  width: 6px; height: 6px;
  border-radius: 50%;
  pointer-events: none;
  z-index: 100;
  animation: learn-particle-fly 0.8s ease-out forwards;
}
@keyframes learn-particle-fly {
  0% { opacity: 1; transform: translate(0, 0) scale(1); }
  100% { opacity: 0; transform: translate(var(--tx), var(--ty)) scale(0); }
}

/* ── Nav dots (bottom) ── */
.learn-nav-dots {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 6px;
  padding: 8px 0 4px;
  z-index: 5;
}
.learn-nav-dot {
  width: 6px; height: 6px;
  border-radius: 50%;
  background: rgba(255,255,255,0.15);
  transition: all 0.35s ease;
}
.learn-nav-dot.active {
  width: 20px;
  border-radius: 3px;
  background: linear-gradient(90deg, var(--cyan), var(--magenta));
}
.learn-nav-dot.quiz { background: rgba(255,98,154,0.25); }
.learn-nav-dot.quiz.active { background: linear-gradient(90deg, var(--magenta), var(--orange)); }
.learn-nav-dot.complete { background: rgba(255,163,0,0.25); }
.learn-nav-dot.complete.active { background: linear-gradient(90deg, var(--orange), var(--cyan)); }
.learn-nav-dot.interactive { background: rgba(132,207,195,0.25); }
.learn-nav-dot.interactive.active { background: linear-gradient(90deg, var(--cyan), var(--orange)); }

/* Duolingo-style continue bar */
.learn-continue-bar {
  padding: 0 24px calc(12px + var(--safe-bottom));
  z-index: 10;
  position: relative;
}
.learn-continue-btn {
  width: 100%;
  padding: 16px;
  border: none;
  border-radius: 14px;
  background: linear-gradient(90deg, var(--cyan), var(--magenta));
  color: #fff;
  font-family: 'aktiv-grotesk-condensed', 'Oswald', sans-serif;
  font-size: 16px;
  font-weight: 900;
  letter-spacing: 4px;
  text-transform: uppercase;
  cursor: pointer;
  position: relative;
  overflow: hidden;
  -webkit-tap-highlight-color: transparent;
  box-shadow: 0 4px 20px rgba(132,207,195,0.3);
  transition: transform 0.15s, box-shadow 0.15s;
}
.learn-continue-btn:active {
  transform: scale(0.97);
  box-shadow: 0 2px 10px rgba(132,207,195,0.2);
}
.learn-continue-btn::after {
  content: '';
  position: absolute;
  top: 0; left: -100%; width: 200%; height: 100%;
  background: linear-gradient(90deg, transparent, rgba(255,255,255,0.15), transparent);
  animation: learn-shimmer 3s ease-in-out infinite;
}

/* Disabled continue button (gated slides) */
.learn-continue-btn.disabled {
  opacity: 0.15;
  pointer-events: none;
  box-shadow: none;
  filter: grayscale(0.6);
  transform: scale(0.97);
}
.learn-continue-btn.disabled::after {
  animation: none;
}
/* Glow pulse when continue unlocks */
.learn-continue-btn.just-unlocked {
  animation: learn-btn-unlock 1s ease;
}
@keyframes learn-btn-unlock {
  0% { transform: scale(0.97); opacity: 0.5; box-shadow: none; }
  40% { transform: scale(1.03); box-shadow: 0 0 30px rgba(132,207,195,0.4), 0 0 60px rgba(255,98,154,0.2); }
  100% { transform: scale(1); box-shadow: 0 4px 20px rgba(0,0,0,0.3); }
}
/* Points counter tick */
#learn-xp-display.tick {
  animation: learn-points-tick 0.4s ease;
}
@keyframes learn-points-tick {
  0% { transform: scale(1); }
  30% { transform: scale(1.4); color: #fff; }
  100% { transform: scale(1); }
}

/* ── SWIPE TRUE/FALSE CARDS ── */
.si-swipe-tf {
  position: relative;
  width: 100%;
  min-height: 220px;
  display: flex;
  align-items: center;
  justify-content: center;
  perspective: 800px;
  touch-action: none; /* prevent scroll fighting with card drag */
  margin: 8px 0;
}
.si-swipe-tf-card {
  position: absolute;
  left: 50%;
  transform: translateX(-50%);
  width: 88%;
  max-width: 320px;
  padding: 28px 22px;
  border-radius: 20px;
  background: rgba(255,255,255,0.05);
  border: 1.5px solid rgba(255,255,255,0.12);
  backdrop-filter: blur(16px);
  -webkit-backdrop-filter: blur(16px);
  text-align: center;
  touch-action: none;
  cursor: grab;
  transition: transform 0.25s cubic-bezier(0.25,0.46,0.45,0.94), box-shadow 0.3s, border-color 0.3s;
  will-change: transform;
  user-select: none;
  -webkit-user-select: none;
}
.si-swipe-tf-card.dragging {
  cursor: grabbing;
  transition: none;
  box-shadow: 0 12px 40px rgba(0,0,0,0.5);
}
/* Glow border on drag direction */
.si-swipe-tf-card.drag-right { border-color: rgba(132,207,195,0.5); box-shadow: 0 0 24px rgba(132,207,195,0.15); }
.si-swipe-tf-card.drag-left { border-color: rgba(255,80,80,0.5); box-shadow: 0 0 24px rgba(255,80,80,0.15); }
.si-swipe-tf-card .si-tf-statement {
  font-family: 'aktiv-grotesk-condensed', 'Oswald', sans-serif;
  font-size: 19px;
  font-weight: 600;
  line-height: 1.4;
  color: var(--text-primary);
  margin-bottom: 14px;
}
.si-swipe-tf-card .si-tf-hint {
  font-size: 10px;
  color: var(--text-dim);
  letter-spacing: 1.5px;
  text-transform: uppercase;
  font-weight: 600;
}
.si-tf-zones {
  display: flex;
  justify-content: space-between;
  padding: 0 12px;
  margin-top: 8px;
  pointer-events: none;
}
.si-tf-zone {
  font-family: 'aktiv-grotesk-condensed', 'Oswald', sans-serif;
  font-size: 14px;
  font-weight: 700;
  letter-spacing: 2px;
  text-transform: uppercase;
  opacity: 0.25;
  transition: opacity 0.2s;
}
.si-tf-zone.false-zone { color: #ff5050; }
.si-tf-zone.true-zone { color: var(--cyan); }
.si-tf-zone.lit { opacity: 1; }
.si-tf-counter {
  text-align: center;
  font-size: 12px;
  color: var(--text-dim);
  margin-top: 12px;
  font-weight: 500;
}
.si-swipe-tf-card.exit-left {
  animation: si-card-exit-left 0.4s ease-out forwards;
}
.si-swipe-tf-card.exit-right {
  animation: si-card-exit-right 0.4s ease-out forwards;
}
@keyframes si-card-exit-left {
  to { transform: translateX(calc(-50% - 120%)) rotate(-15deg); opacity: 0; }
}
@keyframes si-card-exit-right {
  to { transform: translateX(calc(-50% + 120%)) rotate(15deg); opacity: 0; }
}
.si-tf-feedback {
  position: absolute;
  top: 50%; left: 50%;
  transform: translate(-50%, -50%) scale(0);
  font-family: 'aktiv-grotesk-condensed', 'Oswald', sans-serif;
  font-size: 48px;
  font-weight: 900;
  letter-spacing: 3px;
  pointer-events: none;
  z-index: 10;
  text-shadow: 0 0 30px currentColor;
}
.si-tf-feedback.correct {
  color: var(--cyan);
  animation: si-feedback-pop 0.6s cubic-bezier(0.34,1.56,0.64,1) forwards;
}
.si-tf-feedback.wrong {
  color: #ff5050;
  animation: si-feedback-pop 0.6s cubic-bezier(0.34,1.56,0.64,1) forwards;
}
@keyframes si-feedback-pop {
  0% { transform: translate(-50%,-50%) scale(0); opacity: 1; }
  50% { transform: translate(-50%,-50%) scale(1.2); opacity: 1; }
  100% { transform: translate(-50%,-50%) scale(1); opacity: 0; }
}
.si-tf-explain {
  padding: 12px 16px;
  border-radius: 12px;
  background: rgba(132,207,195,0.06);
  border: 1px solid rgba(132,207,195,0.12);
  font-size: 13px;
  line-height: 1.6;
  color: var(--text-secondary);
  margin-top: 12px;
  opacity: 0;
  transform: translateY(8px);
  transition: all 0.4s ease;
}
.si-tf-explain.visible { opacity: 1; transform: translateY(0); }

/* ── SLIDER GUESS ── */
.si-slider-guess {
  width: 100%;
  text-align: center;
}
.si-slider-question {
  font-family: 'aktiv-grotesk-condensed', 'Oswald', sans-serif;
  font-size: 20px;
  font-weight: 600;
  color: var(--text-primary);
  line-height: 1.35;
  margin-bottom: 24px;
}
.si-slider-display {
  font-family: 'aktiv-grotesk-condensed', 'Oswald', sans-serif;
  font-size: 72px;
  font-weight: 900;
  background: linear-gradient(135deg, var(--cyan), var(--magenta));
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  line-height: 1;
  margin-bottom: 8px;
  transition: all 0.1s;
}
.si-slider-display.revealed {
  background: linear-gradient(135deg, var(--orange), #f97316);
  -webkit-background-clip: text;
  background-clip: text;
  animation: learn-correct-pulse 0.6s ease;
}
.si-slider-label {
  font-size: 12px;
  color: var(--text-dim);
  letter-spacing: 1px;
  text-transform: uppercase;
  margin-bottom: 20px;
}
.si-slider-track {
  position: relative;
  width: 100%;
  height: 8px;
  border-radius: 4px;
  background: rgba(255,255,255,0.08);
  margin-bottom: 8px;
}
.si-slider-fill {
  position: absolute;
  left: 0; top: 0;
  height: 100%;
  border-radius: 4px;
  background: linear-gradient(90deg, var(--cyan), var(--magenta));
  transition: width 0.1s;
}
.si-slider-input {
  -webkit-appearance: none;
  appearance: none;
  width: 100%;
  height: 44px;
  background: transparent;
  margin: -22px 0 0;
  position: relative;
  z-index: 2;
}
.si-slider-input::-webkit-slider-thumb {
  -webkit-appearance: none;
  width: 32px; height: 32px;
  border-radius: 50%;
  background: linear-gradient(135deg, var(--cyan), var(--magenta));
  border: 3px solid #080810;
  box-shadow: 0 0 16px rgba(132,207,195,0.4);
  cursor: grab;
}
.si-slider-input:active::-webkit-slider-thumb { cursor: grabbing; transform: scale(1.15); }
.si-slider-lock-btn {
  margin-top: 20px;
  padding: 14px 48px;
  border: none;
  border-radius: 100px;
  background: linear-gradient(90deg, var(--cyan), var(--magenta));
  color: #fff;
  font-family: 'aktiv-grotesk-condensed', 'Oswald', sans-serif;
  font-size: 15px;
  font-weight: 700;
  letter-spacing: 3px;
  text-transform: uppercase;
  cursor: pointer;
  box-shadow: 0 4px 20px rgba(132,207,195,0.3);
}
.si-slider-lock-btn:active { transform: scale(0.96); }
.si-slider-lock-btn:disabled {
  opacity: 0.3;
  pointer-events: none;
}
.si-slider-result {
  margin-top: 16px;
  padding: 16px;
  border-radius: 14px;
  text-align: center;
  opacity: 0;
  transform: translateY(10px);
  transition: all 0.5s ease;
}
.si-slider-result.visible { opacity: 1; transform: translateY(0); }
.si-slider-result.close {
  background: rgba(132,207,195,0.08);
  border: 1px solid rgba(132,207,195,0.2);
}
.si-slider-result.far {
  background: rgba(255,163,0,0.08);
  border: 1px solid rgba(255,163,0,0.2);
}
.si-slider-result-text {
  font-family: 'aktiv-grotesk-condensed', 'Oswald', sans-serif;
  font-size: 16px;
  font-weight: 600;
  margin-bottom: 4px;
}
.si-slider-result-detail {
  font-size: 13px;
  color: var(--text-secondary);
  line-height: 1.5;
}

/* ── SCENARIO CHOOSE ── */
.si-scenario {
  width: 100%;
  text-align: center;
}
.si-scenario-badge {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 6px 14px;
  border-radius: 100px;
  background: rgba(255,163,0,0.1);
  border: 1px solid rgba(255,163,0,0.2);
  color: var(--orange);
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 1.5px;
  text-transform: uppercase;
  margin-bottom: 16px;
}
.si-scenario-prompt {
  font-family: 'aktiv-grotesk-condensed', 'Oswald', sans-serif;
  font-size: 20px;
  font-weight: 600;
  color: var(--text-primary);
  line-height: 1.35;
  margin-bottom: 24px;
}
.si-scenario-context {
  font-size: 13px;
  color: var(--text-secondary);
  line-height: 1.6;
  margin-bottom: 20px;
  font-style: italic;
}
.si-scenario-options {
  display: flex;
  flex-direction: column;
  gap: 10px;
  text-align: left;
}
.si-scenario-opt {
  padding: 16px 18px;
  border-radius: 14px;
  border: 1.5px solid var(--border-glass);
  background: rgba(255,255,255,0.03);
  color: var(--text-primary);
  font-size: 14px;
  line-height: 1.5;
  cursor: pointer;
  transition: all 0.3s;
  position: relative;
  overflow: hidden;
}
.si-scenario-opt:active { transform: scale(0.97); }
.si-scenario-opt .si-opt-label {
  font-family: 'aktiv-grotesk-condensed', 'Oswald', sans-serif;
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 1.5px;
  color: var(--text-dim);
  margin-bottom: 4px;
}
.si-scenario-opt.best {
  border-color: var(--cyan) !important;
  background: rgba(132,207,195,0.1) !important;
}
.si-scenario-opt.best::after {
  content: 'BEST';
  position: absolute;
  right: 12px; top: 12px;
  font-family: 'aktiv-grotesk-condensed', 'Oswald', sans-serif;
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 1.5px;
  color: var(--cyan);
  padding: 2px 8px;
  border-radius: 100px;
  background: rgba(132,207,195,0.15);
}
.si-scenario-opt.ok {
  border-color: rgba(255,163,0,0.4) !important;
  background: rgba(255,163,0,0.06) !important;
}
.si-scenario-opt.bad {
  border-color: rgba(255,80,80,0.4) !important;
  background: rgba(255,80,80,0.06) !important;
}
.si-scenario-explain {
  padding: 14px 16px;
  border-radius: 12px;
  background: rgba(132,207,195,0.06);
  border: 1px solid rgba(132,207,195,0.12);
  font-size: 13px;
  line-height: 1.6;
  color: var(--text-secondary);
  margin-top: 16px;
  opacity: 0;
  transform: translateY(8px);
  transition: all 0.4s ease;
}
.si-scenario-explain.visible { opacity: 1; transform: translateY(0); }

/* ── DRAG TO SORT ── */
.si-sort {
  width: 100%;
}
.si-sort-hint {
  font-size: 11px;
  color: var(--text-dim);
  letter-spacing: 1.5px;
  text-transform: uppercase;
  font-weight: 600;
  text-align: center;
  margin-bottom: 16px;
}
.si-sort-list {
  display: flex;
  flex-direction: column;
  gap: 8px;
}
.si-sort-item {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 14px 16px;
  border-radius: 14px;
  border: 1.5px solid rgba(255,255,255,0.1);
  background: rgba(255,255,255,0.04);
  cursor: grab;
  touch-action: none;
  user-select: none;
  -webkit-user-select: none;
  transition: transform 0.2s, border-color 0.2s, background 0.2s;
}
.si-sort-item:active { cursor: grabbing; }
.si-sort-item.dragging {
  z-index: 10;
  border-color: var(--cyan);
  background: rgba(132,207,195,0.08);
  box-shadow: 0 8px 32px rgba(0,0,0,0.4);
}
.si-sort-item .si-sort-num {
  width: 28px; height: 28px;
  border-radius: 50%;
  background: rgba(255,255,255,0.06);
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: 'aktiv-grotesk-condensed', 'Oswald', sans-serif;
  font-size: 14px;
  font-weight: 700;
  color: var(--text-dim);
  flex-shrink: 0;
}
.si-sort-item .si-sort-icon {
  font-size: 20px;
  flex-shrink: 0;
}
.si-sort-item .si-sort-text {
  font-size: 14px;
  color: var(--text-primary);
  line-height: 1.4;
  flex: 1;
}
.si-sort-item .si-sort-grip {
  color: var(--text-dim);
  font-size: 16px;
  flex-shrink: 0;
  opacity: 0.4;
}
.si-sort-check-btn {
  margin-top: 16px;
  width: 100%;
  padding: 14px;
  border: none;
  border-radius: 100px;
  background: linear-gradient(90deg, var(--cyan), var(--magenta));
  color: #fff;
  font-family: 'aktiv-grotesk-condensed', 'Oswald', sans-serif;
  font-size: 15px;
  font-weight: 700;
  letter-spacing: 3px;
  text-transform: uppercase;
  cursor: pointer;
  box-shadow: 0 4px 20px rgba(132,207,195,0.3);
}
.si-sort-check-btn:active { transform: scale(0.96); }
.si-sort-item.correct-pos {
  border-color: var(--cyan) !important;
  background: rgba(132,207,195,0.08) !important;
}
.si-sort-item.correct-pos .si-sort-num {
  background: var(--cyan);
  color: #080810;
}
.si-sort-item.wrong-pos {
  border-color: rgba(255,80,80,0.4) !important;
  background: rgba(255,80,80,0.06) !important;
  animation: learn-wrong-shake 0.4s ease;
}
.si-sort-result {
  text-align: center;
  margin-top: 12px;
  font-size: 13px;
  color: var(--text-secondary);
  opacity: 0;
  transition: opacity 0.4s;
}
.si-sort-result.visible { opacity: 1; }

/* ── Expanded title for Substance Intelligence ── */
.si-title-logo {
  width: 48px;
  margin: 0 auto 16px;
  animation: learn-slide-up 0.6s ease 0.1s both;
}
.si-title-logo img, .si-title-logo svg {
  width: 100%; height: auto;
  filter: drop-shadow(0 0 20px rgba(132,207,195,0.3));
}
.si-title-eyebrow {
  font-family: 'aktiv-grotesk-condensed', 'Oswald', sans-serif;
  font-size: 13px;
  font-weight: 700;
  letter-spacing: 5px;
  text-transform: uppercase;
  color: var(--cyan);
  margin-bottom: 8px;
  animation: learn-slide-up 0.6s ease 0.2s both;
  text-shadow: 0 0 20px rgba(132,207,195,0.3);
}
.si-title-name {
  font-family: 'aktiv-grotesk-condensed', 'Oswald', sans-serif;
  font-size: 42px;
  font-weight: 900;
  letter-spacing: 3px;
  text-transform: uppercase;
  background: linear-gradient(90deg, var(--orange), var(--magenta), #c084fc, var(--cyan));
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  background-size: 200% 200%;
  animation: learn-slide-up 0.6s ease 0.3s both, learn-gradient-shift 4s ease infinite;
  line-height: 1;
  margin-bottom: 4px;
}
@keyframes learn-gradient-shift {
  0% { background-position: 0% 50%; }
  50% { background-position: 100% 50%; }
  100% { background-position: 0% 50%; }
}
.si-title-sub {
  font-size: 13px;
  color: var(--text-dim);
  letter-spacing: 0.5px;
  margin-bottom: 20px;
  animation: learn-slide-up 0.6s ease 0.4s both;
}
.si-title-substance {
  font-family: 'aktiv-grotesk-condensed', 'Oswald', sans-serif;
  font-size: clamp(80px, 22vw, 140px);
  font-weight: 900;
  letter-spacing: 8px;
  background: linear-gradient(90deg, var(--orange), var(--magenta), #c084fc, var(--cyan));
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  background-size: 200% 200%;
  animation: learn-slide-up 0.6s ease 0.5s both, learn-gradient-shift 4s ease infinite;
  line-height: 0.95;
}
.si-title-chem {
  font-size: 10px;
  color: var(--text-dim);
  letter-spacing: 0.5px;
  margin: 4px 0 20px;
  animation: learn-slide-up 0.6s ease 0.55s both;
}
.si-title-aliases {
  font-size: 13px;
  color: var(--orange);
  font-weight: 600;
  font-style: italic;
  animation: learn-slide-up 0.6s ease 0.6s both;
}
/* Corner band rings on alternating content slides */
.learn-slide:nth-child(odd) .learn-content-slide::before {
  content: '';
  position: absolute;
  top: -100px; right: -100px;
  width: 200px; height: 200px;
  border-radius: 50%;
  border: 1px solid rgba(255,163,0,0.12);
  box-shadow: inset 0 0 0 8px rgba(132,207,195,0.06), inset 0 0 0 20px rgba(255,98,154,0.04);
  pointer-events: none;
  z-index: 0;
}
.learn-slide:nth-child(even) .learn-content-slide::before {
  content: '';
  position: absolute;
  bottom: -80px; left: -80px;
  width: 180px; height: 180px;
  border-radius: 50%;
  border: 1px solid rgba(132,207,195,0.12);
  box-shadow: inset 0 0 0 8px rgba(255,98,154,0.06), inset 0 0 0 20px rgba(255,163,0,0.04);
  pointer-events: none;
  z-index: 0;
}
.learn-content-slide { position: relative; overflow: hidden; }

/* Share button on completion */
.learn-share-btn {
  width: 100%; padding: 14px;
  border: 1px solid rgba(132,207,195,0.2);
  border-radius: 14px;
  background: rgba(132,207,195,0.06);
  color: var(--cyan);
  font-family: 'aktiv-grotesk-condensed','Oswald',sans-serif;
  font-size: 14px; font-weight: 600; letter-spacing: 1px;
  cursor: pointer; margin-top: 12px;
  transition: all 0.2s;
}
.learn-share-btn:active { transform: scale(0.97); opacity: 0.8; }

/* Next course teaser */
.next-course-teaser {
  display: flex; align-items: center; justify-content: space-between;
  padding: 14px 16px;
  border: 1px solid rgba(255,255,255,0.06);
  border-radius: 14px;
  background: rgba(255,255,255,0.02);
  margin-top: 12px; width: 100%;
}

/* Dose cards */
.dose-cards { display: flex; flex-direction: column; gap: 8px; width: 100%; margin-bottom: 16px; }
.dose-card {
  display: flex; align-items: center; justify-content: space-between;
  padding: 14px 18px; border-radius: 12px;
  border: 1px solid rgba(255,255,255,0.06);
  background: rgba(255,255,255,0.02);
  cursor: pointer; transition: all 0.3s ease;
  text-align: left;
}
.dose-card:nth-child(1) { border-left: 3px solid var(--cyan); }
.dose-card:nth-child(2) { border-left: 3px solid #60a5fa; }
.dose-card:nth-child(3) { border-left: 3px solid var(--orange); }
.dose-card:nth-child(4) { border-left: 3px solid #ef4444; }
.dose-card.dose-active {
  background: rgba(255,255,255,0.06);
  border-color: rgba(255,255,255,0.15);
  box-shadow: 0 2px 12px rgba(0,0,0,0.3);
}
.dose-card.dose-explored { opacity: 0.6; }
.dose-card.dose-active.dose-explored { opacity: 1; }
.dose-amount { font-family: 'aktiv-grotesk-condensed','Oswald',sans-serif; font-size: 20px; font-weight: 700; color: #fff; }
.dose-label { font-size: 12px; color: var(--text-dim); }
.dose-detail {
  padding: 16px; border-radius: 14px;
  background: rgba(255,255,255,0.03);
  border: 1px solid rgba(255,255,255,0.08);
  text-align: left; font-size: 13px; line-height: 1.6; color: var(--text-secondary);
  min-height: 80px; transition: opacity 0.3s ease;
}
.dose-detail:empty { display: none; }

/* Resonance buttons (What resonated? slide) */
.resonance-btn {
  width: 90px; padding: 14px 8px;
  border-radius: 14px;
  border: 1px solid rgba(255,255,255,0.08);
  background: rgba(255,255,255,0.03);
  color: var(--text-secondary);
  cursor: pointer;
  transition: all 0.3s ease;
  backdrop-filter: blur(8px); -webkit-backdrop-filter: blur(8px);
}
.resonance-btn:active { transform: scale(0.95); }
.resonance-btn.resonated-selected {
  border-color: var(--cyan);
  background: rgba(132,207,195,0.1);
  box-shadow: 0 0 16px rgba(132,207,195,0.2);
  transform: scale(1.05);
}

/* Full-screen title slide — break out of parent constraints */
.learn-slide:has(.si-title-substance) {
  padding: 0;
  justify-content: center;
}
.learn-slide:has(.si-title-substance) .learn-content-slide {
  max-width: 100%;
  width: 100%;
  height: 100%;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  position: relative;
}
/* Center completion slide */
.learn-slide:has(.learn-complete-slide) {
  justify-content: center;
  padding-bottom: 20px;
}
/* Center resonance slide */
.learn-slide:has(.resonance-btn) {
  justify-content: center;
}
/* Background rings on title/completion */
.learn-bg-rings {
  position: absolute;
  top: 50%; left: 50%;
  transform: translate(-50%, -50%);
  pointer-events: none;
  z-index: 0;
}
.learn-bg-ring {
  position: absolute;
  border-radius: 50%;
  border: 1px solid rgba(255,255,255,0.03);
  top: 50%; left: 50%;
  transform: translate(-50%, -50%);
}
.learn-bg-ring:nth-child(1) { width: 200px; height: 200px; }
.learn-bg-ring:nth-child(2) { width: 350px; height: 350px; }
.learn-bg-ring:nth-child(3) { width: 500px; height: 500px; }

/* ── Slide type badges (TEACH / TEST) ── */
.si-slide-badge {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  padding: 5px 14px;
  border-radius: 100px;
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 1.5px;
  text-transform: uppercase;
  margin-bottom: 12px;
  position: relative;
}
.si-slide-badge.teach {
  background: rgba(132,207,195,0.08);
  border: 1px solid rgba(132,207,195,0.3);
  color: var(--cyan);
  box-shadow: 0 0 12px rgba(132,207,195,0.15), inset 0 0 8px rgba(132,207,195,0.05);
}
.si-slide-badge.teach::before {
  content: '✦';
  font-size: 8px;
  opacity: 0.7;
}
.si-slide-badge.test {
  background: rgba(255,98,154,0.08);
  border: 1px solid rgba(255,98,154,0.3);
  color: var(--magenta);
  box-shadow: 0 0 12px rgba(255,98,154,0.15), inset 0 0 8px rgba(255,98,154,0.05);
}
.si-slide-badge.test::before {
  content: '✦';
  font-size: 8px;
  opacity: 0.7;
}

/* ── IG-matched interactive slide styles ── */

/* Corner gradient bands (planetary rings from IG posts) */
.learn-ig-corner-band {
  position: absolute;
  width: 260px; height: 260px;
  border-radius: 50%;
  pointer-events: none;
  z-index: 0;
}
.learn-ig-corner-band::before,
.learn-ig-corner-band::after {
  content: '';
  position: absolute;
  border-radius: 50%;
}
.learn-ig-corner-band.top-right {
  top: -130px; right: -130px;
  border: 2px solid rgba(255,163,0,0.3);
  box-shadow: 0 0 40px rgba(255,163,0,0.08);
}
.learn-ig-corner-band.top-right::before {
  top: 8px; left: 8px; right: 8px; bottom: 8px;
  border: 1.5px solid rgba(132,207,195,0.25);
}
.learn-ig-corner-band.top-right::after {
  top: 20px; left: 20px; right: 20px; bottom: 20px;
  border: 1px solid rgba(255,98,154,0.2);
}
.learn-ig-corner-band.bottom-left {
  bottom: -130px; left: -130px;
  border: 2px solid rgba(132,207,195,0.3);
  box-shadow: 0 0 40px rgba(132,207,195,0.08);
}
.learn-ig-corner-band.bottom-left::before {
  top: 8px; left: 8px; right: 8px; bottom: 8px;
  border: 1.5px solid rgba(255,98,154,0.25);
}
.learn-ig-corner-band.bottom-left::after {
  top: 20px; left: 20px; right: 20px; bottom: 20px;
  border: 1px solid rgba(255,163,0,0.2);
}

/* Smiley pill hero (title slide) */
.learn-ig-pill-hero {
  width: 100px; height: 100px;
  margin: 8px auto 28px;
  animation: learn-pill-bob 3s ease-in-out infinite;
  filter: drop-shadow(0 0 30px rgba(255,163,0,0.2)) drop-shadow(0 0 60px rgba(255,98,154,0.15));
}
@keyframes learn-pill-bob {
  0%, 100% { transform: translateY(0); }
  50% { transform: translateY(-12px); }
}

/* IG gradient heading (two-color) */
.learn-ig-h1 {
  font-family: 'aktiv-grotesk-condensed', 'Oswald', sans-serif;
  font-size: 32px;
  font-weight: 900;
  letter-spacing: 1.5px;
  text-transform: uppercase;
  line-height: 1.1;
  margin-bottom: 12px;
}
.learn-ig-h1 .orange { color: var(--orange); }
.learn-ig-h1 .magenta { color: var(--magenta); }
.learn-ig-h1 .white { color: #fff; }

/* IG bordered content box */
.learn-ig-box {
  border: 1.5px solid;
  border-image: linear-gradient(135deg, var(--orange), var(--cyan)) 1;
  background: rgba(0,0,0,0.4);
  padding: 20px;
  margin: 16px 0;
  position: relative;
}

/* IG gradient divider */
.learn-ig-divider {
  height: 0;
  margin: 0;
  opacity: 0;
}

/* IG pill bullet icon */
.learn-ig-pill-icon {
  width: 18px; height: 18px;
  flex-shrink: 0;
  margin-top: 2px;
}

/* Tap-to-reveal (Slide 1) */
.learn-ig-reveal-item {
  display: flex;
  gap: 14px;
  padding: 16px;
  opacity: 0.2;
  filter: blur(4px);
  transform: translateY(6px);
  transition: all 0.5s cubic-bezier(0.25, 0.46, 0.45, 0.94);
  cursor: pointer;
  background: rgba(255,255,255,0.02);
  border: 1px solid rgba(255,255,255,0.06);
  border-left: 3px solid var(--cyan);
  border-radius: 0 14px 14px 0;
  margin-bottom: 10px;
}
.learn-ig-reveal-item:nth-child(odd) { border-left-color: var(--magenta); }
.learn-ig-reveal-item:nth-child(3n) { border-left-color: var(--orange); }
.learn-ig-reveal-item.revealed {
  opacity: 1;
  filter: blur(0);
  transform: translateY(0);
  background: rgba(255,255,255,0.04);
  border-color: rgba(255,255,255,0.1);
  box-shadow: 0 2px 16px rgba(0,0,0,0.2);
}
.learn-ig-tap-hint {
  font-size: 11px;
  color: var(--text-dim);
  letter-spacing: 2px;
  text-transform: uppercase;
  font-weight: 600;
  margin-bottom: 12px;
  animation: learn-pulse-hint 2s ease-in-out infinite;
}
@keyframes learn-pulse-hint {
  0%, 100% { opacity: 0.5; }
  50% { opacity: 1; }
}

/* Era cards (Slide 2 - History) */
.learn-ig-era-card {
  border: 1.5px solid rgba(255,255,255,0.1);
  border-radius: 12px;
  padding: 16px;
  margin-bottom: 10px;
  cursor: pointer;
  transition: border-color 0.3s, background 0.3s;
  overflow: hidden;
}
.learn-ig-era-card:not(.explored) {
  background: rgba(255,255,255,0.02);
}
.learn-ig-era-card.explored {
  border-color: var(--cyan);
  background: rgba(132,207,195,0.05);
}
.learn-ig-era-header {
  display: flex;
  align-items: center;
  gap: 12px;
}
.learn-ig-era-year {
  font-family: 'aktiv-grotesk-condensed', 'Oswald', sans-serif;
  font-size: 28px;
  font-weight: 700;
  background: linear-gradient(135deg, var(--orange), var(--magenta));
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
}
.learn-ig-era-title {
  font-family: 'aktiv-grotesk-condensed', 'Oswald', sans-serif;
  font-size: 14px;
  font-weight: 600;
  letter-spacing: 1px;
  text-transform: uppercase;
  color: var(--text-secondary);
}
.learn-ig-era-detail {
  max-height: 0;
  overflow: hidden;
  transition: max-height 0.4s ease, opacity 0.3s ease, margin 0.3s ease;
  opacity: 0;
  margin-top: 0;
  font-size: 13px;
  line-height: 1.6;
  color: var(--text-secondary);
}
.learn-ig-era-card.explored .learn-ig-era-detail {
  max-height: 200px;
  opacity: 1;
  margin-top: 12px;
}
.learn-ig-era-chevron {
  margin-left: auto;
  width: 16px; height: 16px;
  color: var(--text-dim);
  transition: transform 0.3s;
}
.learn-ig-era-card.explored .learn-ig-era-chevron {
  transform: rotate(180deg);
  color: var(--cyan);
}

/* 3D Flip cards (Slide 3 - How Taken) */
.learn-ig-flip-card {
  perspective: 600px;
  height: 110px;
  margin-bottom: 10px;
  cursor: pointer;
}
.learn-ig-flip-inner {
  position: relative;
  width: 100%;
  height: 100%;
  transform-style: preserve-3d;
  transition: transform 0.6s cubic-bezier(0.4, 0, 0.2, 1);
}
.learn-ig-flip-inner.flipped {
  transform: rotateY(180deg);
}
.learn-ig-flip-front,
.learn-ig-flip-back {
  position: absolute;
  width: 100%;
  height: 100%;
  backface-visibility: hidden;
  -webkit-backface-visibility: hidden;
  border: 1.5px solid;
  border-image: linear-gradient(135deg, var(--orange), var(--cyan)) 1;
  background: rgba(0,0,0,0.5);
  padding: 16px;
  display: flex;
  align-items: center;
  gap: 14px;
  box-sizing: border-box;
}
.learn-ig-flip-back {
  transform: rotateY(180deg);
  border-image: linear-gradient(135deg, var(--cyan), var(--magenta)) 1;
  background: rgba(132,207,195,0.06);
  font-size: 13px;
  line-height: 1.5;
  color: var(--text-secondary);
}
.learn-ig-flip-label {
  font-family: 'aktiv-grotesk-condensed', 'Oswald', sans-serif;
  font-size: 16px;
  font-weight: 700;
  letter-spacing: 1px;
  color: #fff;
}
.learn-ig-flip-sub {
  font-size: 11px;
  color: var(--text-dim);
  margin-top: 2px;
}
.learn-ig-flip-icon {
  font-size: 28px;
  flex-shrink: 0;
}
.learn-ig-flip-tap {
  margin-left: auto;
  font-size: 10px;
  color: var(--text-dim);
  letter-spacing: 1px;
  text-transform: uppercase;
  opacity: 0.6;
}
.learn-ig-flip-inner.flipped ~ .learn-ig-flip-tap,
.learn-ig-flip-inner.flipped .learn-ig-flip-tap {
  display: none;
}

/* Research stat cards (Slide 8) */
.learn-ig-research-card {
  border: 1.5px solid rgba(255,255,255,0.08);
  border-radius: 12px;
  padding: 14px 16px;
  margin-bottom: 10px;
  cursor: pointer;
  transition: border-color 0.3s, background 0.3s;
  overflow: hidden;
}
.learn-ig-research-card.expanded {
  border-color: var(--orange);
  background: rgba(255,163,0,0.04);
}
.learn-ig-research-header {
  display: flex;
  align-items: center;
  gap: 10px;
}
.learn-ig-research-stat {
  font-family: 'aktiv-grotesk-condensed', 'Oswald', sans-serif;
  font-size: 32px;
  font-weight: 700;
  color: var(--orange);
  min-width: 60px;
  text-align: center;
  opacity: 0;
  transition: opacity 0.3s;
}
.learn-ig-research-card.expanded .learn-ig-research-stat {
  opacity: 1;
}
.learn-ig-research-title {
  font-size: 14px;
  font-weight: 600;
  color: #fff;
  flex: 1;
}
.learn-ig-research-detail {
  max-height: 0;
  overflow: hidden;
  transition: max-height 0.4s ease, opacity 0.3s, margin 0.3s;
  opacity: 0;
  margin-top: 0;
  font-size: 12px;
  line-height: 1.6;
  color: var(--text-dim);
}
.learn-ig-research-card.expanded .learn-ig-research-detail {
  max-height: 120px;
  opacity: 1;
  margin-top: 10px;
}

/* IG note callout */
.learn-ig-note {
  margin-top: 14px;
  padding: 12px;
  background: rgba(255,163,0,0.06);
  border-left: 2px solid var(--orange);
  border-radius: 0 8px 8px 0;
  font-size: 12px;
  line-height: 1.5;
  color: var(--text-secondary);
}
.learn-ig-note strong {
  color: var(--orange);
  font-weight: 700;
}

/* ── Animated background elements ── */
.learn-bg-rings {
  position: absolute;
  top: 50%; left: 50%;
  transform: translate(-50%, -50%);
  pointer-events: none;
  z-index: 0;
  opacity: 0.08;
}
.learn-bg-ring {
  position: absolute;
  border-radius: 50%;
  border: 1px solid;
  top: 50%; left: 50%;
  transform: translate(-50%, -50%);
}
.learn-bg-ring:nth-child(1) { width: 55vmin; height: 55vmin; border-color: var(--cyan); animation: learn-ring-pulse 4s ease infinite; }
.learn-bg-ring:nth-child(2) { width: 80vmin; height: 80vmin; border-color: var(--magenta); animation: learn-ring-pulse 4s ease infinite 0.8s; }
.learn-bg-ring:nth-child(3) { width: 105vmin; height: 105vmin; border-color: var(--orange); animation: learn-ring-pulse 4s ease infinite 1.6s; }
@keyframes learn-ring-pulse {
  0%, 100% { opacity: 0.3; transform: translate(-50%, -50%) scale(1); }
  50% { opacity: 1; transform: translate(-50%, -50%) scale(1.05); }
}

/* ── Four-pointed star bursts ── */
.learn-star {
  position: absolute;
  pointer-events: none;
  z-index: 0;
}
.learn-star svg { width: 100%; height: 100%; }
.learn-star.s1 { width: 16px; height: 16px; top: 12%; right: 15%; opacity: 0.15; animation: learn-star-twinkle 3s ease infinite; }
.learn-star.s2 { width: 10px; height: 10px; top: 25%; left: 10%; opacity: 0.1; animation: learn-star-twinkle 3s ease infinite 1s; }
.learn-star.s3 { width: 20px; height: 20px; bottom: 20%; right: 8%; opacity: 0.12; animation: learn-star-twinkle 3s ease infinite 2s; }
.learn-star.s4 { width: 12px; height: 12px; bottom: 35%; left: 18%; opacity: 0.08; animation: learn-star-twinkle 3s ease infinite 0.5s; }
@keyframes learn-star-twinkle {
  0%, 100% { opacity: inherit; transform: scale(1) rotate(0deg); }
  50% { opacity: 0.3; transform: scale(1.3) rotate(45deg); }
}

/* ══════════════════════════════════════════════════════════════
   INSTAGRAM-STYLE LEARN SLIDES — Editorial/Magazine Layout
   ══════════════════════════════════════════════════════════════ */

/* Hero visual — large SVG illustration (160-200px) */
.learn-hero-vis {
  width: 180px; height: 180px;
  margin: 0 auto 20px;
  position: relative;
  filter: drop-shadow(0 0 40px rgba(132,207,195,0.15));
}
.learn-hero-vis svg { width: 100%; height: 100%; }

/* Video background for title slide */
.learn-video-bg {
  position: absolute;
  top: 0; left: 0; right: 0; bottom: 0;
  z-index: 0;
  overflow: hidden;
  pointer-events: none;
}
.learn-video-bg video {
  width: 100%; height: 100%;
  object-fit: cover;
}
.learn-video-bg::after {
  content: '';
  position: absolute;
  left: 0; right: 0; bottom: 0;
  height: 120px;
  background: linear-gradient(180deg, transparent 0%, #080810 100%);
}

/* Big gradient heading — "WHAT IS MDMA?" style */
.learn-ig-heading {
  font-family: 'aktiv-grotesk-condensed', 'Oswald', sans-serif;
  font-size: 38px;
  font-weight: 900;
  letter-spacing: 2px;
  line-height: 1.1;
  background: linear-gradient(135deg, var(--cyan) 0%, var(--magenta) 50%, var(--orange) 100%);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  background-size: 200% 200%;
  animation: learn-gradient-shift 4s ease infinite;
  margin-bottom: 16px;
  text-transform: uppercase;
}
@keyframes learn-gradient-shift {
  0%, 100% { background-position: 0% 50%; }
  50% { background-position: 100% 50%; }
}

/* Teal-bordered content box (IG's signature) */
.learn-ig-box {
  padding: 20px;
  background: rgba(132,207,195,0.04);
  border: 1.5px solid rgba(132,207,195,0.25);
  border-radius: 14px;
  margin: 16px 0;
}
.learn-ig-box.magenta-border {
  border-color: rgba(255,98,154,0.25);
  background: rgba(255,98,154,0.04);
}
.learn-ig-box.orange-border {
  border-color: rgba(255,163,0,0.25);
  background: rgba(255,163,0,0.04);
}

/* Colored dot bullets */
.learn-ig-bullet {
  display: flex;
  align-items: flex-start;
  gap: 14px;
  margin-bottom: 10px;
  padding: 14px 16px;
  font-size: 14px;
  line-height: 1.55;
  color: var(--text-secondary);
  background: rgba(255,255,255,0.025);
  border: 1px solid rgba(255,255,255,0.06);
  border-radius: 12px;
  border-left: 3px solid var(--cyan);
}
.learn-ig-bullet:last-child { margin-bottom: 0; }
.learn-ig-bullet .dot {
  width: 8px; height: 8px;
  border-radius: 50%;
  flex-shrink: 0;
  margin-top: 5px;
}
.learn-ig-bullet .dot.teal { background: var(--cyan); }
.learn-ig-bullet .dot.magenta { background: var(--magenta); }
.learn-ig-bullet .dot.orange { background: var(--orange); }
.learn-ig-bullet:nth-child(2) { border-left-color: var(--magenta); }
.learn-ig-bullet:nth-child(3) { border-left-color: var(--orange); }

/* Bordered form row (how taken) */
.learn-ig-form-row {
  display: flex;
  align-items: center;
  gap: 14px;
  padding: 14px 16px;
  border: 1px solid rgba(132,207,195,0.15);
  border-radius: 12px;
  margin-bottom: 10px;
  background: rgba(255,255,255,0.02);
}
.learn-ig-form-row:last-child { margin-bottom: 0; }
.learn-ig-form-icon {
  width: 32px; height: 32px;
  flex-shrink: 0;
}
.learn-ig-form-icon svg { width: 100%; height: 100%; }
.learn-ig-form-text {
  flex: 1;
}
.learn-ig-form-text strong {
  display: block;
  font-size: 14px;
  font-weight: 600;
  margin-bottom: 2px;
}
.learn-ig-form-text span {
  font-size: 12px;
  color: var(--text-dim);
  line-height: 1.4;
}

/* Timing stat boxes (onset/peak/duration) */
.learn-ig-timing {
  display: flex;
  gap: 8px;
  margin: 16px 0;
}
.learn-ig-timing-box {
  flex: 1;
  padding: 14px 10px;
  border-radius: 12px;
  text-align: center;
}
.learn-ig-timing-box.teal { background: rgba(132,207,195,0.06); border: 1px solid rgba(132,207,195,0.15); }
.learn-ig-timing-box.magenta { background: rgba(255,98,154,0.06); border: 1px solid rgba(255,98,154,0.15); }
.learn-ig-timing-box.orange { background: rgba(255,163,0,0.06); border: 1px solid rgba(255,163,0,0.15); }
.learn-ig-timing-label {
  font-size: 10px;
  text-transform: uppercase;
  letter-spacing: 1px;
  color: var(--text-dim);
  margin-bottom: 4px;
}
.learn-ig-timing-val {
  font-family: 'Oswald', sans-serif;
  font-size: 22px;
  font-weight: 700;
}
.learn-ig-timing-unit {
  font-size: 10px;
  color: var(--text-dim);
  margin-top: 1px;
}

/* Ambient glow orb */
.learn-glow-orb {
  position: absolute;
  border-radius: 50%;
  pointer-events: none;
  z-index: 0;
  filter: blur(60px);
}
.learn-glow-orb.amber { background: rgba(255,163,0,0.08); width: 200px; height: 200px; }
.learn-glow-orb.teal { background: rgba(132,207,195,0.06); width: 180px; height: 180px; }
.learn-glow-orb.magenta { background: rgba(255,98,154,0.06); width: 160px; height: 160px; }

/* Harm reduction item (lined separator) */
.learn-ig-hr-item {
  padding: 14px 0;
  border-bottom: 1px solid rgba(132,207,195,0.1);
  display: flex;
  align-items: flex-start;
  gap: 12px;
}
.learn-ig-hr-item:last-child { border-bottom: none; }
.learn-ig-hr-icon {
  width: 28px; height: 28px;
  flex-shrink: 0;
}
.learn-ig-hr-icon svg { width: 100%; height: 100%; }
.learn-ig-hr-text {
  flex: 1;
  font-size: 14px;
  line-height: 1.55;
  color: var(--text-secondary);
}
.learn-ig-hr-text strong {
  color: var(--text-primary);
  font-weight: 600;
  display: block;
  margin-bottom: 2px;
}

/* Note callout (purity warning, etc.) */
.learn-ig-note {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  padding: 14px 16px;
  border-radius: 10px;
  background: rgba(255,98,154,0.05);
  border: 1px solid rgba(255,98,154,0.15);
  margin-top: 12px;
  font-size: 13px;
  line-height: 1.55;
  color: var(--text-secondary);
}
.learn-ig-note .note-icon {
  width: 20px; height: 20px;
  flex-shrink: 0;
  margin-top: 1px;
}
.learn-ig-note .note-icon svg { width: 100%; height: 100%; }

/* Title slide massive text */
.learn-title-huge {
  font-family: 'Oswald', sans-serif;
  font-size: 72px;
  font-weight: 700;
  letter-spacing: 6px;
  background: linear-gradient(135deg, var(--cyan) 0%, var(--magenta) 50%, var(--orange) 100%);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  margin-bottom: 8px;
  text-shadow: none;
}
.learn-title-aka {
  font-size: 13px;
  color: var(--text-dim);
  letter-spacing: 1px;
  margin-bottom: 28px;
  line-height: 1.5;
}

/* Action card video background */
.action-card-video {
  position: absolute;
  top: 0; left: 0; right: 0; bottom: 0;
  z-index: 0;
  overflow: hidden;
  border-radius: 16px;
  pointer-events: none;
}
.action-card-video video {
  width: 100%; height: 100%;
  object-fit: cover;
  opacity: 0.3;
  pointer-events: none;
}
.action-card-video * {
  pointer-events: none;
}
.action-card-video::after {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0; bottom: 0;
  background: linear-gradient(135deg, rgba(8,8,16,0.6) 0%, rgba(8,8,16,0.85) 100%);
  pointer-events: none;
}

/* ══════════════════════════════════════════════════════════════
   INTERACTIVE MODULES — Timeline, Swipe Deck, Risk Cards, Checklist
   ══════════════════════════════════════════════════════════════ */

/* ── Effects Timeline Module ── */
.learn-timeline-module { width: 100%; max-width: 380px; }
.learn-timeline-module .tm-phase-label {
  font-family: 'Oswald', sans-serif;
  font-size: 18px;
  font-weight: 700;
  letter-spacing: 1px;
  margin-bottom: 6px;
  transition: color 0.3s;
}
.learn-timeline-module .tm-desc {
  font-size: 13px;
  color: var(--text-secondary);
  line-height: 1.6;
  margin-bottom: 14px;
  min-height: 42px;
  transition: opacity 0.3s;
}
.learn-timeline-module .tm-curve {
  position: relative;
  height: 120px;
  margin: 12px 0 8px;
  border-radius: 12px;
  overflow: hidden;
  background: rgba(255,255,255,0.02);
  border: 1px solid var(--border-glass);
}
.learn-timeline-module .tm-curve canvas {
  width: 100%; height: 100%;
  display: block;
}
.learn-timeline-module .tm-cursor {
  position: absolute;
  top: 0; bottom: 0;
  width: 2px;
  background: linear-gradient(180deg, var(--cyan), var(--magenta));
  transition: left 0.15s ease;
  pointer-events: none;
  z-index: 2;
}
.learn-timeline-module .tm-cursor::after {
  content: '';
  position: absolute;
  top: 50%;
  left: -5px;
  width: 12px; height: 12px;
  border-radius: 50%;
  background: var(--magenta);
  transform: translateY(-50%);
  box-shadow: 0 0 12px rgba(255,98,154,0.5);
}
.learn-timeline-module .tm-slider {
  -webkit-appearance: none;
  width: 100%;
  height: 36px;
  background: transparent;
  margin: 0;
  cursor: pointer;
  position: relative;
  z-index: 3;
}
.learn-timeline-module .tm-slider::-webkit-slider-thumb {
  -webkit-appearance: none;
  width: 24px; height: 24px;
  border-radius: 50%;
  background: linear-gradient(135deg, var(--cyan), var(--magenta));
  border: 2px solid #fff;
  box-shadow: 0 0 16px rgba(132,207,195,0.5);
  cursor: grab;
}
.learn-timeline-module .tm-time-labels {
  display: flex;
  justify-content: space-between;
  font-size: 10px;
  color: var(--text-dim);
  margin-top: -4px;
}
.learn-timeline-module .tm-effects {
  margin-top: 14px;
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
}
.learn-timeline-module .tm-effect-tag {
  padding: 5px 10px;
  border-radius: 100px;
  font-size: 11px;
  font-weight: 500;
  background: rgba(255,255,255,0.04);
  border: 1px solid var(--border-glass);
  color: var(--text-secondary);
  transition: all 0.3s;
  animation: tm-tag-in 0.3s ease;
}
@keyframes tm-tag-in { from { opacity: 0; transform: scale(0.85); } to { opacity: 1; transform: scale(1); } }
.learn-timeline-module .tm-hydration {
  margin-top: 12px;
  padding: 10px 14px;
  border-radius: 10px;
  background: rgba(132,207,195,0.06);
  border: 1px solid rgba(132,207,195,0.12);
  font-size: 12px;
  color: var(--text-secondary);
  line-height: 1.5;
  display: flex;
  align-items: flex-start;
  gap: 8px;
}
.learn-timeline-module .tm-xp-unlocked {
  text-align: center;
  margin-top: 12px;
  font-family: 'Oswald', sans-serif;
  font-size: 14px;
  color: var(--cyan);
  letter-spacing: 1px;
  opacity: 0;
  transition: opacity 0.4s;
}
.learn-timeline-module .tm-xp-unlocked.visible { opacity: 1; }

/* ── Myth vs Fact Swipe Deck ── */
.learn-swipe-deck { width: 100%; max-width: 380px; text-align: center; }
.learn-swipe-deck .sd-stack {
  position: relative;
  height: 320px;
  margin: 16px 0;
  perspective: 600px;
}
.learn-swipe-deck .sd-card {
  position: absolute;
  top: 0; left: 50%;
  width: 300px;
  transform: translateX(-50%);
  border-radius: 20px;
  padding: 32px 24px;
  text-align: center;
  transition: transform 0.4s ease, opacity 0.4s ease;
  cursor: grab;
  touch-action: pan-y;
  user-select: none;
  -webkit-user-select: none;
  background: rgba(255,255,255,0.04);
  border: 1.5px solid var(--border-glass);
  backdrop-filter: blur(20px);
  -webkit-backdrop-filter: blur(20px);
}
.learn-swipe-deck .sd-card.swiping {
  transition: none;
}
.learn-swipe-deck .sd-card .sd-statement {
  font-family: 'Oswald', sans-serif;
  font-size: 18px;
  font-weight: 600;
  color: var(--text-primary);
  line-height: 1.4;
  margin-bottom: 24px;
  letter-spacing: 0.5px;
}
.learn-swipe-deck .sd-card .sd-prompt {
  font-size: 12px;
  color: var(--text-dim);
  letter-spacing: 1.5px;
  text-transform: uppercase;
  font-weight: 600;
}
.learn-swipe-deck .sd-card .sd-verdict {
  display: none;
  margin-top: 16px;
  font-size: 13px;
  color: var(--text-secondary);
  line-height: 1.6;
  text-align: left;
}
.learn-swipe-deck .sd-card.revealed .sd-verdict { display: block; }
.learn-swipe-deck .sd-card.revealed .sd-prompt { display: none; }
.learn-swipe-deck .sd-card .sd-label {
  display: none;
  font-family: 'Oswald', sans-serif;
  font-size: 32px;
  font-weight: 700;
  letter-spacing: 3px;
  margin-bottom: 10px;
}
.learn-swipe-deck .sd-card.revealed .sd-label { display: block; }
.learn-swipe-deck .sd-card.revealed .sd-label.myth { color: var(--magenta); }
.learn-swipe-deck .sd-card.revealed .sd-label.fact { color: var(--cyan); }
.learn-swipe-deck .sd-buttons {
  display: flex;
  justify-content: center;
  gap: 32px;
  margin-top: 16px;
}
.learn-swipe-deck .sd-btn {
  width: 60px; height: 60px;
  border-radius: 50%;
  border: 2px solid;
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: 'Oswald', sans-serif;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 1px;
  cursor: pointer;
  transition: all 0.2s;
  background: transparent;
}
.learn-swipe-deck .sd-btn.myth-btn {
  border-color: rgba(255,98,154,0.3);
  color: var(--magenta);
}
.learn-swipe-deck .sd-btn.myth-btn:active { background: rgba(255,98,154,0.15); transform: scale(0.9); }
.learn-swipe-deck .sd-btn.fact-btn {
  border-color: rgba(132,207,195,0.3);
  color: var(--cyan);
}
.learn-swipe-deck .sd-btn.fact-btn:active { background: rgba(132,207,195,0.15); transform: scale(0.9); }
.learn-swipe-deck .sd-counter {
  font-size: 12px;
  color: var(--text-dim);
  margin-top: 12px;
}
.learn-swipe-deck .sd-xp {
  font-family: 'Oswald', sans-serif;
  font-size: 14px;
  color: var(--cyan);
  letter-spacing: 1px;
  margin-top: 4px;
  opacity: 0;
  transition: opacity 0.4s;
}
.learn-swipe-deck .sd-xp.visible { opacity: 1; }

/* ── Risk Awareness Expandable Cards ── */
.learn-risk-cards { width: 100%; max-width: 380px; }
.learn-risk-card {
  border: 1px solid var(--border-glass);
  border-radius: 14px;
  margin-bottom: 10px;
  overflow: hidden;
  transition: border-color 0.3s;
  background: rgba(255,255,255,0.02);
}
.learn-risk-card.expanded { border-color: rgba(255,98,154,0.3); }
.learn-risk-card .rc-header {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 14px 16px;
  cursor: pointer;
  -webkit-tap-highlight-color: transparent;
}
.learn-risk-card .rc-icon { font-size: 20px; flex-shrink: 0; }
.learn-risk-card .rc-title {
  flex: 1;
  font-family: 'Oswald', sans-serif;
  font-size: 14px;
  font-weight: 600;
  letter-spacing: 0.5px;
  color: var(--text-primary);
}
.learn-risk-card .rc-severity {
  font-size: 9px;
  font-weight: 700;
  letter-spacing: 1px;
  text-transform: uppercase;
  padding: 3px 8px;
  border-radius: 100px;
}
.learn-risk-card .rc-severity.high { background: rgba(255,163,0,0.12); color: var(--orange); }
.learn-risk-card .rc-severity.critical { background: rgba(255,98,154,0.12); color: var(--magenta); }
.learn-risk-card .rc-severity.moderate { background: rgba(132,207,195,0.12); color: var(--cyan); }
.learn-risk-card .rc-chevron {
  width: 16px; height: 16px;
  color: var(--text-dim);
  transition: transform 0.3s;
  flex-shrink: 0;
}
.learn-risk-card.expanded .rc-chevron { transform: rotate(180deg); }
.learn-risk-card .rc-preview {
  font-size: 12px;
  color: var(--text-dim);
  padding: 0 16px 12px 48px;
  line-height: 1.5;
}
.learn-risk-card.expanded .rc-preview { display: none; }
.learn-risk-card .rc-detail {
  display: none;
  padding: 0 16px 16px 48px;
  font-size: 13px;
  color: var(--text-secondary);
  line-height: 1.65;
  animation: rc-expand 0.3s ease;
}
.learn-risk-card.expanded .rc-detail { display: block; }
@keyframes rc-expand { from { opacity: 0; transform: translateY(-8px); } to { opacity: 1; transform: translateY(0); } }
.learn-risk-xp {
  text-align: center;
  margin-top: 12px;
  font-family: 'Oswald', sans-serif;
  font-size: 14px;
  color: var(--cyan);
  letter-spacing: 1px;
  opacity: 0;
  transition: opacity 0.4s;
}
.learn-risk-xp.visible { opacity: 1; }

/* ── Harm Reduction Checklist ── */
.learn-checklist { width: 100%; max-width: 380px; }
.learn-check-item {
  display: flex;
  align-items: flex-start;
  gap: 14px;
  padding: 16px;
  border: 1.5px solid var(--border-glass);
  border-radius: 14px;
  margin-bottom: 10px;
  cursor: pointer;
  transition: all 0.3s;
  background: rgba(255,255,255,0.02);
  -webkit-tap-highlight-color: transparent;
}
.learn-check-item.checked {
  border-color: rgba(132,207,195,0.3);
  background: rgba(132,207,195,0.04);
}
.learn-check-item .ci-box {
  width: 28px; height: 28px;
  border-radius: 8px;
  border: 2px solid rgba(255,255,255,0.15);
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  font-size: 16px;
  transition: all 0.3s;
}
.learn-check-item.checked .ci-box {
  border-color: var(--cyan);
  background: rgba(132,207,195,0.15);
  animation: ci-check-pop 0.35s ease;
}
@keyframes ci-check-pop {
  0% { transform: scale(1); }
  40% { transform: scale(1.3); }
  100% { transform: scale(1); }
}
.learn-check-item .ci-icon { font-size: 20px; flex-shrink: 0; margin-top: 2px; }
.learn-check-item .ci-title {
  font-family: 'Oswald', sans-serif;
  font-size: 15px;
  font-weight: 600;
  color: var(--text-primary);
  margin-bottom: 4px;
  letter-spacing: 0.3px;
}
.learn-check-item .ci-desc {
  font-size: 12px;
  color: var(--text-dim);
  line-height: 1.5;
}
.learn-check-progress {
  text-align: center;
  margin-top: 14px;
}
.learn-check-progress .cp-bar {
  height: 4px;
  border-radius: 2px;
  background: rgba(255,255,255,0.06);
  overflow: hidden;
  margin-bottom: 8px;
}
.learn-check-progress .cp-fill {
  height: 100%;
  border-radius: 2px;
  background: linear-gradient(90deg, var(--cyan), var(--magenta));
  transition: width 0.4s ease;
}
.learn-check-badge {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 8px 18px;
  border-radius: 100px;
  background: rgba(132,207,195,0.08);
  border: 1px solid rgba(132,207,195,0.2);
  font-family: 'Oswald', sans-serif;
  font-size: 13px;
  color: var(--cyan);
  letter-spacing: 1px;
  opacity: 0;
  transform: translateY(8px);
  transition: all 0.4s ease;
}
.learn-check-badge.visible { opacity: 1; transform: translateY(0); }

/* ── Multi-Quiz (5 questions, scrollable) ── */
.learn-multiquiz { width: 100%; max-width: 380px; }
.learn-mq-counter {
  text-align: center;
  font-family: 'Oswald', sans-serif;
  font-size: 14px;
  color: var(--text-dim);
  letter-spacing: 1px;
  margin-bottom: 6px;
}
.learn-mq-score {
  text-align: center;
  font-family: 'Oswald', sans-serif;
  font-size: 22px;
  color: var(--cyan);
  letter-spacing: 1px;
  margin-bottom: 16px;
}
.learn-mq-score span { font-size: 14px; color: var(--text-dim); }
.learn-mq-card {
  padding: 24px 20px;
  border-radius: 16px;
  border: 1.5px solid var(--border-glass);
  background: rgba(255,255,255,0.02);
  margin-bottom: 0;
  transition: all 0.4s;
}
.learn-mq-q {
  font-family: 'Oswald', sans-serif;
  font-size: 18px;
  font-weight: 600;
  color: var(--text-primary);
  line-height: 1.35;
  margin-bottom: 20px;
  text-align: center;
}
.learn-mq-options { display: flex; flex-direction: column; gap: 8px; }
.learn-mq-opt {
  padding: 14px 16px;
  border-radius: 10px;
  border: 1.5px solid var(--border-glass);
  background: rgba(255,255,255,0.03);
  color: var(--text-primary);
  font-size: 14px;
  text-align: left;
  cursor: pointer;
  transition: all 0.3s;
}
.learn-mq-opt:active { transform: scale(0.97); }
.learn-mq-opt.correct {
  border-color: var(--cyan) !important;
  background: rgba(132,207,195,0.12) !important;
  animation: learn-correct-pulse 0.5s ease;
}
.learn-mq-opt.correct::after { content: '✓'; float: right; color: var(--cyan); font-weight: 700; }
.learn-mq-opt.wrong {
  border-color: rgba(255,80,80,0.4) !important;
  background: rgba(255,80,80,0.08) !important;
  animation: learn-wrong-shake 0.4s ease;
}
.learn-mq-opt.wrong::after { content: '✗'; float: right; color: #ff5050; font-weight: 700; }
.learn-mq-explain {
  margin-top: 14px;
  padding: 12px 14px;
  border-radius: 10px;
  background: rgba(132,207,195,0.06);
  border: 1px solid rgba(132,207,195,0.12);
  font-size: 12px;
  line-height: 1.6;
  color: var(--text-secondary);
  opacity: 0;
  transform: translateY(6px);
  transition: all 0.4s;
}
.learn-mq-explain.visible { opacity: 1; transform: translateY(0); }
.learn-mq-next {
  display: block;
  margin: 16px auto 0;
  padding: 12px 32px;
  border-radius: 100px;
  border: none;
  background: linear-gradient(90deg, var(--cyan), var(--magenta));
  color: #fff;
  font-family: 'Oswald', sans-serif;
  font-size: 13px;
  font-weight: 600;
  letter-spacing: 1.5px;
  text-transform: uppercase;
  cursor: pointer;
  opacity: 0;
  transition: opacity 0.3s;
}
.learn-mq-next.visible { opacity: 1; }
.learn-mq-next:active { transform: scale(0.95); }
.learn-mq-result {
  text-align: center;
  padding: 24px;
  animation: tm-tag-in 0.4s ease;
}
.learn-mq-result .mq-grade {
  font-family: 'Oswald', sans-serif;
  font-size: 48px;
  font-weight: 700;
  background: linear-gradient(135deg, var(--cyan), var(--magenta));
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  margin-bottom: 8px;
}
.learn-mq-result .mq-label {
  font-size: 14px;
  color: var(--text-secondary);
  margin-bottom: 4px;
}
.learn-mq-result .mq-xp {
  font-family: 'Oswald', sans-serif;
  font-size: 16px;
  color: var(--cyan);
  letter-spacing: 1px;
}

/* ── Interactive module nav dot variants ── */
.learn-nav-dot.interactive { background: rgba(132,207,195,0.25); }
.learn-nav-dot.interactive.active { background: linear-gradient(90deg, var(--cyan), var(--orange)); }

/* ── Embed mode (iframe-friendly, strips app shell) ── */
body.embed-mode .bottom-nav,
body.embed-mode #bottom-nav,
body.embed-mode .app-header,
body.embed-mode .events-search-bar,
body.embed-mode .event-filters,
body.embed-mode #top-profile-btn,
body.embed-mode .ds-sidebar,
body.embed-mode .ds-topnav,
body.embed-mode #ds-user,
body.embed-mode .bicycle-day-banner,
body.embed-mode #event-reminders-container,
body.embed-mode .event-submit-fab,
body.embed-mode .events-list,
body.embed-mode .install-prompt-overlay,
body.embed-mode .install-prompt-sheet { display: none !important; }
body.embed-mode .screen { padding-top: 0 !important; }
body.embed-mode .events-screen { padding-top: 0 !important; }
body.embed-mode .bd-city-list-overlay { top: 0 !important; z-index: 10 !important; }
body.embed-mode .bd-detail-overlay { top: 0 !important; }
body.embed-mode .auth-screen { padding-top: 40px !important; }
body.embed-mode #screen-events { opacity: 0; pointer-events: none; }
body.embed-mode.embed-ready #screen-events { opacity: 1; pointer-events: auto; }
body.embed-mode .bd-city-list-overlay { opacity: 0; transition: opacity 0.25s ease; }
body.embed-mode .bd-city-list-overlay.visible { opacity: 1; }
body.embed-mode .bd-detail-overlay { opacity: 0; transition: opacity 0.25s ease; }
body.embed-mode .bd-detail-overlay.visible { opacity: 1; }

/* ── THE PREPARATION — Course Overlay ── */
.course-overlay {
  display: none; position: fixed; inset: 0; z-index: 9999;
  background: #1a1a1a; flex-direction: column; overflow: hidden;
}
.course-overlay.visible { display: flex; animation: course-fade-in 0.35s ease; }
@keyframes course-fade-in { from { opacity: 0; } to { opacity: 1; } }

/* Progress bar */
.course-progress-bar {
  position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: rgba(255,255,255,0.06); z-index: 10;
}
.course-progress-fill {
  height: 100%; width: 0%;
  background: linear-gradient(90deg, #ffa300, #ff629a);
  transition: width 0.4s cubic-bezier(0.16,1,0.3,1);
  border-radius: 0 2px 2px 0;
}

/* Header */
.course-header {
  display: flex; align-items: center; justify-content: space-between;
  padding: 14px 16px 10px; z-index: 5; flex-shrink: 0;
}
.course-back, .course-close {
  background: none; border: none; color: rgba(240,232,255,0.6);
  font-size: 22px; width: 36px; height: 36px; display: flex;
  align-items: center; justify-content: center; cursor: pointer;
  border-radius: 50%; transition: background 0.2s;
}
.course-back:hover, .course-close:hover { background: rgba(255,255,255,0.06); }
.course-back.hidden { visibility: hidden; pointer-events: none; }
.course-header-label {
  font-family: 'Inter', sans-serif; font-size: 11px; font-weight: 500;
  color: rgba(240,232,255,0.45); letter-spacing: 1.2px; text-transform: uppercase;
}

/* Viewport + slide track */
.course-viewport {
  flex: 1; overflow: hidden; position: relative;
}
.course-slide-track {
  display: flex; height: 100%;
  transition: transform 0.28s cubic-bezier(0.32,0.72,0,1);
}
.course-slide {
  min-width: 100%; height: 100%; overflow-y: auto; overflow-x: hidden;
  padding: 0 24px 120px; box-sizing: border-box;
  -webkit-overflow-scrolling: touch;
}

/* Typography */
.course-eyebrow {
  font-family: 'Inter', sans-serif; font-size: 11px; font-weight: 500;
  color: rgba(240,232,255,0.4); letter-spacing: 1.5px; text-transform: uppercase;
  margin-bottom: 12px;
}
.course-title {
  font-family: 'Oswald', sans-serif; font-size: 26px; font-weight: 600;
  color: #F0E8FF; text-transform: uppercase; letter-spacing: 1.5px;
  line-height: 1.2; margin-bottom: 16px;
}
.course-body {
  font-family: 'Inter', sans-serif; font-size: 15px; font-weight: 300;
  color: rgba(240,232,255,0.8); line-height: 1.65; margin-bottom: 20px;
}
.course-subtitle {
  font-family: 'Inter', sans-serif; font-size: 14px; font-weight: 400;
  color: rgba(240,232,255,0.5); line-height: 1.5; margin-bottom: 24px;
}

/* Video placeholder */
.course-video-placeholder {
  position: relative; width: 100%; aspect-ratio: 16/9;
  background: linear-gradient(135deg, #252525 0%, #1a1a1a 100%);
  border-radius: 12px; margin-bottom: 20px; overflow: hidden;
  border: 1px solid rgba(240,232,255,0.06);
  display: flex; align-items: center; justify-content: center;
}
.course-video-play {
  width: 56px; height: 56px; border-radius: 50%;
  background: rgba(255,163,0,0.9); display: flex;
  align-items: center; justify-content: center;
  box-shadow: 0 4px 24px rgba(255,163,0,0.3);
  transition: transform 0.2s;
}
.course-video-play:active { transform: scale(0.92); }
.course-video-play svg { margin-left: 3px; }
.course-video-placeholder.watched { border-color: rgba(132,207,195,0.2); }
.course-video-placeholder.watched .course-video-play { display: none; }

/* Intro branded header */
.course-intro-header {
  text-align: center; margin-bottom: 20px; padding-top: 4px;
}
.course-intro-header-series {
  font-family: 'Oswald', sans-serif; font-size: 28px; font-weight: 700;
  color: #F0E8FF; text-transform: uppercase; letter-spacing: 3px;
  line-height: 1.1; margin-bottom: 10px;
}
.course-intro-header-partnership {
  display: flex; align-items: center; justify-content: center; gap: 6px;
}
.course-intro-header-partnership span {
  font-family: 'Inter', sans-serif; font-size: 10px; font-weight: 400;
  color: rgba(240,232,255,0.25); letter-spacing: 0.5px;
}
.course-intro-header-partnership img { height: 12px; opacity: 0.4; }
.course-intro-divider {
  width: 40px; height: 1px; margin: 16px auto 0;
  background: linear-gradient(90deg, transparent, rgba(255,163,0,0.4), transparent);
}
.course-video-watched {
  font-family: 'Oswald', sans-serif; font-size: 14px; font-weight: 600;
  color: #84cfc3; letter-spacing: 1.5px; text-transform: uppercase;
  opacity: 0; transition: opacity 0.3s ease;
}
.course-video-placeholder.watched .course-video-watched { display: flex !important; opacity: 1; }
.course-host {
  font-family: 'Inter', sans-serif; font-size: 12px; font-weight: 400;
  color: rgba(240,232,255,0.45); margin-bottom: 16px;
}
.course-host strong { color: rgba(240,232,255,0.7); font-weight: 500; }

/* Multi-select choice cards */
.course-choices { display: flex; flex-direction: column; gap: 10px; }
.course-choice-card {
  display: flex; align-items: center; gap: 14px;
  background: rgba(30,28,28,0.9); border: 1px solid rgba(240,232,255,0.08);
  border-radius: 12px; padding: 16px 18px; cursor: pointer;
  transition: border-color 0.2s, background 0.2s, transform 0.15s;
  -webkit-tap-highlight-color: transparent; user-select: none;
}
.course-choice-card:active { transform: scale(0.98); }
.course-choice-card.selected {
  border-color: rgba(255,163,0,0.5);
  background: rgba(255,163,0,0.08);
}
.course-choice-emoji { font-size: 22px; flex-shrink: 0; }
.course-choice-text {
  font-family: 'Inter', sans-serif; font-size: 14px; font-weight: 400;
  color: #F0E8FF; line-height: 1.4;
}
.course-choice-check {
  margin-left: auto; width: 22px; height: 22px; border-radius: 50%;
  border: 1.5px solid rgba(240,232,255,0.15); flex-shrink: 0;
  display: flex; align-items: center; justify-content: center;
  transition: border-color 0.2s, background 0.2s;
}
.course-choice-card.selected .course-choice-check {
  border-color: #ffa300; background: #ffa300;
}
.course-choice-card.selected .course-choice-check::after {
  content: '✓'; color: #1a1a1a; font-size: 13px; font-weight: 700;
}

/* Pull quote card */
.course-quote-card {
  border-left: 3px solid #ffa300; padding: 16px 20px;
  background: rgba(255,163,0,0.04); border-radius: 0 12px 12px 0;
  margin: 20px 0;
}
.course-quote-text {
  font-family: 'Inter', sans-serif; font-size: 15px; font-weight: 400;
  color: #F0E8FF; line-height: 1.6; font-style: italic;
}
.course-quote-attr {
  font-family: 'Inter', sans-serif; font-size: 12px; font-weight: 400;
  color: rgba(240,232,255,0.4); margin-top: 10px;
}

/* Concept cards */
.course-concepts { display: flex; flex-direction: column; gap: 12px; }
.course-concept-card {
  display: flex; gap: 14px; align-items: flex-start;
  background: rgba(30,28,28,0.9); border: 1px solid rgba(240,232,255,0.06);
  border-radius: 12px; padding: 18px;
}
.course-concept-dot {
  width: 10px; height: 10px; border-radius: 50%; flex-shrink: 0; margin-top: 4px;
}
.course-concept-label {
  font-family: 'Oswald', sans-serif; font-size: 13px; font-weight: 600;
  color: #F0E8FF; letter-spacing: 1.5px; text-transform: uppercase; margin-bottom: 4px;
}
.course-concept-desc {
  font-family: 'Inter', sans-serif; font-size: 13px; font-weight: 300;
  color: rgba(240,232,255,0.65); line-height: 1.5;
}

/* Intention input */
.course-intention-wrap {
  margin: 32px 0 16px; text-align: center;
}
.course-intention-label {
  font-family: 'Inter', sans-serif; font-size: 12px; font-weight: 400;
  color: rgba(240,232,255,0.4); letter-spacing: 1px; text-transform: uppercase;
  margin-bottom: 12px;
}
.course-intention-input {
  width: 100%; background: none; border: none; outline: none;
  font-family: 'Georgia', 'Times New Roman', serif; font-size: 24px;
  font-style: italic; color: #F0E8FF; text-align: center;
  padding: 16px 0; border-bottom: 1px solid rgba(240,232,255,0.1);
  caret-color: #ffa300;
}
.course-intention-input::placeholder { color: rgba(240,232,255,0.2); }
.course-intention-hint {
  font-family: 'Inter', sans-serif; font-size: 11px; font-weight: 400;
  color: rgba(240,232,255,0.3); margin-top: 12px;
}

/* Journal textarea */
.course-journal-prompt {
  font-family: 'Inter', sans-serif; font-size: 14px; font-weight: 400;
  color: rgba(240,232,255,0.5); font-style: italic; margin-bottom: 16px;
}
.course-journal-textarea {
  width: 100%; min-height: 140px; background: rgba(30,28,28,0.9);
  border: 1px solid rgba(240,232,255,0.08); border-radius: 12px;
  padding: 16px 18px; font-family: 'Inter', sans-serif; font-size: 15px;
  font-weight: 300; color: #F0E8FF; line-height: 1.6; resize: none;
  outline: none; box-sizing: border-box; caret-color: #ffa300;
  transition: border-color 0.2s;
}
.course-journal-textarea:focus { border-color: rgba(255,163,0,0.3); }
.course-journal-textarea::placeholder { color: rgba(240,232,255,0.25); }

/* Bottom bar + CTA */
.course-bottom-bar {
  padding: 12px 24px 28px; flex-shrink: 0; text-align: center;
  background: linear-gradient(to top, #1a1a1a 60%, transparent);
  z-index: 5;
}
.course-cta {
  width: 100%; padding: 16px 24px; border: none; border-radius: 28px;
  font-family: 'Oswald', sans-serif; font-size: 16px; font-weight: 600;
  letter-spacing: 1px; text-transform: uppercase; cursor: pointer;
  background: linear-gradient(90deg, #ffa300, #ff629a);
  color: #1a1a1a; transition: opacity 0.2s, transform 0.15s;
}
.course-cta:active { transform: scale(0.97); }
.course-cta.disabled {
  opacity: 0.3; pointer-events: none;
}
.course-skip {
  font-family: 'Inter', sans-serif; font-size: 13px; font-weight: 400;
  color: rgba(240,232,255,0.35); margin-top: 14px; cursor: pointer;
  transition: color 0.2s;
}
.course-skip:hover { color: rgba(240,232,255,0.55); }

/* Completion screen */
.course-completion { text-align: center; padding-top: 40px; }
.course-star-burst {
  font-size: 64px; color: #ffa300; display: inline-block;
  animation: course-star-burst 0.8s cubic-bezier(0.16,1,0.3,1) forwards;
  text-shadow: 0 0 40px rgba(255,163,0,0.4);
}
@keyframes course-star-burst {
  0% { transform: scale(0) rotate(-30deg); opacity: 0; }
  60% { transform: scale(1.2) rotate(5deg); opacity: 1; }
  100% { transform: scale(1) rotate(0deg); opacity: 1; }
}
.course-complete-title {
  font-family: 'Oswald', sans-serif; font-size: 28px; font-weight: 600;
  color: #F0E8FF; text-transform: uppercase; letter-spacing: 2px;
  margin: 20px 0 8px;
}
.course-complete-sub {
  font-family: 'Inter', sans-serif; font-size: 14px; font-weight: 300;
  color: rgba(240,232,255,0.6); line-height: 1.5; margin-bottom: 32px;
}
.course-points-card {
  background: rgba(30,28,28,0.95); border: 1px solid rgba(255,163,0,0.2);
  border-radius: 16px; padding: 20px; margin-bottom: 16px;
}
.course-points-label {
  font-family: 'Inter', sans-serif; font-size: 11px; font-weight: 500;
  color: rgba(240,232,255,0.4); letter-spacing: 1.5px; text-transform: uppercase;
  margin-bottom: 6px;
}
.course-points-value {
  font-family: 'Oswald', sans-serif; font-size: 32px; font-weight: 600;
  color: #ffa300; letter-spacing: 1px;
}
.course-code-card {
  background: rgba(30,28,28,0.95); border: 1px solid rgba(132,207,195,0.25);
  border-radius: 16px; padding: 20px; margin-bottom: 8px;
}
.course-code-value {
  font-family: 'Oswald', sans-serif; font-size: 22px; font-weight: 600;
  color: #84cfc3; letter-spacing: 3px; margin-bottom: 6px;
}
.course-code-copy {
  display: inline-block; font-family: 'Oswald', sans-serif; font-size: 13px;
  font-weight: 600; color: #84cfc3; letter-spacing: 1px; text-transform: uppercase;
  padding: 8px 20px; border: 1px solid rgba(132,207,195,0.3); border-radius: 20px;
  cursor: pointer; margin: 10px 0 12px; transition: background 0.2s, color 0.2s;
  -webkit-tap-highlight-color: transparent;
}
.course-code-copy:active { background: rgba(132,207,195,0.15); }
.course-code-copy.copied {
  background: rgba(132,207,195,0.15); color: #84cfc3;
  pointer-events: none;
}
.course-code-hint {
  font-family: 'Inter', sans-serif; font-size: 11px; font-weight: 400;
  color: rgba(240,232,255,0.3); line-height: 1.4;
}

/* Module hub (coming soon) */
.course-module-hub { margin-top: 32px; text-align: left; }
.course-module-action {
  display: flex; align-items: center; gap: 12px;
  padding: 14px 0; border-bottom: 1px solid rgba(240,232,255,0.04);
}
.course-module-action-num {
  width: 28px; height: 28px; border-radius: 50%; display: flex;
  align-items: center; justify-content: center;
  font-family: 'Oswald', sans-serif; font-size: 13px; font-weight: 600;
  flex-shrink: 0;
}
.course-module-action-num.done { background: #ffa300; color: #1a1a1a; }
.course-module-action-num.locked { background: rgba(240,232,255,0.06); color: rgba(240,232,255,0.3); }
.course-module-action-name {
  font-family: 'Inter', sans-serif; font-size: 14px; font-weight: 400;
  color: #F0E8FF; flex: 1;
}
.course-module-action-badge {
  font-family: 'Inter', sans-serif; font-size: 10px; font-weight: 500;
  color: rgba(240,232,255,0.3); letter-spacing: 1px; text-transform: uppercase;
  background: rgba(240,232,255,0.04); padding: 4px 10px; border-radius: 20px;
}

/* Journey tab entry card */
.course-journey-card {
  background: rgba(30,28,28,0.95); border: 1px solid rgba(255,163,0,0.12);
  border-radius: 16px; padding: 20px; margin-bottom: 20px;
  position: relative; overflow: hidden; cursor: pointer;
  transition: transform 0.15s;
  -webkit-tap-highlight-color: transparent;
}
.course-journey-card:active { transform: scale(0.98); }
.course-journey-card-star {
  position: absolute; top: 14px; right: 16px; font-size: 28px;
  color: #ffa300; opacity: 0.15;
}
.course-journey-card-tag {
  font-family: 'Inter', sans-serif; font-size: 10px; font-weight: 500;
  color: rgba(240,232,255,0.35); letter-spacing: 1.5px; text-transform: uppercase;
  margin-bottom: 8px;
}
.course-journey-card-title {
  font-family: 'Oswald', sans-serif; font-size: 20px; font-weight: 600;
  color: #F0E8FF; text-transform: uppercase; letter-spacing: 1.5px;
  margin-bottom: 4px;
}
.course-journey-card-sub {
  font-family: 'Inter', sans-serif; font-size: 13px; font-weight: 300;
  color: rgba(240,232,255,0.5); margin-bottom: 14px;
}
.course-journey-card-progress {
  font-family: 'Inter', sans-serif; font-size: 11px; font-weight: 400;
  color: rgba(240,232,255,0.3); margin-bottom: 14px;
}
.course-journey-card-cta {
  display: inline-block; font-family: 'Oswald', sans-serif; font-size: 14px;
  font-weight: 600; color: #ffa300; letter-spacing: 1px; text-transform: uppercase;
}

/* ── Interactive Components — Shared ── */

/* Flip cards */
.course-flip-card {
  perspective: 800px; cursor: pointer;
  -webkit-tap-highlight-color: transparent;
}
.course-flip-card:active { transform: scale(0.97); }
.course-flip-inner {
  position: relative; width: 100%; min-height: 120px;
  transform-style: preserve-3d;
  transition: transform 0.6s cubic-bezier(0.4, 0, 0.2, 1);
}
.course-flip-inner.flipped { transform: rotateY(180deg); }
.course-flip-front, .course-flip-back {
  position: absolute; inset: 0; backface-visibility: hidden; -webkit-backface-visibility: hidden;
  border-radius: 12px; padding: 18px; box-sizing: border-box;
  border: 1px solid rgba(240,232,255,0.08); background: rgba(30,28,28,0.9);
}
.course-flip-front {
  display: flex; flex-direction: column; align-items: center; justify-content: center;
  gap: 8px; text-align: center;
}
.course-flip-back {
  transform: rotateY(180deg);
}
.course-flip-front .course-flip-dot {
  width: 12px; height: 12px; border-radius: 50%; margin-bottom: 4px;
}
.course-flip-front .course-flip-label {
  font-family: 'Oswald', sans-serif; font-size: 15px; font-weight: 600;
  color: #F0E8FF; letter-spacing: 1.5px; text-transform: uppercase;
}
.course-flip-front .course-flip-hint {
  font-family: 'Inter', sans-serif; font-size: 11px; color: rgba(240,232,255,0.3);
}
.course-flip-back .course-flip-back-label {
  font-family: 'Oswald', sans-serif; font-size: 12px; font-weight: 600;
  color: #ffa300; letter-spacing: 1px; text-transform: uppercase; margin-bottom: 8px;
}
.course-flip-back .course-flip-back-desc {
  font-family: 'Inter', sans-serif; font-size: 13px; font-weight: 300;
  color: rgba(240,232,255,0.7); line-height: 1.55;
}
.course-flip-counter {
  font-family: 'Inter', sans-serif; font-size: 11px; font-weight: 500;
  color: rgba(240,232,255,0.3); text-align: center; margin-top: 12px; letter-spacing: 1px;
}

/* Breathing animation */
.course-breathing-wrap {
  display: flex; flex-direction: column; align-items: center; justify-content: center;
  padding: 40px 0; transition: opacity 0.5s ease;
}
.course-breath-circle {
  width: 100px; height: 100px; border-radius: 50%;
  border: 2px solid rgba(255,163,0,0.3);
  background: rgba(255,163,0,0.04);
  transition: transform 4s ease-in-out, border-color 4s ease, background 4s ease;
}
.course-breath-circle.inhale {
  transform: scale(1.5);
  border-color: rgba(255,163,0,0.5);
  background: rgba(255,163,0,0.08);
}
.course-breath-text {
  font-family: 'Inter', sans-serif; font-size: 14px; font-weight: 300;
  color: rgba(240,232,255,0.5); margin-top: 20px; letter-spacing: 0.5px;
  transition: opacity 0.3s;
}

/* Choice card affirmations */
.course-choice-affirmation {
  font-family: 'Inter', sans-serif; font-size: 12px; font-weight: 400;
  color: rgba(255,163,0,0.7); font-style: italic; line-height: 1.4;
  max-height: 0; opacity: 0; overflow: hidden; margin-top: 0;
  transition: max-height 0.35s ease, opacity 0.25s ease, margin 0.25s;
}
.course-choice-card.selected .course-choice-affirmation {
  max-height: 40px; opacity: 1; margin-top: 8px;
}

/* Progressive reveal */
.course-reveal-block {
  opacity: 0; transform: translateY(16px);
  transition: opacity 0.5s ease, transform 0.5s ease;
}
.course-reveal-block.visible {
  opacity: 1; transform: translateY(0);
}

/* Keepsake echo card */
.course-echo-card {
  background: rgba(30,28,28,0.95); border: 1px solid rgba(255,163,0,0.15);
  border-radius: 16px; padding: 20px; margin-top: 20px; text-align: center;
  opacity: 0; transition: opacity 0.4s ease;
}
.course-echo-card.visible { opacity: 1; }
.course-echo-text {
  font-family: 'Georgia', 'Times New Roman', serif; font-size: 18px;
  font-style: italic; color: #F0E8FF; line-height: 1.5; min-height: 28px;
}

/* Rotating prompt */
.course-rotating-prompt {
  transition: opacity 0.4s ease;
}

/* Word milestone encouragement */
.course-word-milestone {
  font-family: 'Inter', sans-serif; font-size: 12px; font-weight: 400;
  color: rgba(255,163,0,0.6); text-align: center; margin-top: 12px;
  opacity: 0; transition: opacity 0.5s ease;
}
.course-word-milestone.visible { opacity: 1; }

/* Depth meter (Five Whys) */
.course-depth-meter {
  position: absolute; left: 0; top: 0; bottom: 0; width: 3px;
  background: rgba(240,232,255,0.04); border-radius: 2px; overflow: hidden;
}
.course-depth-fill {
  width: 100%; height: 0%; border-radius: 2px;
  background: linear-gradient(to bottom, #ffa300, #ff629a, #84cfc3);
  transition: height 0.6s cubic-bezier(0.16,1,0.3,1);
}
.course-depth-fill.glow {
  box-shadow: 0 0 12px rgba(132,207,195,0.4);
}

/* Deeper button pulse */
.course-deeper-btn.pulse {
  animation: course-pulse-btn 1.5s ease infinite;
}
@keyframes course-pulse-btn {
  0%, 100% { box-shadow: 0 0 0 0 rgba(255,163,0,0.2); }
  50% { box-shadow: 0 0 0 8px rgba(255,163,0,0); }
}

/* Why layer deepening border colors */
.course-why-layer.depth-1 { border-left-color: rgba(255,163,0,0.3); }
.course-why-layer.depth-2 { border-left-color: rgba(255,163,0,0.5); }
.course-why-layer.depth-3 { border-left-color: rgba(255,130,80,0.5); }
.course-why-layer.depth-4 { border-left-color: rgba(255,98,154,0.5); }
.course-why-layer.depth-5 { border-left-color: rgba(132,207,195,0.5); }

/* Encouragement text */
.course-encourage {
  font-family: 'Inter', sans-serif; font-size: 12px; font-weight: 400;
  color: rgba(255,163,0,0.5); font-style: italic; text-align: center;
  opacity: 0; transition: opacity 0.4s ease; margin: 8px 0;
}
.course-encourage.visible { opacity: 1; }

/* ── Action 2: Know Your Why — Additional Styles ── */

/* Why pairs (Surface → Real reveal) */
.course-why-pairs { display: flex; flex-direction: column; gap: 14px; }
.course-why-pair {
  background: rgba(30,28,28,0.9); border: 1px solid rgba(240,232,255,0.06);
  border-radius: 14px; overflow: hidden; cursor: pointer;
  transition: border-color 0.3s; -webkit-tap-highlight-color: transparent;
}
.course-why-pair:active { transform: scale(0.98); }
.course-why-pair.revealed { border-color: rgba(132,207,195,0.2); cursor: default; }
.course-why-pair-surface { padding: 18px; }
.course-why-pair-tag {
  font-family: 'Oswald', sans-serif; font-size: 10px; font-weight: 600;
  letter-spacing: 1.5px; text-transform: uppercase; margin-bottom: 8px;
}
.surface-tag { color: rgba(255,98,154,0.6); }
.real-tag { color: #84cfc3; }
.course-why-pair-text {
  font-family: 'Inter', sans-serif; font-size: 15px; font-weight: 400;
  color: #F0E8FF; line-height: 1.5; font-style: italic;
}
.course-why-pair-tap {
  font-family: 'Inter', sans-serif; font-size: 11px; font-weight: 400;
  color: rgba(240,232,255,0.25); margin-top: 10px;
  transition: opacity 0.3s;
}
.course-why-pair.revealed .course-why-pair-tap { opacity: 0; height: 0; margin: 0; overflow: hidden; }
.course-why-pair-real {
  max-height: 0; opacity: 0; overflow: hidden;
  padding: 0 18px; border-top: 0 solid rgba(132,207,195,0.15);
  transition: max-height 0.5s ease, opacity 0.4s ease, padding 0.4s ease, border-top-width 0.3s;
}
.course-why-pair.revealed .course-why-pair-real {
  max-height: 120px; opacity: 1; padding: 16px 18px; border-top-width: 1px;
}
.course-why-pairs-insight {
  margin-top: 20px; opacity: 0; transform: translateY(12px);
  transition: opacity 0.5s ease, transform 0.5s ease;
}
.course-why-pairs-insight.visible { opacity: 1; transform: translateY(0); }

/* Legacy contrast cards (keep for compatibility) */
.course-contrast-cards { display: flex; flex-direction: column; gap: 12px; margin: 20px 0; }
.course-contrast-card {
  background: rgba(30,28,28,0.9); border-radius: 12px; padding: 18px;
  border: 1px solid rgba(240,232,255,0.06);
}

/* 2x2 practice grid */
.course-practice-grid {
  display: grid; grid-template-columns: 1fr 1fr; gap: 10px; margin: 20px 0;
}
.course-practice-card {
  background: rgba(30,28,28,0.9); border: 1px solid rgba(240,232,255,0.06);
  border-radius: 12px; padding: 16px; cursor: pointer;
  transition: border-color 0.25s, max-height 0.35s ease, padding 0.25s;
  -webkit-tap-highlight-color: transparent; overflow: hidden;
}
.course-practice-card:active { transform: scale(0.97); }
.course-practice-card.expanded {
  border-color: rgba(255,163,0,0.3);
  grid-column: 1 / -1;
}
.course-practice-emoji { font-size: 24px; margin-bottom: 8px; }
.course-practice-icon { margin-bottom: 10px; opacity: 0.85; }
.course-practice-name {
  font-family: 'Oswald', sans-serif; font-size: 13px; font-weight: 600;
  color: #F0E8FF; letter-spacing: 1px; text-transform: uppercase;
}
.course-practice-desc {
  font-family: 'Inter', sans-serif; font-size: 13px; font-weight: 300;
  color: rgba(240,232,255,0.6); line-height: 1.5; margin-top: 8px;
  max-height: 0; opacity: 0; overflow: hidden;
  transition: max-height 0.35s ease, opacity 0.25s ease, margin 0.25s;
}
.course-practice-card.expanded .course-practice-desc {
  max-height: 80px; opacity: 1;
}

/* Callout box */
.course-callout {
  background: rgba(132,207,195,0.06); border: 1px solid rgba(132,207,195,0.2);
  border-radius: 12px; padding: 14px 16px; margin: 16px 0;
}
.course-callout-text {
  font-family: 'Inter', sans-serif; font-size: 13px; font-weight: 400;
  color: rgba(240,232,255,0.6); line-height: 1.5; font-style: italic;
}

/* Five Whys reveal sequence */
.course-why-sequence { margin: 20px 0; }
.course-why-layer {
  padding: 12px 0 12px 16px; border-left: 2px solid rgba(240,232,255,0.06);
  margin-left: 8px; opacity: 0; max-height: 0; overflow: hidden;
  transition: opacity 0.4s ease, max-height 0.4s ease, margin 0.3s;
}
.course-why-layer.revealed {
  opacity: 1; max-height: 120px; margin-bottom: 4px;
}
.course-why-layer:first-child { border-left: none; margin-left: 0; padding-left: 0; }
.course-why-layer:first-child.revealed { max-height: 60px; }
.course-why-arrow {
  font-family: 'Inter', sans-serif; font-size: 11px; font-weight: 500;
  color: rgba(240,232,255,0.3); letter-spacing: 1px; text-transform: uppercase;
  margin-bottom: 4px;
}
.course-why-text {
  font-family: 'Inter', sans-serif; font-size: 15px; font-weight: 300;
  color: rgba(240,232,255,0.8); line-height: 1.5; font-style: italic;
}
.course-why-reveal-card {
  background: rgba(255,163,0,0.06); border: 1px solid rgba(255,163,0,0.25);
  border-radius: 12px; padding: 16px; margin-top: 16px;
  opacity: 0; transform: translateY(12px);
  transition: opacity 0.5s ease, transform 0.5s ease;
}
.course-why-reveal-card.revealed {
  opacity: 1; transform: translateY(0);
}
.course-why-reveal-text {
  font-family: 'Inter', sans-serif; font-size: 15px; font-weight: 500;
  color: #ffa300; font-style: italic;
}
.course-deeper-btn {
  display: inline-block; font-family: 'Inter', sans-serif; font-size: 13px;
  font-weight: 500; color: #ffa300; cursor: pointer; margin-top: 12px;
  padding: 8px 16px; border: 1px solid rgba(255,163,0,0.25); border-radius: 20px;
  background: rgba(255,163,0,0.06); transition: background 0.2s;
  -webkit-tap-highlight-color: transparent;
}
.course-deeper-btn:active { background: rgba(255,163,0,0.12); }
.course-deeper-btn.hidden { display: none; }

/* Sequential unlock inputs (Five Whys user input) */
.course-whys-inputs { display: flex; flex-direction: column; gap: 16px; margin: 20px 0; }
.course-why-field {
  opacity: 0.3; pointer-events: none;
  transition: opacity 0.4s ease;
}
.course-why-field.unlocked {
  opacity: 1; pointer-events: auto;
}
.course-why-field.just-unlocked {
  animation: course-field-unlock 0.5s ease;
}
@keyframes course-field-unlock {
  0% { opacity: 0.3; }
  50% { opacity: 1; border-color: rgba(255,163,0,0.4); }
  100% { opacity: 1; }
}
.course-why-field-label {
  font-family: 'Inter', sans-serif; font-size: 12px; font-weight: 500;
  color: rgba(240,232,255,0.4); letter-spacing: 0.5px; margin-bottom: 6px;
}
.course-why-field-input {
  width: 100%; background: rgba(30,28,28,0.9);
  border: 1px solid rgba(240,232,255,0.08); border-radius: 10px;
  padding: 14px 16px; font-family: 'Inter', sans-serif; font-size: 15px;
  font-weight: 300; color: #F0E8FF; line-height: 1.5;
  outline: none; box-sizing: border-box; caret-color: #ffa300;
  transition: border-color 0.2s;
}
.course-why-field-input:focus { border-color: rgba(255,163,0,0.3); }
.course-why-field-input::placeholder { color: rgba(240,232,255,0.2); }

/* Display card (Your Real Why) */
.course-real-why-card {
  background: rgba(30,28,28,0.95); border: 1px solid rgba(240,232,255,0.08);
  border-radius: 16px; padding: 24px; margin: 24px 0; text-align: center;
  position: relative;
}
.course-real-why-star {
  position: absolute; top: 12px; right: 14px; font-size: 18px;
  color: #ffa300; opacity: 0.2;
}
.course-real-why-label {
  font-family: 'Inter', sans-serif; font-size: 10px; font-weight: 500;
  color: rgba(240,232,255,0.35); letter-spacing: 1.5px; text-transform: uppercase;
  margin-bottom: 12px;
}
.course-real-why-text {
  font-family: 'Georgia', 'Times New Roman', serif; font-size: 20px;
  font-style: italic; color: #F0E8FF; line-height: 1.5;
}

/* Module progress mini card */
.course-module-progress-mini {
  font-family: 'Inter', sans-serif; font-size: 12px; font-weight: 400;
  color: rgba(240,232,255,0.4); margin: 16px 0 8px; text-align: center;
}
.course-next-preview {
  background: rgba(30,28,28,0.9); border: 1px solid rgba(240,232,255,0.06);
  border-radius: 12px; padding: 14px 16px; margin-top: 12px; text-align: left;
}
.course-next-preview-label {
  font-family: 'Inter', sans-serif; font-size: 10px; font-weight: 500;
  color: rgba(240,232,255,0.3); letter-spacing: 1px; text-transform: uppercase;
  margin-bottom: 4px;
}
.course-next-preview-title {
  font-family: 'Oswald', sans-serif; font-size: 15px; font-weight: 600;
  color: #F0E8FF; text-transform: uppercase; letter-spacing: 1px;
}
.course-next-preview-teaser {
  font-family: 'Inter', sans-serif; font-size: 12px; font-weight: 300;
  color: rgba(240,232,255,0.45); margin-top: 4px;
}

/* ═══════════════════════════════════════════════════════
   BD LIVE CHECK-IN MAP — Bicycle Day 2026
   ═══════════════════════════════════════════════════════ */

/* Check-In Bottom Sheet */
/* BD Live Map discoverability — top banner on the BD tab + floating action button */
.bd-livemap-banner { position:relative;display:flex;align-items:center;gap:12px;padding:14px 16px;margin:0 0 16px;border-radius:14px;background:linear-gradient(135deg,#ffa300,#ff629a);color:#0a0a0a;font-family:'Oswald',var(--font-heading),sans-serif;font-weight:700;font-size:15px;letter-spacing:0.8px;text-transform:uppercase;cursor:pointer;box-shadow:0 6px 22px rgba(255,98,154,0.35);border:none;width:100%;text-align:left;overflow:hidden; }
.bd-livemap-banner::before { content:'';position:absolute;inset:0;background:radial-gradient(circle at 85% 50%,rgba(255,255,255,0.3) 0%,transparent 45%);pointer-events:none; }
.bd-livemap-banner .bd-livemap-banner-pulse { width:10px;height:10px;border-radius:50%;background:#0a0a0a;flex-shrink:0;animation:bd-livemap-pulse 1.6s ease-in-out infinite; }
.bd-livemap-banner .bd-livemap-banner-text { flex:1;line-height:1.2;letter-spacing:0.6px; }
.bd-livemap-banner .bd-livemap-banner-arrow { font-size:20px;font-weight:400;flex-shrink:0; }
@keyframes bd-livemap-pulse { 0%,100% { opacity:1;transform:scale(1); } 50% { opacity:0.4;transform:scale(1.35); } }
.bd-livemap-fab { position:fixed;right:calc(16px + env(safe-area-inset-right, 0px));bottom:calc(88px + env(safe-area-inset-bottom, 0px));z-index:9000;display:flex;align-items:center;gap:8px;padding:12px 18px 12px 14px;border-radius:999px;border:none;background:linear-gradient(135deg,#ffa300,#ff629a);color:#0a0a0a;font-family:'Oswald',var(--font-heading),sans-serif;font-weight:700;font-size:13px;letter-spacing:0.8px;text-transform:uppercase;cursor:pointer;box-shadow:0 6px 22px rgba(255,98,154,0.45); }
.bd-livemap-fab:active { transform:scale(0.96); }
.bd-checkin-bg { position:fixed;inset:0;z-index:100010;background:rgba(0,0,0,0.65);backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);opacity:0;pointer-events:none;transition:opacity .25s ease; }
.bd-checkin-bg.visible { opacity:1;pointer-events:auto; }
.bd-checkin-sheet { position:fixed;bottom:0;left:0;right:0;z-index:100011;background:var(--card,#1a1a2e);border-radius:20px 20px 0 0;padding:16px 20px calc(env(safe-area-inset-bottom,16px) + 16px);transform:translateY(100%);transition:transform .3s cubic-bezier(.4,0,.2,1);max-height:85vh;overflow-y:auto; }
.bd-checkin-sheet.visible { transform:translateY(0); }
.bd-checkin-sheet-handle { width:36px;height:4px;background:rgba(255,255,255,0.15);border-radius:2px;margin:0 auto 16px; }
.bd-checkin-sheet-title { font-family:'Oswald',var(--font-heading),sans-serif;font-size:20px;font-weight:600;color:#fff;text-transform:uppercase;letter-spacing:1px;margin-bottom:4px; }
.bd-checkin-sheet-sub { font-size:13px;color:var(--text-dim);margin-bottom:16px; }
.bd-checkin-photo-picker { display:flex;align-items:center;gap:12px;margin-bottom:16px; }
.bd-checkin-photo-btn { width:80px;height:80px;border-radius:14px;border:2px dashed rgba(132,207,195,0.35);background:rgba(132,207,195,0.06);display:flex;flex-direction:column;align-items:center;justify-content:center;cursor:pointer;color:var(--cyan,#84cfc3);font-size:11px;font-weight:600;gap:4px;transition:border-color .2s; }
.bd-checkin-photo-btn:active { border-color:rgba(132,207,195,0.7); }
.bd-checkin-photo-preview { width:80px;height:80px;border-radius:14px;object-fit:cover;display:none; }
.bd-checkin-msg-input { width:100%;background:rgba(255,255,255,0.06);border:1px solid rgba(255,255,255,0.1);border-radius:12px;padding:12px 14px;color:var(--text,#fff);font-size:14px;font-family:'Inter',var(--font-body),sans-serif;resize:none;outline:none; }
.bd-checkin-msg-input::placeholder { color:var(--text-dim,rgba(255,255,255,0.4)); }
.bd-checkin-msg-input:focus { border-color:rgba(132,207,195,0.4); }
.bd-checkin-submit-btn { width:100%;margin-top:16px;padding:14px;border-radius:14px;border:none;background:linear-gradient(135deg,#412B51,#5a3d6e);color:#F4F4BE;font-family:'Oswald',var(--font-heading),sans-serif;font-size:16px;font-weight:600;text-transform:uppercase;letter-spacing:1px;cursor:pointer;transition:opacity .2s; }
.bd-checkin-submit-btn:disabled { opacity:0.5;cursor:not-allowed; }
.bd-checkin-submit-btn:active:not(:disabled) { opacity:0.8; }
.bd-checkin-gps-status { font-size:12px;color:var(--text-dim);margin-bottom:12px;display:flex;align-items:center;gap:6px; }
.bd-checkin-gps-dot { width:8px;height:8px;border-radius:50%;background:#84cfc3;display:inline-block; }
.bd-checkin-gps-dot.error { background:#ff629a; }

/* Check-In Confirmation Card */
.bd-checkin-confirm-card { background:linear-gradient(180deg,#2a1a3e,#1a1028);border:1px solid rgba(151,116,181,0.25);border-radius:16px;padding:24px 20px;text-align:center;margin:16px 0; }
.bd-checkin-confirm-emoji { font-size:40px;margin-bottom:8px; }
.bd-checkin-confirm-title { font-family:'Oswald',var(--font-heading),sans-serif;font-size:22px;font-weight:600;color:#fff;text-transform:uppercase;letter-spacing:1px;margin-bottom:4px; }
.bd-checkin-confirm-city { font-size:15px;color:#ffa300;font-weight:600;margin-bottom:2px; }
.bd-checkin-confirm-user { font-size:13px;color:var(--text-dim);margin-bottom:2px; }
.bd-checkin-confirm-time { font-size:12px;color:var(--text-dim); }
.bd-checkin-confirm-share { margin-top:16px;padding:10px 20px;border-radius:10px;border:1px solid rgba(132,207,195,0.2);background:transparent;color:var(--cyan,#84cfc3);font-size:13px;cursor:pointer; }
.bd-checkin-confirm-share:active { opacity:0.7; }

/* Live Map Overlay */
.bd-livemap-overlay { position:fixed;inset:0;z-index:100005;background:var(--bg,#080810);display:none;flex-direction:column; }
.bd-livemap-overlay.visible { display:flex; }
.bd-livemap-header { display:flex;align-items:center;padding:12px 16px;padding-top:calc(env(safe-area-inset-top,12px) + 12px);background:rgba(8,8,16,0.95);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);z-index:2;gap:12px; }
.bd-livemap-back { font-size:22px;color:var(--text);cursor:pointer;padding:4px;line-height:1; }
.bd-livemap-title { font-family:'Oswald',var(--font-heading),sans-serif;font-size:18px;font-weight:600;color:#fff;text-transform:uppercase;letter-spacing:1px;flex:1; }
.bd-livemap-counter { background:linear-gradient(135deg,rgba(255,163,0,0.15),rgba(132,207,195,0.15));border:1px solid rgba(255,163,0,0.3);border-radius:20px;padding:4px 12px;font-size:13px;font-weight:700;color:#ffa300; }
.bd-livemap-map { flex:1;position:relative; }
.bd-livemap-map .leaflet-container { background:#0f0f19 !important; }
.bd-livemap-map .leaflet-control-attribution { display:none; }
.bd-livemap-map .leaflet-control-zoom { display:none; }

/* Photo Feed */
.bd-photofeed-panel { position:absolute;bottom:0;left:0;right:0;z-index:3;background:linear-gradient(180deg,transparent,rgba(8,8,16,0.95) 40px);max-height:45vh;overflow-y:auto;padding:40px 12px 12px; }
.bd-photofeed-toggle { display:flex;align-items:center;justify-content:center;gap:6px;padding:8px;cursor:pointer;color:var(--text-dim);font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:0.5px; }
.bd-photofeed-grid { display:grid;grid-template-columns:repeat(3,1fr);gap:4px; }
.bd-photofeed-thumb { position:relative;aspect-ratio:1;border-radius:8px;overflow:hidden;cursor:pointer; }
.bd-photofeed-thumb img { width:100%;height:100%;object-fit:cover; }
.bd-photofeed-thumb-city { position:absolute;bottom:0;left:0;right:0;padding:4px 6px;background:linear-gradient(transparent,rgba(0,0,0,0.8));font-size:10px;font-weight:600;color:#fff;text-transform:uppercase;letter-spacing:0.5px; }

/* Check-In Button on Ride Detail */
.bd-checkin-ride-btn { display:flex;align-items:center;justify-content:center;gap:8px;width:100%;padding:14px;border-radius:14px;border:2px solid rgba(255,163,0,0.5);background:linear-gradient(135deg,rgba(255,163,0,0.12),rgba(255,98,154,0.08));color:#ffa300;font-family:'Oswald',var(--font-heading),sans-serif;font-size:16px;font-weight:600;text-transform:uppercase;letter-spacing:1px;cursor:pointer;transition:all .2s;margin:12px 0; }
.bd-checkin-ride-btn:active { opacity:0.8;transform:scale(0.98); }
.bd-checkin-ride-btn.checked-in { border-color:rgba(132,207,195,0.5);background:linear-gradient(135deg,rgba(132,207,195,0.12),rgba(132,207,195,0.06));color:#84cfc3;cursor:default; }

/* Leaflet check-in popup */
.bd-checkin-popup .leaflet-popup-content-wrapper { background:rgba(26,16,40,0.95);border:1px solid rgba(151,116,181,0.25);border-radius:14px;box-shadow:0 8px 24px rgba(0,0,0,0.5); }
.bd-checkin-popup .leaflet-popup-tip { background:rgba(26,16,40,0.95);border:1px solid rgba(151,116,181,0.25); }
.bd-checkin-popup .leaflet-popup-content { margin:0 !important;width:auto !important;padding:12px; }

/* ── Accessibility: honor prefers-reduced-motion ──
   Users who have enabled "Reduce Motion" in iOS/macOS accessibility settings
   get static versions of looping animations (skeleton shimmer, spinners,
   pulses, the starfield). Transitions shrink to a token duration so UI still
   feels responsive without triggering vestibular discomfort. */
@media (prefers-reduced-motion: reduce) {
  *,
  *::before,
  *::after {
    animation-duration: 0.001ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.08s !important;
    scroll-behavior: auto !important;
  }
  /* Starfield canvas doesn't use CSS animation — hide it to remove parallax drift. */
  #starfield { display: none !important; }
  /* Keep indicator dots visible but stop their pulse — just a solid glow. */
  .bd-livemap-banner-pulse,
  .founder-pulse-dot { animation: none !important; }
  /* Skeleton shimmers become static low-opacity blocks so layout still reserves space. */
  .bd-memfeed-skeleton,
  .skeleton-bar,
  .skeleton-circle,
  .skeleton-card,
  .dm-convo-skeleton,
  .bd-skeleton-card {
    animation: none !important;
    background: rgba(255,255,255,0.06) !important;
  }
}


/* Event social proof — attendee face pile + local-aware copy */
.event-attendees { display: flex; align-items: center; gap: 8px; }
.evp-faces { display: inline-flex; align-items: center; }
.evp-face { display: inline-flex; }
.evp-face .evp-face-img, .evp-face img, .evp-face > div { border: 2px solid #1a1a1a !important; }
.evp-more { font-size: 11px; font-weight: 700; color: var(--text-secondary); margin-left: 4px; }
.evp-copy { font-size: 12.5px; color: var(--text-secondary); font-weight: 500; }
.event-attendees.evp-you .evp-copy { color: var(--cyan); font-weight: 600; }

/* Local discovery — "People in your city" strip */
#city-people-strip { margin-bottom: 6px; }
.cps-strip { display: flex; gap: 14px; overflow-x: auto; padding: 8px 2px 10px; -webkit-overflow-scrolling: touch; scrollbar-width: none; }
.cps-strip::-webkit-scrollbar { display: none; }
.cps-person { flex-shrink: 0; width: 62px; text-align: center; cursor: pointer; }
.cps-person .cps-av { display: block; margin: 0 auto; }
.cps-name { font-size: 11.5px; color: var(--text-secondary); margin-top: 5px; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.cps-more-circle { width: 52px; height: 52px; border-radius: 50%; border: 1.5px dashed rgba(255,255,255,0.25); display: flex; align-items: center; justify-content: center; margin: 0 auto; color: var(--text-secondary); font-size: 20px; }

/* Contextual push opt-in nudge in circle chat */
#chat-notif-nudge { display: none; align-items: center; gap: 10px; padding: 11px 14px; margin: 8px 12px; background: rgba(255,163,0,0.1); border: 1px solid rgba(255,163,0,0.25); border-radius: 12px; }
.cnn-text { flex: 1; font-size: 13px; color: var(--text-primary); line-height: 1.4; }
.cnn-actions { display: flex; align-items: center; gap: 8px; flex-shrink: 0; }
.cnn-enable { background: linear-gradient(90deg, #ffa300, #ff629a); color: #0a0a0a; border: none; border-radius: 999px; padding: 7px 16px; font-size: 13px; font-weight: 700; cursor: pointer; white-space: nowrap; }
.cnn-skip { background: transparent; border: none; color: var(--text-secondary); font-size: 12px; cursor: pointer; white-space: nowrap; }

/* ── Deeper circle chat UX: grouping, optimistic send, warm empty state ── */
/* Consecutive-message grouping (same author, within 4 min) */
.chat-msg.grouped { margin-top: -3px; }
.chat-msg.grouped .chat-msg-avatar-wrap { visibility: hidden; width: 32px; height: 0; overflow: hidden; }
.chat-msg.grouped .chat-msg-name { display: none; }

/* Optimistic send states */
.chat-msg.pending { opacity: 0.6; }
.chat-msg-sending { font-style: italic; color: var(--text-dim); }
.chat-msg.failed { opacity: 1; }
.chat-msg-failed { color: #ff6b6b; font-weight: 600; cursor: pointer; }
.chat-msg-failed:active { opacity: 0.7; }

/* Warm, always-on empty state + conversation starters */
.chat-empty-state { text-align: center; padding: 40px 24px 24px; display: flex; flex-direction: column; align-items: center; }
.chat-empty-icon { font-size: 30px; margin-bottom: 10px; opacity: 0.7; }
.chat-empty-title { font-size: 17px; font-weight: 700; color: var(--text-primary); margin-bottom: 6px; }
.chat-empty-sub { font-size: 13.5px; color: var(--text-secondary); line-height: 1.5; max-width: 300px; margin-bottom: 18px; }
.chat-empty-starters { display: flex; flex-wrap: wrap; gap: 8px; justify-content: center; }
.chat-starter { background: rgba(132,207,195,0.12); border: 1px solid rgba(132,207,195,0.3); color: var(--text-primary); border-radius: 999px; padding: 8px 14px; font-size: 13px; font-weight: 600; cursor: pointer; transition: transform 0.1s ease, background 0.15s ease; }
.chat-starter:active { transform: scale(0.96); background: rgba(132,207,195,0.2); }
.chat-starter-event { background: linear-gradient(90deg, rgba(255,163,0,0.16), rgba(255,98,154,0.16)); border-color: rgba(255,163,0,0.35); }

/* Realtime presence pill ("N online") in the chat header */
.chat-online-dot { display: inline-block; width: 7px; height: 7px; border-radius: 50%; background: #3ddc84; box-shadow: 0 0 6px rgba(61,220,132,0.7); margin: 0 4px 0 1px; vertical-align: middle; }

/* Pinned "happening in {city}" events strip at top of a circle chat */
.chat-events-strip { padding: 10px 14px 4px; border-bottom: 1px solid rgba(255,255,255,0.06); background: rgba(255,255,255,0.015); flex-shrink: 0; }
.ces-head { font-size: 11.5px; font-weight: 700; letter-spacing: 0.3px; color: var(--text-secondary); text-transform: uppercase; margin-bottom: 8px; }
.ces-scroll { display: flex; gap: 8px; overflow-x: auto; padding-bottom: 6px; scrollbar-width: none; -webkit-overflow-scrolling: touch; }
.ces-scroll::-webkit-scrollbar { display: none; }
.ces-card { flex: 0 0 auto; display: flex; align-items: center; gap: 9px; max-width: 240px; padding: 8px 12px 8px 8px; border-radius: 12px; background: rgba(255,163,0,0.08); border: 1px solid rgba(255,163,0,0.22); cursor: pointer; text-align: left; transition: transform 0.1s ease, background 0.15s ease; }
.ces-card:active { transform: scale(0.97); background: rgba(255,163,0,0.14); }
.ces-date { flex: 0 0 auto; display: flex; flex-direction: column; align-items: center; justify-content: center; width: 38px; height: 38px; border-radius: 9px; background: linear-gradient(160deg, #ffa300, #ff629a); color: #0a0a0a; }
.ces-mon { font-size: 8.5px; font-weight: 800; letter-spacing: 0.5px; line-height: 1; }
.ces-day { font-size: 16px; font-weight: 800; line-height: 1.05; }
.ces-body { display: flex; flex-direction: column; min-width: 0; }
.ces-title { font-size: 13px; font-weight: 600; color: var(--text-primary); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; max-width: 170px; }
.ces-meta { font-size: 11px; color: var(--text-secondary); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; max-width: 170px; margin-top: 1px; }

/* Event card IN a chat message bubble */
.chat-event-card { display: flex; align-items: center; gap: 10px; width: 250px; max-width: 100%; padding: 10px; border-radius: 14px; background: rgba(255,163,0,0.09); border: 1px solid rgba(255,163,0,0.25); cursor: pointer; }
.chat-event-card .cec-date { flex: 0 0 auto; display: flex; flex-direction: column; align-items: center; justify-content: center; width: 42px; height: 42px; border-radius: 10px; background: linear-gradient(160deg, #ffa300, #ff629a); color: #0a0a0a; }
.cec-body { display: flex; flex-direction: column; min-width: 0; gap: 2px; flex: 1; }
.cec-title { font-size: 13.5px; font-weight: 700; color: var(--text-primary); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.cec-meta { font-size: 11px; color: var(--text-secondary); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.cec-rsvp { align-self: flex-start; margin-top: 4px; background: rgba(132,207,195,0.15); border: 1px solid rgba(132,207,195,0.4); color: var(--text-primary); border-radius: 999px; padding: 4px 14px; font-size: 12px; font-weight: 700; cursor: pointer; transition: transform 0.1s ease, background 0.15s ease; }
.cec-rsvp:active { transform: scale(0.95); }
.cec-rsvp.is-going { background: linear-gradient(90deg, #ffa300, #ff629a); border-color: transparent; color: #0a0a0a; }
.cec-rsvp:disabled { opacity: 0.6; }

/* Share-an-event picker sheet */
.circle-event-picker { position: fixed; inset: 0; z-index: 100020; display: none; }
.circle-event-picker.show { display: block; }
.cep-backdrop { position: absolute; inset: 0; background: rgba(0,0,0,0.55); }
.cep-panel { position: absolute; left: 0; right: 0; bottom: 0; max-height: 70vh; display: flex; flex-direction: column; background: var(--bg-card, #16131d); border-radius: 20px 20px 0 0; padding: 8px 16px max(16px, env(safe-area-inset-bottom)); box-shadow: 0 -8px 30px rgba(0,0,0,0.4); }
.cep-handle { width: 40px; height: 4px; border-radius: 2px; background: rgba(255,255,255,0.2); margin: 6px auto 10px; }
.cep-head { font-size: 16px; font-weight: 700; color: var(--text-primary); margin-bottom: 10px; }
.cep-list { overflow-y: auto; display: flex; flex-direction: column; gap: 8px; }
.cep-empty { padding: 24px 8px; text-align: center; color: var(--text-secondary); font-size: 13.5px; }
.cep-item { display: flex; align-items: center; gap: 12px; padding: 10px 12px; border-radius: 12px; background: rgba(255,255,255,0.04); border: 1px solid rgba(255,255,255,0.07); cursor: pointer; text-align: left; }
.cep-item:active { background: rgba(255,255,255,0.08); }
.cep-date { flex: 0 0 auto; width: 56px; font-size: 12px; font-weight: 700; color: var(--portal-accent, #ffa300); }
.cep-info { display: flex; flex-direction: column; min-width: 0; }
.cep-item .cep-title { font-size: 14px; font-weight: 600; color: var(--text-primary); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.cep-venue { font-size: 12px; color: var(--text-secondary); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.cep-cancel { margin-top: 12px; padding: 12px; border-radius: 12px; background: rgba(255,255,255,0.06); border: none; color: var(--text-primary); font-size: 14px; font-weight: 600; cursor: pointer; }

/* Jump-to-latest pill (shown when scrolled up + new messages arrive) */
.chat-jump-pill { position: absolute; left: 50%; bottom: 84px; transform: translateX(-50%) translateY(8px); z-index: 20; display: inline-flex; align-items: center; gap: 6px; padding: 8px 16px; border-radius: 999px; background: linear-gradient(90deg, #ffa300, #ff629a); color: #0a0a0a; font-size: 13px; font-weight: 700; border: none; cursor: pointer; box-shadow: 0 4px 16px rgba(0,0,0,0.35); opacity: 0; pointer-events: none; transition: opacity 0.18s ease, transform 0.18s ease; }
.chat-jump-pill.show { opacity: 1; pointer-events: auto; transform: translateX(-50%) translateY(0); }

/* Pinned message banner (one pin per circle, below events strip) */
.chat-pinned-banner { display: none; align-items: center; gap: 8px; padding: 9px 12px; background: rgba(132,207,195,0.10); border-bottom: 1px solid rgba(132,207,195,0.22); flex-shrink: 0; }
.cpb-icon { flex: 0 0 auto; font-size: 13px; }
.cpb-text { flex: 1; min-width: 0; font-size: 12.5px; color: var(--text-primary); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; cursor: pointer; }
.cpb-unpin { flex: 0 0 auto; background: none; border: none; color: var(--text-dim); font-size: 18px; line-height: 1; cursor: pointer; padding: 0 4px; -webkit-tap-highlight-color: transparent; }
.cpb-unpin:active { color: var(--text-primary); }
