*,:before,:after{box-sizing:border-box}@keyframes spin{to{transform:rotate(360deg)}}body{color:#1e293b;background:#f1f5f9;margin:0;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Arial,sans-serif;font-size:14px}.layout{min-height:100vh;display:flex}.sidebar{color:#94a3b8;background:#0f172a;flex-direction:column;flex-shrink:0;width:230px;height:100vh;display:flex;position:sticky;top:0}.sidebar-brand{border-bottom:1px solid #1e293b;padding:24px 20px 16px}.sidebar-brand h2{color:#f1f5f9;margin:0;font-size:18px;font-weight:700}.sidebar-sub{text-transform:uppercase;letter-spacing:.06em;color:#475569;margin:2px 0 0;font-size:11px}.sidebar-nav{flex:1;padding:12px 0}.nav-link{color:#94a3b8;border-left:3px solid #0000;align-items:center;gap:10px;padding:10px 20px;font-size:13.5px;text-decoration:none;transition:background .15s,color .15s;display:flex}.nav-link:hover{color:#e2e8f0;background:#1e293b}.nav-link.active{color:#f8fafc;background:#1e293b;border-left-color:#6366f1;font-weight:600}.nav-icon{text-align:center;width:20px;font-size:16px}.sidebar-footer{color:#334155;padding:16px 20px;font-size:11px}.main{flex:1;padding:28px 32px;overflow-y:auto}.page-loading{text-align:center;color:#64748b;padding:48px;font-size:14px}.page-title{color:#0f172a;margin:0 0 20px;font-size:22px;font-weight:700}.page-header{justify-content:space-between;align-items:center;margin-bottom:20px;display:flex}.page-header .page-title{margin:0}.card{background:#fff;border-radius:12px;margin-bottom:20px;padding:20px 24px;box-shadow:0 1px 4px #00000012,0 4px 16px #0000000a}.stat-grid{grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:16px;display:grid}.stat-card{background:#fff;border-radius:12px;flex-direction:column;gap:6px;padding:20px;display:flex;box-shadow:0 1px 4px #00000012}.stat-value{font-size:32px;font-weight:700;line-height:1}.stat-label{color:#64748b;text-transform:uppercase;letter-spacing:.05em;font-size:12px}.btn{color:#fff;cursor:pointer;white-space:nowrap;background:#6366f1;border:none;border-radius:8px;padding:9px 18px;font-size:13.5px;font-weight:600;transition:background .15s}.btn:hover{background:#4f46e5}.btn:disabled{cursor:not-allowed;background:#a5b4fc}.btn-outline{color:#6366f1;background:0 0;border:1.5px solid #6366f1}.btn-outline:hover{background:#ede9fe}.btn-danger-sm{color:#ef4444;cursor:pointer;background:#fee2e2;border:none;border-radius:6px;padding:4px 8px;font-size:13px}.btn-danger-sm:hover{background:#fca5a5}.btn-warning-sm{color:#d97706;cursor:pointer;background:#fef3c7;border:1px solid #fde68a;border-radius:6px;padding:4px 10px;font-size:13px}.btn-warning-sm:hover{background:#fde68a}.form-grid{grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:14px 18px;display:grid}.field{flex-direction:column;gap:5px;display:flex}.field label{color:#475569;text-transform:uppercase;letter-spacing:.04em;font-size:12px;font-weight:600}input,select,textarea{color:#1e293b;background:#fff;border:1.5px solid #e2e8f0;border-radius:8px;width:100%;padding:8px 11px;font-size:14px;transition:border-color .15s}input:focus,select:focus{border-color:#6366f1;outline:none}.data-table{border-collapse:collapse;width:100%;margin-top:12px;font-size:13.5px}.data-table th{text-align:left;text-transform:uppercase;letter-spacing:.05em;color:#64748b;border-bottom:1.5px solid #e2e8f0;padding:10px 12px;font-size:11px;font-weight:700}.data-table td{vertical-align:middle;border-bottom:1px solid #f1f5f9;padding:11px 12px}.data-table tr:last-child td{border-bottom:none}.data-table tr:hover td{background:#fafbff}.search-input{border:1.5px solid #e2e8f0;border-radius:8px;width:100%;max-width:380px;margin-bottom:4px;padding:8px 12px;font-size:14px}.search-input:focus{border-color:#6366f1;outline:none}.badge{color:#475569;text-transform:uppercase;letter-spacing:.04em;background:#e2e8f0;border-radius:999px;padding:3px 10px;font-size:11px;font-weight:600;display:inline-block}.badge-danger{color:#ef4444;background:#fee2e2}.badge-ok,.badge-success{color:#16a34a;background:#dcfce7}.badge-warning{color:#d97706;background:#fef3c7}.tabs{gap:4px;margin-bottom:18px;display:flex}.tab{color:#64748b;cursor:pointer;background:#fff;border:1.5px solid #e2e8f0;border-radius:8px;padding:8px 18px;font-size:13.5px;font-weight:500;transition:all .15s}.tab:hover{color:#6366f1;border-color:#6366f1}.tab.active{color:#fff;background:#6366f1;border-color:#6366f1;font-weight:600}.item-chip{color:#374151;cursor:pointer;background:#fff;border:1.5px solid #e2e8f0;border-radius:8px;padding:7px 14px;font-size:13px;transition:all .15s}.item-chip:hover{color:#6366f1;border-color:#6366f1}.item-chip.active{color:#4f46e5;background:#ede9fe;border-color:#6366f1;font-weight:600}.info-box{background:#f8fafc;border:1px solid #e2e8f0;border-radius:8px;margin-top:12px;padding:10px 14px;font-size:13.5px}.error-msg{color:#ef4444;margin:0;font-size:13px}.success-msg{color:#16a34a;margin:0;font-size:13px}.muted{color:#94a3b8}.color-chip{cursor:pointer;letter-spacing:.04em;border-radius:999px;padding:7px 18px;font-size:13px;font-weight:700;transition:all .15s}.radio-label{cursor:pointer;border:1.5px solid #e2e8f0;border-radius:8px;align-items:center;gap:6px;padding:6px 12px;font-size:13.5px;transition:border-color .15s;display:flex}.radio-label:hover{border-color:#6366f1}.radio-label input{accent-color:#6366f1}.issued-chip{background:#f0fdf4;border:1.5px solid #bbf7d0;border-radius:8px;align-items:center;gap:5px;padding:5px 10px;font-size:12.5px;display:inline-flex}.issued-chip-name{color:#166534;font-weight:600}.issued-chip-meta{color:#64748b}.issued-chip-qty{color:#16a34a;font-weight:700}.edit-student-form{flex-direction:column;flex:1;gap:12px;display:flex}.back-link{color:#6366f1;align-items:center;gap:6px;font-size:13.5px;font-weight:500;text-decoration:none;display:inline-flex}.back-link:hover{text-decoration:underline}.table-link{color:#1e293b;text-decoration:none}.table-link:hover{color:#6366f1;text-decoration:underline}.student-header-card{flex-wrap:wrap;align-items:center;gap:20px;display:flex}.student-avatar{color:#6366f1;background:#ede9fe;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:56px;height:56px;font-size:24px;font-weight:700;display:flex}.student-header-info{flex:1;min-width:0}.student-header-stats{gap:20px;display:flex}.mini-stat{flex-direction:column;align-items:center;display:flex}.mini-stat-val{color:#0f172a;font-size:22px;font-weight:700}.mini-stat-lbl{color:#64748b;text-transform:uppercase;letter-spacing:.04em;font-size:11px}.report-toolbar{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;margin-bottom:12px;display:flex}.report-toolbar .search-input{margin-bottom:0}.sidebar-user{border-top:1px solid #1e293b;align-items:center;gap:10px;padding:12px 16px;display:flex}.sidebar-user-info{flex:1;min-width:0}.sidebar-user-name{color:#e2e8f0;white-space:nowrap;text-overflow:ellipsis;font-size:13px;font-weight:600;display:block;overflow:hidden}.sidebar-user-role{text-transform:uppercase;letter-spacing:.06em;margin-top:1px;font-size:10px;font-weight:700;display:block}.logout-btn{color:#64748b;cursor:pointer;background:0 0;border:1.5px solid #334155;border-radius:7px;flex-shrink:0;justify-content:center;align-items:center;width:30px;height:30px;font-size:14px;transition:all .15s;display:flex}.logout-btn:hover{color:#ef4444;border-color:#ef4444}.login-bg{background:linear-gradient(135deg,#0f172a 0%,#1e293b 100%);justify-content:center;align-items:center;min-height:100vh;padding:20px;display:flex}.login-card{background:#fff;border-radius:16px;width:100%;max-width:400px;padding:40px 36px;box-shadow:0 20px 60px #0000004d}.login-logo{text-align:center;margin-bottom:28px}.login-logo h1{color:#0f172a;margin:0;font-size:26px;font-weight:800}.login-logo p{color:#64748b;margin:4px 0 0;font-size:13px}.login-form{flex-direction:column;gap:16px;display:flex}.btn-full{width:100%;margin-top:4px;padding:11px;font-size:15px}.login-roles{flex-wrap:wrap;justify-content:center;gap:6px;margin-top:20px;display:flex}.dash-grid{grid-template-columns:1fr 1fr;gap:20px;margin-bottom:20px;display:grid}@media (width<=780px){.dash-grid{grid-template-columns:1fr}}.stat-card{flex-direction:column;gap:6px;display:flex}a.stat-card:hover{transition:all .15s;transform:translateY(-1px);box-shadow:0 4px 20px #6366f126}.alert-card{border-left:4px solid #ef4444}.alert-header{align-items:center;gap:10px;margin-bottom:12px;display:flex}.alert-icon{color:#ef4444;font-size:18px}.alert-list{flex-direction:column;gap:6px;display:flex}.alert-row{border-radius:8px;align-items:center;gap:10px;padding:8px 12px;font-size:13px;display:flex}.alert-out{background:#fff1f2}.alert-low{background:#fffbeb}.alert-item-name{flex:1;font-weight:600}.alert-meta{color:#64748b;align-items:center;gap:6px;display:flex}.alert-qty{text-align:right;min-width:60px;font-weight:700}.qty-out{color:#ef4444}.qty-low{color:#f59e0b}.alert-footer-link{color:#6366f1;margin-top:10px;font-size:12.5px;text-decoration:none;display:block}.alert-footer-link:hover{text-decoration:underline}.activity-list{flex-direction:column;display:flex}.activity-row{border-bottom:1px solid #f1f5f9;align-items:center;gap:10px;padding:9px 0;display:flex}.activity-row:last-child{border-bottom:none}.activity-dot{border-radius:50%;flex-shrink:0;width:8px;height:8px}.activity-dot-green{background:#10b981}.activity-dot-purple{background:#6366f1}.activity-body{flex:1;min-width:0}.activity-title{white-space:nowrap;text-overflow:ellipsis;font-size:13px;font-weight:600;display:block;overflow:hidden}.activity-sub{color:#64748b;white-space:nowrap;text-overflow:ellipsis;font-size:12px;display:block;overflow:hidden}.activity-time{color:#94a3b8;flex-shrink:0;font-size:11px}.drop-zone{text-align:center;cursor:pointer;color:#64748b;background:#fafbff;border:2px dashed #c7d2fe;border-radius:12px;padding:40px 20px;transition:all .15s}.drop-zone:hover,.drop-zone.drag-over{background:#ede9fe;border-color:#6366f1}.drop-icon{margin-bottom:8px;font-size:36px}.drop-zone p{margin:0;font-size:14px}.import-result-grid{grid-template-columns:repeat(3,1fr);gap:12px;margin-bottom:8px;display:grid}.import-stat{text-align:center;color:#64748b;border:2px solid #e2e8f0;border-radius:10px;flex-direction:column;align-items:center;gap:4px;padding:14px;font-size:13px;display:flex}.pagination{flex-wrap:wrap;align-items:center;gap:4px;margin-top:16px;display:flex}.page-btn{color:#374151;cursor:pointer;background:#fff;border:1.5px solid #e2e8f0;border-radius:7px;min-width:34px;height:34px;padding:0 8px;font-size:13px;transition:all .15s}.page-btn:hover:not(:disabled){color:#6366f1;border-color:#6366f1}.page-btn.active{color:#fff;background:#6366f1;border-color:#6366f1;font-weight:700}.page-btn:disabled{opacity:.4;cursor:default}.page-gap{color:#94a3b8;padding:0 4px;font-size:13px}.page-info{color:#64748b;margin-left:8px;font-size:12px}.btn-print-sm{color:#16a34a;cursor:pointer;white-space:nowrap;background:#f0fdf4;border:1.5px solid #bbf7d0;border-radius:7px;padding:4px 10px;font-size:12px;transition:all .15s}.btn-print-sm:hover{background:#dcfce7}.modal-overlay{z-index:1000;background:#00000073;justify-content:center;align-items:center;padding:16px;display:flex;position:fixed;inset:0}.modal-box{background:#fff;border-radius:14px;flex-direction:column;width:100%;max-width:660px;max-height:90vh;display:flex;overflow:hidden;box-shadow:0 24px 60px #00000040}.modal-header{border-bottom:1px solid #e2e8f0;flex-shrink:0;justify-content:space-between;align-items:center;gap:12px;padding:16px 20px;display:flex}.slip-content{flex:1;padding:20px 24px;overflow-y:auto}.slip-header{text-align:center;border-bottom:2px solid #1e293b;margin-bottom:16px;padding-bottom:12px}.slip-header h2{font-size:17px;font-weight:700}.slip-header p{color:#64748b;margin-top:3px;font-size:12px}.slip-meta{grid-template-columns:1fr 1fr;gap:6px 20px;margin-bottom:16px;font-size:13px;display:grid}.slip-meta strong{min-width:90px;display:inline-block}.slip-footer{grid-template-columns:1fr 1fr;gap:30px;margin-top:30px;display:grid}.sig-line{text-align:center;color:#64748b;border-top:1px solid #94a3b8;margin-top:40px;padding-top:6px;font-size:11px}.hamburger{z-index:500;color:#f1f5f9;cursor:pointer;background:#0f172a;border:none;border-radius:8px;justify-content:center;align-items:center;width:40px;height:40px;font-size:20px;line-height:1;display:none;position:fixed;top:12px;left:12px}.sidebar-overlay{z-index:299;background:#0006;display:none;position:fixed;inset:0}@media (width<=900px){.hamburger{display:flex}.sidebar-overlay{display:block}.sidebar{z-index:300;width:240px;height:100vh;transition:transform .25s;position:fixed;top:0;left:0;transform:translate(-100%)}.sidebar.sidebar-open{transform:translate(0);box-shadow:4px 0 20px #00000059}.main{width:100%;padding:64px 16px 20px}}
