:root{--border-color: #d1d5db;--practice-alg-track-max: 1125px;--bg: #f3f4f6;--surface: #ffffff;--raised: #f9fafb;--border: #9ca3af;--border-l: #d1d5db;--accent: #3b82f6;--accent-h: #1d4ed8;--ok: #22c55e;--warn: #f59e0b;--danger: #ef4444;--fg: #111827;--fg2: #374151;--fg3: #6b7280;--fg4: #9ca3af;--mono: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, monospace;--sidebar-w: 64px;--tab-h: 60px;--radius: 12px;--radius-sm: 8px;--radius-pill: 9999px;--shadow-sm: 0 1px 2px rgb(0 0 0 / .06), 0 1px 3px rgb(0 0 0 / .06);--shadow-md: 0 4px 6px -1px rgb(0 0 0 / .1), 0 2px 4px -2px rgb(0 0 0 / .1);--accent-tint: rgba(59, 130, 246, .12)}html.dark{--border-color: #2d3748;--bg: #111827;--surface: #1f2937;--raised: #374151;--border: #374151;--border-l: #4b5563;--fg: #ffffff;--fg2: #e5e7eb;--fg3: #9ca3af;--fg4: #6b7280;--accent-tint: rgba(96, 165, 250, .18)}html{line-height:1.5;-webkit-text-size-adjust:100%;-moz-tab-size:4;tab-size:4;font-family:ui-sans-serif,system-ui,sans-serif,"Apple Color Emoji","Segoe UI Emoji",Segoe UI Symbol,"Noto Color Emoji";font-feature-settings:normal;font-variation-settings:normal;-webkit-tap-highlight-color:transparent;background-color:var(--bg);min-height:100%;color-scheme:light}html.dark{color-scheme:dark;background-color:var(--bg)}*{box-sizing:border-box}html,body{margin:0;padding:0;min-height:100%}#root{height:100vh;height:100dvh;display:flex;overflow:hidden;background-color:var(--bg)}body{min-width:360px;line-height:1.625;font-family:inherit;background-color:var(--bg);color:var(--fg);font-size:.875rem}@media(min-width:640px){body{font-size:1rem}}html.dark body{background-color:var(--bg);color:var(--fg)}a{color:inherit}button,input,select,textarea{font:inherit}.hidden{display:none!important}.app-shell{min-height:100vh;display:flex;flex-direction:column;padding:.25rem;gap:0}@media(min-width:640px){.app-shell{padding:1rem}}html.dark .app-shell{background-color:#111827;color:#fff;flex:1}.app-main-row{display:flex;flex:1;min-height:0;min-width:0;width:100%}.menu-container{position:relative;z-index:50;display:flex;justify-content:center;flex-shrink:0;width:11rem}.menu-toggle-container{position:fixed;top:1rem;left:1rem}.menu-toggle{position:absolute;top:0;left:0;border:0;background:transparent;color:var(--accent);font-size:1.5rem;line-height:1;cursor:pointer;display:none}.menu-items{position:absolute;top:0;left:0;margin-top:.5rem;width:11rem;border-radius:.5rem;overflow:hidden;background:#fff;box-shadow:0 10px 15px -3px #0000001a,0 4px 6px -4px #0000001a;border:none}html.dark .menu-items{background:#1f2937;box-shadow:0 10px 15px -3px #0000001a,0 4px 6px -4px #0000001a}.menu-items-mobile-hidden{display:block}.menu-item{display:flex;align-items:center;gap:.5rem;width:100%;border:0;background:transparent;text-align:left;padding:.5rem 1rem;cursor:pointer;color:#374151;font-weight:400}.menu-item-icon-wrap{display:inline-flex;flex-shrink:0;align-items:center;justify-content:center;color:inherit}.menu-nav-icon{width:1.5rem;height:1.5rem;display:block}.menu-item-label{flex:1;min-width:0}.menu-item-top{border-top-left-radius:.5rem;border-top-right-radius:.5rem}.menu-item-bottom{border-bottom-left-radius:.5rem;border-bottom-right-radius:.5rem}html.dark .menu-item{color:#e5e7eb}.menu-item:hover,.menu-item.selected{background:#dbeafe}html.dark .menu-item:hover,html.dark .menu-item.selected{background:#374151}.app-content{flex:1;display:flex;flex-direction:column;gap:0;padding:.5rem;min-width:0}.top-grid-shell{position:relative;display:grid;grid-template-columns:minmax(0,1fr);gap:.25rem;align-items:center;justify-content:center;margin-bottom:.75rem}@media(min-width:640px){.top-grid-shell{grid-template-columns:repeat(3,minmax(0,1fr));gap:.5rem}}.flashing-indicator{position:absolute;inset:0;border-radius:.5rem;opacity:.75;z-index:50;animation:flash 1s infinite}@keyframes flash{0%,to{opacity:.75}50%{opacity:0}}@keyframes appViewFadeIn{0%{opacity:0}to{opacity:1}}.app-view-fade-in{animation:appViewFadeIn .12s ease-out both}@media(prefers-reduced-motion:reduce){.app-view-fade-in{animation:none;opacity:1}}.app-footer-chrome{position:relative;z-index:2;box-shadow:0 -1px 0 var(--border)}html.dark .app-footer-chrome{box-shadow:0 -1px #ffffff14}.empty-state{display:flex;flex-direction:column;align-items:center;text-align:center;justify-content:center;padding:20px 16px 22px;max-width:32rem;margin:0 auto;color:var(--fg2)}.empty-state--compact{padding:8px 4px 10px;max-width:none}.empty-state-icon-wrap{color:var(--fg3);margin-bottom:10px;opacity:.9}.empty-state--compact .empty-state-icon-wrap{margin-bottom:6px}.empty-state--compact .empty-state-icon-svg{width:22px;height:22px}.empty-state-title{margin:0;font-size:14px;font-weight:600;color:var(--fg);line-height:1.35}.empty-state--compact .empty-state-title{font-size:13px}.empty-state-desc{margin:6px 0 0;font-size:12px;line-height:1.5;color:var(--fg3);max-width:28rem}.empty-state--compact .empty-state-desc{font-size:11px;margin-top:4px}.empty-state-cta{margin-top:14px;padding:7px 14px;border-radius:8px;border:1px solid var(--border);background:var(--accent);color:#fff;font-size:12px;font-weight:600;font-family:inherit;cursor:pointer;transition:filter .15s,opacity .15s}.empty-state-cta:hover{filter:brightness(1.06)}.empty-state-cta:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.empty-state--compact .empty-state-cta{margin-top:8px;padding:5px 10px;font-size:11px}.alg-cases-empty{min-height:200px;display:flex;align-items:center;justify-content:center;border-radius:12px;border:1px dashed var(--border);background:var(--raised)}@media(prefers-reduced-motion:reduce){.practice-timer-card,.mobile-timer-card{transition:border-color .15s,box-shadow .15s!important}.practice-timer-card,.mobile-timer-card,.practice-timer-value,.practice-timer-value--mobile{transform:none!important}}button:active{opacity:.75}button{-webkit-tap-highlight-color:transparent}.top-column{min-height:100%;width:100%;max-width:100%;min-width:0}.left-column,.right-column{display:flex;flex-direction:column}.left-column{align-items:center;min-width:min(100%,240px)}.right-column{align-items:center}@media(min-width:640px){.right-column{align-items:flex-end}}.shell-card{border:1px solid #9ca3af;border-radius:.5rem;background:#fff;color:#111827;box-shadow:var(--shadow-md)}html.dark .shell-card{border-color:#374151;background-color:#374151;color:#fff;box-shadow:var(--shadow-md)}.side-card{min-height:100%;padding:.5rem}#left-side-inner.shell-card,html.dark #left-side-inner.shell-card{background:transparent;border:none;box-shadow:none}.alg-name-display-container{display:flex;align-items:center;justify-content:center;gap:.5rem;min-height:1.75rem;text-align:center;font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,monospace;font-size:.875rem;color:#111827}html.dark .alg-name-display-container{color:#fff}@media(min-width:640px){.alg-name-display-container{font-size:1rem}}.alg-name-display{margin:0}.icon-button,.link-button{border:0;background:transparent;cursor:pointer}.times-display{min-height:4rem;font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,monospace}.times-grid{display:grid;grid-template-columns:auto 1fr;gap:.25rem .5rem;padding-top:.5rem}.times-grid-label{text-align:right}.times-grid-value{text-align:left}.times-grid-emphasis{font-weight:700}.graph-display{display:flex;align-items:center;justify-content:center;width:100%;max-width:100%;min-height:200px;margin:0 auto}.recent-times-header{display:flex;align-items:center;justify-content:space-between;gap:8px;margin-bottom:8px}.recent-times-toggle{flex-shrink:0;display:inline-flex;align-items:center;justify-content:center;width:36px;height:36px;padding:0;border:none;border-radius:8px;background:var(--raised);color:var(--fg2);cursor:pointer}.recent-times-toggle:hover{color:var(--accent)}.practice-top-grid{width:100%;max-width:95%;display:grid;grid-template-columns:minmax(240px,1fr) minmax(0,2fr) minmax(240px,1fr);gap:14px;align-items:start}.practice-side-column{display:flex;flex-direction:column;align-items:center;justify-content:flex-start;min-width:0}.practice-side-column--left{align-items:flex-end}.practice-recent-card,.practice-side-column--right{width:min(100%,360px);min-width:240px}.practice-timer-card{overflow:hidden}.practice-timer-value{max-width:100%;overflow:hidden;text-align:right;font-size:clamp(2.5rem,3.2vw,3.75rem)}.practice-timer-value--mobile{text-align:center;font-size:clamp(2.375rem,14vw,3.5rem);overflow:visible}.practice-recent-card{overflow:hidden}.practice-recent-card .graph-display{min-height:130px}.practice-recent-card .times-display{min-height:130px;overflow:auto}.practice-cube-column{display:flex;flex-direction:column;align-items:center;justify-content:flex-start;gap:10px;min-width:0;width:100%}.practice-cube-card{width:100%;max-width:100%;min-width:0}@media(max-width:1080px){.practice-top-grid{grid-template-columns:1fr;justify-items:center}.practice-cube-column{order:1}.practice-side-column--left{order:2;width:100%;align-items:center}.practice-side-column--right{order:3;width:min(100%,420px)}.practice-recent-card{width:min(100%,420px)}}@media(max-width:639px){.mobile-timer-card{isolation:isolate}.mobile-stat-chip-row{row-gap:8px}}.cube-area{min-width:0;min-height:10em;display:flex;align-items:stretch;justify-content:center;justify-self:center;max-width:100%;position:relative}.cube-area-content{width:100%;height:100%}.cube-area-content--hidden{visibility:hidden}.cube-countdown-overlay{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;font-size:clamp(4rem,18vw,7rem);font-weight:700;line-height:1;pointer-events:none}@media(min-width:640px){.cube-area{min-width:15em;min-height:15em}}.twisty-cube-host{width:100%;height:100%;min-width:0;min-height:0;display:flex;align-items:center;justify-content:center}.twisty-cube-host twisty-player{width:100%;height:100%;max-width:100%}.connect-row{display:flex;justify-content:center;align-items:center;gap:.5rem}@media(min-width:640px){.connect-row{justify-content:flex-end}}.primary-button,.round-button,.mask-toggle-button{border:0;background:var(--accent);color:#fff;cursor:pointer;transition:background-color .2s ease}.primary-button:hover,.round-button:hover,.mask-toggle-button:hover{background:var(--accent-h)}.round-button:disabled{cursor:not-allowed;background:#9ca3af;color:#d1d5db}html.dark .round-button:disabled{background:#9ca3af;color:#d1d5db}.primary-button{border-radius:.5rem;padding:.5rem 1rem;font-weight:700;font-size:.875rem;transition:background-color .3s ease}@media(min-width:640px){.primary-button{font-size:1rem}}.primary-button:disabled{cursor:not-allowed;background:#9ca3af;color:#d1d5db}html.dark .primary-button:disabled{background:#9ca3af;color:#d1d5db}.connect-button{display:inline-flex;align-items:center;gap:.5rem}.indicator-badge{display:inline-flex;align-items:center;justify-content:center;min-width:1.5rem}.touch-timer{min-height:11rem;display:flex;justify-content:center;align-items:center;width:100%}.timer-stack{display:flex;flex-direction:column;align-items:center;gap:.5rem}.time-attack-banner{display:flex;flex-direction:column;align-items:center;gap:.125rem;padding:.625rem .875rem;border:1px solid #93c5fd;border-radius:.5rem;background:#eff6ff;color:var(--accent-h);text-align:center}.time-attack-banner-title{font-weight:600}.time-attack-banner-progress{font-size:.875rem}.timer-display{border:1px solid #9ca3af;border-radius:.5rem;padding:.5rem .75rem;font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,monospace;font-size:.875rem;margin-top:.5rem;text-align:right}@media(min-width:640px){.timer-display{font-size:1.25rem;margin-left:2rem}}@media(min-width:768px){.timer-display{font-size:1.5rem}}@media(min-width:1024px){.timer-display{font-size:1.875rem}}html.dark .timer-display{border-color:#374151;color:#fff}html.dark .time-attack-banner{border-color:var(--accent-h);background:#1e3a8a4d;color:#bfdbfe}.alg-bar{display:flex;flex-direction:row;align-items:center;width:100%;max-width:var(--practice-alg-track-max);margin:0 auto}.alg-track{display:flex;align-items:center;flex:1;min-width:0;gap:6px}.alg-bar .alg-input--track{margin-bottom:0;flex:1 1 auto;min-width:0}.alg-display--embed{margin:0;padding:0;min-height:0;background:transparent;border:none;box-shadow:none;flex:1;min-width:0}.round-button{display:inline-flex;align-items:center;justify-content:center;width:2.5rem;height:2.5rem;margin-top:0;padding:0;border-radius:9999px;flex-shrink:0;line-height:0;font-size:0;font-weight:400;box-shadow:0 10px 15px -3px #0000001a,0 4px 6px -4px #0000001a;transition:background-color .3s ease,color .3s ease}.round-button svg{display:block;width:1.5rem;height:1.5rem;flex-shrink:0}.alg-bar #train-alg{margin-right:0}.alg-bar #scramble-to{margin-left:0}.alg-bar>.alg-input,.alg-bar>.alg-display-container{flex:1;min-width:0}.alg-input,.alg-display,.text-input,.readonly-input,.select-input,.number-input{width:100%;border:1px solid #9ca3af;border-radius:.5rem;background:#fff;color:#111827;box-shadow:var(--shadow-md);outline:none;transition:border-color .15s ease,box-shadow .15s ease}.alg-input:focus,.text-input:focus,.readonly-input:focus,.select-input:focus,.number-input:focus{border-color:var(--accent)}html.dark .alg-input,html.dark .alg-display,html.dark .text-input,html.dark .readonly-input,html.dark .select-input,html.dark .number-input{border-color:#374151;background:#374151;color:#fff}.alg-input,.text-input,.readonly-input,.select-input,.number-input{padding:.75rem 1rem}.alg-input{box-sizing:border-box;padding:1rem;font-size:1rem;line-height:1.5;margin-top:0;margin-bottom:1rem;height:calc(3.59375rem + 2px);min-height:calc(3.59375rem + 2px);max-height:calc(3.59375rem + 2px);-webkit-text-fill-color:#111827;caret-color:#111827}.alg-input::placeholder{color:#6b7280;-webkit-text-fill-color:#6b7280;font-style:normal;opacity:1}@media(min-width:640px){.alg-input{font-size:1.125rem;height:calc(3.78125rem + 2px);min-height:calc(3.78125rem + 2px);max-height:calc(3.78125rem + 2px)}}html.dark .alg-input{-webkit-text-fill-color:#ffffff;caret-color:#fff}html.dark .alg-input::placeholder{color:#6b7280;-webkit-text-fill-color:#6b7280;font-style:normal;opacity:1}.text-input,.readonly-input,.select-input,.number-input{-webkit-text-fill-color:currentColor}.text-input::placeholder{color:#6b7280;-webkit-text-fill-color:#6b7280;font-style:italic;opacity:1}html.dark .text-input::placeholder{color:#6b7280;-webkit-text-fill-color:#6b7280;opacity:1}.alg-display-container{position:relative;flex:1;min-width:0;width:100%;margin:0}.alg-display-container--embed{flex:1;min-width:0;margin:0;padding:0;border:none;background:transparent}.alg-display-mask-row{display:flex;justify-content:flex-end}.mask-toggle-button{position:absolute;top:0;right:0;z-index:2;display:inline-flex;align-items:center;justify-content:center;gap:.25rem;border-radius:.5rem;padding:0 .5rem;min-height:0;text-decoration:none;font-size:.875rem;line-height:1.25}.mask-toggle-button svg{display:block;flex-shrink:0;width:1.5rem;height:1.5rem}.alg-display{box-sizing:border-box;padding:1rem;margin-top:0;margin-bottom:1rem;font-weight:700;font-size:1rem;line-height:1.5;letter-spacing:.025em;min-height:calc(3.59375rem + 2px)}@media(min-width:640px){.alg-display{font-size:1.125rem;min-height:calc(3.78125rem + 2px)}}.alg-display-moves{display:block;width:100%;font-size:1.0625rem}@media(min-width:640px){.alg-display-moves{font-size:1.1875rem;white-space:nowrap;overflow-x:auto;overflow-y:hidden}}@media(max-width:639px){.alg-display-moves{white-space:normal;overflow-x:visible}}.alg-track .alg-input--track{height:auto;min-height:1.5rem;max-height:none;padding:0;border:none;border-radius:0;background:transparent;box-shadow:none}.alg-display.alg-display--embed{min-height:0;margin:0;padding:0;border:none;border-radius:0;background:transparent!important;box-shadow:none}.alg-display.alg-display--embed .alg-display-moves{background:transparent;line-height:1.35}.circle{display:inline-flex;align-items:center;justify-content:center;background-color:#f97316;border-radius:25%;padding:.08em .28em;margin:0 .05em;vertical-align:baseline;line-height:1.1;box-decoration-break:clone;-webkit-box-decoration-break:clone}.alg-display .circle .move{color:#fff;-webkit-text-fill-color:currentColor}.info-inline{width:100%;max-width:var(--practice-alg-track-max);margin:0 auto;padding:0 1rem;box-sizing:border-box;font-size:.75rem;color:#6b7280}html.dark .info-inline{color:#9ca3af}.info-inline-row{display:flex;flex-direction:row;gap:.5rem;align-items:flex-start}.info-inline-row-text{margin:0;padding-top:.25rem}.status-panel{width:100%;max-width:var(--practice-alg-track-max);margin:0 auto 1rem;padding:1rem;box-sizing:border-box;border-radius:.5rem;border:1px solid #d1d5db;background:#f9fafb}html.dark .status-panel{border-color:#374151;background:#374151}html.dark .status-panel.status-error{border-color:#f87171}html.dark .status-panel.status-success{border-color:#4ade80}.status-error{color:#dc2626}html.dark .status-panel.status-error,html.dark .status-error{color:#ef4444}.status-success{color:#16a34a}html.dark .status-panel.status-success,html.dark .status-success{color:#22c55e}.help-panel,.load-panel,.options-panel{padding:1rem}.help-panel.shell-card{margin-top:2rem}@media(min-width:640px){.help-panel.shell-card{margin-top:1.25rem}}@media(min-width:768px){.help-panel.shell-card{margin-top:0}}.load-panel{display:flex;flex-direction:column;gap:1rem;margin-top:1rem}.panel-header-row{display:grid;grid-template-columns:1fr 1fr;gap:.5rem;align-items:center}.panel-title{margin:0;font-size:1.5rem;font-weight:700}.help-toggle-text{margin:0;text-align:right;font-size:1.25rem;font-weight:700}.section-title{font-weight:700;margin:1rem 0 .5rem}.input-label{display:block;font-weight:400;margin:0 0 .5rem}.help-list{margin:0;padding-left:1.25rem}.help-list li{margin-bottom:.5rem}.help-panel a{color:var(--accent)}.help-panel a:hover{text-decoration:underline}html.dark .help-panel a{color:#60a5fa}.video-shell{margin:.75rem 0 1rem;min-height:220px;display:flex;align-items:center;justify-content:center}.help-footer-shell{display:flex;justify-content:center}.subpanel{width:min(100%,900px);border:1px solid #9ca3af;border-radius:.5rem;background:#f9fafb;padding:1rem;box-shadow:var(--shadow-md)}html.dark .subpanel{border-color:#374151;background:#4b5563;color:#fff}.centered-text{text-align:center}.save-panel{display:flex;flex-direction:column;gap:1rem;font-size:.875rem}@media(min-width:640px){.save-panel{font-size:1rem}}.save-panel-actions{display:flex;flex-direction:row;flex-wrap:wrap;align-items:center;align-self:flex-start;gap:.5rem;width:fit-content;max-width:100%}.save-panel-button{flex:0 0 auto;width:auto;border:0;border-radius:.5rem;padding:.5rem 1rem;font-weight:700;font-size:inherit;line-height:1.5;background:var(--accent);color:#fff;cursor:pointer;transition:background-color .3s ease-in-out}.save-panel-button:hover{background:var(--accent-h)}.save-panel-button:disabled{cursor:not-allowed;background:#9ca3af;color:#d1d5db}html.dark .save-panel-button:disabled{background:#9ca3af;color:#d1d5db}.form-grid,.info-panel{display:grid;grid-template-columns:auto 1fr;gap:1rem;align-items:center}.info-panel.shell-card{background:transparent;border:none;box-shadow:none;padding:0;margin:1rem 0}html.dark .info-panel.shell-card{background:transparent;border:none;box-shadow:none}.info-panel .form-label{color:#4b5563}html.dark .info-panel .form-label{color:#9ca3af}.form-label{text-align:right;white-space:nowrap}.stats-panel{display:flex;flex-direction:column;gap:0;width:100%;max-width:var(--practice-alg-track-max);margin:0 auto;padding:0;box-sizing:border-box}@media(min-width:1024px){.stats-panel{flex-direction:row;align-items:stretch}}html.dark .stats-panel.shell-card{background:#1f2937;border-color:#374151}.stats-graph-container{flex:1 1 auto;width:100%;min-width:0;min-height:240px;max-height:600px;max-width:750px;padding:.5rem .5rem 0;box-sizing:border-box}@media(min-width:640px){.stats-graph-container{padding:1rem 1rem 0}}@media(min-width:1024px){.stats-graph-container{display:flex;flex-direction:column;padding:1rem 0 1rem 1rem;max-width:none;flex:1 1 0;min-width:0}}.stats-graph-shell{position:relative;box-sizing:border-box;width:100%;max-width:90vw;height:300px;margin-left:auto;margin-right:auto}@media(min-width:640px){.stats-graph-shell{height:350px}}@media(min-width:768px){.stats-graph-shell{height:450px}}@media(min-width:1024px){.stats-graph-shell{flex:1 1 auto;min-height:0;height:auto;max-width:100%;margin-top:0;margin-bottom:0}}.stats-graph-canvas{width:100%;height:100%}.metrics-container{width:100%;min-width:min(100%,250px);box-sizing:border-box}@media(min-width:1024px){.metrics-container{width:290px;min-width:290px;max-width:290px;flex-shrink:0}}.metrics-title{text-align:center;font-size:1rem;line-height:1.5;font-weight:700;padding:.5rem 1rem .25rem}@media(min-width:768px){.metrics-title{font-size:1.125rem}}@media(min-width:1024px){.metrics-title{font-size:1.5rem;padding-top:1rem;max-width:280px;margin-left:auto;margin-right:auto}}.metrics-grid{display:flex;flex-direction:column;width:100%;justify-content:flex-start}@media(min-width:640px)and (max-width:1023px){.metrics-grid{flex-direction:row;flex-wrap:wrap;justify-content:center}}@media(min-width:1024px){.metrics-grid{flex-direction:column;justify-content:flex-start}}.metric-box{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.2rem;box-sizing:border-box;min-width:154px;margin:.25rem;padding:.25rem;border:1px solid #9ca3af;border-radius:.5rem;background:#f9fafb;font-size:1rem;line-height:1.4;font-weight:700;text-align:center;box-shadow:var(--shadow-md)}@media(min-width:640px){.metric-box{margin:1rem;padding:1rem}}@media(min-width:768px){.metric-box{font-size:1.125rem}}@media(min-width:1024px){.metric-box{margin:2rem;padding:2rem;font-size:1.5rem}}html.dark .metric-box{border-color:#374151;background:#4b5563;color:#fff}.metric-box-title{font-weight:700;text-align:center;white-space:nowrap}.metric-box--time{align-items:stretch;text-align:left}@media(min-width:1024px){.metric-box--time{padding-top:1rem;padding-bottom:1rem}}.metric-time-row{display:flex;align-items:baseline;justify-content:space-between;gap:.75rem;width:min(100%,160);margin:0 auto}.metric-time-row--secondary{font-size:.85em}.metric-time-label,.metric-time-value{display:inline-flex}.metric-time-value{font-variant-numeric:tabular-nums}.control-row{display:block;gap:.5rem}@media(min-width:640px){.control-row{display:flex;flex-direction:row;flex-wrap:wrap;gap:.5rem;align-items:flex-start}}.selector-card{width:200px;max-width:100%}.selector-card .select-input{width:11rem;max-width:100%;padding:.5rem;font-size:.875rem}@media(min-width:640px){.selector-card .select-input{font-size:1rem}}html.dark .selector-card .select-input{background:#4b5563;color:#fff;border-color:#374151}.selector-options-card{flex:1;min-width:0;max-width:100%}@media(min-width:1024px){.selector-options-card{max-width:500px}}@media(min-width:1280px){.selector-options-card{max-width:750px}}.toggle-grid{display:grid;grid-template-columns:1fr;gap:1rem .5rem;padding:1rem;border:1px solid #9ca3af;border-radius:.5rem;background:#f9fafb;box-shadow:var(--shadow-md)}@media(min-width:1024px){.toggle-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}@media(min-width:1280px){.toggle-grid{grid-template-columns:repeat(3,minmax(180px,1fr))}}html.dark .toggle-grid{border-color:#374151;background:#4b5563;color:#fff}.toggle-grid .toggle-switch{margin-bottom:0;max-width:250px}.toggle-item{display:inline-flex;align-items:center;gap:.5rem;cursor:pointer}.text-blue-500{color:var(--accent);background:none;border:none;padding:0;font:inherit;cursor:pointer}.text-blue-500:hover{text-decoration:underline}.subset-label-row{display:flex;align-items:center;flex-wrap:wrap;gap:.25rem;margin-top:.5rem;margin-bottom:.5rem}.subset-item{padding:.35rem 0}.subset-label{display:flex;align-items:center;gap:.5rem}.subsets-panel{padding:1rem;border:1px solid #9ca3af;border-radius:.5rem;background:#f9fafb;box-shadow:var(--shadow-md)}html.dark .subsets-panel{border-color:#374151;background:#4b5563;color:#fff}.subset-grid,.alg-cases-grid{display:grid;grid-template-columns:repeat(1,minmax(0,1fr));gap:.5rem}.alg-cases-grid,.alg-cases-virtualized{padding:.5rem}@media(min-width:640px){.subset-grid,.alg-cases-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.alg-cases-grid{padding:1rem;gap:1rem}}@media(min-width:768px){.subset-grid,.alg-cases-grid{grid-template-columns:repeat(3,minmax(0,1fr))}}@media(min-width:1024px){.subset-grid,.alg-cases-grid{grid-template-columns:repeat(4,minmax(0,1fr))}}@media(min-width:1280px){.subset-grid,.alg-cases-grid{grid-template-columns:repeat(5,minmax(0,1fr))}}@media(min-width:1536px){.subset-grid,.alg-cases-grid{grid-template-columns:repeat(6,minmax(0,1fr))}}.cases-category-strip::-webkit-scrollbar{display:none}.case-wrapper{position:relative;padding:1rem;border-radius:.5rem;box-shadow:var(--shadow-md);border:none;content-visibility:auto;contain-intrinsic-size:260px 240px}.case-alt-dark{background:#9ca3af}html.dark .case-alt-dark{background:#1f2937}.case-alt-light{background:#f9fafb}html.dark .case-alt-light{background:#4b5563}.case-card-header{display:flex;justify-content:space-between;align-items:flex-start;gap:.5rem}.case-name{width:100%;font-size:.875rem}.bookmark-button{display:block;border:0;background:transparent;cursor:pointer;padding:0}.bookmark-button[aria-disabled=true]{cursor:default}.case-card-body{display:block;cursor:pointer}.case-metric{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,monospace;font-size:.75rem;color:#111827}html.dark .case-metric{color:#fff}.case-preview{display:flex;align-items:center;justify-content:center;min-height:120px;margin:.25rem -.5rem}.case-preview-inner{transform:scale(.5);transform-origin:center;margin:-2.5rem -5rem}.twisty-case-host{width:240px;min-height:240px;height:240px;display:flex;align-items:center;justify-content:center}.twisty-case-host twisty-player{width:100%;height:100%}.case-toggle-row{position:relative;display:grid;grid-template-columns:auto 1fr;align-items:center;min-height:1.75rem;margin-top:.25rem}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border-width:0}.toggle-track{width:2.75rem;height:1.5rem;background:#e5e7eb;border-radius:9999px;box-shadow:inset 0 1px 2px #0f172a1f}.toggle-dot{position:absolute;left:.25rem;top:50%;width:1rem;height:1rem;background:#fff;border-radius:9999px;box-shadow:0 1px 2px #0f172a2e;transform:translateY(-50%);transition:transform .2s ease-in-out}.case-toggle-row>input:checked+.toggle-track{background:var(--accent)}.case-toggle-row>input:checked+.toggle-track+.toggle-dot{transform:translate(1.25rem,-50%)}.case-results{position:absolute;right:0;display:grid;grid-template-columns:repeat(2,auto);gap:.25rem}.failed-count{color:#dc2626;font-size:.875rem;font-weight:700}.success-count{color:#16a34a;font-size:.875rem;font-weight:700}.bg-red-400{background:#f87171}.toggle-switch{position:relative;display:inline-flex;align-items:center;cursor:pointer;margin-bottom:1rem;max-width:250px}.toggle-switch-track{width:2.75rem;height:1.5rem;flex-shrink:0;background:#e5e7eb;border-radius:9999px;box-shadow:inset 0 2px 4px #0000000d}.toggle-switch-dot{position:absolute;left:.25rem;top:50%;width:1rem;height:1rem;background:#fff;border-radius:9999px;box-shadow:0 1px 2px #0f172a2e;transform:translateY(-50%);transition:transform .2s ease-in-out}.toggle-switch input.sr-only:checked+.toggle-switch-track{background-color:var(--accent)}.toggle-switch input.sr-only:checked+.toggle-switch-track+.toggle-switch-dot{transform:translate(1.25rem,-50%)}.toggle-switch input.sr-only:disabled+.toggle-switch-track{opacity:.5;cursor:not-allowed}.toggle-switch input.sr-only:disabled~.toggle-switch-label{opacity:.6;cursor:not-allowed}.toggle-switch-label{margin-left:.5rem;font-size:.875rem;color:#111827}html.dark .toggle-switch-label{color:#fff}@media(min-width:640px){.toggle-switch-label{font-size:1rem}}.options-panel .toggle-switch,#device-options-container .toggle-switch{max-width:none}.toggle-switch--inline{margin-bottom:0;max-width:none}.toggle-switch--indented{margin-left:1.5rem}.subset-grid input[type=checkbox].subset-checkbox,.subset-label-row input[type=checkbox].subset-checkbox{appearance:none;-webkit-appearance:none;width:1.25rem;height:1.25rem;margin:0;margin-left:.5rem;flex-shrink:0;vertical-align:middle;cursor:pointer;border:2px solid #9ca3af;border-radius:.25rem;background-color:#fff;position:relative;transition:border-color .15s ease,background-color .15s ease}html.dark .subset-grid input[type=checkbox].subset-checkbox,html.dark .subset-label-row input[type=checkbox].subset-checkbox{border-color:#e5e7eb;background-color:transparent}.subset-grid input[type=checkbox].subset-checkbox:checked,.subset-label-row input[type=checkbox].subset-checkbox:checked{background-color:var(--accent);border-color:var(--accent)}.subset-grid input[type=checkbox].subset-checkbox:checked:after,.subset-label-row input[type=checkbox].subset-checkbox:checked:after{content:"";position:absolute;left:50%;top:45%;width:.3rem;height:.55rem;border:solid #ffffff;border-width:0 2px 2px 0;transform:translate(-50%,-50%) rotate(45deg)}.subset-grid input[type=checkbox].subset-checkbox:focus-visible,.subset-label-row input[type=checkbox].subset-checkbox:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.white-bottom-group{display:flex;flex-direction:column;align-items:flex-start;margin-bottom:1rem}.white-bottom-group .toggle-switch{margin-bottom:0}.white-bottom-group .subtle-text{margin-left:1.5rem;margin-top:.25rem}.delete-mode-container,.button-row,.options-group{display:flex;gap:.75rem;flex-wrap:wrap;align-items:center}.options-panel{display:flex;flex-direction:column;gap:1rem}#options-container.options-panel{gap:.5rem;border-radius:.5rem;margin-top:2rem;font-size:.875rem}@media(min-width:640px){#options-container.options-panel{margin-top:1.25rem;font-size:1rem}}@media(min-width:768px){#options-container.options-panel{margin-top:0}}.options-section{display:block;margin-bottom:1rem}.options-section-title{margin:0;font-weight:400;font-size:inherit}#options-container .options-button-row{display:flex;flex-wrap:wrap;gap:.5rem;align-items:center}.options-toggle-row{display:flex;align-items:center;margin-bottom:1rem;font-size:inherit}.options-toggle-row .toggle-switch{margin-bottom:0}#options-container .toggle-switch-label{font-size:inherit}#visualization-container{display:block}.options-viz-label{display:block;margin:0 0 .5rem;font-size:1rem;font-weight:400;color:#111827}html.dark .options-viz-label{color:#fff}.options-cube-size-label{display:block;margin:0 0 .25rem;font-size:1rem;font-weight:400;color:#111827}html.dark .options-cube-size-label{color:#fff}#options-container .select-input{display:block;width:11.25rem;max-width:100%;padding:.5rem;margin-bottom:1rem}#options-container .number-input{padding:.5rem;width:6rem}#device-options-container .device-ble-toggle-row{display:flex;flex-direction:column;gap:.25rem;margin-top:.75rem;font-size:.875rem}#device-options-container .device-ble-toggle-row .toggle-switch{margin-bottom:0}@media(min-width:640px){#device-options-container .device-ble-toggle-row{font-size:1rem}}.battery-icon{display:inline-block;width:2rem;height:2rem;vertical-align:middle}.subtle-text{color:#6b7280;font-size:.75rem}.cube-size-row{display:flex;align-items:center;gap:.5rem;max-width:300px}.cube-size-row input[type=range]{flex:1;width:100%;min-width:0}.number-input{width:6rem}.footer{display:block;min-width:360px;text-align:center;font-size:.75rem;color:#4b5563;line-height:1.25;padding:.5rem}html.dark .footer{color:#9ca3af}.footer a{color:var(--accent);text-decoration:none}.footer a:hover{text-decoration:underline}.footer p{margin:0 0 .5rem}.footer p:last-child{margin-bottom:0}@media(max-width:639px){.left-column{order:2}.cube-area{order:3}.right-column{order:1}}.w-6{width:1.5rem}.h-6{height:1.5rem}.w-8{width:2rem}.h-8{height:2rem}.inline-block{display:inline-block}@media(max-width:767px){.app-shell{padding-top:3rem}.menu-container{width:0}.menu-toggle{display:block}.menu-items{top:3rem}.menu-items-mobile-hidden{display:none}.alg-bar{flex-wrap:nowrap}.alg-bar .alg-track{flex:1 1 auto;min-width:0}.panel-header-row,.form-grid,.info-panel{grid-template-columns:1fr}.form-label,.help-toggle-text{text-align:left}.subset-grid,.toggle-grid{grid-template-columns:1fr}}
