.menu-overlay{z-index:998;background:#00000080;animation:.3s fadeIn;position:fixed;inset:0}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.side-menu{z-index:999;background:#fff;flex-direction:column;width:320px;height:100vh;transition:right .3s;display:flex;position:fixed;top:0;right:-320px;box-shadow:-2px 0 10px #0000001a}.side-menu.open{right:0}.menu-header{border-bottom:1px solid #e1e8ed;justify-content:space-between;align-items:center;padding:1.5rem;display:flex}.menu-header h2{color:#2c3e50;margin:0;font-size:1.25rem;font-weight:600}.close-btn{cursor:pointer;color:#7f8c8d;background:0 0;border:none;justify-content:center;align-items:center;padding:.5rem;transition:color .2s;display:flex}.close-btn:hover{color:#2c3e50}.menu-nav{flex:1;padding:1rem 0;overflow-y:auto}.menu-item{color:#2c3e50;cursor:pointer;align-items:center;gap:1rem;padding:1rem 1.5rem;text-decoration:none;transition:background-color .2s;display:flex}.menu-item:hover{background:#f8f9fa}.menu-item svg{color:#8b5cf6;flex-shrink:0}.menu-item span{font-size:1rem;font-weight:500}.menu-divider{background:#e1e8ed;height:1px;margin:.5rem 1.5rem}.menu-footer{text-align:center;border-top:1px solid #e1e8ed;padding:1.5rem}.menu-footer p{color:#7f8c8d;margin:0;font-size:.875rem}@media (max-width:768px){.side-menu{width:280px;right:-280px}}
