*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}body{margin:0;background:transparent;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.fp-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000bf;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);display:flex;align-items:center;justify-content:center;z-index:200;animation:fpFadeIn .25s ease}@keyframes fpFadeIn{0%{opacity:0}to{opacity:1}}.fp-container{width:96vw;height:94vh;background:var(--surface, #1a1d27);border-radius:var(--radius, 16px);border:1px solid var(--surface-border, rgba(255, 255, 255, .06));box-shadow:0 24px 60px #0009;display:flex;flex-direction:column;overflow:hidden;animation:fpScaleIn .3s cubic-bezier(.16,1,.3,1)}@media(orientation:portrait){.fp-container{width:98vw;height:96vh;border-radius:var(--radius-sm, 10px)}.fp-header{padding:1rem 1.25rem}.fp-title{font-size:1.15rem}.fp-legend{flex-wrap:wrap;gap:1rem;padding:.85rem 1.25rem}}@media(orientation:portrait)and (max-width:480px){.fp-container{width:100vw;height:100vh;border-radius:0}}@keyframes fpScaleIn{0%{opacity:0;transform:scale(.95) translateY(10px)}to{opacity:1;transform:scale(1) translateY(0)}}.fp-header{display:flex;align-items:center;justify-content:space-between;padding:1.1rem 1.5rem;border-bottom:1px solid var(--surface-border, rgba(255, 255, 255, .06));flex-shrink:0}.fp-title{font-size:1.3rem;font-weight:700;color:var(--text, #f1f3f7);letter-spacing:-.01em}.fp-subtitle{font-size:.85rem;color:var(--text-muted, #8b92a5);margin-top:3px}.fp-close{width:48px;height:48px;display:flex;align-items:center;justify-content:center;background:var(--surface-border, rgba(255, 255, 255, .06));border:1px solid var(--surface-border, rgba(255, 255, 255, .08));border-radius:12px;color:var(--text-muted, #8b92a5);font-size:1.25rem;cursor:pointer;transition:background .15s,color .15s}.fp-close:active{background:var(--surface-hover, rgba(255, 255, 255, .1));color:var(--text, #f1f3f7)}.fp-canvas{flex:1;min-height:0;cursor:grab;touch-action:none}.fp-canvas:active{cursor:grabbing}.fp-canvas canvas{display:block;width:100%!important;height:100%!important}.fp-legend{display:flex;align-items:center;gap:1.5rem;padding:.85rem 1.5rem;border-top:1px solid var(--surface-border, rgba(255, 255, 255, .06));flex-shrink:0}.fp-legend-item{display:flex;align-items:center;gap:.5rem;font-size:.9rem;color:var(--text-muted, #8b92a5)}.fp-dot{width:12px;height:12px;border-radius:50%}.fp-dot--green{background:#22c55e}.fp-dot--accent{background:var(--accent, #3b82f6)}.fp-dot--path{background:var(--accent, #3b82f6);opacity:.6;width:20px;height:5px;border-radius:3px}:root,[data-theme=dark]{--accent: #3b82f6;--accent-dark: #3b82f6dd;--bg: #0f1117;--surface: #1a1d27;--surface-hover: #22263a;--surface-border: rgba(255, 255, 255, .06);--text: #f1f3f7;--text-muted: #8b92a5;--text-dim: #5a6178;--radius: 16px;--radius-sm: 10px;--shadow-lg: 0 20px 50px rgba(0, 0, 0, .5)}[data-theme=light]{--bg: #f0f2f5;--surface: #ffffff;--surface-hover: #f0f2f5;--surface-border: rgba(0, 0, 0, .08);--text: #1a1d27;--text-muted: #5a6178;--text-dim: #8b92a5;--shadow-lg: 0 20px 50px rgba(0, 0, 0, .12)}*,*:before,*:after{-webkit-user-select:none;user-select:none;-webkit-touch-callout:none;-webkit-tap-highlight-color:transparent}input,textarea{-webkit-user-select:text;user-select:text}.wf-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100vh;gap:1.25rem;color:var(--text-muted);font-family:Inter,system-ui,-apple-system,sans-serif}.wf-spinner{width:48px;height:48px;border:4px solid var(--surface);border-top-color:var(--accent);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.wf-root{display:flex;flex-direction:column;height:100vh;overflow:hidden;font-family:Inter,system-ui,-apple-system,sans-serif;font-size:18px;background:var(--bg);color:var(--text);touch-action:manipulation}.wf-header{display:flex;align-items:center;justify-content:space-between;padding:1.25rem 1.75rem;background:var(--surface);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-bottom:1px solid var(--surface-border);flex-shrink:0}.wf-header-left{display:flex;align-items:center;gap:1rem}.wf-logo{display:flex;align-items:center;justify-content:center;width:52px;height:52px;border-radius:14px;background:#3b82f61a;border:1px solid rgba(59,130,246,.2)}.wf-title{font-size:1.5rem;font-weight:700;letter-spacing:-.02em;line-height:1.2}.wf-subtitle{font-size:.8rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.08em;margin-top:3px}.wf-clock{text-align:right}.wf-clock-time{font-size:1.75rem;font-weight:600;font-variant-numeric:tabular-nums;letter-spacing:-.02em}.wf-clock-date{font-size:.85rem;color:var(--text-muted);margin-top:2px}.wf-search-bar{position:relative;margin:1.25rem 1.75rem 0;flex-shrink:0}.wf-search-icon{position:absolute;left:18px;top:50%;transform:translateY(-50%);color:var(--text-dim);pointer-events:none;width:24px;height:24px}.wf-search-input{width:100%;padding:1.1rem 3rem 1.1rem 3.25rem;font-size:1.1rem;color:var(--text);background:var(--surface);border:1px solid var(--surface-border);border-radius:var(--radius);outline:none;transition:border-color .2s,box-shadow .2s}.wf-search-input::placeholder{color:var(--text-dim)}.wf-search-input:focus{border-color:var(--accent);box-shadow:0 0 0 3px #3b82f626}.wf-search-clear{position:absolute;right:8px;top:50%;transform:translateY(-50%);background:none;border:none;color:var(--text-dim);font-size:1.25rem;cursor:pointer;padding:10px 14px;border-radius:8px;min-width:48px;min-height:48px;display:flex;align-items:center;justify-content:center;transition:color .15s,background .15s}.wf-search-clear:active{color:var(--text);background:var(--surface-hover)}.wf-categories{display:flex;gap:.6rem;padding:1rem 1.75rem 0;overflow-x:auto;flex-shrink:0;-webkit-overflow-scrolling:touch;scrollbar-width:none}.wf-categories::-webkit-scrollbar{display:none}.wf-pill{padding:.65rem 1.25rem;font-size:.95rem;font-weight:500;white-space:nowrap;border-radius:999px;border:1px solid var(--surface-border);background:var(--surface);color:var(--text-muted);cursor:pointer;min-height:48px;display:flex;align-items:center;transition:all .15s}.wf-pill:active{background:var(--surface-hover);color:var(--text)}.wf-pill--active{background:var(--accent);border-color:var(--accent);color:#fff}.wf-results-count{padding:.75rem 1.75rem 0;font-size:.85rem;color:var(--text-dim);flex-shrink:0}.wf-grid{flex:1;overflow-y:auto;padding:.75rem 1.75rem 1.75rem;display:flex;flex-direction:column;gap:.65rem;scrollbar-width:thin;scrollbar-color:var(--surface-hover) transparent;-webkit-overflow-scrolling:touch}.wf-floor-group{display:flex;flex-direction:row;gap:0}.wf-floor-group+.wf-floor-group{margin-top:1rem}.wf-floor-header{display:flex;align-items:center;justify-content:center;width:2.75rem;flex-shrink:0;position:sticky;top:0;align-self:stretch;z-index:2;border-radius:var(--radius) 0 0 var(--radius);background:var(--floor-color, var(--accent))}.wf-floor-label{font-size:.8rem;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:#fff;writing-mode:vertical-rl;transform:rotate(180deg);white-space:nowrap;text-shadow:0 1px 3px rgba(0,0,0,.3)}.wf-floor-cards{display:flex;flex-direction:column;gap:.5rem;flex:1;min-width:0;padding-left:.65rem;border-left:3px solid var(--floor-color, var(--accent))}.wf-floor-group:not(:has(.wf-floor-header)) .wf-floor-cards{border-left:none;padding-left:0}.wf-card{display:flex;align-items:center;gap:1.1rem;padding:1.1rem 1.25rem;background:var(--surface);border:1px solid var(--surface-border);border-radius:var(--radius);cursor:pointer;text-align:left;color:var(--text);font:inherit;min-height:72px;transition:transform .12s,background .12s,box-shadow .12s;animation:cardIn .35s ease both}.wf-card:active{background:var(--surface-hover);transform:scale(.98);box-shadow:0 4px 20px #00000040}.wf-card--here{border-color:#22c55e;box-shadow:inset 0 0 0 1px #22c55e,0 0 12px #22c55e26}.wf-here-badge{display:inline-block;font-size:.65rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:#fff;background:#22c55e;padding:2px 8px;border-radius:999px;margin-left:.5rem;vertical-align:middle}@keyframes cardIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.wf-card-icon{font-size:1.8rem;width:56px;height:56px;display:flex;align-items:center;justify-content:center;border-radius:14px;background:var(--surface-border);flex-shrink:0}.wf-card-body{flex:1;min-width:0}.wf-card-name{font-weight:600;font-size:1.1rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.wf-card-meta{display:flex;align-items:center;gap:.6rem;margin-top:4px}.wf-badge{font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.04em;padding:3px 9px;border-radius:5px;background:#3b82f61f;color:var(--accent)}.wf-badge--lg{font-size:.85rem;padding:4px 11px}.wf-badge--outline{background:transparent;border:1px solid var(--surface-border);color:var(--text-muted);font-size:.75rem}.wf-card-room{font-size:.85rem;color:var(--text-dim)}.wf-card-arrow{flex-shrink:0;color:var(--text-dim);width:24px;height:24px}.wf-empty{text-align:center;padding:3rem 1rem;color:var(--text-muted)}.wf-empty-icon{font-size:3rem;margin-bottom:1rem}.wf-link{background:none;border:none;color:var(--accent);cursor:pointer;font-size:1.05rem;font-weight:500;margin-top:.5rem;text-decoration:underline;text-underline-offset:3px;padding:.5rem 1rem;min-height:48px}.wf-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0009;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:stretch;justify-content:flex-end;z-index:100;animation:fadeIn .2s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.wf-detail{width:min(480px,92vw);background:var(--surface);overflow-y:auto;display:flex;flex-direction:column;animation:slideIn .3s cubic-bezier(.16,1,.3,1);box-shadow:var(--shadow-lg)}@keyframes slideIn{0%{transform:translate(100%)}to{transform:translate(0)}}.wf-detail-close{position:absolute;top:1rem;right:1rem;width:48px;height:48px;display:flex;align-items:center;justify-content:center;background:#0006;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border:none;border-radius:50%;color:#fff;font-size:1.25rem;cursor:pointer;transition:background .15s;z-index:10}.wf-detail-close:active{background:#000000b3}.wf-detail-hero{position:relative;height:200px;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--accent),#6366f1);flex-shrink:0}.wf-detail-icon{font-size:4.5rem;filter:drop-shadow(0 4px 12px rgba(0,0,0,.3))}.wf-detail-content{padding:1.75rem;display:flex;flex-direction:column;gap:1.15rem}.wf-detail-name{font-size:1.75rem;font-weight:700;letter-spacing:-.02em}.wf-detail-tags{display:flex;flex-wrap:wrap;gap:.5rem}.wf-detail-info-grid{display:flex;gap:1.75rem}.wf-detail-info-item{display:flex;align-items:center;gap:.5rem;font-size:1rem;color:var(--text-muted)}.wf-detail-info-item svg{color:var(--accent);flex-shrink:0}.wf-detail-desc{font-size:1.05rem;line-height:1.65;color:var(--text-muted)}.wf-detail-directions{display:flex;align-items:center;justify-content:center;gap:.65rem;padding:1.1rem;font-size:1.1rem;font-weight:600;color:#fff;background:linear-gradient(135deg,var(--accent),#6366f1);border:none;border-radius:var(--radius);cursor:pointer;min-height:56px;transition:opacity .15s,transform .15s;margin-top:.5rem}.wf-detail-directions:active{opacity:.85;transform:scale(.97)}.wf-qr-section{display:flex;flex-direction:column;align-items:center;gap:.6rem;padding:1.25rem 0 .5rem;margin-top:.5rem;border-top:1px solid var(--surface-border)}.wf-qr-code{padding:.75rem;background:var(--surface-hover);border-radius:var(--radius-sm);line-height:0}.wf-qr-code svg{display:block}.wf-qr-label{font-size:.8rem;color:var(--text-dim);text-align:center}.wf-dev-select{height:40px;padding:0 .5rem;background:var(--surface);border:1px solid var(--accent);border-radius:8px;color:var(--text);font-size:.8rem;cursor:pointer;outline:none}.wf-theme-toggle{width:48px;height:48px;display:flex;align-items:center;justify-content:center;background:var(--surface-border);border:1px solid var(--surface-border);border-radius:12px;color:var(--text-muted);cursor:pointer;transition:background .2s,color .2s;flex-shrink:0}.wf-theme-toggle:active{background:var(--surface-hover);color:var(--text)}
