.dashboard{display:flex;height:100vh;overflow:hidden}.dashboard-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100vh;gap:1rem;color:var(--color-text-secondary)}.dashboard-loading__spinner{width:40px;height:40px;border:3px solid var(--color-border);border-top-color:var(--color-primary);border-radius:50%;animation:spin .8s linear infinite}.dashboard__sidebar{width:260px;background:var(--color-surface);border-right:1px solid var(--color-border);display:flex;flex-direction:column;flex-shrink:0}.dashboard__logo{display:flex;align-items:center;gap:.75rem;padding:1.25rem 1.5rem;border-bottom:1px solid var(--color-border)}.dashboard__logo-icon{width:36px;height:36px;flex-shrink:0;background:linear-gradient(135deg,var(--color-primary),#8b5cf6);border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;font-weight:700;font-size:.875rem;color:#fff}.dashboard__logo-icon--image{padding:0;overflow:hidden;background:var(--color-surface-elevated);border:1px solid var(--color-border)}.dashboard__logo-icon--image img{width:100%;height:100%;object-fit:cover;display:block}.dashboard__logo-text{font-size:1.125rem;font-weight:600}.dashboard__nav{flex:1;padding:1rem .75rem;display:flex;flex-direction:column;gap:.25rem}.dashboard__nav-item{display:flex;align-items:center;gap:.75rem;padding:.75rem 1rem;border-radius:var(--radius-md);color:var(--color-text-secondary);font-size:.9375rem;font-weight:500;transition:all var(--transition)}.dashboard__nav-item:hover{background:var(--color-surface-elevated);color:var(--color-text)}.dashboard__nav-item--active{background:#6366f11a;color:var(--color-primary)}.dashboard__nav-item--active:hover{background:#6366f126;color:var(--color-primary)}.dashboard__nav-icon{width:20px;height:20px;flex-shrink:0}.dashboard__sidebar-footer{padding:1rem;border-top:1px solid var(--color-border);display:flex;align-items:center;gap:.75rem}.dashboard__user{flex:1;display:flex;align-items:center;gap:.75rem;min-width:0}.dashboard__user-avatar{width:36px;height:36px;background:var(--color-primary);border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:600;font-size:.875rem;color:#fff;flex-shrink:0}.dashboard__user-avatar--image{padding:0;overflow:hidden;background:var(--color-surface-elevated);border:1px solid var(--color-border)}.dashboard__user-avatar--image img{width:100%;height:100%;object-fit:cover;display:block}.dashboard__user-info{display:flex;flex-direction:column;min-width:0}.dashboard__user-name{font-size:.875rem;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.dashboard__user-email{font-size:.75rem;color:var(--color-text-secondary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.dashboard__logout{width:36px;height:36px;background:transparent;border:none;border-radius:var(--radius-md);color:var(--color-text-secondary);display:flex;align-items:center;justify-content:center;transition:all var(--transition);flex-shrink:0}.dashboard__logout:hover{background:var(--color-surface-elevated);color:var(--color-error)}.dashboard__logout svg{width:20px;height:20px}.dashboard__main{flex:1;overflow-y:auto;padding:2rem;background:var(--color-bg)}@media(max-width:768px){.dashboard__sidebar{width:72px}.dashboard__logo-text,.dashboard__nav-item span,.dashboard__user-info{display:none}.dashboard__nav-item{justify-content:center;padding:.75rem}.dashboard__sidebar-footer{flex-direction:column;gap:.5rem}.dashboard__main{padding:1rem}}:root{--color-bg: #0f0f0f;--color-surface: #1a1a1a;--color-surface-elevated: #242424;--color-border: #333;--color-text: #f5f5f5;--color-text-secondary: #a0a0a0;--color-placeholder: rgba(245, 245, 245, .38);--color-primary: #6366f1;--color-primary-hover: #818cf8;--color-success: #22c55e;--color-warning: #f59e0b;--color-error: #ef4444;--radius-sm: 4px;--radius-md: 8px;--radius-lg: 12px;--shadow-sm: 0 1px 2px rgba(0, 0, 0, .3);--shadow-md: 0 4px 6px rgba(0, 0, 0, .3);--transition: .15s ease}[data-theme=light]{--color-bg: #f5f5f5;--color-surface: #ffffff;--color-surface-elevated: #fafafa;--color-border: #e5e5e5;--color-text: #171717;--color-text-secondary: #737373;--color-placeholder: rgba(23, 23, 23, .4)}*{box-sizing:border-box;margin:0;padding:0}html,body{height:100%}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,sans-serif;background:var(--color-bg);color:var(--color-text);line-height:1.5}#root{height:100%}a{color:var(--color-primary);text-decoration:none}a:hover{color:var(--color-primary-hover)}button{cursor:pointer;font-family:inherit}input,select,textarea{font-family:inherit}.page-fallback{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;gap:1rem;color:var(--color-text-secondary)}.page-fallback__spinner{width:32px;height:32px;border:3px solid var(--color-border);border-top-color:var(--color-primary);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.btn{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;padding:.625rem 1rem;font-size:.875rem;font-weight:500;border-radius:var(--radius-md);border:none;transition:all var(--transition)}.btn--primary{background:var(--color-primary);color:#fff}.btn--primary:hover:not(:disabled){background:var(--color-primary-hover)}.btn--secondary{background:var(--color-surface-elevated);color:var(--color-text);border:1px solid var(--color-border)}.btn--secondary:hover:not(:disabled){background:var(--color-border)}.btn--danger{background:var(--color-error);color:#fff}.btn--danger:hover:not(:disabled){background:#dc2626}.btn--ghost{background:transparent;color:var(--color-text-secondary)}.btn--ghost:hover:not(:disabled){background:var(--color-surface-elevated);color:var(--color-text)}.btn:disabled{opacity:.5;cursor:not-allowed}.btn--sm{padding:.375rem .75rem;font-size:.8125rem}.btn--lg{padding:.75rem 1.5rem;font-size:1rem}.form-group{display:flex;flex-direction:column;gap:.375rem}.form-label{font-size:.875rem;font-weight:500;color:var(--color-text)}.form-input,.form-select,.form-textarea{padding:.625rem .75rem;font-size:.875rem;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-text);transition:border-color var(--transition)}.form-input:focus,.form-select:focus,.form-textarea:focus{outline:none;border-color:var(--color-primary)}.form-input::placeholder,.form-select::placeholder,.form-textarea::placeholder{color:var(--color-placeholder);opacity:1}.form-error{font-size:.8125rem;color:var(--color-error)}.form-hint{display:block;margin-top:.35rem;font-size:.8125rem;color:var(--color-text-secondary)}.card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:1.5rem}.card__header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1rem}.card__title{font-size:1.125rem;font-weight:600}.table-container{overflow-x:auto}.table{width:100%;border-collapse:collapse}.table th,.table td{padding:.75rem 1rem;text-align:left;border-bottom:1px solid var(--color-border)}.table th{font-size:.8125rem;font-weight:600;color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.05em}.table tbody tr:hover{background:var(--color-surface-elevated)}.badge{display:inline-flex;align-items:center;padding:.25rem .625rem;font-size:.75rem;font-weight:500;border-radius:9999px}.badge--success{background:#22c55e26;color:var(--color-success)}.badge--warning{background:#f59e0b26;color:var(--color-warning)}.badge--error{background:#ef444426;color:var(--color-error)}.badge--info{background:#6366f126;color:var(--color-primary)}.text-secondary{color:var(--color-text-secondary)}.text-success{color:var(--color-success)}.text-warning{color:var(--color-warning)}.text-error{color:var(--color-error)}.mt-1{margin-top:.25rem}.mt-2{margin-top:.5rem}.mt-3{margin-top:.75rem}.mt-4{margin-top:1rem}.mb-1{margin-bottom:.25rem}.mb-2{margin-bottom:.5rem}.mb-3{margin-bottom:.75rem}.mb-4{margin-bottom:1rem}
