*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;-webkit-text-size-adjust:100%}body{font-family:Inter,Segoe UI,system-ui,sans-serif;background:#f5f7fa;color:#1a1a2e;line-height:1.5}.main-content{padding:24px;max-width:1280px;margin:0 auto;width:100%}.idle-warning{background:#fff3cd;color:#856404;padding:10px 24px;display:flex;align-items:center;justify-content:center;gap:16px;font-size:.9rem;font-weight:600;border-bottom:2px solid #ffc107;flex-wrap:wrap}.idle-warning button{background:#1a1a2e;color:#fff;border:none;padding:5px 14px;border-radius:6px;cursor:pointer;font-size:.85rem}.data-table-wrap,.table-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch;width:100%}.data-table{width:100%;border-collapse:collapse;min-width:500px}.card{background:#fff;border-radius:12px;padding:20px;box-shadow:0 2px 8px #0000000f}.form-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:14px}.filters{display:flex;flex-wrap:wrap;gap:12px;align-items:flex-end;margin-bottom:16px}.modal{width:100%;max-width:560px;max-height:90svh;overflow-y:auto}@media(max-width:1024px){.main-content{padding:20px}}@media(max-width:768px){html{font-size:15px}.main-content{padding:12px}.idle-warning{font-size:.8rem;flex-direction:column;text-align:center;gap:8px}.form-grid{grid-template-columns:1fr}}@media(max-width:480px){html{font-size:14px}.main-content{padding:8px}.page-header{flex-direction:column;align-items:flex-start}.modal{max-height:95svh;border-radius:12px 12px 0 0}}.navbar{display:flex;align-items:center;gap:12px;background:#1a1a2e;color:#fff;padding:10px 20px;position:sticky;top:0;z-index:100;flex-wrap:wrap}.nav-logo{width:32px;height:32px;object-fit:contain;border-radius:6px}.navbar-brand{display:flex;align-items:center;gap:8px;font-weight:700;font-size:1rem;margin-right:auto}.hamburger{display:none;flex-direction:column;justify-content:center;align-items:center;gap:5px;background:transparent;border:none;cursor:pointer;padding:4px;margin-left:auto}.hamburger span{display:block;width:22px;height:2px;background:#fff;border-radius:2px}.navbar-links{display:flex;gap:8px;flex-wrap:wrap;align-items:center}.navbar-links a{color:#ccc;text-decoration:none;padding:6px 10px;border-radius:6px;font-size:.85rem;white-space:nowrap}.navbar-links a.router-link-active{color:#fff;background:#ffffff26}.navbar-user{display:flex;align-items:center;gap:10px;font-size:.85rem;white-space:nowrap}.btn-logout{background:#e74c3c;color:#fff;border:none;padding:5px 12px;border-radius:6px;cursor:pointer;font-size:.83rem}.mobile-only{display:none}.desktop-only{display:flex}@media(max-width:768px){.hamburger{display:flex}.navbar-brand{flex:1}.desktop-only{display:none}.navbar-links{display:none;flex-direction:column;align-items:flex-start;width:100%;background:#12122a;padding:12px 16px;gap:4px;border-top:1px solid rgba(255,255,255,.1)}.navbar-links.open{display:flex}.navbar-links a{width:100%;padding:10px 12px;font-size:.95rem}.mobile-only{display:flex;margin-top:12px;border-top:1px solid rgba(255,255,255,.1);padding-top:12px}}.page-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:20px;flex-wrap:wrap;gap:12px}.title-row{display:flex;align-items:center;gap:20px;flex-wrap:wrap}.date-picker-wrap{display:flex;align-items:center;gap:8px}.date-picker-wrap label{font-size:.82rem;font-weight:600;color:#555}.saturday-select{padding:7px 12px;border:1.5px solid #1a1a2e;border-radius:8px;font-size:.88rem;background:#fff;cursor:pointer}.today-badge{background:#27ae60;color:#fff;font-size:.72rem;font-weight:700;padding:2px 8px;border-radius:10px}.filters{display:flex;gap:12px;margin-bottom:16px}.search-input,select{padding:8px 12px;border:1.5px solid #e0e0e0;border-radius:8px;font-size:.9rem}.search-input{flex:1}.actions{display:flex;gap:8px}.filters{display:flex;gap:16px;align-items:flex-end;margin-bottom:16px;flex-wrap:wrap}.toggle-label{display:flex;align-items:center;gap:6px;font-size:.88rem;cursor:pointer;padding-bottom:2px}.badge.closed{background:#e9ecef;color:#6c757d}.modal{background:#fff;border-radius:16px;padding:28px;width:100%;max-width:520px}.hint{font-size:.8rem;color:#888;margin-top:12px}.error{color:#e74c3c;font-size:.85rem;margin-top:8px}h2{font-size:1.5rem;margin-bottom:4px}h3{font-size:1.1rem}.date-line{color:#666;margin-bottom:24px}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:16px;margin-bottom:32px}.stat-card{background:#fff;border-radius:12px;padding:20px;text-align:center;box-shadow:0 2px 8px #0000000f;border-left:4px solid #1a1a2e}.stat-card.green{border-color:#27ae60}.stat-card.orange{border-color:#f39c12}.stat-card.red{border-color:#e74c3c}.stat-value{font-size:2rem;font-weight:700}.stat-label{font-size:.85rem;color:#666;margin-top:4px}.section-header{display:flex;justify-content:space-between;align-items:flex-end;margin-bottom:12px;flex-wrap:wrap;gap:12px}.filters{display:flex;gap:12px;align-items:flex-end;flex-wrap:wrap}.field input{padding:8px 12px;border:1.5px solid #e0e0e0;border-radius:8px;font-size:.9rem}.data-table{width:100%;border-collapse:collapse;background:#fff;border-radius:12px;overflow:hidden;box-shadow:0 2px 8px #0000000f;margin-bottom:28px}.data-table td{padding:10px 16px;border-bottom:1px solid #f0f0f0;font-size:.9rem}.range-error{color:#e74c3c;font-size:.85rem;margin-bottom:8px}.empty{color:#999;text-align:center;padding:24px;margin-bottom:24px}.loading{text-align:center;padding:24px;color:#666;margin-bottom:24px}.quick-links{display:flex;gap:16px;flex-wrap:wrap;margin-top:8px}.quick-card{background:#fff;border-radius:12px;padding:20px 28px;text-decoration:none;color:#1a1a2e;font-weight:600;box-shadow:0 2px 8px #0000000f;transition:transform .15s}.quick-card:hover{transform:translateY(-2px)}.login-page{min-height:100svh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#0f0c29,#302b63,#24243e);padding:16px}.login-card{background:#fff;padding:40px;border-radius:20px;box-shadow:0 8px 40px #0000004d;width:100%;max-width:420px}.login-logo{display:flex;align-items:center;gap:14px;margin-bottom:28px}.login-logo img{width:56px;height:56px;object-fit:contain;border-radius:12px}h1{font-size:1.3rem;color:#1a1a2e;line-height:1.2}.subtitle{color:#888;font-size:.85rem;margin-top:2px}.tabs{display:flex;gap:8px;margin-bottom:24px}.tabs button{flex:1;padding:9px;border:2px solid #e0e0e0;background:#fff;border-radius:10px;cursor:pointer;font-size:.9rem;font-weight:500;transition:all .2s}.field{margin-bottom:16px}.field label{display:block;font-size:.83rem;font-weight:600;margin-bottom:6px;color:#444}.field input{width:100%;padding:11px 14px;border:1.5px solid #e0e0e0;border-radius:10px;font-size:.95rem;transition:border-color .2s}.field input:focus{outline:none;border-color:#1a1a2e;box-shadow:0 0 0 3px #1a1a2e1a}.btn-primary{width:100%;padding:13px;background:#1a1a2e;color:#fff;border:none;border-radius:10px;font-size:1rem;font-weight:600;cursor:pointer;margin-top:8px;transition:opacity .2s}.btn-primary:disabled{opacity:.55;cursor:not-allowed}.btn-link{background:none;border:none;color:#666;font-size:.85rem;cursor:pointer;margin-top:10px;display:block;text-align:center}.error{color:#e74c3c;font-size:.84rem;margin-bottom:8px;background:#fff5f5;padding:8px 12px;border-radius:8px}.demo-hint{font-size:.8rem;color:#888;margin-top:6px}.email-hint{font-size:.82rem;color:#27ae60;margin-top:6px}.config-loading{text-align:center;padding:20px;color:#aaa;font-size:.9rem}.otp-disabled-notice{background:#f0f4ff;border:1.5px solid #c0cdf0;border-radius:8px;padding:10px 14px;font-size:.85rem;color:#1a1a2e;margin-bottom:18px}.auth-disabled-notice{background:#fff5f5;border:1.5px solid #f8d7da;border-radius:8px;padding:10px 14px;font-size:.85rem;color:#721c24;margin-bottom:18px;text-align:center}@media(max-width:480px){.login-card{padding:28px 20px;border-radius:16px}.login-logo img{width:44px;height:44px}h1{font-size:1.15rem}}.page-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px;flex-wrap:wrap;gap:8px}.header-actions{display:flex;gap:8px;flex-wrap:wrap}.btn-primary{background:#1a1a2e;color:#fff;border:none;padding:8px 18px;border-radius:8px;cursor:pointer;font-size:.85rem}.btn-secondary{background:#f0f0f0;color:#333;border:none;padding:8px 16px;border-radius:8px;cursor:pointer;font-size:.85rem}.btn-secondary:disabled{opacity:.5;cursor:not-allowed}.filters{display:flex;gap:12px;flex-wrap:wrap;align-items:flex-end;margin-bottom:12px}.field label{display:block;font-size:.8rem;font-weight:600;margin-bottom:4px}.field input,.field select{padding:7px 10px;border:1.5px solid #e0e0e0;border-radius:8px;font-size:.88rem}.stats-bar{font-size:.83rem;color:#666;margin-bottom:10px}.stats-bar strong{color:#1a1a2e}.table-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch}.data-table{width:100%;border-collapse:collapse;background:#fff;border-radius:12px;overflow:hidden;box-shadow:0 2px 8px #0000000f;font-size:.84rem;min-width:600px}.data-table th{background:#1a1a2e;color:#fff;padding:10px 14px;text-align:left;white-space:nowrap}.data-table td{padding:8px 14px;border-bottom:1px solid #f0f0f0;vertical-align:top}.detail-cell{font-size:.78rem;color:#555;word-break:break-all}.error-msg{color:#e74c3c;background:#fff5f5;padding:12px 16px;border-radius:8px;font-size:.88rem}@media(max-width:600px){.filters{flex-direction:column}.header-actions{width:100%}}.page-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:8px}.date-line{color:#666;font-size:.9rem;margin-top:2px}.year-select{padding:8px 12px;border:1.5px solid #e0e0e0;border-radius:8px;font-size:.9rem}.tabs{display:flex;gap:8px;margin-bottom:20px;flex-wrap:wrap}.tabs button{padding:8px 18px;border:2px solid #e0e0e0;background:#fff;border-radius:8px;cursor:pointer;font-size:.88rem}.load-error{color:#e74c3c;font-size:.85rem;margin-bottom:12px;background:#fdf0f0;padding:10px 14px;border-radius:8px}.self-checkin-card{background:#f0f4ff;border:2px solid #1a1a2e;border-radius:12px;padding:16px 20px;margin-bottom:20px;display:flex;align-items:center;gap:16px;flex-wrap:wrap}.self-checkin-info{display:flex;align-items:center;gap:12px;flex:1}.student-card{background:#fff;border-radius:12px;padding:16px 20px;margin-bottom:12px;box-shadow:0 2px 8px #0000000f;display:flex;align-items:center;gap:16px;flex-wrap:wrap}.student-info{display:flex;align-items:center;gap:12px;flex:1;min-width:200px}.avatar{width:44px;height:44px;border-radius:50%;background:#1a1a2e;color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:1rem;flex-shrink:0}.avatar.self{background:#3498db}.student-name{font-weight:600;font-size:1rem}.student-meta{font-size:.82rem;color:#888;margin-top:2px}.attendance-status{display:flex;flex-direction:column;gap:4px}.times{font-size:.8rem;color:#666;display:flex;gap:10px}.card-actions{margin-left:auto}.student-link{color:#3498db;cursor:pointer;font-weight:600;text-decoration:underline}.student-link:hover{color:#1a1a2e}.badge.checked-in{background:#d4edda;color:#155724}.badge.checked-out{background:#fff3cd;color:#856404}.btn-sm{padding:5px 12px;border:none;border-radius:6px;cursor:pointer;font-size:.82rem;font-weight:600}.done{font-size:.82rem;color:#27ae60;font-weight:600}.filters{display:flex;gap:12px;margin-bottom:14px}.search-input{flex:1;padding:8px 12px;border:1.5px solid #e0e0e0;border-radius:8px;font-size:.9rem}.section-hint{font-size:.85rem;color:#666;margin-bottom:14px}.modal{background:#fff;border-radius:16px;padding:28px;width:100%;max-width:540px;max-height:90vh;overflow-y:auto}.modal h3{margin-bottom:4px}.modal-sub{font-size:.85rem;color:#888;margin-bottom:18px}.field label{display:block;font-size:.82rem;font-weight:600;margin-bottom:5px}.field textarea{width:100%;padding:8px 10px;border:1.5px solid #e0e0e0;border-radius:8px;font-size:.9rem;resize:vertical}.marks-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-top:14px}.mark-field label{display:block;font-size:.82rem;font-weight:600;margin-bottom:5px}.mark-input-row{display:flex;align-items:center;gap:6px}.mark-input-row input{width:70px;padding:6px 8px;border:1.5px solid #e0e0e0;border-radius:8px;font-size:.9rem}.mark-unit{font-size:.8rem;color:#999}.mark-bar{height:6px;background:#f0f0f0;border-radius:3px;margin-top:6px;overflow:hidden}.mark-fill{height:100%;border-radius:3px;transition:width .3s}.history-section{margin-top:18px;border-top:1px solid #f0f0f0;padding-top:12px}.history-title{font-size:.82rem;font-weight:600;color:#888;margin-bottom:8px}.history-row{display:flex;gap:12px;font-size:.8rem;color:#555;padding:4px 0;border-bottom:1px solid #f8f8f8;flex-wrap:wrap}.history-date{font-weight:600;color:#333;min-width:90px}.history-mark{background:#f5f5f5;padding:2px 8px;border-radius:10px}.save-error{color:#e74c3c;font-size:.85rem;margin-top:8px}.btn-primary{background:#1a1a2e;color:#fff;border:none;padding:8px 20px;border-radius:8px;cursor:pointer}.page-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}.tabs{display:flex;gap:8px;margin-bottom:16px}.tabs button{padding:7px 18px;border:2px solid #e0e0e0;background:#fff;border-radius:8px;cursor:pointer;font-size:.88rem}.tabs button.active{border-color:#1a1a2e;background:#1a1a2e;color:#fff}.filters{display:flex;gap:12px;align-items:flex-end;margin-bottom:16px;flex-wrap:wrap}.field input,.field select{padding:8px 12px;border:1.5px solid #e0e0e0;border-radius:8px;font-size:.9rem}.btn-primary{background:#1a1a2e;color:#fff;border:none;padding:9px 20px;border-radius:8px;cursor:pointer}.data-table td{padding:12px 16px;border-bottom:1px solid #f0f0f0;font-size:.9rem}.badge.in{background:#d4edda;color:#155724}.badge.out{background:#fff3cd;color:#856404}.badge.absent{background:#f8d7da;color:#721c24}.date-link{color:#3498db;cursor:pointer;text-decoration:underline;font-weight:600}.date-link:hover{color:#1a1a2e}.page-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px;flex-wrap:wrap;gap:10px}h2{font-size:1.3rem}.header-actions{display:flex;gap:8px;flex-wrap:wrap;align-items:center}.header-actions select,.date-input{padding:7px 10px;border:1.5px solid #e0e0e0;border-radius:8px;font-size:.88rem}.btn-secondary{background:#f0f0f0;color:#333;border:none;padding:7px 14px;border-radius:8px;cursor:pointer;font-size:.88rem}.hint{color:#888;font-size:.9rem;margin-bottom:16px}.class-label{padding:7px 10px;background:#f9f9f9;border:1.5px solid #e0e0e0;border-radius:8px;font-size:.88rem;font-weight:600;color:#333}.loading,.empty{text-align:center;padding:40px;color:#666}.table-wrap{overflow-x:auto;border-radius:12px;box-shadow:0 2px 8px #00000014}.rubric-table{border-collapse:collapse;background:#fff;min-width:1100px;width:100%;font-size:.82rem}.rubric-table th,.rubric-table td{border:1px solid #e0e0e0;padding:6px 8px;text-align:center;vertical-align:middle}.rubric-table thead th{background:#1a1a2e;color:#fff}.group-header{font-size:.78rem;font-weight:700;letter-spacing:.02em}.group-header.g1{background:#1565c0}.group-header.g2{background:#2e7d32}.criteria-th{font-size:.72rem;font-weight:600;min-width:80px}.criteria-th.g1{background:#1976d2}.criteria-th.g2{background:#388e3c}.criteria-label{line-height:1.3}.criteria-max{font-size:.68rem;opacity:.85;margin-top:2px}.sticky-col{position:sticky;left:0;background:#fff;z-index:2;text-align:left;min-width:160px;border-right:2px solid #e0e0e0}thead .sticky-col{background:#1a1a2e;z-index:3}.student-name-cell{font-weight:600}.roll-no{font-size:.72rem;color:#999;margin-top:2px}.score-cell{padding:4px}.score-cell.g1{background:#e3f2fd}.score-cell.g2{background:#e8f5e9}.star-cell{background:#fff8e1}.score-input{width:52px;padding:4px 6px;border:1.5px solid #ccc;border-radius:6px;text-align:center;font-size:.88rem}.score-input:focus{outline:none;border-color:#1a1a2e}.score-input:disabled{background:#f5f5f5;color:#aaa;cursor:not-allowed}.score-input.over-max{border-color:#e74c3c;background:#fdf0f0}.total-col{background:#1a1a2e;color:#fff;font-weight:700;min-width:60px}.total-cell{font-weight:700;font-size:.95rem;background:#f5f5f5}tr.saving{opacity:.7}.save-toast{position:fixed;bottom:24px;right:24px;padding:10px 20px;border-radius:8px;font-weight:600;font-size:.9rem;z-index:999;animation:fadeIn .2s}.save-toast.saved{background:#d4edda;color:#155724}.save-toast.error{background:#f8d7da;color:#721c24}@keyframes fadeIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}h2{font-size:1.4rem;margin-bottom:20px}h3{font-size:1.05rem;margin-bottom:6px}.hint{font-size:.82rem;color:#666;margin-bottom:16px;line-height:1.5}.settings-card{background:#fff;border-radius:14px;padding:24px;box-shadow:0 2px 10px #00000012;margin-bottom:20px;max-width:700px}.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-bottom:18px}.field input[type=number],.field input[type=email],.field input[type=text],.field input[type=password],.field select{width:100%;padding:8px 10px;border:1.5px solid #e0e0e0;border-radius:8px;font-size:.9rem}.field-hint{font-size:.75rem;color:#aaa;margin-top:4px}.toggle-field{display:flex;align-items:center;gap:14px;margin-bottom:14px}.toggle-field>label:first-child{flex:1;font-size:.9rem;font-weight:600;margin:0}.toggle-switch{position:relative;display:inline-block;width:44px;height:24px;flex-shrink:0}.toggle-switch input{opacity:0;width:0;height:0}.slider{position:absolute;inset:0;background:#ccc;border-radius:24px;cursor:pointer;transition:background .25s}.slider:before{content:"";position:absolute;height:18px;width:18px;left:3px;bottom:3px;background:#fff;border-radius:50%;transition:transform .25s}.toggle-switch input:checked+.slider{background:#1a1a2e}.toggle-switch input:checked+.slider:before{transform:translate(20px)}.btn-primary{background:#1a1a2e;color:#fff;border:none;padding:9px 22px;border-radius:8px;cursor:pointer;font-size:.9rem}.btn-secondary{background:#f0f0f0;color:#333;border:none;padding:9px 18px;border-radius:8px;cursor:pointer;font-size:.9rem}.btn-row{display:flex;gap:10px;flex-wrap:wrap;margin-top:4px}.success{color:#27ae60;margin-top:10px;font-size:.88rem;font-weight:600}.test-result{padding:10px 14px;border-radius:8px;font-size:.85rem;margin-bottom:12px}.test-result.ok{background:#d4edda;color:#155724}.test-result.fail{background:#f8d7da;color:#721c24}.btn-danger{background:#e74c3c;color:#fff;border:none;padding:9px 18px;border-radius:8px;cursor:pointer;font-size:.9rem}.btn-danger:disabled{opacity:.55;cursor:not-allowed}.log-stats{margin-bottom:4px}.count-badge{background:#1a1a2e;color:#fff;padding:4px 14px;border-radius:20px;font-size:.82rem;font-weight:700}.error-msg{background:#fff5f5;color:#e74c3c;border-radius:8px;padding:10px 14px;font-size:.85rem;margin-top:8px}.logs-card{max-width:1000px}.log-card-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:16px;flex-wrap:wrap;gap:10px}.log-filters{display:flex;gap:10px;flex-wrap:wrap;align-items:flex-end;margin-bottom:12px}.log-table-wrap{overflow-x:auto;margin-bottom:14px;border-radius:8px;border:1px solid #e0e0e0}.log-table{width:100%;border-collapse:collapse;background:#fff;font-size:.84rem;min-width:600px}.log-table th{background:#1a1a2e;color:#fff;padding:8px 12px;text-align:left}.log-table td{padding:8px 12px;border-bottom:1px solid #f0f0f0;vertical-align:top}.log-table tr:last-child td{border-bottom:none}.row-error td{background:#fff5f5}.row-warn td{background:#fffbf0}.mono{font-family:monospace;font-size:.79rem}.small{font-size:.78rem}.detail{font-size:.78rem;color:#555;word-break:break-word}.empty{text-align:center;color:#999;padding:24px}.badge{padding:2px 8px;border-radius:20px;font-size:.72rem;font-weight:700;text-transform:uppercase}.badge.info{background:#d4edda;color:#155724}.badge.warn{background:#fff3cd;color:#856404}.badge.error{background:#f8d7da;color:#721c24}.log-loading{text-align:center;padding:30px;color:#666}@media(max-width:600px){.form-grid{grid-template-columns:1fr}.settings-card{padding:16px}}.header-actions{display:flex;gap:8px;align-items:center;flex-wrap:wrap}.search-input{width:100%;padding:8px 12px;border:1.5px solid #e0e0e0;border-radius:8px;margin-bottom:16px;font-size:.9rem}select{padding:8px 12px;border:1.5px solid #e0e0e0;border-radius:8px}.empty{text-align:center;color:#999;padding:32px}.bulk-bar{margin-top:12px;display:flex;align-items:center;gap:12px;background:#fff3cd;padding:10px 16px;border-radius:8px}.btn-primary:disabled{opacity:.5;cursor:not-allowed}.btn-secondary{background:#f0f0f0;color:#333;border:none;padding:8px 16px;border-radius:8px;cursor:pointer}.modal{background:#fff;border-radius:16px;padding:28px;width:100%;max-width:600px;max-height:90vh;overflow-y:auto}.modal-wide{max-width:800px}.modal h3{margin-bottom:8px}.hint{font-size:.83rem;color:#666;margin-bottom:16px}.hint code{background:#f0f0f0;padding:1px 5px;border-radius:4px}.field label{display:block;font-size:.82rem;font-weight:600;margin-bottom:4px}.field input,.field select{width:100%;padding:8px 10px;border:1.5px solid #e0e0e0;border-radius:8px;font-size:.9rem}.drop-zone{border:2px dashed #c0c0c0;border-radius:10px;padding:32px;text-align:center;cursor:pointer;color:#666;font-size:.95rem;transition:border-color .2s,background .2s;margin-bottom:16px}.drop-zone.dragover{border-color:#1a1a2e;background:#f0f4ff}.drop-zone:hover{border-color:#999}.preview-section{margin-bottom:12px}.preview-label{font-size:.82rem;color:#666;margin-bottom:6px}.preview-scroll{overflow-x:auto}.preview-table{width:100%;border-collapse:collapse;font-size:.8rem}.preview-table th{background:#f5f5f5;padding:6px 10px;text-align:left;border-bottom:1px solid #e0e0e0;white-space:nowrap}.preview-table td{padding:5px 10px;border-bottom:1px solid #f0f0f0;white-space:nowrap}.error-list{background:#fff3cd;border-radius:8px;padding:10px 14px;margin-bottom:12px;font-size:.82rem}.error-list ul{margin:4px 0 0 16px}.result-banner{padding:10px 14px;border-radius:8px;margin-bottom:12px;font-size:.88rem;font-weight:600}.result-banner.success{background:#d4edda;color:#155724}.result-banner.error{background:#f8d7da;color:#721c24}.page-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}.header-actions{display:flex;gap:8px}h2{font-size:1.4rem}.data-table{width:100%;border-collapse:collapse;background:#fff;border-radius:12px;overflow:hidden;box-shadow:0 2px 8px #0000000f}.data-table th{background:#1a1a2e;color:#fff;padding:12px 16px;text-align:left;font-size:.85rem}.data-table th.sortable{cursor:pointer;-webkit-user-select:none;user-select:none}.data-table th.sortable:hover{background:#2d2d4e}.data-table td{padding:10px 16px;border-bottom:1px solid #f0f0f0;font-size:.88rem}.super-admin td{background:#f8f9ff}.badge{padding:3px 10px;border-radius:20px;font-size:.78rem;font-weight:600}.badge.active{background:#d4edda;color:#155724}.badge.disabled{background:#f8d7da;color:#721c24}.badge.role{background:#e8eaf6;color:#3949ab}.tag-chip{display:inline-block;background:#e3f2fd;color:#1565c0;border-radius:12px;padding:2px 8px;font-size:.75rem;font-weight:600;margin-right:4px}.muted{color:#bbb}.actions{display:flex;gap:6px}.btn-sm{padding:4px 10px;border:none;border-radius:6px;cursor:pointer;font-size:.8rem;font-weight:600}.btn-sm:disabled{opacity:.4;cursor:not-allowed}.btn-sm.blue{background:#3498db;color:#fff}.btn-sm.red{background:#e74c3c;color:#fff}.btn-sm.orange{background:#f39c12;color:#fff}.btn-sm.green{background:#27ae60;color:#fff}.bulk-bar{margin-top:12px;display:flex;align-items:center;gap:12px;background:#fff3cd;padding:10px 16px;border-radius:8px;font-size:.9rem}.btn-primary{background:#1a1a2e;color:#fff;border:none;padding:8px 16px;border-radius:8px;cursor:pointer}.btn-secondary{background:#e0e0e0;color:#333;border:none;padding:8px 16px;border-radius:8px;cursor:pointer}.modal-overlay{position:fixed;inset:0;background:#0006;display:flex;align-items:center;justify-content:center;z-index:200}.modal{background:#fff;border-radius:16px;padding:28px;width:100%;max-width:520px;max-height:90vh;overflow-y:auto}.modal h3{margin-bottom:20px}.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px}.field.full{grid-column:1 / -1}.field label{display:block;font-size:.82rem;font-weight:600;margin-bottom:6px}.field input[type=text],.field input[type=email],.field input[type=password],.field select{width:100%;padding:8px 10px;border:1.5px solid #e0e0e0;border-radius:8px;font-size:.9rem}.tag-checkboxes{display:flex;gap:16px;flex-wrap:wrap}.tag-check{display:flex;align-items:center;gap:6px;cursor:pointer;font-size:.88rem;font-weight:500}.tag-check input{width:16px;height:16px;cursor:pointer}.hint{font-size:.78rem;color:#999;margin-top:6px}.save-error{color:#e74c3c;font-size:.85rem;margin-bottom:8px}.toggle-label{display:flex;align-items:center;gap:8px;cursor:pointer;font-size:.88rem}.toggle-label input{width:16px;height:16px}.modal-actions{display:flex;justify-content:flex-end;gap:10px;margin-top:20px}.loading{text-align:center;padding:40px;color:#666}.table-pagination{display:flex;justify-content:space-between;align-items:center;margin-top:16px;padding:12px 16px;background:#fff;border-radius:8px;box-shadow:0 1px 3px #0000000d;font-size:.9rem;flex-wrap:wrap;gap:12px;border:1px solid #e2e8f0}.pagination-info{color:#64748b}.pagination-controls{display:flex;align-items:center;flex-wrap:wrap;gap:16px}.pagination-size{display:flex;align-items:center;gap:6px;color:#64748b}.pagination-select{padding:4px 8px;border:1px solid #e2e8f0;border-radius:6px;font-size:.85rem;color:#1a1a2e;background:#f8fafc;cursor:pointer;outline:none;font-family:inherit}.pagination-select:focus{border-color:#1a1a2e}.pagination-buttons{display:flex;align-items:center;gap:6px}.pagination-text{font-size:.85rem;color:#64748b;margin:0 4px}.pagination-btn{display:inline-flex;align-items:center;justify-content:center;min-width:28px;height:28px;padding:0 8px;border:1px solid #e2e8f0;border-radius:6px;font-size:.85rem;font-weight:500;color:#1a1a2e;background:#fff;cursor:pointer;transition:all .2s ease;-webkit-user-select:none;user-select:none}.pagination-btn:hover:not(:disabled){background:#f1f5f9;border-color:#cbd5e1}.pagination-btn:disabled{color:#cbd5e1;cursor:not-allowed;background:#f8fafc;border-color:#f1f5f9}.toast-stack[data-v-92163961]{position:fixed;top:1.25rem;right:1.25rem;z-index:9999;display:flex;flex-direction:column;gap:.6rem;max-width:min(420px,calc(100vw - 2.5rem));pointer-events:none}.toast-list[data-v-92163961]{display:flex;flex-direction:column;gap:.6rem}.toast-item[data-v-92163961]{position:relative;display:flex;align-items:flex-start;gap:.7rem;padding:.85rem 1rem .85rem .9rem;border-radius:10px;border:1px solid transparent;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);box-shadow:0 4px 20px #00000040,0 1px 4px #0000001f;overflow:hidden;pointer-events:all;min-width:280px;animation:toast-in-92163961 .28s cubic-bezier(.34,1.3,.64,1) both}.toast--error[data-v-92163961]{background:#1e0a0ae0;border-color:#ef444466;color:#fee2e2}.toast--warn[data-v-92163961]{background:#1e1605e0;border-color:#fbbf2466;color:#fef3c7}.toast--success[data-v-92163961]{background:#05190fe0;border-color:#22c55e66;color:#dcfce7}.toast--info[data-v-92163961]{background:#051223e0;border-color:#60a5fa66;color:#dbeafe}.toast-icon[data-v-92163961]{flex-shrink:0;display:flex;align-items:center;justify-content:center;width:1.7rem;height:1.7rem;border-radius:50%;font-size:.85rem;font-weight:700;margin-top:.05rem}.toast--error .toast-icon[data-v-92163961]{background:#ef444433;color:#f87171}.toast--warn .toast-icon[data-v-92163961]{background:#fbbf2433;color:#fbbf24}.toast--success .toast-icon[data-v-92163961]{background:#22c55e33;color:#4ade80}.toast--info .toast-icon[data-v-92163961]{background:#60a5fa33;color:#60a5fa}.toast-body[data-v-92163961]{flex:1;min-width:0}.toast-title[data-v-92163961]{margin:0 0 .2rem;font-size:.8rem;font-weight:700;letter-spacing:.04em;text-transform:uppercase;opacity:.9}.toast-message[data-v-92163961]{margin:0;font-size:.875rem;line-height:1.4;word-break:break-word}.toast-actions[data-v-92163961]{display:flex;gap:.5rem;margin-top:.5rem}.toast-action-btn[data-v-92163961]{padding:.25rem .7rem;border-radius:6px;border:1px solid currentColor;background:transparent;color:inherit;font-size:.78rem;font-weight:600;cursor:pointer;opacity:.85;transition:opacity .15s,background .15s}.toast-action-btn[data-v-92163961]:hover{opacity:1;background:#ffffff1f}.toast-close[data-v-92163961]{flex-shrink:0;display:flex;align-items:center;justify-content:center;width:1.5rem;height:1.5rem;border-radius:50%;border:none;background:#ffffff14;color:inherit;font-size:1.15rem;line-height:1;cursor:pointer;opacity:.65;transition:opacity .15s,background .15s;margin-top:.05rem}.toast-close[data-v-92163961]:hover{opacity:1;background:#ffffff2e}.toast-progress[data-v-92163961]{position:absolute;bottom:0;left:0;height:2.5px;width:100%;border-radius:0 0 10px 10px;transform-origin:left center;animation:toast-progress-92163961 linear forwards}.toast--error .toast-progress[data-v-92163961]{background:#f87171}.toast--warn .toast-progress[data-v-92163961]{background:#fbbf24}.toast--success .toast-progress[data-v-92163961]{background:#4ade80}.toast--info .toast-progress[data-v-92163961]{background:#60a5fa}@keyframes toast-in-92163961{0%{opacity:0;transform:translate(110%) scale(.92)}to{opacity:1;transform:translate(0) scale(1)}}@keyframes toast-progress-92163961{0%{transform:scaleX(1)}to{transform:scaleX(0)}}.toast-enter-active[data-v-92163961]{transition:all .28s cubic-bezier(.34,1.3,.64,1)}.toast-leave-active[data-v-92163961]{transition:all .22s ease-in}.toast-enter-from[data-v-92163961]{opacity:0;transform:translate(110%) scale(.92)}.toast-leave-to[data-v-92163961]{opacity:0;transform:translate(110%) scale(.88);max-height:0;margin:0;padding-block:0}.toast-move[data-v-92163961]{transition:transform .22s ease}
