/* ═══════════════════════════════════════════════════════════════════════
   VIBRATIONAL IDENTITY — Visual Overhaul v2.0
   Loaded AFTER style.css to upgrade the entire visual design.
   ═══════════════════════════════════════════════════════════════════════ */

/* ── DESIGN TOKENS (override) ──────────────────────────────────────── */
:root {
  /* Refined palette — richer, more depth */
  --bg-deep:       #050510;
  --bg-surface:    #0c0c24;
  --bg-card:       rgba(14, 14, 42, 0.65);
  --bg-card-hover: rgba(20, 20, 58, 0.75);

  --purple:    #7c3aed;
  --blue:      #38bdf8;
  --accent:    #a855f7;
  --gold:      #f59e0b;
  --gold-soft: rgba(245, 158, 11, 0.12);
  --rose:      #f43f5e;
  --emerald:   #10b981;

  --purple-rgb: 124, 58, 237;
  --blue-rgb:   56, 189, 248;
  --accent-rgb: 168, 85, 247;

  --text-primary:   #f1f0ff;
  --text-secondary: #a5a2c8;
  --text-muted:     #6b6895;
  --text-accent:    #c4b5fd;

  /* Glass — better contrast */
  --glass-bg:        rgba(14, 14, 42, 0.55);
  --glass-border:    rgba(124, 58, 237, 0.2);
  --glass-highlight: rgba(255, 255, 255, 0.04);
  --glass-shadow:    0 8px 40px rgba(0, 0, 0, 0.5),
                     0 0 80px rgba(124, 58, 237, 0.08);
  --card-glow:       0 0 60px rgba(124, 58, 237, 0.12);

  /* Radius */
  --r-sm: 10px;
  --r-md: 16px;
  --r-lg: 24px;
  --r-full: 9999px;
}

/* ── BASE OVERRIDES ────────────────────────────────────────────────── */
body {
  background: var(--bg-deep);
  background-image:
    radial-gradient(ellipse 80% 60% at 50% -10%, rgba(124,58,237,0.12) 0%, transparent 60%),
    radial-gradient(ellipse 60% 50% at 80% 100%, rgba(56,189,248,0.06) 0%, transparent 50%);
  color: var(--text-primary);
  font-family: var(--font-body);
  -webkit-font-smoothing: antialiased;
  min-height: 100dvh;
}

/* Subtle animated grain overlay */
body::before {
  content: '';
  position: fixed; inset: 0;
  background: url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.03'/%3E%3C/svg%3E");
  pointer-events: none;
  z-index: 0;
}

/* ── SPLASH / AUTH ─────────────────────────────────────────────────── */
#auth-splash {
  background: var(--bg-deep) !important;
  background-image:
    radial-gradient(ellipse 70% 50% at 50% 30%, rgba(124,58,237,0.18) 0%, transparent 60%),
    radial-gradient(ellipse 50% 40% at 20% 80%, rgba(56,189,248,0.08) 0%, transparent 50%) !important;
}

#auth-splash .splash-title,
.splash-title {
  font-family: var(--font-display) !important;
  font-weight: 700 !important;
  font-size: 2.2rem !important;
  background: linear-gradient(135deg, #f1f0ff 0%, #c4b5fd 50%, #a855f7 100%) !important;
  -webkit-background-clip: text !important;
  -webkit-text-fill-color: transparent !important;
  letter-spacing: -0.02em !important;
}

.splash-sub {
  color: var(--text-secondary) !important;
  font-size: 1rem !important;
  max-width: 320px;
  margin: 0 auto;
}

.splash-cta,
.splash-btn,
button[onclick*="splashCreateAccount"],
button[onclick*="splashSignIn"],
button[onclick*="splashGuest"] {
  border-radius: var(--r-full) !important;
  font-weight: 600 !important;
  font-size: 0.95rem !important;
  padding: 14px 32px !important;
  transition: all 0.3s cubic-bezier(0.2,0.9,0.2,1) !important;
  border: 1px solid rgba(124,58,237,0.3) !important;
  backdrop-filter: blur(12px) !important;
}

.splash-cta:first-of-type,
button[onclick*="splashCreateAccount"] {
  background: linear-gradient(135deg, #7c3aed, #a855f7) !important;
  color: white !important;
  border: none !important;
  box-shadow: 0 4px 24px rgba(124,58,237,0.35) !important;
}

.splash-cta:first-of-type:hover,
button[onclick*="splashCreateAccount"]:hover {
  transform: translateY(-2px) !important;
  box-shadow: 0 8px 32px rgba(124,58,237,0.45) !important;
}

/* ── APP SHELL ─────────────────────────────────────────────────────── */
#app-shell {
  background: transparent !important;
}

.app-main {
  padding-bottom: 100px !important;
}

/* ── TOP HERO / PROFILE BAR ────────────────────────────────────────── */
.profile-hero,
.home-hero-bar {
  background: linear-gradient(180deg, rgba(124,58,237,0.08) 0%, transparent 100%) !important;
  padding: 20px 20px 16px !important;
  border: none !important;
}

.profile-hero-avatar,
#home-avatar-btn {
  width: 44px !important;
  height: 44px !important;
  border-radius: 50% !important;
  background: linear-gradient(135deg, #7c3aed, #a855f7) !important;
  border: 2px solid rgba(255,255,255,0.15) !important;
  font-size: 1.1rem !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  box-shadow: 0 4px 16px rgba(124,58,237,0.3) !important;
}

.profile-hero-name,
#home-greeting-name {
  font-family: var(--font-display) !important;
  font-weight: 600 !important;
  font-size: 1.15rem !important;
  color: var(--text-primary) !important;
}

.profile-hero-sub,
#home-hero-sub {
  color: var(--text-muted) !important;
  font-size: 0.8rem !important;
}

.profile-badge {
  background: var(--gold-soft) !important;
  color: var(--gold) !important;
  font-size: 0.7rem !important;
  font-weight: 600 !important;
  padding: 3px 10px !important;
  border-radius: var(--r-full) !important;
  border: 1px solid rgba(245,158,11,0.2) !important;
}

/* ── HOME DASHBOARD SUMMARY ────────────────────────────────────────── */
.home-summary {
  padding: 0 20px 20px !important;
}

.home-summary-title,
#home-summary-title {
  font-family: var(--font-display) !important;
  font-size: 1.5rem !important;
  font-weight: 700 !important;
  color: var(--text-primary) !important;
  letter-spacing: -0.02em !important;
}

.home-summary-sub,
#home-summary-sub {
  color: var(--text-secondary) !important;
  font-size: 0.9rem !important;
  margin-top: 4px !important;
}

.home-summary-pill {
  display: inline-flex !important;
  align-items: center !important;
  background: var(--glass-bg) !important;
  border: 1px solid var(--glass-border) !important;
  border-radius: var(--r-full) !important;
  padding: 5px 14px !important;
  font-size: 0.78rem !important;
  font-weight: 500 !important;
  color: var(--text-accent) !important;
  backdrop-filter: blur(8px) !important;
}

/* ── READING TYPE GRID (DASHBOARD) ─────────────────────────────────── */
.home-explore-grid,
#home-explore-grid {
  display: grid !important;
  grid-template-columns: repeat(2, 1fr) !important;
  gap: 14px !important;
  padding: 0 20px 24px !important;
}

/* Make first card span full width as a hero card */
.home-explore-grid > .home-explore-card:first-child,
#home-explore-grid > div:first-child {
  grid-column: 1 / -1 !important;
}

.home-explore-card,
.home-explore-grid > div {
  background: var(--bg-card) !important;
  backdrop-filter: blur(16px) !important;
  border: 1px solid rgba(124,58,237,0.15) !important;
  border-radius: var(--r-md) !important;
  padding: 18px !important;
  cursor: pointer !important;
  transition: all 0.3s cubic-bezier(0.2,0.9,0.2,1) !important;
  position: relative !important;
  overflow: hidden !important;
}

.home-explore-card:hover,
.home-explore-grid > div:hover {
  background: var(--bg-card-hover) !important;
  border-color: rgba(124,58,237,0.3) !important;
  transform: translateY(-2px) !important;
  box-shadow: var(--card-glow) !important;
}

/* Subtle glow accent on each card */
.home-explore-card::before,
.home-explore-grid > div::before {
  content: '' !important;
  position: absolute !important;
  top: 0 !important; left: 0 !important; right: 0 !important;
  height: 2px !important;
  background: linear-gradient(90deg, transparent, rgba(124,58,237,0.4), transparent) !important;
  opacity: 0 !important;
  transition: opacity 0.3s !important;
}

.home-explore-card:hover::before,
.home-explore-grid > div:hover::before {
  opacity: 1 !important;
}

.home-explore-card .explore-card-icon,
.home-explore-grid > div .explore-card-icon {
  font-size: 1.8rem !important;
  margin-bottom: 8px !important;
  display: block !important;
}

.home-explore-card .explore-card-title,
.home-explore-grid > div .explore-card-title,
.explore-card-title {
  font-family: var(--font-display) !important;
  font-weight: 600 !important;
  font-size: 0.95rem !important;
  color: var(--text-primary) !important;
  margin-bottom: 4px !important;
}

.home-explore-card .explore-card-desc,
.home-explore-grid > div .explore-card-desc,
.explore-card-desc {
  font-size: 0.78rem !important;
  color: var(--text-muted) !important;
  line-height: 1.4 !important;
}

/* ── SECTION HEADERS (reading categories) ──────────────────────────── */
.home-section-heading,
.explore-section-title {
  font-family: var(--font-display) !important;
  font-size: 0.75rem !important;
  font-weight: 600 !important;
  text-transform: uppercase !important;
  letter-spacing: 0.1em !important;
  color: var(--text-muted) !important;
  padding: 16px 20px 8px !important;
}

/* ── MAIN FORM CARD ────────────────────────────────────────────────── */
.hero-text,
#hero-section {
  padding: 0 16px !important;
}

.hero-h1,
#hero-headline {
  font-family: var(--font-display) !important;
  font-size: clamp(1.8rem, 5vw, 2.6rem) !important;
  font-weight: 800 !important;
  line-height: 1.1 !important;
  letter-spacing: -0.03em !important;
  background: linear-gradient(135deg, #f1f0ff 0%, #c4b5fd 60%, #a855f7 100%) !important;
  -webkit-background-clip: text !important;
  -webkit-text-fill-color: transparent !important;
  text-align: center !important;
  margin-bottom: 8px !important;
}

.hero-sub {
  color: var(--text-secondary) !important;
  font-size: 1rem !important;
  text-align: center !important;
  max-width: 380px !important;
  margin: 0 auto 24px !important;
}

.card,
#card-form {
  background: var(--bg-card) !important;
  backdrop-filter: blur(20px) saturate(1.3) !important;
  border: 1px solid rgba(124,58,237,0.18) !important;
  border-radius: var(--r-lg) !important;
  padding: 28px 24px !important;
  box-shadow: var(--glass-shadow) !important;
  position: relative !important;
  overflow: hidden !important;
}

.card::before,
#card-form::before {
  content: '' !important;
  position: absolute !important;
  inset: 0 !important;
  border-radius: inherit !important;
  background: linear-gradient(135deg, rgba(255,255,255,0.03) 0%, transparent 60%) !important;
  pointer-events: none !important;
}

.card-noise {
  display: none !important;
}

.card-header {
  margin-bottom: 20px !important;
}

.card-title {
  font-family: var(--font-display) !important;
  font-size: 1.2rem !important;
  font-weight: 700 !important;
  color: var(--text-primary) !important;
}

.card-subtitle {
  color: var(--text-secondary) !important;
  font-size: 0.85rem !important;
}

/* ── FORM INPUTS ───────────────────────────────────────────────────── */
.field-group {
  margin-bottom: 16px !important;
}

.field-label {
  font-size: 0.72rem !important;
  font-weight: 600 !important;
  text-transform: uppercase !important;
  letter-spacing: 0.08em !important;
  color: var(--text-muted) !important;
  margin-bottom: 6px !important;
  display: block !important;
}

.field-input,
.auth-input,
.add-person-input,
.cs-chart-form input,
.cs-chart-form select {
  background: rgba(255,255,255,0.04) !important;
  border: 1px solid rgba(124,58,237,0.2) !important;
  border-radius: var(--r-sm) !important;
  padding: 12px 16px !important;
  font-size: 0.95rem !important;
  color: var(--text-primary) !important;
  font-family: var(--font-body) !important;
  width: 100% !important;
  transition: all 0.2s ease !important;
  outline: none !important;
}

.field-input:focus,
.auth-input:focus,
.add-person-input:focus,
.cs-chart-form input:focus {
  border-color: var(--accent) !important;
  background: rgba(124,58,237,0.06) !important;
  box-shadow: 0 0 0 3px rgba(124,58,237,0.12) !important;
}

.field-input::placeholder,
.auth-input::placeholder,
.add-person-input::placeholder {
  color: var(--text-muted) !important;
}

.field-input--date::-webkit-calendar-picker-indicator {
  filter: invert(0.7) !important;
}

.field-error {
  color: var(--rose) !important;
  font-size: 0.78rem !important;
}

.field-helper {
  color: var(--text-muted) !important;
  font-size: 0.78rem !important;
}

/* ── BUTTONS ───────────────────────────────────────────────────────── */
.btn-primary,
#submit-btn,
.auth-submit-btn,
.add-person-submit,
.cs-chart-submit {
  background: linear-gradient(135deg, #7c3aed 0%, #a855f7 100%) !important;
  color: white !important;
  font-family: var(--font-display) !important;
  font-weight: 700 !important;
  font-size: 1rem !important;
  padding: 14px 32px !important;
  border: none !important;
  border-radius: var(--r-full) !important;
  cursor: pointer !important;
  transition: all 0.3s cubic-bezier(0.2,0.9,0.2,1) !important;
  box-shadow: 0 4px 20px rgba(124,58,237,0.35) !important;
  position: relative !important;
  overflow: hidden !important;
  width: 100% !important;
  letter-spacing: 0.02em !important;
}

.btn-primary:hover,
#submit-btn:hover,
.auth-submit-btn:hover {
  transform: translateY(-2px) !important;
  box-shadow: 0 8px 32px rgba(124,58,237,0.5) !important;
}

.btn-primary:active,
#submit-btn:active {
  transform: translateY(0) !important;
}

.btn-primary::after {
  display: none !important;
}

.btn-ghost,
#restart-btn {
  background: transparent !important;
  border: 1px solid rgba(124,58,237,0.3) !important;
  color: var(--text-accent) !important;
  border-radius: var(--r-full) !important;
  padding: 12px 28px !important;
  font-weight: 600 !important;
  cursor: pointer !important;
  transition: all 0.2s ease !important;
}

.btn-ghost:hover,
#restart-btn:hover {
  background: rgba(124,58,237,0.1) !important;
  border-color: rgba(124,58,237,0.5) !important;
}

/* ── RESULTS CARD ──────────────────────────────────────────────────── */
.card--results,
#card-results {
  background: var(--bg-card) !important;
  backdrop-filter: blur(20px) !important;
  border: 1px solid rgba(124,58,237,0.18) !important;
  border-radius: var(--r-lg) !important;
  box-shadow: var(--glass-shadow) !important;
}

.results-header {
  text-align: center !important;
  padding: 28px 24px 20px !important;
}

.results-greeting,
#results-greeting {
  font-family: var(--font-display) !important;
  font-size: 1.1rem !important;
  color: var(--text-secondary) !important;
}

.py-number,
#py-number {
  font-family: var(--font-display) !important;
  font-size: 4rem !important;
  font-weight: 800 !important;
  background: linear-gradient(135deg, #f59e0b, #fbbf24) !important;
  -webkit-background-clip: text !important;
  -webkit-text-fill-color: transparent !important;
  line-height: 1 !important;
}

.halo-wrap,
#halo-wrap {
  position: relative !important;
  margin: 20px auto !important;
}

.halo-ring {
  border-color: rgba(124,58,237,0.3) !important;
}

.halo-glow {
  background: radial-gradient(circle, rgba(245,158,11,0.15), transparent 70%) !important;
}

.py-label,
#py-label {
  font-size: 0.85rem !important;
  color: var(--text-secondary) !important;
  font-weight: 500 !important;
}

.results-body,
#results-body {
  padding: 0 24px 24px !important;
  color: var(--text-secondary) !important;
  line-height: 1.7 !important;
  font-size: 0.92rem !important;
}

/* ── TYPEWRITER ────────────────────────────────────────────────────── */
.typewriter-container,
#typewriter-container {
  min-height: 120px !important;
}

.typewriter-text,
#typewriter-text {
  color: var(--text-secondary) !important;
  font-size: 0.92rem !important;
  line-height: 1.8 !important;
}

.cursor,
#tw-cursor {
  color: var(--accent) !important;
}

/* ── LOADING CARD ──────────────────────────────────────────────────── */
.card--loading {
  background: var(--bg-card) !important;
  backdrop-filter: blur(20px) !important;
  border: 1px solid rgba(124,58,237,0.18) !important;
  border-radius: var(--r-lg) !important;
}

.spinner-ring {
  border-color: rgba(124,58,237,0.15) !important;
  border-top-color: var(--accent) !important;
}

.loading-status {
  color: var(--text-secondary) !important;
}

/* ── MONTHLY ACCORDION ─────────────────────────────────────────────── */
.monthly-accordion {
  margin-top: 16px !important;
}

.monthly-accordion__header,
.monthly-accordion-header {
  background: rgba(124,58,237,0.08) !important;
  border: 1px solid rgba(124,58,237,0.15) !important;
  border-radius: var(--r-md) !important;
  padding: 14px 18px !important;
  color: var(--text-primary) !important;
  font-weight: 600 !important;
  cursor: pointer !important;
  transition: all 0.2s ease !important;
}

.monthly-accordion__header:hover {
  background: rgba(124,58,237,0.14) !important;
}

.monthly-accordion__body,
.monthly-accordion-content {
  padding: 16px 18px !important;
  color: var(--text-secondary) !important;
  line-height: 1.7 !important;
  font-size: 0.9rem !important;
}

/* ── BOTTOM NAVIGATION ─────────────────────────────────────────────── */
#bottom-nav {
  background: rgba(8, 8, 28, 0.92) !important;
  backdrop-filter: blur(24px) saturate(1.5) !important;
  border-top: 1px solid rgba(124,58,237,0.12) !important;
  padding: 8px 0 env(safe-area-inset-bottom, 8px) !important;
  position: fixed !important;
  bottom: 0 !important;
  left: 0 !important;
  right: 0 !important;
  z-index: 1000 !important;
  display: flex !important;
  align-items: center !important;
  justify-content: space-around !important;
}

.nav-tab-btn,
.nav-tab-btn.active {
  background: none !important;
  border: none !important;
  display: flex !important;
  flex-direction: column !important;
  align-items: center !important;
  gap: 4px !important;
  padding: 6px 16px !important;
  cursor: pointer !important;
  transition: all 0.2s ease !important;
  position: relative !important;
  -webkit-tap-highlight-color: transparent !important;
}

.nav-tab-btn .tab-icon {
  font-size: 1.3rem !important;
  transition: transform 0.2s ease !important;
}

.nav-tab-btn .tab-label {
  font-size: 0.65rem !important;
  font-weight: 500 !important;
  color: var(--text-muted) !important;
  text-transform: uppercase !important;
  letter-spacing: 0.06em !important;
  transition: color 0.2s ease !important;
}

.nav-tab-btn.active .tab-label {
  color: var(--accent) !important;
}

.nav-tab-btn.active::after {
  content: '' !important;
  position: absolute !important;
  top: -8px !important;
  left: 50% !important;
  transform: translateX(-50%) !important;
  width: 24px !important;
  height: 3px !important;
  background: linear-gradient(90deg, #7c3aed, #a855f7) !important;
  border-radius: 2px !important;
}

/* Center + button */
#add-person-nav-btn {
  width: 52px !important;
  height: 52px !important;
  border-radius: 50% !important;
  background: linear-gradient(135deg, #7c3aed, #a855f7) !important;
  border: 2px solid rgba(255,255,255,0.1) !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  box-shadow: 0 4px 24px rgba(124,58,237,0.4) !important;
  cursor: pointer !important;
  transition: all 0.3s cubic-bezier(0.2,0.9,0.2,1) !important;
  margin-top: -20px !important;
  color: white !important;
}

#add-person-nav-btn:hover {
  transform: scale(1.08) !important;
  box-shadow: 0 8px 32px rgba(124,58,237,0.55) !important;
}

#add-person-nav-btn svg {
  width: 22px !important;
  height: 22px !important;
}

/* ── PROFILES TAB ──────────────────────────────────────────────────── */
#profiles-panel {
  padding: 20px 16px 100px !important;
  min-height: 80vh !important;
}

#profiles-panel-content {
  min-height: 200px !important;
}

/* Profile header card */
.profiles-user-card,
.profile-owner-card {
  background: var(--bg-card) !important;
  border: 1px solid rgba(124,58,237,0.15) !important;
  border-radius: var(--r-lg) !important;
  padding: 24px !important;
  text-align: center !important;
  margin-bottom: 24px !important;
  position: relative !important;
  overflow: hidden !important;
}

.profiles-user-card::before,
.profile-owner-card::before {
  content: '' !important;
  position: absolute !important;
  top: 0 !important; left: 0 !important; right: 0 !important;
  height: 80px !important;
  background: linear-gradient(135deg, rgba(124,58,237,0.2), rgba(56,189,248,0.1)) !important;
  border-radius: var(--r-lg) var(--r-lg) 0 0 !important;
}

/* Saved profiles list */
.profiles-grid,
.saved-profiles-list {
  display: grid !important;
  grid-template-columns: repeat(auto-fill, minmax(160px, 1fr)) !important;
  gap: 12px !important;
}

.saved-profile-card,
.profile-card-mini {
  background: var(--bg-card) !important;
  border: 1px solid rgba(124,58,237,0.12) !important;
  border-radius: var(--r-md) !important;
  padding: 16px !important;
  text-align: center !important;
  cursor: pointer !important;
  transition: all 0.25s ease !important;
}

.saved-profile-card:hover,
.profile-card-mini:hover {
  border-color: rgba(124,58,237,0.3) !important;
  transform: translateY(-2px) !important;
  box-shadow: var(--card-glow) !important;
}

.saved-profile-card .profile-avatar,
.profile-card-mini .profile-avatar {
  width: 48px !important;
  height: 48px !important;
  border-radius: 50% !important;
  background: linear-gradient(135deg, #7c3aed, #38bdf8) !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  font-size: 1.2rem !important;
  font-weight: 700 !important;
  color: white !important;
  margin: 0 auto 10px !important;
}

.saved-profile-card .profile-name,
.profile-card-mini .profile-name {
  font-weight: 600 !important;
  font-size: 0.88rem !important;
  color: var(--text-primary) !important;
}

.saved-profile-card .profile-dob,
.profile-card-mini .profile-dob {
  font-size: 0.75rem !important;
  color: var(--text-muted) !important;
  margin-top: 2px !important;
}

/* Empty state */
.profiles-empty,
.profiles-empty-state {
  text-align: center !important;
  padding: 48px 24px !important;
  color: var(--text-muted) !important;
}

.profiles-empty-icon {
  font-size: 3rem !important;
  margin-bottom: 16px !important;
  opacity: 0.4 !important;
}

.profiles-empty-title {
  font-family: var(--font-display) !important;
  font-size: 1.1rem !important;
  font-weight: 600 !important;
  color: var(--text-secondary) !important;
  margin-bottom: 8px !important;
}

.profiles-empty-sub {
  font-size: 0.85rem !important;
  color: var(--text-muted) !important;
  max-width: 260px !important;
  margin: 0 auto 20px !important;
  line-height: 1.5 !important;
}

.profiles-empty-btn {
  background: linear-gradient(135deg, #7c3aed, #a855f7) !important;
  color: white !important;
  border: none !important;
  border-radius: var(--r-full) !important;
  padding: 12px 28px !important;
  font-weight: 600 !important;
  cursor: pointer !important;
  font-size: 0.9rem !important;
}

/* ── PROFILE DETAIL PANEL ──────────────────────────────────────────── */
#profile-detail-panel {
  background: var(--bg-deep) !important;
  background-image:
    radial-gradient(ellipse 80% 50% at 50% 0%, rgba(124,58,237,0.1) 0%, transparent 60%) !important;
}

.profile-detail-name,
#pd-name {
  font-family: var(--font-display) !important;
  font-size: 1.5rem !important;
  font-weight: 700 !important;
  color: var(--text-primary) !important;
}

.profile-detail-dob,
#pd-dob {
  color: var(--text-secondary) !important;
  font-size: 0.85rem !important;
}

.profile-detail-avatar-lg,
#pd-avatar {
  width: 64px !important;
  height: 64px !important;
  border-radius: 50% !important;
  background: linear-gradient(135deg, #7c3aed, #a855f7) !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  font-size: 1.6rem !important;
  font-weight: 700 !important;
  color: white !important;
  box-shadow: 0 4px 24px rgba(124,58,237,0.3) !important;
}

.profile-detail-py-num,
#pd-py-num {
  font-family: var(--font-display) !important;
  font-size: 2.5rem !important;
  font-weight: 800 !important;
  background: linear-gradient(135deg, #f59e0b, #fbbf24) !important;
  -webkit-background-clip: text !important;
  -webkit-text-fill-color: transparent !important;
}

.section-tabs,
#pd-section-tabs {
  display: flex !important;
  overflow-x: auto !important;
  gap: 6px !important;
  padding: 0 16px 12px !important;
  -webkit-overflow-scrolling: touch !important;
  scrollbar-width: none !important;
}

.section-tabs::-webkit-scrollbar {
  display: none !important;
}

.section-tab-btn {
  background: rgba(124,58,237,0.08) !important;
  border: 1px solid rgba(124,58,237,0.15) !important;
  border-radius: var(--r-full) !important;
  padding: 8px 18px !important;
  font-size: 0.8rem !important;
  font-weight: 500 !important;
  color: var(--text-secondary) !important;
  white-space: nowrap !important;
  cursor: pointer !important;
  transition: all 0.2s ease !important;
}

.section-tab-btn.active,
.section-tab-btn--active {
  background: linear-gradient(135deg, #7c3aed, #a855f7) !important;
  border-color: transparent !important;
  color: white !important;
}

.section-content-area,
#pd-section-content {
  padding: 16px !important;
}

/* ── FORENSICS TAB ─────────────────────────────────────────────────── */
#forensics-panel {
  padding: 20px 16px 100px !important;
}

.cs-panel-inner {
  background: var(--bg-card) !important;
  border: 1px solid rgba(124,58,237,0.15) !important;
  border-radius: var(--r-lg) !important;
  padding: 24px !important;
}

#cs-chart-headline {
  font-family: var(--font-display) !important;
  font-size: 1.3rem !important;
  font-weight: 700 !important;
  color: var(--text-primary) !important;
}

#cs-mode-toggle {
  display: flex !important;
  gap: 8px !important;
  margin: 16px 0 !important;
}

.cs-mode-btn {
  flex: 1 !important;
  background: rgba(124,58,237,0.06) !important;
  border: 1px solid rgba(124,58,237,0.15) !important;
  border-radius: var(--r-md) !important;
  padding: 12px 16px !important;
  color: var(--text-secondary) !important;
  font-size: 0.85rem !important;
  font-weight: 500 !important;
  cursor: pointer !important;
  transition: all 0.2s ease !important;
  text-align: center !important;
}

.cs-mode-btn--active,
.cs-mode-btn.active {
  background: rgba(124,58,237,0.15) !important;
  border-color: rgba(124,58,237,0.4) !important;
  color: var(--text-primary) !important;
}

.cs-chart-form label {
  font-size: 0.72rem !important;
  font-weight: 600 !important;
  text-transform: uppercase !important;
  letter-spacing: 0.08em !important;
  color: var(--text-muted) !important;
}

.cs-chart-submit,
#cs-chart-btn {
  background: linear-gradient(135deg, #f59e0b, #fbbf24) !important;
  color: #0c0c24 !important;
  border: none !important;
  border-radius: var(--r-full) !important;
  padding: 14px 32px !important;
  font-weight: 700 !important;
  font-size: 0.95rem !important;
  cursor: pointer !important;
  box-shadow: 0 4px 20px rgba(245,158,11,0.25) !important;
  transition: all 0.3s ease !important;
  width: 100% !important;
}

.cs-chart-submit:hover,
#cs-chart-btn:hover {
  transform: translateY(-2px) !important;
  box-shadow: 0 8px 28px rgba(245,158,11,0.35) !important;
}

/* Chart result styling */
#cr-chart-result {
  margin-top: 24px !important;
}

#cr-chart-result table {
  border-collapse: separate !important;
  border-spacing: 0 !important;
  width: 100% !important;
  border-radius: var(--r-md) !important;
  overflow: hidden !important;
}

#cr-chart-result th {
  background: rgba(124,58,237,0.12) !important;
  color: var(--text-primary) !important;
  font-size: 0.75rem !important;
  font-weight: 600 !important;
  text-transform: uppercase !important;
  letter-spacing: 0.05em !important;
  padding: 10px 12px !important;
}

#cr-chart-result td {
  background: rgba(14,14,42,0.4) !important;
  color: var(--text-secondary) !important;
  font-size: 0.85rem !important;
  padding: 8px 12px !important;
  border-bottom: 1px solid rgba(124,58,237,0.08) !important;
}

/* ── DAY CALENDAR TAB ──────────────────────────────────────────────── */
#daycal-panel {
  padding: 20px 16px 100px !important;
}

.daycal-header {
  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;
  margin-bottom: 16px !important;
}

.daycal-header button {
  background: rgba(124,58,237,0.1) !important;
  border: 1px solid rgba(124,58,237,0.2) !important;
  border-radius: var(--r-sm) !important;
  color: var(--text-primary) !important;
  padding: 8px 12px !important;
  cursor: pointer !important;
}

.daycal-month-name {
  font-family: var(--font-display) !important;
  font-size: 1.3rem !important;
  font-weight: 700 !important;
  color: var(--text-primary) !important;
}

.daycal-month-picker {
  display: flex !important;
  flex-wrap: wrap !important;
  gap: 6px !important;
  margin-bottom: 16px !important;
}

.daycal-month-picker button,
.daycal-month-btn {
  background: rgba(124,58,237,0.06) !important;
  border: 1px solid rgba(124,58,237,0.12) !important;
  border-radius: var(--r-full) !important;
  padding: 6px 14px !important;
  font-size: 0.78rem !important;
  font-weight: 500 !important;
  color: var(--text-secondary) !important;
  cursor: pointer !important;
  transition: all 0.2s ease !important;
}

.daycal-month-picker button.active,
.daycal-month-btn.active {
  background: rgba(124,58,237,0.2) !important;
  border-color: var(--accent) !important;
  color: var(--text-primary) !important;
}

.daycal-calendar-area {
  min-height: 300px !important;
}

.daycal-grid,
.calendar-grid {
  display: grid !important;
  grid-template-columns: repeat(7, 1fr) !important;
  gap: 4px !important;
}

.daycal-day,
.calendar-day {
  background: var(--bg-card) !important;
  border: 1px solid rgba(124,58,237,0.08) !important;
  border-radius: var(--r-sm) !important;
  padding: 10px 4px !important;
  text-align: center !important;
  font-size: 0.85rem !important;
  color: var(--text-primary) !important;
  cursor: pointer !important;
  transition: all 0.2s ease !important;
  aspect-ratio: 1 !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
}

.daycal-day:hover {
  background: rgba(124,58,237,0.12) !important;
  border-color: rgba(124,58,237,0.3) !important;
}

.daycal-day.today,
.calendar-day.today {
  border-color: var(--accent) !important;
  background: rgba(124,58,237,0.15) !important;
  font-weight: 700 !important;
}

.daycal-day-header {
  font-size: 0.7rem !important;
  font-weight: 600 !important;
  color: var(--text-muted) !important;
  text-transform: uppercase !important;
}

/* CTA to go home */
.daycal-empty-cta,
button[onclick*="goHomeTab"] {
  display: block !important;
  background: rgba(124,58,237,0.08) !important;
  border: 1px solid rgba(124,58,237,0.2) !important;
  border-radius: var(--r-full) !important;
  padding: 12px 24px !important;
  color: var(--text-accent) !important;
  font-weight: 600 !important;
  cursor: pointer !important;
  margin: 20px auto !important;
  font-size: 0.9rem !important;
}

/* ── AUTH OVERLAY ───────────────────────────────────────────────────── */
#auth-overlay,
[id="auth-overlay"] {
  background: rgba(5,5,16,0.95) !important;
  backdrop-filter: blur(24px) !important;
}

.auth-sheet,
.auth-panel {
  background: var(--bg-card) !important;
  border: 1px solid rgba(124,58,237,0.18) !important;
  border-radius: var(--r-lg) var(--r-lg) 0 0 !important;
  max-width: 420px !important;
  margin: 0 auto !important;
  padding: 32px 24px !important;
}

.auth-title,
#auth-title {
  font-family: var(--font-display) !important;
  font-size: 1.4rem !important;
  font-weight: 700 !important;
  color: var(--text-primary) !important;
  text-align: center !important;
  margin-bottom: 8px !important;
}

.auth-tabs {
  display: flex !important;
  gap: 4px !important;
  background: rgba(124,58,237,0.06) !important;
  border-radius: var(--r-full) !important;
  padding: 4px !important;
  margin: 16px 0 20px !important;
}

.auth-tab {
  flex: 1 !important;
  background: transparent !important;
  border: none !important;
  border-radius: var(--r-full) !important;
  padding: 10px 16px !important;
  font-size: 0.88rem !important;
  font-weight: 500 !important;
  color: var(--text-muted) !important;
  cursor: pointer !important;
  transition: all 0.2s ease !important;
}

.auth-tab.active {
  background: linear-gradient(135deg, #7c3aed, #a855f7) !important;
  color: white !important;
}

.auth-error,
#auth-error {
  background: rgba(244,63,94,0.08) !important;
  border: 1px solid rgba(244,63,94,0.2) !important;
  border-radius: var(--r-sm) !important;
  padding: 10px 14px !important;
  color: var(--rose) !important;
  font-size: 0.85rem !important;
  margin-bottom: 12px !important;
}

.auth-success,
#auth-success {
  background: rgba(16,185,129,0.08) !important;
  border: 1px solid rgba(16,185,129,0.2) !important;
  border-radius: var(--r-sm) !important;
  padding: 10px 14px !important;
  color: var(--emerald) !important;
  font-size: 0.85rem !important;
  margin-bottom: 12px !important;
}

/* ── SAVE PROMPT MODAL ─────────────────────────────────────────────── */
.save-prompt-overlay,
#save-prompt-overlay {
  background: rgba(5,5,16,0.85) !important;
  backdrop-filter: blur(12px) !important;
}

.save-prompt-modal {
  background: var(--bg-surface) !important;
  border: 1px solid rgba(124,58,237,0.2) !important;
  border-radius: var(--r-lg) !important;
  padding: 28px 24px !important;
  max-width: 360px !important;
  margin: 0 auto !important;
  text-align: center !important;
}

.save-prompt-modal h2 {
  font-family: var(--font-display) !important;
  color: var(--text-primary) !important;
  font-size: 1.15rem !important;
  font-weight: 700 !important;
}

.save-prompt-sub {
  color: var(--text-secondary) !important;
  font-size: 0.9rem !important;
  margin: 8px 0 16px !important;
}

/* ── ACCOUNT SHEET ─────────────────────────────────────────────────── */
#account-sheet-overlay {
  background: rgba(5,5,16,0.9) !important;
  backdrop-filter: blur(16px) !important;
}

.account-sheet {
  background: var(--bg-surface) !important;
  border: 1px solid rgba(124,58,237,0.18) !important;
  border-radius: var(--r-lg) var(--r-lg) 0 0 !important;
  padding: 32px 24px !important;
}

.account-sheet-avatar,
#as-avatar {
  width: 56px !important;
  height: 56px !important;
  border-radius: 50% !important;
  background: linear-gradient(135deg, #7c3aed, #a855f7) !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  font-size: 1.4rem !important;
  font-weight: 700 !important;
  color: white !important;
  margin: 0 auto 12px !important;
}

.account-sheet-name,
#as-name {
  font-family: var(--font-display) !important;
  font-weight: 600 !important;
  font-size: 1.1rem !important;
  color: var(--text-primary) !important;
  text-align: center !important;
}

.account-sheet-email,
#as-email {
  color: var(--text-muted) !important;
  font-size: 0.85rem !important;
  text-align: center !important;
}

/* ── ADD PERSON OVERLAY ────────────────────────────────────────────── */
#add-person-overlay {
  background: rgba(5,5,16,0.9) !important;
  backdrop-filter: blur(16px) !important;
}

.add-person-modal,
#add-person-overlay > div {
  background: var(--bg-surface) !important;
  border: 1px solid rgba(124,58,237,0.18) !important;
  border-radius: var(--r-lg) !important;
  padding: 28px 24px !important;
  max-width: 400px !important;
  margin: 0 auto !important;
}

.add-person-submit,
#ap-submit-btn {
  background: linear-gradient(135deg, #7c3aed, #a855f7) !important;
  color: white !important;
}

/* ── RESULTS CHOICE OVERLAY ────────────────────────────────────────── */
#results-choice-overlay {
  background: rgba(5,5,16,0.9) !important;
  backdrop-filter: blur(16px) !important;
}

.results-choice-card,
#results-choice-overlay > div > div {
  background: var(--bg-surface) !important;
  border: 1px solid rgba(124,58,237,0.18) !important;
  border-radius: var(--r-lg) !important;
}

.results-choice-avatar,
#rc-name-initial {
  background: linear-gradient(135deg, #7c3aed, #a855f7) !important;
  border-radius: 50% !important;
  width: 48px !important;
  height: 48px !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  font-size: 1.3rem !important;
  color: white !important;
}

.results-choice-btn,
#results-choice-overlay button {
  background: var(--bg-card) !important;
  border: 1px solid rgba(124,58,237,0.15) !important;
  border-radius: var(--r-md) !important;
  padding: 14px 18px !important;
  color: var(--text-primary) !important;
  cursor: pointer !important;
  transition: all 0.2s ease !important;
  text-align: left !important;
  width: 100% !important;
}

.results-choice-btn:hover,
#results-choice-overlay button:hover {
  background: var(--bg-card-hover) !important;
  border-color: rgba(124,58,237,0.3) !important;
}

/* ── TOAST NOTIFICATIONS ───────────────────────────────────────────── */
#toast-container {
  position: fixed !important;
  top: 16px !important;
  right: 16px !important;
  z-index: 10000 !important;
  display: flex !important;
  flex-direction: column !important;
  gap: 8px !important;
}

.toast {
  background: var(--bg-surface) !important;
  border: 1px solid rgba(124,58,237,0.2) !important;
  border-radius: var(--r-md) !important;
  padding: 12px 20px !important;
  font-size: 0.88rem !important;
  color: var(--text-primary) !important;
  box-shadow: 0 8px 32px rgba(0,0,0,0.4) !important;
  animation: toastIn 0.3s ease-out !important;
}

.toast-success {
  border-left: 3px solid var(--emerald) !important;
}

.toast-error {
  border-left: 3px solid var(--rose) !important;
}

@keyframes toastIn {
  from { opacity: 0; transform: translateY(-12px); }
  to   { opacity: 1; transform: translateY(0); }
}

/* ── GUEST EMAIL MODAL ─────────────────────────────────────────────── */
#guest-email-overlay {
  position: fixed !important;
  inset: 0 !important;
  background: rgba(5,5,16,0.9) !important;
  backdrop-filter: blur(16px) !important;
  z-index: 5000 !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  padding: 20px !important;
}

.guest-email-modal {
  background: var(--bg-surface) !important;
  border: 1px solid rgba(124,58,237,0.2) !important;
  border-radius: var(--r-lg) !important;
  padding: 32px 24px !important;
  max-width: 380px !important;
  width: 100% !important;
  text-align: center !important;
}

.guest-email-modal h2 {
  font-family: var(--font-display) !important;
  font-size: 1.3rem !important;
  font-weight: 700 !important;
  color: var(--text-primary) !important;
  margin-bottom: 8px !important;
}

.guest-email-modal p {
  color: var(--text-secondary) !important;
  font-size: 0.9rem !important;
  margin-bottom: 20px !important;
  line-height: 1.5 !important;
}

.guest-email-modal input[type="email"] {
  background: rgba(255,255,255,0.04) !important;
  border: 1px solid rgba(124,58,237,0.2) !important;
  border-radius: var(--r-sm) !important;
  padding: 14px 16px !important;
  font-size: 1rem !important;
  color: var(--text-primary) !important;
  width: 100% !important;
  margin-bottom: 14px !important;
  outline: none !important;
}

.guest-email-modal input[type="email"]:focus {
  border-color: var(--accent) !important;
  box-shadow: 0 0 0 3px rgba(124,58,237,0.12) !important;
}

.guest-email-modal .btn-primary {
  margin-bottom: 10px !important;
}

.guest-email-modal .btn-ghost {
  font-size: 0.85rem !important;
  width: auto !important;
}

/* ── SCROLLBAR STYLING ─────────────────────────────────────────────── */
::-webkit-scrollbar {
  width: 6px;
}

::-webkit-scrollbar-track {
  background: transparent;
}

::-webkit-scrollbar-thumb {
  background: rgba(124,58,237,0.2);
  border-radius: 3px;
}

::-webkit-scrollbar-thumb:hover {
  background: rgba(124,58,237,0.35);
}

/* ── RESPONSIVE ────────────────────────────────────────────────────── */
@media (min-width: 768px) {
  .home-explore-grid,
  #home-explore-grid {
    grid-template-columns: repeat(3, 1fr) !important;
    max-width: 700px !important;
    margin: 0 auto !important;
  }

  .card,
  #card-form,
  .card--results {
    max-width: 500px !important;
    margin-left: auto !important;
    margin-right: auto !important;
  }

  .hero-h1 {
    font-size: 2.8rem !important;
  }
}

@media (min-width: 1024px) {
  .home-explore-grid,
  #home-explore-grid {
    grid-template-columns: repeat(4, 1fr) !important;
    max-width: 900px !important;
  }
}

/* ── ANIMATIONS ────────────────────────────────────────────────────── */
@keyframes fadeInUp {
  from { opacity: 0; transform: translateY(16px); }
  to   { opacity: 1; transform: translateY(0); }
}

.card,
.home-explore-card {
  animation: fadeInUp 0.5s ease-out !important;
}

/* Stagger card animations */
.home-explore-grid > div:nth-child(1) { animation-delay: 0ms !important; }
.home-explore-grid > div:nth-child(2) { animation-delay: 60ms !important; }
.home-explore-grid > div:nth-child(3) { animation-delay: 120ms !important; }
.home-explore-grid > div:nth-child(4) { animation-delay: 180ms !important; }
.home-explore-grid > div:nth-child(5) { animation-delay: 240ms !important; }
.home-explore-grid > div:nth-child(6) { animation-delay: 300ms !important; }
.home-explore-grid > div:nth-child(7) { animation-delay: 360ms !important; }
.home-explore-grid > div:nth-child(8) { animation-delay: 420ms !important; }

/* Tab panel transitions */
.tab-panel {
  animation: fadeInUp 0.3s ease-out !important;
}

/* ── AI PROFILE PICKER ─────────────────────────────────────────────── */
#ai-profile-picker-overlay {
  background: rgba(5,5,16,0.9) !important;
  backdrop-filter: blur(16px) !important;
}

.ai-profile-picker-search,
#ai-profile-picker-search {
  background: rgba(255,255,255,0.04) !important;
  border: 1px solid rgba(124,58,237,0.2) !important;
  border-radius: var(--r-full) !important;
  padding: 12px 18px !important;
  color: var(--text-primary) !important;
  font-size: 0.9rem !important;
}

.ai-profile-picker-list,
#ai-profile-picker-list {
  max-height: 300px !important;
  overflow-y: auto !important;
}

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

.sr-only {
  position: absolute !important;
  width: 1px !important; height: 1px !important;
  padding: 0 !important; margin: -1px !important;
  overflow: hidden !important;
  clip: rect(0,0,0,0) !important;
  white-space: nowrap !important;
  border: 0 !important;
}

/* ── SIDEBAR (unused but styled just in case) ──────────────────────── */
.sidebar,
#sidebar {
  background: var(--bg-surface) !important;
  border-right: 1px solid rgba(124,58,237,0.15) !important;
}

.sidebar-overlay,
#sidebar-overlay {
  background: rgba(5,5,16,0.8) !important;
}

/* ── BACK TO HOME BUTTON ───────────────────────────────────────────── */
button[onclick*="goHomeTab"],
.back-home-btn {
  background: rgba(124,58,237,0.08) !important;
  border: 1px solid rgba(124,58,237,0.15) !important;
  border-radius: var(--r-full) !important;
  padding: 8px 18px !important;
  color: var(--text-accent) !important;
  font-size: 0.85rem !important;
  font-weight: 500 !important;
  cursor: pointer !important;
  margin-bottom: 16px !important;
  display: inline-flex !important;
  align-items: center !important;
  gap: 6px !important;
}

/* ── CHART TABLE IMPROVEMENTS ──────────────────────────────────────── */
table {
  width: 100% !important;
  border-collapse: separate !important;
  border-spacing: 0 2px !important;
}

th {
  background: rgba(124,58,237,0.1) !important;
  color: var(--text-primary) !important;
  font-size: 0.72rem !important;
  font-weight: 600 !important;
  text-transform: uppercase !important;
  letter-spacing: 0.05em !important;
  padding: 8px 10px !important;
  text-align: left !important;
}

td {
  background: rgba(14,14,42,0.3) !important;
  color: var(--text-secondary) !important;
  font-size: 0.82rem !important;
  padding: 7px 10px !important;
}

tr:hover td {
  background: rgba(124,58,237,0.06) !important;
}

/* ── ASK MY READING FAB ────────────────────────────────────────────── */
.fab-reading,
[class*="ask-reading"],
button[class*="reading-fab"] {
  background: linear-gradient(135deg, #7c3aed, #a855f7) !important;
  border: none !important;
  border-radius: var(--r-full) !important;
  padding: 14px 24px !important;
  color: white !important;
  font-weight: 600 !important;
  box-shadow: 0 4px 24px rgba(124,58,237,0.4) !important;
  cursor: pointer !important;
  font-size: 0.9rem !important;
}

/* ── PRINT STYLES ──────────────────────────────────────────────────── */
@media print {
  body { background: white !important; color: black !important; }
  #bottom-nav { display: none !important; }
  .card { border: 1px solid #ddd !important; box-shadow: none !important; }
}

/* ── PROFILE CARDS (rendered by renderProfilesPanel) ───────────────── */
.profiles-header-bar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 8px 0 20px;
}

.profiles-title {
  font-family: var(--font-display);
  font-size: 1.4rem;
  font-weight: 700;
  color: var(--text-primary);
}

.profiles-count {
  font-size: 0.8rem;
  font-weight: 500;
  color: var(--text-muted);
  background: rgba(124,58,237,0.08);
  padding: 4px 12px;
  border-radius: var(--r-full);
  border: 1px solid rgba(124,58,237,0.12);
}

.profiles-grid {
  display: flex;
  flex-direction: column;
  gap: 10px;
}

.profile-card {
  display: flex;
  align-items: center;
  gap: 14px;
  background: var(--bg-card);
  border: 1px solid rgba(124,58,237,0.12);
  border-radius: var(--r-md);
  padding: 16px;
  cursor: pointer;
  transition: all 0.25s ease;
}

.profile-card:hover {
  border-color: rgba(124,58,237,0.3);
  background: var(--bg-card-hover);
  transform: translateX(4px);
}

.profile-card-avatar {
  width: 44px;
  height: 44px;
  border-radius: 50%;
  background: linear-gradient(135deg, #7c3aed, #38bdf8);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.1rem;
  font-weight: 700;
  color: white;
  flex-shrink: 0;
}

.profile-card-info {
  flex: 1;
  min-width: 0;
}

.profile-card-name {
  font-weight: 600;
  font-size: 0.95rem;
  color: var(--text-primary);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.profile-card-meta {
  font-size: 0.78rem;
  color: var(--text-muted);
  margin-top: 2px;
}

.profile-card-right {
  display: flex;
  align-items: center;
  gap: 10px;
  flex-shrink: 0;
}

.profile-card-py {
  font-family: var(--font-display);
  font-weight: 700;
  font-size: 0.88rem;
  color: var(--gold);
  background: var(--gold-soft);
  padding: 4px 10px;
  border-radius: var(--r-full);
  border: 1px solid rgba(245,158,11,0.15);
}

.profile-card-delete-btn {
  background: none;
  border: none;
  color: var(--text-muted);
  font-size: 0.9rem;
  cursor: pointer;
  padding: 4px 8px;
  border-radius: 50%;
  transition: all 0.2s ease;
  opacity: 0.5;
}

.profile-card-delete-btn:hover {
  opacity: 1;
  color: var(--rose);
  background: rgba(244,63,94,0.1);
}

/* ── PANEL TOPBAR ──────────────────────────────────────────────────── */
.panel-topbar {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 4px 0 16px;
}

.panel-topbar--split {
  justify-content: space-between;
}

.panel-back-btn {
  background: rgba(124,58,237,0.08);
  border: 1px solid rgba(124,58,237,0.15);
  border-radius: var(--r-sm);
  color: var(--text-accent);
  width: 36px;
  height: 36px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.3rem;
  cursor: pointer;
  flex-shrink: 0;
}

.panel-topbar-title {
  font-family: var(--font-display);
  font-weight: 700;
  font-size: 1.15rem;
  color: var(--text-primary);
}

.panel-topbar-sub {
  font-size: 0.8rem;
  color: var(--text-muted);
  margin-top: 2px;
}

.panel-topbar-meta {
  font-size: 0.78rem;
  color: var(--text-muted);
  background: rgba(124,58,237,0.06);
  padding: 4px 10px;
  border-radius: var(--r-full);
}
