:root{--primary: #2563eb;--primary-dark: #1d4ed8;--primary-light: #eff6ff;--gray-50: #f9fafb;--gray-100: #f3f4f6;--gray-200: #e5e7eb;--gray-300: #d1d5db;--gray-400: #9ca3af;--gray-500: #6b7280;--gray-600: #4b5563;--gray-700: #374151;--gray-800: #1f2937;--gray-900: #111827;--success: #10b981;--warning: #f59e0b;--danger: #ef4444;--header-height: 56px;--tabs-height: 64px;--safe-area-bottom: env(safe-area-inset-bottom, 0px)}*{box-sizing:border-box;-webkit-tap-highlight-color:transparent}html{font-size:16px}body{margin:0;padding:0;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background:var(--gray-50);color:var(--gray-900);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.app-layout{min-height:100vh;min-height:100dvh;display:flex;flex-direction:column}.app-main{flex:1;padding:16px;overflow-y:auto;-webkit-overflow-scrolling:touch}.top-header{position:sticky;top:0;z-index:100;height:var(--header-height);background:var(--primary);color:#fff;display:flex;align-items:center;justify-content:space-between;padding:0 16px;box-shadow:0 2px 4px #0000001a}.header-brand{display:flex;align-items:center;gap:8px}.header-icon{font-size:20px}.header-title{font-weight:600;font-size:16px}.header-actions{display:flex;align-items:center;gap:8px}.session-timer{background:#ffffff26;border:none;color:#fff;padding:6px 12px;border-radius:20px;font-size:14px;font-family:inherit;cursor:pointer;display:flex;align-items:center;gap:4px;transition:background .2s}.session-timer:active{background:#ffffff40}.session-timer.low{background:#ef4444cc;animation:pulse 1s infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.7}}.header-settings{background:transparent;border:none;color:#fff;font-size:20px;padding:8px;cursor:pointer;border-radius:50%;display:flex;align-items:center;justify-content:center}.header-settings:active{background:#ffffff1a}.header-tabs{position:sticky;top:var(--header-height);z-index:99;background:#fff;border-bottom:1px solid var(--gray-200);overflow-x:auto;overflow-y:hidden;-webkit-overflow-scrolling:touch;scrollbar-width:none;-ms-overflow-style:none}.header-tabs::-webkit-scrollbar{display:none}.header-tabs-inner{display:flex;min-width:max-content;padding:0 12px;gap:4px}.header-tab-item{display:flex;align-items:center;justify-content:center;padding:12px 16px;text-decoration:none;color:var(--gray-500);font-size:14px;font-weight:500;white-space:nowrap;border-bottom:2px solid transparent;transition:all .2s}.header-tab-item:active{background:var(--gray-50)}.header-tab-item.active{color:var(--primary);border-bottom-color:var(--primary)}.login-page{min-height:100vh;min-height:100dvh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--primary) 0%,#7f1d1d 100%);padding:16px}.login-card{background:#fff;padding:32px 24px;border-radius:20px;box-shadow:0 20px 40px #0003;width:100%;max-width:360px}.login-icon{text-align:center;font-size:48px;margin-bottom:16px}.login-card h1{margin:0 0 8px;text-align:center;font-size:24px;color:var(--gray-900)}.login-subtitle{text-align:center;color:var(--gray-500);margin:0 0 24px;font-size:14px}.otp-info{text-align:center;margin-bottom:20px;color:var(--gray-700);font-size:14px;line-height:1.5}.otp-input{text-align:center;font-size:28px!important;letter-spacing:8px;font-family:monospace;font-weight:600}.otp-expires{text-align:center;font-size:14px;color:var(--gray-500);margin:8px 0 16px;font-weight:500}.otp-expires.warning{color:var(--danger)}.login-actions{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-top:20px}.form-group{margin-bottom:16px}.form-group label{display:block;margin-bottom:8px;font-size:14px;font-weight:500;color:var(--gray-700)}.form-group input,.form-group select{width:100%;padding:14px 16px;border:1px solid var(--gray-300);border-radius:12px;font-size:16px;background:#fff;transition:border-color .2s,box-shadow .2s}.form-group input:focus,.form-group select:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-light)}.form-error{background:var(--primary-light);color:var(--danger);padding:12px 16px;border-radius:12px;margin-bottom:16px;font-size:14px}.btn-primary,.btn-secondary{display:inline-flex;align-items:center;justify-content:center;padding:14px 24px;border-radius:12px;font-size:16px;font-weight:600;cursor:pointer;transition:all .2s;border:none;font-family:inherit}.btn-primary{background:var(--primary);color:#fff}.btn-primary:active{background:var(--primary-dark)}.btn-primary:disabled{background:var(--gray-300);cursor:not-allowed}.btn-secondary{background:var(--gray-100);color:var(--gray-700);border:1px solid var(--gray-200)}.btn-secondary:active{background:var(--gray-200)}.btn-block{width:100%;margin-top:8px}.btn-small{padding:8px 12px;font-size:13px;border-radius:8px}.btn-danger{background:var(--gray-100);color:var(--danger);border:1px solid var(--gray-200)}.btn-danger:active{background:var(--gray-200)}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;display:flex;align-items:flex-end;justify-content:center;z-index:200;padding:0}.modal{background:#fff;border-radius:20px 20px 0 0;width:100%;max-width:500px;max-height:90vh;overflow-y:auto;animation:slideUp .3s ease-out}@keyframes slideUp{0%{transform:translateY(100%);opacity:0}to{transform:translateY(0);opacity:1}}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:20px;border-bottom:1px solid var(--gray-200);position:sticky;top:0;background:#fff}.modal-header h2{margin:0;font-size:18px}.modal-close{background:var(--gray-100);border:none;width:32px;height:32px;border-radius:50%;font-size:18px;cursor:pointer;display:flex;align-items:center;justify-content:center;color:var(--gray-600)}.modal-body{padding:20px}.modal-actions{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-top:20px;padding-bottom:var(--safe-area-bottom)}.settings-modal .modal-body{padding:0}.settings-profile{display:flex;align-items:center;gap:16px;padding:20px;border-bottom:1px solid var(--gray-200)}.settings-avatar{width:56px;height:56px;background:var(--gray-100);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:28px}.settings-name{font-weight:600;font-size:16px}.settings-email{color:var(--gray-500);font-size:14px;margin-top:2px}.settings-menu{padding:8px 0}.settings-item{display:flex;align-items:center;width:100%;padding:16px 20px;background:transparent;border:none;font-size:16px;cursor:pointer;text-align:left;color:var(--gray-700);font-family:inherit}.settings-item:active{background:var(--gray-50)}.settings-item.danger{color:var(--danger)}.settings-item-icon{font-size:20px;margin-right:16px}.settings-item-text{flex:1}.settings-item-arrow{color:var(--gray-400);font-size:20px}.page-header{margin-bottom:20px}.page-title{margin:0 0 4px;font-size:24px;font-weight:700}.page-subtitle{margin:0;color:var(--gray-500);font-size:14px}.stat-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:20px}.stat-card{background:#fff;border-radius:16px;padding:16px;box-shadow:0 1px 3px #0000000d}.stat-card.wide{grid-column:span 2}.stat-icon{font-size:24px;margin-bottom:8px}.stat-label{font-size:12px;color:var(--gray-500);text-transform:uppercase;letter-spacing:.5px;margin-bottom:4px}.stat-value{font-size:28px;font-weight:700;color:var(--gray-900)}.stat-details{margin-top:8px;font-size:12px;color:var(--gray-500);display:flex;flex-wrap:wrap;gap:8px}.card-list{display:flex;flex-direction:column;gap:12px}.card{background:#fff;border-radius:16px;padding:16px;box-shadow:0 1px 3px #0000000d}.card-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:12px}.card-title{font-weight:600;font-size:16px;margin:0}.card-subtitle{color:var(--gray-500);font-size:14px;margin-top:2px}.card-meta{display:flex;flex-wrap:wrap;gap:8px;font-size:13px;color:var(--gray-500)}.card-actions{display:flex;gap:8px;margin-top:12px;padding-top:12px;border-top:1px solid var(--gray-100)}.card-actions button{flex:1}.badge{display:inline-flex;align-items:center;padding:4px 10px;border-radius:20px;font-size:12px;font-weight:500}.badge-success{background:#d1fae5;color:#065f46}.badge-warning{background:#fef3c7;color:#92400e}.badge-danger{background:#fee2e2;color:#991b1b}.badge-info{background:var(--gray-100);color:var(--gray-700)}.data-table-wrapper{overflow-x:auto;-webkit-overflow-scrolling:touch;border-radius:16px;background:#fff;box-shadow:0 1px 3px #0000000d}.data-table{width:100%;border-collapse:collapse;min-width:600px}.data-table th,.data-table td{padding:14px 16px;text-align:left;border-bottom:1px solid var(--gray-100)}.data-table th{background:var(--gray-50);font-weight:500;font-size:13px;color:var(--gray-600)}.data-table tr:last-child td{border-bottom:none}.fab{position:fixed;bottom:calc(var(--safe-area-bottom) + 24px);right:16px;width:56px;height:56px;border-radius:50%;background:var(--primary);color:#fff;border:none;font-size:28px;cursor:pointer;box-shadow:0 4px 12px #2563eb66;display:flex;align-items:center;justify-content:center;z-index:50;transition:transform .2s,box-shadow .2s}.fab:active{transform:scale(.95);box-shadow:0 2px 8px #2563eb66}.empty-state{text-align:center;padding:40px 20px;color:var(--gray-500)}.empty-state-icon{font-size:48px;margin-bottom:16px}.empty-state-text{font-size:16px}.loading{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:40px;color:var(--gray-500)}.loading-spinner{width:32px;height:32px;border:3px solid var(--gray-200);border-top-color:var(--primary);border-radius:50%;animation:spin .8s linear infinite;margin-bottom:12px}.checkbox-label{display:flex;align-items:center;gap:12px;font-size:15px;cursor:pointer;padding:8px 0}.checkbox-label input{width:20px;height:20px;accent-color:var(--primary)}.sub-nav{display:flex;gap:4px;background:var(--gray-100);padding:4px;border-radius:12px;margin-bottom:16px}.sub-nav-item{flex:1;padding:10px 16px;border:none;background:transparent;color:var(--gray-600);font-size:14px;font-weight:500;cursor:pointer;border-radius:8px;transition:all .2s;font-family:inherit}.sub-nav-item:active{background:var(--gray-200)}.sub-nav-item.active{background:#fff;color:var(--primary);box-shadow:0 1px 3px #0000001a}.chip-filters{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:16px}.chip{display:inline-flex;align-items:center;gap:6px;padding:8px 14px;border:1px solid var(--gray-200);background:#fff;color:var(--gray-700);font-size:13px;font-weight:500;cursor:pointer;border-radius:20px;transition:all .2s;font-family:inherit}.chip:active{background:var(--gray-50)}.chip.active{background:var(--primary-light);border-color:var(--primary);color:var(--primary)}.chip-count{background:var(--gray-200);color:var(--gray-600);font-size:11px;font-weight:600;padding:2px 6px;border-radius:10px;min-width:18px;text-align:center}.chip.active .chip-count{background:var(--primary);color:#fff}.badge-tier-superadmin{background:#fce7f3;color:#9d174d}.badge-tier-admin{background:#e0f2fe;color:#0369a1}.badge-tier-teacher{background:#f0fdf4;color:#166534}.badge-tier-student{background:#fef3c7;color:#92400e}@media (min-width: 768px){.app-main{max-width:800px;margin:0 auto;padding:24px}.modal{border-radius:20px;margin:auto;max-height:80vh}.modal-overlay{align-items:center;padding:20px}.stat-grid{grid-template-columns:repeat(3,1fr);gap:16px}.stat-card.wide{grid-column:span 1}.login-card{padding:40px}.page-title{font-size:28px}}@media (min-width: 1024px){.stat-grid{grid-template-columns:repeat(4,1fr)}}:root{--bib-blue: #2E89F3;--bib-blue-light: #5BA3F5;--bib-blue-dark: #1A6FD4;--bib-blue-bg: rgba(46, 137, 243, .08);--gray-50: #F9FAFB;--gray-100: #F2F4F6;--gray-200: #E5E8EB;--gray-300: #D1D6DB;--gray-400: #B0B8C1;--gray-500: #8B95A1;--gray-600: #6B7684;--gray-700: #4E5968;--gray-900: #191F28;--success: #00C853;--success-bg: rgba(0, 200, 83, .1);--error: #F44336;--error-bg: rgba(244, 67, 54, .08)}*{box-sizing:border-box;margin:0;padding:0}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.login-page{display:flex;align-items:center;justify-content:center;min-height:100vh;min-height:100dvh;background:linear-gradient(180deg,#f8fafc,#eef2f6);padding:24px}.login-container{background:#fff;border-radius:28px;box-shadow:0 0 0 1px #00000005,0 4px 8px #0000000a,0 16px 32px #0000000f,0 32px 64px #0000000a;padding:48px 40px;width:100%;max-width:420px;animation:cardAppear .5s cubic-bezier(.16,1,.3,1)}@keyframes cardAppear{0%{opacity:0;transform:translateY(24px) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}.login-header{text-align:center;margin-bottom:40px}.login-logo{width:72px;height:72px;margin-bottom:24px;border-radius:18px;box-shadow:0 4px 16px #2e89f333}.login-header h1{font-size:26px;font-weight:700;color:var(--gray-900);margin:0 0 8px;line-height:1.3;letter-spacing:-.02em}.login-header p{font-size:15px;color:var(--gray-500);margin:0;line-height:1.5}.login-form{display:flex;flex-direction:column;gap:20px}.login-form .form-group{display:flex;flex-direction:column;gap:8px}.login-form label{font-size:13px;font-weight:600;color:var(--gray-700);letter-spacing:.01em}.login-form input{width:100%;padding:16px 18px;font-size:16px;color:var(--gray-900);background:var(--gray-50);border:2px solid transparent;border-radius:14px;outline:none;transition:all .2s ease}.login-form input::placeholder{color:var(--gray-400)}.login-form input:hover:not(:disabled){background:var(--gray-100)}.login-form input:focus{background:#fff;border-color:var(--bib-blue);box-shadow:0 0 0 4px var(--bib-blue-bg)}.login-form input:disabled{background:var(--gray-100);color:var(--gray-500);cursor:not-allowed}.login-button{width:100%;padding:18px;font-size:16px;font-weight:700;color:#fff;background:linear-gradient(180deg,var(--bib-blue) 0%,var(--bib-blue-dark) 100%);border:none;border-radius:14px;cursor:pointer;transition:all .2s ease;margin-top:12px;box-shadow:0 4px 12px #2e89f34d;letter-spacing:.01em}.login-button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 20px #2e89f366}.login-button:active:not(:disabled){transform:translateY(0);box-shadow:0 2px 8px #2e89f34d}.login-button:disabled{opacity:.6;cursor:not-allowed;transform:none}.login-error{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:14px 18px;background:var(--error-bg);color:var(--error);border-radius:12px;font-size:14px;font-weight:500;animation:errorShake .4s ease}@keyframes errorShake{0%,to{transform:translate(0)}20%,60%{transform:translate(-6px)}40%,80%{transform:translate(6px)}}.error-dismiss{background:none;border:none;font-size:20px;color:var(--error);cursor:pointer;padding:0;line-height:1;opacity:.7;transition:opacity .2s}.error-dismiss:hover{opacity:1}.login-footer{text-align:center;margin-top:32px;padding-top:24px;border-top:1px solid var(--gray-100)}.login-footer p{color:var(--gray-500);font-size:14px;margin:0}.login-footer a{color:var(--bib-blue);text-decoration:none;font-weight:600}.login-footer a:hover{text-decoration:underline}.loading-container{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100vh;background:var(--gray-50);gap:16px}.loading-container:before{content:"";width:40px;height:40px;border:3px solid var(--gray-200);border-top-color:var(--bib-blue);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.loading-container .loading{color:var(--gray-500);font-size:15px}.pin-login-page{display:flex;align-items:center;justify-content:center;min-height:100vh;min-height:100dvh;background:linear-gradient(180deg,#f8fafc,#eef2f6);padding:24px}.pin-login-container{background:#fff;border-radius:32px;box-shadow:0 0 0 1px #00000005,0 4px 8px #0000000a,0 16px 32px #0000000f,0 32px 64px #0000000a;padding:48px 32px;width:100%;max-width:380px;text-align:center;animation:cardAppear .5s cubic-bezier(.16,1,.3,1)}.pin-login-header{margin-bottom:36px}.pin-login-logo{width:80px;height:80px;margin-bottom:24px;border-radius:20px;box-shadow:0 4px 16px #2e89f340}.pin-login-header h1{font-size:26px;font-weight:700;color:var(--gray-900);margin:0 0 8px;line-height:1.3;letter-spacing:-.02em}.pin-login-header p{font-size:15px;color:var(--gray-500);margin:0;line-height:1.5}.pin-login-error{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:14px 18px;background:var(--error-bg);color:var(--error);border-radius:14px;font-size:14px;font-weight:500;margin-bottom:24px;animation:errorShake .4s ease}.pin-display{position:relative;background:var(--gray-50);border:2px solid transparent;border-radius:16px;padding:20px 24px;margin-bottom:12px;min-height:72px;display:flex;align-items:center;justify-content:center;transition:all .2s ease}.pin-display:focus-within{background:#fff;border-color:var(--bib-blue);box-shadow:0 0 0 4px var(--bib-blue-bg)}.pin-numbers{font-size:36px;font-weight:700;color:var(--gray-900);letter-spacing:12px;font-family:SF Mono,Menlo,monospace;text-align:center}.pin-placeholder{position:absolute;font-size:16px;color:var(--gray-400);font-weight:500}.pin-display.shake{animation:pinShake .5s ease-in-out}@keyframes pinShake{0%,to{transform:translate(0)}10%,30%,50%,70%,90%{transform:translate(-8px)}20%,40%,60%,80%{transform:translate(8px)}}.pin-length-hint{height:24px;margin-bottom:24px;text-align:center}.pin-length-hint span{font-size:13px;color:var(--gray-400);font-weight:500}.pin-length-hint span.valid{color:var(--success)}.pin-dots{display:flex;justify-content:center;gap:14px;margin-bottom:36px}.pin-dot{width:18px;height:18px;border-radius:50%;background:var(--gray-100);border:none;transition:all .15s cubic-bezier(.16,1,.3,1)}.pin-dot.filled{background:var(--bib-blue);transform:scale(1.3);box-shadow:0 2px 8px #2e89f366}.pin-dots.shake{animation:pinShake .5s ease-in-out}.pin-loading{color:var(--gray-500);font-size:14px;margin-bottom:24px;font-weight:500}.pin-keypad{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;max-width:300px;margin:0 auto 36px}.pin-key{width:76px;height:76px;border:none;border-radius:50%;background:var(--gray-50);color:var(--gray-900);font-size:26px;font-weight:600;cursor:pointer;transition:all .12s ease;display:flex;align-items:center;justify-content:center;margin:0 auto;-webkit-tap-highlight-color:transparent;-webkit-user-select:none;user-select:none}.pin-key:hover:not(:disabled){background:var(--gray-100)}.pin-key:active:not(:disabled){transform:scale(.88);background:var(--gray-200)}.pin-key:disabled{opacity:.5;cursor:not-allowed}.pin-key-empty{background:transparent;cursor:default}.pin-key-empty:hover,.pin-key-empty:active{background:transparent;transform:none}.pin-key-delete{background:transparent;color:var(--gray-600)}.pin-key-delete:hover:not(:disabled){background:var(--gray-100)}.pin-key-delete svg{width:26px;height:26px}.pin-login-button{width:100%;padding:18px;font-size:17px;font-weight:700;color:#fff;background:linear-gradient(180deg,var(--bib-blue) 0%,var(--bib-blue-dark) 100%);border:none;border-radius:14px;cursor:pointer;transition:all .2s ease;margin-top:8px;margin-bottom:28px;box-shadow:0 4px 12px #2e89f34d;letter-spacing:.01em}.pin-login-button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 20px #2e89f366}.pin-login-button:active:not(:disabled){transform:translateY(0);box-shadow:0 2px 8px #2e89f34d}.pin-login-button:disabled{opacity:.4;cursor:not-allowed;transform:none;background:var(--gray-300);box-shadow:none}.pin-login-footer{padding-top:24px;border-top:1px solid var(--gray-100)}.pin-login-footer p{font-size:14px;color:var(--gray-500);margin:0;line-height:1.5}.pin-login-footer .pin-help{font-size:13px;color:var(--gray-400);margin-top:6px}@media (max-height: 700px){.pin-login-container{padding:36px 28px;border-radius:24px}.pin-login-header{margin-bottom:28px}.pin-login-header h1{font-size:22px}.pin-login-logo{width:64px;height:64px;margin-bottom:16px}.pin-display{padding:16px 20px;min-height:60px;margin-bottom:8px}.pin-numbers{font-size:28px;letter-spacing:8px}.pin-length-hint{margin-bottom:16px}.pin-dots{margin-bottom:28px;gap:12px}.pin-dot{width:16px;height:16px}.pin-keypad{gap:10px;margin-bottom:20px}.pin-key{width:64px;height:64px;font-size:22px}.pin-login-button{padding:16px;font-size:16px;margin-bottom:20px}}@media (max-width: 360px){.login-container{padding:36px 28px;border-radius:24px}.pin-login-container{padding:32px 24px}.pin-display{padding:14px 16px;min-height:56px}.pin-numbers{font-size:24px;letter-spacing:6px}.pin-keypad{gap:10px}.pin-key{width:60px;height:60px;font-size:20px}.pin-login-button{padding:14px;font-size:15px}}@media (min-width: 768px){.login-container{padding:56px 52px}.login-header h1{font-size:28px}.pin-login-container{padding:56px 44px}.pin-display{padding:24px 28px;min-height:80px}.pin-numbers{font-size:40px;letter-spacing:14px}.pin-keypad{gap:16px}.pin-key{width:84px;height:84px;font-size:28px}.pin-login-button{padding:20px;font-size:18px}}
