:root{font-family:Aptos,Segoe UI,sans-serif;color:#211d18;background:#fff;color-scheme:light;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;--ink: #211d18;--muted: #6f6f6f;--paper: #ffffff;--line: rgba(0, 0, 0, .16);--clay: #111111;--sage: #333333;--sand: #f1f1f1;--black: #050505;--panel: #101010;--panel-soft: #181818;--panel-line: rgba(255, 255, 255, .16);--panel-muted: #b7b7b7}*{box-sizing:border-box}html,body,#root{min-height:100%;margin:0}body{min-height:100vh;overflow:hidden;color:var(--ink);background:#fff}button,input{font:inherit}button{border:1px solid var(--line);border-radius:8px;background:#fff;color:var(--ink);cursor:pointer}button:disabled{opacity:.5;cursor:not-allowed}input{width:100%;border:1px solid var(--line);border-radius:8px;background:#fff;color:var(--ink);padding:.62rem .7rem}input[type=range]{padding:0;border:0;background:transparent;touch-action:auto}.physics-stage{position:relative;width:100vw;height:100vh;overflow:hidden;background-color:#fff;background-image:radial-gradient(circle,rgba(0,0,0,.16) 1px,transparent 1.2px);background-position:var(--grid-x, 0) var(--grid-y, 0);background-size:var(--grid-size, 34px) var(--grid-size, 34px)}.exercise-menu-screen{min-height:100vh;display:grid;place-items:center;padding:28px;background-color:#fff;background-image:radial-gradient(circle,rgba(0,0,0,.14) 1px,transparent 1.2px);background-size:34px 34px}.exercise-menu-shell{width:min(980px,100%);display:grid;gap:1.35rem}.exercise-menu-header{display:grid;gap:.35rem}.exercise-menu-header span{color:var(--muted);font-size:.9rem;font-weight:800}.exercise-menu-header h1{margin:0;font-family:Georgia,Times New Roman,serif;font-size:clamp(2.15rem,6vw,4.8rem);font-weight:800;letter-spacing:0;line-height:.95}.exercise-menu-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:.8rem}.physics-box{position:absolute;overflow:visible;border:0;border-radius:0;background:transparent;box-shadow:none;transform-origin:top left;touch-action:none}.viewport-status{position:fixed;left:10px;top:10px;z-index:3;display:inline-flex;align-items:center;gap:.65rem;min-height:34px;padding:0 .75rem;border:1px solid rgba(33,29,24,.14);border-radius:999px;background:#fffffff0;cursor:default;pointer-events:none;-webkit-user-select:none;user-select:none}.viewport-status strong{font-family:Georgia,Times New Roman,serif;font-size:1.05rem}.viewport-status span{color:var(--muted);font-size:.82rem}.time-toggle{position:fixed;top:10px;right:10px;z-index:8;display:grid;place-items:center;width:44px;height:44px;padding:0;border-color:var(--black);border-radius:50%;background:var(--black);color:#fff;font-size:1.05rem;font-weight:800;line-height:1;box-shadow:0 12px 28px #0000002e}.time-toggle:hover{transform:translateY(-1px)}.menu-return{position:fixed;right:74px;bottom:18px;z-index:9;min-height:46px;padding:0 1rem;border-color:var(--black);border-radius:999px;background:#fff;color:var(--black);font-weight:800;letter-spacing:0;box-shadow:0 12px 28px #00000029;transition:transform .15s ease,background .15s ease,color .15s ease}.menu-return:hover{background:var(--black);color:#fff;transform:translateY(-1px)}.ball{position:absolute;z-index:2;display:grid;place-items:center;overflow:hidden;padding:0;border:2px solid rgba(33,29,24,.14);border-radius:50%;box-shadow:0 6px 16px #40302424;touch-action:none;-webkit-user-select:none;user-select:none}.ball:active{cursor:grabbing;border-color:var(--clay);box-shadow:0 8px 20px #c15f3c33}.ball img{width:100%;height:100%;object-fit:cover;pointer-events:none}.ball-valued{border-color:#05050594;box-shadow:0 8px 22px #0000003d}.ball-merge-source{outline:4px solid rgba(255,255,255,.95);outline-offset:3px;box-shadow:0 0 0 7px #05050566,0 10px 26px #00000047}.ball-value{position:absolute;inset:50% auto auto 50%;transform:translate(-50%,-50%);display:grid;place-items:center;min-width:0;min-height:0;padding:0;border-radius:0;background:transparent;color:#fff;font-weight:800;font-size:clamp(.8rem,42%,1.45rem);line-height:1;pointer-events:none;text-shadow:0 2px 5px rgba(0,0,0,.72)}.empty-state{position:absolute;inset:50% auto auto 50%;transform:translate(-50%,-50%);display:grid;gap:.25rem;text-align:center;color:var(--muted)}.empty-state strong{color:var(--ink);font-family:Georgia,Times New Roman,serif;font-size:1.5rem}.config-dock{position:fixed;right:18px;bottom:18px;z-index:10;display:grid;justify-items:end;gap:.6rem}.dock-toggle{width:46px;height:46px;min-width:46px;min-height:46px;padding:0;border-radius:50%;border-color:var(--black);background:var(--black);color:#fff;font-size:1.4rem;line-height:1;box-shadow:0 12px 28px #0000002e}.dock-panel{width:min(360px,calc(100vw - 36px));max-height:min(720px,calc(100vh - 84px));overflow:auto;display:grid;gap:.8rem;padding:.9rem;border:1px solid var(--panel-line);border-radius:14px;background:var(--panel);color:#fff;box-shadow:0 18px 46px #0000003d}.dock-header{display:flex;justify-content:space-between;align-items:center;gap:1rem}.dock-header strong{font-family:Georgia,Times New Roman,serif;font-size:1.15rem}.dock-header span,.field span{color:var(--panel-muted);font-size:.78rem}.dock-panel input{border-color:#ffffff2e;background:#050505;color:#fff}.dock-panel input:focus{outline:2px solid #ffffff;outline-offset:2px}.dock-panel input[type=range]{accent-color:#ffffff}.exercise-list{display:grid;gap:.55rem}.exercise-card{display:grid;grid-template-columns:42px minmax(0,1fr);align-items:center;gap:.7rem;min-height:64px;padding:.65rem;border-color:#fff3;background:#fff;color:#050505;text-align:left;transition:transform .15s ease,border-color .15s ease,background .15s ease}.exercise-card:hover{border-color:#fff;background:#f1f1f1;transform:translateY(-1px)}.exercise-card-alt{background:#050505;color:#fff}.exercise-card-alt:hover{background:#181818}.exercise-card-alt .exercise-number{background:#fff;color:#050505}.exercise-card-alt .exercise-copy span{color:#c7c7c7}.exercise-number{display:grid;place-items:center;width:42px;height:42px;border-radius:50%;background:#050505;color:#fff;font-weight:900;line-height:1}.exercise-copy{display:grid;gap:.18rem;min-width:0}.exercise-copy strong{overflow:hidden;font-size:.95rem;line-height:1.15;white-space:nowrap;text-overflow:ellipsis}.exercise-copy span{color:#5d5d5d;font-size:.78rem}.menu-section-label{margin-top:.25rem;padding-top:.75rem;border-top:1px solid var(--panel-line);color:var(--panel-muted);font-size:.78rem;font-weight:700}.menu-screen-button{min-height:42px;border-color:#fff;background:#fff;color:#050505;font-weight:800;transition:background .15s ease,color .15s ease,transform .15s ease}.menu-screen-button:hover{background:#050505;color:#fff;transform:translateY(-1px)}.new-exercise-screen{min-height:100vh;display:grid;place-items:center;padding:28px;background:linear-gradient(90deg,rgba(0,0,0,.08) 1px,transparent 1px),linear-gradient(rgba(0,0,0,.08) 1px,transparent 1px),#f7f7f7;background-size:48px 48px}.new-exercise-back{position:fixed;left:18px;top:18px;min-height:42px;padding:0 1rem;border-color:var(--black);border-radius:999px;background:#fff;color:var(--black);font-weight:800}.new-exercise-shell{width:min(820px,100%);display:grid;gap:.75rem}.new-exercise-shell span{color:var(--muted);font-size:.9rem;font-weight:900}.new-exercise-shell h1{margin:0;font-family:Georgia,Times New Roman,serif;font-size:clamp(2.5rem,8vw,6rem);line-height:.9;letter-spacing:0}.new-exercise-shell p{max-width:520px;margin:0;color:#4f4f4f;font-size:1.05rem;line-height:1.45}.addition-shell{width:min(1120px,100%);display:grid;gap:1.2rem}.addition-header{display:grid;gap:.28rem}.addition-header span{color:var(--muted);font-size:.9rem;font-weight:900}.addition-header h1{margin:0;font-family:Georgia,Times New Roman,serif;font-size:clamp(2.3rem,7vw,5.6rem);line-height:.92;letter-spacing:0}.operation-switcher{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:.45rem}.operation-switcher button{min-height:44px;padding:0 .7rem;border:2px solid #050505;background:#fff;color:#050505;font-weight:900;transition:background .15s ease,color .15s ease,transform .15s ease}.operation-switcher button:hover{transform:translateY(-1px)}.operation-switcher button.active{background:#050505;color:#fff}.addition-layout{display:grid;grid-template-columns:minmax(0,1fr) minmax(260px,320px);align-items:start;gap:1rem}.addition-board{display:grid;gap:.34rem;width:max-content;max-width:100%;overflow-x:auto;padding:1rem;border:2px solid #050505;border-radius:8px;background:#fff;box-shadow:0 18px 38px #0000001f}.addition-row{display:grid;grid-template-columns:32px 28px repeat(var(--addition-columns),52px);gap:.28rem;align-items:center}.addition-row-action{display:grid;place-items:center;width:32px;height:32px;padding:0;border-radius:50%;background:#fff;color:#050505;font-size:.85rem;font-weight:900}.addition-row-action:disabled{opacity:0}.addition-sign{display:grid;place-items:center;min-height:52px;color:#050505;font-size:1.75rem;font-weight:900}.addition-cell{width:52px;height:52px;padding:0;border:2px solid #050505;border-radius:6px;background:#fff;color:#050505;text-align:center;font-size:1.55rem;font-weight:900;line-height:1}.addition-cell:focus{outline:3px solid rgba(5,5,5,.18);outline-offset:2px}.addition-carry-row{opacity:.88}.addition-carry-cell{height:34px;border-style:dashed;font-size:1rem}.addition-divider{height:4px;margin-left:60px;background:#050505;border-radius:999px}.addition-answer-cell{background:#050505;color:#fff}.multiplication-board{gap:.28rem}.multiplication-partial-row{opacity:.95}.addition-partial-cell{background:#f4f4f4}.addition-final-divider{margin-top:.18rem}.division-board{width:max-content;max-width:100%;overflow-x:auto;display:grid;gap:.34rem;padding:1rem;border:2px solid #050505;border-radius:8px;background:#fff;box-shadow:0 18px 38px #0000001f}.division-answer-row{display:grid;grid-template-columns:86px repeat(var(--addition-columns),52px);gap:.28rem;align-items:center}.division-spacer{min-height:52px}.division-house-row{display:grid;grid-template-columns:86px minmax(0,1fr);gap:0;align-items:start}.division-divisor{width:74px;height:52px;padding:0;border:2px solid #050505;border-radius:6px;background:#fff;color:#050505;text-align:center;font-size:1.35rem;font-weight:900}.division-house{display:grid;grid-template-columns:repeat(var(--addition-columns),52px);gap:.28rem;padding-top:.42rem;padding-left:.45rem;border-top:4px solid #050505;border-left:4px solid #050505;border-top-left-radius:8px}.division-work{display:grid;gap:.62rem;margin-left:86px}.division-work-step{display:grid;gap:.24rem;width:max-content;padding-bottom:.36rem;border-bottom:2px dashed rgba(5,5,5,.55)}.division-work-row{display:grid;grid-template-columns:28px repeat(var(--division-work-cells),52px);gap:.28rem;width:max-content;align-items:center}.division-work-sign{display:grid;place-items:center;min-height:52px;color:#050505;font-size:1.55rem;font-weight:900}.division-work-subtract-row .division-work-cell{background:#fff}.division-work-cell{background:#f4f4f4}.addition-tools{display:grid;gap:.8rem;padding:1rem;border:2px solid #050505;border-radius:8px;background:#050505;color:#fff;box-shadow:0 18px 38px #0000001f}.addition-field{display:grid;gap:.45rem}.addition-field span{color:#cfcfcf;font-size:.78rem;font-weight:800}.addition-field input{border-color:#ffffff38;background:#111;color:#fff}.addition-actions{display:grid;grid-template-columns:1fr 1fr;gap:.55rem}.addition-actions button{min-height:42px;border-color:#fff;background:#fff;color:#050505;font-weight:800}.addition-actions button:disabled{border-color:#fff3;background:#202020;color:#777}.addition-actions button.ghost{border-color:#ffffff47;background:#181818;color:#fff}.addition-feedback{min-height:52px;display:grid;place-items:center;padding:.75rem;border:1px solid rgba(255,255,255,.18);border-radius:8px;background:#181818;color:#fff;text-align:center;font-weight:900}.addition-feedback.good{background:#fff;color:#050505}.upload-button{display:grid;place-items:center;min-height:42px;border:1px solid #ffffff;border-radius:8px;background:#050505;color:#fff;cursor:pointer;transition:background .15s ease,color .15s ease,transform .15s ease}.upload-button:hover{background:#fff;color:#050505;transform:translateY(-1px)}.upload-button input{display:none}.field{display:grid;gap:.34rem}.two-up{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:.6rem}.action-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:.55rem}.action-grid button{min-height:40px;padding:0 .7rem;border-color:#fff;background:#050505;color:#fff;transition:background .15s ease,color .15s ease,transform .15s ease}.action-grid button:hover{background:#fff;color:#050505;transform:translateY(-1px)}.action-grid button.ghost{border-color:#ffffff47;background:var(--panel-soft);color:#fff}.asset-list{display:grid;gap:.45rem}.asset-mini{display:grid;grid-template-columns:36px minmax(0,1fr);align-items:center;gap:.55rem;min-height:46px;padding:.3rem;text-align:left;border-color:#ffffff29;background:var(--panel-soft);color:#fff}.asset-mini img{width:36px;height:36px;object-fit:cover;border-radius:50%}.asset-mini span{overflow:hidden;white-space:nowrap;text-overflow:ellipsis}@media (max-width: 760px){.physics-box{max-width:calc(100vw - 24px)}.viewport-status span{display:none}.two-up,.action-grid{grid-template-columns:1fr}.menu-return{right:72px;max-width:calc(100vw - 144px);padding:0 .85rem;overflow:hidden;white-space:nowrap;text-overflow:ellipsis}.addition-layout{grid-template-columns:1fr}.operation-switcher{grid-template-columns:repeat(2,minmax(0,1fr))}.addition-board{width:100%}.addition-row{grid-template-columns:30px 24px repeat(var(--addition-columns),44px)}.addition-cell{width:44px;height:44px;font-size:1.25rem}.division-answer-row{grid-template-columns:72px repeat(var(--addition-columns),44px)}.division-house-row{grid-template-columns:72px minmax(0,1fr)}.division-divisor{width:62px;height:44px}.division-house{grid-template-columns:repeat(var(--addition-columns),44px)}.division-work{margin-left:72px}.division-work-row{grid-template-columns:24px repeat(var(--division-work-cells),44px)}.division-work-sign{min-height:44px}}
