/* ══════════════════════════════════════════
   CallPersona — App Design System
   Desktop-first, Sidebar Layout
   ══════════════════════════════════════════ */
@import url('https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700;800;900&display=swap');

:root {
  --bg: #0b0d12;
  --bg-2: #111318;
  --sidebar-bg: #0f1116;
  --panel: #16181f;
  --surface: rgba(255,255,255,0.05);
  --surface-hover: rgba(255,255,255,0.08);
  --line: rgba(255,255,255,0.07);
  --line-hover: rgba(255,255,255,0.12);
  --text: #f0f0f3;
  --text-2: #a0a0b0;
  --muted: #5a5a6e;
  --accent: #b44ef8;
  --accent-hover: #9d3ae8;
  --accent-glow: rgba(180,78,248,0.18);
  --accent-subtle: rgba(180,78,248,0.08);
  --good: #00cec9;
  --danger: #ff6b6b;
  --danger-subtle: rgba(255,107,107,0.1);
  --warning: #feca57;
  --r-xs: 6px;
  --r-sm: 8px;
  --r-md: 12px;
  --r-lg: 16px;
  --r-xl: 20px;
  --r-pill: 999px;
  --t: 0.2s cubic-bezier(0.4,0,0.2,1);
  --sidebar-w: 240px;
}

*,*::before,*::after { box-sizing:border-box; margin:0; padding:0; }

body {
  background:var(--bg);
  color:var(--text);
  font-family:'Inter',-apple-system,BlinkMacSystemFont,'Segoe UI',system-ui,sans-serif;
  font-size:14px;
  line-height:1.5;
  -webkit-font-smoothing:antialiased;
  overflow:hidden;
  min-height:100vh;
  min-height:100dvh;
}

button,input,textarea,select { font:inherit; color:inherit; }
a { color:var(--accent); text-decoration:none; }
::selection { background:rgba(180,78,248,0.3); color:#fff; }
::-webkit-scrollbar { width:5px; height:5px; }
::-webkit-scrollbar-track { background:transparent; }
::-webkit-scrollbar-thumb { background:rgba(255,255,255,0.08); border-radius:3px; transition:background 0.2s; }
::-webkit-scrollbar-thumb:hover { background:rgba(180,78,248,0.3); }

.hidden { display:none !important; }
.muted { color:var(--text-2); }
.small { font-size:12px; }

/* ══════════════════════════════════════════
   App Shell — Sidebar + Main
   ══════════════════════════════════════════ */
.app {
  display:grid;
  grid-template-columns:var(--sidebar-w) 1fr;
  grid-template-rows:1fr;
  height:100vh;
  height:100dvh;
  overflow:hidden;
}
.app.no-sidebar {
  grid-template-columns:1fr;
}

/* ── Sidebar ── */
.sidebar {
  background:var(--sidebar-bg);
  border-right:1px solid var(--line);
  display:flex;
  flex-direction:column;
  height:100vh;
  height:100dvh;
  overflow:hidden;
  z-index:80;
}
.sidebar-brand {
  padding:16px 16px 12px;
  display:flex;
  align-items:center;
  gap:10px;
  border-bottom:1px solid var(--line);
  flex-shrink:0;
}
.logoMark {
  width:32px; height:32px; border-radius:9px;
  overflow:hidden; flex-shrink:0;
  display:flex; align-items:center; justify-content:center;
}
.logoMark img { width:100%; height:100%; object-fit:contain; }
@keyframes logoGradient {
  0%,100% { background-position:0% 50%; }
  50% { background-position:100% 50%; }
}
.brand-logo-font { height:20px; object-fit:contain; }
.auth-hero-logo-font { height:22px; object-fit:contain; }

.sidebar-nav {
  flex:1; overflow-y:auto; padding:8px;
  display:flex; flex-direction:column; gap:2px;
}
.nav-item {
  display:flex; align-items:center; gap:10px;
  padding:10px 12px; border-radius:var(--r-sm);
  border:none; background:none;
  color:var(--text-2); font-size:14px; font-weight:500;
  cursor:pointer; transition:all 0.25s ease;
  width:100%; text-align:left;
  position:relative; overflow:hidden;
}
.nav-item::before {
  content:""; position:absolute; left:0; top:50%;
  width:3px; height:0; border-radius:0 2px 2px 0;
  background:var(--accent); transform:translateY(-50%);
  transition:height 0.25s ease;
}
.nav-item svg { flex-shrink:0; opacity:0.7; transition:all 0.25s ease; }
.nav-item:hover {
  background:var(--surface); color:var(--text);
  box-shadow:inset 0 0 20px rgba(255,255,255,0.02);
}
.nav-item:hover svg { opacity:1; transform:scale(1.1); }
.nav-item.active {
  background:var(--accent-subtle);
  color:var(--accent);
  font-weight:600;
}
.nav-item.active::before { height:60%; }
.nav-item.active svg { opacity:1; color:var(--accent); }

.sidebar-divider {
  height:1px; background:var(--line); margin:6px 12px;
}

.sidebar-footer {
  padding:8px; border-top:1px solid var(--line); flex-shrink:0;
  position:relative;
}
.sidebar-user {
  display:flex; align-items:center; gap:10px;
  padding:8px 10px; border-radius:var(--r-sm);
  width:100%; background:none; border:none; cursor:pointer;
  color:inherit; text-align:left;
  transition:background 0.15s;
}
.sidebar-user:hover { background:var(--hover); }
.sidebar-user-avatar {
  width:32px; height:32px; border-radius:var(--r-pill);
  display:grid; place-items:center;
  background:linear-gradient(135deg,var(--accent),#c96ffb);
  color:#fff; font-weight:700; font-size:13px; flex-shrink:0;
  transition:box-shadow 0.3s ease;
}
.sidebar-user:hover .sidebar-user-avatar {
  box-shadow:0 0 12px var(--accent-glow);
}
.sidebar-user-info { min-width:0; flex:1; }
.sidebar-user-name {
  font-size:13px; font-weight:600;
  white-space:nowrap; overflow:hidden; text-overflow:ellipsis;
}
.sidebar-user-email {
  font-size:11px; color:var(--muted);
  white-space:nowrap; overflow:hidden; text-overflow:ellipsis;
}
.user-menu-chevron {
  flex-shrink:0; opacity:0.5;
  transition:transform 0.2s ease, opacity 0.2s;
}
.sidebar-user[aria-expanded="true"] .user-menu-chevron {
  transform:rotate(180deg); opacity:1;
}
/* Slide-up popup */
.user-menu-popup {
  position:absolute; left:8px; right:8px;
  bottom:calc(100% + 4px);
  background:var(--surface-2,#1e1e2e);
  border:1px solid var(--line);
  border-radius:var(--r);
  padding:4px;
  box-shadow:0 -8px 24px rgba(0,0,0,0.4);
  transform-origin:bottom center;
  transform:translateY(6px);
  opacity:0;
  pointer-events:none;
  transition:transform 0.18s ease, opacity 0.18s ease;
  z-index:200;
}
.user-menu-popup:not(.hidden) {
  transform:translateY(0);
  opacity:1;
  pointer-events:auto;
}
.user-menu-divider {
  height:1px; background:var(--line); margin:4px 0;
}
.logout-item { color:var(--danger) !important; }
.logout-item svg { stroke:var(--danger) !important; opacity:1 !important; }

/* Sidebar overlay (mobile) */
.sidebar-overlay {
  display:none;
  position:fixed; inset:0;
  background:rgba(0,0,0,0.5);
  z-index:79;
}
.sidebar-overlay.open { display:block; }

/* ── Main Content ── */
.main {
  display:flex; flex-direction:column;
  height:100vh; height:100dvh; overflow:hidden;
}

/* Topbar */
.topbar {
  height:56px; flex-shrink:0;
  display:flex; align-items:center;
  gap:12px;
  padding:0 20px;
  border-bottom:1px solid var(--line);
  background:var(--bg-2);
}
.mobile-menu-btn {
  display:none;
  background:none; border:none; color:var(--text-2);
  cursor:pointer; padding:4px;
}
.topbar-title {
  font-size:16px; font-weight:700; letter-spacing:-0.2px;
  flex:1;
}
.topbar-actions {
  display:flex; align-items:center; gap:6px;
}
.topbar-icon-btn {
  width:36px; height:36px; border-radius:var(--r-pill);
  border:1px solid var(--line); background:var(--surface);
  color:var(--text-2); cursor:pointer; display:grid; place-items:center;
  transition:all var(--t); position:relative;
}
.topbar-icon-btn:hover {
  background:var(--surface-hover); border-color:rgba(180,78,248,0.2); color:var(--text);
  box-shadow:0 0 10px rgba(180,78,248,0.1);
  transform:scale(1.05);
}
.topbar-icon-btn:active { transform:scale(0.95); }

/* ── App Content (scrollable page area) ── */
.app-content {
  flex:1; overflow-y:auto; overflow-x:hidden;
  position:relative; min-height:0;
}

/* ── Page system ── */
.page {
  display:none; padding:24px;
  opacity:0; transform:translateY(10px);
  transition:opacity 0.3s ease, transform 0.3s ease;
}
.page.active {
  display:block;
  opacity:1; transform:translateY(0);
}
.page-header {
  display:flex; align-items:center; justify-content:space-between;
  gap:12px; margin-bottom:20px;
}
.page-header h2 {
  font-size:22px; font-weight:800; letter-spacing:-0.3px;
}

/* ══════════════════════════════════════════
   Buttons
   ══════════════════════════════════════════ */
.btn-primary {
  border:none; border-radius:var(--r-sm);
  padding:0 18px; height:40px;
  cursor:pointer; color:#fff; background:var(--accent);
  font-weight:700; font-size:14px;
  display:inline-flex; align-items:center; justify-content:center; gap:6px;
  box-shadow:0 2px 10px var(--accent-glow);
  transition:all 0.25s cubic-bezier(0.4,0,0.2,1); white-space:nowrap;
  position:relative; overflow:hidden;
}
.btn-primary::after {
  content:""; position:absolute; inset:0;
  background:linear-gradient(45deg,transparent 30%,rgba(255,255,255,0.15) 50%,transparent 70%);
  background-size:200% 200%; opacity:0;
  transition:opacity 0.3s;
}
.btn-primary:hover::after { opacity:1; animation:btnSheen 0.8s ease; }
@keyframes btnSheen {
  from { background-position:200% 0; }
  to { background-position:-200% 0; }
}
.btn-primary:hover {
  background:var(--accent-hover); transform:translateY(-2px) scale(1.02);
  box-shadow:0 6px 20px rgba(180,78,248,0.35);
}
.btn-primary:active { transform:translateY(0) scale(0.97); box-shadow:0 1px 6px var(--accent-glow); }
.btn-primary.small { height:30px; font-size:12px; padding:0 12px; border-radius:var(--r-xs); }

.ghost-btn {
  border:1px solid var(--line); background:var(--surface);
  border-radius:var(--r-sm);
  padding:0 12px; height:34px;
  cursor:pointer; color:var(--text-2);
  font-weight:600; font-size:13px;
  display:inline-flex; align-items:center; justify-content:center; gap:5px;
  transition:all 0.25s ease; white-space:nowrap;
}
.ghost-btn:hover {
  background:var(--surface-hover); border-color:rgba(180,78,248,0.25); color:var(--text);
  box-shadow:0 0 12px rgba(180,78,248,0.08);
}
.ghost-btn:active { transform:scale(0.97); }
.ghost-btn.small { height:28px; font-size:11px; padding:0 8px; }
.ghost-btn.danger { background:var(--danger-subtle); border-color:rgba(255,107,107,0.15); color:var(--danger); }
.ghost-btn.danger:hover { background:rgba(255,107,107,0.18); }

.btn-ghost {
  border:1px solid var(--line); background:var(--surface);
  border-radius:var(--r-sm);
  padding:0 14px; height:40px;
  cursor:pointer; color:var(--text);
  font-weight:600; font-size:14px;
  display:inline-flex; align-items:center; justify-content:center; gap:6px;
  transition:all var(--t); white-space:nowrap;
}
.btn-ghost:hover { background:var(--surface-hover); border-color:var(--line-hover); }

/* Legacy button classes (for sub-modules) */
.ghost {
  border:1px solid var(--line); background:var(--surface);
  border-radius:var(--r-sm);
  padding:0 14px; height:36px;
  cursor:pointer; color:var(--text);
  font-weight:600; font-size:13px;
  display:inline-flex; align-items:center; justify-content:center; gap:6px;
  transition:all var(--t); white-space:nowrap;
}
.ghost:hover { background:var(--surface-hover); border-color:var(--line-hover); }
.primary {
  background:var(--accent); border:none; color:#fff;
  border-radius:var(--r-sm);
  padding:0 14px; height:36px;
  cursor:pointer; font-weight:600; font-size:13px;
  display:inline-flex; align-items:center; justify-content:center; gap:6px;
  box-shadow:0 2px 10px var(--accent-glow);
  transition:all var(--t); white-space:nowrap;
}
.primary:hover { background:var(--accent-hover); transform:translateY(-1px); }
.danger { background:var(--danger-subtle); border:1px solid rgba(255,107,107,0.15); color:var(--danger);
  border-radius:var(--r-sm);
  padding:0 14px; height:36px;
  cursor:pointer; font-weight:600; font-size:13px;
  display:inline-flex; align-items:center; justify-content:center; gap:6px;
  transition:all var(--t); white-space:nowrap;
}
.danger:hover { background:rgba(255,107,107,0.18); }

/* ══════════════════════════════════════════
   Auth View
   ══════════════════════════════════════════ */
.auth-view {
  display:flex; align-items:center; justify-content:center; gap:64px;
  flex:1; padding:32px 24px;
  background:
    radial-gradient(ellipse at 20% 20%, rgba(180,78,248,0.10) 0%, transparent 55%),
    radial-gradient(ellipse at 80% 80%, rgba(108,92,231,0.07) 0%, transparent 55%),
    var(--bg);
}

/* Left hero panel */
.auth-hero {
  display:none; /* hidden on mobile */
  flex-direction:column; gap:24px;
  max-width:380px; flex-shrink:0;
}
@media(min-width:860px) { .auth-hero { display:flex; } }
.auth-hero-logo {
  display:flex; align-items:center; gap:10px;
}
.auth-hero-brand {
  font-size:18px; font-weight:800; letter-spacing:-0.3px;
}
.auth-hero-headline {
  font-size:36px; font-weight:800; letter-spacing:-0.8px; line-height:1.15;
  margin:0;
}
.auth-hero-headline em { font-style:normal; color:var(--accent); }
.auth-hero-sub {
  font-size:15px; color:var(--text-2); line-height:1.6; margin:0;
}
.auth-feature-list {
  list-style:none; margin:0; padding:0;
  display:flex; flex-direction:column; gap:14px;
}
.auth-feature-list li {
  display:flex; align-items:flex-start; gap:12px;
  font-size:13px; color:var(--text-2); line-height:1.5;
}
.auth-feature-icon {
  width:26px; height:26px; border-radius:var(--r-sm); flex-shrink:0;
  background:rgba(180,78,248,0.12); border:1px solid rgba(180,78,248,0.2);
  display:grid; place-items:center; color:var(--accent);
  margin-top:1px;
}

/* Right: card */
.auth-card {
  width:100%; max-width:400px; padding:40px 32px;
  background:rgba(22,24,31,0.85);
  backdrop-filter:blur(24px); -webkit-backdrop-filter:blur(24px);
  border:1px solid rgba(255,255,255,0.08);
  border-radius:var(--r-xl); text-align:center;
  box-shadow:0 24px 64px rgba(0,0,0,0.4), 0 0 40px rgba(180,78,248,0.06);
  animation:authCardIn 0.5s cubic-bezier(0.34,1.56,0.64,1);
}
.auth-card-logo-mobile { display:block; }
@media(min-width:860px) { .auth-card-logo-mobile { display:none; } }
@keyframes authCardIn {
  from { opacity:0; transform:translateY(20px) scale(0.97); }
  to { opacity:1; transform:translateY(0) scale(1); }
}
@keyframes logoPulse {
  0%,100% { box-shadow:0 2px 10px var(--accent-glow); }
  50% { box-shadow:0 4px 24px rgba(180,78,248,0.35); }
}
.logoMark { animation:logoPulse 3s ease-in-out infinite; }
.auth-card h1 {
  font-size:22px; font-weight:800; letter-spacing:-0.3px; margin-bottom:4px;
}
.auth-card > p { color:var(--text-2); margin-bottom:4px; }

.auth-tabs {
  display:grid; grid-template-columns:1fr 1fr; gap:4px;
  padding:4px; margin:20px 0 16px;
  background:var(--surface); border-radius:var(--r-sm);
}
.auth-tab {
  border:none; border-radius:var(--r-xs); padding:0 14px; height:36px;
  cursor:pointer; font-weight:600; font-size:13px;
  background:transparent; color:var(--text-2);
  transition:all var(--t);
}
.auth-tab.active { background:var(--accent); color:#fff; }
.auth-tab:not(.active):hover { background:rgba(255,255,255,0.04); color:var(--text); }

.auth-form { display:grid; gap:12px; text-align:left; }
.auth-form .btn-primary {
  width:100%; height:44px; border-radius:var(--r-pill);
  font-size:15px; font-weight:700; margin-top:4px;
}

/* ── Onboarding Modal ── */
.onboarding-overlay {
  position:fixed; inset:0; z-index:1000;
  background:rgba(0,0,0,0.65);
  display:flex; align-items:center; justify-content:center;
  padding:24px;
  backdrop-filter:blur(4px);
  animation:authCardIn 0.2s ease;
}
.onboarding-overlay.hidden { display:none !important; }
.onboarding-card {
  background:var(--panel); border:1px solid var(--line);
  border-radius:var(--r-xl); padding:36px 32px;
  max-width:420px; width:100%; text-align:center;
  animation:authCardIn 0.35s cubic-bezier(0.34,1.4,0.64,1);
  box-shadow:0 24px 64px rgba(0,0,0,0.5);
}
.onboarding-badge {
  font-size:40px; margin-bottom:16px; line-height:1;
}
.onboarding-card h2 {
  font-size:22px; font-weight:800; margin-bottom:6px;
}
.onboarding-steps {
  list-style:none; margin:20px 0 0; padding:0;
  display:flex; flex-direction:column; gap:14px; text-align:left;
}
.onboarding-steps li {
  display:flex; align-items:flex-start; gap:14px;
}
.onboarding-step-num {
  width:28px; height:28px; border-radius:var(--r-pill); flex-shrink:0;
  background:rgba(180,78,248,0.12); border:1px solid rgba(180,78,248,0.25);
  color:var(--accent); font-weight:700; font-size:13px;
  display:grid; place-items:center; margin-top:1px;
}

/* ── Empty States ── */
.empty-state {
  display:flex; flex-direction:column; align-items:center; gap:10px;
  padding:52px 24px; text-align:center;
}
.empty-state-icon {
  width:56px; height:56px; border-radius:var(--r-xl);
  background:var(--surface); border:1px solid var(--line);
  display:grid; place-items:center; color:var(--muted);
  margin-bottom:4px;
}
.empty-state-title {
  font-size:15px; font-weight:700; color:var(--text);
}
.empty-state-sub {
  font-size:12px; color:var(--muted); max-width:260px; line-height:1.5;
}
.empty-state-action {
  margin-top:8px; padding:0 20px; height:38px;
  border-radius:var(--r-pill); font-size:13px;
}

/* ══════════════════════════════════════════
   Forms
   ══════════════════════════════════════════ */
.field label {
  display:block; margin-bottom:4px;
  color:var(--text-2); font-weight:600; font-size:12px;
  text-transform:uppercase; letter-spacing:0.4px;
}
input,textarea,select {
  width:100%; background:var(--surface);
  border:1px solid var(--line); color:var(--text);
  border-radius:var(--r-sm); padding:10px 12px; font-size:14px;
  transition:all var(--t); outline:none;
}
input:focus,textarea:focus,select:focus {
  border-color:var(--accent);
  box-shadow:0 0 0 3px var(--accent-glow);
}
input::placeholder,textarea::placeholder { color:var(--muted); }
textarea { resize:vertical; min-height:42px; }
select {
  cursor:pointer;
}
select[data-custom-select="true"] {
  display:none !important;
}

.cp-select {
  position:relative;
}
.cp-select-trigger {
  width:100%;
  background:var(--surface);
  border:1px solid var(--line);
  color:var(--text);
  border-radius:var(--r-sm);
  padding:10px 38px 10px 12px;
  font-size:14px;
  text-align:left;
  cursor:pointer;
  transition:all var(--t);
  position:relative;
}
.cp-select-trigger:hover {
  border-color:var(--line-hover);
  background:var(--surface-hover);
}
.cp-select-trigger:focus-visible {
  border-color:var(--accent);
  box-shadow:0 0 0 3px var(--accent-glow);
}
.cp-select-trigger::after {
  content:"";
  position:absolute;
  right:12px;
  top:50%;
  width:8px;
  height:8px;
  border-right:2px solid var(--text-2);
  border-bottom:2px solid var(--text-2);
  transform:translateY(-65%) rotate(45deg);
  transition:transform var(--t), border-color var(--t);
}
.cp-select.open .cp-select-trigger::after {
  transform:translateY(-25%) rotate(-135deg);
  border-color:var(--accent);
}
.cp-select-menu {
  position:absolute;
  left:0;
  right:0;
  top:calc(100% + 6px);
  background:var(--panel);
  border:1px solid var(--line-hover);
  border-radius:var(--r-sm);
  overflow:auto;
  max-height:260px;
  box-shadow:0 12px 28px rgba(0,0,0,0.35);
  z-index:120;
}
.cp-select-menu.hidden {
  display:none;
}
.cp-select-option {
  width:100%;
  border:0;
  background:transparent;
  color:var(--text);
  text-align:left;
  padding:10px 12px;
  font-size:14px;
  cursor:pointer;
}
.cp-select-option:hover {
  background:var(--surface-hover);
}
.cp-select-option.active {
  background:var(--accent-subtle);
  color:var(--accent);
  font-weight:600;
}

.row { display:flex; gap:8px; align-items:center; }
.form-actions { display:flex; gap:8px; margin-top:4px; }
.form-actions .btn-primary { flex:1; height:44px; border-radius:var(--r-pill); font-size:15px; }

/* ══════════════════════════════════════════
   Discover Page
   ══════════════════════════════════════════ */
.discover-search-bar {
  display:flex; gap:10px; margin-bottom:12px; align-items:center;
}
.search-input-wrap {
  flex:1; position:relative; display:flex; align-items:center;
}
.search-input-wrap svg {
  position:absolute; left:12px; color:var(--muted); pointer-events:none;
}
.search-input-wrap input {
  padding-left:36px;
  border-radius:var(--r-pill);
}
.discover-search-bar select { width:140px; border-radius:var(--r-pill); }

/* Category Filter Chips */
.discover-filter-chips {
  display:flex; gap:7px; margin-bottom:18px; flex-wrap:wrap;
}
.chip {
  display:inline-flex; align-items:center; gap:5px;
  padding:5px 13px; border-radius:var(--r-pill);
  border:1px solid var(--line); background:var(--panel);
  color:var(--text-2); font-size:12px; font-weight:600;
  cursor:pointer; transition:all 0.2s; white-space:nowrap;
  line-height:1;
}
.chip:hover {
  border-color:rgba(180,78,248,0.3); color:var(--text);
  background:var(--surface-hover);
}
.chip.active {
  border-color:var(--accent); background:var(--accent-subtle);
  color:var(--accent);
}
.chip svg { flex-shrink:0; }

/* Result count badge */
.discover-count {
  display:inline-block; font-size:12px; font-weight:600;
  color:var(--muted); background:var(--surface); border-radius:var(--r-pill);
  padding:1px 8px; vertical-align:middle; margin-left:6px;
}

/* Skeleton loading */
@keyframes skeletonPulse {
  0%,100% { opacity:0.35; }
  50% { opacity:0.65; }
}
.skeleton-card { pointer-events:none; }
.skeleton-banner {
  height:116px;
  background:linear-gradient(135deg,var(--panel),var(--surface-hover));
  animation:skeletonPulse 1.6s ease infinite;
}
.skeleton-line {
  height:11px; border-radius:var(--r-sm);
  background:var(--surface-hover);
  animation:skeletonPulse 1.6s ease infinite;
}
.skeleton-line.wide { width:80%; }
.skeleton-line.medium { width:58%; }
.skeleton-line.short { width:40%; }

.discover-quick-row {
  display:flex; gap:10px; margin-bottom:24px;
}
.quick-card {
  flex:1; display:flex; align-items:center; gap:10px;
  border:1px solid var(--line); background:var(--panel);
  border-radius:var(--r-md); padding:12px 14px;
  color:var(--text); font-size:13px; font-weight:600;
  cursor:pointer; transition:all 0.3s ease;
  position:relative; overflow:hidden;
}
.quick-card::before {
  content:""; position:absolute; inset:-1px;
  border-radius:inherit;
  background:conic-gradient(from var(--card-angle,0deg),transparent,var(--accent),transparent,transparent);
  opacity:0; transition:opacity 0.4s;
  z-index:-1;
}
.quick-card:hover::before { opacity:0.3; animation:borderRotate 3s linear infinite; }
@keyframes borderRotate { to { --card-angle:360deg; } }
@property --card-angle { syntax:"<angle>"; initial-value:0deg; inherits:false; }
.quick-card:hover {
  border-color:rgba(180,78,248,0.2); background:var(--surface-hover);
  transform:translateY(-3px); box-shadow:0 8px 24px rgba(0,0,0,0.25), 0 0 16px rgba(180,78,248,0.08);
}
.quick-card:hover .quick-icon { transform:scale(1.1); }
.quick-card:active { transform:translateY(0) scale(0.98); }
.quick-icon {
  width:34px; height:34px; border-radius:var(--r-sm); flex-shrink:0;
  display:grid; place-items:center; color:#fff;
  transition:transform 0.3s ease;
}
.quick-icon.pink { background:linear-gradient(135deg,#b44ef8,#c96ffb); }
.quick-icon.purple { background:linear-gradient(135deg,#6c5ce7,#a29bfe); }
.quick-icon.teal { background:linear-gradient(135deg,#00cec9,#0984e3); }

.section-label {
  display:flex; align-items:center; justify-content:space-between;
  gap:12px; margin-bottom:14px;
  font-size:16px; font-weight:700;
}

/* Discover Card Grid */
.card-grid {
  display:grid; grid-template-columns:repeat(auto-fill,minmax(200px,1fr));
  gap:12px;
}
.discover-card {
  border:1px solid var(--line); border-radius:14px;
  overflow:hidden; background:var(--panel);
  display:flex; flex-direction:column;
  transition:all 0.35s cubic-bezier(0.4,0,0.2,1);
  animation:cardEntrance 0.4s ease both;
}
.discover-card:nth-child(1) { animation-delay:0s; }
.discover-card:nth-child(2) { animation-delay:0.05s; }
.discover-card:nth-child(3) { animation-delay:0.1s; }
.discover-card:nth-child(4) { animation-delay:0.15s; }
.discover-card:nth-child(5) { animation-delay:0.2s; }
.discover-card:nth-child(6) { animation-delay:0.25s; }
.discover-card:nth-child(n+7) { animation-delay:0.3s; }
@keyframes cardEntrance {
  from { opacity:0; transform:translateY(16px) scale(0.97); }
  to { opacity:1; transform:translateY(0) scale(1); }
}
.discover-card:hover {
  border-color:rgba(180,78,248,0.3);
  transform:translateY(-4px) scale(1.01);
  box-shadow:0 12px 32px rgba(0,0,0,0.3), 0 0 20px var(--accent-glow);
}
.discover-card-banner {
  height:116px; display:flex; align-items:center; justify-content:center;
  position:relative; overflow:hidden;
}
.discover-card-banner::before {
  content:"";
  position:absolute;
  inset:0;
  background:linear-gradient(to bottom, rgba(0,0,0,0.02), rgba(0,0,0,0.26));
  pointer-events:none;
}
.discover-card-banner::after {
  content:""; position:absolute; inset:0;
  background:linear-gradient(45deg,transparent 40%,rgba(255,255,255,0.06) 50%,transparent 60%);
  background-size:300% 300%;
  opacity:0; transition:opacity 0.4s;
}
.discover-card:hover .discover-card-banner::after {
  opacity:1; animation:bannerSheen 1.5s ease infinite;
}
@keyframes bannerSheen {
  0% { background-position:200% 0; }
  100% { background-position:-200% 0; }
}
.discover-card-avatar {
  width: 100%;
  height: 100%;
  border-radius: 0;
  display: grid;
  place-items: center;
  font-size: 26px;
  font-weight: 800;
  color: rgba(255,255,255,0.86);
  border: none;
  background: rgba(0,0,0,0.08);
  background-size: cover;
  background-position: top center;
  background-repeat: no-repeat;
  transition: transform 0.4s ease;
}
.discover-card:hover .discover-card-avatar {
  transform: scale(1.03);
}
.discover-card-body { padding:12px; }
.discover-card-header {
  display:flex; align-items:flex-start; justify-content:space-between; gap:6px;
}
.discover-card-name { font-size:15px; font-weight:700; line-height:1.25; flex:1; min-width:0; }
.discover-card-category {
  flex-shrink:0; font-size:10px; font-weight:700; letter-spacing:0.04em;
  text-transform:uppercase; padding:2px 7px; border-radius:var(--r-pill);
  border:1px solid; line-height:1.6;
}
.discover-card-category.cat-roleplay   { color:#a29bfe; border-color:rgba(162,155,254,0.3); background:rgba(162,155,254,0.08); }
.discover-card-category.cat-assistant  { color:var(--good); border-color:rgba(0,206,201,0.3); background:rgba(0,206,201,0.08); }
.discover-card-category.cat-education  { color:#feca57; border-color:rgba(254,202,87,0.3); background:rgba(254,202,87,0.08); }
.discover-card-category.cat-entertainment { color:#fd79a8; border-color:rgba(253,121,168,0.3); background:rgba(253,121,168,0.08); }
.discover-card-category.cat-other      { color:var(--text-2); border-color:var(--line); background:var(--surface); }

.discover-card-meta { color:var(--text-2); font-size:12px; margin-top:3px; }
.discover-card-byline {
  margin-top: 5px;
  font-size: 12px;
  color: var(--text-2);
}
.discover-card-handle {
  color: var(--accent);
  font-size: 12px;
  font-weight: 700;
}
.discover-card-handle.is-clickable { cursor: pointer; }
.discover-card-handle.is-clickable:hover { text-decoration: underline; }
.discover-card-tagline {
  margin-top: 5px;
  font-size: 12px;
  line-height: 1.35;
  color: var(--text-2);
  white-space: normal;
  overflow: visible;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}
.discover-card-tags {
  display:flex; gap:5px; flex-wrap:wrap; margin-top:9px;
}
.discover-card-tag {
  font-size:11px; font-weight:500;
  color:var(--accent); background:rgba(180,78,248,0.1);
  border:1px solid rgba(180,78,248,0.25); border-radius:var(--r-pill);
  padding:2px 9px; line-height:1.6; letter-spacing:0.01em;
  transition:background 0.15s, border-color 0.15s;
}
.discover-card-stats {
  display:flex; gap:10px; margin-top:8px;
  font-size:11px; color:var(--muted); align-items:center;
}
.discover-card-stat {
  display:inline-flex; align-items:center; gap:4px;
}
.discover-card-stat svg { flex-shrink:0; }
.discover-card-actions { display:flex; gap:6px; margin-top:10px; flex-wrap:wrap; }

/* ══════════════════════════════════════════
   Tag Input Widget
   ══════════════════════════════════════════ */
.tag-input-wrap {
  display:flex; flex-wrap:wrap; gap:6px; align-items:center;
  background:var(--surface); border:1px solid var(--line); border-radius:var(--r);
  padding:6px 10px; min-height:40px; cursor:text;
  transition:border-color 0.15s;
}
.tag-input-wrap:focus-within { border-color:var(--accent); }
.tag-pills { display:contents; }
.tag-pill {
  display:inline-flex; align-items:center; gap:4px;
  background:rgba(180,78,248,0.12); color:var(--accent);
  border:1px solid rgba(180,78,248,0.3); border-radius:var(--r-pill);
  font-size:12px; padding:2px 8px; white-space:nowrap;
}
.tag-pill-remove {
  background:none; border:none; color:var(--accent); cursor:pointer;
  padding:0; line-height:1; font-size:14px; opacity:0.7;
  display:inline-flex; align-items:center;
}
.tag-pill-remove:hover { opacity:1; }
.tag-input {
  border:none; outline:none; background:transparent;
  font-size:13px; color:var(--text-1); flex:1; min-width:80px;
  padding:0; font-family:inherit;
}
.tag-input::placeholder { color:var(--muted); }

/* ══════════════════════════════════════════
   Creator Studio
   ══════════════════════════════════════════ */
.creator-form { display:grid; gap:14px; }
.char-avatar-upload {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 8px;
  padding: 8px 0 2px;
}
.char-avatar-pick {
  position: relative;
  display: inline-grid;
  place-items: center;
  width: 112px;
  height: 112px;
  padding: 0;
  border-radius: 999px;
  border: 1px solid var(--line);
  background: radial-gradient(circle at 30% 25%, rgba(255,255,255,0.08), rgba(255,255,255,0.01));
  color: var(--text);
  cursor: pointer;
  box-shadow: inset 0 1px 0 rgba(255,255,255,0.06), 0 10px 24px rgba(0,0,0,0.2);
}
.char-avatar-pick:hover {
  border-color: rgba(180,78,248,0.38);
  background: radial-gradient(circle at 30% 25%, rgba(255,255,255,0.12), rgba(255,255,255,0.02));
}
.char-avatar-preview {
  width: 88px;
  height: 88px;
  border-radius: 999px;
  border: 2px solid rgba(255,255,255,0.7);
  display: grid;
  place-items: center;
  color: rgba(255,255,255,0.85);
  background: rgba(255,255,255,0.02);
  overflow: hidden;
}
.char-avatar-preview.has-image {
  border-style: solid;
  border-color: rgba(255,255,255,0.92);
}
.char-avatar-edit-badge {
  position: absolute;
  right: 5px;
  bottom: 5px;
  width: 30px;
  height: 30px;
  border-radius: 999px;
  display: grid;
  place-items: center;
  border: 1px solid rgba(255,255,255,0.2);
  background: rgba(18, 22, 30, 0.92);
  color: rgba(255,255,255,0.88);
  box-shadow: 0 4px 10px rgba(0,0,0,0.35);
}
.char-avatar-caption {
  font-weight: 600;
  font-size: 12px;
}
.create-studio-home { margin-top: 4px; }
.create-studio-intro {
  margin: 0 0 12px;
}
.create-studio-intro h3 {
  margin: 0 0 4px;
  font-size: 18px;
  font-weight: 800;
}
.create-studio-intro p {
  margin: 0;
}
.create-studio-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(320px, 1fr));
  gap: 14px;
}
.create-studio-card {
  min-height: 190px;
  display: grid;
  grid-template-rows: auto auto 1fr auto;
  align-items: flex-start;
  text-align: left;
  gap: 12px;
  padding: 18px;
  border: 1px solid var(--line);
  border-radius: var(--r-md);
  background:
    radial-gradient(circle at 88% 8%, rgba(255,255,255,0.09), transparent 35%),
    linear-gradient(160deg, rgba(255,255,255,0.06), rgba(255,255,255,0.01));
  box-shadow: 0 14px 28px rgba(0,0,0,0.22);
}
.create-studio-card-kicker {
  font-size: 11px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--text-2);
  opacity: 0.92;
}
.create-studio-card-head {
  display: flex;
  align-items: center;
  gap: 10px;
}
.create-studio-card:hover {
  transform: translateY(-4px);
  border-color: rgba(180,78,248,0.32);
  box-shadow: 0 20px 36px rgba(0,0,0,0.3), 0 0 18px rgba(180,78,248,0.1);
}
.create-studio-card-title {
  font-weight: 800;
  font-size: 20px;
  line-height: 1.2;
}
.create-studio-card-desc {
  font-size: 14px;
  line-height: 1.45;
  color: var(--text-2);
}
.create-studio-card-cta {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 38px;
  padding: 0 12px;
  border-radius: 10px;
  border: 1px solid rgba(255,255,255,0.14);
  background: rgba(255,255,255,0.04);
  color: var(--text);
  font-size: 13px;
  font-weight: 700;
}
.create-studio-card:hover .create-studio-card-cta {
  border-color: rgba(180,78,248,0.38);
  background: rgba(180,78,248,0.12);
}
.create-panel-actions {
  display: flex;
  margin-bottom: 10px;
}
.options-grid { display:grid; grid-template-columns:1fr; gap:10px; }
.field-span-2 { grid-column:span 1; }
.voice-row { display:block; }
.voice-row select {
  width:100%;
}
.voice-actions {
  display:flex;
  gap:8px;
  margin-top:8px;
  flex-wrap: wrap;
}
#customVoiceRecordBtn.recording {
  border-color: rgba(255, 90, 90, 0.48);
  background: rgba(255, 90, 90, 0.12);
  color: #ffd6d6;
}
#customVoiceRecordBtn.countdown {
  border-color: rgba(255, 198, 92, 0.45);
  background: rgba(255, 198, 92, 0.12);
}
.voice-tips-grid {
  margin-top: 8px;
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 8px;
}
.voice-tip {
  border: 1px solid var(--line);
  border-radius: 10px;
  padding: 10px;
  background: rgba(255,255,255,0.02);
}
.voice-tip-title {
  font-size: 12px;
  font-weight: 700;
  margin-bottom: 4px;
}
.voice-tip-text {
  font-size: 12px;
  line-height: 1.35;
  color: var(--text-2);
}
.voice-recorder-shell {
  margin-top: 10px;
  border: 1px dashed rgba(255,255,255,0.18);
  border-radius: 12px;
  padding: 12px;
  background: linear-gradient(160deg, rgba(255,255,255,0.025), rgba(255,255,255,0.01));
}
.voice-recorder-meta {
  margin-top: 10px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
}
.voice-record-badge {
  display: inline-flex;
  align-items: center;
  gap: 7px;
  min-height: 28px;
  padding: 0 10px;
  border-radius: 999px;
  border: 1px solid var(--line);
  font-size: 12px;
  color: var(--text-2);
  background: rgba(255,255,255,0.02);
}
.voice-record-badge.live {
  border-color: rgba(255, 92, 92, 0.55);
  color: #ffd6d6;
  background: rgba(255, 92, 92, 0.12);
}
.voice-record-dot {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: rgba(255,255,255,0.32);
}
.voice-record-badge.live .voice-record-dot {
  background: #ff5c5c;
  box-shadow: 0 0 0 6px rgba(255, 92, 92, 0.16);
}
.voice-countdown {
  width: 42px;
  text-align: center;
  font-size: 24px;
  font-weight: 800;
  color: #ffc55e;
}
.voice-record-timer {
  min-width: 56px;
  text-align: right;
  font-size: 12px;
  color: var(--text-2);
  font-variant-numeric: tabular-nums;
}
.voice-custom-grid {
  display:flex;
  gap:8px;
  margin-top:8px;
}
#customVoiceStatus {
  margin-top:6px;
}
#customVoiceModalStatus {
  margin-top:10px;
}

.cp-modal {
  position: fixed;
  inset: 0;
  z-index: 250;
  display: flex;
  align-items: center;
  justify-content: center;
}
.cp-modal.hidden { display: none; }
.cp-modal-backdrop {
  position: absolute;
  inset: 0;
  background: rgba(0,0,0,0.56);
}
.cp-modal-card {
  position: relative;
  width: min(560px, calc(100vw - 28px));
  background: var(--panel);
  border: 1px solid var(--line);
  border-radius: var(--r-md);
  box-shadow: 0 24px 60px rgba(0,0,0,0.45);
  padding: 14px;
}
.cp-modal-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
  margin-bottom: 10px;
}
.cp-modal-head h3 {
  margin: 0;
  font-size: 15px;
}
.cp-modal-body {
  display: grid;
  gap: 10px;
}
.cp-modal-body .field {
  margin: 0;
}
.cp-modal-body .voice-custom-grid {
  flex-wrap: wrap;
}
.cp-modal-body .voice-custom-grid .ghost-btn {
  min-width: 120px;
}

/* legacy: keep row spacing in creator */
.voice-custom-grid {
  gap:8px;
}
#createVoicePanel .card {
  border: 1px solid var(--line);
  border-radius: 14px;
  padding: 16px;
  background: linear-gradient(160deg, rgba(255,255,255,0.035), rgba(255,255,255,0.01));
}
#createVoicePanel .form-actions {
  margin-top: 10px;
}
#createVoicePanel #saveCustomVoiceBtn {
  min-width: 150px;
}
.voice-inline-actions {
  display: flex;
  gap: 8px;
  margin-top: 8px;
  flex-wrap: wrap;
}
.custom-voices-panel {
  margin-top: 14px;
  border-top: 1px solid var(--line);
  padding-top: 12px;
}
.custom-voices-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 8px;
}
.custom-voices-head h4 {
  margin: 0;
  font-size: 13px;
  font-weight: 700;
}
.custom-voices-list {
  display: grid;
  gap: 8px;
}
.custom-voice-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
  border: 1px solid var(--line);
  border-radius: 10px;
  padding: 9px 10px;
  background: rgba(255,255,255,0.02);
}
.custom-voice-meta {
  min-width: 0;
  flex: 1 1 auto;
}
.custom-voice-actions {
  display: flex;
  gap: 6px;
  flex: 0 0 auto;
}
.custom-voice-name {
  font-size: 13px;
  font-weight: 700;
  line-height: 1.3;
}
.custom-voice-file {
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  max-width: 100%;
}

/* ══════════════════════════════════════════
   Chat Page — Split View
   ══════════════════════════════════════════ */
.page-chats {
  padding:0 !important;
  position:absolute !important; inset:0;
  overflow:hidden;
  opacity:1 !important; transform:none !important;
  transition:none !important;
}
.chat-layout {
  display:grid;
  grid-template-columns:1fr;
  height:100%;
  overflow:hidden;
  position:relative;
}
.chat-layout.show-chat .chat-sidebar { display:none; }
.chat-layout:not(.show-chat) .chat-main { display:none; }

/* Chat sidebar (conversation list) */
.chat-sidebar {
  border-right:1px solid var(--line);
  display:flex; flex-direction:column;
  overflow:hidden; background:var(--bg-2);
  position:relative;
  z-index:1;
}
.chat-sidebar-header {
  padding:14px 16px; border-bottom:1px solid var(--line);
  display:flex; align-items:center; justify-content:space-between;
  flex-shrink:0;
}
.chat-sidebar-title {
  font-size:15px; font-weight:700;
}
.conv-list {
  flex:1;
  overflow-y:auto;
  padding:0;
}
.conv-item {
  display:flex;
  align-items:center;
  gap:12px;
  padding:11px 16px;
  border-radius:0;
  border-bottom:1px solid rgba(255,255,255,0.08);
  border-left:3px solid transparent;
  cursor:pointer;
  transition:all 0.25s ease;
  margin-bottom:0;
  animation:convSlideIn 0.3s ease both;
}
.conv-item:nth-child(1) { animation-delay:0s; }
.conv-item:nth-child(2) { animation-delay:0.04s; }
.conv-item:nth-child(3) { animation-delay:0.08s; }
.conv-item:nth-child(4) { animation-delay:0.12s; }
.conv-item:nth-child(5) { animation-delay:0.16s; }
.conv-item:nth-child(n+6) { animation-delay:0.2s; }
@keyframes convSlideIn {
  from { opacity:0; transform:translateX(-12px); }
  to { opacity:1; transform:translateX(0); }
}
.conv-item:hover { background:rgba(255,255,255,0.03); }
.conv-item.active {
  background:rgba(180,78,248,0.12);
  border-left-color:var(--accent);
}
.conv-item-avatar {
  width:42px;
  height:42px;
  border-radius:50%;
  display:grid;
  place-items:center;
  flex-shrink:0;
  font-size:16px;
  font-weight:700;
  color:#fff;
  background:#b44ef8;
}
.conv-item-meta {
  min-width:0;
  flex:1;
}
.conv-item-name {
  font-size:18px;
  font-weight:700;
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
}
.conv-item-subline {
  margin-top:3px;
  font-size:13px;
  color:var(--muted);
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
}

/* Chat main area */
.chat-main {
  display:flex;
  flex-direction:column;
  height:100%;
  overflow:hidden;
  background:var(--bg);
}
.chat-header {
  padding:12px 16px; display:flex; align-items:center; gap:12px;
  border-bottom:1px solid var(--line);
  background:var(--bg-2); flex-shrink:0;
}
.chat-back-btn {
  display:none;
  background:none; border:none; color:var(--text-2);
  cursor:pointer; padding:4px;
}
.chat-layout.show-chat .chat-back-btn { display:flex; }
.chat-avatar {
  width:38px; height:38px; border-radius:var(--r-pill);
  display:grid; place-items:center;
  font-weight:700; font-size:15px; color:#fff; flex-shrink:0;
}
.chat-header-info { flex:1; min-width:0; }
.chat-char-name {
  font-size:15px; font-weight:700; letter-spacing:-0.2px;
  white-space:nowrap; overflow:hidden; text-overflow:ellipsis;
}
.chat-thread-meta {
  font-size:12px; color:var(--text-2);
  white-space:nowrap; overflow:hidden; text-overflow:ellipsis;
}
.chat-header-actions { display:flex; gap:4px; flex-shrink:0; }

/* Messages */
.messages {
  flex:1; overflow-y:auto; -webkit-overflow-scrolling:touch;
  padding:16px 20px; display:flex; flex-direction:column; gap:6px;
  background:var(--bg);
}
.msg {
  max-width:70%; border-radius:16px; padding:10px 14px;
  line-height:1.5; font-size:14px; word-wrap:break-word;
}
.msg.user {
  align-self:flex-end; background:var(--accent); color:#fff;
  border-bottom-right-radius:4px;
  box-shadow:0 3px 12px var(--accent-glow);
  animation:msgInRight 0.3s cubic-bezier(0.34,1.56,0.64,1);
}
.msg.character {
  align-self:flex-start; background:var(--panel);
  border:1px solid var(--line); border-bottom-left-radius:4px;
  animation:msgInLeft 0.3s cubic-bezier(0.34,1.56,0.64,1);
}
.msg.system {
  align-self:center;
  max-width:90%;
  background:transparent;
  border:1px dashed var(--line);
  color:var(--text-2);
  border-radius:999px;
  padding:6px 12px;
  font-size:12px;
  box-shadow:none;
  animation:none;
}
.msg.system .msgMeta {
  display:none;
}
@keyframes msgInRight {
  from { opacity:0; transform:translateX(20px) scale(0.95); }
  to { opacity:1; transform:translateX(0) scale(1); }
}
@keyframes msgInLeft {
  from { opacity:0; transform:translateX(-20px) scale(0.95); }
  to { opacity:1; transform:translateX(0) scale(1); }
}

/* Typing dots indicator */
.typing-dots { display:flex; gap:4px; padding:4px 0; align-items:center; }
.typing-dots span {
  width:7px; height:7px; border-radius:50%;
  background:var(--text-2); opacity:0.5;
  animation:typingBounce 1.4s ease-in-out infinite;
}
.typing-dots span:nth-child(2) { animation-delay:0.2s; }
.typing-dots span:nth-child(3) { animation-delay:0.4s; }
@keyframes typingBounce {
  0%,60%,100% { transform:translateY(0); opacity:0.4; }
  30% { transform:translateY(-6px); opacity:1; }
}
.msgMeta { display:flex; align-items:center; gap:6px; margin-top:3px; font-size:10px; opacity:0.5; }
.msg:not(:hover) .msg-del-btn { opacity:0; }
.msg-del-btn {
  background:none; border:none; padding:0 2px; cursor:pointer;
  font-size:13px; line-height:1; color:inherit;
  transition:opacity 0.15s;
}
.msg-del-btn:hover { color:var(--danger); opacity:1 !important; }
.msgText { white-space:pre-wrap; }

/* Chat toolbar */
.chat-toolbar {
  display:flex; gap:4px; padding:4px 16px; flex-wrap:wrap;
  border-top:1px solid var(--line); flex-shrink:0;
}

/* Composer */
.chat-composer {
  display:grid; grid-template-columns:1fr auto;
  gap:8px; align-items:end;
  padding:12px 16px; border-top:1px solid var(--line);
  background:var(--bg-2); flex-shrink:0;
}
.chat-composer textarea {
  border-radius:var(--r-pill); background:var(--surface);
  border:1px solid var(--line); padding:10px 16px;
  font-size:16px; resize:none; min-height:40px; max-height:100px;
}
.chat-composer textarea:focus {
  border-color:var(--accent); box-shadow:0 0 0 3px var(--accent-glow);
}
.composer-send {
  border:none; border-radius:var(--r-pill);
  background:var(--accent); color:#fff;
  width:40px; height:40px;
  cursor:pointer; display:grid; place-items:center;
  box-shadow:0 2px 10px var(--accent-glow);
  transition:all 0.25s cubic-bezier(0.4,0,0.2,1);
}
.composer-send:hover {
  background:var(--accent-hover); transform:translateY(-2px) scale(1.08);
  box-shadow:0 6px 20px rgba(180,78,248,0.4);
}
.composer-send:hover svg { transform:rotate(-12deg); transition:transform 0.25s ease; }
.composer-send:active { transform:scale(0.9); }

/* ══════════════════════════════════════════
   Character List Items
   ══════════════════════════════════════════ */
.list { display:grid; gap:8px; }
.item {
  border:1px solid var(--line); border-radius:var(--r-sm);
  padding:12px; background:var(--surface); transition:all var(--t);
}
.item:hover { background:var(--surface-hover); border-color:var(--line-hover); }
.itemTop { display:flex; justify-content:space-between; gap:8px; align-items:flex-start; }
.itemTop strong { font-weight:700; }
.creator-char-head {
  display: flex;
  align-items: center;
  gap: 10px;
  min-width: 0;
}
.creator-char-head strong {
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.creator-char-avatar {
  width: 34px;
  height: 34px;
  border-radius: 999px;
  display: grid;
  place-items: center;
  flex: 0 0 34px;
  font-size: 12px;
  font-weight: 700;
  color: #fff;
  background: linear-gradient(135deg, var(--accent), #c96ffb);
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
}
.creator-char-avatar.has-image {
  color: transparent;
}
.pill {
  font-size:10px; font-weight:600; padding:2px 8px;
  border-radius:var(--r-pill); background:var(--accent-subtle);
  border:1px solid rgba(180,78,248,0.15); color:var(--accent);
  text-transform:uppercase; letter-spacing:0.3px;
}
.item .prompt { margin-top:6px; color:var(--text-2); white-space:pre-wrap; font-size:13px; }
.actions { margin-top:10px; display:flex; gap:6px; }

/* Minimal contact-list style for "My Characters" */
.characters-contact-list {
  display:grid;
  gap:8px;
}
.characters-contact-list {
  display:flex; flex-direction:column;
}
.character-contact {
  display:grid;
  grid-template-columns:46px 1fr auto;
  align-items:center;
  gap:14px;
  padding:13px 4px;
  border-bottom:0.5px solid rgba(255,255,255,0.06);
  transition:background 0.15s ease;
  cursor:default;
}
.character-contact:last-child { border-bottom:0; }
.character-contact:active { background:rgba(255,255,255,0.04); border-radius:var(--r-sm); }
.character-contact-main {
  display:contents;
}
.character-contact-avatar {
  width:46px;
  height:46px;
  border-radius:var(--r-pill);
  display:grid;
  place-items:center;
  font-size:17px;
  font-weight:600;
  letter-spacing:0.2px;
  color:#fff;
  background:linear-gradient(135deg,var(--accent),#c96ffb);
}
.character-contact-meta {
  min-width:0;
}
.character-contact-name {
  font-size:17px;
  font-weight:600;
  letter-spacing:-0.2px;
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
}
.character-contact-subline {
  margin-top:3px;
  display:flex;
  gap:8px;
  align-items:center;
  color:var(--text-2);
  font-size:13px;
}
.character-contact-subline span {
  white-space:nowrap;
}
.character-visibility {
  margin-left:6px;
}
.character-contact-actions {
  display:flex;
  align-items:center;
  gap:8px;
}
.character-contact-actions .ghost-btn {
  width:36px; height:36px;
  border-radius:var(--r-pill);
  background:rgba(180,78,248,0.12);
  color:var(--accent);
  border:none;
  display:grid; place-items:center;
  cursor:pointer;
  padding:0;
  font-size:0;
  transition:transform 0.1s ease, background 0.15s ease;
}
.character-contact-actions .ghost-btn:active { transform:scale(0.9); }
.character-contact-actions .ghost-btn:hover { background:rgba(180,78,248,0.2); }
.character-contact-actions .ghost-btn.danger {
  background:rgba(255,107,107,0.12);
  color:var(--danger);
}
.character-contact-actions .ghost-btn.danger:hover { background:rgba(255,107,107,0.2); }

/* ══════════════════════════════════════════
   Notifications
   ══════════════════════════════════════════ */
.notifWrap { position:relative; }
.notifBadge {
  position:absolute; top:-3px; right:-5px;
  min-width:16px; height:16px; border-radius:var(--r-pill);
  background:var(--danger); color:#fff;
  font-size:9px; font-weight:800;
  display:flex; align-items:center; justify-content:center;
  padding:0 3px; pointer-events:none;
}
.notifDropdown {
  position:absolute; top:44px; right:0;
  width:320px; max-height:400px;
  background:var(--panel); border:1px solid var(--line);
  border-radius:var(--r-md); overflow:hidden; z-index:90;
  box-shadow:0 8px 32px rgba(0,0,0,0.4);
  animation:dropIn 0.15s ease-out;
}
@keyframes dropIn {
  from { opacity:0; transform:translateY(-10px) scale(0.95); }
  to { opacity:1; transform:translateY(0) scale(1); }
}
.notifHeader { padding:12px 14px; font-weight:700; font-size:14px; border-bottom:1px solid var(--line); }
.notifList { max-height:340px; overflow-y:auto; }
.notifItem {
  padding:10px 14px; border-bottom:1px solid var(--line);
  transition:background var(--t);
}
.notifItem:last-child { border-bottom:0; }
.notifItem:hover { background:var(--surface); }
.notifItem.notifUnread { background:var(--accent-subtle); border-left:3px solid var(--accent); }
.notifMsg { font-size:13px; line-height:1.4; }
.notifTime { margin-top:2px; }

/* ══════════════════════════════════════════
   Profile
   ══════════════════════════════════════════ */
.profileHeader { display:flex; align-items:center; gap:16px; margin-bottom:20px; }
.profileAvatarWrap { position:relative; flex-shrink:0; }
.profileAvatarLarge {
  width:64px; height:64px; border-radius:var(--r-pill);
  background:linear-gradient(135deg,var(--accent),#c96ffb);
  display:flex; align-items:center; justify-content:center;
  font-size:26px; font-weight:800; color:#fff;
  box-shadow:0 4px 16px var(--accent-glow);
  animation:avatarBreath 3s ease-in-out infinite;
}
@keyframes avatarBreath {
  0%,100% { box-shadow:0 4px 16px var(--accent-glow); }
  50% { box-shadow:0 6px 28px rgba(180,78,248,0.35); }
}
.profileAvatarUploadBtn {
  position:absolute; bottom:-2px; right:-2px;
  width:22px; height:22px; border-radius:var(--r-pill);
  background:var(--surface-2,#1e1e2e); border:1.5px solid var(--line);
  display:grid; place-items:center; cursor:pointer;
  color:var(--text-2); transition:background 0.15s, color 0.15s;
}
.profileAvatarUploadBtn:hover { background:var(--accent); color:#fff; border-color:var(--accent); }
.profileDisplayName { font-size:22px; font-weight:800; letter-spacing:-0.3px; }
.profileHandle { font-size:13px; color:var(--accent); font-weight:600; }
.profileBio { margin-top:3px; font-size:13px; }
.profilePublicChars { margin-top: 18px; }
.profilePublicCharsHead {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: 10px;
  margin-bottom: 10px;
}
.profilePublicCharsTitle { font-size: 14px; font-weight: 700; letter-spacing: .2px; }
.profileCharsGrid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));
  gap: 10px;
}
.profileCharCard {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 10px;
  border-radius: 12px;
  border: 1px solid var(--line);
  background: rgba(255,255,255,.02);
}
.profileCharAvatar {
  width: 46px;
  height: 46px;
  border-radius: 10px;
  display: grid;
  place-items: center;
  font-size: 16px;
  font-weight: 800;
  color: rgba(255,255,255,.86);
  background: linear-gradient(135deg, rgba(180,78,248,.35), rgba(39,188,255,.28));
  background-repeat: no-repeat;
}
.profileCharMeta { min-width: 0; flex: 1; }
.profileCharName {
  font-size: 13px;
  font-weight: 700;
  line-height: 1.25;
}
.profileCharTagline {
  margin-top: 2px;
  font-size: 12px;
  color: var(--text-2);
  line-height: 1.3;
  white-space: normal;
}
.profileCharsEmpty {
  padding: 12px;
  border: 1px dashed var(--line);
  border-radius: 10px;
}
.profileEditForm {
  margin-top:14px; display:grid; gap:10px;
  padding:14px; background:var(--surface); border-radius:var(--r-md); border:1px solid var(--line);
}

/* ══════════════════════════════════════════
   Account Page Tabs
   ══════════════════════════════════════════ */
.acct-header {
  display:flex; align-items:center; gap:16px;
  margin-bottom:20px; padding-bottom:18px;
  border-bottom:1px solid var(--line);
}
.acct-tabs {
  display:flex; gap:4px; margin-bottom:16px; flex-wrap:wrap;
  border-bottom:1px solid var(--line); padding-bottom:0;
}
.acct-tab {
  padding:9px 16px; font-size:13px; font-weight:600;
  background:none; border:none; border-bottom:2px solid transparent;
  color:var(--text-2); cursor:pointer; transition:color 0.15s, border-color 0.15s;
  margin-bottom:-1px;
}
.acct-tab:hover { color:var(--fg); }
.acct-tab.active { color:var(--fg); border-bottom-color:var(--accent); }
.acct-tab-danger { color:var(--danger) !important; }
.acct-tab-danger:hover { color:var(--danger) !important; opacity:0.8; }
.acct-panel { display:none; }
.acct-panel.active { display:block; }
.acct-card {
  background:var(--surface); border:1px solid var(--line);
  border-radius:var(--r-md); padding:18px; margin-bottom:14px;
}
.acct-card .field { margin-bottom:10px; }
.acct-card .field:last-of-type { margin-bottom:0; }
.acct-card .row { margin-top:12px; }
.acct-card-danger { border-color:rgba(255,107,107,0.25); }
.acct-card-title {
  font-size:15px; font-weight:700; margin-bottom:14px;
}
.acct-info-row {
  display:flex; justify-content:space-between; align-items:center;
  padding:10px 0; border-bottom:1px solid var(--line);
}
.acct-info-row:last-child { border-bottom:none; }
.acct-info-label { color:var(--text-2); font-size:13px; }
.acct-info-val { font-size:13px; text-align:right; max-width:65%; word-break:break-word; }
.plan-pro-pill { background:rgba(99,179,237,0.12); color:#63b3ed; border-color:rgba(99,179,237,0.2); }
.plan-premium-pill { background:rgba(254,202,87,0.12); color:#feca57; border-color:rgba(254,202,87,0.2); }
@media (max-width:480px) {
  .acct-tabs { gap:0; }
  .acct-tab { padding:8px 12px; font-size:12px; }
  .acct-info-val { max-width:55%; }
}

/* ══════════════════════════════════════════
   Creator Dashboard & Admin
   ══════════════════════════════════════════ */
.statGrid {
  display:grid; grid-template-columns:repeat(auto-fill,minmax(120px,1fr)); gap:10px;
}
.statCard {
  background:var(--surface); border:1px solid var(--line);
  border-radius:var(--r-md); padding:16px; text-align:center;
  transition:all 0.3s ease;
}
.statCard:hover {
  border-color:rgba(180,78,248,0.2); transform:translateY(-3px);
  box-shadow:0 8px 24px rgba(0,0,0,0.2), 0 0 12px rgba(180,78,248,0.06);
}
.statCard:hover .statVal { transform:scale(1.08); }
.statVal { transition:transform 0.3s ease; }
.admin-plan-pill { font-size:10px; text-transform:uppercase; font-weight:700; letter-spacing:.5px; }
.admin-plan-free    { background:var(--panel-2); color:var(--muted); border-color:var(--line); }
.admin-plan-pro     { background:rgba(99,179,237,0.12); color:#63b3ed; border-color:rgba(99,179,237,0.25); }
.admin-plan-premium { background:rgba(254,202,87,0.12); color:#feca57; border-color:rgba(254,202,87,0.25); }
.statVal {
  font-size:28px; font-weight:800;
  background:linear-gradient(135deg,var(--accent),#ff8fa3);
  -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text;
}
.statLabel {
  font-size:11px; font-weight:600; color:var(--text-2);
  margin-top:2px; text-transform:uppercase; letter-spacing:0.4px;
}

/* ══════════════════════════════════════════
   Ratings
   ══════════════════════════════════════════ */
.ratingRow { display:flex; gap:2px; margin-top:6px; }
.ratingStar {
  border:0; background:transparent; color:var(--muted);
  font-size:18px; cursor:pointer; padding:0 1px; line-height:1;
  transition:all var(--t);
}
.ratingStar:hover { transform:scale(1.15); }
.ratingStar.filled { color:var(--warning); text-shadow:0 0 6px rgba(254,202,87,0.35); }
.ratingDisplay { font-size:12px; color:var(--warning); }

/* ══════════════════════════════════════════
   Toast
   ══════════════════════════════════════════ */
.toast {
  position:fixed; bottom:24px; left:50%; transform:translateX(-50%);
  background:var(--panel); border:1px solid var(--line);
  border-left:3px solid var(--accent);
  color:var(--text); border-radius:var(--r-sm);
  padding:10px 18px; z-index:200;
  font-weight:600; font-size:13px;
  box-shadow:0 12px 40px rgba(0,0,0,0.5), 0 0 12px rgba(180,78,248,0.1);
  animation:toastIn 0.4s cubic-bezier(0.34,1.56,0.64,1);
}
@keyframes toastIn {
  from { opacity:0; transform:translateX(-50%) translateY(20px) scale(0.9); }
  to { opacity:1; transform:translateX(-50%) translateY(0) scale(1); }
}

.call-loading {
  position: fixed;
  left: 50%;
  bottom: 24px;
  transform: translateX(-50%);
  z-index: 220;
  display: inline-flex;
  align-items: center;
  gap: 10px;
  background: var(--panel);
  border: 1px solid var(--line);
  border-left: 3px solid var(--accent);
  border-radius: var(--r-sm);
  color: var(--text);
  padding: 10px 14px;
  box-shadow: 0 12px 40px rgba(0,0,0,0.5), 0 0 12px rgba(180,78,248,0.1);
  font-weight: 600;
  font-size: 13px;
  animation: toastIn 0.25s ease;
}
.call-loading-spinner {
  width: 14px;
  height: 14px;
  border-radius: 50%;
  border: 2px solid rgba(255,255,255,0.2);
  border-top-color: var(--accent);
  animation: spinLoader 0.85s linear infinite;
}
@keyframes spinLoader {
  from { transform: rotate(0deg); }
  to { transform: rotate(360deg); }
}

/* ══════════════════════════════════════════
   Call Overlay — Glassy Premium
   ══════════════════════════════════════════ */
.callOverlay {
  position:fixed; inset:0; z-index:999;
  background:rgba(11,13,18,0.6);
  backdrop-filter:blur(12px); -webkit-backdrop-filter:blur(12px);
  display:flex; align-items:center; justify-content:center;
}
.callOverlay.hidden { display:none; }

.callOverlayInner {
  display:flex; flex-direction:column; align-items:center;
  gap:16px; max-width:400px; width:100%; padding:48px 24px;
  background:none;
  border:none;
  border-radius:0;
  box-shadow:none;
}

.callAvatarLarge {
  width:110px; height:110px; border-radius:var(--r-pill);
  --voice-scale: 1;
  --voice-shadow-1: 26px;
  --voice-shadow-2: 56px;
  --voice-alpha: 0.26;
  --ring-opacity: 0.2;
  background:linear-gradient(135deg,var(--accent),#c96ffb,#9d3ae8);
  background-size:200% 200%;
  animation:logoGradient 4s ease infinite;
  display:flex; align-items:center; justify-content:center;
  font-size:42px; font-weight:800; color:#fff;
  transform:scale(var(--voice-scale));
  box-shadow:
    0 0 var(--voice-shadow-1) rgba(180,78,248,var(--voice-alpha)),
    0 0 var(--voice-shadow-2) rgba(180,78,248,0.14);
  transition:transform 90ms linear, box-shadow 90ms linear;
  will-change:transform, box-shadow;
  position:relative;
}
.callAvatarLarge.has-photo {
  animation:none;
  background-size:cover;
  background-position:center;
  color:transparent;
  font-size:0;
}
.callAvatarLarge::after {
  content:""; position:absolute; inset:-6px;
  border-radius:var(--r-pill);
  border:2px solid rgba(180,78,248,var(--ring-opacity));
  transition:border-color 90ms linear;
  animation:none;
}
.callAvatarLarge.callAvatarTalking::after {
  box-shadow:0 0 20px rgba(180,78,248,0.18);
}
@keyframes callAvatarGlow {
  0%,100% { box-shadow:0 0 40px var(--accent-glow), 0 0 80px rgba(180,78,248,0.08); }
  50% { box-shadow:0 0 60px rgba(180,78,248,0.35), 0 0 100px rgba(180,78,248,0.12); }
}
@keyframes callRingPulse {
  0%,100% { transform:scale(1); opacity:0.6; }
  50% { transform:scale(1.08); opacity:0.2; }
}

.callName {
  font-size:24px; font-weight:800; letter-spacing:-0.3px;
  margin-top:4px;
  text-shadow:0 2px 12px rgba(0,0,0,0.3);
}
.callStatus {
  font-size:13px; color:rgba(255,255,255,0.5); font-weight:500;
  letter-spacing:0.3px; text-transform:uppercase;
}
.callTimer {
  font-size:36px; font-weight:200; color:rgba(255,255,255,0.4);
  font-variant-numeric:tabular-nums; letter-spacing:2px;
  text-shadow:0 0 20px rgba(180,78,248,0.15);
}

.callTranscript {
  width:100%; max-height:180px; overflow-y:auto;
  display:flex; flex-direction:column; gap:6px; padding:10px;
  background:rgba(0,0,0,0.15);
  border-radius:var(--r-md);
  border:1px solid rgba(255,255,255,0.05);
}
.callTranscriptLine {
  font-size:12px; color:rgba(255,255,255,0.7);
  padding:8px 12px; border-radius:12px; max-width:85%;
  animation:msgInLeft 0.3s ease;
}
.callTranscriptLine.user {
  align-self:flex-end; background:rgba(180,78,248,0.15); color:var(--accent);
  border-bottom-right-radius:4px;
  animation:msgInRight 0.3s ease;
}
.callTranscriptLine.character {
  align-self:flex-start; background:rgba(255,255,255,0.06);
  border-bottom-left-radius:4px;
}

.callControls {
  display:flex; gap:24px; margin-top:16px;
  justify-content:center; align-items:center;
}
.callCtrlBtn {
  width:56px; height:56px; border-radius:50%;
  border:1px solid rgba(255,255,255,0.1); background:rgba(255,255,255,0.08);
  cursor:pointer; color:#fff;
  transition:all 0.25s ease;
  display:grid; place-items:center;
  padding:0;
  box-shadow:0 4px 16px rgba(0,0,0,0.2), inset 0 1px 0 rgba(255,255,255,0.1);
}
.callCtrlBtn svg { width:22px; height:22px; }
.callCtrlBtn:hover {
  background:rgba(255,255,255,0.12); border-color:rgba(255,255,255,0.18);
  transform:scale(1.1);
  box-shadow:0 6px 20px rgba(0,0,0,0.3);
}
.callCtrlBtn:active { transform:scale(0.93); }
.callCtrlBtn.hangup {
  width:56px; height:56px;
  background:var(--danger); border:none;
  box-shadow:0 4px 24px rgba(255,107,107,0.35);
}
.callCtrlBtn.hangup:hover {
  background:#ff5252; transform:scale(1.1);
  box-shadow:0 8px 32px rgba(255,107,107,0.45);
}

/* ══════════════════════════════════════════
   Skeleton / Loading
   ══════════════════════════════════════════ */
@keyframes shimmer {
  0% { background-position:-200% 0; }
  100% { background-position:200% 0; }
}
.skeleton {
  background:linear-gradient(90deg,var(--surface) 25%,rgba(180,78,248,0.06) 50%,var(--surface) 75%);
  background-size:200% 100%; animation:shimmer 1.8s ease-in-out infinite; border-radius:var(--r-sm);
}
.slide-up { animation:slideUp 0.35s ease-out; }
@keyframes slideUp {
  from { opacity:0; transform:translateY(12px); }
  to { opacity:1; transform:translateY(0); }
}

/* ══════════════════════════════════════════
   Mobile Bottom Nav
   ══════════════════════════════════════════ */
.bottom-nav {
  display:none;
  background:var(--sidebar-bg);
  border-top:1px solid var(--line);
  padding:4px 8px calc(2px + env(safe-area-inset-bottom, 0px));
  flex-shrink:0;
}
.bottom-nav-item {
  display:flex; flex-direction:column; align-items:center;
  justify-content:center; gap:2px;
  background:none; border:none; color:var(--text-2);
  font-size:10px; font-weight:600; cursor:pointer;
  padding:6px 4px; border-radius:var(--r-xs);
  transition:all var(--t); flex:1;
}
.bottom-nav-item svg { width:20px; height:20px; }
.bottom-nav-item.active { color:var(--accent); }
.bottom-nav-item:hover { color:var(--text); }

/* ══════════════════════════════════════════
   Responsive — Mobile (< 768px)
   ══════════════════════════════════════════ */
@media (max-width:768px) {
  body {
    overflow:auto;
  }
  .app {
    grid-template-columns:1fr;
    padding-top:max(env(safe-area-inset-top), 0px);
    padding-bottom:0;
    height:100vh;
    height:100dvh;
  }
  .main {
    height:100%;
    min-height:0;
  }

  /* Sidebar: hidden by default, slide-in on mobile */
  .sidebar {
    position:fixed; left:0; top:0; bottom:0;
    padding-top:max(env(safe-area-inset-top), 0px);
    width:var(--sidebar-w);
    transform:translateX(-100%);
    transition:transform 0.25s ease;
    z-index:80;
  }
  .sidebar.open {
    transform:translateX(0);
  }

  .mobile-menu-btn { display:flex; }

  .bottom-nav {
    display:grid; grid-template-columns:repeat(5,1fr);
  }

  .topbar {
    padding:0 12px;
  }
  .topbar-title {
    font-size:15px;
  }

  /* iOS Safari zooms focused form fields if font-size < 16px */
  input,
  textarea,
  select,
  .cp-select-trigger {
    font-size:16px;
  }

  .page-header {
    flex-wrap:wrap;
    margin-bottom:14px;
  }
  .page-header h2 {
    font-size:18px;
  }

  .discover-search-bar {
    flex-direction:column;
    align-items:stretch;
    gap:8px;
  }
  .discover-search-bar select {
    width:100%;
  }
  .section-label {
    flex-wrap:wrap;
    gap:8px;
  }

  /* Chat layout: single column with toggle */
  .chat-layout {
    grid-template-columns:1fr !important;
  }
  .chat-main {
    position:absolute; inset:0; z-index:2;
    transform:translateX(100%);
    transition:transform 0.25s ease;
    pointer-events:none;
  }
  .chat-layout.show-chat .chat-main {
    transform:translateX(0);
    pointer-events:auto;
  }
  .chat-layout.show-chat .chat-sidebar { display:none; }
  .chat-back-btn { display:flex; }
  .page-chats { position:relative; }

  .page { padding:16px; }
  .page:last-child { padding-bottom:calc(24px + env(safe-area-inset-bottom, 0px)); }
  .page-chats { padding:0 !important; }
  .discover-quick-row { flex-direction:column; }
  .card-grid { grid-template-columns:repeat(2,1fr); }
  .options-grid { grid-template-columns:1fr; }
  .field-span-2 { grid-column:span 1; }
  .create-studio-grid { grid-template-columns:1fr; }
  .voice-tips-grid { grid-template-columns:1fr; }
  .voice-actions { flex-wrap:wrap; }
  .voice-actions .ghost-btn {
    flex:1 1 calc(50% - 4px);
    min-height:38px;
  }
  .voice-recorder-meta {
    flex-wrap: wrap;
  }
  .voice-record-timer {
    text-align: left;
  }
  .custom-voice-row {
    flex-wrap: wrap;
    align-items: flex-start;
  }
  .custom-voice-actions {
    width: 100%;
    justify-content: flex-end;
  }
  .voice-custom-grid {
    flex-direction:column;
  }

  .chat-header {
    padding:10px 12px;
    gap:8px;
  }
  .chat-toolbar {
    padding:6px 12px;
    gap:6px;
  }
  .chat-toolbar .ghost-btn {
    flex:1 1 calc(50% - 3px);
    min-height:36px;
  }
  .messages {
    padding:12px;
  }
  .chat-composer {
    padding:10px 12px;
    gap:6px;
    position:sticky;
    bottom:0;
    z-index:3;
  }
  .chat-composer textarea {
    min-height:38px;
    max-height:88px;
  }

  .notifDropdown {
    position:fixed;
    top:56px;
    left:8px;
    right:8px;
    width:auto;
    max-height:calc(100dvh - 76px);
  }

  .cp-select-menu {
    max-height:42dvh;
  }

  .character-contact {
    padding:10px 4px;
    gap:10px;
  }

  .callOverlayInner {
    max-width:100%;
    padding:24px 14px;
  }
  .callControls {
    gap:20px;
  }
  .callCtrlBtn {
    width:52px; height:52px;
  }
  .callCtrlBtn.hangup {
    width:52px; height:52px;
  }

  .msg { max-width:85%; }
}

@media (max-width:480px) {
  .page { padding:12px; }
  .page-chats { padding:0 !important; }
  .card-grid { grid-template-columns:1fr 1fr; gap:8px; }
  .discover-card-name { font-size:13px; }
  .auth-card {
    padding:24px 16px;
    border-radius:var(--r-lg);
  }
  .topbar-actions {
    gap:4px;
  }
  .topbar-icon-btn {
    width:34px;
    height:34px;
  }
  .chat-toolbar .ghost-btn {
    flex:1 1 100%;
  }
  .bottom-nav-item {
    padding:6px 2px;
    font-size:9px;
  }
  .bottom-nav-item svg {
    width:18px; height:18px;
  }
}

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

/* ══════════════════════════════════════════
   Documents (RAG) — Creator Studio
   ══════════════════════════════════════════ */
.char-documents {
  margin-top:28px;
  padding-top:20px;
  border-top:1px solid var(--line);
}
.char-documents-header {
  display:flex;
  align-items:center;
  gap:8px;
  margin-bottom:4px;
}
.char-documents-title {
  font-weight:600;
  font-size:13px;
  color:var(--text);
}
.char-documents-hint {
  margin-bottom:12px;
}
.doc-list {
  display:flex;
  flex-direction:column;
  gap:6px;
  margin-bottom:12px;
}
.doc-empty {
  padding:10px 0;
}
.doc-item {
  display:flex;
  align-items:center;
  gap:10px;
  background:var(--surface);
  border:1px solid var(--line);
  border-radius:var(--r-sm);
  padding:10px 12px;
  transition:border-color var(--t);
}
.doc-item:hover {
  border-color:var(--line-hover);
}
.doc-item-icon {
  flex-shrink:0;
  color:var(--text-2);
}
.doc-item-info {
  flex:1;
  min-width:0;
}
.doc-item-name {
  font-size:13px;
  font-weight:500;
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
}
.doc-item-meta {
  display:flex;
  gap:8px;
  margin-top:2px;
}
.doc-status-ready { color:var(--good); }
.doc-status-error { color:var(--danger); }
.doc-status-processing { color:var(--warning); }
.doc-status-pending { color:var(--muted); }
.doc-item-pending { opacity:0.75; }
.doc-status-en-done { color:var(--good); font-size:11px; }
.doc-status-en-progress { color:var(--warning); font-size:11px; }
.reindex-progress { margin-bottom:12px; display:flex; flex-direction:column; gap:6px; padding:10px 12px; background:var(--surface); border-radius:var(--r); border:1px solid var(--line); }
.reindex-bar-track { height:4px; background:var(--line); border-radius:var(--r-pill); overflow:hidden; }
.reindex-bar-fill { height:100%; background:var(--accent); border-radius:var(--r-pill); width:0%; transition:width 0.4s ease; }
.doc-item-actions { display:flex; align-items:center; gap:4px; flex-shrink:0; }
.doc-upload-progress { margin-top:10px; display:flex; flex-direction:column; gap:6px; }
.doc-upload-bar-track { height:4px; background:var(--surface); border-radius:var(--r-pill); overflow:hidden; }
.doc-upload-bar-fill { height:100%; background:var(--accent); border-radius:var(--r-pill); width:0%; transition:width 0.3s ease; }
.doc-upload-row {
  display:flex;
  align-items:center;
  gap:12px;
  flex-wrap:wrap;
}

/* ══════════════════════════════════════════
   Premium / Pricing
   ══════════════════════════════════════════ */

/* Sidebar nav premium button */
.nav-item-premium {
  color: #feca57;
  position: relative;
}
.nav-item-premium:hover { background: rgba(254,202,87,0.1); }
.nav-item-premium svg { stroke: #feca57; }
.nav-item-premium.active { background: rgba(254,202,87,0.15); }

/* Premium badge in sidebar for active subscribers */
.sidebar-premium-badge {
  display:inline-flex; align-items:center; gap:4px;
  font-size:10px; font-weight:700; letter-spacing:0.05em; text-transform:uppercase;
  color:#feca57; background:rgba(254,202,87,0.15); border:1px solid rgba(254,202,87,0.3);
  border-radius:var(--r-pill); padding:2px 8px; margin-left:auto;
}

/* Pricing page */
.pricing-hero {
  text-align:center;
  padding:32px 16px 24px;
}
.pricing-hero-icon {
  width:56px; height:56px; border-radius:50%;
  background:rgba(254,202,87,0.15); border:1px solid rgba(254,202,87,0.3);
  color:#feca57;
  display:inline-flex; align-items:center; justify-content:center;
  margin-bottom:16px;
}
.pricing-hero h2 { margin:0 0 8px; }
.pricing-hero .muted { margin:0; }

.pricing-cards {
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:16px;
  max-width:920px;
  margin:0 auto;
}

.pricing-card {
  background:var(--surface);
  border:1px solid var(--line);
  border-radius:var(--r-lg);
  padding:24px;
  position:relative;
  display:flex;
  flex-direction:column;
  gap:12px;
}
.pricing-card-pro {
  border-color:rgba(116,185,255,0.4);
  background:linear-gradient(160deg, rgba(116,185,255,0.06) 0%, transparent 60%);
}
.pricing-card-pro .pricing-card-tier { color:#74b9ff; }
.pricing-card-premium {
  border-color:rgba(254,202,87,0.4);
  background:linear-gradient(160deg, rgba(254,202,87,0.06) 0%, transparent 60%);
}
.pricing-card-badge {
  position:absolute;
  top:-11px;
  left:50%;
  transform:translateX(-50%);
  background:#feca57;
  color:#0a0a0a;
  font-size:11px;
  font-weight:700;
  letter-spacing:0.04em;
  padding:2px 12px;
  border-radius:var(--r-pill);
  white-space:nowrap;
}
.pricing-card-tier {
  font-size:12px;
  font-weight:700;
  letter-spacing:0.08em;
  text-transform:uppercase;
  color:var(--text-2);
}
.pricing-card-premium .pricing-card-tier { color:#feca57; }

.pricing-card-price {
  display:flex;
  align-items:baseline;
  gap:4px;
}
.pricing-amount {
  font-size:32px;
  font-weight:800;
  color:var(--text-1);
  line-height:1;
}
.pricing-period {
  font-size:14px;
  color:var(--muted);
}

.pricing-features {
  list-style:none;
  padding:0;
  margin:0;
  display:flex;
  flex-direction:column;
  gap:8px;
  flex:1;
}
.pricing-feature {
  display:flex;
  align-items:center;
  gap:8px;
  font-size:13px;
  color:var(--text-2);
}
.pricing-feature svg { flex-shrink:0; }
.pricing-feature.ok svg { stroke:#00cec9; }
.pricing-feature.no { color:var(--muted); }
.pricing-feature.no svg { stroke:var(--muted); }

.pricing-paypal-wrap {
  margin-top:8px;
}
.pricing-current-badge {
  text-align:center;
  padding:8px;
  font-size:12px;
  color:var(--muted);
  border:1px solid var(--line);
  border-radius:var(--r);
}
.pricing-premium-active {
  display:flex;
  flex-direction:column;
  align-items:center;
  gap:8px;
  margin-top:8px;
}
.pricing-premium-badge {
  display:inline-flex; align-items:center; gap:6px;
  color:#feca57;
  font-weight:700;
  font-size:14px;
}
.pricing-premium-badge svg { stroke:#feca57; }

.pricing-grace-notice {
  display:flex; align-items:center; gap:6px;
  margin-top:8px;
  font-size:13px;
  color:var(--muted);
  justify-content:center;
}
.pricing-grace-notice svg { stroke:var(--accent); flex-shrink:0; }

.pricing-legal-links {
  text-align:center;
  font-size:12px;
  color:var(--muted);
  margin-top:24px;
  padding-bottom:16px;
}
.pricing-legal-links .link-btn {
  background:none; border:none; padding:0;
  color:var(--muted); font-size:12px; cursor:pointer;
  text-decoration:underline;
  text-underline-offset:2px;
}
.pricing-legal-links .link-btn:hover { color:var(--fg); }

.auth-legal-links {
  text-align:center;
  font-size:12px;
  color:var(--muted);
  margin-top:16px;
}
.auth-legal-links a {
  color:var(--muted);
  text-decoration:underline;
  text-underline-offset:2px;
}
.auth-legal-links a:hover { color:var(--fg); }

/* Legal pages */
.legal-content {
  max-width:680px;
  margin:0 auto;
  padding:0 16px 48px;
  line-height:1.7;
}
.legal-content h3 {
  font-size:15px;
  font-weight:700;
  margin:24px 0 8px;
  color:var(--fg);
}
.legal-content p {
  font-size:14px;
  color:var(--muted);
  margin:0 0 12px;
}
.legal-content a { color:var(--accent); }

/* Paywall prompt modal */
.paywall-overlay {
  position:fixed; inset:0; z-index:9000;
  background:rgba(0,0,0,0.7);
  display:flex; align-items:center; justify-content:center;
  padding:16px;
  animation:fadeIn 0.15s ease;
}
.paywall-card {
  background:var(--panel);
  border:1px solid var(--line);
  border-radius:var(--r-lg);
  padding:32px 28px;
  max-width:380px;
  width:100%;
  text-align:center;
  display:flex;
  flex-direction:column;
  gap:14px;
}
.paywall-icon {
  width:52px; height:52px; border-radius:50%;
  background:rgba(254,202,87,0.15); border:1px solid rgba(254,202,87,0.3);
  color:#feca57;
  display:inline-flex; align-items:center; justify-content:center;
  margin:0 auto;
}
.paywall-card h3 { margin:0; font-size:18px; }
.paywall-card p { margin:0; color:var(--text-2); font-size:14px; }
.paywall-actions { display:flex; flex-direction:column; gap:8px; margin-top:4px; }

@media (max-width:860px) {
  .pricing-cards { grid-template-columns:1fr; }
}
@media (min-width:861px) and (max-width:1080px) {
  .pricing-cards { grid-template-columns:1fr 1fr; }
  .pricing-cards > .pricing-card:first-child { grid-column:span 2; }
}
