:root{--fp-purple:#a373f8;--fp-purple-deep:#5d2da8;--fp-black:#000;--fp-dark:#1c1429;--fp-dark-2:#120c1c;--fp-white:#fff;--fp-ink:#ece9f5;--fp-dim:#9b93b3;--fp-border:#ffffff26;--fp-border-soft:#ffffff14;--fp-glass:#ffffff0d;--font-head:"Clash Display", system-ui, sans-serif;--font-body:"Satoshi", system-ui, sans-serif;--font-accent:"Panchang", system-ui, sans-serif;--radius:14px;--radius-sm:8px}*{box-sizing:border-box}html,body,#root{height:100%}body{background:radial-gradient(1100px 620px at 72% -8%, #241a3a 0%, #241a3a00 55%), radial-gradient(900px 500px at 12% 108%, #1a1230 0%, #1a123000 50%), var(--fp-black);color:var(--fp-ink);font-family:var(--font-body);-webkit-font-smoothing:antialiased;margin:0}h1,h2,h3,h4{font-family:var(--font-head);letter-spacing:-.01em;margin:0;font-weight:500}button{font-family:var(--font-body);cursor:pointer}.fp-accent{font-family:var(--font-accent);text-transform:uppercase;letter-spacing:.06em}.glass{background:var(--fp-glass);border:1px solid var(--fp-border-soft);border-radius:var(--radius);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}::-webkit-scrollbar{width:10px;height:10px}::-webkit-scrollbar-thumb{background:#a373f84d;border-radius:8px}.module{border:1px solid var(--fp-border-soft);border-radius:var(--radius);background:linear-gradient(#1c1429eb,#120c1ceb);flex-direction:column;min-height:0;padding:9px 12px 11px;display:flex;overflow:hidden;box-shadow:inset 0 1px #ffffff08,0 8px 24px #00000059}.module--placeholder{opacity:.45;border-style:dashed}.module-head{border-bottom:1px solid var(--fp-border-soft);justify-content:space-between;align-items:center;margin-bottom:8px;padding-bottom:6px;display:flex}.module-title{color:var(--fp-purple);letter-spacing:.1em;font-size:11px;line-height:1}.module-body{flex:1;min-height:0;display:flex}.knob{-webkit-user-select:none;user-select:none;flex-direction:column;align-items:center;gap:3px;display:flex}.knob svg{cursor:ns-resize;touch-action:none;display:block}.knob svg:focus-visible{outline:2px solid var(--fp-purple);outline-offset:4px;border-radius:50%}.knob-target{stroke:#58d99c6b}.knob-modulation{stroke:var(--fp-purple);opacity:.62;pointer-events:none}.knob-modulation--env-1{stroke:#e7b46a}.knob-modulation--env-2{stroke:#62d6a8}.knob-modulation--lfo-1{stroke:#a373f8}.knob-modulation--velocity{stroke:#ef8bab}.knob-modulation.selected{opacity:1;pointer-events:stroke;cursor:ns-resize}.knob-modulation-hit{pointer-events:stroke;cursor:ns-resize}.knob-modulation.bypassed{opacity:.2;stroke-dasharray:.015 .018!important}.knob--assignable{position:relative}.knob--assignable:before{content:"";border:1px dashed color-mix(in srgb, var(--fp-purple) 42%, transparent);pointer-events:none;opacity:.5;border-radius:50%;position:absolute;inset:-3px 1px 25px}.knob-assign{border:1px solid color-mix(in srgb, var(--fp-purple) 42%, transparent);width:17px;height:17px;color:var(--fp-purple);font:700 12px/1 var(--font-body);opacity:.72;background:#0b0812;border-radius:50%;place-items:center;padding:0;display:grid;position:absolute;top:-1px;right:-1px}.knob-assign:hover,.knob-assign:focus-visible{border-color:var(--fp-purple);color:var(--fp-text);opacity:1}.knob--correct .knob-value{color:#70d6aa}.knob--close .knob-value{color:#f2c66d}.knob--off .knob-value{color:#f28a9b}.knob-label{font-family:var(--font-body);color:var(--fp-dim);text-align:center;letter-spacing:.01em;font-size:10px;font-weight:600;line-height:1.1}.knob-value{color:var(--fp-purple);font-variant-numeric:tabular-nums;text-align:center;white-space:nowrap;font-size:10px}.knob-slot{height:79px}.param-select{gap:5px;min-width:0;display:grid}.param-select__label{color:var(--fp-dim);letter-spacing:.1em;text-transform:uppercase;font-size:9px}.param-select__options{gap:3px;min-width:0;display:flex}.param-select__options button{border:1px solid var(--fp-border-soft);min-width:0;color:var(--fp-dim);font:inherit;cursor:pointer;background:#08060ebf;border-radius:6px;padding:5px 7px;font-size:9px;line-height:1}.param-select__options button:hover,.param-select__options button:focus-visible{color:var(--fp-text);border-color:#a373f88c}.param-select__options button.active{border-color:var(--fp-purple);color:#fff;background:#a373f82e}.switch{border:1px solid var(--fp-border);background:#ffffff0f;border-radius:10px;width:34px;height:18px;padding:0;transition:all .15s;position:relative}.switch--on{background:var(--fp-purple);border-color:#0000}.switch-knob{background:#fff;border-radius:50%;width:14px;height:14px;transition:all .15s;position:absolute;top:1px;left:1px}.switch--on .switch-knob{left:17px}.knob-row{flex-wrap:wrap;align-items:flex-start;gap:13px;width:100%;display:flex}.filter-layout,.env-layout{align-items:flex-start;gap:13px;width:100%;display:flex}.filter-type{flex:none}.filter-type .param-select__options button{width:28px;height:22px;padding:0}.osc-layout{flex-direction:column;gap:7px;width:100%;display:flex}.osc-knobs{flex-wrap:nowrap;gap:5px}.wt-wrap{width:100%}.wt-display{border:1px solid var(--fp-border-soft);background:linear-gradient(#0c0916,#070510);border-radius:8px;width:100%;height:48px;display:block}.wt-caption{color:var(--fp-dim);text-align:center;margin-top:4px;font-size:10px}.osc-shape .param-select__options{gap:2px}.osc-shape .param-select__options button{flex:1 1 0;padding-inline:3px;font-size:8px}.adsr{border:1px solid var(--fp-border-soft);background:linear-gradient(#0c0916,#070510);border-radius:8px;flex-shrink:0;width:116px;height:80px;display:block}.env-layout .knob-row{flex-wrap:nowrap;gap:6px}.source-stack{gap:8px;width:100%;display:grid}.source-row{grid-template-columns:minmax(72px,1fr) auto auto;align-items:start;gap:8px;display:grid}.source-row__head{color:var(--fp-text);letter-spacing:.06em;text-transform:uppercase;justify-content:space-between;align-items:center;gap:8px;padding-top:4px;font-size:10px;font-weight:650;display:flex}.source-row--noise{border-top:1px solid var(--fp-border-soft);padding-top:7px}.lfo-layout{grid-template-columns:minmax(110px,1fr) auto;align-items:start;gap:12px;width:100%;display:grid}.lfo-display{border:1px solid var(--fp-border-soft);background:linear-gradient(#0c0916,#070510);border-radius:8px;width:100%;height:64px}.lfo-visual{gap:7px;min-width:0;display:grid}.lfo-visual .param-select__options button{flex:1 1 0;padding-inline:4px}.compact-knobs{flex-wrap:nowrap;gap:7px}.mod-matrix{--matrix-columns:minmax(112px, .85fr) 86px minmax(100px, .7fr) minmax(142px, 1.15fr) minmax(160px, 1.2fr) 34px 28px;gap:7px;width:100%;display:grid;container-type:inline-size}.mod-matrix__head,.mod-matrix__row{grid-template-columns:var(--matrix-columns);align-items:center;gap:8px;display:grid}.mod-matrix__head{color:var(--fp-dim);letter-spacing:.09em;text-transform:uppercase;padding:0 8px 2px;font-size:8px;font-weight:700}.mod-matrix__rows{gap:5px;display:grid}.mod-matrix__row{--route-color:var(--fp-purple);border:1px solid var(--fp-border-soft);background:color-mix(in srgb, var(--route-color) 4%, #07050cb8);border-radius:8px;min-height:46px;padding:6px 8px;position:relative}.mod-matrix__row--env-1{--route-color:#e7b46a}.mod-matrix__row--env-2{--route-color:#62d6a8}.mod-matrix__row--lfo-1{--route-color:#a373f8}.mod-matrix__row--velocity{--route-color:#ef8bab}.mod-matrix__row.unsupported{opacity:.7;padding-bottom:24px}.mod-matrix select{border:1px solid color-mix(in srgb, var(--route-color) 32%, var(--fp-border-soft));width:100%;min-width:0;height:30px;color:var(--fp-text);font:600 10px/1 var(--font-body);text-overflow:ellipsis;background:#0b0812;border-radius:6px;padding:0 25px 0 9px}.mod-matrix select:focus-visible,.mod-matrix button:focus-visible,.mod-matrix input:focus-visible{outline:2px solid var(--route-color,var(--fp-purple));outline-offset:2px}.polarity{border:1px solid var(--fp-border-soft);min-height:30px;color:var(--fp-dim);font:650 9px/1 var(--font-body);background:#0b0812;border-radius:6px;justify-content:center;align-items:center;gap:4px;padding:0 7px;display:inline-flex}.polarity span{color:var(--route-color);font-size:12px}.polarity.bipolar{border-color:color-mix(in srgb, var(--route-color) 55%, transparent);color:var(--fp-text)}.mod-slider{grid-template-columns:minmax(50px,1fr) 38px;align-items:center;gap:6px;min-width:0;display:grid}.mod-slider input{width:100%;min-width:0;accent-color:var(--route-color)}.mod-slider output{color:var(--route-color);font-variant-numeric:tabular-nums;text-align:right;font-size:9px}.route-bypass,.route-remove{border:1px solid var(--fp-border-soft);width:28px;height:28px;color:var(--fp-dim);background:#0b0812;border-radius:50%;place-items:center;padding:0;display:grid}.route-bypass span{background:var(--route-color);width:10px;height:10px;box-shadow:0 0 0 3px color-mix(in srgb, var(--route-color) 15%, transparent);border-radius:50%}.route-bypass.bypassed span{box-shadow:none;background:#5d5668}.route-remove{font-size:17px;line-height:1}.route-remove:hover{color:#ef8bab;border-color:#ef8bab}.mod-matrix__empty{border:1px dashed var(--fp-border-soft);min-height:46px;color:var(--fp-dim);border-radius:8px;align-items:baseline;gap:8px;padding:12px 14px;font-size:10px;display:flex}.mod-matrix__empty strong{color:var(--fp-text)}.add-route{border:1px solid color-mix(in srgb, var(--fp-purple) 42%, transparent);background:color-mix(in srgb, var(--fp-purple) 9%, transparent);min-height:30px;color:var(--fp-text);font:650 10px/1 var(--font-body);border-radius:6px;justify-self:start;align-items:center;gap:6px;padding:0 11px;display:inline-flex}.add-route span{color:var(--fp-purple);font-size:15px}.add-route:hover{background:color-mix(in srgb, var(--fp-purple) 17%, transparent)}.mod-matrix__mobile-label{display:none}.route-compatibility{color:#d7b66f;font-size:8px;position:absolute;bottom:5px;left:8px}.effects-grid{grid-template-columns:repeat(4,minmax(0,1fr));gap:8px;width:100%;display:grid}.effect-strip{border:1px solid var(--fp-border-soft);background:#07050c7a;border-radius:9px;grid-template-columns:minmax(74px,1fr) auto;align-items:start;gap:8px;padding:8px 9px;display:grid}.effect-strip header{color:var(--fp-text);letter-spacing:.06em;text-transform:uppercase;gap:8px;font-size:10px;font-weight:650;display:grid}@media (width<=920px){.effects-grid{grid-template-columns:1fr 1fr}}@media (width<=620px){.lfo-layout,.effects-grid{grid-template-columns:1fr}}@container (width<=760px){.mod-matrix__head{display:none}.mod-matrix__row{grid-template-columns:1fr 1fr;gap:9px;padding:10px}.mod-matrix__row>label,.mod-slider{grid-template-columns:1fr;gap:4px;display:grid}.mod-matrix__mobile-label{color:var(--fp-dim);letter-spacing:.08em;text-transform:uppercase;font-size:8px;font-weight:700;display:block}.route-bypass,.route-remove{place-self:end start}.mod-matrix__empty{flex-direction:column;align-items:flex-start}}.mod-source{--source-color:var(--fp-purple);border:1px solid color-mix(in srgb, var(--source-color) 48%, transparent);background:color-mix(in srgb, var(--source-color) 9%, #0b0712);min-height:24px;color:color-mix(in srgb, var(--source-color) 76%, #f4effc);font:700 9px/1 var(--font-body);letter-spacing:.06em;cursor:grab;touch-action:manipulation;border-radius:999px;align-items:center;gap:5px;padding:3px 8px 3px 5px;display:inline-flex}.mod-source:active{cursor:grabbing}.mod-source:hover,.mod-source.selected{border-color:var(--source-color);background:color-mix(in srgb, var(--source-color) 20%, #0b0712);color:#f5efff}.mod-source:focus-visible{outline:2px solid var(--source-color);outline-offset:2px}.mod-source__grip{opacity:.7;font-size:11px}.mod-source--env-1{--source-color:#e7b46a}.mod-source--env-2{--source-color:#62d6a8}.mod-source--lfo-1{--source-color:#a373f8}.mod-source--velocity{--source-color:#ef8bab}.panel{grid-template-columns:repeat(12,minmax(0,1fr));grid-template-areas:"osc1 osc1 osc1 osc1 osc2 osc2 osc2 osc2 osc3 osc3 osc3 osc3""sub sub sub sub filter1 filter1 filter1 filter1 filter2 filter2 filter2 filter2""env1 env1 env1 env1 env2 env2 env2 env2 lfo lfo lfo lfo""modmatrix modmatrix modmatrix modmatrix modmatrix modmatrix modmatrix modmatrix modmatrix modmatrix modmatrix modmatrix""fx fx fx fx fx fx fx fx fx fx fx fx";grid-auto-rows:minmax(156px,auto);gap:10px;width:100%;max-width:1180px;margin:0 auto;display:grid}.panel--lesson{align-items:stretch;gap:10px;display:flex}.panel--lesson>*{flex:1 1 0;min-height:148px;grid-area:auto!important}.panel--lesson>:only-child{flex:0 580px}.panel--lesson .module{border-radius:10px;padding:8px 10px 10px}.panel--lesson .module-head{margin-bottom:7px;padding-bottom:6px}@media (width<=920px){.panel{grid-template:none/repeat(2,1fr);grid-auto-rows:auto}.panel>*{grid-area:auto!important}.panel>.module--modmatrix,.panel>.module--fx{grid-column:1/-1!important}}@media (width<=620px){.panel{grid-template-columns:1fr}.panel--lesson{flex-direction:column}}.keyboard{-webkit-user-select:none;user-select:none;touch-action:none;gap:2px;width:100%;max-width:1180px;height:48px;margin:0 auto;display:flex;position:relative}.wkey{cursor:pointer;background:linear-gradient(#efeaf7 0%,#cfc7e2 100%);border:1px solid #b4abce;border-radius:0 0 4px 4px;flex:1}.wkey.down{background:linear-gradient(180deg, #c9aefb, var(--fp-purple))}.bkey{width:calc(100% / var(--white-count) * .62);cursor:pointer;z-index:2;background:linear-gradient(#3a3350,#1b1530);border:1px solid #0e0a18;border-radius:0 0 4px 4px;height:30px;position:absolute;top:0}.bkey.down{background:linear-gradient(#a274f0,#6d28d9)}.output-meter{color:#817493;flex:none;align-items:center;gap:7px;display:flex}.output-meter__title{font-family:var(--font-accent);letter-spacing:.12em;text-transform:uppercase;font-size:8px;font-weight:700}.output-meter__channels{gap:3px;display:grid}.output-meter__channel{grid-template-columns:7px 64px;align-items:center;gap:4px;font-size:7px;font-weight:750;line-height:1;display:grid}.output-meter__track{background:repeating-linear-gradient(90deg,#0000 0 5px,#100b17 5px 7px),#2d2638;border-radius:1px;height:4px;overflow:hidden}.output-meter__level{--output-level:0;width:100%;height:100%;transform:scaleX(var(--output-level));transform-origin:0;will-change:transform;background:repeating-linear-gradient(90deg,#0000 0 5px,#100b17 5px 7px),linear-gradient(90deg,#5ecf98 0 76%,#e0bd63 76% 91%,#e57984 91%)}@media (width<=700px){.output-meter__title{display:none}.output-meter__channel{grid-template-columns:7px 44px}}.patch-tools{border:1px solid var(--fp-border-soft);background:#0d0913;border-radius:8px;width:100%;max-width:1180px}.patch-tools summary{color:var(--fp-dim);cursor:pointer;justify-content:space-between;align-items:center;gap:16px;padding:9px 11px;font-size:10px;list-style:none;display:flex}.patch-tools summary::-webkit-details-marker{display:none}.patch-tools summary:after{content:"+";color:var(--fp-purple);font-size:16px}.patch-tools[open] summary:after{content:"−"}.patch-tools__body{border-top:1px solid var(--fp-border-soft);gap:10px;padding:10px;display:grid}.patch-meta{grid-template-columns:1.2fr 1fr 1.5fr auto;align-items:end;gap:8px;display:grid}.patch-meta label{gap:5px;min-width:0;display:grid}.patch-meta label>span{color:var(--fp-dim);letter-spacing:.09em;text-transform:uppercase;font-size:9px}.patch-meta input{border:1px solid var(--fp-border-soft);width:100%;min-width:0;color:var(--fp-ink);font:11px var(--font-body);background:#15101d;border-radius:5px;outline:none;padding:7px 8px}.patch-meta input:focus{border-color:var(--fp-purple)}.patch-file-actions{gap:6px;display:flex}.patch-file-actions button,.wavetable-loader__action{border:1px solid var(--fp-border);color:var(--fp-ink);font:700 10px var(--font-body);white-space:nowrap;background:#1b1425;border-radius:5px;padding:7px 9px}.patch-file-actions button.primary{border-color:var(--fp-purple);background:var(--fp-purple);color:#160d22}.wavetable-loaders{grid-template-columns:repeat(3,minmax(0,1fr));gap:7px;display:grid}.wavetable-loader{border:1px solid var(--fp-border-soft);cursor:pointer;border-radius:6px;grid-template-columns:auto minmax(0,1fr) auto;align-items:center;gap:9px;padding:7px 8px;display:grid}.wavetable-loader:hover{border-color:#a373f880}.wavetable-loader__number{color:var(--fp-purple);font:650 9px var(--font-accent)}.wavetable-loader__name{color:var(--fp-dim);text-overflow:ellipsis;white-space:nowrap;font-size:10px;overflow:hidden}.wavetable-loader__action{padding-block:5px}.patch-notice{color:#b9a6d3;font-size:10px}.visually-hidden{clip:rect(0, 0, 0, 0)!important;white-space:nowrap!important;border:0!important;width:1px!important;height:1px!important;margin:-1px!important;padding:0!important;position:absolute!important;overflow:hidden!important}@media (width<=800px){.patch-meta{grid-template-columns:1fr 1fr}.patch-meta__comments,.patch-file-actions{grid-column:1/-1}.wavetable-loaders{grid-template-columns:1fr}}.app{flex-direction:column;min-height:100%;padding:10px clamp(14px,3vw,32px) 20px;display:flex;position:relative}.app--locked>.app-head,.app--locked>.stage,.app--locked>.loading{opacity:.46;filter:saturate(.45);pointer-events:none;-webkit-user-select:none;user-select:none}.app-head,.stage,.loading{transition:opacity .18s ease-out,filter .18s ease-out}.start-gate{z-index:20;background:#040207d1;justify-content:center;align-items:flex-start;padding:clamp(28px,6vh,72px) clamp(16px,4vw,48px) 32px;display:flex;position:absolute;inset:0;overflow-y:auto}.start-prompt{width:min(820px,100%);color:var(--fp-ink);background:#0d0913;border:1px solid #a373f85c;border-radius:10px;overflow:hidden;box-shadow:0 24px 80px #000000ad}.start-prompt__masthead{border-bottom:1px solid var(--fp-border-soft);justify-content:space-between;align-items:center;gap:16px;padding:14px clamp(20px,4vw,40px);display:flex}.start-prompt__product{color:var(--fp-purple);font:600 22px/1 var(--font-head);letter-spacing:-.025em}.start-prompt__part{color:#9589aa;font:700 10px/1.2 var(--font-accent);letter-spacing:.12em;text-transform:uppercase;text-align:right}.start-prompt__body{grid-template-columns:minmax(0,1.2fr) minmax(240px,.8fr);gap:clamp(28px,5vw,56px);padding:clamp(32px,6vw,60px) clamp(20px,5vw,48px);display:grid}.start-prompt__intro{text-align:left}.start-prompt__eyebrow{color:var(--fp-purple);font:700 10px/1.2 var(--font-accent);letter-spacing:.15em;text-transform:uppercase;margin-bottom:14px}.start-prompt h1{color:#f6f2fc;max-width:12ch;font:500 clamp(36px, 5.4vw, 58px)/.98 var(--font-head);letter-spacing:-.035em}.start-prompt__lead{color:#bcb3cc;max-width:47ch;margin-top:22px;font-size:16px;line-height:1.6}.start-prompt__outcomes{text-align:left;align-self:end;padding-top:6px}.start-prompt__outcomes-title{color:#e9e4f2;font-size:13px;font-weight:700;line-height:1.4}.start-prompt__outcomes ul{border-top:1px solid var(--fp-border-soft);gap:0;margin:12px 0 0;padding:0;list-style:none;display:grid}.start-prompt__outcomes li{color:#bcb3cc;border-bottom:1px solid var(--fp-border-soft);grid-template-columns:30px 1fr;gap:10px;padding:13px 0;font-size:14px;line-height:1.4;display:grid}.start-prompt__outcomes li span{color:var(--fp-purple);font:700 9px/1.5 var(--font-accent);letter-spacing:.08em}.start-prompt__action{text-align:left;background:#a373f80e;border-top:1px solid #a373f82e;justify-content:space-between;align-items:center;gap:24px;padding:18px clamp(20px,5vw,48px);display:flex}.start-prompt__action p{color:#e9e4f2;font-size:14px;font-weight:650}.start-prompt__action small{color:#8f849f;margin-top:2px;font-size:12px;display:block}.start-prompt__error{color:#fda4af;text-align:left;background:#be185d1a;border-top:1px solid #fb71853d;padding:11px clamp(20px,5vw,48px);font-size:13px;line-height:1.45}.start-session-btn{color:#160d22;background:var(--fp-purple);border:1px solid var(--fp-purple);white-space:nowrap;border-radius:5px;min-width:174px;min-height:44px;padding:11px 18px;font-size:15px;font-weight:750;transition:transform .15s ease-out,background .15s ease-out,border-color .15s ease-out}.start-session-btn:hover:not(:disabled){background:#b58df9;border-color:#b58df9;transform:translateY(-1px)}.start-session-btn:active:not(:disabled){transform:translateY(0)}.start-session-btn:focus-visible{outline-offset:3px;outline:2px solid #fff}.start-session-btn:disabled{opacity:.62;cursor:wait}.app-head{justify-content:space-between;align-items:center;gap:20px;width:100%;max-width:1180px;margin:0 auto 8px;display:flex}.primer-wordmark{color:var(--fp-purple);font:600 24px/1 var(--font-head);letter-spacing:-.025em;flex:none}.app-head__output{align-items:center;gap:12px;display:flex}.futureproof-logo{object-fit:contain;mix-blend-mode:screen;flex:0 0 30px;width:30px;height:30px;display:block}.feedback-button{width:30px;height:30px;color:var(--fp-ink);border:1px solid var(--fp-border-soft);background:#ffffff0f;border-radius:50%;flex:0 0 30px;justify-content:center;align-items:center;margin-left:auto;text-decoration:none;transition:transform .16s,background .16s,border-color .16s,color .16s;display:inline-flex}.feedback-button:hover{color:#fff;background:#a373f824;border-color:#a373f86b;transform:translateY(-1px)}.feedback-button:focus-visible{outline:2px solid var(--fp-purple);outline-offset:3px}.feedback-button:active{transform:translateY(0)}.loading{color:var(--fp-dim);text-align:center;padding:60px}.stage{flex-direction:column;align-items:center;gap:8px;width:100%;display:flex}.lesson-nav{flex-wrap:wrap;flex:auto;align-items:center;gap:6px;display:flex}.lesson-nav__step{width:26px;height:26px;color:var(--fp-dim);border:1px solid var(--fp-border-soft);background:0 0;border-radius:5px;justify-content:center;align-items:center;font-size:18px;transition:all .15s;display:inline-flex}.lesson-nav__step:not(:disabled):hover{color:var(--fp-ink);border-color:#a373f89e}.lesson-nav__step:disabled{opacity:.35;cursor:default}.lesson-nav__current{cursor:pointer;text-align:left;background:0 0;border:0;flex-direction:column;align-items:flex-start;gap:1px;padding:2px 6px;display:flex}.lesson-nav__module{color:#fff;letter-spacing:-.01em;font-size:15px;font-weight:650}.lesson-nav__pos{color:var(--fp-dim);letter-spacing:.1em;text-transform:uppercase;font-size:11px;font-weight:600}.lesson-nav__lessons{color:var(--fp-dim);border:1px solid var(--fp-border-soft);background:0 0;border-radius:5px;padding:6px 10px;font-size:14px;font-weight:650;transition:all .15s}.lesson-nav__lessons:hover{color:var(--fp-ink);border-color:#a373f89e}.lesson-drawer{border:1px solid var(--fp-border-soft);background:#a373f80d;border-radius:8px;grid-template-columns:repeat(auto-fill,minmax(190px,1fr));gap:14px 18px;width:100%;margin-top:8px;padding:14px 16px;display:grid}.lesson-drawer__group{flex-direction:column;gap:3px;display:flex}.lesson-drawer__head{color:var(--fp-purple);letter-spacing:.14em;text-transform:uppercase;margin-bottom:3px;font-size:11px;font-weight:700}.lesson-drawer__item{color:var(--fp-dim);text-align:left;background:0 0;border:0;border-radius:5px;justify-content:space-between;align-items:center;gap:8px;padding:5px 8px;font-size:15px;font-weight:600;transition:all .12s;display:flex}.lesson-drawer__item:hover{color:var(--fp-ink);background:#a373f814}.lesson-drawer__item.active{color:#fff;background:#a373f829}.lesson-drawer__item.solved:not(.active){color:#80d6b1}.lesson-head{text-align:left;justify-content:space-between;align-items:center;gap:20px;width:100%;max-width:1180px;padding:2px 0 3px;display:flex}.lesson-head:not(.lesson-head--sandbox){border:1px solid var(--fp-border-soft);background:#a373f806;border-radius:8px;grid-template-columns:minmax(0,1fr) auto;gap:0 20px;padding:14px 16px 16px;display:grid}.lesson-head:not(.lesson-head--sandbox) .blurb{grid-column:1}.lesson-head:not(.lesson-head--sandbox) .lesson-meta{grid-area:1/2/span 2;align-self:start}.lesson-title-block{flex:none}.lesson-kicker{color:var(--fp-purple);font-family:var(--font-accent);letter-spacing:.14em;text-transform:uppercase;margin-bottom:3px;font-size:12px;font-weight:650}.lesson-head h1{letter-spacing:-.035em;font-size:clamp(30px,3.6vw,40px);line-height:1}.blurb{color:var(--fp-dim);text-align:left;max-width:680px;margin-top:5px;font-size:16px;line-height:1.35}.lesson-head--sandbox{align-items:flex-end;padding-block:1px 2px}.lesson-head--sandbox .blurb{text-align:right;max-width:520px;margin:0 0 2px auto}.lesson-meta{color:var(--fp-purple);letter-spacing:.16em;flex-direction:column;align-items:flex-end;display:flex}.lesson-meta small{color:var(--fp-dim);letter-spacing:.06em;text-transform:uppercase;margin-top:4px;font-size:11px}.listen-bar{background:#171021;border:1px solid #a373f842;border-radius:7px;justify-content:space-between;align-items:center;gap:18px;width:100%;max-width:1180px;padding:8px 10px;display:flex}.listen-copy,.success-copy{text-align:left;align-items:center;gap:9px;display:flex}.listen-copy p,.success-copy p,.check-prompt{flex-direction:column;gap:2px;display:flex}.listen-copy strong,.success-copy strong,.check-prompt strong{color:var(--fp-ink);font-size:16px}.listen-copy p span,.success-copy p span,.check-prompt span{color:var(--fp-dim);font-size:14px}.listen-step,.result-icon{color:#160d22;background:var(--fp-purple);width:30px;height:25px;font:750 11px var(--font-body);border-radius:4px;flex:none;place-items:center;display:grid}.listen-actions,.result-actions{align-items:center;gap:8px;display:flex}.audition-btn,.check-btn,.text-btn{border:1px solid var(--fp-border);border-radius:5px;padding:7px 11px;font-size:14px;font-weight:700}.audition-btn{color:var(--fp-ink);background:#241a30;align-items:center;gap:8px;display:inline-flex}.audition-btn.target{color:#160d22;background:var(--fp-purple);border-color:var(--fp-purple)}.audition-btn:disabled{opacity:.45;cursor:not-allowed}.audition-btn kbd{min-width:18px;font:750 11px/1 var(--font-body);text-align:center;opacity:.72;border:1px solid;border-radius:3px;padding:2px 4px}.scaffold-note{color:#b9a6d3;text-align:left;width:100%;max-width:1180px;padding:0 2px;font-size:14px}.result-panel{border:1px solid var(--fp-border-soft);background:#100b17;border-radius:7px;justify-content:space-between;align-items:center;gap:16px;width:100%;max-width:1180px;min-height:50px;padding:8px 11px;display:flex}.result-panel.success{background:#235d4329;border-color:#50ca916b}.result-main{flex:1}.result-icon{color:#091810;background:#70d6aa}.grade-list{flex-wrap:wrap;gap:7px;display:flex}.grade-chip{border:1px solid var(--fp-border-soft);border-radius:5px;gap:8px;padding:7px 9px;font-size:14px;display:flex}.grade-chip span{color:var(--fp-dim)}.grade-chip.correct strong{color:#70d6aa}.grade-chip.close strong{color:#f2c66d}.grade-chip.off strong{color:#f28a9b}.text-btn{color:var(--fp-dim);background:0 0;border-color:#0000}.check-btn{color:#160d22;background:var(--fp-purple);border-color:var(--fp-purple)}.detection-btn{min-width:88px;color:var(--fp-ink);border:1px solid var(--fp-border);background:#241a30;border-radius:5px;padding:7px 12px;font-size:14px;font-weight:700}.detection-btn:hover,.detection-btn:focus-visible{color:#fff;border-color:#a373f89e}.detection-btn:disabled{opacity:.45;cursor:not-allowed}.lesson-media{border:1px solid var(--fp-border-soft);background:#100b17;border-radius:7px;width:100%;max-width:1180px;overflow:hidden}.lesson-media video{width:100%;max-height:66vh;display:block}.hint{color:var(--fp-dim);margin-top:0;font-size:12px}.err{color:#fb7185;font-size:15px}.app-footer{color:#756c89;text-align:center;margin-top:200px;font-size:11px;line-height:1.35}.app-footer a{color:#9b88bd;text-underline-offset:2px}@media (width<=700px){.start-gate{padding:16px 12px 24px}.start-prompt__masthead{align-items:flex-start}.start-prompt__part{max-width:21ch}.start-prompt__body{grid-template-columns:1fr;gap:30px;padding-top:36px;padding-bottom:32px}.start-prompt h1{max-width:10ch;font-size:clamp(36px,12vw,48px)}.start-prompt__lead{margin-top:18px}.start-prompt__outcomes{padding-top:0}.start-prompt__action{flex-direction:column;align-items:stretch;gap:16px}.start-session-btn{width:100%}.app-head{align-items:flex-start}.primer-wordmark{padding-top:5px}.lesson-head,.listen-bar,.result-panel{flex-direction:column;align-items:flex-start}.lesson-head:not(.lesson-head--sandbox){gap:20px;display:flex}.lesson-head--sandbox .blurb{text-align:left;margin-left:0}.lesson-meta{align-items:flex-start}.listen-actions,.result-actions{width:100%}.audition-btn,.check-btn{flex:1}}html.primer-embedded,html.primer-embedded body,html.primer-embedded #root{height:auto;min-height:0}html.primer-embedded .app{min-height:0}.explainer{color:var(--fp-ink);opacity:.93;grid-column:1;max-width:680px;margin-top:7px;font-size:16px;line-height:1.45}.module-intro{border:1px solid #a373f838;border-left:2px solid var(--fp-purple);background:#a373f80f;border-radius:6px;grid-column:1;max-width:680px;margin-top:9px;padding:9px 12px}.module-intro__eyebrow{color:var(--fp-purple);font-family:var(--font-accent);letter-spacing:.14em;text-transform:uppercase;margin-bottom:3px;font-size:11px;font-weight:700}.module-intro__body{color:var(--fp-ink);font-size:16px;line-height:1.45}
