.students-page{--students-blue: var(--brand-action, #1967d2);--students-blue-hover: var(--brand-action-hover, #1557b8);--students-text: #0f172a;--students-muted: #64748b;--students-border: #e2e8f0;--students-row-alt: #f8fafc;--students-green: #059669;--students-green-bg: #ecfdf5;--students-red: #dc2626;--students-red-bg: #fef2f2;max-width:100%;width:100%;min-width:0;box-sizing:border-box}.students-page__header{display:flex;flex-wrap:wrap;align-items:flex-start;justify-content:space-between;gap:1rem 1.5rem;margin-bottom:1.25rem}.students-page__header-left{display:flex;align-items:flex-start;gap:1rem;min-width:0}.students-page__icon{width:52px;height:52px;border-radius:50%;background:linear-gradient(145deg,#2563eb 0%,var(--students-blue) 100%);color:#fff;display:flex;align-items:center;justify-content:center;flex-shrink:0;box-shadow:0 4px 14px #1967d247}.students-page__title{margin:0 0 .35rem;font-size:1.65rem;font-weight:700;color:var(--students-text);letter-spacing:-.02em;line-height:1.2}.students-page__subtitle{margin:0;font-size:.9rem;color:var(--students-muted);line-height:1.5;max-width:40rem}.students-page__header-actions{display:flex;flex-wrap:wrap;align-items:center;gap:.5rem;flex-shrink:0}.students-page__import-btn{display:inline-flex;align-items:center;gap:.4rem;padding:.6rem 1.15rem;border:1px solid var(--students-blue);border-radius:var(--radius-pill, 999px);background:#fff;color:var(--students-blue);font-size:.875rem;font-weight:600;font-family:inherit;cursor:pointer;white-space:nowrap;box-shadow:none;transition:background .15s ease,border-color .15s ease}.students-page__import-btn:hover{background:#eff6ff;border-color:var(--students-blue-hover)}.students-page__card{background:#fff;border:1px solid var(--students-border);border-radius:14px;box-shadow:0 1px 3px #0f172a0f;overflow:hidden;width:100%;min-width:0}.students-page__filters{display:flex;flex-wrap:wrap;align-items:flex-end;gap:.85rem 1rem;padding:1rem 1.25rem;border-bottom:1px solid var(--students-border);background:#fafbfc;width:100%;min-width:0;box-sizing:border-box}.students-page__filter-field{display:flex;flex-direction:column;gap:.35rem;min-width:140px}.students-page__filter-field label{font-size:.72rem;font-weight:600;letter-spacing:.03em;text-transform:uppercase;color:var(--students-muted)}.students-page__filter-field select{padding:.5rem 2rem .5rem .75rem;border:1px solid var(--students-border);border-radius:10px;background:#fff;font-size:.88rem;color:var(--students-text);font-family:inherit;cursor:pointer;-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 24 24' fill='none' stroke='%2394a3b8' stroke-width='2'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right .6rem center}.students-page__filter-field select:disabled{opacity:.55;cursor:not-allowed}.students-page__search-field{flex:1 1 220px;min-width:200px;max-width:none}.students-page__search{display:flex;align-items:center;gap:.5rem;padding:.5rem .85rem;border:1px solid var(--students-border);border-radius:10px;background:#fff}.students-page__search input{flex:1;border:none;background:transparent;font-size:.88rem;color:var(--students-text);outline:none;min-width:0}.students-page__search input::placeholder{color:#94a3b8}.students-page__search svg{color:#94a3b8;flex-shrink:0}.students-page__clear-btn{margin-bottom:.05rem;color:var(--students-muted)}.students-page__clear-btn:hover:not(:disabled){color:var(--students-text)}.students-page__table-wrap{overflow-x:auto;width:100%;min-width:0;-webkit-overflow-scrolling:touch}.students-page__table{width:100%;min-width:1040px;border-collapse:collapse;font-size:.88rem;table-layout:auto}.students-page__table thead th{text-align:left;padding:.75rem 1rem;font-size:.72rem;font-weight:600;letter-spacing:.04em;text-transform:uppercase;color:var(--students-muted);background:#eef4fc;border-bottom:1px solid var(--students-border);white-space:nowrap}.students-page__th-sort{display:inline-flex;align-items:center;gap:.35rem;border:none;background:none;padding:0;font:inherit;color:inherit;letter-spacing:inherit;text-transform:inherit;cursor:pointer}.students-page__th-sort:hover{color:var(--students-text)}.students-page__table tbody td{padding:.85rem 1rem;color:var(--students-text);border-bottom:1px solid #f1f5f9;vertical-align:middle}.students-page__table tbody tr:nth-child(2n){background:var(--students-row-alt)}.students-page__table tbody tr:hover{background:#f1f5f9}.students-page__name-cell{display:flex;align-items:center;gap:.75rem;min-width:200px}.students-page__avatar{width:40px;height:40px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.75rem;font-weight:700;color:#fff;flex-shrink:0;letter-spacing:.02em}.students-page__avatar--blue{background:linear-gradient(145deg,#3b82f6,#2563eb)}.students-page__avatar--purple{background:linear-gradient(145deg,#a855f7,#7c3aed)}.students-page__avatar--green{background:linear-gradient(145deg,#22c55e,#059669)}.students-page__avatar--orange{background:linear-gradient(145deg,#f97316,#ea580c)}.students-page__avatar--teal{background:linear-gradient(145deg,#14b8a6,#0d9488)}.students-page__name-block{min-width:0}.students-page__name{display:block;font-weight:600;color:var(--students-text);line-height:1.3}.students-page__email{display:block;font-size:.78rem;color:var(--students-muted);line-height:1.35;margin-top:.1rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:min(240px,28vw)}.students-page__code{font-weight:500;color:var(--students-text)}.students-page__status{display:inline-flex;align-items:center;gap:.4rem;padding:.22rem .65rem;border-radius:999px;font-size:.78rem;font-weight:600}.students-page__status--active{background:var(--students-green-bg);color:var(--students-green)}.students-page__status--inactive{background:var(--students-red-bg);color:var(--students-red)}.students-page__status-dot{width:6px;height:6px;border-radius:50%;background:currentColor}.students-page__table thead th:last-child,.students-page__table tbody td:last-child{min-width:120px}.students-page__actions{display:flex;align-items:center;gap:.35rem;white-space:nowrap}.students-page__edit-btn{display:inline-flex;align-items:center;gap:.35rem;padding:.4rem .85rem;border:1px solid var(--students-blue);border-radius:var(--radius-pill, 999px);background:#fff;color:var(--students-blue);font-size:.8125rem;font-weight:600;font-family:inherit;cursor:pointer;transition:background .15s ease,border-color .15s ease}.students-page__edit-btn:hover{background:#eff6ff;border-color:var(--students-blue-hover)}.students-page__kebab{display:inline-flex;align-items:center;justify-content:center;width:32px;height:32px;padding:0;border:none;border-radius:8px;background:transparent;color:#94a3b8;cursor:pointer;transition:background .15s ease,color .15s ease}.students-page__kebab:hover{background:#f1f5f9;color:var(--students-text)}.students-page__empty{padding:2.5rem 1rem;text-align:center;color:var(--students-muted);font-size:.9rem}.students-page__footer{display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:.75rem;padding:.85rem 1.25rem;border-top:1px solid var(--students-border);font-size:.82rem;color:var(--students-muted)}.students-page__pagination{display:flex;align-items:center;gap:.35rem}.students-page__pagination button{min-width:32px;height:32px;padding:0 .5rem;border:1px solid var(--students-border);border-radius:var(--radius-pill, 999px);background:#fff;color:var(--students-muted);font-size:.85rem;font-weight:600;font-family:inherit;cursor:pointer;box-shadow:none;transition:border-color .15s,color .15s,background .15s}.students-page__pagination button:disabled{opacity:.4;cursor:not-allowed}.students-page__pagination button.is-current{background:var(--students-blue);border-color:var(--students-blue);color:#fff}.students-page__pagination button:not(:disabled):not(.is-current):hover{border-color:#cbd5e1;color:var(--students-text)}[data-theme=dark] .students-page__card{background:var(--bg-elevated);border-color:var(--border-subtle)}[data-theme=dark] .students-page__filters{background:#ffffff08}[data-theme=dark] .students-page__title,[data-theme=dark] .students-page__name,[data-theme=dark] .students-page__table tbody td{color:var(--text-main)}[data-theme=dark] .students-page__filter-field select,[data-theme=dark] .students-page__search{background:#ffffff0a;border-color:var(--border-subtle)}@media(max-width:768px){.students-page__header-actions{width:100%;justify-content:flex-start}.students-page__filters{flex-direction:column;align-items:stretch}.students-page__filter-field,.students-page__search-field{max-width:none;width:100%}}.assessments-page{--assess-blue: var(--brand-action, #1967d2);--assess-blue-hover: var(--brand-action-hover, #1557b8);--assess-text: #0f172a;--assess-muted: #64748b;--assess-border: #e2e8f0;--assess-row-alt: #f8fafc;--assess-green: #059669;--assess-green-bg: #ecfdf5;--assess-red: #dc2626;--assess-red-bg: #fef2f2;max-width:100%;width:100%}.assessments-page__land{animation:dashboard-card-land-in 1.05s cubic-bezier(.22,1,.32,1) both}.assessments-page__land--card{animation-duration:1.2s;animation-delay:.1s}.assessments-page__row-skeleton td{padding:.85rem 1rem;border-bottom:1px solid #f1f5f9}.assessments-page__skeleton-bar{display:block;height:.85rem;max-width:100%;border-radius:6px;background:linear-gradient(90deg,#e2e8f0,#f1f5f9,#e2e8f0 90%);background-size:200% 100%;animation:assessments-skeleton-shimmer 1.4s ease-in-out infinite}.assessments-page__row-skeleton:nth-child(1) .assessments-page__skeleton-bar{width:72%}.assessments-page__row-skeleton:nth-child(2) .assessments-page__skeleton-bar{width:58%}.assessments-page__row-skeleton:nth-child(3) .assessments-page__skeleton-bar{width:81%}.assessments-page__row-skeleton:nth-child(4) .assessments-page__skeleton-bar{width:64%}.assessments-page__row-skeleton:nth-child(5) .assessments-page__skeleton-bar{width:76%}@keyframes assessments-skeleton-shimmer{0%{background-position:100% 0}to{background-position:-100% 0}}@media(prefers-reduced-motion:reduce){.assessments-page__land{animation:none!important;opacity:1!important;transform:none!important}.assessments-page__skeleton-bar{animation:none;background:#e2e8f0}}.assessments-page__header{display:flex;flex-wrap:wrap;align-items:flex-start;gap:1rem;margin-bottom:1.25rem}.assessments-page__header-left{display:flex;align-items:flex-start;gap:1rem;min-width:0}.assessments-page__icon{width:52px;height:52px;border-radius:12px;background:#e8f0fb;color:var(--assess-blue);display:flex;align-items:center;justify-content:center;flex-shrink:0}.assessments-page__title{margin:0 0 .35rem;font-size:1.65rem;font-weight:700;color:var(--assess-text);letter-spacing:-.02em}.assessments-page__subtitle{margin:0;font-size:.9rem;color:var(--assess-muted);line-height:1.5;max-width:40rem}.assessments-page__card{background:#fff;border:1px solid var(--assess-border);border-radius:14px;box-shadow:0 1px 3px #0f172a0f;overflow:hidden}.assessments-page__card-head{display:flex;flex-wrap:wrap;align-items:flex-start;justify-content:space-between;gap:1rem;padding:1rem 1.25rem;border-bottom:1px solid var(--assess-border)}.assessments-page__card-title{display:flex;align-items:center;gap:.5rem;font-size:1rem;font-weight:700;color:var(--assess-text)}.assessments-page__card-title-icon{width:32px;height:32px;border-radius:8px;background:#eff6ff;color:var(--assess-blue);display:flex;align-items:center;justify-content:center}.assessments-page__card-actions{display:flex;flex-direction:column;align-items:flex-end;gap:.65rem;min-width:200px}.assessments-page__add-btn{white-space:nowrap}.assessments-page__search{display:flex;align-items:center;gap:.5rem;width:100%;max-width:260px;padding:.5rem .85rem;border:1px solid var(--assess-border);border-radius:10px;background:#f8fafc}.assessments-page__search input{flex:1;border:none;background:transparent;font-size:.88rem;color:var(--assess-text);outline:none;min-width:0}.assessments-page__search input::placeholder{color:#94a3b8}.assessments-page__search svg{color:#94a3b8;flex-shrink:0}.assessments-page__table-wrap{overflow-x:auto}.assessments-page__table{width:100%;min-width:1080px;border-collapse:collapse;font-size:.88rem}.assessments-page__table thead th{text-align:left;padding:.75rem 1rem;font-size:.68rem;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:var(--assess-muted);background:#f8fafc;border-bottom:1px solid var(--assess-border);white-space:nowrap}.assessments-page__th-sort{display:inline-flex;align-items:center;gap:.35rem;border:none;background:none;padding:0;font:inherit;color:inherit;letter-spacing:inherit;text-transform:inherit;cursor:pointer;white-space:nowrap}.assessments-page__th-sort:hover{color:var(--assess-text)}.assessments-page__table tbody td{padding:.9rem 1rem;color:var(--assess-text);border-bottom:1px solid #f1f5f9;vertical-align:middle}.assessments-page__table tbody tr:nth-child(2n){background:var(--assess-row-alt)}.assessments-page__table tbody tr:hover{background:#f1f5f9}.assessments-page__name-cell{display:flex;align-items:center;gap:.75rem;min-width:180px}.assessments-page__name-icon{width:36px;height:36px;border-radius:10px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.assessments-page__name-icon--blue{background:#eff6ff;color:#2563eb}.assessments-page__name-icon--purple{background:#f3e8ff;color:#7c3aed}.assessments-page__name-icon--green{background:#ecfdf5;color:#059669}.assessments-page__name-icon--orange{background:#fff7ed;color:#ea580c}.assessments-page__name-text{font-weight:600;color:var(--assess-text)}.assessments-page__duration-cell{display:inline-flex;align-items:center;gap:.35rem;color:var(--assess-muted);white-space:nowrap}.assessments-page__duration-cell svg{color:#94a3b8}.assessments-page__status{display:inline-flex;align-items:center;gap:.4rem;padding:.22rem .65rem;border-radius:999px;font-size:.78rem;font-weight:600}.assessments-page__status--active{background:var(--assess-green-bg);color:var(--assess-green)}.assessments-page__status--inactive{background:var(--assess-red-bg);color:var(--assess-red)}.assessments-page__status-dot{width:6px;height:6px;border-radius:50%;background:currentColor}.assessments-page__actions{display:flex;align-items:center;gap:.35rem;flex-wrap:nowrap;white-space:nowrap;min-width:220px}.assessments-page__table thead th:last-child,.assessments-page__table tbody td:last-child{min-width:220px}.assessments-page__action-btn{width:34px;height:34px;display:inline-flex;align-items:center;justify-content:center;border-radius:var(--radius-pill, 999px);border:1px solid var(--assess-border);background:#fff;cursor:pointer;transition:background .15s,border-color .15s}.assessments-page__action-btn--edit{color:var(--assess-blue)}.assessments-page__action-btn--edit:hover{background:#eff6ff;border-color:#bfdbfe}.assessments-page__action-btn--play{color:var(--assess-green)}.assessments-page__action-btn--play:hover{background:var(--assess-green-bg);border-color:#a7f3d0}.assessments-page__action-btn--danger{color:var(--assess-red)}.assessments-page__action-btn--danger:hover{background:var(--assess-red-bg);border-color:#fecaca}.assessments-page__add-questions-btn{padding:.45rem .95rem;border:none;border-radius:var(--radius-pill, 999px);background:var(--assess-blue);color:#fff;font-size:.8125rem;font-weight:600;font-family:inherit;white-space:nowrap;cursor:pointer;flex-shrink:0;box-shadow:none;transition:background .15s ease}.assessments-page__add-questions-btn:hover{background:var(--assess-blue-hover)}.assessments-page__empty{padding:2.5rem 1rem;text-align:center;color:var(--assess-muted);font-size:.9rem}.assessments-page__footer{display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:.75rem;padding:.85rem 1.25rem;border-top:1px solid var(--assess-border);font-size:.82rem;color:var(--assess-muted)}.assessments-page__pagination{display:flex;align-items:center;gap:.35rem}.assessments-page__pagination button{min-width:32px;height:32px;padding:0 .5rem;border:1px solid var(--assess-border);border-radius:var(--radius-pill, 999px);font-weight:600;font-family:inherit;box-shadow:none;background:#fff;color:var(--assess-muted);font-size:.85rem;cursor:pointer}.assessments-page__pagination button:disabled{opacity:.4;cursor:not-allowed}.assessments-page__pagination button.is-current{border-color:var(--assess-blue);color:var(--assess-blue);font-weight:600}[data-theme=dark] .assessments-page__card{background:var(--bg-elevated);border-color:var(--border-subtle)}[data-theme=dark] .assessments-page__title,[data-theme=dark] .assessments-page__name-text,[data-theme=dark] .assessments-page__table tbody td{color:var(--text-main)}[data-theme=dark] .assessments-page__search{background:#ffffff0a;border-color:var(--border-subtle)}@media(max-width:768px){.assessments-page__card-head{flex-direction:column}.assessments-page__card-actions{align-items:stretch;width:100%}.assessments-page__search{max-width:none}}.courses-page{--courses-blue: var(--brand-action, #1967d2);--courses-blue-hover: var(--brand-action-hover, #1557b8);--courses-text: #0f172a;--courses-muted: #64748b;--courses-border: #e2e8f0;--courses-row-alt: #f8fafc;--courses-green: #059669;--courses-green-bg: #ecfdf5;max-width:100%;width:100%;min-width:0;box-sizing:border-box}.courses-page__land{animation:dashboard-card-land-in 1.05s cubic-bezier(.22,1,.32,1) both}.courses-page__land--card{animation-duration:1.2s;animation-delay:.1s}.courses-page__row-skeleton td{padding:.85rem 1rem;border-bottom:1px solid #f1f5f9}.courses-page__skeleton-bar{display:block;height:.85rem;max-width:100%;border-radius:6px;background:linear-gradient(90deg,#e2e8f0,#f1f5f9,#e2e8f0 90%);background-size:200% 100%;animation:courses-skeleton-shimmer 1.4s ease-in-out infinite}.courses-page__row-skeleton:nth-child(1) .courses-page__skeleton-bar{width:72%}.courses-page__row-skeleton:nth-child(2) .courses-page__skeleton-bar{width:58%}.courses-page__row-skeleton:nth-child(3) .courses-page__skeleton-bar{width:81%}.courses-page__row-skeleton:nth-child(4) .courses-page__skeleton-bar{width:64%}.courses-page__row-skeleton:nth-child(5) .courses-page__skeleton-bar{width:76%}@keyframes courses-skeleton-shimmer{0%{background-position:100% 0}to{background-position:-100% 0}}@media(prefers-reduced-motion:reduce){.courses-page__land{animation:none!important;opacity:1!important;transform:none!important}.courses-page__skeleton-bar{animation:none;background:#e2e8f0}}.courses-page__header{display:flex;flex-wrap:wrap;align-items:flex-start;justify-content:space-between;gap:1rem 1.5rem;margin-bottom:1.25rem}.courses-page__header-left{display:flex;align-items:flex-start;gap:1rem;min-width:0}.courses-page__icon{width:52px;height:52px;border-radius:50%;background:linear-gradient(145deg,#2563eb,#1d5fb0);color:#fff;display:flex;align-items:center;justify-content:center;flex-shrink:0;box-shadow:0 4px 14px #1d5fb047}.courses-page__title{margin:0 0 .35rem;font-size:1.65rem;font-weight:700;color:var(--courses-text);letter-spacing:-.02em;line-height:1.2}.courses-page__subtitle{margin:0;font-size:.9rem;color:var(--courses-muted);line-height:1.5;max-width:36rem}.courses-page__add-btn{flex-shrink:0}.courses-page__card{background:#fff;border:1px solid var(--courses-border);border-radius:14px;box-shadow:0 1px 3px #0f172a0f;overflow:hidden;width:100%;min-width:0}.courses-page__toolbar{display:flex;flex-wrap:wrap;align-items:center;gap:.75rem;padding:1rem 1.25rem;border-bottom:1px solid var(--courses-border)}.courses-page__search{flex:1;min-width:200px;max-width:420px;display:flex;align-items:center;gap:.5rem;padding:.5rem .85rem;border:1px solid var(--courses-border);border-radius:10px;background:#f8fafc}.courses-page__search input{flex:1;border:none;background:transparent;font-size:.88rem;color:var(--courses-text);outline:none;min-width:0}.courses-page__search input::placeholder{color:#94a3b8}.courses-page__search svg{color:#94a3b8;flex-shrink:0}.courses-page__filter-wrap{position:relative}.courses-page__filter-btn{display:inline-flex;align-items:center;gap:.45rem;padding:.5rem 1rem;border:1px solid var(--courses-border);border-radius:var(--radius-pill, 999px);background:#fff;color:var(--courses-text);font-size:.875rem;font-weight:600;font-family:inherit;cursor:pointer;box-shadow:none;transition:border-color .15s,background .15s}.courses-page__filter-btn:hover{border-color:#cbd5e1;background:#f8fafc}.courses-page__filter-menu{position:absolute;top:calc(100% + .35rem);right:0;z-index:20;min-width:160px;padding:.35rem;border:1px solid var(--courses-border);border-radius:10px;background:#fff;box-shadow:0 10px 40px #0f172a1f}.courses-page__filter-menu button{display:block;width:100%;text-align:left;padding:.45rem .65rem;border:none;border-radius:6px;background:transparent;font-size:.85rem;color:var(--courses-text);cursor:pointer}.courses-page__filter-menu button:hover,.courses-page__filter-menu button.is-active{background:#eff6ff;color:var(--courses-blue)}.courses-page__table-wrap{overflow-x:auto;width:100%;min-width:0}.courses-page__table{width:100%;min-width:720px;border-collapse:collapse;font-size:.88rem;table-layout:auto}.courses-page__table thead th{text-align:left;padding:.75rem 1rem;font-size:.72rem;font-weight:600;letter-spacing:.04em;text-transform:uppercase;color:var(--courses-muted);background:#f8fafc;border-bottom:1px solid var(--courses-border);white-space:nowrap}.courses-page__th-sort{display:inline-flex;align-items:center;gap:.35rem;border:none;background:none;padding:0;font:inherit;color:inherit;letter-spacing:inherit;text-transform:inherit;cursor:pointer}.courses-page__th-sort:hover{color:var(--courses-text)}.courses-page__table tbody td{padding:.9rem 1rem;color:var(--courses-text);border-bottom:1px solid #f1f5f9;vertical-align:middle}.courses-page__table tbody tr:nth-child(2n){background:var(--courses-row-alt)}.courses-page__table tbody tr:hover{background:#f1f5f9}.courses-page__course-id-cell{display:inline-flex;align-items:center;gap:.55rem;min-width:0}.courses-page__course-id-icon{width:32px;height:32px;border-radius:8px;background:#e8f0fb;color:var(--courses-blue);display:flex;align-items:center;justify-content:center;flex-shrink:0}.courses-page__course-id{font-weight:600;color:var(--courses-text);letter-spacing:.01em}.courses-page__date-cell{display:inline-flex;align-items:center;gap:.4rem;color:var(--courses-muted);white-space:nowrap}.courses-page__date-cell svg{color:#94a3b8;flex-shrink:0}.courses-page__status{display:inline-flex;align-items:center;gap:.4rem;padding:.22rem .65rem;border-radius:999px;font-size:.78rem;font-weight:600}.courses-page__status--active{background:var(--courses-green-bg);color:var(--courses-green)}.courses-page__status--inactive{background:#fef2f2;color:#dc2626}.courses-page__status-dot{width:6px;height:6px;border-radius:50%;background:currentColor}.courses-page__actions{display:flex;align-items:center;gap:.4rem}.courses-page__action-btn{width:34px;height:34px;display:inline-flex;align-items:center;justify-content:center;border-radius:8px;border:1px solid var(--courses-border);background:#fff;color:var(--courses-blue);cursor:pointer;transition:background .15s,border-color .15s}.courses-page__action-btn:hover{background:#eff6ff;border-color:#bfdbfe}.courses-page__action-btn--view{color:var(--courses-blue)}.courses-page__action-btn--view:hover{background:#eff6ff;border-color:#bfdbfe}.courses-page__action-btn--danger{color:#dc2626}.courses-page__action-btn--danger:hover{background:#fef2f2;border-color:#fecaca}.courses-page__empty{padding:2.5rem 1rem;text-align:center;color:var(--courses-muted);font-size:.9rem}.courses-page__footer{display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:.75rem;padding:.85rem 1.25rem;border-top:1px solid var(--courses-border);font-size:.82rem;color:var(--courses-muted)}.courses-page__pagination{display:flex;align-items:center;gap:.35rem}.courses-page__pagination button{min-width:32px;height:32px;padding:0 .5rem;border:1px solid var(--courses-border);border-radius:var(--radius-pill, 999px);background:#fff;color:var(--courses-muted);font-size:.85rem;font-weight:600;font-family:inherit;cursor:pointer;box-shadow:none;transition:border-color .15s,color .15s}.courses-page__pagination button:disabled{opacity:.4;cursor:not-allowed}.courses-page__pagination button.is-current{border-color:var(--courses-blue);color:var(--courses-blue);font-weight:600}.courses-page__pagination button:not(:disabled):not(.is-current):hover{border-color:#cbd5e1;color:var(--courses-text)}[data-theme=dark] .courses-page__card{background:var(--bg-elevated);border-color:var(--border-subtle)}[data-theme=dark] .courses-page__title{color:var(--text-main)}[data-theme=dark] .courses-page__subtitle{color:var(--text-muted)}[data-theme=dark] .courses-page__search,[data-theme=dark] .courses-page__filter-btn{background:#ffffff0a;border-color:var(--border-subtle)}[data-theme=dark] .courses-page__table thead th{background:#ffffff0a}[data-theme=dark] .courses-page__table tbody tr:nth-child(2n){background:#ffffff05}[data-theme=dark] .courses-page__course-id-icon{background:#3b82f62e;color:#93c5fd}[data-theme=dark] .courses-page__course-id,[data-theme=dark] .courses-page__table tbody td{color:var(--text-main)}@media(max-width:768px){.courses-page__header{flex-direction:column}.courses-page__search{max-width:none;width:100%}}.batches-page{--batches-blue: var(--brand-action, #1967d2);--batches-blue-hover: var(--brand-action-hover, #1557b8);--batches-orange: #ea580c;--batches-text: #0f172a;--batches-muted: #64748b;--batches-border: #e2e8f0;--batches-row-alt: #f8fafc;--batches-green: #059669;--batches-green-bg: #ecfdf5;max-width:100%;width:100%;min-width:0;box-sizing:border-box}.batches-page__land{animation:dashboard-card-land-in 1.05s cubic-bezier(.22,1,.32,1) both}.batches-page__land--card{animation-duration:1.2s;animation-delay:.1s}.batches-page__row-skeleton td{padding:.85rem 1rem;border-bottom:1px solid #f1f5f9}.batches-page__skeleton-bar{display:block;height:.85rem;max-width:100%;border-radius:6px;background:linear-gradient(90deg,#e2e8f0,#f1f5f9,#e2e8f0 90%);background-size:200% 100%;animation:batches-skeleton-shimmer 1.4s ease-in-out infinite}.batches-page__row-skeleton:nth-child(1) .batches-page__skeleton-bar{width:72%}.batches-page__row-skeleton:nth-child(2) .batches-page__skeleton-bar{width:58%}.batches-page__row-skeleton:nth-child(3) .batches-page__skeleton-bar{width:81%}.batches-page__row-skeleton:nth-child(4) .batches-page__skeleton-bar{width:64%}.batches-page__row-skeleton:nth-child(5) .batches-page__skeleton-bar{width:76%}@keyframes batches-skeleton-shimmer{0%{background-position:100% 0}to{background-position:-100% 0}}@media(prefers-reduced-motion:reduce){.batches-page__land{animation:none!important;opacity:1!important;transform:none!important}.batches-page__skeleton-bar{animation:none;background:#e2e8f0}}.batches-page__header{display:flex;flex-wrap:wrap;align-items:flex-start;justify-content:space-between;gap:1rem;margin-bottom:1.25rem}.batches-page__header-left{display:flex;align-items:flex-start;gap:1rem;min-width:0}.batches-page__icon{width:52px;height:52px;border-radius:50%;background:linear-gradient(145deg,#2563eb,#1d5fb0);color:#fff;display:flex;align-items:center;justify-content:center;flex-shrink:0;box-shadow:0 4px 14px #1d5fb047}.batches-page__title{margin:0 0 .35rem;font-size:1.65rem;font-weight:700;color:var(--batches-text);letter-spacing:-.02em}.batches-page__subtitle{margin:0;font-size:.9rem;color:var(--batches-muted);line-height:1.5;max-width:32rem}.batches-page__card{background:#fff;border:1px solid var(--batches-border);border-radius:14px;box-shadow:0 1px 3px #0f172a0f;overflow:hidden;width:100%;min-width:0}.batches-page__toolbar{display:flex;flex-wrap:wrap;align-items:flex-end;justify-content:space-between;gap:1rem;padding:1rem 1.25rem;border-bottom:1px solid var(--batches-border)}.batches-page__filters{display:flex;flex-wrap:wrap;align-items:flex-end;gap:.75rem 1rem;flex:1;min-width:0}.batches-page__filters-label{display:inline-flex;align-items:center;gap:.4rem;font-size:.88rem;font-weight:600;color:var(--batches-text);padding-bottom:.45rem;white-space:nowrap}.batches-page__filter-field{display:flex;flex-direction:column;gap:.3rem;min-width:130px}.batches-page__filter-field label{font-size:.72rem;font-weight:600;color:var(--batches-muted);text-transform:uppercase;letter-spacing:.04em}.batches-page__filter-field select,.batches-page__filter-select{padding:.5rem 2rem .5rem .75rem;border:1px solid var(--batches-border);border-radius:6px;background:#fff;font-size:.85rem;font-weight:500;font-family:inherit;color:var(--batches-text);min-width:140px;cursor:pointer;-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%2394a3b8' stroke-width='2'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right .55rem center;box-shadow:0 1px 2px #0f172a0a;transition:border-color .2s ease,box-shadow .2s ease,background-color .2s ease}.batches-page__filter-field select:hover,.batches-page__filter-select:hover{border-color:#cbd5e1;background-color:#fafbfc}.batches-page__filter-field select:focus,.batches-page__filter-select:focus{outline:none;border-color:var(--batches-blue);box-shadow:0 0 0 3px #1967d21f}.batches-page__clear-btn{margin-bottom:.05rem;color:var(--batches-muted)}.batches-page__clear-btn:hover:not(:disabled){color:var(--batches-text)}.batches-page__clear-btn:disabled{opacity:.45;cursor:not-allowed}.batches-page__toolbar-actions{display:flex;flex-wrap:wrap;align-items:center;gap:.5rem;flex-shrink:0}.batches-page__add-btn{white-space:nowrap}.batches-page__table-wrap{overflow-x:auto;width:100%;min-width:0}.batches-page__table{width:100%;min-width:1020px;border-collapse:collapse;font-size:.86rem;table-layout:auto}.batches-page__table thead th{text-align:left;padding:.75rem 1rem;font-size:.7rem;font-weight:600;letter-spacing:.04em;text-transform:uppercase;color:var(--batches-muted);background:#f8fafc;border-bottom:1px solid var(--batches-border);white-space:nowrap}.batches-page__th-sort{display:inline-flex;align-items:center;gap:.35rem;border:none;background:none;padding:0;font:inherit;color:inherit;letter-spacing:inherit;text-transform:inherit;cursor:pointer}.batches-page__th-sort:hover{color:var(--batches-text)}.batches-page__table tbody td{padding:.85rem 1rem;color:var(--batches-text);border-bottom:1px solid #f1f5f9;vertical-align:middle}.batches-page__table tbody tr:nth-child(2n){background:var(--batches-row-alt)}.batches-page__table tbody tr:hover{background:#f1f5f9}.batches-page__batch-id-cell{display:inline-flex;align-items:center;gap:.55rem;min-width:0}.batches-page__batch-id-icon{width:32px;height:32px;border-radius:8px;background:#e8f0fb;color:var(--batches-blue);display:flex;align-items:center;justify-content:center;flex-shrink:0}.batches-page__batch-id{font-weight:600;color:var(--batches-text);letter-spacing:.01em}.batches-page__status-cell{display:inline-flex;align-items:center;gap:.25rem;flex-wrap:wrap}.batches-page__status-select{display:inline-flex;align-items:center;gap:.4rem;min-height:32px;padding:0 .5rem 0 .55rem;border-radius:6px;border:1px solid #e2e8f0;background:#fff;box-shadow:0 1px 2px #0f172a0d;transition:border-color .22s ease,background-color .22s ease,box-shadow .22s ease,color .22s ease}.batches-page__status-select:hover{border-color:#cbd5e1;box-shadow:0 2px 6px #0f172a0f}.batches-page__status-select:focus-within{border-color:var(--batches-blue);box-shadow:0 0 0 3px #1967d224}.batches-page__status-dot{width:7px;height:7px;border-radius:2px;flex-shrink:0;background:currentColor;transition:background-color .22s ease}.batches-page__status-select-input{border:none;background:transparent;font-size:.8125rem;font-weight:600;font-family:inherit;line-height:1.3;color:inherit;cursor:pointer;padding:.4rem 1.75rem .4rem 0;min-width:7.25rem;-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%2394a3b8' stroke-width='2'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right .15rem center;transition:color .22s ease}.batches-page__status-select-input:focus{outline:none}.batches-page__status-select--yet-to-start{color:#475569;border-color:#cbd5e1;background:#f8fafc}.batches-page__status-select--yet-to-start:hover{background:#f1f5f9;border-color:#94a3b8}.batches-page__status-select--in-progress{color:#c2410c;border-color:#fdba74;background:#fff7ed}.batches-page__status-select--in-progress:hover{background:#ffedd5;border-color:#fb923c}.batches-page__status-select--completed{color:#047857;border-color:#6ee7b7;background:#ecfdf5}.batches-page__status-select--completed:hover{background:#d1fae5;border-color:#34d399}.batches-page__status-pct{font-size:.8rem;font-weight:600;white-space:nowrap}.batches-page__status-pct--in-progress{color:var(--batches-orange)}.batches-page__status-pct--completed{color:var(--batches-green)}.batches-page__status-pct--yet-to-start{color:var(--batches-muted)}.batches-page__status-readonly{display:inline-flex;align-items:center;gap:.25rem;font-size:.82rem;font-weight:600}.batches-page__date-cell{display:inline-flex;align-items:center;gap:.35rem;color:var(--batches-muted);white-space:nowrap;font-size:.84rem}.batches-page__date-cell svg{color:#94a3b8;flex-shrink:0}.batches-page__active{display:inline-flex;align-items:center;gap:.4rem;padding:.22rem .65rem;border-radius:999px;font-size:.78rem;font-weight:600;background:var(--batches-green-bg);color:var(--batches-green)}.batches-page__active--inactive{background:#fef2f2;color:#dc2626}.batches-page__active-dot{width:6px;height:6px;border-radius:50%;background:currentColor}.batches-page__actions{display:flex;align-items:center;gap:.4rem}.batches-page__action-btn{width:34px;height:34px;display:inline-flex;align-items:center;justify-content:center;border-radius:8px;border:1px solid var(--batches-border);background:#fff;cursor:pointer;transition:background .15s,border-color .15s}.batches-page__action-btn--view{color:var(--batches-blue)}.batches-page__action-btn--view:hover{background:#eff6ff;border-color:#bfdbfe}.batches-page__action-btn--edit{color:var(--batches-orange)}.batches-page__action-btn--edit:hover{background:#fff7ed;border-color:#fed7aa}.batches-page__action-btn--danger{color:#dc2626}.batches-page__action-btn--danger:hover{background:#fef2f2;border-color:#fecaca}.batches-page__empty{padding:2.5rem 1rem;text-align:center;color:var(--batches-muted);font-size:.9rem}.batches-page__footer{display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:.75rem;padding:.85rem 1.25rem;border-top:1px solid var(--batches-border);font-size:.82rem;color:var(--batches-muted)}.batches-page__pagination{display:flex;align-items:center;gap:.35rem}.batches-page__pagination button{min-width:32px;height:32px;padding:0 .5rem;border:1px solid var(--batches-border);border-radius:var(--radius-pill, 999px);background:#fff;color:var(--batches-muted);font-size:.85rem;font-weight:600;font-family:inherit;cursor:pointer;box-shadow:none}.batches-page__pagination button:disabled{opacity:.4;cursor:not-allowed}.batches-page__pagination button.is-current{border-color:var(--batches-blue);color:var(--batches-blue);font-weight:600}[data-theme=dark] .batches-page__card{background:var(--bg-elevated);border-color:var(--border-subtle)}[data-theme=dark] .batches-page__batch-id-icon{background:#3b82f62e;color:#93c5fd}[data-theme=dark] .batches-page__title,[data-theme=dark] .batches-page__table tbody td,[data-theme=dark] .batches-page__batch-id{color:var(--text-main)}[data-theme=dark] .batches-page__filter-field select,[data-theme=dark] .batches-page__filter-select{background:#ffffff0a;border-color:var(--border-subtle)}[data-theme=dark] .batches-page__status-select--yet-to-start{background:#ffffff0f}[data-theme=dark] .batches-page__status-select--in-progress{background:#ea580c1f}[data-theme=dark] .batches-page__status-select--completed{background:#0596691f}@media(max-width:900px){.batches-page__toolbar{flex-direction:column;align-items:stretch}.batches-page__toolbar-actions{justify-content:flex-end}}.documents-page{--docs-blue: var(--brand-action, #1967d2);--docs-blue-hover: var(--brand-action-hover, #1557b8);--docs-text: #0f172a;--docs-muted: #64748b;--docs-border: #e2e8f0;--docs-row-alt: #f8fafc;--docs-red: #dc2626;--docs-red-bg: #fef2f2;max-width:100%;width:100%;min-width:0;box-sizing:border-box}.documents-page__land{animation:dashboard-card-land-in 1.05s cubic-bezier(.22,1,.32,1) both}.documents-page__land--card{animation-duration:1.2s;animation-delay:.1s}.documents-page__header{display:flex;flex-wrap:wrap;align-items:flex-start;justify-content:space-between;gap:1rem 1.5rem;margin-bottom:1.25rem}.documents-page__header-left{display:flex;align-items:flex-start;gap:1rem;min-width:0}.documents-page__icon{width:52px;height:52px;border-radius:50%;background:#e8f0fb;color:var(--docs-blue);display:flex;align-items:center;justify-content:center;flex-shrink:0}.documents-page__title{margin:0 0 .35rem;font-size:1.65rem;font-weight:700;color:var(--docs-text);letter-spacing:-.02em;line-height:1.2}.documents-page__subtitle{margin:0;font-size:.9rem;color:var(--docs-muted);line-height:1.5;max-width:36rem}.documents-page__upload-card{background:#fff;border:1px solid var(--docs-border);border-radius:12px;box-shadow:0 2px 12px #0f172a0d;padding:1rem 1.15rem 0;margin-bottom:1rem;width:100%;max-width:42rem}.documents-page__upload-header{display:flex;align-items:flex-start;gap:.65rem;margin-bottom:.9rem}.documents-page__upload-header-icon{width:36px;height:36px;border-radius:8px;background:#e8f0fb;color:var(--docs-blue);display:flex;align-items:center;justify-content:center;flex-shrink:0}.documents-page__upload-header-icon svg{width:18px;height:18px}.documents-page__upload-title{margin:0 0 .15rem;font-size:.95rem;font-weight:700;color:var(--docs-text);letter-spacing:-.01em}.documents-page__upload-subtitle{margin:0;font-size:.8rem;color:var(--docs-muted);line-height:1.4}.documents-page__upload-form{display:flex;flex-direction:column}.documents-page__upload-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:.75rem .85rem;margin-bottom:.65rem}.documents-page__upload-field--name,.documents-page__upload-field--description{min-width:0}.documents-page__upload-field--file{grid-column:1 / -1;min-width:0}.documents-page__upload-field--file .documents-page__formats-hint{margin-top:.4rem;margin-bottom:0}.documents-page__sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.documents-page__upload-field label{display:block;margin-bottom:.35rem;font-size:.8rem;font-weight:600;color:var(--docs-text)}.documents-page__required{color:var(--docs-red);font-weight:700}.documents-page__input-wrap{position:relative}.documents-page__input-wrap input{width:100%;box-sizing:border-box;padding:.5rem 2.25rem .5rem .7rem;border:1px solid var(--docs-border);border-radius:8px;font-size:.8125rem;font-family:inherit;color:var(--docs-text);background:#fff;transition:border-color .15s ease,box-shadow .15s ease}.documents-page__input-wrap input::placeholder{color:#94a3b8}.documents-page__input-wrap input:focus{outline:none;border-color:var(--docs-blue);box-shadow:0 0 0 3px #1967d21f}.documents-page__input-icon{position:absolute;right:.75rem;top:50%;transform:translateY(-50%);color:#94a3b8;display:flex;align-items:center;pointer-events:none}.documents-page__file-input-hidden{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.documents-page__dropzone{border:2px dashed rgba(25,103,210,.35);border-radius:8px;background:#f0f6ff;padding:1rem .85rem .9rem;text-align:center;cursor:pointer;transition:border-color .2s ease,background .2s ease,box-shadow .2s ease}.documents-page__dropzone:hover,.documents-page__dropzone--active{border-color:var(--docs-blue);background:#e8f1fc;box-shadow:0 0 0 3px #1967d214}.documents-page__dropzone:focus-visible{outline:2px solid var(--docs-blue);outline-offset:2px}.documents-page__dropzone-icon{width:40px;height:40px;margin:0 auto .5rem;border-radius:50%;background:#dce9fa;color:var(--docs-blue);display:flex;align-items:center;justify-content:center}.documents-page__dropzone-icon svg{width:20px;height:20px}.documents-page__dropzone-title{margin:0 0 .2rem;font-size:.82rem;font-weight:700;color:#1e3a5f}.documents-page__dropzone-or{margin:0 0 .5rem;font-size:.75rem;color:var(--docs-muted)}.documents-page__browse-btn{display:inline-flex;align-items:center;gap:.35rem;padding:.4rem .85rem;border-radius:var(--radius-pill, 999px);border:1px solid var(--docs-blue);background:#fff;color:var(--docs-blue);font-size:.8125rem;font-weight:600;font-family:inherit;cursor:pointer;transition:background .15s ease,color .15s ease,border-color .15s ease}.documents-page__browse-btn:hover{background:#e8f0fb}.documents-page__file-selected{margin:.5rem 0 0;font-size:.75rem;font-weight:600;color:var(--docs-blue);word-break:break-all}.documents-page__formats-hint{display:flex;align-items:flex-start;gap:.35rem;margin:.45rem 0 0;font-size:.72rem;color:var(--docs-muted);line-height:1.45}.documents-page__formats-hint svg{flex-shrink:0;margin-top:.1rem;color:#94a3b8}.documents-page__upload-error{margin:.5rem 0 0;font-size:.85rem;color:var(--error-text, #b91c1c)}.documents-page__upload-footer{display:flex;align-items:center;justify-content:space-between;gap:.65rem;margin-top:.75rem;padding:.75rem 0 1rem;border-top:1px solid var(--docs-border)}.documents-page__upload-footer .pill-button{padding:.5rem 1rem;font-size:.8125rem}.documents-page__btn-cancel{display:inline-flex;align-items:center;gap:.35rem;padding:.5rem .9rem;border-radius:var(--radius-pill, 999px);border:1px solid var(--docs-border);background:#fff;color:var(--docs-text);font-size:.8125rem;font-weight:600;font-family:inherit;cursor:pointer;transition:background .15s ease,border-color .15s ease}.documents-page__btn-cancel:hover:not(:disabled){background:#f8fafc;border-color:#cbd5e1}.documents-page__btn-cancel:disabled{opacity:.55;cursor:not-allowed}.documents-page__card{background:#fff;border:1px solid var(--docs-border);border-radius:14px;box-shadow:0 1px 3px #0f172a0f;overflow:hidden;width:100%;min-width:0}.documents-page__toolbar{display:flex;flex-wrap:wrap;align-items:center;justify-content:flex-end;gap:.65rem;padding:1rem 1.25rem;border-bottom:1px solid var(--docs-border);background:#fafbfc}.documents-page__search-form{display:flex;flex-wrap:wrap;align-items:center;gap:.5rem;flex:1;justify-content:flex-end;min-width:280px}.documents-page__search{flex:1;min-width:220px;max-width:520px;display:flex;align-items:center;gap:.5rem;padding:.5rem .85rem;border:1px solid var(--docs-border);border-radius:10px;background:#fff}.documents-page__search input{flex:1;border:none;background:transparent;font-size:.88rem;color:var(--docs-text);outline:none;min-width:0}.documents-page__search input::placeholder{color:#94a3b8}.documents-page__search svg{color:#94a3b8;flex-shrink:0}.documents-page__search-btn{flex-shrink:0}.documents-page__clear-btn{display:inline-flex;align-items:center;gap:.35rem;color:var(--docs-muted)}.documents-page__clear-btn:hover:not(:disabled){color:var(--docs-text)}.documents-page__table-wrap{overflow-x:auto;width:100%;min-width:0}.documents-page__table{width:100%;min-width:880px;border-collapse:collapse;font-size:.88rem}.documents-page__table thead th{text-align:left;padding:.75rem 1rem;font-size:.72rem;font-weight:600;letter-spacing:.04em;text-transform:uppercase;color:var(--docs-muted);background:#eef4fc;border-bottom:1px solid var(--docs-border);white-space:nowrap}.documents-page__th-sort{display:inline-flex;align-items:center;gap:.35rem;border:none;background:none;padding:0;font:inherit;color:inherit;letter-spacing:inherit;text-transform:inherit;cursor:pointer}.documents-page__th-sort:hover{color:var(--docs-text)}.documents-page__table tbody td{padding:.9rem 1rem;color:var(--docs-text);border-bottom:1px solid #f1f5f9;vertical-align:middle}.documents-page__table tbody tr:nth-child(2n){background:var(--docs-row-alt)}.documents-page__table tbody tr:hover{background:#f1f5f9}.documents-page__name-cell{display:flex;align-items:flex-start;gap:.75rem;min-width:220px;max-width:360px}.documents-page__file-icon{width:40px;height:40px;border-radius:8px;display:flex;align-items:center;justify-content:center;flex-shrink:0;font-size:.65rem;font-weight:800;letter-spacing:.02em;line-height:1}.documents-page__file-icon--pdf{background:#fef2f2;color:#dc2626;border:1px solid #fecaca}.documents-page__file-icon--excel{background:#ecfdf5;color:#059669;border:1px solid #a7f3d0}.documents-page__file-icon--image{background:#eff6ff;color:#2563eb;border:1px solid #bfdbfe}.documents-page__file-icon--text{background:#f8fafc;color:#475569;border:1px solid #e2e8f0}.documents-page__file-icon--generic{background:#eef2ff;color:#4f46e5;border:1px solid #c7d2fe}.documents-page__file-icon svg{width:20px;height:20px}.documents-page__name-block{min-width:0}.documents-page__doc-title{display:block;font-weight:600;color:var(--docs-text);line-height:1.35}.documents-page__doc-desc{margin-top:.2rem;font-size:.78rem;color:var(--docs-muted);line-height:1.4;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.documents-page__desc-cell{color:var(--docs-muted);font-size:.85rem;max-width:200px}.documents-page__file-link{display:inline-flex;align-items:center;gap:.35rem;color:var(--docs-blue);font-weight:500;text-decoration:none;word-break:break-all}.documents-page__file-link:hover{color:var(--docs-blue-hover);text-decoration:underline}.documents-page__file-link svg{flex-shrink:0;color:#94a3b8}.documents-page__uploaded{color:var(--docs-muted);white-space:nowrap;font-size:.85rem}.documents-page__actions{display:flex;align-items:center;gap:.4rem;flex-wrap:nowrap;white-space:nowrap}.documents-page__table thead th:last-child,.documents-page__table tbody td:last-child{min-width:200px}.documents-page__view-btn{display:inline-flex;align-items:center;gap:.35rem;padding:.4rem .75rem;border:1px solid var(--docs-blue);border-radius:6px;background:#fff;color:var(--docs-blue);font-size:.8125rem;font-weight:600;font-family:inherit;cursor:pointer;transition:background .15s ease,border-color .15s ease}.documents-page__view-btn:hover{background:#eff6ff;border-color:var(--docs-blue-hover)}.documents-page__download-btn{text-decoration:none;box-sizing:border-box}.documents-page__delete-btn{display:inline-flex;align-items:center;gap:.35rem;padding:.4rem .75rem;border:1px solid #fca5a5;border-radius:6px;background:#fff;color:var(--docs-red);font-size:.8125rem;font-weight:600;font-family:inherit;cursor:pointer;transition:background .15s ease,border-color .15s ease}.documents-page__delete-btn:hover{background:var(--docs-red-bg);border-color:#f87171}.documents-page__kebab{display:inline-flex;align-items:center;justify-content:center;width:32px;height:32px;padding:0;border:none;border-radius:6px;background:transparent;color:#94a3b8;cursor:pointer}.documents-page__kebab:hover{background:#f1f5f9;color:var(--docs-text)}.documents-page__empty{padding:2.5rem 1rem;text-align:center;color:var(--docs-muted);font-size:.9rem}.documents-page__footer{display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:.75rem;padding:.85rem 1.25rem;border-top:1px solid var(--docs-border);font-size:.82rem;color:var(--docs-muted)}.documents-page__pagination{display:flex;align-items:center;gap:.35rem}.documents-page__pagination button{min-width:32px;height:32px;padding:0 .5rem;border:1px solid var(--docs-border);border-radius:var(--radius-pill, 999px);background:#fff;color:var(--docs-muted);font-size:.85rem;font-weight:600;font-family:inherit;cursor:pointer;box-shadow:none;transition:border-color .15s,color .15s,background .15s}.documents-page__pagination button:disabled{opacity:.4;cursor:not-allowed}.documents-page__pagination button.is-current{background:var(--docs-blue);border-color:var(--docs-blue);color:#fff}.documents-page__pagination button:not(:disabled):not(.is-current):hover{border-color:#cbd5e1;color:var(--docs-text)}[data-theme=dark] .documents-page__card,[data-theme=dark] .documents-page__upload-card{background:var(--bg-elevated);border-color:var(--border-subtle)}[data-theme=dark] .documents-page__title,[data-theme=dark] .documents-page__doc-title,[data-theme=dark] .documents-page__table tbody td{color:var(--text-main)}[data-theme=dark] .documents-page__search,[data-theme=dark] .documents-page__toolbar{background:#ffffff0a;border-color:var(--border-subtle)}.documents-page__preview-modal{width:min(1140px,calc(100vw - 2rem))!important;max-width:100%}@media(max-width:768px){.documents-page__upload-card{max-width:100%}.documents-page__upload-grid{grid-template-columns:1fr}.documents-page__upload-footer{flex-direction:column-reverse;align-items:stretch}.documents-page__upload-footer .pill-button,.documents-page__btn-cancel{width:100%;justify-content:center}.documents-page__toolbar{flex-direction:column;align-items:stretch}.documents-page__search-form{max-width:none;justify-content:stretch}.documents-page__search{max-width:none}}.reports-page{--rp-blue: var(--brand-action, #1967d2);--rp-blue-hover: var(--brand-action-hover, #1557b8);--rp-purple: #7c3aed;--rp-purple-bg: #f5f3ff;--rp-text: #0f172a;--rp-muted: #64748b;--rp-border: #e2e8f0;--rp-error: #b91c1c;width:100%;max-width:100%;min-width:0;box-sizing:border-box;flex:1 1 auto;display:flex;flex-direction:column;min-height:0}.reports-page__header{margin-bottom:1.25rem}.reports-page__title{margin:0 0 .35rem;font-size:1.65rem;font-weight:700;color:var(--rp-text);letter-spacing:-.02em}.reports-page__subtitle{margin:0;font-size:.9rem;color:var(--rp-muted);line-height:1.5;max-width:40rem}.reports-page__card{flex-shrink:0;background:#fff;border:1px solid var(--rp-border);border-radius:14px;padding:1.35rem 1.5rem 1.5rem;box-shadow:0 1px 3px #0f172a0f;margin-bottom:1.25rem}.reports-page__card-head{display:flex;align-items:flex-start;gap:.85rem;margin-bottom:1rem}.reports-page__card-icon{width:40px;height:40px;border-radius:10px;background:var(--rp-purple-bg);color:var(--rp-purple);display:flex;align-items:center;justify-content:center;flex-shrink:0}.reports-page__card-title{margin:0 0 .25rem;font-size:1.05rem;font-weight:700;color:var(--rp-text)}.reports-page__card-desc{margin:0;font-size:.85rem;color:var(--rp-muted);line-height:1.45}.reports-page__divider{border:none;border-top:1px solid var(--rp-border);margin:0 0 1.25rem}.reports-page__form-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:1rem 1.15rem;align-items:end}.reports-form__field{min-width:0}.reports-form__label{display:block;font-size:.8rem;font-weight:600;color:var(--rp-text);margin-bottom:.4rem}.reports-form__required{color:var(--rp-error)}.reports-form__input-wrap{position:relative;display:flex;align-items:center}.reports-form__input-icon{position:absolute;left:.75rem;top:50%;transform:translateY(-50%);color:var(--rp-muted);display:flex;pointer-events:none;z-index:1}.reports-form__control{width:100%;min-height:42px;padding:.5rem .75rem .5rem 2.45rem;font-size:.88rem;font-family:inherit;color:var(--rp-text);background:#fff;border:1px solid var(--rp-border);border-radius:10px;box-sizing:border-box;transition:border-color .2s ease,box-shadow .2s ease}.reports-form__control:focus{outline:none;border-color:var(--rp-blue);box-shadow:0 0 0 3px #1967d21f}.reports-form__control:disabled{background:#f8fafc;color:var(--rp-muted);cursor:not-allowed}select.reports-form__control{-webkit-appearance:none;-moz-appearance:none;appearance:none;padding-right:2rem;cursor:pointer;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%2364748b' stroke-width='2'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right .75rem center}.reports-form__field--checkbox-inline{display:flex;align-items:flex-end;padding-bottom:.55rem}.reports-form__checkbox{display:inline-flex;align-items:center;gap:.45rem;font-size:.88rem;font-weight:600;color:var(--rp-text);cursor:pointer;margin:0;min-height:42px}.reports-form__checkbox input[type=checkbox]{width:1rem;height:1rem;margin:0;accent-color:var(--rp-blue);cursor:pointer}.reports-form__field--checks{align-self:end}.reports-form__checkbox-row{display:flex;flex-wrap:wrap;gap:.75rem 1.25rem;min-height:42px;align-items:center;padding:.35rem 0}.reports-form__checkbox-row .reports-form__checkbox{min-height:auto}.reports-form__error{margin:.75rem 0 0;font-size:.82rem;color:var(--rp-error)}.reports-page__form-actions{margin-top:1.25rem;padding-top:.25rem}.reports-page__submit-btn{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;min-width:140px;min-height:42px;padding:.55rem 1.25rem;font-size:.9rem;font-weight:600;font-family:inherit;color:#fff;background:var(--rp-blue);border:none;border-radius:10px;cursor:pointer;transition:background .2s ease}.reports-page__submit-btn:hover:not(:disabled){background:var(--rp-blue-hover)}.reports-page__submit-btn:disabled{opacity:.55;cursor:not-allowed}.reports-page__results{display:flex;flex-direction:column;flex:1 1 auto;min-height:22rem;height:28rem;background:#fff;border:1px solid var(--rp-border);border-radius:14px;box-shadow:0 1px 3px #0f172a0f;overflow:hidden}.reports-page__results-head{display:flex;align-items:center;justify-content:space-between;gap:1rem;flex-wrap:wrap;padding:1rem 1.25rem;border-bottom:1px solid var(--rp-border);flex-shrink:0}.reports-page__results-title{margin:0;font-size:1rem;font-weight:700;color:var(--rp-text)}.reports-page__results .attendance-records-wrap{flex:1 1 0;min-height:0;overflow:auto;padding:0 1.25rem 1rem}.reports-page__results .table{table-layout:fixed;width:100%}.reports-page__results .table th,.reports-page__results .table td{overflow-wrap:break-word;word-wrap:break-word;vertical-align:top}[data-theme=dark] .reports-page__card,[data-theme=dark] .reports-page__results{background:var(--bg-elevated);border-color:var(--border-subtle)}[data-theme=dark] .reports-page__title,[data-theme=dark] .reports-page__card-title,[data-theme=dark] .reports-page__results-title,[data-theme=dark] .reports-form__label{color:var(--text-main)}[data-theme=dark] .reports-form__control{background:var(--bg);border-color:var(--border-subtle);color:var(--text-main)}@media(max-width:1024px){.reports-page__form-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}@media(max-width:640px){.reports-page__form-grid{grid-template-columns:1fr}.reports-form__field--checkbox-inline{padding-bottom:0}}.student-search-page{--ss-blue: var(--brand-action, #1967d2);--ss-blue-hover: var(--brand-action-hover, #1557b8);--ss-purple: #7c3aed;--ss-purple-bg: #f5f3ff;--ss-orange: #ea580c;--ss-orange-bg: #fff7ed;--ss-green: #059669;--ss-green-bg: #ecfdf5;--ss-text: #0f172a;--ss-muted: #64748b;--ss-border: #e2e8f0;width:100%;max-width:100%;min-width:0;box-sizing:border-box}.student-search-page__header{display:flex;align-items:flex-start;justify-content:space-between;gap:1rem;margin-bottom:1.25rem}.student-search-page__header-copy{flex:1;min-width:0}.student-search-page__title{margin:0 0 .35rem;font-size:1.65rem;font-weight:700;color:var(--ss-text);letter-spacing:-.02em}.student-search-page__subtitle{margin:0;font-size:.9rem;color:var(--ss-muted);line-height:1.5;max-width:36rem}.student-search-page__hero-art{flex-shrink:0;width:120px;display:flex;align-items:center;justify-content:flex-end}.student-search-page__card{background:#fff;border:1px solid var(--ss-border);border-radius:14px;padding:1.25rem 1.5rem;margin-bottom:1.25rem;box-shadow:0 1px 3px #0f172a0f;min-width:0}.student-search-page__card-head{display:flex;align-items:flex-start;justify-content:space-between;gap:1rem;margin-bottom:1rem}.student-search-page__card-head-left{display:flex;align-items:flex-start;gap:.75rem;min-width:0}.student-search-page__card-icon{width:40px;height:40px;border-radius:10px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.student-search-page__card-icon--blue{background:#eff6ff;color:var(--ss-blue)}.student-search-page__card-icon--purple{background:var(--ss-purple-bg);color:var(--ss-purple)}.student-search-page__card-icon--green{background:var(--ss-green-bg);color:var(--ss-green)}.student-search-page__card-title{margin:0 0 .2rem;font-size:1.05rem;font-weight:700;color:var(--ss-text)}.student-search-page__card-desc{margin:0;font-size:.82rem;color:var(--ss-muted)}.student-search-page__search-row{display:flex;align-items:stretch;gap:.75rem;flex-wrap:wrap}.student-search-page__search-input-wrap{flex:1;min-width:200px;position:relative;display:flex;align-items:center}.student-search-page__search-input-icon{position:absolute;left:.85rem;color:var(--ss-muted);display:flex;pointer-events:none}.student-search-page__search-input{width:100%;min-height:44px;padding:.55rem 1rem .55rem 2.65rem;font-size:.9rem;font-family:inherit;border:1px solid var(--ss-border);border-radius:10px;color:var(--ss-text);background:#fff;box-sizing:border-box}.student-search-page__search-input:focus{outline:none;border-color:var(--ss-blue);box-shadow:0 0 0 3px #1967d21f}.student-search-page__search-btn{display:inline-flex;align-items:center;justify-content:center;gap:.45rem;min-height:44px;padding:0 1.25rem;font-size:.9rem;font-weight:600;font-family:inherit;color:#fff;background:var(--ss-blue);border:none;border-radius:10px;cursor:pointer;flex-shrink:0}.student-search-page__search-btn:hover:not(:disabled){background:var(--ss-blue-hover)}.student-search-page__search-btn:disabled{opacity:.6;cursor:not-allowed}.student-search-page__error{margin:.75rem 0 0;font-size:.85rem;color:var(--error-text, #b91c1c);font-weight:600}.student-search-page__pdf-btn{display:inline-flex;align-items:center;justify-content:center;width:40px;height:40px;border:1px solid #fecaca;border-radius:10px;background:#fef2f2;color:#dc2626;cursor:pointer;flex-shrink:0;transition:background .15s ease}.student-search-page__pdf-btn:hover{background:#fee2e2}.student-search-page__info-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:1rem 1.25rem}.student-search-page__info-item{display:flex;align-items:flex-start;gap:.65rem;min-width:0}.student-search-page__info-icon{width:36px;height:36px;border-radius:8px;display:flex;align-items:center;justify-content:center;flex-shrink:0;background:#f1f5f9;color:var(--ss-muted)}.student-search-page__info-icon--purple{background:var(--ss-purple-bg);color:var(--ss-purple)}.student-search-page__info-icon--blue{background:#eff6ff;color:var(--ss-blue)}.student-search-page__info-icon--green{background:var(--ss-green-bg);color:var(--ss-green)}.student-search-page__info-icon--orange{background:var(--ss-orange-bg);color:var(--ss-orange)}.student-search-page__info-label{display:block;font-size:.72rem;font-weight:600;color:var(--ss-muted);margin-bottom:.15rem}.student-search-page__info-value{display:block;font-size:.88rem;font-weight:600;color:var(--ss-text);word-break:break-word}.student-search-page__stats-row{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:1rem;margin-bottom:1.25rem}.student-search-page__stat-card{background:#fff;border:1px solid var(--ss-border);border-radius:14px;padding:1.15rem 1.25rem;box-shadow:0 1px 3px #0f172a0f;min-width:0}.student-search-page__stat-head{display:flex;align-items:center;gap:.55rem;margin-bottom:.65rem}.student-search-page__stat-icon{width:36px;height:36px;border-radius:8px;display:flex;align-items:center;justify-content:center}.student-search-page__stat-icon--purple{background:var(--ss-purple-bg);color:var(--ss-purple)}.student-search-page__stat-icon--orange{background:var(--ss-orange-bg);color:var(--ss-orange)}.student-search-page__stat-title{margin:0;font-size:.95rem;font-weight:700;color:var(--ss-text)}.student-search-page__stat-value{margin:0 0 .2rem;font-size:2rem;font-weight:800;line-height:1.1;letter-spacing:-.03em}.student-search-page__stat-value--purple{color:var(--ss-purple)}.student-search-page__stat-value--orange{color:var(--ss-orange)}.student-search-page__stat-sub{margin:0;font-size:.78rem;color:var(--ss-muted)}.student-search-page__table-wrap{width:100%;min-width:0;overflow-x:auto;-webkit-overflow-scrolling:touch}.student-search-page__table{width:100%;min-width:640px;table-layout:fixed;border-collapse:collapse;font-size:.88rem}.student-search-page__table thead th{text-align:left;font-size:.68rem;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:#9ca3af;padding:.65rem .75rem;border-bottom:1px solid var(--ss-border);white-space:nowrap}.student-search-page__table tbody td{padding:.85rem .75rem;border-bottom:1px solid #f1f5f9;color:var(--ss-text);vertical-align:middle;overflow-wrap:break-word;word-break:break-word}.student-search-page__table tbody tr:last-child td{border-bottom:none}.student-search-page__pill{display:inline-flex;align-items:center;padding:.2rem .6rem;border-radius:999px;font-size:.75rem;font-weight:600}.student-search-page__pill--present{background:var(--ss-green-bg);color:var(--ss-green)}.student-search-page__pill--absent{background:#fef2f2;color:#dc2626}.student-search-page__pill--progress{background:#fef9c3;color:#a16207}.student-search-page__pill--success{background:var(--ss-green-bg);color:var(--ss-green)}.student-search-page__pill--warn{background:#ffedd5;color:#c2410c}.student-search-page__pill--danger{background:#fef2f2;color:#dc2626}.student-search-page__attendance-summary{font-size:.82rem;font-weight:600;color:var(--ss-green);white-space:nowrap}.student-search-page__footer{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:.75rem;margin-top:1rem;padding-top:1rem;border-top:1px solid var(--ss-border);font-size:.82rem;color:var(--ss-muted)}.student-search-page__pagination{display:flex;align-items:center;gap:.35rem}.student-search-page__pagination button{min-width:32px;height:32px;border:1px solid var(--ss-border);border-radius:8px;background:#fff;color:var(--ss-muted);font-weight:600;font-family:inherit;cursor:pointer}.student-search-page__pagination button:disabled{opacity:.45;cursor:not-allowed}.student-search-page__pagination button.is-current{border-color:var(--ss-blue);color:var(--ss-blue);background:#eff6ff}.student-search-page__empty{padding:2rem 1rem;text-align:center;font-size:.88rem;color:var(--ss-muted)}.student-search-page__results{min-width:0}[data-theme=dark] .student-search-page__card,[data-theme=dark] .student-search-page__stat-card{background:var(--bg-elevated);border-color:var(--border-subtle)}[data-theme=dark] .student-search-page__title,[data-theme=dark] .student-search-page__card-title,[data-theme=dark] .student-search-page__info-value{color:var(--text-main)}[data-theme=dark] .student-search-page__search-input{background:var(--bg);border-color:var(--border-subtle);color:var(--text-main)}@media(max-width:1024px){.student-search-page__info-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}@media(max-width:768px){.student-search-page__header{flex-direction:column}.student-search-page__hero-art{width:100%;justify-content:center}.student-search-page__info-grid,.student-search-page__stats-row{grid-template-columns:1fr}.student-search-page__search-row{flex-direction:column}.student-search-page__search-btn{width:100%}}.student-dash{--sd-purple: #7c3aed;--sd-purple-bg: #f5f3ff;--sd-green: #059669;--sd-green-bg: #ecfdf5;--sd-teal: #0d9488;--sd-teal-bg: #f0fdfa;--sd-orange: #ea580c;--sd-orange-bg: #fff7ed;--sd-blue: var(--brand-action, #1967d2);--sd-blue-bg: #eff6ff;--sd-text: #0f172a;--sd-muted: #64748b;--sd-border: #e2e8f0;max-width:100%;width:100%;min-width:0}.student-dash__top{display:flex;align-items:flex-start;justify-content:space-between;gap:1rem;margin-bottom:1.25rem;flex-wrap:wrap}.student-dash__intro{flex:1;min-width:0}.student-dash__greeting{display:flex;flex-wrap:wrap;align-items:center;gap:.5rem .65rem;margin:0 0 .35rem;font-size:1.65rem;font-weight:700;color:var(--sd-text);letter-spacing:-.02em;line-height:1.25}.student-dash__greeting-label{font-weight:700}.student-dash__greeting-name{font-weight:700;color:var(--sd-text)}.student-dash__greeting-code{display:inline-flex;align-items:center;padding:.2rem .55rem;font-size:.82rem;font-weight:600;color:var(--sd-muted);background:#f1f5f9;border:1px solid var(--sd-border);border-radius:8px;letter-spacing:.02em}.student-dash__greeting-wave{font-size:1.35rem;line-height:1}.student-dash__toolbar{display:flex;align-items:center;gap:.65rem;flex-shrink:0}.student-dash__logout{display:inline-flex;align-items:center;justify-content:center;gap:.4rem;min-height:40px;padding:0 .85rem;font-size:.88rem;font-weight:600;font-family:inherit;color:#b91c1c;background:#fff;border:1px solid rgba(239,68,68,.45);border-radius:10px;box-shadow:0 1px 2px #0f172a0d;cursor:pointer;transition:background .2s ease,border-color .2s ease,color .2s ease}.student-dash__logout:hover{background:#fef2f2;border-color:#ef4444;color:#dc2626}.student-dash__greeting-sub{margin:0;font-size:.9rem;color:var(--sd-muted);line-height:1.5}.student-dash__period{display:inline-flex;align-items:center;gap:.45rem;min-height:40px;padding:0 .85rem 0 .65rem;font-size:.88rem;font-weight:600;color:var(--sd-text);background:#fff;border:1px solid var(--sd-border);border-radius:10px;box-shadow:0 1px 2px #0f172a0d}.student-dash__period svg{color:var(--sd-muted);flex-shrink:0}.student-dash__period select{border:none;background:transparent;font:inherit;font-weight:600;color:inherit;cursor:pointer;padding:.35rem .15rem;outline:none}.student-dash__cards{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:1rem;margin-bottom:1.25rem}.student-dash__card{position:relative;display:flex;flex-direction:column;min-height:200px;padding:1rem 1rem .85rem;background:#fff;border:1px solid var(--sd-border);border-radius:14px;box-shadow:0 1px 3px #0f172a0f;overflow:hidden}.student-dash__card:before{content:"";position:absolute;left:0;top:0;bottom:0;width:4px;background:var(--card-accent, var(--sd-purple))}.student-dash__card--purple{--card-accent: var(--sd-purple)}.student-dash__card--green{--card-accent: var(--sd-green)}.student-dash__card--teal{--card-accent: var(--sd-teal)}.student-dash__card--orange{--card-accent: var(--sd-orange)}.student-dash__card-top{display:flex;align-items:flex-start;justify-content:space-between;gap:.5rem;margin-bottom:.65rem}.student-dash__card-icon{width:40px;height:40px;border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0}.student-dash__card--purple .student-dash__card-icon{background:var(--sd-purple-bg);color:var(--sd-purple)}.student-dash__card--green .student-dash__card-icon{background:var(--sd-green-bg);color:var(--sd-green)}.student-dash__card--teal .student-dash__card-icon{background:var(--sd-teal-bg);color:var(--sd-teal)}.student-dash__card--orange .student-dash__card-icon{background:var(--sd-orange-bg);color:var(--sd-orange)}.student-dash__card-side-stats{text-align:right;font-size:.72rem;line-height:1.55;color:var(--sd-muted);white-space:nowrap}.student-dash__card-side-stats strong{color:var(--sd-text);font-weight:700}.student-dash__card-title{margin:0 0 .15rem;font-size:.92rem;font-weight:700;color:var(--sd-text)}.student-dash__card-value{margin:0;font-size:2rem;font-weight:800;line-height:1.1;letter-spacing:-.03em}.student-dash__card--purple .student-dash__card-value{color:var(--sd-purple)}.student-dash__card--green .student-dash__card-value{color:var(--sd-green)}.student-dash__card--teal .student-dash__card-value{color:var(--sd-teal)}.student-dash__card--orange .student-dash__card-value{color:var(--sd-orange)}.student-dash__card-label{margin:0 0 auto;font-size:.78rem;color:var(--sd-muted);line-height:1.35}.student-dash__card-link{display:inline-flex;align-items:center;gap:.2rem;margin-top:.85rem;padding:.45rem .85rem;font-size:.8rem;font-weight:600;color:var(--sd-text);background:#fff;border:1px solid var(--sd-border);border-radius:8px;text-decoration:none;transition:border-color .2s ease,background .2s ease}.student-dash__card-link:hover{border-color:#cbd5e1;background:#f8fafc}.student-dash__notifications{background:#fff;border:1px solid var(--sd-border);border-radius:14px;box-shadow:0 1px 3px #0f172a0f;overflow:hidden}.student-dash__notifications-head{display:flex;align-items:flex-start;justify-content:space-between;gap:1rem;padding:1.15rem 1.25rem;border-bottom:1px solid var(--sd-border);flex-wrap:wrap}.student-dash__notifications-head-left{display:flex;align-items:flex-start;gap:.75rem;min-width:0}.student-dash__bell-icon{width:40px;height:40px;border-radius:50%;background:var(--sd-blue-bg);color:var(--sd-blue);display:flex;align-items:center;justify-content:center;flex-shrink:0}.student-dash__notifications-title{margin:0 0 .2rem;font-size:1.05rem;font-weight:700;color:var(--sd-text)}.student-dash__notifications-desc{margin:0;font-size:.82rem;color:var(--sd-muted);line-height:1.45}.student-dash__view-all{display:inline-flex;align-items:center;gap:.2rem;padding:.45rem .85rem;font-size:.8rem;font-weight:600;color:var(--sd-text);background:#fff;border:1px solid var(--sd-border);border-radius:8px;text-decoration:none;white-space:nowrap;flex-shrink:0}.student-dash__view-all:hover{background:#f8fafc}.student-dash__notify-list{list-style:none;margin:0;padding:0}.student-dash__notify-item{display:flex;align-items:center;gap:.75rem;padding:.95rem 1.25rem;border-bottom:1px solid #f1f5f9;text-decoration:none;color:inherit;transition:background .15s ease}.student-dash__notify-item:hover{background:#f8fafc}.student-dash__notify-item:last-child{border-bottom:none}.student-dash__notify-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.student-dash__notify-dot--green{background:#22c55e}.student-dash__notify-dot--orange{background:#f97316}.student-dash__notify-type-icon{width:36px;height:36px;border-radius:8px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.student-dash__notify-type-icon--green{background:var(--sd-green-bg);color:var(--sd-green)}.student-dash__notify-type-icon--orange{background:var(--sd-orange-bg);color:var(--sd-orange)}.student-dash__notify-body{flex:1;min-width:0}.student-dash__notify-title{margin:0 0 .15rem;font-size:.9rem;font-weight:600;color:var(--sd-text);line-height:1.35}.student-dash__notify-course{margin:0;font-size:.78rem;color:var(--sd-muted)}.student-dash__notify-meta{display:flex;align-items:center;gap:.35rem;flex-shrink:0;font-size:.78rem;color:var(--sd-muted);white-space:nowrap}.student-dash__notify-empty{padding:2rem 1.25rem;text-align:center;font-size:.88rem;color:var(--sd-muted)}.student-dash__show-more{display:flex;align-items:center;justify-content:center;gap:.35rem;width:100%;padding:.85rem;font-size:.85rem;font-weight:600;color:var(--sd-blue);background:none;border:none;border-top:1px solid var(--sd-border);cursor:pointer}.student-dash__show-more:hover{background:#f8fafc}.student-dash__loading{padding:2rem 0;color:var(--sd-muted);font-size:.9rem}[data-theme=dark] .student-dash__card,[data-theme=dark] .student-dash__notifications,[data-theme=dark] .student-dash__period{background:var(--bg-elevated);border-color:var(--border-subtle)}[data-theme=dark] .student-dash__greeting,[data-theme=dark] .student-dash__greeting-name,[data-theme=dark] .student-dash__card-title,[data-theme=dark] .student-dash__notifications-title,[data-theme=dark] .student-dash__notify-title{color:var(--text-main)}[data-theme=dark] .student-dash__greeting-code{background:#ffffff0f;border-color:var(--border-subtle);color:var(--text-muted)}[data-theme=dark] .student-dash__logout{background:var(--bg-elevated);color:#fca5a5;border-color:#ef444473}[data-theme=dark] .student-dash__logout:hover{background:#ef44441f;color:#fecaca}[data-theme=dark] .student-dash__notify-item:hover{background:#ffffff08}@media(max-width:1200px){.student-dash__cards{grid-template-columns:repeat(2,minmax(0,1fr))}}@media(max-width:560px){.student-dash__cards{grid-template-columns:1fr}.student-dash__greeting{font-size:1.35rem}.student-dash__toolbar{width:100%;justify-content:flex-end}.student-dash__logout span{display:none}.student-dash__logout{padding:0 .65rem}}.my-profile-page{--mp-blue: var(--brand-action, #1967d2);--mp-blue-hover: var(--brand-action-hover, #1557b8);--mp-purple: #7c3aed;--mp-purple-bg: #f5f3ff;--mp-purple-light: #ede9fe;--mp-text: #0f172a;--mp-muted: #64748b;--mp-border: #e2e8f0;--mp-sidebar-bg: #f8fafc;max-width:100%;width:100%;min-width:0;box-sizing:border-box}.my-profile-page__header{display:flex;align-items:flex-start;gap:1rem;margin-bottom:1.25rem}.my-profile-page__header-icon{width:52px;height:52px;border-radius:50%;background:var(--mp-purple-light);color:var(--mp-purple);display:flex;align-items:center;justify-content:center;flex-shrink:0}.my-profile-page__title{margin:0 0 .35rem;font-size:1.65rem;font-weight:700;color:var(--mp-text);letter-spacing:-.02em;line-height:1.2}.my-profile-page__subtitle{margin:0;font-size:.9rem;color:var(--mp-muted);line-height:1.5;max-width:42rem}.my-profile-page__card{display:flex;align-items:stretch;background:#fff;border:1px solid var(--mp-border);border-radius:16px;box-shadow:0 1px 3px #0f172a0f;overflow:hidden;min-width:0}.my-profile-page__sidebar{width:260px;flex-shrink:0;display:flex;flex-direction:column;align-items:center;padding:1.75rem 1.25rem;background:var(--mp-sidebar-bg);border-right:1px solid var(--mp-border);text-align:center}.my-profile-page__avatar-wrap{position:relative;margin-bottom:1rem}.my-profile-page__avatar{width:120px;height:120px;border-radius:50%;border:none;padding:0;overflow:hidden;background:linear-gradient(145deg,#7c3aed,#f97316);display:flex;align-items:center;justify-content:center;cursor:pointer;box-shadow:0 8px 24px #7c3aed38}.my-profile-page__avatar img{width:100%;height:100%;object-fit:cover}.my-profile-page__avatar-initials{font-size:2.5rem;font-weight:700;color:#fff;letter-spacing:.02em}.my-profile-page__avatar-camera{position:absolute;right:4px;bottom:4px;width:34px;height:34px;border-radius:50%;border:2px solid #fff;background:var(--mp-blue);color:#fff;display:flex;align-items:center;justify-content:center;cursor:pointer;box-shadow:0 2px 8px #0f172a26;transition:background .2s ease}.my-profile-page__avatar-camera:hover{background:var(--mp-blue-hover)}.my-profile-page__sidebar-name{margin:0 0 .25rem;font-size:1.05rem;font-weight:700;color:var(--mp-text);text-transform:uppercase;letter-spacing:.03em;line-height:1.3}.my-profile-page__sidebar-code{margin:0 0 1rem;font-size:.82rem;color:var(--mp-muted)}.my-profile-page__upload-btn{display:inline-flex;align-items:center;justify-content:center;gap:.45rem;width:100%;max-width:200px;padding:.55rem 1rem;font-size:.88rem;font-weight:600;color:var(--mp-purple);background:#fff;border:1.5px solid var(--mp-purple);border-radius:10px;cursor:pointer;transition:background .2s ease,color .2s ease}.my-profile-page__upload-btn:hover:not(:disabled){background:var(--mp-purple-bg)}.my-profile-page__upload-btn:disabled{opacity:.65;cursor:not-allowed}.my-profile-page__upload-hint{display:flex;align-items:flex-start;gap:.35rem;margin:.75rem 0 0;font-size:.72rem;color:var(--mp-muted);line-height:1.45;max-width:200px;text-align:left}.my-profile-page__upload-hint svg{flex-shrink:0;margin-top:.1rem;color:var(--mp-muted)}.my-profile-page__photo-error{margin-top:.5rem;font-size:.72rem;color:var(--error-text, #b91c1c);max-width:200px}.my-profile-page__photo-input{position:absolute;width:0;height:0;opacity:0;pointer-events:none}.my-profile-page__main{flex:1;min-width:0;padding:1.5rem 1.75rem;display:flex;flex-direction:column;gap:1.25rem}.my-profile-page__section{padding:1.15rem 1.25rem;border:1px solid var(--mp-border);border-radius:12px;background:#fff}.my-profile-page__section-head{display:flex;align-items:flex-start;gap:.75rem;margin-bottom:1.1rem}.my-profile-page__section-icon{width:36px;height:36px;border-radius:8px;background:var(--mp-purple-light);color:var(--mp-purple);display:flex;align-items:center;justify-content:center;flex-shrink:0}.my-profile-page__section-title{margin:0 0 .2rem;font-size:1rem;font-weight:700;color:var(--mp-text)}.my-profile-page__section-desc{margin:0;font-size:.82rem;color:var(--mp-muted)}.my-profile-page__fields{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:1rem 1.1rem}.my-profile-page__fields--two{grid-template-columns:repeat(2,minmax(0,1fr))}.my-profile-page__field--span-1{grid-column:span 1}.my-profile-page__field label{display:block;font-size:.8rem;font-weight:600;color:var(--mp-text);margin-bottom:.4rem}.my-profile-page__input-wrap{position:relative;display:flex;align-items:center}.my-profile-page__input-icon{position:absolute;left:.75rem;top:50%;transform:translateY(-50%);color:var(--mp-muted);display:flex;pointer-events:none;z-index:1}.my-profile-page__input,.my-profile-page__textarea,.my-profile-page__select{width:100%;font-size:.88rem;color:var(--mp-text);background:#fff;border:1px solid var(--mp-border);border-radius:10px;transition:border-color .2s ease,box-shadow .2s ease}.my-profile-page__input,.my-profile-page__select{min-height:42px;padding:.5rem .75rem}.my-profile-page__input-wrap .my-profile-page__input,.my-profile-page__input-wrap .my-profile-page__select{padding-left:2.5rem}.my-profile-page__input-wrap--select .my-profile-page__select{padding-right:2.25rem;-webkit-appearance:none;-moz-appearance:none;appearance:none;cursor:pointer}.my-profile-page__select-chevron{position:absolute;right:.75rem;top:50%;transform:translateY(-50%);color:var(--mp-muted);pointer-events:none}.my-profile-page__input:focus,.my-profile-page__textarea:focus,.my-profile-page__select:focus{outline:none;border-color:var(--mp-blue);box-shadow:0 0 0 3px #1967d21f}.my-profile-page__input:disabled{background:#f8fafc;color:var(--mp-muted);cursor:not-allowed}.my-profile-page__textarea{min-height:88px;padding:.65rem .75rem;resize:vertical;line-height:1.45}.my-profile-page__actions{display:flex;align-items:center;gap:1rem;padding-top:.25rem}.my-profile-page__save-btn{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;min-width:150px;padding:.6rem 1.25rem;font-size:.9rem;font-weight:600;color:#fff;background:var(--mp-blue);border:none;border-radius:10px;cursor:pointer;transition:background .2s ease}.my-profile-page__save-btn:hover:not(:disabled){background:var(--mp-blue-hover)}.my-profile-page__save-btn:disabled{opacity:.65;cursor:not-allowed}.my-profile-page__reset-btn{padding:.5rem .75rem;font-size:.9rem;font-weight:600;color:var(--mp-muted);background:none;border:none;cursor:pointer;transition:color .2s ease}.my-profile-page__reset-btn:hover{color:var(--mp-text)}.my-profile-page__loading{padding:2rem 0;color:var(--mp-muted);font-size:.9rem}.my-profile-page__error{padding:1.5rem;border:1px solid var(--mp-border);border-radius:12px;background:#fff}[data-theme=dark] .my-profile-page__card,[data-theme=dark] .my-profile-page__section,[data-theme=dark] .my-profile-page__error{background:var(--bg-elevated);border-color:var(--border-subtle)}[data-theme=dark] .my-profile-page__sidebar{background:#ffffff08}[data-theme=dark] .my-profile-page__title,[data-theme=dark] .my-profile-page__section-title,[data-theme=dark] .my-profile-page__field label{color:var(--text-main)}[data-theme=dark] .my-profile-page__input,[data-theme=dark] .my-profile-page__textarea,[data-theme=dark] .my-profile-page__select{background:var(--bg);border-color:var(--border-subtle);color:var(--text-main)}[data-theme=dark] .my-profile-page__input:disabled{background:#ffffff0a}[data-theme=dark] .my-profile-page__upload-btn{background:transparent}@media(max-width:1024px){.my-profile-page__card{flex-direction:column}.my-profile-page__sidebar{width:100%;border-right:none;border-bottom:1px solid var(--mp-border);padding:1.5rem}}@media(max-width:768px){.my-profile-page__fields{grid-template-columns:1fr 1fr}.my-profile-page__fields--two{grid-template-columns:1fr}.my-profile-page__main{padding:1.25rem}}@media(max-width:520px){.my-profile-page__fields,.my-profile-page__fields--two{grid-template-columns:1fr}}.cert-page{--cert-blue: var(--brand-action, #1967d2);--cert-blue-soft: #e8f0fb;--cert-green: #059669;--cert-green-soft: #ecfdf5;--cert-module-blue: #2563eb;--cert-module-soft: #eff6ff;--cert-border: #e5e7eb;--cert-muted: #6b7280;--cert-text: #111827;width:100%;max-width:100%;min-width:0;box-sizing:border-box}.cert-page__hero{display:flex;align-items:stretch;justify-content:space-between;gap:1.5rem;padding:1.75rem 2rem;margin-bottom:1.25rem;border-radius:16px;background:linear-gradient(135deg,#f0f6ff,#fff 55%,#f8fafc);border:1px solid var(--cert-border);overflow:hidden;position:relative}.cert-page__hero-copy{position:relative;z-index:1;flex:1;min-width:0}.cert-page__hero-title{margin:0 0 .35rem;font-size:1.75rem;font-weight:700;color:var(--cert-text);letter-spacing:-.02em}.cert-page__hero-sub{margin:0;font-size:.95rem;color:var(--cert-muted);max-width:28rem;line-height:1.5}.cert-page__hero-art{flex-shrink:0;width:200px;display:flex;align-items:center;justify-content:flex-end;position:relative;z-index:0}.cert-page__hero-art svg{width:100%;max-width:180px;height:auto}.cert-filter-card,.cert-grid-card{width:100%;min-width:0;box-sizing:border-box;background:#fff;border:1px solid var(--cert-border);border-radius:14px;padding:1.25rem 1.5rem;margin-bottom:1.25rem;box-shadow:0 1px 3px #0f172a0a}.cert-filter-card__head{display:flex;align-items:center;gap:.5rem;margin-bottom:1rem;font-size:.95rem;font-weight:600;color:var(--cert-text)}.cert-filter-card__row{display:flex;flex-wrap:wrap;align-items:flex-end;justify-content:space-between;gap:1rem 1.5rem}.cert-filter-types label.cert-filter-types__label{display:block;font-size:.8rem;font-weight:500;color:var(--cert-muted);margin-bottom:.5rem}.cert-type-pills{display:flex;flex-wrap:wrap;gap:.5rem}.cert-type-pill{display:inline-flex;align-items:center;gap:.4rem;padding:.45rem .85rem;border-radius:999px;border:1px solid var(--cert-border);background:#fff;color:var(--cert-muted);font-size:.82rem;font-weight:500;cursor:pointer;transition:border-color .15s,background .15s,color .15s}.cert-type-pill:hover{border-color:#cbd5e1}.cert-type-pill.is-active{border-color:var(--cert-blue);background:var(--cert-blue-soft);color:var(--cert-blue)}.cert-search-wrap{flex:1;min-width:200px;max-width:320px;margin-left:auto}.cert-search-wrap label{display:block;font-size:.8rem;font-weight:500;color:transparent;height:0;overflow:hidden}.cert-search-input{display:flex;align-items:center;gap:.5rem;padding:.5rem .85rem;border:1px solid var(--cert-border);border-radius:10px;background:#f9fafb}.cert-search-input input{flex:1;border:none;background:transparent;font-size:.88rem;color:var(--cert-text);outline:none;min-width:0}.cert-search-input input::placeholder{color:#9ca3af}.cert-grid-card__head{display:flex;align-items:flex-start;gap:.75rem;margin-bottom:1.25rem}.cert-grid-card__icon{width:40px;height:40px;border-radius:10px;background:var(--cert-blue-soft);color:var(--cert-blue);display:flex;align-items:center;justify-content:center;flex-shrink:0}.cert-grid-card__title{margin:0;font-size:1.05rem;font-weight:700;color:var(--cert-text)}.cert-grid-card__sub{margin:.2rem 0 0;font-size:.85rem;color:var(--cert-muted)}.cert-table-wrap{width:100%;min-width:0;overflow-x:auto;-webkit-overflow-scrolling:touch}.cert-table{width:100%;min-width:0;table-layout:fixed;border-collapse:collapse;font-size:.88rem}.cert-table thead th:nth-child(1){width:36%}.cert-table thead th:nth-child(2){width:11%}.cert-table thead th:nth-child(3){width:14%}.cert-table thead th:nth-child(4){width:9%}.cert-table thead th:nth-child(5){width:30%}.cert-table thead th{text-align:left;font-size:.68rem;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:#9ca3af;padding:.65rem .75rem;border-bottom:1px solid var(--cert-border);white-space:nowrap}.cert-table tbody td{padding:1rem .75rem;border-bottom:1px solid #f3f4f6;vertical-align:middle;color:var(--cert-text);overflow:hidden;word-break:break-word}.cert-table tbody tr:last-child td{border-bottom:none}.cert-title-cell{display:flex;align-items:flex-start;gap:.85rem;min-width:0}.cert-title-cell__icon{width:42px;height:42px;border-radius:10px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.cert-title-cell__icon--course{background:var(--cert-green-soft);color:var(--cert-green)}.cert-title-cell__icon--assessment{background:var(--cert-module-soft);color:var(--cert-module-blue)}.cert-title-cell__name{font-weight:600;font-size:.92rem;margin:0 0 .2rem;color:var(--cert-text)}.cert-title-cell__desc{margin:0;font-size:.8rem;color:var(--cert-muted);line-height:1.4;max-width:100%;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.cert-badge{display:inline-block;padding:.25rem .65rem;border-radius:999px;font-size:.75rem;font-weight:600}.cert-badge--course{background:var(--cert-green-soft);color:var(--cert-green)}.cert-badge--assessment{background:var(--cert-module-soft);color:var(--cert-module-blue)}.cert-date-cell{display:inline-flex;align-items:center;gap:.4rem;color:var(--cert-muted);flex-wrap:wrap;font-size:.82rem}.cert-score-pill{display:inline-block;padding:.2rem .55rem;border-radius:6px;font-size:.8rem;font-weight:600}.cert-score-pill--high{background:var(--cert-green-soft);color:var(--cert-green)}.cert-score-pill--mid{background:var(--cert-module-soft);color:var(--cert-module-blue)}.cert-credential{display:inline-flex;align-items:center;gap:.35rem;font-family:ui-monospace,monospace;font-size:.8rem;color:var(--cert-muted)}.cert-credential__copy{border:none;background:transparent;padding:.2rem;cursor:pointer;color:#9ca3af;border-radius:4px;display:inline-flex}.cert-credential__copy:hover{color:var(--cert-blue);background:var(--cert-blue-soft)}.cert-action-cell{display:flex;align-items:center;justify-content:flex-end;flex-wrap:wrap;gap:.35rem;min-width:0}.cert-download-btn{display:inline-flex;align-items:center;justify-content:center;gap:.35rem;max-width:100%;padding:.45rem .75rem;border:none;border-radius:var(--radius-pill, 999px);background:var(--cert-blue);color:#fff;font-size:.8125rem;font-weight:600;font-family:inherit;cursor:pointer;box-shadow:none;transition:background .15s ease}.cert-download-btn:hover:not(:disabled){background:var(--brand-action-hover, #1557b8)}.cert-download-btn:disabled{background:#d1d5db;color:#9ca3af;cursor:not-allowed}.cert-kebab{border:none;background:transparent;padding:.35rem;border-radius:6px;color:#9ca3af;cursor:pointer}.cert-kebab:hover{background:#f3f4f6;color:var(--cert-text)}.cert-table-footer{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:.75rem;margin-top:1rem;padding-top:1rem;border-top:1px solid var(--cert-border);font-size:.82rem;color:var(--cert-muted)}.cert-pagination{display:flex;align-items:center;gap:.35rem}.cert-pagination button{font-weight:600;font-family:inherit;box-shadow:none;min-width:32px;height:32px;border:1px solid var(--cert-border);border-radius:var(--radius-pill, 999px);background:#fff;color:var(--cert-muted);cursor:pointer;font-size:.85rem}.cert-pagination button:disabled{opacity:.45;cursor:not-allowed}.cert-pagination button.is-current{border-color:var(--cert-blue);color:var(--cert-blue);font-weight:600}.cert-empty{padding:2rem .75rem;text-align:center;color:var(--cert-muted);font-size:.88rem}[data-theme=dark] .cert-page__hero,[data-theme=dark] .cert-filter-card,[data-theme=dark] .cert-grid-card{background:var(--bg-elevated);border-color:var(--border-subtle)}[data-theme=dark] .cert-page__hero-title,[data-theme=dark] .cert-grid-card__title,[data-theme=dark] .cert-title-cell__name,[data-theme=dark] .cert-table tbody td{color:var(--text-main)}[data-theme=dark] .cert-type-pill{background:var(--bg-elevated);border-color:var(--border-subtle)}[data-theme=dark] .cert-search-input{background:#ffffff0a;border-color:var(--border-subtle)}@media(max-width:1024px){.cert-table thead th:nth-child(1){width:32%}.cert-table thead th:nth-child(5){width:34%}.cert-download-btn__label-long{display:none}}@media(max-width:768px){.cert-page__hero{flex-direction:column;padding:1.25rem}.cert-page__hero-art{width:100%;justify-content:center}.cert-search-wrap{max-width:none;margin-left:0;width:100%}.cert-grid-card{padding:1rem}.cert-table{font-size:.82rem}.cert-table thead th:nth-child(4),.cert-table tbody td:nth-child(4){display:none}.cert-table thead th:nth-child(1){width:42%}.cert-table thead th:nth-child(2){width:14%}.cert-table thead th:nth-child(3){width:18%}.cert-table thead th:nth-child(5){width:26%}.cert-kebab{display:none}.cert-download-btn{padding:.4rem .55rem;font-size:.75rem}}.my-attendance-page{--ma-blue: var(--brand-action, #1967d2);--ma-text: #0f172a;--ma-muted: #64748b;--ma-border: #e2e8f0;--ma-green: #059669;--ma-green-bg: #ecfdf5;--ma-green-light: #d1fae5;--ma-red: #dc2626;--ma-red-bg: #fef2f2;--ma-red-light: #fee2e2;--ma-purple: #7c3aed;--ma-purple-bg: #f5f3ff;--ma-purple-light: #ede9fe;max-width:100%;width:100%;min-width:0;box-sizing:border-box}.my-attendance-page__header{display:flex;align-items:flex-start;gap:1rem;margin-bottom:1rem}.my-attendance-page__icon{width:52px;height:52px;border-radius:12px;background:linear-gradient(145deg,#2563eb 0%,var(--ma-blue) 100%);color:#fff;display:flex;align-items:center;justify-content:center;flex-shrink:0;box-shadow:0 4px 14px #1967d240}.my-attendance-page__title{margin:0 0 .35rem;font-size:1.65rem;font-weight:700;color:var(--ma-text);letter-spacing:-.02em;line-height:1.2}.my-attendance-page__subtitle{margin:0;font-size:.9rem;color:var(--ma-muted);line-height:1.5}.my-attendance-page__inline-stats{display:flex;flex-wrap:wrap;align-items:center;gap:.5rem 0;padding:.85rem 1.15rem;background:#fff;border:1px solid var(--ma-border);border-radius:12px;box-shadow:0 1px 3px #0f172a0d;font-size:.9rem;font-weight:600;color:var(--ma-muted);margin-bottom:1rem}.my-attendance-page__inline-stats strong{font-weight:700}.my-attendance-page__inline-stats .is-present{color:var(--ma-green)}.my-attendance-page__inline-stats .is-absent{color:var(--ma-red)}.my-attendance-page__inline-stats .is-total{color:var(--ma-purple)}.my-attendance-page__inline-divider{width:1px;height:1.1rem;background:var(--ma-border);margin:0 1rem}.my-attendance-page__summary{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:1rem;margin-bottom:1.25rem}.my-attendance-page__stat-card{display:flex;align-items:flex-start;gap:.85rem;padding:1.15rem 1.2rem;background:#fff;border:1px solid var(--ma-border);border-radius:12px;box-shadow:0 1px 3px #0f172a0f;min-width:0}.my-attendance-page__stat-icon{width:44px;height:44px;border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0}.my-attendance-page__stat-icon--present{background:var(--ma-green-light);color:var(--ma-green)}.my-attendance-page__stat-icon--absent{background:var(--ma-red-light);color:var(--ma-red)}.my-attendance-page__stat-icon--total{background:var(--ma-purple-light);color:var(--ma-purple)}.my-attendance-page__stat-body{flex:1;min-width:0}.my-attendance-page__stat-label{font-size:.72rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--ma-muted);margin-bottom:.25rem}.my-attendance-page__stat-value{font-size:2rem;font-weight:700;line-height:1.1;margin-bottom:.5rem}.my-attendance-page__stat-value--present{color:var(--ma-green)}.my-attendance-page__stat-value--absent{color:var(--ma-red)}.my-attendance-page__stat-value--total{color:var(--ma-purple)}.my-attendance-page__stat-bar{height:6px;border-radius:999px;background:#f1f5f9;overflow:hidden;margin-bottom:.4rem}.my-attendance-page__stat-bar-fill{height:100%;border-radius:999px;transition:width .35s ease}.my-attendance-page__stat-bar-fill--present{background:var(--ma-green)}.my-attendance-page__stat-bar-fill--absent{background:var(--ma-red)}.my-attendance-page__stat-hint{font-size:.78rem;color:var(--ma-muted);line-height:1.35}.my-attendance-page__card{background:#fff;border:1px solid var(--ma-border);border-radius:14px;box-shadow:0 1px 3px #0f172a0f;overflow:hidden}.my-attendance-page__card-header{display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:.75rem 1rem;padding:1rem 1.25rem;border-bottom:1px solid var(--ma-border);background:#fafbfc}.my-attendance-page__card-title-row{display:flex;align-items:center;gap:.5rem;min-width:0}.my-attendance-page__card-title-icon{color:var(--ma-blue);display:flex;align-items:center}.my-attendance-page__card-title{margin:0;font-size:1rem;font-weight:700;color:var(--ma-text)}.my-attendance-page__card-meta{display:flex;flex-wrap:wrap;align-items:center;gap:.35rem .75rem;font-size:.8rem;font-weight:600;color:var(--ma-muted)}.my-attendance-page__export-btn{display:inline-flex;align-items:center;gap:.4rem;padding:.5rem 1rem;border-radius:var(--radius-pill, 999px);border:1px solid var(--ma-blue);background:#fff;color:var(--ma-blue);font-size:.8125rem;font-weight:600;font-family:inherit;cursor:pointer;transition:background .15s ease,color .15s ease;flex-shrink:0}.my-attendance-page__export-btn:hover:not(:disabled){background:#e8f0fb}.my-attendance-page__export-btn:disabled{opacity:.5;cursor:not-allowed}.my-attendance-page__table-wrap{overflow-x:auto;width:100%}.my-attendance-page__table{width:100%;border-collapse:collapse;font-size:.875rem}.my-attendance-page__table thead th{padding:.75rem 1rem;text-align:left;font-size:.8rem;font-weight:600;color:var(--ma-muted);background:#f8fafc;border-bottom:1px solid var(--ma-border);white-space:nowrap}.my-attendance-page__th-sort{display:inline-flex;align-items:center;gap:.35rem;padding:0;border:none;background:none;font:inherit;color:inherit;cursor:pointer}.my-attendance-page__th-sort:hover{color:var(--ma-text)}.my-attendance-page__table tbody td{padding:.85rem 1rem;border-bottom:1px solid var(--ma-border);color:var(--ma-text);vertical-align:middle}.my-attendance-page__table tbody tr:nth-child(2n){background:#fafbfc}.my-attendance-page__table tbody tr:hover{background:#f1f5f9}.my-attendance-page__date-cell{display:flex;align-items:center;gap:.5rem;font-weight:500}.my-attendance-page__date-icon{color:var(--ma-blue);display:flex;flex-shrink:0}.my-attendance-page__status-pill{display:inline-flex;align-items:center;gap:.4rem;padding:.28rem .65rem;border-radius:999px;font-size:.8125rem;font-weight:600}.my-attendance-page__status-pill--present{background:var(--ma-green-bg);color:var(--ma-green)}.my-attendance-page__status-pill--absent{background:var(--ma-red-bg);color:var(--ma-red)}.my-attendance-page__status-dot{width:7px;height:7px;border-radius:50%;flex-shrink:0}.my-attendance-page__status-pill--present .my-attendance-page__status-dot{background:var(--ma-green)}.my-attendance-page__status-pill--absent .my-attendance-page__status-dot{background:var(--ma-red)}.my-attendance-page__attendance-text{color:var(--ma-muted);font-weight:500}.my-attendance-page__empty{padding:2.5rem 1.25rem;text-align:center;color:var(--ma-muted);font-size:.9rem;line-height:1.5}.my-attendance-page__footer{display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:.75rem;padding:.85rem 1.25rem;border-top:1px solid var(--ma-border);font-size:.85rem;color:var(--ma-muted)}.my-attendance-page__pagination{display:flex;align-items:center;gap:.35rem}.my-attendance-page__pagination button{min-width:34px;height:34px;padding:0 .5rem;border:1px solid var(--ma-border);border-radius:8px;background:#fff;color:var(--ma-muted);font-size:.85rem;font-weight:600;font-family:inherit;cursor:pointer;transition:border-color .15s,color .15s,background .15s}.my-attendance-page__pagination button:disabled{opacity:.4;cursor:not-allowed}.my-attendance-page__pagination button.is-current{background:var(--ma-blue);border-color:var(--ma-blue);color:#fff}.my-attendance-page__pagination button:not(:disabled):not(.is-current):hover{border-color:#cbd5e1;color:var(--ma-text)}.my-attendance-page__loading{padding:2rem;text-align:center;color:var(--ma-muted);font-size:.9rem}.my-attendance-page__error{padding:1rem 1.15rem;border-radius:10px;background:var(--ma-red-bg);color:var(--ma-red);font-size:.9rem;margin-bottom:1rem}@media(max-width:900px){.my-attendance-page__summary{grid-template-columns:1fr}.my-attendance-page__inline-divider{display:none}.my-attendance-page__card-header{flex-direction:column;align-items:flex-start}}: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;--brand-action: #1967d2;--brand-action-hover: #1557b8;--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)}.app-sidebar{width:260px;flex-shrink:0;padding:1rem .85rem .75rem;background:#f8fafc;border-right-color:#e8edf3;gap:0;transition:width .2s ease,padding .2s ease,border-color .2s ease,opacity .2s ease}.app-sidebar--hidden{width:0;min-width:0;padding-left:0;padding-right:0;border-right-width:0;overflow:hidden;opacity:0;pointer-events:none}.app-sidebar__top{flex:1;min-height:0;display:flex;flex-direction:column;overflow:hidden}.app-sidebar__brand{margin-bottom:.85rem}.app-sidebar__search{display:flex;align-items:center;gap:.45rem;margin-bottom:1rem;padding:.45rem .65rem;border:1px solid #e2e8f0;border-radius:999px;background:#fff;cursor:text}.app-sidebar__search-icon{display:flex;color:#94a3b8;flex-shrink:0}.app-sidebar__search-icon svg{width:15px;height:15px}.app-sidebar__search-input{flex:1;min-width:0;border:none;background:transparent;font-size:.8125rem;color:#334155;outline:none}.app-sidebar__search-input::placeholder{color:#94a3b8}.app-sidebar__search-kbd{font-size:.65rem;color:#94a3b8;border:1px solid #e2e8f0;border-radius:4px;padding:.1rem .3rem;line-height:1.2;font-family:inherit}.app-sidebar__role{display:none}.app-sidebar__nav{flex:1;min-height:0;overflow-y:auto;overflow-x:hidden;padding-right:.15rem;scrollbar-width:thin}.app-sidebar__section{margin-bottom:.35rem}.app-sidebar__section-head{display:flex;align-items:center;justify-content:space-between;width:100%;padding:.4rem .55rem;margin-bottom:.2rem;border:none;border-radius:8px;background:transparent;cursor:pointer;font:inherit;text-align:left;transition:background .2s ease,color .2s ease}.app-sidebar__section-head:not(.app-sidebar__section-head--static):hover{filter:brightness(.97)}.app-sidebar__section-head--static{cursor:default;pointer-events:none}.app-sidebar__section-title{font-size:.625rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:#64748b}.app-sidebar__section--main .app-sidebar__section-head{background:linear-gradient(90deg,#eff6ff,#eff6ff59)}.app-sidebar__section--main .app-sidebar__section-title,.app-sidebar__section--main .app-sidebar__chevron{color:#1d4ed8}.app-sidebar__section--academics .app-sidebar__section-head{background:linear-gradient(90deg,#eef2ff,#eef2ff59)}.app-sidebar__section--academics .app-sidebar__section-title,.app-sidebar__section--academics .app-sidebar__chevron{color:#4338ca}.app-sidebar__section--users .app-sidebar__section-head{background:linear-gradient(90deg,#ecfdf5,#ecfdf559)}.app-sidebar__section--users .app-sidebar__section-title,.app-sidebar__section--users .app-sidebar__chevron{color:#047857}.app-sidebar__section--content .app-sidebar__section-head{background:linear-gradient(90deg,#f5f3ff,#f5f3ff59)}.app-sidebar__section--content .app-sidebar__section-title,.app-sidebar__section--content .app-sidebar__chevron{color:#6d28d9}.app-sidebar__section--tasks .app-sidebar__section-head{background:linear-gradient(90deg,#fffbeb,#fffbeb59)}.app-sidebar__section--tasks .app-sidebar__section-title,.app-sidebar__section--tasks .app-sidebar__chevron{color:#b45309}.app-sidebar__section--config .app-sidebar__section-head{background:linear-gradient(90deg,#fff1f2,#fff1f259)}.app-sidebar__section--config .app-sidebar__section-title,.app-sidebar__section--config .app-sidebar__chevron{color:#be123c}.app-sidebar__section--tools .app-sidebar__section-head{background:linear-gradient(90deg,#ecfeff,#ecfeff59)}.app-sidebar__section--tools .app-sidebar__section-title,.app-sidebar__section--tools .app-sidebar__chevron{color:#0e7490}.app-sidebar__chevron{color:#94a3b8;transition:transform .15s ease,color .2s ease;flex-shrink:0}.app-sidebar__chevron--open{transform:rotate(180deg)}.app-sidebar__section-items{display:flex;flex-direction:column;gap:.12rem}.app-sidebar__link{display:flex;align-items:center;gap:.65rem;padding:.5rem .65rem;min-height:38px;border-radius:10px;font-size:.875rem;font-weight:500;color:#475569;text-decoration:none;transition:background .15s ease,color .15s ease}.app-sidebar__link:hover{background:#f1f5f9;color:#1e293b}.app-sidebar__link--active{background:var(--brand-action);color:#fff}.app-sidebar__link--active:hover{background:var(--brand-action-hover);color:#fff}.app-sidebar__link-icon{display:flex;align-items:center;justify-content:center;flex-shrink:0;width:18px;height:18px}.app-sidebar__link-label{flex:1;min-width:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.app-sidebar__badge{flex-shrink:0;min-width:1.35rem;padding:.1rem .4rem;border-radius:999px;font-size:.6875rem;font-weight:700;line-height:1.3;text-align:center;color:#fff}.app-sidebar__badge--purple{background:#7b5cff}.app-sidebar__badge--lavender{background:#c4b5fd;color:#5b21b6}.app-sidebar__badge--green{background:#22c55e}.app-sidebar--collapsed .app-sidebar__link{justify-content:center;padding-left:.5rem;padding-right:.5rem}.app-sidebar--collapsed .brand-logo,.app-sidebar--collapsed .brand-logo-inner{width:44px;height:44px;margin:0 auto}.app-sidebar--collapsed .brand-logo-inner img{object-fit:contain}.app-sidebar__footer{display:flex;align-items:center;gap:.35rem;margin-top:auto;padding-top:.75rem;border-top:1px solid #e8edf3}.app-sidebar__footer-link{flex:1;min-width:0}.app-sidebar__collapse-btn{flex-shrink:0;display:flex;align-items:center;justify-content:center;width:32px;height:32px;border:1px solid #e2e8f0;border-radius:8px;background:#fff;color:#64748b;cursor:pointer;transition:background .15s,color .15s,border-color .15s}.app-sidebar__collapse-btn:hover{background:#f1f5f9;color:#334155;border-color:#cbd5e1}.app-sidebar__collapse-icon--flip{transform:rotate(180deg)}.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}.layout-header--landing{justify-content:stretch;align-items:stretch;padding:1.15rem 1.75rem 1.2rem;background:#fff;border-bottom-color:#e8edf3}.dashboard-landing-header{display:flex;align-items:center;justify-content:space-between;gap:1.25rem;width:100%;min-width:0}.dashboard-landing-header__intro{min-width:0;flex:1;display:flex;align-items:flex-start;gap:.85rem}.dashboard-landing-header__intro-text{min-width:0;flex:1}.layout-sidebar-toggle{flex-shrink:0;display:inline-flex;align-items:center;justify-content:center;width:40px;height:40px;padding:0;border:1px solid #e2e8f0;border-radius:10px;background:#fff;color:#475569;cursor:pointer;transition:background .15s ease,border-color .15s ease,color .15s ease}.layout-sidebar-toggle:hover{background:#f1f5f9;border-color:#cbd5e1;color:#1e293b}.layout-sidebar-toggle__icon{position:relative;display:block;width:16px;height:2px;background:currentColor;border-radius:1px}.layout-sidebar-toggle__icon:before,.layout-sidebar-toggle__icon:after{content:"";position:absolute;left:0;width:16px;height:2px;background:currentColor;border-radius:1px}.layout-sidebar-toggle__icon:before{top:-5px}.layout-sidebar-toggle__icon:after{top:5px}.layout-header__menu-toggle{margin-right:auto}.layout-header:not(.layout-header--landing){justify-content:flex-start;gap:.75rem}.layout-header:not(.layout-header--landing) .layout-header-welcome{position:static;transform:none;flex:1;max-width:none;text-align:left;pointer-events:auto}.layout-header:not(.layout-header--landing) .layout-header-logout{margin-left:0}.dashboard-landing-header__title{margin:0 0 .3rem;font-size:1.5rem;font-weight:700;line-height:1.25;color:#1a202c;letter-spacing:-.02em}.dashboard-landing-header__subtitle{margin:0;font-size:.9375rem;font-weight:400;line-height:1.45;color:#718096}.dashboard-landing-header__actions{display:flex;align-items:center;gap:.85rem;flex-shrink:0}.dashboard-landing-header__date{position:relative;display:inline-flex;align-items:center;gap:.5rem;padding:.5rem .75rem;border:1px solid #e2e8f0;border-radius:10px;background:#fff;color:#334155;font-size:.875rem;font-weight:500;font-family:inherit;cursor:pointer;transition:border-color .15s,box-shadow .15s}.dashboard-landing-header__date:hover{border-color:#cbd5e1;box-shadow:0 1px 3px #0f172a0f}.dashboard-landing-header__date-icon{display:flex;color:#64748b}.dashboard-landing-header__date-chevron{display:flex;color:#94a3b8;margin-left:.1rem}.dashboard-landing-header__date-input{position:absolute;top:0;right:0;bottom:0;left:0;opacity:0;width:100%;height:100%;cursor:pointer;pointer-events:none}.dashboard-landing-header__notify{position:relative;display:flex;align-items:center;justify-content:center;width:40px;height:40px;padding:0;border:none;border-radius:10px;background:transparent;color:#475569;cursor:pointer;transition:background .15s,color .15s}.dashboard-landing-header__notify:hover{background:#f1f5f9;color:#1e293b}.dashboard-landing-header__notify-badge{position:absolute;top:4px;right:4px;min-width:1.1rem;height:1.1rem;padding:0 .25rem;border-radius:999px;background:#ef4444;color:#fff;font-size:.625rem;font-weight:700;line-height:1.1rem;text-align:center;border:2px solid #fff}.dashboard-landing-header__avatar{width:44px;height:44px;border-radius:50%;overflow:hidden;flex-shrink:0;background:linear-gradient(135deg,var(--brand-action) 0%,#3b82f6 100%);box-shadow:0 2px 8px #1d5fb047;display:flex;align-items:center;justify-content:center}.dashboard-landing-header__avatar-initials{font-size:.875rem;font-weight:700;color:#fff;letter-spacing:.04em}.dashboard-landing-header__logout{display:flex;align-items:center;justify-content:center;width:40px;height:40px;padding:0;border:1px solid #e2e8f0;border-radius:10px;background:#fff;color:#64748b;cursor:pointer;transition:background .15s,color .15s,border-color .15s}.dashboard-landing-header__logout:hover{background:#fef2f2;border-color:#fecaca;color:#dc2626}.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}.app-sidebar:not(.app-sidebar--collapsed){width:230px}.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}.app-sidebar{width:100%;max-height:none}.app-sidebar--collapsed{width:100%}.app-sidebar__nav{max-height:220px}.app-sidebar__footer{flex-wrap:wrap}.app-sidebar__search-kbd{display:none}.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:not(.layout-header--landing) .layout-header-welcome{order:1}.layout-header__menu-toggle{order:0}.layout-header:not(.layout-header--landing) .layout-header-logout{order:2;margin-left:auto}.layout-header--landing{padding:1rem 1rem 1.1rem}.dashboard-landing-header{flex-direction:column;align-items:flex-start;gap:1rem}.dashboard-landing-header__actions{width:100%;flex-wrap:wrap;justify-content:flex-start}.dashboard-landing-header__title{font-size:1.25rem}.dashboard-landing-header__subtitle{font-size:.875rem}.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 phase batch" "actions actions 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-checkboxes{grid-area:batchwise;display:flex;flex-wrap:wrap;align-items:flex-end;gap:.75rem 1.5rem}.reports-filter-row-attendance .reports-attendance-checkboxes .reports-checkbox-field{margin:0}.reports-filter-row-attendance .reports-attendance-course{grid-area:course}.reports-filter-row-attendance .reports-attendance-phase{grid-area:phase}.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" "phase" "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:.6rem 1.25rem;font-size:.875rem;font-weight:600;font-family:inherit;line-height:1.25;border:1px solid rgba(148,163,184,.45);background:#0f172ae6;color:var(--text-main);display:inline-flex;align-items:center;justify-content:center;gap:.4rem;cursor:pointer;white-space:nowrap;box-shadow:none;text-decoration:none;transition:background .15s ease,border-color .15s ease,color .15s ease}.pill-button:hover:not(:disabled){border-color:#94a3b899;background:#1e293bf2}.pill-button:disabled{opacity:.55;cursor:not-allowed}.pill-button-primary{background:var(--brand-action);border-color:var(--brand-action);color:#fff}.pill-button-primary:hover:not(:disabled){background:var(--brand-action-hover);border-color:var(--brand-action-hover);color:#fff}.pill-button-sm{padding:.45rem .95rem;font-size:.8125rem}.pill-button-danger{border-color:#ef44448c;color:#fca5a5;background:transparent}.pill-button-danger:hover:not(:disabled){border-color:var(--danger);background:#ef44441f;color:#fecaca}.pill-button-soft{border-color:transparent;background:#94a3b824}.pill-button-soft:hover:not(:disabled){background:#94a3b838}.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:#3b82f6d9}.login-glass-field--dropdown:focus-within{border-bottom-color:#3b82f6d9}.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 #1d5fb08c}.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:#93c5fd}.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,#16263af0,#0f172aeb);border:1px solid rgba(59,130,246,.28);box-shadow:0 18px 40px #00000073,0 0 0 1px #93c5fd1a 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:#1d5fb038;color:#fff}.login-user-type-option.is-selected{background:#1d5fb061;color:#fff}.login-user-type-option.is-selected.is-highlighted{background:#1d5fb07a}@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:.65rem 1.35rem;border:none;border-radius:var(--radius-pill);font-size:.9rem;font-weight:600;letter-spacing:normal;text-transform:none;color:#fff;cursor:pointer;font-family:inherit;background:var(--brand-action);box-shadow:none;transition:background .15s ease}.login-glass-submit:hover:not(:disabled){background:var(--brand-action-hover)}.login-glass-submit:active:not(:disabled){background:var(--brand-action-hover)}.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:#0f172afa}[data-theme=light] .login-user-type-menu{background:#eff6ff}}.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] .app-sidebar__link{color:#475569}[data-theme=light] .app-sidebar__link:hover{background:#f1f5f9;color:#1e293b}[data-theme=light] .app-sidebar__link--active,[data-theme=light] .app-sidebar__link--active:hover{background:var(--brand-action);color:#fff}[data-theme=light] .app-sidebar__link--active:hover{background:var(--brand-action-hover)}[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--landing{background:#fff;border-bottom-color:#e8edf3}[data-theme=light] .dashboard-landing-header__title{color:#1a202c}[data-theme=light] .dashboard-landing-header__subtitle{color:#718096}[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:#0f172a}[data-theme=light] .pill-button:hover:not(:disabled){border-color:#94a3b8;background:#f8fafc;color:#0f172a}[data-theme=light] .pill-button-primary{background:var(--brand-action);color:#fff;border-color:var(--brand-action)}[data-theme=light] .pill-button-primary:hover:not(:disabled){background:var(--brand-action-hover);border-color:var(--brand-action-hover);color:#fff}[data-theme=light] .pill-button-danger{border-color:#fca5a5;color:#dc2626;background:#fff}[data-theme=light] .pill-button-danger:hover:not(:disabled){background:#fef2f2;border-color:#f87171;color:#991b1b}[data-theme=light] .pill-button-soft{color:#0f172a;background:#f1f5f9;border-color:transparent}[data-theme=light] .pill-button-soft:hover:not(:disabled){background:#e2e8f0;color:#0f172a}[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-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-glass-field:focus-within{border-bottom-color:#1d5fb0a6}[data-theme=light] .login-user-type-trigger:focus-visible{box-shadow:0 0 0 2px #1d5fb066}[data-theme=light] .login-user-type-chevron{color:#64748b}[data-theme=light] .login-user-type-chevron.is-open{color:var(--brand-action)}[data-theme=light] .login-user-type-menu{background:linear-gradient(180deg,#eff6ff,#dbeafe);border-color:#1d5fb047;box-shadow:0 18px 40px #0f172a14,0 0 0 1px #1d5fb01f 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:#1d5fb01f;color:var(--text-main)}[data-theme=light] .login-user-type-option.is-selected{background:#1d5fb033;color:#1e3a8a}[data-theme=light] .login-user-type-option.is-selected.is-highlighted{background:#1d5fb047}[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}.current-week-attendance-title-row{width:100%;align-items:flex-start}.open-in-new-window-btn{display:inline-flex;align-items:center;justify-content:center;width:2rem;height:2rem;padding:0;border:1px solid rgba(148,163,184,.35);border-radius:var(--radius-pill);background:#0f172a59;color:var(--text-muted);cursor:pointer;flex-shrink:0;transition:color .15s ease,border-color .15s ease,background .15s ease}.open-in-new-window-btn:hover:not(:disabled){color:var(--accent);border-color:#38bdf873;background:#38bdf81f}.open-in-new-window-btn:disabled{opacity:.45;cursor:not-allowed}[data-theme=light] .open-in-new-window-btn{background:#ffffffe6;border-color:#0f172a1f;color:#0f172a8c}[data-theme=light] .open-in-new-window-btn:hover:not(:disabled){color:#0c4a6e;border-color:#0e749059;background:#cfecf3a6}.modal-overlay-card-attendance-expanded{width:min(1080px,96vw)!important;max-height:min(96vh,100dvh - 1.5rem);overflow-y:auto;display:flex;flex-direction:column;padding-bottom:1.25rem}.attendance-expanded-header{flex-shrink:0}.attendance-batch-filters{flex-shrink:0;display:flex;flex-wrap:wrap;align-items:flex-start;gap:.65rem 1.25rem;padding:0 0 1rem;border-bottom:1px solid rgba(148,163,184,.2);margin-bottom:1rem}.attendance-batch-filters--below-chart{padding:1rem 0 0;margin-bottom:0;border-bottom:none;border-top:1px solid rgba(148,163,184,.2)}.attendance-batch-filters-label{font-size:.84rem;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.04em;padding-top:.2rem}.attendance-batch-filters-list{display:flex;flex-wrap:wrap;gap:.5rem 1rem}.attendance-batch-filter-item{display:inline-flex;align-items:center;gap:.4rem;font-size:.85rem;cursor:pointer;-webkit-user-select:none;user-select:none}.attendance-batch-filter-item input{width:1rem;height:1rem;accent-color:var(--accent)}.attendance-expanded-chart-wrap{flex-shrink:0;width:100%;min-height:340px;padding:0 .5rem;margin-bottom:.25rem}.attendance-expanded-chart-wrap .attendance-line-chart-wrap{width:100%}.attendance-expanded-chart-wrap .attendance-line-chart{width:100%;height:340px;min-height:340px;display:block}.performance-attendance-card-head{align-items:flex-start}.performance-attendance-column .performance-attendance-card-standalone .performance-attendance-card-head{margin-top:.45rem;margin-bottom:.15rem}.modal-overlay-card-assessment-expanded{width:min(1180px,96vw)!important;max-height:min(96vh,100dvh - 1.5rem);overflow-y:auto;display:flex;flex-direction:column;padding-bottom:1.25rem}.assessment-expanded-body{display:flex;flex-direction:row;gap:1.5rem;align-items:stretch;min-height:380px}.assessment-expanded-charts{flex:1 1 0;min-width:0;display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:1rem;align-items:start}.assessment-expanded-batches{flex:0 0 220px;border-left:1px solid rgba(148,163,184,.25);padding-left:1.25rem;display:flex;flex-direction:column;gap:.75rem}.assessment-expanded-batches-title{font-size:.78rem;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.04em}.assessment-expanded-batches-list{display:flex;flex-direction:column;gap:.5rem;max-height:min(52vh,420px);overflow-y:auto}.assessment-expanded-batch-item{display:flex;align-items:center;gap:.5rem;font-size:.88rem;cursor:pointer;-webkit-user-select:none;user-select:none;padding:.35rem 0}.assessment-expanded-batch-item input{width:1rem;height:1rem;accent-color:var(--accent);flex-shrink:0}.assessment-score-pie-chart{display:flex;flex-direction:column;align-items:center;gap:.65rem;padding:1rem .85rem;background:linear-gradient(165deg,#ffffff0f,#94a3b814);border-radius:14px;border:1px solid rgba(148,163,184,.18);box-shadow:0 12px 28px #0f172a1f,inset 0 1px #ffffff1f;transition:box-shadow .35s ease,transform .35s ease}.assessment-score-pie-chart:hover{box-shadow:0 16px 36px #0f172a29,inset 0 1px #ffffff29}.assessment-score-pie-title{font-size:.84rem;font-weight:600;text-align:center;line-height:1.35;max-width:100%;color:var(--text-main);letter-spacing:.01em;overflow:hidden;text-overflow:ellipsis;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical}.assessment-score-pie-visual{position:relative;width:100%;max-width:240px}.assessment-score-pie-svg{width:100%;height:auto;display:block;overflow:visible}.assessment-score-pie-floor-shadow{fill:#1e293b24}.assessment-score-pie-3d-group{transform-origin:center;animation:assessmentPieFloatIn .65s cubic-bezier(.22,1,.32,1) both}.assessment-score-pie-slice-wrap{transform-origin:center;transform-box:fill-box;animation:assessmentPieSliceIn .55s cubic-bezier(.22,1,.32,1) both;cursor:pointer;transition:transform .28s cubic-bezier(.22,1,.32,1),opacity .28s ease}.assessment-score-pie-slice-wrap.is-hovered{transform:scale(1.04) translateY(-3px)}.assessment-score-pie-slice-wrap.is-dimmed{opacity:.55}.assessment-score-pie-slice{transition:filter .28s ease,stroke-width .2s ease}.assessment-score-pie-slice-wrap.is-hovered .assessment-score-pie-slice{filter:brightness(1.08) saturate(1.05);stroke-width:2}.assessment-score-pie-slice-shadow{pointer-events:none}.assessment-score-pie-tooltip{position:absolute;transform:translate(-50%,calc(-100% - 10px));min-width:128px;padding:.5rem .65rem;border-radius:10px;background:#fffffff7;border:1px solid rgba(148,163,184,.35);box-shadow:0 10px 24px #0f172a2e,0 2px 6px #0f172a14;pointer-events:none;z-index:5;animation:assessmentTooltipIn .22s cubic-bezier(.22,1,.32,1) both;text-align:center}.assessment-score-pie-tooltip-label{display:block;font-size:.72rem;font-weight:600;color:#475569;margin-bottom:.15rem}.assessment-score-pie-tooltip-value{display:block;font-size:.8rem;color:#0f172a}.assessment-score-pie-tooltip-value strong{font-size:1rem;font-weight:700;color:#0f172a}.assessment-score-pie-tooltip-pct{display:block;font-size:.68rem;color:#64748b;margin-top:.1rem}.assessment-score-pie-legend{list-style:none;margin:0;padding:0;width:100%;font-size:.7rem;color:var(--text-muted)}.assessment-score-pie-legend li{display:flex;align-items:flex-start;gap:.4rem;margin-bottom:.28rem;padding:.2rem .35rem;border-radius:6px;cursor:default;transition:background .2s ease,opacity .2s ease}.assessment-score-pie-legend li.is-active{background:#94a3b824;opacity:1}.assessment-legend-swatch{width:10px;height:10px;border-radius:3px;flex-shrink:0;margin-top:.12rem;box-shadow:0 1px 3px #0f172a26}.assessment-score-pie-empty{min-height:140px;display:flex;align-items:center;justify-content:center;text-align:center;padding:1rem}@keyframes assessmentPieFloatIn{0%{opacity:0;transform:translateY(12px) scale(.94)}to{opacity:1;transform:translateY(0) scale(1)}}@keyframes assessmentPieSliceIn{0%{opacity:0;transform:scale(.88)}to{opacity:1;transform:scale(1)}}@keyframes assessmentTooltipIn{0%{opacity:0;transform:translate(-50%,calc(-100% - 4px)) scale(.92)}to{opacity:1;transform:translate(-50%,calc(-100% - 10px)) scale(1)}}[data-theme=light] .assessment-score-pie-chart{background:linear-gradient(165deg,#fff,#f8fafc);border-color:#94a3b847;box-shadow:0 12px 28px #0f172a14,inset 0 1px #ffffffe6}[data-theme=light] .assessment-score-pie-floor-shadow{fill:#0f172a14}@media(prefers-reduced-motion:reduce){.assessment-score-pie-3d-group,.assessment-score-pie-slice-wrap,.assessment-score-pie-tooltip{animation:none}.assessment-score-pie-slice-wrap,.assessment-score-pie-slice{transition:none}}@media(max-width:900px){.assessment-expanded-body{flex-direction:column}.assessment-expanded-batches{flex:none;border-left:none;border-top:1px solid rgba(148,163,184,.25);padding-left:0;padding-top:1rem}.assessment-expanded-charts{grid-template-columns:1fr}}.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}.mark-att-absentees-panel{display:flex;flex-wrap:wrap;align-items:flex-start;gap:1rem 1.25rem;margin-bottom:1.25rem;padding:1rem 1.1rem;border-radius:12px;border:1px solid rgba(148,163,184,.28);background:var(--bg-elevated)}.mark-att-absentees-field{flex:1;min-width:min(100%,280px)}.mark-att-absentees-field label{display:block;font-size:.88rem;font-weight:600;margin-bottom:.45rem;color:var(--text-main)}.mark-att-absentees-textarea{width:100%;min-height:4.5rem;padding:.65rem .75rem;border-radius:10px;border:1px solid rgba(148,163,184,.35);background:#0f172a59;color:var(--text-main);font-family:inherit;font-size:.88rem;line-height:1.45;resize:vertical;box-sizing:border-box}.mark-att-absentees-textarea:focus{outline:none;border-color:var(--brand-action);box-shadow:0 0 0 2px #1d5fb040}.mark-att-absentees-hint{margin:.45rem 0 0;font-size:.78rem;color:var(--text-muted);line-height:1.45}.mark-att-absentees-hint code{font-size:.76rem;padding:.1rem .35rem;border-radius:4px;background:#94a3b81f}.mark-att-absentees-actions{flex-shrink:0;display:flex;align-items:flex-end;padding-top:1.65rem}[data-theme=light] .mark-att-absentees-panel{background:#f8fafc;border-color:#e2e8f0}[data-theme=light] .mark-att-absentees-textarea{background:#fff;border-color:#cbd5e1}.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(7,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;height:28rem;min-height:28rem;margin-top:1rem;display:flex;flex-direction:column;overflow:hidden}.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-card .attendance-records-wrap{flex:1 1 auto;min-height:0;height:21rem;max-height:21rem;overflow-x:auto;overflow-y:auto}.attendance-records-card .attendance-records-wrap .table{width:max-content;min-width:100%}.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;height:28rem;min-height:28rem;margin-bottom:0;overflow:hidden}.report-results-card .card-header{flex-shrink:0}.report-results-card .attendance-records-wrap{flex:1 1 0;min-height:0}.feedback-form-row{display:grid;grid-template-columns:repeat(6,minmax(0,1fr)) auto;gap:.75rem;align-items:end}.feedback-form-row .field{margin-bottom:0}.feedback-form-action{align-self:end}@media(max-width:1300px){.feedback-form-row{grid-template-columns:repeat(3,minmax(0,1fr))}}@media(max-width:760px){.feedback-form-row{grid-template-columns:1fr}}.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}.update-attendance-sessions-card{overflow:hidden}.update-attendance-sessions-wrap{width:100%;overflow-x:auto;overflow-y:auto}.update-attendance-sessions-table{width:100%;min-width:100%;table-layout:fixed;margin-bottom:0}.update-attendance-sessions-table th,.update-attendance-sessions-table td{overflow-wrap:anywhere;word-break:break-word;vertical-align:top}.update-attendance-sessions-table th:nth-child(1),.update-attendance-sessions-table td:nth-child(1){width:30%}.update-attendance-sessions-table th:nth-child(2),.update-attendance-sessions-table td:nth-child(2){width:30%}.update-attendance-sessions-table th:nth-child(3),.update-attendance-sessions-table td:nth-child(3){width:18%}.update-attendance-sessions-table th:nth-child(4),.update-attendance-sessions-table td:nth-child(4){width:22%}.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,.dashboard-cards-land>.card.dashboard-card-land,.dashboard-cards-land>.performance-attendance-column{animation:dashboard-card-land-in 1.2s cubic-bezier(.22,1,.32,1) both}.dashboard-cards-land>*:nth-child(1){animation-delay:0ms}.dashboard-cards-land>*:nth-child(2){animation-delay:.14s}.dashboard-cards-land>*:nth-child(3){animation-delay:.28s}.dashboard-cards-land>*:nth-child(4){animation-delay:.42s}.dashboard-cards-land>*:nth-child(5){animation-delay:.56s}.dashboard-cards-land>*:nth-child(6){animation-delay:.7s}.dashboard-cards-land>*:nth-child(7){animation-delay:.84s}.dashboard-cards-land>*:nth-child(8){animation-delay:.98s}.dashboard-cards-land>*:nth-child(9){animation-delay:1.12s}.dashboard-cards-land>*:nth-child(10){animation-delay:1.26s}.dashboard-cards-land>*:nth-child(11){animation-delay:1.4s}.dashboard-cards-land>*:nth-child(12){animation-delay:1.54s}.dashboard-cards-land>*:nth-child(n+13){animation-delay:1.68s}.performance-dashboard-page .dash-landing{display:flex;flex-direction:column;gap:1.15rem;width:100%;max-width:100%;min-width:0;box-sizing:border-box}.dash-landing{display:flex;flex-direction:column;gap:1.15rem;width:100%;max-width:100%;min-width:0}.dash-landing-kpi-row{display:grid;grid-template-columns:repeat(5,minmax(0,1fr));gap:.85rem;align-items:stretch;width:100%;min-width:0}.dash-landing-kpi-row.dashboard-cards-land>.dash-landing-kpi{min-width:0;width:100%}.dash-landing-kpi.dashboard-card-land{box-shadow:0 1px 2px #0f172a0d}.dash-landing-kpi{position:relative;background:#fff;border:1px solid #e8edf3;border-radius:16px;padding:1rem 1.1rem .9rem;box-shadow:0 1px 2px #0f172a0d;display:flex;flex-direction:column;min-height:196px;height:100%;overflow:hidden;margin-bottom:0;box-sizing:border-box}.dash-landing-kpi__accent{position:absolute;top:0;left:0;right:0;height:3px;background:var(--kpi-accent);border-radius:16px 16px 0 0;z-index:2}.dash-landing-kpi__content{position:relative;z-index:2;display:flex;flex-direction:column;flex:1;min-height:0;width:100%}.dash-landing-kpi__main{display:flex;align-items:flex-start;gap:.7rem;padding-top:.35rem;flex:1;min-height:0}.dash-landing-kpi__icon{width:42px;height:42px;flex-shrink:0;border-radius:11px;display:inline-flex;align-items:center;justify-content:center;background:var(--kpi-icon-bg);color:var(--kpi-icon-color)}.dash-landing-kpi__icon .dash-kpi-glyph{display:block;width:22px;height:22px;flex-shrink:0}.dash-landing-kpi__copy{flex:1;min-width:0;padding-right:3.25rem}.dash-landing-kpi__title{margin:0 0 .35rem;font-size:.8125rem;font-weight:600;color:#334155;line-height:1.25}.dash-landing-kpi__value{margin:0 0 .15rem;font-size:2rem;font-weight:700;line-height:1.05;color:#020617;letter-spacing:-.03em}.dash-landing-kpi__sub{margin:0;font-size:.75rem;font-weight:500;color:#64748b;line-height:1.35}.dash-landing-kpi__footer{display:flex;align-items:flex-end;justify-content:flex-start;margin-top:auto;padding-top:.65rem;position:relative;z-index:3;min-height:1.85rem}.dash-landing-kpi__trend-spacer{flex:0 0 auto;min-width:0}.dash-landing-kpi__trend{display:inline-flex;align-items:center;flex-wrap:nowrap;gap:.25rem .4rem;padding:.35rem .65rem;border-radius:999px;font-size:.6875rem;font-weight:600;line-height:1.2;background:var(--kpi-trend-bg);color:var(--kpi-trend-text, var(--kpi-accent));max-width:calc(100% - 3.5rem);white-space:nowrap}.dash-landing-kpi__trend-pct{font-weight:700}.dash-landing-kpi__trend-note{font-weight:500;color:inherit;opacity:1}.dash-landing-kpi__trend--up{color:var(--kpi-trend-text, var(--kpi-accent))}.dash-landing-kpi__trend--down{color:#b91c1c;background:#fef2f2}.dash-landing-kpi__trend--neutral{color:var(--kpi-trend-text, var(--kpi-accent))}.dash-landing-kpi__trend--neutral .dash-landing-kpi__trend-note{font-weight:600}.dash-landing-kpi__watermark{position:absolute;right:-.35rem;bottom:-.55rem;display:flex;align-items:flex-end;justify-content:flex-end;color:var(--kpi-accent);opacity:.1;pointer-events:none;line-height:0;z-index:1}.dash-landing-kpi__watermark .dash-kpi-glyph--watermark{display:block;width:5.5rem;height:5.5rem}.dash-landing-kpi__trend svg{display:block;width:12px;height:12px;flex-shrink:0}.dash-landing-kpi--students-ref{box-shadow:0 1px 3px #0f172a14;padding-bottom:.85rem}.dash-landing-kpi--students-ref .dash-landing-kpi__accent{left:0;right:auto;width:38%;max-width:4.75rem;height:3px;border-radius:0 0 3px}.dash-landing-kpi--students-ref .dash-landing-kpi__main{padding-top:.5rem;flex:0 0 auto}.dash-landing-kpi--students-ref .dash-landing-kpi__icon{width:44px;height:44px;border-radius:10px;background:#e0e7ff;color:#2563eb}.dash-landing-kpi--students-ref .dash-landing-kpi__copy{padding-right:.25rem}.dash-landing-kpi--students-ref .dash-landing-kpi__title{margin-bottom:.28rem;color:#334155}.dash-landing-kpi--students-ref .dash-landing-kpi__value{margin-bottom:.2rem;font-size:1.875rem;color:#0f172a}.dash-landing-kpi--students-ref .dash-landing-kpi__sub{color:#64748b}.dash-landing-kpi--students-ref .dash-landing-kpi__footer{margin-top:auto;padding-top:.5rem;min-height:0;flex-shrink:0}.dash-landing-kpi--students-ref .dash-landing-kpi__trend{align-items:flex-start;gap:.4rem;padding:.4rem .55rem;border-radius:8px;background:#eff6ff;color:#2563eb;max-width:calc(100% - 2rem);white-space:normal;position:relative;z-index:2}.dash-landing-kpi--students-ref .dash-landing-kpi__trend-stack{display:flex;flex-direction:column;align-items:flex-start;gap:.08rem;min-width:0}.dash-landing-kpi--students-ref .dash-landing-kpi__trend-pct{font-size:.75rem;font-weight:700;line-height:1.15;color:#2563eb}.dash-landing-kpi--students-ref .dash-landing-kpi__trend-note{font-size:.625rem;font-weight:500;line-height:1.2;color:#64748b}.dash-landing-kpi--students-ref .dash-landing-kpi__trend svg{width:13px;height:13px;margin-top:.12rem;color:#2563eb;flex-shrink:0}.dash-landing-kpi--students-ref .dash-landing-kpi__watermark{left:auto;right:0;bottom:0;width:72%;max-width:8.5rem;height:auto;align-items:flex-end;justify-content:flex-end;opacity:1;color:#3b82f6;z-index:0;pointer-events:none}.dash-landing-kpi--students-ref .dash-landing-kpi__watermark .dash-kpi-glyph--chart-area{display:block;width:100%;height:3rem;max-height:3rem}.dash-landing-detail-row{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:.85rem;align-items:stretch;width:100%;min-width:0}.dash-landing-detail-row.dashboard-cards-land>.dash-landing-panel{min-width:0;width:100%;height:100%}.dash-landing-panel{display:flex;flex-direction:column;min-height:340px;height:100%;padding:1rem 1.05rem .9rem;margin-bottom:0;background:#fff;border:1px solid #e8edf3;border-radius:14px;box-shadow:0 2px 10px #0f172a0a;box-sizing:border-box;min-width:0}.performance-dashboard-page .dash-landing-panel{background:#fff;border:1px solid #e8edf3}.dash-landing-panel__title{margin:0 0 .85rem;font-size:.9375rem;font-weight:700;color:#0f172a}.dash-landing-summary-body{display:flex;align-items:center;gap:1rem;flex:1;min-height:0}.dash-landing-donut-wrap{flex-shrink:0}.dash-landing-donut{width:140px;height:140px;border-radius:50%;display:flex;align-items:center;justify-content:center}.dash-landing-donut-hole{width:72px;height:72px;border-radius:50%;background:#fff}.dash-landing-legend{list-style:none;margin:0;padding:0;flex:1;display:flex;flex-direction:column;gap:.55rem}.dash-landing-legend li{display:grid;grid-template-columns:10px 1fr auto;align-items:center;gap:.5rem;font-size:.8125rem}.dash-landing-legend__dot{width:10px;height:10px;border-radius:50%}.dash-landing-legend__label{color:#475569;font-weight:500}.dash-landing-legend__value{color:#0f172a;font-weight:700}.dash-landing-summary-banner{display:flex;align-items:center;gap:.5rem;margin-top:auto;padding:.65rem .85rem;border-radius:10px;background:#ecfdf5;color:#15803d;font-size:.8125rem;font-weight:600}.dash-landing-summary-banner svg{flex-shrink:0;color:#16a34a}.dash-landing-logins-card{width:100%;padding:1rem 1.15rem;border-radius:14px;border:1px solid #e2e8f0;background:#fff;box-shadow:0 1px 2px #0f172a0a}.dash-landing-logins-card__head{display:flex;align-items:center;gap:.5rem;margin-bottom:.75rem}.dash-landing-logins-card__icon{display:inline-flex;align-items:center;justify-content:center;width:28px;height:28px;border-radius:8px;background:#dbeafe;color:#1d4ed8;flex-shrink:0}.dash-landing-logins-card__title{margin:0;font-size:.875rem;font-weight:700;color:#0f172a}.dash-landing-logins-card__grid{display:grid;grid-template-columns:repeat(4,1fr);gap:.6rem}.dash-landing-logins-stat{display:flex;flex-direction:column;align-items:center;gap:.15rem;padding:.6rem .4rem;border-radius:10px;background:#f8fafc;border:1px solid #eef2f7}.dash-landing-logins-stat__value{font-size:1.15rem;font-weight:800;line-height:1.1;color:#1d4ed8}.dash-landing-logins-stat__label{font-size:.7rem;font-weight:600;color:#64748b;text-align:center}@media(max-width:640px){.dash-landing-logins-card__grid{grid-template-columns:repeat(2,1fr)}}[data-theme=dark] .dash-landing-logins-card{background:var(--bg-elevated, #1e293b);border-color:#94a3b840}[data-theme=dark] .dash-landing-logins-stat{background:#0f172a8c;border-color:#94a3b833}[data-theme=dark] .dash-landing-logins-card__title{color:#e2e8f0}[data-theme=dark] .dash-landing-logins-stat__value{color:#93c5fd}.dash-landing-batches-table{flex:1;min-height:0;overflow-y:auto}.dash-landing-batches-thead,.dash-landing-batches-row{display:grid;grid-template-columns:minmax(0,1.5fr) repeat(3,minmax(2.5rem,1fr));gap:.45rem .5rem;align-items:center}.dash-landing-batches-name-col{display:flex;flex-direction:column;align-items:flex-start;justify-content:flex-start;gap:.2rem;min-width:0;line-height:1.2}.dash-landing-batches-thead{font-size:.6875rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:#94a3b8;padding-bottom:.45rem;border-bottom:1px solid #f1f5f9;margin-bottom:.35rem}.dash-landing-batches-row{align-items:start;padding:.5rem 0;border-bottom:1px solid #f8fafc;font-size:.8125rem}.dash-landing-batches-name{display:block;width:100%;font-weight:600;color:#0f172a;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.dash-landing-batches-status{display:block;font-size:.6875rem;font-weight:600;line-height:1.15}.dash-landing-batches-status.is-active{color:#16a34a}.dash-landing-batches-status.is-inactive{color:#dc2626}.dash-landing-batches-num{font-weight:700;color:#334155;text-align:center}.dash-landing-batches-num.is-active{color:#16a34a}.dash-landing-batches-active-col{display:flex;flex-direction:column;align-items:center;gap:.2rem;padding-top:.15rem}.dash-landing-batches-bar{width:100%;max-width:56px;height:4px;background:#e2e8f0;border-radius:999px;overflow:hidden}.dash-landing-batches-bar-fill{height:100%;background:#9ca3af;border-radius:999px}.dash-landing-batches-bar-fill.is-active{background:#22c55e}.dash-landing-course-list{list-style:none;margin:0;padding:0;flex:1;display:flex;flex-direction:column;gap:.45rem;min-height:0;overflow-y:auto}.dash-landing-course-row{display:flex;align-items:center;justify-content:space-between;gap:.5rem;padding:.4rem 0;border-bottom:1px solid #f8fafc}.dash-landing-course-name{font-size:.8125rem;font-weight:500;color:#334155;min-width:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.dash-landing-course-badge{flex-shrink:0;min-width:1.75rem;padding:.15rem .5rem;border-radius:8px;font-size:.75rem;font-weight:700;text-align:center;color:#fff}.dash-landing-course-badge--modules{background:#a855f7}.dash-landing-course-badge--assessments{background:#ef4444}.dash-landing-panel__link{margin-top:.75rem;font-size:.8125rem;font-weight:600;text-decoration:none;display:inline-flex;align-items:center;gap:.25rem}.dash-landing-panel__link--blue{color:#2563eb}.dash-landing-panel__link--purple{color:#7c3aed}.dash-landing-panel__link--red{color:#dc2626}.dash-landing-panel__link:hover{text-decoration:underline}.dash-landing-empty{padding:.5rem 0;font-size:.8125rem}@media(max-width:1400px){.dash-landing-detail-row{grid-template-columns:repeat(2,minmax(0,1fr))}.dash-landing-panel{min-height:300px}}@media(max-width:1100px){.dash-landing-kpi-row{grid-template-columns:repeat(3,minmax(0,1fr))}}@media(max-width:900px){.dash-landing-kpi-row{grid-template-columns:repeat(2,minmax(0,1fr))}.dash-landing-detail-row{grid-template-columns:1fr}.dash-landing-summary-body{flex-direction:column;align-items:flex-start}.dash-landing-donut-wrap{align-self:center}}@media(max-width:560px){.dash-landing-kpi-row{grid-template-columns:1fr}.dash-landing-batches-thead,.dash-landing-batches-row{grid-template-columns:minmax(0,1fr) repeat(3,minmax(2rem,.85fr));font-size:.75rem}}.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,.dashboard-cards-land>.card.dashboard-card-land,.dashboard-cards-land>.performance-attendance-column,.dashboard-cards-land>*,.landing-card-land,.async-list-land>*,tbody.async-list-land>tr{animation:none!important;opacity:1!important;transform:none!important}}.performance-dashboard-page{font-size:1.0625rem;width:100%;max-width:100%;min-width:0;box-sizing:border-box}[data-theme=light] .performance-dashboard-page .dash-landing-kpi,[data-theme=light] .performance-dashboard-page .dash-landing-panel{background:#fff;border-color:#e8edf3;color:#0f172a}[data-theme=light] .performance-dashboard-page .dash-landing-kpi__title{color:#334155}[data-theme=light] .performance-dashboard-page .dash-landing-kpi__sub{color:#64748b}[data-theme=light] .performance-dashboard-page .dash-landing-kpi__value,[data-theme=light] .performance-dashboard-page .dash-landing-legend__value{color:#020617}.performance-dashboard-page .card-title{font-size:1.05rem}.performance-dashboard-page .overview-muted-line{font-size:.84rem}.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:.96rem;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):not(.overview-card-students--ref){background:linear-gradient(160deg,#bfdbfe8f,#dbeafe6b)}.performance-dashboard-page .overview-cards-row>.overview-card:nth-child(2):not(.overview-card-courses--ref){background:linear-gradient(160deg,#bbf7d08a,#dcfce766)}.performance-dashboard-page .overview-cards-row>.overview-card:nth-child(3):not(.performance-batches-card--ref){background:linear-gradient(160deg,#fde68a85,#fef3c761)}.performance-dashboard-page .overview-cards-row>.overview-card:nth-child(4):not(.overview-card-modules--ref){background:linear-gradient(160deg,#ddd6fe8f,#ede9fe6b)}.performance-dashboard-page .overview-cards-row>.overview-card:nth-child(5):not(.overview-card-assessments--ref){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--ref{position:relative;overflow:hidden;border-top:none!important;background:linear-gradient(165deg,#1e293b,#1e3a5f)!important;border:1px solid rgba(96,165,250,.4)!important;color:#f1f5f9;box-shadow:0 1px #ffffff14 inset,0 10px 22px #0f172a47}.overview-card-students-accent{position:absolute;top:0;left:0;width:38%;height:4px;background:#3b82f6;border-radius:0 0 3px;z-index:2}.overview-card-students-sparkline{position:absolute;right:0;bottom:0;width:72%;height:58%;min-height:4.5rem;pointer-events:none;z-index:0;opacity:.55}.overview-card-students-inner{position:relative;z-index:1;display:flex;flex-direction:column;flex:1;min-height:0}.overview-card-students-head{display:flex;align-items:flex-start;gap:.65rem;margin-bottom:.35rem}.overview-card-students-icon{width:2.35rem;height:2.35rem;border-radius:10px;display:inline-flex;align-items:center;justify-content:center;flex-shrink:0;background:#3b82f62e;color:#2563eb}.overview-card-students-title-block{min-width:0;flex:1}.overview-card-students-title{font-size:.88rem;font-weight:600;color:#cbd5e1;line-height:1.25;margin-bottom:.2rem}.overview-card-students--ref .students-count-large{font-size:clamp(2rem,3.4vw,2.5rem);font-weight:800;text-align:left;color:#f8fafc;letter-spacing:-.02em;line-height:1.05;margin:0}.overview-card-students-subtitle{margin:0 0 .5rem;font-size:.8rem;color:#94a3b8;line-height:1.3}.overview-card-students-growth{display:inline-flex;flex-wrap:wrap;align-items:center;gap:.3rem .45rem;align-self:flex-start;margin-bottom:.45rem;padding:.35rem .55rem;border-radius:8px;background:#3b82f61f;border:1px solid rgba(59,130,246,.2)}.overview-card-students-growth-icon{display:inline-flex;color:#2563eb}.overview-card-students-growth-pct{font-size:.82rem;font-weight:700;color:#2563eb;line-height:1}.overview-card-students-growth-note{flex:1 0 100%;font-size:.62rem;color:#64748b;line-height:1.2;margin-left:1.35rem}.overview-card-students--ref .overview-students-by-course{position:relative;z-index:1}.overview-card-students--ref .overview-students-by-course-n{color:#cbd5e1}.overview-students-by-course{margin-top:.55rem;max-height:7.25rem;overflow-y:auto;display:flex;flex-direction:column;gap:0;padding:0 .1rem;text-align:left}.overview-students-by-course-row{display:flex;justify-content:space-between;align-items:baseline;gap:.45rem;font-size:.7rem;line-height:1.28;font-weight:500;padding:.38rem 0;border-bottom:1px solid rgba(148,163,184,.38)}.overview-students-by-course-row:last-child{border-bottom:none;padding-bottom:.12rem}.overview-students-by-course-name{flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-weight:600}.overview-students-by-course-row:nth-child(7n+1) .overview-students-by-course-name{color:#1d4ed8}.overview-students-by-course-row:nth-child(7n+2) .overview-students-by-course-name{color:#047857}.overview-students-by-course-row:nth-child(7n+3) .overview-students-by-course-name{color:#a16207}.overview-students-by-course-row:nth-child(7n+4) .overview-students-by-course-name{color:#b45309}.overview-students-by-course-row:nth-child(7n+5) .overview-students-by-course-name{color:#7c3aed}.overview-students-by-course-row:nth-child(7n+6) .overview-students-by-course-name{color:#be185d}.overview-students-by-course-row:nth-child(7n+7) .overview-students-by-course-name{color:#0f766e}.overview-students-by-course-n{flex-shrink:0;font-variant-numeric:tabular-nums;color:var(--text-muted);opacity:.95}.overview-card-courses--ref{position:relative;overflow:hidden;border-top:none!important;background:linear-gradient(165deg,#1e293b,#142e24)!important;border:1px solid rgba(34,197,94,.32)!important;color:#f1f5f9;box-shadow:0 1px #ffffff0f inset,0 10px 22px #0f172a42;display:flex;flex-direction:column;min-height:0}.overview-card-courses-accent{position:absolute;top:0;left:0;width:38%;height:4px;background:#22c55e;border-radius:0 0 3px;z-index:2}.overview-course-overview-head{display:flex;align-items:center;gap:.4rem;margin-bottom:.45rem;position:relative;z-index:1}.overview-course-overview-icon{width:1.75rem;height:1.75rem;border-radius:8px;display:inline-flex;align-items:center;justify-content:center;flex-shrink:0;background:#3b82f624;color:#2563eb}.overview-course-overview-icon svg{width:13px;height:13px}.overview-course-overview-title{font-size:.84rem;font-weight:700;color:#f8fafc;line-height:1.15}.overview-course-overview-body{display:grid;grid-template-columns:auto 1fr;gap:.5rem .65rem;align-items:center;position:relative;z-index:1;flex:1;min-height:0}.overview-course-donut-wrap{display:flex;align-items:center;justify-content:center}.overview-course-donut{width:5.5rem;height:5.5rem;border-radius:50%;display:grid;place-items:center;position:relative}.overview-course-donut-hole{width:3.55rem;height:3.55rem;border-radius:50%;background:#fff;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;box-shadow:inset 0 0 0 1px #94a3b826}.overview-course-donut-value{font-size:1.02rem;font-weight:800;color:#0f172a;line-height:1.05;letter-spacing:-.02em}.overview-course-donut-label{margin-top:.1rem;font-size:.56rem;font-weight:500;color:#64748b;line-height:1.1}.overview-course-stats{display:flex;flex-direction:column;gap:.32rem;min-width:0}.overview-course-stat-row{display:grid;grid-template-columns:auto 1fr auto;align-items:center;gap:.35rem .4rem;padding:.32rem .45rem;border-radius:8px;background:#94a3b81f}.overview-course-stat-dot{width:.45rem;height:.45rem;border-radius:999px;flex-shrink:0}.overview-course-stat-dot--active{background:#22c55e}.overview-course-stat-dot--inactive{background:#f59e0b}.overview-course-stat-dot--total{background:#94a3b8}.overview-course-stat-label{font-size:.72rem;font-weight:600;color:#cbd5e1;line-height:1.2;min-width:0}.overview-course-stat-value{font-size:.78rem;font-weight:700;font-variant-numeric:tabular-nums;line-height:1.1}.overview-course-stat-value--active{color:#22c55e}.overview-course-stat-value--inactive{color:#f59e0b}.overview-course-stat-value--total{color:#e2e8f0}.overview-course-stat-badge{display:inline-flex;align-items:center;gap:.35rem;padding:.34rem .5rem;border-radius:8px;background:#22c55e24;font-size:.72rem;font-weight:700;color:#22c55e;line-height:1.2}.overview-course-stat-badge-icon{display:inline-flex;color:#16a34a}.performance-dashboard-page .overview-card-courses--ref.overview-card{background:linear-gradient(165deg,#1e293b,#142e24)!important;border:1px solid rgba(34,197,94,.32)!important}[data-theme=light] .overview-card-courses--ref{background:linear-gradient(165deg,#fff,#f0fdf4)!important;border:1px solid rgba(34,197,94,.38)!important;color:#0f172a;box-shadow:0 1px #fffffffa inset,0 12px 24px #1665341a}[data-theme=light] .overview-course-overview-title{color:#0f172a}[data-theme=light] .overview-course-stat-row{background:#f1f5f9}[data-theme=light] .overview-course-stat-label{color:#334155}[data-theme=light] .overview-course-stat-value--total{color:#0f172a}[data-theme=light] .overview-course-stat-badge{background:#dcfce7;color:#15803d}[data-theme=light] .overview-course-stat-badge-icon{color:#16a34a}[data-theme=light] .performance-dashboard-page .overview-card-courses--ref.overview-card{background:linear-gradient(165deg,#fff,#f0fdf4)!important;border:1px solid rgba(34,197,94,.38)!important}html:not([data-theme=light]) .overview-course-donut-hole{background:#0f172a;box-shadow:inset 0 0 0 1px #94a3b833}html:not([data-theme=light]) .overview-course-donut-value{color:#f8fafc}html:not([data-theme=light]) .overview-course-donut-label{color:#94a3b8}.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] .overview-card-students--ref{background:linear-gradient(165deg,#fff,#eef5ff)!important;border:1px solid rgba(147,197,253,.55)!important;color:#0f172a;box-shadow:0 1px #fffffffa inset,0 12px 26px #1e40af24}[data-theme=light] .overview-card-students--ref .overview-card-students-title{color:#334155}[data-theme=light] .overview-card-students--ref .students-count-large{color:#020617}[data-theme=light] .overview-card-students--ref .overview-card-students-subtitle{color:#475569}[data-theme=light] .overview-card-students--ref .overview-card-students-icon{background:#3b82f624;color:#1d4ed8}[data-theme=light] .overview-card-students--ref .overview-students-by-course-n{color:#475569}[data-theme=light] .overview-card-students--ref .overview-students-by-course-row{border-bottom-color:#94a3b859}[data-theme=light] .overview-card-students--ref .overview-card-students-sparkline{opacity:.7}[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--ref{position:relative;overflow:hidden;border-top:none!important;background:linear-gradient(165deg,#1e293b,#292419)!important;border:1px solid rgba(251,191,36,.35)!important;color:#f1f5f9;box-shadow:0 1px #ffffff0f inset,0 10px 22px #0f172a42;display:flex;flex-direction:column;min-height:0}.overview-card-batches-accent{position:absolute;top:0;left:0;width:38%;height:4px;background:#f59e0b;border-radius:0 0 3px;z-index:2}.overview-card-batches-head{display:flex;align-items:center;justify-content:space-between;gap:.4rem;margin-bottom:.35rem;position:relative;z-index:1}.overview-card-batches-head-left{display:flex;align-items:center;gap:.4rem;min-width:0}.overview-card-batches-icon{width:1.75rem;height:1.75rem;border-radius:8px;display:inline-flex;align-items:center;justify-content:center;flex-shrink:0;background:#fbbf2438;color:#d97706}.overview-card-batches-icon svg{width:13px;height:13px}.overview-card-batches-title{font-size:.84rem;font-weight:700;color:#f8fafc;line-height:1.15;letter-spacing:.01em}.batches-overview-table{position:relative;z-index:1;flex:0 0 auto;min-height:0;padding:0;gap:0;overflow:visible}.batches-overview-thead,.batches-overview-row{display:grid;grid-template-columns:minmax(0,1.35fr) .55fr .7fr .65fr;gap:.2rem .35rem;align-items:center}.batches-overview-thead{padding:0 0 .22rem;margin-bottom:.08rem;border-bottom:1px solid rgba(148,163,184,.35);font-size:.62rem;font-weight:600;color:#94a3b8;text-transform:none;letter-spacing:.02em}.batches-overview-thead span:not(:first-child){text-align:center}.batches-overview-row{padding:.26rem 0;border-bottom:1px solid rgba(148,163,184,.28)}.batches-overview-row:last-child{border-bottom:none}.batches-overview-batch-col{min-width:0}.batches-overview-name{font-size:.72rem;font-weight:700;color:#f8fafc;line-height:1.15;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.batches-row-status{font-size:.62rem;margin-top:.04rem;line-height:1.1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.batches-row-status.active{color:#22c55e;font-weight:600}.batches-row-status.inactive{color:#ef4444;font-weight:500}.batches-overview-num{font-size:.72rem;font-weight:700;color:#f1f5f9;text-align:center;font-variant-numeric:tabular-nums;line-height:1.1}.batches-overview-active-col{display:flex;flex-direction:column;align-items:center;gap:.1rem;min-width:0}.batches-overview-active-col .batches-mini-track{width:100%;max-width:2.65rem}.performance-batches-card--ref .batches-mini-track{height:3px;border-radius:999px;background:#9ca3af66;overflow:hidden}.batches-mini-track{height:5px;border-radius:999px;background:#9ca3af66;overflow:hidden}.batches-mini-fill{height:100%;background:#9ca3af;border-radius:999px}.batches-mini-fill.active{background:#22c55e}.batches-overview-empty{padding:.2rem 0;font-size:.62rem}.overview-card-modules--ref,.overview-card-assessments--ref{position:relative;overflow:hidden;border-top:none!important;display:flex;flex-direction:column;min-height:0}.overview-card-modules--ref{background:linear-gradient(165deg,#1e293b,#2e1f4a)!important;border:1px solid rgba(167,139,250,.35)!important;color:#f1f5f9;box-shadow:0 1px #ffffff0f inset,0 10px 22px #0f172a42}.overview-card-assessments--ref{background:linear-gradient(165deg,#1e293b,#3b1c1c)!important;border:1px solid rgba(248,113,113,.35)!important;color:#f1f5f9;box-shadow:0 1px #ffffff0f inset,0 10px 22px #0f172a42}.overview-card-modules-accent,.overview-card-assessments-accent{position:absolute;top:0;left:0;width:38%;height:4px;border-radius:0 0 3px;z-index:2}.overview-card-modules-accent{background:#8b5cf6}.overview-card-assessments-accent{background:#ef4444}.overview-course-count-head{display:flex;align-items:center;gap:.4rem;margin-bottom:.4rem;position:relative;z-index:1}.overview-course-count-icon{width:1.75rem;height:1.75rem;border-radius:8px;display:inline-flex;align-items:center;justify-content:center;flex-shrink:0}.overview-course-count-icon svg{width:13px;height:13px}.overview-course-count-icon--modules{background:#8b5cf638;color:#7c3aed}.overview-course-count-icon--assessments{background:#ef444433;color:#dc2626}.overview-course-count-title{font-size:.84rem;font-weight:700;color:#f8fafc;line-height:1.15;letter-spacing:.01em}.overview-course-count-list{position:relative;z-index:1;flex:0 0 auto;display:flex;flex-direction:column;gap:0;overflow:visible}.overview-course-count-row{display:flex;align-items:center;justify-content:space-between;gap:.45rem;padding:.38rem 0;border-bottom:1px solid rgba(148,163,184,.28)}.overview-course-count-row:last-child{border-bottom:none}.overview-course-count-name{flex:1;min-width:0;font-size:.76rem;font-weight:500;color:#cbd5e1;line-height:1.2;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.overview-course-count-badge{flex-shrink:0;min-width:1.65rem;padding:.12rem .45rem;border-radius:999px;font-size:.74rem;font-weight:700;text-align:center;font-variant-numeric:tabular-nums;line-height:1.2}.overview-course-count-badge--modules{background:#8b5cf638;color:#ddd6fe}.overview-course-count-badge--assessments{background:#ef444433;color:#fecaca}.overview-card-modules--ref .overview-course-count-badge--modules{color:#c4b5fd}.overview-card-assessments--ref .overview-course-count-badge--assessments{color:#fca5a5}.overview-course-count-empty{padding:.2rem 0;font-size:.62rem}.performance-dashboard-page .overview-card-modules--ref.overview-card{background:linear-gradient(165deg,#1e293b,#2e1f4a)!important;border:1px solid rgba(167,139,250,.35)!important}.performance-dashboard-page .overview-card-assessments--ref.overview-card{background:linear-gradient(165deg,#1e293b,#3b1c1c)!important;border:1px solid rgba(248,113,113,.35)!important}[data-theme=light] .overview-card-modules--ref{background:linear-gradient(165deg,#fff,#f5f3ff)!important;border:1px solid rgba(167,139,250,.4)!important;color:#0f172a;box-shadow:0 1px #fffffffa inset,0 12px 24px #5b21b61a}[data-theme=light] .overview-card-assessments--ref{background:linear-gradient(165deg,#fff,#fff5f5)!important;border:1px solid rgba(248,113,113,.4)!important;color:#0f172a;box-shadow:0 1px #fffffffa inset,0 12px 24px #b91c1c1a}[data-theme=light] .overview-card-modules--ref .overview-course-count-title,[data-theme=light] .overview-card-assessments--ref .overview-course-count-title{color:#0f172a}[data-theme=light] .overview-card-modules--ref .overview-course-count-name,[data-theme=light] .overview-card-assessments--ref .overview-course-count-name{color:#475569}[data-theme=light] .overview-card-modules--ref .overview-course-count-row,[data-theme=light] .overview-card-assessments--ref .overview-course-count-row{border-bottom-color:#e2e8f0f2}[data-theme=light] .overview-course-count-badge--modules{background:#ede9fe;color:#6d28d9}[data-theme=light] .overview-course-count-badge--assessments{background:#fee2e2;color:#b91c1c}[data-theme=light] .overview-course-count-icon--modules{background:#ede9fef2;color:#7c3aed}[data-theme=light] .overview-course-count-icon--assessments{background:#fee2e2f2;color:#dc2626}[data-theme=light] .performance-dashboard-page .overview-card-modules--ref.overview-card{background:linear-gradient(165deg,#fff,#f5f3ff)!important;border:1px solid rgba(167,139,250,.4)!important}[data-theme=light] .performance-dashboard-page .overview-card-assessments--ref.overview-card{background:linear-gradient(165deg,#fff,#fff5f5)!important;border:1px solid rgba(248,113,113,.4)!important}[data-theme=light] .performance-batches-card--ref{background:linear-gradient(165deg,#fff,#fffbeb)!important;border:1px solid rgba(251,191,36,.45)!important;color:#0f172a;box-shadow:0 1px #fffffffa inset,0 12px 24px #78350f1a}[data-theme=light] .overview-card-batches-title,[data-theme=light] .performance-batches-card--ref .batches-overview-name{color:#0f172a}[data-theme=light] .batches-overview-thead{color:#64748b;border-bottom-color:#94a3b866}[data-theme=light] .performance-batches-card--ref .batches-overview-num{color:#0f172a}[data-theme=light] .performance-batches-card--ref .batches-overview-row{border-bottom-color:#e2e8f0f2}[data-theme=light] .overview-card-batches-icon{background:#fef3c7f2;color:#d97706}.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:flex-start;align-items:center;gap:.75rem;flex-wrap:wrap}.performance-filter-radios-stack{display:flex;flex-direction:column;align-items:flex-start;margin-bottom:.45rem}.performance-filter-bar--ref{gap:.65rem;width:100%;padding:.7rem .9rem;border-radius:12px;border:1px solid #e2e8f0;background:#fff;box-shadow:0 1px 3px #0f172a0f}.performance-filter-chip-row{display:flex;flex-wrap:wrap;align-items:center;gap:.55rem .65rem;width:100%}.performance-filter-label{display:inline-flex;align-items:center;gap:.45rem;flex-shrink:0}.performance-filter-label-icon{width:2rem;height:2rem;border-radius:8px;display:inline-flex;align-items:center;justify-content:center;flex-shrink:0}.performance-filter-label-icon--course{background:#3b82f624;color:#2563eb}.performance-filter-label-icon--phase{background:#a855f724;color:#7c3aed}.performance-filter-label-text{font-size:.92rem;font-weight:700;color:#0f172a;line-height:1.2;white-space:nowrap}.performance-filter-chips{display:flex;flex-wrap:wrap;align-items:center;gap:.45rem;min-width:0;flex:1}.performance-filter-chip{position:relative;display:inline-flex;align-items:center;gap:.42rem;padding:.45rem .85rem;border-radius:10px;border:1px solid #e2e8f0;background:#fff;color:#475569;font-size:.86rem;font-weight:500;line-height:1.2;cursor:pointer;transition:border-color .18s ease,background-color .18s ease,color .18s ease,box-shadow .18s ease}.performance-filter-chip input{position:absolute;opacity:0;width:0;height:0;margin:0;pointer-events:none}.performance-filter-chip-swatch{width:.5rem;height:.5rem;border-radius:999px;flex-shrink:0}.performance-filter-chip-text{white-space:nowrap}.performance-filter-chip:hover{border-color:#cbd5e1;background:#f8fafc}.performance-filter-chip.is-selected,.performance-filter-chip:has(input:checked){border-color:#93c5fd;background:#eff6ff;color:#047857;font-weight:600;box-shadow:0 1px 3px #3b82f61f}.performance-filter-chip.is-selected .performance-filter-chip-swatch,.performance-filter-chip:has(input:checked) .performance-filter-chip-swatch{box-shadow:0 0 0 1px #ffffffd9}html:not([data-theme=light]) .performance-filter-label-text{color:#e2e8f0}html:not([data-theme=light]) .performance-filter-bar--ref{background:#0f172ae0;border-color:#94a3b852}html:not([data-theme=light]) .performance-filter-chip{background:#0f172ab8;border-color:#94a3b859;color:#94a3b8}html:not([data-theme=light]) .performance-filter-chip.is-selected,html:not([data-theme=light]) .performance-filter-chip:has(input:checked){background:#1e3a8a59;border-color:#60a5fa8c;color:#bbf7d0}html:not([data-theme=light]) .performance-filter-chip:hover{background:#1e293be6;border-color:#94a3b880}.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-attendance-column{display:grid;grid-template-rows:minmax(0,1fr) auto;gap:.55rem;height:100%;min-height:0;align-self:stretch}.performance-attendance-column .performance-attendance-card-standalone{display:flex;flex-direction:column;min-height:0;margin-top:0;padding-top:0;height:100%}.performance-attendance-column .performance-attendance-card-standalone .attendance-trend-panel--card{flex:1;min-height:0;display:flex;flex-direction:column;justify-content:flex-start;gap:0}.performance-attendance-column .performance-attendance-card-standalone .attendance-trend-panel-chart{flex:0 0 auto;min-height:0;display:block}.performance-attendance-column .performance-attendance-card-standalone .attendance-trend-panel-chart .attendance-line-chart-wrap{flex:none;min-height:unset;height:auto;padding:.4rem .45rem .12rem}.performance-attendance-column .performance-attendance-card-standalone .attendance-line-chart--compact{display:block;width:100%;height:auto;max-height:none}.performance-attendance-column .performance-attendance-card-standalone .attendance-line-footer{margin-top:0;line-height:1.15}.performance-attendance-column .performance-attendance-card-standalone .attendance-trend-panel--card .attendance-batch-filters--below-chart{flex-shrink:0;margin:2lh 0 0;padding:.4rem 0 0;border-top:1px solid rgba(148,163,184,.2)}.performance-attendance-column .performance-attendance-card-standalone .attendance-batch-filters-list{gap:.35rem .6rem}.performance-attendance-column .performance-attendance-card-standalone .attendance-batch-filter-item{font-size:.8rem}.performance-dashboard-page .attendance-batch-filters-label{font-size:.84rem}.performance-dashboard-page .attendance-line-footer{font-size:.82rem}.attendance-trend-panel--modal{display:flex;flex-direction:column;flex:1;min-height:0}.performance-attendance-column .performance-kpi-row{flex-shrink:0}.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-dashboard-page .overview-card-students--ref.overview-card{background:linear-gradient(165deg,#1e293b,#1e3a5f)!important;border:1px solid rgba(96,165,250,.4)!important;color:#f1f5f9}.performance-dashboard-page .overview-card.performance-batches-card--ref{background:linear-gradient(165deg,#1e293b,#292419)!important;border:1px solid rgba(251,191,36,.35)!important;color:#f1f5f9}.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-list{display:flex;flex-direction:column;gap:.5rem;flex:1;min-height:0;overflow-y:auto;overflow-x:hidden;padding-right:.15rem;align-content:start}.performance-batch-progress-card .batch-progress-list-row--compact{grid-template-columns:34px minmax(0,1fr) minmax(88px,auto) minmax(72px,1fr) auto 20px;gap:.45rem .5rem;padding:.62rem .7rem;min-height:0;background:#fffffff5;border:1px solid rgba(226,232,240,.95);box-shadow:0 1px 4px #0f172a0f}.performance-batch-progress-card .batch-progress-list-row--compact .batch-progress-list-row-icon{width:34px;height:34px;border-radius:9px}.performance-batch-progress-card .batch-progress-list-row--compact .batch-progress-list-row-name{font-size:.8rem;font-weight:700;color:#0f172a;text-shadow:none}.performance-batch-progress-card .batch-progress-list-row--compact .batch-progress-list-row-students{font-size:.74rem;margin-top:.15rem}.performance-batch-progress-card .batch-progress-list-row--compact .batch-progress-list-stat-value{font-size:.88rem}.performance-batch-progress-card .batch-progress-list-row--compact .batch-progress-list-stat-label{font-size:.68rem}.performance-batch-progress-card .batch-progress-list-row--compact .batch-progress-list-row-stats{gap:.25rem}.performance-batch-progress-card .batch-progress-list-row--compact .batch-progress-list-pct{font-size:.72rem;min-width:2.25rem}.performance-batch-progress-card .batch-progress-list-row--compact .batch-progress-list-badge{font-size:.62rem;padding:.2rem .45rem;white-space:nowrap}.performance-batch-progress-card .batch-progress-list-row--compact .batch-progress-list-bar-track{height:6px}.performance-dashboard-page .performance-batch-progress-card .batch-progress-list-row--compact:hover{border-color:#cbd5e1;box-shadow:0 3px 10px #2563eb1a}[data-theme=dark] .performance-dashboard-page .performance-batch-progress-card .batch-progress-list-row--compact{background:#0f172ab8;border-color:#94a3b838}[data-theme=dark] .performance-dashboard-page .performance-batch-progress-card .batch-progress-list-row--compact .batch-progress-list-row-name{color:var(--text-main)}.performance-assessment-card{border-top:4px solid #22c55e}.performance-assessment-card--wide{grid-column:1 / -1}.performance-assessment-card-actions{justify-content:flex-end;margin-bottom:.15rem}.assessment-performance-panel{display:flex;flex-direction:column;gap:1.15rem;margin-top:-.2rem}.assessment-performance-main{display:grid;grid-template-columns:minmax(280px,1fr) minmax(320px,1.35fr);grid-template-rows:auto 1fr;gap:.35rem 1rem;align-items:stretch}.assessment-section-title{margin:0 0 .75rem;font-size:.98rem;font-weight:700;color:#0f172a;letter-spacing:-.01em}.assessment-overview-section{grid-column:1;grid-row:2;display:flex;flex-direction:column;min-width:0;height:100%;align-self:start}.assessment-overview-head{grid-column:1;grid-row:1;display:flex;align-items:center;min-height:1.65rem;margin:-.45rem 0 0;flex-shrink:0;align-self:end}.assessment-overview-head .assessment-section-title{margin:0}.assessment-overview-list{display:flex;flex-direction:column;gap:.65rem;flex:1}.assessment-overview-card{display:grid;grid-template-columns:44px minmax(0,1fr) 64px;align-items:center;gap:.75rem;padding:.8rem .95rem;min-height:72px;border-radius:12px;background:#fff;border:1px solid #e2e8f0;box-shadow:0 2px 8px #0f172a0a;transition:box-shadow .2s ease,border-color .2s ease}.assessment-overview-card:hover{border-color:#cbd5e1;box-shadow:0 6px 16px #2563eb14}.assessment-overview-icon{width:44px;height:44px;border-radius:11px;display:inline-flex;align-items:center;justify-content:center;flex-shrink:0}.assessment-overview-body{min-width:0;display:flex;flex-direction:column;justify-content:center}.assessment-overview-title-row{display:flex;flex-wrap:wrap;align-items:center;gap:.4rem .5rem}.assessment-overview-name{margin:0;font-size:.94rem;font-weight:700;color:#0f172a;line-height:1.25}.assessment-overview-badge{font-size:.74rem;font-weight:600;padding:.15rem .45rem;border-radius:999px;white-space:nowrap}.assessment-overview-meta{margin:.3rem 0 0;font-size:.82rem;color:#64748b}.assessment-overview-meta strong{color:#0f172a;font-weight:700}.assessment-score-ring{flex-shrink:0}.assessment-score-ring-progress{transition:stroke-dashoffset .6s cubic-bezier(.4,0,.2,1)}.assessment-score-ring-label{font-size:11px;font-weight:700;fill:#334155}.assessment-view-all-btn{margin-top:auto;width:100%;flex-shrink:0;display:inline-flex;align-items:center;justify-content:center;gap:.35rem;padding:.6rem 1.25rem;border-radius:var(--radius-pill);border:1px solid #e2e8f0;background:#fff;color:#334155;font-size:.875rem;font-weight:600;font-family:inherit;cursor:pointer;box-shadow:none;transition:background .15s ease,border-color .15s ease,color .15s ease}.assessment-view-all-btn:hover{background:#f8fafc;border-color:#cbd5e1;color:#0f172a}.assessment-trend-section{grid-column:2;grid-row:2;display:flex;flex-direction:column;min-width:0;height:100%;padding:.75rem 1rem .85rem;border-radius:12px;background:#fff;border:1px solid #e2e8f0;box-shadow:0 2px 8px #0f172a0a;align-self:start}.assessment-trend-head{display:flex;align-items:center;justify-content:space-between;gap:.5rem;min-height:2rem;margin-bottom:.55rem;flex-shrink:0}.assessment-trend-head .assessment-section-title{margin-bottom:0}.assessment-trend-filter select{border:1px solid #e2e8f0;border-radius:8px;padding:.35rem 1.75rem .35rem .6rem;font-size:.76rem;font-weight:500;color:#475569;background:#fff url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath d='M3 5l3 3 3-3' fill='none' stroke='%2364748b' stroke-width='1.5'/%3E%3C/svg%3E") no-repeat right .45rem center;-webkit-appearance:none;-moz-appearance:none;appearance:none;cursor:pointer}.assessment-trend-chart-wrap{width:100%;overflow-x:auto;flex:1;display:flex;align-items:center;min-height:0}.assessment-trend-chart{width:100%;min-width:280px;height:auto;display:block}.assessment-trend-grid-line{stroke:#f1f5f9;stroke-width:1}.assessment-trend-y-label{font-size:11px;fill:#94a3b8}.assessment-trend-line{stroke:#3b82f6;stroke-width:2.5;stroke-linecap:round;stroke-linejoin:round}.assessment-trend-area{opacity:1}.assessment-trend-point-dot{fill:#fff;stroke:#3b82f6;stroke-width:2.5}.assessment-trend-point-value{font-size:12px;font-weight:700;fill:#1d4ed8}.assessment-trend-x-label{font-size:10px;fill:#64748b}.assessment-trend-empty{padding:2rem 0;text-align:center}.assessment-summary-section{padding-top:.15rem}.assessment-summary-cards{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:.75rem}.assessment-summary-card{display:flex;align-items:flex-start;gap:.7rem;padding:.9rem 1rem;border-radius:12px;background:#fff;border:1px solid #e2e8f0;box-shadow:0 2px 8px #0f172a0a}.assessment-summary-icon{width:40px;height:40px;border-radius:10px;display:inline-flex;align-items:center;justify-content:center;flex-shrink:0}.assessment-summary-icon--best{background:#dcfce7;color:#16a34a}.assessment-summary-icon--improve{background:#ffedd5;color:#ea580c}.assessment-summary-icon--total{background:#dbeafe;color:#2563eb}.assessment-summary-label{margin:0;font-size:.78rem;font-weight:600;color:#64748b}.assessment-summary-value{margin:.2rem 0 0;font-size:.92rem;font-weight:700;color:#0f172a;line-height:1.3}.assessment-summary-value--lg{font-size:1.42rem;letter-spacing:-.02em}.assessment-summary-hint{margin:.2rem 0 0;font-size:.78rem;font-weight:500}.assessment-summary-hint--best{color:#16a34a}.assessment-summary-hint--improve{color:#ea580c}.assessment-summary-hint--total{color:#2563eb}.assessment-performance-empty{padding:1.5rem .5rem;text-align:center}[data-theme=dark] .assessment-section-title{color:var(--text-main)}[data-theme=dark] .assessment-overview-card,[data-theme=dark] .assessment-trend-section,[data-theme=dark] .assessment-summary-card{background:#0f172a8c;border-color:#94a3b833}[data-theme=dark] .assessment-overview-name,[data-theme=dark] .assessment-summary-value{color:var(--text-main)}[data-theme=dark] .assessment-view-all-btn{background:#1e293b99;border-color:#94a3b840;color:#cbd5e1}@media(max-width:1100px){.assessment-performance-main{grid-template-columns:1fr;grid-template-rows:auto auto auto}.assessment-overview-head{grid-column:1;grid-row:1;margin-top:0;align-self:start}.assessment-overview-section{grid-column:1;grid-row:2}.assessment-trend-section{grid-column:1;grid-row:3}.assessment-summary-cards{grid-template-columns:1fr}}@media(max-width:760px){.assessment-summary-cards{grid-template-columns:1fr}}.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;position:relative;border-radius:12px;padding:.55rem .5rem;background:linear-gradient(165deg,#ffffff0f,#94a3b81a);border:1px solid rgba(148,163,184,.16);box-shadow:0 10px 22px #0206172e,inset 0 1px #ffffff24;transition:box-shadow .35s ease,transform .35s cubic-bezier(.22,1,.32,1)}.performance-assessment-item:hover{transform:translateY(-2px);box-shadow:0 14px 28px #02061738,inset 0 1px #ffffff2e}.assessment-needle-gauge-wrap{position:relative;display:flex;justify-content:center;width:100%}.performance-assessment-needle-gauge{width:152px;max-width:100%;height:auto;display:block;overflow:visible}.assessment-needle-gauge-floor{fill:#1e293b1f}.assessment-needle-gauge-arcs{animation:assessmentGaugeArcsIn .6s cubic-bezier(.22,1,.32,1) both}.assessment-needle-gauge-segment{animation:assessmentGaugeSegmentIn .5s cubic-bezier(.22,1,.32,1) both;opacity:0}.assessment-needle-gauge-needle-group{transition:transform .75s cubic-bezier(.22,1,.32,1)}.assessment-needle-gauge-wrap:hover .assessment-needle-gauge-needle-group{filter:drop-shadow(0 2px 4px rgba(15,23,42,.25))}.performance-assessment-needle-line{stroke:#475569;stroke-width:2.2;stroke-linecap:round;filter:drop-shadow(0 1px 2px rgba(15,23,42,.2))}.performance-assessment-needle-center{stroke:#fff9;stroke-width:.6;filter:drop-shadow(0 1px 2px rgba(15,23,42,.15))}.performance-assessment-needle-value{fill:var(--text-main, #e2e8f0);font-size:15px;font-weight:700;letter-spacing:.02em;animation:assessmentGaugeValueIn .5s cubic-bezier(.22,1,.32,1) .25s both}.assessment-needle-gauge-tooltip{position:absolute;left:50%;top:0;transform:translate(-50%,-100%);margin-top:-6px;min-width:140px;padding:.45rem .6rem;border-radius:10px;background:#fffffff7;border:1px solid rgba(148,163,184,.35);box-shadow:0 10px 24px #0f172a29;z-index:8;pointer-events:none;text-align:center;animation:assessmentTooltipIn .22s cubic-bezier(.22,1,.32,1) both}.assessment-needle-gauge-tooltip-title{display:block;font-size:.7rem;font-weight:600;color:#334155;margin-bottom:.12rem;line-height:1.25}.assessment-needle-gauge-tooltip-value{display:block;font-size:.78rem;color:#0f172a}.assessment-needle-gauge-tooltip-value strong{font-size:.95rem}.assessment-needle-gauge-tooltip-meta,.assessment-needle-gauge-tooltip-band{display:block;font-size:.65rem;color:#64748b;margin-top:.08rem}@keyframes assessmentGaugeArcsIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}@keyframes assessmentGaugeSegmentIn{0%{opacity:0}to{opacity:1}}@keyframes assessmentGaugeValueIn{0%{opacity:0;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}.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-kpi-row{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:.65rem}.performance-dashboard-page .performance-kpi-card{min-height:118px;min-width:0;padding:.7rem .75rem!important;border-radius:12px;border:1px solid var(--kpi-border)!important;border-top:3px solid var(--kpi-accent)!important;background:var(--kpi-bg)!important;box-shadow:var(--kpi-shadow)!important;transition:transform .32s cubic-bezier(.22,1,.32,1),box-shadow .32s ease}.performance-dashboard-page .performance-kpi-card:hover{transform:translateY(-3px);box-shadow:var(--kpi-shadow-hover)!important}.performance-kpi-card--class-days{--kpi-accent: #38bdf8;--kpi-accent-deep: #0284c7;--kpi-bg: linear-gradient(165deg, rgba(56, 189, 248, .18) 0%, rgba(14, 165, 233, .06) 55%, rgba(15, 23, 42, .02) 100%);--kpi-border: rgba(56, 189, 248, .32);--kpi-value: #7dd3fc;--kpi-title: #e0f2fe;--kpi-note: #94a3b8;--kpi-icon-bg: linear-gradient(145deg, rgba(125, 211, 252, .45), rgba(14, 165, 233, .2));--kpi-shadow: 0 10px 24px rgba(2, 132, 199, .2), inset 0 1px 0 rgba(255, 255, 255, .1);--kpi-shadow-hover: 0 14px 32px rgba(2, 132, 199, .28), inset 0 1px 0 rgba(255, 255, 255, .14)}.performance-kpi-card--duration{--kpi-accent: #2dd4bf;--kpi-accent-deep: #0d9488;--kpi-bg: linear-gradient(165deg, rgba(45, 212, 191, .17) 0%, rgba(20, 184, 166, .06) 55%, rgba(15, 23, 42, .02) 100%);--kpi-border: rgba(45, 212, 191, .3);--kpi-value: #5eead4;--kpi-title: #ccfbf1;--kpi-note: #94a3b8;--kpi-icon-bg: linear-gradient(145deg, rgba(94, 234, 212, .42), rgba(13, 148, 136, .2));--kpi-shadow: 0 10px 24px rgba(13, 148, 136, .18), inset 0 1px 0 rgba(255, 255, 255, .1);--kpi-shadow-hover: 0 14px 32px rgba(13, 148, 136, .26), inset 0 1px 0 rgba(255, 255, 255, .14)}.performance-kpi-card--completed{--kpi-accent: #fbbf24;--kpi-accent-deep: #d97706;--kpi-bg: linear-gradient(165deg, rgba(251, 191, 36, .16) 0%, rgba(217, 119, 6, .05) 55%, rgba(15, 23, 42, .02) 100%);--kpi-border: rgba(251, 191, 36, .28);--kpi-value: #fcd34d;--kpi-title: #fef3c7;--kpi-note: #94a3b8;--kpi-icon-bg: linear-gradient(145deg, rgba(252, 211, 77, .45), rgba(217, 119, 6, .18));--kpi-shadow: 0 10px 24px rgba(180, 83, 9, .16), inset 0 1px 0 rgba(255, 255, 255, .1);--kpi-shadow-hover: 0 14px 32px rgba(180, 83, 9, .24), inset 0 1px 0 rgba(255, 255, 255, .14)}.performance-kpi-card--certificates{--kpi-accent: #a78bfa;--kpi-accent-deep: #7c3aed;--kpi-bg: linear-gradient(165deg, rgba(167, 139, 250, .17) 0%, rgba(124, 58, 237, .06) 55%, rgba(15, 23, 42, .02) 100%);--kpi-border: rgba(167, 139, 250, .3);--kpi-value: #c4b5fd;--kpi-title: #ede9fe;--kpi-note: #94a3b8;--kpi-icon-bg: linear-gradient(145deg, rgba(196, 181, 253, .42), rgba(124, 58, 237, .2));--kpi-shadow: 0 10px 24px rgba(109, 40, 217, .18), inset 0 1px 0 rgba(255, 255, 255, .1);--kpi-shadow-hover: 0 14px 32px rgba(109, 40, 217, .26), inset 0 1px 0 rgba(255, 255, 255, .14)}.performance-kpi-card-title{color:var(--kpi-title)!important;font-weight:600;letter-spacing:.01em}.performance-kpi-card-value,.performance-kpi-card .overview-primary-value,.performance-kpi-card .performance-duration-value{margin-top:.25rem;font-size:2.1rem;font-weight:700;line-height:1.1;color:var(--kpi-value)!important;word-break:break-word;text-shadow:0 1px 12px rgba(0,0,0,.12)}.performance-kpi-card .performance-kpi-note{margin-top:.28rem;font-size:.78rem;color:var(--kpi-note);opacity:.92}.performance-kpi-card__icon{width:30px;height:30px;border-radius:50%;display:inline-flex;align-items:center;justify-content:center;background:var(--kpi-icon-bg);color:var(--kpi-accent-deep);box-shadow:0 2px 8px #0f172a1f}.performance-kpi-card__icon svg,.performance-kpi-card__icon .dash-kpi-glyph{width:16px;height:16px;display:block;color:var(--kpi-accent-deep)}.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;grid-column:1 / -1}.performance-top-attendance-head-wrap{margin-bottom:.65rem}.top-attendance-table{display:flex;flex-direction:column;gap:0;border-radius:12px;overflow:hidden;border:1px solid rgba(226,232,240,.85);background:#fff}.top-attendance-table-head,.top-attendance-table-row{display:grid;grid-template-columns:52px minmax(140px,1.6fr) minmax(90px,1fr) minmax(110px,1fr) minmax(150px,1.4fr) 36px;align-items:center;gap:.5rem .75rem;padding:.65rem .85rem}.top-attendance-table-head{background:linear-gradient(180deg,#e8f4fc,#dbeafe);font-size:.78rem;font-weight:700;color:#334155;letter-spacing:.02em;border-bottom:1px solid rgba(148,163,184,.25)}.top-attendance-col-hours{display:inline-flex;align-items:center;justify-content:flex-start;gap:.3rem;border:none;background:transparent;padding:0;font:inherit;font-weight:700;color:inherit;cursor:pointer;text-align:left}.top-attendance-col-hours:hover{color:#2563eb}.top-attendance-sort-icon{flex-shrink:0;opacity:.65}.top-attendance-table-body{display:flex;flex-direction:column}.top-attendance-table-row{font-size:.86rem;color:#0f172a;border-bottom:1px solid #f1f5f9;transition:background .15s ease}.top-attendance-table-row:hover{background:#f8fafc}.top-attendance-table-row:last-child{border-bottom:none}.top-attendance-rank{display:inline-flex;align-items:center;justify-content:center;width:28px;height:28px;border-radius:999px;font-size:.84rem;font-weight:700;line-height:1}.top-attendance-rank--gold{background:linear-gradient(145deg,#fde047,#eab308);color:#713f12;box-shadow:0 2px 6px #eab30859}.top-attendance-rank--silver{background:linear-gradient(145deg,#f1f5f9,#94a3b8);color:#1e293b;box-shadow:0 2px 6px #94a3b84d}.top-attendance-rank--bronze{background:linear-gradient(145deg,#fdba74,#d97706);color:#431407;box-shadow:0 2px 6px #d977064d}.top-attendance-rank--plain{background:transparent;color:#64748b;font-weight:600;width:auto;height:auto}.top-attendance-col-name{display:flex;align-items:center;gap:.55rem;min-width:0}.top-attendance-avatar{width:32px;height:32px;border-radius:999px;overflow:hidden;flex-shrink:0;display:inline-flex;align-items:center;justify-content:center;background:linear-gradient(145deg,#dbeafe,#bfdbfe);border:2px solid #fff;box-shadow:0 1px 4px #0f172a1f}.top-attendance-avatar img{width:100%;height:100%;object-fit:cover}.top-attendance-avatar-fallback{font-size:.65rem;font-weight:700;color:#1d4ed8}.top-attendance-student-name{font-weight:600;font-size:.84rem;letter-spacing:.02em;text-transform:uppercase;line-height:1.25;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.top-attendance-col-code{color:#64748b;font-size:.82rem}.top-attendance-hours-value{font-size:.94rem;font-weight:700;color:#16a34a}.top-attendance-col-attendance{display:flex;align-items:center;gap:.5rem;min-width:0}.top-attendance-progress-track{flex:1;height:7px;border-radius:999px;background:#e2e8f0;overflow:hidden;min-width:48px}.top-attendance-progress-fill{height:100%;border-radius:999px;background:linear-gradient(90deg,#4ade80,#16a34a);transition:width .4s ease}.top-attendance-pct{font-size:.82rem;font-weight:600;color:#16a34a;white-space:nowrap;min-width:2.5rem;text-align:right}.top-attendance-menu-btn{display:inline-flex;align-items:center;justify-content:center;width:28px;height:28px;border:none;border-radius:8px;background:transparent;color:#94a3b8;cursor:pointer;padding:0}.top-attendance-menu-btn:hover{background:#f1f5f9;color:#475569}.top-attendance-table-footer{display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:.65rem;padding:.75rem .85rem;border-top:1px solid #f1f5f9;background:#fafbfc}.top-attendance-range{font-size:.84rem;color:#64748b}.top-attendance-pagination{display:inline-flex;align-items:center;gap:.25rem}.top-attendance-page-btn,.top-attendance-page-num-btn{min-width:32px;height:32px;padding:0 .35rem;border-radius:8px;border:1px solid rgba(148,163,184,.35);background:#fff;color:#475569;font-size:.88rem;cursor:pointer;line-height:1}.top-attendance-page-btn:hover:not(:disabled),.top-attendance-page-num-btn:hover:not(.is-active){border-color:#3b82f6;color:#2563eb;background:#eff6ff}.top-attendance-page-btn:disabled{opacity:.45;cursor:not-allowed}.top-attendance-page-num-btn.is-active{background:#eff6ff;border-color:#3b82f6;color:#2563eb;font-weight:600}.top-attendance-page-ellipsis{padding:0 .2rem;color:#94a3b8;font-size:.85rem}.top-attendance-empty{padding:1.5rem .5rem;text-align:center}[data-theme=dark] .top-attendance-table{background:#0f172a8c;border-color:#94a3b833}[data-theme=dark] .top-attendance-table-head{background:linear-gradient(180deg,#38bdf838,#2563eb2e);color:#e2e8f0}[data-theme=dark] .top-attendance-table-row{color:var(--text-main);border-bottom-color:#94a3b81f}[data-theme=dark] .top-attendance-table-row:hover{background:#94a3b814}[data-theme=dark] .top-attendance-table-footer{background:#0f172a66}[data-theme=dark] .top-attendance-page-btn,[data-theme=dark] .top-attendance-page-num-btn{background:#1e293bcc;border-color:#94a3b840;color:#cbd5e1}@media(max-width:900px){.top-attendance-table-head,.top-attendance-table-row{grid-template-columns:40px 1fr 1fr;grid-template-areas:"rank name actions" "code hours hours" "att attendance attendance";gap:.35rem .5rem}.top-attendance-col-rank{grid-area:rank}.top-attendance-col-name{grid-area:name}.top-attendance-col-code{grid-area:code}.top-attendance-col-hours{grid-area:hours}.top-attendance-col-attendance{grid-area:attendance}.top-attendance-col-actions{grid-area:actions;justify-self:end}.top-attendance-table-head .top-attendance-col-code,.top-attendance-table-head .top-attendance-col-attendance,.top-attendance-table-head .top-attendance-col-actions{display:none}.top-attendance-table-head .top-attendance-col-hours:before{content:"Hours"}.top-attendance-table-head .top-attendance-col-hours{font-size:0}.top-attendance-table-head .top-attendance-col-hours .top-attendance-sort-icon{font-size:initial}}.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-legend{display:flex;flex-wrap:wrap;gap:.25rem .65rem;margin-bottom:.25rem;font-size:.68rem;color:#dbeafe}.attendance-legend-item{display:inline-flex;align-items:center;gap:.28rem}.attendance-legend-swatch{width:9px;height:9px;border-radius:999px;display:inline-block}.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-filter-bar--ref{background:#fff;border-color:#e2e8f0}[data-theme=light] .performance-filter-label-text{color:#0f172a}[data-theme=light] .performance-filter-chip{background:#fff;border-color:#e2e8f0;color:#475569}[data-theme=light] .performance-filter-chip.is-selected,[data-theme=light] .performance-filter-chip:has(input:checked){background:#eff6ff;border-color:#93c5fd;color:#047857}[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-dashboard-page .overview-card-students--ref.overview-card{background:linear-gradient(165deg,#fff,#eef5ff)!important;border:1px solid rgba(147,197,253,.55)!important;color:#0f172a}[data-theme=light] .performance-dashboard-page .overview-card.performance-batches-card--ref{background:linear-gradient(165deg,#fff,#fffbeb)!important;border:1px solid rgba(251,191,36,.45)!important;color:#0f172a}[data-theme=light] .performance-batch-progress-card .batch-progress-list-row--compact,[data-theme=light] .performance-assessment-item{background:linear-gradient(165deg,#fff,#f8fafc);border-color:#e2e8f0f2;box-shadow:0 2px 8px #0f172a0f,inset 0 1px #fffffff2}[data-theme=light] .assessment-needle-gauge-floor{fill:#0f172a12}[data-theme=light] .performance-batch-progress-card .batch-progress-list-row-name,[data-theme=light] .performance-assessment-name{color:#0f172a;text-shadow:none}[data-theme=light] .performance-assessment-meta{color:#475569}[data-theme=light] .performance-kpi-card--class-days{--kpi-accent: #0ea5e9;--kpi-accent-deep: #0369a1;--kpi-bg: linear-gradient(165deg, #f0f9ff 0%, #e0f2fe 50%, #ffffff 100%);--kpi-border: rgba(14, 165, 233, .22);--kpi-value: #0369a1;--kpi-title: #0c4a6e;--kpi-note: #64748b;--kpi-icon-bg: linear-gradient(145deg, #bae6fd, #7dd3fc);--kpi-shadow: 0 8px 20px rgba(14, 165, 233, .1), inset 0 1px 0 rgba(255, 255, 255, .95);--kpi-shadow-hover: 0 12px 26px rgba(14, 165, 233, .16), inset 0 1px 0 #fff}[data-theme=light] .performance-kpi-card--duration{--kpi-accent: #14b8a6;--kpi-accent-deep: #0f766e;--kpi-bg: linear-gradient(165deg, #f0fdfa 0%, #ccfbf1 50%, #ffffff 100%);--kpi-border: rgba(20, 184, 166, .22);--kpi-value: #0f766e;--kpi-title: #134e4a;--kpi-note: #64748b;--kpi-icon-bg: linear-gradient(145deg, #99f6e4, #5eead4);--kpi-shadow: 0 8px 20px rgba(20, 184, 166, .09), inset 0 1px 0 rgba(255, 255, 255, .95);--kpi-shadow-hover: 0 12px 26px rgba(20, 184, 166, .14), inset 0 1px 0 #fff}[data-theme=light] .performance-kpi-card--completed{--kpi-accent: #f59e0b;--kpi-accent-deep: #b45309;--kpi-bg: linear-gradient(165deg, #fffbeb 0%, #fef3c7 50%, #ffffff 100%);--kpi-border: rgba(245, 158, 11, .22);--kpi-value: #b45309;--kpi-title: #78350f;--kpi-note: #64748b;--kpi-icon-bg: linear-gradient(145deg, #fde68a, #fcd34d);--kpi-shadow: 0 8px 20px rgba(245, 158, 11, .09), inset 0 1px 0 rgba(255, 255, 255, .95);--kpi-shadow-hover: 0 12px 26px rgba(245, 158, 11, .14), inset 0 1px 0 #fff}[data-theme=light] .performance-kpi-card--certificates{--kpi-accent: #8b5cf6;--kpi-accent-deep: #6d28d9;--kpi-bg: linear-gradient(165deg, #f5f3ff 0%, #ede9fe 50%, #ffffff 100%);--kpi-border: rgba(139, 92, 246, .22);--kpi-value: #6d28d9;--kpi-title: #4c1d95;--kpi-note: #64748b;--kpi-icon-bg: linear-gradient(145deg, #ddd6fe, #c4b5fd);--kpi-shadow: 0 8px 20px rgba(109, 40, 217, .09), inset 0 1px 0 rgba(255, 255, 255, .95);--kpi-shadow-hover: 0 12px 26px rgba(109, 40, 217, .14), inset 0 1px 0 #fff}[data-theme=light] .performance-kpi-card-value,[data-theme=light] .performance-kpi-card .overview-primary-value,[data-theme=light] .performance-kpi-card .performance-duration-value{text-shadow:none}[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] .attendance-line-legend{color:#334155}[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:#334155}[data-theme=light] .performance-assessment-needle-center{stroke:#fffc}[data-theme=light] .performance-assessment-needle-value{fill:#0f172a}@media(prefers-reduced-motion:reduce){.assessment-needle-gauge-arcs,.assessment-needle-gauge-segment,.performance-assessment-needle-value,.assessment-needle-gauge-needle-group{animation:none;transition:none}.performance-assessment-item{transition:none}}@media(max-width:960px){.performance-dashboard-cards-grid{grid-template-columns:1fr}.performance-attendance-column{grid-template-rows:auto auto;height:auto}.performance-attendance-column .performance-attendance-card-standalone{height:auto}.performance-attendance-column .performance-attendance-card-standalone .attendance-trend-panel-chart .attendance-line-chart-wrap{min-height:unset}}@media(max-width:760px){.performance-batch-progress-card .batch-progress-list-row--compact{grid-template-columns:32px 1fr auto;grid-template-areas:"icon info chevron" "stats stats stats" "progress progress badge"}.performance-batch-progress-card .batch-progress-list-row--compact .batch-progress-list-row-icon{grid-area:icon}.performance-batch-progress-card .batch-progress-list-row--compact .batch-progress-list-row-info{grid-area:info}.performance-batch-progress-card .batch-progress-list-row--compact .batch-progress-list-row-stats{grid-area:stats}.performance-batch-progress-card .batch-progress-list-row--compact .batch-progress-list-row-progress{grid-area:progress}.performance-batch-progress-card .batch-progress-list-row--compact .batch-progress-list-badge{grid-area:badge;justify-self:start}.performance-batch-progress-card .batch-progress-list-row--compact .batch-progress-list-chevron{grid-area:chevron;justify-self:end}.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}}.modal-overlay-card-batch-progress-list{width:min(1180px,96vw)!important;max-height:min(92vh,100dvh - 1.5rem);overflow:hidden;display:flex;flex-direction:column;padding:1.35rem 1.5rem 1.1rem;background:linear-gradient(180deg,#f8fafc,#fff 42%);border:1px solid rgba(148,163,184,.22);box-shadow:0 24px 48px #0f172a24}.batch-progress-list-header{display:flex;align-items:flex-start;justify-content:space-between;gap:1rem;margin-bottom:1.1rem;flex-shrink:0}.batch-progress-list-title{margin:0;font-size:1.35rem;font-weight:700;color:#0f172a;letter-spacing:-.02em}.batch-progress-list-context{margin-top:.25rem}.batch-progress-list-subtitle{margin:0;font-size:.88rem;font-weight:600;color:#334155}.batch-progress-list-phase{margin:.2rem 0 0;font-size:.8rem;color:#64748b}.batch-progress-list-phase-label{font-weight:600;color:#475569;margin-right:.35rem}.batch-progress-list-toolbar{display:flex;flex-wrap:wrap;align-items:center;justify-content:flex-end;gap:.65rem;margin-bottom:1rem;flex-shrink:0}.batch-progress-list-search{display:inline-flex;align-items:center;gap:.5rem;min-width:min(280px,100%);padding:.5rem .85rem;border-radius:10px;border:1px solid rgba(148,163,184,.35);background:#fff;color:#64748b;box-shadow:0 1px 2px #0f172a0a}.batch-progress-list-search input{flex:1;border:none;outline:none;font-size:.88rem;color:#0f172a;background:transparent}.batch-progress-list-filter{display:inline-flex;align-items:center;gap:.45rem;padding:.5rem .75rem;border-radius:10px;border:1px solid rgba(148,163,184,.35);background:#fff;color:#64748b;box-shadow:0 1px 2px #0f172a0a}.batch-progress-list-filter select{border:none;outline:none;font-size:.88rem;font-weight:500;color:#334155;background:transparent;cursor:pointer}.batch-progress-list-body{flex:1;min-height:0;overflow-y:auto;padding-right:.15rem}.batch-progress-list-rows{display:flex;flex-direction:column;gap:.75rem}.batch-progress-list-row{display:grid;grid-template-columns:auto minmax(140px,1.4fr) minmax(200px,1.6fr) minmax(160px,1.2fr) auto auto;align-items:center;gap:1rem 1.25rem;padding:1rem 1.15rem;border-radius:14px;background:#fff;border:1px solid rgba(226,232,240,.95);box-shadow:0 2px 10px #0f172a0d;transition:box-shadow .2s ease,border-color .2s ease}.batch-progress-list-row:hover{border-color:#3b82f647;box-shadow:0 6px 18px #2563eb1a}.batch-progress-list-row-icon{width:44px;height:44px;border-radius:12px;display:inline-flex;align-items:center;justify-content:center;background:linear-gradient(145deg,#dbeafe,#eff6ff);color:#2563eb;flex-shrink:0}.batch-progress-list-row-name{margin:0;font-size:.95rem;font-weight:700;color:#0f172a;line-height:1.3}.batch-progress-list-row-students{display:inline-flex;align-items:center;gap:.35rem;margin:.3rem 0 0;font-size:.8rem;color:#64748b}.batch-progress-list-row-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:.5rem;text-align:center}.batch-progress-list-stat-value{display:block;font-size:1.05rem;font-weight:700;line-height:1.2}.batch-progress-list-stat-label{display:block;margin-top:.15rem;font-size:.72rem;color:#94a3b8;font-weight:500}.batch-progress-list-stat--completed .batch-progress-list-stat-value{color:#16a34a}.batch-progress-list-stat--in-progress .batch-progress-list-stat-value{color:#d97706}.batch-progress-list-stat--yet .batch-progress-list-stat-value{color:#475569}.batch-progress-list-row-progress{display:flex;align-items:center;gap:.65rem;min-width:0}.batch-progress-list-bar-track{flex:1;height:8px;border-radius:999px;background:#e2e8f0;overflow:hidden}.batch-progress-list-bar-fill{height:100%;border-radius:999px;background:linear-gradient(90deg,#22c55e,#16a34a);transition:width .45s ease}.batch-progress-list-pct{font-size:.88rem;font-weight:700;color:#16a34a;white-space:nowrap;min-width:2.75rem;text-align:right}.batch-progress-list-badge{display:inline-flex;align-items:center;gap:.35rem;padding:.35rem .7rem;border-radius:999px;font-size:.75rem;font-weight:600;white-space:nowrap}.batch-progress-list-badge--completed{background:#dcfce7;color:#15803d}.batch-progress-list-badge--in-progress{background:#fef3c7;color:#b45309}.batch-progress-list-badge--yet-to-start{background:#f1f5f9;color:#475569}.batch-progress-list-chevron{color:#94a3b8;display:inline-flex;align-items:center}.batch-progress-list-footer{display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:.75rem;margin-top:1rem;padding-top:.85rem;border-top:1px solid rgba(226,232,240,.9);flex-shrink:0}.batch-progress-list-range{font-size:.82rem;color:#64748b}.batch-progress-list-pagination{display:inline-flex;align-items:center;gap:.35rem}.batch-progress-list-page-btn{width:32px;height:32px;border-radius:8px;border:1px solid rgba(148,163,184,.35);background:#fff;color:#334155;font-size:1.1rem;cursor:pointer;line-height:1}.batch-progress-list-page-btn:hover:not(:disabled){border-color:#3b82f6;color:#2563eb;background:#eff6ff}.batch-progress-list-page-btn:disabled{opacity:.45;cursor:not-allowed}.batch-progress-list-page-num{min-width:32px;height:32px;display:inline-flex;align-items:center;justify-content:center;border-radius:8px;background:#2563eb;color:#fff;font-size:.85rem;font-weight:600}.batch-progress-list-loading,.batch-progress-list-empty{padding:2.5rem 1rem;text-align:center}.course-batch-progress-dashboard-counts .open-in-new-window-btn{flex-shrink:0}@media(max-width:1024px){.batch-progress-list-row{grid-template-columns:auto 1fr;grid-template-areas:"icon info" "stats stats" "progress progress" "badge chevron"}.batch-progress-list-row-icon{grid-area:icon}.batch-progress-list-row-info{grid-area:info}.batch-progress-list-row-stats{grid-area:stats}.batch-progress-list-row-progress{grid-area:progress}.batch-progress-list-badge{grid-area:badge;justify-self:start}.batch-progress-list-chevron{grid-area:chevron;justify-self:end}}.vl-page{animation:vl-fade-in .35s ease}@keyframes vl-fade-in{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}.vl-hero{display:flex;align-items:center;gap:1rem;margin-bottom:1.5rem;padding:1.25rem 1.5rem;border-radius:16px;background:linear-gradient(135deg,#4f46e51f,#0ea5e914);border:1px solid rgba(99,102,241,.15)}.vl-hero-icon{width:56px;height:56px;border-radius:14px;display:flex;align-items:center;justify-content:center;background:linear-gradient(145deg,#4f46e5,#0ea5e9);color:#fff;flex-shrink:0;box-shadow:0 8px 24px #4f46e559}.vl-upload-card{border-radius:16px;box-shadow:0 4px 24px #0f172a0f}.vl-form-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem;margin-bottom:1.25rem}.vl-field-full{width:100%}.vl-textarea{width:100%;min-height:4rem;padding:.55rem .65rem;border:1px solid rgba(15,23,42,.15);border-radius:8px;font-size:.88rem;font-family:inherit;resize:vertical;line-height:1.45}.vl-textarea:focus{outline:none;border-color:#4f46e5;box-shadow:0 0 0 2px #4f46e526}.vl-pending-description{min-height:2.5rem;font-size:.8rem}.vl-admin-video-description{margin:.2rem 0 .35rem;font-size:.82rem;color:var(--text-muted, #64748b);line-height:1.4}@media(max-width:900px){.vl-form-grid{grid-template-columns:1fr}}.vl-input-error{border-color:#ef4444!important;box-shadow:0 0 0 2px #ef444426}.vl-field-error{display:block;margin-top:.25rem;font-size:.78rem;color:#ef4444}.vl-dropzone{border:2px dashed rgba(99,102,241,.35);border-radius:14px;padding:2rem 1.5rem;text-align:center;cursor:pointer;transition:border-color .2s,background .2s,transform .2s;background:#6366f108;color:var(--text-muted, #64748b)}.vl-dropzone:hover,.vl-dropzone-active{border-color:#4f46e5;background:#4f46e50f;transform:translateY(-1px)}.vl-dropzone-title{margin:.75rem 0 .25rem;font-weight:600;color:var(--text, #0f172a)}.vl-dropzone-hint{margin:0;font-size:.82rem}.vl-pending-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:1rem;margin-top:1.25rem}.vl-pending-card{border-radius:12px;overflow:hidden;border:1px solid rgba(15,23,42,.08);background:var(--card-bg, #fff);transition:box-shadow .2s}.vl-pending-card:hover{box-shadow:0 8px 20px #0f172a14}.vl-pending-thumb{position:relative;aspect-ratio:16 / 9;background:#0f172a}.vl-pending-thumb img{width:100%;height:100%;object-fit:cover}.vl-pending-body{padding:.75rem;display:flex;flex-direction:column;gap:.35rem}.vl-pending-body input{width:100%;font-size:.88rem}.vl-pending-meta{font-size:.75rem;color:var(--text-muted, #64748b)}.vl-remove-btn{align-self:flex-start;background:none;border:none;color:#ef4444;font-size:.78rem;cursor:pointer;padding:0}.vl-remove-btn:hover{text-decoration:underline}.vl-duration-badge{position:absolute;top:6px;right:6px;padding:2px 6px;border-radius:4px;font-size:.7rem;font-weight:600;background:#000000bf;color:#fff}.vl-progress-wrap{margin-top:1rem;display:flex;flex-direction:column;gap:.35rem;font-size:.82rem;color:var(--text-muted, #64748b)}.vl-progress-bar{height:6px;border-radius:999px;background:#4f46e526;overflow:hidden}.vl-progress-fill{height:100%;border-radius:999px;background:linear-gradient(90deg,#4f46e5,#0ea5e9);transition:width .2s}.vl-form-actions{margin-top:1.25rem;display:flex;gap:.75rem}.vl-form-actions .pill-button{display:inline-flex;align-items:center;gap:.5rem}.vl-btn-spinner{display:inline-block;width:16px;height:16px;border:2px solid rgba(255,255,255,.35);border-top-color:#fff;border-radius:50%;animation:vl-spin .7s linear infinite}.vl-loading-state .vl-btn-spinner{border-color:#4f46e540;border-top-color:#4f46e5;margin-right:.5rem}@keyframes vl-spin{to{transform:rotate(360deg)}}.vl-empty{color:var(--text-muted, #64748b);text-align:center;padding:2rem}.vl-tag{display:inline-block;margin-left:.5rem;padding:.15rem .5rem;border-radius:999px;font-size:.72rem;background:#4f46e51f;color:#4f46e5;font-weight:600}.vl-admin-groups{display:flex;flex-direction:column;gap:1rem}.vl-admin-group{border:1px solid rgba(15,23,42,.08);border-radius:12px;overflow:hidden}.vl-admin-group-head{display:flex;justify-content:space-between;align-items:center;padding:1rem 1.25rem;background:#6366f10a}.vl-admin-group-head h3{margin:0;font-size:1rem}.vl-admin-video-list{padding:.5rem}.vl-admin-video-row{display:flex;align-items:center;gap:1rem;padding:.65rem .75rem;border-radius:8px;transition:background .15s}.vl-admin-video-row:hover{background:#0f172a08}.vl-admin-video-thumb{width:80px;aspect-ratio:16 / 9;border-radius:6px;overflow:hidden;flex-shrink:0;background:#0f172a}.vl-admin-video-thumb img{width:100%;height:100%;object-fit:cover}.vl-thumb-placeholder{width:100%;height:100%;background:linear-gradient(135deg,#1e293b,#334155)}.vl-admin-video-info{flex:1;display:flex;flex-direction:column;gap:.2rem;min-width:0}.vl-admin-video-info span{font-size:.78rem;color:var(--text-muted, #64748b)}.vl-student-page .vl-student-hero{margin-bottom:2rem}.vl-student-groups{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1.25rem;align-items:start}.vl-student-group-card{border-radius:16px;overflow:hidden;background:var(--card-bg, #fff);border:1px solid rgba(15,23,42,.08);box-shadow:0 4px 20px #0f172a0f;transition:box-shadow .25s,transform .25s}.vl-student-group-card:hover{box-shadow:0 12px 32px #4f46e51f;transform:translateY(-2px)}.vl-student-group-card.expanded{grid-column:1 / -1}.vl-student-group-trigger{width:100%;display:grid;grid-template-columns:1fr auto;grid-template-rows:auto auto;gap:0;padding:0;border:none;background:none;cursor:pointer;text-align:left}.vl-group-banner{position:relative;grid-column:1 / -1;aspect-ratio:16 / 7;overflow:hidden;background:#0f172a}.vl-group-banner-img{width:100%;height:100%;object-fit:cover;transition:transform .4s ease}.vl-student-group-card:hover .vl-group-banner-img{transform:scale(1.04)}.vl-group-banner-fallback{width:100%;height:100%;display:flex;align-items:center;justify-content:center;color:#ffffff80;background:linear-gradient(135deg,#1e1b4b,#312e81)}.vl-play-fab{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;background:#00000040;opacity:0;transition:opacity .25s}.vl-student-group-card:hover .vl-play-fab{opacity:1}.vl-play-fab svg{width:48px;height:48px;padding:12px;border-radius:50%;background:#fffffff2;color:#4f46e5;box-shadow:0 8px 24px #0000004d}.vl-student-group-meta{padding:1rem 1.1rem .5rem}.vl-student-group-meta h2{margin:0 0 .35rem;font-size:1.05rem}.vl-student-video-play-card{display:flex;flex-direction:column;width:100%;padding:0;border:none;border-radius:inherit;background:transparent;cursor:pointer;text-align:left;overflow:hidden;transition:transform .2s,box-shadow .2s}.vl-student-group-card .vl-student-video-play-card{border-radius:16px}.vl-student-video-play-card:hover{transform:translateY(-2px)}.vl-student-video-play-card:focus-visible{outline:2px solid #4f46e5;outline-offset:2px}.vl-student-video-play-card-thumb{position:relative;width:100%;aspect-ratio:16 / 9;background:#0f172a;overflow:hidden}.vl-student-video-play-card-thumb .vl-play-overlay,.vl-student-video-play-card-thumb .vl-duration-badge{pointer-events:none}.vl-student-video-play-card-thumb img,.vl-student-video-play-card-thumb .vl-thumb-placeholder{width:100%;height:100%;object-fit:cover;display:block;transition:transform .35s ease}.vl-student-video-play-card:hover .vl-student-video-play-card-thumb img{transform:scale(1.04)}.vl-student-video-play-card-body{padding:.85rem 1.1rem 1rem;display:flex;flex-direction:column;gap:.2rem;min-width:0}.vl-student-video-play-card-subtitle{font-size:.78rem;font-weight:600;text-transform:uppercase;letter-spacing:.04em;color:#4f46e5}.vl-student-video-play-card-title{font-size:.95rem;font-weight:600;color:var(--text, #0f172a);line-height:1.35}.vl-group-video-list{list-style:none;margin:0;padding:0 .75rem .75rem;display:flex;flex-direction:column;gap:.65rem}.vl-group-video-list .vl-student-video-play-card{border:1px solid rgba(15,23,42,.08);border-radius:12px;background:var(--card-bg, #fff);box-shadow:0 2px 8px #0f172a0a}.vl-group-video-list .vl-student-video-play-card:hover{box-shadow:0 8px 20px #4f46e51f}.vl-student-group-header{padding:.85rem 1.1rem .35rem}.vl-student-group-header h2{margin:0 0 .2rem;font-size:1.05rem}.vl-student-group-card-multi .vl-group-video-list{padding-top:.25rem}.vl-student-group-trigger-compact{display:flex;align-items:center;justify-content:space-between;width:100%;padding:.85rem 1.1rem .5rem;border:none;background:none;cursor:pointer;text-align:left}.vl-student-group-meta-compact{padding:0!important}.vl-student-group-meta-compact h2{margin:0 0 .2rem}.vl-group-video-name{font-size:.74rem;color:var(--text-muted, #64748b);line-height:1.25;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.vl-video-count{font-size:.82rem;color:var(--text-muted, #64748b)}.vl-chevron{position:absolute;right:1rem;bottom:1rem;transition:transform .25s;color:var(--text-muted, #64748b)}.vl-chevron.open{transform:rotate(180deg)}.vl-student-group-trigger{position:relative}.vl-student-videos-panel{padding:0 1.1rem 1.1rem;animation:vl-slide-down .3s ease}@keyframes vl-slide-down{0%{opacity:0;max-height:0}to{opacity:1;max-height:2000px}}.vl-student-videos-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:1rem}.vl-student-video-tile{border:none;background:none;padding:0;cursor:pointer;text-align:left;border-radius:12px;overflow:hidden;transition:transform .2s}.vl-student-video-tile:hover{transform:scale(1.02)}.vl-student-video-tile:focus-visible{outline:2px solid #4f46e5;outline-offset:2px}.vl-student-video-thumb{position:relative;aspect-ratio:16 / 9;border-radius:10px;overflow:hidden;background:#0f172a}.vl-student-video-thumb img{width:100%;height:100%;object-fit:cover}.vl-play-overlay{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;background:#00000059;opacity:0;transition:opacity .2s;color:#fff}.vl-student-video-tile:hover .vl-play-overlay{opacity:1}.vl-student-video-meta{margin-top:.5rem;display:flex;flex-direction:column;gap:.2rem;min-width:0}.vl-student-video-title{display:block;font-size:.88rem;font-weight:600;color:var(--text, #0f172a);line-height:1.3}.vl-student-video-name{display:block;font-size:.75rem;font-weight:400;color:var(--text-muted, #64748b);line-height:1.25;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.vl-empty-card{text-align:center;padding:3rem}.vl-player-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:9999;display:flex;align-items:center;justify-content:center;padding:1rem;animation:vl-fade-in .25s ease}.vl-player-backdrop{position:absolute;top:0;right:0;bottom:0;left:0;background:#000000e0;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.vl-player-shell{position:relative;z-index:1;width:min(1100px,96vw);max-height:90vh;background:#000;border-radius:12px;overflow:hidden;box-shadow:0 24px 80px #0009}.vl-player-shell-fs{width:100vw;max-width:100vw;height:100vh;max-height:100vh;border-radius:0}.vl-player-video{width:100%;max-height:calc(90vh - 120px);display:block;background:#000;cursor:pointer}.vl-player-shell-fs .vl-player-video{max-height:calc(100vh - 120px);height:calc(100vh - 120px);object-fit:contain}.vl-player-spinner{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);color:#fff;pointer-events:none}.vl-player-top{position:absolute;top:0;left:0;right:0;display:flex;justify-content:space-between;align-items:center;padding:.75rem 1rem;background:linear-gradient(180deg,rgba(0,0,0,.75),transparent);transition:opacity .3s}.vl-player-title{margin:0;font-size:.95rem;color:#fff;font-weight:600;text-shadow:0 1px 4px rgba(0,0,0,.5)}.vl-player-controls{position:absolute;bottom:0;left:0;right:0;padding:.5rem .75rem .75rem;background:linear-gradient(0deg,rgba(0,0,0,.85),transparent);transition:opacity .3s}.vl-controls-hidden{opacity:0;pointer-events:none}.vl-progress-row{display:flex;align-items:center;gap:.5rem;margin-bottom:.35rem}.vl-time{font-size:.72rem;color:#ffffffd9;min-width:36px;font-variant-numeric:tabular-nums}.vl-seek{flex:1;height:4px;-webkit-appearance:none;-moz-appearance:none;appearance:none;background:#ffffff40;border-radius:999px;cursor:pointer}.vl-seek::-webkit-slider-thumb{-webkit-appearance:none;width:12px;height:12px;border-radius:50%;background:#4f46e5}.vl-toolbar{display:flex;align-items:center;gap:.35rem;flex-wrap:wrap}.vl-toolbar-spacer{flex:1}.vl-icon-btn{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border:none;border-radius:8px;background:transparent;color:#fff;cursor:pointer;transition:background .15s}.vl-icon-btn:hover{background:#ffffff1f}.vl-volume-wrap{display:flex;align-items:center;gap:.25rem}.vl-volume{width:72px;height:4px;-webkit-appearance:none;-moz-appearance:none;appearance:none;background:#ffffff40;border-radius:999px}.vl-volume::-webkit-slider-thumb{-webkit-appearance:none;width:10px;height:10px;border-radius:50%;background:#fff}.vl-speed-wrap{position:relative}.vl-speed-btn{padding:.25rem .5rem;border-radius:6px;border:1px solid rgba(255,255,255,.25);background:transparent;color:#fff;font-size:.78rem;cursor:pointer}.vl-speed-menu{position:absolute;bottom:100%;left:0;margin-bottom:4px;background:#0f172af2;border-radius:8px;padding:.25rem;min-width:64px;box-shadow:0 8px 24px #0006}.vl-speed-menu button{display:block;width:100%;padding:.35rem .6rem;border:none;background:none;color:#fff;font-size:.78rem;text-align:left;cursor:pointer;border-radius:4px}.vl-speed-menu button:hover,.vl-speed-menu button.active{background:#4f46e580}.vl-quality-badge{font-size:.68rem;font-weight:700;padding:.15rem .4rem;border-radius:4px;background:#4f46e599;color:#fff}.vl-sidebar-section{display:flex;flex-direction:column;gap:.15rem}.vl-nav-submenu{list-style:none;margin:0 0 .35rem;padding:0 0 0 .85rem;border-left:2px solid rgba(148,163,184,.2);display:flex;flex-direction:column;gap:.1rem}.vl-nav-submenu-loading{padding:.35rem .75rem .35rem 1.1rem;font-size:.75rem;color:var(--text-muted, #94a3b8)}.nav-link-submenu{font-size:.82rem!important;font-weight:500!important;min-height:36px!important;padding:.35rem .65rem!important;color:#94a3b8!important}.nav-link-submenu.nav-link-active{color:var(--text-main, #f1f5f9)!important;background:#7b5cff26!important}.vl-student-library-browse .vl-search-bar-wrap{position:relative;margin-bottom:1.5rem;max-width:520px}.vl-search-icon{position:absolute;left:1rem;top:50%;transform:translateY(-50%);color:var(--text-muted, #64748b);pointer-events:none;display:flex}.vl-search-input{width:100%;padding:.75rem 1rem .75rem 2.75rem;border:1px solid rgba(15,23,42,.12);border-radius:12px;font-size:.95rem;background:var(--card-bg, #fff);box-shadow:0 2px 12px #0f172a0f;transition:border-color .2s,box-shadow .2s}.vl-search-input:focus{outline:none;border-color:#4f46e5;box-shadow:0 0 0 3px #4f46e51f}.vl-sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.vl-empty-hint{margin-top:.35rem;font-size:.85rem;color:var(--text-muted, #64748b)}.vl-video-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1.25rem}@media(max-width:1100px){.vl-video-grid{grid-template-columns:repeat(2,1fr)}}@media(max-width:640px){.vl-video-grid{grid-template-columns:1fr}}.vl-video-grid-card{border-radius:14px;overflow:hidden;background:var(--card-bg, #fff);border:1px solid rgba(15,23,42,.08);box-shadow:0 4px 16px #0f172a0f;transition:box-shadow .25s,transform .25s}.vl-video-grid-card:hover{box-shadow:0 12px 32px #4f46e524;transform:translateY(-3px)}.vl-video-grid-card-inner{display:flex;flex-direction:column;width:100%;padding:0;border:none;background:none;cursor:pointer;text-align:left}.vl-video-grid-card-inner:focus-visible{outline:2px solid #4f46e5;outline-offset:2px}.vl-video-grid-thumb{position:relative;aspect-ratio:16 / 9;background:#0f172a;overflow:hidden}.vl-video-grid-thumb img,.vl-video-grid-thumb .vl-thumb-image,.vl-video-grid-thumb .vl-title-thumb,.vl-video-grid-thumb .vl-thumb-placeholder{width:100%;height:100%;object-fit:cover;transition:transform .35s ease}.vl-video-grid-card:hover .vl-video-grid-thumb img,.vl-video-grid-card:hover .vl-video-grid-thumb .vl-thumb-image{transform:scale(1.05)}.vl-title-thumb{position:relative;width:100%;height:100%;display:flex;align-items:stretch;justify-content:center;overflow:hidden;color:#fff}.vl-title-thumb-grid{position:absolute;top:0;right:0;bottom:0;left:0;background-image:linear-gradient(rgba(255,255,255,.04) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.04) 1px,transparent 1px);background-size:24px 24px;opacity:.6}.vl-title-thumb-glow{position:absolute;width:140px;height:140px;border-radius:50%;top:-40px;right:-30px;opacity:.22;filter:blur(28px)}.vl-title-thumb-content{position:relative;z-index:1;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:1rem 1.25rem;width:100%;gap:.35rem}.vl-title-thumb-group{font-size:.65rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;opacity:.85;max-width:100%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.vl-title-thumb-initials{font-size:2rem;font-weight:800;line-height:1;opacity:.95;text-shadow:0 2px 12px rgba(0,0,0,.25)}.vl-title-thumb-title{margin:0;font-size:.92rem;font-weight:700;line-height:1.35;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden;text-shadow:0 1px 8px rgba(0,0,0,.35);max-width:100%}.vl-title-thumb-film{position:absolute;left:0;right:0;bottom:0;height:10px;display:flex;justify-content:space-evenly;align-items:center;background:#00000059;z-index:2}.vl-title-thumb-film span{width:5px;height:5px;border-radius:1px;background:#ffffff59}.vl-title-thumb-compact .vl-title-thumb-initials{font-size:1.5rem}.vl-title-thumb-compact .vl-title-thumb-title{font-size:.8rem;-webkit-line-clamp:2}.vl-thumb-image,.vl-thumb-video-frame{display:block;width:100%;height:100%;object-fit:cover;background:#0f172a}.vl-video-grid-card:hover .vl-thumb-video-frame{transform:scale(1.05);transition:transform .35s ease}.vl-thumb-media{position:relative;width:100%;height:100%}.vl-thumb-image-overlay{position:absolute;left:0;right:0;bottom:0;padding:1.75rem .75rem .65rem;background:linear-gradient(180deg,transparent 0%,rgba(0,0,0,.75) 100%);display:flex;flex-direction:column;gap:.15rem;pointer-events:none}.vl-thumb-image-group{font-size:.62rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:#ffffffd9;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.vl-thumb-image-title{font-size:.82rem;font-weight:700;color:#fff;line-height:1.3;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;text-shadow:0 1px 4px rgba(0,0,0,.5)}.vl-video-grid-thumb .vl-play-overlay,.vl-video-grid-thumb .vl-duration-badge{pointer-events:none}.vl-video-grid-body{padding:1rem 1.1rem 1.1rem;display:flex;flex-direction:column;gap:.35rem;min-width:0}.vl-video-grid-group{font-size:.72rem;font-weight:600;text-transform:uppercase;letter-spacing:.04em;color:#4f46e5}.vl-video-grid-title{margin:0;font-size:1rem;font-weight:600;color:var(--text, #0f172a);line-height:1.35;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.vl-video-grid-description{margin:0;font-size:.82rem;color:var(--text-muted, #64748b);line-height:1.45;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.vl-video-grid-footer{display:flex;align-items:center;justify-content:space-between;gap:.5rem;margin-top:.35rem;padding-top:.65rem;border-top:1px solid rgba(15,23,42,.06)}.vl-video-grid-date{font-size:.78rem;color:var(--text-muted, #64748b)}.vl-video-grid-play-btn{display:inline-flex;align-items:center;gap:.35rem;font-size:.82rem;font-weight:600;color:#4f46e5;padding:.3rem .65rem;border-radius:999px;background:#4f46e51a;transition:background .15s}.vl-video-grid-card:hover .vl-video-grid-play-btn{background:#4f46e52e}@media(max-width:640px){.vl-student-groups{grid-template-columns:1fr}.vl-volume{width:48px}.vl-player-overlay{padding:0}.vl-player-shell{width:100%;max-height:100vh;border-radius:0}}
