:root,:host{--ol-background-color: white;--ol-accent-background-color: #F5F5F5;--ol-subtle-background-color: rgba(128, 128, 128, .25);--ol-partial-background-color: rgba(255, 255, 255, .75);--ol-foreground-color: #333333;--ol-subtle-foreground-color: #666666;--ol-brand-color: #00AAFF}.ol-box{box-sizing:border-box;border-radius:2px;border:1.5px solid var(--ol-background-color);background-color:var(--ol-partial-background-color)}.ol-mouse-position{top:8px;right:8px;position:absolute}.ol-scale-line{background:var(--ol-partial-background-color);border-radius:4px;bottom:8px;left:8px;padding:2px;position:absolute}.ol-scale-line-inner{border:1px solid var(--ol-subtle-foreground-color);border-top:none;color:var(--ol-foreground-color);font-size:10px;text-align:center;margin:1px;will-change:contents,width;transition:all .25s}.ol-scale-bar{position:absolute;bottom:8px;left:8px}.ol-scale-bar-inner{display:flex}.ol-scale-step-marker{width:1px;height:15px;background-color:var(--ol-foreground-color);float:right;z-index:10}.ol-scale-step-text{position:absolute;bottom:-5px;font-size:10px;z-index:11;color:var(--ol-foreground-color);text-shadow:-1.5px 0 var(--ol-partial-background-color),0 1.5px var(--ol-partial-background-color),1.5px 0 var(--ol-partial-background-color),0 -1.5px var(--ol-partial-background-color)}.ol-scale-text{position:absolute;font-size:12px;text-align:center;bottom:25px;color:var(--ol-foreground-color);text-shadow:-1.5px 0 var(--ol-partial-background-color),0 1.5px var(--ol-partial-background-color),1.5px 0 var(--ol-partial-background-color),0 -1.5px var(--ol-partial-background-color)}.ol-scale-singlebar{position:relative;height:10px;z-index:9;box-sizing:border-box;border:1px solid var(--ol-foreground-color)}.ol-scale-singlebar-even{background-color:var(--ol-subtle-foreground-color)}.ol-scale-singlebar-odd{background-color:var(--ol-background-color)}.ol-unsupported{display:none}.ol-viewport,.ol-unselectable{-webkit-touch-callout:none;-webkit-user-select:none;-moz-user-select:none;user-select:none;-webkit-tap-highlight-color:transparent}.ol-viewport canvas{all:unset;overflow:hidden}.ol-viewport{touch-action:pan-x pan-y}.ol-selectable{-webkit-touch-callout:default;-webkit-user-select:text;-moz-user-select:text;user-select:text}.ol-grabbing{cursor:-webkit-grabbing;cursor:-moz-grabbing;cursor:grabbing}.ol-grab{cursor:move;cursor:-webkit-grab;cursor:-moz-grab;cursor:grab}.ol-control{position:absolute;background-color:var(--ol-subtle-background-color);border-radius:4px}.ol-zoom{top:.5em;left:.5em}.ol-rotate{top:.5em;right:.5em;transition:opacity .25s linear,visibility 0s linear}.ol-rotate.ol-hidden{opacity:0;visibility:hidden;transition:opacity .25s linear,visibility 0s linear .25s}.ol-zoom-extent{top:4.643em;left:.5em}.ol-full-screen{right:.5em;top:.5em}.ol-control button{display:block;margin:1px;padding:0;color:var(--ol-subtle-foreground-color);font-weight:700;text-decoration:none;font-size:inherit;text-align:center;height:1.375em;width:1.375em;line-height:.4em;background-color:var(--ol-background-color);border:none;border-radius:2px}.ol-control button::-moz-focus-inner{border:none;padding:0}.ol-zoom-extent button{line-height:1.4em}.ol-compass{display:block;font-weight:400;will-change:transform}.ol-touch .ol-control button{font-size:1.5em}.ol-touch .ol-zoom-extent{top:5.5em}.ol-control button:hover,.ol-control button:focus{text-decoration:none;outline:1px solid var(--ol-subtle-foreground-color);color:var(--ol-foreground-color)}.ol-zoom .ol-zoom-in{border-radius:2px 2px 0 0}.ol-zoom .ol-zoom-out{border-radius:0 0 2px 2px}.ol-attribution{text-align:right;bottom:.5em;right:.5em;max-width:calc(100% - 1.3em);display:flex;flex-flow:row-reverse;align-items:center}.ol-attribution a{color:var(--ol-subtle-foreground-color);text-decoration:none}.ol-attribution ul{margin:0;padding:1px .5em;color:var(--ol-foreground-color);text-shadow:0 0 2px var(--ol-background-color);font-size:12px}.ol-attribution li{display:inline;list-style:none}.ol-attribution li:not(:last-child):after{content:" "}.ol-attribution img{max-height:2em;max-width:inherit;vertical-align:middle}.ol-attribution button{flex-shrink:0}.ol-attribution.ol-collapsed ul{display:none}.ol-attribution:not(.ol-collapsed){background:var(--ol-partial-background-color)}.ol-attribution.ol-uncollapsible{bottom:0;right:0;border-radius:4px 0 0}.ol-attribution.ol-uncollapsible img{margin-top:-.2em;max-height:1.6em}.ol-attribution.ol-uncollapsible button{display:none}.ol-zoomslider{top:4.5em;left:.5em;height:200px}.ol-zoomslider button{position:relative;height:10px}.ol-touch .ol-zoomslider{top:5.5em}.ol-overviewmap{left:.5em;bottom:.5em}.ol-overviewmap.ol-uncollapsible{bottom:0;left:0;border-radius:0 4px 0 0}.ol-overviewmap .ol-overviewmap-map,.ol-overviewmap button{display:block}.ol-overviewmap .ol-overviewmap-map{border:1px solid var(--ol-subtle-foreground-color);height:150px;width:150px}.ol-overviewmap:not(.ol-collapsed) button{bottom:0;left:0;position:absolute}.ol-overviewmap.ol-collapsed .ol-overviewmap-map,.ol-overviewmap.ol-uncollapsible button{display:none}.ol-overviewmap:not(.ol-collapsed){background:var(--ol-subtle-background-color)}.ol-overviewmap-box{border:1.5px dotted var(--ol-subtle-foreground-color)}.ol-overviewmap .ol-overviewmap-box:hover{cursor:move}:root{--color-primary: #2c5282;--color-primary-dark: #1a365d;--color-primary-light: #4299e1;--color-secondary: #38a169;--color-background: #f7fafc;--color-surface: #ffffff;--color-text: #1a202c;--color-text-muted: #718096;--color-border: #e2e8f0;--color-error: #e53e3e;--color-warning: #dd6b20;--color-success: #38a169;--font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;--font-size-base: 16px;--font-size-sm: .875rem;--font-size-lg: 1.125rem;--font-size-xl: 1.5rem;--line-height: 1.5;--spacing-xs: .25rem;--spacing-sm: .5rem;--spacing-md: 1rem;--spacing-lg: 1.5rem;--spacing-xl: 2rem;--sidepanel-width: 350px;--header-height: 60px;--z-index-map: 1;--z-index-ui: 10;--z-index-sidepanel: 20;--z-index-modal: 100;--transition-fast: .15s ease-in-out;--transition-normal: .25s ease-in-out;--shadow-sm: 0 1px 2px rgba(0, 0, 0, .05);--shadow-md: 0 4px 6px rgba(0, 0, 0, .1);--shadow-lg: 0 10px 15px rgba(0, 0, 0, .15);--radius-sm: 4px;--radius-md: 8px;--radius-lg: 12px}*,*:before,*:after{box-sizing:border-box}html{font-size:var(--font-size-base);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{margin:0;padding:0;font-family:var(--font-family);line-height:var(--line-height);color:var(--color-text);background-color:var(--color-background);overflow:hidden}#app{width:100vw;height:100vh;position:relative}html,body{height:100%;width:100%}#map-container{position:absolute;top:56px;left:0;right:0;bottom:0;background-color:#1a1a2e;z-index:var(--z-index-map)}@media (max-width: 480px){#map-container{top:48px}}.error-overlay{position:absolute;top:0;left:0;width:100%;height:100%;display:flex;align-items:center;justify-content:center;background-color:#000c}.error-overlay .error-message{background-color:var(--color-surface);padding:var(--spacing-xl);border-radius:var(--radius-lg);max-width:400px;text-align:center}.error-overlay h2{color:var(--color-error);margin-bottom:var(--spacing-md)}.error-overlay button{margin-top:var(--spacing-md);padding:var(--spacing-sm) var(--spacing-lg);background-color:var(--color-primary);color:#fff;border:none;border-radius:var(--radius-md);cursor:pointer;font-size:var(--font-size-base)}.error-overlay button:hover{background-color:var(--color-primary-dark)}.ol-viewport{touch-action:none}.ol-zoom{position:absolute;top:var(--spacing-md);right:var(--spacing-md);left:auto}.ol-zoom button{background-color:var(--color-surface);color:var(--color-text);border:1px solid var(--color-border);padding:var(--spacing-sm);cursor:pointer;transition:background-color var(--transition-fast)}.ol-zoom button:hover{background-color:var(--color-background)}.sidepanel{grid-area:sidepanel;width:var(--sidepanel-width);height:100vh;background-color:var(--color-surface);border-left:1px solid var(--color-border);box-shadow:var(--shadow-lg);z-index:var(--z-index-sidepanel);overflow-y:auto;display:flex;flex-direction:column}.sidepanel-content{padding:var(--spacing-lg);flex:1}.sidepanel h2{margin:0 0 var(--spacing-md);font-size:var(--font-size-xl);color:var(--color-primary-dark)}.sidepanel p{margin:0 0 var(--spacing-md);color:var(--color-text-muted)}.search-container{grid-area:search;position:absolute;top:var(--spacing-md);left:50%;transform:translate(-50%);z-index:var(--z-index-ui);width:100%;max-width:400px;padding:0 var(--spacing-md)}.search-input{width:100%;padding:var(--spacing-sm) var(--spacing-md);font-size:var(--font-size-base);border:1px solid var(--color-border);border-radius:var(--radius-md);background-color:var(--color-surface);box-shadow:var(--shadow-md);transition:border-color var(--transition-fast),box-shadow var(--transition-fast)}.search-input:focus{outline:none;border-color:var(--color-primary);box-shadow:var(--shadow-lg),0 0 0 3px #4299e133}.breadcrumb{position:absolute;bottom:var(--spacing-md);left:var(--spacing-md);z-index:var(--z-index-ui);background-color:var(--color-surface);padding:var(--spacing-sm) var(--spacing-md);border-radius:var(--radius-md);box-shadow:var(--shadow-md);display:flex;align-items:center;gap:var(--spacing-sm);font-size:var(--font-size-sm)}.breadcrumb a{color:var(--color-primary);text-decoration:none;transition:color var(--transition-fast)}.breadcrumb a:hover{color:var(--color-primary-dark);text-decoration:underline}.breadcrumb-separator{color:var(--color-text-muted)}.loading-message{text-align:center;color:var(--color-text-muted);padding:var(--spacing-xl)}.error-message{color:var(--color-error);background-color:#fed7d7;padding:var(--spacing-md);border-radius:var(--radius-md);border:1px solid #fc8181}.noscript-warning{position:fixed;top:0;left:0;width:100%;height:100%;display:flex;align-items:center;justify-content:center;background-color:var(--color-background);z-index:9999}.noscript-warning p{padding:var(--spacing-xl);background-color:var(--color-surface);border-radius:var(--radius-md);box-shadow:var(--shadow-lg);max-width:400px;text-align:center}@media (max-width: 1024px){:root{--sidepanel-width: 300px}}@media (max-width: 768px){#app{grid-template-columns:1fr;grid-template-rows:1fr;grid-template-areas:"map"}.sidepanel{position:fixed;width:100%;height:50vh;bottom:0;left:0;border-left:none;border-top:1px solid var(--color-border);border-radius:var(--radius-lg) var(--radius-lg) 0 0;transform:translateY(calc(100% - 60px));transition:transform var(--transition-normal)}.sidepanel.expanded{transform:translateY(0)}.search-container{max-width:calc(100% - var(--spacing-xl))}.breadcrumb{max-width:calc(100% - var(--spacing-xl));overflow-x:auto;white-space:nowrap}}:focus-visible{outline:2px solid var(--color-primary);outline-offset:2px}:focus:not(:focus-visible){outline:none}.skip-link{position:absolute;top:-100px;left:16px;background:var(--color-primary);color:#fff;padding:var(--spacing-sm) var(--spacing-md);z-index:9999;border-radius:var(--radius-md);text-decoration:none;font-weight:500;transition:top var(--transition-fast)}.skip-link:focus{top:16px}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}@media (prefers-reduced-motion: reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}}@media (prefers-contrast: high){:root{--color-border: #000000;--color-text-muted: #000000}}.toolbar{position:absolute;top:0;left:0;right:0;height:56px;background:#fff;border-bottom:1px solid #e5e7eb;display:flex;align-items:center;padding:0 16px;gap:16px;z-index:1000;box-shadow:0 1px 3px #0000000d}.toolbar-brand{display:flex;align-items:center;gap:8px;flex-shrink:0}.toolbar-logo{font-size:1.5rem}.toolbar-title{font-size:1.1rem;font-weight:600;color:#1f2937;white-space:nowrap}.toolbar-search{flex:1;display:flex;justify-content:center;max-width:400px;margin:0 auto}.toolbar-actions{display:flex;align-items:center;gap:8px;flex-shrink:0}@media (max-width: 768px){.toolbar{padding:0 12px;gap:12px}.toolbar-title{display:none}.toolbar-search{flex:1;max-width:none;margin:0}}@media (max-width: 480px){.toolbar{height:48px;padding:0 8px}.toolbar-brand{display:none}}.search-field{position:relative;width:100%;max-width:300px}.search-input-wrapper{display:flex;align-items:center;background:#f9fafb;border:1px solid #d1d5db;border-radius:8px;padding:0 12px;transition:border-color .15s,box-shadow .15s,background .15s}.search-field--open .search-input-wrapper,.search-input-wrapper:focus-within{background:#fff;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.search-icon{font-size:.9rem;color:#9ca3af;margin-right:8px;flex-shrink:0}.search-input{flex:1;border:none;outline:none;padding:10px 0;font-size:.95rem;background:transparent;min-width:0}.search-input::placeholder{color:#9ca3af}.search-clear{background:none;border:none;font-size:1.2rem;color:#9ca3af;cursor:pointer;padding:4px;line-height:1;flex-shrink:0;border-radius:4px;transition:background .1s,color .1s}.search-clear:hover{color:#374151;background:#e5e7eb}.search-results{position:absolute;top:100%;left:0;right:0;margin-top:4px;background:#fff;border:1px solid #d1d5db;border-radius:8px;box-shadow:0 4px 12px #0000001a;max-height:300px;overflow-y:auto;list-style:none;padding:4px;z-index:1001}.search-result{display:flex;align-items:center;gap:12px;padding:10px 12px;cursor:pointer;border-radius:6px;transition:background .1s}.search-result:hover,.search-result--selected{background:#f3f4f6}.search-result-type{font-size:1.1rem;flex-shrink:0}.search-result-type--structure{color:#3b82f6}.search-result-type--keb{color:#f59e0b}.search-result-content{flex:1;min-width:0}.search-result-name{display:block;font-weight:500;color:#374151;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.search-result-category{display:block;font-size:.8rem;color:#9ca3af;margin-top:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.search-no-results{padding:16px;text-align:center;color:#9ca3af;font-size:.9rem}@media (max-width: 768px){.search-field{max-width:none}.search-results{max-height:250px}}.search-kbd-hint{display:none;align-items:center;gap:2px;color:#9ca3af;font-size:.75rem;margin-left:8px}.search-input-wrapper:not(:focus-within) .search-kbd-hint{display:flex}.search-kbd{background:#e5e7eb;border-radius:3px;padding:2px 4px;font-family:monospace;font-size:.7rem}@media (max-width: 768px){.search-kbd-hint{display:none!important}}.search-filter-toggle{background:none;border:none;padding:4px 8px;cursor:pointer;display:flex;align-items:center;gap:4px;color:#6b7280;border-radius:4px;flex-shrink:0;transition:background .1s,color .1s}.search-filter-toggle:hover{background:#f3f4f6}.search-filter-toggle--active{background:#eff6ff;color:#3b82f6}.filter-icon{font-size:.9rem}.filter-count{background:#3b82f6;color:#fff;font-size:.65rem;padding:2px 6px;border-radius:10px;min-width:16px;text-align:center;font-weight:600}.search-filters{position:absolute;top:100%;left:0;right:0;margin-top:4px;background:#fff;border:1px solid #d1d5db;border-radius:8px;padding:12px;box-shadow:0 4px 12px #0000001a;z-index:1002}.search-filter-section{margin-bottom:12px}.search-filter-section:last-of-type{margin-bottom:16px}.search-filter-label{display:block;font-size:.75rem;font-weight:600;color:#6b7280;margin-bottom:8px;text-transform:uppercase;letter-spacing:.05em}.search-filter-chips{display:flex;flex-wrap:wrap;gap:6px}.filter-chip{background:#f3f4f6;border:1px solid #e5e7eb;border-radius:16px;padding:4px 12px;font-size:.8rem;cursor:pointer;transition:all .15s;color:#374151}.filter-chip:hover{background:#e5e7eb;border-color:#d1d5db}.filter-chip--active{background:#3b82f6;border-color:#3b82f6;color:#fff}.filter-chip--active:hover{background:#2563eb;border-color:#2563eb}.search-filter-clear{width:100%;padding:8px;background:none;border:1px solid #e5e7eb;border-radius:6px;color:#6b7280;cursor:pointer;font-size:.85rem;transition:background .1s,color .1s,border-color .1s}.search-filter-clear:hover{background:#f9fafb;color:#374151;border-color:#d1d5db}@media (max-width: 768px){.search-filters{padding:10px}.search-filter-chips{gap:4px}.filter-chip{padding:3px 10px;font-size:.75rem}}.tree-view{position:fixed;top:56px;left:0;width:280px;height:calc(100% - 56px);background:#fff;box-shadow:2px 0 10px #0000001a;transform:translate(-100%);transition:transform .3s ease;z-index:900;display:flex;flex-direction:column}.tree-view--open{transform:translate(0)}.tree-view-header{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;border-bottom:1px solid #e5e7eb;background:#f9fafb;flex-shrink:0}.tree-view-title{margin:0;font-size:.95rem;font-weight:600;color:#374151}.tree-view-close{background:none;border:none;font-size:1.3rem;cursor:pointer;color:#6b7280;line-height:1;padding:4px;border-radius:4px;transition:background .1s,color .1s}.tree-view-close:hover{color:#374151;background:#e5e7eb}.tree-view-content{flex:1;overflow-y:auto;padding:8px}.tree-root{list-style:none;margin:0;padding:0}.tree-node{-webkit-user-select:none;user-select:none}.tree-node-content{display:flex;align-items:center;padding:4px;border-radius:4px;transition:background .1s}.tree-node-content:hover{background:#f3f4f6}.tree-node--selected>.tree-node-content{background:#eff6ff}.tree-node--selected>.tree-node-content .tree-node-label{color:#3b82f6;font-weight:500}.tree-node-toggle{background:none;border:none;width:24px;height:24px;cursor:pointer;display:flex;align-items:center;justify-content:center;border-radius:4px;color:#6b7280;flex-shrink:0;transition:background .1s,color .1s}.tree-node-toggle:hover{background:#e5e7eb;color:#374151}.tree-node-icon{font-size:.65rem;transition:transform .15s}.tree-node-spacer{width:24px;flex-shrink:0}.tree-node-label{background:none;border:none;padding:4px 8px;cursor:pointer;font-size:.85rem;color:#374151;text-align:left;flex:1;min-width:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;transition:color .1s}.tree-node-label:hover{color:#3b82f6}.tree-node-children{list-style:none;margin:0;padding-left:20px}.tree-view-toggle{position:fixed;left:16px;bottom:80px;width:48px;height:48px;border-radius:50%;background:#fff;border:1px solid #e5e7eb;box-shadow:0 2px 8px #0000001a;cursor:pointer;font-size:1.2rem;z-index:800;transition:transform .2s,box-shadow .2s,background .2s;display:flex;align-items:center;justify-content:center}.tree-view-toggle:hover{transform:scale(1.05);box-shadow:0 4px 12px #00000026}.tree-view-toggle--active{background:#3b82f6;color:#fff;border-color:#3b82f6}@media (max-width: 768px){.tree-view{width:100%;top:48px;height:calc(100% - 48px)}.tree-view-toggle{left:auto;right:16px;bottom:72px;width:44px;height:44px}}@media (max-width: 480px){.tree-view-header{padding:10px 12px}.tree-view-title{font-size:.9rem}.tree-node-label{font-size:.8rem;padding:3px 6px}.tree-node-children{padding-left:16px}}.sidepanel{position:fixed;top:0;right:0;width:400px;max-width:100%;height:100%;background:#fff;box-shadow:-2px 0 10px #0003;transform:translate(100%);transition:transform .3s ease;z-index:1000;display:flex;flex-direction:column}.sidepanel--open{transform:translate(0)}.sidepanel-header{display:flex;align-items:center;justify-content:space-between;padding:16px;border-bottom:1px solid #e0e0e0;background:#f5f5f5;flex-shrink:0}.sidepanel-title{margin:0 12px 0 0;font-size:1.25rem;font-weight:600;color:#333;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;flex:1}.sidepanel-close{background:none;border:none;font-size:1.5rem;cursor:pointer;padding:4px 8px;color:#666;line-height:1;flex-shrink:0}.sidepanel-close:hover{color:#333}.sidepanel-close:focus{outline:2px solid #3b82f6;outline-offset:2px}.sidepanel-content{flex:1;display:flex;flex-direction:column;overflow:hidden;min-height:0}.sidepanel-description{padding:16px;margin:0;color:#666;font-size:.95rem;border-bottom:1px solid #e0e0e0;flex-shrink:0}.sidepanel-description[hidden]{display:none}.sidepanel-wikipedia{flex:1;display:flex;flex-direction:column;min-height:0;position:relative}.sidepanel-loading{display:flex;align-items:center;justify-content:center;gap:12px;padding:32px;color:#666}.sidepanel-loading[hidden]{display:none}.spinner{width:24px;height:24px;border:3px solid #e0e0e0;border-top-color:#3b82f6;border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.sidepanel-iframe{flex:1;width:100%;border:none;min-height:0}.sidepanel-iframe[hidden]{display:none}.sidepanel-fallback{padding:32px 16px;text-align:center}.sidepanel-fallback[hidden]{display:none}.sidepanel-fallback p{color:#666;margin-bottom:16px}.sidepanel-link{display:inline-block;padding:12px 24px;background:#3b82f6;color:#fff;text-decoration:none;border-radius:6px;font-weight:500}.sidepanel-link:hover{background:#2563eb}.sidepanel-link:focus{outline:2px solid #2563eb;outline-offset:2px}.sidepanel-no-wiki{padding:32px 16px;text-align:center}.sidepanel-no-wiki[hidden]{display:none}.sidepanel-no-wiki p{color:#999;font-style:italic}@media (max-width: 767px){.sidepanel{width:100%;height:auto;max-height:60vh;top:auto;right:0;bottom:0;left:0;border-radius:16px 16px 0 0;transform:translateY(100%);box-shadow:0 -4px 20px #0003}.sidepanel--open{transform:translateY(0)}.sidepanel-header{padding:20px 16px 16px;position:relative}.sidepanel-header:before{content:"";position:absolute;top:8px;left:50%;transform:translate(-50%);width:40px;height:4px;background:#d1d5db;border-radius:2px}.sidepanel-title{font-size:1.1rem}.sidepanel-description{padding:12px 16px}.sidepanel-content{max-height:calc(60vh - 100px);overflow-y:auto}.sidepanel-fallback,.sidepanel-no-wiki{padding:24px 16px}}@media (min-width: 768px) and (max-width: 1023px){.sidepanel{width:350px}}@media (min-width: 1024px){.sidepanel{width:400px}}.breadcrumb{position:fixed;top:0;left:0;right:0;z-index:100;background:#fffffff2;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);padding:8px 16px;box-shadow:0 1px 3px #0000001a;opacity:0;transform:translateY(-100%);transition:opacity .2s ease,transform .2s ease;pointer-events:none}.breadcrumb--visible{opacity:1;transform:translateY(0);pointer-events:auto}.breadcrumb-list{display:flex;align-items:center;flex-wrap:wrap;gap:4px;margin:0;padding:0;list-style:none;font-size:.9rem}.breadcrumb-item{display:flex;align-items:center;gap:4px}.breadcrumb-link{background:none;border:none;padding:4px 8px;color:#3b82f6;cursor:pointer;font-size:inherit;font-family:inherit;border-radius:4px;transition:background .15s ease}.breadcrumb-link:hover{background:#3b82f61a;text-decoration:underline}.breadcrumb-link:focus{outline:2px solid #3b82f6;outline-offset:2px}.breadcrumb-link:active{background:#3b82f633}.breadcrumb-separator{color:#9ca3af;-webkit-user-select:none;user-select:none;font-size:1.1em}.breadcrumb-current{padding:4px 8px;color:#374151;font-weight:500}@media (max-width: 767px){.breadcrumb{padding:8px 12px}.breadcrumb-list{font-size:.85rem;flex-wrap:nowrap;overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none}.breadcrumb-list::-webkit-scrollbar{display:none}.breadcrumb-link,.breadcrumb-current{padding:4px 6px;white-space:nowrap}.breadcrumb-item{flex-shrink:0}}@media (min-width: 769px){.sidepanel--open~.breadcrumb,body:has(.sidepanel--open) .breadcrumb{right:400px}.breadcrumb{transition:right .3s ease,opacity .2s ease,transform .2s ease}}.notifications{position:fixed;bottom:20px;left:20px;z-index:2000;display:flex;flex-direction:column;gap:10px;max-width:400px;pointer-events:none}.notification{display:flex;align-items:center;gap:12px;padding:12px 16px;background:#fff;border-radius:8px;box-shadow:0 4px 12px #00000026;animation:slideIn .3s ease;pointer-events:auto}.notification--leaving{animation:slideOut .3s ease forwards}@keyframes slideIn{0%{transform:translate(-100%);opacity:0}to{transform:translate(0);opacity:1}}@keyframes slideOut{to{transform:translate(-100%);opacity:0}}.notification--error{border-left:4px solid #ef4444}.notification--warning{border-left:4px solid #f59e0b}.notification--info{border-left:4px solid #3b82f6}.notification--success{border-left:4px solid #10b981}.notification-icon{font-size:1.2rem;flex-shrink:0}.notification--error .notification-icon{color:#ef4444}.notification--warning .notification-icon{color:#f59e0b}.notification--info .notification-icon{color:#3b82f6}.notification--success .notification-icon{color:#10b981}.notification-message{flex:1;font-size:.9rem;color:#374151;line-height:1.4}.notification-action{padding:6px 12px;background:#f3f4f6;border:none;border-radius:4px;cursor:pointer;font-size:.85rem;font-family:inherit;color:#374151;flex-shrink:0}.notification-action:hover{background:#e5e7eb}.notification-action:focus{outline:2px solid #3b82f6;outline-offset:2px}.notification-close{background:none;border:none;font-size:1.2rem;cursor:pointer;color:#9ca3af;padding:4px;line-height:1;flex-shrink:0}.notification-close:hover{color:#374151}.notification-close:focus{outline:2px solid #3b82f6;outline-offset:2px}@media (max-width: 480px){.notifications{left:10px;right:10px;max-width:none;bottom:10px}.notification{padding:10px 12px;gap:10px}.notification-message{font-size:.85rem}}.popup{position:absolute;background:#fff;border-radius:12px;box-shadow:0 4px 20px #0003;min-width:250px;max-width:350px;opacity:0;visibility:hidden;transform:translateY(10px);transition:opacity .2s,transform .2s,visibility .2s;z-index:1000;pointer-events:none}.popup--visible{opacity:1;visibility:visible;transform:translateY(0);pointer-events:auto}.popup-close{position:absolute;top:8px;right:8px;background:none;border:none;font-size:1.5rem;cursor:pointer;color:#9ca3af;line-height:1;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:6px;transition:background .15s,color .15s}.popup-close:hover{background:#f3f4f6;color:#374151}.popup-close:focus{outline:2px solid #3b82f6;outline-offset:-2px}.popup-header{display:flex;align-items:center;gap:12px;padding:16px 16px 8px}.popup-icon{font-size:1.5rem;flex-shrink:0}.popup-title{margin:0;font-size:1.1rem;font-weight:600;color:#374151;padding-right:24px;line-height:1.3}.popup-content{padding:0 16px 16px;font-size:.9rem;color:#4b5563;line-height:1.5;max-height:200px;overflow-y:auto}.popup-content p{margin:0 0 8px}.popup-content p:last-child{margin-bottom:0}.popup-content ul,.popup-content ol{margin:0 0 8px;padding-left:20px}.popup-content a{color:#3b82f6;text-decoration:none}.popup-content a:hover{text-decoration:underline}.popup-footer{padding:0 16px 16px}.popup-footer:empty{display:none}.popup-link{display:inline-flex;align-items:center;gap:4px;padding:8px 16px;background:#3b82f6;color:#fff;text-decoration:none;border-radius:6px;font-size:.9rem;font-weight:500;transition:background .15s}.popup-link:hover{background:#2563eb;text-decoration:none}.popup-link:focus{outline:2px solid #3b82f6;outline-offset:2px}.popup-link[hidden]{display:none}.popup:after{content:"";position:absolute;bottom:-10px;left:50%;transform:translate(-50%);border-width:10px 10px 0 10px;border-style:solid;border-color:white transparent transparent transparent}.popup-content::-webkit-scrollbar{width:6px}.popup-content::-webkit-scrollbar-track{background:#f1f1f1;border-radius:3px}.popup-content::-webkit-scrollbar-thumb{background:#c1c1c1;border-radius:3px}.popup-content::-webkit-scrollbar-thumb:hover{background:#a1a1a1}@media (max-width: 480px){.popup{min-width:200px;max-width:calc(100vw - 32px)}.popup-header{padding:12px 12px 6px}.popup-content{padding:0 12px 12px;max-height:150px}.popup-footer{padding:0 12px 12px}}.tour-overlay{position:fixed;top:0;left:0;width:100%;height:100%;z-index:10000;pointer-events:auto}.tour-backdrop{position:absolute;top:0;left:0;width:100%;height:100%;background:#0009}.tour-tooltip{position:fixed;background:#fff;border-radius:12px;box-shadow:0 10px 40px #0000004d;max-width:380px;min-width:280px;z-index:10001;animation:tour-fade-in .2s ease}@keyframes tour-fade-in{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}.tour-header{display:flex;align-items:center;justify-content:space-between;padding:12px 16px 0}.tour-step-indicator{font-size:.8rem;color:#9ca3af;font-weight:500}.tour-close{background:none;border:none;font-size:1.5rem;color:#9ca3af;cursor:pointer;padding:4px;line-height:1;border-radius:4px;transition:background .15s,color .15s}.tour-close:hover{background:#f3f4f6;color:#374151}.tour-title{margin:12px 16px 8px;font-size:1.15rem;font-weight:600;color:#1f2937}.tour-text{margin:0 16px 16px;font-size:.95rem;color:#4b5563;line-height:1.5}.tour-footer{display:flex;justify-content:flex-end;gap:8px;padding:0 16px 16px}.tour-btn{padding:10px 20px;border-radius:6px;font-size:.9rem;font-weight:500;cursor:pointer;border:none;transition:background .15s}.tour-btn--primary{background:#3b82f6;color:#fff}.tour-btn--primary:hover{background:#2563eb}.tour-btn--secondary{background:#f3f4f6;color:#374151}.tour-btn--secondary:hover{background:#e5e7eb}@media (max-width: 480px){.tour-tooltip{max-width:calc(100% - 32px);min-width:auto;left:16px!important;right:16px;transform:none!important}.tour-title{font-size:1.05rem}.tour-text{font-size:.9rem}.tour-btn{padding:8px 16px}}.legal-page{min-height:100vh;background:#f9fafb;font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;display:flex;flex-direction:column}.legal-header{background:#1f2937;color:#fff;padding:20px 24px;position:sticky;top:0;z-index:100}.legal-back{display:inline-flex;align-items:center;color:#93c5fd;text-decoration:none;font-size:.9rem;margin-bottom:12px;transition:color .15s}.legal-back:hover{color:#fff}.legal-header h1{margin:0;font-size:1.75rem;font-weight:600}.legal-content{flex:1;max-width:800px;margin:0 auto;padding:32px 24px;width:100%;line-height:1.7;color:#374151}.legal-content section{margin-bottom:32px}.legal-content h2{color:#1f2937;font-size:1.35rem;font-weight:600;margin-top:32px;margin-bottom:16px;padding-bottom:8px;border-bottom:2px solid #e5e7eb}.legal-content h3{color:#374151;font-size:1.1rem;font-weight:600;margin-top:24px;margin-bottom:12px}.legal-content p{margin-bottom:16px}.legal-content ul{margin:16px 0;padding-left:24px}.legal-content li{margin-bottom:8px}.legal-placeholder{background:#fef3c7;border:1px solid #f59e0b;border-radius:6px;padding:12px 16px;color:#92400e}.legal-footer{background:#1f2937;padding:20px 24px;display:flex;justify-content:center;gap:24px}.legal-footer a{color:#93c5fd;text-decoration:none;font-size:.9rem;transition:color .15s}.legal-footer a:hover{color:#fff}.app-footer{position:fixed;bottom:0;left:0;right:0;background:#1f2937f2;padding:8px 16px;display:flex;justify-content:center;gap:24px;z-index:1000;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.app-footer a{color:#9ca3af;text-decoration:none;font-size:.8rem;transition:color .15s}.app-footer a:hover{color:#fff}@media (max-width: 767px){.legal-header{padding:16px}.legal-header h1{font-size:1.5rem}.legal-content{padding:24px 16px}.legal-content h2{font-size:1.2rem}.app-footer{padding:6px 12px}}
