:root{font-family:Space Grotesk,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;color:#0b0c0f;background-color:#f7f4ef;line-height:1.4;font-weight:400;color-scheme:light}*{box-sizing:border-box}body{margin:0;min-height:100vh;background:radial-gradient(circle at top,#fefefe,#ede7dd)}button{font-family:inherit}.app{padding:1.5rem;max-width:1200px;margin:0 auto;display:flex;flex-direction:column;gap:1.5rem}header{display:flex;flex-wrap:wrap;justify-content:space-between;gap:1rem;align-items:center}header h1{margin:0;font-size:2rem}.tabs{display:flex;gap:.5rem}.tabs button{padding:.5rem 1.5rem;border:1px solid rgba(0,0,0,.1);border-radius:.5rem;background:#fff;cursor:pointer;font-size:1rem;transition:all .15s ease}.tabs button:hover{background:#f5f5f5}.tabs button.active{background:#2e7bb5;color:#fff;border-color:#2e7bb5}.mode-selector-wrapper{margin-bottom:.5rem}.layout{display:grid;grid-template-columns:minmax(0,1fr) 280px;gap:1.25rem}.left-panel{display:flex;flex-direction:column;gap:1rem}.board{display:grid;gap:.4rem;padding:.75rem;border-radius:1rem;background:linear-gradient(145deg,#f2eadf,#e1d7c5);box-shadow:inset 0 1px 3px #0000001a;aspect-ratio:1;width:100%;max-width:min(100%,calc(432px + 3.5rem));margin:0 auto;min-width:0;grid-auto-rows:1fr;contain:layout}.board-cell{position:relative;padding:0;aspect-ratio:1;border:none;border-radius:12px;background:#ffffffa6;cursor:pointer;transition:transform .12s ease,background .12s ease;min-width:0;min-height:0;width:100%;height:100%;display:flex;align-items:center;justify-content:center;overflow:hidden}.board-cell:disabled{cursor:not-allowed;opacity:.7}.board-cell.cell-has-piece{background:#ffffffe6}.board-cell.cell-preview-origin,.board-cell.cell-impact-origin{box-shadow:inset 0 0 0 3px #f909}.board-cell.cell-preview-destination,.board-cell.cell-impact-destination{animation:pulse .6s ease-out;background:#87cefa59}.board-cell.cell-pending-removal{outline:3px dashed #d97757}.board-cell.cell-removal-required{opacity:.8}.board-cell.cell-preview-off-board{outline:2px dotted #999}.board-cell:hover:not(:disabled){transform:translateY(-2px)}.piece{display:block;width:66%;height:66%;max-width:48px;max-height:48px;border-radius:50%;object-fit:cover;margin:0 auto;transition:transform .15s ease;aspect-ratio:1}.piece.kitten{border:3px solid currentColor;box-sizing:border-box}.piece.cat{border:6px solid currentColor;box-sizing:border-box}.piece.player-1{border-color:#2e7bb5}.piece.player-2{border-color:#e91e63}.piece.ghost{opacity:.4;border-style:dashed}.boop-arrow{position:absolute;width:8px;height:8px;border-radius:999px;background:#0b0c0f;right:8px;bottom:8px}.mode-selector{display:grid;gap:.5rem;grid-template-columns:repeat(auto-fit,minmax(160px,1fr))}.mode-selector button{padding:.75rem;border-radius:.75rem;border:1px solid rgba(0,0,0,.08);background:#fff;text-align:left;cursor:pointer}.mode-selector button.active{border-color:#2e7bb5;box-shadow:0 0 0 2px #2e7bb51a}.mode-selector small{display:block;color:#555}.control-bar{display:flex;align-items:center;gap:1rem;flex-wrap:wrap;padding:.75rem 1rem;border-radius:.75rem;background:#ffffffd9}.piece-toggle{display:inline-flex;border-radius:999px;background:#f0e8dc;padding:.2rem}.piece-toggle button{border:none;background:transparent;padding:.4rem .9rem;border-radius:999px;cursor:pointer}.piece-toggle button.active{background:#fff;box-shadow:0 1px 3px #0000001a}.status-text{flex:1;min-width:220px}.status-pill{margin-left:.5rem;padding:.15rem .5rem;border-radius:999px;font-size:.85rem;background:#ffe08a}.reserve-panel{display:flex;flex-direction:column;gap:1rem}.reserve-card{padding:1rem;border-radius:.75rem;background:#ffffffd9;border:2px solid transparent}.reserve-card.active{border-color:#2e7bb5}.reserve-card h3{margin-top:0;margin-bottom:.5rem}.reserve-row{display:flex;justify-content:space-between;font-size:.95rem}.online-panel{display:flex;gap:1rem;flex-wrap:wrap;padding:1rem;border-radius:.75rem;background:#ffffffd9}.online-panel label{display:flex;flex-direction:column;font-size:.85rem;gap:.25rem}.online-panel input{padding:.4rem .6rem;border-radius:.5rem;border:1px solid rgba(0,0,0,.2)}.online-buttons{display:flex;gap:.5rem;flex-wrap:wrap;margin-top:.5rem}.online-panel button{border:none;border-radius:.5rem;padding:.4rem .9rem;background:#2e7bb5;color:#fff;cursor:pointer}.online-panel button:disabled{opacity:.6;cursor:not-allowed}.online-status{flex:1;min-width:220px}.online-status .error{color:#b3261e;margin:.4rem 0 0}@keyframes pulse{0%{transform:scale(.95)}to{transform:scale(1)}}.rules-page{max-width:800px;margin:0 auto}.rules-content{background:#ffffffd9;border-radius:1rem;padding:2rem;line-height:1.6}.rules-content h2{margin-top:0;margin-bottom:1.5rem;font-size:2rem;color:#2e7bb5}.rules-content h3{margin-top:1.5rem;margin-bottom:.75rem;font-size:1.25rem;color:#333}.rules-content section{margin-bottom:1.5rem}.rules-content p{margin:.5rem 0;color:#555}.rules-content ul{margin:.5rem 0;padding-left:1.5rem;color:#555}.rules-content li{margin:.5rem 0}.rules-content strong{color:#2e7bb5;font-weight:600}@media(max-width:960px){.layout{grid-template-columns:1fr}.board{justify-items:center;max-width:100%}.board-cell{min-width:40px;min-height:40px}.rules-content{padding:1.5rem}}
