@import "https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700&display=swap";:root{--primary:#014099;--primary-hover:#012d6c;--bg-color:#f4f6f8;--text-primary:#1f2937;--text-secondary:#4b5563;--panel-bg:#fff;--border-color:#e5e7eb;--panel-shadow:0 4px 12px #0000000d;--error-color:#dc2626;--success-color:#059669}*{box-sizing:border-box;margin:0;padding:0}body{color:var(--text-primary);background-color:var(--bg-color);-webkit-tap-highlight-color:transparent;justify-content:center;align-items:flex-start;min-height:100vh;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;display:flex;overflow-x:hidden}#root{width:100%;max-width:100%;margin:0 auto;padding:1rem}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@keyframes spin{to{transform:rotate(360deg)}}.glass-panel{background:var(--panel-bg);border:1px solid var(--border-color);box-shadow:var(--panel-shadow);border-radius:.75rem;padding:1.5rem;animation:.4s ease-out forwards fadeIn}.title{text-align:center;color:var(--primary);letter-spacing:-.02em;margin-bottom:.25rem;font-size:1.5rem;font-weight:700}.subtitle{text-align:center;color:var(--text-secondary);margin-bottom:1.5rem;font-size:.9rem}.form-group{flex-direction:column;margin-bottom:1rem;display:flex}.form-group label{color:var(--text-secondary);margin-bottom:.4rem;font-size:.85rem;font-weight:600}.input-field{color:var(--text-primary);background:#fff;border:1px solid #d1d5db;border-radius:.375rem;outline:none;width:100%;padding:.75rem 1rem;font-family:inherit;font-size:1rem;transition:all .2s}.input-field:focus{border-color:var(--primary);box-shadow:0 0 0 3px #01409926}.input-field::placeholder{color:#9ca3af}.btn-primary{background:var(--primary);color:#fff;cursor:pointer;border:none;border-radius:.375rem;justify-content:center;align-items:center;gap:.5rem;width:100%;margin-top:1.5rem;padding:.875rem;font-size:1rem;font-weight:600;transition:all .2s;display:flex}.btn-primary:hover:not(:disabled){background:var(--primary-hover)}.btn-primary:active:not(:disabled){transform:scale(.98)}.btn-primary:disabled{opacity:.7;cursor:not-allowed}.spinner{border:2px solid #ffffff4d;border-top-color:#fff;border-radius:50%;width:18px;height:18px;animation:.8s linear infinite spin}.app-container{flex-direction:column;justify-content:center;align-items:center;width:100%;min-height:calc(100vh - 2rem);display:flex}.login-form-container{width:100%;max-width:400px}.results-container{width:100%;max-width:500px}.alert-error{border-left:4px solid var(--error-color);color:#b91c1c;background:#fef2f2;border-radius:4px;margin-bottom:1.5rem;padding:.75rem 1rem;font-size:.85rem;line-height:1.4}.dashboard-grid{flex-direction:column;gap:.75rem;margin-bottom:2rem;display:flex}.stat-card{border:1px solid var(--border-color);background:#f8fafc;border-radius:.5rem;flex-direction:column;padding:1rem 1.25rem;display:flex}.stat-label{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em;margin-bottom:.25rem;font-size:.75rem;font-weight:600}.stat-value{color:var(--primary);font-size:1.25rem;font-weight:700}.stat-subtitle{color:var(--text-secondary);margin-top:.2rem;font-size:.8rem}.badge{color:#475569;background:#f1f5f9;border-radius:9999px;padding:.2rem .6rem;font-size:.75rem;font-weight:600;display:inline-block}.badge.success{color:#047857;background:#d1fae5;border:1px solid #a7f3d0}.seating-chart-container{border:1px solid var(--border-color);background:#fff;border-radius:.5rem;margin:1.5rem 0;overflow:hidden}.seating-chart-title{border-bottom:1px solid var(--border-color);color:var(--text-primary);background:#f8fafc;padding:.75rem 1rem;font-size:.9rem;font-weight:600}.seating-chart-img{width:100%;height:auto;display:block}.attendance-list{flex-direction:column;gap:.75rem;display:flex}.empty-state{text-align:center;color:#64748b;border:1px dashed var(--border-color);background:#f8fafc;border-radius:.5rem;padding:2rem 1rem;font-size:.9rem}.attendance-card{border:1px solid var(--border-color);background:#fff;border-radius:.5rem;flex-direction:column;gap:.5rem;padding:1rem;display:flex}.attendance-header{justify-content:space-between;align-items:center;display:flex}.attendance-date{color:var(--text-primary);font-size:.9rem;font-weight:600}.attendance-status{background:#f1f5f9;border-radius:.25rem;padding:.2rem .6rem;font-size:.8rem;font-weight:600}.status-present{color:#059669}.status-absent{color:#dc2626}.status-late{color:#d97706}.status-unknown{color:#64748b}.attendance-details{color:var(--text-secondary);justify-content:space-between;align-items:flex-start;font-size:.85rem;display:flex}.attendance-category{color:#4b5563}.attendance-instructor{text-align:right;color:#6b7280;max-width:60%;line-height:1.3}.header-action{justify-content:space-between;align-items:center;margin-bottom:1.5rem;display:flex}.btn-icon{color:var(--text-secondary);border:1px solid var(--border-color);cursor:pointer;background:#f8fafc;border-radius:.375rem;padding:.4rem .8rem;font-size:.8rem;transition:all .2s}.btn-icon:active{background:#e2e8f0;transform:scale(.95)}@media (width>=640px){#root{padding:2rem}.dashboard-grid{flex-flow:wrap}.stat-card{flex:1;min-width:140px}.glass-panel{padding:2.5rem}.title{font-size:1.75rem}}
