.mic-test-card{max-width:520px}.mic-test-card h1{font-size:24px;margin-bottom:8px}.mic-test-instructions{background:#0f172a;border-radius:10px;padding:16px;margin:20px 0;text-align:left}.mic-test-instructions p{color:#94a3b8;font-size:14px;line-height:1.6;margin:0}.mic-test-recording{margin:20px 0}.mic-test-recording p{color:#94a3b8;margin:16px 0}.mic-test-result{margin:20px 0}.mic-test-result>p{color:#94a3b8;margin-bottom:12px}.mic-test-result audio{width:100%;margin-bottom:16px}.mic-test-actions{display:flex;gap:12px}.mic-test-actions .btn{flex:1}.instructions-card{max-width:640px;text-align:left}.instructions-card h1{text-align:center;font-size:22px;margin-bottom:4px}.instructions-subtitle{text-align:center;color:#94a3b8;font-size:14px;letter-spacing:.2em;margin-bottom:24px}.instructions-section{background:#0f172a;border-radius:10px;padding:16px 20px;margin-bottom:16px}.instructions-section h3{font-size:14px;margin-bottom:12px;color:#e2e8f0}.instructions-section ol,.instructions-section ul{margin:0;padding-left:20px;color:#94a3b8;font-size:13px;line-height:1.8;text-align:left}.instructions-section li{margin-bottom:4px}.instructions-card>.btn{margin-top:8px}*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,PingFang SC,Microsoft YaHei,sans-serif;background:#0f172a;color:#e2e8f0;min-height:100vh}.page{min-height:100vh;display:flex;align-items:center;justify-content:center}.page.center{flex-direction:column}.page.full-width{justify-content:flex-start}.card{background:#1e293b;border-radius:16px;padding:40px;max-width:520px;width:100%;box-shadow:0 4px 24px #0000004d;text-align:center}.card h1{font-size:24px;margin-bottom:8px;color:#f8fafc}.card h2{font-size:20px;margin-bottom:16px;color:#f8fafc}.subtitle{color:#94a3b8;margin-bottom:24px}.name-hint{font-size:13px;color:#64748b;margin-bottom:10px}.name-hint strong{color:#f59e0b}.candidate-name-display{font-size:28px;color:#f8fafc;background:#0f172a;padding:16px 24px;border-radius:12px;margin:20px 0}.input{width:100%;padding:10px 14px;border:1px solid #334155;border-radius:8px;background:#0f172a;color:#e2e8f0;font-size:14px;margin-bottom:12px;outline:none;transition:border-color .2s}.input:focus{border-color:#3b82f6}.select{cursor:pointer}form{width:100%}button[type=submit]{margin-top:4px}.btn{padding:10px 20px;border-radius:8px;border:none;cursor:pointer;font-size:14px;font-weight:500;transition:all .2s;width:100%}.btn.sm{padding:6px 12px;font-size:12px;width:auto}.btn.primary{background:#3b82f6;color:#fff}.btn.primary:hover{background:#2563eb}.btn.danger{background:#ef4444;color:#fff}.btn.danger:hover{background:#dc2626}.btn.outline{background:transparent;color:#94a3b8;border:1px solid #334155}.btn.outline:hover{border-color:#3b82f6;color:#3b82f6}.btn.outline.danger{color:#ef4444;border-color:#ef4444}.btn:disabled{opacity:.5;cursor:not-allowed}.badge{display:inline-block;padding:2px 8px;border-radius:6px;font-size:12px;font-weight:500}.badge.easy{background:#22c55e22;color:#22c55e}.badge.medium{background:#f59e0b22;color:#f59e0b}.badge.hard{background:#ef444422;color:#ef4444}.badge-blue{background:#3b82f622;color:#3b82f6}.badge-green{background:#22c55e22;color:#22c55e}.badge-gray{background:#334155;color:#94a3b8}.countdown-card .countdown-number{font-size:80px;font-weight:700;color:#3b82f6;line-height:1;margin:24px 0}.recording-indicator{display:flex;align-items:center;justify-content:center;gap:8px;color:#ef4444;font-weight:600;margin-bottom:16px}.recording-indicator .dot{width:12px;height:12px;background:#ef4444;border-radius:50%;animation:blink 1s infinite}@keyframes blink{0%,to{opacity:1}50%{opacity:.3}}.direction-label{font-size:16px;color:#94a3b8;margin-bottom:24px}.source-timer{margin-bottom:20px}.source-timer-bar{height:6px;background:#334155;border-radius:3px;overflow:hidden;margin-bottom:6px}.source-timer-fill{height:100%;background:linear-gradient(90deg,#3b82f6,#60a5fa);border-radius:3px;transition:width .25s linear}.source-timer-text{display:flex;justify-content:space-between;font-size:13px;color:#64748b}.audio-preview{margin:16px 0}.audio-preview p{font-size:13px;color:#64748b;margin-bottom:8px}.audio-preview audio{width:100%}.rest-options{display:flex;gap:12px;margin-top:24px}.rest-options .btn{flex:1}.loading-dots{display:flex;justify-content:center;gap:6px;margin:24px 0}.loading-dots span{width:8px;height:8px;background:#3b82f6;border-radius:50%;animation:dot-bounce 1.4s infinite ease-in-out both}.loading-dots span:nth-child(1){animation-delay:-.32s}.loading-dots span:nth-child(2){animation-delay:-.16s}@keyframes dot-bounce{0%,80%,to{transform:scale(0)}40%{transform:scale(1)}}.admin-layout{display:flex;min-height:100vh}.sidebar{width:220px;background:#1e293b;border-right:1px solid #334155;padding:24px 16px;display:flex;flex-direction:column;gap:8px;flex-shrink:0}.logo{font-size:16px;font-weight:700;color:#f8fafc;margin-bottom:24px;text-align:center}.nav-btn{width:100%;padding:10px 14px;border-radius:8px;border:none;background:transparent;color:#94a3b8;cursor:pointer;font-size:14px;text-align:left;transition:all .2s}.nav-btn:hover{background:#334155;color:#e2e8f0}.nav-btn.active{background:#3b82f6;color:#fff}.material-stats{margin-top:auto;padding-top:16px;border-top:1px solid #334155}.stats-title{font-size:11px;color:#64748b;text-transform:uppercase;letter-spacing:.05em;margin-bottom:8px}.stats-row{display:flex;flex-direction:column;gap:4px;margin-bottom:10px}.stats-dir{font-size:12px;color:#94a3b8}.stats-count{font-size:11px;color:#475569;padding:2px 6px;border-radius:4px}.stats-count.has-material{color:#22c55e;background:#22c55e22}.main-content{flex:1;padding:24px;overflow-y:auto}.two-col{display:grid;grid-template-columns:1fr 1fr;gap:20px;height:calc(100vh - 48px)}.panel{background:#1e293b;border-radius:12px;padding:20px;overflow-y:auto}.panel.full{grid-column:1 / -1}.panel h2{font-size:16px;margin-bottom:16px;color:#f8fafc;border-bottom:1px solid #334155;padding-bottom:12px}.panel h3{font-size:14px;margin:16px 0 8px;color:#e2e8f0}.create-form{display:flex;gap:8px;margin-bottom:16px}.create-form .input{flex:1;margin-bottom:0}.create-form .btn{width:auto;white-space:nowrap}.session-list{display:flex;flex-direction:column;gap:8px}.session-item{padding:12px;border-radius:8px;border:1px solid #334155;cursor:pointer;transition:all .2s}.session-item:hover{border-color:#3b82f6}.session-item.selected{border-color:#3b82f6;background:#3b82f611}.session-info{display:flex;justify-content:space-between;align-items:center;margin-bottom:4px}.session-info strong{color:#f8fafc}.session-meta{display:flex;gap:12px;font-size:12px;color:#64748b}.detail-header{display:flex;align-items:center;gap:10px;margin-bottom:8px}.detail-header h2{margin:0}.detail-meta{font-size:13px;color:#64748b;margin-bottom:12px}.share-link{display:flex;gap:8px;align-items:center;margin-bottom:16px;background:#0f172a;padding:8px;border-radius:8px}.share-link span{font-size:12px;color:#64748b;white-space:nowrap}.link-input{flex:1;font-size:12px;margin-bottom:0;background:transparent;border-color:#334155}.rounds-section{margin-bottom:16px}.round-card{background:#0f172a;border-radius:8px;padding:14px;margin-bottom:10px}.round-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px;font-size:13px;color:#94a3b8}.total-score{font-size:36px;font-weight:700;color:#3b82f6;margin-bottom:12px}.total-score small{font-size:16px;color:#64748b;font-weight:400}.score-details{display:grid;grid-template-columns:1fr 1fr;gap:8px}.score-item{background:#1e293b;padding:8px 10px;border-radius:6px;display:flex;justify-content:space-between;font-size:13px}.score-item span{color:#94a3b8}.score-item strong{color:#f8fafc}.transcription-detail{margin-top:10px}.transcription-detail summary{cursor:pointer;color:#64748b;font-size:12px}.transcription-text{margin-top:6px;font-size:13px;color:#94a3b8;background:#1e293b;padding:8px;border-radius:6px;white-space:pre-wrap}.ai-comment{margin-top:10px;font-size:13px;color:#94a3b8;background:#1e293b;padding:10px;border-radius:6px;border-left:3px solid #3b82f6}.round-pending p{color:#64748b;font-size:13px;margin-bottom:8px}.source-input-group{display:flex;gap:8px;margin-top:8px}.source-input-group .input{flex:1;font-size:12px;margin-bottom:0}.source-input-group .btn{width:auto;white-space:nowrap}.admin-actions{display:flex;gap:8px;margin-top:16px;border-top:1px solid #334155;padding-top:16px}.admin-actions .btn{flex:1}.download-row{display:flex;justify-content:flex-start;margin-top:6px}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:100}.modal{background:#1e293b;border-radius:12px;padding:24px;width:560px;max-height:80vh;overflow-y:auto}.modal h3{color:#f8fafc;margin-bottom:16px}.modal h4{color:#94a3b8;font-size:13px;margin:12px 0 8px}.modal-actions{display:flex;gap:8px;margin-top:20px;justify-content:flex-end}.modal-actions .btn{width:auto}.picker-row{display:flex;align-items:center;gap:12px;margin-bottom:12px}.picker-row label{font-size:13px;color:#94a3b8;white-space:nowrap}.picker-row .select{width:auto;margin-bottom:0}.picker-list{display:flex;flex-direction:column;gap:6px;max-height:160px;overflow-y:auto}.picker-item{padding:10px 14px;border-radius:8px;border:1px solid #334155;cursor:pointer;display:flex;justify-content:space-between;align-items:center;font-size:13px;color:#94a3b8;transition:all .15s}.picker-item:hover{border-color:#3b82f6;color:#e2e8f0}.picker-item.selected{border-color:#3b82f6;background:#3b82f611;color:#e2e8f0}.picker-badge{font-size:11px;color:#22c55e;background:#22c55e22;padding:2px 6px;border-radius:4px}.upload-form{display:flex;gap:8px;margin-bottom:12px;flex-wrap:wrap;align-items:center}.upload-form input[type=file]{color:#94a3b8;font-size:13px}.upload-form .btn{width:auto}.source-text-upload{margin-bottom:20px}.source-text-label{display:block;font-size:13px;color:#94a3b8;margin-bottom:8px}.material-source-text{margin-top:6px}.material-source-text summary{cursor:pointer;color:#64748b;font-size:12px}.material-source-text p{margin-top:4px;font-size:12px;color:#94a3b8;background:#1e293b;padding:8px;border-radius:6px;white-space:pre-wrap}.material-groups{display:grid;grid-template-columns:1fr 1fr;gap:24px}.group-title{font-size:15px;color:#f8fafc;margin-bottom:16px;border-bottom:1px solid #334155;padding-bottom:8px}.material-group{margin-bottom:16px}.group-sub{font-size:13px;margin-bottom:8px;font-weight:500}.group-sub.easy{color:#22c55e}.group-sub.medium{color:#f59e0b}.group-sub.hard{color:#ef4444}.material-list{display:flex;flex-direction:column;gap:8px}.material-item{display:flex;justify-content:space-between;align-items:center;background:#0f172a;padding:8px 12px;border-radius:6px;font-size:13px;color:#94a3b8;gap:12px}.material-item>span{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.material-item>div{display:flex;align-items:center;gap:8px;flex-shrink:0}.empty-msg{color:#475569;font-size:13px;text-align:center;padding:20px}.error-msg{color:#ef4444;font-size:13px;text-align:center;padding:12px}.manual-score-section{margin-top:12px}.manual-score-section summary{cursor:pointer;color:#64748b;font-size:13px;padding:4px 0;-webkit-user-select:none;user-select:none}.manual-score-section summary:hover{color:#94a3b8}.manual-form{padding-top:10px;display:flex;flex-direction:column;gap:6px}.manual-form label{font-size:12px;color:#94a3b8;margin-top:4px}.manual-form textarea.input{resize:vertical;font-size:13px}.manual-form .btn{margin-top:4px}.manual-tip{font-size:11px;color:#475569;line-height:1.5}.source-text-hint{display:flex;align-items:center;gap:8px;margin-bottom:6px}.source-text-hint span{font-size:12px;color:#22c55e}.source-text-hint .btn{width:auto;margin:0}
