@import"https://fonts.googleapis.com/css2?family=Fraunces:wght@400;600;700&family=IBM+Plex+Mono:wght@400;600;700&display=swap";:root{color-scheme:light;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;--font-display: "Fraunces", "Georgia", serif;--font-mono: "IBM Plex Mono", "Courier New", monospace;--ink: #1b1b1b;--ink-muted: #4a3f35;--paper: #f7efe2;--paper-strong: #e9dac1;--panel: #fff9f0;--line: #d1bfa6;--accent: #1f6d6a;--accent-strong: #0f4d4a;--accent-soft: rgba(31, 109, 106, .16);--warn: #b4472d;--shadow: 0 16px 40px rgba(26, 18, 9, .18);--shadow-soft: 0 10px 22px rgba(26, 18, 9, .14)}*,*:before,*:after{box-sizing:border-box}body{margin:0;min-width:320px;min-height:100vh;color:var(--ink);font-family:var(--font-display);line-height:1.5;background:radial-gradient(1200px 600px at 12% 12%,rgba(255,230,186,.8),transparent 60%),radial-gradient(900px 500px at 90% 10%,rgba(255,255,255,.7),transparent 55%),linear-gradient(135deg,#f2e5d1,#efe1cd 45%,#e7d2b8)}a{font-weight:600;color:var(--accent);text-decoration:none}a:hover{color:var(--accent-strong)}button{border-radius:999px;border:1px solid var(--line);padding:.55rem 1.1rem;font-size:.95rem;font-weight:600;font-family:var(--font-mono);background-color:var(--paper);color:var(--ink);cursor:pointer;transition:transform .15s ease,box-shadow .2s ease,background .2s ease}button:hover{background-color:#fffdf8;box-shadow:var(--shadow-soft);transform:translateY(-1px)}button:focus-visible{outline:3px solid var(--accent-soft);outline-offset:2px}#root{margin:0;padding:0;width:100%;min-height:100vh}.app{min-height:100vh;display:flex;flex-direction:column;gap:12px}.app-header{width:100%;max-width:1200px;margin:0 auto;padding:6px 8px 0}.app-kicker{margin:0 0 6px;font-family:var(--font-mono);letter-spacing:.28em;text-transform:uppercase;font-size:.7rem;color:var(--ink-muted)}.app-title{margin:0;font-size:1.4rem;letter-spacing:.01em}.app-subtitle{margin:8px 0 0;max-width:640px;color:var(--ink-muted);font-size:1rem}.play-area{width:100%;max-width:1200px;margin:0 auto;padding:6px 8px 8px;display:grid;grid-template-columns:minmax(0,1fr) 320px;gap:8px;align-items:start}.board-shell{background:var(--paper);border:1px solid var(--line);border-radius:22px;padding:4px;box-shadow:var(--shadow)}.board{width:100%;background:#fdf8f1;border-radius:16px;overflow:hidden}.board svg{display:block;width:100%;height:auto}.room-hit{fill:transparent;cursor:pointer;transition:fill .2s ease;pointer-events:all}.room-hit--reachable{fill:#2e957538}.room-hit--blocked{fill:#0000002e}.room-hit:hover{fill:#ffffff29}.piece{stroke:#ffffffe6;stroke-width:1.4;filter:drop-shadow(0 1px 2px rgba(0,0,0,.35))}.piece--locked{opacity:1;cursor:default}.piece--movable{cursor:pointer}.piece--selected{stroke:#96f;stroke-width:3;filter:drop-shadow(0 0 6px rgba(122,74,217,.65))}.piece--planned-ghost{stroke:#1f4f7a;stroke-width:4;filter:drop-shadow(0 0 4px rgba(43,108,176,.45))}.piece-label{font-family:var(--font-mono);font-weight:800;text-anchor:middle;dominant-baseline:middle;pointer-events:none}.planner-panel{background:var(--panel);border:1px solid var(--line);border-radius:22px;padding:10px 12px;box-shadow:var(--shadow-soft)}.planner-header{display:flex;justify-content:space-between;align-items:start;gap:12px;margin-bottom:10px}.planner-header-actions{display:flex;align-items:center;gap:10px}.planner-kicker{margin:0;font-family:var(--font-mono);font-size:.75rem;letter-spacing:.16em;text-transform:uppercase;color:var(--ink-muted)}.planner-title{margin:6px 0 0;font-size:1.4rem}.planner-info-button,.planner-reset-button{padding-inline:.9rem}.planner-line{display:flex;justify-content:space-between;gap:12px;padding:10px 0;border-bottom:1px dashed var(--line)}.planner-line:last-of-type{border-bottom:none}.planner-label{font-family:var(--font-mono);font-size:.82rem;text-transform:uppercase;letter-spacing:.08em;color:var(--ink-muted)}.planner-value{text-align:right;font-weight:600}.planner-actions{display:flex;gap:12px;margin-top:16px}.planner-button--primary{background:var(--accent);color:#fefbf5;border-color:var(--accent-strong)}.planner-button--primary:hover{background:var(--accent-strong)}.planner-error{margin:14px 0 0;padding:10px 12px;border-radius:12px;background:#b4472d1a;color:var(--warn);font-weight:600}.planner-info{margin-top:16px;padding:12px;border-radius:14px;background:#fffdf8;border:1px solid var(--line);font-size:.95rem;color:var(--ink-muted)}.planner-info h3{margin:0 0 8px;color:var(--ink)}.play-area-summary{grid-column:1 / -1}.game-summary{margin:0;padding:16px;background:#ffffffa6;border-radius:16px;border:1px solid var(--line);font-family:var(--font-mono);font-size:.85rem;text-align:left;white-space:pre-wrap}.game-summary--history{margin-top:0}.play-area-error{padding:24px;color:var(--warn);font-weight:600}@media(max-width:980px){.play-area{grid-template-columns:1fr}.planner-panel{order:-1}}
