*{margin:0;padding:0;box-sizing:border-box}body{font-family:Poppins,sans-serif;background:#f8f8f8}.app-container{display:flex;height:100vh;overflow:hidden}.menu-sidebar{width:68px;background:#fff;box-shadow:1px 0 10px #00000008;border-right:1px solid rgba(0,0,0,.06);display:flex;flex-direction:column;align-items:center;padding:12px 0;position:relative;z-index:20;height:100vh}.logo{margin-bottom:8px;cursor:pointer;transition:opacity .2s}.logo:hover{opacity:.9}.logo img{width:64px;height:64px}.divider{width:100%;display:flex;justify-content:center}.empty-divider{height:8px}.line-divider{height:4px;display:flex;align-items:center}.line-divider:after{content:"";width:100%;height:1px;background:#e0e0e0}.menu-item{width:56px;height:56px;margin:2px 0;background:transparent;border:none;border-radius:12px;cursor:pointer;display:flex;flex-direction:column;align-items:center;justify-content:center;color:#64748b;transition:all .2s cubic-bezier(.4,0,.2,1);position:relative}.menu-item:hover:not(.active){background:#f1f5f9;color:#334155}.menu-item.active{background:#2563eb14}.menu-item.active:before{content:"";position:absolute;left:-6px;top:10px;bottom:10px;width:3px;background:#2563eb;border-radius:0 4px 4px 0}.icon-wrapper{width:24px;height:24px;display:flex;align-items:center;justify-content:center;position:relative}.notification-dot{position:absolute;top:-2px;right:-2px;width:8px;height:8px;background-color:#ef4444;border:1.5px solid #ffffff;border-radius:50%;z-index:10}.menu-item.active .icon-wrapper{color:#2563eb}.menu-item svg{width:22px;height:22px;fill:currentColor}.menu-label{font-size:10px;font-weight:600;margin-top:2px;text-align:center;color:inherit;width:100%;white-space:normal;line-height:1.2;overflow:hidden;padding:0 2px}.menu-item.disabled{opacity:.6;cursor:not-allowed!important;pointer-events:none;filter:grayscale(.8)}.menu-item.disabled:hover{background:transparent!important}.coming-soon-badge{position:absolute;top:4px;right:-2px;background:#64748b;color:#fff;font-size:7px;padding:1px 3px;border-radius:4px;font-weight:800;text-transform:uppercase;letter-spacing:.2px;z-index:5;box-shadow:0 1px 2px #0000001a;white-space:nowrap}@media (max-width: 768px){.coming-soon-badge{top:2px;right:2px;font-size:6px}}.desktop-menu{display:flex;flex-direction:column;margin:4px 6px 8px}.desktop-menu .menu-item{width:auto}.mobile-menu,.hamburger-menu{display:none}.bottom-section{margin-top:auto;display:flex;flex-direction:column;align-items:center}.home-layout{display:flex;flex-direction:column;height:100vh;width:100vw;overflow:hidden;position:relative}.detail-sidebar{--detail-sidebar-shell-gutter: 12px;background:#f8f8f8;box-shadow:2px 0 10px #0000001a;position:relative;width:100%;z-index:40;transition:transform .3s ease-in-out,width .3s ease-in-out,height .3s ease-in-out;flex-shrink:0;overflow:visible}.content{padding:var(--detail-sidebar-shell-gutter);height:100%;display:flex;flex-direction:column;overflow-y:auto;overflow-x:hidden;scrollbar-width:thin;scrollbar-color:#ccc #f8f8f8}.content::-webkit-scrollbar{width:6px}.content::-webkit-scrollbar-track{background:#f8f8f8}.content::-webkit-scrollbar-thumb{background:#ccc;border-radius:3px}.detail-menu{padding:16px}.detail-menu__filters{display:flex;gap:8px;align-items:center;margin-bottom:8px}.detail-menu__create-folder,.detail-menu__create-folder-form{display:flex;gap:8px;align-items:center;margin:8px 0}.detail-content{padding:16px 0;margin:8px 0;flex-grow:1;overflow-y:auto;scrollbar-width:thin;scrollbar-color:#ccc #f8f8f8}.detail-content::-webkit-scrollbar{width:6px}.detail-content::-webkit-scrollbar-track{background:#f8f8f8}.detail-content::-webkit-scrollbar-thumb{background:#ccc;border-radius:3px}.routes-list{list-style:none;padding:0}.routes-list li{display:flex;align-items:center;gap:8px;padding:12px 8px;border-bottom:none}.routes-list li:hover{background:#f0f0f0}.routes-list li small{color:#666}.language-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px}.language-item{display:flex;align-items:center;padding:6px 8px;background:none;border:1px solid #e0e0e0;border-radius:4px;cursor:pointer;text-align:left;font-size:14px;color:#777}.language-item:hover{background:#f5f5f5}.language-item.selected{background:#4285f41a;border-color:#4285f4;color:#4285f4;font-weight:600}.flag{margin-right:8px;font-size:18px}.name{flex-grow:1}.close-btn{position:absolute;top:50%;right:-12px;transform:translateY(-50%);background:#fff;border:1px solid #ccc;border-radius:50%;width:24px;height:24px;display:flex;align-items:center;justify-content:center;cursor:pointer;z-index:60}.close-btn svg{width:20px;height:20px;fill:#5d5d5d}.close-btn:hover .tooltip{visibility:visible;opacity:1}.tooltip{visibility:hidden;opacity:0;position:absolute;right:100%;top:50%;transform:translateY(-50%);background:#333;color:#fff;padding:4px 8px;border-radius:4px;font-size:12px;white-space:nowrap;transition:opacity .2s;margin-right:8px}.open-btn{position:absolute;left:68px;top:50%;transform:translateY(-50%);background:#2563eb;border:none;border-radius:0 8px 8px 0;width:24px;height:48px;display:flex;align-items:center;justify-content:center;cursor:pointer;z-index:60;box-shadow:2px 0 8px #00000026;transition:all .2s ease}.open-btn:hover{width:32px;background:#1d4ed8}.open-btn svg{width:20px;height:20px;fill:#fff}.auth-form{padding:16px;max-width:300px;margin:0 auto}.form-group{margin-bottom:12px}.form-group label{display:block;font-size:14px;margin-bottom:4px}.form-group input{width:100%;padding:8px;border:1px solid #e0e0e0;border-radius:4px}.error{color:red;font-size:12px;margin:8px 0}.auth-form button[type=submit]{width:100%;padding:10px;background:#4285f4;color:#fff;border:none;border-radius:4px;cursor:pointer}.link{background:none;border:none;color:#4285f4;text-decoration:underline;cursor:pointer}.edit-btn{background:#4285f4;color:#fff;border:none;padding:8px 16px;border-radius:4px;cursor:pointer;margin-right:8px}.logout-btn{background:#d32f2f;color:#fff;border:none;padding:8px 16px;border-radius:4px;cursor:pointer}.sort-controls{margin-bottom:16px}.sort-controls label{margin-right:8px}.sort-controls select{padding:4px;border-radius:4px}.map-container{flex:1;width:100%;height:100%;position:relative;z-index:10}.map-container .maplibregl-ctrl-bottom-left,.map-container .maplibregl-ctrl-bottom-right{margin-bottom:calc(10px + var(--route-bottom-panel-height, 0px));transition:margin-bottom .18s ease}.map-lock-callout{position:absolute;top:50%;left:clamp(56px,7vw,120px);transform:translateY(-50%);z-index:25;max-width:min(420px,calc(100% - 96px));pointer-events:none;display:flex;flex-direction:column}.map-lock-claim{margin:0;padding:22px 26px;border-radius:18px;background:#0f172ab8;border:1px solid rgba(255,255,255,.08);box-shadow:0 20px 25px #0f172a33;color:#f8fafc;font-family:Fira Code,monospace;font-size:clamp(24px,2.6vw,36px);font-weight:700;line-height:1.25;letter-spacing:-.02em;text-wrap:balance}button.menu-item:disabled .icon-wrapper svg{fill:#b0bec5}button.menu-item:disabled .menu-label{color:#b0bec5}@media (min-width: 769px){.close-btn.mobile-close,.hamburger-logo{display:none}.open-btn.desktop-open{display:block}.open-btn.mobile-open{display:none}.home-layout{display:flex;flex-direction:row}.detail-sidebar{position:relative;top:auto;left:auto;width:0;height:100%;transform:none!important;overflow:visible;transition:width .3s ease-in-out}.detail-sidebar.open{width:336px;transform:none!important}.detail-sidebar:not(.open) .desktop-close{display:none}.detail-sidebar:not(.open) .content{display:none}.map-container{flex:1;height:100%;position:relative;width:auto;top:auto;left:auto}}@media (max-width: 768px){.detail-sidebar{--detail-sidebar-shell-gutter: 10px}.map-lock-callout{top:24px;left:16px;transform:none;max-width:calc(100% - 32px)}.map-lock-claim{font-size:22px;padding:18px 20px}.close-btn.desktop-close{display:none}.close-btn.mobile-close{display:flex;top:-16px;left:50%;transform:translate(-50%);right:auto;z-index:30;background:#f8f8f8;border-radius:50%;box-shadow:0 -2px 10px #0000001a}.open-btn.desktop-open{display:none}.open-btn.mobile-open{display:flex;left:50%;transform:translate(-50%);top:auto;bottom:72px;width:48px;height:24px;border-radius:8px 8px 0 0;box-shadow:0 -2px 10px #0003}.open-btn.mobile-open:hover{width:48px;background:#1d4ed8;height:28px}}@media (max-width: 768px){.menu-sidebar{position:fixed;bottom:0;width:100%;height:78px;flex-direction:row;justify-content:stretch;box-shadow:0 -8px 24px #0f172a14;border-top:1px solid rgba(148,163,184,.2);padding:6px 10px calc(env(safe-area-inset-bottom,0px) + 6px);z-index:50}.logo,.divider,.desktop-menu{display:none}.mobile-menu{display:flex;flex-direction:row;width:100%;align-items:stretch;gap:6px}.mobile-menu>*{flex:1 1 0;min-width:0}.mobile-menu-slot{position:relative;display:flex;min-width:0}.mobile-menu-slot>.menu-item{width:100%}.language-section{display:none}.menu-item{flex:1;margin:0;min-width:0;padding:8px 4px;width:auto}.menu-label{font-size:9px;line-height:1.1}.icon-wrapper{width:34px;height:34px;display:flex;align-items:center;justify-content:center}.mobile-menu .menu-item{height:66px;border-radius:18px}.mobile-menu .menu-item.active:before{left:8px;top:14px;bottom:14px}.hamburger-menu .icon-wrapper{width:32px;height:32px}.hamburger-menu svg{width:24px;height:24px}.hamburger-menu{display:flex;flex-direction:column;position:absolute;bottom:76px;right:0;width:min(180px,calc(100vw - 20px));background:#f8fafcfa;border:1px solid rgba(148,163,184,.2);border-radius:18px 18px 8px;box-shadow:0 18px 36px #0f172a24;padding:6px;z-index:100}.hamburger-menu .menu-item{width:100%;height:auto;min-height:48px;flex-direction:row;justify-content:flex-start;gap:10px;padding:10px 12px;border-radius:14px}.hamburger-menu .menu-label{text-align:left;font-size:12px}.detail-sidebar{width:100%;height:0;transform:none;order:2;margin-bottom:72px}.map-container{order:1;flex:1;position:relative}.detail-sidebar.open{height:40vh}.content{padding:8px 0 0;flex-direction:column;justify-content:flex-start;height:100%;max-height:40vh;overflow-y:auto;scrollbar-width:thin;scrollbar-color:#ccc #f8f8f8}.content::-webkit-scrollbar{width:6px}.content::-webkit-scrollbar-track{background:#f8f8f8}.content::-webkit-scrollbar-thumb{background:#ccc;border-radius:3px}.detail-menu{padding:8px 16px;min-height:80px;flex-shrink:0}.detail-menu__filters{display:flex;gap:4px;align-items:center;margin-bottom:4px}.detail-menu__create-folder,.detail-menu__create-folder-form{display:flex;gap:4px;align-items:center;margin:4px 0}.detail-content{padding:8px 16px;margin:8px 0 0}.line-divider{height:4px;display:flex;align-items:center}.line-divider:after{content:"";width:100%;height:1px;background:#e0e0e0}.language-grid{gap:8px}.language-item{padding:8px 12px;font-size:14px}.flag{font-size:20px}.open-btn.mobile-open{bottom:78px}.hamburger-logo{width:28px;height:28px;object-fit:contain}.hide-on-mobile{display:none!important}}
