@import"https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700;800&display=swap";:root{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,sans-serif;line-height:1.5;font-weight:400;color-scheme:dark;color:#f1f5f9;background-color:#0f172a;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;--vv-safe-top: 0px;--vv-safe-bottom: 0px;--vv-safe-left: 0px;--vv-safe-right: 0px;--safe-area-top: max(env(safe-area-inset-top, 0px), var(--vv-safe-top));--safe-area-bottom: max(env(safe-area-inset-bottom, 0px), var(--vv-safe-bottom));--safe-area-left: max(env(safe-area-inset-left, 0px), var(--vv-safe-left));--safe-area-right: max(env(safe-area-inset-right, 0px), var(--vv-safe-right))}*{margin:0;padding:0;box-sizing:border-box}html,body{width:100%;height:100%;overflow-x:hidden;scroll-behavior:smooth;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;padding:0}#root{width:100%;min-height:100vh;min-height:100svh}a{font-weight:500;color:#3b82f6;text-decoration:inherit}a:hover{color:#60a5fa}button{font-family:inherit}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:#1e293b}::-webkit-scrollbar-thumb{background:#475569;border-radius:4px}::-webkit-scrollbar-thumb:hover{background:#64748b}::selection{background:#3b82f64d;color:#fff}.floor-map-container{position:relative;width:100%;height:100%;min-height:600px;background:#000;border-radius:16px;overflow:hidden;perspective:2000px;perspective-origin:50% 50%}.canvas-wrapper{width:100%;height:100%;transition:transform 1.2s cubic-bezier(.19,1,.22,1);transform-style:preserve-3d;background:#000;will-change:transform}.canvas-wrapper canvas{image-rendering:high-quality;image-rendering:-webkit-optimize-contrast}.view-3d .canvas-wrapper{transform:rotateX(55deg) rotate(-12deg) translateY(60px) scale(.9);box-shadow:0 50px 100px -20px #000c,0 30px 60px -30px #000000e6}.floor-map-container.fullscreen{position:fixed;top:0;left:0;width:100vw;height:100svh;height:100dvh;z-index:990;background:#000}.fullscreen-close{background:#d34a09e6}.fullscreen-close:hover{background:#d34a09}.map-ui-header{position:absolute;top:20px;left:20px;right:auto;display:flex;gap:12px;z-index:150}.ui-group{display:flex;background:#0a0a0ae6;border:1px solid rgba(255,255,255,.1);border-radius:8px;padding:4px;gap:4px}.ui-group button{width:32px;height:32px;display:flex;align-items:center;justify-content:center;background:transparent;border:none;color:#fff;border-radius:6px;cursor:pointer;transition:all .2s;opacity:.8}.ui-group button:hover{background:#ffffff26;color:#fff;opacity:1}.ui-group button.active{background:linear-gradient(135deg,#d34a09,#d8830d);color:#fff}.map-editor-toolbar{position:absolute;top:80px;left:20px;display:flex;flex-direction:column;gap:8px;z-index:150;background:#0a0a0af2;border:1px solid rgba(255,255,255,.1);border-radius:12px;padding:12px;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);width:140px}.toolbar-label{font-size:10px;font-weight:700;color:#525252;margin-bottom:4px;letter-spacing:.05em}.map-editor-toolbar button{display:flex;align-items:center;gap:10px;width:100%;padding:8px 12px;background:#1e1e1e80;border:1px solid transparent;border-radius:8px;color:#a3a3a3;font-size:12px;font-weight:500;cursor:pointer;transition:all .2s;text-align:left}.map-editor-toolbar button:hover{background:#d34a0933;color:#fff;border-color:#d34a0966}.map-editor-toolbar button.active{background:linear-gradient(135deg,#d34a09,#d8830d);color:#fff;border-color:transparent;box-shadow:0 4px 12px #d34a094d}.tool-options{margin-top:8px;padding-top:8px;border-top:1px solid rgba(255,255,255,.1)}.tool-options select{width:100%;background:#000;border:1px solid #333;color:#fff;font-size:11px;padding:6px;border-radius:6px;outline:none;cursor:pointer}.tool-options input[type=range]{width:100%;height:4px;background:#333;border-radius:2px;outline:none;cursor:pointer;-webkit-appearance:none;appearance:none}.tool-options input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:14px;height:14px;background:linear-gradient(135deg,#d34a09,#d8830d);border-radius:50%;cursor:pointer}.tool-options input[type=range]::-moz-range-thumb{width:14px;height:14px;background:linear-gradient(135deg,#d34a09,#d8830d);border-radius:50%;cursor:pointer;border:none}.editor-properties-panel{position:absolute;top:80px;left:170px;width:260px;background:#0a0a0af2;border:1px solid rgba(255,255,255,.15);border-radius:12px;padding:16px;z-index:150;box-shadow:0 10px 25px -5px #0009;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);animation:slideIn .2s ease-out}@keyframes slideIn{0%{opacity:0;transform:translate(-10px)}to{opacity:1;transform:translate(0)}}.panel-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px;border-bottom:1px solid rgba(255,255,255,.1);padding-bottom:8px}.panel-header span{color:#fff;font-weight:600;font-size:13px}.panel-header button{background:none;border:none;color:#737373;cursor:pointer;padding:4px;display:flex}.panel-header button:hover{color:#fff}.panel-row{margin-bottom:12px}.panel-row label{display:block;color:#737373;font-size:10px;font-weight:600;margin-bottom:6px;text-transform:uppercase}.panel-row input,.panel-row select{width:100%;background:#171717;border:1px solid #333;color:#fff;padding:8px;border-radius:6px;font-size:12px;outline:none}.panel-row input:focus,.panel-row select:focus{border-color:#d34a09}.panel-row.coords{display:flex;gap:8px}.delete-btn{width:100%;background:#ef44441a;color:#ef4444;border:1px solid rgba(239,68,68,.2);padding:10px;border-radius:6px;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:6px;font-size:12px;font-weight:600;margin-top:12px;transition:all .2s}.delete-btn:hover{background:#ef4444;color:#fff}.disabled-input{opacity:.5;cursor:not-allowed;font-family:monospace;color:#737373!important}.map-legend-colored{position:absolute;bottom:20px;left:50%;transform:translate(-50%);background:#0a0a0ae6;border:1px solid rgba(255,255,255,.1);border-radius:12px;padding:12px 20px;display:flex;flex-direction:column;gap:8px;z-index:100;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.legend-row{display:flex;gap:16px;justify-content:center}.legend-item{display:flex;align-items:center;gap:6px;font-size:11px;color:#a3a3a3;font-weight:500}.dot{width:10px;height:10px;border-radius:50%;box-shadow:0 0 4px #0000004d}@media(max-width:768px){.map-ui-header{top:calc(var(--safe-area-top) + 130px);left:10px;right:10px;flex-wrap:wrap;gap:8px}.ui-group{flex-shrink:0}.ui-group button{width:36px;height:36px}.map-editor-toolbar{top:70px;left:10px;width:120px}.editor-properties-panel{left:140px;width:200px}}.search-bar-container{position:relative;width:100%}.search-input-wrapper{position:relative;display:flex;align-items:center;background:#0f0f0f;border:1.5px solid #2A2A2A;border-radius:12px;transition:border-color .2s ease,box-shadow .2s ease}.search-input-wrapper:focus-within{border-color:#d34509;box-shadow:0 0 0 2px #d3450926}.search-icon{position:absolute;left:14px;color:#8a8a8a;pointer-events:none}.search-input{width:100%;padding:13px 44px;border:none;border-radius:12px;background:transparent;font-size:14px;font-weight:500;color:#fff;outline:none}.search-input::placeholder{color:#7a7a7a}.clear-button{position:absolute;right:10px;width:26px;height:26px;border:none;border-radius:50%;background:#1c1c1c;color:#b0b0b0;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .15s ease,color .15s ease}.clear-button:hover{background:#262626;color:#fff}.suggestions-dropdown{position:absolute;top:calc(100% + 8px);left:0;right:0;background:#121212;border:1px solid #2A2A2A;border-radius:14px;box-shadow:0 12px 36px #0009;max-height:360px;overflow-y:auto;z-index:1000}.suggestion-item{display:flex;align-items:center;gap:12px;padding:12px 14px;cursor:pointer;transition:background .15s ease}.suggestion-item:not(:last-child){border-bottom:1px solid #242424}.suggestion-item:hover,.suggestion-item.selected{background:#d345091f}.suggestion-icon{color:#d8870c;flex-shrink:0;display:flex;align-items:center;justify-content:center}.suggestion-item:hover .suggestion-icon,.suggestion-item.selected .suggestion-icon{color:#fff}.suggestion-content{flex:1;display:flex;flex-direction:column;gap:3px;min-width:0}.suggestion-label{font-size:14px;font-weight:600;color:#fff;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;display:flex;align-items:center;gap:.5rem}.match-badge{display:inline-block;padding:.125rem .375rem;font-size:.65rem;font-weight:700;text-transform:uppercase;background:#d34a0926;color:#d34509;border-radius:4px;letter-spacing:.03em;flex-shrink:0}.floor-badge{display:inline-block;padding:.125rem .5rem;font-size:.65rem;font-weight:700;background:#a855f733;color:#a855f7;border-radius:4px;letter-spacing:.03em;flex-shrink:0}.suggestion-type{font-size:11px;font-weight:500;color:#9a9a9a;text-transform:uppercase;letter-spacing:.4px}.no-results{padding:28px 20px;text-align:center}.no-results-icon{color:#d34509;margin-bottom:6px}.no-results-text{font-size:14px;font-weight:600;color:#fff;margin:0}.no-results-hint{font-size:12px;color:#8a8a8a;margin:0}.suggestions-dropdown::-webkit-scrollbar{width:6px}.suggestions-dropdown::-webkit-scrollbar-track{background:#0f0f0f}.suggestions-dropdown::-webkit-scrollbar-thumb{background:#3a3a3a;border-radius:3px}.suggestions-dropdown::-webkit-scrollbar-thumb:hover{background:#555}@media(max-width:768px){.search-input{padding:11px 38px;font-size:14px}.search-icon{left:12px;width:16px;height:16px}.clear-button{right:10px;width:24px;height:24px}.suggestion-item{padding:12px;min-height:48px}.suggestion-label{font-size:14px}.suggestion-type{font-size:11px}.suggestions-list{max-height:50vh}}.route-info-container{background:#121212;border:1px solid #2A2A2A;border-radius:14px;padding:12px;box-shadow:0 8px 24px #00000080;overflow:hidden}.route-summary{margin-bottom:12px}.route-header{display:flex;justify-content:space-between;align-items:center;gap:8px;margin-bottom:10px}.route-title{font-size:14px;font-weight:800;background:linear-gradient(135deg,#d34b09,#d7860c);background-clip:text;-webkit-background-clip:text;-webkit-text-fill-color:transparent;letter-spacing:.02em}.route-badges{display:flex;gap:6px;flex-shrink:0}.route-badge{display:flex;align-items:center;gap:4px;padding:4px 8px;border-radius:10px;font-size:11px;font-weight:700;background:linear-gradient(135deg,#d34b0933,#d7860c33);color:#ffd6a0}.route-endpoints{display:flex;align-items:center;gap:10px;padding:10px;background:#0f0f0f;border-radius:10px;overflow:hidden}.endpoint{display:flex;align-items:center;gap:6px;flex:1;min-width:0}.endpoint-icon{flex-shrink:0;color:#d34b09}.endpoint-text{display:flex;flex-direction:column;gap:1px;min-width:0;overflow:hidden}.endpoint-label{font-size:8px;font-weight:700;color:#6a6a6a;text-transform:uppercase;letter-spacing:.5px}.endpoint-name{font-size:12px;font-weight:700;color:#fff;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.route-arrow{color:#4a4a4a;flex-shrink:0}.directions-list{border-top:1px solid #2A2A2A;padding-top:10px}.directions-title{font-size:10px;font-weight:800;color:#8a8a8a;margin-bottom:8px;text-transform:uppercase;letter-spacing:.6px}.direction-item{display:flex;align-items:center;gap:8px;padding:8px 0;border-bottom:1px solid #1F1F1F}.direction-item:last-child{border-bottom:none;padding-bottom:0}.step-number{width:22px;height:22px;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#d34b09,#d7860c);color:#fff;border-radius:50%;font-size:10px;font-weight:800;flex-shrink:0}.direction-icon{color:#9a9a9a;flex-shrink:0}.direction-text{font-size:12px;font-weight:600;color:#e5e5e5;line-height:1.4;flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis}.direction-item.start .step-number{background:#22c55e}.direction-item.end .step-number{background:#ef4444}@media(max-width:768px){.route-info-container{padding:10px}.route-endpoints{flex-direction:column;gap:8px;align-items:stretch}.endpoint{justify-content:flex-start}.route-arrow{transform:rotate(90deg);align-self:center}.route-header{flex-direction:column;align-items:flex-start;gap:6px}.route-badges{width:100%}.route-badge{flex:1;justify-content:center}.direction-text{font-size:11px}}.quick-actions-container{background:#121212;border:1px solid #2A2A2A;border-radius:16px;padding:16px;box-shadow:0 12px 36px #0009}.quick-actions-header{display:flex;justify-content:space-between;align-items:center;cursor:pointer;margin-bottom:14px;-webkit-user-select:none;user-select:none}.quick-actions-container.collapsed .quick-actions-header{margin-bottom:0}.quick-actions-title{font-size:11px;font-weight:700;color:#fff;margin:0;text-transform:uppercase;letter-spacing:.6px}.toggle-icon{color:#6a6a6a;display:flex;align-items:center;justify-content:center;transition:color .15s ease}.quick-actions-header:hover .toggle-icon{color:#fff}.animate-in{animation:gridFadeIn .25s cubic-bezier(.16,1,.3,1)}@keyframes gridFadeIn{0%{opacity:0;transform:translateY(-8px) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}.quick-actions-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:10px}@media(max-width:768px){.quick-actions-grid{grid-template-columns:repeat(3,1fr);gap:8px}.quick-action-button{padding:12px 8px;gap:4px}.quick-actions-container{padding:12px}}.quick-action-button{--action-color: #D34509;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:6px;padding:14px 10px;background:#0f0f0f;border:1px solid #2A2A2A;border-radius:12px;cursor:pointer;color:#fff;transition:background .15s ease,border-color .15s ease}.quick-action-button:hover:not(:disabled){background:#d3450914;border-color:var(--action-color)}.quick-action-button:disabled{opacity:.35;cursor:not-allowed}.quick-action-button .action-icon{color:var(--action-color);transition:color .15s ease}.quick-action-button:hover:not(:disabled) .action-icon{color:#fff}.quick-action-button .action-label{font-size:11px;font-weight:600;text-align:center;color:#9a9a9a;transition:color .15s ease}.quick-action-button:hover:not(:disabled) .action-label{color:#fff}@media(max-width:768px){.quick-actions-grid{grid-template-columns:repeat(3,1fr);gap:8px}.quick-action-button{padding:12px 8px}.quick-action-button .action-label{font-size:10px}}@media(max-width:480px){.quick-actions-grid{grid-template-columns:repeat(2,1fr)}}.nav-overlay-integrated{width:100%}.nav-card-integrated{background:#121212f2;border:1px solid rgba(255,255,255,.08);border-radius:16px;overflow:hidden;margin-bottom:12px}.nav-content-integrated{display:flex;align-items:center;padding:12px 14px;gap:12px}.nav-content-integrated .nav-icon-wrapper{flex-shrink:0;width:44px;height:44px;background:#ffffff0d;border-radius:12px;display:flex;align-items:center;justify-content:center;color:#fff;border:1px solid rgba(255,255,255,.05);transition:all .3s ease}.nav-card-integrated.turn-right .nav-icon-wrapper,.nav-card-integrated.turn-left .nav-icon-wrapper{background:#d34a0926;color:#d34a09;border-color:#d34a094d}.nav-card-integrated.end .nav-icon-wrapper{background:#10b98126;color:#10b981;border-color:#10b9814d}.nav-content-integrated .nav-text{flex:1;display:flex;flex-direction:column;justify-content:center;min-width:80px;overflow:hidden}.nav-content-integrated .step-count{font-size:11px;text-transform:uppercase;letter-spacing:.8px;font-weight:600;color:#999;margin-bottom:3px}.nav-content-integrated .instruction-text{font-size:15px;font-weight:600;color:#fff;margin:0;line-height:1.3;word-wrap:break-word;overflow-wrap:break-word}.nav-content-integrated .nav-controls{display:flex;gap:6px;padding-left:10px;margin-left:auto;border-left:1px solid rgba(255,255,255,.1);flex-shrink:0}.nav-content-integrated .nav-btn{width:38px;height:38px;border-radius:10px;border:1px solid rgba(255,255,255,.2);background:#ffffff26;color:#fff;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s ease}.nav-content-integrated .nav-btn:hover:not(:disabled){background:#ffffff40;border-color:#ffffff4d}.nav-content-integrated .nav-btn:disabled{opacity:.3;cursor:default}.nav-content-integrated .nav-btn.finish{background:#10b981;color:#000}.nav-content-integrated .nav-btn.finish:hover{background:#059669}.nav-minimize-btn{width:36px;height:36px;border-radius:10px;border:none;background:transparent;color:#888;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s ease;margin-left:4px}.nav-minimize-btn:hover{background:#ffffff1a;color:#fff}.nav-overlay-integrated.minimized .nav-card-integrated{margin-bottom:0}.nav-overlay-container{position:absolute;bottom:24px;left:50%;transform:translate(-50%);width:95%;max-width:480px;z-index:1000;pointer-events:none;display:flex;justify-content:center;display:none}.nav-card{background:#161616f2;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border:1px solid rgba(255,255,255,.08);border-radius:20px;padding:0;width:100%;box-shadow:0 10px 40px #0009;overflow:hidden;pointer-events:auto;animation:slideUp .4s cubic-bezier(.16,1,.3,1);display:flex;flex-direction:column}@keyframes slideUp{0%{opacity:0;transform:translateY(40px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}.nav-progress{height:4px;width:100%;background:#ffffff0d}.nav-progress-bar{height:100%;background:linear-gradient(90deg,#d34a09,#d8830d);transition:width .3s ease}.nav-content{display:flex;align-items:center;padding:16px 20px;gap:16px}.nav-icon-wrapper{flex-shrink:0;width:52px;height:52px;background:#ffffff0d;border-radius:14px;display:flex;align-items:center;justify-content:center;color:#fff;border:1px solid rgba(255,255,255,.05);transition:all .3s ease}.nav-card.turn-right .nav-icon-wrapper,.nav-card.turn-left .nav-icon-wrapper{background:#d34a0926;color:#d34a09;border-color:#d34a094d}.nav-card.end .nav-icon-wrapper{background:#10b98126;color:#10b981;border-color:#10b9814d}.nav-text{flex:1;display:flex;flex-direction:column;justify-content:center;min-width:0}.step-count{font-size:11px;text-transform:uppercase;letter-spacing:.8px;font-weight:600;color:#888;margin-bottom:2px}.instruction-text{font-size:16px;font-weight:600;color:#fff;margin:0;white-space:normal;overflow:hidden;line-height:1.3}.nav-controls{display:flex;gap:8px;padding-left:8px;border-left:1px solid rgba(255,255,255,.1)}.nav-btn{width:40px;height:40px;border-radius:12px;border:none;background:transparent;color:#fff;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s ease}.nav-btn:hover:not(:disabled){background:#ffffff1a}.nav-btn:disabled{opacity:.3;cursor:default}.nav-btn.finish{background:#10b981;color:#000}.nav-btn.finish:hover{background:#059669}@media(max-width:768px){.nav-overlay-container{transition:bottom .3s ease}.nav-content-integrated{padding:14px 16px;gap:12px}.nav-content-integrated .nav-icon-wrapper{width:44px;height:44px}.nav-content-integrated .step-count{font-size:11px}.nav-content-integrated .instruction-text{font-size:16px}.nav-content-integrated .nav-btn{width:36px;height:36px}.nav-minimize-btn{width:32px;height:32px}.nav-content-integrated .nav-controls{padding-left:8px;gap:6px}}.multi-floor-badge{position:absolute;top:8px;right:12px;background:linear-gradient(135deg,#f97316,#ea580c);padding:3px 10px;border-radius:10px;font-size:10px;font-weight:600;color:#fff;text-transform:uppercase;letter-spacing:.5px;z-index:10}.nav-card-integrated.multi-floor{position:relative;padding-top:4px}.nav-progress-bar.multi-floor-progress{background:linear-gradient(90deg,#f97316,#ea580c,#10b981)}.nav-card-integrated.transition-phase{background:linear-gradient(135deg,#f9731633,#ea580c33);border-color:#f9731666}.nav-progress-bar.transition-progress{background:linear-gradient(90deg,#f97316,#ea580c)}.nav-icon-wrapper.floor-change{background:#f9731633;color:#f97316;border-color:#f973164d}.floor-change-label{color:#f97316!important;font-weight:600!important}.nav-btn.floor-reached-btn{background:linear-gradient(135deg,#f97316,#ea580c);color:#fff;border:none;min-width:80px;padding:0 16px}.nav-btn.floor-reached-btn:hover{transform:scale(1.02);box-shadow:0 4px 12px #f9731666}.nav-btn.next-phase{background:linear-gradient(135deg,#f97316,#ea580c);color:#fff;border:none;animation:pulse-phase 2s infinite}.nav-btn.next-phase:hover{transform:scale(1.05);box-shadow:0 4px 12px #f9731680}@keyframes pulse-phase{0%,to{box-shadow:0 0 #f9731666}50%{box-shadow:0 0 0 8px #f9731600}}.nav-card-integrated.transition-point .nav-icon-wrapper{background:#f9731626;color:#f97316;border-color:#f973164d}.skip-to-transition{display:flex;align-items:center;justify-content:center;gap:6px;width:100%;padding:8px 12px;margin-top:0;background:#f973161a;border:none;border-top:1px solid rgba(249,115,22,.2);border-radius:0 0 16px 16px;color:#f97316;font-size:12px;font-weight:500;cursor:pointer;transition:all .2s ease}.skip-to-transition:hover{background:#f9731633}.skip-to-transition span{text-transform:capitalize}.install-prompt{position:fixed;bottom:-100px;left:50%;transform:translate(-50%);z-index:9999;transition:bottom .4s cubic-bezier(.34,1.56,.64,1);max-width:90%;width:400px}.install-prompt.show{bottom:calc(24px + var(--safe-area-bottom))}.install-prompt-content{background:linear-gradient(135deg,#d34a09f2,#d8830df2);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-radius:16px;padding:16px 20px;display:flex;align-items:center;gap:16px;box-shadow:0 10px 40px #d34a0966;border:1px solid rgba(255,255,255,.1)}.install-icon{width:48px;height:48px;background:#ffffff26;border-radius:12px;display:flex;align-items:center;justify-content:center;color:#fff;flex-shrink:0}.install-text{flex:1;min-width:0}.install-text h3{margin:0;font-size:16px;font-weight:700;color:#fff;line-height:1.2}.install-text p{margin:4px 0 0;font-size:13px;color:#ffffffe6;line-height:1.3}.install-actions{display:flex;align-items:center;gap:8px}.install-btn{background:#fffffff2;color:#d34a09;border:none;border-radius:10px;padding:10px 20px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s ease}.install-btn:hover{background:#fff;transform:scale(1.05)}.install-btn:active{transform:scale(.98)}.dismiss-btn{width:36px;height:36px;background:#ffffff26;border:none;border-radius:8px;color:#fff;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s ease}.dismiss-btn:hover{background:#ffffff40}@media(max-width:768px){.install-prompt{width:calc(100% - 32px);max-width:none}.install-prompt.show{bottom:calc(16px + var(--safe-area-bottom))}.install-prompt-content{padding:14px 16px;gap:12px}.install-icon{width:44px;height:44px}.install-text h3{font-size:15px}.install-text p{font-size:12px}.install-btn{padding:8px 16px;font-size:13px}}.tutorial-overlay{position:fixed;inset:0;z-index:9999;background:#000000d9;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;padding:20px;opacity:0;transition:opacity .3s ease}.tutorial-overlay.visible{opacity:1}.tutorial-modal{position:relative;width:100%;max-width:420px;background:var(--glass-bg);border:1px solid var(--glass-border);border-radius:var(--radius-lg);box-shadow:0 24px 64px #00000080;overflow:hidden;transform:scale(.9) translateY(20px);opacity:0;transition:transform .4s cubic-bezier(.34,1.56,.64,1),opacity .3s ease}.tutorial-modal.visible{transform:scale(1) translateY(0);opacity:1}.tutorial-close{position:absolute;top:16px;right:16px;width:36px;height:36px;background:#ffffff0d;border:1px solid var(--glass-border);border-radius:50%;color:var(--text-secondary);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s ease;z-index:10}.tutorial-close:hover{background:#ffffff1a;color:var(--text-primary)}.tutorial-header{padding:32px 24px 16px;text-align:center}.tutorial-badge{display:inline-block;padding:6px 16px;background:var(--accent-gradient);border-radius:20px;font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:#fff}.tutorial-content{padding:24px 32px 32px;text-align:center;min-height:200px;display:flex;flex-direction:column;align-items:center;justify-content:center}.tutorial-icon{width:72px;height:72px;background:linear-gradient(135deg,#d34a0926,#d8830d26);border:1px solid rgba(211,74,9,.3);border-radius:50%;display:flex;align-items:center;justify-content:center;color:var(--accent-primary);margin-bottom:24px;animation:pulse-glow 2s infinite}@keyframes pulse-glow{0%,to{box-shadow:0 0 20px #d34a0933}50%{box-shadow:0 0 30px #d34a0966}}.tutorial-title{font-size:24px;font-weight:600;color:var(--text-primary);margin:0 0 12px}.tutorial-description{font-size:15px;line-height:1.6;color:var(--text-secondary);margin:0;max-width:320px}.tutorial-progress{display:flex;align-items:center;justify-content:center;gap:8px;padding:0 24px 24px}.progress-dot{width:8px;height:8px;border-radius:50%;background:#fff3;border:none;cursor:pointer;padding:0;transition:all .3s ease}.progress-dot:hover{background:#fff6}.progress-dot.active{width:24px;border-radius:4px;background:var(--accent-gradient)}.progress-dot.completed{background:var(--accent-primary);opacity:.6}.tutorial-actions{display:flex;align-items:center;justify-content:space-between;padding:16px 24px 24px;gap:12px}.tutorial-btn{display:flex;align-items:center;justify-content:center;gap:6px;padding:12px 24px;border-radius:var(--radius-sm);font-size:14px;font-weight:500;cursor:pointer;transition:all .2s ease;border:none}.tutorial-btn.primary{flex:1;background:var(--accent-gradient);color:#fff;box-shadow:0 4px 16px #d34a094d}.tutorial-btn.primary:hover{transform:translateY(-2px);box-shadow:0 6px 20px #d34a0966}.tutorial-btn.secondary{background:#ffffff14;color:var(--text-primary);border:1px solid var(--glass-border)}.tutorial-btn.secondary:hover{background:#ffffff1f}.tutorial-btn.skip{background:transparent;color:var(--text-secondary);padding:12px 16px}.tutorial-btn.skip:hover{color:var(--text-primary)}@media(max-width:480px){.tutorial-modal{max-width:100%;margin:0 12px}.tutorial-content{padding:20px 24px 28px;min-height:180px}.tutorial-icon{width:64px;height:64px}.tutorial-icon svg{width:28px;height:28px}.tutorial-title{font-size:20px}.tutorial-description{font-size:14px}.tutorial-actions{flex-direction:column-reverse;gap:10px}.tutorial-btn{width:100%}}:root{--bg-primary: #000000;--bg-secondary: #0A0A0A;--glass-bg: rgba(18, 18, 18, .92);--glass-border: rgba(255, 255, 255, .06);--text-primary: #FFFFFF;--text-secondary: #9A9A9A;--accent-primary: #D34A09;--accent-secondary: #D8830D;--accent-gradient: linear-gradient(135deg, #D34A09 0%, #D8830D 100%);--shadow-float: 0 6px 24px rgba(0, 0, 0, .55);--radius-sm: 10px;--radius-md: 14px;--radius-lg: 16px;--font-family: "Inter", sans-serif}body{background:var(--bg-primary);color:var(--text-primary);font-family:var(--font-family);overflow:hidden}.app{position:relative;width:100vw;height:100vh;height:100svh}.map-fullscreen{position:absolute;inset:0;z-index:0}.floating-menu-trigger{position:absolute;top:16px;right:16px;left:auto;z-index:10;opacity:0;pointer-events:none}.floating-menu-trigger.visible{opacity:1;pointer-events:auto}.glass-btn{width:40px;height:40px;background:var(--glass-bg);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border:1px solid var(--glass-border);border-radius:var(--radius-sm);color:var(--text-primary);display:flex;align-items:center;justify-content:center;cursor:pointer;box-shadow:var(--shadow-float);transition:background .15s ease,transform .15s ease}.glass-btn:hover{background:#1e1e1e}.glass-btn.active{background:var(--accent-gradient);border-color:transparent}.sidebar-wrapper{position:absolute;inset:0 auto 0 0;width:340px;z-index:20;padding:14px;display:flex;flex-direction:column;gap:10px;pointer-events:none;transition:transform .35s cubic-bezier(.32,.72,0,1)}.sidebar-wrapper.closed{transform:translate(-110%)}.panel-card{background:var(--glass-bg);-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);border:1px solid var(--glass-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-float);pointer-events:auto;overflow:hidden;animation:panelIn .35s ease-out}@keyframes panelIn{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}.header-island{overflow:visible;z-index:20}.sidebar-header{padding:12px 14px;display:flex;justify-content:space-between;align-items:center;border-bottom:1px solid var(--glass-border)}.brand{display:flex;align-items:center;gap:8px}.brand-dot{width:6px;height:6px;background:var(--accent-gradient);border-radius:50%}.brand h1{font-size:13px;font-weight:600;letter-spacing:.4px}.close-btn-mini{background:none;border:none;padding:4px;color:var(--text-secondary);cursor:pointer}.close-btn-mini:hover{color:var(--text-primary)}.search-section{padding:14px}.search-label{display:flex;align-items:center;gap:6px;font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:var(--text-secondary);margin-bottom:4px}.dot{width:6px;height:6px;border-radius:50%}.start-dot{border:2px solid var(--text-secondary)}.end-dot{background:var(--accent-primary)}.connector-gap{height:12px;display:flex;align-items:center;justify-content:flex-end;margin-right:6px}.swap-button-floating{position:relative;top:9px;width:24px;height:24px;border-radius:50%;background:#181818;border:1px solid var(--glass-border);color:var(--text-secondary);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:background .15s ease,transform .15s ease}.swap-button-floating:hover:not(:disabled){background:var(--accent-gradient);color:#fff;transform:rotate(180deg)}.clear-route-link{margin-top:8px;background:none;border:none;font-size:11px;text-align:right;color:#fca5a5;cursor:pointer;opacity:.75}.clear-route-link:hover{opacity:1;text-decoration:underline}.error-message{font-size:11px;color:#fca5a5;margin-top:6px;display:flex;align-items:center;gap:6px}.action-island{padding:14px;max-height:calc(100vh - 220px);overflow-y:auto;scroll-padding-bottom:24px;scrollbar-width:thin;scrollbar-color:#333333 transparent}.action-island::-webkit-scrollbar{width:5px}.action-island::-webkit-scrollbar-track{background:transparent}.action-island::-webkit-scrollbar-thumb{background:#333;border-radius:10px}.action-island::-webkit-scrollbar-thumb:hover{background:#444}.navigation-integrated{margin-bottom:0}.card-label{font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:var(--text-secondary);margin-bottom:6px}.divider{height:1px;background:var(--glass-border);margin:10px 0}.map-tool-layer{position:absolute;top:20px;right:20px;z-index:100;display:flex;flex-direction:column;gap:12px}.admin-controls-group{display:flex;flex-direction:column;gap:8px}.admin-access-btn:hover{color:var(--accent-primary)!important}.logout-btn{transition:all .2s ease}.logout-btn:hover{color:#ef4444!important;background:#ef44441a!important}.floor-dropdown-container{position:relative;display:flex;flex-direction:column;align-items:flex-end}.floor-dropdown-trigger{width:auto!important;padding:0 12px;gap:10px}.floor-label{font-size:13px;font-weight:700;min-width:24px;text-align:center}.rotate-180{transform:rotate(180deg)}.floor-options-panel{position:absolute;top:calc(100% + 8px);right:0;width:200px;padding:8px;display:flex;flex-direction:column;gap:4px;animation:dropdownFade .2s cubic-bezier(.16,1,.3,1)}@keyframes dropdownFade{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.glass-panel{background:var(--glass-bg);-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);border:1px solid var(--glass-border);border-radius:var(--radius-md);box-shadow:var(--shadow-float)}.floor-option{display:flex;align-items:center;gap:12px;padding:10px 14px;background:transparent;border:1px solid transparent;border-radius:var(--radius-sm);color:var(--text-secondary);cursor:pointer;text-align:left;transition:all .2s}.floor-option:hover{background:#ffffff0d;color:var(--text-primary)}.floor-option.selected{background:#d34a0926;color:var(--accent-primary);border-color:#d34a094d}.floor-num{font-weight:800;font-size:12px;width:20px}.floor-name{font-size:12px;font-weight:500}.top-search-bar{position:absolute;top:12px;left:12px;right:12px;z-index:30;pointer-events:auto}.top-search-card{background:var(--glass-bg);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border:1px solid var(--glass-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-float);padding:12px}.search-compact-group{display:flex;flex-direction:column;gap:8px}.search-row{display:flex;align-items:center;gap:6px}.search-row .search-bar-container{flex:1}.swap-btn-compact{width:36px;height:36px;min-width:36px;border-radius:8px;background:#181818;border:1px solid var(--glass-border);color:var(--text-secondary);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s ease}.swap-btn-compact:hover:not(:disabled){background:var(--accent-gradient);color:#fff;transform:rotate(180deg)}.swap-btn-compact:disabled{opacity:.3;cursor:not-allowed}.clear-route-btn-mobile{background:#ef444426;border:1px solid rgba(239,68,68,.3);border-radius:8px;padding:8px 12px;color:#fca5a5;font-size:12px;font-weight:500;display:flex;align-items:center;justify-content:center;gap:6px;cursor:pointer;transition:all .2s ease}.clear-route-btn-mobile:hover{background:#ef444440;color:#ef4444}.search-compact-selected{display:flex;flex-direction:column;gap:8px}.search-inline-row{display:flex;align-items:center;gap:6px}.location-pill{flex:1;display:flex;align-items:center;gap:8px;background:#0f0f0f;border:1px solid #2A2A2A;border-radius:10px;padding:10px 12px;min-width:0}.pill-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.pill-dot.start{background:#22c55e}.pill-dot.end{background:#ef4444}.pill-text{font-size:13px;font-weight:500;color:#fff;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.swap-btn-inline{width:28px;height:28px;min-width:28px;border-radius:50%;background:#181818;border:1px solid #2A2A2A;color:#888;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s ease;flex-shrink:0}.swap-btn-inline:hover{background:var(--accent-gradient);color:#fff;transform:rotate(180deg)}@media(max-width:768px){.sidebar-wrapper{inset:auto 0 0;width:100%;padding:0;gap:0;z-index:50;padding-bottom:var(--safe-area-bottom)}.sidebar-wrapper.closed{transform:translateY(calc(100% - 50px - var(--safe-area-bottom)))}.sidebar-wrapper.minimized{transform:translateY(0)}.sidebar-wrapper.minimized .action-island{padding:12px;max-height:auto}.sidebar-wrapper.minimized .sheet-handle{display:none}.panel-card{border-radius:20px 20px 0 0;border-bottom:none;box-shadow:0 -4px 20px #0006}.header-island{display:none}.action-island{border-radius:20px 20px 0 0;max-height:65vh;overflow-y:auto;padding-bottom:calc(16px + var(--safe-area-bottom));scroll-padding-bottom:calc(16px + var(--safe-area-bottom))}.top-search-bar{display:block}.top-search-card{padding:10px}.search-compact-group{gap:6px}.map-tool-layer{top:130px;bottom:auto;right:12px;transition:top .3s ease}.sidebar-wrapper:not(.closed)~.map-tool-layer{top:130px}.sidebar-wrapper.minimized~.map-tool-layer{top:130px}.floating-menu-trigger{display:none}.glass-btn{width:44px;height:44px}.sheet-handle{width:40px;height:4px;background:#fff3;border-radius:2px;margin:8px auto 12px;cursor:grab}.sheet-handle:active{cursor:grabbing}}@media(min-width:769px){.top-search-bar,.sheet-handle{display:none}}.cross-floor-indicator{background:linear-gradient(135deg,#f9731626,#ea580c26);border:1px solid rgba(249,115,22,.3);border-radius:var(--radius-md);padding:10px 12px;margin-bottom:8px}.cross-floor-header{display:flex;justify-content:center;align-items:center;margin-bottom:8px}.cross-floor-info{font-size:13px;color:#fff;font-weight:600;background:#f97316;padding:4px 12px;border-radius:20px}.cross-floor-phases{display:flex;align-items:center;justify-content:center;gap:4px;margin-bottom:12px}.phase-step{display:flex;flex-direction:column;align-items:center;gap:4px;padding:8px 12px;border-radius:8px;transition:all .2s ease}.phase-step.active{background:#a855f74d}.phase-step.completed{background:#22c55e33}.phase-step.completed .phase-num{background:#22c55e}.phase-num{width:24px;height:24px;border-radius:50%;background:#ffffff26;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:600;color:var(--text-primary)}.phase-step.active .phase-num{background:var(--accent-gradient)}.phase-text{font-size:10px;color:var(--text-secondary);text-transform:capitalize}.phase-step.active .phase-text{color:var(--text-primary)}.phase-connector{width:20px;height:2px;background:#ffffff26}.transition-message{text-align:center;padding:16px;background:#a855f71a;border-radius:var(--radius-sm);margin-top:8px}.transition-icon{font-size:32px;margin-bottom:8px}.transition-message p{font-size:14px;color:var(--text-primary);margin-bottom:16px}.continue-btn{background:var(--accent-gradient);color:#fff;border:none;padding:12px 24px;border-radius:var(--radius-sm);font-size:14px;font-weight:600;cursor:pointer;transition:all .2s ease}.continue-btn:hover{transform:scale(1.02);box-shadow:0 4px 12px #d34a0966}.phase-navigation{display:flex;justify-content:center;gap:12px;margin-top:12px}.phase-btn{padding:8px 16px;border-radius:var(--radius-sm);font-size:12px;font-weight:500;cursor:pointer;transition:all .2s ease;border:1px solid rgba(255,255,255,.1);background:#ffffff0d;color:var(--text-primary)}.phase-btn:hover{background:#ffffff1a}.phase-btn.next{background:var(--accent-gradient);border:none}.phase-btn.next:hover{box-shadow:0 4px 12px #d34a0966}.transition-selection{margin-top:4px}.selection-title{font-size:12px;color:var(--text-secondary);margin-bottom:8px;text-align:center}.transition-options{display:flex;gap:8px;align-items:center}.transition-or{font-size:12px;color:var(--text-secondary);font-weight:500}.transition-option{flex:1;display:flex;flex-direction:row;align-items:center;justify-content:center;gap:8px;padding:10px 12px;border-radius:var(--radius-sm);border:1px solid rgba(255,255,255,.1);background:#ffffff08;cursor:pointer;transition:all .2s ease}.transition-option:hover{border-color:#ffffff40;background:#ffffff14;transform:translateY(-2px)}.transition-option.lift-option:hover,.transition-option.stairs-option:hover{border-color:#f9731680;background:#f973161a}.option-label{font-size:13px;font-weight:600;color:var(--text-primary)}.option-distance{font-size:11px;color:var(--text-secondary)}.admin-page{width:100%;height:100vh;background:linear-gradient(135deg,#0a0a0a,#1a1a1a);display:flex;align-items:center;justify-content:center;position:relative;overflow:hidden}.admin-page:before{content:"";position:absolute;width:500px;height:500px;background:radial-gradient(circle,rgba(211,74,9,.15) 0%,transparent 70%);border-radius:50%;top:-250px;right:-250px;pointer-events:none}.back-to-home{position:absolute;top:2rem;left:2rem;display:flex;align-items:center;gap:.5rem;padding:3rem 5rem;z-index:10}.back-to-home:hover{color:var(--accent-primary)}.admin-login-container{width:100%;max-width:450px;padding:2rem}.admin-login-card{padding:3rem 2.5rem;text-align:center;animation:slideUp .4s cubic-bezier(.16,1,.3,1)}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.lock-icon{width:80px;height:80px;background:linear-gradient(135deg,#d34a0933,#d34a090d);color:var(--accent-primary);border-radius:50%;display:flex;align-items:center;justify-content:center;margin:0 auto 1.5rem;border:2px solid rgba(211,74,9,.3)}.login-header h1{font-size:2rem;font-weight:900;margin-bottom:.5rem;color:var(--text-primary);letter-spacing:-.02em}.login-header p{color:var(--text-secondary);font-size:.95rem;margin-bottom:2.5rem}.login-form{display:flex;flex-direction:column;gap:1.25rem}.input-field{position:relative;display:flex;align-items:center}.field-icon{position:absolute;left:1.125rem;color:var(--text-secondary);z-index:1}.input-field input{width:100%;padding:1rem 1.125rem 1rem 3rem;background:#ffffff0d;border:1px solid var(--glass-border);border-radius:var(--radius-md);color:var(--text-primary);font-size:.95rem;transition:all .2s}.input-field input:focus{outline:none}.input-field input::placeholder{color:var(--text-secondary)}.login-error{color:#ef4444;font-size:.875rem;font-weight:600;padding:.75rem;background:#ef44441a;border-radius:var(--radius-sm);border:1px solid rgba(239,68,68,.3)}.login-submit{width:100%;padding:1rem;background:var(--accent-primary);color:#fff;border:none;border-radius:var(--radius-md);font-weight:800;font-size:1rem;cursor:pointer;transition:all .2s;margin-top:.5rem;letter-spacing:.02em}.admin-footer{margin-top:2rem;padding-top:1.5rem;border-top:1px solid var(--glass-border)}.security-note{color:var(--text-secondary);font-size:.85rem;display:flex;align-items:center;justify-content:center;gap:.5rem}@media(max-width:640px){.admin-login-container{padding:1rem}.admin-login-card{padding:2rem 1.5rem}.back-to-home{top:1rem;left:1rem}}
