*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--blue: #0071e3;--blue-light: #f0f7ff;--bg: #f5f5f7;--white: #ffffff;--text: #1d1d1f;--text-secondary: #6e6e73;--border: #e0e0e5;--border-hover: #adadb8;--shadow: 0 1px 3px rgba(0,0,0,.08);--shadow-md: 0 4px 12px rgba(0,0,0,.1);--radius: 10px;--radius-sm: 6px;--font: -apple-system, BlinkMacSystemFont, "Apple SD Gothic Neo", "Pretendard", "Noto Sans KR", sans-serif}html,body,#root{height:100%;font-family:var(--font);background:var(--bg);color:var(--text);font-size:14px;line-height:1.5;-webkit-font-smoothing:antialiased}.app-shell{display:flex;flex-direction:column;height:100vh;overflow:hidden}.top-bar{background:#ffffffd9;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-bottom:1px solid var(--border);display:flex;align-items:center;padding:0 20px;height:48px;flex-shrink:0;position:sticky;top:0;z-index:100;gap:4px}.top-bar-title{font-size:15px;font-weight:600;color:var(--text);margin-right:20px;white-space:nowrap}.tab-btn{background:transparent;border:none;border-bottom:2px solid transparent;color:var(--text-secondary);padding:10px 14px;cursor:pointer;font-size:13px;font-weight:400;font-family:var(--font);transition:all .15s;white-space:nowrap;height:48px;display:flex;align-items:center;gap:4px}.tab-btn:hover{color:var(--text)}.tab-btn.active{color:var(--blue);border-bottom-color:var(--blue);font-weight:500}.body-area{display:flex;flex:1;overflow:hidden}.sidebar{width:190px;flex-shrink:0;border-right:1px solid var(--border);background:#fafafa;display:flex;flex-direction:column;overflow-y:auto;overflow-x:hidden}.sidebar-section{padding:10px 8px 4px;font-size:10px;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em}.src-item{padding:8px 12px;cursor:pointer;font-size:12px;color:#555;border-left:2px solid transparent;display:flex;justify-content:space-between;align-items:center;transition:background .1s;gap:6px}.src-item:hover{background:var(--white)}.src-item.active{color:var(--blue);border-left-color:var(--blue);background:var(--white);font-weight:500}.src-item-label{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.badge{font-size:10px;background:#e8e8ed;padding:1px 5px;border-radius:4px;color:var(--text-secondary);flex-shrink:0}.src-item.active .badge{background:#daeaff;color:var(--blue)}.sidebar-bottom{margin-top:auto;padding:10px 8px;border-top:1px solid var(--border)}.main-content{flex:1;overflow-y:auto;overflow-x:hidden;padding:20px;display:flex;flex-direction:column;gap:16px}.card{background:var(--white);border:1px solid var(--border);border-radius:var(--radius);padding:14px 16px;box-shadow:var(--shadow)}.card-title{font-size:13px;font-weight:600;color:var(--text);margin-bottom:10px}.btn{display:inline-flex;align-items:center;justify-content:center;gap:5px;padding:7px 14px;border-radius:var(--radius-sm);border:1px solid var(--border);background:var(--white);color:var(--text);font-size:13px;font-family:var(--font);cursor:pointer;transition:all .15s;font-weight:400;white-space:nowrap}.btn:hover{border-color:var(--border-hover);background:#f9f9f9}.btn:active{transform:scale(.98)}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:var(--blue);color:#fff;border-color:var(--blue)}.btn-primary:hover{background:#005ec4;border-color:#005ec4}.btn-danger{color:#d32f2f;border-color:#ffcdd2}.btn-danger:hover{background:#fff5f5;border-color:#ef9a9a}.btn-sm{padding:4px 10px;font-size:11px}.btn-icon{padding:5px 8px;font-size:13px}.filter-bar{display:flex;gap:8px;flex-wrap:wrap;align-items:center}.filter-select{padding:6px 10px;border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--white);color:var(--text);font-size:12px;font-family:var(--font);cursor:pointer;outline:none;transition:border-color .15s}.filter-select:focus{border-color:var(--blue)}.search-input{padding:6px 10px;border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--white);color:var(--text);font-size:12px;font-family:var(--font);outline:none;width:180px;transition:border-color .15s}.search-input:focus{border-color:var(--blue);width:220px}.search-input::placeholder{color:#aaa}.upload-area{border:2px dashed var(--border);border-radius:var(--radius);padding:28px 20px;text-align:center;cursor:pointer;transition:all .15s;background:var(--white)}.upload-area:hover,.upload-area.drag-over{border-color:var(--blue);background:var(--blue-light)}.upload-area-icon{font-size:32px;margin-bottom:8px}.upload-area-text{font-size:13px;color:var(--text-secondary)}.upload-area-hint{font-size:11px;color:#aaa;margin-top:4px}.progress-bar-wrap{background:#eee;border-radius:4px;height:6px;overflow:hidden}.progress-bar{height:100%;background:var(--blue);border-radius:4px;transition:width .3s ease}.question-card{background:var(--white);border:1px solid var(--border);border-radius:var(--radius);padding:14px 16px;transition:border-color .1s}.question-card:hover{border-color:var(--border-hover)}.question-card.selected{border-color:var(--blue);background:var(--blue-light)}.question-card-header{display:flex;align-items:flex-start;gap:8px;margin-bottom:8px}.question-num{font-size:11px;font-weight:600;color:var(--text-secondary);width:24px;flex-shrink:0;padding-top:1px}.question-text{font-size:13px;color:var(--text);flex:1;line-height:1.6}.passage-preview{font-size:11px;color:var(--text-secondary);background:#f8f8fa;border-radius:var(--radius-sm);padding:6px 8px;margin-bottom:8px;line-height:1.5;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}.options-list{list-style:none;display:flex;flex-direction:column;gap:3px;margin:8px 0}.option-item{font-size:12px;color:var(--text-secondary);padding:3px 6px;border-radius:4px}.option-item.correct{color:#0a7d3e;background:#e8f5e9;font-weight:500}.explanation-box{font-size:11px;color:var(--text-secondary);background:#fffbe6;border-left:3px solid #ffc107;padding:6px 8px;border-radius:0 var(--radius-sm) var(--radius-sm) 0;margin-top:8px;line-height:1.5}.type-badge{display:inline-flex;align-items:center;padding:2px 7px;border-radius:10px;font-size:10px;font-weight:600;background:#e8e8ed;color:var(--text-secondary);white-space:nowrap}.type-badge.main_idea{background:#e3f2fd;color:#1565c0}.type-badge.title{background:#f3e5f5;color:#6a1b9a}.type-badge.blank{background:#e8f5e9;color:#2e7d32}.type-badge.order{background:#fff3e0;color:#e65100}.type-badge.insert{background:#fce4ec;color:#880e4f}.type-badge.grammar{background:#e0f2f1;color:#00695c}.type-badge.summary{background:#ede7f6;color:#4527a0}.type-badge.vocabulary{background:#e1f5fe;color:#01579b}.type-badge.content_match{background:#fbe9e7;color:#bf360c}.type-badge.grammar_choice{background:#e0f2f1;color:#00695c}.type-badge.vocabulary_choice{background:#e1f5fe;color:#01579b}.type-badge.irrelevant_sentence{background:#fce4ec;color:#880e4f}.type-badge.connector{background:#f3e5f5;color:#6a1b9a}.type-badge.summary_completion{background:#ede7f6;color:#4527a0}.type-badge.emotion{background:#fff3e0;color:#e65100}.type-badge.reference{background:#e8eaf6;color:#283593}.type-badge.chart{background:#e8f5e9;color:#1b5e20}.type-badge.ai{background:#fff8e1;color:#f57f17}.toggle-wrap{display:flex;align-items:center;gap:8px;cursor:pointer;-webkit-user-select:none;user-select:none}.toggle-track{width:36px;height:20px;background:#ccc;border-radius:10px;position:relative;transition:background .2s;flex-shrink:0}.toggle-track.on{background:var(--blue)}.toggle-thumb{width:16px;height:16px;background:#fff;border-radius:50%;position:absolute;top:2px;left:2px;box-shadow:0 1px 3px #0003;transition:left .2s}.toggle-track.on .toggle-thumb{left:18px}.toggle-label{font-size:13px;color:var(--text)}.chk{width:18px;height:18px;border-radius:4px;flex-shrink:0;border:1.5px solid #ccc;background:var(--bg);display:flex;align-items:center;justify-content:center;font-size:11px;cursor:pointer;transition:all .1s}.chk.on{background:var(--blue);border-color:var(--blue);color:#fff}.form-group{display:flex;flex-direction:column;gap:5px}.form-label{font-size:12px;font-weight:600;color:var(--text-secondary)}.form-input,.form-textarea{padding:8px 10px;border:1px solid var(--border);border-radius:var(--radius-sm);font-size:13px;font-family:var(--font);color:var(--text);outline:none;transition:border-color .15s;background:var(--white)}.form-input:focus,.form-textarea:focus{border-color:var(--blue)}.form-textarea{resize:vertical;line-height:1.6}.step-bar{display:flex;align-items:center;gap:0;margin-bottom:16px}.step-item{display:flex;align-items:center;gap:6px;font-size:12px;color:var(--text-secondary)}.step-item.active{color:var(--blue);font-weight:600}.step-item.done{color:#0a7d3e}.step-circle{width:22px;height:22px;border-radius:50%;border:1.5px solid var(--border);display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:600;background:var(--white)}.step-item.active .step-circle{border-color:var(--blue);color:var(--blue);background:var(--blue-light)}.step-item.done .step-circle{border-color:#0a7d3e;color:#fff;background:#0a7d3e}.step-line{width:28px;height:1px;background:var(--border);flex-shrink:0}.type-chips{display:flex;flex-wrap:wrap;gap:6px}.type-chip{padding:5px 12px;border-radius:16px;border:1.5px solid var(--border);font-size:12px;cursor:pointer;background:var(--white);color:var(--text-secondary);transition:all .1s;-webkit-user-select:none;user-select:none}.type-chip:hover{border-color:var(--blue);color:var(--blue)}.type-chip.selected{border-color:var(--blue);background:var(--blue-light);color:var(--blue);font-weight:500}.data-table{width:100%;border-collapse:collapse;font-size:12px}.data-table th{text-align:left;padding:8px 10px;border-bottom:1.5px solid var(--border);color:var(--text-secondary);font-weight:600;font-size:11px;text-transform:uppercase;letter-spacing:.04em;background:#fafafa}.data-table td{padding:8px 10px;border-bottom:1px solid var(--border);color:var(--text);vertical-align:top}.data-table tr:last-child td{border-bottom:none}.data-table tr:hover td{background:#f8f8fa}.loading{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px;padding:40px;color:var(--text-secondary);font-size:13px}.spinner{width:24px;height:24px;border:2px solid var(--border);border-top-color:var(--blue);border-radius:50%;animation:spin .6s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.empty-state{text-align:center;padding:48px 20px;color:var(--text-secondary)}.empty-state-icon{font-size:40px;margin-bottom:12px}.empty-state-text{font-size:14px;font-weight:500;margin-bottom:4px;color:var(--text)}.empty-state-hint{font-size:12px}.alert{padding:10px 14px;border-radius:var(--radius-sm);font-size:12px;line-height:1.5;display:flex;align-items:flex-start;gap:8px}.alert-error{background:#fff5f5;border:1px solid #ffcdd2;color:#c62828}.alert-success{background:#f1f8e9;border:1px solid #c5e1a5;color:#2e7d32}.alert-info{background:var(--blue-light);border:1px solid #bbdefb;color:#1565c0}.divider{height:1px;background:var(--border);margin:12px 0}.section-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px;gap:8px}.section-title{font-size:14px;font-weight:600;color:var(--text)}.col-2{display:grid;grid-template-columns:1fr 1fr;gap:12px}.passage-full{font-size:12px;line-height:1.8;color:var(--text);background:#fafafa;border:1px solid var(--border);border-radius:var(--radius-sm);padding:10px 12px;margin-bottom:8px;white-space:pre-wrap}@page{margin-top:0;margin-bottom:0}@media print{.no-print{display:none!important}body{background:#fff;font-size:10pt}.app-shell{height:auto}.top-bar,.sidebar{display:none!important}.main-content{padding:12mm 14mm;overflow:visible}.print-header{text-align:center;margin-bottom:16pt}.print-title{font-size:16pt;font-weight:700;margin-bottom:4pt}.print-meta{font-size:9pt;color:#666}body.print-exam .exam-columns{column-count:2;column-gap:20pt;column-rule:1px solid #ccc}.question-card{break-inside:avoid;page-break-inside:avoid;border:none;border-bottom:1px solid #eee;border-radius:0;padding:8pt 0;margin-bottom:6pt;box-shadow:none;background:#fff}.question-card.selected{background:#fff;border-color:#eee}.card{border:none;box-shadow:none;padding:0}.passage-preview{-webkit-line-clamp:unset;display:block;background:none;padding:0;margin-bottom:4pt}.answer-sheet{break-before:page}}.upload-mode-tabs{display:flex;gap:2px;background:var(--bg);border:1px solid var(--border);border-radius:var(--radius-sm);padding:2px}.upload-mode-btn{background:transparent;border:none;border-radius:4px;padding:5px 12px;font-size:12px;font-family:var(--font);color:var(--text-secondary);cursor:pointer;transition:all .12s;white-space:nowrap}.upload-mode-btn.active{background:var(--white);color:var(--text);font-weight:600;box-shadow:0 1px 3px #00000014}.wb-type-chip{display:flex;align-items:center;gap:8px;padding:8px 10px;border:1.5px solid var(--border);border-radius:var(--radius-sm);cursor:pointer;font-size:12px;background:var(--white);color:var(--text);transition:all .12s;-webkit-user-select:none;user-select:none}.wb-type-chip:hover{border-color:var(--blue)}.wb-type-chip.on{border-color:var(--blue);background:var(--blue-light);color:var(--blue)}.wb-type-num{font-size:15px;width:22px;text-align:center;flex-shrink:0}.wb-progress-wrap{position:relative;height:34px;border-radius:var(--radius-sm);overflow:hidden;background:#e8e8ed;margin-top:10px}.wb-progress-bar-inner{position:absolute;top:0;left:0;height:100%;background:var(--blue);transition:width .3s ease}.wb-progress-label{position:relative;z-index:1;font-size:11px;color:var(--white);padding:0 12px;line-height:34px;display:block;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.wb-passage-block{margin-bottom:28px}.wb-passage-label{font-size:12px;font-weight:700;color:#1e3a5f;border-left:4px solid #1e3a5f;padding:4px 10px;background:#eef2f8;border-radius:0 4px 4px 0;margin-bottom:12px}.wb-section{border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;margin-bottom:14px}.wb-section:last-child{margin-bottom:0}.wb-section-head{background:#1e3a5f;color:#fff;display:flex;align-items:center;gap:10px;padding:8px 14px;font-size:13px;font-weight:600}.wb-section-num{width:24px;height:24px;border-radius:50%;background:#fff3;display:flex;align-items:center;justify-content:center;font-size:13px;flex-shrink:0}.wb-section-body{padding:12px 14px}.wb-pt-table{width:100%;border-collapse:collapse;font-size:12px;line-height:1.65}.wb-pt-table th{background:#f5f5f7;padding:6px 8px;text-align:left;font-size:11px;font-weight:600;color:var(--text-secondary);border:1px solid var(--border)}.wb-pt-table td{padding:7px 8px;border:1px solid var(--border);vertical-align:top}.wb-pt-num{text-align:center;color:var(--text-secondary);font-size:11px;width:32px;font-weight:600}.wb-pt-eng{color:var(--text)}.wb-pt-kor{color:#333;min-width:140px}.wb-items{display:flex;flex-direction:column;gap:10px}.wb-item{display:flex;gap:10px;align-items:flex-start}.wb-item-num{width:24px;height:24px;border-radius:50%;background:#1e3a5f;color:#fff;font-size:11px;font-weight:700;display:flex;align-items:center;justify-content:center;flex-shrink:0;margin-top:1px}.wb-item-num-inline{display:inline-flex;width:20px;height:20px;border-radius:50%;background:#1e3a5f;color:#fff;font-size:10px;font-weight:700;align-items:center;justify-content:center;margin-right:4px;vertical-align:middle;flex-shrink:0}.wb-item-body{flex:1;min-width:0}.wb-item-q{font-size:12px;color:var(--text);line-height:1.65;margin-bottom:4px}.wb-item-error{display:flex;gap:10px;align-items:flex-start;padding:6px 0;border-bottom:1px dashed var(--border)}.wb-item-error:last-child{border-bottom:none}.wb-ox-boxes{display:flex;flex-direction:column;gap:3px;flex-shrink:0}.wb-ox-box{width:22px;height:22px;border:1.5px solid #aaa;border-radius:4px;display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:700;color:var(--text-secondary)}.wb-ans-row{display:flex;align-items:center;gap:6px;margin-top:3px;min-height:18px;flex-wrap:wrap}.wb-ans-arrow{font-size:10px;color:#1e3a5f;flex-shrink:0}.wb-ans-text{font-size:11px;color:#1565c0;font-weight:500}.wb-err-text{color:#c62828;font-size:11px;font-weight:500}.wb-ok-text{color:#2e7d32;font-size:11px;font-weight:500}.wb-choice{color:#c62828;font-weight:600;font-size:12px}.wb-blank-line{display:none}@media print{body.print-wb .wb-ans,body.print-wb .wb-ans-arrow{display:none!important}body.print-wb .wb-blank-line{display:block!important;width:100%;border-bottom:1px solid #999;height:18px;margin-top:2px}body.print-wb .wb-pt-kor .wb-ans{display:none!important}body.print-wb .wb-pt-kor .wb-blank-line{display:block!important;border-bottom:1px solid #999;height:16px;margin-top:2px}body.print-ak .wb-blank-line{display:none!important}body.print-ak .wb-ans,body.print-ak .wb-ans-arrow{display:inline!important}body.print-ak .wb-ans-row{display:flex!important}.wb-section,.wb-passage-block{break-inside:avoid}}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:#ccc;border-radius:3px}::-webkit-scrollbar-thumb:hover{background:#aaa}.vocab-table{width:100%;border-collapse:collapse;font-size:12px}.vocab-table th{background:#f5f5f7;padding:8px 10px;text-align:left;font-size:11px;font-weight:600;color:var(--text-secondary);border-bottom:1.5px solid var(--border)}.vocab-table td{padding:7px 10px;border-bottom:1px solid var(--border);vertical-align:top}.vocab-table tr:last-child td{border-bottom:none}.pos-badge{display:inline-block;font-size:9px;padding:1px 5px;background:#e8e8ed;color:var(--text-secondary);border-radius:3px;font-family:monospace}.answer-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:6px;font-size:12px}.answer-cell{border:1px solid var(--border);border-radius:var(--radius-sm);padding:6px 8px;text-align:center}.answer-cell-num{font-size:10px;color:var(--text-secondary);margin-bottom:2px}.answer-cell-val{font-weight:600;color:var(--text)}.passage-row{background:var(--white);border:1px solid var(--border);border-radius:var(--radius-sm);padding:10px 12px;display:flex;align-items:center;gap:8px;cursor:pointer;transition:border-color .1s}.passage-row:hover{border-color:var(--border-hover)}.passage-row.sel{border-color:var(--blue);background:var(--blue-light)}.row-actions{display:flex;gap:4px;opacity:0;transition:opacity .15s}.question-card:hover .row-actions,.passage-row:hover .row-actions{opacity:1}.result-card{background:var(--white);border:1.5px solid var(--blue);border-radius:var(--radius);padding:14px 16px}.passage-group-card{background:var(--white);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow)}.passage-group-header{display:flex;align-items:center;gap:8px;padding:12px 16px;background:#f8f9fb;border-bottom:1px solid var(--border);cursor:pointer;-webkit-user-select:none;user-select:none}.passage-group-header:hover{background:#f0f2f5}.passage-text-block{padding:12px 16px;font-size:13px;line-height:1.8;color:#2c2c2e;border-bottom:1px solid var(--border);font-family:Georgia,serif;white-space:pre-wrap;overflow:hidden}.passage-text-block.collapsed{display:-webkit-box;-webkit-line-clamp:4;-webkit-box-orient:vertical;overflow:hidden;white-space:normal}.passage-toggle-btn{display:block;width:100%;padding:6px 16px;background:none;border:none;border-bottom:1px solid var(--border);font-size:11px;color:var(--blue);cursor:pointer;text-align:left}.passage-toggle-btn:hover{background:var(--blue-light)}.question-rows{display:flex;flex-direction:column}.question-row{display:flex;align-items:center;gap:10px;padding:10px 16px;border-bottom:1px solid var(--border);cursor:pointer;transition:background .1s}.question-row:last-child{border-bottom:none}.question-row:hover{background:var(--blue-light)}.question-row-num{font-size:12px;font-weight:600;color:var(--text-secondary);width:28px;flex-shrink:0}.question-row-text{flex:1;font-size:13px;color:var(--text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.question-row-arrow{font-size:11px;color:#bbb;flex-shrink:0}.saved-summary{display:flex;align-items:stretch;gap:8px;flex-wrap:wrap}.saved-summary-item{min-width:76px;padding:8px 10px;border:1px solid var(--border);border-radius:var(--radius-sm);background:#f7f8fb;display:flex;flex-direction:column;gap:2px}.saved-summary-item strong{font-size:15px;line-height:1}.saved-summary-item span{font-size:10px;color:var(--text-secondary)}.saved-explorer{display:grid;grid-template-columns:minmax(280px,360px) minmax(0,1fr);gap:12px}.saved-list{display:flex;flex-direction:column;gap:10px;max-height:720px;overflow-y:auto;padding-right:4px}.saved-card{width:100%;border:1px solid var(--border);border-radius:var(--radius);background:var(--white);padding:12px 13px;cursor:pointer;text-align:left;display:flex;flex-direction:column;gap:8px;transition:border-color .12s,background .12s,box-shadow .12s;font-family:var(--font)}.saved-card:hover{border-color:var(--blue);background:var(--blue-light)}.saved-card.active{border-color:var(--blue);background:var(--blue-light);box-shadow:0 0 0 1px #0071e314}.saved-card-head{display:flex;align-items:flex-start;justify-content:space-between;gap:8px}.saved-card-title{flex:1;min-width:0;font-size:13px;font-weight:600;color:var(--text);line-height:1.4}.saved-card-count{font-size:10px;font-weight:700;color:var(--blue);background:#e7f1ff;padding:3px 7px;border-radius:999px;white-space:nowrap}.saved-card-meta{font-size:11px;color:var(--text-secondary)}.saved-card-preview{font-size:12px;line-height:1.65;color:var(--text);display:-webkit-box;-webkit-line-clamp:4;-webkit-box-orient:vertical;overflow:hidden}.saved-card-footer{display:flex;justify-content:space-between;align-items:flex-end;gap:10px;font-size:10px;color:var(--text-secondary)}.saved-card-types{display:flex;flex-wrap:wrap;justify-content:flex-end;gap:4px}.saved-detail{border:1px solid var(--border);border-radius:var(--radius);background:#fcfcfd;padding:16px;display:flex;flex-direction:column;gap:16px;min-width:0}.saved-detail-head{display:flex;justify-content:space-between;align-items:flex-start;gap:14px;flex-wrap:wrap}.saved-detail-eyebrow{font-size:10px;font-weight:700;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.06em;margin-bottom:4px}.saved-detail-title{font-size:18px;font-weight:700;color:var(--text);line-height:1.3}.saved-detail-meta{display:flex;align-items:center;flex-wrap:wrap;gap:6px;font-size:12px;color:var(--text-secondary);margin-top:6px}.saved-detail-dot{color:#b7b7be}.saved-detail-stats{display:flex;gap:8px;flex-wrap:wrap}.saved-detail-stat{min-width:74px;padding:8px 10px;border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--white);display:flex;flex-direction:column;gap:2px}.saved-detail-stat strong{font-size:15px;line-height:1}.saved-detail-stat span{font-size:10px;color:var(--text-secondary)}.saved-detail-types{display:flex;flex-wrap:wrap;gap:6px}.saved-detail-section{display:flex;flex-direction:column;gap:8px;min-width:0}.saved-detail-section-head{display:flex;justify-content:space-between;align-items:center;gap:8px;flex-wrap:wrap}.saved-detail-note{font-size:11px;color:var(--text-secondary)}.saved-detail-passage{font-size:13px;line-height:1.85;color:#2c2c2e;font-family:Georgia,serif;white-space:pre-wrap;background:var(--white);border:1px solid var(--border);border-radius:var(--radius-sm);padding:14px;max-height:340px;overflow-y:auto}.saved-question-list{display:flex;flex-direction:column;gap:8px;max-height:320px;overflow-y:auto;padding-right:4px}.saved-question-card{width:100%;border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--white);padding:10px 12px;text-align:left;cursor:pointer;transition:border-color .12s,background .12s;font-family:var(--font)}.saved-question-card:hover{border-color:var(--blue);background:var(--blue-light)}.saved-question-card-head{display:flex;justify-content:space-between;gap:8px;align-items:flex-start;margin-bottom:6px}.saved-question-card-num{font-size:12px;font-weight:600;color:var(--text-secondary);white-space:nowrap}.saved-question-card-answer{font-size:11px;font-weight:700;color:#2e7d32;white-space:nowrap}.saved-question-card-text{font-size:13px;line-height:1.55;color:var(--text);display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.saved-detail-empty,.saved-detail-empty-inline{border:1px dashed var(--border);border-radius:var(--radius-sm);background:#fafbfc;color:var(--text-secondary);font-size:12px;line-height:1.6}.saved-detail-empty{min-height:280px;display:flex;align-items:center;justify-content:center;padding:20px;text-align:center}.saved-detail-empty-inline{padding:14px 12px}@media (max-width: 1100px){.saved-explorer{grid-template-columns:1fr}.saved-list{max-height:280px}.saved-detail-passage,.saved-question-list{max-height:none}}.detail-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000040;z-index:200}.detail-panel{position:fixed;top:0;right:0;width:440px;max-width:95vw;height:100vh;background:var(--white);box-shadow:-4px 0 24px #0000001f;z-index:201;display:flex;flex-direction:column;animation:slideInRight .22s ease}@keyframes slideInRight{0%{transform:translate(100%);opacity:0}to{transform:translate(0);opacity:1}}.detail-panel-header{display:flex;align-items:center;gap:8px;padding:14px 16px;border-bottom:1px solid var(--border);flex-shrink:0}.detail-panel-body{flex:1;overflow-y:auto;padding:16px;display:flex;flex-direction:column;gap:16px}.detail-section-label{font-size:10px;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.06em;margin-bottom:6px}.detail-passage-text{font-size:13px;line-height:1.85;color:#2c2c2e;font-family:Georgia,serif;white-space:pre-wrap;background:#fafafa;border-radius:var(--radius-sm);padding:12px;border:1px solid var(--border)}.detail-question-text{font-size:14px;line-height:1.6;font-weight:500;color:var(--text)}.detail-options{display:flex;flex-direction:column;gap:6px;list-style:none}.detail-option{display:flex;align-items:flex-start;gap:8px;padding:8px 10px;border-radius:var(--radius-sm);border:1px solid var(--border);font-size:13px;line-height:1.5}.detail-option.correct{border-color:#4caf50;background:#f1f8f1;color:#1b5e20;font-weight:500}.detail-option-num{font-size:12px;color:var(--text-secondary);flex-shrink:0;padding-top:1px}.detail-answer-box{background:#f0faf4;border:1px solid #c8e6c9;border-radius:var(--radius-sm);padding:10px 12px;font-size:13px}.detail-explanation{background:#fffde7;border:1px solid #fff176;border-radius:var(--radius-sm);padding:10px 12px;font-size:13px;line-height:1.6;color:#5d4037}.stats-bar{display:flex;align-items:center;gap:6px;flex-wrap:wrap;font-size:12px;color:var(--text-secondary)}.stats-chip{display:inline-flex;align-items:center;gap:3px;padding:3px 8px;border-radius:20px;background:#f0f0f5;font-size:11px;cursor:pointer;transition:background .1s;white-space:nowrap}.stats-chip:hover{background:#e3eaff}.stats-chip.active{background:#daeaff;color:var(--blue);font-weight:500}.stats-chip .chip-count{font-weight:600;color:var(--text)}.stats-chip.active .chip-count{color:var(--blue)}.view-toggle{display:inline-flex;border:1px solid var(--border);border-radius:var(--radius-sm);overflow:hidden}.view-toggle-btn{padding:5px 10px;font-size:12px;border:none;background:var(--white);cursor:pointer;color:var(--text-secondary);font-family:var(--font);transition:background .1s}.view-toggle-btn:hover{background:#f5f5f7}.view-toggle-btn.active{background:var(--blue);color:#fff}:root{--blue: #a65f43;--blue-light: #f7eee8;--bg: #fbf9f5;--white: #ffffff;--text: #2b2620;--text-secondary: #6f6557;--border: #ebe4d4;--border-hover: #d8cbb4;--shadow: 0 1px 2px rgba(43, 38, 32, .04), 0 8px 24px rgba(43, 38, 32, .05);--shadow-md: 0 12px 32px rgba(43, 38, 32, .1);--radius: 8px;--radius-sm: 6px}html,body,#root{background:var(--bg)}.app-shell{flex-direction:row;background:var(--bg)}.body-area{width:100%;min-width:0}.top-bar{display:none}.sidebar{width:256px;padding:0;background:#f5f1e8;border-right:1px solid var(--border);color:var(--text)}.sidebar-brand{display:flex;align-items:center;gap:10px;padding:16px 16px 12px}.brand-mark{width:28px;height:28px;border-radius:7px;display:grid;place-items:center;background:var(--text);color:var(--bg);font-family:Georgia,Times New Roman,serif;font-size:16px;font-style:italic;font-weight:700}.brand-name{font-size:14px;font-weight:700;letter-spacing:-.01em}.brand-subtitle{margin-top:1px;font-size:10.5px;color:#968b78}.sidebar-search{margin:4px 10px 8px;padding:7px 10px;border:1px solid var(--border);border-radius:6px;background:#fffdfa;color:#968b78;font-size:12px}.sidebar-nav{padding:4px 8px 10px;border-bottom:1px solid rgba(235,228,212,.75)}.nav-item{width:100%;display:flex;align-items:center;gap:9px;border:0;border-radius:6px;padding:7px 8px;background:transparent;color:var(--text-secondary);cursor:pointer;font-family:var(--font);text-align:left}.nav-item:hover{background:#2b26200a}.nav-item.active{background:#fffdfa;color:var(--text);box-shadow:0 1px 2px #2b26200a,0 0 0 1px var(--border)}.nav-dot{width:7px;height:7px;border-radius:3px;background:var(--blue);opacity:.35;flex-shrink:0}.nav-item.active .nav-dot{opacity:1}.nav-copy{flex:1;min-width:0;display:flex;flex-direction:column;line-height:1.2}.nav-label{font-size:13.5px;font-weight:650}.nav-kicker{margin-top:1px;color:#968b78;font-size:10.5px}.nav-count{padding:1px 7px;border-radius:999px;background:#efe8dc;color:#746957;font-size:11px;font-variant-numeric:tabular-nums}.sidebar-section{padding:13px 16px 5px;color:#968b78;font-size:10.5px;letter-spacing:.08em}.source-scroll{min-height:0;overflow-y:auto;padding-bottom:10px}.src-item{margin:1px 8px;padding:6px 8px 6px 22px;border-left:0;border-radius:5px;position:relative;color:var(--text-secondary)}.src-item:before{content:"";position:absolute;left:11px;top:10px;width:6px;height:6px;border-radius:2px;background:var(--blue);opacity:.35}.src-item:hover,.src-item.active{background:#2b26200a}.src-item.active{color:var(--text)}.src-item.active:before{opacity:1}.badge,.src-item.active .badge{background:#efe8dc;color:#746957;border-radius:999px;font-variant-numeric:tabular-nums}.sidebar-bottom{background:#f5f1e8}.main-content{padding:0 32px 32px;gap:14px;background:var(--bg)}.workspace-cover{height:96px;margin:0 -32px;border-bottom:1px solid var(--border);background:radial-gradient(circle at 20% 30%,rgba(255,255,255,.7) 0,transparent 38%),radial-gradient(circle at 78% 72%,rgba(157,189,179,.3) 0,transparent 42%),linear-gradient(120deg,#f6e9df,#f3ead7);flex-shrink:0}.workspace-titlebar{display:flex;align-items:flex-end;justify-content:space-between;gap:16px;margin:0 -32px 4px;padding:14px 32px 16px;border-bottom:1px solid var(--border);background:var(--bg)}.workspace-crumb{color:#968b78;font-size:12px;margin-bottom:3px}.workspace-titlebar h1{margin:0;color:var(--text);font-family:Georgia,Times New Roman,"Noto Serif KR",serif;font-size:30px;font-weight:650;letter-spacing:-.02em}.workspace-titlebar p{margin:4px 0 0;color:var(--text-secondary);font-size:13px}.workspace-mini-stats{display:flex;flex-wrap:wrap;justify-content:flex-end;gap:7px;max-width:420px}.workspace-mini-stats span{padding:5px 9px;border:1px solid var(--border);border-radius:999px;background:#fffdfa;color:var(--text-secondary);font-size:12px;font-variant-numeric:tabular-nums}.card,.question-card,.passage-group-card,.saved-explorer,.result-card{background:#fffdfa;border-color:var(--border);border-radius:9px;box-shadow:var(--shadow)}.card{padding:16px 18px}.card-title,.section-title{color:var(--text);font-size:13px;font-weight:700;letter-spacing:-.01em}.btn{border-color:var(--border);border-radius:6px;background:#fffdfa;font-weight:600}.btn:hover{background:#f6f0e6;border-color:var(--border-hover)}.btn-primary,.view-toggle-btn.active{background:var(--blue);border-color:var(--blue);color:#fff}.btn-primary:hover{background:#8f5139;border-color:#8f5139}.filter-select,.search-input,.form-input,.form-textarea{border-color:var(--border);background:#fffdfa;border-radius:6px}.filter-select:focus,.search-input:focus,.form-input:focus,.form-textarea:focus{border-color:var(--blue);box-shadow:0 0 0 3px #a65f431a}.type-chip,.stats-chip,.view-toggle-btn{background:#fffdfa;border-color:var(--border)}.type-chip:hover,.stats-chip:hover{background:#f6f0e6}.type-chip.selected,.stats-chip.active{border-color:#a65f4359;background:#f7eee8;color:var(--blue)}.upload-area{background:#fffdfa;border-color:#d9cfb8}.upload-area:hover,.upload-area.drag-over{background:#f7eee8;border-color:var(--blue)}.passage-group-card{padding:16px 18px}.passage-group-card:hover,.question-row:hover,.saved-card:hover{box-shadow:var(--shadow-md)}.passage-text-block,.passage-full,.detail-passage-text{background:#fbf7ef;border-color:var(--border);color:#332d25;font-family:Georgia,Times New Roman,"Noto Serif KR",serif;line-height:1.8}.question-row{border-color:var(--border);border-radius:7px;background:#fffdfa}.question-row.sel{background:#f7eee8;border-color:#a65f4359}.chk.on,.detail-option.correct,.option-item.correct{background:#eef7ed;border-color:#b8d8b7;color:#2e6d39}.result-card{border-width:1px;border-color:#d9cfb8}.ai-generate-card{max-width:1040px}.ai-input-header,.ai-type-toolbar,.ai-results-head{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:8px}.ai-input-actions,.ai-presets{display:flex;gap:6px;flex-wrap:wrap}.ai-passage-picker{margin-bottom:8px;overflow:hidden;border:1px solid var(--border);border-radius:8px;background:#fffdfa}.ai-picker-head{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:8px 10px;border-bottom:1px solid var(--border);background:#f7f0e6;color:var(--text-secondary);font-size:11px}.ai-picker-list{max-height:220px;overflow-y:auto;display:flex;flex-direction:column}.ai-loaded-passages{padding:10px 12px;border:1px solid #c9dcc3;border-radius:8px;background:#f3f8ef}.ai-loaded-title{margin-bottom:8px;color:#436d3d;font-size:11px;font-weight:700}.ai-loaded-list{display:flex;flex-wrap:wrap;gap:6px}.ai-loaded-chip{display:inline-flex;align-items:center;gap:6px;padding:4px 9px;border:1px solid #b7d3ae;border-radius:999px;background:#fffdfa;color:#32652f;font-size:12px}.ai-loaded-chip button{border:0;background:transparent;color:#78936f;cursor:pointer;font-size:14px;font-weight:800;line-height:1}.ai-type-count-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(176px,1fr));gap:8px}.ai-type-count{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:10px;border:1px solid var(--border);border-radius:8px;background:#fffdfa;color:var(--text-secondary)}.ai-type-count.active{border-color:#a65f4359;background:#f7eee8;color:var(--text)}.ai-type-count-label{min-width:0;font-size:12.5px;font-weight:700}.ai-count-stepper{display:inline-flex;align-items:center;overflow:hidden;border:1px solid var(--border);border-radius:7px;background:#fffefa;flex-shrink:0}.ai-count-stepper button{width:26px;height:28px;border:0;background:transparent;color:var(--text-secondary);cursor:pointer;font-weight:800}.ai-count-stepper button:hover:not(:disabled){background:#f6f0e6;color:var(--blue)}.ai-count-stepper button:disabled{opacity:.35;cursor:not-allowed}.ai-count-stepper input{width:38px;height:28px;border:0;border-left:1px solid var(--border);border-right:1px solid var(--border);background:transparent;color:var(--text);text-align:center;font-family:var(--font);font-size:12px;font-weight:800;outline:none}.ai-generation-summary{margin-top:8px;color:#968b78;font-size:12px}.ai-result-meta{display:flex;flex-wrap:wrap;gap:6px;margin:12px 0 5px}.ai-result-meta span{padding:3px 8px;border-radius:999px;background:#f7f0e6;color:var(--text-secondary);font-size:11px;font-weight:700}#exam-preview{background:#fffefa;border:1px solid var(--border);border-radius:10px;box-shadow:0 18px 55px #2b26201a}.exam-columns .question-card{border-color:#eadfca;background:#fffefa}.answer-grid{background:#fffefa}.step-bar{padding:10px 12px;border:1px solid var(--border);border-radius:8px;background:#fffdfa}.step-item.active .step-circle{background:#f7eee8}.step-item.done .step-circle,.toggle-track.on,.progress-bar{background:var(--blue);border-color:var(--blue)}.alert-info{background:#f7eee8;border-color:#e7cdbc;color:#7d452f}.data-table th{background:#f7f0e6}.data-table tr:hover td{background:#fbf7ef}@media (max-width: 980px){.sidebar{width:220px}.main-content{padding-left:20px;padding-right:20px}.workspace-cover,.workspace-titlebar{margin-left:-20px;margin-right:-20px}.workspace-titlebar{padding-left:20px;padding-right:20px;align-items:flex-start;flex-direction:column}}@media print{.workspace-cover,.workspace-titlebar{display:none!important}.main-content{padding:12mm 14mm}}.main-content-essay,.main-content-workbook,.main-content-vocab,.main-content-logs{background:radial-gradient(circle at 74% 7%,rgba(157,189,179,.16),transparent 28%),var(--bg)}.essay-config-card,.workbook-config-card,.workbook-saved-card{max-width:980px}.workbook-saved-list{display:flex;flex-direction:column;gap:8px}.workbook-saved-item{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:11px 12px;border:1px solid var(--border);border-radius:8px;background:#fffdfa;cursor:pointer;transition:border-color .15s,box-shadow .15s,background .15s}.workbook-saved-item:hover{border-color:var(--border-hover);background:#fbf7ef;box-shadow:var(--shadow)}.workbook-saved-title{color:var(--text);font-size:13px;font-weight:700}.workbook-saved-meta{margin-top:2px;color:#968b78;font-size:11px}.main-content-essay .passage-row,.main-content-workbook .passage-row,.vocab-workspace .src-item{border:1px solid transparent;border-radius:8px;background:#fffdfa;box-shadow:inset 0 0 0 1px #ebe4d48c}.main-content-essay .passage-row:hover,.main-content-workbook .passage-row:hover,.vocab-workspace .src-item:hover{border-color:var(--border-hover);box-shadow:var(--shadow)}.passage-row.sel,.vocab-workspace .src-item.active{background:#f7eee8;border-color:#a65f4359}.chk{width:18px;height:18px;border-radius:5px;border:1px solid #d9cfb8;background:#fffdfa;display:grid;place-items:center;color:var(--blue);font-size:11px;font-weight:700;flex-shrink:0}.wb-type-chip{display:flex;align-items:center;gap:10px;padding:10px 12px;border:1px solid var(--border);border-radius:8px;background:#fffdfa;cursor:pointer;color:var(--text-secondary);transition:box-shadow .15s,border-color .15s,background .15s}.wb-type-chip:hover{border-color:var(--border-hover);box-shadow:var(--shadow)}.wb-type-chip.on{background:#f7eee8;border-color:#a65f4359;color:var(--text)}.wb-type-num{width:24px;height:24px;border-radius:7px;display:grid;place-items:center;background:#efe8dc;color:var(--blue);font-size:12px;font-weight:700;flex-shrink:0}.wb-progress-wrap{position:relative;height:30px;overflow:hidden;border:1px solid var(--border);border-radius:8px;background:#fbf7ef}.wb-progress-bar-inner{position:absolute;inset:0 auto 0 0;background:#a65f432e;transition:width .25s ease}.wb-progress-label{position:relative;z-index:1;display:flex;align-items:center;height:100%;padding:0 10px;color:var(--text-secondary);font-size:12px;font-weight:600}.wb-passage-block{margin-bottom:22px;padding:18px 20px;border:1px solid var(--border);border-radius:10px;background:#fffefa;box-shadow:var(--shadow)}.wb-passage-label{margin-bottom:14px;color:var(--text);font-family:Georgia,Times New Roman,"Noto Serif KR",serif;font-size:18px;font-weight:700}.wb-section{margin-top:14px;border:1px solid #eadfca;border-radius:9px;overflow:hidden;background:#fffdfa}.wb-section-head{display:flex;align-items:center;gap:8px;padding:10px 12px;border-bottom:1px solid var(--border);background:#f7f0e6;color:var(--text);font-size:13px;font-weight:700}.wb-section-num{color:var(--blue);font-variant-numeric:tabular-nums}.wb-section-body{padding:12px}.wb-pt-table,.vocab-table{width:100%;border-collapse:collapse;font-size:12.5px}.wb-pt-table th,.vocab-table th{padding:9px 10px;border-bottom:1px solid var(--border);background:#f7f0e6;color:#746957;text-align:left;font-size:11px;letter-spacing:.04em}.wb-pt-table td,.vocab-table td{padding:9px 10px;border-bottom:1px solid #efe6d6;vertical-align:top}.wb-item,.wb-item-error{display:flex;gap:10px;padding:10px 0;border-bottom:1px dashed var(--border)}.wb-item:last-child,.wb-item-error:last-child{border-bottom:0}.wb-item-num,.wb-item-num-inline{color:var(--blue);font-weight:700;font-variant-numeric:tabular-nums}.wb-blank-line{display:inline-block;min-width:180px;border-bottom:1px solid #d8cbb4}.vocab-workspace{align-items:flex-start}.vocab-workspace>div:first-child{width:280px!important}.vocab-workspace>div:first-child .card{position:sticky;top:0}.vocab-workspace>div:last-child{flex:1;min-width:0}.pos-badge{display:inline-flex;padding:2px 7px;border-radius:999px;background:#efe8dc;color:#746957;font-size:11px;font-weight:700}.main-content-vocab .empty-state,.main-content-logs .empty-state{border:1px solid var(--border);background:#fffdfa;border-radius:10px}.log-workspace{display:flex;flex-direction:column;gap:14px;max-width:1040px}.log-summary-card,.log-preview-toolbar{display:flex;align-items:center;justify-content:space-between;gap:16px}.log-muted{margin-top:3px;color:#968b78;font-size:12px}.log-total{min-width:58px;text-align:center;color:var(--blue);font-family:Georgia,Times New Roman,serif;font-size:30px;font-weight:700;font-variant-numeric:tabular-nums}.log-list{position:relative;display:flex;flex-direction:column;gap:10px;padding-left:18px}.log-list:before{content:"";position:absolute;left:6px;top:8px;bottom:8px;width:1px;background:var(--border)}.log-card{position:relative;display:flex;align-items:center;gap:14px;padding:14px 16px;border:1px solid var(--border);border-radius:10px;background:#fffdfa;box-shadow:var(--shadow)}.log-card-marker{position:absolute;left:-16px;top:22px;width:10px;height:10px;border:2px solid #fffdfa;border-radius:50%;background:var(--blue);box-shadow:0 0 0 1px var(--border)}.log-switch{display:inline-flex;width:fit-content;padding:3px;border:1px solid var(--border);border-radius:8px;background:#fffdfa;box-shadow:var(--shadow)}.log-switch button{display:inline-flex;align-items:center;gap:6px;border:0;border-radius:6px;padding:7px 11px;background:transparent;color:var(--text-secondary);font-family:var(--font);font-size:12px;font-weight:700;cursor:pointer}.log-switch button.active{background:var(--text);color:var(--bg)}.log-switch span{opacity:.7;font-variant-numeric:tabular-nums}.log-card-main{flex:1;min-width:0}.log-card-head{display:flex;justify-content:space-between;align-items:flex-start;gap:12px}.log-title{color:var(--text);font-size:14px;font-weight:700}.log-card-meta{display:flex;gap:8px;flex-wrap:wrap;margin-top:10px}.log-card-meta span{padding:3px 8px;border-radius:999px;background:#f7f0e6;color:var(--text-secondary);font-size:11px}.ai-log-card.failed .log-card-marker{background:#c4493d}.ai-log-card.partial .log-card-marker{background:#bd7a27}.ai-status{display:inline-flex;padding:3px 8px;border-radius:999px;background:#eef7ed;color:#2e6d39;font-size:11px;font-weight:800}.ai-status.partial{background:#fff4dd;color:#9a5b11}.ai-status.failed{background:#fff0ed;color:#b53a30}.ai-log-detail{display:flex;flex-wrap:wrap;gap:6px;margin-top:10px}.ai-log-detail span{max-width:100%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;padding:4px 8px;border:1px solid var(--border);border-radius:999px;background:#fffefa;color:#746957;font-size:11px}.log-actions{display:flex;gap:8px}@media (max-width: 1040px){.vocab-workspace{flex-direction:column}.vocab-workspace>div:first-child{width:100%!important}.vocab-workspace>div:first-child .card{position:static}.log-card,.log-summary-card,.log-preview-toolbar{align-items:flex-start;flex-direction:column}}@media print{.log-workspace{max-width:none}.wb-passage-block,.wb-section{box-shadow:none;border-color:#ddd}}
