.login-page-new{min-height:100vh;display:flex;align-items:center;justify-content:center;background-color:var(--bg);font-family:var(--font);padding:20px}.login-card-new{background:var(--bg);width:100%;max-width:420px;border-radius:12px;overflow:hidden;display:flex;flex-direction:column;animation:fadeIn .5s ease}@media (max-width: 480px){.login-page-new{padding:0}.login-card-new{max-width:100%;min-height:100vh;border-radius:0;box-shadow:none}}.login-header-new{background:linear-gradient(135deg,#37352f,#2f2f2c);padding:44px 20px 36px;display:flex;flex-direction:column;align-items:center;color:#fff;border-bottom-left-radius:20px;border-bottom-right-radius:20px;text-align:center;box-shadow:none}.login-logo-circle{width:72px;height:72px;background:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;margin-bottom:16px;box-shadow:none;border:1px solid var(--border)}.login-logo-circle svg{width:36px;height:36px;color:var(--secondary)}.logo-img-new{width:56px;height:56px;object-fit:contain;border-radius:50%}.login-header-new h2{font-size:var(--fs-xl);font-weight:var(--fw-bold);margin-bottom:6px;letter-spacing:-.01em}.login-header-new p{font-size:var(--fs-sm);opacity:.85;font-weight:var(--fw-medium)}.login-form-new{padding:40px 32px;flex:1;display:flex;flex-direction:column;justify-content:space-between}.login-form-new .form-group{margin-bottom:24px}.login-form-new .form-label{font-size:var(--fs-sm);font-weight:var(--fw-semibold);color:var(--text);margin-bottom:8px;display:block}.login-form-new .form-input{width:100%;padding:11px 14px;border:1.5px solid var(--border);border-radius:6px;font-size:var(--fs-sm);transition:all .2s ease;background-color:#fff;color:var(--text)}.login-form-new .form-input:focus{border-color:var(--primary);box-shadow:none;outline:none}.login-form-new .form-input::placeholder{color:#94a3b8}.password-wrapper-new{position:relative}.password-wrapper-new .form-input{padding-right:48px}.password-toggle-new{position:absolute;right:14px;top:50%;transform:translateY(-50%);background:none;border:none;cursor:pointer;color:#94a3b8;display:flex;align-items:center;padding:4px;transition:color .2s}.password-toggle-new:hover{color:var(--text)}.btn-signin-new{width:100%;background:linear-gradient(135deg,#37352f,#2f2f2c);color:#fff;border:none;padding:12px;border-radius:8px;font-size:var(--fs-sm);font-weight:var(--fw-semibold);cursor:pointer;transition:transform .1s ease,opacity .2s;box-shadow:none;display:flex;align-items:center;justify-content:center;gap:8px}.btn-signin-new:hover{opacity:.95;transform:translateY(-1px)}.btn-signin-new:active{transform:translateY(0)}.btn-signin-new:disabled{opacity:.6;cursor:not-allowed;transform:none}.login-footer-new{text-align:center;font-size:var(--fs-xs);color:var(--text-muted);margin-top:40px;font-weight:var(--fw-medium)}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.login-error-new{background-color:#fef2f2;border:1px solid #f87171;color:#dc2626;padding:10px 14px;border-radius:6px;margin-bottom:20px;display:flex;align-items:center;gap:10px;font-size:var(--fs-sm);font-weight:var(--fw-medium);animation:fadeIn .3s ease}@keyframes shake{10%,90%{transform:translate3d(-1px,0,0)}20%,80%{transform:translate3d(2px,0,0)}30%,50%,70%{transform:translate3d(-4px,0,0)}40%,60%{transform:translate3d(4px,0,0)}}.no-scrollbar::-webkit-scrollbar{display:none}.no-scrollbar{-ms-overflow-style:none;scrollbar-width:none}@keyframes shimmer{0%{background-position:-600px 0}to{background-position:600px 0}}.sk{background:linear-gradient(90deg,#eef0ff 25%,#e2e4f0,#eef0ff 75%);background-size:600px 100%;animation:shimmer 1.4s infinite linear;border-radius:8px}:root{--primary: #37352F;--primary-dark: #2F2F2C;--primary-light: #F1F1EF;--secondary: #787774;--accent: #f97316;--success: #059669;--danger: #ef4444;--danger-light: #fef2f2;--warning: #f59e0b;--bg: #FAFAF8;--bg-card: #FFFFFF;--text: #1A1A18;--text-muted: #787774;--border: #E9E9E6;--sidebar-bg: #F7F7F5;--sidebar-text: #37352F;--sidebar-active: #EEEEE9;--radius: 10px;--radius-sm: 6px;--shadow-sm: none;--shadow: none;--shadow-md: none;--shadow-lg: none;--font: "Google Sans", "Inter", system-ui, -apple-system, sans-serif;--fs-xs: .75rem;--fs-xxs: .625rem;--fs-tiny: .5rem;--fs-sm: .875rem;--fs-base: 1rem;--fs-lg: 1.125rem;--fs-xl: 1.25rem;--fs-xxl: 1.5rem;--fw-regular: 400;--fw-medium: 500;--fw-semibold: 600;--fw-bold: 700;--fw-extrabold: 800}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0;-webkit-tap-highlight-color:transparent;-webkit-touch-callout:none}html{font-size:16px;scroll-behavior:smooth}body{font-family:var(--font);background:var(--bg);color:var(--text);line-height:1.6;font-weight:var(--fw-regular);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.app-layout{display:flex;min-height:100vh}.sidebar{width:252px;background:var(--sidebar-bg);border-right:1px solid var(--border);display:flex;flex-direction:column;position:fixed;top:0;left:0;bottom:0;z-index:100;transition:transform .3s cubic-bezier(.4,0,.2,1)}.sidebar-logo{height:58px;padding:0 24px;border-bottom:1px solid var(--border);display:flex;align-items:center}.sidebar-logo h1{font-family:var(--font);color:var(--text);font-size:.9rem;font-weight:var(--fw-semibold);line-height:1.3;display:flex;align-items:center;gap:10px;letter-spacing:-.01em}.sidebar-logo h1 svg,.sidebar-logo h1 img{width:26px;height:26px;color:var(--primary);flex-shrink:0;object-fit:contain}.sidebar-nav{flex:1;padding:16px 12px;overflow-y:auto}.nav-section-title{font-size:.65rem;font-weight:var(--fw-semibold);letter-spacing:.08em;text-transform:uppercase;color:#9b9b98;padding:14px 14px 8px}.nav-item{display:flex;align-items:center;gap:10px;padding:8px 12px;border-radius:var(--radius-sm);color:#5a5955;text-decoration:none;font-size:var(--fs-sm);font-weight:var(--fw-medium);cursor:pointer;border:none;background:none;width:100%;margin-bottom:2px;position:relative;letter-spacing:-.005em}.nav-item:hover{background:var(--sidebar-active);color:var(--text)}.nav-item.active{background:var(--bg-card);color:var(--primary);font-weight:var(--fw-semibold);border:1px solid var(--border);box-shadow:0 1px 2px #0000000d}.nav-item.active:before{display:none}.nav-item svg{width:16px;height:16px;flex-shrink:0;stroke-width:1.8;opacity:.65}.nav-item:hover svg{opacity:.9;color:var(--text)}.nav-item.active svg{color:var(--primary);opacity:1}.sidebar-footer{padding:16px 12px;border-top:1px solid var(--border)}.sidebar-footer .nav-item{color:var(--danger)}.sidebar-footer .nav-item svg{color:var(--danger)}.sidebar-footer .nav-item:hover{background:var(--danger-light);color:var(--danger)}.main-content{flex:1;margin-left:252px;min-height:100vh;display:flex;flex-direction:column}.topbar{background:var(--bg-card);border-bottom:1px solid var(--border);height:58px;padding:0 24px;display:flex;align-items:center;justify-content:space-between;position:sticky;top:0;z-index:50;box-shadow:none}.topbar-title{font-size:var(--fs-sm);font-weight:var(--fw-semibold);color:var(--text);letter-spacing:-.01em}.topbar-user{display:flex;align-items:center;gap:10px;font-size:.85rem;color:var(--text-muted)}.avatar{width:32px;height:32px;border-radius:50%;background:var(--primary);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:var(--fw-medium);font-size:var(--fs-xs);letter-spacing:.02em}.user-dropdown{position:absolute;top:calc(100% + 10px);right:0;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-sm);box-shadow:none;padding:8px;min-width:150px;z-index:100;animation:slideUp .2s ease}.dropdown-item{display:flex;align-items:center;gap:10px;width:100%;padding:8px 12px;border:none;background:none;color:#f87171;font-size:.85rem;font-family:var(--font);cursor:pointer;border-radius:6px;transition:all .15s}.dropdown-item:hover{background:#f871711a;color:#ef4444}.page{padding:28px 32px;flex:1}.card{background:var(--bg-card);border-radius:var(--radius);border:1px solid var(--border);box-shadow:none;padding:24px;transition:transform .2s ease}.card-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px}.card-title{font-size:var(--fs-base);font-weight:var(--fw-bold);color:var(--text);letter-spacing:-.01em}.card-subtitle{font-size:var(--fs-xs);color:var(--text-muted);margin-top:3px}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px;margin-bottom:24px}.stat-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:20px;display:flex;align-items:center;gap:16px;box-shadow:none;transition:transform .2s ease}.stat-card:hover{transform:translateY(-1px);box-shadow:none}.stat-icon{width:46px;height:46px;border-radius:10px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.stat-icon svg{width:22px;height:22px;stroke-width:1.8}.stat-icon.blue{background:#eef2ff;color:#3b5bdb}.stat-icon.green{background:#ecfdf5;color:var(--success)}.stat-icon.amber{background:#fffbeb;color:var(--warning)}.stat-icon.red{background:#fef2f2;color:var(--danger)}.stat-icon.cyan{background:#e0f2fe;color:#0369a1}.stat-value{font-size:var(--fs-xl);font-weight:var(--fw-semibold);line-height:1.1;letter-spacing:-.02em;color:var(--text)}.stat-label{font-size:var(--fs-xs);color:var(--text-muted);margin-top:3px;font-weight:var(--fw-regular)}.btn{display:inline-flex;align-items:center;gap:7px;padding:9px 18px;border-radius:var(--radius-sm);font-size:var(--fs-sm);font-weight:var(--fw-semibold);font-family:var(--font);cursor:pointer;border:none;transition:all .18s cubic-bezier(.4,0,.2,1);text-decoration:none;letter-spacing:-.005em}.btn svg{width:16px;height:16px;stroke-width:2}.btn-primary{background:var(--primary);color:#fff;box-shadow:none}.btn-primary:hover{background:var(--primary-dark);box-shadow:none;transform:translateY(-1px)}.btn-secondary{background:var(--bg-card);color:var(--text);border:1px solid var(--border)}.btn-secondary:hover{background:#f8fafc;border-color:#cbd5e1}.btn-danger{background:#fef2f2;color:var(--danger);border:1px solid #fecaca}.btn-danger:hover{background:var(--danger);color:#fff;box-shadow:none}.btn-success{background:#ecfdf5;color:var(--success);border:1px solid #a7f3d0}.btn-success:hover{background:var(--success);color:#fff;box-shadow:none}.btn-sm{padding:6px 12px;font-size:var(--fs-xs)}.btn-icon{padding:8px;border-radius:var(--radius-sm)}.btn:disabled{opacity:.55;cursor:not-allowed;transform:none!important}.btn:active:not(:disabled){transform:translateY(0) scale(.98)}.form-group{margin-bottom:16px}.form-label{display:block;font-size:var(--fs-sm);font-weight:var(--fw-semibold);color:var(--text);margin-bottom:6px;letter-spacing:.01em}.form-input,.form-select{width:100%;padding:10px 14px;border:1.5px solid var(--border);border-radius:var(--radius-sm);font-size:var(--fs-base);font-family:var(--font);color:var(--text);background:var(--bg-card);transition:border-color .2s;outline:none}.form-select{appearance:none;-webkit-appearance:none;-moz-appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 24 24' stroke='%23475569' stroke-width='2'%3E%3Cpath stroke-linecap='round' stroke-linejoin='round' d='M19 9l-7 7-7-7'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 14px center;background-size:16px;padding-right:36px}.form-input[type=date],.form-input[type=month]{position:relative;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 24 24' stroke='%23475569' stroke-width='2'%3E%3Cpath stroke-linecap='round' stroke-linejoin='round' d='M8 7V3m8 4V3m-9 8h10M5 21h14a2 2 0 002-2V7a2 2 0 00-2-2H5a2 2 0 00-2 2v12a2 2 0 002 2z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 14px center;background-size:16px;padding-right:36px}.form-input[type=date]::-webkit-calendar-picker-indicator,.form-input[type=month]::-webkit-calendar-picker-indicator{position:absolute;left:0;top:0;width:100%;height:100%;opacity:0;cursor:pointer}.form-input:focus,.form-select:focus{border-color:var(--primary);box-shadow:none;background:var(--bg)}.form-input::placeholder{color:#94a3b8}.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px}.form-grid-3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:16px}.input-with-icon{position:relative}.input-with-icon>svg{position:absolute;left:14px;top:50%;transform:translateY(-50%);width:16px;height:16px;color:#94a3b8;stroke-width:1.8;pointer-events:none}.input-with-icon .form-input{padding-left:40px}.table-wrap{overflow-x:auto}table{width:100%;border-collapse:collapse;font-size:var(--fs-sm)}thead tr{background:#f7f7f5}th{padding:11px 16px;text-align:left;font-size:var(--fs-xs);font-weight:var(--fw-bold);color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em;border-bottom:1px solid var(--border)}td{padding:12px 16px;border-bottom:1px solid var(--border);color:var(--text);vertical-align:middle}tr:last-child td{border-bottom:none}tbody tr{transition:background .15s ease}tbody tr:hover{background:#f7f7f5}tbody tr:nth-child(2n){background:transparent}tbody tr:nth-child(2n):hover{background:#f7f7f5}.clickable-row{cursor:pointer}.clickable-row:hover{background:#f7f7f5!important;box-shadow:none;transition:all .2s ease}tr.clickable-row:hover{transform:none;box-shadow:none}.badge{display:inline-flex;align-items:center;gap:4px;padding:3px 10px;border-radius:100px;font-size:var(--fs-xs);font-weight:var(--fw-semibold);letter-spacing:.01em}.badge-green{background:#ecfdf5;color:var(--success)}.badge-red{background:#fef2f2;color:var(--danger)}.badge-blue{background:#eef2ff;color:#3b5bdb}.badge-amber{background:#fffbeb;color:var(--warning)}.badge-gray{background:#f1f1ef;color:#787774}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0f172a80;display:flex;align-items:center;justify-content:center;z-index:200;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);animation:fadeIn .15s ease}.modal{background:var(--bg-card);border-radius:var(--radius);box-shadow:none;border:1px solid var(--border);padding:28px;width:90%;max-width:520px;max-height:90vh;overflow-y:auto;animation:slideUp .25s cubic-bezier(.4,0,.2,1)}.modal-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px}.modal-title{font-size:var(--fs-lg);font-weight:var(--fw-bold);letter-spacing:-.01em}.modal-close{width:32px;height:32px;border-radius:8px;border:none;background:#f1f5f9;color:var(--text-muted);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .15s}.modal-close:hover{background:#e2e8f0;color:var(--text)}.modal-close svg{width:16px;height:16px;stroke-width:2}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--bg);padding:20px;position:relative;overflow:hidden}.login-container{display:flex;background:#fff;border-radius:24px;box-shadow:none;overflow:hidden;width:100%;max-width:1000px;min-height:600px;z-index:10;border:1px solid var(--border)}.login-form-side{flex:1;padding:60px 48px;display:flex;flex-direction:column;justify-content:center;background:#fff}.login-image-side{flex:1.2;background:linear-gradient(135deg,var(--primary) 0%,var(--primary-dark) 100%);display:flex;flex-direction:column;align-items:center;justify-content:center;padding:48px;color:#fff;text-align:center;position:relative;overflow:hidden}.login-image-side:before{content:"";position:absolute;width:600px;height:600px;background:radial-gradient(circle,rgba(255,255,255,.1) 0%,transparent 70%);top:-200px;right:-200px;border-radius:50%}.login-image-side:after{content:"";position:absolute;width:400px;height:400px;background:radial-gradient(circle,rgba(255,255,255,.05) 0%,transparent 70%);bottom:-100px;left:-100px;border-radius:50%}.login-image-side h2{font-size:var(--fs-xxl);font-weight:var(--fw-extrabold);margin-bottom:16px;line-height:1.2;z-index:2}.login-image-side p{font-size:var(--fs-base);opacity:.85;max-width:400px;line-height:1.6;z-index:2}.login-logo{display:flex;flex-direction:column;margin-bottom:40px}.login-logo .logo-icon{width:54px;height:54px;background:var(--primary-light);border-radius:14px;display:flex;align-items:center;justify-content:center;margin-bottom:16px}.login-logo .logo-icon svg{width:28px;height:28px;color:var(--primary);stroke-width:2}.login-logo h1{font-family:var(--font);font-size:var(--fs-xxl);font-weight:var(--fw-extrabold);color:var(--text);letter-spacing:-.02em}.login-logo p{font-size:var(--fs-sm);color:var(--text-muted);margin-top:6px;font-weight:var(--fw-medium)}.login-error-banner{background:var(--danger);color:#fff;padding:14px 18px;border-radius:var(--radius-sm);display:flex;align-items:center;gap:12px;margin-bottom:24px;font-size:var(--fs-sm);font-weight:var(--fw-semibold);box-shadow:none;animation:slideUp .3s cubic-bezier(.4,0,.2,1)}.login-error-banner svg{flex-shrink:0;width:20px;height:20px}@keyframes shake{0%,to{transform:translate(0)}10%,30%,50%,70%,90%{transform:translate(-6px)}20%,40%,60%,80%{transform:translate(6px)}}.shake{animation:shake .5s cubic-bezier(.36,.07,.19,.97) both}.tags-wrap{display:flex;flex-wrap:wrap;gap:6px;padding:8px;border:1.5px solid var(--border);border-radius:var(--radius-sm);min-height:44px;cursor:text;transition:border-color .2s}.tags-wrap:focus-within{border-color:var(--primary);box-shadow:none}.tag{display:flex;align-items:center;gap:4px;background:var(--primary-light);color:var(--primary);border-radius:6px;padding:3px 10px;font-size:var(--fs-xs);font-weight:var(--fw-semibold)}.tag button{background:none;border:none;cursor:pointer;color:var(--primary);font-size:1rem;line-height:1;padding:0;opacity:.6;transition:opacity .15s}.tag button:hover{opacity:1}.tag-input{border:none;outline:none;font-family:var(--font);font-size:.85rem;flex:1;min-width:80px;background:transparent}.attendance-row{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;border-radius:var(--radius-sm);border:1px solid var(--border);margin-bottom:6px;background:var(--bg-card);transition:border-color .15s}.attendance-row:hover{border-color:#cbd5e1;box-shadow:none}.attendance-toggle{display:flex;gap:6px}.toggle-btn{padding:6px 16px;border-radius:6px;border:1.5px solid var(--border);font-size:var(--fs-xs);font-weight:var(--fw-semibold);cursor:pointer;background:none;font-family:var(--font);transition:all .18s cubic-bezier(.4,0,.2,1);display:flex;align-items:center;gap:5px}.toggle-btn svg{width:14px;height:14px;stroke-width:2}.toggle-btn:hover{border-color:#94a3b8}.toggle-btn.present{border-color:var(--success);background:#ecfdf5;color:var(--success)}.toggle-btn.absent{border-color:var(--danger);background:#fef2f2;color:var(--danger)}.credential-box{background:#ecfdf5;border:1.5px solid #a7f3d0;border-radius:var(--radius-sm);padding:16px;margin-top:16px}.credential-box h4{color:var(--success);font-size:var(--fs-sm);font-weight:var(--fw-bold);margin-bottom:8px}.credential-row{display:flex;justify-content:space-between;align-items:center;font-size:.85rem;margin:4px 0}.credential-val{font-family:SF Mono,Fira Code,monospace;font-weight:var(--fw-bold);font-size:var(--fs-sm);background:#fff;padding:3px 10px;border-radius:6px;border:1px solid #d1fae5}.empty-state{text-align:center;padding:48px 24px;color:var(--text-muted)}.empty-state svg{width:48px;height:48px;opacity:.25;margin-bottom:12px;stroke-width:1.2}.empty-state p{font-size:var(--fs-sm);font-weight:var(--fw-medium)}.report-header{text-align:center;margin-bottom:24px}.report-header h2{font-family:var(--font);font-size:var(--fs-xl);font-weight:var(--fw-extrabold);letter-spacing:-.02em;display:flex;align-items:center;justify-content:center;gap:10px}.report-header h2 svg{width:24px;height:24px;color:var(--primary);stroke-width:1.8}.test-block{margin-bottom:20px}.test-block-title{font-weight:var(--fw-bold);color:var(--primary);font-size:var(--fs-sm);margin-bottom:8px;border-left:3px solid var(--primary);padding-left:10px}.progress-bar{background:#e2e8f0;border-radius:100px;height:8px;overflow:hidden}.progress-fill{height:100%;border-radius:100px;transition:width .8s cubic-bezier(.4,0,.2,1)}.page-header{margin-bottom:20px}.page-header h2{font-family:var(--font);font-size:var(--fs-lg);font-weight:var(--fw-semibold);letter-spacing:-.01em;color:var(--text)}.page-header p{font-size:var(--fs-sm);color:var(--text-muted);margin-top:2px;font-weight:var(--fw-regular)}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}::-webkit-scrollbar{width:5px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:3px}::-webkit-scrollbar-thumb:hover{background:#94a3b8}.divider{border:none;border-top:1px solid var(--border);margin:16px 0}.search-wrap{position:relative}.search-wrap svg{position:absolute;left:12px;top:50%;transform:translateY(-50%);color:var(--text-muted);width:16px;height:16px;stroke-width:1.8}.search-input{width:100%;padding:9px 14px 9px 38px;border:1.5px solid var(--border);border-radius:var(--radius-sm);font-size:var(--fs-base);font-family:var(--font);outline:none;background:var(--bg-card);transition:border-color .2s}.search-input:focus{border-color:var(--primary);box-shadow:none}.search-input::placeholder{color:#94a3b8}@media print{.sidebar,.topbar,.no-print{display:none!important}.main-content{margin-left:0}.card{box-shadow:none;border:1px solid #ddd}}@media (max-width: 900px){.login-container{flex-direction:column;max-width:480px;min-height:auto}.login-image-side{display:none}.login-form-side{padding:48px 32px}}@media (max-width: 768px){.sidebar{position:fixed;bottom:0;left:0;right:0;width:100%;max-width:100%;height:auto;min-height:58px;border-radius:0;border:none;border-top:1px solid var(--border);flex-direction:row;top:auto;transform:none;background:#fffffffa;backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);box-shadow:0 -1px 0 var(--border),0 -4px 16px #0000000a;padding:0 8px;padding-bottom:env(safe-area-inset-bottom,0px);justify-content:space-around;align-items:center;z-index:999;gap:0}.sidebar-logo,.nav-section-title,.sidebar-footer{display:none}.sidebar-nav{display:flex;flex-direction:row;width:100%;height:100%;padding:0;justify-content:space-around;align-items:center;overflow:visible;gap:0}.nav-item{width:auto;margin-bottom:0;padding:8px 6px 7px;border-radius:10px;gap:3px;justify-content:center;align-items:center;flex-direction:column;border:none!important;box-shadow:none!important;flex:1;min-width:0;position:relative;color:#9b9b98}.nav-item svg{width:21px;height:21px;stroke-width:1.7;opacity:.55;color:var(--text)}.nav-item:hover svg{opacity:.75}.nav-item.active{color:var(--primary);background:none;padding:8px 6px 7px}.nav-item.active svg{color:var(--primary);opacity:1;stroke-width:2}.nav-item.active:before{display:none}.nav-item.active:after{content:"";position:absolute;top:0;left:50%;transform:translate(-50%);width:20px;height:2px;border-radius:0 0 2px 2px;background:var(--primary);opacity:.8}.nav-label{display:block;font-size:.58rem;font-weight:500;letter-spacing:.01em;line-height:1;white-space:nowrap;color:inherit}.nav-item.active .nav-label{display:block;font-weight:600}@keyframes fadeSlideIn{0%{opacity:0}to{opacity:1}}.main-content{margin-left:0;padding-bottom:80px;width:100%;max-width:100%;overflow-x:clip}.page-header p,.dashboard-subtitle{display:none}.page{padding:14px 16px}.topbar{padding:0 16px;height:52px;min-height:52px;flex-wrap:nowrap}.card{padding:16px;border-radius:var(--radius-sm);margin-bottom:16px;overflow-x:hidden}.card-header{flex-direction:column;align-items:stretch;gap:12px}.card-header>div{flex-direction:column;align-items:stretch!important;gap:10px;width:100%}.card-header>div:last-child{flex-direction:row!important}.card-header>div:last-child .btn{flex:1;justify-content:center}.search-wrap{min-width:100%!important}.form-select{width:100%!important}.stats-grid{grid-template-columns:1fr 1fr;gap:10px;margin-bottom:16px}.stat-card{padding:14px;gap:10px}.form-grid,.form-grid-3{grid-template-columns:1fr}.attendance-row{flex-direction:row!important;align-items:center!important;justify-content:space-between!important;background:transparent!important;border:none!important;border-bottom:1px solid var(--border, #e2e8f0)!important;border-radius:0!important;padding:12px 0!important;margin-bottom:0!important;box-shadow:none;text-align:left!important}.attendance-toggle{justify-content:flex-end!important}.attendance-list-wrapper{background:transparent!important;padding:0!important;border:none!important;box-shadow:none}.save-attendance-btn-container{justify-content:center!important;width:100%!important}.save-attendance-action{width:100%!important;height:50px!important;justify-content:center!important;font-size:1.05rem!important;border-radius:12px!important}.toggle-btn{height:44px!important;padding:0 16px!important;display:flex!important;align-items:center!important;font-size:.92rem!important;font-weight:var(--fw-semibold)!important;border-radius:10px!important}}.badge-class-12{background:#fffbeb!important;color:#d97706!important}.badge-class-11{background:#eff6ff!important;color:#2563eb!important}.badge-class-10{background:#f0fdf4!important;color:#16a34a!important}.badge-class-9{background:#faf5ff!important;color:#9333ea!important}.badge-class-8{background:#fff1f2!important;color:#e11d48!important}.badge-class-other{background:#f1f5f9!important;color:#475569!important}.drawer-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0f172a66;z-index:1000;display:flex;justify-content:flex-end;animation:fadeIn .3s ease forwards}.drawer{width:100%;max-width:520px;background:var(--bg-card);height:100vh;box-shadow:-4px 0 24px #0000001a;display:flex;flex-direction:column;transform:translate(100%);animation:slideInRight .3s cubic-bezier(.16,1,.3,1) forwards}.drawer-header{padding:24px;border-bottom:1px solid var(--border);display:flex;justify-content:space-between;align-items:flex-start}.drawer-content{flex:1;overflow-y:auto;padding:24px}@keyframes slideInRight{0%{transform:translate(100%)}to{transform:translate(0)}}@media (max-width: 768px){.sidebar.admin-desktop-sidebar{display:none!important;transform:none!important}}.admin-mobile-nav{display:none}@media (max-width: 768px){.admin-mobile-nav{display:flex;position:fixed;bottom:0;left:0;right:0;width:100%;max-width:100%;height:auto;min-height:58px;background:#fffffffa;backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border:none;border-top:1px solid var(--border);border-radius:0;box-shadow:0 -1px 0 var(--border),0 -4px 16px #0000000a;transform:none;z-index:999;align-items:center;justify-content:space-around;padding:0 8px;padding-bottom:env(safe-area-inset-bottom,0px);gap:0;-webkit-tap-highlight-color:transparent}.admin-mobile-nav-item{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;padding:8px 6px 7px;border-radius:10px;color:#9b9b98;text-decoration:none;cursor:pointer;border:none;background:none;font-family:var(--font);-webkit-tap-highlight-color:transparent;transition:all .18s ease;flex:1;min-width:0;position:relative}.admin-mobile-nav-item svg{width:21px;height:21px;stroke-width:1.7;opacity:.55;transition:all .18s ease}.admin-mobile-nav-item:hover svg{opacity:.75}.admin-mobile-nav-label{font-size:.6rem;font-weight:500;letter-spacing:.01em;line-height:1;white-space:nowrap}.admin-mobile-nav-item:hover{color:var(--text)}.admin-mobile-nav-item.active{color:var(--primary);background:none}.admin-mobile-nav-item.active:after{content:"";position:absolute;top:0;left:50%;transform:translate(-50%);width:20px;height:2px;border-radius:0 0 2px 2px;background:var(--primary);opacity:.8}.admin-mobile-nav-item.active svg{color:var(--primary);opacity:1;stroke-width:2}.admin-mobile-more-btn.active{color:var(--primary);background:none}.admin-mobile-more-btn.active:after{content:"";position:absolute;top:0;left:50%;transform:translate(-50%);width:20px;height:2px;border-radius:0 0 2px 2px;background:var(--primary);opacity:.8}}.admin-mobile-drawer-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#1a1a1866;z-index:1200;animation:fadeIn .2s ease;-webkit-tap-highlight-color:transparent}.admin-mobile-drawer{position:absolute;top:0;right:0;bottom:0;width:min(300px,82vw);background:#fff;display:flex;flex-direction:column;animation:adminDrawerSlideIn .28s cubic-bezier(.16,1,.3,1) forwards;overflow:hidden}@keyframes adminDrawerSlideIn{0%{transform:translate(100%);opacity:.8}to{transform:translate(0);opacity:1}}.admin-mobile-drawer-header{height:58px;padding:0 16px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;flex-shrink:0}.admin-mobile-drawer-logo{display:flex;align-items:center;gap:9px;font-size:.875rem;font-weight:600;color:var(--text);letter-spacing:-.01em}.admin-mobile-drawer-logo img{width:22px;height:22px;object-fit:contain}.admin-mobile-drawer-close{width:30px;height:30px;border-radius:6px;border:1px solid var(--border);background:var(--bg);color:var(--text-muted);cursor:pointer;display:flex;align-items:center;justify-content:center;-webkit-tap-highlight-color:transparent;transition:all .15s ease}.admin-mobile-drawer-close:hover{background:var(--border);color:var(--text)}.admin-mobile-drawer-nav{flex:1;padding:12px 10px;overflow-y:auto}.admin-mobile-drawer-section-label{font-size:.6rem;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:#9b9b98;padding:10px 10px 8px}.admin-mobile-drawer-item{display:flex;align-items:center;gap:12px;padding:12px;border-radius:8px;color:#5a5955;text-decoration:none;font-size:.875rem;font-weight:500;cursor:pointer;transition:all .15s ease;margin-bottom:2px;-webkit-tap-highlight-color:transparent;border:1px solid transparent}.admin-mobile-drawer-item svg{width:18px;height:18px;stroke-width:1.8;opacity:.6;flex-shrink:0;transition:all .15s ease}.admin-mobile-drawer-item:hover{background:var(--sidebar-active);color:var(--text)}.admin-mobile-drawer-item:hover svg{opacity:.9}.admin-mobile-drawer-item.active{background:var(--bg-card);color:var(--primary);font-weight:600;border-color:var(--border);box-shadow:0 1px 2px #0000000d}.admin-mobile-drawer-item.active svg{opacity:1;color:var(--primary)}.admin-mobile-drawer-footer{padding:12px 10px;border-top:1px solid var(--border);flex-shrink:0}.admin-mobile-drawer-logout{display:flex;align-items:center;gap:12px;width:100%;padding:11px 12px;border-radius:8px;border:none;background:none;color:var(--danger);font-size:.875rem;font-weight:500;cursor:pointer;font-family:var(--font);-webkit-tap-highlight-color:transparent;transition:all .15s ease}.admin-mobile-drawer-logout:hover{background:var(--danger-light)}.admin-mobile-drawer-logout svg{width:17px;height:17px;stroke-width:1.8;flex-shrink:0}
