/* ═══════════════════════════════════════════════════════════════════════════
   CheMentor Design System v4.0 — Unified, Complete, Error-Free
   Author: CheMentor Dev
   ═══════════════════════════════════════════════════════════════════════════ */

/* ── Google Fonts ─────────────────────────────────────────────────────────── */
@import url('https://fonts.googleapis.com/css2?family=Plus+Jakarta+Sans:ital,wght@0,300;0,400;0,500;0,600;0,700;0,800;1,400&family=Space+Grotesk:wght@400;500;600;700;800&family=JetBrains+Mono:wght@400;600&display=swap');

/* ── CSS Reset ────────────────────────────────────────────────────────────── */
*,*::before,*::after { box-sizing:border-box; margin:0; padding:0; }

/* ── Design Tokens ─────────────────────────────────────────────────────────  */
:root {
  /* Brand Palette */
  --brand:       #6366f1;
  --brand-dark:  #4f46e5;
  --brand-soft:  #818cf8;
  --brand-pale:  #eef2ff;
  --accent:      #8b5cf6;
  --accent-soft: #ede9fe;

  /* Status */
  --success:     #10b981;
  --success-bg:  #d1fae5;
  --warning:     #f59e0b;
  --warning-bg:  #fef3c7;
  --danger:      #ef4444;
  --danger-bg:   #fee2e2;
  --info:        #3b82f6;
  --info-bg:     #dbeafe;
  --pink:        #ec4899;

  /* Gradients */
  --g-brand:    linear-gradient(135deg, #6366f1 0%, #8b5cf6 100%);
  --g-sidebar:  linear-gradient(180deg, #1e1b4b 0%, #312e81 60%, #1e1b4b 100%);
  --g-hero:     linear-gradient(135deg, #667eea 0%, #764ba2 100%);
  --g-success:  linear-gradient(135deg, #10b981 0%, #059669 100%);
  --g-warning:  linear-gradient(135deg, #f59e0b 0%, #d97706 100%);
  --g-danger:   linear-gradient(135deg, #ef4444 0%, #dc2626 100%);
  --g-info:     linear-gradient(135deg, #3b82f6 0%, #2563eb 100%);
  --g-coins:    linear-gradient(135deg, #f59e0b 0%, #d97706 100%);

  /* Admin Gradients */
  --g-admin:    linear-gradient(135deg, #ff416c 0%, #ff4b2b 100%);
  --g-admin-sb: linear-gradient(180deg, #1a0808 0%, #2d0a0a 50%, #1a0a2d 100%);

  /* Teacher Gradients */
  --g-teacher:  linear-gradient(135deg, #059669 0%, #047857 100%);

  /* Surfaces — Light Mode */
  --bg:          #f0f2ff;
  --surface:     #ffffff;
  --surface2:    #f8f9ff;
  --surface3:    #f1f3fe;
  --border:      #e5e7f0;
  --border-soft: #eff0f7;

  /* Text */
  --t1: #0f172a;
  --t2: #475569;
  --t3: #94a3b8;
  --t-inv: #ffffff;

  /* Layout */
  --sidebar-w: 278px;
  --max-w:     1440px;

  /* Radii */
  --r-xs:  6px;
  --r-sm:  10px;
  --r-md:  14px;
  --r-lg:  20px;
  --r-xl:  28px;
  --r-pill:9999px;

  /* Shadows */
  --sh-xs: 0 1px 3px rgba(0,0,0,.05);
  --sh-sm: 0 2px 10px rgba(0,0,0,.07);
  --sh-md: 0 4px 20px rgba(0,0,0,.09);
  --sh-lg: 0 8px 40px rgba(0,0,0,.13);
  --sh-xl: 0 16px 64px rgba(0,0,0,.18);
  --sh-brand: 0 4px 20px rgba(99,102,241,.25);

  /* Motion */
  --ease:       cubic-bezier(.4,0,.2,1);
  --trans:      .22s var(--ease);
  --trans-slow: .38s var(--ease);
}

/* ── Dark Mode ──────────────────────────────────────────────────────────────  */
[data-theme="dark"] {
  --bg:          #0d0f1a;
  --surface:     #161827;
  --surface2:    #1e2035;
  --surface3:    #252844;
  --border:      #2a2d45;
  --border-soft: #1e2138;
  --t1:  #f1f5f9;
  --t2:  #cbd5e1;
  --t3:  #64748b;
  --brand-pale:  rgba(99,102,241,.15);
  --accent-soft: rgba(139,92,246,.15);
  --success-bg:  rgba(16,185,129,.15);
  --warning-bg:  rgba(245,158,11,.15);
  --danger-bg:   rgba(239,68,68,.15);
  --info-bg:     rgba(59,130,246,.15);
  --sh-sm:  0 2px 10px rgba(0,0,0,.3);
  --sh-md:  0 4px 20px rgba(0,0,0,.4);
  --sh-lg:  0 8px 40px rgba(0,0,0,.5);
}

/* ── Base ────────────────────────────────────────────────────────────────── */
html { scroll-behavior:smooth; }
body {
  font-family: 'Plus Jakarta Sans', system-ui, -apple-system, sans-serif;
  background: var(--bg);
  color: var(--t1);
  min-height: 100vh;
  overflow-x: hidden;
  transition: background var(--trans), color var(--trans);
  scrollbar-width: thin;
  scrollbar-color: var(--t3) transparent;
}
body::-webkit-scrollbar { width:6px; height:6px; }
body::-webkit-scrollbar-thumb { background:var(--t3); border-radius:3px; }
body::-webkit-scrollbar-track { background:transparent; }
button, input, textarea, select { font-family:inherit; }
*:focus-visible { outline:2.5px solid rgba(99,102,241,.6); outline-offset:2px; border-radius:4px; }
a { text-decoration:none; color:inherit; }
img { max-width:100%; }

/* ═══════════════════════════════════════════════════════════════════════════
   OVERLAY
   ═══════════════════════════════════════════════════════════════════════════ */
.overlay {
  position:fixed; inset:0;
  background:rgba(0,0,0,.52);
  z-index:800;
  opacity:0; pointer-events:none;
  transition:opacity var(--trans);
  backdrop-filter:blur(4px);
}
.overlay.visible { opacity:1; pointer-events:all; }

/* ═══════════════════════════════════════════════════════════════════════════
   SIDEBAR — Student
   ═══════════════════════════════════════════════════════════════════════════ */
.sidebar {
  position:fixed;
  left:0; top:0; bottom:0;
  width:var(--sidebar-w);
  background:var(--g-sidebar);
  display:flex;
  flex-direction:column;
  overflow-y:auto;
  overflow-x:hidden;
  z-index:900;
  transition:transform var(--trans-slow);
  scrollbar-width:none;
  flex-shrink:0;
}
.sidebar::-webkit-scrollbar { display:none; }

/* Brand */
.sidebar-brand {
  padding:22px 18px 16px;
  border-bottom:1px solid rgba(255,255,255,.08);
  flex-shrink:0;
}
.brand-row {
  display:flex;
  align-items:center;
  gap:12px;
  margin-bottom:16px;
}
.logo-icon {
  width:42px; height:42px;
  border-radius:50%;
  background:var(--g-brand);
  display:flex; align-items:center; justify-content:center;
  font-size:1.2rem; color:#fff;
  flex-shrink:0;
  overflow:hidden;
  border:2px solid rgba(255,255,255,.22);
}
.logo-icon img { width:100%; height:100%; object-fit:cover; border-radius:50%; }
.sidebar-brand h2 { color:#fff; font-size:1.15rem; font-weight:800; letter-spacing:-.3px; }
.sidebar-brand p  { color:rgba(255,255,255,.42); font-size:.68rem; letter-spacing:.6px; text-transform:uppercase; margin-top:2px; }

/* User Card */
.sidebar-user {
  display:flex;
  align-items:center;
  gap:12px;
  padding:12px 13px;
  background:rgba(99,102,241,.14);
  border:1px solid rgba(99,102,241,.28);
  border-radius:12px;
}
.s-avatar {
  width:42px; height:42px;
  border-radius:50%;
  background:var(--g-brand);
  display:flex; align-items:center; justify-content:center;
  font-weight:800; color:#fff; font-size:1rem;
  flex-shrink:0; overflow:hidden;
  border:2px solid rgba(255,255,255,.2);
}
.s-avatar img { width:100%; height:100%; object-fit:cover; border-radius:50%; }
.s-name  { color:#fff; font-weight:700; font-size:.88rem; }
.s-role  { color:rgba(255,255,255,.42); font-size:.7rem; margin-top:2px; }

/* Nav Sections */
.nav-section { padding:12px 14px 4px; }
.nav-label {
  font-size:.62rem; font-weight:700;
  letter-spacing:1.2px; color:rgba(255,255,255,.25);
  text-transform:uppercase;
  padding-bottom:6px;
}
.nav-item {
  display:flex;
  align-items:center;
  gap:11px;
  padding:9px 12px;
  border-radius:10px;
  color:rgba(255,255,255,.68);
  font-size:.84rem;
  font-weight:600;
  transition:all var(--trans);
  position:relative;
  margin-bottom:2px;
  border-left:2.5px solid transparent;
}
.nav-item i { width:17px; text-align:center; font-size:.9rem; flex-shrink:0; }
.nav-item span { flex:1; }
.nav-item:hover {
  background:rgba(255,255,255,.1);
  color:#fff;
  transform:translateX(3px);
}
.nav-item.active {
  background:rgba(99,102,241,.28);
  color:#fff;
  border-left-color:var(--brand-soft);
}
.nav-badge {
  background:var(--g-danger);
  color:#fff;
  font-size:.68rem;
  font-weight:900;
  padding:2px 7px;
  border-radius:999px;
  min-width:20px;
  text-align:center;
}
.nav-item.ext i.ext-ico {
  font-size:.7rem;
  opacity:.5;
  margin-left:auto;
  width:auto;
}

/* Sidebar Footer */
.sidebar-footer {
  margin-top:auto;
  padding:14px 16px 18px;
  border-top:1px solid rgba(255,255,255,.08);
  flex-shrink:0;
}
.sidebar-coins {
  display:flex;
  align-items:center;
  gap:9px;
  padding:11px 14px;
  background:var(--g-coins);
  border-radius:12px;
  color:#fff;
  font-weight:900;
  font-size:.88rem;
  margin-bottom:8px;
  box-shadow:0 6px 18px rgba(245,158,11,.3);
}
.sidebar-coins i { font-size:1rem; }
.logout-btn {
  display:flex;
  align-items:center;
  gap:10px;
  padding:9px 12px;
  border-radius:10px;
  color:rgba(255,255,255,.6);
  font-size:.84rem;
  font-weight:600;
  transition:all var(--trans);
  cursor:pointer;
  border:none; background:none; width:100%;
}
.logout-btn:hover { background:rgba(239,68,68,.2); color:#fca5a5; }
.logout-btn i { width:17px; text-align:center; }

/* Mobile Menu Btn */
.mobile-menu-btn {
  display:none;
  position:fixed;
  top:14px; left:14px;
  width:44px; height:44px;
  border-radius:12px;
  border:1.5px solid var(--border);
  background:var(--surface);
  color:var(--t1);
  font-size:1.1rem;
  cursor:pointer;
  z-index:901;
  box-shadow:var(--sh-sm);
  transition:all var(--trans);
}
.mobile-menu-btn:hover { background:var(--brand); color:#fff; border-color:var(--brand); }

/* ═══════════════════════════════════════════════════════════════════════════
   MAIN CONTENT
   ═══════════════════════════════════════════════════════════════════════════ */
.main-content {
  margin-left:var(--sidebar-w);
  min-height:100vh;
  padding:28px 28px 100px;
  transition:margin var(--trans-slow);
}
.page-container {
  max-width:var(--max-w);
  margin:0 auto;
}

/* ═══════════════════════════════════════════════════════════════════════════
   PAGE HEADER (Topbar within pages)
   ═══════════════════════════════════════════════════════════════════════════ */
.page-topbar {
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:16px;
  margin-bottom:26px;
  flex-wrap:wrap;
}
.page-topbar-left h1 {
  font-family:'Space Grotesk',sans-serif;
  font-size:1.7rem;
  font-weight:800;
  letter-spacing:-.4px;
  color:var(--t1);
}
.page-topbar-left p {
  font-size:.87rem;
  color:var(--t3);
  margin-top:4px;
}
.topbar-actions {
  display:flex;
  align-items:center;
  gap:10px;
}

/* Icon Btn */
.icon-btn {
  width:40px; height:40px;
  border-radius:10px;
  border:1.5px solid var(--border);
  background:var(--surface);
  color:var(--t2);
  cursor:pointer;
  display:grid; place-items:center;
  font-size:.95rem;
  transition:all var(--trans);
  position:relative;
  box-shadow:var(--sh-xs);
}
.icon-btn:hover {
  border-color:var(--brand);
  color:var(--brand);
  box-shadow:0 0 0 3px rgba(99,102,241,.15);
}
.icon-btn .badge-dot {
  position:absolute; top:7px; right:7px;
  width:8px; height:8px;
  background:var(--danger);
  border:2px solid var(--surface);
  border-radius:50%;
}

/* ═══════════════════════════════════════════════════════════════════════════
   CARDS
   ═══════════════════════════════════════════════════════════════════════════ */
.card {
  background:var(--surface);
  border:1.5px solid var(--border);
  border-radius:var(--r-lg);
  overflow:hidden;
  box-shadow:var(--sh-sm);
  transition:box-shadow var(--trans), border-color var(--trans), background var(--trans);
  display:flex;
  flex-direction:column;
}
.card:hover { box-shadow:var(--sh-md); }

.card-head {
  padding:16px 20px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  border-bottom:1px solid var(--border-soft);
}
.card-title {
  display:flex;
  align-items:center;
  gap:10px;
  font-family:'Space Grotesk',sans-serif;
  font-size:.95rem;
  font-weight:700;
  color:var(--t1);
}
.card-title .pill {
  width:32px; height:32px;
  border-radius:9px;
  display:grid; place-items:center;
  background:var(--g-brand);
  color:#fff;
  font-size:.85rem;
  flex-shrink:0;
}
.card-body { padding:16px 20px; flex:1; }

/* ═══════════════════════════════════════════════════════════════════════════
   STAT CARDS
   ═══════════════════════════════════════════════════════════════════════════ */
.stats-grid {
  display:grid;
  grid-template-columns:repeat(auto-fit, minmax(190px, 1fr));
  gap:16px;
  margin-bottom:22px;
}
.stat-card {
  background:var(--surface);
  border:1.5px solid var(--border);
  border-radius:var(--r-lg);
  padding:18px 18px;
  display:flex;
  gap:14px;
  align-items:center;
  box-shadow:var(--sh-sm);
  transition:all var(--trans);
  overflow:hidden;
  position:relative;
}
.stat-card::after {
  content:'';
  position:absolute;
  top:-20px; right:-20px;
  width:80px; height:80px;
  border-radius:50%;
  opacity:.06;
}
.stat-card:hover { transform:translateY(-3px); box-shadow:var(--sh-lg); border-color:var(--brand); }
.stat-icon {
  width:52px; height:52px;
  border-radius:14px;
  display:grid; place-items:center;
  font-size:1.3rem;
  color:#fff;
  flex-shrink:0;
  box-shadow:0 8px 18px rgba(0,0,0,.15);
}
.ico-brand   { background:var(--g-brand);   }
.ico-success { background:var(--g-success); }
.ico-warning { background:var(--g-warning); }
.ico-info    { background:var(--g-info);    }
.ico-danger  { background:var(--g-danger);  }
.ico-pink    { background:linear-gradient(135deg,#ec4899,#db2777); }
.ico-admin   { background:var(--g-admin);   }
.ico-teacher { background:var(--g-teacher); }

.stat-val {
  font-family:'Space Grotesk',sans-serif;
  font-size:1.9rem;
  font-weight:900;
  line-height:1;
  color:var(--t1);
}
.stat-label {
  font-size:.8rem;
  font-weight:700;
  color:var(--t2);
  margin-top:5px;
}
.stat-sub {
  display:inline-flex;
  align-items:center;
  gap:4px;
  font-size:.72rem;
  font-weight:700;
  padding:3px 9px;
  border-radius:999px;
  margin-top:6px;
}
.sub-brand   { background:var(--brand-pale); color:var(--brand-dark); }
.sub-success { background:var(--success-bg); color:#059669; }
.sub-warning { background:var(--warning-bg); color:#b45309; }
.sub-danger  { background:var(--danger-bg);  color:#dc2626; }
.sub-info    { background:var(--info-bg);    color:#1d4ed8; }

/* ═══════════════════════════════════════════════════════════════════════════
   GRID SYSTEM
   ═══════════════════════════════════════════════════════════════════════════ */
.grid { display:grid; grid-template-columns:repeat(12,1fr); gap:16px; margin-bottom:18px; }
.col-3  { grid-column:span 3; }
.col-4  { grid-column:span 4; }
.col-5  { grid-column:span 5; }
.col-6  { grid-column:span 6; }
.col-7  { grid-column:span 7; }
.col-8  { grid-column:span 8; }
.col-9  { grid-column:span 9; }
.col-12 { grid-column:span 12; }

/* ═══════════════════════════════════════════════════════════════════════════
   BUTTONS
   ═══════════════════════════════════════════════════════════════════════════ */
.btn {
  display:inline-flex;
  align-items:center;
  gap:8px;
  padding:10px 20px;
  border-radius:10px;
  font-weight:700;
  font-size:.85rem;
  cursor:pointer;
  border:none;
  transition:all var(--trans);
  text-decoration:none;
  white-space:nowrap;
  line-height:1.2;
}
.btn-primary { background:var(--g-brand); color:#fff; box-shadow:var(--sh-brand); }
.btn-primary:hover { filter:brightness(1.1); transform:translateY(-2px); box-shadow:0 8px 24px rgba(99,102,241,.4); }
.btn-success { background:var(--g-success); color:#fff; box-shadow:0 4px 14px rgba(16,185,129,.3); }
.btn-success:hover { filter:brightness(1.08); transform:translateY(-2px); }
.btn-warning { background:var(--g-warning); color:#fff; box-shadow:0 4px 14px rgba(245,158,11,.3); }
.btn-warning:hover { filter:brightness(1.08); transform:translateY(-2px); }
.btn-danger  { background:var(--g-danger);  color:#fff; box-shadow:0 4px 14px rgba(239,68,68,.3); }
.btn-danger:hover  { filter:brightness(1.08); transform:translateY(-2px); }
.btn-outline {
  background:transparent;
  color:var(--brand);
  border:1.5px solid var(--brand);
}
.btn-outline:hover { background:var(--brand); color:#fff; }
.btn-ghost {
  background:var(--surface2);
  color:var(--t2);
  border:1.5px solid var(--border);
}
.btn-ghost:hover { background:var(--border); color:var(--t1); }
.btn-sm { padding:6px 14px; font-size:.78rem; border-radius:8px; }
.btn-xs { padding:4px 10px; font-size:.73rem; border-radius:6px; }
.btn-admin { background:var(--g-admin); color:#fff; }
.btn-admin:hover { filter:brightness(1.1); transform:translateY(-2px); }

/* ═══════════════════════════════════════════════════════════════════════════
   BADGES / PILLS
   ═══════════════════════════════════════════════════════════════════════════ */
.badge {
  display:inline-flex;
  align-items:center;
  gap:4px;
  font-size:.72rem;
  font-weight:800;
  padding:3px 10px;
  border-radius:999px;
  white-space:nowrap;
}
.badge-brand   { background:var(--brand-pale);   color:var(--brand-dark); }
.badge-success { background:var(--success-bg);   color:#059669; }
.badge-warning { background:var(--warning-bg);   color:#b45309; }
.badge-danger  { background:var(--danger-bg);    color:#dc2626; }
.badge-info    { background:var(--info-bg);      color:#1d4ed8; }
.badge-neutral { background:var(--surface2);     color:var(--t3); border:1px solid var(--border); }

/* ═══════════════════════════════════════════════════════════════════════════
   FORM ELEMENTS
   ═══════════════════════════════════════════════════════════════════════════ */
.form-group { margin-bottom:18px; }
.form-label {
  display:block;
  font-size:.82rem;
  font-weight:700;
  color:var(--t2);
  margin-bottom:6px;
}
.form-control {
  width:100%;
  padding:10px 14px;
  border:1.5px solid var(--border);
  border-radius:10px;
  background:var(--surface2);
  color:var(--t1);
  font-size:.9rem;
  font-family:inherit;
  transition:border-color var(--trans), box-shadow var(--trans), background var(--trans);
}
.form-control:focus {
  outline:none;
  border-color:var(--brand);
  box-shadow:0 0 0 3px rgba(99,102,241,.12);
  background:var(--surface);
}
.input-group {
  position:relative;
  display:flex;
  align-items:center;
}
.input-icon {
  position:absolute;
  left:13px;
  color:var(--t3);
  font-size:.9rem;
  pointer-events:none;
}
.input-group .form-control { padding-left:38px; }
textarea.form-control { resize:vertical; min-height:90px; }
select.form-control { cursor:pointer; }

/* ═══════════════════════════════════════════════════════════════════════════
   TABLE
   ═══════════════════════════════════════════════════════════════════════════ */
.table-wrap {
  overflow-x:auto;
  border-radius:var(--r-lg);
}
.table {
  width:100%;
  border-collapse:collapse;
  font-size:.84rem;
}
.table thead th {
  background:var(--surface2);
  color:var(--t3);
  font-weight:700;
  font-size:.72rem;
  text-transform:uppercase;
  letter-spacing:.6px;
  padding:11px 14px;
  text-align:left;
  white-space:nowrap;
  border-bottom:1.5px solid var(--border);
}
.table tbody tr {
  border-bottom:1px solid var(--border-soft);
  transition:background var(--trans);
}
.table tbody tr:last-child { border-bottom:none; }
.table tbody tr:hover { background:var(--surface2); }
.table tbody td {
  padding:12px 14px;
  color:var(--t1);
  vertical-align:middle;
}

/* ═══════════════════════════════════════════════════════════════════════════
   ALERTS
   ═══════════════════════════════════════════════════════════════════════════ */
.alert {
  display:flex;
  align-items:flex-start;
  gap:12px;
  padding:14px 18px;
  border-radius:12px;
  border-left:4px solid;
  margin-bottom:18px;
  font-size:.88rem;
  font-weight:600;
  animation:slideDown .3s var(--ease);
}
@keyframes slideDown { from { opacity:0; transform:translateY(-8px); } to { opacity:1; transform:translateY(0); } }
.alert-success { background:var(--success-bg); border-color:var(--success); color:#064e3b; }
.alert-danger  { background:var(--danger-bg);  border-color:var(--danger);  color:#7f1d1d; }
.alert-warning { background:var(--warning-bg); border-color:var(--warning); color:#78350f; }
.alert-info    { background:var(--info-bg);    border-color:var(--info);    color:#1e3a5f; }
[data-theme="dark"] .alert-success { color:var(--success); }
[data-theme="dark"] .alert-danger  { color:#fca5a5; }
[data-theme="dark"] .alert-warning { color:var(--warning); }
[data-theme="dark"] .alert-info    { color:#93c5fd; }
.alert i { margin-top:2px; flex-shrink:0; }

/* ═══════════════════════════════════════════════════════════════════════════
   MODALS
   ═══════════════════════════════════════════════════════════════════════════ */
.modal-bg {
  position:fixed; inset:0;
  background:rgba(0,0,0,.55);
  z-index:1000;
  display:flex;
  align-items:center;
  justify-content:center;
  padding:16px;
  opacity:0;
  pointer-events:none;
  transition:opacity var(--trans);
  backdrop-filter:blur(4px);
}
.modal-bg.open { opacity:1; pointer-events:all; }
.modal-box {
  background:var(--surface);
  border-radius:var(--r-xl);
  padding:28px;
  max-width:520px;
  width:100%;
  box-shadow:var(--sh-xl);
  transform:scale(.95) translateY(10px);
  transition:transform var(--trans);
  max-height:90vh;
  overflow-y:auto;
}
.modal-bg.open .modal-box { transform:scale(1) translateY(0); }
.modal-header {
  display:flex;
  align-items:center;
  justify-content:space-between;
  margin-bottom:20px;
}
.modal-title {
  font-family:'Space Grotesk',sans-serif;
  font-size:1.1rem;
  font-weight:800;
}
.modal-close {
  width:34px; height:34px;
  border-radius:8px;
  border:1.5px solid var(--border);
  background:var(--surface2);
  color:var(--t3);
  cursor:pointer;
  display:grid; place-items:center;
  transition:all var(--trans);
}
.modal-close:hover { background:var(--danger-bg); color:var(--danger); border-color:var(--danger); }

/* ═══════════════════════════════════════════════════════════════════════════
   EMPTY STATE
   ═══════════════════════════════════════════════════════════════════════════ */
.empty-state {
  text-align:center;
  padding:48px 24px;
  color:var(--t3);
}
.empty-state .empty-icon {
  font-size:3rem;
  margin-bottom:14px;
  display:block;
  opacity:.5;
}
.empty-state h3 { font-size:1rem; font-weight:700; color:var(--t2); margin-bottom:6px; }
.empty-state p  { font-size:.85rem; }

/* ═══════════════════════════════════════════════════════════════════════════
   LOGIN PAGE
   ═══════════════════════════════════════════════════════════════════════════ */
.login-page {
  min-height:100vh;
  display:flex;
  align-items:center;
  justify-content:center;
  background:var(--g-hero);
  padding:16px;
}
.login-box {
  display:grid;
  grid-template-columns:1fr 1fr;
  max-width:900px;
  width:100%;
  border-radius:28px;
  overflow:hidden;
  box-shadow:0 32px 80px rgba(0,0,0,.22);
}
.login-left {
  background:linear-gradient(160deg,#4338ca 0%,#7c3aed 100%);
  padding:48px 38px;
  color:#fff;
  display:flex;
  flex-direction:column;
  gap:22px;
}
.login-logo {
  display:flex;
  align-items:center;
  gap:14px;
}
.login-logo-icon {
  width:52px; height:52px;
  border-radius:14px;
  background:rgba(255,255,255,.15);
  border:2px solid rgba(255,255,255,.28);
  display:flex; align-items:center; justify-content:center;
  font-size:1.6rem;
  overflow:hidden;
}
.login-logo-icon img { width:100%; height:100%; object-fit:cover; border-radius:12px; }
.login-logo-name { font-family:'Space Grotesk',sans-serif; font-size:1.6rem; font-weight:900; }
.login-logo-sub  { font-size:.72rem; opacity:.62; letter-spacing:.8px; text-transform:uppercase; }
.login-tagline   { font-size:1.45rem; font-weight:800; line-height:1.4; letter-spacing:-.3px; }
.login-desc      { font-size:.87rem; opacity:.78; line-height:1.7; }
.login-features  { list-style:none; display:flex; flex-direction:column; gap:10px; margin-top:4px; }
.login-features li {
  display:flex; align-items:center; gap:10px;
  font-size:.85rem; opacity:.9;
}
.login-features li::before {
  content:'✓';
  width:22px; height:22px;
  border-radius:50%;
  background:rgba(255,255,255,.18);
  display:flex; align-items:center; justify-content:center;
  font-size:.72rem;
  font-weight:900;
  flex-shrink:0;
}

.login-right {
  background:var(--surface);
  padding:48px 40px;
  display:flex;
  flex-direction:column;
  justify-content:center;
}
.login-right h2 {
  font-family:'Space Grotesk',sans-serif;
  font-size:1.5rem;
  font-weight:800;
  color:var(--t1);
  margin-bottom:6px;
}
.login-right .sub {
  font-size:.87rem;
  color:var(--t3);
  margin-bottom:28px;
}
.login-field { margin-bottom:16px; }
.login-field label { display:block; font-size:.8rem; font-weight:700; color:var(--t2); margin-bottom:7px; }
.login-input-wrap { position:relative; display:flex; align-items:center; }
.login-input-wrap i {
  position:absolute; left:14px;
  color:var(--t3); font-size:.9rem;
  pointer-events:none;
}
.login-input-wrap input {
  width:100%;
  padding:13px 14px 13px 40px;
  border:1.5px solid var(--border);
  border-radius:12px;
  font-size:.92rem;
  background:var(--surface2);
  color:var(--t1);
  transition:all var(--trans);
}
.login-input-wrap input:focus {
  outline:none;
  border-color:var(--brand);
  background:var(--surface);
  box-shadow:0 0 0 3px rgba(99,102,241,.12);
}
.login-btn {
  width:100%;
  padding:14px;
  border:none;
  border-radius:12px;
  background:var(--g-brand);
  color:#fff;
  font-size:.95rem;
  font-weight:800;
  cursor:pointer;
  display:flex;
  align-items:center;
  justify-content:center;
  gap:9px;
  transition:all var(--trans);
  box-shadow:var(--sh-brand);
  margin-top:20px;
}
.login-btn:hover { filter:brightness(1.1); transform:translateY(-2px); box-shadow:0 10px 28px rgba(99,102,241,.4); }
.login-err {
  background:var(--danger-bg);
  color:#7f1d1d;
  border:1px solid rgba(239,68,68,.25);
  border-radius:10px;
  padding:11px 14px;
  font-size:.84rem;
  font-weight:600;
  display:flex;
  align-items:center;
  gap:9px;
  margin-bottom:16px;
}
.login-help {
  text-align:center;
  margin-top:20px;
  font-size:.82rem;
  color:var(--t3);
}
.login-help a { color:var(--brand); font-weight:700; }

/* ═══════════════════════════════════════════════════════════════════════════
   WELCOME BANNER
   ═══════════════════════════════════════════════════════════════════════════ */
.welcome-banner {
  background:var(--g-brand);
  color:#fff;
  border-radius:var(--r-xl);
  padding:28px 30px;
  display:grid;
  grid-template-columns:1.3fr .7fr;
  gap:20px;
  align-items:center;
  position:relative;
  overflow:hidden;
  margin-bottom:22px;
  box-shadow:var(--sh-md);
}
.welcome-banner::before {
  content:'';
  position:absolute; inset:0;
  background:url("data:image/svg+xml,%3Csvg width='500' height='300' xmlns='http://www.w3.org/2000/svg'%3E%3Ccircle cx='420' cy='60' r='180' fill='rgba(255,255,255,.06)'/%3E%3Ccircle cx='30' cy='260' r='130' fill='rgba(255,255,255,.04)'/%3E%3C/svg%3E") right center/auto no-repeat;
  pointer-events:none;
}
.wb-left { position:relative; z-index:1; }
.wb-greeting {
  font-size:.82rem;
  opacity:.75;
  font-weight:600;
  letter-spacing:.3px;
  margin-bottom:4px;
}
.wb-name {
  font-family:'Space Grotesk',sans-serif;
  font-size:1.9rem;
  font-weight:900;
  letter-spacing:-.5px;
  line-height:1.15;
}
.wb-name span { opacity:.7; font-weight:500; }
.wb-quote {
  margin-top:14px;
  padding:12px 14px;
  border-radius:12px;
  background:rgba(255,255,255,.12);
  border:1px solid rgba(255,255,255,.2);
  backdrop-filter:blur(10px);
  max-width:500px;
  display:flex;
  gap:10px;
}
.wb-quote i { opacity:.7; margin-top:2px; font-size:.9rem; }
.wb-qt { font-size:.83rem; line-height:1.7; font-style:italic; opacity:.95; }
.wb-qa { font-size:.73rem; opacity:.65; font-weight:800; margin-top:3px; }

.wb-right {
  position:relative; z-index:1;
  display:flex; flex-direction:column;
  gap:12px; align-items:flex-end;
}
.wb-coins-badge {
  display:flex; gap:9px; align-items:center;
  padding:10px 18px;
  border-radius:999px;
  background:rgba(255,255,255,.18);
  border:1px solid rgba(255,255,255,.28);
  backdrop-filter:blur(10px);
  font-family:'Space Grotesk',sans-serif;
  font-size:1.3rem;
  font-weight:900;
}
.wb-coins-badge i { color:#fde68a; }
.wb-actions { display:flex; flex-wrap:wrap; gap:9px; justify-content:flex-end; }
.wb-btn {
  padding:8px 14px;
  border-radius:999px;
  border:1px solid rgba(255,255,255,.28);
  cursor:pointer;
  font-weight:800;
  font-size:.8rem;
  display:inline-flex; align-items:center; gap:7px;
  transition:all var(--trans);
  color:#fff;
  background:rgba(255,255,255,.12);
  text-decoration:none;
}
.wb-btn.primary {
  background:rgba(255,255,255,.92);
  color:var(--brand-dark);
  border-color:transparent;
}
.wb-btn:hover { transform:translateY(-2px); box-shadow:0 8px 20px rgba(0,0,0,.15); }

/* ═══════════════════════════════════════════════════════════════════════════
   PRODUCT CARDS
   ═══════════════════════════════════════════════════════════════════════════ */
.products-grid {
  display:grid;
  grid-template-columns:repeat(auto-fill, minmax(270px, 1fr));
  gap:16px;
}
.product-card {
  background:var(--surface);
  border:1.5px solid var(--border);
  border-radius:var(--r-lg);
  padding:20px;
  transition:all var(--trans);
  position:relative;
  overflow:hidden;
}
.product-card:hover { transform:translateY(-4px); box-shadow:var(--sh-lg); border-color:var(--brand); }
.product-card::before {
  content:'';
  position:absolute;
  top:0; left:0; right:0;
  height:3px;
  background:var(--g-brand);
  opacity:0;
  transition:opacity var(--trans);
}
.product-card:hover::before { opacity:1; }
.pc-type {
  display:inline-flex;
  align-items:center;
  gap:6px;
  font-size:.72rem;
  font-weight:800;
  padding:4px 10px;
  border-radius:999px;
  background:var(--brand-pale);
  color:var(--brand-dark);
  margin-bottom:12px;
  text-transform:uppercase;
  letter-spacing:.5px;
}
.pc-name {
  font-family:'Space Grotesk',sans-serif;
  font-size:1rem;
  font-weight:700;
  color:var(--t1);
  margin-bottom:10px;
  line-height:1.4;
}
.pc-meta {
  display:flex;
  align-items:center;
  justify-content:space-between;
  margin-bottom:14px;
  font-size:.8rem;
  color:var(--t3);
}
.pc-price {
  font-family:'Space Grotesk',sans-serif;
  font-size:1.1rem;
  font-weight:900;
  color:var(--success);
}

/* ═══════════════════════════════════════════════════════════════════════════
   DOUBT CARDS
   ═══════════════════════════════════════════════════════════════════════════ */
.doubt-card {
  background:var(--surface);
  border:1.5px solid var(--border);
  border-radius:var(--r-lg);
  padding:18px 20px;
  margin-bottom:12px;
  transition:all var(--trans);
}
.doubt-card:hover { border-color:var(--brand-soft); box-shadow:var(--sh-sm); }
.dc-top {
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:12px;
  margin-bottom:10px;
}
.dc-subject {
  font-size:.72rem;
  font-weight:800;
  text-transform:uppercase;
  letter-spacing:.6px;
  color:var(--t3);
  display:flex;
  align-items:center;
  gap:6px;
}
.dc-text {
  font-size:.9rem;
  color:var(--t1);
  line-height:1.6;
  margin-bottom:10px;
}
.dc-answer {
  background:var(--success-bg);
  border-left:3px solid var(--success);
  border-radius:0 10px 10px 0;
  padding:11px 14px;
  margin-top:10px;
  font-size:.85rem;
  color:var(--t1);
  line-height:1.6;
}
[data-theme="dark"] .dc-answer { background:rgba(16,185,129,.12); }
.dc-meta {
  display:flex;
  align-items:center;
  gap:12px;
  font-size:.76rem;
  color:var(--t3);
  margin-top:10px;
  flex-wrap:wrap;
}

/* ═══════════════════════════════════════════════════════════════════════════
   COINS PAGE
   ═══════════════════════════════════════════════════════════════════════════ */
.coins-hero {
  background:var(--g-coins);
  border-radius:var(--r-xl);
  padding:28px 30px;
  color:#fff;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:20px;
  margin-bottom:22px;
  box-shadow:0 10px 30px rgba(245,158,11,.3);
  position:relative;
  overflow:hidden;
}
.coins-hero::before {
  content:'🪙';
  position:absolute;
  right:24px; top:50%;
  transform:translateY(-50%);
  font-size:6rem;
  opacity:.15;
}
.ch-amount {
  font-family:'Space Grotesk',sans-serif;
  font-size:3rem;
  font-weight:900;
  letter-spacing:-.5px;
  line-height:1;
}
.ch-label { font-size:.85rem; opacity:.78; margin-top:5px; }

/* Coins history */
.coins-list { display:flex; flex-direction:column; gap:10px; }
.coin-item {
  display:flex;
  align-items:center;
  gap:14px;
  padding:13px 16px;
  background:var(--surface2);
  border:1.5px solid var(--border-soft);
  border-radius:12px;
  transition:all var(--trans);
}
.coin-item:hover { border-color:var(--border); }
.ci-icon {
  width:38px; height:38px;
  border-radius:10px;
  display:grid; place-items:center;
  flex-shrink:0;
  font-size:1rem;
}
.ci-credit { background:var(--success-bg); color:var(--success); }
.ci-debit  { background:var(--danger-bg);  color:var(--danger); }
.ci-reason { font-size:.87rem; font-weight:600; color:var(--t1); }
.ci-date   { font-size:.74rem; color:var(--t3); margin-top:3px; }
.ci-amount {
  margin-left:auto;
  font-family:'Space Grotesk',sans-serif;
  font-size:1rem;
  font-weight:900;
}
.ci-credit .ci-amount { color:var(--success); }
.ci-debit  .ci-amount { color:var(--danger); }

/* ═══════════════════════════════════════════════════════════════════════════
   MOLAR MASS CALCULATOR
   ═══════════════════════════════════════════════════════════════════════════ */
.molar-calc {
  background:var(--surface);
  border:1.5px solid var(--border);
  border-radius:var(--r-xl);
  padding:28px;
  box-shadow:var(--sh-sm);
  max-width:560px;
}
.molar-calc-header {
  display:flex;
  align-items:center;
  gap:12px;
  margin-bottom:20px;
}
.molar-calc-header .mc-icon {
  width:46px; height:46px;
  border-radius:12px;
  background:var(--g-brand);
  display:grid; place-items:center;
  font-size:1.3rem;
  color:#fff;
}
.molar-calc-header h3 {
  font-family:'Space Grotesk',sans-serif;
  font-size:1.1rem;
  font-weight:800;
}
.mc-input-row {
  display:flex;
  gap:10px;
  margin-bottom:14px;
}
.mc-input-row input {
  flex:1;
  padding:12px 16px;
  border:1.5px solid var(--border);
  border-radius:10px;
  font-size:1rem;
  font-family:'JetBrains Mono',monospace;
  background:var(--surface2);
  color:var(--t1);
  transition:all var(--trans);
}
.mc-input-row input:focus {
  outline:none;
  border-color:var(--brand);
  background:var(--surface);
  box-shadow:0 0 0 3px rgba(99,102,241,.12);
}
.mc-result {
  padding:14px 16px;
  border-radius:12px;
  font-size:.9rem;
  min-height:50px;
  display:flex;
  align-items:center;
  gap:10px;
  background:var(--surface2);
  border:1.5px solid var(--border-soft);
  font-family:'JetBrains Mono',monospace;
  transition:all var(--trans);
  margin-bottom:14px;
}
.mc-result.success {
  background:var(--success-bg);
  border-color:rgba(16,185,129,.3);
  color:var(--t1);
}
.mc-result.error {
  background:var(--danger-bg);
  border-color:rgba(239,68,68,.3);
  color:var(--danger);
}
.mc-examples {
  display:flex;
  flex-wrap:wrap;
  gap:8px;
}
.mc-ex-btn {
  padding:5px 12px;
  border-radius:999px;
  border:1.5px solid var(--border);
  background:var(--surface2);
  color:var(--t2);
  font-size:.78rem;
  font-weight:700;
  cursor:pointer;
  transition:all var(--trans);
  font-family:'JetBrains Mono',monospace;
}
.mc-ex-btn:hover { border-color:var(--brand); color:var(--brand); background:var(--brand-pale); }

/* ═══════════════════════════════════════════════════════════════════════════
   PROFILE PAGE
   ═══════════════════════════════════════════════════════════════════════════ */
.profile-hero {
  background:var(--g-brand);
  border-radius:var(--r-xl);
  padding:28px;
  color:#fff;
  display:flex;
  align-items:center;
  gap:22px;
  margin-bottom:22px;
  position:relative;
  overflow:hidden;
}
.profile-hero::before {
  content:'';
  position:absolute; inset:0;
  background:url("data:image/svg+xml,%3Csvg width='400' height='200' xmlns='http://www.w3.org/2000/svg'%3E%3Ccircle cx='360' cy='40' r='150' fill='rgba(255,255,255,.06)'/%3E%3C/svg%3E") right/auto no-repeat;
  pointer-events:none;
}
.profile-avatar-wrap { position:relative; flex-shrink:0; z-index:1; }
.profile-avatar {
  width:90px; height:90px;
  border-radius:50%;
  border:3px solid rgba(255,255,255,.35);
  overflow:hidden;
  background:var(--accent);
  display:flex; align-items:center; justify-content:center;
  font-size:2.2rem;
  font-weight:900;
  color:#fff;
  cursor:pointer;
}
.profile-avatar img { width:100%; height:100%; object-fit:cover; }
.profile-avatar-edit {
  position:absolute; bottom:2px; right:2px;
  width:28px; height:28px;
  border-radius:50%;
  background:var(--g-brand);
  border:2px solid #fff;
  display:grid; place-items:center;
  font-size:.72rem;
  color:#fff;
  cursor:pointer;
  transition:transform var(--trans);
}
.profile-avatar-edit:hover { transform:scale(1.15); }
.profile-info { position:relative; z-index:1; }
.profile-info h2 {
  font-family:'Space Grotesk',sans-serif;
  font-size:1.6rem;
  font-weight:900;
  letter-spacing:-.4px;
}
.profile-info p { opacity:.75; font-size:.88rem; margin-top:5px; }
.profile-info .profile-tags { display:flex; flex-wrap:wrap; gap:8px; margin-top:10px; }
.ptag {
  display:flex; align-items:center; gap:6px;
  padding:5px 12px;
  border-radius:999px;
  background:rgba(255,255,255,.15);
  border:1px solid rgba(255,255,255,.25);
  font-size:.78rem;
  font-weight:700;
  backdrop-filter:blur(8px);
}

/* ═══════════════════════════════════════════════════════════════════════════
   ADMIN SIDEBAR
   ═══════════════════════════════════════════════════════════════════════════ */
.sidebar-admin {
  background:var(--g-admin-sb);
}
.sidebar-admin .nav-item.active {
  background:rgba(255,65,108,.25);
  border-left-color:#ff416c;
}
.sidebar-admin .nav-item:hover {
  background:rgba(255,65,108,.12);
}
.sidebar-admin .sidebar-coins {
  background:var(--g-admin);
  box-shadow:0 6px 18px rgba(255,65,108,.3);
}

/* Teacher Sidebar */
.sidebar-teacher {
  background:linear-gradient(180deg, #064e3b 0%, #065f46 60%, #064e3b 100%);
}
.sidebar-teacher .nav-item.active {
  background:rgba(5,150,105,.3);
  border-left-color:#10b981;
}
.sidebar-teacher .nav-item:hover {
  background:rgba(5,150,105,.15);
}
.sidebar-teacher .sidebar-brand { border-bottom-color:rgba(255,255,255,.06); }
.sidebar-teacher .sidebar-user { background:rgba(5,150,105,.15); border-color:rgba(5,150,105,.3); }

/* ═══════════════════════════════════════════════════════════════════════════
   ANIMATIONS
   ═══════════════════════════════════════════════════════════════════════════ */
.fade-up {
  animation:fadeUp .6s var(--ease) both;
}
@keyframes fadeUp {
  from { opacity:0; transform:translateY(18px); }
  to   { opacity:1; transform:translateY(0); }
}
.fade-in { animation:fadeIn .35s var(--ease) both; }
@keyframes fadeIn { from { opacity:0; } to { opacity:1; } }

/* Stagger children */
.stagger > *:nth-child(1) { animation-delay:.05s; }
.stagger > *:nth-child(2) { animation-delay:.10s; }
.stagger > *:nth-child(3) { animation-delay:.15s; }
.stagger > *:nth-child(4) { animation-delay:.20s; }
.stagger > *:nth-child(5) { animation-delay:.25s; }
.stagger > *:nth-child(6) { animation-delay:.30s; }

/* ═══════════════════════════════════════════════════════════════════════════
   MISC UTILITIES
   ═══════════════════════════════════════════════════════════════════════════ */
.text-muted  { color:var(--t3); }
.text-small  { font-size:.8rem; }
.fw-800      { font-weight:800; }
.mono        { font-family:'JetBrains Mono',monospace; }
.spacer      { flex:1; }
.gap-8       { gap:8px; }
.mt-8        { margin-top:8px; }
.mt-16       { margin-top:16px; }
.mb-16       { margin-bottom:16px; }
.d-flex      { display:flex; }
.align-center{ align-items:center; }
.flex-wrap   { flex-wrap:wrap; }
.w-100       { width:100%; }

/* Divider */
.divider { height:1px; background:var(--border); margin:16px 0; }

/* Section title */
.section-title {
  font-family:'Space Grotesk',sans-serif;
  font-size:1rem;
  font-weight:800;
  color:var(--t1);
  margin-bottom:14px;
  display:flex;
  align-items:center;
  gap:10px;
}
.section-title::after {
  content:'';
  flex:1;
  height:1.5px;
  background:var(--border);
  border-radius:1px;
}

/* ═══════════════════════════════════════════════════════════════════════════
   RESPONSIVE
   ═══════════════════════════════════════════════════════════════════════════ */
@media (max-width: 1100px) {
  .col-3  { grid-column:span 6; }
  .col-4  { grid-column:span 6; }
  .col-5  { grid-column:span 7; }
  .col-7  { grid-column:span 12; }
  .col-8  { grid-column:span 12; }
  .col-9  { grid-column:span 12; }
}
@media (max-width: 768px) {
  :root { --sidebar-w: 0px; }
  .sidebar {
    transform:translateX(-100%);
    width:270px;
  }
  .sidebar.open { transform:translateX(0); box-shadow:var(--sh-xl); }
  .mobile-menu-btn { display:grid; }
  .main-content { margin-left:0; padding:72px 16px 80px; }
  .login-box { grid-template-columns:1fr; }
  .login-left { display:none; }
  .login-right { border-radius:28px; }
  .welcome-banner { grid-template-columns:1fr; }
  .wb-right { align-items:flex-start; }
  .stats-grid { grid-template-columns:repeat(2,1fr); }
  .grid { grid-template-columns:1fr; }
  .col-3,.col-4,.col-5,.col-6,.col-7,.col-8,.col-9,.col-12 { grid-column:span 1; }
  .profile-hero { flex-direction:column; text-align:center; }
  .page-topbar { flex-direction:column; align-items:flex-start; }
}
@media (max-width: 480px) {
  .stats-grid { grid-template-columns:1fr; }
  .products-grid { grid-template-columns:1fr; }
  .welcome-banner { padding:20px 18px; }
  .wb-name { font-size:1.5rem; }
  .main-content { padding:68px 12px 72px; }
}

/* ═══════════════════════════════════════════════════════════════════════════
   PRINT
   ═══════════════════════════════════════════════════════════════════════════ */
@media print {
  .sidebar, .mobile-menu-btn, .overlay { display:none!important; }
  .main-content { margin-left:0!important; padding:0!important; }
  .card { break-inside:avoid; }
}
