:root{--primary-color: #6366f1;--primary-hover: #4f46e5;--success-color: #10b981;--error-color: #ef4444;--warning-color: #f59e0b;--bg-primary: #ffffff;--bg-secondary: #f9fafb;--bg-tertiary: #f3f4f6;--bg-hover: #e5e7eb;--text-primary: #111827;--text-secondary: #374151;--text-muted: #6b7280;--border-color: #e5e7eb;--border-radius: .5rem;--shadow-sm: 0 1px 2px 0 rgba(0, 0, 0, .05);--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .1);--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .1);--spacing-xs: .25rem;--spacing-sm: .5rem;--spacing-md: 1rem;--spacing-lg: 1.5rem;--spacing-xl: 2rem;--board-light-square: #f0d9b5;--board-dark-square: #b58863;--board-highlight: rgba(255, 255, 0, .5);--board-last-move: rgba(155, 199, 0, .4)}@media(prefers-color-scheme:dark){:root{--bg-primary: #111827;--bg-secondary: #1f2937;--bg-tertiary: #374151;--bg-hover: #4b5563;--text-primary: #f9fafb;--text-secondary: #e5e7eb;--text-muted: #9ca3af;--border-color: #374151;--board-light-square: #f0d9b5;--board-dark-square: #b58863}}*{margin:0;padding:0;box-sizing:border-box}html,body{width:100%;height:100%;overflow-x:hidden}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:var(--bg-primary);color:var(--text-primary);line-height:1.6}code,pre{font-family:Courier New,Courier,monospace}h1{font-size:2.25rem;font-weight:700;line-height:1.2;margin-bottom:var(--spacing-lg)}h2{font-size:1.875rem;font-weight:600;line-height:1.3;margin-bottom:var(--spacing-md)}h3{font-size:1.5rem;font-weight:600;line-height:1.4;margin-bottom:var(--spacing-md)}p{margin-bottom:var(--spacing-md)}a{color:var(--primary-color);text-decoration:none;transition:color .2s}a:hover{color:var(--primary-hover)}button{font-family:inherit;font-size:inherit;cursor:pointer;border:none;outline:none}button:disabled{opacity:.5;cursor:not-allowed}.container{max-width:1400px;margin:0 auto;padding:0 var(--spacing-lg)}.text-center{text-align:center}.text-muted{color:var(--text-muted)}.mb-1{margin-bottom:var(--spacing-sm)}.mb-2{margin-bottom:var(--spacing-md)}.mb-3{margin-bottom:var(--spacing-lg)}.mt-1{margin-top:var(--spacing-sm)}.mt-2{margin-top:var(--spacing-md)}.mt-3{margin-top:var(--spacing-lg)}.loading{display:inline-block}.loading:after{content:"";display:inline-block;width:24px;height:24px;border:3px solid var(--border-color);border-top-color:var(--primary-color);border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}@media(max-width:1024px){.container{padding:0 var(--spacing-md)}h1{font-size:1.875rem}h2{font-size:1.5rem}h3{font-size:1.25rem}}@media(max-width:640px){.container{padding:0 var(--spacing-sm)}h1{font-size:1.5rem}h2{font-size:1.25rem}h3{font-size:1.125rem}}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:var(--bg-secondary)}::-webkit-scrollbar-thumb{background:var(--bg-tertiary);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:var(--bg-hover)}::selection{background:var(--primary-color);color:#fff}*:focus-visible{outline:2px solid var(--primary-color);outline-offset:2px}.dip-svg.svelte-145hawz{width:100%;height:100%}.board-container.svelte-nkg03k{position:relative;width:100%;max-width:600px;padding:1rem;background:var(--bg-secondary);border-radius:.5rem;box-shadow:0 2px 8px #0000001a}.board-svg.svelte-nkg03k{display:block;width:100%;height:auto}.controls.svelte-1y71c66{display:flex;align-items:center;gap:.5rem;padding:1rem;background:var(--bg-secondary);border-radius:.5rem}.control-btn.svelte-1y71c66{width:40px;height:40px;border:none;background:var(--bg-tertiary);color:var(--text-primary);border-radius:.375rem;cursor:pointer;font-size:1.25rem;transition:all .2s}.control-btn.svelte-1y71c66:hover:not(:disabled){background:var(--primary-color);color:#fff;transform:scale(1.05)}.control-btn.svelte-1y71c66:disabled{opacity:.3;cursor:not-allowed}.control-btn.svelte-1y71c66.play-btn{background:var(--primary-color);color:#fff;width:50px;height:50px;font-size:1.5rem}.control-btn.svelte-1y71c66.play-btn:hover{background:var(--primary-hover)}.move-indicator.svelte-1y71c66{margin-left:auto;padding:.5rem 1rem;background:var(--bg-tertiary);border-radius:.375rem;font-size:.875rem;color:var(--text-secondary)}.move-list.svelte-13gy6vj{background:var(--bg-secondary);border-radius:.5rem;padding:1rem;height:100%;display:flex;flex-direction:column}.move-list.svelte-13gy6vj h3:where(.svelte-13gy6vj){margin:0 0 1rem;font-size:1.125rem;color:var(--text-primary)}.moves-scroll.svelte-13gy6vj{flex:1;overflow-y:auto;padding-right:.5rem}.moves-scroll.svelte-13gy6vj::-webkit-scrollbar{width:6px}.moves-scroll.svelte-13gy6vj::-webkit-scrollbar-thumb{background:var(--bg-tertiary);border-radius:3px}.move-item.svelte-13gy6vj{display:flex;align-items:center;gap:.5rem;padding:.5rem;margin-bottom:.25rem;border-radius:.375rem;cursor:pointer;transition:background .2s;font-size:.875rem}.move-item.svelte-13gy6vj:hover{background:var(--bg-hover)}.move-item.svelte-13gy6vj.active{background:var(--primary-color);color:#fff}.move-item.svelte-13gy6vj.active .move-number:where(.svelte-13gy6vj),.move-item.svelte-13gy6vj.active .move-pos:where(.svelte-13gy6vj),.move-item.svelte-13gy6vj.active .fallen:where(.svelte-13gy6vj){color:#fff}.move-number.svelte-13gy6vj{font-weight:600;color:var(--text-muted);min-width:30px}.move-dip-icon.svelte-13gy6vj{width:24px;height:24px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.move-dip.svelte-13gy6vj{flex:1;font-family:monospace}.move-pos.svelte-13gy6vj{color:var(--text-muted);font-size:.75rem}.fallen.svelte-13gy6vj{color:var(--error-color);font-size:.75rem;font-weight:600}.game-info.svelte-vl478m{background:var(--bg-secondary);border-radius:.5rem;padding:1.5rem}.players.svelte-vl478m{display:flex;align-items:center;justify-content:space-between;gap:2rem;margin-bottom:1.5rem}.player.svelte-vl478m{display:flex;align-items:center;gap:1rem;flex:1}.player-avatar.svelte-vl478m{width:80px;height:80px;display:flex;align-items:center;justify-content:center}.player-details.svelte-vl478m{flex:1}.player-name.svelte-vl478m{font-weight:600;font-size:1.125rem;margin-bottom:.25rem}.player-id.svelte-vl478m{font-size:.6875rem;color:var(--text-muted);font-family:monospace;margin-bottom:.25rem;opacity:.7}.player-rating.svelte-vl478m{font-size:.875rem;color:var(--text-muted)}.rating-change.svelte-vl478m{font-weight:600}.rating-change.svelte-vl478m.positive{color:var(--success-color)}.rating-change.svelte-vl478m.negative{color:var(--error-color)}.result.svelte-vl478m{text-align:center;padding:1rem;background:var(--bg-tertiary);border-radius:.5rem}.score.svelte-vl478m{font-size:1.5rem;font-weight:700;margin-bottom:.25rem}.result-text.svelte-vl478m{font-size:.875rem;color:var(--text-muted)}.metadata.svelte-vl478m{display:flex;gap:2rem;padding-top:1.5rem;border-top:1px solid var(--border-color)}.meta-item.svelte-vl478m{flex:1}.meta-item.svelte-vl478m .label:where(.svelte-vl478m){display:block;font-size:.75rem;color:var(--text-muted);margin-bottom:.25rem;text-transform:uppercase;letter-spacing:.5px}.meta-item.svelte-vl478m .value:where(.svelte-vl478m){display:block;font-weight:600;font-size:1rem}.meta-item.svelte-vl478m .value:where(.svelte-vl478m).captures{color:var(--error-color)}@media(max-width:768px){.players.svelte-vl478m{flex-direction:column;gap:1rem}.metadata.svelte-vl478m{flex-wrap:wrap;gap:1rem}.metadata.svelte-vl478m .meta-item:where(.svelte-vl478m){min-width:45%}}.share-buttons.svelte-ocoyyc{display:flex;gap:.5rem;justify-content:center;position:relative}.share-btn.svelte-ocoyyc{display:flex;align-items:center;gap:.5rem;padding:.75rem 1.25rem;background:var(--bg-tertiary);border:none;border-radius:.375rem;cursor:pointer;transition:all .2s;color:var(--text-primary);font-size:.875rem}.share-btn.svelte-ocoyyc .icon:where(.svelte-ocoyyc){font-size:1.25rem}.share-btn.svelte-ocoyyc:hover{background:var(--primary-color);color:#fff;transform:translateY(-2px)}.feedback.svelte-ocoyyc{position:absolute;top:-2.5rem;left:50%;transform:translate(-50%);background:var(--success-color);color:#fff;padding:.5rem 1rem;border-radius:.375rem;font-size:.875rem;white-space:nowrap;animation:svelte-ocoyyc-fadeIn .2s ease-out}@keyframes svelte-ocoyyc-fadeIn{0%{opacity:0;transform:translate(-50%) translateY(-10px)}to{opacity:1;transform:translate(-50%) translateY(0)}}@media(max-width:640px){.share-buttons.svelte-ocoyyc{flex-wrap:wrap}.share-btn.svelte-ocoyyc .text:where(.svelte-ocoyyc){display:none}.share-btn.svelte-ocoyyc{padding:.75rem}}.game-viewer.svelte-1yyyalw{width:100%;height:100%}.loading.svelte-1yyyalw{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:400px}.loading.svelte-1yyyalw .spinner:where(.svelte-1yyyalw){width:50px;height:50px;border:4px solid var(--bg-tertiary);border-top-color:var(--primary-color);border-radius:50%;animation:svelte-1yyyalw-spin 1s linear infinite}.loading.svelte-1yyyalw p:where(.svelte-1yyyalw){margin-top:1rem;color:var(--text-muted)}.error.svelte-1yyyalw{text-align:center;padding:3rem 2rem;max-width:600px;margin:0 auto}.error.svelte-1yyyalw .error-code:where(.svelte-1yyyalw){font-size:8rem;font-weight:700;color:var(--primary-color);line-height:1;margin-bottom:1rem}.error.svelte-1yyyalw h2:where(.svelte-1yyyalw){font-size:2rem;font-weight:600;color:var(--text-primary);margin-bottom:1rem}.error.svelte-1yyyalw .error-message:where(.svelte-1yyyalw){font-size:1.125rem;color:var(--text-muted);margin-bottom:2rem;line-height:1.6}.error.svelte-1yyyalw .error-actions:where(.svelte-1yyyalw){display:flex;gap:1rem;justify-content:center;flex-wrap:wrap}.error.svelte-1yyyalw .btn:where(.svelte-1yyyalw){display:inline-block;padding:.75rem 2rem;border-radius:.375rem;text-decoration:none;font-weight:600;transition:all .2s;border:none;cursor:pointer;font-size:1rem;font-family:inherit}.error.svelte-1yyyalw .btn-primary:where(.svelte-1yyyalw){background:var(--primary-color);color:#fff}.error.svelte-1yyyalw .btn-primary:where(.svelte-1yyyalw):hover{background:var(--primary-hover);transform:translateY(-2px)}.error.svelte-1yyyalw .btn-secondary:where(.svelte-1yyyalw){background:var(--bg-secondary);color:var(--text-primary);border:1px solid var(--border-color)}.error.svelte-1yyyalw .btn-secondary:where(.svelte-1yyyalw):hover{background:var(--bg-primary);transform:translateY(-2px)}@media(max-width:640px){.error.svelte-1yyyalw .error-code:where(.svelte-1yyyalw){font-size:6rem}.error.svelte-1yyyalw h2:where(.svelte-1yyyalw){font-size:1.5rem}.error.svelte-1yyyalw .error-message:where(.svelte-1yyyalw){font-size:1rem}.error.svelte-1yyyalw .error-actions:where(.svelte-1yyyalw){flex-direction:column}.error.svelte-1yyyalw .btn:where(.svelte-1yyyalw){width:100%}}.viewer-layout.svelte-1yyyalw{display:grid;grid-template-columns:1fr 2fr 1fr;grid-template-rows:auto 1fr;gap:1.5rem;height:100%}.game-info-section.svelte-1yyyalw{grid-column:1 / -1}.board-section.svelte-1yyyalw{grid-column:2;display:flex;flex-direction:column;align-items:center;gap:1rem}.moves-section.svelte-1yyyalw{grid-column:3}@keyframes svelte-1yyyalw-spin{to{transform:rotate(360deg)}}@media(max-width:1024px){.viewer-layout.svelte-1yyyalw{grid-template-columns:1fr;grid-template-rows:auto auto auto}.board-section.svelte-1yyyalw,.moves-section.svelte-1yyyalw{grid-column:1}}.game-list.svelte-1hc8sw2{max-width:1200px;margin:0 auto}.archive-search.svelte-1hc8sw2{background:var(--bg-secondary);padding:3rem;border-radius:.75rem;margin-bottom:3rem;text-align:center}.archive-search.svelte-1hc8sw2 h2:where(.svelte-1hc8sw2){font-size:2rem;margin:0 0 .5rem}.archive-search.svelte-1hc8sw2 .description:where(.svelte-1hc8sw2){color:var(--text-muted);margin-bottom:2rem}.archive-search.svelte-1hc8sw2 .search-box:where(.svelte-1hc8sw2){display:flex;gap:1rem;max-width:600px;margin:0 auto 1rem}.archive-search.svelte-1hc8sw2 .search-box:where(.svelte-1hc8sw2) .archive-input:where(.svelte-1hc8sw2){flex:1;padding:.875rem 1.25rem;border:2px solid var(--border-color);border-radius:.5rem;background:var(--bg-primary);color:var(--text-primary);font-size:1rem;transition:border-color .2s}.archive-search.svelte-1hc8sw2 .search-box:where(.svelte-1hc8sw2) .archive-input:where(.svelte-1hc8sw2):focus{outline:none;border-color:var(--primary-color)}.archive-search.svelte-1hc8sw2 .search-box:where(.svelte-1hc8sw2) .archive-input:where(.svelte-1hc8sw2)::placeholder{color:var(--text-muted)}.archive-search.svelte-1hc8sw2 .search-box:where(.svelte-1hc8sw2) .load-button:where(.svelte-1hc8sw2){padding:.875rem 2rem;background:var(--primary-color);color:#fff;border:none;border-radius:.5rem;font-size:1rem;font-weight:600;cursor:pointer;transition:background .2s;white-space:nowrap}.archive-search.svelte-1hc8sw2 .search-box:where(.svelte-1hc8sw2) .load-button:where(.svelte-1hc8sw2):hover:not(:disabled){background:var(--primary-hover)}.archive-search.svelte-1hc8sw2 .search-box:where(.svelte-1hc8sw2) .load-button:where(.svelte-1hc8sw2):disabled{opacity:.5;cursor:not-allowed}.archive-search.svelte-1hc8sw2 .help-text:where(.svelte-1hc8sw2){font-size:.875rem;color:var(--text-muted)}.browse-section.svelte-1hc8sw2 .browse-toggle:where(.svelte-1hc8sw2){display:block;margin:0 auto 2rem;padding:.75rem 1.5rem;background:var(--bg-secondary);color:var(--text-primary);border:1px solid var(--border-color);border-radius:.5rem;font-size:1rem;cursor:pointer;transition:all .2s}.browse-section.svelte-1hc8sw2 .browse-toggle:where(.svelte-1hc8sw2):hover{background:var(--bg-hover);border-color:var(--primary-color)}.games-grid.svelte-1hc8sw2{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1.5rem;margin-top:2rem}.game-card.svelte-1hc8sw2{background:var(--bg-secondary);padding:1.5rem;border-radius:.5rem;text-decoration:none;color:var(--text-primary);transition:transform .2s,box-shadow .2s}.game-card.svelte-1hc8sw2:hover{transform:translateY(-4px);box-shadow:0 4px 12px #00000026}.game-players.svelte-1hc8sw2{display:flex;align-items:center;justify-content:space-between;margin-bottom:1rem;font-weight:600}.game-players.svelte-1hc8sw2 .vs:where(.svelte-1hc8sw2){color:var(--text-muted);font-size:.875rem}.game-meta.svelte-1hc8sw2{display:flex;justify-content:space-between;margin-bottom:.5rem;font-size:.875rem;color:var(--text-muted)}.game-date.svelte-1hc8sw2{font-size:.75rem;color:var(--text-muted)}.loading.svelte-1hc8sw2{text-align:center;padding:3rem}@media(max-width:768px){.archive-search.svelte-1hc8sw2{padding:2rem 1rem}.archive-search.svelte-1hc8sw2 .search-box:where(.svelte-1hc8sw2){flex-direction:column}.archive-search.svelte-1hc8sw2 .search-box:where(.svelte-1hc8sw2) .load-button:where(.svelte-1hc8sw2){width:100%}}.not-found.svelte-uw6fqd{text-align:center;padding:3rem 2rem;max-width:600px;margin:0 auto}.not-found.svelte-uw6fqd .error-code:where(.svelte-uw6fqd){font-size:8rem;font-weight:700;color:var(--primary-color);line-height:1;margin-bottom:1rem}.not-found.svelte-uw6fqd h1:where(.svelte-uw6fqd){font-size:2rem;font-weight:600;margin-bottom:1rem}.not-found.svelte-uw6fqd .error-message:where(.svelte-uw6fqd){font-size:1.125rem;color:var(--text-muted);margin-bottom:2rem;line-height:1.6}.not-found.svelte-uw6fqd .error-actions:where(.svelte-uw6fqd){display:flex;gap:1rem;justify-content:center;flex-wrap:wrap}.not-found.svelte-uw6fqd .btn:where(.svelte-uw6fqd){display:inline-block;padding:.75rem 2rem;border-radius:.375rem;text-decoration:none;font-weight:600;transition:all .2s;border:none;cursor:pointer;font-size:1rem;font-family:inherit}.not-found.svelte-uw6fqd .btn-primary:where(.svelte-uw6fqd){background:var(--primary-color);color:#fff}.not-found.svelte-uw6fqd .btn-primary:where(.svelte-uw6fqd):hover{background:var(--primary-hover);transform:translateY(-2px)}.not-found.svelte-uw6fqd .btn-secondary:where(.svelte-uw6fqd){background:var(--bg-secondary);color:var(--text-primary);border:1px solid var(--border-color)}.not-found.svelte-uw6fqd .btn-secondary:where(.svelte-uw6fqd):hover{background:var(--bg-primary);transform:translateY(-2px)}@media(max-width:640px){.not-found.svelte-uw6fqd .error-code:where(.svelte-uw6fqd){font-size:6rem}.not-found.svelte-uw6fqd h1:where(.svelte-uw6fqd){font-size:1.5rem}.not-found.svelte-uw6fqd .error-message:where(.svelte-uw6fqd){font-size:1rem}.not-found.svelte-uw6fqd .error-actions:where(.svelte-uw6fqd){flex-direction:column}.not-found.svelte-uw6fqd .btn:where(.svelte-uw6fqd){width:100%}}.app.svelte-1n46o8q{display:flex;flex-direction:column;min-height:100vh}.app-header.svelte-1n46o8q{display:flex;justify-content:space-between;align-items:center;padding:1rem 2rem;background:var(--bg-secondary);border-bottom:1px solid var(--border-color)}.app-header.svelte-1n46o8q h1:where(.svelte-1n46o8q){display:flex;align-items:center;gap:.75rem;margin:0;font-size:1.5rem}.app-header.svelte-1n46o8q .logo:where(.svelte-1n46o8q){color:var(--text-primary);text-decoration:none;font-weight:700}.app-header.svelte-1n46o8q .logo:where(.svelte-1n46o8q):hover{color:var(--primary-color)}.app-header.svelte-1n46o8q .archive-label:where(.svelte-1n46o8q){font-size:.875rem;font-weight:400;color:var(--text-muted);border:1px solid var(--border-color);padding:.25rem .75rem;border-radius:1rem}.app-header.svelte-1n46o8q nav:where(.svelte-1n46o8q){display:flex;gap:1rem;align-items:center}.app-header.svelte-1n46o8q nav:where(.svelte-1n46o8q) a:where(.svelte-1n46o8q){text-decoration:none;color:var(--text-secondary);padding:.5rem 1rem;border-radius:.375rem;transition:all .2s}.app-header.svelte-1n46o8q nav:where(.svelte-1n46o8q) a:where(.svelte-1n46o8q):hover{background:var(--bg-hover);color:var(--text-primary)}.app-header.svelte-1n46o8q nav:where(.svelte-1n46o8q) a:where(.svelte-1n46o8q).active{background:var(--primary-color);color:#fff}.app-header.svelte-1n46o8q nav:where(.svelte-1n46o8q) a:where(.svelte-1n46o8q).play-button{background:var(--primary-color);color:#fff;font-weight:500}.app-header.svelte-1n46o8q nav:where(.svelte-1n46o8q) a:where(.svelte-1n46o8q).play-button:hover{background:var(--primary-hover)}.app-content.svelte-1n46o8q{flex:1;padding:2rem;max-width:1400px;margin:0 auto;width:100%}.app-footer.svelte-1n46o8q{padding:2rem;background:var(--bg-secondary);border-top:1px solid var(--border-color);text-align:center;color:var(--text-muted);font-size:.875rem}.app-footer.svelte-1n46o8q a:where(.svelte-1n46o8q){color:var(--text-secondary);text-decoration:none}.app-footer.svelte-1n46o8q a:where(.svelte-1n46o8q):hover{color:var(--primary-color)}@media(max-width:768px){.app-header.svelte-1n46o8q{flex-direction:column;gap:1rem;padding:1rem}.app-header.svelte-1n46o8q nav:where(.svelte-1n46o8q){width:100%;justify-content:space-between}.app-content.svelte-1n46o8q{padding:1rem}}
