.sidebar{display:flex;flex-direction:column;position:fixed;left:0;top:0;height:100vh;background:#fff;color:#111827;transition:width .3s ease,background-color .2s ease,color .2s ease;width:250px;box-shadow:1px 0 3px rgba(0,0,0,.08);z-index:1000;overflow-y:auto;overflow-x:hidden;border-right:1px solid #e5e7eb}html.dark .sidebar{background:#1f2937;border-right-color:#374151}.sidebar-header{display:flex;align-items:center;justify-content:space-between;padding:1.25rem 1rem;border-bottom:1px solid #e5e7eb;background:#fff;flex-shrink:0}html.dark .sidebar-header{background:#111827;border-bottom-color:#374151}.logo{margin:0;font-size:1.5rem;font-weight:700;flex:1;padding-left:.5rem;letter-spacing:-.5px;color:#111827}html.dark .logo{color:#f3f4f6}.toggle-btn{background:none;border:none;color:#6b7280;font-size:1.2rem;cursor:pointer;padding:.5rem;border-radius:6px;transition:all .2s ease;display:flex;align-items:center;justify-content:center}.toggle-btn:hover{background:#f3f4f6;color:#111827}html.dark .toggle-btn{color:#9ca3af}html.dark .toggle-btn:hover{background:#374151;color:#f3f4f6}.user-info{display:flex;align-items:center;gap:.75rem;padding:1rem;border-bottom:1px solid #e5e7eb;background:#fff}html.dark .user-info{border-bottom-color:#374151;background:#111827}.avatar{width:40px;height:40px;border-radius:8px;background:linear-gradient(135deg,#667eea,#764ba2);display:flex;align-items:center;justify-content:center;font-weight:600;font-size:1rem;flex-shrink:0;color:#fff}.user-details{flex:1;min-width:0}.user-details p{margin:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.name{font-weight:600;font-size:.9rem;color:#111827}html.dark .name{color:#f3f4f6}.role{opacity:.7;font-size:.75rem;text-transform:capitalize;color:#6b7280}html.dark .role{color:#9ca3af}.nav-menu{flex:1;overflow-y:auto;padding:.5rem;display:flex;flex-direction:column;gap:.25rem}.nav-item{display:flex;align-items:center;gap:.875rem;width:100%;padding:.75rem 1rem;background:none;border:none;color:#6b7280;font-size:.95rem;cursor:pointer;transition:all .2s ease;border-radius:6px;font-weight:500;text-align:left}.nav-item:hover{background:#f3f4f6;color:#111827}.nav-item.active{background:#dbeafe;color:#1e40af}html.dark .nav-item{color:#d1d5db}html.dark .nav-item:hover{background:#374151;color:#f3f4f6}html.dark .nav-item.active{background:#1e3a8a;color:#bfdbfe}.nav-item svg{width:20px;height:20px;flex-shrink:0}.label{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;flex:1}.sidebar.closed .label{display:none}.nav-menu::-webkit-scrollbar{width:6px}.nav-menu::-webkit-scrollbar-track{background:transparent}.nav-menu::-webkit-scrollbar-thumb{background:#d1d5db;border-radius:3px}.nav-menu::-webkit-scrollbar-thumb:hover{background:#9ca3af}html.dark .nav-menu::-webkit-scrollbar-thumb{background:#4b5563}html.dark .nav-menu::-webkit-scrollbar-thumb:hover{background:#6b7280}.sidebar-footer{padding:1rem .5rem;border-top:1px solid #e5e7eb;background:#fff;flex-shrink:0}html.dark .sidebar-footer{border-top-color:#374151;background:#111827}.logout-btn{width:100%;padding:.75rem 1rem;background:#f3f4f6;border:1px solid #e5e7eb;color:#111827;border-radius:6px;cursor:pointer;font-size:.95rem;font-weight:500;transition:all .2s ease;display:flex;align-items:center;justify-content:center;gap:.5rem}.logout-btn:hover{background:#dc2626;border-color:#dc2626;color:#fff}html.dark .logout-btn{background:#374151;border-color:#4b5563;color:#d1d5db}html.dark .logout-btn:hover{background:#dc2626;border-color:#dc2626;color:#fff}.sidebar.closed{width:80px}.sidebar.closed .sidebar-header{justify-content:center;padding:1rem .5rem}.sidebar.closed .logo{display:none}.sidebar.closed .user-info{padding:.75rem .5rem;flex-direction:column}.sidebar.closed .user-details{display:none}.sidebar.closed .avatar{width:36px;height:36px;font-size:.9rem}.sidebar.closed .nav-item{justify-content:center;padding:.75rem .5rem}.sidebar.closed .sidebar-footer{padding:.75rem .5rem}.sidebar.closed .logout-btn{padding:.75rem .5rem;aspect-ratio:1/1;display:flex;align-items:center;justify-content:center;font-size:0}main.main-content{margin-left:250px;transition:margin-left .3s ease;min-height:100vh;padding:1rem}body.sidebar-closed main.main-content{margin-left:80px}@media (max-width:768px){.sidebar{width:80px}.sidebar-header{justify-content:center;padding:1rem .5rem}.logo{display:none}.user-info{padding:.75rem .5rem;flex-direction:column}.user-details{display:none}.nav-item{justify-content:center}.logout-btn,.nav-item,.sidebar-footer{padding:.75rem .5rem}.logout-btn{font-size:0}main.main-content{margin-left:80px}}