:root{--white: #F7F6F2;--black: #0A0A0A;--gray: #AAAAAA;--gray-lt: #E4E3DF;--gray-md: #CCCCCA;--accent: #D4000F;--mono: "Manrope", sans-serif;--sans: "Manrope", sans-serif;--topbar-h: 56px;--browser-h: 260px;--controls-w: 460px;--pad-gap: 3px;--fam-retro: #0e0e14;--fam-noise: #1a1a1a;--fam-geo: #e8e7e3;--fam-organic: #0d1f0e;--fam-distort: #150d1f;--fam-digital: #0a1a0e;--fam-motion: #0d1220;--fam-special: #1f1500}[data-theme=dark]{--white: #0D0D0B;--black: #EEEEE8;--gray: #666;--gray-lt: #1E1E1B;--gray-md: #2E2E2B}[data-theme=dark] .pad-num{color:#666}[data-theme=dark] .knob-ring:after{background:var(--black)}[data-theme=dark] .shader-item{border-color:#333}[data-theme=dark] .kit-card{background:#1a1a18;border-color:#333;color:#e8e8e2}[data-theme=dark] .kit-card-user{background:#141412}[data-theme=dark] #ftu-box{background:var(--white);border-color:#333}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html,body{height:100%;background:var(--white);color:var(--black);font-family:var(--mono);font-size:11px;text-transform:lowercase;overflow:hidden;-webkit-font-smoothing:antialiased}button{cursor:pointer;font-family:var(--mono);font-size:11px;text-transform:lowercase}input,select{font-family:var(--mono);font-size:11px;text-transform:lowercase}#pad-videos{position:fixed;width:1px;height:1px;opacity:0;pointer-events:none;overflow:hidden}#app{display:grid;grid-template-rows:var(--topbar-h) 1fr var(--browser-h);height:100vh;height:100dvh;padding-top:env(safe-area-inset-top,0px);padding-bottom:env(safe-area-inset-bottom,0px)}#topbar{display:flex;align-items:center;justify-content:space-between;padding:0 14px;border-bottom:1px solid var(--black);background:var(--white);gap:12px;flex-shrink:0}#brand{font-family:var(--sans);font-weight:700;font-size:20px;letter-spacing:-.03em;white-space:nowrap;display:flex;flex-direction:column;gap:2px;line-height:1}#brand-sub{font-family:var(--mono);font-weight:500;font-size:10px;color:var(--gray);letter-spacing:.08em}#topbar-center{display:flex;align-items:center;gap:10px;flex:1}.status-dot{font-size:10px;color:var(--gray);white-space:nowrap}.status-dot.connected{color:var(--black)}.btn-icon{background:none;border:none;padding:0 6px;color:var(--black);font-size:16px;line-height:1}.btn-icon:hover{opacity:.4}#midi-source,#audio-source{border:1px solid var(--gray-md);background:var(--white);padding:4px 6px;max-width:160px;color:var(--black);font-size:12px}#midi-source{border-color:var(--black)}#topbar-right{display:flex;align-items:center;gap:10px}#set-controls{display:flex;gap:4px}#set-controls .btn-text{font-size:10px;padding:4px 8px}.btn-text{background:none;border:1px solid var(--black);padding:5px 12px;color:var(--black);font-size:12px}.btn-text:hover{background:var(--black);color:var(--white)}.btn-text.recording{background:var(--accent);border-color:var(--accent);color:var(--white)}#rec-timer{font-size:10px;color:var(--accent)}#tap-btn{padding:4px 8px;font-size:10px}#tap-btn.active{background:var(--black);color:var(--white)}#bpm-display{font-size:10px;color:var(--gray);white-space:nowrap;min-width:44px;letter-spacing:.04em}#bpm-display.live{color:var(--black)}#lang-toggle{display:flex;border:1px solid var(--black)}.lang-btn{background:none;border:none;padding:5px 8px;color:var(--gray);font-size:12px}.lang-btn.active{background:var(--black);color:var(--white)}.lang-btn:not(.active):hover{color:var(--black)}#main{display:grid;grid-template-columns:minmax(0,1fr) var(--controls-w);overflow:hidden;min-height:0}#monitor-wrap{position:relative;background:#000;overflow:hidden}#hydra-canvas{width:100%;height:100%;display:block}#patch-label{position:absolute;bottom:10px;left:12px;font-size:9px;color:#ffffff40;letter-spacing:.12em;pointer-events:none}#rec-indicator{position:absolute;top:10px;right:12px;width:6px;height:6px;border-radius:50%;background:var(--accent);opacity:0}#rec-indicator.active{opacity:1;animation:blink 1s step-end infinite}@keyframes blink{50%{opacity:0}}#cut-flash{position:absolute;top:0;right:0;bottom:0;left:0;background:#000;opacity:0;pointer-events:none;z-index:3;transition:opacity .12s ease-out}#fullscreen-btn{position:absolute;bottom:8px;right:8px;z-index:10;background:#00000059;border:1px solid rgba(255,255,255,.2);color:#ffffff80;font-size:13px;width:24px;height:24px;display:flex;align-items:center;justify-content:center;cursor:pointer;padding:0;border-radius:2px;transition:background .1s,color .1s}#fullscreen-btn:hover{background:#000000b3;color:#ffffffe6}#controls{display:flex;flex-direction:column;background:var(--white);border-left:1px solid var(--black);overflow:hidden}#knobs{display:flex;justify-content:space-around;align-items:center;padding:10px 8px 8px;border-bottom:1px solid var(--gray-lt);flex-shrink:0}.knob-col{display:flex;flex-direction:column;align-items:center;gap:4px}.knob-ring{width:44px;height:44px;border:2px solid var(--black);border-radius:50%;display:flex;align-items:center;justify-content:center;position:relative;background:var(--white);cursor:ns-resize;touch-action:none;-webkit-user-select:none;user-select:none}.knob-ring.dragging{border-color:var(--accent)}.knob-ring:after{content:"";position:absolute;top:5px;left:50%;width:2px;height:8px;background:var(--black);transform-origin:bottom center;transform:translate(-50%) rotate(calc((var(--v, .5) * 270deg) - 135deg))}.knob-lbl{font-size:8px;color:var(--black);letter-spacing:.04em;text-align:center;max-width:60px;line-height:1.2}.knob-cc{font-size:7px;color:#999;letter-spacing:.04em;cursor:pointer;-webkit-user-select:none;user-select:none;transition:color .1s}.knob-cc:hover{color:#555}.knob-cc.learning{color:var(--accent);animation:blink .5s step-end infinite}#fx-toggle-col{margin-left:4px}.fx-toggle-btn{width:44px;height:44px;border:2px solid #bbb;border-radius:50%;background:var(--white);color:#aaa;font-size:9px;font-family:var(--mono);letter-spacing:.08em;cursor:pointer;transition:background .1s,color .1s,border-color .1s}.fx-toggle-btn.active{background:var(--black);border-color:var(--black);color:var(--white)}.fx-toggle-btn:hover:not(.active){border-color:#666;color:#333}#banks-section{display:flex;align-items:center;gap:8px;padding:6px 10px;border-bottom:1px solid var(--gray-lt);flex-shrink:0}#banks-label{font-size:9px;color:#444;letter-spacing:.08em;flex-shrink:0;width:34px}#banks-btns{display:grid;grid-template-columns:repeat(10,1fr);gap:2px;flex:1}.bank-btn{background:none;border:1px solid #bbb;font-size:9px;padding:3px 0;color:#444;cursor:pointer;text-align:center;font-family:var(--mono);text-transform:lowercase}.bank-btn:hover{border-color:var(--black);color:var(--black)}.bank-btn.active{background:var(--black);border-color:var(--black);color:var(--white)}#fill-btn{background:none;border:1px solid #bbb;color:#444;font-size:13px;padding:2px 5px;cursor:pointer;line-height:1;flex-shrink:0}#fill-btn:hover{border-color:var(--black);color:var(--black)}.bank-btn.has-content{border-color:#555;color:#222;font-weight:700}.pad,.shader-item,.media-item,.kit-card,.bank-btn,.tab,.btn-text,.btn-icon,.lang-btn,#tap-btn,#fill-btn,#fx-toggle{touch-action:manipulation}#pad-grid{display:grid;grid-template-columns:repeat(4,1fr);grid-template-rows:repeat(4,1fr);gap:var(--pad-gap);padding:var(--pad-gap);width:100%;aspect-ratio:1;flex-shrink:0}.pad{position:relative;border:1px solid var(--black);background:var(--white);cursor:pointer;overflow:hidden;transition:outline .05s;display:flex;flex-direction:column;justify-content:flex-end;padding:4px}.pad:active{background:#00000026}.pad.active{outline:2px solid var(--black);outline-offset:-2px}.pad.assign-selected{outline:2px solid var(--accent);outline-offset:-2px}.pad.assign-selected:after{content:"●";position:absolute;top:3px;right:4px;font-size:7px;color:var(--accent)}.pad.drag-over{outline:2px solid var(--accent);outline-offset:-2px}.pad.has-shader .pad-num{color:#ffffffa6}.pad.has-shader .pad-label{color:#ffffffe6}.pad.has-media .pad-label{color:var(--black);font-size:7px}.pad.has-broken{border-color:#c0392b!important;background:#1a0808!important}.pad.has-broken .pad-num{color:#ff7878b3}.pad.has-broken .pad-label{color:#e07070;font-size:7px}.pad-num{position:absolute;top:4px;left:5px;font-size:8px;color:#333;line-height:1;z-index:2;text-shadow:0 0 3px rgba(255,255,255,.8)}.pad-label{position:relative;z-index:2;font-size:8px;color:var(--black);line-height:1.2;word-break:break-word;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:100%}.pad-thumb{position:absolute;top:0;right:0;bottom:0;left:0;background-size:cover;background-position:center;pointer-events:none;z-index:1;opacity:0}.pad.has-media .pad-thumb{opacity:.75}.pad.has-shader .pad-thumb{opacity:.5}#browser{border-top:1px solid var(--black);display:flex;flex-direction:column;overflow:hidden;background:var(--white);flex-shrink:0}#browser-tabs{display:flex;align-items:center;border-bottom:1px solid var(--black);flex-shrink:0;height:28px}.tab{background:none;border:none;border-right:1px solid var(--black);padding:0 14px;height:100%;color:var(--gray);font-size:10px;white-space:nowrap}.tab.active{background:var(--black);color:var(--white)}.tab:not(.active):hover{color:var(--black);background:var(--gray-lt)}#assign-hint{margin-left:12px;font-size:9px;color:var(--accent);flex:1}#selected-pad-label{margin-left:auto;margin-right:12px;font-size:9px;color:var(--gray)}.tab-panel{display:none;flex:1;overflow:hidden;min-height:0}.tab-panel.active{display:flex}#shaders-panel{flex-direction:row}#shaders-grid{flex:1;display:flex;flex-wrap:wrap;align-content:flex-start;overflow-y:auto;padding:4px;gap:2px}.shader-item{width:68px;height:68px;border:1px solid var(--gray-md);cursor:pointer;overflow:hidden;flex-shrink:0;position:relative;background-size:cover;background-position:center;background-color:#111;transition:border-color .05s}.shader-item:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(to top,rgba(0,0,0,.88) 0%,transparent 55%);z-index:1;pointer-events:none}.shader-item:hover{border-color:var(--black)}.shader-item:hover:before{background:linear-gradient(to top,#000000e6,#00000059)}.shader-item.selected{border-color:var(--accent)}.shader-item.selected:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;border:2px solid var(--accent);pointer-events:none;z-index:3}.shader-name{position:absolute;bottom:4px;left:5px;right:5px;z-index:2;font-size:9px;color:#fff;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.shader-family{position:absolute;top:4px;left:5px;z-index:2;font-size:7px;color:#ffffff80}#files-panel{flex-direction:row;gap:0;align-items:stretch}#files-left{width:130px;flex-shrink:0;border-right:1px solid var(--black);display:flex;flex-direction:column;padding:8px;gap:6px;justify-content:center}#drop-zone{border:1px dashed var(--black);padding:10px 8px;font-size:9px;color:var(--gray);cursor:pointer;text-align:center;line-height:1.4}#drop-zone:hover{background:var(--gray-lt);color:var(--black)}#files-grid{flex:1;display:flex;flex-wrap:wrap;gap:3px;overflow-y:auto;padding:6px;align-content:flex-start}#giphy-panel{flex-direction:row}#giphy-left{width:130px;flex-shrink:0;border-right:1px solid var(--black);display:flex;flex-direction:column;justify-content:center;padding:8px;gap:6px}#giphy-input{border:1px solid var(--black);background:var(--white);padding:4px 6px;width:100%;color:var(--black)}#giphy-btn{border:1px solid var(--black);background:var(--white);padding:4px;width:100%;color:var(--black)}#giphy-btn:hover{background:var(--black);color:var(--white)}#giphy-grid{flex:1;display:flex;flex-wrap:wrap;gap:3px;overflow-y:auto;padding:6px;align-content:flex-start}#cam-panel{flex-direction:row;align-items:center;gap:0;padding:0}#cam-left{width:130px;flex-shrink:0;border-right:1px solid var(--black);display:flex;flex-direction:column;align-items:center;justify-content:center;padding:8px;gap:6px}#webcam-preview{width:110px;height:82px;background:#000;object-fit:cover;cursor:grab;display:block}#cam-btn{border:1px solid var(--black);background:var(--white);padding:4px 8px;width:100%;font-size:9px}#cam-btn:hover{background:var(--black);color:var(--white)}#cam-hint{flex:1;display:flex;align-items:center;justify-content:center;font-size:9px;color:var(--gray);padding:12px;text-align:center;line-height:1.6}.media-item{width:60px;height:60px;border:1px solid var(--gray-md);cursor:grab;overflow:hidden;flex-shrink:0;position:relative}.media-item:hover{border-color:var(--black)}.media-item.dbl-hint:after{content:"2×";position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;font-size:14px;color:#fff;background:#00000080;pointer-events:none}.media-item img,.media-item video{width:100%;height:100%;object-fit:cover;display:block;pointer-events:none}::-webkit-scrollbar{width:3px;height:3px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--gray-md)}#ftu-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0a0a0ad9;display:flex;align-items:center;justify-content:center;z-index:1000;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}#ftu-overlay[hidden]{display:none}#ftu-box{background:var(--white);border:1px solid var(--black);width:560px;max-width:90vw;padding:40px;display:flex;flex-direction:column;gap:32px}#ftu-header{display:flex;flex-direction:column;gap:6px}#ftu-title{font-family:var(--sans);font-size:32px;font-weight:800;letter-spacing:-.04em;line-height:1;color:var(--black)}#ftu-byline{font-size:11px;font-weight:500;color:var(--gray);letter-spacing:.08em}#ftu-desc{font-size:13px;font-weight:400;color:var(--black);margin-top:4px;line-height:1.4}#ftu-plans{display:grid;grid-template-columns:1fr 1fr;gap:16px}.ftu-plan{border:1px solid var(--gray-md);padding:20px;display:flex;flex-direction:column;gap:12px}.ftu-plan-pro{border-color:var(--black);background:var(--black);color:var(--white)}.ftu-plan-name{font-size:11px;font-weight:700;letter-spacing:.12em;text-transform:uppercase}.ftu-plan-pro .ftu-plan-name{color:var(--accent)}.ftu-features{list-style:none;display:flex;flex-direction:column;gap:7px}.ftu-features li{font-size:12px;font-weight:400;line-height:1.3;padding-left:12px;position:relative;color:var(--black)}.ftu-features li:before{content:"—";position:absolute;left:0;color:var(--gray)}.ftu-plan-pro .ftu-features li{color:var(--gray-lt)}.ftu-plan-pro .ftu-features li:before{color:var(--accent)}#ftu-actions{display:flex;gap:12px;align-items:center}#ftu-free-btn{background:none;border:1px solid var(--black);padding:10px 20px;font-size:12px;font-weight:600;color:var(--black);cursor:pointer;letter-spacing:.02em}#ftu-free-btn:hover{background:var(--black);color:var(--white)}#ftu-pro-btn{display:inline-block;background:var(--black);border:1px solid var(--black);padding:10px 20px;font-size:12px;font-weight:600;color:var(--white);text-decoration:none;letter-spacing:.02em;font-family:var(--sans)}#ftu-pro-btn:hover{background:var(--accent);border-color:var(--accent)}#ftu-kofi-btn{display:inline-block;background:none;border:1px solid var(--gray-md);padding:10px 16px;font-size:12px;font-weight:500;color:var(--black);text-decoration:none;letter-spacing:.02em;font-family:var(--sans);margin-left:auto}#ftu-kofi-btn:hover{border-color:var(--black)}#info-btn{font-size:13px;font-weight:700;width:24px;height:24px;border:1px solid var(--black);border-radius:50%;display:flex;align-items:center;justify-content:center;padding:0;line-height:1}#ftu-tos{font-size:9px;color:var(--gray);line-height:1.5;border-top:1px solid var(--gray-lt);padding-top:12px;margin-top:-8px}#fx-panel{flex-direction:column;overflow-y:auto;padding:12px 14px;gap:10px;align-items:flex-start}#fx-left{display:flex;flex-direction:column;gap:10px;width:100%;max-width:360px;flex-shrink:0}#fx-mode-toggle{display:flex;gap:4px}.fx-mode-btn{padding:4px 12px;font-size:10px;font-weight:600;border:1px solid var(--black);background:none;cursor:pointer;letter-spacing:.02em;color:var(--black);font-family:var(--sans);touch-action:manipulation}.fx-mode-btn.active{background:var(--black);color:var(--white)}.fx-info-text{font-size:10px;color:var(--gray);line-height:1.5}#fx-manual-controls{display:flex;flex-direction:column;gap:6px}.fx-knob-row{display:flex;align-items:center;gap:10px}.fx-knob-lbl{font-size:10px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;min-width:52px;color:var(--gray);font-family:var(--sans)}.fx-knob-select{border:1px solid var(--black);background:var(--white);padding:5px 8px;font-size:11px;color:var(--black);cursor:pointer;font-family:var(--sans);flex:1}#kits-browser{display:flex;flex-direction:column;height:100%;overflow:hidden}#kits-toolbar{padding:8px 12px 6px;border-bottom:1px solid var(--gray-lt);flex-shrink:0}.kits-section-lbl{display:block;font-size:9px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--gray);padding:8px 12px 4px;flex-shrink:0}#kits-grid,#user-kits-grid{display:flex;flex-direction:row;gap:10px;padding:8px 14px 12px;overflow-x:auto;align-items:stretch;flex-shrink:0}.kit-card{flex:0 0 152px;background:var(--black);color:var(--white);border:1px solid var(--black);padding:14px 12px 12px;cursor:pointer;display:flex;flex-direction:column;gap:4px;transition:border-color .12s;position:relative;overflow:hidden}.kit-card:hover{border-color:var(--accent)}.kit-swatches{display:flex;gap:3px;margin-bottom:6px}.kit-swatch{width:8px;height:8px;border-radius:50%;display:inline-block;opacity:.7}.kit-name{font-size:13px;font-weight:700;letter-spacing:.02em;line-height:1.2;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.kit-desc{font-size:9px;opacity:.45;letter-spacing:.04em;line-height:1.5;flex:1}.kit-count{font-size:9px;opacity:.3;letter-spacing:.05em;margin-top:auto}.kit-card-user{background:#111;border-color:#333;position:relative}.kit-delete-btn{position:absolute;top:6px;right:6px;background:none;border:none;color:#ffffff4d;font-size:14px;line-height:1;cursor:pointer;padding:0;width:16px;height:16px;display:flex;align-items:center;justify-content:center}.kit-delete-btn:hover{color:#fff}#export-settings{display:flex;gap:4px}#export-settings select{border:1px solid var(--black);background:var(--white);padding:4px 6px;font-size:11px;color:var(--black);cursor:pointer}#midi-modal{position:fixed;top:0;right:0;bottom:0;left:0;z-index:900;background:#0a0a0abf;display:flex;align-items:center;justify-content:center;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px)}#midi-modal[hidden]{display:none}#midi-modal-box{background:var(--white);border:1px solid var(--black);width:360px;max-width:90vw;display:flex;flex-direction:column}#midi-modal-header{display:flex;justify-content:space-between;align-items:center;padding:10px 14px;border-bottom:1px solid var(--gray-lt)}#midi-modal-title{font-size:11px;font-weight:700;letter-spacing:.08em}#midi-modal-body{padding:14px;display:flex;flex-direction:column;gap:10px}#midi-map-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:3px}.midi-map-cell{border:1px solid var(--gray-md);padding:6px 4px 5px;cursor:pointer;display:flex;flex-direction:column;align-items:center;gap:2px;transition:border-color .08s;touch-action:manipulation}.midi-map-cell:hover{border-color:var(--black)}.midi-map-cell.learning{border-color:var(--accent);animation:blink .5s step-end infinite}.midi-map-pad-num{font-size:8px;color:var(--gray);letter-spacing:.04em}.midi-map-note{font-size:10px;font-weight:700;color:var(--black)}#midi-modal-hint{font-size:9px;color:var(--gray);text-align:center;line-height:1.5}#midi-modal-footer{display:flex;gap:6px;padding:10px 14px;border-top:1px solid var(--gray-lt)}#midi-modal-footer .btn-text{font-size:10px;padding:4px 10px}#midi-modal-done{margin-left:auto}#midi-modal-knobs{display:flex;flex-direction:column;gap:4px;padding-bottom:10px;border-bottom:1px solid var(--gray-lt)}.midi-knob-row{display:flex;align-items:center;gap:8px}.midi-knob-label{font-size:10px;font-weight:700;letter-spacing:.06em;min-width:18px;color:var(--black)}.midi-knob-cc{font-size:10px;color:var(--gray);font-family:var(--mono);min-width:32px}.midi-learn-modal-btn{font-size:9px;padding:3px 8px;margin-left:auto;touch-action:manipulation}.midi-learn-modal-btn.learning{background:var(--black);color:var(--white);animation:blink .5s step-end infinite}#kit-name-modal{position:fixed;top:0;right:0;bottom:0;left:0;z-index:910;background:#0a0a0abf;display:flex;align-items:center;justify-content:center;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px)}#kit-name-modal[hidden]{display:none}#kit-name-box{background:var(--white);border:1px solid var(--black);padding:24px;width:300px;max-width:90vw;display:flex;flex-direction:column;gap:12px}#kit-name-title{font-size:11px;font-weight:700;letter-spacing:.08em}#kit-name-input{border:1px solid var(--black);background:var(--white);color:var(--black);padding:7px 10px;font-size:12px;font-family:var(--mono);width:100%}#kit-name-input:focus{outline:2px solid var(--black);outline-offset:1px}#kit-name-actions{display:flex;gap:6px;justify-content:flex-end}#kit-name-actions .btn-text{font-size:11px}#xy-pad{position:absolute;top:0;right:0;bottom:0;left:0;z-index:5;touch-action:none;-webkit-user-select:none;user-select:none;cursor:crosshair}#fullscreen-btn{z-index:20}#monitor-wrap.css-fullscreen{position:fixed!important;top:0!important;right:0!important;bottom:0!important;left:0!important;z-index:9000!important;width:100%!important;height:100%!important;background:#000}#fullscreen-btn.fs-active{position:fixed!important;bottom:20px!important;right:20px!important;z-index:9999!important;width:36px!important;height:36px!important;font-size:16px!important;background:#0009!important;color:#ffffffe6!important;border-color:#fff6!important}#upgrade-btn{font-size:10px;font-weight:700;letter-spacing:.06em;padding:3px 8px;border:1px solid var(--accent);color:var(--accent);background:transparent;border-radius:2px;cursor:pointer;white-space:nowrap;transition:background .15s,color .15s}#upgrade-btn:hover{background:var(--accent);color:var(--white)}#upgrade-modal{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1100;background:#0000008c;display:flex;align-items:center;justify-content:center}#upgrade-modal[hidden]{display:none}#upgrade-box{background:var(--white);border:1px solid var(--black);width:min(380px,90vw);display:flex;flex-direction:column}#upgrade-header{display:flex;align-items:center;justify-content:space-between;padding:10px 14px;border-bottom:1px solid var(--black);font-size:11px;font-weight:700;letter-spacing:.08em}#upgrade-body{padding:16px 14px 18px;display:flex;flex-direction:column;gap:12px}#upgrade-pitch{font-size:12px;margin:0;color:#0000008c}#upgrade-features{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:6px}#upgrade-features li{font-size:11px;letter-spacing:.02em}#upgrade-store-btn{display:block;text-align:center;padding:10px;background:var(--black);color:var(--white);font-size:11px;font-weight:700;letter-spacing:.08em;text-decoration:none;border-radius:2px;margin-top:4px;transition:opacity .15s}#upgrade-store-btn:hover{opacity:.8}#projects-modal{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1000;background:#00000080;display:flex;align-items:center;justify-content:center}#projects-modal[hidden]{display:none}#projects-box{background:var(--white);border:1px solid var(--black);width:min(480px,92vw);max-height:80vh;display:flex;flex-direction:column}#projects-header{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;border-bottom:1px solid var(--black);flex-shrink:0}#projects-title{font-size:11px;font-weight:700;letter-spacing:.08em}#projects-list{flex:1;overflow-y:auto}#projects-empty{padding:24px 16px;font-size:10px;color:var(--gray);text-align:center}.project-row{display:flex;align-items:center;padding:10px 16px;border-bottom:1px solid var(--gray-lt);gap:12px}.project-row:last-child{border-bottom:none}.project-info{flex:1;display:flex;flex-direction:column;gap:2px}.project-name{font-size:12px;font-weight:600}.project-date{font-size:9px;color:var(--gray);letter-spacing:.04em}.project-actions{display:flex;align-items:center;gap:6px}.project-load-btn{font-size:10px;padding:4px 10px;touch-action:manipulation}.project-del-btn{font-size:16px;color:var(--gray);touch-action:manipulation}.project-del-btn:hover{color:var(--accent)}#projects-footer{padding:8px 16px;border-top:1px solid var(--gray-lt);flex-shrink:0}#projects-hint{font-size:9px;color:var(--gray)}
