/* ═══════════════════════════════════════════════════════
   RUNNING JACK ICT ACADEMY — SHARED THEME & BASE STYLES
   Used by: courses.php, about.php, login.php, register.php,
            admin/*, student/*
═══════════════════════════════════════════════════════ */
@import url('https://fonts.googleapis.com/css2?family=DM+Serif+Display:ital@0;1&family=DM+Sans:ital,wght@0,300;0,400;0,500;0,600;0,700;1,400&display=swap');

*,*::before,*::after{margin:0;padding:0;box-sizing:border-box;}
:root{
  /* Brand */
  --pink:#e8186d; --rose:#c0003a; --gold:#d4920a; --violet:#7c2d8e; --violet2:#9b3daf; --green:#10b981;
  /* Dark theme (default) */
  --surface:#0a0c1a; --card:#10132b; --card2:#141729;
  --line:rgba(255,255,255,.11); --text:#ffffff; --muted:rgba(210,218,245,.88);
  /* Typography */
  --fd:'DM Serif Display','Georgia',serif;
  --fb:'DM Sans','Inter','Segoe UI',sans-serif;
  --ease:cubic-bezier(.22,1,.36,1);
}
/* Light theme */
[data-theme="light"]{
  --surface:#f0ece5; --card:#fff; --card2:#f8f5f0;
  --line:rgba(0,0,0,.12); --text:#0e1018; --muted:rgba(14,16,24,.65);
}
html{scroll-behavior:smooth;}
body{font-family:var(--fb);background:var(--surface);color:var(--text);transition:background .35s,color .35s;overflow-x:hidden;}

/* Custom scrollbar */
::-webkit-scrollbar{width:4px;}
::-webkit-scrollbar-track{background:transparent;}
::-webkit-scrollbar-thumb{background:var(--pink);border-radius:4px;}

/* ── TYPOGRAPHY ─────────────────────────────────────── */
h1,h2,h3{font-family:var(--fd);color:var(--text);line-height:1.15;}

/* ── BUTTONS ────────────────────────────────────────── */
.btn-primary,.btn-rose{display:inline-flex;align-items:center;gap:8px;padding:11px 24px;border-radius:10px;font-family:var(--fb);font-size:.82rem;font-weight:700;letter-spacing:.5px;text-transform:uppercase;text-decoration:none;border:none;cursor:pointer;transition:all .2s;background:var(--pink);color:#fff;box-shadow:0 4px 18px rgba(232,24,109,.35);}
.btn-primary:hover,.btn-rose:hover{background:var(--rose);transform:translateY(-1px);box-shadow:0 8px 24px rgba(232,24,109,.45);}
.btn-ghost{display:inline-flex;align-items:center;gap:8px;padding:10px 22px;border-radius:10px;font-family:var(--fb);font-size:.82rem;font-weight:600;letter-spacing:.5px;text-transform:uppercase;text-decoration:none;border:1.5px solid var(--line);color:var(--muted);background:transparent;cursor:pointer;transition:all .2s;}
.btn-ghost:hover{border-color:var(--pink);color:var(--pink);background:rgba(232,24,109,.06);}
.btn-gold{background:linear-gradient(135deg,var(--gold),#b87800);color:#fff;box-shadow:0 4px 18px rgba(212,146,10,.35);}
.btn-gold:hover{filter:brightness(1.1);transform:translateY(-1px);}

/* ── CARDS ──────────────────────────────────────────── */
.card{background:var(--card);border:1px solid var(--line);border-radius:16px;padding:24px;}
.wid{background:var(--card);border:1px solid var(--line);border-radius:14px;padding:20px;}

/* ── BADGES ─────────────────────────────────────────── */
.badge{display:inline-flex;align-items:center;gap:5px;padding:3px 10px;border-radius:20px;font-size:.7rem;font-weight:700;letter-spacing:.5px;}
.badge-pink{background:rgba(232,24,109,.12);color:var(--pink);}
.badge-gold{background:rgba(212,146,10,.12);color:var(--gold);}
.badge-green{background:rgba(16,185,129,.12);color:#10b981;}
.badge-violet{background:rgba(124,45,142,.12);color:var(--violet2);}
.badge-success{background:rgba(16,185,129,.12);color:#10b981;}
.badge-danger{background:rgba(229,62,62,.12);color:#e53e3e;}

/* ── FORMS ──────────────────────────────────────────── */
.field{display:flex;flex-direction:column;gap:6px;margin-bottom:18px;}
.field label{font-size:.78rem;font-weight:600;color:var(--text);}
.field input,.field select{background:rgba(255,255,255,.04);border:1.5px solid var(--line);border-radius:10px;padding:11px 36px 11px 14px;}.field textarea{background:rgba(255,255,255,.04);border:1.5px solid var(--line);border-radius:10px;padding:11px 14px;font-family:var(--fb);font-size:.88rem;color:var(--text);transition:border-color .2s;}
[data-theme="light"] .field input,[data-theme="light"] .field select,[data-theme="light"] .field textarea{background:rgba(0,0,0,.03);border-color:rgba(0,0,0,.12);}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--pink);}
.field input::placeholder,.field textarea::placeholder{color:var(--muted);}

/* ── TABLES ─────────────────────────────────────────── */
.table-wrap{overflow-x:auto;}
table{width:100%;border-collapse:collapse;}
table th{font-size:.65rem;font-weight:700;text-transform:uppercase;letter-spacing:2px;color:var(--muted);padding:10px 14px;text-align:left;border-bottom:1px solid var(--line);}
table td{font-size:.83rem;padding:13px 14px;border-bottom:1px solid var(--line);color:var(--text);vertical-align:middle;}
table tr:hover td{background:rgba(255,255,255,.02);}
[data-theme="light"] table tr:hover td{background:rgba(0,0,0,.02);}

/* ── THEME TOGGLE ───────────────────────────────────── */
.t-toggle{display:flex;align-items:center;width:44px;height:24px;border-radius:12px;border:1.5px solid var(--line);background:rgba(255,255,255,.06);cursor:pointer;position:relative;transition:background .3s,border-color .3s;flex-shrink:0;}
[data-theme="light"] .t-toggle{background:rgba(0,0,0,.06);border-color:rgba(0,0,0,.15);}
.t-knob{position:absolute;left:3px;width:16px;height:16px;border-radius:50%;background:var(--muted);transition:transform .3s,background .3s;}
[data-theme="light"] .t-knob{transform:translateX(20px);background:var(--gold);}
.t-toggle .t-icon{position:absolute;font-size:9px;transition:opacity .3s;}
.t-toggle .t-moon{right:5px;opacity:1;}
.t-toggle .t-sun{left:5px;opacity:0;}
[data-theme="light"] .t-toggle .t-moon{opacity:0;}
[data-theme="light"] .t-toggle .t-sun{opacity:1;}

/* ── STATS ──────────────────────────────────────────── */
.stat-card{display:flex;flex-direction:column;gap:6px;background:var(--card);border:1px solid var(--line);border-radius:14px;padding:20px;}
.stat-icon{font-size:20px;width:40px;height:40px;border-radius:10px;display:flex;align-items:center;justify-content:center;}
.stat-label{font-size:.72rem;font-weight:600;text-transform:uppercase;letter-spacing:1px;color:var(--muted);}
.stat-value{font-size:1.6rem;font-weight:800;color:var(--text);}
.stat-danger{color:#e53e3e;}
.stat-warning{color:var(--gold);}
.stat-success{color:#10b981;}
.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:16px;}

/* ── PAGE LAYOUT ────────────────────────────────────── */
.page-header{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;margin-bottom:28px;flex-wrap:wrap;}
.page-title{font-family:var(--fd);font-size:1.5rem;color:var(--text);display:flex;align-items:center;gap:10px;}
.page-subtitle{font-size:.82rem;color:var(--muted);margin-top:4px;}
.mb-24{margin-bottom:24px;}

/* ── MISC ───────────────────────────────────────────── */
code{font-family:'DM Mono','Courier New',monospace;font-size:.82em;background:rgba(255,255,255,.06);padding:2px 6px;border-radius:4px;}
[data-theme="light"] code{background:rgba(0,0,0,.06);}
.muted{color:var(--muted);}
.text-pink{color:var(--pink);}
.text-gold{color:var(--gold);}
.text-green{color:#10b981;}
.sep{height:1px;background:var(--line);margin:20px 0;}
.neu{background:var(--card);border:1px solid var(--line);border-radius:16px;}
.neu-btn{display:inline-flex;align-items:center;gap:6px;padding:8px 16px;border-radius:8px;background:var(--card);border:1px solid var(--line);color:var(--text);font-size:.82rem;font-weight:600;cursor:pointer;text-decoration:none;transition:all .2s;}
.neu-btn:hover{border-color:var(--pink);color:var(--pink);}
.neu-input{background:rgba(255,255,255,.04);border:1.5px solid var(--line);border-radius:8px;padding:8px 12px;font-family:var(--fb);font-size:.85rem;color:var(--text);width:100%;}
[data-theme="light"] .neu-input{background:rgba(0,0,0,.03);border-color:rgba(0,0,0,.12);}
.neu-input:focus{outline:none;border-color:var(--pink);}
.form-label{font-size:.75rem;font-weight:600;color:var(--muted);text-transform:uppercase;letter-spacing:.5px;display:block;margin-bottom:4px;}

/* ── TOAST ──────────────────────────────────────────── */
.toast{position:fixed;bottom:28px;right:24px;padding:14px 20px;border-radius:14px;background:var(--card);border:1px solid var(--line);color:var(--text);font-size:.82rem;font-weight:500;z-index:9000;display:flex;align-items:center;gap:10px;box-shadow:0 20px 60px rgba(0,0,0,.4);transform:translateY(80px);opacity:0;transition:all .4s var(--ease);}
.toast.show{transform:translateY(0);opacity:1;}

/* ── RESPONSIVE ─────────────────────────────────────── */
@media(max-width:768px){
  .stats-grid{grid-template-columns:1fr 1fr;}
  .page-header{flex-direction:column;}
}

/*
/* Custom cursor is handled inline only by admin/student pages */
#dot,/* ── AURORA + GRAIN ────────────────────────────────── */
#aurora{position:fixed;inset:0;pointer-events:none;z-index:-1;opacity:.45;}
.grain{position:fixed;inset:0;pointer-events:none;z-index:1;opacity:.022;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='f'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.8' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23f)'/%3E%3C/svg%3E");}

/* ── REVEAL ANIMATIONS (.rv) ───────────────────────── */
/* Visible by default — JS enhances with animation only when confirmed running */
.rv{opacity:1;transform:none;}

/* ═══════════════════════════════════════════════════════
   SIDEBAR STYLES (desktop only, ≥1024px via nav.css)
═══════════════════════════════════════════════════════ */
.sidebar {
  background: var(--card);
  border-right: 1px solid var(--line);
  padding: 0;
  overflow-y: auto;
  overflow-x: hidden;
}
.sidebar-brand {
  display: flex; align-items: center; gap: 10px;
  padding: 18px 16px 14px;
  border-bottom: 1px solid var(--line);
  text-decoration: none;
}
.sidebar-logo {
  width: 36px; height: 36px; border-radius: 9px; object-fit: contain; flex-shrink: 0;
}
.sidebar-name {
  font-family: var(--fd); font-size: .9rem; color: var(--text); line-height: 1.2;
}
.sidebar-name em { font-style: normal; color: var(--gold); }
.sidebar-sub {
  font-size: .62rem; color: var(--muted); letter-spacing: 1px; margin-top: 2px;
}
.sidebar-nav {
  padding: 10px 10px 10px;
  display: flex; flex-direction: column; gap: 2px;
}
.sidebar-section {
  font-size: .58rem; font-weight: 800; text-transform: uppercase;
  letter-spacing: 2px; color: var(--muted); padding: 12px 8px 5px;
}
.nav-link {
  display: flex; align-items: center; gap: 10px;
  padding: 9px 11px; border-radius: 10px;
  font-size: .8rem; font-weight: 600; color: var(--muted);
  text-decoration: none; transition: all .18s;
  border: 1px solid transparent;
}
.nav-link svg {
  width: 16px; height: 16px; stroke: currentColor;
  fill: none; stroke-width: 1.8; flex-shrink: 0;
}
.nav-link:hover {
  color: var(--text);
  background: rgba(255,255,255,.04);
}
[data-theme="light"] .nav-link:hover {
  background: rgba(0,0,0,.04);
}
.nav-link.active {
  color: var(--pink);
  background: rgba(232,24,109,.08);
  border-color: rgba(232,24,109,.15);
}
.nav-link.active svg { stroke: var(--pink); }

/* ── GRAIN OVERLAY ── */
canvas#aurora {
  position: fixed; inset: 0; z-index: 0; pointer-events: none;
}
.grain {
  position: fixed; inset: 0; z-index: 1; pointer-events: none;
  opacity: .025;
  background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
  background-size: 200px 200px;
}



/* duplicate select rules removed */
[data-theme="light"] select {
  background-color: rgba(0,0,0,.03);
  border-color: rgba(0,0,0,.12);
  color: var(--text);
}
[data-theme="light"] select option { background: #fff; color: #12141f; }

/* ═══════════════════════════════════════════
   SIDEBAR LAYOUT — desktop only
═══════════════════════════════════════════ */
@media(min-width: 1024px) {
  body { display: block; }

  .sidebar-foot {
    margin-top: auto;
    padding: 14px;
    border-top: 1px solid var(--line);
  }
  .su-av {
    width: 36px; height: 36px; border-radius: 10px;
    display: flex; align-items: center; justify-content: center;
    font-family: var(--fd); font-size: .8rem; color: #fff;
    font-weight: 700; flex-shrink: 0; overflow: hidden;
  }
  .su-name { font-size: .8rem; font-weight: 600; color: var(--text); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
  .su-role { font-size: .64rem; color: var(--muted); margin-top: 2px; text-transform: uppercase; letter-spacing: .5px; }
}



/* ═══════════════════════════════════════════════════════════════════════
   RUNNING JACK ICT — COMPLETE THEME ENFORCEMENT
   Replaces all previous attempts. Single source of truth.

   DARK MODE  → var(--text)  = #eceef8  |  var(--muted) = rgba(226,228,240,.72)
   LIGHT MODE → var(--text)  = #0e1018  |  var(--muted) = rgba(14,16,24,.65)

   Strategy:
   ─ Fix the 3 root :root blocks (main.css, index.php, login.php, register.php) ✓ done
   ─ Fix .field input/select missing color in base                              ↓ here
   ─ Add light-mode counterparts for every rgba(255,255,255,.xx) background    ↓ here
   ─ Cover every text class used across all admin + student pages               ↓ here
═══════════════════════════════════════════════════════════════════════ */

/* ── 1. BASE ELEMENT COLORS (dark mode — already inherit from body) ─── */
body { color: var(--text); }
p, li, dt, dd, caption, figcaption { color: var(--text); }
h1, h2, h3, h4, h5, h6 { color: var(--text); }
label { color: var(--text); }
table th { color: var(--muted); }
table td { color: var(--text); }
small { color: var(--muted); }

/* Fix: .field input/.field select were missing color entirely */
.field input, .field select { color: var(--text); }

/* All inputs across all pages */
input, textarea, select { color: var(--text); }
input::placeholder, textarea::placeholder { color: var(--muted); }

/* ── 2. LIGHT MODE — BASE ELEMENTS ──────────────────────────────────── */
[data-theme="light"] body,
[data-theme="light"] p,
[data-theme="light"] li,
[data-theme="light"] dt,
[data-theme="light"] dd,
[data-theme="light"] caption { color: var(--text); }

[data-theme="light"] h1,
[data-theme="light"] h2,
[data-theme="light"] h3,
[data-theme="light"] h4,
[data-theme="light"] h5,
[data-theme="light"] h6 { color: var(--text); }

[data-theme="light"] label { color: var(--text); }
[data-theme="light"] small { color: var(--muted); }
[data-theme="light"] table th { color: var(--muted); }
[data-theme="light"] table td { color: var(--text); }

[data-theme="light"] input,
[data-theme="light"] textarea,
[data-theme="light"] select { color: var(--text) !important; }

[data-theme="light"] input::placeholder,
[data-theme="light"] textarea::placeholder { color: var(--muted) !important; }

/* ── 3. LIGHT MODE — rgba(255,255,255,.xx) BACKGROUNDS → swap to dark ─
   Every input/surface that uses a white-tint background in dark mode
   must get a dark-tint background in light mode so text stays readable.
─────────────────────────────────────────────────────────────────────── */

/* Form inputs (shared across all pages using .form-input, .field input, etc.) */
[data-theme="light"] .form-input,
[data-theme="light"] .form-select,
[data-theme="light"] .field input,
[data-theme="light"] .field select,
[data-theme="light"] .field textarea,
[data-theme="light"] .search-input,
[data-theme="light"] .search-box,
[data-theme="light"] .filter-select,
[data-theme="light"] .neu-input {
  background: rgba(0,0,0,.04) !important;
  border-color: rgba(0,0,0,.12) !important;
  color: var(--text) !important;
}

/* Button-like surfaces */
[data-theme="light"] .btn-ghost,
[data-theme="light"] .btn-ghost-fw,
[data-theme="light"] .btn-nav,
[data-theme="light"] .btn-lock,
[data-theme="light"] .btn-qn,
[data-theme="light"] .mc-btn-ghost,
[data-theme="light"] .btn-dl-ghost { background: rgba(0,0,0,.03); color: var(--muted); }

/* Tab surfaces */
[data-theme="light"] .mod-tab { background: rgba(0,0,0,.03); color: var(--muted); }
[data-theme="light"] .mod-tab:hover:not(.active) { color: var(--text); background: rgba(0,0,0,.05); }
[data-theme="light"] .mod-tab .tab-count { background: rgba(0,0,0,.07); }
[data-theme="light"] .pm-tab { background: rgba(0,0,0,.03); color: var(--muted); }
[data-theme="light"] .tab-btn { color: var(--muted); }
[data-theme="light"] .tab-btn:hover { background: rgba(0,0,0,.04); color: var(--text); }
[data-theme="light"] .tab-btn.active { color: var(--pink); }

/* Action/icon buttons */
[data-theme="light"] .act-btn { background: rgba(0,0,0,.03); }
[data-theme="light"] .act-btn svg { stroke: var(--muted); }

/* Modal close */
[data-theme="light"] .modal-close { background: rgba(0,0,0,.03); }

/* Settings toggle switch */
[data-theme="light"] .sw { background: rgba(0,0,0,.1); }

/* Progress/bar tracks */
[data-theme="light"] .prog-bar,
[data-theme="light"] .ls-bar,
[data-theme="light"] .mc-prog-bar,
[data-theme="light"] .pw-bar,
[data-theme="light"] .q-progress-bar,
[data-theme="light"] .progress-wrap { background: rgba(0,0,0,.08); }

/* Stat boxes / quiz cards */
[data-theme="light"] .stat-box,
[data-theme="light"] .q-card { background: rgba(0,0,0,.03); }

/* Lesson list items */
[data-theme="light"] .ls-item:hover { background: rgba(0,0,0,.03); }
[data-theme="light"] .l-num-todo { background: rgba(0,0,0,.07); color: var(--muted); }
[data-theme="light"] .lesson-row { border-bottom-color: rgba(0,0,0,.06); }
[data-theme="light"] .course-header:hover { background: rgba(0,0,0,.02); }

/* Muted badge */
[data-theme="light"] .b-muted { background: rgba(0,0,0,.06); }

/* Rule/firewall row */
[data-theme="light"] .rule-row { background: rgba(0,0,0,.02); }
[data-theme="light"] .toggle.off { background: rgba(0,0,0,.1); }

/* Code blocks in prose */
[data-theme="light"] .prose code { background: rgba(0,0,0,.06); }
[data-theme="light"] .prose pre { background: rgba(0,0,0,.04); }

/* Lesson dot */
[data-theme="light"] .ls-dot { border-color: rgba(0,0,0,.2); }

/* ── 4. LIGHT MODE — NAMED TEXT CLASSES (all pages) ─────────────────── */

/* Page-level titles/subtitles */
[data-theme="light"] .ptitle,
[data-theme="light"] .page-title,
[data-theme="light"] .tcard-title,
[data-theme="light"] .card-title,
[data-theme="light"] .modal-title,
[data-theme="light"] .greeting,
[data-theme="light"] .section-head { color: var(--text); }

[data-theme="light"] .psub,
[data-theme="light"] .page-subtitle,
[data-theme="light"] .gdate { color: var(--muted); }

/* Widget / stat numbers */
[data-theme="light"] .wid-n,
[data-theme="light"] .wid-l,
[data-theme="light"] .stat-value,
[data-theme="light"] .stat-n,
[data-theme="light"] .mstat-n,
[data-theme="light"] .sc-n,
[data-theme="light"] .ps-n { color: var(--text); }

[data-theme="light"] .stat-label,
[data-theme="light"] .stat-l,
[data-theme="light"] .mstat-l,
[data-theme="light"] .sc-l,
[data-theme="light"] .ps-l,
[data-theme="light"] .wid-l { color: var(--muted); }

/* Content item labels */
[data-theme="light"] .ci-name,
[data-theme="light"] .cp-title,
[data-theme="light"] .cert-title,
[data-theme="light"] .course-name,
[data-theme="light"] .mc-title,
[data-theme="light"] .ls-title,
[data-theme="light"] .quiz-title,
[data-theme="light"] .q-text,
[data-theme="light"] .pr-course,
[data-theme="light"] .qa-label { color: var(--text); }

[data-theme="light"] .ci-sub,
[data-theme="light"] .cert-no,
[data-theme="light"] .cert-date,
[data-theme="light"] .course-prog,
[data-theme="light"] .mc-course,
[data-theme="light"] .ls-dur,
[data-theme="light"] .cc-meta,
[data-theme="light"] .quiz-course,
[data-theme="light"] .quiz-meta,
[data-theme="light"] .q-num,
[data-theme="light"] .pr-date,
[data-theme="light"] .qa-sub,
[data-theme="light"] .wid-trend { color: var(--muted); }

/* Lesson row text */
[data-theme="light"] .l-next .l-title { color: var(--text); }
[data-theme="light"] .l-done .l-title { color: var(--muted); }
[data-theme="light"] .l-meta { color: var(--muted); }

/* Form labels */
[data-theme="light"] .form-label { color: var(--muted); }

/* Empty states */
[data-theme="light"] .empty-state { color: var(--muted); }

/* Sidebar */
[data-theme="light"] .sidebar-name { color: var(--text); }
[data-theme="light"] .sidebar-name em { color: var(--gold); }
[data-theme="light"] .sidebar-sub,
[data-theme="light"] .sidebar-section { color: var(--muted); }
[data-theme="light"] .nav-link { color: var(--muted); }
[data-theme="light"] .nav-link:hover { color: var(--text); background: rgba(0,0,0,.04); }
[data-theme="light"] .nav-link.active { color: var(--pink); background: rgba(232,24,109,.08); }
[data-theme="light"] .su-name { color: var(--text); }
[data-theme="light"] .su-role { color: var(--muted); }

/* Top navbar */
[data-theme="light"] .tnav-brand { color: var(--text); }
[data-theme="light"] .tnav-brand em { color: var(--gold); }
[data-theme="light"] .tnav-icon { color: var(--muted); }
[data-theme="light"] .tnav-icon:hover { color: var(--pink); }
[data-theme="light"] .tnav-uname,
[data-theme="light"] .tnav-user { color: var(--text); }

/* Bottom tabs */
[data-theme="light"] .btab { color: var(--muted); }
[data-theme="light"] .btab.active { color: var(--pink); }
[data-theme="light"] .btab:hover { color: var(--text); }
[data-theme="light"] .btab-more-item { color: var(--muted); }
[data-theme="light"] .btab-more-item:hover,
[data-theme="light"] .btab-more-item.active { color: var(--pink); }

/* Public nav */
[data-theme="light"] .nav-name { color: var(--text); }
[data-theme="light"] .nav-name em { color: var(--gold); }
[data-theme="light"] .nav-links a { color: var(--muted); }
[data-theme="light"] .nav-links a:hover,
[data-theme="light"] .nav-links a.active { color: var(--pink); }
[data-theme="light"] .pub-mob-nav a { color: var(--text); }
[data-theme="light"] .pub-mob-nav a:hover { color: var(--pink); }
[data-theme="light"] .nav-mobile-menu a { color: var(--text); }
[data-theme="light"] .nav-mobile-menu a:hover,
[data-theme="light"] .nav-mobile-menu a.active { color: var(--pink); }

/* Misc utility */
[data-theme="light"] .muted { color: var(--muted); }
[data-theme="light"] .text-pink { color: var(--pink); }
[data-theme="light"] .text-gold { color: var(--gold); }
[data-theme="light"] .text-green { color: var(--green); }
[data-theme="light"] code { color: var(--text); background: rgba(0,0,0,.06); }
[data-theme="light"] .check-name,
[data-theme="light"] .rule-name { color: var(--text); }
[data-theme="light"] .neu-btn { color: var(--text); }
[data-theme="light"] .neu-btn:hover { color: var(--pink); }
[data-theme="light"] .toast { color: var(--text); }

/* Quick action buttons */
[data-theme="light"] .qa-btn { color: var(--text); }
[data-theme="light"] .qa-btn:hover { background: rgba(232,24,109,.04); }

/* Intro/description text */
[data-theme="light"] .intro-sub { color: var(--muted); }
[data-theme="light"] .balance-l { color: rgba(14,16,24,.5); }
