.app{min-height:100vh;display:flex;background-color:#f5f5f5}.sidebar{width:220px;background:#fff;color:#1a1a1a;display:flex;flex-direction:column;box-shadow:2px 0 10px #0000000d;border-right:1px solid #e5e7eb;position:fixed;height:100vh;left:0;top:0;z-index:1000}.sidebar-header{padding:1.5rem 1rem;border-bottom:1px solid #e5e7eb}.sidebar-title{font-size:1.25rem;font-weight:600;display:flex;align-items:center;gap:.5rem;margin:0;color:#1a1a1a}.sidebar-icon{width:20px;height:20px;display:flex;align-items:center;justify-content:center;color:inherit}.sidebar-icon svg{width:100%;height:100%}.sidebar-nav{flex:1;padding:1rem 0;overflow-y:auto}.sidebar-link{display:flex;align-items:center;gap:.75rem;padding:.75rem 1rem;color:#6b7280;text-decoration:none;transition:all .3s;border-left:3px solid transparent;position:relative}.sidebar-link:hover{background-color:#f9fafb;color:#1a1a1a}.sidebar-link.active{background-color:#f3f4f6;color:#1a1a1a;border-left-color:#667eea;font-weight:600}.sidebar-link.disabled{opacity:.5;cursor:not-allowed;color:#9ca3af}.link-icon{width:20px;height:20px;display:flex;align-items:center;justify-content:center;flex-shrink:0;color:inherit}.link-icon svg{width:100%;height:100%}.link-text{flex:1;font-size:.9rem}.badge{background-color:#e5e7eb;color:#6b7280;padding:.25rem .5rem;border-radius:12px;font-size:.75rem;font-weight:500}.sidebar-divider{height:1px;background-color:#e5e7eb;margin:.75rem 1rem}.sidebar-footer{padding:1rem;border-top:1px solid #e5e7eb}.sidebar-user{display:flex;align-items:center;gap:1rem;padding:.75rem;background-color:#f9fafb;border-radius:8px}.user-icon{width:40px;height:40px;display:flex;align-items:center;justify-content:center;background-color:#e5e7eb;border-radius:50%;color:#6b7280;flex-shrink:0}.user-icon svg{width:20px;height:20px}.user-info{display:flex;flex-direction:column;gap:.25rem}.user-name{font-size:.95rem;font-weight:600;color:#1a1a1a}.user-role{font-size:.75rem;color:#6b7280}.main-content{flex:1;margin-left:220px;padding:2rem;width:calc(100% - 220px);min-height:100vh}.page-header{margin-bottom:2rem}.page-header h2{color:#333;font-size:2rem;margin-bottom:.5rem}.page-header p{color:#666;font-size:1rem}.btn{padding:.75rem 1.5rem;border:none;border-radius:6px;font-size:1rem;font-weight:500;cursor:pointer;transition:all .3s;display:inline-flex;align-items:center;gap:.5rem}.btn-primary{background:#fff;color:#1a1a1a;border:1px solid #e5e7eb}.btn-primary:hover{background:#f9fafb;border-color:#d1d5db;box-shadow:0 1px 3px #0000001a}.btn-secondary{background-color:#fff;color:#6b7280;border:1px solid #e5e7eb}.btn-secondary:hover{background-color:#f9fafb;border-color:#d1d5db;color:#1a1a1a}.btn-success{background-color:#fff;color:#059669;border:1px solid #e5e7eb}.btn-success:hover{background-color:#f0fdf4;border-color:#86efac;color:#047857}.btn-danger{background-color:#fff;color:#dc2626;border:1px solid #e5e7eb}.btn-danger:hover{background-color:#fef2f2;border-color:#fca5a5;color:#b91c1c}.btn-small{padding:.5rem 1rem;font-size:.875rem}.card{background:#fff;border-radius:8px;padding:2rem;box-shadow:0 2px 8px #0000001a;margin-bottom:2rem}.table-container{overflow-x:auto}.table{width:100%;border-collapse:collapse;background:#fff}.table th,.table td{padding:1rem;text-align:left;border-bottom:1px solid #e0e0e0}.table th{background-color:#f8f9fa;font-weight:600;color:#333}.table tbody tr:hover{background-color:#f8f9fa}.table-actions{display:flex;gap:.5rem;align-items:center}.btn-icon{width:32px;height:32px;display:flex;align-items:center;justify-content:center;background:#fff;border:1px solid #e5e7eb;border-radius:6px;cursor:pointer;transition:all .2s;padding:0;color:#6b7280}.btn-icon:hover{background:#f9fafb;border-color:#d1d5db}.btn-icon svg{width:18px;height:18px}.btn-icon-view{color:#667eea}.btn-icon-view:hover{background:#f3f4f6;border-color:#667eea;color:#667eea}.btn-icon-edit{color:#6b7280}.btn-icon-edit:hover{background:#f3f4f6;border-color:#9ca3af;color:#1a1a1a}.btn-icon-delete{color:#dc2626}.btn-icon-delete:hover{background:#fef2f2;border-color:#fca5a5;color:#b91c1c}.form-group{margin-bottom:1.5rem}.form-group label{display:block;margin-bottom:.5rem;color:#333;font-weight:500}.form-control{width:100%;padding:.75rem;border:1px solid #ddd;border-radius:6px;font-size:1rem;transition:border-color .3s}.form-control:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000}.modal{background:#fff;border-radius:8px;padding:2rem;max-width:600px;width:90%;max-height:90vh;overflow-y:auto}.modal-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem}.modal-header h3{color:#333;font-size:1.5rem}.modal-close{background:none;border:none;font-size:1.5rem;cursor:pointer;color:#666}.modal-footer{display:flex;justify-content:flex-end;gap:1rem;margin-top:2rem}.empty-state{text-align:center;padding:3rem;color:#666}.empty-state p{margin-bottom:1.5rem;font-size:1.1rem}.loading-container{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:60vh;padding:2rem}.loading-spinner{width:48px;height:48px;border:4px solid #e5e7eb;border-top-color:#667eea;border-radius:50%;animation:spin .8s linear infinite;margin-bottom:1rem}@keyframes spin{to{transform:rotate(360deg)}}.loading-message{color:#6b7280;font-size:1rem;font-weight:500;margin:0}.loading{text-align:center;padding:2rem;color:#666}.error{background-color:#f8d7da;color:#721c24;padding:1rem;border-radius:6px;margin-bottom:1rem}@media (max-width: 768px){.sidebar{width:70px}.sidebar-title{font-size:0}.sidebar-icon{font-size:1.25rem}.link-text,.badge,.user-info{display:none}.sidebar-link{justify-content:center;padding:.75rem .5rem}.sidebar-user{justify-content:center}.main-content{margin-left:70px;width:calc(100% - 70px);padding:1rem}.form-row{grid-template-columns:1fr}.table-container{font-size:.875rem}.table th,.table td{padding:.75rem .5rem}}@media (max-width: 480px){.sidebar{width:60px}.main-content{margin-left:60px;width:calc(100% - 60px)}}*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:#f5f5f5}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}#root{min-height:100vh}
