:root{--bg: #0a0a0f;--bg-card: #12121a;--bg-input: #1a1a26;--bg-hover: #222233;--border: #2a2a3a;--text: #e0e0e8;--text-dim: #8888a0;--accent: #00d4aa;--accent-dim: #00a884;--danger: #ff4466;--radius: 8px}*{margin:0;padding:0;box-sizing:border-box}body{font-family:Consolas,SF Mono,Fira Code,monospace;background:var(--bg);color:var(--text);min-height:100vh}.header{display:flex;justify-content:space-between;align-items:center;padding:16px 24px;border-bottom:1px solid var(--border);background:var(--bg-card)}@media (max-width: 600px){.header{padding:12px 14px;gap:8px}.logo h1{font-size:16px}.tagline{display:none}.credits-value{font-size:18px}.credits-label{display:none}.credits-unit{margin-right:6px}.btn-recharge{padding:5px 10px;font-size:12px}.tab-nav{padding:0 10px;overflow-x:auto}.tab-btn{padding:10px 14px;font-size:13px;white-space:nowrap}.main{padding:0 12px;margin:16px auto}}.logo{display:flex;align-items:center;gap:10px}.mode-btn{background:var(--bg-input);border:1px solid var(--border);border-radius:var(--radius);color:var(--text);padding:8px 16px;cursor:pointer;font-size:14px;font-family:inherit;display:flex;align-items:center;gap:8px}.mode-btn:hover{background:var(--bg-hover)}.mode-arrow{font-size:10px;color:#94a3b8}.mode-dropdown{position:absolute;top:100%;right:0;margin-top:4px;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;z-index:100;min-width:200px}.mode-dropdown button{display:block;width:100%;text-align:left;padding:12px 16px;background:none;border:none;color:var(--text);cursor:pointer;font-family:inherit;font-size:14px;border-bottom:1px solid var(--border)}.mode-dropdown button:last-child{border-bottom:none}.mode-dropdown button:hover{background:var(--bg-hover)}.mode-dropdown button.active{background:var(--bg-hover);color:#10b981}.mode-desc{display:block;font-size:11px;color:#94a3b8;margin-top:2px}.logo-icon{font-size:24px}.logo h1{font-size:20px;font-weight:700;color:#10b981;letter-spacing:1px}.tagline{font-size:12px;color:#94a3b8;border:1px solid var(--border);padding:2px 8px;border-radius:4px}.credits-bar{display:flex;align-items:center;gap:6px;flex-shrink:1;min-width:0;overflow:hidden}.credits-label{font-size:12px;color:#94a3b8}.credits-value{font-size:22px;font-weight:700;color:#10b981;flex-shrink:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.credits-value.low{color:var(--danger)}.credits-unit{font-size:12px;color:#94a3b8;margin-right:12px}.btn-recharge{background:#10b981;color:#fff;border:none;padding:6px 16px;border-radius:var(--radius);font-weight:700;font-size:13px;cursor:pointer;transition:background .2s;font-family:inherit}.btn-recharge:hover{background:var(--accent-dim)}.btn-login{background:none;border:1px solid #10b981;color:#10b981;padding:5px 14px;border-radius:var(--radius);font-weight:600;font-size:13px;cursor:pointer;transition:all .2s;font-family:inherit;margin-left:8px}.btn-login:hover{background:#10b981;color:#fff}.user-info-bar{display:flex;align-items:center;gap:8px;margin-left:10px}.user-name{color:#10b981;font-size:13px;font-weight:600}.btn-logout{background:none;border:1px solid rgba(255,255,255,.2);color:#94a3b8;padding:4px 10px;border-radius:var(--radius);font-size:12px;cursor:pointer;transition:all .2s;font-family:inherit}.btn-logout:hover{border-color:var(--danger);color:var(--danger)}.tab-nav{display:flex;gap:0;padding:0 24px;border-bottom:1px solid var(--border);background:linear-gradient(180deg,#00d4aa0f,#00d4aa03);border-top:1px solid rgba(0,212,170,.1)}.tab-btn{background:none;border:none;color:#94a3b8;padding:12px 28px;font-size:14px;cursor:pointer;border-bottom:2px solid transparent;transition:all .2s;font-family:inherit;position:relative}.tab-btn:hover{color:var(--text)}.tab-btn.active{color:#10b981;border-bottom-color:#10b981;background:#00d4aa0a}.main{max-width:960px;margin:32px auto;padding:0 24px}.toolbox-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-top:16px}.toolbox-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:32px 24px;cursor:pointer;transition:all .25s;display:flex;flex-direction:column;align-items:center;text-align:center;position:relative}.toolbox-card:hover{border-color:#10b981;background:var(--bg-hover);transform:translateY(-2px)}.toolbox-card-icon{font-size:40px;margin-bottom:16px}.toolbox-card-title{font-size:17px;font-weight:700;color:var(--text);margin-bottom:10px}.toolbox-card-desc{font-size:12px;color:#94a3b8;line-height:1.6}.toolbox-card-arrow{position:absolute;right:16px;top:50%;transform:translateY(-50%);font-size:20px;color:#94a3b8;transition:color .2s}.toolbox-card:hover .toolbox-card-arrow{color:#10b981}.toolbox-active{margin-top:8px}.btn-back{background:none!important;border:1px solid var(--border)!important;color:var(--text-dim)!important;padding:6px 16px!important;border-radius:var(--radius)!important;font-size:13px!important;font-family:inherit!important;cursor:pointer;transition:all .2s;margin-bottom:20px;display:inline-block}.btn-back:hover{border-color:#10b981!important;color:#10b981!important}.module-panel{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:24px}.module-title{font-size:18px;margin-bottom:8px;color:#10b981}.module-section{margin-bottom:16px}.module-label{display:block;font-size:13px;color:#94a3b8;margin-bottom:6px}.placeholder-page{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:400px;text-align:center}.placeholder-icon{font-size:64px;margin-bottom:20px;opacity:.6}.placeholder-text{font-size:28px;font-weight:700;color:#94a3b8;margin-bottom:12px}.placeholder-sub{font-size:14px;color:#94a3b8;opacity:.5}.hint{font-size:12px;color:#94a3b8;margin-bottom:16px;line-height:1.5}.row{display:flex;align-items:center;gap:8px;margin-bottom:12px}.row span{font-size:13px;color:#94a3b8}select{background:var(--bg-input);color:var(--text);border:1px solid var(--border);padding:6px 12px;border-radius:var(--radius);font-family:inherit;font-size:13px;cursor:pointer;outline:none}select:focus{border-color:#10b981}textarea{width:100%;background:var(--bg-input);color:var(--text);border:1px solid var(--border);border-radius:var(--radius);padding:12px;font-family:inherit;font-size:13px;line-height:1.6;resize:vertical;margin-bottom:12px;outline:none}textarea::placeholder{color:#94a3b8;opacity:.6}textarea:focus{border-color:#10b981}button{font-family:inherit}button:not(.tab-btn):not(.btn-recharge):not(.modal-close):not(.btn-pay):not(.btn-copy):not(.btn-back):not(.btn-swap):not(.btn-modify):not(.mode-btn):not(.btn-reset):not(.scope-tab):not(.tpl-btn):not(.admin-btn-sm):not(.admin-btn-ghost):not(.toggle-btn):not(.admin-modal-close){background:#10b981;color:#fff;border:none;padding:10px 28px;border-radius:var(--radius);font-weight:700;font-size:14px;cursor:pointer;transition:background .2s}button:not(.tab-btn):not(.btn-recharge):not(.modal-close):not(.btn-pay):not(.btn-copy):not(.btn-back):not(.btn-swap):not(.btn-modify):not(.mode-btn):not(.btn-reset):not(.scope-tab):not(.tpl-btn):not(.admin-btn-sm):not(.admin-btn-ghost):not(.toggle-btn):not(.admin-modal-close):hover{background:var(--accent-dim)}button:disabled{opacity:.5;cursor:not-allowed}.scope-tabs{display:flex;gap:8px;margin-bottom:12px;width:fit-content}.scope-tab{background:var(--bg-input);border:1px solid #00d4aa;color:#00d4aa;padding:8px 16px;font-size:13px;font-weight:600;font-family:inherit;cursor:pointer;transition:all .2s;border-radius:var(--radius)}.scope-tab:hover{background:#00d4aa;color:#fff}.scope-tab.active,.scope-tab.active:hover{background:#00d4aa;color:#fff;border-color:#00d4aa}.error{color:var(--danger);font-size:13px;margin-top:8px}.result-area{margin-top:20px;border-top:1px solid var(--border);padding-top:16px}.result-area h3{font-size:14px;color:#94a3b8;margin-bottom:8px}.result-area pre{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius);padding:16px;font-size:12px;line-height:1.6;overflow-x:auto;white-space:pre-wrap;word-break:break-all}.btn-copy{margin-top:8px;background:var(--bg-input)!important;color:var(--text-dim)!important;border:1px solid var(--border)!important;padding:4px 12px!important;font-size:12px!important;border-radius:4px!important;cursor:pointer;transition:all .2s;font-family:inherit}.btn-copy:hover{border-color:#10b981!important;color:#10b981!important}.copy-row{display:flex;align-items:center;gap:8px}.project-workbench{margin-top:8px}.flow-guide{display:flex;align-items:flex-start;gap:0;padding:16px 20px;margin-bottom:16px;background:linear-gradient(135deg,#00d4aa0a,#00a88405);border:1px solid rgba(0,212,170,.15);border-radius:12px;overflow-x:auto;-webkit-overflow-scrolling:touch}.flow-step{display:flex;flex-direction:column;align-items:center;flex:1;min-width:100px;text-align:center;position:relative;padding:8px 4px;border-radius:10px;transition:all .3s}.flow-step-active{background:#00d4aa0f}.flow-step-icon-wrap{position:relative;margin-bottom:8px}.flow-step-icon{display:flex;align-items:center;justify-content:center;width:44px;height:44px;border-radius:50%;font-size:18px;background:var(--bg-input);border:2px solid var(--border);transition:all .3s}.flow-step-active .flow-step-icon{border-color:#10b981;background:#00d4aa1a;box-shadow:0 0 12px #00d4aa33}.flow-step-done .flow-step-icon{border-color:#10b981;background:#10b981;color:#fff;font-size:16px;font-weight:700}.flow-step-badge{position:absolute;top:-4px;right:-8px;font-size:9px;font-weight:700;color:#fff;background:#10b981;padding:1px 5px;border-radius:8px;white-space:nowrap;line-height:1.4}.flow-step-content{display:flex;flex-direction:column;gap:2px}.flow-step-title{font-size:13px;font-weight:700;color:#ffffffd9;transition:color .3s}.flow-step-active .flow-step-title{color:#10b981}.flow-step-done .flow-step-title{color:#fffffff2}.flow-step-desc{font-size:10px;color:#ffffff8c}.flow-step-sub{font-size:10px;color:#10b981;font-weight:600}.flow-step-action{margin-top:6px;padding:3px 12px!important;background:#10b981!important;color:#000!important;border:none!important;border-radius:10px!important;font-size:11px!important;font-weight:700!important;cursor:pointer;font-family:inherit;transition:all .2s;white-space:nowrap}.flow-step-action:hover{background:var(--accent-dim)!important}.flow-arrow{display:flex;align-items:center;padding-top:18px;flex-shrink:0;min-width:28px}.flow-arrow-line{flex:1;height:2px;background:var(--border);border-radius:1px;transition:background .3s}.flow-arrow-done .flow-arrow-line{background:#10b981}.flow-arrow-head{font-size:18px;color:#94a3b8;margin-left:-2px;line-height:1;transition:color .3s}.flow-arrow-done .flow-arrow-head{color:#10b981}@media (max-width: 600px){.flow-guide{padding:12px 10px}.flow-step{min-width:72px;padding:6px 2px}.flow-step-icon{width:36px;height:36px;font-size:15px}.flow-step-title{font-size:11px}.flow-step-desc{display:none}.flow-step-sub{font-size:9px}.flow-arrow{min-width:16px;padding-top:14px}.flow-arrow-head{font-size:14px}}.workbench-tabs{display:flex;gap:8px;margin-bottom:16px}.workbench-main{display:grid;grid-template-columns:1fr 1fr;gap:24px}.workbench-single-col{display:flex;flex-direction:column;gap:16px}.workbench-single-col .workbench-toolbar,.workbench-single-col .project-tree{background:var(--bg-card);border:1px solid #333;border-radius:var(--radius);padding:16px;box-shadow:0 1px 3px #0000004d}.workbench-left,.workbench-right{display:flex;flex-direction:column;gap:16px}.workbench-toolbar{background:var(--bg-card);border:1px solid #333;border-radius:var(--radius);padding:12px 16px;box-shadow:0 1px 3px #0000004d}.toolbar-info-row{display:flex;align-items:center;gap:16px;margin-bottom:8px}.input-project-name{width:60%;padding:8px 12px;background:var(--bg-input);color:var(--text);border:1px solid #333;border-radius:4px;font-family:inherit;font-size:13px;outline:none;transition:border-color .2s}.input-project-name:focus{border-color:#00d4aa}.input-project-name::placeholder{color:#94a3b8;opacity:.5}.select-platform{width:38%;padding:8px 12px;background:var(--bg-input);color:var(--text);border:1px solid #333;border-radius:4px;font-family:inherit;font-size:13px;outline:none;cursor:pointer;transition:border-color .2s}.select-platform:focus{border-color:#00d4aa}.stat-selected-inline{font-size:12px;color:#ccc;white-space:nowrap;flex-shrink:0}.stat-selected-inline strong{color:#00d4aa}.toolbar-stats-compact{display:flex;justify-content:space-between;align-items:baseline;padding:4px 0 8px;font-size:12px;color:#ccc;border-bottom:1px solid #333;margin-bottom:10px}.toolbar-stats-compact .stat-selected-inline{text-align:left}.toolbar-stats-right{display:flex;gap:16px;align-items:baseline}.stat-credits-compact,.stat-balance-compact{font-size:12px;white-space:nowrap}.stat-credits-compact strong,.stat-balance-compact strong{color:#00d4aa}.credits-ok{color:#10b981}.credits-low{color:var(--danger)}.toolbar-actions{display:flex;gap:8px;align-items:center}.btn-select-all{background:var(--bg-input)!important;color:#10b981!important;border:1px solid #10b981!important;padding:8px 16px!important;border-radius:var(--radius)!important;font-size:13px!important;font-weight:600!important;font-family:inherit!important;cursor:pointer;transition:all .2s}.btn-select-all:hover{background:#10b981!important;color:#000!important}.btn-generate-project{flex:1;min-width:200px;background:#10b981!important;color:#000!important;border:none!important;padding:10px 20px!important;border-radius:var(--radius)!important;font-weight:700!important;font-size:14px!important;font-family:inherit!important;cursor:pointer;transition:background .2s;display:flex;align-items:center;justify-content:center;gap:8px}.btn-generate-project:hover:not(:disabled){background:var(--accent-dim)!important;box-shadow:0 0 0 2px #00d4aa!important}.btn-generate-project:disabled{opacity:.5;cursor:not-allowed}.btn-generating{display:inline-flex;align-items:center;gap:8px}.btn-save-template{background:var(--bg-input)!important;color:#10b981!important;border:1px solid #10b981!important;padding:10px 20px!important;border-radius:var(--radius)!important;font-weight:700!important;font-size:14px!important;cursor:pointer;transition:all .2s;font-family:inherit;white-space:nowrap}.btn-save-template:hover{background:#10b981!important;color:#000!important}.btn-download-zip{background:linear-gradient(135deg,#00d4aa,#00a884)!important;color:#000!important;border:none!important;padding:10px 20px!important;border-radius:var(--radius)!important;font-weight:700!important;font-size:14px!important;cursor:pointer;transition:all .2s;font-family:inherit;white-space:nowrap;animation:pulse-download 2s infinite}.btn-download-zip:hover{background:linear-gradient(135deg,#00e4ba,#059669)!important;transform:scale(1.02)}@keyframes pulse-download{0%,to{box-shadow:0 0 #00d4aa66}50%{box-shadow:0 0 0 8px #00d4aa00}}.btn-abort{background:var(--bg-input)!important;color:var(--danger)!important;border:1px solid var(--danger)!important;padding:10px 16px!important;border-radius:var(--radius)!important;font-weight:700!important;font-size:14px!important;font-family:inherit!important;cursor:pointer;transition:all .2s;white-space:nowrap;flex-shrink:0}.error-bar{display:flex;align-items:center;justify-content:space-between;gap:8px;padding:8px 12px;margin-top:8px;background:#ff446614;border:1px solid rgba(255,68,102,.3);border-radius:var(--radius);color:var(--danger);font-size:12px}.btn-retry-sm{background:var(--bg-input)!important;color:#10b981!important;border:1px solid #10b981!important;padding:4px 12px!important;border-radius:4px!important;font-size:11px!important;font-family:inherit!important;cursor:pointer;transition:all .2s;white-space:nowrap}.btn-retry-sm:hover{background:#10b981!important;color:#000!important}.success-msg{color:#10b981;font-size:13px;margin-top:8px;padding:6px 12px;background:#00d4aa14;border:1px solid rgba(0,212,170,.3);border-radius:var(--radius);animation:fadeIn .3s}.project-tree{background:var(--bg-card);border:1px solid #333;border-radius:var(--radius);padding:12px 8px;max-height:700px;overflow-y:auto;box-shadow:0 1px 3px #0000004d}.dep-hint-banner{display:flex;align-items:center;gap:8px;padding:8px 12px;margin-bottom:8px;background:#ffaa441a;border:1px solid rgba(255,170,68,.3);border-radius:6px;font-size:12px;color:#fa4}.dep-hint-icon{font-size:16px;flex-shrink:0}.dep-hint-down{color:#fa4;margin:0 4px}.dep-hint-up{color:#6cf;margin:0 4px}.dep-hint-note{color:#888;font-size:11px}.tree-root-title-row{display:flex;align-items:center;justify-content:space-between;padding:6px 12px 10px;border-bottom:1px solid var(--border);margin-bottom:4px}.tree-root-title-row .tree-root-title{font-size:14px;font-weight:700;color:var(--text);letter-spacing:.5px;padding:0;border:none;margin:0}.tree-root-title{font-size:14px;font-weight:700;color:var(--text);padding:6px 12px 10px;border-bottom:1px solid var(--border);margin-bottom:4px;letter-spacing:.5px}.tree-group{margin-bottom:2px;position:relative}.tree-group-header{display:flex;align-items:center;gap:8px;padding:8px 12px;cursor:pointer;border-radius:var(--radius);transition:background .2s;-webkit-user-select:none;user-select:none}.tree-group-header:hover{background:var(--bg-hover)}.tree-toggle{font-size:10px;color:#94a3b8;width:14px;text-align:center;flex-shrink:0}.tree-group-label{font-size:14px;font-weight:700;color:var(--text);flex:1;letter-spacing:.3px}.tree-group-count{font-size:11px;color:#94a3b8;background:var(--bg-input);padding:2px 8px;border-radius:10px}.tree-group-tagline{font-size:11px;color:#00d4aa;padding:2px 12px 6px 34px;opacity:.8;font-style:italic}.tree-children{padding-left:24px;position:relative}.tree-children:before{content:"";position:absolute;left:14px;top:0;bottom:8px;width:1px;background:var(--border)}.tree-leaf{padding:5px 12px;border-radius:var(--radius);margin-bottom:1px;transition:all .2s;border:1px solid transparent;position:relative}.tree-leaf:before{content:"";position:absolute;left:-10px;top:14px;width:10px;height:1px;background:var(--border)}.tree-leaf-selected{background:#00d4aa0f;border-color:#00d4aa33}.tree-leaf-row{display:flex;align-items:center;justify-content:space-between;gap:10px}.tree-checkbox-label{display:flex;align-items:center;gap:8px;cursor:pointer;flex:1;min-width:0}.tree-checkbox{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:18px;height:18px;border:2px solid #333;border-radius:3px;background:var(--bg-input);cursor:pointer;position:relative;transition:all .2s;flex-shrink:0}.tree-checkbox:checked{background:#00d4aa;border-color:#00d4aa}.tree-checkbox:checked:after{content:"✓";position:absolute;top:-1px;left:2px;font-size:13px;color:#fff;font-weight:700}.tree-leaf-name{font-size:13px;color:var(--text);font-weight:600;font-family:Consolas,Monaco,Courier New,monospace;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.tree-leaf-selected .tree-leaf-name{color:#00d4aa}.tree-selected-tag{font-size:10px;color:#00d4aa;background:#00d4aa26;padding:1px 6px;border-radius:3px;font-weight:600;flex-shrink:0}.tree-auto-tag{font-size:10px;color:#fa4;background:#ffaa4426;padding:1px 6px;border-radius:3px;font-weight:600;flex-shrink:0}.tree-dep-reason{display:flex;flex-wrap:wrap;gap:4px;margin-top:2px;padding-left:24px}.dep-reason-tag{font-size:9px;color:#6cf;background:#64c8ff14;padding:1px 5px;border-radius:2px;white-space:nowrap}.tree-leaf-auto{border-left:2px solid #ffaa44}.tree-checkbox-auto{accent-color:#ffaa44}.device-config-row{display:flex;align-items:center;gap:6px;padding:4px 8px 4px 28px;margin-top:4px;background:#64c8ff0d;border-radius:4px}.device-config-label{font-size:11px;color:#94a3b8;white-space:nowrap}.device-config-input{width:48px;padding:3px 6px;background:var(--bg-input);color:var(--text-main);border:1px solid #444;border-radius:4px;font-size:11px;text-align:center;outline:none}.device-config-input:focus{border-color:#6cf}.device-config-prefix{width:72px;text-align:left}.device-config-preview{font-size:10px;color:#6cf;white-space:nowrap}.btn-io-config{padding:3px 10px;background:#64c8ff1a;border:1px solid rgba(100,200,255,.3);border-radius:4px;color:#6cf;font-size:11px;cursor:pointer;white-space:nowrap;transition:all .2s}.btn-io-config:hover{background:#64c8ff33}.btn-io-config:disabled{opacity:.5;cursor:not-allowed}.io-modal{background:var(--bg-card);border:1px solid #444;border-radius:12px;width:600px;max-width:90vw;max-height:80vh;display:flex;flex-direction:column;box-shadow:0 8px 32px #00000080}.io-modal-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid #333}.io-modal-header h3{margin:0;font-size:16px;color:var(--text-main)}.io-modal-body{padding:16px 20px;overflow-y:auto;flex:1}.io-import-section{margin-bottom:16px}.io-import-tabs{display:flex;align-items:center;gap:8px;margin-bottom:10px;flex-wrap:wrap}.io-import-title{font-size:12px;color:#94a3b8}.io-import-or{font-size:11px;color:#666}.io-file-label{padding:4px 12px;background:#64c8ff1a;border:1px solid rgba(100,200,255,.3);border-radius:4px;color:#6cf;font-size:12px;cursor:pointer;transition:all .2s}.io-file-label:hover{background:#64c8ff33}.io-paste-area{width:100%;padding:10px;background:var(--bg-input);color:var(--text-main);border:1px solid #333;border-radius:6px;font-size:11px;font-family:Consolas,Courier New,monospace;resize:vertical;outline:none;margin-bottom:8px}.io-paste-area:focus{border-color:#6cf}.btn-io-parse{padding:6px 16px;background:#64c8ff26;border:1px solid rgba(100,200,255,.3);border-radius:4px;color:#6cf;font-size:12px;cursor:pointer;transition:all .2s}.btn-io-parse:hover:not(:disabled){background:#64c8ff40}.btn-io-parse:disabled{opacity:.4;cursor:not-allowed}.io-table-section{border-top:1px solid #333;padding-top:12px}.io-table-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px;font-size:12px;color:#94a3b8}.btn-io-clear{padding:2px 10px;background:#ff64641a;border:1px solid rgba(255,100,100,.3);border-radius:4px;color:#f66;font-size:11px;cursor:pointer}.io-table-scroll{max-height:240px;overflow-y:auto}.io-data-table{width:100%;border-collapse:collapse;font-size:11px}.io-data-table th{text-align:left;padding:6px 8px;background:#ffffff0d;color:#94a3b8;border-bottom:1px solid #333;font-weight:600}.io-data-table td{padding:5px 8px;border-bottom:1px solid #222;color:var(--text-main)}.io-data-table .io-addr{color:#6cf;font-family:Consolas,monospace}.io-modal-footer{padding:12px 20px;border-top:1px solid #333;display:flex;justify-content:flex-end}.dep-panel{padding:16px}.dep-panel-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}.dep-panel-header h3{margin:0;font-size:16px;color:var(--text-main)}.dep-panel-stats{display:flex;gap:12px;font-size:12px}.dep-layer-stat{font-weight:600}.dep-source-tag{color:#888;font-size:11px}.dep-panel-toolbar{display:flex;align-items:center;gap:8px;margin-bottom:16px;flex-wrap:wrap}.dep-filter-input{padding:6px 12px;background:var(--bg-input);color:var(--text-main);border:1px solid #333;border-radius:4px;font-size:12px;width:180px;outline:none}.dep-filter-input:focus{border-color:#6cf}.dep-toolbar-btn{padding:6px 14px;background:#ffffff0d;border:1px solid #444;border-radius:4px;color:#94a3b8;font-size:12px;cursor:pointer;transition:all .2s}.dep-toolbar-btn:hover:not(:disabled){background:#ffffff1a}.dep-toolbar-btn:disabled{opacity:.5;cursor:not-allowed}.dep-btn-save{background:#64c8ff1a;border-color:#64c8ff4d;color:#6cf}.dep-btn-save:hover:not(:disabled){background:#64c8ff33}.dep-btn-reset{background:#ffaa441a;border-color:#ffaa444d;color:#fa4}.dep-btn-reset:hover:not(:disabled){background:#fa43}.dep-msg{font-size:12px;color:#6bcb77;padding:4px 8px}.dep-editor-list{display:flex;flex-direction:column;gap:12px;max-height:600px;overflow-y:auto}.dep-editor-wrapper{position:relative}.dep-delete-node{position:absolute;top:8px;right:8px;padding:2px 8px;background:#ff64641a;border:1px solid rgba(255,100,100,.2);border-radius:3px;color:#f66;font-size:10px;cursor:pointer;opacity:0;transition:opacity .2s}.dep-editor-wrapper:hover .dep-delete-node{opacity:1}.dep-editor-node{background:var(--bg-card);border:1px solid #333;border-left:3px solid;border-radius:6px;padding:12px}.dep-editor-header{display:flex;align-items:center;gap:8px;margin-bottom:10px}.dep-editor-layer{font-size:11px;font-weight:700;padding:1px 6px;border-radius:3px;background:#ffffff0d}.dep-editor-id{font-size:13px;color:var(--text-main);font-weight:600}.dep-editor-section{margin-bottom:8px;padding-left:12px}.dep-section-label{font-size:11px;color:#888;margin-bottom:4px}.dep-tags-row{display:flex;flex-wrap:wrap;gap:4px;margin-bottom:4px}.dep-tag{display:inline-flex;align-items:center;gap:4px;padding:2px 8px;border:1px solid;border-radius:3px;font-size:11px;font-family:Consolas,monospace}.dep-tag-remove{cursor:pointer;font-size:10px;opacity:.6;margin-left:2px}.dep-tag-remove:hover{opacity:1}.dep-add-row{display:flex;gap:4px;align-items:center}.dep-add-input{padding:3px 8px;background:var(--bg-input);color:var(--text-main);border:1px solid #333;border-radius:3px;font-size:11px;outline:none;flex:1;min-width:0}.dep-add-input:focus{border-color:#6cf}.dep-add-gvl{flex:.4}.dep-add-template{flex:.6}.dep-add-btn{padding:3px 10px;background:#64c8ff1a;border:1px solid rgba(100,200,255,.3);border-radius:3px;color:#6cf;font-size:12px;cursor:pointer;flex-shrink:0}.dep-add-btn:hover{background:#64c8ff33}.dep-gvl-item{display:flex;align-items:center;gap:6px;padding:3px 0;font-size:11px}.dep-gvl-gvl{color:#ffd93d;font-family:Consolas,monospace;min-width:80px}.dep-gvl-template{color:#94a3b8;font-family:Consolas,monospace;flex:1}.dep-empty{text-align:center;color:#666;padding:40px;font-size:13px}.tree-template-select{width:120px;padding:6px 12px;background:var(--bg-input);color:#94a3b8;border:1px solid #333;border-radius:4px;font-size:11px;font-family:inherit;cursor:pointer;outline:none;transition:border-color .2s;flex-shrink:0}.tree-template-select:focus{border-color:#00d4aa}.tree-leaf-desc{font-size:11px;color:#94a3b8;padding:2px 0 2px 30px;line-height:1.4;opacity:.7}.tree-custom-req{width:calc(100% - 30px);margin:4px 0 0 30px;padding:8px 10px;background:var(--bg-input);color:var(--text);border:1px solid #333;border-radius:4px;font-size:12px;font-family:inherit;line-height:1.5;resize:vertical;outline:none;transition:border-color .2s;box-sizing:border-box}.tree-custom-req:focus{border-color:#00d4aa}.tree-custom-req::placeholder{color:#666}.tree-subgroups{padding-left:20px;position:relative}.tree-subgroups:before{content:"";position:absolute;left:10px;top:0;bottom:8px;width:1px;background:var(--border)}.tree-subgroup{margin-bottom:2px;position:relative}.tree-subgroup:before{content:"";position:absolute;left:-10px;top:14px;width:10px;height:1px;background:var(--border)}.tree-subgroup-header{display:flex;align-items:center;gap:6px;padding:6px 10px;cursor:pointer;border-radius:var(--radius);transition:background .2s;-webkit-user-select:none;user-select:none}.tree-subgroup-header:hover{background:var(--bg-hover)}.tree-toggle-sm{font-size:9px;color:#94a3b8;width:12px;text-align:center;flex-shrink:0}.tree-subgroup-label{font-size:12px;font-weight:600;color:#00d4aa;opacity:.85;flex:1}.tree-subgroup-count{font-size:10px;color:#94a3b8;background:var(--bg-input);padding:1px 6px;border-radius:8px}.progress-panel{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:16px}.progress-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}.progress-header h3{font-size:14px;color:#10b981}.progress-pct{font-size:18px;font-weight:700;color:#10b981}.progress-bar-bg{height:6px;background:var(--bg-input);border-radius:3px;overflow:hidden;margin-bottom:12px}.progress-bar-fill{height:100%;background:#10b981;border-radius:3px;transition:width .4s ease}.progress-list{display:flex;flex-direction:column;gap:4px;max-height:300px;overflow-y:auto}.progress-item{display:flex;align-items:center;gap:8px;padding:4px 8px;font-size:12px;border-radius:4px;background:var(--bg-input)}.progress-status-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.progress-indicator{width:18px;height:18px;border-radius:50%;border:2px solid #333;flex-shrink:0;display:flex;align-items:center;justify-content:center;position:relative;transition:all .3s}.progress-indicator.status-done{background:#00d4aa;border-color:#00d4aa}.progress-indicator.status-error{border-color:#f46;background:#ff446626}.progress-indicator.status-active{border-color:#fa4;background:transparent}.progress-indicator.status-pending{border-color:#333;background:transparent}.progress-indicator-check{font-size:11px;color:#fff;font-weight:700;line-height:1}.progress-indicator-spinner{width:10px;height:10px;border:2px solid transparent;border-top-color:#fa4;border-radius:50%;animation:indicatorSpin .8s linear infinite}@keyframes indicatorSpin{to{transform:rotate(360deg)}}.progress-mini-bar{width:60px;height:4px;background:#333;border-radius:2px;overflow:hidden;flex-shrink:0}.progress-mini-bar-fill{width:40%;height:100%;background:#00d4aa;border-radius:2px;animation:miniBarPulse 1.2s ease-in-out infinite}@keyframes miniBarPulse{0%{width:10%;opacity:.6}50%{width:70%;opacity:1}to{width:10%;opacity:.6}}.status-done{background:#10b981}.status-error{background:var(--danger)}.status-active{background:#fa4;animation:dotPulse 1.4s infinite}.status-pending{background:var(--text-dim);opacity:.4}.progress-node-id{color:var(--text);font-weight:600;flex:1}.progress-status-text{font-size:11px}.progress-status-text.status-done{color:#10b981}.progress-status-text.status-error{color:var(--danger)}.progress-status-text.status-active{color:#fa4}.progress-status-text.status-pending{color:#94a3b8}.progress-layer-tag{font-size:10px;color:#94a3b8;background:var(--bg);padding:1px 6px;border-radius:3px;border:1px solid var(--border)}.code-result-panel{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:16px}.code-result-panel .result-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}.code-result-panel .result-header h3{font-size:14px;color:#10b981}.code-result-folders{display:flex;flex-direction:column;gap:12px;max-height:500px;overflow-y:auto}.code-folder{border:1px solid var(--border);border-radius:var(--radius);overflow:hidden}.code-folder-header{display:flex;align-items:center;gap:8px;padding:8px 12px;background:var(--bg-input);font-size:13px;font-weight:700;color:var(--text)}.code-folder-icon{font-size:14px}.code-folder-name{flex:1}.code-folder-count{font-size:11px;color:#94a3b8;font-weight:400}.code-file{border-top:1px solid var(--border)}.code-file-header{display:flex;align-items:center;gap:8px;padding:6px 12px;background:#00d4aa08}.code-file-icon{font-size:12px}.code-file-name{font-size:12px;color:#10b981;font-weight:600;flex:1}.btn-copy-sm{background:var(--bg-input)!important;color:var(--text-dim)!important;border:1px solid var(--border)!important;padding:2px 8px!important;font-size:10px!important;border-radius:3px!important;cursor:pointer;font-family:inherit;transition:all .2s}.btn-copy-sm:hover{border-color:#10b981!important;color:#10b981!important}.code-file-content{padding:8px 12px;font-size:11px;line-height:1.5;color:#94a3b8;white-space:pre-wrap;word-break:break-all;max-height:200px;overflow-y:auto;margin:0;background:var(--bg)}.copy-msg{position:fixed;bottom:80px;left:50%;transform:translate(-50%);background:#10b981;color:#fff;padding:6px 16px;border-radius:var(--radius);font-size:13px;font-weight:700;z-index:100;animation:fadeIn .2s}.toast-popup{position:fixed;bottom:24px;left:50%;transform:translate(-50%);padding:8px 16px;background:#10b981;color:#fff;font-size:13px;font-weight:500;border-radius:var(--radius);box-shadow:0 4px 12px #0000004d;z-index:1000;animation:toastIn .3s ease;white-space:nowrap;max-width:220px;height:auto;line-height:1.4;display:inline-block;pointer-events:none}@keyframes toastIn{0%{opacity:0;transform:translate(-50%) translateY(10px)}to{opacity:1;transform:translate(-50%) translateY(0)}}.btn-generate-dim{opacity:.55!important}.btn-generate-dim:hover{opacity:.75!important}.my-projects{margin-top:8px}.my-project-toolbar{background:var(--bg-card);border:1px solid #333;border-radius:var(--radius);padding:16px;margin-bottom:12px;box-shadow:0 1px 3px #0000004d}.my-project-toolbar .toolbar-info-row{display:flex;gap:12px;margin-bottom:10px}.my-project-toolbar .toolbar-stats-compact{margin-bottom:10px}.my-project-toolbar .toolbar-actions{display:flex;flex-wrap:wrap;gap:8px;align-items:center}.preview-section{background:var(--bg-card);border:1px solid #333;border-radius:var(--radius);padding:16px;margin-bottom:20px;box-shadow:0 1px 3px #0000004d}.preview-header{margin-bottom:16px;padding-bottom:12px;border-bottom:1px solid #333}.preview-title{font-size:16px;font-weight:700;color:#00d4aa;margin:0 0 8px}.preview-meta{display:flex;gap:16px;align-items:center;font-size:13px}.preview-name{color:#fff;font-weight:700}.preview-platform{color:#ccc;background:#333;padding:3px 10px;border-radius:4px;font-size:12px}.preview-count{color:#00d4aa;font-weight:600;font-size:12px}.preview-progress-badge{background:#00d4aa;color:#fff;padding:3px 10px;border-radius:4px;font-size:12px;font-weight:700}.preview-tree{display:flex;flex-direction:column;gap:12px}.preview-group{border:1px solid #333;border-radius:6px;overflow:hidden}.preview-group-header{display:flex;align-items:center;gap:10px;padding:10px 14px;background:#252525;border-bottom:1px solid #333}.preview-group-label{font-size:13px;font-weight:700;color:#fff;flex:1}.preview-group-tagline{font-size:11px;color:#00d4aa;opacity:.7;font-style:italic}.preview-group-count{font-size:11px;color:#ccc;background:#333;padding:2px 8px;border-radius:10px}.preview-children{display:flex;flex-direction:column}.preview-child{display:flex;align-items:center;gap:12px;padding:8px 14px;border-bottom:1px solid rgba(51,51,51,.5);transition:background .15s}.preview-child:last-child{border-bottom:none}.preview-child:hover{background:#00d4aa08}.preview-child-name{font-size:13px;font-weight:600;color:#00d4aa;font-family:Consolas,Monaco,Courier New,monospace;min-width:160px;flex-shrink:0}.preview-child-desc{font-size:11px;color:#999;flex:1;line-height:1.4}.preview-child-tpl{font-size:10px;color:#ccc;padding:2px 8px;border-radius:3px;border:1px solid #333;background:#33333380;flex-shrink:0;white-space:nowrap}.preview-layer-progress{display:flex;align-items:center;gap:10px;padding:6px 14px;background:#00d4aa08;border-bottom:1px solid rgba(51,51,51,.3)}.preview-layer-progress-bar{width:80px;height:4px;background:#333;border-radius:2px;overflow:hidden;flex-shrink:0}.preview-layer-progress-fill{height:100%;background:#00d4aa;border-radius:2px;transition:width .3s}.preview-layer-progress-text{font-size:11px;color:#00d4aa;font-weight:600}.preview-child-indicator{width:16px;height:16px;border-radius:50%;border:2px solid #333;flex-shrink:0;display:flex;align-items:center;justify-content:center;font-size:10px;font-weight:700;transition:all .3s}.preview-child-indicator.indicator-done{background:transparent;border:2px solid #00d4aa;color:#00d4aa;font-size:12px}.preview-child-indicator.indicator-active{border-color:#fa4;background:transparent}.preview-child-indicator.indicator-error{border-color:#f46;background:#ff446626;color:#f46}.preview-child-indicator.indicator-pending{border-color:#333;background:transparent}.preview-child-spinner{width:8px;height:8px;border:2px solid transparent;border-top-color:#fa4;border-radius:50%;animation:indicatorSpin .8s linear infinite}.preview-child-req{font-size:12px;flex-shrink:0;cursor:help}.history-section{margin-top:4px}.history-title{font-size:14px;font-weight:700;color:#ccc;margin:0 0 12px;padding-bottom:8px;border-bottom:1px solid #333}.project-list{display:flex;flex-direction:column;gap:12px}.project-card{display:flex;justify-content:space-between;align-items:center;padding:16px 20px;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);transition:border-color .2s}.project-card:hover{border-color:#10b981}.project-card-info{display:flex;flex-direction:column;gap:4px}.project-card-name{font-size:16px;font-weight:700;color:var(--text)}.project-card-meta{display:flex;gap:8px;font-size:12px;color:#94a3b8}.project-card-actions{display:flex;gap:8px}.btn-download-project{background:#10b981!important;color:#000!important;border:none!important;padding:6px 16px!important;border-radius:var(--radius)!important;font-size:12px!important;font-weight:700!important;font-family:inherit!important;cursor:pointer;transition:background .2s}.btn-download-project:hover{background:var(--accent-dim)!important}.btn-delete-project{background:var(--bg-input)!important;color:var(--danger)!important;border:1px solid var(--danger)!important;padding:6px 16px!important;border-radius:var(--radius)!important;font-size:12px!important;font-weight:600!important;font-family:inherit!important;cursor:pointer;transition:all .2s}.btn-delete-project:hover{background:var(--danger)!important;color:#fff!important}.btn-regenerate-project{background:var(--bg-input)!important;color:#10b981!important;border:1px solid #10b981!important;padding:6px 16px!important;border-radius:var(--radius)!important;font-size:12px!important;font-weight:600!important;font-family:inherit!important;cursor:pointer;transition:all .2s}.btn-regenerate-project:hover{background:#10b981!important;color:#000!important}.btn-spinner{display:inline-block;width:14px;height:14px;border:2px solid rgba(0,0,0,.2);border-top-color:#fff;border-radius:50%;animation:spin .6s linear infinite}.btn-swap{background:var(--bg-input)!important;color:#10b981!important;border:1px solid var(--border)!important;padding:4px 10px!important;font-size:16px!important;border-radius:var(--radius)!important;cursor:pointer;transition:all .2s;font-family:inherit;line-height:1}.btn-swap:hover{border-color:#10b981!important;background:#10b981!important;color:#000!important}.mode-switch{position:relative}.mode-btn{background:var(--bg-input)!important;color:var(--text-dim)!important;border:none!important;padding:6px 14px!important;font-size:13px!important;font-weight:600!important;font-family:inherit!important;cursor:pointer;transition:all .2s}.mode-btn.active{background:#10b981!important;color:#000!important}.mode-btn:not(.active):hover{color:var(--text)!important;background:var(--bg-hover)!important}.mode-cost-hint{font-size:11px;color:#fa4;font-weight:600;animation:fadeIn .3s}.mode-info{font-size:12px;color:#94a3b8;margin-bottom:12px;padding:4px 8px;background:var(--bg-input);border-radius:4px;border:1px solid var(--border)}.btn-row{display:flex;align-items:center;gap:8px}.btn-modify{background:var(--bg-input)!important;color:#10b981!important;border:1px solid #10b981!important;padding:10px 20px!important;border-radius:var(--radius)!important;font-weight:700!important;font-size:14px!important;cursor:pointer;transition:all .2s;font-family:inherit}.btn-modify:hover{background:#10b981!important;color:#000!important}.loading-hint{display:flex;align-items:center;gap:6px;margin-top:10px;font-size:12px;color:#94a3b8;animation:fadeIn .3s}.loading-dots{display:inline-flex;gap:2px}.loading-dots span{animation:dotPulse 1.4s infinite;font-size:16px;line-height:1;font-weight:700;color:#10b981}@keyframes dotPulse{0%,80%,to{opacity:.2;transform:scale(.8)}40%{opacity:1;transform:scale(1.2)}}.queue-info{color:#10b981;font-weight:600}.elapsed-tag{margin-left:auto;color:#94a3b8;font-size:11px;font-variant-numeric:tabular-nums}.desc-area{margin-top:20px;border-top:1px solid var(--border);padding-top:16px}.desc-area h3{font-size:14px;color:#10b981;margin-bottom:12px}.desc-section{margin-bottom:14px}.desc-section h4{font-size:12px;color:var(--text);margin-bottom:6px;padding-left:8px;border-left:3px solid #10b981}.desc-section ul{list-style:none;padding:0}.desc-section ul li{font-size:12px;color:#94a3b8;line-height:1.8;padding-left:16px;position:relative}.desc-section ul li:before{content:"·";position:absolute;left:4px;color:#10b981;font-weight:700}.desc-table{display:flex;flex-direction:column;gap:4px}.desc-table-row{display:flex;align-items:center;gap:12px;font-size:12px}.desc-code{min-width:28px;text-align:center;background:var(--bg-input);border:1px solid var(--border);border-radius:3px;padding:1px 6px;color:#10b981;font-weight:700;font-size:11px}.desc-meaning{color:#94a3b8}.prompt-area{margin-top:20px;border-top:1px solid var(--border);padding-top:12px}.prompt-header{display:flex;justify-content:space-between;align-items:center;cursor:pointer;padding:8px 12px;background:var(--bg-input);border:1px solid var(--border);border-radius:var(--radius);font-size:12px;color:#94a3b8;transition:all .2s}.prompt-header:hover{border-color:#10b981;color:var(--text)}.prompt-toggle{font-size:10px}.prompt-content{margin-top:8px}.prompt-section{margin-bottom:12px}.prompt-section h4{font-size:12px;color:#10b981;margin-bottom:4px}.prompt-section pre{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius);padding:12px;font-size:11px;line-height:1.5;overflow-x:auto;white-space:pre-wrap;word-break:break-all;max-height:300px;overflow-y:auto;color:#94a3b8}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:999}.modal{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:32px;width:360px;position:relative}.modal-close{position:absolute;top:12px;right:16px;background:none;border:none;color:#94a3b8;font-size:18px;cursor:pointer;font-family:inherit}.modal h2{font-size:18px;color:#10b981;margin-bottom:20px}.pay-options{display:flex;gap:12px;margin-bottom:20px}.pay-card{flex:1;border:2px solid var(--border);border-radius:var(--radius);padding:16px;text-align:center;cursor:pointer;transition:border-color .2s}.pay-card.active{border-color:#10b981}.pay-price{font-size:28px;font-weight:700;color:#10b981}.pay-credits{font-size:14px;color:var(--text);margin:4px 0}.pay-desc{font-size:12px;color:#94a3b8}.btn-pay{width:100%;background:#10b981!important;color:#000!important;border:none!important;padding:12px!important;border-radius:var(--radius)!important;font-weight:700!important;font-size:14px!important;cursor:pointer;font-family:inherit}.btn-pay:hover{background:var(--accent-dim)!important}.pay-qrcode{text-align:center;color:#94a3b8;font-size:13px}.qr-code-wrapper{margin:16px auto;padding:12px;background:#fff;border-radius:8px;display:inline-block}.qr-code-img{width:200px;height:200px;display:block}.pay-actions{margin-top:12px;display:flex;flex-direction:column;align-items:center;gap:8px}.btn-pay-link{background:transparent;color:#10b981;border:1px solid #10b981;padding:8px 24px;border-radius:var(--radius);font-size:13px;cursor:pointer;font-family:inherit}.btn-pay-link:hover{background:#10b981;color:#fff}.order-id{font-size:11px;color:#94a3b8;word-break:break-all}.polling-hint{color:#10b981;margin-top:8px}.pay-success{text-align:center;padding:20px 0}.login-modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0f172abf;display:flex;align-items:center;justify-content:center;z-index:10000;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);animation:fadeIn .2s ease}@keyframes modalIn{0%{opacity:0;transform:translateY(-16px) scale(.97)}to{opacity:1;transform:translateY(0) scale(1)}}.login-modal{background:#1e293b;border:1px solid rgba(255,255,255,.08);border-radius:16px;padding:40px 36px 32px;width:400px;max-width:92vw;position:relative;animation:modalIn .25s ease;box-shadow:0 24px 48px #0006}.login-modal-close{position:absolute;top:14px;right:14px;background:none;border:none;color:#64748b;font-size:18px;cursor:pointer;padding:4px 8px;border-radius:6px;transition:all .15s;line-height:1}.login-modal-close:hover{color:#e2e8f0;background:#ffffff0f}.login-modal-header{text-align:center;margin-bottom:28px}.login-modal-header h2{font-size:24px;font-weight:700;color:#f1f5f9;margin:0 0 8px}.login-modal-header p{font-size:14px;color:#94a3b8;margin:0;font-weight:400}.login-type-tabs{display:flex;border-bottom:1px solid rgba(255,255,255,.08);margin-bottom:24px}.login-type-tab{flex:1;padding:10px 0;background:none!important;border:none!important;border-bottom:2px solid transparent!important;border-radius:0!important;color:#64748b!important;font-size:15px;font-weight:600;cursor:pointer;transition:all .15s;font-family:inherit;text-align:center;box-shadow:none!important}.login-type-tab.active{color:#10b981!important;border-bottom-color:#10b981!important}.login-type-tab:not(.active):hover{color:#cbd5e1!important;background:none!important}.login-form{display:flex;flex-direction:column;gap:18px}.login-field{display:flex;flex-direction:column;gap:6px}.login-field label{font-size:14px;color:#cbd5e1;font-weight:500}.login-field input{width:100%;padding:12px 14px;background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:8px;color:#f1f5f9;font-size:15px;outline:none;transition:border-color .15s,box-shadow .15s;box-sizing:border-box;font-family:inherit}.login-field input:focus{border-color:#10b981;box-shadow:0 0 0 3px #10b9811f}.login-field input::placeholder{color:#475569}.login-password-row{position:relative;display:flex;align-items:center}.login-password-row input{width:100%;padding-right:56px}.login-pw-toggle{position:absolute;right:8px;background:none;border:none;color:#64748b;font-size:13px;cursor:pointer;padding:4px 8px;border-radius:4px;transition:color .15s;font-family:inherit}.login-pw-toggle:hover{color:#cbd5e1}.login-error{background:#ef44441a;border:1px solid rgba(239,68,68,.2);color:#fca5a5;padding:10px 14px;border-radius:8px;font-size:14px}.login-submit-btn{width:100%;padding:12px;background:#10b981;color:#fff;border:none;border-radius:8px;font-size:15px;font-weight:600;cursor:pointer;transition:background .15s,box-shadow .15s;font-family:inherit;margin-top:4px}.login-submit-btn:hover{background:#059669;box-shadow:0 4px 12px #10b9814d}.login-submit-btn:active{background:#047857}.login-submit-btn:disabled{opacity:.5;cursor:not-allowed;box-shadow:none}.login-switch{text-align:center;margin-top:18px;font-size:14px;color:#64748b}.login-switch button{background:none;border:none;color:#10b981;font-weight:600;cursor:pointer;font-size:14px;padding:0;font-family:inherit;transition:color .15s}.login-switch button:hover{color:#34d399}.scan-login-area{min-height:300px;display:flex;align-items:center;justify-content:center}.scan-loading{text-align:center;color:#94a3b8}.scan-loading p{margin-top:16px;font-size:14px}.scan-spinner{width:40px;height:40px;border:3px solid rgba(255,255,255,.1);border-top-color:#10b981;border-radius:50%;animation:spin .8s linear infinite;margin:0 auto}.scan-qr-wrapper{text-align:center}.scan-qr-container{display:inline-block}.scan-qr-box{display:inline-block;background:#fff;padding:16px;border-radius:12px}.scan-info{margin-top:16px}.scan-hint{font-size:14px;color:#cbd5e1;margin:0 0 8px}.scan-code-text{font-size:12px;color:#64748b;font-family:SF Mono,Consolas,monospace;letter-spacing:.5px;margin:0}.scan-status-msg{text-align:center}.scan-status-msg p{font-size:14px;color:#94a3b8;margin:0 0 16px}.scan-refresh-btn{padding:10px 24px;background:#10b981;color:#fff;border:none;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;font-family:inherit;transition:background .15s}.scan-refresh-btn:hover{background:#059669}.scan-success{text-align:center}.scan-success-icon{width:56px;height:56px;background:#10b981;color:#fff;font-size:28px;font-weight:700;border-radius:50%;display:flex;align-items:center;justify-content:center;margin:0 auto 12px;animation:scanSuccessPop .3s ease}@keyframes scanSuccessPop{0%{transform:scale(0)}60%{transform:scale(1.1)}to{transform:scale(1)}}.scan-success p{font-size:16px;font-weight:600;color:#10b981}@media screen and (max-width: 480px){.login-modal{padding:32px 24px 24px;width:94vw;max-width:94vw;border-radius:12px}.login-modal-header h2{font-size:22px}.login-modal-header p{font-size:13px}.login-field input{padding:11px 12px;font-size:14px}.login-submit-btn{padding:11px;font-size:14px}.login-switch,.login-switch button{font-size:13px}.scan-qr-box{padding:12px}.scan-qr-box svg{width:160px!important;height:160px!important}.scan-hint{font-size:13px}.scan-code-text{font-size:11px;padding:8px 14px}.scan-refresh-btn{padding:10px 20px;font-size:13px}}.uc-account-card{background:linear-gradient(135deg,#4d96ff1a,#4d96ff08);border:1px solid rgba(77,150,255,.3);border-radius:var(--radius);padding:20px;display:flex;align-items:center;gap:16px;margin-top:16px}.uc-account-icon{font-size:40px;flex-shrink:0}.uc-account-content{flex:1}.uc-account-title{font-size:16px;font-weight:700;color:#4d96ff;margin-bottom:4px}.uc-account-desc{font-size:12px;color:#aaa}.uc-account-btn{background:linear-gradient(135deg,#4d96ff,#6c5ce7);color:#fff;border:none;border-radius:8px;padding:10px 24px;font-size:14px;font-weight:700;cursor:pointer;flex-shrink:0;transition:all .2s}.uc-account-btn:hover{transform:translateY(-1px);box-shadow:0 4px 12px #4d96ff4d}.uc-form-group{margin-bottom:14px}.uc-form-group label{display:block;font-size:13px;color:#94a3b8;margin-bottom:6px;font-weight:500}.footer{text-align:center;padding:20px;font-size:11px;color:#94a3b8;border-top:1px solid var(--border);margin-top:40px}.footer-beian{margin-top:6px}.footer-beian a{color:#94a3b8;text-decoration:none}.footer-beian a:hover{color:var(--text-secondary);text-decoration:underline}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.batch-three-col{display:grid;grid-template-columns:2fr 2fr 1fr;gap:16px;margin-top:16px}.batch-col{display:flex;flex-direction:column}.batch-col-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:6px}.batch-col-actions{display:flex;gap:6px;align-items:center}.btn-import{background:var(--bg-input)!important;color:#10b981!important;border:1px solid #10b981!important;padding:4px 12px!important;border-radius:4px!important;font-size:12px!important;font-weight:600!important;font-family:inherit!important;cursor:pointer;transition:all .2s}.btn-import:hover{background:#10b981!important;color:#000!important}.file-info-bar{display:flex;align-items:center;gap:8px;padding:4px 8px;background:var(--bg-input);border:1px solid var(--border);border-radius:4px;margin-bottom:6px;font-size:12px}.file-info-name{color:#10b981;font-weight:600}.btn-reset{margin-left:auto;background:var(--bg-input)!important;color:var(--text-dim)!important;border:1px solid var(--border)!important;padding:2px 8px!important;font-size:11px!important;border-radius:3px!important;cursor:pointer;font-family:inherit;transition:all .2s}.btn-reset:hover{border-color:var(--danger)!important;color:var(--danger)!important}.btn-download{background:#10b981!important;color:#000!important;border:none!important;padding:4px 12px!important;border-radius:4px!important;font-size:12px!important;font-weight:600!important;font-family:inherit!important;cursor:pointer;transition:background .2s}.btn-download:hover{background:var(--accent-dim)!important}.download-msg{font-size:11px;color:#10b981;margin-bottom:4px;animation:fadeIn .2s}.batch-textarea{flex:1;min-height:200px;margin-bottom:8px!important}.batch-stat{font-size:12px;color:#94a3b8;padding:4px 0}.batch-stat strong{color:#10b981;font-weight:700}.parse-errors{margin-top:4px}.parse-errors .error{margin-top:2px;font-size:11px}.batch-col-ctrl{background:var(--bg-input);border:1px solid var(--border);border-radius:var(--radius);padding:12px}.batch-ctrl-inner{display:flex;flex-direction:column;gap:12px;margin-top:8px}.batch-n-row{display:flex;align-items:center;gap:8px;font-size:13px;color:#94a3b8}.input-select{flex:1;padding:4px 8px;background:var(--bg);color:var(--text);border:1px solid var(--border);border-radius:4px;font-family:inherit;font-size:13px;outline:none}.input-select:focus{border-color:#10b981}.hint-inline{font-size:12px;color:#94a3b8}.input-n{width:60px;padding:4px 8px;background:var(--bg);color:var(--text);border:1px solid var(--border);border-radius:4px;font-family:inherit;font-size:13px;text-align:center;outline:none}.input-n:focus{border-color:#10b981}.btn-generate-batch{width:100%;padding:10px 16px!important;background:#10b981!important;color:#000!important;border:none!important;border-radius:var(--radius)!important;font-weight:700!important;font-size:14px!important;font-family:inherit!important;cursor:pointer;transition:background .2s}.btn-generate-batch:hover:not(:disabled){background:var(--accent-dim)!important}.btn-generate-batch:disabled{opacity:.5;cursor:not-allowed}.btn-abort{width:100%;padding:6px 12px!important;background:var(--bg-input)!important;color:var(--danger)!important;border:1px solid var(--danger)!important;border-radius:var(--radius)!important;font-size:12px!important;font-family:inherit!important;cursor:pointer;transition:all .2s}.btn-abort:hover{background:var(--danger)!important;color:#fff!important}.loading-hint{display:flex;align-items:center;gap:8px;padding:8px 12px;margin-top:12px;background:var(--bg-input);border:1px solid var(--border);border-radius:var(--radius);font-size:13px;color:#94a3b8}.loading-dots span{animation:blink 1.4s infinite both}.loading-dots span:nth-child(2){animation-delay:.2s}.loading-dots span:nth-child(3){animation-delay:.4s}@keyframes blink{0%,80%,to{opacity:0}40%{opacity:1}}.elapsed-tag{margin-left:auto;font-size:12px;color:#10b981;font-weight:600}.merged-code{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius);padding:16px;font-size:12px;line-height:1.6;overflow-x:auto;white-space:pre-wrap;word-break:break-all;font-family:Consolas,SF Mono,monospace;margin:0 0 12px}.merged-textarea{width:100%;min-height:200px;padding:16px;background:var(--bg);color:var(--text);border:1px solid var(--border);border-radius:var(--radius);font-family:Consolas,SF Mono,monospace;font-size:12px;line-height:1.6;resize:vertical;outline:none;margin:0 0 12px;box-sizing:border-box}.merged-textarea:focus{border-color:#10b981}.copy-row{display:flex;align-items:center;gap:8px;margin-bottom:12px}.copy-msg{font-size:12px;color:#10b981;animation:fadeIn .2s}.prompt-area{margin-top:16px;border:1px solid var(--border);border-radius:var(--radius);overflow:hidden}.prompt-header{display:flex;justify-content:space-between;align-items:center;padding:8px 12px;background:var(--bg-input);cursor:pointer;font-size:13px;color:#94a3b8;-webkit-user-select:none;user-select:none}.prompt-header:hover{color:#10b981}.prompt-toggle{font-size:11px}.prompt-content{border-top:1px solid var(--border);padding:12px}.prompt-section h4{font-size:13px;color:#10b981;margin:0 0 8px}.prompt-section pre{background:var(--bg);border:1px solid var(--border);border-radius:4px;padding:12px;font-size:11px;line-height:1.5;overflow-x:auto;white-space:pre-wrap;word-break:break-all;margin:0;font-family:Consolas,SF Mono,monospace}.batch-results{margin-top:24px;border-top:1px solid var(--border);padding-top:16px}.batch-results-title{font-size:15px;color:var(--text);margin-bottom:12px}.batch-result-block{margin-bottom:12px;border:1px solid var(--border);border-radius:var(--radius);overflow:hidden}.batch-result-header{display:flex;justify-content:space-between;align-items:center;padding:6px 12px;background:var(--bg-input);border-bottom:1px solid var(--border);font-size:12px;color:#94a3b8}.batch-result-code{background:var(--bg);padding:12px;font-size:12px;line-height:1.6;overflow-x:auto;white-space:pre-wrap;word-break:break-all;margin:0;font-family:Consolas,SF Mono,monospace}.fb-top-row{display:flex;align-items:flex-end;gap:24px;margin-bottom:12px}.fb-config-row{display:flex;align-items:flex-end;gap:16px;margin-bottom:16px;flex-wrap:wrap}.fb-field{display:flex;flex-direction:column;gap:4px}.fb-field select{min-width:160px}.fb-credits-tag{font-size:13px;color:#94a3b8;margin-left:auto;padding:6px 12px;background:var(--bg-input);border:1px solid var(--border);border-radius:var(--radius)}.credits-ok{color:#10b981;font-size:16px}.credits-low{color:var(--danger);font-size:16px}.fb-mode-section{margin-bottom:16px}.fb-mode-section .module-label{display:block;margin-bottom:8px}.fb-mode-options{display:flex;gap:12px;flex-wrap:wrap}.fb-mode-btn{display:flex;flex-direction:column;align-items:flex-start;padding:10px 20px!important;background:var(--bg-input)!important;border:1px solid #10b981!important;border-radius:var(--radius)!important;cursor:pointer;transition:all .2s;min-width:180px;font-weight:700!important}.fb-mode-btn:hover{background:#00d4aa26!important}.fb-mode-btn.active{background:#10b981!important}.fb-mode-btn:disabled{opacity:.5;cursor:not-allowed}.fb-mode-label{font-size:14px;font-weight:700;color:#10b981;margin-bottom:4px}.fb-mode-btn.active .fb-mode-label{color:#fff}.fb-mode-desc{font-size:12px;color:#94a3b8}.fb-mode-btn.active .fb-mode-desc{color:#0009}.fb-standard-section{margin-bottom:16px;padding:12px;background:var(--bg-input);border-radius:var(--radius);border:1px solid var(--border)}.fb-standard-section .module-label{display:block;margin-bottom:8px}.fb-node-select{width:100%;padding:10px 12px;background:var(--bg);border:1px solid var(--border);border-radius:var(--radius);color:var(--text);font-size:14px}.fb-node-info{margin-top:8px;padding:8px 12px;background:#00d4aa14;border-radius:var(--radius);font-size:13px;color:#94a3b8}.fb-name-section{margin-bottom:16px}.fb-name-section .module-label{display:block;margin-bottom:8px}.fb-name-input{width:100%;max-width:400px;padding:10px 12px;background:var(--bg);border:1px solid var(--border);border-radius:var(--radius);color:var(--text);font-size:14px}.fb-name-input:focus{outline:none;border-color:#10b981}.fb-requirement-section{margin-bottom:16px}.fb-requirement-section .module-label{display:block;margin-bottom:8px}.btn-save-tpl{padding:6px 14px;background:transparent;border:1px solid #10b981;border-radius:var(--radius);color:#10b981;font-size:13px;font-weight:500;cursor:pointer;transition:all .15s}.btn-save-tpl:hover{background:#00d4aa1a}.tpl-modal-sm{max-width:420px;width:90%}.tpl-form-label{display:block;font-size:13px;font-weight:500;color:var(--text);margin-bottom:6px}.tpl-form-input{width:100%;padding:10px 12px;background:var(--bg);border:1px solid var(--border);border-radius:var(--radius);color:var(--text);font-size:14px}.tpl-form-input:focus{outline:none;border-color:#10b981}.tpl-form-textarea{width:100%;padding:10px 12px;background:var(--bg);border:1px solid var(--border);border-radius:var(--radius);color:var(--text);font-size:14px;resize:vertical;min-height:60px}.tpl-form-textarea:focus{outline:none;border-color:#10b981}.tpl-btn{padding:8px 16px;border-radius:var(--radius);font-size:14px;font-weight:500;cursor:pointer;transition:all .15s}.tpl-btn-ghost{background:transparent;border:1px solid var(--border);color:#94a3b8}.tpl-btn-ghost:hover{background:var(--bg-input);color:var(--text)}.tpl-btn-primary{background:#10b981;border:1px solid #10b981;color:#fff}.tpl-btn-primary:hover{background:#00eabb}.tpl-btn-primary:disabled{opacity:.5;cursor:not-allowed}.code-block{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius);padding:0;overflow-x:auto;font-family:Consolas,SF Mono,Fira Code,monospace;font-size:12px;line-height:1.7}.code-table{border-collapse:collapse;width:100%}.code-table tr:hover{background:#00d4aa0a}.code-lineno{padding:0 12px;text-align:right;color:#94a3b8;opacity:.4;-webkit-user-select:none;user-select:none;white-space:nowrap;border-right:1px solid var(--border);min-width:40px;vertical-align:top;font-size:11px}.code-content{padding:0 16px;white-space:pre;vertical-align:top}.hl-keyword{color:#00d4aa;font-weight:600}.hl-comment{color:#6a9955;font-style:italic}.hl-address{color:#ce9178}.hl-literal,.hl-number{color:#b5cea8}.result-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}.result-header h3{margin:0;font-size:14px;color:#94a3b8}.error-clickable{cursor:pointer;transition:all .2s;padding:4px 8px;border-radius:4px;border-left:3px solid var(--danger);background:#ff44660f}.error-clickable:hover{background:#ff44661f}.error-icon{font-size:12px;margin-right:4px}.error-highlight{border-color:var(--danger)!important;box-shadow:0 0 0 2px #ff44664d!important;animation:errorPulse .6s ease-in-out}@keyframes errorPulse{0%,to{box-shadow:0 0 0 2px #ff44664d}50%{box-shadow:0 0 0 4px #ff446680}}.stat-error{color:var(--danger);font-size:12px;font-weight:600}.download-done{color:#10b981;font-weight:600}.success-msg{color:#10b981;font-size:13px;margin-top:8px;padding:6px 12px;background:#00d4aa14;border:1px solid rgba(0,212,170,.2);border-radius:var(--radius);animation:fadeIn .3s}.btn-spinner{display:inline-block;width:12px;height:12px;border:2px solid rgba(0,0,0,.2);border-top-color:#fff;border-radius:50%;animation:spin .6s linear infinite;vertical-align:middle;margin-right:4px}@keyframes spin{to{transform:rotate(360deg)}}.btn-retry{background:var(--bg-input)!important;color:#10b981!important;border:1px solid #10b981!important;padding:6px 16px!important;border-radius:var(--radius)!important;font-size:13px!important;font-weight:600!important;font-family:inherit!important;cursor:pointer;transition:all .2s}.btn-retry:hover{background:#10b981!important;color:#000!important}.network-error-banner{display:flex;align-items:center;justify-content:space-between;padding:10px 16px;margin-top:8px;background:#ff446614;border:1px solid rgba(255,68,102,.3);border-radius:var(--radius);animation:fadeIn .3s}.network-error-text{color:var(--danger);font-size:13px;font-weight:600}.merged-code-scroll{max-height:500px;overflow-y:auto;border:1px solid var(--border);border-radius:var(--radius);background:var(--bg)}.merged-code-scroll::-webkit-scrollbar{width:6px}.merged-code-scroll::-webkit-scrollbar-track{background:var(--bg)}.merged-code-scroll::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}.merged-code-scroll::-webkit-scrollbar-thumb:hover{background:var(--text-dim)}.result-item{border-bottom:1px solid var(--border)}.result-item:last-child{border-bottom:none}.result-item-header{display:flex;align-items:center;gap:8px;padding:8px 16px 4px;background:var(--bg-input);border-bottom:1px solid var(--border)}.result-item-index{color:#10b981;font-weight:700;font-size:13px;min-width:24px}.result-item-label{color:#94a3b8;font-size:12px}@media (max-width: 768px){.toolbox-cards{grid-template-columns:1fr}.header{flex-direction:column;gap:12px}.tab-btn{padding:10px 16px;font-size:13px}.batch-three-col{grid-template-columns:1fr}.fb-top-row{flex-direction:column;align-items:stretch;gap:12px}.fb-credits-tag{margin-left:0}.result-header{flex-direction:column;align-items:flex-start;gap:8px}.network-error-banner{flex-direction:column;gap:8px;text-align:center}}.template-library{position:relative}.tpl-toast{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);padding:14px 28px;border-radius:8px;font-size:15px;font-weight:700;z-index:300;animation:toastIn .3s ease;pointer-events:none}.tpl-toast-success{background:#00d4aaf2;color:#fff;box-shadow:0 4px 20px #00d4aa66}.tpl-toast-error{background:#ff4466f2;color:#fff;box-shadow:0 4px 20px #f466}.tpl-toast-info{background:#333333f2;color:#fff;box-shadow:0 4px 20px #0006}.tpl-toolbar{background:var(--bg-card);border:1px solid #333;border-radius:var(--radius);padding:16px;margin-bottom:16px;box-shadow:0 1px 3px #0000004d}.tpl-filter-row{display:flex;gap:10px;align-items:center}.tpl-search{flex:6;padding:8px 12px;background:var(--bg-input);color:var(--text);border:1px solid #333;border-radius:4px;font-size:13px;font-family:inherit;outline:none;transition:border-color .2s}.tpl-search:focus{border-color:#00d4aa}.tpl-search::placeholder{color:#666}.tpl-select{flex:3;padding:8px 10px;background:var(--bg-input);color:var(--text);border:1px solid #333;border-radius:4px;font-size:13px;font-family:inherit;outline:none;cursor:pointer;transition:border-color .2s}.tpl-select:focus{border-color:#00d4aa}.tpl-select-sm{flex:1}.tpl-list{display:flex;flex-direction:column;gap:16px}.tpl-loading{display:flex;align-items:center;justify-content:center;gap:8px;padding:60px 0;color:#94a3b8;font-size:14px}.tpl-spinner{display:inline-block;width:18px;height:18px;border:2px solid #333;border-top-color:#00d4aa;border-radius:50%;animation:spin .7s linear infinite}.tpl-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 0;text-align:center}.tpl-empty-icon{font-size:48px;margin-bottom:12px;opacity:.5}.tpl-empty-text{font-size:14px;color:#ccc}.tpl-card{background:var(--bg-card);border:1px solid #333;border-radius:4px;padding:16px;transition:border-color .2s}.tpl-card:hover{border-color:#00d4aa}.tpl-card-header{display:flex;align-items:center;gap:10px;margin-bottom:8px}.tpl-card-name{font-size:16px;font-weight:700;color:#fff;flex:1}.tpl-card-category{background:#00d4aa;color:#fff;padding:2px 8px;border-radius:4px;font-size:11px;font-weight:700;flex-shrink:0}.tpl-card-badge{padding:2px 8px;border-radius:4px;font-size:11px;font-weight:600;flex-shrink:0}.tpl-badge-public{background:#00d4aa26;color:#00d4aa;border:1px solid rgba(0,212,170,.3)}.tpl-badge-private{background:#ffaa4426;color:#fa4;border:1px solid rgba(255,170,68,.3)}.tpl-card-desc{font-size:12px;color:#ccc;line-height:1.6;margin-bottom:10px}.tpl-card-meta{display:flex;gap:16px;font-size:12px;color:#94a3b8;margin-bottom:12px}.tpl-meta-item{display:flex;align-items:center;gap:4px}.tpl-card-actions{display:flex;gap:8px;align-items:center}.tpl-btn{padding:8px 16px;border-radius:var(--radius);font-size:13px;font-weight:600;font-family:inherit;cursor:pointer;transition:all .2s;white-space:nowrap}.tpl-btn:disabled{opacity:.5;cursor:not-allowed}.tpl-btn-ghost{background:var(--bg-input);border:1px solid #00d4aa;color:#00d4aa}.tpl-btn-ghost:hover:not(:disabled){background:#00d4aa;color:#fff}.tpl-btn-primary{background:var(--bg-input);border:1px solid #00d4aa;color:#00d4aa}.tpl-btn-primary:hover:not(:disabled){background:#00d4aa;color:#fff}.tpl-btn-danger{background:#333;color:#ff4d4f;border:1px solid #ff4d4f}.tpl-btn-danger:hover:not(:disabled){background:#ff4d4f;color:#fff}.tpl-modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:999;animation:fadeIn .2s}.tpl-modal{background:var(--bg-card);border:1px solid #333;border-radius:8px;width:600px;max-width:90vw;max-height:85vh;display:flex;flex-direction:column;animation:toastIn .3s ease}.tpl-modal-sm{width:400px}.tpl-modal-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid #333}.tpl-modal-title{font-size:18px;font-weight:700;color:#fff;margin:0}.tpl-modal-close{background:none;border:none;color:#94a3b8;font-size:18px;cursor:pointer;padding:4px 8px;border-radius:4px;transition:all .2s}.tpl-modal-close:hover{color:#fff;background:var(--bg-hover)}.tpl-modal-body{padding:20px;overflow-y:auto;flex:1}.tpl-modal-footer{display:flex;justify-content:flex-end;gap:8px;padding:16px 20px;border-top:1px solid #333}.tpl-preview-info{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px;padding-bottom:12px;border-bottom:1px solid #333;font-size:13px;color:#ccc}.tpl-preview-count{color:#00d4aa;font-weight:600;font-size:13px}.tpl-preview-tree{display:flex;flex-direction:column;gap:12px}.tpl-preview-group{border:1px solid #333;border-radius:6px;overflow:hidden}.tpl-preview-layer{padding:8px 14px;background:#252525;border-bottom:1px solid #333;font-size:13px;font-weight:700;color:#00d4aa}.tpl-preview-node{display:flex;align-items:center;gap:12px;padding:8px 14px;border-bottom:1px solid rgba(51,51,51,.5);transition:background .15s}.tpl-preview-node:last-child{border-bottom:none}.tpl-preview-node:hover{background:#00d4aa08}.tpl-preview-node-name{font-size:13px;font-weight:600;color:#00d4aa;font-family:Consolas,Monaco,Courier New,monospace;min-width:160px;flex-shrink:0}.tpl-preview-node-desc{font-size:11px;color:#999;flex:1}.tpl-form-group{margin-bottom:16px}.tpl-form-label{display:block;font-size:13px;font-weight:600;color:#ccc;margin-bottom:6px}.tpl-form-input{width:100%;padding:8px 12px;background:var(--bg-input);color:var(--text);border:1px solid #333;border-radius:4px;font-size:13px;font-family:inherit;outline:none;transition:border-color .2s;box-sizing:border-box}.tpl-form-input:focus{border-color:#00d4aa}.tpl-form-textarea{width:100%;padding:8px 12px;background:var(--bg-input);color:var(--text);border:1px solid #333;border-radius:4px;font-size:13px;font-family:inherit;outline:none;transition:border-color .2s;resize:vertical;box-sizing:border-box}.tpl-form-textarea:focus{border-color:#00d4aa}.tpl-form-select{width:100%;padding:8px 12px;background:var(--bg-input);color:var(--text);border:1px solid #333;border-radius:4px;font-size:13px;font-family:inherit;outline:none;cursor:pointer;transition:border-color .2s}.tpl-form-select:focus{border-color:#00d4aa}.tpl-confirm-text{font-size:14px;color:#ccc;line-height:1.6;margin:0}@media (max-width: 768px){.tpl-filter-row{flex-direction:column}.tpl-search,.tpl-select,.tpl-select-sm{flex:none;width:100%}.tpl-card-actions{flex-wrap:wrap}.tpl-modal{width:95vw}.row{flex-wrap:wrap}.row select{flex:1;min-width:0}.fb-config-row{flex-direction:column;align-items:stretch}.fb-mode-options{flex-direction:column}.fb-mode-btn{width:100%;min-width:0}.fb-name-input{max-width:100%}}.user-console{padding:0;height:100%;display:flex;flex-direction:column}.uc-toast{position:fixed;top:20px;right:20px;padding:10px 20px;border-radius:var(--radius);font-size:13px;z-index:9999;animation:fadeIn .2s}.uc-toast-info{background:#2a2a3a;color:#e0e0e0}.uc-toast-success{background:#1a3a2a;color:#00d4aa;border:1px solid #00d4aa44}.uc-toast-error{background:#3a1a1a;color:#ff6b6b;border:1px solid #ff6b6b44}.uc-loading{text-align:center;padding:40px;color:#888}.uc-empty{text-align:center;padding:60px 20px}.uc-empty-icon{font-size:48px;margin-bottom:12px}.uc-empty-text{font-size:15px;color:#aaa;margin-bottom:6px}.uc-empty-hint{font-size:12px;color:#666}.uc-empty-sm{text-align:center;padding:30px;color:#666;font-size:13px}.uc-templates{margin-top:4px}.uc-tpl-card{background:#1a1a2e;border:1px solid #2a2a3a;border-radius:var(--radius);padding:16px;margin-bottom:10px;transition:border-color .15s}.uc-tpl-card:hover{border-color:#3a3a5a}.uc-tpl-header{display:flex;align-items:center;gap:10px;margin-bottom:8px}.uc-tpl-name{font-size:15px;font-weight:700;color:#e0e0e0;flex:1}.uc-tpl-badge{font-size:11px;font-weight:600;padding:2px 10px;border-radius:10px}.uc-badge-published{background:#00d4aa26;color:#00d4aa}.uc-badge-draft{background:#ffd93d26;color:#ffd93d}.uc-badge-type{background:#6495ed26;color:#6495ed}.uc-tpl-desc{font-size:12px;color:#888;margin-bottom:10px;line-height:1.5}.uc-tpl-meta{display:flex;gap:14px;flex-wrap:wrap;margin-bottom:12px}.uc-meta-item{font-size:12px;color:#888}.uc-meta-credits{color:#00d4aa;font-weight:600}.uc-meta-earned{color:#6bcb77;font-weight:600}.uc-tpl-actions{display:flex;gap:8px}.uc-btn{padding:6px 14px;border-radius:var(--radius);font-size:12px;font-weight:600;cursor:pointer;background:transparent!important;transition:all .15s}.uc-btn-ghost{color:#aaa!important;border:1px solid #555!important}.uc-btn-ghost:hover{background:#aaaaaa1a!important;color:#ddd!important;border-color:#aaa!important}.uc-btn-primary{color:#00d4aa!important;border:1px solid #00d4aa!important}.uc-btn-primary:hover{background:#00d4aa26!important}.uc-btn-warn{color:#ffd93d!important;border:1px solid #ffd93d!important}.uc-btn-warn:hover{background:#ffd93d26!important}.uc-btn-danger{color:#ff6b6b!important;border:1px solid #ff6b6b!important}.uc-btn-danger:hover{background:#ff6b6b26!important}.uc-btn-success{color:#00d4aa!important;border:1px solid #00d4aa!important}.uc-btn-success:hover{background:#00d4aa26!important}.uc-credits{margin-top:4px}.uc-credit-tabs{display:flex;gap:0;margin-bottom:12px}.uc-credit-overview{display:flex;flex-direction:column;gap:16px}.uc-credit-balance{background:linear-gradient(135deg,#1a2a3e,#1a1a2e);border:1px solid #2a3a5a;border-radius:var(--radius);padding:24px;text-align:center}.uc-balance-label{font-size:13px;color:#888;margin-bottom:8px}.uc-balance-value{font-size:48px;font-weight:800;color:#00d4aa;line-height:1}.uc-balance-unit{font-size:14px;color:#666;margin-top:4px}.uc-credit-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}.uc-stat-card{background:#1a1a2e;border:1px solid #2a2a3a;border-radius:var(--radius);padding:16px;text-align:center}.uc-stat-value{font-size:24px;font-weight:700;color:#e0e0e0}.uc-stat-label{font-size:12px;color:#888;margin-top:4px}.uc-free-credits-card{background:linear-gradient(135deg,#00d4aa1a,#0096780d);border:1px solid rgba(0,212,170,.3);border-radius:var(--radius);padding:20px;display:flex;align-items:center;gap:16px}.uc-recovery-card{background:linear-gradient(135deg,#ffc1071a,#ff98000d);border:1px solid rgba(255,193,7,.3);border-radius:var(--radius);padding:20px;display:flex;align-items:center;gap:16px;margin-top:16px}.uc-recovery-icon{font-size:40px;flex-shrink:0}.uc-recovery-content{flex:1}.uc-recovery-title{font-size:16px;font-weight:700;color:#ffc107;margin-bottom:6px}.uc-recovery-code{font-size:24px;font-weight:800;font-family:monospace;color:#fff;letter-spacing:4px;background:#ffc10726;padding:8px 16px;border-radius:6px;display:inline-block;margin-bottom:6px}.uc-recovery-desc{font-size:12px;color:#aaa;line-height:1.4}.uc-recovery-copy-btn{background:linear-gradient(135deg,#ffc107,#ff9800);color:#fff;border:none;border-radius:8px;padding:10px 24px;font-size:14px;font-weight:700;cursor:pointer;flex-shrink:0;transition:all .2s}.uc-recovery-copy-btn:hover{transform:translateY(-1px);box-shadow:0 4px 12px #ffc1074d}.uc-recover-entry{display:flex;align-items:center;justify-content:center;gap:8px;margin-top:16px;padding:12px;background:#ffffff08;border-radius:var(--radius)}.uc-recover-entry-text{font-size:13px;color:#94a3b8}.uc-recover-entry-btn{background:none;border:1px solid #10b981;color:#10b981;border-radius:6px;padding:6px 16px;font-size:13px;font-weight:600;cursor:pointer;transition:all .2s}.uc-recover-entry-btn:hover{background:#10b981;color:#fff}.uc-free-credits-icon{font-size:40px;flex-shrink:0}.uc-free-credits-content{flex:1}.uc-free-credits-title{font-size:16px;font-weight:700;color:#e0e0e0;margin-bottom:6px}.uc-free-credits-desc{font-size:13px;color:#aaa;line-height:1.4}.uc-free-credits-btn{background:linear-gradient(135deg,#00d4aa,#00b088);color:#fff;border:none;border-radius:8px;padding:10px 24px;font-size:14px;font-weight:700;cursor:pointer;transition:transform .1s,opacity .1s;flex-shrink:0}.uc-free-credits-btn:hover:not(:disabled){transform:scale(1.03)}.uc-free-credits-btn:active:not(:disabled){transform:scale(.98)}.uc-free-credits-btn:disabled{opacity:.5;cursor:not-allowed}.uc-log-list{display:flex;flex-direction:column}.uc-log-item{display:flex;justify-content:space-between;align-items:center;padding:10px 14px;border-bottom:1px solid #1a1a2a;transition:background .1s}.uc-log-item:hover{background:#ffffff05}.uc-log-left{display:flex;align-items:center;gap:10px}.uc-log-type{font-size:11px;font-weight:700;padding:2px 8px;border-radius:8px;background:#ffffff0d;min-width:40px;text-align:center}.uc-log-remark{font-size:12px;color:#ddd}.uc-log-pay-amount{font-size:12px;color:#00d4aa;font-weight:600;margin-left:4px}.uc-remark-icon{margin-right:4px}.uc-log-right{display:flex;align-items:center;gap:12px}.uc-log-amount{font-size:14px;font-weight:700;min-width:50px;text-align:right}.uc-log-balance{font-size:11px;color:#666;min-width:60px}.uc-log-time{font-size:11px;color:#555;min-width:130px;text-align:right}.uc-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#0009;display:flex;justify-content:center;align-items:center;z-index:1000}.uc-modal{background:#12121a;border:1px solid #2a2a3a;border-radius:12px;width:480px;max-width:90vw;max-height:85vh;overflow-y:auto}.uc-modal-sm{width:360px}.uc-modal-header{display:flex;justify-content:space-between;align-items:center;padding:16px 20px;border-bottom:1px solid #2a2a3a}.uc-modal-header h3{font-size:15px;font-weight:700;color:#e0e0e0;margin:0}.uc-modal-close{background:none;border:none;color:#888;font-size:18px;cursor:pointer;padding:4px}.uc-modal-close:hover{color:#e0e0e0}.uc-modal-body{padding:20px}.uc-modal-body p{font-size:13px;color:#bbb;line-height:1.6}.uc-modal-footer{display:flex;justify-content:flex-end;gap:10px;padding:16px 20px;border-top:1px solid #2a2a3a}.uc-form-group{margin-bottom:16px}.uc-import-preview{display:flex;flex-wrap:wrap;gap:6px;max-height:150px;overflow-y:auto;padding:8px;background:var(--bg-input);border-radius:var(--radius);border:1px solid var(--border)}.uc-preview-tag{display:inline-block;padding:2px 8px;font-size:11px;background:#10b981;color:#fff;border-radius:3px;font-weight:600;font-family:monospace}.uc-preview-empty{font-size:12px;color:#94a3b8;font-style:italic}.uc-form-label{display:block;font-size:12px;font-weight:600;color:#aaa;margin-bottom:6px}.uc-form-hint{font-size:11px;color:#666;font-weight:400;margin-left:8px}.uc-form-input{width:100%;padding:8px 12px;background:#0a0a0a;border:1px solid #2a2a3a;border-radius:var(--radius);color:#e0e0e0;font-size:13px;outline:none;transition:border-color .15s}.uc-form-input:focus{border-color:#00d4aa}.uc-form-input-sm{width:80px}.uc-form-static{padding:8px 12px;background:#0a0a0a;border:1px solid #2a2a3a;border-radius:var(--radius);color:#e0e0e0;font-size:13px}.uc-form-textarea{width:100%;padding:8px 12px;background:#0a0a0a;border:1px solid #2a2a3a;border-radius:var(--radius);color:#e0e0e0;font-size:13px;outline:none;resize:vertical;transition:border-color .15s;font-family:inherit}.uc-form-textarea:focus{border-color:#00d4aa}.uc-form-info{background:#0a0a0a;border:1px solid #1a1a2a;border-radius:var(--radius);padding:12px}.uc-form-info-row{display:flex;justify-content:space-between;padding:4px 0;font-size:12px}.uc-form-info-row span:first-child{color:#888}.uc-form-info-row span:last-child{color:#ccc;font-weight:600}.uc-feedback{padding:16px}.uc-feedback-form{background:var(--bg-card);border:1px solid var(--border);border-radius:8px;padding:16px;margin-bottom:20px}.uc-feedback-form h4{margin:0 0 12px;font-size:14px;color:var(--text)}.uc-feedback-history{margin-top:20px}.uc-feedback-history h4{margin:0 0 12px;font-size:14px;color:var(--text)}.uc-fb-card{background:var(--bg-card);border:1px solid var(--border);border-radius:8px;padding:14px;margin-bottom:12px}.uc-fb-header{display:flex;align-items:center;gap:10px;margin-bottom:8px;flex-wrap:wrap}.uc-fb-id{font-size:12px;color:#888;font-weight:600}.uc-fb-category{font-size:11px;padding:2px 8px;background:#2a2a3a;border-radius:4px;color:#aaa}.uc-fb-status{font-size:11px;font-weight:600}.uc-fb-time{font-size:11px;color:#666;margin-left:auto}.uc-fb-content{font-size:13px;color:var(--text);line-height:1.5;padding:10px;background:var(--bg-input);border-radius:4px;white-space:pre-wrap}.uc-fb-replies{margin-top:12px;padding-top:12px;border-top:1px solid var(--border)}.uc-fb-reply{display:flex;flex-direction:column;gap:4px;padding:10px 12px;margin-bottom:8px;border-radius:6px}.uc-fb-reply.reply-admin{background:#00d4aa1a;border-left:3px solid #10b981}.uc-fb-reply.reply-user{background:#64647826;border-left:3px solid #666}.uc-fb-reply-author{font-size:11px;font-weight:600;color:#10b981}.reply-user .uc-fb-reply-author{color:#888}.uc-fb-reply-content{font-size:13px;color:var(--text);line-height:1.5;white-space:pre-wrap}.uc-fb-reply-time{font-size:10px;color:#555}.admin-back-bar{display:flex;align-items:center;gap:12px;padding:8px 0;margin-bottom:4px}.admin-back-title{font-size:15px;font-weight:700;color:#e0e0e0}.admin-panel{padding:0;height:100%;display:flex;flex-direction:column}.admin-tree-view{margin-top:4px}.atv-group{margin-bottom:8px;border:1px solid #2a2a2a;border-radius:var(--radius);overflow:hidden}.atv-group-header{display:flex;align-items:center;gap:10px;padding:10px 14px;background:#1a1a2e;cursor:pointer;-webkit-user-select:none;user-select:none;transition:background .15s}.atv-group-header:hover{background:#222240}.atv-toggle{font-size:12px;color:#888;width:16px;text-align:center}.atv-group-label{font-size:14px;font-weight:700;color:#e0e0e0;flex:1}.atv-group-count{font-size:12px;color:#888}.atv-layer-tag{font-size:11px;font-weight:700;padding:2px 8px;border-radius:10px;color:#fff}.atv-group-tagline{padding:6px 14px 6px 30px;font-size:12px;color:#666;background:#161628;font-style:italic}.atv-subgroups{padding-left:12px}.atv-subgroup{border-left:2px solid #333;margin:4px 0}.atv-subgroup-header{display:flex;align-items:center;gap:8px;padding:6px 12px;cursor:pointer;-webkit-user-select:none;user-select:none;transition:background .15s}.atv-subgroup-header:hover{background:#ffffff08}.atv-toggle-sm{font-size:11px;color:#888;width:14px;text-align:center}.atv-subgroup-label{font-size:13px;font-weight:600;color:#aaa}.atv-subgroup-count{font-size:11px;color:#666}.atv-children{padding-left:8px}.atv-node{padding:6px 12px;border-bottom:1px solid #1a1a1a;cursor:pointer;transition:background .15s}.atv-node:hover{background:#00d4aa0d}.atv-node-selected{background:#00d4aa1a;border-left:3px solid #00d4aa}.atv-node-hidden{opacity:.5}.atv-node-main{display:flex;align-items:center;gap:10px}.atv-node-id{font-size:12px;color:#888;font-family:Consolas,Monaco,monospace;min-width:180px}.atv-node-label{font-size:13px;font-weight:600;color:#e0e0e0;min-width:140px}.atv-node-missing{color:#ff6b6b;font-style:italic;font-weight:400}.atv-node-category{font-size:11px;color:#888;background:#222;padding:2px 8px;border-radius:8px}.atv-sort-btns{display:inline-flex;gap:2px;margin-left:auto}.atv-sort-btn{width:22px;height:22px;border:1px solid #333;background:#1a1a1a;color:#888;border-radius:4px;cursor:pointer;font-size:12px;line-height:1;display:flex;align-items:center;justify-content:center;transition:all .15s}.atv-sort-btn:hover{background:#2a2a2a;color:#00d4aa;border-color:#00d4aa}.catgrp-panel{display:flex;flex-direction:column;gap:24px}.catgrp-section{background:#161616;border:1px solid #2a2a2a;border-radius:var(--radius);padding:16px}.catgrp-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}.catgrp-header h3{font-size:15px;color:#e0e0e0;margin:0}.atv-node-detail{margin-top:8px;padding:10px;background:#111;border-radius:var(--radius);border:1px solid #2a2a2a}.atv-detail-row{display:flex;gap:16px;margin-bottom:8px;align-items:center}.atv-detail-key{font-size:12px;color:#888}.atv-detail-val{font-size:12px;color:#ccc;margin-right:12px}.atv-detail-prompt{margin-top:8px}.atv-detail-prompt-label{font-size:11px;color:#00d4aa;font-weight:600;margin-bottom:4px}.atv-detail-prompt-text{font-size:12px;color:#bbb;line-height:1.5;padding:8px;background:#0a0a0a;border-radius:4px;border:1px solid #222;white-space:pre-wrap;word-break:break-all;max-height:120px;overflow-y:auto}.admin-toolbar{display:flex;gap:10px;align-items:center;margin-bottom:16px;flex-wrap:wrap}.admin-search{flex:1;min-width:180px;background:var(--bg-input);border:1px solid #333;color:var(--text);padding:8px 12px;border-radius:var(--radius);font-size:13px;font-family:inherit}.admin-search:focus{outline:none;border-color:#00d4aa}.admin-select{background:var(--bg-input);border:1px solid #333;color:var(--text);padding:8px 12px;border-radius:var(--radius);font-size:13px;font-family:inherit;cursor:pointer}.admin-select:focus{outline:none;border-color:#00d4aa}.admin-btn-primary{background:#00d4aa;color:#fff;border:none;padding:8px 18px;font-size:13px;font-weight:600;font-family:inherit;border-radius:var(--radius);cursor:pointer;transition:all .2s;white-space:nowrap}.admin-btn-primary:hover{background:#00eabb}.admin-btn-ghost{background:transparent;color:#888;border:1px solid #444;padding:8px 18px;font-size:13px;font-family:inherit;border-radius:var(--radius);cursor:pointer;transition:all .2s}.admin-btn-ghost:hover{color:#ccc;border-color:#666}.admin-btn-sm{background:transparent;color:#00d4aa;border:1px solid #00d4aa;padding:3px 10px;font-size:12px;font-family:inherit;border-radius:4px;cursor:pointer;transition:all .2s;margin-right:6px}.admin-btn-sm:hover{background:#00d4aa;color:#fff}.admin-btn-sm.danger{color:#ff6b6b;border-color:#ff6b6b}.admin-btn-sm.danger:hover{background:#ff6b6b;color:#fff}.admin-btn-sm.accent{color:#ffd93d;border-color:#ffd93d}.admin-btn-sm.accent:hover{background:#ffd93d;color:#fff}.admin-loading{text-align:center;color:#666;padding:40px;font-size:14px}.admin-empty{text-align:center;color:#555;padding:40px;font-size:14px}.admin-table-header,.admin-table-row{display:flex;align-items:center;padding:10px 12px;gap:8px;font-size:13px}.admin-table-header{color:#888;font-weight:600;border-bottom:1px solid #222;position:sticky;top:0;background:var(--bg-card);z-index:1}.admin-table-row{border-bottom:1px solid #1a1a1a;transition:background .15s}.admin-table-row:hover{background:#00d4aa0a}.admin-table-row.row-hidden{opacity:.45}.col-path{flex:2;min-width:120px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.col-label{flex:1.2;min-width:80px}.col-layer{flex:.6;min-width:50px}.col-category{flex:1;min-width:70px}.col-order,.col-visible{flex:.5;min-width:40px;text-align:center}.col-actions{flex:1.2;min-width:100px}.col-id{flex:.5;min-width:40px}.col-sort{flex:.5;min-width:40px;text-align:center}.col-display{flex:1.5;min-width:100px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:#aaa}.col-name{flex:2;min-width:120px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.col-tpl-category{flex:1.2;min-width:100px}.col-nodes{flex:.5;min-width:40px;text-align:center}.col-platform{flex:.8;min-width:60px}.col-uses{flex:.5;min-width:40px;text-align:center}.col-review{flex:1;min-width:80px;text-align:center}.col-tpl-visible{flex:.5;min-width:40px;text-align:center}.col-tpl-actions{flex:1.2;min-width:100px}.layer-tag{display:inline-block;padding:2px 8px;border-radius:3px;font-size:11px;font-weight:700;letter-spacing:.5px}.layer-dut{background:#1a3a5c;color:#4fc3f7}.layer-gvl{background:#1a3c2a;color:#66bb6a}.layer-fc{background:#3c2a1a;color:#ffa726}.layer-fb{background:#3c1a2a;color:#ef5350}.layer-prg{background:#2a1a3c;color:#ab47bc}.toggle-btn{background:none;border:none;font-size:18px;cursor:pointer;padding:0;line-height:1;transition:color .2s}.toggle-btn.on{color:#00d4aa}.toggle-btn.off{color:#444}.toggle-btn:hover{transform:scale(1.2)}.admin-select-sm{background:var(--bg-input);border:1px solid #333;color:var(--text);padding:2px 6px;border-radius:3px;font-size:12px;font-family:inherit;cursor:pointer;max-width:100px}.admin-node-list,.admin-tpl-list{flex:1;overflow-y:auto;max-height:calc(100vh - 280px)}.admin-modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:1000}.admin-modal{background:#1a1a24;border:1px solid #333;border-radius:8px;width:640px;max-width:95vw;max-height:90vh;display:flex;flex-direction:column;box-shadow:0 8px 32px #00000080}.admin-modal-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid #222}.admin-modal-header h3{margin:0;font-size:16px;color:#eee}.admin-modal-close{background:none;border:none;color:#666;font-size:20px;cursor:pointer;padding:0;line-height:1}.admin-modal-close:hover{color:#ff6b6b}.admin-modal-body{padding:20px;overflow-y:auto;flex:1}.admin-modal-body label{display:block;font-size:13px;color:#aaa;margin-bottom:4px;margin-top:12px}.admin-modal-body label:first-child{margin-top:0}.admin-modal-body input[type=text],.admin-modal-body input[type=number],.admin-modal-body select,.admin-modal-body textarea{width:100%;background:var(--bg-input);border:1px solid #333;color:var(--text);padding:8px 10px;border-radius:4px;font-size:13px;font-family:inherit;box-sizing:border-box}.admin-modal-body input:focus,.admin-modal-body select:focus,.admin-modal-body textarea:focus{outline:none;border-color:#00d4aa}.admin-modal-body input:disabled{opacity:.5;cursor:not-allowed}.admin-textarea-lg{resize:vertical;min-height:60px;line-height:1.5}.admin-form-row{display:flex;gap:12px}.admin-form-col{flex:1}.admin-form-col label{margin-top:0}.admin-form-col input,.admin-form-col select{margin-top:4px}.required{color:#ff6b6b}.admin-modal-footer{display:flex;justify-content:flex-end;gap:10px;padding:16px 20px;border-top:1px solid #222}.admin-section-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}.admin-section-header h3{margin:0;font-size:16px;color:#eee}.admin-section-actions{display:flex;gap:8px;align-items:center}.admin-feedback{padding:0}.admin-feedback-layout{display:flex;gap:16px;height:calc(100vh - 320px);min-height:400px}.admin-feedback-list{width:320px;flex-shrink:0;background:var(--bg-card);border:1px solid var(--border);border-radius:6px;overflow-y:auto;display:flex;flex-direction:column}.admin-feedback-item{padding:12px;border-bottom:1px solid var(--border);cursor:pointer;transition:background .15s}.admin-feedback-item:hover{background:#00d4aa0d}.admin-feedback-item.selected{background:#00d4aa1f;border-left:3px solid #10b981}.admin-feedback-item-header{display:flex;align-items:center;gap:8px;margin-bottom:6px}.admin-feedback-id{font-size:12px;color:#888;font-weight:600}.admin-feedback-category{font-size:11px;padding:2px 6px;background:#2a2a3a;border-radius:3px;color:#aaa}.admin-feedback-status{font-size:11px;padding:2px 8px;border-radius:3px;color:#fff;font-weight:600}.admin-feedback-item-content{font-size:13px;color:var(--text);line-height:1.4;margin-bottom:6px}.admin-feedback-item-meta{display:flex;gap:12px;font-size:11px;color:#666}.admin-feedback-detail{flex:1;background:var(--bg-card);border:1px solid var(--border);border-radius:6px;display:flex;flex-direction:column;overflow:hidden}.admin-feedback-detail-header{display:flex;align-items:center;gap:8px;padding:12px 16px;border-bottom:1px solid var(--border);font-size:14px;font-weight:600;color:#eee}.admin-feedback-detail-body{padding:16px;flex:1;overflow-y:auto}.admin-feedback-meta-row{display:flex;flex-wrap:wrap;gap:16px;font-size:12px;color:#888;margin-bottom:12px}.admin-feedback-content{font-size:14px;line-height:1.6;color:var(--text);padding:12px;background:var(--bg-input);border-radius:4px;white-space:pre-wrap}.admin-feedback-replies{padding:16px;border-top:1px solid var(--border);max-height:200px;overflow-y:auto}.admin-feedback-replies h4{margin:0 0 12px;font-size:13px;color:#aaa}.admin-feedback-reply{margin-bottom:10px;padding:10px;border-radius:6px}.admin-feedback-reply.reply-admin{background:#00d4aa1a;border-left:3px solid #10b981}.admin-feedback-reply.reply-user{background:#64647826;border-left:3px solid #666}.reply-header{display:flex;justify-content:space-between;margin-bottom:6px}.reply-author{font-size:12px;font-weight:600;color:#10b981}.reply-user .reply-author{color:#888}.reply-time{font-size:11px;color:#555}.reply-content{font-size:13px;line-height:1.5;color:var(--text);white-space:pre-wrap}.admin-feedback-reply-form{padding:16px;border-top:1px solid var(--border)}.admin-pagination{display:flex;align-items:center;justify-content:center;gap:12px;padding:12px;border-top:1px solid var(--border);margin-top:auto}.admin-pagination button{background:var(--bg-input);border:1px solid var(--border);color:var(--text);padding:6px 12px;border-radius:4px;font-size:12px;cursor:pointer;font-family:inherit}.admin-pagination button:hover:not(:disabled){border-color:#10b981;color:#10b981}.admin-pagination button:disabled{opacity:.4;cursor:not-allowed}.admin-pagination span{font-size:12px;color:#888}.admin-error-log{padding:0}.error-stats-bar{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:16px;padding:12px;background:var(--bg-card);border-radius:6px;border:1px solid var(--border)}.error-stat-chip{display:inline-block;padding:4px 10px;border-radius:4px;font-size:12px;font-weight:600;color:#fff}.error-trend{display:flex;align-items:flex-end;gap:6px;margin-bottom:16px;padding:12px;background:var(--bg-card);border-radius:6px;border:1px solid var(--border)}.error-trend-day{display:flex;flex-direction:column;align-items:center;gap:4px}.error-trend-bar{width:24px;background:#10b981;border-radius:2px 2px 0 0;min-height:2px}.error-trend-label{font-size:10px;color:#666}.admin-table{background:var(--bg-card);border:1px solid var(--border);border-radius:6px;overflow:hidden}.error-detail{padding:12px 16px;background:#0003;border-bottom:1px solid var(--border);font-size:12px;color:#aaa}.error-detail div{margin-bottom:8px}.error-detail strong{color:#ccc;margin-right:8px}.recharge-panel{padding:0}.recharge-sub-tabs{display:flex;gap:4px;margin-bottom:20px;border-bottom:1px solid var(--border);padding-bottom:8px}.rp-card{background:var(--bg-card);border:1px solid var(--border);border-radius:8px;padding:20px;margin-bottom:16px}.rp-card h4{color:var(--text);margin:0 0 16px;font-size:15px}.rp-row{display:flex;align-items:center;margin-bottom:12px;gap:12px}.rp-row label{color:#aaa;font-size:13px;min-width:120px;text-align:right}.rp-row input{background:#0000004d;border:1px solid var(--border);border-radius:4px;color:var(--text);padding:6px 10px;font-size:14px;width:120px}.rp-row-switch{margin-top:4px}.rp-toggle{background:#ffffff1a;border:1px solid var(--border);border-radius:4px;color:#888;padding:6px 16px;cursor:pointer;font-size:13px;transition:all .2s}.rp-toggle.active{background:#10b98126;border-color:#00d4aa;color:#00d4aa}.rp-preview{background:#10b98114;border:1px solid rgba(16,185,129,.2);border-radius:6px;padding:12px 16px;color:#00d4aa;font-size:14px;margin-top:8px}.rp-promo-tag{background:#ff6b6b;color:#fff;font-size:11px;padding:2px 6px;border-radius:3px;margin-left:8px}.rp-actions{display:flex;align-items:center;gap:12px;margin-top:16px}.rp-save-btn{background:linear-gradient(135deg,#00d4aa,#059669);color:#fff;border:none;border-radius:6px;padding:8px 24px;font-size:14px;cursor:pointer;transition:opacity .2s}.rp-save-btn:hover{opacity:.9}.rp-save-btn:disabled{opacity:.5;cursor:not-allowed}.rp-msg{font-size:13px}.rp-msg.success{color:#00d4aa}.rp-msg.error{color:#ff6b6b}.ri-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin-bottom:20px}.ri-stat-card{background:var(--bg-card);border:1px solid var(--border);border-radius:8px;padding:16px;text-align:center}.ri-stat-value{font-size:22px;font-weight:700;color:#00d4aa}.ri-stat-label{font-size:12px;color:#888;margin-top:4px}.ri-col-time{width:160px}.ri-col-uuid{width:80px}.ri-col-type,.ri-col-amount{width:60px}.ri-col-remark{flex:1}.ri-type-tag{font-size:11px;padding:2px 8px;border-radius:3px}.ri-type-tag.recharge{background:#10b98126;color:#00d4aa}.ri-type-tag.income{background:#4d96ff26;color:#4d96ff}.ri-type-tag.paid{background:#10b98126;color:#00d4aa}.ri-type-tag.pending{background:#ffd93d26;color:#ffd93d}.ri-pagination{display:flex;align-items:center;justify-content:center;gap:12px;margin-top:16px}.ri-pagination button{background:#ffffff14;border:1px solid var(--border);border-radius:4px;color:var(--text);padding:4px 12px;cursor:pointer;font-size:12px}.ri-pagination button:disabled{opacity:.4;cursor:not-allowed}.ri-pagination span{color:#888;font-size:12px}.uc-referral-section{padding:0}.uc-referral-card{background:linear-gradient(135deg,#10b98114,#4d96ff14);border:1px solid rgba(16,185,129,.25);border-radius:12px;padding:24px;margin-bottom:16px}.uc-referral-header{display:flex;align-items:center;gap:8px;margin-bottom:8px}.uc-referral-icon{font-size:24px}.uc-referral-header h3{color:var(--text);margin:0;font-size:16px}.uc-referral-desc{color:#888;font-size:13px;margin:0 0 16px}.uc-referral-link-row{display:flex;gap:8px;margin-bottom:16px}.uc-referral-input{flex:1;background:#0000004d;border:1px solid var(--border);border-radius:6px;color:#aaa;padding:8px 12px;font-size:12px;font-family:monospace}.uc-referral-copy-btn{background:linear-gradient(135deg,#00d4aa,#059669);color:#fff;border:none;border-radius:6px;padding:8px 20px;font-size:13px;cursor:pointer;white-space:nowrap;transition:opacity .2s}.uc-referral-copy-btn:hover{opacity:.9}.uc-referral-stats{display:flex;gap:32px}.uc-referral-stat{display:flex;flex-direction:column;align-items:center}.uc-referral-stat-value{font-size:20px;font-weight:700;color:#00d4aa}.uc-referral-stat-label{font-size:12px;color:#888;margin-top:2px}.uc-referral-history{background:var(--bg-card);border:1px solid var(--border);border-radius:8px;padding:16px}.uc-referral-history h4{color:var(--text);margin:0 0 12px;font-size:14px}.uc-referral-record{display:flex;align-items:center;padding:8px 0;border-bottom:1px solid rgba(255,255,255,.05);font-size:13px}.uc-referral-record:last-child{border-bottom:none}.uc-rr-user{color:#888;font-family:monospace;min-width:100px}.uc-rr-reward{color:#00d4aa;font-weight:600;min-width:80px}.uc-rr-time{color:#666;font-size:12px}.smart-workbench{max-width:900px;margin:0 auto}.smart-step-section{margin-bottom:24px;padding-bottom:24px;border-bottom:1px solid var(--border)}.smart-step-section:last-of-type{border-bottom:none;margin-bottom:0;padding-bottom:0}.smart-section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}.smart-section-header h3{font-size:16px;color:#10b981;margin:0}.smart-section-actions{display:flex;gap:8px;align-items:center}.btn-file-import{display:inline-flex;align-items:center;gap:4px;padding:6px 14px!important;background:var(--bg-input)!important;color:var(--text)!important;border:1px solid var(--border)!important;border-radius:var(--radius)!important;font-size:13px!important;font-family:inherit;cursor:pointer;transition:all .2s;white-space:nowrap}.btn-file-import:hover{border-color:#10b981!important;color:#10b981!important}.io-more{font-size:12px;color:#94a3b8;margin-top:8px;text-align:center}.smart-step{background:var(--bg-card);border-radius:var(--radius);border:1px solid var(--border);padding:24px}.smart-step h3{font-size:18px;color:#10b981;margin-bottom:16px}.step-hint{font-size:13px;color:#94a3b8;margin-bottom:12px}.io-textarea{width:100%;min-height:150px;padding:12px;background:var(--bg-input);border:1px solid var(--border);border-radius:var(--radius);color:var(--text);font-family:Consolas,monospace;font-size:13px;resize:vertical;margin-bottom:12px}.io-preview{margin:16px 0;padding:16px;background:var(--bg-input);border-radius:var(--radius);border:1px solid var(--border)}.io-preview h4{font-size:14px;color:#10b981;margin-bottom:12px}.io-table{width:100%;border-collapse:collapse;font-size:13px}.io-table th,.io-table td{padding:8px 12px;text-align:left;border-bottom:1px solid var(--border)}.io-table th{color:#94a3b8;font-weight:500}.step-actions{display:flex;justify-content:space-between;margin-top:20px;padding-top:16px;border-top:1px solid var(--border)}.project-name-input{display:flex;align-items:center;gap:12px;margin-bottom:20px;padding:12px;background:var(--bg-input);border-radius:var(--radius);border:1px solid var(--border)}.project-name-input label{color:#94a3b8;font-size:14px}.project-name-input input{flex:1;padding:8px 12px;background:var(--bg);border:1px solid var(--border);border-radius:var(--radius);color:var(--text);font-family:inherit;font-size:14px}.sbr-list{display:flex;flex-direction:column;gap:12px;margin-bottom:20px}.sbr-item{padding:16px;background:var(--bg-input);border:1px solid var(--border);border-radius:var(--radius);transition:all .2s}.sbr-item.selected{border-color:#10b981;background:#00d4aa0d}.sbr-header{display:flex;align-items:center;gap:12px;margin-bottom:8px}.sbr-header input[type=checkbox]{width:18px;height:18px;accent-color:#10b981}.sbr-name{font-size:15px;font-weight:600;color:var(--text)}.sbr-gen-type{font-size:12px;color:#94a3b8;padding:2px 8px;background:var(--bg);border-radius:4px}.sbr-desc{font-size:13px;color:#94a3b8;margin:0;padding-left:30px}.sbr-options{margin-top:12px;padding-top:12px;border-top:1px solid var(--border)}.option-row{display:flex;align-items:flex-start;gap:12px;margin-bottom:12px}.option-row label{width:60px;color:#94a3b8;font-size:13px;padding-top:6px}.option-row select{flex:1;padding:8px 12px;background:var(--bg);border:1px solid var(--border);border-radius:var(--radius);color:var(--text);font-family:inherit;font-size:13px}.option-row textarea{flex:1;min-height:60px;padding:8px 12px;background:var(--bg);border:1px solid var(--border);border-radius:var(--radius);color:var(--text);font-family:inherit;font-size:13px;resize:vertical}.var-summary{margin:20px 0;padding:16px;background:var(--bg-input);border-radius:var(--radius);border:1px solid var(--border)}.var-summary h4{font-size:14px;color:#10b981;margin-bottom:12px}.var-summary p{font-size:13px;color:#94a3b8;margin:4px 0}.alarm-info{margin-top:16px;padding-top:16px;border-top:1px solid var(--border)}.alarm-info h5{font-size:14px;color:#f46;margin-bottom:8px}.btn-generate{padding:12px 32px;font-size:15px;font-weight:600}.generation-progress{margin:16px 0;padding:16px;background:var(--bg-input);border-radius:var(--radius);border:1px solid var(--border)}.progress-item{padding:6px 0;font-size:13px;color:#94a3b8}.progress-item.generating{color:#10b981}.progress-item.done{color:#0f8}.progress-item.error{color:#f46}.result-summary{padding:20px;background:#00d4aa1a;border-radius:var(--radius);border:1px solid #10b981;margin-bottom:20px}.result-summary h4{font-size:18px;color:#10b981;margin-bottom:12px}.sbr-codes{margin:20px 0}.sbr-codes h4{font-size:14px;color:#94a3b8;margin-bottom:12px}.sbr-code-item{margin-bottom:16px;border:1px solid var(--border);border-radius:var(--radius);overflow:hidden}.sbr-code-header{display:flex;justify-content:space-between;align-items:center;padding:10px 14px;background:var(--bg-input);border-bottom:1px solid var(--border)}.sbr-code-header span{font-size:14px;color:var(--text)}.btn-download-small{padding:4px 12px;background:var(--bg);border:1px solid var(--border);border-radius:4px;color:#94a3b8;font-size:12px;cursor:pointer;font-family:inherit}.btn-download-small:hover{background:var(--bg-hover);color:#10b981}.code-preview{padding:14px;background:var(--bg);font-family:Consolas,monospace;font-size:12px;color:#94a3b8;overflow-x:auto;white-space:pre;max-height:200px;overflow-y:auto}.download-actions{display:flex;gap:12px;margin-top:20px;padding-top:16px;border-top:1px solid var(--border)}.no-result{text-align:center;padding:40px;color:#94a3b8}.usage-stats-panel{padding:20px}.usage-stats-filters{display:flex;gap:16px;align-items:center;margin-bottom:20px;flex-wrap:wrap}.usage-stats-filters label{display:flex;align-items:center;gap:8px;color:var(--text);font-size:13px}.usage-stats-filters input[type=date]{background:var(--bg-input);border:1px solid #333;color:var(--text);padding:6px 10px;border-radius:4px;font-size:13px}.usage-summary-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:16px;margin-bottom:24px}.usage-card{background:var(--bg-card);border:1px solid var(--border);border-radius:8px;padding:20px;text-align:center}.usage-card-value{font-size:32px;font-weight:700;color:#10b981}.usage-card-label{font-size:13px;color:#94a3b8;margin-top:4px}.usage-stats-section{margin-bottom:24px}.usage-stats-section h4{margin:0 0 12px;font-size:14px;color:var(--text)}.usage-type-stats{display:flex;flex-wrap:wrap;gap:10px}.usage-type-item{display:flex;align-items:center;gap:8px;background:var(--bg-card);border:1px solid var(--border);border-radius:20px;padding:6px 14px;font-size:13px}.usage-type-name{color:var(--text)}.usage-type-count{color:#10b981;font-weight:600}.usage-page-stats{display:flex;flex-wrap:wrap;gap:8px}.usage-page-item{display:flex;align-items:center;gap:8px;background:var(--bg-card);border:1px solid var(--border);border-radius:4px;padding:6px 12px;font-size:12px}.usage-page-name{color:#94a3b8}.usage-page-count{color:#10b981;font-weight:600}.usage-daily-stats{display:flex;gap:8px;overflow-x:auto;padding-bottom:10px}.usage-daily-item{flex-shrink:0;width:60px;text-align:center}.usage-daily-date{font-size:11px;color:#94a3b8;margin-bottom:6px}.usage-daily-bar{width:40px;margin:0 auto;background:linear-gradient(to top,#10b981,#00d4aa4d);border-radius:4px 4px 0 0;min-height:4px}.usage-daily-count{font-size:13px;font-weight:600;color:var(--text);margin-top:4px}.usage-daily-visitors{font-size:10px;color:#94a3b8}.usage-user-stats{display:flex;flex-direction:column;gap:8px}.usage-user-item{display:flex;align-items:center;gap:12px;background:var(--bg-card);border:1px solid var(--border);border-radius:4px;padding:8px 12px;font-size:13px}.usage-user-rank{color:#94a3b8;min-width:24px}.usage-user-uuid{font-family:monospace;color:var(--text);flex:1}.usage-user-count{color:#10b981;font-weight:600}.usage-log-filters{margin-bottom:12px}.usage-log-table{border:1px solid var(--border);border-radius:6px;overflow:hidden}.admin-table-header{display:grid;grid-template-columns:160px 120px 100px 1fr 120px 100px;gap:8px;padding:10px 12px;background:var(--bg-card);border-bottom:1px solid var(--border);font-size:12px;font-weight:600;color:#94a3b8}.admin-table-row{display:grid;grid-template-columns:160px 120px 100px 1fr 120px 100px;gap:8px;padding:8px 12px;border-bottom:1px solid var(--border);font-size:12px;color:var(--text);align-items:center}.admin-table-row:last-child{border-bottom:none}.admin-table-row:hover{background:#00d4aa08}.usage-log-col{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.usage-log-detail{font-size:11px;color:#94a3b8}.usage-type-tag{display:inline-block;padding:2px 8px;border-radius:10px;font-size:11px}.usage-type-tag.type-page_view{background:#e0e0e0;color:#333}.usage-type-tag.type-generate_mimic{background:#4caf50;color:#fff}.usage-type-tag.type-generate_block{background:#2196f3;color:#fff}.usage-type-tag.type-generate_smart_project{background:#ff9800;color:#fff}.usage-type-tag.type-translate_code{background:#9c27b0;color:#fff}.usage-type-tag.type-claim_referral{background:#00bcd4;color:#fff}.usage-type-tag.type-claim_free_credits{background:#e91e63;color:#fff}.usage-log-pagination{display:flex;align-items:center;gap:12px;margin-top:12px;justify-content:center}@media (max-width: 768px){.admin-table-header,.admin-table-row{grid-template-columns:130px 90px 80px 1fr}.admin-table-header>:nth-child(5),.admin-table-header>:nth-child(6),.admin-table-row>:nth-child(5),.admin-table-row>:nth-child(6){display:none}}
