/* ============================================================
   InvestPro v2.0 – Liquid Glass UI
   ============================================================ */
@import url('https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800&family=JetBrains+Mono:wght@400;500;600&display=swap');

/* ── Variables ─────────────────────────────────────────────── */
:root {
  --brand:       #6366F1;
  --brand-dark:  #4F46E5;
  --brand-light: #818CF8;
  --success:     #10B981;
  --danger:      #EF4444;
  --warning:     #F59E0B;
  --info:        #3B82F6;
  --sidebar-w:   260px;
  --topbar-h:    60px;
  --radius:      14px;
  --radius-sm:   8px;
  --transition:  .25s cubic-bezier(.4,0,.2,1);

  /* Dark theme */
  --bg:          #07090F;
  --bg2:         #0D1117;
  --bg3:         #161B27;
  --border:      rgba(255,255,255,.07);
  --border2:     rgba(255,255,255,.12);
  --text:        #E8ECF4;
  --text2:       #8B98B4;
  --text3:       #4A5568;
  --glass-bg:    rgba(255,255,255,.04);
  --glass-blur:  blur(20px);
  --glass-border:rgba(255,255,255,.08);
  --card-shadow: 0 8px 32px rgba(0,0,0,.45), inset 0 1px 0 rgba(255,255,255,.06);
  --glow:        0 0 40px rgba(99,102,241,.15);
}
[data-theme="light"] {
  --bg:          #F0F4FF;
  --bg2:         rgba(255,255,255,.85);
  --bg3:         rgba(255,255,255,.6);
  --border:      rgba(0,0,0,.06);
  --border2:     rgba(0,0,0,.1);
  --text:        #0F172A;
  --text2:       #475569;
  --text3:       #94A3B8;
  --glass-bg:    rgba(255,255,255,.65);
  --glass-blur:  blur(20px);
  --glass-border:rgba(255,255,255,.8);
  --card-shadow: 0 8px 32px rgba(99,102,241,.08), inset 0 1px 0 rgba(255,255,255,.9);
  --glow:        0 0 40px rgba(99,102,241,.08);
}

/* ── Base ──────────────────────────────────────────────────── */
*,*::before,*::after { box-sizing:border-box; margin:0; padding:0; }
html { scroll-behavior:smooth; }
body {
  font-family:'Inter',sans-serif;
  background:var(--bg);
  color:var(--text);
  -webkit-font-smoothing:antialiased;
  min-height:100vh;
  overflow-x:hidden;
}
[data-theme="dark"] body { background:radial-gradient(ellipse 80% 50% at 50% -20%,rgba(99,102,241,.12),transparent) var(--bg); }
[data-theme="light"] body { background:radial-gradient(ellipse 80% 50% at 50% -20%,rgba(99,102,241,.06),transparent) var(--bg); }
::-webkit-scrollbar { width:4px; height:4px; }
::-webkit-scrollbar-track { background:transparent; }
::-webkit-scrollbar-thumb { background:var(--border2); border-radius:999px; }
a { text-decoration:none; color:inherit; }

/* ── Layout ────────────────────────────────────────────────── */
.app-wrapper { display:flex; min-height:100vh; }
.main-content {
  flex:1;
  margin-left:var(--sidebar-w);
  display:flex;
  flex-direction:column;
  min-height:100vh;
  transition:margin var(--transition);
}
.main-content.sidebar-collapsed { margin-left:0; }
.page-body { flex:1; padding:24px; width:100%; box-sizing:border-box; }

/* ── Liquid Glass Sidebar ──────────────────────────────────── */
.sidebar {
  width:var(--sidebar-w);
  background:var(--glass-bg);
  backdrop-filter:var(--glass-blur);
  -webkit-backdrop-filter:var(--glass-blur);
  border-right:1px solid var(--glass-border);
  position:fixed;
  top:0; left:0; bottom:0;
  display:flex;
  flex-direction:column;
  z-index:200;
  transition:transform var(--transition);
  overflow-y:auto;
  overflow-x:hidden;
}
[data-theme="dark"] .sidebar { background:rgba(13,17,23,.8); }
[data-theme="light"] .sidebar { background:rgba(255,255,255,.75); box-shadow:4px 0 30px rgba(99,102,241,.06); }
.sidebar.collapsed { transform:translateX(-100%); }

.sidebar-brand {
  padding:18px 20px;
  border-bottom:1px solid var(--border);
  display:flex;
  align-items:center;
  gap:12px;
  min-height:var(--topbar-h);
}
.brand-icon {
  width:36px; height:36px;
  border-radius:10px;
  background:linear-gradient(135deg,var(--brand),var(--brand-dark));
  display:flex; align-items:center; justify-content:center;
  font-size:17px; flex-shrink:0;
  box-shadow:0 4px 14px rgba(99,102,241,.4);
}
.sidebar-brand h1 { font-size:15px; font-weight:700; color:var(--text); line-height:1.2; }
.sidebar-brand small { font-size:9px; color:var(--text3); }

.sidebar-section { padding:16px 14px 4px; }
.sidebar-section-label {
  font-size:9px; font-weight:700; color:var(--text3);
  text-transform:uppercase; letter-spacing:1.5px; padding:0 8px;
}
nav .nav-item {
  display:flex; align-items:center; gap:10px;
  padding:9px 12px; border-radius:10px;
  font-size:13px; font-weight:500; color:var(--text2);
  cursor:pointer; text-decoration:none;
  transition:all var(--transition);
  margin:1px 8px;
  position:relative;
}
nav .nav-item:hover {
  background:var(--glass-bg);
  color:var(--text);
  transform:translateX(2px);
}
nav .nav-item.active {
  background:linear-gradient(135deg,rgba(99,102,241,.18),rgba(99,102,241,.08));
  color:var(--brand-light);
  border-left:2.5px solid var(--brand);
  padding-left:10px;
}
[data-theme="light"] nav .nav-item.active { background:linear-gradient(135deg,rgba(99,102,241,.1),rgba(99,102,241,.04)); }
.nav-icon { width:17px; height:17px; flex-shrink:0; }
.nav-badge { margin-left:auto; background:var(--danger); color:#fff; font-size:9px; font-weight:700; padding:1px 6px; border-radius:999px; }

/* ── Topbar ─────────────────────────────────────────────────  */
.topbar {
  height:var(--topbar-h);
  background:var(--glass-bg);
  backdrop-filter:var(--glass-blur);
  -webkit-backdrop-filter:var(--glass-blur);
  border-bottom:1px solid var(--border);
  padding:0 24px;
  display:flex; align-items:center; justify-content:space-between;
  position:sticky; top:0; z-index:100;
}
[data-theme="dark"]  .topbar { background:rgba(7,9,15,.7); }
[data-theme="light"] .topbar { background:rgba(255,255,255,.75); }
.topbar-left  { display:flex; align-items:center; gap:12px; }
.topbar-right { display:flex; align-items:center; gap:12px; }
.breadcrumb { font-size:13px; color:var(--text2); }
.breadcrumb span { color:var(--brand-light); font-weight:600; }

.topbar-btn {
  background:var(--glass-bg);
  border:1px solid var(--border);
  cursor:pointer; color:var(--text2);
  width:36px; height:36px; border-radius:10px;
  display:flex; align-items:center; justify-content:center;
  transition:all var(--transition);
  position:relative;
}
.topbar-btn:hover { background:var(--border2); color:var(--text); border-color:var(--brand); }
.notif-dot { position:absolute; top:6px; right:6px; width:7px; height:7px; background:var(--danger); border-radius:50%; border:2px solid var(--bg); }

.avatar-btn {
  display:flex; align-items:center; gap:8px;
  padding:5px 10px 5px 5px;
  border-radius:12px;
  background:var(--glass-bg);
  border:1px solid var(--border);
  cursor:pointer;
  transition:all var(--transition);
}
.avatar-btn:hover { background:var(--border2); border-color:var(--brand); }
.avatar {
  width:30px; height:30px; border-radius:8px;
  background:linear-gradient(135deg,var(--brand),var(--brand-dark));
  display:flex; align-items:center; justify-content:center;
  color:#fff; font-size:11px; font-weight:700; flex-shrink:0;
  box-shadow:0 2px 8px rgba(99,102,241,.4);
}
.avatar img { width:100%; height:100%; border-radius:8px; object-fit:cover; }

/* ── Sidebar Toggle Switch ─────────────────────────────────── */
.sidebar-toggle-wrap {
  display:flex; align-items:center; gap:8px;
}
#sidebarToggle {
  position:relative; display:flex; align-items:center;
  width:42px; height:24px; cursor:pointer;
  background:none; border:none; padding:0;
  flex-shrink:0;
}
#sidebarToggle .toggle-track {
  width:42px; height:24px; border-radius:999px;
  background:var(--border2);
  border:1px solid var(--border);
  transition:background .3s, border-color .3s;
  position:relative;
}
#sidebarToggle.open .toggle-track {
  background:linear-gradient(135deg,var(--brand),var(--brand-dark));
  border-color:var(--brand);
}
#sidebarToggle .toggle-thumb {
  position:absolute; top:2px; left:2px;
  width:18px; height:18px; border-radius:50%; background:#fff;
  box-shadow:0 2px 6px rgba(0,0,0,.3);
  transition:transform .3s cubic-bezier(.34,1.56,.64,1);
}
#sidebarToggle.open .toggle-thumb { transform:translateX(18px); }
.sidebar-toggle-label {
  font-size:11px; font-weight:600; color:var(--text3);
  white-space:nowrap; user-select:none;
}

/* Sidebar overlay for mobile */
.sidebar-overlay {
  display:none; position:fixed; inset:0;
  background:rgba(0,0,0,.5);
  backdrop-filter:blur(4px);
  z-index:199;
}
.sidebar-overlay.show { display:block; }

/* ── Glass Cards ────────────────────────────────────────────── */
.card {
  background:var(--glass-bg);
  backdrop-filter:var(--glass-blur);
  -webkit-backdrop-filter:var(--glass-blur);
  border:1px solid var(--glass-border);
  border-radius:var(--radius);
  box-shadow:var(--card-shadow);
  transition:border-color var(--transition), transform var(--transition);
  position:relative;
  overflow:hidden;
}
[data-theme="dark"]  .card { background:rgba(13,17,23,.75); }
[data-theme="light"] .card { background:rgba(255,255,255,.8); }
.card::before {
  content:''; position:absolute;
  top:0; left:0; right:0; height:1px;
  background:linear-gradient(90deg,transparent,rgba(255,255,255,.1),transparent);
  pointer-events:none;
}
.card:hover { border-color:rgba(99,102,241,.3); }
.card-glow { box-shadow:var(--card-shadow), var(--glow); }
.card-body { padding:20px; }
.card-header {
  padding:16px 20px;
  border-bottom:1px solid var(--border);
  display:flex; align-items:center; justify-content:space-between;
}
.card-title { font-size:14px; font-weight:600; color:var(--text); }

/* ── Stat Cards ─────────────────────────────────────────────── */
.stat-card {
  background:var(--glass-bg);
  backdrop-filter:var(--glass-blur);
  -webkit-backdrop-filter:var(--glass-blur);
  border:1px solid var(--glass-border);
  border-radius:var(--radius);
  padding:20px;
  display:flex; align-items:flex-start; gap:14px;
  box-shadow:var(--card-shadow);
  transition:all var(--transition);
  cursor:default; position:relative; overflow:hidden;
}
[data-theme="dark"]  .stat-card { background:rgba(13,17,23,.75); }
[data-theme="light"] .stat-card { background:rgba(255,255,255,.8); }
.stat-card::after {
  content:''; position:absolute;
  top:-40px; right:-40px;
  width:120px; height:120px; border-radius:50%;
  background:var(--icon-color,#6366F1);
  opacity:.05; pointer-events:none;
}
.stat-card:hover { transform:translateY(-3px); border-color:rgba(99,102,241,.35); box-shadow:var(--card-shadow),var(--glow); }
.stat-icon {
  width:48px; height:48px; border-radius:12px;
  display:flex; align-items:center; justify-content:center;
  flex-shrink:0;
  background:var(--icon-bg,rgba(99,102,241,.12));
  color:var(--icon-color,#6366F1);
  box-shadow:0 4px 14px rgba(0,0,0,.15);
}
.stat-label { font-size:10px; font-weight:700; color:var(--text3); text-transform:uppercase; letter-spacing:1px; margin-bottom:4px; }
.stat-value { font-size:22px; font-weight:700; font-family:'JetBrains Mono',monospace; color:var(--text); line-height:1; }
.stat-sub { font-size:11px; color:var(--text3); margin-top:4px; }

/* ── Buttons ─────────────────────────────────────────────────  */
.btn {
  display:inline-flex; align-items:center; gap:7px;
  padding:9px 18px; border-radius:10px;
  font-size:13px; font-weight:600;
  cursor:pointer; border:none;
  transition:all var(--transition);
  text-decoration:none; white-space:nowrap; font-family:inherit;
}
.btn-primary {
  background:linear-gradient(135deg,var(--brand),var(--brand-dark));
  color:#fff;
  box-shadow:0 4px 14px rgba(99,102,241,.35);
}
.btn-primary:hover { transform:translateY(-1px); box-shadow:0 6px 20px rgba(99,102,241,.5); }
.btn-success { background:linear-gradient(135deg,#10B981,#059669); color:#fff; box-shadow:0 4px 14px rgba(16,185,129,.3); }
.btn-danger  { background:linear-gradient(135deg,#EF4444,#DC2626); color:#fff; box-shadow:0 4px 14px rgba(239,68,68,.3); }
.btn-warning { background:linear-gradient(135deg,#F59E0B,#D97706); color:#fff; }
.btn-ghost {
  background:var(--glass-bg);
  color:var(--text2);
  border:1px solid var(--border);
}
.btn-ghost:hover { background:var(--border2); color:var(--text); border-color:var(--brand); }
.btn-sm { padding:6px 12px; font-size:12px; border-radius:8px; }
.btn-icon { width:36px; height:36px; padding:0; border-radius:9px; justify-content:center; }

/* ── Forms ───────────────────────────────────────────────────  */
.form-group { margin-bottom:18px; }
.form-label { display:block; font-size:11px; font-weight:700; color:var(--text2); margin-bottom:6px; text-transform:uppercase; letter-spacing:.8px; }
.form-control {
  width:100%; padding:10px 14px; border-radius:10px;
  background:var(--glass-bg);
  border:1px solid var(--border2);
  color:var(--text); font-size:13px; font-family:'Inter',sans-serif;
  transition:all var(--transition); outline:none;
  backdrop-filter:var(--glass-blur);
}
[data-theme="dark"]  .form-control { background:rgba(255,255,255,.05); }
[data-theme="light"] .form-control { background:rgba(255,255,255,.85); }
.form-control:focus { border-color:var(--brand); box-shadow:0 0 0 3px rgba(99,102,241,.18); }
.form-control::placeholder { color:var(--text3); }
select.form-control option { background:var(--bg2); }
textarea.form-control { resize:vertical; min-height:88px; }
.input-group { display:flex; align-items:stretch; }
.input-group .form-control { border-radius:10px 0 0 10px; border-right:none; }
.input-addon {
  padding:10px 14px; background:var(--glass-bg);
  border:1px solid var(--border2); border-radius:0 10px 10px 0;
  color:var(--text2); font-size:13px; display:flex; align-items:center;
}
.form-hint  { font-size:11px; color:var(--text3); margin-top:4px; }
.form-error { font-size:11px; color:var(--danger); margin-top:4px; }

/* ── Grid ────────────────────────────────────────────────────  */
.grid { display:grid; gap:20px; }
.grid-2 { grid-template-columns:repeat(2,1fr); }
.grid-3 { grid-template-columns:repeat(3,1fr); }
.grid-4 { grid-template-columns:repeat(4,1fr); }
.grid-5 { grid-template-columns:repeat(5,1fr); }
.grid-12 { grid-template-columns:repeat(12,1fr); }
.col-span-2{grid-column:span 2}.col-span-3{grid-column:span 3}
.col-span-4{grid-column:span 4}.col-span-5{grid-column:span 5}
.col-span-6{grid-column:span 6}.col-span-7{grid-column:span 7}
.col-span-8{grid-column:span 8}

/* ── Tables ──────────────────────────────────────────────────  */
.table-wrap { overflow-x:auto; }
table.data-table { width:100%; border-collapse:collapse; font-size:13px; }
table.data-table th {
  padding:10px 14px; text-align:left;
  font-size:10px; font-weight:700; text-transform:uppercase; letter-spacing:.8px;
  color:var(--text3); background:rgba(255,255,255,.03);
  border-bottom:1px solid var(--border);
}
table.data-table td { padding:12px 14px; border-bottom:1px solid var(--border); color:var(--text); vertical-align:middle; }
table.data-table tr:last-child td { border-bottom:none; }
table.data-table tbody tr { transition:background var(--transition); }
table.data-table tbody tr:hover { background:rgba(99,102,241,.05); }
.mono { font-family:'JetBrains Mono',monospace; font-size:12px; }

/* ── Badges ──────────────────────────────────────────────────  */
.badge { display:inline-flex; align-items:center; gap:4px; padding:3px 9px; border-radius:999px; font-size:10px; font-weight:700; text-transform:uppercase; letter-spacing:.5px; }
.badge-success { background:rgba(16,185,129,.15);  color:#10B981; }
.badge-danger  { background:rgba(239,68,68,.15);   color:#EF4444; }
.badge-warning { background:rgba(245,158,11,.15);  color:#F59E0B; }
.badge-info    { background:rgba(59,130,246,.15);  color:#3B82F6; }
.badge-purple  { background:rgba(99,102,241,.15);  color:#818CF8; }
.badge-gray    { background:rgba(100,116,139,.15); color:#94A3B8; }

/* ── Modal ────────────────────────────────────────────────────  */
.modal-overlay {
  position:fixed; inset:0;
  background:rgba(0,0,0,.6);
  backdrop-filter:blur(8px);
  -webkit-backdrop-filter:blur(8px);
  z-index:300; display:flex; align-items:center; justify-content:center; padding:20px;
  opacity:0; pointer-events:none; transition:opacity .3s;
}
.modal-overlay.open { opacity:1; pointer-events:all; }
.modal {
  background:var(--glass-bg);
  backdrop-filter:blur(30px);
  -webkit-backdrop-filter:blur(30px);
  border:1px solid var(--glass-border);
  border-radius:18px; width:100%; max-width:560px;
  max-height:90vh; overflow-y:auto;
  box-shadow:0 25px 80px rgba(0,0,0,.5), inset 0 1px 0 rgba(255,255,255,.1);
  transform:scale(.95) translateY(10px);
  transition:transform .3s cubic-bezier(.34,1.56,.64,1);
}
[data-theme="dark"]  .modal { background:rgba(13,17,23,.92); }
[data-theme="light"] .modal { background:rgba(255,255,255,.92); }
.modal-overlay.open .modal { transform:scale(1) translateY(0); }
.modal-header { padding:20px 24px 16px; border-bottom:1px solid var(--border); display:flex; align-items:center; justify-content:space-between; }
.modal-title  { font-size:16px; font-weight:700; color:var(--text); }
.modal-close  { background:none; border:none; cursor:pointer; color:var(--text3); font-size:18px; border-radius:7px; width:30px; height:30px; display:flex;align-items:center;justify-content:center;transition:all var(--transition); }
.modal-close:hover { background:var(--border2); color:var(--text); }
.modal-body   { padding:20px 24px; }
.modal-footer { padding:16px 24px; border-top:1px solid var(--border); display:flex; gap:10px; justify-content:flex-end; }

/* ── Alerts ──────────────────────────────────────────────────  */
.alert { padding:12px 16px; border-radius:12px; font-size:13px; display:flex; align-items:center; gap:10px; margin-bottom:16px; backdrop-filter:var(--glass-blur); }
.alert-success { background:rgba(16,185,129,.1);  border:1px solid rgba(16,185,129,.2);  color:#10B981; }
.alert-danger  { background:rgba(239,68,68,.1);   border:1px solid rgba(239,68,68,.2);   color:#EF4444; }
.alert-warning { background:rgba(245,158,11,.1);  border:1px solid rgba(245,158,11,.2);  color:#F59E0B; }
.alert-info    { background:rgba(59,130,246,.1);  border:1px solid rgba(59,130,246,.2);  color:#3B82F6; }

/* ── Dropdown ────────────────────────────────────────────────  */
.dropdown { position:relative; }
.dropdown-menu {
  position:absolute; right:0; top:calc(100% + 8px); min-width:200px;
  background:var(--glass-bg);
  backdrop-filter:blur(30px);
  -webkit-backdrop-filter:blur(30px);
  border:1px solid var(--glass-border);
  border-radius:14px; padding:8px;
  box-shadow:0 20px 60px rgba(0,0,0,.4);
  z-index:150; opacity:0; pointer-events:none;
  transform:translateY(-6px) scale(.97);
  transition:all .2s cubic-bezier(.34,1.56,.64,1);
}
[data-theme="dark"]  .dropdown-menu { background:rgba(13,17,23,.95); }
[data-theme="light"] .dropdown-menu { background:rgba(255,255,255,.95); }
.dropdown-menu.open { opacity:1; pointer-events:all; transform:translateY(0) scale(1); }
.dropdown-item {
  display:flex; align-items:center; gap:9px;
  padding:9px 12px; border-radius:9px;
  font-size:13px; color:var(--text2);
  cursor:pointer; text-decoration:none; transition:all .15s;
}
.dropdown-item:hover { background:rgba(99,102,241,.1); color:var(--text); }
.dropdown-divider { height:1px; background:var(--border); margin:6px 0; }

/* ── Progress bars ───────────────────────────────────────────  */
.progress-track { background:rgba(255,255,255,.06); border-radius:999px; overflow:hidden; }
.progress-bar   { height:100%; border-radius:999px; transition:width 1.2s cubic-bezier(.25,1,.25,1); }

/* ── Live dot ────────────────────────────────────────────────  */
.live-dot { display:inline-block; width:8px; height:8px; background:#10B981; border-radius:50%; animation:pulse-dot 2s infinite; box-shadow:0 0 10px #10B981; }
@keyframes pulse-dot { 0%,100%{opacity:1;transform:scale(1)} 50%{opacity:.6;transform:scale(.85)} }

/* ── Profit Calendar ─────────────────────────────────────────  */
.cal-grid { display:grid; grid-template-columns:repeat(7,1fr); gap:5px; }
.cal-day-header { text-align:center; font-size:10px; font-weight:700; color:var(--text3); padding:5px; }
.cal-day {
  min-height:70px;
  background:rgba(255,255,255,.03);
  border:1px solid var(--border);
  border-radius:10px; padding:7px;
  cursor:pointer; transition:all var(--transition);
}
.cal-day:hover { border-color:var(--brand); background:rgba(99,102,241,.06); }
.cal-day.today  { border-color:var(--brand); box-shadow:0 0 12px rgba(99,102,241,.2); }
.cal-day.has-profit { background:rgba(16,185,129,.07);  border-color:rgba(16,185,129,.25); }
.cal-day.has-loss   { background:rgba(239,68,68,.07);   border-color:rgba(239,68,68,.25); }
.cal-day-num { font-size:11px; font-weight:700; color:var(--text3); }
.cal-day.today .cal-day-num { color:var(--brand-light); }
.cal-profit { font-size:10px; font-weight:700; font-family:'JetBrains Mono',monospace; margin-top:4px; }
.cal-profit.positive { color:#10B981; }
.cal-profit.negative { color:#EF4444; }

/* ── Model pills ─────────────────────────────────────────────  */
.model-pill { font-size:10px; font-weight:700; padding:3px 8px; border-radius:999px; display:inline-block; }
.model-pct   { background:rgba(99,102,241,.15);  color:#818CF8; }
.model-fixed { background:rgba(16,185,129,.15);  color:#10B981; }

/* ── Theme toggle ────────────────────────────────────────────  */
.theme-toggle {
  width:44px; height:24px; border-radius:999px;
  background:var(--border2);
  border:1px solid var(--border);
  position:relative; cursor:pointer; transition:background .3s;
}
.theme-toggle::after {
  content:''; position:absolute;
  width:18px; height:18px; border-radius:50%;
  background:#fff; top:2px; left:2px;
  transition:transform .3s cubic-bezier(.34,1.56,.64,1);
  box-shadow:0 2px 6px rgba(0,0,0,.3);
}
[data-theme="light"] .theme-toggle { background:var(--brand); border-color:var(--brand); }
[data-theme="light"] .theme-toggle::after { transform:translateX(20px); }

/* ── Skeleton ────────────────────────────────────────────────  */
.skeleton {
  background:linear-gradient(90deg,var(--bg3) 25%,var(--border2) 50%,var(--bg3) 75%);
  background-size:200% 100%;
  animation:shimmer 1.5s infinite; border-radius:8px;
}
@keyframes shimmer { 0%{background-position:200% 0} 100%{background-position:-200% 0} }

/* ── Animations ──────────────────────────────────────────────  */
@keyframes fadeUp  { from{transform:translateY(16px);opacity:0} to{transform:translateY(0);opacity:1} }
@keyframes fadeIn  { from{opacity:0} to{opacity:1} }
@keyframes slideIn { from{transform:translateX(-16px);opacity:0} to{transform:translateX(0);opacity:1} }
.fade-up  { animation:fadeUp  .5s cubic-bezier(.25,1,.25,1) both; }
.fade-in  { animation:fadeIn  .4s ease both; }
.slide-in { animation:slideIn .4s cubic-bezier(.25,1,.25,1) both; }
.anim-delay-1{animation-delay:.08s}.anim-delay-2{animation-delay:.16s}
.anim-delay-3{animation-delay:.24s}.anim-delay-4{animation-delay:.32s}

/* ── Ticker ──────────────────────────────────────────────────  */
.ticker-wrap { overflow:hidden; background:rgba(255,255,255,.03); border:1px solid var(--border); border-radius:8px; padding:6px 0; }
.ticker-inner { display:inline-flex; gap:32px; white-space:nowrap; animation:ticker 30s linear infinite; }
@keyframes ticker { 0%{transform:translateX(0)} 100%{transform:translateX(-50%)} }

/* ── Footer ──────────────────────────────────────────────────  */
.app-footer {
  padding:20px 24px;
  border-top:1px solid var(--border);
  background:var(--glass-bg);
  backdrop-filter:var(--glass-blur);
  -webkit-backdrop-filter:var(--glass-blur);
}
.footer-inner {
  max-width:1200px; margin:0 auto;
  display:flex; align-items:center; justify-content:center;
  flex-wrap:wrap; gap:16px;
}
.footer-brand {
  display:flex; align-items:center; gap:8px;
  font-size:13px; font-weight:700; color:var(--text2);
}
.footer-brand .fb-icon {
  width:26px; height:26px; border-radius:7px;
  background:linear-gradient(135deg,var(--brand),var(--brand-dark));
  display:flex; align-items:center; justify-content:center;
  font-size:13px;
}
.footer-divider { width:4px; height:4px; border-radius:50%; background:var(--border2); }
.footer-text { font-size:11px; color:var(--text3); text-align:center; }
.footer-text a { color:var(--brand-light); font-weight:500; }
.footer-text a:hover { text-decoration:underline; }
.footer-badge {
  font-size:10px; font-weight:700; padding:2px 8px; border-radius:999px;
  background:linear-gradient(135deg,rgba(99,102,241,.15),rgba(16,185,129,.1));
  border:1px solid rgba(99,102,241,.2); color:var(--brand-light); letter-spacing:.5px;
}

/* ── Responsive ──────────────────────────────────────────────  */
@media(max-width:1400px){
  .grid-5 { grid-template-columns:repeat(4,1fr); }
}
@media(max-width:1200px){
  .grid-4 { grid-template-columns:repeat(2,1fr); }
  .grid-5 { grid-template-columns:repeat(3,1fr); }
  .grid-12 .col-span-8 { grid-column:span 7; }
  .grid-12 .col-span-4 { grid-column:span 5; }
}
@media(max-width:992px){
  .grid-3 { grid-template-columns:repeat(2,1fr); }
  .grid-12 .col-span-7,.grid-12 .col-span-8 { grid-column:span 12; }
  .grid-12 .col-span-4,.grid-12 .col-span-5 { grid-column:span 12; }
}
/* Responsive inline grids */
@media(max-width:992px){
  [style*="grid-template-columns:2fr 1fr"],
  [style*="grid-template-columns:1fr 2fr"],
  [style*="grid-template-columns:7fr 5fr"],
  [style*="grid-template-columns:5fr 7fr"],
  [style*="grid-template-columns:2fr 1fr;"],
  [style*="grid-template-columns:1fr 1fr"] { grid-template-columns:1fr !important; }
}
@media(max-width:768px){
  :root { --sidebar-w:0px; }
  .sidebar { transform:translateX(-260px); width:260px; }
  .sidebar.mobile-open { transform:translateX(0); }
  .main-content { margin-left:0 !important; }
  .grid-2,.grid-3,.grid-4,.grid-5 { grid-template-columns:1fr; }
  .page-body { padding:14px; }
  .topbar { padding:0 14px; }
  .stat-card { padding:14px; }
  .stat-value { font-size:18px; }
}
@media(max-width:480px){
  .page-body { padding:10px; }
  .stat-icon { width:40px; height:40px; }
  .stat-value { font-size:16px; }
  .card-body { padding:14px; }
  .topbar-right .breadcrumb { display:none; }
}
