:root{--ink-900: #0f2036;--ink-700: #3e4d63;--ink-500: #68788c;--line-soft: rgba(15, 32, 54, .1);--surface-strong: rgba(255, 255, 255, .96);--surface-soft: rgba(255, 255, 255, .78);--surface-muted: rgba(15, 32, 54, .05);--warm-500: #ff7a45;--warm-600: #f56a2f;--gold-500: #d79b1f;--silver-500: #7f8da1;--bronze-500: #ab6f47;--success-600: #0b8b4d;--error-600: #c23030}.root-bg{font-family:Noto Sans SC,PingFang SC,Microsoft YaHei,sans-serif;color:var(--ink-900);background:radial-gradient(circle at 2% 10%,rgba(255,205,95,.55),transparent 45%),radial-gradient(circle at 85% 0%,rgba(15,112,255,.22),transparent 52%),linear-gradient(180deg,#fdf6f0,#f2f5ff 58%,#eef3f6)}*,*:before,*:after{box-sizing:border-box}html,body{margin:0;min-height:100vh}body{color:var(--ink-900)}button,input,textarea,select{font:inherit}a{color:inherit}#root{min-height:100vh}.app-shell{display:grid;grid-template-columns:288px 1fr;min-height:100vh}.shell-sidebar{position:sticky;top:0;min-height:100vh;background:linear-gradient(180deg,#fffffff0,#f2f6ffe6),radial-gradient(circle at top left,rgba(255,198,122,.26),transparent 36%);border-right:1px solid rgba(255,255,255,.55);padding:28px 22px;display:flex;flex-direction:column;gap:18px;-webkit-backdrop-filter:blur(22px);backdrop-filter:blur(22px);box-shadow:inset -1px 0 #0f20360d}.logo{font-size:24px;font-weight:700;letter-spacing:.2em}.sidebar-brand-card,.sidebar-user-card{position:relative;overflow:hidden;padding:18px 18px 20px;border-radius:24px;background:linear-gradient(160deg,#ffffffe6,#ffffffb8),radial-gradient(circle at top right,rgba(255,184,131,.22),transparent 40%);border:1px solid rgba(255,255,255,.68);box-shadow:0 14px 30px #0f203614}.sidebar-brand-card:after,.sidebar-user-card:after{content:"";position:absolute;inset:auto -24px -24px auto;width:96px;height:96px;border-radius:999px;background:radial-gradient(circle,rgba(15,112,255,.12),transparent 68%)}.sidebar-brand-card .eyebrow,.sidebar-user-role{display:block;margin-bottom:10px}.sidebar-note,.sidebar-user-card p{position:relative;z-index:1;margin:10px 0 0;color:var(--ink-700);line-height:1.7;font-size:14px}.sidebar-user-card strong{position:relative;z-index:1;display:block;font-size:22px;line-height:1.2}.sidebar-user-role{color:var(--ink-500);font-size:13px}.nav-group{display:flex;flex-direction:column;gap:10px}.nav-link{position:relative;padding:12px 16px;border-radius:16px;text-decoration:none;color:var(--ink-900);background:#ffffff8f;border:1px solid rgba(255,255,255,.38);box-shadow:0 8px 18px #0f20360a;transition:transform .2s ease,background-color .2s ease,color .2s ease,box-shadow .2s ease,border-color .2s ease}.nav-link:hover{transform:translate(3px);background:#ffffffdb;border-color:#0f203614;box-shadow:0 12px 22px #0f203614}.nav-link.active{background:linear-gradient(135deg,#102847,#1a4f86);color:#fff;border-color:transparent;box-shadow:0 16px 32px #0f203642}.shell-content{padding:36px 34px 40px;background:transparent}.shell-header{margin-bottom:24px}.shell-header-banner{position:relative;overflow:hidden;padding:24px 28px;border-radius:30px;background:linear-gradient(135deg,#ffffffeb,#ffffffb8),radial-gradient(circle at top right,rgba(255,202,141,.3),transparent 42%);border:1px solid rgba(255,255,255,.5);box-shadow:0 22px 44px #0f203614}.shell-header-banner:after{content:"";position:absolute;right:-40px;top:-36px;width:180px;height:180px;border-radius:999px;background:radial-gradient(circle,rgba(15,112,255,.14),transparent 68%)}.shell-header h1{margin:4px 0 0;font-size:36px;position:relative;z-index:1}.shell-subtitle{position:relative;z-index:1;margin:12px 0 0;color:var(--ink-700);line-height:1.8;max-width:720px}.eyebrow{letter-spacing:.3em;color:#0f20368c;font-size:12px;text-transform:uppercase}.grid-layout{display:grid;gap:26px}.panel-card{position:relative;overflow:hidden;background:var(--surface-strong);border:1px solid rgba(255,255,255,.4);border-radius:28px;padding:24px;box-shadow:0 24px 46px #0f203614;-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px)}.panel-card:before{content:"";position:absolute;inset:0 0 auto;height:4px;background:linear-gradient(90deg,#ff7a45eb,#0f70ffb8)}.panel-card:after{content:"";position:absolute;right:-36px;top:-36px;width:140px;height:140px;border-radius:999px;background:radial-gradient(circle,rgba(15,112,255,.08),transparent 70%)}.panel-heading,.panel-body{position:relative;z-index:1}.panel-heading{display:flex;align-items:start;justify-content:space-between;gap:16px;padding-bottom:14px;border-bottom:1px solid rgba(15,32,54,.06)}.panel-heading h2{margin:0;font-size:22px;color:var(--ink-900)}.panel-heading p{margin:4px 0 0;color:var(--ink-700)}.panel-body{margin-top:16px}.stacked-list{display:flex;flex-direction:column;gap:12px}.task-card{display:flex;flex-direction:column;gap:14px;padding:18px;border-radius:22px;background:linear-gradient(160deg,#ffffffdb,#f4f8ffbd),radial-gradient(circle at top right,rgba(255,188,130,.2),transparent 40%);text-decoration:none;color:inherit;border:1px solid rgba(255,255,255,.58);transition:transform .2s ease,border-color .2s ease,box-shadow .2s ease}.task-card:hover{transform:translateY(-2px);border-color:#0f203614;box-shadow:0 18px 28px #0f203614}.task-meta{display:flex;gap:6px;flex-wrap:wrap}.badge-pill{font-size:12px;padding:5px 10px;border-radius:999px;background:#0f203614;border:1px solid rgba(15,32,54,.05)}.primary-btn,.ghost-btn,.link-button{transition:transform .2s ease,box-shadow .2s ease,border-color .2s ease,background-color .2s ease}.primary-btn:hover,.ghost-btn:hover,.link-button:hover{transform:translateY(-1px)}.primary-btn:disabled,.ghost-btn:disabled{cursor:not-allowed;opacity:.7;transform:none}.primary-btn{background:linear-gradient(135deg,var(--warm-600),var(--warm-500));color:#fff;border:none;padding:12px 28px;border-radius:14px;cursor:pointer;box-shadow:0 14px 24px #ff6c3757}.ghost-btn{border:1px solid rgba(15,32,54,.16);background:#ffffffd6;padding:10px 16px;border-radius:14px;cursor:pointer;box-shadow:0 8px 18px #0f20360d}.link-button{display:inline-flex;align-items:center;justify-content:center;padding:10px 16px;border-radius:999px;text-decoration:none;border:1px solid rgba(15,32,54,.14);color:var(--ink-900);background:#ffffffd1;box-shadow:0 8px 18px #0f20360d}.button-row{display:flex;gap:12px;flex-wrap:wrap}.auth-page{min-height:100vh;display:grid;place-items:center}.auth-form{width:min(420px,90vw);display:flex;flex-direction:column;padding:32px;gap:16px;border-radius:24px;background:#fffffff2;box-shadow:0 20px 50px #0d192b40}.auth-form input,.auth-form textarea,.form-stack input,.form-stack textarea{width:100%;padding:10px 14px;border-radius:12px;border:1px solid rgba(15,32,54,.2);background:#fafafae6;margin-top:8px}.auth-form input:focus,.auth-form textarea:focus,.form-stack input:focus,.form-stack textarea:focus{outline:none;border-color:#0f70ff6b;box-shadow:0 0 0 4px #0f70ff1f;background:#fffffff5}.auth-form textarea,.form-stack textarea{min-height:112px;resize:vertical}.form-stack{display:flex;flex-direction:column;gap:12px}.form-success{color:var(--success-600)}.form-error{color:var(--error-600)}.auth-tip{margin:0;color:var(--ink-700);line-height:1.7;text-align:center}.word-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:16px}.word-card{padding:16px;border-radius:16px;background:#0f20360d}.word-meaning{font-weight:600}.word-example{font-size:13px;color:#425466}.quiz-panel{margin-top:24px;padding:16px;border-radius:16px;background:#fffffff2;border:1px solid rgba(15,32,54,.1)}.quiz-question{display:flex;flex-direction:column;gap:12px}.quiz-choices{display:flex;flex-wrap:wrap;gap:8px}.record-list{list-style:none;padding:0;margin:8px 0 0;display:flex;flex-direction:column;gap:6px}.record-list li.correct{color:var(--success-600)}.record-list li.incorrect{color:var(--error-600)}.podium{display:flex;gap:12px;flex-wrap:wrap}.podium-card{min-width:180px;padding:16px 18px;border-radius:20px;background:linear-gradient(160deg,#ffffffeb,#f6f8ffd1),radial-gradient(circle at top right,rgba(255,189,133,.18),transparent 42%);border:1px solid rgba(255,255,255,.56);box-shadow:0 16px 28px #0f203614}.rank-row{display:grid;grid-template-columns:repeat(4,1fr);gap:8px;padding:14px 16px;border-radius:18px;background:#ffffffad;border:1px solid rgba(255,255,255,.6);box-shadow:0 10px 18px #0f20360a}.preview-card{margin-top:16px;padding:18px;border-radius:22px;background:linear-gradient(160deg,#ffffffe6,#f6faffd1),radial-gradient(circle at top right,rgba(122,194,255,.14),transparent 42%);border:1px solid rgba(255,255,255,.62);box-shadow:inset 0 1px #ffffff8c}.admin-word-card{gap:18px}.admin-word-card-head{display:flex;justify-content:space-between;gap:16px;align-items:start}.admin-word-card-head h3{margin:0 0 6px}.admin-word-phonetic{margin:0;color:var(--ink-500)}.admin-word-detail-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:14px}.admin-word-detail{padding:14px 16px;border-radius:16px;background:#0f20360a;border:1px solid rgba(15,32,54,.06)}.admin-word-detail span{display:block;margin-bottom:8px;color:var(--ink-500);font-size:14px}.admin-word-detail p{margin:0;line-height:1.7;color:var(--ink-900)}.admin-overview-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px}.admin-overview-item{padding:16px 18px;border-radius:18px;background:linear-gradient(160deg,#ffffffdb,#f3f7ffc2),radial-gradient(circle at top right,rgba(255,188,130,.18),transparent 42%);border:1px solid rgba(255,255,255,.62);box-shadow:0 10px 20px #0f20360d}.admin-overview-item span{display:block;margin-bottom:8px;color:var(--ink-500);font-size:14px}.admin-overview-item p{margin:0;color:var(--ink-900);font-size:18px;line-height:1.6}.admin-overview-actions{margin-top:18px}.task-pagination-bar{display:flex;align-items:center;justify-content:space-between;gap:14px;margin-bottom:18px;flex-wrap:wrap}.task-pagination-pages{display:flex;gap:8px;flex-wrap:wrap}.task-page-button{min-width:44px}.task-page-button.active{background:linear-gradient(135deg,#102847,#1a4f86);color:#fff;border-color:transparent;box-shadow:0 14px 24px #0f20362e}.checkin-board{overflow:auto;padding:6px;border-radius:22px;background:linear-gradient(180deg,#ffffffd6,#f3f7ffc7),radial-gradient(circle at top right,rgba(140,191,255,.14),transparent 40%);border:1px solid rgba(255,255,255,.6)}.checkin-row{display:grid;grid-auto-flow:column;grid-auto-columns:minmax(96px,1fr);gap:10px;min-width:max-content;margin-bottom:10px}.checkin-row:last-child{margin-bottom:0}.checkin-row span{padding:12px 14px;border-radius:16px;background:#ffffffc7;border:1px solid rgba(15,32,54,.06);text-align:center;color:var(--ink-700);box-shadow:0 10px 18px #0f20360a}.checkin-row span:first-child{font-weight:700;color:var(--ink-900);background:linear-gradient(135deg,#fffffff0,#fff2e7e6),radial-gradient(circle at top right,rgba(255,187,126,.18),transparent 40%)}.checkin-head span{font-size:13px;letter-spacing:.08em;color:var(--ink-500);background:#0f20360f;box-shadow:none}.page-loading{min-height:60vh;display:grid;place-items:center}.student-home-grid{gap:20px}.student-hero,.student-list-banner{display:grid;grid-template-columns:minmax(0,1.6fr) minmax(240px,.9fr);gap:20px;align-items:stretch;padding:28px;border-radius:28px;background:linear-gradient(135deg,#ffffffeb,#ffffffc2),radial-gradient(circle at top right,rgba(255,182,115,.35),transparent 45%);border:1px solid rgba(255,255,255,.45);box-shadow:0 22px 46px #0f203614;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px)}.student-hero-copy h2,.student-list-banner h2{margin:6px 0 12px;font-size:32px}.student-hero-note,.student-list-banner p{margin:0;color:var(--ink-700);line-height:1.7}.student-hero-tags{display:flex;flex-wrap:wrap;gap:10px;margin-top:18px}.student-hero-tags span{padding:8px 14px;border-radius:999px;background:#0f20360f;color:var(--ink-900)}.student-hero-panel,.student-list-banner-side{display:flex;flex-direction:column;justify-content:space-between;gap:12px;padding:20px;border-radius:22px;background:linear-gradient(180deg,#0f20360f,#0f203605);border:1px solid rgba(15,32,54,.08)}.student-hero-panel-label{color:var(--ink-500);font-size:14px}.student-hero-panel strong,.student-list-banner-side p:first-child{font-size:28px;line-height:1.1}.student-list-banner-side p{margin:0}.student-summary-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:16px}.student-stat-card{padding:20px;border-radius:22px;background:var(--surface-strong);border:1px solid rgba(255,255,255,.55);box-shadow:0 16px 30px #0f20360f}.student-stat-card span{display:block;color:var(--ink-500);margin-bottom:12px}.student-stat-card strong{font-size:32px;line-height:1.1}.student-stat-card p{margin:12px 0 0;color:var(--ink-700);line-height:1.7}.student-progress-meter{display:flex;flex-direction:column;gap:12px}.student-progress-track,.task-card-progress-bar,.study-progress-track,.quiz-progress-bar{width:100%;height:12px;border-radius:999px;background:#0f203614;overflow:hidden}.student-progress-track span,.task-card-progress-bar span,.study-progress-track span,.quiz-progress-bar span{display:block;height:100%;border-radius:inherit;background:linear-gradient(90deg,#ffba75,#ff7a45)}.student-progress-meta{display:flex;justify-content:space-between;gap:12px;color:var(--ink-700)}.student-overview-cards{margin-top:18px;display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px}.student-note-card{padding:18px;border-radius:18px;background:#0f20360a;border:1px solid rgba(15,32,54,.06)}.student-note-card h3{margin:0 0 10px}.student-note-card p{margin:0;color:var(--ink-700);line-height:1.7}.student-task-list-card{gap:16px}.task-card-main{display:flex;justify-content:space-between;gap:12px;align-items:start}.task-card-main h3{margin:0 0 4px}.task-card-main p{margin:0;color:var(--ink-700)}.task-status-inline{padding:8px 12px;border-radius:999px;background:#fffc;border:1px solid rgba(15,32,54,.08);color:var(--ink-900);white-space:nowrap}.task-card-progress{display:flex;flex-direction:column;gap:12px}.study-page-layout,.student-quiz-layout{gap:20px}.study-shell{display:flex;flex-direction:column;gap:18px}.study-progress-head{display:flex;justify-content:space-between;gap:12px;color:var(--ink-700)}.study-step-row{display:flex;gap:8px;flex-wrap:wrap}.study-step{width:36px;height:36px;display:inline-flex;align-items:center;justify-content:center;border-radius:999px;background:#0f203614;color:var(--ink-700);border:1px solid transparent}.study-step.done{background:#0b8b4d1f;color:var(--success-600)}.study-step.current{border-color:#ff7a4573;color:var(--warm-600);background:#ff7a4514}.study-word-card,.study-complete-card,.study-empty-state{padding:24px;border-radius:22px;background:linear-gradient(180deg,#ffffffeb,#ffffffd6),radial-gradient(circle at top right,rgba(255,198,145,.24),transparent 42%);border:1px solid rgba(15,32,54,.08)}.study-word-top{display:flex;justify-content:space-between;gap:14px;align-items:start;margin-bottom:20px}.study-word-top h3{margin:4px 0 8px;font-size:36px}.study-word-phonetic{margin:0;color:var(--ink-500)}.study-word-block{margin-bottom:18px}.study-word-block:last-of-type{margin-bottom:24px}.study-word-block span{display:block;margin-bottom:8px;color:var(--ink-500);font-size:14px}.study-word-block p{margin:0;line-height:1.8}.study-complete-card,.study-empty-state{display:flex;flex-direction:column;gap:18px}.study-complete-copy h3{margin:0 0 10px}.study-complete-copy p,.study-empty-state p{margin:0;line-height:1.8;color:var(--ink-700)}.quiz-shell{display:flex;flex-direction:column;gap:18px}.quiz-shell-head{display:flex;justify-content:space-between;gap:12px;align-items:end}.quiz-shell-head h3{margin:6px 0 0}.quiz-shell-head p:last-child{margin:0;font-size:24px;font-weight:700}.quiz-question-card{padding:24px;border-radius:22px;background:linear-gradient(180deg,#fffffff0,#ffffffd1),radial-gradient(circle at top right,rgba(145,190,255,.2),transparent 42%);border:1px solid rgba(15,32,54,.08)}.quiz-prompt-label{margin:0 0 12px;color:var(--ink-500)}.quiz-sentence{margin:0 0 22px;font-size:18px;line-height:1.8}.quiz-choice-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}.quiz-choice{padding:14px 16px;border-radius:16px;border:1px solid rgba(15,32,54,.12);background:#ffffffe6;cursor:pointer;text-align:left;min-height:56px}.quiz-choice.is-correct{border-color:#0b8b4d47;background:#0b8b4d1f;color:var(--success-600)}.quiz-choice.is-wrong{border-color:#c2303042;background:#c230301a;color:var(--error-600)}.quiz-choice.is-selected{border-color:#0b8b4d47}.quiz-choice.is-muted{opacity:.65}.quiz-side-note{margin:18px 0 0;color:var(--ink-700);line-height:1.7}.quiz-feedback-box{margin:18px 0;padding:14px 16px;border-radius:16px;border:1px solid transparent}.quiz-feedback-box p{margin:0}.quiz-feedback-box p+p{margin-top:8px}.quiz-feedback-box.success{background:#0b8b4d1a;border-color:#0b8b4d24;color:var(--success-600)}.quiz-feedback-box.error{background:#c230301a;border-color:#c2303024;color:var(--error-600)}.quiz-result-stack{display:flex;flex-direction:column;gap:18px}.quiz-result-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:14px}.quiz-result-tile{padding:18px;border-radius:18px;background:#0f20360a;border:1px solid rgba(15,32,54,.06)}.quiz-result-tile span{display:block;color:var(--ink-500);margin-bottom:10px}.quiz-result-tile strong{font-size:24px;line-height:1.4}.quiz-result-summary{padding:18px;border-radius:18px;background:#ff7a4514;border:1px solid rgba(255,122,69,.12)}.quiz-result-summary h3{margin:0 0 10px}.quiz-result-summary p{margin:0;line-height:1.7;color:var(--ink-700)}.wrong-word-list{display:flex;flex-direction:column;gap:12px}.wrong-word-card{display:flex;justify-content:space-between;gap:16px;padding:16px 18px;border-radius:18px;background:#0f20360a;border:1px solid rgba(15,32,54,.06)}.wrong-word-card h4{margin:6px 0 8px}.wrong-word-card p{margin:0}.wrong-word-answer{display:flex;flex-direction:column;gap:8px;color:var(--ink-700)}.quiz-perfect-note{margin:0;padding:18px;border-radius:18px;background:#0b8b4d14;color:var(--success-600)}.ranking-hero{margin-bottom:0}.ranking-podium-card{padding-top:30px;padding-bottom:12px}.podium-stage{display:flex;align-items:end;justify-content:center;gap:18px;min-height:460px;flex-wrap:wrap}.podium-slot{width:min(100%,240px);padding:18px 18px 22px;border-radius:24px 24px 20px 20px;color:#1f2d3d;box-shadow:0 18px 30px #0f20361a;border:1px solid rgba(255,255,255,.38)}.podium-slot h3{margin:12px 0 16px;font-size:24px}.podium-slot p{margin:8px 0 0}.podium-slot.place-1{min-height:390px;background:linear-gradient(180deg,#fff9e6fa,#f6e09aeb),linear-gradient(180deg,rgba(255,255,255,.5),transparent)}.podium-slot.place-2{min-height:300px;background:linear-gradient(180deg,#fafcfffa,#d6dfebeb),linear-gradient(180deg,rgba(255,255,255,.5),transparent)}.podium-slot.place-3{min-height:230px;background:linear-gradient(180deg,#fff6f0fa,#e0bb9deb),linear-gradient(180deg,rgba(255,255,255,.5),transparent)}.medal-badge{display:inline-flex;align-items:center;justify-content:center;min-width:72px;padding:8px 12px;border-radius:999px;font-weight:700}.place-1 .medal-badge{background:#d79b1f29;color:var(--gold-500)}.place-2 .medal-badge{background:#7f8da129;color:var(--silver-500)}.place-3 .medal-badge{background:#ab6f4729;color:var(--bronze-500)}.podium-rank{margin-top:16px;font-size:14px;letter-spacing:.18em;color:#0f20369e}.ranking-row-card{grid-template-columns:80px minmax(180px,1.4fr) 1fr 1fr 1.3fr;align-items:center;border-bottom:none;border-radius:18px;background:#ffffffb8}.ranking-column-head{background:#0f20360f;box-shadow:none}.ranking-column-cell{margin:0;font-weight:700;color:var(--ink-700)}.ranking-row-card p{margin:0}.ranking-row-card strong{display:block;margin-bottom:4px}.ranking-index{font-size:24px;font-weight:700}@media(max-width:1100px){.student-summary-grid,.quiz-result-grid,.student-overview-cards,.quiz-choice-grid,.admin-word-detail-grid,.admin-overview-grid,.student-hero,.student-list-banner{grid-template-columns:1fr}.podium-stage,.podium-slot.place-1,.podium-slot.place-2,.podium-slot.place-3{min-height:0}}@media(max-width:900px){.app-shell{grid-template-columns:1fr}.shell-sidebar{position:static;min-height:auto;flex-direction:row;flex-wrap:wrap}.sidebar-brand-card,.sidebar-user-card{width:100%}.nav-group{flex:1 1 100%}.shell-content{padding:20px}.student-hero-copy h2,.student-list-banner h2,.shell-header h1{font-size:28px}.task-card-main,.admin-word-card-head,.wrong-word-card,.quiz-shell-head,.study-progress-head{flex-direction:column;align-items:start}.rank-row,.ranking-row-card{grid-template-columns:1fr}}@media(max-width:640px){.shell-content,.panel-card,.student-hero,.student-list-banner,.study-word-card,.study-complete-card,.study-empty-state,.quiz-question-card{padding:18px}.student-hero-tags,.button-row,.task-meta{width:100%}.button-row>*{width:100%}.shell-header-banner{padding:18px 20px}.study-word-top h3{font-size:30px}}
