:root{--color-primary:#6366f1;--color-primary-dark:#4f46e5;--color-primary-light:#818cf8;--color-accent:#8b5cf6;--gradient-primary:linear-gradient(135deg,#6366f1,#8b5cf6);--gradient-primary-hover:linear-gradient(135deg,#4f46e5,#7c3aed);--color-success:#00920a;--color-success-bg:#ecfdf5;--color-success-text:#00920a;--color-warning:#ff6f00;--color-warning-bg:#fffbeb;--color-warning-text:#ff6f00;--color-error:#ff2626;--color-error-bg:#fef2f2;--color-error-text:#ff2626;--color-muted:#a3a3a3;--color-muted-bg:#f1f5f9;--color-muted-text:#a3a3a3;--bg-body-from:#f8fafc;--bg-body-to:#eef2ff;--bg-surface:#fff;--bg-surface-hover:#f8fafc;--bg-overlay:#ffffffb3;--text-primary:#1e293b;--text-secondary:#64748b;--text-tertiary:#94a3b8;--border-light:#e2e8f0;--border-focus:#6366f1;--radius-sm:8px;--radius-md:12px;--radius-lg:16px;--radius-xl:20px;--radius-full:9999px;--shadow-sm:0 1px 2px #0000000d;--shadow-md:0 4px 6px -1px #00000012,0 2px 4px -2px #0000000d;--shadow-lg:0 10px 15px -3px #00000014,0 4px 6px -4px #0000000a;--shadow-xl:0 20px 25px -5px #00000014,0 8px 10px -6px #0000000a;--shadow-primary:0 4px 14px #6366f140;--transition-fast:150ms ease;--transition-base:200ms ease;--transition-slow:300ms ease}*{box-sizing:border-box;margin:0;padding:0}button{appearance:none;-webkit-appearance:none;cursor:pointer;font-family:inherit}body{background:linear-gradient(180deg,#f8fafc,#eef2ff);background:linear-gradient(180deg,var(--bg-body-from),var(--bg-body-to));background-attachment:fixed;color:#1e293b;color:var(--text-primary);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Noto Sans KR,sans-serif}.app,body{min-height:100vh}.app{margin:0 auto;max-width:1120px;padding:48px 24px}h1{color:#1e293b;color:var(--text-primary);font-size:32px;font-weight:800;letter-spacing:-.5px;margin-bottom:8px}.text-gradient{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#6366f1,#8b5cf6);background:var(--gradient-primary);-webkit-background-clip:text;background-clip:text}.subtitle{color:#64748b;color:var(--text-secondary);font-size:16px;line-height:1.7;margin-bottom:36px}.app-mode-tabs{background:#f1f5f9;background:var(--color-muted-bg);border-bottom:none;display:inline-flex;margin-bottom:32px;padding:4px}.app-mode-tab,.app-mode-tabs{border-radius:9999px;border-radius:var(--radius-full)}.app-mode-tab{background:#0000;border:none;color:#64748b;color:var(--text-secondary);cursor:pointer;flex:initial;font-size:14px;font-weight:600;margin-bottom:0;padding:10px 24px;transition:all .2s ease;transition:all var(--transition-base)}.app-mode-tab:hover{color:#1e293b;color:var(--text-primary)}.app-mode-tab.active{background:#fff;background:var(--bg-surface);border-bottom-color:#0000;box-shadow:0 1px 2px #0000000d;box-shadow:var(--shadow-sm);color:#6366f1;color:var(--color-primary)}.result-layout{height:760px;margin:0 auto;width:1072px}.result-main{flex:1 1;gap:24px;min-width:0}.input-section,.result-main{display:flex;flex-direction:column}.input-section{gap:20px;max-width:720px}.input-mode-tabs{background:#f1f5f9;background:var(--color-muted-bg);border-bottom:none;display:inline-flex;margin-bottom:20px;padding:4px}.input-mode-tab,.input-mode-tabs{border-radius:9999px;border-radius:var(--radius-full)}.input-mode-tab{background:#0000;border:none;color:#64748b;color:var(--text-secondary);cursor:pointer;flex:initial;font-size:14px;font-weight:500;margin-bottom:0;padding:8px 20px;transition:all .2s ease;transition:all var(--transition-base)}.input-mode-tab:hover:not(:disabled){color:#1e293b;color:var(--text-primary)}.input-mode-tab.active{background:#fff;background:var(--bg-surface);border-bottom-color:#0000;box-shadow:0 1px 2px #0000000d;box-shadow:var(--shadow-sm);color:#6366f1;color:var(--color-primary)}.input-mode-tab:disabled{cursor:not-allowed;opacity:.5}.textarea-wrapper{position:relative}textarea{background:#fff;background:var(--bg-surface);border:2px solid #e2e8f0;border:2px solid var(--border-light);border-radius:16px;border-radius:var(--radius-lg);color:#1e293b;color:var(--text-primary);font-family:inherit;font-size:16px;line-height:1.7;min-height:160px;padding:20px;resize:vertical;transition:border-color .2s ease,box-shadow .2s ease;transition:border-color var(--transition-base),box-shadow var(--transition-base);width:100%}textarea:focus{border-color:#6366f1;border-color:var(--border-focus);box-shadow:0 0 0 3px #6366f11a;outline:none}textarea:disabled{background:#f1f5f9;background:var(--color-muted-bg)}.char-count{bottom:14px;color:#94a3b8;color:var(--text-tertiary);font-size:13px;position:absolute;right:18px}.btn-group{align-items:center;display:flex;gap:12px}.btn-evaluate{align-items:center;background:linear-gradient(135deg,#6366f1,#8b5cf6);background:var(--gradient-primary);border:none;border-radius:12px;border-radius:var(--radius-md);box-shadow:0 4px 14px #6366f140;box-shadow:var(--shadow-primary);color:#fff;cursor:pointer;display:inline-flex;font-size:16px;font-weight:600;justify-content:center;padding:14px 36px;transition:transform .15s ease,box-shadow .2s ease;transition:transform var(--transition-fast),box-shadow var(--transition-base)}.btn-evaluate:hover:not(:disabled){box-shadow:0 6px 20px #6366f159;transform:translateY(-1px)}.btn-evaluate:active:not(:disabled){transform:translateY(0)}.btn-evaluate:disabled{background:#f1f5f9;background:var(--color-muted-bg);box-shadow:none;color:#94a3b8;color:var(--text-tertiary);cursor:not-allowed}.btn-evaluate:disabled,.btn-rerecord{border:1px solid #e2e8f0;border:1px solid var(--border-light)}.btn-rerecord{background:#fff;background:var(--bg-surface);border-radius:12px;border-radius:var(--radius-md);color:#64748b;color:var(--text-secondary);cursor:pointer;font-size:15px;font-weight:500;padding:12px 22px;transition:all .2s ease;transition:all var(--transition-base)}.btn-rerecord:hover{background:#f1f5f9;background:var(--color-muted-bg);border-color:#a3a3a3;border-color:var(--color-muted)}.btn-rerecord:disabled{cursor:not-allowed;opacity:.5}.voice-input-area{background:linear-gradient(135deg,#faf5ff,#eef2ff);border:2px dashed #e2e8f0;border:2px dashed var(--border-light);border-radius:20px;border-radius:var(--radius-xl);justify-content:center;margin-bottom:16px;min-height:220px;padding:32px}.voice-idle,.voice-input-area{align-items:center;display:flex;flex-direction:column}.voice-idle{gap:16px}.btn-record{align-items:center;background:linear-gradient(135deg,#6366f1,#8b5cf6);background:var(--gradient-primary);border:none;border-radius:50%;box-shadow:0 4px 14px #6366f140;box-shadow:var(--shadow-primary);color:#fff;cursor:pointer;display:flex;height:88px;justify-content:center;position:relative;transition:transform .2s ease,box-shadow .2s ease;transition:transform var(--transition-base),box-shadow var(--transition-base);width:88px}.btn-record:hover{box-shadow:0 6px 20px #6366f159;transform:scale(1.08)}.btn-record:active{transform:scale(.96)}@keyframes pulse-ring{0%{opacity:.5;transform:scale(1)}to{opacity:0;transform:scale(1.8)}}.btn-record:before{animation:pulse-ring 2s ease-out infinite;background:linear-gradient(135deg,#6366f1,#8b5cf6);background:var(--gradient-primary);border-radius:50%;content:"";inset:0;pointer-events:none;position:absolute}.btn-record-icon{font-size:36px;position:relative;z-index:1}.voice-hint{color:#94a3b8;color:var(--text-tertiary);font-size:14px}.voice-recording{align-items:center;display:flex;flex-direction:column;gap:16px;width:100%}.recording-indicator{align-items:center;color:#1e293b;color:var(--text-primary);display:flex;font-size:15px;font-weight:500;gap:8px}.recording-dot{animation:blink 1s infinite;background:#ff2626;background:var(--color-error);border-radius:50%;height:12px;width:12px}@keyframes blink{0%,to{opacity:1}50%{opacity:.3}}.recording-timer{font-feature-settings:"tnum";color:#64748b;color:var(--text-secondary);font-size:14px;font-variant-numeric:tabular-nums}.recording-progress{background:#e2e8f0;background:var(--border-light);height:6px;max-width:300px;overflow:hidden;width:100%}.recording-progress,.recording-progress-fill{border-radius:9999px;border-radius:var(--radius-full)}.recording-progress-fill{background:#ff2626;background:var(--color-error);height:100%;transition:width 1s linear}.btn-stop{background:#fff;background:var(--bg-surface);border:1px solid #ff2626;border:1px solid var(--color-error);border-radius:12px;border-radius:var(--radius-md);color:#ff2626;color:var(--color-error);cursor:pointer;font-size:14px;font-weight:500;padding:10px 24px;transition:background .2s ease;transition:background var(--transition-base)}.btn-stop:hover{background:#fef2f2;background:var(--color-error-bg)}.voice-transcribing{color:#64748b;color:var(--text-secondary);font-size:15px;gap:12px}.loading,.voice-transcribing{align-items:center;display:flex;flex-direction:column}.loading{gap:16px;padding:32px}.spinner{animation:spin .8s linear infinite;border:3px solid #e2e8f0;border-top-color:#6366f1;border:3px solid var(--border-light);border-radius:50%;border-top-color:var(--color-primary);height:40px;width:40px}@keyframes spin{to{transform:rotate(1turn)}}.loading p{color:#64748b;color:var(--text-secondary);font-size:15px}.error{background:#fef2f2;background:var(--color-error-bg);border:1px solid #ef444433;border-radius:12px;border-radius:var(--radius-md);padding:16px 20px;text-align:center}.error p{font-size:15px;margin-bottom:12px}.btn-retry,.error p{color:#ff2626;color:var(--color-error)}.btn-retry{background:#fff;background:var(--bg-surface);border:1px solid #ff2626;border:1px solid var(--color-error);border-radius:8px;border-radius:var(--radius-sm);cursor:pointer;font-size:14px;padding:8px 20px;transition:background .2s ease;transition:background var(--transition-base)}.btn-retry:hover{background:#fef2f2;background:var(--color-error-bg)}.result-section{display:flex;flex-direction:column;gap:24px}.legend{background:#fff;background:var(--bg-surface);border:1px solid #e2e8f0;border:1px solid var(--border-light);border-radius:12px;border-radius:var(--radius-md);box-shadow:0 1px 2px #0000000d;box-shadow:var(--shadow-sm);display:flex;flex-wrap:wrap;gap:20px;padding:14px 20px}.legend-item{align-items:center;color:#64748b;color:var(--text-secondary);display:flex;font-size:13px;font-weight:500;gap:8px}.legend-color{border-radius:50%;display:inline-block;height:12px;width:12px}.highlight-result{background:#fff7ed;border-radius:16px;font-size:18px;font-weight:700;line-height:1.5;margin-bottom:36px;padding:20px;word-break:keep-all}.highlight-correct,.highlight-correct+span{color:#00920a}.legend-color.highlight-correct{background-color:#00920a}.highlight-partial{color:#ff6f00}.legend-color.highlight-partial{background-color:#ff6f00}.highlight-partial+span{color:#ff6f00}.highlight-incorrect{color:#ff2626}.legend-color.highlight-incorrect{background-color:#ff2626}.highlight-incorrect+span{color:#ff2626}.highlight-unsupported{color:#a3a3a3}.legend-color.highlight-unsupported{background-color:#a3a3a3}.highlight-unsupported+span{color:#a3a3a3}.feedback-section{display:flex;flex-direction:column;gap:18px}.feedback-title{border-bottom:2px solid #222;color:#1e293b;color:var(--text-primary);font-size:18px;font-weight:700;padding-bottom:10px}.feedback-card{border-bottom:1px solid #e2e8f0;border-bottom:1px solid var(--border-light);padding:0 0 18px}.feedback-card-incorrect{border-left-color:#ff2626;border-left-color:var(--color-error)}.feedback-card-partial{border-left-color:#ff6f00;border-left-color:var(--color-warning)}.feedback-label{border-radius:9999px;border-radius:var(--radius-full);display:inline-block;font-size:12px;font-weight:600;margin-bottom:10px;padding:3px 10px}.feedback-user-text{font-size:16px;font-weight:700;margin-bottom:8px}.feedback-note{color:#64748b;color:var(--text-secondary);font-size:14px;line-height:1.6;margin-bottom:10px}.feedback-correction{background:#eef2ff;border-radius:8px;border-radius:var(--radius-sm);padding:14px}.feedback-correction-label{color:#6366f1;color:var(--color-primary);font-size:12px;font-weight:600;letter-spacing:.5px;text-transform:uppercase}.feedback-correction p{color:#1e293b;color:var(--text-primary);font-size:14px;line-height:1.6;margin-top:6px}.analysis-panel{background:#fff;background:var(--bg-surface);border:1px solid #e2e8f0;border:1px solid var(--border-light);border-radius:16px;border-radius:var(--radius-lg);box-shadow:0 4px 6px -1px #00000012,0 2px 4px -2px #0000000d;box-shadow:var(--shadow-md);display:flex;flex-direction:column;gap:12px;margin:0 auto 16px;max-width:380px;padding:16px 20px}.analysis-panel-title{border-bottom:1px solid #e2e8f0;border-bottom:1px solid var(--border-light);color:#1e293b;color:var(--text-primary);font-size:14px;font-weight:700;padding-bottom:10px}.analysis-score{align-items:center;display:flex;flex-direction:column;gap:6px}.analysis-score-circle{align-items:center;background:conic-gradient(#00920a 0,#e2e8f0 0);background:conic-gradient(var(--color-success) calc(var(--accuracy, 0)*1%),var(--border-light) 0);border-radius:50%;display:flex;height:80px;justify-content:center;position:relative;width:80px}.analysis-score-circle:before{background:#fff;background:var(--bg-surface);border-radius:50%;content:"";height:58px;position:absolute;width:58px}.analysis-score-value{font-size:22px;font-weight:800}.analysis-score-unit,.analysis-score-value{color:#00920a;color:var(--color-success-text);position:relative;z-index:1}.analysis-score-unit{font-size:12px;font-weight:600;margin-top:2px}.analysis-score-label{color:#64748b;color:var(--text-secondary);font-size:12px;font-weight:500}.analysis-stats{background:#f1f5f9;background:var(--color-muted-bg);border-radius:8px;border-radius:var(--radius-sm);display:flex;flex-direction:column;gap:4px;padding:8px 12px}.analysis-stat-row{align-items:center;display:flex;justify-content:space-between}.analysis-stat-label{color:#64748b;color:var(--text-secondary);font-size:12px}.analysis-stat-value{color:#1e293b;color:var(--text-primary);font-size:12px;font-weight:600}.analysis-distribution{display:flex;flex-direction:column;gap:6px}.analysis-dist-title{color:#1e293b;color:var(--text-primary);font-size:12px;font-weight:600}.analysis-bar-row{display:flex;flex-direction:column;gap:3px}.analysis-bar-header{align-items:center;display:flex;justify-content:space-between}.analysis-bar-label{color:#64748b;color:var(--text-secondary);font-size:11px}.analysis-bar-count{color:#94a3b8;color:var(--text-tertiary);font-size:11px}.analysis-bar-track{background:#f1f5f9;background:var(--color-muted-bg);height:8px;overflow:hidden;width:100%}.analysis-bar-fill,.analysis-bar-track{border-radius:9999px;border-radius:var(--radius-full)}.analysis-bar-fill{height:100%;min-width:2px;transition:width .6s ease}.btn-reset{align-self:center;background:#fff;background:var(--bg-surface);border:2px solid #6366f1;border:2px solid var(--color-primary);border-radius:9999px;border-radius:var(--radius-full);color:#6366f1;color:var(--color-primary);cursor:pointer;font-size:16px;font-weight:600;padding:14px 36px;transition:all .2s ease;transition:all var(--transition-base)}.btn-reset:hover{background:linear-gradient(135deg,#6366f1,#8b5cf6);background:var(--gradient-primary);border-color:#0000;box-shadow:0 4px 14px #6366f140;box-shadow:var(--shadow-primary);color:#fff}.pipeline-section{background:#fff;background:var(--bg-surface);border:1px solid #e2e8f0;border:1px solid var(--border-light);border-radius:16px;border-radius:var(--radius-lg);box-shadow:0 1px 2px #0000000d;box-shadow:var(--shadow-sm);display:flex;flex-direction:column;gap:18px;padding:24px}.pipeline-title{color:#94a3b8;color:var(--text-tertiary);font-size:13px;font-weight:700;letter-spacing:1.5px;text-transform:uppercase}.pipeline-timeline{display:flex;flex-direction:column;gap:0}.pipeline-stage{align-items:stretch;display:flex;gap:12px;min-height:42px}.pipeline-dot-col{align-items:center;display:flex;flex-direction:column;flex-shrink:0;width:20px}.pipeline-dot{background:#6366f1;background:var(--color-primary);border-radius:50%;flex-shrink:0;height:10px;margin-top:6px;width:10px}.pipeline-line{background:#e2e8f0;background:var(--border-light);flex:1 1;margin-top:4px;width:2px}.pipeline-stage-info{align-items:center;border-bottom:1px solid #f1f5f9;border-bottom:1px solid var(--color-muted-bg);display:flex;flex:1 1;justify-content:space-between;padding-bottom:10px}.pipeline-stage-name{color:#1e293b;color:var(--text-primary);font-size:14px;font-weight:500}.pipeline-stage-time{font-feature-settings:"tnum";color:#6366f1;color:var(--color-primary);font-size:13px;font-variant-numeric:tabular-nums;font-weight:600}.pipeline-summary{background:#f1f5f9;background:var(--color-muted-bg);border-radius:8px;border-radius:var(--radius-sm);display:flex;flex-direction:column;gap:8px;padding:14px}.pipeline-summary-row{align-items:center;color:#64748b;color:var(--text-secondary);display:flex;font-size:13px;justify-content:space-between}.pipeline-summary-value{color:#1e293b;color:var(--text-primary);font-weight:600}.metrics-grid{grid-gap:12px;display:grid;gap:12px;grid-template-columns:repeat(auto-fit,minmax(160px,1fr))}.metric-card{background:#fff;background:var(--bg-surface);border:1px solid #e2e8f0;border:1px solid var(--border-light);border-radius:16px;border-radius:var(--radius-lg);box-shadow:0 1px 2px #0000000d;box-shadow:var(--shadow-sm);display:flex;flex-direction:column;gap:14px;padding:20px;transition:box-shadow .2s ease,transform .2s ease;transition:box-shadow var(--transition-base),transform var(--transition-base)}.metric-card:hover{box-shadow:0 4px 6px -1px #00000012,0 2px 4px -2px #0000000d;box-shadow:var(--shadow-md);transform:translateY(-2px)}.metric-card-title{color:#94a3b8;color:var(--text-tertiary);font-size:12px;font-weight:700;letter-spacing:1px;text-transform:uppercase}.metric-rows{display:flex;flex-direction:column;gap:8px}.metric-row{align-items:center;color:#64748b;color:var(--text-secondary);display:flex;font-size:13px;justify-content:space-between}.metric-row-highlight{border-top:1px solid #f1f5f9;border-top:1px solid var(--color-muted-bg);margin-top:2px;padding-top:10px}.metric-value{font-feature-settings:"tnum";color:#1e293b;color:var(--text-primary);font-variant-numeric:tabular-nums;font-weight:600}.metric-value-accent{color:#6366f1;color:var(--color-primary)}.metric-value-cost{color:#00920a;color:var(--color-success);font-size:14px}.metric-badge-ok{background:#ecfdf5;background:var(--color-success-bg);color:#00920a;color:var(--color-success-text)}.metric-badge-ok,.metric-badge-warn{border-radius:9999px;border-radius:var(--radius-full);display:inline-block;font-size:12px;font-weight:600;padding:2px 10px}.metric-badge-warn{background:#fffbeb;background:var(--color-warning-bg);color:#ff6f00;color:var(--color-warning-text)}.metric-bar-wrap{background:#f1f5f9;background:var(--color-muted-bg);border-radius:9999px;border-radius:var(--radius-full);display:flex;height:8px;overflow:hidden}.metric-bar-fill{height:100%;transition:width .5s ease}.metric-bar-content{background:#6366f1;background:var(--color-primary)}.metric-bar-punct{background:#e2e8f0;background:var(--border-light)}.metric-bar-legend{color:#94a3b8;color:var(--text-tertiary);display:flex;font-size:11px;gap:14px}.metric-bar-legend-item{align-items:center;display:flex;gap:5px}.metric-dot{border-radius:50%;display:inline-block;height:8px;width:8px}.metric-dot-content{background:#6366f1;background:var(--color-primary)}.metric-dot-punct{background:#e2e8f0;background:var(--border-light)}.metric-coverage-bar{background:#f1f5f9;background:var(--color-muted-bg);height:8px;overflow:hidden}.metric-coverage-bar,.metric-coverage-fill{border-radius:9999px;border-radius:var(--radius-full)}.metric-coverage-fill{background:linear-gradient(135deg,#6366f1,#8b5cf6);background:var(--gradient-primary);height:100%;transition:width .5s ease}.metric-note{color:#94a3b8;color:var(--text-tertiary);font-size:12px;line-height:1.6}.prompt-detail-section{background:#fff;background:var(--bg-surface);border:1px solid #e2e8f0;border:1px solid var(--border-light);border-radius:16px;border-radius:var(--radius-lg);box-shadow:0 1px 2px #0000000d;box-shadow:var(--shadow-sm);display:flex;flex-direction:column;gap:14px;padding:24px}.prompt-detail-title{color:#94a3b8;color:var(--text-tertiary);font-size:12px;font-weight:700;letter-spacing:1.5px;text-transform:uppercase}.prompt-detail-block{display:flex;flex-direction:column}.prompt-detail-toggle{align-items:center;background:#f1f5f9;background:var(--color-muted-bg);border:1px solid #e2e8f0;border:1px solid var(--border-light);border-radius:8px;border-radius:var(--radius-sm);color:#1e293b;color:var(--text-primary);cursor:pointer;display:flex;font-family:inherit;font-size:14px;font-weight:500;gap:8px;padding:10px 14px;transition:background .15s ease;transition:background var(--transition-fast)}.prompt-detail-toggle:hover{background:#e2e8f0;background:var(--border-light)}.prompt-detail-toggle-icon{color:#94a3b8;color:var(--text-tertiary);font-size:11px;width:14px}.prompt-detail-size{color:#94a3b8;color:var(--text-tertiary);font-size:12px;font-weight:400;margin-left:auto}.prompt-detail-content{background:#1e1b2e;border-radius:12px;border-radius:var(--radius-md);color:#c4b5fd;font-family:Consolas,Monaco,Courier New,monospace;font-size:13px;line-height:1.7;margin-top:10px;max-height:400px;overflow-x:auto;overflow-y:auto;padding:18px;white-space:pre-wrap;word-break:break-word}.prompt-detail-pair{display:flex;flex-direction:column;gap:12px;padding:12px}.prompt-detail-sub{display:flex;flex-direction:column;gap:6px}.prompt-detail-sub-label{color:#94a3b8;color:var(--text-tertiary);font-size:12px;font-weight:600;letter-spacing:.5px;text-transform:uppercase}.metrics-toggle-section{border:1px solid #e2e8f0;border:1px solid var(--border-light);border-radius:12px;border-radius:var(--radius-md);box-shadow:0 1px 2px #0000000d;box-shadow:var(--shadow-sm);margin-top:24px;overflow:hidden}.metrics-toggle-btn{align-items:center;background:#f1f5f9;background:var(--color-muted-bg);border:none;color:#64748b;color:var(--text-secondary);cursor:pointer;display:flex;font-family:inherit;font-size:15px;font-weight:600;gap:8px;padding:14px 20px;text-align:left;transition:background .2s ease;transition:background var(--transition-base);width:100%}.metrics-toggle-btn:hover{background:#e2e8f0;background:var(--border-light)}.metrics-toggle-icon{color:#94a3b8;color:var(--text-tertiary);font-size:12px}.metrics-toggle-content{border-top:1px solid #e2e8f0;border-top:1px solid var(--border-light);padding:20px}.metrics-toggle-content,.metrics-toggle-content>div:not(.attempt-metrics-section){display:flex;flex-direction:column;gap:16px}.metrics-row-equal{align-items:stretch;display:flex;gap:16px}.metrics-row-equal>*{box-sizing:border-box;flex:1 1;margin:0;max-width:none;min-width:0}.metrics-row-equal .analysis-panel,.metrics-row-equal .pipeline-section{align-self:stretch;height:auto}.chat-start-screen{align-items:center;display:flex;flex-direction:column;padding:72px 24px;text-align:center}.chat-start-icon{filter:drop-shadow(0 4px 12px rgba(99,102,241,.2));font-size:72px;margin-bottom:20px}.chat-start-screen h2{color:#1e293b;color:var(--text-primary);font-size:24px;font-weight:700;margin-bottom:12px}.chat-start-desc{color:#64748b;color:var(--text-secondary);font-size:16px;line-height:1.7;margin-bottom:36px}.chat-btn-start{background:linear-gradient(135deg,#6366f1,#8b5cf6);background:var(--gradient-primary);border:none;border-radius:9999px;border-radius:var(--radius-full);box-shadow:0 4px 14px #6366f140;box-shadow:var(--shadow-primary);color:#fff;cursor:pointer;font-size:16px;font-weight:600;padding:14px 44px;transition:transform .15s ease,box-shadow .2s ease;transition:transform var(--transition-fast),box-shadow var(--transition-base)}.chat-btn-start:hover:not(:disabled){box-shadow:0 6px 20px #6366f159;transform:translateY(-1px)}.chat-btn-start:disabled{cursor:not-allowed;opacity:.6}.chat-container{display:flex;flex-direction:column;height:calc(100vh - 200px);max-height:700px;min-height:400px}.chat-header{align-items:center;background:#fff;background:var(--bg-surface);border:1px solid #e2e8f0;border:1px solid var(--border-light);border-radius:12px;border-radius:var(--radius-md);box-shadow:0 1px 2px #0000000d;box-shadow:var(--shadow-sm);display:flex;justify-content:space-between;margin-bottom:16px;padding:14px 20px}.chat-header-title{color:#1e293b;color:var(--text-primary);font-weight:700}.chat-header-turns{color:#64748b;color:var(--text-secondary);font-size:13px;font-weight:500}.chat-messages{display:flex;flex:1 1;flex-direction:column;gap:14px;overflow-y:auto;padding:12px 0}.chat-bubble{animation:fadeIn .3s ease;display:flex;gap:10px;max-width:85%}@keyframes fadeIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.chat-bubble-system{align-self:flex-start}.chat-bubble-user{align-self:flex-end;flex-direction:row-reverse}.chat-bubble-avatar{flex-shrink:0;font-size:28px;margin-top:2px}.chat-avatar-img{border-radius:50%;height:36px;object-fit:cover;width:36px}.chat-bubble-content{border-radius:16px;border-radius:var(--radius-lg);font-size:15px;line-height:1.7;padding:14px 18px}.chat-bubble-content p{margin:0}.chat-bubble-system .chat-bubble-content{background:#fff;background:var(--bg-surface);border:1px solid #e2e8f0;border:1px solid var(--border-light);border-top-left-radius:4px;box-shadow:0 1px 2px #0000000d;box-shadow:var(--shadow-sm);color:#1e293b;color:var(--text-primary)}.chat-bubble-user .chat-bubble-content{background:linear-gradient(135deg,#6366f1,#8b5cf6);background:var(--gradient-primary);border-top-right-radius:4px;box-shadow:0 4px 6px -1px #00000012,0 2px 4px -2px #0000000d;box-shadow:var(--shadow-md);color:#fff}.chat-accuracy-badge{border-radius:9999px;border-radius:var(--radius-full);display:inline-block;font-size:12px;font-weight:600;margin-top:10px;padding:3px 12px}.chat-badge-correct{background:#ecfdf5;background:var(--color-success-bg);color:#00920a;color:var(--color-success-text)}.chat-badge-partial{background:#fffbeb;background:var(--color-warning-bg);color:#ff6f00;color:var(--color-warning-text)}.chat-badge-incorrect{background:#fef2f2;background:var(--color-error-bg);color:#ff2626;color:var(--color-error-text)}.chat-badge-offtopic{background:#f1f5f9;background:var(--color-muted-bg);color:#a3a3a3;color:var(--color-muted-text)}.chat-typing{display:flex;gap:5px;padding:4px 0}.chat-typing-dot{animation:typingBounce 1.4s ease-in-out infinite;background:#a3a3a3;background:var(--color-muted);border-radius:50%;height:8px;width:8px}.chat-typing-dot:nth-child(2){animation-delay:.2s}.chat-typing-dot:nth-child(3){animation-delay:.4s}@keyframes typingBounce{0%,80%,to{opacity:.4;transform:scale(.6)}40%{opacity:1;transform:scale(1)}}.chat-input-area{backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);background:#ffffffb3;background:var(--bg-overlay);border-radius:16px 16px 0 0;border-radius:var(--radius-lg) var(--radius-lg) 0 0;border-top:1px solid #e2e8f0;border-top:1px solid var(--border-light);margin-top:8px;padding:16px}.chat-input-row{align-items:flex-end;display:flex;gap:10px}.chat-input-text{background:#fff;background:var(--bg-surface);border:1px solid #e2e8f0;border:1px solid var(--border-light);border-radius:12px;border-radius:var(--radius-md);color:#1e293b;color:var(--text-primary);flex:1 1;font-family:inherit;font-size:15px;line-height:1.5;max-height:100px;overflow-y:auto;padding:12px 16px;resize:none;transition:border-color .2s ease,box-shadow .2s ease;transition:border-color var(--transition-base),box-shadow var(--transition-base)}.chat-input-text:focus{border-color:#6366f1;border-color:var(--border-focus);box-shadow:0 0 0 3px #6366f11a;outline:none}.chat-btn-voice{align-items:center;background:#fff;background:var(--bg-surface);border:1px solid #e2e8f0;border:1px solid var(--border-light);border-radius:50%;cursor:pointer;display:flex;flex-shrink:0;font-size:18px;height:44px;justify-content:center;transition:all .2s ease;transition:all var(--transition-base);width:44px}.chat-btn-voice:hover:not(:disabled){background:#f1f5f9;background:var(--color-muted-bg);border-color:#818cf8;border-color:var(--color-primary-light)}.chat-btn-send{background:linear-gradient(135deg,#6366f1,#8b5cf6);background:var(--gradient-primary);border:none;border-radius:12px;border-radius:var(--radius-md);box-shadow:0 4px 14px #6366f140;box-shadow:var(--shadow-primary);color:#fff;cursor:pointer;flex-shrink:0;font-size:14px;font-weight:600;padding:10px 20px;transition:transform .15s ease,box-shadow .2s ease;transition:transform var(--transition-fast),box-shadow var(--transition-base)}.chat-btn-send:hover:not(:disabled){box-shadow:0 6px 16px #6366f14d;transform:translateY(-1px)}.chat-btn-send:disabled{box-shadow:none;cursor:not-allowed;opacity:.5;transform:none}.chat-btn-end{background:#fff;background:var(--bg-surface);border:1px solid #e2e8f0;border:1px solid var(--border-light);border-radius:12px;border-radius:var(--radius-md);color:#64748b;color:var(--text-secondary);cursor:pointer;flex-shrink:0;font-size:14px;padding:10px 16px;transition:all .2s ease;transition:all var(--transition-base)}.chat-btn-end:hover:not(:disabled){background:#f1f5f9;background:var(--color-muted-bg);border-color:#a3a3a3;border-color:var(--color-muted);color:#1e293b;color:var(--text-primary)}.chat-recording{align-items:center;background:#fef2f2;background:var(--color-error-bg);border-radius:12px;border-radius:var(--radius-md);color:#ff2626;color:var(--color-error-text);display:flex;font-size:14px;gap:10px;margin-bottom:10px;padding:12px 18px}.chat-btn-stop{background:#fff;background:var(--bg-surface);border:1px solid #ff2626;border:1px solid var(--color-error);border-radius:8px;border-radius:var(--radius-sm);color:#ff2626;color:var(--color-error);cursor:pointer;font-size:13px;margin-left:auto;padding:6px 14px;transition:background .2s ease;transition:background var(--transition-base)}.chat-btn-stop:hover{background:#fef2f2;background:var(--color-error-bg)}.chat-transcribing{font-size:14px;gap:10px;padding:12px 18px}.chat-transcribing,.chat-tts-status{align-items:center;color:#64748b;color:var(--text-secondary);display:flex}.chat-tts-status{animation:ttsStatusFade .3s ease-in;font-size:13px;gap:8px;padding:6px 16px 10px}.chat-tts-icon{animation:ttsPulse 1.2s ease-in-out infinite}.tts-status{align-items:center;animation:ttsStatusFade .3s ease-in;color:#64748b;color:var(--text-secondary);display:flex;font-size:12px;gap:6px;margin-top:8px}@keyframes ttsPulse{0%,to{opacity:1}50%{opacity:.4}}@keyframes ttsStatusFade{0%{opacity:0}to{opacity:1}}.voice-select-wrap{align-items:center;display:flex;gap:10px;margin:16px 0}.voice-select-label{color:var(--color-text-secondary);font-size:14px;font-weight:600;white-space:nowrap}.voice-select{background:var(--color-bg);border:1px solid var(--color-border);border-radius:8px;border-radius:var(--radius-sm);color:var(--color-text);cursor:pointer;font-size:14px;min-width:140px;padding:8px 12px}.voice-select:focus{border-color:#6366f1;border-color:var(--color-primary);box-shadow:0 0 0 2px #6366f126;outline:none}.tts-status-below{align-items:center;animation:ttsStatusFade .3s ease;background:#6366f11f;border-radius:20px;color:#6366f1;display:flex;font-size:12px;font-weight:500;gap:6px;justify-content:center;margin-top:8px;padding:6px 14px}.tts-status-icon{animation:ttsPulse 1.2s infinite}.chat-error{background:#fef2f2;background:var(--color-error-bg);border:1px solid #ef444426;border-radius:8px;border-radius:var(--radius-sm);color:#ff2626;color:var(--color-error);font-size:13px;margin:0 0 10px;padding:10px 14px}.chat-summary{animation:fadeIn .4s ease;background:#fff;background:var(--bg-surface);border:1px solid #e2e8f0;border:1px solid var(--border-light);border-radius:20px;border-radius:var(--radius-xl);box-shadow:0 10px 15px -3px #00000014,0 4px 6px -4px #0000000a;box-shadow:var(--shadow-lg);margin-top:20px;padding:32px}.chat-summary-title{color:#1e293b;color:var(--text-primary);font-size:20px;font-weight:800;margin-bottom:24px;text-align:center}.chat-summary-score{display:flex;justify-content:center;margin-bottom:28px}.chat-summary-score-circle{align-items:center;background:linear-gradient(135deg,#6366f1,#8b5cf6);background:var(--gradient-primary);border-radius:50%;box-shadow:0 4px 14px #6366f140;box-shadow:var(--shadow-primary);color:#fff;display:flex;flex-direction:column;height:110px;justify-content:center;width:110px}.chat-summary-score-value{font-size:36px;font-weight:800;line-height:1}.chat-summary-score-unit{font-size:14px;opacity:.9}.chat-summary-section{margin-bottom:20px}.chat-summary-section h4{color:#64748b;color:var(--text-secondary);font-size:14px;font-weight:700;margin-bottom:10px}.chat-summary-section ul{display:flex;flex-wrap:wrap;gap:8px;list-style:none;margin:0;padding:0}.chat-summary-section li{border-radius:9999px;border-radius:var(--radius-full);font-size:13px;font-weight:500;padding:6px 14px}.chat-summary-good{background:#ecfdf5;background:var(--color-success-bg);color:#00920a;color:var(--color-success-text)}.chat-summary-review{background:#fffbeb;background:var(--color-warning-bg);color:#ff6f00;color:var(--color-warning-text)}.chat-summary-feedback{background:#f1f5f9;background:var(--color-muted-bg);border-radius:12px;border-radius:var(--radius-md);margin-top:20px;padding:20px}.chat-summary-feedback p{color:#64748b;color:var(--text-secondary);font-size:15px;line-height:1.8;margin:0}.chat-btn-restart{background:linear-gradient(135deg,#6366f1,#8b5cf6);background:var(--gradient-primary);border:none;border-radius:9999px;border-radius:var(--radius-full);box-shadow:0 4px 14px #6366f140;box-shadow:var(--shadow-primary);color:#fff;cursor:pointer;display:block;font-size:15px;font-weight:600;margin:24px auto 0;padding:14px 36px;transition:transform .15s ease,box-shadow .2s ease;transition:transform var(--transition-fast),box-shadow var(--transition-base)}.chat-btn-restart:hover{box-shadow:0 6px 20px #6366f159;transform:translateY(-1px)}.metric-accuracy-dist{border-top:1px solid #e2e8f0;border-top:1px solid var(--border-light);margin-top:14px;padding-top:14px}.metric-dist-title{color:#64748b;color:var(--text-secondary);font-size:13px;font-weight:600;margin:0 0 12px}@media (max-width:900px){.metrics-grid{grid-template-columns:1fr}}@media (max-width:768px){.app{padding:32px 16px}h1{font-size:26px}.result-layout{flex-direction:column}.analysis-panel{position:static;width:100%}.app-mode-tabs{display:flex;width:100%}.app-mode-tab{flex:1 1;text-align:center}.input-mode-tabs{display:flex;width:100%}.input-mode-tab{flex:1 1;text-align:center}.chat-bubble{max-width:92%}.compare-split-panel,.compare-summary-cards{flex-direction:column}.compare-model-selectors{align-items:center;flex-direction:column}}.compare-start-screen{align-items:center;display:flex;flex-direction:column;padding:48px 24px;text-align:center}.compare-start-icon{filter:drop-shadow(0 4px 12px rgba(99,102,241,.2));font-size:64px;margin-bottom:16px}.compare-start-screen h2{color:#1e293b;color:var(--text-primary);font-size:24px;font-weight:700;margin-bottom:12px}.compare-start-desc{color:#64748b;color:var(--text-secondary);font-size:15px;line-height:1.7;margin-bottom:24px}.compare-count-selector{align-items:center;display:flex;gap:12px;margin-bottom:24px}.compare-count-label{color:#64748b;color:var(--text-secondary);font-size:14px;font-weight:600}.compare-count-btns{border:1px solid #e2e8f0;border:1px solid var(--border-light);border-radius:12px;border-radius:var(--radius-md);display:flex;gap:0;overflow:hidden}.compare-count-btn{background:#fff;background:var(--bg-surface);border:none;color:#64748b;color:var(--text-secondary);cursor:pointer;font-family:inherit;font-size:14px;font-weight:600;padding:8px 20px;transition:all .15s ease;transition:all var(--transition-fast)}.compare-count-btn+.compare-count-btn{border-left:1px solid #e2e8f0;border-left:1px solid var(--border-light)}.compare-count-btn.active{background:linear-gradient(135deg,#6366f1,#8b5cf6);background:var(--gradient-primary);color:#fff}.compare-count-btn:disabled{cursor:not-allowed;opacity:.4}.compare-model-selectors{align-items:center;display:flex;gap:16px;margin-bottom:32px;max-width:700px;width:100%}.compare-model-selectors.count-3{max-width:900px}.compare-model-group{display:flex;flex:1 1;flex-direction:column;gap:8px}.compare-model-label{color:#64748b;color:var(--text-secondary);font-size:13px;font-weight:600}.compare-model-select{background:#fff;background:var(--bg-surface);border:1px solid #e2e8f0;border:1px solid var(--border-light);border-radius:12px;border-radius:var(--radius-md);color:#1e293b;color:var(--text-primary);cursor:pointer;font-family:inherit;font-size:14px;padding:12px 16px;transition:border-color .2s ease;transition:border-color var(--transition-base)}.compare-model-select:focus{border-color:#6366f1;border-color:var(--border-focus);box-shadow:0 0 0 3px #6366f11a;outline:none}.compare-vs{color:#6366f1;color:var(--color-primary);flex-shrink:0;font-size:18px;font-weight:800;margin-top:20px}.compare-btn-start{background:linear-gradient(135deg,#6366f1,#8b5cf6);background:var(--gradient-primary);border:none;border-radius:9999px;border-radius:var(--radius-full);box-shadow:0 4px 14px #6366f140;box-shadow:var(--shadow-primary);color:#fff;cursor:pointer;font-size:16px;font-weight:600;padding:14px 44px;transition:transform .15s ease,box-shadow .2s ease;transition:transform var(--transition-fast),box-shadow var(--transition-base)}.compare-btn-start:hover:not(:disabled){box-shadow:0 6px 20px #6366f159;transform:translateY(-1px)}.compare-btn-start:disabled{cursor:not-allowed;opacity:.6}.compare-container{display:flex;flex-direction:column;height:calc(100vh - 200px);max-height:800px;min-height:500px}.compare-header{align-items:center;background:#fff;background:var(--bg-surface);border:1px solid #e2e8f0;border:1px solid var(--border-light);border-radius:12px;border-radius:var(--radius-md);box-shadow:0 1px 2px #0000000d;box-shadow:var(--shadow-sm);display:flex;gap:12px;justify-content:space-between;margin-bottom:16px;padding:14px 20px}.compare-header-title{color:#1e293b;color:var(--text-primary);font-weight:700}.compare-header-models{color:#6366f1;color:var(--color-primary);font-size:13px;font-weight:600}.compare-header-turns{color:#64748b;color:var(--text-secondary);font-size:13px;font-weight:500}.compare-messages{flex:1 1;gap:20px;overflow-y:auto;padding:12px 0}.compare-messages,.compare-turn{display:flex;flex-direction:column}.compare-turn{animation:fadeIn .3s ease;gap:12px}.compare-question{align-self:flex-start;display:flex;gap:10px;max-width:90%}.compare-question-avatar{flex-shrink:0;font-size:28px}.compare-question p{background:#fff;background:var(--bg-surface);border:1px solid #e2e8f0;border:1px solid var(--border-light);border-radius:16px;border-radius:var(--radius-lg);border-top-left-radius:4px;box-shadow:0 1px 2px #0000000d;box-shadow:var(--shadow-sm);color:#1e293b;color:var(--text-primary);font-size:15px;line-height:1.7;margin:0;padding:14px 18px}.compare-user-answer{align-self:flex-end;max-width:85%}.compare-user-answer p{background:linear-gradient(135deg,#6366f1,#8b5cf6);background:var(--gradient-primary);border-radius:16px;border-radius:var(--radius-lg);border-top-right-radius:4px;box-shadow:0 4px 6px -1px #00000012,0 2px 4px -2px #0000000d;box-shadow:var(--shadow-md);color:#fff;font-size:15px;line-height:1.7;margin:0;padding:14px 18px}.compare-split-panel{display:flex;gap:16px}.compare-result-card{background:#fff;background:var(--bg-surface);border:1px solid #e2e8f0;border:1px solid var(--border-light);border-radius:16px;border-radius:var(--radius-lg);box-shadow:0 1px 2px #0000000d;box-shadow:var(--shadow-sm);display:flex;flex:1 1;flex-direction:column;gap:10px;padding:18px;position:relative;transition:box-shadow .2s ease;transition:box-shadow var(--transition-base)}.compare-result-card:hover{box-shadow:0 4px 6px -1px #00000012,0 2px 4px -2px #0000000d;box-shadow:var(--shadow-md)}.compare-result-card.fastest{border-color:#818cf8;border-color:var(--color-primary-light);box-shadow:0 0 0 1px #818cf8,0 1px 2px #0000000d;box-shadow:0 0 0 1px var(--color-primary-light),var(--shadow-sm)}.compare-fastest-badge{background:linear-gradient(135deg,#6366f1,#8b5cf6);background:var(--gradient-primary);border-radius:9999px;border-radius:var(--radius-full);box-shadow:0 4px 14px #6366f140;box-shadow:var(--shadow-primary);color:#fff;font-size:10px;font-weight:800;letter-spacing:1px;padding:2px 10px;position:absolute;right:12px;top:-10px}.compare-result-header{align-items:center;display:flex;justify-content:space-between}.compare-result-model{color:#6366f1;color:var(--color-primary);font-size:13px;font-weight:700}.compare-result-time{font-feature-settings:"tnum";background:#f1f5f9;background:var(--color-muted-bg);border-radius:9999px;border-radius:var(--radius-full);color:#94a3b8;color:var(--text-tertiary);font-size:12px;font-variant-numeric:tabular-nums;font-weight:600;padding:2px 8px}.compare-result-feedback{color:#64748b;color:var(--text-secondary);font-size:14px;line-height:1.7;margin:0}.compare-result-meta{border-top:1px solid #f1f5f9;border-top:1px solid var(--color-muted-bg);color:#94a3b8;color:var(--text-tertiary);display:flex;font-size:11px;justify-content:space-between;padding-top:8px}.compare-loading{align-items:center;color:#64748b;color:var(--text-secondary);display:flex;font-size:14px;gap:12px;padding:16px 20px}.compare-loading p{margin:0}.compare-input-area{backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);background:#ffffffb3;background:var(--bg-overlay);border-radius:16px 16px 0 0;border-radius:var(--radius-lg) var(--radius-lg) 0 0;border-top:1px solid #e2e8f0;border-top:1px solid var(--border-light);margin-top:8px;padding:16px}.compare-input-row{align-items:flex-end;display:flex;gap:10px}.compare-input-text{background:#fff;background:var(--bg-surface);border:1px solid #e2e8f0;border:1px solid var(--border-light);border-radius:12px;border-radius:var(--radius-md);color:#1e293b;color:var(--text-primary);flex:1 1;font-family:inherit;font-size:15px;line-height:1.5;max-height:100px;overflow-y:auto;padding:12px 16px;resize:none;transition:border-color .2s ease,box-shadow .2s ease;transition:border-color var(--transition-base),box-shadow var(--transition-base)}.compare-input-text:focus{border-color:#6366f1;border-color:var(--border-focus);box-shadow:0 0 0 3px #6366f11a;outline:none}.compare-btn-send{background:linear-gradient(135deg,#6366f1,#8b5cf6);background:var(--gradient-primary);border:none;border-radius:12px;border-radius:var(--radius-md);box-shadow:0 4px 14px #6366f140;box-shadow:var(--shadow-primary);color:#fff;cursor:pointer;flex-shrink:0;font-size:14px;font-weight:600;padding:10px 20px;transition:transform .15s ease,box-shadow .2s ease;transition:transform var(--transition-fast),box-shadow var(--transition-base)}.compare-btn-send:hover:not(:disabled){box-shadow:0 6px 16px #6366f14d;transform:translateY(-1px)}.compare-btn-send:disabled{box-shadow:none;cursor:not-allowed;opacity:.5;transform:none}.compare-btn-end{background:#fff;background:var(--bg-surface);border:1px solid #e2e8f0;border:1px solid var(--border-light);border-radius:12px;border-radius:var(--radius-md);color:#64748b;color:var(--text-secondary);cursor:pointer;flex-shrink:0;font-size:14px;padding:10px 16px;transition:all .2s ease;transition:all var(--transition-base)}.compare-btn-end:hover:not(:disabled){background:#f1f5f9;background:var(--color-muted-bg);border-color:#a3a3a3;border-color:var(--color-muted);color:#1e293b;color:var(--text-primary)}.compare-summary{animation:fadeIn .4s ease;background:#fff;background:var(--bg-surface);border:1px solid #e2e8f0;border:1px solid var(--border-light);border-radius:20px;border-radius:var(--radius-xl);box-shadow:0 10px 15px -3px #00000014,0 4px 6px -4px #0000000a;box-shadow:var(--shadow-lg);margin-top:20px;padding:32px}.compare-summary-title{color:#1e293b;color:var(--text-primary);font-size:20px;font-weight:800;margin-bottom:28px;text-align:center}.compare-summary-cards{display:flex;gap:20px;margin-bottom:28px}.compare-summary-card{background:#f1f5f9;background:var(--color-muted-bg);border-radius:16px;border-radius:var(--radius-lg);display:flex;flex:1 1;flex-direction:column;gap:16px;padding:24px}.compare-summary-model{color:#6366f1;color:var(--color-primary);font-size:14px;font-weight:700;margin:0;text-align:center}.compare-summary-score{display:flex;justify-content:center}.compare-summary-score-value{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#6366f1,#8b5cf6);background:var(--gradient-primary);-webkit-background-clip:text;background-clip:text;font-size:42px;font-weight:800;line-height:1}.compare-summary-score-unit{align-self:flex-end;color:#64748b;color:var(--text-secondary);font-size:16px;font-weight:600;margin-bottom:4px;margin-left:4px}.compare-summary-stats{display:flex;flex-direction:column;gap:6px}.compare-summary-stat{color:#64748b;color:var(--text-secondary);display:flex;font-size:13px;justify-content:space-between}.compare-summary-stat span:last-child{color:#1e293b;color:var(--text-primary);font-weight:600}.compare-summary-section{margin-top:4px}.compare-summary-section h5{color:#94a3b8;color:var(--text-tertiary);font-size:12px;font-weight:700;letter-spacing:.5px;margin:0 0 8px;text-transform:uppercase}.compare-summary-section ul{display:flex;flex-wrap:wrap;gap:6px;list-style:none;margin:0;padding:0}.compare-summary-section li{background:#fff;background:var(--bg-surface);border-radius:9999px;border-radius:var(--radius-full);color:#64748b;color:var(--text-secondary);font-size:12px;font-weight:500;padding:4px 10px}.compare-summary-feedback{color:#64748b;color:var(--text-secondary);font-size:13px;line-height:1.7;margin:0}.compare-comparison{grid-gap:12px;background:#f1f5f9;background:var(--color-muted-bg);border-radius:16px;border-radius:var(--radius-lg);display:grid;gap:12px;grid-template-columns:repeat(3,1fr);margin-bottom:24px;padding:20px}.compare-comparison-item{align-items:center;display:flex;flex-direction:column;gap:6px;text-align:center}.compare-comparison-label{color:#94a3b8;color:var(--text-tertiary);font-size:11px;font-weight:600;letter-spacing:.5px;text-transform:uppercase}.compare-comparison-value{color:#1e293b;color:var(--text-primary);font-size:16px;font-weight:700}.compare-winner-badge{color:#6366f1!important;color:var(--color-primary)!important;font-size:13px!important}.compare-btn-restart{background:linear-gradient(135deg,#6366f1,#8b5cf6);background:var(--gradient-primary);border:none;border-radius:9999px;border-radius:var(--radius-full);box-shadow:0 4px 14px #6366f140;box-shadow:var(--shadow-primary);color:#fff;cursor:pointer;display:block;font-size:15px;font-weight:600;margin:0 auto;padding:14px 36px;transition:transform .15s ease,box-shadow .2s ease;transition:transform var(--transition-fast),box-shadow var(--transition-base)}.compare-btn-restart:hover{box-shadow:0 6px 20px #6366f159;transform:translateY(-1px)}.keyword-start-screen{align-items:center;display:flex;flex-direction:column;padding:48px 24px;text-align:center}.keyword-start-icon{filter:drop-shadow(0 4px 12px rgba(99,102,241,.2));font-size:64px;margin-bottom:16px}.keyword-start-screen h2{color:#1e293b;color:var(--text-primary);font-size:24px;font-weight:700;margin-bottom:12px}.keyword-start-desc{color:#64748b;color:var(--text-secondary);font-size:15px;line-height:1.7;margin-bottom:24px}.keyword-start-btn{background:linear-gradient(135deg,#6366f1,#8b5cf6);background:var(--gradient-primary);border:none;border-radius:9999px;border-radius:var(--radius-full);color:#fff;cursor:pointer;font-size:16px;font-weight:600;padding:14px 40px;transition:all .2s}.keyword-start-btn:hover:not(:disabled){box-shadow:0 6px 20px #6366f159;transform:translateY(-1px)}.keyword-start-btn:disabled{cursor:not-allowed;opacity:.6}.keyword-prompt-section{margin:0 auto;max-width:640px;padding:24px 0}.keyword-prompt-text{color:#1e293b;color:var(--text-primary);font-size:17px;font-weight:600;line-height:1.7;margin-bottom:20px;text-align:center}.keyword-chips{display:flex;flex-wrap:wrap;gap:12px;justify-content:center;margin-bottom:24px}.keyword-chip{background:linear-gradient(135deg,#e8f0fe,#ede9fe);border:2px solid #818cf8;border:2px solid var(--color-primary-light);border-radius:9999px;border-radius:var(--radius-full);color:#4f46e5;color:var(--color-primary-dark);display:inline-block;font-size:16px;font-weight:700;padding:10px 20px}.keyword-retry-hint{background:#fffbeb;background:var(--color-warning-bg);border-radius:12px;border-radius:var(--radius-md);color:#ff6f00;color:var(--color-warning-text);font-size:14px;padding:10px 16px;text-align:center}.keyword-retry-hint strong{color:#ff2626;color:var(--color-error);font-weight:700}.keyword-checklist{background:#fff;background:var(--bg-surface);border:1px solid #e2e8f0;border:1px solid var(--border-light);border-radius:12px;border-radius:var(--radius-md);margin-bottom:20px;padding:16px 20px}.keyword-checklist-title{color:#64748b;color:var(--text-secondary);font-size:14px;font-weight:600;margin-bottom:12px}.keyword-checklist-items{display:flex;flex-wrap:wrap;gap:16px}.keyword-check-item{font-size:16px;font-weight:600}.keyword-check-item.found{color:#00920a;color:var(--color-success-text)}.keyword-check-item.missing{color:#ff2626;color:var(--color-error-text)}.keyword-accuracy-banner{background:#ecfdf5;background:var(--color-success-bg);border:1px solid #00920a;border:1px solid var(--color-success);border-radius:12px;border-radius:var(--radius-md);color:#00920a;color:var(--color-success-text);font-size:18px;font-weight:700;margin-bottom:16px;padding:12px;text-align:center}.score-bar-chart-wrap{align-items:flex-start;background:#fff;background:var(--bg-surface);border:1px solid #e2e8f0;border:1px solid var(--border-light);border-radius:12px;border-radius:var(--radius-md);display:flex;gap:12px;justify-content:center;margin-bottom:20px;padding:16px 28px 12px}.score-bar-yaxis{display:flex;flex-direction:column;height:160px;justify-content:space-between;padding-right:4px}.score-bar-ytick{color:#94a3b8;color:var(--text-tertiary);font-size:10px;line-height:1;text-align:right}.score-bar-cols{align-items:flex-end;display:flex;gap:32px}.score-bar-col{align-items:center;display:flex;flex-direction:column;gap:8px}.score-bar-track{background:#fce4ec;border-radius:6px 6px 0 0;height:160px;overflow:visible;position:relative;width:56px}.score-bar-fill{background:linear-gradient(0deg,#d81b60,#f06292);border-radius:6px 6px 0 0;bottom:0;left:0;position:absolute;right:0;transition:height .6s cubic-bezier(.4,0,.2,1)}.score-bar-dashed-wrap{align-items:center;display:flex;left:-4px;pointer-events:none;position:absolute;right:-56px}.score-bar-dashed-line{border-top:2px dashed #e91e8c;width:60px}.score-bar-score-label{color:#e91e8c;font-size:12px;font-weight:700;padding-left:5px;white-space:nowrap}.score-bar-col-label{color:#64748b;color:var(--text-secondary);font-size:13px;font-weight:700;letter-spacing:.02em}.score-bar-improved .score-bar-fill{background:linear-gradient(0deg,#00695c,#26a69a)}.score-bar-improved .score-bar-dashed-line{border-color:#00897b}.score-bar-improved .score-bar-score-label{color:#00897b}.score-bar-fill.bar-total{background:linear-gradient(0deg,#d81b60,#f06292)}.score-cards-wrap{display:flex;gap:16px;justify-content:center;margin-bottom:20px}.score-cards-two{gap:12px}.score-cards-two .comprehension-row{gap:6px}.score-cards-two .comprehension-donut,.score-cards-two .comprehension-donut-wrap{height:54px;width:54px}.score-cards-two .comp-score-main{font-size:11px}.score-cards-two .comp-score-sub{font-size:8px}.score-cards-two .comp-keyword-row{font-size:10px;gap:3px}.score-cards-two .comp-keyword-dot{height:5px;width:5px}.score-cards-two .comp-keyword-name{white-space:nowrap}.score-cards-two .comp-keyword-score{font-size:10px}.score-cards-two .comprehension-keywords{gap:2px}.score-card{align-items:center;background:#fff;background:var(--bg-surface);border:1.5px solid #e8d5f0;border-radius:16px;display:flex;flex:1 1;flex-direction:column;max-width:380px;min-width:260px;padding:16px 20px 14px}.score-card-attempt-label{background:#f3e5f5;border-radius:20px;color:#9c27b0;font-size:11px;font-weight:700;letter-spacing:.06em;margin-bottom:6px;padding:2px 12px}.score-card-title{color:#64748b;color:var(--text-secondary);font-size:13px;font-weight:700;margin-bottom:8px}.score-card-bar-section{display:flex;justify-content:center;margin-bottom:14px;width:100%}.score-card .score-bar-chart-wrap{background:#0000;border:none;gap:8px;margin-bottom:0;padding:28px 0 0}.score-card .score-bar-dashed-wrap{left:0;right:auto}.score-card .score-bar-dashed-line{min-width:80px;width:80px}.score-card .score-bar-track{width:80px}.score-card-bottom{align-items:flex-start;display:flex;gap:16px;width:100%}.score-accuracy-section{flex:1 1;min-width:0}.score-section-title{color:#64748b;color:var(--text-secondary);font-size:12px;font-weight:700;margin-bottom:6px}.accuracy-bar-row{align-items:center;display:flex;gap:8px;margin-bottom:8px}.accuracy-bar-capsule{background:#e3eaff;border-radius:999px;flex:1 1;height:10px;overflow:hidden}.accuracy-bar-fill{background:linear-gradient(90deg,#1565c0,#42a5f5);border-radius:999px;height:100%;transition:width .6s cubic-bezier(.4,0,.2,1)}.accuracy-score-label{color:#1976d2;font-size:13px;font-weight:700;white-space:nowrap}.accuracy-stats{display:flex;flex-direction:column;gap:4px}.accuracy-stat{align-items:center;color:#64748b;color:var(--text-secondary);display:flex;font-size:11px;gap:5px}.accuracy-dot{border-radius:50%;flex-shrink:0;height:8px;width:8px}.dot-incorrect,.dot-missing{background:#42a5f5}.accuracy-stat-count{color:#1e293b;color:var(--text-primary);font-weight:600;margin-left:auto}.score-comprehension-section{flex:1 1;min-width:0}.comprehension-row{align-items:center;display:flex;gap:10px}.comprehension-donut-wrap{flex-shrink:0;height:68px;position:relative;width:68px}.comprehension-donut{background:conic-gradient(#42a5f5 calc(var(--comp)*1%),#e3eaff calc(var(--comp)*1%));border-radius:50%;height:68px;-webkit-mask:radial-gradient(farthest-side,#0000 58%,#000 59%);mask:radial-gradient(farthest-side,#0000 58%,#000 59%);width:68px}.comprehension-donut-center{align-items:center;display:flex;flex-direction:column;inset:0;justify-content:center;pointer-events:none;position:absolute}.comp-score-main{color:#1565c0;font-size:13px;font-weight:700;line-height:1.1}.comp-score-sub{color:#94a3b8;color:var(--text-tertiary);font-size:9px;line-height:1}.comprehension-keywords{display:flex;flex-direction:column;gap:4px}.comp-keyword-row{align-items:center;color:#64748b;color:var(--text-secondary);display:flex;font-size:11px;gap:5px}.comp-keyword-dot{background:#42a5f5;border-radius:50%;flex-shrink:0;height:7px;width:7px}.comp-keyword-name{flex:1 1;white-space:nowrap}.comp-keyword-score{color:#1e293b;color:var(--text-primary);font-weight:600;white-space:nowrap}.retry-notice{background:#fffbeb;background:var(--color-warning-bg);border:1px solid #ff6f00;border:1px solid var(--color-warning);border-radius:12px;border-radius:var(--radius-md);margin-top:20px;padding:20px;text-align:center}.retry-notice-message{color:#ff6f00;color:var(--color-warning-text);font-size:16px;font-weight:600;margin-bottom:16px}.retry-btn-group{display:flex;gap:12px;justify-content:center}.btn-retry-again{background:linear-gradient(135deg,#6366f1,#8b5cf6);background:var(--gradient-primary);border:none;border-radius:9999px;border-radius:var(--radius-full);cursor:pointer;font-size:15px;font-weight:600;padding:12px 28px;transition:all .2s}.btn-retry-again:hover{box-shadow:0 4px 12px #6366f14d;transform:translateY(-1px)}.btn-finish-here{background:#0000;border:1px solid #e2e8f0;border:1px solid var(--border-light);border-radius:9999px;border-radius:var(--radius-full);color:#64748b;color:var(--text-secondary);cursor:pointer;font-size:15px;font-weight:600;padding:12px 28px;transition:all .2s}.btn-finish-here:hover{background:#f8fafc;background:var(--bg-surface-hover)}.result-sidebar{display:flex;flex-direction:column;gap:8px}.attempt-analysis-label{background:#fff;background:var(--bg-surface);border-left:3px solid #6366f1;border-left:3px solid var(--color-primary);border-radius:8px;border-radius:var(--radius-sm);color:#6366f1;color:var(--color-primary);font-size:14px;font-weight:700;padding:8px 16px}.attempt-metrics-section{border-bottom:1px solid #e2e8f0;border-bottom:1px solid var(--border-light);display:flex;flex-direction:column;gap:16px;margin-bottom:24px;padding-bottom:24px}.attempt-metrics-section:last-child{border-bottom:none;margin-bottom:0;padding-bottom:0}.attempt-metrics-title{border-bottom:2px solid #6366f1;border-bottom:2px solid var(--color-primary);color:#6366f1;color:var(--color-primary);font-size:16px;font-weight:700;margin-bottom:16px;padding-bottom:8px}.science-encyclopedia{margin:0 auto;width:100%}.science-title{color:#1e293b;color:var(--text-primary);font-size:22px;font-weight:800;margin-bottom:8px;text-align:center}.science-instruction{color:#64748b;color:var(--text-secondary);font-size:14px;line-height:1.6;margin-bottom:24px;text-align:center}.keyword-card-grid{grid-gap:12px;display:grid;gap:12px;grid-template-columns:repeat(3,1fr);margin-bottom:24px}.keyword-card{align-items:center;background:#f8fafc;border:2px solid #e2e8f0;border:2px solid var(--border-light);border-radius:12px;border-radius:var(--radius-md);display:flex;flex-direction:column;padding:12px 8px;transition:border-color .2s,box-shadow .2s}.keyword-card:hover{border-color:#818cf8;border-color:var(--color-primary-light);box-shadow:0 2px 8px #6366f126}.keyword-card-img{border-radius:8px;border-radius:var(--radius-sm);height:100px;margin-bottom:8px;max-width:140px;object-fit:contain;width:100%}.keyword-card-label{background:linear-gradient(135deg,#eef2ff,#e0e7ff);border-radius:9999px;border-radius:var(--radius-full);color:#4f46e5;color:var(--color-primary-dark);font-size:15px;font-weight:700;padding:4px 16px}.question-bubble{align-items:flex-start;background:linear-gradient(135deg,#fff7ed,#fef3c7);border:1px solid #fbbf24;border-radius:12px;border-radius:var(--radius-md);display:flex;gap:10px;margin-bottom:20px;padding:14px 18px}.question-bubble-icon{flex-shrink:0;font-size:24px}.question-bubble p{color:#92400e;font-size:15px;font-weight:600;line-height:1.5;margin:0}.keyword-status-grid{align-items:center;display:flex;flex-wrap:wrap;gap:5px;justify-content:center;margin-bottom:20px}.keyword-status-badge{border-radius:16px;height:100px;overflow:hidden;padding:6px;width:192px}.keyword-status-badge ul{align-items:center;display:flex;list-style:none;width:100%}.keyword-status-badge ul li:first-of-type{height:88px;width:88px}.keyword-status-badge ul li:last-of-type{padding-left:10px}.keyword-status-badge ul li:first-of-type img{width:100%}.keyword-status-badge ul span{display:block}.keyword-status-label{font-size:11px;font-weight:700;letter-spacing:.5px;margin-bottom:2px;text-transform:uppercase}.keyword-status-word{font-size:24px;font-weight:800}.keyword-status-badge.kw-pass{background:#00920a;color:#fff}.keyword-status-badge.kw-supplement{background:#ff6f00;color:#fff}.keyword-status-badge.kw-misconception{background:red;color:#fff}.keyword-status-badge.kw-missing{background:#a3a3a3;color:#fff}.keyword-retry-hint{display:flex;flex-wrap:wrap;gap:8px;justify-content:center;margin-bottom:16px}.kw-retry-badge{align-items:center;border:1px solid;border-radius:9999px;border-radius:var(--radius-full);display:inline-flex;font-size:13px;gap:4px;padding:4px 12px}.kw-retry-badge.kw-supplement{background:#fffbeb;border-color:#f59e0b;color:#92400e}.kw-retry-badge.kw-misconception{background:#fef2f2;border-color:#ef4444;color:#991b1b}.kw-retry-badge.kw-missing{background:#f1f5f9;border-color:#94a3b8;color:#475569}.visual_wrap{background:url(/static/media/bg.d1191a92f2408f78af5b.png) top no-repeat #cda173;background-size:100%;height:760px;margin:0 auto;max-width:1072px;padding:20px 40px;position:relative;width:100%}.top-instruction-panel{align-items:center;background-color:#fff9;border-radius:16px;box-shadow:0 4px 12px #0000001a;display:flex;height:56px;justify-content:center;margin:0 auto;width:100%}.top-instruction-panel p{color:#6a2e01;font-size:24px;font-weight:700}.keyword-panel{padding-top:60px;position:absolute;right:0;top:0}.keyword-title{text-align:center;width:200px}.keyword-title img{height:auto;width:100%}.keyword-item{align-items:center;background-color:#ffebd0;border:4px solid #f74e0b;border-radius:16px;box-shadow:0 4px 12px #0000001a;display:flex;height:100px;justify-content:left;margin-bottom:5px;width:200px}.keyword-text{color:#b24c00;font-size:24px;font-weight:700;margin:0 auto}.keyword-img-box{height:88px;margin-left:2px;width:88px}.keyword-img-box img{height:auto!important;width:100%!important}.main-interaction-area{position:relative;width:100%}.character-speech-bubble{align-items:center;background-color:#fff;border-radius:40px;box-shadow:0 6px 16px #00000026;display:inline-flex;justify-content:center;left:80px;max-width:250px;padding:24px 36px;position:absolute;top:80px;z-index:10}.character-speech-bubble p{color:#333;font-size:26px;font-weight:800;letter-spacing:-.5px;margin:0;text-align:center;word-break:keep-all}.character-speech-bubble:after{border-color:#0000 #0000 #0000 #fff;border-style:solid;border-width:14px 0 14px 20px;content:"";position:absolute;right:-16px;top:70%;transform:translateY(-50%)}.character-display-area{left:50%;position:absolute;top:70px;transform:translateX(-50%);width:300px;z-index:1}.character-display-area img{height:auto;width:100%}.bottom-input-area{bottom:20px;left:50%;max-width:992px;position:absolute;transform:translateX(-50%);width:100%}.bottom-input-area .input-box{background-color:#fff;border:4px solid #ff4848;border-radius:0 20px 20px 20px;box-shadow:0 4px 12px #0000001a;height:178px;padding:0 10px;width:100%}.bottom-input-area .input-box textarea{border:none;border-radius:0;font-size:24px;font-weight:700;width:75%}.bottom-input-area .input-box textarea:focus{border:none;box-shadow:none;outline:none}.input-tabs{align-items:flex-end;display:flex}.bottom-input-area .input-tabs .tab-btn{background-color:#cd2727;border:none;border-radius:20px 20px 0 0;color:#ffffff80;cursor:pointer;font-size:24px;font-weight:700;height:48px;margin-right:2px;width:200px}.bottom-input-area .input-tabs .tab-btn.active{background-color:#ff4747;color:#fff;height:56px}.bottom-input-area .submit-btn-wrap{position:absolute;right:20px;top:120px}.bottom-input-area .submit-btn-wrap .btn-submit{background-color:#379b34;border:none;border-bottom:10px solid #085706;border-radius:20px;color:#fff;cursor:pointer;font-size:28px;font-weight:700;height:78px;width:200px}.result-layout{background:url(/static/media/bg.d1191a92f2408f78af5b.png) top no-repeat #cda173;background-size:100%;display:flex;overflow:hidden;padding:65px 40px;position:relative}.retry-notice{background:none;border:none;margin:0;padding:0 40px 0 0;width:310px}.retry-notice .character-display-area{align-items:flex-end;display:flex;height:380px;overflow:hidden;position:relative;top:auto;width:100%}.retry-notice .character-display-area img{margin-bottom:-30px;max-height:100%;object-fit:contain;object-position:bottom;vertical-align:bottom}.retry-notice-message{align-items:center;background-color:#fff;border-radius:40px;box-shadow:0 6px 16px #00000026;color:#333;display:inline-flex;font-size:26px;font-weight:800;justify-content:center;letter-spacing:-.5px;margin:0;overflow-wrap:break-word;padding:24px 36px;position:relative;word-break:keep-all}.retry-notice-message:after{border-color:#fff #0000 #0000;border-style:solid;border-width:20px 14px 0;content:"";left:50%;position:absolute;top:100%;transform:translateX(-50%)}.retry-btn-group{display:block;position:relative}.btn-retry-again{background:#4a47ff;border-bottom:4px solid #0b08af;margin-bottom:10px}.btn-finish-here,.btn-retry-again{border-radius:20px;color:#fff;font-size:24px;font-weight:700;height:72px;width:270px}.btn-finish-here{background:#a6acff!important;border:none;border-bottom:4px solid #5a60ac}.btn-finish-here:hover{box-shadow:0 4px 12px #6366f14d;transform:translateY(-1px)}.result-main{background:#fff;border:4px solid #7ab0e5;border-radius:20px;display:block;height:660px;overflow:hidden;overflow-y:auto;padding:30px;width:680px}.result-main::-webkit-scrollbar{width:20px}.result-main::-webkit-scrollbar-track{background:#0000;margin:16px 0}.result-main::-webkit-scrollbar-thumb{background-clip:padding-box;background-color:#dbeafe;border:6px solid #fff;border-radius:10px}.result-main::-webkit-scrollbar-thumb:hover{background-clip:padding-box;background-color:#bfdbfe;border:6px solid #fff}.legend{border:none;box-shadow:none;justify-content:flex-end;margin-bottom:20px;padding:0}.title_result{left:616px;position:absolute;top:30px}.highlight{transition:color .15s ease;transition:color var(--transition-fast)}.bottom-input-area .input-box{position:relative}.bottom-input-area .tab-btn:disabled{cursor:not-allowed;opacity:.5}.bottom-input-area .submit-btn-wrap{align-items:stretch;display:flex;flex-direction:column;gap:8px;top:50%;transform:translateY(-50%)}.bottom-input-area .submit-btn-wrap .btn-submit:disabled{background-color:#9ca3af;border-bottom-color:#6b7280;cursor:not-allowed}.bottom-input-area .submit-btn-wrap .btn-rerecord-inline{background-color:#cd2727;border:none;border-bottom:10px solid #8b1a1a;border-radius:20px;color:#fff;cursor:pointer;font-size:28px;font-weight:700;height:78px;width:200px}.bottom-input-area .submit-btn-wrap .btn-rerecord-inline:hover{background-color:#b82222}.voice-input-area-inline{align-items:center;display:flex;flex-direction:column;justify-content:center;min-height:150px}.visual-error{bottom:5px}.visual-error,.visual_wrap .keyword-retry-hint{left:50%;position:absolute;transform:translateX(-50%);z-index:20}.visual_wrap .keyword-retry-hint{top:82px}.attempt-result-section{margin-bottom:24px}.attempt-result-title{border-bottom:2px solid #6366f1;border-bottom:2px solid var(--color-primary);color:#6366f1;color:var(--color-primary);font-size:16px;font-weight:700;margin-bottom:12px;padding-bottom:8px}
/*# sourceMappingURL=main.3d402454.css.map*/