.sidebar{position:fixed;left:0;top:0;bottom:0;width:260px;background:linear-gradient(180deg,#1e293b,#0f172a);color:#fff;display:none;flex-direction:column;z-index:200;box-shadow:2px 0 8px #0000001a}@media (min-width: 1024px){.sidebar{display:flex}}.sidebar-header{padding:1.5rem;border-bottom:1px solid rgba(255,255,255,.1)}.sidebar-logo{display:flex;align-items:center;justify-content:center;color:#fff}.sidebar-logo-img{height:40px;width:auto;max-width:100%}.sidebar-nav{flex:1;padding:1rem;overflow-y:auto}.sidebar-nav-item{width:100%;display:flex;align-items:center;gap:.75rem;padding:.75rem 1rem;border:none;background:none;color:#ffffffb3;border-radius:.5rem;cursor:pointer;transition:all .2s;font-family:inherit;font-size:.95rem;text-align:left;margin-bottom:.25rem}.sidebar-nav-item:hover{background:#ffffff1a;color:#fff}.sidebar-nav-item.active{background:#2563eb33;color:#fff;border-left:3px solid #2563eb}.sidebar-nav-item svg{flex-shrink:0}.sidebar-footer{padding:1rem;border-top:1px solid rgba(255,255,255,.1)}.sidebar-user{display:flex;align-items:center;gap:.75rem;padding:.75rem;background:#ffffff0d;border-radius:.5rem;margin-bottom:.75rem}.sidebar-user-avatar{width:40px;height:40px;border-radius:50%;background:#2563eb4d;display:flex;align-items:center;justify-content:center;color:#fff;flex-shrink:0}.sidebar-user-info{flex:1;min-width:0}.sidebar-user-name{font-size:.875rem;font-weight:600;color:#fff;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sidebar-user-email{font-size:.75rem;color:#fff9;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sidebar-logout{width:100%;display:flex;align-items:center;gap:.75rem;padding:.75rem 1rem;border:none;background:#ef444433;color:#fca5a5;border-radius:.5rem;cursor:pointer;transition:all .2s;font-family:inherit;font-size:.95rem}.sidebar-logout:hover{background:#ef44444d;color:#fff}.sidebar-logout svg{flex-shrink:0}.sidebar-nav::-webkit-scrollbar{width:6px}.sidebar-nav::-webkit-scrollbar-track{background:transparent}.sidebar-nav::-webkit-scrollbar-thumb{background:#fff3;border-radius:3px}.sidebar-nav::-webkit-scrollbar-thumb:hover{background:#ffffff4d}.app-container{min-height:100vh;display:flex;flex-direction:column;width:100%;max-width:100%;overflow-x:hidden;box-sizing:border-box}.app-with-sidebar{margin-left:260px}@media (max-width: 1023px){.app-with-sidebar{margin-left:0}}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.fade-in{animation:fadeIn .3s ease-in-out}.loading-spinner{border:3px solid var(--border-color);border-top:3px solid var(--primary-color);border-radius:50%;width:40px;height:40px;animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}:root{--primary-color: #2563eb;--primary-dark: #1e40af;--secondary-color: #64748b;--success-color: #10b981;--warning-color: #f59e0b;--error-color: #ef4444;--bg-color: #f8fafc;--surface-color: #ffffff;--text-primary: #1e293b;--text-secondary: #64748b;--border-color: #e2e8f0;--shadow: 0 1px 3px rgba(0, 0, 0, .1);--shadow-lg: 0 10px 25px rgba(0, 0, 0, .1);--mobile: 480px;--tablet: 768px;--desktop: 1024px;--wide: 1440px}*{margin:0;padding:0;box-sizing:border-box}html{font-size:16px}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,sans-serif;background-color:var(--bg-color);color:var(--text-primary);line-height:1.6;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;overflow-x:hidden}#root{min-height:100vh}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:var(--bg-color)}::-webkit-scrollbar-thumb{background:var(--border-color);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:var(--secondary-color)}@media (max-width: 480px){html{font-size:14px}}@media (min-width: 769px){html{font-size:16px}}@media (min-width: 1024px){html{font-size:16px}}.container{width:100%;max-width:1200px;margin:0 auto;padding:0 1rem}@media (min-width: 769px){.container{padding:0 2rem}}@media (hover: none) and (pointer: coarse){button,a,[role=button]{min-height:44px;min-width:44px}}
