.board-wrapper{display:flex;justify-content:center;align-items:center;width:100%}.board-container{display:grid;grid-template-columns:auto 1fr;grid-template-rows:1fr auto;gap:0;max-width:min(90vw,90vh,640px);width:100%}.rank-labels{display:flex;flex-direction:column;justify-content:space-around;padding-right:4px;grid-row:1;grid-column:1}.rank-label{display:flex;align-items:center;justify-content:center;font-size:.75rem;color:#888;-webkit-user-select:none;user-select:none;width:1.2em}.file-labels{display:flex;justify-content:space-around;padding-top:4px;grid-row:2;grid-column:2}.file-label{display:flex;align-items:center;justify-content:center;font-size:.75rem;color:#888;-webkit-user-select:none;user-select:none}.board{display:grid;grid-template-columns:repeat(8,1fr);grid-template-rows:repeat(8,1fr);aspect-ratio:1 / 1;width:100%;grid-row:1;grid-column:2;border:2px solid #333;border-radius:2px;overflow:hidden}.square{position:relative;display:flex;align-items:center;justify-content:center;aspect-ratio:1 / 1}.square-light{background-color:#f0d9b5}.square-dark{background-color:#b58863}.piece{width:80%;height:80%;pointer-events:none;-webkit-user-select:none;user-select:none;transition:transform .1s ease-out}.piece-white{color:#f8f8f8}.piece-black{color:#1a1a1a}@media(max-width:480px){.board-container{max-width:95vw}.rank-label,.file-label{font-size:.6rem}}.overlay{position:absolute;top:0;left:0;width:100%;height:100%;pointer-events:none}.overlay-legal-move{display:flex;align-items:center;justify-content:center}.overlay-legal-move:after{content:"";width:28%;height:28%;border-radius:50%;background:#00000040}.overlay-capture{border-radius:50%;border:5px solid rgba(0,0,0,.25)}.overlay-contested{display:flex;align-items:center;justify-content:center}.overlay-contested:after{content:"";width:32%;height:32%;border-radius:50%;background:#dc8c2899;border:2px solid rgba(220,140,40,.8)}.overlay-last-move{background:#ffff004d}.square-selected{background-color:#6496ff66!important}.square-check{background:radial-gradient(circle,rgba(255,0,0,.6) 0%,rgba(255,0,0,.2) 70%,transparent 100%)!important}.square-clickable{cursor:pointer}.overlay-superposition{position:absolute;top:0;left:0;width:100%;height:100%;display:flex;align-items:center;justify-content:center;pointer-events:none}.overlay-superposition .piece{width:70%;height:70%}.overlay-superposition-own{opacity:.45;background:#7c5cbf26}.overlay-superposition-opponent{opacity:.4;background:#c83c3c1f}.overlay-superposition-selected{opacity:.55;background:#7c5cbf1f;border:1px solid rgba(124,92,191,.35);border-radius:3px}.overlay-superposition-previewing{opacity:.7;background:#7c5cbf33;border:2px solid rgba(160,120,230,.6);border-radius:3px}.overlay-superposition-inspected{opacity:.55;background:#50c8c81f;border:1px solid rgba(80,200,200,.4);border-radius:3px}.overlay-superposition-inspected-ghost{opacity:.7;background:#50c8c833;border:2px solid rgba(80,220,220,.65);border-radius:3px}.overlay-inspection-move{position:absolute;top:50%;left:50%;width:24%;height:24%;transform:translate(-50%,-50%);border-radius:50%;background:#50c8c84d;pointer-events:none}.overlay-desired-position{display:flex;align-items:flex-end;justify-content:flex-end;padding:3px}.overlay-desired-position:after{content:"";width:22%;height:22%;border-radius:50%;background:#7c5cbf;box-shadow:0 0 4px #7c5cbfcc}.overlay-challenge-warning{border:3px solid rgba(255,165,0,.7);border-radius:2px}.overlay-conflict-warning{position:absolute;top:0;left:0;width:100%;height:100%;border:3px solid rgba(124,92,191,.7);border-radius:2px;background:#7c5cbf14;pointer-events:none;box-sizing:border-box}.overlay-superposition-collapsing{animation:superposition-fade .4s ease-out forwards}@keyframes superposition-fade{0%{opacity:.45}to{opacity:0}}.overlay-challenge-active{background:#ffc10740;border:2px solid rgba(255,193,7,.7);border-radius:2px;box-sizing:border-box}.overlay-challenge-absent-flash{animation:challenge-absent-flash .5s ease-out forwards}@keyframes challenge-absent-flash{0%{background:#e5737366;border-color:#e57373cc}to{background:transparent;border-color:transparent}}.overlay-challenged-piece{border-radius:50%;border:3px solid rgba(255,193,7,.6);box-sizing:border-box;animation:challenged-piece-pulse 1.5s ease-in-out infinite}@keyframes challenged-piece-pulse{0%,to{border-color:#ffc10799;transform:scale(1)}50%{border-color:#ffc107e6;transform:scale(1.04)}}.overlay-moving-piece-at-challenge{position:absolute;top:0;left:0;width:100%;height:100%;display:flex;align-items:center;justify-content:center;pointer-events:none;opacity:.8;background:#7c5cbf1f}.overlay-moving-piece-at-challenge .piece{width:75%;height:75%}.dialog-backdrop{position:fixed;top:0;left:0;right:0;bottom:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:100}.dialog{background:#252540;border-radius:8px;padding:1.5rem 2rem;min-width:260px;text-align:center;box-shadow:0 4px 24px #0006}.dialog h3{font-size:1.2rem;margin-bottom:1rem;color:#e0e0e0}.dialog p{margin-bottom:1rem;color:#bbb}.dialog-btn{padding:.5rem 1.5rem;border:none;border-radius:6px;background:#7c5cbf;color:#fff;font-size:.9rem;font-weight:600;cursor:pointer;transition:background .15s;min-height:44px}.dialog-btn:hover,.dialog-btn:active{background:#6a4aad}.dialog-actions{display:flex;gap:.75rem;justify-content:center;align-items:center;flex-wrap:wrap}.dialog-actions .dialog-btn-secondary{margin-top:0}.rematch-offered-text{color:#81c784;font-size:.9rem;margin-bottom:.75rem}.promotion-options{display:flex;gap:.5rem;justify-content:center}.promotion-btn{width:56px;height:56px;padding:6px;border:2px solid #444;border-radius:6px;background:#1a1a2e;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:border-color .15s}.promotion-btn:hover,.promotion-btn:active{border-color:#7c5cbf}.promotion-btn .piece{width:100%;height:100%}.dialog-btn-secondary{padding:.4rem 1rem;border:1px solid #555;border-radius:6px;background:transparent;color:#aaa;font-size:.85rem;cursor:pointer;margin-top:.75rem;transition:border-color .15s,color .15s;min-height:44px}.dialog-btn-secondary:hover,.dialog-btn-secondary:active{border-color:#888;color:#ccc}.commit-piece-icon{width:48px;height:48px;margin:0 auto .75rem}.commit-piece-icon .piece{width:100%;height:100%}.commit-options{display:flex;flex-wrap:wrap;gap:.4rem;justify-content:center;margin-bottom:.5rem}.commit-btn{padding:.4rem .8rem;border:2px solid #444;border-radius:4px;background:#1a1a2e;color:#e0e0e0;font-size:.85rem;font-family:monospace;cursor:pointer;transition:border-color .15s}.commit-btn:hover,.commit-btn:active{border-color:#7c5cbf}.commit-btn-desired{border-color:#7c5cbf;background:#7c5cbf26}.commit-desired-tag{display:block;font-size:.6rem;color:#7c5cbf;margin-top:2px}.conflict-subtitle{color:#999;font-size:.8rem;margin-bottom:.75rem}.conflict-question{margin-bottom:1rem;color:#ccc}.conflict-choices{display:flex;gap:.75rem;justify-content:center;margin-bottom:.5rem}.conflict-choice{display:flex;flex-direction:column;align-items:center;gap:.3rem;padding:.75rem 1rem;border:2px solid #444;border-radius:6px;background:#1a1a2e;color:#e0e0e0;cursor:pointer;transition:border-color .15s;min-width:120px;min-height:44px}.conflict-choice:hover,.conflict-choice:active{border-color:#7c5cbf}.conflict-piece-icon{width:40px;height:40px}.conflict-piece-icon .piece{width:100%;height:100%}.conflict-choice-label{font-size:.85rem;font-weight:600}.conflict-choice-desc{font-size:.7rem;color:#888;text-align:center}.challenge-square{font-family:monospace;font-size:1.2rem;font-weight:700;color:#7c5cbf;margin:.5rem 0}.challenge-choices{display:flex;gap:.75rem;justify-content:center;margin-bottom:.5rem}.challenge-btn-present{padding:.6rem 1.2rem;border:2px solid #4caf50;border-radius:6px;background:#4caf5026;color:#81c784;font-size:.9rem;font-weight:600;cursor:pointer;transition:background .15s;min-height:44px}.challenge-btn-present:hover,.challenge-btn-present:active{background:#4caf504d}.challenge-btn-absent{padding:.6rem 1.2rem;border:2px solid #f44336;border-radius:6px;background:#f4433626;color:#e57373;font-size:.9rem;font-weight:600;cursor:pointer;transition:background .15s;min-height:44px}.challenge-btn-absent:hover,.challenge-btn-absent:active{background:#f443364d}.bug-report-dialog{min-width:0;max-width:440px;width:90vw;text-align:left}.bug-report-form{display:flex;flex-direction:column;gap:.75rem}.bug-report-label{display:flex;flex-direction:column;gap:.3rem;font-size:.8rem;color:#aaa}.bug-report-textarea{width:100%;padding:.5rem;border:1px solid #444;border-radius:4px;background:#1a1a2e;color:#e0e0e0;font-size:.85rem;font-family:inherit;resize:vertical;box-sizing:border-box}.bug-report-textarea:focus{outline:none;border-color:#7c5cbf}.bug-report-checkbox-label{display:flex;align-items:center;gap:.4rem;font-size:.8rem;color:#aaa;cursor:pointer}.bug-report-error{color:#e57373;font-size:.8rem;margin:0}.bug-report-actions{display:flex;flex-direction:column;align-items:center;gap:.25rem;margin-top:.25rem}.bug-report-actions .dialog-btn:disabled{opacity:.5;cursor:not-allowed}@media(max-width:640px){.dialog{padding:1.25rem;min-width:0;width:92vw;max-width:360px}.dialog h3{font-size:1.1rem}.dialog-btn{padding:.5rem 1.2rem;width:100%}.dialog-actions{flex-direction:column;gap:.5rem}.dialog-actions .dialog-btn,.dialog-actions .dialog-btn-secondary{width:100%;margin-top:0}.promotion-options{gap:.75rem}.conflict-choices{flex-direction:column;align-items:stretch}.conflict-choice{min-width:0;flex-direction:row;gap:.75rem;padding:.75rem}.challenge-choices{flex-direction:column;align-items:stretch}.challenge-btn-present,.challenge-btn-absent{width:100%;text-align:center}.commit-options{gap:.5rem}.commit-btn{min-height:44px;padding:.5rem .8rem}.bug-report-dialog{width:95vw}}.action-panel{width:100%;background:#252540;border-radius:6px;overflow:hidden;border:1px solid #333}.action-panel-strip{padding:.5rem 1rem;font-size:.85rem;font-weight:500;text-align:center;min-height:40px;display:flex;align-items:center;justify-content:center}.action-panel-yourturn{color:#81c784}.action-panel-waiting{color:#999}.action-panel-check{color:#ffb74d;font-weight:600}.action-panel-gameover{color:#e0e0e0;font-weight:600;background:#7c5cbf26}.action-panel-expanded{padding:.75rem 1rem;display:flex;flex-direction:column;gap:.5rem}.action-panel-header{display:flex;align-items:center;justify-content:space-between;gap:.5rem}.panel-title{font-size:.85rem;font-weight:600;color:#e0e0e0}.panel-counter{font-size:.75rem;color:#999}.panel-question{font-size:.85rem;color:#ccc;text-align:center}.panel-subtitle{font-size:.75rem;color:#c9a44a;text-align:center}.panel-waiting{font-size:.85rem;color:#999;text-align:center;padding:.5rem 0}.panel-actions{display:flex;gap:.5rem;justify-content:center}.panel-btn{display:inline-flex;align-items:center;gap:.4rem;padding:.5rem 1rem;border:1px solid #444;border-radius:6px;background:#1e1e35;color:#e0e0e0;font-size:.85rem;font-weight:500;cursor:pointer;transition:border-color .15s,background .15s;min-height:44px}.panel-btn:hover,.panel-btn:active{border-color:#7c5cbf;background:#2a2a4a}.panel-btn-icon{display:inline-flex;width:24px;height:24px}.panel-btn-icon .piece{width:100%;height:100%}.panel-btn-primary{border-color:#7c5cbf;background:#7c5cbf26}.panel-btn-primary:hover,.panel-btn-primary:active{background:#7c5cbf4d}.panel-btn-secondary{border-color:#555}.panel-btn-present{border-color:#4caf50;background:#4caf501f;color:#81c784}.panel-btn-present:hover,.panel-btn-present:active{background:#4caf5040}.panel-btn-absent{border-color:#e57373;background:#e573731f;color:#ef9a9a}.panel-btn-absent:hover,.panel-btn-absent:active{background:#e5737340}.panel-btn-reset{padding:.35rem .75rem;border:1px solid #555;border-radius:4px;background:transparent;color:#999;font-size:.75rem;cursor:pointer;align-self:center;transition:border-color .15s,color .15s;min-height:44px}.panel-btn-reset:hover,.panel-btn-reset:active{border-color:#e57373;color:#ef9a9a}.challenge-tracker{display:flex;align-items:center;gap:.5rem;justify-content:center;padding:.25rem 0}.challenge-tracker-desktop{display:flex;gap:.75rem;flex-wrap:wrap;justify-content:center}.challenge-tracker-mobile{display:none;gap:.4rem;justify-content:center}.challenge-tracker-item{font-size:.75rem;padding:.2rem .5rem;border-radius:3px}.tracker-resolved{color:#999}.tracker-present{background:#4caf5026}.tracker-absent{background:#e5737326}.tracker-current{color:#e0e0e0;font-weight:600;background:#7c5cbf33}.tracker-pending{color:#666}.tracker-pip{width:10px;height:10px;border-radius:50%;background:#444;display:inline-block}.pip-resolved{background:#81c784}.pip-current{background:#7c5cbf;box-shadow:0 0 4px #7c5cbf80}.panel-challenge-body{display:flex;flex-direction:column;align-items:center;gap:.25rem}.panel-challenge-piece{width:40px;height:40px}.panel-challenge-piece .piece{width:100%;height:100%}.consequence-preview{border-top:1px solid #333;padding-top:.5rem;margin-top:.25rem}.consequence-toggle{background:none;border:none;color:#888;font-size:.75rem;cursor:pointer;padding:.2rem 0;text-decoration:underline}.consequence-toggle:hover,.consequence-toggle:active{color:#bbb}.consequence-list{display:flex;flex-direction:column;gap:.3rem;margin-top:.3rem}.consequence-item{font-size:.75rem;color:#aaa;line-height:1.4}.consequence-label{font-weight:600;color:#ccc;margin-right:.3rem}.consequence-desc{color:#999}@media(max-width:640px){.action-panel-strip{min-height:40px;font-size:.8rem}.action-panel:has(.action-panel-expanded){position:relative;z-index:10;margin-top:-80px;box-shadow:0 -4px 16px #0006}.action-panel-expanded{padding:.5rem .75rem}.panel-actions{flex-direction:row;flex-wrap:wrap}.panel-btn{flex:1;min-width:120px;justify-content:center;min-height:44px}.panel-btn-reset{min-height:44px}.challenge-tracker-desktop{display:none}.challenge-tracker-mobile{display:flex}.panel-challenge-piece{width:32px;height:32px}}.lobby-screen{max-width:800px;margin:0 auto;padding:1.5rem}.lobby-header{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:1.5rem}.lobby-header h2{margin:0}.lobby-welcome{color:#888;font-size:.9rem}.lobby-error{background:#ffebee;color:#c62828;padding:.75rem 1rem;border-radius:6px;margin-bottom:1rem}.lobby-actions{display:flex;gap:.75rem;margin-bottom:1.5rem}.lobby-section{margin-bottom:2rem}.lobby-section h3{margin:0 0 .75rem;display:flex;align-items:center;gap:.5rem}.lobby-action-count{font-size:.8rem;font-weight:400;color:#e65100}.lobby-loading,.lobby-empty{padding:2rem;text-align:center;color:#888}.game-card-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:.75rem}.game-card{display:block;text-decoration:none;color:inherit;background:#1e1e1e;border:1px solid #333;border-radius:8px;padding:1rem;transition:border-color .15s}.game-card:hover,.game-card:active{border-color:#666}.game-card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem}.game-card-mode{font-size:.8rem;text-transform:uppercase;letter-spacing:.05em;color:#888}.game-card-badge{font-size:.75rem;padding:.15rem .5rem;border-radius:10px;font-weight:600}.badge-action{background:#2e7d32;color:#fff}.badge-challenge{background:#e65100;color:#fff}.badge-waiting{background:#424242;color:#bbb}.badge-pending{background:#37474f;color:#90a4ae}.game-card-opponent{font-size:1.1rem;font-weight:500;margin-bottom:.25rem}.game-card-players{display:flex;align-items:center;gap:.4rem;margin-bottom:.25rem;font-size:.9rem;font-weight:500;flex-wrap:wrap}.game-card-player{white-space:nowrap}.game-card-white{color:#e0e0e0}.game-card-black{color:#aaa}.game-card-vs{font-size:.75rem;color:#666;flex-shrink:0}.game-card-meta{font-size:.8rem;color:#888}.invite-list{display:flex;flex-direction:column;gap:.5rem}.invite-card{display:flex;justify-content:space-between;align-items:center;background:#1e1e1e;border:1px solid #333;border-radius:8px;padding:.75rem 1rem}.invite-card-info{font-size:.9rem}.invite-mode{color:#90caf9}.invite-time{color:#888;margin-left:.25rem}.invite-card-actions{display:flex;gap:.5rem}.create-game-form{background:#1e1e1e;border:1px solid #333;border-radius:8px;padding:1.5rem;margin-bottom:1.5rem}.create-game-form h3{margin:0 0 1rem}.form-label{display:block;margin-bottom:.75rem;font-size:.85rem;color:#aaa}.form-label select,.form-label input{display:block;width:100%;margin-top:.25rem;padding:.5rem;background:#2a2a2a;border:1px solid #444;border-radius:4px;color:#eee;font-size:.9rem}.form-error{color:#ef5350;font-size:.85rem;margin-bottom:.75rem}.form-actions{display:flex;gap:.75rem;margin-top:1rem}.invite-link-display{background:#1e1e1e;border:1px solid #333;border-radius:8px;padding:1.5rem;margin-bottom:1.5rem}.invite-link-display h3{margin:0 0 .75rem}.invite-link-row{display:flex;gap:.5rem;margin:.5rem 0}.invite-link-input{flex:1;padding:.5rem;background:#2a2a2a;border:1px solid #444;border-radius:4px;color:#eee;font-family:monospace;font-size:.85rem}.btn{display:inline-flex;align-items:center;justify-content:center;padding:.5rem 1rem;border:none;border-radius:6px;font-size:.9rem;cursor:pointer;text-decoration:none;text-align:center;transition:background .15s;min-height:44px}.btn-primary{background:#1976d2;color:#fff}.btn-primary:hover,.btn-primary:active{background:#1565c0}.btn-secondary{background:#424242;color:#eee}.btn-secondary:hover,.btn-secondary:active{background:#616161}.btn-accept{background:#2e7d32;color:#fff}.btn-accept:hover,.btn-accept:active{background:#1b5e20}.btn-decline{background:#c62828;color:#fff}.btn-decline:hover,.btn-decline:active{background:#b71c1c}.btn-copy{background:#37474f;color:#eee;white-space:nowrap}.btn-copy:hover,.btn-copy:active{background:#455a64}.join-screen{max-width:500px;margin:3rem auto;text-align:center;padding:1.5rem}.join-error{color:#ef5350}.ws-status{font-size:.75rem;padding:.25rem .75rem;border-radius:4px;text-align:center;margin-bottom:.25rem}.ws-connected{background:#1b5e20;color:#a5d6a7}.ws-polling{background:#e65100;color:#ffcc80}.ws-disconnected{background:#b71c1c;color:#ef9a9a}.opponent-status{font-size:.75rem;padding:.25rem .75rem;border-radius:4px;text-align:center;margin-bottom:.5rem}.opponent-online{background:#1b5e20;color:#a5d6a7}.opponent-offline{background:#424242;color:#999}.notification-prompt{display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:.75rem 1rem;background:#6464ff1f;border:1px solid rgba(100,100,255,.3);border-radius:8px;margin-bottom:1rem;font-size:.9rem;color:#ccc}.notification-prompt .btn{white-space:nowrap;flex-shrink:0;font-size:.8rem;padding:.4rem .8rem}.nav-badge{display:inline-flex;align-items:center;justify-content:center;min-width:18px;height:18px;padding:0 5px;border-radius:9px;background:#e74c3c;color:#fff;font-size:.7rem;font-weight:700;margin-left:4px;vertical-align:middle}.game-card-pending-actions{display:flex;align-items:center;justify-content:space-between;gap:.5rem;margin-top:.25rem}.game-card-pending-hint{font-size:.8rem;color:#90a4ae}.btn-copy-sm{font-size:.75rem;padding:.25rem .6rem;min-height:28px;border-radius:4px}.matchmaking-active{display:flex;align-items:center;gap:1rem;padding:1rem 1.25rem;background:#16213e;border:1px solid #333;border-radius:8px;width:100%;max-width:420px;margin-bottom:1rem}.matchmaking-spinner{width:1.2rem;height:1.2rem;border:2px solid #444;border-top-color:#7c5cbf;border-radius:50%;animation:spin .8s linear infinite;flex-shrink:0}.matchmaking-status{flex:1;display:flex;flex-direction:column;gap:.2rem;font-size:.9rem;color:#ccc}.matchmaking-mode{font-size:.78rem;color:#7c5cbf}.matchmaking-mode-select{display:flex;gap:.5rem;margin-bottom:.5rem}.matchmaking-stub{padding:1.25rem;background:#ffffff0d;border:1px solid #444;border-radius:8px;margin-bottom:1rem;text-align:center}.matchmaking-stub h3{margin:0 0 .5rem}.matchmaking-stub p{color:#aaa;font-size:.9rem;margin:0 0 1rem;line-height:1.5}@media(max-width:640px){.lobby-screen{padding:1rem}.lobby-header{flex-direction:column;gap:.25rem;margin-bottom:1rem}.lobby-actions{flex-direction:column}.lobby-actions .btn{width:100%}.game-card-grid{grid-template-columns:1fr}.invite-card{flex-direction:column;align-items:stretch;gap:.75rem}.invite-card-actions{justify-content:stretch}.invite-card-actions .btn{flex:1}.invite-link-row{flex-direction:column}.notification-prompt{flex-direction:column;text-align:center;gap:.75rem}.notification-prompt .btn{width:100%}.matchmaking-stub{padding:1rem}}.game-loading,.game-error{max-width:500px;margin:3rem auto;text-align:center;padding:1.5rem}.history-screen{max-width:800px;margin:0 auto;padding:1.5rem}.history-header{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:1.5rem}.history-header h2{margin:0}.history-list{display:flex;flex-direction:column;gap:.5rem}.history-row{display:grid;grid-template-columns:2fr 1fr .8fr 1fr 1fr;align-items:center;gap:.75rem;padding:.75rem 1rem;background:#1e1e1e;border:1px solid #333;border-radius:8px;text-decoration:none;color:inherit;transition:border-color .15s}.history-row:hover,.history-row:active{border-color:#666}.history-opponent{font-weight:500}.history-mode{font-size:.8rem;text-transform:uppercase;letter-spacing:.05em;color:#888}.history-result{font-size:.85rem;font-weight:600;padding:.15rem .5rem;border-radius:10px;text-align:center;width:fit-content}.result-win{background:#1b5e20;color:#a5d6a7}.result-loss{background:#b71c1c;color:#ef9a9a}.result-draw{background:#424242;color:#bbb}.history-moves{font-size:.85rem;color:#aaa}.history-date{font-size:.8rem;color:#888;text-align:right}.history-pagination{display:flex;align-items:center;justify-content:center;gap:1rem;margin-top:1.5rem}.history-page-info{font-size:.85rem;color:#aaa}.stats-bar{display:flex;gap:1rem;padding:1rem;background:#1e1e1e;border:1px solid #333;border-radius:8px;margin-bottom:1.5rem;flex-wrap:wrap;justify-content:center}.stat-item{display:flex;flex-direction:column;align-items:center;min-width:60px}.stat-value{font-size:1.3rem;font-weight:700;color:#e0e0e0}.stat-label{font-size:.7rem;color:#888;text-transform:uppercase;letter-spacing:.05em}.stat-value.stat-win{color:#81c784}.stat-value.stat-loss{color:#e57373}.stat-value.stat-draw{color:#90a4ae}.completed-games-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.75rem}.completed-games-header h3{margin:0}.replay-screen{max-width:960px;margin:0 auto;padding:1rem}.replay-header{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:1rem}.replay-header h2{margin:0;font-size:1.2rem}.replay-layout{display:flex;gap:1.5rem;align-items:flex-start}.replay-main{flex:1;min-width:0}.replay-sidebar{min-width:200px;max-width:260px;display:flex;flex-direction:column;gap:1rem}.replay-controls{display:flex;align-items:center;gap:.5rem;padding:.75rem;background:#1e1e1e;border:1px solid #333;border-radius:8px;margin-top:.5rem;flex-wrap:wrap;justify-content:center}.replay-btn{padding:.3rem .6rem;border:1px solid #555;border-radius:4px;background:transparent;color:#bbb;font-size:.85rem;cursor:pointer;min-width:44px;min-height:44px;display:inline-flex;align-items:center;justify-content:center;text-align:center;transition:border-color .15s,color .15s}.replay-btn:hover:not(:disabled),.replay-btn:active:not(:disabled){border-color:#888;color:#fff}.replay-btn:disabled{opacity:.4;cursor:not-allowed}.replay-btn.active{background:#7c5cbf;border-color:#7c5cbf;color:#fff}.replay-step-info{font-size:.8rem;color:#aaa;margin:0 .5rem}.replay-speed{display:flex;align-items:center;gap:.3rem;margin-left:.5rem}.replay-speed label{font-size:.75rem;color:#888}.replay-speed input[type=range]{width:60px;accent-color:#7c5cbf}.replay-perspective{display:flex;gap:.25rem;margin-top:.5rem;justify-content:center}.perspective-btn{padding:.3rem .6rem;border:1px solid #444;border-radius:4px;background:transparent;color:#aaa;font-size:.75rem;cursor:pointer;transition:all .15s;min-height:44px;display:inline-flex;align-items:center}.perspective-btn:hover,.perspective-btn:active{border-color:#666;color:#e0e0e0}.perspective-btn.active{border-color:#7c5cbf;background:#7c5cbf26;color:#b39ddb}.replay-move-list{background:#1e1e1e;border:1px solid #333;border-radius:8px;overflow:hidden}.replay-move-list-title{font-size:.85rem;font-weight:600;padding:.5rem .75rem;border-bottom:1px solid #333;color:#bbb}.replay-move-list-body{max-height:400px;overflow-y:auto;padding:.25rem 0}.replay-move-entry{display:flex;gap:.5rem;padding:.3rem .75rem;font-size:.8rem;cursor:pointer;transition:background .1s}.replay-move-entry:hover,.replay-move-entry:active{background:#ffffff0a}.replay-move-entry.active{background:#7c5cbf26;color:#b39ddb}.replay-move-num{color:#666;min-width:2em}.replay-move-from,.replay-move-to{color:#ccc}.replay-move-color{min-width:1em}.replay-log{background:#1e1e1e;border:1px solid #333;border-radius:8px;overflow:hidden}.replay-log-title{font-size:.85rem;font-weight:600;padding:.5rem .75rem;border-bottom:1px solid #333;color:#bbb}.replay-log-body{max-height:200px;overflow-y:auto;padding:.25rem 0}.replay-log-entry{padding:.25rem .75rem;font-size:.8rem;color:#ccc}.replay-log-empty{padding:.75rem;text-align:center;color:#666;font-size:.8rem}@media(max-width:640px){.history-row{grid-template-columns:1fr 1fr;gap:.4rem}.history-mode,.history-moves{display:none}.replay-layout{flex-direction:column}.replay-sidebar{min-width:0;max-width:100%;width:100%}}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,sans-serif;background-color:#1a1a2e;color:#e0e0e0;min-height:100vh}#root{min-height:100vh;display:flex;flex-direction:column}.app{display:flex;flex-direction:column;align-items:center;min-height:100vh;padding:1rem}.app-header{display:flex;align-items:center;justify-content:space-between;width:100%;max-width:960px;margin-bottom:1rem}.app-logo-link{text-decoration:none}.app-header h1{font-size:1.5rem;font-weight:700;color:#e0e0e0;letter-spacing:.05em}.app-header h1 span{color:#7c5cbf}.app-version{font-size:.65rem;color:#666;letter-spacing:.04em}.app-nav{display:flex;align-items:center;gap:.75rem}.nav-username{color:#ccc;text-decoration:none;font-size:.9rem}.nav-username:hover,.nav-username:active{color:#7c5cbf}.nav-logout,.nav-login{font-size:.85rem;color:#aaa;background:none;border:1px solid #444;border-radius:4px;padding:.3rem .6rem;cursor:pointer;text-decoration:none;transition:border-color .15s,color .15s;min-height:44px;display:inline-flex;align-items:center}.nav-logout:hover,.nav-login:hover,.nav-logout:active,.nav-login:active{color:#e0e0e0;border-color:#7c5cbf}.auth-loading{display:flex;align-items:center;justify-content:center;margin-top:4rem;color:#888;font-size:1rem}.join-screen{display:flex;flex-direction:column;align-items:center;gap:1.5rem;margin-top:3rem;width:100%}.join-challenge-header{text-align:center;max-width:420px}.join-challenge-header h2{font-size:1.4rem;font-weight:700;color:#e0e0e0;margin-bottom:.5rem}.join-challenge-sub{color:#999;font-size:.95rem}.join-error{color:#e74c3c;font-size:.9rem;margin-top:.5rem}.home-page{display:flex;flex-direction:column;align-items:center}.home-local-section{display:flex;flex-direction:column;align-items:center;gap:.75rem;margin-top:1.25rem;margin-bottom:2rem}.home-local-divider{color:#666;font-size:.85rem;margin:0}.htp-home-link{font-size:.82rem;color:#7c5cbf;text-decoration:underline;cursor:pointer;margin-top:.25rem}.htp-home-link:hover,.htp-home-link:active{color:#9370db}.htp-screen{display:flex;justify-content:center;padding:2rem 1rem 3rem;width:100%}.htp-content{width:100%;max-width:640px}.htp-content h2{font-size:1.4rem;font-weight:700;margin-bottom:1rem;color:#e0e0e0}.htp-intro{font-size:1rem;color:#ccc;line-height:1.6;margin-bottom:2rem;padding-bottom:1.5rem;border-bottom:1px solid #2a2a4a}.htp-section{margin-bottom:2rem}.htp-section h3{font-size:1rem;font-weight:600;color:#e0e0e0;margin-bottom:.75rem;display:flex;align-items:center;gap:.5rem}.htp-icon{display:inline-flex;align-items:center;justify-content:center;width:1.6rem;height:1.6rem;border-radius:50%;background:#7c5cbf22;border:1px solid #7c5cbf66;color:#9370db;font-size:.85rem;font-weight:700;flex-shrink:0}.htp-section p{color:#bbb;line-height:1.65;margin-bottom:.75rem;font-size:.95rem}.htp-note{background:#1a1a2e;border-left:3px solid #7c5cbf;padding:.6rem .9rem;border-radius:0 4px 4px 0;font-size:.88rem;color:#aaa;line-height:1.5;margin-top:.75rem}.htp-outcomes{display:flex;flex-direction:column;gap:.5rem;margin:.75rem 0}.htp-outcome{display:flex;align-items:baseline;gap:.75rem;padding:.6rem .9rem;border-radius:6px;font-size:.9rem}.htp-present{background:#1a3a1a;border:1px solid #2d5a2d}.htp-absent{background:#2a1a1a;border:1px solid #5a2d2d}.htp-outcome-label{font-weight:700;min-width:4.5rem;flex-shrink:0}.htp-present .htp-outcome-label{color:#81c784}.htp-absent .htp-outcome-label{color:#e57373}.htp-outcome-desc{color:#bbb;line-height:1.5}.htp-list{list-style:none;padding:0;margin:.5rem 0 .75rem;display:flex;flex-direction:column;gap:.45rem}.htp-list li{color:#bbb;font-size:.92rem;line-height:1.55;padding-left:1.2rem;position:relative}.htp-list li:before{content:"–";position:absolute;left:0;color:#7c5cbf}.htp-footer{display:flex;gap:.75rem;margin-top:2.5rem;padding-top:1.5rem;border-top:1px solid #2a2a4a}.login-screen{display:flex;justify-content:center;margin-top:3rem;width:100%}.login-card{background:#16213e;border:1px solid #333;border-radius:8px;padding:2rem;width:100%;max-width:380px}.login-card h2{font-size:1.2rem;font-weight:600;margin-bottom:1.5rem;text-align:center;color:#e0e0e0}.login-field{display:flex;flex-direction:column;gap:.3rem;margin-bottom:1rem}.login-field span{font-size:.85rem;color:#aaa}.login-field input{padding:.5rem .75rem;border:1px solid #444;border-radius:4px;background:#1a1a2e;color:#e0e0e0;font-size:.95rem;outline:none;transition:border-color .15s}.login-field input:focus{border-color:#7c5cbf}.login-error{color:#e74c3c;font-size:.85rem;margin-bottom:.75rem;text-align:center}.login-submit{width:100%;padding:.6rem;border:none;border-radius:4px;background:#7c5cbf;color:#fff;font-size:.95rem;font-weight:600;cursor:pointer;transition:background .15s;min-height:44px}.login-submit:hover:not(:disabled),.login-submit:active:not(:disabled){background:#9370db}.login-submit:disabled{opacity:.6;cursor:not-allowed}.login-toggle{margin-top:1rem;text-align:center;font-size:.85rem;color:#888}.login-toggle-btn{background:none;border:none;color:#7c5cbf;cursor:pointer;font-size:.85rem;text-decoration:underline}.login-toggle-btn:hover,.login-toggle-btn:active{color:#9370db}.lobby-screen{display:flex;flex-direction:column;align-items:center;gap:1rem;margin-top:2rem}.lobby-screen h2{font-size:1.25rem;font-weight:600}.lobby-placeholder{color:#888;font-size:.9rem}.lobby-placeholder a{color:#7c5cbf}.game-online-placeholder{margin-top:3rem;color:#888;font-size:.9rem;text-align:center}.mode-select{display:flex;flex-direction:column;align-items:center;gap:1.5rem;margin-top:2rem}.mode-select h2{font-size:1.25rem;font-weight:600}.mode-options{display:flex;gap:.75rem}.mode-btn{padding:.6rem 1.2rem;border:2px solid #444;border-radius:6px;background:transparent;color:#ccc;font-size:.9rem;cursor:pointer;transition:border-color .15s,color .15s;min-height:44px}.mode-btn:hover,.mode-btn:active{border-color:#7c5cbf;color:#fff}.mode-btn-active{border-color:#7c5cbf;background:#7c5cbf22;color:#fff}.player-names{display:flex;gap:1.5rem}.player-names label{display:flex;flex-direction:column;gap:.3rem;font-size:.85rem;color:#aaa}.player-names input{padding:.4rem .6rem;border:1px solid #444;border-radius:4px;background:#252540;color:#e0e0e0;font-size:.9rem;width:140px;min-height:44px}.player-names input:focus{outline:none;border-color:#7c5cbf}.variant-rules-panel{width:100%;max-width:320px;background:#252540;border:1px solid #444;border-radius:6px;overflow:hidden}.variant-rules-title{font-size:.8rem;font-weight:600;padding:.5rem .75rem;border-bottom:1px solid #333;color:#bbb;letter-spacing:.04em}.variant-rules-list{list-style:none;padding:.35rem 0}.variant-rule{display:flex;align-items:center;gap:.5rem;padding:.25rem .75rem;font-size:.82rem;cursor:default}.variant-rule-icon{flex-shrink:0;width:1.1em;text-align:center;font-weight:700}.variant-rule-on .variant-rule-icon{color:#81c784}.variant-rule-on .variant-rule-label{color:#e0e0e0}.variant-rule-off .variant-rule-icon{color:#666}.variant-rule-off .variant-rule-label{color:#777}.start-btn{padding:.7rem 2rem;border:none;border-radius:6px;background:#7c5cbf;color:#fff;font-size:1rem;font-weight:600;cursor:pointer;transition:background .15s;min-height:44px}.start-btn:hover,.start-btn:active{background:#6a4aad}.game-screen{display:flex;gap:1.5rem;width:100%;max-width:900px;align-items:flex-start}.game-main{display:flex;flex-direction:column;gap:.5rem;flex:1;min-width:0;position:relative}.game-sidebar{display:flex;flex-direction:column;gap:1rem;min-width:180px}.bug-report-btn{padding:.3rem .6rem;border:1px solid #444;border-radius:4px;background:transparent;color:#888;font-size:.75rem;cursor:pointer;transition:border-color .15s,color .15s;align-self:flex-start}.bug-report-btn:hover,.bug-report-btn:active{border-color:#888;color:#ccc}.back-to-lobby-link{display:block;margin-top:auto;padding:.5rem .75rem;font-size:.85rem;color:#ccc;text-decoration:none;text-align:center;border:1px solid #444;border-radius:6px;transition:border-color .15s,color .15s}.back-to-lobby-link:hover,.back-to-lobby-link:active{color:#fff;border-color:#666}.turn-indicator{display:flex;align-items:center;gap:.5rem;padding:.6rem 1rem;border-radius:6px;background:#252540;font-size:.9rem;font-weight:500}.turn-dot{width:12px;height:12px;border-radius:50%}.dot-white{background:#f8f8f8;border:1px solid #888}.dot-black{background:#1a1a1a;border:1px solid #888}.captured-pieces{display:flex;align-items:center;gap:.5rem;min-height:2rem}.captured-label{font-size:.75rem;color:#888;white-space:nowrap}.captured-list{display:flex;flex-wrap:wrap;gap:2px}.captured-piece{display:inline-flex;width:1.5rem;height:1.5rem}.captured-piece .piece{width:100%;height:100%}.action-log{background:#252540;border-radius:6px;overflow:hidden}.action-log-title{font-size:.85rem;font-weight:600;padding:.5rem .75rem;border-bottom:1px solid #333;color:#bbb}.action-log-list{max-height:300px;overflow-y:auto;padding:.25rem 0}.action-log-empty{padding:1rem;text-align:center;color:#666;font-size:.8rem}.action-log-entry{display:flex;align-items:flex-start;gap:.4rem;padding:.3rem .75rem;font-size:.8rem;line-height:1.4}.action-log-entry:hover{background:#ffffff08}.log-icon{flex-shrink:0;font-size:.75rem;width:1.2em;text-align:center}.log-text{color:#ccc}.log-type-capture .log-text{color:#e57373}.log-type-check .log-text{color:#ffb74d;font-weight:600}.log-type-game_event .log-text{color:#81c784;font-weight:600}.mode-badge{padding:.3rem .8rem;border-radius:4px;background:#7c5cbf33;border:1px solid #7c5cbf;color:#b39ddb;font-size:.75rem;text-align:center;font-weight:600;letter-spacing:.05em}.rules-panel{background:#252540;border-radius:6px;overflow:hidden}.rules-panel-header{display:flex;align-items:center;justify-content:space-between;padding:.45rem .75rem;font-size:.8rem;font-weight:600;color:#bbb;letter-spacing:.04em;cursor:pointer;-webkit-user-select:none;user-select:none;transition:background .1s}.rules-panel-header:hover,.rules-panel-header:active{background:#ffffff0a}.rules-panel-toggle{font-size:.7rem;color:#777;transition:transform .2s}.rules-panel-toggle.open{transform:rotate(90deg)}.rules-panel-body{border-top:1px solid #333;padding:.3rem 0}.game-controls{display:flex;align-items:center;gap:.75rem;padding:.4rem .75rem;background:#252540;border-radius:6px;font-size:.8rem;flex-wrap:wrap}.game-controls-info{display:flex;align-items:center;gap:.5rem}.gc-move-number{color:#999;font-weight:500}.game-controls-actions{display:flex;align-items:center;gap:.5rem;margin-left:auto}.gc-btn{padding:.25rem .6rem;border:1px solid #555;border-radius:4px;background:transparent;color:#bbb;font-size:.75rem;cursor:pointer;transition:border-color .15s,color .15s;min-height:32px}.gc-btn:hover,.gc-btn:active{border-color:#888;color:#e0e0e0}.gc-btn-draw:hover,.gc-btn-draw:active{border-color:#7c5cbf;color:#b39ddb}.gc-btn-resign:hover,.gc-btn-resign:active{border-color:#e57373;color:#ef9a9a}.gc-draw-offered{display:flex;align-items:center;gap:.4rem}.gc-draw-label{color:#c9a44a;font-size:.75rem}.gc-btn-accept{border-color:#4caf50;color:#81c784}.gc-btn-accept:hover,.gc-btn-accept:active{background:#4caf5026}.gc-btn-decline{color:#999}.gc-resign-confirm{display:flex;align-items:center;gap:.4rem}.gc-resign-label{color:#e57373;font-weight:600;font-size:.75rem}.gc-btn-resign-yes{border-color:#e57373;color:#ef9a9a}.gc-btn-resign-yes:hover,.gc-btn-resign-yes:active{background:#e5737326}.gc-btn-resign-no{color:#999}@media(max-width:640px){.app{padding:.5rem}.app-header h1{font-size:1.2rem;margin-bottom:.5rem}.game-screen{flex-direction:column;align-items:center;gap:.5rem}.game-main{gap:.25rem;width:100%}.game-sidebar{width:100%;min-width:0}.mode-options{flex-direction:column}.player-names{flex-direction:column;gap:.75rem}.player-names input{width:100%}.game-controls{padding:.3rem .5rem;font-size:.75rem;gap:.4rem}.gc-btn{padding:.2rem .5rem;font-size:.7rem;min-height:44px}.gc-draw-label{font-size:.7rem}.captured-pieces{min-height:1.5rem}.captured-label{font-size:.65rem}.captured-piece{width:1.2rem;height:1.2rem}}.move-loading-overlay{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;background:#00000026;pointer-events:none;z-index:20}.move-loading-spinner{width:2rem;height:2rem;border:3px solid rgba(255,255,255,.3);border-top-color:var(--accent, #7c3aed);border-radius:50%;animation:spin .6s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.error-toast{position:absolute;bottom:.5rem;left:50%;transform:translate(-50%);background:#dc2626;color:#fff;padding:.5rem 1rem;border-radius:6px;font-size:.85rem;cursor:pointer;z-index:30;animation:toast-in .2s ease-out;max-width:90%;text-align:center}@keyframes toast-in{0%{opacity:0;transform:translate(-50%) translateY(10px)}to{opacity:1;transform:translate(-50%) translateY(0)}}.offline-indicator{color:#e74c3c;font-size:.8rem;font-weight:600;letter-spacing:.03em}.install-prompt{position:fixed;bottom:0;left:0;right:0;display:flex;align-items:center;justify-content:center;gap:1rem;padding:.75rem 1rem;background:#16213e;border-top:1px solid #7c5cbf;z-index:100;animation:slide-up .3s ease-out}@keyframes slide-up{0%{transform:translateY(100%)}to{transform:translateY(0)}}.install-prompt-text{font-size:.9rem;color:#e0e0e0}.install-prompt-actions{display:flex;gap:.5rem}.install-prompt-btn{padding:.4rem .8rem;border-radius:4px;font-size:.85rem;font-weight:600;cursor:pointer;transition:background .15s}.install-prompt-btn.install{background:#7c5cbf;color:#fff;border:none}.install-prompt-btn.install:hover,.install-prompt-btn.install:active{background:#9370db}.install-prompt-btn.dismiss{background:transparent;color:#aaa;border:1px solid #555}.install-prompt-btn.dismiss:hover,.install-prompt-btn.dismiss:active{color:#e0e0e0;border-color:#888}@media(max-width:640px){.install-prompt{flex-direction:column;gap:.5rem;padding:.6rem .75rem}.install-prompt-text{font-size:.8rem}}
