*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--bg:#0f0f18;--bg2:#17172a;--bg3:#1e1e36;--border:#2e2e50;--accent:#6c47ff;--accent-hover:#7d5cff;--text:#e8e8f0;--text2:#9090b0;--danger:#e05555;--success:#3ecf8e;--radius:8px;--font:-apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--mono:"Fira Code", "Cascadia Code", Consolas, monospace}html,body,#root{height:100%}body{background:var(--bg);color:var(--text);font-family:var(--font);font-size:15px;line-height:1.5}.app-root{flex-direction:column;height:100vh;display:flex}.app-outlet{flex:1;overflow-y:auto}.top-nav{background:var(--bg2);border-bottom:1px solid var(--border);flex-shrink:0;align-items:center;gap:8px;height:52px;padding:0 16px;display:flex}.top-nav-brand{color:var(--accent);margin-right:8px;font-size:17px;font-weight:700}.top-nav-links{gap:4px;display:flex}.top-nav-links a{border-radius:var(--radius);color:var(--text2);padding:6px 12px;font-size:14px;text-decoration:none;transition:background .15s,color .15s}.top-nav-links a:hover,.top-nav-links a.active{background:var(--bg3);color:var(--text)}.top-nav-spacer{flex:1}.top-nav-user{align-items:center;gap:8px;display:flex}.top-nav-user-name{color:var(--text2);font-size:13px}.auth-gate{justify-content:center;align-items:center;height:100vh;display:flex}.auth-gate-text{color:var(--text2)}.login-page{justify-content:center;align-items:center;min-height:100vh;padding:20px;display:flex}.login-card{text-align:center;width:100%;max-width:380px}.login-logo{margin-bottom:12px}.login-card h1{margin-bottom:4px;font-size:24px}.login-card .hint{margin-bottom:20px}.btn-link{color:var(--accent);cursor:pointer;font-size:inherit;background:0 0;border:none;padding:0;text-decoration:underline}.panel{background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius);padding:20px}.field{color:var(--text2);flex-direction:column;gap:6px;margin-bottom:16px;font-size:14px;display:flex}.field input,.field select,.field textarea{background:var(--bg3);border:1px solid var(--border);border-radius:var(--radius);color:var(--text);font-size:14px;font-family:var(--font);outline:none;padding:8px 12px;transition:border-color .15s}.field input:focus,.field select:focus,.field textarea:focus{border-color:var(--accent)}.input-with-btn{gap:8px;display:flex}.input-with-btn input{flex:1}.input-sm{background:var(--bg3);border:1px solid var(--border);border-radius:var(--radius);color:var(--text);outline:none;padding:6px 10px;font-size:13px;transition:border-color .15s}.input-sm:focus{border-color:var(--accent)}button{cursor:pointer;font-family:var(--font);border:none;outline:none}.btn{border-radius:var(--radius);padding:9px 18px;font-size:14px;font-weight:500;transition:background .15s,opacity .15s}.btn:disabled{opacity:.5;cursor:not-allowed}.btn.primary{background:var(--accent);color:#fff}.btn.primary:hover:not(:disabled){background:var(--accent-hover)}.btn.secondary{background:var(--bg3);color:var(--text);border:1px solid var(--border)}.btn.secondary:hover:not(:disabled){border-color:var(--accent);color:var(--accent)}.btn.danger{color:var(--danger);border:1px solid var(--danger);background:0 0}.btn.danger:hover:not(:disabled){background:var(--danger);color:#fff}.btn.small{padding:5px 12px;font-size:13px}.btn-ghost{color:var(--text2);border-radius:var(--radius);background:0 0;padding:6px 10px;font-size:13px}.btn-ghost:hover{color:var(--text);background:var(--bg3)}.banner{border-radius:var(--radius);margin-bottom:12px;padding:10px 14px;font-size:14px}.banner.error{color:#f08080;background:#e055551f;border:1px solid #e055554d}.banner.success{color:#81c784;background:#4caf501f;border:1px solid #4caf504d}.hint{color:var(--text2);font-size:13px}.page{max-width:1000px;margin:0 auto;padding:24px}.page-header{justify-content:space-between;align-items:center;margin-bottom:24px;display:flex}.page-header h1{font-size:22px}.studio-layout{grid-template-columns:1fr 1fr;height:calc(100vh - 52px);display:grid;overflow:hidden}.chat-panel{border-right:1px solid var(--border);flex-direction:column;min-width:0;height:100%;display:flex;overflow:hidden}.chat-header{border-bottom:1px solid var(--border);flex-shrink:0;justify-content:space-between;align-items:center;padding:12px 16px;display:flex}.chat-mode-label{color:var(--text2);font-size:13px;font-weight:500}.chat-messages{flex-direction:column;flex:1;gap:12px;padding:16px;display:flex;overflow-y:auto}.chat-empty{text-align:center;height:100%;color:var(--text2);flex-direction:column;justify-content:center;align-items:center;gap:8px;display:flex}.chat-message{display:flex}.chat-message.user{justify-content:flex-end}.chat-message.assistant{justify-content:flex-start}.chat-bubble{border-radius:12px;max-width:80%;padding:10px 14px;font-size:14px;line-height:1.6}.chat-bubble p{margin-bottom:4px}.chat-bubble p:last-child{margin-bottom:0}.chat-message.user .chat-bubble{background:var(--accent);color:#fff;border-radius:12px 12px 4px}.chat-message.assistant .chat-bubble{background:var(--bg3);color:var(--text);border:1px solid var(--border);border-radius:12px 12px 12px 4px}.typing-indicator{font-family:var(--mono)}.agent-notification{color:var(--text2);background:linear-gradient(90deg,#6366f11f 0%,#6366f10f 100%);border:1px solid #6366f140;border-radius:20px;align-self:center;align-items:center;gap:8px;max-width:90%;padding:7px 14px;font-size:13px;display:flex}.agent-notification-dot{background:#6366f1;border-radius:50%;flex-shrink:0;width:7px;height:7px;animation:2s ease-in-out infinite agent-pulse;box-shadow:0 0 6px #6366f199}@keyframes agent-pulse{0%,to{opacity:1;box-shadow:0 0 6px #6366f199}50%{opacity:.5;box-shadow:0 0 2px #6366f14d}}.chat-input-area{border-top:1px solid var(--border);flex-direction:column;flex-shrink:0;gap:8px;padding:12px 16px;display:flex}.quick-actions-bar{background:var(--bg2);border-top:1px solid var(--border);flex-shrink:0;align-items:center;gap:8px;padding:8px 16px;display:flex}.quick-actions-label{color:var(--text2);white-space:nowrap;margin-right:4px;font-size:12px}.chat-actions{gap:8px;display:flex}.chat-input-row{align-items:flex-end;gap:8px;display:flex}.chat-textarea{resize:none;background:var(--bg3);border:1px solid var(--border);border-radius:var(--radius);color:var(--text);font-size:14px;font-family:var(--font);outline:none;flex:1;padding:8px 12px;transition:border-color .15s}.chat-textarea:focus{border-color:var(--accent)}.send-btn{align-self:flex-end;padding:8px 16px}.chat-generate-row{gap:8px;display:flex}.chat-attach-btn{align-self:flex-end;padding:6px 10px;font-size:15px}.chat-image-preview{border:1px solid var(--border);border-radius:8px;align-items:flex-start;max-width:180px;display:inline-flex;position:relative;overflow:hidden}.chat-image-preview img{object-fit:cover;max-width:180px;max-height:120px;display:block}.chat-image-remove{color:#fff;cursor:pointer;background:#0009;border:none;border-radius:50%;justify-content:center;align-items:center;width:20px;height:20px;font-size:11px;line-height:1;display:flex;position:absolute;top:4px;right:4px}.chat-image-remove:hover{background:#dc3232d9}.chat-attached-image{object-fit:contain;border-radius:6px;max-width:100%;max-height:200px;margin-bottom:6px;display:block}.code-panel{flex-direction:column;min-width:0;height:100%;display:flex;overflow:hidden}.code-panel-header{border-bottom:1px solid var(--border);flex-wrap:wrap;flex-shrink:0;justify-content:space-between;align-items:center;gap:8px;padding:12px 16px;font-size:14px;font-weight:500;display:flex}.code-panel-actions{flex-wrap:wrap;align-items:center;gap:8px;display:flex}.save-msg{color:var(--success);font-size:13px}.code-content{flex-direction:column;flex:1;padding:16px;display:flex;overflow-y:auto}.code-content .code-editor-textarea{resize:none;border-radius:var(--radius);border:1px solid var(--border);flex:1;height:100%;min-height:0;max-height:none}.code-empty{text-align:center;height:100%;color:var(--text2);flex-direction:column;justify-content:center;align-items:center;gap:8px;display:flex}.code-block{background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius);font-family:var(--mono);white-space:pre-wrap;word-break:break-all;color:#b0c4ff;padding:16px;font-size:13px;line-height:1.5;overflow-x:auto}.projects-grid{grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:16px;display:grid}.project-card{flex-direction:column;gap:12px;display:flex}.project-card-header{justify-content:space-between;align-items:flex-start;gap:8px;display:flex}.project-card-header h3{font-size:15px;font-weight:600}.project-date{color:var(--text2);white-space:nowrap;font-size:12px}.code-preview{font-family:var(--mono);color:var(--text2);white-space:pre-wrap;word-break:break-all;max-height:80px;font-size:11px;line-height:1.4;overflow:hidden}.project-card-actions{gap:8px;margin-top:4px;display:flex}.empty-state{text-align:center;color:var(--text2);flex-direction:column;align-items:center;gap:16px;padding:60px 20px;display:flex}.settings-page{max-width:600px}.settings-panel h2{margin-bottom:20px;font-size:17px}.admin-panel{max-width:700px}.admin-badge{color:var(--accent);vertical-align:middle;background:#6c47ff33;border:1px solid #6c47ff59;border-radius:4px;margin-left:8px;padding:1px 6px;font-size:11px;font-weight:700;display:inline-block}.admin-badge.small{margin-left:4px;padding:1px 5px;font-size:10px}.admin-users-list{flex-direction:column;gap:6px;margin-bottom:16px;display:flex}.admin-user-row{background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius);justify-content:space-between;align-items:center;gap:10px;padding:8px 12px;display:flex}.admin-user-info{flex:1;align-items:center;gap:8px;min-width:0;display:flex}.admin-user-name{font-size:14px;font-weight:600}.admin-user-login{color:var(--text2);font-size:12px}.admin-user-actions{flex-shrink:0;align-items:center;gap:6px;display:flex}.btn.danger{color:#f08080;background:#e0555526;border:1px solid #e055554d}.btn.danger:hover{background:#e0555540}.admin-reset-form{background:var(--bg3);border-radius:var(--radius);flex-wrap:wrap;align-items:center;gap:8px;margin-bottom:12px;padding:10px 12px;display:flex}.admin-create-form{border-top:1px solid var(--border);padding-top:14px}.admin-create-form h3{color:var(--text2);text-transform:uppercase;letter-spacing:.04em;margin-bottom:10px;font-size:13px;font-weight:600}.admin-create-row{flex-wrap:wrap;align-items:center;gap:8px;display:flex}.admin-create-row .input-sm{flex:1;min-width:110px}.admin-check-label{cursor:pointer;white-space:nowrap;align-items:center;gap:5px;font-size:13px;display:flex}.lang-toggle{gap:8px;margin-top:6px;display:flex}.lang-btn{border-radius:var(--radius);background:var(--bg3);color:var(--text2);border:1px solid var(--border);cursor:pointer;padding:7px 18px;font-size:14px;transition:all .15s}.lang-btn:hover{border-color:var(--accent);color:var(--text)}.lang-btn.active{background:var(--accent);color:#fff;border-color:var(--accent)}.filter-tabs{gap:4px;margin-bottom:20px;display:flex}.filter-tab{color:var(--text2);border:1px solid var(--border);cursor:pointer;background:0 0;border-radius:20px;align-items:center;gap:6px;padding:6px 14px;font-size:13px;transition:all .15s;display:flex}.filter-tab:hover{border-color:var(--accent);color:var(--text)}.filter-tab.active{background:var(--accent);color:#fff;border-color:var(--accent)}.filter-count{background:#fff3;border-radius:10px;padding:1px 6px;font-size:11px}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--text2)}.template-category-bar{border-bottom:1px solid var(--border);background:var(--bg);scrollbar-width:none;flex-shrink:0;gap:4px;padding:6px 10px;display:flex;overflow-x:auto}.template-category-bar::-webkit-scrollbar{display:none}.template-cat-btn{white-space:nowrap;color:var(--text2);border:1px solid var(--border);cursor:pointer;background:0 0;border-radius:20px;flex-shrink:0;align-items:center;gap:4px;padding:4px 10px;font-size:12px;transition:all .15s;display:flex}.template-cat-btn:hover{border-color:var(--accent);color:var(--text)}.template-cat-btn.active{background:var(--accent);color:#fff;border-color:var(--accent)}.video-template-picker{border-bottom:1px solid var(--border);background:var(--bg2);scrollbar-width:thin;flex-shrink:0;gap:4px;padding:8px 10px;display:flex;overflow-x:auto}.video-template-btn{border-radius:var(--radius);color:var(--text2);cursor:pointer;background:0 0;border:1px solid #0000;flex-direction:column;flex-shrink:0;align-items:center;gap:2px;min-width:68px;padding:6px 10px;font-size:12px;transition:all .15s;display:flex;position:relative}.video-template-btn:hover{background:var(--bg3);color:var(--text)}.video-template-btn.active{background:var(--bg3);color:var(--accent);border-color:var(--accent)}.template-alpha-badge{color:var(--success);background:#3ecf8e26;border-radius:3px;padding:0 3px;font-size:9px;font-weight:700;position:absolute;top:3px;right:3px}.format-bar{border-bottom:1px solid var(--border);background:var(--bg2);flex-wrap:wrap;flex-shrink:0;align-items:center;gap:12px;padding:8px 12px;display:flex}.format-group{align-items:center;gap:4px;display:flex}.format-label{color:var(--text2);white-space:nowrap;margin-right:2px;font-size:12px}.format-btn{border-radius:var(--radius);color:var(--text2);border:1px solid var(--border);cursor:pointer;background:0 0;padding:4px 10px;font-size:12px;font-weight:500;transition:all .15s}.format-btn:hover{border-color:var(--accent);color:var(--text)}.format-btn.active{background:var(--accent);color:#fff;border-color:var(--accent)}.format-btn.alpha.active{background:linear-gradient(135deg,#6c47ff,#3ecf8e);border-color:#0000}.format-info{color:var(--text2);margin-left:auto;font-size:11px}.code-tabs{gap:2px;display:flex}.code-tab{border-radius:var(--radius);color:var(--text2);cursor:pointer;background:0 0;border:1px solid #0000;padding:4px 12px;font-size:13px;font-weight:500;transition:all .15s}.code-tab:hover{color:var(--text);background:var(--bg3)}.code-tab.active{background:var(--accent);color:#fff}.code-tab:disabled{opacity:.35;cursor:not-allowed}.render-bar{border-bottom:1px solid var(--border);background:#6c47ff0f;flex-shrink:0;align-items:center;gap:8px;padding:6px 16px;display:flex}.render-progress-wrap{flex:1;align-items:center;gap:8px;min-width:0;display:flex}.render-progress-bar{background:var(--bg3);border-radius:3px;flex:1;height:6px;overflow:hidden}.render-progress-fill{background:var(--accent);border-radius:3px;height:100%;transition:width .3s}.render-progress-label{color:var(--text2);white-space:nowrap;font-size:12px}.render-done-label{color:var(--success);font-size:12px;font-weight:600}.render-error-label{color:#ff6b6b;font-size:12px;font-weight:600}.render-error-detail{color:#f99;font-size:11px;font-family:var(--mono);text-overflow:ellipsis;white-space:nowrap;max-width:400px;overflow:hidden}.preview-player-wrap{background:#111;flex-direction:column;flex:1;padding:12px;display:flex;overflow:auto}.preview-status{color:var(--text2);padding:8px 0;font-size:13px}.preview-error{color:#ff6b6b;font-size:12px;font-family:var(--mono);white-space:pre-wrap;border-radius:var(--radius);background:#ff6b6b14;padding:12px}.video-player-wrap{background:#000;flex-direction:column;flex:1;display:flex;overflow:hidden}.video-player{object-fit:contain;flex:1;width:100%;min-height:0;display:block}.video-player-actions{background:var(--bg2);border-top:1px solid var(--border);flex-shrink:0;gap:8px;padding:8px 12px;display:flex}.mov-notice{text-align:center;background:var(--bg1);flex-direction:column;flex:1;justify-content:center;align-items:center;gap:16px;padding:32px;display:flex}.mov-notice-icon{font-size:48px}.mov-notice-text{flex-direction:column;gap:6px;display:flex}.mov-notice-text strong{color:var(--text1);font-size:16px}.mov-notice-text span{color:var(--text2);max-width:360px;font-size:13px}.template-selector{border-bottom:1px solid var(--border);background:var(--bg2);flex-shrink:0;position:relative}.template-current{cursor:pointer;width:100%;color:var(--text);background:0 0;border:none;align-items:center;gap:8px;padding:8px 14px;font-size:14px;font-weight:500;transition:background .15s;display:flex}.template-current:hover{background:var(--bg3)}.template-current-icon{font-size:20px;line-height:1}.template-current-label{text-align:left;flex:1}.template-current-arrow{color:var(--text2);font-size:10px}.template-dropdown{z-index:100;background:var(--bg2);border-bottom:1px solid var(--border);flex-wrap:wrap;gap:4px;padding:10px 12px;display:flex;position:absolute;top:100%;left:0;right:0;box-shadow:0 8px 24px #00000059}.template-btn{border-radius:var(--radius);color:var(--text2);cursor:pointer;background:0 0;border:1px solid #0000;flex-direction:column;align-items:center;gap:2px;min-width:56px;padding:6px 8px;font-size:12px;transition:all .15s;display:flex}.template-btn:hover{background:var(--bg3);color:var(--text)}.template-btn.active{background:var(--bg3);color:var(--accent);border-color:var(--accent)}.template-icon{font-size:18px;line-height:1}.template-label{white-space:nowrap;font-size:11px}.preview-content{background:var(--bg);flex:1;justify-content:center;align-items:flex-start;min-width:0;padding:16px;display:flex;overflow:auto}.preview-wrapper{border-radius:var(--radius);border:1px solid var(--border);background-image:linear-gradient(45deg,#1a1a2e 25%,#0000 25%),linear-gradient(-45deg,#1a1a2e 25%,#0000 25%),linear-gradient(45deg,#0000 75%,#1a1a2e 75%),linear-gradient(-45deg,#0000 75%,#1a1a2e 75%);background-position:0 0,0 8px,8px -8px,-8px 0;background-size:16px 16px;background-color:var(--bg3);flex-shrink:0;position:relative;overflow:hidden}.zoom-bar{align-items:center;gap:6px;display:flex}.zoom-btn{background:var(--bg3);border:1px solid var(--border);color:var(--text);cursor:pointer;border-radius:4px;justify-content:center;align-items:center;width:28px;height:28px;font-size:16px;line-height:1;display:flex}.zoom-btn:hover{background:var(--border)}.zoom-label{color:var(--text2);text-align:center;-webkit-user-select:none;user-select:none;min-width:40px;font-size:12px}.live-params-panel{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);width:100%;max-width:700px;font-size:.78rem;overflow:hidden}.live-params-toggle{cursor:pointer;width:100%;color:var(--text-muted);text-align:left;background:0 0;border:none;align-items:center;gap:8px;padding:7px 12px;font-size:.78rem;font-weight:500;transition:background .15s;display:flex}.live-params-toggle:hover{background:var(--bg-hover,#ffffff0a)}.live-params-chevron{opacity:.6;margin-left:2px;font-size:.65rem}.live-params-reset{border:1px solid var(--border);cursor:pointer;color:var(--text-muted);background:0 0;border-radius:4px;margin-left:auto;padding:2px 8px;font-size:.72rem;transition:border-color .15s}.live-params-reset:hover{border-color:var(--accent);color:var(--accent)}.live-params-grid{border-top:1px solid var(--border);flex-wrap:wrap;gap:6px 12px;padding:8px 12px 10px;display:flex}.live-param-item{cursor:default;border-radius:4px;align-items:center;gap:6px;padding:2px 4px;transition:background .1s;display:flex}.live-param-item.changed{background:#6b5bff14}.live-param-label{color:var(--text-muted);white-space:nowrap;text-overflow:ellipsis;max-width:110px;font-size:.73rem;overflow:hidden}.live-param-color{border:1px solid var(--border);cursor:pointer;background:0 0;border-radius:4px;width:28px;height:22px;padding:0}.live-param-number{background:var(--bg);border:1px solid var(--border);width:64px;color:var(--text);border-radius:4px;padding:2px 5px;font-size:.75rem}.live-param-number:focus{border-color:var(--accent);outline:none}.live-param-bool{cursor:pointer;accent-color:var(--accent)}.preview-with-seamless{flex-direction:column;align-items:center;gap:12px;display:flex}.seamless-result{border-radius:var(--radius);border:1px solid;flex-direction:column;gap:10px;width:100%;max-width:620px;padding:12px 14px;display:flex}.seamless-result.ok{background:#3ecf8e14;border-color:#3ecf8e4d}.seamless-result.fail{background:#e0555514;border-color:#e055554d}.seamless-result-header{align-items:center;gap:8px;display:flex}.seamless-result-icon{flex-shrink:0;font-size:16px}.seamless-result.ok .seamless-result-icon{color:var(--success)}.seamless-result.fail .seamless-result-icon{color:var(--danger)}.seamless-result-label{font-size:13px;font-weight:500}.seamless-tile-wrap{flex-wrap:wrap;align-items:flex-start;gap:10px;display:flex}.seamless-tile-label{color:var(--text2);flex-shrink:0;padding-top:4px;font-size:12px}.seamless-tile-img{border:1px solid var(--border);image-rendering:pixelated;border-radius:4px;max-width:300px;max-height:300px;display:block;width:auto!important;height:auto!important}.quality-panel{border:1px solid var(--border);border-radius:8px;width:100%;max-width:560px;padding:10px 14px;font-size:13px}.quality-panel.ok{background:#0d2218;border-color:#22c55e}.quality-panel.fail{background:#2a1010;border-color:#ef4444}.quality-panel.assessing{background:var(--surface);color:var(--text2);align-items:center;gap:8px;display:flex}.quality-header{flex-wrap:wrap;align-items:center;gap:10px;display:flex}.quality-icon{font-size:16px}.quality-score{font-weight:700}.quality-verdict{color:var(--text2);flex:1}.quality-issues{color:var(--text2);margin:8px 0 0 20px;padding:0;list-style:outside}.quality-issues li{margin-bottom:2px}.history-strip{border-top:1px solid var(--border);background:var(--surface);flex-wrap:wrap;flex-shrink:0;align-items:center;gap:8px;padding:10px 16px;display:flex}.history-strip-label{color:var(--text2);white-space:nowrap;margin-right:4px;font-size:12px}.history-thumb{border:2px solid var(--border);background:var(--bg);cursor:pointer;border-radius:6px;flex-shrink:0;justify-content:center;align-items:center;width:64px;height:64px;padding:0;transition:border-color .15s,transform .1s;display:flex;position:relative;overflow:hidden}.history-thumb:hover{border-color:var(--accent);transform:scale(1.06)}.history-thumb.active{border-color:var(--accent);box-shadow:0 0 0 2px var(--accent)}.history-thumb-img{object-fit:cover;width:100%;height:100%;display:block}.history-thumb-placeholder{font-size:22px}.history-quality-badge{pointer-events:none;border-radius:3px;padding:1px 3px;font-size:11px;font-weight:700;line-height:1;position:absolute;bottom:2px;right:2px}.history-quality-badge.ok{color:#fff;background:#22c55e}.history-quality-badge.fail{color:#fff;background:#ef4444}.history-quality-badge.assessing{color:#fff;background:#6366f1}.hint-large{margin-bottom:8px;font-size:40px;line-height:1}.project-type-badge{border-radius:20px;padding:2px 8px;font-size:11px;font-weight:600;display:inline-block}.project-type-badge.video{color:var(--accent);background:#6c47ff26}.project-type-badge.graphics{color:var(--success);background:#3ecf8e26}@media (width<=768px){.studio-layout{grid-template-rows:1fr 1fr;grid-template-columns:1fr}.chat-panel{border-right:none;border-bottom:1px solid var(--border)}}.batch-open-btn{font-size:12px}.batch-overlay{z-index:200;background:#000000bf;justify-content:center;align-items:center;padding:16px;display:flex;position:fixed;inset:0}.batch-modal{background:var(--bg2);border:1px solid var(--border);border-radius:12px;flex-direction:column;width:min(960px,100%);height:min(760px,95vh);display:flex;overflow:hidden}.batch-header{border-bottom:1px solid var(--border);flex-shrink:0;justify-content:space-between;align-items:center;padding:14px 20px;display:flex}.batch-header-info{flex-direction:column;gap:2px;display:flex}.batch-title{font-size:16px;font-weight:700}.batch-subtitle{color:var(--text2);font-size:12px}.batch-steps{border-bottom:1px solid var(--border);flex-shrink:0;align-items:center;gap:0;padding:10px 20px;display:flex}.batch-step{color:var(--text2);border-radius:20px;align-items:center;gap:6px;padding:4px 12px;font-size:12px;display:flex;position:relative}.batch-step.active{color:var(--accent);background:#6c47ff26;font-weight:600}.batch-step.done{color:var(--success)}.batch-step-num{border:1px solid;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:18px;height:18px;font-size:10px;display:flex}.batch-step.done .batch-step-num:before{content:"✓"}.batch-step.done .batch-step-num{font-size:0}.batch-body{flex:1;padding:20px;overflow-y:auto}.batch-phase{flex-direction:column;gap:14px;display:flex}.batch-phase-header{justify-content:space-between;align-items:center;display:flex}.batch-phase-header h3{font-size:14px;font-weight:600}.batch-count-label{color:var(--text2);font-size:13px}.batch-agent-messages{flex-direction:column;gap:10px;max-height:320px;padding:4px 0 8px;display:flex;overflow-y:auto}.batch-agent-empty{color:var(--text2);text-align:center;padding:16px 0;font-size:13px;line-height:1.7}.batch-agent-input-row{align-items:flex-end;gap:8px;display:flex}.batch-agent-input-row .chat-textarea{flex:1;min-height:52px;font-size:13px}.batch-agent-footer{border-top:1px solid var(--border);justify-content:space-between;align-items:center;gap:8px;padding-top:4px;display:flex}.batch-error{border-radius:var(--radius);color:var(--danger);background:#e055551f;border:1px solid #e055554d;padding:8px 12px;font-size:13px}.batch-empty{color:var(--text2);padding:20px 0;font-size:13px;line-height:1.7}.batch-ideas-list{flex-direction:column;gap:6px;max-height:360px;display:flex;overflow-y:auto}.batch-idea-row{background:var(--bg3);border-radius:var(--radius);cursor:pointer;align-items:flex-start;gap:10px;padding:8px 12px;font-size:13px;transition:background .15s;display:flex}.batch-idea-row:hover{background:#252540}.batch-idea-row input[type=checkbox]{accent-color:var(--accent);flex-shrink:0;margin-top:2px}.batch-idea-num{color:var(--text2);flex-shrink:0;min-width:20px}.batch-idea-text{line-height:1.5}.batch-ideas-footer{flex-wrap:wrap;align-items:center;gap:8px;padding-top:4px;display:flex}.batch-progress-bar-wrap{padding:4px 0}.batch-progress-bar{background:var(--bg3);border-radius:2px;height:4px;overflow:hidden}.batch-progress-fill{background:var(--accent);height:100%;transition:width .3s}.batch-queue-list{flex-direction:column;gap:4px;max-height:400px;display:flex;overflow-y:auto}.batch-queue-row{background:var(--bg3);border-radius:var(--radius);align-items:flex-start;gap:8px;min-height:36px;padding:7px 10px;font-size:13px;display:flex}.batch-queue-icon{text-align:center;flex-shrink:0;width:18px;padding-top:2px;font-size:14px}.batch-queue-num{color:var(--text2);flex-shrink:0;min-width:24px;padding-top:1px}.batch-queue-text{-webkit-line-clamp:2;white-space:normal;cursor:default;-webkit-box-orient:vertical;flex:1;line-height:1.45;display:-webkit-box;overflow:hidden}.batch-queue-error{color:var(--danger);flex-shrink:0;padding-top:2px;font-size:12px}.batch-queue-pct{color:var(--text2);flex-shrink:0;padding-top:2px;font-size:12px}.status-done .batch-queue-icon{color:var(--success)}.status-running .batch-queue-icon{color:var(--accent);animation:1s linear infinite spin}.status-error .batch-queue-icon{color:var(--danger)}.status-saved .batch-queue-icon{color:var(--success)}@keyframes spin{to{transform:rotate(360deg)}}.batch-results-layout{grid-template-columns:1fr 1fr;gap:14px;min-height:280px;display:grid}.batch-results-list{flex-direction:column;gap:5px;max-height:320px;display:flex;overflow-y:auto}.batch-result-row{background:var(--bg3);border-radius:var(--radius);align-items:flex-start;gap:8px;min-height:36px;padding:7px 10px;font-size:13px;transition:background .15s;display:flex}.batch-result-row.previewing{background:#6c47ff1f;border:1px solid #6c47ff4d}.batch-result-check{accent-color:var(--accent);flex-shrink:0;margin-top:3px}.batch-result-status-icon{text-align:center;flex-shrink:0;width:16px;padding-top:1px}.batch-result-num{color:var(--text2);flex-shrink:0;min-width:22px;padding-top:1px}.batch-result-text{-webkit-line-clamp:2;white-space:normal;cursor:default;-webkit-box-orient:vertical;flex:1;line-height:1.45;display:-webkit-box;overflow:hidden}.status-done .batch-result-status-icon{color:var(--success)}.status-error .batch-result-status-icon{color:var(--danger)}.batch-preview-panel{background:var(--bg3);border-radius:var(--radius);border:1px solid var(--border);flex-direction:column;display:flex;overflow:hidden}.batch-preview-empty{height:100%;color:var(--text2);text-align:center;justify-content:center;align-items:center;padding:20px;font-size:13px;display:flex}.batch-preview-label{color:var(--text2);border-bottom:1px solid var(--border);text-overflow:ellipsis;white-space:nowrap;padding:8px 10px;font-size:11px;overflow:hidden}.batch-preview-status{color:var(--text2);text-align:center;padding:20px;font-size:13px}.batch-render-setup{border-top:1px solid var(--border);flex-direction:column;gap:10px;padding-top:8px;display:flex}.batch-folder-row{flex-wrap:wrap;align-items:center;gap:10px;display:flex}.batch-folder-display{padding:8px 0}.batch-folder-label{color:var(--text2);flex-shrink:0;font-size:13px}.batch-folder-input{min-width:200px;font-family:var(--mono);flex:1}.batch-folder-path{font-family:var(--mono);color:var(--text);background:var(--bg3);word-break:break-all;border-radius:4px;padding:4px 8px;font-size:12px}.batch-render-footer{justify-content:flex-end;align-items:center;gap:10px;display:flex}.batch-render-mini-bar{background:var(--bg2);border-radius:2px;flex-shrink:0;width:80px;height:4px;overflow:hidden}.batch-render-mini-fill{background:var(--accent);height:100%;transition:width .3s}.batch-mode-toggle{background:var(--bg3);border-radius:var(--radius);gap:4px;padding:3px;display:flex}.batch-mode-btn{color:var(--text2);background:0 0;border-radius:6px;flex:1;padding:7px 12px;font-size:13px;transition:background .15s,color .15s}.batch-mode-btn.active{background:var(--accent);color:#fff;font-weight:600}.batch-size-row{align-items:center;gap:8px;display:flex}.batch-size-label{color:var(--text2);flex-shrink:0;font-size:13px}.batch-size-input{text-align:center;width:60px}.batch-list-textarea{background:var(--bg3);border:1px solid var(--border);border-radius:var(--radius);width:100%;color:var(--text);font-size:13px;font-family:var(--font);resize:vertical;outline:none;padding:10px 12px;line-height:1.7;transition:border-color .15s}.batch-list-textarea:focus{border-color:var(--accent)}.batch-list-textarea::placeholder{color:var(--text2)}.batch-results-meta{align-items:center;gap:8px;display:flex}.batch-error-badge{color:var(--danger);background:#e0555526;border-radius:20px;padding:2px 8px;font-size:12px}.batch-result-actions{flex-shrink:0;gap:4px;margin-left:auto;display:flex}.folder-browser{background:var(--bg3);border:1px solid var(--border);border-radius:var(--radius);flex-direction:column;max-height:220px;display:flex;overflow:hidden}.folder-browser-header{border-bottom:1px solid var(--border);flex-shrink:0;justify-content:space-between;align-items:center;padding:8px 10px;display:flex}.folder-browser-path{font-family:var(--mono);color:var(--text2);text-overflow:ellipsis;white-space:nowrap;flex:1;margin-right:8px;font-size:11px;overflow:hidden}.folder-browser-list{flex-direction:column;flex:1;gap:1px;padding:4px;display:flex;overflow-y:auto}.folder-browser-item{text-align:left;color:var(--text);background:0 0;border-radius:4px;padding:5px 8px;font-size:12px;transition:background .1s}.folder-browser-item:hover{background:#ffffff0f}.folder-browser-item.parent{color:var(--text2);font-style:italic}.folder-browser-loading,.folder-browser-empty{color:var(--text2);padding:8px;font-size:12px}.folder-browser-error{color:var(--danger);padding:6px 10px;font-size:12px}.folder-browser-footer{border-top:1px solid var(--border);flex-shrink:0;padding:6px 8px}.batch-done{border-radius:var(--radius);background:#3ecf8e14;border:1px solid #3ecf8e40;flex-direction:column;align-items:flex-start;gap:12px;padding:16px;display:flex}.batch-done p{font-size:14px;line-height:1.6}.batch-done code{font-family:var(--mono);background:var(--bg3);border-radius:4px;padding:2px 6px;font-size:12px}.meta-overlay{z-index:200;background:#000000b3;justify-content:center;align-items:center;padding:20px;display:flex;position:fixed;inset:0}.meta-modal{background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius);flex-direction:column;width:100%;max-width:960px;max-height:90vh;display:flex;overflow:hidden}.meta-header{border-bottom:1px solid var(--border);flex-shrink:0;justify-content:space-between;align-items:center;padding:14px 18px;display:flex}.meta-title{font-size:15px;font-weight:600}.meta-header-actions{align-items:center;gap:8px;display:flex}.meta-body{flex:1;grid-template-columns:240px 1fr;gap:0;display:grid;overflow:hidden}.meta-preview-col{border-right:1px solid var(--border);flex-direction:column;gap:12px;padding:16px;display:flex;overflow-y:auto}.meta-preview-img{aspect-ratio:1;object-fit:cover;border:1px solid var(--border);background:var(--bg3);border-radius:6px;width:100%}.meta-filepath{color:var(--text2);word-break:break-all;font-size:11px}.meta-stats{flex-direction:column;gap:4px;margin-top:4px;display:flex}.meta-stat{color:var(--text2);justify-content:space-between;font-size:11px;display:flex}.meta-stat span:last-child{color:var(--accent);font-weight:600}.meta-error{color:var(--danger);font-size:12px}.meta-fields-col{flex-direction:column;gap:14px;padding:16px;display:flex;overflow-y:auto}.meta-field{flex-direction:column;gap:6px;display:flex}.meta-field-header{justify-content:space-between;align-items:center;display:flex}.meta-field-header label{color:var(--text2);text-transform:uppercase;letter-spacing:.05em;font-size:12px;font-weight:600}.meta-input{background:var(--bg3);border:1px solid var(--border);color:var(--text1);border-radius:6px;width:100%;padding:8px 10px;font-size:13px}.meta-textarea{background:var(--bg3);border:1px solid var(--border);color:var(--text1);resize:vertical;border-radius:6px;width:100%;padding:8px 10px;font-family:inherit;font-size:13px;line-height:1.5}.meta-kw-textarea{font-size:12px}.meta-kw-count{color:var(--accent);font-weight:600}.meta-kw-tags{flex-wrap:wrap;gap:4px;max-height:80px;display:flex;overflow-y:auto}.meta-kw-tag{color:var(--accent);background:#6366f126;border-radius:4px;padding:2px 7px;font-size:11px}.meta-actions{align-items:center;gap:10px;padding-top:4px;display:flex}.btn-copy{border:1px solid var(--border);color:var(--text2);cursor:pointer;background:0 0;border-radius:4px;padding:2px 8px;font-size:11px}.btn-copy:hover:not(:disabled){background:var(--bg3);color:var(--text1)}.btn-copy:disabled{opacity:.4;cursor:default}.meta-preview-alpha{background-color:#fff;background-image:linear-gradient(45deg,#ccc 25%,#0000 25%),linear-gradient(-45deg,#ccc 25%,#0000 25%),linear-gradient(45deg,#0000 75%,#ccc 75%),linear-gradient(-45deg,#0000 75%,#ccc 75%);background-position:0 0,0 8px,8px -8px,-8px 0;background-size:16px 16px}.meta-alpha-badge{color:var(--accent);text-align:center;background:#6366f11f;border-radius:4px;padding:2px 8px;font-size:11px;font-weight:600}.batch-meta-badge{border-radius:4px;flex-shrink:0;margin-left:4px;padding:1px 6px;font-size:11px}.batch-meta-badge.running{color:var(--accent);animation:1s linear infinite spin}.batch-meta-badge.done{color:var(--success)}.batch-meta-badge.error{color:var(--danger);cursor:help}.kw-page{flex-direction:column;gap:14px;max-width:1100px;margin:0 auto;padding:24px;display:flex}.kw-header{flex-direction:column;gap:4px;display:flex}.kw-title{font-size:22px;font-weight:700}.kw-subtitle{color:var(--text2);font-size:13px}.kw-folder-row{flex-wrap:wrap;align-items:center;gap:8px;display:flex}.kw-folder-label{color:var(--text2);flex-shrink:0;font-size:13px}.kw-folder-input{flex:1;min-width:200px}.kw-error{border-radius:var(--radius);color:var(--danger);background:#e055551f;border:1px solid #e055554d;padding:8px 12px;font-size:13px}.kw-empty{color:var(--text2);text-align:center;padding:40px 0;font-size:14px}.kw-toolbar{background:var(--bg2);border-radius:var(--radius);flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;padding:10px 14px;display:flex}.kw-toolbar-left,.kw-toolbar-right{flex-wrap:wrap;align-items:center;gap:8px;display:flex}.kw-filter-tabs{gap:4px;display:flex}.kw-filter-tab{border:1px solid var(--border);border-radius:var(--radius);color:var(--text2);cursor:pointer;background:0 0;padding:4px 10px;font-size:12px}.kw-filter-tab.active{border-color:var(--accent);color:var(--accent);background:#6c47ff26;font-weight:600}.kw-filter-tab:hover:not(.active){background:var(--bg3);color:var(--text1)}.kw-stats{color:var(--text2);gap:16px;font-size:13px;display:flex}.kw-stat strong{color:var(--text1)}.kw-stat-done strong{color:var(--success)}.kw-stat-saved strong{color:var(--accent)}.kw-file-list{flex-direction:column;gap:2px;display:flex}.kw-file-row{border-radius:var(--radius);border:1px solid #0000;transition:border-color .15s;overflow:hidden}.kw-file-row.status-done{border-color:#4ade8026}.kw-file-row.status-error{border-color:#e0555533}.kw-file-row.status-loading,.kw-file-row.status-keywording{border-color:#6c47ff40}.kw-file-main{background:var(--bg2);cursor:default;align-items:center;gap:10px;padding:8px 12px;display:flex}.kw-file-row.status-done .kw-file-main{cursor:pointer}.kw-file-row.status-done .kw-file-main:hover{background:var(--bg3)}.kw-thumb{background:var(--bg3);border-radius:4px;flex-shrink:0;justify-content:center;align-items:center;width:48px;height:48px;display:flex;overflow:hidden}.kw-thumb-img{object-fit:cover;width:100%;height:100%}.kw-thumb-placeholder{font-size:22px}.kw-file-info{flex:1;min-width:0}.kw-file-name{white-space:nowrap;text-overflow:ellipsis;font-size:13px;font-weight:500;overflow:hidden}.kw-file-size{color:var(--text2);margin-top:2px;font-size:11px}.kw-file-status{text-align:right;flex-shrink:0;min-width:110px}.kw-badge{border-radius:4px;padding:2px 8px;font-size:12px}.kw-badge.running{color:var(--accent);animation:1s linear infinite spin}.kw-badge.done{color:var(--success)}.kw-badge.error{color:var(--danger)}.kw-error-msg{color:var(--danger);background:color-mix(in srgb, var(--danger) 8%, transparent);border-top:1px solid color-mix(in srgb, var(--danger) 20%, transparent);word-break:break-word;padding:6px 12px 6px 52px;font-size:.78rem}.kw-expand-arrow{color:var(--text2);flex-shrink:0;font-size:10px}.kw-meta-expand{background:var(--bg1);border-top:1px solid var(--border);flex-direction:column;gap:10px;padding:12px 14px;display:flex}.kw-meta-row{flex-direction:column;gap:4px;display:flex}.kw-meta-label{color:var(--text2);font-size:12px;font-weight:600}.kw-desc-textarea{font-size:12px}.kw-meta-actions{align-items:center;gap:10px;display:flex}.code-editor-panel{border-top:1px solid var(--border);background:var(--bg-panel);flex-direction:column;display:flex}.code-editor-header{border-bottom:1px solid var(--border);background:var(--bg-card);justify-content:space-between;align-items:center;padding:6px 10px;font-size:.8rem;font-weight:600;display:flex}.code-editor-textarea{resize:vertical;color:#e8e8f0;tab-size:2;background:#1a1a2e;border:none;outline:none;flex:1;min-height:220px;max-height:400px;padding:10px;font-family:Consolas,Fira Mono,monospace;font-size:.72rem;line-height:1.5}.params-bar{background:var(--bg-card);border-bottom:1px solid var(--border);flex-wrap:wrap;align-items:center;gap:10px 16px;padding:8px 12px;display:flex}.param-item{color:var(--text-muted);cursor:default;align-items:center;gap:6px;font-size:.78rem;display:flex}.param-label{white-space:nowrap}.param-color{border:1px solid var(--border);cursor:pointer;background:0 0;border-radius:4px;width:28px;height:22px;padding:1px}.param-range-wrap{align-items:center;gap:4px;display:flex}.param-range{width:70px;accent-color:var(--accent)}.param-range-val{text-align:right;min-width:14px;color:var(--text);font-size:.75rem}.param-select{border:1px solid var(--border);background:var(--bg);color:var(--text);border-radius:4px;padding:2px 4px;font-size:.75rem}.verify-panel{border-top:2px solid var(--border);flex-direction:column;gap:6px;padding:8px 12px;font-size:.82rem;display:flex}.verify-panel.ok{background:#f0fff4;border-color:#4caf50}.verify-panel.fail{background:#fff5f5;border-color:#e53935}.verify-panel.verifying{color:#666;background:#f9f9f9;border-color:#999}.verify-header{flex-wrap:wrap;align-items:center;gap:8px;display:flex}.verify-icon{font-size:1rem}.verify-label{flex:1;font-weight:600}.verify-panel.ok .verify-label{color:#2e7d32}.verify-panel.fail .verify-label{color:#c62828}.verify-errors{color:#c62828;margin:2px 0 0 20px;padding:0;font-size:.78rem;line-height:1.5}.mask-panel{border:1px solid var(--border);background:var(--bg-card);border-radius:6px;margin:4px 0;overflow:hidden}.mask-panel-header{background:var(--bg-secondary);justify-content:space-between;align-items:center;gap:8px;padding:6px 10px;font-size:.82rem;font-weight:600;display:flex}.mask-panel-body{flex-direction:column;gap:8px;padding:10px;display:flex}.mask-controls{flex-direction:column;gap:6px;display:flex}.mask-input-row{align-items:center;gap:6px;display:flex}.mask-file-row{align-items:center;gap:8px;display:flex}.mask-presets{margin-bottom:4px}.mask-preset-grid{flex-wrap:wrap;gap:4px;display:flex}.mask-preset-btn{padding:2px 7px!important;font-size:.72rem!important}.mask-suggestions{flex-wrap:wrap;gap:4px;display:flex}.mask-suggestion-btn{padding:2px 8px!important;font-size:.75rem!important}.mask-preview{background:var(--bg-secondary);border-radius:4px;justify-content:center;padding:4px;display:flex}.mask-error{color:#c62828;padding:4px 0;font-size:.78rem}.unique-panel{border:1px solid var(--border);border-radius:6px;flex-wrap:wrap;align-items:center;gap:8px;margin-top:4px;padding:6px 10px;font-size:.82rem;display:flex}.unique-panel.ok{color:#2e7d32;background:#f0fff4;border-color:#4caf50}.unique-panel.fail{color:#a04000;background:#fff8f0;border-color:#e67e22}.unique-panel.checking{color:#666;background:#f9f9f9;border-color:#999}.unique-icon{font-size:1rem}.studio-mode-tabs{border-bottom:1px solid var(--border);gap:4px;padding:6px 10px 0;display:flex}.studio-mode-tab{color:var(--text-secondary);cursor:pointer;background:0 0;border:1px solid #0000;border-bottom:none;border-radius:6px 6px 0 0;margin-bottom:-1px;padding:5px 14px;font-size:.82rem;font-weight:500;transition:background .15s,color .15s}.studio-mode-tab:hover{background:var(--bg-secondary);color:var(--text)}.studio-mode-tab.active{background:var(--bg);color:var(--text);border-color:var(--border);border-bottom-color:var(--bg)}.prompts-panel{flex-direction:column;flex:1;gap:10px;padding:10px;display:flex;overflow-y:auto}.prompt-sets-bar{flex-wrap:wrap;align-items:flex-start;gap:6px;display:flex}.prompt-sets-label{color:var(--text-secondary);white-space:nowrap;padding-top:3px;font-size:.75rem}.prompt-sets-chips{flex-wrap:wrap;gap:4px;display:flex}.prompt-set-chip{border:1px solid var(--border);background:var(--bg-secondary);color:var(--text);cursor:pointer;border-radius:12px;padding:2px 10px;font-size:.75rem;transition:background .15s}.prompt-set-chip:hover{background:var(--bg-hover,#e8e8e8)}.prompt-set-chip.active{background:var(--accent);color:#fff;border-color:var(--accent)}.prompt-generator-row{align-items:center;gap:8px;display:flex}.prompt-topic-input{border:1px solid var(--border);background:var(--bg);color:var(--text);border-radius:6px;flex:1;padding:7px 10px;font-size:.85rem}.prompt-topic-input:focus{border-color:var(--accent);outline:none}.prompt-gen-error{color:#c62828;padding:4px 0;font-size:.82rem}.prompts-empty{color:var(--text-secondary);text-align:center;flex-direction:column;flex:1;justify-content:center;align-items:center;gap:6px;padding:20px;font-size:.85rem;display:flex}.prompt-cards{flex-direction:column;gap:8px;display:flex}.prompt-cards-header{align-items:baseline;gap:8px;padding-bottom:4px;display:flex}.prompt-cards-topic{font-size:.9rem;font-weight:600}.prompt-card{border:1px solid var(--border);background:var(--bg-secondary);border-radius:8px;align-items:flex-start;gap:10px;padding:10px;display:flex}.prompt-card-num{color:var(--accent);min-width:18px;padding-top:2px;font-size:.75rem;font-weight:700}.prompt-card-content{flex-direction:column;flex:1;gap:4px;display:flex}.prompt-card-en{color:var(--text);font-size:.82rem;line-height:1.45}.prompt-card-ru{color:var(--text-secondary);font-size:.78rem;font-style:italic;line-height:1.4}.prompt-card-use{white-space:nowrap;align-self:flex-start;margin-top:2px}.sudoku-page{height:100%;display:flex;overflow:hidden}.sudoku-settings{border-right:1px solid var(--border);background:var(--bg-card);flex-direction:column;flex-shrink:0;gap:0;width:300px;min-width:280px;padding:16px 14px 32px;display:flex;overflow-y:auto}.sset-title{color:var(--text);margin-bottom:4px;font-size:1.1rem;font-weight:700}.sset-desc{color:var(--text-muted);margin-bottom:14px;font-size:.78rem;line-height:1.4}.sset-section{border-bottom:1px solid var(--border);flex-direction:column;gap:5px;padding:10px 0;display:flex}.sset-section:last-child{border-bottom:none}.sset-label{letter-spacing:.08em;color:var(--text-muted);margin-bottom:4px;font-size:.67rem;font-weight:600}.sset-hint{color:var(--text-muted);font-size:.74rem}.sset-btns{flex-wrap:wrap;gap:4px;display:flex}.sset-btn{border:1px solid var(--border);background:var(--bg);color:var(--text);cursor:pointer;white-space:nowrap;border-radius:6px;padding:4px 10px;font-size:.76rem;transition:all .15s}.sset-btn:hover{border-color:var(--accent);color:var(--accent)}.sset-btn.active{background:var(--accent);border-color:var(--accent);color:#fff}.sset-slider-row{color:var(--text-muted);justify-content:space-between;align-items:center;font-size:.76rem;display:flex}.sset-val{color:var(--text-secondary);text-align:right;min-width:36px;font-size:.74rem}.sset-slider{width:100%;accent-color:var(--accent);cursor:pointer;margin:1px 0}.sset-colors{grid-template-columns:1fr 1fr;gap:5px 8px;display:grid}.sset-color-item{color:var(--text-muted);cursor:pointer;align-items:center;gap:6px;font-size:.74rem;display:flex}.sset-color-item input[type=color]{border:1px solid var(--border);cursor:pointer;background:0 0;border-radius:4px;flex-shrink:0;width:26px;height:22px;padding:0}.sset-check{color:var(--text-muted);cursor:pointer;align-items:center;gap:7px;font-size:.76rem;display:flex}.sset-check input[type=checkbox]{accent-color:var(--accent);cursor:pointer;flex-shrink:0;width:14px;height:14px}.sset-regen{border:1px solid var(--border);background:var(--bg);width:100%;color:var(--text);cursor:pointer;text-align:center;border-radius:8px;padding:7px 12px;font-size:.8rem;transition:border-color .15s,color .15s}.sset-regen:hover:not(:disabled){border-color:var(--accent);color:var(--accent)}.sset-regen:disabled{opacity:.5;cursor:not-allowed}.sset-dl-row{gap:6px;display:flex}.sset-dl{border:1px solid var(--border);background:var(--bg);color:var(--text);cursor:pointer;text-align:center;border-radius:8px;flex:1;padding:8px 4px;font-size:.8rem;transition:all .15s}.sset-dl:hover:not(:disabled){border-color:var(--accent);color:var(--accent)}.sset-dl.primary{background:var(--accent);border-color:var(--accent);color:#fff;font-weight:600}.sset-dl.primary:hover:not(:disabled){opacity:.9}.sset-dl:disabled{opacity:.45;cursor:not-allowed}.save-panel{flex-direction:column;gap:6px;display:flex}.save-panel-formats{gap:6px;display:flex}.save-panel-formats .sset-btn{text-align:center;flex:1}.save-panel-batch{border-top:1px solid var(--border);margin-top:4px;padding-top:10px}.wc-textarea{resize:vertical;background:var(--bg3);border:1px solid var(--border);border-radius:var(--radius);width:100%;min-height:110px;color:var(--text);box-sizing:border-box;padding:8px;font-size:.82rem;line-height:1.5}.wc-textarea:focus{border-color:var(--accent);outline:none}.sudoku-preview{flex-direction:column;flex:1;justify-content:flex-start;align-items:center;gap:24px;padding:24px 20px;display:flex;position:relative;overflow:auto}.sudoku-generating{color:var(--text-muted);pointer-events:none;font-size:.95rem;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.sudoku-canvases{flex-wrap:wrap;justify-content:center;gap:24px;transition:opacity .2s;display:flex}.sudoku-canvas-wrap{flex-direction:column;align-items:center;gap:8px;display:flex}.sudoku-canvas{border-radius:8px;display:block;box-shadow:0 4px 20px #0000001f}.sudoku-canvas-label{color:var(--text-muted);letter-spacing:.04em;font-size:.76rem;font-weight:500}.sset-save-msg{color:var(--success,#4caf50);word-break:break-all;padding:3px 0;font-size:.73rem;line-height:1.35}.sset-save-msg:not(:empty):has-text-starting-with("Ошибка"){color:var(--error,#e53935)}.sset-lang-preview{color:var(--text-muted);background:var(--bg);border:1px solid var(--border);border-radius:4px;padding:4px 6px;font-size:.72rem;font-style:italic;line-height:1.4}.maze-file-btn{border:1px dashed var(--border);border-radius:var(--radius);color:var(--text2);cursor:pointer;text-align:center;padding:6px 10px;font-size:.8rem;transition:border-color .15s,color .15s;display:block}.maze-file-btn:hover{border-color:var(--accent);color:var(--accent)}
