@import "https://fonts.googleapis.com/css2?family=IBM+Plex+Mono:wght@300;400;500;600&display=swap";:root{--bg:#0a0a0a;--bg1:#111;--bg2:#161616;--bg3:#1e1e1e;--border:#2a2a2a;--border-hi:#3a3a3a;--text:#e8e8e8;--text-dim:#666;--text-dimmer:#2e2e2e;--accent:#e8ff3a;--accent2:#ff3a6e;--accent3:#3affe8;--mono:"IBM Plex Mono", monospace;--panel-w:260px;--header-h:44px}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html,body,#root{background:var(--bg);width:100%;height:100%;color:var(--text);font-family:var(--mono);overflow:hidden}.app{flex-direction:column;width:100vw;height:100vh;display:flex}.app-header{height:var(--header-h);background:var(--bg1);border-bottom:1px solid var(--border);z-index:100;flex-shrink:0;align-items:center;gap:0;padding:0 12px;display:flex}.app-body{flex:1;display:flex;overflow:hidden}.canvas-wrap{background:var(--bg);flex:1;justify-content:center;align-items:center;display:flex;position:relative;overflow:hidden}.render-area{justify-content:center;align-items:center;width:100%;height:100%;display:flex;position:relative;overflow:hidden}.model-layer{z-index:1;transition:opacity .15s;position:absolute;inset:0}.effect-layer{z-index:2;pointer-events:none;justify-content:center;align-items:center;display:flex;position:absolute;inset:0}.effect-layer canvas{image-rendering:pixelated;max-width:100%;max-height:100%;display:block}.sidebar{width:var(--panel-w);background:var(--bg1);border-left:1px solid var(--border);scrollbar-width:thin;scrollbar-color:var(--border) transparent;flex-shrink:0;overflow-y:auto}.logo{flex-shrink:0;align-items:baseline;gap:5px;margin-right:16px;display:flex}.logo-fx{font-family:var(--mono);color:var(--accent);letter-spacing:.08em;font-size:15px;font-weight:600}.logo-dot{color:var(--text-dim);font-size:12px}.logo-sub{font-family:var(--mono);color:var(--text-dim);letter-spacing:.2em;text-transform:uppercase;font-size:9px;font-weight:400}.export-btn{border:1px solid var(--border-hi);color:var(--text-dim);font-family:var(--mono);cursor:pointer;letter-spacing:.05em;background:0 0;margin-left:auto;padding:4px 10px;font-size:11px;transition:all .15s}.export-btn:hover{border-color:var(--accent);color:var(--accent)}.input-selector{background:var(--border);border:1px solid var(--border);gap:1px;padding:1px;display:flex}.input-tab{background:var(--bg1);color:var(--text-dim);font-family:var(--mono);cursor:pointer;letter-spacing:.08em;white-space:nowrap;border:none;align-items:center;gap:5px;padding:4px 10px;font-size:10px;transition:all .1s;display:flex}.input-tab:hover{background:var(--bg3);color:var(--text)}.input-tab.active{background:var(--accent);color:#000}.input-icon{font-size:10px}.input-label{font-size:9px;font-weight:500}.control-panel{flex-direction:column;min-height:100%;display:flex}.panel-header{border-bottom:1px solid var(--border);flex-shrink:0;justify-content:space-between;align-items:center;padding:10px 12px;display:flex}.panel-logo{font-family:var(--mono);color:var(--accent);letter-spacing:.15em;font-size:11px;font-weight:600}.share-btn{border:1px solid var(--border-hi);color:var(--text-dim);font-family:var(--mono);cursor:pointer;letter-spacing:.05em;background:0 0;padding:3px 8px;font-size:9px;transition:all .15s}.share-btn:hover{border-color:var(--accent3);color:var(--accent3)}.ctrl-section{border-bottom:1px solid var(--border);padding-bottom:8px}.ctrl-section-title{font-family:var(--mono);color:var(--text-dimmer);letter-spacing:.25em;text-transform:uppercase;padding:10px 12px 6px;font-size:8px;font-weight:600}.ctrl-row{justify-content:space-between;align-items:center;gap:8px;min-height:26px;padding:3px 12px;display:flex}.ctrl-label{color:var(--text-dim);letter-spacing:.03em;white-space:nowrap;flex-shrink:0;font-size:10px}.ctrl-input{flex:1;justify-content:flex-end;align-items:center;gap:6px;display:flex}.effect-tabs{grid-template-columns:repeat(4,1fr);gap:1px;padding:0 12px 8px;display:grid}.effect-tab{background:var(--bg3);border:1px solid var(--border);color:var(--text-dim);font-family:var(--mono);cursor:pointer;letter-spacing:.06em;text-align:center;padding:5px 2px;font-size:8px;transition:all .1s}.effect-tab:hover{border-color:var(--border-hi);color:var(--text)}.effect-tab.active{background:var(--accent);color:#000;border-color:var(--accent);font-weight:600}.slider-wrap{align-items:center;gap:6px;width:100%;display:flex}.slider-wrap input[type=range]{-webkit-appearance:none;background:var(--border-hi);cursor:pointer;outline:none;flex:1;height:2px}.slider-wrap input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;background:var(--accent);cursor:pointer;border-radius:0;width:10px;height:10px;transition:transform .1s}.slider-wrap input[type=range]::-webkit-slider-thumb:hover{transform:scale(1.3)}.slider-val{color:var(--text-dim);text-align:right;flex-shrink:0;width:30px;font-size:9px}.toggle{background:var(--bg3);border:1px solid var(--border);color:var(--text-dim);font-family:var(--mono);cursor:pointer;letter-spacing:.08em;padding:3px 8px;font-size:9px;transition:all .1s}.toggle.on{background:var(--accent);border-color:var(--accent);color:#000;font-weight:600}select{background:var(--bg3);border:1px solid var(--border);color:var(--text);font-family:var(--mono);cursor:pointer;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='8' height='5' viewBox='0 0 8 5'%3E%3Cpath fill='%23666' d='M0 0l4 5 4-5z'/%3E%3C/svg%3E");background-position:right 6px center;background-repeat:no-repeat;outline:none;width:100%;padding:3px 20px 3px 6px;font-size:10px}select:focus{border-color:var(--accent)}select option{background:var(--bg2)}input[type=color]{border:1px solid var(--border);cursor:pointer;background:0 0;width:28px;height:20px;padding:0}.drop-hint{color:var(--text-dim);pointer-events:none;-webkit-user-select:none;user-select:none;flex-direction:column;align-items:center;gap:12px;display:flex}.drop-hint-icon{opacity:.3;font-size:32px}.drop-hint-text{font-family:var(--mono);letter-spacing:.1em;text-transform:uppercase;font-size:11px}.toast{background:var(--accent);color:#000;font-family:var(--mono);letter-spacing:.1em;z-index:1000;padding:8px 20px;font-size:11px;font-weight:600;animation:.2s fadeInUp;position:fixed;bottom:24px;left:50%;transform:translate(-50%)}@keyframes fadeInUp{0%{opacity:0;transform:translate(-50%,8px)}to{opacity:1;transform:translate(-50%)}}::-webkit-scrollbar{width:4px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--border-hi)}
