:root{color-scheme:light;--bg: #ecc8d2;--surface: #f7f3ea;--text: #221f1f;--muted: #6e5560;--border: #221f1f;--accent: #d9476b;--accent-soft: #f6dee5;--ink: #221f1f;--festival-yellow: #f2c93b;--shadow: 5px 6px 0 rgba(34, 31, 31, .85);--shadow-soft: 3px 4px 0 rgba(34, 31, 31, .7);font-family:Zen Kaku Gothic New,system-ui,sans-serif;line-height:1.55;font-weight:400;color:var(--text);background:var(--bg);font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased}body:before{content:"";position:fixed;top:0;right:0;bottom:0;left:0;background-image:radial-gradient(rgba(34,31,31,.055) 1px,transparent 1.4px);background-size:7px 9px;pointer-events:none;z-index:0}h1,h2,h3{font-weight:900}*{box-sizing:border-box}body{margin:0;min-width:320px}a{color:inherit}button,.button{font:inherit;cursor:pointer}#root{min-height:100vh}.app-shell{min-height:100vh;display:flex;flex-direction:column}.app-columns{flex:1;display:grid;grid-template-columns:minmax(0,clamp(380px,34vw,540px)) minmax(0,1fr);align-items:stretch;gap:.75rem clamp(1.25rem,2.5vw,2.5rem);width:100%;max-width:none;margin:0;padding:0 clamp(1rem,2.5vw,2rem);min-height:0}.cube-rail{align-self:stretch;display:flex;flex-direction:column;align-items:stretch;padding:1.15rem 0 1.5rem;background:transparent}.cube-rail__sticky{position:sticky;top:3.6rem;z-index:3;display:flex;flex-direction:column;align-items:stretch;max-height:calc(100dvh - 4.3rem);overflow-y:auto;overscroll-behavior:contain;scrollbar-gutter:stable}.cube-stage{position:relative;flex:0 0 auto;display:flex;width:100%;aspect-ratio:1;min-height:240px;max-height:min(52vh,460px);padding:.5rem;box-sizing:border-box;background:var(--bg);border-radius:4px;border:2px solid var(--ink);box-shadow:8px 9px #221f1fd9;overflow:hidden}.cube-rail .cube-canvas{flex:1;width:100%;height:100%;min-height:0;border-radius:2px;overflow:hidden;background:var(--bg);touch-action:none}.cube-keyboard-hint{position:absolute;left:.65rem;top:.65rem;z-index:1;margin:0;display:flex;flex-direction:column;gap:.25rem;padding:.45rem .55rem;border-radius:.65rem;border:1px solid var(--border);background:#ffffffeb;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);box-shadow:0 6px 18px #1c1b1914;pointer-events:none;-webkit-user-select:none;user-select:none}.cube-keyboard-hint__label{font-size:.68rem;font-weight:600;letter-spacing:.04em;text-transform:uppercase;color:var(--muted)}.cube-keyboard-hint__keys{display:flex;flex-wrap:wrap;align-items:center;gap:.3rem;font-size:.78rem;color:var(--text)}.cube-keyboard-hint__or{font-size:.72rem;color:var(--muted);margin:0 .1rem}.cube-keyboard-hint kbd{display:inline-flex;align-items:center;justify-content:center;min-width:1.55rem;padding:.15rem .4rem;border-radius:.35rem;border:1px solid #c8c2b8;border-bottom-width:2px;background:#f7f5f1;font-family:IBM Plex Mono,ui-monospace,monospace;font-size:.72rem;font-weight:600;line-height:1.3;color:var(--text)}.cube-rail .cube-canvas canvas{cursor:default;touch-action:none}.cube-rail .cube-controls{margin-top:1.1rem;padding:.7rem .75rem;border:2px solid var(--ink);border-radius:4px;background:var(--surface);box-shadow:var(--shadow)}.cube-rail .cube-controls .scramble-row{margin-bottom:.4rem}.cube-rail .cube-controls .control-row{gap:.35rem}.cube-rail .cube-controls .control-row button,.cube-rail .cube-controls .face-buttons button{padding:.32rem .5rem;font-size:.8rem;box-shadow:2px 2px 0 var(--ink)}.cube-rail .cube-controls .control-row button:hover:not(:disabled),.cube-rail .cube-controls .face-buttons button:hover:not(:disabled){box-shadow:3px 3px 0 var(--ink)}.cube-rail .cube-controls .control-row button:active:not(:disabled),.cube-rail .cube-controls .face-buttons button:active:not(:disabled){box-shadow:1px 1px 0 var(--ink)}.cube-rail .cube-controls .face-grid{margin-top:.2rem}.cube-rail .cube-controls .control-label{margin:.55rem 0 .35rem;font-size:.72rem}.cube-rail .cube-controls .face-buttons{gap:.35rem}.cube-rail .cube-controls .face-group{gap:.25rem}.cube-hint{margin:.65rem 0 0;text-align:center;font-size:.82rem;color:var(--muted)}.piece-panel{margin-top:.9rem;padding:.85rem 1rem;border-radius:4px;border:2px solid var(--ink);background:var(--surface);box-shadow:var(--shadow-soft)}.piece-panel__header{display:flex;align-items:center;justify-content:space-between;gap:.5rem}.piece-panel__title{margin:0;font-size:.72rem;font-weight:600;letter-spacing:.04em;text-transform:uppercase;color:var(--muted)}.piece-panel__clear{border:none;background:transparent;color:var(--muted);font-size:1.1rem;line-height:1;padding:.15rem .35rem;border-radius:.35rem}.piece-panel__clear:hover{background:var(--accent-soft);color:var(--accent)}.piece-panel__name{margin:.35rem 0 0;font-size:.95rem;font-weight:600;color:var(--text)}.piece-panel__hint{margin:.35rem 0 .55rem;font-size:.78rem;color:var(--muted)}.piece-panel__moves{display:flex;flex-wrap:wrap;gap:.45rem}.solution-panel{margin-top:.9rem;padding:.85rem 1rem;border-radius:4px;border:2px solid var(--ink);background:var(--surface);box-shadow:var(--shadow-soft)}.solution-panel__header{display:flex;align-items:center;justify-content:space-between;gap:.5rem}.solution-panel__title{margin:0;font-size:.72rem;font-weight:600;letter-spacing:.04em;text-transform:uppercase;color:var(--muted)}.solution-panel__toggle{border:1px solid var(--border);background:var(--surface);color:var(--text);font:inherit;font-size:.74rem;padding:.25rem .6rem;border-radius:999px;transition:border-color .12s,background .12s}.solution-panel__toggle:hover{border-color:var(--accent);background:var(--accent-soft)}.solution-panel__status{margin:.4rem 0 0;font-size:.92rem;color:var(--text)}.solution-panel__status strong{font-size:1.15rem}.solution-panel__status--solved{font-weight:600;color:#1c7c45}.solution-panel__stages{margin-top:.7rem;display:flex;flex-direction:column;gap:.55rem;max-height:13rem;overflow-y:auto}.solution-stage{border-top:1px solid var(--border);padding-top:.5rem}.solution-stage__row{display:flex;align-items:center;gap:.5rem}.solution-stage__label{font-size:.84rem;font-weight:600;color:var(--text);text-decoration:none}.solution-stage__label:hover{color:var(--accent);text-decoration:underline}.solution-stage__count{margin-left:auto;font-size:.74rem;color:var(--muted)}.solution-stage__play,.solution-panel__play-all{border:1px solid var(--border);background:var(--surface);color:var(--text);font:inherit;font-size:.74rem;padding:.2rem .55rem;border-radius:999px;transition:border-color .12s,background .12s}.solution-stage__play:hover:not(:disabled),.solution-panel__play-all:hover:not(:disabled){border-color:var(--accent);background:var(--accent-soft)}.solution-stage__play:disabled,.solution-panel__play-all:disabled{opacity:.55;cursor:not-allowed}.solution-stage__moves{display:block;margin-top:.3rem;font-family:IBM Plex Mono,ui-monospace,monospace;font-size:.74rem;line-height:1.5;color:var(--muted);word-spacing:.2em}.solution-panel__footer{border-top:1px solid var(--border);padding-top:.55rem}.solution-panel__note{margin:.45rem 0 0;font-size:.72rem;color:var(--muted)}.move-chip{display:inline-flex;align-items:center;gap:.4rem;padding:.35rem .6rem;border-radius:999px;border:1px solid var(--border);background:var(--surface);font:inherit;font-size:.78rem;color:var(--text);transition:border-color .12s,background .12s}.move-chip:hover:not(:disabled),.move-chip.active{border-color:var(--accent);background:var(--accent-soft)}.move-chip:disabled{opacity:.55;cursor:not-allowed}.move-chip__swatch{width:.75rem;height:.75rem;border-radius:2px;border:1px solid rgba(0,0,0,.12);flex-shrink:0}.move-chip__face{font-family:IBM Plex Mono,ui-monospace,monospace;font-weight:700}.move-chip__drag{font-size:.68rem;color:var(--muted)}.content-rail{min-width:0;padding:1.15rem 0 2.5rem}.page-content{min-width:0}.single-page{display:flex;flex-direction:column;gap:2.5rem}.sections{display:flex;flex-direction:column;gap:2rem}.lesson-section{padding:.5rem .75rem .25rem;border-top:2px solid var(--border);border-radius:4px;transition:background .25s,border-color .25s;scroll-margin-top:4.2rem}.lesson-section--active{background:#f6dee573;border-top-color:var(--accent)}.lesson-section--active .eyebrow{border-color:var(--accent);color:var(--accent);background:var(--festival-yellow)}.section-header h2{margin:0 0 .5rem;font-size:clamp(1.4rem,2.5vw,1.85rem);letter-spacing:-.02em}.section-header .lesson-algorithm{display:inline-block;margin-top:.75rem}.step-list{margin:1rem 0 0;padding:0;list-style:none;display:flex;flex-direction:column;gap:1rem}.step-item{background:var(--surface);border:2px solid var(--ink);border-radius:3px;padding:1rem 1.1rem;box-shadow:var(--shadow-soft);transition:border-color .2s,box-shadow .2s,background .2s}.step-item--active{border-color:var(--accent);border-left-width:4px;background:var(--festival-yellow);box-shadow:var(--shadow)}.step-item p{margin:0}.step-math{margin:.65rem 0 0}.step-math code{display:block;padding:.55rem .75rem;border-radius:.5rem;background:#f4f6f8;border:1px solid var(--border);font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,monospace;font-size:.88rem;color:#2c3e50;white-space:pre-wrap}.step-item .lesson-moves{margin-top:.75rem;margin-bottom:0}.site-footer{margin-top:2rem;padding:1.5rem 0 2rem;border-top:1px solid var(--border);text-align:center;font:.8125rem/1.5 ui-monospace,SFMono-Regular,Menlo,monospace;color:var(--muted)}.site-footer p{margin:0}.site-footer a{color:var(--accent);text-decoration:none}.site-footer a:hover{text-decoration:underline}.eyebrow{display:inline-block;margin:0 0 .6rem;padding:.28rem .15rem;text-transform:uppercase;letter-spacing:.3em;font-size:.72rem;font-weight:700;color:var(--ink);border-top:2px solid var(--ink);border-bottom:2px solid var(--ink)}.page-header{max-width:42rem;margin-bottom:1.5rem}.page-header h1,.hero-copy h1{margin:0 0 .75rem;font-size:clamp(2rem,4vw,3rem);line-height:1.05;letter-spacing:-.03em}.page-header p,.hero-copy .lede{margin:0;color:var(--muted);font-size:1.05rem}.page-header.compact h1{font-size:clamp(1.7rem,3vw,2.4rem)}.goal{font-weight:500;color:var(--text)!important}.hero-copy{max-width:none}.hero-points{margin-top:1.25rem;margin:0;padding-left:1.1rem;color:var(--muted)}.hero-points li+li{margin-top:.35rem}.cube-canvas{width:100%}.cube-controls{padding:1rem;border-top:1px solid var(--border);background:#faf9f6}.cube-controls.compact{padding:.75rem 1rem}.control-row{display:flex;flex-wrap:wrap;gap:.5rem}.scramble-row{margin-bottom:.6rem}.scramble-row__label{display:block;margin:0 0 .4rem;font-size:.72rem;font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:.08em}.scramble-row .control-row button{flex:1}.control-row .stop-button{background:var(--accent);color:var(--surface);font-weight:700}.practice-setup{display:flex;align-items:baseline;flex-wrap:wrap;gap:.6rem;margin-top:.75rem}.practice-setup__hint{font-size:.82rem;color:var(--muted);flex:1;min-width:14rem}.control-row button,.lesson-nav button,.lesson-moves .ghost,.face-buttons button{border:2px solid var(--ink);background:var(--surface);border-radius:3px;padding:.5rem .85rem;font-weight:700;box-shadow:3px 3px 0 var(--ink);transition:transform .1s ease-out,box-shadow .1s ease-out}.control-row button:hover:not(:disabled),.lesson-nav button:hover:not(:disabled),.lesson-moves .ghost:hover:not(:disabled),.face-buttons button:hover:not(:disabled){transform:translate(-1px,-1px);box-shadow:4px 4px 0 var(--ink)}.control-row button:active:not(:disabled),.face-buttons button:active:not(:disabled){transform:translate(2px,2px);box-shadow:1px 1px 0 var(--ink)}.scramble-row .control-row button{background:var(--festival-yellow)}.control-row button:disabled,.lesson-nav button:disabled,.face-buttons button:disabled{opacity:.45;cursor:not-allowed}.control-label{margin:.85rem 0 .5rem;font-size:.85rem;font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:.08em}.face-grid{margin-top:.35rem}.face-buttons{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:.5rem}.face-group{display:grid;grid-template-columns:1fr 1fr;gap:.35rem}.lesson-algorithm,.lesson-moves code{font-family:IBM Plex Mono,ui-monospace,SFMono-Regular,Menlo,monospace;background:var(--ink);color:var(--festival-yellow);border-radius:3px;padding:.35rem .6rem;font-size:.86rem;letter-spacing:.04em}.lesson-moves{display:flex;flex-wrap:wrap;gap:.6rem;align-items:center;margin-bottom:.85rem}.lesson-moves .label{font-size:.8rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--muted)}.lesson-tip{margin:.75rem 0 0;padding:.7rem .9rem;border-radius:3px;border:2px solid var(--ink);background:var(--festival-yellow);color:var(--ink);box-shadow:3px 3px 0 var(--ink);font-size:.92rem}@media(max-width:900px){.app-columns{grid-template-columns:1fr;grid-template-rows:auto 1fr;gap:0;max-width:none;padding:0}.cube-rail{align-self:start;padding:.85rem 1rem .35rem}.cube-rail__sticky{position:relative;top:auto;z-index:auto;max-height:none;overflow:visible}.cube-stage{max-height:min(52vw,300px);min-height:200px;margin:0 auto;max-width:300px}.cube-rail .cube-canvas{min-height:200px}.cube-keyboard-hint{display:none}.content-rail{padding:.75rem 1.15rem 2.25rem}.cube-hint{font-size:.78rem;padding:0 .25rem}}@media(pointer:coarse){.cube-keyboard-hint{display:none}}.masthead{--collapse: 0;--masthead-bar: 3.2rem;position:sticky;top:calc(-1 * (var(--masthead-h, 18rem) - var(--masthead-bar)));z-index:20;flex-shrink:0;height:var(--masthead-h, auto);border-bottom:2px solid var(--ink);background:var(--bg)}.masthead__sizer{visibility:hidden;padding:.8rem clamp(1rem,2.5vw,2rem) 1.5rem}.masthead__sizer>svg{display:block;width:min(100%,74rem);margin:0 auto}.masthead__title-wrap{position:absolute;left:50%;transform:translate(-50%);bottom:calc(1.5rem - 1.05rem * var(--collapse));width:min(calc(100% - (2*clamp(1rem,2.5vw,2rem))),calc(74rem - 54rem * var(--collapse)))}.masthead__title{display:block;width:100%}.masthead__credit{position:absolute;left:clamp(1rem,2.5vw,2rem);bottom:.55rem;display:block;width:auto;max-width:11rem;text-decoration:none;color:inherit;transition:opacity .15s ease;opacity:calc(1 - var(--collapse) * 1.8)}.masthead__credit:hover{opacity:.88}.masthead__credit:focus-visible{outline:2px solid var(--accent);outline-offset:4px}@media(max-width:900px){.masthead__sizer{padding:.75rem 1rem 1.4rem}.masthead__credit{max-width:9rem}}@media(max-width:520px){.masthead__sizer{padding:.65rem .75rem 1.3rem}.masthead__credit{left:.75rem;bottom:.4rem;max-width:7.5rem}.cube-stage{max-height:min(72vw,300px);max-width:100%}.section-header h2{font-size:1.25rem}}@media(prefers-reduced-motion:reduce){*{scroll-behavior:auto!important}}
