@import"https://fonts.googleapis.com/css2?family=Noto+Sans+KR:wght@300;400;500;600;700&display=swap";:root{--primary: #000000;--primary-hover: #1a1a1a;--secondary: #666666;--text-primary: #111111;--text-secondary: #555555;--text-muted: #888888;--border: #e0e0e0;--border-light: #f0f0f0;--bg-primary: #ffffff;--bg-secondary: #fafafa;--bg-tertiary: #f5f5f5;--danger: #333333;--success: #222222;--warning: #444444}*{margin:0;padding:0;box-sizing:border-box}body{font-family:Noto Sans KR,-apple-system,BlinkMacSystemFont,sans-serif;background-color:var(--bg-secondary);color:var(--text-primary);line-height:1.7;font-size:15px;word-break:keep-all;-webkit-font-smoothing:antialiased;letter-spacing:-.01em}a{text-decoration:none;color:inherit}button{cursor:pointer;font-family:inherit}h1,h2,h3,h4,h5,h6{word-break:keep-all;line-height:1.4;font-weight:600;color:var(--text-primary)}p{word-break:keep-all}.home-page{min-height:100vh;display:flex;justify-content:center;align-items:center;background:var(--primary);padding:2rem}.home-container{background:var(--bg-primary);border-radius:16px;box-shadow:0 20px 60px #0000004d;padding:3rem;max-width:800px;width:100%;text-align:center}.home-header h1{font-size:2.5rem;color:var(--primary);margin-bottom:.5rem;font-weight:700;letter-spacing:-.02em}.home-header .subtitle{font-size:1.1rem;color:var(--text-muted);margin-bottom:2rem}.feature-list{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1.5rem;margin-bottom:2.5rem}.feature-item{padding:1.5rem;background:var(--bg-secondary);border-radius:12px;text-align:center;border:1px solid var(--border-light)}.feature-icon{font-size:2rem;display:block;margin-bottom:.75rem;filter:grayscale(100%)}.feature-item h3{font-size:1rem;color:var(--text-primary);margin-bottom:.5rem}.feature-item p{font-size:.875rem;color:var(--text-secondary);line-height:1.6}.home-actions{display:flex;justify-content:center;gap:1rem;flex-wrap:wrap}.btn-large{padding:1rem 2.5rem;font-size:1rem;min-width:150px}.home-actions .btn-primary{width:auto}.home-actions .btn-secondary{background:var(--bg-primary);border:2px solid var(--primary);color:var(--primary)}.home-actions .btn-secondary:hover{background:var(--bg-tertiary)}.home-footer{margin-top:2rem;padding-top:1.5rem;border-top:1px solid var(--border);color:var(--text-muted);font-size:.8rem}.loading,.error{display:flex;justify-content:center;align-items:center;min-height:200px;font-size:1rem;color:var(--text-muted)}.auth-page{min-height:100vh;display:flex;justify-content:center;align-items:center;background:var(--primary)}.auth-container{background:var(--bg-primary);padding:2.5rem;border-radius:12px;box-shadow:0 10px 40px #0003;width:100%;max-width:400px}.auth-container h1{text-align:center;color:var(--primary);margin-bottom:.5rem;font-size:1.75rem}.auth-container h2{text-align:center;font-size:1.1rem;color:var(--text-muted);margin-bottom:1.5rem;font-weight:400}.form-row{display:flex;gap:1rem}.form-row .form-group{flex:1}.form-group{margin-bottom:1rem}.form-group label{display:block;margin-bottom:.5rem;font-weight:500;color:var(--text-primary);font-size:.9rem}.form-group input,.form-group textarea,.form-group select{width:100%;padding:.75rem;border:1px solid var(--border);border-radius:8px;font-size:1rem;transition:border-color .2s;background:var(--bg-primary)}.form-group input:focus,.form-group textarea:focus,.form-group select:focus{outline:none;border-color:var(--primary)}.role-select{display:flex;gap:1.5rem}.role-select label{display:flex;align-items:center;gap:.5rem;cursor:pointer;font-weight:400}.btn-primary{width:100%;padding:.875rem;background:var(--primary);color:var(--bg-primary);border:none;border-radius:8px;font-size:.95rem;font-weight:600;transition:background .2s;letter-spacing:.02em}.btn-primary:hover{background:var(--primary-hover)}.btn-primary:disabled{opacity:.5;cursor:not-allowed}.btn-secondary{padding:.75rem 1.5rem;background:var(--bg-tertiary);color:var(--text-primary);border:1px solid var(--border);border-radius:8px;font-size:.95rem;font-weight:500}.btn-secondary:hover{background:var(--border)}.btn-danger{padding:.75rem 1.5rem;background:var(--text-primary);color:var(--bg-primary);border:none;border-radius:8px;font-size:.95rem;font-weight:500}.btn-danger:hover{background:var(--primary)}.btn-small{padding:.5rem 1rem;font-size:.85rem}.btn-icon{padding:.5rem .75rem;background:var(--bg-tertiary);border:1px solid var(--border);border-radius:6px;font-size:.85rem}.btn-icon:hover{background:var(--border)}.btn-icon.btn-danger{background:var(--bg-tertiary);border-color:var(--border);color:var(--text-primary)}.auth-link{text-align:center;margin-top:1.5rem;color:var(--text-muted);font-size:.9rem}.auth-link a{color:var(--primary);font-weight:500;text-decoration:underline}.error-message{background:var(--bg-tertiary);border:1px solid var(--border);color:var(--text-primary);padding:.75rem;border-radius:8px;margin-bottom:1rem;text-align:center;font-size:.9rem}.navbar{background:var(--bg-primary);box-shadow:0 1px 0 var(--border);padding:0 2rem;display:flex;align-items:center;justify-content:space-between;height:60px;position:sticky;top:0;z-index:100}.navbar-brand a{font-size:1.2rem;font-weight:700;color:var(--primary);letter-spacing:-.02em}.navbar-menu{display:flex;gap:2rem}.navbar-menu a{color:var(--text-secondary);font-weight:500;font-size:.9rem;transition:color .2s}.navbar-menu a:hover{color:var(--primary)}.navbar-user{display:flex;align-items:center;gap:1rem}.navbar-user span{color:var(--text-muted);font-size:.9rem}.btn-logout{padding:.5rem 1rem;background:transparent;border:1px solid var(--border);border-radius:6px;color:var(--text-secondary);font-size:.85rem}.btn-logout:hover{background:var(--bg-tertiary);color:var(--primary)}.main-content{max-width:1200px;margin:0 auto;padding:2rem}.dashboard h1{margin-bottom:1.5rem;color:var(--text-primary)}.dashboard-grid{display:grid;gap:1.5rem}.stats-section{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem}.stat-card{background:var(--bg-primary);padding:1.5rem;border-radius:12px;border:1px solid var(--border-light)}.stat-card h3{font-size:.8rem;color:var(--text-muted);margin-bottom:.5rem;font-weight:500}.stat-value{font-size:1.75rem;font-weight:700;color:var(--primary)}.review-banner{background:var(--primary);padding:1.5rem 2rem;border-radius:12px;display:flex;justify-content:space-between;align-items:center;color:var(--bg-primary)}.review-banner h3{margin-bottom:.25rem}.review-banner .btn-primary{width:auto;background:var(--bg-primary);color:var(--primary)}.recent-section,.quick-actions{background:var(--bg-primary);padding:1.5rem;border-radius:12px;border:1px solid var(--border-light)}.section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.section-header h2{font-size:1rem;color:var(--text-primary)}.section-header .link{color:var(--text-secondary);font-size:.85rem;text-decoration:underline}.homework-list{display:grid;gap:.75rem}.homework-card{display:block;padding:1rem;background:var(--bg-secondary);border-radius:8px;transition:background .2s;border:1px solid var(--border-light)}.homework-card:hover{background:var(--bg-tertiary)}.homework-card h3{font-size:.95rem;margin-bottom:.5rem}.homework-meta{display:flex;gap:1rem;font-size:.85rem;color:var(--text-muted)}.empty-message{color:var(--text-muted);text-align:center;padding:1rem;font-size:.9rem}.quick-actions h2{margin-bottom:1rem}.action-btn{display:block;padding:.875rem 1rem;background:var(--bg-secondary);border-radius:8px;margin-bottom:.5rem;color:var(--text-primary);font-weight:500;transition:background .2s;border:1px solid var(--border-light);font-size:.9rem}.action-btn:hover{background:var(--bg-tertiary)}.page-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem}.page-header h1{color:var(--text-primary);font-size:1.5rem}.header-actions{display:flex;gap:.5rem}.excel-upload-section{background:#f8f9fa;padding:1.25rem;border-radius:8px;margin-bottom:1.5rem;border:2px dashed #dee2e6}.excel-upload-section h3{margin:0 0 .5rem;font-size:1rem}.upload-desc{color:#666;margin-bottom:1rem;font-size:.85rem}.upload-category-row{display:flex;gap:1rem;margin-bottom:1rem}.upload-field{flex:1}.upload-field label{display:block;font-size:.8rem;font-weight:600;margin-bottom:.3rem;color:var(--text-secondary)}.upload-field input{width:100%;padding:.5rem .75rem;border:1px solid var(--border);border-radius:6px;font-size:.85rem;background:#fff}.upload-actions{display:flex;gap:.75rem;align-items:center}.upload-result{margin-top:.75rem;padding:.6rem 1rem;border-radius:4px;font-size:.85rem}.upload-result.success{background:#d4edda;color:#155724}.upload-result.error{background:#f8d7da;color:#721c24}.upload-field select,.form-group select{width:100%;padding:.5rem .75rem;border:1px solid var(--border);border-radius:6px;font-size:.85rem;background:#fff;cursor:pointer;-webkit-appearance:auto;-moz-appearance:auto;appearance:auto}.upload-field select:disabled,.form-group select:disabled{opacity:.5;cursor:not-allowed}.custom-input-row{display:flex;gap:.4rem;align-items:center}.custom-input-row input{flex:1}.btn-inline-cancel{padding:.4rem .6rem;font-size:.75rem;border:1px solid var(--border);border-radius:6px;background:#fff;color:var(--text-secondary);cursor:pointer;white-space:nowrap;transition:all .15s}.btn-inline-cancel:hover{background:#f3f4f6;color:var(--text-primary)}.vocab-accordion{display:flex;flex-direction:column;gap:.5rem}.vocab-accordion-textbook{border:1px solid #e5e7eb;border-radius:8px;overflow:hidden;background:#fff}.vocab-accordion-textbook.uncategorized{border-style:dashed;border-color:#d1d5db}.vocab-accordion-header{display:flex;justify-content:space-between;align-items:center;padding:.85rem 1rem;cursor:pointer;-webkit-user-select:none;user-select:none;transition:background .15s}.vocab-accordion-header:hover{background:#f9fafb}.vocab-accordion-header.textbook-level{font-weight:600;background:#f8fafc}.vocab-accordion-header.unit-level{padding-left:2rem;font-size:.9rem;border-top:1px solid #f3f4f6}.accordion-header-left{display:flex;align-items:center;gap:.6rem}.accordion-toggle{font-size:.7rem;color:var(--text-secondary);width:1rem}.accordion-title{color:var(--text-primary)}.accordion-subtitle{color:var(--text-secondary);font-weight:400;font-size:.85rem}.accordion-count{font-size:.8rem;color:var(--text-secondary);font-weight:400}.accordion-loading,.accordion-empty{padding:1rem 2rem;color:var(--text-muted);font-size:.85rem}.vocab-accordion-body{border-top:1px solid #e5e7eb}.vocab-word-list{border-top:1px solid #f3f4f6}.vocab-word-row{display:flex;justify-content:space-between;align-items:center;padding:.6rem 1rem .6rem 3.5rem;border-bottom:1px solid #f3f4f6;gap:1rem}.vocab-word-row:last-child{border-bottom:none}.vocab-word-row:hover{background:#fafbfc}.vocab-word-content{display:flex;align-items:baseline;gap:1rem;flex:1;min-width:0;flex-wrap:wrap}.vocab-english{font-weight:600;color:var(--primary);min-width:120px}.vocab-korean{color:var(--text-primary)}.vocab-example{font-size:.8rem;color:var(--text-muted);font-style:italic;width:100%}.vocab-word-actions{display:flex;gap:.4rem;flex-shrink:0}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#0009;display:flex;justify-content:center;align-items:center;z-index:200;padding:1rem}.modal{background:var(--bg-primary);border-radius:12px;padding:2rem;width:100%;max-width:500px;max-height:90vh;overflow-y:auto}.modal-large{max-width:700px}.modal h2{margin-bottom:1.5rem;color:var(--text-primary);font-size:1.2rem}.modal-actions{display:flex;justify-content:flex-end;gap:1rem;margin-top:1.5rem}.modal-actions .btn-primary{width:auto;padding:.75rem 1.5rem}.checkbox-grid{max-height:200px;overflow-y:auto;border:1px solid var(--border);border-radius:8px;padding:.5rem}.checkbox-item{display:flex;align-items:center;gap:.5rem;padding:.5rem;cursor:pointer;font-size:.9rem}.checkbox-item:hover{background:var(--bg-secondary)}.homework-list-page{display:grid;gap:1rem}.homework-item{display:flex;justify-content:space-between;align-items:center;background:var(--bg-primary);padding:1.25rem;border-radius:12px;border:1px solid var(--border-light);transition:transform .2s}.homework-item:hover{transform:translateY(-2px);box-shadow:0 4px 12px #00000014}.homework-item-wrapper{display:flex;gap:.75rem;align-items:stretch}.homework-item-wrapper .homework-item{flex:1}.btn-delete-homework{padding:.5rem 1rem;background:var(--text-primary);color:var(--bg-primary);border:none;border-radius:8px;cursor:pointer;font-size:.85rem;font-weight:500;transition:background .2s;white-space:nowrap}.btn-delete-homework:hover{background:var(--primary)}.btn-delete-homework:disabled{background:var(--text-muted);cursor:not-allowed}.homework-info h3{margin-bottom:.5rem;font-size:1rem}.homework-info p{color:var(--text-muted);margin-bottom:.5rem;font-size:.9rem}.status-badge{padding:.375rem .75rem;border-radius:20px;font-size:.75rem;font-weight:600}.status-pending{background:var(--bg-tertiary);color:var(--text-secondary);border:1px solid var(--border)}.status-submitted{background:var(--text-primary);color:var(--bg-primary)}.status-graded{background:var(--primary);color:var(--bg-primary)}.homework-detail .back-link{color:var(--text-secondary);font-size:.85rem;display:inline-block;margin-bottom:.5rem;text-decoration:underline}.homework-detail .detail-content{display:grid;gap:1.5rem}.detail-section{background:var(--bg-primary);padding:1.5rem;border-radius:12px;border:1px solid var(--border-light)}.detail-section h2{font-size:1rem;margin-bottom:1rem;color:var(--text-primary)}.detail-meta p{margin-bottom:.5rem;color:var(--text-secondary);font-size:.9rem}.vocab-table,.assignments-table,.difficult-words-table{overflow-x:auto}table{width:100%;border-collapse:collapse}th,td{text-align:left;padding:.75rem;border-bottom:1px solid var(--border);font-size:.9rem}th{background:var(--bg-secondary);font-weight:600;color:var(--text-primary)}table td{white-space:normal}.submission-status p{margin-bottom:.5rem}.action-buttons{display:flex;gap:1rem;margin-top:1rem}.action-buttons .btn-primary{width:auto;padding:.75rem 1.5rem}.exam-table-wrapper{background:var(--bg-primary);border-radius:12px;border:1px solid var(--border-light);overflow-x:auto}.exam-table{width:100%;border-collapse:collapse}.exam-table thead th{background:var(--bg-secondary);font-weight:600;color:var(--text-primary);text-align:left;padding:.875rem 1rem;border-bottom:2px solid var(--border);font-size:.85rem;white-space:nowrap}.exam-th-sortable{cursor:pointer;-webkit-user-select:none;user-select:none;transition:background .15s}.exam-th-sortable:hover{background:var(--bg-tertiary)!important}.exam-th-inner{display:inline-flex;align-items:center;gap:.25rem}.sort-indicator{font-size:.7rem;color:var(--text-muted);min-width:1rem}.exam-th-sortable:hover .sort-indicator{color:var(--text-primary)}.exam-table tbody td{padding:.875rem 1rem;border-bottom:1px solid var(--border-light);font-size:.9rem;color:var(--text-secondary);white-space:nowrap}.exam-table-row{transition:background .15s}.exam-table-row:hover{background:var(--bg-secondary)}.exam-table-row:last-child td{border-bottom:none}.exam-title-cell{font-weight:500;color:var(--text-primary)!important;max-width:300px;overflow:hidden;text-overflow:ellipsis}.exam-actions-cell{display:flex;gap:.5rem;align-items:center}.btn-sm{padding:.375rem .75rem!important;font-size:.8rem!important}.status-completed{background:var(--text-primary);color:var(--bg-primary)}.exam-table-row{cursor:default}.test-page{min-height:calc(100vh - 60px);display:flex;justify-content:center;align-items:center;padding:2rem}.test-container{background:var(--bg-primary);padding:2rem;border-radius:16px;border:1px solid var(--border-light);width:100%;max-width:600px}.test-header{margin-bottom:2rem}.test-header h1{margin-bottom:1rem;text-align:center;font-size:1.25rem}.test-progress{display:flex;align-items:center;gap:1rem}.progress-bar{flex:1;height:6px;background:var(--border);border-radius:3px;overflow:hidden}.progress-fill{height:100%;background:var(--primary);transition:width .3s}.test-question{text-align:center;margin-bottom:2rem}.question-word h2{font-size:1.75rem;color:var(--primary);margin-bottom:.5rem}.example-sentence{color:var(--text-muted);font-style:italic;margin-bottom:2rem;font-size:.9rem}.answer-input{text-align:left}.answer-input label{display:block;margin-bottom:.5rem;font-weight:500;font-size:.9rem}.answer-input input{width:100%;padding:1rem;font-size:1.1rem;border:2px solid var(--border);border-radius:12px;text-align:center}.answer-input input:focus{outline:none;border-color:var(--primary)}.test-navigation{display:flex;justify-content:space-between;gap:1rem}.test-navigation .btn-primary,.test-navigation .btn-secondary{width:auto;padding:.875rem 2rem}.btn-submit{background:var(--primary)}.test-result{background:var(--bg-primary);padding:2rem;border-radius:16px;border:1px solid var(--border-light);width:100%;max-width:700px}.test-result h1{text-align:center;margin-bottom:2rem;font-size:1.25rem}.score-display{text-align:center;margin-bottom:2rem}.score-circle{display:inline-flex;align-items:baseline;justify-content:center;width:120px;height:120px;border:3px solid var(--primary);border-radius:50%;margin-bottom:.5rem}.score-number{font-size:2.5rem;font-weight:700;color:var(--primary)}.score-total{font-size:1.25rem;color:var(--text-muted)}.score-percentage{font-size:1.5rem;font-weight:600;color:var(--text-primary)}.result-details h2{margin-bottom:1rem;font-size:1rem}.result-list{max-height:400px;overflow-y:auto}.result-item{display:flex;align-items:center;gap:1rem;padding:1rem;border-radius:8px;margin-bottom:.5rem}.result-item.correct{background:var(--bg-secondary);border:1px solid var(--border)}.result-item.incorrect{background:var(--bg-tertiary);border:1px solid var(--text-muted)}.result-number{width:30px;height:30px;display:flex;align-items:center;justify-content:center;background:var(--bg-primary);border-radius:50%;font-weight:600;font-size:.85rem}.result-content{flex:1}.result-word{font-weight:600;margin-bottom:.25rem}.result-answer,.result-your-answer{font-size:.85rem}.result-answer .label,.result-your-answer .label{color:var(--text-muted)}.result-status{font-size:1.25rem;font-weight:700}.result-item.correct .result-status{color:var(--primary)}.result-item.incorrect .result-status{color:var(--text-secondary)}.result-actions{display:flex;justify-content:center;gap:1rem;margin-top:2rem}.result-actions .btn-primary,.result-actions .btn-secondary{width:auto;padding:.875rem 2rem}.test-empty{text-align:center;padding:3rem}.test-empty h2{margin-bottom:1rem;color:var(--text-primary);font-size:1.2rem}.test-empty p{color:var(--text-muted);margin-bottom:2rem}.test-empty .btn-primary{width:auto;display:inline-block;padding:.875rem 2rem}.analytics-page h1{margin-bottom:1.5rem}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem;margin-bottom:2rem}.chart-section{background:var(--bg-primary);padding:1.5rem;border-radius:12px;border:1px solid var(--border-light);margin-bottom:1.5rem}.chart-section h2{margin-bottom:1rem;font-size:1rem;color:var(--text-primary)}.chart-container{width:100%}.difficult-words-section{background:var(--bg-primary);padding:1.5rem;border-radius:12px;border:1px solid var(--border-light)}.difficult-words-section h2{margin-bottom:1rem;font-size:1rem}.empty-analytics{text-align:center;padding:3rem;background:var(--bg-primary);border-radius:12px}.empty-analytics h2{color:var(--text-primary);margin-bottom:.5rem}.empty-analytics p{color:var(--text-muted)}.students-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1rem}.student-card{background:var(--bg-primary);padding:1.5rem;border-radius:12px;border:1px solid var(--border-light);display:flex;justify-content:space-between;align-items:center}.student-info h3{margin-bottom:.25rem;font-size:1rem}.student-info p{color:var(--text-muted);font-size:.85rem}.created-at{font-size:.75rem!important;color:var(--text-muted)!important}.student-list-modal{max-height:300px;overflow-y:auto}.student-item-modal{display:flex;justify-content:space-between;align-items:center;padding:.75rem;border-bottom:1px solid var(--border)}.student-item-modal:last-child{border-bottom:none}.student-name{font-weight:500}.student-email{font-size:.85rem;color:var(--text-muted)}.pagination{display:flex;justify-content:center;align-items:center;gap:1rem;margin-top:2rem}.pagination button{padding:.5rem 1rem;background:var(--bg-primary);border:1px solid var(--border);border-radius:6px;color:var(--text-primary);font-size:.9rem}.pagination button:hover:not(:disabled){background:var(--bg-tertiary)}.pagination button:disabled{opacity:.5;cursor:not-allowed}.pagination span{color:var(--text-muted);font-size:.9rem}.textbook-browser{min-height:calc(100vh - 60px - 4rem)}.browser-layout{display:grid;grid-template-columns:280px 1fr;gap:1.5rem;min-height:600px}.browser-sidebar{background:var(--bg-primary);border-radius:12px;border:1px solid var(--border-light);overflow:hidden}.sidebar-section{padding:1rem;border-bottom:1px solid var(--border)}.sidebar-section:last-child{border-bottom:none}.sidebar-section h3{font-size:.8rem;color:var(--text-muted);margin-bottom:.75rem;font-weight:500}.textbook-select{width:100%;padding:.75rem;border:1px solid var(--border);border-radius:8px;font-size:.9rem;background:var(--bg-primary)}.unit-list{max-height:500px;overflow-y:auto}.unit-item{padding:.75rem;border-radius:8px;cursor:pointer;transition:background .2s;margin-bottom:.25rem}.unit-item:hover{background:var(--bg-tertiary)}.unit-item.selected{background:var(--bg-tertiary);border-left:3px solid var(--primary)}.unit-name{font-weight:600;color:var(--text-primary);font-size:.85rem}.unit-title{font-size:.75rem;color:var(--text-muted);margin-top:.25rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.unit-count{font-size:.75rem;color:var(--text-secondary);margin-top:.25rem}.browser-main{background:var(--bg-primary);border-radius:12px;border:1px solid var(--border-light);padding:1.5rem}.vocab-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem;padding-bottom:1rem;border-bottom:1px solid var(--border)}.vocab-header h2{font-size:1rem;color:var(--text-primary)}.vocab-list{max-height:500px;overflow-y:auto}.vocab-item{display:grid;grid-template-columns:40px 40px 1fr 2fr;gap:1rem;align-items:center;padding:.75rem;border-radius:8px;cursor:pointer;transition:background .2s}.vocab-item:hover{background:var(--bg-secondary)}.vocab-item.selected{background:var(--bg-tertiary)}.vocab-checkbox{display:flex;justify-content:center}.vocab-checkbox input{width:18px;height:18px;cursor:pointer;accent-color:var(--primary)}.vocab-number{font-size:.85rem;color:var(--text-muted);text-align:center}.vocab-word{font-weight:600;color:var(--primary)}.vocab-meaning{color:var(--text-secondary);font-size:.9rem}.empty-state{display:flex;justify-content:center;align-items:center;height:300px;color:var(--text-muted)}.student-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem}.student-item-modal{display:flex;align-items:center;gap:.75rem;padding:.75rem;border-bottom:1px solid var(--border);cursor:pointer;transition:background .2s}.student-item-modal:hover{background:var(--bg-secondary)}.student-item-modal.selected{background:var(--bg-tertiary)}.student-item-modal input{width:18px;height:18px;accent-color:var(--primary)}.test-sheet-page{max-width:900px;margin:0 auto}.test-sheet-config{background:var(--bg-primary);border-radius:12px;border:1px solid var(--border-light);padding:1.5rem}.config-section{margin-bottom:2rem;padding-bottom:1.5rem;border-bottom:1px solid var(--border)}.config-section:last-of-type{border-bottom:none;margin-bottom:0}.config-section h3{font-size:.95rem;color:var(--primary);margin-bottom:1rem}.config-row{display:flex;align-items:center;gap:1rem;margin-bottom:.75rem}.config-row label{min-width:100px;font-weight:500;color:var(--text-primary);font-size:.9rem}.config-row input[type=text],.config-row select{flex:1;padding:.5rem .75rem;border:1px solid var(--border);border-radius:6px;font-size:.9rem}.config-row input[type=checkbox]{width:18px;height:18px;margin-right:.5rem;accent-color:var(--primary)}.unit-selection label{display:block;margin-bottom:.5rem;font-weight:500;color:var(--text-primary);font-size:.9rem}.unit-grid{display:flex;flex-wrap:wrap;gap:.5rem}.unit-chip{padding:.5rem 1rem;background:var(--bg-tertiary);border:1px solid var(--border);border-radius:20px;font-size:.85rem;cursor:pointer;transition:all .2s}.unit-chip:hover{background:var(--border)}.unit-chip.selected{background:var(--primary);border-color:var(--primary);color:var(--bg-primary)}.word-selection-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.75rem}.word-selection-list{display:flex;flex-wrap:wrap;gap:.5rem;max-height:300px;overflow-y:auto;padding:.5rem;border:1px solid var(--border);border-radius:8px}.word-chip{display:flex;align-items:center;gap:.5rem;padding:.4rem .75rem;background:var(--bg-secondary);border:1px solid var(--border);border-radius:6px;font-size:.85rem;cursor:pointer;transition:all .2s}.word-chip:hover{background:var(--bg-tertiary)}.word-chip.selected{background:var(--bg-tertiary);border-color:var(--primary)}.word-chip .word-num{color:var(--text-muted);font-size:.75rem}.word-chip .word-eng{color:var(--text-primary)}.section-header-toggle{cursor:pointer;padding:.5rem 0}.section-header-toggle h3{display:flex;align-items:center;gap:.5rem}.section-header-toggle .badge{background:var(--primary);color:var(--bg-primary);padding:.15rem .5rem;border-radius:10px;font-size:.75rem;font-weight:500}.toggle-hint{display:block;font-size:.8rem;color:var(--text-muted);font-weight:400;margin-top:.25rem}.wrong-words-controls{display:flex;justify-content:space-between;align-items:center;margin-bottom:.75rem;padding:.75rem;background:var(--bg-tertiary);border-radius:8px}.wrong-words-selection-list{display:flex;flex-direction:column;gap:.5rem;max-height:350px;overflow-y:auto;padding:.5rem;border:1px solid var(--border);border-radius:8px;background:var(--bg-secondary)}.wrong-word-item{display:flex;align-items:center;gap:.75rem;padding:.75rem;background:var(--bg-primary);border:1px solid var(--border);border-radius:8px;cursor:pointer;transition:all .2s}.wrong-word-item:hover{background:var(--bg-tertiary)}.wrong-word-item.selected{background:var(--bg-tertiary);border-color:var(--primary)}.wrong-word-item.high-error{border-left:3px solid var(--primary)}.wrong-word-item input[type=checkbox]{width:18px;height:18px;flex-shrink:0;accent-color:var(--primary)}.wrong-word-info{flex:1;min-width:0}.wrong-word-eng{display:block;font-weight:600;color:var(--text-primary)}.wrong-word-kor{display:block;font-size:.85rem;color:var(--text-muted);margin-top:.15rem}.wrong-word-meta{display:flex;flex-direction:column;align-items:flex-end;gap:.15rem;font-size:.75rem}.wrong-student{color:var(--text-secondary);font-weight:500}.wrong-count{color:var(--text-primary);font-weight:600}.wrong-days{color:var(--text-muted)}.btn-history-toggle{margin-top:.25rem;padding:.2rem .5rem;font-size:.7rem;background:var(--bg-tertiary);border:none;border-radius:4px;cursor:pointer;color:var(--text-secondary)}.btn-history-toggle:hover{background:var(--border)}.wrong-word-wrapper{margin-bottom:.5rem}.wrong-word-history{margin-top:.25rem;margin-left:2rem;padding:.75rem;background:var(--bg-secondary);border:1px solid var(--border);border-radius:6px;font-size:.8rem}.wrong-word-history .history-header{font-weight:600;color:var(--text-primary);margin-bottom:.5rem;padding-bottom:.25rem;border-bottom:1px solid var(--border)}.wrong-word-history .history-item{display:flex;justify-content:space-between;padding:.35rem 0;border-bottom:1px dashed var(--border)}.wrong-word-history .history-item:last-child{border-bottom:none}.wrong-word-history .history-date{color:var(--text-muted)}.wrong-word-history .history-answer{color:var(--text-secondary);font-style:italic}.wrong-words-selected-info{margin-top:.75rem;padding:.5rem 1rem;background:var(--bg-tertiary);border-radius:6px;font-size:.9rem;color:var(--text-primary);font-weight:500;text-align:center}.config-actions{margin-top:1.5rem;text-align:center;display:flex;justify-content:center;gap:1rem;flex-wrap:wrap}.config-actions .btn-large{min-width:180px}.print-controls{display:flex;justify-content:space-between;margin-bottom:1rem;padding:1rem;background:var(--bg-secondary);border-radius:8px}.print-area{background:var(--bg-primary)}.test-paper{padding:2rem;max-width:800px;margin:0 auto}.test-header{text-align:center;margin-bottom:2rem;padding-bottom:1rem;border-bottom:2px solid var(--primary)}.test-header h1{font-size:1.5rem;margin-bottom:1rem}.test-info{display:flex;justify-content:center;gap:2rem}.info-row{display:flex;align-items:center;gap:.5rem;font-size:.9rem}.blank-line{display:inline-block;min-width:100px;border-bottom:1px solid var(--primary);padding:0 .5rem}.test-questions{display:grid;grid-template-columns:repeat(2,1fr);gap:.75rem 2rem}.question-item{display:flex;align-items:center;gap:.5rem;padding:.5rem 0;border-bottom:1px dotted var(--border)}.q-number{min-width:25px;font-weight:600}.q-word{min-width:120px;font-size:1rem}.q-answer-line{flex:1;border-bottom:1px solid var(--primary);min-width:80px}.answer-key{border-top:3px dashed var(--border);margin-top:2rem;padding-top:2rem}.answer-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:.5rem 2rem}.answer-item{display:flex;align-items:center;gap:.5rem;padding:.3rem 0;font-size:.9rem}.a-number{min-width:25px;font-weight:600}.a-question,.a-arrow{color:var(--text-muted)}.a-answer{color:var(--primary);font-weight:500}@media print{.no-print{display:none!important}.navbar,.main-content{padding:0!important;max-width:none!important}body{background:#fff!important}.test-paper{padding:1cm;box-shadow:none}.page-break{page-break-before:always}.test-questions,.answer-grid{grid-template-columns:repeat(2,1fr)}}.wrong-words-page{max-width:900px;margin:0 auto}.wrong-words-page .page-header{display:block;margin-bottom:1.5rem}.wrong-words-page .page-header h1{margin-bottom:.5rem}.page-description{color:var(--text-muted);font-size:.9rem}.empty-wrong-words{text-align:center;padding:4rem 2rem;background:var(--bg-primary);border-radius:16px;border:1px solid var(--border-light)}.empty-icon{font-size:3rem;margin-bottom:1rem;filter:grayscale(100%)}.empty-wrong-words h2{color:var(--text-primary);margin-bottom:.5rem;font-size:1.2rem}.empty-wrong-words p{color:var(--text-muted);margin-bottom:2rem}.empty-wrong-words .btn-primary{width:auto;display:inline-block;padding:.875rem 2rem}.wrong-words-summary{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem;margin-bottom:1.5rem}.summary-card{background:var(--bg-primary);padding:1.25rem;border-radius:12px;border:1px solid var(--border-light);display:flex;align-items:center;gap:1rem}.summary-card.review-card{background:var(--primary);color:var(--bg-primary);cursor:pointer;transition:transform .2s,box-shadow .2s;border:none}.summary-card.review-card:hover{transform:translateY(-2px);box-shadow:0 4px 12px #0003}.summary-icon{font-size:1.5rem;filter:grayscale(100%)}.review-card .summary-icon{filter:none}.summary-content{display:flex;flex-direction:column}.summary-value{font-size:1.75rem;font-weight:700;color:var(--primary)}.review-card .summary-value{color:var(--bg-primary)}.summary-label{font-size:.85rem;color:var(--text-muted)}.review-card .summary-label{color:var(--bg-primary);font-weight:500}.summary-sub{font-size:.8rem;opacity:.9}.wrong-words-controls{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem;padding:1rem;background:var(--bg-primary);border-radius:10px;border:1px solid var(--border-light)}.control-group{display:flex;align-items:center;gap:.75rem}.control-group label{font-weight:500;color:var(--text-muted);font-size:.9rem}.control-group select{padding:.5rem 1rem;border:1px solid var(--border);border-radius:8px;font-size:.9rem;background:var(--bg-primary)}.wrong-words-list{display:flex;flex-direction:column;gap:.75rem}.wrong-word-card{display:flex;align-items:center;gap:1rem;padding:1.25rem;background:var(--bg-primary);border-radius:12px;border:1px solid var(--border-light);border-left:4px solid var(--border);transition:transform .2s,box-shadow .2s}.wrong-word-card:hover{transform:translate(4px);box-shadow:0 4px 12px #00000014}.wrong-word-card.medium-error{border-left-color:var(--text-secondary)}.wrong-word-card.high-error{border-left-color:var(--primary)}.word-rank{width:36px;height:36px;display:flex;align-items:center;justify-content:center;background:var(--bg-tertiary);border-radius:50%;font-weight:600;color:var(--text-secondary);font-size:.9rem}.word-main{flex:1;min-width:0}.word-english{font-size:1.1rem;font-weight:600;color:var(--primary);margin-bottom:.25rem}.word-korean{color:var(--text-secondary);font-size:.95rem}.word-stats{display:flex;gap:1.5rem}.stat-item{display:flex;flex-direction:column;align-items:center;min-width:50px}.stat-label{font-size:.75rem;color:var(--text-muted);margin-bottom:.25rem}.stat-value{font-weight:600;color:var(--text-primary)}.stat-value.wrong{color:var(--text-primary)}.stat-value.high{color:var(--primary)}.wrong-words-tip{display:flex;align-items:flex-start;gap:1rem;margin-top:1.5rem;padding:1.25rem;background:var(--bg-secondary);border-radius:12px;border:1px solid var(--border)}.tip-icon{font-size:1.5rem;filter:grayscale(100%)}.tip-content{color:var(--text-secondary);font-size:.9rem;line-height:1.6}.tip-content strong{display:block;margin-bottom:.25rem;color:var(--text-primary)}.tab-navigation{display:flex;gap:.5rem;margin-bottom:1.5rem;background:var(--bg-primary);padding:.5rem;border-radius:12px;border:1px solid var(--border-light)}.tab-button{flex:1;padding:.875rem 1.5rem;background:transparent;border:none;border-radius:8px;font-size:.9rem;font-weight:500;color:var(--text-muted);cursor:pointer;transition:all .2s}.tab-button:hover{background:var(--bg-tertiary);color:var(--text-primary)}.tab-button.active{background:var(--primary);color:var(--bg-primary)}.assignment-create-page{max-width:1000px;margin:0 auto}.tab-content{background:var(--bg-primary);border-radius:12px;border:1px solid var(--border-light);padding:1.5rem;margin-bottom:1rem;min-height:400px}.manual-selection{max-height:500px;overflow-y:auto}.assignment-actions{display:flex;justify-content:space-between;align-items:center;padding:1rem 1.5rem;background:var(--bg-primary);border-radius:12px;border:1px solid var(--border-light);position:sticky;bottom:1rem}.assignment-actions .selected-count{font-weight:600;color:var(--primary)}.assignment-actions .action-buttons{display:flex;gap:.75rem}.assignment-actions .btn-primary,.assignment-actions .btn-secondary{width:auto;padding:.75rem 1.5rem}.students-page-v2{display:flex;gap:1.5rem;height:calc(100vh - 140px);min-height:500px}.students-list-panel{width:320px;flex-shrink:0;background:var(--bg-primary);border-radius:12px;border:1px solid var(--border-light);display:flex;flex-direction:column;overflow:hidden}.students-list-panel .panel-header{display:flex;justify-content:space-between;align-items:center;padding:1rem 1.25rem;border-bottom:1px solid var(--border)}.students-list-panel .panel-header h2{font-size:1rem;font-weight:600;color:var(--text-primary);margin:0}.create-actions{display:flex;gap:.5rem;padding:.75rem 1rem;border-bottom:1px solid var(--border)}.btn-create{flex:1;padding:.5rem .75rem;font-size:.8rem;font-weight:500;border:1px dashed var(--primary);background:transparent;color:var(--primary);border-radius:6px;cursor:pointer;transition:all .15s}.btn-create:hover{background:var(--primary);color:#fff;border-style:solid}.students-list{flex:1;overflow-y:auto;padding:.5rem}.students-list .empty-list{text-align:center;padding:2rem 1rem;color:var(--text-muted)}.students-list .empty-list p{margin-bottom:1rem}.student-list-item{display:flex;align-items:center;gap:.75rem;padding:.75rem 1rem;border-radius:8px;cursor:pointer;transition:all .2s;margin-bottom:.25rem}.student-list-item:hover{background:var(--bg-tertiary)}.student-list-item.selected{background:var(--bg-tertiary);border-left:3px solid var(--primary)}.student-avatar{width:40px;height:40px;border-radius:50%;background:var(--primary);color:var(--bg-primary);display:flex;align-items:center;justify-content:center;font-weight:600;font-size:1rem;flex-shrink:0}.student-brief{flex:1;min-width:0}.student-brief .student-name{display:block;font-weight:500;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.student-brief .student-email{display:block;font-size:.8rem;color:var(--text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.student-detail-panel{flex:1;background:var(--bg-primary);border-radius:12px;border:1px solid var(--border-light);display:flex;flex-direction:column;overflow:hidden}.student-detail-panel .no-selection{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;color:var(--text-muted)}.student-detail-panel .no-selection-icon{font-size:3rem;margin-bottom:1rem;filter:grayscale(100%)}.student-detail-header{display:flex;justify-content:space-between;align-items:flex-start;padding:1.5rem;border-bottom:1px solid var(--border)}.student-profile{display:flex;gap:1rem;align-items:center}.student-avatar-large{width:64px;height:64px;border-radius:50%;background:var(--primary);color:var(--bg-primary);display:flex;align-items:center;justify-content:center;font-weight:600;font-size:1.5rem}.student-info h2{margin:0 0 .25rem;font-size:1.2rem;color:var(--text-primary)}.student-info .email{color:var(--text-muted);margin:0 0 .25rem;font-size:.9rem}.student-info .join-date{font-size:.8rem;color:var(--text-muted);margin:0}.detail-tabs{display:flex;gap:0;border-bottom:1px solid var(--border);padding:0 1rem}.detail-tabs .tab-btn{padding:.875rem 1.25rem;background:none;border:none;border-bottom:2px solid transparent;color:var(--text-muted);font-weight:500;cursor:pointer;transition:all .2s;font-size:.9rem}.detail-tabs .tab-btn:hover{color:var(--primary)}.detail-tabs .tab-btn.active{color:var(--primary);border-bottom-color:var(--primary)}.student-detail-panel .detail-content{flex:1;min-height:0;overflow-y:auto;padding:1.5rem}.overview-tab .stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem;margin-bottom:2rem}.overview-tab .stat-card{background:var(--bg-secondary);border-radius:10px;padding:1rem;display:flex;align-items:center;gap:.75rem;border:1px solid var(--border-light)}.overview-tab .stat-card.warning{background:var(--bg-tertiary)}.overview-tab .stat-icon{font-size:1.5rem;filter:grayscale(100%)}.overview-tab .stat-info{display:flex;flex-direction:column}.overview-tab .stat-value{font-size:1.5rem;font-weight:700;color:var(--text-primary)}.overview-tab .stat-label{font-size:.8rem;color:var(--text-muted)}.difficult-section{background:var(--bg-secondary);border-radius:10px;padding:1.25rem;border:1px solid var(--border-light)}.difficult-section h3{margin:0 0 1rem;font-size:.95rem;color:var(--text-primary)}.difficult-words-list{display:flex;flex-direction:column;gap:.5rem}.difficult-word-item{display:flex;align-items:center;gap:.75rem;padding:.5rem 0;border-bottom:1px dashed var(--border)}.difficult-word-item:last-child{border-bottom:none}.difficult-word-item .rank{width:24px;height:24px;background:var(--text-secondary);color:var(--bg-primary);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.75rem;font-weight:600}.difficult-word-item .word{font-weight:600;color:var(--text-primary);min-width:120px}.difficult-word-item .meaning{flex:1;color:var(--text-muted)}.difficult-word-item .error-rate{color:var(--text-primary);font-weight:500;font-size:.85rem}.wrong-words-grouped{display:flex;flex-direction:column;gap:1rem}.wrong-group-textbook{border:1px solid var(--border);border-radius:12px;overflow:hidden}.wrong-group-header{display:flex;justify-content:space-between;align-items:center;padding:.85rem 1.25rem;cursor:pointer;-webkit-user-select:none;user-select:none;transition:background .15s}.wrong-group-header:hover{background:var(--bg-tertiary)}.group-header-left{display:flex;align-items:center;gap:.6rem}.group-toggle{font-size:.7rem;color:var(--text-muted);width:1rem;text-align:center}.textbook-header{background:var(--bg-secondary);border-bottom:1px solid var(--border-light)}.textbook-header .group-title{font-weight:700;font-size:.95rem;color:var(--text-primary)}.unit-header{background:var(--bg-primary);border-bottom:1px solid var(--border-light);padding-left:2rem}.unit-header .group-title{font-weight:600;font-size:.88rem;color:var(--text-secondary)}.group-count{font-size:.8rem;font-weight:600;color:var(--text-muted);background:var(--bg-tertiary);padding:.2rem .6rem;border-radius:10px}.wrong-group-units{display:flex;flex-direction:column}.wrong-group-unit .wrong-words-list{padding:.5rem .5rem .5rem 2rem}.wrong-words-tab .wrong-words-list{display:flex;flex-direction:column;gap:.75rem}.wrong-word-detail{background:var(--bg-secondary);border-radius:10px;overflow:hidden;border:1px solid var(--border-light)}.wrong-word-main{display:flex;justify-content:space-between;align-items:center;padding:1rem 1.25rem}.wrong-word-main .word-content{display:flex;flex-direction:column;gap:.25rem}.wrong-word-main .english{font-weight:600;color:var(--text-primary)}.wrong-word-main .korean{font-size:.9rem;color:var(--text-muted)}.wrong-word-main .word-meta{display:flex;align-items:center;gap:.75rem;font-size:.8rem}.wrong-word-main .wrong-count{color:var(--text-secondary);font-weight:600}.wrong-word-main .wrong-count.high{color:var(--primary)}.wrong-word-main .textbook{color:var(--text-muted);background:var(--bg-tertiary);padding:.2rem .5rem;border-radius:4px}.btn-toggle-history{background:var(--bg-tertiary);border:none;padding:.25rem .5rem;border-radius:4px;font-size:.75rem;cursor:pointer;color:var(--text-secondary)}.btn-toggle-history:hover{background:var(--border)}.wrong-history{background:var(--bg-tertiary);padding:1rem 1.25rem;border-top:1px solid var(--border)}.wrong-history .history-title{font-weight:600;font-size:.85rem;color:var(--text-primary);margin-bottom:.5rem}.wrong-history .history-row{display:flex;justify-content:space-between;padding:.35rem 0;font-size:.85rem;border-bottom:1px dashed var(--border)}.wrong-history .history-row:last-child{border-bottom:none}.wrong-history .history-date{color:var(--text-muted)}.wrong-history .history-answer{color:var(--text-secondary);font-style:italic}.homework-tab{padding:.5rem 0}.student-homework-list{display:flex;flex-direction:column;gap:.75rem}.student-homework-item{display:flex;justify-content:space-between;align-items:center;background:var(--bg-secondary);border-radius:10px;padding:1rem 1.25rem;border:1px solid var(--border-light);text-decoration:none;color:inherit;transition:all .2s ease}.student-homework-item:hover{border-color:var(--primary-light);background:var(--bg-tertiary)}.student-homework-item.pending{border-left:3px solid var(--text-muted)}.student-homework-item.submitted{border-left:3px solid var(--warning)}.student-homework-item.graded{border-left:3px solid var(--success)}.homework-main-info h4{margin:0 0 .25rem;font-size:1rem;font-weight:600;color:var(--text-primary)}.homework-main-info .homework-desc{margin:0;font-size:.85rem;color:var(--text-muted);display:-webkit-box;-webkit-line-clamp:1;-webkit-box-orient:vertical;overflow:hidden}.homework-meta-info{display:flex;align-items:center;gap:.75rem;flex-shrink:0}.homework-meta-info .due-date{font-size:.8rem;color:var(--text-muted)}.homework-meta-info .status-badge{font-size:.75rem;font-weight:600;padding:.25rem .6rem;border-radius:4px}.homework-meta-info .status-badge.pending{background:var(--bg-tertiary);color:var(--text-muted)}.homework-meta-info .status-badge.submitted{background:#ff9f0a26;color:var(--warning)}.homework-meta-info .status-badge.graded{background:#34c75926;color:var(--success)}.homework-meta-info .grade-badge{font-size:.8rem;font-weight:700;color:var(--primary);background:#007aff1a;padding:.25rem .5rem;border-radius:4px}.student-tests-list{display:flex;flex-direction:column;gap:.5rem}.student-test-item{border:1px solid #e5e7eb;border-radius:8px;overflow:hidden;background:#fff}.test-main-info{display:flex;justify-content:space-between;align-items:center;padding:.75rem 1rem;cursor:pointer;transition:background .15s}.test-main-info:hover{background:#f9fafb}.test-left{display:flex;align-items:center;gap:.75rem}.test-type-badge{font-size:.7rem;font-weight:600;padding:.2rem .5rem;border-radius:4px;background:var(--primary);color:#fff;white-space:nowrap}.test-title-area h4{margin:0;font-size:.9rem;font-weight:600;color:var(--text-primary)}.test-date{font-size:.75rem;color:var(--text-secondary)}.test-right{display:flex;align-items:center;gap:.75rem}.test-score{font-weight:700;font-size:.85rem;padding:.2rem .6rem;border-radius:4px}.test-score.high{color:#059669;background:#ecfdf5}.test-score.mid{color:#d97706;background:#fffbeb}.test-score.low{color:#dc2626;background:#fef2f2}.test-expand-toggle{font-size:.7rem;color:var(--text-secondary)}.test-results-detail{border-top:1px solid #e5e7eb;padding:.5rem;background:#fafafa}.test-results-table{width:100%;border-collapse:collapse;font-size:.8rem}.test-results-table th{text-align:left;padding:.4rem .6rem;border-bottom:1px solid #e5e7eb;font-weight:600;color:var(--text-secondary);font-size:.75rem}.test-results-table td{padding:.4rem .6rem;border-bottom:1px solid #f3f4f6}.test-results-table tr.wrong td{color:#dc2626;background:#fef2f2}.test-results-table tr.correct td{color:#059669}.btn-override{font-size:.7rem;padding:.2rem .5rem;border:1px solid var(--primary);background:#fff;color:var(--primary);border-radius:4px;cursor:pointer;white-space:nowrap;transition:all .15s}.btn-override:hover{background:var(--primary);color:#fff}.create-exam-content,.create-homework-content{display:flex;flex-direction:column;gap:1rem}.unit-chips,.vocab-chips,.student-chips{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:.5rem;max-height:200px;overflow-y:auto;padding:.5rem;background:var(--bg-secondary);border-radius:8px}.unit-chip,.vocab-chip,.student-chip{padding:.4rem .75rem;font-size:.8rem;border:1px solid var(--border);background:#fff;border-radius:20px;cursor:pointer;transition:all .15s;-webkit-user-select:none;user-select:none}.unit-chip:hover,.vocab-chip:hover,.student-chip:hover{border-color:var(--primary)}.unit-chip.selected,.vocab-chip.selected,.student-chip.selected{background:var(--primary);color:#fff;border-color:var(--primary)}.vocab-chip{display:flex;align-items:center;gap:.4rem}.vocab-chip .chip-num{font-size:.7rem;color:var(--text-muted);font-weight:600}.vocab-chip.selected .chip-num{color:#fffc}.attachments-list{display:flex;flex-direction:column;gap:.5rem}.attachments-list .attachment-item{display:flex;justify-content:space-between;align-items:center;padding:.5rem .75rem;background:var(--bg-secondary);border-radius:6px;font-size:.85rem}@media (max-width: 768px){.navbar{padding:0 1rem;flex-wrap:wrap;height:auto;min-height:60px}.navbar-brand{order:1}.navbar-user{order:2}.navbar-menu{order:3;width:100%;padding:.75rem 0;gap:.75rem;font-size:.8rem;flex-wrap:wrap;justify-content:center;border-top:1px solid var(--border)}.main-content{padding:1rem}.modal{padding:1.5rem}.stats-section{grid-template-columns:repeat(2,1fr)}.review-banner{flex-direction:column;text-align:center;gap:1rem}.upload-category-row{flex-direction:column}.vocab-word-row,.vocab-accordion-header.unit-level{padding-left:1.5rem}.browser-layout{grid-template-columns:1fr}.vocab-item{grid-template-columns:30px 30px 1fr}.vocab-meaning{grid-column:1 / -1;padding-left:70px;margin-top:-.5rem}.wrong-words-summary{grid-template-columns:1fr 1fr}.wrong-words-summary .summary-card:last-child{grid-column:1 / -1}.wrong-word-card{flex-wrap:wrap}.word-stats{width:100%;justify-content:flex-start;padding-top:.75rem;margin-top:.75rem;border-top:1px solid var(--border);gap:1rem}.stat-item{flex-direction:row;gap:.5rem}.config-actions{flex-direction:column;align-items:stretch}.config-actions .btn-large{min-width:auto}}@media (max-width: 1024px){.students-page-v2{flex-direction:column;height:auto}.students-list-panel{width:100%;max-height:300px}.student-detail-panel{overflow:visible}.student-detail-panel .detail-content{overflow-y:visible}.overview-tab .stats-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width: 640px){.overview-tab .stats-grid{grid-template-columns:1fr}.student-detail-header{flex-direction:column;gap:1rem}.wrong-word-main{flex-direction:column;align-items:flex-start;gap:.5rem}.wrong-word-main .word-meta{flex-wrap:wrap}}
