/* OFM CRM — Shared Styles */
@import url('https://fonts.googleapis.com/css2?family=DM+Sans:wght@300;400;500;600&family=DM+Mono:wght@400;500&display=swap');

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

:root {
  --bg: #0a0a0b; --bg2: #111113; --bg3: #18181b; --bg4: #1f1f23;
  --border: rgba(255,255,255,0.07); --border2: rgba(255,255,255,0.12);
  --text: #f0f0f0; --text2: #888890; --text3: #555560;
  --accent: #6c63ff; --accent2: #8b84ff; --accent-bg: rgba(108,99,255,0.12);
  --green: #22c55e; --green-bg: rgba(34,197,94,0.1);
  --red: #ef4444; --red-bg: rgba(239,68,68,0.1);
  --amber: #f59e0b; --amber-bg: rgba(245,158,11,0.1);
  --pink: #ec4899; --pink-bg: rgba(236,72,153,0.1);
  --sidebar-w: 224px;
  --font: 'DM Sans', sans-serif;
  --mono: 'DM Mono', monospace;
}

body {
  font-family: var(--font);
  background: var(--bg);
  color: var(--text);
  display: flex;
  height: 100vh;
  max-height: 100vh;
  overflow: hidden;
  font-size: 13px;
}

/* ── SIDEBAR ── */
:root {
  --sidebar-w: 224px;
  --sidebar-collapsed-w: 48px;
  --sidebar-transition: 0.2s ease;
}

#sidebar {
  width: var(--sidebar-w);
  min-width: var(--sidebar-w);
  max-width: var(--sidebar-w);
  height: 100vh;
  background: var(--bg2);
  border-right: 1px solid var(--border);
  display: flex;
  flex-direction: column;
  overflow-y: auto;
  overflow-x: hidden;
  flex-shrink: 0;
  transition: width var(--sidebar-transition), min-width var(--sidebar-transition), max-width var(--sidebar-transition);
  position: relative;
  z-index: 20;
}
#sidebar::-webkit-scrollbar { width: 0; }

/* ── Collapsed state ── */
#sidebar.collapsed {
  width: var(--sidebar-collapsed-w);
  min-width: var(--sidebar-collapsed-w);
  max-width: var(--sidebar-collapsed-w);
}

/* ── Logo ── */
.logo {
  height: 52px;
  padding: 0 10px;
  border-bottom: 1px solid var(--border);
  display: flex;
  align-items: center;
  gap: 10px;
  flex-shrink: 0;
  overflow: hidden;
  cursor: pointer;
  user-select: none;
}
.logo:hover { background: var(--bg3); }
.logo-icon {
  width: 28px; height: 28px;
  background: var(--accent); border-radius: 7px;
  display: flex; align-items: center; justify-content: center;
  font-size: 9px; font-weight: 800; color: #fff;
  flex-shrink: 0;
}
.logo-text {
  flex: 1; min-width: 0; overflow: hidden;
  opacity: 1; transition: opacity var(--sidebar-transition);
}
.logo-name { font-size: 13px; font-weight: 700; color: var(--text); letter-spacing: -0.4px; white-space: nowrap; }
.logo-sub { font-size: 8.5px; color: var(--text3); text-transform: uppercase; letter-spacing: 0.5px; margin-top: 1px; white-space: nowrap; }
.logo-toggle {
  width: 18px; height: 18px; border-radius: 4px;
  background: var(--bg4); display: flex; align-items: center; justify-content: center;
  flex-shrink: 0; color: var(--text3); transition: background 0.15s, color 0.15s;
}
.logo-toggle svg { width: 10px; height: 10px; transition: transform var(--sidebar-transition); flex-shrink: 0; }
.logo:hover .logo-toggle { background: var(--bg3); color: var(--text2); }
#sidebar.collapsed .logo-text { opacity: 0; width: 0; min-width: 0; }
#sidebar.collapsed .logo-toggle { opacity: 0; width: 0; }
#sidebar.collapsed .logo-toggle svg { transform: rotate(180deg); }

/* ── Nav sections ── */
.nav-section { padding: 6px 6px 2px; }

.nav-label {
  font-size: 9px; font-weight: 700; color: var(--text3);
  text-transform: uppercase; letter-spacing: 1px;
  padding: 5px 8px 3px; margin-bottom: 1px;
  display: flex; align-items: center; justify-content: space-between;
  cursor: pointer; user-select: none;
  white-space: nowrap; overflow: hidden;
  max-height: 24px;
  transition: max-height var(--sidebar-transition), opacity var(--sidebar-transition), padding var(--sidebar-transition);
}
.nav-label svg { width: 10px; height: 10px; opacity: 0.4; transition: transform 0.2s; flex-shrink: 0; }
.nav-label.collapsed svg { transform: rotate(-90deg); }

/* Hide section labels when collapsed */
#sidebar.collapsed .nav-label {
  max-height: 0;
  opacity: 0;
  padding: 0;
  margin: 0;
  pointer-events: none;
}
#sidebar.collapsed .nav-section { padding: 2px 6px; }

/* ── Nav items ── */
.nav-item {
  display: flex;
  align-items: center;
  gap: 9px;
  padding: 7px 8px;
  border-radius: 7px;
  cursor: pointer; color: var(--text2);
  font-size: 12.5px; font-weight: 400;
  transition: background 0.15s, color 0.15s;
  text-decoration: none;
  white-space: nowrap;
  overflow: hidden;
  position: relative;
}
.nav-item > svg { width: 15px; height: 15px; flex-shrink: 0; opacity: 0.6; }
.nav-item:hover { background: var(--bg4); color: var(--text); }
.nav-item:hover > svg { opacity: 1; }
.nav-item.active { background: var(--accent-bg); color: var(--accent2); font-weight: 500; }
.nav-item.active > svg { opacity: 1; }
.nav-item > span { flex: 1; overflow: hidden; text-overflow: ellipsis; transition: opacity var(--sidebar-transition), max-width var(--sidebar-transition); max-width: 200px; }

/* Collapsed nav items — icon only, centred */
#sidebar.collapsed .nav-item {
  justify-content: center;
  padding: 9px 0;
  width: var(--sidebar-collapsed-w);
}
#sidebar.collapsed .nav-item > span { max-width: 0; opacity: 0; overflow: hidden; }
#sidebar.collapsed .nav-badge { display: none; }

/* Tooltip */
#sidebar.collapsed .nav-item::after {
  content: attr(data-label);
  position: fixed;
  left: calc(var(--sidebar-collapsed-w) + 6px);
  background: var(--bg3);
  border: 1px solid var(--border2);
  color: var(--text);
  font-size: 11.5px;
  font-weight: 500;
  padding: 5px 10px;
  border-radius: 7px;
  white-space: nowrap;
  pointer-events: none;
  opacity: 0;
  transition: opacity 0.1s;
  z-index: 1000;
  box-shadow: 0 4px 20px rgba(0,0,0,0.5);
}
#sidebar.collapsed .nav-item:hover::after { opacity: 1; }

/* ── Badges ── */
.nav-badge {
  margin-left: auto; font-size: 9px; font-weight: 700;
  padding: 1px 5px; border-radius: 4px;
  background: var(--accent-bg); color: var(--accent2); flex-shrink: 0;
}
.nav-badge.new { background: var(--green-bg); color: var(--green); }
.nav-badge.stub { background: rgba(239,68,68,0.1); color: #ef4444; }

/* ── Sidebar bottom ── */
.sidebar-bottom { margin-top: auto; border-top: 1px solid var(--border); padding: 6px; }
#sidebar.collapsed .sidebar-bottom { padding: 6px; }

/* AI Balance widget */
.ai-balance-widget { display: flex; align-items: center; gap: 9px; padding: 8px 10px; margin: 0 2px 4px; border-radius: 8px; background: var(--bg3); border: 1px solid var(--border); overflow: hidden; transition: opacity var(--sidebar-transition); }
.ai-balance-dot { width: 8px; height: 8px; border-radius: 50%; flex-shrink: 0; }
.ai-balance-info { min-width: 0; overflow: hidden; }
.ai-balance-label { font-size: 10px; color: var(--text3); text-transform: uppercase; letter-spacing: .5px; white-space: nowrap; }
.ai-balance-val { font-size: 13px; font-weight: 600; white-space: nowrap; }
#sidebar.collapsed .ai-balance-widget { justify-content: center; padding: 8px 0; }
#sidebar.collapsed .ai-balance-info { display: none; }

/* Logout */
.sidebar-logout {
  display: flex; align-items: center; gap: 9px;
  padding: 7px 8px; border-radius: 7px;
  cursor: pointer; color: var(--text2);
  font-size: 12.5px; font-weight: 400;
  transition: background 0.15s, color 0.15s;
  background: none; border: none;
  width: 100%; font-family: var(--font); text-align: left;
  white-space: nowrap; overflow: hidden;
}
.sidebar-logout:hover { background: var(--red-bg); color: var(--red); }
.sidebar-logout > svg { width: 15px; height: 15px; flex-shrink: 0; opacity: 0.6; }
.sidebar-logout:hover > svg { opacity: 1; }
.sidebar-logout > span { flex: 1; overflow: hidden; text-overflow: ellipsis; transition: opacity var(--sidebar-transition), max-width var(--sidebar-transition); max-width: 200px; }
#sidebar.collapsed .sidebar-logout { justify-content: center; padding: 9px 0; }
#sidebar.collapsed .sidebar-logout > span { max-width: 0; opacity: 0; overflow: hidden; }

/* ── MAIN ── */
.main { flex: 1; display: flex; flex-direction: column; overflow: hidden; min-width: 0; }

#topbar { height: 50px; border-bottom: 1px solid var(--border); display: flex; align-items: center; padding: 0 22px; gap: 10px; flex-shrink: 0; background: var(--bg2); }
.topbar-title { font-size: 14px; font-weight: 500; }
.topbar-right { margin-left: auto; display: flex; align-items: center; gap: 9px; }

.lang-switcher { display: flex; background: var(--bg4); border: 1px solid var(--border); border-radius: 7px; overflow: hidden; }
.lang-btn { padding: 4px 11px; font-size: 11px; font-weight: 700; font-family: var(--font); cursor: pointer; border: none; background: transparent; color: var(--text2); transition: all 0.15s; }
.lang-btn.active { background: var(--accent); color: #fff; }
.lang-btn:hover:not(.active) { color: var(--text); }

.icon-btn { width: 30px; height: 30px; border-radius: 7px; background: var(--bg4); border: 1px solid var(--border); display: flex; align-items: center; justify-content: center; cursor: pointer; position: relative; transition: all 0.15s; color: var(--text2); }
.icon-btn:hover { background: var(--bg3); color: var(--text); }
.icon-btn svg { width: 14px; height: 14px; }
.notif-dot { width: 6px; height: 6px; background: var(--red); border-radius: 50%; position: absolute; top: 5px; right: 5px; border: 1.5px solid var(--bg2); }
.topbar-logout-btn { width: 30px; height: 30px; border-radius: 7px; background: var(--bg4); border: 1px solid var(--border); display: flex; align-items: center; justify-content: center; cursor: pointer; color: var(--text2); transition: all 0.15s; flex-shrink: 0; }
.topbar-logout-btn:hover { background: var(--red-bg); border-color: var(--red); color: var(--red); }
.avatar { width: 30px; height: 30px; border-radius: 50%; background: var(--accent); display: flex; align-items: center; justify-content: center; font-size: 10px; font-weight: 700; color: #fff; cursor: pointer; }
.avatar-name { font-size: 12px; color: var(--text2); }

.content { flex: 1; overflow-y: auto; padding: 20px 22px; background: var(--bg); }
.content::-webkit-scrollbar { width: 4px; }
.content::-webkit-scrollbar-thumb { background: var(--bg4); border-radius: 4px; }

/* ── COMMON COMPONENTS ── */
.page-header { display: flex; align-items: center; justify-content: space-between; margin-bottom: 18px; }
.page-title { font-size: 20px; font-weight: 600; letter-spacing: -0.4px; }

.btn { display: flex; align-items: center; gap: 6px; padding: 7px 14px; border-radius: 8px; font-size: 12.5px; font-family: var(--font); font-weight: 500; cursor: pointer; border: none; transition: all 0.15s; white-space: nowrap; }
.btn-primary { background: var(--accent); color: #fff; }
.btn-primary:hover { background: var(--accent2); }
.btn-ghost { background: transparent; border: 1px solid var(--border); color: var(--text2); }
.btn-ghost:hover { background: var(--bg4); color: var(--text); border-color: var(--border2); }
.btn svg { width: 13px; height: 13px; }

.badge { display: inline-flex; align-items: center; gap: 4px; padding: 3px 8px; border-radius: 5px; font-size: 10.5px; font-weight: 600; }
.badge-green { background: var(--green-bg); color: var(--green); }
.badge-red { background: var(--red-bg); color: var(--red); }
.badge-amber { background: var(--amber-bg); color: var(--amber); }
.badge-gray { background: var(--bg4); color: var(--text2); }
.badge-purple { background: var(--accent-bg); color: var(--accent2); }
.badge-pink { background: var(--pink-bg); color: var(--pink); }
.badge-dot { width: 5px; height: 5px; border-radius: 50%; background: currentColor; flex-shrink: 0; }

.card { background: var(--bg2); border: 1px solid var(--border); border-radius: 12px; }
.mono { font-family: var(--mono); font-size: 12px; }

.table-wrap { background: var(--bg2); border: 1px solid var(--border); border-radius: 12px; overflow: hidden; }
table { width: 100%; border-collapse: collapse; }
thead tr { border-bottom: 1px solid var(--border); }
th { text-align: left; padding: 9px 13px; font-size: 10px; font-weight: 600; color: var(--text3); text-transform: uppercase; letter-spacing: 0.6px; white-space: nowrap; cursor: pointer; user-select: none; }
th:hover { color: var(--text2); }
td { padding: 10px 13px; font-size: 12.5px; border-bottom: 1px solid var(--border); white-space: nowrap; vertical-align: middle; }
tbody tr:last-child td { border-bottom: none; }
tbody tr { transition: background 0.1s; }
tbody tr:hover { background: var(--bg3); }

.section-header { display: flex; align-items: center; justify-content: space-between; margin-bottom: 10px; }
.section-title { font-size: 13px; font-weight: 500; }

.tabs { display: flex; gap: 2px; border-bottom: 1px solid var(--border); margin-bottom: 18px; }
.tab { padding: 9px 16px; font-size: 13px; color: var(--text2); cursor: pointer; border-bottom: 2px solid transparent; margin-bottom: -1px; transition: all 0.15s; }
.tab:hover { color: var(--text); }
.tab.active { color: var(--accent2); border-bottom-color: var(--accent); font-weight: 500; }

.search-wrap { display: flex; align-items: center; gap: 7px; background: var(--bg2); border: 1px solid var(--border); border-radius: 8px; padding: 6px 10px; transition: border-color 0.15s; }
.search-wrap:focus-within { border-color: var(--accent); }
.search-wrap svg { width: 12px; height: 12px; color: var(--text3); flex-shrink: 0; }
.search-wrap input { background: none; border: none; outline: none; color: var(--text); font-size: 12px; font-family: var(--font); width: 100%; }
.search-wrap input::placeholder { color: var(--text3); }

.filter-select { background: var(--bg2); border: 1px solid var(--border); border-radius: 8px; color: var(--text); font-size: 12px; font-family: var(--font); padding: 6px 26px 6px 10px; cursor: pointer; outline: none; appearance: none; -webkit-appearance: none; background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6'%3E%3Cpath d='M1 1l4 4 4-4' stroke='%23555560' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E"); background-repeat: no-repeat; background-position: right 8px center; }
.filter-select option { background: var(--bg3); }

.pagination { display: flex; align-items: center; justify-content: space-between; padding: 9px 13px; border-top: 1px solid var(--border); font-size: 11.5px; color: var(--text2); }
.page-btns { display: flex; gap: 3px; }
.page-btn { width: 26px; height: 26px; border-radius: 6px; display: flex; align-items: center; justify-content: center; font-size: 11px; cursor: pointer; border: 1px solid var(--border); background: transparent; color: var(--text2); font-family: var(--font); transition: all 0.15s; }
.page-btn:hover { background: var(--bg4); color: var(--text); }
.page-btn.active { background: var(--accent); border-color: var(--accent); color: #fff; }

.toggle { width: 34px; height: 19px; background: var(--accent); border-radius: 10px; position: relative; cursor: pointer; flex-shrink: 0; }
.toggle::after { content: ''; position: absolute; width: 13px; height: 13px; background: #fff; border-radius: 50%; top: 3px; right: 3px; transition: all 0.2s; }
.toggle.off { background: var(--bg4); }
.toggle.off::after { right: auto; left: 3px; }

/* MODAL */
.overlay { position: fixed; inset: 0; background: rgba(0,0,0,0.7); z-index: 100; display: flex; align-items: center; justify-content: center; opacity: 0; pointer-events: none; transition: opacity 0.2s; }
.overlay.open { opacity: 1; pointer-events: all; }
.modal { background: var(--bg2); border: 1px solid var(--border2); border-radius: 16px; width: 480px; max-width: 95vw; max-height: 90vh; overflow-y: auto; transform: translateY(16px) scale(0.98); transition: transform 0.2s; }
.overlay.open .modal { transform: translateY(0) scale(1); }
.modal::-webkit-scrollbar { width: 0; }
.modal-header { padding: 20px 22px 16px; border-bottom: 1px solid var(--border); display: flex; align-items: flex-start; justify-content: space-between; }
.modal-title { font-size: 16px; font-weight: 600; letter-spacing: -0.3px; }
.modal-sub { font-size: 12px; color: var(--text2); margin-top: 3px; }
.modal-close { width: 28px; height: 28px; border-radius: 7px; background: var(--bg4); border: 1px solid var(--border); display: flex; align-items: center; justify-content: center; cursor: pointer; color: var(--text2); transition: all 0.15s; flex-shrink: 0; }
.modal-close:hover { background: var(--bg3); color: var(--text); }
.modal-close svg { width: 12px; height: 12px; }
.modal-body { padding: 20px 22px; }
.modal-footer { padding: 14px 22px; border-top: 1px solid var(--border); display: flex; justify-content: flex-end; gap: 8px; }

/* FORM */
.form-group { margin-bottom: 16px; }
.form-label { font-size: 11.5px; font-weight: 500; color: var(--text2); margin-bottom: 6px; display: block; }
.form-input { width: 100%; background: var(--bg3); border: 1px solid var(--border); border-radius: 8px; color: var(--text); font-size: 13px; font-family: var(--font); padding: 9px 12px; outline: none; transition: border-color 0.15s; }
.form-input:focus { border-color: var(--accent); }
.form-input::placeholder { color: var(--text3); }
.form-select { width: 100%; background: var(--bg3); border: 1px solid var(--border); border-radius: 8px; color: var(--text); font-size: 13px; font-family: var(--font); padding: 9px 30px 9px 12px; outline: none; appearance: none; -webkit-appearance: none; background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6'%3E%3Cpath d='M1 1l4 4 4-4' stroke='%23555560' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E"); background-repeat: no-repeat; background-position: right 10px center; cursor: pointer; transition: border-color 0.15s; }
.form-select:focus { border-color: var(--accent); }
.form-hint { font-size: 11px; color: var(--text3); margin-top: 5px; line-height: 1.5; }

/* SAVE BAR */
.save-bar { position: sticky; bottom: 0; background: var(--bg2); border-top: 1px solid var(--border); padding: 12px 26px; display: flex; align-items: center; justify-content: space-between; }
.save-hint { font-size: 11.5px; color: var(--text3); }
.save-actions { display: flex; gap: 8px; }

/* ACCOUNT AVATAR */
.account-ava { width: 30px; height: 30px; border-radius: 50%; display: flex; align-items: center; justify-content: center; font-size: 10px; font-weight: 700; flex-shrink: 0; }
.account-cell { display: flex; align-items: center; gap: 9px; }
.account-name { font-weight: 500; font-size: 12.5px; }
.account-handle { font-size: 10.5px; color: var(--text2); margin-top: 1px; }

/* STAT CHIPS */
.stat-chips { display: flex; gap: 8px; margin-bottom: 18px; flex-wrap: wrap; }
.stat-chip { background: var(--bg2); border: 1px solid var(--border); border-radius: 8px; padding: 8px 14px; display: flex; align-items: center; gap: 8px; }
.stat-chip-val { font-size: 16px; font-weight: 600; font-family: var(--mono); }
.stat-chip-label { font-size: 11px; color: var(--text2); }
.stat-chip-dot { width: 8px; height: 8px; border-radius: 50%; flex-shrink: 0; }

/* METRIC CARDS */
.metrics-scroll { overflow-x: auto; margin-bottom: 16px; padding-bottom: 3px; }
.metrics-scroll::-webkit-scrollbar { height: 3px; }
.metrics-scroll::-webkit-scrollbar-thumb { background: var(--bg4); border-radius: 3px; }
.metrics-row { display: flex; gap: 8px; min-width: max-content; }
.metric-card { background: var(--bg2); border: 1px solid var(--border); border-radius: 10px; padding: 11px 14px; min-width: 118px; cursor: default; transition: border-color 0.15s; }
.metric-card:hover { border-color: var(--border2); }
.metric-label { font-size: 10px; color: var(--text2); margin-bottom: 5px; white-space: nowrap; display: flex; align-items: center; gap: 3px; }
.metric-val { font-size: 17px; font-weight: 600; font-family: var(--mono); letter-spacing: -0.5px; }
.metric-change { font-size: 10px; margin-top: 3px; }
.up { color: var(--green); }
.down { color: var(--red); }
.flat { color: var(--text3); }
.pos { color: var(--green); }

/* ACTION BUTTONS */
.action-btn { background: none; border: 1px solid var(--border); border-radius: 6px; color: var(--text2); padding: 4px 9px; font-size: 11px; font-family: var(--font); cursor: pointer; transition: all 0.15s; }
.action-btn:hover { background: var(--bg4); color: var(--text); border-color: var(--border2); }
.icon-action { width: 28px; height: 28px; border-radius: 6px; border: 1px solid var(--border); background: none; display: flex; align-items: center; justify-content: center; cursor: pointer; color: var(--text2); transition: all 0.15s; }
.icon-action:hover { background: var(--bg4); color: var(--text); border-color: var(--border2); }
.icon-action svg { width: 12px; height: 12px; }
.actions-cell { display: flex; align-items: center; gap: 6px; }



/* ============================================================ */
/* PAGE-SPECIFIC STYLES (extracted from inline <style> blocks) */
/* ============================================================ */


/* --- ACCOUNTS --- */
.filters-bar{display:flex;align-items:center;gap:10px;margin-bottom:16px;flex-wrap:wrap}
.filter-tags{display:flex;gap:6px;margin-left:auto}
.filter-tag{display:flex;align-items:center;gap:5px;padding:4px 10px;border-radius:6px;font-size:11px;font-weight:500;background:var(--bg4);border:1px solid var(--border);color:var(--text2);cursor:pointer;transition:all .15s}
.filter-tag:hover{border-color:var(--border2);color:var(--text)}
.filter-tag.active{background:var(--accent-bg);border-color:rgba(108,99,255,.3);color:var(--accent2)}
.steps{display:flex;align-items:center;gap:6px;margin-bottom:22px}
.step{display:flex;align-items:center;gap:6px;font-size:12px;color:var(--text3)}
.step-num{width:22px;height:22px;border-radius:50%;border:1.5px solid var(--border);display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:600;flex-shrink:0}
.step.active .step-num{background:var(--accent);border-color:var(--accent);color:#fff}
.step.active{color:var(--text);font-weight:500}
.step.done .step-num{background:var(--green);border-color:var(--green);color:#fff}
.step-sep{flex:1;height:1px;background:var(--border)}
.platform-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:20px}
.platform-card{background:var(--bg3);border:1.5px solid var(--border);border-radius:10px;padding:14px 16px;cursor:pointer;transition:all .15s;display:flex;align-items:center;gap:12px}
.platform-card:hover{border-color:var(--border2)}
.platform-card.selected{border-color:var(--accent);background:var(--accent-bg)}
.platform-card.disabled{opacity:.4;cursor:not-allowed}
.platform-icon{width:36px;height:36px;border-radius:9px;display:flex;align-items:center;justify-content:center;font-size:18px;flex-shrink:0}
.platform-name{font-size:13px;font-weight:500}
.platform-desc{font-size:11px;color:var(--text2);margin-top:2px}
.platform-check{width:18px;height:18px;border-radius:50%;border:1.5px solid var(--border2);margin-left:auto;flex-shrink:0;display:flex;align-items:center;justify-content:center}
.platform-card.selected .platform-check{background:var(--accent);border-color:var(--accent)}
.platform-check svg{width:10px;height:10px;color:#fff;display:none}
.platform-card.selected .platform-check svg{display:block}
.oauth-btn{width:100%;display:flex;align-items:center;justify-content:center;gap:10px;padding:11px 16px;border-radius:10px;border:1.5px solid var(--accent);background:var(--accent-bg);color:var(--accent2);font-size:13px;font-weight:500;font-family:var(--font);cursor:pointer;transition:all .15s;margin-bottom:16px}
.oauth-btn:hover{background:var(--accent);color:#fff}
.oauth-divider{display:flex;align-items:center;gap:12px;margin-bottom:16px}
.oauth-divider-line{flex:1;height:1px;background:var(--border)}
.oauth-divider-text{font-size:11px;color:var(--text3);white-space:nowrap}
.info-box{background:var(--bg4);border:1px solid var(--border);border-radius:8px;padding:12px 14px;margin-bottom:16px;display:flex;gap:10px}
.info-box svg{width:14px;height:14px;color:var(--accent2);flex-shrink:0;margin-top:1px}
.info-box-text{font-size:12px;color:var(--text2);line-height:1.6}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:12px}

/* --- AI CHAT --- */
.chat-layout{display:grid;grid-template-columns:260px 1fr 280px;height:calc(100vh - 100px);gap:0;background:var(--bg2);border:1px solid var(--border);border-radius:12px;overflow:hidden}
.chat-list{border-right:1px solid var(--border);display:flex;flex-direction:column}
.chat-list-header{padding:12px 14px;border-bottom:1px solid var(--border)}
.chat-search{display:flex;align-items:center;gap:7px;background:var(--bg4);border:1px solid var(--border);border-radius:7px;padding:6px 10px}
.chat-search svg{width:12px;height:12px;color:var(--text3);flex-shrink:0}
.chat-search input{background:none;border:none;outline:none;color:var(--text);font-size:12px;font-family:var(--font);width:100%}
.chat-scroll{flex:1;overflow-y:auto}
.chat-scroll::-webkit-scrollbar{width:0}
.chat-item{padding:10px 14px;cursor:pointer;transition:background .15s;border-bottom:1px solid var(--border);display:flex;align-items:center;gap:10px}
.chat-item:hover{background:var(--bg3)}
.chat-item.active{background:var(--accent-bg)}
.chat-ava{width:36px;height:36px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:700;flex-shrink:0;position:relative}
.online-dot{position:absolute;bottom:0;right:0;width:9px;height:9px;background:var(--green);border-radius:50%;border:2px solid var(--bg2)}
.chat-item-info{flex:1;min-width:0}
.chat-item-top{display:flex;align-items:center;justify-content:space-between}
.chat-fan-name{font-size:12.5px;font-weight:500}
.chat-time{font-size:10px;color:var(--text3)}
.chat-preview{font-size:11.5px;color:var(--text2);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-top:2px}
.chat-unread{width:16px;height:16px;background:var(--accent);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:9px;font-weight:700;color:#fff;flex-shrink:0}
.chat-main{display:flex;flex-direction:column}
.chat-topbar{padding:12px 16px;border-bottom:1px solid var(--border);display:flex;align-items:center;gap:12px}
.chat-fan-ava{width:34px;height:34px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:700}
.chat-fan-info{flex:1}
.chat-fan-nm{font-size:13px;font-weight:500}
.chat-fan-status{font-size:11px;color:var(--green)}
.chat-actions{display:flex;gap:6px}
.chat-messages{flex:1;overflow-y:auto;padding:16px;display:flex;flex-direction:column;gap:10px}
.chat-messages::-webkit-scrollbar{width:3px}
.chat-messages::-webkit-scrollbar-thumb{background:var(--bg4);border-radius:3px}
.msg{max-width:75%;display:flex;flex-direction:column;gap:3px}
.msg.fan{align-self:flex-start}
.msg.model{align-self:flex-end}
.msg-bubble{padding:9px 13px;border-radius:12px;font-size:13px;line-height:1.5}
.msg.fan .msg-bubble{background:var(--bg4);color:var(--text);border-bottom-left-radius:3px}
.msg.model .msg-bubble{background:var(--accent);color:#fff;border-bottom-right-radius:3px}
.msg-time{font-size:10px;color:var(--text3)}
.msg.model .msg-time{text-align:right}
.msg-ppv{background:var(--bg3);border:1px solid var(--border);border-radius:10px;padding:10px 14px;display:flex;align-items:center;gap:10px;max-width:240px}
.msg-ppv-icon{font-size:24px}
.msg-ppv-label{font-size:11.5px;color:var(--text2)}
.msg-ppv-price{font-size:15px;font-weight:700;color:var(--accent2);font-family:var(--mono)}
.msg-ppv-btn{margin-left:auto;padding:5px 12px;background:var(--accent);color:#fff;border:none;border-radius:6px;font-size:11.5px;font-family:var(--font);cursor:pointer}
.chat-input-wrap{padding:12px 16px;border-top:1px solid var(--border)}
.ai-suggestions{display:flex;gap:6px;margin-bottom:8px;overflow-x:auto;padding-bottom:2px}
.ai-suggestions::-webkit-scrollbar{height:0}
.ai-suggestion{padding:5px 12px;background:var(--accent-bg);border:1px solid rgba(108,99,255,.2);border-radius:20px;font-size:11.5px;color:var(--accent2);cursor:pointer;white-space:nowrap;transition:all .15s;flex-shrink:0}
.ai-suggestion:hover{background:var(--accent);color:#fff}
.chat-input-row{display:flex;align-items:flex-end;gap:8px}
.chat-input{flex:1;background:var(--bg3);border:1px solid var(--border);border-radius:10px;color:var(--text);font-size:13px;font-family:var(--font);padding:9px 13px;outline:none;resize:none;min-height:40px;max-height:120px;transition:border-color .15s;line-height:1.5}
.chat-input:focus{border-color:var(--accent)}
.send-btn{width:38px;height:38px;background:var(--accent);border:none;border-radius:9px;display:flex;align-items:center;justify-content:center;cursor:pointer;flex-shrink:0;transition:background .15s}
.send-btn:hover{background:var(--accent2)}
.send-btn svg{width:16px;height:16px;color:#fff}
.attach-btn{width:34px;height:34px;background:var(--bg4);border:1px solid var(--border);border-radius:8px;display:flex;align-items:center;justify-content:center;cursor:pointer;flex-shrink:0;color:var(--text2);transition:all .15s}
.attach-btn:hover{background:var(--bg3);color:var(--text)}
.attach-btn svg{width:14px;height:14px}
.fan-panel{border-left:1px solid var(--border);display:flex;flex-direction:column;overflow-y:auto}
.fan-panel::-webkit-scrollbar{width:0}
.fan-panel-header{padding:14px 16px;border-bottom:1px solid var(--border)}
.fan-panel-title{font-size:12px;font-weight:600;color:var(--text2);text-transform:uppercase;letter-spacing:.6px}
.fan-profile{padding:16px;border-bottom:1px solid var(--border);text-align:center}
.fan-profile-ava{width:56px;height:56px;border-radius:50%;margin:0 auto 10px;display:flex;align-items:center;justify-content:center;font-size:20px;font-weight:700}
.fan-profile-name{font-size:14px;font-weight:600;margin-bottom:3px}
.fan-profile-sub{font-size:11.5px;color:var(--text2)}
.fan-stats{padding:12px 16px;border-bottom:1px solid var(--border);display:grid;grid-template-columns:1fr 1fr;gap:8px}
.fan-stat-card{background:var(--bg3);border-radius:7px;padding:8px 10px}
.fan-stat-val{font-size:15px;font-weight:600;font-family:var(--mono)}
.fan-stat-label{font-size:10px;color:var(--text2);margin-top:2px}
.fan-ai-block{padding:14px 16px}
.fan-ai-title{font-size:12px;font-weight:600;color:var(--text2);text-transform:uppercase;letter-spacing:.6px;margin-bottom:10px}
.ai-mode-toggle{display:flex;background:var(--bg4);border-radius:8px;padding:2px;margin-bottom:12px}
.ai-mode-btn{flex:1;padding:5px;border-radius:6px;font-size:11px;font-family:var(--font);cursor:pointer;border:none;background:transparent;color:var(--text2);transition:all .15s;text-align:center}
.ai-mode-btn.active{background:var(--bg2);color:var(--text);font-weight:500}
.ai-toggle-row{display:flex;align-items:center;justify-content:space-between;padding:8px 0;border-bottom:1px solid var(--border)}
.ai-toggle-row:last-child{border-bottom:none}
.ai-toggle-label{font-size:12px;font-weight:500}
.ai-toggle-desc{font-size:10.5px;color:var(--text2);margin-top:1px}

/* --- DASHBOARD --- */
.org-header { background: var(--bg2); border: 1px solid var(--border); border-radius: 12px; padding: 15px 20px; display: flex; align-items: center; gap: 14px; margin-bottom: 16px; }
  .org-avatar { width: 40px; height: 40px; border-radius: 10px; background: var(--bg4); border: 1px solid var(--border2); display: flex; align-items: center; justify-content: center; font-size: 18px; flex-shrink: 0; }
  .org-info h2 { font-size: 14px; font-weight: 600; }
  .org-info p { font-size: 11px; color: var(--text2); margin-top: 2px; }
  .org-stats { margin-left: auto; display: flex; gap: 28px; }
  .org-stat { text-align: center; }
  .org-stat-val { font-size: 19px; font-weight: 600; font-family: var(--mono); }
  .org-stat-label { font-size: 10px; color: var(--text2); margin-top: 2px; }
  .filters-row { background: var(--bg2); border: 1px solid var(--border); border-radius: 12px; padding: 12px 18px; display: flex; align-items: flex-end; gap: 12px; margin-bottom: 16px; flex-wrap: wrap; }
  .filter-group { display: flex; flex-direction: column; gap: 4px; }
  .filter-label { font-size: 9.5px; color: var(--text3); text-transform: uppercase; letter-spacing: 0.7px; font-weight: 600; }
  .toggle-group { display: flex; align-items: center; gap: 7px; margin-top: 2px; }
  .select-sm { background: var(--bg4); border: 1px solid var(--border); border-radius: 7px; color: var(--text2); font-size: 11px; font-family: var(--font); padding: 4px 22px 4px 8px; cursor: pointer; outline: none; appearance: none; -webkit-appearance: none; background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6'%3E%3Cpath d='M1 1l4 4 4-4' stroke='%23555560' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E"); background-repeat: no-repeat; background-position: right 6px center; }
  .btn-sm { display: flex; align-items: center; gap: 5px; padding: 5px 11px; border-radius: 7px; font-size: 12px; font-family: var(--font); font-weight: 500; cursor: pointer; border: none; transition: all 0.15s; }
  .btn-sm svg { width: 12px; height: 12px; }

/* --- INSIGHTS --- */
.filters-row{background:var(--bg2);border:1px solid var(--border);border-radius:12px;padding:12px 18px;display:flex;align-items:flex-end;gap:12px;margin-bottom:18px;flex-wrap:wrap}
.filter-group{display:flex;flex-direction:column;gap:4px}
.filter-label{font-size:9.5px;color:var(--text3);text-transform:uppercase;letter-spacing:.7px;font-weight:600}
.kpi-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:10px;margin-bottom:18px}
.kpi-card{background:var(--bg2);border:1px solid var(--border);border-radius:12px;padding:16px 18px;transition:border-color .15s}
.kpi-card:hover{border-color:var(--border2)}
.kpi-label{font-size:10.5px;color:var(--text2);margin-bottom:8px;display:flex;align-items:center;justify-content:space-between}
.kpi-val{font-size:24px;font-weight:700;font-family:var(--mono);letter-spacing:-1px}
.kpi-change{font-size:11px;margin-top:5px;display:flex;align-items:center;gap:4px}
.chart-grid{display:grid;grid-template-columns:2fr 1fr;gap:12px;margin-bottom:18px}
.chart-card{background:var(--bg2);border:1px solid var(--border);border-radius:12px;padding:18px}
.chart-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}
.chart-title{font-size:13px;font-weight:500}
.chart-tabs{display:flex;gap:2px;background:var(--bg4);border-radius:7px;padding:2px}
.chart-tab{padding:4px 10px;border-radius:5px;font-size:11px;cursor:pointer;color:var(--text2);transition:all .15s}
.chart-tab.active{background:var(--bg2);color:var(--text);font-weight:500}
.fans-list{display:flex;flex-direction:column;gap:6px}
.fan-item{display:flex;align-items:center;gap:10px;padding:8px 10px;background:var(--bg3);border-radius:8px;transition:background .15s}
.fan-item:hover{background:var(--bg4)}
.fan-ava{width:28px;height:28px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:10px;font-weight:700;flex-shrink:0}
.fan-name{font-size:12.5px;font-weight:500}
.fan-spent{font-size:11px;color:var(--text2)}
.fan-val{margin-left:auto;font-family:var(--mono);font-size:12px;color:var(--green)}
.bottom-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.time-grid{display:grid;grid-template-columns:repeat(24,1fr);gap:2px}
.time-cell{height:28px;border-radius:3px;background:var(--bg4);position:relative;cursor:pointer;transition:opacity .15s}
.time-cell:hover{opacity:.8}
.day-labels{display:grid;grid-template-columns:repeat(24,1fr);gap:2px;margin-bottom:4px}
.day-label{font-size:9px;color:var(--text3);text-align:center}

/* --- KNOWLEDGE BASE --- */
.kb-layout{display:grid;grid-template-columns:220px 1fr;gap:16px}
.kb-nav{background:var(--bg2);border:1px solid var(--border);border-radius:12px;padding:12px;height:fit-content}
.kb-nav-title{font-size:10px;font-weight:600;color:var(--text3);text-transform:uppercase;letter-spacing:.8px;margin-bottom:8px;padding:0 6px}
.kb-nav-item{display:flex;align-items:center;gap:8px;padding:7px 8px;border-radius:7px;cursor:pointer;color:var(--text2);font-size:12.5px;transition:all .15s;text-decoration:none}
.kb-nav-item:hover{background:var(--bg4);color:var(--text)}
.kb-nav-item.active{background:var(--accent-bg);color:var(--accent2);font-weight:500}
.kb-nav-item svg{width:13px;height:13px;flex-shrink:0;opacity:.65}
.kb-nav-item.active svg{opacity:1}
.kb-nav-sep{height:1px;background:var(--border);margin:8px 0}
.kb-content{display:flex;flex-direction:column;gap:14px}
.kb-search-wrap{background:var(--bg2);border:1px solid var(--border);border-radius:12px;padding:16px 20px}
.kb-search-row{display:flex;align-items:center;gap:10px}
.kb-search-input{flex:1;background:var(--bg3);border:1px solid var(--border);border-radius:8px;color:var(--text);font-size:13px;font-family:var(--font);padding:9px 14px;outline:none;transition:border-color .15s}
.kb-search-input:focus{border-color:var(--accent)}
.kb-search-input::placeholder{color:var(--text3)}
.articles-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:12px}
.article-card{background:var(--bg2);border:1px solid var(--border);border-radius:10px;padding:16px;cursor:pointer;transition:all .15s;text-decoration:none;display:block}
.article-card:hover{border-color:var(--accent);background:var(--bg3)}
.article-icon{width:36px;height:36px;border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:18px;margin-bottom:10px}
.article-title{font-size:13px;font-weight:500;color:var(--text);margin-bottom:5px;line-height:1.4}
.article-desc{font-size:11.5px;color:var(--text2);line-height:1.5}
.article-footer{display:flex;align-items:center;gap:8px;margin-top:10px}
.article-tag{font-size:10px;padding:2px 7px;border-radius:4px;background:var(--bg4);color:var(--text3)}
.article-date{font-size:10px;color:var(--text3);margin-left:auto}
.lock-badge{display:flex;align-items:center;gap:3px;font-size:10px;padding:2px 7px;border-radius:4px;background:var(--amber-bg);color:var(--amber)}
.section-header-row{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px}
.section-label{font-size:12px;font-weight:600;color:var(--text2);text-transform:uppercase;letter-spacing:.6px}

/* --- MASS MESSAGES --- */
.mm-layout{display:grid;grid-template-columns:1fr 340px;gap:16px;height:calc(100vh - 130px)}
.mm-main{display:flex;flex-direction:column;gap:14px;overflow-y:auto;padding-right:4px}
.mm-main::-webkit-scrollbar{width:3px}
.mm-main::-webkit-scrollbar-thumb{background:var(--bg4);border-radius:3px}
.compose-card{background:var(--bg2);border:1px solid var(--border);border-radius:12px;padding:18px 20px}
.compose-title{font-size:13px;font-weight:500;margin-bottom:14px}
.field-row{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:12px}
.field-label{font-size:10.5px;color:var(--text3);text-transform:uppercase;letter-spacing:.6px;font-weight:600;margin-bottom:5px}
.field-input{width:100%;background:var(--bg3);border:1px solid var(--border);border-radius:8px;color:var(--text);font-size:13px;font-family:var(--font);padding:8px 11px;outline:none;transition:border-color .15s}
.field-input:focus{border-color:var(--accent)}
.field-input::placeholder{color:var(--text3)}
.field-select{width:100%;background:var(--bg3);border:1px solid var(--border);border-radius:8px;color:var(--text);font-size:13px;font-family:var(--font);padding:8px 28px 8px 11px;outline:none;appearance:none;-webkit-appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6'%3E%3Cpath d='M1 1l4 4 4-4' stroke='%23555560' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 9px center;cursor:pointer;transition:border-color .15s}
.field-select:focus{border-color:var(--accent)}
.field-select option{background:var(--bg3)}
.field-textarea{width:100%;background:var(--bg3);border:1px solid var(--border);border-radius:8px;color:var(--text);font-size:13px;font-family:var(--font);padding:10px 11px;outline:none;transition:border-color .15s;resize:vertical;min-height:90px;line-height:1.6}
.field-textarea:focus{border-color:var(--accent)}
.field-textarea::placeholder{color:var(--text3)}
.media-upload{border:2px dashed var(--border);border-radius:8px;padding:20px;text-align:center;cursor:pointer;transition:all .15s;margin-bottom:12px}
.media-upload:hover{border-color:var(--accent);background:var(--accent-bg)}
.media-upload-icon{font-size:24px;margin-bottom:6px}
.media-upload-text{font-size:12px;color:var(--text2)}
.media-upload-hint{font-size:10.5px;color:var(--text3);margin-top:2px}
.price-row{display:flex;align-items:center;gap:10px;margin-bottom:12px}
.price-toggle{display:flex;align-items:center;gap:8px;padding:8px 12px;background:var(--bg3);border:1px solid var(--border);border-radius:8px;cursor:pointer;transition:all .15s;flex:1}
.price-toggle:hover{border-color:var(--border2)}
.price-toggle.active{border-color:var(--accent);background:var(--accent-bg)}
.price-toggle-label{font-size:12px;font-weight:500}
.price-toggle-desc{font-size:10.5px;color:var(--text2);margin-top:1px}
.compose-actions{display:flex;align-items:center;justify-content:space-between;padding-top:14px;border-top:1px solid var(--border)}
.compose-hint{font-size:11px;color:var(--text3)}
.history-card{background:var(--bg2);border:1px solid var(--border);border-radius:12px;overflow:hidden}
.history-header{padding:14px 16px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between}
.history-title{font-size:13px;font-weight:500}
.history-item{padding:12px 16px;border-bottom:1px solid var(--border);transition:background .15s;cursor:pointer}
.history-item:hover{background:var(--bg3)}
.history-item:last-child{border-bottom:none}
.history-item-top{display:flex;align-items:center;justify-content:space-between;margin-bottom:4px}
.history-name{font-size:12.5px;font-weight:500}
.history-date{font-size:10.5px;color:var(--text3)}
.history-preview{font-size:11.5px;color:var(--text2);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-bottom:6px}
.history-stats{display:flex;gap:10px}
.history-stat{font-size:10.5px;color:var(--text3);display:flex;align-items:center;gap:3px}
.history-stat span{color:var(--text2);font-weight:500}
.side-panel{display:flex;flex-direction:column;gap:12px}
.side-card{background:var(--bg2);border:1px solid var(--border);border-radius:12px;padding:16px}
.side-title{font-size:12px;font-weight:600;color:var(--text2);text-transform:uppercase;letter-spacing:.6px;margin-bottom:12px}
.audience-option{display:flex;align-items:center;gap:10px;padding:8px 10px;border-radius:8px;cursor:pointer;transition:all .15s;border:1px solid transparent}
.audience-option:hover{background:var(--bg4)}
.audience-option.selected{background:var(--accent-bg);border-color:rgba(108,99,255,.3)}
.audience-icon{width:30px;height:30px;border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:14px;flex-shrink:0}
.audience-name{font-size:12.5px;font-weight:500}
.audience-count{font-size:11px;color:var(--text2)}
.audience-check{width:16px;height:16px;border-radius:50%;border:1.5px solid var(--border2);margin-left:auto;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.audience-option.selected .audience-check{background:var(--accent);border-color:var(--accent)}
.est-card{background:var(--bg3);border-radius:8px;padding:12px 14px}
.est-row{display:flex;align-items:center;justify-content:space-between;margin-bottom:6px}
.est-row:last-child{margin-bottom:0}
.est-label{font-size:11.5px;color:var(--text2)}
.est-val{font-size:12px;font-weight:600;font-family:var(--mono)}

/* --- MODEL CARDS --- */
/* Layout */
.cards-layout{display:grid;grid-template-columns:240px 1fr;gap:14px;align-items:flex-start}
.cards-sidebar{display:flex;flex-direction:column;gap:8px;position:sticky;top:0}

/* Card list item */
.model-list-item{background:var(--bg2);border:1px solid var(--border);border-radius:10px;padding:11px 12px;cursor:pointer;transition:all .15s;display:flex;align-items:center;gap:10px;overflow:hidden}
.model-list-item:hover{border-color:var(--border2);background:var(--bg3)}
.model-list-item.active{border-color:var(--accent);background:var(--accent-bg)}
.mli-ava{width:38px;height:38px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:700;flex-shrink:0}
.mli-name{font-size:13px;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.mli-nick{font-size:11px;color:var(--text2);margin-top:1px}
.mli-status{margin-left:auto;width:7px;height:7px;border-radius:50%;flex-shrink:0}

/* Detail panel */
.card-detail{background:var(--bg2);border:1px solid var(--border);border-radius:12px;overflow:hidden;min-width:0}
.card-hero{padding:24px 24px 0;display:flex;align-items:flex-start;gap:18px;border-bottom:1px solid var(--border);padding-bottom:20px}
.hero-ava{width:72px;height:72px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:24px;font-weight:700;flex-shrink:0;border:2px solid var(--border2)}
.hero-info{flex:1}
.hero-name{font-size:20px;font-weight:700;letter-spacing:-.4px}
.hero-nick{font-size:13px;color:var(--accent2);margin-top:2px;font-family:var(--mono)}
.hero-tagline{font-size:12px;color:var(--text2);margin-top:6px;line-height:1.5;max-width:480px}
.hero-badges{display:flex;gap:6px;margin-top:10px;flex-wrap:wrap}
.hero-actions{display:flex;gap:8px;margin-left:auto;flex-shrink:0}

/* Tabs inside card */
.card-tabs{display:flex;gap:0;border-bottom:1px solid var(--border);padding:0 24px;overflow-x:auto;flex-shrink:0;background:var(--bg2);border-radius:12px 12px 0 0;}
.card-tab{padding:10px 16px;font-size:12.5px;color:var(--text2);cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-1px;transition:all .15s;white-space:nowrap}
.card-tab:hover{color:var(--text)}
.card-tab.active{color:var(--accent2);border-bottom-color:var(--accent);font-weight:500}

/* Tab panes */
.tab-panes-wrap{overflow:hidden;min-width:0}
.tab-pane{display:none !important;padding:20px 24px;min-width:0}
.tab-pane.active{display:block !important}

/* Section */
.info-section{margin-bottom:22px}
.info-section-title{font-size:10px;font-weight:700;color:var(--text3);text-transform:uppercase;letter-spacing:.9px;margin-bottom:10px;display:flex;align-items:center;gap:6px}
.info-section-title svg{width:12px;height:12px}
.info-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.info-grid-3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:10px}
.info-field{background:var(--bg3);border-radius:8px;padding:9px 12px}
.info-field-label{font-size:10px;color:var(--text3);margin-bottom:4px;text-transform:uppercase;letter-spacing:.5px}
.info-field-val{font-size:12.5px;color:var(--text);font-weight:500;line-height:1.4}
.info-field-full{background:var(--bg3);border-radius:8px;padding:9px 12px;grid-column:1/-1}

/* Platform links */
.platform-links{display:grid;grid-template-columns:1fr 1fr;gap:8px}
.platform-link-card{background:var(--bg3);border:1px solid var(--border);border-radius:9px;padding:10px 12px;display:flex;align-items:center;gap:10px;text-decoration:none;transition:all .15s;cursor:pointer}
.platform-link-card:hover{border-color:var(--border2);background:var(--bg4)}
.pl-icon{width:32px;height:32px;border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:15px;flex-shrink:0}
.pl-name{font-size:12px;font-weight:500;color:var(--text)}
.pl-url{font-size:10.5px;color:var(--text2);margin-top:1px;font-family:var(--mono);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:140px}
.pl-arrow{margin-left:auto;color:var(--text3)}
.pl-arrow svg{width:12px;height:12px}

/* Satellite accounts */
.satellite-list{display:flex;flex-direction:column;gap:6px}
.satellite-item{background:var(--bg3);border:1px solid var(--border);border-radius:8px;padding:9px 12px;display:flex;align-items:center;gap:10px;transition:border-color .15s}
.satellite-item:hover{border-color:var(--border2)}
.sat-num{width:20px;height:20px;border-radius:5px;background:var(--bg4);display:flex;align-items:center;justify-content:center;font-size:10px;font-weight:600;color:var(--text3);flex-shrink:0}
.sat-url{font-size:12px;color:var(--accent2);font-family:var(--mono);flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.sat-geo{font-size:11px;color:var(--text2);background:var(--bg4);padding:2px 8px;border-radius:5px;white-space:nowrap;flex-shrink:0}
.sat-actions{display:flex;gap:5px;flex-shrink:0}

.add-satellite-btn{border:1.5px dashed var(--border);border-radius:8px;padding:9px 12px;display:flex;align-items:center;justify-content:center;gap:7px;font-size:12px;color:var(--text3);cursor:pointer;transition:all .15s;background:transparent;width:100%;font-family:var(--font)}
.add-satellite-btn:hover{border-color:var(--accent);color:var(--accent2);background:var(--accent-bg)}

/* Voice & phrases */
.phrase-list{display:flex;flex-direction:column;gap:6px}
.phrase-item{background:var(--bg3);border-left:2px solid var(--accent);border-radius:0 7px 7px 0;padding:8px 12px;font-size:12px;color:var(--text);line-height:1.5;font-style:italic}

.emoji-list{display:flex;gap:8px;flex-wrap:wrap}
.emoji-chip{background:var(--bg3);border-radius:7px;padding:6px 10px;font-size:16px;cursor:default}

/* Prompt box */
.prompt-box{background:var(--bg3);border:1px solid var(--border);border-radius:9px;padding:12px 14px;font-size:12px;font-family:var(--mono);color:var(--text2);line-height:1.7;position:relative}
.prompt-copy{position:absolute;top:8px;right:8px;background:var(--bg4);border:1px solid var(--border);border-radius:6px;padding:3px 9px;font-size:10.5px;color:var(--text2);cursor:pointer;font-family:var(--font);transition:all .15s}
.prompt-copy:hover{background:var(--bg2);color:var(--text)}

/* Appearance tags */
.appearance-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:8px}
.appear-item{background:var(--bg3);border-radius:8px;padding:8px 10px}
.appear-label{font-size:9.5px;color:var(--text3);text-transform:uppercase;letter-spacing:.5px;margin-bottom:3px}
.appear-val{font-size:12px;font-weight:500}

/* Red flags */
.redflag-list{display:flex;flex-wrap:wrap;gap:6px}
.redflag-chip{background:var(--red-bg);border:1px solid rgba(239,68,68,.2);border-radius:6px;padding:3px 10px;font-size:11.5px;color:var(--red)}

/* Scroll inside tab — scroll the whole .content, not the tab pane */
.tab-pane::-webkit-scrollbar{width:3px}
.tab-pane::-webkit-scrollbar-thumb{background:var(--bg4);border-radius:3px}

/* Modal: satellite */
.geo-select{width:100%;background:var(--bg3);border:1px solid var(--border);border-radius:8px;color:var(--text);font-size:13px;font-family:var(--font);padding:9px 30px 9px 12px;outline:none;appearance:none;-webkit-appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6'%3E%3Cpath d='M1 1l4 4 4-4' stroke='%23555560' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 10px center;cursor:pointer;transition:border-color .15s}
.geo-select:focus{border-color:var(--accent)}
.geo-select option{background:var(--bg3)}

/* --- SETTINGS --- */
.settings-layout{display:grid;grid-template-columns:200px 1fr;gap:16px}
.settings-nav{background:var(--bg2);border:1px solid var(--border);border-radius:12px;padding:8px;height:fit-content}
.settings-nav-item{display:flex;align-items:center;gap:8px;padding:7px 10px;border-radius:7px;cursor:pointer;color:var(--text2);font-size:12.5px;transition:all .15s}
.settings-nav-item:hover{background:var(--bg4);color:var(--text)}
.settings-nav-item.active{background:var(--accent-bg);color:var(--accent2);font-weight:500}
.settings-nav-item svg{width:13px;height:13px;flex-shrink:0;opacity:.65}
.settings-nav-item.active svg{opacity:1}
.settings-content{display:flex;flex-direction:column;gap:14px}
.settings-card{background:var(--bg2);border:1px solid var(--border);border-radius:12px;overflow:hidden}
.settings-card-header{padding:14px 20px;border-bottom:1px solid var(--border)}
.settings-card-title{font-size:13px;font-weight:500}
.settings-card-desc{font-size:11.5px;color:var(--text2);margin-top:2px}
.settings-card-body{padding:16px 20px}
.settings-row{display:flex;align-items:center;justify-content:space-between;padding:10px 0;border-bottom:1px solid var(--border)}
.settings-row:last-child{border-bottom:none}
.settings-row-label{font-size:13px;font-weight:500}
.settings-row-desc{font-size:11.5px;color:var(--text2);margin-top:2px}
.field-row-2{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:14px}
.field-label{font-size:10.5px;color:var(--text3);text-transform:uppercase;letter-spacing:.6px;font-weight:600;margin-bottom:5px}
.field-input{width:100%;background:var(--bg3);border:1px solid var(--border);border-radius:8px;color:var(--text);font-size:13px;font-family:var(--font);padding:8px 11px;outline:none;transition:border-color .15s}
.field-input:focus{border-color:var(--accent)}
.field-input::placeholder{color:var(--text3)}
.field-select{width:100%;background:var(--bg3);border:1px solid var(--border);border-radius:8px;color:var(--text);font-size:13px;font-family:var(--font);padding:8px 28px 8px 11px;outline:none;appearance:none;-webkit-appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6'%3E%3Cpath d='M1 1l4 4 4-4' stroke='%23555560' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 9px center;cursor:pointer}
.danger-zone{background:rgba(239,68,68,.05);border:1px solid rgba(239,68,68,.15);border-radius:12px;padding:16px 20px}
.danger-zone-title{font-size:12px;font-weight:600;color:var(--red);text-transform:uppercase;letter-spacing:.6px;margin-bottom:12px}
.danger-row{display:flex;align-items:center;justify-content:space-between;padding:8px 0;border-bottom:1px solid rgba(239,68,68,.1)}
.danger-row:last-child{border-bottom:none}
.btn-danger{background:var(--red-bg);color:var(--red);border:1px solid rgba(239,68,68,.2);padding:5px 12px;border-radius:7px;font-size:12px;font-family:var(--font);cursor:pointer;transition:all .15s}
.btn-danger:hover{background:rgba(239,68,68,.2)}
.plan-card{background:var(--accent-bg);border:1px solid rgba(108,99,255,.3);border-radius:10px;padding:14px 16px;display:flex;align-items:center;gap:14px;margin-bottom:14px}
.plan-icon{font-size:24px}
.plan-name{font-size:15px;font-weight:700;color:var(--accent2)}
.plan-price{font-size:12px;color:var(--text2);margin-top:2px}
.plan-features{display:flex;gap:8px;flex-wrap:wrap;margin-top:6px}
.plan-feature{font-size:10.5px;padding:2px 8px;background:rgba(108,99,255,.15);color:var(--accent2);border-radius:4px}

/* --- TEAM --- */
.team-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:14px;margin-bottom:20px}
.member-card{background:var(--bg2);border:1px solid var(--border);border-radius:12px;padding:18px;transition:border-color .15s;cursor:pointer}
.member-card:hover{border-color:var(--border2)}
.member-top{display:flex;align-items:flex-start;gap:12px;margin-bottom:14px}
.member-ava{width:44px;height:44px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:15px;font-weight:700;flex-shrink:0}
.member-info{flex:1}
.member-name{font-size:14px;font-weight:600;margin-bottom:2px}
.member-role{font-size:11.5px;color:var(--text2)}
.member-handle{font-size:11px;color:var(--text3);margin-top:2px}
.member-stats{display:grid;grid-template-columns:1fr 1fr 1fr;gap:8px;margin-bottom:12px}
.mstat{text-align:center;background:var(--bg3);border-radius:7px;padding:7px 6px}
.mstat-val{font-size:14px;font-weight:600;font-family:var(--mono)}
.mstat-label{font-size:9.5px;color:var(--text2);margin-top:2px}
.member-footer{display:flex;align-items:center;justify-content:space-between}
.member-accounts{display:flex;gap:-6px}
.member-account-dot{width:22px;height:22px;border-radius:50%;border:2px solid var(--bg2);display:flex;align-items:center;justify-content:center;font-size:8px;font-weight:700;margin-left:-6px}
.member-account-dot:first-child{margin-left:0}
.shift-badge{display:flex;align-items:center;gap:4px;font-size:10.5px;padding:3px 8px;border-radius:5px}
.shift-on{background:var(--green-bg);color:var(--green)}
.shift-off{background:var(--bg4);color:var(--text2)}
.invite-card{background:var(--bg2);border:2px dashed var(--border);border-radius:12px;padding:18px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px;cursor:pointer;transition:all .15s;min-height:180px}
.invite-card:hover{border-color:var(--accent);background:var(--accent-bg)}
.invite-icon{width:44px;height:44px;border-radius:50%;background:var(--bg4);display:flex;align-items:center;justify-content:center}
.invite-icon svg{width:20px;height:20px;color:var(--text3)}
.invite-text{font-size:13px;font-weight:500;color:var(--text2)}
.invite-hint{font-size:11px;color:var(--text3)}

/* --- TRAFFIC --- */
.filter-chips-row{display:flex;align-items:center;gap:8px;margin-bottom:14px;flex-wrap:wrap}
.filter-chip{display:inline-flex;align-items:center;gap:5px;padding:5px 10px;border-radius:6px;font-size:11.5px;background:var(--bg2);border:1px solid var(--border);color:var(--text2);cursor:pointer;transition:all .15s;white-space:nowrap}
.filter-chip:hover{border-color:var(--border2);color:var(--text)}
.filter-chip.active{background:var(--accent-bg);border-color:rgba(108,99,255,.3);color:var(--accent2)}
.filter-chip-x{display:flex;align-items:center;justify-content:center;width:14px;height:14px;border-radius:50%;background:rgba(255,255,255,.08);font-size:10px;line-height:1;color:var(--text3);flex-shrink:0}
.filter-chip-x:hover{background:rgba(255,255,255,.15);color:var(--text)}

.adv-filters{display:flex;align-items:center;gap:8px;margin-bottom:16px;flex-wrap:wrap}
.adv-filter-btn{display:inline-flex;align-items:center;gap:5px;padding:5px 11px;border-radius:6px;font-size:11.5px;background:var(--bg2);border:1px solid var(--border);color:var(--text2);cursor:pointer;transition:all .15s;white-space:nowrap}
.adv-filter-btn:hover{border-color:var(--border2);color:var(--text)}
.adv-filter-btn svg{width:11px;height:11px}
.adv-filter-sep{width:1px;height:20px;background:var(--border)}

.toggle-row{display:flex;align-items:center;gap:14px;margin-left:auto}
.toggle-item{display:flex;align-items:center;gap:7px;font-size:11.5px;color:var(--text2);cursor:pointer;user-select:none}

.tab-count{display:inline-flex;align-items:center;justify-content:center;min-width:18px;height:16px;padding:0 5px;border-radius:4px;font-size:9.5px;font-weight:600;background:var(--bg4);color:var(--text3);margin-left:5px}
.tab.active .tab-count{background:var(--accent-bg);color:var(--accent2)}

.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:80px 20px;gap:14px;text-align:center}
.empty-icon{width:80px;height:80px;border-radius:20px;background:var(--bg2);border:1px solid var(--border);display:flex;align-items:center;justify-content:center;font-size:38px}
.empty-title{font-size:15px;font-weight:600;color:var(--text)}
.empty-desc{font-size:12.5px;color:var(--text2);max-width:280px;line-height:1.6}

.metrics-kpi{display:grid;grid-template-columns:repeat(5,1fr);gap:10px;margin-bottom:18px}
.kpi-card{background:var(--bg2);border:1px solid var(--border);border-radius:12px;padding:14px 16px;transition:border-color .15s}
.kpi-card:hover{border-color:var(--border2)}
.kpi-label{font-size:10px;color:var(--text2);margin-bottom:7px;text-transform:uppercase;letter-spacing:.5px;font-weight:600}
.kpi-val{font-size:22px;font-weight:700;font-family:var(--mono);letter-spacing:-1px}
.kpi-change{font-size:10.5px;margin-top:4px;display:flex;align-items:center;gap:3px}

.traffic-table-wrap{background:var(--bg2);border:1px solid var(--border);border-radius:12px;overflow:hidden}
.traffic-th-row{display:flex;align-items:center;justify-content:space-between;padding:10px 14px;border-bottom:1px solid var(--border)}

.link-cell{display:flex;align-items:center;gap:9px}
.link-icon{width:26px;height:26px;border-radius:6px;background:var(--bg4);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.link-icon svg{width:12px;height:12px;color:var(--text2)}
.link-url{font-size:12px;color:var(--accent2);font-family:var(--mono)}
.link-label{font-size:11px;color:var(--text2);margin-top:1px}

.skeleton{background:linear-gradient(90deg,var(--bg3) 25%,var(--bg4) 50%,var(--bg3) 75%);background-size:200% 100%;animation:shimmer 1.4s ease-in-out infinite;border-radius:5px;height:12px}
@keyframes shimmer{0%{background-position:200% 0}100%{background-position:-200% 0}}

.shared-table-wrap{background:var(--bg2);border:1px solid var(--border);border-radius:12px;overflow:hidden}

.report-link-cell{display:flex;align-items:center;gap:9px}
.report-link-icon{width:28px;height:28px;border-radius:7px;background:var(--accent-bg);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.report-link-icon svg{width:13px;height:13px;color:var(--accent2)}
.expiry-badge{display:inline-flex;align-items:center;gap:4px;padding:2px 8px;border-radius:5px;font-size:10.5px;font-weight:500}
.expiry-active{background:var(--green-bg);color:var(--green)}
.expiry-soon{background:var(--amber-bg);color:var(--amber)}
.expiry-expired{background:var(--red-bg);color:var(--red)}

/* Modal */
.date-inputs{display:grid;grid-template-columns:1fr 1fr;gap:10px}

/* ── PWA / Mobile adaptive (задача #11) ─────────────────────────────────── */
@media (max-width: 768px) {
  /* Sidebar collapse */
  #sidebar { width: 0; min-width: 0; overflow: hidden; position: fixed; z-index: 200; height: 100vh; transition: width .25s; }
  #sidebar.open { width: 220px; box-shadow: 4px 0 20px rgba(0,0,0,.5); }
  .main { margin-left: 0 !important; }

  /* Topbar: hamburger */
  .topbar { padding: 10px 14px; gap: 10px; }
  .topbar-hamburger { display: flex; align-items: center; justify-content: center; width: 34px; height: 34px; border-radius: 8px; background: var(--bg3); border: 1px solid var(--border); cursor: pointer; flex-shrink: 0; }
  .topbar-hamburger svg { width: 18px; height: 18px; stroke: var(--text2); }

  /* Content padding */
  .content { padding: 14px 12px !important; }

  /* Cards/grids to single column */
  .kpi-grid, [class*=grid-cols] { grid-template-columns: 1fr !important; }
  .st-chart-row { flex-direction: column !important; }

  /* Tables horizontal scroll */
  .table-wrap, .shared-table-wrap, .traffic-table-wrap { overflow-x: auto; }

  /* Modals full-width on mobile */
  .modal { width: 95vw !important; max-width: 95vw !important; margin: 0 auto; }
  .overlay { align-items: flex-end !important; padding: 0 !important; }
  .overlay .modal { border-bottom-left-radius: 0 !important; border-bottom-right-radius: 0 !important; max-height: 92vh; }

  /* AI Chat: full screen */
  .chat-layout { flex-direction: column; }
  .chat-list-panel { width: 100% !important; height: 45vh; border-right: none !important; border-bottom: 1px solid var(--border); }
  .chat-main { height: 55vh; }

  /* Buttons: bigger tap targets */
  .btn { min-height: 36px; padding: 7px 14px; }

  /* Hide non-essential columns on mobile */
  .hide-mobile { display: none !important; }

  /* Push enable button in topbar */
  .push-btn { display: flex; align-items: center; gap: 6px; padding: 5px 10px; border-radius: 8px; background: var(--bg3); border: 1px solid var(--border); color: var(--text2); font-size: 12px; cursor: pointer; }
}

@media (min-width: 769px) {
  .topbar-hamburger { display: none; }
  .push-btn { display: none; }
}
