*{box-sizing:border-box;margin:0;padding:0}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;overflow-x:hidden}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}.loading-container{align-items:center;background:#f8fafc;display:flex;justify-content:center;min-height:100vh}.loading-spinner{text-align:center}.spinner{border:4px solid #e5e7eb;border-top-color:#3b82f6;height:40px;margin:0 auto 16px;width:40px}.loading-spinner p{color:#6b7280;font-size:14px}.login-container{background:#f8fafc;display:flex;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,sans-serif;min-height:100vh}.login-left-panel{background:linear-gradient(135deg,#1e3a8a,#1e40af 50%,#3b82f6);overflow:hidden;position:relative}.login-left-panel,.login-right-panel{align-items:center;display:flex;flex:1 1;justify-content:center;padding:60px}.login-right-panel{background:#fff}.login-card{animation:slideInRight .8s ease-out;max-width:450px;padding:0;width:100%}.login-branding{animation:slideInLeft .8s ease-out;color:#fff;position:relative;text-align:center;z-index:2}@keyframes slideInLeft{0%{opacity:0;transform:translateX(-50px)}to{opacity:1;transform:translateX(0)}}.logo-container{gap:20px;margin-bottom:40px}.logo-container,.logo-icon{align-items:center;display:flex;justify-content:center}.logo-icon{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffff26;border:1px solid #fff3;border-radius:16px;height:60px;width:60px}.logo-icon svg{color:#fff;height:32px;width:32px}.logo-text h1{color:#fff;font-size:32px;font-weight:800;letter-spacing:-1px;margin:0}.logo-text span{color:#fffc;font-size:18px;font-weight:400;margin-left:8px}.branding-content h2{color:#fff;font-size:28px;font-weight:700;margin:0 0 16px}.branding-content p{color:#ffffffe6;font-size:16px;line-height:1.6;margin:0 auto 32px;max-width:400px}.features-list{display:flex;flex-direction:column;gap:16px;margin:0 auto;max-width:300px}.feature-item{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffff1a;border:1px solid #fff3;border-radius:12px;gap:12px;padding:12px 16px}.feature-icon,.feature-item{align-items:center;display:flex}.feature-icon{background:#ffffff26;border-radius:8px;font-size:20px;height:32px;justify-content:center;width:32px}.feature-item span{color:#fff;font-size:14px;font-weight:500}.login-header{margin-bottom:32px;text-align:left}.login-header h3{color:#1e293b;font-size:28px;font-weight:700;letter-spacing:-.5px;margin:0 0 8px}.login-header p{color:#64748b;font-size:16px;font-weight:400;margin:0}.login-form{display:flex;flex-direction:column;gap:20px}.error-banner{align-items:center;background:#fef2f2;border:1px solid #fecaca;border-radius:12px;color:#dc2626;display:flex;font-size:14px;font-weight:500;gap:12px;padding:16px}.error-icon{flex-shrink:0;font-size:18px}.form-group{display:flex;flex-direction:column;gap:8px}.form-label{color:#374151;font-size:14px;font-weight:600}.form-input,.form-textarea{background:#fff;border-radius:12px;box-sizing:border-box;color:#111827;font-size:16px;font-weight:400;padding:16px 20px;transition:all .3s ease}.form-textarea{min-height:100px}.form-input::placeholder,.form-textarea::placeholder{color:#9ca3af;font-weight:400}.form-input:focus,.form-textarea:focus{box-shadow:0 0 0 4px #3b82f61a}.form-input.error,.form-textarea.error{box-shadow:0 0 0 4px #ef44441a}.form-input:disabled,.form-textarea:disabled{background-color:#f9fafb;cursor:not-allowed;opacity:.6}.error-message{color:#e53e3e;font-weight:500}.checkbox-group{align-items:center;flex-direction:row;gap:12px}.checkbox-label{align-items:center;color:#4a5568;cursor:pointer;display:flex;font-size:14px;font-weight:500;gap:12px}.checkbox-input{display:none}.checkbox-custom{align-items:center;border:2px solid #e2e8f0;border-radius:4px;display:flex;flex-shrink:0;height:20px;justify-content:center;transition:all .2s ease;width:20px}.checkbox-input:checked+.checkbox-custom{background:#3b82f6;border-color:#3b82f6}.checkbox-input:checked+.checkbox-custom:after{color:#fff;content:"✓";font-size:14px;font-weight:700}.login-button{align-items:center;background:linear-gradient(135deg,#3b82f6,#2563eb);border:none;border-radius:12px;color:#fff;cursor:pointer;display:flex;font-size:16px;font-weight:600;gap:8px;justify-content:center;padding:16px 24px;transition:all .3s ease;width:100%}.login-button:hover:not(:disabled){background:linear-gradient(135deg,#2563eb,#1d4ed8);box-shadow:0 8px 16px #3b82f64d;transform:translateY(-2px)}.login-button:disabled{cursor:not-allowed;opacity:.6}.login-button.loading{pointer-events:none}.spinner{animation:spin .8s linear infinite;border:2px solid #ffffff4d;border-radius:50%;border-top-color:#fff;height:16px;width:16px}@keyframes spin{to{transform:rotate(1turn)}}.form-footer{align-items:center;display:flex;flex-direction:column;gap:12px;margin-top:8px}.link-button{background:none;border:none;color:#3b82f6;cursor:pointer;font-size:14px;font-weight:500;padding:8px;transition:color .2s ease}.link-button:hover{color:#2563eb;text-decoration:underline}.link-button.primary{color:#1e293b;font-weight:600}.divider-text{color:#9ca3af;font-size:14px;margin:4px 0}@media (max-width:768px){.login-container{flex-direction:column}.login-left-panel{min-height:auto;padding:40px 20px}.login-right-panel{padding:40px 20px}.login-card{max-width:100%}}.student-profile{margin:0 auto;max-width:1200px}.warning-banner{align-items:center;animation:slideDown .3s ease;background:#fee2e2;border:2px solid #ef4444;border-radius:12px;box-shadow:0 4px 12px #ef444433;color:#991b1b;display:flex;font-size:15px;font-weight:600;gap:12px;margin-bottom:24px;padding:16px 20px}.warning-banner svg{color:#dc2626;flex-shrink:0}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.profile-header{align-items:center;background:#fff;border-radius:16px;box-shadow:0 1px 3px #0000001a;display:flex;gap:24px;margin-bottom:24px;padding:32px}.profile-avatar{align-items:center;background:linear-gradient(135deg,#3b82f6,#2563eb);border:5px solid #e0f2fe;border-radius:50%;box-shadow:0 4px 12px #3b82f633;color:#fff;display:flex;flex-shrink:0;font-size:56px;font-weight:700;height:140px;justify-content:center;overflow:hidden;transition:transform .2s ease,box-shadow .2s ease;width:140px}.profile-avatar.clickable{cursor:pointer}.profile-avatar.clickable:hover{box-shadow:0 8px 20px #3b82f659;transform:scale(1.05)}.profile-image{height:100%;object-fit:cover;width:100%}.profile-initials{font-size:56px;font-weight:700}.profile-header-info h2{color:#1e293b;font-size:28px;font-weight:700;margin:0 0 8px}.profile-subtitle{color:#64748b;font-size:16px;margin:0 0 12px}.status-badge{border-radius:20px;font-size:12px;padding:6px 12px}.status-badge.active{background:#d1fae5;color:#065f46}.status-badge.inactive{background:#fee2e2;color:#991b1b}.profile-content{display:flex;flex-direction:column;gap:24px}.profile-section{background:#fff;border-radius:16px;box-shadow:0 1px 3px #0000001a;padding:24px}.section-title{border-bottom:2px solid #e5e7eb;color:#1e293b;font-size:20px;font-weight:700;margin:0 0 20px;padding-bottom:12px}.info-grid{grid-gap:24px;display:grid;gap:24px;grid-template-columns:repeat(auto-fit,minmax(250px,1fr))}.info-item{display:flex;flex-direction:column;gap:8px}.info-item label{color:#64748b;font-size:14px;font-weight:600;letter-spacing:.5px;text-transform:uppercase}.info-item p{color:#1e293b;font-size:16px;font-weight:500;margin:0}.seat-info-card{align-items:center;background:linear-gradient(135deg,#f0f9ff,#e0f2fe);border:2px solid #bae6fd;border-radius:12px;display:flex;justify-content:space-between;padding:24px}.seat-number-display{display:flex;flex-direction:column;gap:8px}.seat-label{color:#0369a1;font-size:14px;font-weight:600;text-transform:uppercase}.seat-value{color:#0c4a6e;font-size:36px;font-weight:800}.view-seat-button{background:#3b82f6;border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:14px;font-weight:600;padding:12px 24px;transition:all .2s ease}.view-seat-button:hover{background:#2563eb;box-shadow:0 4px 12px #3b82f64d;transform:translateY(-2px)}.action-button{align-items:center;background:#fff;border:2px solid #3b82f6;border-radius:8px;color:#3b82f6;cursor:pointer;display:flex;font-size:14px;font-weight:600;gap:8px;padding:12px 20px;transition:all .2s ease}.action-button:hover{box-shadow:0 4px 12px #3b82f64d;transform:translateY(-2px)}.action-button.primary,.action-button:hover{background:#3b82f6;color:#fff}.action-button.primary:hover{background:#2563eb}.image-modal-overlay{align-items:center;animation:fadeIn .2s ease;background:#000000b3;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:1000}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.image-modal{animation:scaleIn .2s ease;background:#fff;border-radius:16px;box-shadow:0 20px 60px #0000004d;max-width:400px;padding:20px;position:relative;width:90%}@keyframes scaleIn{0%{opacity:0;transform:scale(.9)}to{opacity:1;transform:scale(1)}}.image-modal-close{align-items:center;background:#f1f5f9;border:none;border-radius:50%;color:#64748b;cursor:pointer;display:flex;height:36px;justify-content:center;position:absolute;right:12px;top:12px;transition:all .2s ease;width:36px}.image-modal-close:hover{background:#e2e8f0;color:#1e293b}.image-modal-img{aspect-ratio:1;border-radius:12px;margin-bottom:16px;object-fit:cover;width:100%}.image-modal-name{color:#1e293b;font-size:18px;font-weight:600;margin:0;text-align:center}@media (max-width:768px){.profile-header{flex-direction:column;text-align:center}.profile-avatar{margin:0 auto}.info-grid{grid-template-columns:1fr}.seat-info-card{gap:16px;text-align:center}.action-buttons,.seat-info-card{flex-direction:column}.action-button{justify-content:center;width:100%}.image-modal{max-width:320px}}.sitting-arrangement{margin:0 auto;max-width:1400px}.arrangement-header{align-items:center;background:#fff;border-radius:16px;box-shadow:0 1px 3px #0000001a;display:flex;flex-wrap:wrap;gap:16px;justify-content:space-between;margin-bottom:24px;padding:24px}.header-info h2{color:#1e293b;font-size:24px;font-weight:700;margin:0 0 8px}.header-info p{color:#64748b;font-size:14px;margin:0}.view-toggle{background:#f1f5f9;border-radius:8px;display:flex;gap:8px;padding:4px}.toggle-btn{align-items:center;background:#0000;border:none;border-radius:6px;color:#64748b;cursor:pointer;display:flex;font-size:14px;font-weight:600;gap:6px;padding:8px 16px;transition:all .2s ease}.toggle-btn:hover{color:#3b82f6}.toggle-btn.active{background:#fff;box-shadow:0 2px 4px #0000001a;color:#3b82f6}.current-seat-info{align-items:center;background:linear-gradient(135deg,#dbeafe,#bfdbfe);border:2px solid #3b82f6;border-radius:12px;display:flex;gap:16px;margin-bottom:24px;padding:16px 20px}.info-icon{font-size:24px}.info-content{display:flex;flex-direction:column;gap:4px}.info-content strong{color:#1e40af;font-size:16px}.info-content span{color:#1e40af;font-size:14px;opacity:.8}.seats-grid{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(auto-fill,minmax(120px,1fr));margin-bottom:24px}.seat-card{background:#fff;border:2px solid #0000;border-radius:12px;box-shadow:0 1px 3px #0000001a;cursor:pointer;padding:16px;text-align:center;transition:all .2s ease}.seat-card:hover{box-shadow:0 4px 12px #00000026;transform:translateY(-4px)}.seat-card.available{border-color:#10b981}.seat-card.occupied{border-color:#ef4444}.seat-card.current-user{background:linear-gradient(135deg,#dbeafe,#bfdbfe);border-color:#3b82f6}.seat-number{color:#1e293b;font-size:24px;font-weight:800;margin-bottom:8px}.seat-status{display:flex;justify-content:center}.status-badge.available{background:#d1fae5;color:#065f46}.status-badge.occupied{background:#fee2e2;color:#991b1b}.status-badge.current{background:#dbeafe;color:#1e40af}.seats-list{background:#fff;border-radius:16px;box-shadow:0 1px 3px #0000001a;overflow-x:auto;padding:24px}.seats-table{border-collapse:collapse;width:100%}.seats-table thead{background:#f8fafc}.seats-table th{border-bottom:2px solid #e5e7eb;color:#1e293b;font-size:14px;font-weight:600;letter-spacing:.5px;padding:12px 16px;text-align:left;text-transform:uppercase}.seats-table td{border-bottom:1px solid #e5e7eb;color:#475569;font-size:14px;padding:16px}.seats-table tbody tr{cursor:pointer;transition:background .2s ease}.seats-table tbody tr:hover{background:#f8fafc}.seats-table tbody tr.current-user-row{background:#dbeafe;font-weight:600}.seats-table tbody tr.current-user-row td{color:#1e40af}@media (max-width:768px){.seats-grid{gap:12px;grid-template-columns:repeat(auto-fill,minmax(100px,1fr))}.arrangement-header{align-items:stretch;flex-direction:column}.view-toggle{justify-content:stretch;width:100%}.toggle-btn{flex:1 1;justify-content:center}}.seat-change-request{margin:0 auto;max-width:1000px}.request-header{background:#fff;border-radius:16px;box-shadow:0 1px 3px #0000001a;margin-bottom:24px;padding:24px}.request-header h2{color:#1e293b;font-size:24px;font-weight:700;margin:0 0 8px}.request-header p{color:#64748b;font-size:14px;margin:0}.request-content{display:flex;flex-direction:column;gap:24px}.current-seat-info-card{background:linear-gradient(135deg,#f0f9ff,#e0f2fe);border:2px solid #bae6fd;border-radius:12px;display:flex;gap:32px;padding:24px}.current-seat-info-card .info-item{display:flex;flex-direction:column;gap:8px}.current-seat-info-card label{color:#0369a1;font-size:12px;font-weight:600;letter-spacing:.5px;text-transform:uppercase}.seat-display,.student-id-display{color:#0c4a6e;font-size:24px;font-weight:800}.request-form{background:#fff;border-radius:16px;box-shadow:0 1px 3px #0000001a;padding:24px}.form-group{margin-bottom:20px}.form-group label{color:#374151;display:block;font-size:14px;font-weight:600;margin-bottom:8px}.form-input,.form-textarea{border:2px solid #e5e7eb;border-radius:8px;font-family:inherit;font-size:14px;padding:12px 16px;transition:all .2s ease;width:100%}.form-textarea{min-height:120px;resize:vertical}.form-input:focus,.form-textarea:focus{border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a;outline:none}.form-input.error,.form-textarea.error{border-color:#ef4444;box-shadow:0 0 0 3px #ef44441a}.error-message{color:#ef4444;display:block;font-size:12px;margin-top:4px}.submit-button{background:linear-gradient(135deg,#3b82f6,#2563eb);border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:16px;font-weight:600;padding:14px 24px;transition:all .2s ease;width:100%}.submit-button:hover{background:linear-gradient(135deg,#2563eb,#1d4ed8);box-shadow:0 4px 12px #3b82f64d;transform:translateY(-2px)}.requests-history{background:#fff;border-radius:16px;box-shadow:0 1px 3px #0000001a;padding:24px}.requests-history h3{color:#1e293b;font-size:20px;font-weight:700;margin:0 0 20px}.no-requests{color:#64748b;padding:40px;text-align:center}.requests-list{display:flex;flex-direction:column;gap:16px}.request-card{background:#f8fafc;border:1px solid #e5e7eb;border-radius:12px;padding:20px;transition:all .2s ease}.request-card:hover{box-shadow:0 4px 12px #0000001a;transform:translateY(-2px)}.request-header-row{align-items:center;display:flex;justify-content:space-between;margin-bottom:16px}.request-info{align-items:center;display:flex;gap:12px}.request-id{color:#1e293b;font-size:14px;font-weight:600}.request-date{color:#64748b;font-size:12px}.request-details{display:flex;gap:24px;margin-bottom:12px}.detail-item{display:flex;gap:8px}.detail-label{color:#64748b;font-size:14px;font-weight:500}.detail-value{color:#1e293b;font-size:14px;font-weight:600}.request-reason{border-top:1px solid #e5e7eb;margin-top:12px;padding-top:12px}.reason-label{color:#64748b;display:block;font-size:12px;font-weight:600;margin-bottom:8px;text-transform:uppercase}.request-reason p{color:#475569;font-size:14px;line-height:1.6;margin:0}.request-review-date{border-top:1px solid #e5e7eb;color:#64748b;font-size:12px;margin-top:12px;padding-top:12px}.status-badge.approved{background:#d1fae5;color:#065f46}.status-badge.rejected{background:#fee2e2;color:#991b1b}@media (max-width:768px){.current-seat-info-card{flex-direction:column;gap:16px}.request-header-row{align-items:flex-start}.request-details,.request-header-row{flex-direction:column;gap:12px}}.payment-history{margin:0 auto;max-width:1400px}.payment-header{background:#fff;border-radius:16px;box-shadow:0 1px 3px #0000001a;margin-bottom:24px;padding:24px}.payment-header h2{color:#1e293b;font-size:24px;font-weight:700;margin:0 0 8px}.payment-header p{color:#64748b;font-size:14px;margin:0}.payment-summary{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));margin-bottom:24px}.summary-card{background:#fff;box-shadow:0 1px 3px #0000001a;gap:16px;padding:20px}.summary-card,.summary-icon{align-items:center;border-radius:12px;display:flex}.summary-icon{background:linear-gradient(135deg,#dbeafe,#bfdbfe);flex-shrink:0;font-size:32px;height:56px;justify-content:center;width:56px}.summary-content{display:flex;flex-direction:column;gap:4px}.summary-content label{color:#64748b;font-size:12px;font-weight:600;letter-spacing:.5px;text-transform:uppercase}.summary-amount,.summary-count{color:#1e293b;font-size:24px;font-weight:800}.payment-filters{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:24px}.filter-btn{background:#fff;border:2px solid #e5e7eb;border-radius:8px;color:#64748b;cursor:pointer;font-size:14px;font-weight:600;padding:8px 16px;transition:all .2s ease}.filter-btn:hover{border-color:#3b82f6;color:#3b82f6}.filter-btn.active{background:#3b82f6;border-color:#3b82f6;color:#fff}.payments-list{background:#fff;border-radius:16px;box-shadow:0 1px 3px #0000001a;padding:24px}.no-payments{color:#64748b;padding:40px;text-align:center}.payments-table-container{overflow-x:auto}.payments-table{border-collapse:collapse;width:100%}.payments-table thead{background:#f8fafc}.payments-table th{border-bottom:2px solid #e5e7eb;color:#1e293b;font-size:14px;font-weight:600;letter-spacing:.5px;padding:12px 16px;text-align:left;text-transform:uppercase}.payments-table td{border-bottom:1px solid #e5e7eb;color:#475569;font-size:14px;padding:16px}.payments-table tbody tr{transition:background .2s ease}.payments-table tbody tr:hover{background:#f8fafc}.amount-cell{color:#059669;font-weight:700}.transaction-id{color:#64748b;font-family:Courier New,monospace;font-size:12px}.action-buttons{display:flex;flex-wrap:wrap;gap:12px}.action-btn,.action-buttons{align-items:center;justify-content:center}.action-btn{border:none;color:#fff;cursor:pointer;display:inline-flex;font-size:14px;font-weight:600;gap:6px;padding:10px 20px;white-space:nowrap}.action-btn.btn-primary{background:#0000;border:2px solid #3b82f6;border-radius:8px;color:#3b82f6;transition:all .25s ease}.action-btn.btn-primary:hover{background:#3b82f61a;box-shadow:0 4px 12px #3b82f633;color:#000;transform:translateY(-2px)}.action-btn.btn-primary:hover svg{stroke:#000}.action-btn.btn-primary:active{background:#3b82f633;color:#000;transform:translateY(0)}.action-btn.btn-primary:active svg{stroke:#000}.action-btn.download-btn{background:#0000;border:2px solid #10b981;border-radius:8px;color:#10b981;transition:all .25s ease}.action-btn.download-btn:hover{background:#10b9811a;box-shadow:0 4px 12px #10b98133;color:#000;transform:translateY(-2px)}.action-btn.download-btn:hover svg{stroke:#000}.action-btn.download-btn:active{background:#10b98133;color:#000;transform:translateY(0)}.action-btn.download-btn:active svg{stroke:#000}.action-btn svg{stroke-width:2;flex-shrink:0;height:16px;width:16px}.status-badge{border-radius:12px;display:inline-block;font-size:11px;font-weight:600;padding:4px 12px;text-transform:uppercase}.status-badge.COMPLETED{background:#d1fae5;color:#065f46}.status-badge.pending{background:#fef3c7;color:#92400e}.status-badge.failed{background:#fee2e2;color:#991b1b}@media (max-width:768px){.payment-summary{grid-template-columns:1fr}.payments-table-container{overflow-x:scroll}.payments-table{min-width:600px}.action-buttons{flex-direction:column;gap:8px;width:100%}.action-btn{font-size:13px;min-width:auto;padding:12px 16px;width:100%}}@media (max-width:480px){.action-btn{font-size:12px;gap:6px;padding:10px 14px}.action-btn svg{height:16px;width:16px}}.toast-container{display:flex;flex-direction:column;gap:12px;max-width:400px;pointer-events:none;position:fixed;right:20px;top:20px;width:100%;z-index:10000}.toast{align-items:center;animation:slideInRight .3s ease-out,fadeOut .3s ease-in 2.7s forwards;background:#fff;border-radius:12px;box-shadow:0 10px 40px #00000026,0 2px 8px #0000001a;cursor:pointer;display:flex;gap:12px;overflow:hidden;padding:16px 20px;pointer-events:auto;position:relative;transition:transform .2s ease,box-shadow .2s ease}.toast:before{background:currentColor;bottom:0;content:"";left:0;opacity:.8;position:absolute;top:0;width:4px}.toast:hover{box-shadow:0 12px 48px #0003,0 4px 12px #00000026;transform:translateX(-4px)}.toast-icon{align-items:center;color:currentColor;display:flex;flex-shrink:0;height:24px;justify-content:center;width:24px}.toast-icon svg{height:100%;width:100%}.toast-message{color:#1f2937;flex:1 1;font-size:14px;font-weight:500;line-height:1.5}.toast-close{align-items:center;background:#0000;border:none;border-radius:4px;color:#6b7280;cursor:pointer;display:flex;flex-shrink:0;height:20px;justify-content:center;padding:0;transition:color .2s ease,transform .2s ease;width:20px}.toast-close:hover{color:#1f2937;transform:rotate(90deg)}.toast-close svg{height:16px;width:16px}.toast-success{border-left:4px solid #10b981;color:#10b981}.toast-success:before{background:#10b981}.toast-error{border-left:4px solid #ef4444;color:#ef4444}.toast-error:before{background:#ef4444}.toast-warning{border-left:4px solid #f59e0b;color:#f59e0b}.toast-warning:before{background:#f59e0b}.toast-info{border-left:4px solid #3b82f6;color:#3b82f6}.toast-info:before{background:#3b82f6}@keyframes slideInRight{0%{opacity:0;transform:translateX(100%)}to{opacity:1;transform:translateX(0)}}@keyframes fadeOut{0%{opacity:1;transform:translateX(0)}to{opacity:0;transform:translateX(100%)}}@media (max-width:768px){.toast-container{left:10px;max-width:none;right:10px;top:10px}.toast{padding:14px 16px}.toast-message{font-size:13px}}.App{position:relative;width:100%}.App,.layout{min-height:100vh}.layout,.topbar{display:flex}.topbar{align-items:center;background:#0b5ed7;border-bottom:1px solid #0a58ca;box-shadow:0 1px 2px #0003;color:#fff;gap:12px;height:56px;padding:0 12px;position:-webkit-sticky;position:sticky;top:0;z-index:50}.topbar-title{flex:1 1;font-size:22px;font-weight:800;letter-spacing:.2px;text-align:left}.topbar-user{gap:10px;position:relative}.avatar,.topbar-user{align-items:center;display:inline-flex}.avatar{background:#ffffff40;border-radius:9999px;color:#fff;font-weight:700;height:32px;justify-content:center;width:32px}.user-meta{display:flex;flex-direction:column;line-height:1.1}.user-name{font-weight:700}.user-role{font-size:12px;opacity:.9}.user-menu{align-items:center;background:#ffffff26;border:1px solid #fff3;border-radius:8px;color:#fff;cursor:pointer;display:inline-flex;height:32px;justify-content:center;padding:0;width:32px}.user-dropdown{background:#fff;border:1px solid #e5e7eb;border-radius:10px;box-shadow:0 12px 24px #02061726;color:#0f172a;min-width:180px;padding:6px;position:absolute;right:0;top:44px;z-index:60}.dropdown-user-info{background:#f8fafc;border-radius:8px;margin-bottom:8px;padding:12px 16px}.dropdown-user-name{color:#1e293b;font-size:14px;font-weight:600;margin-bottom:2px}.dropdown-user-email{color:#64748b;font-size:12px}.dropdown-item{background:#0000;border:none;border-radius:8px;cursor:pointer;padding:10px;text-align:left;width:100%}.dropdown-item:hover{background:#f1f5f9}.dropdown-item.danger{color:#b91c1c}.dropdown-sep{background:#e5e7eb;height:1px;margin:6px 0}.sidebar-toggle{align-items:center;background:#ffffff26;border:1px solid #fff3;border-radius:8px;color:#fff;cursor:pointer;display:inline-flex;height:36px;justify-content:center;padding:0;transition:background .15s ease,border-color .15s ease;width:36px}.sidebar-toggle:hover{background:#ffffff40;border-color:#ffffff59}.mobile-only{display:none}.sidebar{background:#0f172a;border-right:1px solid #111827;color:#e2e8f0;height:calc(100vh - 56px);padding:16px 12px;position:-webkit-sticky;position:sticky;top:56px;transition:width .2s ease,padding .2s ease,transform .2s ease;width:240px;z-index:40}.sidebar.collapsed{padding:16px 8px;width:64px}.sidebar.open{transform:translateX(0)}.sidebar-backdrop{display:none;z-index:30}.sidebar-header{align-items:center;display:flex;gap:8px;justify-content:space-between;margin-bottom:12px}.sidebar-title{color:#94a3b8;font-size:13px;font-weight:700;letter-spacing:.08em;text-transform:uppercase}.sidebar.collapsed .sidebar-title-text{display:none}.sidebar-nav{display:flex;flex-direction:column;gap:8px}.nav-item{align-items:center;background:#0000;border:1px solid #0000;border-radius:8px;color:#cbd5e1;cursor:pointer;display:flex;font-weight:600;gap:10px;padding:10px 12px;text-align:left;transition:background .15s ease,color .15s ease}.nav-item:hover{background:#111827;color:#e5e7eb}.nav-item.active{background:linear-gradient(180deg,#111827,#0b1220);border-color:#1f2937;color:#fff;position:relative}.nav-item.active:before{background:#2563eb;border-radius:2px;bottom:8px;content:"";left:0;position:absolute;top:8px;width:3px}.nav-icon{display:inline-flex}.sidebar.collapsed .nav-label{display:none}.sidebar.collapsed .nav-item{justify-content:center;padding:10px}.content{background:#f1f5f9;flex:1 1;overflow:auto;padding:20px}.with-topbar{padding-top:12px}@media (max-width:768px){.user-meta{display:none}.layout{flex-direction:column}.mobile-only{display:inline-flex}.sidebar{height:calc(100vh - 56px);left:0;position:fixed;top:56px;transform:translateX(-100%);width:260px}.sidebar.open{transform:translateX(0)}.sidebar.collapsed{padding:16px 12px;width:260px}.sidebar-backdrop{background:#02061780;display:block;inset:56px 0 0 0;opacity:0;pointer-events:none;position:fixed;transition:opacity .2s ease}.sidebar-backdrop.show{opacity:1;pointer-events:auto}}
/*# sourceMappingURL=main.fa78894b.css.map*/