:root{--bg: #171a21;--panel: #1f2330;--panel-2: #272c3c;--border: #353b4f;--text: #e8eaf0;--muted: #8d93a5;--accent: #4a90d9;--good: #2ecc71;--warn: #e6b450;--bad: #e05555;font-family:Segoe UI,system-ui,-apple-system,sans-serif}*{box-sizing:border-box}body{margin:0;background:var(--bg);color:var(--text)}html,body{height:100%;overscroll-behavior:none;touch-action:manipulation}#root{width:100vw;height:100vh;height:100dvh}canvas{touch-action:none}button{font:inherit;font-size:13px;color:var(--text);background:var(--panel-2);border:1px solid var(--border);border-radius:6px;padding:6px 12px;cursor:pointer}button:hover{background:#313748}button:disabled{opacity:.4;cursor:not-allowed}button.primary{background:var(--accent);border-color:var(--accent);color:#fff}button.primary:hover{background:#5b9de0}button.danger:hover{background:#5b2c2c;border-color:var(--bad)}input{font:inherit;font-size:13px;color:var(--text);background:var(--panel-2);border:1px solid var(--border);border-radius:6px;padding:6px 10px}input[type=number]{width:56px}h1,h2,h3,h4{margin:.4em 0}.muted{color:var(--muted)}.small{font-size:12px}.brand{font-weight:800;letter-spacing:.18em}.brand.big{font-size:30px}.subtitle{color:var(--muted);margin-top:-4px}.spacer{flex:1}.btn-row{display:flex;gap:8px;align-items:center}kbd{background:#14161c;border:1px solid var(--border);border-radius:4px;padding:1px 5px;font-size:11px;margin-left:auto}.hud-top{position:fixed;top:0;left:0;right:0;display:flex;justify-content:space-between;align-items:center;padding:12px 16px;pointer-events:none}.hud-top button{pointer-events:auto}.hud-left{display:flex;align-items:baseline;gap:14px}.hud-right{display:flex;gap:8px}.level-name{color:var(--muted)}.falls{color:var(--warn);font-size:13px}.hud-hint{position:fixed;bottom:14px;left:0;right:0;text-align:center;color:var(--muted);font-size:13px;pointer-events:none;padding:0 12px}.tilt-enable{position:fixed;left:0;right:0;bottom:40px;display:flex;flex-direction:column;align-items:center;gap:8px;pointer-events:none}.tilt-enable button{pointer-events:auto}.big-tap{font-size:16px;padding:14px 22px;border-radius:10px}.tilt-err{color:var(--bad);font-size:12px;margin:0}.overlay{position:fixed;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;background:rgba(10,12,17,.55)}.overlay-panel{background:var(--panel);border:1px solid var(--border);border-radius:12px;padding:26px 34px;text-align:center;min-width:300px;box-shadow:0 12px 40px #00000080}.overlay-panel h2{margin-top:0}.overlay-panel .btn-row{justify-content:center;margin-top:14px}.panel-screen{position:fixed;top:0;right:0;bottom:0;left:0;overflow-y:auto;display:flex;justify-content:center;background:rgba(10,12,17,.72)}.panel{width:min(680px,94vw);margin:6vh 0;background:var(--panel);border:1px solid var(--border);border-radius:14px;padding:28px 32px;height:fit-content}.level-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:10px}.level-card{display:flex;flex-direction:column;gap:4px;align-items:flex-start;padding:12px 14px;text-align:left}.level-card-name{font-weight:600}.level-card-meta{color:var(--muted);font-size:12px}.saved-list{display:flex;flex-direction:column;gap:6px}.saved-row{display:flex;justify-content:space-between;align-items:center;background:var(--panel-2);border:1px solid var(--border);border-radius:8px;padding:8px 12px}.saved-row.small{padding:5px 8px;font-size:12px}.saved-name{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.editor-screen{position:fixed;top:0;right:0;bottom:0;left:0;display:flex;flex-direction:column;background:var(--bg)}.editor-header{display:flex;align-items:center;gap:10px;padding:10px 16px;background:var(--panel);border-bottom:1px solid var(--border);flex-wrap:wrap}.editor-header label{display:flex;align-items:center;gap:6px;color:var(--muted);font-size:13px}.name-input{width:180px}.editor-body{flex:1;display:flex;min-height:0}.editor-side{width:230px;padding:14px;background:var(--panel);border-right:1px solid var(--border);overflow-y:auto}.tool-btn{display:flex;align-items:center;gap:8px;width:100%;margin-bottom:6px;text-align:left}.tool-btn.active{border-color:var(--accent);background:#2a3550}.swatch{width:14px;height:14px;border-radius:3px;border:1px solid rgba(255,255,255,.25)}.editor-main{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:18px;min-width:0;min-height:0}.editor-board-fit{flex:1;width:100%;display:flex;align-items:center;justify-content:center;min-height:0}.editor-grid{display:grid;gap:0;background:#b98f57;border:6px solid #6e5232;border-radius:4px;max-width:100%;max-height:100%;-webkit-user-select:none;user-select:none;touch-action:none}.cell{position:relative;background:#b98f57;display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:700;color:#fff;cursor:pointer;min-width:0;min-height:0;box-shadow:inset 0 0 0 .5px #6e523240}.cell-hole{background:radial-gradient(circle at 50% 45%,#000 0 38%,#14161c 40%,#b98f57 60%)}.cell-start{color:#fff;background:#4a90d9}.cell-goal{color:#fff;background:#2ecc71}.wall-seg{position:absolute;background:#7a5a36;border-radius:1px;pointer-events:none;z-index:2}.wall-n,.wall-s{left:-1px;right:-1px;height:16%;min-height:4px}.wall-e,.wall-w{top:-1px;bottom:-1px;width:16%;min-width:4px}.wall-n{top:0;transform:translateY(-50%)}.wall-s{bottom:0;transform:translateY(50%)}.wall-w{left:0;transform:translate(-50%)}.wall-e{right:0;transform:translate(50%)}.editor-grid.wall-mode .cell{cursor:crosshair}.edge-zone{position:absolute;z-index:3;touch-action:none}.edge-zone:hover{background:rgba(255,255,255,.35)}.ez-n,.ez-s{left:14%;right:14%;height:30%}.ez-e,.ez-w{top:14%;bottom:14%;width:30%}@media (pointer: coarse){.ez-n,.ez-s{left:8%;right:8%;height:38%}.ez-e,.ez-w{top:8%;bottom:8%;width:38%}.edge-zone{background:rgba(255,255,255,.06)}}.ez-n{top:0}.ez-s{bottom:0}.ez-w{left:0}.ez-e{right:0}.editor-status{margin-top:12px;font-size:13px;min-height:18px}.editor-status.good{color:var(--good)}.editor-status.warn{color:var(--warn)}.editor-status.bad{color:var(--bad)}@media (max-width: 720px){.hud-top{padding:8px 10px;gap:8px}.hud-left{gap:8px;flex-wrap:wrap}.brand{letter-spacing:.1em;font-size:13px}.brand.big{font-size:24px}.hud-right button,.hud-left .level-name{font-size:12px}.hud-right button{padding:8px 10px}.hud-hint{font-size:12px;bottom:10px}.panel{width:100%;min-height:100%;margin:0;border-radius:0;padding:20px 16px}.panel-screen{background:rgba(10,12,17,.92)}.level-grid{grid-template-columns:1fr 1fr}.saved-row{flex-direction:column;align-items:stretch;gap:6px}.overlay-panel{min-width:0;width:min(92vw,360px);padding:22px 20px}.overlay-panel button{padding:12px 16px}.editor-body{flex-direction:column}.editor-side{width:100%;border-right:none;border-bottom:1px solid var(--border);display:grid;grid-template-columns:repeat(5,1fr);gap:6px;align-items:start;max-height:38vh}.editor-side h4,.editor-side>p,.editor-side .saved-list{grid-column:1 / -1}.tool-btn{margin-bottom:0;padding:10px 6px}.editor-header{gap:6px;padding:8px 10px}.editor-header .brand{width:100%}.name-input{width:100%;flex:1 1 120px}.editor-header button{padding:8px 10px}.editor-main{padding:10px}}
