.app-error-fallback[data-v-294ce32d]{min-height:60vh;display:grid;place-content:center;gap:12px;padding:24px;text-align:center}.app-error-fallback h1[data-v-294ce32d]{margin:0;font-size:1.35rem}.app-error-fallback p[data-v-294ce32d]{margin:0;color:#64748b}.app-error-fallback button[data-v-294ce32d]{justify-self:center;border:0;border-radius:10px;padding:10px 18px;background:#4f46e5;color:#fff;cursor:pointer}:root{--purple: #6d4aff;--purple-dark: #5336db;--purple-light: #eeeaff;--ink: #202036;--muted: #77778b;--line: #e9e7f1;--surface: #ffffff;--background: #fbfaff;--green: #1ba97f;--green-light: #e8f8f2;--orange: #ff994a;--orange-light: #fff2e8;--red: #e45a67;--shadow: 0 24px 60px rgba(66, 49, 120, .1)}html{scroll-behavior:smooth}body{margin:0;color:var(--ink);background:var(--background);font-family:DM Sans,Noto Sans SC,sans-serif;line-height:1.6}button,input{font:inherit}button,a{-webkit-tap-highlight-color:transparent}a{color:inherit;text-decoration:none}svg{width:24px;height:24px;fill:none;stroke:currentColor;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}.container{width:min(1160px,calc(100% - 40px));margin-inline:auto}.skip-link{position:fixed;top:-80px;left:16px;z-index:1000;padding:10px 16px;border-radius:8px;background:var(--ink);color:#fff}.skip-link:focus{top:16px}.site-header{position:sticky;top:0;z-index:50;background:#fbfaffdb;border-bottom:1px solid rgba(233,231,241,.8);-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px)}.nav{height:78px;display:flex;align-items:center;justify-content:space-between;gap:28px}.brand{display:inline-flex;align-items:center;gap:10px;font-size:19px;font-weight:800;white-space:nowrap}.brand-mark{width:36px;height:36px;display:grid;place-items:center;border-radius:11px;background:var(--purple);box-shadow:0 7px 16px #6d4aff40}.brand-mark svg{width:26px;height:26px;color:#fff;stroke-width:2.2}.nav-links{display:flex;align-items:center;gap:34px;margin-left:auto}.nav-links a{position:relative;color:#5e5c70;font-size:14px;font-weight:600;transition:color .2s ease}.nav-links a:hover,.nav-links a.active{color:var(--purple)}.nav-links a.active:after{content:"";position:absolute;left:50%;bottom:-27px;width:18px;height:3px;border-radius:3px;background:var(--purple);transform:translate(-50%)}.nav-actions{display:flex;align-items:center;gap:14px}.text-button,.menu-toggle{border:0;background:transparent;color:var(--ink);cursor:pointer;font-weight:600}.button{min-height:50px;display:inline-flex;align-items:center;justify-content:center;gap:16px;padding:0 24px;border-radius:14px;background:var(--purple);color:#fff;box-shadow:0 10px 22px #6d4aff3b;font-weight:700;transition:transform .2s ease,background .2s ease,box-shadow .2s ease}.button:hover{background:var(--purple-dark);transform:translateY(-2px);box-shadow:0 14px 28px #6d4aff47}.button:focus-visible,button:focus-visible,input:focus-visible,a:focus-visible{outline:3px solid rgba(109,74,255,.3);outline-offset:3px}.button-small{min-height:42px;padding-inline:19px;border-radius:11px;font-size:14px}.menu-toggle{display:none;width:44px;height:44px;padding:10px}.menu-toggle span{display:block;width:22px;height:2px;margin:5px 0;background:currentColor}.hero{position:relative;overflow:hidden;padding:92px 0 96px;background:radial-gradient(circle at 73% 42%,#f0ecff 0,rgba(240,236,255,.42) 25%,transparent 52%)}.hero-grid{display:grid;grid-template-columns:.92fr 1.08fr;align-items:center;gap:50px}.eyebrow{display:inline-flex;align-items:center;gap:9px;padding:8px 13px;border:1px solid #e3ddff;border-radius:99px;background:#ffffffbd;color:var(--purple);font-size:13px;font-weight:700}.eyebrow span{width:7px;height:7px;border-radius:50%;background:var(--purple);box-shadow:0 0 0 4px var(--purple-light)}.hero h1{margin:25px 0 22px;font-size:clamp(48px,5.2vw,72px);line-height:1.16;letter-spacing:-3px}.hero h1 em{position:relative;color:var(--purple);font-style:normal}.hero h1 em:after{content:"";position:absolute;left:4%;bottom:-7px;width:92%;height:9px;border-radius:50%;border-top:4px solid #f4b665;transform:rotate(-2deg)}.hero-copy>p{max-width:490px;margin:0;color:var(--muted);font-size:17px}.hero-actions{display:flex;align-items:center;gap:27px;margin-top:34px}.watch-link{display:inline-flex;align-items:center;gap:10px;font-size:14px;font-weight:700}.play-icon{width:38px;height:38px;display:grid;place-items:center;border:1px solid var(--line);border-radius:50%;background:#fff;color:var(--purple);font-size:11px;box-shadow:0 7px 16px #3c2d6c14}.social-proof{display:flex;align-items:center;gap:14px;margin-top:42px}.avatars{display:flex}.avatars span{width:33px;height:33px;display:grid;place-items:center;margin-left:-7px;border:3px solid white;border-radius:50%;background:#d8d0ff;color:var(--purple-dark);font-size:11px;font-weight:800}.avatars span:first-child{margin-left:0;background:#ffd9c2}.avatars span:nth-child(3){background:#c9efe2}.avatars span:nth-child(4){background:#ffe3a9}.social-proof strong,.social-proof small{display:block}.social-proof strong{font-size:14px}.social-proof small{color:var(--muted);font-size:12px}.hero-visual{position:relative;min-height:465px;display:grid;place-items:center}.main-illustration{position:relative;width:min(430px,90%);aspect-ratio:1.05;display:grid;place-items:center;border-radius:48% 52% 44% 56%/57% 41% 59% 43%;background:linear-gradient(145deg,#e8e1ff,#f5f1ff)}.orbit{position:absolute;border:1px solid rgba(109,74,255,.12);border-radius:50%}.orbit-one{inset:9%}.orbit-two{inset:-7%}.character{position:relative;width:205px;height:285px;z-index:2}.face{position:absolute;top:42px;left:49px;width:112px;height:128px;border-radius:49% 51% 45% 45%;background:#ffcbaa;box-shadow:inset 0 -8px #e8855d14;z-index:2}.hair{position:absolute;top:16px;left:31px;width:148px;height:118px;border-radius:52% 48% 37% 53%;background:#34304b;transform:rotate(-4deg);z-index:3;clip-path:polygon(0 0,100% 0,100% 80%,78% 62%,67% 36%,52% 66%,31% 50%,23% 80%,0 93%)}.eye{position:absolute;top:63px;width:9px;height:11px;border-radius:50%;background:#34304b}.eye.left{left:28px}.eye.right{right:28px}.smile{position:absolute;left:44px;top:88px;width:26px;height:13px;border-bottom:3px solid #c66e5c;border-radius:50%}.body{position:absolute;left:22px;bottom:2px;width:160px;height:143px;border-radius:60px 60px 25px 25px;background:var(--purple)}.book{position:absolute;left:24px;bottom:8px;width:159px;height:88px;border-radius:8px 8px 15px 15px;background:#fff;box-shadow:0 13px 22px #2d23542b;z-index:4;transform:perspective(100px) rotateX(-3deg);text-align:center;color:var(--purple);font-weight:800;padding-top:25px}.book:after{content:"";position:absolute;left:50%;top:0;bottom:0;border-left:1px solid #e4e0ef}.book span{position:relative;z-index:2;background:#fff;padding:3px 7px}.speech-bubble{position:absolute;z-index:3;padding:10px 17px;border-radius:15px;background:#fff;box-shadow:0 12px 26px #4531781c;color:var(--purple);font-size:14px;font-weight:800}.bubble-left{left:2%;top:33%}.bubble-right{right:3%;top:19%;color:var(--orange)}.float-card{position:absolute;z-index:5;display:flex;align-items:center;gap:11px;padding:13px 16px;border:1px solid rgba(255,255,255,.9);border-radius:14px;background:#ffffffed;box-shadow:var(--shadow);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.float-card small,.float-card strong{display:block}.float-card small{color:var(--muted);font-size:10px}.float-card strong{font-size:13px}.phrase-card{left:1%;top:5%}.progress-card{right:-2%;bottom:6%;min-width:205px}.mini-icon{width:36px;height:36px;display:grid;place-items:center;border-radius:10px;font-size:12px;font-weight:800}.mini-icon.purple{color:var(--purple);background:var(--purple-light)}.mini-icon.green{color:var(--green);background:var(--green-light)}.mini-icon svg{width:19px}.mini-progress{position:absolute;left:64px;right:16px;bottom:9px;height:3px;border-radius:3px;background:#e9e7ee}.mini-progress i{display:block;width:80%;height:100%;border-radius:inherit;background:var(--green)}.practice-section{padding:85px 0 92px;background:#fff}.section-heading{text-align:center}.section-kicker{color:var(--purple);font-size:13px;font-weight:800;letter-spacing:1px}.section-heading h2,.cta-card h2{margin:8px 0;font-size:clamp(30px,3vw,42px);letter-spacing:-1.5px}.section-heading p{margin:0;color:var(--muted);font-size:15px}.practice-layout{width:min(100%,1040px);display:block;margin:44px auto 0}.daily-card,.quiz-card,.stats-card{border:1px solid var(--line);background:#fff;box-shadow:0 15px 40px #3a2d6212}.daily-card,.stats-card{padding:22px;border-radius:18px}.daily-card{text-align:center}.daily-icon{width:48px;height:48px;display:grid;place-items:center;margin:0 auto 13px;border-radius:13px;background:var(--purple-light);color:var(--purple)}.daily-card>span{color:var(--muted);font-size:12px}.daily-card>strong{display:block;margin:6px 0 10px;font-size:26px}.daily-card>strong b{color:var(--purple)}.progress-track{height:7px;overflow:hidden;border-radius:99px;background:#eeecf4}.progress-track i{display:block;width:70%;height:100%;border-radius:inherit;background:var(--purple);transition:width .35s ease}.daily-card>p{margin:8px 0 19px;color:var(--muted);font-size:10px}.daily-card>p b{color:var(--purple)}.streak{display:flex;align-items:center;justify-content:center;gap:8px;padding-top:15px;border-top:1px solid var(--line);text-align:left}.streak svg{color:var(--orange);fill:var(--orange-light)}.streak strong,.streak small{display:block}.streak strong{font-size:14px}.streak small{color:var(--muted);font-size:10px}.quiz-card{width:100%;padding:32px 44px 38px;border-radius:24px;box-shadow:0 24px 64px #412e781f}.quiz-topbar{display:flex;align-items:center;justify-content:space-between}.level-pill{padding:6px 11px;border-radius:99px;background:var(--purple-light);color:var(--purple);font-size:10px;font-weight:700}.quiz-top-actions{display:flex;gap:8px}.sound-button,.fullscreen-button{min-width:76px;height:40px;display:flex;align-items:center;justify-content:center;gap:6px;padding:0 12px;border:1px solid var(--line);border-radius:10px;background:#fff;color:var(--purple);cursor:pointer;font-size:11px;font-weight:800}.sound-button svg,.fullscreen-button svg{width:17px}.fullscreen-button{color:#625e72}.fullscreen-button:hover,.sound-button:hover{border-color:#bdb1ff;background:#faf9ff;color:var(--purple)}.question-area{padding:18px 0 20px;text-align:center}.question-area span{color:var(--muted);font-size:11px}.question-area h3{margin:9px 0 0;font-size:23px;letter-spacing:-.5px}#quiz-form label{display:block;margin-bottom:7px;color:#555368;font-size:11px;font-weight:700}.answer-wrap{position:relative}.answer-wrap input{width:100%;height:50px;padding:0 84px 0 15px;border:1.5px solid #dedbe8;border-radius:11px;color:var(--ink);outline:none;transition:border-color .2s,box-shadow .2s}.answer-wrap input::placeholder{color:#aaa7b6}.answer-wrap input:focus{border-color:var(--purple);box-shadow:0 0 0 4px #6d4aff17}.answer-wrap input.correct{border-color:var(--green);background:#f7fdfa}.answer-wrap input.incorrect{border-color:var(--red);background:#fff9fa}.answer-wrap kbd{position:absolute;right:12px;top:12px;padding:4px 7px;border:0;border-radius:5px;background:#f1eff5;color:#8a8799;font:10px DM Sans,sans-serif}.input-help{margin:6px 0 0;color:#aaa7b5;font-size:10px}.feedback{min-height:25px;padding-top:5px;font-size:12px;font-weight:600}.feedback.success{color:var(--green)}.feedback.error{color:var(--red)}.answer-analysis{margin:10px 0 20px;padding:22px 24px 20px;border:1px solid #dcd5ff;border-radius:16px;background:linear-gradient(145deg,#faf9ff,#f4f1ff);text-align:center;animation:analysis-in .25s ease-out}.answer-analysis[hidden]{display:none}.analysis-heading{display:flex;align-items:center;justify-content:space-between;color:var(--purple);font-size:10px;font-weight:800;letter-spacing:.7px}.analysis-sound{width:30px;height:30px;display:grid;place-items:center;border:1px solid #ddd7ff;border-radius:8px;background:#fff;color:var(--purple);cursor:pointer}.analysis-sound svg{width:15px;height:15px}.analysis-phonetic{margin:1px 0 3px;color:#8c86a2;font-size:13px;font-family:DM Sans,sans-serif}.analysis-english{margin:0 0 14px;color:var(--ink);font-size:22px;font-weight:800;line-height:1.35;letter-spacing:-.3px}.grammar-parts{display:flex;flex-wrap:wrap;justify-content:center;gap:8px;padding:12px 0;border-top:1px solid #e6e1fa;border-bottom:1px solid #e6e1fa}.grammar-chip{min-width:68px;padding:7px 9px;border-radius:9px;background:#fff;box-shadow:0 3px 10px #4633780f}.grammar-chip b,.grammar-chip span,.grammar-chip small{display:block}.grammar-chip b{color:#39364c;font-size:12px}.grammar-chip span{margin:2px 0 1px;color:var(--purple);font-size:9px;font-weight:800}.grammar-chip small{color:#9995a7;font-size:8px}.analysis-chinese{display:flex;align-items:center;justify-content:center;gap:9px;margin-top:12px}.analysis-chinese span{padding:2px 6px;border-radius:5px;background:var(--purple-light);color:var(--purple);font-size:9px;font-weight:800}.analysis-chinese strong{font-size:13px}@keyframes analysis-in{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}.content-tools{display:flex;justify-content:center;gap:8px;margin:-2px 0 14px}.content-tools button{min-height:34px;display:inline-flex;align-items:center;gap:5px;padding:0 10px;border:1px solid #e1ddee;border-radius:8px;background:#fff;color:#706b82;cursor:pointer;font-size:9px;font-weight:700}.content-tools button:hover{border-color:#bdb1ff;color:var(--purple);background:#faf9ff}.content-tools svg{width:14px;height:14px}.word-inputs{min-height:82px;display:flex;flex-wrap:wrap;align-items:flex-end;gap:10px;padding:15px 18px;border:1.5px solid #dedbe8;border-radius:13px;background:#fff;transition:border-color .2s,box-shadow .2s}.word-inputs:focus-within{border-color:var(--purple);box-shadow:0 0 0 4px #6d4aff17}.word-field{position:relative;min-width:64px;padding-top:16px}.word-field:before{content:attr(data-number);position:absolute;top:-2px;left:50%;color:#aaa6b8;font-size:8px;transform:translate(-50%)}.word-field input{width:100%;height:39px;padding:0 4px 5px;border:0;border-bottom:3px solid #cbc6d7;border-radius:0;outline:0;background:transparent;color:var(--ink);text-align:center;font-size:21px;font-weight:700;letter-spacing:.2px}.word-field input:focus{border-bottom-color:var(--purple)}.word-field input.word-correct{border-bottom-color:var(--green);color:#137d60;background:linear-gradient(transparent 78%,#1ba97f14 0)}.word-field input.word-error{border-bottom-color:var(--red);color:var(--red);background:linear-gradient(transparent 78%,#e45a6717 0);animation:word-shake .22s ease}.word-field input::placeholder{color:#bbb7c7;font-size:16px;font-weight:500}@keyframes word-shake{25%{transform:translate(-3px)}75%{transform:translate(3px)}}.word-analysis{display:flex;flex-wrap:wrap;align-items:stretch;justify-content:center;gap:12px;margin:5px 0 18px;padding-bottom:18px;border-bottom:1px solid #e6e1fa}.analysis-word{min-width:102px;padding:12px 12px 13px;border-radius:12px;background:#fff;box-shadow:0 5px 15px #46337812}.analysis-word .ipa{display:block;min-height:25px;color:#706a84;font-size:14px;font-weight:600;line-height:1.25}.analysis-word b{display:block;margin:4px 0 7px;color:var(--ink);font-size:19px}.analysis-word em,.analysis-word small{display:block;font-style:normal}.analysis-word em{color:var(--purple);font-size:11px;font-weight:800}.analysis-word small{margin-top:2px;color:#777285;font-size:10px}.analysis-word .word-meaning{display:block;margin-top:7px;padding-top:7px;border-top:1px dashed #ddd8eb;color:#3f3b50;font-size:12px;font-weight:700}.analysis-chinese strong{font-size:16px}.compact-metrics{display:grid;grid-template-columns:1.15fr 1fr;gap:12px;margin:18px 0 2px}.compact-progress,.compact-stats{min-height:72px;border:1px solid #e8e4f2;border-radius:13px;background:#fcfbff}.compact-progress{display:grid;grid-template-columns:42px auto 1fr;grid-template-rows:auto auto;align-items:center;gap:2px 11px;padding:10px 14px}.compact-icon{grid-row:1 / 3;width:38px;height:38px;display:grid;place-items:center;border-radius:10px;background:var(--purple-light);color:var(--purple)}.compact-icon svg{width:19px}.compact-progress small,.compact-stats small{display:block;color:var(--muted);font-size:9px}.compact-progress strong{font-size:17px}.compact-progress strong b{color:var(--purple)}.compact-track{height:5px;overflow:hidden;border-radius:9px;background:#e9e6f0}.compact-track i{display:block;width:70%;height:100%;border-radius:inherit;background:var(--purple);transition:width .3s ease}.compact-progress p{grid-column:2 / 4;margin:0;color:var(--muted);font-size:9px}.compact-progress p b{color:var(--purple)}.compact-stats{display:grid;grid-template-columns:repeat(3,1fr);align-items:center;padding:10px 8px}.compact-stats div{padding:3px 10px;text-align:center}.compact-stats div+div{border-left:1px solid #e8e4f2}.compact-stats strong{display:block;margin-top:3px;color:var(--ink);font-size:14px}.learning-dialog{width:min(620px,calc(100% - 28px));max-height:min(780px,calc(100dvh - 30px));padding:0;border:0;border-radius:20px;background:transparent;box-shadow:0 30px 80px #1f193740}.learning-dialog::backdrop{background:#1d192e8c;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.dialog-card{max-height:min(780px,calc(100dvh - 30px));overflow:auto;padding:28px;border-radius:20px;background:#fff}.dialog-head{display:flex;align-items:flex-start;justify-content:space-between;gap:20px}.dialog-head span{color:var(--purple);font-size:10px;font-weight:800;letter-spacing:.8px}.dialog-head h2{margin:2px 0 0;font-size:24px}.dialog-close{width:44px;height:44px;flex:0 0 auto;border:1px solid var(--line);border-radius:11px;background:#fff;color:#777386;cursor:pointer;font-size:22px}.dialog-help{margin:14px 0 18px;color:var(--muted);font-size:12px}.file-picker{min-height:48px;display:flex!important;align-items:center;justify-content:center;gap:8px;margin-bottom:16px!important;border:1px dashed #bdb3e9;border-radius:11px;background:#faf9ff;color:var(--purple)!important;cursor:pointer;font-size:12px!important}.file-picker svg{width:18px}.file-picker input{display:none}.dialog-card>label:not(.file-picker){display:block;margin-bottom:7px;color:#555368;font-size:12px;font-weight:700}.dialog-card textarea{width:100%;resize:vertical;padding:13px 14px;border:1.5px solid #dedbe8;border-radius:11px;outline:0;color:var(--ink);font:14px/1.7 DM Sans,Noto Sans SC,sans-serif}.dialog-card textarea:focus{border-color:var(--purple);box-shadow:0 0 0 4px #6d4aff17}.dialog-status{min-height:25px;padding-top:5px;color:var(--green);font-size:11px}.dialog-actions{display:flex;justify-content:flex-end;gap:10px;margin-top:10px}.dialog-actions button{min-height:44px;padding:0 17px;border-radius:10px;cursor:pointer;font-weight:700}.dialog-secondary{border:1px solid var(--line);background:#fff;color:#686477}.dialog-primary{border:1px solid var(--purple);background:var(--purple);color:#fff}.library-list{overflow:hidden;border:1px solid var(--line);border-radius:13px}.library-item{display:grid;grid-template-columns:minmax(130px,1fr) minmax(110px,1fr) auto;align-items:center;gap:18px;padding:13px 16px;background:#fff}.library-item+.library-item{border-top:1px dashed #c8c2d8}.library-item strong{color:#39364b;font-size:13px;overflow-wrap:anywhere}.library-item span{color:var(--muted);font-size:12px;overflow-wrap:anywhere}.library-delete{min-width:58px;min-height:36px;border:1px solid #f0cdd1;border-radius:8px;background:snow;color:var(--red);cursor:pointer;font-size:10px;font-weight:700}.library-delete:hover{background:#fff1f3}.library-source{display:block;margin-top:3px;color:#a09bad!important;font-size:9px!important}.library-empty{padding:36px 20px;color:var(--muted);text-align:center;font-size:13px}.answer-actions{display:grid;grid-template-columns:.92fr .92fr 1.16fr;gap:10px;margin-top:3px}.result-button{min-height:44px;display:flex;align-items:center;justify-content:center;gap:7px;border-radius:10px;cursor:pointer;font-size:11px;font-weight:700;transition:transform .18s,box-shadow .18s,border-color .18s,background .18s}.result-button:active{transform:scale(.98)}.result-button svg{width:16px}.reveal-button,.repeat-button{border:1px solid #ded9ee;background:#fff;color:#69657c}.reveal-button:hover,.repeat-button:hover{border-color:#bfb4ff;background:#faf9ff;color:var(--purple)}.submit-answer-button{border:1px solid var(--purple);background:var(--purple);color:#fff}.submit-answer-button:hover{box-shadow:0 8px 18px #6d4aff38}.stat-head{display:flex;justify-content:space-between;color:#565467;font-size:12px;font-weight:700}.stat-head button{border:0;background:transparent;color:#aaa7b5;cursor:pointer}.accuracy-ring{--accuracy: 86;width:105px;height:105px;display:grid;place-items:center;margin:18px auto;border-radius:50%;background:conic-gradient(var(--purple) calc(var(--accuracy) * 1%),#ece9f4 0)}.accuracy-ring:before{content:"";grid-area:1/1;width:78px;height:78px;border-radius:50%;background:#fff}.accuracy-ring div{grid-area:1/1;z-index:1;text-align:center}.accuracy-ring strong,.accuracy-ring small{display:block}.accuracy-ring strong{font-size:20px}.accuracy-ring small{color:var(--muted);font-size:9px}.stat-row{display:flex;justify-content:space-between;margin:10px 0;color:var(--muted);font-size:10px}.stat-row strong{color:var(--ink);font-size:10px}.dot{width:7px;height:7px;display:inline-block;margin-right:6px;border-radius:50%}.purple-dot{background:var(--purple)}.orange-dot{background:var(--orange)}.encouragement{display:flex;align-items:center;gap:8px;margin-top:16px;padding:10px;border-radius:9px;background:var(--orange-light);color:#8d623e;font-size:9px;line-height:1.45}.encouragement svg{flex:0 0 auto;width:18px;color:var(--orange);fill:#ffd7bb}.features{padding:88px 0}.feature-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;margin-top:42px}.feature-grid article{padding:30px;border:1px solid var(--line);border-radius:20px;background:#fff;box-shadow:0 12px 32px #3a2d620d}.feature-icon{width:48px;height:48px;display:grid;place-items:center;border-radius:13px}.feature-icon.purple{color:var(--purple);background:var(--purple-light)}.feature-icon.orange{color:var(--orange);background:var(--orange-light)}.feature-icon.green{color:var(--green);background:var(--green-light)}.feature-grid h3{margin:18px 0 7px;font-size:18px}.feature-grid p{margin:0;color:var(--muted);font-size:14px}.challenge-heading{margin-bottom:38px}.challenge-heading p{margin-top:8px}.benefits-heading{margin-top:110px}.challenge-game{max-width:960px;min-height:560px;margin:0 auto;padding:30px 36px 34px;border:1px solid #ddd7ff;border-radius:26px;background:linear-gradient(145deg,#fff,#faf8ff);box-shadow:0 25px 70px #44307d1f}.challenge-header{display:flex;align-items:center;justify-content:space-between;gap:20px}.challenge-level-copy span{color:var(--purple);font-size:12px;font-weight:800}.challenge-level-copy h3{margin:3px 0 0;font-size:24px}.challenge-level-copy small{color:var(--muted);font-size:10px}.challenge-header-actions{display:flex;gap:8px}.challenge-restart,.challenge-map-button{min-height:42px;display:inline-flex;align-items:center;gap:7px;padding:0 14px;border:1px solid var(--line);border-radius:10px;background:#fff;color:#69657a;cursor:pointer;font-size:11px;font-weight:700}.challenge-restart svg{width:16px}.challenge-map-button{color:var(--purple)}.course-map-head{text-align:center}.course-map-head span{color:var(--purple);font-size:11px;font-weight:800;letter-spacing:.8px}.course-map-head h3{margin:5px 0 7px;font-size:28px}.course-map-head p{margin:0;color:var(--muted);font-size:13px}.course-map-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-top:28px}.course-map-card{min-height:126px;display:flex;flex-direction:column;align-items:flex-start;justify-content:space-between;padding:17px;border:2px solid #e5e1ee;border-radius:16px;background:#fff;color:var(--ink);cursor:pointer;text-align:left;transition:transform .18s,border-color .18s,box-shadow .18s}.course-map-card:hover:not(:disabled){transform:translateY(-3px);border-color:#bdb1ff;box-shadow:0 10px 22px #4c37871a}.course-map-card.current{border-color:var(--purple);background:var(--purple-light)}.course-map-card.completed{border-color:#aadfce;background:#f5fcf9}.course-map-card:disabled{background:#f4f2f6;color:#aaa5b1;cursor:not-allowed}.course-map-number{width:30px;height:30px;display:grid;place-items:center;border-radius:9px;background:#f0edfa;color:var(--purple);font-size:12px;font-weight:800}.course-map-card.completed .course-map-number{background:var(--green);color:#fff}.course-map-card:disabled .course-map-number{background:#e5e2e8;color:#aaa5b1}.course-map-card strong{font-size:15px}.course-map-card small{color:var(--muted);font-size:10px}.course-map-status{align-self:flex-end;color:var(--purple);font-size:9px;font-weight:800}.course-map-card.completed .course-map-status{color:var(--green)}.challenge-progress{height:8px;overflow:hidden;margin:20px 0 28px;border-radius:99px;background:#ebe8f3}.challenge-progress i{display:block;width:9.09%;height:100%;border-radius:inherit;background:linear-gradient(90deg,var(--purple),#9b7cff);transition:width .35s ease}.challenge-stage{min-height:350px;display:grid;align-content:center}.challenge-prompt{text-align:center}.challenge-prompt small{color:var(--muted);font-size:12px}.challenge-prompt h4{margin:10px 0 8px;font-size:clamp(28px,4vw,42px);line-height:1.25}.challenge-prompt p{margin:0;color:var(--muted);font-size:13px}.challenge-blank{display:inline-flex;min-width:130px;min-height:48px;align-items:center;justify-content:center;margin-left:7px;padding:0 14px;border-bottom:3px solid var(--purple);color:var(--purple);vertical-align:middle}.challenge-options{display:grid;grid-template-columns:repeat(4,minmax(120px,1fr));gap:14px;margin-top:34px}.challenge-options.three{grid-template-columns:repeat(3,minmax(140px,1fr))}.challenge-option{min-height:76px;padding:12px 15px;border:2px solid #e3dff0;border-radius:15px;background:#fff;color:var(--ink);cursor:pointer;font-size:18px;font-weight:800;transition:border-color .18s,color .18s,background .18s,transform .18s}.challenge-option:hover{border-color:#bdb2ff;transform:translateY(-2px)}.challenge-option.selected{border-color:var(--purple);background:var(--purple-light);color:var(--purple)}.challenge-option.correct{border-color:var(--green);background:var(--green-light);color:#14775d}.challenge-option:disabled{cursor:default;transform:none}.challenge-builder{margin-top:28px}.challenge-answer-line{min-height:74px;display:flex;flex-wrap:wrap;align-items:center;justify-content:center;gap:9px;padding:13px;border:2px dashed #c8bfef;border-radius:15px;background:#fcfbff}.challenge-answer-line:empty:before{content:"点击下方词语，依次放入这里";color:#aaa5b8;font-size:13px}.challenge-token{min-height:45px;padding:0 17px;border:1px solid #ddd7ec;border-radius:10px;background:#fff;color:#4e495e;cursor:pointer;font-weight:700}.challenge-token.selected-token{border-color:var(--purple);background:var(--purple);color:#fff}.challenge-token:disabled{opacity:.35;cursor:default}.challenge-token-pool{display:flex;flex-wrap:wrap;justify-content:center;gap:10px;margin-top:22px}.challenge-feedback{min-height:42px;display:flex;align-items:center;justify-content:center;margin-top:8px;font-size:14px;font-weight:800}.challenge-feedback.success{color:var(--green)}.challenge-feedback.error{color:var(--red)}.challenge-actions{display:flex;justify-content:flex-end;gap:12px}.challenge-actions button{min-width:145px;min-height:48px;border-radius:12px;cursor:pointer;font-weight:800}.challenge-confirm{border:1px solid var(--purple);background:var(--purple);color:#fff}.challenge-confirm:disabled{border-color:#ddd9e8;background:#e8e5ee;color:#aaa5b4;cursor:not-allowed}.challenge-continue{border:1px solid var(--green);background:var(--green);color:#fff}.matching-board{position:relative;display:grid;grid-template-columns:minmax(150px,1fr) minmax(150px,1fr);gap:110px;margin-top:22px;padding:8px 18px}.matching-column{display:grid;gap:10px;z-index:2}.matching-item{min-height:48px;display:grid;place-items:center;padding:8px 12px;border:2px solid #ded9eb;border-radius:11px;background:#fff;cursor:pointer;font-size:15px;font-weight:800;-webkit-user-select:none;user-select:none}.matching-item.active{border-color:var(--purple);background:var(--purple-light)}.matching-item.matched{border-color:var(--green);background:var(--green-light);color:#14775d;cursor:default}.matching-svg{position:absolute;inset:0;z-index:1;width:100%;height:100%;overflow:visible;pointer-events:none}.matching-svg line{stroke:var(--green);stroke-width:3;stroke-linecap:round}.challenge-complete{text-align:center}.challenge-complete-mark{width:86px;height:86px;display:grid;place-items:center;margin:0 auto 20px;border-radius:50%;background:var(--green-light);color:var(--green)}.challenge-complete-mark svg{width:42px;height:42px}.challenge-complete h4{margin:0 0 8px;font-size:34px}.challenge-complete p{margin:0;color:var(--muted)}.course-complete-actions{display:flex;justify-content:center;gap:10px;margin-top:24px}.course-complete-actions button{min-height:46px;padding:0 20px;border-radius:11px;cursor:pointer;font-weight:800}.course-complete-map{border:1px solid var(--line);background:#fff;color:#625e70}.course-complete-next{border:1px solid var(--green);background:var(--green);color:#fff}@keyframes challenge-shake{25%{transform:translate(-7px)}50%{transform:translate(6px)}75%{transform:translate(-3px)}}.challenge-shake{animation:challenge-shake .35s ease}.simple-section{padding:15px 0 90px}.cta-card{display:flex;align-items:center;justify-content:space-between;gap:30px;padding:45px 52px;border-radius:25px;background:var(--ink);color:#fff}.cta-card p{margin:0;color:#bcb9ca}.about-section{padding:70px 0;background:var(--purple-light);text-align:center}.about-section p{max-width:700px;margin:auto;font-size:22px;font-weight:600}@media(max-width:980px){.nav-links{gap:14px}.nav-actions{gap:6px}.nav-actions .text-button{padding-inline:8px}.nav-actions .button-small{padding-inline:13px}.hero-grid{grid-template-columns:1fr 1fr}.quiz-card{padding-inline:30px}}@media(max-width:760px){.container{width:min(100% - 28px,620px)}.nav{height:68px}.menu-toggle{display:block;order:3}.nav-actions{margin-left:auto}.nav-actions .button{display:none}.nav-links{position:absolute;top:68px;left:14px;right:14px;display:none;flex-direction:column;align-items:stretch;gap:0;padding:10px;border:1px solid var(--line);border-radius:14px;background:#fff;box-shadow:var(--shadow)}.nav-links.open{display:flex}.nav-links a{min-height:48px;display:flex;align-items:center;padding:0 14px;border-radius:9px}.nav-links a.active{background:var(--purple-light)}.nav-links a.active:after{display:none}.hero{padding:62px 0 70px}.hero-grid{grid-template-columns:1fr}.hero-copy{text-align:center}.hero-copy>p{margin-inline:auto}.hero-actions,.social-proof{justify-content:center}.hero h1{font-size:clamp(43px,13vw,64px);letter-spacing:-2px}.hero-visual{min-height:405px}.main-illustration{width:min(390px,84%)}.phrase-card{left:0}.progress-card{right:0}.practice-layout{grid-template-columns:1fr}.daily-card{display:grid;grid-template-columns:60px 1fr;text-align:left;align-items:center}.daily-icon{grid-row:1 / 4;margin:0}.daily-card>strong{margin:0}.progress-track,.daily-card>p{grid-column:1 / -1}.streak{grid-column:1 / -1}.stats-card{display:block}.accuracy-ring{margin:20px auto}.feature-grid{grid-template-columns:1fr}.cta-card{align-items:flex-start;flex-direction:column;padding:36px 28px}}@media(max-width:480px){.brand{font-size:16px}.brand-mark{width:32px;height:32px}.hero-actions{flex-direction:column;gap:18px}.hero-actions .button{width:100%}.hero-visual{min-height:340px}.main-illustration{width:290px}.character{transform:scale(.82)}.float-card{padding:10px 12px}.phrase-card{top:0}.progress-card{bottom:0;min-width:180px}.bubble-left{left:-1%}.bubble-right{right:-1%}.quiz-card{padding:22px 18px 24px}.answer-actions{grid-template-columns:1fr 1fr}.submit-answer-button{grid-column:1 / -1}.question-area h3{font-size:20px}.answer-analysis{padding-inline:12px}.analysis-english{font-size:19px}.grammar-chip{flex:1 1 29%;min-width:62px}.about-section p{font-size:18px}footer .container{flex-direction:column;gap:10px}}@media(prefers-reduced-motion:reduce){*,*:before,*:after{scroll-behavior:auto!important;transition-duration:.01ms!important;animation-duration:.01ms!important}}@media(max-width:480px){.content-tools{flex-direction:column}.content-tools button{justify-content:center}.word-inputs{gap:5px;padding-inline:8px}.word-field{min-width:42px}.word-field input{font-size:14px}.analysis-word{min-width:56px}.dialog-card{padding:22px 18px}.dialog-actions{display:grid;grid-template-columns:1fr 1fr}.library-item{grid-template-columns:1fr;gap:4px}}@media(max-width:700px){.compact-metrics{grid-template-columns:1fr}.quiz-card{padding:24px 18px 28px}.analysis-word{min-width:86px}.library-item{grid-template-columns:1fr auto}.library-item>span{grid-column:1}.library-delete{grid-column:2;grid-row:1 / 3}}.nav-actions .text-button{min-height:42px;display:inline-flex;align-items:center;padding:0 12px}.mobile-auth-link{display:none}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.challenge-section{padding-bottom:110px}.page-main{min-height:calc(100vh - 150px)}.page-hero{position:relative;overflow:hidden;padding:88px 0 72px;background:radial-gradient(circle at 82% 24%,#e9e3ff 0,rgba(238,234,255,.55) 24%,transparent 52%)}.page-hero:after{content:"";position:absolute;width:260px;height:260px;left:-100px;bottom:-150px;border-radius:50%;background:#ff994a17}.page-hero-grid{position:relative;z-index:1;display:grid;grid-template-columns:1.05fr .95fr;align-items:center;gap:54px}.page-kicker{display:inline-flex;align-items:center;gap:8px;color:var(--purple);font-size:13px;font-weight:800;letter-spacing:.5px}.page-kicker:before{content:"";width:24px;height:3px;border-radius:3px;background:var(--purple)}.page-hero h1{max-width:680px;margin:16px 0 18px;font-size:clamp(42px,5vw,66px);line-height:1.12;letter-spacing:-2px}.page-hero h1 em{color:var(--purple);font-style:normal}.page-hero-copy>p{max-width:620px;margin:0;color:var(--muted);font-size:17px}.page-hero-actions{display:flex;gap:12px;margin-top:28px}.secondary-button{min-height:50px;display:inline-flex;align-items:center;justify-content:center;padding:0 22px;border:1px solid var(--line);border-radius:14px;background:#fff;color:var(--ink);cursor:pointer;font-weight:700}.hero-panel{padding:28px;border:1px solid #ddd7ff;border-radius:26px;background:#ffffffdb;box-shadow:var(--shadow);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.hero-panel-top{display:flex;justify-content:space-between;align-items:center;gap:15px;margin-bottom:24px}.status-dot{display:inline-flex;align-items:center;gap:7px;color:var(--green);font-size:12px;font-weight:700}.status-dot:before{content:"";width:8px;height:8px;border-radius:50%;background:currentColor;box-shadow:0 0 0 5px var(--green-light)}.mini-dialogue{display:grid;gap:12px}.mini-bubble{max-width:86%;padding:13px 16px;border-radius:15px 15px 15px 4px;background:var(--purple-light);font-weight:600}.mini-bubble.user{justify-self:end;border-radius:15px 15px 4px;background:var(--ink);color:#fff}.content-section{padding:82px 0}.content-section.alt{background:#fff}.section-intro{max-width:680px;margin-bottom:36px}.section-intro h2{margin:8px 0 10px;font-size:clamp(30px,4vw,44px);line-height:1.2}.section-intro p{margin:0;color:var(--muted)}.card-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}.info-card{padding:26px;border:1px solid var(--line);border-radius:20px;background:#fff;box-shadow:0 12px 35px #3c2d6c0f}.info-card .card-icon{width:48px;height:48px;display:grid;place-items:center;border-radius:14px;background:var(--purple-light);color:var(--purple)}.info-card h3{margin:18px 0 7px;font-size:20px}.info-card p{margin:0;color:var(--muted);font-size:14px}.tag-row{display:flex;flex-wrap:wrap;gap:7px;margin-top:18px}.tag{padding:5px 10px;border-radius:99px;background:#f4f2fa;color:#625e70;font-size:11px;font-weight:700}.tool-bar{display:flex;flex-wrap:wrap;align-items:center;gap:12px;margin-bottom:28px}.search-field{min-height:48px;flex:1 1 280px;padding:0 16px;border:1px solid var(--line);border-radius:12px;background:#fff;color:var(--ink)}.filter-group{display:flex;flex-wrap:wrap;gap:8px}.filter-button{min-height:44px;padding:0 16px;border:1px solid var(--line);border-radius:11px;background:#fff;color:#656176;cursor:pointer;font-weight:700}.filter-button.active{border-color:var(--purple);background:var(--purple-light);color:var(--purple)}.resource-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}.resource-card{position:relative;display:flex;flex-direction:column;min-height:245px;padding:24px;border:1px solid var(--line);border-radius:20px;background:#fff;box-shadow:0 10px 30px #3c2d6c0d}.resource-card[hidden]{display:none}.resource-meta{display:flex;justify-content:space-between;gap:10px;color:var(--muted);font-size:11px}.resource-card h3{margin:20px 0 8px;font-size:20px}.resource-card p{margin:0 0 20px;color:var(--muted);font-size:14px}.resource-footer{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-top:auto}.favorite-button{width:44px;height:44px;display:grid;place-items:center;border:1px solid var(--line);border-radius:12px;background:#fff;color:#8b8699;cursor:pointer}.favorite-button.active{border-color:#ffb2bb;background:#fff0f2;color:var(--red)}.coach-layout{display:grid;grid-template-columns:320px 1fr;gap:22px}.scenario-list,.coach-room{padding:24px;border:1px solid var(--line);border-radius:22px;background:#fff;box-shadow:0 14px 40px #3c2d6c0f}.scenario-button{width:100%;display:grid;grid-template-columns:42px 1fr;gap:12px;align-items:center;margin-top:10px;padding:13px;border:1px solid transparent;border-radius:13px;background:transparent;color:var(--ink);cursor:pointer;text-align:left}.scenario-button.active{border-color:#d9d1ff;background:var(--purple-light)}.scenario-button span:first-child{width:42px;height:42px;display:grid;place-items:center;border-radius:12px;background:#fff;color:var(--purple);font-weight:800}.scenario-button strong,.scenario-button small{display:block}.scenario-button small{color:var(--muted)}.coach-room-head{display:flex;align-items:center;justify-content:space-between;gap:15px;padding-bottom:18px;border-bottom:1px solid var(--line)}.coach-messages{min-height:330px;display:grid;align-content:end;gap:13px;padding:28px 0}.coach-message{max-width:78%;padding:15px 18px;border-radius:17px 17px 17px 5px;background:#f2efff}.coach-message.user{justify-self:end;border-radius:17px 17px 5px;background:var(--ink);color:#fff}.coach-message small{display:block;margin-top:4px;opacity:.65}.coach-compose{display:grid;grid-template-columns:1fr auto;gap:10px}.coach-compose input{min-height:50px;padding:0 16px;border:1px solid var(--line);border-radius:12px}.phrase-suggestions{display:flex;flex-wrap:wrap;gap:8px;margin-top:14px}.phrase-suggestions button{padding:7px 11px;border:1px solid #ddd7ff;border-radius:99px;background:#faf8ff;color:var(--purple);cursor:pointer;font-size:12px}.help-layout{display:grid;grid-template-columns:250px 1fr;gap:30px}.help-sidebar{position:sticky;top:100px;align-self:start;padding:18px;border:1px solid var(--line);border-radius:17px;background:#fff}.help-sidebar a{display:block;padding:10px 12px;border-radius:9px;color:#666176;font-size:14px;font-weight:600}.help-sidebar a:hover{background:var(--purple-light);color:var(--purple)}.help-articles{display:grid;gap:12px}.help-item{overflow:hidden;border:1px solid var(--line);border-radius:16px;background:#fff}.help-question{width:100%;min-height:62px;display:flex;justify-content:space-between;align-items:center;padding:0 20px;border:0;background:#fff;color:var(--ink);cursor:pointer;text-align:left;font-weight:800}.help-answer{padding:0 20px 20px;color:var(--muted)}.help-answer[hidden]{display:none}.values-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}.value-card{padding:30px;border-radius:22px;background:#fff;border:1px solid var(--line)}.value-card strong{display:block;color:var(--purple);font-size:34px}.auth-page{min-height:calc(100vh - 78px);display:grid;grid-template-columns:1fr 1fr}.auth-showcase{display:grid;place-items:center;padding:70px;background:linear-gradient(145deg,#2e2850,#6d4aff);color:#fff}.auth-showcase-inner{max-width:500px}.auth-showcase h1{margin:18px 0;font-size:clamp(42px,5vw,68px);line-height:1.1}.auth-showcase p{color:#ddd7ff}.auth-points{display:grid;gap:12px;margin-top:30px}.auth-points span{display:flex;align-items:center;gap:10px}.auth-points i{width:25px;height:25px;display:grid;place-items:center;border-radius:50%;background:#ffffff26;font-style:normal}.auth-panel{display:grid;place-items:center;padding:55px 28px;background:#fff}.auth-card{width:min(440px,100%)}.auth-card h2{margin:16px 0 8px;font-size:34px}.auth-card>p{margin:0 0 28px;color:var(--muted)}.form-field{margin-bottom:17px}.form-field label{display:block;margin-bottom:7px;font-size:13px;font-weight:700}.form-field input{width:100%;min-height:50px;padding:0 14px;border:1px solid var(--line);border-radius:12px}.form-field input.invalid{border-color:var(--red)}.field-error{min-height:18px;margin-top:4px;color:var(--red);font-size:11px}.password-wrap{position:relative}.password-wrap input{padding-right:72px}.password-toggle{position:absolute;right:8px;top:7px;min-height:36px;padding:0 9px;border:0;border-radius:8px;background:#f4f2fa;color:#69657a;cursor:pointer;font-size:12px}.form-row{display:flex;justify-content:space-between;align-items:center;gap:15px;margin:2px 0 20px;font-size:13px}.check-label{display:flex;align-items:center;gap:8px}.check-label input{width:17px;height:17px;accent-color:var(--purple)}.auth-submit{width:100%;border:0;cursor:pointer}.auth-submit:disabled{opacity:.65;cursor:wait}.auth-status{min-height:24px;margin:12px 0;color:var(--red);font-size:13px;text-align:center}.auth-status.success{color:var(--green)}.auth-switch{text-align:center;color:var(--muted);font-size:14px}.auth-switch a{color:var(--purple);font-weight:800}.password-meter{height:5px;overflow:hidden;margin-top:7px;border-radius:99px;background:#eeeaf3}.password-meter i{display:block;width:0;height:100%;background:var(--red);transition:width .2s,background .2s}.empty-state{grid-column:1 / -1;padding:55px;border:1px dashed #d7d2e2;border-radius:18px;color:var(--muted);text-align:center}.testimonials-section{padding:88px 0 80px;border-top:1px solid rgba(233,231,241,.72);background:linear-gradient(180deg,#f8f7fc,#fbfaff)}.testimonials-heading{max-width:620px;margin:0 auto 42px;text-align:center}.testimonials-heading h2{margin:8px 0;font-size:clamp(32px,4vw,44px);line-height:1.2}.testimonials-heading p{margin:0;color:var(--muted);font-size:15px}.testimonials-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:20px}.testimonial-card{min-height:218px;display:flex;flex-direction:column;justify-content:space-between;padding:27px;border:1px solid var(--line);border-radius:20px;background:#fffffff0;box-shadow:0 14px 38px #3d2d6e0f}.testimonial-card blockquote{margin:0;color:#343247;font-size:15px;font-weight:600;line-height:1.85}.testimonial-person{display:flex;align-items:center;gap:12px;margin-top:24px}.testimonial-avatar{width:42px;height:42px;flex:0 0 42px;display:grid;place-items:center;border-radius:50%;background:var(--purple-light);color:var(--purple);font-size:14px;font-weight:800}.testimonial-person strong,.testimonial-person small{display:block}.testimonial-person strong{font-size:14px}.testimonial-person small{margin-top:1px;color:var(--muted);font-size:12px}.testimonial-note{margin:18px 0 0;color:#9995a5;font-size:11px;text-align:right}.site-footer{padding:52px 0 0;border-top:1px solid var(--line);background:#fff}.site-footer .container{display:block}.site-footer-grid{display:grid;grid-template-columns:minmax(260px,1.7fr) repeat(3,minmax(130px,1fr));gap:56px;padding-bottom:44px}.footer-brand-column .brand-mark{width:34px;height:34px}.footer-brand-column .brand-mark svg{width:23px;height:23px}.footer-brand-column>p{max-width:280px;margin:16px 0 0;color:var(--muted);font-size:14px}.footer-link-column{display:flex;flex-direction:column;align-items:flex-start;gap:5px}.footer-link-column strong{margin-bottom:9px;color:var(--ink);font-size:14px}.footer-link-column a{min-height:38px;display:inline-flex;align-items:center;color:#666176;font-size:13px;transition:color .18s,transform .18s}.footer-link-column a:hover{color:var(--purple);transform:translate(2px)}.site-footer-bottom{display:flex;justify-content:center;padding:20px 0 24px;border-top:1px solid var(--line)}.site-footer-bottom p{margin:0;color:var(--muted);font-size:12px;text-align:center}@media(max-width:980px){.page-hero-grid,.auth-page{grid-template-columns:1fr}.hero-panel{max-width:650px}.card-grid,.resource-grid,.values-grid{grid-template-columns:1fr 1fr}.coach-layout{grid-template-columns:1fr}.scenario-list{display:flex;flex-wrap:wrap;gap:8px}.scenario-list h3{width:100%}.scenario-button{width:auto;flex:1 1 200px;margin:0}.auth-showcase{min-height:420px;padding:60px 28px}.testimonials-grid{grid-template-columns:1fr 1fr}.testimonial-card:last-child{grid-column:1 / -1}.site-footer-grid{grid-template-columns:1.5fr 1fr 1fr;gap:36px}.footer-brand-column{grid-column:1 / -1}}@media(max-width:760px){.nav-actions{display:none}.nav-links.open:after{content:"";display:block;height:1px;margin:8px 10px;background:var(--line)}.nav-links.open .mobile-auth-link{display:flex}.mobile-auth-link{display:none}.page-hero{padding:62px 0 54px}.page-hero-grid{gap:34px}.page-hero h1{font-size:42px}.card-grid,.resource-grid,.values-grid,.help-layout{grid-template-columns:1fr}.help-sidebar{position:static;display:flex;overflow-x:auto}.help-sidebar a{white-space:nowrap}.coach-compose{grid-template-columns:1fr}.coach-compose .button{width:100%}.auth-showcase{display:none}.auth-page{min-height:calc(100vh - 68px)}.testimonials-section{padding:68px 0 60px}.testimonials-grid{grid-template-columns:1fr}.testimonial-card:last-child{grid-column:auto}.site-footer-grid{grid-template-columns:1fr 1fr;gap:34px 24px}.footer-brand-column{grid-column:1 / -1}}@media(max-width:480px){.testimonial-card{min-height:0;padding:22px}.testimonial-note{text-align:center}.site-footer{padding-top:42px}.site-footer-grid{grid-template-columns:1fr;gap:28px}.footer-brand-column{grid-column:auto}.footer-link-column a{min-height:44px}.site-footer-bottom{justify-content:flex-start}.site-footer-bottom p{text-align:left}}@media(max-width:760px){.challenge-game{min-height:520px;padding:22px 18px 26px}.challenge-options,.challenge-options.three{grid-template-columns:1fr 1fr}.matching-board{gap:38px;padding-inline:0}.benefits-heading{margin-top:80px}}@media(max-width:760px){.course-map-grid{grid-template-columns:repeat(2,1fr)}.challenge-header{align-items:flex-start}.challenge-header-actions{flex-direction:column}}@media(max-width:480px){.challenge-header{align-items:flex-start}.challenge-level-copy h3{font-size:19px}.challenge-restart{min-width:44px;padding:0 10px}.challenge-restart svg{margin:auto}.challenge-restart{font-size:0}.challenge-options,.challenge-options.three{grid-template-columns:1fr}.challenge-stage{min-height:390px}.challenge-actions button{flex:1;min-width:0}.matching-board{grid-template-columns:1fr 1fr;gap:22px}.matching-item{min-height:52px;padding-inline:6px;font-size:13px}}.quiz-card:fullscreen{width:100%;height:100%;overflow:auto;padding:clamp(24px,5vw,70px) clamp(22px,8vw,120px);border:0;border-radius:0;background:var(--background)}.quiz-card:fullscreen .word-inputs{min-height:72px}.quiz-card:fullscreen .question-area h3{font-size:clamp(26px,4vw,42px)}.quiz-card:fullscreen .analysis-word{min-width:118px}:root{--purple:#6d4aff;--purple-dark:#5336db;--purple-light:#eeeaff;--ink:#202036;--muted:#77778b;--line:#e9e7f1;--surface:#fff;--background:#f7f6fb;--green:#1ba97f;--green-light:#e8f8f2;--orange:#ff994a;--orange-light:#fff2e8;--red:#e45a67;--shadow:0 18px 45px rgba(66,49,120,.09)}*{box-sizing:border-box}html{color-scheme:light}body.dashboard-ready{margin:0;color:var(--ink);background:var(--background);font-family:DM Sans,Noto Sans SC,sans-serif;line-height:1.5}body.dashboard-ready button,body.dashboard-ready input{font:inherit}body.dashboard-ready button,body.dashboard-ready a{-webkit-tap-highlight-color:transparent}body.dashboard-ready button{cursor:pointer}body.dashboard-ready a{color:inherit;text-decoration:none}body.dashboard-ready svg{width:20px;height:20px;fill:none;stroke:currentColor;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}.icon-sprite{position:absolute;width:0;height:0;overflow:hidden}.dashboard-shell{min-height:100vh;display:flex}.dashboard-sidebar{position:fixed;inset:0 auto 0 0;z-index:40;width:250px;display:flex;flex-direction:column;border-right:1px solid var(--line);background:#fff;transition:transform .25s ease}.dashboard-brand{height:74px;display:flex;align-items:center;gap:11px;padding:0 20px;border-bottom:1px solid var(--line);font-size:17px}.dashboard-brand-mark{width:36px;height:36px;display:grid;place-items:center;border-radius:11px;background:var(--purple);color:#fff;box-shadow:0 8px 18px #6d4aff38}.dashboard-brand-mark svg{width:24px;height:24px}.sidebar-nav{flex:1;overflow:auto;padding:18px 13px}.sidebar-nav section+section{margin-top:21px}.sidebar-nav h2{margin:0 10px 7px;color:#aaa5b5;font-size:11px;letter-spacing:.8px}.sidebar-nav a{min-height:43px;display:flex;align-items:center;gap:11px;padding:0 12px;border-radius:11px;color:#676275;font-size:13px;font-weight:600;transition:background .18s,color .18s}.sidebar-nav a svg{width:18px;height:18px;color:#9994a5}.sidebar-nav a:hover,.sidebar-nav a.active{background:var(--purple-light);color:var(--purple)}.sidebar-nav a.active svg{color:var(--purple)}.sidebar-promos{display:grid;gap:9px;padding:12px;border-top:1px solid var(--line)}.promo-card{width:100%;min-height:67px;display:grid;grid-template-columns:36px 1fr auto;align-items:center;gap:9px;padding:10px;border:1px solid var(--line);border-radius:13px;background:#fff;color:var(--ink);text-align:left}.promo-card>svg:first-child{width:36px;height:36px;padding:8px;border-radius:10px;background:var(--purple-light);color:var(--purple)}.promo-card strong,.promo-card small{display:block}.promo-card strong{font-size:12px}.promo-card small{color:var(--muted);font-size:10px}.promo-card b{color:var(--purple);font-size:10px}.commission-card{border:0;background:linear-gradient(135deg,#ffad62,#ff8842);color:#fff}.commission-card>svg:first-child{background:#ffffff2e;color:#fff}.commission-card small,.commission-card b{color:#ffffffd1}.chevron{width:16px!important;height:16px!important;padding:0!important;background:none!important}.dashboard-main{width:calc(100% - 250px);min-width:0;margin-left:250px}.dashboard-topbar{position:sticky;top:0;z-index:30;min-height:74px;display:flex;align-items:center;justify-content:space-between;gap:24px;padding:10px 30px;border-bottom:1px solid var(--line);background:#ffffffe8;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px)}.topbar-title{display:flex;align-items:center;gap:12px}.topbar-title h1{margin:0;font-size:20px}.topbar-title p{margin:2px 0 0;color:var(--muted);font-size:11px}.topbar-actions,.topbar-actions nav{display:flex;align-items:center;gap:8px}.topbar-actions nav button{min-height:38px;padding:0 10px;border:0;background:transparent;color:#696477;font-size:12px}.topbar-actions nav button:hover{color:var(--purple)}.points-pill{min-height:38px;display:flex;align-items:center;gap:6px;padding:0 12px;border-radius:99px;background:#fff8df;color:#a06b00;font-size:12px}.points-pill svg{width:17px}.user-menu{position:relative}.user-trigger{min-height:44px;display:flex;align-items:center;gap:8px;padding:3px 8px 3px 3px;border:0;border-radius:99px;background:#f4f2fa;color:var(--ink)}.user-trigger>svg{width:14px;transform:rotate(90deg)}.user-avatar{width:38px;height:38px;display:grid;place-items:center;border-radius:50%;background:linear-gradient(145deg,#9278ff,var(--purple));color:#fff;font-weight:800}.user-name{max-width:90px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-size:12px;font-weight:700}.user-dropdown{position:absolute;top:calc(100% + 10px);right:0;width:190px;padding:7px;border:1px solid var(--line);border-radius:14px;background:#fff;box-shadow:var(--shadow)}.user-dropdown a,.user-dropdown button{width:100%;min-height:40px;display:flex;align-items:center;gap:10px;padding:0 10px;border:0;border-radius:9px;background:transparent;color:#5f5a6c;font-size:13px;font-weight:500;text-align:left}.user-dropdown a:hover,.user-dropdown button:hover{background:var(--purple-light);color:var(--purple)}.user-dropdown hr{border:0;border-top:1px solid var(--line)}.user-dropdown .logout-button{color:var(--red)}.mobile-sidebar-button{display:none;width:44px;height:44px;border:1px solid var(--line);border-radius:11px;background:#fff;color:var(--ink)}.dashboard-content{padding:28px 30px 45px}[hidden]{display:none!important}.dashboard-grid{display:grid;grid-template-columns:minmax(0,2fr) minmax(300px,1fr);gap:22px}.dashboard-primary,.dashboard-secondary{display:grid;align-content:start;gap:20px}.dashboard-card{padding:22px;border:1px solid var(--line);border-radius:20px;background:#fff;box-shadow:0 10px 30px #3d2d6e0b}.card-heading{display:flex;align-items:center;justify-content:space-between;gap:15px;margin-bottom:20px}.card-heading>div{display:flex;align-items:center;gap:10px}.card-heading h2{margin:0;font-size:16px}.card-heading button{min-height:36px;padding:0 8px;border:0;background:transparent;color:var(--muted);font-size:11px}.card-heading button:hover{color:var(--purple)}.heading-icon{width:36px;height:36px;display:grid;place-items:center;border-radius:11px}.heading-icon.purple{background:var(--purple-light);color:var(--purple)}.heading-icon.yellow{background:#fff7d9;color:#c58a00}.heading-icon.blue{background:#eaf3ff;color:#4084df}.heading-icon.pink{background:#fff0f4;color:#e65e87}.heading-icon.green{background:var(--green-light);color:var(--green)}.icon-button{width:38px!important;padding:0!important;border:1px solid var(--line)!important;border-radius:10px!important}.checkin-summary{display:grid;grid-template-columns:auto 1fr auto;align-items:center;gap:28px;padding:15px 5px}.checkin-summary>div:first-child,.checkin-summary>div:last-child{text-align:center}.checkin-summary small{display:block;color:var(--muted);font-size:11px}.checkin-summary strong{display:block;margin-top:3px;color:var(--purple);font-size:30px}.checkin-summary .orange{color:var(--orange)}.goal-progress p{display:flex;justify-content:space-between;margin:0 0 7px;color:var(--muted);font-size:11px}.goal-progress>div{height:8px;overflow:hidden;border-radius:99px;background:#eceaf2}.goal-progress i{display:block;width:0;height:100%;border-radius:inherit;background:linear-gradient(90deg,var(--purple),#9b7cff);transition:width .3s}.week-checkin{display:flex;align-items:center;justify-content:space-between;gap:16px;margin:13px 0 18px}.week-checkin>span{color:var(--muted);font-size:11px}.week-checkin>div{display:flex;gap:9px}.day-dot{display:grid;justify-items:center;gap:5px}.day-dot span{width:32px;height:32px;display:grid;place-items:center;border-radius:50%;background:#f3f1f7;color:#9c97a7;font-size:11px}.day-dot i{width:7px;height:7px;border-radius:50%;background:#d7d3dd}.day-dot.done span{background:var(--purple-light);color:var(--purple);font-weight:800}.day-dot.done i{background:var(--purple)}.reward-tip{min-height:43px;display:flex;align-items:center;justify-content:space-between;gap:10px;padding:8px 13px;border-radius:11px;background:var(--orange-light);color:#9b5d27;font-size:11px}.reward-tip button{border:0;background:transparent;color:#d46f20;font-weight:700}.checkin-actions{display:grid;grid-template-columns:1fr 1fr;gap:11px;margin-top:14px}.secondary-action,.primary-action{min-height:47px;border-radius:12px;font-weight:700}.secondary-action{border:1px solid var(--line);background:#f7f5fa;color:#666173}.primary-action{display:flex;align-items:center;justify-content:center;gap:8px;border:0;background:var(--purple);color:#fff;box-shadow:0 9px 20px #6d4aff2e}.primary-action.completed{background:var(--green)}.quick-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}.quick-stats article{display:flex;align-items:flex-start;gap:12px;padding:17px}.quick-stats small,.quick-stats p{display:block;margin:0;color:var(--muted);font-size:10px}.quick-stats p{min-height:34px;margin:3px 0 8px;color:#555064;font-size:11px}.quick-stats strong{margin-right:7px;color:var(--orange);font-size:24px}.course-list{display:grid;gap:10px}.course-item{display:grid;grid-template-columns:44px 1fr auto;align-items:center;gap:12px;padding:12px;border:1px solid var(--line);border-radius:13px}.course-item>span{width:44px;height:44px;display:grid;place-items:center;border-radius:12px;background:var(--purple-light);color:var(--purple)}.course-item strong,.course-item small{display:block}.course-item small{color:var(--muted);font-size:11px}.course-item button{border:0;background:transparent;color:var(--red)}.empty-course{width:100%;min-height:145px;display:grid;place-items:center;align-content:center;gap:9px;margin-top:11px;border:2px dashed #ddd9e7;border-radius:15px;background:#fcfbfe;color:var(--muted)}.empty-course span{width:46px;height:46px;display:grid;place-items:center;border-radius:50%;background:#f1eff6}.empty-course p{margin:0;font-size:12px}.task-list{display:grid;gap:10px}.task-list article{display:grid;grid-template-columns:36px 1fr auto;align-items:center;gap:10px;padding:11px;border-radius:12px;background:#f8f7fb}.task-list strong,.task-list small{display:block}.task-list strong{font-size:12px}.task-list small{color:var(--muted);font-size:10px}.task-list button{min-height:34px;border:0;background:transparent;color:var(--purple);font-size:10px;font-weight:800}.task-list article.done{opacity:.7}.task-list article.done button{color:var(--green)}.calendar-card .card-heading>span{color:var(--muted);font-size:10px}.calendar-week,.calendar-days{display:grid;grid-template-columns:repeat(7,1fr);gap:5px;text-align:center}.calendar-week{margin-bottom:6px;color:var(--muted);font-size:10px}.calendar-days span{aspect-ratio:1;display:grid;place-items:center;border-radius:8px;background:#f4f2f7;color:#a09baa;font-size:10px}.calendar-days span.studied{background:var(--green-light);color:var(--green);font-weight:800}.calendar-days span.today{box-shadow:0 0 0 3px #6d4aff59;color:var(--purple);font-weight:800}.calendar-days span.today.studied{box-shadow:0 0 0 3px #1aa97f59}.recent-list{display:grid;gap:13px}.recent-item{display:grid;grid-template-columns:40px 1fr auto;align-items:center;gap:10px}.recent-item>span{width:40px;height:40px;display:grid;place-items:center;border-radius:11px;background:var(--purple-light);color:var(--purple)}.recent-item strong,.recent-item small{display:block}.recent-item strong{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-size:12px}.recent-item small{color:var(--muted);font-size:10px}.plan-card{display:grid;grid-template-columns:1fr auto;gap:15px;padding:22px;border-radius:20px;background:linear-gradient(135deg,var(--purple),#a35ae5);color:#fff;box-shadow:0 17px 38px #6d4aff33}.plan-card p{margin:0;font-size:13px;font-weight:700}.plan-card small{color:#ffffffb3;font-size:10px}.plan-card>svg{width:35px;height:35px;opacity:.7}.plan-card>div:last-child{grid-column:1/-1;display:grid;grid-template-columns:1fr 1fr;gap:10px}.plan-card button{min-height:40px;border:1px solid rgba(255,255,255,.24);border-radius:10px;background:#ffffff24;color:#fff}.plan-card button:last-child{background:#fff;color:var(--purple);font-weight:800}.sidebar-backdrop{display:none}.dashboard-toast{position:fixed;left:50%;bottom:28px;z-index:100;max-width:min(420px,calc(100% - 30px));padding:12px 18px;border-radius:12px;background:var(--ink);color:#fff;box-shadow:var(--shadow);font-size:12px;opacity:0;pointer-events:none;transform:translate(-50%,15px);transition:.2s}.dashboard-toast.show{opacity:1;transform:translate(-50%)}.dashboard-dialog{width:min(460px,calc(100% - 28px));padding:0;border:0;border-radius:20px;box-shadow:0 25px 80px #1f193738}.dashboard-dialog::backdrop{background:#1e193066;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px)}.dashboard-dialog form{padding:24px}.dialog-heading{display:flex;justify-content:space-between;align-items:flex-start}.dialog-heading span{color:var(--purple);font-size:11px;font-weight:800}.dialog-heading h2{margin:3px 0 20px}.dialog-heading button{width:40px;height:40px;border:0;border-radius:10px;background:#f4f2f7}.dashboard-dialog label{display:block;margin:13px 0 6px;font-size:12px;font-weight:700}.dashboard-dialog input{width:100%;min-height:48px;padding:0 13px;border:1px solid var(--line);border-radius:11px}.dialog-actions{display:flex;justify-content:flex-end;gap:10px;margin-top:22px}.dialog-actions button{min-height:42px;padding:0 18px;border:1px solid var(--line);border-radius:10px;background:#fff}.dialog-actions button:last-child{border-color:var(--purple);background:var(--purple);color:#fff}body.dashboard-ready button:focus-visible,body.dashboard-ready a:focus-visible,body.dashboard-ready input:focus-visible{outline:3px solid rgba(109,74,255,.3);outline-offset:2px}@media(max-width:1180px){.dashboard-sidebar{width:220px}.dashboard-main{width:calc(100% - 220px);margin-left:220px}.dashboard-content{padding-inline:20px}.dashboard-grid{grid-template-columns:minmax(0,1.65fr) minmax(280px,1fr)}.topbar-actions nav{display:none}.quick-stats{grid-template-columns:1fr}.quick-stats article{align-items:center}.quick-stats p{min-height:0}}@media(max-width:900px){.dashboard-sidebar{transform:translate(-100%);width:270px}.dashboard-sidebar.open{transform:translate(0)}.dashboard-main{width:100%;margin-left:0}.mobile-sidebar-button{display:grid;place-items:center}.sidebar-backdrop{position:fixed;inset:0;z-index:35;border:0;background:#1d183159}.sidebar-backdrop.show{display:block}.dashboard-grid{grid-template-columns:1fr}.dashboard-secondary{grid-template-columns:1fr 1fr}.plan-card{grid-column:1/-1}}@media(max-width:620px){.dashboard-topbar{padding:9px 14px}.topbar-title p,.user-name,.points-pill span{display:none}.points-pill{padding:0 9px}.dashboard-content{padding:18px 14px 35px}.dashboard-card{padding:17px;border-radius:16px}.checkin-summary{grid-template-columns:1fr 1fr;gap:15px}.goal-progress{grid-column:1/-1;grid-row:2}.week-checkin{align-items:flex-start;flex-direction:column}.week-checkin>div{width:100%;justify-content:space-between;gap:3px}.day-dot span{width:30px;height:30px}.checkin-actions,.dashboard-secondary,.quick-stats{grid-template-columns:1fr}.course-item{grid-template-columns:40px 1fr auto}.reward-tip{align-items:flex-start}.topbar-actions{gap:4px}.user-trigger{padding-right:3px}.user-trigger>svg{display:none}}.sidebar-nav{padding:10px 12px}.sidebar-nav section+section{margin-top:10px}.sidebar-nav h2{margin:0 9px 3px;color:#8f899d;font-size:10px;font-weight:800;letter-spacing:.9px}.sidebar-nav a{min-height:38px;gap:9px;padding:0 10px;border-radius:9px;font-size:12px;cursor:pointer}.sidebar-nav a svg{width:16px;height:16px}.sidebar-nav a:hover{background:#f7f5fc;color:var(--purple)}.sidebar-nav a.active{box-shadow:inset 3px 0 0 var(--purple);font-weight:800}.sidebar-promos{gap:6px;padding:8px 10px 10px}.promo-card{min-height:52px;grid-template-columns:30px 1fr auto;gap:7px;padding:7px 8px;border-radius:11px}.promo-card>svg:first-child{width:30px;height:30px;padding:7px;border-radius:9px}.promo-card strong{font-size:11px}.promo-card small,.promo-card b{font-size:9px}.course-selector{display:grid;grid-template-columns:1fr 1fr;gap:10px;max-height:380px;overflow-y:auto;margin-bottom:12px;padding:2px}.selector-hint{grid-column:1/-1;color:var(--muted);font-size:11px;margin:0 0 4px}.course-option{position:relative;display:flex;flex-direction:column;padding:0;border:2px solid var(--line);border-radius:14px;cursor:pointer;transition:border-color .2s,box-shadow .2s;background:#fff;overflow:hidden}.course-option:hover{border-color:#c5bff2;box-shadow:0 4px 16px #6d4aff14}.course-option.checked{border-color:var(--purple);box-shadow:0 0 0 3px #6d4aff24}.course-option input[type=checkbox]{position:absolute;width:1px;height:1px;overflow:hidden;clip:rect(0 0 0 0);white-space:nowrap}.course-option-cover{width:100%;height:90px;object-fit:cover;display:block;background:#e8e5f2;flex-shrink:0}.course-option span{display:flex;flex-direction:column;gap:2px;padding:10px 12px 12px}.course-option span strong{display:block;font-size:13px;line-height:1.3}.course-option span small{display:block;color:var(--muted);font-size:11px}.course-option:after{content:"✓";position:absolute;top:8px;right:8px;width:26px;height:26px;display:grid;place-items:center;border-radius:50%;background:var(--purple);color:#fff;font-size:13px;font-weight:800;opacity:0;transform:scale(.6);transition:opacity .2s,transform .2s;pointer-events:none}.course-option.checked:after{opacity:1;transform:scale(1)}.dashboard-dialog #save-courses:disabled{opacity:.4;cursor:not-allowed}@keyframes highlight-pulse{0%{box-shadow:0 0 #6d4aff66}50%{box-shadow:0 0 0 12px #6d4aff00}to{box-shadow:0 0 #6d4aff00}}.calendar-card.highlight-pulse{animation:highlight-pulse .8s ease-out 2}.profile-content .dashboard-grid{grid-template-columns:minmax(0,2fr) minmax(300px,1fr);gap:22px}.profile-info-header{display:flex;align-items:center;gap:14px}.profile-avatar{width:52px;height:52px;display:grid;place-items:center;border-radius:50%;background:linear-gradient(145deg,#9278ff,var(--purple));color:#fff;font-size:22px;font-weight:800;flex-shrink:0}.profile-info-meta{flex:1;min-width:0}.profile-info-meta strong{display:block;font-size:16px}.profile-info-meta small{display:block;color:var(--muted);font-size:11px;margin-top:2px}.profile-edit-btn{min-height:36px;padding:0 14px;border:1px solid var(--line);border-radius:9px;background:#f7f5fa;color:#676275;font-size:12px;font-weight:600;cursor:pointer;display:flex;align-items:center;gap:6px}.profile-edit-btn:hover{background:var(--purple-light);color:var(--purple)}.profile-stat-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin-top:18px}.profile-stat-item{display:flex;align-items:center;gap:10px;padding:12px;border:1px solid var(--line);border-radius:12px}.profile-stat-icon{width:36px;height:36px;display:grid;place-items:center;border-radius:10px}.profile-stat-icon.coins{background:#fff8df;color:#d69700}.profile-stat-icon.courses{background:var(--purple-light);color:var(--purple)}.profile-stat-icon.streak{background:#fff0ed;color:#e86a4b}.profile-stat-item strong{font-size:20px;display:block}.profile-stat-item small{display:block;color:var(--muted);font-size:10px}.profile-security-list{display:grid;gap:6px}.security-row{display:flex;align-items:center;gap:12px;padding:12px;border:1px solid var(--line);border-radius:11px}.sec-icon{width:36px;height:36px;display:grid;place-items:center;border-radius:9px;background:#f4f2f7;color:#8a8096;flex-shrink:0}.sec-info{flex:1;min-width:0}.sec-info strong{display:block;font-size:13px}.sec-info small{display:block;color:var(--muted);font-size:11px;margin-top:1px}.sec-action{min-height:32px;padding:0 12px;border:1px solid var(--line);border-radius:8px;background:#fff;color:var(--purple);font-size:11px;font-weight:600;cursor:pointer}.sec-action:hover{background:var(--purple-light)}.profile-membership-card .card-heading{margin-bottom:16px}.profile-membership-status{display:flex;align-items:center;gap:12px;margin-bottom:16px}.member-badge{display:inline-flex;align-items:center;gap:6px;padding:5px 14px;border-radius:99px;font-size:12px;font-weight:700}.member-badge.free{background:#f4f2f7;color:#7a728b}.member-badge.vip{background:linear-gradient(135deg,gold,#fa0);color:#fff}.member-badge svg{width:14px;height:14px}.member-desc{color:var(--muted);font-size:11px;margin:0}.profile-feature-list{display:grid;gap:8px;margin-bottom:18px}.feature-row{display:flex;align-items:center;gap:10px;padding:8px 0;font-size:12px}.feature-dot{width:22px;height:22px;display:grid;place-items:center;border-radius:50%;flex-shrink:0}.feature-row.unlocked .feature-dot{background:var(--green-light);color:var(--green)}.feature-row.locked{color:#bbb6c3}.feature-row.locked .feature-dot{background:#f4f2f7;color:#c5bfcd}.feature-dot svg{width:12px;height:12px}.feature-tag{margin-left:auto;padding:2px 8px;border-radius:99px;background:var(--green-light);color:var(--green);font-size:10px;font-weight:600}.feature-tag.locked-tag{background:#f4f2f7;color:#bbb6c3}.profile-upgrade-btn{width:100%;min-height:44px;display:flex;align-items:center;justify-content:center;gap:8px;border:0;border-radius:12px;background:linear-gradient(135deg,var(--purple),#a35ae5);color:#fff;font-size:14px;font-weight:700;cursor:pointer;box-shadow:0 9px 20px #6d4aff2e}.profile-upgrade-btn.vip{background:linear-gradient(135deg,gold,#fa0);color:#3b2800}.profile-quick-card{padding:14px 22px!important}.profile-quick-actions{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}.quick-action-btn{min-height:48px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:5px;border:0;border-radius:12px;background:#f7f5fa;color:#676275;font-size:11px;font-weight:600;cursor:pointer;transition:background .18s}.quick-action-btn:hover{background:var(--purple-light);color:var(--purple)}.quick-action-btn.danger{color:var(--red)}.quick-action-btn.danger:hover{background:#fff0f0}.quick-action-btn svg{width:18px;height:18px}.dialog-body label{display:block;margin:13px 0 6px;font-size:12px;font-weight:700}.dialog-body input{width:100%;min-height:48px;padding:0 13px;border:1px solid var(--line);border-radius:11px}.dialog-hint{color:var(--muted);font-size:10px;margin:4px 0 0}@media(max-width:900px){.profile-content .dashboard-grid{grid-template-columns:1fr}.profile-stat-grid,.profile-quick-actions{grid-template-columns:repeat(3,1fr)}}@media(max-width:620px){.profile-info-header{flex-wrap:wrap}.profile-stat-grid,.profile-quick-actions{grid-template-columns:1fr}}.suggestion-dialog textarea{width:100%;min-height:150px;padding:12px 13px;border:1px solid var(--line);border-radius:11px;font:inherit;line-height:1.7;resize:vertical;outline:none}.suggestion-dialog textarea:focus{border-color:var(--purple);box-shadow:0 0 0 4px #6d4aff17}.suggestion-dialog .dialog-actions button:disabled{opacity:.55;cursor:not-allowed}.member-card{border-color:#d9d0ff;background:linear-gradient(135deg,#f7f3ff,#fff);box-shadow:0 10px 22px #6d4aff14}.member-card:hover{border-color:#b7a7ff;transform:translateY(-1px);transition:border-color .2s,transform .2s,box-shadow .2s;box-shadow:0 14px 28px #6d4aff21}.member-card b{min-width:38px;padding:4px 8px;border-radius:99px;background:var(--purple);color:#fff;text-align:center}.membership-dialog{width:min(1080px,calc(100% - 32px));max-height:calc(100vh - 34px);padding:0;border:0;border-radius:24px;background:#f8f7fc;color:var(--ink);box-shadow:0 28px 90px #1f193740;overflow:auto}.membership-dialog::backdrop{background:#1e19307a;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.membership-dialog form{padding:24px}.membership-head{display:flex;align-items:flex-start;justify-content:space-between;gap:18px;margin-bottom:16px}.membership-kicker{display:inline-flex;align-items:center;margin-bottom:7px;color:var(--purple);font-size:12px;font-weight:800}.membership-head h2{margin:0;font-size:26px;line-height:1.25}.membership-head p{max-width:650px;margin:8px 0 0;color:var(--muted);font-size:13px}.membership-close{width:42px;height:42px;display:grid;place-items:center;border:0;border-radius:12px;background:#fff;color:#686174;box-shadow:0 8px 18px #3d2d6e0f}.billing-tabs{width:min(320px,100%);display:grid;grid-template-columns:repeat(3,1fr);gap:4px;margin:0 auto 22px;padding:5px;border:1px solid #dcd7eb;border-radius:14px;background:#fff}.billing-tabs button{min-height:42px;border:0;border-radius:10px;background:transparent;color:#686174;font-size:13px;font-weight:800}.billing-tabs button.active{background:linear-gradient(135deg,var(--purple),#7e5bff);color:#fff;box-shadow:0 8px 18px #6d4aff38}.membership-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:16px}.membership-plan{position:relative;display:flex;flex-direction:column;min-height:520px;padding:22px;border:1px solid var(--line);border-radius:20px;background:#fff;box-shadow:0 12px 34px #3d2d6e0f}.membership-plan.featured-plan{border-color:#b6a8ff;box-shadow:0 18px 46px #6d4aff26}.membership-plan.partner-plan{border-color:#ffd089;background:linear-gradient(180deg,#fffaf0,#fff);box-shadow:0 18px 46px #ff994a24}.plan-badge{position:absolute;top:-14px;left:50%;display:inline-flex;align-items:center;gap:5px;padding:6px 12px;border-radius:99px;background:var(--purple);color:#fff;font-size:11px;font-weight:800;transform:translate(-50%);box-shadow:0 9px 18px #6d4aff40}.plan-badge svg{width:14px;height:14px}.plan-title{display:flex;align-items:center;gap:12px}.plan-title>span{width:42px;height:42px;display:grid;place-items:center;border-radius:13px;background:var(--purple-light);color:var(--purple)}.partner-plan .plan-title>span{background:#fff1d7;color:#c76c00}.free-plan .plan-title>span{background:#f2f0f7;color:#7a728b}.plan-title h3{margin:0;font-size:20px}.plan-title p{margin:3px 0 0;color:#5f5870;font-size:12px}.plan-price{display:flex;align-items:flex-end;gap:6px;margin:28px 0 7px}.plan-price small{align-self:center;color:var(--ink);font-size:18px;font-weight:800}.plan-price strong{font-size:46px;line-height:.9;font-weight:800;letter-spacing:0;font-variant-numeric:tabular-nums}.plan-price span{color:#6b6577;font-size:14px;font-weight:700}.price-note{width:max-content;max-width:100%;margin:0 0 22px;padding:5px 10px;border-radius:7px;background:var(--green-light);color:#07815f;font-size:12px;font-weight:800}.orange-note{background:#fff2df;color:#c76c00}.plan-button{min-height:52px;margin-bottom:22px;border:0;border-radius:13px;background:linear-gradient(135deg,#2f6de8,var(--purple));color:#fff;font-size:15px;font-weight:800;box-shadow:0 14px 30px #4a5be633}.plan-button.partner{background:linear-gradient(135deg,#ff9f0a,#e27600);box-shadow:0 14px 30px #e276002e}.plan-button.ghost{border:1px solid var(--line);background:#fff;color:#5f5870;box-shadow:none}.plan-button:disabled{cursor:not-allowed;opacity:.85}.membership-plan ul{display:grid;gap:13px;margin:0;padding:0;list-style:none}.membership-plan li{display:flex;align-items:flex-start;gap:9px;color:#252339;font-size:13px;line-height:1.45}.membership-plan li svg{width:18px;height:18px;flex:0 0 auto;color:#5d7cff}.partner-plan li svg{color:#dd7900}.membership-plan li.muted{color:#8d8799}.membership-plan li.muted svg{color:#a9a3b5}@media(max-width:980px){.membership-grid{grid-template-columns:1fr 1fr}.membership-plan.partner-plan{grid-column:1/-1;min-height:auto}.membership-plan{min-height:0}}@media(max-width:620px){.membership-dialog{width:calc(100% - 18px);border-radius:18px}.membership-dialog form{padding:18px}.membership-head h2{font-size:21px}.membership-head p{font-size:12px}.membership-grid{grid-template-columns:1fr}.membership-plan.partner-plan{grid-column:auto}.membership-plan{padding:18px;border-radius:16px}.plan-price strong{font-size:40px}.billing-tabs{margin-bottom:16px}.billing-tabs button{min-height:40px}.plan-button{min-height:48px}}.team-learning-panel{padding:32px 40px 60px;min-height:calc(100vh - 74px);background:linear-gradient(175deg,#f8f6ff,#f0edfa,#f4f2fb 60%,#faf8ff)}.team-learning-page{width:100%;max-width:1400px;margin:0 auto}.team-panel-head{display:flex;align-items:center;justify-content:center;flex-direction:column;text-align:center;gap:8px;margin-bottom:28px}.team-kicker{display:inline-flex;align-items:center;gap:6px;padding:4px 16px;border-radius:50px;background:#7c5cff14;color:#7c5cff;font-size:11px;font-weight:700;letter-spacing:.5px}.team-panel-head h2{margin:4px 0 0;font-size:28px;font-weight:800;color:#2d2a3d;line-height:1.25}.team-panel-head p{margin:4px 0 0;color:#8b8499;font-size:13px;max-width:500px}.team-search-bar{position:relative;display:flex;align-items:center;max-width:600px;margin:0 auto 28px;background:#fff;border-radius:50px;border:1px solid #e2dff0;box-shadow:0 2px 12px #6d4aff0d;overflow:hidden;transition:box-shadow .2s,border-color .2s}.team-search-bar:focus-within{box-shadow:0 4px 20px #6d4aff26;border-color:#7c5cff}.team-search-bar svg{flex-shrink:0;margin-left:20px;width:18px;height:18px;color:#a49dbb;position:static}.team-search-bar input{flex:1;height:48px;padding:0 16px;border:none;background:transparent;color:#333;font-size:14px;outline:none}.team-search-bar input::placeholder{color:#b5adc8}.team-search-bar button{flex-shrink:0;height:40px;padding:0 28px;margin:4px 4px 4px 0;border:none;border-radius:40px;background:linear-gradient(135deg,#7c5cff,#a080ff);color:#fff;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s;position:static}.team-search-bar button:hover{background:linear-gradient(135deg,#6d4aff,#8b6eff);box-shadow:0 4px 16px #7c5cff59}.team-create-card{padding:0;border:1px solid rgba(232,227,245,.6);border-radius:18px;background:#fff;margin-bottom:24px;overflow:hidden;box-shadow:0 4px 20px #6d4aff0f,0 1px 3px #00000005;transition:box-shadow .25s,border-color .25s}.team-create-card:hover{border-color:#c4b8f0cc;box-shadow:0 8px 32px #6d4aff1a}.team-create-header{display:flex;align-items:center;gap:12px;padding:18px 22px;cursor:pointer;transition:background .2s}.team-create-header:hover{background:#faf8ff}.team-create-header .heading-icon{width:40px;height:40px;border-radius:12px}.team-create-header h3{margin:0;font-size:16px;font-weight:700;color:#2d2a3d}.team-create-chevron{width:18px;height:18px;margin-left:auto;color:#a49dbb;transition:transform .25s ease}.team-create-body{padding:22px;display:grid;gap:18px;border-top:1px solid #f0edf7}.team-form-row{display:grid;grid-template-columns:1fr 1fr 120px 120px;gap:14px;align-items:end}.team-field{position:relative}.team-field label{display:block;margin-bottom:6px;font-size:12px;font-weight:700;color:#4f4a5d}.team-field input,.team-field select{width:100%;min-height:44px;padding:0 36px 0 16px;border:1.5px solid #e8e4f2;border-radius:14px;background:#fff;font-size:13px;color:#333;outline:none;appearance:none;-webkit-appearance:none;transition:border-color .2s,box-shadow .2s}.team-field input:focus,.team-field select:focus{border-color:#7c5cff;box-shadow:0 0 0 3px #7c5cff1a}.team-field input::placeholder{color:#b5adc8}.team-field select{cursor:pointer;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='14' fill='none' stroke='%23a49dbb' stroke-width='2'%3E%3Cpath d='M3 5l4 4 4-4'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 14px center;padding-right:40px}.team-field select:hover{border-color:#c4b8f0}.team-field:after{content:""}.team-type-toggle{display:flex;gap:6px;padding:4px;border-radius:14px;background:#f5f3fa;border:1px solid #e8e4f2}.team-type-btn{flex:1;min-height:38px;border:0;border-radius:11px;background:transparent;color:#6b6580;font-size:13px;font-weight:600;transition:all .2s ease}.team-type-btn:hover{color:#7c5cff;background:#7c5cff0d}.team-type-btn.active{background:linear-gradient(135deg,#7c5cff,#a080ff);color:#fff;box-shadow:0 4px 14px #7c5cff66}.team-create-btn{min-height:48px;display:flex;align-items:center;justify-content:center;gap:8px;border:0;border-radius:14px;background:linear-gradient(135deg,#7c5cff,#a080ff);color:#fff;font-size:14px;font-weight:700;cursor:pointer;box-shadow:0 6px 20px #7c5cff38;transition:all .2s}.team-create-btn:hover{background:linear-gradient(135deg,#6d4aff,#8b6eff);transform:translateY(-1px);box-shadow:0 8px 28px #7c5cff59}.team-create-btn:active{transform:translateY(0)}.team-search-results{margin-bottom:24px}.team-search-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;min-height:180px;padding:40px 20px;border-radius:16px;background:#fff;border:1px solid rgba(232,227,245,.5);color:#9b93aa;font-size:14px;text-align:center}.team-search-empty:before{content:"";width:56px;height:56px;border-radius:50%;background:linear-gradient(135deg,#f0ecff,#e4dcff)}.team-search-empty strong{color:#4f4a5d;font-size:15px;font-weight:700}.team-section{margin-bottom:24px}.team-section-head{display:flex;align-items:center;gap:12px;margin-bottom:16px}.team-section-head h3{margin:0;font-size:16px;font-weight:700;color:#2d2a3d}.team-refresh-btn{width:34px;height:34px;display:grid;place-items:center;margin-left:auto;border:1.5px solid #e8e4f2;border-radius:10px;background:#fff;color:#a49dbb;cursor:pointer;transition:all .15s}.team-refresh-btn:hover{background:#7c5cff0d;color:#7c5cff;border-color:#c4b8f0}.team-room-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:18px}.team-empty-hint{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;min-height:160px;padding:40px 20px;border-radius:16px;background:#fff;border:1px solid rgba(232,227,245,.5);color:#9b93aa;font-size:14px;text-align:center}.team-empty-hint:before{content:"";width:48px;height:48px;border-radius:50%;background:linear-gradient(135deg,#f0ecff,#e4dcff)}.room-card{display:flex;flex-direction:column;gap:12px;padding:20px;border:1px solid rgba(232,227,245,.6);border-radius:16px;background:#fff;transition:all .3s cubic-bezier(.4,0,.2,1);box-shadow:0 4px 20px #6d4aff0a,0 1px 3px #00000005}.room-card:hover{transform:translateY(-4px);box-shadow:0 16px 40px #6d4aff1f,0 6px 20px #6d4aff0f;border-color:#c4b8f0b3}.room-card.studying{border-color:#10b98126;background:linear-gradient(160deg,#f6fdf9,#fff);box-shadow:0 4px 20px #10b9810a}.room-card.studying:hover{border-color:#10b9814d;box-shadow:0 16px 40px #10b9811a}.room-card-top{display:flex;align-items:flex-start;justify-content:space-between;gap:10px}.room-info strong{font-size:15px;display:flex;align-items:center;gap:6px;color:#2d2a3d;font-weight:700}.room-info small{display:block;color:#b5adc8;font-size:11px;margin-top:3px;font-weight:500}.room-host-tag{padding:2px 8px;border-radius:6px;background:linear-gradient(135deg,#7c5cff,#a080ff);color:#fff;font-size:10px;font-weight:700;letter-spacing:.3px}.room-status{padding:4px 10px;border-radius:20px;font-size:11px;font-weight:700;white-space:nowrap;flex-shrink:0;letter-spacing:.3px}.room-status.green{background:#10b9811a;color:#059669}.room-status.orange{background:#f59e0b1a;color:#d97706}.room-card-body{display:grid;gap:6px}.room-meta{display:flex;align-items:center;gap:6px;font-size:12px;color:#6b6580}.room-meta svg{width:14px;height:14px;color:#a49dbb;flex-shrink:0}.room-members{display:flex;gap:5px;padding-top:4px}.room-member-avatar{width:32px;height:32px;display:grid;place-items:center;border-radius:50%;background:linear-gradient(135deg,#f0edff,#e8e2fc);color:#7c5cff;font-size:12px;font-weight:700;border:2px solid #fff;box-shadow:0 2px 6px #6d4aff14}.room-member-avatar.host{background:linear-gradient(145deg,#7c5cff,#6366f1);color:#fff;box-shadow:0 3px 10px #7c5cff40}.room-member-extra{width:32px;height:32px;display:grid;place-items:center;border-radius:50%;background:#f5f3fa;color:#a49dbb;font-size:11px;font-weight:700;border:2px solid #fff}.room-card-actions{display:flex;gap:8px;padding-top:4px}.room-action-btn{min-height:34px;padding:0 14px;border-radius:50px;font-size:12px;font-weight:700;border:1.5px solid #e8e4f2;background:#fff;color:#5e5877;cursor:pointer;transition:all .2s ease}.room-action-btn:hover{background:#faf8ff;border-color:#c4b8f0}.room-action-btn.enter{border-color:transparent;background:#10b981;color:#fff;box-shadow:0 4px 12px #10b98133}.room-action-btn.enter:hover{background:#059669;box-shadow:0 6px 18px #10b9814d}.room-action-btn.join{border-color:transparent;background:linear-gradient(135deg,#7c5cff,#a080ff);color:#fff;box-shadow:0 4px 14px #7c5cff38}.room-action-btn.join:hover{background:linear-gradient(135deg,#6d4aff,#8b6eff);box-shadow:0 6px 20px #7c5cff59;transform:translateY(-1px)}.room-action-btn.copy{width:34px;display:grid;place-items:center;padding:0;background:#fff;color:#a49dbb;border-color:#e8e4f2}.room-action-btn.copy:hover{background:#7c5cff0d;color:#7c5cff;border-color:#c4b8f0}.room-action-btn.leave{background:#fff;color:#ef4444;border-color:#ef444426;font-size:11px;font-weight:600}.room-action-btn.leave:hover{background:#fef2f2;border-color:#ef44444d;color:#dc2626}.room-action-btn.start-game{border:0;background:linear-gradient(135deg,#10b981,#059669);color:#fff;font-weight:700;box-shadow:0 4px 14px #10b98138}.room-action-btn.start-game:hover{background:linear-gradient(135deg,#059669,#047857);transform:translateY(-1px);box-shadow:0 6px 20px #10b98152}.room-action-btn.start-game:disabled{opacity:.4;cursor:not-allowed;transform:none;box-shadow:none;background:linear-gradient(135deg,#a7f3d0,#6ee7b7)}.room-action-btn.ready{border-color:transparent;background:linear-gradient(135deg,#7c5cff,#a080ff);color:#fff;font-weight:700;box-shadow:0 4px 14px #7c5cff33}.room-action-btn.ready:hover{background:linear-gradient(135deg,#6d4aff,#8b6eff);box-shadow:0 6px 20px #7c5cff52;transform:translateY(-1px)}.room-action-btn.ready-done{border-color:#10b98133;background:#10b9810f;color:#059669;font-weight:700}.room-action-btn.ready-done:hover{background:#10b9811f;border-color:#10b98159}.room-member-avatar.ready-mark{position:relative}.room-member-avatar.ready-mark:after{content:"";position:absolute;bottom:-2px;right:-2px;width:12px;height:12px;border-radius:50%;background:#10b981;border:2px solid #fff;box-shadow:0 2px 4px #10b9814d}@media(max-width:900px){.team-form-row,.team-room-grid{grid-template-columns:1fr 1fr}.team-search-bar{max-width:100%}}@media(max-width:620px){.team-learning-panel{padding:24px 20px 40px}.team-panel-head h2{font-size:22px}.team-form-row,.team-room-grid{grid-template-columns:1fr}.room-card{padding:16px}.team-search-bar input{font-size:13px}.team-search-bar button{padding:0 20px;font-size:13px}.team-panel-head{align-items:flex-start;text-align:left}}.system-messages-dialog{width:min(600px,calc(100% - 28px));max-height:min(700px,calc(100vh - 40px));padding:0;border:0;border-radius:22px;background:#faf9ff;color:var(--ink);box-shadow:0 25px 80px #1f193738;overflow:hidden}.system-messages-dialog[open]{display:flex;flex-direction:column}.system-messages-dialog::backdrop{background:#1e193073;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.system-messages-dialog form{display:flex;flex-direction:column;flex:1;min-height:0;padding:0}.sysmsg-head{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;padding:22px 24px 12px;border-bottom:1px solid #f0edf7}.sysmsg-kicker{display:inline-flex;align-items:center;margin-bottom:6px;color:var(--purple);font-size:11px;font-weight:800}.sysmsg-head h2{margin:0;font-size:22px;line-height:1.25}.sysmsg-head p{margin:5px 0 0;color:var(--muted);font-size:12px}.sysmsg-close{width:38px;height:38px;display:grid;place-items:center;border:0;border-radius:10px;background:#fff;color:#686174;flex-shrink:0;cursor:pointer;box-shadow:0 6px 14px #3d2d6e0f;transition:background .2s}.sysmsg-close:hover{background:#f4f2f7}.sysmsg-list{flex:1;overflow-y:auto;padding:10px;display:grid;gap:6px}.sysmsg-item{display:flex;gap:12px;padding:14px 16px;border-radius:14px;background:#fff;border:1px solid #f0edf7;position:relative;transition:border-color .2s,box-shadow .2s}.sysmsg-item:hover{border-color:#e0d8f5;box-shadow:0 4px 16px #6d4aff0f}.sysmsg-item.unread{background:linear-gradient(135deg,#faf7ff,#fff);border-color:#e4dcf8}.sysmsg-icon{width:44px;height:44px;display:grid;place-items:center;border-radius:12px;background:#f7f5fc;font-size:20px;flex-shrink:0}.sysmsg-item.unread .sysmsg-icon{background:var(--purple-light)}.sysmsg-body{flex:1;min-width:0}.sysmsg-row{display:flex;align-items:baseline;justify-content:space-between;gap:12px;margin-bottom:5px}.sysmsg-row strong{font-size:14px;color:#202036;font-weight:700}.sysmsg-row small{font-size:11px;color:#b0aabc;white-space:nowrap;flex-shrink:0}.sysmsg-body p{margin:0;font-size:12px;line-height:1.6;color:#696477;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.sysmsg-dot{position:absolute;top:14px;right:14px;width:8px;height:8px;border-radius:50%;background:var(--purple);box-shadow:0 0 0 3px #6d4aff2e}@media(max-width:620px){.system-messages-dialog{width:calc(100% - 16px);border-radius:16px}.sysmsg-head{padding:16px 16px 10px}.sysmsg-head h2{font-size:18px}.sysmsg-list{padding:6px}.sysmsg-item{padding:12px;gap:10px}.sysmsg-icon{width:38px;height:38px;font-size:18px}.sysmsg-body p{-webkit-line-clamp:3}}.pay-dialog{width:min(960px,calc(100% - 28px));max-height:calc(100vh - 40px);padding:0;border:0;border-radius:22px;background:#fff;color:var(--ink);box-shadow:0 25px 80px #1f193740;overflow:hidden}.pay-dialog::backdrop{background:#1e193080;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px)}.pay-dialog form{padding:0}.pay-layout{display:grid;grid-template-columns:400px 1fr;min-height:600px;max-height:min(760px,calc(100vh - 40px))}.pay-left{display:flex;flex-direction:column;justify-content:center;padding:40px 36px;background:linear-gradient(160deg,#f5f1ff,#ede7ff 40%,#e0d6ff)}.pay-left-icon{width:52px;height:52px;display:grid;place-items:center;border-radius:15px;background:linear-gradient(135deg,var(--purple),#9b7cff);color:#fff;box-shadow:0 12px 28px #6d4aff38;margin-bottom:20px}.pay-left-icon svg{width:28px;height:28px}.pay-left h2{margin:0 0 20px;font-size:22px;line-height:1.35;color:#2d2547}.pay-benefits{margin:0;padding:0;list-style:none;display:grid;gap:14px}.pay-benefits li{display:flex;align-items:flex-start;gap:10px;font-size:14px;color:#4a4160;line-height:1.5}.pay-benefits li svg{width:22px;height:22px;flex-shrink:0;color:#07c160;margin-top:1px}.pay-testimonial{margin-top:auto;padding:16px;border-radius:14px;background:#ffffffb8;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border:1px solid #e4dbf5}.pay-testimonial>p{margin:0 0 12px;font-size:13px;color:#4b3d6e;line-height:1.6;font-style:italic}.pay-testimonial>div{display:flex;align-items:center;gap:10px}.pay-testimonial>div>span{width:36px;height:36px;display:grid;place-items:center;border-radius:50%;color:#fff;font-size:15px;font-weight:800}.pay-testimonial strong{display:block;font-size:13px;color:#2d2547}.pay-testimonial small{display:block;font-size:11px;color:#8b7fa8;margin-top:2px}.pay-right{display:flex;flex-direction:column;padding:28px 30px 24px;position:relative;overflow-y:auto}.pay-close-btn{position:absolute;top:16px;right:16px;width:36px;height:36px;display:grid;place-items:center;border:0;border-radius:10px;background:#f5f3f9;color:#686174;cursor:pointer;transition:background .2s}.pay-close-btn:hover{background:#e8e4f2}.pay-right h3{margin:0 0 12px;font-size:18px;font-weight:800;color:#202036}.pay-plan-cards{display:flex;flex-direction:column;gap:10px;margin-bottom:14px}.pay-plan-card{position:relative;display:flex;align-items:center;gap:12px;padding:14px 16px;border:2px solid #e8e4f2;border-radius:14px;background:#fdfcff;cursor:pointer;transition:border-color .2s,background .2s,box-shadow .2s}.pay-plan-card:hover{border-color:#d4cdf0;background:#faf8ff}.pay-plan-card:has(input:checked){background:#faf7ff!important;border-color:var(--purple)!important;box-shadow:0 0 0 4px #6d4aff1f!important}.pay-plan-card.recommended{border-color:#e0d9f7}.pay-plan-radio{width:22px;height:22px;flex-shrink:0;border-radius:50%;border:2px solid #c5bfd4;display:grid;place-items:center;transition:border-color .2s,background .2s}.pay-plan-card:has(input:checked) .pay-plan-radio{border-color:var(--purple);background:var(--purple)}.pay-plan-card:has(input:checked) .pay-plan-radio:after{content:"";display:block;width:6px;height:6px;border-radius:50%;background:#fff}.pay-plan-info{flex:1;min-width:0;display:flex;flex-direction:column;gap:3px}.pay-plan-name{font-size:14px;font-weight:700;color:#202036}.pay-plan-duration{font-size:11px;color:#8b7fa8}.pay-plan-price-row{display:flex;align-items:baseline;gap:6px;flex-shrink:0}.pay-plan-price-row strong{font-size:20px;color:var(--purple);font-weight:800}.pay-plan-price-row del{font-size:12px;color:#b5adc4;text-decoration:line-through}.pay-plan-badge{display:inline-block;padding:2px 8px;border-radius:99px;background:var(--green-light);color:#07815f;font-size:10px;font-weight:700;align-self:flex-start}.pay-plan-card.recommended .pay-plan-badge{background:#fff0db;color:#c76c00}.pay-methods{display:flex;align-items:center;gap:10px;margin-bottom:16px;padding:14px 0;border-top:1px solid #f0edf7;border-bottom:1px solid #f0edf7}.pay-methods>span{font-size:13px;font-weight:700;color:#6b6577;margin-right:6px}.pay-method-item{display:flex;align-items:center;gap:10px;padding:12px 18px;border:2px solid #ece9f2;border-radius:13px;background:#fff;font-size:14px;font-weight:600;color:#555064;cursor:pointer;transition:all .2s;flex:1;justify-content:center}.pay-method-item:hover{background:#faf7ff;border-color:#d4cdf0;transform:translateY(-1px);box-shadow:0 4px 12px #6d4aff14}.pay-method-item:has(input:checked),.pay-method-item.active{border-color:var(--purple);background:linear-gradient(135deg,#faf7ff,#f3efff);color:var(--purple);box-shadow:0 0 0 4px #6d4aff26}.pay-method-item svg{flex-shrink:0;width:28px;height:28px}.pay-summary{margin-bottom:14px;padding:12px 14px;border-radius:14px;background:#faf9fd;display:grid;gap:8px}.pay-summary-row{display:flex;justify-content:space-between;align-items:center;font-size:13px;color:#696477}.pay-summary-row.discount{color:var(--green)}.pay-summary-row.total{border-top:1px solid #ece9f2;padding-top:10px;font-weight:700}.pay-summary-row.total span:first-child{font-size:14px;color:#202036}.pay-summary-row.total span:last-child{font-size:22px;color:var(--purple);font-weight:800}.pay-submit-btn{width:100%;min-height:48px;display:flex;align-items:center;justify-content:center;gap:8px;border:0;border-radius:14px;background:linear-gradient(135deg,var(--purple),#7e5bff);color:#fff;font-size:16px;font-weight:800;cursor:pointer;box-shadow:0 12px 28px #6d4aff38;transition:opacity .2s,transform .2s}.pay-submit-btn:hover{opacity:.92;transform:translateY(-1px)}.pay-submit-btn:active{transform:translateY(0)}.pay-submit-btn.loading{opacity:.7;pointer-events:none}.pay-agreement{margin:10px 0 0;text-align:center;font-size:11px;color:#b0aabc;line-height:1.5}.pay-agreement a{color:var(--purple);font-weight:600;text-decoration:none}.pay-agreement a:hover{text-decoration:underline}.pay-step{display:flex;flex-direction:column;gap:10px;animation:payFadeIn .25s ease}.pay-step[hidden]{display:none}@keyframes payFadeIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.pay-qr-back{display:inline-flex;align-items:center;gap:6px;align-self:flex-start;padding:8px 14px;border:1px solid #e8e4f2;border-radius:10px;background:#fff;color:#6b6577;font-size:13px;font-weight:600;cursor:pointer;transition:all .2s}.pay-qr-back:hover{background:#faf7ff;border-color:var(--purple);color:var(--purple)}.pay-qr-back svg{width:16px;height:16px;transform:rotate(180deg)}.pay-qr-order-info{display:flex;flex-direction:column;align-items:center;gap:6px;padding:18px 0 10px}.pay-qr-order-label{font-size:15px;font-weight:700;color:#4a4160;padding:4px 14px;border-radius:99px;background:#f5f1ff}.pay-qr-order-info strong{font-size:32px;font-weight:800;color:var(--purple);letter-spacing:-.5px}.pay-qr-order-info small{font-size:12px;color:#9b93aa}.pay-qr-order-info small span{font-weight:600;color:#6b6577}.pay-qr-box{display:flex;flex-direction:column;align-items:center;gap:14px;padding:24px;border-radius:18px;background:#faf9fd;border:2px dashed #e8e4f2}.pay-qr-img{display:grid;place-items:center;padding:12px;border-radius:16px;background:#fff;box-shadow:0 4px 20px #6d4aff1a}.pay-qr-img svg{display:block}.pay-qr-hint{font-size:13px;color:#8b7fa8;margin:0}#pay-mock-btn{margin-top:6px}.pay-toast{position:fixed;left:50%;bottom:28px;z-index:200;max-width:min(420px,calc(100% - 30px));padding:12px 18px;border-radius:12px;background:var(--ink);color:#fff;box-shadow:0 18px 45px #00000040;font-size:13px;opacity:0;pointer-events:none;transform:translate(-50%,15px);transition:.2s}.pay-toast.show{opacity:1;transform:translate(-50%)}.pay-toast.success{background:var(--green)}@media(max-width:780px){.pay-layout{grid-template-columns:1fr;height:auto}.pay-left{padding:28px 24px;text-align:center}.pay-left h2{font-size:19px}.pay-benefits li{justify-content:center;font-size:13px}.pay-right{padding:24px 20px 22px;overflow-y:auto}.pay-plan-cards{gap:8px}.pay-methods{flex-wrap:wrap}.pay-method-item{flex:1 1 100px}}.courses-content{min-height:calc(100vh - 74px);padding:32px 40px 60px;background:linear-gradient(175deg,#f8f6ff,#f0edfa,#f4f2fb 60%,#faf8ff)}.courses-page{width:100%;max-width:1400px;margin:0 auto;display:grid;gap:24px}.courses-control-card{padding:28px 32px 4px;border:1px solid rgba(232,227,245,.6);border-radius:16px;background:#fff;box-shadow:0 4px 20px #6d4aff0f,0 1px 3px #00000005}.courses-heading-row{display:grid;grid-template-columns:auto minmax(260px,480px) 1fr;align-items:center;gap:22px;margin-bottom:20px}.courses-heading-row h1{margin:0;font-size:22px;font-weight:700;color:#2d2a3d}.courses-heading-row p{display:none}.course-search{min-height:46px;display:flex;align-items:center;gap:10px;padding:0 18px;border-radius:50px;background:#f8f7fc;border:1px solid #e8e3f5;color:#a49dbb;transition:border-color .2s,box-shadow .2s}.course-search:focus-within{border-color:#7c5cff;box-shadow:0 0 0 3px #7c5cff14}.course-search input{width:100%;border:0;outline:0;background:transparent;color:#2d2a3d;font-size:14px}.course-search input::placeholder{color:#b5adc8}.course-add-button{justify-self:end;min-height:44px;display:flex;align-items:center;gap:7px;padding:0 22px;border:none;border-radius:50px;background:linear-gradient(135deg,#7c5cff,#a080ff);color:#fff;font-weight:600;font-size:14px;cursor:pointer;transition:all .2s ease;box-shadow:0 4px 14px #7c5cff4d}.course-add-button:hover{background:linear-gradient(135deg,#6d4aff,#8b6eff);box-shadow:0 6px 20px #7c5cff66;transform:translateY(-1px)}.course-stat-grid{display:grid;grid-template-columns:repeat(6,1fr);gap:14px;margin:0 0 20px;padding-bottom:20px;border-bottom:1px solid #f0edf7}.course-stat-grid article{min-height:88px;display:grid;place-content:center;text-align:center;border-radius:14px;background:#faf8ff;border:1px solid rgba(232,227,245,.5);transition:transform .2s,box-shadow .2s}.course-stat-grid article:hover{transform:translateY(-2px);box-shadow:0 4px 16px #6d4aff14}.course-stat-grid span{color:#948faa;font-size:12px;font-weight:500}.course-stat-grid strong{margin-top:4px;font-size:26px;font-weight:700;color:#2d2a3d}.course-stat-grid .green{color:#10b981}.course-stat-grid .blue{color:#7c5cff}.course-stat-grid .purple{color:#a080ff}.course-stat-grid .orange{color:#f59e0b;font-size:18px}.continue-card{padding:24px 30px;border:1px solid rgba(232,227,245,.6);border-radius:16px;background:#fff;box-shadow:0 4px 20px #6d4aff0f,0 1px 3px #00000005}.continue-heading{display:flex;align-items:center;justify-content:space-between;margin-bottom:18px}.continue-heading h2{display:flex;align-items:center;gap:9px;margin:0;font-size:17px;font-weight:700;color:#2d2a3d}.play-dot{width:24px;height:24px;display:grid;place-items:center;border-radius:50%;background:linear-gradient(135deg,#7c5cff,#a080ff);color:#fff;font-size:10px}.continue-heading>div,.continue-heading>span{display:flex;align-items:center;gap:16px;color:#948faa;font-size:13px}.continue-heading time{color:#948faa;font-size:12px}.continue-heading button{min-height:36px;padding:0 18px;border:1.5px solid #c4b8f0;border-radius:50px;background:#f8f6ff;color:#7c5cff;font-weight:600;font-size:13px;cursor:pointer;transition:all .2s}.continue-heading button:hover{background:#f0ecff;border-color:#7c5cff}.continue-course{display:grid;grid-template-columns:160px 1fr auto;align-items:center;gap:24px;padding:22px;border-radius:14px;background:linear-gradient(135deg,#faf8ff,#f5f2fd);border:1px solid rgba(232,227,245,.4);transition:box-shadow .2s}.continue-course:hover{box-shadow:0 4px 18px #6d4aff14}.continue-detail h3{margin:0 0 6px;font-size:18px;font-weight:700;color:#2d2a3d}.continue-detail p{display:flex;align-items:center;gap:10px;margin:0 0 14px;color:#9b93aa;font-size:13px}.continue-detail p b{padding:4px 10px;border-radius:20px;background:#f0ecff;color:#7c5cff;font-weight:600}.continue-detail mark{padding:4px 10px;border-radius:20px;background:#ecfdf5;color:#10b981;font-weight:600}.course-progress-label{display:flex;justify-content:space-between;margin-bottom:6px;color:#948faa;font-size:12px}.course-progress-label strong{color:#7c5cff;font-weight:700}.course-progress{height:6px;border-radius:50px;background:#e8e3f5;overflow:hidden}.course-progress i{display:block;width:0;height:100%;border-radius:50px;background:linear-gradient(135deg,#7c5cff,#a080ff);transition:width .5s ease}.continue-button{min-width:120px;min-height:48px;padding:0 24px;border:none;border-radius:50px;background:linear-gradient(135deg,#7c5cff,#a080ff);color:#fff;font-weight:700;font-size:14px;cursor:pointer;box-shadow:0 4px 14px #7c5cff59;transition:all .2s ease}.continue-button:hover{background:linear-gradient(135deg,#6d4aff,#8b6eff);box-shadow:0 6px 22px #7c5cff73;transform:translateY(-1px)}.course-library{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:16px;align-items:stretch}.library-course-card{display:flex;flex-direction:column;overflow:hidden;border-radius:16px;background:#fff;cursor:pointer;border:1px solid rgba(232,227,245,.6);box-shadow:0 4px 20px #6d4aff0f,0 1px 3px #00000005;transition:all .3s cubic-bezier(.4,0,.2,1)}.library-course-card:hover{transform:translateY(-6px);box-shadow:0 20px 48px #6d4aff26,0 8px 24px #6d4aff14;border-color:#c4b8f0cc}.library-course-card>img{width:100%;aspect-ratio:4 / 3;height:auto;display:block;object-fit:cover;border-radius:16px 16px 0 0}.library-course-meta{display:flex;align-items:center;justify-content:space-between;padding:10px 14px 4px;color:#948faa;font-size:11px;font-weight:500}.library-course-meta>div{display:flex;gap:10px}.library-course-meta time{color:#b5adc8;font-size:10px}.library-course-title{display:flex;align-items:flex-start;gap:8px;padding:4px 14px 12px;border-bottom:1px solid #f5f2fc}.library-course-title strong{flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-size:14px;font-weight:600;color:#2d2a3d;transition:color .2s}.library-course-card:hover .library-course-title strong{color:#7c5cff}.library-course-title span{flex-shrink:0;padding:3px 8px;border-radius:20px;background:#f0ecff;color:#7c5cff;font-size:10px;font-weight:600}.library-course-card button{width:calc(100% - 24px);min-height:38px;margin:10px 12px 12px;border:1.5px solid #c4b8f0;border-radius:50px;background:#f8f6ff;color:#7c5cff;font-weight:700;font-size:12px;cursor:pointer;transition:all .2s ease}.library-course-card button:hover{background:#f0ecff;border-color:#7c5cff}.discover-course-card{display:grid;place-content:center;justify-items:center;gap:12px;min-height:220px;border:2px dashed #d5cff0;border-radius:16px;background:#ffffff80;color:#9b93aa;transition:all .2s}.discover-course-card:hover{border-color:#7c5cff;background:#fffc}.discover-course-card span{width:56px;height:56px;display:grid;place-items:center;border-radius:50%;background:linear-gradient(135deg,#f0ecff,#e4dcff)}.discover-course-card svg{width:26px!important;height:26px!important;color:#7c5cff}.discover-course-card strong{font-weight:600;font-size:15px;color:#5e5877}.course-empty-result{grid-column:1 / -1;min-height:220px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px;padding:40px 20px;border-radius:16px;background:#fff;border:1px solid rgba(232,227,245,.6);color:#9b93aa;font-size:14px;text-align:center}.course-empty-result:before{content:"";width:56px;height:56px;border-radius:50%;background:linear-gradient(135deg,#f0ecff,#e4dcff);margin-bottom:4px}.course-empty-result strong{color:#4f4a5d;font-size:15px;font-weight:700}.course-cover{position:relative;min-height:180px;overflow:hidden;padding:22px 18px;background:linear-gradient(145deg,#f5aa46 0 46%,#f7df91 46% 100%);color:#25545a;border-radius:16px 16px 0 0}.course-cover strong{position:relative;z-index:2;display:block;margin-top:24px;font-size:25px;letter-spacing:1px;text-align:center}.course-cover strong span{color:#df7138}.course-cover>small{position:relative;z-index:2;display:block;text-align:center;font-size:8px;letter-spacing:.7px}.cover-bubbles{position:absolute;inset:13px 14px auto;display:flex;justify-content:space-between}.cover-bubbles i{padding:5px 8px;border:2px solid #315a5d;border-radius:50%;background:#fff8d6;font-size:8px;font-style:normal;font-weight:900;transform:rotate(-8deg)}.cover-bubbles i:last-child{transform:rotate(8deg)}.cover-scene{position:absolute;inset:auto 0 0;height:88px;background:#72b7a3}.cover-scene b{position:absolute;left:18px;bottom:15px;font-size:35px;color:#356d70}.cover-scene span{position:absolute;left:82px;bottom:18px;width:75px;height:28px;border-radius:8px;background:#e56f39;box-shadow:28px -12px 0 -6px #f4c453}.cover-scene i,.cover-scene em{position:absolute;bottom:10px;width:28px;height:55px;border-radius:50% 50% 10px 10px;background:#56463e}.cover-scene i{right:52px}.cover-scene em{right:20px;background:#bf5d3f}.course-cover-small{min-height:90px;padding:8px}.course-cover-small strong{margin-top:22px;font-size:14px}.course-cover-small>small{font-size:5px}.course-cover-small .cover-bubbles{inset:6px 7px auto}.course-cover-small .cover-bubbles i{padding:2px 4px;border-width:1px;font-size:5px}.course-cover-small .cover-scene{height:35px}.course-cover-small .cover-scene b{left:8px;bottom:5px;font-size:15px}.course-cover-small .cover-scene span{left:40px;bottom:6px;width:35px;height:12px}.course-cover-small .cover-scene i,.course-cover-small .cover-scene em{bottom:3px;width:12px;height:23px}.course-cover-small .cover-scene i{right:25px}.course-cover-small .cover-scene em{right:9px}.continue-course>img{width:100%;height:118px;display:block;object-fit:cover;border-radius:12px;box-shadow:0 4px 16px #6d4aff1a}.continue-detail{min-width:0}.continue-detail h3{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.continue-detail p{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.continue-button{justify-self:end}@media(max-width:1280px){.course-stat-grid{grid-template-columns:repeat(3,1fr)}.course-library{grid-template-columns:repeat(3,minmax(0,1fr))}.courses-heading-row{grid-template-columns:auto 1fr auto}}@media(max-width:1024px){.course-library{grid-template-columns:repeat(2,minmax(0,1fr))}}@media(max-width:768px){.courses-content{padding:24px 20px 40px}.courses-control-card{padding:20px 18px 4px}.continue-card{padding:20px 18px}.courses-heading-row{grid-template-columns:1fr auto}.course-search{grid-column:1 / -1;grid-row:2}.course-stat-grid{grid-template-columns:repeat(2,1fr);gap:10px}.course-stat-grid article{min-height:76px}.course-stat-grid strong{font-size:22px}.continue-course{grid-template-columns:110px 1fr}.continue-button{grid-column:1 / -1;width:100%;justify-self:stretch}.continue-detail p{align-items:flex-start;flex-wrap:wrap}.course-library{grid-template-columns:repeat(2,minmax(0,1fr));gap:14px}.discover-course-card{min-height:160px}.continue-heading{align-items:flex-start;flex-direction:column;gap:8px}.continue-heading time{display:none}.library-course-meta{gap:10px}.library-course-meta>div{flex-wrap:wrap;gap:6px 12px}}@media(max-width:480px){.courses-content{padding:18px 14px 35px}.courses-heading-row h1{font-size:20px}.course-add-button{padding:0 16px;font-size:13px}.course-stat-grid{grid-template-columns:repeat(2,1fr);gap:8px}.continue-course,.course-library{grid-template-columns:1fr}.continue-course>img{height:auto;aspect-ratio:16 / 9}.continue-detail h3,.continue-detail p{white-space:normal}.course-cover-small{min-height:120px}}@media(prefers-reduced-motion:reduce){.course-add-button,.continue-button,.library-course-card,.course-stat-grid article,.continue-course{transition:none}.library-course-card:hover{transform:none}.course-stat-grid article:hover{transform:none}}.course-center-content{min-height:calc(100vh - 74px);padding:32px 40px 60px;background:linear-gradient(175deg,#f8f6ff,#f0edfa,#f4f2fb 60%,#faf8ff)}.course-center-page{width:100%;max-width:1400px;margin:0 auto}.course-center-search-bar{display:flex;align-items:center;max-width:600px;margin:0 auto 28px;background:#fff;border-radius:50px;border:1px solid #e2dff0;box-shadow:0 2px 12px #6d4aff0d;overflow:hidden;transition:box-shadow .2s,border-color .2s}.course-center-search-bar:focus-within{box-shadow:0 4px 20px #6d4aff26;border-color:#6d4aff}.course-center-search-icon{flex-shrink:0;margin-left:20px;color:#a49dbb}.course-center-search-input{flex:1;height:48px;padding:0 16px;border:none;background:transparent;color:#333;font-size:14px;outline:none}.course-center-search-input::placeholder{color:#b5adc8}.course-center-search-btn{flex-shrink:0;height:40px;padding:0 28px;margin:4px 4px 4px 0;border:none;border-radius:40px;background:linear-gradient(135deg,#7c5cff,#a080ff);color:#fff;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s}.course-center-search-btn:hover{background:linear-gradient(135deg,#6d4aff,#8b6eff);box-shadow:0 4px 16px #7c5cff59}.course-center-categories-wrap{display:flex;justify-content:center;margin-bottom:16px}.course-center-categories{display:flex;flex-wrap:wrap;justify-content:center;gap:10px;padding:10px 16px;border-radius:50px;background:#f8f6ffe6;border:1px solid rgba(232,227,245,.6);box-shadow:0 4px 20px #6d4aff14,0 1px 3px #00000005;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.course-center-categories button{height:40px;padding:0 24px;border:1.5px solid transparent;border-radius:50px;background:transparent;color:#5e5877;cursor:pointer;font-size:15px;font-weight:500;transition:all .2s ease;outline:none}.course-center-categories button:hover{color:#7c5cff;background:#7c5cff0f}.course-center-categories button.active{background:linear-gradient(135deg,#7c5cff,#a080ff);color:#fff;border-color:transparent;box-shadow:0 4px 14px #7c5cff66;font-weight:500}.course-center-subtabs-wrap{display:flex;justify-content:center;margin-bottom:28px}.course-center-subtabs{display:flex;flex-wrap:wrap;justify-content:center;gap:8px;padding:8px 14px;border-radius:50px;background:#ffffffb3;border:1px solid rgba(232,227,245,.5);box-shadow:0 2px 12px #6d4aff0a;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.course-center-subtabs button{height:32px;padding:0 18px;border:1.5px solid transparent;border-radius:50px;background:transparent;color:#6b6580;cursor:pointer;font-size:14px;font-weight:500;transition:all .2s ease;outline:none}.course-center-subtabs button:hover{color:#7c5cff;background:#7c5cff0d}.course-center-subtabs button.active{background:#f8f6ff;color:#7c5cff;border-color:#c4b8f0;font-weight:500}.course-center-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:20px}.course-center-card{display:flex;flex-direction:column;overflow:hidden;border-radius:16px;background:#fff;cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1);border:1px solid rgba(232,227,245,.6);box-shadow:0 4px 20px #6d4aff0f,0 1px 3px #00000005;padding:0;margin:0;box-sizing:border-box}.course-center-card:hover{transform:translateY(-6px);box-shadow:0 20px 48px #6d4aff26,0 8px 24px #6d4aff14;border-color:#c4b8f0cc}.course-center-cover-wrap{position:relative;width:100%;height:160px;background:linear-gradient(135deg,#8b5cf6,#6366f1,#3b82f6 50%,#06b6d4);overflow:hidden;flex-shrink:0;border-radius:16px 16px 0 0;box-sizing:border-box;margin:0;padding:0}.course-center-card .course-center-cover{display:block;position:absolute;top:0;left:0;width:100%;height:100%;min-width:100%;min-height:100%;max-width:none;max-height:none;object-fit:fill;border:none;outline:none;margin:0;padding:0;border-radius:16px 16px 0 0;box-sizing:border-box}.course-center-cover-badge{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);z-index:2;background:#fffffff2;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);padding:14px 28px;border-radius:12px;text-align:center;box-shadow:0 4px 20px #0000001a;min-width:120px}.course-center-cover-badge h3{margin:0 0 4px;font-size:18px;font-weight:700;color:#4f46e5;letter-spacing:1px}.course-center-cover-badge p{margin:0;font-size:11px;color:#8b5cf6;font-weight:500}.course-center-corner-tag{position:absolute;top:10px;right:10px;z-index:3;padding:4px 10px;border-radius:6px;font-size:11px;font-weight:600;color:#fff;text-transform:uppercase;letter-spacing:.5px}.course-center-corner-tag.new{background:linear-gradient(135deg,#10b981,#34d399)}.course-center-corner-tag.hot{background:linear-gradient(135deg,#f59e0b,#fbbf24)}.course-center-corner-tag.free{background:linear-gradient(135deg,#ec4899,#f472b6)}.course-center-corner-tag.member{background:linear-gradient(135deg,#7c5cff,#a080ff)}.course-center-card-body{display:flex;flex-direction:column;padding:16px;flex:1;gap:12px}.course-center-card-meta{display:flex;align-items:center;justify-content:space-between;gap:8px}.course-center-card-meta small{font-size:12px;font-weight:500;padding:5px 12px;border-radius:20px}.course-center-card-meta small:first-child{background:#f0edff;color:#7c5cff}.course-center-card-meta small:last-child{background:#f8f7fc;color:#8b8499}.course-center-card-body>strong{display:-webkit-box;overflow:hidden;-webkit-line-clamp:2;-webkit-box-orient:vertical;color:#2d2a3d;font-size:15px;font-weight:600;line-height:1.5;min-height:45px}.course-center-card:hover .course-center-card-body>strong{color:#7c5cff}.course-center-card-body>em{display:block;font-style:normal;font-size:12px;font-weight:400;color:#a8a3b8}.course-center-empty{grid-column:1 / -1;min-height:220px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px;padding:40px 20px;border-radius:16px;background:#fff;color:#9b93aa;font-size:14px;text-align:center}.course-center-empty:before{content:"";width:56px;height:56px;border-radius:50%;background:linear-gradient(135deg,#f0ecff,#e4dcff);margin-bottom:4px}.course-center-empty strong{color:#4f4a5d;font-size:15px;font-weight:700}@media(max-width:1280px){.course-center-grid{grid-template-columns:repeat(4,1fr)}}@media(max-width:1024px){.course-center-grid{grid-template-columns:repeat(3,1fr)}}@media(max-width:768px){.course-center-content{padding:24px 20px 40px}.course-center-grid{grid-template-columns:repeat(2,1fr);gap:16px}.course-center-cover-wrap{height:140px}.course-center-cover-badge{padding:12px 20px;min-width:100px}.course-center-cover-badge h3{font-size:16px}.course-center-categories button{padding:0 18px;height:38px;font-size:13px}.course-center-subtabs button{padding:0 12px;height:30px;font-size:12px}}@media(max-width:480px){.course-center-grid{grid-template-columns:1fr}.course-center-search-bar{margin-bottom:20px}.course-center-search-btn{padding:0 18px}}@media(prefers-reduced-motion:reduce){.course-center-categories button,.course-center-subtabs button,.course-center-card,.course-center-search-input{transition:none}.course-center-card:hover{transform:none}}#course-detail-panel{width:100%;min-height:100%;background:#f5f3f8}.learning-loader,.learning-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:400px;padding:40px;text-align:center;color:#7c7497}.learning-loader:before{content:"";width:40px;height:40px;border:3px solid #e6e0f0;border-top-color:#8b5cf6;border-radius:50%;animation:detail-spin 1s linear infinite;margin-bottom:16px}@keyframes detail-spin{to{transform:rotate(360deg)}}.learning-empty h2{font-size:20px;font-weight:600;color:#1f1833;margin-bottom:8px}.learning-empty p{font-size:14px;color:#7c7497;margin-bottom:24px}.detail-retry-btn,.detail-go-back-btn{padding:10px 24px;border-radius:8px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s;border:none}.detail-retry-btn{background:#8b5cf6;color:#fff;margin-bottom:12px}.detail-retry-btn:hover{background:#7c3aed}.detail-go-back-btn{background:transparent;color:#7c7497}.detail-go-back-btn:hover{color:#1f1833}.detail-hero{position:relative;width:100%;min-height:280px;background:linear-gradient(135deg,#8b5cf6,#a78bfa 35%,#c4b5fd 65%,#f5d0fe);padding:32px 40px 40px;box-sizing:border-box;overflow:hidden}.detail-hero:before{content:"";position:absolute;right:-80px;top:-80px;width:420px;height:420px;background:radial-gradient(circle,rgba(255,255,255,.35) 0%,transparent 65%);border-radius:50%;pointer-events:none}.detail-hero:after{content:"";position:absolute;right:180px;bottom:-120px;width:320px;height:320px;background:radial-gradient(circle,rgba(255,255,255,.25) 0%,transparent 60%);border-radius:50%;pointer-events:none}.detail-hero-inner{position:relative;z-index:2;max-width:1200px;margin:0;display:flex;align-items:center;justify-content:space-between;min-height:210px}.detail-hero-left{flex:1;max-width:560px}.detail-hero-top-row{display:flex;align-items:center;gap:10px;margin-bottom:18px}.detail-back-nav{display:inline-flex;align-items:center;gap:6px;padding:8px 18px;background:#fff;border:none;border-radius:24px;font-size:13px;color:#4b445c;cursor:pointer;transition:all .2s;box-shadow:0 2px 8px #00000014;flex-shrink:0}.detail-back-nav:hover{transform:translateY(-1px);box-shadow:0 4px 14px #0000001f}.detail-back-nav svg{width:14px;height:14px;color:#7c7497}.detail-badges{display:inline-flex;align-items:center;gap:8px;vertical-align:middle}.detail-badge{display:inline-flex;align-items:center;padding:5px 12px;font-size:12px;font-weight:600;border-radius:16px}.detail-badge.free{background:#86efac;color:#166534}.detail-badge.member{background:#fde68a;color:#92400e}.detail-badge.level{background:#ffffffe6;color:#6d28d9;border:1px solid rgba(255,255,255,.5)}.detail-hero-title-wrap{display:flex;align-items:center;gap:10px;margin-bottom:10px}.detail-hero-title{font-size:34px;font-weight:800;color:#fff;margin:0;line-height:1.2;text-shadow:0 2px 8px rgba(0,0,0,.1)}.detail-hero-title-icon{width:26px;height:26px;color:#fff;filter:drop-shadow(0 2px 4px rgba(0,0,0,.1))}.detail-hero-subtitle{display:flex;align-items:center;gap:8px;font-size:14px;color:#ffffffd9;margin-bottom:26px}.detail-hero-subtitle:before{content:"ⓘ";display:inline-flex;align-items:center;justify-content:center;width:16px;height:16px;border:1.5px solid rgba(255,255,255,.6);border-radius:50%;font-size:10px;color:#fffc;flex-shrink:0}.detail-hero-cta{display:inline-flex;align-items:center;justify-content:center;padding:13px 36px;background:#7c3aed;color:#fff;font-size:15px;font-weight:600;border:none;border-radius:10px;cursor:pointer;transition:all .2s;box-shadow:0 4px 18px #7c3aed66}.detail-hero-cta:hover{background:#6d28d9;transform:translateY(-2px);box-shadow:0 8px 24px #7c3aed80}.detail-hero-cta:disabled{background:#ffffff59;cursor:not-allowed;box-shadow:none;transform:none;color:#fffc}.detail-hero-illustration{position:relative;width:340px;height:220px;flex-shrink:0;margin-left:40px}.detail-hero-illustration:before{content:"";position:absolute;right:0;top:50%;transform:translateY(-50%);width:320px;height:180px;background:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 360 200'%3E%3Cdefs%3E%3ClinearGradient id='mon' x1='0%25' y1='0%25' x2='100%25' y2='100%25'%3E%3Cstop offset='0%25' stop-color='%23ffffff' stop-opacity='0.95'/%3E%3Cstop offset='100%25' stop-color='%23f3e8ff' stop-opacity='0.9'/%3E%3C/linearGradient%3E%3Cfilter id='shadow' x='-20%25' y='-20%25' width='140%25' height='140%25'%3E%3CfeDropShadow dx='0' dy='4' stdDeviation='6' flood-color='%237c3aed' flood-opacity='0.15'/%3E%3C/filter%3E%3C/defs%3E%3Crect x='120' y='65' width='120' height='80' rx='8' fill='url(%23mon)' filter='url(%23shadow)'/%3E%3Crect x='132' y='77' width='96' height='56' rx='4' fill='%23ddd6fe' opacity='0.5'/%3E%3Crect x='60' y='120' width='70' height='12' rx='6' fill='%23ffffff' opacity='0.6'/%3E%3Crect x='230' y='110' width='60' height='10' rx='5' fill='%23ffffff' opacity='0.5'/%3E%3Crect x='250' y='55' width='32' height='32' rx='6' fill='%23ffffff' opacity='0.7'/%3E%3Crect x='75' y='45' width='28' height='28' rx='6' fill='%23ffffff' opacity='0.4'/%3E%3C/svg%3E") no-repeat center;background-size:contain;opacity:.9}.detail-meta-bar{display:flex;align-items:center;gap:20px;padding:16px 40px;background:#fff;border-bottom:1px solid #ede9f5;max-width:1200px;margin:0;box-shadow:0 2px 12px #8b5cf60a}.detail-meta-title{font-size:17px;font-weight:700;color:#1f1833}.detail-meta-divider{width:1px;height:20px;background:#e6e0f0}.detail-meta-tag{display:flex;align-items:center;gap:6px;font-size:13px;color:#5b5370;padding:6px 14px;background:#faf8fc;border-radius:20px;border:1px solid #ede9f5}.detail-meta-tag svg{width:14px;height:14px;color:#9d8ec4}.detail-body{display:grid;grid-template-columns:1fr 340px;gap:24px;padding:28px 40px 48px;max-width:1200px;margin:0}.detail-card{background:#fff;border-radius:16px;border:1px solid #ede9f5;box-shadow:0 4px 18px #7c5cf60f;margin-bottom:22px;overflow:hidden;transition:box-shadow .2s}.detail-card:hover{box-shadow:0 6px 26px #7c5cf61a}.detail-card-header{display:flex;align-items:center;justify-content:space-between;padding:18px 22px;border-bottom:1px solid #f5f3f8}.detail-card-title{display:flex;align-items:center;gap:10px;font-size:16px;font-weight:700;color:#1f1833}.detail-card-title-icon{width:20px;height:20px;color:#8b5cf6}.detail-card-search{width:20px;height:20px;color:#a69fc4;cursor:pointer;transition:color .2s}.detail-card-search:hover{color:#8b5cf6}.detail-card-body{padding:18px 22px;font-size:14px;line-height:1.8;color:#5b5370;min-height:60px}.detail-intro-text{color:#5b5370;line-height:1.8}.detail-items-card{border-bottom:4px solid #8b5cf6}.detail-items-header{display:flex;align-items:center;justify-content:space-between;padding:18px 22px;cursor:pointer;transition:background .2s}.detail-items-header:hover{background:#faf8fc}.detail-items-title{display:flex;align-items:center;gap:10px;font-size:16px;font-weight:700;color:#1f1833}.detail-items-count{font-size:13px;color:#7c7497;font-weight:500;margin-left:4px}.detail-items-toggle{width:22px;height:22px;color:#9d8ec4;transition:transform .25s}.detail-items-toggle.expanded{transform:rotate(180deg)}.detail-items-list{max-height:0;overflow:hidden;transition:max-height .35s ease}.detail-items-list.expanded{max-height:900px}.detail-item{display:flex;align-items:center;gap:12px;padding:14px 22px;border-top:1px solid #f5f3f8;font-size:14px;color:#5b5370;transition:background .15s}.detail-item:hover{background:#faf8fc}.detail-item-num{display:flex;align-items:center;justify-content:center;width:26px;height:26px;background:#f3e8ff;color:#7c3aed;font-size:12px;font-weight:700;border-radius:6px;flex-shrink:0}.detail-item-title{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.detail-item-type{font-size:12px;color:#9d8ec4;padding:3px 10px;background:#faf8fc;border-radius:12px;border:1px solid #ede9f5}.detail-sidebar{display:flex;flex-direction:column;gap:20px}.detail-stats-card{background:#fff;border-radius:16px;border:1px solid #ede9f5;box-shadow:0 4px 18px #7c5cf60f;padding:24px 22px}.detail-stats{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-bottom:20px}.detail-stat{text-align:center;padding:18px 10px;background:#faf8fc;border-radius:12px;border:1px solid #ede9f5}.detail-stat-value{display:block;font-size:30px;font-weight:800;color:#7c3aed;line-height:1.2;margin-bottom:6px}.detail-stat-label{font-size:13px;color:#7c7497;font-weight:500}.detail-actions{padding-top:8px}.detail-action-item{display:flex;align-items:center;justify-content:space-between;padding:14px 0;font-size:14px;color:#5b5370;cursor:pointer;transition:all .2s;border-bottom:1px solid #f5f3f8}.detail-action-item:hover{color:#7c3aed}.detail-action-item:last-child{border-bottom:none}.detail-action-item svg{width:16px;height:16px;color:#9d8ec4;transition:transform .2s}.detail-action-item:hover svg{color:#7c3aed;transform:translate(3px)}.detail-hint{padding:14px;background:#faf8fc;border-radius:10px;font-size:12px;color:#7c7497;line-height:1.6;margin-top:12px;border:1px solid #ede9f5}.detail-btn-primary{display:flex;align-items:center;justify-content:center;width:100%;padding:13px;background:#8b5cf6;color:#fff;font-size:15px;font-weight:600;border:none;border-radius:10px;cursor:pointer;transition:all .2s;margin-bottom:8px;box-shadow:0 4px 14px #8b5cf659}.detail-btn-primary:hover{background:#7c3aed;transform:translateY(-1px);box-shadow:0 6px 20px #8b5cf673}.detail-btn-primary:disabled{background:#c4b5fd;cursor:not-allowed;box-shadow:none;transform:none}@media(max-width:960px){.detail-body{grid-template-columns:1fr}.detail-hero-inner{flex-direction:column;align-items:flex-start}.detail-hero-illustration{display:none}.detail-hero,.detail-body,.detail-meta-bar{padding-left:24px;padding-right:24px}}@media(max-width:600px){.detail-hero-title{font-size:26px}.detail-meta-bar{flex-wrap:wrap;gap:10px}.detail-meta-divider{display:none}.detail-hero,.detail-body,.detail-meta-bar{padding-left:16px;padding-right:16px}}.nav-logout-button,.mobile-logout-button{font:inherit;cursor:pointer}.nav-logout-button{border:0}.mobile-logout-button{width:100%;min-height:44px;padding:0;border:0;background:transparent;color:var(--red);text-align:left}
