*{margin:0;padding:0;box-sizing:border-box}button,input,select,textarea{color:inherit;font:inherit}:root{--bg:#F7F8FA;--surface:#ffffff;--border:#DFE2E6;--text:#1A1C1E;--text-secondary:#585D63;--accent:#003DA5;--accent-light:#DEEAFD;--error:#ED1C24;--error-light:#FDE8E9;--success:#22C47D;--success-light:#DDFAEB;--warning-light:#FFF8E0;--radius:8px;--radius-lg:12px}@media (prefers-color-scheme:dark){:root{--bg:#0C0D0E;--surface:#1A1C1E;--border:#3F4347;--text:#F7F8FA;--text-secondary:#C2C7CD;--accent:#4A90F0;--accent-light:#001D4A;--error:#F47176;--error-light:#7A0F14;--success:#4FD69A;--success-light:#0A4D2E;--warning-light:#7A5C00}}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background:var(--bg);color:var(--text);line-height:1.5}.app-layout{display:flex;min-height:calc(100vh - 65px)}.container{flex:1 1;min-width:0;padding:24px}.header{display:flex;align-items:center;justify-content:space-between;padding:16px 24px;background:var(--surface);border-bottom:1px solid var(--border)}.cloud-panel{display:flex;flex-direction:column;overflow:hidden;flex:1 1;min-height:0}.cloud-panel-header{display:flex;align-items:center;padding:12px 16px;border-bottom:1px solid var(--border)}.cloud-panel-header h3{font-size:14px;font-weight:600;margin:0;flex:1 1}.cloud-panel-toggle{background:none;border:none;cursor:pointer;color:var(--text-secondary);font-size:12px;padding:2px 4px;line-height:1;flex-shrink:0}.cloud-panel-toggle:hover{color:var(--text)}.cloud-panel-body{padding:12px 16px;overflow-y:auto;flex:1 1}.cloud-panel .cloud-list{gap:4px}.cloud-panel .cloud-list-item{padding:8px 10px;font-size:13px}.cloud-panel .cloud-list-title{font-size:13px}.cloud-panel .cloud-list-subtitle{font-size:11px}.cloud-list-path{font-family:ui-monospace,SFMono-Regular,SF Mono,Menlo,monospace;font-size:10px!important;opacity:.6;word-break:break-all;white-space:normal}.cloud-list-actions{display:flex;flex-direction:column;gap:4px;align-items:center;flex-shrink:0}.cloud-list-copy-btn{background:none;border:none;cursor:pointer;color:var(--text-secondary);padding:4px;border-radius:4px;display:flex;align-items:center;justify-content:center}.cloud-list-copy-btn:hover{color:var(--accent);background:var(--accent-light)}.cloud-panel .form-input{font-size:13px;padding:6px 8px}.cloud-panel .form-label{font-size:13px}.cloud-panel .back-btn{font-size:12px;margin-bottom:8px}.version-details-panel{width:260px;min-width:260px;background:var(--surface);border-left:1px solid var(--border);overflow-y:auto}.version-details-header{padding:12px 16px;border-bottom:1px solid var(--border)}.version-details-header h3{font-size:14px;font-weight:600;margin:0}.version-details-body{padding:12px 16px}.version-details-list{display:grid;grid-template-columns:auto 1fr;grid-gap:4px 10px;gap:4px 10px;font-size:12px}.version-details-list dt{color:var(--text-secondary);font-weight:500}.version-details-list dd{color:var(--text);word-break:break-all}.details-copyable{display:flex;align-items:flex-start;gap:4px}.details-copyable span{flex:1 1;min-width:0}.cloud-panel-actions{display:flex;gap:6px;margin-bottom:8px}.compare-checkbox{accent-color:var(--accent);width:16px;height:16px;flex-shrink:0}.cloud-list-item.compare-selected{background:var(--accent-light);border-color:var(--accent)}.modal.compare-modal{width:calc(100vw - 160px);height:calc(100vh - 160px);max-width:none;max-height:none}.modal.compare-modal>.modal-body{flex:1 1;min-height:0}.compare-version-labels{display:flex;align-items:center;gap:12px;padding:8px 20px 12px;border-bottom:1px solid var(--border)}.compare-version-label{display:flex;align-items:center;gap:8px;flex:1 1;min-width:0}.compare-label-tag{display:inline-flex;align-items:center;justify-content:center;width:22px;height:22px;border-radius:4px;font-size:12px;font-weight:700;flex-shrink:0}.compare-label-a .compare-label-tag{background:var(--error-light);color:var(--error)}.compare-label-b .compare-label-tag{background:var(--success-light);color:var(--success)}.compare-sections{display:flex;flex-direction:column;gap:4px}.compare-section-header{display:flex;align-items:center;gap:8px;width:100%;padding:10px 12px;background:var(--bg);border:1px solid var(--border);border-radius:var(--radius);cursor:pointer;text-align:left;font-size:13px}.compare-section-header:hover{background:var(--accent-light)}.compare-section-expand{font-size:11px;color:var(--text-secondary);width:12px}.compare-section-title{font-weight:600;flex:1 1}.compare-section-counts{display:flex;gap:6px}.diff-badge{font-size:11px;font-weight:600;padding:1px 6px;border-radius:10px}.diff-badge.diff-added{background:var(--success-light);color:var(--success)}.diff-badge.diff-removed{background:var(--error-light);color:var(--error)}.diff-badge.diff-changed{background:var(--warning-light);color:var(--text)}.diff-badge.diff-equal{background:transparent;color:var(--text-tertiary)}.compare-section-equal{opacity:.5}.compare-section-body{display:flex;flex-direction:column;gap:2px;padding:4px 0 8px 20px}.compare-item{border-radius:var(--radius);overflow:hidden}.compare-item-header{display:flex;align-items:center;gap:8px;width:100%;padding:6px 10px;background:none;border:none;text-align:left;font-size:13px}.compare-item-header:hover{background:var(--bg)}.diff-status-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.diff-status-dot.diff-added{background:var(--success)}.diff-status-dot.diff-removed{background:var(--error)}.diff-status-dot.diff-changed{background:#E5A100}.compare-item-label{flex:1 1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.compare-item-status{font-size:11px;color:var(--text-secondary);flex-shrink:0}.compare-item-expand{font-size:10px;color:var(--text-secondary);width:12px}.compare-field-diffs{padding:4px 10px 8px 26px}.diff-table{width:100%;border-collapse:collapse;font-size:12px}.diff-table th{text-align:left;font-weight:600;color:var(--text-secondary);font-size:11px;text-transform:uppercase;letter-spacing:.3px}.diff-table td,.diff-table th{padding:4px 8px;border-bottom:1px solid var(--border)}.diff-table td{vertical-align:top;word-break:break-word;max-width:250px}.diff-table tr:last-child td{border-bottom:none}.diff-field-name{font-weight:500;color:var(--text-secondary);white-space:nowrap;width:1%}.diff-value-a{background:var(--error-light)}.diff-value-b{background:var(--success-light)}.diff-element-row,.diff-row-expandable:hover{background:var(--bg)}.diff-element-row:hover{background:var(--border)}.diff-element-label{padding-left:24px!important}.diff-element-status{color:var(--text-tertiary);font-weight:400;font-style:italic}.diff-subfield-row td{font-size:11px}.diff-subfield-name{padding-left:44px!important}.btn-raw-json{display:block;margin:8px 0 4px auto;padding:4px 10px;font-size:11px;font-family:monospace;color:var(--text-secondary);background:var(--bg);border:1px solid var(--border);border-radius:var(--radius);cursor:pointer}.btn-raw-json:hover{color:var(--text);border-color:var(--text-secondary)}.modal.raw-json-modal{width:calc(100vw - 160px);height:calc(100vh - 160px);max-width:none;max-height:none}.raw-json-body{flex:1 1;min-height:0;display:flex;gap:1px;background:var(--border)}.raw-json-pane{flex:1 1;display:flex;flex-direction:column;min-width:0;background:var(--surface)}.raw-json-pane-label{padding:8px 12px;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.3px;color:var(--text-secondary);border-bottom:1px solid var(--border)}.raw-json-pane-a .raw-json-pane-label{background:var(--error-light)}.raw-json-pane-b .raw-json-pane-label{background:var(--success-light)}.raw-json-pre{flex:1 1;margin:0;padding:0;overflow:auto;font-size:12px;line-height:1.5;white-space:pre;-moz-tab-size:2;tab-size:2}.raw-json-line{padding:0 12px;min-height:1.5em}.raw-json-line-removed{background:var(--error-light)}.raw-json-line-added{background:var(--success-light)}.header h1{font-size:20px;font-weight:600}.header .directory-name{font-size:14px;color:var(--text-secondary);background:var(--accent-light);padding:4px 12px;border-radius:var(--radius-lg)}.btn{display:inline-flex;align-items:center;gap:8px;padding:12px 24px;border:none;border-radius:var(--radius);font-size:16px;font-weight:500;cursor:pointer;transition:opacity .15s}.btn:hover{opacity:.85}.btn-primary{background:var(--accent);color:white}.btn-secondary{background:var(--border);color:var(--text)}.btn-sm{padding:6px 14px;font-size:12px}.btn-danger{color:var(--error)}.btn:disabled{opacity:.5;cursor:not-allowed}.error{color:var(--error);font-size:14px}.browser{display:grid;grid-template-columns:280px 1fr;grid-gap:24px;gap:24px;min-height:calc(100vh - 130px)}.left-panel{display:flex;flex-direction:column;width:390px;min-width:390px;border-right:1px solid var(--border);background:var(--surface);transition:width .15s,min-width .15s}.left-panel.collapsed{width:42px;min-width:42px}.sidebar{display:flex;flex-direction:column;gap:4px}.level-item{display:flex;align-items:center;gap:8px;padding:10px 12px;border-radius:var(--radius);cursor:pointer;border:1px solid transparent;background:none;width:100%;text-align:left;font-size:14px;font-weight:500;transition:background .1s}.level-item.active,.level-item:hover{background:var(--accent-light)}.level-item.active{border-color:var(--accent)}.level-expand{font-size:12px;width:16px;flex-shrink:0;color:var(--text-secondary)}.level-units{padding-left:8px;margin-bottom:8px}.unit-item{display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:var(--radius);cursor:pointer;border:1px solid transparent;background:none;width:100%;text-align:left;font-size:14px;transition:background .1s}.unit-item.active,.unit-item:hover{background:var(--accent-light)}.unit-item.active{border-color:var(--accent)}.unit-nested{padding-left:16px;font-size:13px}.unit-icon{font-size:20px;flex-shrink:0}.unit-info{display:flex;flex-direction:column}.unit-title{font-weight:500}.unit-meta{font-size:12px;color:var(--text-secondary)}.main{background:var(--surface);border-radius:var(--radius);border:1px solid var(--border);padding:24px;overflow-y:auto}.main-empty{display:flex;align-items:center;justify-content:center;color:var(--text-secondary)}.lesson-list{display:flex;flex-direction:column;gap:12px}.lesson-card{padding:16px;border:1px solid var(--border);border-radius:var(--radius);cursor:pointer;transition:border-color .1s}.lesson-card.active,.lesson-card:hover{border-color:var(--accent)}.lesson-card.active{background:var(--accent-light)}.lesson-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:4px}.badge,.lesson-title{font-weight:500}.badge{font-size:11px;padding:2px 8px;border-radius:var(--radius-lg);background:var(--accent-light);color:var(--accent)}.lesson-meta{font-size:13px;color:var(--text-secondary)}.exercise-list{display:flex;flex-direction:column;gap:16px;margin-top:16px}.exercise-card{padding:16px;border:1px solid var(--border);border-radius:var(--radius)}.exercise-type{font-size:11px;text-transform:uppercase;letter-spacing:.5px;color:var(--accent);font-weight:600;margin-bottom:6px}.exercise-prompt{font-weight:500;margin-bottom:8px}.exercise-detail{font-size:13px;color:var(--text-secondary)}.exercise-detail strong{color:var(--text)}.options-list{display:flex;flex-wrap:wrap;gap:6px;margin-top:6px}.option{font-size:13px;padding:4px 10px;border-radius:4px;background:var(--bg);border:1px solid var(--border)}.option.correct{background:var(--success-light);border-color:var(--success);font-weight:500}.stats{display:flex;gap:24px;padding:12px 0;margin-bottom:16px;border-bottom:1px solid var(--border);font-size:14px;color:var(--text-secondary)}.stats strong{color:var(--text)}.back-btn{background:none;border:none;color:var(--accent);cursor:pointer;font-size:14px;padding:0;margin-bottom:12px}.back-btn:hover{text-decoration:underline}.explanation-block{padding:16px;border:1px solid var(--border);border-radius:var(--radius);background:var(--warning-light)}.explanation-block h4{margin-bottom:8px}.explanation-block p{font-size:14px;margin-bottom:6px}.grammar-table{width:100%;border-collapse:collapse;margin:8px 0;font-size:13px}.grammar-table td,.grammar-table th{border:1px solid var(--border);padding:6px 10px;text-align:left}.grammar-table th{font-weight:500}.grammar-table th,.rule-box{background:var(--accent-light)}.rule-box{border-left:3px solid var(--accent);padding:8px 12px;margin-top:8px;font-size:14px;font-style:italic}.vocab-list{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));grid-gap:12px;gap:12px;margin-top:16px}.vocab-card{padding:12px;border:1px solid var(--border);border-radius:var(--radius)}.vocab-word{font-weight:600;font-size:16px}.vocab-english{color:var(--text-secondary);margin-bottom:4px}.vocab-pronunciation{font-size:13px;color:var(--accent);font-style:italic}.vocab-example{font-size:13px;color:var(--text-secondary);margin-top:6px;border-top:1px solid var(--border);padding-top:6px}.form{display:flex;flex-direction:column;gap:16px;max-width:600px}.form-row{display:flex;gap:12px;align-items:flex-start}.form-label{display:flex;flex-direction:column;gap:4px;font-size:13px;font-weight:500;color:var(--text-secondary)}.form-input{padding:8px 12px;border:1px solid var(--border);border-radius:var(--radius);font-size:14px;color:var(--text);background:var(--surface);outline:none;transition:border-color .15s}.form-input:focus{border-color:var(--accent)}select.form-input{-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%23666' d='M6 8L1 3h10z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center;padding-right:32px}.form-input-sm{width:80px}.form-hint{font-size:12px;color:var(--text-secondary);font-weight:400}.form-hint code{background:var(--accent-light);padding:1px 4px;border-radius:4px;font-size:11px}.form-actions{display:flex;gap:8px;justify-content:flex-end;padding-top:8px}.login-page{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100vh;gap:8px}.login-page h1{font-size:32px;font-weight:700}.login-page p{color:var(--text-secondary);margin-bottom:16px}.login-form{display:flex;flex-direction:column;gap:12px;width:320px}.login-form input{padding:10px 14px;border:1px solid var(--border);border-radius:var(--radius);font-size:14px;color:var(--text);background:var(--surface);outline:none;transition:border-color .15s}.login-form input:focus{border-color:var(--accent)}.toolbar-btn{padding:6px 14px;font-size:13px}.modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,.4);display:flex;align-items:center;justify-content:center;z-index:100}.modal{background:var(--surface);border-radius:var(--radius);box-shadow:0 8px 32px rgba(0,0,0,.2);width:480px;max-height:80vh;display:flex;flex-direction:column}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid var(--border)}.modal-header h2{font-size:16px;font-weight:600}.modal-close{background:none;border:none;font-size:22px;cursor:pointer;color:var(--text-secondary);padding:0 4px;line-height:1}.modal-close:hover{color:var(--text)}.modal-body{padding:16px 20px;overflow-y:auto}.cloud-list{display:flex;flex-direction:column;gap:8px;margin-top:8px}.cloud-list-item{display:flex;align-items:center;padding:14px 20px;border:1px solid var(--border);border-radius:var(--radius);background:var(--surface);cursor:pointer;transition:border-color .15s,background .15s;text-align:left}.cloud-list-item:hover:not(:disabled){border-color:var(--accent);background:var(--accent-light)}.cloud-list-item:disabled{opacity:.5;cursor:not-allowed}.cloud-list-content{display:flex;flex-direction:column;gap:2px}.cloud-list-title{font-size:15px;font-weight:500;color:var(--text)}.cloud-list-subtitle{font-size:13px;color:var(--text-secondary);font-weight:400}.cloud-form{display:flex;flex-direction:column;gap:16px;margin-top:8px}.text-secondary{color:var(--text-secondary);font-size:14px}.import-structure{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius);padding:12px 16px;font-size:13px;line-height:1.6;margin-bottom:16px;overflow-x:auto}.import-dropzone{border:2px dashed var(--border);border-radius:var(--radius);padding:24px;text-align:center;display:flex;flex-direction:column;align-items:center;gap:8px;transition:border-color .15s,background .15s}.import-dropzone.dragover{border-color:var(--accent);background:color-mix(in srgb,var(--accent) 8%,transparent)}.import-stats{display:grid;grid-template-columns:repeat(4,1fr);grid-gap:12px;gap:12px;margin-bottom:16px}.import-stat{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius);padding:12px;text-align:center;display:flex;flex-direction:column;gap:4px}.import-stat-value{font-size:24px;font-weight:700;color:var(--accent)}.import-stat-label{font-size:12px;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px}.import-detail-section{margin-bottom:12px}.import-detail-section h4{font-size:13px;font-weight:600;margin-bottom:6px;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px}.import-detail-list{border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;max-height:200px;overflow-y:auto}.import-detail-item{display:flex;justify-content:space-between;align-items:center;padding:8px 12px;font-size:13px;border-bottom:1px solid var(--border)}.import-detail-item:last-child{border-bottom:none}.details-panel{background:var(--surface);border-radius:var(--radius);border:1px solid var(--border);padding:16px;overflow-y:auto}.details-panel h3{font-size:14px;font-weight:600;margin-bottom:12px;padding-bottom:8px;border-bottom:1px solid var(--border)}.details-list{display:grid;grid-template-columns:auto 1fr;grid-gap:6px 12px;gap:6px 12px;font-size:13px}.details-list dt{color:var(--text-secondary);font-weight:500}.details-list dd{color:var(--text);word-break:break-all}.details-mono{font-family:ui-monospace,SFMono-Regular,SF Mono,Menlo,monospace;font-size:11px}.loading-spinner{width:32px;height:32px;border:3px solid var(--border);border-top-color:var(--accent);border-radius:9999px;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(1turn)}}.auth-user{display:flex;align-items:center;gap:8px;font-size:13px;color:var(--text-secondary)}.auth-user button{background:none;border:none;color:var(--accent);cursor:pointer;font-size:13px;padding:0}.auth-user button:hover{text-decoration:underline}.vocab-filters{display:flex;gap:8px;margin:12px 0}.vocab-filters .form-input{margin:0}.vocab-filters select{max-width:200px}.vocab-browser-list{display:flex;flex-direction:column;gap:2px}.vocab-browser-item{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:8px 12px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);cursor:pointer;text-align:left;width:100%;transition:border-color .15s}.vocab-browser-item:hover{border-color:var(--accent)}.vocab-browser-main{display:flex;gap:12px;align-items:baseline;min-width:0}.vocab-browser-sl{font-weight:600;font-size:14px;white-space:nowrap}.vocab-browser-en{font-size:13px;color:var(--text-secondary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.vocab-browser-meta{display:flex;gap:4px;flex-shrink:0}.badge-success{background:color-mix(in srgb,var(--success) 15%,transparent)!important;color:var(--success)!important}.badge-muted{background:var(--bg)!important;color:var(--text-secondary)!important}.audio-filter-row{display:flex;gap:6px;margin:8px 0}.audio-url-row{display:flex;gap:8px;align-items:center}.audio-url-row .form-input{flex:1 1}.audio-play-btn{display:inline-flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:50%;border:1.5px solid var(--accent);background:transparent;color:var(--accent);font-size:14px;cursor:pointer;flex-shrink:0;transition:background .15s,color .15s}.audio-play-btn:hover{background:var(--accent);color:#fff}.audio-play-btn-sm{width:26px;height:26px;font-size:10px;border-width:1px}.audio-play-btn-playing{background:var(--accent);color:#fff}.audio-play-btn-error{border-color:var(--error);color:var(--error)}.audio-play-btn-error:hover{background:var(--error);color:#fff}.gen-progress-bar{height:4px;background:var(--border);border-radius:2px;overflow:hidden}.gen-progress-fill{height:100%;background:var(--accent);transition:width .3s ease}.gen-word-list{display:flex;flex-direction:column;gap:2px}.gen-word-item{display:flex;align-items:center;justify-content:space-between;padding:6px 10px;border-radius:4px;font-size:13px;background:var(--surface);border:1px solid var(--border)}.gen-word-generating{background:color-mix(in srgb,var(--accent) 5%,var(--surface))}.gen-word-generating,.gen-word-uploading{border-color:var(--accent)}.gen-word-done{border-color:var(--success);background:color-mix(in srgb,var(--success) 5%,var(--surface))}.gen-word-error{border-color:var(--error);background:color-mix(in srgb,var(--error) 5%,var(--surface))}.gen-word-text{font-weight:500}.gen-word-id{font-size:11px;color:var(--text-secondary);font-family:ui-monospace,SFMono-Regular,SF Mono,Menlo,monospace;flex:1 1;text-align:right;margin-right:8px}.gen-word-status{display:flex;align-items:center;min-width:60px;justify-content:flex-end}.gen-spinner{display:inline-block;width:14px;height:14px;border:2px solid var(--border);border-top-color:var(--accent);border-radius:50%;animation:spin .6s linear infinite}.changes-panel{margin-top:20px;padding-top:16px;border-top:1px solid var(--border)}.changes-panel h3{display:flex;align-items:center;gap:8px}.changes-badge{display:inline-flex;align-items:center;justify-content:center;min-width:20px;height:20px;padding:0 6px;border-radius:10px;background:var(--accent);color:#fff;font-size:11px;font-weight:600}.changes-empty{font-size:12px;color:var(--text-secondary)}.changes-success{font-size:12px;color:var(--success);font-weight:500}.changes-list{list-style:none;padding:0;margin:0;gap:6px}.change-item,.changes-list{display:flex;flex-direction:column}.change-item{gap:2px;padding:6px 8px;background:var(--bg);border-radius:4px;border-left:3px solid var(--accent)}.change-path{font-family:ui-monospace,SFMono-Regular,SF Mono,Menlo,monospace;font-size:11px;color:var(--text);font-weight:500}.change-fields{font-size:11px;color:var(--text-secondary)}