/* ============================================================
   GYM CREATOR — BENTO AUTHORITY DESIGN SYSTEM
   Premium dark dashboard · Bento grid · Glassmorphism · Tinted cards
   ============================================================ */

/* ─── TOKENS ─────────────────────────────────────────────── */
:root {
  /* Apple 3-tier background system (dark) */
  --bg-base:     #000000;
  --bg-surface:  #1C1C1E;
  --bg-elevated: #2C2C2E;
  --bg-hover:    rgba(255,255,255,.08);
  --bg-glass:    rgba(28,28,30,.85);

  /* Primary — Apple Blue */
  --primary:        #0A84FF;
  --primary-dim:    rgba(10,132,255,.12);
  --primary-glow:   rgba(10,132,255,.20);
  --primary-border: rgba(10,132,255,.30);

  /* Secondary — Apple Green */
  --secondary:        #30D158;
  --secondary-dim:    rgba(48,209,88,.12);
  --secondary-glow:   rgba(48,209,88,.20);
  --secondary-border: rgba(48,209,88,.30);

  /* Accent — Apple Indigo */
  --accent:        #5E5CE6;

  /* CTA — Apple Orange */
  --cta:        #FF9F0A;
  --cta-dim:    rgba(255,159,10,.12);
  --cta-border: rgba(255,159,10,.30);

  /* Apple label colors (dark mode) */
  --text-1: #FFFFFF;
  --text-2: rgba(235,235,245,.6);
  --text-3: rgba(235,235,245,.3);

  /* Apple separator/border (dark mode) */
  --border-xs: rgba(84,84,88,.3);
  --border-sm: rgba(84,84,88,.45);
  --border-md: rgba(84,84,88,.6);

  /* Apple system colors (dark mode) */
  --red:    #FF453A;
  --orange: #FF9F0A;
  --blue:   #0A84FF;
  --purple: #BF5AF2;
  --gold:   #FFD60A;
  --rose:   #FF375F;

  /* Type — Apple HIG: SF Pro stack via Inter */
  --font-display: -apple-system, BlinkMacSystemFont, 'Inter', 'SF Pro Display', 'Segoe UI', Roboto, Helvetica, Arial, sans-serif;
  --font-body:    -apple-system, BlinkMacSystemFont, 'Inter', 'SF Pro Text', 'Segoe UI', Roboto, Helvetica, Arial, sans-serif;
  --font-mono:    'SF Mono', 'DM Mono', ui-monospace, 'Cascadia Code', 'Fira Code', monospace;

  /* Apple spacing scale (base-4 / base-8) */
  --s1:  4px;   --s2:  8px;   --s3: 12px;
  --s4:  16px;  --s5:  20px;  --s6: 24px;
  --s7:  28px;  --s8:  32px;  --s10: 40px;
  --s12: 48px;  --s14: 56px;  --s16: 64px;
  --s20: 80px;

  /* Apple radius — continuous (squircle) corners */
  --r1: 6px;    --r2: 8px;    --r3: 12px;
  --r-sm: 8px;  --r-md: 12px;  --r-lg: 16px;
  --r-xl: 22px; --r-2xl: 28px; --r-full: 9999px;

  /* Sidebar */
  --sb-w: 240px;
  --sb-w-closed: 72px;
  --topbar-h: 64px;

  /* Aliases for legacy/component references */
  --bg-inset:   #1A1A1C;
  --bg-3:       #2C2C2E;
  --border:     rgba(84,84,88,.45);
  --green:      #30D158;
  --font-sans:  -apple-system, BlinkMacSystemFont, 'Inter', 'SF Pro Display', 'Segoe UI', Roboto, Helvetica, Arial, sans-serif;

  /* Apple dark surfaces — solid tiers */
  --card-bg:   #1C1C1E;
  --card-bg2:  #2C2C2E;
  --surface-2: #1C1C1E;
  --surface-3: #000000;
  --surface-4: #2C2C2E;

  /* Apple transitions — spring physics */
  --ease-fast:   120ms cubic-bezier(0.25, 1, 0.5, 1);
  --ease-base:   280ms cubic-bezier(0.32, 0.72, 0, 1);
  --ease-slow:   420ms cubic-bezier(0.32, 0.72, 0, 1);
  --ease-spring: 500ms cubic-bezier(0.32, 0.72, 0, 1);
  --ease-bounce: 600ms cubic-bezier(0.25, 1, 0.5, 1);

  /* Apple shadows — two-layer system */
  --shadow-sm: 0 1px 2px rgba(0,0,0,.12), 0 0 1px rgba(0,0,0,.08);
  --shadow-md: 0 4px 12px rgba(0,0,0,.15), 0 0 1px rgba(0,0,0,.1);
  --shadow-lg: 0 12px 40px rgba(0,0,0,.2), 0 0 1px rgba(0,0,0,.08);
  --shadow-xl: 0 24px 80px rgba(0,0,0,.3), 0 0 1px rgba(0,0,0,.1);
}

/* ── Card stagger entrance animation ── */
@keyframes cardStaggerIn {
  from { opacity: 0; transform: translateY(16px) scale(0.98); }
  to   { opacity: 1; transform: translateY(0) scale(1); }
}
.stagger-animate {
  animation: cardStaggerIn 400ms cubic-bezier(0.32,0.72,0,1) both;
}

*:focus-visible {
  outline: 2px solid var(--primary);
  outline-offset: 2px;
}

/* ═══════════════════════════════════════════════════════════
   LIGHT MODE — [data-theme="light"]
   ═══════════════════════════════════════════════════════════ */
[data-theme="light"] {
  /* Apple 3-tier background system (light) */
  --bg-base:     #F2F2F7;
  --bg-surface:  #FFFFFF;
  --bg-elevated: #FFFFFF;
  --bg-hover:    rgba(0,0,0,0.04);
  --bg-glass:    rgba(255,255,255,0.88);

  /* Apple Blue (light) */
  --primary:        #007AFF;
  --primary-dim:    rgba(0,122,255,0.10);
  --primary-glow:   rgba(0,122,255,0.15);
  --primary-border: rgba(0,122,255,0.25);

  /* Apple Green (light) */
  --secondary:        #34C759;
  --secondary-dim:    rgba(52,199,89,0.10);
  --secondary-glow:   rgba(52,199,89,0.15);
  --secondary-border: rgba(52,199,89,0.25);

  /* Apple Indigo (light) */
  --accent:     #5856D6;

  /* Apple Orange (light) */
  --cta:        #FF9500;
  --cta-dim:    rgba(255,149,0,0.10);
  --cta-border: rgba(255,149,0,0.25);

  /* Apple label colors (light mode) */
  --text-1: #000000;
  --text-2: rgba(60,60,67,0.6);
  --text-3: rgba(60,60,67,0.3);

  /* Apple separator/border (light mode) */
  --border-xs: rgba(60,60,67,0.12);
  --border-sm: rgba(60,60,67,0.18);
  --border-md: rgba(60,60,67,0.29);

  /* Apple system colors (light mode) */
  --red:    #FF3B30;
  --orange: #FF9500;
  --gold:   #FFCC00;
  --rose:   #FF2D55;

  /* Aliases (light) */
  --bg-inset:   #E8E8ED;
  --bg-3:       #F2F2F7;
  --border:     rgba(60,60,67,.18);
  --green:      #34C759;

  /* Surface tiers */
  --card-bg:   #FFFFFF;
  --card-bg2:  rgba(0,0,0,.03);
  --surface-2: #FFFFFF;
  --surface-3: #F2F2F7;
  --surface-4: rgba(0,0,0,.04);
}

/* Body */
[data-theme="light"] body { background: var(--bg-base); color: var(--text-1); }

/* Grain / Orbs / Custom cursor — all hidden */
[data-theme="light"] .grain { display: none; }
[data-theme="light"] .orb-1, [data-theme="light"] .orb-2, [data-theme="light"] .orb-3 { display: none; }
[data-theme="light"] .cursor-dot, [data-theme="light"] .cursor-ring { display: none !important; }

/* Apple light mode cards — subtle shadow, no border */
[data-theme="light"] .card {
  border: none;
  box-shadow: 0 1px 3px rgba(0,0,0,.08), 0 0 1px rgba(0,0,0,.04);
}
[data-theme="light"] .card:hover {
  box-shadow: 0 2px 8px rgba(0,0,0,.1), 0 0 1px rgba(0,0,0,.04);
}
[data-theme="light"] .metrics-strip,
[data-theme="light"] .wk-plan,
[data-theme="light"] .mission-min,
[data-theme="light"] .authority-profile,
[data-theme="light"] .activity-ticker {
  border: none;
  box-shadow: 0 1px 3px rgba(0,0,0,.08), 0 0 1px rgba(0,0,0,.04);
}
[data-theme="light"] .type-card,
[data-theme="light"] .template-card,
[data-theme="light"] .planner-day {
  border-color: rgba(0,0,0,.06);
  box-shadow: 0 1px 2px rgba(0,0,0,.06);
}
/* Apple light CTA / primary buttons — no shadow */
[data-theme="light"] .btn-primary,
[data-theme="light"] .btn-cta {
  box-shadow: none;
}
/* Apple light nav */
[data-theme="light"] .nav-item.active {
  background: var(--primary-dim);
}
/* Apple light gem/xp pills */
[data-theme="light"] .gems-pill,
[data-theme="light"] .xp-pill {
  background: rgba(0,0,0,.04);
}
[data-theme="light"] .gems-pill:hover,
[data-theme="light"] .xp-pill:hover {
  background: rgba(0,0,0,.07);
}
[data-theme="light"] #gemsCount {
  color: var(--text-2);
}
[data-theme="light"] .xp-level-badge {
  background: var(--primary);
}

/* Scrollbar */
[data-theme="light"] ::-webkit-scrollbar-thumb { background: rgba(0,0,0,0.15); }

/* Sidebar */
[data-theme="light"] .sidebar {
  background: rgba(255,255,255,0.82);
  backdrop-filter: blur(40px) saturate(180%);
  border-right: 0.5px solid rgba(0,0,0,0.06);
  box-shadow: none;
}
[data-theme="light"] .nav-item { color: var(--text-2); }
[data-theme="light"] .nav-item:hover {
  background: rgba(0,0,0,0.04);
  color: var(--text-1);
}
[data-theme="light"] .nav-item:active {
  background: rgba(0,0,0,0.08);
}
[data-theme="light"] .nav-item.active {
  background: rgba(82,84,204,.1);
  color: var(--primary);
}
[data-theme="light"] .plan-badge { background: rgba(82,84,204,0.14); color: var(--primary); }
[data-theme="light"] .plan-name  { color: var(--text-1); }
[data-theme="light"] .plan-credits { color: var(--text-2); }
[data-theme="light"] .sidebar-footer { border-top: 1px solid rgba(0,0,0,0.08); }
[data-theme="light"] .btn-upgrade { color: var(--text-2); border-color: rgba(0,0,0,0.1); }
[data-theme="light"] .btn-upgrade:hover { background: rgba(0,0,0,0.05); }
[data-theme="light"] .sb-toggle { background: rgba(0,0,0,0.05); border-color: rgba(0,0,0,0.08); color: var(--text-2); }

/* Topbar */
[data-theme="light"] .topbar {
  background: rgba(249,249,249,.94);
  backdrop-filter: blur(20px) saturate(180%);
  border-bottom: 0.5px solid rgba(60,60,67,.29);
}
[data-theme="light"] .topbar::after { display: none; }
[data-theme="light"] .topbar-search input {
  background: rgba(118,118,128,.12);
  border: none;
  color: var(--text-1);
}
[data-theme="light"] .topbar-search input:focus {
  background: rgba(118,118,128,.18);
  box-shadow: none;
}
[data-theme="light"] .topbar-icon-btn { color: var(--text-2); background: rgba(0,0,0,.04); }
[data-theme="light"] .topbar-icon-btn:hover { background: rgba(0,0,0,.08); color: var(--text-1); }
[data-theme="light"] .avatar { background: linear-gradient(135deg, var(--primary), var(--accent)); }

/* Pages container */
[data-theme="light"] .pages-container {
  background: radial-gradient(ellipse 100% 40% at 70% 0%, rgba(82,84,204,.05) 0%, transparent 60%);
}

/* CMD HERO */
[data-theme="light"] .cmd-hero::before {
  background-image: radial-gradient(circle, rgba(0,0,0,0.1) 1px, transparent 1px);
}
[data-theme="light"] .cmd-hero::after {
  background: linear-gradient(to bottom, transparent, rgba(82,84,204,0.04), transparent);
}
[data-theme="light"] .cmd-label  { color: var(--primary); }
[data-theme="light"] .cmd-label::before { background: var(--primary); }
[data-theme="light"] .cmd-sub    { color: var(--text-2); }
[data-theme="light"] .cmd-sub strong { color: var(--text-1); }
[data-theme="light"] .cmd-accent {
  color: var(--primary);
  -webkit-text-fill-color: var(--primary);
}

/* Dial SVG — invert light-colored strokes */
[data-theme="light"] .dial-outer-ring { stroke: rgba(0,0,0,0.05) !important; }
[data-theme="light"] .dial-track-arc  { stroke: rgba(0,0,0,0.1) !important; }
[data-theme="light"] .dial-inner-ring { stroke: rgba(0,0,0,0.06) !important; }
[data-theme="light"] .dial-tick       { stroke: rgba(0,0,0,0.18) !important; }
[data-theme="light"] .dial-tick-top   { stroke: rgba(0,0,0,0.35) !important; }
[data-theme="light"] .dial-range-lbl  { fill: rgba(0,0,0,0.25) !important; }
[data-theme="light"] .dial-num   { color: var(--text-1); }
[data-theme="light"] .dial-name  { color: var(--primary); }
[data-theme="light"] .dial-desc  { color: var(--text-3); }
[data-theme="light"] .dial-wrap::before {
  background: radial-gradient(circle, rgba(82,84,204,0.12) 0%, transparent 70%);
}
[data-theme="light"] .dial-wrap::after {
  border-color: rgba(82,84,204,0.15);
}
[data-theme="light"] .dial-status { color: var(--secondary); }
[data-theme="light"] .dial-status-dot { background: var(--secondary); }

/* Phase progress */
[data-theme="light"] .phase-badge {
  background: rgba(124,58,237,0.1);
  border-color: rgba(124,58,237,0.2);
  color: var(--accent);
}
[data-theme="light"] .phase-bar-track { background: rgba(0,0,0,0.08); }
[data-theme="light"] .phase-bar-label { color: var(--text-3); }
[data-theme="light"] .phase-progress-name { color: var(--text-3); }

/* Metrics strip */
[data-theme="light"] .metrics-strip {
  background: #FFFFFF;
  border-color: rgba(0,0,0,0.04);
  box-shadow: 0 1px 3px rgba(0,0,0,.06), 0 0 1px rgba(0,0,0,.04);
}
[data-theme="light"] .metric-val  { color: var(--text-1); }
[data-theme="light"] .metric-lbl  { color: var(--text-2); }
[data-theme="light"] .metric-delta-lbl { color: var(--text-2); }
[data-theme="light"] .metric-delta-lbl.up { color: var(--secondary); }
[data-theme="light"] .metric-divider { background: rgba(0,0,0,0.07); }
@media (max-width: 768px) {
  [data-theme="light"] .metrics-strip { background: rgba(0,0,0,.12); border-color: rgba(0,0,0,.1); }
  [data-theme="light"] .metric-item { background: #FFFFFF; }
}
[data-theme="light"] .metric-streak .metric-val { color: var(--cta) !important; }

/* Daily tasks */
[data-theme="light"] .daily-tasks {
  background: #FFFFFF;
  border-color: rgba(0,0,0,0.04);
  box-shadow: 0 1px 3px rgba(0,0,0,.06), 0 0 1px rgba(0,0,0,.04);
}
[data-theme="light"] .daily-tasks-label { color: var(--text-3); }
[data-theme="light"] .task-text   { color: var(--text-1); }
[data-theme="light"] .task-item.done .task-text { color: var(--text-3); }
[data-theme="light"] .task-check-visual { border-color: rgba(0,0,0,0.15); }
[data-theme="light"] .task-item.pending:hover {
  background: rgba(82,84,204,0.04);
  border-color: rgba(82,84,204,0.14);
}
[data-theme="light"] .task-exec-btn {
  background: rgba(82,84,204,0.1);
  border-color: rgba(82,84,204,0.22);
  color: var(--primary);
}
[data-theme="light"] .task-exec-btn:hover { background: rgba(82,84,204,0.18); }
[data-theme="light"] .tasks-footer { color: var(--text-3); border-top-color: rgba(0,0,0,0.07); }
[data-theme="light"] .tasks-footer strong { color: var(--text-2); }
[data-theme="light"] .tasks-reset-row { color: var(--text-3); }
[data-theme="light"] .reset-countdown { color: var(--text-2); }
[data-theme="light"] .reset-countdown.urgent { color: var(--cta); }
[data-theme="light"] .reset-countdown.danger  { color: var(--red); }

/* Intel cards */
[data-theme="light"] .intel-card {
  background: #FFFFFF;
  border-color: rgba(0,0,0,0.04);
  box-shadow: 0 1px 3px rgba(0,0,0,.06), 0 0 1px rgba(0,0,0,.04);
}
[data-theme="light"] .intel-card:hover {
  border-color: rgba(0,0,0,0.08);
  box-shadow: 0 4px 12px rgba(0,0,0,.08), 0 0 1px rgba(0,0,0,.04);
  transform: translateY(-1px);
}
[data-theme="light"] .intel-label { color: var(--text-3); }
[data-theme="light"] .intel-body  { color: var(--text-2); }
[data-theme="light"] .intel-badge.amber {
  background: rgba(217,119,6,0.1);
  border-color: rgba(217,119,6,0.2);
  color: var(--cta);
}
[data-theme="light"] .intel-badge.green {
  background: rgba(13,169,116,0.1);
  border-color: rgba(13,169,116,0.2);
  color: var(--secondary);
}

/* Week plan */
[data-theme="light"] .wk-plan {
  background: #FFFFFF;
  border-color: rgba(0,0,0,0.04);
  box-shadow: 0 1px 3px rgba(0,0,0,.06), 0 0 1px rgba(0,0,0,.04);
}
[data-theme="light"] .wk-header .section-title { color: var(--text-3); }
[data-theme="light"] .wk-day {
  background: rgba(0,0,0,0.03);
  border-color: rgba(0,0,0,0.07);
}
[data-theme="light"] .wk-day-name { color: var(--text-2); }
[data-theme="light"] .wk-day-type { color: var(--text-3); }
[data-theme="light"] .wk-day.today {
  background: rgba(82,84,204,0.08);
  border-color: rgba(82,84,204,0.25);
  box-shadow: 0 0 14px rgba(82,84,204,0.08), inset 0 1px 0 rgba(82,84,204,0.12);
}
[data-theme="light"] .wk-day.done { opacity: 0.55; }
[data-theme="light"] .wk-day-dot  { background: rgba(0,0,0,0.1); }
[data-theme="light"] .wk-day.today .wk-day-dot { background: var(--primary); }

/* Danger banner */
[data-theme="light"] .streak-danger-banner {
  background: rgba(217,119,6,0.06);
  border-color: rgba(217,119,6,0.18);
}
[data-theme="light"] .streak-danger-banner svg { color: var(--cta); }

/* Toast */
[data-theme="light"] .gc-toast {
  background: rgba(255,255,255,0.92);
  backdrop-filter: blur(40px) saturate(180%);
  border-color: rgba(0,0,0,0.06);
  color: var(--text-1);
  box-shadow: 0 8px 32px rgba(0,0,0,0.1), 0 0 1px rgba(0,0,0,.08);
}

/* Dropdowns */
[data-theme="light"] .avatar-dropdown,
[data-theme="light"] .notif-dropdown {
  background: rgba(255,255,255,0.92);
  backdrop-filter: blur(40px) saturate(180%);
  border-color: rgba(0,0,0,0.04);
  box-shadow: 0 12px 40px rgba(0,0,0,.1), 0 0 1px rgba(0,0,0,.06);
}
[data-theme="light"] .dropdown-item { color: var(--text-1); }
[data-theme="light"] .dropdown-item:hover { background: rgba(0,0,0,0.04); }
[data-theme="light"] .dropdown-divider { background: rgba(0,0,0,0.05); }
[data-theme="light"] .notif-item { border-color: rgba(0,0,0,0.04); }

/* Buttons */
[data-theme="light"] .btn-ghost {
  border-color: rgba(0,0,0,0.1);
  color: var(--text-2);
}
[data-theme="light"] .btn-ghost:hover {
  background: rgba(0,0,0,0.03);
  border-color: rgba(0,0,0,0.15);
  color: var(--text-1);
}
[data-theme="light"] .btn-text { color: var(--primary); }

/* Light mode inputs — Apple filled fields */
[data-theme="light"] .settings-input {
  background: rgba(118,118,128,.08);
  color: var(--text-1);
}
[data-theme="light"] .settings-input::placeholder { color: rgba(0,0,0,.25); }
[data-theme="light"] .settings-input:focus { box-shadow: 0 0 0 3px rgba(82,84,204,.2); }

/* Light mode toggle switch */
[data-theme="light"] .toggle-switch { background: rgba(120,120,128,.16); }
[data-theme="light"] .toggle-switch.on { background: #34C759; }
[data-theme="light"] .toggle-switch::after { box-shadow: 0 3px 8px rgba(0,0,0,.1), 0 1px 1px rgba(0,0,0,.04); }

/* Light mode modal — Apple sheet */
[data-theme="light"] .modal {
  background: rgba(255,255,255,0.95);
  backdrop-filter: blur(40px) saturate(180%);
  border-color: rgba(0,0,0,0.04);
  box-shadow: 0 24px 80px rgba(0,0,0,.12), 0 0 1px rgba(0,0,0,.06);
}
[data-theme="light"] .modal::before { background: rgba(0,0,0,.06); }
[data-theme="light"] .modal-overlay { background: rgba(0,0,0,.25); }
[data-theme="light"] .modal-close { background: rgba(0,0,0,.05); color: var(--text-2); }
[data-theme="light"] .modal-close:hover { background: rgba(0,0,0,.1); }

/* Theme toggle — Apple circle button */
.theme-toggle-btn {
  width: 34px; height: 34px;
  border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  color: var(--text-2);
  border: none;
  background: rgba(255,255,255,.06);
  transition: background 150ms cubic-bezier(0.32, 0.72, 0, 1), color 150ms cubic-bezier(0.32, 0.72, 0, 1), transform 100ms cubic-bezier(0.32, 0.72, 0, 1);
  cursor: pointer;
  -webkit-tap-highlight-color: transparent;
}
.theme-toggle-btn:hover {
  color: var(--text-1);
  background: rgba(255,255,255,.12);
}
.theme-toggle-btn:active { transform: scale(0.96); }
[data-theme="light"] .theme-toggle-btn { background: rgba(0,0,0,.04); }
[data-theme="light"] .theme-toggle-btn:hover { background: rgba(0,0,0,.08); }

/* Mobile menu button light */
[data-theme="light"] .mobile-menu-btn {
  background: rgba(0,0,0,.04);
  color: var(--text-2);
}
[data-theme="light"] .mobile-menu-btn:hover { background: rgba(0,0,0,.08); color: var(--text-1); }

/* ─── RESET ───────────────────────────────────────────────── */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { font-size: 16px; }
body {
  background: var(--bg-base);
  color: var(--text-1);
  font-family: var(--font-body);
  font-size: 17px;
  line-height: 1.47;
  letter-spacing: -0.022em;
  font-feature-settings: 'cv01' 1, 'cv02' 1;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  overflow: hidden;
  height: 100vh;
}
a { text-decoration: none; color: inherit; }
button { border: none; background: none; cursor: pointer; font-family: inherit; }
input, textarea { font-family: inherit; }
svg { display: block; }
img { display: block; max-width: 100%; }

/* ─── SCROLLBAR — Apple minimal ───────────────────────────── */
::-webkit-scrollbar { width: 6px; height: 6px; }
::-webkit-scrollbar-track { background: transparent; }
::-webkit-scrollbar-thumb {
  background: rgba(255,255,255,.12);
  border-radius: 3px;
  border: 1px solid transparent;
  background-clip: padding-box;
}
::-webkit-scrollbar-thumb:hover { background: rgba(255,255,255,.2); }
* { scrollbar-width: thin; scrollbar-color: rgba(255,255,255,.12) transparent; }

/* ─── CUSTOM CURSOR — HIDDEN (not Apple) ─────────────────── */
.cursor-dot, .cursor-ring { display: none !important; }
body.cursor-active { cursor: auto !important; }
/* Original cursor code preserved below but disabled */
.cursor-dot-DISABLED, .cursor-ring-DISABLED {
  position: fixed;
  top: 0; left: 0;
  pointer-events: none;
  z-index: 99999;
  /* mix-blend-mode removed — causes severe FPS drops over gradients */
  will-change: left, top;
}
.cursor-dot {
  width: 6px; height: 6px;
  background: #F5A623;
  border-radius: 50%;
  transform: translate(-50%, -50%);
  transition: transform var(--ease-fast), opacity var(--ease-fast);
  box-shadow: 0 0 6px rgba(245,166,35,0.7);
}
.cursor-ring {
  width: 36px; height: 36px;
  border: 1.5px solid rgba(245,166,35,0.55);
  border-radius: 50%;
  transform: translate(-50%, -50%);
  transition: width var(--ease-base), height var(--ease-base),
              border-color var(--ease-base), box-shadow var(--ease-base);
}
.cursor-ring.hover {
  width: 52px; height: 52px;
  border-color: #F5A623;
  box-shadow: 0 0 14px rgba(245,166,35,0.35);
}
body.cursor-active { cursor: none; }

/* Hide custom cursor on touch devices */
@media (hover: none), (pointer: coarse) {
  .cursor-dot, .cursor-ring { display: none !important; }
  body.cursor-active { cursor: auto; }
}

/* ─── GRAIN OVERLAY — HIDDEN (not Apple) ─────────────────── */
.grain { display: none; }

/* ─── BACKGROUND MESH — HIDDEN (not Apple) ───────────────── */
.bg-orbs { display: none; }
.orb, .orb-1, .orb-2, .orb-3 { display: none; }

/* ─── APP LAYOUT ──────────────────────────────────────────── */
.app-layout {
  position: relative;
  z-index: 1;
  display: grid;
  grid-template-columns: var(--sb-w) 1fr;
  grid-template-rows: 100vh;
  height: 100vh;
  transition: grid-template-columns var(--ease-slow);
}
.app-layout.sb-closed {
  grid-template-columns: var(--sb-w-closed) 1fr;
}

/* ─── SIDEBAR — Apple material ────────────────────────────── */
.sidebar {
  display: flex;
  flex-direction: column;
  height: 100vh;
  background: rgba(28,28,30,.92);
  backdrop-filter: blur(40px) saturate(180%);
  -webkit-backdrop-filter: blur(40px) saturate(180%);
  border-right: 0.5px solid rgba(84,84,88,.4);
  overflow: visible;
  padding: var(--s5) 0;
  position: relative;
  z-index: 10;
}

/* Logo */
.sidebar-logo {
  display: flex;
  align-items: center;
  gap: var(--s3);
  padding: var(--s3) var(--s5) var(--s6);
  margin-bottom: var(--s3);
  position: relative;
}
.sidebar-logo::after {
  content: '';
  position: absolute; bottom: 0; left: 20px; right: 20px; height: 0.5px;
  background: rgba(255,255,255,.06);
}
.logo-mark-wrap {
  flex-shrink: 0;
  width: 38px; height: 38px;
  display: flex;
  align-items: center;
  justify-content: center;
}
.logo-mark-img {
  width: 38px; height: 38px;
  object-fit: contain;
}
.logo-text {
  font-family: var(--font-display);
  font-size: 15px;
  font-weight: 700;
  letter-spacing: -.4px;
  white-space: nowrap;
  opacity: 1;
  transition: opacity var(--ease-base), transform var(--ease-base);
}
.sb-closed .logo-text {
  opacity: 0;
  transform: translateX(-8px);
  pointer-events: none;
}

/* Nav */
.sidebar-nav {
  flex: 1;
  display: flex;
  flex-direction: column;
  gap: var(--s1);
  padding: 0 var(--s3);
}
.nav-item {
  display: flex;
  align-items: center;
  gap: var(--s3);
  padding: 10px var(--s4);
  border-radius: var(--r-sm);
  border: none;
  color: var(--text-2);
  font-size: 13px;
  font-weight: 500;
  letter-spacing: -0.01em;
  white-space: nowrap;
  transition: background 150ms cubic-bezier(0.32, 0.72, 0, 1), color 150ms cubic-bezier(0.32, 0.72, 0, 1);
  position: relative;
  cursor: pointer;
}
.nav-item:hover {
  background: rgba(255,255,255,.06);
  color: var(--text-1);
}
.nav-item:active {
  background: rgba(255,255,255,.1);
  transition: background 60ms cubic-bezier(0.32, 0.72, 0, 1);
}
.nav-item.active {
  background: rgba(59,130,246,.12);
  color: var(--primary);
}
.nav-item.active .nav-icon svg path,
.nav-item.active .nav-icon svg rect,
.nav-item.active .nav-icon svg circle {
  stroke: var(--primary);
}
/* Remove gradient indicator — Apple uses fill only */
.nav-item::before {
  display: none;
}
.nav-icon {
  width: 20px; height: 20px;
  flex-shrink: 0;
  display: flex;
  align-items: center;
  justify-content: center;
}
.nav-label {
  opacity: 1;
  transform: translateX(0);
  transition: opacity var(--ease-base), transform var(--ease-base);
}
.sb-closed .nav-label {
  opacity: 0;
  transform: translateX(-6px);
  pointer-events: none;
  width: 0;
  overflow: hidden;
}

/* Sidebar toggle */
.sb-toggle {
  position: absolute;
  right: -16px;
  top: 50%;
  transform: translateY(-50%);
  width: 32px;
  height: 32px;
  border-radius: 50%;
  background: var(--bg-glass);
  backdrop-filter: blur(12px);
  border: 1px solid var(--border-md);
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  z-index: 20;
  transition: all var(--ease-fast);
  color: var(--text-1);
  box-shadow: 0 4px 12px rgba(0,0,0,.5);
}
.sb-toggle:hover {
  background: var(--primary);
  color: #fff;
  border-color: var(--primary);
  box-shadow: 0 2px 8px rgba(0,0,0,.3);
  transform: translateY(-50%) scale(1.05);
}
.sb-closed .sb-toggle {
  transform: translateY(-50%) rotate(180deg);
}

/* Sidebar footer */
.sidebar-footer {
  padding: var(--s4) var(--s3) var(--s2);
  border-top: 1px solid var(--border-sm);
  display: flex;
  flex-direction: column;
  gap: var(--s3);
}
/* Sidebar quick toggles (mobile only — theme + advanced) */
.sb-footer-toggles {
  display: flex; gap: var(--s2); margin-bottom: var(--s1);
}
.sb-toggle-btn {
  flex: 1; display: flex; align-items: center; gap: 6px;
  padding: 8px 10px; border-radius: var(--r-md);
  background: rgba(255,255,255,.06); border: 1px solid var(--border-sm);
  color: var(--text-2); font-size: 11px; font-weight: 500;
  cursor: pointer; transition: background 150ms cubic-bezier(0.32,0.72,0,1);
}
.sb-toggle-btn:hover { background: rgba(255,255,255,.12); color: var(--text-1); }
.sb-toggle-btn:active { transform: scale(0.96); }
[data-theme="light"] .sb-toggle-btn { background: rgba(0,0,0,.04); border-color: rgba(0,0,0,.08); }
[data-theme="light"] .sb-toggle-btn:hover { background: rgba(0,0,0,.08); }
.plan-info {
  display: flex;
  align-items: center;
  gap: var(--s3);
  padding: var(--s2) var(--s3);
}
.plan-badge {
  flex-shrink: 0;
  padding: 3px 10px;
  background: var(--primary);
  color: #fff;
  font-size: 9px;
  font-weight: 700;
  font-family: var(--font-body);
  letter-spacing: .3px;
  border-radius: var(--r-full);
  text-transform: none;
}
.plan-details {
  opacity: 1;
  transition: opacity var(--ease-base);
  overflow: hidden;
}
.sb-closed .plan-details { opacity: 0; }
.plan-name {
  font-size: 12px;
  font-weight: 600;
  color: var(--text-1);
}
.plan-credits {
  font-size: 11px;
  color: var(--text-3);
  font-family: var(--font-mono);
}
.btn-upgrade {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: var(--s2);
  padding: 10px var(--s4);
  border-radius: var(--r-md);
  background: linear-gradient(135deg, rgba(59,130,246,.12), rgba(139,92,246,.08));
  border: 1px solid var(--primary-border);
  color: var(--primary);
  font-size: 12px;
  font-weight: 600;
  letter-spacing: .2px;
  transition: all var(--ease-fast);
  white-space: nowrap;
}
.btn-upgrade:hover {
  background: var(--primary-dim);
  box-shadow: none;
}
.sb-closed .btn-upgrade {
  opacity: 0;
  pointer-events: none;
}

/* ─── MAIN CONTENT ────────────────────────────────────────── */
.main-content {
  display: grid;
  grid-template-rows: var(--topbar-h) 1fr;
  height: 100vh;
  overflow: hidden;
  min-width: 0;
}

/* ─── TOPBAR — Apple navigation bar ──────────────────────── */
.topbar {
  display: flex;
  align-items: center;
  gap: var(--s4);
  padding: 0 var(--s8);
  border-bottom: 0.5px solid rgba(84,84,88,.4);
  background: rgba(29,29,29,.94);
  backdrop-filter: blur(20px) saturate(180%);
  -webkit-backdrop-filter: blur(20px) saturate(180%);
  position: relative;
  z-index: 9;
}
.topbar::after {
  display: none;
}
.topbar-search {
  flex: 1;
  max-width: 400px;
  position: relative;
}
.topbar-search input {
  width: 100%;
  background: rgba(118,118,128,.12);
  border: none;
  border-radius: 10px;
  padding: 8px 16px 8px 36px;
  font-size: 15px;
  color: var(--text-1);
  outline: none;
  transition: all var(--ease-fast);
}
.topbar-search input::placeholder { color: var(--text-3); }
.topbar-search input:focus {
  background: rgba(118,118,128,.18);
  box-shadow: none;
}
.topbar-search .search-icon {
  position: absolute;
  left: 14px; top: 50%;
  transform: translateY(-50%);
  color: var(--text-3);
}
.topbar-actions {
  display: flex;
  align-items: center;
  gap: var(--s3);
  margin-left: auto;
}
/* Apple-style action button */
.btn-create-quick {
  display: flex;
  align-items: center;
  gap: var(--s2);
  padding: 8px 16px;
  background: var(--primary);
  color: #fff;
  border-radius: var(--r-full);
  font-size: 13px;
  font-weight: 600;
  letter-spacing: -0.01em;
  transition: transform 100ms cubic-bezier(0.32, 0.72, 0, 1), filter 150ms cubic-bezier(0.32, 0.72, 0, 1);
  box-shadow: none;
}
.btn-create-quick:hover {
  filter: brightness(1.1);
}
.btn-create-quick:active {
  transform: scale(0.95);
  filter: brightness(0.95);
}
/* Apple-style icon buttons */
.topbar-icon-btn {
  width: 36px; height: 36px;
  border-radius: 50%;
  border: none;
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--text-2);
  transition: background 150ms cubic-bezier(0.32, 0.72, 0, 1), color 150ms cubic-bezier(0.32, 0.72, 0, 1), transform 100ms cubic-bezier(0.32, 0.72, 0, 1);
  position: relative;
  background: rgba(255,255,255,.06);
}
.topbar-icon-btn:hover { background: rgba(255,255,255,.12); color: var(--text-1); }
.topbar-icon-btn:active { transform: scale(0.96); transition: transform 80ms cubic-bezier(0.32, 0.72, 0, 1); }
.notif-dot {
  position: absolute;
  top: 7px; right: 7px;
  width: 7px; height: 7px;
  background: var(--rose);
  border-radius: 50%;
  border: 1.5px solid var(--bg-base);
  animation: notifPulse 2s ease-in-out infinite;
}
@keyframes notifPulse {
  0%,100% { transform: scale(1); }
  50% { transform: scale(1.3); }
}
@keyframes pulse {
  0%,100% { opacity: 1; transform: scale(1); }
  50% { opacity: .7; transform: scale(1.05); }
}
.notif-dot.seen { display: none; }
.avatar-wrap { position: relative; }
/* Apple-style avatar — circular */
.avatar {
  width: 34px; height: 34px;
  background: linear-gradient(135deg, var(--primary), var(--accent));
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 13px;
  font-weight: 700;
  color: #fff;
  cursor: pointer;
  transition: transform 150ms cubic-bezier(0.32, 0.72, 0, 1), box-shadow 150ms cubic-bezier(0.32, 0.72, 0, 1);
}
.avatar:hover {
  transform: scale(1.05);
}
.avatar:active {
  transform: scale(0.95);
}

/* Avatar cosmetic borders — Apple subtle */
.avatar.cosmetic-gold {
  border: 2px solid #FFD700;
  box-shadow: none;
}
.avatar.cosmetic-diamond {
  border: 2px solid #B9F2FF;
  box-shadow: none;
  animation: none;
}

/* Avatar & Notif dropdown — Apple menu style */
.avatar-dropdown {
  position: absolute;
  top: calc(100% + 8px);
  right: 0;
  width: 220px;
  background: var(--bg-surface);
  backdrop-filter: blur(40px) saturate(180%);
  -webkit-backdrop-filter: blur(40px) saturate(180%);
  border: 0.5px solid rgba(255,255,255,.1);
  border-radius: 14px;
  padding: 4px;
  opacity: 0;
  transform: translateY(-6px) scale(.96);
  pointer-events: none;
  transition: opacity 200ms cubic-bezier(0.32, 0.72, 0, 1),
              transform 250ms cubic-bezier(0.32, 0.72, 0, 1);
  box-shadow: 0 12px 40px rgba(0,0,0,.35), 0 0 1px rgba(0,0,0,.1);
  z-index: 100;
}
.avatar-dropdown.open {
  opacity: 1;
  transform: translateY(0) scale(1);
  pointer-events: all;
}
.dropdown-item {
  display: flex;
  align-items: center;
  gap: var(--s3);
  padding: 10px 12px;
  border-radius: 10px;
  font-size: 14px;
  font-weight: 400;
  letter-spacing: -0.01em;
  color: var(--text-1);
  transition: background 100ms cubic-bezier(0.32, 0.72, 0, 1);
  cursor: pointer;
}
.dropdown-item:hover { background: rgba(255,255,255,.08); }
.dropdown-item:active { background: rgba(255,255,255,.14); }
.dropdown-item.danger { color: var(--red); }
.dropdown-item.danger:hover { background: rgba(239,68,68,.1); }
.dropdown-divider { height: 0.5px; background: rgba(255,255,255,.06); margin: 4px 8px; }

/* Notif dropdown override */
.notif-dropdown { right: -60px; min-width: 320px; }

/* ─── PAGES CONTAINER ─────────────────────────────────────── */
.pages-container {
  overflow-y: auto;
  overflow-x: hidden;
  position: relative;
  scroll-behavior: smooth;
}
.page {
  display: none;
  min-height: 100%;
  padding: var(--s6) var(--s8) var(--s16);
  opacity: 0;
  transform: translateY(20px) scale(0.99);
  transition: opacity 350ms cubic-bezier(0.32, 0.72, 0, 1),
              transform 450ms cubic-bezier(0.32, 0.72, 0, 1);
}
.page.active { display: block; }
.page.visible { opacity: 1; transform: translateY(0) scale(1); }

/* ─── PAGE HEADERS ────────────────────────────────────────── */
.page-header { margin-bottom: var(--s6); }
.page-eyebrow {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-size: 13px;
  font-family: var(--font-body);
  font-weight: 500;
  letter-spacing: 0;
  text-transform: none;
  color: var(--text-3);
  background: none;
  border: none;
  border-radius: 0;
  padding: 0;
  margin-bottom: var(--s2);
}
.page-eyebrow::before {
  display: none;
}
.page-title {
  font-family: var(--font-display);
  font-size: clamp(28px, 3.5vw, 34px);
  font-weight: 700;
  line-height: 1.15;
  letter-spacing: 0.01em;
  color: var(--text-1);
}
.page-subtitle {
  margin-top: var(--s3);
  font-size: 15px;
  color: var(--text-2);
  max-width: 500px;
  line-height: 1.5;
}

/* ─── CARDS — Apple solid surface ─────────────────────────── */
.card {
  background: var(--bg-surface);
  border: none;
  border-radius: 12px;
  padding: var(--s4);
  position: relative;
  box-shadow: none;
  transition: transform 280ms cubic-bezier(0.32, 0.72, 0, 1),
              background 280ms cubic-bezier(0.32, 0.72, 0, 1);
}
.card:hover {
  background: var(--bg-elevated);
}
.card-elevated { background: var(--bg-elevated); }

/* Apple card variants — solid fills, no gradients, no colored borders */
.card-blue,
.card-green,
.card-violet,
.card-amber,
.card-rose {
  background: var(--bg-surface);
}
.card-blue:hover,
.card-green:hover,
.card-violet:hover,
.card-amber:hover,
.card-rose:hover {
  background: var(--bg-elevated);
}

/* Glass card — Apple thick material (only for overlays) */
.card-glass {
  background: var(--bg-glass);
  backdrop-filter: blur(40px) saturate(180%);
  -webkit-backdrop-filter: blur(40px) saturate(180%);
  border: 0.5px solid rgba(255,255,255,.08);
  box-shadow: var(--shadow-md);
}

/* ─── BUTTONS (Apple HIG) ────────────────────────────────── */
.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--s2);
  border-radius: var(--r-md);
  font-family: var(--font-body);
  font-weight: 600;
  font-size: 15px;
  letter-spacing: -0.01em;
  cursor: pointer;
  transition: transform 100ms cubic-bezier(0.25, 1, 0.5, 1),
              opacity 100ms cubic-bezier(0.32, 0.72, 0, 1),
              box-shadow 280ms cubic-bezier(0.32, 0.72, 0, 1),
              background 150ms cubic-bezier(0.32, 0.72, 0, 1);
  white-space: nowrap;
  -webkit-tap-highlight-color: transparent;
}
/* Apple press: scale down fast, release slow */
.btn:active {
  transform: scale(0.97);
  transition: transform 100ms cubic-bezier(0.25, 1, 0.5, 1);
}
.btn-primary {
  padding: 12px var(--s5);
  background: var(--primary);
  color: #fff;
  font-size: 15px;
  font-weight: 600;
  letter-spacing: -0.01em;
  border-radius: var(--r-md);
  box-shadow: none;
}
.btn-primary:hover {
  filter: brightness(1.08);
  box-shadow: none;
}
.btn-primary:active {
  transform: scale(0.97);
  filter: brightness(0.95);
}
.btn-primary:disabled {
  opacity: .5; cursor: not-allowed; transform: none; filter: none;
}
.btn-spinner {
  display: inline-block; width: 14px; height: 14px;
  border: 2px solid rgba(255,255,255,.3);
  border-top-color: #fff; border-radius: 50%;
  animation: btnSpin .6s linear infinite;
  vertical-align: middle;
}
@keyframes btnSpin { to { transform: rotate(360deg); } }
.btn-secondary {
  padding: 10px var(--s5);
  background: rgba(255,255,255,.06);
  color: var(--text-1);
  font-size: 14px;
  border: 1px solid var(--border-md);
}
.btn-secondary:hover { background: rgba(255,255,255,.1); }
/* Apple secondary button */
.btn-ghost {
  padding: 9px var(--s4);
  color: var(--text-2);
  font-size: 14px;
  letter-spacing: -0.01em;
  border: 0.5px solid var(--border-sm);
  background: rgba(255,255,255,.04);
}
.btn-ghost:hover { background: rgba(255,255,255,.08); color: var(--text-1); }
.btn-ghost:active { transform: scale(0.97); background: rgba(255,255,255,.12); }
.btn-sm { padding: 7px var(--s3); font-size: 13px; border-radius: var(--r-sm); }
.btn-lg { padding: 14px var(--s8); font-size: 16px; border-radius: var(--r-lg); letter-spacing: -0.01em; }
.btn-danger { background: rgba(239,68,68,.08); color: var(--red); border: 0.5px solid rgba(239,68,68,.15); }
.btn-danger:hover { background: rgba(239,68,68,.18); }

/* ─── CTA BUTTON — Apple solid fill ──────────────────────── */
.btn-cta {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--s2);
  padding: 13px var(--s6);
  background: var(--primary);
  color: #fff;
  border-radius: var(--r-lg);
  font-family: var(--font-body);
  font-size: 15px;
  font-weight: 600;
  letter-spacing: -0.01em;
  box-shadow: none;
  transition: transform 100ms cubic-bezier(0.25, 1, 0.5, 1),
              filter 150ms cubic-bezier(0.32, 0.72, 0, 1);
  position: relative;
  overflow: hidden;
}
.btn-cta::before { display: none; }
.btn-cta:hover {
  filter: brightness(1.08);
  transform: none;
}
.btn-cta:active {
  transform: scale(0.97);
  filter: brightness(0.95);
}

/* ─── BADGES ──────────────────────────────────────────────── */
.badge {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  padding: 3px 10px;
  border-radius: var(--r-full);
  font-size: 11px;
  font-weight: 600;
  font-family: var(--font-body);
  letter-spacing: 0;
  text-transform: none;
}
.badge-green  { background: var(--secondary-dim); color: var(--secondary); }
.badge-red    { background: rgba(239,68,68,.1); color: var(--red); }
.badge-blue   { background: rgba(59,130,246,.1); color: var(--blue); }
.badge-purple { background: rgba(139,92,246,.1); color: var(--purple); }
.badge-orange { background: rgba(245,158,11,.1); color: var(--orange); }
.badge-gold   { background: rgba(251,191,36,.1); color: var(--gold); }
.badge-rose   { background: rgba(244,63,94,.1); color: var(--rose); }

/* ─── STATUS LIVE DOT ─────────────────────────────────────── */
.status-live {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-size: 12px;
  font-family: var(--font-body);
  font-weight: 600;
  color: var(--secondary);
  letter-spacing: 0;
}
.status-live::before {
  content: '';
  width: 7px; height: 7px;
  border-radius: 50%;
  background: var(--secondary);
  box-shadow: none;
  animation: livePulse 2s ease-in-out infinite;
}
@keyframes livePulse {
  0%,100% { opacity: 1; }
  50% { opacity: .4; }
}

/* ─── HOME PAGE — MINIMAL COCKPIT ───────────────────────── */

/* CMD HERO — 2-column, headline + dial */
.cmd-hero {
  display: grid;
  grid-template-columns: 1fr 420px;
  gap: var(--s12);
  align-items: center;
  padding: var(--s12) 0 var(--s8);
  min-height: 480px;
  position: relative;
}
.cmd-hero::before { display: none; }
.cmd-label {
  display: inline-flex;
  align-items: center;
  gap: var(--s2);
  font-family: var(--font-body);
  font-size: 11px;
  font-weight: 600;
  letter-spacing: 0.02em;
  text-transform: none;
  color: var(--text-3);
  margin-bottom: var(--s4);
}
.cmd-label::before { display: none; }
.cmd-headline {
  font-size: clamp(40px, 4.2vw, 60px);
  font-weight: 800;
  line-height: 1.06;
  letter-spacing: -0.025em;
  color: var(--text-1);
  margin-bottom: var(--s4);
}
.cmd-accent { color: var(--primary); }
.cmd-sub {
  font-size: 15px;
  line-height: 1.65;
  color: var(--text-2);
  margin-bottom: var(--s8);
  max-width: 380px;
}
.cmd-sub strong { color: var(--text-1); font-weight: 700; }
.cmd-actions { display: flex; gap: var(--s3); align-items: center; flex-wrap: wrap; }

/* SCORE DIAL */
.dial-wrap {
  position: relative;
  width: 360px;
  height: 360px;
  margin: 0 auto;
}
.dial-wrap::before { display: none; }
.dial-svg { width: 100%; height: 100%; }
.dial-progress-arc {
  transition: stroke-dasharray 1.8s cubic-bezier(0.4, 0, 0.2, 1);
}
.dial-center {
  position: absolute;
  inset: 0;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  text-align: center;
  pointer-events: none;
}
.dial-num {
  font-size: 72px;
  font-weight: 800;
  line-height: 1;
  color: var(--text-1);
  letter-spacing: -0.04em;
  font-variant-numeric: tabular-nums;
}
.dial-name {
  font-family: var(--font-body);
  font-size: 11px;
  font-weight: 600;
  letter-spacing: 0.02em;
  text-transform: none;
  color: var(--text-2);
  margin-top: 10px;
}
.dial-desc {
  font-size: 11px;
  color: var(--text-3);
  margin-top: 5px;
}

/* METRICS STRIP */
.metrics-strip {
  display: flex;
  align-items: center;
  background: var(--bg-surface);
  border: 1px solid var(--border-sm);
  border-radius: var(--r-lg);
  padding: var(--s5) var(--s8);
  margin-bottom: var(--s4);
}
.metric-item { flex: 1; text-align: center; }
.metric-divider {
  width: 1px;
  height: 44px;
  background: var(--border-sm);
  flex-shrink: 0;
}
.metric-val {
  font-size: 34px;
  font-weight: 800;
  line-height: 1;
  color: var(--text-1);
  letter-spacing: -0.025em;
  font-variant-numeric: tabular-nums;
}
.metric-val .unit {
  font-size: 17px;
  color: var(--text-3);
  font-weight: 400;
  letter-spacing: 0;
}
.metric-lbl {
  font-family: var(--font-body);
  font-size: 11px;
  font-weight: 500;
  letter-spacing: 0;
  text-transform: none;
  color: var(--text-2);
  margin-top: 6px;
}
.metric-delta-lbl {
  font-size: 11px;
  color: var(--text-3);
  margin-top: 3px;
}
.metric-delta-lbl.up { color: var(--secondary); }

/* WEEK PLAN MINIMAL */
.wk-plan {
  background: var(--bg-surface);
  border: 1px solid var(--border-sm);
  border-radius: var(--r-lg);
  padding: var(--s5) var(--s7);
  margin-bottom: var(--s4);
}
.wk-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: var(--s5);
}
.wk-strip {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: var(--s3);
}
.wk-day {
  padding: var(--s3) var(--s2);
  border-radius: var(--r-md);
  text-align: center;
  border: 1px solid transparent;
  transition: border-color var(--ease-base), background var(--ease-base);
  min-height: 0;
}
.wk-day.done {
  background: rgba(16,185,129,0.05);
  border-color: rgba(16,185,129,0.1);
}
.wk-day.today {
  background: rgba(99,102,241,0.08);
  border-color: rgba(99,102,241,0.2);
}
.wk-day-name {
  font-family: var(--font-body);
  font-size: 11px;
  font-weight: 500;
  letter-spacing: 0;
  text-transform: none;
  color: var(--text-3);
  margin-bottom: 5px;
}
.wk-day.today .wk-day-name { color: var(--primary); }
.wk-day-type {
  font-size: 11px;
  font-weight: 600;
  color: var(--text-2);
  margin-bottom: 7px;
  line-height: 1.3;
  min-height: 1.3em;
}
.wk-day.today .wk-day-type { color: var(--text-1); }
.wk-day-dot {
  width: 6px; height: 6px;
  border-radius: 50%;
  margin: 0 auto;
  background: var(--border-md);
}
.wk-day.done .wk-day-dot { background: var(--secondary); }
.wk-day.today .wk-day-dot {
  background: var(--primary);
  box-shadow: none;
}

/* MISSION MINIMAL */
.mission-min {
  background: var(--bg-surface);
  border: 1px solid var(--border-sm);
  border-radius: var(--r-lg);
  padding: var(--s5) var(--s7);
  display: grid;
  grid-template-columns: 90px 1fr auto;
  gap: var(--s6);
  align-items: center;
  margin-bottom: var(--s4);
}
.mission-min-label {
  font-family: var(--font-body);
  font-size: 13px;
  font-weight: 600;
  letter-spacing: 0;
  text-transform: none;
  color: var(--primary);
  line-height: 1.6;
  border-right: 1px solid var(--border-sm);
  padding-right: var(--s6);
}
.mission-min-text {
  font-size: 14px;
  line-height: 1.6;
  color: var(--text-1);
}
.mission-min-actions { display: flex; flex-direction: column; gap: var(--s2); min-width: 150px; }

/* btn-text */
/* Apple text button — opacity on press */
.btn-text {
  background: none;
  border: none;
  padding: 0;
  font-family: var(--font-body);
  font-size: 13px;
  font-weight: 500;
  color: var(--primary);
  cursor: pointer;
  transition: opacity 100ms cubic-bezier(0.32, 0.72, 0, 1);
}
.btn-text:hover { opacity: 0.75; }
.btn-text:active { opacity: 0.4; }
.btn-text-sm { font-size: 12px; }

/* Widget header badge (IA, NOVO, etc.) */
.widget-badge {
  font-size: 9px;
  padding: 2px 6px;
  border-radius: 6px;
  margin-left: 4px;
  font-weight: 700;
  letter-spacing: 0;
}
.widget-badge-ai     { background: rgba(139,92,246,.15); color: #A78BFA; }
.widget-badge-new    { background: rgba(16,185,129,.15); color: #30D158; }
.widget-badge-gold   { background: rgba(245,158,11,.15); color: #FF9F0A; }

/* Notification dropdown */
.notif-header {
  padding: var(--s4) var(--s5) var(--s3);
  border-bottom: 1px solid var(--border-sm);
  display: flex;
  align-items: center;
  justify-content: space-between;
}
.notif-title {
  font-size: 13px;
  font-weight: 700;
  color: var(--text-1);
}
.notif-mark-all {
  font-size: 11px;
  color: var(--primary);
  cursor: pointer;
  font-family: var(--font-mono);
}
.notif-footer {
  padding: var(--s3) var(--s5);
  border-top: 1px solid var(--border-sm);
}
.notif-footer-link {
  font-size: 11.5px;
  color: var(--primary);
  cursor: pointer;
}

/* Authority Profile Strip */
.authority-profile {
  display: flex;
  align-items: center;
  gap: var(--s4);
  padding: 14px var(--s5);
  background: var(--bg-surface);
  border: 1px solid var(--border-sm);
  border-radius: var(--r-lg);
  margin-bottom: var(--s4);
  flex-wrap: wrap;
}
.ap-segment { flex: 1; min-width: 120px; }
.ap-label {
  font-size: 11px;
  font-weight: 500;
  font-family: var(--font-body);
  color: var(--text-3);
  text-transform: none;
  letter-spacing: 0;
  margin-bottom: 2px;
}
.ap-value {
  font-size: 13px;
  font-weight: 600;
  color: var(--text-1);
  letter-spacing: -.2px;
}
.ap-highlight { color: var(--primary); }
.ap-divider {
  width: 1px;
  height: 28px;
  background: var(--border-sm);
}
.ap-edit {
  margin-left: auto;
  font-size: 11px;
  color: var(--text-3);
  transition: color var(--ease-fast);
}
.ap-edit:hover { color: var(--primary); }

/* Hero Card — Apple clean surface */
.home-hero {
  padding: var(--s8);
  background: var(--bg-surface) !important;
  border: none !important;
  border-radius: var(--r-lg);
  position: relative;
  overflow: hidden;
}
.home-hero::before {
  display: none;
}
.hero-tag {
  display: inline-flex;
  margin-bottom: var(--s4);
}
.hero-title {
  font-family: var(--font-display);
  font-size: clamp(24px, 3vw, 40px);
  font-weight: 700;
  letter-spacing: -1.5px;
  line-height: 1;
  color: var(--text-1);
  max-width: 600px;
  margin-bottom: var(--s6);
}
.hero-title .highlight { color: var(--primary); position: relative; }
.hero-cta-row { display: flex; align-items: center; gap: var(--s4); flex-wrap: wrap; }
.hero-decoration { display: none; }

/* Authority Score Card — Apple clean */
.score-card {
  padding: var(--s6);
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--s4);
  text-align: center;
  background: var(--bg-surface) !important;
  border: none !important;
}
.score-ring-wrap {
  position: relative;
  width: 140px; height: 140px;
}
.score-ring-wrap svg {
  width: 140px; height: 140px;
  transform: rotate(-90deg);
}
.score-ring-bg { fill: none; stroke: rgba(255,255,255,.06); stroke-width: 6; }
.score-ring-fill {
  fill: none;
  stroke: url(#scoreGradient);
  stroke-width: 6;
  stroke-linecap: round;
  stroke-dasharray: 395.84;
  stroke-dashoffset: 98.96;
  transition: stroke-dashoffset 1.8s cubic-bezier(.4,0,.2,1);
  filter: none;
}
.score-center {
  position: absolute; inset: 0;
  display: flex; flex-direction: column;
  align-items: center; justify-content: center;
  gap: 2px;
}
.score-number {
  font-family: var(--font-display);
  font-size: 40px;
  font-weight: 700;
  letter-spacing: -2px;
  color: var(--text-1);
  line-height: 1;
}
.score-max {
  font-size: 11px;
  color: var(--text-3);
  font-family: var(--font-body);
}
.score-label-text { font-size: 13px; font-weight: 600; color: var(--text-1); }
.score-sublabel { font-size: 11px; color: var(--text-2); }
.score-level-bar {
  width: 100%; height: 4px;
  background: rgba(255,255,255,.06);
  border-radius: 3px; overflow: hidden;
}
.score-level-fill {
  height: 100%;
  background: var(--primary);
  border-radius: 3px;
  width: 74%;
  transition: width 1.8s cubic-bezier(.4,0,.2,1);
}

/* Mission Card */
.mission-card {
  padding: var(--s6);
  position: relative;
  overflow: hidden;
}
.mission-card::after {
  content: '//';
  position: absolute;
  right: var(--s5); bottom: var(--s3);
  font-family: var(--font-mono);
  font-size: 64px;
  font-weight: 700;
  color: var(--primary);
  opacity: .05;
  pointer-events: none;
}
.mission-label {
  font-size: 10px;
  font-weight: 700;
  font-family: var(--font-mono);
  color: var(--primary);
  text-transform: none;
  letter-spacing: 1.5px;
  margin-bottom: var(--s3);
}
.mission-text {
  font-size: 17px;
  font-weight: 600;
  font-family: var(--font-display);
  color: var(--text-1);
  line-height: 1.35;
  letter-spacing: -.3px;
  margin-bottom: var(--s5);
}
.mission-actions { display: flex; gap: var(--s2); }

/* Insights */
.insights-list {
  display: flex;
  flex-direction: column;
  gap: var(--s2);
}
.insight-item {
  display: flex;
  align-items: flex-start;
  gap: var(--s3);
  padding: var(--s3);
  border-radius: var(--r-md);
  border: 1px solid transparent;
  font-size: 13px;
  color: var(--text-2);
  transition: all var(--ease-fast);
  cursor: default;
}
.insight-item:hover {
  background: rgba(255,255,255,.03);
  border-color: var(--border-sm);
}
.insight-icon {
  width: 28px; height: 28px;
  border-radius: var(--r-sm);
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}
.insight-icon.green  { background: rgba(16,185,129,.1); color: var(--secondary); }
.insight-icon.orange { background: rgba(245,158,11,.1); color: var(--cta); }
.insight-icon.blue   { background: rgba(59,130,246,.1); color: var(--primary); }
.insight-icon.red    { background: rgba(239,68,68,.1); color: var(--red); }

/* Wins */
.wins-grid { display: flex; flex-direction: column; gap: var(--s2); }
.win-card {
  display: flex;
  align-items: center;
  gap: var(--s4);
  padding: var(--s3) var(--s4);
  background: var(--bg-surface);
  border: 1px solid var(--border-xs);
  border-radius: var(--r-md);
  transition: all var(--ease-fast);
}
.win-card:hover { background: rgba(255,255,255,.04); border-color: var(--border-sm); }
.win-emoji {
  width: 34px; height: 34px;
  border-radius: var(--r-sm);
  display: flex; align-items: center; justify-content: center;
  flex-shrink: 0;
}
.win-card:nth-child(1) .win-emoji { color: var(--cta); background: rgba(245,158,11,.1); }
.win-card:nth-child(2) .win-emoji { color: var(--secondary); background: rgba(16,185,129,.1); }
.win-card:nth-child(3) .win-emoji { color: var(--accent); background: rgba(139,92,246,.1); }
.win-card:nth-child(4) .win-emoji { color: var(--primary); background: rgba(59,130,246,.1); }
.win-title { font-size: 13px; font-weight: 700; color: var(--text-1); line-height: 1.3; }
.win-sub { font-size: 11px; color: var(--text-3); font-family: var(--font-mono); margin-top: 1px; }

/* Section header */
.section-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: var(--s4);
}
.section-title {
  font-size: 13px;
  font-weight: 600;
  text-transform: none;
  letter-spacing: -0.01em;
  color: var(--text-2);
  font-family: var(--font-body);
}
.section-action {
  font-size: 12px;
  color: var(--primary);
  font-weight: 600;
  cursor: pointer;
  transition: opacity var(--ease-fast);
}
.section-action:hover { opacity: .7; }

/* Milestone card */
.milestone-next-card {
  display: flex;
  align-items: center;
  gap: var(--s4);
  padding: var(--s4) var(--s5);
  background: var(--bg-surface);
  backdrop-filter: blur(12px);
  border: 1px solid var(--border-sm);
  border-radius: var(--r-lg);
  transition: all var(--ease-base);
}
.milestone-next-card:hover { border-color: var(--border-md); }
.milestone-next-icon {
  width: 40px; height: 40px;
  border-radius: var(--r-md);
  background: linear-gradient(135deg, var(--primary-dim), rgba(139,92,246,.1));
  display: flex; align-items: center; justify-content: center;
  color: var(--primary);
  flex-shrink: 0;
}
.milestone-next-info { flex: 1; min-width: 0; }
.milestone-next-label { font-size: 10px; font-family: var(--font-mono); color: var(--text-3); text-transform: none; letter-spacing: .8px; }
.milestone-next-title { font-size: 13px; font-weight: 600; color: var(--text-1); margin: 2px 0 6px; }
.milestone-next-bar { width: 100%; height: 4px; background: rgba(255,255,255,.06); border-radius: 3px; overflow: hidden; }
.milestone-next-fill { height: 100%; background: var(--primary); border-radius: 3px; transition: width 1.2s cubic-bezier(0.32, 0.72, 0, 1); }
.milestone-next-pct { font-family: var(--font-mono); font-size: 13px; font-weight: 700; color: var(--primary); flex-shrink: 0; }

/* Home column helpers */
.home-right-col { display: flex; flex-direction: column; gap: var(--s4); }
.home-left-col  { display: flex; flex-direction: column; gap: var(--s4); }

/* ─── CREATE PAGE ─────────────────────────────────────────── */
.create-layout {
  display: grid;
  grid-template-columns: minmax(0, 1fr);
  gap: var(--s5);
}
.create-layout.with-result { grid-template-columns: minmax(0, 1fr) 480px; }
.create-main { min-width: 0; }

/* Tabs */
.tabs-row {
  display: flex;
  gap: 0;
  background: rgba(118,118,128,.12);
  border: none;
  border-radius: 9px;
  padding: 2px;
  width: fit-content;
  margin-bottom: var(--s6);
}
.tab-btn {
  padding: 7px 14px;
  border-radius: 7px;
  font-size: 13px;
  font-weight: 500;
  color: var(--text-2);
  transition: all 200ms cubic-bezier(0.32, 0.72, 0, 1);
  cursor: pointer;
  border: none;
  background: none;
}
.tab-btn.active {
  background: var(--bg-elevated);
  color: var(--text-1);
  font-weight: 600;
  box-shadow: 0 1px 3px rgba(0,0,0,.12), 0 0 0 0.5px rgba(0,0,0,.04);
}
[data-theme="light"] .tabs-row { background: rgba(118,118,128,.12); }
[data-theme="light"] .tab-btn.active { background: #fff; box-shadow: 0 1px 3px rgba(0,0,0,.1), 0 0 0 0.5px rgba(0,0,0,.04); }
.tab-btn:not(.active):hover { color: var(--text-1); }
.tab-content { display: none; }
.tab-content.active { display: block; }

/* Generate */
.generate-header { margin-bottom: var(--s6); }
.generate-title {
  font-family: var(--font-display);
  font-size: clamp(20px, 2.5vw, 28px);
  font-weight: 700;
  letter-spacing: -.8px;
  color: var(--text-1);
  margin-bottom: var(--s2);
}
.generate-subtitle { font-size: 14px; color: var(--text-2); }
.generate-input-wrap { position: relative; margin-bottom: var(--s5); }
.generate-textarea {
  width: 100%;
  background: rgba(118,118,128,.12);
  border: none;
  border-radius: var(--r-md);
  padding: var(--s4) var(--s4) 56px;
  font-size: 17px;
  color: var(--text-1);
  outline: none;
  resize: none;
  min-height: 120px;
  transition: all var(--ease-fast);
  line-height: 1.5;
}
.generate-textarea::placeholder { color: var(--text-3); }
.generate-textarea:focus {
  background: rgba(118,118,128,.18);
  box-shadow: none;
}
.generate-input-actions {
  position: absolute;
  bottom: var(--s3); right: var(--s3); left: var(--s3);
  display: flex; align-items: center; justify-content: space-between;
}
.generate-char-count { font-size: 11px; color: var(--text-3); font-family: var(--font-mono); transition: color .2s; }
.generate-char-count.near-limit { color: #FF9F0A; }
.generate-char-count.at-limit { color: #FF453A; font-weight: 600; }

/* Create categories */
.create-categories { display: flex; flex-direction: column; gap: var(--s5); }
.create-cat-label {
  font-size: 13px;
  font-weight: 600;
  font-family: var(--font-body);
  color: var(--text-2);
  text-transform: none;
  letter-spacing: 0;
  margin-bottom: var(--s3);
}

/* Quick type cards */
.quick-types {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(140px, 1fr));
  gap: var(--s3);
}
.type-card {
  padding: var(--s4) var(--s3);
  background: var(--bg-surface);
  border: 1px solid var(--border-sm);
  border-radius: var(--r-lg);
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--s2);
  cursor: pointer;
  transition: all var(--ease-base);
  text-align: center;
}
.type-card:hover {
  border-color: var(--primary-border);
  background: var(--bg-elevated);
}
.type-card-icon {
  width: 40px; height: 40px;
  border-radius: var(--r-md);
  display: flex; align-items: center; justify-content: center;
  background: rgba(255,255,255,.05);
  color: var(--text-2);
  transition: all var(--ease-fast);
}
.type-card:hover .type-card-icon { color: var(--primary); background: rgba(59,130,246,.12); }
.type-card-name { font-size: 12px; font-weight: 600; color: var(--text-1); line-height: 1.3; }
.type-card-desc { font-size: 9px; color: var(--text-3); line-height: 1.2; margin-top: 2px; }

/* Top card — Apple subtle highlight */
.type-card-top {
  position: relative;
  border-color: var(--secondary-border);
}
.type-card-top:hover {
  border-color: var(--secondary);
  background: var(--secondary-dim);
}
.type-card-top .type-card-icon { color: #30D158; background: rgba(16,185,129,.1); }
.type-card-top:hover .type-card-icon { color: #30D158; background: rgba(16,185,129,.18); }
/* ── Unified micro-badge system ── */
.micro-badge {
  display: inline-flex; align-items: center; gap: 4px;
  padding: 3px 10px; border-radius: var(--r-full);
  font-size: 10px; font-weight: 600;
  letter-spacing: 0; line-height: 1.4;
}

.type-card-top-badge {
  position: absolute; top: -1px; right: -1px;
  background: #30D158; color: #fff;
  font-size: 9px; font-weight: 700;
  padding: 3px 8px;
  border-radius: 0 var(--r-lg) 0 var(--r-md);
  line-height: 1.4; letter-spacing: 0;
}

/* Result panel */
.result-panel { position: relative; }
.result-panel-inner {
  position: sticky;
  top: var(--s6);
  background: var(--bg-glass);
  backdrop-filter: blur(20px) saturate(1.2);
  border: 1px solid var(--border-sm);
  border-radius: var(--r-xl);
  overflow: hidden;
  max-height: calc(100vh - var(--topbar-h) - var(--s16));
  display: flex;
  flex-direction: column;
}
.result-header {
  padding: var(--s5) var(--s5) var(--s4);
  border-bottom: 1px solid var(--border-sm);
  display: flex; align-items: center; justify-content: space-between;
  flex-shrink: 0;
}
.result-title { font-size: 13px; font-weight: 700; color: var(--text-1); }
.result-body {
  flex: 1;
  overflow-y: auto;
  padding: var(--s5);
  display: flex; flex-direction: column; gap: var(--s4);
}
.result-section { display: flex; flex-direction: column; gap: var(--s2); }
.result-section-label {
  font-size: 10px; font-weight: 700; font-family: var(--font-mono);
  color: var(--text-3); text-transform: none; letter-spacing: 0;
}
.result-section-content {
  font-size: 13px; color: var(--text-2); line-height: 1.6;
  background: rgba(255,255,255,.04);
  border-radius: var(--r-md);
  padding: var(--s3) var(--s4);
  border: 1px solid var(--border-xs);
}
.result-section-content.hook {
  font-size: 15px; font-weight: 600; color: var(--text-1);
  font-family: var(--font-display); letter-spacing: -.3px;
}
.result-tags { display: flex; flex-wrap: wrap; gap: var(--s1); }
.result-tag {
  padding: 3px 10px;
  background: rgba(255,255,255,.04);
  border: 1px solid var(--border-sm);
  border-radius: var(--r-full);
  font-size: 11px;
  color: var(--text-2);
  font-family: var(--font-mono);
}
.result-footer {
  padding: var(--s4) var(--s5);
  border-top: 1px solid var(--border-sm);
  display: grid; grid-template-columns: 1fr 1fr; gap: var(--s2);
  flex-shrink: 0;
}
.result-info-bar {
  display: flex; align-items: center; gap: var(--s4);
  font-size: 11px; font-family: var(--font-mono); color: var(--text-3);
  padding: 0 var(--s5) var(--s4);
}
.result-info-item { display: flex; align-items: center; gap: var(--s2); }

/* AI source indicator */
.ai-source-badge {
  display: inline-block;
  font-size: 10px;
  font-family: var(--font-mono);
  padding: 2px 8px;
  border-radius: 4px;
  margin: 0 var(--s5) var(--s2);
  width: fit-content;
}
.ai-source-ai {
  display: inline-block;
  background: rgba(16, 185, 129, 0.12);
  color: #10b981;
  border: 1px solid rgba(16, 185, 129, 0.25);
}
.ai-source-fallback {
  display: inline-block;
  background: rgba(139, 92, 246, 0.10);
  color: #8b5cf6;
  border: 1px solid rgba(139, 92, 246, 0.20);
}

/* Result meta row */
.result-meta-row {
  display: flex; flex-wrap: wrap; gap: var(--s2);
  padding: var(--s3) var(--s5);
  border-bottom: 1px solid var(--border-sm);
}
.result-meta-tag {
  display: flex; align-items: center; gap: 5px;
  padding: 5px 12px;
  background: var(--bg-elevated);
  border: 1px solid var(--border-sm);
  border-radius: var(--r-full);
  font-size: 12px;
}
.meta-label { color: var(--text-2); font-weight: 600; }
.meta-value { color: var(--text-1); font-weight: 600; }

/* Generating state */
.generating-overlay {
  position: absolute; inset: 0;
  background: var(--bg-glass);
  backdrop-filter: blur(20px);
  border-radius: var(--r-xl);
  display: flex; flex-direction: column; align-items: center; justify-content: center;
  gap: var(--s4); z-index: 10;
  opacity: 0; pointer-events: none; transition: opacity var(--ease-base);
}
.generating-overlay.visible { opacity: 1; pointer-events: all; }
.generating-text { font-size: 14px; font-weight: 600; color: var(--text-1); font-family: var(--font-mono); }
.generating-steps { display: flex; flex-direction: column; gap: var(--s2); align-items: flex-start; }
.gen-step {
  display: flex; align-items: center; gap: var(--s3);
  font-size: 12px; color: var(--text-3); font-family: var(--font-mono);
  transition: color var(--ease-base);
}
.gen-step.done   { color: var(--primary); }
.gen-step.active { color: var(--text-1); }
.gen-step-dot {
  width: 6px; height: 6px; border-radius: 50%;
  background: var(--text-3); transition: background var(--ease-base); flex-shrink: 0;
}
.gen-step.done .gen-step-dot   { background: var(--primary); }
.gen-step.active .gen-step-dot { background: var(--text-1); animation: pulse 1s ease infinite; }

/* Loading bar */
.loading-bar { width: 200px; height: 2px; background: rgba(255,255,255,.06); border-radius: 1px; overflow: hidden; }
.loading-bar-fill {
  height: 100%;
  background: var(--primary);
  border-radius: 1px;
  animation: loadingBar 2s ease-in-out infinite;
  transform-origin: left;
}
@keyframes loadingBar {
  0%   { transform: scaleX(0) translateX(0); }
  50%  { transform: scaleX(1) translateX(0); }
  100% { transform: scaleX(0) translateX(100%); }
}

/* Templates */
.templates-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: var(--s4); }
.template-card {
  padding: var(--s5);
  border-radius: var(--r-lg);
  border: 1px solid var(--border-sm);
  background: var(--bg-surface);
  backdrop-filter: blur(12px);
  cursor: pointer;
  transition: all var(--ease-base);
  display: flex; flex-direction: column; gap: var(--s3);
}
.template-card:hover {
  border-color: var(--border-md);
  background: var(--bg-elevated);
}
.template-card-type { font-size: 10px; font-weight: 700; font-family: var(--font-mono); text-transform: none; letter-spacing: 0; }
.template-card-title { font-size: 15px; font-weight: 700; color: var(--text-1); font-family: var(--font-display); letter-spacing: -.3px; line-height: 1.3; }
.template-card-desc { font-size: 12px; color: var(--text-2); line-height: 1.5; }
.template-card-meta { display: flex; align-items: center; gap: var(--s2); margin-top: auto; }

/* Empty state */
.empty-state {
  display: flex; flex-direction: column; align-items: center; justify-content: center;
  gap: var(--s4); padding: var(--s16) var(--s8); text-align: center;
}
.empty-icon {
  width: 60px; height: 60px; border-radius: var(--r-xl);
  background: rgba(255,255,255,.04); border: 1px solid var(--border-sm);
  display: flex; align-items: center; justify-content: center; color: var(--text-3);
}
.empty-title { font-size: 16px; font-weight: 700; color: var(--text-1); font-family: var(--font-display); letter-spacing: -.3px; }
.empty-sub { font-size: 13px; color: var(--text-2); max-width: 280px; line-height: 1.5; }

/* ─── PLANNER PAGE ────────────────────────────────────────── */
.planner-toolbar {
  display: flex; align-items: center; justify-content: space-between;
  margin-bottom: var(--s6); gap: var(--s4);
}
.planner-nav { display: flex; align-items: center; gap: var(--s3); }
.planner-week-label {
  font-size: 15px; font-weight: 700; color: var(--text-1);
  font-family: var(--font-display); letter-spacing: -.3px;
  min-width: 200px; text-align: center;
}
.planner-nav-btn {
  width: 34px; height: 34px; border-radius: var(--r-md);
  border: 1px solid var(--border-sm);
  display: flex; align-items: center; justify-content: center;
  color: var(--text-2); transition: all var(--ease-fast);
  background: rgba(255,255,255,.02);
}
.planner-nav-btn:hover { background: rgba(255,255,255,.06); color: var(--text-1); border-color: var(--border-md); }
.planner-actions { display: flex; gap: var(--s3); }

/* Balance card */
.balance-card { margin-bottom: var(--s5); }
.balance-header {
  display: flex; align-items: flex-start; justify-content: space-between; gap: var(--s5);
  margin-bottom: var(--s5);
}
.balance-header p { font-size: 12px; color: var(--text-2); line-height: 1.5; margin-top: var(--s2); }
.balance-score-wrap { text-align: right; flex-shrink: 0; }
.balance-score-number {
  font-family: var(--font-display); font-size: 36px; font-weight: 700; letter-spacing: -2px;
}
.balance-score-label { font-size: 10px; font-family: var(--font-mono); color: var(--text-3); text-transform: none; letter-spacing: 0; }
.balance-bars { display: flex; flex-direction: column; gap: var(--s3); }
.balance-bar-row { display: flex; align-items: center; gap: var(--s3); }
.balance-bar-label { font-size: 12px; font-weight: 600; color: var(--text-2); width: 100px; flex-shrink: 0; }
.balance-bar-track { flex: 1; height: 8px; background: rgba(255,255,255,.04); border-radius: 4px; overflow: hidden; }
.balance-bar-fill { height: 100%; border-radius: 4px; transition: width 1s cubic-bezier(0.32, 0.72, 0, 1); }
.balance-bar-pct { font-size: 12px; font-family: var(--font-mono); font-weight: 700; width: 35px; text-align: right; }
.balance-tip {
  margin-top: var(--s4); font-size: 12px; color: var(--text-2); line-height: 1.6;
  padding: var(--s3) var(--s4); background: rgba(245,158,11,.06); border: 1px solid rgba(245,158,11,.12);
  border-radius: var(--r-md);
}

/* Calendar grid */
.planner-grid { display: grid; grid-template-columns: repeat(7, 1fr); gap: var(--s3); }
.planner-day {
  border-radius: var(--r-lg); border: 1px solid var(--border-sm);
  background: var(--bg-surface); backdrop-filter: blur(12px);
  overflow: hidden; transition: all var(--ease-base);
  cursor: pointer; min-height: 200px; display: flex; flex-direction: column;
}
.planner-day:hover { border-color: var(--border-md); background: var(--bg-elevated); }
.planner-day.today { border-color: var(--primary-border); background: rgba(59,130,246,.04); }
.planner-day.has-content { border-color: rgba(59,130,246,.2); }
.planner-day-header {
  padding: var(--s3) var(--s3) var(--s2);
  border-bottom: 1px solid var(--border-sm);
  display: flex; align-items: center; justify-content: space-between;
}
.planner-day-name { font-size: 9px; font-weight: 700; font-family: var(--font-mono); color: var(--text-3); text-transform: none; letter-spacing: 0; }
.planner-day.today .planner-day-name { color: var(--primary); }
.planner-day-num { font-size: 14px; font-weight: 700; color: var(--text-2); }
.planner-day.today .planner-day-num {
  background: var(--primary); color: #fff;
  width: 24px; height: 24px; border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  font-size: 11px;
}
.planner-day-body { flex: 1; padding: var(--s3); display: flex; flex-direction: column; gap: var(--s2); }
.planner-content-item {
  padding: var(--s2) var(--s3); border-radius: var(--r-sm);
  font-size: 11px; font-weight: 600; line-height: 1.4;
}
.planner-content-item.authority  { background: rgba(59,130,246,.1); color: var(--primary); }
.planner-content-item.conversion { background: rgba(245,158,11,.1); color: var(--cta); }
.planner-content-item.connection { background: rgba(139,92,246,.1); color: var(--accent); }
.planner-content-item.empty-slot {
  background: transparent; border: 1.5px dashed var(--border-sm);
  color: var(--text-3); text-align: center; cursor: pointer;
}
.planner-content-item.empty-slot:hover { border-color: var(--primary-border); color: var(--primary); background: rgba(59,130,246,.04); }
.planner-add-btn {
  width: 100%; padding: var(--s2); background: transparent;
  border: 1.5px dashed var(--border-sm); border-radius: var(--r-sm);
  color: var(--text-3); font-size: 11px;
  display: flex; align-items: center; justify-content: center; gap: var(--s1);
  transition: all var(--ease-fast); cursor: pointer;
}
.planner-add-btn:hover { border-color: var(--primary-border); color: var(--primary); background: rgba(59,130,246,.04); }

/* ── Planner empty state ── */
.planner-empty-state {
  display: flex; flex-direction: column; align-items: center;
  gap: 4px; padding: 12px 8px;
}
.planner-empty-state svg { color: var(--text-3); opacity: 0.5; }
.planner-empty-state span { font-size: 10px; color: var(--text-3); opacity: 0.6; }

/* ─── GROWTH PAGE ─────────────────────────────────────────── */
.growth-grid { display: grid; grid-template-columns: 1fr 320px; gap: var(--s5); }
.growth-main { display: flex; flex-direction: column; gap: var(--s5); }

/* Growth domain grid */
.growth-domain-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: var(--s3); }
.growth-domain-card {
  padding: var(--s5); display: flex; flex-direction: column; gap: var(--s2);
}
.domain-icon {
  width: 40px; height: 40px; border-radius: var(--r-md);
  display: flex; align-items: center; justify-content: center;
}
.domain-name { font-size: 11px; font-weight: 700; font-family: var(--font-mono); color: var(--text-3); text-transform: none; letter-spacing: .8px; }
.domain-value { font-family: var(--font-display); font-size: 28px; font-weight: 700; letter-spacing: -1.5px; line-height: 1; }
.domain-sub { font-size: 11px; color: var(--text-2); }
.domain-trend { font-size: 11px; font-family: var(--font-mono); color: var(--secondary); }
.domain-bar-track { width: 100%; height: 4px; background: rgba(255,255,255,.06); border-radius: 3px; overflow: hidden; margin-top: var(--s2); }
.domain-bar-fill { height: 100%; border-radius: 3px; transition: width 1.2s cubic-bezier(0.32, 0.72, 0, 1); }

/* Chart */
.chart-card { padding: var(--s5); }
.chart-header { display: flex; align-items: center; justify-content: space-between; margin-bottom: var(--s5); }
.chart-title { font-size: 15px; font-weight: 700; color: var(--text-1); font-family: var(--font-display); letter-spacing: -.3px; }
.chart-filters {
  display: flex; gap: var(--s1);
  background: rgba(255,255,255,.04);
  border: 1px solid var(--border-sm);
  border-radius: var(--r-full);
  padding: 2px;
}
.chart-filter {
  padding: 5px 14px; border-radius: var(--r-full);
  font-size: 11px; font-weight: 600; font-family: var(--font-mono);
  color: var(--text-2); cursor: pointer; transition: all var(--ease-fast);
}
.chart-filter.active { background: rgba(59,130,246,.12); color: var(--text-1); }
.chart-area { width: 100%; height: 200px; position: relative; }
.chart-area canvas { width: 100% !important; height: 200px !important; }

/* Top content */
.top-content-list { display: flex; flex-direction: column; gap: var(--s2); }
.top-content-item {
  display: flex; align-items: center; gap: var(--s4);
  padding: var(--s3) var(--s4); border-radius: var(--r-md);
  border: 1px solid var(--border-sm);
  background: var(--bg-surface); backdrop-filter: blur(12px);
  transition: all var(--ease-base); cursor: default;
}
.top-content-item:hover { border-color: var(--border-md); transform: translateX(3px); }
.top-content-rank { font-family: var(--font-mono); font-size: 12px; font-weight: 700; color: var(--text-3); width: 20px; flex-shrink: 0; text-align: center; }
.top-content-rank.first { color: var(--gold); }
.top-content-info { flex: 1; min-width: 0; }
.top-content-title { font-size: 13px; font-weight: 600; color: var(--text-1); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.top-content-sub { font-size: 11px; color: var(--text-2); font-family: var(--font-mono); }
.top-content-stat { font-family: var(--font-mono); font-size: 12px; font-weight: 700; color: var(--primary); white-space: nowrap; }

/* Growth sidebar */
.growth-sidebar { display: flex; flex-direction: column; gap: var(--s4); }
.insights-sidebar-card { padding: var(--s5); }
.insight-list-sidebar { display: flex; flex-direction: column; gap: var(--s3); margin-top: var(--s4); }
.insight-sidebar-item { display: flex; align-items: flex-start; gap: var(--s3); font-size: 12px; color: var(--text-2); line-height: 1.5; }
.insight-sidebar-dot { width: 5px; height: 5px; border-radius: 50%; background: var(--primary); margin-top: 6px; flex-shrink: 0; }
.adjustments-card { padding: var(--s5); }
.adjustment-item {
  display: flex; align-items: center; gap: var(--s3);
  padding: var(--s3) 0; border-bottom: 1px solid var(--border-xs);
  font-size: 12px; color: var(--text-2);
}
.adjustment-item:last-child { border-bottom: none; }
.adjustment-check {
  width: 18px; height: 18px; border-radius: 5px;
  border: 1.5px solid var(--border-md); flex-shrink: 0; cursor: pointer;
  transition: all var(--ease-fast);
  display: flex; align-items: center; justify-content: center;
}
.adjustment-check.checked { background: var(--primary); border-color: var(--primary); }

/* ─── MODALS — Apple Sheet Style ─────────────────────────── */
.modal-overlay {
  position: fixed; inset: 0;
  background: rgba(0,0,0,.45);
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
  z-index: 1000;
  display: flex; align-items: center; justify-content: center;
  opacity: 0; pointer-events: none;
  transition: opacity 250ms cubic-bezier(0.32, 0.72, 0, 1);
}
.modal-overlay.open { opacity: 1; pointer-events: all; }
.modal {
  background: var(--bg-surface);
  backdrop-filter: blur(40px) saturate(180%);
  -webkit-backdrop-filter: blur(40px) saturate(180%);
  border: 0.5px solid rgba(255,255,255,.1);
  border-radius: var(--r-xl);
  padding: var(--s8);
  padding-top: 24px;
  max-width: 520px;
  width: calc(100% - var(--s8));
  transform: translateY(40px) scale(0.94);
  transition: transform 450ms cubic-bezier(0.32, 0.72, 0, 1);
  box-shadow: var(--shadow-xl);
  position: relative; overflow: hidden;
}
.modal-overlay.open .modal {
  transform: translateY(0) scale(1);
}
.modal::before {
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 0.5px;
  background: rgba(255,255,255,.15);
}
.modal::after {
  content: '';
  position: absolute;
  top: 8px; left: 50%;
  transform: translateX(-50%);
  width: 36px; height: 5px;
  border-radius: 2.5px;
  background: rgba(60,60,67,.3);
  z-index: 1;
}
[data-theme="light"] .modal::after {
  background: rgba(60,60,67,.25);
}
.modal-close {
  position: absolute; top: var(--s4); right: var(--s4);
  width: 30px; height: 30px; border-radius: 50%;
  background: rgba(255,255,255,.08);
  border: none;
  display: flex; align-items: center; justify-content: center;
  color: var(--text-2); cursor: pointer;
  transition: all 150ms cubic-bezier(0.32, 0.72, 0, 1);
}
.modal-close:hover { background: rgba(255,255,255,.14); color: var(--text-1); }
.modal-close:active { transform: scale(0.96); }
.modal-icon {
  width: 52px; height: 52px; border-radius: var(--r-lg);
  display: flex; align-items: center; justify-content: center;
  margin-bottom: var(--s5);
}
.modal-icon.milestone { background: linear-gradient(135deg, var(--primary-dim), rgba(139,92,246,.12)); color: var(--primary); }
.modal-title { font-family: var(--font-display); font-size: 22px; font-weight: 700; letter-spacing: -1px; color: var(--text-1); margin-bottom: var(--s3); }
.modal-sub { font-size: 14px; color: var(--text-2); line-height: 1.6; margin-bottom: var(--s6); }
.modal-actions { display: flex; gap: var(--s3); }

/* Settings modal */
.settings-modal { max-width: 680px; padding: 0; }
.settings-layout { display: grid; grid-template-columns: 180px 1fr; min-height: 480px; }
.settings-nav {
  padding: var(--s6) var(--s4); border-right: 1px solid var(--border-sm);
  display: flex; flex-direction: column; gap: var(--s1);
}
.settings-nav-item {
  padding: 9px var(--s3); border-radius: var(--r-sm);
  font-size: 13px; font-weight: 500; color: var(--text-2);
  cursor: pointer; transition: all var(--ease-fast);
}
.settings-nav-item:hover { background: rgba(255,255,255,.04); color: var(--text-1); }
.settings-nav-item.active { background: rgba(59,130,246,.1); color: var(--primary); }
.settings-content { padding: var(--s6); overflow-y: auto; display: flex; flex-direction: column; gap: var(--s5); }
.settings-nav-title { padding: var(--s5) var(--s3) var(--s4); font-size: 11px; font-weight: 700; color: var(--text-3); text-transform: none; letter-spacing: 0; font-family: var(--font-mono); }
.settings-nav-spacer { flex: 1; }
.settings-nav-close { color: var(--red); }
.settings-close-btn { display: none; }
.settings-modal { position: relative; }
.settings-section-title { font-size: 22px; font-weight: 700; font-family: var(--font-display); color: var(--text-1); letter-spacing: -0.02em; margin-bottom: var(--s4); }
.settings-avatar-row {
  display: flex; align-items: center; gap: 16px; margin-bottom: 20px;
}
.settings-avatar-preview {
  width: 64px; height: 64px; border-radius: 50%; flex-shrink: 0;
  background: var(--primary-dim); border: 2px solid var(--primary-border);
  display: flex; align-items: center; justify-content: center;
  font-size: 24px; font-weight: 800; color: var(--primary);
  font-family: var(--font-display);
}
.settings-avatar-actions { display: flex; flex-direction: column; gap: 4px; }
.settings-field { display: flex; flex-direction: column; gap: 6px; }
.settings-field label { font-size: 13px; font-weight: 500; color: var(--text-2); letter-spacing: -0.005em; }
/* Apple filled text field */
.settings-input {
  background: rgba(118,118,128,.12); border: none;
  border-radius: 10px; padding: 11px var(--s4);
  font-size: 15px; color: var(--text-1); outline: none; width: 100%;
  letter-spacing: -0.01em;
  transition: box-shadow 200ms cubic-bezier(0.32, 0.72, 0, 1);
}
.settings-input:focus { box-shadow: 0 0 0 3px rgba(59,130,246,.3); }
.settings-input::placeholder { color: rgba(255,255,255,.25); }
/* Apple-style settings rows */
.toggle-row {
  display: flex; align-items: center; justify-content: space-between;
  padding: var(--s3) 0; min-height: 44px;
  border-bottom: 0.5px solid rgba(255,255,255,.04);
}
.toggle-row:last-child { border-bottom: none; }
.toggle-info { display: flex; flex-direction: column; gap: 2px; }
.toggle-label { font-size: 15px; font-weight: 500; color: var(--text-1); letter-spacing: -0.01em; }
.toggle-sublabel { font-size: 12px; color: var(--text-2); letter-spacing: -0.005em; }
/* Apple iOS Toggle Switch — 51×31 with shadow knob */
.toggle-switch {
  width: 51px; height: 31px;
  background: rgba(120,120,128,.32);
  border-radius: 15.5px; position: relative; cursor: pointer;
  transition: background 250ms cubic-bezier(0.32, 0.72, 0, 1);
  flex-shrink: 0;
}
.toggle-switch.on { background: #34C759; }
.toggle-switch::after {
  content: ''; position: absolute; top: 2px; left: 2px;
  width: 27px; height: 27px; background: #fff; border-radius: 50%;
  transition: transform 250ms cubic-bezier(0.32, 0.72, 0, 1);
  box-shadow: 0 3px 8px rgba(0,0,0,.15), 0 1px 1px rgba(0,0,0,.06);
}
.toggle-switch.on::after { transform: translateX(20px); }

/* ─── ONBOARDING ──────────────────────────────────────────── */
.onboarding-overlay {
  position: fixed; inset: 0; background: var(--bg-base); z-index: 9999;
  display: flex; flex-direction: column; align-items: center; justify-content: center;
  padding: var(--s8);
}
.onboarding-wrap { width: 100%; max-width: 560px; position: relative; }
.onboarding-logo { display: flex; align-items: center; gap: var(--s3); margin-bottom: var(--s10); justify-content: center; }
.onboarding-steps-indicator { display: flex; gap: var(--s2); margin-bottom: var(--s10); justify-content: center; }
.step-dot { width: 28px; height: 3px; background: var(--border-md); border-radius: 2px; transition: background var(--ease-base); }
.step-dot.done   { background: var(--primary); }
.step-dot.active { background: var(--primary); opacity: .6; }
.onboarding-step { display: none; animation: stepIn var(--ease-slow) forwards; }
.onboarding-step.active { display: block; }
@keyframes stepIn { from { opacity: 0; transform: translateX(20px); } to { opacity: 1; transform: translateX(0); } }
.ob-step-num { font-size: 10px; font-weight: 700; font-family: var(--font-mono); color: var(--primary); letter-spacing: 1.5px; text-transform: none; margin-bottom: var(--s3); }
.ob-step-title { font-family: var(--font-display); font-size: clamp(24px, 4vw, 36px); font-weight: 700; letter-spacing: -1.5px; color: var(--text-1); line-height: 1.05; margin-bottom: var(--s3); }
.ob-step-sub { font-size: 14px; color: var(--text-2); line-height: 1.6; margin-bottom: var(--s8); }
.ob-options { display: grid; grid-template-columns: 1fr 1fr; gap: var(--s3); margin-bottom: var(--s8); }
.ob-option {
  padding: var(--s4) var(--s5); background: var(--bg-surface);
  border: 1.5px solid var(--border-sm); border-radius: var(--r-lg);
  cursor: pointer; transition: all var(--ease-base);
  display: flex; flex-direction: column; gap: var(--s2);
}
.ob-option:hover { border-color: var(--border-md); background: rgba(255,255,255,.05); transform: translateY(-1px); }
.ob-option.selected { border-color: var(--primary); background: rgba(59,130,246,.06); }
.ob-option-emoji { font-size: 20px; color: var(--text-2); display: flex; align-items: center; }
.ob-option.selected .ob-option-emoji { color: var(--primary); }
.ob-option-emoji svg { flex-shrink: 0; }
.ob-option-label { font-size: 14px; font-weight: 700; color: var(--text-1); }
.ob-option-sub   { font-size: 12px; color: var(--text-2); line-height: 1.4; }
.ob-input-field {
  background: rgba(255,255,255,.03); border: 1.5px solid var(--border-sm);
  border-radius: var(--r-lg); padding: var(--s4) var(--s5);
  font-size: 15px; color: var(--text-1); width: 100%; outline: none;
  margin-bottom: var(--s8); transition: all var(--ease-fast);
}
.ob-input-field:focus { border-color: var(--primary-border); box-shadow: 0 0 0 3px rgba(59,130,246,.08); }
.ob-input-field::placeholder { color: var(--text-3); }
.ob-footer { display: flex; align-items: center; justify-content: space-between; gap: var(--s4); }
.ob-back-btn { font-size: 13px; color: var(--text-2); font-weight: 600; cursor: pointer; transition: color var(--ease-fast); }
.ob-back-btn:hover { color: var(--text-1); }

/* Diagnostic */
.diagnostic-card {
  padding: var(--s8); background: var(--bg-surface); backdrop-filter: blur(16px);
  border: 1px solid var(--border-sm); border-radius: var(--r-lg);
  position: relative; overflow: hidden; text-align: center;
}
.diagnostic-card::before { content: ''; position: absolute; top: 0; left: 0; right: 0; height: 1px; background: linear-gradient(90deg, transparent, var(--primary), transparent); }
.diagnostic-score-ring { margin: 0 auto var(--s5); width: 120px; height: 120px; position: relative; }
.diagnostic-score-ring svg { width: 120px; height: 120px; transform: rotate(-90deg); }
.diagnostic-center { position: absolute; inset: 0; display: flex; flex-direction: column; align-items: center; justify-content: center; }
.diagnostic-score-num { font-family: var(--font-display); font-size: 28px; font-weight: 700; color: var(--primary); letter-spacing: -2px; }
.diagnostic-score-sub { font-size: 10px; color: var(--text-3); font-family: var(--font-mono); }
.diagnostic-title { font-family: var(--font-display); font-size: 22px; font-weight: 700; letter-spacing: -1px; color: var(--text-1); margin-bottom: var(--s3); }
.diagnostic-sub { font-size: 14px; color: var(--text-2); line-height: 1.6; margin-bottom: var(--s6); }
.diagnostic-points { display: flex; flex-direction: column; gap: var(--s2); text-align: left; margin-bottom: var(--s6); }
.diagnostic-point { display: flex; align-items: center; gap: var(--s3); font-size: 13px; color: var(--text-2); }
.diagnostic-point::before {
  content: ''; width: 16px; height: 16px; border-radius: 50%;
  background: var(--primary-dim); border: 1.5px solid var(--primary); flex-shrink: 0;
}

/* ─── ANIMATIONS ──────────────────────────────────────────── */
@keyframes fadeUp { from { opacity: 0; transform: translateY(20px); } to { opacity: 1; transform: translateY(0); } }
@keyframes fadeIn { from { opacity: 0; } to { opacity: 1; } }
@keyframes slideInLeft { from { opacity: 0; transform: translateX(-20px); } to { opacity: 1; transform: translateX(0); } }
.animate-up { animation: fadeUp var(--ease-slow) both; }
.animate-in { animation: fadeIn var(--ease-slow) both; }

/* Skeleton */
.skeleton {
  background: linear-gradient(90deg, rgba(255,255,255,.04) 25%, rgba(255,255,255,.08) 50%, rgba(255,255,255,.04) 75%);
  background-size: 400% 100%; animation: shimmer 1.5s ease infinite; border-radius: var(--r-sm);
}
@keyframes shimmer { 0% { background-position: -468px 0; } 100% { background-position: 468px 0; } }

/* Typing cursor */
.typing-cursor { display: inline-block; width: 2px; height: 1em; background: var(--primary); margin-left: 2px; animation: blink 1s step-end infinite; vertical-align: text-bottom; }
@keyframes blink { 0%,100% { opacity: 1; } 50% { opacity: 0; } }

/* Milestone animation */
@keyframes milestoneIn { 0% { transform: scale(.5) rotate(-10deg); opacity: 0; } 60% { transform: scale(1.1) rotate(2deg); opacity: 1; } 100% { transform: scale(1) rotate(0); opacity: 1; } }
.milestone-icon-anim { animation: milestoneIn var(--ease-spring) both; }

/* ─── TOAST ───────────────────────────────────────────────── */
.toast-container {
  position: fixed; bottom: var(--s8); right: var(--s8);
  display: flex; flex-direction: column; gap: var(--s3);
  z-index: 9000; pointer-events: none;
}
.toast {
  pointer-events: all; padding: var(--s3) var(--s5);
  background: var(--bg-glass); backdrop-filter: blur(20px);
  border: 1px solid var(--border-md); border-radius: var(--r-lg);
  box-shadow: 0 8px 32px rgba(0,0,0,.4);
  display: flex; align-items: center; gap: var(--s3);
  font-size: 13px; font-weight: 600; color: var(--text-1);
  min-width: 260px;
  transform: translateX(300px); transition: transform var(--ease-slow), opacity var(--ease-base); opacity: 0;
}
.toast.show { transform: translateX(0); opacity: 1; }
.toast.hide { transform: translateX(300px); opacity: 0; }
.toast-icon { font-size: 16px; }
.toast.success { border-color: var(--primary-border); }
.toast.success .toast-icon { color: var(--primary); }

/* ─── GRADIENT TEXT — Apple uses solid colors ────────────── */
.gradient-text {
  color: var(--primary);
  -webkit-text-fill-color: var(--primary);
}
.gradient-text-flow {
  color: var(--primary);
  -webkit-text-fill-color: var(--primary);
  animation: none;
}
@keyframes gradientFlow { 0% { background-position: 0% center; } 100% { background-position: 200% center; } }

/* ─── REVEAL ON ENTRY ─────────────────────────────────────── */
.reveal { opacity: 0; transform: translateY(32px); transition: opacity 0.7s cubic-bezier(.4,0,.2,1), transform 0.7s cubic-bezier(.4,0,.2,1); }
.reveal.visible { opacity: 1; transform: translateY(0); }
.reveal-left { opacity: 0; transform: translateX(-32px); transition: opacity 0.7s cubic-bezier(.4,0,.2,1), transform 0.7s cubic-bezier(.4,0,.2,1); }
.reveal-left.visible { opacity: 1; transform: translateX(0); }
.reveal-scale { opacity: 0; transform: scale(0.92); transition: opacity 0.6s cubic-bezier(.34,1.56,.64,1), transform 0.6s cubic-bezier(.34,1.56,.64,1); }
.reveal-scale.visible { opacity: 1; transform: scale(1); }
.stagger-reveal > * { opacity: 0; transform: translateY(20px); transition: opacity 0.5s cubic-bezier(.4,0,.2,1), transform 0.5s cubic-bezier(.4,0,.2,1); }
.stagger-reveal.visible > *:nth-child(1) { opacity: 1; transform: translateY(0); transition-delay: 0ms; }
.stagger-reveal.visible > *:nth-child(2) { opacity: 1; transform: translateY(0); transition-delay: 80ms; }
.stagger-reveal.visible > *:nth-child(3) { opacity: 1; transform: translateY(0); transition-delay: 160ms; }
.stagger-reveal.visible > *:nth-child(4) { opacity: 1; transform: translateY(0); transition-delay: 240ms; }
.stagger-reveal.visible > *:nth-child(5) { opacity: 1; transform: translateY(0); transition-delay: 320ms; }
.stagger-reveal.visible > *:nth-child(6) { opacity: 1; transform: translateY(0); transition-delay: 400ms; }
.stagger-reveal.visible > *:nth-child(7) { opacity: 1; transform: translateY(0); transition-delay: 480ms; }
.stagger-reveal.visible > *:nth-child(8) { opacity: 1; transform: translateY(0); transition-delay: 560ms; }

/* ─── 3D / TILT / MAGNETIC — disabled (not Apple) ────────── */
.tilt-card { transition: transform 0.15s cubic-bezier(0.32, 0.72, 0, 1); }
.tilt-card:hover { box-shadow: none; }
.magnetic { transition: transform 0.3s cubic-bezier(.34,1.56,.64,1); will-change: transform; position: relative; }

/* ─── GLITCH / GLOW / SCAN / FLOAT — all disabled (not Apple) ─── */
.glitch::before, .glitch::after { display: none; }
.glow-border::before { display: none; }
.float-anim { animation: none; }
.scan-container::after { display: none; }
.grid-bg::before { display: none; }

/* ─── UTILS ───────────────────────────────────────────────── */
.flex { display: flex; }
.flex-col { display: flex; flex-direction: column; }
.items-center { align-items: center; }
.justify-between { justify-content: space-between; }
.gap-2 { gap: var(--s2); }
.gap-3 { gap: var(--s3); }
.gap-4 { gap: var(--s4); }
.gap-5 { gap: var(--s5); }
.mt-2 { margin-top: var(--s2); }
.mt-4 { margin-top: var(--s4); }
.mt-5 { margin-top: var(--s5); }
.mt-6 { margin-top: var(--s6); }
.mt-8 { margin-top: var(--s8); }
.mb-4 { margin-bottom: var(--s4); }
.mb-5 { margin-bottom: var(--s5); }
.mb-6 { margin-bottom: var(--s6); }
.mb-8 { margin-bottom: var(--s8); }
.w-full { width: 100%; }
.text-primary  { color: var(--primary) !important; }
.text-2 { color: var(--text-2); }
.text-3 { color: var(--text-3); }
.font-mono { font-family: var(--font-mono); }
.font-display { font-family: var(--font-display); }
.text-sm { font-size: 12px; }
.text-xs { font-size: 11px; }
.font-bold { font-weight: 700; }
.truncate { white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.opacity-0 { opacity: 0; }
.pointer { cursor: pointer; }
.select-none { user-select: none; }

/* ═══════════════════════════════════════════════════════════
   POLISH & HARMONY — micro-interactions, refinements, depth
   ═══════════════════════════════════════════════════════════ */

/* ── CMD ACCENT — Apple blue, no gradient text ────────────── */
.cmd-accent {
  color: var(--primary);
  -webkit-text-fill-color: var(--primary);
}

/* ── CMD HERO — Apple clean, no scan line ────────────────── */
.cmd-hero {
  overflow: hidden;
}
.cmd-hero::after { display: none; }

/* ── DIAL — Apple clean, no pulse ─────────────────────────── */
.dial-wrap::after { display: none; }

/* ── DIAL STATUS BADGE ───────────────────────────────────── */
.dial-status {
  position: absolute;
  bottom: -2px;
  left: 50%;
  transform: translateX(-50%);
  display: flex;
  align-items: center;
  gap: 5px;
  font-family: var(--font-body);
  font-size: 11px;
  font-weight: 500;
  letter-spacing: 0;
  text-transform: none;
  color: var(--secondary);
  white-space: nowrap;
}
.dial-status-dot {
  width: 5px; height: 5px;
  border-radius: 50%;
  background: var(--secondary);
  box-shadow: none;
  animation: pulse 2s ease-in-out infinite;
  flex-shrink: 0;
}

/* ── SEARCH KEYBOARD HINT ────────────────────────────────── */
.search-kbd {
  position: absolute;
  right: 10px; top: 50%;
  transform: translateY(-50%);
  font-family: var(--font-mono);
  font-size: 10px;
  color: var(--text-3);
  background: rgba(255,255,255,0.04);
  border: 1px solid var(--border-sm);
  border-radius: 5px;
  padding: 2px 6px;
  letter-spacing: 0;
  pointer-events: none;
  transition: opacity var(--ease-fast);
}
.topbar-search:focus-within .search-kbd { opacity: 0; }

/* ── PAGES CONTAINER — Apple clean ────────────────────────── */
.pages-container {
  background: transparent;
}

/* ── METRICS STRIP — Apple clean ──────────────────────────── */
.metrics-strip {
  box-shadow: none;
}
.metric-item {
  border-radius: var(--r-sm);
  transition: background var(--ease-fast);
  cursor: default;
}
.metric-item:hover { background: rgba(255,255,255,0.025); }

/* ── SECTION CARDS — Apple clean ────────────────────────── */
.wk-plan,
.mission-min {
  box-shadow: none;
  transition: border-color var(--ease-base);
}

/* ── WEEK DAY refinements ────────────────────────────────── */
.wk-day:not(.done):not(.today):hover {
  border-color: rgba(255,255,255,0.07);
  background: rgba(255,255,255,0.02);
}
.wk-day.today {
  background: var(--primary-dim);
  border-color: var(--primary-border);
  box-shadow: none;
}

/* ── MISSION MIN hover ───────────────────────────────────── */
.mission-min:hover {
  border-color: var(--border-md);
  box-shadow: none;
}

/* ── BTN GHOST refinement in hero ────────────────────────── */
.cmd-actions .btn-ghost {
  color: var(--text-2);
  font-size: 13px;
  padding: 9px 16px;
}
.cmd-actions .btn-ghost:hover {
  color: var(--text-1);
  border-color: var(--border-md);
}

/* ── NAV ITEM active — Apple solid tint ─────────────────── */
.nav-item.active {
  background: var(--primary-dim);
  border-color: transparent;
}
.nav-item.active .nav-label { color: var(--primary); font-weight: 600; }

/* ── SECTION TITLE — Apple clean ─────────────────────────── */
.wk-header .section-title,
.section-header .section-title {
  letter-spacing: -0.01em;
}

/* ── CARD hover — Apple clean ─────────────────────────────── */
.card:hover {
  box-shadow: none;
}

/* ── TOPBAR search input padding right for kbd ───────────── */
.topbar-search input { padding-right: 44px; }

/* ─── MOBILE ─────────────────────────────────────────────── */
.mobile-menu-btn {
  display: none;
  width: 34px; height: 34px;
  border-radius: 50%;
  border: none;
  align-items: center; justify-content: center;
  color: var(--text-2);
  background: rgba(255,255,255,.06);
  cursor: pointer;
  flex-shrink: 0;
  transition: background 150ms cubic-bezier(0.32, 0.72, 0, 1), color 150ms cubic-bezier(0.32, 0.72, 0, 1), transform 100ms cubic-bezier(0.32, 0.72, 0, 1);
}
.mobile-menu-btn:hover { background: rgba(255,255,255,.12); color: var(--text-1); }
.mobile-menu-btn:active { transform: scale(0.96); }
.mobile-overlay {
  display: none; position: fixed; inset: 0; z-index: 99;
  background: rgba(0,0,0,.6);
  opacity: 0; transition: opacity var(--ease-base); pointer-events: none;
}
.mobile-overlay.visible { opacity: 1; pointer-events: all; display: block; }

/* ─── TABLET (769–1100px) ─────────────────────────────────── */
@media (min-width: 769px) and (max-width: 1100px) {
  .cmd-hero {
    grid-template-columns: 1fr 300px;
    gap: var(--s8);
    min-height: 400px;
    padding: var(--s8) 0 var(--s6);
  }
  .dial-wrap { width: 280px; height: 280px; }
  .dial-num { font-size: 58px; }
  .cmd-headline { font-size: clamp(36px, 4vw, 50px); }
  .metrics-strip { padding: var(--s4) var(--s5); }
  .metric-val { font-size: 28px; }
  .page { padding: var(--s5) var(--s6) var(--s14); }
}

/* ─── MOBILE (≤768px) ─────────────────────────────────────── */
@media (max-width: 768px) {
  /* ── Layout base ── */
  .mobile-menu-btn { display: flex; }
  .sidebar {
    position: fixed; left: -260px; top: 0; bottom: 0;
    width: 260px; z-index: 300;
    overflow: hidden;
    transition: left var(--ease-slow);
    border-right: 1px solid var(--border-sm);
  }
  .sidebar.mobile-open { left: 0; box-shadow: 24px 0 80px rgba(0,0,0,.6); }
  .sb-toggle { display: none; }
  .mobile-overlay { z-index: 299; }
  .mobile-overlay.visible { display: block; }
  /* CRITICAL: remove stacking context from app-layout so sidebar z-index:300 beats overlay z-index:299 at root */
  .app-layout { grid-template-columns: 1fr !important; z-index: auto !important; }
  .main-content { width: 100% !important; overflow-x: hidden; }
  body { overflow-x: hidden; }
  .pages-container { overflow-x: hidden; }
  /* Topbar: compact on mobile — hamburger is now inside flex flow */
  .topbar { padding: 0 var(--s3); gap: 0; max-width: 100vw; }
  .topbar-search { display: none; }
  .topbar-actions { gap: 6px; flex-shrink: 0; flex: 1; margin-left: 0; }
  .mobile-menu-btn svg { width: 15px; height: 15px; }
  /* Hide less essential toggles on mobile — accessible via sidebar */
  .theme-toggle-btn { display: flex !important; }
  .advanced-toggle-btn { display: none !important; }
  /* All icon buttons uniform 34px */
  .topbar-icon-btn { width: 34px; height: 34px; }
  .topbar-icon-btn svg { width: 15px; height: 15px; }
  .theme-toggle-btn { width: 34px; height: 34px; }
  /* Hide less essential items on mobile */
  .xp-pill { display: none; }
  /* Create button: prominent center, slightly larger */
  .btn-create-quick { font-size: 0; gap: 0; padding: 0; width: 36px; height: 36px; min-width: 36px; border-radius: 50%; display: flex; align-items: center; justify-content: center; margin: 0 auto; }
  .btn-create-quick svg { width: 14px; height: 14px; }
  .page { padding: var(--s4) var(--s4) 90px; max-width: 100%; overflow-x: hidden; }

  /* ── Dropdowns mobile: fixed to escape overflow:hidden parents ── */
  .avatar-dropdown {
    position: fixed;
    top: 58px;
    right: var(--s3);
    z-index: 400;
  }
  .notif-dropdown {
    position: fixed;
    top: 58px;
    right: var(--s3);
    left: var(--s3);
    min-width: 0;
    z-index: 400;
  }

  /* ── Activity ticker mobile: hide for cleaner look ── */
  .activity-ticker { display: none; }

  /* ── Danger banner mobile ── */
  .streak-danger-banner {
    flex-wrap: wrap;
    gap: var(--s2);
    padding: var(--s3);
    font-size: 12px;
  }
  .streak-danger-banner span { flex: 1; min-width: 0; }
  .streak-danger-banner > button:not(.banner-dismiss) {
    margin-left: 0;
    font-size: 10.5px;
    padding: 4px 10px;
  }

  /* ── Home — CMD Hero ── */
  .cmd-hero {
    grid-template-columns: 1fr;
    gap: var(--s3);
    padding: var(--s2) 0 var(--s1);
    min-height: auto;
  }
  .cmd-hero-right { order: -1; }
  .cmd-hero::before { display: none; }
  .dial-wrap { width: 180px; height: 180px; }
  .dial-num { font-size: 42px; }
  .dial-name { font-size: 9px; }
  .dial-desc { display: none; }
  .dial-social-proof { display: none; }
  .dial-status { display: none; }
  .cmd-headline { font-size: clamp(24px, 7vw, 32px); margin-bottom: var(--s1); }
  .cmd-sub { font-size: 12px; margin-bottom: var(--s3); max-width: 100%; }
  .cmd-label { display: none; }
  .phase-progress { margin-bottom: var(--s2); }
  .phase-bar-label { font-size: 10px; }
  .cmd-actions { gap: var(--s2); }
  .cmd-actions .btn-ghost { display: none; }

  /* ── Home — Metrics strip ── */
  .metrics-strip {
    display: grid;
    grid-template-columns: 1fr 1fr;
    grid-auto-rows: 1fr;
    padding: 0;
    gap: 1px;
    background: var(--border-sm);
    border-radius: var(--r-lg);
    overflow: hidden;
  }
  .metric-item {
    background: var(--bg-surface);
    padding: var(--s4) var(--s3);
    text-align: center;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
  }
  .metric-divider { display: none; }
  .metric-val { font-size: 24px; }
  .streak-flame-wrap { display: none !important; }
  .metric-lbl { font-size: 9px; }
  .metric-delta-lbl { font-size: 9px; }

  /* ── Daily tasks mobile ── */
  .daily-tasks { padding: var(--s4); }
  .task-text { font-size: 12.5px; }
  .task-exec-btn { font-size: 10px; padding: 6px 12px; min-height: 36px; }
  .tasks-footer { font-size: 10.5px; }
  .tasks-reset-row { font-size: 10px; }

  /* ── Intel row mobile ── */
  .intel-row { grid-template-columns: 1fr; }
  .intel-body { font-size: 12.5px; }

  /* ── Home — Week strip ── */
  .wk-strip { grid-template-columns: repeat(5, 1fr); gap: var(--s2); }
  .wk-plan { padding: var(--s4); }
  .wk-day-type { font-size: 9px; }
  .wk-day-name { font-size: 8px; }
  .wk-day { padding: var(--s2) var(--s1); }

  /* ── Home — Mission ── */
  .mission-min {
    grid-template-columns: 1fr;
    gap: var(--s3);
    padding: var(--s4);
  }
  .mission-min-label {
    border-right: none;
    padding-right: 0;
    border-bottom: 1px solid var(--border-sm);
    padding-bottom: var(--s3);
    writing-mode: horizontal-tb;
  }
  .mission-min-actions { flex-direction: row; min-width: unset; flex-wrap: wrap; }

  /* ── Other pages ── */
  .growth-grid { grid-template-columns: 1fr !important; }
  .growth-domain-grid { grid-template-columns: 1fr 1fr !important; }
  .templates-grid { grid-template-columns: 1fr !important; }
  .planner-grid { grid-template-columns: repeat(3, 1fr) !important; }
  .create-layout.with-result { grid-template-columns: 1fr !important; }
  .settings-layout { grid-template-columns: 1fr !important; }
  .settings-nav {
    flex-direction: row; overflow-x: auto;
    border-right: none; border-bottom: 1px solid var(--border-sm);
    padding: var(--s3); flex-wrap: nowrap; scrollbar-width: none;
  }
  .settings-nav::-webkit-scrollbar { display: none; }
  .settings-nav-title { display: none !important; }
  .settings-nav-spacer { display: none !important; }
  .settings-nav-close { display: none !important; }
  .settings-nav-item { white-space: nowrap; flex-shrink: 0; }
  .settings-close-btn { display: flex !important; }
  .balance-header { flex-direction: column; gap: var(--s2); }
  .planner-toolbar { flex-direction: column; align-items: flex-start; gap: var(--s3); }
  .page-title { font-size: clamp(28px, 7vw, 40px); }
}

/* ─── SMALL MOBILE (≤480px) ──────────────────────────────── */
@media (max-width: 480px) {
  .growth-domain-grid { grid-template-columns: 1fr !important; }
  .planner-grid { grid-template-columns: 1fr 1fr !important; }
  .ob-options { grid-template-columns: 1fr !important; }
  .btn-create-quick span:not(svg) { display: none; }
  .topbar-search input { font-size: 12px; }
  .wk-strip { grid-template-columns: repeat(5, 1fr); gap: var(--s1); }
  .cmd-headline { font-size: 28px; }
  .dial-wrap { width: 170px; height: 170px; }
  .dial-num { font-size: 40px; }
}

/* ═══════════════════════════════════════════════════════════
   DOPAMINE LAYER — phase progress, tasks, intel, toast
   ═══════════════════════════════════════════════════════════ */

/* ── ACTIVITY TICKER ────────────────────────────────────── */
.activity-ticker {
  overflow: hidden;
  border: 1px solid var(--border-sm);
  border-radius: var(--r-md);
  background: var(--bg-surface);
  padding: 7px 0;
  margin-bottom: var(--s4);
  position: relative;
  box-shadow: none;
}
/* Fade masks on left/right edges */
.activity-ticker::before,
.activity-ticker::after {
  content: '';
  position: absolute;
  top: 0; bottom: 0;
  width: 60px;
  z-index: 1;
  pointer-events: none;
}
.activity-ticker::before {
  left: 0;
  background: linear-gradient(to right, var(--bg-base), transparent);
}
.activity-ticker::after {
  right: 0;
  background: linear-gradient(to left, var(--bg-base), transparent);
}
.ticker-track {
  display: inline-flex;
  white-space: nowrap;
  animation: tickerScroll 40s linear infinite;
  font-size: 12px;
  color: var(--text-3);
  font-family: var(--font-body);
  letter-spacing: 0;
  user-select: none;
}
.ticker-track span { display: inline-block; }
.ticker-track span:first-child { color: var(--secondary); }
@keyframes tickerScroll {
  from { transform: translateX(0); }
  to   { transform: translateX(-50%); }
}
.activity-ticker:hover .ticker-track { animation-play-state: paused; }

/* Light mode ticker */
[data-theme="light"] .activity-ticker {
  background: #FFFFFF;
  border-color: rgba(0,0,0,0.08);
}
[data-theme="light"] .activity-ticker::before {
  background: linear-gradient(to right, var(--bg-base), transparent);
}
[data-theme="light"] .activity-ticker::after {
  background: linear-gradient(to left, var(--bg-base), transparent);
}

/* ── PHASE PROGRESS ──────────────────────────────────────── */
.phase-progress {
  display: flex;
  flex-direction: column;
  gap: 7px;
  margin-bottom: var(--s6);
}
.phase-progress-top {
  display: flex;
  align-items: center;
  gap: var(--s3);
}
.phase-badge {
  font-family: var(--font-body);
  font-size: 11px;
  font-weight: 600;
  letter-spacing: 0;
  text-transform: none;
  color: var(--primary);
  background: var(--primary-dim);
  border: none;
  padding: 3px 10px;
  border-radius: 20px;
}
.phase-progress-name {
  font-size: 12px;
  color: var(--text-3);
  font-family: var(--font-body);
  letter-spacing: 0;
}
.phase-bar-row {
  display: flex;
  align-items: center;
  gap: var(--s3);
}
.phase-bar-track {
  flex: 0 0 160px;
  height: 2px;
  background: rgba(255,255,255,0.06);
  border-radius: 1px;
  overflow: hidden;
}
.phase-bar-fill {
  height: 100%;
  background: var(--primary);
  border-radius: 1px;
  transition: width 1.6s cubic-bezier(0.4,0,0.2,1);
}
.phase-bar-label {
  font-size: 11px;
  color: var(--text-3);
  font-family: var(--font-body);
  letter-spacing: 0;
  white-space: nowrap;
  font-variant-numeric: tabular-nums;
}

/* ── DAILY TASKS ─────────────────────────────────────────── */
.daily-tasks {
  background: var(--bg-surface);
  border: 1px solid var(--border-sm);
  border-radius: var(--r-lg);
  padding: var(--s5) var(--s6);
  margin-bottom: var(--s4);
  box-shadow: inset 0 1px 0 rgba(255,255,255,0.05);
  transition: border-color var(--ease-base);
}
.daily-tasks-header {
  display: flex;
  flex-direction: column;
  gap: var(--s2);
  margin-bottom: var(--s4);
}
.daily-tasks-title-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
}
.daily-tasks-label {
  font-family: var(--font-mono);
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0;
  text-transform: none;
  color: var(--text-3);
}
.daily-tasks-count {
  font-family: var(--font-mono);
  font-size: 12px;
  font-weight: 700;
  color: var(--primary);
}
.daily-tasks-count span {
  color: var(--text-3);
  font-weight: 400;
  margin: 0 1px;
}
.daily-tasks-bar {
  height: 2px;
  background: rgba(255,255,255,0.05);
  border-radius: 1px;
  overflow: hidden;
}
.daily-tasks-bar-fill {
  height: 100%;
  background: linear-gradient(90deg, var(--primary), var(--accent));
  border-radius: 1px;
  transition: width 0.8s cubic-bezier(0.4,0,0.2,1);
}
.tasks-list {
  display: flex;
  flex-direction: column;
  gap: 3px;
}
.task-item {
  display: flex;
  align-items: center;
  gap: var(--s3);
  padding: 9px var(--s3);
  border-radius: var(--r-md);
  border: 1px solid transparent;
  cursor: pointer;
  transition: all var(--ease-fast);
}
.task-item.pending:hover {
  background: rgba(99,102,241,0.04);
  border-color: rgba(99,102,241,0.14);
}
.task-item.done { cursor: default; }
.task-check-visual {
  width: 18px;
  height: 18px;
  border-radius: 50%;
  border: 1.5px solid rgba(255,255,255,0.14);
  flex-shrink: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  color: transparent;
  transition: all 0.4s cubic-bezier(0.34,1.56,0.64,1);
}
.task-check-visual.done {
  background: var(--secondary);
  border-color: var(--secondary);
  color: #07080E;
  box-shadow: 0 0 10px rgba(16,185,129,0.35);
}
.task-check-visual.in-progress {
  border-color: #FF9F0A;
  color: #FF9F0A;
  animation: task-spin 3s linear infinite;
}
@keyframes task-spin {
  to { transform: rotate(360deg); }
}
.task-item.in-progress {
  /* Apple: no accent border */
}
.task-body {
  flex: 1;
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 2px;
  min-width: 0;
}
.task-text {
  font-size: 13.5px;
  color: var(--text-1);
  font-weight: 500;
  line-height: 1.35;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}
.task-item.done .task-text {
  text-decoration: line-through;
  color: var(--text-3);
}
.task-pts {
  font-size: 11px;
  color: var(--text-2);
  font-weight: 500;
  flex-shrink: 0;
  transition: opacity var(--ease-fast);
}
.task-item.done .task-pts { opacity: 0.3; }
.task-exec-btn {
  background: rgba(99,102,241,0.12);
  border: 1px solid rgba(99,102,241,0.24);
  color: var(--primary);
  font-size: 11px;
  font-weight: 700;
  padding: 4px 13px;
  border-radius: 20px;
  cursor: pointer;
  transition: all var(--ease-fast);
  font-family: var(--font-display);
  letter-spacing: 0.02em;
  white-space: nowrap;
  flex-shrink: 0;
}
.task-exec-btn:hover {
  background: rgba(99,102,241,0.22);
  border-color: rgba(99,102,241,0.4);
  transform: translateX(2px);
}
.tasks-footer {
  display: flex;
  align-items: flex-start;
  gap: var(--s2);
  margin-top: var(--s4);
  padding-top: var(--s3);
  border-top: 1px solid var(--border-sm);
  font-size: 11px;
  color: var(--text-3);
  font-family: var(--font-mono);
  letter-spacing: 0;
  line-height: 1.5;
  flex-wrap: wrap;
}
.tasks-footer strong { color: var(--text-2); font-weight: 600; }
.tasks-footer svg { flex-shrink: 0; color: var(--primary); opacity: 0.45; }
.tasks-footer.complete { color: var(--secondary); }
.tasks-footer.complete svg { color: var(--secondary); opacity: 0.8; }

/* ── INTELLIGENCE ROW ────────────────────────────────────── */
.intel-row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--s4);
  margin-bottom: var(--s4);
}
.intel-card {
  background: var(--bg-surface);
  border: 1px solid var(--border-sm);
  border-radius: var(--r-lg);
  padding: var(--s5);
  display: flex;
  flex-direction: column;
  gap: var(--s3);
  box-shadow: inset 0 1px 0 rgba(255,255,255,0.04);
  transition: all var(--ease-base);
}
.intel-card:hover {
  border-color: rgba(255,255,255,0.1);
  transform: translateY(-2px);
  box-shadow: inset 0 1px 0 rgba(255,255,255,0.06), 0 6px 24px rgba(0,0,0,0.18);
}
.intel-card-top {
  display: flex;
  align-items: center;
  justify-content: space-between;
}
.intel-label {
  font-family: var(--font-mono);
  font-size: 9.5px;
  font-weight: 700;
  letter-spacing: 0;
  text-transform: none;
  color: var(--text-3);
}
.intel-badge {
  font-size: 9px;
  font-weight: 700;
  padding: 2px 9px;
  border-radius: 20px;
  font-family: var(--font-mono);
  letter-spacing: 0;
  text-transform: none;
}
.intel-badge.amber {
  color: var(--cta);
  background: rgba(245,158,11,0.1);
  border: 1px solid rgba(245,158,11,0.2);
}
.intel-badge.green {
  color: var(--secondary);
  background: rgba(16,185,129,0.1);
  border: 1px solid rgba(16,185,129,0.2);
}
.intel-body {
  font-size: 12.5px;
  color: var(--text-2);
  line-height: 1.45;
  margin: 0;
  flex: 1;
}
.intel-action {
  background: var(--primary-dim);
  border: 1px solid var(--primary-border);
  font-size: 12px;
  color: var(--primary);
  font-weight: 700;
  cursor: pointer;
  padding: 8px 14px;
  text-align: center;
  font-family: var(--font-display);
  transition: all var(--ease-fast);
  letter-spacing: 0.01em;
  border-radius: var(--r-md);
  width: 100%;
  margin-top: auto;
}
.intel-action:hover {
  background: var(--primary-glow);
  transform: translateY(-1px);
}

/* ─── RANKING PAGE ────────────────────────────────────────── */
.rp-statsbar {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 0;
  background: var(--bg-surface);
  border: 1px solid var(--border-sm);
  border-radius: var(--r-lg);
  overflow: hidden;
  margin-bottom: var(--s5);
}
.rp-stat {
  padding: var(--s4) var(--s5);
  display: flex;
  flex-direction: column;
  gap: 5px;
  position: relative;
}
.rp-stat-divider {
  width: 1px;
  background: var(--border-sm);
  margin: var(--s3) 0;
}
.rp-stat-label {
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0;
  text-transform: none;
  color: var(--text-3);
}
.rp-stat-value {
  font-size: 22px;
  font-weight: 800;
  color: var(--text-1);
  letter-spacing: -.5px;
}
.rp-stat-value.green { color: #30D158; }
.rp-stat-value.gold  { color: #FF9F0A; }
.rp-stat-value.mono  { font-family: var(--font-mono); font-size: 16px; }

.rp-podium { margin-bottom: var(--s5); }

.rp-list-wrap {
  background: var(--bg-surface);
  border: 1px solid var(--border-sm);
  border-radius: var(--r-lg);
  overflow: hidden;
  margin-bottom: var(--s5);
}
.rp-list-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: var(--s4) var(--s5);
  border-bottom: 1px solid var(--border-sm);
  font-size: 12px;
  font-weight: 700;
  color: var(--text-2);
  letter-spacing: 0;
  text-transform: none;
}
.rp-update-note {
  font-size: 10px;
  font-weight: 500;
  color: var(--text-3);
  text-transform: none;
  letter-spacing: 0;
}
.rp-list-wrap .ranking-list { padding: var(--s2) var(--s3) var(--s3); }

/* Nav ranking badge */
.nav-ranking-badge {
  margin-left: auto;
  width: 7px; height: 7px;
  border-radius: 50%;
  background: #FF9F0A;
  animation: navDotPulse 2.5s ease-in-out infinite;
}

/* Motivation footer */
.rp-motivation {
  background: linear-gradient(135deg, rgba(245,158,11,.08), rgba(99,102,241,.06));
  border: 1px solid rgba(245,158,11,.15);
  border-radius: var(--r-lg);
  padding: var(--s5) var(--s6);
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--s4);
}
.rp-motivation-text {
  font-size: 14px;
  color: var(--text-2);
  line-height: 1.6;
}
.rp-motivation-text strong { color: var(--text-1); }

/* Light mode */
[data-theme="light"] .rp-statsbar { background: #fff; }
[data-theme="light"] .rp-list-wrap { background: #fff; }

/* Mobile */
@media (max-width: 768px) {
  .rp-statsbar { grid-template-columns: repeat(2, 1fr); }
  .rp-stat-divider:nth-child(2) { display: none; }
  .rp-stat-divider:nth-child(4) { display: none; }
  .rp-stat:nth-child(1) { border-bottom: 1px solid var(--border-sm); }
  .rp-stat:nth-child(3) { border-bottom: 1px solid var(--border-sm); }
}

/* ─── WEEKLY RANKING ─────────────────────────────────────── */
.weekly-ranking {
  background: var(--bg-surface);
  border: 1px solid var(--border-sm);
  border-radius: var(--r-lg);
  padding: var(--s6);
  margin-top: var(--s5);
}
.ranking-header {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: var(--s4);
  margin-bottom: var(--s5);
}
.ranking-eyebrow {
  display: flex;
  align-items: center;
  gap: 5px;
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0;
  color: #FF9F0A;
  text-transform: none;
  margin-bottom: 4px;
}
.ranking-title {
  font-size: 15px;
  font-weight: 700;
  color: var(--text-1);
  letter-spacing: -.3px;
}
.ranking-resets {
  font-size: 11px;
  color: var(--text-3);
  background: rgba(255,255,255,.04);
  border: 1px solid var(--border-sm);
  padding: 4px 10px;
  border-radius: var(--r-full);
  white-space: nowrap;
  flex-shrink: 0;
}
.ranking-resets span {
  color: var(--text-2);
  font-weight: 600;
  font-family: var(--font-mono);
}

/* ── Podium ── */
.ranking-podium {
  display: flex;
  align-items: flex-end;
  justify-content: center;
  gap: 8px;
  margin-bottom: var(--s5);
}
.podium-item {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 6px;
  flex: 1;
  max-width: 115px;
}
.podium-medal {
  height: 22px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 17px;
}
.podium-avatar {
  width: 44px; height: 44px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 13px;
  font-weight: 700;
  color: #fff;
  border: 2px solid rgba(255,255,255,.08);
  transition: box-shadow var(--ease-base);
}
.podium-1 .podium-avatar {
  width: 56px; height: 56px;
  font-size: 15px;
  border-color: #FF9F0A;
  animation: podiumGlow 3s ease-in-out infinite;
}
@keyframes podiumGlow {
  0%,100% { box-shadow: 0 0 20px rgba(245,158,11,.4), 0 0 0 4px rgba(245,158,11,.07); }
  50%      { box-shadow: 0 0 34px rgba(245,158,11,.65), 0 0 0 6px rgba(245,158,11,.13); }
}
.podium-2 .podium-avatar { border-color: rgba(148,163,184,.3); }
.podium-3 .podium-avatar { border-color: rgba(180,128,80,.3); }
.podium-you .podium-avatar {
  border-color: var(--primary) !important;
  box-shadow: none !important;
  animation: none !important;
}
.podium-name {
  font-size: 12px;
  font-weight: 600;
  color: var(--text-2);
  text-align: center;
  white-space: nowrap;
}
.podium-1 .podium-name  { color: var(--text-1); }
.podium-you .podium-name { color: var(--primary); }
.podium-pct {
  font-size: 13px;
  font-weight: 800;
  color: #30D158;
  letter-spacing: -.3px;
}
.podium-1 .podium-pct { font-size: 15px; color: #FF9F0A; }
.podium-plinth {
  width: 100%;
  border-radius: 6px 6px 0 0;
  display: flex;
  align-items: center;
  justify-content: center;
}
.podium-1 .podium-plinth {
  min-height: 68px;
  background: linear-gradient(180deg, rgba(245,158,11,.17) 0%, rgba(245,158,11,.04) 100%);
  border: 1px solid rgba(245,158,11,.22); border-bottom: none;
}
.podium-2 .podium-plinth {
  min-height: 50px;
  background: rgba(148,163,184,.04);
  border: 1px solid rgba(148,163,184,.1); border-bottom: none;
}
.podium-3 .podium-plinth {
  min-height: 36px;
  background: rgba(180,128,80,.04);
  border: 1px solid rgba(180,128,80,.1); border-bottom: none;
}
.podium-rank {
  font-size: 14px; font-weight: 800; color: var(--text-3);
}
.podium-1 .podium-rank { color: #FF9F0A; font-size: 16px; }
.podium-2 .podium-rank { color: rgba(148,163,184,.65); }
.podium-3 .podium-rank { color: rgba(180,128,80,.65); }

/* ── Urgency CTA ── */
.ranking-urgency {
  background: linear-gradient(135deg, rgba(245,158,11,.07), rgba(99,102,241,.04));
  border: 1px solid rgba(245,158,11,.18);
  border-radius: var(--r-lg);
  padding: var(--s4) var(--s5);
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--s4);
  margin-bottom: var(--s4);
}
.ranking-urgency.winning {
  background: linear-gradient(135deg, rgba(16,185,129,.07), rgba(99,102,241,.04));
  border-color: rgba(16,185,129,.2);
}
.ranking-urgency-text {
  font-size: 13px;
  color: var(--text-2);
  line-height: 1.55;
  flex: 1;
}
.ranking-urgency-text strong { color: var(--text-1); }
.ranking-urgency-accent { color: #FF9F0A; font-weight: 700; }
.ranking-urgency.winning .ranking-urgency-accent { color: #30D158; }
.ranking-urgency-btn {
  flex-shrink: 0;
  padding: 8px 14px;
  background: linear-gradient(135deg, #FF9F0A, #FF453A);
  color: #fff;
  font-size: 12px;
  font-weight: 700;
  border-radius: var(--r-md);
  white-space: nowrap;
  cursor: pointer;
  border: none;
  font-family: inherit;
  transition: transform var(--ease-fast), box-shadow var(--ease-fast);
}
.ranking-urgency-btn:hover {
  transform: translateY(-1px);
  box-shadow: 0 6px 20px rgba(245,158,11,.35);
}
.ranking-urgency.winning .ranking-urgency-btn {
  background: linear-gradient(135deg, #30D158, #059669);
}
.ranking-urgency.winning .ranking-urgency-btn:hover {
  box-shadow: 0 6px 20px rgba(16,185,129,.35);
}

/* ── List 4th+ ── */
.ranking-list { display: flex; flex-direction: column; }
.ranking-row {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 9px var(--s3);
  border-radius: var(--r-md);
  transition: background var(--ease-fast);
}
.ranking-row:hover { background: rgba(255,255,255,.022); }
.ranking-row.you {
  background: rgba(99,102,241,.07);
  border: 1px solid rgba(99,102,241,.15);
  margin: 2px 0;
}
.ranking-row-pos {
  width: 18px; text-align: center;
  font-size: 11px; font-weight: 700;
  color: var(--text-3); flex-shrink: 0;
  font-family: var(--font-mono);
}
.ranking-row.you .ranking-row-pos { color: var(--primary); }
.ranking-row-av {
  width: 28px; height: 28px;
  border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  font-size: 9px; font-weight: 700;
  color: #fff; flex-shrink: 0;
}
.ranking-row-name {
  flex: 1; font-size: 13px; font-weight: 500;
  color: var(--text-2); min-width: 0;
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
.ranking-row.you .ranking-row-name { color: var(--text-1); font-weight: 700; }
.ranking-row-pct {
  font-size: 12px; font-weight: 700;
  color: #30D158; flex-shrink: 0;
  font-family: var(--font-mono);
}

/* Overtake flash */
@keyframes overtakeFlash {
  0%   { background: rgba(99,102,241,.35); }
  100% { background: rgba(99,102,241,.07); }
}
.ranking-row.you.just-promoted {
  animation: overtakeFlash 1.4s ease-out forwards;
}

/* Light mode overrides */
[data-theme="light"] .weekly-ranking { background: #fff; border-color: var(--border-sm); }
[data-theme="light"] .ranking-resets { background: rgba(0,0,0,.03); }
[data-theme="light"] .ranking-urgency { background: linear-gradient(135deg, rgba(245,158,11,.06), rgba(99,102,241,.03)); }
[data-theme="light"] .ranking-urgency.winning { background: linear-gradient(135deg, rgba(16,185,129,.06), rgba(99,102,241,.03)); }
[data-theme="light"] .rp-motivation { background: rgba(245,158,11,.06); border-color: rgba(245,158,11,.2); }
[data-theme="light"] .rp-motivation-text { color: var(--text-1); }
[data-theme="light"] .ranking-row.you { background: rgba(99,102,241,.06); }
[data-theme="light"] .ranking-row:hover { background: rgba(0,0,0,.025); }
[data-theme="light"] .podium-1 .podium-plinth { background: rgba(245,158,11,.08); }
[data-theme="light"] .podium-2 .podium-plinth { background: rgba(148,163,184,.06); }
[data-theme="light"] .podium-3 .podium-plinth { background: rgba(180,128,80,.06); }

/* ── Tier badges ── */
.rr-tier {
  font-size: 9px; font-weight: 700;
  letter-spacing: 0; text-transform: none;
  padding: 2px 6px; border-radius: 4px; flex-shrink: 0;
}
.tier-elite      { color: #FF9F0A; background: rgba(245,158,11,.1);  border: 1px solid rgba(245,158,11,.2); }
.tier-pro        { color: var(--primary); background: rgba(99,102,241,.08); border: 1px solid rgba(99,102,241,.15); }
.tier-challenger { color: #60A5FA; background: rgba(96,165,250,.08); border: 1px solid rgba(96,165,250,.15); }
.tier-rising     { color: var(--text-3); background: rgba(255,255,255,.04); border: 1px solid var(--border-sm); }

/* ── Momentum arrows ── */
.rm-up   { color: #30D158; font-weight: 700; font-size: 12px; flex-shrink: 0; }
.rm-down { color: #FF453A; font-weight: 700; font-size: 12px; flex-shrink: 0; }
.rm-eq   { color: var(--text-3); font-size: 12px; flex-shrink: 0; }

/* ── Cosmetic Effects ── */

/* Gold border on ranking avatar */
.ranking-row-av.cosmetic-gold {
  border: 2px solid #FFD700;
  box-shadow: 0 0 8px rgba(255,215,0,.35), 0 0 2px rgba(255,215,0,.2);
}
.podium-avatar.cosmetic-gold {
  border: 2.5px solid #FFD700 !important;
  box-shadow: 0 0 12px rgba(255,215,0,.4), 0 0 3px rgba(255,215,0,.25) !important;
}

/* Diamond border on ranking avatar — animated shimmer */
.ranking-row-av.cosmetic-diamond {
  border: 2px solid #B9F2FF;
  box-shadow: 0 0 10px rgba(185,242,255,.35), 0 0 3px rgba(185,242,255,.2);
  animation: diamondShimmer 2.5s ease-in-out infinite;
}
.podium-avatar.cosmetic-diamond {
  border: 2.5px solid #B9F2FF !important;
  box-shadow: 0 0 14px rgba(185,242,255,.45), 0 0 4px rgba(185,242,255,.3) !important;
  animation: diamondShimmer 2.5s ease-in-out infinite !important;
}
@keyframes diamondShimmer {
  0%,100% {
    border-color: #B9F2FF;
    box-shadow: 0 0 10px rgba(185,242,255,.35), 0 0 3px rgba(185,242,255,.2);
  }
  33% {
    border-color: #E0C3FC;
    box-shadow: 0 0 12px rgba(224,195,252,.4), 0 0 4px rgba(224,195,252,.25);
  }
  66% {
    border-color: #93C5FD;
    box-shadow: 0 0 10px rgba(147,197,253,.35), 0 0 3px rgba(147,197,253,.2);
  }
}

/* Verified badge next to name */
.ranking-verified-badge {
  display: inline-flex; align-items: center; justify-content: center;
  width: 14px; height: 14px; flex-shrink: 0;
  color: #A855F7;
  margin-left: -2px;
}
.podium-verified-badge {
  display: inline-flex; align-items: center; justify-content: center;
  width: 16px; height: 16px;
  color: #A855F7;
}

/* Elite flame (purple) */
.flame-elite-icon { color: #A855F7 !important; }
.flame-elite-icon svg path { fill: #A855F7; }

/* Custom title below name in ranking */
.ranking-custom-title {
  font-size: 9px;
  color: #FF6B6B;
  font-weight: 600;
  letter-spacing: .4px;
  text-transform: none;
  margin-top: 1px;
  opacity: .85;
}
.podium-custom-title {
  font-size: 8px;
  color: #FF6B6B;
  font-weight: 600;
  letter-spacing: .3px;
  text-transform: none;
  margin-top: -2px;
}

/* ── Expanded row layout ── */
.ranking-row { align-items: flex-start; padding: 10px var(--s4); }
.ranking-row .ranking-row-av  { margin-top: 1px; flex-shrink: 0; }
.ranking-row .ranking-row-pos { margin-top: 3px; }
.ranking-row-main { flex: 1; min-width: 0; }
.ranking-row-top  { display: flex; align-items: center; gap: 7px; flex-wrap: nowrap; }
.ranking-row-name { min-width: 0; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }

/* ── Near-miss progress bar ── */
.rr-progress-wrap {
  display: flex; align-items: center; gap: 8px; margin-top: 5px;
}
.rr-progress-bar {
  flex: 1; height: 3px;
  background: rgba(255,255,255,.07);
  border-radius: 2px; overflow: hidden;
}
.rr-progress-fill {
  height: 100%; background: var(--primary);
  border-radius: 2px; transition: width .6s cubic-bezier(0.32, 0.72, 0, 1);
}
.rr-progress-fill.near-miss-fill {
  background: linear-gradient(90deg, #FF9F0A, #FF453A);
  animation: progressPulse 1.8s ease-in-out infinite;
}
@keyframes progressPulse { 0%,100% { opacity: 1; } 50% { opacity: .65; } }
.rr-progress-label { font-size: 10px; color: var(--text-3); white-space: nowrap; }
.ranking-row.you.near-miss .rr-progress-label { color: #FF9F0A; font-weight: 600; }

/* ── Target row (person just above) ── */
.ranking-row.target-row {
  border: 1px dashed rgba(245,158,11,.22);
  background: rgba(245,158,11,.03);
}
.rr-target-label { font-size: 10px; color: #FF9F0A; font-weight: 600; margin-top: 3px; }

/* ── Ghost row (chasing from below) ── */
.ranking-row.ghost-row {
  border: 1px dashed rgba(239,68,68,.2);
  background: rgba(239,68,68,.03);
}
.rr-ghost-label { font-size: 10px; color: #FF453A; font-weight: 600; margin-top: 3px; }

/* ── Podium shadow rows (already in podium but shown in zone) ── */
.ranking-row.podium-shadow-row { opacity: 0.65; }
.rr-podium-dot { font-size: 7px; color: #FF9F0A; margin-left: 1px; vertical-align: super; }

/* ── Stats bar — 5 cols ── */
.rp-statsbar { grid-template-columns: repeat(5, 1fr); }

/* ── Zone color banding ── */
/* Elite zone rows (rank 1-2): gold glow strip on left edge */
.ranking-row.zone-elite {
  /* Apple: no accent border */
  background: linear-gradient(90deg, rgba(245,158,11,.04) 0%, transparent 60%);
}
/* Danger zone rows (near bottom of zone): red glow strip */
.ranking-row.zone-danger {
  /* Apple: no accent border */
  background: linear-gradient(90deg, rgba(239,68,68,.03) 0%, transparent 60%);
}
/* Your row in zone: blue left stripe */
.ranking-row.you {
  border-left: 2px solid var(--primary);
}

/* ── Decay warning banner ── */
.rp-decay-banner {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 10px 14px;
  background: rgba(239,68,68,.07);
  border: 1px solid rgba(239,68,68,.2);
  border-radius: var(--r-md);
  margin-bottom: var(--s4);
  font-size: 12.5px;
  color: #FCA5A5;
  line-height: 1.45;
  animation: decayPulse 2.5s ease-in-out infinite;
}
.rp-decay-banner strong { color: #F87171; }
.rp-decay-banner-icon { font-size: 16px; flex-shrink: 0; }
@keyframes decayPulse { 0%,100% { border-color: rgba(239,68,68,.2); } 50% { border-color: rgba(239,68,68,.45); } }

/* ── Loss aversion toast variant ── */
.gc-toast-loss { border-color: rgba(239,68,68,.35); }
.gc-toast-loss .toast-icon { color: #FF453A; }

/* Light mode */
[data-theme="light"] .tier-rising { background: rgba(0,0,0,.04); border-color: var(--border-sm); }
[data-theme="light"] .ranking-row.target-row { background: rgba(245,158,11,.03); }
[data-theme="light"] .ranking-row.ghost-row  { background: rgba(239,68,68,.03); }
[data-theme="light"] .ranking-row.zone-elite { background: linear-gradient(90deg, rgba(245,158,11,.05) 0%, transparent 60%); }
[data-theme="light"] .ranking-row.zone-danger { background: linear-gradient(90deg, rgba(239,68,68,.04) 0%, transparent 60%); }
[data-theme="light"] .rp-decay-banner { background: rgba(239,68,68,.05); color: #B91C1C; }
[data-theme="light"] .rp-decay-banner strong { color: #DC2626; }

/* Mobile */
@media (max-width: 768px) {
  .ranking-podium { gap: 4px; }
  .podium-item { max-width: 100px; }
  .podium-1 .podium-avatar { width: 50px; height: 50px; }
  .ranking-urgency { flex-direction: column; gap: var(--s3); }
  .ranking-urgency-btn { width: 100%; text-align: center; padding: 10px; }
  .rp-motivation { flex-direction: column; gap: var(--s3); }
  .rp-motivation .ranking-urgency-btn { width: 100%; text-align: center; padding: 12px; }
  .rp-statsbar { grid-template-columns: repeat(3, 1fr); }
  .rp-stat-divider:nth-child(8) { display: none; }
  .rp-stat-divider:nth-child(10) { display: none; }
}

/* ── TOAST — Apple Notification Banner ───────────────────── */
.gc-toast {
  position: fixed;
  bottom: 28px;
  right: 24px;
  background: var(--bg-surface);
  backdrop-filter: blur(40px) saturate(180%);
  -webkit-backdrop-filter: blur(40px) saturate(180%);
  border: 0.5px solid rgba(255,255,255,.1);
  border-radius: 14px;
  padding: 12px 16px;
  display: flex;
  align-items: center;
  gap: 10px;
  font-size: 13px;
  font-weight: 500;
  letter-spacing: -0.01em;
  color: var(--text-1);
  box-shadow: 0 8px 32px rgba(0,0,0,.25), 0 0 1px rgba(0,0,0,.1);
  z-index: 500;
  transform: translateY(12px) scale(0.92);
  opacity: 0;
  transition: transform 350ms cubic-bezier(0.32, 0.72, 0, 1),
              opacity 250ms cubic-bezier(0.32, 0.72, 0, 1);
  pointer-events: none;
  max-width: 340px;
}
.gc-toast.visible {
  transform: translateY(0) scale(1);
  opacity: 1;
}
.gc-toast + .gc-toast { bottom: 76px; }
.gc-toast + .gc-toast + .gc-toast { bottom: 124px; }
.toast-icon { font-size: 15px; line-height: 1; flex-shrink: 0; }
.gc-toast-score .toast-icon  { color: var(--secondary); }
.gc-toast-unlock .toast-icon { color: var(--accent); }
.gc-toast-info .toast-icon   { color: var(--primary); }

/* ── STREAK FLAME — metric item ─────────────────────────── */
/* Gray flame (default — daily reset) */
.streak-flame-svg.streak-flame-gray {
  animation: none !important;
  filter: none !important;
  opacity: 0.35;
}
.streak-flame-svg.streak-flame-gray path { fill: #6B7280 !important; stroke: #6B7280 !important; }

/* Clickable streak card */
.metric-streak-btn { cursor: pointer; border-radius: var(--r-md); transition: background var(--ease-base); }
.metric-streak-btn:hover { background: rgba(245,158,11,.07); }

.metric-streak { position: relative; }
.streak-flame-wrap {
  display: flex;
  justify-content: center;
  margin-bottom: 3px;
}
.streak-flame-svg {
  filter: drop-shadow(0 0 6px rgba(245,158,11,0.7));
  transform-origin: center bottom;
  animation: flameLive 2.2s ease-in-out infinite;
}
@keyframes flameLive {
  0%, 100% { transform: scaleY(1) rotate(-1deg); filter: drop-shadow(0 0 5px rgba(245,158,11,0.6)); }
  33%  { transform: scaleY(1.08) rotate(1deg); filter: drop-shadow(0 0 10px rgba(245,158,11,0.9)); }
  66%  { transform: scaleY(0.96) rotate(-0.5deg); filter: drop-shadow(0 0 6px rgba(245,158,11,0.7)); }
}
.metric-streak .metric-val {
  color: #FF9F0A !important;
  text-shadow: 0 0 20px rgba(245,158,11,0.3);
}
.metric-streak .metric-val .unit { color: rgba(245,158,11,0.6) !important; }
.metric-streak .metric-delta-lbl { color: #FF9F0A !important; opacity: 0.85; }

/* ── PHASE BAR SHIMMER ───────────────────────────────────── */
.phase-bar-fill { position: relative; overflow: hidden; }
.phase-bar-fill::after {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(90deg, transparent 0%, rgba(255,255,255,0.4) 50%, transparent 100%);
  background-size: 200% 100%;
  animation: barShimmer 2.8s ease-in-out infinite;
}
@keyframes barShimmer {
  0%   { background-position: -200% 0; }
  100% { background-position: 200% 0; }
}
.phase-bar-fill.near-complete {
  box-shadow: 0 0 10px rgba(139,92,246,0.55), 0 0 20px rgba(139,92,246,0.2);
  animation: nearGlow 1.8s ease-in-out infinite;
}
@keyframes nearGlow {
  0%, 100% { box-shadow: 0 0 6px rgba(139,92,246,0.4); }
  50%       { box-shadow: 0 0 18px rgba(139,92,246,0.8), 0 0 32px rgba(139,92,246,0.25); }
}

/* ── DIAL SOCIAL PROOF ───────────────────────────────────── */
.dial-social-proof {
  font-family: var(--font-mono);
  font-size: 9px;
  letter-spacing: 0;
  text-transform: none;
  color: var(--secondary);
  margin-top: 7px;
  opacity: 0.75;
}

/* ── TASKS RESET TIMER ───────────────────────────────────── */
.tasks-reset-row {
  display: flex;
  align-items: center;
  gap: var(--s2);
  margin-top: var(--s2);
  font-size: 10.5px;
  color: var(--text-3);
  font-family: var(--font-mono);
  letter-spacing: 0;
}
.tasks-reset-row svg { flex-shrink: 0; opacity: 0.4; }
.reset-countdown {
  font-weight: 700;
  color: var(--text-2);
  letter-spacing: 0;
  font-variant-numeric: tabular-nums;
  transition: color 0.5s cubic-bezier(0.32, 0.72, 0, 1);
}
.reset-countdown.urgent { color: #FF9F0A; }
.reset-countdown.danger { color: var(--red); animation: cntBlink 1s ease-in-out infinite; }
@keyframes cntBlink { 0%, 100% { opacity: 1; } 50% { opacity: 0.4; } }

/* ── NAV NEW DOT ─────────────────────────────────────────── */
.nav-new-dot {
  width: 6px; height: 6px;
  border-radius: 50%;
  background: var(--secondary);
  box-shadow: none;
  margin-left: auto;
  flex-shrink: 0;
  animation: navDotPulse 2.5s ease-in-out infinite;
}
@keyframes navDotPulse {
  0%, 100% { transform: scale(1); opacity: 1; }
  50%       { transform: scale(1.4); opacity: 0.6; }
}
.sidebar.collapsed .nav-new-dot { position: absolute; top: 6px; right: 6px; }

/* ── STREAK DANGER BANNER ────────────────────────────────── */
.streak-danger-banner {
  display: none;
  align-items: center;
  gap: var(--s3);
  background: rgba(245,158,11,0.06);
  border: 1px solid rgba(245,158,11,0.2);
  border-radius: var(--r-lg);
  padding: var(--s3) var(--s5);
  margin-bottom: var(--s4);
  font-size: 12.5px;
  color: var(--text-2);
  animation: bannerIn 400ms cubic-bezier(0.22,1,0.36,1);
}
.streak-danger-banner.visible { display: flex; }
@keyframes bannerIn {
  0%   { transform: translateY(-8px); opacity: 0; }
  100% { transform: translateY(0);    opacity: 1; }
}
.streak-danger-banner svg { color: #FF9F0A; flex-shrink: 0; }
.streak-danger-banner strong { color: #FF9F0A; }
.streak-danger-banner > button:not(.banner-dismiss) {
  margin-left: auto;
  background: rgba(245,158,11,0.12);
  border: 1px solid rgba(245,158,11,0.25);
  color: #FF9F0A;
  font-size: 11.5px;
  font-weight: 700;
  padding: 4px 14px;
  border-radius: 20px;
  cursor: pointer;
  font-family: var(--font-display);
  white-space: nowrap;
  transition: all var(--ease-fast);
}
.streak-danger-banner > button:not(.banner-dismiss):hover {
  background: rgba(245,158,11,0.22);
}
.banner-dismiss {
  background: none;
  border: none;
  color: var(--text-3);
  font-size: 12px;
  cursor: pointer;
  padding: 2px 5px;
  line-height: 1;
  flex-shrink: 0;
  transition: color var(--ease-fast);
}
.banner-dismiss:hover { color: var(--text-2); }

/* ── CHECKMARK DRAW ANIMATION ────────────────────────────── */
.task-check-visual.done svg path {
  stroke-dasharray: 14;
  stroke-dashoffset: 14;
  animation: checkDraw 320ms ease-out 80ms both;
}
@keyframes checkDraw { to { stroke-dashoffset: 0; } }

/* ── TASK CHECK BOUNCE ───────────────────────────────────── */
.task-check-visual.done {
  animation: checkBounce 400ms cubic-bezier(0.34,1.56,0.64,1) both;
}
@keyframes checkBounce {
  0%   { transform: scale(0.7); }
  60%  { transform: scale(1.18); }
  100% { transform: scale(1); }
}

/* ── ENHANCED TOAST — left border variants ───────────────── */
.gc-toast-score  { border-left: 2px solid var(--secondary) !important; }
.gc-toast-unlock { border-left: 2px solid var(--accent) !important; }
.gc-toast-info   { border-left: 2px solid var(--primary) !important; }
.gc-toast-streak { border-left: 2px solid #FF9F0A !important; }
.gc-toast-streak .toast-icon { color: #FF9F0A; }

/* ── RESPONSIVE — dopamine sections ─────────────────────── */
@media (min-width: 769px) and (max-width: 1100px) {
  .intel-row { grid-template-columns: 1fr 1fr; gap: var(--s3); }
  .intel-body { font-size: 12.5px; }
  .task-text { font-size: 13px; }
}
@media (max-width: 768px) {
  .intel-row { grid-template-columns: 1fr; gap: var(--s3); }
  .phase-bar-track { flex: 0 0 120px; }
  .task-text { font-size: 13px; }
  .task-exec-btn { font-size: 10.5px; padding: 3px 10px; }
  .daily-tasks { padding: var(--s4) var(--s4); }
  .gc-toast { right: 12px; bottom: 20px; max-width: calc(100vw - 24px); }
}
@media (max-width: 480px) {
  .phase-progress-name { display: none; }
  .phase-bar-label { font-size: 9.5px; }
}

/* ─── SAVED CARDS (inline styles from app.html) ──────────── */
.saved-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(300px, 1fr));
  gap: var(--s4);
}
.saved-card {
  padding: var(--s5);
  border-radius: var(--r-lg);
  background: var(--bg-surface);
  backdrop-filter: blur(12px);
  border: 1px solid var(--border-sm);
  display: flex; flex-direction: column; gap: var(--s3);
  cursor: pointer; transition: all var(--ease-base);
}
.saved-card:hover { border-color: var(--border-md); transform: translateY(-2px); }
.saved-card-header { display: flex; align-items: center; justify-content: space-between; }
.saved-card-title { font-size: 14px; font-weight: 700; color: var(--text-1); font-family: var(--font-display); letter-spacing: -.2px; }
.saved-card-preview { font-size: 12px; color: var(--text-2); line-height: 1.5; display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden; }
.saved-card-footer { display: flex; align-items: center; justify-content: space-between; gap: var(--s3); margin-top: var(--s2); }
.home-right-col { display: flex; flex-direction: column; gap: var(--s4); }
.home-left-col  { display: flex; flex-direction: column; gap: var(--s4); }

/* ============================================================
   GROWTH 2.0
   ============================================================ */
.gw-update-bar {
  display: flex; align-items: center; justify-content: space-between;
  padding: 10px 16px; background: var(--bg-surface);
  border: 1px solid var(--border-sm); border-radius: var(--r-md);
  margin-bottom: var(--s4); gap: var(--s3); flex-wrap: wrap;
}
.gw-update-left { display: flex; align-items: center; gap: 8px; }
.gw-update-dot { width: 8px; height: 8px; border-radius: 50%; background: var(--text-3); flex-shrink: 0; }
.gw-update-dot.fresh { background: #30D158; box-shadow: 0 0 6px rgba(16,185,129,.5); }
.gw-update-dot.stale { background: #FF9F0A; box-shadow: 0 0 6px rgba(245,158,11,.4); }
.gw-update-dot.old { background: #FF453A; animation: dotPulse 1.5s ease-in-out infinite; }
@keyframes dotPulse { 0%,100% { opacity:1; box-shadow:0 0 6px rgba(239,68,68,.5); } 50% { opacity:.5; box-shadow:none; } }
.gw-update-text { font-size: 12.5px; color: var(--text-2); }
.gw-update-actions { display: flex; gap: 6px; flex-wrap: wrap; }

.gw-stats-bar {
  display: grid; grid-template-columns: 1fr 1px 1fr 1px 1fr 1px 1fr;
  background: var(--bg-surface); border: 1px solid var(--border-sm);
  border-radius: var(--r-lg); margin-bottom: var(--s4); overflow: hidden;
}
.gw-stat { padding: 16px 20px; display: flex; flex-direction: column; gap: 4px; }
.gw-stat-divider { background: var(--border-xs); }
.gw-stat-label { font-size: 10px; text-transform: none; letter-spacing: 0; color: var(--text-3); font-weight: 600; }
.gw-stat-value { font-size: 22px; font-weight: 700; font-family: var(--font-display); letter-spacing: -1px; color: var(--text-1); }
.gw-stat-delta { font-size: 11px; color: var(--text-3); }
.gw-stat-delta.up { color: #30D158; }
.gw-stat-delta.down { color: #FF453A; }

/* ── Instagram Connect Card ── */
.ig-connect-card {
  background: var(--bg-surface); border-radius: var(--r-lg); padding: 16px 20px;
  border: 1px solid var(--border-xs); margin-bottom: var(--s3);
}
.ig-connect-not-connected {
  display: flex; align-items: center; gap: 14px;
}
.ig-connect-icon {
  flex-shrink: 0; width: 44px; height: 44px; display: flex; align-items: center; justify-content: center;
  background: linear-gradient(135deg, rgba(245,133,41,.08), rgba(221,42,123,.08), rgba(129,52,175,.08));
  border-radius: var(--r-md);
}
.ig-connect-info { flex: 1; min-width: 0; }
.ig-connect-title { font-size: 14px; font-weight: 600; color: var(--text-1); }
.ig-connect-desc { font-size: 12px; color: var(--text-3); margin-top: 2px; }
.ig-connect-btn {
  background: linear-gradient(135deg, #F58529, #DD2A7B, #8134AF) !important;
  border: none !important; color: #fff !important; font-weight: 600;
  padding: 8px 18px !important; white-space: nowrap;
}
.ig-connect-btn:hover { opacity: .9; }
.ig-connect-connected { display: flex; align-items: center; justify-content: space-between; gap: 12px; }
.ig-connect-connected.hidden { display: none; }
.ig-connect-profile { display: flex; align-items: center; gap: 10px; }
.ig-connect-avatar { width: 36px; height: 36px; border-radius: 50%; object-fit: cover; border: 2px solid var(--border-xs); }
.ig-connect-username { font-size: 14px; font-weight: 600; color: var(--text-1); display: block; }
.ig-connect-sync { font-size: 11px; color: #30D158; display: block; }
.ig-connect-sync.syncing { color: var(--primary); }
.ig-connect-sync.error { color: #FF453A; }
.ig-connect-actions { display: flex; gap: 6px; flex-shrink: 0; }

@media (max-width: 480px) {
  .ig-connect-not-connected { flex-wrap: wrap; }
  .ig-connect-btn { width: 100%; margin-top: 4px; }
  .ig-connect-connected { flex-direction: column; align-items: flex-start; }
}

.gw-tabs {
  display: flex; gap: 4px; margin-bottom: var(--s4); padding: 4px;
  background: var(--bg-surface); border-radius: var(--r-lg); border: 1px solid var(--border-xs);
}
.gw-tab {
  flex: 1; padding: 8px 12px; border-radius: var(--r-md);
  font-size: 13px; font-weight: 500; color: var(--text-3);
  background: transparent; border: none; cursor: pointer;
  transition: all var(--ease-fast); font-family: var(--font-sans);
}
.gw-tab:hover { color: var(--text-2); background: var(--bg-elevated); }
.gw-tab.active { color: var(--text-1); background: var(--bg-surface); box-shadow: 0 1px 4px rgba(0,0,0,.3); }

.gw-panel.hidden { display: none; }
.gw-two-col { display: grid; grid-template-columns: 1.6fr 1fr; gap: var(--s4); }
.gw-insights-col { display: flex; flex-direction: column; gap: var(--s3); }
.gw-panel-header { display: flex; justify-content: space-between; align-items: flex-start; margin-bottom: var(--s4); gap: var(--s3); }
.gw-panel-sub { font-size: 12px; color: var(--text-3); margin-top: 3px; }

.gw-chart-empty {
  position: absolute; inset: 0; display: flex; flex-direction: column;
  align-items: center; justify-content: center;
  background: var(--bg-surface); border-radius: var(--r-md); text-align: center; padding: var(--s5);
}
.gw-chart-empty.hidden { display: none; }

.gw-follower-log { margin-top: var(--s3); }
.gw-follower-log-hdr {
  display: flex; justify-content: space-between; padding: 0 0 6px;
  font-size: 10px; font-weight: 700; text-transform: none;
  letter-spacing: 0; color: var(--text-3); border-bottom: 1px solid var(--border-xs);
}
.gw-follower-row {
  display: flex; align-items: center; justify-content: space-between;
  padding: 7px 0; border-bottom: 1px solid var(--border-xs); font-size: 12.5px;
}
.gw-follower-row:last-child { border-bottom: none; }
.gw-follower-date { color: var(--text-3); font-size: 11px; font-family: var(--font-mono); }
.gw-follower-count { color: var(--text-1); font-weight: 600; }
.gw-follower-gain { font-size: 11px; padding: 1px 6px; border-radius: 4px; }
.gw-follower-gain.pos { color: #30D158; background: rgba(16,185,129,.1); }
.gw-follower-gain.neg { color: #FF453A; background: rgba(239,68,68,.08); }

.gw-insight-card { background: var(--bg-surface); border: 1px solid var(--border-sm); border-radius: var(--r-lg); padding: var(--s4); }
.gw-insight-card-title { font-size: 11px; text-transform: none; letter-spacing: 0; color: var(--text-3); font-weight: 600; margin-bottom: var(--s3); }
.gw-insight-item {
  display: flex; align-items: flex-start; gap: 8px; padding: 6px 0;
  border-bottom: 1px solid var(--border-xs); font-size: 12.5px; color: var(--text-2); line-height: 1.45;
}
.gw-insight-item:last-child { border-bottom: none; }
.gw-insight-dot { width: 6px; height: 6px; border-radius: 50%; flex-shrink: 0; margin-top: 5px; }
.gw-mission-item {
  display: flex; align-items: center; gap: 10px; padding: 8px 10px;
  background: var(--bg-surface); border-radius: var(--r-md); border: 1px solid var(--border-xs);
  font-size: 12.5px; color: var(--text-2); margin-bottom: 6px; line-height: 1.4;
}
.gw-mission-icon { font-size: 15px; flex-shrink: 0; }

.gw-table { width: 100%; border-collapse: collapse; }
.gw-table th {
  text-align: left; font-size: 10px; text-transform: none;
  letter-spacing: 0; color: var(--text-3); font-weight: 600;
  padding: 8px 12px; border-bottom: 1px solid var(--border-xs); white-space: nowrap;
}
.gw-table td { padding: 10px 12px; font-size: 12.5px; color: var(--text-2); border-bottom: 1px solid var(--border-xs); vertical-align: middle; }
.gw-table tr:last-child td { border-bottom: none; }
.gw-table tr:hover td { background: var(--bg-hover); }
.gw-table-title { color: var(--text-1); font-weight: 500; max-width: 200px; }
.gw-table-title span { display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden; }
.gw-eng { font-weight: 700; }
.gw-eng.good { color: #30D158; }
.gw-eng.ok { color: #FF9F0A; }
.gw-eng.bad { color: #FF453A; }
.gw-del-btn { color: var(--text-3); background: none; border: none; cursor: pointer; font-size: 16px; padding: 2px 6px; border-radius: 4px; line-height: 1; }
.gw-del-btn:hover { color: #FF453A; background: rgba(239,68,68,.1); }

.gw-empty {
  text-align: center; padding: 48px 24px; color: var(--text-3);
  background: var(--bg-surface); border: 1px dashed var(--border-sm); border-radius: var(--r-lg);
}
.gw-empty-icon { font-size: 32px; margin-bottom: 12px; }
.gw-empty-title { font-size: 14px; font-weight: 600; color: var(--text-2); margin-bottom: 6px; }
.gw-empty-sub { font-size: 12px; margin-bottom: 16px; line-height: 1.5; }

.gw-modal-overlay {
  position: fixed; inset: 0; background: rgba(0,0,0,.65);
  backdrop-filter: blur(8px); -webkit-backdrop-filter: blur(8px);
  z-index: 400; display: flex; align-items: center; justify-content: center; padding: var(--s4);
}
.gw-modal-overlay.hidden { display: none; }
.gw-modal {
  width: 100%; max-width: 500px; background: var(--bg-base);
  border: 1px solid var(--border-md); border-radius: var(--r-xl);
  box-shadow: 0 24px 64px rgba(0,0,0,.7); overflow: hidden;
  animation: gwModalIn .22s cubic-bezier(.34,1.56,.64,1);
}
@keyframes gwModalIn { from { transform: scale(.94) translateY(12px); opacity:0; } to { transform:none; opacity:1; } }
.gw-modal-header { display: flex; align-items: center; justify-content: space-between; padding: 16px 20px; border-bottom: 1px solid var(--border-xs); }
.gw-modal-title { font-size: 15px; font-weight: 600; color: var(--text-1); }
.gw-modal-close {
  width: 28px; height: 28px; border-radius: 50%; background: var(--bg-elevated);
  border: none; cursor: pointer; font-size: 13px; color: var(--text-2);
  display: flex; align-items: center; justify-content: center; transition: all var(--ease-fast);
}
.gw-modal-close:hover { background: rgba(239,68,68,.15); color: #FF453A; }
.gw-modal-body { padding: 20px; max-height: 72vh; overflow-y: auto; }
.gw-modal-footer { display: flex; justify-content: flex-end; gap: 8px; padding: 12px 20px; border-top: 1px solid var(--border-xs); }

.gw-field { margin-bottom: 14px; }
.gw-field label { display: block; font-size: 11px; font-weight: 600; color: var(--text-3); text-transform: none; letter-spacing: 0; margin-bottom: 6px; }
.gw-field input, .gw-field select {
  width: 100%; background: var(--bg-surface); border: 1px solid var(--border-md);
  border-radius: var(--r-md); padding: 9px 12px; font-size: 14px; color: var(--text-1);
  font-family: var(--font-sans); outline: none; transition: border-color var(--ease-fast); box-sizing: border-box;
}
.gw-field input:focus, .gw-field select:focus { border-color: var(--primary); }
.gw-field-hint { font-size: 11px; color: var(--text-3); margin-top: 4px; }
.gw-2col { display: grid; grid-template-columns: 1fr 1fr; gap: 10px; }
.gw-sep { font-size: 11px; font-weight: 700; text-transform: none; letter-spacing: 0; color: var(--text-3); margin: 16px 0 10px; padding-bottom: 6px; border-bottom: 1px solid var(--border-xs); }

[data-theme="light"] .gw-update-bar { background: #fff; }
[data-theme="light"] .gw-stats-bar { background: #fff; }
[data-theme="light"] .gw-tabs { background: #f1f5f9; }
[data-theme="light"] .gw-tab.active { background: #fff; box-shadow: 0 1px 4px rgba(0,0,0,.1); }
[data-theme="light"] .gw-insight-card { background: #fff; }
[data-theme="light"] .gw-modal { background: #fff; }
[data-theme="light"] .gw-field input, [data-theme="light"] .gw-field select { background: #f8fafc; }
[data-theme="light"] .gw-chart-empty { background: #fff; }
[data-theme="light"] .gw-empty { background: #fff; }

@media (max-width: 900px) { .gw-two-col { grid-template-columns: 1fr; } }
@media (max-width: 768px) {
  .gw-stats-bar { grid-template-columns: 1fr 1px 1fr; }
  .gw-stat-divider:nth-child(4), .gw-stat-divider:nth-child(6) { display: none; }
  .gw-tabs .gw-tab { font-size: 12px; padding: 7px 8px; }
  .gw-2col { grid-template-columns: 1fr; }
}
@media (max-width: 600px) {
  .gw-stats-bar {
    grid-template-columns: 1fr 1fr !important;
    gap: var(--s3) !important;
  }
  .gw-stat-divider {
    display: none !important;
  }
  .gw-stat {
    padding: var(--s2) 0 !important;
  }
}

/* ─── PLANNER ENTRIES ───────────────────────────────────── */
.planner-entry-item {
  display: block;
  width: 100%;
  text-align: left;
  background: rgba(59,130,246,.12);
  border: 1px solid rgba(59,130,246,.25);
  border-radius: 5px;
  color: var(--primary);
  font-size: 11px;
  font-weight: 500;
  line-height: 1.3;
  padding: 5px 8px;
  margin-bottom: 4px;
  cursor: pointer;
  transition: background .15s, border-color .15s;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.planner-entry-item:hover {
  background: rgba(59,130,246,.22);
  border-color: rgba(59,130,246,.5);
}

/* Planner roteiro view modal */
.pe-section { margin-bottom: 16px; }
.pe-label {
  font-size: 10px;
  font-weight: 700;
  text-transform: none;
  letter-spacing: 0;
  color: var(--text-3);
  margin-bottom: 5px;
}
.pe-text {
  font-size: 13px;
  line-height: 1.6;
  color: var(--text-1);
  background: var(--bg-surface);
  border-radius: 6px;
  padding: 10px 12px;
}
.pe-script { font-size: 12px; color: var(--text-2); }
.pe-hashtags { color: var(--primary); font-size: 12px; word-break: break-word; white-space: normal; }

/* ─── TRENDS PAGE ───────────────────────────────────────── */
.tr-niche-bar {
  display: flex;
  align-items: center;
  gap: 10px;
  margin-bottom: 20px;
  flex-wrap: wrap;
}
.tr-niche-label { font-size: 13px; color: var(--text-3); font-weight: 500; text-transform: none; letter-spacing: 0; }
.tr-niche-pill {
  background: rgba(59,130,246,.15);
  border: 1px solid rgba(59,130,246,.3);
  color: var(--primary);
  font-size: 12px;
  font-weight: 600;
  padding: 4px 12px;
  border-radius: 20px;
}
.tr-niche-hint { font-size: 11px; color: var(--text-3); }
.tr-api-badge {
  margin-left: auto;
  font-size: 11px;
  font-weight: 600;
  text-transform: none;
  letter-spacing: 0;
  border: none;
  border-radius: var(--r-full);
  padding: 4px 10px;
}

/* Tabs */
.tr-tabs {
  display: flex;
  gap: 0;
  background: rgba(118,118,128,.12);
  border-radius: 9px;
  padding: 2px;
  margin-bottom: 24px;
  width: fit-content;
}
.tr-tab {
  display: flex;
  align-items: center;
  gap: 6px;
  padding: 7px 14px;
  border-radius: 7px;
  font-size: 13px;
  font-weight: 500;
  color: var(--text-2);
  background: none;
  border: none;
  cursor: pointer;
  transition: all 200ms cubic-bezier(0.32, 0.72, 0, 1);
}
.tr-tab:hover { color: var(--text-1); }
.tr-tab.active {
  background: var(--bg-elevated);
  color: var(--text-1);
  font-weight: 600;
  box-shadow: 0 1px 3px rgba(0,0,0,.12), 0 0 0 0.5px rgba(0,0,0,.04);
}

/* Group label */
.tr-group-label {
  font-size: 13px;
  font-weight: 600;
  text-transform: none;
  letter-spacing: 0;
  color: var(--text-2);
  margin: 24px 0 12px;
  display: flex;
  align-items: center;
  gap: 8px;
}
.tr-group-label::after { content: ''; flex: 1; height: 1px; background: var(--border-xs); }

/* Cards grid */
.tr-cards-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
  gap: 14px;
}

/* Individual card */
.tr-card {
  background: var(--bg-surface);
  border: 1px solid var(--border-xs);
  border-radius: 12px;
  padding: 16px;
  display: flex;
  flex-direction: column;
  gap: 8px;
  transition: border-color .15s, box-shadow .15s;
}
.tr-card:hover { border-color: rgba(59,130,246,.35); box-shadow: 0 4px 16px rgba(0,0,0,.15); }
.tr-card-down { opacity: .65; }
.tr-card-down:hover { opacity: .85; border-color: rgba(244,63,94,.2); }

.tr-card-top { display: flex; align-items: center; justify-content: space-between; }
.tr-category {
  font-size: 10px;
  font-weight: 700;
  text-transform: none;
  letter-spacing: 0;
  color: var(--text-3);
  background: var(--bg-base);
  border-radius: 4px;
  padding: 2px 7px;
}
.tr-vel {
  display: flex;
  align-items: center;
  gap: 3px;
  font-size: 12px;
  font-weight: 700;
  font-variant-numeric: tabular-nums;
  border-radius: 5px;
  padding: 2px 7px;
}
.tr-vel-up   { color: #30D158; background: rgba(16,185,129,.1); }
.tr-vel-down { color: #F43F5E; background: rgba(244,63,94,.1); }

.tr-topic {
  font-size: 16px;
  font-weight: 700;
  color: var(--text-1);
  line-height: 1.25;
}
.tr-desc {
  font-size: 12px;
  color: var(--text-2);
  line-height: 1.55;
  flex: 1;
}
.tr-use-btn {
  display: flex;
  align-items: center;
  gap: 6px;
  margin-top: 4px;
  padding: 9px 14px;
  background: var(--primary);
  color: #fff;
  border: none;
  border-radius: 8px;
  font-size: 12px;
  font-weight: 600;
  cursor: pointer;
  transition: opacity .15s, transform .1s;
  width: 100%;
  justify-content: center;
}
.tr-use-btn:hover { opacity: .88; transform: translateY(-1px); }
.tr-down-note {
  font-size: 11px;
  color: var(--text-3);
  text-align: center;
  padding: 6px 0 2px;
  font-style: italic;
}

/* Panel */
.tr-panel { padding-bottom: 32px; }
.tr-panel.hidden { display: none; }

/* Light mode */
[data-theme="light"] .tr-tabs { background: rgba(118,118,128,.12); }
[data-theme="light"] .tr-tab.active { background: #fff; box-shadow: 0 1px 3px rgba(0,0,0,.1), 0 0 0 0.5px rgba(0,0,0,.04); }
[data-theme="light"] .tr-card { background: #fff; }
[data-theme="light"] .tr-category { background: #f1f5f9; }

@media (max-width: 768px) {
  .tr-cards-grid { grid-template-columns: 1fr; }
  .tr-tabs { width: 100%; }
  .tr-tab { flex: 1; justify-content: center; padding: 8px 8px; font-size: 12px; }
}

/* ─── GEMS PILL ───────────────────────────────────────────── */
/* Apple-style pill badge */
.gems-pill {
  display: flex; align-items: center; gap: 4px;
  background: rgba(255,255,255,.06); border: none;
  border-radius: var(--r-full); padding: 5px 10px; cursor: pointer;
  transition: background 150ms cubic-bezier(0.32, 0.72, 0, 1);
}
.gems-pill:hover { background: rgba(255,255,255,.1); }
#gemsCount {
  font-size: 13px; font-weight: 600; color: var(--text-2);
  font-family: var(--font-body);
  letter-spacing: -0.01em;
  font-variant-numeric: tabular-nums;
}
@media (max-width: 768px) { .gems-pill { padding: 4px 8px; height: 34px; } }

/* ─── TASK MISSION MODAL ─────────────────────────────────── */
.task-modal-overlay {
  position: fixed; inset: 0; z-index: 9000;
  background: rgba(0,0,0,.65); backdrop-filter: blur(8px);
  display: flex; align-items: flex-end; justify-content: center;
  opacity: 0; pointer-events: none; transition: opacity .3s cubic-bezier(0.32, 0.72, 0, 1);
  padding-bottom: 0;
}
.task-modal-overlay.hidden { display: none; }
.task-modal-overlay.visible { opacity: 1; pointer-events: auto; }
.task-modal-overlay.visible .task-modal-card { transform: translateY(0); }
.task-modal-card {
  background: var(--bg-surface); border: 1px solid var(--border-sm);
  border-radius: 24px 24px 0 0; padding: 32px 28px 40px;
  width: 100%; max-width: 520px;
  transform: translateY(60px); transition: transform .35s cubic-bezier(0.34,1.2,0.64,1);
  display: flex; flex-direction: column; align-items: center; text-align: center; gap: 12px;
}
.tm-cat-badge {
  font-size: 10px; font-weight: 700; letter-spacing: 0;
  color: var(--primary); background: rgba(99,102,241,.12);
  border: 1px solid rgba(99,102,241,.2); border-radius: 20px; padding: 3px 10px;
}
.tm-title {
  font-size: 18px; font-weight: 700; color: var(--text-1); line-height: 1.3;
  margin-top: 4px;
}
.tm-desc {
  font-size: 13.5px; color: var(--text-2); line-height: 1.6; max-width: 340px;
}
/* ── Prompt preview inside task modal ── */
.tm-prompt-preview {
  width: 100%; margin: 6px 0 2px; text-align: left;
}
.tm-prompt-label {
  font-size: 10px; font-weight: 700; text-transform: none; letter-spacing: 0;
  color: var(--text-3); margin-bottom: 5px;
}
.tm-prompt-text {
  font-size: 12px; line-height: 1.55; color: var(--text-2);
  background: rgba(99,102,241,.06); border: 1px solid rgba(99,102,241,.12);
  border-radius: var(--r-md); padding: 10px 12px;
  max-height: 80px; overflow-y: auto;
}
[data-theme="light"] .tm-prompt-text {
  background: rgba(99,102,241,.04); border-color: rgba(99,102,241,.1);
}

.tm-rewards {
  display: flex; gap: 8px; justify-content: center; margin: 4px 0;
}
.tm-reward-pill {
  display: flex; align-items: center; gap: 5px;
  background: rgba(99,102,241,.1); border: 1px solid rgba(99,102,241,.2);
  border-radius: 20px; padding: 5px 12px;
  font-size: 12.5px; font-weight: 700; color: var(--primary);
}
.tm-reward-pill.gems {
  background: rgba(96,165,250,.1); border-color: rgba(96,165,250,.25);
  color: #60A5FA;
}
.tm-complete-btn {
  width: 100%; padding: 14px; font-size: 15px; font-weight: 700;
  border-radius: 14px; margin-top: 8px;
  display: flex; align-items: center; justify-content: center; gap: 8px;
}
.tm-cancel {
  font-size: 13px; color: var(--text-3); margin-top: 4px; cursor: pointer;
}

/* ── Task step indicators ── */
.tm-steps {
  display: flex; gap: 8px; width: 100%; margin: 4px 0;
}
.tm-step {
  flex: 1; display: flex; align-items: center; gap: 8px;
  padding: 10px 12px; border-radius: var(--r-md);
  background: rgba(255,255,255,.04); border: 1px solid var(--border-sm);
  font-size: 12px; color: var(--text-3); transition: all .2s;
}
.tm-step.active {
  background: var(--primary-dim); border-color: var(--primary-border);
  color: var(--primary);
}
.tm-step.done {
  background: rgba(16,185,129,.08); border-color: rgba(16,185,129,.2);
  color: var(--secondary);
}
.tm-step-num {
  width: 22px; height: 22px; border-radius: 50%; flex-shrink: 0;
  display: flex; align-items: center; justify-content: center;
  font-size: 11px; font-weight: 700; font-family: var(--font-mono);
  background: rgba(255,255,255,.06); border: 1px solid var(--border-sm);
}
.tm-step.active .tm-step-num { background: var(--primary); color: #fff; border-color: var(--primary); }
.tm-step.done .tm-step-num { background: var(--secondary); color: #fff; border-color: var(--secondary); }
.tm-step-label { font-size: 11.5px; font-weight: 600; line-height: 1.3; text-align: left; }
[data-theme="light"] .tm-step { background: rgba(0,0,0,.03); }
[data-theme="light"] .tm-step.active { background: var(--primary-dim); }
[data-theme="light"] .tm-step.done { background: rgba(16,185,129,.06); }

/* Task progress dots on task item */
.task-progress-mini { display: flex; gap: 4px; margin-top: 3px; }
.task-step-dot {
  width: 6px; height: 6px; border-radius: 50%;
  background: var(--border-md); transition: all .3s;
}
.task-step-dot.active { background: var(--primary); box-shadow: none; }
.task-step-dot.done { background: var(--secondary); }

/* Task hint banner */
.task-hint-banner {
  display: flex; align-items: center; gap: 10px;
  padding: 10px 14px; margin: 8px 12px;
  background: linear-gradient(135deg, var(--primary-dim), rgba(99,102,241,.06));
  border: 1px solid var(--primary-border); border-radius: var(--r-md);
  animation: hintSlideIn .3s ease;
  position: relative; z-index: 10;
}
@keyframes hintSlideIn { from { opacity: 0; transform: translateY(-8px); } to { opacity: 1; transform: translateY(0); } }
.task-hint-pulse {
  width: 8px; height: 8px; border-radius: 50%; flex-shrink: 0;
  background: var(--primary); animation: pulse 1.5s ease-in-out infinite;
}
.task-hint-text { flex: 1; font-size: 12px; color: var(--text-2); line-height: 1.4; }
.task-hint-text strong { color: var(--primary); }
.task-hint-close {
  background: none; border: none; color: var(--text-3); cursor: pointer;
  padding: 4px; flex-shrink: 0;
}

/* Target glow for task flow */
@keyframes taskTargetGlow {
  0%, 100% { box-shadow: 0 0 0 3px rgba(99,102,241,.3); }
  50% { box-shadow: 0 0 0 6px rgba(99,102,241,.15), 0 0 20px rgba(99,102,241,.2); }
}
.task-target-glow {
  animation: taskTargetGlow 1.5s ease-in-out infinite !important;
  position: relative; z-index: 5;
}

/* Light mode — task modal + chest modal solid backgrounds */
[data-theme="light"] .task-modal-card {
  background: #FFFFFF;
  border-color: rgba(0,0,0,.1);
  box-shadow: 0 -8px 40px rgba(0,0,0,.15);
}
[data-theme="light"] .chest-modal-card {
  background: #FFFFFF;
  border-color: rgba(0,0,0,.1);
  box-shadow: 0 16px 48px rgba(0,0,0,.2);
}
.tm-cancel:hover { color: var(--text-1); }

/* ─── CHEST MODAL ─────────────────────────────────────────── */
.chest-modal-overlay {
  position: fixed; inset: 0; z-index: 9100;
  background: rgba(0,0,0,.75); backdrop-filter: blur(12px);
  display: flex; align-items: center; justify-content: center;
  opacity: 0; transition: opacity .3s;
}
.chest-modal-overlay.hidden { display: none; }
.chest-modal-overlay.visible { opacity: 1; }
.chest-modal-card {
  background: var(--bg-surface); border: 1px solid var(--border-sm);
  border-radius: 24px; padding: 36px 28px;
  width: 340px; max-width: calc(100vw - 40px);
  display: flex; flex-direction: column; align-items: center; gap: 16px;
  position: relative; overflow: hidden;
}
.chest-modal-overlay.visible .chest-modal-card {
  animation: chestCardIn .4s cubic-bezier(0.34,1.2,0.64,1);
}
@keyframes chestCardIn { from { transform: scale(.8); opacity: 0; } to { transform: scale(1); opacity: 1; } }

/* Chest 3D */
.chest-scene {
  position: relative; width: 130px; height: 110px; perspective: 500px;
  filter: drop-shadow(0 8px 24px rgba(245,158,11,.35));
}
.chest-body-wrap {
  position: absolute; inset: 0; transform-style: preserve-3d;
}
.chest-lid {
  position: absolute; top: 0; left: 8px; right: 8px; height: 46px;
  transform-origin: top center;
  transition: transform .6s cubic-bezier(0.34,1.2,0.64,1);
  z-index: 1;
}
.chest-lid.open { transform: rotateX(-130deg); }
.chest-lid-face {
  width: 100%; height: 100%;
  background: linear-gradient(180deg, #D97706 0%, #B45309 50%, #92400E 100%);
  border-radius: 10px 10px 2px 2px;
  border: 2px solid #FBBF24;
  display: flex; align-items: center; justify-content: center;
  position: relative;
  box-shadow: inset 0 2px 4px rgba(255,255,255,.2), inset 0 -2px 4px rgba(0,0,0,.2);
}
.chest-lid-stripe {
  position: absolute; top: 50%; left: 10px; right: 10px; height: 4px;
  background: linear-gradient(90deg, #FF9F0A, #FBBF24, #FF9F0A);
  border-radius: 2px; transform: translateY(-50%);
  box-shadow: 0 1px 3px rgba(0,0,0,.3);
}
.chest-base {
  position: absolute; bottom: 0; left: 8px; right: 8px; height: 62px;
  background: linear-gradient(180deg, #A16207 0%, #854D0E 40%, #713F12 100%);
  border-radius: 4px 4px 12px 12px;
  border: 2px solid #FBBF24; border-top: none;
  display: flex; align-items: center; justify-content: center;
  box-shadow: inset 0 4px 8px rgba(245,158,11,.15), inset 0 -2px 6px rgba(0,0,0,.3);
}
.chest-base::before {
  content: ''; position: absolute; top: -1px; left: 15%; right: 15%; height: 2px;
  background: rgba(245,158,11,.4); border-radius: 1px;
}
.chest-base-lock { color: #FBBF24; filter: drop-shadow(0 0 6px rgba(251,191,36,.5)); }
.chest-scene::after {
  content: ''; position: absolute; inset: -20px; z-index: -1;
  background: radial-gradient(circle, rgba(245,158,11,.2) 0%, transparent 70%);
  animation: chestGlow 2s ease-in-out infinite;
  border-radius: 50%;
}
@keyframes chestGlow {
  0%, 100% { opacity: .5; transform: scale(.9); }
  50% { opacity: 1; transform: scale(1.1); }
}
.chest-particles { position: absolute; inset: 0; pointer-events: none; }
.chest-particle {
  position: absolute; top: 50%; left: 50%;
  font-size: 18px; animation: particleFly .8s forwards;
}
@keyframes particleFly {
  0%   { transform: translate(-50%,-50%) scale(0) rotate(0deg); opacity: 1; }
  60%  { opacity: 1; }
  100% { transform: translate(calc(-50% + var(--dx)), calc(-50% + var(--dy))) scale(1.2) rotate(var(--rot)); opacity: 0; }
}
.chest-info { text-align: center; }
.chest-title-txt { font-size: 18px; font-weight: 800; color: var(--text-1); }
.chest-sub-txt { font-size: 13px; color: var(--text-2); margin-top: 4px; }
.chest-reward {
  background: linear-gradient(135deg, rgba(251,191,36,.12), rgba(99,102,241,.12));
  border: 1px solid rgba(251,191,36,.3); border-radius: 16px;
  padding: 16px 32px; text-align: center;
  animation: chestRewardIn .4s cubic-bezier(0.34,1.2,0.64,1);
}
@keyframes chestRewardIn { from { transform: scale(.6); opacity: 0; } to { transform: scale(1); opacity: 1; } }
.chest-reward.hidden { display: none; }
.chest-reward-num {
  font-size: 32px; font-weight: 900; color: #60A5FA;
  text-shadow: 0 0 20px rgba(96,165,250,.5);
}
.chest-reward-label { font-size: 12px; color: var(--text-2); margin-top: 4px; font-weight: 600; letter-spacing: 0; }
.chest-open-btn { width: 100%; padding: 13px; font-size: 15px; font-weight: 700; border-radius: 14px; }
.chest-skip-btn { font-size: 13px; color: var(--text-3); margin-top: -4px; }
.chest-skip-btn.hidden { display: none; }
.chest-open-btn.hidden { display: none; }

/* ─── STREAK ONBOARDING ──────────────────────────────────── */
.streak-ob-overlay {
  position: fixed; inset: 0; z-index: 9200;
  background: rgba(0,0,0,.8); backdrop-filter: blur(16px);
  display: flex; align-items: center; justify-content: center;
  opacity: 0; transition: opacity .35s;
}
.streak-ob-overlay.hidden { display: none; }
.streak-ob-overlay.visible { opacity: 1; }
.streak-ob-card {
  background: var(--bg-surface); border: 1px solid var(--border-sm);
  border-radius: 28px; padding: 40px 32px;
  width: 360px; max-width: calc(100vw - 32px);
  text-align: center;
  animation: sobCardIn .45s cubic-bezier(0.34,1.2,0.64,1);
}
@keyframes sobCardIn { from { transform: scale(.75) translateY(40px); opacity: 0; } to { transform: scale(1) translateY(0); opacity: 1; } }
.sob-screen { display: flex; flex-direction: column; align-items: center; gap: 16px; }
.sob-screen.hidden { display: none; }

/* Screen 1 */
.sob-fire-wrap { position: relative; margin-bottom: 4px; }
.sob-fire {
  font-size: 72px; display: block;
  animation: firePulse 1s ease-in-out infinite alternate;
  filter: drop-shadow(0 0 18px #F97316) drop-shadow(0 0 36px #FF9F0A);
}
@keyframes firePulse {
  0%  { transform: scale(1) rotate(-2deg); filter: drop-shadow(0 0 14px #F97316); }
  100%{ transform: scale(1.1) rotate(2deg); filter: drop-shadow(0 0 28px #F97316) drop-shadow(0 0 50px #FBBF24); }
}
.sob-day-num {
  position: absolute; bottom: -4px; right: -8px;
  background: linear-gradient(135deg, #F97316, #FF9F0A);
  color: #fff; font-size: 22px; font-weight: 900;
  width: 36px; height: 36px; border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  border: 3px solid var(--bg-surface);
  box-shadow: 0 4px 12px rgba(249,115,22,.5);
}
.sob-headline {
  font-size: 26px; font-weight: 900; color: var(--text-1);
  letter-spacing: -.5px;
}
.sob-week {
  display: flex; gap: 6px; justify-content: center; margin: 4px 0;
}
.sob-day-pill {
  display: flex; flex-direction: column; align-items: center; gap: 4px;
  padding: 8px 6px; border-radius: 10px; min-width: 36px;
  border: 1.5px solid var(--border-sm);
  transition: all .2s;
}
.sob-day-pill.active {
  background: linear-gradient(135deg, rgba(249,115,22,.2), rgba(245,158,11,.15));
  border-color: #F97316;
}
.sob-day-pill.past { opacity: .5; }
.sob-day-name { font-size: 9px; font-weight: 700; letter-spacing: 0; color: var(--text-3); }
.sob-day-pill.active .sob-day-name { color: #F97316; }
.sob-day-dot {
  font-size: 13px; color: var(--text-3);
}
.sob-day-pill.active .sob-day-dot { color: #F97316; font-weight: 900; }
.sob-day-pill.past .sob-day-dot { color: var(--green); }
.sob-msg {
  font-size: 15px; color: var(--text-2); line-height: 1.6;
}
.sob-msg strong { color: var(--text-1); font-size: 16px; }
.sob-cta {
  width: 100%; padding: 14px; font-size: 15px; font-weight: 700;
  border-radius: 14px; margin-top: 4px;
}

/* Screen 2 */
.sob-headline-2 {
  font-size: 20px; font-weight: 900; color: var(--text-1); letter-spacing: -.4px;
}
.sob-sub { font-size: 13px; color: var(--text-2); margin-top: -4px; margin-bottom: 4px; }
.sob-goals { display: flex; flex-direction: column; gap: 10px; width: 100%; }
.sob-goal {
  display: flex; align-items: center; gap: 10px;
  background: var(--card-bg2, rgba(255,255,255,.04));
  border: 1.5px solid var(--border-sm); border-radius: 14px;
  padding: 14px 16px; cursor: pointer; position: relative;
  transition: all .2s;
}
.sob-goal:hover { border-color: var(--primary); background: rgba(99,102,241,.06); }
.sob-goal.selected { border-color: var(--primary); background: rgba(99,102,241,.12); }
.sob-goal.featured { border-color: rgba(249,115,22,.5); background: rgba(249,115,22,.06); }
.sob-goal.featured:hover, .sob-goal.featured.selected { border-color: #F97316; background: rgba(249,115,22,.12); }
.sob-goal-days {
  font-size: 15px; font-weight: 800; color: var(--text-1); flex: 1;
}
.sob-goal-gems {
  font-size: 13px; font-weight: 700; color: #60A5FA;
  display: flex; align-items: center; gap: 4px;
}
.sob-goal-badge {
  font-size: 9px; font-weight: 800; letter-spacing: 0;
  padding: 2px 7px; border-radius: 20px;
  background: rgba(99,102,241,.15); color: var(--primary); border: 1px solid rgba(99,102,241,.2);
}
.sob-goal-badge.top {
  background: rgba(249,115,22,.15); color: #F97316; border-color: rgba(249,115,22,.3);
}
.sob-goal-badge.elite {
  background: linear-gradient(135deg,rgba(245,158,11,.2),rgba(249,115,22,.2));
  color: #FF9F0A; border-color: rgba(245,158,11,.35);
}

[data-theme="light"] .sob-goal { background: #f8fafc; }
[data-theme="light"] .sob-goal.featured { background: rgba(249,115,22,.05); }

/* ─── OFENSIVA MODAL ────────────────────────────────────────── */
.ofensiva-overlay {
  position: fixed; inset: 0; z-index: 8800;
  background: rgba(0,0,0,.65); backdrop-filter: blur(10px);
  display: flex; align-items: center; justify-content: center;
  opacity: 0; transition: opacity .3s;
}
.ofensiva-overlay.hidden { display: none; }
.ofensiva-overlay.visible { opacity: 1; }
.ofensiva-card {
  background: var(--bg-surface); border: 1px solid var(--border-sm);
  border-radius: 26px; padding: 28px 24px 32px;
  width: 420px; max-width: calc(100vw - 32px);
  max-height: calc(100vh - 64px); overflow-y: auto;
  position: relative;
  animation: ofmCardIn .4s cubic-bezier(0.34,1.2,0.64,1);
}
@keyframes ofmCardIn { from { transform: scale(.85) translateY(30px); opacity: 0; } to { transform: scale(1) translateY(0); opacity: 1; } }
.ofensiva-close {
  position: absolute; top: 16px; right: 16px;
  background: rgba(255,255,255,.06); border: 1px solid var(--border-sm);
  border-radius: 50%; width: 30px; height: 30px;
  display: flex; align-items: center; justify-content: center;
  cursor: pointer; color: var(--text-2); transition: all .2s;
}
.ofensiva-close:hover { background: rgba(255,255,255,.12); color: var(--text-1); }

/* Tabs */
.ofm-tabs {
  display: flex; gap: 4px; background: rgba(255,255,255,.05);
  border-radius: 12px; padding: 4px; margin-bottom: 24px;
}
.ofm-tab {
  flex: 1; display: flex; align-items: center; justify-content: center; gap: 6px;
  padding: 8px 12px; border-radius: 9px; font-size: 13px; font-weight: 600;
  color: var(--text-2); cursor: pointer; transition: all .2s;
}
.ofm-tab.active { background: var(--primary); color: #fff; }
.ofm-panel.hidden { display: none; }

/* Ofensiva panel */
.ofm-fire-hero {
  display: flex; flex-direction: column; align-items: center; gap: 4px;
  margin-bottom: 16px;
}
.ofm-fire-emoji {
  font-size: 64px; line-height: 1;
  transition: filter .5s, opacity .5s;
}
.ofm-fire-emoji.gray {
  filter: grayscale(1) brightness(.55);
  animation: none;
}
.ofm-fire-emoji.active {
  animation: ofmFirePulse 1.2s ease-in-out infinite alternate;
  filter: drop-shadow(0 0 16px #F97316) drop-shadow(0 0 32px #FBBF24);
}
@keyframes ofmFirePulse {
  0%  { transform: scale(1) rotate(-2deg); }
  100%{ transform: scale(1.08) rotate(2deg); }
}
.ofm-streak-info {
  display: flex; align-items: baseline; gap: 4px;
}
.ofm-streak-num {
  font-size: 40px; font-weight: 900; color: var(--text-1); line-height: 1;
  font-variant-numeric: tabular-nums;
}
.ofm-streak-unit { font-size: 16px; color: var(--text-2); font-weight: 600; }
.ofm-status-msg {
  text-align: center; font-size: 14px; color: var(--text-2);
  background: rgba(255,255,255,.04); border: 1px solid var(--border-sm);
  border-radius: 12px; padding: 12px 16px; display: flex; align-items: center;
  gap: 8px; justify-content: center; margin-bottom: 16px;
}
.ofm-status-msg.done {
  background: rgba(16,185,129,.08); border-color: rgba(16,185,129,.25);
  color: var(--green);
}
.ofm-goal-row {
  display: flex; align-items: center; gap: 8px; margin-bottom: 18px;
  padding: 10px 14px; background: rgba(255,255,255,.04);
  border: 1px solid var(--border-sm); border-radius: 10px;
}
.ofm-goal-label {
  font-size: 10px; font-weight: 700; letter-spacing: 0; color: var(--text-3);
}
.ofm-goal-val { font-size: 13px; font-weight: 700; color: var(--text-1); flex: 1; }
.ofm-change-goal {
  font-size: 11px; color: var(--primary); cursor: pointer; font-weight: 600;
}
.ofm-change-goal:hover { text-decoration: underline; }

/* Progress grid */
.ofm-progress-wrap { width: 100%; }
.ofm-progress-grid {
  display: grid; grid-template-columns: repeat(7, 1fr);
  gap: 6px; justify-items: center;
}
.ofm-day-dot {
  width: 32px; height: 32px; border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  font-size: 10px; font-weight: 700;
  border: 1.5px solid var(--border-sm);
  color: var(--text-3); background: rgba(255,255,255,.03);
  transition: all .25s; position: relative;
}
.ofm-day-dot.done {
  background: linear-gradient(135deg, #F97316, #FF9F0A);
  border-color: transparent; color: #fff;
  box-shadow: 0 2px 8px rgba(249,115,22,.35);
}
.ofm-day-dot.today {
  border-color: #F97316; color: #F97316;
  box-shadow: 0 0 0 2px rgba(249,115,22,.2);
}
.ofm-day-dot.today.done { color: #fff; }

/* Amigos panel */
.ofm-friends-hero { text-align: center; margin-bottom: 20px; }
.ofm-friends-title { font-size: 18px; font-weight: 800; color: var(--text-1); }
.ofm-friends-sub { font-size: 13px; color: var(--text-2); margin-top: 4px; }
.ofm-friends-list { display: flex; flex-direction: column; gap: 10px; margin-bottom: 16px; }
.ofm-friend-item {
  display: flex; align-items: center; gap: 12px;
  padding: 12px 14px; background: rgba(255,255,255,.04);
  border: 1px solid var(--border-sm); border-radius: 12px;
}
.ofm-friend-avatar {
  width: 38px; height: 38px; border-radius: 50%;
  background: linear-gradient(135deg, #6366F1, #BF5AF2);
  display: flex; align-items: center; justify-content: center;
  font-size: 14px; font-weight: 800; color: #fff; flex-shrink: 0;
}
.ofm-friend-info { flex: 1; }
.ofm-friend-name { font-size: 13.5px; font-weight: 700; color: var(--text-1); }
.ofm-friend-streak { font-size: 12px; color: var(--text-3); margin-top: 2px; }
.ofm-friend-flame {
  font-size: 20px;
  filter: drop-shadow(0 0 6px rgba(249,115,22,.5));
}
.ofm-friend-flame.gray { filter: grayscale(1); opacity: .4; }
.ofm-invite-btn {
  width: 100%; padding: 12px; border-radius: 12px; font-weight: 700;
  display: flex; align-items: center; justify-content: center; gap: 8px;
}
.ofm-invite-box {
  margin-top: 14px; padding: 16px; border-radius: 14px;
  background: rgba(99,102,241,.08); border: 1px solid rgba(99,102,241,.2);
  text-align: center;
}
.ofm-invite-box.hidden { display: none; }
.ofm-invite-label { font-size: 11px; color: var(--text-3); font-weight: 600; letter-spacing: 0; margin-bottom: 8px; }
.ofm-invite-code {
  font-size: 24px; font-weight: 900; color: var(--primary);
  font-family: var(--font-mono); letter-spacing: 0; margin-bottom: 10px;
}
.ofm-copy-btn {
  font-size: 12px; font-weight: 700; color: var(--primary);
  background: rgba(99,102,241,.12); border: 1px solid rgba(99,102,241,.2);
  border-radius: 8px; padding: 5px 14px; cursor: pointer; transition: all .2s;
}
.ofm-copy-btn:hover { background: rgba(99,102,241,.2); }
.ofm-empty-friends {
  text-align: center; padding: 24px 16px; color: var(--text-3);
  font-size: 13px; border: 1px dashed var(--border-sm); border-radius: 12px;
}

[data-theme="light"] .ofm-tabs { background: #f1f5f9; }
[data-theme="light"] .ofm-status-msg { background: #f8fafc; }
[data-theme="light"] .ofm-goal-row { background: #f8fafc; }
[data-theme="light"] .ofm-friend-item { background: #f8fafc; }
[data-theme="light"] .ofm-day-dot { background: #f1f5f9; }

/* ─── TIER SYSTEM COLORS ─────────────────────────────────── */
.tier-surreal  { background: rgba(255,107,107,.15) !important; color: #FF6B6B !important; }
.tier-lendas   { background: rgba(168,85,247,.15)  !important; color: #A855F7 !important; }
.tier-elite-p  { background: rgba(245,158,11,.15)  !important; color: #FF9F0A !important; }
.tier-diamante { background: rgba(103,232,249,.15) !important; color: #67E8F9 !important; }
.tier-platina  { background: rgba(199,210,254,.15) !important; color: #C7D2FE !important; }
.tier-ouro     { background: rgba(252,211,77,.15)  !important; color: #FCD34D !important; }
.tier-prata    { background: rgba(148,163,184,.15) !important; color: #94A3B8 !important; }
.tier-bronze   { background: rgba(205,127,50,.15)  !important; color: #CD7F32 !important; }

/* ─── TIER SHOWCASE CARD ─────────────────────────────────── */
.rp-tier-showcase {
  display: flex; align-items: center; gap: 16px;
  border-radius: 18px; padding: 18px 20px; margin-bottom: 16px;
  border: 1px solid var(--border-sm);
  background: var(--bg-surface);
}
.rp-tier-badge-icon {
  font-size: 36px; line-height: 1; flex-shrink: 0;
  filter: drop-shadow(0 0 12px currentColor);
}
.rp-tier-text { flex: 1; min-width: 0; }
.rp-tier-fullname { font-size: 20px; font-weight: 900; letter-spacing: -.4px; }
.rp-tier-sub-txt { font-size: 12px; color: var(--text-3); margin-top: 2px; }
.rp-tier-prog-wrap { width: 140px; flex-shrink: 0; }
.rp-tier-prog-bar {
  height: 6px; background: rgba(255,255,255,.08); border-radius: 3px; overflow: hidden;
  margin-bottom: 5px;
}
.rp-tier-prog-fill { height: 100%; border-radius: 3px; transition: width .6s var(--ease-base); }
.rp-tier-prog-label { font-size: 10.5px; color: var(--text-3); text-align: right; }

/* Tier background tints */
.tier-diamante-bg { border-color: rgba(103,232,249,.2) !important; background: linear-gradient(135deg, rgba(103,232,249,.06), rgba(103,232,249,.02)) !important; }
.tier-platina-bg  { border-color: rgba(199,210,254,.2) !important; background: linear-gradient(135deg, rgba(199,210,254,.06), rgba(199,210,254,.02)) !important; }
.tier-ouro-bg     { border-color: rgba(252,211,77,.2)  !important; background: linear-gradient(135deg, rgba(252,211,77,.06),  rgba(252,211,77,.02))  !important; }
.tier-prata-bg    { border-color: rgba(148,163,184,.2) !important; }
.tier-bronze-bg   { border-color: rgba(205,127,50,.2)  !important; }
.tier-elite-p-bg  { border-color: rgba(245,158,11,.25) !important; background: linear-gradient(135deg, rgba(245,158,11,.08),  rgba(245,158,11,.02))  !important; }
.tier-lendas-bg   { border-color: rgba(168,85,247,.25) !important; background: linear-gradient(135deg, rgba(168,85,247,.08),  rgba(168,85,247,.02))  !important; }
.tier-surreal-bg  { border-color: rgba(255,107,107,.25)!important; background: linear-gradient(135deg, rgba(255,107,107,.08), rgba(255,107,107,.02)) !important; }

/* Tier ladder (ranking page expandable) */
.rp-tier-ladder-wrap { margin-bottom: 12px; }
.rp-tier-ladder-wrap summary { user-select: none; }
.rp-tier-ladder {
  display: grid; grid-template-columns: repeat(3, 1fr); gap: 6px;
  padding: 10px 0;
}
.rp-ladder-tier {
  display: flex; align-items: center; gap: 6px;
  padding: 6px 10px; border-radius: 10px; font-size: 12px;
  color: var(--text-3); border: 1px solid transparent;
  background: rgba(255,255,255,.02);
  transition: all .2s cubic-bezier(0.32, 0.72, 0, 1);
}
.rp-ladder-tier.rp-ladder-reached { color: var(--text-2); background: rgba(255,255,255,.04); }
.rp-ladder-tier.rp-ladder-current {
  font-weight: 700; border-width: 2px;
  background: rgba(255,255,255,.06);
  box-shadow: 0 0 12px rgba(255,255,255,.05);
}
.rp-ladder-icon { font-size: 14px; flex-shrink: 0; }
.rp-ladder-name { flex: 1; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.rp-ladder-you { font-size: 10px; font-weight: 600; opacity: .8; }
[data-theme="light"] .rp-ladder-tier { background: rgba(0,0,0,.02); }
[data-theme="light"] .rp-ladder-tier.rp-ladder-reached { background: rgba(0,0,0,.04); }
[data-theme="light"] .rp-ladder-tier.rp-ladder-current { background: rgba(0,0,0,.06); }
@media (max-width: 600px) {
  .rp-tier-ladder { grid-template-columns: repeat(2, 1fr); }
}

/* ─── RANKING TABS ───────────────────────────────────────── */
.rp-tabs {
  display: flex; gap: 4px; background: rgba(255,255,255,.05);
  border-radius: 12px; padding: 4px; margin-bottom: 20px;
}
.rp-tab-btn {
  flex: 1; display: flex; align-items: center; justify-content: center; gap: 6px;
  padding: 9px 14px; border-radius: 9px; font-size: 13px; font-weight: 600;
  color: var(--text-2); cursor: pointer; transition: all .2s; position: relative;
}
.rp-tab-btn.active { background: var(--primary); color: #fff; }
.rp-friends-badge {
  background: rgba(255,255,255,.25); color: #fff;
  font-size: 10px; font-weight: 800; border-radius: 20px;
  padding: 1px 6px; min-width: 18px; text-align: center;
}
.rp-tab-btn:not(.active) .rp-friends-badge {
  background: rgba(99,102,241,.2); color: var(--primary);
}

/* ─── FRIENDS PANEL (Ranking) ────────────────────────────── */
.rpf-header { text-align: center; margin-bottom: 20px; }
.rpf-title { font-size: 18px; font-weight: 800; color: var(--text-1); }
.rpf-sub { font-size: 13px; color: var(--text-2); margin-top: 4px; }
.rpf-item {
  display: flex; align-items: center; gap: 12px;
  padding: 14px 16px; background: var(--bg-surface);
  border: 1px solid var(--border-sm); border-radius: 14px;
  margin-bottom: 8px; transition: all .2s;
}
.rpf-item:hover { border-color: var(--border-md); }
.rpf-item-you { border-color: rgba(99,102,241,.35) !important; background: rgba(99,102,241,.06) !important; }
.rpf-rank { font-size: 18px; min-width: 28px; text-align: center; }
.rpf-avatar {
  width: 38px; height: 38px; border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  font-size: 14px; font-weight: 800; color: #fff; flex-shrink: 0;
}
.rpf-info { flex: 1; min-width: 0; }
.rpf-name { font-size: 13.5px; font-weight: 700; color: var(--text-1); }
.rpf-stats { display: flex; gap: 8px; align-items: center; margin-top: 4px; flex-wrap: wrap; }
.rpf-tier-badge {
  font-size: 10.5px; font-weight: 700; padding: 2px 7px;
  border-radius: 20px; background: rgba(255,255,255,.06);
}
.rpf-streak, .rpf-gems { font-size: 11px; color: var(--text-3); font-weight: 600; }
.rpf-growth { font-size: 14px; font-weight: 800; color: var(--green); flex-shrink: 0; }
.rpf-fire { font-size: 18px; flex-shrink: 0; }
.rpf-fire.gray { filter: grayscale(1); opacity: .35; }
.rpf-invite-row { margin-top: 16px; }
.rpf-invite-btn {
  width: 100%; padding: 12px; border-radius: 12px; font-weight: 700;
  display: flex; align-items: center; justify-content: center; gap: 8px;
}
.rpf-invite-box {
  margin-top: 14px; padding: 18px; border-radius: 14px;
  background: rgba(99,102,241,.08); border: 1px solid rgba(99,102,241,.2);
  text-align: center;
}
.rpf-invite-box.hidden { display: none; }
.rpf-invite-label { font-size: 11px; color: var(--text-3); letter-spacing: 0; font-weight: 600; margin-bottom: 8px; }
.rpf-invite-code { font-size: 26px; font-weight: 900; color: var(--primary); font-family: var(--font-mono); letter-spacing: 0; margin-bottom: 10px; }
.rpf-copy-btn {
  font-size: 12px; font-weight: 700; color: var(--primary);
  background: rgba(99,102,241,.12); border: 1px solid rgba(99,102,241,.2);
  border-radius: 8px; padding: 6px 16px; cursor: pointer; transition: all .2s;
}
.rpf-copy-btn:hover { background: rgba(99,102,241,.22); }
.rpf-empty {
  text-align: center; padding: 32px 16px; color: var(--text-3); font-size: 13.5px;
  border: 1px dashed var(--border-sm); border-radius: 14px; line-height: 1.7;
}

[data-theme="light"] .rp-tabs { background: #f1f5f9; }
[data-theme="light"] .rp-tier-prog-bar { background: rgba(0,0,0,.08); }
[data-theme="light"] .rp-tier-prog-label { color: var(--text-2); }
[data-theme="light"] .rp-tier-sub-txt { color: var(--text-2); }
[data-theme="light"] .rpf-item { background: #fff; }
[data-theme="light"] .rpf-tier-badge { background: rgba(0,0,0,.06); }

@media (max-width: 768px) {
  .rp-tier-showcase { flex-wrap: wrap; gap: 12px; }
  .rp-tier-prog-wrap { width: 100%; }
  .rp-tier-prog-label { text-align: left; }
}

/* ─── PANEL HIDDEN UTILITY (Ranking + shared) ───────────────── */
#rpPanelCompetition.hidden,
#rpPanelFriends.hidden,
#rpPanelLiga.hidden,
#rpPanelEvolucao.hidden { display: none; }

/* ─── RANKING ZONES ──────────────────────────────────────── */
.rz-separator {
  display: flex; align-items: center; gap: 7px;
  font-size: 10px; font-weight: 800; letter-spacing: 0;
  text-transform: none; padding: 10px 14px 6px;
  color: var(--text-3); margin-top: 4px;
}
.rz-separator.promo { color: #30D158; }
.rz-separator.relega { color: #FF453A; }
.ranking-row.row-promo { /* Apple: no accent border */ }
.ranking-row.row-relega { /* Apple: no accent border */ }

/* Podium medal redesign (no emoji) */
.podium-medal { display: none; }
.podium-medal-1, .podium-medal-2, .podium-medal-3 {
  font-size: 11px; font-weight: 900; letter-spacing: 0;
  padding: 2px 8px; border-radius: 20px; margin-bottom: 4px;
  display: inline-block;
}
.podium-medal-1 { background: rgba(245,158,11,.2); color: #FF9F0A; border: 1px solid rgba(245,158,11,.4); }
.podium-medal-2 { background: rgba(148,163,184,.15); color: #94A3B8; border: 1px solid rgba(148,163,184,.3); }
.podium-medal-3 { background: rgba(205,127,50,.15); color: #CD7F32; border: 1px solid rgba(205,127,50,.3); }

/* Ofm flame SVG */
.ofm-flame-svg { width: 52px; height: 65px; }
.ofm-fire-emoji.gray .ofm-flame-svg path { fill: #6B7280 !important; }
.ofm-fire-emoji.active .ofm-flame-svg { filter: drop-shadow(0 0 12px rgba(249,115,22,.6)); animation: ofmFirePulse 1.2s ease-in-out infinite alternate; }

/* Sob flame SVG */
.sob-flame-svg { width: 72px; height: 90px; }
.sob-fire-wrap .sob-flame-svg { filter: drop-shadow(0 0 18px rgba(249,115,22,.6)) drop-shadow(0 0 36px rgba(245,158,11,.4)); animation: firePulse 1s ease-in-out infinite alternate; }

/* ─── FRIEND PROFILE MODAL ───────────────────────────────── */
.fpro-overlay {
  position: fixed; inset: 0; z-index: 9300;
  background: rgba(0,0,0,.7); backdrop-filter: blur(12px);
  display: flex; align-items: center; justify-content: center;
  opacity: 0; transition: opacity .3s;
}
.fpro-overlay.hidden { display: none; }
.fpro-overlay.visible { opacity: 1; }
.fpro-card {
  background: var(--bg-surface); border: 1px solid var(--border-sm);
  border-radius: 24px; padding: 36px 28px 32px;
  width: 320px; max-width: calc(100vw - 40px);
  display: flex; flex-direction: column; align-items: center;
  gap: 12px; position: relative; text-align: center;
  animation: ofmCardIn .4s cubic-bezier(0.34,1.2,0.64,1);
}
.fpro-close {
  position: absolute; top: 14px; right: 14px;
  background: rgba(255,255,255,.06); border: 1px solid var(--border-sm);
  border-radius: 50%; width: 28px; height: 28px;
  display: flex; align-items: center; justify-content: center;
  cursor: pointer; color: var(--text-2); transition: all .2s;
}
.fpro-close:hover { background: rgba(255,255,255,.12); }
.fpro-avatar {
  width: 72px; height: 72px; border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  font-size: 24px; font-weight: 900; color: #fff;
  box-shadow: 0 8px 24px rgba(0,0,0,.25);
}
.fpro-name { font-size: 20px; font-weight: 900; color: var(--text-1); }
.fpro-tier {
  font-size: 13px; font-weight: 700; padding: 4px 12px;
  border-radius: 20px; background: rgba(255,255,255,.06);
  border: 1px solid rgba(255,255,255,.1);
}
.fpro-stats-grid {
  display: flex; gap: 12px; width: 100%; margin: 4px 0;
}
.fpro-stat {
  flex: 1; background: rgba(255,255,255,.04);
  border: 1px solid var(--border-sm); border-radius: 12px;
  padding: 12px 8px; display: flex; flex-direction: column;
  align-items: center; gap: 4px;
}
.fpro-stat-icon { display: flex; align-items: center; justify-content: center; }
.fpro-stat-val { font-size: 16px; font-weight: 900; color: var(--text-1); }
.fpro-stat-lbl { font-size: 10px; color: var(--text-3); font-weight: 600; letter-spacing: 0; }
.fpro-active-row {
  display: flex; align-items: center; gap: 7px;
  font-size: 12.5px; font-weight: 600; padding: 8px 14px;
  border-radius: 20px; border: 1px solid var(--border-sm);
}
.fpro-active-row.active { color: #30D158; border-color: rgba(16,185,129,.25); background: rgba(16,185,129,.08); }
.fpro-active-row.inactive { color: var(--text-3); }
.fpro-active-dot {
  width: 7px; height: 7px; border-radius: 50%; background: currentColor; flex-shrink: 0;
}
.fpro-active-row.active .fpro-active-dot { animation: livePulse 1.4s ease-in-out infinite; }
.fpro-challenge-btn {
  width: 100%; padding: 11px; border-radius: 12px; font-weight: 700; font-size: 13.5px;
  background: rgba(99,102,241,.12); border: 1px solid rgba(99,102,241,.25);
  color: var(--primary); transition: all .2s;
}
.fpro-challenge-btn:hover { background: rgba(99,102,241,.2); }

[data-theme="light"] .fpro-stat { background: #f8fafc; }
[data-theme="light"] .fpro-tier { background: rgba(0,0,0,.05); border-color: rgba(0,0,0,.1); }

/* ═══════════════════════════════════════════
   TASK CONFIRMATION OVERLAY
   ═══════════════════════════════════════════ */
.task-confirm-overlay {
  position: fixed; inset: 0; z-index: 9200;
  background: rgba(0,0,0,.70); backdrop-filter: blur(10px);
  display: flex; align-items: center; justify-content: center;
  padding: 16px;
  opacity: 0; transition: opacity .3s cubic-bezier(0.32, 0.72, 0, 1);
}
.task-confirm-overlay.visible { opacity: 1; }
.task-confirm-card {
  background: var(--bg-surface); border: 1px solid var(--border-sm);
  border-radius: var(--r-2xl); padding: 28px 24px;
  width: 100%; max-width: 380px;
  text-align: center;
  transform: translateY(20px) scale(.95);
  transition: transform .35s cubic-bezier(.34,1.56,.64,1);
}
.task-confirm-overlay.visible .task-confirm-card {
  transform: translateY(0) scale(1);
}
.task-confirm-icon {
  width: 48px; height: 48px; border-radius: 50%;
  background: rgba(16,185,129,.12); border: 2px solid rgba(16,185,129,.25);
  display: flex; align-items: center; justify-content: center;
  font-size: 22px; color: #30D158; margin: 0 auto 14px;
}
.task-confirm-title {
  font-size: 18px; font-weight: 700; color: var(--text-1); margin-bottom: 8px;
}
.task-confirm-desc {
  font-size: 13px; color: var(--text-2); line-height: 1.5; margin-bottom: 14px;
}
.task-confirm-desc strong {
  color: var(--text-1); font-weight: 600;
}
.task-confirm-rewards {
  display: flex; gap: 8px; justify-content: center; margin-bottom: 14px;
}
.task-confirm-reward {
  display: flex; align-items: center; gap: 4px;
  background: rgba(99,102,241,.1); border: 1px solid rgba(99,102,241,.2);
  border-radius: 16px; padding: 4px 10px;
  font-size: 11px; font-weight: 700; color: var(--primary);
}
.task-confirm-reward.gems {
  background: rgba(96,165,250,.1); border-color: rgba(96,165,250,.25);
  color: #60A5FA;
}
.task-confirm-note {
  font-size: 11px; color: var(--text-3); line-height: 1.5;
  margin-bottom: 18px; padding: 0 8px;
  font-style: italic;
}
.task-confirm-actions {
  display: flex; flex-direction: column; gap: 8px;
}
.task-confirm-yes {
  width: 100%; padding: 12px; font-size: 14px; font-weight: 700;
  border-radius: 12px;
}
.task-confirm-no {
  font-size: 13px; color: var(--text-3); padding: 6px;
}
.task-confirm-no:hover { color: var(--text-2); }

/* ═══════════════════════════════════════════
   GEMS SHOP MODAL
   ═══════════════════════════════════════════ */
.shop-overlay {
  position: fixed; inset: 0; z-index: 9000;
  background: rgba(0,0,0,.65); backdrop-filter: blur(8px);
  display: flex; align-items: center; justify-content: center;
  padding: 16px;
  opacity: 0; transition: opacity .3s cubic-bezier(0.32, 0.72, 0, 1);
}
.shop-overlay.visible { opacity: 1; }
.shop-overlay.hidden { display: none; }
.shop-card {
  background: var(--bg-surface); border: 1px solid var(--border-sm);
  border-radius: var(--r-2xl); padding: 28px 24px;
  width: 100%; max-width: 480px;
  max-height: 90vh; overflow-y: auto;
  position: relative;
  transform: translateY(16px); transition: transform .3s cubic-bezier(.34,1.56,.64,1);
}
.shop-overlay.visible .shop-card { transform: translateY(0); }
.shop-close {
  position: absolute; top: 16px; right: 16px;
  background: var(--bg-base); border: 1px solid var(--border-sm);
  border-radius: 50%; width: 30px; height: 30px;
  display: flex; align-items: center; justify-content: center;
  color: var(--text-2); cursor: pointer; transition: all .15s;
}
.shop-close:hover { background: var(--bg-elevated); color: var(--text-1); }
.shop-header { margin-bottom: 20px; }
.shop-title { font-size: 20px; font-weight: 700; color: var(--text-1); margin-bottom: 4px; }
.shop-subtitle { font-size: 13px; color: var(--text-2); margin-bottom: 12px; }
.shop-balance {
  display: inline-flex; align-items: center; gap: 6px;
  background: rgba(99,102,241,.1); border: 1px solid rgba(99,102,241,.2);
  border-radius: 20px; padding: 5px 12px;
  font-size: 13px; font-weight: 600; color: var(--primary);
  font-family: var(--font-mono);
}
.shop-grid { display: flex; flex-direction: column; gap: 10px; }
.shop-item {
  display: flex; align-items: center; gap: 14px;
  background: var(--bg-base); border: 1px solid var(--border-sm);
  border-radius: var(--r-lg); padding: 14px 16px;
  transition: border-color .15s;
}
.shop-item:hover { border-color: var(--border-md); }
.shop-item.owned { border-color: rgba(16,185,129,.3); background: rgba(16,185,129,.06); }
.shop-item.cant-afford { opacity: .55; }
.shop-item-icon {
  font-size: 22px; width: 40px; height: 40px; border-radius: 10px;
  background: var(--bg-elevated); display: flex; align-items: center; justify-content: center;
  flex-shrink: 0;
}
.shop-item-info { flex: 1; min-width: 0; }
.shop-item-name { font-size: 14px; font-weight: 600; color: var(--text-1); margin-bottom: 2px; }
.shop-item-desc { font-size: 11.5px; color: var(--text-2); line-height: 1.4; margin-bottom: 4px; }
.shop-item-type {
  font-size: 10px; font-family: var(--font-mono); text-transform: none;
  color: var(--text-3); letter-spacing: 0;
}
.shop-item-right { flex-shrink: 0; }
.shop-buy-btn {
  display: flex; align-items: center; gap: 5px;
  background: rgba(99,102,241,.12); border: 1px solid rgba(99,102,241,.25);
  border-radius: 20px; padding: 6px 12px;
  font-size: 13px; font-weight: 700; color: var(--primary);
  cursor: pointer; transition: all .15s;
}
.shop-buy-btn:hover:not(.disabled) { background: rgba(99,102,241,.22); transform: scale(1.04); }
.shop-buy-btn.disabled { opacity: .45; cursor: not-allowed; }
.shop-item-owned {
  font-size: 11px; font-weight: 700; color: var(--secondary);
  font-family: var(--font-mono); text-transform: none; letter-spacing: 0;
}

/* ═══════════════════════════════════════════
   PLANNER QUICK-ADD MODAL
   ═══════════════════════════════════════════ */
.pa-overlay {
  position: fixed; inset: 0; z-index: 9000;
  background: rgba(0,0,0,.6); backdrop-filter: blur(6px);
  display: flex; align-items: center; justify-content: center;
  padding: 16px;
  opacity: 0; transition: opacity .25s cubic-bezier(0.32, 0.72, 0, 1);
}
.pa-overlay.visible { opacity: 1; }
.pa-overlay.hidden { display: none; }
.pa-card {
  background: var(--bg-surface); border: 1px solid var(--border-sm);
  border-radius: var(--r-2xl); padding: 24px 22px;
  width: 100%; max-width: 400px;
  transform: translateY(14px) scale(.97);
  transition: transform .3s cubic-bezier(.34,1.56,.64,1);
}
.pa-overlay.visible .pa-card { transform: none; }
.pa-header {
  display: flex; align-items: center; justify-content: space-between;
  margin-bottom: 12px;
}
.pa-title { font-size: 16px; font-weight: 700; color: var(--text-1); }
.pa-close {
  background: none; border: none; color: var(--text-2);
  cursor: pointer; padding: 4px; border-radius: 6px; transition: color .15s;
}
.pa-close:hover { color: var(--text-1); }
.pa-day-label {
  font-size: 12px; font-family: var(--font-mono); color: var(--primary);
  margin-bottom: 14px; font-weight: 600; letter-spacing: .2px;
}
.pa-input {
  width: 100%; margin-bottom: 16px;
  background: var(--bg-base) !important;
}
.pa-type-label { font-size: 11px; font-weight: 600; color: var(--text-3); text-transform: none; letter-spacing: 0; margin-bottom: 8px; }
.pa-types { display: flex; flex-wrap: wrap; gap: 6px; margin-bottom: 20px; }
.pa-type-btn {
  padding: 5px 12px; border-radius: 20px; font-size: 12px; font-weight: 600;
  background: var(--bg-base); border: 1px solid var(--border-sm);
  color: var(--text-2); cursor: pointer; transition: all .15s;
}
.pa-type-btn:hover { border-color: var(--border-md); color: var(--text-1); }
.pa-type-btn.active {
  background: rgba(99,102,241,.12); border-color: rgba(99,102,241,.3);
  color: var(--primary);
}
.pa-footer { display: flex; justify-content: flex-end; gap: 8px; }

/* ═══════════════════════════════════════════
   XP & LEVEL SYSTEM
   ═══════════════════════════════════════════ */
/* XP Pill — Apple minimal capsule */
.xp-pill {
  display: flex; align-items: center; gap: 5px;
  background: rgba(255,255,255,.06); border: none;
  border-radius: var(--r-full); padding: 4px 10px 4px 6px;
  cursor: pointer; transition: background .15s cubic-bezier(0.32, 0.72, 0, 1);
  min-width: 100px;
}
.xp-pill:hover { background: rgba(255,255,255,.1); }
.xp-level-badge {
  background: var(--primary);
  color: #fff; font-size: 10px; font-weight: 600;
  padding: 2px 7px; border-radius: 10px;
  font-family: var(--font-body); letter-spacing: 0;
  white-space: nowrap; flex-shrink: 0;
}
.xp-bar-wrap {
  flex: 1; height: 4px; background: rgba(255,255,255,.08);
  border-radius: 2px; overflow: hidden; min-width: 28px;
}
.xp-bar-fill {
  height: 100%; border-radius: 2px;
  background: var(--primary);
  transition: width .6s cubic-bezier(.4,0,.2,1);
  position: relative;
}
.xp-bar-fill::after { display: none; }
.xp-label {
  font-size: 10px; font-family: var(--font-body);
  color: var(--text-3); white-space: nowrap; flex-shrink: 0;
  font-variant-numeric: tabular-nums;
}
/* XP level-up — subtle scale */
@keyframes xpLevelUp {
  0% { transform: scale(1); }
  50% { transform: scale(1.05); }
  100% { transform: scale(1); }
}
.xp-pill.level-up { animation: xpLevelUp .5s ease; }

/* ═══════════════════════════════════════════
   FLOATING NUMBERS ANIMATION
   ═══════════════════════════════════════════ */
.float-reward {
  position: absolute; pointer-events: none;
  font-family: var(--font-display); font-weight: 800;
  font-size: 18px; white-space: nowrap;
  animation: floatUp 1.4s cubic-bezier(.2,.8,.3,1) forwards;
  text-shadow: 0 2px 8px rgba(0,0,0,.4);
  z-index: 99999;
}
.float-reward.pts { color: #A78BFA; }
.float-reward.gems { color: #60A5FA; }
.float-reward.xp { color: #C4B5FD; }
@keyframes floatUp {
  0% { opacity: 1; transform: translateY(0) scale(1); }
  30% { opacity: 1; transform: translateY(-20px) scale(1.15); }
  100% { opacity: 0; transform: translateY(-70px) scale(.8); }
}

/* ═══════════════════════════════════════════
   DAILY BONUS MODAL
   ═══════════════════════════════════════════ */
.db-overlay {
  position: fixed; inset: 0; z-index: 9100;
  background: rgba(0,0,0,.7); backdrop-filter: blur(8px);
  display: flex; align-items: center; justify-content: center;
  padding: 16px;
  opacity: 0; transition: opacity .3s cubic-bezier(0.32, 0.72, 0, 1);
}
.db-overlay.visible { opacity: 1; }
.db-overlay.hidden { display: none; }
.db-card {
  background: var(--bg-surface); border: 1px solid var(--border-sm);
  border-radius: var(--r-2xl); padding: 32px 28px;
  width: 100%; max-width: 420px; text-align: center;
  transform: scale(.92); transition: transform .4s cubic-bezier(.34,1.56,.64,1);
}
.db-overlay.visible .db-card { transform: scale(1); }
.db-sparkle {
  font-size: 36px; color: #FF9F0A; margin-bottom: 8px;
  animation: sparkleRotate 3s linear infinite;
}
@keyframes sparkleRotate {
  0%,100% { transform: rotate(0deg) scale(1); }
  25% { transform: rotate(15deg) scale(1.1); }
  50% { transform: rotate(0deg) scale(1); }
  75% { transform: rotate(-15deg) scale(1.1); }
}
.db-title {
  font-size: 22px; font-weight: 800; color: var(--text-1);
  font-family: var(--font-display); margin-bottom: 4px;
}
.db-subtitle { font-size: 13px; color: var(--text-2); margin-bottom: 24px; }
.db-cards {
  display: flex; gap: 14px; justify-content: center; margin-bottom: 20px;
}
.db-mystery-card {
  width: 100px; height: 130px; border-radius: 14px;
  background: linear-gradient(145deg, rgba(99,102,241,.15), rgba(139,92,246,.1));
  border: 2px solid rgba(99,102,241,.3);
  cursor: pointer; position: relative;
  transition: all .3s; perspective: 600px;
  overflow: hidden;
}
.db-mystery-card:hover:not(.revealed):not(.dimmed) {
  transform: translateY(-4px) scale(1.04);
  border-color: rgba(139,92,246,.6);
  box-shadow: 0 8px 24px rgba(99,102,241,.25);
}
.db-card-front, .db-card-back {
  position: absolute; inset: 0;
  display: flex; flex-direction: column;
  align-items: center; justify-content: center;
  border-radius: 12px; transition: all .5s;
  backface-visibility: hidden;
}
.db-card-front {
  font-size: 36px; font-weight: 800; color: rgba(139,92,246,.5);
  font-family: var(--font-display);
  background: linear-gradient(145deg, rgba(99,102,241,.08), rgba(139,92,246,.05));
}
.db-card-back {
  background: linear-gradient(145deg, rgba(16,185,129,.12), rgba(99,102,241,.08));
  border: 1px solid rgba(16,185,129,.3);
  opacity: 0; transform: rotateY(180deg);
}
.db-mystery-card.revealed .db-card-front { opacity: 0; transform: rotateY(180deg); }
.db-mystery-card.revealed .db-card-back { opacity: 1; transform: rotateY(0); }
.db-mystery-card.chosen {
  border-color: rgba(16,185,129,.6) !important;
  box-shadow: 0 0 20px rgba(16,185,129,.3) !important;
}
.db-mystery-card.dimmed { opacity: .45; cursor: default; transform: scale(.95); }
.db-reward-icon { font-size: 28px; margin-bottom: 4px; }
.db-reward-val {
  font-size: 16px; font-weight: 800; color: var(--text-1);
  font-family: var(--font-mono);
}
.db-footer { min-height: 24px; }
.db-streak-bonus {
  font-size: 12px; color: var(--cta); font-weight: 600;
  font-family: var(--font-mono);
}

/* ═══════════════════════════════════════════
   ACHIEVEMENTS MODAL
   ═══════════════════════════════════════════ */
.ach-overlay {
  position: fixed; inset: 0; z-index: 9000;
  background: rgba(0,0,0,.75); backdrop-filter: blur(10px);
  display: flex; align-items: center; justify-content: center;
  padding: 16px;
  opacity: 0; transition: opacity .25s cubic-bezier(0.32, 0.72, 0, 1);
}
.ach-overlay.visible { opacity: 1; }
.ach-overlay.hidden { display: none; }
.ach-card {
  background: var(--bg-surface); border: 1px solid var(--border-sm);
  border-radius: var(--r-2xl); padding: 28px 24px;
  width: 100%; max-width: 500px; max-height: 85vh; overflow-y: auto;
  position: relative;
  transform: translateY(16px); transition: transform .3s cubic-bezier(.34,1.56,.64,1);
}
.ach-overlay.visible .ach-card { transform: translateY(0); }
.ach-header { text-align: center; margin-bottom: 20px; }
.ach-title { font-size: 20px; font-weight: 800; color: var(--text-1); margin-bottom: 4px; }
.ach-subtitle { font-size: 13px; color: var(--text-2); margin-bottom: 14px; }
.ach-progress-row { display: flex; align-items: center; gap: 10px; justify-content: center; }
.ach-progress-bar {
  width: 160px; height: 6px; background: rgba(255,255,255,.06);
  border-radius: 3px; overflow: hidden;
}
.ach-progress-fill {
  height: 100%; border-radius: 3px;
  background: linear-gradient(90deg, #FF9F0A, #F97316);
  transition: width .6s cubic-bezier(0.32, 0.72, 0, 1);
}
.ach-progress-label {
  font-size: 12px; font-family: var(--font-mono); color: var(--text-3); font-weight: 600;
}
.ach-grid {
  display: grid; grid-template-columns: 1fr 1fr; gap: 10px;
}
.ach-item {
  display: flex; align-items: center; gap: 12px;
  background: var(--bg-base); border: 1px solid var(--border-sm);
  border-radius: var(--r-lg); padding: 14px 12px;
  transition: all .2s;
}
.ach-item.unlocked {
  border-color: rgba(245,158,11,.25);
  background: rgba(245,158,11,.04);
}
.ach-item.locked { opacity: .5; }
.ach-item-icon {
  width: 40px; height: 40px; border-radius: 10px;
  display: flex; align-items: center; justify-content: center;
  font-size: 20px; flex-shrink: 0;
  background: var(--bg-elevated);
}
.ach-item.unlocked .ach-item-icon {
  background: rgba(245,158,11,.12);
}
.ach-item-info { flex: 1; min-width: 0; }
.ach-item-name {
  font-size: 13px; font-weight: 700; color: var(--text-1); margin-bottom: 2px;
}
.ach-item.locked .ach-item-name { color: var(--text-3); }
.ach-item-desc {
  font-size: 11px; color: var(--text-2); line-height: 1.4;
}
.ach-item.locked .ach-item-desc { color: var(--text-3); }
.ach-item-check {
  width: 20px; height: 20px; border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  flex-shrink: 0;
}
.ach-item.unlocked .ach-item-check {
  background: rgba(16,185,129,.15); color: #30D158;
}
.ach-item.locked .ach-item-check {
  background: var(--bg-elevated); color: var(--text-3);
}
/* Achievement unlock toast special */
@keyframes achieveUnlock {
  0% { transform: translateX(120%); opacity: 0; }
  10% { transform: translateX(0); opacity: 1; }
  90% { transform: translateX(0); opacity: 1; }
  100% { transform: translateX(120%); opacity: 0; }
}
.achieve-toast {
  position: fixed; bottom: 80px; right: 16px;
  background: var(--bg-surface);
  border: 1px solid rgba(245,158,11,.3);
  border-radius: 14px; padding: 12px 16px;
  display: flex; align-items: center; gap: 10px;
  z-index: 99997; min-width: 240px;
  animation: achieveUnlock 4s cubic-bezier(.34,1.2,.64,1) forwards;
  backdrop-filter: blur(12px);
}
.achieve-toast-icon { font-size: 24px; }
.achieve-toast-text { flex: 1; }
.achieve-toast-label {
  font-size: 10px; font-weight: 700; text-transform: none;
  letter-spacing: .8px; color: #FF9F0A; font-family: var(--font-mono);
}
.achieve-toast-name { font-size: 14px; font-weight: 700; color: var(--text-1); }

/* Light mode — achievements modal solid background */
[data-theme="light"] .ach-overlay { background: rgba(0,0,0,.55); }
[data-theme="light"] .ach-card {
  background: #FFFFFF;
  border-color: rgba(0,0,0,.1);
  box-shadow: 0 16px 48px rgba(0,0,0,.2);
}
[data-theme="light"] .ach-item {
  background: #F5F6FA;
  border-color: rgba(0,0,0,.06);
}
[data-theme="light"] .ach-progress-bar { background: rgba(0,0,0,.06); }
[data-theme="light"] .db-card {
  background: #FFFFFF;
  border-color: rgba(0,0,0,.1);
  box-shadow: 0 16px 48px rgba(0,0,0,.2);
}

/* ═══════════════════════════════════════════
   ONBOARDING TOUR
   ═══════════════════════════════════════════ */
.tour-overlay {
  position: fixed; inset: 0; z-index: 10000;
  background: rgba(0,0,0,.6);
  pointer-events: auto;
}
.tour-spotlight {
  position: fixed; z-index: 10001;
  box-shadow: 0 0 0 9999px rgba(0,0,0,.55);
  border: 2px solid var(--primary);
  pointer-events: none;
  transition: all .4s cubic-bezier(.4,0,.2,1);
}
.tour-tooltip {
  position: fixed; z-index: 10002;
  width: 280px;
  background: var(--surface-2, #12141C);
  border: 1px solid var(--primary-border);
  border-radius: var(--r-lg);
  padding: 16px 18px;
  box-shadow: 0 12px 40px rgba(0,0,0,.4);
  animation: tourFadeIn .3s ease;
}
@keyframes tourFadeIn { from { opacity: 0; transform: translateY(8px); } to { opacity: 1; transform: translateY(0); } }
.tour-tooltip.above { animation-name: tourFadeInUp; }
@keyframes tourFadeInUp { from { opacity: 0; transform: translateY(-8px); } to { opacity: 1; transform: translateY(0); } }
.tour-step-count {
  font-size: 10px; font-family: var(--font-mono); color: var(--primary);
  letter-spacing: 0; margin-bottom: 6px; font-weight: 600;
}
.tour-title { font-size: 15px; font-weight: 800; color: var(--text-1); margin-bottom: 4px; }
.tour-text { font-size: 12.5px; color: var(--text-2); line-height: 1.5; margin-bottom: 14px; }
.tour-actions { display: flex; justify-content: space-between; align-items: center; }
.tour-skip {
  background: none; border: none; font-size: 12px; color: var(--text-3);
  cursor: pointer; padding: 0; font-family: inherit;
}
.tour-skip:hover { color: var(--text-2); }
.tour-next {
  background: var(--primary); color: #fff; border: none;
  padding: 8px 18px; border-radius: var(--r-md); font-size: 12px;
  font-weight: 700; cursor: pointer; font-family: inherit;
  transition: all var(--ease-fast);
}
.tour-next:hover { opacity: .85; transform: translateY(-1px); }
[data-theme="light"] .tour-tooltip { background: #FFFFFF; box-shadow: 0 12px 40px rgba(0,0,0,.2); }

/* ═══════════════════════════════════════════
   SOCIAL PROOF PULSE
   ═══════════════════════════════════════════ */
@keyframes socialPulseIn {
  0% { transform: translateX(-100%) scale(.9); opacity: 0; }
  8% { transform: translateX(0) scale(1); opacity: 1; }
  85% { transform: translateX(0) scale(1); opacity: 1; }
  100% { transform: translateX(-100%); opacity: 0; }
}
.social-pulse {
  position: fixed; bottom: 24px; left: 16px;
  background: var(--bg-surface); border: 1px solid var(--border-sm);
  border-radius: 12px; padding: 10px 14px;
  display: flex; align-items: center; gap: 10px;
  z-index: 9990; max-width: 320px;
  animation: socialPulseIn 5s cubic-bezier(.34,1.2,.64,1) forwards;
  box-shadow: 0 4px 20px rgba(0,0,0,.3);
}
.social-pulse-av {
  width: 30px; height: 30px; border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  font-size: 11px; font-weight: 700; color: #fff; flex-shrink: 0;
}
.social-pulse-text { font-size: 12px; color: var(--text-2); line-height: 1.4; }
.social-pulse-text strong { color: var(--text-1); font-weight: 700; }
.social-pulse-time {
  font-size: 9px; color: var(--text-3); font-family: var(--font-mono);
  margin-top: 2px;
}

/* ═══════════════════════════════════════════
   MYSTERY MULTIPLIER SPINNER
   ═══════════════════════════════════════════ */
.mult-spinner { text-align: center; margin-bottom: 12px; }
.mult-spinner.hidden { display: none; }
.mult-label {
  font-size: 11px; font-weight: 700; text-transform: none;
  letter-spacing: 0; color: #FF9F0A;
  font-family: var(--font-mono); margin-bottom: 8px;
}
.mult-reel-wrap {
  width: 80px; height: 48px; margin: 0 auto;
  overflow: hidden; border-radius: 10px;
  border: 2px solid rgba(245,158,11,.4);
  background: rgba(245,158,11,.06);
  position: relative;
}
.mult-reel-wrap::before, .mult-reel-wrap::after {
  content: ''; position: absolute; left: 0; right: 0; height: 10px; z-index: 2;
  pointer-events: none;
}
.mult-reel-wrap::before { top: 0; background: linear-gradient(to bottom, var(--bg-surface), transparent); }
.mult-reel-wrap::after { bottom: 0; background: linear-gradient(to top, var(--bg-surface), transparent); }
.mult-reel {
  display: flex; flex-direction: column;
  transition: transform 2.2s cubic-bezier(.15,.85,.25,1);
}
.mult-slot {
  height: 48px; display: flex; align-items: center; justify-content: center;
  font-size: 24px; font-weight: 900; color: var(--text-1);
  font-family: var(--font-display);
}
.mult-slot[data-val="5"] { color: #FF9F0A; text-shadow: 0 0 10px rgba(245,158,11,.5); }
.mult-slot[data-val="3"] { color: #A78BFA; }
.mult-slot[data-val="2"] { color: #60A5FA; }
/* Jackpot flash */
@keyframes jackpotFlash {
  0%,100% { box-shadow: none; }
  50% { box-shadow: 0 0 30px rgba(245,158,11,.6), inset 0 0 20px rgba(245,158,11,.15); }
}
.mult-reel-wrap.jackpot {
  border-color: #FF9F0A !important;
  animation: jackpotFlash .5s ease 3;
}

/* ═══════════════════════════════════════════
   GHOST COMPETITOR
   ═══════════════════════════════════════════ */
.ghost-rival {
  position: absolute;
  pointer-events: none; z-index: 3;
  display: flex; align-items: center; gap: 5px;
  transition: all 1s cubic-bezier(0.32, 0.72, 0, 1);
}
.ghost-dot {
  width: 10px; height: 10px; border-radius: 50%;
  background: rgba(244,63,94,.7);
  box-shadow: 0 0 8px rgba(244,63,94,.5);
  animation: ghostBreathe 2.5s ease-in-out infinite;
}
@keyframes ghostBreathe {
  0%,100% { opacity: .5; transform: scale(1); }
  50% { opacity: .9; transform: scale(1.2); }
}
.ghost-rival.close .ghost-dot {
  background: rgba(239,68,68,.9);
  animation-duration: 1.2s;
  box-shadow: 0 0 12px rgba(239,68,68,.7);
}
.ghost-label {
  font-size: 9px; font-family: var(--font-mono);
  color: rgba(244,63,94,.7); white-space: nowrap;
  font-weight: 600; letter-spacing: .3px;
}
.ghost-rival.close .ghost-label { color: rgba(239,68,68,.9); }

/* ═══════════════════════════════════════════
   COMBO COUNTER
   ═══════════════════════════════════════════ */
.combo-badge {
  display: flex; align-items: center; gap: 8px;
  background: linear-gradient(135deg, rgba(245,158,11,.12), rgba(239,68,68,.08));
  border: 1px solid rgba(245,158,11,.3);
  border-radius: 12px; padding: 8px 12px;
  margin-bottom: 12px; width: fit-content;
  animation: comboEntrance .5s cubic-bezier(.34,1.56,.64,1);
}
.combo-badge.hidden { display: none; }
@keyframes comboEntrance {
  0% { transform: scale(0) rotate(-10deg); opacity: 0; }
  100% { transform: scale(1) rotate(0); opacity: 1; }
}
.combo-fire { font-size: 18px; }
.combo-label {
  font-size: 9px; font-weight: 700; text-transform: none;
  letter-spacing: 0; color: var(--cta); font-family: var(--font-mono);
}
.combo-val {
  font-size: 20px; font-weight: 900; color: var(--text-1);
  font-family: var(--font-display);
}
.combo-badge.perfect { border-color: rgba(16,185,129,.5); background: linear-gradient(135deg, rgba(16,185,129,.15), rgba(99,102,241,.08)); }
.combo-badge.perfect .combo-label { color: var(--secondary); }
.combo-badge.perfect .combo-val { color: #30D158; }
.combo-timer-ring { flex-shrink: 0; }
@keyframes comboPulse {
  0%,100% { transform: scale(1); }
  50% { transform: scale(1.08); }
}
.combo-badge.bump { animation: comboPulse .4s ease; }

/* ═══════════════════════════════════════════
   MOBILE POLISH — comprehensive fixes
   ═══════════════════════════════════════════ */
@media (max-width: 480px) {
  /* Ranking stats bar: 2 col, last item spans full */
  .rp-statsbar {
    grid-template-columns: 1fr 1fr !important;
    gap: 0;
  }
  .rp-stat-divider { display: none !important; }
  .rp-stat {
    padding: 10px 12px !important;
    border-bottom: 1px solid var(--border-sm);
  }
  .rp-stat:last-child { grid-column: 1 / -1; border-bottom: none; }
  .rp-stat-label { font-size: 9px; }
  .rp-stat-value { font-size: 18px; }

  /* Growth update bar: stack buttons */
  .gw-update-actions {
    flex-wrap: wrap !important;
    gap: 4px !important;
  }
  .gw-update-actions .btn { font-size: 11px !important; padding: 5px 8px !important; }
  .gw-update-bar {
    flex-direction: column !important;
    align-items: flex-start !important;
    gap: 8px !important;
  }

  /* Growth stats bar: 2 columns */
  .gw-stats-bar {
    grid-template-columns: 1fr 1fr !important;
    gap: 0 !important;
  }
  .gw-stat-divider { display: none !important; }
  .gw-stat {
    padding: 10px 12px !important;
    border-bottom: 1px solid var(--border-sm);
  }
  .gw-stat:last-child, .gw-stat:nth-last-child(2) { border-bottom: none; }

  /* Planner toolbar: tighter */
  .planner-nav { gap: 6px; }
  .planner-week-label { font-size: 12px; }
  .planner-actions { gap: 4px; }
  .planner-actions .btn { font-size: 11px; padding: 6px 10px; }

  /* Type cards: horizontal scroll on mobile */
  .quick-types {
    display: flex !important;
    overflow-x: auto !important;
    scroll-snap-type: x mandatory;
    -webkit-overflow-scrolling: touch;
    gap: 10px !important;
    padding-bottom: 4px;
    scrollbar-width: none;
  }
  .quick-types::-webkit-scrollbar { display: none; }
  .quick-types .type-card {
    min-width: 130px;
    flex-shrink: 0;
    scroll-snap-align: start;
  }
  .type-card-name { font-size: 11px; }

  /* Balance card */
  .balance-score-number { font-size: 36px; }
  .balance-tip { font-size: 11px; }

  /* Ranking rows tighter */
  .ranking-row { padding: 8px 10px !important; gap: 8px !important; }
  .ranking-row .ranking-av { width: 28px; height: 28px; font-size: 10px; }
  .ranking-row .ranking-name { font-size: 12px; }
  .ranking-row .ranking-tier-pill { font-size: 9px; padding: 1px 6px; }
  .ranking-row .ranking-growth { font-size: 12px; }

  /* Podium smaller */
  .podium-item { padding: 8px 4px; }
  .podium-name { font-size: 10px; }
  .podium-score { font-size: 11px; }
  .podium-1 .podium-avatar { width: 42px !important; height: 42px !important; font-size: 14px; }
  .podium-2 .podium-avatar, .podium-3 .podium-avatar { width: 32px; height: 32px; font-size: 11px; }

  /* Ranking tab buttons */
  .rp-tabs { gap: 4px; }
  .rp-tab-btn { font-size: 12px; padding: 8px 12px; }

  /* Ofensiva modal */
  .ofensiva-card { padding: 20px 16px !important; max-width: calc(100vw - 24px); }
  .ofm-tabs { gap: 4px; }
  .ofm-tab { font-size: 12px; padding: 7px 12px; }
  .ofm-fire-hero { padding: 12px 0; }
  .ofm-fire-emoji svg { width: 50px; height: 65px; }
  .ofm-streak-num { font-size: 36px; }
  .ofm-day-dot { width: 28px; height: 28px; font-size: 10px; }

  /* Task modal */
  .task-modal-card { padding: 20px 16px !important; max-width: calc(100vw - 24px); }
  .tm-title { font-size: 16px; }
  .tm-desc { font-size: 12px; }

  /* Chest modal */
  .chest-modal-card { padding: 20px 16px !important; max-width: calc(100vw - 24px); }

  /* Streak onboarding */
  .streak-ob-card { padding: 20px 16px !important; max-width: calc(100vw - 24px); }
  .sob-headline { font-size: 20px; }
  .sob-goals { gap: 8px; }
  .sob-goal { padding: 10px 12px; }

  /* Shop modal */
  .shop-card { padding: 20px 16px !important; max-width: calc(100vw - 24px); }
  .shop-title { font-size: 18px; }
  .shop-item { padding: 10px 12px; gap: 10px; }
  .shop-item-icon { width: 34px; height: 34px; font-size: 18px; }
  .shop-item-name { font-size: 13px; }
  .shop-item-desc { font-size: 10.5px; }
  .shop-buy-btn { padding: 5px 10px; font-size: 12px; }

  /* Planner add modal */
  .pa-card { padding: 18px 14px !important; }

  /* Friend profile modal */
  .fpro-card { padding: 20px 16px !important; max-width: calc(100vw - 24px); }
  .fpro-stats-grid { grid-template-columns: 1fr 1fr !important; gap: 6px !important; }

  /* Settings modal */
  .settings-modal { max-height: 90vh !important; position: relative; overflow-y: auto !important; }
  .settings-close-btn { display: none !important; }
  .settings-nav { gap: 4px !important; padding: 10px 8px !important; flex-wrap: nowrap !important; overflow-x: auto !important; -webkit-overflow-scrolling: touch; scrollbar-width: none; position: relative; }
  .settings-nav::-webkit-scrollbar { display: none; }
  .settings-nav::after { content: ''; position: sticky; right: 0; flex-shrink: 0; width: 28px; min-height: 36px; background: linear-gradient(to right, transparent, var(--bg-surface) 70%); pointer-events: none; }
  .settings-nav-title { display: none !important; }
  .settings-nav-spacer { display: none !important; }
  .settings-nav-close { display: none !important; }
  .settings-nav-item { font-size: 12px; padding: 8px 12px; white-space: nowrap; flex-shrink: 0; min-height: 36px; display: flex; align-items: center; }
  .settings-content { padding: 16px !important; }

  /* Trend cards */
  .tr-card { padding: 14px !important; }
  .tr-topic { font-size: 15px; }
  .tr-desc { font-size: 11.5px; }

  /* Home hero: tighter */
  .cmd-hero { padding: var(--s2) 0 var(--s1); gap: var(--s3); }
  .dial-wrap { width: 160px; height: 160px; }
  .dial-num { font-size: 38px; }
  .dial-desc { display: none; }
  .dial-social-proof { display: none; }
  .dial-status { display: none; }

  /* Activity ticker */
  .activity-ticker { font-size: 10px; padding: 6px 0; }
  .ticker-track span { font-size: 10px; }

  /* Page headers */
  .page-eyebrow, .page-label { font-size: 12px; }
  .page-sub { font-size: 12px; }

  /* Toast on mobile */
  .gc-toast { right: 8px; left: 8px; bottom: 16px; max-width: none; }

  /* Zone separators */
  .rz-separator { font-size: 10px; padding: 4px 10px; }

  /* Ranking urgency card */
  .ranking-urgency { padding: 14px !important; font-size: 13px; }
  .rp-motivation { padding: 14px !important; font-size: 13px; }

  /* Templates grid */
  .saved-grid { grid-template-columns: 1fr !important; }

  /* XP pill mobile: compact, same height as other topbar items */
  .xp-pill { min-width: unset; padding: 3px 6px 3px 4px; gap: 3px; height: 34px; }
  .xp-level-badge { font-size: 9px; padding: 2px 5px; }
  .xp-label { display: none; }
  .xp-bar-wrap { min-width: 20px; width: 20px; }

  /* Daily bonus mobile */
  .db-card { padding: 24px 16px !important; max-width: calc(100vw - 24px); }
  .db-mystery-card { width: 85px; height: 110px; }
  .db-cards { gap: 10px; }
  .db-title { font-size: 18px; }

  /* Achievements mobile */
  .ach-card { padding: 20px 14px !important; max-width: calc(100vw - 24px); }
  .ach-grid { grid-template-columns: 1fr !important; }
  .ach-item { padding: 10px 10px; gap: 8px; }
  .ach-item-icon { width: 34px; height: 34px; font-size: 17px; }

  /* Social pulse mobile */
  .social-pulse { max-width: calc(100vw - 32px); left: 8px; bottom: 16px; }

  /* Ghost competitor: hide label on small screens, keep dot only */
  .ghost-label { display: none; }
  .ghost-dot { width: 8px; height: 8px; }

  /* Combo badge: compact */
  .combo-badge { padding: 6px 10px; gap: 6px; }
  .combo-val { font-size: 16px; }
  .combo-label { font-size: 8px; }
  .combo-timer-ring svg { width: 26px; height: 26px; }

  /* Multiplier spinner compact */
  .mult-reel-wrap { width: 66px; height: 40px; }
  .mult-slot { height: 40px; font-size: 20px; }

  /* Reduce metric deltas for cleaner look */
  .metric-delta-lbl { font-size: 9px; }

  /* Intel cards: less text */
  .intel-body { font-size: 12px; line-height: 1.4; }
  .intel-card { padding: var(--s3) !important; }

  /* Daily tasks: tighter */
  .daily-tasks-header { margin-bottom: 8px; }
  .task-item { padding: 8px 0; }

  /* Week plan: tighter */
  .wk-header { margin-bottom: 8px; }

}

/* ── Mobile search button ────────────────────────────────── */
.mobile-search-btn { display: none; }
@media (max-width: 768px) { .mobile-search-btn { display: flex; } }

/* ── COMMAND PALETTE ──────────────────────────────────────── */
.cmd-palette-overlay {
  display: none;
  position: fixed;
  inset: 0;
  z-index: 500;
  background: rgba(0,0,0,.5);
  backdrop-filter: blur(4px);
  justify-content: center;
  padding-top: min(20vh, 160px);
}
.cmd-palette-overlay.open { display: flex; }
.cmd-palette {
  width: 90%;
  max-width: 520px;
  max-height: 420px;
  background: var(--bg-base, #07080E);
  border: 1px solid var(--border-sm);
  border-radius: var(--r-lg);
  box-shadow: 0 24px 80px rgba(0,0,0,.5);
  overflow: hidden;
  display: flex;
  flex-direction: column;
  animation: cmdIn .15s ease;
}
@keyframes cmdIn { from { opacity: 0; transform: scale(.97) translateY(-8px); } }
.cmd-palette-input-wrap {
  display: flex;
  align-items: center;
  gap: var(--s3);
  padding: var(--s4) var(--s5);
  border-bottom: 1px solid var(--border-sm);
  color: var(--text-3);
}
.cmd-palette-input {
  flex: 1;
  background: transparent;
  border: none;
  outline: none;
  font-size: 15px;
  color: var(--text-1);
  font-family: var(--font-body);
}
.cmd-palette-input::placeholder { color: var(--text-3); }
.cmd-palette-kbd {
  font-size: 10px;
  color: var(--text-3);
  background: var(--bg-surface);
  border: 1px solid var(--border-sm);
  border-radius: 4px;
  padding: 2px 6px;
  letter-spacing: 0;
}
.cmd-palette-results {
  overflow-y: auto;
  padding: var(--s2);
}
.cmd-result {
  display: flex;
  align-items: center;
  gap: var(--s3);
  padding: var(--s3) var(--s4);
  border-radius: var(--r-md);
  cursor: pointer;
  color: var(--text-2);
  font-size: 13px;
  transition: background .12s;
}
.cmd-result:hover, .cmd-result.selected {
  background: var(--bg-hover);
  color: var(--text-1);
}
.cmd-result-icon {
  width: 32px; height: 32px;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: var(--r-sm);
  background: var(--bg-surface);
  color: var(--text-3);
  flex-shrink: 0;
}
.cmd-result.selected .cmd-result-icon { background: var(--primary-dim); color: var(--primary); }
.cmd-result-text { display: flex; flex-direction: column; gap: 1px; }
.cmd-result-label { font-weight: 500; color: inherit; }
.cmd-result-hint { font-size: 11px; color: var(--text-3); }
.cmd-results-group {
  padding: var(--s2) var(--s4) var(--s1);
  font-size: 10px;
  font-weight: 600;
  letter-spacing: 0;
  text-transform: none;
  color: var(--text-3);
}
[data-theme="light"] .cmd-palette {
  background: #FFFFFF;
  box-shadow: 0 24px 80px rgba(0,0,0,.15);
}

/* ── PULL TO REFRESH ─────────────────────────────────────── */
.pull-indicator {
  display: flex;
  align-items: center;
  justify-content: center;
  height: 0;
  overflow: hidden;
  transition: height .2s cubic-bezier(0.32, 0.72, 0, 1);
}
.pull-spinner {
  width: 28px; height: 28px;
  border: 2.5px solid var(--border-sm);
  border-top-color: var(--primary);
  border-radius: 50%;
  transition: transform .1s linear;
}
.pull-indicator.refreshing .pull-spinner {
  animation: btnSpin 600ms linear infinite;
}

/* ── TAP FEEDBACK (mobile press effect) ──────────────────── */
@media (pointer: coarse) {
  .card:active, .metric-item:active, .daily-tasks:active,
  .intel-card:active, .wk-day:active,
  .type-card:active, .template-card:active, .trend-item:active,
  .task-item:active, .insight-item:active,
  .planner-day:active, .milestone-next-card:active {
    transform: scale(.97);
    transition: transform 80ms cubic-bezier(0.32, 0.72, 0, 1);
  }
  .bnav-item:active { transform: scale(0.96); }
  .btn:active, .btn-primary:active, .btn-cta:active {
    transform: scale(.95);
    transition: transform 60ms cubic-bezier(0.32, 0.72, 0, 1);
  }
}

/* ── PAGE TRANSITIONS — Apple spring slide ───────────────── */
.page {
  --page-dir: 1;
}
.page.slide-out-left {
  animation: pageOutLeft 220ms cubic-bezier(0.32, 0.72, 0, 1) forwards;
}
.page.slide-out-right {
  animation: pageOutRight 220ms cubic-bezier(0.32, 0.72, 0, 1) forwards;
}
.page.slide-in {
  animation: pageSlideIn 380ms cubic-bezier(0.32, 0.72, 0, 1) forwards;
}
@keyframes pageOutLeft {
  to { opacity: 0; transform: translateX(calc(-24px * var(--page-dir))) scale(0.98); }
}
@keyframes pageOutRight {
  to { opacity: 0; transform: translateX(calc(24px * var(--page-dir))) scale(0.98); }
}
@keyframes pageSlideIn {
  from { opacity: 0; transform: translateX(calc(20px * var(--page-dir))) scale(0.99); }
  to   { opacity: 1; transform: translateX(0) scale(1); }
}

/* ── AUTH OVERLAY ────────────────────────────────────────── */
.auth-overlay {
  position: fixed; inset: 0; z-index: 10000;
  background: var(--bg-base);
  display: flex; align-items: center; justify-content: center;
  transition: opacity .3s cubic-bezier(0.32, 0.72, 0, 1);
}
.auth-overlay.hidden { display: none; }

.auth-card {
  width: 100%; max-width: 400px;
  padding: 40px 32px;
  background: var(--bg-elevated);
  border: 1px solid var(--border-sm);
  border-radius: 20px;
  margin: 16px;
}
.auth-logo {
  display: flex; align-items: center; gap: 10px;
  justify-content: center; margin-bottom: 28px;
}
.auth-logo-text {
  font-size: 20px; font-weight: 700; color: var(--text-1);
  letter-spacing: -.3px;
}
.auth-title {
  font-size: 22px; font-weight: 700; color: var(--text-1);
  text-align: center; margin: 0 0 6px;
}
.auth-subtitle {
  font-size: 13px; color: var(--text-3); text-align: center;
  margin: 0 0 24px; line-height: 1.5;
}
.auth-field { margin-bottom: 16px; }
.auth-field label {
  display: block; font-size: 12px; font-weight: 600;
  color: var(--text-2); margin-bottom: 6px; text-transform: none;
  letter-spacing: 0;
}
.auth-field input {
  width: 100%; padding: 12px 14px;
  background: var(--bg-surface); border: 1px solid var(--border-sm);
  border-radius: 10px; color: var(--text-1); font-size: 14px;
  font-family: inherit; outline: none; transition: border-color .2s;
  box-sizing: border-box;
}
.auth-field input:focus {
  border-color: var(--primary);
  box-shadow: 0 0 0 3px var(--primary-dim);
}
.auth-field input::placeholder { color: var(--text-3); }

.auth-error {
  font-size: 13px; color: #F87171; text-align: center;
  margin-bottom: 12px; padding: 8px 12px;
  background: rgba(248,113,113,.08); border-radius: 8px;
}
.auth-btn {
  width: 100%; padding: 13px; margin-top: 4px;
  background: var(--primary); color: #fff; border: none;
  border-radius: 10px; font-size: 14px; font-weight: 600;
  font-family: inherit; cursor: pointer;
  transition: opacity .2s, transform .1s;
}
.auth-btn:hover { opacity: .9; }
.auth-btn:active { transform: scale(.98); }
.auth-btn:disabled { opacity: .5; cursor: not-allowed; }

.auth-footer {
  display: flex; align-items: center; justify-content: center;
  gap: 6px; margin-top: 20px; font-size: 13px; color: var(--text-3);
}
.auth-link {
  background: none; border: none; color: var(--primary);
  font-size: 13px; font-family: inherit; cursor: pointer;
  padding: 0; font-weight: 600;
}
.auth-link:hover { text-decoration: underline; }
.auth-forgot {
  display: block; margin: 10px auto 0; text-align: center;
  font-size: 12px; color: var(--text-3); font-weight: 400;
}
.auth-forgot:hover { color: var(--primary); }

.auth-divider {
  display: flex; align-items: center; gap: 12px;
  margin: 20px 0 16px; color: var(--text-3); font-size: 12px;
}
.auth-divider::before, .auth-divider::after {
  content: ''; flex: 1; height: 1px; background: var(--border-sm);
}
.auth-skip {
  width: 100%; padding: 11px; background: transparent;
  border: 1px solid var(--border-md); color: var(--text-2);
  border-radius: 10px; font-size: 13px; font-family: inherit;
  cursor: pointer; transition: all .2s;
}
.auth-skip:hover {
  border-color: var(--primary-border); color: var(--text-1);
  background: var(--primary-dim);
}

/* Auth loading state */
.auth-btn .auth-spinner {
  display: inline-block; width: 14px; height: 14px;
  border: 2px solid rgba(255,255,255,.3);
  border-top-color: #fff; border-radius: 50%;
  animation: btnSpin .6s linear infinite;
  vertical-align: middle; margin-right: 6px;
}

/* Light theme auth */
[data-theme="light"] .auth-overlay { background: #f8fafc; }
[data-theme="light"] .auth-card { background: #fff; border-color: #e2e8f0; }
[data-theme="light"] .auth-field input { background: #f1f5f9; border-color: #e2e8f0; }

/* ── BOTTOM NAV — Apple Tab Bar ──────────────────────────── */
.bottom-nav {
  display: none;
  position: fixed;
  bottom: 0; left: 0; right: 0;
  z-index: 200;
  height: 49px;
  padding-bottom: env(safe-area-inset-bottom, 0px);
  background: rgba(29,29,29,.94);
  backdrop-filter: blur(20px) saturate(180%);
  -webkit-backdrop-filter: blur(20px) saturate(180%);
  border-top: 0.5px solid rgba(84,84,88,.4);
  justify-content: space-around;
  align-items: center;
}
.bnav-item {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 1px;
  padding: 4px 0 2px;
  min-width: 56px;
  min-height: 44px;
  justify-content: center;
  color: #8E8E93;
  text-decoration: none;
  font-size: 10px;
  font-weight: 500;
  letter-spacing: 0.01em;
  transition: color 200ms cubic-bezier(0.32, 0.72, 0, 1);
  -webkit-tap-highlight-color: transparent;
  position: relative;
}
.bnav-item svg {
  transition: transform 350ms cubic-bezier(0.32, 0.72, 0, 1),
              color 200ms cubic-bezier(0.32, 0.72, 0, 1);
}
/* Apple tab bar: outline icons for inactive, filled for active */
.bnav-item .bnav-ico-filled { display: none; }
.bnav-item .bnav-ico-outline { display: block; }
.bnav-item.active .bnav-ico-filled { display: block; }
.bnav-item.active .bnav-ico-outline { display: none; }
.bnav-item:active { transform: scale(0.96); transition: transform 80ms cubic-bezier(0.32, 0.72, 0, 1); }
.bnav-item.active { color: var(--primary); }
.bnav-item.active svg { transform: scale(1.08); }
/* No dot indicator — Apple uses color only */
[data-theme="light"] .bottom-nav {
  background: rgba(249,249,249,.94);
  border-top-color: rgba(60,60,67,.29);
}
[data-theme="light"] .bnav-item { color: #8E8E93; }
[data-theme="light"] .bnav-item.active { color: var(--primary); }

@media (max-width: 768px) {
  .bottom-nav { display: flex; }
  .page { padding-bottom: calc(49px + env(safe-area-inset-bottom, 16px) + 24px) !important; }
}

/* Very small screens (320px) */
@media (max-width: 360px) {
  .topbar { padding: 0 var(--s2); }
  .btn-create-quick { width: 32px; height: 32px; min-width: 32px; }
  .gems-pill { padding: 3px 6px; height: 30px; }
  #gemsCount { font-size: 11px; }
  .avatar { width: 30px; height: 30px; font-size: 10px; }
  .topbar-icon-btn { width: 30px; height: 30px; }
  .mobile-menu-btn { width: 30px; height: 30px; }
  .mobile-menu-btn svg { width: 13px; height: 13px; }
  .theme-toggle-btn { width: 30px; height: 30px; }
  .planner-grid { grid-template-columns: 1fr !important; }
  .wk-strip { grid-template-columns: repeat(5, 1fr); gap: 3px; }
  .wk-day-type { font-size: 8px; }
  .metrics-strip { grid-template-columns: 1fr 1fr; }
  .metric-val { font-size: 22px; }
  .cmd-headline { font-size: 24px; }
  .page-title { font-size: 24px !important; }
}

/* ═══════════════════════════════════════════════════════════
   FEATURE 1: RANKING — Mode Toggle + Benchmarks + Personal Evolution
   ═══════════════════════════════════════════════════════════ */

/* Mode toggle buttons */
.rp-mode-toggle {
  display: flex;
  gap: var(--s2);
  margin-bottom: var(--s4);
  padding: 3px;
  background: var(--bg-surface);
  border-radius: var(--r-lg);
  border: 1px solid var(--border-sm);
}
.rp-mode-btn {
  flex: 1;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 6px;
  padding: 10px 16px;
  font-size: 13px;
  font-weight: 600;
  color: var(--text-2);
  background: transparent;
  border: none;
  border-radius: var(--r-md);
  cursor: pointer;
  transition: all var(--ease-fast);
}
.rp-mode-btn:hover { color: var(--text-1); background: var(--bg-hover); }
.rp-mode-btn.active {
  background: var(--primary-dim);
  color: var(--primary);
  border: 1px solid var(--primary-border);
}

/* Benchmark badge */
.ranking-ref-badge {
  font-size: 9px;
  font-weight: 600;
  padding: 1px 5px;
  border-radius: 4px;
  background: rgba(148,163,184,.12);
  color: var(--text-3);
  margin-left: 4px;
  letter-spacing: 0.02em;
}
.ranking-row-benchmark {
  opacity: 0.65;
}
.ranking-row-benchmark:hover { opacity: 0.85; }

/* Personal Evolution grid */
.pe-evolution-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(220px, 1fr));
  gap: var(--s3);
  margin-top: var(--s3);
}
.pe-evo-card {
  background: var(--bg-surface);
  border: 1px solid var(--border-sm);
  border-radius: var(--r-md);
  padding: var(--s5);
  text-align: center;
  transition: border-color var(--ease-fast);
}
.pe-evo-card:hover { border-color: var(--border-md); }
.pe-evo-highlight {
  border-color: var(--primary-border);
  background: var(--primary-dim);
}
.pe-evo-icon {
  font-size: 20px;
  margin-bottom: var(--s2);
}
.pe-evo-value {
  font-size: 22px;
  font-weight: 700;
  color: var(--text-1);
  margin-bottom: var(--s1);
  font-family: var(--font-display);
}
.pe-evo-label {
  font-size: 12px;
  font-weight: 600;
  color: var(--text-2);
  margin-bottom: var(--s1);
}
.pe-evo-sub {
  font-size: 11px;
  color: var(--text-3);
  line-height: 1.4;
}

/* ═══════════════════════════════════════════════════════════
   FEATURE 2 & 3: GROWTH — Metrics IG Panel
   ═══════════════════════════════════════════════════════════ */

.gw-feedback-section {
  margin-top: var(--s4);
}

/* ═══════════════════════════════════════════════════════════
   FEATURE 4: LIFECYCLE STATUS ON PLANNER ENTRIES
   ═══════════════════════════════════════════════════════════ */

.planner-entry-item-wrap {
  display: flex;
  flex-direction: column;
  gap: 3px;
  width: 100%;
}
.pe-status-row {
  display: flex;
  align-items: center;
  gap: 5px;
  padding: 0 2px;
}
.pe-status-dot {
  width: 6px;
  height: 6px;
  border-radius: 50%;
  flex-shrink: 0;
}
.pe-status-label {
  font-size: 9px;
  font-weight: 600;
  letter-spacing: 0;
}
.pe-lifecycle-btn {
  margin-left: auto;
  font-size: 9px;
  font-weight: 600;
  padding: 2px 6px;
  border-radius: 4px;
  border: 1px solid var(--primary-border);
  background: var(--primary-dim);
  color: var(--primary);
  cursor: pointer;
  transition: all var(--ease-fast);
  white-space: nowrap;
}
.pe-lifecycle-btn:hover {
  background: var(--primary);
  color: #fff;
}
.pe-lifecycle-btn.pe-lifecycle-analyze {
  border-color: var(--cta-border);
  background: var(--cta-dim);
  color: var(--cta);
}
.pe-lifecycle-btn.pe-lifecycle-analyze:hover {
  background: var(--cta);
  color: #fff;
}

/* ═══════════════════════════════════════════════════════════
   FEATURE 5: FEEDBACK LOOP — Type comparison grid
   ═══════════════════════════════════════════════════════════ */

.pe-feedback-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(160px, 1fr));
  gap: var(--s3);
  margin-top: var(--s3);
}
.pe-feedback-type-card {
  background: var(--bg-elevated);
  border: 1px solid var(--border-sm);
  border-radius: var(--r-sm);
  padding: var(--s3);
  transition: border-color var(--ease-fast);
}
.pe-feedback-type-card:hover { border-color: var(--border-md); }
.pe-feedback-best {
  border-color: var(--secondary-border);
  background: var(--secondary-dim);
}
.pe-feedback-type-name {
  font-size: 13px;
  font-weight: 700;
  color: var(--text-1);
  margin-bottom: var(--s2);
}
.pe-feedback-stat {
  font-size: 11px;
  color: var(--text-2);
  margin-bottom: 2px;
  line-height: 1.5;
}
.pe-feedback-stat strong { color: var(--text-1); }
.pe-feedback-stat-count {
  font-size: 10px;
  color: var(--text-3);
  margin-top: var(--s1);
  font-family: var(--font-mono);
}

/* ═══════════════════════════════════════════════════════════
   HOME CONTENT INSIGHT WIDGET (Feature 5)
   ═══════════════════════════════════════════════════════════ */

.home-insight-card {
  display: flex;
  align-items: center;
  gap: var(--s3);
  padding: var(--s4);
  background: var(--bg-surface);
  border: 1px solid var(--secondary-border);
  border-radius: var(--r-md);
  margin-bottom: var(--s4);
  transition: border-color var(--ease-fast);
}
.home-insight-card:hover { border-color: var(--secondary); }
.home-insight-icon {
  font-size: 18px;
  color: var(--secondary);
  flex-shrink: 0;
}
.home-insight-text { flex: 1; min-width: 0; }
.home-insight-title {
  font-size: 11px;
  font-weight: 600;
  color: var(--text-2);
  text-transform: none;
  letter-spacing: 0;
  margin-bottom: 2px;
}
.home-insight-value {
  font-size: 13px;
  color: var(--text-1);
  line-height: 1.4;
}
.home-insight-btn {
  padding: 6px 14px;
  font-size: 11px;
  font-weight: 600;
  border: 1px solid var(--secondary-border);
  background: var(--secondary-dim);
  color: var(--secondary);
  border-radius: var(--r-sm);
  cursor: pointer;
  white-space: nowrap;
  transition: all var(--ease-fast);
}
.home-insight-btn:hover {
  background: var(--secondary);
  color: #fff;
}

/* Responsive: personal evolution grid */
@media (max-width: 600px) {
  .pe-evolution-grid { grid-template-columns: 1fr 1fr; }
  .pe-feedback-grid { grid-template-columns: 1fr 1fr; }
  .rp-mode-toggle { flex-direction: row; }
  .rp-mode-btn { font-size: 12px; padding: 8px 10px; }
  .home-insight-card { flex-direction: column; text-align: center; }
}


/* ═══════════════════════════════════════════════════════════
   FEATURE 1: MINI CRM — Pipeline de Vendas
   ═══════════════════════════════════════════════════════════ */

/* Instagram home widget */
.ig-connect-banner {
  background: var(--bg-surface);
  border: 1px solid var(--border-sm);
  border-radius: var(--r-lg);
  padding: var(--s4) var(--s5);
  margin-bottom: var(--s4);
}
[data-theme="light"] .ig-connect-banner {
  background: #fff;
  box-shadow: 0 1px 3px rgba(0,0,0,.06);
  border-color: rgba(0,0,0,.06);
}
.ig-home-widget {
  background: var(--bg-surface);
  border: 1px solid var(--border-sm);
  border-radius: var(--r-lg);
  padding: var(--s4);
  margin-bottom: var(--s4);
  /* Apple: no accent border */
}

/* Trends home widget */
.trends-home-widget {
  background: var(--bg-surface);
  border: 1px solid var(--border-sm);
  border-radius: var(--r-lg);
  padding: var(--s4);
  margin-bottom: var(--s4);
  /* Apple: no accent border */
}
.trends-home-widget .trends-home-list > div:hover {
  background: var(--bg-elevated);
  border-radius: var(--r-sm);
}

/* Onboarding overlay */
.onboarding-overlay {
  position: fixed; inset: 0; z-index: 9999;
  background: rgba(0,0,0,.7); backdrop-filter: blur(8px);
  display: flex; align-items: center; justify-content: center;
  padding: 20px;
}
.onboarding-card {
  background: #fff;
  color: #1e293b;
  border: 1px solid #e2e8f0;
  border-radius: var(--r-lg);
  padding: 32px 24px;
  max-width: 380px; width: 100%;
  text-align: center;
  animation: onboardIn .4s cubic-bezier(.34,1.56,.64,1) forwards;
  opacity: 1; /* fallback for reduced-motion */
}
.onboarding-card label,
.onboarding-card input,
.onboarding-card select { color: #334155; }
.onboarding-card input,
.onboarding-card select { background: #f8fafc; border-color: #cbd5e1; }
@keyframes onboardIn {
  from { opacity: 0; transform: scale(.9) translateY(20px); }
  to { opacity: 1; transform: none; }
}
.onboarding-title {
  font-size: 18px; font-weight: 700; color: #0f172a;
  margin-bottom: 8px;
}
.onboarding-desc {
  font-size: 13px; color: #64748b; line-height: 1.5;
  margin-bottom: 16px;
}

/* Content funnel widget */
.funnel-home-widget {
  background: var(--bg-surface);
  border: 1px solid var(--border-sm);
  border-radius: var(--r-md);
  padding: var(--s4);
  margin-bottom: var(--s4);
}
.funnel-bar-row {
  display: flex; align-items: center; gap: 8px; margin-top: 6px;
}
.funnel-bar-label {
  font-size: 10px; color: var(--text-3); min-width: 55px; text-align: right;
}
.funnel-bar-track {
  flex: 1; height: 14px; background: var(--bg-elevated);
  border-radius: 7px; overflow: hidden; position: relative;
}
.funnel-bar-fill {
  height: 100%; border-radius: 7px; transition: width .4s ease;
  min-width: 2px; background: var(--text-3);
}
.funnel-bar-val {
  font-size: 10px; font-weight: 600; color: var(--text-2); min-width: 28px;
}

/* Planner AI suggest button */
.planner-ai-suggest {
  background: rgba(139,92,246,.08) !important;
}

/* Pipeline widget on home */
.pipeline-widget {
  background: var(--bg-surface);
  border: 1px solid var(--border-sm);
  border-radius: var(--r-lg);
  padding: var(--s4);
  margin-bottom: var(--s4);
}
.pw-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: var(--s3);
}
.pw-title-row {
  display: flex;
  align-items: center;
  gap: var(--s2);
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0;
  color: var(--text-2);
  text-transform: none;
}
.pw-title-row svg { color: #30D158; }
.pw-stats {
  display: flex;
  gap: var(--s3);
  flex-wrap: wrap;
}
.pw-stat {
  display: flex;
  align-items: center;
  gap: 6px;
  font-size: 12px;
  color: var(--text-2);
}
.pw-stat-dot {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  flex-shrink: 0;
}
.pw-stat-val {
  font-weight: 600;
  color: var(--text-1);
}

/* Kanban board in modal */
.pipeline-kanban {
  display: flex;
  gap: 2px;
  padding: var(--s3);
  overflow-x: auto;
  min-height: 300px;
}
.pk-column {
  flex: 1;
  min-width: 150px;
  background: var(--bg-surface);
  border-radius: var(--r-sm);
  padding: var(--s2);
  display: flex;
  flex-direction: column;
}
.pk-col-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: var(--s2);
  margin-bottom: var(--s2);
  border-bottom: 2px solid var(--border-sm);
}
.pk-col-title {
  font-size: 11px;
  font-weight: 700;
  text-transform: none;
  letter-spacing: 0;
  display: flex;
  align-items: center;
  gap: 6px;
}
.pk-col-count {
  font-size: 10px;
  background: var(--bg-elevated);
  padding: 2px 6px;
  border-radius: var(--r-full);
  color: var(--text-2);
  font-weight: 600;
}
.pk-col-body {
  flex: 1;
  display: flex;
  flex-direction: column;
  gap: var(--s2);
  min-height: 60px;
}

/* Lead card in kanban */
.pk-lead-card {
  background: var(--bg-elevated);
  border: 1px solid var(--border-xs);
  border-radius: var(--r-sm);
  padding: var(--s3);
  cursor: pointer;
  transition: all var(--ease-fast);
}
.pk-lead-card:hover {
  border-color: var(--border-md);
  transform: translateY(-1px);
}
.pk-lead-name {
  font-size: 13px;
  font-weight: 600;
  color: var(--text-1);
  margin-bottom: 4px;
}
.pk-lead-source {
  font-size: 10px;
  color: var(--text-2);
  display: flex;
  align-items: center;
  gap: 4px;
}
.pk-lead-meta {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-top: 6px;
}
.pk-lead-days {
  font-size: 10px;
  color: var(--text-3);
  font-family: var(--font-mono);
}
.pk-lead-value {
  font-size: 10px;
  font-weight: 600;
  color: #30D158;
}
.pk-lead-note {
  font-size: 10.5px;
  color: var(--text-3);
  margin-top: 4px;
  line-height: 1.4;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.pk-lead-actions {
  display: flex;
  gap: 4px;
  margin-top: 6px;
}
.pk-lead-status-btn {
  font-size: 9px;
  padding: 2px 6px;
  border-radius: var(--r-full);
  background: var(--bg-hover);
  border: 1px solid var(--border-xs);
  color: var(--text-2);
  cursor: pointer;
  transition: all var(--ease-fast);
}
.pk-lead-status-btn:hover {
  background: var(--primary-dim);
  color: var(--primary);
  border-color: var(--primary-border);
}

/* Lead status colors */
.lead-status-novo       { color: var(--text-2); }
.lead-status-respondido { color: #6366F1; }
.lead-status-interessado { color: #FF9F0A; }
.lead-status-agendado   { color: #3B82F6; }
.lead-status-fechado    { color: #30D158; }
.lead-status-perdido    { color: #FF453A; }

.lead-dot-novo       { background: var(--text-2); }
.lead-dot-respondido { background: #6366F1; }
.lead-dot-interessado { background: #FF9F0A; }
.lead-dot-agendado   { background: #3B82F6; }
.lead-dot-fechado    { background: #30D158; }
.lead-dot-perdido    { background: #FF453A; }

/* Lead detail modal */
.ld-history {
  list-style: none;
  padding: 0;
  margin: var(--s3) 0 0;
}
.ld-history-item {
  display: flex;
  gap: var(--s3);
  padding: var(--s2) 0;
  border-bottom: 1px solid var(--border-xs);
  font-size: 12px;
}
.ld-history-date {
  color: var(--text-3);
  font-family: var(--font-mono);
  font-size: 10px;
  min-width: 70px;
}
.ld-history-action {
  color: var(--text-2);
  font-weight: 500;
}
.ld-history-note {
  color: var(--text-3);
}
.ld-status-select {
  background: var(--bg-elevated);
  border: 1px solid var(--border-sm);
  border-radius: var(--r-sm);
  color: var(--text-1);
  padding: 6px 10px;
  font-size: 12px;
  font-family: var(--font-body);
  cursor: pointer;
  width: 100%;
}
.ld-add-note-row {
  display: flex;
  gap: var(--s2);
  margin-top: var(--s3);
}
.ld-add-note-row input {
  flex: 1;
}

@media (max-width: 700px) {
  .pipeline-kanban {
    flex-direction: column;
  }
  .pk-column {
    min-width: unset;
  }
}


/* ═══════════════════════════════════════════════════════════
   FEATURE 2: QUICK ACTIONS
   ═══════════════════════════════════════════════════════════ */

.quick-action-card {
  position: relative;
  display: flex;
  align-items: center;
  gap: var(--s4);
  background: var(--bg-surface);
  border: 1px solid var(--border-sm);
  border-radius: var(--r-lg);
  padding: var(--s4) var(--s5);
  margin-bottom: var(--s4);
}
[data-theme="light"] .quick-action-card {
  background: #fff;
  box-shadow: 0 1px 3px rgba(0,0,0,.06);
  border-color: rgba(0,0,0,.06);
}
.qa-icon {
  width: 44px;
  height: 44px;
  border-radius: var(--r-md);
  background: var(--primary-dim);
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  font-size: 20px;
}
.qa-body { flex: 1; min-width: 0; }
.qa-label {
  font-size: 11px;
  font-weight: 600;
  letter-spacing: 0;
  color: var(--primary);
  text-transform: none;
  margin-bottom: 2px;
}
.qa-title {
  font-size: 14px;
  font-weight: 600;
  color: var(--text-1);
  line-height: 1.3;
}
.qa-desc {
  font-size: 11px;
  color: var(--text-2);
  margin-top: 2px;
}
.qa-btn {
  padding: 8px 16px;
  border-radius: var(--r-full);
  background: var(--primary);
  color: #fff;
  font-size: 12px;
  font-weight: 600;
  border: none;
  cursor: pointer;
  flex-shrink: 0;
  transition: all var(--ease-fast);
  font-family: var(--font-body);
}
.qa-btn:hover {
  filter: brightness(1.08);
}
.qa-btn:active {
  transform: scale(0.97);
  transition: transform 100ms cubic-bezier(0.32, 0.72, 0, 1);
}
.qa-dismiss {
  position: absolute;
  top: 8px;
  right: 8px;
  background: none;
  border: none;
  color: var(--text-3);
  cursor: pointer;
  font-size: 12px;
  padding: 4px;
  line-height: 1;
}
.qa-dismiss:hover { color: var(--text-2); }

/* Focus strip */
.focus-strip {
  display: flex;
  align-items: center;
  gap: var(--s3);
  background: var(--bg-surface);
  border: 1px solid var(--border-xs);
  border-radius: var(--r-md);
  padding: var(--s3) var(--s4);
  margin-bottom: var(--s4);
  font-size: 12px;
  color: var(--text-2);
  flex-wrap: wrap;
}
.fs-label {
  font-weight: 700;
  color: var(--text-1);
  font-size: 11px;
  text-transform: none;
  letter-spacing: 0;
}
.fs-item {
  display: flex;
  align-items: center;
  gap: 4px;
}
.fs-item.done {
  text-decoration: line-through;
  opacity: 0.5;
}
.fs-check {
  width: 14px;
  height: 14px;
  border-radius: 4px;
  border: 1.5px solid var(--border-md);
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}
.fs-item.done .fs-check {
  background: #30D158;
  border-color: #30D158;
  color: #fff;
}
.fs-progress {
  margin-left: auto;
  font-family: var(--font-mono);
  font-size: 11px;
  font-weight: 600;
  color: var(--primary);
}

@media (max-width: 600px) {
  .quick-action-card {
    flex-direction: column;
    text-align: center;
    gap: var(--s3);
  }
  .qa-btn { width: 100%; }
}


/* ═══════════════════════════════════════════════════════════
   FEATURE 3: CONTENT FUNNEL
   ═══════════════════════════════════════════════════════════ */

.content-funnel-card {
  background: var(--bg-surface);
  border: 1px solid var(--border-sm);
  border-radius: var(--r-md);
  padding: var(--s6);
  margin-bottom: var(--s5);
  backdrop-filter: blur(16px);
  -webkit-backdrop-filter: blur(16px);
}
.cf-header {
  margin-bottom: var(--s5);
}
.cf-title {
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0;
  color: var(--text-2);
  text-transform: none;
  margin-bottom: 4px;
}
.cf-subtitle {
  font-size: 12px;
  color: var(--text-3);
}
.cf-funnel {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 0px;
}

/* ── Individual funnel step ── */
.cf-step {
  display: flex;
  align-items: center;
  gap: var(--s4);
  padding: 14px 20px;
  border-radius: var(--r-sm);
  position: relative;
  transition: transform 220ms cubic-bezier(0.32, 0.72, 0, 1), box-shadow 220ms cubic-bezier(0.32, 0.72, 0, 1), background 220ms cubic-bezier(0.32, 0.72, 0, 1);
  width: 100%;
  border: 1px solid transparent;
  cursor: default;
  border-radius: var(--r-md);
}
.cf-step:not(:last-child)::after {
  content: '';
  position: absolute;
  right: -12px;
  top: 50%;
  transform: translateY(-50%);
  width: 0;
  height: 0;
  border-left: 6px solid var(--border);
  border-top: 5px solid transparent;
  border-bottom: 5px solid transparent;
}
.cf-step:hover {
  transform: scale(1.015);
  box-shadow: 0 4px 24px rgba(0,0,0,.25);
  z-index: 2;
}

/* Left color accent */
.cf-step-accent {
  position: absolute;
  left: 0;
  top: 0;
  bottom: 0;
  width: 4px;
  border-radius: 4px 0 0 4px;
}

/* Step icon */
.cf-step-icon {
  width: 40px;
  height: 40px;
  border-radius: 10px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 18px;
  flex-shrink: 0;
  position: relative;
  z-index: 1;
}
.cf-step-icon svg {
  width: 20px;
  height: 20px;
  stroke-width: 2;
  fill: none;
  stroke: currentColor;
}

/* Text block: label + badge row, then big number */
.cf-step-info {
  flex: 1;
  min-width: 0;
  position: relative;
  z-index: 1;
}
.cf-step-top-row {
  display: flex;
  align-items: center;
  gap: 8px;
  margin-bottom: 2px;
}
.cf-step-label {
  font-size: 12px;
  font-weight: 600;
  color: var(--text-2);
  text-transform: none;
  letter-spacing: 0;
}
.cf-step-badge {
  font-size: 9px;
  font-weight: 700;
  letter-spacing: 0;
  padding: 2px 7px;
  border-radius: 20px;
  text-transform: none;
  white-space: nowrap;
  flex-shrink: 0;
}
.cf-step-badge--auto {
  background: rgba(16,185,129,.15);
  color: #34D399;
}
.cf-step-badge--manual {
  background: rgba(148,163,184,.12);
  color: var(--text-2);
}
.cf-step-value {
  font-size: 26px;
  font-weight: 800;
  font-family: var(--font-mono);
  color: var(--text-1);
  line-height: 1.1;
}

/* CTA link */
.cf-step-cta {
  font-size: 11px;
  color: var(--primary);
  cursor: pointer;
  text-decoration: none;
  font-weight: 600;
  opacity: .8;
  transition: opacity 180ms cubic-bezier(0.32, 0.72, 0, 1);
  white-space: nowrap;
  flex-shrink: 0;
  position: relative;
  z-index: 1;
}
.cf-step-cta:hover {
  opacity: 1;
  text-decoration: underline;
}

/* ── Connector between steps (arrow + conversion rate) ── */
.cf-connector {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 0;
  padding: 2px 0;
  position: relative;
  z-index: 1;
}
.cf-connector-line {
  width: 2px;
  height: 14px;
  background: var(--border-sm);
  border-radius: 2px;
}
.cf-connector-rate {
  font-size: 10px;
  font-weight: 700;
  font-family: var(--font-mono);
  padding: 1px 8px;
  border-radius: 10px;
  background: rgba(255,255,255,.04);
  border: 1px solid var(--border-sm);
  color: var(--text-2);
  line-height: 1.6;
}
.cf-connector-arrow {
  width: 0;
  height: 0;
  border-left: 5px solid transparent;
  border-right: 5px solid transparent;
  border-top: 6px solid var(--border-sm);
}

/* ── Width taper for funnel shape ── */
.cf-step-width-6 { width: 100%; }
.cf-step-width-5 { width: 94%; }
.cf-step-width-4 { width: 88%; }
.cf-step-width-3 { width: 82%; }
.cf-step-width-2 { width: 76%; }
.cf-step-width-1 { width: 70%; }

/* ── Mobile responsive ── */
@media (max-width: 600px) {
  .content-funnel-card { padding: var(--s4); }
  .cf-step {
    padding: 10px 14px;
    gap: var(--s3);
    border-radius: var(--r-sm);
  }
  .cf-step-icon { width: 34px; height: 34px; font-size: 15px; }
  .cf-step-icon svg { width: 16px; height: 16px; }
  .cf-step-value { font-size: 20px; }
  .cf-step-label { font-size: 11px; }
  .cf-step-badge { font-size: 8px; padding: 1px 5px; }
  .cf-step-cta { font-size: 10px; }
  .cf-step-width-6 { width: 100%; }
  .cf-step-width-5 { width: 96%; }
  .cf-step-width-4 { width: 92%; }
  .cf-step-width-3 { width: 88%; }
  .cf-step-width-2 { width: 84%; }
  .cf-step-width-1 { width: 80%; }
}

/* ═══════════════════════════════════════
   SIMPLIFIED HOME — GREETING HEADER
   ═══════════════════════════════════════ */
.home-greeting {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 16px 0 8px;
}
.home-greeting-name {
  font-size: 22px;
  font-weight: 700;
  color: var(--text-1);
  margin: 0;
}
.home-greeting-sub {
  font-size: 13px;
  color: var(--text-2);
  margin-top: 2px;
}
.home-greeting-badges {
  display: flex;
  gap: 8px;
  align-items: center;
}
.home-streak-badge {
  background: rgba(249,115,22,.12);
  color: #F97316;
  padding: 4px 10px;
  border-radius: 20px;
  font-size: 10px;
  font-weight: 600;
}
.home-tier-badge {
  background: rgba(205,127,50,.12);
  color: #CD7F32;
  padding: 3px 10px;
  border-radius: var(--r-full);
  font-size: 10px;
  font-weight: 600;
}

/* Light theme overrides */
[data-theme="light"] .home-greeting-name { color: var(--text-1); }
[data-theme="light"] .home-streak-badge { background: rgba(249,115,22,.1); }
[data-theme="light"] .home-tier-badge { background: rgba(205,127,50,.1); }

/* Mobile: stack greeting vertically */
@media (max-width: 480px) {
  .home-greeting {
    flex-direction: column;
    align-items: flex-start;
    gap: 8px;
  }
  .home-greeting-badges {
    align-self: flex-start;
  }
}

/* Utility: hide removed home sections */
.home-removed { display: none !important; }

/* ═══════════════════════════════════════════════════════════
   WEEKLY SUMMARY WIDGET + MODAL
   ═══════════════════════════════════════════════════════════ */
.weekly-summary-widget {
  background: var(--bg-surface);
  border: 1px solid var(--border-sm);
  border-radius: var(--r-lg);
  padding: var(--s4);
  margin-bottom: var(--s4);
}
.ws-stats-row { display: flex; gap: var(--s3); margin-top: var(--s3); flex-wrap: wrap; }
.ws-stat-card {
  flex: 1; min-width: 90px;
  background: var(--bg-inset);
  border-radius: var(--r-sm);
  padding: var(--s2) var(--s3);
  text-align: center;
}
.ws-stat-value { font-size: 18px; font-weight: 700; font-family: var(--font-mono); }
.ws-stat-label { font-size: 10px; color: var(--text-3); text-transform: none; letter-spacing: 0; margin-top: 2px; }
.ws-trend-up { color: #30D158; }
.ws-trend-down { color: #FF453A; }
.ws-trend-neutral { color: var(--text-3); }
.ws-best-post {
  margin-top: var(--s3);
  padding: var(--s3);
  background: var(--bg-inset);
  border-radius: var(--r-sm);
  border-left: 3px solid #30D158;
}
.ws-worst-post {
  margin-top: var(--s2);
  padding: var(--s3);
  background: var(--bg-inset);
  border-radius: var(--r-sm);
  border-left: 3px solid #FF453A;
}
.ws-post-label { font-size: 10px; font-weight: 700; text-transform: none; letter-spacing: 0; margin-bottom: 4px; }
.ws-post-caption { font-size: 12px; color: var(--text-2); line-height: 1.4; display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden; }
.ws-post-metrics { font-size: 11px; color: var(--text-3); margin-top: 4px; font-family: var(--font-mono); }
.ws-recommendation {
  margin-top: var(--s3);
  padding: var(--s3);
  background: linear-gradient(135deg, rgba(139,92,246,.08), rgba(99,102,241,.08));
  border: 1px solid rgba(139,92,246,.15);
  border-radius: var(--r-sm);
  font-size: 12px;
  color: var(--text-1);
  line-height: 1.5;
}
.ws-recommendation strong { color: var(--primary); }
.weekly-summary-modal .ws-modal-header {
  text-align: center; margin-bottom: var(--s4);
}
.ws-modal-title { font-size: 20px; font-weight: 700; color: var(--text-1); }
.ws-modal-subtitle { font-size: 12px; color: var(--text-3); margin-top: 4px; }
.ws-comparison-row {
  display: grid; grid-template-columns: 1fr 1fr; gap: var(--s3); margin-top: var(--s4);
}
.ws-type-grid { display: flex; gap: var(--s2); margin-top: var(--s3); flex-wrap: wrap; }
.ws-type-badge {
  padding: 4px 10px;
  border-radius: 20px;
  font-size: 11px;
  font-weight: 600;
  background: var(--bg-inset);
  color: var(--text-2);
}
.ws-type-badge.best { background: rgba(16,185,129,.15); color: #30D158; border: 1px solid rgba(16,185,129,.2); }
.ws-connect-cta {
  text-align: center; padding: var(--s6) var(--s4);
}
.ws-connect-cta p { font-size: 13px; color: var(--text-2); margin-bottom: var(--s3); }

/* ═══════════════════════════════════════════════════════════
   ROADMAP — Zero to Hero Journey
   ═══════════════════════════════════════════════════════════ */
.roadmap-overview {
  background: var(--bg-surface);
  border: 1px solid var(--border-sm);
  border-radius: var(--r-md);
  padding: var(--s4);
  margin-bottom: var(--s4);
}
.roadmap-progress-label { display: flex; justify-content: space-between; align-items: center; margin-bottom: var(--s2); }
.roadmap-progress-title { font-size: 13px; font-weight: 600; color: var(--text-1); }
.roadmap-progress-pct { font-size: 13px; font-weight: 700; font-family: var(--font-mono); color: var(--primary); }
.roadmap-progress-bar { height: 8px; background: var(--bg-inset); border-radius: 4px; overflow: hidden; }
.roadmap-progress-fill { height: 100%; border-radius: 4px; background: linear-gradient(90deg, #6366F1, #BF5AF2); transition: width .6s cubic-bezier(.4,0,.2,1); }
.roadmap-week-card {
  background: var(--bg-surface);
  border: 1px solid var(--border-sm);
  border-radius: var(--r-md);
  margin-bottom: var(--s3);
  overflow: hidden;
  transition: border-color .2s;
}
.roadmap-week-card.active { border-color: var(--primary); }
.roadmap-week-card.completed { border-color: #30D158; }
.roadmap-week-header {
  display: flex; align-items: center; gap: var(--s3);
  padding: var(--s4);
  cursor: pointer;
  user-select: none;
}
.roadmap-week-header:hover { background: var(--bg-inset); }
.roadmap-week-num {
  width: 36px; height: 36px;
  border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  font-size: 14px; font-weight: 700;
  color: #fff;
  flex-shrink: 0;
}
.roadmap-week-info { flex: 1; min-width: 0; }
.roadmap-week-title { font-size: 14px; font-weight: 700; color: var(--text-1); }
.roadmap-week-subtitle { font-size: 11px; color: var(--text-3); margin-top: 2px; }
.roadmap-week-badge {
  font-size: 11px; font-weight: 600; font-family: var(--font-mono);
  padding: 2px 8px;
  border-radius: 10px;
  flex-shrink: 0;
}
.roadmap-week-badge.complete { background: rgba(16,185,129,.15); color: #30D158; }
.roadmap-week-badge.in-progress { background: rgba(99,102,241,.15); color: #6366F1; }
.roadmap-week-badge.locked { background: var(--bg-inset); color: var(--text-3); }
.roadmap-week-body {
  padding: 0 var(--s4) var(--s4);
  display: none;
}
.roadmap-week-card.open .roadmap-week-body { display: block; }
.roadmap-step {
  display: flex; align-items: flex-start; gap: var(--s3);
  padding: var(--s2) 0;
  border-bottom: 1px solid var(--border-sm);
}
.roadmap-step:last-child { border-bottom: none; }
.roadmap-step-check {
  width: 22px; height: 22px;
  border-radius: 50%;
  border: 2px solid var(--border-md);
  display: flex; align-items: center; justify-content: center;
  flex-shrink: 0;
  cursor: pointer;
  margin-top: 2px;
  transition: all .2s;
}
.roadmap-step.done .roadmap-step-check {
  background: #30D158; border-color: #30D158; color: #fff;
}
.roadmap-step-content { flex: 1; min-width: 0; }
.roadmap-step-label { font-size: 13px; font-weight: 600; color: var(--text-1); }
.roadmap-step.done .roadmap-step-label { text-decoration: line-through; color: var(--text-3); }
.roadmap-step-desc { font-size: 11px; color: var(--text-3); margin-top: 2px; }
.roadmap-step-action {
  font-size: 11px; font-weight: 600; color: var(--primary);
  cursor: pointer; flex-shrink: 0; margin-top: 2px;
}
.roadmap-step-action:hover { text-decoration: underline; }
.roadmap-celebration {
  text-align: center; padding: var(--s6); margin: var(--s3) 0;
  background: linear-gradient(135deg, rgba(16,185,129,.1), rgba(99,102,241,.1));
  border: 1px solid rgba(16,185,129,.2);
  border-radius: var(--r-md);
}
.roadmap-celebration-emoji { font-size: 32px; margin-bottom: var(--s2); }
.roadmap-celebration-title { font-size: 16px; font-weight: 700; color: var(--text-1); }
.roadmap-celebration-desc { font-size: 12px; color: var(--text-2); margin-top: var(--s1); }

/* Roadmap home widget */
.roadmap-home-widget {
  background: var(--bg-surface);
  border: 1px solid var(--border-sm);
  border-radius: var(--r-md);
  padding: var(--s4);
  margin-bottom: var(--s4);
}
.roadmap-home-steps { margin-top: var(--s2); }
.roadmap-home-step {
  display: flex; align-items: center; gap: var(--s2);
  padding: 4px 0;
  font-size: 12px;
  color: var(--text-2);
}
.roadmap-home-step.done { color: var(--text-3); text-decoration: line-through; }
.roadmap-home-check { font-size: 10px; }

/* Library home widget */
.library-home-widget {
  background: var(--bg-surface);
  border: 1px solid var(--border-sm);
  border-radius: var(--r-lg);
  padding: var(--s4);
  margin-bottom: var(--s4);
}
.library-home-cards { display: flex; flex-direction: column; gap: var(--s2); margin-top: var(--s3); }
.library-home-card {
  display: flex; align-items: center; gap: var(--s3);
  padding: var(--s2) var(--s3);
  background: var(--bg-inset);
  border-radius: var(--r-sm);
  cursor: pointer;
  transition: background .15s;
}
.library-home-card:hover { background: var(--border-sm); }
.library-home-type {
  font-size: 9px; font-weight: 700; text-transform: none;
  padding: 2px 6px; border-radius: 4px; flex-shrink: 0;
}
.library-home-title { font-size: 12px; color: var(--text-1); font-weight: 500; flex: 1; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }

/* Library tab on Create page */
.library-filters { display: flex; flex-wrap: wrap; gap: var(--s2); margin-bottom: var(--s4); }
.library-filter-chip {
  padding: 4px 12px;
  border-radius: 20px;
  font-size: 11px; font-weight: 600;
  background: var(--bg-inset);
  color: var(--text-2);
  cursor: pointer; border: 1px solid transparent;
  transition: all .15s;
}
.library-filter-chip:hover { border-color: var(--border-md); }
.library-filter-chip.active { background: rgba(99,102,241,.15); color: var(--primary); border-color: rgba(99,102,241,.3); }
.library-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(260px, 1fr)); gap: var(--s3); }
.library-card {
  background: var(--bg-surface);
  border: 1px solid var(--border-sm);
  border-radius: var(--r-md);
  padding: var(--s4);
  cursor: pointer;
  transition: border-color .15s, box-shadow .15s;
}
.library-card:hover { border-color: var(--primary); box-shadow: 0 4px 12px rgba(99,102,241,.1); }
.library-card-badges { display: flex; gap: var(--s2); margin-bottom: var(--s2); }
.library-card-badge {
  font-size: 9px; font-weight: 700; text-transform: none;
  padding: 2px 6px; border-radius: 4px;
}
.library-card-badge.reels { background: rgba(239,68,68,.15); color: #FF453A; }
.library-card-badge.carrossel { background: rgba(59,130,246,.15); color: #3B82F6; }
.library-card-badge.stories { background: rgba(245,158,11,.15); color: #FF9F0A; }
.library-card-badge.autoridade { background: rgba(99,102,241,.12); color: #6366F1; }
.library-card-badge.engajamento { background: rgba(245,158,11,.12); color: #FF9F0A; }
.library-card-badge.conexao { background: rgba(236,72,153,.12); color: #EC4899; }
.library-card-badge.conversao { background: rgba(16,185,129,.12); color: #30D158; }
.library-card-badge.prova_social { background: rgba(245,158,11,.12); color: #FF9F0A; }
.library-card-title { font-size: 14px; font-weight: 600; color: var(--text-1); line-height: 1.3; margin-bottom: var(--s2); }
.library-card-hook { font-size: 12px; color: var(--text-2); line-height: 1.4; display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden; }
.library-card-footer { display: flex; justify-content: space-between; align-items: center; margin-top: var(--s3); }
.library-card-diff { font-size: 10px; color: var(--text-3); }
.library-card-use { font-size: 11px; font-weight: 600; color: var(--primary); }

/* ═══════════════════════════════════════════════════════════
   BIO TEMPLATES
   ═══════════════════════════════════════════════════════════ */
.bio-filters { display: flex; flex-wrap: wrap; gap: var(--s2); margin-bottom: var(--s4); }
.bio-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(300px, 1fr)); gap: var(--s3); }
.bio-card {
  background: var(--bg-surface); border: 1px solid var(--border-sm);
  border-radius: var(--r-md); padding: var(--s4);
  transition: border-color .2s, box-shadow .2s;
}
.bio-card:hover { border-color: var(--primary); box-shadow: 0 4px 12px rgba(99,102,241,.1); }
.bio-card-header { display: flex; align-items: center; gap: var(--s2); margin-bottom: var(--s3); }
.bio-card-badge {
  font-size: 10px; font-weight: 600; padding: 2px 8px;
  border-radius: 6px; flex-shrink: 0;
}
.bio-card-title { font-size: 13px; font-weight: 600; color: var(--text-1); }
.bio-card-text {
  font-size: 13px; color: var(--text-2); line-height: 1.6;
  white-space: pre-line; font-family: inherit;
  background: var(--bg-inset); border-radius: var(--r-sm);
  padding: var(--s3); margin: 0 0 var(--s2);
  border: 1px solid var(--border-sm);
}
.bio-card-cta {
  font-size: 11px; color: var(--text-3); margin-bottom: var(--s3);
  font-style: italic;
}
.bio-card-actions {
  display: flex; align-items: center; justify-content: space-between;
}
.bio-char-count {
  font-size: 10px; color: var(--text-3); font-family: var(--font-mono);
}

/* ═══════════════════════════════════════════════════════════
   PRICING CALCULATOR
   ═══════════════════════════════════════════════════════════ */
.pricing-calc-widget {
  background: var(--bg-surface); border: 1px solid var(--border-sm);
  border-radius: var(--r-md); padding: var(--s4); margin-bottom: var(--s4);
}
.pricing-form { display: flex; flex-direction: column; gap: var(--s3); }
.pricing-field { display: flex; flex-direction: column; gap: 4px; }
.pricing-field label { font-size: 12px; font-weight: 600; color: var(--text-2); }
.pricing-result-card {
  background: var(--bg-inset); border-radius: var(--r-md);
  padding: var(--s4); border: 1px solid var(--border-sm);
}
.pricing-range { margin: var(--s3) 0; }
.pricing-range-bar {
  display: flex; height: 24px; border-radius: 12px; overflow: hidden;
  background: var(--bg-elevated);
}
.pricing-range-min { background: rgba(245,158,11,.4); }
.pricing-range-rec { background: rgba(99,102,241,.6); }
.pricing-range-max { background: rgba(16,185,129,.4); }
.pricing-range-labels {
  display: flex; justify-content: space-between; margin-top: var(--s2);
  font-size: 11px; color: var(--text-3); text-align: center;
}
.pricing-range-labels strong { display: block; font-size: 14px; color: var(--text-1); }
.pricing-projections {
  display: flex; gap: var(--s2); flex-wrap: wrap;
}
.pricing-proj-item {
  flex: 1; min-width: 120px; padding: var(--s3);
  background: var(--bg-surface); border-radius: var(--r-sm);
  border: 1px solid var(--border-sm); text-align: center;
}
.pricing-proj-rec {
  border-color: rgba(99,102,241,.4);
  background: rgba(99,102,241,.06);
}
.pricing-proj-label { font-size: 10px; color: var(--text-3); display: block; margin-bottom: 4px; }
.pricing-proj-value { font-size: 14px; font-weight: 700; color: var(--text-1); }
.pricing-proj-rec .pricing-proj-value { color: var(--primary); }
.pricing-tip {
  background: rgba(99,102,241,.06); border: 1px solid rgba(99,102,241,.15);
  border-radius: var(--r-sm); padding: var(--s3);
  font-size: 12px; color: var(--text-2); line-height: 1.6;
}

/* ═══════════════════════════════════════════════════════════
   WEEKLY SUMMARY SHARE BUTTONS
   ═══════════════════════════════════════════════════════════ */
.ws-share-row {
  display: flex; gap: var(--s2); margin-top: var(--s4); flex-wrap: wrap;
}
.ws-share-row .btn { flex: 1; min-width: 180px; }

/* ─── PWA Install Banner ─── */
.pwa-install-banner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--s4);
  padding: var(--s4) var(--s5);
  margin: var(--s4) 0;
  background: linear-gradient(135deg, rgba(99,102,241,.12) 0%, rgba(139,92,246,.08) 100%);
  border: 1px solid rgba(99,102,241,.2);
  border-radius: var(--r3);
}
.pwa-install-content {
  display: flex;
  align-items: center;
  gap: var(--s3);
  flex: 1;
  min-width: 0;
}
.pwa-install-icon {
  width: 40px;
  height: 40px;
  border-radius: var(--r2);
  background: rgba(99,102,241,.15);
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--primary);
  flex-shrink: 0;
}
.pwa-install-text {
  display: flex;
  flex-direction: column;
  gap: 2px;
  min-width: 0;
}
.pwa-install-text strong {
  font-size: 13px;
  font-weight: 600;
  color: var(--text-1);
}
.pwa-install-text span {
  font-size: 11px;
  color: var(--text-3);
}
.pwa-install-actions {
  display: flex;
  align-items: center;
  gap: var(--s2);
  flex-shrink: 0;
}
.pwa-install-btn {
  padding: 8px 16px;
  background: var(--primary);
  color: #fff;
  border: none;
  border-radius: var(--r2);
  font-size: 12px;
  font-weight: 600;
  cursor: pointer;
  transition: opacity .2s;
}
.pwa-install-btn:hover { opacity: .85; }
.pwa-install-dismiss {
  background: none;
  border: none;
  color: var(--text-3);
  cursor: pointer;
  padding: 4px;
  display: flex;
}

/* Standalone mode adjustments */
@media (display-mode: standalone) {
  .topbar { padding-top: env(safe-area-inset-top, 0); }
  body { padding-bottom: env(safe-area-inset-bottom, 0); }
}

/* ═══════════════════════════════════════════════════════════
   GUIDED ONBOARDING — Premium 5-step wizard
   ═══════════════════════════════════════════════════════════ */

.guided-ob-overlay {
  position: fixed; inset: 0; z-index: 10000;
  background: linear-gradient(135deg, #0a0a0f 0%, #111827 50%, #0f172a 100%);
  display: flex; align-items: center; justify-content: center;
  padding: 16px;
  overflow-y: auto;
}

.guided-ob-container {
  width: 100%; max-width: 480px;
  position: relative;
  padding: 24px 20px 28px;
}

/* Progress bar */
.guided-ob-progress {
  width: 100%; height: 3px;
  background: rgba(255,255,255,.08);
  border-radius: 2px;
  overflow: hidden;
  margin-bottom: 8px;
}
.guided-ob-progress-fill {
  height: 100%;
  background: linear-gradient(90deg, #3B82F6, #BF5AF2);
  border-radius: 2px;
  transition: width .5s cubic-bezier(.4,0,.2,1);
}

.guided-ob-step-counter {
  font-size: 11px;
  font-weight: 600;
  color: rgba(255,255,255,.35);
  letter-spacing: 0;
  text-transform: none;
  margin-bottom: 28px;
  text-align: center;
  font-family: var(--font-mono, monospace);
}

/* Steps */
.guided-ob-step {
  display: none;
  animation: guidedObFadeIn .45s cubic-bezier(.4,0,.2,1) forwards;
}
.guided-ob-step.active { display: block; }

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

/* Icon container */
.guided-ob-icon {
  display: flex; justify-content: center;
  margin-bottom: 20px;
}
.guided-ob-icon svg {
  filter: drop-shadow(0 0 20px rgba(59,130,246,.25));
}

/* Typography */
.guided-ob-title {
  font-family: var(--font-display, sans-serif);
  font-size: clamp(22px, 5vw, 28px);
  font-weight: 700;
  color: #fff;
  text-align: center;
  line-height: 1.15;
  letter-spacing: -0.5px;
  margin-bottom: 8px;
}
.guided-ob-title-celebration {
  color: var(--primary);
  -webkit-text-fill-color: var(--primary);
}
.guided-ob-desc {
  font-size: 14px;
  color: rgba(255,255,255,.55);
  text-align: center;
  line-height: 1.6;
  margin-bottom: 24px;
}

/* Input fields */
.guided-ob-field {
  margin-bottom: 16px;
}
.guided-ob-field label {
  display: block;
  font-size: 12px;
  font-weight: 600;
  color: rgba(255,255,255,.6);
  margin-bottom: 6px;
  letter-spacing: .3px;
}
.guided-ob-input {
  width: 100%;
  padding: 12px 14px;
  background: rgba(255,255,255,.06);
  border: 1.5px solid rgba(255,255,255,.1);
  border-radius: 10px;
  color: #fff;
  font-size: 15px;
  font-family: inherit;
  outline: none;
  transition: border-color .2s, background .2s;
  -webkit-appearance: none;
  appearance: none;
}
.guided-ob-input:focus {
  border-color: #3B82F6;
  background: rgba(59,130,246,.06);
}
.guided-ob-input option {
  background: #1e293b;
  color: #fff;
}

/* Buttons */
.guided-ob-btn-primary {
  display: inline-flex; align-items: center; justify-content: center; gap: 8px;
  width: 100%; padding: 14px 20px;
  background: linear-gradient(135deg, #3B82F6, #6366F1);
  color: #fff; font-size: 15px; font-weight: 600;
  border: none; border-radius: 12px; cursor: pointer;
  transition: transform .15s, box-shadow .2s, opacity .2s;
  box-shadow: 0 4px 16px rgba(59,130,246,.25);
  font-family: inherit;
  margin-top: 8px;
}
.guided-ob-btn-primary:hover { transform: translateY(-1px); box-shadow: 0 6px 24px rgba(59,130,246,.35); }
.guided-ob-btn-primary:active { transform: scale(.98); }
.guided-ob-btn-primary:disabled { opacity: .4; cursor: not-allowed; transform: none; box-shadow: none; }

.guided-ob-btn-secondary {
  display: inline-flex; align-items: center; justify-content: center; gap: 6px;
  padding: 12px 18px;
  background: rgba(255,255,255,.06);
  color: rgba(255,255,255,.7); font-size: 14px; font-weight: 500;
  border: 1px solid rgba(255,255,255,.1); border-radius: 10px; cursor: pointer;
  transition: background .15s, border-color .15s;
  font-family: inherit;
}
.guided-ob-btn-secondary:hover { background: rgba(255,255,255,.1); border-color: rgba(255,255,255,.2); }

.guided-ob-btn-explore {
  display: inline-flex; align-items: center; justify-content: center; gap: 8px;
  width: 100%; padding: 14px 20px;
  background: rgba(255,255,255,.06);
  color: rgba(255,255,255,.8); font-size: 15px; font-weight: 600;
  border: 1.5px solid rgba(255,255,255,.12); border-radius: 12px; cursor: pointer;
  transition: background .15s, border-color .2s;
  font-family: inherit;
}
.guided-ob-btn-explore:hover { background: rgba(255,255,255,.1); border-color: rgba(255,255,255,.25); }

.guided-ob-btn-full { width: 100%; }

.guided-ob-btn-row {
  display: flex; gap: 10px; margin-top: 16px;
}
.guided-ob-btn-row .guided-ob-btn-primary { flex: 1; margin-top: 0; }

.guided-ob-skip {
  display: block; width: 100%;
  padding: 10px; margin-top: 8px;
  background: none; border: none;
  color: rgba(255,255,255,.3); font-size: 12px; font-weight: 500;
  cursor: pointer; text-align: center; font-family: inherit;
  transition: color .15s;
}
.guided-ob-skip:hover { color: rgba(255,255,255,.5); }

/* Pillars grid */
.guided-ob-pillars {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 8px;
  margin-bottom: 8px;
}
.guided-ob-pillar {
  display: flex; align-items: center; gap: 8px;
  padding: 10px 12px;
  background: rgba(255,255,255,.04);
  border: 1.5px solid rgba(255,255,255,.08);
  border-radius: 10px;
  color: rgba(255,255,255,.65);
  font-size: 12px; font-weight: 500;
  cursor: pointer;
  transition: all .2s cubic-bezier(.4,0,.2,1);
  font-family: inherit;
  text-align: left;
}
.guided-ob-pillar:hover {
  background: rgba(255,255,255,.07);
  border-color: rgba(255,255,255,.15);
  color: rgba(255,255,255,.85);
}
.guided-ob-pillar.selected {
  background: rgba(59,130,246,.1);
  border-color: #3B82F6;
  color: #fff;
  box-shadow: 0 0 12px rgba(59,130,246,.15);
}
.guided-ob-pillar.selected svg { stroke: #3B82F6; }
.guided-ob-pillar span { flex: 1; line-height: 1.2; }

.guided-ob-hint {
  font-size: 11px;
  color: rgba(255,255,255,.3);
  text-align: center;
  margin-bottom: 4px;
  transition: color .2s;
}
.guided-ob-hint.error { color: #FF453A; }
.guided-ob-hint.ok { color: #30D158; }

/* Instagram benefits */
.guided-ob-benefits {
  display: flex; flex-direction: column; gap: 10px;
  margin-bottom: 24px;
  padding: 16px;
  background: rgba(34,197,94,.04);
  border: 1px solid rgba(34,197,94,.12);
  border-radius: 12px;
}
.guided-ob-benefit {
  display: flex; align-items: center; gap: 10px;
  font-size: 13px; color: rgba(255,255,255,.75);
  font-weight: 500;
}

/* Step 4 — Generation */
.guided-ob-generating {
  display: flex; flex-direction: column; align-items: center;
  padding: 40px 20px;
  gap: 16px;
}
.guided-ob-spinner {
  width: 40px; height: 40px;
  border: 3px solid rgba(255,255,255,.1);
  border-top-color: #3B82F6;
  border-radius: 50%;
  animation: guidedObSpin 1s linear infinite;
}
@keyframes guidedObSpin { to { transform: rotate(360deg); } }

.guided-ob-gen-text {
  font-size: 14px; color: rgba(255,255,255,.5);
  text-align: center;
  animation: guidedObPulse 2s ease-in-out infinite;
}
@keyframes guidedObPulse { 0%,100% { opacity: .5; } 50% { opacity: 1; } }

.guided-ob-gen-error {
  text-align: center;
  padding: 20px;
  color: rgba(255,255,255,.5);
  font-size: 13px;
}

/* Result card */
.guided-ob-result {
  background: rgba(255,255,255,.04);
  border: 1px solid rgba(255,255,255,.1);
  border-radius: 14px;
  padding: 18px 16px;
  margin-bottom: 12px;
  position: relative;
  animation: guidedObResultIn .5s cubic-bezier(.34,1.56,.64,1) forwards;
}
@keyframes guidedObResultIn {
  from { opacity: 0; transform: scale(.95) translateY(10px); }
  to   { opacity: 1; transform: none; }
}

.guided-ob-result-badge {
  display: inline-flex; align-items: center; gap: 6px;
  font-size: 10px; font-weight: 700;
  color: #BF5AF2;
  text-transform: none; letter-spacing: 0;
  margin-bottom: 10px;
}
.guided-ob-result-badge svg { stroke: #BF5AF2; }

.guided-ob-result-hook {
  font-size: 16px; font-weight: 700;
  color: #fff;
  line-height: 1.35;
  margin-bottom: 10px;
}
.guided-ob-result-script {
  font-size: 13px;
  color: rgba(255,255,255,.55);
  line-height: 1.65;
  margin-bottom: 12px;
  max-height: 120px;
  overflow-y: auto;
}
.guided-ob-result-script::-webkit-scrollbar { width: 3px; }
.guided-ob-result-script::-webkit-scrollbar-track { background: transparent; }
.guided-ob-result-script::-webkit-scrollbar-thumb { background: rgba(255,255,255,.15); border-radius: 2px; }

.guided-ob-result-meta {
  display: flex; gap: 8px; flex-wrap: wrap;
}
.guided-ob-result-tag {
  display: inline-block;
  padding: 4px 10px;
  background: rgba(59,130,246,.1);
  border-radius: 6px;
  font-size: 11px; font-weight: 600;
  color: #60A5FA;
}

/* Step 5 — Celebration */
.guided-ob-celebration-icon {
  display: flex; justify-content: center;
  margin-bottom: 20px;
}
.guided-ob-celebration-icon svg {
  filter: drop-shadow(0 0 24px rgba(34,197,94,.3));
  animation: guidedObCheckPop .6s cubic-bezier(.34,1.56,.64,1) forwards;
}
@keyframes guidedObCheckPop {
  from { opacity: 0; transform: scale(.5); }
  to   { opacity: 1; transform: scale(1); }
}

.guided-ob-xp-badge {
  display: inline-flex; align-items: center; gap: 8px;
  margin: 0 auto 20px;
  padding: 10px 18px;
  background: rgba(234,179,8,.08);
  border: 1px solid rgba(234,179,8,.2);
  border-radius: 10px;
  font-size: 14px; font-weight: 700;
  color: #EAB308;
  text-align: center;
  justify-content: center;
  width: fit-content;
  display: flex;
}

.guided-ob-result-mini {
  background: rgba(255,255,255,.04);
  border: 1px solid rgba(255,255,255,.08);
  border-radius: 10px;
  padding: 14px;
  margin-bottom: 20px;
  text-align: center;
}
.guided-ob-result-mini-hook {
  font-size: 14px; font-weight: 600;
  color: rgba(255,255,255,.7);
  line-height: 1.4;
  margin: 0;
}

.guided-ob-final-btns {
  display: flex; flex-direction: column; gap: 10px;
}

/* Mobile refinements */
@media (max-width: 480px) {
  .guided-ob-container { padding: 20px 16px 24px; }
  .guided-ob-pillars { grid-template-columns: 1fr 1fr; gap: 6px; }
  .guided-ob-pillar { padding: 8px 10px; font-size: 11px; }
  .guided-ob-title { font-size: 22px; }
}

@media (max-width: 350px) {
  .guided-ob-pillars { grid-template-columns: 1fr; }
}

/* ─── IG Insights Strip (Feature 2: AI + Instagram Data) ─── */
.ig-insights-strip {
  padding: var(--s3) var(--s4);
  margin: var(--s3) 0;
  background: linear-gradient(135deg, rgba(139,92,246,.08) 0%, rgba(59,130,246,.06) 100%);
  border: 1px solid rgba(139,92,246,.15);
  border-radius: var(--r-md);
  display: flex;
  flex-wrap: wrap;
  gap: var(--s3);
  align-items: center;
}
.ig-insights-strip .ig-insight-badge {
  padding: 4px 10px;
  background: rgba(139,92,246,.15);
  border-radius: 20px;
  font-size: 11px;
  font-weight: 600;
  color: #A78BFA;
  display: flex;
  align-items: center;
  gap: 4px;
}
.ig-insights-strip .ig-insight-item {
  font-size: 12px;
  color: var(--text-2);
  display: flex;
  align-items: center;
  gap: 4px;
}
.ig-insights-strip .ig-insight-item strong {
  color: var(--text-1);
}
.ig-insights-strip .ig-connect-cta {
  font-size: 12px;
  color: var(--text-2);
  display: flex;
  align-items: center;
  gap: 6px;
}
.ig-insights-strip .ig-connect-cta a {
  color: #A78BFA;
  text-decoration: none;
  font-weight: 600;
  cursor: pointer;
}

/* ─── Revenue Widget (Feature 3: R$ Revenue Potential) ─── */
.revenue-widget {
  background: var(--bg-surface);
  border: 1px solid var(--border-sm);
  border-radius: var(--r-lg);
  padding: var(--s4) var(--s5);
  margin-bottom: var(--s4);
}
.revenue-widget-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: var(--s3);
}
.revenue-widget-title {
  font-size: 11px;
  font-weight: 700;
  text-transform: none;
  letter-spacing: 0;
  color: var(--text-3);
}
.revenue-widget-amount {
  font-size: 28px;
  font-weight: 700;
  color: #30D158;
  margin-bottom: 4px;
}
.revenue-widget-sub {
  font-size: 11px;
  color: var(--text-3);
}
.revenue-funnel {
  display: flex;
  align-items: center;
  gap: var(--s2);
  margin-top: var(--s3);
  padding-top: var(--s3);
  border-top: 1px solid var(--border-sm);
  flex-wrap: wrap;
}
.revenue-funnel-step {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 2px;
  flex: 1;
  min-width: 50px;
}
.revenue-funnel-step .rf-value {
  font-size: 14px;
  font-weight: 700;
  color: var(--text-1);
}
.revenue-funnel-step .rf-label {
  font-size: 9px;
  color: var(--text-3);
  text-align: center;
}
.revenue-funnel-arrow {
  color: var(--text-3);
  font-size: 10px;
  flex-shrink: 0;
}

/* Revenue in weekly summary modal */
.ws-revenue-section {
  margin-top: var(--s4);
  padding: var(--s4);
  background: linear-gradient(135deg, rgba(16,185,129,.1) 0%, rgba(34,197,94,.05) 100%);
  border: 1px solid rgba(16,185,129,.2);
  border-radius: var(--r-sm);
}
.ws-revenue-title {
  font-size: 12px;
  font-weight: 700;
  color: #30D158;
  text-transform: none;
  letter-spacing: 0;
  margin-bottom: var(--s3);
}
.ws-revenue-amount {
  font-size: 24px;
  font-weight: 700;
  color: #30D158;
}
.ws-revenue-detail {
  font-size: 12px;
  color: var(--text-2);
  margin-top: 4px;
}
.ws-revenue-disclaimer {
  font-size: 10px;
  color: var(--text-3);
  font-style: italic;
  margin-top: var(--s2);
}

/* Revenue section on growth page */
.gw-revenue-section {
  margin-top: var(--s4);
  padding: var(--s4);
  background: linear-gradient(135deg, rgba(16,185,129,.06) 0%, rgba(34,197,94,.03) 100%);
  border: 1px solid rgba(16,185,129,.15);
  border-radius: var(--r-sm);
}

/* ─── Schedule Queue (Fila de Publicacao) ─── */
.schedule-queue {
  margin-top: var(--s5);
}
.sq-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: var(--s4);
}
.sq-header-left {
  display: flex;
  align-items: center;
  gap: var(--s2);
  color: var(--text-2);
}
.sq-title {
  font-size: 13px;
  font-weight: 700;
  text-transform: none;
  letter-spacing: 0;
  color: var(--text-2);
}
.sq-count {
  font-size: 11px;
  color: var(--text-3);
  background: var(--bg-surface);
  padding: 3px 10px;
  border-radius: var(--r-full);
}
.sq-list {
  display: flex;
  flex-direction: column;
  gap: var(--s3);
}
.sq-item {
  background: var(--bg-surface);
  border: 1px solid var(--border-sm);
  border-radius: var(--r-md);
  padding: var(--s4);
  transition: border-color .2s;
}
.sq-item:hover {
  border-color: var(--primary);
}
.sq-item-overdue {
  border-color: rgba(245,158,11,.4) !important;
  background: linear-gradient(135deg, rgba(245,158,11,.06) 0%, transparent 100%);
}
.sq-item-top {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: var(--s2);
}
.sq-item-type {
  font-size: 10px;
  font-weight: 700;
  text-transform: none;
  letter-spacing: 0;
  padding: 2px 8px;
  border-radius: 4px;
  background: rgba(99,102,241,.12);
  color: var(--primary);
}
.sq-item-time {
  font-size: 11px;
  color: var(--text-3);
}
.sq-item-title {
  font-size: 14px;
  font-weight: 600;
  color: var(--text-1);
  margin-bottom: var(--s2);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.sq-item-countdown {
  font-size: 12px;
  color: var(--secondary);
  font-weight: 600;
  margin-bottom: var(--s3);
}
.sq-item-overdue .sq-item-countdown {
  color: #FF9F0A;
}
.sq-item-actions {
  display: flex;
  gap: var(--s2);
  align-items: center;
}
.sq-action-btn {
  display: flex;
  align-items: center;
  gap: 4px;
  padding: 6px 12px;
  border: 1px solid var(--border-sm);
  border-radius: var(--r-sm);
  background: transparent;
  color: var(--text-2);
  font-size: 11px;
  font-weight: 500;
  cursor: pointer;
  transition: all .2s;
  font-family: var(--font-body);
}
.sq-action-btn:hover {
  background: var(--bg-hover);
  color: var(--text-1);
}
.sq-action-publish {
  border-color: rgba(16,185,129,.3);
  color: #30D158;
}
.sq-action-publish:hover {
  background: rgba(16,185,129,.1);
}
.sq-action-notif.active {
  color: var(--primary);
  border-color: rgba(99,102,241,.3);
}
.sq-empty {
  text-align: center;
  padding: var(--s6) var(--s4);
  color: var(--text-3);
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--s2);
}
.sq-empty span:first-of-type {
  font-size: 13px;
  font-weight: 600;
  color: var(--text-2);
}
.sq-empty-sub {
  font-size: 11px;
}

/* Planner add modal — schedule row + format buttons */
.pa-schedule-row {
  display: flex;
  align-items: center;
  gap: var(--s2);
  margin-top: var(--s2);
}
.pa-time-select {
  width: 64px;
  padding: 6px 8px;
  font-size: 13px;
}
.pa-notif-toggle {
  display: flex;
  align-items: center;
  gap: 4px;
  font-size: 11px;
  color: var(--text-2);
  cursor: pointer;
  margin-left: var(--s3);
  white-space: nowrap;
}
.pa-notif-toggle input[type="checkbox"] {
  width: auto;
  margin: 0;
}
.pa-format-btn {
  padding: 6px 12px;
  border: 1px solid var(--border-sm);
  border-radius: var(--r-sm);
  background: transparent;
  color: var(--text-2);
  font-size: 11px;
  font-weight: 600;
  cursor: pointer;
  transition: all .2s;
  font-family: var(--font-body);
}
.pa-format-btn:hover {
  border-color: var(--primary-border);
  color: var(--primary);
}
.pa-format-btn.active {
  background: var(--primary-dim);
  border-color: var(--primary-border);
  color: var(--primary);
}

/* ═══════════════════════════════════════════════════════════
   FEATURE A/B/C: Smart Week, Performance Memory, Style Learning
   ═══════════════════════════════════════════════════════════ */

/* ─── Smart Week Banner ─── */
.smart-week-banner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--s4);
  padding: var(--s4) var(--s5);
  margin: var(--s4) 0;
  background: linear-gradient(135deg, rgba(99,102,241,.08) 0%, rgba(168,85,247,.06) 100%);
  border: 1px solid rgba(99,102,241,.15);
  border-radius: var(--r3);
}
.sw-banner-content {
  display: flex;
  align-items: center;
  gap: var(--s3);
  flex: 1;
  color: var(--text-2);
}
.sw-banner-content strong {
  display: block;
  font-size: 13px;
  color: var(--text-1);
}
.sw-banner-content span {
  font-size: 11px;
  color: var(--text-3);
}
.sw-banner-btn {
  padding: 8px 16px;
  background: var(--primary);
  color: #fff;
  border: none;
  border-radius: var(--r2);
  font-size: 12px;
  font-weight: 600;
  cursor: pointer;
  white-space: nowrap;
  font-family: var(--font-body);
}
.sw-banner-btn:hover { opacity: .85; }

/* Suggested planner entries */
.planner-entry.ai-suggested {
  border-style: dashed !important;
  border-color: rgba(99,102,241,.3) !important;
  background: rgba(99,102,241,.03) !important;
}
.planner-entry.ai-suggested .ai-badge,
.planner-entry-item-wrap.ai-suggested .ai-badge {
  font-size: 9px;
  font-weight: 700;
  padding: 1px 6px;
  border-radius: 4px;
  background: rgba(99,102,241,.12);
  color: var(--primary);
  letter-spacing: 0;
}
.ai-suggestion-actions {
  display: flex;
  gap: var(--s2);
  margin-top: var(--s2);
}
.ai-suggestion-actions button {
  padding: 4px 10px;
  border: 1px solid var(--border-sm);
  border-radius: var(--r1);
  background: transparent;
  color: var(--text-2);
  font-size: 10px;
  cursor: pointer;
  font-family: var(--font-body);
  transition: all .2s;
}
.ai-suggestion-actions button:first-child {
  background: rgba(16,185,129,.1);
  border-color: rgba(16,185,129,.3);
  color: #30D158;
}
.ai-suggestion-actions button:first-child:hover {
  background: rgba(16,185,129,.2);
}
.ai-suggestion-actions button:last-child:hover {
  border-color: var(--primary);
  color: var(--primary);
}

/* Performance/Style Learning Indicators */
.ai-learning-strip {
  display: flex;
  align-items: center;
  gap: var(--s3);
  padding: var(--s2) var(--s3);
  margin: var(--s2) 0;
  font-size: 11px;
  color: var(--text-3);
}
.ai-learning-strip .al-bar {
  width: 60px;
  height: 4px;
  border-radius: 2px;
  background: var(--bg-3);
  overflow: hidden;
  flex-shrink: 0;
}
.ai-learning-strip .al-bar-fill {
  height: 100%;
  border-radius: 2px;
  background: linear-gradient(90deg, var(--primary), #A78BFA);
  transition: width .3s;
}
.ai-learning-strip .al-label {
  color: var(--text-2);
  font-weight: 500;
}
.planner-entry-item-wrap.ai-suggested {
  border-radius: var(--r2);
  padding: var(--s2);
  border: 1px dashed rgba(99,102,241,.3);
  background: rgba(99,102,241,.03);
}

@media (max-width: 600px) {
  .smart-week-banner {
    flex-direction: column;
    align-items: flex-start;
    gap: var(--s3);
  }
  .sw-banner-btn {
    width: 100%;
    text-align: center;
  }
  .ai-learning-strip {
    flex-wrap: wrap;
  }
}

/* ═══════════════════════════════════════════════════════════
   ADVANCED MODE TOGGLE
   ═══════════════════════════════════════════════════════════ */

/* Hide advanced sections by default */
.advanced-only {
  display: none !important;
}
/* Show when body has advanced-mode class */
body.advanced-mode .advanced-only {
  display: block !important;
}
/* Pages must respect active state even in advanced mode */
body.advanced-mode .page.advanced-only:not(.active) {
  display: none !important;
}
body.advanced-mode .advanced-only.advanced-only--grid {
  display: grid !important;
}
body.advanced-mode .advanced-only.advanced-only--flex {
  display: flex !important;
}

/* Toggle button styling */
.advanced-toggle-btn {
  position: relative;
}
.advanced-toggle-btn.active {
  color: var(--primary) !important;
  background: var(--primary-dim) !important;
}
.advanced-toggle-btn.active::after {
  content: '';
  position: absolute;
  bottom: -2px;
  left: 50%;
  transform: translateX(-50%);
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: var(--primary);
}

/* ── Advanced Mode Confirmation Dialog ─────────────────── */
/* Apple-style alert dialog */
.adv-confirm-overlay {
  position: fixed; inset: 0; z-index: 9200;
  background: rgba(0,0,0,.4); backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
  display: flex; align-items: center; justify-content: center;
  opacity: 0; transition: opacity 200ms cubic-bezier(0.32, 0.72, 0, 1);
  pointer-events: none;
}
.adv-confirm-overlay.visible { opacity: 1; pointer-events: auto; }
.adv-confirm-overlay.hidden { opacity: 0; pointer-events: none; }

.adv-confirm-card {
  background: var(--bg-surface);
  backdrop-filter: blur(40px) saturate(180%);
  -webkit-backdrop-filter: blur(40px) saturate(180%);
  border: 0.5px solid rgba(255,255,255,.1);
  border-radius: 14px; padding: 24px 20px;
  max-width: 320px; width: 85%; text-align: center;
  transform: scale(.94); opacity: 0;
  transition: transform 350ms cubic-bezier(0.32, 0.72, 0, 1), opacity 250ms cubic-bezier(0.32, 0.72, 0, 1);
  box-shadow: 0 24px 80px rgba(0,0,0,.3), 0 0 1px rgba(0,0,0,.1);
}
.adv-confirm-overlay.visible .adv-confirm-card {
  transform: scale(1); opacity: 1;
}

.adv-confirm-icon {
  width: 48px; height: 48px; margin: 0 auto 12px;
  background: var(--primary-dim); border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  color: var(--primary);
}
.adv-confirm-title {
  font-family: var(--font-display); font-size: 17px;
  font-weight: 600; letter-spacing: -0.02em;
  color: var(--text-1); margin-bottom: 8px;
}
.adv-confirm-desc {
  font-size: 13px; color: var(--text-2); line-height: 1.5; margin-bottom: 12px;
  letter-spacing: -0.005em;
}
.adv-confirm-list {
  text-align: left; font-size: 13px; color: var(--text-2);
  line-height: 1.7; padding-left: 18px; margin-bottom: 12px;
}
.adv-confirm-list li::marker { color: var(--primary); }
.adv-confirm-note {
  font-size: 12px; color: var(--text-3); margin-bottom: 16px;
}
.adv-confirm-actions {
  display: flex; gap: 8px;
}
.adv-confirm-cancel {
  flex: 1; padding: 11px; font-size: 15px; font-weight: 400;
  border: none; border-radius: 12px;
  background: rgba(255,255,255,.08); color: var(--text-1); cursor: pointer;
  transition: background 100ms cubic-bezier(0.32, 0.72, 0, 1), transform 100ms cubic-bezier(0.32, 0.72, 0, 1);
}
.adv-confirm-cancel:hover { background: rgba(255,255,255,.14); }
.adv-confirm-cancel:active { transform: scale(0.97); }
.adv-confirm-yes {
  flex: 1; padding: 11px; font-size: 15px; font-weight: 600;
  border-radius: 12px;
}
.adv-confirm-yes:active { transform: scale(0.97); }

/* ── Advanced Mode Tooltip — Apple popover ────────────── */
.adv-tooltip {
  position: fixed; z-index: 9200;
  transform: translateX(-50%) translateY(6px) scale(0.96);
  width: 260px; opacity: 0; pointer-events: none;
  transition: opacity 250ms cubic-bezier(0.32, 0.72, 0, 1),
              transform 300ms cubic-bezier(0.32, 0.72, 0, 1);
}
.adv-tooltip.visible {
  opacity: 1; pointer-events: auto; transform: translateX(-50%) translateY(0) scale(1);
}
.adv-tooltip-arrow {
  width: 12px; height: 12px; background: var(--bg-surface);
  border: 0.5px solid rgba(255,255,255,.1); border-bottom: none; border-right: none;
  transform: rotate(45deg); position: absolute; top: -6px; left: 50%;
  margin-left: -6px;
}
.adv-tooltip-body {
  background: var(--bg-surface);
  backdrop-filter: blur(40px) saturate(180%);
  border: 0.5px solid rgba(255,255,255,.1);
  border-radius: 14px; padding: 16px; text-align: center;
  box-shadow: 0 12px 40px rgba(0,0,0,.25), 0 0 1px rgba(0,0,0,.1);
}
.adv-tooltip-body strong {
  display: block; font-size: 14px; font-weight: 600;
  letter-spacing: -0.01em;
  color: var(--text-1); margin-bottom: 6px;
}
.adv-tooltip-body p {
  font-size: 13px; color: var(--text-2); line-height: 1.5; margin-bottom: 12px;
  letter-spacing: -0.005em;
}
.adv-tooltip-ok {
  padding: 9px 20px; font-size: 14px; font-weight: 600;
  width: 100%; border-radius: 10px;
  letter-spacing: -0.01em;
}

/* ═══════════════════════════════════════════════════════════
   AI TIER SELECTOR & CREDIT BAR
   ═══════════════════════════════════════════════════════════ */
.ai-tier-bar {
  margin-bottom: var(--s4);
}
.ai-tier-selector {
  display: flex;
  gap: var(--s2);
  margin-bottom: var(--s3);
}
.ai-tier-btn {
  flex: 1;
  padding: 10px 8px;
  border-radius: var(--r-md);
  border: 1px solid var(--border-sm);
  background: var(--bg-surface);
  cursor: pointer;
  transition: all var(--ease-fast);
  text-align: center;
  position: relative;
}
.ai-tier-btn:hover {
  border-color: var(--border-md);
  background: var(--bg-elevated);
}
.ai-tier-btn.active {
  border-color: var(--primary-border);
  background: var(--primary-dim);
}
.ai-tier-btn.disabled {
  opacity: 0.4;
  cursor: not-allowed;
}
.ai-tier-name {
  font-size: 12px;
  font-weight: 700;
  color: var(--text-1);
  margin-bottom: 2px;
}
.ai-tier-cost {
  font-size: 10px;
  color: var(--text-3);
}
.ai-tier-badge {
  position: absolute;
  top: -6px;
  right: 8px;
  background: var(--primary);
  color: #fff;
  font-size: 8px;
  font-weight: 700;
  padding: 1px 6px;
  border-radius: 4px;
  letter-spacing: 0;
}
.ai-credit-bar-wrap {
  display: flex;
  align-items: center;
  gap: var(--s2);
}
.ai-credit-bar {
  flex: 1;
  height: 6px;
  border-radius: 3px;
  background: var(--bg-elevated);
  overflow: hidden;
}
.ai-credit-bar-fill {
  height: 100%;
  border-radius: 3px;
  background: linear-gradient(90deg, var(--primary), var(--secondary));
  transition: width 0.4s cubic-bezier(0.32, 0.72, 0, 1);
}
.ai-credit-bar-fill.low {
  background: linear-gradient(90deg, var(--cta), var(--red));
}
.ai-credit-label {
  font-size: 10px;
  color: var(--text-3);
  white-space: nowrap;
  font-family: var(--font-mono);
}

/* ═══════════════════════════════════════════════════════════
   MOBILE DESIGN OVERHAUL — Better cards, tabs, spacing
   ═══════════════════════════════════════════════════════════ */

/* ── Tabs: horizontal scroll on mobile ── */
@media (max-width: 768px) {
  .tabs-row {
    width: 100%;
    overflow-x: auto;
    scrollbar-width: none;
    -webkit-overflow-scrolling: touch;
    flex-wrap: nowrap;
  }
  .tabs-row::-webkit-scrollbar { display: none; }
  .tab-btn {
    white-space: nowrap;
    flex-shrink: 0;
    padding: 8px 14px;
    font-size: 12px;
  }

  /* ── Home cards: better spacing & radius ── */
  .pipeline-widget,
  .ig-home-widget,
  .ig-connect-banner,
  .revenue-widget,
  .funnel-widget,
  .weekly-summary-widget,
  .roadmap-widget,
  .library-home-widget,
  .pricing-widget,
  .daily-tasks,
  .wk-plan,
  .intel-row {
    border-radius: var(--r-md) !important;
  }

  /* ── Quick action widget: more compact ── */
  .quick-action-widget { padding: var(--s3) !important; }
  .quick-action-widget .qa-title { font-size: 13px; }

  /* ── IG connect banner: compact ── */
  .ig-connect-banner { padding: var(--s3) !important; }
  .ig-connect-banner .btn-sm { padding: 6px 14px; font-size: 12px; }

  /* ── Planner grid: scrollable on small screens ── */
  .planner-grid {
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
    scrollbar-width: none;
    padding-bottom: var(--s2);
  }
  .planner-grid::-webkit-scrollbar { display: none; }
  .planner-day {
    min-width: 140px;
    min-height: 100px;
  }
  .planner-day.has-content {
    min-height: auto;
  }

  /* ── Pipeline kanban: horizontal scroll ── */
  .pipeline-kanban {
    display: flex !important;
    overflow-x: auto !important;
    -webkit-overflow-scrolling: touch;
    scrollbar-width: none;
    gap: var(--s3) !important;
    padding-bottom: var(--s2);
  }
  .pipeline-kanban::-webkit-scrollbar { display: none; }
  .pk-column {
    min-width: 220px !important;
    flex-shrink: 0;
  }

  /* ── Modals: better mobile sizing ── */
  .gw-modal {
    max-width: calc(100vw - 16px) !important;
    max-height: calc(100vh - 32px) !important;
    margin: 16px auto;
    border-radius: var(--r-lg) !important;
  }
  .gw-modal-body { padding: var(--s3) !important; }
  .gw-modal-header { padding: var(--s3) var(--s3) 0 !important; }
  .gw-modal-footer { padding: 0 var(--s3) var(--s3) !important; }

  /* ── Growth page cards: tighter ── */
  .gw-stat-value { font-size: 20px; }
  .gw-stat-label { font-size: 9px; }

  /* ── Trends cards: full width ── */
  .trend-card { margin-bottom: var(--s3); }

  /* ── Page titles: slightly smaller on mobile ── */
  .page-accent-word { font-size: clamp(28px, 8vw, 36px); }

  /* ── IG insights strip: wrap on mobile ── */
  .ig-insights-strip {
    flex-wrap: wrap !important;
    gap: var(--s2) !important;
  }
  .ig-insights-strip > div {
    min-width: calc(50% - 4px);
  }
}

/* ── Even smaller phones ── */
@media (max-width: 380px) {
  .tab-btn { padding: 7px 10px; font-size: 11px; }
  .planner-day { min-width: 120px; }
  .pk-column { min-width: 200px !important; }
  .metric-val { font-size: 20px; }
  .cmd-headline { font-size: 22px; }
}

/* ═══════════════════════════════════════════════════════════
   WHATSAPP INTEGRATION — Lead cards & buttons
   ═══════════════════════════════════════════════════════════ */
.whatsapp-btn {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 8px 16px;
  background: #25D366;
  color: #fff;
  border: none;
  border-radius: var(--r-full);
  font-size: 13px;
  font-weight: 600;
  cursor: pointer;
  transition: all var(--ease-fast);
  width: 100%;
  justify-content: center;
}
.whatsapp-btn:hover {
  background: #20BD5A;
  transform: translateY(-1px);
  box-shadow: 0 4px 12px rgba(37,211,102,.3);
}
.whatsapp-btn svg { flex-shrink: 0; }

.wa-msg-preview {
  padding: var(--s3);
  background: var(--bg-elevated);
  border: 1px solid var(--border-sm);
  border-radius: var(--r-md);
  margin: var(--s3) 0;
}
.wa-msg-preview textarea {
  width: 100%;
  min-height: 80px;
  background: transparent;
  border: none;
  color: var(--text-1);
  font-size: 13px;
  line-height: 1.5;
  resize: vertical;
  font-family: var(--font-body);
}
.wa-msg-preview textarea:focus { outline: none; }
.wa-msg-templates {
  display: flex;
  flex-wrap: wrap;
  gap: var(--s2);
  margin-bottom: var(--s3);
}
.wa-msg-template-btn {
  padding: 5px 12px;
  background: rgba(37,211,102,.08);
  border: 1px solid rgba(37,211,102,.2);
  border-radius: var(--r-full);
  color: #25D366;
  font-size: 11px;
  font-weight: 600;
  cursor: pointer;
  transition: all var(--ease-fast);
}
.wa-msg-template-btn:hover,
.wa-msg-template-btn.active {
  background: rgba(37,211,102,.18);
  border-color: rgba(37,211,102,.4);
}
.phone-input-row {
  display: flex;
  gap: var(--s2);
  align-items: center;
}
.phone-input-row input {
  flex: 1;
}
.phone-prefix {
  font-size: 13px;
  color: var(--text-2);
  font-weight: 600;
  white-space: nowrap;
}

/* ═══════════════════════════════════════════════════════════
   WEEK-OVER-WEEK COMPARISON
   ═══════════════════════════════════════════════════════════ */
.gw-stat-delta.delta-up { color: #30D158; font-weight: 600; }
.gw-stat-delta.delta-down { color: #FF453A; font-weight: 600; }
.gw-stat-delta.delta-neutral { color: var(--text-3); }
.delta-arrow { font-size: 10px; margin-right: 2px; }

/* ═══════════════════════════════════════════════════════════
   AI INSIGHTS HOME
   ═══════════════════════════════════════════════════════════ */
.ai-insights-home { margin-bottom: var(--s4); }
.ai-insights-list { display: flex; flex-direction: column; gap: var(--s2); margin-top: var(--s3); }
.ai-insight-item {
  display: flex; align-items: flex-start; gap: var(--s3);
  padding: var(--s3) var(--s4); border-radius: var(--r-md);
  background: var(--bg-elevated); border-left: 3px solid var(--primary);
}
[data-theme="light"] .ai-insight-item { background: #fff; box-shadow: 0 1px 3px rgba(0,0,0,.06); }
.ai-insight-icon { font-size: 18px; flex-shrink: 0; margin-top: 1px; }
.ai-insight-text { font-size: 12px; color: var(--text-2); line-height: 1.5; }
.ai-insight-text strong { color: var(--text-1); font-weight: 600; }

/* ═══════════════════════════════════════════════════════════
   MONTHLY REPORT CARD
   ═══════════════════════════════════════════════════════════ */
.monthly-report-card { margin-bottom: var(--s4); }
.monthly-report-grid {
  display: grid; grid-template-columns: repeat(2, 1fr); gap: var(--s3);
  margin-top: var(--s3);
}
@media (min-width: 600px) { .monthly-report-grid { grid-template-columns: repeat(4, 1fr); } }
.mr-stat {
  background: var(--bg-elevated); border-radius: var(--r-md);
  padding: var(--s4); text-align: center;
  border: 1px solid var(--border-sm);
}
[data-theme="light"] .mr-stat { background: #fff; box-shadow: 0 1px 3px rgba(0,0,0,.06); }
.mr-stat-value { font-size: 22px; font-weight: 700; color: var(--text-1); margin-bottom: 2px; }
.mr-stat-label { font-size: 10px; color: var(--text-3); text-transform: lowercase; }

/* ═══════════════════════════════════════════════════════════
   PLATFORM PLACEHOLDERS (Coming Soon)
   ═══════════════════════════════════════════════════════════ */
.platform-placeholders { display: flex; flex-direction: column; gap: var(--s2); }
.platform-ph-card {
  display: flex; align-items: center; justify-content: space-between;
  padding: var(--s3) var(--s4); border-radius: var(--r-md);
  background: var(--bg-elevated); border: 1px solid var(--border-sm);
  opacity: 0.6;
}
[data-theme="light"] .platform-ph-card { background: #fff; }
.platform-ph-left { display: flex; align-items: center; gap: var(--s3); }
.platform-ph-left svg { color: var(--text-3); }
.platform-ph-name { font-size: 13px; font-weight: 600; color: var(--text-1); }
.platform-ph-desc { font-size: 10px; color: var(--text-3); }
.platform-ph-badge {
  padding: 3px 10px; border-radius: var(--r-full);
  background: rgba(255,255,255,.06); border: 1px solid var(--border-sm);
  font-size: 9px; font-weight: 600; color: var(--text-3);
}
[data-theme="light"] .platform-ph-badge { background: rgba(0,0,0,.04); }

/* ═══════════════════════════════════════════════════════════
   LEVEL ASSESSMENT WIZARD
   ═══════════════════════════════════════════════════════════ */
.level-assessment-overlay {
  position: fixed; inset: 0; z-index: 10000;
  background: rgba(0,0,0,.6); backdrop-filter: blur(12px);
  display: flex; align-items: center; justify-content: center;
  padding: var(--s4);
}
.level-assessment-card {
  background: var(--bg-elevated); border-radius: var(--r-xl);
  padding: var(--s6); max-width: 420px; width: 100%;
  box-shadow: 0 24px 80px rgba(0,0,0,.4);
}
[data-theme="light"] .level-assessment-card {
  background: #fff; box-shadow: 0 24px 80px rgba(0,0,0,.15);
}
.la-progress {
  height: 3px; background: rgba(255,255,255,.1); border-radius: 2px;
  margin-bottom: var(--s6); overflow: hidden;
}
[data-theme="light"] .la-progress { background: rgba(0,0,0,.06); }
.la-progress-fill {
  height: 100%; background: var(--primary); border-radius: 2px;
  transition: width 400ms cubic-bezier(0.32,0.72,0,1);
}
.la-step { display: none; text-align: center; }
.la-step.active { display: block; animation: cardStaggerIn 350ms cubic-bezier(0.32,0.72,0,1) both; }
.la-icon { font-size: 40px; margin-bottom: var(--s3); }
.la-title { font-size: 20px; font-weight: 700; color: var(--text-1); margin-bottom: var(--s2); }
.la-desc { font-size: 13px; color: var(--text-3); margin-bottom: var(--s5); }
.la-options { display: flex; flex-direction: column; gap: var(--s2); }
.la-option {
  display: flex; align-items: center; gap: var(--s3);
  padding: 14px 16px; border-radius: var(--r-md);
  background: rgba(255,255,255,.05); border: 1.5px solid var(--border-sm);
  color: var(--text-1); cursor: pointer; text-align: left;
  transition: all 200ms cubic-bezier(0.32,0.72,0,1);
}
.la-option:hover { background: rgba(255,255,255,.1); border-color: var(--primary); }
.la-option.selected { background: rgba(0,122,255,.1); border-color: var(--primary); }
[data-theme="light"] .la-option { background: rgba(0,0,0,.02); }
[data-theme="light"] .la-option:hover { background: rgba(0,122,255,.06); }
[data-theme="light"] .la-option.selected { background: rgba(0,122,255,.08); }
.la-option-emoji { font-size: 22px; flex-shrink: 0; }
.la-option-label { font-size: 14px; font-weight: 600; }
.la-option-desc { font-size: 11px; color: var(--text-3); margin-left: auto; }

/* ═══════════════════════════════════════════════════════════
   SIMPLIFIED MODE (Beginner)
   ═══════════════════════════════════════════════════════════ */
body.simplified-mode .pipeline-widget,
body.simplified-mode .pipeline-card,
body.simplified-mode .advanced-toggle-btn,
body.simplified-mode .revenue-widget,
body.simplified-mode .funnel-home-widget,
body.simplified-mode .content-funnel-card,
body.simplified-mode .pricing-calc-widget,
body.simplified-mode .roadmap-home-widget,
body.simplified-mode .gw-feedback-section,
body.simplified-mode .platform-placeholders,
body.simplified-mode .gw-tab[data-gwtab="paid"],
body.simplified-mode .gw-tab[data-gwtab="analytics"],
body.simplified-mode .content-funnel-card,
body.simplified-mode .da-pro-badge { display: none !important; }

/* ═══════════════════════════════════════════════════════════
   READY POSTS SECTION (Create page)
   ═══════════════════════════════════════════════════════════ */
.ready-posts-section {
  margin-bottom: var(--s4);
}
.ready-posts-grid {
  display: grid; grid-template-columns: 1fr; gap: var(--s3);
  margin-top: var(--s3);
}
@media (min-width: 600px) { .ready-posts-grid { grid-template-columns: repeat(3, 1fr); } }
.ready-post-card {
  background: var(--bg-elevated); border-radius: var(--r-md);
  padding: var(--s4); border: 1px solid var(--border-sm);
  transition: border-color 200ms cubic-bezier(0.32,0.72,0,1);
}
.ready-post-card:hover { border-color: var(--primary); }
[data-theme="light"] .ready-post-card { background: #fff; box-shadow: 0 1px 3px rgba(0,0,0,.06); }
.ready-post-card h4 { font-size: 13px; font-weight: 600; color: var(--text-1); margin-bottom: var(--s2); }
.ready-post-card p { font-size: 11px; color: var(--text-3); line-height: 1.5; margin-bottom: var(--s3);
  display: -webkit-box; -webkit-line-clamp: 3; -webkit-box-orient: vertical; overflow: hidden; }
.ready-post-copy-btn {
  display: inline-flex; align-items: center; gap: 4px;
  padding: 5px 12px; border-radius: var(--r-full);
  background: var(--primary); color: #fff;
  font-size: 11px; font-weight: 600; border: none; cursor: pointer;
  transition: filter 150ms;
}
.ready-post-copy-btn:hover { filter: brightness(1.1); }

/* ═══════════════════════════════════════════════════════════
   COACH MARKS
   ═══════════════════════════════════════════════════════════ */
.coach-mark {
  position: fixed; z-index: 9999;
  background: var(--primary); color: #fff;
  padding: 10px 16px; border-radius: var(--r-md);
  font-size: 12px; font-weight: 500; line-height: 1.4;
  max-width: 260px; box-shadow: 0 8px 32px rgba(0,0,0,.3);
  animation: cardStaggerIn 400ms cubic-bezier(0.32,0.72,0,1) both;
}
.coach-mark::after {
  content: ''; position: absolute; top: -6px; left: 24px;
  width: 12px; height: 12px; background: var(--primary);
  transform: rotate(45deg); border-radius: 2px;
}
.coach-mark-dismiss {
  display: inline-block; margin-top: 8px; padding: 4px 12px;
  background: rgba(255,255,255,.2); border-radius: var(--r-full);
  font-size: 11px; font-weight: 600; border: none; color: #fff;
  cursor: pointer;
}
.coach-mark-dismiss:hover { background: rgba(255,255,255,.3); }

/* ═══════════════════════════════════════════════════════════
   PROFESSIONAL FEATURES — Team, Multi-account, Analytics
   ═══════════════════════════════════════════════════════════ */

/* Team management */
.team-members-list { display: flex; flex-direction: column; gap: var(--s2); margin-top: var(--s3); }
.team-member-card {
  display: flex; align-items: center; gap: var(--s3);
  padding: var(--s3); border-radius: var(--r-md);
  background: var(--bg-elevated); border: 1px solid var(--border-sm);
}
.team-member-info { flex: 1; }
.team-member-name { font-size: 13px; font-weight: 600; color: var(--text-1); }
.team-member-role { font-size: 10px; color: var(--text-3); }
.team-role-badge {
  padding: 2px 8px; border-radius: var(--r-full);
  font-size: 9px; font-weight: 600;
}
.badge-admin { background: rgba(0,122,255,.12); color: var(--primary); }
.badge-editor { background: rgba(48,209,88,.12); color: #30D158; }
.badge-social { background: rgba(191,90,242,.12); color: #BF5AF2; }

/* Account switcher */
.account-switcher { padding: 8px; }
.account-switch-item {
  display: flex; align-items: center; gap: 8px;
  padding: 6px 8px; border-radius: var(--r-md);
  cursor: pointer;
}
.account-switch-item.active { background: rgba(0,122,255,.08); }
.account-switch-info { flex: 1; display: flex; align-items: center; justify-content: space-between; }
.account-switch-name { font-size: 12px; font-weight: 500; color: var(--text-1); }
.account-switch-check { font-size: 12px; color: var(--primary); font-weight: 700; }
.account-add-btn {
  display: flex; align-items: center; gap: 6px;
  width: 100%; padding: 6px 8px; border-radius: var(--r-md);
  background: none; border: 1px dashed var(--border-sm);
  color: var(--text-3); font-size: 11px; cursor: pointer;
  margin-top: 4px; transition: all 150ms;
}
.account-add-btn:hover { border-color: var(--primary); color: var(--primary); }

/* Integrations */
.integrations-grid { display: grid; grid-template-columns: 1fr; gap: var(--s2); margin-top: var(--s3); }
@media (min-width: 480px) { .integrations-grid { grid-template-columns: repeat(2, 1fr); } }
.integration-card {
  display: flex; align-items: center; gap: var(--s3);
  padding: var(--s3); border-radius: var(--r-md);
  background: var(--bg-elevated); border: 1px solid var(--border-sm);
  transition: border-color 200ms;
}
.integration-card:hover { border-color: var(--primary); }
.integration-icon { font-size: 24px; flex-shrink: 0; }
.integration-info { flex: 1; min-width: 0; }
.integration-name { font-size: 13px; font-weight: 600; color: var(--text-1); }
.integration-desc { font-size: 10px; color: var(--text-3); }
.integration-connect-btn {
  padding: 5px 12px; border-radius: var(--r-full);
  background: rgba(0,122,255,.1); color: var(--primary);
  border: none; font-size: 11px; font-weight: 600;
  cursor: pointer; flex-shrink: 0; transition: all 150ms;
}
.integration-connect-btn:hover { background: rgba(0,122,255,.2); }

/* Deep Analytics */
.deep-analytics-section { display: flex; flex-direction: column; gap: var(--s4); }
.da-card {
  background: var(--bg-elevated); border-radius: var(--r-lg);
  padding: var(--s5); border: 1px solid var(--border-sm);
}
[data-theme="light"] .da-card { background: #fff; box-shadow: 0 1px 3px rgba(0,0,0,.06); }
.da-header { display: flex; align-items: center; justify-content: space-between; margin-bottom: var(--s4); }
.da-header h4 { font-size: 14px; font-weight: 600; color: var(--text-1); margin: 0; }
.da-pro-badge {
  padding: 2px 8px; border-radius: var(--r-full);
  background: linear-gradient(135deg, #007AFF, #5856D6);
  color: #fff; font-size: 9px; font-weight: 700;
}
.da-table { display: flex; flex-direction: column; gap: 1px; }
.da-row {
  display: grid; grid-template-columns: 2fr 1fr 1fr;
  padding: 8px 0; font-size: 12px; color: var(--text-2);
  border-bottom: 1px solid var(--border-sm);
}
.da-row-header { font-weight: 600; color: var(--text-3); font-size: 10px; text-transform: uppercase; }
.da-row:last-child { border-bottom: none; }
.da-funnel-visual { display: flex; flex-direction: column; gap: 4px; }
.da-funnel-step {
  display: flex; justify-content: space-between;
  padding: 8px 12px; border-radius: var(--r-md);
  background: rgba(0,122,255,.08); font-size: 12px;
  color: var(--text-1); transition: width 600ms cubic-bezier(0.32,0.72,0,1);
}
.da-funnel-step span:last-child { font-weight: 700; color: var(--primary); }
.da-cohort-note {
  display: flex; align-items: flex-start; gap: var(--s3);
  padding: var(--s4); border-radius: var(--r-md);
  background: rgba(255,159,10,.06); border: 1px solid rgba(255,159,10,.15);
  font-size: 12px; color: var(--text-2); line-height: 1.5;
}
.da-cohort-note svg { flex-shrink: 0; color: #FF9F0A; margin-top: 2px; }

/* Generate report button */
.generate-report-btn {
  display: inline-flex; align-items: center; gap: 6px;
  font-size: 12px;
}

/* Growth page beginner welcome (simplified mode only) */
.gw-beginner-welcome { display: none; }
body.simplified-mode .gw-beginner-welcome { display: block !important; }

/* ─── DASHBOARD STATS STRIP ───────────────────────────── */
.dash-stats {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: var(--s3);
  margin-bottom: var(--s4);
}
.dash-stat {
  background: var(--bg-surface);
  border: 1px solid var(--border-sm);
  border-radius: var(--r-md);
  padding: var(--s4) var(--s3);
  text-align: center;
}
[data-theme="light"] .dash-stat {
  background: #fff;
  box-shadow: 0 1px 3px rgba(0,0,0,.06);
  border-color: rgba(0,0,0,.06);
}
.dash-stat-value {
  font-size: 22px;
  font-weight: 800;
  color: var(--text-1);
  font-family: var(--font-display);
  letter-spacing: -1px;
  line-height: 1;
  margin-bottom: 4px;
}
.dash-stat-label {
  font-size: 10px;
  color: var(--text-3);
  text-transform: uppercase;
  letter-spacing: .3px;
  font-weight: 500;
}

@media (max-width: 600px) {
  .dash-stats { grid-template-columns: repeat(2, 1fr); }
  .dash-stat-value { font-size: 20px; }
}

/* Trends tab always visible — even in simplified mode */

/* ─── CONTEUDO DO DIA CARD ────────────────────────────── */
.content-today-card {
  background: var(--bg-surface);
  border: 1px solid var(--border-sm);
  border-radius: var(--r-lg);
  padding: var(--s5) var(--s6);
  margin-bottom: var(--s4);
  position: relative;
  overflow: hidden;
}
[data-theme="light"] .content-today-card {
  background: #fff;
  box-shadow: 0 1px 3px rgba(0,0,0,.06), 0 0 1px rgba(0,0,0,.03);
  border-color: rgba(0,0,0,.06);
}
.ct-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: var(--s3);
}
.ct-badge {
  font-size: 10px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: .5px;
  color: var(--text-2);
  background: var(--bg-elevated);
  border: 1px solid var(--border-sm);
  padding: 3px 10px;
  border-radius: 20px;
}
.ct-time {
  font-size: 11px;
  color: var(--text-2);
  font-family: var(--font-mono);
}
.ct-title {
  font-size: 17px;
  font-weight: 700;
  color: var(--text-1);
  margin: 0 0 var(--s2);
  line-height: 1.35;
}
.ct-reason {
  font-size: 12.5px;
  color: var(--text-2);
  line-height: 1.55;
  margin: 0 0 var(--s4);
}
.ct-meta {
  display: flex;
  gap: var(--s3);
  margin-bottom: var(--s4);
  flex-wrap: wrap;
}

/* ─── AI SUGGESTION CARD ON CREATE PAGE ───────────────── */
.ai-suggestion-card {
  background: var(--bg-surface);
  border: 1px solid var(--border-sm);
  border-radius: var(--r-md);
  padding: var(--s4) var(--s5);
  margin-bottom: var(--s4);
}
[data-theme="light"] .ai-suggestion-card {
  background: #fff;
  box-shadow: 0 1px 3px rgba(0,0,0,.06);
  border-color: rgba(0,0,0,.06);
}
.ais-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: var(--s2);
}
.ais-badge {
  font-size: 10px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: .5px;
  color: var(--text-2);
  background: var(--bg-elevated);
  border: 1px solid var(--border-sm);
  padding: 3px 10px;
  border-radius: 20px;
}
.ais-dismiss {
  background: none;
  border: none;
  color: var(--text-3);
  font-size: 14px;
  cursor: pointer;
  padding: 4px;
}
.ais-content {
  font-size: 13px;
  color: var(--text-1);
  line-height: 1.5;
  margin-bottom: var(--s3);
  font-weight: 500;
}
.ais-use-btn {
  background: #1c1c1e;
  color: #fff;
  border: none;
  border-radius: var(--r-sm);
  padding: 8px 16px;
  font-size: 12px;
  font-weight: 600;
  cursor: pointer;
  font-family: var(--font-display);
}
[data-theme="dark"] .ais-use-btn {
  background: #f5f5f7;
  color: #1c1c1e;
}
.ais-use-btn:hover { opacity: .85; }
.ct-meta-tag {
  font-size: 10px;
  padding: 3px 8px;
  border-radius: 6px;
  background: var(--bg-elevated);
  color: var(--text-2);
  font-weight: 500;
  border: 1px solid var(--border-sm);
}
.ct-btn {
  width: 100%;
  padding: 12px;
  border: none;
  border-radius: var(--r-md);
  background: #1c1c1e;
  color: #fff;
  font-size: 14px;
  font-weight: 600;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  transition: opacity .2s, transform .1s;
  font-family: var(--font-display);
}
[data-theme="dark"] .ct-btn {
  background: #f5f5f7;
  color: #1c1c1e;
}
.ct-btn:hover { opacity: .85; }
.ct-btn:active { transform: scale(.98); }

@media (max-width: 600px) {
  .ct-title { font-size: 15px; }
  .ct-reason { font-size: 12px; }
}

/* ─── CONTENT LIFECYCLE STRIP (Home) ─────────────────── */
.content-lifecycle-strip {
  margin-bottom: var(--s4);
}
.cls-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: var(--s3);
}
.cls-title {
  font-size: 13px;
  font-weight: 600;
  color: var(--text-1);
}
.cls-see-all {
  background: none;
  border: none;
  font-size: 12px;
  color: var(--text-3);
  cursor: pointer;
  padding: 0;
  font-family: var(--font-body);
}
.cls-see-all:hover { color: var(--text-2); }
.cls-scroll {
  display: flex;
  gap: 10px;
  overflow-x: auto;
  padding-bottom: 4px;
  -ms-overflow-style: none;
  scrollbar-width: none;
}
.cls-scroll::-webkit-scrollbar { display: none; }
.cls-card {
  min-width: 150px;
  max-width: 180px;
  background: var(--bg-surface);
  border: 1px solid var(--border-sm);
  border-radius: var(--r-md);
  padding: 12px;
  cursor: pointer;
  transition: border-color .15s;
  flex-shrink: 0;
}
[data-theme="light"] .cls-card {
  background: #fff;
  box-shadow: 0 1px 2px rgba(0,0,0,.05);
  border-color: rgba(0,0,0,.06);
}
.cls-card:hover { border-color: var(--text-3); }
.cls-card-status {
  display: flex;
  align-items: center;
  gap: 6px;
  margin-bottom: 8px;
}
.cls-dot {
  width: 6px;
  height: 6px;
  border-radius: 50%;
  flex-shrink: 0;
}
.cls-status-label {
  font-size: 10px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: .3px;
  color: var(--text-3);
}
.cls-card-title {
  font-size: 12px;
  font-weight: 500;
  color: var(--text-1);
  line-height: 1.4;
  margin-bottom: 6px;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}
.cls-card-date {
  font-size: 10px;
  color: var(--text-3);
}

/* ─── AUTO-FILL WEEK BUTTON (Planner) ────────────────── */
.autofill-week-btn {
  background: none;
  border: 1px solid var(--border-sm);
  border-radius: var(--r-sm);
  padding: 6px 14px;
  font-size: 12px;
  font-weight: 500;
  color: var(--text-2);
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  gap: 6px;
  transition: all .15s;
  font-family: var(--font-body);
}
.autofill-week-btn:hover {
  border-color: var(--text-3);
  color: var(--text-1);
}
[data-theme="light"] .autofill-week-btn:hover {
  background: rgba(0,0,0,.02);
}

/* ═══════════════════════════════════════════════════════════
   MORNING BRIEFING CARD
   ═══════════════════════════════════════════════════════════ */
.morning-briefing {
  background: var(--bg-surface);
  border: 1px solid var(--border-sm);
  border-radius: var(--r-lg);
  padding: 14px 16px;
  margin-bottom: var(--s3);
}
[data-theme="light"] .morning-briefing {
  background: #fff;
  box-shadow: 0 1px 3px rgba(0,0,0,.06);
}
.mb-line {
  line-height: 1.45;
}
.mb-line-1 {
  font-size: 14px;
  font-weight: 700;
  color: var(--text-1);
  letter-spacing: -0.01em;
}
.mb-line-2 {
  font-size: 12px;
  color: var(--text-2);
  margin-top: 3px;
}
.mb-line-3 {
  font-size: 11px;
  color: var(--text-3);
  margin-top: 2px;
}
.mb-line-3 .mb-accent {
  color: var(--text-2);
  font-weight: 600;
}

/* ═══════════════════════════════════════════════════════════
   WEEKLY CONSISTENCY SCORE
   ═══════════════════════════════════════════════════════════ */
.weekly-score {
  display: flex;
  align-items: center;
  gap: 12px;
  background: var(--bg-surface);
  border: 1px solid var(--border-sm);
  border-radius: var(--r-lg);
  padding: 12px 16px;
  margin-bottom: var(--s4);
}
[data-theme="light"] .weekly-score {
  background: #fff;
  box-shadow: 0 1px 3px rgba(0,0,0,.06);
}
.ws-ring-wrap {
  position: relative;
  width: 44px;
  height: 44px;
  flex-shrink: 0;
}
.ws-ring {
  width: 44px;
  height: 44px;
  transform: rotate(-90deg);
}
.ws-ring-bg {
  stroke: var(--border-sm);
}
.ws-ring-fill {
  stroke: var(--text-1);
  transition: stroke-dasharray .5s ease;
}
.ws-ring-value {
  position: absolute;
  inset: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 11px;
  font-weight: 700;
  color: var(--text-1);
  font-family: var(--font-display);
  letter-spacing: -0.5px;
}
.ws-text {
  display: flex;
  flex-direction: column;
  gap: 2px;
  min-width: 0;
}
.ws-label {
  font-size: 13px;
  font-weight: 600;
  color: var(--text-1);
}
.ws-nudge {
  font-size: 11px;
  color: var(--text-3);
  line-height: 1.35;
}
.ws-nudge:empty {
  display: none;
}
.ws-dot {
  display: inline-block;
  width: 5px;
  height: 5px;
  border-radius: 50%;
  background: var(--text-3);
  margin-right: 4px;
  vertical-align: middle;
}
.ws-dot--active {
  background: var(--text-1);
}

/* ═══════════════════════════════════════════════════════════
   FLOATING "PUBLIQUEI" BUTTON
   ═══════════════════════════════════════════════════════════ */
.publiquei-float {
  position: fixed;
  bottom: 80px;
  left: 50%;
  transform: translateX(-50%) translateY(30px);
  z-index: 9999;
  opacity: 0;
  pointer-events: none;
  transition: opacity .35s ease, transform .35s cubic-bezier(.4,.0,.2,1);
}
.publiquei-float--visible {
  opacity: 1;
  transform: translateX(-50%) translateY(0);
  pointer-events: auto;
}
.publiquei-btn {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 12px 28px;
  border: none;
  border-radius: 999px;
  font-family: var(--font-body);
  font-size: 15px;
  font-weight: 700;
  letter-spacing: 0.02em;
  cursor: pointer;
  background: #1c1c1e;
  color: #f5f5f7;
  box-shadow: 0 4px 24px rgba(0,0,0,.25), 0 1px 4px rgba(0,0,0,.15);
  transition: transform .15s ease, box-shadow .15s ease;
  -webkit-tap-highlight-color: transparent;
}
.publiquei-btn:hover {
  transform: scale(1.04);
  box-shadow: 0 6px 28px rgba(0,0,0,.3), 0 2px 6px rgba(0,0,0,.18);
}
.publiquei-btn:active {
  transform: scale(0.97);
}
.publiquei-btn svg {
  flex-shrink: 0;
}
[data-theme="dark"] .publiquei-btn {
  background: #f5f5f7;
  color: #1c1c1e;
  box-shadow: 0 4px 24px rgba(255,255,255,.1), 0 1px 4px rgba(0,0,0,.3);
}
[data-theme="dark"] .publiquei-btn:hover {
  box-shadow: 0 6px 28px rgba(255,255,255,.14), 0 2px 6px rgba(0,0,0,.35);
}

/* ─── SHARE GROWTH CARD ─── */
.gc-share-growth-bar {
  margin-top: 12px;
  padding-top: 12px;
  border-top: 1px solid var(--border-xs);
}
.gc-share-growth-btn {
  width: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  background: var(--bg-elevated);
  color: var(--text-2);
  border: 1px solid var(--border-sm);
  font-weight: 600;
  font-size: 13px;
  padding: 10px 16px;
  border-radius: 10px;
  cursor: pointer;
  transition: all .2s ease;
  font-family: var(--font-body);
}
[data-theme="light"] .gc-share-growth-btn {
  background: #f5f5f7;
  border-color: rgba(0,0,0,.08);
}
.gc-share-growth-btn:hover {
  color: var(--text-1);
  border-color: var(--text-3);
}
.gc-share-growth-btn:active {
  transform: translateY(0);
}
.gc-share-growth-btn svg {
  flex-shrink: 0;
  opacity: .8;
}

/* ═══════════════════════════════════════════════════════════
   AI INTELLIGENCE CARD
   ═══════════════════════════════════════════════════════════ */
.ai-intelligence-card {
  background: var(--bg-surface);
  border: 1px solid var(--border-sm);
  border-radius: var(--r-lg);
  padding: var(--s4) var(--s5);
  margin-bottom: var(--s4);
}
[data-theme="light"] .ai-intelligence-card {
  background: #fff;
  box-shadow: 0 1px 3px rgba(0,0,0,.06), 0 0 1px rgba(0,0,0,.04);
}

.aic-header {
  display: flex;
  align-items: center;
  gap: 8px;
  margin-bottom: 12px;
}
.aic-icon {
  color: var(--text-3);
  flex-shrink: 0;
}
.aic-title {
  font-family: var(--font-body);
  font-size: 13px;
  font-weight: 600;
  color: var(--text-2);
  letter-spacing: 0.01em;
}

.aic-list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 8px;
}
.aic-item {
  font-family: var(--font-body);
  font-size: 13px;
  line-height: 1.5;
  color: var(--text-1);
  padding-left: 16px;
  position: relative;
}
.aic-item::before {
  content: '';
  position: absolute;
  left: 0;
  top: 7px;
  width: 5px;
  height: 5px;
  border-radius: 50%;
  background: var(--primary);
  opacity: 0.6;
}
.aic-item:nth-child(2)::before { background: var(--secondary); }
.aic-item:nth-child(3)::before { background: var(--cta); }
.aic-item:nth-child(4)::before { background: var(--accent); }

/* ═══════════════════════════════════════════════════════════
   FIRST CONTENT CARD
   ═══════════════════════════════════════════════════════════ */
.first-content-card {
  background: var(--bg-elevated);
  border: 1px solid var(--border-sm);
  border-radius: var(--r-lg);
  padding: var(--s5) var(--s5) var(--s4);
  margin-bottom: var(--s4);
  position: relative;
  box-shadow: 0 2px 8px rgba(0,0,0,.10);
}
[data-theme="light"] .first-content-card {
  background: #fff;
  box-shadow: 0 2px 12px rgba(0,0,0,.08), 0 0 1px rgba(0,0,0,.04);
}

.fc-top-label {
  font-family: var(--font-body);
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--primary);
  margin-bottom: 8px;
}

.fc-title {
  font-family: var(--font-display);
  font-size: 17px;
  font-weight: 700;
  line-height: 1.35;
  color: var(--text-1);
  margin: 0 0 6px;
}

.fc-subtitle {
  font-family: var(--font-body);
  font-size: 13px;
  color: var(--text-2);
  line-height: 1.5;
  margin: 0 0 16px;
}

.fc-cta-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 10px 24px;
  border: none;
  border-radius: var(--r-full);
  font-family: var(--font-body);
  font-size: 14px;
  font-weight: 700;
  letter-spacing: 0.01em;
  cursor: pointer;
  background: #1c1c1e;
  color: #f5f5f7;
  transition: transform 0.15s ease, box-shadow 0.15s ease;
  -webkit-tap-highlight-color: transparent;
}
.fc-cta-btn:hover {
  transform: scale(1.03);
  box-shadow: 0 4px 16px rgba(0,0,0,.18);
}
.fc-cta-btn:active {
  transform: scale(0.97);
}
[data-theme="dark"] .fc-cta-btn {
  background: #f5f5f7;
  color: #1c1c1e;
}
[data-theme="dark"] .fc-cta-btn:hover {
  box-shadow: 0 4px 16px rgba(255,255,255,.10);
}

.fc-niche-note {
  display: block;
  margin-top: 12px;
  font-family: var(--font-body);
  font-size: 11px;
  color: var(--text-3);
  letter-spacing: 0.01em;
}

/* ═══════════════════════════════════════════════════════════
   CONTENT RECYCLER CARD
   ═══════════════════════════════════════════════════════════ */
.content-recycler {
  background: var(--bg-surface);
  border: 1px solid var(--border-sm);
  border-radius: var(--r-lg);
  padding: var(--s4) var(--s5);
  margin-bottom: var(--s4);
}
[data-theme="light"] .content-recycler {
  background: #fff;
  box-shadow: 0 1px 3px rgba(0,0,0,.06), 0 0 1px rgba(0,0,0,.04);
  border-color: rgba(0,0,0,.06);
}
.cr-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 12px;
}
.cr-header-left {
  display: flex;
  align-items: center;
  gap: 8px;
}
.cr-icon {
  color: var(--text-3);
  flex-shrink: 0;
}
.cr-title {
  font-size: 13px;
  font-weight: 600;
  color: var(--text-1);
}
.cr-dismiss {
  background: none;
  border: none;
  color: var(--text-3);
  font-size: 16px;
  cursor: pointer;
  padding: 4px;
  line-height: 1;
}
.cr-dismiss:hover { color: var(--text-2); }
.cr-content-title {
  font-size: 14px;
  font-weight: 600;
  color: var(--text-1);
  line-height: 1.4;
  margin-bottom: 8px;
}
.cr-meta {
  display: flex;
  gap: 6px;
  flex-wrap: wrap;
  margin-bottom: 8px;
}
.cr-meta-tag {
  font-size: 10px;
  padding: 2px 8px;
  border-radius: 6px;
  background: var(--bg-elevated);
  color: var(--text-3);
  font-weight: 500;
  border: 1px solid var(--border-xs);
}
[data-theme="light"] .cr-meta-tag {
  background: #f5f5f7;
  border-color: rgba(0,0,0,.05);
}
.cr-reason {
  font-size: 12px;
  color: var(--text-2);
  line-height: 1.5;
  margin-bottom: 12px;
}
.cr-action-btn {
  background: #1c1c1e;
  color: #fff;
  border: none;
  border-radius: var(--r-sm);
  padding: 8px 16px;
  font-size: 12px;
  font-weight: 600;
  cursor: pointer;
  font-family: var(--font-display);
  transition: opacity .15s;
}
[data-theme="dark"] .cr-action-btn {
  background: #f5f5f7;
  color: #1c1c1e;
}
.cr-action-btn:hover { opacity: .85; }
.cr-more {
  margin-top: 10px;
  padding-top: 10px;
  border-top: 1px solid var(--border-xs);
  font-size: 11px;
  color: var(--text-3);
}

/* ═══════════════════════════════════════════════════════════
   CLIENT MANAGEMENT + REVENUE TRACKING
   ═══════════════════════════════════════════════════════════ */

/* ─── Revenue Panel (Home Widget) ─── */
.revenue-panel {
  background: var(--bg-surface);
  border: 1px solid var(--border-sm);
  border-radius: var(--r-lg);
  padding: var(--s4) var(--s5);
  margin-bottom: var(--s4);
  cursor: pointer;
  transition: transform var(--ease-fast), box-shadow var(--ease-fast);
}
.revenue-panel:active {
  transform: scale(0.98);
}
[data-theme="light"] .revenue-panel {
  background: #fff;
  box-shadow: 0 1px 3px rgba(0,0,0,.06);
}
.rp-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: var(--s3);
}
.rp-title-row {
  display: flex;
  align-items: center;
  gap: 6px;
  font-size: 11px;
  font-weight: 700;
  color: var(--text-3);
  text-transform: none;
  letter-spacing: 0;
}
.rp-mrr {
  font-size: 28px;
  font-weight: 700;
  color: #30D158;
  line-height: 1.1;
}
.rp-stats {
  display: flex;
  align-items: center;
  gap: var(--s4);
  margin-top: var(--s2);
}
.rp-stat {
  display: flex;
  flex-direction: column;
  gap: 1px;
}
.rp-stat-value {
  font-size: 14px;
  font-weight: 700;
  color: var(--text-1);
}
.rp-stat-label {
  font-size: 10px;
  color: var(--text-3);
  font-weight: 500;
}
.rp-trend {
  display: inline-flex;
  align-items: center;
  gap: 3px;
  font-size: 11px;
  font-weight: 600;
  margin-left: 6px;
}
.rp-trend.up { color: #30D158; }
.rp-trend.down { color: #FF453A; }
.rp-trend.neutral { color: var(--text-3); }
.rp-empty {
  font-size: 12px;
  color: var(--text-3);
  line-height: 1.5;
}
.rp-empty-cta {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  margin-top: 8px;
  font-size: 12px;
  font-weight: 600;
  color: #30D158;
}
.rp-tap-hint {
  font-size: 10px;
  color: var(--text-3);
  margin-top: 8px;
  opacity: 0.6;
}

/* ─── Client Modal Summary Stats ─── */
.cm-summary {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: var(--s3);
  padding: var(--s4) var(--s5);
  border-bottom: 1px solid var(--border-xs);
}
@media (max-width: 500px) {
  .cm-summary {
    grid-template-columns: repeat(2, 1fr);
  }
}
.cm-stat {
  display: flex;
  flex-direction: column;
  gap: 2px;
}
.cm-stat-value {
  font-size: 18px;
  font-weight: 700;
  color: var(--text-1);
}
.cm-stat-value.green { color: #30D158; }
.cm-stat-label {
  font-size: 10px;
  color: var(--text-3);
  font-weight: 500;
  text-transform: none;
}

/* ─── Client List ─── */
.cm-list {
  padding: var(--s3) var(--s5);
}
.cm-client-card {
  display: flex;
  align-items: center;
  gap: var(--s3);
  padding: var(--s3) var(--s4);
  background: var(--bg-surface);
  border: 1px solid var(--border-sm);
  border-radius: var(--r-md);
  margin-bottom: var(--s2);
  cursor: pointer;
  transition: background var(--ease-fast), transform var(--ease-fast);
}
.cm-client-card:hover {
  background: var(--bg-hover);
}
.cm-client-card:active {
  transform: scale(0.98);
}
[data-theme="light"] .cm-client-card {
  background: #fff;
  box-shadow: 0 1px 3px rgba(0,0,0,.06);
}
[data-theme="light"] .cm-client-card:hover {
  background: #f8fafc;
}
.cm-avatar {
  width: 36px;
  height: 36px;
  border-radius: 50%;
  background: var(--bg-elevated);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 14px;
  font-weight: 700;
  color: var(--text-2);
  flex-shrink: 0;
}
.cm-client-info {
  flex: 1;
  min-width: 0;
}
.cm-client-name {
  font-size: 13px;
  font-weight: 600;
  color: var(--text-1);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.cm-client-meta {
  display: flex;
  align-items: center;
  gap: 8px;
  margin-top: 2px;
  font-size: 11px;
  color: var(--text-3);
}
.cm-client-value {
  font-size: 14px;
  font-weight: 700;
  color: var(--text-1);
  white-space: nowrap;
}

/* ─── Status Badges ─── */
.cm-status {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  font-size: 10px;
  font-weight: 600;
  padding: 2px 8px;
  border-radius: var(--r-full);
  white-space: nowrap;
}
.cm-status-dot {
  width: 6px;
  height: 6px;
  border-radius: 50%;
  flex-shrink: 0;
}
.cm-status.ativo { background: rgba(48,209,88,.12); color: #30D158; }
.cm-status.ativo .cm-status-dot { background: #30D158; }
.cm-status.pausado { background: rgba(255,214,10,.12); color: #FFD60A; }
.cm-status.pausado .cm-status-dot { background: #FFD60A; }
.cm-status.encerrado { background: rgba(255,69,58,.12); color: #FF453A; }
.cm-status.encerrado .cm-status-dot { background: #FF453A; }

/* ─── Client Form Fields ─── */
.cf-source-content {
  display: none;
}
.cf-source-content.visible {
  display: block;
}

/* ─── Client Detail ─── */
.cd-header {
  display: flex;
  align-items: center;
  gap: var(--s3);
  margin-bottom: var(--s4);
}
.cd-avatar {
  width: 48px;
  height: 48px;
  border-radius: 50%;
  background: var(--bg-elevated);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 18px;
  font-weight: 700;
  color: var(--text-2);
  flex-shrink: 0;
}
.cd-name {
  font-size: 16px;
  font-weight: 700;
  color: var(--text-1);
}
.cd-since {
  font-size: 11px;
  color: var(--text-3);
  margin-top: 2px;
}
.cd-stats {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--s3);
  margin-bottom: var(--s4);
}
.cd-stat {
  background: var(--bg-surface);
  border: 1px solid var(--border-xs);
  border-radius: var(--r-md);
  padding: var(--s3);
  text-align: center;
}
[data-theme="light"] .cd-stat {
  background: #f8fafc;
}
.cd-stat-value {
  font-size: 16px;
  font-weight: 700;
  color: var(--text-1);
}
.cd-stat-label {
  font-size: 10px;
  color: var(--text-3);
  margin-top: 2px;
}
.cd-section {
  margin-bottom: var(--s4);
}
.cd-section-title {
  font-size: 11px;
  font-weight: 700;
  color: var(--text-3);
  margin-bottom: var(--s2);
}
.cd-notes {
  font-size: 12px;
  color: var(--text-2);
  line-height: 1.5;
  white-space: pre-wrap;
}
.cd-actions {
  display: flex;
  gap: var(--s2);
  margin-top: var(--s4);
  padding-top: var(--s4);
  border-top: 1px solid var(--border-xs);
}
.cd-btn {
  flex: 1;
  padding: 10px;
  border: none;
  border-radius: var(--r-md);
  font-size: 12px;
  font-weight: 600;
  cursor: pointer;
  font-family: var(--font-display);
  transition: opacity var(--ease-fast);
}
.cd-btn:hover { opacity: 0.85; }
.cd-btn-edit {
  background: #1c1c1e;
  color: #fff;
}
[data-theme="dark"] .cd-btn-edit {
  background: #f5f5f7;
  color: #1c1c1e;
}
.cd-btn-delete {
  background: rgba(255,69,58,.12);
  color: #FF453A;
}

/* ─── Empty state for client list ─── */
.cm-empty {
  padding: var(--s8) var(--s5);
  text-align: center;
}
.cm-empty-icon {
  font-size: 36px;
  margin-bottom: var(--s3);
  opacity: 0.4;
}
.cm-empty-text {
  font-size: 14px;
  font-weight: 600;
  color: var(--text-2);
  margin-bottom: var(--s2);
}
.cm-empty-sub {
  font-size: 12px;
  color: var(--text-3);
  margin-bottom: var(--s4);
}
.cm-empty-btn {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  background: rgba(48,209,88,.12);
  color: #30D158;
  border: 1px solid rgba(48,209,88,.25);
  border-radius: var(--r-md);
  padding: 10px 20px;
  font-size: 13px;
  font-weight: 600;
  cursor: pointer;
  font-family: var(--font-display);
  transition: opacity var(--ease-fast);
}
.cm-empty-btn:hover { opacity: 0.85; }

/* ─── Client filter tabs ─── */
.cm-filters {
  display: flex;
  gap: var(--s1);
  padding: var(--s3) var(--s5);
  border-bottom: 1px solid var(--border-xs);
  overflow-x: auto;
}
.cm-filter-btn {
  padding: 4px 12px;
  border-radius: var(--r-full);
  font-size: 11px;
  font-weight: 600;
  border: 1px solid var(--border-sm);
  background: transparent;
  color: var(--text-2);
  cursor: pointer;
  white-space: nowrap;
  transition: all var(--ease-fast);
  font-family: var(--font-display);
}
.cm-filter-btn.active {
  background: var(--text-1);
  color: var(--bg-base);
  border-color: var(--text-1);
}
[data-theme="light"] .cm-filter-btn.active {
  background: #1c1c1e;
  color: #fff;
  border-color: #1c1c1e;
}

/* ═══════════════════════════════════════════════════════════
   WHATSAPP TEMPLATES
   ═══════════════════════════════════════════════════════════ */
.wa-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(320px, 1fr));
  gap: var(--s3);
}
.wa-card {
  background: var(--bg-surface);
  border: 1px solid var(--border-sm);
  border-radius: var(--r-lg);
  padding: var(--s4);
  transition: border-color .2s, box-shadow .2s;
}
[data-theme="light"] .wa-card {
  background: #fff;
  box-shadow: 0 1px 3px rgba(0,0,0,.06);
}
.wa-card:hover {
  border-color: #25D366;
  box-shadow: 0 4px 12px rgba(37,211,102,.1);
}
.wa-card-header {
  display: flex;
  align-items: center;
  gap: var(--s2);
  margin-bottom: var(--s3);
}
.wa-card-badge {
  font-size: 9px;
  font-weight: 700;
  letter-spacing: .5px;
  text-transform: uppercase;
  padding: 3px 8px;
  border-radius: 6px;
  flex-shrink: 0;
}
.wa-card-desc {
  font-size: 11px;
  color: var(--text-3);
  margin-left: auto;
}
.wa-card-text {
  font-size: 13px;
  color: var(--text-2);
  line-height: 1.65;
  white-space: pre-line;
  font-family: inherit;
  background: var(--bg-elevated);
  border-radius: var(--r-sm);
  padding: var(--s3);
  margin: 0 0 var(--s3);
  border: 1px solid var(--border-sm);
}
.wa-card-note {
  font-size: 10px;
  color: var(--text-3);
  margin-bottom: var(--s3);
  font-style: italic;
}
.wa-card-actions {
  display: flex;
  align-items: center;
  gap: var(--s2);
}
.wa-copy-btn {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  background: #1c1c1e;
  color: #fff;
  border: none;
  border-radius: var(--r-sm);
  padding: 8px 16px;
  font-size: 12px;
  font-weight: 600;
  cursor: pointer;
  font-family: var(--font-display);
  transition: opacity .15s;
}
[data-theme="dark"] .wa-copy-btn {
  background: #f5f5f7;
  color: #1c1c1e;
}
.wa-copy-btn:hover { opacity: .85; }
.wa-copy-btn svg { flex-shrink: 0; }

/* ══════════════════════════════════════════════════���════════
   VOICE DNA CARD
   ═══════════════════════════════════════════════════════════ */
.vdna-card {
  background: var(--bg-surface);
  border: 1px solid var(--border-sm);
  border-radius: var(--r-lg);
  padding: var(--s4);
  margin-bottom: var(--s4);
}
[data-theme="light"] .vdna-card {
  background: #fff;
  box-shadow: 0 1px 3px rgba(0,0,0,.06);
}
.vdna-header {
  display: flex;
  align-items: center;
  gap: var(--s2);
  margin-bottom: var(--s3);
}
.vdna-icon {
  width: 28px;
  height: 28px;
  border-radius: var(--r-sm);
  background: rgba(99,102,241,.12);
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}
.vdna-title {
  font-size: 13px;
  font-weight: 700;
  color: var(--text-1);
}
.vdna-subtitle {
  font-size: 10px;
  color: var(--text-3);
}
.vdna-stats {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--s2);
}
.vdna-stat {
  background: var(--bg-elevated);
  border-radius: var(--r-sm);
  padding: 8px 10px;
  border: 1px solid var(--border-xs);
}
.vdna-stat-label {
  font-size: 10px;
  color: var(--text-3);
  margin-bottom: 2px;
}
.vdna-stat-value {
  font-size: 12px;
  font-weight: 600;
  color: var(--text-1);
}
.vdna-words {
  display: flex;
  flex-wrap: wrap;
  gap: 4px;
  margin-top: var(--s2);
}
.vdna-word {
  font-size: 10px;
  padding: 2px 8px;
  border-radius: var(--r-full);
  background: rgba(99,102,241,.1);
  color: #6366F1;
  font-weight: 500;
}
.vdna-progress {
  margin-top: var(--s3);
}
.vdna-progress-bar {
  height: 4px;
  background: var(--bg-elevated);
  border-radius: 2px;
  overflow: hidden;
}
.vdna-progress-fill {
  height: 100%;
  background: #6366F1;
  border-radius: 2px;
  transition: width .3s;
}
.vdna-progress-label {
  font-size: 10px;
  color: var(--text-3);
  margin-top: 4px;
  display: flex;
  justify-content: space-between;
}

/* ═══════════════════════════════════════════════════════════
   ENHANCED FUNNEL — Revenue Attribution Row
   ═══════════════════════════════════════════════════════════ */
.funnel-revenue-row {
  margin-top: var(--s3);
}
.funnel-revenue-divider {
  height: 1px;
  background: var(--border-sm);
  margin-bottom: var(--s3);
}
.funnel-revenue-data {
  display: flex;
  flex-direction: column;
  gap: 6px;
}
.funnel-revenue-item {
  display: flex;
  justify-content: space-between;
  align-items: center;
}
.funnel-revenue-label {
  font-size: 11px;
  color: var(--text-3);
}
.funnel-revenue-val {
  font-size: 12px;
  font-weight: 600;
  color: var(--text-1);
}
.funnel-revenue-highlight {
  font-size: 14px;
  font-weight: 700;
}

/* ═══════════════════════════════════════════════════════════
   WEEKLY BUSINESS REPORT
   ═══════════════════════════════════════════════════════════ */
.weekly-biz-report {
  background: var(--bg-surface);
  border: 1px solid var(--border-sm);
  border-radius: var(--r-lg);
  padding: var(--s4);
  margin-bottom: var(--s3);
}
.wbr-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: var(--s3);
}
.wbr-header-left {
  display: flex;
  align-items: center;
  gap: var(--s2);
}
.wbr-icon {
  color: var(--text-2);
}
.wbr-title {
  font-size: 13px;
  font-weight: 700;
  color: var(--text-1);
}
.wbr-date {
  font-size: 10px;
  color: var(--text-3);
  font-weight: 500;
}
.wbr-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--s2);
  margin-bottom: var(--s3);
}
.wbr-metric {
  background: var(--bg-elevated);
  border-radius: var(--r-sm);
  padding: 10px 12px;
  border: 1px solid var(--border-xs);
}
.wbr-metric-wide {
  grid-column: span 2;
}
.wbr-metric-val {
  font-size: 18px;
  font-weight: 700;
  color: var(--text-1);
  line-height: 1.2;
}
.wbr-metric-label {
  font-size: 10px;
  color: var(--text-3);
  margin-top: 2px;
}
.wbr-recommendation {
  background: var(--bg-elevated);
  border-radius: var(--r-sm);
  padding: 10px 12px;
  border: 1px solid var(--border-xs);
}
.wbr-rec-label {
  font-size: 9px;
  font-weight: 700;
  letter-spacing: 0.05em;
  color: var(--text-3);
  margin-bottom: 4px;
}
.wbr-rec-text {
  font-size: 12px;
  color: var(--text-2);
  line-height: 1.5;
}
[data-theme="light"] .weekly-biz-report {
  background: #fff;
  box-shadow: 0 1px 3px rgba(0,0,0,.06);
}

/* ═══════════════════════════════════════════════════════════
   SERIES NAVIGATION
   ═══════════════════════════════════════════════════════════ */
.series-nav {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 10px 16px;
  background: var(--bg-elevated);
  border-bottom: 1px solid var(--border-sm);
  border-radius: var(--r-lg) var(--r-lg) 0 0;
}
.series-nav-btn {
  font-size: 12px;
  font-weight: 600;
  color: var(--text-1);
  background: var(--bg-surface);
  border: 1px solid var(--border-sm);
  border-radius: var(--r-md);
  padding: 6px 14px;
  cursor: pointer;
  transition: opacity .2s;
}
.series-nav-btn:disabled {
  opacity: 0.3;
  cursor: default;
}
.series-nav-indicator {
  font-size: 13px;
  font-weight: 700;
  color: var(--text-1);
}
[data-theme="light"] .series-nav {
  background: #f5f5f7;
}

/* ═══════════════════════════════════════════════════════════
   ACCUMULATED VALUE CARD
   ═══════════════════════════════════════════════════════════ */
.accumulated-value-card {
  background: var(--bg-surface);
  border: 1px solid var(--border-sm);
  border-radius: var(--r-lg);
  padding: 14px 16px;
}
.av-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 12px;
}
.av-header-left {
  display: flex;
  align-items: center;
  gap: 8px;
  color: var(--text-2);
}
.av-title {
  font-size: 13px;
  font-weight: 600;
  color: var(--text-1);
}
.av-stats {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(140px, 1fr));
  gap: 8px;
}
.av-stat {
  display: flex;
  align-items: center;
  gap: 6px;
  padding: 8px 10px;
  background: var(--bg-elevated);
  border-radius: var(--r-md);
  font-size: 12px;
}
.av-stat-icon {
  color: var(--text-3);
  font-size: 10px;
  flex-shrink: 0;
}
.av-stat-val {
  font-weight: 700;
  color: var(--text-1);
  white-space: nowrap;
}
.av-stat-label {
  color: var(--text-3);
  font-size: 11px;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
[data-theme="light"] .accumulated-value-card {
  background: #fff;
  box-shadow: 0 1px 3px rgba(0,0,0,.06);
}

/* ═══════════════════════════════════════════════════════════
   VOICE PROFILE CARD
   ═══════════════════════════════════════════════════════════ */
.voice-profile-card {
  background: var(--bg-surface);
  border: 1px solid var(--border-sm);
  border-radius: var(--r-lg);
  padding: 14px 16px;
}
.vp-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 12px;
}
.vp-header-left {
  display: flex;
  align-items: center;
  gap: 8px;
  color: var(--text-2);
}
.vp-title {
  font-size: 13px;
  font-weight: 600;
  color: var(--text-1);
}
.vp-status {
  font-size: 10px;
  font-weight: 600;
  letter-spacing: 0.5px;
  padding: 3px 8px;
  border-radius: 20px;
}
.vp-active {
  color: #30D158;
  background: rgba(48,209,88,.1);
}
.vp-learning {
  color: var(--text-3);
  background: var(--bg-elevated);
}
.vp-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 8px;
  margin-bottom: 10px;
}
.vp-item {
  padding: 8px 10px;
  background: var(--bg-elevated);
  border-radius: var(--r-md);
}
.vp-item-label {
  font-size: 10px;
  color: var(--text-3);
  margin-bottom: 2px;
}
.vp-item-value {
  font-size: 13px;
  font-weight: 600;
  color: var(--text-1);
}
.vp-section {
  margin-top: 8px;
}
.vp-section-label {
  font-size: 10px;
  color: var(--text-3);
  margin-bottom: 6px;
}
.vp-words {
  display: flex;
  flex-wrap: wrap;
  gap: 4px;
}
.vp-word {
  font-size: 11px;
  padding: 3px 8px;
  background: var(--bg-elevated);
  border-radius: 12px;
  color: var(--text-2);
}
.vp-ctas {
  display: flex;
  flex-direction: column;
  gap: 4px;
}
.vp-cta {
  font-size: 11px;
  color: var(--text-2);
  font-style: italic;
}
.vp-progress {
  margin-top: 10px;
}
.vp-progress-bar {
  height: 3px;
  background: var(--bg-elevated);
  border-radius: 2px;
  overflow: hidden;
}
.vp-progress-fill {
  height: 100%;
  background: var(--text-3);
  border-radius: 2px;
  transition: width .6s ease;
}
.vp-progress-label {
  font-size: 10px;
  color: var(--text-3);
  margin-top: 4px;
}
[data-theme="light"] .voice-profile-card {
  background: #fff;
  box-shadow: 0 1px 3px rgba(0,0,0,.06);
}

/* ═══════════════════════════════════════════════════════════
   MONTHLY PULSE CARD
   ═══════════════════════════════════════════════════════════ */
.monthly-pulse-card {
  background: var(--bg-surface);
  border: 1px solid var(--border-sm);
  border-radius: var(--r-lg);
  padding: 14px 16px;
}
.mp-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 12px;
}
.mp-header-left {
  display: flex;
  align-items: center;
  gap: 8px;
  color: var(--text-2);
}
.mp-title {
  font-size: 13px;
  font-weight: 600;
  color: var(--text-1);
}
.mp-delta {
  font-size: 11px;
  font-weight: 600;
  padding: 2px 8px;
  border-radius: 12px;
}
.mp-delta-up {
  color: #30D158;
  background: rgba(48,209,88,.1);
}
.mp-delta-down {
  color: #FF453A;
  background: rgba(255,69,58,.1);
}
.mp-stats {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 6px;
  margin-bottom: 10px;
}
.mp-stat {
  text-align: center;
  padding: 8px 4px;
  background: var(--bg-elevated);
  border-radius: var(--r-md);
}
.mp-stat-val {
  font-size: 18px;
  font-weight: 700;
  color: var(--text-1);
  line-height: 1.2;
}
.mp-stat-label {
  font-size: 10px;
  color: var(--text-3);
  margin-top: 2px;
}
.mp-details {
  display: flex;
  gap: 12px;
  margin-bottom: 10px;
}
.mp-detail {
  display: flex;
  align-items: center;
  gap: 6px;
  font-size: 11px;
}
.mp-detail-label {
  color: var(--text-3);
}
.mp-detail-val {
  color: var(--text-1);
  font-weight: 600;
}
.mp-narrative {
  font-size: 12px;
  color: var(--text-2);
  line-height: 1.5;
  padding: 8px 10px;
  background: var(--bg-elevated);
  border-radius: var(--r-md);
  border-left: 3px solid var(--text-3);
}
[data-theme="light"] .monthly-pulse-card {
  background: #fff;
  box-shadow: 0 1px 3px rgba(0,0,0,.06);
}

/* ═══════════════════════════════════════════════════════════
   POST-PUBLISH LOG OVERLAY
   ═══════════════════════════════════════════════════════════ */
.ppl-overlay {
  position: fixed;
  inset: 0;
  z-index: 9999;
  display: flex;
  align-items: flex-end;
  justify-content: center;
  background: rgba(0,0,0,.5);
  opacity: 0;
  transition: opacity .3s ease;
  padding: 16px;
}
.ppl-overlay.ppl-visible {
  opacity: 1;
}
.ppl-card {
  width: 100%;
  max-width: 400px;
  background: var(--bg-surface);
  border: 1px solid var(--border-sm);
  border-radius: var(--r-lg);
  padding: 20px;
  transform: translateY(100%);
  transition: transform .3s ease;
}
.ppl-overlay.ppl-visible .ppl-card {
  transform: translateY(0);
}
.ppl-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 16px;
}
.ppl-title {
  font-size: 15px;
  font-weight: 700;
  color: var(--text-1);
}
.ppl-skip {
  font-size: 12px;
  color: var(--text-3);
  background: none;
  border: none;
  cursor: pointer;
  padding: 4px 8px;
}
.ppl-fields {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 10px;
  margin-bottom: 10px;
}
.ppl-field label {
  display: block;
  font-size: 11px;
  color: var(--text-3);
  margin-bottom: 4px;
}
.ppl-field input {
  width: 100%;
  padding: 10px 8px;
  background: var(--bg-elevated);
  border: 1px solid var(--border-sm);
  border-radius: var(--r-md);
  color: var(--text-1);
  font-size: 16px;
  font-weight: 600;
  text-align: center;
  outline: none;
  -webkit-appearance: none;
  -moz-appearance: textfield;
}
.ppl-field input:focus {
  border-color: var(--text-3);
}
.ppl-tip {
  font-size: 10px;
  color: var(--text-3);
  text-align: center;
  margin-bottom: 12px;
}
.ppl-actions {
  display: flex;
  justify-content: center;
}
.ppl-save {
  padding: 10px 24px;
  background: var(--text-1);
  color: var(--bg-base);
  border: none;
  border-radius: var(--r-md);
  font-size: 13px;
  font-weight: 600;
  cursor: pointer;
  width: 100%;
}
[data-theme="light"] .ppl-card {
  background: #fff;
  box-shadow: 0 -4px 24px rgba(0,0,0,.12);
}

/* ═══════════════════════════════════════════════════════════
   CONTENT RECYCLER (enhanced)
   ═══════════════════════════════════════════════════════════ */
.cr-item {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 8px 0;
  border-bottom: 1px solid var(--border-xs);
}
.cr-item:last-child {
  border-bottom: none;
}
.cr-item-info {
  flex: 1;
  min-width: 0;
}
.cr-item-title {
  font-size: 12px;
  font-weight: 600;
  color: var(--text-1);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.cr-item-meta {
  font-size: 10px;
  color: var(--text-3);
  margin-top: 2px;
  display: flex;
  align-items: center;
  gap: 6px;
}
.cr-metrics {
  font-size: 10px;
  color: var(--text-2);
}
.cr-reuse-btn {
  flex-shrink: 0;
  padding: 5px 12px;
  background: var(--bg-elevated);
  border: 1px solid var(--border-sm);
  border-radius: var(--r-md);
  color: var(--text-2);
  font-size: 11px;
  font-weight: 600;
  cursor: pointer;
  margin-left: 10px;
  transition: all .2s;
}
.cr-reuse-btn:hover {
  background: var(--text-1);
  color: var(--bg-base);
  border-color: var(--text-1);
}
