.layout{display:flex;min-height:100vh}.sidebar{position:fixed;top:0;left:0;bottom:0;width:var(--sidebar-width);background-color:var(--color-bg-dark);color:#fff;display:flex;flex-direction:column;z-index:30}.sidebar-header{display:flex;align-items:center;justify-content:space-between;height:64px;padding:0 1rem;background-color:#1f2937}.sidebar-title{font-size:1.25rem;font-weight:600}.sidebar-nav{flex:1;padding:1rem .5rem}.nav-link{display:flex;align-items:center;padding:.75rem 1rem;margin-bottom:.25rem;border-radius:.5rem;color:#d1d5db;transition:background-color .15s,color .15s}.nav-link:hover{background-color:#374151;color:#fff}.nav-link.active{background-color:var(--color-primary);color:#fff}.nav-link svg{width:1.25rem;height:1.25rem;margin-right:.75rem}.sidebar-footer{padding:1rem;border-top:1px solid #374151}.admin-info{padding:.5rem;margin-bottom:.75rem}.admin-name{font-size:.875rem;font-weight:500;color:#fff}.admin-role{font-size:.75rem;color:#9ca3af}.logout-btn{display:flex;align-items:center;width:100%;padding:.5rem 1rem;background:none;border:none;color:#d1d5db;border-radius:.5rem;transition:background-color .15s,color .15s}.logout-btn:hover{background-color:#374151;color:#fff}.logout-btn svg{width:1.25rem;height:1.25rem;margin-right:.75rem}.main-content{flex:1;margin-left:var(--sidebar-width)}.top-bar{position:sticky;top:0;height:64px;background-color:#fff;box-shadow:0 1px 3px #0000001a;z-index:10}.page-content{padding:1.5rem}.mobile-menu-btn{display:none}@media (max-width: 1024px){.sidebar{transform:translate(-100%)}.sidebar.open{transform:translate(0)}.main-content{margin-left:0}.mobile-menu-btn{display:flex;align-items:center;justify-content:center;padding:.5rem;background:none;border:none;color:var(--color-text-light)}.sidebar-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background-color:#00000080;z-index:20}}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background-color:var(--color-bg-dark);padding:1rem}.login-container{width:100%;max-width:400px}.login-header{text-align:center;margin-bottom:2rem}.login-icon{width:48px;height:48px;display:flex;align-items:center;justify-content:center;background-color:var(--color-primary);border-radius:50%;margin:0 auto 1.5rem}.login-icon svg{width:24px;height:24px;color:#fff}.login-title{font-size:1.875rem;font-weight:800;color:#fff;margin-bottom:.5rem}.login-subtitle{font-size:.875rem;color:#9ca3af}.login-form{display:flex;flex-direction:column;gap:1.5rem}.login-error{padding:.75rem 1rem;background-color:#ef44441a;border:1px solid var(--color-error);border-radius:.5rem;color:var(--color-error);font-size:.875rem}.form-group{display:flex;flex-direction:column;gap:.25rem}.form-label{font-size:.875rem;font-weight:500;color:#d1d5db}.login-form .form-input{padding:.625rem .75rem!important;background-color:#1f2937!important;border:1px solid #374151!important;border-radius:.5rem!important;color:#fff!important;font-size:1rem!important;transition:border-color .15s,box-shadow .15s}.login-form .form-input::placeholder{color:#6b7280}.login-form .form-input:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px #4f46e533}.login-btn{width:100%;padding:.75rem 1rem;background-color:var(--color-primary);border:none;border-radius:.5rem;color:#fff;font-size:.875rem;font-weight:500;transition:background-color .15s}.login-btn:hover:not(:disabled){background-color:var(--color-primary-hover)}.login-btn:disabled{opacity:.5;cursor:not-allowed}.dashboard{display:flex;flex-direction:column;gap:1.5rem}.page-title{font-size:1.5rem;font-weight:700;color:var(--color-text)}.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1.5rem}@media (max-width: 1200px){.stats-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width: 640px){.stats-grid{grid-template-columns:1fr}}.stat-card{background-color:var(--color-bg-card);border-radius:.5rem;box-shadow:0 1px 3px #0000001a;padding:1.5rem;display:flex;align-items:center}.stat-icon{width:48px;height:48px;display:flex;align-items:center;justify-content:center;border-radius:.5rem;margin-right:1rem}.stat-icon svg{width:24px;height:24px;color:#fff}.stat-icon.blue{background-color:#3b82f6}.stat-icon.green{background-color:#10b981}.stat-icon.purple{background-color:#8b5cf6}.stat-icon.orange{background-color:#f97316}.stat-content{flex:1}.stat-label{font-size:.875rem;color:var(--color-text-light);margin-bottom:.25rem}.stat-value{font-size:1.5rem;font-weight:600;color:var(--color-text)}.card{background-color:var(--color-bg-card);border-radius:.5rem;box-shadow:0 1px 3px #0000001a;padding:1.5rem}.card-title{font-size:1.125rem;font-weight:600;color:var(--color-text);margin-bottom:1rem}.chart-container{height:256px}.two-col-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1.5rem}@media (max-width: 1024px){.two-col-grid{grid-template-columns:1fr}}.list-item{display:flex;align-items:center;justify-content:space-between;padding:.75rem 0;border-bottom:1px solid var(--color-border)}.list-item:last-child{border-bottom:none}.list-item-label{font-size:.875rem;color:var(--color-text-light)}.list-item-value{font-size:.875rem;font-weight:500;color:var(--color-text)}.loading-container{display:flex;align-items:center;justify-content:center;height:256px}.page-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1.5rem}.page-header-title{font-size:1.5rem;font-weight:700;color:var(--color-text)}.page-header-subtitle{font-size:.875rem;color:var(--color-text-light)}.search-form{display:flex;gap:.5rem;margin-bottom:1.5rem}.search-input-wrapper{position:relative;flex:1;max-width:400px}.search-input-wrapper svg{position:absolute;left:.75rem;top:50%;transform:translateY(-50%);width:1rem;height:1rem;color:var(--color-text-light)}.search-input{width:100%;padding:.5rem .75rem .5rem 2.5rem;border:1px solid var(--color-border);border-radius:.5rem;font-size:.875rem}.search-input:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px #4f46e51a}.search-btn{padding:.5rem 1rem;background-color:var(--color-primary);border:none;border-radius:.5rem;color:#fff;font-size:.875rem;font-weight:500}.search-btn:hover{background-color:var(--color-primary-hover)}.table-container{background-color:var(--color-bg-card);border-radius:.5rem;box-shadow:0 1px 3px #0000001a;overflow:hidden}.table{width:100%;border-collapse:collapse}.table th{padding:.75rem 1.5rem;text-align:left;font-size:.75rem;font-weight:500;text-transform:uppercase;letter-spacing:.05em;color:var(--color-text-light);background-color:#f9fafb;border-bottom:1px solid var(--color-border)}.table td{padding:1rem 1.5rem;font-size:.875rem;border-bottom:1px solid var(--color-border)}.table tbody tr:hover{background-color:#f9fafb}.table tbody tr:last-child td{border-bottom:none}.cell-main{font-weight:500;color:var(--color-text)}.cell-sub{font-size:.875rem;color:var(--color-text-light)}.badge{display:inline-flex;padding:.25rem .5rem;font-size:.75rem;font-weight:600;border-radius:9999px}.badge.green{background-color:#d1fae5;color:#065f46}.badge.red{background-color:#fee2e2;color:#991b1b}.badge.blue{background-color:#dbeafe;color:#1e40af}.badge.yellow{background-color:#fef3c7;color:#92400e}.badge.purple{background-color:#ede9fe;color:#5b21b6}.badge.gray{background-color:#f3f4f6;color:#4b5563}.action-btn{padding:.25rem;background:none;border:none;border-radius:.25rem;color:var(--color-text-light);transition:color .15s}.action-btn:hover{color:var(--color-text)}.action-btn.green:hover{color:var(--color-success)}.action-btn.red:hover{color:var(--color-error)}.action-btn.blue:hover,.action-btn.primary:hover{color:var(--color-primary)}.action-btn svg{width:1.25rem;height:1.25rem}.actions-cell{display:flex;justify-content:flex-end;gap:.5rem}.pagination{display:flex;align-items:center;justify-content:space-between;padding:.75rem 1rem;border-top:1px solid var(--color-border)}.pagination-info{font-size:.875rem;color:var(--color-text-light)}.pagination-buttons{display:flex;gap:.5rem}.pagination-btn{padding:.25rem .75rem;background:none;border:1px solid var(--color-border);border-radius:.5rem;display:flex;align-items:center;justify-content:center}.pagination-btn:hover:not(:disabled){background-color:#f9fafb}.pagination-btn:disabled{opacity:.5;cursor:not-allowed}.pagination-btn svg{width:1.25rem;height:1.25rem}.empty-state{padding:3rem;text-align:center;color:var(--color-text-light)}.select{padding:.5rem .75rem;border:1px solid var(--color-border);border-radius:.5rem;font-size:.875rem;background-color:#fff}.select:focus{outline:none;border-color:var(--color-primary)}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background-color:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000}.modal{background:#fff;border-radius:.75rem;width:100%;max-width:480px;box-shadow:0 20px 25px -5px #0000001a}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.5rem;border-bottom:1px solid var(--color-border)}.modal-header h2{font-size:1.125rem;font-weight:600;margin:0}.modal-close{background:none;border:none;color:var(--color-text-light);padding:.25rem;border-radius:.25rem}.modal-close:hover{color:var(--color-text)}.modal-body{padding:1.5rem}.modal-footer{display:flex;justify-content:flex-end;gap:.75rem;padding:1rem 1.5rem;border-top:1px solid var(--color-border)}.form-group{margin-bottom:1rem}.form-group label{display:block;font-size:.875rem;font-weight:500;margin-bottom:.5rem;color:var(--color-text)}.form-input,.form-select{width:100%;padding:.5rem .75rem;border:1px solid var(--color-border);border-radius:.5rem;font-size:.875rem;background-color:#fff}.form-input:focus,.form-select:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px #4f46e51a}.btn{padding:.5rem 1rem;border-radius:.5rem;font-size:.875rem;font-weight:500;border:none;cursor:pointer;transition:background-color .15s}.btn-primary:hover:not(:disabled){background-color:var(--color-primary-hover)}.btn-primary:disabled{opacity:.6;cursor:not-allowed}.btn-secondary{background-color:#f3f4f6;color:var(--color-text)}.btn-secondary:hover{background-color:#e5e7eb}.confirm-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background-color:#00000080;display:flex;align-items:center;justify-content:center;z-index:1100;animation:fadeIn .15s ease-out}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.confirm-dialog{background:#fff;border-radius:.75rem;width:100%;max-width:400px;padding:1.5rem;text-align:center;box-shadow:0 20px 25px -5px #00000026;animation:slideUp .2s ease-out}@keyframes slideUp{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.confirm-icon{width:48px;height:48px;border-radius:50%;display:flex;align-items:center;justify-content:center;margin:0 auto 1rem}.confirm-title{font-size:1.125rem;font-weight:600;color:var(--color-text);margin-bottom:.5rem}.confirm-message{font-size:.875rem;color:var(--color-text-light);margin-bottom:1.5rem;line-height:1.5}.confirm-actions{display:flex;gap:.75rem;justify-content:center}.confirm-btn{padding:.5rem 1.25rem;border-radius:.5rem;font-size:.875rem;font-weight:500;border:none;cursor:pointer;transition:opacity .15s,transform .1s}.confirm-btn:hover:not(:disabled){opacity:.9}.confirm-btn:active:not(:disabled){transform:scale(.98)}.confirm-btn:disabled{opacity:.6;cursor:not-allowed}.confirm-btn-cancel{background-color:#f3f4f6;color:var(--color-text)}.confirm-btn-cancel:hover:not(:disabled){background-color:#e5e7eb}.confirm-btn-confirm{color:#fff}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background-color:#00000080;display:flex;align-items:center;justify-content:center;z-index:50;padding:1rem}.modal{background-color:var(--color-bg-card);border-radius:.5rem;box-shadow:0 25px 50px #00000040;width:100%;max-width:28rem;padding:1.5rem}.modal-title{font-size:1.125rem;font-weight:600;color:var(--color-text);margin-bottom:1.5rem}.modal-form{display:flex;flex-direction:column;gap:1rem}.modal-form .form-group{display:flex;flex-direction:column;gap:.25rem}.modal-form .form-label{font-size:.875rem;font-weight:500;color:var(--color-text)}.modal-form .form-input{padding:.5rem .75rem;border:1px solid var(--color-border);border-radius:.5rem;font-size:.875rem;background-color:#fff;color:var(--color-text)}.modal-form .form-input:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px #4f46e51a}.modal-actions{display:flex;justify-content:flex-end;gap:.75rem;margin-top:1.5rem}.btn{padding:.5rem 1rem;border-radius:.5rem;font-size:.875rem;font-weight:500;border:none;transition:background-color .15s}.btn-secondary{background-color:#fff;border:1px solid var(--color-border);color:var(--color-text)}.btn-secondary:hover{background-color:#f9fafb}.btn-primary{background-color:var(--color-primary);color:#fff}.btn-primary:hover{background-color:var(--color-primary-hover)}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--color-primary: #4f46e5;--color-primary-hover: #4338ca;--color-bg: #f9fafb;--color-bg-dark: #111827;--color-bg-card: #ffffff;--color-text: #111827;--color-text-light: #6b7280;--color-border: #e5e7eb;--color-success: #10b981;--color-warning: #f59e0b;--color-error: #ef4444;--sidebar-width: 256px}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,sans-serif;background-color:var(--color-bg);color:var(--color-text);line-height:1.5}a{color:inherit;text-decoration:none}button{cursor:pointer;font-family:inherit}input,select{font-family:inherit}.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-center{justify-content:center}.justify-between{justify-content:space-between}.gap-2{gap:.5rem}.gap-4{gap:1rem}.gap-6{gap:1.5rem}.text-sm{font-size:.875rem}.text-lg{font-size:1.125rem}.text-xl{font-size:1.25rem}.text-2xl{font-size:1.5rem}.text-3xl{font-size:1.875rem}.font-medium{font-weight:500}.font-semibold{font-weight:600}.font-bold{font-weight:700}.rounded{border-radius:.375rem}.rounded-lg{border-radius:.5rem}.rounded-full{border-radius:9999px}.shadow{box-shadow:0 1px 3px #0000001a}.shadow-lg{box-shadow:0 10px 15px #0000001a}.spinner{width:2rem;height:2rem;border:2px solid var(--color-border);border-top-color:var(--color-primary);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}
