@import "https://fonts.googleapis.com/css2?family=Noto+Sans+SC:wght@300;400;500;600;700&display=swap";*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--brand:#8b5cf6;--brand-light:#7c3aed;--brand-muted:#8b5cf614;--navy:#1a2744;--sidebar-w:200px;--header-h:56px;--text:#1f2937;--text-2:#6b7280;--text-3:#9ca3af;--border:#e5e7eb;--border-2:#f3f4f6;--bg:#f4f4ee;--white:#fff;--success:#10b981;--success-bg:#ecfdf5;--warning:#f59e0b;--link:#2563eb;--radius:6px;--shadow:0 1px 3px #00000014, 0 1px 2px #0000000d;--shadow-md:0 4px 12px #0000001a}html,body,#root{height:100%}body{color:var(--ink);font-family:Noto Sans SC,sans-serif;font-size:14px;background:var(--bg)!important}button{cursor:pointer;border:none;outline:none;font-family:inherit;font-size:14px}input,textarea,select{outline:none;font-family:inherit;font-size:14px}a{color:var(--highlight);text-decoration:none}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:#d1d5db;border-radius:3px}.layout{height:100vh;display:flex;overflow:hidden}.sidebar{width:var(--sidebar-w);background:#fff;border-right:1px solid #ebebef;flex-direction:column;flex-shrink:0;display:flex;box-shadow:2px 0 8px #0000000f}.sidebar-logo{padding:16px 18px}.sidebar-nav{flex:1;padding:10px 0;overflow-y:auto}.nav-icon{justify-content:center;align-items:center;width:18px;height:18px;display:flex}.badge{background:var(--ink);color:var(--bg);text-align:center;border-radius:10px;min-width:18px;margin-left:auto;padding:1px 6px;font-size:11px}.main{background:var(--bg);width:100%;max-width:1320px;margin:0 auto;padding:32px 40px 64px}.topbar{height:var(--header-h);background:0 0;flex-shrink:0;justify-content:space-between;align-items:center;padding:0 32px;display:flex}.topbar-title{color:#1c1c1e;font-size:15px;font-weight:600}.topbar-breadcrumb{color:var(--ink-soft);align-items:center;gap:6px;font-size:13px;display:flex}.topbar-breadcrumb span{color:var(--ink-mute)}.topbar-actions{align-items:center;gap:16px;display:flex}.icon-btn{cursor:pointer;width:32px;height:32px;color:var(--ink-soft);background:0 0;border:none;border-radius:50%;justify-content:center;align-items:center;transition:background .15s;display:flex}.icon-btn:hover{background:var(--surface-alt)}.avatar{color:#fff;cursor:pointer;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:50%;justify-content:center;align-items:center;width:32px;height:32px;font-size:12px;display:flex}.content{flex:1;padding:20px;overflow-y:auto}.card{background:var(--surface);border-radius:var(--radius);border:1px solid var(--line);box-shadow:var(--shadow)}.panel{background:var(--surface);border:1px solid var(--line);border-radius:12px;margin-bottom:16px;padding:28px 32px}.section-title{color:var(--ink-soft);align-items:center;gap:8px;margin-bottom:16px;font-size:13px;font-weight:600;display:flex}.section-title:before{content:"";background:var(--ink);border-radius:2px;width:3px;height:14px}.form-row{align-items:flex-start;gap:16px;margin-bottom:14px;display:flex}.form-group{flex-direction:column;flex:1;gap:6px;display:flex}.form-label{color:var(--ink-soft);font-size:13px;font-weight:500}.form-label.required:after{content:" *";color:var(--highlight)}.form-input{height:34px;color:var(--ink);background:var(--surface);border:1px solid #e5e5ea;border-radius:8px;width:100%;padding:0 10px;transition:border-color .15s}.form-input:focus{border-color:var(--highlight);box-shadow:0 0 0 2px var(--highlight-soft)}.form-input::placeholder{color:var(--ink-mute)}.form-textarea{color:var(--ink);background:var(--surface);resize:vertical;border:1px solid #e5e5ea;border-radius:8px;width:100%;min-height:70px;padding:8px 10px;transition:border-color .15s}.form-textarea:focus{border-color:var(--highlight);box-shadow:0 0 0 2px var(--highlight-soft)}.form-select{border:1px solid var(--line);border-radius:var(--radius);height:34px;color:var(--ink);background:var(--surface);appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%236b7280' stroke-width='2'%3E%3Cpolyline points='6 9 12 15 18 9'%3E%3C/polyline%3E%3C/svg%3E");background-position:right 10px center;background-repeat:no-repeat;width:100%;padding:0 10px}.btn{border-radius:var(--radius);white-space:nowrap;justify-content:center;align-items:center;gap:6px;height:34px;padding:0 16px;font-size:13px;font-weight:500;transition:all .15s;display:inline-flex}.btn-primary{background:var(--accent);color:var(--accent-ink);border:1px solid var(--line-strong)}.btn-primary:hover{background:var(--accent);filter:brightness(.95)}.btn-primary:disabled{background:var(--surface-alt);color:var(--ink-mute);cursor:not-allowed;border-color:var(--line)}.btn-action{background:var(--ink);color:var(--bg);border:none}.btn-action:hover{background:var(--ink-soft)}.btn-danger{background:var(--ink);color:var(--bg);border:none}.btn-danger:hover{background:var(--ink-soft)}.btn-outline{border:1px solid var(--line);color:var(--ink-soft);background:0 0}.btn-outline:hover{border-color:var(--line-strong);color:var(--ink)}.btn-ghost{color:var(--highlight);background:0 0}.btn-ghost:hover{background:#2563eb0f}.btn-sm{height:28px;padding:0 10px;font-size:12px}.btn-success{background:var(--success);color:#fff}.btn-success:hover{background:#059669}.steps{background:var(--surface);border:1px solid var(--line);border-radius:12px;align-items:center;margin-bottom:16px;padding:20px 32px;display:flex}.step{flex-direction:column;flex:1;align-items:center;gap:6px;display:flex;position:relative}.step:not(:last-child):after{content:"";z-index:0;background:#e5e5ea;width:80%;height:2px;position:absolute;top:14px;left:60%}.step.done:not(:last-child):after,.step.active:not(:last-child):after{background:var(--accent)}.step-circle{border:2px solid var(--line-strong);background:var(--surface);width:28px;height:28px;color:var(--ink-soft);z-index:1;border-radius:50%;justify-content:center;align-items:center;font-size:12px;font-weight:600;display:flex;position:relative}.step.active .step-circle{border-color:var(--ink);background:var(--accent);color:var(--accent-ink)}.step.done .step-circle{border-color:var(--ink);background:var(--ink);color:var(--bg)}.step-label{color:#8e8e93;font-size:12px;font-weight:500}.step.active .step-label{color:var(--ink);font-weight:600}.step.done .step-label{color:var(--ink-mute)}.table-wrap{overflow-x:auto}table{border-collapse:collapse;width:100%}thead{background:var(--surface-alt)}th{text-align:left;color:var(--ink-soft);border-bottom:1px solid var(--line);white-space:nowrap;padding:10px 14px;font-size:13px;font-weight:600}td{color:var(--ink);border-bottom:1px solid var(--surface-alt);padding:12px 14px;font-size:13px}tr:last-child td{border-bottom:none}tr:hover td{background:#fafafa}.status{border-radius:20px;align-items:center;gap:4px;padding:2px 10px;font-size:12px;font-weight:500;display:inline-flex}.status-published{background:var(--success-soft);color:var(--success)}.status-draft{background:var(--surface-alt);color:var(--ink-soft)}.status-pass{background:var(--success-soft);color:var(--success)}.status-fail{color:#ef4444;background:#fef2f2}.status-dot:before{content:"";background:currentColor;border-radius:50%;width:6px;height:6px}.search-bar{border-bottom:1px solid var(--line);flex-wrap:wrap;align-items:center;gap:12px;padding:16px 20px;display:flex}.search-input-wrap{align-items:center;display:flex;position:relative}.search-input-wrap input{border:1px solid var(--line);border-radius:var(--radius);width:200px;height:32px;color:var(--ink);background:var(--surface);padding:0 32px 0 10px;font-size:13px}.search-input-wrap input:focus{border-color:var(--highlight)}.search-icon{color:var(--ink-mute);pointer-events:none;position:absolute;right:8px}.search-label{color:var(--ink-soft);white-space:nowrap;font-size:13px}.search-actions{margin-left:auto}.pagination{justify-content:flex-end;align-items:center;gap:4px;padding:16px 20px;display:flex}.page-btn{border-radius:var(--radius);cursor:pointer;color:#1c1c1e;background:#fff;border:.5px solid #e5e5ea;justify-content:center;align-items:center;width:32px;height:32px;font-size:13px;transition:all .15s;display:flex}.page-btn:hover{border-color:var(--line-strong);color:var(--ink)}.page-btn.active{background:var(--ink);color:var(--bg);border:none}.upload-area{border:1.5px dashed var(--line);border-radius:var(--radius);background:var(--surface-alt);cursor:pointer;color:var(--highlight);align-items:center;gap:6px;padding:10px 16px;font-size:13px;transition:all .15s;display:inline-flex}.upload-area:hover{border-color:var(--highlight);background:var(--highlight-soft)}.file-table{border:1px solid var(--line);border-radius:var(--radius);margin-top:8px;overflow:hidden}.progress-bar{background:#e5e5ea;border-radius:2px;width:120px;height:4px;overflow:hidden}.progress-fill{background:var(--ink);border-radius:2px;height:100%}.role-chip{background:var(--surface-alt);color:var(--ink-soft);border-radius:12px;align-items:center;gap:4px;padding:2px 8px;font-size:12px;font-weight:500;display:inline-flex}.audio-chip{color:#2563eb;background:#eff6ff;border-radius:12px;align-items:center;gap:4px;padding:2px 8px;font-size:12px;display:inline-flex}.loop-card{border:1px solid var(--line);border-radius:var(--radius);margin-bottom:12px;overflow:hidden}.loop-header{background:var(--surface-alt);border-bottom:1px solid var(--line);align-items:center;gap:10px;padding:10px 14px;display:flex}.loop-num{background:var(--ink);width:22px;height:22px;color:var(--bg);border-radius:50%;justify-content:center;align-items:center;font-size:11px;font-weight:700;display:flex}.loop-title{color:var(--ink);flex:1;font-size:13px;font-weight:600}.loop-tag{color:#1d4ed8;background:#dbeafe;border-radius:10px;padding:2px 8px;font-size:11px}.loop-body{padding:10px 14px}.score-big{color:var(--ink);font-size:28px;font-weight:700}.notif-dot{position:relative}.notif-dot:after{content:"";background:var(--accent);border:1.5px solid var(--surface);border-radius:50%;width:7px;height:7px;position:absolute;top:2px;right:2px}.tabs{border-bottom:1px solid var(--line);display:flex}.tab{cursor:pointer;color:var(--ink-soft);border-bottom:2px solid #0000;padding:10px 20px;font-size:13px;transition:all .15s}.tab.active{color:var(--ink);border-bottom-color:var(--ink);font-weight:600}.tab:hover:not(.active){color:var(--ink)}.modal-overlay{z-index:100;background:#0006;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.modal{background:var(--surface);box-shadow:var(--shadow-md);border-radius:8px;width:100%;min-width:420px;max-width:560px;padding:24px}.modal-title{color:var(--ink);margin-bottom:16px;font-size:16px;font-weight:600}.modal-footer{justify-content:flex-end;gap:10px;margin-top:20px;display:flex}.toast{background:var(--ink);color:#fff;border-radius:var(--radius);z-index:200;box-shadow:var(--shadow-md);padding:10px 18px;font-size:13px;animation:.2s slideIn;position:fixed;top:20px;right:20px}.toast.success{background:var(--success)}.toast.error{background:#ef4444}@keyframes slideIn{0%{opacity:0;transform:translate(20px)}to{opacity:1;transform:translate(0)}}.checkbox{border:1.5px solid var(--line);cursor:pointer;appearance:none;background:#fff;border-radius:3px;flex-shrink:0;width:15px;height:15px;transition:all .15s}.checkbox:checked{background:var(--ink);border-color:var(--ink);background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='10' viewBox='0 0 24 24' fill='none' stroke='white' stroke-width='3'%3E%3Cpolyline points='20 6 9 17 4 12'%3E%3C/polyline%3E%3C/svg%3E");background-position:50%;background-repeat:no-repeat}.flex{display:flex}.items-center{align-items:center}.gap-8{gap:8px}.ml-auto{margin-left:auto}.text-link{color:var(--highlight);cursor:pointer}.text-link:hover{text-decoration:underline}.text-danger{color:var(--highlight);cursor:pointer}.text-danger:hover{text-decoration:underline}.text-muted{color:var(--ink-soft)}.text-xs{font-size:12px}.font-bold{font-weight:700}.mt-8{margin-top:8px}.mt-4{margin-top:4px}.mb-12{margin-bottom:12px}.hint{color:var(--ink-mute);margin-top:4px;font-size:12px}.hint.error{color:#ef4444}.hint.warning{color:var(--warning)}.divider{border:none;border-top:1px solid var(--line);margin:16px 0}.bottom-bar{background:var(--surface);border-top:1px solid var(--line);justify-content:center;gap:12px;padding:14px 24px;display:flex}.result-meta{border-bottom:1px solid var(--line);flex-wrap:wrap;align-items:center;gap:24px;padding:16px 20px;display:flex}.meta-item{flex-direction:column;gap:2px;display:flex}.meta-label{color:var(--ink-soft);font-size:12px}.meta-value{color:var(--ink);font-size:14px;font-weight:600}.conv-bubble{gap:10px;margin-bottom:14px;display:flex}.conv-bubble.user{flex-direction:row-reverse}.bubble-avatar{border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:32px;height:32px;font-size:12px;font-weight:600;display:flex}.bubble-ai{background:var(--surface-alt,#e8ead8);color:var(--ink,#0f0f10);border:1px solid var(--line,#e8e6dd)}.bubble-user{background:var(--accent);color:var(--accent-ink);border:1px solid var(--ink)}.bubble-content{max-width:70%}.bubble-name{color:var(--ink-mute);margin-bottom:4px;font-size:11px}.bubble-text{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius-lg);padding:10px 14px;font-size:13px;line-height:1.6}.conv-bubble.user .bubble-text{background:var(--accent-soft);color:var(--ink);border:1px solid var(--accent-muted)}.conv-bubble.user .bubble-name{text-align:right}.score-row{align-items:center;gap:10px;margin-bottom:10px;display:flex}.score-row-label{width:120px;color:var(--ink-soft);flex-shrink:0;font-size:13px}.score-bar-wrap{background:var(--line);border-radius:4px;flex:1;height:8px;overflow:hidden}.score-bar{background:var(--ink);border-radius:4px;height:100%}.score-row-val{text-align:right;width:36px;color:var(--ink);font-size:13px;font-weight:600}:root{--bg:#f4f4ee;--surface:#fff;--surface-alt:#e8ead8;--sidebar:#fff;--sidebar-text:#0f0f10;--sidebar-muted:#6f6f6f;--ink:#0f0f10;--ink-soft:#3a3a3d;--ink-mute:#7a7a7d;--line:#e8e6dd;--line-strong:#c8c5b6;--brand:#0f0f10;--accent:#d8ff3d;--accent-soft:#f0ffb8;--accent-ink:#0f0f10;--accent-muted:#9dba2e;--highlight:#c9b8ff;--highlight-soft:#ede6ff;--highlight-ink:#3a2d6b;--success:#5c8612;--success-soft:#5c86121f;--warning:#c99a4a;--warning-soft:#c99a4a1f;--info:#5c8612;--error:#b91c1c;--error-soft:#fee2e2;--error-ink:#b91c1c;--radius:6px;--radius-lg:12px;--radius-xl:20px;--card-shadow:0 1px 0 #0f0f1008, 0 4px 16px #0f0f100a;--card-border:1px solid #e0e0d8;--font-display:"Inter", system-ui, sans-serif;--font-body:"Inter", "Noto Sans SC", "PingFang SC", system-ui, sans-serif;--font-mono:"JetBrains Mono", ui-monospace, monospace;--font-zh:"Noto Sans SC", "PingFang SC", sans-serif;--display-weight:500;--display-letter:-.035em}*{box-sizing:border-box;margin:0;padding:0}body{color:var(--ink);font-family:var(--font-body);background:var(--bg)!important}::-webkit-scrollbar{display:none}*{scrollbar-width:none;-ms-overflow-style:none}
