*{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}.container{max-width:1200px;margin:0 auto;padding:24px}.header{display:flex;align-items:center;justify-content:space-between;padding:16px 24px;background:var(--surface);border-bottom:1px solid var(--border);margin-bottom:24px}.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 - 120px)}.browser:has(.details-panel){grid-template-columns:280px 1fr 260px}.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}.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}