/* ═══════════════════════════════════════════════════════════════════════════
   TMS Teacher Portal — Design System v5.0 — Complete Redesign
   ═══════════════════════════════════════════════════════════════════════════ */

@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');

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

/* ── Design Tokens ─────────────────────────────────────────────────────── */
:root {
  --brand:        #059669;
  --brand-dark:   #047857;
  --brand-soft:   #34d399;
  --brand-pale:   #d1fae5;
  --accent:       #0ea5e9;
  --accent-soft:  #e0f2fe;

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

  --g-brand:      linear-gradient(135deg,#059669 0%,#047857 100%);
  --g-teacher:    linear-gradient(135deg,#059669 0%,#22c55e 100%);
  --g-sidebar:    linear-gradient(180deg,#022c22 0%,#064e3b 55%,#022c22 100%);
  --g-hero:       linear-gradient(135deg,#059669 0%,#0ea5e9 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%);
  --g-brand-full: linear-gradient(135deg,#059669 0%,#22c55e 40%,#0ea5e9 100%);

  --bg:           #f0fdf4;
  --surface:      #ffffff;
  --surface2:     #f8fffe;
  --surface3:     #f0fdf4;
  --border:       #d1fae5;
  --border-soft:  #e6fff6;

  --t1:   #0f172a;
  --t2:   #374151;
  --t3:   #6b7280;
  --t-inv:#ffffff;

  --sidebar-w:  280px;
  --max-w:      1440px;

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

  --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(5,150,105,.3);

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

[data-theme="dark"] {
  --bg:         #071a12;
  --surface:    #0f2419;
  --surface2:   #162e1e;
  --surface3:   #1a3824;
  --border:     #1e4030;
  --border-soft:#162e20;
  --t1:  #f0fdf4;
  --t2:  #a7f3d0;
  --t3:  #4b9a6e;
  --brand-pale: rgba(5,150,105,.18);
  --accent-soft:rgba(14,165,233,.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,.4);
  --sh-md:  0 4px 20px rgba(0,0,0,.5);
  --sh-lg:  0 8px 40px rgba(0,0,0,.6);
}

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(5,150,105,.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,.5);
  z-index:800;
  opacity:0; pointer-events:none;
  transition:opacity var(--trans);
  backdrop-filter:blur(4px);
}
.overlay.visible { opacity:1; pointer-events:all; }

/* ═══════════════════════════════════════════════════════════════════════════
   SIDEBAR
   ═══════════════════════════════════════════════════════════════════════════ */
.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;
  border-right:1px solid rgba(16,185,129,.12);
}
.sidebar::-webkit-scrollbar { display:none; }

.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:46px; height:46px;
  border-radius:14px;
  background:var(--g-teacher);
  display:flex; align-items:center; justify-content:center;
  font-size:1.3rem; color:#fff;
  flex-shrink:0; overflow:hidden;
  border:2px solid rgba(255,255,255,.25);
  box-shadow:0 4px 14px rgba(5,150,105,.4);
}
.logo-icon img { width:100%; height:100%; object-fit:cover; border-radius:12px; }
.sidebar-brand h2 { color:#fff; font-size:1.1rem; font-weight:800; letter-spacing:-.3px; }
.sidebar-brand p  { color:rgba(255,255,255,.4); font-size:.68rem; letter-spacing:.6px; text-transform:uppercase; margin-top:2px; }

.sidebar-user {
  display:flex; align-items:center; gap:12px;
  padding:11px 13px;
  background:rgba(16,185,129,.14);
  border:1px solid rgba(16,185,129,.28);
  border-radius:12px;
}
.s-avatar {
  width:42px; height:42px;
  border-radius:50%;
  background:var(--g-teacher);
  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-section { padding:12px 14px 4px; }
.nav-label {
  font-size:.62rem; font-weight:700;
  letter-spacing:1.2px; color:rgba(255,255,255,.22);
  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,.65);
  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(16,185,129,.15); color:#fff; transform:translateX(3px);
}
.nav-item.active {
  background:rgba(16,185,129,.25); color:#fff; border-left-color:#34d399;
}
.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;
}

.sidebar-footer {
  margin-top:auto;
  padding:14px 16px 18px;
  border-top:1px solid rgba(255,255,255,.08);
  flex-shrink:0;
}
.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; }

/* ═══════════════════════════════════════════════════════════════════════════
   MAIN CONTENT
   ═══════════════════════════════════════════════════════════════════════════ */
.main-content {
  margin-left:var(--sidebar-w);
  min-height:100vh;
  display:flex; flex-direction:column;
  transition:margin-left var(--trans-slow);
}
.page-container {
  flex:1; padding:28px 32px;
  max-width:var(--max-w);
  width:100%;
}

/* ── Page Topbar ─────────────────────────────────────────────────────────── */
.page-topbar {
  display:flex; align-items:center; justify-content:space-between;
  gap:16px; flex-wrap:wrap; margin-bottom:24px;
}
.page-topbar-left h1 {
  font-family:'Space Grotesk',sans-serif;
  font-size:1.55rem; font-weight:800; color:var(--t1);
  display:flex; align-items:center; gap:10px;
}
.page-topbar-left p { color:var(--t3); font-size:.88rem; margin-top:4px; }
.topbar-actions { display:flex; align-items:center; gap:8px; flex-wrap:wrap; }

/* ═══════════════════════════════════════════════════════════════════════════
   CARDS
   ═══════════════════════════════════════════════════════════════════════════ */
.card {
  background:var(--surface);
  border:1.5px solid var(--border);
  border-radius:var(--r-xl);
  box-shadow:var(--sh-sm);
  overflow:hidden;
  transition:box-shadow var(--trans);
}
.card:hover { box-shadow:var(--sh-md); }
.card-head {
  display:flex; align-items:center; justify-content:space-between;
  padding:18px 22px; border-bottom:1px solid var(--border-soft);
}
.card-title {
  display:flex; align-items:center; gap:10px;
  font-weight:800; font-size:.95rem; color:var(--t1);
}
.card-body { padding:20px 22px; }

/* Stat Cards */
.stats-grid {
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(180px,1fr));
  gap:16px; margin-bottom:24px;
}
.stat-card {
  background:var(--surface);
  border:1.5px solid var(--border);
  border-radius:var(--r-lg);
  padding:20px 18px;
  display:flex; align-items:center; gap:14px;
  box-shadow:var(--sh-xs);
  transition:all var(--trans);
  position:relative; overflow:hidden;
}
.stat-card::before {
  content:''; position:absolute; inset:0;
  background:linear-gradient(135deg,transparent 60%,rgba(5,150,105,.04));
  pointer-events:none;
}
.stat-card:hover { transform:translateY(-3px); box-shadow:var(--sh-md); }
.stat-icon {
  width:48px; height:48px; border-radius:14px;
  display:flex; align-items:center; justify-content:center;
  font-size:1.2rem; flex-shrink:0;
}
.ico-success { background:var(--success-bg); color:var(--success); }
.ico-warning { background:var(--warning-bg); color:var(--warning); }
.ico-danger  { background:var(--danger-bg);  color:var(--danger);  }
.ico-info    { background:var(--info-bg);    color:var(--info);    }
.ico-brand   { background:var(--brand-pale); color:var(--brand);   }
.ico-pink    { background:#fdf2f8; color:var(--pink); }
.stat-val    { font-size:1.7rem; font-weight:900; color:var(--t1); line-height:1; }
.stat-label  { font-size:.78rem; font-weight:700; color:var(--t3); margin-top:3px; }
.stat-sub    { font-size:.7rem; margin-top:4px; display:flex; align-items:center; gap:4px; }
.sub-success { color:var(--success); }
.sub-warning { color:var(--warning); }
.sub-info    { color:var(--info); }
.sub-brand   { color:var(--brand); }

/* ═══════════════════════════════════════════════════════════════════════════
   GRID
   ═══════════════════════════════════════════════════════════════════════════ */
.grid {
  display:grid;
  grid-template-columns:repeat(12,1fr);
  gap:20px;
}
.col-1  { grid-column:span 1; }
.col-2  { grid-column:span 2; }
.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-10 { grid-column:span 10; }
.col-11 { grid-column:span 11; }
.col-12 { grid-column:span 12; }

/* ═══════════════════════════════════════════════════════════════════════════
   BUTTONS
   ═══════════════════════════════════════════════════════════════════════════ */
.btn {
  display:inline-flex; align-items:center; gap:7px;
  padding:9px 18px; border-radius:var(--r-sm);
  font-size:.84rem; font-weight:700; cursor:pointer;
  transition:all var(--trans); border:none;
  white-space:nowrap; text-decoration:none;
}
.btn-primary {
  background:var(--g-teacher); color:#fff;
  box-shadow:0 4px 14px rgba(5,150,105,.3);
}
.btn-primary:hover { opacity:.9; transform:translateY(-1px); box-shadow:var(--sh-brand); }
.btn-ghost {
  background:var(--surface2); color:var(--t2);
  border:1.5px solid var(--border);
}
.btn-ghost:hover { background:var(--surface3); color:var(--t1); }
.btn-danger { background:var(--g-danger); color:#fff; }
.btn-danger:hover { opacity:.9; }
.btn-success { background:var(--g-success); color:#fff; }
.btn-info { background:var(--g-info); color:#fff; }
.btn-warning { background:var(--g-warning); color:#fff; }
.btn-sm  { padding:6px 13px; font-size:.78rem; border-radius:var(--r-sm); }
.btn-xs  { padding:4px 9px; font-size:.72rem; border-radius:6px; }
.btn-lg  { padding:12px 26px; font-size:.96rem; }
.icon-btn {
  width:36px; height:36px; border-radius:9px;
  background:var(--surface2); border:1.5px solid var(--border);
  display:flex; align-items:center; justify-content:center;
  cursor:pointer; color:var(--t3); transition:all var(--trans);
}
.icon-btn:hover { background:var(--surface3); color:var(--t1); }

/* ═══════════════════════════════════════════════════════════════════════════
   FORMS
   ═══════════════════════════════════════════════════════════════════════════ */
.form-group { display:flex; flex-direction:column; gap:5px; }
.form-label { font-size:.78rem; font-weight:700; color:var(--t2); }
.form-control {
  width:100%; padding:9px 12px;
  border:1.5px solid var(--border);
  border-radius:var(--r-sm);
  background:var(--surface);
  color:var(--t1); font-size:.9rem;
  transition:all var(--trans);
  outline:none;
}
.form-control:focus { border-color:var(--brand); box-shadow:0 0 0 3px rgba(5,150,105,.12); }
.form-control::placeholder { color:var(--t3); }
select.form-control { cursor:pointer; }
textarea.form-control { resize:vertical; min-height:80px; }
.form-hint { font-size:.72rem; color:var(--t3); margin-top:3px; }

.adv-select {
  appearance:none; -webkit-appearance:none;
  width:100%; padding:9px 12px;
  border:1.5px solid var(--border);
  border-radius:var(--r-sm);
  background:var(--surface) url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%236b7280' stroke-width='2'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E") no-repeat right 12px center;
  color:var(--t1); font-size:.9rem; cursor:pointer;
  transition:all var(--trans); outline:none;
}
.adv-select:focus { border-color:var(--brand); box-shadow:0 0 0 3px rgba(5,150,105,.12); }

/* ═══════════════════════════════════════════════════════════════════════════
   BADGES & PILLS
   ═══════════════════════════════════════════════════════════════════════════ */
.badge {
  display:inline-flex; align-items:center; gap:4px;
  padding:2px 9px; border-radius:var(--r-pill);
  font-size:.68rem; font-weight:800; letter-spacing:.3px;
}
.badge-success { background:var(--success-bg); color:#065f46; }
.badge-warning { background:var(--warning-bg); color:#92400e; }
.badge-danger  { background:var(--danger-bg);  color:#991b1b; }
.badge-info    { background:var(--info-bg);    color:#1e40af; }
.badge-brand   { background:var(--brand-pale); color:#065f46; }
.badge-neutral { background:var(--surface2);   color:var(--t3); border:1px solid var(--border); }
.badge-pink    { background:#fdf2f8; color:#9d174d; }

.pill {
  width:30px; height:30px; border-radius:9px;
  display:flex; align-items:center; justify-content:center;
  color:#fff; font-size:.85rem; flex-shrink:0;
}

/* ═══════════════════════════════════════════════════════════════════════════
   ALERTS
   ═══════════════════════════════════════════════════════════════════════════ */
.alert {
  padding:12px 18px; border-radius:var(--r-md);
  display:flex; align-items:center; gap:10px;
  font-size:.88rem; font-weight:600; margin-bottom:20px;
  border-left:4px solid currentColor;
}
.alert-success { background:var(--success-bg); color:#065f46; }
.alert-danger  { background:var(--danger-bg);  color:#991b1b; }
.alert-warning { background:var(--warning-bg); color:#92400e; }
.alert-info    { background:var(--info-bg);    color:#1e40af; }

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

/* ═══════════════════════════════════════════════════════════════════════════
   MOBILE MENU
   ═══════════════════════════════════════════════════════════════════════════ */
.mobile-menu-btn {
  display:none;
  position:fixed; top:14px; left:14px; z-index:1000;
  width:42px; height:42px; border-radius:12px;
  background:var(--brand); border:none;
  color:#fff; font-size:1.1rem; cursor:pointer;
  box-shadow:0 4px 14px rgba(5,150,105,.4);
  align-items:center; justify-content:center;
}

/* ═══════════════════════════════════════════════════════════════════════════
   LOGIN PAGE
   ═══════════════════════════════════════════════════════════════════════════ */
.login-page {
  min-height:100vh;
  display:flex; align-items:center; justify-content:center;
  padding:20px;
}
.login-box {
  width:100%; max-width:920px;
  background:var(--surface);
  border-radius:var(--r-xl);
  overflow:hidden;
  box-shadow:var(--sh-xl);
  display:flex; min-height:540px;
}
.login-left {
  width:340px; flex-shrink:0;
  padding:40px 36px;
  display:flex; flex-direction:column;
  color:#fff;
}
.login-logo { display:flex; align-items:center; gap:14px; margin-bottom:32px; }
.login-logo-icon {
  width:52px; height:52px; border-radius:16px;
  background:rgba(255,255,255,.2);
  display:flex; align-items:center; justify-content:center;
  font-size:1.6rem;
  border:2px solid rgba(255,255,255,.25);
}
.login-logo-name { font-size:1.15rem; font-weight:900; color:#fff; }
.login-logo-sub  { font-size:.72rem; color:rgba(255,255,255,.5); margin-top:2px; }
.login-tagline {
  font-family:'Space Grotesk',sans-serif;
  font-size:2rem; font-weight:900; color:#fff;
  line-height:1.2; margin-bottom:14px;
}
.login-desc { font-size:.84rem; opacity:.78; margin-bottom:24px; }
.login-features { list-style:none; display:flex; flex-direction:column; gap:8px; }
.login-features li {
  display:flex; align-items:center; gap:10px;
  font-size:.82rem; opacity:.85;
}
.login-features li::before {
  content:'✓'; width:20px; height:20px;
  background:rgba(255,255,255,.2); border-radius:50%;
  display:flex; align-items:center; justify-content:center;
  font-size:.72rem; flex-shrink:0;
}
.login-right {
  flex:1; padding:40px 42px;
  display:flex; flex-direction:column; justify-content:center;
}
.login-right h2 { font-family:'Space Grotesk',sans-serif; font-size:1.5rem; font-weight:900; margin-bottom:4px; }
.login-right .sub { color:var(--t3); font-size:.85rem; margin-bottom:24px; }
.login-err {
  background:var(--danger-bg); color:#991b1b;
  padding:10px 14px; border-radius:var(--r-md);
  font-size:.84rem; margin-bottom:16px;
  display:flex; align-items:center; gap:8px;
  border-left:3px solid var(--danger);
}
.login-field { margin-bottom:14px; }
.login-field label { display:block; font-size:.78rem; font-weight:700; color:var(--t2); margin-bottom:5px; }
.login-input-wrap {
  position:relative; display:flex; align-items:center;
}
.login-input-wrap i { position:absolute; left:13px; color:var(--t3); pointer-events:none; }
.login-input-wrap input {
  width:100%; padding:11px 14px 11px 38px;
  border:1.5px solid var(--border); border-radius:var(--r-sm);
  background:var(--surface); color:var(--t1); font-size:.92rem;
  transition:all var(--trans); outline:none;
}
.login-input-wrap input:focus { border-color:var(--brand); box-shadow:0 0 0 3px rgba(5,150,105,.12); }
.login-btn {
  width:100%; padding:12px;
  border:none; border-radius:var(--r-sm);
  font-size:.92rem; font-weight:800; color:#fff; cursor:pointer;
  display:flex; align-items:center; justify-content:center; gap:9px;
  transition:all var(--trans); margin-top:8px;
  box-shadow:0 4px 16px rgba(5,150,105,.35);
}
.login-btn:hover { opacity:.92; transform:translateY(-1px); }

/* ═══════════════════════════════════════════════════════════════════════════
   STAGGER / ANIMATIONS
   ═══════════════════════════════════════════════════════════════════════════ */
@keyframes fadeSlideUp {
  from { opacity:0; transform:translateY(18px); }
  to   { opacity:1; transform:translateY(0); }
}
.fade-up { animation:fadeSlideUp .4s var(--ease) both; }
.stagger > * { animation:fadeSlideUp .4s var(--ease) both; }
.stagger > *:nth-child(1)  { animation-delay:.04s; }
.stagger > *:nth-child(2)  { animation-delay:.08s; }
.stagger > *:nth-child(3)  { animation-delay:.12s; }
.stagger > *:nth-child(4)  { animation-delay:.16s; }
.stagger > *:nth-child(5)  { animation-delay:.20s; }
.stagger > *:nth-child(6)  { animation-delay:.24s; }
.stagger > *:nth-child(7)  { animation-delay:.28s; }
.stagger > *:nth-child(8)  { animation-delay:.32s; }
.fade-in { animation:fadeSlideUp .3s var(--ease) both; }

/* ═══════════════════════════════════════════════════════════════════════════
   SPOTLIGHT MODAL
   ═══════════════════════════════════════════════════════════════════════════ */
.modal-bg {
  position:fixed; inset:0;
  background:rgba(0,0,0,.6);
  z-index:2000;
  display:none;
  align-items:center; justify-content:center;
  backdrop-filter:blur(6px);
}
.modal-bg.open { display:flex !important; }
.modal-box {
  background:var(--surface);
  border-radius:var(--r-xl);
  box-shadow:var(--sh-xl);
  width:100%; max-width:580px;
  max-height:88vh; overflow-y:auto;
  padding:24px;
  border:1.5px solid var(--border);
}
.spotlight-item {
  display:flex; align-items:center; gap:12px;
  padding:10px 12px; border-radius:var(--r-md);
  cursor:pointer; transition:background var(--trans);
  text-decoration:none; color:var(--t1);
}
.spotlight-item:hover { background:var(--surface2); }
.spotlight-icon {
  width:34px; height:34px; border-radius:9px;
  background:var(--brand-pale); color:var(--brand);
  display:flex; align-items:center; justify-content:center;
  font-size:.85rem; flex-shrink:0;
}
.spotlight-name  { font-weight:700; font-size:.88rem; }
.spotlight-hint  { font-size:.72rem; color:var(--t3); }

/* ═══════════════════════════════════════════════════════════════════════════
   TOAST
   ═══════════════════════════════════════════════════════════════════════════ */
#toastContainer {
  position:fixed; bottom:24px; right:24px; z-index:5000;
  display:flex; flex-direction:column; gap:10px;
}
.toast {
  padding:12px 18px; border-radius:var(--r-md);
  font-size:.84rem; font-weight:700;
  display:flex; align-items:center; gap:10px;
  box-shadow:var(--sh-lg);
  animation:fadeSlideUp .3s var(--ease) both;
  max-width:320px;
}
.toast-success { background:#065f46; color:#fff; }
.toast-danger  { background:#991b1b; color:#fff; }
.toast-info    { background:#1e40af; color:#fff; }

/* ═══════════════════════════════════════════════════════════════════════════
   LOADING
   ═══════════════════════════════════════════════════════════════════════════ */
.loading-spinner {
  width:16px; height:16px;
  border:2.5px solid rgba(255,255,255,.3);
  border-top-color:#fff;
  border-radius:50%;
  display:inline-block;
  animation:spin .7s linear infinite;
}
@keyframes spin { to { transform:rotate(360deg); } }

/* ═══════════════════════════════════════════════════════════════════════════
   HERO BANNER
   ═══════════════════════════════════════════════════════════════════════════ */
.hero-banner {
  background:var(--g-brand-full);
  border-radius:var(--r-xl);
  padding:28px 32px;
  color:#fff; margin-bottom:24px;
  position:relative; overflow:hidden;
  display:flex; align-items:center; justify-content:space-between; gap:20px;
  flex-wrap:wrap;
}
.hero-banner::after {
  content:'';
  position:absolute; right:-40px; top:-40px;
  width:240px; height:240px;
  background:rgba(255,255,255,.06);
  border-radius:50%;
  pointer-events:none;
}
.hero-banner h1 { font-family:'Space Grotesk',sans-serif; font-size:1.6rem; font-weight:900; margin-bottom:6px; }
.hero-banner p  { opacity:.88; font-size:.9rem; margin:0; }

/* ═══════════════════════════════════════════════════════════════════════════
   TABLE
   ═══════════════════════════════════════════════════════════════════════════ */
.table-wrap { overflow-x:auto; }
table { width:100%; border-collapse:collapse; }
thead th {
  text-align:left; padding:10px 14px;
  font-size:.72rem; font-weight:800; letter-spacing:.4px;
  text-transform:uppercase; color:var(--t3);
  background:var(--surface2); border-bottom:1px solid var(--border);
}
tbody td {
  padding:12px 14px; border-bottom:1px solid var(--border-soft);
  font-size:.86rem; color:var(--t1);
}
tbody tr:last-child td { border-bottom:none; }
tbody tr:hover { background:var(--surface2); }

/* ═══════════════════════════════════════════════════════════════════════════
   TABS
   ═══════════════════════════════════════════════════════════════════════════ */
.tabs {
  display:flex; gap:0; background:var(--surface);
  border:1.5px solid var(--border); border-radius:var(--r-md);
  overflow:hidden; margin-bottom:20px;
}
.tab-btn {
  flex:1; padding:10px 16px; border:none; background:transparent;
  cursor:pointer; font-size:.82rem; font-weight:700; color:var(--t3);
  transition:all var(--trans); border-right:1px solid var(--border);
  display:flex; align-items:center; justify-content:center; gap:6px;
}
.tab-btn:last-child { border-right:none; }
.tab-btn.active { background:var(--g-teacher); color:#fff; }
.tab-btn:hover:not(.active) { background:var(--surface2); color:var(--t1); }

/* ═══════════════════════════════════════════════════════════════════════════
   QUICK ACTION GRID
   ═══════════════════════════════════════════════════════════════════════════ */
.quick-grid {
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(160px,1fr));
  gap:12px; margin-bottom:24px;
}
.quick-card {
  background:var(--surface); border:1.5px solid var(--border);
  border-radius:var(--r-lg); padding:20px 14px;
  display:flex; flex-direction:column; align-items:center; gap:10px;
  text-align:center; cursor:pointer; transition:all var(--trans);
  text-decoration:none; color:var(--t1);
}
.quick-card:hover {
  border-color:var(--brand); background:var(--brand-pale);
  transform:translateY(-3px); box-shadow:var(--sh-md);
}
.quick-card-icon {
  width:50px; height:50px; border-radius:14px;
  background:var(--brand-pale); color:var(--brand);
  display:flex; align-items:center; justify-content:center;
  font-size:1.3rem;
}
.quick-card-label { font-size:.8rem; font-weight:700; }

/* ═══════════════════════════════════════════════════════════════════════════
   RESPONSIVE
   ═══════════════════════════════════════════════════════════════════════════ */
@media (max-width:1100px) {
  .col-5,.col-7 { grid-column:span 6; }
}
@media (max-width:900px) {
  :root { --sidebar-w:0px; }
  .sidebar { transform:translateX(-100%); width:280px; }
  .sidebar.open { transform:translateX(0); }
  .main-content { margin-left:0; }
  .mobile-menu-btn { display:flex; }
  .page-container { padding:20px 16px 70px; }
  .grid { grid-template-columns:1fr; }
  .col-1,.col-2,.col-3,.col-4,.col-5,.col-6,
  .col-7,.col-8,.col-9,.col-10,.col-11,.col-12 { grid-column:span 1; }
  .login-box { flex-direction:column; }
  .login-left { width:100%; }
}
@media (max-width:600px) {
  .stats-grid { grid-template-columns:1fr 1fr; }
  .quick-grid  { grid-template-columns:1fr 1fr; }
  .hero-banner { padding:20px; }
  .hero-banner h1 { font-size:1.2rem; }
}

/* ═══════════════════════════════════════════════════════════════════════════
   TEACHER-SPECIFIC UTILITIES
   ═══════════════════════════════════════════════════════════════════════════ */
.section-divider {
  border:none; border-top:1px solid var(--border);
  margin:20px 0;
}
.text-green  { color:var(--brand); }
.text-muted  { color:var(--t3); }
.fw-900 { font-weight:900; }
.fw-700 { font-weight:700; }
.fs-sm  { font-size:.82rem; }
.fs-xs  { font-size:.72rem; }
.mt-4   { margin-top:16px; }
.mb-4   { margin-bottom:16px; }
.p-0    { padding:0; }

/* Progress bar */
.progress-bar-wrap {
  height:8px; background:var(--surface2); border-radius:999px; overflow:hidden;
}
.progress-bar-fill {
  height:100%; border-radius:999px;
  background:var(--g-teacher); transition:width .6s var(--ease);
}

/* Feature card */
.feature-card {
  background:var(--surface); border:1.5px solid var(--border);
  border-radius:var(--r-lg); padding:20px;
  transition:all var(--trans); cursor:pointer;
  text-decoration:none; color:var(--t1);
  display:flex; flex-direction:column; gap:10px;
}
.feature-card:hover { border-color:var(--brand); transform:translateY(-3px); box-shadow:var(--sh-md); }
.feature-card-icon {
  width:44px; height:44px; border-radius:12px;
  display:flex; align-items:center; justify-content:center;
  font-size:1.2rem; color:#fff;
}
