:root{--bg: #fafafb;--bg-gradient: linear-gradient(135deg, #f8fafc 0%, #f5f3ff 50%, #fef6f4 100%);--surface: rgba(255, 255, 255, .7);--surface-solid: #ffffff;--surface-2: #fafafa;--surface-3: #f4f4f6;--border: rgba(15, 23, 42, .06);--border-strong: rgba(15, 23, 42, .1);--border-dashed: rgba(15, 23, 42, .15);--text-0: #0a0a0f;--text-1: #1e293b;--text-2: #64748b;--text-3: #94a3b8;--accent: #6366f1;--accent-hover: #4f46e5;--accent-soft: #eef2ff;--success: #10b981;--warning: #f59e0b;--danger: #ef4444;--tab-color: #6366f1;--tab-soft: #eef2ff;--shadow-sm: 0 1px 2px rgba(15, 23, 42, .04);--shadow-md: 0 1px 3px rgba(15, 23, 42, .06), 0 4px 12px rgba(15, 23, 42, .04);--shadow-lg: 0 4px 6px rgba(15, 23, 42, .05), 0 12px 32px rgba(15, 23, 42, .08);--shadow-xl: 0 8px 12px rgba(15, 23, 42, .06), 0 20px 48px rgba(15, 23, 42, .12);--r-sm: 8px;--r-md: 12px;--r-lg: 18px;--r-xl: 24px;--r-pill: 999px;--theme-transition: background-color .3s ease, color .3s ease, border-color .3s ease, box-shadow .3s ease}:root[data-theme=dark]{--bg: #0a0a0f;--bg-gradient: linear-gradient(135deg, #0a0a0f 0%, #15102a 50%, #0f0a1a 100%);--surface: rgba(30, 30, 46, .6);--surface-solid: #15151f;--surface-2: #1f1f2e;--surface-3: #2a2a3d;--border: rgba(255, 255, 255, .08);--border-strong: rgba(255, 255, 255, .15);--border-dashed: rgba(255, 255, 255, .2);--text-0: #ffffff;--text-1: #e2e8f0;--text-2: #94a3b8;--text-3: #64748b;--accent: #818cf8;--accent-hover: #a5b4fc;--accent-soft: rgba(129, 140, 248, .15);--success: #34d399;--warning: #fbbf24;--danger: #f87171;--shadow-sm: 0 1px 2px rgba(0, 0, 0, .3);--shadow-md: 0 1px 3px rgba(0, 0, 0, .4), 0 4px 12px rgba(0, 0, 0, .3);--shadow-lg: 0 4px 6px rgba(0, 0, 0, .4), 0 12px 32px rgba(0, 0, 0, .3);--shadow-xl: 0 8px 12px rgba(0, 0, 0, .4), 0 20px 48px rgba(0, 0, 0, .4)}.material-symbols-outlined{font-variation-settings:"FILL" 0,"wght" 400,"GRAD" 0,"opsz" 24;font-size:20px;line-height:1;user-select:none;vertical-align:middle;display:inline-block;font-style:normal}.ms-sm{font-size:16px}.ms-xs{font-size:14px}.md-sm{font-size:18px}.ms-md{font-size:22px}.ms-lg{font-size:32px}.ms-xl{font-size:64px}*{margin:0;padding:0;box-sizing:border-box}html,body{height:100%;background:var(--bg);background-image:var(--bg-gradient);background-attachment:fixed;color:var(--text-1);font-family:DM Sans,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,PingFang SC,Hiragino Sans GB,Microsoft YaHei,sans-serif;font-size:14px;line-height:1.5;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-feature-settings:"cv11","ss01"}#root{height:100%}.app{max-width:1200px;margin:0 auto;height:100vh;display:flex;flex-direction:column;position:relative;overflow:hidden;background:#ffffff8c;backdrop-filter:blur(30px);-webkit-backdrop-filter:blur(30px);border:1px solid var(--border);border-radius:0;box-shadow:0 0 0 1px #ffffff80 inset,0 24px 80px -12px #0f172a14,0 8px 24px -4px #0f172a0a}@media (max-height: 760px){.app{height:auto;min-height:100vh}.main{overflow:visible}}@media (min-width: 1280px){.app{margin-top:20px;margin-bottom:20px;height:calc(100vh - 40px);border-radius:20px;overflow:hidden}}.top-progress{position:fixed;top:0;left:0;height:2px;background:linear-gradient(90deg,var(--accent),#ec4899,var(--accent));background-size:200% 100%;animation:shimmer 1.5s linear infinite;z-index:1000;transition:width .3s ease;box-shadow:0 0 8px #6366f180}@keyframes shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.header{display:flex;justify-content:space-between;align-items:center;padding:14px 28px;background:var(--surface);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-bottom:1px solid var(--border);flex-shrink:0;position:relative;z-index:10}.hero{display:flex;align-items:center;gap:16px}.hero-logo-wrap{width:48px;height:48px;border-radius:12px;background:linear-gradient(135deg,#f0f0ff,#ffe0e9);display:flex;align-items:center;justify-content:center;box-shadow:var(--shadow-sm)}.hero-logo{width:36px;height:36px;filter:drop-shadow(0 2px 4px rgba(99,102,241,.2));animation:float 4s ease-in-out infinite}@keyframes float{0%,to{transform:translateY(0) rotate(0)}50%{transform:translateY(-2px) rotate(3deg)}}.hero-text{display:flex;flex-direction:column;line-height:1.15}.hero-title{font-size:26px;font-weight:700;color:var(--text-0);letter-spacing:-.6px;font-family:DM Sans,sans-serif}.hero-accent{background:linear-gradient(135deg,#6366f1,#ec4899,#f59e0b);background-size:200% 200%;-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;animation:gradient 6s ease infinite}@keyframes gradient{0%,to{background-position:0% 50%}50%{background-position:100% 50%}}.hero-subtitle{font-size:12px;color:var(--text-2);margin-top:2px;font-weight:400;letter-spacing:.2px}.warning{display:flex;align-items:center;gap:6px;background:#f59e0b14;border-bottom:1px solid rgba(245,158,11,.2);color:#b45309;padding:8px 32px;font-size:12px;flex-shrink:0}.tabs-nav{display:flex;align-items:center;gap:16px;padding:18px 32px;flex-shrink:0;background:transparent}.tabs-dashed{display:inline-flex;border:1.5px dashed var(--border-dashed);border-radius:var(--r-xl);padding:4px;gap:2px;background:var(--surface);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);transition:all .3s}.tabs-dashed:hover{border-color:var(--border-strong)}.tab-nav{position:relative;display:flex;align-items:center;gap:8px;background:transparent;border:none;color:var(--text-2);padding:10px 18px;border-radius:var(--r-lg);cursor:pointer;font-size:14px;font-weight:500;font-family:inherit;transition:all .2s}.tab-nav:hover{color:var(--text-1);background:var(--surface-2)}.tab-nav.active{background:var(--surface-solid);color:var(--text-0);font-weight:600;box-shadow:var(--shadow-md)}.tab-nav-icon{display:inline-flex;align-items:center;justify-content:center;color:var(--tab-c);transition:transform .3s}.tab-nav:hover .tab-nav-icon{transform:scale(1.15)}.tab-nav-label{font-size:14px}.tab-hint-inline{display:flex;align-items:center;gap:6px;font-size:12px;color:var(--text-2);padding:6px 14px;background:var(--surface);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border:1px solid var(--border);border-radius:var(--r-pill);transition:all .3s;animation:fadeIn .3s ease-out}.tab-hint-dot{width:6px;height:6px;border-radius:50%;background:var(--tab-color);box-shadow:0 0 6px currentColor;transition:background .3s}@keyframes fadeIn{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.main{flex:1;display:grid;grid-template-columns:360px 1fr;gap:20px;padding:0 32px 32px;overflow:hidden;min-height:0}.left-panel,.right-panel{display:flex;flex-direction:column;gap:16px;min-height:0;overflow-y:auto}.card{background:var(--surface);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border:1px solid var(--border);border-radius:var(--r-lg);padding:18px;box-shadow:var(--shadow-sm);transition:box-shadow .2s,border-color .2s}.card:hover{box-shadow:var(--shadow-md);border-color:var(--border-strong)}.input-card,.config-card{flex-shrink:0}.output-card{flex:1;display:flex;flex-direction:column;gap:12px;overflow:hidden}.upload-zone{border:1.5px dashed var(--border-dashed);border-radius:var(--r-lg);padding:24px 16px;text-align:center;cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1);background:var(--surface-2);min-height:140px;display:flex;align-items:center;justify-content:center;position:relative;overflow:hidden}.upload-zone:before{content:"";position:absolute;inset:0;background:radial-gradient(circle at center,var(--tab-color),transparent 70%);opacity:0;transition:opacity .3s}.upload-zone:hover{border-color:var(--tab-color);border-style:solid;background:var(--surface-3);transform:translateY(-2px);box-shadow:var(--shadow-md)}.upload-zone:hover:before{opacity:.05}.upload-prompt{color:var(--text-2);position:relative;display:flex;flex-direction:column;align-items:center;gap:10px}.upload-icon-circle{width:56px;height:56px;border-radius:50%;display:flex;align-items:center;justify-content:center;transition:transform .3s,box-shadow .3s}.upload-zone:hover .upload-icon-circle{transform:scale(1.1);box-shadow:0 4px 16px #00000014}.upload-text{font-size:14px;color:var(--text-1);font-weight:500}.upload-hint{font-size:11px;color:var(--text-3)}.preview-container{width:100%;display:flex;flex-direction:column;align-items:center;gap:8px;position:relative}.preview-media{max-width:100%;max-height:200px;border-radius:var(--r-md)}.preview-audio{width:100%}.preview-info{display:flex;align-items:center;gap:4px;font-size:11px;color:var(--text-2)}.preview-size{color:var(--text-3)}.examples-row{display:flex;align-items:center;gap:8px;margin-top:14px;flex-wrap:wrap}.examples-label{display:flex;align-items:center;gap:4px;font-size:12px;color:var(--text-2);font-weight:500}.chip{display:inline-flex;align-items:center;gap:4px;background:var(--surface-2);border:1px solid var(--border);color:var(--text-1);padding:5px 12px;border-radius:var(--r-pill);cursor:pointer;font-size:12px;font-weight:500;font-family:inherit;transition:all .2s}.chip:hover{background:var(--tab-color);border-color:var(--tab-color);color:#fff;transform:translateY(-1px);box-shadow:0 4px 12px #6366f14d}.chip:active{transform:translateY(0)}.field-group{display:flex;flex-direction:column;gap:6px}.field-label{display:flex;justify-content:space-between;align-items:center;font-size:12px;color:var(--text-2);font-weight:500}.field-label span:first-child{display:flex;align-items:center;gap:6px}.field-warn{color:var(--warning);font-size:10px}.field-hint{display:flex;align-items:center;gap:3px;color:var(--text-2);font-size:10px}.select-wrap{position:relative}.select{appearance:none;-webkit-appearance:none;-moz-appearance:none;width:100%;background:var(--surface-2);border:1px solid var(--border);color:var(--text-1);padding:9px 36px 9px 12px;border-radius:var(--r-md);font-size:13px;font-family:inherit;cursor:pointer;outline:none;transition:all .2s}.select:hover{border-color:var(--border-strong)}.select:focus,input:focus{border-color:var(--tab-color);box-shadow:0 0 0 3px var(--tab-soft)}input[type=text],input[type=password]{width:100%;background:var(--surface-2);border:1px solid var(--border);color:var(--text-1);padding:9px 12px;border-radius:var(--r-md);font-size:13px;font-family:inherit;outline:none;transition:all .2s}.select-caret{position:absolute;right:12px;top:50%;transform:translateY(-50%);pointer-events:none;color:var(--text-2);font-size:18px}.btn-pill{display:inline-flex;align-items:center;justify-content:center;gap:6px;border:none;cursor:pointer;font-family:inherit;font-weight:500;transition:all .2s;white-space:nowrap}.btn-pill-primary{background:var(--accent);color:#fff;padding:9px 18px;border-radius:var(--r-pill);font-size:13px;box-shadow:0 1px 2px #6366f133}.btn-pill-primary:hover:not(:disabled){background:var(--accent-hover);transform:translateY(-1px);box-shadow:0 6px 16px #6366f159}.btn-pill-primary:active:not(:disabled){transform:translateY(0)}.btn-pill-primary:disabled{background:var(--surface-3);color:var(--text-3);cursor:not-allowed;box-shadow:none}.btn-pill-ghost{background:var(--surface);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);color:var(--text-1);padding:8px 16px;border-radius:var(--r-pill);border:1px solid var(--border);font-size:13px;position:relative}.btn-pill-ghost:hover{background:var(--surface-2);border-color:var(--border-strong);transform:translateY(-1px);box-shadow:var(--shadow-sm)}.btn-pill-block{width:100%;margin-top:12px;font-size:14px;padding:12px}.btn-pill-mini{background:var(--surface-2);color:var(--text-1);padding:4px 10px;border-radius:var(--r-pill);font-size:11px;border:1px solid var(--border);display:inline-flex;align-items:center;gap:4px}.btn-pill-mini:hover{background:var(--tab-color);border-color:var(--tab-color);color:#fff}.btn-pill-danger:hover{background:var(--danger);border-color:var(--danger);color:#fff}.spinner{display:inline-block;width:14px;height:14px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .8s linear infinite}.spinner-lg{width:40px;height:40px;border-width:3px;border-color:var(--tab-soft);border-top-color:var(--tab-color)}@keyframes spin{to{transform:rotate(360deg)}}.seg-control{display:grid;grid-template-columns:repeat(4,1fr);gap:4px;background:var(--surface-2);padding:4px;border-radius:var(--r-md);border:1px solid var(--border)}.seg-btn{display:flex;align-items:center;justify-content:center;gap:4px;background:transparent;border:none;color:var(--text-2);padding:7px 4px;border-radius:8px;cursor:pointer;font-size:11px;font-weight:500;font-family:inherit;transition:all .2s}.seg-btn:hover{color:var(--text-1)}.seg-btn.active{background:var(--surface-solid);color:var(--tab-color);font-weight:600;box-shadow:var(--shadow-sm)}.badge{position:absolute;top:-4px;right:-4px;background:var(--accent);color:#fff;font-size:10px;font-weight:700;padding:1px 6px;border-radius:var(--r-pill);min-width:16px;text-align:center;box-shadow:0 2px 6px #6366f166}.output-header{display:flex;justify-content:space-between;font-size:12px;color:var(--text-2);padding-bottom:12px;border-bottom:1px solid var(--border);align-items:center;flex-wrap:wrap;gap:6px}.output-header-left{display:flex;align-items:center;gap:8px}.output-target{color:var(--text-0);font-weight:500}.output-meta{color:var(--text-3);font-size:11px}.tag{display:inline-flex;align-items:center;gap:3px;padding:3px 10px;border-radius:var(--r-pill);font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.5px}.tag-json{background:#10b9811a;color:#047857;border:1px solid rgba(16,185,129,.2)}.tag-meta{background:#f59e0b1a;color:#b45309;border:1px solid rgba(245,158,11,.2)}.tag-hybrid{background:#6366f11a;color:#4338ca;border:1px solid rgba(99,102,241,.2)}.output-block{display:flex;flex-direction:column;gap:6px;animation:slideUp .3s ease-out}@keyframes slideUp{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.output-block-header{display:flex;justify-content:space-between;align-items:center;font-size:11px;color:var(--text-2)}.output-block-title{display:flex;align-items:center;gap:6px;font-weight:600;color:var(--text-1)}.dot{display:inline-block;width:6px;height:6px;border-radius:50%}.dot-pos{background:var(--success)}.dot-neg{background:var(--danger)}.output-content{background:var(--surface-2);border:1px solid var(--border);border-radius:var(--r-md);padding:12px;font-family:SF Mono,Monaco,Consolas,Courier New,monospace;font-size:12px;line-height:1.65;color:var(--text-1);white-space:pre-wrap;word-wrap:break-word;max-height:220px;overflow-y:auto;transition:border-color .2s}.output-content:hover{border-color:var(--border-strong)}.json-raw{margin-top:8px;font-size:11px;color:var(--text-2)}.json-raw summary{display:inline-flex;align-items:center;gap:6px;cursor:pointer;padding:6px 12px;background:var(--surface-2);border:1px solid var(--border);border-radius:var(--r-pill);user-select:none;transition:all .2s}.json-raw summary:hover{background:var(--surface-3);color:var(--text-1)}.json-raw pre{margin-top:8px;max-height:220px}.output-empty{height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;color:var(--text-2);text-align:center;padding:24px;min-height:300px;gap:12px;position:relative;overflow:hidden}.output-empty-glow{position:absolute;top:50%;left:50%;width:400px;height:400px;transform:translate(-50%,-50%);pointer-events:none;filter:blur(40px);opacity:.5}.output-empty-icon{position:relative;z-index:1;animation:floatSlow 4s ease-in-out infinite;background:var(--surface-solid);width:96px;height:96px;border-radius:24px;display:flex;align-items:center;justify-content:center;box-shadow:var(--shadow-lg)}@keyframes floatSlow{0%,to{transform:translateY(0) rotate(0)}50%{transform:translateY(-6px) rotate(2deg)}}.output-empty-title{position:relative;z-index:1;font-size:18px;font-weight:600;color:var(--text-0);margin-top:4px}.output-empty-text{position:relative;z-index:1;font-size:13px;line-height:1.8}.output-empty-text p{margin:2px 0}.output-empty-features{position:relative;z-index:1;display:flex;flex-wrap:wrap;gap:10px;justify-content:center;margin:8px 0;max-width:480px}.feature-item{display:flex;align-items:center;gap:6px;padding:6px 12px;background:var(--surface-solid);border:1px solid var(--border);border-radius:var(--r-pill);font-size:11px;color:var(--text-1);font-weight:500;box-shadow:var(--shadow-sm)}.feature-item .material-symbols-outlined{color:var(--tab-color);font-size:16px}.output-empty-hint{position:relative;z-index:1;font-size:11px;color:var(--text-3);margin-top:4px}.modal-backdrop{position:fixed;inset:0;background:#0f172a66;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:100;padding:20px;animation:fadeIn .2s ease-out}.modal{background:var(--surface-solid);border:1px solid var(--border);border-radius:var(--r-xl);width:100%;max-width:800px;max-height:90vh;display:flex;flex-direction:column;box-shadow:var(--shadow-xl);animation:modalIn .3s cubic-bezier(.34,1.56,.64,1)}@keyframes modalIn{0%{opacity:0;transform:scale(.95) translateY(20px)}to{opacity:1;transform:scale(1) translateY(0)}}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:18px 24px;border-bottom:1px solid var(--border)}.modal-header h2{display:flex;align-items:center;gap:8px;font-size:17px;font-weight:600;color:var(--text-0)}.btn-icon-round{background:var(--surface-2);border:1px solid var(--border);color:var(--text-2);width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;font-family:inherit;transition:all .2s}.btn-icon-round:hover{background:var(--surface-3);color:var(--text-0);transform:rotate(90deg)}.modal-body{flex:1;overflow-y:auto;padding:20px 24px}.modal-footer{padding:14px 24px;border-top:1px solid var(--border);display:flex;justify-content:flex-end}.add-section h3,.provider-list h3{font-size:13px;color:var(--text-1);margin-bottom:10px;font-weight:600}.preset-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:8px;margin-bottom:20px}.preset-card{background:var(--surface-2);border:1px solid var(--border);color:var(--text-1);padding:10px 12px;border-radius:var(--r-md);cursor:pointer;font-size:12px;font-family:inherit;text-align:left;transition:all .2s}.preset-card:hover{background:var(--accent);border-color:var(--accent);color:#fff;transform:translateY(-2px);box-shadow:0 4px 12px #6366f14d}.preset-card-name{font-weight:500}.empty{display:flex;flex-direction:column;align-items:center;gap:8px;text-align:center;color:var(--text-2);padding:28px;font-size:13px}.provider-list{display:flex;flex-direction:column;gap:12px}.provider-card{background:var(--surface-2);border:1px solid var(--border);border-radius:var(--r-md);padding:14px;transition:all .2s}.provider-card:hover{border-color:var(--border-strong)}.provider-card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px;gap:8px}.input-name{flex:1;font-weight:500;background:transparent;border:1px solid transparent;padding:4px 8px;border-radius:var(--r-sm);font-size:14px;color:var(--text-0);font-family:inherit;outline:none}.input-name:hover,.input-name:focus{background:var(--surface-solid);border-color:var(--border)}.toggle{display:flex;align-items:center;gap:4px;font-size:12px;color:var(--text-2);cursor:pointer}.toggle input{width:16px;height:16px;accent-color:var(--accent)}.provider-card-body{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-bottom:10px}.field{display:flex;flex-direction:column;gap:4px}.field label{font-size:11px;color:var(--text-2);font-weight:500}.field input,.field select{font-size:12px;padding:6px 10px}.provider-card-actions{display:flex;gap:6px;justify-content:flex-end}.toast{position:fixed;bottom:24px;left:50%;transform:translate(-50%);background:var(--text-0);color:#fff;padding:10px 20px;border-radius:var(--r-pill);font-size:13px;display:flex;align-items:center;gap:6px;box-shadow:var(--shadow-xl);z-index:200;animation:toastIn .3s ease-out}@keyframes toastIn{0%{transform:translate(-50%,20px);opacity:0}to{transform:translate(-50%);opacity:1}}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--border-strong);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:var(--text-3)}@media (max-width: 1024px){.main{grid-template-columns:320px 1fr;padding:0 20px 20px}.header{padding:16px 20px}.tabs-nav{padding:14px 20px}.hero-title{font-size:22px}}@media (max-width: 768px){.header{padding:12px 16px}.hero-subtitle{display:none}.hero-logo-wrap{width:40px;height:40px}.hero-logo{width:28px;height:28px}.hero-title{font-size:20px}.tabs-nav{padding:12px 16px;flex-direction:column;align-items:stretch;gap:10px}.tabs-dashed{justify-content:space-between}.tab-nav{flex:1;justify-content:center;padding:8px 4px}.tab-nav-label{font-size:12px}.tab-hint-inline{text-align:center;font-size:11px}.main{grid-template-columns:1fr;grid-template-rows:auto 1fr;padding:12px 16px 16px;overflow-y:auto}.right-panel{min-height:400px}.provider-card-body{grid-template-columns:1fr}.preset-grid{grid-template-columns:1fr 1fr}.upload-zone{min-height:110px;padding:18px 12px}.upload-icon-circle{width:44px;height:44px}}.app,.header,.card,.upload-zone,.input,.select,.btn-pill,.btn-theme,.tab-nav,.tabs-dashed,.tab-hint-inline,.chip,.feature-item,.output,.tabs-nav,main{transition:background-color .3s ease,color .3s ease,border-color .3s ease,box-shadow .3s ease}.btn-theme{display:inline-flex;align-items:center;justify-content:center;width:36px;height:36px;background:var(--surface);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);color:var(--text-1);border:1px solid var(--border);border-radius:var(--r-pill);cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1);font-family:inherit}.btn-theme:hover{background:var(--accent-soft);border-color:var(--accent);color:var(--accent);transform:rotate(15deg) scale(1.05)}.btn-theme .material-symbols-outlined{font-size:18px}:root[data-theme=dark] ::selection{background:var(--accent-soft);color:var(--text-0)}:root[data-theme=dark] .top-progress{box-shadow:0 0 8px var(--accent)}.quality-score{background:var(--surface-solid);border:1px solid var(--border);border-radius:var(--r-md);padding:12px 14px;display:flex;flex-direction:column;gap:10px}.quality-score[data-grade=high]{border-color:#10b9814d;background:linear-gradient(135deg,var(--surface-solid) 0%,rgba(16,185,129,.05) 100%)}.quality-score[data-grade=mid]{border-color:#f59e0b4d;background:linear-gradient(135deg,var(--surface-solid) 0%,rgba(245,158,11,.05) 100%)}.quality-score[data-grade=low]{border-color:#ef44444d;background:linear-gradient(135deg,var(--surface-solid) 0%,rgba(239,68,68,.05) 100%)}.quality-score-head{display:flex;align-items:center;gap:14px}.quality-score-num{display:flex;align-items:baseline;gap:2px}.quality-score-value{font-size:32px;font-weight:800;color:var(--text-0);font-family:DM Sans,sans-serif;letter-spacing:-1px}[data-grade=high] .quality-score-value{color:var(--success)}[data-grade=mid] .quality-score-value{color:var(--warning)}[data-grade=low] .quality-score-value{color:var(--danger)}.quality-score-label{font-size:12px;color:var(--text-3);font-weight:500}.quality-score-meta{flex:1}.quality-score-title{font-size:14px;font-weight:600;color:var(--text-0)}.quality-score-sub{font-size:11px;color:var(--text-2);margin-top:2px}.quality-score-bars{display:flex;flex-direction:column;gap:6px}.quality-bar{display:grid;grid-template-columns:50px 1fr 24px;gap:10px;align-items:center}.quality-bar-label{font-size:11px;color:var(--text-2);text-align:right}.quality-bar-track{height:6px;background:var(--surface-2);border-radius:3px;overflow:hidden}.quality-bar-fill{height:100%;background:linear-gradient(90deg,var(--accent),var(--accent-hover));border-radius:3px;transition:width .4s ease}[data-grade=high] .quality-bar-fill{background:linear-gradient(90deg,var(--success),#34d399)}[data-grade=mid] .quality-bar-fill{background:linear-gradient(90deg,var(--warning),#fbbf24)}[data-grade=low] .quality-bar-fill{background:linear-gradient(90deg,var(--danger),#f87171)}.quality-bar-val{font-size:11px;font-weight:700;color:var(--text-1);text-align:right;font-variant-numeric:tabular-nums}.quality-score-suggestions{display:flex;gap:8px;padding-top:8px;border-top:1px solid var(--border);font-size:11px;color:var(--text-2)}.quality-score-suggestions .material-symbols-outlined{color:var(--warning);font-size:18px;flex-shrink:0}.quality-score-suggestions ul{margin:0;padding-left:18px;line-height:1.6}.quality-score-suggestions li{margin:2px 0}.skeleton{background:linear-gradient(90deg,var(--surface-2) 0%,var(--surface-3) 50%,var(--surface-2) 100%);background-size:200% 100%;animation:skeletonShimmer 1.5s ease-in-out infinite;border-radius:6px;height:14px}@keyframes skeletonShimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.skeleton-line{display:flex;flex-direction:column;gap:8px;padding:12px}.skeleton-line>div{height:12px}.skeleton-line>div:nth-child(1){width:90%}.skeleton-line>div:nth-child(2){width:70%}.skeleton-line>div:nth-child(3){width:85%}.skeleton-line>div:nth-child(4){width:60%}.skeleton-line>div:nth-child(5){width:75%}.analyzing-overlay{position:relative;overflow:hidden}.analyzing-overlay:before{content:"";position:absolute;inset:0;background:linear-gradient(90deg,transparent 0%,var(--accent-soft) 50%,transparent 100%);background-size:50% 100%;background-repeat:no-repeat;animation:scanLight 1.5s ease-in-out infinite;pointer-events:none;z-index:1}@keyframes scanLight{0%{background-position:-50% 0}to{background-position:150% 0}}.preview-media,.preview-audio{animation:subtlePulse 2s ease-in-out infinite}@keyframes subtlePulse{0%,to{opacity:1}50%{opacity:.85}}@keyframes ripple{to{transform:scale(2.5);opacity:0}}.ripple{position:absolute;border-radius:50%;background:var(--accent);transform:scale(0);animation:ripple .6s ease-out;pointer-events:none}.quality-score[data-grade=excellent]{border-color:#10b98166;background:linear-gradient(135deg,var(--surface-solid) 0%,rgba(16,185,129,.08) 100%)}.quality-score[data-grade=good]{border-color:#6366f166;background:linear-gradient(135deg,var(--surface-solid) 0%,rgba(99,102,241,.08) 100%)}.quality-score[data-grade=fair]{border-color:#f59e0b66;background:linear-gradient(135deg,var(--surface-solid) 0%,rgba(245,158,11,.08) 100%)}.quality-score[data-grade=poor]{border-color:#ef444466;background:linear-gradient(135deg,var(--surface-solid) 0%,rgba(239,68,68,.08) 100%)}.quality-bar-val{font-size:10px;font-weight:600;color:var(--text-1);text-align:right;font-variant-numeric:tabular-nums;letter-spacing:-.3px}.quality-checks{margin-top:6px;padding-top:8px;border-top:1px solid var(--border);font-size:12px}.quality-checks>summary{cursor:pointer;user-select:none;font-weight:600;color:var(--text-1);padding:4px 0;list-style:none;display:flex;align-items:center;gap:4px;font-size:12px}.quality-checks>summary::-webkit-details-marker{display:none}.quality-checks>summary:before{content:"▼";font-size:8px;color:var(--text-2);transition:transform .2s}.quality-checks:not([open])>summary:before{transform:rotate(-90deg)}.quality-checks-list{display:flex;flex-direction:column;gap:3px;padding-top:6px}.quality-check{display:grid;grid-template-columns:16px 1fr auto;align-items:center;gap:8px;padding:3px 6px;border-radius:4px;font-size:11px;transition:background .15s}.quality-check.pass{background:#10b9810f;color:var(--text-1)}.quality-check.fail{background:#ef44440f;color:var(--text-1)}.quality-check-mark{font-weight:700;font-size:11px;text-align:center}.quality-check.pass .quality-check-mark{color:var(--success)}.quality-check.fail .quality-check-mark{color:var(--danger)}.quality-check-label{color:var(--text-1)}.quality-check-points{font-size:10px;color:var(--text-2);font-weight:500;font-variant-numeric:tabular-nums}[data-grade=excellent] .quality-score-value{color:var(--success)}[data-grade=good] .quality-score-value{color:var(--accent)}[data-grade=fair] .quality-score-value{color:var(--warning)}[data-grade=poor] .quality-score-value{color:var(--danger)}[data-grade=excellent] .quality-bar-fill{background:linear-gradient(90deg,var(--success),#34d399)}[data-grade=good] .quality-bar-fill{background:linear-gradient(90deg,var(--accent),#818cf8)}[data-grade=fair] .quality-bar-fill{background:linear-gradient(90deg,var(--warning),#fbbf24)}[data-grade=poor] .quality-bar-fill{background:linear-gradient(90deg,var(--danger),#f87171)}.prompt-input-zone{display:flex;flex-direction:column;gap:10px;padding:8px 4px}.prompt-input-header{display:flex;align-items:center;gap:6px;font-size:13px;font-weight:600;color:var(--text-1)}.prompt-input-header .material-symbols-outlined{color:var(--accent);font-size:18px}.prompt-textarea{width:100%;min-height:100px;padding:12px 14px;font-family:inherit;font-size:14px;line-height:1.6;color:var(--text-0);background:var(--surface-2);border:1.5px solid var(--border);border-radius:var(--r-md);resize:vertical;transition:all .2s}.prompt-textarea:focus{outline:none;border-color:var(--accent);background:var(--surface-solid);box-shadow:0 0 0 3px var(--accent-soft)}.prompt-textarea::placeholder{color:var(--text-3);font-size:13px}.prompt-counter{font-size:11px;color:var(--text-3);text-align:right;font-variant-numeric:tabular-nums}.prompt-type-selector{display:grid;grid-template-columns:repeat(4,1fr);gap:6px;margin-bottom:10px;padding:4px;background:var(--surface-2);border-radius:var(--r-md);border:1px solid var(--border)}.prompt-type-btn{display:flex;align-items:center;justify-content:center;gap:4px;padding:6px 4px;background:transparent;border:none;border-radius:6px;color:var(--text-2);font-family:inherit;font-size:12px;font-weight:500;cursor:pointer;transition:all .2s}.prompt-type-btn:hover{background:var(--surface-3);color:var(--text-1)}.prompt-type-btn.active{background:var(--surface-solid);color:var(--accent);font-weight:600;box-shadow:var(--shadow-sm)}.prompt-type-btn .material-symbols-outlined{font-size:16px}.output-toolbar{display:flex;gap:8px;margin-bottom:8px}.btn-copy{display:inline-flex;align-items:center;gap:6px;padding:6px 14px;background:var(--surface-2);color:var(--text-1);border:1px solid var(--border);border-radius:var(--r-pill);font-family:inherit;font-size:12px;font-weight:500;cursor:pointer;transition:all .2s}.btn-copy:hover{background:var(--accent-soft);border-color:var(--accent);color:var(--accent)}.btn-copy .material-symbols-outlined{font-size:16px}.output-tip{display:flex;align-items:center;gap:6px;margin-top:10px;padding:8px 10px;background:var(--accent-soft);border-radius:var(--r-sm);font-size:11px;color:var(--accent)}.output-tip .material-symbols-outlined{font-size:16px}.prompt-categories{display:flex;flex-direction:column;gap:8px;margin-bottom:14px;padding:10px 12px;background:var(--surface-2);border-radius:var(--r-md);border:1px solid var(--border)}.prompt-section-label{display:flex;align-items:center;gap:6px;font-size:12px;font-weight:600;color:var(--text-1)}.prompt-section-label .material-symbols-outlined{color:var(--accent);font-size:16px}.prompt-section-hint{margin-left:auto;font-size:10px;font-weight:500;color:var(--text-2);padding:2px 8px;background:var(--surface-solid);border-radius:var(--r-pill);border:1px solid var(--border)}.prompt-category-chips{display:flex;flex-wrap:wrap;gap:6px}.category-chip{display:inline-flex;align-items:center;gap:4px;padding:5px 12px;background:var(--surface-solid);color:var(--text-2);border:1px solid var(--border);border-radius:var(--r-pill);font-family:inherit;font-size:12px;font-weight:500;cursor:pointer;transition:all .2s}.category-chip:hover{background:var(--accent-soft);border-color:var(--accent);color:var(--accent)}.category-chip.active{background:var(--accent);color:#fff;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}.category-chip .material-symbols-outlined{font-size:14px}.output-card.analysis-output,.output-card.prompt-output{display:flex;flex-direction:column;height:100%;min-height:500px}.output-header{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:10px 14px;border-bottom:1px solid var(--border);background:var(--surface-2);flex-shrink:0}.output-header-left{display:flex;align-items:center;gap:8px;flex:1;min-width:0}.output-actions{display:flex;align-items:center;gap:6px;flex-shrink:0}.output-target{font-size:12px;color:var(--text-2);font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.output-meta{font-size:10px;color:var(--text-3);font-weight:500;padding:2px 6px;background:var(--surface-3);border-radius:var(--r-pill);font-variant-numeric:tabular-nums}.output-action-btn{display:inline-flex;align-items:center;gap:4px;padding:4px 10px;background:var(--surface-solid);color:var(--text-1);border:1px solid var(--border);border-radius:var(--r-pill);font-family:inherit;font-size:11px;font-weight:500;cursor:pointer;transition:all .2s;white-space:nowrap}.output-action-btn:hover{background:var(--accent-soft);border-color:var(--accent);color:var(--accent)}.output-action-btn .material-symbols-outlined{font-size:14px}.output-action-btn-primary{background:var(--accent);color:#fff;border-color:var(--accent)}.output-action-btn-primary:hover{background:var(--accent-hover);color:#fff}.output-layout{display:grid;grid-template-columns:1fr 360px;gap:0;flex:1;min-height:0}@media (max-width: 900px){.output-layout{grid-template-columns:1fr}}.prompt-pane{display:flex;flex-direction:column;min-width:0;min-height:0;border-right:1px solid var(--border)}@media (max-width: 900px){.prompt-pane{border-right:none;border-bottom:1px solid var(--border)}}.prompt-pane-header{display:flex;align-items:center;justify-content:space-between;padding:6px 14px;background:var(--surface-2);border-bottom:1px solid var(--border);font-size:11px;font-weight:600;color:var(--text-2);flex-shrink:0}.prompt-pane-label{display:flex;align-items:center;gap:4px}.prompt-text{flex:1;margin:0;padding:16px 20px;font-family:JetBrains Mono,SF Mono,Monaco,Cascadia Code,Consolas,monospace;font-size:13px;line-height:1.7;color:var(--text-0);background:var(--surface-solid);white-space:pre-wrap;word-break:break-word;overflow-y:auto;max-height:calc(100vh - 320px);min-height:240px}@media (max-width: 900px){.prompt-text{max-height:50vh;min-height:200px}}.score-pane{display:flex;flex-direction:column;background:var(--surface-2);overflow-y:auto;min-height:0;max-height:calc(100vh - 200px)}@media (max-width: 900px){.score-pane{max-height:none}}.score-compact{background:var(--surface-solid);border-bottom:1px solid var(--border);padding:12px 14px}.score-compact-head{display:flex;align-items:center;gap:12px;margin-bottom:10px}.score-compact-value{font-size:28px;font-weight:800;line-height:1;letter-spacing:-1px;font-variant-numeric:tabular-nums}.score-compact[data-grade=excellent] .score-compact-value{color:var(--success)}.score-compact[data-grade=good] .score-compact-value{color:var(--accent)}.score-compact[data-grade=fair] .score-compact-value{color:var(--warning)}.score-compact[data-grade=poor] .score-compact-value{color:var(--danger)}.score-compact-meta{flex:1}.score-compact-grade{font-size:13px;font-weight:600;color:var(--text-0)}.score-compact-sub{font-size:10px;color:var(--text-2);margin-top:1px}.score-bars-mini{display:flex;flex-direction:column;gap:5px}.score-bar-mini{display:grid;grid-template-columns:50px 1fr 28px;gap:8px;align-items:center}.score-bar-mini-label{font-size:10px;color:var(--text-2);text-align:right;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.score-bar-mini-track{height:5px;background:var(--surface-2);border-radius:3px;overflow:hidden;border:1px solid var(--border)}.score-bar-mini-fill{height:100%;background:linear-gradient(90deg,var(--accent),var(--accent-hover));border-radius:3px;transition:width .4s ease}.score-compact[data-grade=excellent] .score-bar-mini-fill{background:linear-gradient(90deg,var(--success),#34d399)}.score-compact[data-grade=good] .score-bar-mini-fill{background:linear-gradient(90deg,var(--accent),#818cf8)}.score-compact[data-grade=fair] .score-bar-mini-fill{background:linear-gradient(90deg,var(--warning),#fbbf24)}.score-compact[data-grade=poor] .score-bar-mini-fill{background:linear-gradient(90deg,var(--danger),#f87171)}.score-bar-mini-val{font-size:10px;font-weight:700;color:var(--text-1);text-align:right;font-variant-numeric:tabular-nums}.score-details{border-top:1px solid var(--border);margin-top:8px;padding-top:6px}.score-details>summary{cursor:pointer;user-select:none;font-size:11px;font-weight:600;color:var(--text-1);padding:4px 0;list-style:none;display:flex;align-items:center;gap:4px}.score-details>summary::-webkit-details-marker{display:none}.score-details>summary:before{content:"▼";font-size:8px;color:var(--text-2);transition:transform .2s}.score-details:not([open])>summary:before{transform:rotate(-90deg)}.score-checks-mini{display:flex;flex-direction:column;gap:2px;padding-top:4px;max-height:160px;overflow-y:auto}.score-check-mini{display:grid;grid-template-columns:14px 1fr 30px;gap:4px;align-items:center;font-size:10px;padding:2px 4px;border-radius:3px}.score-check-mini.pass{color:var(--text-1)}.score-check-mini.fail{color:var(--text-1);background:#ef44440a}.score-check-mini-mark{font-weight:700;text-align:center}.score-check-mini.pass .score-check-mini-mark{color:var(--success)}.score-check-mini.fail .score-check-mini-mark{color:var(--danger)}.score-check-mini-label{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.score-check-mini-points{font-weight:500;text-align:right;color:var(--text-2)}.score-suggestions-mini{list-style:none;margin:0;padding:4px 0 0;font-size:10px;color:var(--text-2);line-height:1.5}.score-suggestions-mini li{padding:2px 0 2px 12px;position:relative}.score-suggestions-mini li:before{content:"•";position:absolute;left:0;color:var(--warning)}.json-raw{border-top:1px solid var(--border);padding:8px 14px;background:var(--surface-2)}.json-raw>summary{cursor:pointer;user-select:none;font-size:11px;font-weight:600;color:var(--text-1);list-style:none;display:flex;align-items:center;gap:4px}.json-raw>summary::-webkit-details-marker{display:none}.json-raw>summary:before{content:"▼";font-size:8px;color:var(--text-2);transition:transform .2s}.json-raw:not([open])>summary:before{transform:rotate(-90deg)}.json-raw pre{margin:6px 0 0;padding:8px 10px;background:var(--bg);border:1px solid var(--border);border-radius:6px;font-family:JetBrains Mono,monospace;font-size:10px;line-height:1.5;color:var(--text-1);max-height:200px;overflow-y:auto;white-space:pre-wrap;word-break:break-word}.output-tip-mini{display:flex;align-items:center;gap:6px;padding:8px 14px;background:var(--accent-soft);font-size:11px;color:var(--accent);border-top:1px solid var(--border);flex-shrink:0}.output-tip-mini .material-symbols-outlined{font-size:14px}
