:root{--bg: #050816;--bg-elevated: #0b1020;--accent: #7b5cff;--accent-soft: rgba(101, 74, 224, .15);--accent-strong: #f97316;--border-subtle: rgba(255, 255, 255, .08);--text-main: #f9fafb;--text-muted: #9ca3af;--danger: #ef4444;--error-text: #b91c1c;--success: #22c55e;--radius-lg: 18px;--radius-md: 12px;--radius-pill: 999px;--shadow-soft: 0 22px 80px rgba(0, 0, 0, .7)}*,*:before,*:after{box-sizing:border-box}body{margin:0;font-family:system-ui,-apple-system,BlinkMacSystemFont,SF Pro Text,sans-serif;background:radial-gradient(circle at top,#111827,#020617 40%,#000);color:var(--text-main);min-height:100vh}a{color:inherit;text-decoration:none}.page-shell{height:100vh;display:flex;flex-direction:column;overflow:hidden}.landing-page-shell{min-height:100vh;min-height:100dvh;background-size:cover;background-position:center;background-repeat:no-repeat;background-attachment:fixed;background-color:var(--bg)}@media(max-width:768px){.landing-page-shell{background-attachment:scroll}}.page-title{font-size:1.5rem;font-weight:600;margin-bottom:.25rem}.page-subtitle{font-size:.9rem;color:var(--text-muted);margin-bottom:1.5rem}.layout-shell{display:flex;min-height:100vh}.sidebar{width:240px;flex-shrink:0;background:var(--bg-elevated);border-right:1px solid var(--border-subtle);padding:1.25rem 1rem;display:flex;flex-direction:column;justify-content:space-between}.sidebar .brand-logo,.sidebar .brand-logo-inner{width:200px;height:65px}.sidebar-section-label{font-size:.7rem;text-transform:uppercase;letter-spacing:.1em;color:var(--text-muted);margin-bottom:.5rem}.sidebar-nav{display:flex;flex-direction:column;gap:.25rem}.nav-link{display:block;padding:.5rem .75rem;min-height:42px;border-radius:var(--radius-md);font-size:.9rem;font-weight:600;color:#cbd5e1;transition:background .15s,color .15s}.nav-link:hover{background:#94a3b81f;color:var(--text-main)}.nav-link-active{background:#7b5cff33;color:var(--text-main)}.layout-main{flex:1;display:flex;flex-direction:column;min-height:0;min-width:0}.layout-header{position:relative;flex-shrink:0;display:flex;align-items:center;justify-content:flex-end;padding:.6rem 1.5rem .6rem 2rem;border-bottom:1px solid var(--border-subtle);background:var(--bg-elevated)}.layout-header-welcome{position:absolute;left:50%;transform:translate(-50%);max-width:min(55vw,28rem);text-align:center;font-size:.9rem;line-height:1.3;color:var(--text-muted);pointer-events:none;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.layout-header-welcome-prefix,.layout-header-welcome-code{color:var(--text-muted);font-weight:500}.layout-header-welcome-name{color:var(--text-main);font-weight:700}.layout-header-logout{display:inline-flex;align-items:center;gap:.4rem;padding:.4rem .75rem;min-height:40px;font-size:.8rem;border-color:#ef444480;color:#fca5a5}.layout-header-logout:hover{border-color:var(--danger);background:#ef44441f;color:#fecaca}.content-area{flex:1;display:flex;flex-direction:column;min-height:0;padding:1.5rem 2rem;overflow:auto}.app-footer{flex-shrink:0;padding:.6rem 1.5rem .6rem 2rem;border-top:1px solid var(--border-subtle);background:var(--bg-elevated);display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:.5rem 1rem;font-size:.72rem;color:var(--text-muted)}.app-footer-links{display:flex;align-items:center;flex-wrap:wrap;gap:.75rem 1.25rem}.app-footer-link{display:inline-flex;align-items:center;gap:.35rem;color:var(--text-muted);text-decoration:none;font-size:.72rem;transition:color .15s}.app-footer-link:hover{color:var(--accent)}.app-footer-copy,.app-footer-version{margin:0}.page-shell .app-footer{flex-direction:row;flex-wrap:wrap;justify-content:center;align-items:center;gap:.5rem 1.25rem;text-align:center}@media(max-width:1024px){.sidebar{width:210px;padding:1rem .8rem}.content-area{padding:1rem 1.15rem}.layout-header{padding:.55rem 1.15rem}}@media(max-width:768px){.layout-shell{flex-direction:column;min-height:100dvh}.sidebar{width:100%;border-right:none;border-bottom:1px solid var(--border-subtle);padding:.75rem .9rem .9rem;gap:.5rem}.sidebar .brand-logo,.sidebar .brand-logo-inner{width:170px;height:56px}.sidebar-nav{flex-direction:row;flex-wrap:nowrap;gap:.5rem;overflow-x:auto;overflow-y:hidden;padding-bottom:.2rem;-webkit-overflow-scrolling:touch;scrollbar-width:thin}.sidebar-nav .nav-link{flex:0 0 auto;white-space:nowrap;padding:.55rem .85rem}.layout-header{justify-content:space-between;align-items:flex-start;flex-wrap:wrap;gap:.55rem;padding:.65rem .9rem}.layout-header-welcome{position:static;transform:none;max-width:100%;text-align:left;order:1;white-space:normal;overflow:visible;text-overflow:unset;line-height:1.35}.layout-header-logout{order:2;margin-left:auto}.content-area{padding:.9rem}.app-footer{padding:.7rem .9rem;justify-content:center;text-align:center}.card{padding:.9rem}.table-scroll-wrap{width:100%;overflow-x:auto;-webkit-overflow-scrolling:touch}.table{min-width:640px}button,.button,.pill-button,input,select,textarea{font-size:16px}.top-nav{padding:.65rem 1rem;flex-wrap:wrap;gap:.5rem}.landing-main{padding:1rem;align-items:flex-start}.login-panel--glass{width:100%;max-width:min(380px,calc(100vw - 2rem))}input.search-input,.card-header input[type=text]{min-width:0;width:100%;max-width:100%}.view-details-table tr td:first-child{white-space:normal;min-width:0;width:auto}.select-fluid{max-width:100%}.reports-filter-row .field{flex:1 1 100%}.filter-row-actions{margin-left:0;width:100%}.filter-row-actions .pill-button{width:100%;justify-content:center}}@media(max-width:480px){.page-title{font-size:1.2rem}.page-subtitle{font-size:.82rem;margin-bottom:1rem}.card-header{gap:.55rem}.sidebar-nav .nav-link{font-size:.82rem;min-height:40px}}html{-webkit-text-size-adjust:100%}.select-fluid{width:100%;max-width:22rem;min-width:0;box-sizing:border-box}.find-student-row{display:flex;flex-wrap:wrap;gap:.75rem;align-items:flex-end;margin-top:.75rem}.find-student-row .field{flex:1 1 16rem;margin-bottom:0;min-width:0;max-width:100%}.search-user-detail-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:.5rem 1.5rem;font-size:.88rem}.search-stats-cards-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:1rem;margin-bottom:1.25rem}.course-modal-detail-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:.4rem 1.5rem;font-size:.85rem;margin-bottom:.75rem}.student-form-grid-4{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:.6rem}.reports-filter-row{display:flex;flex-wrap:wrap;margin-top:.75rem;align-items:flex-end;gap:.75rem}.reports-filter-row .field{margin-bottom:0;flex:1 1 12rem;min-width:0}.reports-filter-row .reports-checkbox-field{flex:0 0 auto;min-width:fit-content}.reports-filter-row .reports-checkbox-label{display:inline-flex;align-items:center;gap:.4rem;margin-bottom:0;white-space:nowrap}.reports-filter-row .reports-checkbox-label input[type=checkbox]{width:auto;margin:0}.reports-filter-row .reports-filter-break{flex-basis:100%;width:100%;height:0}.reports-filter-row-attendance{display:grid;grid-template-columns:minmax(240px,22rem) minmax(240px,22rem) auto;grid-template-areas:"reportType weekRange custom" "from to batchwise" "course batch actions";align-items:end;column-gap:.75rem;row-gap:.5rem;justify-content:start}.reports-filter-row-attendance .reports-attendance-report-type{grid-area:reportType}.reports-filter-row-attendance .reports-attendance-week-range{grid-area:weekRange}.reports-filter-row-attendance .reports-attendance-custom-checkbox{grid-area:custom}.reports-filter-row-attendance .reports-attendance-from{grid-area:from}.reports-filter-row-attendance .reports-attendance-to{grid-area:to}.reports-filter-row-attendance .reports-attendance-batchwise-checkbox{grid-area:batchwise}.reports-filter-row-attendance .reports-attendance-course{grid-area:course}.reports-filter-row-attendance .reports-attendance-batch{grid-area:batch}.reports-filter-row-attendance .reports-attendance-actions{grid-area:actions;margin-left:0;align-self:end}.reports-filter-row-attendance .reports-attendance-report-type,.reports-filter-row-attendance .reports-attendance-week-range,.reports-filter-row-attendance .reports-attendance-from,.reports-filter-row-attendance .reports-attendance-to{width:100%;min-width:0}.reports-filter-row-attendance .reports-attendance-from input,.reports-filter-row-attendance .reports-attendance-to input{width:100%;box-sizing:border-box}@media(max-width:980px){.reports-filter-row-attendance{grid-template-columns:1fr;grid-template-areas:"reportType" "weekRange" "custom" "batchwise" "from" "to" "course" "batch" "actions"}.reports-filter-row-attendance .reports-attendance-actions{justify-self:start}}.filter-row-actions{margin-left:auto;flex-shrink:0}.card-narrow{max-width:28rem;width:100%}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0f172ad9;display:flex;align-items:center;justify-content:center;z-index:40;padding:max(.75rem,env(safe-area-inset-top,0px)) max(.75rem,env(safe-area-inset-right,0px)) max(.75rem,env(safe-area-inset-bottom,0px)) max(.75rem,env(safe-area-inset-left,0px));overflow-y:auto;-webkit-overflow-scrolling:touch}.modal-overlay .card{width:min(920px,100%);max-width:100%}.modal-overlay-card-wide{width:min(900px,100%)!important;max-height:min(92vh,100dvh - 2rem);overflow:auto}.modal-overlay-card-form{width:min(720px,100%)!important;max-height:min(94vh,100dvh - 2rem);overflow:auto}.modal-overlay-card-narrow{width:min(560px,100%)!important;max-height:min(92vh,100dvh - 2rem);overflow:auto}.modal-overlay-card-sm{width:min(600px,100%)!important;max-height:min(90vh,100dvh - 2rem);overflow:auto}.modal-overlay-card-md{width:min(640px,100%)!important;max-height:min(90vh,100dvh - 2rem);overflow:auto}.modal-overlay-card-tall{width:min(900px,100%)!important;max-height:min(94vh,100dvh - 2rem);overflow:auto}@media(max-width:900px){.search-user-detail-grid,.course-modal-detail-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}@media(max-width:640px){.search-stats-cards-grid,.search-user-detail-grid,.student-form-grid-4,.course-modal-detail-grid{grid-template-columns:1fr}}.page-shell .app-footer-links{flex-shrink:0}.page-shell .app-footer-copy,.page-shell .app-footer-version{width:auto;flex-shrink:0}.brand-mark{display:flex;align-items:center;gap:.75rem}.brand-logo{width:200px;height:65px;border-radius:30%;background:none;display:flex;align-items:center;justify-content:center}.brand-logo-inner{width:200px;height:65px;border-radius:24%;overflow:hidden;background:none;display:flex;align-items:center;justify-content:center}.brand-logo-inner img{width:100%;height:100%;object-fit:contain}.brand-text-title{font-weight:650;font-size:.8rem;text-transform:uppercase;color:#e5e7eb}.top-nav .brand-text-title--landing-tagline{text-transform:none;letter-spacing:normal;font-weight:600;font-size:clamp(.8rem,2.2vw,1rem);line-height:1.35;max-width:min(100%,22rem)}.brand-text-sub{font-size:.72rem;color:var(--text-muted);letter-spacing:.16em;text-transform:uppercase}.pill-button{border-radius:var(--radius-pill);padding:.5rem 1.1rem;font-size:.8rem;border:2px solid rgba(148,163,184,.35);background:radial-gradient(circle at 10% -30%,#94a3b833,#0f172af2);color:var(--text-main);display:inline-flex;align-items:center;gap:.4rem;cursor:pointer;transition:border-color .15s,background .15s}.pill-button:hover{border-color:#94a3b880;background:radial-gradient(circle at 10% -30%,#94a3b847,#0f172afa)}.pill-button-primary{background:linear-gradient(135deg,#22c55e,#16a34a);border-color:transparent;color:#fff}.pill-button-primary:hover{background:linear-gradient(135deg,#16a34a,#15803d)}.pill-button-sm{padding:.35rem .75rem;font-size:.78rem}.pill-button-danger{border-color:#ef444499;color:#fca5a5}.pill-button-danger:hover{border-color:var(--danger);background:#ef444426}.export-icon-group{display:flex;align-items:center;gap:.35rem;flex-wrap:wrap}.export-icon-btn{display:inline-flex;align-items:center;justify-content:center;padding:.4rem;border-radius:var(--radius-md, 8px);border:1px solid rgba(148,163,184,.35);background:#0f172a99;cursor:pointer;line-height:0;transition:border-color .15s ease,background .15s ease,transform .1s ease}.export-icon-btn:hover:not(:disabled){border-color:#60a5fa8c;background:#1e293bd9;transform:translateY(-1px)}.export-icon-btn:disabled{opacity:.45;cursor:not-allowed}.export-icon-btn__img-wrap{display:flex;align-items:center;justify-content:center;line-height:0}.export-icon-btn__img{display:block;width:32px;height:32px;min-width:32px;min-height:32px;object-fit:contain;object-position:center;flex-shrink:0}.export-icon-btn--img .export-icon-btn__img{filter:drop-shadow(0 1px 1px rgba(0,0,0,.2))}[data-theme=light] .export-icon-btn--img .export-icon-btn__img{filter:drop-shadow(0 1px 2px rgba(15,23,42,.12))}.export-icon-btn__fallback{display:flex;align-items:center;justify-content:center;min-width:32px;min-height:32px;font-size:.72rem;font-weight:700;letter-spacing:.04em;color:var(--text-main);line-height:1}[data-theme=light] .export-icon-btn{background:#ffffffe6;border-color:#94a3b873}[data-theme=light] .export-icon-btn:hover:not(:disabled){background:#f1f5f9;border-color:#3b82f673}.card{background:#0f172ad9;border:1px solid rgba(148,163,184,.2);border-radius:var(--radius-lg);padding:1.25rem;margin-bottom:1rem}.card-header{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:.75rem;margin-bottom:1rem}.card-title{font-size:.98rem;font-weight:600;text-transform:capitalize}.table{width:100%;border-collapse:collapse;font-size:.8rem}.table th,.table td{padding:.5rem .65rem;border-bottom:1px solid rgba(31,41,55,.9);text-align:left}.table th{color:var(--text-muted);font-weight:500;font-size:.75rem}.table tbody tr:nth-child(2n){background:#94a3b80f}.table tbody tr:hover{background:#94a3b81f}.batch-status-yet-to-start{color:#fca5a5;font-weight:500}.batch-status-in-progress{color:#fcd34d;font-weight:500}.batch-status-completed{color:#86efac;font-weight:500}.batch-status-select-wrap{display:inline-block;border-radius:6px;border-left:3px solid transparent}.batch-status-select-wrap.batch-status-yet-to-start{border-left-color:#f87171}.batch-status-select-wrap.batch-status-in-progress{border-left-color:#fbbf24}.batch-status-select-wrap.batch-status-completed{border-left-color:#4ade80}select.inline-field.batch-status-yet-to-start{color:#fca5a5!important}select.inline-field.batch-status-in-progress{color:#fcd34d!important}select.inline-field.batch-status-completed{color:#86efac!important}.batch-status-yet-to-start option,.batch-status-in-progress option,.batch-status-completed option{background:var(--bg-card, #0f172a);color:inherit}.table-scroll-wrap .table thead th{position:sticky;top:0;z-index:1;background:#0f172af2;border-bottom:1px solid rgba(148,163,184,.3);box-shadow:0 1px #94a3b833}.batch-stats-by-course-table .batch-stat-course{color:var(--text-main);font-weight:500}.batch-stats-by-course-table .batch-stat-total{color:var(--accent);font-weight:700;font-size:.95rem}.batch-stats-by-course-table .batch-stat-in-progress{color:var(--accent);font-weight:600;font-size:.9rem}.batch-stats-by-course-table .batch-stat-completed{color:var(--success);font-weight:600;font-size:.9rem}.batch-stats-by-course-table .batch-stat-yet-to-start{color:var(--accent-strong);font-weight:600;font-size:.9rem}.batch-stats-by-course-table thead th:nth-child(1){color:var(--text-main);font-weight:600}.batch-stats-by-course-table thead th:nth-child(2){color:var(--accent);font-weight:600}.batch-stats-by-course-table thead th:nth-child(3){color:var(--accent);font-weight:600}.batch-stats-by-course-table thead th:nth-child(4){color:var(--success);font-weight:600}.batch-stats-by-course-table thead th:nth-child(5){color:var(--accent-strong);font-weight:600}.view-details-table{width:100%;border-collapse:collapse;font-size:.9rem;color:var(--text-main)}.view-details-table td{padding:.4rem .6rem .4rem 0;vertical-align:top;border:none}.view-details-table tr td:first-child{color:var(--text-muted);font-weight:500;white-space:nowrap;width:1%;min-width:10rem}.tag{display:inline-flex;align-items:center;gap:.25rem;border-radius:var(--radius-pill);padding:.1rem .5rem;font-size:.7rem;border:1px solid rgba(148,163,184,.6)}.tag-success{border-color:#22c55ee6;color:#bbf7d0}.tag-danger{border-color:#f87171e6;color:#fecaca}.tag-warning{border-color:#fbbf24e6;color:#fef3c7}.tag-mid{border-color:#f97316e6;color:#fed7aa}.grid-3{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:1rem}.field{margin-bottom:.5rem}.field label{display:block;font-size:.8rem;font-weight:500;color:var(--text-muted);margin-bottom:.25rem}.field input,.field select,.field textarea{width:100%;padding:.45rem .6rem;border-radius:8px;border:1px solid rgba(148,163,184,.4);background:#0f172af2;color:var(--text-main);font-size:.9rem;font-family:inherit}.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:#94a3b8b3}input.search-input,.card-header input[type=text]{min-width:220px;padding:.4rem .7rem;border-radius:8px;border:1px solid rgba(148,163,184,.4);background:#0f172af2;color:var(--text-main);font-size:.82rem;outline:none}input.search-input:focus,.card-header input[type=text]:focus{border-color:#94a3b8b3}.inline-field{font-size:.78rem;padding:.25rem .4rem;border-radius:6px;border:1px solid rgba(148,163,184,.4);background:#0f172af2;color:var(--text-main);outline:none}.inline-field:focus{border-color:#94a3b8b3}.metric-value{font-size:1.75rem;font-weight:700;color:var(--text-main)}.metric-label{font-size:.8rem;color:var(--text-muted);margin-top:.2rem}.metric-card{padding:.75rem;border-radius:var(--radius-md);border:1px solid rgba(148,163,184,.2);background:#0f172a99}.timer-badge{font-size:.78rem;padding:.25rem .6rem;border-radius:var(--radius-pill);background:#94a3b826;color:#e5e7eb}.progress-bar-outer{width:100%;height:6px;border-radius:var(--radius-pill);background:#1f2937f2;overflow:hidden}.progress-bar-inner{height:100%;border-radius:inherit;background:linear-gradient(90deg,#22c55e,#16a34a);transition:width .3s ease}.subtle-link{color:#93c5fd;text-decoration:none;font-size:.85rem}.subtle-link:hover{text-decoration:underline}.top-nav{display:flex;align-items:center;justify-content:space-between;padding:1rem 2rem;position:sticky;top:0;z-index:20;-webkit-backdrop-filter:blur(14px) saturate(1.2);backdrop-filter:blur(14px) saturate(1.2);background:#020617e0;border-bottom:1px solid rgba(148,163,184,.12)}.page-shell .top-nav{background:linear-gradient(180deg,#020617f0,#020617d1)}.top-nav .brand-mark{flex-shrink:0}.top-nav-cta{display:flex;gap:.75rem;flex-wrap:wrap;align-items:center}.theme-toggle{display:flex;align-items:center;gap:.35rem}.theme-toggle-btn{display:inline-flex;align-items:center;justify-content:center;width:2.25rem;height:2.25rem;padding:0}.theme-label{font-size:.8rem;color:var(--text-muted);margin-right:.25rem}.top-nav-cta .pill-button .dot{width:6px;height:6px;border-radius:50%;background:var(--success)}.landing-main{flex:1;min-height:0;display:flex;justify-content:center;align-items:center;padding:1.5rem}.landing-main--auth{position:relative;overflow:hidden}.landing-main__backdrop{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;z-index:0;background:radial-gradient(ellipse 85% 50% at 50% -15%,rgba(123,92,255,.38),transparent 58%),radial-gradient(ellipse 55% 45% at 100% 30%,rgba(239,68,68,.12),transparent 50%),radial-gradient(ellipse 45% 40% at 0% 70%,rgba(34,197,94,.14),transparent 48%),radial-gradient(ellipse 50% 42% at 92% 85%,rgba(56,189,248,.18),transparent 52%),radial-gradient(ellipse 40% 35% at 15% 90%,rgba(99,102,241,.15),transparent 45%)}.landing-main--auth>.login-panel{position:relative;z-index:1}.hero-copy{min-width:0;min-height:0;display:flex;flex-direction:column;overflow:hidden}.eyebrow{display:flex;flex-wrap:wrap;align-items:center;gap:.5rem 1rem;margin-bottom:.5rem;font-size:.85rem;color:var(--text-muted)}.eyebrow-pill{display:inline-block;padding:.25rem .6rem;border-radius:var(--radius-pill);background:#22c55e26;color:#86efac;font-size:.78rem;font-weight:500}.hero-title{font-size:clamp(1.5rem,3.5vw,2rem);font-weight:700;line-height:1.25;margin:0 0 .5rem;color:var(--text-main)}.hero-title .highlight{color:#22c55e}.hero-sub{font-size:.92rem;line-height:1.45;color:#cbd5e1;margin:0;max-width:540px}.hero-metrics{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem;margin-bottom:1.5rem}@media(max-width:600px){.hero-metrics{grid-template-columns:1fr}}.hero-news-panel{display:flex;flex-direction:column;gap:.75rem;margin-top:1rem;flex:1;min-height:0;overflow:hidden}.hero-login-aside{display:flex;flex-direction:column;align-items:stretch;position:sticky;top:5rem}@media(max-width:900px){.hero-login-aside{position:static}}.hero-news-header{display:flex;align-items:flex-start;justify-content:space-between;gap:.75rem;padding-bottom:.75rem;border-bottom:1px solid rgba(148,163,184,.2)}.pill-mini{flex-shrink:0;font-size:.7rem;padding:.2rem .5rem;border-radius:var(--radius-pill);background:#22c55e33;color:#86efac}.news-list{flex:1;min-height:0;overflow:hidden;position:relative}.news-list-inner{display:flex;flex-direction:column;gap:.75rem;animation:newsScroll 12s linear infinite}.news-list:hover .news-list-inner{animation-play-state:paused}.student-dashboard-page{display:flex;flex-direction:column;flex:1;min-height:0;max-height:100%}.student-dashboard-welcome{margin-bottom:.35rem;font-size:.9rem;color:var(--text-muted)}.student-dashboard-subtitle{margin:0 0 .6rem;font-size:.85rem}.student-dashboard-grid{display:grid;grid-template-columns:repeat(4,1fr);grid-template-rows:auto 1fr;gap:.65rem;flex:1;min-height:0}.student-dashboard-grid .card{margin-bottom:0;padding:.75rem 1rem}.student-dashboard-grid .card-title{margin-bottom:.15rem;font-size:.88rem}.student-dashboard-grid .card .pill-button-sm{margin-top:.3rem}.student-dashboard-stat-num{font-size:1.5rem;font-weight:700}.student-dashboard-stat-num-lg{font-size:1.65rem}@media(max-width:1000px){.student-dashboard-grid{grid-template-columns:1fr 1fr}}@media(max-width:520px){.student-dashboard-grid{grid-template-columns:1fr}}.student-dashboard-news-card{grid-column:1 / -1;flex:1;min-height:0;margin-bottom:0;padding:.75rem 1rem;display:flex;flex-direction:column}.student-dashboard-news-card-title{margin-bottom:.15rem;font-size:.88rem}.student-dashboard-news-card-desc{font-size:.75rem;color:var(--text-muted);margin:0 0 .5rem}.student-dashboard-news-actions{margin-top:.5rem;display:flex;gap:.5rem;flex-wrap:wrap}.student-dashboard-page .student-dashboard-news-list{max-height:160px;min-height:80px;flex:1}.student-dashboard-page .news-item{padding:.4rem 0}.student-attendance-page{display:flex;flex-direction:column;gap:1.25rem}.student-attendance-summary{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem}.student-attendance-card{padding:1.25rem;text-align:center;margin-bottom:0}.student-attendance-card-label{font-size:.8rem;font-weight:600;text-transform:uppercase;letter-spacing:.03em;color:var(--text-muted);margin-bottom:.5rem}.student-attendance-card-value{font-size:2.25rem;font-weight:700;line-height:1.2}.student-attendance-card-sublabel{font-size:.78rem;color:var(--text-muted);margin-top:.35rem}.student-attendance-card-present{border-left:4px solid var(--success)}.student-attendance-card-present .student-attendance-card-value{color:var(--success)}.student-attendance-card-absent{border-left:4px solid var(--danger)}.student-attendance-card-absent .student-attendance-card-value{color:var(--danger)}.student-attendance-card-total{border-left:4px solid var(--accent)}.student-attendance-card-total .student-attendance-card-value{color:var(--accent)}.student-attendance-records-card{display:flex;flex-direction:column;min-height:20rem;margin-bottom:0}.student-attendance-records-card .card-header{flex-shrink:0}.student-attendance-records-card .attendance-records-wrap{flex:1 1 0;min-height:0}@media(max-width:700px){.student-attendance-summary{grid-template-columns:1fr}}.hero-copy .hero-news-card{flex:1;min-height:0;display:flex;flex-direction:column;margin-top:1rem}.hero-copy .hero-news-card .student-dashboard-news-list{max-height:160px;min-height:80px;flex:1}.hero-copy .hero-news-card .news-item{padding:.4rem 0}@keyframes newsScroll{0%{transform:translateY(0)}to{transform:translateY(-50%)}}.news-item{display:flex;gap:.75rem;align-items:flex-start;padding:.6rem 0;border-bottom:1px solid rgba(148,163,184,.1)}.news-item:last-child{border-bottom:none}.news-dot{width:8px;height:8px;border-radius:50%;background:var(--success);flex-shrink:0;margin-top:.4rem}.news-content-title{font-size:.88rem;font-weight:500;color:var(--text-main);margin-bottom:.2rem}.news-content-meta{font-size:.78rem;color:var(--text-muted);line-height:1.4}.login-panel{padding:1.25rem;border-radius:var(--radius-lg);border:1px solid rgba(148,163,184,.25);background:#0f172ae6;width:100%;max-width:400px}.login-panel--glass{position:relative;isolation:isolate;max-width:380px;padding:2rem 1.85rem 1.65rem;border-radius:28px;background:linear-gradient(165deg,#ffffff1f,#1e293b85 45%,#0f172a7a);border:1px solid rgba(255,255,255,.22);box-shadow:0 8px 32px #00000052,0 24px 72px #0000007a,0 0 0 1px #ffffff1a inset,0 1px #ffffff29 inset;backdrop-filter:blur(22px) saturate(1.45);-webkit-backdrop-filter:blur(22px) saturate(1.45)}.login-panel--glass:before{content:"";position:absolute;top:0;left:0;right:0;height:42%;border-radius:28px 28px 0 0;background:linear-gradient(180deg,rgba(255,255,255,.16) 0%,transparent 100%);pointer-events:none;z-index:0}.login-panel-title{font-size:1rem;font-weight:600;margin-bottom:1rem;color:var(--text-main)}.landing-main .login-panel{flex-shrink:0}.field-grid{display:flex;flex-direction:column;gap:.75rem}.login-form--glass{text-align:center}.login-glass-avatar{width:76px;height:76px;margin:0 auto 1.1rem;border-radius:50%;background:#ffffff29;border:1px solid rgba(255,255,255,.3);display:flex;align-items:center;justify-content:center;color:#f8fafceb;box-shadow:0 4px 20px #00000026}.login-glass-title{margin:0 0 1.45rem;font-size:1.2rem;font-weight:600;letter-spacing:.04em;color:var(--text-main)}.login-glass-fields{display:flex;flex-direction:column;gap:1.25rem;text-align:left}.login-glass-field{display:flex;align-items:center;gap:.7rem;margin:0;padding-bottom:.4rem;border-bottom:1px solid rgba(255,255,255,.4);cursor:text;transition:border-color .2s ease}.login-glass-field:focus-within{border-bottom-color:#86efacd9}.login-glass-field--dropdown{cursor:default}.login-glass-field-icon{flex-shrink:0;display:flex;align-items:center;justify-content:center;color:#f8fafce0;opacity:.95}.login-glass-field input{flex:1;min-width:0;border:none;background:transparent;color:var(--text-main);font-size:.92rem;padding:.2rem 0;outline:none;font-family:inherit;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizeLegibility}.login-glass-field input::placeholder{color:#f8fafc85;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.login-user-type-dropdown{position:relative;flex:1;min-width:0}.login-user-type-trigger{display:flex;align-items:center;justify-content:space-between;gap:.5rem;width:100%;margin:0;padding:.2rem 0;border:none;background:transparent;color:var(--text-main);font-size:.92rem;font-weight:500;letter-spacing:.025em;line-height:1.4;font-family:inherit;text-align:left;cursor:pointer;outline:none;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizeLegibility;transition:color .2s ease,opacity .2s ease;border-radius:6px}.login-user-type-trigger:disabled{opacity:.55;cursor:not-allowed}.login-user-type-trigger:focus-visible{box-shadow:0 0 0 2px #4ade808c}.login-user-type-trigger-label{flex:1;min-width:0}.login-user-type-chevron{flex-shrink:0;display:flex;align-items:center;justify-content:center;color:#f8fafcb3;transition:transform .28s cubic-bezier(.34,1.2,.64,1),color .2s ease}.login-user-type-chevron.is-open{transform:rotate(180deg);color:#bbf7d0}.login-user-type-chevron-svg{display:block}.login-user-type-menu{position:absolute;left:0;right:0;top:calc(100% + 8px);z-index:40;margin:0;padding:.4rem;list-style:none;border-radius:14px;background:linear-gradient(180deg,#182a22f0,#0f1e18eb);border:1px solid rgba(134,239,172,.22);box-shadow:0 18px 40px #00000073,0 0 0 1px #bbf7d014 inset;backdrop-filter:blur(18px) saturate(1.2);-webkit-backdrop-filter:blur(18px) saturate(1.2);opacity:0;visibility:hidden;transform:translateY(-8px) scale(.98);transform-origin:top center;pointer-events:none;transition:opacity .26s cubic-bezier(.22,1,.36,1),transform .26s cubic-bezier(.22,1,.36,1),visibility .26s}.login-user-type-menu.is-open{opacity:1;visibility:visible;transform:translateY(0) scale(1);pointer-events:auto}.login-user-type-option{margin:0;padding:.58rem .75rem;border-radius:10px;font-size:.9rem;font-weight:500;letter-spacing:.02em;line-height:1.35;color:#f8fafceb;cursor:pointer;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizeLegibility;transition:background .18s ease,color .18s ease,transform .15s ease}.login-user-type-option:hover,.login-user-type-option.is-highlighted{background:#22c55e24;color:#fff}.login-user-type-option.is-selected{background:#22c55e4d;color:#fff}.login-user-type-option.is-selected.is-highlighted{background:#22c55e66}@media(prefers-reduced-motion:reduce){.login-user-type-menu{transition:opacity .15s ease,visibility .15s;transform:none}.login-user-type-menu.is-open{transform:none}.login-user-type-chevron{transition:color .15s ease}.login-user-type-chevron.is-open{transform:rotate(180deg)}}.login-glass-options{display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:.65rem 1rem;margin-top:1.1rem;text-align:left}.login-glass-remember{display:inline-flex;align-items:center;gap:.45rem;font-size:.8rem;color:#f8fafce0;cursor:pointer;-webkit-user-select:none;user-select:none}.login-glass-remember input{width:1rem;height:1rem;accent-color:var(--accent);cursor:pointer}.login-glass-forgot-wrap{flex:1;min-width:8rem;text-align:right}.login-glass-forgot{font-size:.76rem;font-style:italic;color:#f8fafcb8;line-height:1.35}.login-form-error{margin-top:.75rem;padding:.5rem .65rem;border-radius:var(--radius-md);font-size:.8rem;line-height:1.35;color:var(--error-text);background:#ef44441f;border:1px solid rgba(239,68,68,.28)}.login-form-error--glass{text-align:left}.login-glass-submit{width:100%;margin-top:1.45rem;padding:.82rem 1.5rem;border:none;border-radius:999px;font-size:.82rem;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:#fff;cursor:pointer;font-family:inherit;background:linear-gradient(90deg,#4ade80,#22c55e 42%,#15803d);box-shadow:0 4px 22px #22c55e61;transition:background .2s ease,box-shadow .2s ease,transform .15s ease}.login-glass-submit:hover:not(:disabled){background:linear-gradient(90deg,#22c55e,#16a34a 45%,#166534);box-shadow:0 6px 28px #22c55e73;transform:translateY(-1px)}.login-glass-submit:active:not(:disabled){transform:translateY(0)}.login-glass-submit:disabled{opacity:.65;cursor:not-allowed;transform:none}.login-glass-hint{margin:1.15rem 0 0;font-size:.7rem;line-height:1.45;color:#f8fafc94}@media(max-width:400px){.login-glass-options{flex-direction:column;align-items:stretch}.login-glass-forgot-wrap{text-align:left}}@media(prefers-reduced-transparency:reduce){.login-panel--glass{backdrop-filter:none;-webkit-backdrop-filter:none;background:linear-gradient(165deg,#334155,#1e293b 55%,#0f172a)}[data-theme=light] .login-panel--glass{background:#fff}.login-user-type-menu{backdrop-filter:none;-webkit-backdrop-filter:none;background:#12231cfa}[data-theme=light] .login-user-type-menu{background:#ecfdf5}}.student-profile-page{display:flex;flex-direction:column;flex:1;min-height:0;max-height:100%;gap:.5rem}.profile-page-header{flex-shrink:0;margin-bottom:0}.profile-page-header .page-title{margin:0 0 .15rem;font-size:1.35rem}.profile-page-header .page-subtitle{margin:0;font-size:.82rem;color:var(--text-muted);line-height:1.35}.profile-card{display:flex;flex:1;min-height:0;background:var(--bg-elevated);border:1px solid var(--border-subtle);border-radius:16px;overflow:hidden;box-shadow:0 4px 24px #0000000f,0 1px 3px #0000000a}.profile-sidebar{width:240px;flex-shrink:0;display:flex;flex-direction:column;align-items:center;padding:1.1rem 1rem;background:linear-gradient(180deg,rgba(56,189,248,.1) 0%,rgba(99,102,241,.04) 50%,transparent 100%);border-right:1px solid var(--border-subtle)}.profile-sidebar .profile-avatar-circle{width:96px;height:96px;border-radius:50%;overflow:hidden;background:linear-gradient(145deg,var(--accent) 0%,var(--accent-strong) 100%);display:flex;align-items:center;justify-content:center;border:3px solid rgba(255,255,255,.3);box-shadow:0 8px 24px #38bdf833}.profile-sidebar .profile-avatar-img{width:100%;height:100%;object-fit:cover}.profile-sidebar .profile-avatar-placeholder{font-size:1.75rem;font-weight:600;color:#fffffff2;letter-spacing:.02em}.profile-sidebar-name{font-size:1rem;font-weight:600;color:var(--text-main);margin:.5rem 0 .1rem;text-align:center;line-height:1.3}.profile-sidebar-code{font-size:.75rem;color:var(--text-muted);margin:0 0 .6rem;text-align:center}.profile-photo-input{position:absolute;width:0;height:0;opacity:0;pointer-events:none}.profile-sidebar .profile-upload-btn{margin-bottom:.35rem}.profile-sidebar .pill-button-primary{margin-bottom:.25rem}.profile-photo-error,.error-message,.validation-error{color:var(--error-text)}.profile-photo-error{font-size:.72rem;margin-top:.35rem;max-width:200px;text-align:center}.profile-main{flex:1;min-width:0;display:flex;flex-direction:column;padding:.9rem 1.25rem;gap:.65rem;overflow:hidden}.profile-section-card{padding:.65rem 1rem;background:#00000005;border:1px solid var(--border-subtle);border-radius:10px;flex-shrink:0}.profile-section-title{font-size:.68rem;font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:var(--accent);margin:0 0 .5rem;padding-left:.5rem;border-left:3px solid var(--accent)}.profile-fields{display:grid;grid-template-columns:1fr 1fr 1fr;gap:.5rem .85rem}.profile-fields-two-cols{grid-template-columns:1fr 1fr}.profile-field label{display:block;font-size:.72rem;font-weight:500;color:var(--text-muted);margin-bottom:.2rem}.profile-field input,.profile-field textarea{width:100%;padding:.4rem .6rem;font-size:.85rem;border:1px solid var(--border-subtle);border-radius:8px;background:var(--bg);color:var(--text-main);transition:border-color .2s ease,box-shadow .2s ease}.profile-field input:focus,.profile-field textarea:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px #38bdf81f}.profile-field input:disabled{opacity:.75;cursor:not-allowed;background:#00000008}.profile-field textarea{resize:vertical;min-height:48px}.profile-field-full{grid-column:1 / -1}.profile-actions{flex-shrink:0;padding-top:.35rem}.profile-actions .pill-button{min-width:120px;padding:.45rem 1rem;font-size:.85rem}@media(max-width:900px){.profile-card{flex-direction:column}.profile-sidebar{width:100%;flex-direction:row;flex-wrap:wrap;justify-content:center;gap:1rem;padding:1.25rem;border-right:none;border-bottom:1px solid var(--border-subtle)}.profile-sidebar .profile-avatar-circle{width:80px;height:80px}.profile-sidebar-name,.profile-sidebar-code{margin:0;text-align:left;width:100%}.profile-sidebar .profile-upload-btn,.profile-sidebar .pill-button-primary{margin:0}}@media(max-width:768px){.profile-fields{grid-template-columns:1fr 1fr}}@media(max-width:520px){.profile-fields,.profile-fields-two-cols{grid-template-columns:1fr}.profile-main{padding:1rem}}.take-test-option{text-align:left;border-radius:12px;padding:.35rem .6rem;border:1px solid var(--border-subtle);background:var(--bg-elevated);color:var(--text-main);font-size:.85rem;cursor:pointer}.take-test-option:hover{border-color:#94a3b880}.take-test-option.selected{border-color:#22c55ee6;background:#22c55e1f}[data-theme=light] .take-test-option.selected{background:#22c55e26}.take-test-option .option-letter{display:inline-flex;width:22px;height:22px;border-radius:999px;align-items:center;justify-content:center;font-size:.78rem;border:1px solid var(--text-muted);margin-right:8px;color:var(--text-main)}.take-test-nav{margin-top:1rem;display:flex;flex-wrap:wrap;justify-content:space-between;align-items:center;gap:.75rem}.take-test-nav-hint{font-size:.78rem;color:#9ca3af;flex:1 1 12rem;min-width:0;line-height:1.35}@media(max-width:520px){.take-test-option{min-height:44px;padding:.5rem .65rem}.take-test-nav{flex-direction:column;align-items:stretch}.take-test-nav .pill-button{width:100%;justify-content:center}.take-test-nav-hint{order:3;text-align:center;flex-basis:100%}}.assessment-review-page{max-width:52rem;margin:0 auto}.assessment-review-subtitle{margin-bottom:1rem}.assessment-review-muted{color:var(--text-muted);font-size:.9rem}.assessment-review-error-card{margin-top:.5rem}.assessment-review-header-card{margin-bottom:1rem}.assessment-review-header-top{display:flex;flex-wrap:wrap;align-items:flex-start;justify-content:space-between;gap:.75rem;margin-bottom:1rem}.assessment-review-assessment-name{margin-bottom:.25rem}.assessment-review-meta{font-size:.85rem;color:var(--text-muted)}.assessment-review-nav-pills{display:flex;flex-wrap:wrap;gap:.35rem}.assessment-review-pill{min-width:2.25rem;height:2.25rem;padding:0 .45rem;border-radius:8px;border:1px solid var(--border-subtle);background:var(--bg-elevated);color:var(--text-main);font-size:.8rem;font-weight:600;cursor:pointer;transition:border-color .15s ease,background .15s ease}.assessment-review-pill:hover{border-color:#60a5fa8c}.assessment-review-pill--active{border-color:#22c55ed9;background:#22c55e26;color:#86efac}.assessment-review-question-card{margin-bottom:1rem}.assessment-review-q-head{display:flex;flex-wrap:wrap;align-items:center;gap:.5rem;margin-bottom:.75rem}.assessment-review-q-label{font-size:.8rem;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.04em}.assessment-review-badge{font-size:.72rem;font-weight:700;padding:.2rem .5rem;border-radius:999px;text-transform:uppercase;letter-spacing:.03em}.assessment-review-badge--ok{background:#22c55e33;color:#86efac;border:1px solid rgba(34,197,94,.45)}.assessment-review-badge--bad{background:#ef444426;color:#fca5a5;border:1px solid rgba(239,68,68,.45)}.assessment-review-badge--warn{background:#fbbf241f;color:#fcd34d;border:1px solid rgba(251,191,36,.35)}.assessment-review-question-text{font-size:.95rem;line-height:1.5;color:var(--text-main);margin-bottom:1rem}.assessment-review-options{display:flex;flex-direction:column;gap:.5rem;margin-bottom:1.25rem}.assessment-review-option{display:flex;flex-direction:column;gap:.35rem;padding:.65rem .75rem;border-radius:10px;border:1px solid var(--border-subtle);background:#0f172a59}.assessment-review-option-main{display:flex;align-items:flex-start;gap:.5rem}.assessment-review-option-letter{flex-shrink:0;display:inline-flex;width:26px;height:26px;border-radius:8px;align-items:center;justify-content:center;font-size:.78rem;font-weight:700;border:1px solid var(--text-muted);color:var(--text-main)}.assessment-review-option-text{flex:1;font-size:.88rem;line-height:1.45;color:var(--text-main)}.assessment-review-option-badges{display:flex;flex-wrap:wrap;gap:.35rem;padding-left:calc(26px + .5rem)}.assessment-review-tag{font-size:.68rem;font-weight:700;padding:.15rem .45rem;border-radius:6px;text-transform:uppercase;letter-spacing:.04em}.assessment-review-tag--correct{background:#22c55e38;color:#86efac;border:1px solid rgba(34,197,94,.5)}.assessment-review-tag--wrong{background:#ef444433;color:#fca5a5;border:1px solid rgba(239,68,68,.5)}.assessment-review-option--correct{border-color:#22c55e8c;background:#22c55e1a}.assessment-review-option--wrong{border-color:#ef44448c;background:#ef444414}.assessment-review-option--selected-correct{box-shadow:0 0 0 1px #22c55e59}.assessment-review-subjective{margin-bottom:1.25rem;padding:.75rem;border-radius:10px;border:1px solid var(--border-subtle);background:#0f172a59}.assessment-review-summary-row{display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:.5rem;font-size:.88rem}.assessment-review-summary-label{font-weight:600;color:var(--text-muted);min-width:7rem}.assessment-review-summary-value{color:var(--text-main);flex:1}.assessment-review-summary-value--ok{color:#86efac;font-weight:600}.assessment-review-summary-value--bad{color:#fca5a5;font-weight:600}.assessment-review-explanation{padding-top:1rem;border-top:1px solid var(--border-subtle);margin-bottom:1rem}.assessment-review-explanation-label{font-weight:700;font-size:.85rem;color:var(--text-main);margin-bottom:.35rem}.assessment-review-explanation-body{font-size:.88rem;line-height:1.55;color:var(--text-muted);white-space:pre-wrap}.assessment-review-footer-nav{display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:.75rem}.assessment-review-footer-hint{font-size:.75rem;color:var(--text-muted);text-align:center;flex:1;min-width:10rem}@media(max-width:640px){.assessment-review-option-badges{padding-left:0}.assessment-review-footer-nav{flex-direction:column}.assessment-review-footer-hint{order:3}}[data-theme=light]{--bg: #f8fafc;--bg-elevated: #ffffff;--border-subtle: rgba(0, 0, 0, .08);--text-main: #020617;--text-muted: #334155}[data-theme=light] body{background:#f1f5f9;color:var(--text-main)}[data-theme=light] .page-title,[data-theme=light] .card-title,[data-theme=light] .login-panel-title{color:var(--text-main)}[data-theme=light] .page-subtitle{color:#334155}[data-theme=light] .sidebar{background:var(--bg-elevated);border-right-color:#e2e8f0}[data-theme=light] .nav-link{color:#1e293b}[data-theme=light] .nav-link:hover{background:#f1f5f9;color:var(--text-main)}[data-theme=light] .nav-link-active{background:#22c55e26;color:#15803d}[data-theme=light] .sidebar-section-label,[data-theme=light] .brand-text-sub{color:#334155}[data-theme=light] .brand-text-title{color:var(--text-main)}[data-theme=light] .layout-header-welcome-prefix,[data-theme=light] .layout-header-welcome-code{color:var(--text-muted)}[data-theme=light] .layout-header-welcome-name{color:var(--text-main)}[data-theme=light] .layout-header{border-bottom-color:#e2e8f0;background:#fff}[data-theme=light] .layout-header-logout{border-color:#fca5a5;color:#dc2626}[data-theme=light] .layout-header-logout:hover{background:#fef2f2;color:#991b1b;border-color:#dc2626}[data-theme=light] .content-area{background:#f1f5f9}[data-theme=light] .app-footer{border-top-color:#e2e8f0;background:#fff;color:#64748b}[data-theme=light] .app-footer-link{color:#64748b}[data-theme=light] .app-footer-link:hover{color:#16a34a}[data-theme=light] .card{background:var(--bg-elevated);border-color:#e2e8f0}.submit-track-form{margin-bottom:1rem;padding:1rem;border-radius:12px;border:1px solid var(--border-subtle);background:var(--bg)}[data-theme=light] .submit-track-form{background:#f1f5f9;border-color:#e2e8f0}[data-theme=light] .table th,[data-theme=light] .table td{border-bottom-color:#e2e8f0;color:#0f172a}[data-theme=light] .table th{color:#1e293b;font-weight:600}[data-theme=light] .table tbody tr:nth-child(2n){background:#f1f5f9b3}[data-theme=light] .table tbody tr:hover{background:#e2e8f099}[data-theme=light] .table-scroll-wrap .table thead th{background:var(--bg-elevated);border-bottom-color:#e2e8f0;box-shadow:0 1px #e2e8f0}[data-theme=light] .batch-status-yet-to-start{color:#dc2626}[data-theme=light] .batch-status-in-progress{color:#d97706}[data-theme=light] .batch-status-completed{color:#15803d}[data-theme=light] .batch-status-select-wrap.batch-status-yet-to-start{border-left-color:#dc2626}[data-theme=light] .batch-status-select-wrap.batch-status-in-progress{border-left-color:#d97706}[data-theme=light] .batch-status-select-wrap.batch-status-completed{border-left-color:#15803d}[data-theme=light] select.inline-field.batch-status-yet-to-start{color:#dc2626!important}[data-theme=light] select.inline-field.batch-status-in-progress{color:#d97706!important}[data-theme=light] select.inline-field.batch-status-completed{color:#15803d!important}[data-theme=light] .batch-stats-by-course-table .batch-stat-course{color:#0f172a}[data-theme=light] .batch-stats-by-course-table .batch-stat-total,[data-theme=light] .batch-stats-by-course-table .batch-stat-in-progress{color:#6366f1}[data-theme=light] .batch-stats-by-course-table .batch-stat-completed{color:#16a34a}[data-theme=light] .batch-stats-by-course-table .batch-stat-yet-to-start{color:#ea580c}[data-theme=light] .batch-stats-by-course-table thead th:nth-child(1){color:#0f172a}[data-theme=light] .batch-stats-by-course-table thead th:nth-child(2){color:#6366f1}[data-theme=light] .batch-stats-by-course-table thead th:nth-child(3){color:#6366f1}[data-theme=light] .batch-stats-by-course-table thead th:nth-child(4){color:#16a34a}[data-theme=light] .batch-stats-by-course-table thead th:nth-child(5){color:#ea580c}[data-theme=light] .view-details-table tr td:first-child{color:var(--text-muted)}[data-theme=light] .view-details-table{color:var(--text-main)}[data-theme=light] .pill-button{border-color:#cbd5e1;background:#fff;color:var(--text-main)}[data-theme=light] .pill-button:hover{border-color:#94a3b8;background:#f1f5f9;color:#020617}[data-theme=light] .pill-button-primary{background:linear-gradient(135deg,#22c55e,#16a34a);color:#fff;border-color:transparent}[data-theme=light] .pill-button-primary:hover{background:linear-gradient(135deg,#16a34a,#15803d);color:#fff}[data-theme=light] .pill-button-danger{border-color:#fca5a5;color:#dc2626}[data-theme=light] .pill-button-danger:hover{background:#fef2f2;color:#991b1b}[data-theme=light] .pill-button-soft{color:var(--text-main)}[data-theme=light] .pill-button-soft:hover{background:#f1f5f9;color:#020617}[data-theme=light] .field input,[data-theme=light] .field select,[data-theme=light] .field textarea{background:#fff;border-color:#e2e8f0;color:var(--text-main)}[data-theme=light] .field input:focus,[data-theme=light] .field select:focus,[data-theme=light] .field textarea:focus{border-color:#94a3b8}[data-theme=light] input.search-input,[data-theme=light] .card-header input[type=text]{background:#fff;border-color:#e2e8f0;color:var(--text-main)}[data-theme=light] input.search-input:focus,[data-theme=light] .card-header input[type=text]:focus{border-color:#94a3b8}[data-theme=light] .inline-field{background:#fff;border-color:#e2e8f0;color:#0f172a}[data-theme=light] .inline-field:focus{border-color:#94a3b8}[data-theme=light] .field label{color:#1e293b;font-weight:600}[data-theme=light] .tag{border-color:#cbd5e1}[data-theme=light] .tag-success{border-color:#86efac;color:#166534}[data-theme=light] .tag-danger{border-color:#fca5a5;color:#dc2626}[data-theme=light] .tag-warning{border-color:#fcd34d;color:#b45309}[data-theme=light] .metric-value{color:var(--text-main)}[data-theme=light] .metric-card{background:#fff;border-color:#e2e8f0}[data-theme=light] .timer-badge{background:#e2e8f0;color:#1e293b}[data-theme=light] .subtle-link{color:#2563eb}[data-theme=light] .subtle-link:hover{color:#1d4ed8}[data-theme=light] .top-nav{background:#fffffff2;border-bottom-color:#e2e8f0}[data-theme=light] .page-shell .top-nav{background:linear-gradient(180deg,#fff,#f8fafcf7)}[data-theme=light] .eyebrow{color:#334155}[data-theme=light] .eyebrow-pill{background:#22c55e33;color:#166534}[data-theme=light] .hero-title{color:var(--text-main)}[data-theme=light] .hero-title .highlight{color:#16a34a}[data-theme=light] .hero-sub{color:#1e293b}[data-theme=light] .hero-news-header{border-bottom-color:#e2e8f0}[data-theme=light] .hero-news-header div{color:var(--text-main)}[data-theme=light] .hero-news-header div div:last-child{color:var(--text-muted)!important}[data-theme=light] .pill-mini{background:#22c55e33;color:#166534}[data-theme=light] .news-content-title{color:var(--text-main)}[data-theme=light] .news-content-meta{color:#334155}[data-theme=light] .news-item{border-bottom-color:#e2e8f0}[data-theme=light] .news-list::-webkit-scrollbar-thumb{background:#64748b4d}[data-theme=light] .news-list::-webkit-scrollbar-thumb:hover{background:#64748b80}[data-theme=light] .login-panel{background:#fff;border-color:#e2e8f0}[data-theme=light] .landing-main__backdrop{background:radial-gradient(ellipse 90% 55% at 50% -18%,rgba(123,92,255,.14),transparent 55%),radial-gradient(ellipse 50% 42% at 92% 42%,rgba(34,197,94,.08),transparent 52%),radial-gradient(ellipse 48% 38% at 8% 88%,rgba(56,189,248,.08),transparent 50%)}[data-theme=light] .login-panel--glass{background:#ffffffbd;border-color:#ffffffeb;box-shadow:0 6px 24px #0f172a14,0 22px 64px #0f172a24,0 0 0 1px #ffffffa6 inset}[data-theme=light] .login-glass-avatar{background:#ffffffeb;border-color:#94a3b847;color:#64748b;box-shadow:0 4px 16px #0f172a0f}[data-theme=light] .login-glass-field{border-bottom-color:#0f172a2e}[data-theme=light] .login-glass-field:focus-within{border-bottom-color:#22c55e8c}[data-theme=light] .login-glass-field-icon{color:#475569}[data-theme=light] .login-glass-field input{color:var(--text-main)}[data-theme=light] .login-glass-field input::placeholder{color:#3341558c}[data-theme=light] .login-user-type-trigger{color:var(--text-main)}[data-theme=light] .login-user-type-trigger:focus-visible{box-shadow:0 0 0 2px #22c55e73}[data-theme=light] .login-user-type-chevron{color:#64748b}[data-theme=light] .login-user-type-chevron.is-open{color:#15803d}[data-theme=light] .login-user-type-menu{background:linear-gradient(180deg,#ecfdf5,#d1fae5);border-color:#22c55e47;box-shadow:0 18px 40px #0f172a14,0 0 0 1px #22c55e1f inset}[data-theme=light] .login-user-type-option{color:var(--text-main)}[data-theme=light] .login-user-type-option:hover,[data-theme=light] .login-user-type-option.is-highlighted{background:#22c55e24;color:var(--text-main)}[data-theme=light] .login-user-type-option.is-selected{background:#22c55e38;color:#14532d}[data-theme=light] .login-user-type-option.is-selected.is-highlighted{background:#22c55e4d}[data-theme=light] .login-glass-remember{color:var(--text-muted)}[data-theme=light] .login-glass-forgot,[data-theme=light] .login-glass-hint{color:#64748b}[data-theme=light] .login-form-error{background:#fef2f2;border-color:#fecaca;color:#b91c1c}[data-theme=light] .theme-label{color:var(--text-muted)}.course-batch-progress-dashboard{background:#0f172ad9;border:1px solid var(--border-subtle);border-radius:var(--radius-lg);padding:1.5rem;margin-bottom:1.5rem;box-shadow:var(--shadow-soft)}.current-week-attendance-section{display:flex;flex-direction:column;min-height:28rem}.current-week-attendance-section .course-batch-progress-dashboard-header{flex-shrink:0}.current-week-attendance-section .attendance-records-wrap{flex:1 1 0;min-height:0}.course-batch-progress-dashboard-header{margin-bottom:1.25rem}.course-batch-progress-dashboard-title-row{display:flex;flex-wrap:wrap;justify-content:space-between;align-items:flex-start;gap:1rem;margin-bottom:1rem}.course-batch-progress-dashboard-title{font-size:1.15rem;font-weight:600;margin:0 0 .35rem;color:var(--text-main)}.course-batch-progress-dashboard-subtitle{font-size:.875rem;color:var(--text-muted);margin:0}.course-batch-progress-dashboard-counts{display:flex;flex-wrap:wrap;gap:.75rem 1rem;align-items:center;font-size:.75rem;color:var(--text-muted)}.course-batch-progress-count{white-space:nowrap}.course-batch-progress-count strong{font-weight:600;color:var(--text-main)}.course-batch-progress-count-in-progress strong{color:#f97316}.course-batch-progress-count-completed strong{color:#22c55e}.course-batch-progress-count-yet-start strong{color:#ef4444}.course-batch-progress-dashboard-select-wrap{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap}.course-batch-progress-select-label{font-size:.875rem;font-weight:500;color:var(--text-muted);white-space:nowrap}.course-batch-progress-select{min-width:12rem;max-width:20rem;padding:.5rem .75rem;font-size:.9rem;background:var(--bg-elevated);border:1px solid var(--border-subtle);border-radius:var(--radius-md);color:var(--text-main);cursor:pointer;transition:border-color .2s,box-shadow .2s}.course-batch-progress-select:hover{border-color:#94a3b859}.course-batch-progress-select:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 2px #7b5cff40}.batch-progress-legend{display:flex;flex-wrap:wrap;gap:1rem;margin-bottom:1rem;font-size:.75rem;color:var(--text-muted)}.batch-progress-legend-item{display:inline-flex;align-items:center;gap:.4rem;padding:.25rem .6rem;border-radius:6px;color:var(--text-main);background:#ffffff0f}.batch-progress-legend-dot{width:10px;height:10px;border-radius:3px;flex-shrink:0}.batch-progress-loading,.batch-progress-empty{padding:2rem;text-align:center;font-size:.9rem;color:var(--text-muted)}.batch-progress-cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1.25rem}.batch-progress-card{background:var(--bg-elevated);border:1px solid var(--border-subtle);border-radius:var(--radius-md);padding:1.25rem;transition:box-shadow .2s ease,transform .2s ease,border-color .2s ease}.batch-progress-card:hover{box-shadow:0 8px 24px #00000059;border-color:#94a3b833}.batch-progress-card-header{display:flex;justify-content:space-between;align-items:flex-start;gap:.5rem;margin-bottom:.35rem}.batch-progress-card-title{font-size:1rem;font-weight:600;margin:0;color:var(--text-main);line-height:1.3}.batch-progress-card-pct{font-size:1.1rem;font-weight:700;color:var(--accent);flex-shrink:0}.batch-progress-card-meta{font-size:.8rem;color:var(--text-muted);margin-bottom:.75rem}.batch-progress-bar{display:flex;height:12px;border-radius:var(--radius-pill);overflow:visible;background:#94a3b826}.batch-progress-bar .batch-progress-segment:first-child{border-radius:var(--radius-pill) 0 0 var(--radius-pill)}.batch-progress-bar .batch-progress-segment:last-child{border-radius:0 var(--radius-pill) var(--radius-pill) 0}.batch-progress-bar-empty{width:100%;height:100%;font-size:.7rem;color:var(--text-muted);display:flex;align-items:center;justify-content:center;background:#94a3b81a}.batch-progress-segment{height:100%;transition:min-width .2s ease,opacity .2s ease;position:relative;cursor:pointer}.batch-progress-segment:hover{opacity:.95}.batch-progress-tooltip{position:absolute;left:50%;bottom:calc(100% + 10px);transform:translate(-50%);min-width:200px;max-width:280px;padding:.6rem .75rem;background:#0f172a;border:1px solid var(--border-subtle);border-radius:var(--radius-md);box-shadow:0 10px 40px #00000080;z-index:100;pointer-events:none;animation:batch-progress-tooltip-in .15s ease}@keyframes batch-progress-tooltip-in{0%{opacity:0;transform:translate(-50%) translateY(4px)}to{opacity:1;transform:translate(-50%) translateY(0)}}.batch-progress-tooltip-title{font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);margin-bottom:.4rem}.batch-progress-tooltip-list{list-style:none;margin:0;padding:0;font-size:.8rem}.batch-progress-tooltip-list li{padding:.25rem 0;border-bottom:1px solid rgba(255,255,255,.06);display:flex;flex-direction:column;gap:.1rem}.batch-progress-tooltip-list li:last-child{border-bottom:none}.batch-progress-tooltip-name{color:var(--text-main);font-weight:500}.batch-progress-tooltip-meta{font-size:.72rem;color:var(--text-muted)}.batch-progress-tooltip-pct{margin-top:.4rem;padding-top:.4rem;border-top:1px solid var(--border-subtle);font-size:.75rem;color:var(--text-muted)}@media(max-width:768px){.batch-progress-cards{grid-template-columns:1fr}.course-batch-progress-dashboard{padding:1rem}}[data-theme=light] .course-batch-progress-dashboard{background:var(--bg-elevated);border-color:#e2e8f0;box-shadow:0 1px 3px #00000014}[data-theme=light] .course-batch-progress-dashboard-title{color:var(--text-main)}[data-theme=light] .course-batch-progress-dashboard-subtitle,[data-theme=light] .course-batch-progress-select-label{color:var(--text-muted)}[data-theme=light] .course-batch-progress-select{background:#fff;border-color:#e2e8f0;color:var(--text-main)}[data-theme=light] .course-batch-progress-select:hover{border-color:#cbd5e1}[data-theme=light] .course-batch-progress-select:focus{border-color:var(--accent);box-shadow:0 0 0 2px #7b5cff33}[data-theme=light] .batch-progress-legend-item{color:var(--text-main);background:#f1f5f9}[data-theme=light] .batch-progress-loading,[data-theme=light] .batch-progress-empty{color:var(--text-muted)}[data-theme=light] .batch-progress-card{background:#fff;border-color:#e2e8f0}[data-theme=light] .batch-progress-card:hover{box-shadow:0 4px 12px #00000014;border-color:#cbd5e1}[data-theme=light] .batch-progress-card-title{color:var(--text-main)}[data-theme=light] .batch-progress-card-pct{color:var(--accent)}[data-theme=light] .batch-progress-card-meta{color:var(--text-muted)}[data-theme=light] .batch-progress-bar{background:#e2e8f0}[data-theme=light] .batch-progress-bar-empty{background:#f1f5f9;color:var(--text-muted)}[data-theme=light] .batch-progress-tooltip{background:#fff;border-color:#e2e8f0;box-shadow:0 10px 40px #0000001f}[data-theme=light] .batch-progress-tooltip-title{color:var(--text-muted)}[data-theme=light] .batch-progress-tooltip-name{color:var(--text-main)}[data-theme=light] .batch-progress-tooltip-meta{color:var(--text-muted)}[data-theme=light] .batch-progress-tooltip-list li{border-bottom-color:#e2e8f0}[data-theme=light] .batch-progress-tooltip-pct{border-top-color:#e2e8f0;color:var(--text-muted)}[data-theme=light] .course-batch-progress-dashboard-counts{color:var(--text-muted)}[data-theme=light] .course-batch-progress-count strong{color:var(--text-main)}[data-theme=light] .course-batch-progress-count-in-progress strong{color:#ea580c}[data-theme=light] .course-batch-progress-count-completed strong{color:#15803d}[data-theme=light] .course-batch-progress-count-yet-start strong{color:#dc2626}[data-theme=light] .assessment-review-pill--active{color:#15803d;background:#22c55e1f}[data-theme=light] .assessment-review-option,[data-theme=light] .assessment-review-subjective{background:#f8fafc}[data-theme=light] .assessment-review-badge--ok{color:#15803d;background:#22c55e1f}[data-theme=light] .assessment-review-badge--bad{color:#b91c1c;background:#ef44441a}[data-theme=light] .assessment-review-badge--warn{color:#b45309;background:#fbbf2426}[data-theme=light] .assessment-review-tag--correct{color:#15803d;background:#22c55e1f}[data-theme=light] .assessment-review-tag--wrong{color:#b91c1c;background:#ef44441a}[data-theme=light] .assessment-review-summary-value--ok{color:#15803d}[data-theme=light] .assessment-review-summary-value--bad{color:#b91c1c}.attendance-tooltip-wrap{position:relative;display:inline-block;cursor:help}.attendance-tooltip-wrap .attendance-tooltip-content{visibility:hidden;opacity:0;position:absolute;z-index:100;bottom:100%;left:50%;transform:translate(-50%) translateY(-6px);padding:.5rem .75rem;min-width:120px;max-width:280px;background:linear-gradient(135deg,#1e293b,#0f172a);color:#f1f5f9;font-size:.8rem;line-height:1.4;border-radius:10px;box-shadow:0 10px 40px #0006,0 0 0 1px #ffffff0f;white-space:normal;word-break:break-word;pointer-events:none;transition:opacity .2s ease,visibility .2s ease,transform .2s ease}.attendance-tooltip-wrap .attendance-tooltip-content:before{content:"";position:absolute;top:100%;left:50%;transform:translate(-50%);border:6px solid transparent;border-top-color:#1e293b}.attendance-tooltip-wrap .attendance-tooltip-label{display:block;font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:.04em;color:#94a3b8;margin-bottom:.25rem}.attendance-tooltip-wrap:hover .attendance-tooltip-content{visibility:visible;opacity:1;transform:translate(-50%) translateY(-8px)}[data-theme=light] .attendance-tooltip-wrap .attendance-tooltip-content{background:linear-gradient(135deg,#fff,#f8fafc);color:#0f172a;box-shadow:0 10px 40px #0000001f,0 0 0 1px #e2e8f0}[data-theme=light] .attendance-tooltip-wrap .attendance-tooltip-content:before{border-top-color:#f8fafc}.attendance-page{display:flex;flex-direction:column;flex:1;min-height:0;min-width:0}.attendance-page-top{flex-shrink:0}.attendance-form-row-1,.attendance-form-row-2,.attendance-form-metrics-row{align-items:start}.attendance-form-row-1 .field,.attendance-form-row-2 .field,.attendance-form-metrics-row .field{display:flex;flex-direction:column;margin-bottom:0;min-height:0}.attendance-form-row-1 .field .field-hint,.attendance-form-row-2 .field .field-hint,.attendance-form-metrics-row .field .field-hint,.attendance-form-row-1 .field .field-hint-spacer,.attendance-form-row-2 .field .field-hint-spacer,.attendance-form-metrics-row .field .field-hint-spacer{display:block;min-height:1.25rem;margin-top:.2rem}.attendance-form-row-1 .field label,.attendance-form-row-2 .field label,.attendance-form-metrics-row .field label{flex-shrink:0}.attendance-form-row-1 .field input,.attendance-form-row-1 .field select,.attendance-form-row-2 .field input:not([type=checkbox]),.attendance-form-row-2 .field select,.attendance-form-metrics-row .field input:not([type=checkbox]),.attendance-form-metrics-row .field select{flex-shrink:0;height:2.25rem;box-sizing:border-box}.attendance-form-row-1{display:grid;grid-template-columns:repeat(6,minmax(0,1fr));gap:.75rem 1rem}.attendance-form-row-2{display:flex;flex-wrap:wrap;gap:.75rem 1rem;margin-top:1rem;align-items:flex-end}.attendance-form-metrics-row{display:grid;grid-template-columns:repeat(3,minmax(0,1fr)) minmax(9.5rem,max-content) minmax(12rem,1.35fr);gap:.65rem .85rem;margin-top:1rem;align-items:start}.attendance-form-metrics-row .attendance-form-field-absent,.attendance-form-metrics-row .attendance-form-field-absent-ids,.attendance-form-metrics-row .attendance-form-field-pct,.attendance-form-field-comments,.attendance-form-holiday-field{min-width:0}.attendance-form-metrics-row .attendance-metrics-label{display:block;font-size:.8rem;font-weight:500;color:var(--text-muted);margin-bottom:.25rem;line-height:1.2;min-height:1rem}.attendance-holiday-inline{display:flex;align-items:center;gap:.5rem;min-height:2.25rem;box-sizing:border-box;padding:.15rem 0}.attendance-form-metrics-row .attendance-holiday-inline input[type=checkbox]{width:1.05rem;height:1.05rem;min-height:1.05rem;margin:0;flex-shrink:0;cursor:pointer;accent-color:var(--accent);padding:0}.attendance-form-metrics-row .attendance-holiday-inline-label{display:inline;margin-bottom:0;font-size:.9rem;font-weight:400;color:var(--text-main);line-height:1.2;cursor:pointer;-webkit-user-select:none;user-select:none}.attendance-form-metrics-row .attendance-comments-textarea{width:100%;min-height:4.1rem;height:4.1rem;max-height:9rem;resize:vertical;line-height:1.35;box-sizing:border-box;padding:.4rem .6rem;font-size:.9rem}.attendance-form-actions-bar{display:flex;flex-wrap:wrap;align-items:center;gap:.5rem;margin-top:1.25rem;padding-top:1rem;border-top:1px solid var(--border-subtle)}.attendance-form-actions{display:flex;align-items:flex-end;gap:.5rem;padding-bottom:.15rem}.attendance-form-row-2 .attendance-form-actions{align-self:flex-end}@media(max-width:1100px){.attendance-form-row-1{grid-template-columns:repeat(3,minmax(0,1fr))}}@media(max-width:1024px){.attendance-form-metrics-row{grid-template-columns:repeat(3,minmax(0,1fr)) minmax(0,max-content)}.attendance-form-metrics-row .attendance-form-field-comments{grid-column:1 / -1}}@media(max-width:560px){.attendance-form-row-1{grid-template-columns:1fr 1fr}.attendance-form-metrics-row{grid-template-columns:1fr}.attendance-form-metrics-row .attendance-form-field-comments{grid-column:auto}}.attendance-records-card{flex:1 1 0;min-height:28rem;margin-top:1rem;display:flex;flex-direction:column}.attendance-records-card .card-header{flex-shrink:0}.course-progress-grid-card{margin-bottom:0}.course-progress-grid-card .table{table-layout:fixed;width:100%}.course-progress-grid-card .table th,.course-progress-grid-card .table td{overflow-wrap:break-word;word-wrap:break-word;vertical-align:top}.attendance-records-wrap{flex:1 1 0;min-height:0;overflow-x:auto;overflow-y:auto;border:1px solid var(--border-subtle);border-radius:var(--radius-md)}.attendance-records-wrap .table{margin-bottom:0}.attendance-records-wrap .table thead th{position:sticky;top:0;background:var(--bg-elevated);z-index:1;box-shadow:0 1px 0 var(--border-subtle)}[data-theme=light] .attendance-records-wrap{border-color:#e2e8f0}[data-theme=light] .attendance-records-wrap .table thead th{background:#f8fafc;box-shadow:0 1px #e2e8f0}.reports-page{flex:1 1 auto;display:flex;flex-direction:column;min-height:0;min-width:0}.reports-page .reports-filters-card{flex-shrink:0;margin-bottom:1.5rem}.report-results-land-root{flex:1 1 auto;display:flex;flex-direction:column;min-height:0;min-width:0}.report-results-card{display:flex;flex-direction:column;flex:1 1 auto;min-height:28rem;margin-bottom:0}.report-results-card .card-header{flex-shrink:0}.report-results-card .attendance-records-wrap{flex:1 1 0;min-height:0}.report-results-card .table{table-layout:fixed;width:100%}.report-results-card .table th,.report-results-card .table td{overflow-wrap:break-word;word-wrap:break-word;vertical-align:top}.student-reports-card{flex:1 1 auto;display:flex;flex-direction:column;min-height:22rem;margin-bottom:0}.student-reports-card .card-title{flex-shrink:0}.student-reports-table-wrap{flex:1 1 0;min-height:0;overflow:auto;border:1px solid var(--border-subtle);border-radius:var(--radius-md);margin-top:.75rem}.student-reports-card .table{table-layout:fixed;width:100%}.student-reports-card .table th,.student-reports-card .table td{overflow-wrap:break-word;word-wrap:break-word;vertical-align:top}.student-reports-table-wrap .table thead th{position:sticky;top:0;background:var(--bg-elevated);z-index:1;box-shadow:0 1px 0 var(--border-subtle)}[data-theme=light] .student-reports-table-wrap{border-color:#e2e8f0}[data-theme=light] .student-reports-table-wrap .table thead th{background:#f8fafc;box-shadow:0 1px #e2e8f0}.assignments-manage-table-wrap{overflow-x:auto;width:100%}.assignments-manage-card .assignments-manage-table{table-layout:fixed;width:100%;min-width:720px}.assignments-manage-card .assignments-manage-table th,.assignments-manage-card .assignments-manage-table td{word-wrap:break-word;overflow-wrap:break-word;vertical-align:top;box-sizing:border-box}.assignments-manage-card .assignments-manage-table .col-num{width:2.5rem;min-width:2.5rem;text-align:center;vertical-align:top}.assignments-manage-card .assignments-manage-table .col-name{width:14%;min-width:80px}.assignments-manage-card .assignments-manage-table .col-desc{width:28%;min-width:100px;max-width:320px}.assignments-manage-card .assignments-manage-table .col-course{width:14%;min-width:80px}.assignments-manage-card .assignments-manage-table .col-doc{width:10%;min-width:70px;white-space:nowrap}.assignments-manage-card .assignments-manage-table .col-status{width:8%;min-width:70px;white-space:nowrap}.assignments-manage-card .assignments-manage-table .col-actions{width:14%;min-width:180px}.assignments-actions-cell{display:flex;flex-wrap:wrap;align-items:center;gap:.35rem;width:100%;max-width:100%}.admin-dashboard-page .card.dashboard-card-land,.staff-dashboard-page .card.dashboard-card-land{box-shadow:0 1px #ffffff24 inset,0 2px 4px #0000001f,0 6px 16px #0f172a24,0 14px 36px #0f172a1a}.admin-dashboard-page .dashboard-card-land .course-batch-progress-dashboard,.staff-dashboard-page .dashboard-card-land .course-batch-progress-dashboard{box-shadow:0 1px #ffffff24 inset,0 2px 4px #0000001f,0 6px 16px #0f172a24,0 14px 36px #0f172a1a;margin-bottom:0}[data-theme=light] .admin-dashboard-page .card.dashboard-card-land,[data-theme=light] .staff-dashboard-page .card.dashboard-card-land,[data-theme=light] .admin-dashboard-page .dashboard-card-land .course-batch-progress-dashboard,[data-theme=light] .staff-dashboard-page .dashboard-card-land .course-batch-progress-dashboard{box-shadow:0 1px #fffffffa inset,0 2px 6px #0f172a0f,0 8px 24px #0f172a14,0 18px 48px #0f172a0f}@keyframes dashboard-card-land-in{0%{opacity:0;transform:translate3d(0,2rem,0)}to{opacity:1;transform:translateZ(0)}}.dashboard-cards-land>.dashboard-card-land{animation:dashboard-card-land-in 1.2s cubic-bezier(.22,1,.32,1) both}.dashboard-cards-land>.dashboard-card-land:nth-child(1){animation-delay:0ms}.dashboard-cards-land>.dashboard-card-land:nth-child(2){animation-delay:.14s}.dashboard-cards-land>.dashboard-card-land:nth-child(3){animation-delay:.28s}.dashboard-cards-land>.dashboard-card-land:nth-child(4){animation-delay:.42s}.dashboard-cards-land>.dashboard-card-land:nth-child(5){animation-delay:.56s}.dashboard-cards-land>.dashboard-card-land:nth-child(6){animation-delay:.7s}.dashboard-cards-land>.dashboard-card-land:nth-child(7){animation-delay:.84s}.dashboard-cards-land>.dashboard-card-land:nth-child(8){animation-delay:.98s}.dashboard-cards-land>.dashboard-card-land:nth-child(9){animation-delay:1.12s}.dashboard-cards-land>.dashboard-card-land:nth-child(10){animation-delay:1.26s}.dashboard-cards-land>.dashboard-card-land:nth-child(11){animation-delay:1.4s}.dashboard-cards-land>.dashboard-card-land:nth-child(12){animation-delay:1.54s}.landing-card-land{animation:dashboard-card-land-in 1.35s cubic-bezier(.22,1,.32,1) both}.landing-card-land--header{animation-delay:0ms}.landing-card-land--panel{animation-delay:.18s}.async-list-land>*,tbody.async-list-land>tr{animation:dashboard-card-land-in 1.15s cubic-bezier(.22,1,.32,1) both}.async-list-land>*:nth-child(1),tbody.async-list-land>tr:nth-child(1){animation-delay:0ms}.async-list-land>*:nth-child(2),tbody.async-list-land>tr:nth-child(2){animation-delay:.14s}.async-list-land>*:nth-child(3),tbody.async-list-land>tr:nth-child(3){animation-delay:.28s}.async-list-land>*:nth-child(4),tbody.async-list-land>tr:nth-child(4){animation-delay:.42s}.async-list-land>*:nth-child(5),tbody.async-list-land>tr:nth-child(5){animation-delay:.56s}.async-list-land>*:nth-child(6),tbody.async-list-land>tr:nth-child(6){animation-delay:.7s}.async-list-land>*:nth-child(7),tbody.async-list-land>tr:nth-child(7){animation-delay:.84s}.async-list-land>*:nth-child(8),tbody.async-list-land>tr:nth-child(8){animation-delay:.98s}.async-list-land>*:nth-child(9),tbody.async-list-land>tr:nth-child(9){animation-delay:1.12s}.async-list-land>*:nth-child(10),tbody.async-list-land>tr:nth-child(10){animation-delay:1.26s}.async-list-land>*:nth-child(11),tbody.async-list-land>tr:nth-child(11){animation-delay:1.4s}.async-list-land>*:nth-child(12),tbody.async-list-land>tr:nth-child(12){animation-delay:1.54s}.async-list-land>*:nth-child(n+13),tbody.async-list-land>tr:nth-child(n+13){animation-delay:1.68s}@media(prefers-reduced-motion:reduce){.dashboard-cards-land>.dashboard-card-land,.landing-card-land,.async-list-land>*,tbody.async-list-land>tr{animation:none!important;opacity:1!important;transform:none!important}}.performance-dashboard-page .performance-panel{background:transparent;border:none;box-shadow:none;padding:0;margin-bottom:.5rem}.performance-dashboard-page .performance-banner{background:linear-gradient(90deg,#22c55e24,#10b98114);border:1px solid rgba(34,197,94,.2);color:var(--text-main);font-size:.9rem;padding:.75rem 1rem}.performance-dashboard-page .performance-summary-card table{font-size:.82rem}.performance-main-grid{display:grid;grid-template-columns:minmax(0,2fr) minmax(280px,1fr);gap:1rem}.performance-left-stack,.performance-right-stack{display:grid;gap:1rem;align-content:start}.performance-overall-wrap{display:flex;gap:1rem;align-items:center;flex-wrap:wrap}.performance-inline-metrics{display:grid;gap:.5rem;flex:1;min-width:220px}.performance-inline-metric{display:flex;justify-content:space-between;align-items:center;padding:.45rem .6rem;border-radius:10px;background:#94a3b81f;font-size:.8rem}.performance-inline-metric strong{color:var(--accent-strong);font-size:.88rem}.performance-quick-stats{display:grid;gap:.55rem}.performance-quick-stats>div{display:flex;justify-content:space-between;align-items:center;padding:.5rem .6rem;border-radius:10px;background:#94a3b81f;font-size:.82rem}.performance-quick-stats strong{font-size:.9rem;color:var(--accent-strong)}@media(max-width:1050px){.performance-main-grid{grid-template-columns:1fr}}.overview-cards-row{display:grid;grid-template-columns:repeat(5,minmax(0,1fr));gap:.85rem;align-items:stretch}.overview-card{margin-bottom:0;border-top:4px solid var(--accent);display:flex;flex-direction:column;min-height:210px}.performance-dashboard-page .overview-cards-row>.overview-card:nth-child(1){background:linear-gradient(160deg,#bfdbfe8f,#dbeafe6b)}.performance-dashboard-page .overview-cards-row>.overview-card:nth-child(2){background:linear-gradient(160deg,#bbf7d08a,#dcfce766)}.performance-dashboard-page .overview-cards-row>.overview-card:nth-child(3){background:linear-gradient(160deg,#fde68a85,#fef3c761)}.performance-dashboard-page .overview-cards-row>.overview-card:nth-child(4){background:linear-gradient(160deg,#ddd6fe8f,#ede9fe6b)}.performance-dashboard-page .overview-cards-row>.overview-card:nth-child(5){background:linear-gradient(160deg,#fecaca85,#fee2e261)}.overview-card-head{display:flex;justify-content:space-between;align-items:center;gap:.5rem;margin-bottom:.4rem}.overview-primary-value{font-size:2rem;font-weight:700;line-height:1.1;color:var(--text-main)}.overview-card-students{border:1px solid rgba(147,197,253,.45);box-shadow:inset 0 0 0 2px #bfdbfe66,0 12px 24px #1e40af2e}.students-count-large{font-size:clamp(2.9rem,5.2vw,4.1rem);font-weight:800;text-align:center;color:#1d4ed8;letter-spacing:.02em;margin-top:.15rem}.overview-card-students .overview-muted-line{text-align:center}.courses-card-body{display:grid;grid-template-columns:auto 1fr;gap:.55rem;align-items:center;min-height:0}.courses-mini-ring{width:108px;height:108px;border-radius:50%;position:relative;display:grid;place-items:center;box-shadow:inset 0 0 0 1px #94a3b833}.courses-mini-ring:before{content:"";width:68px;height:68px;border-radius:50%;background:#f1f5f9e6;box-shadow:inset 0 0 10px #94a3b838}.courses-mini-ring>span{position:absolute;font-size:.62rem;font-weight:700;color:#0f172a}.courses-metrics>div{background:#f8fafc73}[data-theme=light] .students-count-large{color:#1e3a8a}[data-theme=light] .courses-mini-ring:before{background:#fff}.overview-muted-line{font-size:.76rem;color:var(--text-muted)}.overview-list{display:grid;gap:.45rem;margin-top:.2rem}.overview-list>div,.overview-list-row-simple{display:flex;justify-content:space-between;align-items:center;gap:.5rem;padding:.35rem .45rem;border-radius:8px;background:#94a3b81f;font-size:.78rem}.overview-list>div strong,.overview-list-row-simple strong{color:var(--accent-strong);font-size:.82rem}.performance-courses-card .course-count-total{color:#166534}.performance-courses-card .course-count-active{color:#86efac}.performance-courses-card .course-count-inactive{color:#ef4444}[data-theme=light] .performance-courses-card .course-count-total{color:#14532d}[data-theme=light] .performance-courses-card .course-count-active{color:#15803d}[data-theme=light] .performance-courses-card .course-count-inactive{color:#dc2626}.overview-scroll{display:grid;gap:.45rem;max-height:150px;overflow:auto;padding-right:.2rem}.overview-scroll-no-limit{max-height:none;overflow:visible;padding-right:0}.overview-list-row{padding:.4rem .45rem;border-radius:8px;background:#94a3b81f}.performance-batches-card{border:1px solid rgba(234,179,8,.48);box-shadow:inset 0 0 0 2px #fef08a57,0 12px 24px #78350f29}.performance-batches-card .overview-list-row{position:relative;border-radius:0;background:transparent;border-bottom:1px solid rgba(148,163,184,.38);padding:.3rem .1rem .42rem 0}.performance-batches-card .overview-list-row:last-child{border-bottom:none}.performance-batches-card .overview-list-title{font-size:.7rem;font-weight:400;color:#0b1324;letter-spacing:.01em;white-space:nowrap;max-width:98px;overflow:hidden;text-overflow:ellipsis}.performance-batches-card .overview-scroll{position:relative;padding-left:.12rem}.batches-row-main{display:grid;grid-template-columns:minmax(96px,.88fr) minmax(0,2fr);gap:.16rem;align-items:start}.batches-course-block{min-width:0}.batches-row-status{font-size:.68rem;color:#6b7280;margin-top:.05rem;max-width:88px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.batches-row-status.active{color:#16a34a;font-weight:500}.batches-row-status.inactive{color:#9ca3af}.batches-metrics-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:.18rem .32rem;margin-left:-.04rem}.batches-metric-cell{display:grid;gap:.14rem;font-size:.7rem;color:#111827}.batches-metric-cell span{white-space:nowrap}.batches-mini-track{height:4px;border-radius:999px;background:#9ca3af5c;overflow:hidden}.batches-mini-fill{height:100%;background:#9ca3af}.batches-mini-fill.active{background:#22c55e}.batches-mini-fill.muted{background:#6b7280}[data-theme=light] .batches-row-status{color:#475569}[data-theme=light] .performance-batches-card{border-color:#ca8a0459;box-shadow:inset 0 0 0 2px #fde68a47,0 10px 20px #78350f1a}.overview-list-title{font-size:.78rem;font-weight:600;color:var(--text-main)}.overview-list-meta{display:flex;flex-wrap:wrap;gap:.25rem .65rem;margin-top:.2rem;font-size:.72rem;color:var(--text-muted)}@media(max-width:1400px){.overview-cards-row{grid-template-columns:repeat(3,minmax(0,1fr))}}@media(max-width:960px){.overview-cards-row{grid-template-columns:repeat(2,minmax(0,1fr))}}@media(max-width:620px){.overview-cards-row{grid-template-columns:1fr}}.performance-dashboard-section{margin-top:.3rem}.performance-header-row{display:flex;justify-content:space-between;align-items:center;gap:.75rem;flex-wrap:wrap}.performance-course-radios{display:flex;flex-wrap:wrap;gap:.35rem .5rem;align-items:center;margin-top:.85rem}.performance-course-radio{display:inline-flex;align-items:center;gap:.25rem;font-size:.74rem;color:#e2e8f0;padding:.2rem .45rem;border-radius:999px;border:1px solid rgba(56,189,248,.25);background:linear-gradient(135deg,#1e293beb,#0f172aeb);transition:background .2s ease,border-color .2s ease,transform .2s ease}.performance-course-radio input{accent-color:#0ea5e9}.performance-course-radio:has(input:checked){background:linear-gradient(135deg,#0ea5e957,#22c55e47);border-color:#38bdf8bf;color:#f8fafc;transform:translateY(-1px)}.performance-dashboard-cards-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:.55rem;align-items:stretch}.performance-right-stack{display:grid;gap:.25rem;align-content:start;height:100%}.performance-dashboard-page .overview-card,.performance-dashboard-page .performance-batch-progress-card,.performance-dashboard-page .performance-assessment-card{background:linear-gradient(160deg,#ffffff12,#94a3b814);box-shadow:0 14px 26px #02061747,0 4px 10px #0f172a2e,inset 0 1px #ffffff3d;border:1px solid rgba(148,163,184,.25)}.performance-dashboard-page .overview-card:hover,.performance-dashboard-page .performance-batch-progress-card:hover,.performance-dashboard-page .performance-assessment-card:hover{transform:translateY(-2px);box-shadow:0 18px 32px #02061757,0 6px 12px #0f172a38,inset 0 1px #ffffff4d}.performance-batch-progress-card{border-top:4px solid #0ea5e9;height:100%;display:flex;flex-direction:column}.performance-batch-progress-head{display:flex;justify-content:space-between;align-items:center;gap:.75rem;margin-bottom:.3rem}.performance-batch-progress-table{display:grid;gap:.32rem;max-height:none;flex:1;min-height:0;overflow:auto;padding-right:.2rem;align-content:start}.performance-batch-progress-row{display:grid;grid-template-columns:minmax(170px,1.2fr) minmax(230px,2fr) 56px;gap:.65rem;align-items:center;padding:.4rem .45rem;border-radius:10px;background:#94a3b81f;box-shadow:0 8px 16px #0206172e,inset 0 1px #fff3}.performance-batch-progress-title{font-size:.78rem;font-weight:600;color:var(--text-main);text-shadow:0 1px 0 rgba(15,23,42,.35)}.performance-batch-progress-subtitle{font-size:.72rem;color:var(--text-muted);margin-top:.1rem}.performance-batch-progress-bar-wrap{display:grid;gap:.3rem}.performance-batch-progress-bar{height:9px;border-radius:999px;overflow:hidden;display:flex;background:#94a3b83d}.performance-batch-progress-seg{display:block;height:100%}.performance-batch-progress-seg.completed{background:#22c55e}.performance-batch-progress-seg.inprogress{background:#f97316}.performance-batch-progress-seg.yetstart{background:#ef4444}.performance-batch-progress-meta{display:flex;gap:.45rem;flex-wrap:wrap;font-size:.7rem;color:#cbd5e1}.performance-batch-progress-pct{font-weight:700;color:#0ea5e9;font-size:.86rem;text-align:right}.performance-assessment-card{border-top:4px solid #22c55e}.performance-assessment-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:.45rem;max-height:none;overflow:visible;padding-right:0}.performance-assessment-item{display:grid;gap:.26rem;justify-items:center;text-align:center;border-radius:10px;padding:.5rem .45rem;background:#94a3b81f;box-shadow:0 10px 18px #02061733,inset 0 1px #fff3}.performance-assessment-needle-gauge{width:146px;max-width:100%;height:86px;display:block}.performance-assessment-needle-line{stroke:#f8fafc;stroke-width:1.6;filter:drop-shadow(0 1px 2px rgba(15,23,42,.55))}.performance-assessment-needle-center{fill:#f8fafc;stroke:#0f172a;stroke-width:.8}.performance-assessment-needle-value{fill:#e2e8f0;font-size:13px;font-weight:700}.performance-assessment-name{font-size:.76rem;font-weight:600;color:#f8fafc;text-shadow:0 1px 0 rgba(15,23,42,.35)}.performance-assessment-meta{font-size:.7rem;color:#cbd5e1}.performance-class-days-card{border-top-color:#38bdf8;min-height:110px;padding-top:.55rem;padding-bottom:.55rem}.performance-certificates-card{max-width:none;width:100%;min-height:110px}.performance-kpi-row{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:.24rem}.performance-kpi-row .performance-class-days-card{min-height:118px}.performance-duration-value{margin-top:.2rem;font-size:2rem;font-weight:700;line-height:1.1;color:var(--text-main);word-break:break-word}.performance-kpi-note{margin-top:.2rem;font-size:.72rem;color:var(--text-muted)}.performance-class-days-title{font-size:.72rem;color:#e2e8f0}.performance-class-days-value{margin-top:.1rem;font-size:1.35rem;font-weight:800;line-height:1.1;color:#f8fafc}.performance-class-days-sub{margin-top:.12rem;font-size:.65rem;color:#cbd5e1}.performance-attendance-card{margin-top:.8rem;padding-top:.55rem;border-top:1px solid rgba(148,163,184,.25)}.performance-attendance-card-standalone{border-top-color:#38bdf8}.performance-top-attendance-card{border-top-color:#22c55e}.performance-top-attendance-grid{display:grid;gap:.38rem}.performance-top-attendance-head,.performance-top-attendance-row{display:grid;grid-template-columns:1.5fr .9fr 1fr;gap:.45rem;align-items:center;padding:.4rem .45rem;border-radius:9px;font-size:.74rem}.performance-top-attendance-head{background:#0ea5e933;color:#e2e8f0;font-weight:700}.performance-top-attendance-row{background:#94a3b81f;color:var(--text-main)}.performance-top-attendance-row strong{color:#22c55e}.attendance-line-chart-wrap{background:#94a3b81f;border-radius:10px;padding:.55rem .6rem .45rem;position:relative;box-shadow:0 10px 18px #02061733,inset 0 1px #fff3}.attendance-line-chart{width:100%;height:260px;display:block}.attendance-axis{stroke:#94a3b8b3;stroke-width:1}.attendance-grid-line{stroke:#94a3b838;stroke-width:1}.attendance-axis-text{fill:#cbd5e1;font-size:9px}.attendance-axis-title{fill:#e2e8f0;font-size:12px;font-weight:600}.attendance-line{fill:none;stroke:#38bdf8;stroke-width:2.5;filter:drop-shadow(0 3px 6px rgba(14,165,233,.35))}.attendance-dot{fill:#22c55e;stroke:#dcfce7;stroke-width:1}.attendance-point-value{fill:#e2e8f0;font-size:8px;font-weight:600}.attendance-line-footer{margin-top:.1rem;display:flex;justify-content:space-between;gap:.4rem;font-size:.7rem;color:#cbd5e1}.attendance-tooltip{position:absolute;top:10px;right:12px;min-width:90px;background:#0f172ae6;border:1px solid rgba(148,163,184,.35);border-radius:8px;padding:.28rem .45rem;color:#f8fafc;font-size:.7rem;box-shadow:0 10px 16px #02061759}[data-theme=light] .attendance-axis-text{fill:#475569}[data-theme=light] .performance-course-radio{background:linear-gradient(135deg,#dbeafef2,#f0f9fff2);border-color:#0e74904d;color:#0f172a}[data-theme=light] .performance-course-radio:has(input:checked){background:linear-gradient(135deg,#38bdf861,#10b98147);border-color:#0e74908c;color:#0b1324}[data-theme=light] .attendance-axis-title,[data-theme=light] .attendance-point-value{fill:#0f172a}[data-theme=light] .performance-dashboard-page .overview-card,[data-theme=light] .performance-dashboard-page .performance-batch-progress-card,[data-theme=light] .performance-dashboard-page .performance-assessment-card{background:linear-gradient(160deg,#fff,#f4f8ff);border:1px solid rgba(148,163,184,.26);box-shadow:0 12px 20px #0f172a1a,0 3px 8px #1e40af14,inset 0 1px #ffffffd9}[data-theme=light] .performance-batch-progress-row,[data-theme=light] .performance-assessment-item{background:linear-gradient(180deg,#f8fbff,#eef5ff);box-shadow:0 8px 14px #0f172a14,inset 0 1px #fffffff2}[data-theme=light] .performance-batch-progress-title,[data-theme=light] .performance-assessment-name{color:#0f172a;text-shadow:none}[data-theme=light] .performance-batch-progress-meta,[data-theme=light] .performance-assessment-meta{color:#475569}[data-theme=light] .performance-class-days-card{border-top-color:#0ea5e9}[data-theme=light] .performance-class-days-title,[data-theme=light] .performance-class-days-sub{color:#334155}[data-theme=light] .performance-class-days-value{color:#0f172a}[data-theme=light] .attendance-line-chart-wrap{background:linear-gradient(180deg,#f8fbff,#eef5ff);box-shadow:0 8px 14px #0f172a14,inset 0 1px #fffffff2}[data-theme=light] .performance-top-attendance-head{background:#38bdf838;color:#0f172a}[data-theme=light] .attendance-line-footer{color:#475569}[data-theme=light] .attendance-tooltip{background:#fffffff5;color:#0f172a;border-color:#94a3b866}[data-theme=light] .performance-assessment-needle-line{stroke:#0f172a}[data-theme=light] .performance-assessment-needle-center{fill:#0f172a;stroke:#e2e8f0}[data-theme=light] .performance-assessment-needle-value{fill:#0f172a}@media(max-width:960px){.performance-dashboard-cards-grid{grid-template-columns:1fr}}@media(max-width:760px){.performance-batch-progress-row{grid-template-columns:1fr}.performance-batch-progress-pct{text-align:left}.performance-assessment-grid{grid-template-columns:1fr}.performance-kpi-row{grid-template-columns:repeat(2,minmax(0,1fr))}}@media(max-width:560px){.performance-kpi-row{grid-template-columns:1fr}}
