.camp-switcher{display:inline-flex;background:var(--color-bg-base);border:1px solid var(--color-border);border-radius:var(--radius-full);padding:3px;gap:2px}.camp-switcher-btn{border:none;background:transparent;padding:6px 14px;border-radius:var(--radius-full);font-family:inherit;font-size:.8125rem;font-weight:600;color:var(--color-text-muted);cursor:pointer;transition:color var(--transition-fast),background-color var(--transition-fast)}.camp-switcher-btn:hover{color:var(--color-text-base)}.camp-switcher-btn.active{background:var(--color-bg-surface);color:var(--color-primary);box-shadow:var(--shadow-sm)}.layout-container{display:flex;height:100vh;width:100vw;overflow:hidden;background-color:var(--color-bg-base)}.sidebar{width:260px;flex-shrink:0;background-color:var(--color-bg-surface);border-right:1px solid var(--color-border);display:flex;flex-direction:column;transition:transform var(--transition-default);z-index:40}.sidebar-header{height:70px;padding:0 var(--spacing-lg);display:flex;align-items:center;border-bottom:1px solid var(--color-border)}.logo-container{display:flex;align-items:center;gap:var(--spacing-sm)}.logo-icon{width:32px;height:32px;background:linear-gradient(135deg,var(--color-primary),var(--color-primary-hover));color:#fff;border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;font-weight:700;font-family:var(--font-display)}.logo-text{font-family:var(--font-display);font-weight:700;font-size:1.125rem;color:var(--color-text-base)}.sidebar-nav{flex-grow:1;padding:var(--spacing-md) 0;overflow-y:auto}.sidebar-nav ul{list-style:none;display:flex;flex-direction:column;gap:var(--spacing-xs);padding:0 var(--spacing-md)}.nav-link{display:flex;align-items:center;gap:var(--spacing-md);padding:var(--spacing-sm) var(--spacing-md);text-decoration:none;color:var(--color-text-muted);border-radius:var(--radius-md);font-weight:500;transition:background-color var(--transition-fast),color var(--transition-fast)}.nav-link:hover{background-color:var(--color-primary-subtle);color:var(--color-text-base)}.nav-link.active{background-color:var(--color-primary-subtle);color:var(--color-primary)}.nav-icon{opacity:.7}.nav-link.active .nav-icon{opacity:1}.sidebar-footer{padding:var(--spacing-md);border-top:1px solid var(--color-border)}.user-profile{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-sm);border-radius:var(--radius-md);cursor:pointer;transition:background-color var(--transition-fast)}.user-profile:hover{background-color:var(--color-primary-subtle)}.avatar{width:36px;height:36px;border-radius:var(--radius-full);background-color:var(--color-primary);color:#fff;display:flex;align-items:center;justify-content:center;font-size:.875rem;font-weight:600}.user-info{display:flex;flex-direction:column}.user-name{font-weight:600;font-size:.875rem}.user-role{font-size:.75rem;color:var(--color-text-muted)}.main-content{flex-grow:1;display:flex;flex-direction:column;overflow:hidden}.top-bar{height:70px;background-color:var(--color-bg-surface);border-bottom:1px solid var(--color-border);display:flex;align-items:center;justify-content:space-between;padding:0 var(--spacing-xl);flex-shrink:0}.search-input{width:300px;padding:var(--spacing-sm) var(--spacing-md);border:1px solid var(--color-border);border-radius:var(--radius-md);font-family:inherit;font-size:.875rem;transition:border-color var(--transition-fast),box-shadow var(--transition-fast);background-color:var(--color-bg-base)}.search-input:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 2px var(--color-primary-subtle)}.content-area{flex-grow:1;overflow-y:auto;padding:var(--spacing-xl)}.mobile-header{display:none;height:60px;background-color:var(--color-bg-surface);border-bottom:1px solid var(--color-border);align-items:center;justify-content:space-between;padding:0 var(--spacing-md);z-index:30}.mobile-menu-btn{background:none;border:none;color:var(--color-text-base);cursor:pointer;padding:var(--spacing-xs)}.sidebar-overlay{display:none;position:fixed;inset:0;background-color:#0006;z-index:35;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);animation:fadeIn .2s ease-out}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@media(max-width:768px){.mobile-header{display:flex}.desktop-only{display:none}.sidebar{position:fixed;top:60px;bottom:0;left:0;transform:translate(-100%)}.sidebar.sidebar-open{transform:translate(0)}.sidebar-overlay{display:block}.top-bar{padding:0 var(--spacing-md)}.search-input{width:200px}.content-area{padding:var(--spacing-md)}}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#f2f4f8,#f9fafb);padding:var(--spacing-md)}.login-card{background:var(--color-bg-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:2.5rem;width:100%;max-width:400px;box-shadow:var(--shadow-lg)}.login-logo{display:flex;align-items:center;gap:var(--spacing-sm);margin-bottom:2rem}.login-logo-icon{width:40px;height:40px;background:linear-gradient(135deg,var(--color-primary),var(--color-primary-hover));color:#fff;border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;font-weight:700;font-size:1.25rem;font-family:var(--font-display)}.login-logo-text{font-family:var(--font-display);font-weight:700;font-size:1.25rem;color:var(--color-text-base)}.login-title{font-size:1.5rem;color:var(--color-text-base);margin-bottom:.25rem}.login-subtitle{font-size:.875rem;color:var(--color-text-muted);margin-bottom:2rem}.login-form{display:flex;flex-direction:column;gap:var(--spacing-md)}.form-group{display:flex;flex-direction:column;gap:var(--spacing-xs)}.form-label{font-size:.875rem;font-weight:500;color:var(--color-text-base)}.form-input{padding:.625rem var(--spacing-md);border:1px solid var(--color-border);border-radius:var(--radius-md);font-family:inherit;font-size:.9375rem;color:var(--color-text-base);background:var(--color-bg-base);transition:border-color var(--transition-fast),box-shadow var(--transition-fast)}.form-input:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px var(--color-primary-subtle)}.login-error{font-size:.8125rem;color:#d92626;background:#fdf1f1;border:1px solid hsl(0,60%,88%);border-radius:var(--radius-md);padding:var(--spacing-sm) var(--spacing-md)}.login-btn{margin-top:var(--spacing-xs);padding:.6875rem var(--spacing-md);background:var(--color-primary);color:#fff;border:none;border-radius:var(--radius-md);font-family:inherit;font-size:.9375rem;font-weight:600;cursor:pointer;transition:background-color var(--transition-fast),transform var(--transition-fast)}.login-btn:hover:not(:disabled){background:var(--color-primary-hover);transform:translateY(-1px)}.login-btn:disabled{opacity:.6;cursor:not-allowed}.review-form-container{padding:var(--spacing-xl);display:flex;flex-direction:column;height:100%}.review-header{margin-bottom:var(--spacing-xl);padding-bottom:var(--spacing-md);border-bottom:1px solid var(--color-border)}.review-header h3{font-size:1.25rem;color:var(--color-text-base);margin-bottom:var(--spacing-xs)}.subtitle{color:var(--color-text-muted);font-size:.875rem}.criteria-list{display:flex;flex-direction:column;gap:var(--spacing-lg);margin-bottom:var(--spacing-xl)}.criteria-item{display:flex;flex-direction:column;gap:var(--spacing-sm)}.criteria-header{display:flex;justify-content:space-between;align-items:center}.criteria-name{font-weight:600;color:var(--color-text-base)}.criteria-weight{font-size:.75rem;color:var(--color-text-muted);background-color:var(--color-bg-base);padding:2px 6px;border-radius:var(--radius-sm);border:1px solid var(--color-border)}.scoring-controls{display:flex;gap:var(--spacing-xs)}.score-btn{flex:1;height:44px;border:1px solid var(--color-border);background-color:var(--color-bg-surface);color:var(--color-text-base);border-radius:var(--radius-md);font-family:var(--font-display);font-weight:600;font-size:1rem;cursor:pointer;transition:background-color var(--transition-fast),border-color var(--transition-fast),color var(--transition-fast),box-shadow var(--transition-fast)}.score-btn:hover{background-color:var(--color-primary-subtle);border-color:var(--color-primary-light)}.score-btn.active{background-color:var(--color-primary);color:#fff;border-color:var(--color-primary);box-shadow:0 0 0 3px var(--color-primary-subtle)}.overall-score-section{background-color:var(--color-bg-base);border-radius:var(--radius-lg);padding:var(--spacing-lg);margin-bottom:var(--spacing-xl);display:flex;align-items:center;justify-content:space-between;border:1px solid var(--color-border)}.score-display{display:flex;flex-direction:column}.score-label{font-size:.875rem;font-weight:600;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.05em;margin-bottom:4px}.score-number-group{display:flex;align-items:baseline;gap:2px}.score-large{font-family:var(--font-display);font-size:2.5rem;font-weight:700;color:var(--color-primary);line-height:1}.score-max{font-size:1rem;color:var(--color-text-muted);font-weight:500}.comments-section{display:flex;flex-direction:column;gap:var(--spacing-sm);margin-bottom:var(--spacing-xl)}.comments-section label{font-weight:600;font-size:.875rem;color:var(--color-text-base)}.comments-input{width:100%;padding:var(--spacing-md);border:1px solid var(--color-border);border-radius:var(--radius-md);font-family:inherit;font-size:.875rem;resize:vertical;min-height:100px;background-color:var(--color-bg-base);transition:border-color var(--transition-fast),box-shadow var(--transition-fast)}.comments-input:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 2px var(--color-primary-subtle)}.review-actions{margin-top:auto;margin-bottom:var(--spacing-xl)}.btn-primary{width:100%;padding:var(--spacing-md);background-color:var(--color-primary);color:#fff;border:none;border-radius:var(--radius-md);font-weight:600;font-size:1rem;cursor:pointer;transition:background-color var(--transition-fast),transform var(--transition-fast),box-shadow var(--transition-fast);box-shadow:var(--shadow-sm)}.btn-primary:hover:not(:disabled){background-color:var(--color-primary-hover);box-shadow:var(--shadow-md)}.btn-primary:active:not(:disabled){background-color:var(--color-primary-active);transform:translateY(1px)}.btn-primary:disabled{background-color:var(--color-border);color:var(--color-text-muted);cursor:not-allowed;box-shadow:none}.decision-section{border-top:1px solid var(--color-border);padding-top:var(--spacing-lg)}.decision-section h4{font-size:1rem;color:var(--color-text-base);margin-bottom:4px}.decision-hint{font-size:.75rem;color:var(--color-text-muted);margin-bottom:var(--spacing-md)}.decision-buttons{display:grid;grid-template-columns:1fr 1fr 1fr;gap:var(--spacing-sm)}.btn-decision{padding:var(--spacing-sm) 0;border-radius:var(--radius-md);font-weight:600;font-size:.875rem;cursor:pointer;background-color:var(--color-bg-surface);border:1px solid var(--color-border);transition:background-color var(--transition-fast),border-color var(--transition-fast),color var(--transition-fast)}.btn-decision.accept{color:#0f7033;border-color:#d4f7e1;background-color:#e9fbf0}.btn-decision.accept:hover{background-color:#d4f7e1}.btn-decision.waitlist{color:#935f06;border-color:#fef3c8;background-color:#fefae6}.btn-decision.waitlist:hover{background-color:#fef3c8}.btn-decision.reject{color:#bc1010;border-color:#fcd9d9;background-color:#fdecec}.btn-decision.reject:hover{background-color:#fcd9d9}.split-view-container{position:fixed;inset:0;z-index:50;display:flex;justify-content:flex-end;visibility:hidden;pointer-events:none}.split-view-container.open{visibility:visible;pointer-events:auto}.split-view-mask{position:absolute;inset:0;background-color:#0000004d;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);opacity:0;transition:opacity var(--transition-default)}.split-view-container.open .split-view-mask{opacity:1}.split-view-panel{position:relative;width:100%;max-width:1200px;height:100vh;background-color:var(--color-bg-base);box-shadow:-10px 0 30px #0000001a;display:flex;flex-direction:column;transform:translate(100%);transition:transform var(--transition-default);background:#fffffff2;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px)}.split-view-container.open .split-view-panel{transform:translate(0)}.panel-header{height:80px;padding:0 var(--spacing-xl);border-bottom:1px solid var(--color-border);display:flex;align-items:center;justify-content:space-between;background-color:var(--color-bg-surface);flex-shrink:0}.applicant-overview{display:flex;flex-direction:column}.panel-title{font-size:1.5rem;color:var(--color-text-base);margin-bottom:2px}.panel-subtitle{font-size:.875rem;color:var(--color-text-muted)}.panel-actions{display:flex;align-items:center;gap:var(--spacing-md)}.close-btn{background-color:var(--color-bg-base);border:1px solid var(--color-border);border-radius:var(--radius-full);width:36px;height:36px;display:flex;align-items:center;justify-content:center}.close-btn:hover{background-color:var(--color-border);transform:scale(1.05)}.panel-content{flex-grow:1;display:flex;overflow:hidden}.applicant-data-section{flex:3;overflow-y:auto;padding:var(--spacing-xl);border-right:1px solid var(--color-border);background-color:var(--color-bg-base)}.review-panel-section{flex:2;overflow-y:auto;background-color:var(--color-bg-surface);padding:0}.data-group{margin-bottom:var(--spacing-xl);background:var(--color-bg-surface);border-radius:var(--radius-lg);padding:var(--spacing-lg);border:1px solid var(--color-border);box-shadow:var(--shadow-sm)}.data-group h3{font-size:1.125rem;color:var(--color-text-base);margin-bottom:var(--spacing-lg);padding-bottom:var(--spacing-sm);border-bottom:1px solid var(--color-border)}.info-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:var(--spacing-lg)}.info-item{display:flex;align-items:flex-start;gap:var(--spacing-sm)}.info-icon{color:var(--color-primary);margin-top:2px;opacity:.8}.info-content{display:flex;flex-direction:column;gap:2px}.info-label{font-size:.75rem;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.05em;font-weight:600}.info-value{font-size:.875rem;font-weight:500;color:var(--color-text-base)}.document-list{display:flex;flex-direction:column;gap:var(--spacing-sm)}.document-item{display:flex;align-items:center;gap:var(--spacing-md);padding:var(--spacing-sm) var(--spacing-md);border:1px solid var(--color-border);border-radius:var(--radius-md);background-color:var(--color-bg-base);transition:border-color var(--transition-fast)}.document-item:hover{border-color:var(--color-primary-subtle);background-color:var(--color-bg-surface)}.doc-icon-wrapper{color:var(--color-primary);opacity:.8}.doc-details{flex-grow:1;display:flex;flex-direction:column}.doc-name{font-size:.875rem;font-weight:500}.doc-size{font-size:.75rem;color:var(--color-text-muted)}.btn-secondary{background-color:var(--color-bg-base);color:var(--color-text-base);border:1px solid var(--color-border);border-radius:var(--radius-sm);font-weight:500;cursor:pointer;transition:background-color var(--transition-fast)}.btn-secondary:hover{background-color:var(--color-border)}.btn-sm{padding:.25rem .75rem;font-size:.875rem}.qa-item{margin-bottom:var(--spacing-lg)}.qa-item:last-child{margin-bottom:0}.question{font-weight:600;font-size:.9rem;margin-bottom:var(--spacing-xs);color:var(--color-text-base)}.answer{font-size:.9rem;color:var(--color-text-muted);line-height:1.6;background:var(--color-bg-base);padding:var(--spacing-md);border-radius:var(--radius-md);border-left:3px solid var(--color-primary-subtle)}@media(max-width:1024px){.panel-content{flex-direction:column}.applicant-data-section{border-right:none;border-bottom:1px solid var(--color-border);flex:none;height:auto}}@media(max-width:768px){.panel-header{flex-direction:column;align-items:flex-start;padding:var(--spacing-md);height:auto;gap:var(--spacing-md)}.panel-actions{width:100%;justify-content:space-between}.data-group{padding:var(--spacing-md)}}.attendance-page{display:flex;flex-direction:column;gap:var(--spacing-lg)}.attendance-summary{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:var(--spacing-md)}.summary-card{background:var(--color-bg-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:var(--spacing-lg);display:flex;align-items:center;gap:var(--spacing-md);box-shadow:var(--shadow-sm);transition:transform var(--transition-default),box-shadow var(--transition-default)}.summary-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-md)}.summary-card-icon{width:48px;height:48px;border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;flex-shrink:0}.summary-card-icon.total{background:#e3ebfd;color:#1152d4}.summary-card-icon.present{background:#dcf9e8;color:#1b984f}.summary-card-icon.late{background:#feeccd;color:#c78005}.summary-card-icon.absent{background:#fadbdb;color:#c91d1d}.summary-card-info h3{font-size:.75rem;font-weight:500;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.05em;margin-bottom:2px}.summary-card-info .summary-value{font-size:1.5rem;font-weight:700;color:var(--color-text-base);font-family:var(--font-display)}.attendance-toolbar{background:var(--color-bg-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:var(--spacing-md) var(--spacing-lg);display:flex;flex-wrap:wrap;gap:var(--spacing-md);align-items:center;box-shadow:var(--shadow-sm)}.attendance-search{flex:1;min-width:220px;position:relative}.attendance-search .search-icon{position:absolute;left:12px;top:50%;transform:translateY(-50%);color:var(--color-text-muted);pointer-events:none}.attendance-search input{width:100%;padding:.6rem .75rem .6rem 2.5rem;border:1px solid var(--color-border);border-radius:var(--radius-sm);font-size:.875rem;font-family:var(--font-sans);color:var(--color-text-base);background:var(--color-bg-base);transition:border-color var(--transition-fast),box-shadow var(--transition-fast)}.attendance-search input:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px #2b6cee26}.attendance-filter select{padding:.6rem .75rem;border:1px solid var(--color-border);border-radius:var(--radius-sm);font-size:.875rem;font-family:var(--font-sans);color:var(--color-text-base);background:var(--color-bg-surface);cursor:pointer;transition:border-color var(--transition-fast);min-width:160px}.attendance-filter select:focus{outline:none;border-color:var(--color-primary)}.attendance-filter-date input[type=date]{padding:.6rem .75rem;border:1px solid var(--color-border);border-radius:var(--radius-sm);font-size:.875rem;font-family:var(--font-sans);color:var(--color-text-base);background:var(--color-bg-surface);transition:border-color var(--transition-fast)}.attendance-filter-date input[type=date]:focus{outline:none;border-color:var(--color-primary)}.attendance-filter-date span{color:var(--color-text-muted);font-size:.8rem;margin:0 4px}.attendance-table-wrapper{background:var(--color-bg-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);box-shadow:var(--shadow-sm);overflow:hidden}.attendance-table{width:100%;border-collapse:collapse;font-size:.875rem}.attendance-table thead{background:var(--color-bg-base);border-bottom:2px solid var(--color-border)}.attendance-table th{padding:.75rem 1rem;text-align:left;font-weight:600;color:var(--color-text-muted);font-size:.75rem;text-transform:uppercase;letter-spacing:.05em;white-space:nowrap}.attendance-table td{padding:.75rem 1rem;border-bottom:1px solid var(--color-border);color:var(--color-text-base)}.attendance-table tbody tr{transition:background-color var(--transition-fast)}.attendance-table tbody tr:hover{background-color:#2b6cee0a}.attendance-table tbody tr:last-child td{border-bottom:none}.status-badge{display:inline-flex;align-items:center;gap:4px;padding:3px 10px;border-radius:var(--radius-full);font-size:.75rem;font-weight:600;white-space:nowrap}.status-badge.present{background:#dcf9e8;color:#178244}.status-badge.late{background:#feeccd;color:#8a5d0f}.status-badge.absent{background:#fbe0e0;color:#ad1f1f}.status-badge.excused{background:#e4eaf6;color:#359}.attendance-empty,.attendance-loading,.attendance-error{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--spacing-xl) var(--spacing-lg);text-align:center;min-height:300px;background:var(--color-bg-surface);border:1px solid var(--color-border);border-radius:var(--radius-md)}.attendance-empty .empty-icon,.attendance-loading .loading-icon,.attendance-error .error-icon{color:var(--color-text-muted);margin-bottom:var(--spacing-md);opacity:.5}.attendance-empty h3,.attendance-loading h3{color:var(--color-text-base);margin-bottom:var(--spacing-xs)}.attendance-empty p,.attendance-loading p{color:var(--color-text-muted);font-size:.875rem;max-width:400px}.attendance-error h3{color:#c91d1d;margin-bottom:var(--spacing-xs)}.attendance-error p{color:var(--color-text-muted);font-size:.875rem}.attendance-error .retry-btn{margin-top:var(--spacing-md);padding:.5rem 1.25rem;border:none;border-radius:var(--radius-sm);background:var(--color-primary);color:#fff;font-size:.875rem;font-weight:500;cursor:pointer;transition:background var(--transition-fast)}.attendance-error .retry-btn:hover{background:var(--color-primary-hover)}@keyframes attendance-spin{to{transform:rotate(360deg)}}.attendance-loading .loading-icon{animation:attendance-spin 1.2s linear infinite}.attendance-pagination{display:flex;align-items:center;justify-content:space-between;padding:var(--spacing-md) var(--spacing-lg);border-top:1px solid var(--color-border);font-size:.8rem;color:var(--color-text-muted)}.attendance-pagination .page-info{font-weight:500}.attendance-pagination .page-controls{display:flex;gap:var(--spacing-xs)}.attendance-pagination button{padding:.35rem .75rem;border:1px solid var(--color-border);border-radius:var(--radius-sm);background:var(--color-bg-surface);color:var(--color-text-base);font-size:.8rem;cursor:pointer;transition:all var(--transition-fast)}.attendance-pagination button:hover:not(:disabled){background:var(--color-primary-subtle);border-color:var(--color-primary);color:var(--color-primary)}.attendance-pagination button:disabled{opacity:.4;cursor:not-allowed}.view-mode-toggle{display:flex;gap:.25rem;background:var(--color-bg-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:.35rem;align-self:flex-start;box-shadow:var(--shadow-sm)}.view-mode-btn{display:flex;align-items:center;gap:6px;padding:.45rem 1rem;border:none;border-radius:calc(var(--radius-md) - 2px);font-size:.875rem;font-weight:500;cursor:pointer;color:var(--color-text-muted);background:transparent;transition:all var(--transition-fast);white-space:nowrap}.view-mode-btn:hover{color:var(--color-text-base);background:var(--color-bg-base)}.view-mode-btn.active{background:var(--color-primary);color:#fff;box-shadow:0 1px 4px #2563eb4d}.roster-header{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:.75rem;padding:1rem 1.25rem;border-bottom:1px solid var(--color-border);background:var(--color-bg-base)}.roster-meta{display:flex;flex-direction:column;gap:2px}.roster-course{font-weight:700;font-size:1rem;color:var(--color-text-base)}.roster-date{font-size:.8rem;color:var(--color-text-muted)}.roster-summary-pills{display:flex;gap:.5rem;flex-wrap:wrap}.roster-pill{display:inline-flex;align-items:center;gap:5px;padding:.3rem .75rem;border-radius:var(--radius-full);font-size:.8rem;font-weight:600}.roster-pill.present-pill{background:#dcf9e8;color:#178244}.roster-pill.absent-pill{background:#fbe0e0;color:#ad1f1f}.roster-pill.total-pill{background:#e8ebf3;color:#475c85}.class-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:var(--spacing-md)}.class-grid-caption{font-size:.82rem;color:var(--color-text-muted);padding:0 2px;margin-bottom:var(--spacing-md)}.class-card{display:flex;flex-direction:column;gap:.75rem;width:100%;text-align:left;background:var(--color-bg-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);box-shadow:var(--shadow-sm);padding:1.1rem 1.25rem;cursor:pointer;transition:transform var(--transition-default),box-shadow var(--transition-default),border-color var(--transition-fast)}.class-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-md);border-color:var(--color-primary)}.class-card-top{display:flex;align-items:flex-start;justify-content:space-between;gap:.5rem}.class-name{font-weight:700;font-size:.98rem;line-height:1.3;color:var(--color-text-base);display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;overflow-wrap:anywhere;min-height:2.548rem}.class-go{color:var(--color-text-muted);flex-shrink:0;margin-top:2px}.class-card:hover .class-go{color:var(--color-primary)}.class-card-id{min-height:22px;display:flex;align-items:center}.class-id-chip{align-self:flex-start;font-family:var(--font-mono, monospace);font-size:.72rem;font-weight:600;padding:2px 8px;border-radius:var(--radius-full);background:#e8ebf3;color:#475c85}.class-card-stats{display:flex;gap:.5rem}.class-stat{flex:1;display:flex;flex-direction:column;align-items:center;gap:2px;padding:.5rem .25rem;border-radius:var(--radius-sm)}.class-stat.present{background:#e9fbf1}.class-stat.absent{background:#fceded}.class-stat.total{background:#f2f4f8}.class-stat-num{font-size:1.15rem;font-weight:700;font-family:var(--font-display);color:var(--color-text-base)}.class-stat.present .class-stat-num{color:#178244}.class-stat.absent .class-stat-num{color:#b62020}.class-stat-lbl{font-size:.68rem;text-transform:uppercase;letter-spacing:.04em;color:var(--color-text-muted)}.class-rate-bar{height:6px;border-radius:var(--radius-full);background:var(--color-border);overflow:hidden}.class-rate-fill{height:100%;background:var(--color-primary);border-radius:var(--radius-full);transition:width var(--transition-default)}.class-rate-label{font-size:.75rem;color:var(--color-text-muted);font-weight:500}.class-detail{display:flex;flex-direction:column;gap:var(--spacing-md)}.class-detail-bar{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:.5rem}.class-detail-back{display:inline-flex;align-items:center;gap:4px;padding:.45rem .9rem;border:1px solid var(--color-border);border-radius:var(--radius-sm);background:var(--color-bg-surface);color:var(--color-text-base);font-size:.85rem;font-weight:500;cursor:pointer;transition:all var(--transition-fast)}.class-detail-back:hover{background:var(--color-primary-subtle);border-color:var(--color-primary);color:var(--color-primary)}.class-detail-filter{display:flex;align-items:center;gap:.75rem;flex-wrap:wrap}.class-detail-clear{padding:.4rem .75rem;border:1px solid var(--color-border);border-radius:var(--radius-sm);background:var(--color-bg-surface);color:var(--color-text-muted);font-size:.78rem;font-weight:500;cursor:pointer;transition:all var(--transition-fast)}.class-detail-clear:hover{border-color:var(--color-primary);color:var(--color-primary)}.class-detail-head{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:.75rem;background:var(--color-bg-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);box-shadow:var(--shadow-sm);padding:1.1rem 1.25rem}.class-detail-title{display:flex;align-items:center;gap:.75rem;flex-wrap:wrap}.class-detail-title h2{font-size:1.25rem;font-weight:700;color:var(--color-text-base);margin:0}.class-empty-note{padding:1rem 1.25rem;font-size:.85rem;color:var(--color-text-muted)}.session-block{margin-bottom:var(--spacing-md)}.session-head{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:.75rem;padding:.9rem 1.25rem;background:var(--color-bg-base);border-bottom:1px solid var(--color-border)}.session-when{display:flex;flex-direction:column;gap:2px}.session-date{font-weight:700;font-size:.95rem;color:var(--color-text-base)}.session-time{font-size:.78rem;color:var(--color-text-muted)}@media(max-width:768px){.attendance-toolbar{flex-direction:column;align-items:stretch}.attendance-search{min-width:unset}.attendance-filter select,.attendance-filter-date input[type=date]{width:100%}.attendance-table-wrapper{overflow-x:auto}.attendance-table{min-width:600px}.attendance-summary{grid-template-columns:repeat(2,1fr)}}.class-qr-page{min-height:100vh;background-color:var(--color-bg-base);display:flex;flex-direction:column;padding:2rem;font-family:Inter,system-ui,sans-serif;position:relative}.qr-page-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem}.back-btn{display:flex;align-items:center;gap:8px;background:transparent;border:1px solid var(--color-border);padding:.5rem 1rem;border-radius:8px;color:var(--color-text-base);font-weight:500;cursor:pointer;transition:all .2s}.back-btn:hover{background:var(--color-bg-muted)}.security-badge{display:flex;align-items:center;gap:6px;color:var(--color-success);font-weight:600;font-size:.9rem;background:#22c55e1a;padding:.5rem 1rem;border-radius:20px}.qr-presentation-area{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center}.qr-title-box{margin-bottom:3rem}.qr-title-box h1{font-size:3.5rem;font-weight:800;color:var(--color-text-base);margin:0;margin-bottom:1rem;letter-spacing:-1px}.qr-title-box p{font-size:1.5rem;color:var(--color-text-muted);margin:0}.huge-qr-container{background:#fff;padding:2rem;border-radius:24px;box-shadow:0 20px 40px #00000014;margin-bottom:2rem;border:4px solid var(--color-primary)}.huge-qr-img{height:auto;max-width:100%}.qr-placeholder{width:400px;height:400px;display:flex;align-items:center;justify-content:center;font-size:1.2rem;color:var(--color-text-muted)}.qr-url-display{font-size:1.5rem;color:var(--color-text-muted);margin-bottom:3rem}.qr-url-display strong{color:var(--color-primary)}.qr-action-buttons{display:flex;align-items:center;gap:1rem;flex-wrap:wrap;justify-content:center}.fullscreen-btn{display:flex;align-items:center;gap:10px;background:var(--color-text-base);color:var(--color-bg-base);border:none;padding:1rem 2rem;border-radius:12px;font-size:1.1rem;font-weight:600;cursor:pointer;transition:all .2s;box-shadow:var(--shadow-md)}.fullscreen-btn:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg);background:#000}.stop-attendance-btn{display:flex;align-items:center;gap:10px;background:linear-gradient(135deg,#ef4444,#dc2626);color:#fff;border:none;padding:1rem 2rem;border-radius:12px;font-size:1.1rem;font-weight:600;cursor:pointer;transition:all .2s;box-shadow:0 4px 14px #ef444459}.stop-attendance-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 20px #ef444480;filter:brightness(1.1)}.stop-attendance-btn:active:not(:disabled){transform:translateY(0)}.stop-attendance-btn:disabled{opacity:.7;cursor:wait}.session-ended-message{display:flex;align-items:center;gap:10px;background:#22c55e1a;color:#16a34a;padding:1rem 1.5rem;border-radius:12px;font-size:1.1rem;font-weight:600;border:1.5px solid rgba(34,197,94,.25)}.live-attendance-counter{position:fixed;bottom:1.5rem;right:1.5rem;background:#0f172aeb;backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border-radius:16px;padding:1rem 1.25rem;color:#fff;box-shadow:0 8px 32px #0000004d;z-index:1000;min-width:180px;animation:slideInCounter .4s cubic-bezier(.16,1,.3,1)}.counter-header{display:flex;align-items:center;gap:.5rem;font-weight:700;font-size:.85rem;text-transform:uppercase;letter-spacing:.06em;margin-bottom:.75rem;color:#ffffffd9}.counter-pulse{width:8px;height:8px;background:#22c55e;border-radius:50%;margin-left:auto;animation:pulse 1.5s infinite}.counter-stats{display:flex;flex-direction:column;gap:.5rem}.counter-stat{display:flex;align-items:center;gap:.5rem;font-size:.9rem;padding:.4rem .5rem;border-radius:8px}.counter-stat.checkin-stat{background:#22c55e26;color:#86efac}.counter-stat.checkout-stat{background:#f9731626;color:#fdba74}.counter-number{font-size:1.4rem;font-weight:800;min-width:2ch}.counter-label{font-size:.8rem;opacity:.8;font-weight:500}@keyframes slideInCounter{0%{opacity:0;transform:translateY(20px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}@keyframes pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(1.3)}}:fullscreen .qr-page-header{display:none}:fullscreen .class-qr-page{padding:0;justify-content:center}:fullscreen .huge-qr-container{padding:3rem;box-shadow:0 40px 80px #00000026}:fullscreen .qr-title-box h1{font-size:5rem}:fullscreen .qr-title-box p{font-size:2rem}:fullscreen .live-attendance-counter{bottom:2rem;right:2rem}.mobile-checkin-page{min-height:100vh;background-color:#f8fafc;display:flex;flex-direction:column;font-family:Inter,system-ui,sans-serif}.mobile-app-header{background:#fff;padding:1rem 1.5rem;box-shadow:0 1px 3px #0000000d}.mobile-app-header .logo-container{display:flex;align-items:center;gap:10px}.mobile-app-header .logo-icon{width:32px;height:32px;background:var(--color-primary);color:#fff;border-radius:8px;display:flex;align-items:center;justify-content:center;font-weight:800}.mobile-app-header .logo-text{font-weight:700;color:var(--color-text-base);font-size:1.1rem}.mobile-main{flex:1;padding:2rem 1.5rem;max-width:480px;margin:0 auto;width:100%}.welcome-banner{text-align:center;margin-bottom:2.5rem}.welcome-icon{color:var(--color-primary);margin-bottom:1rem}.welcome-banner h1{font-size:1.8rem;font-weight:800;color:var(--color-text-base);margin:0 0 .5rem;letter-spacing:-.5px}.welcome-banner p{color:var(--color-text-muted);margin:0;font-size:1.05rem}.checkin-card{background:#fff;border-radius:20px;padding:1.5rem;box-shadow:0 10px 25px #0000000d;border:1px solid var(--color-border)}.location-info{display:flex;gap:1rem;margin-bottom:1.5rem;padding-bottom:1.5rem;border-bottom:1px solid var(--color-border)}.loc-item{display:flex;align-items:center;gap:6px;font-size:.85rem;color:var(--color-text-muted);font-weight:500}.loc-item svg{color:var(--color-primary)}.form-group{display:flex;flex-direction:column;gap:.5rem;margin-bottom:1.5rem}.form-group label{font-size:.95rem;font-weight:600;color:var(--color-text-base)}.mobile-select,.mobile-input{padding:1rem;border-radius:12px;border:2px solid var(--color-border);font-size:1rem;font-weight:500;color:var(--color-text-base);background:#f8fafc;transition:all .2s;appearance:none}.mobile-select{cursor:pointer}.mobile-select:focus,.mobile-input:focus{outline:none;border-color:var(--color-primary);background:#fff}.student-verify-card{background:#2563eb0d;border-radius:10px;padding:1rem;margin-bottom:2rem}.verify-row{display:flex;justify-content:space-between;font-size:.95rem;color:var(--color-text-muted)}.verify-value{font-weight:600;color:var(--color-primary)}.action-buttons{display:flex;flex-direction:column;gap:1rem}.btn-submit-attendance{width:100%;padding:1.25rem;border:none;border-radius:14px;font-size:1.1rem;font-weight:600;cursor:pointer;transition:all .2s;color:#fff;background:var(--color-primary);box-shadow:0 4px 14px #2563eb4d}.btn-submit-attendance:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 20px #2563eb66;filter:brightness(1.1)}.btn-submit-attendance:active:not(:disabled){transform:translateY(0)}.btn-submit-attendance:disabled{opacity:.7;cursor:wait;transform:none;box-shadow:none}.result-toast{margin-top:1.5rem;padding:1rem;border-radius:10px;display:flex;align-items:center;gap:10px;font-weight:500;font-size:.95rem;animation:fadeIn .3s ease-out}.result-toast.success{background:#22c55e1a;color:var(--color-success)}.result-toast.error{background:#ef44441a;color:var(--color-danger)}.mobile-footer{display:flex;align-items:center;justify-content:center;gap:6px;margin-top:2rem;color:#94a3b8;font-size:.85rem}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.mobile-app-header{display:none}.lms-page{display:flex;flex-direction:column;gap:1.5rem}.lms-loading,.lms-error{display:flex;flex-direction:column;align-items:center;justify-content:center;height:50vh;gap:1rem;color:var(--color-text-muted)}.lms-error{color:#c32222}.lms-spinner{animation:lms-spin .8s linear infinite}@keyframes lms-spin{to{transform:rotate(360deg)}}.lms-summary{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem}.lms-summary-card{display:flex;align-items:center;gap:1rem;padding:1.25rem;background:var(--color-bg-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);transition:box-shadow .2s}.lms-summary-card:hover{box-shadow:var(--shadow-md)}.lms-card-icon{width:44px;height:44px;border-radius:12px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.lms-card-icon.accepted{background:#e8dffb;color:#6226d9}.lms-card-icon.synced{background:#dcf9e7;color:#1b9849}.lms-card-icon.pending{background:#fff0d6;color:#b8780a}.lms-card-icon.courses{background:#d8f1fd;color:#137bae}.lms-card-info{display:flex;flex-direction:column}.lms-card-value{font-size:1.5rem;font-weight:800;color:var(--color-text-base);line-height:1.2}.lms-card-label{font-size:.8rem;color:var(--color-text-muted);font-weight:500}.lms-toolbar{display:flex;align-items:center;gap:1rem;flex-wrap:wrap}.lms-search{flex:1;min-width:240px;display:flex;align-items:center;background:var(--color-bg-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:0 .75rem;transition:border-color .2s}.lms-search:focus-within{border-color:var(--color-primary)}.lms-search-icon{color:var(--color-text-muted);flex-shrink:0}.lms-search input{flex:1;border:none;background:transparent;padding:.6rem .5rem;font-size:.85rem;color:var(--color-text-base);outline:none}.lms-toolbar-actions{display:flex;gap:.5rem;align-items:center}.lms-btn-primary{display:flex;align-items:center;gap:6px;padding:.55rem 1rem;border:none;border-radius:var(--radius-md);font-size:.82rem;font-weight:600;cursor:pointer;background:linear-gradient(135deg,#713cdd,#5417cf);color:#fff;transition:all .2s;box-shadow:0 2px 8px #6226d94d;white-space:nowrap}.lms-btn-primary:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 4px 12px #6226d966}.lms-btn-primary:disabled{opacity:.6;cursor:not-allowed;transform:none}.lms-btn-secondary{display:flex;align-items:center;gap:6px;padding:.55rem 1rem;border:1px solid var(--color-border);border-radius:var(--radius-md);font-size:.82rem;font-weight:500;cursor:pointer;background:var(--color-bg-surface);color:var(--color-text-base);text-decoration:none;transition:all .2s;white-space:nowrap}.lms-btn-secondary:hover{background:var(--color-bg-subtle)}.lms-empty{text-align:center;padding:4rem 2rem;color:var(--color-text-muted);background:var(--color-bg-surface);border-radius:var(--radius-lg);border:1px solid var(--color-border)}.lms-empty-icon{opacity:.4;margin-bottom:1rem}.lms-empty h3{color:var(--color-text-base);margin:0 0 .5rem}.lms-empty p{margin:0;font-size:.9rem}.lms-table-wrapper{background:var(--color-bg-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);overflow:hidden}.lms-table{width:100%;border-collapse:collapse;table-layout:fixed}.lms-table thead tr{background:var(--color-bg-subtle);border-bottom:1px solid var(--color-border)}.lms-table th{padding:.6rem .75rem;font-size:.7rem;font-weight:600;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.05em;text-align:left}.lms-table td{padding:.65rem .75rem;font-size:.82rem;color:var(--color-text-base);border-bottom:1px solid var(--color-border);vertical-align:middle;overflow:hidden}.lms-table tbody tr{transition:background .15s}.lms-table tbody tr:hover{background:var(--color-bg-subtle)}.lms-table tbody tr.row-synced{background:#e9fbf04d}.td-name{width:22%}.td-courses{width:18%}.student-name-cell{display:flex;align-items:center;gap:.5rem}.student-avatar{width:28px;height:28px;border-radius:50%;background:var(--color-bg-subtle);border:1px solid var(--color-border);display:flex;align-items:center;justify-content:center;font-weight:700;font-size:.72rem;color:var(--color-text-base);flex-shrink:0}.student-name-info{display:flex;flex-direction:column;min-width:0}.student-fullname{font-weight:600;font-size:.82rem;color:var(--color-text-base);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.student-email-sub{font-size:.72rem;color:var(--color-text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.track-badge{display:inline-block;padding:2px 10px;border-radius:999px;font-size:.72rem;font-weight:600;background:#e5eeff;color:#144bb8;border:1px solid hsl(220,60%,85%);white-space:nowrap}.status-badge{display:inline-flex;align-items:center;gap:4px;padding:3px 10px;border-radius:999px;font-size:.72rem;font-weight:600;white-space:nowrap}.status-badge.synced{background:#dcf9e7;color:#17823e;border:1px solid hsl(142,60%,80%)}.status-badge.not-synced{background:#f0f0f0;color:#737373;border:1px solid hsl(0,0%,85%)}.status-badge.error{background:#fce8e8;color:#c32222;border:1px solid hsl(0,60%,85%)}.td-credentials{width:18%}.credentials-info{display:flex;flex-direction:column;gap:3px}.cred-row{display:flex;align-items:center;gap:4px}.cred-row code{font-size:.75rem;background:var(--color-bg-subtle);padding:2px 6px;border-radius:4px;font-family:SF Mono,Fira Code,monospace;color:var(--color-text-base)}.cred-row code.pw{color:#6226d9}.copy-btn{display:flex;align-items:center;justify-content:center;width:22px;height:22px;border:none;background:transparent;cursor:pointer;border-radius:4px;color:var(--color-text-muted);transition:all .15s;padding:0}.copy-btn:hover{background:var(--color-bg-subtle);color:var(--color-primary)}.no-creds{color:var(--color-text-muted);font-size:.8rem}.lms-btn-sync{display:inline-flex;align-items:center;gap:5px;padding:.4rem .75rem;border:none;border-radius:var(--radius-sm);font-size:.78rem;font-weight:600;cursor:pointer;background:var(--color-primary);color:#fff;transition:all .2s;white-space:nowrap}.lms-btn-sync:hover:not(:disabled){filter:brightness(1.1);transform:translateY(-1px)}.lms-btn-sync:disabled{opacity:.7;cursor:wait}.synced-label{font-size:.8rem;font-weight:600;color:#1b9849}.lms-pagination{display:flex;justify-content:space-between;align-items:center;padding:.75rem 1rem;border-top:1px solid var(--color-border)}.lms-page-info{font-size:.8rem;color:var(--color-text-muted)}.lms-page-controls{display:flex;gap:.25rem}.lms-page-controls button{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border:1px solid var(--color-border);border-radius:var(--radius-sm);background:var(--color-bg-surface);cursor:pointer;color:var(--color-text-base);transition:all .15s}.lms-page-controls button:hover:not(:disabled){background:var(--color-bg-subtle)}.lms-page-controls button:disabled{opacity:.4;cursor:not-allowed}@media(max-width:768px){.lms-summary{grid-template-columns:repeat(2,1fr)}.lms-toolbar{flex-direction:column;align-items:stretch}.lms-toolbar-actions{justify-content:flex-end}}.course-selector{position:relative}.course-selector-trigger{display:inline-flex;align-items:center;gap:5px;padding:.35rem .65rem;border:1px solid var(--color-border);border-radius:var(--radius-sm);font-size:.78rem;font-weight:500;cursor:pointer;background:var(--color-bg-surface);color:var(--color-text-base);transition:all .2s;white-space:nowrap}.course-selector-trigger:hover:not(:disabled){border-color:var(--color-primary);background:var(--color-bg-subtle)}.course-selector-trigger:disabled{opacity:.5;cursor:not-allowed}.course-selector-trigger .chevron{transition:transform .2s}.course-selector-trigger .chevron.open{transform:rotate(180deg)}.course-selector-dropdown{position:absolute;top:calc(100% + 4px);left:0;z-index:100;min-width:320px;width:max-content;max-width:450px;max-height:400px;overflow-y:auto;background:var(--color-bg-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);box-shadow:var(--shadow-lg, 0 8px 24px rgba(0, 0, 0, .12));padding:4px 0}.course-selector-header{padding:.5rem .75rem;font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--color-text-muted);border-bottom:1px solid var(--color-border)}.course-option{display:flex;align-items:flex-start;gap:.5rem;padding:.5rem .75rem;cursor:pointer;transition:background .1s}.course-option:hover{background:var(--color-bg-subtle)}.course-option input[type=checkbox]{margin-top:2px;accent-color:hsl(260,70%,55%);flex-shrink:0}.course-option-info{display:flex;flex-direction:column;gap:1px;min-width:0}.course-option-name{font-size:.8rem;font-weight:500;color:var(--color-text-base);line-height:1.3}.course-option-short{font-size:.7rem;color:var(--color-text-muted)}.course-selector-empty{padding:1rem;text-align:center;font-size:.8rem;color:var(--color-text-muted)}.enrolled-tags{display:flex;flex-wrap:wrap;gap:4px}.enrolled-tag{display:inline-block;padding:2px 8px;border-radius:999px;font-size:.68rem;font-weight:600;background:#dcf9e7;color:#17823e;border:1px solid hsl(142,60%,80%);white-space:nowrap}.auto-assigned-courses{display:flex;flex-direction:column;gap:4px}.auto-assigned-courses .course-selector-trigger{font-size:.68rem;padding:2px 6px;height:auto;opacity:.6}.courses-panel{background:var(--color-bg-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);overflow:hidden}.courses-panel-header{display:flex;align-items:center;justify-content:space-between;padding:.9rem 1.25rem;cursor:pointer;-webkit-user-select:none;user-select:none;transition:background .15s}.courses-panel-header:hover{background:var(--color-bg-subtle)}.courses-panel-title{display:flex;align-items:center;gap:.6rem;font-size:.9rem;font-weight:600;color:var(--color-text-base)}.courses-panel-count{font-size:.72rem;font-weight:500;color:var(--color-text-muted);background:var(--color-bg-subtle);border:1px solid var(--color-border);border-radius:999px;padding:1px 8px}.courses-panel-actions{display:flex;align-items:center;gap:.75rem}.courses-panel-chevron{color:var(--color-text-muted);transition:transform .2s;flex-shrink:0}.courses-panel-chevron.open{transform:rotate(180deg)}.courses-panel-body{border-top:1px solid var(--color-border);overflow-x:auto}.courses-table{width:100%;border-collapse:collapse;min-width:620px}.courses-table thead tr{background:var(--color-bg-subtle)}.courses-table th{padding:.6rem 1rem;font-size:.7rem;font-weight:600;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.05em;text-align:left}.courses-table td{padding:.7rem 1rem;font-size:.84rem;color:var(--color-text-base);border-bottom:1px solid var(--color-border);vertical-align:middle}.courses-table tbody tr:last-child td{border-bottom:none}.courses-table tbody tr:hover{background:var(--color-bg-subtle)}.preset-course-name{display:flex;align-items:center;gap:6px;font-weight:500}.prefix-badge{display:inline-block;padding:1px 7px;border-radius:4px;font-size:.65rem;font-weight:700;letter-spacing:.04em;white-space:nowrap;flex-shrink:0}.prefix-badge.prefix-nsf{background:#d8f1fd;color:#106793;border:1px solid hsl(200,70%,80%)}.prefix-badge.prefix-bira{background:#f2dffb;color:#7e1fad;border:1px solid hsl(280,60%,82%)}.type-badge{display:inline-block;padding:2px 9px;border-radius:999px;font-size:.7rem;font-weight:600;white-space:nowrap}.type-badge.type-core{background:#dcf9e7;color:#15793a;border:1px solid hsl(142,60%,80%)}.type-badge.type-elective{background:#fff0d6;color:#936310;border:1px solid hsl(38,70%,80%)}.type-badge.type-session{background:#e8dffb;color:#4e1fad;border:1px solid hsl(260,60%,82%)}.shortname-code{font-size:.74rem;background:var(--color-bg-subtle);padding:2px 7px;border-radius:4px;font-family:SF Mono,Fira Code,monospace;color:var(--color-text-muted)}.moodle-id{font-size:.76rem;background:#e9fbf0;color:#15793a;padding:2px 7px;border-radius:4px;font-family:SF Mono,Fira Code,monospace;border:1px solid hsl(142,60%,84%)}.course-error-msg{color:#d92626;cursor:help;display:flex;align-items:center}.absent-panel{background:#fef5f5;border:1.5px solid hsl(0,70%,82%);border-radius:10px;overflow:hidden}.absent-panel-header{display:flex;align-items:center;justify-content:space-between;padding:.75rem 1rem;background:#fbe9e9;border-bottom:1px solid hsl(0,60%,85%)}.absent-panel-title{display:flex;align-items:center;gap:.5rem;color:#a51d1d;font-weight:600;font-size:.95rem}.absent-count-badge{background:#d92626;color:#fff;border-radius:12px;padding:1px 8px;font-size:.78rem;font-weight:700}.absent-panel-dismiss{background:none;border:none;cursor:pointer;color:#c65353;padding:4px;border-radius:4px;display:flex;align-items:center}.absent-panel-dismiss:hover{background:#f5d6d6}.absent-loading,.absent-all-present{display:flex;align-items:center;gap:.5rem;padding:1rem;color:var(--color-text-muted);font-size:.9rem}.absent-all-present{color:#248f4b}.absent-list{display:flex;flex-direction:column;max-height:300px;overflow-y:auto}.absent-student-row{display:flex;align-items:center;gap:.6rem;padding:.55rem 1rem;border-bottom:1px solid hsl(0,40%,93%);font-size:.88rem}.absent-student-row:last-child{border-bottom:none}.absent-icon{color:#d14747;flex-shrink:0}.absent-name{font-weight:500;color:var(--color-text-primary);min-width:160px}.absent-email{display:flex;align-items:center;gap:.3rem;color:var(--color-text-muted);font-size:.82rem;text-decoration:none}.absent-email:hover{color:var(--color-primary);text-decoration:underline}.drawer-portal-container{position:fixed;inset:0;z-index:100;pointer-events:none;transition:visibility .3s ease}.drawer-portal-container.open{pointer-events:auto}.drawer-overlay{position:absolute;inset:0;background-color:#0006;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);opacity:0;transition:opacity var(--transition-default)}.drawer-portal-container.open .drawer-overlay{opacity:1}.drawer-content{position:absolute;top:0;bottom:0;background:var(--color-bg-base);box-shadow:-10px 0 30px #0000001a;display:flex;flex-direction:column;transition:transform var(--transition-default)}.drawer-right{right:0;transform:translate(100%)}.drawer-left{left:0;transform:translate(-100%)}.drawer-portal-container.open .drawer-content{transform:translate(0)}.drawer-size-sm{width:400px;max-width:100vw}.drawer-size-md{width:600px;max-width:100vw}.drawer-size-lg{width:800px;max-width:100vw}.drawer-size-xl{width:1200px;max-width:100vw}.drawer-size-full{width:100vw}.drawer-header{height:80px;padding:0 var(--spacing-xl);border-bottom:1px solid var(--color-border);display:flex;align-items:center;justify-content:space-between;background-color:var(--color-bg-surface);flex-shrink:0}.drawer-title{font-size:1.5rem;font-weight:600;color:var(--color-text-base);margin:0}.drawer-body{flex-grow:1;overflow-y:auto;display:flex;flex-direction:column}.drawer-close-btn{background-color:transparent;border:1px solid transparent;color:var(--color-text-muted);border-radius:var(--radius-full);width:36px;height:36px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all var(--transition-fast)}.drawer-close-btn:hover{background-color:var(--color-bg-surface-hover, rgba(0,0,0,.05));color:var(--color-text-base)}.nsf-import{display:flex;flex-direction:column;gap:1.5rem}.nsf-tabs{display:inline-flex;background:var(--color-bg-surface);border:1px solid var(--color-border);border-radius:var(--radius-full);padding:3px;gap:2px;width:fit-content}.nsf-tab{border:none;background:transparent;padding:8px 18px;border-radius:var(--radius-full);font-family:inherit;font-size:.875rem;font-weight:600;color:var(--color-text-muted);cursor:pointer;transition:color var(--transition-fast),background-color var(--transition-fast)}.nsf-tab:hover{color:var(--color-text-base)}.nsf-tab.active{background:var(--color-primary-subtle);color:var(--color-primary)}.nsf-panel{background:var(--color-bg-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:1.75rem}.nsf-form-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:1rem 1.25rem}.nsf-field{display:flex;flex-direction:column;gap:.375rem}.nsf-field.full{grid-column:1 / -1}.nsf-label{font-size:.8125rem;font-weight:500;color:var(--color-text-base)}.nsf-label .req{color:#d92626;margin-left:2px}.nsf-input,.nsf-textarea{padding:.5rem .75rem;border:1px solid var(--color-border);border-radius:var(--radius-md);font-family:inherit;font-size:.9rem;color:var(--color-text-base);background:var(--color-bg-base);transition:border-color var(--transition-fast),box-shadow var(--transition-fast)}.nsf-textarea{resize:vertical;min-height:80px}.nsf-input:focus,.nsf-textarea:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px var(--color-primary-subtle)}.nsf-section-title{font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--color-text-muted);margin-bottom:.75rem;padding-bottom:.5rem;border-bottom:1px solid var(--color-border)}.nsf-section+.nsf-section{margin-top:1.75rem}.nsf-actions{display:flex;gap:.75rem;align-items:center;justify-content:flex-end;margin-top:1.75rem;padding-top:1.25rem;border-top:1px solid var(--color-border)}.nsf-btn{padding:.625rem 1.25rem;border-radius:var(--radius-md);font-family:inherit;font-size:.875rem;font-weight:600;cursor:pointer;border:1px solid transparent;transition:background-color var(--transition-fast),transform var(--transition-fast),opacity var(--transition-fast)}.nsf-btn-primary{background:var(--color-primary);color:#fff}.nsf-btn-primary:hover:not(:disabled){background:var(--color-primary-hover);transform:translateY(-1px)}.nsf-btn-primary:disabled{opacity:.55;cursor:not-allowed}.nsf-btn-secondary{background:var(--color-bg-base);color:var(--color-text-base);border-color:var(--color-border)}.nsf-btn-secondary:hover:not(:disabled){background:var(--color-primary-subtle)}.nsf-alert{padding:.75rem 1rem;border-radius:var(--radius-md);font-size:.8125rem}.nsf-alert.success{background:#edfdf3;color:#136c34;border:1px solid hsl(142,55%,80%)}.nsf-alert.error{background:#fdf1f1;color:#ad1f1f;border:1px solid hsl(0,60%,85%)}.nsf-drop{border:2px dashed var(--color-border);border-radius:var(--radius-lg);padding:2.5rem 1.5rem;text-align:center;background:var(--color-bg-base);transition:border-color var(--transition-fast),background-color var(--transition-fast)}.nsf-drop.dragover{border-color:var(--color-primary);background:var(--color-primary-subtle)}.nsf-drop-title{font-weight:600;color:var(--color-text-base);margin-bottom:.25rem}.nsf-drop-sub{font-size:.8125rem;color:var(--color-text-muted);margin-bottom:1rem}.nsf-drop-hidden-input{display:none}.nsf-preview{overflow-x:auto;border:1px solid var(--color-border);border-radius:var(--radius-md);margin-top:1rem}.nsf-preview table{width:100%;border-collapse:collapse;font-size:.8125rem}.nsf-preview th,.nsf-preview td{padding:.5rem .75rem;text-align:left;border-bottom:1px solid var(--color-border);white-space:nowrap}.nsf-preview th{background:var(--color-bg-base);font-weight:600;color:var(--color-text-muted);font-size:.75rem;text-transform:uppercase;letter-spacing:.04em}.nsf-preview tr.bad td{background:#fef6f6}.nsf-preview .row-issue{color:#c32222;font-size:.75rem}.nsf-columns-hint{font-size:.8125rem;color:var(--color-text-muted);background:var(--color-bg-base);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:.75rem 1rem;margin-top:1rem}.nsf-columns-hint code{background:var(--color-primary-subtle);color:var(--color-primary);padding:1px 6px;border-radius:4px;font-size:.8rem}:root{--color-primary-hue: 220;--color-primary-sat: 85%;--color-primary-light: 55%;--color-primary: hsl(var(--color-primary-hue), var(--color-primary-sat), var(--color-primary-light));--color-primary-hover: hsl(var(--color-primary-hue), var(--color-primary-sat), 45%);--color-primary-active: hsl(var(--color-primary-hue), var(--color-primary-sat), 35%);--color-primary-subtle: hsl(var(--color-primary-hue), var(--color-primary-sat), 96%);--color-bg-base: hsl(220, 20%, 98%);--color-bg-surface: hsl(0, 0%, 100%);--color-text-base: hsl(220, 20%, 20%);--color-text-muted: hsl(220, 10%, 45%);--color-border: hsl(220, 15%, 90%);--font-sans: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;--font-display: "Outfit", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;--spacing-xs: .25rem;--spacing-sm: .5rem;--spacing-md: 1rem;--spacing-lg: 1.5rem;--spacing-xl: 2rem;--radius-sm: 6px;--radius-md: 10px;--radius-lg: 16px;--radius-full: 9999px;--shadow-sm: 0 1px 2px rgba(0,0,0,.05);--shadow-md: 0 4px 6px -1px rgba(0,0,0,.05), 0 2px 4px -1px rgba(0,0,0,.03);--shadow-lg: 0 10px 15px -3px rgba(0,0,0,.05), 0 4px 6px -2px rgba(0,0,0,.025);--transition-fast: .15s cubic-bezier(.4, 0, .2, 1);--transition-default: .25s cubic-bezier(.4, 0, .2, 1)}*{box-sizing:border-box;margin:0;padding:0}body{font-family:var(--font-sans);background-color:var(--color-bg-base);color:var(--color-text-base);line-height:1.5;-webkit-font-smoothing:antialiased}h1,h2,h3,h4,h5,h6{font-family:var(--font-display);font-weight:600;letter-spacing:-.02em}.app-container{display:flex;flex-direction:column;min-height:100vh}.app-header{background-color:var(--color-bg-surface);border-bottom:1px solid var(--color-border);padding:var(--spacing-md) var(--spacing-xl);display:flex;align-items:center;box-shadow:var(--shadow-sm);position:sticky;top:0;z-index:10}.app-header h1{font-size:1.25rem;color:var(--color-text-base)}.app-main{flex-grow:1;padding:var(--spacing-xl);display:flex;flex-direction:column}.dashboard-intro{background:var(--color-bg-surface);border-radius:var(--radius-lg);padding:var(--spacing-xl);box-shadow:var(--shadow-md);border:1px solid var(--color-border);transition:transform var(--transition-default),box-shadow var(--transition-default)}.dashboard-intro:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg)}.dashboard-intro h2{color:var(--color-primary);margin-bottom:var(--spacing-sm)}.dashboard-intro p{color:var(--color-text-muted)}
