*{box-sizing:border-box}body{color:#2d2b28;-webkit-font-smoothing:antialiased;background:#faf8f5;margin:0;font-family:DM Sans,PingFang SC,Microsoft YaHei,sans-serif}button,a{font:inherit}.login-shell{grid-template-columns:minmax(0,1fr) 460px;min-height:100vh;display:grid}.login-visual{color:#faf8f5;background:linear-gradient(#14161ec7,#14161ee0),url(https://images.unsplash.com/photo-1522202176988-66273c2fd55f?auto=format&fit=crop&w=1600&q=80) 50%/cover;flex-direction:column;justify-content:center;padding:64px;display:flex;position:relative;overflow:hidden}.login-visual:after{content:"";pointer-events:none;background:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.04'/%3E%3C/svg%3E");position:absolute;inset:0}.login-visual .brand-mark{color:#faf8f5;letter-spacing:.06em;z-index:1;background:#b8943e38;border:1px solid #b8943e59;border-radius:3px;width:fit-content;margin-bottom:42px;padding:6px 16px;font-family:Playfair Display,serif;font-size:15px;font-weight:700;position:relative}.login-visual h1{letter-spacing:-.01em;z-index:1;max-width:520px;font-family:Playfair Display,serif;font-size:48px;font-weight:700;line-height:1.08;position:relative}.login-visual p{color:#d4cfc4;z-index:1;max-width:520px;font-size:17px;font-weight:400;line-height:1.7;position:relative}.login-panel{background:#f5f1ea;align-items:center;padding:36px;display:grid}.login-card{background:#fffdf9;border:1px solid #e4ddd2;border-radius:4px;padding:32px 28px;box-shadow:0 1px #0000000a}.login-card h2{letter-spacing:-.01em;margin:14px 0 24px;font-family:Playfair Display,serif;font-size:26px;font-weight:700}.login-card .el-button{width:100%}.login-card .el-button--primary{--el-button-bg-color:#1a1d2e;--el-button-border-color:#1a1d2e;--el-button-hover-bg-color:#2d3146;--el-button-hover-border-color:#2d3146;letter-spacing:.02em;border-radius:3px;font-family:DM Sans,sans-serif;font-weight:600}.fingerprint-note{color:#8a8478;align-items:center;gap:8px;min-height:38px;margin-bottom:18px;font-size:13px;display:flex}.student-shell{grid-template-columns:244px 1fr;min-height:100vh;display:grid}.mobile-menu-btn{z-index:40;color:#e4ddd2;cursor:pointer;background:#1a1d2e;border:1px solid #ffffff0f;border-radius:4px;justify-content:center;align-items:center;width:44px;height:44px;display:none;position:fixed;top:12px;left:12px}.mobile-overlay{z-index:20;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#14161e80;display:none;position:fixed;inset:0}.sidebar{color:#e4ddd2;background:#14161e;border-right:1px solid #ffffff0a;height:100vh;padding:32px 18px;position:sticky;top:0}.sidebar:before{content:"";pointer-events:none;background:radial-gradient(80% 50% at 0 20%,#b8943e0f,#0000),radial-gradient(60% 40% at 100% 80%,#5a8a6e0a,#0000);position:absolute;inset:0}.brand{letter-spacing:-.01em;margin-bottom:32px;padding:0 10px;font-family:Playfair Display,serif;font-size:24px;font-weight:700;position:relative}.brand:after{content:"";background:#b8943e;width:28px;height:2px;margin-top:10px;display:block}.sidebar nav{gap:4px;display:grid;position:relative}.sidebar a{color:#9a9488;border-radius:4px;align-items:center;gap:10px;min-height:44px;padding:0 12px;font-size:14px;font-weight:500;text-decoration:none;transition:color .2s,background .2s;display:flex;position:relative}.sidebar a.active,.sidebar a:hover{color:#e4ddd2;background:#ffffff0d}.sidebar a.active:before{content:"";background:#b8943e;border-radius:0 2px 2px 0;width:3px;position:absolute;top:10px;bottom:10px;left:0}.workspace{width:100%;max-width:1540px;padding:34px}.topbar{justify-content:space-between;align-items:center;margin-bottom:28px;display:flex}.topbar-actions{flex-wrap:wrap;justify-content:flex-end;gap:10px;display:flex}.topbar-actions .el-button{min-height:36px}.eyebrow{color:#b8943e;letter-spacing:.08em;text-transform:uppercase;margin:0 0 4px;font-family:DM Sans,sans-serif;font-size:12px;font-weight:600}h1,h2,p{margin-top:0}h1{letter-spacing:-.01em;margin-bottom:0;font-family:Playfair Display,serif;font-size:36px;font-weight:700;line-height:1.12}.study-stage{grid-template-columns:minmax(0,1fr) 380px;align-items:start;gap:20px;margin-bottom:24px;display:grid}.stage-main{gap:16px;min-width:0;display:grid}.course-brief{background:#fffdf9;border:1px solid #e4ddd2;border-radius:4px;justify-content:space-between;align-items:center;gap:18px;min-height:118px;padding:24px 28px;display:flex;box-shadow:0 1px #00000008}.course-brief h2{margin-bottom:8px;font-family:Playfair Display,serif;font-size:24px;font-weight:700;line-height:1.18}.course-brief span{color:#8a8478;font-size:14px}.player-surface{color:#e4ddd2;text-align:center;background:#0c0d13;border-radius:4px;grid-template-rows:minmax(420px,1fr) auto auto;gap:12px;min-height:530px;padding:14px;display:grid;position:relative;overflow:hidden;box-shadow:0 24px 80px #14161e40}.player-surface strong,.player-surface small{z-index:1;display:block;position:relative}.player-surface .lucide,.player-surface .play-auth-status,.player-surface .player-progress,.player-surface .player-hint{z-index:1;position:relative}.player-hint{color:#8a8478;margin-top:8px;font-size:13px;display:block}.player-placeholder{color:#d4cfc4;align-content:center;justify-items:center;gap:10px;min-height:420px;display:grid}.aliyun-player-shell,.aliyun-player,.aliyun-player .prism-player{border-radius:4px;width:100%;min-width:0;height:100%;min-height:420px;overflow:hidden}.aliyun-player-shell{z-index:1;position:relative}.demo-player-shell{z-index:1;color:#e8e2d6;background:linear-gradient(135deg,#091118f2,#212a30eb),radial-gradient(circle at 72% 24%,#b8943e38,#0000 34%);border:1px solid #ffffff14;border-radius:4px;align-content:center;justify-items:center;gap:12px;width:100%;min-height:420px;display:grid;position:relative;overflow:hidden}.demo-player-shell strong{font-size:20px}.demo-player-shell span{color:#b8b0a2;font-size:13px}.demo-player-toggle{color:#17120c;cursor:pointer;background:#d8a84d;border:0;border-radius:4px;min-width:92px;min-height:34px;padding:0 16px;font-weight:700}.play-auth-status{color:#d4cfc4;background:#ffffff0f;border:1px solid #ffffff1a;border-radius:3px;justify-self:center;align-items:center;gap:6px;min-height:30px;padding:0 10px;font-size:13px;display:inline-flex}.player-trial-badge{color:#b8943e;letter-spacing:.04em;background:#b8943e26;border:1px solid #b8943e40;border-radius:2px;padding:1px 8px;font-size:11px;font-weight:600;display:inline-block}.player-progress{color:#b8b0a2;justify-self:center;gap:8px;width:min(360px,90%);font-size:13px;display:grid}.player-progress .el-progress{width:100%}.player-surface.pseudo-fullscreen{z-index:9999;border-radius:0;grid-template-rows:1fr auto auto;padding:0;position:fixed;inset:0}.player-surface.pseudo-fullscreen .aliyun-player,.player-surface.pseudo-fullscreen .aliyun-player .prism-player,.player-surface.pseudo-fullscreen .player-placeholder{min-height:0}.player-surface.pseudo-fullscreen .aliyun-player-shell{z-index:1;position:absolute;inset:0}.player-surface.pseudo-fullscreen .player-progress,.player-surface.pseudo-fullscreen .play-auth-status,.player-surface.pseudo-fullscreen .fullscreen-toggle{z-index:2}.fullscreen-toggle{z-index:3;color:#e4ddd2;cursor:pointer;opacity:0;background:#0006;border:1px solid #ffffff14;border-radius:4px;justify-content:center;align-items:center;width:36px;height:36px;transition:opacity .25s;display:inline-flex;position:absolute;top:12px;right:12px}.player-surface:hover .fullscreen-toggle,.player-surface.pseudo-fullscreen .fullscreen-toggle{opacity:1}.wechat-protected img,.wechat-protected video{-webkit-touch-callout:none;pointer-events:auto}x5-video-player-type[h5-page]{display:block}.lesson-list{background:#fffdf9;border:1px solid #e4ddd2;border-radius:4px;min-width:0;padding:24px;box-shadow:0 1px #00000008}.panel-heading{justify-content:space-between;align-items:center;gap:12px;margin-bottom:16px;display:flex}.panel-heading h2{margin-bottom:0;font-family:Playfair Display,serif;font-size:18px;font-weight:700}.panel-heading>span,.panel-heading>svg{color:#b8943e}.panel-heading.compact{margin-bottom:10px}.chapter-scroll{max-height:292px;padding-right:2px;display:grid;overflow:auto}.lesson-list button{color:#2d2b28;cursor:pointer;text-align:left;background:#faf8f5;border:1px solid #e8e4dc;border-radius:4px;align-items:center;gap:8px;width:100%;min-height:44px;margin-top:10px;padding:0 14px;font-family:DM Sans,sans-serif;font-size:14px;transition:background .15s,border-color .15s;display:flex}.lesson-list .chapter-row{padding-left:calc(14px + (var(--chapter-depth,0) * 18px))}.lesson-list .chapter-section{color:#5f574c;cursor:default;background:#fffaf0}.lesson-list .chapter-section:disabled{opacity:1}.lesson-list button span{text-align:left;text-overflow:ellipsis;white-space:nowrap;flex:1;min-width:0;overflow:hidden}.lesson-list button small{color:#8a8478}.lesson-list .outline{color:#5a5548;background:#fffdf9;border-color:#ddd8cc}.lesson-list button.active{color:#faf8f5;background:#1a1d2e;border-color:#1a1d2e}.lesson-list button.active small{color:#a09888}.resource-section{border-top:1px solid #e8e4dc;margin-top:20px;padding-top:20px}.resource-row{grid-template-columns:22px minmax(0,1fr) auto;align-items:center;column-gap:8px;min-height:42px;display:grid}.resource-row span,.selected-files span{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.assignment-form{gap:10px;display:grid}.file-pick-button{color:#2d2b28;cursor:pointer;background:#faf8f5;border:1px dashed #c4bdb0;border-radius:4px;justify-content:center;align-items:center;gap:8px;min-height:40px;font-size:14px;transition:border-color .15s,background .15s;display:inline-flex}.file-pick-button:hover{background:#f5ecd7;border-color:#b8943e}.selected-files{gap:8px;display:grid}.selected-files button{background:#fffdf9;grid-template-columns:20px minmax(0,1fr) auto;align-items:center;column-gap:8px;min-height:42px;margin-top:0;display:grid}.submission-summary{color:#3d4a3e;background:#f2f7f1;border:1px solid #d4e4d0;border-radius:4px;gap:4px;min-height:76px;padding:16px;display:grid}.submission-summary span,.submission-summary small{color:#5a6b58;font-size:13px}.submission-summary p{color:#314035;margin:4px 0 0;line-height:1.6}.visually-hidden{white-space:nowrap;clip:rect(0, 0, 0, 0);border:0;width:1px;height:1px;padding:0;position:absolute;overflow:hidden}.chapter-drawer-toggle{margin-top:10px;display:none}.chapter-drawer-toggle .el-button{width:100%}.lesson-drawer{max-height:420px;margin-top:10px}.course-grid{gap:18px;margin-bottom:24px;display:grid}.grid-lg{grid-template-columns:repeat(4,minmax(0,1fr))}.grid-md{grid-template-columns:repeat(3,minmax(0,1fr))}.grid-sm{grid-template-columns:repeat(2,minmax(0,1fr))}.grid-xs{grid-template-columns:1fr}.course-card{cursor:pointer;background:#fffdf9;border:1px solid #e4ddd2;border-radius:4px;transition:border-color .25s,box-shadow .25s,transform .25s;overflow:hidden}.course-card:hover,.course-card.active{border-color:#b8943e;transform:translateY(-2px);box-shadow:0 18px 44px #14161e1f}.cover{color:#faf8f5;letter-spacing:-.01em;height:120px;padding:20px;font-family:Playfair Display,serif;font-size:20px;font-weight:700;position:relative;overflow:hidden}.cover:after{content:"";pointer-events:none;background:linear-gradient(135deg,#ffffff14,#0000 60%);position:absolute;inset:0}.image-cover{background:#1a1d2e;padding:0}.image-cover img{object-fit:cover;width:100%;height:100%;display:block}.cover.teal{background:#2d5a54}.cover.indigo{background:#364e78}.cover.rose{background:#7a3a4d}.cover.amber{background:#7a5c28}.course-body{padding:18px}.course-body h2{margin-bottom:6px;font-family:Playfair Display,serif;font-size:17px;font-weight:700}.course-body p{color:#8a8478;font-size:14px;line-height:1.5}.catalog-panel{margin-bottom:24px}.catalog-toolbar{grid-template-columns:minmax(240px,1fr) 220px;gap:12px;margin-bottom:18px;display:grid}.catalog-grid{grid-template-columns:repeat(3,minmax(0,1fr));gap:18px;display:grid}.catalog-card{background:#fffdf9;border:1px solid #e4ddd2;border-radius:4px;flex-direction:column;min-height:430px;display:flex;overflow:hidden;box-shadow:0 1px #00000008}.catalog-cover{color:#faf8f5;background:linear-gradient(135deg,#1b3f4f,#6b5748);justify-content:space-between;align-items:flex-end;min-height:138px;padding:20px;display:flex}.catalog-cover span,.catalog-cover strong{z-index:1;position:relative}.catalog-cover strong{font-size:18px}.catalog-body{flex-direction:column;flex:1;gap:14px;padding:18px;display:flex}.catalog-title-row{justify-content:space-between;align-items:flex-start;gap:10px;display:flex}.catalog-title-row h2{margin-top:4px;font-family:Playfair Display,serif;font-size:20px;line-height:1.25}.catalog-body p{color:#6f685f;-webkit-line-clamp:2;-webkit-box-orient:vertical;min-height:42px;font-size:14px;line-height:1.5;display:-webkit-box;overflow:hidden}.catalog-order-state{color:#594f3f;background:#fbf5e8;border:1px solid #ead8ae;border-radius:4px;grid-template-columns:18px minmax(0,1fr);align-items:flex-start;gap:8px;padding:10px;font-size:13px;line-height:1.45;display:grid}.catalog-order-state svg{color:#a17220;margin-top:1px}.catalog-meta{flex-wrap:wrap;gap:8px;display:flex}.catalog-meta span,.trial-list span{color:#4b4741;background:#faf8f5;border:1px solid #e8e4dc;border-radius:4px;align-items:center;min-height:28px;padding:0 9px;font-size:12px;display:inline-flex}.trial-list{flex-wrap:wrap;gap:8px;display:flex}.catalog-actions{justify-content:space-between;align-items:center;gap:12px;margin-top:auto;padding-top:4px;display:flex}.catalog-actions .el-button{min-height:36px;margin-left:0}.catalog-actions strong{color:#1a1d2e;font-size:20px}.empty-state.compact{min-height:220px}.insight-grid{grid-template-columns:minmax(300px,1fr) minmax(280px,.78fr) minmax(300px,.85fr);align-items:start;gap:16px;display:grid}.flow,.device-panel,.order-panel{background:#fffdf9;border:1px solid #e4ddd2;border-radius:4px;align-content:start;gap:16px;min-width:0;padding:24px;display:grid;box-shadow:0 1px #00000008}.flow h2,.device-panel h2,.order-panel h2{margin-bottom:0}.flow ol{grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;margin:0;padding:0;list-style:none;display:grid}.flow li{background:#faf8f5;border:1px solid #e8e4dc;border-radius:4px;align-content:center;gap:8px;min-height:76px;padding:14px;display:grid}.flow li span{color:#6f685d;font-size:12px;line-height:1.35}.flow li strong{color:#2d2b28;font-size:18px;font-weight:700;line-height:1.15}.device-row{border-bottom:1px solid #ece8df;grid-template-columns:24px minmax(0,1fr) 112px;align-items:start;gap:12px;min-height:64px;padding:10px 0;display:grid}.order-row{border-bottom:1px solid #ece8df;grid-template-columns:24px minmax(0,1fr) 110px;align-items:start;gap:12px;min-height:88px;padding:12px 0;display:grid}.device-row>svg,.order-row>svg{color:#6c665d;margin-top:4px}.device-row strong,.device-row span,.order-row strong,.order-row span,.order-row small{display:block}.device-row span,.order-row span,.order-row small,.muted{color:#8a8478;font-size:13px}.device-main,.order-main{min-width:0}.device-main strong,.order-main strong{overflow-wrap:anywhere;line-height:1.35}.device-main span,.order-main span{margin-top:3px;line-height:1.35}.order-row small{overflow-wrap:anywhere;max-width:100%;margin-top:5px;line-height:1.4}.device-row-actions,.order-row-actions{flex-wrap:nowrap;justify-content:flex-end;align-items:center;gap:6px;min-width:0;display:flex}.device-row-actions .el-button,.order-row-actions .el-button{min-width:44px;margin-left:0}.order-row-actions{align-content:flex-start;width:110px}.device-row-actions{width:112px}.device-row-actions .el-tag,.order-row-actions .el-tag{height:26px;line-height:24px}.device-row-actions .el-button--small,.order-row-actions .el-button--small{height:26px;padding:0 9px}.empty-state{color:#8a8478;text-align:center;background:#fffdf9;border:1px solid #e4ddd2;border-radius:4px;place-items:center;min-height:300px;margin-bottom:24px;padding:40px;display:grid}.empty-state h2{color:#2d2b28;margin:14px 0 6px;font-family:Playfair Display,serif}.el-button{letter-spacing:.01em;border-radius:4px;justify-content:center;align-items:center;font-family:DM Sans,sans-serif;font-weight:500;display:inline-flex}.el-button+.el-button{margin-left:0}.el-button--primary{--el-button-bg-color:#1a1d2e;--el-button-border-color:#1a1d2e;--el-button-hover-bg-color:#2d3146;--el-button-hover-border-color:#2d3146;--el-button-active-bg-color:#0f1119;--el-button-active-border-color:#0f1119}.el-input__wrapper{border-radius:4px;box-shadow:inset 0 0 0 1px #d5cec1}.el-input__wrapper:hover{box-shadow:inset 0 0 0 1px #b8b0a2}.el-input__wrapper.is-focus{box-shadow:inset 0 0 0 1px #b8943e}.el-form-item__label{color:#5a5548;font-family:DM Sans,sans-serif;font-weight:500}.el-tag{border-radius:3px}.el-dialog{border-radius:6px}.el-message{border-radius:4px}@media (width<=767px){.el-message{max-width:calc(100vw - 24px);top:72px!important}}@keyframes drawerIn{0%{opacity:0;transform:translateY(-12px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeUp{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}.course-card{animation:.5s both fadeUp}.course-card:first-child{animation-delay:50ms}.course-card:nth-child(2){animation-delay:.1s}.course-card:nth-child(3){animation-delay:.15s}.course-card:nth-child(4){animation-delay:.2s}.course-card:nth-child(5){animation-delay:.25s}.course-card:nth-child(6){animation-delay:.3s}.course-card:nth-child(7){animation-delay:.35s}.course-card:nth-child(8){animation-delay:.4s}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:#d5cec1;border-radius:3px}::-webkit-scrollbar-thumb:hover{background:#b8b0a2}@media (width<=1199px){.workspace{max-width:100%;padding:28px 24px}.course-grid{gap:14px}.catalog-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}@media (width<=991px){.student-shell,.login-shell,.study-stage,.insight-grid{grid-template-columns:1fr}.sidebar{height:auto;padding:18px;position:static}.sidebar nav{grid-template-columns:repeat(5,minmax(0,1fr));gap:6px}.sidebar a{justify-content:center;padding:0 8px;font-size:13px}.sidebar a.active:before{display:none}.brand{text-align:center;margin-bottom:14px}.brand:after{margin:10px auto 0}.workspace{padding:22px 18px}.flow ol{grid-template-columns:repeat(2,minmax(0,1fr))}.chapter-drawer-toggle{display:block}.lesson-drawer{max-height:460px;animation:.3s drawerIn;overflow-y:auto}.course-grid.grid-md{grid-template-columns:repeat(2,minmax(0,1fr))}.catalog-toolbar{grid-template-columns:1fr}}@media (width<=767px){.login-shell,.student-shell{grid-template-columns:1fr}.mobile-menu-btn{display:flex}.mobile-overlay{display:block}.sidebar{z-index:30;width:260px;height:100dvh;padding:64px 18px 18px;transition:transform .3s cubic-bezier(.22,.61,.36,1);position:fixed;top:0;left:0;overflow-y:auto;transform:translate(-100%)}.sidebar nav{grid-template-columns:1fr;gap:4px;display:grid}.sidebar a{justify-content:flex-start}.sidebar a.active:before{display:block}.brand{text-align:left;margin-bottom:28px}.brand:after{margin:10px 0 0}.sidebar.mobile-open{transform:translate(0)}.workspace{padding:56px 18px 18px}.topbar{flex-direction:column;align-items:flex-start;gap:10px}.topbar-actions{justify-content:flex-start;width:100%}.player-surface{min-height:240px;padding:16px}.flow ol{grid-template-columns:1fr}h1{font-size:26px}.student-shell{padding-top:env(safe-area-inset-top);padding-bottom:env(safe-area-inset-bottom);padding-left:env(safe-area-inset-left);padding-right:env(safe-area-inset-right)}.player-surface,.player-placeholder,.aliyun-player-shell,.aliyun-player,.aliyun-player .prism-player{min-height:300px}.course-brief{flex-direction:column;align-items:flex-start}.login-visual{min-height:240px;padding:36px}.login-panel{padding:18px}.login-visual h1{font-size:34px}.course-grid.grid-sm{grid-template-columns:repeat(2,minmax(0,1fr))}.catalog-grid{grid-template-columns:1fr}}@media (width<=479px){.workspace{padding:52px 12px 12px}.sidebar a{font-size:13px}.player-surface{min-height:200px}.player-surface strong{font-size:15px}.topbar-actions{flex-direction:column;width:100%}.topbar-actions .el-button{width:100%}.course-grid.grid-xs,.course-grid.grid-sm{grid-template-columns:1fr}.catalog-actions{flex-direction:column;align-items:stretch}.catalog-actions .el-button{width:100%}.course-brief h2{font-size:20px}.player-surface,.player-placeholder,.aliyun-player-shell,.aliyun-player,.aliyun-player .prism-player{min-height:220px}}
