:root{--bg:#eef3ff;--bg2:#f7f9ff;--bg-faint:#fbfcff;--panel:#ffffffdb;--panel-solid:#fff;--line:#e4eaff;--text:#3a4d7a;--text-secondary:#4e6291;--muted:#5f6f96;--brand:#7e95ff;--brand2:#84b7ff;--accent:#7fd7ff;--green:#228654;--green-light:#eefaf2;--green-border:#d7f0e0;--danger:#e55555;--danger-light:#fff5f5;--danger-border:#ffd6d6;--warning:#f1b24a;--warning-light:#fff9eb;--sp-1:4px;--sp-2:8px;--sp-3:12px;--sp-4:16px;--sp-5:20px;--sp-6:24px;--sp-8:32px;--sp-10:40px;--sp-12:48px;--radius-xs:8px;--radius-sm:10px;--radius-md:14px;--radius-lg:18px;--radius-xl:22px;--radius-2xl:28px;--radius-3xl:32px;--radius-pill:999px;--shadow-sm:0 4px 12px #6e82be0f;--shadow-md:0 12px 30px #6e82be14;--shadow-lg:0 16px 40px #7086d21f;--shadow-brand:0 10px 22px #6f86ff2e;--shadow-glow:0 8px 18px #7e95ff38;--transition-fast:.15s ease;--transition-normal:.2s ease;--transition-slow:.3s ease;--sidebar-w:200px;--font-sans:-apple-system,BlinkMacSystemFont,"Segoe UI","PingFang SC","Hiragino Sans GB","Microsoft YaHei",sans-serif}*,:before,:after{box-sizing:border-box;margin:0;padding:0}body{font-family:var(--font-sans);color:var(--text);-webkit-font-smoothing:antialiased;background:radial-gradient(circle at 78% 12%,#a1c4ff29,#0000 18%),radial-gradient(circle at 12% 84%,#bac9ff2e,#0000 24%),linear-gradient(#f4f7ff 0%,#edf2ff 100%);min-height:100vh}a{color:inherit}img{max-width:100%;display:block}.page-wrap{padding:var(--sp-5);min-height:100vh}.page-shell{border-radius:var(--radius-2xl);border:1px solid var(--line);box-shadow:var(--shadow-md);background:linear-gradient(135deg,#f4f7fff5,#eef2fff5);position:relative;overflow:hidden}.page-shell:before{content:"";pointer-events:none;background:radial-gradient(circle at 78% 12%,#a1c4ff26,#0000 18%),radial-gradient(circle at 12% 84%,#bac9ff29,#0000 26%),linear-gradient(135deg,#84b4ff0d,#ae8bff0f);position:absolute;inset:0}.page-shell__orb{pointer-events:none;border-radius:50%;animation:12s ease-in-out infinite orb-drift;position:absolute}.page-shell__orb--blue{background:radial-gradient(circle,#a1c4ff47,#0000 65%);width:380px;height:380px;top:-80px;right:-80px}.page-shell__orb--purple{background:radial-gradient(circle,#baaeff38,#0000 65%);width:300px;height:300px;animation-delay:-4s;bottom:-60px;left:-60px}.page-shell__inner{z-index:1;position:relative}.shell{grid-template-columns:var(--sidebar-w)1fr;min-height:820px;display:grid}.main{flex-direction:column;min-width:0;display:flex}.main__content{padding:var(--sp-5)var(--sp-6)var(--sp-8);animation:.25s fade-in}.sidebar{width:var(--sidebar-w);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);background:linear-gradient(#f0f4ffc7,#eaefffc7);border-right:1px solid #e4eaff99;flex-direction:column;min-height:100%;display:flex}.sidebar__logo{padding:var(--sp-4)var(--sp-3);align-items:center;gap:var(--sp-2);border-bottom:1px solid #e4eaff99;text-decoration:none;display:flex}.sidebar__logo-mark{border-radius:var(--radius-md);width:36px;height:36px;box-shadow:var(--shadow-glow);background:linear-gradient(135deg,#7e95ff,#9ad8ff);flex-shrink:0}.sidebar__logo-text{color:var(--text);font-size:22px;font-weight:800}.sidebar__user-wrap{padding:var(--sp-3)var(--sp-2)0}.sidebar__user-card{padding:var(--sp-2)var(--sp-3);border-radius:var(--radius-md);align-items:center;gap:var(--sp-2);background:#ffffff85;border:1px solid #e6ecff;display:flex}.sidebar__avatar{color:#c4856e;background:linear-gradient(135deg,#f5d0c2,#fff4ef);border:2px solid #ffffffb3;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;font-size:13px;font-weight:800;display:flex}.sidebar__user-name{font-size:14px;font-weight:800}.sidebar__user-role{color:var(--muted);font-size:11px}.sidebar__nav{padding:var(--sp-2)var(--sp-2)var(--sp-1);gap:var(--sp-1);flex-direction:column;display:flex}.sidebar__nav-item{border-radius:var(--radius-sm);color:#6074a9;align-items:center;gap:var(--sp-2);height:40px;padding:0 var(--sp-3);cursor:pointer;text-align:left;width:100%;transition:background var(--transition-fast),color var(--transition-fast);background:0 0;border:none;font-size:14px;font-weight:600;text-decoration:none;display:flex}.sidebar__nav-item:hover{color:var(--text);background:#ffffff4d}.sidebar__nav-item--active{color:var(--brand);border-left:2px solid var(--brand);padding-left:calc(var(--sp-3) - 2px);background:#7e95ff1a;font-weight:700}.sidebar__nav-item--active:hover{color:var(--brand);background:#7e95ff26}.sidebar__sub-item{border-radius:var(--radius-xs);height:34px;color:var(--muted);align-items:center;gap:var(--sp-2);padding:0 var(--sp-3);cursor:pointer;text-align:left;width:100%;transition:background var(--transition-fast),color var(--transition-fast);background:0 0;border:none;font-size:13px;font-weight:600;text-decoration:none;display:flex}.sidebar__sub-item:hover{color:var(--brand)}.sidebar__sub-item--active{color:var(--brand);background:#7e95ff14;font-weight:700}.sidebar__sub-content{padding:0 var(--sp-2)var(--sp-1)var(--sp-6);flex-direction:column;gap:2px;display:flex}.sidebar__context-card{border-radius:var(--radius-md);padding:var(--sp-2);background:#ffffff6b;border:1px solid #e4eaff80;flex-direction:column;gap:2px;display:flex}.sidebar__divider{height:1px;margin:var(--sp-1)var(--sp-2);background:linear-gradient(90deg,transparent,var(--line),transparent);border:none}.sidebar__context{padding:var(--sp-2);flex:1;overflow-y:auto}.sidebar__footer{padding:var(--sp-2)var(--sp-3);color:#97a5ca;font-size:11px}.topbar{justify-content:space-between;align-items:center;gap:var(--sp-4);height:64px;padding:0 var(--sp-6);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#fff9;border-bottom:1px solid #e4eaff99;flex-shrink:0;display:flex}.topbar__title{color:var(--text);font-size:16px;font-weight:800}.topbar__breadcrumb{color:var(--muted);font-size:13px}.topbar__breadcrumb a{color:var(--brand);transition:color var(--transition-fast);font-weight:600;text-decoration:none}.topbar__breadcrumb a:hover{color:#6079f5}.topbar__right{align-items:center;gap:var(--sp-3);display:flex}.btn{justify-content:center;align-items:center;gap:var(--sp-2);border-radius:var(--radius-pill);cursor:pointer;padding:11px var(--sp-5);color:#fff;box-shadow:var(--shadow-brand);transition:opacity var(--transition-fast),transform var(--transition-fast);background:linear-gradient(90deg,#6f86ff,#61d1ff);border:none;font-size:14px;font-weight:700;text-decoration:none;display:inline-flex}.btn:hover{opacity:.88}.btn:active{transform:scale(.97)}.btn--block{width:100%}.btn--lg{height:52px;padding:0 var(--sp-6);font-size:16px;font-weight:800}.btn--sm{height:32px;padding:0 var(--sp-3);box-shadow:none;font-size:12px}.btn--soft{border:1px solid var(--line);color:var(--text);box-shadow:none;background:#ffffffc7;font-weight:600}.btn--soft:hover{opacity:1;background:#fffffff5}.btn--danger{background:var(--danger);box-shadow:none}.btn--danger:hover{opacity:.9}.btn--ghost{color:var(--muted);box-shadow:none;background:0 0;font-weight:600}.btn--ghost:hover{color:var(--text);opacity:1;background:#e4eaff66}.btn--disabled,.btn:disabled{opacity:.5;cursor:not-allowed}.btn--disabled:hover,.btn:disabled:hover{opacity:.5;transform:none}.input{border-radius:var(--radius-md);width:100%;height:48px;padding:0 var(--sp-3);color:var(--text);transition:border-color var(--transition-fast),box-shadow var(--transition-fast);background:#ffffffb8;border:1px solid #dde5fb;outline:none;font-family:inherit;font-size:15px}.input::placeholder{color:#7b8dbb80}.input:focus{border-color:var(--brand);box-shadow:0 0 0 3px #7e95ff26}.input:disabled{opacity:.5;cursor:not-allowed}.input--sm{height:40px;font-size:13px}.select{border-radius:var(--radius-md);width:100%;height:44px;padding:0 var(--sp-8)0 var(--sp-3);color:var(--text);appearance:none;cursor:pointer;transition:border-color var(--transition-fast),box-shadow var(--transition-fast);background:#ffffffb8 url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 24 24' fill='none' stroke='%237b8dbb' stroke-width='2'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E") right 12px center no-repeat;border:1px solid #dde5fb;outline:none;font-family:inherit;font-size:14px}.select:focus{border-color:var(--brand);box-shadow:0 0 0 3px #7e95ff26}.field-label{color:var(--text);margin-bottom:var(--sp-2);font-size:13px;font-weight:600;display:block}.field-required{color:var(--danger);margin-left:2px}.field-error{margin-top:var(--sp-1);color:var(--danger);background:var(--danger-light);border-radius:var(--radius-sm);padding:var(--sp-2)var(--sp-3);font-size:13px}.card{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius-2xl);box-shadow:var(--shadow-md)}.card--flat{border:1px solid var(--line);border-radius:var(--radius-xl);box-shadow:none;background:#ffffffd1}.card--glass{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);border-radius:var(--radius-xl);box-shadow:var(--shadow-sm);background:#ffffffd1;border:1px solid #e4eaff99}.pill{border-radius:var(--radius-pill);color:#6278b2;background:#eef3ff;border:1px solid #dfe7ff;align-items:center;gap:6px;padding:4px 10px;font-size:12px;font-weight:600;display:inline-flex}.pill--ok{background:var(--green-light);color:var(--green);border-color:var(--green-border)}.pill--danger{background:var(--danger-light);color:var(--danger);border-color:var(--danger-border)}.pill--warn{background:var(--warning-light);color:#9f7700;border-color:#ffe8a6}.badge-status{border-radius:var(--radius-pill);align-items:center;padding:3px 10px;font-size:12px;font-weight:600;display:inline-flex}.badge-status--published{background:var(--green-light);color:var(--green)}.badge-status--draft{color:var(--brand);background:#eef3ff}.badge-status--offline{color:#6b7280;background:#f3f4f6}.badge-role{border-radius:var(--radius-pill);padding:2px 8px;font-size:11px;font-weight:600;display:inline-flex}.badge-role--admin{color:#6c4fe0;background:#f1edff}.badge-role--teacher{color:#6278b2;background:#eef3ff}.modal-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:100;background:#505a8247;justify-content:center;align-items:center;animation:.2s fade-in;display:flex;position:fixed;inset:0}.modal{background:var(--panel-solid);border:1px solid var(--line);border-radius:var(--radius-2xl);width:100%;max-width:460px;padding:var(--sp-8)var(--sp-8)var(--sp-6);animation:.2s modal-enter;box-shadow:0 24px 64px #7086d22e}.modal__title{margin-bottom:var(--sp-5);font-size:20px;font-weight:800}.modal__body{margin-bottom:var(--sp-6)}.modal__actions{justify-content:flex-end;gap:var(--sp-3);display:flex}.table-wrap{border:1px solid var(--line);border-radius:var(--radius-lg);background:#fff9;overflow-x:auto}.table{border-collapse:collapse;width:100%;font-size:14px}.table th{padding:var(--sp-3)var(--sp-4);text-align:left;color:var(--muted);white-space:nowrap;border-bottom:1px solid var(--line);background:#eef3ff80;font-size:12px;font-weight:700}.table td{padding:var(--sp-3)var(--sp-4);vertical-align:middle;border-bottom:1px solid #e4eaff66}.table tbody tr:last-child td{border-bottom:none}.table tbody tr{transition:background var(--transition-fast)}.table tbody tr:hover{background:#eef3ff4d}.table__cell--truncate{text-overflow:ellipsis;white-space:nowrap;max-width:200px;overflow:hidden}.table__cell--mono{color:var(--muted);font-family:SF Mono,Fira Code,monospace;font-size:13px}.table__empty{text-align:center;padding:var(--sp-10)0;color:var(--muted);font-size:14px}.filter-tree{padding:var(--sp-2)0}.filter-tree__inner{border-radius:var(--radius-md);padding:var(--sp-3);background:#ffffff6b;border:1px solid #e6ecff}.filter-tree__title{margin-bottom:var(--sp-1);color:var(--text);font-size:12px;font-weight:800}.filter-tree__hint{color:var(--muted);margin-bottom:var(--sp-2);font-size:11px}.filter-tree__group-btn{border-radius:var(--radius-sm);cursor:pointer;color:#5f79ef;text-align:left;width:100%;margin-bottom:var(--sp-1);transition:background var(--transition-fast);background:#eef3ff;border:none;padding:7px 10px;font-size:13px;font-weight:700;display:block}.filter-tree__group-btn:hover{background:#e4ecff}.filter-tree__group-btn--inactive{color:var(--muted);background:#fff9;font-weight:600}.filter-tree__sub{margin-left:var(--sp-2);margin-bottom:var(--sp-1);border-left:1px solid #dfe7ff;flex-direction:column;gap:3px;padding-left:10px;display:flex}.filter-tree__sub-btn{cursor:pointer;color:#5f79ef;text-align:left;transition:background var(--transition-fast);background:0 0;border:none;border-radius:9px;padding:6px 10px;font-size:12px;font-weight:700}.filter-tree__sub-btn:hover{background:#eef3ff99}.filter-tree__sub-btn--active{background:#eef3ff}.login{min-height:100vh;padding:var(--sp-5);justify-content:center;align-items:center;display:flex}.login__shell{border-radius:var(--radius-3xl);border:1px solid var(--line);background:linear-gradient(135deg,#f4f7fff7,#eef2fff7);width:100%;max-width:1280px;position:relative;overflow:hidden;box-shadow:0 24px 64px #7086d224}.login__glow{pointer-events:none;background:radial-gradient(circle at 78% 16%,#a1c4ff2e,#0000 18%),radial-gradient(circle at 22% 80%,#bac9ff2e,#0000 24%),linear-gradient(135deg,#84b4ff0f,#ae8bff12);position:absolute;inset:0}.login__grid{z-index:1;grid-template-columns:1.1fr .9fr;min-height:640px;display:grid;position:relative}.login__brand{padding:var(--sp-12)var(--sp-10);flex-direction:column;justify-content:center;display:flex}.login__brand-logo{align-items:center;gap:var(--sp-3);margin-bottom:var(--sp-8);display:flex}.login__brand-title{letter-spacing:-1px;margin-bottom:var(--sp-3);font-size:58px;font-weight:800;line-height:1.08}.login__brand-subtitle{color:#6f80bb;margin-bottom:var(--sp-4);font-size:24px;font-weight:500}.login__brand-desc{color:#7587b5;max-width:480px;margin-bottom:var(--sp-8);font-size:15px;line-height:1.9}.login__brand-features{border:1px solid var(--line);border-radius:var(--radius-xl);padding:var(--sp-4)var(--sp-5);box-shadow:var(--shadow-sm);background:#ffffffa3;width:fit-content}.login__brand-feature-item{color:#5f73b0;font-size:14px;font-weight:700;line-height:1.9}.login__form-area{padding:var(--sp-10)var(--sp-10)var(--sp-10)var(--sp-6);border-left:1px solid #e4eaff99;justify-content:flex-end;align-items:center;display:flex}.login__form{border:1px solid var(--line);border-radius:var(--radius-2xl);width:100%;max-width:400px;padding:36px var(--sp-8)var(--sp-8);box-shadow:var(--shadow-md);background:#ffffffc2}.login__form-title{margin-bottom:var(--sp-1);font-size:30px;font-weight:800}.login__form-subtitle{color:var(--muted);margin-bottom:var(--sp-8);font-size:14px}.login__divider{align-items:center;gap:var(--sp-2);color:var(--muted);margin:var(--sp-3)0;font-size:12px;display:flex}.login__divider:before,.login__divider:after{content:"";background:var(--line);flex:1;height:1px}.login__social-btns{gap:var(--sp-2);display:flex}.login__social-btn{border:1px solid var(--line);border-radius:var(--radius-sm);height:44px;color:var(--text);cursor:not-allowed;opacity:.5;background:#ffffffc7;flex:1;font-size:13px;font-weight:600}.login__social-btn--wechat{color:#4f8d5a;background:#eefcf4d1;border-color:#d9f0df}.pkg-grid{gap:var(--sp-5);grid-template-columns:repeat(3,1fr);display:grid}.pkg-card{border-radius:var(--radius-xl);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);box-shadow:var(--shadow-sm);transition:transform var(--transition-normal),box-shadow var(--transition-normal);background:#ffffffd1;border:1px solid #e4eaff99;animation:.32s both card-enter;overflow:hidden}.pkg-card:hover{transform:translateY(-3px);box-shadow:0 12px 32px #7086d224}.pkg-card__cover{height:200px;position:relative;overflow:hidden}.pkg-card__badge{top:var(--sp-3);right:var(--sp-3);border-radius:var(--radius-pill);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);color:var(--text);box-shadow:var(--shadow-sm);background:#ffffffd9;border:1px solid #fff9;padding:4px 10px;font-size:11px;font-weight:700;position:absolute}.pkg-card__body{padding:var(--sp-4)var(--sp-5)}.pkg-card__title{margin-bottom:var(--sp-2);font-size:18px;font-weight:800}.pkg-card__meta{gap:var(--sp-1);color:var(--text-secondary);margin-bottom:var(--sp-4);flex-direction:column;font-size:14px;display:flex}.pkg-card__footer{color:var(--muted);margin-top:var(--sp-2);font-size:12px}.detail-info{gap:var(--sp-5);padding:var(--sp-5);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);border-radius:var(--radius-lg);box-shadow:var(--shadow-md);margin-bottom:var(--sp-4);background:linear-gradient(#eef3fff2,#ffffffeb);border:1px solid #fff9;grid-template-columns:320px 1fr;display:grid}.detail-info__title{margin:10px 0 8px;font-size:28px;font-weight:800}.detail-info__summary{color:var(--muted);margin-bottom:var(--sp-4);font-size:14px;line-height:1.8}.detail-cover{border-radius:var(--radius-md);background:linear-gradient(135deg,#f0f7ff,#ede8ff);border:1px solid #dfe7ff;min-height:240px;position:relative;overflow:hidden}.detail-cover--empty:after{content:"";opacity:.15;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='64' height='64' viewBox='0 0 24 24' fill='none' stroke='%234d6098' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Crect width='18' height='18' x='3' y='3' rx='2' ry='2'/%3E%3Ccircle cx='9' cy='9' r='2'/%3E%3Cpath d='m21 15-3.086-3.086a2 2 0 0 0-2.828 0L6 21'/%3E%3C/svg%3E");background-repeat:no-repeat;background-size:contain;width:64px;height:64px;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.detail-meta-grid{gap:var(--sp-2);grid-template-columns:repeat(4,1fr);display:grid}.detail-meta-item{-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);border-radius:var(--radius-md);padding:var(--sp-3);transition:background var(--transition-fast);background:#ffffff80;border:1px solid #e4eaff80}.detail-meta-item:hover{background:#ffffffb3}.detail-meta-label{color:var(--muted);margin-bottom:var(--sp-1);font-size:12px}.detail-meta-value{font-size:15px;font-weight:800}.detail-meta-value--success{color:var(--green)}.lesson-list{border:1px solid var(--line);border-radius:var(--radius-lg);padding:var(--sp-5);background:#ffffffd1}.lesson-list__title{margin-bottom:var(--sp-1);font-size:18px;font-weight:800}.lesson-row__meta{color:var(--muted);margin-bottom:var(--sp-1);font-size:13px}.lesson-row{gap:var(--sp-4);padding:var(--sp-4);border-radius:var(--radius-lg);background:var(--bg-faint);border:1px solid var(--line);transition:all var(--transition-normal);grid-template-columns:90px 1fr auto;align-items:center;display:grid}.lesson-row:hover{box-shadow:var(--shadow-sm);background:#ffffffe6;border-color:#dfe7ff;transform:translateY(-1px)}.lesson-row__no{color:var(--text-secondary);font-size:14px;font-weight:700}.lesson-row__title{margin-bottom:var(--sp-2);font-size:18px;font-weight:800}.lesson-row__tags{gap:var(--sp-1);margin-bottom:var(--sp-1);flex-wrap:wrap;display:flex}.lesson-row__summary{color:var(--muted);font-size:13px}.lesson-topbar{border-bottom:1px solid var(--line);height:54px;padding:0 var(--sp-5);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#fff9;flex-shrink:0;justify-content:space-between;align-items:center;display:flex;position:relative}.lesson-topbar__left{align-items:center;gap:var(--sp-3);display:flex}.lesson-topbar__link{color:var(--brand);transition:color var(--transition-fast);font-size:13px;font-weight:600;text-decoration:none}.lesson-topbar__link:hover{color:#6079f5}.lesson-topbar__title{color:var(--text);font-size:14px;font-weight:700}.lesson-progress{background:linear-gradient(90deg,#6f86ff,#61d1ff);border-radius:0 999px 999px 0;height:3px;transition:width .15s;position:absolute;bottom:0;left:0}.lesson-scroll{flex:1;overflow-y:auto}.lesson-content{padding:var(--sp-8)var(--sp-6)64px;max-width:1180px;margin:0 auto}.lesson-layout{gap:var(--sp-6);margin-top:var(--sp-6);grid-template-columns:260px 1fr;align-items:start;display:grid}.lesson-toc-wrap{padding:var(--sp-5);position:sticky;top:20px}.lesson-hero{padding:var(--sp-8)var(--sp-10);border-radius:var(--radius-xl);color:#fff;background:linear-gradient(135deg,#5a96e6eb,#826ed2f0);border:1px solid #ffffff59;position:relative;overflow:hidden}.lesson-hero:before{content:"";filter:blur(4px);background:#ffffff2e;border-radius:50%;width:180px;height:180px;position:absolute;top:-40px;right:-40px}.lesson-hero:after{content:"";filter:blur(4px);background:#ffffff2e;border-radius:50%;width:120px;height:120px;position:absolute;bottom:-28px;left:-20px}.lesson-hero__inner{z-index:1;position:relative}.lesson-hero__tags{margin-bottom:var(--sp-4);flex-wrap:wrap;gap:10px;display:flex}.lesson-hero__tag{border-radius:var(--radius-pill);background:#ffffff38;border:1px solid #ffffff47;align-items:center;padding:7px 12px;font-size:13px;font-weight:600;display:inline-flex}.lesson-hero__title{margin:0 0 10px;font-size:36px;font-weight:800;line-height:1.15}.lesson-hero__subtitle{opacity:.96;max-width:780px;margin:0 0 20px;font-size:16px;line-height:1.75}.lesson-hero__cards{gap:var(--sp-4);grid-template-columns:1.25fr .75fr;display:grid}.lesson-hero__card{border-radius:var(--radius-xl);padding:var(--sp-5);background:#ffffff2e;border:1px solid #ffffff40}.lesson-hero__card-label{opacity:.9;margin-bottom:var(--sp-2);font-size:13px;font-weight:700}.lesson-hero__card-value{font-size:17px;font-weight:700}.lesson-section{border:1px solid var(--line);border-radius:var(--radius-lg);margin-bottom:var(--sp-8);box-shadow:var(--shadow-sm);overflow:hidden}.lesson-section__header{padding:var(--sp-4)var(--sp-5);border-bottom:1px solid var(--line);border-left:3px solid var(--brand);background:linear-gradient(135deg,#8bb1ff1f,#cbb7ff14);font-size:18px;font-weight:800}.lesson-section__body{padding:var(--sp-5);gap:var(--sp-5);flex-direction:column;display:flex}.lesson-block--text{color:var(--text);margin:6px 0;font-size:15px;line-height:1.75}.lesson-block--quote{padding:var(--sp-4);border-radius:var(--radius-md);border-left:3px solid var(--brand);color:var(--text-secondary);background:linear-gradient(135deg,#7e95ff0f,#7e95ff05);font-size:14px;line-height:1.7}.lesson-block--list{margin:6px 0 0;padding-left:20px;font-size:15px;line-height:1.8}.lesson-block--template{border:1px dashed var(--line);border-radius:var(--radius-md);background:#f5f3ff;overflow:hidden}.lesson-block--template__label{padding:var(--sp-2)var(--sp-3);color:var(--brand);background:#eef3ff80;justify-content:space-between;align-items:center;font-size:12px;font-weight:700;display:flex}.lesson-block--template__body{padding:var(--sp-3);white-space:pre-wrap;font-size:14px;line-height:1.8}.lesson-block--template__footer{padding:var(--sp-1)var(--sp-3);justify-content:flex-end;display:flex}.lesson-block--box{padding:var(--sp-4);border-radius:var(--radius-md);background:#f9fafb;border:1px solid #e5e7eb;font-size:14px;line-height:1.7}.lesson-block--box--note{background:var(--warning-light);border-color:#ffe8a6}.lesson-block--box--success{background:var(--green-light);border-color:var(--green-border)}.lesson-block--box--danger{background:var(--danger-light);border-color:var(--danger-border)}.lesson-block--box__title{margin:0 0 8px;font-size:17px;font-weight:700}.lesson-block--accordion{border:1px solid var(--line);border-left:3px solid var(--brand);border-radius:var(--radius-lg);margin-bottom:var(--sp-5);overflow:hidden}.lesson-block--accordion__summary{cursor:pointer;padding:var(--sp-4)var(--sp-5);transition:background var(--transition-fast);border-bottom:1px solid var(--line);background:#eef3ffcc;justify-content:space-between;align-items:center;font-size:15px;font-weight:700;list-style:none;display:flex}.lesson-block--accordion__summary:hover{background:#e4ecffe6}.lesson-block--accordion__body{padding:var(--sp-4)var(--sp-5)var(--sp-5);background:var(--bg-faint)}.lesson-block--qa{gap:var(--sp-2);padding-left:var(--sp-3);border-left:2px solid #e4eaffb3;display:grid}.lesson-block--qa__question{font-size:15px;font-weight:700}.lesson-block--qa__answer{color:var(--text-secondary);margin:0;font-size:14px}.lesson-pill{margin-bottom:10px}.lesson-toc__item--active{color:var(--brand);border-left:2px solid var(--brand);padding-left:calc(var(--sp-3) - 2px);background:#7e95ff2e;font-weight:700}.lesson-block--qa{gap:var(--sp-3);display:grid}.lesson-toc{top:var(--sp-5);position:sticky}.lesson-toc__title{margin-bottom:var(--sp-3);color:var(--text);font-size:13px;font-weight:800}.lesson-toc__item{width:100%;padding:var(--sp-2)var(--sp-3);border-radius:var(--radius-xs);color:var(--muted);text-align:left;cursor:pointer;transition:background var(--transition-fast),color var(--transition-fast);background:0 0;border:none;font-size:13px;font-weight:600;display:block}.lesson-toc__item:hover{color:var(--text);background:#eef3ffb3}.btn-copy{color:var(--brand);cursor:pointer;padding:2px var(--sp-2);border-radius:var(--radius-xs);transition:color var(--transition-fast),background var(--transition-fast);background:0 0;border:none;font-size:11px;font-weight:600}.btn-copy:hover{background:#7e95ff14}.btn-copy--success{color:var(--green)}.admin-header{margin-bottom:var(--sp-5);justify-content:space-between;align-items:center;display:flex}.admin-header__title{font-size:24px;font-weight:800}.admin-header__subtitle{color:var(--muted);margin-top:var(--sp-1);font-size:14px}.upload-zone{border:2px dashed var(--line);border-radius:var(--radius-lg);padding:var(--sp-8);text-align:center;cursor:pointer;transition:border-color var(--transition-fast),background var(--transition-fast)}.upload-zone:hover,.upload-zone--has-file{border-color:var(--brand);background:#eef3ff4d}.upload-result{padding:var(--sp-4);border-radius:var(--radius-md);font-size:14px}.upload-result--success{background:var(--green-light)}.upload-result--error{background:var(--danger-light);color:var(--danger)}.avatar-btn{cursor:pointer;color:#fff;width:36px;height:36px;transition:box-shadow var(--transition-fast);background:linear-gradient(135deg,#8bb1ff,#7ea5ff);border:2px solid #ffffffb3;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:14px;font-weight:800;display:flex;box-shadow:0 4px 12px #7e95ff47}.avatar-btn:hover{box-shadow:0 6px 18px #7e95ff6b}.avatar-dropdown{-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border:1px solid var(--line);border-radius:var(--radius-lg);z-index:999;background:#fffffff5;min-width:168px;animation:.15s dropdown-enter;position:fixed;overflow:hidden;box-shadow:0 12px 32px #7086d224}.avatar-dropdown__info{padding:var(--sp-3)var(--sp-4);border-bottom:1px solid var(--line)}.avatar-dropdown__name{color:var(--text);font-size:14px;font-weight:800}.avatar-dropdown__logout{width:100%;padding:var(--sp-2)var(--sp-4);align-items:center;gap:var(--sp-2);cursor:pointer;color:#e05a5a;text-align:left;transition:background var(--transition-fast);background:0 0;border:none;font-size:13px;font-weight:600;display:flex}.avatar-dropdown__logout:hover{background:#e05a5a0f}.muted{color:var(--muted)}.text-brand{color:var(--brand)}.text-success{color:var(--green)}.text-danger{color:var(--danger)}.small{font-size:13px}.bold{font-weight:800}.sr-only{clip:rect(0,0,0,0);width:1px;height:1px;position:absolute;overflow:hidden}.text-center{text-align:center}.truncate{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.animate-fade-in{animation:.25s fade-in}@keyframes fade-in{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}@keyframes card-enter{0%{opacity:0;transform:translateY(12px)scale(.97)}to{opacity:1;transform:translateY(0)scale(1)}}@keyframes modal-enter{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}@keyframes dropdown-enter{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}@keyframes orb-drift{0%,to{transform:translate(0)scale(1)}33%{transform:translate(6px,-8px)scale(1.04)}66%{transform:translate(-4px,4px)scale(.97)}}@keyframes pulse-soft{0%,to{opacity:1}50%{opacity:.5}}@media print{body{color:#333!important;background:#fff!important;font-size:12px!important}.sidebar,.topbar,.lesson-topbar,.page-shell__orb,.no-print,.btn-copy{display:none!important}.page-wrap{padding:0!important}.page-shell{box-shadow:none!important;background:#fff!important;border:none!important;border-radius:0!important;overflow:visible!important}.page-shell__inner{overflow:visible!important}.shell{grid-template-columns:1fr!important;height:auto!important;min-height:0!important}.main,.lesson-scroll{height:auto!important;overflow:visible!important}.lesson-toc{display:none!important}.lesson-hero{margin-bottom:12px!important;padding:16px!important}.lesson-section{margin-bottom:8px!important}.lesson-section__header{padding:10px 14px!important}.lesson-section__body{gap:8px!important;padding:12px 14px!important}.lesson-block--box,.lesson-block--template,.lesson-block--quote{page-break-inside:avoid}.lesson-block--grid,.lesson-layout{grid-template-columns:1fr!important}.lesson-hero{color:#333!important;background:linear-gradient(135deg,#e8f0ff,#f0ecff)!important;border:1px solid #dde5fb!important}.lesson-hero h1{color:#333!important}.lesson-hero__tag{color:#4d6098!important;background:#eef3ff!important;border:1px solid #dde5fb!important}}@media (max-width:900px){.shell{grid-template-columns:1fr}.sidebar{display:none}.login__grid{grid-template-columns:1fr}}
