/* ========== RESET & BASE ========== */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:'Inter',sans-serif;background:var(--bg);color:var(--text);min-height:100vh;overflow-x:hidden}
a{text-decoration:none;color:inherit}
button{font-family:inherit;cursor:pointer;border:none;outline:none}

/* ========== CSS VARIABLES ========== */
:root{
  --bg:#f8fafc;--bg2:#ffffff;--bg3:#f1f5f9;
  --surface:#ffffff;--surface2:#f1f5f9;--surface3:#e2e8f0;
  --border:#e2e8f0;--border2:#cbd5e1;
  --accent:#4f46e5;--accent2:#4338ca;--accent-glow:rgba(79,70,229,.35);
  --teal:#0d9488;--teal-glow:rgba(13,148,136,.3);
  --amber:#d97706;--rose:#e11d48;--green:#16a34a;
  --text:#0f172a;--text2:#475569;--text3:#64748b;
  --radius:12px;--radius-lg:18px;--radius-xl:24px;
  --shadow:0 4px 24px rgba(0,0,0,.06);--shadow-lg:0 8px 48px rgba(0,0,0,.1);
  --transition:.2s ease;
  
  /* Grade Colors - Light */
  --g-Ap:#8b5cf6; --g-A:#4f46e5; --g-Bp:#0d9488; --g-B:#2563eb;
  --g-Cp:#16a34a; --g-C:#65a30d; --g-Dp:#d97706; --g-D:#ea580c; --g-E:#e11d48;
}

[data-theme="dark"] {
  --bg:#080c14;--bg2:#0d1220;--bg3:#111827;
  --surface:#141c2e;--surface2:#1a2540;--surface3:#1e2d4a;
  --border:#1e2d4a;--border2:#243356;
  --accent:#6366f1;--accent2:#818cf8;--accent-glow:rgba(99,102,241,.35);
  --teal:#14b8a6;--teal-glow:rgba(20,184,166,.3);
  --amber:#f59e0b;--rose:#f43f5e;--green:#22c55e;
  --text:#e2e8f0;--text2:#94a3b8;--text3:#64748b;
  --shadow:0 4px 24px rgba(0,0,0,.4);--shadow-lg:0 8px 48px rgba(0,0,0,.6);

  /* Grade Colors - Dark */
  --g-Ap:#a78bfa; --g-A:#818cf8; --g-Bp:#2dd4bf; --g-B:#60a5fa;
  --g-Cp:#4ade80; --g-C:#a3e635; --g-Dp:#fbbf24; --g-D:#fb923c; --g-E:#fb7185;
}

/* ========== NAVBAR ========== */
.navbar{position:sticky;top:0;z-index:100;background:var(--bg2);opacity:0.95;backdrop-filter:blur(16px);border-bottom:1px solid var(--border);padding:0 1.5rem}
.nav-container{max-width:1400px;margin:0 auto;display:flex;align-items:center;justify-content:space-between;height:40px}
.nav-brand{display:flex;align-items:center;gap:.6rem}
.brand-icon{display:flex;align-items:center;justify-content:center;width:1.25rem;height:1.25rem}
.brand-icon svg{width:100%;height:100%;display:block}
.brand-text{display:flex;flex-direction:column}
.brand-name{font-size:1.05rem;font-weight:800;background:linear-gradient(135deg,#818cf8,#14b8a6);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;line-height:1.1}
.brand-tagline{font-size:.6rem;color:var(--text3);text-transform:uppercase;letter-spacing:.08em}
.nav-links{display:flex;align-items:center;gap:.25rem}
.nav-link{padding:.24rem .75rem;border-radius:6px;font-size:.85rem;font-weight:500;color:var(--text2);transition:var(--transition);display:inline-flex;align-items:center;gap:.4rem}
.nav-link:hover,.nav-link.active{color:var(--text);background:var(--surface2)}
.nav-contact-avatar{width:26px;height:26px;border-radius:50%;object-fit:cover;object-position:center;border:1.5px solid var(--surface);box-shadow:0 0 0 1px var(--border2)}

/* ========== HERO ========== */
.hero{position:relative;min-height:100vh;display:flex;align-items:center;padding:5rem 1.5rem 4rem;gap:4rem;max-width:1400px;margin:0 auto}
.hero-bg{position:fixed;inset:0;z-index:-1;overflow:hidden;pointer-events:none}
.hero-orb{position:absolute;border-radius:50%;filter:blur(80px);animation:float 8s ease-in-out infinite}
.orb-1{width:600px;height:600px;background:radial-gradient(circle,rgba(99,102,241,.18),transparent 70%);top:-150px;left:-100px;animation-delay:0s}
.orb-2{width:500px;height:500px;background:radial-gradient(circle,rgba(20,184,166,.14),transparent 70%);bottom:-100px;right:-100px;animation-delay:-3s}
.orb-3{width:400px;height:400px;background:radial-gradient(circle,rgba(139,92,246,.1),transparent 70%);top:40%;left:50%;animation-delay:-6s}
@keyframes float{0%,100%{transform:translateY(0) scale(1)}50%{transform:translateY(-30px) scale(1.05)}}
.grid-overlay{position:absolute;inset:0;background-image:linear-gradient(rgba(99,102,241,.04) 1px,transparent 1px),linear-gradient(90deg,rgba(99,102,241,.04) 1px,transparent 1px);background-size:48px 48px}
.hero-content{flex:1;max-width:640px}
.hero-badge{display:inline-flex;align-items:center;gap:.5rem;padding:.35rem 1rem;border-radius:999px;border:1px solid rgba(99,102,241,.4);background:rgba(99,102,241,.1);font-size:.8rem;font-weight:500;color:var(--accent2);margin-bottom:1.5rem}
.badge-dot{width:8px;height:8px;border-radius:50%;background:var(--accent2);animation:pulse 2s infinite}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.4}}
.hero-title{font-size:clamp(2.5rem,5vw,4rem);font-weight:900;line-height:1.1;letter-spacing:-.02em;margin-bottom:1.25rem}
.gradient-text{background:linear-gradient(135deg,#818cf8 0%,#14b8a6 60%,#6ee7b7 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.hero-subtitle{font-size:1.1rem;color:var(--text2);line-height:1.7;margin-bottom:2rem}
.hero-cta{display:flex;gap:1rem;flex-wrap:wrap;margin-bottom:2.5rem}
.btn{display:inline-flex;align-items:center;gap:.5rem;padding:.75rem 1.5rem;border-radius:10px;font-size:.95rem;font-weight:600;transition:all .25s ease;cursor:pointer}
.btn-primary{background:linear-gradient(135deg,var(--accent),#8b5cf6);color:#fff;box-shadow:0 0 24px var(--accent-glow)}
.btn-primary:hover{transform:translateY(-2px);box-shadow:0 4px 32px var(--accent-glow)}
.btn-ghost{background:var(--surface);color:var(--text2);border:1px solid var(--border2)}
.btn-ghost:hover{color:var(--accent);border-color:var(--accent);background:rgba(79,70,229,.1)}
.hero-stats{display:flex;align-items:center;gap:1.5rem}
.stat-item{text-align:center}
.stat-number{display:block;font-size:1.75rem;font-weight:800;background:linear-gradient(135deg,#818cf8,#14b8a6);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.stat-label{font-size:.75rem;color:var(--text3);text-transform:uppercase;letter-spacing:.06em}
.stat-divider{width:1px;height:40px;background:var(--border2)}
.hero-visual{flex:1;display:flex;justify-content:center;align-items:center}
.dashboard-mockup{background:var(--surface);border:1px solid var(--border2);border-radius:var(--radius-xl);padding:0;overflow:hidden;width:100%;max-width:420px;box-shadow:var(--shadow-lg),0 0 60px var(--accent-glow)}
.mockup-header{display:flex;align-items:center;gap:.75rem;padding:.85rem 1.25rem;background:var(--surface2);border-bottom:1px solid var(--border)}
.mockup-dots{display:flex;gap:.4rem}
.mockup-dots span{width:10px;height:10px;border-radius:50%;background:var(--border2)}
.mockup-dots span:nth-child(1){background:#f43f5e}
.mockup-dots span:nth-child(2){background:#f59e0b}
.mockup-dots span:nth-child(3){background:#22c55e}
.mockup-title{font-size:.85rem;font-weight:600;color:var(--text2)}
.mockup-body{padding:1.25rem}
.mockup-bar-group{margin-bottom:1rem}
.mockup-label{font-size:.7rem;font-weight:600;color:var(--text3);text-transform:uppercase;letter-spacing:.06em;margin-bottom:.35rem}
.mockup-bar{height:26px;border-radius:6px;background:linear-gradient(90deg,var(--accent),var(--teal));width:var(--w);display:flex;align-items:center;padding:0 .5rem;animation:barIn 1s ease forwards}
@keyframes barIn{from{width:0}to{width:var(--w)}}
.mockup-bar span{font-size:.72rem;font-weight:700;color:#fff}
.mockup-stats-row{display:flex;gap:.75rem;margin-top:1.25rem}
.mockup-stat{flex:1;background:var(--surface2);border-radius:8px;padding:.6rem;text-align:center}
.ms-val{display:block;font-size:1.1rem;font-weight:800;color:#818cf8}
.ms-key{font-size:.65rem;color:var(--text3);text-transform:uppercase;letter-spacing:.04em}

/* ========== COMPACT HERO & REFINEMENTS ========== */
.compact-hero {
  position: relative;
  overflow: hidden;
  background: linear-gradient(135deg, var(--bg2) 0%, var(--bg3) 100%);
  border-bottom: 1px solid var(--border2);
}
.compact-hero-inner {
  max-width: 1400px;
  margin: 0 auto;
  padding: 2rem 1.5rem 1.75rem;
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 2rem;
  align-items: center;
  position: relative;
  z-index: 1;
}
/* Background orbs inside hero */
.compact-hero .hero-bg {
  position: absolute;
  inset: 0;
  pointer-events: none;
  overflow: hidden;
  z-index: 0;
}
.compact-hero .hero-orb {
  filter: blur(60px);
}
.compact-hero .orb-1 {
  width: 420px; height: 260px;
  top: -120px; left: -80px;
}
.compact-hero .orb-2 {
  width: 320px; height: 220px;
  top: -60px; right: -40px;
  animation-delay: -3s;
}
.compact-hero .orb-3 { display: none; }
.compact-hero .grid-overlay {
  opacity: 0.5;
}
/* Left: branding column */
.compact-hero-left {
  display: flex;
  flex-direction: column;
  gap: 0.6rem;
  min-width: 0;
}
.compact-hero-badge {
  display: inline-flex;
  align-items: center;
  gap: 0.45rem;
  padding: 0.28rem 0.85rem;
  border-radius: 999px;
  border: 1px solid rgba(99, 102, 241, 0.35);
  background: rgba(99, 102, 241, 0.09);
  font-size: 0.73rem;
  font-weight: 700;
  color: var(--accent2);
  text-transform: uppercase;
  letter-spacing: 0.07em;
  width: fit-content;
}
.compact-hero-badge-dot {
  width: 7px; height: 7px;
  border-radius: 50%;
  background: var(--accent2);
  animation: pulse 2s infinite;
}
.compact-hero-title {
  font-size: clamp(1.55rem, 3vw, 2.15rem);
  font-weight: 900;
  line-height: 1.15;
  letter-spacing: -0.025em;
  margin: 0;
}
.compact-hero-subtitle {
  font-size: 0.88rem;
  color: var(--text2);
  line-height: 1.6;
  max-width: 560px;
  margin: 0;
}
/* Quick-access chips row */
.compact-hero-chips {
  display: flex;
  flex-wrap: wrap;
  gap: 0.45rem;
  margin-top: 0.35rem;
}
.hero-chip {
  display: inline-flex;
  align-items: center;
  gap: 0.3rem;
  padding: 0.28rem 0.7rem;
  border-radius: 8px;
  font-size: 0.75rem;
  font-weight: 600;
  border: 1px solid var(--border2);
  background: var(--surface);
  color: var(--text2);
  text-decoration: none;
  transition: all 0.2s ease;
  white-space: nowrap;
}
.hero-chip:hover {
  border-color: var(--accent);
  color: var(--accent2);
  background: rgba(99, 102, 241, 0.07);
  transform: translateY(-1px);
}
.hero-chip-icon { font-size: 0.9rem; }
/* Right: stat card panel */
.compact-hero-stats {
  display: flex;
  flex-direction: column;
  gap: 0.55rem;
  min-width: 210px;
  background: var(--surface);
  border: 1px solid var(--border2);
  border-radius: var(--radius-lg);
  padding: 1.1rem 1.25rem;
  box-shadow: var(--shadow);
  flex-shrink: 0;
}
.compact-hero-stats-title {
  font-size: 0.68rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--text3);
  margin-bottom: 0.2rem;
}
.hero-stat-row {
  display: flex;
  align-items: center;
  gap: 0.65rem;
  padding: 0.5rem 0.6rem;
  border-radius: 8px;
  background: var(--surface2);
  text-decoration: none;
  color: var(--text);
  transition: all 0.2s ease;
}
.hero-stat-row:hover {
  background: rgba(99, 102, 241, 0.08);
  color: var(--accent2);
  transform: translateX(2px);
}
.hero-stat-icon {
  font-size: 1.1rem;
  flex-shrink: 0;
  width: 28px;
  text-align: center;
}
.hero-stat-info { flex: 1; min-width: 0; }
.hero-stat-name {
  display: block;
  font-size: 0.76rem;
  font-weight: 700;
  line-height: 1.2;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.hero-stat-tag {
  display: inline-block;
  font-size: 0.62rem;
  font-weight: 600;
  color: var(--text3);
  margin-top: 0.1rem;
}
.hero-stat-arrow {
  width: 12px;
  height: 12px;
  color: var(--text3);
  flex-shrink: 0;
  transition: transform 0.2s ease;
}
.hero-stat-row:hover .hero-stat-arrow { transform: translateX(2px); color: var(--accent2); }
/* Responsive */
@media (max-width: 680px) {
  .compact-hero-inner { grid-template-columns: 1fr; gap: 1.25rem; }
  .compact-hero-stats { flex-direction: row; flex-wrap: wrap; min-width: 0; }
  .hero-stat-row { flex: 1 1 140px; }
}
.tools-section.compact-page-tools {
  padding-top: 0;
  padding-bottom: 0;
}

/* ========== TOOLS SECTION ========== */
.tools-section{padding:5rem 1.5rem;max-width:1400px;margin:0 auto}
.tool-title-link {
  color: var(--text);
  text-decoration: none;
  transition: color var(--transition);
  display: inline-flex;
  align-items: center;
}
.tool-title-link:hover {
  color: var(--accent);
}
.section-container{}
.section-header{text-align:center;margin-bottom:3rem}
.section-badge{display:inline-block;padding:.3rem .9rem;background:rgba(99,102,241,.12);border:1px solid rgba(99,102,241,.3);border-radius:999px;font-size:.78rem;font-weight:600;color:var(--accent2);text-transform:uppercase;letter-spacing:.08em;margin-bottom:.75rem}
.section-title{font-size:clamp(1.8rem,3vw,2.5rem);font-weight:800;margin-bottom:.75rem}
.section-desc{color:var(--text2);font-size:1rem}
.tools-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:1.5rem}
.tool-card{position:relative;background:var(--surface);border:1px solid var(--border2);border-radius:var(--radius-xl);padding:2rem;overflow:hidden;transition:all .3s ease;display:flex;flex-direction:column;gap:.75rem}
.tool-card.featured{border-color:rgba(99,102,241,.5);background:linear-gradient(135deg,rgba(99,102,241,.08),rgba(20,184,166,.05))}
.tool-card.featured:hover{transform:translateY(-4px);box-shadow:0 12px 48px var(--accent-glow),var(--shadow-lg);border-color:rgba(99,102,241,.8)}
.tool-card.coming-soon{opacity:.65;pointer-events:none}
.tool-glow{position:absolute;top:-40px;right:-40px;width:200px;height:200px;background:radial-gradient(circle,rgba(99,102,241,.25),transparent 70%);pointer-events:none}
.tool-icon-wrap{}
.tool-icon{font-size:2.25rem}
.tool-badge-tag{display:inline-block;padding:.2rem .65rem;border-radius:999px;font-size:.72rem;font-weight:700;background:rgba(34,197,94,.15);color:#22c55e;border:1px solid rgba(34,197,94,.3);width:fit-content}
.tool-badge-tag.coming{background:rgba(245,158,11,.1);color:var(--amber);border-color:rgba(245,158,11,.3)}
.tool-name{font-size:1.25rem;font-weight:800}
.tool-desc{font-size:.875rem;color:var(--text2);line-height:1.6}
.tool-features{list-style:none;display:flex;flex-direction:column;gap:.4rem;margin-top:.25rem}
.tool-features li{font-size:.82rem;color:var(--text2);display:flex;align-items:center;gap:.5rem}
.feature-check{color:var(--teal);font-weight:700;font-size:.85rem}
.tool-action{display:flex;align-items:center;gap:.5rem;margin-top:auto;color:var(--accent2);font-size:.875rem;font-weight:600;padding-top:.75rem;border-top:1px solid var(--border)}
.tool-action.disabled{color:var(--text3)}
.tool-card.featured .tool-action svg{transition:transform .2s}
.tool-card.featured:hover .tool-action svg{transform:translateX(4px)}

/* ========== FOOTER ========== */
.footer{border-top:1px solid var(--border);padding:2rem 1.5rem;margin-top:4rem}
.home-page .footer{margin-top:1.5rem}
.footer-container{max-width:1400px;margin:0 auto;display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:1rem}
.footer-brand{display:flex;align-items:center;gap:.5rem;font-size:1rem;font-weight:700}
.footer-icon{display:inline-flex;align-items:center;justify-content:center;width:1.1rem;height:1.1rem;vertical-align:middle;margin-right:0.15rem}
.footer-icon svg{width:100%;height:100%;display:block}
.footer-name{background:linear-gradient(135deg,#818cf8,#14b8a6);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.footer-copy{font-size:.8rem;color:var(--text3)}

/* ========== TOOL PAGE ========== */
.tool-header{position:relative;overflow:hidden;padding:1.5rem 1.5rem 1rem;border-bottom:1px solid var(--border);background:linear-gradient(180deg, var(--bg2) 0%, var(--bg) 100%)}
.tool-header-bg{position:absolute;inset:0;z-index:0;pointer-events:none}
.tool-header-content{position:relative;z-index:1;max-width:1400px;margin:0 auto}
.tool-breadcrumb{display:flex;align-items:center;gap:.5rem;font-size:.8rem;color:var(--text3);margin-bottom:.5rem}
.tool-breadcrumb a{color:var(--accent2)}
.tool-title{font-size:clamp(1.5rem,2.8vw,2.15rem);font-weight:850;color:var(--text);margin-bottom:.25rem;display:flex;align-items:center;gap:.6rem;line-height:1.2;letter-spacing:-.02em}
.tool-title-text{background:linear-gradient(135deg,var(--accent) 0%,var(--teal) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.tool-emoji{display:inline-flex;align-items:center;justify-content:center;font-size:1.1em;vertical-align:middle;filter:drop-shadow(0 2px 8px rgba(0,0,0,.08));-webkit-text-fill-color:initial;background-clip:border-box;animation:emoji-pulse 4s ease-in-out infinite}
@keyframes emoji-pulse{0%,100%{transform:scale(1)}50%{transform:scale(1.05)}}
.tool-subtitle{color:var(--text2);font-size:.88rem;max-width:800px;line-height:1.45}
.tool-main{padding:1.5rem 1.5rem 3rem}
.tool-container{max-width:1400px;margin:0 auto;display:flex;flex-direction:column;gap:2rem}
body.data-focus .tool-header{display:none}
body.data-focus .tool-main{padding-top:1rem}
body.data-focus .tool-container{gap:1rem}

/* ========== PANEL ========== */
.panel{background:var(--surface);border:1px solid var(--border2);border-radius:var(--radius-xl);padding:2rem}
.panel-header{margin-bottom:1.5rem}
.panel-title{font-size:1.1rem;font-weight:700;display:flex;align-items:center;gap:.6rem;margin-bottom:.4rem}
.panel-icon{font-size:1.2rem}
.panel-desc{font-size:.85rem;color:var(--text2)}
.import-panel .panel-header{display:flex;align-items:flex-start;justify-content:space-between;gap:1rem}
.import-toggle{display:inline-flex;align-items:center;justify-content:center;min-height:36px;padding:.45rem .9rem;border:1px solid var(--border2);border-radius:8px;background:var(--surface2);color:var(--text2);font-size:.82rem;font-weight:700;white-space:nowrap}
.import-toggle[hidden]{display:none}
.import-toggle:hover{border-color:var(--accent);color:var(--accent2);background:rgba(99,102,241,.08)}
.import-panel.is-collapsed{padding:1rem 1.25rem}
.import-panel.is-collapsed .panel-header{margin-bottom:0;align-items:center}
.import-panel.is-collapsed .panel-desc,.import-panel.is-collapsed .upload-grid{display:none!important}
.import-panel.is-collapsed .panel-title{margin-bottom:0;font-size:1rem}
body.data-focus .import-panel.is-collapsed{display:none}
#school-name-bar{flex-wrap:wrap}
#school-name-input{min-width:220px}
.btn-source-files{padding:.38rem .75rem;border:1px solid var(--border2);border-radius:8px;background:var(--surface);color:var(--text2);font-size:.78rem;font-weight:700;white-space:nowrap}
.btn-source-files:hover{border-color:var(--accent);color:var(--accent2);background:rgba(99,102,241,.08)}
.settings-menu{position:relative;display:inline-flex}
.settings-menu-toggle{padding-right:1.7rem;position:relative}
.settings-menu-toggle::after{content:'▾';position:absolute;right:.7rem;top:50%;transform:translateY(-50%);font-size:.72rem;color:var(--text3)}
.settings-menu-toggle.active,.settings-menu-toggle[aria-expanded="true"]{border-color:var(--accent);color:var(--accent2);background:rgba(99,102,241,.08)}
.settings-menu-panel{position:absolute;right:0;top:calc(100% + .45rem);z-index:20;min-width:190px;padding:.35rem;background:var(--surface);border:1px solid var(--border2);border-radius:8px;box-shadow:var(--shadow-lg)}
.settings-menu-panel[hidden]{display:none}
.settings-menu-item{display:flex;width:100%;align-items:center;justify-content:flex-start;padding:.55rem .7rem;border-radius:6px;background:transparent;color:var(--text2);font-size:.82rem;font-weight:650;text-align:left;white-space:nowrap}
.settings-menu-item:hover,.settings-menu-item.active{color:var(--accent2);background:rgba(99,102,241,.08)}

/* ========== UPLOAD ========== */
.upload-area{position:relative;border:2px dashed var(--border2);border-radius:var(--radius-lg);padding:3rem 2rem;text-align:center;transition:all .25s;cursor:pointer}
.upload-area:hover,.upload-area.drag-over{border-color:var(--accent);background:rgba(99,102,241,.06)}
.upload-area input[type="file"]{position:absolute;inset:0;opacity:0;cursor:pointer;width:100%;height:100%}
.sslc-import-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1.5rem}
.sslc-import-grid--or{grid-template-columns:1fr auto 1fr;gap:0 1.25rem;align-items:start}
.sslc-or-divider{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.6rem;padding:1rem 0;margin-top:1.85rem}
.sslc-or-line{display:block;width:2px;flex:1;min-height:40px;background:var(--border2);border-radius:2px}
.sslc-or-label{display:inline-flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:50%;border:2px solid var(--border2);background:var(--surface2);color:var(--text3);font-size:.78rem;font-weight:800;letter-spacing:.04em;flex-shrink:0;user-select:none}
@media(max-width:720px){
  .sslc-import-grid--or{grid-template-columns:1fr;gap:0}
  .sslc-or-divider{flex-direction:row;margin-top:0;padding:.75rem 0}
  .sslc-or-line{width:100%;height:2px;min-height:0;flex:1}
}
.sslc-import-heading{font-size:.9rem;margin-bottom:.5rem;color:var(--text2)}
.sslc-paste-panel{border:1px solid var(--border2);border-radius:var(--radius-lg);padding:1rem;background:var(--surface)}
.sslc-paste-help{margin:.75rem 0 0;color:var(--text2);font-size:.84rem;line-height:1.45}
.sslc-paste-help a{color:var(--accent2);font-weight:700;text-decoration:none}
.sslc-paste-help a:hover{text-decoration:underline}
.sslc-paste-box{width:100%;min-height:158px;margin-top:1rem;padding:.85rem;border-radius:8px;border:1px solid var(--border2);background:var(--surface2);color:var(--text);font-family:inherit;font-size:.85rem;line-height:1.5;resize:vertical;outline:none}
.sslc-paste-box:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-glow)}
.upload-visual{pointer-events:none}
.upload-icon{font-size:3rem;margin-bottom:.75rem;display:block}
.upload-primary{font-size:1rem;font-weight:600;margin-bottom:.25rem}
.upload-secondary{font-size:.875rem;color:var(--text2);margin-bottom:.75rem}
.upload-hint{display:inline-block;padding:.25rem .75rem;background:rgba(99,102,241,.1);border-radius:999px;font-size:.75rem;color:var(--accent2)}
.upload-status{display:flex;align-items:center;gap:1rem;padding:1rem 1.25rem;background:rgba(34,197,94,.08);border:1px solid rgba(34,197,94,.3);border-radius:var(--radius);margin-top:1rem}
.status-icon{width:36px;height:36px;border-radius:50%;background:rgba(34,197,94,.2);display:flex;align-items:center;justify-content:center;font-size:1rem;color:#22c55e;flex-shrink:0}
.status-info{flex:1}
.status-filename{display:block;font-weight:600;font-size:.9rem}
.status-rows{font-size:.8rem;color:var(--text2)}
.btn-clear{background:none;color:var(--text3);font-size:1.1rem;padding:.25rem .5rem;border-radius:6px;transition:var(--transition)}
.btn-clear:hover{color:var(--rose);background:rgba(244,63,94,.1)}

/* ========== LOADING ========== */
.loading-overlay{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1rem;padding:3rem;color:var(--text2)}
.spinner{width:44px;height:44px;border:3px solid var(--border2);border-top-color:var(--accent);border-radius:50%;animation:spin .8s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}

/* ========== SUMMARY CARDS ========== */
.summary-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:1rem}
.summary-card{background:var(--surface);border:1px solid var(--border2);border-radius:var(--radius-lg);padding:1.25rem 1.5rem;position:relative;overflow:hidden;text-align:center}
.summary-card::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:var(--card-color,var(--accent))}
.sslc-card-link{display:block;width:100%;color:inherit;font:inherit;transition:var(--transition)}
.sslc-card-link:hover{transform:translateY(-2px);border-color:var(--card-color,var(--accent));box-shadow:0 8px 24px rgba(15,23,42,.08)}
.sc-value > span[onclick]{display:inline-flex;align-items:center;justify-content:center;margin-left:.45rem;padding:.2rem .45rem;border-radius:999px;border:1px solid rgba(16,185,129,.28);background:rgba(16,185,129,.1);font-size:.72rem;font-weight:750;line-height:1.1;vertical-align:middle}
.sc-label{font-size:.72rem;font-weight:600;text-transform:uppercase;letter-spacing:.07em;color:var(--text3);margin-bottom:.35rem}
.sc-value{font-size:2rem;font-weight:800;color:var(--card-color,var(--text));line-height:1}
.sc-sub{font-size:.75rem;color:var(--text3);margin-top:.2rem}

/* ========== TABS ========== */
.tabs-bar{display:flex;gap:.5rem;flex-wrap:wrap;border-bottom:1px solid var(--border);padding-bottom:.5rem}
.tab-btn{padding:.6rem 1.25rem;border-radius:8px 8px 0 0;font-size:.875rem;font-weight:600;color:var(--text2);background:none;transition:var(--transition);border-bottom:2px solid transparent;margin-bottom:-1px}
.tab-btn:hover{color:var(--text);background:var(--surface2)}
.tab-btn.active{color:var(--accent2);border-bottom-color:var(--accent);background:rgba(99,102,241,.08)}

/* ========== TABLE PANEL ========== */
.table-panel {
  background: var(--surface);
  border: 1px solid var(--border2);
  border-radius: var(--radius-xl);
  overflow: hidden;
}
.table-panel-header{display:flex;align-items:center;justify-content:space-between;padding:1.25rem 1.5rem;border-bottom:1px solid var(--border);flex-wrap:wrap;gap:.75rem}
.table-panel-header h3{font-size:1rem;font-weight:700}
.btn-export {
  display: inline-flex;
  align-items: center;
  gap: 0.35rem;
  padding: 0.45rem 1.1rem;
  border-radius: 8px;
  font-size: 0.8rem;
  font-weight: 700;
  background: rgba(99, 102, 241, 0.1);
  color: var(--accent2);
  border: 1px solid rgba(99, 102, 241, 0.25);
  transition: all 0.25s cubic-bezier(0.4, 0, 0.2, 1);
}
.btn-export:hover {
  background: var(--accent);
  color: #fff;
  border-color: var(--accent);
  transform: translateY(-1px);
  box-shadow: 0 4px 12px rgba(99, 102, 241, 0.25);
}
.btn-export .btn-chevron {
  transition: transform 0.25s cubic-bezier(0.4, 0, 0.2, 1);
  width: 14px;
  height: 14px;
  stroke-width: 2.5;
}
.btn-export:hover .btn-chevron {
  transform: translateX(3px);
}
.table-scroll{overflow-x:auto}
.result-table{width:100%;border-collapse:collapse;font-size:.85rem}
.result-table th{padding:.75rem 1rem;text-align:left;font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--text3);background:var(--surface2);white-space:nowrap;border-bottom:1px solid var(--border)}
.result-table td{padding:.7rem 1rem;border-bottom:1px solid var(--border);color:var(--text);white-space:nowrap}
.result-table tbody tr:last-child td{border-bottom:none}
.result-table tbody tr:hover td{background:rgba(99,102,241,.05)}
.result-table tfoot td{font-weight:700;background:var(--surface2);border-top:2px solid var(--border2)}
td.num{text-align:right;font-variant-numeric:tabular-nums}
#grade-table th:not(:first-child),#grade-table td:not(:first-child),
#class-grade-table th:not(:nth-child(2)),#class-grade-table td:not(:nth-child(2)){text-align:center}
#grade-table th:first-child,#grade-table td:first-child,
#class-grade-table th:nth-child(2),#class-grade-table td:nth-child(2){text-align:left}
td.pass-pct{font-weight:700;color:var(--green)}
td.full-a{color:#818cf8;font-weight:700}
td.five-a{color:var(--teal);font-weight:700}
.summary-count-link{display:inline-flex;align-items:center;justify-content:flex-end;min-width:1.6em;padding:.08rem .25rem;border:0;border-radius:5px;background:transparent;color:inherit;font:inherit;font-weight:inherit;text-align:right;cursor:pointer;transition:var(--transition)}
.summary-count-link:hover{background:rgba(99,102,241,.12);color:var(--accent2)}
.summary-improved-count .summary-count-link{min-width:auto;margin-left:4px;color:var(--green);font-size:.75rem;font-weight:800}
.summary-improved-count .summary-count-link:hover{background:rgba(16,185,129,.12);color:var(--green)}
.summary-negative-change{color:var(--rose)}
.summary-fivea-change .summary-count-link{gap:.25rem}
.badge-pass{display:inline-flex;align-items:center;justify-content:center;padding:.2rem .65rem;border-radius:999px;font-size:.73rem;font-weight:800;letter-spacing:.03em;min-width:42px}
.badge-pass.pass{background:rgba(34,197,94,.15);color:#22c55e}
.badge-pass.fail{background:rgba(244,63,94,.12);color:var(--rose)}
.badge-pass.ehs{background:rgba(245,158,11,.12);color:var(--amber)}
.badge-pass.nhs{background:rgba(100,116,139,.12);color:var(--text3)}

/* ========== GRADE BADGE ========== */
.grade-badge{display:inline-block;padding:.15rem .5rem;border-radius:5px;font-size:.8rem;font-weight:800;min-width:32px;text-align:center}
.grade-Ap{background:rgba(139,92,246,.2);color:var(--g-Ap)}
.grade-A{background:rgba(99,102,241,.2);color:var(--g-A)}
.grade-Bp{background:rgba(20,184,166,.2);color:var(--g-Bp)}
.grade-B{background:rgba(59,130,246,.2);color:var(--g-B)}
.grade-Cp{background:rgba(34,197,94,.2);color:var(--g-Cp)}
.grade-C{background:rgba(132,204,22,.2);color:var(--g-C)}
.grade-Dp{background:rgba(245,158,11,.2);color:var(--g-Dp)}
.grade-D{background:rgba(249,115,22,.2);color:var(--g-D)}
.grade-E{background:rgba(244,63,94,.2);color:var(--g-E)}
.grade-Ab{background:rgba(100,116,139,.15);color:var(--text3)}

/* ========== STUDENT TABLE CONTROLS ========== */
.table-controls{display:flex;gap:.5rem;flex-wrap:wrap}
.search-input,.filter-select{padding:.45rem .85rem;border-radius:8px;background:var(--surface2);border:1px solid var(--border2);color:var(--text);font-size:.82rem;font-family:inherit;outline:none;transition:var(--transition)}
.search-input{width:220px}
.search-input:focus,.filter-select:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-glow)}
.filter-select option{background:var(--surface2)}

/* Student list table */
.student-list-header{align-items:flex-start;gap:1rem}
.table-title-block{display:flex;flex-direction:column;gap:.25rem;min-width:180px}
.table-meta{font-size:.78rem;color:var(--text3);font-weight:500}
.student-table-controls{justify-content:flex-end;align-items:center;width:100%}
.btn-clear-filters{background:var(--surface2);color:var(--text2);border-color:var(--border2)}
.btn-clear-filters:hover{color:var(--rose);border-color:rgba(225,29,72,.35);background:rgba(225,29,72,.08)}
.student-table-scroll{max-height:68vh;position:relative}
.student-table{width:100%;min-width:0;border-collapse:separate;border-spacing:0;table-layout:auto}
.student-table th{position:sticky;top:0;z-index:3;text-align:center;background:linear-gradient(rgba(99,102,241,.13),rgba(99,102,241,.13)),var(--surface)!important;color:var(--accent2)!important}
[data-theme="dark"] .student-table th{background:linear-gradient(rgba(99,102,241,.22),rgba(99,102,241,.22)),var(--surface)!important}
.student-table thead tr:nth-child(2) th{top:37px}
.student-table td{vertical-align:middle}
.student-table th,.student-table td{padding:.5rem .45rem;border-right:1px solid var(--border2)}
.student-table th:first-child,.student-table td:first-child{border-left:1px solid var(--border2)}
.student-table thead th{border-bottom:1px solid var(--border2)}
.student-selected-class{display:inline-flex;align-items:center;margin:.2rem 0 .65rem;padding:.34rem .65rem;border:1px solid rgba(15,23,42,.18);border-radius:6px;background:var(--surface2);color:var(--text);font-size:.82rem;font-weight:800}
.student-table th.col-rank{width:42px;min-width:42px;text-align:center;color:var(--text3)}
.student-table td.col-rank{width:42px;min-width:42px;text-align:center;color:var(--text3)}
.student-table .col-reg{width:104px;min-width:104px;font-variant-numeric:tabular-nums}
.student-table .col-student{min-width:170px;white-space:normal}
.student-table .col-class{width:64px;min-width:64px}
.student-table .col-total{width:68px;min-width:68px}
.student-table .col-pct{width:58px;min-width:58px}
.student-table .col-status{width:78px;min-width:78px}
.sslc-student-table{min-width:940px}
.sslc-student-table th.col-rank,.sslc-student-table td.col-rank{width:38px;min-width:38px;left:0}
.sslc-student-table th.col-reg,.sslc-student-table td.col-reg{width:92px;min-width:92px;left:38px}
.sslc-student-table th.col-student,.sslc-student-table td.col-student{min-width:132px;left:130px}
.sslc-student-table th.col-status,.sslc-student-table td.col-status{width:58px;min-width:58px}
.sslc-student-table th.col-total,.sslc-student-table td.col-total{width:44px;min-width:44px}
.sslc-student-table th:not(.col-rank):not(.col-reg):not(.col-student):not(.col-status):not(.col-total),
.sslc-student-table td:not(.col-rank):not(.col-reg):not(.col-student):not(.col-status):not(.col-total){text-align:center;min-width:50px;max-width:58px;white-space:normal}
.sslc-student-table .sslc-subject-head{white-space:normal;line-height:1.15;padding:.45rem .28rem;font-size:.66rem;letter-spacing:0}
.student-table td.col-rank,.student-table td.col-reg,.student-table td.col-student{position:sticky;background:var(--surface)!important;z-index:2}
.student-table th.col-rank,.student-table th.col-reg,.student-table th.col-student{position:sticky;z-index:4}
.student-table th.col-rank,.student-table td.col-rank{left:0}
.student-table th.col-reg,.student-table td.col-reg{left:42px}
.student-table th.col-student,.student-table td.col-student{left:146px;box-shadow:4px 0 10px rgba(15,23,42,.12)}
.student-table th.col-reg,.student-table td.col-reg,
.student-table th.col-class,.student-table td.col-class,
.student-table th.col-total,.student-table td.col-total{text-align:center}
.student-name-cell{white-space:normal;line-height:1.35}
.student-name-cell strong{display:block;color:var(--text);font-weight:750}
.student-name-cell span{display:block;color:var(--text3);font-size:.72rem;margin-top:.15rem}
.student-improved-row td{background:rgba(34,197,94,.045)}
.student-failed-row .student-name-cell strong{color:var(--rose)}
.student-table tbody tr:hover td{background:rgba(99,102,241,.07)}
.sub-cell{white-space:nowrap;font-size:0.75rem;padding:0.38rem 0.42rem;vertical-align:middle;text-align:center;min-width:72px}
.sub-mark-cell{min-width:38px;width:38px;padding:.4rem .28rem;font-variant-numeric:tabular-nums}
.sub-grade-cell{min-width:44px;width:44px;padding:.4rem .24rem}
.sub-group-head{border-left:3px solid var(--accent)!important;background:rgba(99,102,241,.12)!important;color:var(--accent2)!important;font-weight:800}
[data-theme="dark"] .sub-group-head{background:rgba(99,102,241,.2)!important}
.sub-group-start{border-left:3px solid rgba(99,102,241,.45)!important}
.student-summary-start{border-left:3px solid rgba(99,102,241,.45)!important}
.sub-scores{display:inline-flex;align-items:center;justify-content:center;gap:2px;font-variant-numeric:tabular-nums;color:var(--text);padding:.12rem .28rem;border-radius:6px;background:var(--surface2)}
.sub-sep{color:var(--text3);margin:0 1px}
.sub-aplus{background:rgba(34,197,94,.11)}
.sub-aplus .sub-scores{background:rgba(34,197,94,.14);color:#166534}
.sub-aplus .grade-sm{background:rgba(34,197,94,.22);color:#166534}
.sub-failed{background:rgba(244,63,94,.12)}
.sub-failed .sub-scores{background:rgba(244,63,94,.12);color:var(--rose)}
.sub-failed .grade-sm{background:rgba(244,63,94,.18);color:var(--rose)}
.sub-empty{color:var(--text3)}
.grade-sm{font-size:0.62rem!important;padding:1px 5px!important;min-width:24px;vertical-align:middle;margin-left:4px}
.imp-arr{color:var(--green);font-size:0.6rem;margin-left:1px;cursor:default;vertical-align:super}
.imp-delta{font-size:0.7rem;color:var(--green)}
.th-mid{vertical-align:middle!important}
.table-sort-btn{display:inline-flex;align-items:center;justify-content:center;gap:.3rem;width:100%;min-height:24px;background:transparent;color:inherit;font:inherit;text-transform:inherit;letter-spacing:inherit;padding:0}
.table-sort-btn:hover,.table-sort-btn.active{color:var(--accent2)}
.sort-indicator{font-size:.62rem;font-weight:700;color:var(--accent2);line-height:1;text-transform:none;letter-spacing:0}
.th-sub-name{white-space:normal;word-break:break-word;min-width:48px;max-width:72px;text-align:center;line-height:1.3}
.th-sub-scores{font-size:0.65rem!important;font-weight:600!important;color:var(--text2)!important;text-align:center;padding:3px 4px!important;letter-spacing:0.02em}
.student-empty-row td{padding:0!important}
.student-empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.25rem;min-height:180px;color:var(--text2)}
.student-empty-state strong{color:var(--text);font-size:1rem}
.student-empty-state span{font-size:.84rem;color:var(--text3)}
.exclusion-summary{display:inline-flex;align-items:center;min-height:32px;padding:.35rem .7rem;border-radius:8px;background:var(--surface2);border:1px solid var(--border2);color:var(--text2);font-size:.78rem;font-weight:700;white-space:nowrap}
.exclusion-toggle{display:inline-flex;align-items:center;gap:.5rem;min-height:36px;padding:.45rem .75rem;border:1px solid var(--border2);border-radius:8px;background:var(--surface2);color:var(--text2);font-size:.82rem;font-weight:700;white-space:nowrap}
.exclusion-toggle input{width:18px;height:18px;accent-color:var(--accent)}
.exclude-check{width:18px;height:18px;accent-color:var(--accent);vertical-align:middle}
.exclusion-row-muted td{background:rgba(100,116,139,.08);color:var(--text3)}
.exclusion-note{display:inline-flex;margin-left:.4rem;padding:.12rem .4rem;border-radius:999px;background:rgba(245,158,11,.14);color:var(--amber);font-size:.65rem;font-weight:800;vertical-align:middle}
.exclusion-student-scroll{max-height:58vh;overflow:auto}

/* Merit lists */
.merit-table-scroll{max-height:68vh;position:relative}
.merit-table{min-width:860px}
.merit-table th,.merit-table td{text-align:center}
.merit-table td.num{text-align:center}
.merit-table .merit-col-num{width:62px;min-width:62px}
.merit-table .merit-col-class{width:72px;min-width:72px}
.merit-table .merit-col-reg{width:106px;min-width:106px;font-variant-numeric:tabular-nums}
.merit-table .merit-col-name{min-width:250px;text-align:left}
.merit-table th.merit-col-name{text-align:center}
.merit-table .merit-col-mark{width:54px;min-width:54px;font-variant-numeric:tabular-nums}
.merit-table .merit-col-total{width:84px;min-width:84px;font-variant-numeric:tabular-nums}
.merit-table .merit-col-pct{width:78px;min-width:78px;font-variant-numeric:tabular-nums}
.merit-table .merit-col-not-aplus{min-width:190px;text-align:left;white-space:normal}
.merit-table th.merit-col-not-aplus{text-align:center}
.merit-table-controls{justify-content:flex-end}
.merit-improved-row td{background:rgba(34,197,94,.13)}
.merit-improved-row .merit-col-name strong::after{content:'Improved';display:inline-flex;margin-left:.5rem;padding:.12rem .4rem;border-radius:999px;background:rgba(16,185,129,.16);color:var(--green);font-size:.65rem;font-weight:800;vertical-align:middle}
.toppers-limit-control{display:inline-flex;align-items:center;gap:.45rem;padding:.35rem .65rem;border:1px solid var(--border2);border-radius:8px;background:var(--surface2);color:var(--text2);font-size:.78rem;font-weight:650}
.toppers-limit-control input{width:68px;padding:.25rem .35rem;text-align:center}
.btn-pdf{background:linear-gradient(135deg,#0f766e,#0d9488);color:#fff;border:none}

/* ========== THEME TOGGLE ========== */
.theme-toggle{display:flex;align-items:center;justify-content:center;width:28px;height:28px;border-radius:6px;background:var(--surface2);border:1px solid var(--border);color:var(--text2);margin-left:0.75rem;transition:var(--transition)}
.theme-toggle:hover{color:var(--accent);border-color:var(--accent)}
.theme-toggle svg{width:14px;height:14px}
[data-theme="dark"] .sun-icon{display:block}
[data-theme="dark"] .moon-icon{display:none}
.sun-icon{display:none}
.moon-icon{display:block}

/* ========== PAGINATION ========== */
.pagination{display:flex;align-items:center;justify-content:center;gap:.5rem;padding:1rem;flex-wrap:wrap}
.page-btn{padding:.4rem .75rem;border-radius:7px;font-size:.8rem;font-weight:600;background:var(--surface2);color:var(--text2);border:1px solid var(--border);transition:var(--transition)}
.page-btn:hover,.page-btn.active{background:var(--accent);color:#fff;border-color:var(--accent)}
.page-info{font-size:.8rem;color:var(--text3)}

/* ========== GRADE DISTRIBUTION ========== */
.grade-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1.5rem}
.grade-group-card{background:var(--surface);border:1px solid var(--border2);border-radius:var(--radius-xl);padding:1.5rem}
.ggc-title{font-size:1rem;font-weight:700;margin-bottom:1.25rem;display:flex;align-items:center;gap:.5rem}
.ggc-title span{display:inline-block;width:10px;height:10px;border-radius:50%}
.grade-bars{display:flex;flex-direction:column;gap:.6rem}
.gbar-row{display:flex;align-items:center;gap:.75rem}
.gbar-label{width:28px;font-size:.8rem;font-weight:700;color:var(--text2)}
.gbar-track{flex:1;height:20px;background:var(--surface2);border-radius:4px;overflow:hidden}
.gbar-fill{height:100%;border-radius:4px;transition:width .5s ease;display:flex;align-items:center;padding:0 .4rem;min-width:2px}
.gbar-count{font-size:.7rem;font-weight:700;color:#fff;white-space:nowrap}
.gbar-pct{width:40px;font-size:.75rem;color:var(--text3);text-align:right}

/* ========== SUBJECTWISE ANALYSIS ========== */
.subjectwise-panel{overflow:hidden}
.subjectwise-controls{align-items:center;justify-content:flex-end}
.subjectwise-primary-filter{min-width:220px}
.subjectwise-filter-wrap{display:inline-flex;min-width:0}
.subjectwise-filter-wrap[hidden],.subjectwise-toppers-limit[hidden]{display:none!important}
.subjectwise-toppers-limit input{width:68px}
.subjectwise-summary-layout{display:grid;grid-template-columns:minmax(190px,250px) minmax(210px,260px) 1fr;gap:1rem;align-items:center;padding:1.1rem;border-top:1px solid var(--border2)}
.subjectwise-chart-box{position:relative;display:flex;align-items:center;justify-content:center;min-height:230px}
.subjectwise-donut{width:210px;height:210px;border-radius:50%;background:conic-gradient(#e2e8f0 0 360deg);box-shadow:inset 0 0 0 1px var(--border2);transition:background .35s ease}
.subjectwise-donut::after{content:"";position:absolute;inset:50%;width:118px;height:118px;transform:translate(-50%,-50%);border-radius:50%;background:var(--surface);box-shadow:0 0 0 1px var(--border2)}
.subjectwise-donut-center{position:absolute;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.15rem;text-align:center;pointer-events:none}
.subjectwise-donut-center strong{font-size:2rem;line-height:1;font-weight:850;color:var(--text)}
.subjectwise-donut-center span{font-size:.72rem;font-weight:700;text-transform:uppercase;color:var(--text3);letter-spacing:.06em}
.subjectwise-legend{display:grid;grid-template-columns:repeat(2,minmax(96px,1fr));gap:.42rem;max-width:260px}
.subjectwise-legend-item{display:grid;grid-template-columns:10px minmax(24px,.45fr) minmax(26px,.35fr) minmax(38px,.5fr);align-items:center;gap:.3rem;padding:.36rem .42rem;border:1px solid var(--border2);border-radius:8px;background:var(--surface2);font-size:.72rem;color:var(--text2);min-width:0}
.subjectwise-legend-swatch{width:10px;height:10px;border-radius:999px}
.subjectwise-legend-item strong{color:var(--text);font-size:.72rem;min-width:0}
.subjectwise-legend-item span:not(.subjectwise-legend-swatch){font-weight:750;text-align:right;color:var(--text)}
.subjectwise-legend-item small{text-align:right;color:var(--text3);font-size:.66rem;white-space:nowrap;min-width:0}
.subjectwise-class-donuts{display:grid;grid-template-columns:repeat(auto-fit,minmax(86px,1fr));gap:.7rem;align-items:center;width:100%}
.subjectwise-class-donuts[hidden]{display:none!important}
.subjectwise-class-donut-card{display:flex;align-items:center;justify-content:center;min-width:0}
.subjectwise-class-donut{position:relative;width:82px;height:82px;border-radius:50%;background:conic-gradient(#e2e8f0 0 360deg);box-shadow:inset 0 0 0 1px var(--border2)}
.subjectwise-class-donut::after{content:"";position:absolute;inset:50%;width:48px;height:48px;transform:translate(-50%,-50%);border-radius:50%;background:var(--surface);box-shadow:0 0 0 1px var(--border2);z-index:0}
.subjectwise-class-donut-center{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;pointer-events:none;padding:18px;line-height:1.05;z-index:1}
.subjectwise-class-donut-center strong{max-width:52px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-size:.68rem;font-weight:850;color:var(--text);z-index:1}
.subjectwise-class-donut-center span{font-size:.62rem;font-weight:750;color:var(--text3);z-index:1}
.subjectwise-class-empty{grid-column:1/-1;text-align:center;color:var(--text3);font-size:.8rem;padding:1rem}
.subjectwise-table th,.subjectwise-table td{white-space:nowrap;text-align:center}
.subjectwise-table th:nth-child(4),.subjectwise-table td:nth-child(4){white-space:normal;min-width:180px;text-align:left}
.subjectwise-table-scroll{border-top:1px solid var(--border2)}

/* ========== EMPTY STATE ========== */
.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:4rem 2rem;gap:1rem;color:var(--text2)}
.empty-icon{font-size:4rem}
.empty-state h3{font-size:1.25rem;font-weight:700;color:var(--text)}
.empty-state p{max-width:480px;font-size:.9rem;line-height:1.7}

/* ========== HIDDEN ========== */
.hidden{display:none!important}

/* ========== RESPONSIVE ========== */
@media(max-width:900px){
  .hero{flex-direction:column;text-align:center;padding-top:6rem}
  .hero-cta{justify-content:center}
  .hero-stats{justify-content:center}
  .hero-visual{width:100%;max-width:360px;margin:0 auto}
  .table-controls{gap:.5rem}
  .search-input{width:100%}
  .student-table-controls{width:100%;justify-content:stretch}
  .student-table-controls .filter-select,.student-table-controls .btn-export{flex:1 1 150px}
  .subjectwise-summary-layout{grid-template-columns:1fr;padding:1rem}
  .subjectwise-chart-box{min-height:200px}
  .subjectwise-donut{width:180px;height:180px}
  .subjectwise-donut::after{width:102px;height:102px}
  .subjectwise-legend{grid-template-columns:repeat(2,minmax(112px,1fr));max-width:none}
  .subjectwise-class-donuts{grid-template-columns:repeat(auto-fit,minmax(78px,1fr))}
  .subjectwise-class-donut{width:76px;height:76px}
  .subjectwise-class-donut::after{width:44px;height:44px}
}
  .tool-header{padding:2.5rem 1rem 1.5rem}
  .panel{padding:1.25rem}
  .tabs-bar{gap:.25rem}
  .tab-btn{padding:.5rem .75rem;font-size:.8rem}
}

/* =====================================================================
   HSS FINDER — school-finder styles
   ===================================================================== */

/* ── Tool Header Additions ─────────────────────────────────────────── */
.finder-stats-row{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:1.25rem}
.finder-stat-chip{display:inline-flex;align-items:center;gap:.35rem;padding:.3rem .85rem;border-radius:999px;background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.2);font-size:.8rem;font-weight:600;color:var(--text2);backdrop-filter:blur(8px)}
[data-theme="dark"] .finder-stat-chip{background:rgba(255,255,255,.06);border-color:rgba(255,255,255,.12)}

/* ── Page Layout ───────────────────────────────────────────────────── */
.finder-page{display:flex;flex-direction:column;min-height:calc(100vh - 48px)}
.finder-body{display:flex;flex-direction:column;flex:1;min-height:0;position:relative}

/* ── Top Action Bar ────────────────────────────────────────────────── */
.finder-topbar{display:flex;align-items:center;gap:.75rem;padding:.65rem 1.25rem;background:var(--bg2);border-bottom:1px solid var(--border);position:sticky;top:48px;z-index:50;flex-wrap:wrap}
.finder-topbar-actions{display:flex;align-items:center;gap:.5rem;margin-left:auto;flex-shrink:0}
.active-filter-badge{display:inline-flex;align-items:center;justify-content:center;min-width:18px;height:18px;border-radius:999px;background:var(--accent);color:#fff;font-size:.68rem;font-weight:800;padding:0 .35rem;margin-left:.15rem}
.results-stat-bar{flex:1;font-size:.85rem;color:var(--text2);display:flex;align-items:center;gap:.5rem}
.spinner-sm{width:14px;height:14px;border:2px solid var(--border2);border-top-color:var(--accent);border-radius:50%;animation:spin .7s linear infinite;flex-shrink:0}
.btn-mylist-top{display:flex;align-items:center;gap:.45rem;padding:.4rem .9rem;border-radius:8px;border:1px solid rgba(99,102,241,.4);background:rgba(99,102,241,.1);color:var(--accent2);font-size:.82rem;font-weight:600;cursor:pointer;transition:var(--transition)}
.btn-mylist-top:hover{background:rgba(99,102,241,.2);border-color:var(--accent)}
.mylist-count-badge{display:inline-flex;align-items:center;justify-content:center;min-width:18px;height:18px;border-radius:999px;background:var(--accent);color:#fff;font-size:.68rem;font-weight:800;padding:0 .35rem}

/* ── Top Filter Bar ───────────────────────────────────────────────── */
.finder-filter-bar{display:grid;grid-template-columns:minmax(150px,1.2fr) minmax(120px,.8fr) minmax(135px,.95fr) minmax(115px,.8fr) minmax(130px,.95fr) minmax(105px,.7fr) minmax(78px,.55fr);grid-template-areas:"search district stream course course course clear" "edudist taluk localbody type constituency lang gender";align-items:center;gap:.5rem .65rem;padding:.6rem 1.25rem;background:var(--bg2);border-bottom:2px solid var(--border2);overflow:visible}
.finder-filter-bar::-webkit-scrollbar{display:none}
.fb-divider{display:none}
.fb-search-wrap{position:relative;display:flex;align-items:center;min-width:0;grid-area:search}
.fb-search-input{width:100%;padding:.42rem .85rem .42rem 2rem;border-radius:8px;border:1px solid var(--border2);background:var(--surface2);color:var(--text);font-size:.82rem;font-family:inherit;outline:none;transition:var(--transition)}
.fb-search-input:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-glow);background:var(--surface)}
.fb-select{width:100%;min-width:0;padding:.42rem .75rem;border-radius:8px;border:1px solid var(--border2);background:var(--surface2);color:var(--text);font-size:.82rem;font-family:inherit;outline:none;cursor:pointer;transition:var(--transition);grid-area:district}
.fb-select:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-glow)}
.fb-select option{background:var(--surface2)}
.fb-stream-group{display:flex;gap:.3rem;min-width:0;grid-area:stream;flex-wrap:nowrap}
.stream-chip-sm{padding:.3rem .48rem;font-size:.72rem;font-weight:700;border-radius:999px}
.fb-ms{min-width:0}
.fb-ms .ms-trigger{min-width:0;padding:.42rem .7rem;border-radius:8px;font-size:.82rem}
.fb-ms .ms-panel{min-width:220px}
#fs-course{grid-area:course}
#fs-edudist{grid-area:edudist}
#fs-taluk{grid-area:taluk}
#fs-localbody{grid-area:localbody}
#fs-type{grid-area:type}
#fs-constituency{grid-area:constituency}
#fs-lang{grid-area:lang}
#fs-gender{grid-area:gender}
#fs-course.fb-ms .ms-panel{left:auto;right:0;width:min(620px,calc(100vw - 2.5rem));min-width:440px}
.fb-clear-btn{display:inline-flex;align-items:center;justify-content:center;gap:.35rem;padding:.38rem .75rem;border-radius:8px;border:1px solid rgba(225,29,72,.3);background:rgba(225,29,72,.06);color:var(--rose);font-size:.78rem;font-weight:700;cursor:pointer;transition:var(--transition);white-space:nowrap;font-family:inherit;grid-area:clear}
.fb-clear-btn:hover{background:rgba(225,29,72,.14);border-color:var(--rose)}
.sidebar-divider{display:none}
.filter-section{display:none}
.filter-label{font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.07em;color:var(--text3);margin-bottom:.4rem}

/* ── Search Box ────────────────────────────────────────────────────── */
.fs-search-wrap{position:relative;display:flex;align-items:center}
.fs-search-icon{position:absolute;left:.65rem;color:var(--text3);pointer-events:none;flex-shrink:0}
.fs-search-input{width:100%;padding:.5rem .85rem .5rem 2.1rem;border-radius:8px;border:1px solid var(--border2);background:var(--surface2);color:var(--text);font-size:.84rem;font-family:inherit;outline:none;transition:var(--transition)}
.fs-search-input:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-glow);background:var(--surface)}
.fs-search-input::placeholder{color:var(--text3)}
.fs-search-clear{position:absolute;right:.55rem;background:none;border:none;color:var(--text3);font-size:.9rem;cursor:pointer;padding:.15rem .3rem;border-radius:4px;line-height:1;transition:var(--transition)}
.fs-search-clear:hover{color:var(--rose)}

/* ── District Select ───────────────────────────────────────────────── */
.fs-select{width:100%;padding:.5rem .85rem;border-radius:8px;border:1px solid var(--border2);background:var(--surface2);color:var(--text);font-size:.84rem;font-family:inherit;outline:none;cursor:pointer;transition:var(--transition)}
.fs-select:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-glow)}
.fs-select option{background:var(--surface2)}

/* ── Stream Chips ──────────────────────────────────────────────────── */
.stream-chip-group{display:flex;gap:.45rem;flex-wrap:wrap}
.stream-chip-group.fb-stream-group{gap:.2rem;flex-wrap:nowrap;width:100%}
.stream-chip{display:inline-flex;align-items:center;gap:.32rem;padding:.35rem .8rem;border-radius:999px;border:1.5px solid var(--border2);background:var(--surface2);color:var(--text2);font-size:.8rem;font-weight:600;cursor:pointer;transition:all .2s ease;user-select:none}
.stream-chip.stream-chip-sm{flex:1 1 0;justify-content:center;min-width:0;gap:.26rem;padding:.3rem .38rem;font-size:.72rem}
.stream-chip:hover{border-color:var(--accent);color:var(--accent2);background:rgba(99,102,241,.08)}
.stream-chip.active[data-stream="Science"]{background:rgba(79,70,229,.15);border-color:rgba(79,70,229,.6);color:#4f46e5}
.stream-chip.active[data-stream="Humanities"]{background:rgba(13,148,136,.15);border-color:rgba(13,148,136,.6);color:#0d9488}
.stream-chip.active[data-stream="Commerce"]{background:rgba(217,119,6,.15);border-color:rgba(217,119,6,.6);color:#d97706}
[data-theme="dark"] .stream-chip.active[data-stream="Science"]{background:rgba(99,102,241,.2);color:#818cf8;border-color:#818cf8}
[data-theme="dark"] .stream-chip.active[data-stream="Humanities"]{background:rgba(20,184,166,.2);color:#2dd4bf;border-color:#2dd4bf}
[data-theme="dark"] .stream-chip.active[data-stream="Commerce"]{background:rgba(245,158,11,.2);color:#fbbf24;border-color:#fbbf24}
.stream-dot{width:7px;height:7px;border-radius:50%;flex-shrink:0}
.dot-science{background:#4f46e5}
.dot-humanities{background:#0d9488}
.dot-commerce{background:#d97706}
[data-theme="dark"] .dot-science{background:#818cf8}
[data-theme="dark"] .dot-humanities{background:#2dd4bf}
[data-theme="dark"] .dot-commerce{background:#fbbf24}

/* ── MultiSelect Component ─────────────────────────────────────────── */
.ms-container{position:relative}
.ms-root{position:relative}
.ms-trigger{display:flex;align-items:center;justify-content:space-between;width:100%;padding:.48rem .85rem;border-radius:8px;border:1px solid var(--border2);background:var(--surface2);color:var(--text2);font-size:.84rem;font-family:inherit;cursor:pointer;transition:var(--transition);gap:.5rem;text-align:left}
.ms-trigger:hover,.ms-root.is-open .ms-trigger{border-color:var(--accent);background:rgba(99,102,241,.06);color:var(--text)}
.ms-trigger.has-val{color:var(--text);border-color:rgba(99,102,241,.5);background:rgba(99,102,241,.06)}
.ms-label{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;line-height:1.3}
.ms-arrow{flex-shrink:0;opacity:.5;transition:transform .2s ease}
.ms-root.is-open .ms-arrow{transform:rotate(180deg);opacity:.8}
.ms-panel{position:absolute;left:0;right:0;top:calc(100% + 3px);z-index:200;background:var(--surface);border:1px solid var(--border2);border-radius:10px;box-shadow:var(--shadow-lg);overflow:hidden;opacity:0;pointer-events:none;transform:translateY(-6px);transition:opacity .15s ease,transform .15s ease}
.ms-root.is-open .ms-panel{opacity:1;pointer-events:auto;transform:translateY(0)}
.ms-search-row{padding:.45rem .45rem .35rem;border-bottom:1px solid var(--border)}
.ms-search-field{width:100%;padding:.38rem .7rem;border:1px solid var(--border2);border-radius:6px;background:var(--bg3);color:var(--text);font-size:.8rem;font-family:inherit;outline:none;transition:var(--transition)}
.ms-search-field:focus{border-color:var(--accent)}
.ms-option-list{list-style:none;max-height:210px;overflow-y:auto;padding:.2rem 0}
.ms-option-list::-webkit-scrollbar{width:4px}
.ms-option-list::-webkit-scrollbar-thumb{background:var(--border2);border-radius:4px}
.ms-group-hdr{padding:.35rem .75rem .2rem;font-size:.68rem;font-weight:800;text-transform:uppercase;letter-spacing:.07em;color:var(--text3);background:var(--surface2);border-top:1px solid var(--border)}
.ms-group-hdr:first-child{border-top:none}
.ms-opt{display:flex;align-items:flex-start;gap:.55rem;padding:.42rem .75rem;cursor:pointer;transition:background .12s;font-size:.82rem;color:var(--text2);line-height:1.35}
.ms-opt:hover{background:var(--surface2);color:var(--text)}
.ms-opt.is-sel{background:rgba(99,102,241,.08);color:var(--accent2)}
.ms-chk{width:15px;height:15px;min-width:15px;border:1.5px solid var(--border2);border-radius:3px;display:flex;align-items:center;justify-content:center;font-size:.6rem;font-weight:800;color:transparent;background:transparent;transition:all .15s;margin-top:.1rem}
.ms-opt.is-sel .ms-chk{background:var(--accent);border-color:var(--accent);color:#fff}
.ms-opt-text{flex:1;word-break:break-word}
.ms-no-match{padding:.9rem;text-align:center;color:var(--text3);font-size:.82rem}
.ms-footer-row{display:flex;gap:.4rem;padding:.4rem .45rem;border-top:1px solid var(--border)}
.ms-foot-btn{flex:1;padding:.3rem .4rem;border-radius:5px;font-size:.72rem;font-weight:700;background:var(--surface2);color:var(--text2);border:1px solid var(--border);cursor:pointer;transition:var(--transition)}
.ms-foot-btn:hover{color:var(--accent2);border-color:var(--accent);background:rgba(99,102,241,.08)}

/* ── Clear All Button (legacy, unused in filter bar) ────────────────── */
.btn-clear-all-filters{display:flex;align-items:center;gap:.45rem;width:100%;padding:.5rem .85rem;border-radius:8px;border:1px solid var(--border2);background:transparent;color:var(--text3);font-size:.8rem;font-weight:600;cursor:pointer;transition:var(--transition);white-space:nowrap}
.btn-clear-all-filters:hover{color:var(--rose);border-color:rgba(225,29,72,.4);background:rgba(225,29,72,.07)}

/* ── Main Content Area ─────────────────────────────────────────────── */
.finder-main{flex:1;min-width:0;padding:1.25rem 1.5rem 3rem;overflow:hidden}
.results-header-bar{margin-bottom:1rem;display:flex;align-items:center;gap:.75rem}
.results-info-text{font-size:.85rem;color:var(--text2);font-weight:500}
.finder-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1rem;padding:5rem 2rem;color:var(--text2)}

/* ── Results Table ─────────────────────────────────────────────────── */
.school-results-wrap{overflow-x:auto}
.results-table-wrap{border:1px solid var(--border2);border-radius:var(--radius-xl);overflow-x:auto}
.finder-results-table{width:100%;border-collapse:collapse;font-size:.84rem}
.finder-results-table thead th{position:static;z-index:5;background:var(--surface2)}
/* Floating header for finder results table */
.finder-floating-head{position:fixed;display:none;overflow:hidden;z-index:90;background:var(--surface);pointer-events:auto;box-shadow:0 2px 8px rgba(15,23,42,.08)}
.finder-floating-head .finder-results-table{margin:0;table-layout:fixed}
[data-theme="dark"] .finder-floating-head{box-shadow:0 2px 8px rgba(0,0,0,.35)}
.finder-results-table th{padding:.75rem 1rem;text-align:left;font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--text3);background:var(--surface2);white-space:nowrap;border-bottom:2px solid var(--border2)}
.finder-results-table th:first-child{border-radius:var(--radius-xl) 0 0 0}
.finder-results-table th:last-child{border-radius:0 var(--radius-xl) 0 0}
.finder-results-table td{padding:.65rem 1rem;border-bottom:1px solid var(--border);color:var(--text);vertical-align:middle}
.finder-results-table tbody tr:last-child td{border-bottom:none}
.finder-results-table tbody tr:hover td{background:rgba(99,102,241,.05)}
.school-row.row-in-list td{background:rgba(13,148,136,.04)}
.school-row.row-in-list:hover td{background:rgba(13,148,136,.08)}
.school-row{transition:background .15s}

/* Column sizing */
.finder-results-table .col-code{width:70px;min-width:60px}
.finder-results-table .col-name{min-width:180px}
.finder-results-table .col-type{width:110px;min-width:90px}
.finder-results-table .col-course{min-width:160px}
.finder-results-table .col-lang{min-width:120px;font-size:.79rem;color:var(--text2)}
.finder-results-table .col-gender{width:70px;text-align:center}
.finder-results-table .col-actions{width:140px;min-width:130px;white-space:nowrap}

/* Row cells */
.row-code-tag{font-size:.72rem;font-weight:800;color:var(--text3);letter-spacing:.04em;font-variant-numeric:tabular-nums}
.row-name{font-weight:600;color:var(--text);line-height:1.35}
.row-courses{display:flex;flex-wrap:wrap;gap:.3rem}
.row-course-code{display:inline-flex;align-items:center;gap:.25rem;padding:.18rem .45rem;border-radius:5px;font-size:.72rem;font-weight:700;white-space:nowrap;cursor:default}
.row-course-code.cstream-sci{background:rgba(79,70,229,.1);color:#4f46e5;border:1px solid rgba(79,70,229,.2)}
.row-course-code.cstream-hum{background:rgba(13,148,136,.1);color:#0d9488;border:1px solid rgba(13,148,136,.2)}
.row-course-code.cstream-com{background:rgba(217,119,6,.1);color:#d97706;border:1px solid rgba(217,119,6,.2)}
[data-theme="dark"] .row-course-code.cstream-sci{color:#818cf8;background:rgba(99,102,241,.18)}
[data-theme="dark"] .row-course-code.cstream-hum{color:#2dd4bf;background:rgba(20,184,166,.18)}
[data-theme="dark"] .row-course-code.cstream-com{color:#fbbf24;background:rgba(245,158,11,.18)}
.gender-abbr{display:inline-flex;align-items:center;justify-content:center;width:26px;height:26px;border-radius:50%;font-size:.75rem;font-weight:800}
.gender-abbr.sgender-boys{background:rgba(37,99,235,.12);color:#2563eb;border:1px solid rgba(37,99,235,.25)}
.gender-abbr.sgender-girls{background:rgba(219,39,119,.12);color:#db2777;border:1px solid rgba(219,39,119,.25)}
.gender-abbr.sgender-co{background:rgba(22,163,74,.12);color:#16a34a;border:1px solid rgba(22,163,74,.25)}

/* Row action buttons */
.btn-row-add{display:inline-flex;align-items:center;justify-content:center;width:30px;height:30px;border-radius:7px;border:1.5px solid var(--border2);background:var(--surface2);color:var(--text3);cursor:pointer;transition:all .18s ease;vertical-align:middle}
.btn-row-add .icon-check{display:none}
.btn-row-add:hover{border-color:var(--accent);color:var(--accent2);background:rgba(99,102,241,.1)}
.btn-row-add.in-list{border-color:var(--teal);background:rgba(13,148,136,.12);color:var(--teal)}
.btn-row-add.in-list .icon-plus{display:none}
.btn-row-add.in-list .icon-check{display:block}
.btn-row-add.in-list:hover{border-color:var(--rose);background:rgba(225,29,72,.1);color:var(--rose)}
.btn-row-detail{display:inline-flex;align-items:center;gap:.3rem;padding:.28rem .65rem;border-radius:7px;border:1px solid rgba(99,102,241,.35);background:rgba(99,102,241,.08);color:var(--accent2);font-size:.76rem;font-weight:600;cursor:pointer;transition:all .18s ease;margin-left:.4rem;vertical-align:middle}
.btn-row-detail:hover{background:var(--accent);color:#fff;border-color:var(--accent)}

/* Type badges (used in table and modal) */
.sc-type-badge{display:inline-flex;align-items:center;padding:.18rem .55rem;border-radius:999px;font-size:.69rem;font-weight:700;white-space:nowrap}
.sc-type-badge.stype-government{background:rgba(22,163,74,.12);color:#16a34a;border:1px solid rgba(22,163,74,.25)}
.sc-type-badge.stype-aided-general{background:rgba(37,99,235,.12);color:#2563eb;border:1px solid rgba(37,99,235,.25)}
.sc-type-badge.stype-aided-minority{background:rgba(124,58,237,.12);color:#7c3aed;border:1px solid rgba(124,58,237,.25)}
.sc-type-badge.stype-aided-backward{background:rgba(13,148,136,.12);color:#0d9488;border:1px solid rgba(13,148,136,.25)}
.sc-type-badge.stype-unaided{background:rgba(217,119,6,.12);color:#d97706;border:1px solid rgba(217,119,6,.25)}
.sc-type-badge.stype-residential{background:rgba(219,39,119,.12);color:#db2777;border:1px solid rgba(219,39,119,.25)}
.sc-type-badge.stype-technical{background:rgba(225,29,72,.12);color:#e11d48;border:1px solid rgba(225,29,72,.25)}
.sc-type-badge.stype-special{background:rgba(100,116,139,.12);color:var(--text3);border:1px solid rgba(100,116,139,.25)}
.sc-gender-badge{display:inline-flex;align-items:center;gap:.25rem;padding:.18rem .55rem;border-radius:999px;font-size:.69rem;font-weight:700;white-space:nowrap}
.sc-gender-badge.sgender-boys{background:rgba(37,99,235,.1);color:#2563eb;border:1px solid rgba(37,99,235,.2)}
.sc-gender-badge.sgender-girls{background:rgba(219,39,119,.1);color:#db2777;border:1px solid rgba(219,39,119,.2)}
.sc-gender-badge.sgender-co{background:rgba(22,163,74,.1);color:#16a34a;border:1px solid rgba(22,163,74,.2)}
.sc-pin-tag{font-size:.68rem;color:var(--text3);font-weight:500;padding:.18rem .4rem;background:var(--surface2);border-radius:4px;border:1px solid var(--border)}

/* Location rows (used in modal) */
.sc-location,.sc-edu-dist{display:flex;align-items:flex-start;gap:.35rem;font-size:.79rem;color:var(--text2);line-height:1.4}
.sc-location svg,.sc-edu-dist svg{flex-shrink:0;margin-top:.1rem;color:var(--text3)}

/* Courses (used in modal) */
.sc-courses-block{display:flex;flex-direction:column;gap:.4rem}
.sc-courses-label{font-size:.68rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--text3)}
.sc-courses-list{display:flex;flex-direction:column;gap:.3rem}
.course-row{display:flex;align-items:flex-start;gap:.4rem;padding:.3rem .5rem;border-radius:6px;font-size:.77rem;line-height:1.35}
.course-row.cstream-sci{background:rgba(79,70,229,.07);border:1px solid rgba(79,70,229,.15)}
.course-row.cstream-hum{background:rgba(13,148,136,.07);border:1px solid rgba(13,148,136,.15)}
.course-row.cstream-com{background:rgba(217,119,6,.07);border:1px solid rgba(217,119,6,.15)}
.cstream-dot{width:6px;height:6px;border-radius:50%;flex-shrink:0;margin-top:.3rem}
.cdot-sci{background:#4f46e5}
.cdot-hum{background:#0d9488}
.cdot-com{background:#d97706}
[data-theme="dark"] .cdot-sci{background:#818cf8}
[data-theme="dark"] .cdot-hum{background:#2dd4bf}
[data-theme="dark"] .cdot-com{background:#fbbf24}
.cname{flex:1;color:var(--text2);word-break:break-word}
.cbatch{color:var(--text3);font-weight:700;font-size:.7rem;white-space:nowrap;margin-left:auto;padding-left:.3rem}
.cv-badge{display:inline-flex;align-items:center;padding:.08rem .35rem;border-radius:4px;font-size:.63rem;font-weight:800;flex-shrink:0;margin-top:.08rem}
.cv-ca{background:rgba(37,99,235,.15);color:#2563eb;border:1px solid rgba(37,99,235,.25)}
.cv-afs{background:rgba(217,119,6,.15);color:#d97706;border:1px solid rgba(217,119,6,.25)}
[data-theme="dark"] .cv-ca{color:#60a5fa;background:rgba(37,99,235,.2)}
[data-theme="dark"] .cv-afs{color:#fbbf24;background:rgba(217,119,6,.2)}

/* Languages (modal) */
.sc-langs{display:flex;flex-wrap:wrap;align-items:center;gap:.35rem}
.sc-langs-label{font-size:.69rem;font-weight:700;color:var(--text3);text-transform:uppercase;letter-spacing:.04em;white-space:nowrap}
.sc-lang-pills{display:flex;flex-wrap:wrap;gap:.3rem}
.lang-pill{display:inline-block;padding:.15rem .5rem;border-radius:999px;font-size:.69rem;font-weight:600;background:var(--surface2);color:var(--text2);border:1px solid var(--border2)}

/* sc-code-tag and sc-school-name (used in modal head) */
.sc-code-tag{font-size:.7rem;font-weight:800;color:var(--text3);letter-spacing:.05em;text-transform:uppercase;display:block;margin-bottom:.2rem}
.sc-school-name{font-size:1.05rem;font-weight:700;color:var(--text);line-height:1.35;word-break:break-word;margin:0}

/* Maps button */
.btn-view-maps{display:inline-flex;align-items:center;gap:.35rem;padding:.38rem .9rem;border-radius:8px;font-size:.8rem;font-weight:600;background:rgba(99,102,241,.1);color:var(--accent2);border:1px solid rgba(99,102,241,.3);text-decoration:none;transition:all .2s ease;white-space:nowrap}
.btn-view-maps:hover{background:var(--accent);color:#fff;border-color:var(--accent);transform:translateY(-1px);box-shadow:0 4px 12px var(--accent-glow)}
.sc-phone{display:flex;align-items:center;gap:.35rem;font-size:.8rem;color:var(--text3);text-decoration:none;transition:var(--transition)}
.sc-phone:hover{color:var(--accent2)}

/* ── School Detail Modal ────────────────────────────────────────────── */
.school-modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,.55);backdrop-filter:blur(4px);z-index:600;display:flex;align-items:flex-start;justify-content:center;padding:2rem 1rem;overflow-y:auto}
.school-modal-overlay.hidden{display:none!important}
.school-modal{background:var(--surface);border:1px solid var(--border2);border-radius:var(--radius-xl);width:100%;max-width:580px;box-shadow:var(--shadow-lg),0 0 60px rgba(99,102,241,.18);display:flex;flex-direction:column;animation:modalIn .22s ease;margin:auto 0}
@keyframes modalIn{from{opacity:0;transform:translateY(-16px) scale(.97)}to{opacity:1;transform:translateY(0) scale(1)}}
body.modal-open{overflow:hidden}
.modal-head{display:flex;align-items:flex-start;justify-content:space-between;padding:1.25rem 1.35rem 1rem;border-bottom:1px solid var(--border);gap:1rem}
.modal-title-area{flex:1;min-width:0}
.btn-modal-close{display:flex;align-items:center;justify-content:center;width:32px;height:32px;min-width:32px;border-radius:8px;border:1px solid var(--border2);background:var(--surface2);color:var(--text2);font-size:1rem;cursor:pointer;transition:var(--transition);flex-shrink:0}
.btn-modal-close:hover{color:var(--rose);border-color:rgba(225,29,72,.4);background:rgba(225,29,72,.08)}
.modal-body{padding:1.25rem 1.35rem;display:flex;flex-direction:column;gap:.85rem;overflow-y:auto;max-height:60vh}
.modal-body::-webkit-scrollbar{width:4px}
.modal-body::-webkit-scrollbar-thumb{background:var(--border2);border-radius:4px}
.modal-badges{display:flex;flex-wrap:wrap;gap:.35rem}
.modal-location-block{display:flex;flex-direction:column;gap:.35rem}
.modal-contact-block{display:flex;flex-wrap:wrap;gap:.75rem;padding-top:.65rem;border-top:1px solid var(--border)}
.modal-footer{display:flex;align-items:center;gap:.75rem;padding:1rem 1.35rem;border-top:1px solid var(--border);background:var(--surface2);border-radius:0 0 var(--radius-xl) var(--radius-xl);flex-wrap:wrap}
.btn-modal-add{display:inline-flex;align-items:center;gap:.4rem;padding:.4rem 1rem;border-radius:8px;border:1.5px solid var(--border2);background:var(--surface);color:var(--text2);font-size:.82rem;font-weight:600;cursor:pointer;transition:all .2s ease}
.btn-modal-add .icon-check{display:none}
.btn-modal-add:hover{border-color:var(--accent);color:var(--accent2);background:rgba(99,102,241,.1)}
.btn-modal-add.in-list{border-color:var(--teal);background:rgba(13,148,136,.12);color:var(--teal)}
.btn-modal-add.in-list .icon-plus{display:none}
.btn-modal-add.in-list .icon-check{display:block}
.btn-modal-add.in-list:hover{border-color:var(--rose);background:rgba(225,29,72,.1);color:var(--rose)}

/* ── My List Drawer ────────────────────────────────────────────────── */
.mylist-drawer{position:fixed;top:0;right:0;width:min(1120px,100vw);max-width:100vw;height:100vh;background:var(--bg2);border-left:1px solid var(--border2);box-shadow:var(--shadow-lg);z-index:400;display:flex;flex-direction:column;animation:drawerIn .25s ease}
@keyframes drawerIn{from{transform:translateX(100%)}to{transform:translateX(0)}}
.mylist-drawer.hidden{display:none}
.drawer-head{display:flex;align-items:center;justify-content:space-between;padding:1.1rem 1.25rem;border-bottom:1px solid var(--border)}
.drawer-title-block{display:flex;align-items:center;gap:.5rem}
.drawer-icon{font-size:1.1rem}
.drawer-title{font-size:1rem;font-weight:700;margin:0}
.drawer-count-pill{display:inline-flex;align-items:center;justify-content:center;min-width:22px;height:22px;border-radius:999px;background:var(--accent);color:#fff;font-size:.72rem;font-weight:800;padding:0 .4rem}
.drawer-actions{display:flex;align-items:center;gap:.5rem}
.btn-print-list{display:flex;align-items:center;gap:.4rem;padding:.4rem .85rem;border-radius:7px;font-size:.8rem;font-weight:600;background:linear-gradient(135deg,var(--accent),#8b5cf6);color:#fff;border:none;cursor:pointer;transition:all .2s ease;box-shadow:0 2px 8px var(--accent-glow)}
.btn-print-list:hover{opacity:.92;transform:translateY(-1px)}
.btn-drawer-close{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border-radius:8px;border:1px solid var(--border2);background:var(--surface2);color:var(--text2);font-size:1rem;cursor:pointer;transition:var(--transition)}
.btn-drawer-close:hover{color:var(--rose);border-color:rgba(225,29,72,.4);background:rgba(225,29,72,.08)}
.drawer-hint{display:flex;align-items:center;gap:.35rem;padding:.5rem 1.25rem;font-size:.75rem;color:var(--text3);border-bottom:1px solid var(--border);background:var(--bg3)}
.mylist-add-search{padding:.8rem 1.25rem .7rem;border-bottom:1px solid var(--border);background:var(--bg2)}
.mylist-search-label{display:block;margin:0 0 .4rem;font-size:.72rem;font-weight:700;color:var(--text2)}
.mylist-search-box{display:flex;align-items:center;gap:.45rem;height:38px;border:1px solid var(--border2);border-radius:8px;background:var(--surface);padding:0 .6rem;color:var(--text3);transition:var(--transition)}
.mylist-search-box:focus-within{border-color:rgba(99,102,241,.55);box-shadow:0 0 0 3px rgba(99,102,241,.1);color:var(--accent2)}
.mylist-search-input{flex:1;min-width:0;border:0;outline:0;background:transparent;color:var(--text);font-size:.82rem}
.mylist-search-input::placeholder{color:var(--text3)}
.mylist-search-clear{display:flex;align-items:center;justify-content:center;width:22px;height:22px;border:0;border-radius:6px;background:transparent;color:var(--text3);font-size:1rem;line-height:1;cursor:pointer;transition:var(--transition)}
.mylist-search-clear:hover{background:rgba(225,29,72,.1);color:var(--rose)}
.mylist-search-results{display:none;margin:.5rem 1.25rem .75rem;max-height:260px;overflow-y:auto}
.mylist-search-results.has-results{display:flex;flex-direction:column;gap:.35rem}
.mylist-search-results::-webkit-scrollbar{width:4px}
.mylist-search-results::-webkit-scrollbar-thumb{background:var(--border2);border-radius:4px}
.mylist-search-note{margin:0;padding:.55rem .65rem;border:1px dashed var(--border2);border-radius:8px;color:var(--text3);font-size:.78rem;text-align:center}
.mylist-search-result{display:flex;align-items:center;gap:.6rem;width:100%;min-height:50px;padding:.55rem .6rem;border:1px solid var(--border);border-radius:8px;background:var(--surface);color:var(--text);text-align:left;cursor:pointer;transition:var(--transition)}
.mylist-search-result:hover{border-color:rgba(99,102,241,.35);background:rgba(99,102,241,.05)}
.mylist-search-result.is-added{cursor:default;background:rgba(13,148,136,.06);border-color:rgba(13,148,136,.25)}
.mylist-search-result-main{display:flex;flex-direction:column;gap:.15rem;min-width:0;flex:1}
.mylist-search-result-name{font-size:.8rem;font-weight:650;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.mylist-search-result-meta{font-size:.7rem;color:var(--text3);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.mylist-search-result-action{display:inline-flex;align-items:center;justify-content:center;min-width:44px;height:26px;border-radius:7px;background:rgba(99,102,241,.1);color:var(--accent2);font-size:.72rem;font-weight:800;flex-shrink:0}
.mylist-search-result.is-added .mylist-search-result-action{background:rgba(13,148,136,.12);color:var(--teal)}

/* ── Sortable My List ──────────────────────────────────────────────── */
.mylist-table-shell{flex:1;min-height:0;overflow:auto;padding:1rem 1.25rem 1.25rem}
.mylist-results-wrap{min-width:820px;border-radius:var(--radius-xl)}
.mylist-results-table .col-drag{width:76px;min-width:76px}
.mylist-results-table .col-actions{width:150px;min-width:150px}
.mylist-results-table .col-actions .btn-row-detail{margin-left:0}
.mylist-results-table .mylist-rm-btn{display:inline-flex;margin-left:.35rem;vertical-align:middle}
.mylist-table-row .col-drag{display:flex;align-items:center;gap:.45rem}
.mylist-no-results{margin:0;padding:2rem;border:1px dashed var(--border2);border-radius:var(--radius-xl);background:var(--surface);color:var(--text3);font-size:.88rem;text-align:center}
.mylist-sortable-list{list-style:none;flex:1;overflow-y:auto;padding:.5rem .75rem}
.mylist-sortable-list::-webkit-scrollbar{width:4px}
.mylist-sortable-list::-webkit-scrollbar-thumb{background:var(--border2);border-radius:4px}
.mylist-item{display:flex;align-items:center;gap:.6rem;padding:.65rem .75rem;border-radius:10px;border:1px solid var(--border);background:var(--surface);margin-bottom:.45rem;transition:all .2s ease}
.mylist-item:hover{border-color:rgba(99,102,241,.35);background:rgba(99,102,241,.04)}
.drag-handle{color:var(--text3);font-size:1.1rem;cursor:grab;padding:0 .1rem;user-select:none;transition:color .15s;letter-spacing:.05em}
.drag-handle svg{display:block}
.drag-handle:hover,.mylist-item:hover .drag-handle{color:var(--accent2)}
.drag-handle:active{cursor:grabbing}
.mylist-num{min-width:20px;height:20px;border-radius:50%;background:var(--surface2);border:1px solid var(--border2);display:flex;align-items:center;justify-content:center;font-size:.68rem;font-weight:800;color:var(--text3);flex-shrink:0}
.mylist-info{flex:1;min-width:0;display:flex;flex-direction:column;gap:.15rem}
.mylist-name{font-size:.82rem;font-weight:600;color:var(--text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.mylist-meta{font-size:.71rem;color:var(--text3)}
.mylist-rm-btn{display:flex;align-items:center;justify-content:center;width:26px;height:26px;border-radius:6px;border:1px solid transparent;background:transparent;color:var(--text3);cursor:pointer;transition:var(--transition);flex-shrink:0}
.mylist-rm-btn:hover{color:var(--rose);border-color:rgba(225,29,72,.35);background:rgba(225,29,72,.1)}
.sortable-ghost{opacity:.4;background:rgba(99,102,241,.1)!important;border-color:rgba(99,102,241,.4)!important}
.sortable-chosen{box-shadow:0 4px 16px rgba(99,102,241,.2);transform:scale(1.01)}
.drawer-empty-msg{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.75rem;flex:1;padding:2rem 1.5rem;text-align:center;color:var(--text2)}
.de-icon{font-size:2.5rem;opacity:.5}
.drawer-empty-msg p{font-size:.85rem;line-height:1.6;max-width:240px}

/* ── Sidebar backdrop (mobile) ─────────────────────────────────────── */
.sidebar-backdrop{position:fixed;inset:0;background:rgba(0,0,0,.5);z-index:299;backdrop-filter:blur(2px)}

/* ── Pagination extras ─────────────────────────────────────────────── */
.page-ellipsis{padding:.4rem .35rem;font-size:.8rem;color:var(--text3)}
.page-btn.disabled{opacity:.4;pointer-events:none}

/* ── Print Layout ──────────────────────────────────────────────────── */
.print-area{display:none}
@media print{
  body>*:not(#print-area){display:none!important}
  #print-area{display:block!important;font-family:'Inter',Arial,sans-serif;font-size:10pt;color:#000;background:#fff}
  @page{size:A4 portrait;margin:12mm 14mm}
  .pa-header{margin-bottom:6mm;padding-bottom:4mm;border-bottom:2px solid #4f46e5}
  .pa-brand{font-size:11pt;font-weight:800;color:#4f46e5;margin-bottom:1mm}
  .pa-sub{color:#6b7280;font-weight:400}
  .pa-title{font-size:18pt;font-weight:900;color:#0f172a;margin-bottom:2mm}
  .pa-meta{display:flex;gap:8mm;font-size:8.5pt;color:#475569;margin-bottom:1.5mm}
  .pa-filters{font-size:8pt;color:#6b7280;background:#f8fafc;padding:2mm 3mm;border-radius:2mm}
  .pa-table{width:100%;border-collapse:collapse;margin-top:5mm}
  .pa-table th{background:#4f46e5;color:#fff;font-size:7.5pt;font-weight:700;padding:2.5mm 3mm;text-align:left;text-transform:uppercase;letter-spacing:.04em}
  .pa-table td{padding:2mm 3mm;font-size:8.5pt;vertical-align:top;border-bottom:0.5pt solid #e2e8f0;line-height:1.4}
  .pa-table tr:nth-child(even) td{background:#f8fafc}
  .pa-table tr:last-child td{border-bottom:1pt solid #4f46e5}
  .pa-table .pn{width:8mm;text-align:center;font-weight:700;color:#4f46e5}
  .pa-table .pc{width:12mm;font-weight:700;color:#475569}
  .pa-table .ps{min-width:45mm}
  .pa-table .pcrs{min-width:60mm;font-size:7.5pt;color:#374151}
  .pa-footer{margin-top:4mm;font-size:7pt;color:#9ca3af;text-align:center;border-top:0.5pt solid #e2e8f0;padding-top:2mm}
}

/* ── Responsive ────────────────────────────────────────────────────── */
@media(max-width:900px){
  .finder-filter-bar{grid-template-columns:minmax(170px,1.2fr) minmax(135px,1fr) minmax(135px,1fr) minmax(78px,.55fr);grid-template-areas:"search district stream clear" "course course course course" "edudist taluk localbody type" "constituency constituency lang gender";gap:.5rem .6rem;padding:.6rem 1rem}
  #fs-course.fb-ms .ms-panel{left:0;right:auto;width:min(620px,calc(100vw - 2rem));min-width:0}
  .filter-bar-search{min-width:150px}
  .filter-bar-course{min-width:150px;max-width:220px}
  .finder-main{padding:1rem 1rem 3rem}
  .mylist-drawer{width:100vw}
  .finder-results-table .col-lang{display:none}
  .school-modal{max-width:100%;border-radius:var(--radius-lg) var(--radius-lg) 0 0;margin-top:auto;margin-bottom:0}
  .school-modal-overlay{align-items:flex-end;padding:0}
}
@media(max-width:600px){
  .finder-topbar{top:48px;flex-wrap:wrap;gap:.5rem}
  .finder-filter-bar{grid-template-columns:1fr 1fr;grid-template-areas:"search search" "district stream" "course course" "edudist taluk" "localbody type" "constituency constituency" "lang gender" "clear clear";gap:.4rem .5rem;padding:.5rem .75rem}
  .fb-clear-btn{justify-self:start}
  .results-stat-bar{font-size:.78rem;order:2;width:100%}
  .btn-mylist-top{margin-left:auto}
  .finder-results-table .col-gender{display:none}
  .finder-results-table th,.finder-results-table td{padding:.5rem .65rem}
  .modal-body{max-height:70vh}
}

/* ========== COMPARE OPTIONS MODAL ========== */
.btn-compare-options{display:flex;align-items:center;gap:.4rem;padding:.38rem .7rem;border-radius:7px;font-size:.78rem;font-weight:700;background:rgba(13,148,136,.12);color:var(--teal);border:1px solid rgba(13,148,136,.3);cursor:pointer;transition:all .2s ease;white-space:nowrap}
.btn-compare-options:hover{background:rgba(13,148,136,.22);border-color:var(--teal)}

.compare-modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,.55);backdrop-filter:blur(6px);z-index:500;display:flex;align-items:center;justify-content:center;padding:1rem}
.compare-modal-overlay.hidden{display:none}
.compare-modal{background:var(--bg2);border:1px solid var(--border2);border-radius:var(--radius-xl);width:min(1200px,100%);max-height:92vh;display:flex;flex-direction:column;box-shadow:0 24px 80px rgba(0,0,0,.35);animation:compareModalIn .25s ease}
@keyframes compareModalIn{from{opacity:0;transform:scale(.97) translateY(12px)}to{opacity:1;transform:none}}

.compare-modal-head{display:flex;align-items:center;justify-content:space-between;padding:1.25rem 1.5rem;border-bottom:1px solid var(--border);flex-shrink:0}
.compare-modal-title-area{display:flex;align-items:center;gap:.85rem}
.compare-modal-icon{font-size:1.75rem;line-height:1}
.compare-modal-title{font-size:1.2rem;font-weight:800;margin:0 0 .1rem;color:var(--text)}
.compare-modal-subtitle{font-size:.8rem;color:var(--text3);margin:0}
.btn-compare-modal-close{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:9px;border:1px solid var(--border2);background:var(--surface2);color:var(--text2);font-size:1.1rem;cursor:pointer;transition:var(--transition)}
.btn-compare-modal-close:hover{color:var(--rose);border-color:rgba(225,29,72,.4);background:rgba(225,29,72,.08)}

.compare-modal-body{flex:1;overflow-y:auto;overflow-x:hidden}
.compare-modal-body::-webkit-scrollbar{width:6px}
.compare-modal-body::-webkit-scrollbar-thumb{background:var(--border2);border-radius:4px}

.compare-paste-section{padding:1.5rem;display:flex;flex-direction:column;gap:1rem}
.compare-paste-instructions{display:flex;flex-direction:column;gap:.65rem}
.compare-instruction-card{display:flex;align-items:flex-start;gap:.85rem;padding:1rem 1.25rem;background:rgba(99,102,241,.07);border:1px solid rgba(99,102,241,.2);border-radius:var(--radius);line-height:1.5}
.compare-instr-icon{font-size:1.4rem;flex-shrink:0;margin-top:.1rem}
.compare-instruction-card strong{display:block;font-size:.88rem;font-weight:700;color:var(--text);margin-bottom:.2rem}
.compare-instruction-card p{font-size:.83rem;color:var(--text2);margin:0}
.compare-format-hint{display:flex;align-items:center;gap:.6rem;flex-wrap:wrap;padding:.55rem .85rem;background:var(--surface2);border:1px solid var(--border);border-radius:8px;font-size:.8rem}
.compare-format-label{font-weight:700;color:var(--text3);white-space:nowrap}
.compare-format-hint code{font-family:monospace;font-size:.78rem;color:var(--accent2);background:rgba(99,102,241,.1);padding:.1rem .4rem;border-radius:4px}

.compare-paste-box{width:100%;min-height:200px;resize:vertical;border:1.5px solid var(--border2);border-radius:var(--radius);padding:1rem;background:var(--surface2);color:var(--text);font-family:monospace;font-size:.82rem;line-height:1.6;outline:none;transition:border-color .2s,box-shadow .2s}
.compare-paste-box:focus{border-color:var(--teal);box-shadow:0 0 0 3px var(--teal-glow)}
.compare-paste-actions{display:flex;align-items:center;justify-content:space-between;gap:.75rem;flex-wrap:wrap}
.compare-paste-hint{font-size:.8rem;color:var(--text3)}
.compare-paste-hint.error{color:var(--rose)}
.compare-paste-btns{display:flex;align-items:center;gap:.65rem;margin-left:auto}
.btn-compare-clear-paste{padding:.42rem .9rem;border-radius:8px;border:1px solid var(--border2);background:var(--surface2);color:var(--text2);font-size:.82rem;font-weight:600;cursor:pointer;transition:var(--transition)}
.btn-compare-clear-paste:hover{border-color:var(--rose);color:var(--rose);background:rgba(225,29,72,.08)}
.btn-compare-run{display:flex;align-items:center;gap:.45rem;padding:.5rem 1.25rem;border-radius:8px;background:linear-gradient(135deg,var(--teal),#0d9488);color:#fff;font-size:.88rem;font-weight:700;border:none;cursor:pointer;transition:all .2s ease;box-shadow:0 2px 10px var(--teal-glow)}
.btn-compare-run:hover{opacity:.92;transform:translateY(-1px)}

.compare-results-section{display:flex;flex-direction:column;gap:0}
.compare-results-section.hidden{display:none!important}
.compare-results-topbar{display:flex;align-items:center;gap:.75rem;padding:.65rem 1.25rem;border-bottom:1px solid var(--border);background:var(--bg3);flex-wrap:nowrap;min-height:0}
.btn-compare-back{display:flex;align-items:center;gap:.35rem;padding:.38rem .8rem;border-radius:7px;border:1px solid var(--border2);background:var(--surface2);color:var(--text2);font-size:.8rem;font-weight:600;cursor:pointer;transition:var(--transition);flex-shrink:0;white-space:nowrap}
.btn-compare-back:hover{border-color:var(--accent);color:var(--accent2)}

/* filter bar inside topbar */
.compare-results-topbar .compare-filter-bar{flex:1;min-width:0;border:none;background:transparent;padding:0}

/* Row colour highlights — stronger for easy visual scan */
.crow-full-applied td   {background:rgba(22,163,74,.18)}
.crow-partial-applied td{background:rgba(234,179,8,.18)}
.crow-not-applied td    {background:rgba(249,115,22,.18)}
.crow-not-mylist td     {background:rgba(239,68,68,.15)}
[data-theme="dark"] .crow-full-applied td   {background:rgba(34,197,94,.17)}
[data-theme="dark"] .crow-partial-applied td{background:rgba(234,179,8,.17)}
[data-theme="dark"] .crow-not-applied td    {background:rgba(249,115,22,.17)}
[data-theme="dark"] .crow-not-mylist td     {background:rgba(239,68,68,.15)}
/* left accent stripe */
.crow-full-applied    td:first-child{box-shadow:inset 4px 0 0 rgba(22,163,74,.8)}
.crow-partial-applied td:first-child{box-shadow:inset 4px 0 0 rgba(202,138,4,.9)}
.crow-not-applied     td:first-child{box-shadow:inset 4px 0 0 rgba(234,88,12,.9)}
.crow-not-mylist      td:first-child{box-shadow:inset 4px 0 0 rgba(220,38,38,.8)}

/* flat table wrapper */
.compare-flat-wrap{border-radius:var(--radius);overflow:hidden;border:1px solid var(--border2)}
.compare-flat-wrap .compare-table{border-radius:0;border:none}

.compare-results-body{padding:1.25rem 1.5rem;display:flex;flex-direction:column;gap:1.25rem}

.compare-section{border-radius:var(--radius);overflow:hidden;border:1px solid var(--border2)}
.compare-section-head{display:flex;align-items:center;gap:.6rem;padding:.85rem 1.1rem;cursor:pointer;user-select:none;background:var(--surface2);border-bottom:1px solid var(--border)}
.compare-section-head:hover{background:var(--surface3)}
.compare-section-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}
.dot-applied{background:var(--teal)}
.dot-missing{background:var(--amber)}
.dot-other{background:var(--accent2)}
.compare-section-label{font-size:.9rem;font-weight:700;color:var(--text);flex:1}
.compare-section-desc{font-size:.78rem;color:var(--text3);font-weight:400;margin-left:.3rem}
.compare-section-count{display:inline-flex;align-items:center;justify-content:center;min-width:22px;height:22px;border-radius:999px;font-size:.72rem;font-weight:800;padding:0 .4rem;color:#fff}
.scount-applied{background:var(--teal)}
.scount-missing{background:var(--amber)}
.scount-other{background:var(--accent2)}
.compare-section-chevron{font-size:.75rem;color:var(--text3);margin-left:.25rem;transition:transform .2s}
.compare-section.is-collapsed .compare-section-chevron{transform:rotate(-90deg)}
.compare-section.is-collapsed .compare-section-content{display:none}

.compare-section-content{overflow-x:auto}
.compare-table{width:100%;border-collapse:collapse;font-size:.83rem;min-width:500px}
.compare-table th{padding:.65rem 1rem;text-align:left;font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--text3);background:var(--surface);white-space:nowrap;border-bottom:1px solid var(--border)}
.compare-table td{padding:.65rem 1rem;border-bottom:1px solid var(--border2);color:var(--text);vertical-align:top}
.compare-table tbody tr:last-child td{border-bottom:none}
.compare-opt-num{display:inline-flex;align-items:center;justify-content:center;min-width:24px;height:24px;border-radius:50%;background:var(--surface2);border:1px solid var(--border2);font-size:.72rem;font-weight:800;color:var(--text3)}
.compare-school-name{font-weight:600;display:block;color:var(--text);line-height:1.35}
.compare-school-code{display:inline-block;margin-top:.2rem;padding:.1rem .4rem;border-radius:4px;background:var(--surface2);border:1px solid var(--border2);font-size:.72rem;font-weight:700;color:var(--text2)}
.compare-course-name{display:block;color:var(--text);line-height:1.4}
.compare-course-code-badge{display:inline-block;margin-top:.2rem;padding:.15rem .5rem;border-radius:5px;font-size:.72rem;font-weight:800}
.ccb-applied{background:rgba(13,148,136,.14);color:var(--teal)}
.ccb-other{background:rgba(99,102,241,.12);color:var(--accent2)}
.compare-row-applied td{background:rgba(13,148,136,.035)}
.compare-row-other td{background:rgba(99,102,241,.025)}
.compare-mylist-pill{display:inline-flex;align-items:center;gap:.3rem;padding:.22rem .6rem;border-radius:999px;font-size:.72rem;font-weight:800;white-space:nowrap}
.pill-in-list{background:rgba(13,148,136,.14);color:var(--teal)}
.pill-not-in-list{background:rgba(99,102,241,.12);color:var(--accent2)}
.pill-missing{background:rgba(245,158,11,.14);color:var(--amber)}

.compare-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.5rem;padding:2.5rem;text-align:center;color:var(--text2)}
.compare-empty-icon{font-size:2.5rem;opacity:.6}
.compare-empty strong{color:var(--text);font-size:.92rem}
.compare-empty span{font-size:.82rem;color:var(--text3)}

/* ── Compare table output helpers ── */
.compare-codes-wrap{display:flex;flex-wrap:wrap;gap:.3rem;align-items:flex-start;min-width:0}
/* Make the ccb-sm badge a bit smaller than the normal row-course-code */
.ccb-sm{font-size:.72rem!important;padding:.12rem .4rem!important}
/* Faded / muted style for "Not Applied" badges */
.ccb-faded{opacity:.42;filter:grayscale(40%)}
/* Dash / unknown pills */
.compare-none-pill{display:inline-flex;align-items:center;padding:.15rem .5rem;border-radius:5px;background:var(--surface2);border:1px solid var(--border);color:var(--text3);font-size:.72rem}
.compare-none-muted{font-style:italic;color:var(--text3)}
/* Column sizing for 4-column layout (Code | School | Applied | Not Applied) */
.compare-table td.col-code,.compare-table th:first-child{width:62px;min-width:54px;max-width:72px;white-space:nowrap;vertical-align:top}
.compare-table td.col-school,.compare-table th:nth-child(2){min-width:160px;white-space:normal;vertical-align:top}
.compare-table td:not(.col-code):not(.col-school),.compare-table th:nth-child(n+3){min-width:130px;white-space:normal;vertical-align:top}
/* Row highlight adjustments for new layout */
.compare-row-missing td{background:rgba(245,158,11,.04)}
.compare-row-missing td.col-code .compare-school-code{border-color:rgba(245,158,11,.35);color:var(--amber)}

/* ── Compare Filter Bar ── */
.compare-filter-bar{display:flex;align-items:center;min-width:0}
.cfbar-inner{display:flex;align-items:flex-start;gap:1rem;flex-wrap:wrap}
.cfbar-group{display:flex;align-items:flex-start;gap:.55rem;flex-wrap:wrap}
.cfbar-codes{flex:1;min-width:0}
.cfbar-label{font-size:.72rem;font-weight:800;text-transform:uppercase;letter-spacing:.06em;color:var(--text3);white-space:nowrap;padding-top:.3rem;min-width:40px}
.cfbar-chips{display:flex;flex-wrap:wrap;gap:.3rem;align-items:center}
.cfbar-sep{width:1px;background:var(--border2);align-self:stretch;flex-shrink:0;margin:.1rem 0}
.cfbar-hint{font-size:.78rem;color:var(--text3);font-style:italic}

/* filter chips */
.cfchip{display:inline-flex;align-items:center;padding:.22rem .6rem;border-radius:6px;font-size:.78rem;font-weight:700;cursor:pointer;border:1.5px solid transparent;transition:all .15s ease;background:var(--surface2);color:var(--text2);border-color:var(--border2)}
.cfchip:hover{filter:brightness(1.1)}
.cfchip-stream{min-width:36px;justify-content:center}

/* active state inherits stream colour */
.cfchip.cstream-sci.cfchip-active{background:rgba(79,70,229,.14);color:#4f46e5;border-color:rgba(79,70,229,.5)}
.cfchip.cstream-hum.cfchip-active{background:rgba(13,148,136,.14);color:#0d9488;border-color:rgba(13,148,136,.5)}
.cfchip.cstream-com.cfchip-active{background:rgba(217,119,6,.14);color:#d97706;border-color:rgba(217,119,6,.5)}
[data-theme="dark"] .cfchip.cstream-sci.cfchip-active{background:rgba(99,102,241,.2);color:#818cf8;border-color:#818cf8}
[data-theme="dark"] .cfchip.cstream-hum.cfchip-active{background:rgba(20,184,166,.2);color:#2dd4bf;border-color:#2dd4bf}
[data-theme="dark"] .cfchip.cstream-com.cfchip-active{background:rgba(245,158,11,.2);color:#fbbf24;border-color:#fbbf24}
/* code chips also tint by stream when not active */
.cfchip.cfchip-code.cstream-sci{color:#4f46e5;border-color:rgba(79,70,229,.25)}
.cfchip.cfchip-code.cstream-hum{color:#0d9488;border-color:rgba(13,148,136,.25)}
.cfchip.cfchip-code.cstream-com{color:#d97706;border-color:rgba(217,119,6,.25)}
[data-theme="dark"] .cfchip.cfchip-code.cstream-sci{color:#818cf8;border-color:rgba(99,102,241,.3)}
[data-theme="dark"] .cfchip.cfchip-code.cstream-hum{color:#2dd4bf;border-color:rgba(20,184,166,.3)}
[data-theme="dark"] .cfchip.cfchip-code.cstream-com{color:#fbbf24;border-color:rgba(245,158,11,.3)}

.cfbar-clear{margin-left:auto;align-self:center;padding:.28rem .75rem;border-radius:7px;border:1px solid var(--border2);background:var(--surface2);color:var(--text3);font-size:.75rem;font-weight:700;cursor:pointer;transition:var(--transition);white-space:nowrap}
.cfbar-clear:hover{border-color:var(--rose);color:var(--rose);background:rgba(225,29,72,.07)}

@media(max-width:640px){

  .cfbar-sep{display:none}
  .cfbar-group{flex-direction:row}
}

@media(max-width:640px){
  .compare-modal{max-height:100vh;border-radius:var(--radius-lg) var(--radius-lg) 0 0;margin-top:auto;margin-bottom:0;width:100%}
  .compare-modal-overlay{align-items:flex-end;padding:0}
  .compare-paste-section,.compare-results-body{padding:1rem}
  .compare-table th,.compare-table td{padding:.5rem .65rem}
}

/* =====================================================================
   MIRROR SITE BANNER & HOMEPAGE RESTYLE ADDITIONS
   ===================================================================== */
.mirror-banner {
  background: linear-gradient(90deg, #0f172a, #1e1b4b);
  color: #e2e8f0;
  font-size: 0.72rem;
  padding: 0.35rem 1.5rem;
  border-bottom: 1px solid rgba(255, 255, 255, 0.08);
  position: relative;
  z-index: 110;
}
[data-theme="dark"] .mirror-banner {
  background: linear-gradient(90deg, #020617, #0d0b21);
  border-bottom-color: rgba(255, 255, 255, 0.04);
}
.mirror-container {
  max-width: 1400px;
  margin: 0 auto;
  display: flex;
  align-items: center;
  gap: 0.65rem;
  font-weight: 600;
  letter-spacing: 0.02em;
}
.mirror-label {
  color: #94a3b8;
  font-size: 0.68rem;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  display: flex;
  align-items: center;
  gap: 0.25rem;
}
.mirror-link {
  color: #818cf8;
  transition: all 0.2s ease;
  text-decoration: none;
  font-family: monospace;
}
.mirror-link:hover {
  color: #14b8a6;
  text-decoration: underline;
  text-underline-offset: 3px;
}
.mirror-sep {
  color: #334155;
}

/* Core spotlight layout for desktop grid */
@media(min-width: 992px) {
  .tool-card.core-spotlight {
    grid-column: span 2;
  }
}

.tool-badge-row {
  display: flex;
  gap: 0.4rem;
  flex-wrap: wrap;
  margin-bottom: 0.25rem;
}

.tool-badge-tag.helpdesk-badge {
  background: rgba(13, 148, 136, 0.15);
  color: #0d9488;
  border: 1px solid rgba(13, 148, 136, 0.3);
}

.tool-badge-tag.select-badge {
  background: rgba(99, 102, 241, 0.15);
  color: #4f46e5;
  border: 1px solid rgba(99, 102, 241, 0.3);
}

.tool-badge-tag.info-badge {
  background: rgba(217, 119, 6, 0.15);
  color: #d97706;
  border: 1px solid rgba(217, 119, 6, 0.3);
}

[data-theme="dark"] .tool-badge-tag.helpdesk-badge {
  background: rgba(20, 184, 166, 0.15);
  color: #2dd4bf;
  border-color: rgba(20, 184, 166, 0.3);
}

[data-theme="dark"] .tool-badge-tag.select-badge {
  background: rgba(99, 102, 241, 0.2);
  color: #818cf8;
  border-color: rgba(99, 102, 241, 0.4);
}

[data-theme="dark"] .tool-badge-tag.info-badge {
  background: rgba(245, 158, 11, 0.15);
  color: #fbbf24;
  border-color: rgba(245, 158, 11, 0.3);
}

/* SWS Helpdesk Tip */
.compare-instruction-card.helpdesk-tip {
  background: rgba(13, 148, 136, 0.08);
  border-color: rgba(13, 148, 136, 0.25);
}
.compare-instruction-card.helpdesk-tip strong {
  color: #0d9488;
}
[data-theme="dark"] .compare-instruction-card.helpdesk-tip {
  background: rgba(20, 184, 166, 0.05);
  border-color: rgba(20, 184, 166, 0.15);
}
[data-theme="dark"] .compare-instruction-card.helpdesk-tip strong {
  color: #2dd4bf;
}


/* ========== HOMEPAGE MOBILE RESPONSIVENESS ========== */

@media (max-width: 768px) {
  /* Remove double nesting border & shadow of the outer table panel */
  body.home-page .table-panel {
    background: transparent !important;
    border: none !important;
    box-shadow: none !important;
  }
  
  /* Reset table container to block */
  body.home-page .table-scroll {
    overflow: visible !important;
  }

  /* Transform table tags to blocks */
  body.home-page .result-table,
  body.home-page .result-table tbody,
  body.home-page .result-table tr,
  body.home-page .result-table td {
    display: block !important;
    width: 100% !important;
    min-width: 0 !important;
    box-sizing: border-box !important;
  }

  /* Hide table header */
  body.home-page .result-table thead {
    display: none !important;
  }

  /* Style each row as a premium floating card */
  body.home-page .result-table tr {
    background: var(--surface) !important;
    border: 1px solid var(--border2) !important;
    border-radius: var(--radius-xl) !important;
    padding: 1.25rem !important;
    margin-bottom: 1.25rem !important;
    box-shadow: var(--shadow) !important;
    transition: transform 0.2s ease, box-shadow 0.2s ease, border-color 0.2s ease !important;
  }

  body.home-page .result-table tr:hover,
  body.home-page .result-table tr:active {
    transform: translateY(-2px);
    box-shadow: var(--shadow-lg) !important;
    border-color: var(--accent) !important;
  }

  /* Disable table cell hover background */
  body.home-page .result-table tbody tr:hover td {
    background: transparent !important;
  }

  /* Card Header: Tool Name, Icon, & Badges */
  body.home-page .result-table td:nth-child(1) {
    padding: 0 0 0.85rem 0 !important;
    border-bottom: 1px solid var(--border) !important;
    margin-bottom: 0.85rem !important;
  }

  /* Card Body: Description & Bullet Features */
  body.home-page .result-table td:nth-child(2) {
    padding: 0 0 1.15rem 0 !important;
    border-bottom: none !important;
  }
  
  body.home-page .result-table td:nth-child(2) p {
    font-size: 0.85rem !important;
    margin-bottom: 0.75rem !important;
  }

  body.home-page .result-table td:nth-child(2) ul {
    padding-left: 1.15rem !important;
  }

  /* Card Footer: Action Button */
  body.home-page .result-table td:nth-child(3) {
    padding: 0 !important;
    border-bottom: none !important;
    text-align: left !important;
  }

  /* Make open button full-width with a great tap target */
  body.home-page .result-table td:nth-child(3) .btn-export {
    width: 100% !important;
    justify-content: center !important;
    padding: 0.7rem 1.25rem !important;
    font-size: 0.85rem !important;
    border-radius: 10px !important;
  }
}

@media (max-width: 600px) {
  /* Mirror Site Banner wrapping */
  body.home-page .mirror-container {
    flex-wrap: wrap !important;
    justify-content: center !important;
    gap: 0.4rem 0.65rem !important;
  }
  body.home-page .mirror-sep {
    opacity: 0.4 !important;
  }
}

@media (max-width: 540px) {
  /* Stack Hero Quick Access items vertically for full-width legibility */
  body.home-page .compact-hero-stats {
    flex-direction: column !important;
    gap: 0.5rem !important;
    width: 100% !important;
    min-width: 0 !important;
  }
  body.home-page .hero-stat-row {
    flex: none !important;
    width: 100% !important;
  }
  body.home-page .hero-stat-name {
    white-space: normal !important;
  }
}

@media (max-width: 480px) {
  /* Navbar adjustments */
  body.home-page .navbar {
    padding: 0 0.85rem !important;
  }
  body.home-page .nav-link {
    padding: 0.24rem 0.5rem !important;
    font-size: 0.8rem !important;
    gap: 0.25rem !important;
  }
  body.home-page .nav-contact-avatar {
    width: 22px !important;
    height: 22px !important;
  }
  body.home-page .theme-toggle {
    margin-left: 0.4rem !important;
    width: 26px !important;
    height: 26px !important;
  }
}

@media (max-width: 500px) {
  /* Centered Footer layout */
  body.home-page .footer {
    padding: 1.5rem 1rem !important;
  }
  body.home-page .footer-container {
    flex-direction: column !important;
    gap: 0.75rem !important;
    text-align: center !important;
    justify-content: center !important;
  }
}


