body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;margin:0}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}.app-layout{display:flex;height:100vh;overflow:hidden;width:100vw}.sidebar{background:#f4f7fb;border-right:1px solid #0000000f;padding:18px}.sidebar h2{color:#1f2937;font-size:16px;margin:0 0 8px}.sidebar button{background:#2b6cb0;border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:14px;padding:8px 10px}.sidebar button.secondary{background:#4b5563}.canvas-wrap{flex:1 1 auto}.App{text-align:center}.App-logo{height:40vmin;pointer-events:none}@media (prefers-reduced-motion:no-preference){.App-logo{animation:App-logo-spin 20s linear infinite}}.App-header{align-items:center;background-color:#282c34;color:#fff;display:flex;flex-direction:column;font-size:calc(10px + 2vmin);justify-content:center;min-height:100vh}.App-link{color:#61dafb}@keyframes App-logo-spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.layout{display:flex;height:100vh;overflow:hidden;width:100vw}.sidebar{background:linear-gradient(180deg,#1f2937,#111827);box-sizing:border-box;color:#fff;display:flex;flex-direction:column;gap:12px;overflow-y:auto;padding:20px;width:220px}.title{font-size:18px;font-weight:600;margin:0 0 8px}.sidebar-header{align-items:center;display:flex;justify-content:space-between;width:100%}.hamburger-button{background:#0000;border:none;color:#fff;cursor:pointer;display:none;font-size:24px;line-height:1;padding:4px 8px}.hamburger-button:hover{opacity:.8}.hamburger-icon{display:inline-block}.menu{display:flex;flex-direction:column;gap:8px}.menu-button{background:#e5e7eb;border:none;border-radius:6px;color:#111827;cursor:pointer;font-size:14px;font-weight:600;min-height:36px;padding:8px 10px}.menu-button:hover{filter:brightness(.95)}.menu-button:active{filter:brightness(.9)}.status{color:#9ca3af;font-size:13px;margin-top:12px}.main{flex:1 1;position:relative}.canvas{display:block;height:100%;width:100%}@media (max-width:768px){.layout{flex-direction:column}.sidebar{gap:8px;height:auto;max-height:none;overflow-x:visible;overflow-y:visible;padding:12px;width:100%}.sidebar-header{align-items:center;flex-direction:row;justify-content:space-between;width:100%}.hamburger-button{display:block}.title{flex:1 1;font-size:16px;margin:0;text-align:left;width:auto}.menu{display:flex;flex-direction:column;gap:6px;max-height:500px;overflow-y:auto;transition:max-height .3s ease,opacity .3s ease;width:100%}.menu.menu-collapsed{max-height:0;opacity:0;overflow:hidden;pointer-events:none}.menu-button{flex:1 1;font-size:14px;min-height:44px;min-width:auto;padding:12px 16px;touch-action:manipulation;width:100%}.status{display:none}.main{flex:1 1;height:70vh}.move-list{max-height:100px;overflow-y:auto}.show-all-moves{background:#6b7280;border:none;border-radius:4px;color:#fff;cursor:pointer;font-size:12px;margin-top:4px;padding:6px;width:100%}.show-all-moves:active{background:#4b5563}}.move-list{background:#0000000d;border-radius:6px;max-height:200px;overflow-y:auto;padding:8px}.move-item{border-bottom:1px solid #ffffff1a;color:#d1d5db;font-size:12px;padding:4px}.move-item:last-child{border-bottom:none}.move-list.collapsed{max-height:100px}.move-list.expanded{max-height:none}