.modal-shell{position:fixed;top:0;right:0;bottom:0;left:0;display:grid;place-items:center;z-index:2000}.modal-backdrop{position:absolute;top:0;right:0;bottom:0;left:0;background:#00000085}.modal-card{position:relative;width:min(32rem,calc(100% - 1.5rem));max-height:min(80dvh,40rem);overflow:hidden;border-radius:1.2rem;border:1px solid rgba(255,255,255,.08);background:#17100bf5;box-shadow:0 1rem 2.4rem #00000059;padding:.9rem;display:flex;flex-direction:column}.modal-card--import-locks{max-height:min(86dvh,44rem)}.modal-card--allow-overflow{overflow:visible}.modal-card--bottom-edge{align-self:end;margin-bottom:.75rem}.modal-header{display:flex;justify-content:space-between;align-items:center;gap:1rem}.modal-title{margin:0;font-size:1rem;color:var(--text)}.modal-body{margin-top:.85rem;overflow:auto;min-height:0;flex:1 1 auto}.modal-body--allow-overflow{overflow:visible}.modal-inline-actions{display:flex;justify-content:flex-start;margin-bottom:.7rem}.modal-inline-actions--after-code{margin-top:.7rem;margin-bottom:0}.modal-text-button{border:1px solid rgba(227,167,77,.28);background:#e3a74d14;color:#f6dfb2;padding:.35rem .65rem;font:inherit;font-size:.82rem;border-radius:999px;cursor:pointer;box-shadow:0 .35rem .7rem #0000001f;transition:transform .14s ease,background .14s ease,border-color .14s ease,color .14s ease}.modal-text-button--small{align-self:flex-start;margin-top:.15rem}.modal-text-button:hover,.modal-text-button:focus-visible{color:var(--text);background:#e3a74d29;border-color:#e3a74d7a;transform:translateY(-1px);outline:none}.modal-help-list{margin:.8rem 0 0;padding-left:1.2rem;display:grid;gap:.45rem}.modal-note--compact{font-size:.88rem;line-height:1.42}.modal-note--share{padding-bottom:.15rem}.modal-note--spaced-top,.modal-footer--spaced{margin-top:1.8rem}.modal-note--emphasis{color:var(--text);font-size:.98rem;font-weight:700}.modal-note--boxed{padding:.55rem .7rem;border:1px solid rgba(227,167,77,.3);border-radius:.75rem;background:#e3a74d12}.modal-note--validation{color:#ffd77a;font-size:.84rem;line-height:1.35}.saved-lock-name-row{display:flex;align-items:center;gap:.45rem;flex-wrap:wrap}.saved-lock-name{color:var(--text)}.modal-field--share-url{padding-bottom:.35rem}.modal-field--share-url .modal-field-label{margin-top:.4rem}.modal-keyword{display:inline-block;padding:.04rem .35rem;border-radius:999px;background:#e3a74d24;border:1px solid rgba(227,167,77,.24);color:#f6dfb2;font-size:.92em;line-height:1.2}.modal-actions{margin-top:1rem;display:flex;justify-content:center;gap:.65rem;flex-wrap:nowrap;flex:0 0 auto}.modal-actions--fit{width:100%;flex-wrap:wrap}.modal-actions--fit .action-button{width:auto;min-width:0;max-width:none;flex:1 1 11rem}.modal-actions--keep-side-by-side{width:100%;flex-wrap:nowrap}.modal-actions--keep-side-by-side .action-button{width:auto;min-width:0;max-width:none;flex:1 1 0}.modal-actions--import-locks{width:100%;flex-wrap:nowrap}.modal-actions--import-locks .action-button{width:auto;min-width:0;max-width:none;flex:1 1 0}@media (max-width: 540px){.modal-actions--fit .action-button{flex-basis:100%}.modal-actions--keep-side-by-side .action-button{flex-basis:0}}@media (max-width: 420px){.modal-actions--keep-side-by-side{gap:.5rem}.modal-actions--keep-side-by-side .action-button{padding-left:.7rem;padding-right:.7rem;font-size:.9rem}.modal-actions--import-locks{gap:.5rem}.modal-actions--import-locks .action-button{padding-left:.7rem;padding-right:.7rem}}.modal-close{border:0;background:transparent;color:var(--muted);cursor:pointer;font-size:1.35rem;line-height:1;width:2rem;height:2rem;border-radius:999px;display:grid;place-items:center}.modal-close:hover,.modal-close:focus-visible{color:var(--text);background:#ffffff0d;outline:none}.modal-empty,.modal-note{margin:0;color:var(--muted);line-height:1.5}.modal-code-block{margin:0;border-radius:.9rem;border:1px solid rgba(255,255,255,.08);background:#ffffff0a;color:var(--text);padding:.9rem;font:.8rem/1.55 Consolas,Courier New,monospace;white-space:pre-wrap;word-break:break-word;max-height:calc(9.3em + 1.8rem);overflow:auto}.modal-code-block--compact{max-height:calc(4.65em + 1.8rem)}.modal-code-block--share-url{font-size:.74rem;line-height:1.7}.share-url-token{display:inline;color:#ffd77a;font-size:1.2em;font-weight:800;line-height:1.1;letter-spacing:.02em;text-shadow:0 0 .22rem rgba(227,167,77,.18);background:transparent;box-shadow:none;border:0;padding:0;margin:0 .08rem;border-radius:0}.modal-code-block--spaced-top{margin-top:2rem}@media (max-width: 640px){.modal-code-block{max-height:calc(7.25em + 1.6rem)}.modal-code-block--compact{max-height:calc(4.35em + 1.6rem)}}.modal-field{display:grid;gap:.45rem}.modal-field--with-tooltip{position:relative}.modal-field--spaced-top{margin-top:.65rem}.modal-field-label{color:var(--muted);font-size:.8rem}.import-locks-upload-button{margin-bottom:.7rem}.modal-input{width:100%;border:1px solid rgba(255,255,255,.12);border-radius:.85rem;background:#ffffff0a;color:var(--text);font:inherit;padding:.72rem .85rem}.modal-input--textarea{min-height:10rem;resize:vertical}.modal-form-stack>.modal-field--spaced-top{margin-top:.9rem}.modal-tooltip{position:absolute;left:.85rem;right:.85rem;bottom:calc(100% + .5rem);z-index:1;padding:.45rem .65rem;border-radius:.65rem;border:1px solid rgba(227,167,77,.42);background:#271b11fa;box-shadow:0 .5rem 1rem #00000038;color:#ffd77a;font-size:.82rem;line-height:1.35}.modal-tooltip:before{content:"";position:absolute;left:1rem;top:100%;border-width:.42rem .38rem 0;border-style:solid;border-color:rgba(39,27,17,.98) transparent transparent}.developer-setting-row{display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:.4rem 0;cursor:pointer}.developer-setting-label{color:var(--text);font-size:1rem;font-weight:700;line-height:1.35}.developer-setting-checkbox{position:absolute;opacity:0;pointer-events:none}.developer-setting-switch{position:relative;flex:0 0 auto;width:3.35rem;height:1.9rem;border-radius:999px;border:1px solid rgba(255,255,255,.14);background:#ffffff14;transition:background .14s ease,border-color .14s ease}.developer-setting-switch-thumb{position:absolute;top:.18rem;left:.18rem;width:1.42rem;height:1.42rem;border-radius:999px;background:#f2dfb7;box-shadow:0 .3rem .8rem #00000038;transition:transform .14s ease,background .14s ease}.developer-setting-checkbox:checked+.developer-setting-switch{background:#e3a74d47;border-color:#e3a74d8c}.developer-setting-checkbox:checked+.developer-setting-switch .developer-setting-switch-thumb{transform:translate(1.45rem);background:#ffd77a}.developer-setting-row:focus-within .developer-setting-switch{outline:2px solid rgba(227,167,77,.45);outline-offset:2px}.modal-checkbox-row{display:flex;align-items:flex-start;gap:.65rem;margin-top:2.5rem;cursor:pointer}.modal-checkbox{width:1rem;height:1rem;margin:.12rem 0 0;accent-color:#e3a74d;cursor:pointer}.modal-checkbox-label{color:var(--text);font-size:.94rem;font-weight:600;line-height:1.35}.modal-input:focus-visible{outline:none;border-color:#e3a74d8c;background:#e3a74d14}.modal-input--highlighted{border-color:#e3a74dcc;background:#e3a74d1f;box-shadow:0 0 0 .18rem #e3a74d2e}.bottom-panel{padding:.35rem 0 0;display:grid;grid-template-rows:auto minmax(0,1fr);gap:.25rem;min-height:0;overflow:visible;border-top:1px solid var(--divider)}.solution-empty-panel{align-items:center;justify-items:center;min-height:0;grid-template-rows:minmax(0,1fr)}.solution-empty-message{display:grid;justify-items:center;gap:.2rem;text-align:center;padding:2rem 0 1.4rem;align-self:center;justify-self:center}.solution-empty-title{margin:0;color:#f8e6c2;font-size:clamp(1.2rem,3vw,1.8rem);font-weight:800;letter-spacing:.01em;line-height:1}.solution-empty-copy{margin:0;color:#f3e2bdd6;font-size:clamp(.94rem,2vw,1.1rem);font-weight:400;letter-spacing:.01em}.controls-heading.bottom-panel-heading{margin-top:.22rem;margin-bottom:.05rem;display:grid;grid-template-columns:2.5rem minmax(0,1fr) 2.5rem;width:100%;align-items:start;gap:.6rem;min-height:2.6rem;position:relative}.controls-heading.bottom-panel-heading:before{content:"";width:2.5rem;height:2.5rem}.solution-step-header{grid-column:2;display:grid;justify-items:center;gap:.22rem;min-width:0}.bottom-panel-actions{display:flex;justify-content:center;margin-top:.35rem;gap:.7rem;flex-wrap:wrap}.bottom-panel-actions--separate{margin-top:.55rem;padding-top:.75rem;border-top:1px solid rgba(255,255,255,.06);flex-wrap:nowrap}.solution-progress-nav{--solution-control-size: 2.5rem;display:inline-flex;align-items:center;gap:.55rem}.solution-next-wrap{position:relative;display:inline-flex;align-items:center}.solution-nav-button{width:var(--solution-control-size);height:var(--solution-control-size);border:1px solid rgba(255,255,255,.1);border-radius:999px;background:#ffffff0a;color:var(--accent);cursor:pointer;display:grid;place-items:center;transition:transform .14s ease,background .14s ease,border-color .14s ease,opacity .14s ease}.solution-nav-button.is-next-emphasized{border-color:#e3a74d94;background:#e3a74d24;box-shadow:0 0 #e3a74d2e,0 0 1rem #e3a74d38;animation:solutionNextPulse 1.15s ease-in-out infinite}.solution-nav-button:hover,.solution-nav-button:focus-visible{transform:translateY(-1px);border-color:#e3a74d73;background:#e3a74d1f;outline:none}.solution-nav-button[disabled]{opacity:.36;cursor:default;transform:none}.solution-nav-button .material-icon{width:1.2rem;height:1.2rem}.solution-next-tooltip{position:absolute;left:50%;bottom:calc(100% + .55rem);transform:translate(-50%);padding:.42rem .68rem;border-radius:.7rem;border:1px solid rgba(227,167,77,.34);background:#1a120dfa;color:#f8e8c8;font-size:.72rem;font-weight:700;letter-spacing:.02em;white-space:nowrap;box-shadow:0 .75rem 1.4rem #00000042;pointer-events:none;z-index:3;animation:solutionTooltipPulse 1.2s ease-in-out infinite}.solution-next-tooltip:after{content:"";position:absolute;left:50%;top:100%;transform:translate(-50%);border-left:.38rem solid transparent;border-right:.38rem solid transparent;border-top:.42rem solid rgba(26,18,13,.98);filter:drop-shadow(0 1px 0 rgba(227,167,77,.28))}@keyframes solutionNextPulse{0%,to{transform:translateY(0);box-shadow:0 0 #e3a74d2e,0 0 1rem #e3a74d38}50%{transform:translateY(-1px);box-shadow:0 0 0 .22rem #e3a74d1f,0 0 1.35rem #e3a74d57}}@keyframes solutionTooltipPulse{0%,to{transform:translate(-50%) translateY(0);box-shadow:0 .75rem 1.4rem #00000042}50%{transform:translate(-50%) translateY(-1px);box-shadow:0 .95rem 1.65rem #0000004d}}.solution-step-instruction{margin:.28rem 0 0;padding-top:.7rem;padding-bottom:.4rem;color:#f3e2bd;font-size:.92rem;font-weight:600;letter-spacing:.01em;text-align:center}.solution-sequence{display:flex;flex-wrap:wrap;justify-content:center;margin-top:.08rem;width:100%;min-height:0;max-height:none;overflow-y:auto;overflow-x:hidden;align-content:flex-start;padding:0 .12rem .05rem 0}.solution-sequence-wrap{display:flex;gap:.25rem;position:relative;margin-top:-.18rem;width:100%;min-height:0;overflow:hidden}.solution-sequence.is-collapsed{overflow-y:auto;overflow-x:hidden}.solution-toggle-icon{width:var(--solution-control-size, 2.5rem);height:var(--solution-control-size, 2.5rem);border:0;border-radius:.7rem;background:#ffffff0a;box-shadow:none;color:var(--accent);cursor:pointer;display:grid;place-items:center;transition:transform .14s ease,background .14s ease,border-color .14s ease,opacity .14s ease}.solution-toggle-icon:hover,.solution-toggle-icon:focus-visible{transform:translateY(-1px);background:#ffffff14;outline:none}.solution-toggle-icon .material-icon{width:1.2rem;height:1.2rem}.solution-toggle-icon svg{width:1.2rem;height:1.2rem;fill:currentColor}.solution-menu-wrap{--solution-control-size: 2.5rem;grid-column:3;position:relative;justify-self:end}.solution-toggle-menu{min-width:15.5rem;z-index:1000;right:0;border-radius:.85rem;border:1px solid rgba(255,255,255,.1);background:#1a120d!important;background-color:#1a120d!important;box-shadow:0 .9rem 1.8rem #0000004d;padding:.25rem;display:grid;gap:.1rem;opacity:1!important;-webkit-backdrop-filter:none!important;backdrop-filter:none!important;background-clip:padding-box!important}.solution-dialog-list{display:flex;flex-wrap:wrap;gap:.7rem}.solution-toggle-menu,.saved-lock-menu,.modal-card{background:#1a120d!important;background-color:#1a120d!important;opacity:1!important;-webkit-backdrop-filter:none!important;backdrop-filter:none!important;background-clip:padding-box!important;pointer-events:auto!important}.solution-toggle-menu .saved-lock-menu-item{background:#1a120d!important;color:var(--text)!important;border-radius:.65rem!important}.solution-menu-wrap{z-index:12;pointer-events:auto}.solution-dialog-list .solution-step{padding:.66rem .9rem;font-size:.95rem}@media (max-width: 640px){.controls-heading.bottom-panel-heading{margin-top:.16rem;grid-template-columns:2.8rem minmax(0,1fr) 2.8rem}.controls-heading.bottom-panel-heading:before{width:2.8rem;height:2.8rem}.solution-progress-nav,.solution-menu-wrap{--solution-control-size: 2.8rem}.solution-progress-nav{gap:.35rem}}.saved-lock-filter{display:inline-flex;align-items:center;gap:.55rem;margin-bottom:.85rem;color:var(--muted);font-size:.82rem;cursor:pointer;-webkit-user-select:none;user-select:none;justify-self:end}.saved-lock-filter input{position:absolute;opacity:0;pointer-events:none}.saved-lock-filter-switch{width:2.2rem;height:1.25rem;border-radius:999px;border:1px solid rgba(255,255,255,.12);background:#ffffff0d;position:relative;transition:background .14s ease,border-color .14s ease}.saved-lock-filter-switch:after{content:"";position:absolute;top:.08rem;left:.1rem;width:.9rem;height:.9rem;border-radius:999px;background:#f4ead8c7;transition:transform .14s ease,background .14s ease}.saved-lock-filter input:checked+.saved-lock-filter-switch{background:#e3a74d33;border-color:#e3a74d80}.saved-lock-filter input:checked+.saved-lock-filter-switch:after{transform:translate(.92rem);background:#f6dfb2}.saved-lock-list{display:grid;gap:.9rem;font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif;overflow:visible;align-content:start}.controls-card--load-screen{padding-top:.95rem;align-content:start;min-height:0;height:100%;display:flex;flex-direction:column;overflow:hidden}.controls-card--load-screen .load-screen-search,.controls-card--load-screen .saved-locks-dialog{width:min(100%,42rem);margin-inline:auto}.controls-card--load-screen .saved-lock-filter{flex:0 0 auto;margin-bottom:.7rem}.controls-card--load-screen .saved-lock-list{flex:1 1 auto;min-height:0;overflow:auto}.load-screen-footer{position:absolute;left:0;right:0;bottom:.55rem;display:flex;justify-content:center;pointer-events:none}.load-screen-delete-drafts{width:auto;min-width:0;padding:.3rem .65rem;font-size:.68rem;line-height:1;min-height:1.55rem;pointer-events:auto}.saved-locks-dialog .saved-lock-list{flex:1 1 auto;min-height:0;overflow:auto}body.is-load-mode .controls-card--load-screen .saved-lock-list{max-height:none;min-height:0;height:auto;overflow:auto;padding-right:.25rem}body.is-load-mode .panel,body.is-load-mode{overflow:hidden}body.is-load-mode .app-shell{height:100vh;height:100svh;height:100dvh;overflow:hidden}body.is-load-mode .panel{min-height:0;height:calc(100dvh - 1.3rem - env(safe-area-inset-bottom,0px))}body.is-load-mode .controls-card--load-screen{height:100%;min-height:0}body.is-resizing .plate-track{transition:none!important}.saved-lock-section{display:grid;gap:.45rem}.saved-lock-section-header{display:flex;align-items:center;gap:.6rem}.saved-lock-section-header:after{content:"";flex:1 1 auto;height:1px;background:#ffffff14}.saved-lock-section-title{margin:0;color:#f4ead8b8;font-size:.76rem;letter-spacing:.08em;text-transform:uppercase}.saved-lock-section-list{display:grid;gap:.55rem}.saved-lock-empty{display:grid;justify-items:center;gap:.7rem;padding:.55rem 0 .2rem}.saved-lock-item{text-align:left;border:1px solid rgba(255,255,255,.08);border-radius:.9rem;background:#ffffff0a;color:var(--text);padding:.35rem;display:grid;grid-template-columns:minmax(0,1fr) auto;gap:.35rem;align-items:start;overflow:visible;transition:transform .14s ease,border-color .14s ease,background .14s ease,box-shadow .14s ease}.saved-lock-item:hover,.saved-lock-item:focus-within{transform:translateY(-1px);border-color:#e3a74d66;background:#e3a74d14;box-shadow:0 .75rem 1.5rem #0000002e}.saved-lock-main{border:0;background:transparent;color:inherit;text-align:left;padding:.35rem .5rem;cursor:pointer;display:grid;gap:.18rem;border-radius:.65rem;min-width:0}.saved-lock-tools{position:relative;overflow:visible}.saved-lock-menu-toggle{position:relative;z-index:1;width:2rem;height:2rem;border:0;border-radius:999px;background:transparent;color:var(--muted);cursor:pointer;display:grid;place-items:center}.saved-lock-menu-toggle:hover,.saved-lock-menu-toggle:focus-visible,.saved-lock-main:focus-visible{background:#ffffff0a;color:var(--text);outline:none}.saved-lock-menu{position:absolute;right:0;top:calc(100% + .2rem);min-width:9.5rem;border-radius:.85rem;border:1px solid rgba(255,255,255,.1);background:#1a120d;box-shadow:0 .9rem 1.8rem #0000004d;padding:.25rem;display:grid;gap:.1rem;z-index:30;opacity:1;-webkit-backdrop-filter:none;backdrop-filter:none;pointer-events:auto}.saved-lock-menu--portal{position:fixed;right:auto;bottom:auto;z-index:1500}.saved-lock-menu.is-upward{top:auto;bottom:calc(100% + .2rem)}.saved-lock-tools{position:relative;z-index:0}.saved-lock-menu-item{border:0;border-radius:.65rem;background:#1a120d;color:var(--text);padding:.55rem .65rem;display:inline-flex;align-items:center;gap:.55rem;cursor:pointer;text-align:left;white-space:nowrap}.saved-lock-menu-item--toggle{width:100%;gap:0}.saved-lock-menu-item-check{width:0;height:1rem;display:inline-grid;place-items:center;flex:0 0 auto;overflow:hidden;color:#f6dfb2}.saved-lock-menu-item-check.is-visible{width:1rem;margin-right:.55rem}.saved-lock-menu-item-check .material-icon{width:.9rem;height:.9rem}.saved-lock-menu-item:hover,.saved-lock-menu-item:focus-visible{background:#ffffff0d;outline:none}.saved-lock-menu-item.is-danger{color:#f0b2a7}.saved-lock-name{font-size:1rem;font-weight:700;letter-spacing:.01em}.saved-lock-name-row{display:flex;align-items:center;justify-content:space-between;gap:.75rem;min-width:0}.saved-lock-meta{color:var(--muted);font-size:.72rem}.saved-lock-description{color:#f4ead8b3;font-size:.8rem;line-height:1.35}.saved-lock-badge{border-radius:999px;border:1px solid rgba(227,167,77,.32);background:#e3a74d1f;color:#f6dfb2;padding:.16rem .48rem;font-size:.66rem;letter-spacing:.08em;text-transform:uppercase}.saved-lock-name{min-width:0;max-width:100%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;flex:1 1 auto}@media (max-width: 640px){.saved-lock-main{padding-right:.35rem}.saved-lock-name-row{gap:.45rem}.saved-lock-badge{flex:0 0 auto}}.wasd-list{display:flex;flex-wrap:wrap;gap:.55rem;margin-top:.85rem}.wasd-chip{display:inline-flex;align-items:center;gap:.42rem;border-radius:999px;border:1px solid rgba(227,167,77,.45);background:#e3a74d1f;color:#f6dfb2;padding:.45rem .75rem;font-size:.82rem}.wasd-chip-key{color:#f6dfb2}.wasd-chip-count{color:#8dc6d6;font-size:.94rem;font-weight:700;letter-spacing:.04em}.lock-stage{position:relative;overflow-x:clip;overflow-y:visible;display:flex;flex-direction:column;align-items:center;justify-content:flex-start;padding:clamp(1.65rem,3vw,2rem) 0 0;background:linear-gradient(180deg,#ffffff05,#00000005),repeating-linear-gradient(90deg,rgba(255,255,255,.012) 0,rgba(255,255,255,.012) 18px,transparent 18px,transparent 36px);border-top:1px solid var(--divider)}.lock-stage.has-bottom-instruction{padding-bottom:3.25rem}.lock-stage.is-setup-mode{padding-top:clamp(2.25rem,4vw,2.75rem)}.lock-stage.is-setup-mode.has-bottom-instruction{padding-bottom:.85rem}.lock-stage.has-stage-controls{padding-top:3.75rem}body.is-linking-mode .lock-stage.has-stage-controls{padding-top:1rem}.lock-stage.is-solution-compact{--stage-height: clamp(8.8rem, 20vh, 10.75rem);--plate-width: clamp(1.75rem, 5.4vw, 2.45rem);--hole-size: clamp(.48rem, 1.35vw, .68rem);--hole-gap: clamp(.3rem, .66vh, .44rem);--plate-padding-x: 1rem;--plate-body-thickness: clamp(2rem, 4.9vw, 2.55rem);--plate-lane-height: max(clamp(2.8rem, 7vw, 3.9rem), calc(var(--plate-body-thickness) + .48rem));padding-top:.28rem;padding-bottom:.12rem}body.is-testing-mode .lock-stage{--hole-size: clamp(.5rem, 1.6vw, .74rem);--hole-gap: clamp(.58rem, 1.35vh, .88rem);--plate-body-thickness: clamp(2.35rem, 5.8vw, 3rem)}.stage-instruction{position:absolute;top:.6rem;left:50%;transform:translate(-50%);min-height:1rem;font-size:.9rem;letter-spacing:.06em;text-transform:uppercase;color:var(--accent);text-align:center;z-index:4;pointer-events:none}.stage-instruction.is-setup-mode{top:.82rem;left:50%;transform:translate(-50%);width:max-content;max-width:calc(100% - 1rem);margin:0;padding:.3rem .6rem;border-radius:999px;background:#17100bd1;border:1px solid rgba(227,167,77,.22);box-shadow:0 .35rem 1rem #0000002e;font-size:1rem;text-transform:none;letter-spacing:.02em}.stage-instruction.is-linking-mode{position:static;top:auto;left:auto;transform:none;width:max-content;max-width:calc(100% - 1rem);margin:0 0 .45rem;padding:.3rem .55rem;border-radius:999px;background:#17100bd1;border:1px solid rgba(227,167,77,.22);box-shadow:0 .35rem 1rem #0000002e}.stage-instruction.is-manual-mode{letter-spacing:.08em}.stage-reset{z-index:4;border-radius:999px;border:1px solid rgba(255,255,255,.1);background:#17100bb8;color:var(--muted);padding:.58rem 1.08rem;font-size:.8rem;cursor:pointer;transition:transform .14s ease,border-color .14s ease,background .14s ease,color .14s ease,box-shadow .14s ease}@keyframes stageResetGlow{0%,to{box-shadow:0 0 #e3a74d47,0 0 .75rem #e3a74d7a}50%{box-shadow:0 0 0 .32rem #e3a74d29,0 0 1.4rem #e3a74dd1}}.stage-reset.is-emphasized{border-color:#ffdc91eb;background:linear-gradient(180deg,#f0b858,#c77b21);color:#21140a;font-weight:700;animation:stageResetGlow 1.25s ease-in-out infinite}.stage-reset.is-emphasized:hover,.stage-reset.is-emphasized:focus-visible{border-color:#ffe0a1;background:linear-gradient(180deg,#ffd27b,#dc9130);color:#180e07;box-shadow:0 0 0 .28rem #e3a74d33,0 0 1.55rem #e3a74de6}@media (prefers-reduced-motion: reduce){.stage-reset.is-emphasized{animation:none;box-shadow:0 0 0 .2rem #e3a74d2e,0 0 1rem #e3a74da6}}.stage-reset-content{display:inline-flex;align-items:center;gap:.38rem}.stage-reset-wrap{position:relative;display:inline-flex;align-items:center}.stage-reset-tooltip{position:absolute;left:50%;bottom:calc(100% + .55rem);transform:translate(-50%);display:inline-flex;align-items:center;gap:.45rem;padding:.42rem .58rem .42rem .68rem;border-radius:.7rem;border:1px solid rgba(227,167,77,.34);background:#1a120dfa;color:#f8e8c8;font-size:.72rem;font-weight:700;letter-spacing:.02em;white-space:nowrap;box-shadow:0 .75rem 1.4rem #00000042;pointer-events:auto;z-index:3;animation:stageResetTooltipPulse 1.2s ease-in-out infinite}.stage-reset-tooltip:after{content:"";position:absolute;left:50%;top:100%;transform:translate(-50%);border-left:.38rem solid transparent;border-right:.38rem solid transparent;border-top:.42rem solid rgba(26,18,13,.98);filter:drop-shadow(0 1px 0 rgba(227,167,77,.28))}.stage-reset-tooltip-copy{display:inline-block}.stage-reset-tooltip-dismiss{flex:none;width:1.35rem;height:1.35rem;border:0;border-radius:999px;background:#ffffff14;color:#f8e8c8;display:grid;place-items:center;cursor:pointer;transition:transform .14s ease,background .14s ease,color .14s ease}.stage-reset-tooltip-dismiss:hover,.stage-reset-tooltip-dismiss:focus-visible{transform:translateY(-1px);background:#ffffff24;color:#fff6df;outline:none}.stage-reset-tooltip-dismiss .material-icon{width:.78rem;height:.78rem}@keyframes stageResetTooltipPulse{0%,to{transform:translate(-50%) translateY(0);box-shadow:0 .75rem 1.4rem #00000042}50%{transform:translate(-50%) translateY(-1px);box-shadow:0 .95rem 1.65rem #0000004d}}.stage-reset .material-icon{width:.92rem;height:.92rem}.stage-reset:hover,.stage-reset:focus-visible{transform:translateY(-1px);border-color:#e3a74d73;background:#2d1e13e6;outline:none}.stage-start-over{z-index:4;border-radius:999px;border:1px solid rgba(255,255,255,.1);background:#17100bb8;color:var(--muted);padding:.42rem .8rem;font-size:.72rem;cursor:pointer;transition:transform .14s ease,border-color .14s ease,background .14s ease}.stage-start-over:hover,.stage-start-over:focus-visible{transform:translateY(-1px);border-color:#e3a74d73;background:#2d1e13e6;outline:none}.stage-manual-linking{z-index:4;border-radius:999px;border:1px solid rgba(255,255,255,.09);background:transparent;color:var(--muted);padding:.5rem .96rem;font-size:.74rem;cursor:pointer;transition:transform .14s ease,border-color .14s ease,background .14s ease}.stage-manual-linking:hover,.stage-manual-linking:focus-visible{transform:translateY(-1px);border-color:#e3a74d3d;background:#ffffff05;outline:none}.plates-row{position:relative;display:grid;gap:clamp(.22rem,.75vw,.38rem);justify-items:center;align-content:center;justify-content:center;flex:1 1 auto;width:100%;max-width:100%;height:auto;min-height:0;margin:0 auto;overflow-x:clip;z-index:1}.plate-column{position:relative;display:grid;grid-template-columns:var(--plate-width) var(--plate-track-width) var(--plate-width);align-items:center;justify-content:center;width:fit-content;max-width:100%}.plate-column.is-solution-labeled{grid-template-columns:auto var(--plate-width) var(--plate-track-width) var(--plate-width);column-gap:.2rem}.plate-column-label{grid-column:1;align-self:center;justify-self:end;min-width:1.55rem;padding-right:0;color:var(--muted);font-size:.72rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase;text-align:right;pointer-events:none}.plate-column-label.is-active{display:inline-grid;place-items:center;width:1.55rem;height:1.55rem;color:#f6dfb2;font-weight:800;padding:0;border-radius:50%;border:1px solid rgba(227,167,77,.6);background:#e3a74d1f;box-shadow:0 0 0 .18rem #e3a74d14,0 0 .8rem #e3a74d33;text-shadow:none}.plate-column .plate-button[data-direction=left]{grid-column:1}.plate-column .plate-viewport{grid-column:2}.plate-column .plate-button[data-direction=right]{grid-column:3}.plate-column.is-solution-labeled .plate-button[data-direction=left]{grid-column:2}.plate-column.is-solution-labeled .plate-viewport{grid-column:3}.plate-column.is-solution-labeled .plate-button[data-direction=right]{grid-column:4}.plate-column.is-driver .plate-body{box-shadow:inset 0 0 0 1px #ffffff14,inset 0 1rem 1.5rem #ffffff14,inset 0 -1rem 1.6rem #00000024,0 0 0 1px #e3a74d73,0 12px 24px #e3a74d29}.plate-column.is-driver-focus .plate-body{box-shadow:inset 0 0 0 1px #ffffff14,inset 0 1rem 1.5rem #ffffff14,inset 0 -1rem 1.6rem #00000024,0 0 0 2px #e3a74de6,0 0 1.1rem #e3a74d52,0 14px 26px #e3a74d33}.plate-column.is-manual-selection{cursor:pointer;-webkit-tap-highlight-color:transparent}.plate-column.is-manual-pick{grid-template-columns:var(--plate-width) var(--plate-track-width) var(--plate-width);column-gap:.2rem}.plate-column.is-manual-define{column-gap:.2rem}.plate-column.is-manual-pick .plate-button[data-direction=left]{grid-column:1}.plate-column.is-manual-pick .plate-viewport{grid-column:2}.plate-column.is-manual-pick .plate-button[data-direction=right]{grid-column:3}.plate-column.is-manual-pick .plate-body{box-shadow:inset 0 0 0 1px #ffffff14,inset 0 1rem 1.5rem #ffffff14,inset 0 -1rem 1.6rem #00000024,0 10px 22px #00000038}.plate-column.is-manual-pick:hover .plate-body,.plate-column.is-manual-pick:focus-visible .plate-body{box-shadow:inset 0 0 0 1px #ffffff14,inset 0 1rem 1.5rem #ffffff14,inset 0 -1rem 1.6rem #00000024,0 10px 22px #00000038}.plate-column.is-manual-driver .plate-body{box-shadow:inset 0 0 0 1px #ffffff14,inset 0 1rem 1.5rem #ffffff14,inset 0 -1rem 1.6rem #00000024,0 0 0 2px #e3a74de6,0 0 1.1rem #e3a74d52,0 14px 26px #e3a74d33}.plate-column.is-manual-selectable:hover .plate-body,.plate-column.is-manual-selectable:focus-visible .plate-body{box-shadow:inset 0 0 0 1px #ffffff14,inset 0 1rem 1.5rem #ffffff14,inset 0 -1rem 1.6rem #00000024,0 0 0 2px #e3a74df2,0 0 1.35rem #e3a74d73,0 14px 26px #e3a74d38}.plate-column.is-manual-completed .plate-body{box-shadow:inset 0 0 0 1px #ffffff14,inset 0 1rem 1.5rem #ffffff14,inset 0 -1rem 1.6rem #00000024,0 0 0 2px #b7d98de6,0 0 1.1rem #b7d98d47,0 12px 24px #b7d98d2e}.plate-column.is-manual-completed:hover .plate-body,.plate-column.is-manual-completed:focus-visible .plate-body{box-shadow:inset 0 0 0 1px #ffffff14,inset 0 1rem 1.5rem #ffffff14,inset 0 -1rem 1.6rem #00000024,0 0 0 2px #b7d98de6,0 0 1.1rem #b7d98d47,0 12px 24px #b7d98d2e}.lock-stage.is-manual-picking .plate-column.is-manual-completed .plate-body,.lock-stage.is-manual-picking .plate-column.is-manual-completed:hover .plate-body,.lock-stage.is-manual-picking .plate-column.is-manual-completed:focus-visible .plate-body{box-shadow:inset 0 0 0 1px #ffffff14,inset 0 1rem 1.5rem #ffffff14,inset 0 -1rem 1.6rem #00000024,0 0 0 2px #b7d98de6,0 0 1.1rem #b7d98d47,0 12px 24px #b7d98d2e}.lock-stage.is-manual-defining .plate-column.is-manual-selectable .plate-body,.lock-stage.is-manual-defining .plate-column.is-manual-selectable:hover .plate-body,.lock-stage.is-manual-defining .plate-column.is-manual-selectable:focus-visible .plate-body{box-shadow:inset 0 0 0 1px #ffffff14,inset 0 1rem 1.5rem #ffffff14,inset 0 -1rem 1.6rem #00000024,0 10px 22px #00000038}.lock-stage.is-manual-defining .plate-column.is-manual-selectable:has(.plate-button:hover) .plate-body,.lock-stage.is-manual-defining .plate-column.is-manual-selectable:has(.plate-button:focus-visible) .plate-body,.lock-stage.is-manual-defining .plate-column.is-manual-selectable:has(.plate-button:active) .plate-body{box-shadow:inset 0 0 0 1px #ffffff14,inset 0 1rem 1.5rem #ffffff14,inset 0 -1rem 1.6rem #00000024,0 10px 22px #00000038}.lock-stage.is-manual-defining .plate-column.is-manual-driver .plate-body,.lock-stage.is-manual-defining .plate-column.is-manual-driver:hover .plate-body,.lock-stage.is-manual-defining .plate-column.is-manual-driver:focus-visible .plate-body{box-shadow:inset 0 0 0 1px #ffffff14,inset 0 1rem 1.5rem #ffffff14,inset 0 -1rem 1.6rem #00000024,0 0 0 2px #e3a74de6,0 0 1.1rem #e3a74d52,0 14px 26px #e3a74d33}.plate-column.is-body-prompt-up .plate-body{animation:nudgeUp 3s ease-in-out infinite}.plate-column.is-body-prompt-down .plate-body{animation:nudgeDown 3s ease-in-out infinite}.plate-column.is-testing-bounce-up .plate-body{animation:testingBounceUp .32s ease-out}.plate-column.is-testing-bounce-down .plate-body{animation:testingBounceDown .32s ease-out}.plate-column.is-testing-blocked .plate-body{animation:testingBlockedShake .36s ease-in-out;box-shadow:inset 0 0 0 1px #ffffff14,inset 0 1rem 1.5rem #ffffff14,inset 0 -1rem 1.6rem #00000024,0 0 0 2px #8dc6d6d1,0 0 1rem #8dc6d657,0 10px 24px #8dc6d638}.plate-column.is-observe-blocked-left .plate-body,.plate-column.is-observe-blocked-right .plate-body{animation:testingBlockedShake .36s ease-in-out}.plate-button{width:var(--plate-width);height:2.25rem;border:1px solid rgba(255,255,255,.12);border-radius:1rem;background:#ffffff0f;color:var(--text);cursor:pointer;display:grid;place-items:center;transition:transform .14s ease,background .14s ease,border-color .14s ease,opacity .14s ease;touch-action:manipulation;-webkit-tap-highlight-color:transparent}.plate-button:hover:not(.is-suggested):not(.is-observed-left):not(.is-observed-right),.plate-button:focus-visible:not(.is-suggested):not(.is-observed-left):not(.is-observed-right){transform:translateY(-1px);background:#ffffff14;border-color:#ffffff2e;outline:none}.lock-stage.is-manual-defining .plate-button:hover:not(.is-suggested):not(.is-observed-left):not(.is-observed-right),.lock-stage.is-manual-defining .plate-button:focus:not(.is-suggested):not(.is-observed-left):not(.is-observed-right),.lock-stage.is-manual-defining .plate-button:focus-visible:not(.is-suggested):not(.is-observed-left):not(.is-observed-right),.lock-stage.is-manual-defining .plate-button:active:not(.is-suggested):not(.is-observed-left):not(.is-observed-right){background:#ffffff0f;border-color:#ffffff1f;box-shadow:none;transform:none;outline:none}.plate-button[disabled]{opacity:.28;cursor:default;transform:none;border-color:#ffffff14;background:#ffffff08}.plate-button.is-suggested[disabled]{opacity:1}.plate-button.is-suggested{border-color:#e3a74dcc;background:#e3a74d24;animation:pulseHint 9s ease-in-out infinite}.plate-button.is-observed-left,.plate-button.is-observed-right{border-color:#e3a74dd1;background:#e3a74d2e;box-shadow:0 0 .95rem #e3a74d3d}.plate-button span{width:.8rem;height:.8rem;border-right:2px solid currentColor;border-bottom:2px solid currentColor}.plate-button[data-direction=left] span{transform:rotate(135deg);margin-left:.15rem}.plate-button[data-direction=right] span{transform:rotate(-45deg);margin-right:.15rem}.plate-viewport{position:relative;width:min(100%,var(--plate-track-width));height:var(--plate-lane-height);overflow:visible;border-radius:1.2rem;cursor:grab;touch-action:none;-webkit-user-select:none;user-select:none}.plate-column.is-manual-selection .plate-viewport{cursor:pointer}.plate-direction-cue{position:absolute;left:50%;top:50%;opacity:0;pointer-events:none;transition:opacity .16s ease;z-index:3}.plate-direction-cue span{display:block;width:clamp(.58rem,calc(var(--plate-width) * .32),.82rem);height:clamp(.58rem,calc(var(--plate-width) * .32),.82rem);border-right:2px solid rgba(227,167,77,.95);border-bottom:2px solid rgba(227,167,77,.95);filter:drop-shadow(0 0 .35rem rgba(227,167,77,.28))}.plate-column.is-prompt-up .plate-direction-cue,.plate-column.is-prompt-down .plate-direction-cue{opacity:1}.plate-column.is-prompt-up .plate-direction-cue{transform:translate(calc(-50% - (var(--plate-body-width) / 2) - 1rem),-50%);animation:cueUp 1.2s ease-in-out infinite}.plate-column.is-prompt-up .plate-direction-cue span{transform:rotate(135deg)}.plate-column.is-prompt-down .plate-direction-cue{transform:translate(calc(-50% + (var(--plate-body-width) / 2) + 1rem),-50%);animation:cueDown 1.2s ease-in-out infinite}.plate-column.is-prompt-down .plate-direction-cue span{transform:rotate(-45deg)}.plate-viewport.is-locked{cursor:default}.plate-status-row{display:flex;align-items:center;justify-content:center;position:absolute;left:calc(-1 * (var(--plate-status-width) + .25rem));top:50%;transform:translateY(-50%);width:var(--plate-status-width);min-height:var(--plate-lane-height);z-index:4}.plate-status{display:inline-flex;align-items:center;justify-content:center;width:1.55rem;height:1.55rem;border-radius:999px;border:1px solid rgba(255,255,255,.1);background:#17100b75;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);box-shadow:inset 0 0 0 1px #ffffff0a;cursor:default}.plate-status:before{content:"";width:.48rem;height:.48rem;border-radius:999px;background:#ffffff2e}.plate-column.is-known .plate-status{border-color:#b7d98d7a;background:#b7d98d2e;box-shadow:inset 0 0 0 1px #ffffff0a,0 0 0 .12rem #b7d98d14}.plate-column.is-known .plate-status:before{width:.66rem;height:.38rem;border-radius:0;background:transparent;border-left:2px solid #f0f7e3;border-bottom:2px solid #f0f7e3;transform:rotate(-45deg) translateY(-.02rem)}.center-band{position:absolute;inset:0 50% 0 auto;transform:translate(50%);display:flex;justify-content:center;align-items:center;pointer-events:none;z-index:2}.center-marker{position:relative;width:calc(var(--hole-size) * 1.15);height:calc(var(--hole-size) * 1.15);display:grid;place-items:center}.center-marker-cap{position:absolute;inset:calc(var(--hole-size) * -.22);border-radius:999px;background:radial-gradient(circle at 35% 35%,#f6d7a2,#d28d39 62%,#7a4817);box-shadow:0 0 0 calc(var(--hole-size) * .12) #e3a74d1f,0 calc(var(--hole-size) * .2) calc(var(--hole-size) * .45) #0000003d}.center-dot{position:relative;width:calc(var(--hole-size) * .42);height:calc(var(--hole-size) * .42);border-radius:999px;border:max(1px,calc(var(--hole-size) * .08)) solid #f6d7a2;background:#3d2b18;box-shadow:inset 0 calc(var(--hole-size) * .08) calc(var(--hole-size) * .18) #00000080}.plate-column.is-aligned .center-marker-cap{background:radial-gradient(circle at 35% 35%,#8b433d,#4f1f1b 62%,#2f0f0c);box-shadow:0 0 0 calc(var(--hole-size) * .12) #bf483d29,0 calc(var(--hole-size) * .2) calc(var(--hole-size) * .45) #0000003d}.plate-column.is-aligned .center-dot{border-color:#f1b0a9;background:#37110d}.plate-track{position:absolute;left:50%;top:50%;height:var(--plate-body-thickness);width:var(--plate-body-width);transform:translate(-50%,-50%);will-change:transform;transition:transform .18s ease}.plate-track.is-initializing{transition:none}.plate-viewport.is-dragging{cursor:grabbing}.plate-viewport.is-dragging .plate-track{transition:none}.plate-body{position:relative;width:var(--plate-body-width);height:100%;display:flex;justify-content:center;align-items:center;padding:0 var(--plate-padding-x);background:var(--plate);border:1px solid rgba(255,255,255,.08);border-radius:1rem;box-shadow:inset 0 0 0 1px #ffffff14,inset 0 1rem 1.5rem #ffffff14,inset 0 -1rem 1.6rem #00000024,0 10px 22px #00000038}.hole-stack{display:flex;gap:var(--hole-gap);align-items:center}.hole{width:var(--hole-size);height:var(--hole-size);border-radius:999px;background:radial-gradient(circle at 35% 35%,#3a2d24,var(--hole) 70%);border:1px solid rgba(255,239,209,.15);box-shadow:inset 0 .12rem .35rem #00000073}.hole.is-center-hole{box-shadow:inset 0 .12rem .35rem #00000073,0 0 0 .16rem #e3a74d38}.plate-column.is-aligned .hole.is-center-hole{background:radial-gradient(circle at 35% 35%,#8b433d,#4f1f1b 72%);border-color:#ffb8b061;box-shadow:inset 0 .12rem .35rem #0000006b,0 0 0 .16rem #bf483d47,0 0 .55rem #bf483d38}.footer-actions{display:flex;justify-content:center;align-items:center;gap:.55rem;padding-top:.9rem;border-top:1px solid var(--divider)}@keyframes testingBounceUp{0%{transform:translate(0)}35%{transform:translate(calc((var(--hole-size) + var(--hole-gap)) * -.45))}to{transform:translate(0)}}@keyframes testingBounceDown{0%{transform:translate(0)}35%{transform:translate(calc((var(--hole-size) + var(--hole-gap)) * .45))}to{transform:translate(0)}}@keyframes testingBlockedShake{0%,to{transform:translate(0)}20%{transform:translate(-.22rem)}40%{transform:translate(.22rem)}60%{transform:translate(-.16rem)}80%{transform:translate(.16rem)}}.footer-actions[data-mode=linking] .action-button,.footer-actions[data-mode=linking] .action-button-row{white-space:nowrap}.footer-actions[data-mode=linking]{flex-wrap:nowrap;margin-top:auto;padding-top:.35rem}.footer-actions[data-mode=linking] .action-button{min-width:0;flex:1 1 0;min-height:3.8rem;display:flex;flex-direction:column;justify-content:center}body.is-linking-mode .panel,body.is-manual-linking-mode .panel{gap:.35rem;padding-bottom:.3rem}body.is-setup-mode .controls-heading{margin-top:.2rem}body.is-setup-mode .count-picker{margin-bottom:.2rem}.stage-inline-actions{display:flex;justify-content:center;gap:.75rem;margin:.6rem 0 0;padding-top:0;flex-wrap:wrap}.stage-inline-actions[data-mode=linking]{width:100%;flex-direction:row;align-items:center;justify-content:center;gap:.7rem;min-height:0;margin-top:.1rem;margin-bottom:.45rem;padding-top:0;padding-bottom:0}.footer-actions[data-mode=solution],.footer-actions[data-mode=ready_to_solve]{flex-wrap:nowrap}.stage-inline-actions .stage-reset{height:2.48rem;padding:0 1.05rem}.stage-inline-actions .stage-manual-linking{height:2.35rem;padding:0 .95rem}.footer-actions[data-mode=solution] .action-button,.footer-actions[data-mode=ready_to_solve] .action-button{min-width:0;flex:1 1 0}.footer-actions[data-mode=solution] .action-button.icon-only{flex:0 0 auto;width:3.05rem;min-width:3.05rem}.admin-shell{align-items:stretch}.admin-panel{display:grid;grid-template-rows:auto 1fr;min-height:calc(100dvh - 1.3rem - env(safe-area-inset-bottom,0px))}.admin-header{position:relative;min-height:3rem;display:grid;align-items:center}.admin-header-title-wrap{display:flex;align-items:center;justify-content:center;min-height:3rem;padding:0 3.4rem}.admin-title{margin:0;color:#f4ead8d1;font-size:1rem;letter-spacing:.04em;text-align:center}.admin-menu-wrap{position:absolute;top:0;right:0}.admin-menu-toggle{width:3rem;height:3rem;border:0;border-radius:999px;background:transparent;color:var(--muted);cursor:pointer;display:grid;place-items:center}.admin-menu-toggle:disabled{cursor:default;opacity:.65}.admin-menu-toggle:hover,.admin-menu-toggle:focus-visible{color:var(--text);background:#ffffff0a;outline:none}.admin-menu-toggle:disabled:hover,.admin-menu-toggle:disabled:focus-visible{color:var(--muted);background:transparent}.admin-menu-toggle .material-icon{width:1.4rem;height:1.4rem}.admin-menu{position:absolute;right:0;top:calc(100% + .2rem);min-width:9rem;border-radius:.85rem;border:1px solid rgba(255,255,255,.1);background:#1a120d;box-shadow:0 .9rem 1.8rem #0000004d;padding:.25rem;display:grid;gap:.1rem;z-index:30}.admin-menu-item{border:0;border-radius:.65rem;background:#1a120d;color:var(--text);padding:.55rem .65rem;display:inline-flex;align-items:center;gap:.55rem;cursor:pointer;text-align:left;white-space:nowrap}.admin-menu-item:hover,.admin-menu-item:focus-visible{background:#ffffff0d;outline:none}.admin-menu-item:disabled{opacity:.65;cursor:default}.admin-status{display:grid;justify-items:center;align-content:center;gap:.8rem;min-height:100%;padding-bottom:3rem}.admin-status-spinner{width:1.9rem;height:1.9rem;border-radius:999px;border:2px solid rgba(244,234,216,.16);border-top-color:var(--accent);animation:admin-spin .7s linear infinite}.admin-status-text{margin:0;color:#f4ead8d6;font-size:.95rem;letter-spacing:.04em}.admin-logout-frame{width:0;height:0;border:0;position:absolute;opacity:0;pointer-events:none}@keyframes admin-spin{to{transform:rotate(360deg)}}html{height:100%}:root{--bg-1: #15110e;--bg-2: #261a12;--panel: rgba(32, 22, 15, .88);--panel-edge: rgba(255, 222, 173, .14);--divider: rgba(227, 167, 77, .18);--plate: linear-gradient(180deg, #a89c80 0%, #7f735b 48%, #5d513f 100%);--hole: #201812;--accent: #e3a74d;--accent-soft: rgba(227, 167, 77, .18);--text: #f4ead8;--muted: #cfbea7;--shadow: 0 24px 60px rgba(0, 0, 0, .35);--link-same: #e3a74d;--link-opposite: #8dc6d6;--link-known: #b7d98d;--stage-height: clamp(17rem, 45vh, 24rem);--plate-width: clamp(2.8rem, 10vw, 4.6rem);--hole-size: clamp(.52rem, 1.7vw, .78rem);--hole-gap: clamp(.62rem, 1.45vh, .94rem);--plate-padding-x: 1.28rem;--plate-padding-y: .8rem;--travel-steps: 3;--plate-body-height: calc((7 * var(--hole-size)) + (6 * var(--hole-gap)) + (2 * var(--plate-padding-x)));--travel-distance: calc(var(--travel-steps) * (var(--hole-size) + var(--hole-gap)));--plate-overflow-space: max(0px, calc(var(--travel-distance) - ((var(--stage-height) - var(--plate-body-height)) / 2)));--plate-lane-length: clamp(15rem, 54vw, 24rem);--plate-lane-height: max(clamp(3.15rem, 9vw, 4.7rem), calc(var(--plate-body-thickness) + .62rem));--plate-body-width: calc((7 * var(--hole-size)) + (6 * var(--hole-gap)) + (2 * var(--plate-padding-x)));--plate-body-thickness: clamp(2.45rem, 6vw, 3.15rem);--plate-status-width: 1.7rem;--plate-side-gap: clamp(.7rem, 1.8vw, 1rem);--plate-track-width: calc(var(--plate-body-width) + (2 * var(--travel-distance)) + .9rem)}*{box-sizing:border-box}[hidden]{display:none!important}body{margin:0;min-height:100vh;min-height:100svh;min-height:100dvh;overflow-x:hidden;overflow-y:auto;font-family:Georgia,Times New Roman,serif;color:var(--text);background:radial-gradient(circle at top,rgba(227,167,77,.16),transparent 30%),linear-gradient(180deg,var(--bg-1),var(--bg-2))}button{font:inherit;-webkit-tap-highlight-color:transparent;touch-action:manipulation;-webkit-appearance:none;-moz-appearance:none;appearance:none}button.is-touch-pressed{transform:translateY(1px) scale(.985)}.app-shell{min-height:100vh;min-height:100svh;min-height:100dvh;display:flex;justify-content:center;align-items:flex-start;padding:.65rem .65rem calc(.65rem + env(safe-area-inset-bottom,0px));overflow-x:hidden}.panel{width:min(72rem,100%);min-height:calc(100dvh - 1.3rem - env(safe-area-inset-bottom,0px));background:var(--panel);border:1px solid var(--panel-edge);border-radius:1.5rem;box-shadow:var(--shadow);padding:.75rem .85rem .85rem;-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);display:grid;grid-template-rows:auto auto minmax(0,1fr) auto auto;gap:.65rem;overflow-x:hidden;overflow-y:auto}.hero{position:relative;padding:.25rem 2.4rem .45rem;text-align:center;min-height:2rem;display:flex;align-items:center;justify-content:center}.hero-title{color:#f4ead899;margin:0;font-size:.62rem;letter-spacing:.1em;text-transform:none;line-height:1.05;white-space:nowrap;display:block;flex:1 1 auto;min-width:0;max-width:calc(100vw - 7.4rem)}.hero-title-line{display:inline}.hero-title-line--accent{font-size:1em;color:#f4ead8d1}.hero-back{position:absolute;left:0;top:50%;transform:translateY(-50%);width:3rem;height:3rem;border:0;border-radius:999px;background:transparent;color:var(--muted);cursor:pointer;display:grid;place-items:center}.hero-back:before{content:"";position:absolute;top:.5rem;right:.5rem;bottom:.5rem;left:.5rem;border-radius:999px}.hero-back span{width:.6rem;height:.6rem;border-left:2px solid currentColor;border-bottom:2px solid currentColor;transform:rotate(45deg)}.hero-back:hover,.hero-back:focus-visible{color:var(--text);background:#ffffff0a;outline:none}.hero-back.is-touch-pressed{transform:translateY(-50%) scale(.985)}.app-version{position:absolute;top:50%;right:0;transform:translateY(-50%);color:#f4ead899;font-size:.62rem;letter-spacing:.1em;text-transform:uppercase}.hero-menu-wrap{position:absolute;top:50%;right:0;transform:translateY(-50%);z-index:1000;pointer-events:auto}.hero-menu-wrap--load{display:flex;align-items:center;gap:.35rem}.hero-filter-wrap{position:relative}.hero-menu{min-width:11.5rem;right:0}.controls-card{padding:.8rem 0 0;display:grid;grid-template-rows:minmax(0,1fr) auto;gap:.55rem;position:relative;border-top:1px solid var(--divider)}.controls-card--load-screen{padding-top:.95rem;padding-bottom:2.7rem;align-content:start;min-height:0;height:100%;display:flex;flex-direction:column;overflow:hidden}.saved-locks-dialog{flex:1 1 auto;min-height:0;display:flex;flex-direction:column}.load-screen-search{display:flex;align-items:center;gap:.6rem;padding-bottom:.3rem}.load-screen-search-field{position:relative;flex:1 1 auto;display:flex;align-items:center}.load-screen-search-input{padding-left:.85rem;padding-right:.85rem}.load-screen-search-clear{border:0;width:1.9rem;height:1.9rem;border-radius:999px;background:transparent;color:var(--muted);display:grid;place-items:center;cursor:pointer}.load-screen-search-clear:hover,.load-screen-search-clear:focus-visible{color:var(--text);background:#ffffff0d;outline:none}.load-screen-search-clear .material-icon{width:1rem;height:1rem}.controls-card--import-screen{padding-top:.95rem;align-content:start;min-height:0}.controls-heading{display:flex;justify-content:center;align-items:center}.import-notation-actions{display:flex;justify-content:center;align-items:center;gap:.55rem;flex-wrap:nowrap}.import-notation-actions .action-button{flex:1 1 0;width:auto;min-width:0;max-width:none}.controls-title{margin:0;font-size:.82rem;letter-spacing:.08em;text-transform:uppercase;color:var(--muted)}.controls-title.is-solution{font-size:1rem;letter-spacing:.12em;color:var(--text);text-transform:none}.controls-step{display:none}.controls-copy{margin:0;font-size:.95rem;line-height:1.45;text-align:center}.controls-note{margin:0;color:var(--muted);font-size:.78rem;line-height:1.45}.controls-actions{display:flex;justify-content:flex-end}.menu-actions{display:grid;gap:.65rem;width:100%;max-width:22rem}.menu-actions-wrap{display:flex;align-items:flex-start;justify-content:center;flex:1 1 auto;min-height:0;padding-top:1.5rem}body.is-menu-mode .menu-actions{justify-items:center}body.is-menu-mode .menu-actions .action-button{width:min(100%,22rem);min-width:min(22rem,100%);max-width:22rem}.menu-actions .action-button:first-child{margin-top:.55rem}.menu-footer-links{display:flex;justify-content:center;align-items:end;margin-top:auto;padding:.2rem 0 .05rem}.menu-footer-link{border:1px solid rgba(244,234,216,.18);background:transparent;border-radius:999px;color:#f4ead89e;cursor:pointer;font:inherit;font-size:.85rem;letter-spacing:.02em;padding:.4rem .85rem;transition:color .14s ease,opacity .14s ease,transform .14s ease}.menu-footer-link:hover,.menu-footer-link:focus-visible{color:#f4ead8db;border-color:#f4ead84d;outline:none;transform:translateY(-1px)}.import-notation-field{display:grid;gap:.45rem}.import-notation-input{width:100%;min-height:13rem;resize:vertical;border:1px solid rgba(255,255,255,.12);border-radius:.85rem;background:#ffffff0a;color:var(--text);font:inherit;padding:.75rem .85rem;margin-bottom:1rem;line-height:1.45}.import-notation-input:focus-visible{outline:none;border-color:#e3a74d8c;background:#e3a74d14}.import-notation-actions{grid-template-columns:repeat(2,minmax(0,1fr))}.import-notation-error{text-align:center}body.is-menu-mode .hero{padding-top:.7rem;padding-bottom:1rem}body.is-menu-mode .hero-title{color:var(--text);font-size:clamp(1.28rem,3.95vw,1.82rem);letter-spacing:.06em}body.is-menu-mode .hero-title-line--accent{font-size:.96em;color:#f6dfb2}body.is-menu-mode .hero-title-line{display:block}body.is-menu-mode .hero-title-line:first-child{font-size:.62em;color:#f4ead8a8;margin-bottom:.22rem}body.is-setup-mode .hero-title,body.is-linking-mode .hero-title,body.is-solution-mode .hero-title{color:#f4ead8d1;font-size:1rem;letter-spacing:.04em;overflow:hidden;text-overflow:ellipsis}body.is-manual-linking-mode .hero-title{color:#f4ead8eb;font-size:1rem;letter-spacing:.06em}body.is-load-mode .hero-title,body.is-import-mode .hero-title{color:var(--text);font-size:1.2rem;letter-spacing:.08em}body.is-menu-mode .controls-card{padding-top:.15rem;height:100%;display:flex;flex-direction:column;overflow:hidden}body.is-menu-mode .panel{overflow:hidden;grid-template-rows:auto minmax(0,1fr)}body.is-load-mode .panel{grid-template-rows:auto minmax(0,1fr)}body.is-solution-mode{overflow:hidden}body.is-solution-mode .panel{height:calc(100dvh - 1.3rem - env(safe-area-inset-bottom,0px));overflow:hidden;grid-template-rows:auto auto minmax(0,1fr) auto}body.is-load-mode .controls-card--load-screen{border-top:1px solid var(--divider);display:grid;grid-template-rows:auto minmax(0,1fr);min-height:0}.count-picker,.solution-sequence{display:flex;flex-wrap:wrap;gap:.55rem;justify-content:center}.count-button,.progress-pill{min-width:3rem;border:1px solid rgba(255,255,255,.12);border-radius:999px;background:#ffffff0a;color:var(--text);padding:.5rem .8rem;transition:transform .14s ease,border-color .14s ease,background .14s ease}.count-button{cursor:pointer;width:min(100%,4.5rem);max-width:4.5rem}.count-button:hover,.count-button:focus-visible,.count-button.is-active{transform:translateY(-1px);border-color:var(--accent);background:var(--accent-soft);outline:none}.solution-step{min-width:auto;padding:.52rem .78rem;border-radius:.6rem;border:1px solid rgba(255,255,255,.08);background:#ffffff08;color:var(--muted);font-size:.92rem;display:inline-flex;align-items:center;gap:.5rem;cursor:pointer;white-space:nowrap}.solution-step.is-current{border-color:#e3a74df2;background:#e3a74d1f;color:#f6dfb2;text-shadow:0 0 .4rem rgba(227,167,77,.22)}.solution-step.is-done{border-color:#b7d98dcc;background:#b7d98d1a;color:#eef8dc;text-shadow:0 0 .35rem rgba(183,217,141,.12)}.solution-step-label{display:inline-flex;align-items:center;gap:.35rem}.solution-step .material-icon{width:.95rem;height:.95rem}.action-button{width:min(100%,16rem);min-width:min(16rem,100%);max-width:16rem;border-radius:999px;padding:.72rem 1.2rem;cursor:pointer;transition:transform .14s ease,background .14s ease,border-color .14s ease,opacity .14s ease}.manual-linking-reset-wrap{display:flex;justify-content:center;align-items:center}.manual-linking-bottom-actions{display:flex;flex-direction:column;align-items:center;align-self:stretch;width:100%;margin-top:auto;padding-bottom:1rem}.manual-linking-bottom-actions .footer-actions[data-mode=manual_linking]{width:min(100%,22rem);justify-content:center;flex-wrap:nowrap;align-self:center}.manual-linking-bottom-actions .footer-actions[data-mode=manual_linking] .action-button{min-width:0;width:auto;flex:1 1 0}.manual-linking-bottom-actions .footer-actions[data-mode=manual_linking] .action-button.primary{max-width:none;min-height:3.8rem;display:flex;flex-direction:column;justify-content:center}.manual-linking-bottom-actions .footer-actions[data-mode=manual_linking] .action-button.secondary{min-height:3.8rem;display:flex;flex-direction:column;justify-content:center}.manual-linking-reset-wrap .action-button{display:inline-flex;align-items:center;justify-content:center;width:auto;min-width:0;max-width:none;height:auto;padding:.42rem .78rem;font-size:.76rem;line-height:1;flex:0 0 auto}.manual-linking-reset-wrap{margin:.45rem 0 .9rem}.manual-linking-reset-wrap .action-button-row{gap:.32rem}.manual-linking-reset-wrap .material-icon{width:.9rem;height:.9rem}.action-button-row{display:inline-flex;align-items:center;justify-content:center;gap:.45rem}.material-icon{width:1rem;height:1rem;display:inline-flex;flex:0 0 auto}.material-icon svg{width:100%;height:100%;fill:currentColor}.saved-lock-menu-toggle .material-icon{width:1.1rem;height:1.1rem}.action-icon{width:.6rem;height:.6rem;border-right:2px solid currentColor;border-bottom:2px solid currentColor;display:inline-block}.action-icon.is-left{transform:rotate(135deg)}.action-icon.is-right{transform:rotate(-45deg)}.action-icon.is-edit,.action-icon.is-save,.action-icon.is-reset{width:.85rem;height:.85rem;border-right:0;border-bottom:0;position:relative}.action-icon.is-edit:before,.action-icon.is-edit:after,.action-icon.is-save:before,.action-icon.is-save:after,.action-icon.is-reset:before,.action-icon.is-reset:after{content:"";position:absolute}.action-icon.is-edit:before{top:.12rem;right:.18rem;bottom:.2rem;left:.1rem;border-right:2px solid currentColor;border-bottom:2px solid currentColor;transform:rotate(-45deg)}.action-icon.is-edit:after{right:.05rem;top:.05rem;width:.22rem;height:.22rem;background:currentColor;transform:rotate(-45deg)}.action-icon.is-save:before{top:.08rem;right:.08rem;bottom:.08rem;left:.08rem;border:2px solid currentColor;border-radius:.1rem}.action-icon.is-save:after{left:.22rem;right:.22rem;top:.16rem;height:.16rem;background:currentColor;box-shadow:0 .28rem #0000,0 .42rem 0 -.04rem currentColor}.action-icon.is-reset:before,.action-icon.is-reset:after{left:.41rem;top:.12rem;bottom:.12rem;width:2px;background:currentColor}.action-icon.is-reset:before{transform:rotate(45deg) translate(-.08rem)}.action-icon.is-reset:after{transform:rotate(-45deg) translate(.08rem)}.action-button-subtitle{display:block;margin-top:.12rem;font-size:.68em;font-weight:400;letter-spacing:.02em;opacity:.82;line-height:1.05}.action-button:hover,.action-button:focus-visible{transform:translateY(-1px);outline:none}.action-button[disabled],.action-button.is-disabled{opacity:.4;cursor:default;transform:none}.action-button.primary{border:1px solid rgba(227,167,77,.5);background:linear-gradient(180deg,#e3a74d3d,#e3a74d1f);color:var(--text)}.action-button.solve{border:1px solid rgba(183,217,141,.6);background:linear-gradient(180deg,#b7d98d4d,#6e924933);color:#f1f7e3}.action-button.secondary{border:1px solid rgba(255,255,255,.1);background:#ffffff0a;color:var(--muted)}.action-button.compact{width:auto;max-width:none;min-width:auto;padding:.46rem .85rem;font-size:.78rem}.action-button.tertiary{width:auto;max-width:none;min-width:auto;border:1px solid rgba(255,255,255,.1);background:#ffffff0a;color:var(--muted);padding:.48rem .9rem}.action-button.icon-only{min-width:0;width:3rem;max-width:3rem;height:3rem;padding:0;display:grid;place-items:center}.action-button.icon-only .material-icon{width:1.3rem;height:1.3rem}@keyframes pulseHint{0%,to{transform:translateY(0);box-shadow:0 0 #e3a74d00}50%{transform:translateY(-1px);box-shadow:0 0 .9rem #e3a74d38}}@keyframes nudgeUp{0%,40%{transform:translate(0)}60%,93%{transform:translate(calc(-1 * (var(--hole-size) + var(--hole-gap))))}to{transform:translate(0)}}@keyframes nudgeDown{0%,40%{transform:translate(0)}60%,93%{transform:translate(calc(var(--hole-size) + var(--hole-gap)))}to{transform:translate(0)}}@keyframes cueUp{0%,to{transform:translate(calc(-50% - (var(--plate-body-width) / 2) - 1rem),-50%)}50%{transform:translate(calc(-50% - (var(--plate-body-width) / 2) - 1.35rem),-50%)}}@keyframes cueDown{0%,to{transform:translate(calc(-50% + (var(--plate-body-width) / 2) + 1rem),-50%)}50%{transform:translate(calc(-50% + (var(--plate-body-width) / 2) + 1.35rem),-50%)}}@media (max-width: 640px){:root{--stage-height: clamp(13rem, 34dvh, 16.5rem);--hole-gap: clamp(.52rem, 1.15dvh, .76rem)}.panel{min-height:calc(100dvh - 1.3rem - env(safe-area-inset-bottom,0px));padding:.65rem .7rem .8rem;background:transparent;border:0;border-radius:0;box-shadow:none;-webkit-backdrop-filter:none;backdrop-filter:none}.app-shell{padding:.4rem .55rem calc(1rem + env(safe-area-inset-bottom,0px))}.controls-card{padding-top:.7rem}.count-picker{flex-wrap:nowrap;gap:.4rem}.count-button{flex:1 1 0;width:auto;min-width:0;max-width:none;padding-left:.45rem;padding-right:.45rem}.lock-stage{padding-top:1.55rem}.lock-stage.is-solution-compact{--stage-height: clamp(8.2rem, 19dvh, 10.2rem);--plate-width: clamp(1.42rem, 6.2vw, 1.76rem);--hole-size: clamp(.37rem, 1.2vw, .52rem);--hole-gap: clamp(.22rem, .5vh, .28rem);--plate-padding-x: .64rem;--plate-body-thickness: clamp(1.78rem, 5.8vw, 2.22rem);--plate-lane-height: max(clamp(2.38rem, 7.7vw, 3.08rem), calc(var(--plate-body-thickness) + .4rem));padding-top:.72rem}.plates-row{gap:.06rem;width:100%}.plate-button{height:2.35rem;border-radius:.9rem;width:clamp(2.3rem,7vw,2.8rem)}.plate-column .plate-button[data-direction=left]{margin-right:-0rem}.plate-column .plate-button[data-direction=right]{margin-left:0rem}.stage-inline-actions{margin-top:.45rem}.stage-inline-actions[data-mode=linking]{width:100%;max-width:100%;align-self:stretch}.app-version,.hero-title{font-size:.56rem}body.is-setup-mode .hero-title,body.is-linking-mode .hero-title,body.is-solution-mode .hero-title{font-size:.98rem}body.is-menu-mode .hero-title{font-size:clamp(1.15rem,5.3vw,1.62rem)}.footer-actions{flex-wrap:wrap}.action-button{min-width:100%}.action-button.compact,.action-button.tertiary{min-width:auto}.bottom-panel-actions--separate,.solution-progress-nav{gap:.35rem}.solution-nav-button{width:2.8rem;height:2.8rem}.bottom-panel-actions--separate .action-button.tertiary{flex:0 0 auto;padding:0}.bottom-panel-actions--separate .action-button-row{gap:.28rem}.bottom-panel-actions--separate .action-button.icon-only{width:2.85rem;height:2.85rem}.bottom-panel-actions--separate .action-button.icon-only .material-icon{width:1.2rem;height:1.2rem}.footer-actions[data-count="2"]{flex-wrap:nowrap}.footer-actions[data-count="2"] .action-button{min-width:0;flex:1 1 0}.footer-actions[data-count="3"]{flex-wrap:nowrap}.footer-actions[data-count="3"] .action-button{min-width:0;flex:1 1 0}.footer-actions[data-count="3"] .action-button.icon-only{flex:0 0 auto;width:3.05rem;min-width:3.05rem}.footer-actions[data-mode=linking]{flex-wrap:nowrap}.footer-actions[data-mode=linking] .action-button{min-width:0;flex:1 1 0}.manual-linking-bottom-actions .footer-actions[data-mode=manual_linking]{width:min(100%,22rem)}.manual-linking-bottom-actions .footer-actions[data-mode=manual_linking] .action-button{min-width:0}.footer-actions[data-mode=solution],.footer-actions[data-mode=ready_to_solve]{flex-wrap:nowrap}.footer-actions[data-mode=solution] .action-button,.footer-actions[data-mode=ready_to_solve] .action-button{min-width:0;flex:1 1 0}}@media (display-mode: standalone),(display-mode: fullscreen){html,body{height:100dvh;overflow:hidden}.app-shell{min-height:100dvh;height:100dvh;padding-bottom:calc(.65rem + env(safe-area-inset-bottom,0px));overflow:hidden}.panel{min-height:calc(100dvh - 1.3rem - env(safe-area-inset-bottom,0px));height:calc(100dvh - 1.3rem - env(safe-area-inset-bottom,0px));overflow:hidden}}@media (display-mode: standalone) and (max-width: 640px),(display-mode: fullscreen) and (max-width: 640px){.app-shell{padding:.4rem .55rem calc(.75rem + env(safe-area-inset-bottom,0px))}.panel{min-height:calc(100dvh - 1.15rem - env(safe-area-inset-bottom,0px));height:calc(100dvh - 1.15rem - env(safe-area-inset-bottom,0px))}}
