:root{--app-text: #20323c;--app-heading: #10231f;--app-muted: #63736f;--app-subtle: #778883;--app-accent: #0f8a7a;--app-accent-strong: #0b6b61;--app-accent-soft: rgba(15, 138, 122, .11);--app-accent-ring: rgba(15, 138, 122, .2);--app-secondary: #2878d7;--app-warm: #d97706;--app-bg: radial-gradient(circle at top left, rgba(15, 138, 122, .1), transparent 28%), radial-gradient(circle at bottom right, rgba(40, 120, 215, .08), transparent 30%), linear-gradient(180deg, #f7fbfa 0%, #edf5f3 100%);--app-shell-bg: rgba(255, 255, 255, .9);--app-panel-bg: rgba(255, 255, 255, .96);--app-card-bg: #ffffff;--app-input-bg: #ffffff;--app-soft-bg: #f2f7f5;--app-hover-bg: #e8f4f1;--app-border: #dce8e4;--app-border-soft: #e8f0ed;--app-shadow: 0 18px 44px rgba(22, 64, 58, .08);--app-primary: linear-gradient(135deg, #0f8a7a, #2878d7);--app-success: linear-gradient(135deg, #168a63, #66a84f);--app-danger-bg: #fff2f0;--app-danger-text: #cb4f42;font-family:PingFang SC,Noto Sans SC,Helvetica Neue,sans-serif;color:var(--app-text);background:var(--app-bg);font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;line-height:1.5;font-weight:400}*{box-sizing:border-box}body{margin:0;min-width:320px;min-height:100vh;color:var(--app-text);background:var(--app-bg)}button,input,textarea,select{font:inherit}button{border:0;cursor:pointer}#app{min-height:100vh}.app-shell{display:grid;grid-template-columns:248px minmax(0,1fr);min-height:100vh}.sidebar-shell{position:sticky;top:0;height:100vh;padding:24px 16px;border-right:1px solid var(--app-border);background:var(--app-shell-bg);-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px);display:flex;flex-direction:column;gap:22px}.brand-block{display:flex;align-items:center;gap:12px;padding:8px 10px 18px;border-bottom:1px solid var(--app-border-soft)}.brand-home-link{color:inherit;text-decoration:none;border-radius:16px;transition:background .2s ease,transform .15s ease}.brand-home-link:hover{background:var(--app-hover-bg);transform:translateY(-1px)}.brand-mark{width:42px;height:42px;border-radius:10px;display:grid;place-items:center;background:var(--app-primary);color:#fff;font-weight:800;font-size:20px}.logo-brand-mark{overflow:hidden;background:#fff;box-shadow:0 10px 24px #111e3b1f}.logo-brand-mark img{width:100%;height:100%;display:block;object-fit:cover}.brand-name{font-size:19px;font-weight:800;color:var(--app-heading);white-space:nowrap}.brand-copy{margin-top:4px;font-size:11px;color:var(--app-subtle);white-space:nowrap}.brand-tagline{max-width:142px;white-space:normal;line-height:1.35}.sidebar-nav{display:grid;gap:8px}.sidebar-link{position:relative;padding:12px 12px 12px 14px;border-radius:10px;background:transparent;text-decoration:none;color:var(--app-text);transition:background .2s ease,transform .15s ease,box-shadow .2s ease,color .2s ease}.sidebar-link:hover{transform:translateY(-1px);background:var(--app-hover-bg)}.sidebar-link.active{background:linear-gradient(135deg,var(--app-accent-soft),rgba(40,120,215,.08));box-shadow:inset 0 0 0 1px #0f8a7a1f;color:var(--app-heading)}.sidebar-link.active:before{content:"";position:absolute;left:0;top:12px;bottom:12px;width:3px;border-radius:999px;background:var(--app-accent)}.sidebar-link-title{font-size:14px;font-weight:700}.main-shell{min-width:0;padding:24px 28px 36px}body.practice-immersive-active{background:var(--app-input-bg);overflow-x:hidden;overflow-y:auto}body.practice-immersive-active .app-shell{grid-template-columns:1fr;background:var(--app-input-bg)}body.practice-immersive-active .sidebar-shell,body.practice-immersive-active .topbar-shell{display:none}body.practice-immersive-active .main-shell{min-height:100vh;padding:0;overflow-y:auto}.topbar-shell{display:flex;justify-content:space-between;align-items:flex-start;gap:16px;margin-bottom:22px;padding:4px 2px 10px}.topbar-eyebrow{margin:0 0 6px;text-transform:uppercase;letter-spacing:.12em;font-size:12px;color:#8e5cff;font-weight:700}.topbar-shell h1{margin:0;font-size:clamp(1.7rem,2.3vw,2.35rem);line-height:1.15;color:var(--app-heading)}.topbar-actions{display:flex;gap:10px;flex-wrap:wrap;align-items:center}.topbar-chip,.badge{display:inline-flex;align-items:center;justify-content:center;min-height:38px;padding:0 14px;border-radius:999px;background:#eef2ff;color:#4d57a3;font-weight:700}.topbar-chip.soft,.badge.soft-badge{background:var(--app-soft-bg);color:var(--app-muted)}.page-stack{display:grid;gap:20px}.page-header-card,.content-panel,.content-section,.panel,.confirm-dialog{background:var(--app-panel-bg);border:1px solid var(--app-border);box-shadow:var(--app-shadow);border-radius:8px}.page-header-card,.content-panel,.content-section,.panel{padding:22px 24px}.page-header-card{display:flex;justify-content:space-between;align-items:center;gap:18px;background:linear-gradient(135deg,rgba(15,138,122,.09),rgba(255,255,255,.82) 34%,rgba(217,119,6,.07)),var(--app-panel-bg)}.page-header-main{display:grid;gap:14px}.page-title-line{display:flex;align-items:center;gap:14px;flex-wrap:wrap;min-width:0}.page-title-line.compact-tabs{margin-bottom:2px}.page-icon{width:42px;height:42px;border-radius:8px;border:1px solid rgba(15,138,122,.18);display:inline-flex;align-items:center;justify-content:center;flex:0 0 auto;background:linear-gradient(135deg,rgba(15,138,122,.14),rgba(217,119,6,.08)),var(--app-input-bg);color:var(--app-accent);box-shadow:0 10px 24px #2c385b14}.page-icon svg{width:22px;height:22px;display:block;fill:none;stroke:currentColor;stroke-width:1.9;stroke-linecap:round;stroke-linejoin:round}.page-title-line h1,.section-head-row h2,.market-section-head h2{margin:0;font-size:22px;line-height:1.2;min-width:0;overflow-wrap:anywhere}.page-header-actions,.practice-actions,.hero-actions,.course-actions-inline,.detail-chips,.toolbar-right,.mode-actions,.audio-row,.typing-toolbar,.stage-summary{display:flex;gap:12px;flex-wrap:wrap;align-items:center}.package-progress-inline{display:flex;align-items:center;gap:10px;color:var(--app-muted);font-weight:700}.mini-progress,.package-progress-bar{height:8px;border-radius:999px;background:#ead9ff;overflow:hidden}.mini-progress{width:92px}.mini-progress span,.package-progress-bar span{display:block;height:100%;background:linear-gradient(90deg,#9d48ff,#b46dff);border-radius:inherit}.upgrade-btn,.notice-action,.primary-btn,.ghost-btn,.filter-btn,.market-tab{min-height:46px;padding:0 18px;border-radius:8px;display:inline-flex;align-items:center;justify-content:center;color:inherit;font-weight:700;line-height:1;text-decoration:none;white-space:nowrap;transition:transform .15s ease,opacity .2s ease,box-shadow .2s ease,background .2s ease}.upgrade-btn,.notice-action,.primary-btn,.market-tab.active,.danger-solid{color:#fff;background:var(--app-primary);box-shadow:0 12px 26px #0f8a7a29}.primary-btn.secondary{background:var(--app-success)}.topbar-login-btn{min-height:40px;padding:0 22px;border-radius:999px;font-size:15px;box-shadow:0 10px 22px #0f8a7a29}.ghost-btn,.filter-btn,.market-tab{background:var(--app-soft-bg);color:var(--app-text);box-shadow:inset 0 0 0 1px var(--app-border-soft)}.danger-btn{background:var(--app-danger-bg);color:var(--app-danger-text)}.theme-toggle-btn{min-height:40px;padding:0 14px 0 10px;border-radius:8px;display:inline-flex;align-items:center;gap:8px;background:var(--app-soft-bg);color:var(--app-text);font-weight:800;box-shadow:inset 0 0 0 1px var(--app-border);transition:transform .15s ease,background .2s ease,box-shadow .2s ease}.theme-toggle-btn:hover{transform:translateY(-1px);background:var(--app-hover-bg)}.theme-toggle-dot{width:28px;height:28px;border-radius:6px;display:inline-grid;place-items:center;color:#fff;background:var(--app-primary);font-size:14px;line-height:1}.primary-btn:hover,.ghost-btn:hover,.filter-btn:hover,.notice-action:hover,.upgrade-btn:hover,.market-tab:hover{transform:translateY(-1px)}.primary-btn:disabled,.ghost-btn:disabled,.filter-btn:disabled,.notice-action:disabled,.upgrade-btn:disabled{opacity:.56;cursor:not-allowed;transform:none}.toolbar-search{display:flex;align-items:center;min-width:260px;width:min(320px,34vw);background:var(--app-input-bg);border:1px solid var(--app-border);border-radius:8px;padding:0 16px;min-height:48px}.toolbar-search.wide-search{width:min(820px,100%)}.centered-toolbar{display:flex;justify-content:center}.toolbar-search input{flex:1;min-width:0;border:0;outline:none;background:transparent;color:var(--app-text);font-size:15px}.toolbar-search-icon{color:#8d97aa}.keycap{min-width:28px;height:28px;border-radius:8px;display:inline-grid;place-items:center;background:var(--app-soft-bg);color:var(--app-muted);font-size:12px;font-weight:700}.notice-strip{display:flex;justify-content:space-between;align-items:center;gap:18px;padding:18px 22px;border:1px solid rgba(15,138,122,.18);background:linear-gradient(135deg,rgba(15,138,122,.08),var(--app-panel-bg));border-radius:8px}.notice-strip strong{font-size:17px;color:var(--app-heading)}.section-head-row{display:flex;justify-content:space-between;gap:18px;align-items:center;flex-wrap:wrap;margin-bottom:18px}.section-head-row p,.market-section-head p,.preview-panel p,.record-card p,.confirm-dialog p,.resume-entry-box p,.resume-box p,.panel-head p,.stage-copy,.mode-head p,.empty-inline,.empty-state,.error-message,.tips,.package-card-body p,.mall-body p{color:#6d7890}.section-head-row p,.market-section-head p,.preview-panel p,.panel-head p,.mode-head p,.package-card-body p,.mall-body p{margin:8px 0 0;line-height:1.8}.studio-grid,.detail-two-columns{display:grid;grid-template-columns:minmax(0,1.05fr) minmax(0,.95fr);gap:18px}.studio-panel,.detail-card-block,.resume-entry-box,.resume-box,.mode-card,.stage-box,.practice-card,.result-box{border:1px solid #e8edf5;border-radius:8px;background:var(--app-card-bg);padding:18px}.field{display:block;margin-bottom:16px}.field span,.select-line span{display:block;margin-bottom:8px;font-size:13px;color:var(--app-muted);font-weight:700}.field input,.field textarea{width:100%;min-height:48px;padding:0 14px;border-radius:8px;border:1px solid var(--app-border);background:var(--app-input-bg);color:var(--app-text);outline:none}.auth-page-shell{min-height:100vh;display:grid;place-items:center;padding:32px 18px;background:linear-gradient(140deg,rgba(255,255,255,.9),rgba(245,248,255,.9)),#f6f8fc}.customer-auth-page{overflow:hidden;background:radial-gradient(circle at 18% 18%,rgba(34,211,238,.22),transparent 26%),radial-gradient(circle at 78% 82%,rgba(129,140,248,.22),transparent 30%),linear-gradient(135deg,#04111f,#071827 48%,#0b1024)}.customer-auth-page:before{content:"";position:fixed;top:0;right:0;bottom:0;left:0;pointer-events:none;background:linear-gradient(rgba(125,211,252,.055) 1px,transparent 1px),linear-gradient(90deg,rgba(125,211,252,.055) 1px,transparent 1px);background-size:46px 46px;animation:authGridDrift 14s linear infinite}.customer-auth-shell{position:relative;width:min(1160px,calc(100vw - 36px));min-height:min(740px,calc(100vh - 64px));display:grid;grid-template-columns:minmax(0,1.12fr) minmax(340px,.88fr);gap:24px;align-items:stretch}.customer-auth-stage,.customer-auth-card{border:1px solid rgba(125,211,252,.22);border-radius:8px;background:rgba(7,20,38,.76);box-shadow:0 30px 90px #00000057;-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px)}.customer-auth-stage{position:relative;overflow:hidden;display:grid;grid-template-rows:auto minmax(320px,1fr) auto;gap:22px;padding:clamp(24px,4vw,44px)}.customer-auth-stage:after{content:"";position:absolute;top:-40%;right:-20%;bottom:-40%;left:-20%;pointer-events:none;background:linear-gradient(115deg,transparent 42%,rgba(125,211,252,.12),transparent 58%);animation:authScan 6s ease-in-out infinite}.customer-auth-stage>*{position:relative;z-index:1}.customer-auth-brand .brand-name,.customer-auth-card-head h2{color:#f8fbff}.customer-auth-brand .brand-copy,.customer-auth-card-head p,.customer-auth-copy p,.customer-auth-card .auth-helper-text{color:#abc4d8}.login-character-scene{position:relative;min-height:340px;width:min(100%,640px);justify-self:center;display:grid;place-items:center;cursor:default}.study-character{position:absolute;display:block;border-radius:26px;background:linear-gradient(135deg,#22d3ee,#7c8df6);box-shadow:0 26px 60px #22d3ee38;animation:authFloat 4.8s ease-in-out infinite}.study-character:before{content:"";position:absolute;inset:14px 18px auto;height:42%;border-radius:22px;background:linear-gradient(180deg,rgba(255,255,255,.3),transparent);pointer-events:none}.study-character:after{content:"";position:absolute;left:50%;bottom:-14px;width:72%;height:18px;border-radius:50%;background:rgba(0,0,0,.24);filter:blur(8px);transform:translate(-50%)}.character-main{width:150px;height:190px;left:20%;top:58px;z-index:2}.character-sub{width:118px;height:138px;right:18%;top:112px;z-index:2;border-radius:48px 48px 24px 24px;background:linear-gradient(135deg,#f9cf5c,#fb923c);animation-delay:-1.2s}.character-sub .character-eye{width:18px;height:16px}.character-sub .character-mouth{width:30px;height:14px;border-bottom-width:4px}.character-sub .character-arm{width:42px;height:13px}.character-eye{position:absolute;top:42%;width:24px;height:20px;border-radius:50%;background:radial-gradient(circle at 64% 32%,#ffffff 0 12%,transparent 13%),#071827;animation:authBlink 5s infinite;box-shadow:0 0 0 5px #ffffff24}.character-eye.left{left:32%}.character-eye.right{right:32%}.character-mouth{position:absolute;left:50%;bottom:22%;width:42px;height:20px;border-bottom:5px solid rgba(7,24,39,.82);border-radius:0 0 999px 999px;transform:translate(-50%)}.character-arm{position:absolute;top:58%;width:58px;height:16px;border-radius:999px;background:rgba(255,255,255,.88);transform-origin:center;animation:authWave 3.8s ease-in-out infinite}.arm-left{left:-30px;transform:rotate(-28deg)}.arm-right{right:-30px;transform:rotate(28deg);animation-delay:-1.4s}.character-main .arm-right{transform-origin:left center}.character-main .arm-left{transform-origin:right center}.login-character-scene:hover .character-main,.customer-auth-shell.auth-animation-active .character-main{animation:authCharacterHello .9s ease-in-out infinite;box-shadow:0 30px 78px #22d3ee5c,0 0 28px #67e8f947}.login-character-scene:hover .character-sub,.customer-auth-shell.auth-animation-active .character-sub{animation:authCharacterPeek 1s ease-in-out infinite;box-shadow:0 26px 68px #fb923c52,0 0 24px #f9cf5c42}.login-character-scene:hover .character-eye,.customer-auth-shell.auth-animation-active .character-eye{animation:none;transform:scale(1.16);background:radial-gradient(circle at 62% 30%,#ffffff 0 15%,transparent 16%),radial-gradient(circle at 50% 52%,#22d3ee 0 26%,transparent 27%),#071827}.login-character-scene:hover .character-mouth,.customer-auth-shell.auth-animation-active .character-mouth{width:48px;height:24px;border-bottom-color:#071827}.login-character-scene:hover .arm-left,.customer-auth-shell.auth-animation-active .arm-left{animation:authHoverWaveLeft .56s ease-in-out infinite}.login-character-scene:hover .arm-right,.customer-auth-shell.auth-animation-active .arm-right{animation:authHoverWaveRight .56s ease-in-out infinite}.login-character-scene:hover .english-card,.customer-auth-shell.auth-animation-active .english-card{border-color:#67e8f994;box-shadow:0 18px 44px #22d3ee38;transform:translateY(-4px)}.login-character-scene:hover .typing-console,.customer-auth-shell.auth-animation-active .typing-console{border-color:#67e8f97a;box-shadow:0 30px 80px #22d3ee2e,0 20px 54px #00000057}.english-card{position:absolute;z-index:4;min-height:38px;display:inline-flex;align-items:center;padding:0 16px;border:1px solid rgba(125,211,252,.24);border-radius:999px;background:rgba(8,22,42,.5);color:#dff7ff;font-weight:900;box-shadow:0 16px 36px #00000024;animation:authFloat 5.6s ease-in-out infinite;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px)}.english-card-one{left:4%;top:46px}.english-card-two{right:6%;top:58px;animation-delay:-1s}.english-card-three{left:56%;top:236px;animation-delay:-2s}.typing-console{position:absolute;z-index:3;left:50%;bottom:26px;width:min(420px,78%);padding:16px;border:1px solid rgba(125,211,252,.24);border-radius:8px;background:rgba(4,15,30,.5);box-shadow:0 28px 70px #0003;transform:translate(-50%);-webkit-backdrop-filter:blur(7px);backdrop-filter:blur(7px)}.typing-console-head{display:flex;gap:6px;margin-bottom:12px}.typing-console-head span{width:9px;height:9px;border-radius:50%;background:#22d3ee}.typing-console p{margin:0;color:#f8fbff;font-weight:900;letter-spacing:.02em}.typing-caret{display:inline-block;width:2px;height:1em;margin-left:4px;background:#67e8f9;vertical-align:-.15em;animation:authCaret 1s steps(2,start) infinite}.learning-bars{height:54px;display:flex;align-items:end;gap:8px;margin-top:14px}.learning-bars span{flex:1;height:var(--bar-height);border-radius:999px 999px 4px 4px;background:linear-gradient(180deg,#67e8f9,#7c8df6);animation:authBars 1.8s ease-in-out infinite}.learning-bars span:nth-child(2n){animation-delay:-.7s}.customer-auth-copy{display:grid;gap:14px;max-width:650px}.customer-auth-copy span,.customer-auth-card-head span{width:fit-content;min-height:30px;display:inline-flex;align-items:center;padding:0 12px;border-radius:999px;background:rgba(34,211,238,.12);color:#8ff0ff;font-size:12px;font-weight:900;letter-spacing:.08em}.customer-auth-copy h1{margin:0;color:#f8fbff;font-size:clamp(1.02rem,1.28vw,1.42rem);line-height:1.18;white-space:nowrap;max-width:100%;overflow:visible}.customer-auth-copy p{margin:0;max-width:580px;line-height:1.9}.customer-auth-card{display:grid;grid-template-rows:auto auto minmax(0,1fr) auto;align-content:stretch;align-self:end;gap:24px;min-height:650px;padding:clamp(22px,3.2vw,34px)}.customer-auth-card-head{display:grid;gap:14px}.customer-auth-card-head h2{margin:0;font-size:clamp(2rem,3.2vw,3.4rem);line-height:1.08}.customer-auth-card-head p{margin:0;line-height:1.8}.customer-google-button{justify-content:flex-start}.customer-login-features{display:flex;gap:8px;flex-wrap:wrap;align-content:flex-start;max-height:360px;overflow:hidden}.customer-login-features span{min-height:30px;display:inline-flex;align-items:center;padding:0 10px;border-radius:999px;background:rgba(125,211,252,.1);color:#bff7ff;font-size:12px;font-weight:900;animation:authTagFloat 4.8s ease-in-out infinite;transform-origin:center}.customer-login-features span:nth-child(3n){animation-delay:-1.2s}.customer-login-features span:nth-child(4n){animation-delay:-2.4s}.customer-login-features span:nth-child(7n){background:rgba(34,211,238,.18);color:#ecfeff;box-shadow:0 0 #22d3ee00;animation-name:authTagFloat,authTagPop;animation-duration:4.8s,5.6s;animation-timing-function:ease-in-out,ease-in-out;animation-iteration-count:infinite,infinite}.customer-login-features span:nth-child(11n){animation-name:authTagFloat,authTagPop;animation-duration:4.8s,6.4s;animation-delay:-1s,-2s;animation-timing-function:ease-in-out,ease-in-out;animation-iteration-count:infinite,infinite}.customer-auth-card .error-message{margin:0}.auth-card{width:min(100%,520px);padding:34px;border:1px solid #e2e8f2;border-radius:28px;background:rgba(255,255,255,.98);box-shadow:0 24px 70px #111e3b1a}.admin-auth-card{width:min(100%,560px)}.auth-brand-block{display:flex;align-items:center;gap:14px}.auth-title-block{margin:34px 0 26px}.auth-title-block h1{margin:0;color:#172033;font-size:30px;line-height:1.18}.auth-title-block p{margin:12px 0 0;color:#66738b;line-height:1.8}.auth-panel{max-width:680px;margin:0 auto}.auth-head{margin-bottom:20px}.auth-tabs,.auth-actions{display:flex;gap:12px;flex-wrap:wrap}.auth-tabs{margin-bottom:18px}.auth-tab-active{background:linear-gradient(135deg,var(--app-accent-soft),rgba(40,120,215,.1));box-shadow:inset 0 0 0 1px #0f8a7a24}.auth-form{display:grid;gap:4px}.auth-google-stack{display:grid;gap:18px}.auth-feature-list{display:grid;gap:10px}.auth-feature-item{padding:14px 16px;border-radius:18px;background:#f7f9ff;border:1px solid #e2e8f5;color:#31415f}.google-button-shell{min-height:48px;display:flex;justify-content:center;align-items:center}.password-login-form{display:grid;gap:14px}.test-login-button{min-height:48px;border-radius:18px;background:#182235;color:#fff;font-weight:800;box-shadow:0 16px 34px #18223529}.test-login-button:disabled{cursor:not-allowed;opacity:.62}.auth-helper-text{margin:0;text-align:center;color:#52627f}.auth-muted-text{font-size:13px;color:#7887a2}@keyframes authGridDrift{0%{background-position:0 0,0 0}to{background-position:46px 46px,46px 46px}}@keyframes authScan{0%,to{transform:translate(-28%);opacity:0}35%,65%{opacity:1}to{transform:translate(28%)}}@keyframes authFloat{0%,to{transform:translateY(0) rotate(-1deg)}50%{transform:translateY(-14px) rotate(1deg)}}@keyframes authBlink{0%,92%,to{transform:scaleY(1)}95%{transform:scaleY(.08)}}@keyframes authWave{0%,to{rotate:0deg}50%{rotate:10deg}}@keyframes authCharacterHello{0%,to{transform:translateY(-6px) rotate(-3deg) scale(1.03)}50%{transform:translateY(-20px) rotate(3deg) scale(1.08)}}@keyframes authCharacterPeek{0%,to{transform:translateY(0) rotate(3deg) scale(1)}40%,62%{transform:translateY(-52px) rotate(-7deg) scale(1.12)}}@keyframes authHoverWaveLeft{0%,to{transform:rotate(-36deg) translateY(0)}50%{transform:rotate(-10deg) translateY(-8px)}}@keyframes authHoverWaveRight{0%,to{transform:rotate(36deg) translateY(0)}50%{transform:rotate(10deg) translateY(-8px)}}@keyframes authCaret{50%{opacity:0}}@keyframes authBars{0%,to{transform:scaleY(.78)}50%{transform:scaleY(1)}}@keyframes authTagFloat{0%,to{transform:translateY(0) rotate(0)}50%{transform:translateY(-3px) rotate(-1deg)}}@keyframes authTagPop{0%,84%,to{scale:1;box-shadow:0 0 #22d3ee00}90%{scale:1.2;box-shadow:0 0 0 1px #67e8f973,0 0 22px #22d3ee6b}}.field input,.field select,.field textarea,.select-line select,.search-row input,.segment-item input{width:100%;border:1px solid #d8dfea;border-radius:18px;background:#fbfcff;color:#1b263b;padding:14px 16px;outline:none;transition:border-color .2s ease,box-shadow .2s ease}.field textarea{min-height:230px;resize:vertical;line-height:1.8}.field input:focus,.field select:focus,.field textarea:focus,.select-line select:focus,.search-row input:focus,.segment-item input:focus{border-color:var(--app-accent);box-shadow:0 0 0 4px var(--app-accent-ring)}.preview-block pre,.detail-card-block pre{margin:0;padding:16px;border-radius:18px;border:1px solid #e7edf8;background:#f8fbff;white-space:pre-wrap;line-height:1.8}.compact-preview-block{margin-bottom:16px}.summary-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px}.summary-grid.compact{max-width:none}.summary-card{background:#f8fbff;border:1px solid #e4ecf6;border-radius:20px;padding:14px 16px}.summary-card span{display:block;margin-bottom:8px;color:#6f7c93;font-size:12px}.summary-card strong{font-size:20px}.profile-hero-card{align-items:center}.profile-hero-main{display:flex;align-items:center;gap:18px;min-width:0}.profile-hero-main p{margin:8px 0 0;color:#69758d;word-break:break-all}.profile-avatar{width:72px;height:72px;border-radius:24px;display:grid;place-items:center;flex:0 0 auto;background:var(--app-primary);color:#fff;font-size:30px;font-weight:800;box-shadow:0 16px 34px #0f8a7a38;overflow:hidden}.profile-avatar img{width:100%;height:100%;display:block;object-fit:cover}.profile-action-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:14px}.profile-action-card{min-height:132px;padding:18px;border:1px solid #e4ebf6;border-radius:20px;background:#fbfcff;color:#26344d;text-decoration:none;display:flex;flex-direction:column;justify-content:space-between;transition:transform .15s ease,box-shadow .2s ease,border-color .2s ease}.profile-action-card:hover{transform:translateY(-1px);border-color:#0f8a7a4d;box-shadow:0 12px 28px #111e3b14}.profile-action-card strong{font-size:18px}.profile-action-card span{color:#6e7b93;line-height:1.7}.package-card-grid,.mall-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:18px}.package-card,.mall-card{position:relative;overflow:hidden;border:1px solid #e7ecf5;border-radius:20px;background:#fff;box-shadow:0 10px 24px #121c330d}.mall-card.dragging,.package-row.dragging,.console-lesson-row.dragging{opacity:.66}.mall-card.drag-over,.package-row.drag-over,.console-lesson-row.drag-over{border-color:#14c4a8a6;box-shadow:0 0 0 2px #14c4a824,0 14px 32px #111e3b14}.package-drag-handle{width:28px;height:28px;border-radius:8px;display:inline-grid;place-items:center;color:var(--app-muted);font-size:17px;font-weight:900;cursor:grab;-webkit-user-select:none;user-select:none}.package-drag-handle:active{cursor:grabbing}.mall-drag-handle{position:absolute;top:10px;left:10px;z-index:3;background:rgba(255,255,255,.88);color:#526079;box-shadow:0 8px 18px #111e3b1f}.package-card.active{box-shadow:0 0 0 2px var(--app-accent-ring),0 12px 30px #121c3314}.package-cover,.mall-cover{min-height:220px;padding:18px;display:flex;flex-direction:column;justify-content:space-between;color:#fff}.package-cover{background:linear-gradient(180deg,rgba(25,31,55,.15),rgba(25,31,55,.68)),linear-gradient(135deg,#82a8ff,#445fd4)}.package-cover.selected{background:linear-gradient(180deg,rgba(25,31,55,.15),rgba(25,31,55,.72)),var(--app-primary)}.package-cover-top{font-size:14px;font-weight:700}.package-cover-title,.mall-cover-title{font-size:clamp(1.8rem,2.6vw,2.6rem);font-weight:800;line-height:1.08}.package-cover-copy{font-size:14px;opacity:.92}.package-card-body,.mall-body{padding:12px 14px 14px}.package-card-body h3,.mall-body h3,.preview-panel h3,.result-box h3,.detail-card-block h3{margin:0;font-size:15px}.package-progress-bar{margin-top:12px}.package-progress-meta,.mall-meta{display:flex;justify-content:space-between;gap:8px;flex-wrap:wrap;margin-top:6px;color:#707b92;font-size:12px}.sentence-list,.result-list,.record-grid,.sentence-mini-list{display:grid;gap:12px}.sentence-mini-list{grid-template-columns:repeat(4,minmax(0,1fr))}.sentence-mini-card,.sentence-card,.result-row-card{border:1px solid #e7edf8;border-radius:18px;background:#fcfdff;padding:16px}.sentence-mini-card p,.sentence-mini-card small,.sentence-body p,.result-row-card p,.result-row-card small{margin:8px 0 0;display:block}.sentence-card{display:grid;grid-template-columns:64px 1fr;gap:14px;align-items:start}.compact-sentence-list .sentence-card{grid-template-columns:52px 1fr}.sentence-index{display:inline-flex;justify-content:center;align-items:center;min-height:36px;padding:0 12px;border-radius:999px;background:#eef2ff;color:#4d57a3;font-weight:700}.path-line{word-break:break-all;color:#5d6880;font-size:13px}.audio-row>div{min-width:220px}audio{width:100%;margin-top:8px}.record-card,.clickable-card,.sentence-detail-card{display:flex;justify-content:space-between;gap:18px;align-items:center}.result-meta{display:grid;gap:8px;justify-items:end;color:#66738b;font-size:13px}.align-start{justify-items:start}.result-chip{display:inline-flex;align-items:center;justify-content:center;min-height:34px;padding:0 12px;border-radius:999px;font-weight:700}.result-chip.ok{background:#e8fbef;color:#139559}.result-chip.pending{background:#fff1ec;color:#d35f38}.market-tabs{display:flex;gap:8px;flex-wrap:wrap}.market-tab{min-height:42px;border-radius:14px;font-weight:700}.market-section-head{display:flex;align-items:center;gap:16px}.section-badge{width:60px;height:60px;border-radius:18px;display:grid;place-items:center;font-size:30px}.section-badge-star{background:linear-gradient(135deg,var(--app-accent),var(--app-warm));color:#fff}.mall-cover{position:relative;overflow:hidden}.mall-cover-image{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;object-fit:cover;z-index:0}.mall-cover>*{position:relative;z-index:1}.mall-badge{align-self:flex-end;display:inline-flex;align-items:center;min-height:0;padding:0;background:transparent;color:#fff;font-weight:700;text-shadow:0 1px 6px rgba(15,23,42,.32)}.theme-sea{background:linear-gradient(135deg,#97c0ff,#6385ff)}.theme-forest{background:linear-gradient(135deg,#3f815b,#154a36)}.theme-rose{background:linear-gradient(135deg,#ffefef,#f4bcbc);color:#24242c}.theme-music{background:linear-gradient(135deg,#d8fbff,#ffe9a9);color:#24313f}.theme-night{background:linear-gradient(135deg,#1c2a40,#0a1224)}.theme-gold{background:linear-gradient(135deg,#fff1d2,#ffd079);color:#2f2d25}.mode-card,.stage-box,.practice-card,.result-box,.resume-box,.resume-entry-box{border:1px solid #e7edf8;background:#fcfdff;border-radius:22px;padding:18px}.mode-card+.mode-card{margin-top:14px}.mode-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px 16px;margin-top:14px}.pre-practice-steps{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:18px;margin-top:18px;padding-top:16px;border-top:1px solid #e7edf8}.mode-step-group{min-width:0}.mode-step-group h4{display:inline-flex;align-items:center;gap:4px;min-height:30px;margin:0;padding:0 12px;border-radius:999px;background:#eef2ff;color:#4d57a3;font-size:15px;font-weight:800}.mode-step-badge{width:18px;height:18px;border:1px solid #1f2a44;border-radius:50%;display:inline-flex;align-items:center;justify-content:center;color:#1f2a44;background:#ffffff;font-size:12px;line-height:1;font-weight:800;flex:0 0 auto}.select-line span .mode-step-badge{display:inline-flex;margin-right:4px;vertical-align:middle}.mode-step-group .mode-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;margin-top:12px}.mode-step-group .checkbox-line{min-height:44px}.checkbox-line{display:flex;align-items:center;gap:10px;min-height:48px;padding:0 14px;border-radius:16px;border:1px solid #e3eaf5;background:#f9fbff;color:#31405b;font-weight:700}.mode-select-line{min-height:44px;padding:0 12px 0 14px;border-radius:16px;border:1px solid #e3eaf5;background:#f9fbff;color:#31405b;display:flex;align-items:center;justify-content:space-between;gap:10px;font-weight:700}.mode-select-line span{display:inline-flex;align-items:center;gap:4px;margin:0;color:inherit;white-space:nowrap}.mode-select-line select{width:auto;min-width:78px;min-height:34px;padding:0 28px 0 10px;border-radius:12px;border:1px solid #dbe4f0;background-color:#fff;color:#26344d;font-weight:800}.checkbox-line,.mode-select-line,.mode-select-line select{transition:border-color .2s ease,background .2s ease,box-shadow .2s ease}.checkbox-line:hover,.mode-select-line:hover{border-color:#0f8a7a52;background:#ffffff}.mode-select-line select:focus{border-color:var(--app-accent);box-shadow:0 0 0 3px var(--app-accent-ring)}.practice-mode-page .mode-panel{padding:0;border:0;border-radius:0;background:transparent;box-shadow:none}.practice-mode-page .panel-head{margin-bottom:28px;padding-bottom:18px;border-bottom:1px solid var(--app-border)}.practice-mode-page .panel-head h2{margin:0;color:var(--app-heading);font-size:28px;line-height:1.2}.practice-mode-page .mode-card{padding:0 0 26px;border:0;border-radius:0;background:transparent;box-shadow:none}.practice-mode-page .mode-card+.mode-card{margin-top:28px;padding-top:28px;border-top:1px solid var(--app-border)}.practice-mode-page .mode-head{display:grid;gap:8px;margin-bottom:18px}.practice-mode-page .mode-head h3{margin:0;color:var(--app-heading);font-size:22px;line-height:1.25}.practice-mode-page .mode-head p{margin:0}.practice-mode-page .pre-practice-steps{margin-top:0;padding-top:0;border-top:0;gap:22px}.practice-mode-page .mode-step-group{min-width:0;padding:0}.practice-mode-page .mode-step-group h4{background:transparent;color:var(--app-heading);padding:0;border-radius:0}.practice-mode-page .mode-step-badge{border-color:var(--app-accent);background:transparent;color:var(--app-accent-strong)}.practice-mode-page .mode-step-group .mode-grid{gap:10px}.practice-mode-page .checkbox-line,.practice-mode-page .mode-select-line{min-height:46px;border-radius:8px;border-color:var(--app-border-soft);background:color-mix(in srgb,var(--app-card-bg) 68%,transparent);box-shadow:none}.practice-mode-page .checkbox-line input{accent-color:var(--app-accent)}.practice-mode-page .mode-select-line select{border-radius:8px;border-color:var(--app-border);background-color:var(--app-input-bg)}.practice-mode-page .typing-repeat-row{display:flex;flex-wrap:wrap;gap:12px}.practice-mode-page .typing-select-line{width:min(420px,100%)}.practice-mode-page .typing-audio-label{margin-bottom:0;font-size:inherit;font-weight:700;line-height:1.2}.practice-mode-page .typing-audio-label-text{display:inline;margin-bottom:0;color:inherit;font-size:inherit;font-weight:inherit;line-height:inherit}.practice-mode-page .mode-actions{margin-top:30px;padding-top:22px;border-top:1px solid var(--app-border)}.typing-select-line{width:min(280px,100%)}.select-line{display:block}.practice-panel.muted{opacity:.96}body.practice-immersive-active .practice-screen-root{min-height:100vh}body.practice-immersive-active .practice-panel{min-height:100vh;margin:0;border:0;border-radius:0;box-shadow:none;background:#ffffff;overflow:visible}.practice-panel-immersive{padding:18px 22px 22px}.practice-toolbar,.toolbar-left{display:flex;justify-content:space-between;gap:12px;align-items:center;flex-wrap:wrap;margin-bottom:18px}.practice-start-content-panel{display:grid;gap:18px;border:1px solid var(--app-border-soft);border-radius:8px;background:var(--app-card-bg);padding:22px;box-shadow:0 14px 30px #0f172a0d}.practice-start-content-head{display:flex;justify-content:space-between;align-items:flex-start;gap:16px;min-width:0}.practice-start-content-head span{display:inline-flex;margin-bottom:8px;color:var(--app-primary);font-size:12px;font-weight:800;letter-spacing:0}.practice-start-content-head h3{margin:0;color:var(--app-heading);font-size:24px;line-height:1.3;overflow-wrap:anywhere}.practice-start-content-list{display:grid;gap:12px;max-height:min(58vh,640px);overflow:auto;padding-right:4px}.practice-start-content-card{min-height:138px;padding:18px 20px;border:1px solid var(--app-border-soft);border-radius:12px;background:var(--app-input-bg)}.practice-start-content-card strong{display:block;color:var(--app-heading);font-size:18px;margin-bottom:14px}.practice-start-content-card p{margin:0;line-height:1.65}.practice-start-content-english{color:var(--app-heading);font-size:18px}.practice-start-content-japanese{margin-top:8px!important;color:var(--app-muted);font-size:15px}.practice-start-action-row{display:flex;justify-content:center;padding-top:2px}.practice-start-enter-btn{min-width:220px;min-height:54px;font-size:16px}.stage-title{font-size:20px;font-weight:700;margin-bottom:8px}.stage-copy,.prompt-empty,.empty-inline,.empty-state,.error-message,.practice-status{line-height:1.8}.prompt-box{min-height:190px;border-radius:26px;border:1px solid #e5ebf5;background:linear-gradient(145deg,#f5f7ff,#ffffff);display:grid;place-items:center;padding:24px;text-align:center}.prompt-main{font-size:clamp(2rem,5vw,4.2rem);font-weight:800;line-height:1.1}.prompt-sub{margin-top:14px;color:#54637c;font-size:20px}.typing-toolbar,.stage-action-panel,.segment-row,.practice-actions{margin-top:18px}.practice-stage-skip-hint{min-height:44px;display:inline-flex;align-items:center;justify-content:center;padding:0 18px;border:1px solid var(--app-border-soft);border-radius:8px;background:var(--app-card-bg);color:var(--app-muted);font-size:14px;font-weight:700;letter-spacing:0;box-shadow:0 8px 20px #0f172a0d}.inline-record-alert{margin:0}.segment-row{display:flex;flex-wrap:wrap;gap:16px;align-items:flex-start}.segment-item{min-width:130px;flex:1 1 130px;text-align:center}.segment-item input{border:0;border-bottom:4px solid #cfd8e7;border-radius:0;background:transparent;padding:10px 8px 12px;text-align:center;font-size:clamp(1.8rem,3.4vw,3rem)}.segment-item.correct input{border-bottom-color:#21a365;color:#21a365}.segment-item.wrong input{border-bottom-color:#e5453a;color:#e5453a}.segment-item small{display:block;margin-top:10px;font-size:13px;font-weight:700;color:#7d8799}.segment-item.correct small{color:#21a365}.segment-item.wrong small{color:#e5453a}.practice-status{margin-top:18px;padding:16px 18px;border-radius:20px;background:#fff4f3;border:1px solid #ffd0cb;color:#d4483d;font-weight:700}.empty-state{padding:24px;border:1px dashed #d7dfeb;border-radius:22px;color:#67768f}.error-message{color:#d4483d;font-weight:700}.overlay-mask{position:fixed;top:0;right:0;bottom:0;left:0;background:rgba(13,22,42,.42);display:grid;place-items:center;padding:18px;z-index:1000}.confirm-dialog{width:min(100%,560px);padding:24px}.confirm-dialog h3{margin:0 0 12px;font-size:24px}.compact-actions{margin-top:0}.top-gap{margin-top:16px}@media (max-width: 1440px){.package-card-grid,.mall-grid{grid-template-columns:repeat(3,minmax(0,1fr))}}@media (max-width: 1180px){.app-shell{grid-template-columns:1fr}.sidebar-shell{border-right:0;border-bottom:1px solid rgba(227,233,243,.96)}.workspace-grid,.studio-grid,.detail-two-columns,.summary-grid,.pre-practice-steps,.mode-grid,.profile-action-grid,.package-card-grid,.mall-grid,.sentence-mini-list{grid-template-columns:1fr 1fr}.workspace-side{grid-column:1 / -1;position:static}.workspace-main .package-card-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}@media (max-width: 860px){.main-shell{padding:16px}.page-header-card,.content-panel,.content-section,.panel{padding:18px}.page-header-card,.notice-strip,.section-head-row,.profile-hero-card,.resume-entry-box,.resume-box,.record-card,.clickable-card,.sentence-detail-card,.practice-toolbar,.toolbar-left,.topbar-shell{flex-direction:column;align-items:stretch}.workspace-grid,.studio-grid,.detail-two-columns,.summary-grid,.pre-practice-steps,.mode-grid,.profile-action-grid,.package-card-grid,.mall-grid,.sentence-mini-list{grid-template-columns:1fr}.toolbar-search,.toolbar-search.wide-search{width:100%;min-width:0}.sentence-card{grid-template-columns:1fr}.segment-item{min-width:100%}.practice-panel-immersive{padding:16px}.practice-minimal-shell{min-height:auto;gap:18px}.practice-minimal-top,.practice-minimal-bottom{display:grid;grid-template-columns:1fr;justify-items:stretch}.practice-minimal-top{border-bottom:0;padding-bottom:0}.practice-minimal-tools{justify-content:flex-start}.practice-minimal-center{gap:24px}.practice-minimal-workbench{width:100%;padding:22px 18px 18px;border-radius:24px}.minimal-segment-row{grid-template-columns:1fr 1fr;gap:16px 14px}.minimal-segment-item{min-width:0;flex:initial}.minimal-next{width:100%;height:44px;border-radius:18px}}.packages-header{align-items:flex-start}.packages-page .content-panel{gap:24px}.workspace-grid{display:grid;grid-template-columns:minmax(0,1.45fr) minmax(360px,.92fr);gap:22px;align-items:start}.workspace-main,.workspace-side{min-width:0}.workspace-side{display:grid;gap:18px;position:sticky;top:22px}.workspace-main .package-card-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.workspace-panel{box-shadow:none}.detail-sidebar-stack{display:grid;gap:16px}.workspace-placeholder{min-height:280px}.workspace-placeholder .empty-state{margin-top:8px}.create-studio{background:linear-gradient(180deg,#fff,#fcfcff)}.package-card{display:flex;flex-direction:column}.package-cover{min-height:260px;position:relative;overflow:hidden}.package-cover:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:radial-gradient(circle at 20% 15%,rgba(255,255,255,.28),transparent 22%),linear-gradient(180deg,rgba(14,18,34,.08),rgba(14,18,34,.74))}.package-cover>*{position:relative;z-index:1}.package-cover-image{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;object-fit:cover;z-index:0}.package-cover-topline{display:flex;justify-content:space-between;gap:10px;align-items:center}.package-cover-tag,.package-cover-chip{display:inline-flex;align-items:center;min-height:34px;padding:0 12px;border-radius:999px;font-size:13px;font-weight:700}.package-cover-tag{background:rgba(255,255,255,.18);color:#fff}.package-cover-chip{background:rgba(255,214,74,.94);color:#26212a}.package-cover-center{display:grid;gap:10px}.package-cover-lesson{font-size:clamp(2.6rem,4vw,4rem);font-weight:900;line-height:1;letter-spacing:.02em}.package-cover-title{font-size:clamp(2rem,2.8vw,2.9rem);font-weight:900;line-height:1.02;text-shadow:0 8px 24px rgba(0,0,0,.28)}.package-cover-copy{font-size:14px;color:#fffffff0}.cover-sea{background:linear-gradient(180deg,rgba(8,24,49,.05),rgba(6,14,32,.72)),linear-gradient(135deg,#93c0ff 0%,#496fe0 52%,#1f315f 100%)}.cover-forest{background:linear-gradient(180deg,rgba(8,24,49,.05),rgba(6,14,32,.72)),linear-gradient(135deg,#6cc59d 0%,#2f7c61 52%,#183d30 100%)}.cover-violet{background:linear-gradient(180deg,rgba(18,16,32,.05),rgba(18,16,32,.76)),linear-gradient(135deg,#7dd3fc 0%,#2878d7 48%,#16345c 100%)}.cover-sunset{background:linear-gradient(180deg,rgba(26,18,18,.05),rgba(26,18,18,.76)),linear-gradient(135deg,#ffb36a 0%,#f0695b 48%,#522337 100%)}.preview-panel.empty-preview{display:grid;place-content:center;min-height:100%}.mall-panel-spacing{gap:26px}.mall-header-card{align-items:flex-start}.underline-tabs{gap:18px}.plain-tab{min-height:40px;padding:0 4px;border-radius:0;background:transparent;box-shadow:none;color:#48556f;border-bottom:3px solid transparent}.plain-tab.active{background:transparent;color:var(--app-heading);border-bottom-color:var(--app-accent);box-shadow:none}.search-with-shortcut{max-width:860px}.mall-hero-banner{display:flex;justify-content:space-between;gap:24px;align-items:center;padding:28px;border:1px solid var(--app-border);border-radius:26px;background:radial-gradient(circle at top right,rgba(15,138,122,.14),transparent 26%),linear-gradient(135deg,rgba(242,247,245,.96),rgba(255,255,255,.98))}.mall-hero-eyebrow{margin:0 0 10px;color:var(--app-accent);font-size:12px;text-transform:uppercase;letter-spacing:.12em;font-weight:700}.mall-hero-banner h2{margin:0;font-size:clamp(1.8rem,2.4vw,2.6rem);line-height:1.15}.mall-hero-banner p{margin:12px 0 0;color:#67748c;line-height:1.8}.mall-hero-stats{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;min-width:260px}.hero-stat-card{padding:18px;border-radius:20px;background:rgba(255,255,255,.92);border:1px solid #ede5fb;text-align:center}.hero-stat-card strong{display:block;font-size:30px;color:#874eff}.hero-stat-card span{display:block;margin-top:8px;color:#6d7890;font-size:13px}.mall-section-block{gap:18px}.featured-grid{grid-template-columns:repeat(auto-fill,minmax(252px,282px));justify-content:start}.featured-card .mall-cover{min-height:327px}.compact-mall-grid{grid-template-columns:repeat(auto-fill,minmax(237px,270px));justify-content:start}.compact-mall-card .compact-cover{min-height:267px}.mall-cover-row{display:flex;justify-content:flex-end;align-items:center;gap:12px}.mall-cover-title.compact-title{font-size:clamp(1.3rem,2vw,2rem)}.compact-body h3{font-size:17px}.theme-sky{background:linear-gradient(135deg,#bde7ff,#74b9ff);color:#213243}@media (max-width: 1480px){.featured-grid,.compact-mall-grid{grid-template-columns:repeat(auto-fill,minmax(237px,270px))}}@media (max-width: 1180px){.mall-hero-banner{flex-direction:column;align-items:stretch}.featured-grid,.compact-mall-grid{grid-template-columns:repeat(auto-fill,minmax(225px,255px))}}@media (max-width: 860px){.featured-grid,.compact-mall-grid{grid-template-columns:repeat(auto-fill,minmax(150px,1fr))}.mall-hero-stats{grid-template-columns:1fr 1fr;min-width:0}}.create-course-panel{gap:0}.formal-create-section{padding:24px}.formal-create-grid{display:grid;grid-template-columns:minmax(0,1.25fr) minmax(340px,.75fr);gap:22px;align-items:start}.formal-create-main,.formal-create-side{min-width:0}.formal-create-side{display:grid;gap:18px}.short-textarea{min-height:132px}.course-textarea{min-height:320px}.lesson-create-page{min-height:calc(100vh - 150px);display:grid;place-items:start center;padding:4px 0 28px}.lesson-create-card{width:min(860px,100%);border-radius:30px;border:1px solid var(--app-border);background:radial-gradient(circle at top right,rgba(15,138,122,.14),transparent 32%),var(--app-panel-bg);box-shadow:var(--app-shadow);padding:34px}.lesson-create-head{display:flex;justify-content:space-between;gap:18px;align-items:flex-start;margin-bottom:28px}.lesson-create-head h1{margin:16px 0 0;color:var(--app-heading);font-size:36px;line-height:1.12}.lesson-create-kicker{display:inline-flex;align-items:center;gap:10px;color:var(--app-muted);font-size:13px;font-weight:800}.lesson-create-kicker .page-icon{width:36px;height:36px;border-radius:12px}.lesson-create-kicker .page-icon svg{width:18px;height:18px}.lesson-create-body{display:grid;gap:22px}.lesson-create-field{margin:0}.lesson-create-field>span,.lesson-mode-section h2,.lesson-audio-section h2{margin:0 0 10px;color:var(--app-heading);font-size:20px;line-height:1.25;font-weight:800}.lesson-create-field input,.lesson-create-field textarea,.lesson-create-field select{width:100%;border-radius:12px;border:1px solid var(--app-border);background:var(--app-input-bg);color:var(--app-text);outline:none}.lesson-create-field input,.lesson-create-field select{min-height:54px;padding:0 16px}.lesson-create-field textarea{padding:16px;resize:vertical}.lesson-create-field textarea.lesson-desc-textarea{min-height:88px}.lesson-create-field textarea.lesson-textarea{min-height:286px}.lesson-mode-section,.lesson-audio-section{display:grid;gap:12px}.lesson-mode-section p,.lesson-create-note{margin:0;color:var(--app-muted);font-size:14px;line-height:1.7;font-weight:700}.lesson-mode-grid{display:grid;grid-template-columns:minmax(0,1fr);gap:16px}.lesson-audio-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:16px}.lesson-mode-card{min-height:126px;padding:20px 22px;border-radius:20px;border:1px solid var(--app-border-soft);background:var(--app-input-bg);color:var(--app-text);display:grid;gap:12px;text-align:left;position:relative;transition:transform .15s ease,border-color .2s ease,background .2s ease,box-shadow .2s ease}.lesson-mode-card:hover{transform:translateY(-1px);border-color:#0f8a7a6b}.lesson-mode-card.selected{background:linear-gradient(135deg,var(--app-accent-soft),rgba(40,120,215,.08));border-color:#0f8a7a94;box-shadow:inset 0 0 0 1px var(--app-accent-ring)}.lesson-mode-card.disabled{opacity:.64}.lesson-mode-card strong{color:var(--app-heading);font-size:16px;line-height:1.3}.lesson-mode-card span{color:var(--app-muted);font-size:15px;line-height:1.65}.lesson-mode-card em{position:absolute;top:14px;right:14px;padding:5px 8px;border-radius:999px;background:var(--app-soft-bg);color:var(--app-muted);font-size:12px;font-style:normal;font-weight:800}.compact-share-field{max-width:360px}.lesson-preview-panel{padding:18px;border-radius:20px;border:1px solid var(--app-border-soft);background:var(--app-card-bg);display:grid;gap:14px}.lesson-preview-head{display:flex;justify-content:space-between;gap:14px;align-items:center}.lesson-preview-head h2{margin:0;color:var(--app-heading);font-size:18px}.lesson-preview-head p{margin:6px 0 0;color:var(--app-muted);font-size:13px}.lesson-preview-panel pre,.lesson-preview-textarea{max-height:260px;margin:0;padding:16px;overflow:auto;border-radius:16px;border:1px solid var(--app-border);background:var(--app-input-bg);color:var(--app-text);white-space:pre-wrap;line-height:1.7}.lesson-preview-textarea{width:100%;min-height:220px;resize:vertical;outline:none}.lesson-preview-textarea:focus{border-color:var(--app-accent);box-shadow:0 0 0 4px var(--app-accent-ring)}.lesson-create-actions{display:flex;justify-content:flex-end;gap:14px;align-items:center;margin-top:32px}.lesson-create-actions .ghost-btn,.lesson-create-actions .primary-btn{min-width:132px}.format-preview-tooltip-btn{position:relative;overflow:visible}.format-preview-tooltip-btn:before,.format-preview-tooltip-btn:after{position:absolute;left:50%;pointer-events:none;opacity:0;transform:translate(-50%,4px);transition:opacity .18s ease,transform .18s ease;transition-delay:0s;z-index:60}.format-preview-tooltip-btn:before{content:attr(data-tooltip);bottom:calc(100% + 16px);width:max-content;max-width:min(420px,calc(100vw - 48px));padding:12px 16px;border-radius:10px;background:rgba(17,24,39,.96);color:#fff;font-size:15px;font-weight:800;line-height:1.55;text-align:left;white-space:normal;box-shadow:0 18px 40px #0f172a42}.format-preview-tooltip-btn:after{content:"";bottom:calc(100% + 8px);width:14px;height:14px;background:rgba(17,24,39,.96);transform:translate(-50%,4px) rotate(45deg)}.format-preview-tooltip-btn:hover:before,.format-preview-tooltip-btn:focus-visible:before,.format-preview-tooltip-btn:hover:after,.format-preview-tooltip-btn:focus-visible:after{opacity:1;transition-delay:.5s}.format-preview-tooltip-btn:hover:before,.format-preview-tooltip-btn:focus-visible:before{transform:translate(-50%)}.format-preview-tooltip-btn:hover:after,.format-preview-tooltip-btn:focus-visible:after{transform:translate(-50%) rotate(45deg)}.lesson-create-submit{color:#fff;background:var(--app-primary)}.cover-input-row{display:grid;grid-template-columns:minmax(0,1fr);gap:12px;align-items:center}.cover-rule-note{display:block;margin-top:8px;color:var(--app-muted);font-size:12px;line-height:1.5}.cover-choice-row{display:grid;grid-template-columns:repeat(3,minmax(0,170px));gap:12px;margin-bottom:12px}.default-cover-choice{position:relative;width:100%;aspect-ratio:16 / 9;padding:0;border:2px solid transparent;border-radius:10px;background:var(--app-input-bg);overflow:hidden;cursor:pointer;color:var(--app-muted);display:grid;place-items:center;font-weight:800}.default-cover-choice img{width:100%;height:100%;object-fit:cover;display:block}.default-cover-choice.selected{border-color:var(--app-primary);box-shadow:0 0 0 3px #0f8a7a24}.upload-cover-choice,.package-cover-choice{width:100%}.hidden-input{display:none}.cover-preview-panel h3{margin:0 0 14px}.cover-preview-box{min-height:250px;border-radius:24px;overflow:hidden;border:1px solid #e5eaf4;background:linear-gradient(135deg,#eef2ff,#f7f9ff 55%,#ffffff)}.cover-preview-box img{width:100%;height:100%;min-height:250px;object-fit:cover;display:block}.cover-placeholder{min-height:250px;padding:24px;display:flex;flex-direction:column;justify-content:flex-end;gap:10px;background:linear-gradient(180deg,rgba(22,28,48,.08),rgba(22,28,48,.78)),var(--app-primary);color:#fff}.cover-placeholder strong{font-size:28px;line-height:1.15}.cover-placeholder em{display:inline-flex;align-items:center;width:fit-content;min-height:30px;padding:0 12px;border-radius:999px;background:rgba(255,255,255,.16);color:#fffffff2;font-style:normal;font-size:13px;font-weight:700}.cover-placeholder span{font-size:14px;color:#ffffffe0}.sentence-mini-list-single{grid-template-columns:1fr}@media (max-width: 1180px){.formal-create-grid{grid-template-columns:1fr}}@media (max-width: 860px){.lesson-create-card{padding:24px 18px;border-radius:22px}.lesson-create-head{flex-direction:column;align-items:stretch}.lesson-create-head h1{font-size:30px}.lesson-mode-grid,.lesson-audio-grid{grid-template-columns:1fr}.lesson-preview-head,.lesson-create-actions{flex-direction:column;align-items:stretch}.lesson-create-actions .ghost-btn,.lesson-create-actions .primary-btn,.compact-share-field{width:100%;max-width:none}.cover-input-row{grid-template-columns:1fr}.formal-create-section{padding:18px}}.full-course-list-section{overflow:hidden}.package-list{display:grid;gap:14px}.package-row{display:grid;grid-template-columns:112px minmax(0,1fr) 160px auto;gap:18px;align-items:center;min-height:118px;padding:16px;border:1px solid var(--app-border-soft);border-radius:12px;background:var(--app-card-bg);cursor:pointer;transition:transform .15s ease,border-color .2s ease,background .2s ease,box-shadow .2s ease}.package-row.draggable-package-row{grid-template-columns:34px 112px minmax(0,1fr) 160px auto}.package-row:hover{transform:translateY(-1px);border-color:#0f8a7a57;box-shadow:0 14px 32px #111e3b14}.package-row-cover{width:112px;aspect-ratio:16 / 9;border-radius:8px;overflow:hidden;background:linear-gradient(180deg,rgba(17,30,59,.12),rgba(17,30,59,.72)),var(--app-primary);display:grid;place-items:center;color:#fff;font-size:30px;font-weight:900}.package-row-cover img{width:100%;height:100%;object-fit:cover;display:block}.package-row-main{min-width:0;display:grid;gap:8px}.package-row-title{display:flex;align-items:center;gap:10px;min-width:0;flex-wrap:wrap}.package-row-title h3{margin:0;color:var(--app-heading);font-size:18px;line-height:1.3}.package-row-main p{margin:0;color:var(--app-muted);line-height:1.6;display:-webkit-box;-webkit-line-clamp:1;-webkit-box-orient:vertical;overflow:hidden}.package-row-meta{display:flex;flex-wrap:wrap;gap:10px 16px;color:var(--app-muted);font-size:13px;font-weight:700}.package-row-progress{display:grid;gap:8px;min-width:0}.package-row-progress strong{color:var(--app-heading);font-size:20px}.package-row-progress small{color:var(--app-muted);font-weight:700}.package-row-actions{display:flex;gap:8px;justify-content:flex-end;flex-wrap:wrap}.package-create-dialog{width:min(900px,calc(100vw - 36px));max-height:calc(100vh - 48px);overflow:auto}.lesson-create-dialog{width:clamp(360px,78vw,1080px);max-width:calc(100vw - 36px);max-height:calc(100vh - 48px);overflow:auto}.package-cover-picker{display:grid;grid-template-columns:minmax(0,1fr);gap:14px;align-items:center}.package-cover-choice{width:100%;aspect-ratio:16 / 9;border-radius:10px;border:1px dashed rgba(15,138,122,.56);background:var(--app-input-bg);color:var(--app-muted);display:grid;place-items:center;overflow:hidden;font-weight:800}.package-cover-choice.selected{border-style:solid}.package-cover-choice img{width:100%;height:100%;object-fit:cover;display:block}.package-cover-picker input[type=text]{width:100%;min-height:48px;padding:0 14px;border-radius:12px;border:1px solid var(--app-border);background:var(--app-input-bg);color:var(--app-text);outline:none}.full-width-card-grid{grid-template-columns:repeat(4,minmax(0,1fr));gap:14px}.image-only-cover{min-height:160px;padding:0;background:#f2f5fa}.plain-cover-image{position:static;display:block;width:100%;height:160px;object-fit:cover}@media (max-width: 1440px){.full-width-card-grid{grid-template-columns:repeat(3,minmax(0,1fr))}}@media (max-width: 1180px){.full-width-card-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}@media (max-width: 860px){.full-width-card-grid{grid-template-columns:1fr}}.full-width-card-grid{grid-template-columns:repeat(5,minmax(0,1fr));gap:12px}.package-card{border-radius:18px}.image-only-cover{min-height:160px}.plain-cover-image{height:160px}.package-cover{min-height:160px;padding:14px}.package-cover-tag,.package-cover-chip{min-height:28px;padding:0 10px;font-size:12px}.package-cover-lesson{font-size:clamp(1.9rem,2.8vw,2.5rem)}.package-cover-title{font-size:clamp(1.2rem,1.9vw,1.8rem)}.package-cover-copy{font-size:12px}.compact-card-body{padding:10px 12px 12px}.compact-card-body h3{font-size:14px;line-height:1.35}.compact-card-body .package-progress-bar{margin-top:10px}.compact-card-body .package-progress-meta{margin-top:6px;font-size:12px}.course-stat-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px;margin-top:12px}.course-stat-item{min-width:0;padding:8px 10px;border:1px solid #edf1f7;border-radius:8px;background:#f8fafc}.course-stat-item strong,.course-stat-item span{display:block;text-align:left}.course-stat-item strong{color:#182238;font-size:16px;line-height:1.3}.course-stat-item span{margin-top:3px;color:#7d8798;font-size:12px;line-height:1.4}.full-course-list-section .ghost-btn.small-btn,.full-course-list-section .primary-btn.small-solid{min-height:32px;padding:0 10px;border-radius:10px;font-size:12px}.full-course-list-section .course-actions-inline{gap:8px}@media (max-width: 1600px){.full-width-card-grid{grid-template-columns:repeat(4,minmax(0,1fr))}}@media (max-width: 1280px){.full-width-card-grid{grid-template-columns:repeat(3,minmax(0,1fr))}}@media (max-width: 980px){.full-width-card-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.package-row{grid-template-columns:96px minmax(0,1fr)}.package-row.draggable-package-row{grid-template-columns:34px 96px minmax(0,1fr)}.package-row-progress,.package-row-actions{grid-column:2 / -1}.package-row-cover{width:96px}}@media (max-width: 720px){.package-row,.package-row.draggable-package-row,.package-cover-picker{grid-template-columns:1fr}.package-row-cover,.package-cover-choice{width:100%}.package-row-progress,.package-row-actions{grid-column:auto}}.practice-minimal{display:grid;gap:22px;padding:18px 6px 6px}.practice-minimal-shell{min-height:calc(100vh - 190px);display:grid;grid-template-rows:auto auto 1fr auto;gap:24px}body.practice-immersive-active .practice-minimal-shell{min-height:100dvh;padding:18px 24px 20px}.practice-minimal-top{display:flex;justify-content:space-between;align-items:flex-start;gap:18px;padding-bottom:16px;border-bottom:1px solid #edf1f7}.practice-minimal-heading{display:grid;gap:12px}.practice-minimal-heading h2{margin:0;font-size:clamp(1.6rem,2.4vw,2.1rem);line-height:1.2;color:#1f2938}.practice-minimal-meta{display:flex;align-items:center;gap:14px;flex-wrap:wrap;color:#8893a6;font-weight:700}.practice-minimal-meta .minimal-timer{color:#5c6880;font-size:1.05rem;font-weight:800}.practice-minimal-meta span{display:inline-flex;align-items:center;min-height:34px;padding:0 12px;border-radius:999px;background:#f5f7fb}.practice-minimal-progress{height:6px;border-radius:999px;background:#edf2f7;overflow:hidden}.practice-minimal-progress span{display:block;height:100%;border-radius:inherit;background:linear-gradient(90deg,#1eb980,#46c99b)}.minimal-timer{font-variant-numeric:tabular-nums}.practice-minimal-tools{display:flex;gap:10px;flex-wrap:wrap;justify-content:flex-end}.practice-minimal-tools-wrap{display:flex;justify-content:flex-end;align-items:center;flex-wrap:wrap;gap:10px;padding-top:52px}.practice-minimal-tools .ghost-btn{min-height:42px;padding:0 16px;border-radius:999px;background:#f8faff;border-color:#e6ebf5}.practice-session-actions{display:inline-flex;align-items:center;gap:8px;padding:6px 8px 6px 12px;border-radius:999px;border:1px solid #e8edf6;background:rgba(248,250,255,.92)}.practice-session-actions-label{color:#7a859b;font-size:12px;font-weight:700;white-space:nowrap}.practice-session-actions .ghost-btn.compact-btn{min-height:34px;padding:0 12px;border-radius:999px;background:#ffffff;border:1px solid #e6ebf5;box-shadow:none}.practice-session-actions .danger-btn{background:#fff4f2}.practice-theme-toggle-btn{width:36px;height:36px;border:1px solid #e6ebf5;border-radius:999px;background:#ffffff;color:#49566b;box-shadow:none;font-size:15px;font-weight:800}.practice-theme-toggle-btn:hover{background:#f8faff;transform:translateY(-1px)}.practice-fullscreen-btn{position:fixed;right:22px;bottom:22px;z-index:60;width:44px;height:42px;padding:0;border:1px solid rgba(30,185,128,.28);border-radius:12px;background:rgba(255,255,255,.94);color:#236553;box-shadow:0 14px 34px #1f293829;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);display:inline-grid;place-items:center}.practice-fullscreen-btn svg{width:21px;height:21px;fill:none;stroke:currentColor;stroke-width:2.2;stroke-linecap:round;stroke-linejoin:round}.practice-fullscreen-btn:hover{transform:translateY(-1px);background:#ffffff}.practice-screen-root:fullscreen{overflow:auto;background:var(--app-bg)}.icon-btn{width:36px;height:36px;border-radius:12px;border:1px solid #e5ebf5;background:#ffffff;color:#49566b;font-weight:700}.practice-minimal-center{display:grid;align-content:center;justify-items:center;gap:clamp(16px,3.2vh,26px);text-align:center;padding:6px 0}.practice-minimal-prompt{min-height:0;max-width:min(1040px,100%);border:0;background:transparent;display:grid;place-items:center;text-align:center;padding:0 12px}.practice-minimal-main{font-size:clamp(1.1rem,1.9vw,2rem);font-weight:800;line-height:1.34;color:#1c2333}.practice-minimal-sub{margin-top:12px;font-size:clamp(.9rem,1.15vw,1.15rem);line-height:1.45;color:#6d7a90}.practice-minimal-empty{color:#7b879b}.practice-minimal-workbench{width:min(1240px,100%);padding:22px 26px 18px;border-radius:32px;border:1px solid #edf1f7;background:linear-gradient(180deg,rgba(248,250,255,.96),rgba(255,255,255,.96));box-shadow:inset 0 1px #fffc}.minimal-segment-row{width:100%;display:flex;flex-wrap:wrap;justify-content:center;gap:24px 18px;align-items:start}.minimal-segment-item{flex:0 0 auto;min-width:0;max-width:none;display:grid;gap:12px;align-items:start;justify-items:center}.minimal-segment-field{display:flex;align-items:flex-end;justify-content:center;gap:0;width:max-content;max-width:none}.minimal-segment-punctuation{font-size:clamp(1.8rem,3.2vw,3rem);line-height:1.15;font-weight:700;color:#1f2a3b;white-space:nowrap}.minimal-segment-item input{width:var(--slot-width, 8ch);min-width:var(--slot-width, 8ch);max-width:none;border:0;border-bottom:4px solid #cfd8e7;border-radius:0;background:transparent;padding:4px 8px 14px;text-align:center;font-size:clamp(1.8rem,3.4vw,3rem);line-height:1.15;color:#1f2a3b}.minimal-segment-item input:focus{box-shadow:none;border-bottom-color:var(--app-accent)}.practice-input-frame-green .minimal-segment-item input:focus,.practice-input-frame-pink .minimal-segment-item input:focus,.practice-input-frame-yellow .minimal-segment-item input:focus{border-radius:14px;outline:3px solid var(--typing-focus-frame);outline-offset:5px;background:var(--typing-focus-fill);box-shadow:0 8px 20px var(--typing-focus-shadow)}.practice-input-frame-green{--typing-focus-frame: rgba(119, 206, 184, .42);--typing-focus-fill: rgba(236, 253, 248, .56);--typing-focus-shadow: rgba(45, 151, 129, .1)}.practice-input-frame-pink{--typing-focus-frame: rgba(244, 174, 199, .46);--typing-focus-fill: rgba(255, 244, 249, .64);--typing-focus-shadow: rgba(201, 92, 132, .1)}.practice-input-frame-yellow{--typing-focus-frame: rgba(237, 204, 104, .48);--typing-focus-fill: rgba(255, 251, 226, .66);--typing-focus-shadow: rgba(177, 133, 28, .1)}.minimal-segment-item small{margin:0}.minimal-segment-line{width:100%;height:0;border-bottom:3px solid #cfd8e7}.segment-status{min-height:34px;display:inline-flex;align-items:center;justify-content:center;justify-self:center;max-width:100%;padding:0 12px;border-radius:999px;font-size:12px;font-weight:700;letter-spacing:.01em;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.segment-status-correct{background:rgba(33,163,101,.12);color:#1f9c61}.segment-status-wrong{background:rgba(229,69,58,.1);color:#e14d42}.practice-minimal-actions,.practice-minimal-nav{display:flex;flex-wrap:wrap;gap:12px;justify-content:center}.practice-minimal-nav{margin-top:8px}.practice-minimal-bottom{display:grid;grid-template-columns:1fr;align-items:center;justify-items:center;gap:14px}.practice-minimal-bottom-main{display:grid;gap:16px;justify-items:center;width:100%}.practice-minimal-control-row{display:flex;align-items:center;justify-content:center;gap:10px;flex-wrap:wrap;width:min(100%,1120px)}.practice-minimal-control-btn{min-height:44px;padding:0 14px;border-radius:999px;white-space:nowrap}.control-shortcut{display:inline-flex;align-items:center;justify-content:center;min-height:22px;margin-right:8px;padding:0 8px;border-radius:999px;background:rgba(15,138,122,.1);color:var(--app-primary);font-size:12px;font-weight:900}.practice-minimal-status{margin:0;max-width:860px;padding:14px 18px;border-radius:18px;background:#f7f9fd;border:1px solid #e6ebf5;color:#5f6c82;line-height:1.75;text-align:center}.directory-complete-feedback{margin-top:18px;padding:18px 20px;border-radius:20px;border:1px solid #dfe9f6;background:linear-gradient(180deg,#f7fbff,#fbfcff);display:grid;gap:12px}.directory-complete-feedback strong{font-size:17px;color:#1f2b41}.directory-complete-feedback p{margin:0;color:#6f7c93;line-height:1.7}.practice-minimal-error{margin:0;padding:14px 18px;border-radius:18px;background:#fff3f1;border:1px solid #ffd6d0}.shortcut-row{display:flex;align-items:center;gap:8px;flex-wrap:wrap;color:#8a94a6;font-size:12px}.keycap{display:inline-flex;align-items:center;justify-content:center;min-width:28px;height:24px;padding:0 8px;border-radius:8px;border:1px solid #d9e2ef;background:#f7f9fc;color:#5b667a;font-weight:700}.shortcut-label{margin-right:12px}.minimal-next{width:52px;height:52px;border-radius:50%;border:0;background:#ffffff;box-shadow:0 12px 24px #161e3c1f;font-size:30px;color:#4d57a3}.minimal-next:disabled{opacity:.35;cursor:not-allowed;box-shadow:none}.practice-minimal-start{display:grid;gap:16px;padding:24px;border:1px dashed #dfe6f4;border-radius:18px;background:#f8faff;color:#5a6780}.practice-minimal-start .primary-btn{width:fit-content}@media (max-width: 640px){.practice-minimal-meta span,.practice-minimal-tools .ghost-btn{width:100%;justify-content:center}.practice-minimal-tools-wrap,.practice-session-actions{width:100%}.practice-session-actions{justify-content:center;flex-wrap:wrap;border-radius:20px}.minimal-segment-row{gap:18px 12px}.practice-minimal-main{font-size:clamp(1.6rem,7.2vw,2.6rem)}.practice-minimal-sub{font-size:1.05rem}.minimal-segment-item input{font-size:clamp(1.7rem,8vw,2.4rem);min-width:var(--slot-width, 8ch)}.minimal-segment-punctuation{font-size:clamp(1.7rem,8vw,2.4rem)}}.course-type-page{gap:14px}.course-type-panel{display:grid;gap:18px;padding:26px 30px 30px}.type-admin-head{display:flex;align-items:center;justify-content:space-between;gap:18px;padding-bottom:20px;border-bottom:1px solid #edf2f8}.type-admin-head h2{margin:0;font-size:24px;line-height:1.2}.type-admin-head p{margin:6px 0 0;color:#77839a;font-size:14px}.type-toolbar-card{display:grid;grid-template-columns:minmax(260px,1fr) minmax(180px,240px) auto auto;gap:12px;align-items:end;padding:14px;border:1px solid #e4ebf6;border-radius:16px;background:linear-gradient(180deg,#fbfdff,#f7faff);box-shadow:inset 0 1px #fffc}.type-inline-field{margin:0}.type-inline-feedback{display:flex;gap:10px;flex-wrap:wrap}.success-message{margin:0;padding:9px 12px;border-radius:12px;border:1px solid #ccefdc;background:#f1fff7;color:#16814c;font-weight:600;font-size:13px}.type-list-card{display:grid;gap:16px;padding-top:4px}.type-list-header{display:flex;justify-content:space-between;align-items:center;gap:16px;flex-wrap:wrap}.type-list-header h2{margin:0;font-size:21px}.type-list-header p{margin:6px 0 0;color:#7c879c;font-size:13px}.type-list-summary{display:flex;gap:10px;flex-wrap:wrap}.type-empty-state{min-height:180px;border:1px dashed #dce4f2;border-radius:22px;background:#f8fbff;display:grid;place-items:center;color:#7d8aa2;text-align:center;padding:24px}.type-tree-list{display:grid;gap:14px}.type-tree-group{display:grid;gap:8px;position:relative}.type-tree-row{display:grid;grid-template-columns:minmax(0,1fr) 104px auto;gap:10px;align-items:center;min-height:56px;padding:11px 12px 11px 14px;border:1px solid #e6edf8;background:#fff;transition:border-color .18s ease,box-shadow .18s ease,transform .18s ease,background .18s ease}.type-tree-row:hover{border-color:#d8e2f0;box-shadow:0 10px 22px #15223e0d;transform:translateY(-1px)}.type-tree-row.dragging{opacity:.58;border-style:dashed}.type-tree-row.drop-before{box-shadow:inset 0 3px #4f8cff}.type-tree-row.drop-after{box-shadow:inset 0 -3px #4f8cff}.type-tree-row .compact-btn{position:relative;z-index:1;cursor:pointer}.type-tree-row.root{border-radius:16px;background:linear-gradient(180deg,#fbfdff,#f7faff);border-left:4px solid #8a5cff}.type-tree-row.child{margin-left:42px;border-radius:14px;background:#fff;position:relative}.type-tree-row.child:before{content:"";position:absolute;left:-28px;top:50%;width:24px;height:1px;background:#cdd8e8}.type-tree-title{display:flex;align-items:center;gap:10px;min-width:0;flex-wrap:wrap}.type-tree-title strong{color:#192337;font-size:16px}.type-tree-title span{color:#7b879b;font-size:12px;font-weight:700}.type-drag-handle{width:30px;height:30px;border:1px solid #dce5f2;border-radius:10px;background:#fff;color:#738199;cursor:grab;font-weight:800;line-height:1}.type-drag-handle:disabled{cursor:not-allowed;opacity:.5}.type-drag-handle:active{cursor:grabbing}.type-fixed-copy{display:inline-flex;align-items:center;min-height:24px;padding:0 8px;border-radius:999px;background:#eef3fb;color:#6f7b91;font-size:12px;font-weight:700}.type-sort-inline{display:inline-flex;align-items:center;gap:6px;min-height:30px;padding:0 8px;border-radius:999px;background:#eef3fb;color:#6f7b91;font-size:12px;font-weight:700}.type-sort-inline input{width:68px;height:24px;border:1px solid #d8e2f0;border-radius:8px;background:#fff;color:#263247;font-size:13px;font-weight:700;text-align:center}.type-fixed-copy{background:rgba(245,171,53,.14);color:#9b6512}.type-level-badge{display:inline-flex;align-items:center;justify-content:center;min-height:26px;padding:0 9px;border-radius:999px;background:rgba(138,92,255,.12);color:#6f48d9;font-size:12px;font-weight:800}.type-level-badge.secondary{background:rgba(23,143,102,.1);color:#197653}.type-list-table{display:grid;gap:12px}.type-list-row{display:grid;grid-template-columns:minmax(240px,1fr) 120px minmax(260px,auto);gap:14px;align-items:center}.admin-user-row{grid-template-columns:minmax(260px,1.2fr) minmax(180px,.9fr) 140px minmax(280px,auto)}.admin-course-row{grid-template-columns:minmax(280px,1.2fr) minmax(240px,1fr) minmax(160px,.7fr) minmax(280px,auto)}.admin-course-meta{display:grid;gap:8px}.admin-course-status-stack{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.type-list-row-head{padding:0 18px 8px;color:#7c879c;font-size:13px;font-weight:700}.type-list-row-body{padding:18px;border-radius:20px;border:1px solid #e5ebf5;background:#fbfcff}.type-main-cell{display:grid;gap:8px}.type-name-text{font-size:17px;font-weight:700;color:#1f2a3b}.type-reference-copy{color:#7a889f;font-size:13px}.type-status-pill{display:inline-flex;align-items:center;justify-content:center;min-height:32px;padding:0 12px;border-radius:999px;background:rgba(22,184,129,.12);color:#17754d;font-weight:700}.type-status-pill.inactive{background:rgba(124,136,162,.14);color:#66748d}.type-action-group{display:flex;justify-content:flex-start;gap:10px;flex-wrap:wrap}.compact-btn{min-height:32px;padding:0 12px;border-radius:12px}.danger-btn{color:#cf443a}.danger-btn:hover{background:#fff2f0}.type-edit-dialog{display:grid;gap:18px}.type-edit-status-row{display:grid;gap:8px}.type-status-field{max-width:220px}.type-edit-actions{display:flex;justify-content:flex-end;gap:12px;flex-wrap:wrap}@media (max-width: 980px){.type-toolbar-card{grid-template-columns:1fr}.type-admin-head{align-items:flex-start;flex-direction:column}}@media (max-width: 820px){.type-tree-row{grid-template-columns:1fr}.type-tree-row.child{margin-left:14px}.type-list-row{grid-template-columns:1fr;gap:10px 14px}.admin-user-row,.admin-course-row{grid-template-columns:1fr}.type-list-row-head{display:none}.type-list-row-body{padding:16px}.type-main-cell{grid-column:1 / -1}.type-edit-actions .ghost-btn,.type-edit-actions .primary-btn{width:100%;justify-content:center}}.directory-hero-grid{display:grid;grid-template-columns:minmax(180px,240px) minmax(0,1fr);gap:24px;align-items:start}.directory-hero-cover{min-height:140px;max-height:180px;aspect-ratio:4 / 3;border-radius:24px;overflow:hidden;border:1px solid #e4e9f2;background:linear-gradient(135deg,#7f5cff,#2e8ccf)}.directory-cover-image{width:100%;height:100%;object-fit:cover;display:block}.directory-cover-fallback{height:100%;padding:22px;display:grid;align-content:end;gap:8px;color:#fff}.directory-cover-fallback strong{font-size:24px;line-height:1.1}.directory-cover-fallback span{opacity:.88}.directory-hero-info{display:grid;align-content:start;gap:16px}.directory-progress-panel{padding:18px 20px;border-radius:20px;border:1px solid #e6ebf4;background:#fbfcff;display:grid;gap:10px}.directory-progress-head{display:flex;justify-content:space-between;gap:12px;align-items:center;flex-wrap:wrap}.directory-progress-head strong{font-size:17px}.directory-progress-head span,.directory-progress-panel small{color:#7a859b}.directory-progress-foot{display:flex;justify-content:space-between;align-items:center;gap:12px;flex-wrap:wrap}.detail-inline-note{display:inline-flex;align-items:center;min-height:34px;padding:0 12px;margin-top:10px;border-radius:999px;background:#f3f6fb;color:#61718d;font-size:13px;font-weight:700}.detail-inline-note.success-note{background:#eafaf2;color:#17815a}.directory-lessons-head h2{font-size:18px}.directory-lessons-head p{margin-top:6px;font-size:14px;line-height:1.6}.dialog-note{margin:6px 0 0;color:#7a859b;font-size:13px;line-height:1.6}.directory-lesson-list{display:grid;gap:14px}.directory-lesson-card{padding:20px 22px;border-radius:22px;border:1px solid #e5ebf5;background:#fbfcff;display:flex;justify-content:space-between;align-items:center;gap:18px;transition:transform .18s ease,box-shadow .18s ease,border-color .18s ease,background .18s ease}.directory-lesson-card.selected{border-color:#0f8a7a6b;box-shadow:0 16px 32px #0f8a7a14}.directory-lesson-card:hover{transform:translateY(-1px);box-shadow:0 12px 28px #111e3b0f}.directory-lesson-card.dragging{opacity:.72;transform:scale(.99)}.directory-lesson-card.drop-target{border-color:#0f8a7a7a;background:linear-gradient(135deg,var(--app-accent-soft),rgba(40,120,215,.05));box-shadow:0 16px 36px #0f8a7a1f}.directory-lesson-main{min-width:0;display:grid;align-content:start;gap:10px;max-width:360px}.directory-lesson-topline{display:flex;align-items:center;gap:10px;flex-wrap:wrap}.directory-lesson-card strong{display:block;font-size:16px;margin:0}.lesson-order-chip{min-width:42px;height:42px;border-radius:14px;display:inline-flex;align-items:center;justify-content:center;background:#f2f4f8;color:#7c8597;font-size:13px;font-weight:800}.lesson-status-pill{margin-left:auto;min-height:32px;padding:0 12px;border-radius:999px;display:inline-flex;align-items:center;justify-content:center;font-size:13px;font-weight:700}.lesson-status-pill.completed{background:#e7faf1;color:#179666}.lesson-status-pill.in-progress{background:#f3ecff;color:#8f5cff}.lesson-status-pill.abandoned{background:#fff4ea;color:#d4751f}.lesson-status-pill.not-started{background:#eff3f9;color:#74819a}.directory-lesson-card p{color:#6e7890}.directory-lesson-heading{display:flex;align-items:baseline;gap:14px;flex-wrap:wrap}.directory-lesson-progress-row{display:flex;align-items:center;justify-content:space-between;gap:12px;color:#7a859b;font-size:13px}.directory-lesson-progress-bar{height:7px;border-radius:999px;background:#edf1f7;overflow:hidden}.directory-lesson-progress-bar span{display:block;height:100%;border-radius:inherit;background:linear-gradient(90deg,#9d48ff,#b46dff)}.course-pagination{margin-top:18px;display:flex;align-items:center;justify-content:center;gap:14px;color:#6c7891;font-size:14px}.advanced-pagination{flex-direction:column}.pagination-summary{display:flex;align-items:center;justify-content:center;gap:14px;flex-wrap:wrap}.pagination-controls{display:flex;align-items:center;justify-content:center;gap:8px;flex-wrap:wrap}.page-number-btn{min-width:40px}.page-number-btn.active{background:#8f5cff;border-color:#8f5cff;color:#fff}.page-number-btn.ellipsis{pointer-events:none;opacity:.7}.admin-pagination{justify-content:space-between;margin-top:16px;padding:14px 16px;border:1px solid #e2e8f2;border-radius:18px;background:#ffffff;box-shadow:0 12px 28px #111e3b0d}.pagination-size-select{display:inline-flex;align-items:center;gap:8px;color:#6c7891;font-weight:700}.pagination-size-select select{min-height:36px;padding:0 10px;border:1px solid #d7e0ed;border-radius:12px;background:#f8fafd;color:#1c2940;outline:none}.pagination-page-indicator{min-height:36px;padding:0 12px;border-radius:12px;display:inline-flex;align-items:center;background:#f2f5fa;color:#4b5870;font-weight:800}.directory-lesson-card .directory-lesson-title{margin:0;color:#2f3c57;font-size:22px;font-weight:800;line-height:1.2}.directory-lesson-card small{color:#8490a6;font-size:14px}.directory-lesson-meta{display:inline-flex;align-items:center;gap:10px;min-width:0;flex-wrap:wrap}.directory-lesson-copy{display:inline-block;overflow:hidden;max-width:180px;white-space:nowrap;text-overflow:ellipsis;color:#7a859b;font-size:13px;line-height:1.55}.directory-lesson-card .course-actions-inline{justify-content:flex-end}.share-inline-select{min-width:146px;min-height:38px;padding:0 12px;border-radius:12px;border:1px solid #dbe4f0;background:#fff;color:#31415d}.share-inline-select:disabled{background:#f4f7fb;color:#9aa6bb}.share-expire-control{display:inline-flex;align-items:center;gap:8px;min-height:38px;padding:0 10px;border:1px solid #dbe4f0;border-radius:12px;background:#fff;color:#6c7890;font-size:13px;font-weight:700}.share-expire-control input{width:176px;border:0;outline:none;background:transparent;color:#31415d;font:inherit}.share-expire-control input:disabled{color:#9aa6bb}.batch-toolbar{margin-bottom:14px;padding:14px 16px;border-radius:18px;border:1px solid #e5ebf5;background:#fbfcff;display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap}.directory-completion-card{padding:18px 20px;border-radius:20px;border:1px solid #dfe9f6;background:linear-gradient(180deg,#f7fbff,#fbfcff);display:grid;gap:12px}.course-package-workbench{display:grid;grid-template-columns:minmax(220px,280px) minmax(0,1fr);gap:14px;align-items:start;min-width:0}.package-side-card,.package-lessons-panel{border:1px solid var(--app-border);background:var(--app-panel-bg);box-shadow:var(--app-shadow)}.package-side-card{border-radius:14px;padding:18px;display:grid;gap:16px;position:sticky;top:18px;min-width:0}.package-side-cover{width:100%;aspect-ratio:16 / 9;overflow:hidden;border-radius:8px;background:linear-gradient(180deg,rgba(15,25,43,.08),rgba(15,25,43,.72)),var(--app-primary)}.package-side-cover img{width:100%;height:100%;object-fit:cover;display:block}.package-side-title{display:grid;gap:8px}.package-side-title h2{margin:0;color:#d774ff;font-size:23px;line-height:1.15;overflow-wrap:anywhere}.package-side-title p{margin:0;color:var(--app-muted);line-height:1.7}.package-side-meta{margin:0;padding:14px;border:1px solid var(--app-border-soft);border-radius:10px;background:rgba(255,255,255,.03);display:grid;gap:14px}.package-side-meta div{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:12px;align-items:center}.package-side-meta dt,.package-side-meta dd{margin:0}.package-side-meta dt{color:var(--app-muted);font-weight:800}.package-side-meta dd{color:var(--app-heading);font-weight:800}.package-side-actions{display:grid;grid-template-columns:1fr 1fr;gap:10px}.package-lessons-panel{border-radius:14px;overflow:hidden;min-height:640px}.app-shell:not(.admin-app-shell) .package-lessons-panel{border:0;border-radius:0;background:transparent;box-shadow:none;overflow:visible}.package-lessons-toolbar{display:grid;grid-template-columns:minmax(0,1fr) minmax(280px,480px);justify-content:space-between;gap:12px;align-items:center;padding:18px 22px;border-bottom:1px solid var(--app-border);background:var(--app-card-bg)}.app-shell:not(.admin-app-shell) .package-lessons-toolbar{border:1px solid var(--app-border-soft);border-radius:8px;background:color-mix(in srgb,var(--app-card-bg) 82%,transparent)}.package-lessons-toolbar .toolbar-left,.package-lessons-toolbar .toolbar-right{display:flex;gap:10px;align-items:center;flex-wrap:nowrap;min-width:0}.package-lessons-toolbar .toolbar-right{display:grid;grid-template-columns:minmax(220px,1fr) auto;justify-self:end;width:min(100%,480px);align-items:center}.package-lessons-toolbar .ghost-btn,.package-lessons-toolbar .primary-btn{min-height:42px;padding:0 12px;border-radius:10px;white-space:nowrap}.segmented-filter{display:inline-flex;gap:6px;padding:5px;border-radius:8px;background:var(--app-soft-bg);min-width:0}.segmented-filter button{min-height:36px;padding:0 10px;border-radius:7px;background:transparent;color:var(--app-muted);font-weight:800}.segmented-filter button.active{color:#fff;background:var(--app-primary)}.compact-search{min-width:0;width:100%;min-height:44px;border-radius:8px;padding:0 14px}.console-lesson-list{display:grid;gap:14px;padding:18px;max-height:calc(100vh - 250px);overflow:auto}.console-lesson-row{display:grid;grid-template-columns:34px minmax(0,1fr) auto;gap:18px;align-items:center;min-height:116px;padding:20px 22px;border:1px solid var(--app-border-soft);border-radius:12px;background:var(--app-card-bg);transition:transform .16s ease,border-color .2s ease,background .2s ease,box-shadow .2s ease}.console-lesson-row:hover{transform:translateY(-1px);border-color:#0f8a7a57;box-shadow:0 14px 32px #111e3b14}.console-lesson-row.selected{border-color:#0f8a7a85;background:linear-gradient(135deg,var(--app-accent-soft),rgba(40,120,215,.05))}.lesson-drag-handle{color:var(--app-muted);font-size:18px;font-weight:900}.console-lesson-main{min-width:0;display:grid;gap:8px}.console-lesson-title-line{display:flex;align-items:center;gap:10px;flex-wrap:wrap}.console-lesson-title-line strong{color:var(--app-heading);font-size:20px;line-height:1.25}.console-lesson-main p{margin:0;color:var(--app-muted);font-size:15px;line-height:1.55}.console-lesson-meta{display:flex;flex-wrap:wrap;gap:10px 18px;color:var(--app-muted);font-size:13px;font-weight:800}.console-lesson-actions{display:flex;align-items:center;justify-content:flex-end;gap:10px}.console-practice-btn{min-height:42px;min-width:86px;padding:0 14px;border-radius:10px;white-space:nowrap}.console-edit-btn{min-height:42px;min-width:62px;padding:0 14px;border-radius:10px;white-space:nowrap}.console-view-btn{min-height:42px;min-width:78px;padding:0 14px;border-radius:10px;white-space:nowrap}.lesson-content-dialog{width:min(980px,calc(100vw - 36px));max-height:calc(100vh - 48px);overflow:auto}.lesson-content-head{display:flex;justify-content:space-between;align-items:flex-start;gap:16px;margin-bottom:16px;min-width:0}.lesson-content-head h3{margin:0;overflow-wrap:anywhere}.lesson-content-head p{margin:8px 0 0}.lesson-content-list{display:grid;gap:12px}.lesson-content-card{min-height:138px;padding:18px 20px;border:1px solid var(--app-border-soft);border-radius:12px;background:var(--app-input-bg)}.lesson-content-card strong{display:block;color:var(--app-heading);font-size:18px;margin-bottom:14px}.lesson-content-card p{margin:0;line-height:1.65}.lesson-content-english{color:var(--app-heading);font-size:18px}.lesson-content-japanese{margin-top:8px!important;color:var(--app-muted);font-size:15px}.console-delete-btn{min-width:42px;min-height:42px;border-radius:10px;background:transparent;color:#ff6b6b;font-size:0}.console-delete-btn:before{content:"⌫";font-size:22px;line-height:1}.console-delete-btn:hover{background:rgba(239,68,68,.12)}.directory-completion-card strong{font-size:16px;color:#21314b}.directory-completion-card p{margin:0;color:#6f7c93;line-height:1.65}.lesson-select-chip{min-width:58px;min-height:34px;border-radius:12px;background:#f2f4f8;color:#5d6880;font-size:12px;font-weight:700}.course-status-pill{min-height:26px;padding:0 10px;border-radius:999px;display:inline-flex;align-items:center;justify-content:center;font-size:12px;font-weight:700}.course-status-pill.completed{background:#e7faf1;color:#179666}.course-status-pill.in-progress{background:#f3ecff;color:#8f5cff}.course-status-pill.abandoned{background:#fff4ea;color:#d4751f}.course-status-pill.not-started{background:#eff3f9;color:#74819a}.compact-progress-bar{margin-top:8px;height:7px}.compact-progress-note{margin-top:6px}.course-filter-row{display:flex;align-items:flex-end;gap:12px;flex-wrap:wrap}.admin-app-shell{background:#f3f6fb}.admin-app-shell .main-shell{padding:24px 28px 36px}.admin-app-shell .topbar-shell{margin-bottom:18px;padding:16px 18px;border:1px solid #e1e7f0;border-radius:18px;background:rgba(255,255,255,.92);box-shadow:0 14px 36px #111e3b0f}.admin-app-shell .topbar-shell h1{font-size:30px;color:#172033}.admin-app-shell .topbar-chip.soft{background:#edf3ff;color:#415274}.admin-course-page{gap:16px}.admin-console-section{padding:0;border:0;border-radius:0;background:transparent;box-shadow:none}.admin-console-hero{display:grid;grid-template-columns:minmax(260px,.9fr) minmax(420px,1.1fr);gap:10px;align-items:center;margin-bottom:10px}.admin-console-title,.admin-filter-panel,.admin-stat-card,.admin-course-table .type-list-row:not(.type-list-row-head),.admin-folder-group{border:1px solid #e2e8f2;background:#ffffff;box-shadow:0 14px 34px #111e3b0d}.admin-console-title{min-height:76px;padding:14px 16px;border-radius:16px;display:grid;align-content:center}.admin-console-kicker{width:fit-content;min-height:28px;padding:0 10px;border-radius:999px;display:inline-flex;align-items:center;background:#e9f7f2;color:#167c5b;font-size:12px;font-weight:800}.admin-console-title h2{margin:0;color:#172033;font-size:21px;line-height:1.2}.admin-console-title p{margin:5px 0 0;color:#627089;font-size:13px;line-height:1.5}.admin-stat-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:10px}.admin-stat-grid.single{grid-template-columns:minmax(150px,190px);justify-content:end}.admin-stat-card{min-height:76px;padding:12px 14px;border-radius:16px;display:flex;flex-direction:column;justify-content:center;gap:7px;position:relative;overflow:hidden}.admin-stat-card:before{content:"";position:absolute;left:14px;top:10px;width:34px;height:3px;border-radius:999px;background:#3d7cff}.admin-stat-card:nth-child(2):before{background:#18a66d}.admin-stat-card:nth-child(3):before{background:#7b61ff}.admin-stat-card.warning:before{background:#e0604d}.admin-stat-card span{margin-top:6px;color:#64728a;font-size:12px;font-weight:700}.admin-stat-card strong{color:#172033;font-size:24px;line-height:1}.admin-filter-panel{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:16px;align-items:end;margin-bottom:16px;padding:18px;border-radius:18px}.admin-filter-actions{display:flex;gap:10px;justify-content:flex-end;align-items:flex-end}.compact-select{min-width:160px}.compact-select span{margin-bottom:6px}.compact-select select,.compact-select input{min-height:42px;border-radius:14px;padding:0 14px;border:1px solid #d7e0ed;background:#f8fafd;color:#1c2940;outline:none}.compact-select input:focus,.compact-select select:focus{border-color:#4f83ff;background:#ffffff;box-shadow:0 0 0 4px #4f83ff1f}.admin-course-table{gap:10px}.admin-course-table .type-list-row:not(.type-list-row-head){padding:16px;border-radius:18px;transition:transform .16s ease,box-shadow .16s ease,border-color .16s ease}.admin-course-table .type-list-row:not(.type-list-row-head):hover{transform:translateY(-1px);border-color:#cfd9eb;box-shadow:0 18px 42px #111e3b14}.admin-course-table .type-list-row-head{padding:0 18px}.admin-course-table .type-list-row-body{padding:0;border:0;border-radius:0;background:transparent}.admin-course-title-line{display:flex;align-items:center;gap:10px;min-width:0}.admin-course-title-line strong{color:#1a2436;font-size:17px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.admin-alert-dot{min-height:24px;padding:0 8px;border-radius:999px;background:#fff1ee;color:#cf4e3f;font-size:12px;font-weight:800}.admin-course-mini-meta{display:flex;gap:8px;flex-wrap:wrap}.admin-course-mini-meta span{min-height:26px;padding:0 9px;border-radius:999px;display:inline-flex;align-items:center;background:#f0f4fa;color:#63728c;font-size:12px;font-weight:700}.admin-course-meta strong{color:#263348;font-size:15px;font-weight:800}.admin-course-table .course-actions-inline{justify-content:flex-end;gap:8px}.admin-course-table .small-btn{min-height:38px;padding:0 14px;border-radius:12px}.admin-course-table .danger-btn{background:#fff1ee;color:#cc4a3d}.admin-folder-tree{display:grid;gap:10px}.admin-folder-group{display:grid;gap:10px;padding:16px;border-radius:18px}.admin-folder-clickable{cursor:pointer;transition:transform .16s ease,border-color .16s ease,box-shadow .16s ease}.admin-folder-clickable:hover{transform:translateY(-1px);border-color:#cfd9eb;box-shadow:0 18px 42px #111e3b14}.admin-folder-row{display:grid;grid-template-columns:minmax(180px,1.1fr) minmax(180px,.8fr) minmax(260px,1fr) minmax(240px,auto);gap:16px;align-items:center;padding-bottom:12px;border-bottom:1px solid #eef3fa}.admin-folder-head,.admin-lesson-head{min-height:0;padding:0 16px 4px;border:0;background:transparent;color:#7c879c;font-size:13px;font-weight:800;box-shadow:none}.admin-folder-head{border-bottom:0}.admin-folder-head span{min-width:0}.admin-folder-head span:last-child,.admin-lesson-head span:nth-child(4),.admin-lesson-head span:last-child{text-align:right}.admin-folder-main{display:grid;gap:8px;min-width:0}.admin-folder-main>strong{color:#162137;font-size:18px}.admin-folder-category,.admin-folder-meta{display:flex;gap:8px;flex-wrap:wrap}.admin-mall-type-select{min-height:30px;padding:0 10px;border:1px solid var(--app-border);border-radius:999px;background:var(--app-input-bg);color:var(--app-text);font-size:12px;font-weight:800}.admin-folder-category span,.admin-folder-meta span{min-height:26px;padding:0 9px;border-radius:999px;display:inline-flex;align-items:center;background:#f2f5fa;color:#65738d;font-size:12px;font-weight:700}.admin-folder-status{display:flex;justify-content:flex-end;align-items:center;gap:8px;flex-wrap:wrap}.admin-selected-folder{display:flex;justify-content:space-between;gap:16px;align-items:center;padding:16px 18px;margin-bottom:12px;border:1px solid #dce6f5;border-radius:18px;background:linear-gradient(180deg,#fbfdff,#f6f9ff)}.admin-selected-folder div{display:grid;gap:6px}.admin-selected-folder strong{color:#172033;font-size:18px}.admin-selected-folder span{color:#6a7891;font-size:13px;font-weight:700}.admin-lesson-list{display:grid;gap:8px}.admin-lesson-row{display:grid;grid-template-columns:minmax(180px,1fr) minmax(90px,.45fr) minmax(220px,1.1fr) minmax(160px,auto) minmax(220px,auto);gap:12px;align-items:center;padding:12px;border:1px solid #edf2f8;border-radius:14px;background:#fbfcff}.admin-lesson-head{grid-template-columns:minmax(180px,1fr) minmax(90px,.45fr) minmax(220px,1.1fr) minmax(160px,auto) minmax(220px,auto)}.admin-lesson-main{display:grid;gap:7px;min-width:0}.admin-lesson-count,.admin-lesson-desc{min-width:0}.admin-lesson-count span,.admin-lesson-desc span{color:#62708a;font-size:13px;font-weight:700}.admin-lesson-desc span{display:block;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.admin-lesson-row .admin-course-status-stack{justify-content:flex-end}.admin-lesson-row .course-actions-inline{justify-content:flex-end;gap:8px}.admin-lesson-row .small-btn{min-height:36px;padding:0 13px;border-radius:12px}.admin-lesson-row .danger-btn{background:#fff1ee;color:#cc4a3d}.admin-user-page{gap:16px}.admin-user-table{gap:10px}.admin-user-table .type-list-row{grid-template-columns:minmax(320px,1.15fr) minmax(180px,.62fr) minmax(260px,.9fr) minmax(220px,auto)}.admin-user-table .type-list-row:not(.type-list-row-head){padding:16px;border:1px solid #e2e8f2;border-radius:18px;background:#ffffff;box-shadow:0 14px 34px #111e3b0d;transition:transform .16s ease,box-shadow .16s ease,border-color .16s ease}.admin-user-table .type-list-row:not(.type-list-row-head):hover{transform:translateY(-1px);border-color:#cfd9eb;box-shadow:0 18px 42px #111e3b14}.admin-user-table .type-list-row-head{padding:0 18px}.admin-user-table .type-list-row-body{padding:0;border:0;border-radius:0;background:transparent}.admin-user-main-cell{display:flex;align-items:center;gap:14px;min-width:0}.admin-user-avatar{width:48px;height:48px;border-radius:16px;flex:0 0 auto;display:grid;place-items:center;background:linear-gradient(135deg,#eaf1ff,#edf8f4);color:#31557d;font-weight:900;box-shadow:inset 0 0 0 1px #40649614;overflow:hidden}.admin-user-avatar img{width:100%;height:100%;display:block;object-fit:cover}.admin-user-avatar span{display:grid;place-items:center;width:100%;height:100%}.admin-user-copy{display:grid;gap:4px;min-width:0}.admin-user-copy strong,.admin-user-member-cell strong{color:#1a2436;font-size:16px}.admin-user-copy small,.admin-user-member-cell small{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.admin-user-statuses{align-items:center}.admin-user-member-cell{display:grid;gap:6px;min-width:0}.admin-user-table .course-actions-inline{justify-content:flex-end;gap:8px}.admin-user-table .small-btn{min-height:38px;padding:0 14px;border-radius:12px}.admin-user-table .danger-btn{background:#fff1ee;color:#cc4a3d}.admin-user-edit-dialog,.admin-user-detail-dialog{width:min(920px,calc(100vw - 40px));max-height:calc(100vh - 56px);overflow:auto}.admin-course-detail-dialog{width:min(980px,calc(100vw - 40px))}.member-code-filter-panel{margin-bottom:18px}.member-code-table{gap:10px}.member-code-table .type-list-row{grid-template-columns:minmax(260px,1fr) 140px 130px 130px 120px 190px}.member-code-table .type-list-row:not(.type-list-row-head){padding:16px;border:1px solid #e2e8f2;border-radius:18px;background:#ffffff;box-shadow:0 14px 34px #111e3b0d;transition:transform .16s ease,box-shadow .16s ease,border-color .16s ease}.member-code-table .type-list-row:not(.type-list-row-head):hover{transform:translateY(-1px);border-color:#cfd9eb;box-shadow:0 18px 42px #111e3b14}.member-code-table .type-list-row-head{padding:0 18px}.member-code-table .type-list-row-head strong:not(:first-child),.member-code-cell,.member-code-table .type-list-summary{text-align:center}.member-code-table .type-list-summary{justify-content:center;align-items:center}.member-code-table .type-list-row-head strong:last-child{text-align:center}.member-code-table .type-list-row-body{padding:0;border:0;border-radius:0;background:transparent}.member-code-main{display:grid;gap:10px}.member-code-main strong{color:#1a2436;font-size:17px}.member-code-main>span{color:#7a879d;font-size:12px;font-weight:700}.member-code-cell span{min-height:28px;padding:0 10px;border-radius:999px;display:inline-flex;align-items:center;background:#f0f4fa;color:#63728c;font-size:12px;font-weight:700}.member-code-table .course-actions-inline{justify-content:center;gap:8px}.member-code-table .small-btn{min-height:38px;padding:0 14px;border-radius:12px}.member-code-table .danger-btn{background:#fff1ee;color:#cc4a3d}.member-code-use-table .type-list-row{grid-template-columns:minmax(220px,1.1fr) minmax(200px,1fr) 120px 110px minmax(260px,1.2fr) 170px}.member-code-use-table .type-list-row:not(.type-list-row-head){padding:16px;border:1px solid #e2e8f2;border-radius:18px;background:#ffffff;box-shadow:0 14px 34px #111e3b0d}.member-code-use-table .type-list-row-head{padding:0 18px}.member-code-use-table .type-list-row-body{padding:0;border:0;border-radius:0;background:transparent}.member-code-use-table .type-list-row-head strong:not(:first-child),.member-code-use-table .member-code-cell{text-align:center}.member-code-quota-cell span{white-space:normal;line-height:1.5}.member-code-generate-dialog{width:min(860px,calc(100vw - 40px));max-height:calc(100vh - 56px);overflow:auto}.member-code-detail-dialog{width:min(920px,calc(100vw - 40px))}.member-code-dialog-head{display:flex;justify-content:space-between;gap:18px;align-items:flex-start;margin-bottom:18px}.member-code-dialog-head h3{margin-bottom:8px}.member-code-dialog-head p{margin:0}.member-code-dialog-error{margin:0 0 14px;padding:12px 14px;border-radius:14px;background:#fff4f2}.admin-current-membership{margin-bottom:18px;padding:16px;border:1px solid #e3eaf5;border-radius:18px;background:#f8fbff}.admin-detail-membership-editor{margin-top:18px;padding:16px;border:1px solid #e3eaf5;border-radius:18px;background:#f8fbff}.summary-readonly-value{display:block;margin-top:8px;color:#182238;font-size:16px;line-height:1.35;overflow-wrap:anywhere}.member-code-usage-card{grid-column:span 2}.admin-current-membership-head{display:flex;justify-content:space-between;gap:16px;margin-bottom:14px}.admin-current-membership-head strong{color:#1a2436;font-size:15px}.admin-current-membership-head span{color:#7b879c;font-size:13px;font-weight:700}.member-code-form-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px 16px}.member-code-form-grid .field{margin-bottom:0}.member-code-help{margin:18px 0;padding:14px 16px;border:1px solid #e2e9f3;border-radius:16px;background:#f8fbff}.member-code-help p{margin:0;color:#65738c;line-height:1.7}.member-code-help p+p{margin-top:6px}.member-code-dialog-actions{justify-content:flex-end}.membership-panel{gap:18px}.membership-overview{display:grid;grid-template-columns:minmax(0,1fr) minmax(280px,.42fr);gap:16px;align-items:stretch}.membership-identity,.membership-quota,.membership-info-block{border:1px solid #e6edf8;border-radius:18px;background:#fff;box-shadow:0 10px 24px #121c330a}.membership-identity{padding:26px 28px}.membership-identity h2{margin:18px 0 8px;font-size:34px;line-height:1.15}.membership-identity p{margin:0;color:#74819a;font-size:15px}.membership-quota{display:flex;flex-direction:column;justify-content:center;padding:24px}.membership-quota span,.membership-row span{color:#7b879c;font-size:13px;font-weight:700}.membership-quota strong{margin-top:8px;color:#172238;font-size:clamp(18px,2vw,28px);line-height:1.15;white-space:nowrap}.membership-quota small{margin-top:8px;color:#8a95a8;font-size:13px}.membership-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:18px}.membership-info-block{padding:22px 24px}.membership-info-block h3{margin:0 0 18px;font-size:20px}.membership-block-head{display:flex;justify-content:space-between;align-items:center;gap:12px;margin-bottom:18px;flex-wrap:wrap}.membership-block-head h3{margin:0}.membership-purchase-btn{min-height:36px;border-radius:12px}.membership-row{display:flex;justify-content:space-between;gap:18px;padding:14px 0;border-top:1px solid #eef3fa}.membership-row strong{color:#172238;font-size:15px;text-align:right}.membership-redeem-form{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:12px;align-items:end}.membership-redeem-form .field{margin:0}.admin-course-sentence-list,.admin-course-log-list{display:grid;gap:12px}.admin-course-log-card{padding:16px 18px;border-radius:18px;border:1px solid #e5ebf5;background:#fbfcff;display:grid;gap:8px}.inline-empty-state{min-height:auto;padding:18px}.inline-error{margin:0}.practice-record-card{display:flex;justify-content:space-between;gap:14px;align-items:flex-start}.practice-records-page .records-workspace{padding:0;border:0;border-radius:0;background:transparent;box-shadow:none}.practice-records-page .section-head-row{margin-bottom:20px;padding:0 0 18px;border-bottom:1px solid var(--app-border)}.practice-records-page .course-filter-row{background:color-mix(in srgb,var(--app-card-bg) 72%,transparent);border-color:var(--app-border-soft)}.practice-records-page .summary-grid{margin-bottom:20px}.practice-records-page .detail-card-block{padding:0;border:0;border-radius:0;background:transparent;box-shadow:none}.practice-records-page .detail-card-block+.detail-card-block{margin-top:26px}.practice-records-page .detail-card-block>h3{margin:0 0 12px;color:var(--app-heading);font-size:18px}.practice-records-page .detail-card-block>p{margin:-4px 0 14px;color:var(--app-muted)}.practice-records-page .practice-record-card{background:linear-gradient(90deg,rgba(34,211,238,.035),transparent 38%),var(--app-card-bg)}.app-shell:not(.admin-app-shell) .content-panel>.content-section:has(.summary-grid),.app-shell:not(.admin-app-shell) .content-panel>.content-section:has(.package-list),.app-shell:not(.admin-app-shell) .content-panel>.content-section:has(.mall-grid),.app-shell:not(.admin-app-shell) .content-panel>.content-section:has(.result-grid),.app-shell:not(.admin-app-shell) .content-panel>.content-section:has(.record-grid),.app-shell:not(.admin-app-shell) .content-panel>.content-section:has(.membership-overview),.app-shell:not(.admin-app-shell) .content-panel>.content-section:has(.membership-grid){padding:0;border:0;border-radius:0;background:transparent;box-shadow:none}.app-shell:not(.admin-app-shell) .content-panel>.content-section:has(.summary-grid)+.content-section,.app-shell:not(.admin-app-shell) .content-panel>.content-section:has(.package-list)+.content-section,.app-shell:not(.admin-app-shell) .content-panel>.content-section:has(.mall-grid)+.content-section,.app-shell:not(.admin-app-shell) .content-panel>.content-section:has(.result-grid)+.content-section{margin-top:4px}.app-shell:not(.admin-app-shell) .content-panel>.content-section:has(.summary-grid)>.section-head-row,.app-shell:not(.admin-app-shell) .content-panel>.content-section:has(.package-list)>.section-head-row,.app-shell:not(.admin-app-shell) .content-panel>.content-section:has(.mall-grid)>.section-head-row,.app-shell:not(.admin-app-shell) .content-panel>.content-section:has(.result-grid)>.section-head-row,.app-shell:not(.admin-app-shell) .content-panel>.content-section:has(.record-grid)>.section-head-row,.app-shell:not(.admin-app-shell) .content-panel>.content-section:has(.membership-overview)>.section-head-row,.app-shell:not(.admin-app-shell) .content-panel>.content-section:has(.membership-grid)>.section-head-row{padding-bottom:14px;border-bottom-color:var(--app-border)}.app-shell:not(.admin-app-shell) .content-panel>.content-section:has(.summary-grid)>.section-head-row+*,.app-shell:not(.admin-app-shell) .content-panel>.content-section:has(.package-list)>.section-head-row+*,.app-shell:not(.admin-app-shell) .content-panel>.content-section:has(.mall-grid)>.section-head-row+*,.app-shell:not(.admin-app-shell) .content-panel>.content-section:has(.result-grid)>.section-head-row+*,.app-shell:not(.admin-app-shell) .content-panel>.content-section:has(.record-grid)>.section-head-row+*,.app-shell:not(.admin-app-shell) .content-panel>.content-section:has(.membership-overview)>.section-head-row+*,.app-shell:not(.admin-app-shell) .content-panel>.content-section:has(.membership-grid)>.section-head-row+*{margin-top:18px}.practice-record-detail-dialog{width:min(920px,calc(100vw - 40px))}.system-config-section{display:grid;gap:22px}.system-config-section .section-head-row h2{margin:0 0 6px}.system-config-section .section-head-row p{margin:0;color:#7b879c;font-size:14px;font-weight:700}.config-form-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:18px}.config-wide-field{grid-column:1 / -1}.config-wide-field textarea{min-height:120px}@media (max-width: 960px){.admin-app-shell .main-shell{padding:16px}.admin-console-hero,.admin-filter-panel{grid-template-columns:1fr}.admin-filter-actions{justify-content:flex-start}.admin-stat-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.admin-course-table .course-actions-inline{justify-content:flex-start}.admin-user-table .type-list-row,.member-code-table .type-list-row{grid-template-columns:1fr}.admin-user-table .course-actions-inline,.member-code-table .course-actions-inline{justify-content:flex-start}.directory-hero-grid,.course-package-workbench{grid-template-columns:1fr}.package-side-card{position:static;order:2}.package-lessons-panel{order:1}.package-lessons-toolbar{grid-template-columns:1fr;align-items:stretch}.package-lessons-toolbar .toolbar-left,.package-lessons-toolbar .toolbar-right{justify-self:stretch;width:100%}.package-lessons-toolbar .toolbar-left{display:grid;grid-template-columns:1fr;flex-wrap:initial}.directory-lesson-card{flex-direction:column;align-items:stretch}.directory-lesson-main{max-width:none}.directory-lesson-heading{align-items:flex-start}.lesson-status-pill{margin-left:0}.practice-record-card{flex-direction:column}.membership-overview,.membership-grid,.config-form-grid{grid-template-columns:1fr}.member-code-dialog-head{flex-direction:column}.member-code-form-grid{grid-template-columns:1fr}.admin-pagination{flex-direction:column;align-items:stretch}.admin-pagination .pagination-summary,.admin-pagination .pagination-controls{justify-content:space-between}}@media (max-width: 640px){.admin-app-shell .topbar-shell{border-radius:14px}.admin-console-title,.admin-filter-panel,.admin-stat-card,.admin-course-table .type-list-row:not(.type-list-row-head),.admin-user-table .type-list-row:not(.type-list-row-head),.member-code-table .type-list-row:not(.type-list-row-head){border-radius:14px}.admin-stat-grid,.package-side-actions,.console-lesson-row{grid-template-columns:1fr}.console-lesson-actions{justify-content:flex-start;width:100%}.compact-search,.package-lessons-toolbar .toolbar-left,.package-lessons-toolbar .toolbar-right,.package-lessons-toolbar .primary-btn,.package-lessons-toolbar .ghost-btn{width:100%}.package-lessons-toolbar .toolbar-right{grid-template-columns:1fr}.package-lessons-toolbar{gap:10px;padding:14px}.segmented-filter{width:100%;overflow-x:auto;scrollbar-width:none}.segmented-filter button{flex:1 0 max-content;min-width:0}.admin-filter-actions,.admin-filter-actions .ghost-btn,.admin-filter-actions .primary-btn,.admin-course-table .course-actions-inline .small-btn,.admin-user-table .course-actions-inline .small-btn,.member-code-table .course-actions-inline .small-btn,.member-code-dialog-actions .ghost-btn,.member-code-dialog-actions .primary-btn{width:100%}.membership-identity,.membership-quota,.membership-info-block{border-radius:14px;padding:18px}.membership-identity h2,.membership-quota strong{font-size:20px;white-space:nowrap}.membership-row,.membership-redeem-form{grid-template-columns:1fr}.membership-row{display:block}.membership-row strong{display:block;margin-top:6px;text-align:left}.membership-redeem-form .primary-btn{width:100%}}.content-panel{background:transparent;border:0;box-shadow:none;border-radius:0;padding:0}.content-section,.panel,.confirm-dialog,.auth-card,.lesson-create-card,.admin-filter-panel,.admin-course-table,.admin-user-table,.member-code-table,.type-toolbar-card,.type-list-card{border-radius:8px}.package-card,.mall-card,.summary-card,.profile-action-card,.membership-identity,.membership-quota,.membership-info-block,.sentence-mini-card,.sentence-card,.result-row-card,.directory-lesson-card,.practice-record-card,.admin-stat-card{border-radius:8px;background:var(--app-card-bg);border-color:var(--app-border-soft)}.package-card,.mall-card,.package-row,.summary-card,.profile-action-card,.membership-identity,.membership-quota,.membership-info-block{box-shadow:0 10px 26px #0f172a0d}.package-row{border-radius:8px;background:linear-gradient(90deg,rgba(15,138,122,.04),transparent 36%),var(--app-card-bg)}.package-row:hover,.mall-card:hover,.package-card:hover,.profile-action-card:hover{border-color:#0f8a7a4d;box-shadow:0 16px 34px #0f172a14}.package-row-cover,.package-cover-choice,.cover-preview-box,.cover-placeholder,.mall-cover,.package-cover{border-radius:8px}.mall-card,.package-card{transition:transform .15s ease,border-color .2s ease,box-shadow .2s ease}.mall-card:hover,.package-card:hover{transform:translateY(-2px)}.mall-cover:after,.package-cover:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;background:linear-gradient(180deg,rgba(15,23,42,.02),rgba(15,23,42,.44))}.mall-cover>*,.package-cover>*{position:relative;z-index:1}.mall-badge,.package-cover-tag,.package-cover-chip,.course-status-pill,.keycap,.topbar-chip,.badge{border-radius:999px}.section-badge{width:46px;height:46px;border-radius:8px;font-size:24px}.section-badge-star{background:linear-gradient(135deg,var(--app-accent),var(--app-warm))}.plain-tab.active{color:var(--app-accent);border-bottom-color:var(--app-accent)}.course-status-pill.completed{background:#e7f8ef;color:#12704f}.course-status-pill.in-progress{background:#e9f4ff;color:#1d5fbf}.course-status-pill.abandoned{background:#fff4e4;color:#b85d12}.course-status-pill.not-started{background:#eff3f8;color:#64748b}.mini-progress,.package-progress-bar{background:#dce7ef}.mini-progress span,.package-progress-bar span{background:linear-gradient(90deg,var(--app-accent),var(--app-secondary))}.course-filter-row{padding:12px;border:1px solid var(--app-border-soft);border-radius:8px;background:var(--app-soft-bg)}.compact-select select,.field input,.field select,.field textarea,.select-line select,.search-row input,.segment-item input,.package-cover-picker input[type=text]{border-radius:8px}.field option:disabled{color:#9ca3af;background:#f3f4f6}.admin-app-shell .topbar-shell{border-radius:8px;background:linear-gradient(135deg,rgba(37,99,235,.06),rgba(255,255,255,.9)),var(--app-panel-bg)}.admin-app-shell .topbar-shell h1{color:var(--app-heading)}.membership-identity{background:linear-gradient(135deg,rgba(15,138,122,.09),rgba(217,119,6,.08)),var(--app-card-bg)}.membership-quota strong,.hero-stat-card strong{color:var(--app-accent)}.overlay-mask{-webkit-backdrop-filter:blur(7px);backdrop-filter:blur(7px)}.confirm-dialog{box-shadow:0 28px 80px #0f172a38}@media (max-width: 1180px){.sidebar-shell{position:static;height:auto;padding:14px 16px}.brand-block{padding:8px 2px 12px}.sidebar-nav{grid-template-columns:repeat(3,minmax(0,1fr))}}@media (max-width: 860px){.customer-auth-shell{grid-template-columns:1fr}.customer-auth-stage{min-height:680px}.customer-auth-card{min-height:auto}.login-character-scene{min-height:300px}.customer-google-button{justify-content:center}.customer-auth-copy h1{white-space:normal}.sidebar-nav{grid-template-columns:repeat(2,minmax(0,1fr))}.brand-copy{display:none}.topbar-actions,.page-header-actions,.course-filter-row{width:100%}.topbar-actions>*,.page-header-actions>*,.course-filter-row>*{min-width:0}}@media (max-width: 560px){.customer-auth-page{overflow:auto}.customer-auth-shell{width:min(100%,calc(100vw - 24px));min-height:auto}.customer-auth-stage,.customer-auth-card{padding:18px}.login-character-scene{min-height:260px;transform:scale(.82);transform-origin:center}.lesson-create-dialog{width:calc(100vw - 20px);max-width:calc(100vw - 20px);max-height:calc(100vh - 20px);padding:16px}.sidebar-nav{grid-template-columns:1fr}.topbar-actions>.theme-toggle-btn,.topbar-actions>.ghost-btn,.topbar-actions>.primary-btn{width:100%}}::selection{background:var(--app-accent-ring)}button:focus-visible,a:focus-visible,input:focus-visible,textarea:focus-visible,select:focus-visible{outline:3px solid var(--app-accent-ring);outline-offset:2px}.sidebar-shell{box-shadow:10px 0 30px #0f172a09}.sidebar-link{min-height:46px;display:flex;align-items:center}.sidebar-link-title{line-height:1.25}.topbar-actions{padding-top:2px}.page-stack{gap:22px}.page-header-card{min-height:94px;border-top-color:#ffffffe6}.page-title-line h1,.section-head-row h2,.market-section-head h2{color:var(--app-heading);letter-spacing:0}.section-head-row{padding-bottom:12px;border-bottom:1px solid var(--app-border-soft)}.market-section-head{margin-bottom:4px}.market-toolbar{display:flex;align-items:center;justify-content:center;gap:12px;flex-wrap:wrap}.market-notice-toolbar{justify-content:space-between;align-items:center;gap:16px}.mall-market-notice{flex:1 1 520px;min-width:min(100%,320px);margin:0;color:var(--app-muted);font-size:14px;line-height:1.7}.mall-search-box{flex:0 1 320px;min-width:240px;width:320px}.toolbar-search{box-shadow:0 8px 18px #0f172a09}.toolbar-search:focus-within{border-color:#0f8a7a6b;box-shadow:0 0 0 4px #0f8a7a1a,0 10px 24px #0f172a0d}.course-filter-row .select-line{min-width:142px}.course-filter-row .compact-page-size{min-width:112px}.layout-switch{min-height:42px;display:inline-flex;align-items:center;padding:4px;border:1px solid var(--app-border-soft);border-radius:8px;background:var(--app-soft-bg);gap:4px}.layout-switch button{min-height:32px;padding:0 12px;border:0;border-radius:6px;background:transparent;color:var(--app-muted);font-weight:900}.layout-switch button.active{background:var(--app-card-bg);color:var(--app-heading);box-shadow:0 6px 16px #0f172a14}.package-row{grid-template-columns:116px minmax(0,1fr) minmax(132px,160px) auto;gap:20px;padding:14px}.package-row.draggable-package-row{grid-template-columns:32px 116px minmax(0,1fr) minmax(132px,160px) auto}.package-row-cover{width:116px;box-shadow:inset 0 0 0 1px #ffffff3d}.package-row-title h3{font-size:17px}.package-row-meta{gap:8px}.package-row-meta span{min-height:26px;padding:0 9px;border-radius:999px;display:inline-flex;align-items:center;background:#f3f7fb;color:#64748b}.package-row-progress{padding:12px;border:1px solid var(--app-border-soft);border-radius:8px;background:#f8fafc}.package-row-progress strong{font-size:22px}.package-row-actions{min-width:76px}.package-row-actions .small-btn{min-width:68px}.package-list-grid{grid-template-columns:repeat(auto-fill,minmax(250px,320px));justify-content:start}.package-list-grid .package-row,.package-list-grid .package-row.draggable-package-row{grid-template-columns:minmax(0,1fr);align-content:start;gap:14px;min-height:100%}.package-list-grid .package-drag-handle{justify-self:start}.package-list-grid .package-row-cover{width:100%;aspect-ratio:16 / 9}.package-list-grid .package-row-progress,.package-list-grid .package-row-actions{width:100%}.package-list-grid .package-row-progress{align-self:end}.package-list-grid .package-row-actions{justify-content:flex-start}.console-lesson-list-grid{grid-template-columns:repeat(auto-fit,minmax(240px,360px));align-items:stretch;justify-content:start}.console-lesson-list-grid .console-lesson-row{grid-template-columns:minmax(0,1fr);align-content:start;gap:14px;min-height:100%}.console-lesson-list-grid .lesson-drag-handle,.console-lesson-list-grid .lesson-select-chip{justify-self:start}.console-lesson-list-grid .console-lesson-actions{justify-content:flex-start;flex-wrap:wrap}.mall-layout-list{grid-template-columns:minmax(0,1fr)}@media (max-width: 720px){.mall-layout-list .mall-card{grid-template-columns:minmax(0,1fr)}}.mall-layout-list .mall-drag-handle{position:absolute;top:14px;left:14px;z-index:3}.mall-layout-list .mall-cover,.mall-layout-list .featured-card .mall-cover,.mall-layout-list .compact-mall-card .compact-cover{min-height:100%;height:100%}.mall-layout-list .mall-body{align-content:center}@media (max-width: 1100px){.package-list-grid{grid-template-columns:repeat(auto-fill,minmax(230px,300px))}}@media (max-width: 920px){.console-lesson-list-grid{grid-template-columns:repeat(auto-fit,minmax(220px,1fr))}}@media (max-width: 720px){.package-list-grid,.mall-layout-list,.mall-layout-list .mall-card{grid-template-columns:minmax(0,1fr)}.mall-layout-list .mall-cover,.mall-layout-list .featured-card .mall-cover,.mall-layout-list .compact-mall-card .compact-cover{min-height:220px}}.mall-card,.package-card{display:flex;flex-direction:column}.mall-layout-list .mall-card{display:grid;grid-template-columns:minmax(180px,260px) minmax(0,1fr);align-items:stretch;min-height:190px}.mall-cover,.package-cover{isolation:isolate}.mall-cover-image,.package-cover-image,.plain-cover-image{transition:transform .35s ease}.mall-card:hover .mall-cover-image,.package-card:hover .package-cover-image,.package-card:hover .plain-cover-image{transform:scale(1.035)}.mall-cover-title,.package-cover-title{max-width:100%;text-wrap:balance;text-shadow:0 8px 22px rgba(0,0,0,.24)}.theme-rose .mall-cover-title,.theme-music .mall-cover-title,.theme-gold .mall-cover-title,.theme-sky .mall-cover-title{text-shadow:none}.mall-body,.package-card-body{display:grid;gap:8px}.mall-body p,.package-card-body p{margin-top:0}.mall-body .course-actions-inline,.package-card-body .course-actions-inline{margin-top:4px}.mall-meta,.package-progress-meta{padding-top:4px;border-top:1px solid var(--app-border-soft)}.profile-avatar{border-radius:8px;background:var(--app-primary);box-shadow:0 16px 34px #0f8a7a38}.profile-hero-card{background:linear-gradient(135deg,rgba(37,99,235,.08),rgba(255,255,255,.9)),var(--app-panel-bg)}.summary-card{min-height:92px}.course-pagination{margin-top:20px;padding:14px;border:1px solid var(--app-border-soft);border-radius:8px;background:var(--app-card-bg);box-shadow:0 8px 20px #0f172a0a}.page-number-btn.active{background:var(--app-primary);border-color:transparent;color:#fff;box-shadow:0 10px 20px #0f8a7a24}.empty-state{background:linear-gradient(135deg,rgba(248,250,252,.96),rgba(255,255,255,.96))}.success-message,.error-message{padding:12px 14px;border-radius:8px}.success-message{background:#ecfdf3}.error-message{background:#fff5f4}@media (max-width: 980px){.package-row,.package-row.draggable-package-row{gap:14px}.package-row-progress{width:100%}.course-filter-row .select-line,.course-filter-row .compact-page-size{min-width:min(100%,180px)}}@media (max-width: 720px){.practice-start-content-panel{padding:16px}.practice-start-content-head h3{font-size:20px}.practice-start-content-card{padding:16px}.practice-start-content-list{max-height:58vh}.practice-start-enter-btn,.market-toolbar .ghost-btn,.course-filter-row .ghost-btn,.package-row-actions .small-btn,.course-pagination .ghost-btn{width:100%}.package-row-actions{min-width:0;justify-content:stretch}.pagination-controls{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));width:100%}}:root[data-theme=dark]{--app-text: #d8e7f7;--app-heading: #f7fbff;--app-muted: #94a8bf;--app-subtle: #7f95ad;--app-accent: #22d3ee;--app-accent-strong: #67e8f9;--app-accent-soft: rgba(34, 211, 238, .13);--app-accent-ring: rgba(34, 211, 238, .22);--app-secondary: #818cf8;--app-warm: #fbbf24;--app-bg: radial-gradient(circle at top left, rgba(34, 211, 238, .18), transparent 28%), radial-gradient(circle at bottom right, rgba(129, 140, 248, .16), transparent 30%), linear-gradient(180deg, #06111f 0%, #09182b 100%);--app-shell-bg: rgba(8, 19, 34, .92);--app-panel-bg: rgba(12, 26, 45, .96);--app-card-bg: #0f2138;--app-input-bg: #0a1728;--app-soft-bg: #132844;--app-hover-bg: #183653;--app-border: #24415d;--app-border-soft: #1d3651;--app-shadow: 0 22px 58px rgba(0, 0, 0, .34);--app-primary: linear-gradient(135deg, #22d3ee, #818cf8);--app-success: linear-gradient(135deg, #34d399, #22d3ee);--app-danger-bg: rgba(239, 68, 68, .12);--app-danger-text: #ff8c82}:root[data-theme=dark] body,:root[data-theme=dark] .app-shell,:root[data-theme=dark] .main-shell{color:var(--app-text);background:var(--app-bg)}:root[data-theme=dark] .admin-app-shell .topbar-shell{background:var(--app-panel-bg);border-color:var(--app-border);box-shadow:var(--app-shadow)}:root[data-theme=dark] .admin-app-shell .topbar-shell h1{color:var(--app-heading)}:root[data-theme=dark] .sidebar-shell{border-right-color:var(--app-border)}:root[data-theme=dark] .brand-mark{box-shadow:0 14px 30px #22d3ee3d}:root[data-theme=dark] .page-icon{border-color:#22d3ee57;color:var(--app-accent-strong);box-shadow:0 12px 28px #00000038}:root[data-theme=dark] .topbar-chip,:root[data-theme=dark] .badge{background:rgba(34,211,238,.13);color:#baf4ff}:root[data-theme=dark] .topbar-chip.soft,:root[data-theme=dark] .badge.soft-badge{background:var(--app-soft-bg);color:var(--app-muted)}:root[data-theme=dark] .page-header-card,:root[data-theme=dark] .content-panel,:root[data-theme=dark] .content-section,:root[data-theme=dark] .panel,:root[data-theme=dark] .confirm-dialog,:root[data-theme=dark] .auth-card,:root[data-theme=dark] .studio-panel,:root[data-theme=dark] .detail-card-block,:root[data-theme=dark] .resume-entry-box,:root[data-theme=dark] .resume-box,:root[data-theme=dark] .mode-card,:root[data-theme=dark] .stage-box,:root[data-theme=dark] .practice-card,:root[data-theme=dark] .result-box,:root[data-theme=dark] .package-card,:root[data-theme=dark] .type-toolbar-card,:root[data-theme=dark] .type-list-card,:root[data-theme=dark] .admin-filter-panel,:root[data-theme=dark] .admin-course-table,:root[data-theme=dark] .admin-folder-group,:root[data-theme=dark] .admin-lesson-row,:root[data-theme=dark] .admin-user-table,:root[data-theme=dark] .member-code-table,:root[data-theme=dark] .membership-identity,:root[data-theme=dark] .membership-quota,:root[data-theme=dark] .membership-info-block,:root[data-theme=dark] .directory-completion-card,:root[data-theme=dark] .batch-toolbar,:root[data-theme=dark] .admin-course-log-card{background:var(--app-panel-bg);border-color:var(--app-border);box-shadow:var(--app-shadow);color:var(--app-text)}:root[data-theme=dark] .auth-page-shell{background:var(--app-bg)}:root[data-theme=dark] .auth-title-block h1,:root[data-theme=dark] .section-head-row h2,:root[data-theme=dark] .market-section-head h2,:root[data-theme=dark] .package-card-body h3,:root[data-theme=dark] .directory-lesson-title,:root[data-theme=dark] .admin-course-title-line strong,:root[data-theme=dark] .admin-folder-main>strong,:root[data-theme=dark] .member-code-main strong,:root[data-theme=dark] .admin-user-copy strong,:root[data-theme=dark] .admin-user-member-cell strong,:root[data-theme=dark] .type-tree-title strong,:root[data-theme=dark] .summary-card strong,:root[data-theme=dark] .course-stat-item strong,:root[data-theme=dark] .membership-row strong,:root[data-theme=dark] .member-code-dialog-head h3,:root[data-theme=dark] .confirm-dialog h3{color:var(--app-heading)}:root[data-theme=dark] .section-head-row p,:root[data-theme=dark] .market-section-head p,:root[data-theme=dark] .preview-panel p,:root[data-theme=dark] .record-card p,:root[data-theme=dark] .confirm-dialog p,:root[data-theme=dark] .resume-entry-box p,:root[data-theme=dark] .resume-box p,:root[data-theme=dark] .panel-head p,:root[data-theme=dark] .stage-copy,:root[data-theme=dark] .mode-head p,:root[data-theme=dark] .empty-inline,:root[data-theme=dark] .empty-state,:root[data-theme=dark] .tips,:root[data-theme=dark] .package-card-body p,:root[data-theme=dark] .mall-body p,:root[data-theme=dark] .auth-title-block p,:root[data-theme=dark] .directory-lesson-copy,:root[data-theme=dark] .admin-course-mini-meta,:root[data-theme=dark] .admin-folder-category,:root[data-theme=dark] .admin-folder-meta,:root[data-theme=dark] .admin-lesson-count span,:root[data-theme=dark] .admin-lesson-desc span,:root[data-theme=dark] .member-code-main>span,:root[data-theme=dark] .member-code-cell,:root[data-theme=dark] .member-code-table .type-list-summary,:root[data-theme=dark] .admin-user-copy small,:root[data-theme=dark] .admin-user-member-cell small,:root[data-theme=dark] .type-reference-copy,:root[data-theme=dark] .dialog-note,:root[data-theme=dark] .system-config-section .section-head-row p{color:var(--app-muted)}:root[data-theme=dark] input,:root[data-theme=dark] textarea,:root[data-theme=dark] select,:root[data-theme=dark] .toolbar-search,:root[data-theme=dark] .share-inline-select,:root[data-theme=dark] .share-expire-control,:root[data-theme=dark] .pagination-size-select select,:root[data-theme=dark] .cover-input-row input,:root[data-theme=dark] .type-inline-field input,:root[data-theme=dark] .type-inline-field select{background:var(--app-input-bg);border-color:var(--app-border);color:var(--app-text)}:root[data-theme=dark] input::placeholder,:root[data-theme=dark] textarea::placeholder,:root[data-theme=dark] .toolbar-search input::placeholder{color:#697790}:root[data-theme=dark] .pre-practice-steps{border-top-color:var(--app-border)}:root[data-theme=dark] .mode-step-group h4{background:rgba(109,77,255,.18);color:#dbe3ff;border:1px solid rgba(139,154,255,.22)}:root[data-theme=dark] .mode-step-badge{background:#182235;border-color:#7c8df6;color:#dbe3ff}:root[data-theme=dark] .checkbox-line,:root[data-theme=dark] .mode-select-line{background:rgba(20,30,48,.82);border-color:#7c8df638;color:#dbe3ff;box-shadow:inset 0 1px #ffffff08}:root[data-theme=dark] .checkbox-line input{accent-color:#20c7a8}:root[data-theme=dark] .mode-select-line select{background-color:#101827;border-color:#7c8df657;color:#f3f7ff}:root[data-theme=dark] .mode-select-line select:focus{border-color:#20c7a8;box-shadow:0 0 0 3px #20c7a824}:root[data-theme=dark] .checkbox-line:hover,:root[data-theme=dark] .mode-select-line:hover{background:rgba(27,39,62,.96);border-color:#20c7a852}:root[data-theme=dark] body.practice-immersive-active,:root[data-theme=dark] body.practice-immersive-active .app-shell,:root[data-theme=dark] body.practice-immersive-active .main-shell,:root[data-theme=dark] body.practice-immersive-active .practice-panel{background:var(--app-bg);color:var(--app-text)}:root[data-theme=dark] .prompt-box{background:linear-gradient(145deg,rgba(23,36,58,.95),rgba(13,23,39,.96));border-color:var(--app-border)}:root[data-theme=dark] .prompt-main,:root[data-theme=dark] .practice-minimal-heading h2,:root[data-theme=dark] .practice-minimal-main,:root[data-theme=dark] .directory-complete-feedback strong{color:var(--app-heading)}:root[data-theme=dark] .prompt-sub,:root[data-theme=dark] .practice-minimal-meta,:root[data-theme=dark] .practice-minimal-sub,:root[data-theme=dark] .practice-minimal-empty,:root[data-theme=dark] .practice-session-actions-label,:root[data-theme=dark] .directory-complete-feedback p,:root[data-theme=dark] .shortcut-row{color:var(--app-muted)}:root[data-theme=dark] .practice-status,:root[data-theme=dark] .practice-minimal-status{background:rgba(32,199,168,.1);border-color:#20c7a83d;color:#bff7eb}:root[data-theme=dark] .practice-minimal-shell{color:var(--app-text)}:root[data-theme=dark] .practice-minimal-top{border-bottom-color:var(--app-border)}:root[data-theme=dark] .practice-minimal-meta .minimal-timer{color:#dbe3ff}:root[data-theme=dark] .practice-minimal-meta span{background:rgba(124,141,246,.14);color:#dbe3ff;box-shadow:inset 0 0 0 1px #7c8df62e}:root[data-theme=dark] .practice-minimal-progress{background:rgba(124,141,246,.16)}:root[data-theme=dark] .practice-minimal-progress span{background:linear-gradient(90deg,#20c7a8,#7c8df6)}:root[data-theme=dark] .practice-minimal-tools .ghost-btn,:root[data-theme=dark] .practice-session-actions,:root[data-theme=dark] .practice-session-actions .ghost-btn.compact-btn{background:rgba(20,30,48,.88);border-color:#7c8df63d;color:var(--app-text)}:root[data-theme=dark] .practice-session-actions .danger-btn{background:rgba(239,68,68,.13);border-color:#ef44443d;color:#ff9b92}:root[data-theme=dark] .practice-theme-toggle-btn{background:rgba(20,30,48,.88);border-color:#7c8df63d;color:var(--app-text)}:root[data-theme=dark] .practice-theme-toggle-btn:hover{background:rgba(32,45,69,.94)}:root[data-theme=dark] .practice-fullscreen-btn{background:rgba(20,30,48,.9);border-color:#20c7a852;color:#bff7eb;box-shadow:0 14px 34px #00000047}:root[data-theme=dark] .icon-btn,:root[data-theme=dark] .minimal-next{background:rgba(23,36,58,.94);border:1px solid rgba(124,141,246,.24);color:#dbe3ff;box-shadow:0 14px 30px #0000003d}:root[data-theme=dark] .practice-minimal-workbench,:root[data-theme=dark] .directory-complete-feedback,:root[data-theme=dark] .practice-minimal-start{background:linear-gradient(180deg,rgba(20,30,48,.96),rgba(13,23,39,.96));border-color:var(--app-border);box-shadow:inset 0 1px #ffffff0a;color:var(--app-text)}:root[data-theme=dark] .minimal-segment-field{color:var(--app-text)}:root[data-theme=dark] .segment-item input,:root[data-theme=dark] .minimal-segment-item input{border-bottom-color:#42506a;color:#f3f7ff}:root[data-theme=dark] .segment-item input:focus,:root[data-theme=dark] .minimal-segment-item input:focus{border-bottom-color:#20c7a8;box-shadow:none}:root[data-theme=dark] .practice-input-frame-green{--typing-focus-frame: rgba(32, 199, 168, .42);--typing-focus-fill: rgba(32, 199, 168, .1);--typing-focus-shadow: rgba(0, 0, 0, .22)}:root[data-theme=dark] .practice-input-frame-pink{--typing-focus-frame: rgba(255, 159, 194, .42);--typing-focus-fill: rgba(255, 159, 194, .1);--typing-focus-shadow: rgba(0, 0, 0, .22)}:root[data-theme=dark] .practice-input-frame-yellow{--typing-focus-frame: rgba(245, 211, 111, .42);--typing-focus-fill: rgba(245, 211, 111, .1);--typing-focus-shadow: rgba(0, 0, 0, .22)}:root[data-theme=dark] .minimal-segment-punctuation{color:#dbe3ff}:root[data-theme=dark] .segment-item small,:root[data-theme=dark] .minimal-segment-item small{color:#9aa9c4}:root[data-theme=dark] .minimal-segment-line{border-bottom-color:#42506a}:root[data-theme=dark] .segment-status-correct{background:rgba(32,199,168,.14);color:#8ff0d8}:root[data-theme=dark] .segment-status-wrong,:root[data-theme=dark] .practice-minimal-error{background:rgba(239,68,68,.12);border-color:#ef444442;color:#ff9b92}:root[data-theme=dark] .ghost-btn,:root[data-theme=dark] .filter-btn,:root[data-theme=dark] .market-tab,:root[data-theme=dark] .theme-toggle-btn,:root[data-theme=dark] .keycap,:root[data-theme=dark] .pagination-page-indicator,:root[data-theme=dark] .compact-btn{background:var(--app-soft-bg);color:var(--app-text);box-shadow:inset 0 0 0 1px var(--app-border)}:root[data-theme=dark] .keycap{border-color:#7c8df647;background:rgba(20,30,48,.92);color:#cbd6ee}:root[data-theme=dark] .ghost-btn:hover,:root[data-theme=dark] .filter-btn:hover,:root[data-theme=dark] .market-tab:hover,:root[data-theme=dark] .theme-toggle-btn:hover{background:var(--app-hover-bg)}:root[data-theme=dark] .notice-strip,:root[data-theme=dark] .mall-hero-banner{border-color:#22d3ee4d;background:linear-gradient(135deg,rgba(34,211,238,.12),rgba(129,140,248,.08))}:root[data-theme=dark] .notice-strip strong,:root[data-theme=dark] .mall-hero-banner h2{color:var(--app-heading)}:root[data-theme=dark] .mini-progress,:root[data-theme=dark] .package-progress-bar,:root[data-theme=dark] .directory-lesson-progress-bar{background:rgba(34,211,238,.14)}:root[data-theme=dark] .summary-card,:root[data-theme=dark] .course-stat-item,:root[data-theme=dark] .meta-card,:root[data-theme=dark] .type-tree-row,:root[data-theme=dark] .package-row,:root[data-theme=dark] .admin-stat-card,:root[data-theme=dark] .member-code-detail-card,:root[data-theme=dark] .practice-record-card,:root[data-theme=dark] .sentence-detail-card,:root[data-theme=dark] .result-row-card,:root[data-theme=dark] .directory-lesson-card{background:var(--app-card-bg);border-color:var(--app-border-soft);color:var(--app-text)}:root[data-theme=dark] .directory-lesson-card.selected,:root[data-theme=dark] .directory-lesson-card:hover,:root[data-theme=dark] .package-row:hover,:root[data-theme=dark] .type-list-row:not(.type-list-row-head):hover,:root[data-theme=dark] .admin-folder-clickable:hover,:root[data-theme=dark] .admin-lesson-row:not(.admin-lesson-head):hover{background:#172641;border-color:#22d3ee57}:root[data-theme=dark] .admin-folder-row,:root[data-theme=dark] .admin-lesson-row,:root[data-theme=dark] .member-code-table .type-list-row:not(.type-list-row-head),:root[data-theme=dark] .member-code-use-table .type-list-row:not(.type-list-row-head),:root[data-theme=dark] .admin-user-table .type-list-row:not(.type-list-row-head){background:var(--app-card-bg);border-color:var(--app-border-soft);color:var(--app-text)}:root[data-theme=dark] .admin-folder-category span,:root[data-theme=dark] .admin-folder-meta span,:root[data-theme=dark] .admin-lesson-count span,:root[data-theme=dark] .member-code-cell span{background:rgba(148,163,184,.12);color:#b7c3d8}:root[data-theme=dark] .admin-lesson-head,:root[data-theme=dark] .admin-folder-head,:root[data-theme=dark] .member-code-table .type-list-row-head,:root[data-theme=dark] .member-code-use-table .type-list-row-head,:root[data-theme=dark] .admin-user-table .type-list-row-head{background:transparent;box-shadow:none;color:var(--app-muted)}:root[data-theme=dark] .admin-pagination,:root[data-theme=dark] .course-pagination{background:var(--app-panel-bg);border-color:var(--app-border);box-shadow:var(--app-shadow)}:root[data-theme=dark] .overlay-mask{background:rgba(2,6,15,.68)}:root[data-theme=dark] .danger-btn,:root[data-theme=dark] .danger-btn.ghost-btn{background:var(--app-danger-bg);color:var(--app-danger-text)}:root[data-theme=dark] .error-message,:root[data-theme=dark] .inline-error{color:#ff8c82}:root[data-theme=dark] .success-message{color:#4ade80}:root[data-theme=dark] audio{color-scheme:dark}:root[data-theme=dark] .content-panel{background:transparent;border:0;box-shadow:none;color:var(--app-text)}:root[data-theme=dark] .page-header-card{background:linear-gradient(135deg,rgba(34,211,238,.14),rgba(12,26,45,.94) 42%,rgba(129,140,248,.1)),var(--app-panel-bg)}:root[data-theme=dark] .sidebar-link.active{background:linear-gradient(135deg,rgba(34,211,238,.18),rgba(129,140,248,.13));box-shadow:inset 0 0 0 1px #22d3ee3d}:root[data-theme=dark] .sidebar-link.active:before{background:var(--app-accent)}:root[data-theme=dark] .page-icon{border-color:#22d3ee57;color:var(--app-accent-strong);background:linear-gradient(135deg,rgba(34,211,238,.16),rgba(129,140,248,.11)),var(--app-input-bg)}:root[data-theme=dark] .course-filter-row,:root[data-theme=dark] .membership-identity{background:linear-gradient(135deg,rgba(34,211,238,.1),rgba(129,140,248,.08));border-color:var(--app-border)}:root[data-theme=dark] .package-card,:root[data-theme=dark] .mall-card,:root[data-theme=dark] .summary-card,:root[data-theme=dark] .profile-action-card,:root[data-theme=dark] .membership-identity,:root[data-theme=dark] .membership-quota,:root[data-theme=dark] .membership-info-block{box-shadow:0 18px 42px #0000003d}:root[data-theme=dark] .mini-progress span,:root[data-theme=dark] .package-progress-bar span{background:var(--app-primary)}:root[data-theme=dark] .plain-tab.active{color:var(--app-accent-strong);border-bottom-color:var(--app-accent)}:root[data-theme=dark] .membership-quota strong,:root[data-theme=dark] .hero-stat-card strong{color:var(--app-accent-strong)}:root[data-theme=dark] .sidebar-shell{box-shadow:10px 0 34px #00000038}:root[data-theme=dark] .section-head-row,:root[data-theme=dark] .mall-meta,:root[data-theme=dark] .package-progress-meta{border-color:var(--app-border)}:root[data-theme=dark] .toolbar-search:focus-within{border-color:#22d3ee7a;box-shadow:0 0 0 4px #22d3ee21}:root[data-theme=dark] .package-row-meta span{background:rgba(148,163,184,.11);color:#b6c3d8}:root[data-theme=dark] .package-row-progress,:root[data-theme=dark] .course-pagination{background:rgba(17,29,49,.92);border-color:var(--app-border)}:root[data-theme=dark] .profile-hero-card{background:linear-gradient(135deg,rgba(59,130,246,.12),rgba(15,25,43,.94)),var(--app-panel-bg)}:root[data-theme=dark] .empty-state{background:rgba(17,29,49,.88)}:root[data-theme=dark] .success-message{background:rgba(34,197,94,.11)}:root[data-theme=dark] .error-message{background:rgba(239,68,68,.11)}:root[data-theme=dark] .practice-mode-page .mode-panel,:root[data-theme=dark] .practice-mode-page .mode-card{background:transparent;border-color:var(--app-border);box-shadow:none}:root[data-theme=dark] .practice-mode-page .mode-step-group h4{background:transparent;border:0;color:var(--app-heading)}:root[data-theme=dark] .practice-mode-page .checkbox-line,:root[data-theme=dark] .practice-mode-page .mode-select-line{background:rgba(15,33,56,.48);border-color:#22d3ee29;box-shadow:none}:root[data-theme=dark] .practice-mode-page .checkbox-line:hover,:root[data-theme=dark] .practice-mode-page .mode-select-line:hover{background:rgba(18,44,70,.72);border-color:#22d3ee4d}.home-page{max-width:1320px}.home-hero{display:grid;grid-template-columns:minmax(0,1.55fr) minmax(320px,.95fr);gap:20px;align-items:stretch}.home-hero-copy,.home-focus-panel,.home-stat-card,.home-course-card,.home-quick-link,.home-suggest-item{border:1px solid var(--app-border);box-shadow:var(--app-shadow);background:var(--app-panel-bg)}.home-hero-copy{min-height:330px;padding:32px 250px 32px 32px;border-radius:28px;display:flex;flex-direction:column;justify-content:center;position:relative;overflow:hidden}.home-hero-copy:after{content:"";position:absolute;right:8px;bottom:18px;width:220px;height:150px;border-radius:999px;background:radial-gradient(ellipse at center,rgba(20,196,168,.1),transparent 62%),radial-gradient(ellipse at 72% 28%,rgba(143,91,255,.1),transparent 50%);opacity:.72;pointer-events:none}.home-hero-art{position:absolute;right:6px;bottom:20px;width:230px;height:170px;pointer-events:none;opacity:.78;filter:drop-shadow(-14px 22px 28px rgba(32,44,72,.08))}.hero-art-shadow{fill:#505c821a}.hero-art-page{fill:url(#heroBookPage);stroke:#7651f62e;stroke-width:1.4}.hero-art-page.left{filter:url(#heroArtBlur)}.hero-art-spine,.hero-art-line{fill:none;stroke:#7651f638;stroke-width:2;stroke-linecap:round}.hero-art-line.soft{stroke:#14c4a838}.hero-art-pencil path:first-child{fill:url(#heroPencil);opacity:.72}.hero-art-pencil .notebook-pencil-body{fill:url(#heroNotebookPencil)}.hero-art-pencil path:nth-child(2){fill:#f9d69ac7}.hero-art-pencil path:nth-child(3){stroke:#ffffff8c;stroke-width:1.4}.hero-art-spark{fill:#ffcd706b}.hero-art-spark.teal{fill:#14c4a84d}.hero-art-device,.hero-art-notebook-cover,.hero-art-cup{fill:url(#heroKeyboardFill);stroke:#7651f629;stroke-width:1.4}.hero-art-keys rect{fill:#ffffffb8;stroke:#7651f61a}.hero-art-audio-card{fill:url(#heroAudioCardFill);stroke:#45d3c757;stroke-width:1.6}.hero-art-play-ring{fill:#ffffffc7;stroke:#29d7c26b;stroke-width:2}.hero-art-play-mark{fill:#7651f6bd}.hero-art-audio-bars rect{fill:url(#heroAudioWaveFill);opacity:.78}.hero-art-audio-wave{fill:none;stroke:#29d7c294;stroke-width:4;stroke-linecap:round}.hero-art-audio-shadow{fill:#29d7c229}.hero-art-audio-spark{fill:#29d7c28c}.hero-art-card-stack rect{fill:#ffffffb3;stroke:#7651f626;stroke-width:1.4}.hero-art-card-stack rect:nth-child(2){fill:#ebfaf6b8;stroke:#14c4a829}.hero-art-card-stack rect:nth-child(3){fill:#fcfdffd6}.hero-art-headphone-band,.hero-art-wave,.hero-art-steam,.hero-art-cup-handle,.hero-art-notebook-spine{fill:none;stroke:#7651f63d;stroke-width:4;stroke-linecap:round;stroke-linejoin:round}.hero-art-wave,.hero-art-steam{stroke-width:2.6}.hero-art-wave.soft,.hero-art-steam.soft{stroke:#14c4a838}.hero-art-earpad{fill:#ffffffb8;stroke:#7651f629;stroke-width:1.4}.hero-art-notebook-cover{fill:#ffffffbd}.hero-art-cup{fill:url(#heroCupFill)}.hero-art-cup-handle{stroke-width:3.4}.home-date-pill{min-height:34px;padding:0 14px;border-radius:999px;display:inline-flex;align-items:center;background:var(--app-soft-bg);color:var(--app-muted);font-weight:800}.home-hero-copy h1{width:min(640px,100%);margin:22px 0 14px;color:var(--app-heading);font-size:42px;line-height:1.12;letter-spacing:0}.home-hero-copy p{width:min(680px,100%);margin:0;color:var(--app-muted);font-size:16px;line-height:1.8}.home-hero-actions{margin-top:28px;display:flex;flex-wrap:wrap;gap:12px}.home-main-action{min-width:168px}.home-focus-panel{padding:28px;border-radius:28px;display:flex;flex-direction:column;justify-content:space-between;background:linear-gradient(145deg,rgba(18,155,115,.1),rgba(143,91,255,.08)),var(--app-panel-bg)}.home-panel-kicker{width:fit-content;padding:8px 12px;border-radius:999px;background:rgba(18,155,115,.12);color:#0f7d60;font-size:12px;font-weight:900;text-transform:uppercase}.home-focus-panel h2{margin:30px 0 12px;color:var(--app-heading);font-size:28px;line-height:1.18;letter-spacing:0}.home-focus-panel p{margin:0;color:var(--app-muted);line-height:1.7}.home-focus-meta{margin-top:28px;display:flex;flex-wrap:wrap;gap:10px}.home-focus-meta span{min-height:36px;padding:0 12px;border-radius:999px;display:inline-flex;align-items:center;background:var(--app-input-bg);color:var(--app-muted);font-weight:800}.home-stat-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:16px}.home-stat-card{padding:20px;border-radius:24px}.home-stat-card span,.home-stat-card p{color:var(--app-muted)}.home-stat-card span{font-weight:800}.home-stat-card strong{display:block;margin-top:10px;color:var(--app-heading);font-size:34px;line-height:1}.home-stat-card p{margin:10px 0 0}.home-curve-panel{overflow:hidden}.home-curve-summary{display:flex;align-items:center;gap:10px;flex-wrap:wrap;justify-content:flex-end;color:var(--app-muted);font-weight:800}.home-curve-summary span,.home-curve-summary strong{min-height:36px;padding:0 12px;border-radius:999px;display:inline-flex;align-items:center;background:var(--app-soft-bg)}.home-curve-summary strong{color:#0f7d60;background:rgba(18,155,115,.12)}.home-curve-chart{margin-top:18px;width:100%;height:230px;border-radius:22px;position:relative;background:linear-gradient(180deg,rgba(255,255,255,.94),rgba(247,250,255,.98)),var(--app-card-bg);border:1px solid var(--app-border-soft);overflow:hidden;box-shadow:inset 0 1px #ffffffd1,inset 0 -38px 70px #7651f612}.home-curve-chart.theme-sakura{background:radial-gradient(circle at 10% 18%,rgba(255,182,205,.38),transparent 18%),radial-gradient(circle at 90% 82%,rgba(255,211,224,.34),transparent 18%),linear-gradient(135deg,rgba(255,246,251,.98),rgba(247,253,255,.92)),var(--app-card-bg)}.home-curve-chart.theme-sakura:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:radial-gradient(ellipse at 50% 12%,rgba(238,105,134,.32) 0 9%,transparent 10%),radial-gradient(ellipse at 75% 36%,rgba(238,105,134,.3) 0 8%,transparent 9%),radial-gradient(ellipse at 66% 70%,rgba(238,105,134,.26) 0 7%,transparent 8%),radial-gradient(ellipse at 34% 70%,rgba(238,105,134,.26) 0 7%,transparent 8%),radial-gradient(ellipse at 25% 36%,rgba(238,105,134,.3) 0 8%,transparent 9%),radial-gradient(ellipse at 14% 88%,rgba(238,105,134,.34) 0 6%,transparent 7%),radial-gradient(ellipse at 22% 80%,rgba(238,105,134,.28) 0 5%,transparent 6%),radial-gradient(ellipse at 84% 16%,rgba(238,105,134,.25) 0 5%,transparent 6%);background-size:82px 82px,82px 82px,82px 82px,82px 82px,82px 82px,54px 54px,48px 48px,48px 48px;background-position:388px 18px,388px 18px,388px 18px,388px 18px,388px 18px,26px 142px,74px 128px,438px 28px;background-repeat:no-repeat;opacity:.56;pointer-events:none}.home-curve-chart.theme-hinomaru{background:radial-gradient(circle at 87% 18%,rgba(226,71,89,.18),rgba(226,71,89,.08) 16%,transparent 26%),radial-gradient(circle at 10% 86%,rgba(226,71,89,.1),transparent 19%),linear-gradient(90deg,rgba(255,255,255,.98),rgba(246,248,252,.9) 50%,rgba(255,255,255,.98)),linear-gradient(180deg,rgba(255,255,255,.96),rgba(245,248,253,.94)),var(--app-card-bg)}.home-curve-chart.theme-hinomaru:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:conic-gradient(from 210deg at 9% 87%,rgba(226,71,89,.14) 0 14deg,transparent 14deg 22deg,rgba(226,71,89,.11) 22deg 36deg,transparent 36deg 44deg,rgba(226,71,89,.1) 44deg 58deg,transparent 58deg 360deg),radial-gradient(circle at 87% 18%,rgba(255,255,255,.48),transparent 23%),radial-gradient(circle at 87% 18%,rgba(226,71,89,.18),transparent 14%),linear-gradient(35deg,transparent 0 78%,rgba(148,163,184,.12) 79% 80%,transparent 81%),linear-gradient(20deg,transparent 0 84%,rgba(148,163,184,.1) 85% 86%,transparent 87%);opacity:.72;pointer-events:none}.home-curve-chart.theme-ocean{background:radial-gradient(ellipse at 12% 16%,rgba(125,222,255,.32),transparent 24%),radial-gradient(ellipse at 90% 82%,rgba(73,188,227,.22),transparent 26%),linear-gradient(145deg,rgba(230,249,255,.98),rgba(240,246,255,.92) 46%,rgba(222,242,255,.96)),var(--app-card-bg)}.home-curve-chart.theme-ocean:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:radial-gradient(ellipse at 9% 86%,transparent 0 11%,rgba(63,181,224,.24) 12% 14%,transparent 15%),radial-gradient(ellipse at 17% 87%,transparent 0 11%,rgba(63,181,224,.18) 12% 14%,transparent 15%),radial-gradient(ellipse at 25% 87%,transparent 0 11%,rgba(63,181,224,.13) 12% 14%,transparent 15%),radial-gradient(ellipse at 89% 16%,rgba(104,205,241,.22) 0 5%,transparent 6%),radial-gradient(ellipse at 94% 25%,rgba(104,205,241,.16) 0 4%,transparent 5%),radial-gradient(ellipse at 84% 28%,rgba(104,205,241,.13) 0 3%,transparent 4%),linear-gradient(180deg,transparent,rgba(255,255,255,.46));opacity:.74;pointer-events:none}.home-curve-chart.theme-temple{background:radial-gradient(ellipse at 88% 18%,rgba(242,201,159,.22),transparent 26%),radial-gradient(ellipse at 10% 90%,rgba(226,71,89,.1),transparent 20%),linear-gradient(145deg,rgba(255,249,239,.98),rgba(247,253,255,.92)),var(--app-card-bg)}.home-curve-chart.theme-bamboo{background:radial-gradient(ellipse at 92% 34%,rgba(113,190,133,.2),transparent 28%),radial-gradient(ellipse at 8% 92%,rgba(113,190,133,.12),transparent 22%),linear-gradient(145deg,rgba(246,255,248,.98),rgba(240,248,255,.92)),var(--app-card-bg)}.home-curve-chart.theme-mountain{background:radial-gradient(ellipse at 12% 82%,rgba(141,191,236,.2),transparent 26%),radial-gradient(circle at 88% 26%,rgba(255,196,120,.16),transparent 18%),linear-gradient(145deg,rgba(240,249,255,.98),rgba(255,255,255,.94)),var(--app-card-bg)}.home-curve-chart svg.home-curve-graph{width:100%;height:100%;display:block;position:relative;z-index:1}.home-curve-decoration{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;pointer-events:none;z-index:0}.home-curve-chart.theme-sakura:before,.home-curve-chart.theme-hinomaru:before,.home-curve-chart.theme-ocean:before,.home-curve-chart.theme-temple:before,.home-curve-chart.theme-bamboo:before,.home-curve-chart.theme-mountain:before{display:none}.deco-branch{fill:none;stroke:#9d715d3d;stroke-width:2.4;stroke-linecap:round}.watercolor-object{filter:saturate(.92);opacity:.72}.watercolor-line{opacity:.56}.watercolor-line.thin{stroke-width:1.4;opacity:.36}.deco-sakura path{fill:url(#sakuraPetalFill);stroke:#ee69862e;stroke-width:1.2}.deco-sakura circle{fill:#e247592e}.deco-sakura.soft{opacity:.52}.deco-petal{fill:#ee698642}.deco-petal.soft{opacity:.46}.deco-flag-pole{fill:none;stroke:#6b72803d;stroke-width:2.2;stroke-linecap:round}.deco-flag-cloth{fill:url(#flagClothFill);stroke:#94a3b82e;stroke-width:1.1}.deco-flag-sun{fill:#e247592e}.deco-fan path{fill:#ffffff42;stroke:#e2475921;stroke-width:1.25;stroke-linecap:round;stroke-linejoin:round}.deco-sailboat path{fill:url(#sailFill);stroke:#2d8fbe2e;stroke-width:1.45;stroke-linecap:round;stroke-linejoin:round}.deco-wave{fill:none;stroke:#2d8fbe2e;stroke-width:2.8;stroke-linecap:round}.deco-shell path{fill:#ffffff47;stroke:#2d8fbe26;stroke-width:1.3;stroke-linecap:round;stroke-linejoin:round}.deco-temple path{fill:url(#templeFill);stroke:#9d715d33;stroke-width:1.25;stroke-linecap:round;stroke-linejoin:round}.deco-temple path:nth-child(n+5),.deco-lantern path:nth-child(2),.deco-bamboo path,.deco-bamboo-ground,.deco-cloud{fill:none}.deco-lantern path:first-child{fill:#e2475929;stroke:#e247592e}.deco-lantern path:nth-child(2){stroke:#9d715d2e;stroke-width:1.5;stroke-linecap:round}.deco-bamboo path{stroke:#539e6938;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}.deco-bamboo path:nth-child(n+5){fill:#71be8524;stroke:#539e6929}.deco-bamboo-ground{stroke:#539e6929;stroke-width:2.4;stroke-linecap:round}.deco-mountain path{fill:url(#mountainFill);stroke:#5185b829;stroke-width:1.4;stroke-linejoin:round}.deco-mountain path:nth-child(2){fill:#ffffff57}.deco-sun{fill:#ffc4782e;stroke:#ffc47826}.deco-cloud{stroke:#5185b829;stroke-width:2.4;stroke-linecap:round}.home-curve-area{fill:url(#homeCurveAreaGradient)}.home-curve-line{fill:none;stroke:url(#homeCurveLineGradient);stroke-width:4.6;stroke-linecap:round;stroke-linejoin:round;filter:url(#homeCurveGlow)}.home-curve-dot{fill:#fff;stroke:#14c4a8;stroke-width:3}.home-curve-dot-glow{fill:#14c4a82e}.home-curve-point-target{cursor:pointer;outline:none}.home-curve-hit-dot{fill:transparent;pointer-events:all}.home-curve-active-dot{fill:#fff;stroke:#7651f6;stroke-width:3;filter:drop-shadow(0 6px 12px rgba(118,81,246,.22))}.home-curve-tooltip{position:absolute;z-index:3;min-width:118px;padding:10px 12px;border-radius:14px;border:1px solid rgba(118,81,246,.14);background:rgba(255,255,255,.92);box-shadow:0 14px 34px #202c4824;transform:translate(-50%,calc(var(--tooltip-y, -100%) + var(--tooltip-offset, -14px)));pointer-events:none;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.home-curve-tooltip:after{content:"";position:absolute;left:50%;top:var(--tooltip-arrow-y, auto);bottom:var(--tooltip-arrow-bottom, -6px);width:12px;height:12px;background:rgba(255,255,255,.92);border-right:1px solid rgba(118,81,246,.14);border-bottom:1px solid rgba(118,81,246,.14);transform:translate(-50%) rotate(var(--tooltip-arrow-rotate, 45deg))}.home-curve-tooltip span,.home-curve-tooltip strong{display:block;white-space:nowrap}.home-curve-tooltip span{color:var(--app-muted);font-size:12px;font-weight:800}.home-curve-tooltip strong{margin-top:3px;color:var(--app-heading);font-size:15px;line-height:1.2}.home-curve-value{fill:var(--app-heading);font-size:12px;font-weight:900;paint-order:stroke;stroke:#ffffffdb;stroke-width:3px}.home-curve-label{fill:var(--app-muted);font-size:10.5px;font-weight:800}.home-dashboard-grid{display:grid;grid-template-columns:minmax(0,1.45fr) minmax(320px,.85fr);gap:20px;align-items:start}.home-main-panel,.home-side-stack{min-width:0}.home-side-stack{display:grid;gap:20px}.home-course-list,.home-suggest-list{display:grid;gap:12px}.home-course-card{padding:18px;border-radius:20px;cursor:pointer;transition:transform .15s ease,border-color .2s ease,background .2s ease}.home-course-card:hover{transform:translateY(-1px);border-color:#8f5bff3d;background:var(--app-hover-bg)}.home-course-title-row,.home-course-foot{display:flex;align-items:center;gap:12px}.home-course-title-row{justify-content:space-between}.home-course-title-row h3{margin:0;color:var(--app-heading);font-size:17px;line-height:1.35}.home-course-card p{margin:8px 0 16px;color:var(--app-muted)}.home-course-foot{color:var(--app-muted);font-weight:800}.home-progress-track{flex:1;min-width:72px;height:8px;border-radius:999px;overflow:hidden;background:var(--app-soft-bg)}.home-progress-track span{display:block;height:100%;border-radius:inherit;background:linear-gradient(90deg,#129b73,#8f5bff)}.home-quick-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}.home-quick-link,.home-suggest-item{color:var(--app-text);text-decoration:none;border-radius:18px}.home-quick-link{min-height:74px;padding:16px;display:flex;align-items:center;justify-content:center;text-align:center;font-weight:900;background:var(--app-card-bg)}.home-suggest-item{width:100%;padding:16px;display:grid;gap:6px;text-align:left;background:var(--app-card-bg)}.home-suggest-item span{width:fit-content;padding:5px 9px;border-radius:999px;background:rgba(143,91,255,.1);color:#7651f6;font-size:12px;font-weight:900}.home-suggest-item strong{color:var(--app-heading);line-height:1.35}.home-suggest-item small{color:var(--app-muted);font-weight:700}.home-quick-link:hover,.home-suggest-item:hover{transform:translateY(-1px);border-color:#8f5bff3d}@media (max-width: 1180px){.home-hero,.home-dashboard-grid{grid-template-columns:1fr}.home-focus-panel{min-height:220px}}@media (max-width: 760px){.home-hero-copy{min-height:auto;padding:24px}.home-hero-copy:after{display:none}.home-hero-art{display:none}.home-hero-copy h1{font-size:30px}.home-stat-grid,.home-quick-grid{grid-template-columns:1fr}.home-curve-summary{justify-content:flex-start}.home-curve-chart{height:190px}.home-course-title-row,.home-course-foot{align-items:flex-start;flex-direction:column}.home-progress-track{width:100%}}:root[data-theme=dark] .home-hero-copy,:root[data-theme=dark] .home-focus-panel,:root[data-theme=dark] .home-stat-card,:root[data-theme=dark] .home-course-card,:root[data-theme=dark] .home-quick-link,:root[data-theme=dark] .home-suggest-item,:root[data-theme=dark] .home-focus-meta span{background:var(--app-card-bg);border-color:var(--app-border-soft)}:root[data-theme=dark] .home-date-pill,:root[data-theme=dark] .home-progress-track,:root[data-theme=dark] .home-curve-chart,:root[data-theme=dark] .home-curve-summary span{background:var(--app-soft-bg)}:root[data-theme=dark] .home-panel-kicker{color:#8ff0d8;background:rgba(32,199,168,.13)}:root[data-theme=dark] .home-curve-summary strong{color:#8ff0d8;background:rgba(32,199,168,.13)}:root[data-theme=dark] .home-curve-dot{fill:var(--app-card-bg)}:root[data-theme=dark] .home-curve-chart{background:linear-gradient(180deg,rgba(15,23,42,.88),rgba(10,18,32,.96)),var(--app-card-bg);box-shadow:inset 0 1px #ffffff14,inset 0 -38px 70px #14c4a812}:root[data-theme=dark] .home-curve-chart.theme-sakura{background:radial-gradient(circle at 10% 18%,rgba(255,154,190,.18),transparent 19%),radial-gradient(circle at 90% 82%,rgba(255,211,224,.12),transparent 20%),linear-gradient(180deg,rgba(31,24,39,.94),rgba(15,23,42,.96)),var(--app-card-bg)}:root[data-theme=dark] .home-curve-chart.theme-hinomaru{background:radial-gradient(circle at 87% 18%,rgba(226,71,89,.16),rgba(226,71,89,.08) 16%,transparent 28%),radial-gradient(circle at 10% 86%,rgba(226,71,89,.09),transparent 19%),linear-gradient(90deg,rgba(15,23,42,.96),rgba(30,37,54,.9) 50%,rgba(15,23,42,.96)),var(--app-card-bg)}:root[data-theme=dark] .home-curve-chart.theme-ocean{background:radial-gradient(ellipse at 12% 16%,rgba(125,222,255,.16),transparent 30%),radial-gradient(ellipse at 90% 82%,rgba(73,188,227,.12),transparent 28%),linear-gradient(145deg,rgba(10,25,42,.96),rgba(15,23,42,.93) 46%,rgba(13,35,53,.96)),var(--app-card-bg)}:root[data-theme=dark] .home-curve-chart.theme-temple{background:radial-gradient(ellipse at 88% 18%,rgba(242,201,159,.12),transparent 28%),radial-gradient(ellipse at 10% 90%,rgba(226,71,89,.08),transparent 20%),linear-gradient(145deg,rgba(33,26,34,.96),rgba(15,23,42,.94)),var(--app-card-bg)}:root[data-theme=dark] .home-curve-chart.theme-bamboo{background:radial-gradient(ellipse at 92% 34%,rgba(113,190,133,.12),transparent 30%),radial-gradient(ellipse at 8% 92%,rgba(113,190,133,.08),transparent 22%),linear-gradient(145deg,rgba(11,32,27,.96),rgba(15,23,42,.94)),var(--app-card-bg)}:root[data-theme=dark] .home-curve-chart.theme-mountain{background:radial-gradient(ellipse at 12% 82%,rgba(141,191,236,.12),transparent 28%),radial-gradient(circle at 88% 26%,rgba(255,196,120,.1),transparent 18%),linear-gradient(145deg,rgba(12,28,44,.96),rgba(15,23,42,.94)),var(--app-card-bg)}:root[data-theme=dark] .home-curve-value{stroke:#0f172ae6}:root[data-theme=dark] .home-curve-tooltip,:root[data-theme=dark] .home-curve-tooltip:after{background:rgba(15,23,42,.92);border-color:#94a3b83d}:root[data-theme=dark] .home-curve-active-dot{fill:var(--app-card-bg)}:root[data-theme=dark] .deco-branch,:root[data-theme=dark] .deco-flag-pole,:root[data-theme=dark] .deco-wave{opacity:.7}:root[data-theme=dark] .deco-flag-cloth,:root[data-theme=dark] .deco-sailboat path,:root[data-theme=dark] .deco-shell path,:root[data-theme=dark] .deco-fan path,:root[data-theme=dark] .deco-temple path,:root[data-theme=dark] .deco-mountain path{fill:#ffffff21}.admin-dashboard-page{gap:18px}.admin-dashboard-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:18px;align-items:stretch}.admin-dashboard-card{min-width:0;padding:22px;display:flex;flex-direction:column;gap:16px;border:1px solid var(--app-border-soft);border-radius:18px;background:var(--app-card-bg)}.admin-dashboard-card h3,.admin-dashboard-card h4{margin:0;color:var(--app-heading)}.admin-dashboard-card h3{font-size:18px}.admin-dashboard-card h4{font-size:14px}.admin-dashboard-card .primary-btn{width:fit-content;margin-top:auto}.admin-dashboard-card.wide-card{grid-column:1 / -1}.form-grid.two-columns{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px}.toggle-row{display:flex;flex-wrap:wrap;gap:14px;color:var(--app-muted);font-weight:800}.toggle-row label{display:inline-flex;align-items:center;gap:8px}.form-help{margin:-4px 0 0;color:var(--app-muted);font-size:13px;line-height:1.6}.admin-login-list{display:grid;gap:10px}.admin-login-row{min-width:0;padding:12px 14px;display:flex;justify-content:space-between;gap:14px;border-radius:14px;background:var(--app-soft-bg);color:var(--app-muted);font-size:13px}.admin-login-row strong{color:var(--app-heading);overflow-wrap:anywhere}.admin-login-row span{white-space:nowrap}.security-columns{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:18px}.security-columns ul{margin:10px 0 0;padding-left:18px;color:var(--app-muted);line-height:1.7}@media (max-width: 980px){.admin-dashboard-grid,.security-columns,.form-grid.two-columns{grid-template-columns:1fr}.admin-dashboard-card .primary-btn{width:100%}}@media (max-width: 640px){.admin-dashboard-card{padding:18px}.admin-login-row{flex-direction:column}.admin-login-row span{white-space:normal}}.front-site-footer{margin:48px auto 0;padding:28px 16px 8px;width:min(100%,980px);display:grid;gap:10px;justify-items:center;text-align:center;color:var(--app-muted);font-size:13px;line-height:1.7}.front-footer-links{display:flex;flex-wrap:wrap;justify-content:center;gap:4px 8px}.front-site-footer a{color:var(--app-muted);text-decoration:none}.front-footer-link-button{-webkit-appearance:none;-moz-appearance:none;appearance:none;border:0;padding:0;background:transparent;color:var(--app-muted);font:inherit;line-height:inherit;cursor:pointer}.front-site-footer a:hover,.front-footer-link-button:hover{color:var(--app-accent);text-decoration:underline}.front-site-footer p{margin:0}.customer-auth-page{align-content:center;gap:24px;overflow-y:auto}.customer-auth-page .front-site-footer{position:relative;z-index:1;margin-top:0;padding-bottom:0;color:#ffffffb3}.customer-auth-page .front-site-footer a,.customer-auth-page .front-footer-link-button{color:#ffffffc7}.customer-auth-page .front-site-footer a:hover,.customer-auth-page .front-footer-link-button:hover{color:#fff}.legal-page{width:min(100%,980px);margin:0 auto;padding:48px 20px 24px}.legal-document{color:var(--app-heading)}.legal-document h1{margin:0 0 28px;font-size:clamp(28px,4vw,44px);line-height:1.15;letter-spacing:0}.legal-document .legal-text{margin:0;white-space:pre-wrap;overflow-wrap:anywhere;font-family:inherit;font-size:15px;line-height:1.9;color:var(--app-text)}.seo-page{width:min(100%,1080px);margin:0 auto}.seo-hero{min-height:420px;padding:clamp(48px,8vw,86px) clamp(24px,5vw,64px);border-radius:0;background:linear-gradient(135deg,rgba(15,138,122,.12),rgba(40,120,215,.1)),var(--app-panel-bg);border:1px solid var(--app-border-soft);box-shadow:var(--app-shadow);display:flex;align-items:center}.seo-hero>div{width:min(100%,780px)}.seo-kicker{margin:0 0 12px;color:var(--app-accent);font-weight:800;letter-spacing:0}.seo-hero h1{margin:0;color:var(--app-heading);font-size:clamp(36px,6vw,68px);line-height:1.04;letter-spacing:0}.seo-subtitle{margin:18px 0 0;color:var(--app-heading);font-size:clamp(20px,3vw,30px);font-weight:750;line-height:1.35}.seo-lead{margin:18px 0 0;max-width:720px;color:var(--app-muted);font-size:16px;line-height:1.9}.seo-actions{margin-top:28px;display:flex;flex-wrap:wrap;gap:12px}.seo-section{display:grid;gap:22px}.seo-section-head h2{margin:0;color:var(--app-heading);font-size:25px;letter-spacing:0}.seo-section-head p{margin:8px 0 0;color:var(--app-muted);line-height:1.8}.seo-card-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:14px}.seo-info-card{min-height:150px;padding:20px;border-radius:8px;border:1px solid var(--app-border-soft);background:var(--app-card-bg)}.seo-info-card h3,.seo-faq-list h3{margin:0;color:var(--app-heading);font-size:16px;letter-spacing:0;line-height:1.45}.seo-info-card p,.seo-faq-list p{margin:10px 0 0;color:var(--app-muted);font-size:14px;line-height:1.8}.seo-check-list{margin:0;padding:0;list-style:none;display:grid;gap:10px}.seo-check-list li{padding:14px 16px;border:1px solid var(--app-border-soft);border-radius:8px;background:var(--app-soft-bg);color:var(--app-heading);font-weight:650}.seo-link-grid{display:flex;flex-wrap:wrap;gap:10px}.seo-link-grid a{padding:10px 14px;border:1px solid var(--app-border);border-radius:999px;color:var(--app-heading);background:var(--app-card-bg);text-decoration:none;font-weight:700}.seo-link-grid a:hover{color:#fff;border-color:transparent;background:var(--app-primary)}.seo-faq-list{display:grid;gap:12px}.seo-faq-list article{padding:18px 20px;border:1px solid var(--app-border-soft);border-radius:8px;background:var(--app-card-bg)}@media (max-width: 640px){.front-site-footer{margin-top:34px;padding-inline:8px}.legal-page{padding:34px 16px 16px}.seo-hero{min-height:auto;padding:36px 20px}.seo-actions{display:grid}}
