:root{--bg: #0a0a0a;--gold: #c8a060;--blue: #a0c8f0;--violet: #c0a8e0;--amber: #e0a880;--teal: #80c8c0;--text: #e8e8e8;--text-dim: #707070;--panel-bg: rgba(14, 14, 14, .92);--font-display: "Syne", sans-serif;--font-body: "Outfit", sans-serif;--font-mono: "JetBrains Mono", monospace;--ease: cubic-bezier(.16, 1, .3, 1)}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html,body{height:100%;overflow:hidden;background:var(--bg);color:var(--text);font-family:var(--font-body);-webkit-font-smoothing:antialiased}::selection{background:#404044;color:#fff}#boot-screen{position:fixed;inset:0;z-index:1000;background:var(--bg);display:flex;align-items:center;justify-content:center;transition:opacity .5s ease,visibility .5s ease}#boot-screen.done{opacity:0;visibility:hidden;pointer-events:none}.boot-pulse{width:12px;height:12px;border-radius:50%;background:var(--gold);box-shadow:0 0 20px var(--gold),0 0 60px #c8a0604d;animation:bootPulse 1.2s ease-in-out infinite}.boot-skip{position:absolute;bottom:30%;left:50%;transform:translate(-50%);font-family:var(--font-mono);font-size:11px;letter-spacing:2px;text-transform:uppercase;color:var(--text-dim);opacity:0;animation:bootSkipFade .5s ease .4s forwards;cursor:pointer}@keyframes bootPulse{0%,to{transform:scale(1);opacity:.8}50%{transform:scale(1.6);opacity:1}}@keyframes bootSkipFade{to{opacity:.6}}.stroke-char{stroke-dasharray:var(--path-len, 9999);stroke-dashoffset:var(--path-len, 9999);fill-opacity:0}.stroke-char.drawn{stroke-dashoffset:0;fill-opacity:1;stroke-opacity:0;transition:stroke-dashoffset .6s cubic-bezier(.16,1,.3,1),fill-opacity .3s ease .5s,stroke-opacity .3s ease .6s}#network-canvas{position:fixed;inset:0;width:100%;height:100%}#network-canvas canvas{display:block;width:100%;height:100%;cursor:grab}#network-canvas canvas.dragging{cursor:grabbing}#network-canvas canvas.pointer{cursor:pointer}#top-bar{position:fixed;top:0;left:0;right:0;z-index:50;display:flex;align-items:center;justify-content:space-between;padding:0 24px;height:48px;background:#0a0a0ab3;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-bottom:none;opacity:0;transition:opacity .6s ease;pointer-events:none}#top-bar.visible{opacity:1;pointer-events:auto}#top-bar-left{display:flex;align-items:center}#top-bar-right,#desktop-controls{display:flex;align-items:center;gap:6px}#legend{display:flex;gap:16px;font-family:var(--font-mono);font-size:10px;letter-spacing:1.5px;text-transform:uppercase;color:var(--text-dim)}.legend-item{display:flex;align-items:center;cursor:pointer;transition:opacity .3s ease;user-select:none}.legend-item.inactive{opacity:.3}.legend-item.inactive .legend-bar{filter:grayscale(1)}.legend-item.active .legend-bar{box-shadow:0 0 8px currentColor;transform:scaleY(1.3)}.legend-item.active .legend-text{opacity:1;max-width:120px;margin-left:7px;overflow:visible}.legend-bar{width:14px;height:3px;border-radius:2px;display:inline-block;flex-shrink:0;transition:filter .3s ease}.legend-text{display:inline-block;max-width:0;overflow:hidden;opacity:0;margin-left:0;transition:max-width .6s var(--ease),opacity .4s ease,margin-left .4s ease;white-space:nowrap}#legend:hover .legend-text{max-width:120px;opacity:1;margin-left:7px}#title-overlay{position:fixed;top:60px;left:50%;transform:translate(-50%);z-index:50;text-align:center;pointer-events:none;opacity:0;transition:opacity .8s ease}#title-overlay.visible{opacity:1}#title-overlay.hidden{opacity:0}.title-tag-svg{display:block;height:16px;margin:0 auto 10px;color:#707074;filter:drop-shadow(0 0 20px rgba(112,112,116,.4))}.title-name-svg{display:block;height:clamp(32px,5.5vw,52px);margin:0 auto 8px}#detail-panel{position:fixed;top:0;right:0;width:min(440px,92vw);height:100%;z-index:100;background:var(--panel-bg);backdrop-filter:blur(32px);-webkit-backdrop-filter:blur(32px);border-left:3px solid var(--panel-accent, rgba(255, 255, 255, .08));padding:36px 32px;overflow-y:auto;transform:translate(100%);transition:transform .5s var(--ease),border-color .3s ease;mask-image:linear-gradient(to bottom,#000 calc(100% - 48px),transparent 100%);-webkit-mask-image:linear-gradient(to bottom,#000 calc(100% - 48px),transparent 100%)}#detail-panel.open{transform:translate(0)}#detail-panel .detail-title,#detail-panel .detail-subtitle,#detail-panel .detail-date,#detail-panel .detail-body,#detail-panel .detail-code,#detail-panel .detail-tags,#detail-panel .detail-links,#detail-panel .detail-proficiency,#detail-panel .detail-stats,#detail-panel .detail-cta,#detail-panel .detail-related{opacity:0;transform:translateY(10px);animation:none}#detail-panel.open .detail-title{animation:panelFadeIn .4s var(--ease) .08s forwards}#detail-panel.open .detail-subtitle,#detail-panel.open .detail-date{animation:panelFadeIn .4s var(--ease) .16s forwards}#detail-panel.open .detail-body,#detail-panel.open .detail-code{animation:panelFadeIn .4s var(--ease) .24s forwards}#detail-panel.open .detail-stats,#detail-panel.open .detail-tags,#detail-panel.open .detail-proficiency{animation:panelFadeIn .4s var(--ease) .32s forwards}#detail-panel.open .detail-links,#detail-panel.open .detail-cta{animation:panelFadeIn .4s var(--ease) .4s forwards}#detail-panel.open .detail-related{animation:panelFadeIn .4s var(--ease) .48s forwards}@keyframes panelFadeIn{to{opacity:1;transform:translateY(0)}}#detail-panel::-webkit-scrollbar{width:4px}#detail-panel::-webkit-scrollbar-track{background:transparent}#detail-panel::-webkit-scrollbar-thumb{background:#ffffff1a;border-radius:2px}#detail-close{position:absolute;top:20px;right:20px;width:36px;height:36px;font-size:24px;color:var(--text-dim);cursor:pointer;border:1px solid rgba(255,255,255,.06);border-radius:6px;background:#ffffff08;display:flex;align-items:center;justify-content:center;transition:color .2s,border-color .2s;font-family:var(--font-body)}#detail-close:hover{color:var(--text);border-color:#ffffff26}.detail-drag-handle{display:none;width:36px;height:4px;border-radius:2px;background:#fff3;margin:0 auto 12px}#detail-category{font-family:var(--font-mono);font-size:11px;letter-spacing:3px;text-transform:uppercase;margin-bottom:16px;padding-bottom:16px;border-bottom:1px solid rgba(255,255,255,.06)}.detail-title{font-family:var(--font-display);font-size:28px;font-weight:800;margin-bottom:8px;line-height:1.15}.detail-subtitle{font-family:var(--font-mono);font-size:13px;color:var(--text-dim);margin-bottom:24px}.detail-body p{font-size:15px;line-height:1.75;color:#e4e4f0bf;margin-bottom:20px}.detail-stats{display:grid;grid-template-columns:repeat(2,1fr);gap:12px;margin:24px 0}.detail-stat{background:#ffffff08;border:1px solid rgba(255,255,255,.05);border-radius:8px;padding:16px;text-align:center}.detail-stat .stat-val{font-family:var(--font-display);font-size:28px;font-weight:800;display:block;line-height:1;margin-bottom:4px}.detail-stat .stat-lbl{font-family:var(--font-mono);font-size:10px;letter-spacing:1px;text-transform:uppercase;color:var(--text-dim)}.detail-tags{display:flex;flex-wrap:wrap;gap:8px;margin:16px 0 20px}.detail-tags span{font-family:var(--font-mono);font-size:11px;letter-spacing:1px;text-transform:uppercase;padding:5px 14px;border-radius:20px;border:1px solid rgba(160,200,240,.2);background:#a0c8f014;color:var(--blue);transition:background .2s,border-color .2s}.detail-tags span:hover{background:#a0c8f026;border-color:#a0c8f04d}.detail-links{display:flex;gap:16px;margin-top:20px}.detail-links a{font-family:var(--font-mono);font-size:12px;letter-spacing:1px;text-transform:uppercase;padding:10px 20px;border:1px solid rgba(224,224,228,.2);border-radius:3px;color:var(--blue);text-decoration:none;transition:background .2s,box-shadow .2s}.detail-links a:hover{background:#ffffff1a;box-shadow:0 0 20px #ffffff14}.detail-proficiency{margin:20px 0}.prof-bar-track{width:100%;height:6px;background:#ffffff0f;border-radius:3px;overflow:hidden;margin-top:8px}.prof-bar-fill{height:100%;border-radius:3px;background:linear-gradient(90deg,var(--blue),var(--violet));box-shadow:0 0 12px #fff3;transition:width .8s var(--ease);width:0}.prof-label{font-family:var(--font-mono);font-size:12px;color:var(--text-dim);display:flex;justify-content:space-between}.detail-related{margin-top:24px}.detail-related h4{font-family:var(--font-mono);font-size:11px;letter-spacing:2px;text-transform:uppercase;color:var(--text-dim);margin-bottom:12px}.related-list{display:flex;flex-wrap:wrap;gap:8px}.related-chip{font-family:var(--font-mono);font-size:11px;padding:5px 12px;border-radius:3px;background:#ffffff0a;border:1px solid rgba(255,255,255,.06);color:var(--text);cursor:pointer;transition:border-color .2s,background .2s}.related-chip:hover{border-color:#ffffff26;background:#ffffff14}.detail-date{font-family:var(--font-mono);font-size:12px;letter-spacing:2px;margin-bottom:16px}.detail-cta{display:inline-block;font-family:var(--font-mono);font-size:13px;letter-spacing:1px;padding:12px 28px;border:1px solid var(--blue);border-radius:3px;color:var(--blue);text-decoration:none;margin-top:16px;transition:background .2s,box-shadow .2s}.detail-cta:hover{background:#ffffff1a;box-shadow:0 0 20px #ffffff1a}.path-steps{line-height:2;word-break:break-word}.detail-code{background:#0006;border:1px solid rgba(255,255,255,.05);border-radius:8px;padding:16px;margin:16px 0;font-family:var(--font-mono);font-size:12px;line-height:1.8;overflow-x:auto;white-space:pre-wrap;word-break:break-word}.ck{color:var(--amber)}.cc{color:var(--blue)}.cf{color:var(--gold)}.cs{color:var(--teal)}.cp{color:var(--violet)}#back-btn{position:fixed;top:60px;left:24px;z-index:100;font-family:var(--font-mono);font-size:13px;letter-spacing:1px;padding:10px 20px;border:1px solid rgba(255,255,255,.1);border-radius:4px;background:#121212d1;backdrop-filter:blur(12px);color:var(--text-dim);cursor:pointer;opacity:0;visibility:hidden;transition:opacity .4s ease,visibility .4s ease,color .2s,border-color .2s}#back-btn.visible{opacity:1;visibility:visible}#back-btn:hover{color:var(--text);border-color:#fff3}#settings-btn,#pathfinder-btn{width:32px;height:32px;display:flex;align-items:center;justify-content:center;border:1px solid rgba(255,255,255,.06);border-radius:6px;background:transparent;color:var(--text-dim);cursor:pointer;transition:color .2s,border-color .2s,background .2s}#settings-btn:hover,#pathfinder-btn:hover{color:var(--text);border-color:#ffffff26;background:#ffffff0a}#pathfinder-btn.active{color:var(--gold);border-color:#c8a06066;background:#c8a0601a}#settings-panel{position:fixed;top:54px;right:24px;width:280px;max-height:calc(100vh - 80px);overflow-y:auto;z-index:110;background:#0e0e0eeb;backdrop-filter:blur(32px);-webkit-backdrop-filter:blur(32px);border:1px solid rgba(255,255,255,.1);border-radius:12px;padding:20px;opacity:0;visibility:hidden;transform:translateY(-8px) scale(.96);transform-origin:top right;transition:opacity .25s ease,visibility .25s ease,transform .25s var(--ease)}#settings-panel.open{opacity:1;visibility:visible;transform:translateY(0) scale(1)}#settings-panel::-webkit-scrollbar{width:3px}#settings-panel::-webkit-scrollbar-track{background:transparent}#settings-panel::-webkit-scrollbar-thumb{background:#ffffff1a;border-radius:2px}.settings-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px;padding-bottom:12px;border-bottom:1px solid rgba(255,255,255,.1)}.settings-title{font-family:var(--font-mono);font-size:11px;letter-spacing:3px;color:var(--text-dim)}#settings-close{width:28px;height:28px;font-size:18px;color:var(--text-dim);cursor:pointer;border:1px solid rgba(255,255,255,.1);border-radius:5px;background:#ffffff08;display:flex;align-items:center;justify-content:center;transition:color .2s,border-color .2s;font-family:var(--font-body)}#settings-close:hover{color:var(--text);border-color:#ffffff26}.settings-group{margin-bottom:16px}.settings-group-label{font-family:var(--font-mono);font-size:9px;letter-spacing:2px;color:var(--text-dim);margin-bottom:10px}.settings-row{display:flex;justify-content:space-between;align-items:center;padding:6px 0}.settings-row label{font-family:var(--font-body);font-size:13px;color:#e4e4f0bf}.settings-value{font-family:var(--font-mono);font-size:10px;color:var(--text-dim);margin-left:6px}.settings-toggle{appearance:none;-webkit-appearance:none;width:36px;height:20px;border-radius:10px;background:#ffffff14;border:1px solid rgba(255,255,255,.1);cursor:pointer;position:relative;transition:background .2s,border-color .2s;flex-shrink:0}.settings-toggle:after{content:"";position:absolute;top:2px;left:2px;width:14px;height:14px;border-radius:50%;background:var(--text-dim);transition:transform .2s var(--ease),background .2s}.settings-toggle:checked{background:#c8a06040;border-color:#c8a06080}.settings-toggle:checked:after{transform:translate(16px);background:var(--gold)}.settings-select{font-family:var(--font-mono);font-size:11px;letter-spacing:.5px;color:var(--text);background:#ffffff0a;border:1px solid rgba(255,255,255,.08);border-radius:4px;padding:4px 8px;outline:none;cursor:pointer;transition:border-color .2s}.settings-select:focus{border-color:#fff3}.settings-select option{background:#0a0a0a;color:var(--text)}.settings-slider{appearance:none;-webkit-appearance:none;width:100px;height:4px;border-radius:2px;background:#ffffff14;outline:none;cursor:pointer}.settings-slider::-webkit-slider-thumb{appearance:none;-webkit-appearance:none;width:12px;height:12px;border-radius:50%;background:var(--gold);border:none;cursor:pointer}.settings-slider::-moz-range-thumb{width:12px;height:12px;border-radius:50%;background:var(--gold);border:none;cursor:pointer}.pw-group{border-top:none!important;margin-top:0;padding-top:4px}.pw-row{gap:6px}.settings-pw{width:60px;padding:3px 6px;background:transparent;border:1px solid rgba(255,255,255,.06);border-radius:3px;color:var(--text-dim);font-family:var(--font-mono);font-size:10px;outline:none;transition:border-color .3s ease}.settings-pw:focus{border-color:#ffffff26}.pw-status{color:#6dca6d80;font-family:var(--font-mono);font-size:10px}.pw-lock-btn{background:none;border:none;color:#ffffff26;font-size:12px;cursor:pointer;padding:0 4px;line-height:1}.pw-lock-btn:hover{color:#fff6}#pathfinder-status{position:fixed;bottom:70px;left:50%;transform:translate(-50%);z-index:60;font-family:var(--font-mono);font-size:12px;letter-spacing:1.5px;text-transform:uppercase;color:var(--gold);background:#0e0e0ee6;border:1px solid rgba(200,160,96,.25);border-radius:6px;padding:8px 20px;opacity:0;visibility:hidden;transition:opacity .3s ease,visibility .3s ease;pointer-events:none;white-space:nowrap}#pathfinder-status.visible{opacity:1;visibility:visible}#cursor-canvas{position:fixed;inset:0;width:100%;height:100%;z-index:10000;pointer-events:none;display:none}#node-dir{position:relative}#node-dir-toggle{font-family:var(--font-mono);font-size:11px;letter-spacing:2px;text-transform:uppercase;padding:6px 14px;border:1px solid rgba(255,255,255,.06);border-radius:6px;background:transparent;color:var(--text-dim);cursor:pointer;transition:color .2s,border-color .2s,background .2s}#node-dir-toggle:hover{color:var(--text);border-color:#ffffff26;background:#ffffff0a}#node-dir-list{position:absolute;top:calc(100% + 6px);right:0;width:200px;max-height:400px;overflow-y:auto;background:#0e0e0eeb;backdrop-filter:blur(24px);-webkit-backdrop-filter:blur(24px);border:1px solid rgba(255,255,255,.1);border-radius:8px;padding:6px;display:none}#node-dir-list.open{display:block}#node-dir-list::-webkit-scrollbar{width:3px}#node-dir-list::-webkit-scrollbar-track{background:transparent}#node-dir-list::-webkit-scrollbar-thumb{background:#ffffff1a;border-radius:2px}.dir-heading{font-family:var(--font-mono);font-size:9px;letter-spacing:2px;text-transform:uppercase;color:var(--text-dim);padding:8px 10px 4px}.dir-item{font-family:var(--font-body);font-size:12px;text-transform:uppercase;padding:6px 10px;border-radius:4px;color:var(--text);cursor:pointer;transition:background .15s;display:flex;align-items:center;gap:8px}.dir-item:hover{background:#ffffff1a}.dir-dot{width:6px;height:6px;border-radius:50%;flex-shrink:0}#node-tooltip{position:fixed;z-index:200;pointer-events:none;background:#0e0e0ef2;border:1px solid rgba(255,255,255,.08);border-radius:6px;padding:8px 14px;opacity:0;transition:opacity .15s ease;display:flex;flex-direction:column;gap:2px}#node-tooltip.visible{opacity:1}.tooltip-cat{font-family:var(--font-mono);font-size:9px;letter-spacing:2px;text-transform:uppercase}.tooltip-name{font-family:var(--font-display);font-size:14px;font-weight:700;color:var(--text)}#minimap-wrap{position:fixed;bottom:24px;left:24px;width:180px;z-index:50;border-radius:8px;opacity:0;pointer-events:none;transform-origin:bottom left;will-change:transform;transition:opacity .6s ease,transform .4s cubic-bezier(.22,1,.36,1),border-color .3s ease;border:1px solid rgba(255,255,255,.1);cursor:pointer}#minimap-wrap.visible{opacity:1;pointer-events:auto}#minimap-wrap:hover{transform:scale(2);border-color:#ffffff26}#minimap{display:block;width:100%;height:auto;border-radius:7px;background:#121212d1}#minimap-lens{position:absolute;width:48px;height:48px;border-radius:4px;border:1px solid rgba(255,255,255,.5);pointer-events:none;display:none;overflow:hidden;box-shadow:0 0 8px #00000080;z-index:2}#minimap-lens canvas{display:block}#minimap-overlay{position:absolute;inset:0;border-radius:7px;pointer-events:none;display:none;z-index:1;background:#00000059;--lens-size: 24px;-webkit-mask-image:linear-gradient(black,black);mask-image:linear-gradient(#000,#000);-webkit-mask-composite:exclude;clip-path:polygon(0% 0%,100% 0%,100% 100%,0% 100%,0% 0%,var(--lens-l) var(--lens-t),var(--lens-l) var(--lens-b),var(--lens-r) var(--lens-b),var(--lens-r) var(--lens-t),var(--lens-l) var(--lens-t))}#screenshot-btn{width:32px;height:32px;display:flex;align-items:center;justify-content:center;border:1px solid rgba(255,255,255,.06);border-radius:6px;background:transparent;color:var(--text-dim);cursor:pointer;transition:color .2s,border-color .2s,background .2s}#screenshot-btn:hover{color:var(--text);border-color:#ffffff26;background:#ffffff0a}#fps-counter{position:fixed;top:60px;left:24px;z-index:200;font-family:var(--font-mono);font-size:11px;letter-spacing:2px;color:var(--text-dim);background:#0e0e0ed9;border:1px solid rgba(255,255,255,.1);border-radius:4px;padding:4px 10px;pointer-events:none}#webgl-fallback{position:fixed;inset:0;z-index:500;background:var(--bg);display:flex;align-items:center;justify-content:center;text-align:center}.fallback-content h1{font-family:var(--font-display);font-weight:800;font-size:36px;letter-spacing:2px;margin-bottom:8px;background:linear-gradient(135deg,#fff,#b0b0b4,#707074);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.fallback-content p{font-size:15px;color:var(--text-dim);margin-bottom:12px}.fallback-note{font-family:var(--font-mono);font-size:12px!important;line-height:1.8;margin-top:24px!important}.fallback-links{display:flex;gap:16px;justify-content:center;margin-top:24px}.fallback-links a{font-family:var(--font-mono);font-size:12px;letter-spacing:1px;text-transform:uppercase;padding:10px 24px;border:1px solid rgba(255,255,255,.15);border-radius:4px;color:var(--blue);text-decoration:none;transition:background .2s,border-color .2s}.fallback-links a:hover{background:#ffffff1a;border-color:#ffffff40}.dir-search{display:block;width:calc(100% - 12px);margin:4px 6px 6px;padding:6px 10px;font-family:var(--font-mono);font-size:11px;letter-spacing:.5px;color:var(--text);background:#ffffff0a;border:1px solid rgba(255,255,255,.08);border-radius:4px;outline:none;transition:border-color .2s}.dir-search::placeholder{color:var(--text-dim)}.dir-search:focus{border-color:#fff3}#hamburger-btn{display:none;width:44px;height:44px;flex-direction:column;align-items:center;justify-content:center;gap:5px;border:1px solid rgba(255,255,255,.06);border-radius:6px;background:transparent;cursor:pointer;transition:border-color .2s;-webkit-tap-highlight-color:transparent}#hamburger-btn:active{border-color:#fff3}.hamburger-line{display:block;width:18px;height:1.5px;background:var(--text-dim);border-radius:1px;transition:transform .3s var(--ease),opacity .3s ease}#hamburger-btn.active .hamburger-line:nth-child(1){transform:translateY(6.5px) rotate(45deg)}#hamburger-btn.active .hamburger-line:nth-child(2){opacity:0}#hamburger-btn.active .hamburger-line:nth-child(3){transform:translateY(-6.5px) rotate(-45deg)}#mobile-menu{display:none;position:fixed;inset:44px 0 0;z-index:90;background:#0a0a0af2;backdrop-filter:blur(24px);-webkit-backdrop-filter:blur(24px);overflow-y:auto;opacity:0;visibility:hidden;transition:opacity .3s ease,visibility .3s ease;-webkit-overflow-scrolling:touch}#mobile-menu.open{opacity:1;visibility:visible}#mobile-menu-content{padding:16px 20px 40px}.mobile-menu-section{margin-bottom:20px;padding-bottom:16px;border-bottom:1px solid rgba(255,255,255,.06)}.mobile-menu-section:last-child{border-bottom:none}.mobile-menu-row{display:flex;gap:10px}.mobile-menu-btn{flex:1;display:flex;align-items:center;justify-content:center;gap:8px;padding:12px 16px;border:1px solid rgba(255,255,255,.08);border-radius:8px;background:#ffffff08;color:var(--text-dim);font-family:var(--font-mono);font-size:11px;letter-spacing:1px;text-transform:uppercase;cursor:pointer;transition:border-color .2s,color .2s;-webkit-tap-highlight-color:transparent;min-height:44px}.mobile-menu-btn:active{border-color:#fff3;color:var(--text)}.mobile-menu-btn.active{color:var(--gold);border-color:#c8a06066}#mobile-node-dir-list{max-height:200px;overflow-y:auto;-webkit-overflow-scrolling:touch}@media(max-width:768px){.mobile-menu-btn:active,#hamburger-btn:active,#back-btn:active,.related-chip:active,.legend-item:active{background:#c8a0601a;transition:background .05s}}@media(max-width:768px){#hamburger-btn{display:flex}#desktop-controls{display:none}#mobile-menu{display:block}#settings-panel{display:none!important}#legend{gap:12px;font-size:9px;overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none;max-width:calc(100vw - 80px)}#legend::-webkit-scrollbar{display:none}#legend .legend-text{max-width:60px;opacity:.7;margin-left:5px;overflow:hidden;text-overflow:ellipsis}#detail-panel{width:100%;border-left:none;border-top:3px solid var(--panel-accent, rgba(255, 255, 255, .08));top:auto;bottom:0;height:65vh;transform:translateY(100%);border-radius:16px 16px 0 0;padding:12px 24px 36px}#detail-panel.open{transform:translateY(0)}.detail-drag-handle{display:block}#top-bar{padding:0 12px;height:44px}#title-overlay{top:52px}.title-tag-svg{height:10px;margin-bottom:6px}.title-name-svg{height:clamp(20px,4vw,28px)}#back-btn{top:52px;left:12px;font-size:12px;padding:8px 14px;min-height:44px}#minimap-wrap{display:none}#cursor-canvas{display:none!important}.related-chip,.detail-links a,.detail-cta{min-height:44px;display:inline-flex;align-items:center}.legend-item{min-height:44px;display:flex;align-items:center}}@media(max-width:480px){.title-name-svg{height:clamp(16px,3.5vw,22px)}.title-tag-svg{height:8px}#top-bar{padding:0 8px}#legend{gap:8px}}@media(prefers-reduced-motion:reduce){*,*:before,*:after{animation-duration:.01ms!important;transition-duration:.2s!important}}#onboarding-hints{position:fixed;bottom:80px;left:50%;transform:translate(-50%);display:flex;flex-direction:column;align-items:center;gap:8px;z-index:100;pointer-events:none}.onboarding-hint{display:flex;align-items:center;gap:8px;padding:6px 14px;background:#14141480;backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);border:1px solid rgba(255,255,255,.06);border-radius:16px;color:#fff6;font-family:Outfit,sans-serif;font-size:12px;letter-spacing:.3px;opacity:0;transform:translateY(8px);transition:opacity .6s,transform .6s}.onboarding-hint.visible{opacity:1;transform:translateY(0)}.onboarding-hint.fade-out{opacity:0;transform:translateY(-8px)}
