*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}body{font-family:system-ui,sans-serif;background:#1a1a2e;color:#eee;min-height:100vh;display:flex;align-items:center;justify-content:center}.game{display:flex;flex-direction:column;align-items:center;gap:16px;padding:24px}.title{font-size:1.8rem;letter-spacing:.05em;color:#fff}.counters{display:flex;gap:32px}.disc-counter{display:flex;flex-direction:column;align-items:center;gap:6px;padding:8px 16px;border-radius:8px;border:2px solid transparent;transition:border-color .15s}.disc-counter.active{border-color:#fff6}.player-label{font-size:.85rem;text-transform:uppercase;letter-spacing:.1em;font-weight:600}.disc-counter.red .player-label{color:#e05c5c}.disc-counter.black .player-label{color:#aaa}.disc-pips{display:flex;gap:5px}.disc-pip{width:14px;height:14px;border-radius:50%}.disc-pip.red{background:#e05c5c}.disc-pip.black{background:#555}.disc-pip.empty{background:transparent;border:1px solid #444}.player-banner{font-size:1.1rem;font-weight:600;padding:6px 20px;border-radius:20px;letter-spacing:.05em}.player-banner.playing.red{color:#e05c5c}.player-banner.playing.black{color:#aaa}.player-banner.won{color:gold}.player-banner.draw{color:#aaa}.board-area{display:flex;flex-direction:column;align-items:center;gap:4px}.drop-targets{display:flex;align-items:center;gap:4px}.shift-spacer{width:40px;flex-shrink:0}.board-rows{display:flex;flex-direction:column;gap:4px}.board-row-wrapper{display:flex;align-items:center;gap:4px}.row-frame{width:248px;height:80px;overflow-x:hidden;flex-shrink:0}.row-slider{display:flex;gap:4px;width:416px;transition:transform .22s cubic-bezier(.4,0,.2,1);overflow:hidden}@keyframes drop-in{0%{transform:translateY(-48px) scale(.75);opacity:0}65%{transform:translateY(5px) scale(1.08);opacity:1}to{transform:translateY(0) scale(1);opacity:1}}.cell{width:80px;height:80px;border-radius:50%;border:3px solid #333;background:#16213e;transition:background .12s,border-color .2s;flex-shrink:0}.cell.red{background:#e05c5c;border-color:#e05c5c}.cell.black{background:#555;border-color:#777}.cell.winning{box-shadow:inset 0 0 0 4px gold;border-color:gold}.cell.drop-in{animation:drop-in .28s cubic-bezier(.4,0,.2,1) forwards}button{cursor:pointer;border:none;background:none;color:inherit;font-size:inherit;font-family:inherit}.drop-target{width:80px;height:36px;font-size:1.1rem;color:#aaa;background:#fff1;border-radius:6px;transition:background .1s,color .1s;flex-shrink:0}.drop-target:not(:disabled):hover{background:#fff2;color:#fff}.drop-target:disabled,.shift-btn:disabled{opacity:.2;cursor:not-allowed}.shift-btn{width:40px;height:80px;font-size:1.2rem;color:#aaa;background:#fff1;border-radius:6px;transition:background .1s,color .1s;flex-shrink:0}.shift-btn:not(:disabled):hover{background:#fff2;color:#fff}.online-lobby{display:flex;flex-direction:column;align-items:center;gap:16px;padding:32px 24px}.lobby-heading{font-size:1.4rem;font-weight:600;color:#fff}.lobby-status{font-size:1.1rem;color:#aaa}.lobby-hint{font-size:.9rem;color:#888;text-align:center;max-width:280px}.lobby-error{font-size:.9rem;color:#e05c5c}.lobby-btn{padding:12px 28px;border-radius:8px;font-size:1rem;font-weight:600;letter-spacing:.05em;background:#fff3;color:#fff;transition:background .15s}.lobby-btn:hover{background:#fff4}.lobby-btn.secondary{background:#fff1;font-size:.9rem}.lobby-btn.secondary:hover{background:#fff2}.share-row{display:flex;gap:8px;width:100%;max-width:360px}.share-url{flex:1;padding:8px 12px;border-radius:6px;border:1px solid #444;background:#0d1b2a;color:#ccc;font-size:.85rem;font-family:monospace;min-width:0}.copy-btn{padding:8px 14px;border-radius:6px;background:#fff2;color:#fff;font-size:.85rem;font-weight:600;white-space:nowrap;transition:background .15s}.copy-btn:hover{background:#fff3}.username-input{padding:8px 12px;border-radius:6px;border:1px solid #444;background:#0d1b2a;color:#fff;font-size:1rem;font-family:inherit;width:200px;text-align:center}.username-input::placeholder{color:#555}.opponent-name{font-size:.85rem;color:#888;letter-spacing:.05em}.spectator-label{font-style:italic}.repetition-warning{font-size:.85rem;color:#e0a020;text-align:center;padding:4px 0}.rematch-row{display:flex;align-items:center;justify-content:center;min-height:48px}.rematch-waiting{font-size:.9rem;color:#888}@keyframes rematch-pulse{0%,to{box-shadow:0 0 6px 2px #ffffff3b}50%{box-shadow:0 0 18px 6px #ffffff8f}}.lobby-btn.rematch-glow{animation:rematch-pulse 1s ease-in-out infinite}.pre-lobby{display:flex;flex-direction:column;align-items:center;gap:32px;padding:48px 24px}.lobby-options{display:flex;flex-direction:column;gap:20px;width:100%;max-width:420px}.lobby-option-group{display:flex;flex-direction:column;gap:8px}.lobby-option-label{font-size:.75rem;text-transform:uppercase;letter-spacing:.12em;font-weight:600;color:#888}.lobby-option-btns{display:flex;gap:8px;flex-wrap:wrap}.lobby-option-btn{padding:10px 18px;border-radius:8px;font-size:1rem;font-weight:600;letter-spacing:.03em;background:#ffffff18;color:#ccc;transition:background .12s,color .12s}.lobby-option-btn:hover{background:#ffffff28;color:#fff}.lobby-option-btn.active{background:#ffffff38;color:#fff;outline:2px solid #ffffff66}.custom-fields{display:flex;gap:12px;flex-wrap:wrap;overflow:hidden;max-height:0;transition:max-height .25s ease}.custom-fields.open{max-height:120px}.custom-field{display:flex;flex-direction:column;gap:4px}.custom-field-label{font-size:.75rem;text-transform:uppercase;letter-spacing:.1em;font-weight:600;color:#666}.custom-field-stepper{display:flex;align-items:center;border-radius:8px;border:1px solid #333;overflow:hidden}.custom-field-input{width:48px;padding:8px 6px;border:none;background:#0d1b2a;color:#fff;font-size:1rem;font-family:inherit;text-align:center}.custom-field-input:focus{outline:none}.custom-field-input::-webkit-outer-spin-button,.custom-field-input::-webkit-inner-spin-button{-webkit-appearance:none}.custom-field-input[type=number]{-moz-appearance:textfield;-webkit-appearance:textfield;appearance:textfield}.custom-field-arrows{display:flex;flex-direction:column;border-left:1px solid #333}.custom-arrow-btn{width:28px;height:20px;font-size:.55rem;line-height:1;background:#0d1b2a;color:#888;transition:background .1s,color .1s}.custom-arrow-btn+.custom-arrow-btn{border-top:1px solid #333}.custom-arrow-btn:not(:disabled):hover{background:#ffffff18;color:#fff}.custom-arrow-btn:disabled{opacity:.25;cursor:not-allowed}.lobby-play-btn{padding:14px 48px;border-radius:10px;font-size:1.2rem;font-weight:700;letter-spacing:.08em;background:#fff3;color:#fff;transition:background .15s}.lobby-play-btn:hover{background:#fff4}.app-footer{display:flex;gap:20px;align-items:center;justify-content:center;padding:12px 0 24px}.footer-btn{font-size:.85rem;color:#666;transition:color .12s}.footer-btn:hover{color:#aaa}.footer-link{font-size:.85rem;color:#666;text-decoration:none;transition:color .12s}.footer-link:hover{color:#aaa}.rules-dialog{background:#0d1b2a;color:#ccc;border:1px solid #333;border-radius:12px;padding:0;max-width:440px;width:calc(100vw - 48px)}.rules-dialog::backdrop{background:#000a}.rules-content{padding:28px 32px 24px;display:flex;flex-direction:column;gap:16px}.rules-content h2{font-size:1.3rem;font-weight:700;color:#fff;margin:0}.rules-content h3{font-size:.75rem;text-transform:uppercase;letter-spacing:.12em;font-weight:600;color:#888;margin:0 0 6px}.rules-content section{display:flex;flex-direction:column}.rules-content p,.rules-content li{font-size:.95rem;line-height:1.5;margin:0}.rules-content ul{padding-left:18px;display:flex;flex-direction:column;gap:4px;margin:0}.rules-close-btn{align-self:flex-end;margin-top:8px;padding:8px 24px;border-radius:8px;font-size:.95rem;font-weight:600;background:#fff2;color:#fff;transition:background .12s}.rules-close-btn:hover{background:#fff3}.game-btns{display:flex;gap:8px}.back-btn{padding:8px 16px;border-radius:8px;font-size:.9rem;font-weight:600;letter-spacing:.04em;background:#ffffff14;color:#aaa;transition:background .12s,color .12s}.back-btn:hover{background:#fff2;color:#fff}
