@import "https://fonts.googleapis.com/css2?family=Lexend:wght@400;500;700&family=Inter:wght@400;500;600;700&display=swap";@import "https://fonts.googleapis.com/css2?family=Material+Symbols+Outlined:wght,FILL@100..700,0..1&display=swap";:root{--primary:#006879;--primary-container:#a9edff;--on-primary:#fff;--on-primary-fixed:#001f26;--primary-fixed:#a9edff;--primary-fixed-dim:#54d7f2;--secondary:#006879;--secondary-container:#a9edff;--on-secondary:#fff;--on-secondary-container:#004e5b;--tertiary:#435e91;--tertiary-container:#d8e2ff;--tertiary-fixed:#d8e2ff;--tertiary-fixed-dim:#adc7ff;--on-tertiary:#fff;--on-tertiary-fixed:#001a41;--on-tertiary-container:#2a4678;--surface:#f9f9ff;--surface-dim:#d7d9e6;--surface-bright:#f9f9ff;--surface-container-lowest:#fff;--surface-container-low:#f1f3ff;--surface-container:#ebedfa;--surface-container-high:#e5e8f5;--surface-container-highest:#dfe2ef;--surface-variant:#dfe2ef;--on-surface:#181c25;--on-surface-variant:#3f4759;--outline:#6f778b;--outline-variant:#bfc6dc;--error:#ba1a1a;--error-container:#ffdad6;--on-error:#fff;--on-error-container:#93000a;--font-headline:"Lexend", sans-serif;--font-body:"Inter", sans-serif;--radius-sm:2px;--radius-md:4px;--radius-lg:8px;--radius-xl:12px;--radius-full:9999px;--shadow-sm:0 1px 3px #0000000f;--shadow-md:0 4px 24px #00000012;--shadow-lg:0 8px 40px #00000017;--space-xs:4px;--space-sm:8px;--space-md:16px;--space-lg:24px;--space-xl:32px;--space-2xl:48px;--space-3xl:64px;--transition-fast:.15s ease;--transition-base:.25s ease}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth}body{font-family:var(--font-body);background:var(--surface);color:var(--on-surface);-webkit-font-smoothing:antialiased;-webkit-text-rendering:optimizeLegibility;font-size:15px;line-height:1.6}#root{flex-direction:column;min-height:100vh;display:flex}h1,h2,h3,h4,h5,h6{font-family:var(--font-headline);color:var(--on-surface);font-weight:700;line-height:1.2}h1{font-size:clamp(1.8rem,4vw,2.6rem)}h2{font-size:clamp(1.3rem,3vw,1.8rem)}h3{font-size:clamp(1.1rem,2.5vw,1.3rem)}h4{font-size:1rem}p{color:var(--on-surface);font-weight:400}a{color:var(--primary);text-decoration:none}.app-shell{min-height:100vh;display:flex}.sidebar{background:var(--surface-container-low);z-index:40;flex-direction:column;flex-shrink:0;width:256px;height:100vh;padding:32px 0;display:flex;position:fixed;top:0;left:0}.sidebar-brand{padding:0 32px 32px}.sidebar-brand-title{font-family:var(--font-headline);text-transform:uppercase;letter-spacing:-.02em;color:var(--on-surface);font-size:1.1rem;font-weight:800}.sidebar-brand-sub{letter-spacing:.02em;color:var(--on-surface-variant);margin-top:2px;font-size:.6875rem;font-weight:500}.sidebar-nav{flex:1}.sidebar-link{color:var(--on-surface-variant);transition:transform var(--transition-fast);cursor:pointer;text-align:left;width:100%;font-size:.875rem;font-weight:500;font-family:var(--font-body);background:0 0;border:none;align-items:center;gap:12px;padding:12px 24px;text-decoration:none;display:flex}.sidebar-link:hover{color:var(--on-surface);transform:translate(4px)}.sidebar-link.active{background:var(--surface-container-high);color:var(--primary);border-radius:0 9999px 9999px 0;margin-right:12px;font-weight:700}.sidebar-cta{padding:16px 24px}.sidebar-cta-btn{background:linear-gradient(135deg, var(--primary), #00adc8);width:100%;color:var(--on-primary);font-family:var(--font-body);border-radius:var(--radius-xl);cursor:pointer;transition:all var(--transition-fast);border:none;justify-content:center;align-items:center;gap:8px;padding:12px;font-size:.875rem;font-weight:700;display:flex}.sidebar-cta-btn:hover{opacity:.92;transform:translateY(-1px)}.sidebar-footer{border-top:1px solid var(--surface-container-highest);padding:16px 0}.main-content{flex-direction:column;flex:1;min-height:100vh;margin-left:256px;display:flex}.topbar{background:var(--surface-container-low);z-index:50;justify-content:space-between;align-items:center;height:64px;padding:0 32px;display:flex;position:sticky;top:0}.topbar-brand{font-family:var(--font-headline);letter-spacing:-.04em;color:var(--primary);font-size:1.3rem;font-weight:900}.topbar-actions{align-items:center;gap:8px;display:flex}.icon-btn{border-radius:var(--radius-full);cursor:pointer;width:38px;height:38px;color:var(--on-surface-variant);transition:background var(--transition-fast);background:0 0;border:none;justify-content:center;align-items:center;font-size:1.1rem;display:flex}.icon-btn:hover{background:var(--surface-container-high)}.icon-btn:active{transform:scale(.95)}.user-avatar{border-radius:var(--radius-full);background:var(--surface-container-high);width:32px;height:32px;font-family:var(--font-headline);color:var(--primary);cursor:pointer;flex-shrink:0;justify-content:center;align-items:center;font-size:.75rem;font-weight:700;display:flex}.page-wrapper{flex:1;width:100%;max-width:1400px;margin:0 auto;padding:40px 48px}.page-header{margin-bottom:32px}.page-subtitle{color:var(--on-surface);margin-top:4px;font-size:.95rem;font-weight:500}.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-between{justify-content:space-between}.gap-sm{gap:var(--space-sm)}.gap-md{gap:var(--space-md)}.gap-lg{gap:var(--space-lg)}.grid-2{gap:var(--space-lg);grid-template-columns:1fr 1fr;display:grid}.grid-3{gap:var(--space-lg);grid-template-columns:1fr 1fr 1fr;display:grid}.grid-4{gap:var(--space-lg);grid-template-columns:repeat(4,1fr);display:grid}.card{background:var(--surface-container-low);border-radius:var(--radius-xl);padding:var(--space-xl);transition:background var(--transition-base);border:1px solid var(--outline-variant)}.card:hover{background:var(--surface-container)}.stat-card{background:var(--surface-container-low);border-radius:var(--radius-full);padding:var(--space-lg) var(--space-xl);align-items:center;gap:var(--space-md);transition:background var(--transition-base);border:1px solid var(--outline-variant);display:flex}.stat-card:hover{background:var(--surface-container)}.stat-icon{border-radius:var(--radius-full);flex-shrink:0;justify-content:center;align-items:center;width:48px;height:48px;font-size:1.3rem;display:flex}.stat-icon.teal{color:var(--primary);background:#0068791f}.stat-icon.blue{color:var(--tertiary);background:#435e911f}.stat-icon.green{color:var(--secondary);background:#00687914}.stat-icon.amber{color:#b45309;background:#f59e0b1f}.stat-value{font-family:var(--font-headline);color:var(--on-surface);letter-spacing:-.02em;font-size:1.9rem;font-weight:900;line-height:1}.stat-label{color:var(--on-surface);text-transform:uppercase;letter-spacing:.08em;margin-top:3px;font-size:.68rem;font-weight:700}.btn{justify-content:center;align-items:center;gap:var(--space-sm);border-radius:var(--radius-lg);font-family:var(--font-body);cursor:pointer;transition:all var(--transition-fast);white-space:nowrap;border:none;padding:10px 22px;font-size:.875rem;font-weight:700;display:inline-flex}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:linear-gradient(135deg, var(--primary), #00adc8);color:var(--on-primary)}.btn-primary:hover:not(:disabled){opacity:.9;transform:translateY(-1px)}.btn-secondary{background:var(--surface-container-high);color:var(--on-surface)}.btn-secondary:hover:not(:disabled){background:var(--surface-container-highest)}.btn-success{background:var(--secondary);color:var(--on-secondary)}.btn-success:hover:not(:disabled){opacity:.9}.btn-danger{background:var(--error-container);color:var(--on-error-container)}.btn-danger:hover:not(:disabled){opacity:.9}.btn-ghost{color:var(--on-surface-variant);background:0 0}.btn-ghost:hover:not(:disabled){background:var(--surface-container-high)}.btn-sm{padding:7px 14px;font-size:.8rem}.btn-lg{padding:13px 28px;font-size:1rem}.btn-full{justify-content:center;width:100%}.form-group{flex-direction:column;gap:6px;display:flex}.form-label{color:var(--on-surface-variant);text-transform:uppercase;letter-spacing:.06em;font-size:.6875rem;font-weight:700}.form-input,.form-select,.form-textarea{background:var(--surface-container-high);border:1px solid var(--outline-variant);border-radius:var(--radius-lg);color:var(--on-surface);font-family:var(--font-body);transition:background var(--transition-fast), box-shadow var(--transition-fast);width:100%;padding:11px 16px;font-size:.875rem;font-weight:500}.form-input:focus,.form-select:focus,.form-textarea:focus{background:var(--surface-container-highest);box-shadow:0 0 0 2px var(--primary);border-color:var(--primary)}.form-input::placeholder{color:var(--on-surface-variant)}.form-select option{background:var(--surface-container-lowest);color:var(--on-surface);font-weight:500}.form-checkbox-row{align-items:center;gap:var(--space-sm);cursor:pointer;color:var(--on-surface);font-size:.875rem;display:flex}.form-checkbox-row input[type=checkbox]{width:18px;height:18px;accent-color:var(--primary)}.badge{border-radius:var(--radius-full);text-transform:uppercase;letter-spacing:.06em;align-items:center;gap:4px;padding:3px 10px;font-size:.68rem;font-weight:900;display:inline-flex}.badge-uploaded{background:var(--surface-container-highest);color:var(--on-surface-variant)}.badge-paid{background:var(--tertiary-fixed);color:var(--on-tertiary-fixed)}.badge-queued{background:var(--tertiary-container);color:var(--on-tertiary-container)}.badge-printing{background:var(--primary);color:var(--on-primary);animation:2s infinite pulse-badge}.badge-done{background:var(--secondary-container);color:var(--on-secondary-container)}.badge-failed{background:var(--error-container);color:var(--on-error-container)}.badge-cancelled{background:var(--surface-container-highest);color:var(--on-surface-variant)}.badge-role-student{background:var(--tertiary-container);color:var(--on-tertiary-container)}.badge-role-staff{background:var(--primary-fixed);color:var(--on-primary-fixed)}.badge-role-admin{background:var(--error-container);color:var(--on-error-container)}.badge-role-printshop{background:var(--secondary-container);color:var(--on-secondary-container)}@keyframes pulse-badge{0%,to{opacity:1}50%{opacity:.7}}.pulse-dot{background:currentColor;border-radius:50%;width:6px;height:6px;animation:2s infinite pulse}@keyframes pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.4;transform:scale(.8)}}.navbar{display:none}.auth-page{min-height:100vh;padding:var(--space-xl);background:var(--surface);justify-content:center;align-items:center;display:flex}.auth-card{background:var(--surface-container-lowest);border-radius:var(--radius-xl);width:100%;max-width:460px;padding:var(--space-2xl);box-shadow:var(--shadow-lg)}.auth-logo{margin-bottom:var(--space-xl);font-family:var(--font-headline);color:var(--on-surface);letter-spacing:-.03em;justify-content:center;align-items:center;gap:10px;font-size:1.4rem;font-weight:800;display:flex}.auth-logo-icon{background:linear-gradient(135deg, var(--primary), #00adc8);border-radius:var(--radius-lg);justify-content:center;align-items:center;width:44px;height:44px;font-size:22px;display:flex}.auth-form{gap:var(--space-md);flex-direction:column;display:flex}.auth-divider{text-align:center;color:var(--outline);margin:var(--space-sm) 0;font-size:.8rem}.file-drop-zone{border:2px dashed var(--outline-variant);border-radius:var(--radius-xl);padding:48px var(--space-xl);text-align:center;cursor:pointer;transition:all var(--transition-base);background:var(--surface);align-items:center;gap:var(--space-md);flex-direction:column;display:flex}.file-drop-zone:hover,.file-drop-zone.drag-active{border-color:var(--primary);background:#0068790a}.drop-icon{border-radius:var(--radius-full);width:72px;height:72px;transition:transform var(--transition-base);background:#0068790f;justify-content:center;align-items:center;font-size:2rem;display:flex}.file-drop-zone:hover .drop-icon{transform:scale(1.1)}.file-preview{background:var(--surface-container-high);border-radius:var(--radius-lg);padding:var(--space-md);justify-content:space-between;align-items:center;gap:var(--space-md);display:flex}.file-preview-info{align-items:center;gap:var(--space-sm);display:flex}.file-preview-icon{background:var(--primary-fixed);border-radius:var(--radius-sm);flex-shrink:0;justify-content:center;align-items:center;width:40px;height:40px;font-size:18px;display:flex}.queue-item{background:var(--surface-container-low);border-radius:var(--radius-xl);padding:var(--space-md) var(--space-lg);align-items:center;gap:var(--space-md);transition:all var(--transition-base);display:flex;position:relative}.queue-item:hover{background:var(--surface-container);transform:translateY(-1px)}.queue-item.top-priority{background:var(--surface-container-highest)}.queue-position{border-radius:var(--radius-full);background:var(--surface-container-highest);width:36px;height:36px;font-family:var(--font-headline);color:var(--on-surface);flex-shrink:0;justify-content:center;align-items:center;font-size:.875rem;font-weight:900;display:flex}.queue-item.top-priority .queue-position{background:var(--primary);color:var(--on-primary)}.modal-overlay{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:999;background:#181c2580;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.modal{background:var(--surface-container-lowest);border-radius:var(--radius-xl);padding:var(--space-2xl);width:90%;max-width:440px;box-shadow:var(--shadow-lg)}.otp-display{font-family:var(--font-headline);text-align:center;letter-spacing:.3em;color:var(--primary);padding:var(--space-lg);background:var(--surface-container-low);border-radius:var(--radius-lg);margin:var(--space-lg) 0;font-size:3rem;font-weight:900}.otp-digit{background:var(--surface-container-high);border-radius:var(--radius-lg);width:52px;height:60px;font-family:var(--font-headline);text-align:center;color:var(--on-surface);transition:all var(--transition-fast);border:2px solid #0000;outline:none;font-size:1.4rem;font-weight:700}.otp-digit:focus{border-color:var(--primary);background:var(--surface-container-highest)}.otp-input-row{gap:var(--space-sm);justify-content:center;display:flex}.price-breakdown{margin-bottom:var(--space-lg);flex-direction:column;gap:12px;display:flex}.price-row{color:var(--on-surface);justify-content:space-between;align-items:center;padding-bottom:10px;font-size:.875rem;font-weight:500;display:flex}.price-row:not(:last-child){border-bottom:1px solid var(--outline-variant)}.price-row.total{color:var(--on-surface);font-size:1rem;font-weight:700}.price-amount{color:var(--on-surface);font-weight:600}.price-amount.highlight{font-family:var(--font-headline);color:var(--primary);font-size:1.5rem;font-weight:900}.step-indicator{margin-bottom:var(--space-xl);align-items:center;gap:0;display:flex}.step{flex:1;align-items:center;display:flex}.step-circle{border-radius:var(--radius-full);background:var(--surface-container-high);width:34px;height:34px;color:var(--on-surface-variant);transition:all var(--transition-base);flex-shrink:0;justify-content:center;align-items:center;font-size:.8rem;font-weight:700;display:flex}.step-circle.active{background:var(--primary);color:var(--on-primary)}.step-circle.completed{background:var(--secondary);color:var(--on-secondary)}.step-line{background:var(--surface-container-high);flex:1;height:2px}.step-line.filled{background:var(--secondary)}.table-wrapper{overflow-x:auto}table{border-collapse:collapse;width:100%;font-size:.875rem}thead tr{text-transform:uppercase;letter-spacing:.08em;color:var(--on-surface-variant);font-size:.68rem;font-weight:900}th{text-align:left;background:var(--surface-container);padding:14px 16px;font-weight:900}td{color:var(--on-surface);padding:14px 16px;font-weight:500}tbody tr{transition:background var(--transition-fast);cursor:pointer}tbody tr:hover{background:var(--surface-container-high)}.alert{padding:var(--space-md) var(--space-lg);border-radius:var(--radius-lg);align-items:flex-start;gap:10px;font-size:.875rem;display:flex}.alert-info{background:var(--tertiary-container);color:var(--on-tertiary-container)}.alert-success{background:var(--secondary-container);color:var(--on-secondary-container)}.alert-error{background:var(--error-container);color:var(--on-error-container)}.live-badge{color:var(--secondary);text-transform:uppercase;letter-spacing:.06em;background:var(--secondary-container);border-radius:var(--radius-full);align-items:center;gap:6px;padding:4px 10px;font-size:.75rem;font-weight:700;display:flex}.live-dot{background:var(--secondary);border-radius:50%;width:6px;height:6px;animation:1.5s infinite pulse}.skeleton{background:linear-gradient(90deg, var(--surface-container-high) 25%, var(--surface-container) 50%, var(--surface-container-high) 75%);border-radius:var(--radius-lg);background-size:200% 100%;animation:1.5s infinite shimmer}@keyframes shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.spinner{border:2px solid #ffffff4d;border-top-color:#fff;border-radius:50%;width:16px;height:16px;animation:.6s linear infinite spin;display:inline-block}@keyframes spin{to{transform:rotate(360deg)}}.animate-fade-in{animation:.3s fadeIn}@keyframes fadeIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}.material-symbols-outlined{font-variation-settings:"FILL" 0, "wght" 400, "GRAD" 0, "opsz" 24;vertical-align:middle;font-size:20px;line-height:1}[data-theme-mode=dark]{--lightningcss-light: ;--lightningcss-dark:initial;color-scheme:dark}[data-theme-mode=dark] .sidebar{background:var(--surface-container-low);border-right:1px solid var(--surface-container-highest)}[data-theme-mode=dark] .sidebar-link{color:var(--on-surface-variant)}[data-theme-mode=dark] .sidebar-link:hover{color:var(--on-surface)}[data-theme-mode=dark] .sidebar-link.active{background:var(--surface-container-highest);color:var(--primary)}[data-theme-mode=dark] .topbar{background:var(--surface-container-low);border-bottom:1px solid var(--surface-container-highest)}[data-theme-mode=dark] .icon-btn:hover{background:var(--surface-container-high)}[data-theme-mode=dark] tbody tr:hover{background:#00687914}[data-theme-mode=dark] .form-input::placeholder{color:var(--on-surface-variant)}[data-theme-mode=dark] .form-select option{background:var(--surface-container-low);color:var(--on-surface)}[data-theme-mode=dark] .file-drop-zone{background:var(--surface-container)}[data-theme-mode=dark] .file-drop-zone:hover,[data-theme-mode=dark] .file-drop-zone.drag-active{border-color:var(--primary);background:#0068791f}@media (width<=1024px){.sidebar{display:none}.main-content{margin-left:0}.page-wrapper{padding:24px 20px}}@media (width<=768px){.grid-2,.grid-3,.grid-4{grid-template-columns:1fr}}.theme-switcher{border-top:1px solid var(--surface-container-highest);flex-direction:column;gap:12px;padding:16px 24px;font-size:.875rem;display:flex}.theme-section{flex-direction:column;gap:8px;display:flex}.theme-label{text-transform:uppercase;letter-spacing:.06em;color:var(--on-surface-variant);align-items:center;gap:6px;font-size:.7rem;font-weight:700;display:flex}.theme-label .material-symbols-outlined{font-size:14px}.theme-toggle{border-radius:var(--radius-lg);background:var(--surface-container-high);color:var(--on-surface);border:1px solid var(--surface-container-highest);cursor:pointer;transition:all var(--transition-fast);font-size:.8rem;font-weight:600;font-family:var(--font-body);justify-content:center;align-items:center;gap:6px;padding:8px 12px;display:flex}.theme-toggle:hover{background:var(--surface-container-highest);transform:translateY(-1px)}.theme-toggle .material-symbols-outlined{font-size:16px}.palette-grid{grid-template-columns:repeat(5,1fr);gap:6px;display:grid}.palette-btn{aspect-ratio:1;border-radius:var(--radius-md);cursor:pointer;width:100%;transition:all var(--transition-fast);border:2px solid #0000;justify-content:center;align-items:center;display:flex;position:relative;overflow:hidden}.palette-btn:hover{transform:scale(1.05)}.palette-btn.active{border-color:var(--on-surface);box-shadow:0 0 0 2px var(--surface-container-low), 0 0 0 4px var(--on-surface)}.palette-btn .check-icon{color:#fff;text-shadow:0 0 4px #0000004d;font-size:16px}
