@import"https://fonts.googleapis.com/css2?family=Fraunces:wght@500;700&family=Noto+Serif+SC:wght@600;700&family=Noto+Serif+TC:wght@600;700&family=Space+Grotesk:wght@400;500;700&display=swap";:root{font-family:Space Grotesk,system-ui,sans-serif;line-height:1.5;font-weight:400;color:#1c1914;background-color:#f2e6d2;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}html,body{height:100%}*,*:before,*:after{box-sizing:border-box}body{margin:0;min-height:100vh;background:radial-gradient(circle at top,#fff1d9,#f1ddbc 40%,#e6cda3);color:#1c1914;overflow:hidden}#app{height:100%}.app{padding:clamp(14px,2.4vw,32px);display:flex;flex-direction:column;gap:24px;animation:floatIn .8s ease forwards;height:100%;overflow-y:auto}.top{display:flex;flex-wrap:wrap;gap:16px;justify-content:space-between;align-items:flex-end}.title h1{margin:6px 0 8px;font-family:Fraunces,serif;font-size:clamp(32px,4vw,44px);letter-spacing:.02em}.eyebrow{text-transform:uppercase;letter-spacing:.3em;font-size:12px;color:#695a43;margin:0}.subtitle{margin:0;max-width:540px;color:#4b4032}.status{display:flex;gap:10px;flex-wrap:wrap}.pill{padding:8px 14px;border-radius:999px;background:#f5e9d5;border:1px solid #d9c3a1;font-size:13px;text-transform:uppercase;letter-spacing:.08em}.pill.ok{background:#e8f3ea;border-color:#98c7a0}.pill.warn{background:#fff1d1;border-color:#f0c981}.pill.error{background:#ffe3dc;border-color:#e39a88}.layout{display:grid;grid-template-columns:minmax(0,1.35fr) minmax(260px,.65fr);gap:24px;align-items:start}.board-card{background:linear-gradient(145deg,#f7ead3,#ebd0a8);border-radius:20px;border:1px solid #d9c3a1;padding:clamp(16px,2vw,24px);box-shadow:0 22px 40px #4e3c222e;display:flex;flex-direction:column;gap:12px}.board-stage{width:100%;display:flex;justify-content:center}canvas#board{border-radius:18px;background:#f6e7c9;box-shadow:inset 0 0 0 2px #5a432759,inset 0 -12px 20px #5a432714}.board-footer{display:flex;flex-wrap:wrap;gap:12px 20px;justify-content:space-between}.panel{display:flex;flex-direction:column;gap:16px}.panel-block{background:#fff5e2;border-radius:18px;padding:18px;border:1px solid #e1caa5;box-shadow:0 12px 24px #4e3c2224}.panel-block h2{margin:0 0 8px;font-size:18px;color:#2f271c}.stat-row{display:flex;justify-content:space-between;align-items:center;padding:6px 0;font-size:14px;color:#4c3f2f}.stat-row strong{font-size:16px}.meta{margin:0;font-size:13px;color:#5a4c39}.meta-list{margin:0;padding-left:18px;color:#5a4c39;font-size:13px}button{font-family:inherit}.controls{margin-top:12px;display:grid;gap:12px}.field{display:grid;gap:6px}.label{font-size:12px;text-transform:uppercase;letter-spacing:.18em;color:#6a5841}.segmented{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px}.seg-btn{border:1px solid #d6bd94;background:#f4e6cf;color:#3a2d1f;padding:8px 12px;border-radius:10px;font-weight:600;letter-spacing:.06em;text-transform:uppercase;cursor:pointer;transition:transform .2s ease,box-shadow .2s ease}.seg-btn.active{background:#2c251a;color:#fff1d6;border-color:#2c251a;box-shadow:0 10px 16px #2c251a33}.seg-btn:disabled{opacity:.5;cursor:not-allowed}.select select{width:100%;border-radius:10px;border:1px solid #d6bd94;background:#f4e6cf;padding:8px 12px;font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:#3a2d1f}.select select:disabled{opacity:.5;cursor:not-allowed}.action{margin-top:12px;width:100%;border:none;border-radius:12px;padding:12px 16px;font-weight:600;letter-spacing:.06em;text-transform:uppercase;background:linear-gradient(120deg,#b23b2d,#d66b47);color:#fff7eb;cursor:pointer;box-shadow:0 12px 18px #b23b2d33;transition:transform .2s ease,box-shadow .2s ease}.action:hover{transform:translateY(-1px);box-shadow:0 16px 28px #b23b2d47}.ghost{background:transparent;color:#3a2d1f;border:1px solid #d6bd94;box-shadow:none;padding:8px 14px;border-radius:10px;font-weight:600;letter-spacing:.06em;text-transform:uppercase;cursor:pointer}.ghost:hover{box-shadow:0 12px 20px #342a1c1f}.log{display:flex;flex-direction:column;gap:8px;font-size:13px;color:#3d3326;max-height:220px;overflow:hidden}.log-item{padding:8px 10px;border-radius:10px;background:#f2e2c5;border:1px solid #e0c8a2}.log-item.last{background:#fff6e5;border-color:#e9b26c}.overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#1a130c8c;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);display:flex;align-items:center;justify-content:center;padding:20px;opacity:1;transition:opacity .2s ease;z-index:10}.overlay.hidden{opacity:0;pointer-events:none}.overlay-card{background:#fff3de;border-radius:20px;padding:26px;border:1px solid #e1caa5;box-shadow:0 24px 44px #1e160d66;min-width:min(360px,90vw);text-align:center}.overlay-eyebrow{margin:0;letter-spacing:.3em;text-transform:uppercase;font-size:12px;color:#6f5c45}.overlay-card h2{margin:12px 0 8px;font-family:Fraunces,serif;font-size:28px}.overlay-reason{margin:0 0 16px;color:#5a4c39}.overlay-actions{display:flex;flex-wrap:wrap;gap:12px;justify-content:center}.overlay-actions .action{width:auto;margin-top:0}.overlay-stats{margin-top:16px;display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}.overlay-stats .stat{background:#f6e4c4;border-radius:12px;padding:10px 12px;border:1px solid #e0c29a;display:grid;gap:6px}.stat-label{font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:#6c5a42}.replay{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:12px 16px;border-radius:14px;background:#201810c7;color:#f5e6cf;box-shadow:0 12px 24px #0003}.replay.hidden{display:none}.replay-label{font-weight:600;letter-spacing:.08em;text-transform:uppercase;font-size:12px}.replay .ghost{width:auto;margin:0;color:#f5e6cf;border-color:#f5e6cf66}.confetti{position:fixed;top:0;right:0;bottom:0;left:0;pointer-events:none;z-index:12}@media (max-width: 960px){.layout,.overlay-stats{grid-template-columns:1fr}}@media (max-height: 760px){.layout{grid-template-columns:1fr}.app{gap:16px}.board-card{padding:12px}}@keyframes floatIn{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}
