#header{display:flex;justify-content:space-between;align-items:center;padding-right:10px;background-color:var(--color-surface);border-bottom:1px solid var(--color-border-strong);height:60px}.header-left{display:flex;align-items:center}.header-right{display:flex;align-items:center;gap:15px}.user-avatar{width:36px;height:36px;border-radius:50%;object-fit:cover;border:1px solid var(--color-border);background-color:var(--color-surface-muted);display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:600;color:var(--color-muted-text)}.user-avatar.fallback{text-transform:uppercase}.user-info{display:flex;flex-direction:column;align-items:flex-end;font-size:14px}.user-name{font-weight:600;color:var(--color-text)}.user-email{color:var(--color-muted-text);font-size:12px}.logout-btn{padding:8px 16px;background-color:var(--color-button-default);border:1px solid var(--color-border);border-radius:6px;color:var(--color-text);font-size:14px;cursor:pointer;transition:all .2s ease}.logout-btn:hover{background-color:var(--color-button-hover);border-color:var(--color-border)}#header-logo{height:40px;width:auto}@media (max-width: 768px){#header{padding:0 15px}.user-info{display:none}.user-avatar{width:32px;height:32px}.logout-btn{padding:6px 12px;font-size:12px}}.recursive-node{list-style-type:none}.node-content{display:flex;align-items:center;padding:5px 0;color:var(--color-text)}.node-content:hover{background-color:var(--color-hover)}.node-content.selected{background-color:var(--color-active-bg)}.node-content.selected:hover{background-color:var(--color-hover)}.expand-toggle{cursor:pointer;margin-right:5px;width:20px;text-align:center}.expand-toggle.placeholder{margin-right:5px;width:20px}.node-checkbox{margin-right:13px;-webkit-appearance:none;-moz-appearance:none;appearance:none;cursor:pointer;width:1rem;height:1rem;border-radius:15%;border:1px solid var(--color-border);vertical-align:middle;background-color:var(--color-input-bg);position:relative;transition:background-color .2s,border-color .2s}.node-checkbox:checked{background-color:var(--color-success);border-color:var(--color-success)}.node-checkbox:checked:before{content:"";position:absolute;left:50%;top:50%;width:.3rem;height:.6rem;border:solid white;border-width:0 .125rem .125rem 0;transform:translate(-50%,-60%) rotate(45deg)}.node-checkbox:indeterminate{background-color:var(--color-success);border-color:var(--color-success)}.node-checkbox:indeterminate:before{content:"";position:absolute;left:50%;top:50%;width:.6rem;height:.125rem;background-color:#fff;transform:translate(-50%,-50%);border-radius:1px}.node-checkbox:focus-visible{outline:2px solid dodgerblue;outline-offset:2px}.sa-id{margin-left:5px;color:var(--color-text-soft)}.leaf-count{margin-left:8px;color:var(--color-muted-text);font-size:15px}.children-list{padding-left:0;margin:0}.node-title{width:100%;cursor:pointer;font-weight:500}.recursive-node .node-title{color:var(--color-text)}:root[data-theme=dark] .node-content.selected{background-color:#5c93ff47}:root[data-theme=dark] .node-content.selected:hover{background-color:#5c93ff61}.curriculum-row{border-bottom:1px solid var(--color-border)}.curriculum-row.selected{background-color:var(--color-active-bg)}.curriculum-row.selected:hover{background-color:var(--color-hover)}:root[data-theme=dark] .curriculum-row.selected{background-color:#5c93ff47}:root[data-theme=dark] .curriculum-row.selected:hover{background-color:#5c93ff61}.curriculum-header{padding:12px;cursor:pointer}.expand-toggle{margin-right:8px;width:20px;text-align:center;display:inline-block}.type-tag{display:inline-block;border-radius:10px;font-size:.8em;font-weight:400;color:#fff}.curriculum-name{font-weight:500}.curriculum-detail-row{background-color:var(--color-surface)}.curriculum-detail-cell{padding:12px;border-bottom:1px solid var(--color-border)}.curriculum-detail-td{background-color:var(--color-surface)}.curriculum-checkbox{margin-right:13px;-webkit-appearance:none;-moz-appearance:none;appearance:none;cursor:pointer;width:1rem;height:1rem;border-radius:15%;border:1px solid #888;vertical-align:middle;background-color:#fff;position:relative;transition:background-color .2s,border-color .2s}.curriculum-checkbox:checked{background-color:#329c62;border-color:#329c62}.curriculum-checkbox:checked:before{content:"";position:absolute;left:50%;top:50%;width:.3rem;height:.6rem;border:solid white;border-width:0 .125rem .125rem 0;transform:translate(-50%,-60%) rotate(45deg)}.curriculum-checkbox:indeterminate{background-color:#329c62;border-color:#329c62}.curriculum-checkbox:indeterminate:before{content:"";position:absolute;left:50%;top:50%;width:.6rem;height:.125rem;background-color:#fff;transform:translate(-50%,-50%);border-radius:1px}.curriculum-checkbox:focus-visible{outline:2px solid dodgerblue;outline-offset:2px}.question-bank-filter{margin:5px;padding:var(--spacing-xl);border:1px solid var(--color-border);border-radius:5px;background-color:var(--color-surface);color:var(--color-text);width:35%;position:sticky;top:20px;align-self:flex-start}.input-row{display:flex;gap:12px;margin-bottom:5px}.input-section{margin-bottom:0;flex:1}.input-section label{display:block;margin-bottom:6px;font-size:16px;font-weight:400;color:var(--color-text)}.filename-input{padding:var(--spacing-sm) var(--spacing-md);border:1px solid var(--color-input-border);border-radius:var(--border-radius);width:100%;height:20px;font-size:.95em;background-color:var(--color-input-bg);color:var(--color-text)}.filename-input:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 2px var(--color-focus-ring)}.shuffle-toggle{background-color:var(--color-surface);border:1px solid var(--color-border);border-radius:4px;padding:6px 10px;font-size:12px;font-weight:400;color:var(--color-text);cursor:pointer;transition:all .15s ease;-webkit-user-select:none;user-select:none;outline:none}.shuffle-toggle:hover{background-color:var(--color-hover);border-color:var(--color-border-strong);color:var(--color-text)}.shuffle-toggle.active{background-color:#abdff1;border-color:#abdff1;color:#111827}.shuffle-toggle.active:hover{background-color:#88c7dc;border-color:#88c7dc}.type-filter{width:33.33%;height:42px}.type-filter-button{height:100%;width:100%;background-color:var(--color-surface);border:1px solid var(--color-border);padding:8px;text-align:center;border-radius:5px;cursor:pointer;color:var(--color-muted-text);transition:background-color .2s ease,border-color .2s ease,color .2s ease;font-size:16px}.type-filter-button:hover{background-color:var(--color-hover)}.type-filter-button.active{background-color:#abdff1;border-color:#abdff1;color:#111827}.type-filter-button.active:hover{background-color:#88c7dc}:root[data-theme=dark] .shuffle-toggle.active,:root[data-theme=dark] .type-filter-button.active{background-color:#5c93ff59;border-color:#5c93ff;color:#f0f6ff}:root[data-theme=dark] .shuffle-toggle.active:hover,:root[data-theme=dark] .type-filter-button.active:hover{background-color:#5c93ff73}.summary-text{height:36px;font-size:18px}.selected-text-count{font-size:20px;font-weight:700;color:var(--color-success)}.selected-text-count.exceed{color:var(--color-error)}.selected-text-limit{font-size:14px}.question-count{font-size:20px;font-weight:700;color:#282}.question-bank-filter-table{width:100%}.pdf-link-td{width:33.33%}.pdf-link a{margin-top:8px;display:inline-flex;align-items:center;justify-content:center;border:1px solid var(--color-download-pdf);color:var(--color-download-pdf);text-decoration:none;border-radius:var(--border-radius);vertical-align:middle;height:40px;width:100%}.pdf-link a:hover{background-color:#f4cfcf}.submit-button{padding:var(--spacing-md) 18px;cursor:pointer;background-color:#0c4a60;border:1px solid #0C4A60;border-radius:5px;color:#ddd;font-size:16px;font-weight:var(--font-weight-bold)}.submit-button.disabled{background-color:#ccc;border-color:#ccc;cursor:default}.question-bank-new-table{width:100%;border-collapse:collapse;margin-bottom:10px}.question-bank-new-table th{padding:12px 0;border-bottom:1px solid var(--color-border);font-weight:600;text-align:left}.question-bank-new-table th:nth-child(1){width:15%}.question-bank-new-table th:nth-child(2){width:15%}.question-bank-new-table th:nth-child(3){width:15%}.question-bank-new-table th:nth-child(4){width:15%}.question-bank-new-table th:nth-child(5){width:15%}.question-bank-new-table th:nth-child(6){width:25%}.question-bank-new-table td{vertical-align:middle}.modal-side-sheet-new{position:relative;width:80%;min-width:400px;height:100%;background-color:var(--color-surface);box-shadow:-2px 0 8px var(--color-shadow);overflow-y:auto;animation:slideIn .3s ease-out;border-radius:5px 0 0 5px}.selection-button-question-bank{padding:12px 0;width:100%;height:100%;border:1px solid var(--color-border);background-color:var(--color-surface-muted);color:var(--color-text);cursor:pointer;border-radius:var(--border-radius);box-sizing:border-box;transition:background-color .2s ease,border-color .2s ease,color .2s ease;font-size:1em}.selection-button-question-bank:hover{background-color:var(--color-hover)}.selection-button-question-bank.active{background-color:var(--color-primary);border-color:var(--color-primary);color:#fff}.selection-button-question-bank.active:hover{background-color:var(--color-primary-hover)}.tableWithDifficulty-question-bank{width:420px}.tableWithoutDifficulty-question-bank{width:140px}.generation-queue-row{border-bottom:1px solid var(--color-border);height:48px;color:var(--color-text)}.generation-queue-row:hover{background-color:var(--color-hover);cursor:pointer}.generation-queue-row.selected{background-color:var(--color-active-bg)}.generation-queue-row.selected:hover{cursor:auto}.generation-queue-row td{vertical-align:middle}.btn-container{display:flex;border-radius:6px;overflow:hidden;box-shadow:0 1px 3px #0000001a;background-color:var(--color-surface);border:1px solid var(--color-border)}.first-btn,.second-btn,.third-btn{display:inline-flex;align-items:center;justify-content:center;text-decoration:none;color:var(--color-text);font-size:16px;font-weight:400;height:32px;cursor:pointer;transition:all .15s ease;border:none;background-color:var(--color-surface)}.first-btn,.second-btn{width:33%;border-right:1px solid var(--color-border)}.third-btn{width:34%}.first-btn:hover,.second-btn:hover,.third-btn:hover{background-color:var(--color-hover);color:var(--color-text);text-decoration:none}.first-btn:active,.second-btn:active,.third-btn:active{background-color:var(--color-active-bg)}.modal-backdrop{position:fixed;top:0;left:0;width:100%;height:100%;background-color:#00000080;display:flex;justify-content:flex-end;z-index:1000;animation:fadeIn .3s ease-out}:root[data-theme=dark] .modal-backdrop{background-color:#000000b3}.modal-side-sheet{position:relative;width:50%;min-width:400px;height:100%;background-color:var(--color-surface);box-shadow:-2px 0 8px var(--color-shadow);overflow-y:auto;animation:slideIn .3s ease-out;border-radius:5px 0 0 5px}.modal-side-sheet.disabled{background-color:var(--color-surface-muted);cursor:not-allowed}.modal-backdrop.closing{animation:fadeOut .3s ease-in forwards}.modal-side-sheet.closing{animation:slideOut .3s ease-in forwards}.label{margin-bottom:13px;padding-left:2px;font-size:18px;display:flex}.filename-input,.requestor-input{padding:var(--spacing-sm) var(--spacing-md);border:1px solid var(--color-input-border);border-radius:var(--border-radius);width:86%;height:20px;font-size:.95em;margin-bottom:12px;background-color:var(--color-input-bg);color:var(--color-text)}.passage-input{padding:var(--spacing-sm) var(--spacing-md);border:1px solid var(--color-input-border);border-radius:var(--border-radius);width:86%;height:20px;font-size:.95em;margin-bottom:10px;background-color:var(--color-input-bg);color:var(--color-text)}.remove-passage-btn{margin-left:1px;height:38px;width:38px;font-size:.95em;padding:var(--spacing-sm) var(--spacing-md);color:var(--color-error);background-color:var(--color-surface);border:1px solid var(--color-error)}.remove-passage-btn:hover{background-color:var(--color-error-bg)}.add-passage-btn{width:36px;height:36px;border:1px solid var(--color-border);border-radius:50%;background-color:var(--color-surface);color:var(--color-muted-text);cursor:pointer;margin-bottom:12px;justify-content:center;align-items:center;font-size:26px;font-weight:300;padding-bottom:10px;transition:all .2s ease-in-out;margin-left:43.5%}.add-passage-btn:hover{background-color:var(--color-hover);border-color:var(--color-border-strong);color:var(--color-text)}.add-passage-btn:active{background-color:var(--color-hover);transform:scale(.95)}.add-passage-btn:focus{outline:none;box-shadow:0 0 0 3px #007bff66}.edit-button{padding:var(--spacing-md) 18px;cursor:pointer;background-color:#3b82f6;border:1px solid #3b82f6;border-radius:5px;color:#ddd;font-size:16px;font-weight:var(--font-weight-bold);transition:background-color .2s ease-in-out}.delete-button{padding:var(--spacing-md) 18px;cursor:pointer;background-color:#ce3732;border:1px solid #ce3732;border-radius:5px;color:#ddd;font-size:16px;font-weight:var(--font-weight-bold);transition:background-color .2s ease-in-out}#requestorSearchInput{padding:var(--spacing-sm) var(--spacing-md);border:1px solid #b3b3b3;border-radius:var(--border-radius);width:97%;height:20px;font-size:.95em;margin-bottom:12px}.generation-queue-table{width:100%;border-collapse:collapse;margin-bottom:10px}.generation-queue-table th{padding:12px 0;border-bottom:1px solid var(--color-border);font-weight:600;text-align:left}.generation-queue-table th:nth-child(1){width:15%}.generation-queue-table th:nth-child(2){width:40%}.generation-queue-table th:nth-child(3){width:10%}.generation-queue-table th:nth-child(4){width:10%}.generation-queue-table th:nth-child(5){width:25%}.page-button{width:36px;height:32px;font-size:16px;display:flex;align-items:center;justify-content:center;margin:8px;background-color:#fff;color:#777;border:1px solid #b3b3b3}.page-button:hover{background-color:#b3b3b3}.generation-queue-text{padding-left:2px;font-size:20px}.generation-queue-row-v2{border-bottom:1px solid var(--color-border);height:48px;color:var(--color-text)}.generation-queue-row-v2:hover{background-color:var(--color-hover);cursor:pointer}.generation-queue-row-v2.selected{background-color:var(--color-active-bg)}.generation-queue-row-v2.selected:hover{cursor:auto}.generation-queue-row-v2 td{vertical-align:middle}.queue-progress-meta{display:flex;gap:10px;font-size:13px;color:var(--color-muted-text);line-height:1;flex-wrap:wrap}.queue-progress-meta-top{margin-bottom:6px}.queue-progress-meta-item{display:inline-flex;align-items:center;gap:6px;padding:5px 10px;border-radius:999px;background-color:var(--color-surface-muted);border:1px solid var(--color-border);color:var(--color-text);font-weight:600}.queue-progress-meta-item.success{color:var(--color-success-text);border-color:var(--color-success-border);background-color:var(--color-success-bg)}.queue-progress-meta-item.failure{color:var(--color-error-text);border-color:var(--color-error-border);background-color:var(--color-error-bg)}.queue-progress-meta-item.pending{color:var(--color-info-text);border-color:var(--color-info-border);background-color:var(--color-info-bg)}:root[data-theme=dark] .queue-progress-meta-item.success{background:linear-gradient(135deg,#45f0a333,#45f0a373);border-color:#45f0a3b3;color:#d8fff0;box-shadow:0 0 10px #45f0a32e}:root[data-theme=dark] .queue-progress-meta-item.failure{background:linear-gradient(135deg,#ff5b7a33,#ff5b7a7a);border-color:#ff5b7ab3;color:#ffd1dc;box-shadow:0 0 10px #ff5b7a2e}:root[data-theme=dark] .queue-progress-meta-item.pending{background:linear-gradient(135deg,#5c93ff33,#5c93ff7a);border-color:#5c93ffb3;color:#d5e4ff;box-shadow:0 0 10px #5c93ff2e}.queue-progress-success{display:block;height:100%;background-color:#24b46a}.queue-progress-failure{display:block;height:100%;background-color:#e75b5b}.requestor-avatar{width:28px;height:28px;border-radius:50%;object-fit:cover;border:1px solid var(--color-border);background-color:var(--color-surface-muted);flex-shrink:0}.passage-preview{max-width:100%;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.generation-queue-row-v2 td.passage-preview{color:var(--color-text);font-weight:inherit}.content-type-badge{display:inline-flex;align-items:center;justify-content:center;width:32px;height:32px;padding:2px;box-sizing:border-box;border-radius:8px;font-size:11px;font-weight:700;letter-spacing:.2px;border:1px solid var(--color-border);background-color:var(--color-surface);color:var(--color-text);box-shadow:0 1px 0 var(--color-shadow)}.content-type-badge.mc{border-color:#45f0a373;background:linear-gradient(180deg,#61f7b72e,#45f0a347 60%,#29c88759);color:var(--color-success-text)}.content-type-badge.mcm{border-color:#5c93ff73;background:linear-gradient(180deg,#9cbeff33,#5c93ff52 60%,#3e70dc66);color:var(--color-info-text)}.btn-container{border:1px solid var(--color-border);border-radius:var(--border-radius)}.first-btn,.second-btn{display:inline-flex;align-items:center;justify-content:center;border:none;border-right:1px solid var(--color-border);color:var(--color-text);background-color:transparent;vertical-align:middle;height:37px;width:33%;cursor:pointer}.third-btn{display:inline-flex;align-items:center;justify-content:center;border:none;color:var(--color-text);background-color:transparent;vertical-align:middle;height:37px;width:32%;cursor:pointer}.pdf-download{width:20%}.pdf-download a:hover{color:var(--color-error);font-weight:600}:root[data-theme=dark] .generation-queue-row-v2 .ExternalLinkIcon a{color:var(--color-primary)}:root[data-theme=dark] .generation-queue-row-v2 .ExternalLinkIcon a:hover{color:var(--color-primary-hover)}#presetField-v2{width:600px;gap:.3rem;display:grid;grid-template-columns:repeat(3,1fr);margin-bottom:8px}.presetButton-v2{border:1px solid var(--color-border);background-color:var(--color-surface-muted);height:42px;width:200px;color:var(--color-text);cursor:pointer;border-radius:var(--border-radius);transition:background-color .2s ease,border-color .2s ease,color .2s ease;font-size:1em}.presetButton-v2:hover{background-color:var(--color-hover)}.presetButton-v2.active{background-color:#ef6c33;border-color:#ef6c33;color:#fff}.presetButton-v2.active:hover{background-color:#d95c2a}.edit-content-button{background-color:#3b82f6;padding:var(--spacing-sm) var(--spacing-md);border:1px solid #3b82f6;border-radius:var(--border-radius);width:15%;height:38px;font-size:.95em;color:#fff;cursor:pointer}.edit-content-button:hover{background-color:#2563eb}.edit-content-button.disabled,.edit-content-button.disabled:hover{background-color:#6c757d;border:1px solid #6c757d;cursor:default}.generation-queue-form{border-radius:5px;border:1px solid var(--color-border);padding:18px;background-color:var(--color-surface);color:var(--color-text)}.generation-queue-form.disabled{background-color:var(--color-surface-muted);cursor:not-allowed}.generation-queue-form.disabled>*{pointer-events:none}.generation-queue-form.disabled .form-overlay{position:absolute;top:0;left:0;width:100%;height:100%;background-color:#00000014;z-index:10;display:flex;justify-content:center;align-items:center;font-size:1.2rem;font-weight:700;color:var(--color-muted-text);border-radius:8px}.generation-queue-form.disabled input,.generation-queue-form.disabled button{opacity:.7}.edit-button{width:20%;background-color:#3b82f6;transition:background-color .2s ease-in-out}.edit-button:hover{background-color:#2563eb}.delete-button{width:20%;background-color:#ce3732;transition:background-color .2s ease-in-out}.delete-button:hover{background-color:#c82333}.passage-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:6px}.passage-sort-btn{position:relative;background-color:transparent;color:#fff;border:none;padding:10px 0 10px 36px;border-radius:6px;font-size:14px;font-weight:500;cursor:pointer;display:flex;align-items:center;gap:6px;color:var(--color-text);transition:all .2s ease-in-out;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none;outline:none;margin:0 11% 0 0;width:auto;height:auto}.passage-sort-btn:hover{background-color:var(--color-hover)}.passage-sort-btn:before{content:"";position:absolute;left:10px;top:50%;transform:translateY(-50%);width:16px;height:16px;border:2px solid var(--color-input-border);border-radius:3px;background-color:var(--color-input-bg);display:flex;align-items:center;justify-content:center;font-weight:700;color:var(--color-text);transition:all .2s ease-in-out}.passage-sort-btn:not(.active):hover{border-color:var(--color-input-border)}.passage-sort-btn.active:before{content:"✔"}.edit-area{margin-top:12px;display:flex;justify-content:space-between;align-items:flex-start}.content-textarea{flex:1;height:400px;padding:var(--spacing-sm) var(--spacing-md);border:1px solid var(--color-primary);border-radius:var(--border-radius);font-size:16px;font-family:inherit;resize:vertical;background-color:var(--color-input-bg);max-width:80%;min-width:80%;line-height:1.5}.content-textarea:focus{outline:none;box-shadow:0 0 0 2px var(--color-focus-ring)}.edit-buttons-group{display:flex;flex-direction:column;gap:2px;flex-shrink:0;width:15%;align-items:flex-end}.save-button,.cancel-button{padding:var(--spacing-sm) var(--spacing-md);border:1px solid transparent;border-radius:var(--border-radius);color:#fff;font-weight:500;cursor:pointer;white-space:nowrap;transition:background-color .2s ease-in-out;width:100%;font-size:.95rem}.save-button{background-color:#28a745}.save-button:hover{background-color:#218838}.cancel-button{background-color:#6c757d}.cancel-button:hover{background-color:#5a6268}.content-section{border:1px dashed var(--color-border);border-radius:8px;padding:20px 10px;margin-bottom:16px;width:95%}.content-item{padding-left:10px;padding-right:10px;margin-bottom:16px}.content-item:last-child{margin-bottom:0}.content-header{display:flex;justify-content:flex-start;align-items:center;margin-bottom:8px;gap:12px}.content-label{font-weight:600;color:var(--color-text);min-width:225px;font-size:16px}.content-row{display:flex;justify-content:space-between;align-items:center}.content{flex:1;padding:var(--spacing-sm) var(--spacing-md);border:1px solid var(--color-border);border-radius:var(--border-radius);min-width:80%;max-width:80%;height:20px;font-size:.95em;background-color:var(--color-surface-alt);color:var(--color-text)}.content:disabled{background-color:var(--color-surface-muted);color:var(--color-muted-text);border-color:var(--color-border-strong)}.content-checkbox{-moz-appearance:none;appearance:none;-webkit-appearance:none;width:32px;height:32px;border:2px solid var(--color-primary);border-radius:6px;background:var(--color-surface-muted);box-shadow:0 1px 3px var(--color-shadow);cursor:pointer;position:relative;transition:border-color .2s,box-shadow .2s,background .2s;vertical-align:middle;outline:none;flex-shrink:0}.content-checkbox:checked{background:linear-gradient(135deg,var(--color-primary) 60%,var(--color-primary-hover) 100%);border-color:var(--color-primary-hover)}.content-checkbox:checked:after{content:"";position:absolute;left:9px;top:2px;width:8px;height:15px;border:solid #fff;border-width:0 3px 3px 0;transform:rotate(45deg)}.content-checkbox:focus{box-shadow:0 0 0 2px var(--color-focus-ring);border-color:var(--color-primary)}#generation-queue-layout-container{display:block}#requestorSearchInput{padding:var(--spacing-sm) var(--spacing-md);border:1px solid var(--color-input-border);border-radius:var(--border-radius);width:97%;height:20px;font-size:.95em;margin-bottom:12px;background-color:var(--color-input-bg);color:var(--color-text)}.generation-queue-table-v2{width:100%;border-collapse:collapse;margin-bottom:10px}.generation-queue-table-v2 th{padding:12px 0;border-bottom:1px solid var(--color-border);font-weight:600;text-align:left;color:var(--color-text);background-color:var(--color-surface-alt)}.generation-queue-table-v2 th:nth-child(1){width:12%}.generation-queue-table-v2 th:nth-child(2){width:12%}.generation-queue-table-v2 th:nth-child(3){width:28%}.generation-queue-table-v2 th:nth-child(4){width:12%}.generation-queue-table-v2 th:nth-child(5){width:12%}.generation-queue-table-v2 th:nth-child(6){width:12%}.generation-queue-table-v2 th:nth-child(7){width:12%}.add-form-btn{background-color:var(--color-primary);color:#fff;border:none;padding:8px 16px;border-radius:6px;font-size:14px;font-weight:500;cursor:pointer;display:flex;align-items:center;gap:6px;transition:background-color .2s ease;margin:0;width:auto;height:auto}.add-form-btn:hover{background-color:var(--color-primary-hover)}.page-button{width:36px;height:32px;font-size:16px;display:flex;align-items:center;justify-content:center;margin:8px;background-color:var(--color-surface);color:var(--color-muted-text);border:1px solid var(--color-border)}.refresh-btn{background-color:var(--color-surface);color:var(--color-text);border:1px solid var(--color-border);padding:8px 14px;border-radius:6px;font-size:14px;font-weight:500;cursor:pointer;transition:background-color .2s ease,border-color .2s ease,color .2s ease}.refresh-btn:hover{background-color:var(--color-hover);border-color:var(--color-border-strong);color:var(--color-text)}.generation-queue-text{padding-left:2px;font-size:20px;color:var(--color-text)}.dialogue-comm-panel{border:1px solid var(--color-border);background-color:var(--color-surface-muted);border-radius:12px;padding:14px;margin-bottom:12px}.dialogue-comm-header{display:flex;align-items:center;justify-content:space-between;gap:12px}.dialogue-comm-title{font-size:14px;font-weight:600;color:var(--color-text)}.dialogue-comm-tabs{margin-top:10px;display:flex;flex-wrap:wrap;gap:6px}.dialogue-comm-tab{padding:6px 10px;border-radius:999px;border:1px solid var(--color-border);background-color:var(--color-surface);color:var(--color-text);font-size:12px;cursor:pointer;transition:background-color .2s ease,border-color .2s ease,color .2s ease}.dialogue-comm-tab:hover{background-color:var(--color-hover)}.dialogue-comm-tab.active{background-color:var(--color-active-bg);border-color:var(--color-active-text);color:var(--color-active-text)}.dialogue-comm-functions{margin-top:10px;display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:8px;max-height:320px;overflow-y:auto;padding-right:4px}.dialogue-comm-function-item{display:flex;align-items:center;gap:8px;font-size:13px;padding:8px 10px;border-radius:10px;background-color:var(--color-surface);border:1px solid var(--color-border);cursor:pointer;transition:border-color .2s ease,box-shadow .2s ease;color:var(--color-text)}.dialogue-comm-function-item input[type=radio]{accent-color:var(--color-primary)}.dialogue-comm-function-item:hover{border-color:var(--color-border-strong);box-shadow:0 1px 2px var(--color-shadow)}#sa-to-cc-layout-container{display:block}.label{margin-bottom:13px;padding-left:2px;font-size:18px;font-weight:600;display:flex;color:var(--color-text)}#cmsUrlSearchInput{padding:var(--spacing-sm) var(--spacing-md);border:1px solid var(--color-input-border);border-radius:var(--border-radius);width:70%;height:20px;font-size:.95em;background-color:var(--color-input-bg);color:var(--color-text)}.search-input-group{display:flex;gap:12px;align-items:center;margin-bottom:20px}.search-btn{background-color:var(--color-primary);color:#fff;border:none;padding:8px 16px;border-radius:6px;font-size:14px;font-weight:500;cursor:pointer;display:flex;align-items:center;gap:6px;transition:background-color .2s ease;margin:0;width:auto;height:38px}.search-btn:hover:not(:disabled){background-color:var(--color-primary-hover)}.search-btn:disabled{background-color:var(--color-button-default);color:var(--color-muted-text);cursor:not-allowed}.search-btn:active{transform:scale(.95)}.results-table{width:100%;border-collapse:collapse;margin-bottom:10px}.results-table th{padding:12px 0;border-bottom:1px solid var(--color-border);font-weight:600;text-align:left;vertical-align:middle;color:var(--color-text)}.results-table th:nth-child(1){width:6%}.results-table th:nth-child(2){width:5%}.results-table th:nth-child(3){width:40%}.results-table th:nth-child(4){width:20%}.results-table th:nth-child(5){width:20%}.result-row{border-bottom:1px solid var(--color-border);transition:background-color .2s ease;color:var(--color-text)}.result-row td{padding:12px 0;vertical-align:middle}.cc-id-cell{font-weight:600;color:var(--color-primary)}.title-cell{font-weight:500;color:var(--color-text)}.description-cell{color:var(--color-muted-text);font-size:.9em;line-height:1.4}.list-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}.results-text{font-size:18px;font-weight:600;color:var(--color-text)}.no-results{text-align:center;padding:40px;color:var(--color-muted-text);font-size:16px;background-color:var(--color-surface-alt);border-radius:8px;border:1px dashed var(--color-border);margin-top:20px}.loading-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background-color:#00000059;display:flex;flex-direction:column;justify-content:center;align-items:center;z-index:1000}.spinner{width:40px;height:40px;border:4px solid var(--color-surface-muted);border-top:4px solid var(--color-primary);border-radius:50%;animation:spin 1s linear infinite;margin-bottom:16px}.ExternalLinkIcon a{display:inline-flex;align-items:center;justify-content:center;padding:4px;border-radius:4px;transition:background-color .2s ease,color .2s ease}.ExternalLinkIcon a:hover{background-color:#f0f0f0}.ExternalLinkIcon svg{color:#333}:root[data-theme=dark] .ExternalLinkIcon a:hover{background-color:var(--color-hover)}:root[data-theme=dark] .ExternalLinkIcon svg{color:var(--color-primary)}:root[data-theme=dark] .ExternalLinkIcon a:hover svg{color:var(--color-primary-hover)}.status-container{display:flex;align-items:center;gap:6px}.status-indicator{width:12px;height:12px;border-radius:50%;flex-shrink:0}.status-indicator.enabled{background-color:#10b981}.status-indicator.disabled{background-color:#9ca3af}.status-text{font-size:13px;font-weight:500}.status-text.enabled{color:#10b981}.status-text.disabled{color:#9ca3af}.results-layout{display:grid;grid-template-columns:300px 300px 300px 300px;gap:20px;margin-top:30px}.modules-section{grid-column:1}.units-section{grid-column:2}.sa-section{grid-column:3}.mixing-section{grid-column:4}.module-item{background:var(--color-surface-alt);border:1px solid var(--color-border);border-radius:8px;padding:12px;margin-bottom:10px;cursor:pointer;transition:all .3s ease;font-size:.95rem;color:var(--color-text)}.result-content{margin-top:20px}.no-results{background:var(--color-surface-alt);border:1px solid var(--color-border);border-radius:8px;padding:12px;margin-bottom:10px;text-align:center;color:var(--color-muted-text);font-style:italic}.module-item:hover{border-color:var(--color-border-strong);box-shadow:0 2px 10px var(--color-shadow);transform:translateY(-1px)}.module-item.selected{background:#5c93ff38;color:var(--color-text);border-color:#5c93ff}.module-item:last-child,.no-results:last-child{margin-bottom:0}.units-list{display:flex;flex-direction:column;gap:10px}.unit-item{background:var(--color-surface-alt);border:1px solid var(--color-border);border-radius:8px;padding:12px;cursor:pointer;transition:all .3s ease;font-size:.95rem;color:var(--color-text)}.unit-item:hover{border-color:var(--color-border-strong);box-shadow:0 2px 10px var(--color-shadow);transform:translateY(-1px)}.unit-item.selected{background:#5c93ff38;color:var(--color-text);border-color:#5c93ff}.selected-module-info{background:#5c93ff2e;border:1px solid #5c93ff;border-radius:6px;padding:10px;margin-bottom:15px;color:var(--color-text);font-size:.9rem}@media (max-width: 768px){.results-layout{grid-template-columns:300px;gap:15px}.modules-section,.units-section,.sa-section,.mixing-section{grid-column:1}}.sa-content-wrapper{display:flex;gap:20px;align-items:flex-start}.sa-list{display:flex;flex-direction:column;gap:10px;flex:1}.sa-item{background:var(--color-surface-alt);border:1px solid var(--color-border);border-radius:8px;padding:12px;transition:all .3s ease;font-size:.95rem;color:var(--color-text)}.sa-item.shuffle-bounce{animation:shuffleBounce 1s cubic-bezier(.68,-.55,.265,1.55)}.sa-item.shuffle-spin{animation:shuffleSpin 1s cubic-bezier(.175,.885,.32,1.275)}.sa-item.shuffle-wave{animation:shuffleWave 1s cubic-bezier(.25,.46,.45,.94)}.sa-item.shuffle-slide{animation:shuffleSlide 1s cubic-bezier(.68,-.55,.265,1.55)}.sa-item.shuffle-zoom{animation:shuffleZoom 1s cubic-bezier(.175,.885,.32,1.275)}@keyframes shuffleBounce{0%,to{transform:translateY(0) scale(1)}25%{transform:translateY(-8px) scale(1.05)}50%{transform:translateY(0) scale(.95)}75%{transform:translateY(-4px) scale(1.02)}}@keyframes shuffleSpin{0%{transform:rotate(0) scale(1)}50%{transform:rotate(180deg) scale(.9)}to{transform:rotate(360deg) scale(1)}}@keyframes shuffleWave{0%,to{transform:translate(0) scale(1)}25%{transform:translate(-6px) scale(1.02)}50%{transform:translate(6px) scale(.98)}75%{transform:translate(-3px) scale(1.01)}}@keyframes shuffleSlide{0%{transform:translate(0) scale(1)}25%{transform:translate(-12px) scale(.96)}50%{transform:translate(12px) scale(.96)}75%{transform:translate(-6px) scale(.98)}to{transform:translate(0) scale(1)}}@keyframes shuffleZoom{0%,to{transform:scale(1)}25%{transform:scale(1.1)}50%{transform:scale(.85)}75%{transform:scale(1.05)}}.sa-list.shuffling{animation:listShuffle 1s cubic-bezier(.175,.885,.32,1.275)}@keyframes listShuffle{0%{transform:scale(1) rotate(0)}25%{transform:scale(.97) rotate(-.5deg)}50%{transform:scale(.95) rotate(0)}75%{transform:scale(.97) rotate(.5deg)}to{transform:scale(1) rotate(0)}}.sa-item.shuffle-bounce:nth-child(1){animation-delay:0s}.sa-item.shuffle-bounce:nth-child(2){animation-delay:.1s}.sa-item.shuffle-bounce:nth-child(3){animation-delay:.2s}.sa-item.shuffle-bounce:nth-child(4){animation-delay:.3s}.sa-item.shuffle-bounce:nth-child(5){animation-delay:.4s}.sa-item.shuffle-spin:nth-child(1){animation-delay:0s}.sa-item.shuffle-spin:nth-child(2){animation-delay:.15s}.sa-item.shuffle-spin:nth-child(3){animation-delay:.3s}.sa-item.shuffle-spin:nth-child(4){animation-delay:.45s}.sa-item.shuffle-spin:nth-child(5){animation-delay:.6s}.sa-item.shuffle-wave:nth-child(1){animation-delay:0s}.sa-item.shuffle-wave:nth-child(2){animation-delay:.08s}.sa-item.shuffle-wave:nth-child(3){animation-delay:.16s}.sa-item.shuffle-wave:nth-child(4){animation-delay:.24s}.sa-item.shuffle-wave:nth-child(5){animation-delay:.32s}.sa-item.shuffle-slide:nth-child(1){animation-delay:0s}.sa-item.shuffle-slide:nth-child(2){animation-delay:.12s}.sa-item.shuffle-slide:nth-child(3){animation-delay:.24s}.sa-item.shuffle-slide:nth-child(4){animation-delay:.36s}.sa-item.shuffle-slide:nth-child(5){animation-delay:.48s}.sa-item.shuffle-zoom:nth-child(1){animation-delay:0s}.sa-item.shuffle-zoom:nth-child(2){animation-delay:.1s}.sa-item.shuffle-zoom:nth-child(3){animation-delay:.2s}.sa-item.shuffle-zoom:nth-child(4){animation-delay:.3s}.sa-item.shuffle-zoom:nth-child(5){animation-delay:.4s}.sa-item:hover{border-color:var(--color-border-strong);box-shadow:0 2px 10px var(--color-shadow);transform:translateY(-1px)}.sa-title{font-weight:600;color:var(--color-text);margin-bottom:8px;font-size:.95rem}.sa-meta{display:flex;gap:10px;align-items:center;font-size:.85rem}.sa-type{background:#5c93ff2e;color:var(--color-text);padding:2px 8px;border-radius:12px;font-size:.75rem;font-weight:500}.sa-progress{background:#45f0a32e;color:var(--color-text);padding:2px 8px;border-radius:12px;font-size:.75rem;font-weight:500}.sa-marked{color:#ff9800;font-size:1rem}.mixing-section{display:flex;align-items:flex-start}.mix-button{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;padding:12px 20px;border-radius:8px;font-size:1.1rem;font-weight:600;cursor:pointer;transition:all .3s ease;min-width:120px;margin-top:19px}.mix-button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 20px #667eea4d}.mix-button:disabled{opacity:.6;cursor:not-allowed;transform:none}.knowledge-tagging{padding:20px;max-width:1200px;margin:0 auto}.knowledge-tagging-header{display:flex;justify-content:space-between;align-items:center;padding-bottom:20px;border-bottom:2px solid var(--color-border)}.knowledge-tagging-header h2{margin:0;color:var(--color-text);font-size:24px}.header-info{color:var(--color-muted-text);font-size:14px}.loading-container,.error-container{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 20px;text-align:center}.spinner{width:40px;height:40px;border:4px solid var(--color-surface-muted);border-top:4px solid var(--color-primary);border-radius:50%;animation:spin 1s linear infinite;margin-bottom:20px}.error-container p{color:var(--color-error);margin-bottom:20px;font-size:16px}.retry-button{padding:10px 20px;background-color:var(--color-primary);color:var(--color-tooltip-text);border:none;border-radius:4px;cursor:pointer;font-size:14px}.retry-button:hover{background-color:var(--color-primary-hover)}.knowledge-maps-container{margin-bottom:30px}.knowledge-maps-table-container{background:var(--color-surface);border:1px solid var(--color-border);border-radius:8px;overflow:hidden;box-shadow:0 2px 4px var(--color-shadow)}.knowledge-maps-table{width:100%;border-collapse:collapse;font-size:14px}.knowledge-maps-table th{background-color:var(--color-surface-alt);padding:12px 16px;text-align:left;font-weight:600;color:var(--color-text);border-bottom:1px solid var(--color-border);height:20px;line-height:1.4;vertical-align:middle}.knowledge-maps-table th:nth-child(1){width:10%}.knowledge-maps-table th:nth-child(2){width:15%}.knowledge-maps-table th:nth-child(3){width:75%}.knowledge-maps-table td{padding:12px 16px;border-bottom:1px solid var(--color-border);vertical-align:middle;height:34px;line-height:1.2}.knowledge-maps-table td:nth-child(1){width:10%}.knowledge-maps-table td:nth-child(2){width:15%}.knowledge-maps-table td:nth-child(3){width:75%}.knowledge-maps-table tr:last-child td{border-bottom:none}.knowledge-maps-table tr:hover{background-color:var(--color-hover)}.title-cell{min-width:250px}.title-content{display:flex;flex-direction:column;gap:4px}.map-title{font-weight:600;color:var(--color-text);font-size:14px}.map-description{color:var(--color-muted-text);font-size:12px;line-height:1.3}.subject-cell{width:auto;min-width:80px}.subject-text{font-size:14px;font-weight:500;color:var(--color-text)}.status-cell{width:auto;min-width:80px}.status-badge{padding:2px 6px;border-radius:8px;font-size:11px;font-weight:500}.status-badge.enabled{background-color:var(--color-success-bg);color:var(--color-success-text)}.status-badge.disabled{background-color:var(--color-surface-muted);color:var(--color-muted-text)}.pagination{display:inline-flex;justify-content:center;align-items:center;gap:20px;margin-top:30px;flex-wrap:nowrap;white-space:nowrap;min-width:0;width:100%}.pagination-button{padding:8px 16px;background-color:var(--color-button-default);color:var(--color-text);border:none;border-radius:4px;cursor:pointer;font-size:14px;transition:background-color .2s ease;white-space:nowrap;flex-shrink:0}.pagination-button:hover:not(:disabled){background-color:var(--color-button-hover)}.pagination-button:disabled{background-color:var(--color-surface-muted);color:var(--color-muted-text);cursor:not-allowed}.pagination-info{font-size:14px;color:var(--color-muted-text);font-weight:500;white-space:nowrap;flex-shrink:0}.page-button{width:36px;height:32px;font-size:16px;display:flex;align-items:center;justify-content:center;margin:8px;background-color:var(--color-surface);color:var(--color-muted-text);border:1px solid var(--color-border);cursor:pointer}.page-button:hover{background-color:var(--color-hover)}.page-button:disabled{background-color:var(--color-surface-muted);color:var(--color-muted-text);cursor:not-allowed}@media (max-width: 768px){.knowledge-tagging{padding:10px}.knowledge-tagging-header{flex-direction:column;align-items:flex-start;gap:10px}.knowledge-maps-table-container{overflow-x:auto}.knowledge-maps-table{min-width:600px}.knowledge-maps-table th,.knowledge-maps-table td{padding:8px 12px}.pagination{gap:10px;flex-wrap:nowrap;display:inline-flex}.pagination-button{padding:6px 12px;font-size:12px;white-space:nowrap}.pagination-info{font-size:12px;white-space:nowrap}}.clickable-row{cursor:pointer;transition:background-color .2s ease}.clickable-row:hover{background-color:var(--color-hover)}.back-button{padding:8px 16px;background-color:var(--color-button-default);color:var(--color-text);border:1px solid var(--color-border);border-radius:4px;cursor:pointer;font-size:14px;display:flex;align-items:center;gap:8px;transition:background-color .2s ease}.back-button:hover{background-color:var(--color-button-hover)}.knowledge-map-details-container{background:var(--color-surface);border:1px solid var(--color-border);border-radius:8px;padding:24px;box-shadow:0 2px 4px var(--color-shadow)}.knowledge-map-details{font-size:14px;line-height:1.6}.knowledge-node,.knowledge-tag{padding:12px 16px;border-radius:8px;transition:background-color .2s ease}.knowledge-node+.knowledge-node,.knowledge-tag+.knowledge-tag,.knowledge-node+.knowledge-tag,.knowledge-tag+.knowledge-node{padding-top:8px}.node-header{display:flex;align-items:center;gap:8px;cursor:pointer;-webkit-user-select:none;user-select:none;transition:background-color .2s ease;padding:4px 8px;margin:-4px -8px;border-radius:4px;justify-content:flex-start;text-align:left}.node-header:hover{background-color:var(--color-hover)}.toggle-icon{display:inline-flex;align-items:center;justify-content:center;width:16px;height:16px;font-size:12px;font-weight:700;color:var(--color-muted-text);transition:transform .2s ease;flex-shrink:0}.toggle-icon.expanded{color:var(--color-primary)}.toggle-icon.collapsed{color:var(--color-muted-text)}.toggle-icon.no-children{color:var(--color-muted-text);font-size:14px;margin-left:-4px}.node-title{font-weight:600;color:var(--color-primary);font-size:15px;text-align:left}.tag-label{font-weight:600;color:var(--color-info-text);font-size:15px;text-align:left}.tag-subject{color:var(--color-muted-text);font-size:12px;margin-left:8px;font-weight:500;text-align:left}.node-children,.tag-children{padding-top:12px;padding-left:20px}.no-data-message{text-align:center;color:var(--color-muted-text);font-style:italic;padding:40px 20px}.tag-clickable-area{margin-top:8px;padding:8px 12px;background-color:var(--color-surface-alt);border-radius:6px;cursor:pointer;transition:background-color .2s ease;border:1px solid var(--color-border)}.tag-clickable-area:hover{background-color:var(--color-hover)}.tag-click-hint{font-size:12px;color:var(--color-muted-text);font-style:italic}.loading-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#000000b3;z-index:2000;display:flex;justify-content:center;align-items:center;flex-direction:column}.loading-overlay .spinner{width:50px;height:50px;border:4px solid var(--color-surface-muted);border-top:4px solid var(--color-primary);border-radius:50%;animation:spin 1s linear infinite;margin-bottom:20px}.loading-overlay .loading-text{color:var(--color-tooltip-text);font-size:18px;font-weight:500;text-align:center}.loading-overlay .loading-subtext{color:var(--color-muted-text);font-size:14px;margin-top:8px;text-align:center}.tag-sidebar-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#00000080;z-index:1000;display:flex;justify-content:flex-end;align-items:stretch}.tag-sidebar{width:1000px;max-width:90vw;background-color:var(--color-surface);box-shadow:-2px 0 10px var(--color-shadow);display:flex;flex-direction:column;animation:slideInRight .3s ease-out}@keyframes slideInRight{0%{transform:translate(100%)}to{transform:translate(0)}}.tag-sidebar-header{display:flex;justify-content:space-between;align-items:center;padding:20px;border-bottom:1px solid var(--color-border);background-color:var(--color-surface-alt)}.tag-sidebar-header h3{margin:0;color:var(--color-text);font-size:18px}.close-sidebar-btn{background:none;border:none;font-size:20px;color:var(--color-muted-text);cursor:pointer;padding:4px 8px;border-radius:4px;transition:background-color .2s ease}.close-sidebar-btn:hover{background-color:var(--color-hover)}.tag-sidebar-content{flex:1;padding:10px 20px;overflow-y:auto;display:flex;gap:20px}.tag-details{display:flex;flex-direction:column;gap:16px;flex:1}.tag-details-right{flex:1;border-left:1px solid var(--color-border);padding-left:20px;position:sticky;top:0;height:fit-content;max-height:100vh;overflow-y:auto}.tag-details-right h4{margin:0 0 16px;color:var(--color-text);font-size:16px;font-weight:600}.activity-set-id-display{padding:12px;background-color:var(--color-surface-alt);border-radius:6px;border:1px solid var(--color-border)}.activity-set-id{font-size:14px;color:var(--color-text);font-weight:500;word-break:break-all}.no-selection{color:var(--color-muted-text);font-style:italic;font-size:14px}.tag-detail-item strong{color:var(--color-text);margin-right:8px}.activity-sets-list{margin-top:12px;display:flex;flex-direction:column;gap:16px}.activity-set-item{padding:16px;background-color:var(--color-surface);border-radius:8px;border:1px solid var(--color-border);box-shadow:0 2px 4px var(--color-shadow);transition:all .2s ease}.activity-set-item:hover{background-color:var(--color-hover);border-color:var(--color-primary)}.activity-set-item.selected{background-color:var(--color-active-bg);border-color:var(--color-primary);box-shadow:0 2px 8px var(--color-shadow)}.activity-set-header{display:flex;align-items:center;gap:12px;margin-bottom:12px;padding-bottom:8px;border-bottom:1px solid var(--color-border)}.activity-set-title{font-weight:600;color:var(--color-text);font-size:16px}.activity-set-type{background-color:var(--color-info-bg);color:var(--color-info-text);padding:4px 8px;border-radius:4px;font-size:12px;font-weight:500}.activity-set-order{color:var(--color-muted-text);font-size:14px}.activity-set-attributes{border-radius:6px;display:flex;flex-wrap:wrap;gap:8px}.attribute-group{display:flex;gap:8px;flex-wrap:wrap}.attribute-label{font-weight:500;color:var(--color-muted-text);font-size:14px;min-width:80px}.attribute-value{background-color:var(--color-info-bg);color:var(--color-info-text);padding:2px 8px;border-radius:4px;font-size:12px}.attribute-value[data-settype=LEARNING]{background-color:var(--color-success-bg);color:var(--color-success-text)}.attribute-value[data-settype=EVALUATION]{background-color:var(--color-warning-bg);color:var(--color-warning-text)}.attribute-value[data-prefixtitle=true]{background-color:var(--color-surface-alt);color:var(--color-muted-text)}.activity-set-content{margin-top:12px}.content-details{margin:8px 0;display:flex;flex-direction:column;gap:6px}.content-value{color:var(--color-text);font-size:14px}.study-activities{margin-top:16px;padding-top:16px;border-top:1px solid var(--color-border)}.study-activity-item{margin:12px 0;padding:12px;background-color:var(--color-surface-alt);border-radius:6px;border-left:3px solid var(--color-success)}.study-activity-header{display:flex;align-items:center;gap:12px;margin-bottom:8px}.study-activity-title{font-weight:600;color:var(--color-text);font-size:14px}.study-activity-order{color:var(--color-muted-text);font-size:12px}.study-activity-details{margin-top:8px}.study-activity-info{display:flex;align-items:center;gap:8px;margin:4px 0}.info-label{font-weight:500;color:var(--color-muted-text);font-size:13px;min-width:80px}.info-value{color:var(--color-text);font-size:13px}.meta-content-module{margin-top:12px;padding:12px;background-color:var(--color-surface);border-radius:6px;border:1px solid var(--color-border)}.module-details{margin:8px 0;display:flex;flex-direction:column;gap:6px}.module-item{display:flex;align-items:center;gap:8px}.module-label{font-weight:500;color:var(--color-muted-text);font-size:13px;min-width:60px}.module-value{color:var(--color-text);font-size:13px}.meta-chapter{margin-top:12px;padding:12px;background-color:var(--color-surface-alt);border-radius:6px}.chapter-details{margin:8px 0;display:flex;flex-direction:column;gap:6px}.chapter-item{display:flex;align-items:center;gap:8px}.chapter-label{font-weight:500;color:var(--color-muted-text);font-size:13px;min-width:60px}.chapter-value{color:var(--color-text);font-size:13px}.chapter-ancestors{margin-top:8px;display:flex;flex-direction:column;gap:4px}.ancestors-label{font-weight:500;color:var(--color-muted-text);font-size:13px}.ancestor-item{background-color:var(--color-surface-muted);color:var(--color-muted-text);padding:2px 8px;border-radius:4px;font-size:12px;margin-left:16px}@media (max-width: 768px){.tag-sidebar{width:100vw;max-width:100vw}.tag-sidebar-header,.tag-sidebar-content{padding:16px}.activity-set-header{flex-direction:column;align-items:flex-start;gap:8px}.attribute-group,.content-item,.study-activity-info,.module-item,.chapter-item{flex-direction:column;align-items:flex-start;gap:4px}}.management-number-search{display:flex;flex-direction:column;gap:12px}.management-number-input{padding:10px 12px;border:1px solid var(--color-input-border);border-radius:6px;font-size:14px;outline:none;transition:border-color .2s ease}.management-number-input:focus{border-color:var(--color-primary);box-shadow:0 0 0 2px var(--color-focus-ring)}.add-button-section{margin-top:20px}.add-button{width:100%;padding:12px 16px;background-color:var(--color-primary);color:var(--color-tooltip-text);border:none;border-radius:6px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s ease}:root[data-theme=dark] .add-button{background-color:#2b4b8f;border:1px solid #3a5aa5;color:#e6f0ff}.add-button:hover:not(.disabled){background-color:var(--color-primary-hover)}:root[data-theme=dark] .add-button:hover:not(.disabled){background-color:#3459a8}.add-button.disabled{background-color:var(--color-button-default);color:var(--color-muted-text);cursor:not-allowed}.add-button:disabled{background-color:var(--color-button-default);color:var(--color-muted-text);cursor:not-allowed}.add-error{margin-top:12px;padding:8px 12px;background-color:var(--color-error-bg);border:1px solid var(--color-error-border);border-radius:4px;color:var(--color-error-text)}.add-error p{margin:0;font-size:13px}.add-success{margin-top:12px;padding:8px 12px;background-color:var(--color-success-bg);border:1px solid var(--color-success-border);border-radius:4px;color:var(--color-success-text)}.add-success p{margin:0;font-size:13px}.search-loading{margin-top:16px;text-align:center;padding:20px}.search-loading .spinner{width:30px;height:30px;border:3px solid var(--color-surface-muted);border-top:3px solid var(--color-primary);border-radius:50%;animation:spin 1s linear infinite;margin:0 auto 12px}.search-loading p{color:var(--color-muted-text);font-size:14px;margin:0}.search-error{margin-top:16px;padding:12px;background-color:var(--color-error-bg);border:1px solid var(--color-error-border);border-radius:6px;color:var(--color-error-text)}.search-error p{margin:0;font-size:14px}.search-results{margin-top:20px}.search-results h5{margin:0 0 12px;color:var(--color-text);font-size:14px;font-weight:600}.math-question-list{display:flex;flex-direction:column;gap:12px}.math-question-item{padding:12px;background-color:var(--color-surface-alt);border-radius:6px;border:1px solid var(--color-border);cursor:pointer;transition:all .2s ease}.math-question-item:hover{background-color:var(--color-hover);border-color:var(--color-primary)}.math-question-item.selected{background-color:var(--color-active-bg);border-color:var(--color-primary);box-shadow:0 0 0 2px var(--color-focus-ring)}.question-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}.question-title{font-weight:600;color:var(--color-text);font-size:14px}.question-type{background-color:var(--color-surface-muted);color:var(--color-muted-text);padding:2px 8px;border-radius:4px;font-size:12px;font-weight:500}.question-info{display:flex;flex-direction:column;gap:4px}.info-item{font-size:13px;color:var(--color-muted-text)}.info-item strong{color:var(--color-text);margin-right:4px}.manual-input-section{margin-top:20px;padding:16px;background-color:var(--color-surface-alt);border-radius:6px;border:1px solid var(--color-border)}.manual-input-title{margin:0 0 12px;color:var(--color-muted-text);font-size:14px}.manual-input-form{display:flex;flex-direction:column;gap:12px}.manual-sa-url-input{padding:8px 12px;border:1px solid var(--color-input-border);border-radius:4px;font-size:14px}.manual-sa-url-input:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 2px var(--color-focus-ring)}.selected-question-details{margin-top:24px;padding-top:20px;border-top:2px solid var(--color-border)}.selected-question-details h5{margin:0 0 16px;color:var(--color-text);font-size:16px;font-weight:600}.selected-question-content{display:flex;flex-direction:column;gap:20px}.detail-section{background-color:var(--color-surface-alt);padding:16px;border-radius:6px;border:1px solid var(--color-border)}.detail-section h6{margin:0 0 12px;color:var(--color-text);font-size:14px;font-weight:600}.detail-item{margin-bottom:8px;font-size:13px;color:var(--color-muted-text)}.detail-item strong{color:var(--color-text);margin-right:4px}.question-content,.explanation-content{font-size:14px;line-height:1.5;color:var(--color-text)}.question-content img,.explanation-content img{max-width:100%;height:auto;margin:8px 0}.no-results{padding:16px;text-align:center;color:var(--color-muted-text)}.no-results p{margin:8px 0;font-size:14px}.no-results p:last-child{font-family:monospace;font-size:12px;background-color:var(--color-surface-muted);padding:8px;border-radius:4px;text-align:left;white-space:pre-wrap;word-break:break-all}.knowledge-tagging-container h2{margin-bottom:20px;color:var(--color-text);font-size:24px;font-weight:600}.knowledge-map-search{margin-bottom:20px}.knowledge-map-search-input{width:100%;max-width:400px;padding:12px 16px;border:1px solid var(--color-input-border);border-radius:6px;font-size:14px;transition:border-color .2s ease}.knowledge-map-search-input:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 2px var(--color-focus-ring)}.knowledge-map-search-input::placeholder{color:var(--color-input-placeholder)}.simple-login-container{display:flex;justify-content:center;align-items:center;height:100vh;background:linear-gradient(135deg,#667eea,#764ba2);padding:20px;box-sizing:border-box;overflow:hidden;position:relative}.falling-char{position:absolute;pointer-events:none;z-index:1}.login-card{background:#fff;border-radius:12px;box-shadow:0 10px 30px #0003;padding:40px;width:100%;max-width:400px;max-height:90vh;overflow-y:auto;position:relative;z-index:10}.login-card h2{text-align:center;color:#333;margin-bottom:30px;font-size:24px;font-weight:600}.form-group{margin-bottom:20px}.form-group label{display:block;margin-bottom:8px;color:#555;font-weight:500;font-size:14px}.form-group input{width:100%;padding:12px 16px;border:2px solid #e1e5e9;border-radius:8px;font-size:16px;transition:border-color .2s ease,box-shadow .2s ease;box-sizing:border-box}.form-group input:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.form-group input::placeholder{color:#999}.error-message{background-color:#fee;color:#c53030;padding:12px;border-radius:6px;margin-bottom:20px;font-size:14px;border:1px solid #feb2b2}.submit-btn{width:100%;padding:14px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:8px;font-size:16px;font-weight:600;cursor:pointer;transition:transform .2s ease,box-shadow .2s ease;margin-bottom:20px}.submit-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 20px #667eea4d}.submit-btn:disabled{opacity:.7;cursor:not-allowed;transform:none}.login-description{text-align:center;margin-bottom:30px}.login-description h3{color:#333;font-size:20px;font-weight:600;margin-bottom:8px}.login-description p{color:#666;font-size:14px;margin:0}.google-login-section{margin-bottom:10px}#google-login-button{display:flex;justify-content:center;margin:20px 0}.login-card{max-width:350px;padding:35px}@media (max-width: 480px){.simple-login-container{padding:10px}.login-card{padding:30px 20px;margin:0;max-height:95vh}.login-card h2{font-size:20px}.form-group input{font-size:14px}}.search-section{margin-bottom:20px}.search-form{display:flex;gap:10px;max-width:400px}.search-input{flex:1;padding:10px 12px;border:1px solid var(--color-input-border);border-radius:6px;font-size:14px;transition:border-color .2s ease;background-color:var(--color-input-bg);color:var(--color-text)}.search-input:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 2px var(--color-focus-ring)}.search-btn{padding:10px 20px;background-color:var(--color-primary);color:var(--color-tooltip-text);border:none;border-radius:6px;font-size:14px;cursor:pointer;transition:background-color .2s ease}:root[data-theme=dark] .search-btn{background-color:#2b4b8f;border:1px solid #3a5aa5;color:#e6f0ff}.search-btn:hover{background-color:var(--color-primary-hover)}:root[data-theme=dark] .search-btn:hover{background-color:#3459a8}.admin-loading,.admin-error{text-align:center;padding:40px;font-size:16px;color:var(--color-text)}.admin-error{color:var(--color-error)}.users-table{background:var(--color-surface);border:1px solid var(--color-border);border-radius:8px;box-shadow:0 2px 4px var(--color-shadow);overflow:hidden;margin-bottom:20px}.users-table table{width:100%;border-collapse:collapse}.users-table th,.users-table td{padding:12px 16px;text-align:left;border-bottom:1px solid var(--color-border);word-wrap:break-word;overflow-wrap:break-word}.users-table th:nth-child(1),.users-table td:nth-child(1){width:8%}.users-table th:nth-child(2),.users-table td:nth-child(2){width:8%}.users-table th:nth-child(3),.users-table td:nth-child(3){width:16%}.users-table th:nth-child(4),.users-table td:nth-child(4){width:40%}.users-table th:nth-child(5),.users-table td:nth-child(5){width:8%}.users-table th:nth-child(6),.users-table td:nth-child(6){width:10%}.users-table th:nth-child(7),.users-table td:nth-child(7){width:10%}.users-table th{background-color:var(--color-surface-alt);font-weight:600;color:var(--color-text);font-size:14px}.users-table td{font-size:14px;color:var(--color-text)}.users-table tr:hover{background-color:var(--color-hover)}.permission-display{display:flex;flex-wrap:wrap;gap:4px}.permission-tag{background-color:var(--color-surface-muted);color:var(--color-text);border:1px solid var(--color-border);padding:2px 8px;border-radius:12px;font-size:12px;white-space:nowrap}.permission-editor{display:flex;flex-direction:column;gap:6px;max-height:150px;overflow-y:auto}.permission-checkbox{display:flex;align-items:center;gap:6px;font-size:12px;cursor:pointer;color:var(--color-text)}.permission-checkbox input[type=checkbox]{margin:0}.permission-checkbox input[type=checkbox]:disabled{opacity:.5;cursor:not-allowed}.disabled-note{color:var(--color-muted-text);font-size:11px;font-style:italic;margin-left:4px}.permission-checkbox:has(input:disabled){opacity:.7;color:var(--color-muted-text)}.action-buttons{display:flex;gap:8px}.edit-btn,.save-btn,.cancel-btn{padding:6px 12px;border:1px solid var(--color-border);border-radius:4px;font-size:12px;cursor:pointer;transition:background-color .2s ease}.edit-btn{background-color:var(--color-info-bg);color:var(--color-info-text);border-color:var(--color-info-border)}.edit-btn:hover{background-color:var(--color-hover)}.save-btn{background-color:var(--color-success-bg);color:var(--color-success-text);border-color:var(--color-success-border)}.save-btn:hover{background-color:var(--color-hover)}.cancel-btn{background-color:var(--color-button-default);color:var(--color-text)}.cancel-btn:hover{background-color:var(--color-button-hover)}.pagination{margin-top:20px;display:flex;flex-direction:column;align-items:center;gap:15px}.pagination-info{font-size:14px;color:var(--color-muted-text)}.pagination-controls{display:flex;gap:5px;align-items:center}.pagination-btn{padding:8px 12px;border:1px solid var(--color-border);background-color:var(--color-surface);color:var(--color-text);border-radius:4px;font-size:14px;cursor:pointer;transition:all .2s ease;min-width:40px}.pagination-btn:hover:not(:disabled){background-color:var(--color-hover);border-color:var(--color-border-strong)}.pagination-btn.active{background-color:var(--color-active-bg);color:var(--color-active-text);border-color:var(--color-active-text)}.pagination-btn:disabled{opacity:.5;cursor:not-allowed}@media (max-width: 768px){.admin-panel{padding:10px}.users-table{font-size:12px}.users-table th,.users-table td{padding:8px 10px}.permission-editor{max-height:120px}.pagination-controls{flex-wrap:wrap;justify-content:center}.pagination-btn{padding:6px 10px;font-size:12px;min-width:35px}}.modal-backdrop-v2{position:fixed;top:0;left:0;width:100%;height:100%;background-color:#00000080;display:flex;justify-content:flex-end;z-index:1000;animation:fadeIn .3s ease-out}:root[data-theme=dark] .modal-backdrop-v2{background-color:#000000b3}.modal-side-sheet-v2{position:relative;width:50%;min-width:400px;height:100%;background-color:var(--color-surface);box-shadow:-2px 0 8px var(--color-shadow);overflow-y:auto;animation:slideIn .3s ease-out;border-radius:5px 0 0 5px}.modal-side-sheet-v2.disabled{background-color:var(--color-surface-muted);cursor:not-allowed}.modal-backdrop-v2.closing{animation:fadeOut .3s ease-in forwards}.modal-side-sheet-v2.closing{animation:slideOut .3s ease-in forwards}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideIn{0%{transform:translate(100%)}to{transform:translate(0)}}@keyframes fadeOut{0%{opacity:1}to{opacity:0}}@keyframes slideOut{0%{transform:translate(0)}to{transform:translate(100%)}}.modal-close-btn{position:absolute;top:20px;right:20px;background:none;border:none;font-size:24px;cursor:pointer;color:var(--color-muted-text);padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:background-color .2s ease}.modal-close-btn:hover{background-color:var(--color-hover)}.modal-content{padding:24px;color:var(--color-text)}@media (max-width: 768px){.modal-side-sheet{width:100%;min-width:unset}}.selection-card{background-color:var(--color-surface);border:1px solid var(--color-border);border-radius:12px;box-shadow:0 4px 12px var(--color-shadow);padding:1.5rem;display:flex;flex-direction:column;gap:1rem;margin-bottom:1px}.label-v2{font-size:20px;font-weight:600;color:var(--color-text)}.selection-button-v2{padding:6px 0;width:100%;height:100%;border:1px solid var(--color-border);background-color:var(--color-surface-muted);color:var(--color-text);cursor:pointer;border-radius:var(--border-radius);box-sizing:border-box;transition:background-color .2s ease,border-color .2s ease,color .2s ease;font-size:1em}.selection-button-v2:hover{background-color:var(--color-hover)}.selection-button-v2.active{background-color:#abdff1;border-color:#abdff1;color:var(--color-text)}.selection-button-v2.active:hover{background-color:#88c7dc;border-color:#88c7dc}:root[data-theme=dark] .selection-button-v2{background-color:#171f33;border-color:#2f4b8a;color:var(--color-text)}:root[data-theme=dark] .selection-button-v2:hover{background-color:#1f2a44}:root[data-theme=dark] .selection-button-v2.active{background-color:#5c93ff59;border-color:#5c93ff;color:#f0f6ff}:root[data-theme=dark] .selection-button-v2.active:hover{background-color:#5c93ff73}.tableWithDifficulty-v2{width:300px}.tableWithoutDifficulty-v2{width:360px}.tableWithoutDifficulty-v2 tbody{display:grid;grid-template-columns:repeat(3,1fr)}.tableWithoutDifficulty-v2 tr{align-items:center}.tableWithDifficulty-v2 td,.tableWithoutDifficulty-v2 td{padding:1px;width:120px;height:42px;cursor:pointer}.tableWithDifficulty-v2 td:hover,.tableWithoutDifficulty-v2 td:hover{cursor:pointer}.table-container-v2{display:flex;gap:30px;align-items:flex-start}.tableWithDifficulty-v2 td:nth-child(1){width:40%}.label{margin-bottom:13px;padding-left:2px;font-size:18px;font-weight:600;display:flex}.label-in{padding-left:2px;font-size:18px;display:flex}.id-input{padding:var(--spacing-sm) var(--spacing-md);border:1px solid var(--color-input-border);border-radius:var(--border-radius);width:95%;height:20px;font-size:.95em;margin-bottom:20px;background-color:var(--color-input-bg);color:var(--color-text)}.word-textarea{resize:vertical;min-height:200px;max-height:400px;font-family:inherit;line-height:1.6;padding:12px 16px;border:1px solid var(--color-input-border);border-radius:5px;font-size:16px;background-color:var(--color-input-bg);color:var(--color-text);transition:border-color .2s ease,box-shadow .2s ease}.word-textarea:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px var(--color-focus-ring)}.word-textarea:disabled{background-color:var(--color-surface-muted);color:var(--color-muted-text);cursor:not-allowed;border-color:var(--color-border)}.word-textarea::placeholder{color:var(--color-input-placeholder)}.word-problem-form{border-radius:5px;border:1px solid var(--color-border);padding:18px;background-color:var(--color-surface);color:var(--color-text)}.word-problem-form.disabled{background-color:var(--color-surface-muted);cursor:not-allowed}.word-problem-form.disabled>*{pointer-events:none}.word-problem-form.disabled input,.word-problem-form.disabled button{opacity:.7}.word-problem-form-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}.word-problem-close-btn{background:none;border:none;font-size:24px;cursor:pointer;color:var(--color-muted-text);padding:0;width:30px;height:30px;display:flex;align-items:center;justify-content:center}.word-problem-close-btn:hover{color:var(--color-text)}.word-problem-form-title{font-size:20px;font-weight:600;color:var(--color-text)}.word-problem-form-content{display:flex;flex-direction:column;gap:20px}.word-problem-form-row{display:flex;flex-direction:column;gap:8px}.word-problem-form-actions{display:flex;gap:12px;justify-content:flex-end;margin-top:20px}.word-problem-btn{padding:10px 20px;border:none;border-radius:6px;font-size:14px;font-weight:500;cursor:pointer;transition:background-color .2s ease}.word-problem-btn-primary{background-color:#3b82f6;color:#fff}.word-problem-btn-primary:hover{background-color:#2563eb}.word-problem-btn-secondary{background-color:#6c757d;color:#fff}.word-problem-btn-secondary:hover{background-color:#5a6268}.word-problem-btn-danger{background-color:#dc3545;color:#fff}.word-problem-btn-danger:hover{background-color:#c82333}.word-problem-status{padding:8px 12px;border-radius:6px;font-size:14px;font-weight:500;text-align:center}.word-problem-status.completed{background-color:#d4edda;color:#155724}.word-problem-status.processing{background-color:#fff3cd;color:#856404}.word-problem-status.pending{background-color:#d1ecf1;color:#0c5460}.info-section{margin-top:20px;padding:16px;background-color:#f8fafc;border:1px solid #e2e8f0;border-radius:8px;border-left:4px solid #3b82f6}.info-title{font-size:16px;font-weight:600;color:#1e293b;display:flex;align-items:center;gap:6px;cursor:pointer;-webkit-user-select:none;user-select:none;transition:color .2s ease}.info-title:hover{color:#3b82f6}.toggle-icon{margin-left:auto;font-size:12px;color:#64748b;transition:transform .2s ease}.info-content{transition:max-height .3s ease,opacity .3s ease;overflow:hidden}.info-content.expanded{max-height:2000px;opacity:1;margin-top:12px}.info-content.collapsed{max-height:0;opacity:0}.info-content ul{margin:0;padding-left:20px;list-style-type:none}.info-content li{margin-bottom:8px;color:#475569;font-size:14px;line-height:1.5;position:relative;padding-left:16px}.info-content li:before{content:"•";color:#3b82f6;font-weight:700;position:absolute;left:0}.info-content li:last-child{margin-bottom:0}.info-content .sub-list{margin-top:8px;margin-bottom:8px;padding-left:5px}.info-content .sub-list li{margin-bottom:4px;font-size:13px;color:#64748b;padding-left:12px}.info-content .sub-list li:before{content:"◦";color:#94a3b8;font-weight:400}.info-content .sub-list li:last-child{margin-bottom:0}#word-problem-creation-layout-container{display:block}#wordProblemSearchInput{padding:var(--spacing-sm) var(--spacing-md);border:1px solid var(--color-border);border-radius:var(--border-radius);width:97%;height:20px;font-size:.95em;margin-bottom:12px;background-color:var(--color-input-bg);color:var(--color-text)}.word-problem-creation-table{width:100%;border-collapse:collapse;margin-bottom:10px}.word-problem-creation-table th{padding:12px 0;border-bottom:1px solid var(--color-border);font-weight:600;text-align:left}.word-problem-creation-table th:nth-child(1){width:10%}.word-problem-creation-table th:nth-child(2){width:10%}.word-problem-creation-table th:nth-child(3){width:40%}.word-problem-creation-table th:nth-child(4){width:15%}.word-problem-creation-table th:nth-child(5){width:15%}.word-problem-creation-table th:nth-child(6){width:10%}.word-problem-row{cursor:pointer;transition:background-color .2s ease}.word-problem-row:hover{background-color:#f8f9fa}.word-problem-row.selected{background-color:#e3f2fd}.word-problem-row td{height:45px;border-bottom:1px solid var(--color-border);vertical-align:middle}.status-badge{padding:4px 8px;border-radius:12px;font-size:12px;font-weight:500;text-align:center;display:inline-block;min-width:60px}.status-badge.completed{background-color:#d1fae5;color:#065f46}.status-badge.processing{background-color:#fef3c7;color:#92400e}.status-badge.pending{background-color:#f3f4f6;color:#374151}.add-form-btn{background-color:#3b82f6;color:#fff;border:none;padding:8px 16px;border-radius:6px;font-size:14px;font-weight:500;cursor:pointer;display:flex;align-items:center;gap:6px;transition:background-color .2s ease;margin:0;width:auto;height:auto}.add-form-btn:hover{background-color:#2563eb}.add-form-btn:active{transform:scale(.95)}.word-problem-creation-text{padding-left:2px;font-size:20px}.loading-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background-color:#fffc;display:flex;flex-direction:column;justify-content:center;align-items:center;z-index:1000}.spinner{width:40px;height:40px;border:4px solid #f3f3f3;border-top:4px solid #3b82f6;border-radius:50%;animation:spin 1s linear infinite;margin-bottom:16px}#worksheet-problem-creation-layout-container{display:block}.worksheet-problem-creation-text{padding-left:2px;font-size:20px}.list-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}.refresh-btn{background-color:#fff;color:#475569;border:1px solid #cbd5f5;padding:8px 14px;border-radius:6px;font-size:14px;font-weight:500;cursor:pointer;transition:background-color .2s ease,border-color .2s ease,color .2s ease}.refresh-btn:hover{background-color:#f8fafc;border-color:#94a3b8;color:#1f2937}#worksheetProblemSearchInput{padding:var(--spacing-sm) var(--spacing-md);border:1px solid var(--color-border);border-radius:var(--border-radius);width:97%;height:20px;font-size:.95em;margin-bottom:12px;background-color:var(--color-input-bg);color:var(--color-text)}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.loading-message{text-align:center;padding:20px;color:#666}.no-data-message{text-align:center;padding:20px;color:#666;background-color:#f8f9fa;border:1px solid #ddd;border-radius:6px}.queue-table{width:100%;border-collapse:collapse;margin-bottom:10px}.queue-table th{padding:12px 0;border-bottom:1px solid var(--color-border);font-weight:600;text-align:left}.queue-table th:nth-child(1){width:10%}.queue-table th:nth-child(2){width:10%}.queue-table th:nth-child(3){width:40%}.queue-table th:nth-child(4){width:12%}.queue-table th:nth-child(5){width:12%}.queue-table th:nth-child(6){width:8%}.queue-table th:nth-child(7){width:8%}.queue-row{cursor:pointer;transition:background-color .2s ease}.queue-row:hover{background-color:#f8f9fa}.queue-row.selected{background-color:#e3f2fd}.queue-row td{height:45px;border-bottom:1px solid var(--color-border);vertical-align:middle}.passage-preview{text-align:left;font-size:.9em;color:#666;line-height:1.4}.queue-progress{display:flex;flex-direction:column;width:100%}.queue-progress-meta{display:flex;gap:10px;font-size:13px;color:#475569;line-height:1;flex-wrap:wrap}.queue-progress-meta-top{margin-bottom:0}.queue-progress-meta-item{display:inline-flex;align-items:center;gap:6px;padding:5px 10px;border-radius:999px;background-color:#f1f5f9;border:1px solid #e2e8f0}.queue-progress-meta-item.success{color:#147a43;border-color:#c9f1dd;background-color:#e6f7ef}.queue-progress-meta-item.failure{color:#b42323;border-color:#f7c6c6;background-color:#fdecec}.queue-progress-meta-item.pending{color:#5b6473;border-color:#e2e8f0;background-color:#f8fafc}.requestor-cell{display:flex;align-items:center;gap:8px;min-width:0;height:100%}.requestor-avatar{width:28px;height:28px;border-radius:50%;object-fit:cover;border:1px solid #e1e5e9;background-color:#f1f3f5;flex-shrink:0}.requestor-name{display:inline-flex;align-items:center;flex:1 1 auto;min-width:0;height:28px;line-height:1;transform:translateY(1px);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.pagination-controls{display:flex;align-items:center;justify-content:center;margin-top:6px}.page-button{width:36px;height:32px;font-size:16px;display:flex;align-items:center;justify-content:center;margin:8px;background-color:#fff;border:1px solid #ddd;border-radius:4px;cursor:pointer;transition:background-color .2s ease}.page-button:hover{background-color:#f8f9fa}.page-button:disabled{opacity:.5;cursor:not-allowed}.loading-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background-color:#00000080;display:flex;flex-direction:column;justify-content:center;align-items:center;z-index:9999;color:#fff}.spinner{width:40px;height:40px;border:4px solid #f3f3f3;border-top:4px solid #007bff;border-radius:50%;animation:spin 1s linear infinite;margin-bottom:16px}#main-title{font-size:24px;font-weight:600;color:#333;padding:0 20px}.add-form-btn{background-color:#007bff;color:#fff;border:none;padding:8px 16px;border-radius:6px;font-size:14px;font-weight:500;cursor:pointer;transition:background-color .2s}.add-form-btn:hover{background-color:#0056b3}.add-form-btn:disabled{opacity:.5;cursor:not-allowed}.main-main{padding:20px}.meta-sentences-container{border:1px solid var(--color-border);border-radius:6px;overflow:hidden;margin-bottom:16px;height:140px;overflow-y:auto}.meta-sentences-table{width:100%;border-collapse:collapse;max-height:300px;overflow-y:auto}.meta-sentences-table th{background-color:var(--color-surface-alt);font-weight:600;color:var(--color-text);padding:12px;text-align:left;border-bottom:1px solid var(--color-border)}.meta-sentences-table td{padding:12px;border-bottom:1px solid var(--color-border);word-wrap:break-word;vertical-align:top}.meta-sentences-table tr:last-child td{border-bottom:none}.sentence-column{width:60%;border-right:1px solid var(--color-border)}.comprehension-column{width:40%}.no-data-message{padding:20px;color:var(--color-muted-text);background-color:var(--color-surface-alt);border:1px solid var(--color-border);border-radius:6px;margin-bottom:16px;height:100px;display:flex;justify-content:center;align-items:center}.selection-button-v2.failed{background-color:#ef4444;border-color:#ef4444;color:#fff}.selection-button-v2.failed:hover{background-color:#dc2626;border-color:#dc2626}.selection-button-v2.active.failed{background-color:#ef4444;border-color:#ef4444;color:#fff}.prompt-templates{display:flex;flex-direction:column;gap:0}.prompt-templates #main-title{position:relative}.pt-cache-note{margin-left:12px;font-size:12px;color:var(--color-muted-text)}.pt-toolbar{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;flex-wrap:wrap;margin-bottom:12px}.pt-search input{min-width:260px;padding:8px 10px;border:1px solid var(--color-input-border);border-radius:6px;font-size:14px;background-color:var(--color-input-bg);color:var(--color-text)}.pt-search input:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 2px var(--color-focus-ring)}.pt-filters{display:flex;align-items:center;gap:10px;flex-wrap:wrap}.pt-filter{display:flex;align-items:center;gap:6px;font-size:13px;color:var(--color-text)}.pt-filter select{padding:6px 8px;border:1px solid var(--color-input-border);border-radius:6px;font-size:13px;background-color:var(--color-input-bg);color:var(--color-text)}.pt-toggle{display:flex;align-items:center;gap:6px;font-size:13px;color:var(--color-text)}.pt-toggle input{accent-color:var(--color-primary)}.pt-btn{padding:7px 12px;border-radius:6px;font-size:13px;border:none;cursor:pointer;transition:background-color .2s ease,color .2s ease}.pt-btn.primary{background-color:#3b82f6;color:#fff}.pt-btn.primary:hover{background-color:#2563eb}.pt-btn.ghost{background-color:var(--color-button-default);color:var(--color-text)}.pt-btn.ghost:hover{background-color:var(--color-button-hover)}.pt-btn.danger{background-color:var(--color-danger);color:#fff}.pt-btn.danger:hover{background-color:var(--color-danger-hover)}.pt-btn:disabled{opacity:.6;cursor:not-allowed}.pt-alert{padding:10px 12px;border-radius:6px;font-size:13px;margin-bottom:12px}.pt-alert.error{background-color:var(--color-error-bg);color:var(--color-error-text);border:1px solid var(--color-error-border)}.pt-alert.success{background-color:var(--color-success-bg);color:var(--color-success-text);border:1px solid var(--color-success-border)}.pt-content{display:grid;grid-template-columns:minmax(420px,1.2fr) minmax(320px,.8fr);gap:16px;align-items:start}.pt-content>*{min-width:0}.pt-list{background-color:var(--color-surface);border:1px solid var(--color-border);border-radius:8px;overflow:hidden;display:flex;flex-direction:column;min-height:300px;min-width:0}.pt-list-header{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;border-bottom:1px solid var(--color-border);font-weight:600;background-color:var(--color-surface-alt)}.pt-list-header-sub{border-top:1px solid var(--color-border);margin-top:12px}.pt-list-meta{font-size:12px;color:var(--color-muted-text)}.pt-table-wrapper{overflow-x:auto}.pt-table{width:100%;border-collapse:collapse;font-size:13px;table-layout:fixed}.pt-table th,.pt-table td{padding:10px 12px;border-bottom:1px solid var(--color-border);text-align:left;vertical-align:top}.pt-table th{background-color:var(--color-surface-alt);font-weight:600;color:var(--color-text);white-space:nowrap}.pt-table th:nth-child(1),.pt-table td:nth-child(1){width:20%}.pt-table th:nth-child(2),.pt-table td:nth-child(2){width:20%}.pt-table th:nth-child(3),.pt-table td:nth-child(3){width:8%}.pt-table th:nth-child(4),.pt-table td:nth-child(4){width:8%}.pt-table th:nth-child(5),.pt-table td:nth-child(5){width:20%}.pt-table th:nth-child(6),.pt-table td:nth-child(6){width:24%}.pt-row:hover{background-color:var(--color-hover);cursor:pointer}.pt-row.selected{background-color:var(--color-active-bg)}.pt-group-row td{background-color:var(--color-surface-muted);border-bottom:1px solid var(--color-border-strong);color:var(--color-text);font-weight:600}.pt-group-row{cursor:pointer}.pt-group-toggle{border:none;background:transparent;font-size:14px;margin-right:6px;cursor:pointer;color:inherit}.pt-group-title{margin-right:10px}.pt-group-count{font-size:12px;color:var(--color-muted-text)}.pt-cell-key{font-weight:600;color:var(--color-text)}.pt-cell-notes{max-width:180px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.pt-cell-preview{min-width:200px;max-width:320px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;color:var(--color-muted-text)}.pt-badge{display:inline-flex;align-items:center;justify-content:center;padding:2px 8px;border-radius:999px;font-size:11px;font-weight:600}.pt-badge.on{background-color:var(--color-success-bg);color:var(--color-success-text)}.pt-badge.off{background-color:var(--color-error-bg);color:var(--color-error-text)}.pt-empty{text-align:center;color:var(--color-muted-text);padding:20px}.pt-pagination{display:flex;align-items:center;justify-content:center;gap:12px;padding:12px;font-size:13px}.pt-detail{background-color:var(--color-surface);border:1px solid var(--color-border);border-radius:8px;padding:16px;display:flex;flex-direction:column;gap:12px;min-width:0}.pt-detail-header h3{margin:0 0 6px;font-size:18px}.pt-subtext{margin:0;color:var(--color-muted-text);font-size:13px}.pt-status{display:inline-flex;align-items:center;margin-top:6px;padding:2px 8px;border-radius:999px;font-size:11px;font-weight:600}.pt-status.default{background-color:var(--color-info-bg);color:var(--color-info-text)}.pt-status.override{background-color:var(--color-success-bg);color:var(--color-success-text)}.pt-form{display:flex;flex-direction:column;gap:12px}.pt-field label{display:block;font-size:13px;font-weight:600;margin-bottom:6px;color:var(--color-text)}.pt-field-header{display:flex;align-items:center;justify-content:space-between;gap:8px;margin-bottom:6px}.pt-field-header label{margin-bottom:0}.pt-field input[type=text],.pt-field select,.pt-field textarea{width:100%;padding:8px 10px;border:1px solid var(--color-input-border);border-radius:6px;font-size:13px;font-family:inherit;box-sizing:border-box;background-color:var(--color-input-bg);color:var(--color-text)}.pt-field textarea{min-height:220px;font-family:Courier New,monospace;resize:vertical}.pt-grammar-table{border:1px solid var(--color-border);border-radius:8px;overflow:hidden;background-color:var(--color-surface);max-height:360px;overflow-y:auto}.pt-grammar-wrapper{display:flex;flex-direction:column;gap:8px}.pt-grammar-actions{display:flex;justify-content:flex-end}.pt-grammar-row{display:grid;grid-template-columns:1fr 1fr 1.5fr;border-top:1px solid var(--color-border)}.pt-grammar-row:first-child{border-top:none}.pt-grammar-row.header{background-color:var(--color-surface-alt);font-size:12px;font-weight:600;color:var(--color-text)}.pt-grammar-cell{padding:8px 10px;border-left:1px solid var(--color-border)}.pt-grammar-cell:first-child{border-left:none}.pt-grammar-cell input{width:100%;padding:6px 8px;border:1px solid var(--color-input-border);border-radius:6px;font-size:13px;font-family:inherit;background-color:var(--color-input-bg);color:var(--color-text);box-sizing:border-box}.pt-grammar-cell input:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 2px var(--color-focus-ring)}.pt-field input:focus,.pt-field select:focus,.pt-field textarea:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 2px var(--color-focus-ring)}.pt-inline label{display:flex;align-items:center;gap:6px;font-weight:500}.pt-hints{background-color:var(--color-surface-alt);border:1px solid var(--color-border);border-radius:6px;padding:10px 12px;font-size:12px;color:var(--color-text)}.pt-hints ul{margin:6px 0 0 16px;padding:0}.pt-hints li{margin-bottom:4px}.pt-meta{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:6px 12px;font-size:12px;color:var(--color-muted-text)}.pt-meta span{font-weight:600;margin-right:6px;color:var(--color-text)}.pt-actions{display:flex;gap:10px;margin-top:4px}@media (max-width: 1100px){.pt-content{grid-template-columns:1fr}}.my-profile{display:flex;flex-direction:column}.my-profile-card{background-color:var(--color-surface);border:1px solid var(--color-border);border-radius:10px;padding:24px;display:grid;grid-template-columns:220px minmax(0,1fr);gap:32px;align-items:stretch}.my-profile-alert{padding:10px 12px;border-radius:6px;font-size:13px;margin-bottom:12px}.my-profile-alert.error{background-color:var(--color-error-bg);color:var(--color-error-text);border:1px solid var(--color-error-border)}.my-profile-alert.success{background-color:var(--color-success-bg);color:var(--color-success-text);border:1px solid var(--color-success-border)}.my-profile-avatar{display:flex;flex-direction:column;gap:12px;align-items:center;text-align:center;justify-content:center;height:100%}.my-profile-image{width:120px;height:120px;border-radius:50%;object-fit:cover;border:1px solid var(--color-border);background-color:var(--color-surface-muted);display:flex;align-items:center;justify-content:center;font-size:32px;font-weight:600;color:var(--color-muted-text)}.my-profile-image.fallback{text-transform:uppercase}.my-profile-avatar-actions{display:flex;gap:8px;flex-wrap:wrap;justify-content:center}.my-profile-file-input{display:none}.my-profile-hint{margin:0;font-size:12px;color:var(--color-muted-text)}.my-profile-crop-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0f172a8c;display:flex;align-items:center;justify-content:center;z-index:2000;padding:20px}.my-profile-crop-modal{background:var(--color-surface);border-radius:12px;padding:20px;width:420px;max-width:calc(100% - 40px);box-shadow:0 10px 25px var(--color-shadow);display:flex;flex-direction:column;gap:14px}.my-profile-crop-title{font-size:16px;font-weight:600;color:var(--color-text)}.my-profile-crop-area{width:320px;height:320px;margin:0 auto;position:relative;overflow:hidden;border-radius:10px;background:var(--color-surface-muted);border:1px solid var(--color-border);cursor:grab}.my-profile-crop-area:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;border:2px solid rgba(255,255,255,.8);border-radius:8px;pointer-events:none}.my-profile-crop-image{position:absolute;top:50%;left:50%;-webkit-user-select:none;user-select:none;cursor:grab}.my-profile-crop-controls{display:flex;align-items:center;gap:10px;font-size:13px;color:var(--color-text)}.my-profile-crop-controls input[type=range]{flex:1}.my-profile-crop-actions{display:flex;justify-content:flex-end;gap:10px}:root[data-theme=dark] .my-profile-crop-actions .my-profile-btn.primary{background-color:#2b4b8f;border:1px solid #3a5aa5;color:#e6f0ff}:root[data-theme=dark] .my-profile-crop-actions .my-profile-btn.primary:hover{background-color:#3459a8}@media (max-width: 520px){.my-profile-crop-modal{width:100%}}.my-profile-form{display:flex;flex-direction:column;gap:14px;padding-top:4px}.my-profile-field label{display:block;font-size:13px;font-weight:600;margin-bottom:6px;color:var(--color-text)}.my-profile-field input,.my-profile-field select{width:clamp(200px,20%,320px);min-width:0;padding:8px 10px;border:1px solid var(--color-border);border-radius:6px;font-size:13px;box-sizing:border-box;background-color:var(--color-surface);color:var(--color-text)}.my-profile-field input:disabled,.my-profile-field select:disabled{background-color:var(--color-surface-muted);color:var(--color-muted-text)}.my-profile-actions{display:flex;gap:10px}.my-profile-btn{padding:7px 12px;border-radius:6px;border:1px solid transparent;font-size:13px;cursor:pointer;transition:background-color .2s ease,color .2s ease;background-color:var(--color-button-default);color:var(--color-text)}.my-profile-btn:not(.primary):not(.ghost){border-color:var(--color-border)}.my-profile-btn.primary{background-color:var(--color-primary);color:#fff}.my-profile-btn.primary:hover{background-color:var(--color-primary-hover)}:root[data-theme=dark] .my-profile-btn.primary{background-color:#2b4b8f;border:1px solid #3a5aa5;color:#e6f0ff}:root[data-theme=dark] .my-profile-btn.primary:hover{background-color:#3459a8}.my-profile-btn.ghost{background-color:var(--color-surface);border-color:var(--color-border);color:var(--color-text)}.my-profile-btn.ghost:hover{background-color:var(--color-hover)}.my-profile-btn:disabled{opacity:.6;cursor:not-allowed}@media (max-width: 900px){.my-profile-card{grid-template-columns:1fr}.my-profile-field input,.my-profile-field select{width:100%}.my-profile-avatar{border-right:none;padding-right:0;align-items:flex-start;text-align:left}.my-profile-avatar-actions{justify-content:flex-start}}.grammar-drill{display:flex;flex-direction:column;gap:0}.grammar-drill #main-title{position:relative}.gd-alert{padding:10px 12px;border-radius:6px;font-size:13px;margin-bottom:12px}.gd-alert.error{background-color:var(--color-error-bg);color:var(--color-error-text);border:1px solid var(--color-error-border)}.gd-layout{display:grid;grid-template-columns:minmax(380px,1.1fr) minmax(320px,.9fr);gap:16px;align-items:start}.gd-layout>*{min-width:0}.gd-panel{min-height:320px}.gd-meta{font-size:12px;color:var(--color-muted-text)}.gd-tree{padding:0 4px 8px;display:flex;flex-direction:column;gap:10px}.gd-tree-group,.gd-tree-subgroup{display:flex;flex-direction:column;gap:6px}.gd-tree-header,.gd-tree-subheader{display:inline-flex;align-items:center;gap:8px;border:none;background:transparent;color:var(--color-text);font-weight:600;cursor:pointer;padding:4px 0;text-align:left}.gd-tree-subheader{padding-left:12px;font-weight:600;color:var(--color-text-soft)}.gd-tree-caret{font-size:14px;line-height:1}.gd-tree-children{padding-left:8px;display:flex;flex-direction:column;gap:8px}.gd-tree-items{display:flex;flex-direction:column;gap:6px;padding-left:22px}.gd-tree-item{display:flex;align-items:center;gap:12px;border:1px solid var(--color-border);border-radius:6px;padding:8px 10px;background-color:var(--color-surface-alt);color:var(--color-text);cursor:pointer;text-align:left;transition:background-color .2s ease,border-color .2s ease}.gd-tree-item:hover{background-color:var(--color-hover)}.gd-tree-item.selected{background-color:var(--color-active-bg);border-color:var(--color-border-strong)}.gd-empty{text-align:center;padding:24px 12px;color:var(--color-muted-text)}.gd-select-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px;padding:0 4px 8px}.gd-select-column{display:flex;flex-direction:column;gap:8px;min-width:0}.gd-select-header{font-size:12px;font-weight:600;color:var(--color-muted-text);padding:0 4px}.gd-select-list{display:flex;flex-direction:column;gap:6px;border:1px solid var(--color-border);border-radius:8px;padding:8px;background-color:var(--color-surface-alt);min-height:260px;max-height:440px;overflow-y:auto}.gd-select-item{display:flex;align-items:center;gap:8px;border:1px solid var(--color-border);border-radius:6px;padding:8px 10px;background-color:var(--color-surface);color:var(--color-text);cursor:pointer;text-align:left;transition:background-color .2s ease,border-color .2s ease}.gd-select-item:hover{background-color:var(--color-hover)}.gd-select-item.has-selected{border-color:var(--color-border-strong);background-color:#78dc7826;box-shadow:inset 0 0 0 1px #78dc7859}.gd-select-item.selected{background-color:var(--color-active-bg);border-color:var(--color-border-strong)}.gd-select-item.leaf-item.selected{border-color:var(--color-border-strong);background-color:#78dc7826;box-shadow:inset 0 0 0 1px #78dc7859}.gd-type-grid{display:grid;grid-template-columns:repeat(5,minmax(0,1fr));gap:4px;padding:0;margin:0 4px 12px}.gd-type-grid .selection-button-v2{min-height:40px;font-size:.95em;background-color:#fff;border-color:var(--color-border)}.gd-type-grid .selection-button-v2.active{background-color:#abdff1;border-color:#abdff1;color:var(--color-text)}:root[data-theme=dark] .gd-type-grid .selection-button-v2.active{background-color:#5c93ff59;border-color:#5c93ff;color:#f0f6ff}:root[data-theme=dark] .gd-type-grid .selection-button-v2{background-color:#171f33;border-color:#2f4b8a}.gd-summary{margin:12px 4px 8px;padding:12px 14px;border:1px solid var(--color-border);border-radius:8px;background-color:var(--color-surface-alt);display:flex;flex-direction:column;gap:6px}.gd-summary-header{display:flex;align-items:center;justify-content:space-between;gap:8px}.gd-summary-title{font-size:13px;font-weight:700;color:var(--color-text)}.gd-summary-count{font-size:12px;color:var(--color-muted-text)}.gd-summary-group{display:flex;flex-direction:column;gap:6px;padding-top:6px;border-top:1px solid var(--color-border)}.gd-summary-group:first-of-type{border-top:none;padding-top:0}.gd-summary-label{font-size:12px;color:var(--color-muted-text);font-weight:600}.gd-summary-chips{display:flex;flex-wrap:wrap;gap:6px}.gd-chip{display:inline-flex;align-items:center;gap:6px;padding:4px 8px;border-radius:999px;background-color:var(--color-surface);border:1px solid var(--color-border);font-size:12px;color:var(--color-text);cursor:pointer;transition:background-color .2s ease,border-color .2s ease,color .2s ease}.gd-chip:hover{background-color:var(--color-hover);border-color:var(--color-border-strong)}.gd-chip-remove{display:none}.gd-summary-empty{font-size:12px;color:var(--color-muted-text)}.gd-actions{display:flex;align-items:center;gap:12px;padding:0 4px 8px}.gd-form-section+.edit-button{color:#fff}.grammar-drill-search{padding:var(--spacing-sm) var(--spacing-md);border:1px solid var(--color-input-border);border-radius:var(--border-radius);width:97%;height:20px;font-size:.95em;margin-bottom:12px;background-color:var(--color-input-bg);color:var(--color-text)}.grammar-drill-search:disabled{opacity:.7;cursor:not-allowed}.grammar-drill-table{width:100%;border-collapse:collapse;margin-bottom:10px}.grammar-drill-table th{padding:12px 0;border-bottom:1px solid var(--color-border);font-weight:600;text-align:left;color:var(--color-text);background-color:var(--color-surface-alt)}.grammar-drill-table td{padding:12px 0;border-bottom:1px solid var(--color-border);color:var(--color-text)}.grammar-drill-table th:nth-child(1),.grammar-drill-table td:nth-child(1){width:12%}.grammar-drill-table th:nth-child(2),.grammar-drill-table td:nth-child(2){width:12%}.grammar-drill-table th:nth-child(3),.grammar-drill-table td:nth-child(3){width:24%}.grammar-drill-table th:nth-child(4),.grammar-drill-table td:nth-child(4){width:18%}.grammar-drill-table th:nth-child(5),.grammar-drill-table td:nth-child(5){width:14%}.grammar-drill-table th:nth-child(6),.grammar-drill-table td:nth-child(6){width:14%}.grammar-drill-table th:nth-child(7),.grammar-drill-table td:nth-child(7){width:6%}.grammar-drill-form{display:flex;flex-direction:column;gap:16px}.gd-form-section{padding-top:12px}.gd-note{font-size:12px;color:var(--color-muted-text)}@media (max-width: 1100px){.gd-layout{grid-template-columns:1fr}}:root{--color-primary: #7ccd7c;--color-primary-hover: #6cbd6c;--color-text: #333;--color-text-soft: #4f4f4f;--color-background: #f9f9f9;--color-border: #c7d1dd;--color-light-background: #f2f2f2;--color-button-default: #e0e0e0;--color-button-hover: #d0d0d0;--color-success: green;--color-error: #c50000;--color-download-csv: green;--color-download-pdf: #c50000;--color-surface: #ffffff;--color-surface-alt: #f8f8f8;--color-surface-muted: #f2f2f2;--color-border-strong: #b5c1d0;--color-muted-text: #888;--color-hover: #e9e9e9;--color-active-bg: #e3f2fd;--color-active-text: #1976d2;--color-tooltip-bg: #333;--color-tooltip-text: #ffffff;--color-shadow: rgba(0, 0, 0, .15);--color-input-bg: #ffffff;--color-input-border: #c7d1dd;--color-input-placeholder: #9aa0a6;--color-focus-ring: rgba(124, 205, 124, .25);--color-success-bg: #e8f5e9;--color-success-text: #1b5e20;--color-success-border: #c8e6c9;--color-error-bg: #fdecea;--color-error-text: #b02a37;--color-error-border: #f5c2c7;--color-info-bg: #eef2ff;--color-info-text: #3949ab;--color-info-border: #c7d2fe;--color-warning-bg: #fff4e5;--color-warning-text: #8a6d3b;--color-warning-border: #ffe0b2;--color-danger: #dc3545;--color-danger-hover: #b52a36;--sidebar-bg: #ffffff;--sidebar-border: #c7d1dd;--sidebar-text: #1f2937;--sidebar-muted: #6b7280;--sidebar-hover: rgba(15, 23, 42, .06);--sidebar-active-bg: rgba(59, 130, 246, .12);--sidebar-active-text: #1d4ed8;--sidebar-divider: #c7d1dd;--spacing-xs: 5px;--spacing-sm: 8px;--spacing-md: 10px;--spacing-lg: 15px;--spacing-xl: 20px;--border-radius: 4px;--font-weight-normal: 400;--font-weight-bold: 600;--font-weight-bolder: bold}:root[data-theme=dark]{color-scheme:dark;--color-primary: #5cf2ff;--color-primary-hover: #32e7ff;--color-text: #e6f0ff;--color-text-soft: #c9d4e6;--color-background: #0a0c14;--color-border: #2f4b8a;--color-light-background: #101528;--color-button-default: #1a1f33;--color-button-hover: #232945;--color-success: #45f0a3;--color-error: #ff5b7a;--color-download-csv: #45f0a3;--color-download-pdf: #ff5b7a;--color-surface: #111428;--color-surface-alt: #0f111b;--color-surface-muted: #1a1f33;--color-border-strong: #3a5aa5;--color-muted-text: #9bb0d4;--color-hover: rgba(92, 242, 255, .12);--color-active-bg: rgba(92, 242, 255, .2);--color-active-text: #7af7ff;--color-tooltip-bg: #0f1426;--color-tooltip-text: #e6f0ff;--color-shadow: rgba(92, 242, 255, .25);--color-input-bg: #0f1426;--color-input-border: #2f4b8a;--color-input-placeholder: #8aa0c6;--color-focus-ring: rgba(92, 242, 255, .3);--color-success-bg: rgba(69, 240, 163, .24);--color-success-text: #7bffd0;--color-success-border: rgba(69, 240, 163, .55);--color-error-bg: rgba(255, 91, 122, .24);--color-error-text: #ff9bb0;--color-error-border: rgba(255, 91, 122, .55);--color-info-bg: rgba(92, 147, 255, .24);--color-info-text: #a6c7ff;--color-info-border: rgba(92, 147, 255, .55);--color-warning-bg: rgba(255, 204, 102, .22);--color-warning-text: #ffe0a6;--color-warning-border: rgba(255, 204, 102, .5);--color-danger: #ff5b7a;--color-danger-hover: #ff2f5f;--sidebar-bg: #070a12;--sidebar-border: #2f4b8a;--sidebar-text: #d6def0;--sidebar-muted: #9fb2d6;--sidebar-hover: rgba(92, 147, 255, .12);--sidebar-active-bg: linear-gradient(90deg, rgba(92, 147, 255, .22) 0%, rgba(69, 240, 163, .12) 100%);--sidebar-active-text: #e7f1ff;--sidebar-divider: #2f4b8a}body{position:relative;font-family:sans-serif;margin:0;background-color:var(--color-background);color:var(--color-text)}input,select,textarea{background-color:var(--color-input-bg);color:var(--color-text);border-color:var(--color-input-border)}input::placeholder,textarea::placeholder{color:var(--color-input-placeholder)}#header{height:55px;border-bottom:1px solid var(--color-border-strong);margin:0;display:flex;align-items:center;background-color:var(--color-surface)}#header-logo{width:120px;height:auto;padding-left:5px}:root[data-theme=dark] #header-logo{filter:invert(1) hue-rotate(180deg)}#header>a{display:flex;align-items:center;height:100%}#body-main{position:relative;display:flex;margin:0;min-height:calc(100vh - 56px);flex-grow:1}#footer{text-align:center;padding:10px;margin-top:auto;border-top:1px solid var(--color-border-strong);background-color:var(--color-surface-alt)}#footer p{margin:0;font-size:12px;color:var(--color-muted-text)}#main-title{font-size:22px;font-weight:var(--font-weight-normal);padding:var(--spacing-lg);border-bottom:1px solid var(--color-border-strong);height:22px;background-color:var(--color-surface);color:var(--color-text);display:flex;align-items:center;justify-content:space-between}.token-status{display:flex;align-items:center;gap:4px;padding:6px 12px;background-color:var(--color-surface-muted);border:1px solid var(--color-border);border-radius:6px;font-size:14px}.token-label{color:var(--color-muted-text);font-weight:500}.token-count{color:var(--color-success);font-weight:600}.token-separator{color:var(--color-muted-text)}.token-limit{color:var(--color-muted-text);font-weight:600}.token-status{position:relative;cursor:help}.token-status:after{content:attr(title);position:absolute;left:50%;transform:translate(-50%);background-color:var(--color-tooltip-bg);color:var(--color-tooltip-text);padding:8px 12px;border-radius:6px;font-size:12px;white-space:pre-line;text-align:center;width:max-content;max-width:250px;opacity:0;visibility:hidden;transition:opacity .3s ease,visibility .3s ease;z-index:1000;box-shadow:0 4px 12px var(--color-shadow);line-height:1.4}.token-status:before{content:"";position:absolute;left:50%;transform:translate(-50%);border:5px solid transparent;opacity:0;visibility:hidden;transition:opacity .3s ease,visibility .3s ease;z-index:1000}.token-status:after{top:50%;left:0;right:auto;transform:translateY(-50%) translate(-100%);margin-right:0;margin-left:8px}.token-status:before{top:50%;left:0;right:auto;transform:translateY(-50%) translate(-100%);border-right-color:var(--color-tooltip-bg);border-left-color:transparent;border-top-color:transparent;border-bottom-color:transparent}.token-status:hover:after{opacity:1;visibility:visible}.token-status:hover:before{opacity:1;visibility:visible}.token-info-icon{margin-left:6px;font-size:12px;opacity:.7;transition:opacity .2s ease}.token-status:hover .token-info-icon{opacity:1}#left-bar{width:200px;min-width:200px;flex:0 0 200px;border-right:1px solid var(--sidebar-border);background-color:var(--sidebar-bg);padding-top:var(--spacing-lg)}#sidebar-nav ul{list-style:none;margin:0;padding:0 10px}#sidebar-nav li a{display:block;padding:var(--spacing-md) var(--spacing-lg);text-decoration:none;color:var(--sidebar-text);transition:background-color .2s ease,color .2s ease}#sidebar-nav li:not(.section-header) a{padding-left:20px}#sidebar-nav li a:hover{background-color:var(--sidebar-hover)}#sidebar-nav li a.active{background:var(--sidebar-active-bg);color:var(--sidebar-active-text);font-weight:var(--font-weight-bold)}#sidebar-nav .section-header{padding:var(--spacing-md) 10px;margin-top:var(--spacing-xl);margin-bottom:8px;border-bottom:1px solid var(--sidebar-divider)}#sidebar-nav .section-header:first-child{margin-top:0}#sidebar-nav .section-title{font-weight:400;color:var(--sidebar-muted);font-size:.75em;text-transform:uppercase;letter-spacing:.5px}#main{background-color:var(--color-surface-alt);flex-grow:1;position:relative;color:var(--color-text)}#history-section #main-main{padding:var(--spacing-xl)}#history-table{width:100%;border-collapse:collapse;margin-top:var(--spacing-lg)}#history-table th,#history-table td{border:1px solid var(--color-border);padding:var(--spacing-sm) var(--spacing-md);text-align:left}#history-table th{background-color:var(--color-surface-muted);font-weight:var(--font-weight-bold)}#history-table td a{margin-right:var(--spacing-sm);text-decoration:none}#history-table td a:hover{text-decoration:underline}#history-table .delete-button{background:none;border:none;color:var(--color-error);cursor:pointer;font-size:1em;padding:0 5px}.main-main{margin:var(--spacing-xl);padding:var(--spacing-xl);padding-top:18px;border:1px solid var(--color-border-strong);border-radius:5px;background-color:var(--color-surface);flex-grow:1}.main-main-2{margin:10px;border-radius:5px;background-color:var(--color-surface);flex-grow:1}#filenameInput{margin-top:3px;width:200px;height:32px;border:1px solid #cccccc;border-radius:5px}#filenameSection{margin-bottom:var(--spacing-xs)}#problemForm label{display:block;margin-bottom:var(--spacing-xs)}#inputText{width:100%;margin-top:3px;margin-bottom:var(--spacing-lg);height:130px;border:1px solid #cccccc;border-radius:5px;font-size:12px}fieldset{padding-top:var(--spacing-md);margin-top:var(--spacing-xs);border:1px solid #cccccc;border-radius:5px}#submitBtn{padding:var(--spacing-md) 18px;cursor:pointer;background-color:#0c4a60;border-radius:5px;color:#ddd;font-size:16px;font-weight:var(--font-weight-bold)}#submitBtn:disabled{cursor:not-allowed;opacity:.6}#loadingIndicator{margin-top:var(--spacing-xl);font-weight:var(--font-weight-bolder);color:#0c4a60}#resultsArea{margin-top:var(--spacing-xl);border-top:1px solid #dddddd;padding-top:var(--spacing-lg)}.result-item{border:1px solid #dddddd;padding:var(--spacing-sm);margin-bottom:var(--spacing-md);background-color:#f9f9f9;margin-left:-20px}.result-item.success{border-left:5px solid var(--color-success)}.result-item.failure{border-left:5px solid var(--color-error)}.result-item p{margin:var(--spacing-xs) 0}.result-item strong{display:inline-block;min-width:80px}#csvLink a{margin-top:6px;display:inline-flex;align-items:center;justify-content:center;padding:var(--spacing-md) var(--spacing-lg);border:1px solid var(--color-download-csv);color:var(--color-download-csv);font-weight:var(--font-weight-bold);text-decoration:none;border-radius:var(--border-radius);vertical-align:middle;height:25px;width:130px}#csvLink a:hover{border-radius:var(--border-radius);background-color:#cde6cd}#questionPdfLink a,#solutionPdfLink a{margin-top:6px;margin-left:var(--spacing-lg);display:inline-flex;align-items:center;justify-content:center;padding:var(--spacing-md) var(--spacing-lg);border:1px solid var(--color-download-pdf);color:var(--color-download-pdf);text-decoration:none;border-radius:var(--border-radius);vertical-align:middle;height:25px;width:130px}#questionPdfLink a:hover,#solutionPdfLink a:hover{border-radius:var(--border-radius);background-color:#f3b8b8}#resultListHeader,#statusNoti{font-size:20px}#errorMessage{color:var(--color-error);font-weight:var(--font-weight-bolder)}.selection-button{padding:6px 0;width:100%;border:1px solid #E1DDDB;background-color:#e1dddb;color:var(--color-text);cursor:pointer;border-radius:var(--border-radius);box-sizing:border-box;transition:background-color .2s ease,border-color .2s ease,color .2s ease;font-size:1em}.selection-button:hover{background-color:#cfc9c7}.selection-button.active{background-color:#abdff1;border-color:#abdff1}.selection-button.active:hover{background-color:#88c7dc}:root[data-theme=dark] .selection-button{background-color:#171f33;border-color:#2f4b8a;color:var(--color-text)}:root[data-theme=dark] .selection-button:hover{background-color:#1f2a44}:root[data-theme=dark] .selection-button.active{background-color:#5c93ff59;border-color:#5c93ff;color:#f0f6ff}:root[data-theme=dark] .selection-button.active:hover{background-color:#5c93ff73}.table-container,.table-container-v2{display:flex;gap:var(--spacing-xl);align-items:flex-start}.table-container>table{gap:var(--spacing-xl);border-collapse:collapse}.table-container-v2>table{gap:var(--spacing-xl);border-collapse:collapse}#tableWithDifficulty,#tableWithDifficulty-v2{width:350px}#tableWithoutDifficulty{width:180px}#tableWithoutDifficulty-v2{width:540px}#tableWithoutDifficulty-v2 tbody{display:grid;grid-template-columns:repeat(3,1fr)}#tableWithoutDifficulty-v2 tr{align-items:center}#legend{display:flex;margin-left:auto;align-items:center}#legend>div{margin-left:var(--spacing-md)}#frequentErrorLegend{background-color:#ffde1c;width:5px;height:30px}#tableWithDifficulty th,#tableWithDifficulty td,#tableWithDifficulty-v2 th,#tableWithDifficulty-v2 td,#tableWithoutDifficulty th,#tableWithoutDifficulty td,#tableWithoutDifficulty-v2 th,#tableWithoutDifficulty-v2 td{padding:3px;text-indent:2px;width:110px;cursor:pointer}#tableWithDifficulty td:hover,#tableWithDifficulty-v2 td:hover,#tableWithoutDifficulty td:hover,#tableWithoutDifficulty-v2 td:hover{cursor:pointer}#presetField{width:200px;margin-right:100px;margin-left:auto}.presetHeader{width:100%;font-size:20px;padding:var(--spacing-sm);text-align:center}.presetCell{padding:var(--spacing-sm);width:100%}.presetButton{padding:6px 0;width:100%;border:1px solid #ccc;background-color:#e1dddb;color:var(--color-text);cursor:pointer;border-radius:var(--border-radius);box-sizing:border-box;transition:background-color .2s ease,border-color .2s ease,color .2s ease;font-size:1em}.presetButton:hover{background-color:#d1cdcb}.presetButton.active{background-color:#ef6c33;border-color:#ef6c33;color:#fff}.presetButton.active:hover{background-color:#d95c2a}:root[data-theme=dark] .presetButton{border-color:#2f4b8a;background-color:#171f33;color:var(--color-text)}:root[data-theme=dark] .presetButton:hover{background-color:#1f2a44}:root[data-theme=dark] .presetButton.active{background-color:#45f0a359;border-color:#45f0a3b3;color:#eafff5}:root[data-theme=dark] .presetButton.active:hover{background-color:#45f0a373}.inlineBlockContainer>div{display:inline-block}.frequentErrorType{position:relative}.frequentErrorType:before{content:"";position:absolute;left:0;top:0;width:5px;height:100%;background-color:#ffde1c}.loading-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background-color:#0009;z-index:10000;display:flex;flex-direction:column;justify-content:center;align-items:center;color:#fff;text-align:center}.spinner{border:5px solid rgba(255,255,255,.3);border-radius:50%;border-top-color:#fff;width:50px;height:50px;animation:spin 1s linear infinite;margin-bottom:var(--spacing-lg)}@keyframes spin{to{transform:rotate(360deg)}}.download-button{display:inline-block;padding:4px 8px;border:1px solid transparent;color:#fff;text-decoration:none;border-radius:var(--border-radius);cursor:pointer;font-size:.9em;margin-right:var(--spacing-xs);transition:opacity .2s ease;text-align:center;min-width:40px}.download-button:hover{opacity:.85}.download-button.csv-button{background-color:var(--color-download-csv);border-color:var(--color-download-csv)}.download-button.pdf-button{background-color:var(--color-download-pdf);border-color:var(--color-download-pdf)}.history-controls{margin-bottom:var(--spacing-lg);display:flex;align-items:center}#historySearchField{padding:var(--spacing-sm) 6px;border:1px solid var(--color-border);border-radius:var(--border-radius);margin-right:var(--spacing-sm);height:33px;background-color:#fff}#historySearchInput{padding:var(--spacing-sm) var(--spacing-md);border:1px solid var(--color-border);border-radius:var(--border-radius);width:250px;font-size:.95em}#curriculumSearchInput{padding:var(--spacing-sm) var(--spacing-md);border:1px solid #b3b3b3;border-radius:var(--border-radius);width:97%;height:20px;font-size:.95em;margin-bottom:12px}#history-table th[data-sortable=true]{cursor:pointer;position:relative;padding-right:20px}#history-table th[data-sortable=true]:after{content:"";position:absolute;right:5px;top:50%;border:4px solid transparent;margin-top:-4px;border-bottom-color:#ccc}#history-table th.sort-asc:after{border-bottom-color:var(--color-text);margin-top:-2px}#history-table th.sort-desc:after{border-top-color:var(--color-text);border-bottom-color:transparent;margin-top:-6px}.app-container{display:flex;flex-direction:column;min-height:100vh}.question-bank-table{width:100%;border-collapse:collapse}.question-bank-table th{padding:12px 15px;text-align:left;border-bottom:1px solid var(--color-border);font-weight:500}.thead-checkbox-th{width:20px}.thead-checkbox:disabled{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:1rem;height:1rem;border-radius:15%;border:1px solid #bbb}.curriculum-row td{padding:16px 0;vertical-align:middle;border-bottom:1px solid var(--color-border)}.curriculum-row:last-child td{border-bottom:none}.curriculum-row:hover{background-color:var(--color-hover)}.curriculum-checkbox-td{text-align:center}.curriculum-type-cell{width:80px;text-align:center}.type-tag{display:inline-block;padding:5px;border-radius:10px;font-size:.8em;font-weight:400;color:#fff}.type-tag.type-교과서{background-color:#f5f9f7;color:#588d70}.type-tag.type-모의고사{background-color:#fdf6f3;color:#bb6a3e}.type-tag.type-부교재{background-color:#eaebf0;color:#676b7c}.type-tag.type-default{background-color:#aaa;color:#fff}.curriculum-title-cell{cursor:pointer}.title-main{font-size:1em;font-weight:400;color:#333;text-indent:16px}#question-bank-layout-container{display:flex}.curriculum-list-text{margin-bottom:13px;padding-left:2px;font-size:18px}
