.navbar{position:fixed;top:0;left:0;right:0;height:56px;background:#fffffff2;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;padding:0 var(--space-6);z-index:100;box-shadow:var(--shadow-sm)}.navbar-left{display:flex;align-items:center;gap:var(--space-4)}.navbar-toggle{display:none;width:40px;height:40px;background:none;border:none;border-radius:var(--radius-md);cursor:pointer;color:var(--text-primary);transition:all .2s ease}.navbar-toggle:hover{background:var(--surface-hover)}.navbar-logo{display:flex;align-items:center;gap:var(--space-3);text-decoration:none;color:var(--text-primary)}.navbar-logo-icon{width:40px;height:40px;background:var(--gradient-primary);border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;color:#fff;box-shadow:0 4px 12px #667eea4d}.navbar-logo-icon svg{width:24px;height:24px}.navbar-logo-text{font-size:20px;font-weight:700;background:var(--gradient-primary);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;letter-spacing:-.5px}.navbar-logo-subtitle{font-size:12px;font-weight:500;color:var(--text-secondary);margin-left:-8px}.navbar-right{display:flex;align-items:center;gap:var(--space-6)}.navbar-systems{display:flex;align-items:center;gap:var(--space-1);background:var(--surface-hover);padding:4px;border-radius:var(--radius-full)}.system-link{padding:6px 12px;border-radius:var(--radius-full);text-decoration:none;font-size:14px;font-weight:500;color:var(--text-secondary);transition:all .2s ease;position:relative}.system-link:hover{color:var(--text-primary);background:#0000000a}.system-link.active{color:var(--primary);background:#6366f11a;font-weight:600}.navbar-user{position:relative}.navbar-user-button{display:flex;align-items:center;gap:var(--space-2);padding:6px 12px 6px 6px;background:var(--surface-hover);border:1px solid var(--border);border-radius:var(--radius-full);cursor:pointer;transition:all .2s ease}.navbar-user-button:hover{border-color:var(--primary-light);background:linear-gradient(135deg,#f8fafc,#f1f5f9)}.user-avatar{width:32px;height:32px;background:var(--gradient-primary);border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;font-size:14px;font-weight:600}.user-name{font-size:14px;font-weight:500;color:var(--text-primary)}.user-dropdown{position:absolute;top:calc(100% + 8px);right:0;min-width:160px;background:linear-gradient(135deg,#fafafa,#f5f5f5);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);overflow:hidden;animation:fadeInScale .2s ease-out}.user-dropdown-item{width:100%;padding:12px 16px;background:none;border:none;text-align:left;font-size:14px;color:var(--text-primary);cursor:pointer;transition:all .2s ease}.user-dropdown-item:hover{background:var(--surface-hover)}.user-dropdown-item.logout{color:var(--error)}.user-dropdown-item.logout:hover{background:#ef44441a}@media (max-width: 1024px){.navbar-toggle{display:flex;align-items:center;justify-content:center}.navbar-logo-text,.navbar-logo-subtitle,.navbar-systems{display:none}}@media (max-width: 768px){.navbar{padding:0 var(--space-4)}.user-name{display:none}.navbar-user-button{padding:4px}}.sidebar{position:fixed;top:56px;left:0;width:220px;height:calc(100vh - 56px);background:#fffffff2;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-right:1px solid var(--border);padding:var(--space-4);overflow-y:auto;z-index:90;transition:all .3s ease}.main-layout.writing-fullscreen .sidebar{transform:translate(-100%);pointer-events:none;opacity:0}.sidebar.closed{transform:translate(-100%)}.sidebar-nav{display:flex;flex-direction:column;gap:var(--space-1)}.sidebar-link{display:flex;align-items:center;gap:var(--space-3);padding:10px 14px;border-radius:12px;text-decoration:none;font-size:14px;font-weight:500;color:var(--text-secondary);transition:all .2s ease;margin-bottom:4px}.sidebar-link:hover{background:#6366f10d;color:var(--primary)}.sidebar-link.active{background:#6366f11a;color:var(--primary);font-weight:600}.sidebar-system-indicator{padding:var(--space-3) var(--space-4);margin-bottom:var(--space-4);border-radius:var(--radius-md);font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.sidebar-system-indicator.speaking{background:#10b9811a;color:var(--speaking-dark)}.sidebar-system-indicator.reading{background:#3b82f61a;color:var(--reading-dark)}.sidebar-system-indicator.writing{background:#f59e0b1a;color:var(--writing-dark)}.sidebar-overlay{display:none;position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;z-index:80;animation:fadeIn .3s ease-out}@media (max-width: 1024px){.sidebar{transform:translate(-100%)}.sidebar.open{transform:translate(0);box-shadow:4px 0 20px #0000001a}.sidebar-overlay{display:block}}@media (max-width: 768px){.sidebar{width:280px}}.sidebar-link.admin-link{background:linear-gradient(135deg,#ef44441a,#dc26261a);color:#dc2626;border:1px solid rgba(239,68,68,.2);margin-top:var(--space-2)}.sidebar-link.admin-link:hover{background:linear-gradient(135deg,#ef444433,#dc262633);color:#b91c1c}.sidebar-link.admin-link.active{background:linear-gradient(135deg,#ef4444,#dc2626);color:#fff;border-color:transparent;box-shadow:0 2px 8px #ef444466}.main-layout{min-height:100vh;display:flex;flex-direction:column;background:linear-gradient(135deg,#f5f7fa,#e4e8ec)}.main-container{display:flex;flex:1;padding-top:56px}.main-content{flex:1;margin-left:220px;padding:var(--space-6);overflow-y:auto;min-height:calc(100vh - 56px);animation:fadeIn .3s ease-out}.main-content.no-padding{padding:0;margin-left:0;display:flex;flex-direction:column}.main-layout.writing-fullscreen .main-container{padding-top:48px}.main-layout.writing-fullscreen .main-content{margin-left:0;padding:0;min-height:calc(100vh - 48px);display:flex;flex-direction:column}@media (max-width: 1024px){.main-content{margin-left:0;padding:var(--space-4)}}@media (max-width: 768px){.main-content{padding:var(--space-3)}}.auth-layout{min-height:100vh;display:flex;align-items:center;justify-content:center;position:relative;background:linear-gradient(135deg,#667eea,#764ba2);overflow:hidden}.auth-background{position:absolute;top:0;right:0;bottom:0;left:0;overflow:hidden}.auth-blob{position:absolute;border-radius:50%;filter:blur(80px);opacity:.6;animation:float 20s ease-in-out infinite}.auth-blob-1{width:500px;height:500px;background:#ffffff26;top:-10%;left:-10%;animation-delay:0s}.auth-blob-2{width:400px;height:400px;background:#764ba24d;bottom:-10%;right:-10%;animation-delay:-7s}.auth-blob-3{width:300px;height:300px;background:#667eea33;top:50%;left:50%;transform:translate(-50%,-50%);animation-delay:-14s}.auth-content{position:relative;z-index:1;width:100%;max-width:440px;padding:24px}.auth-decoration{position:absolute;z-index:0}.auth-decoration-1{top:10%;right:10%;width:100px;height:100px;border:2px solid rgba(255,255,255,.1);border-radius:50%;animation:spin 30s linear infinite}.auth-decoration-2{bottom:15%;left:5%;width:60px;height:60px;background:#ffffff0d;border-radius:var(--radius-md);transform:rotate(45deg);animation:float 8s ease-in-out infinite}@media (max-width: 480px){.auth-content{padding:16px}.auth-blob-1,.auth-blob-2,.auth-blob-3{display:none}}.admin-layout{display:flex;min-height:100vh;background:#0f172a}.admin-sidebar{width:260px;background:linear-gradient(180deg,#1e293b,#0f172a);border-right:1px solid rgba(255,255,255,.1);display:flex;flex-direction:column;transition:width .3s ease;position:fixed;left:0;top:0;height:100vh;z-index:100}.admin-sidebar.collapsed{width:70px}.admin-sidebar-header{padding:20px;border-bottom:1px solid rgba(255,255,255,.1);display:flex;align-items:center;justify-content:space-between}.admin-logo{display:flex;align-items:center;gap:12px}.admin-logo-icon{font-size:28px}.admin-logo-text{font-size:18px;font-weight:700;color:#f1f5f9;white-space:nowrap}.admin-collapse-btn{background:#ffffff1a;border:none;color:#94a3b8;width:28px;height:28px;border-radius:6px;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:12px;transition:all .2s}.admin-collapse-btn:hover{background:#fff3;color:#f1f5f9}.admin-nav{flex:1;padding:16px 12px;overflow-y:auto}.admin-nav-item{display:flex;align-items:center;gap:12px;padding:14px 16px;color:#94a3b8;text-decoration:none;border-radius:10px;margin-bottom:6px;transition:all .2s;font-size:14px;font-weight:500}.admin-nav-item:hover{background:#6366f126;color:#c7d2fe}.admin-nav-item.active{background:linear-gradient(135deg,#6366f1,#4f46e5);color:#fff;box-shadow:0 4px 15px #6366f166}.admin-nav-icon{font-size:20px;flex-shrink:0}.admin-nav-label{white-space:nowrap}.admin-sidebar.collapsed .admin-nav-item{justify-content:center;padding:14px}.admin-sidebar.collapsed .admin-nav-label{display:none}.admin-sidebar-footer{padding:16px 12px;border-top:1px solid rgba(255,255,255,.1)}.admin-main{flex:1;margin-left:260px;transition:margin-left .3s ease;display:flex;flex-direction:column;min-height:100vh}.admin-sidebar.collapsed~.admin-main{margin-left:70px}.admin-header{background:#1e293bcc;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-bottom:1px solid rgba(255,255,255,.1);padding:16px 32px;display:flex;justify-content:space-between;align-items:center;position:sticky;top:0;z-index:50}.admin-page-title{font-size:24px;font-weight:700;color:#f1f5f9;margin:0}.admin-header-right{display:flex;align-items:center;gap:20px}.admin-user-info{display:flex;align-items:center;gap:12px}.admin-user-role{background:linear-gradient(135deg,#f43f5e,#e11d48);color:#fff;padding:4px 12px;border-radius:20px;font-size:12px;font-weight:600}.admin-user-name{color:#e2e8f0;font-weight:500}.admin-logout-btn{background:#ef444433;border:1px solid rgba(239,68,68,.3);color:#fca5a5;padding:8px 16px;border-radius:8px;font-size:14px;cursor:pointer;transition:all .2s}.admin-logout-btn:hover{background:#ef44444d;color:#fff}.admin-content{flex:1;padding:24px 32px;overflow-y:auto}@media (max-width: 1024px){.admin-sidebar{width:70px}.admin-sidebar .admin-nav-label,.admin-sidebar .admin-logo-text{display:none}.admin-main{margin-left:70px}}@media (max-width: 768px){.admin-sidebar{position:fixed;transform:translate(-100%);width:260px;z-index:200}.admin-sidebar.open{transform:translate(0)}.admin-sidebar.open .admin-nav-label,.admin-sidebar.open .admin-logo-text{display:block}.admin-main{margin-left:0}.admin-content{padding:16px}}.input-wrapper{display:flex;flex-direction:column;gap:6px;width:100%}.input-label{font-size:14px;font-weight:500;color:var(--text-primary)}.input-required{color:var(--error);margin-left:4px}.input-container{position:relative;display:flex;align-items:center}.input-field{width:100%;background:#ffffffe6;border:2px solid var(--border);border-radius:var(--radius-md);padding:12px 16px;font-size:16px;font-family:inherit;color:var(--text-primary);transition:all .3s ease;line-height:1.5;height:48px;box-sizing:border-box}.input-field:hover{border-color:var(--text-muted)}.input-field:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 4px #667eea1a;background:#fff}.input-field::placeholder{color:var(--text-muted)}.input-field:disabled{background:var(--surface-hover);cursor:not-allowed;opacity:.6}.input-field.has-icon-left{padding-left:44px}.input-field.has-icon-right,.input-field:has(+.input-icon-right){padding-right:44px}.input-icon-left,.input-icon-right{position:absolute;display:flex;align-items:center;justify-content:center;width:20px;height:20px;color:var(--text-muted);pointer-events:none;transition:color .2s ease;top:50%;transform:translateY(-50%)}.input-icon-left{left:12px;z-index:1}.input-icon-right{right:12px;z-index:1}.input-field:focus~.input-icon-left,.input-field:focus~.input-icon-right{color:var(--primary)}.input-field.error{border-color:var(--error)}.input-field.error:focus{box-shadow:0 0 0 4px #ef44441a}.input-error-text{font-size:12px;color:var(--error);margin:0;display:flex;align-items:center;gap:4px}.input-helper-text{font-size:13px;color:var(--text-secondary);margin:0}.input-sm .input-field{padding:8px 12px;font-size:14px}.input-lg .input-field{padding:16px 20px;font-size:18px}textarea.input-field{min-height:120px;resize:vertical;line-height:1.6}.input-search .input-field{padding-left:44px;border-radius:var(--radius-full);background:var(--surface-hover);border-color:transparent}.input-search .input-field:focus{background:#fff;border-color:var(--primary)}.input-clearable .input-field{padding-right:44px}.input-clear-btn{position:absolute;right:12px;background:none;border:none;color:var(--text-muted);cursor:pointer;padding:4px;border-radius:50%;display:flex;align-items:center;justify-content:center;transition:all .2s ease}.input-clear-btn:hover{background:var(--surface-hover);color:var(--text-primary)}.line-chart-wrapper{position:relative;width:100%;padding:10px 0}.line-chart-svg{display:block;margin:0 auto}.line-chart-empty{display:flex;align-items:center;justify-content:center;color:#9ca3af;font-size:14px;background:linear-gradient(135deg,#f8fafc,#f1f5f9);border-radius:12px}.chart-axis-label{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;font-weight:500;-webkit-user-select:none;user-select:none}.chart-line{animation:drawLine 1s ease-out forwards}@keyframes drawLine{0%{stroke-dasharray:1000;stroke-dashoffset:1000}to{stroke-dasharray:1000;stroke-dashoffset:0}}.chart-area{animation:fadeInArea 1.2s ease-out forwards;opacity:0}@keyframes fadeInArea{0%{opacity:0}to{opacity:1}}.chart-point-group{cursor:pointer;transition:all .2s ease}.chart-point{transition:all .2s ease}.chart-point-glow{transition:all .3s ease}.chart-tooltip{position:absolute;transform:translate(-50%,-100%);background:linear-gradient(135deg,#1e293b,#334155);color:#fff;padding:8px 14px;border-radius:8px;font-size:12px;pointer-events:none;z-index:100;box-shadow:0 4px 12px #00000026;animation:tooltipFadeIn .2s ease}.chart-tooltip:after{content:"";position:absolute;bottom:-6px;left:50%;transform:translate(-50%);border-left:6px solid transparent;border-right:6px solid transparent;border-top:6px solid #334155}@keyframes tooltipFadeIn{0%{opacity:0;transform:translate(-50%,-110%)}to{opacity:1;transform:translate(-50%,-100%)}}.tooltip-value{font-size:16px;font-weight:700;margin-bottom:2px;text-align:center}.tooltip-date{font-size:11px;opacity:.8;text-align:center}@media (max-width: 768px){.chart-axis-label{font-size:10px!important}}.auth-card{width:100%;background:#fffffffa!important;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border:1px solid rgba(255,255,255,.5)!important;border-radius:var(--radius-xl)!important;box-shadow:0 25px 50px -12px #00000040!important;animation:fadeInScale .5s ease-out;color-scheme:light}.auth-card .card-content{padding:var(--space-10)}.auth-card .input-field,.auth-card input{background:#fffffff2!important;color:#0f172a!important;border-color:#e2e8f0!important}.auth-card .input-field::placeholder,.auth-card input::placeholder{color:#64748b!important}.auth-card .input-field:focus,.auth-card input:focus{border-color:#6366f1!important;background:#fff!important}.auth-card label,.auth-card .auth-title{color:#0f172a!important}.auth-card .auth-subtitle{color:#475569!important}@keyframes fadeInScale{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}.auth-header{text-align:center;margin-bottom:var(--space-8)}.auth-logo{width:72px;height:72px;background:var(--gradient-primary);border-radius:var(--radius-lg);display:flex;align-items:center;justify-content:center;margin:0 auto var(--space-5);color:#fff;box-shadow:0 10px 25px #667eea66;animation:float 3s ease-in-out infinite}.auth-title{font-size:26px;font-weight:700;color:var(--text-primary);margin-bottom:var(--space-2)}.auth-subtitle{font-size:14px;color:var(--text-secondary)}.auth-form{display:flex;flex-direction:column;gap:var(--space-5)}.form-group{display:flex;flex-direction:column;gap:var(--space-2)}.form-label{font-size:14px;font-weight:500;color:var(--text-primary)}.form-label .required{color:var(--error);margin-left:4px}.auth-options{display:flex;justify-content:space-between;align-items:center;font-size:14px}.remember-me{display:flex;align-items:center;gap:var(--space-2);cursor:pointer;color:var(--text-secondary);transition:color .2s}.remember-me:hover{color:var(--text-primary)}.remember-me input[type=checkbox]{width:16px;height:16px;accent-color:var(--primary);cursor:pointer}.forgot-password{color:var(--primary);text-decoration:none;font-weight:500;transition:all .2s}.forgot-password:hover{color:var(--primary-dark);text-decoration:underline}.auth-error{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-3) var(--space-4);background:#ef44441a;border-radius:var(--radius-md);color:var(--error);font-size:14px;animation:fadeIn .3s ease-out}.auth-footer{text-align:center;margin-top:var(--space-6);padding-top:var(--space-6);border-top:1px solid var(--border);font-size:14px;color:var(--text-secondary)}.auth-link{color:var(--primary);font-weight:600;text-decoration:none;margin-left:4px;transition:all .2s}.auth-link:hover{color:var(--primary-dark);text-decoration:underline}.auth-steps{display:flex;align-items:center;justify-content:center;gap:var(--space-3);margin-bottom:var(--space-6)}.step{display:flex;align-items:center;gap:var(--space-2);font-size:13px;color:var(--text-muted)}.step.active{color:var(--primary);font-weight:500}.step.completed{color:var(--success)}.step-number{width:28px;height:28px;border-radius:50%;background:var(--surface-hover);display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:600;transition:all .3s}.step.active .step-number{background:var(--gradient-primary);color:#fff;box-shadow:0 4px 12px #667eea66}.step.completed .step-number{background:var(--success);color:#fff}.step-line{width:40px;height:2px;background:var(--border);transition:all .3s}.step-line.completed{background:var(--success)}.select-field{width:100%;background:#ffffffe6;border:2px solid var(--border);border-radius:var(--radius-md);padding:var(--space-3) var(--space-4);font-size:15px;font-family:inherit;color:var(--text-primary);transition:all .3s ease;cursor:pointer;-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' viewBox='0 0 24 24' fill='none' stroke='%2364748b' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'%3E%3C/polyline%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center;background-size:18px;padding-right:40px}.select-field:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 4px #667eea1a;background:#fff}.form-actions{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-3)}@media (max-width: 480px){.auth-card .card-content{padding:var(--space-6)}.auth-title{font-size:22px}.form-actions{grid-template-columns:1fr}}.dashboard-page{padding:24px;max-width:1100px;margin:0 auto}.dashboard-welcome{display:flex;justify-content:space-between;align-items:center;padding:28px 32px;margin-bottom:24px;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:16px;color:#fff}.welcome-title{font-size:24px;font-weight:700;margin:0 0 6px}.welcome-subtitle{font-size:14px;opacity:.85;margin:0}.welcome-info{display:flex;gap:10px;align-items:center}.cefr-badge{background:#fff3;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);padding:6px 14px;border-radius:20px;font-size:13px;font-weight:600}.institution-tag{background:#ffffff26;padding:6px 14px;border-radius:20px;font-size:13px}.dashboard-section{margin-bottom:24px}.quick-actions{display:grid;grid-template-columns:repeat(4,1fr);gap:12px}.quick-action-btn{display:flex;flex-direction:column;align-items:center;gap:6px;padding:16px 12px;background:#fff;border-radius:12px;box-shadow:0 1px 3px #00000014;text-decoration:none;color:#333;transition:all .2s ease;cursor:pointer}.quick-action-btn:hover{transform:translateY(-2px);box-shadow:0 4px 12px #0000001f}.quick-action-icon{font-size:24px}.quick-action-label{font-size:13px;font-weight:500}.section-title{font-size:18px;font-weight:600;color:#1a1a2e;margin:0 0 16px}.modules-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}.modules-grid-4{grid-template-columns:repeat(4,1fr)}@media (max-width: 1024px){.modules-grid-4{grid-template-columns:repeat(2,1fr)}}.module-card-link{text-decoration:none;color:inherit}.module-card{transition:all .25s ease}.module-card:hover{transform:translateY(-4px);box-shadow:0 8px 24px #0000001f}.module-card .card-content{text-align:center;padding:28px 20px}.module-icon-wrapper{width:64px;height:64px;border-radius:16px;display:flex;align-items:center;justify-content:center;margin:0 auto 16px}.module-icon{font-size:28px}.module-title{font-size:17px;font-weight:600;margin:0 0 8px;color:#1a1a2e}.module-desc{font-size:13px;color:#666;margin:0 0 14px;line-height:1.5}.module-enter{font-size:14px;font-weight:500}.tip-card{background:linear-gradient(135deg,#f8f9ff,#eef1ff);border:1px solid #e0e4ff}.tip-card .card-content{display:flex;align-items:center;gap:16px;padding:20px 24px}.tip-icon{font-size:32px;flex-shrink:0}.tip-content h3{font-size:15px;font-weight:600;margin:0 0 4px;color:#1a1a2e}.tip-content p{font-size:13px;color:#666;margin:0}@media (max-width: 768px){.dashboard-welcome{flex-direction:column;align-items:flex-start;gap:12px}.quick-actions{grid-template-columns:repeat(2,1fr)}.modules-grid{grid-template-columns:1fr}}.about-platform-page{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;color:#333;background-color:#f5f7fa;min-height:100vh;padding-top:0}.about-top-nav{position:sticky;top:0;z-index:100;display:flex;justify-content:space-between;align-items:center;padding:16px 32px;background:#fffffff2;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-bottom:1px solid rgba(0,0,0,.08);box-shadow:0 2px 12px #0000000a}.back-home-link{display:flex;align-items:center;gap:8px;padding:10px 18px;background:linear-gradient(135deg,#6366f1,#8b5cf6);color:#fff;text-decoration:none;border-radius:12px;font-size:14px;font-weight:600;transition:all .25s ease;box-shadow:0 4px 12px #6366f140}.back-home-link:hover{transform:translateY(-2px);box-shadow:0 6px 20px #6366f159}.back-home-link svg{transition:transform .2s ease}.back-home-link:hover svg{transform:translate(-4px)}.nav-brand{font-size:16px;font-weight:700;color:#1f2937;letter-spacing:-.01em}@keyframes fadeIn{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.fade-in{animation:fadeIn .8s ease-out forwards}.about-hero{height:400px;background:linear-gradient(135deg,#0052cc,#0091ff);display:flex;align-items:center;justify-content:center;text-align:center;color:#fff;padding:0 24px;position:relative;overflow:hidden}.about-hero:before{content:"";position:absolute;top:-50%;left:-20%;width:80%;height:200%;background:radial-gradient(circle,rgba(255,255,255,.1) 0%,transparent 70%);transform:rotate(30deg)}.about-title{font-size:48px;font-weight:800;margin-bottom:24px;letter-spacing:-1px;text-shadow:0 4px 12px rgba(0,0,0,.1)}.about-subtitle{font-size:20px;opacity:.95;max-width:700px;margin:0 auto;line-height:1.6;font-weight:300}.sticky-nav{position:sticky;top:0;background:#fffffff2;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);padding:16px 0;display:flex;justify-content:center;gap:16px;z-index:100;box-shadow:0 4px 20px #0000000d;border-bottom:1px solid rgba(0,0,0,.05)}.nav-btn{display:flex;align-items:center;gap:8px;padding:10px 24px;border-radius:30px;border:none;background:transparent;color:#666;font-weight:600;cursor:pointer;transition:all .3s ease;font-size:15px}.nav-btn:hover{background:#f0f4ff;color:#0052cc}.nav-btn.active{background:#0052cc;color:#fff;box-shadow:0 4px 12px #0052cc33}.content-wrapper{max-width:1200px;margin:0 auto;padding:0 24px}.system-section,.about-section{padding:80px 0;border-bottom:1px solid #e5e7eb}.system-section:last-of-type{border-bottom:1px solid #e5e7eb}.section-container{max-width:1000px;margin:0 auto}.section-header{display:flex;align-items:center;gap:20px;margin-bottom:24px}.icon-wrapper{width:64px;height:64px;border-radius:16px;display:flex;align-items:center;justify-content:center;color:#fff;box-shadow:0 8px 24px #0000001a}.bg-blue{background:linear-gradient(135deg,#3b82f6,#2563eb)}.bg-green{background:linear-gradient(135deg,#10b981,#059669)}.bg-purple{background:linear-gradient(135deg,#8b5cf6,#7c3aed)}.text-blue{color:#2563eb}.text-green{color:#059669}.text-purple{color:#7c3aed}.section-header h2{font-size:32px;font-weight:700;color:#1a1a1a;margin:0}.section-desc{font-size:18px;color:#4b5563;line-height:1.8;margin-bottom:48px;max-width:800px}.features-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(320px,1fr));gap:32px}.feature-card{background:#fff;border-radius:20px;padding:32px;box-shadow:0 4px 20px #0000000a;border:1px solid #f3f4f6;transition:transform .3s ease,box-shadow .3s ease;display:flex;flex-direction:column}.feature-card:hover{transform:translateY(-8px);box-shadow:0 12px 40px #00000014}.card-header{display:flex;align-items:center;gap:12px;margin-bottom:16px}.card-header h3{font-size:20px;font-weight:700;color:#1f2937;margin:0}.feature-content{font-size:15px;color:#4b5563;line-height:1.6;margin-bottom:24px;flex-grow:1}.theory-box{background:#f8fafc;border-left:4px solid #94a3b8;padding:16px 20px;border-radius:0 8px 8px 0;position:relative}.quote-icon{position:absolute;top:16px;left:-10px;background:#f8fafc;color:#94a3b8;padding:2px}.theory-text{font-size:13px;color:#64748b;font-style:italic;line-height:1.5;margin:0}.models-section{background-color:#fff}.models-table-container{overflow-x:auto;margin-top:32px;box-shadow:0 4px 20px #0000000d;border-radius:12px}.models-table{width:100%;border-collapse:collapse;min-width:600px}.models-table th,.models-table td{padding:16px 24px;text-align:left;border-bottom:1px solid #e5e7eb}.models-table th{background-color:#f8fafc;font-weight:600;color:#475569;font-size:14px;text-transform:uppercase;letter-spacing:.5px}.models-table td{font-size:15px;color:#334155}.models-table tr:last-child td{border-bottom:none}.models-table tr:hover{background-color:#f1f5f9}.badge{display:inline-block;padding:4px 12px;background-color:#e0e7ff;color:#4338ca;border-radius:9999px;font-size:12px;font-weight:600}.font-bold{font-weight:600;color:#1e293b}.team-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:24px;margin-bottom:64px}.team-member{background:#fff;border-radius:12px;padding:24px;display:flex;align-items:center;gap:20px;box-shadow:0 2px 10px #00000008}.member-avatar{width:60px;height:60px;background:#e0e7ff;color:#0052cc;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:24px;font-weight:700;flex-shrink:0}.member-info h4{font-size:18px;margin:0 0 4px;color:#1a1a1a}.member-role{font-size:14px;color:#0052cc;font-weight:600;margin:0 0 4px}.member-org{font-size:13px;color:#666;margin:0}.support-unit{text-align:center;margin-top:48px;padding-top:48px;border-top:1px solid #e5e7eb}.support-unit p{font-size:16px;color:#666;margin-bottom:16px}.unit-logo-placeholder{display:inline-block;padding:12px 32px;background:#fff;border:1px solid #e2e8f0;border-radius:8px;font-weight:700;color:#1a1a1a;font-size:18px;box-shadow:0 2px 8px #0000000d}.cta-section{padding:80px 0;text-align:center;background:#f0f9ff;border-radius:32px;margin:64px 0}.cta-content h2{font-size:36px;font-weight:800;color:#1e3a8a;margin-bottom:32px}.cta-button{display:inline-flex;align-items:center;gap:12px;background:#0052cc;color:#fff;padding:16px 48px;border-radius:50px;font-size:18px;font-weight:700;text-decoration:none;transition:all .3s ease;box-shadow:0 8px 24px #0052cc4d}.cta-button:hover{background:#0043a8;transform:scale(1.05);box-shadow:0 12px 32px #0052cc66}.references-section{padding:48px 0;border-top:1px solid #e5e7eb;margin-bottom:48px}.references-section h3{font-size:20px;color:#374151;margin-bottom:24px}.references-list{list-style:none;padding:0;display:grid;gap:12px}.references-list li{font-size:13px;color:#6b7280;padding-left:16px;text-indent:-16px;line-height:1.5}.about-footer{background:#111827;color:#fff;padding:64px 24px;text-align:center}.back-home-btn{display:inline-flex;align-items:center;gap:8px;background:#ffffff1a;color:#fff;padding:12px 32px;border-radius:30px;font-weight:600;text-decoration:none;transition:all .3s ease;margin-bottom:32px;border:1px solid rgba(255,255,255,.2)}.back-home-btn:hover{background:#fff;color:#111827}.copyright{color:#9ca3af;font-size:14px;margin:0}@media (max-width: 768px){.about-title{font-size:32px}.about-subtitle{font-size:16px}.about-hero{height:320px}.nav-btn span{display:none}.nav-btn{padding:10px;border-radius:50%}.section-header h2{font-size:24px}.section-desc{font-size:16px}.feature-card{padding:24px}}.assessment-page{min-height:100vh;background:linear-gradient(135deg,#f5f7fa,#e4e8ec);padding:24px}.assessment-select{max-width:900px;margin:0 auto}.assessment-header{text-align:center;margin-bottom:40px;position:relative}.assessment-header .back-btn{position:absolute;left:0;top:0;display:flex;align-items:center;gap:8px;background:#fff;border:none;padding:10px 16px;border-radius:8px;cursor:pointer;font-size:14px;color:#666;box-shadow:0 2px 8px #00000014;transition:all .2s}.assessment-header .back-btn:hover{background:#f5f5f5;color:#333}.assessment-header h1{font-size:32px;font-weight:700;color:#1a1a2e;margin-bottom:8px}.assessment-header .subtitle{font-size:16px;color:#666}.mode-cards{display:grid;grid-template-columns:repeat(2,1fr);gap:24px;margin-bottom:32px}.mode-card{background:#fff;border-radius:16px;padding:32px;text-align:center;cursor:pointer;transition:all .3s ease;box-shadow:0 4px 20px #00000014;border:2px solid transparent}.mode-card:hover{transform:translateY(-4px);box-shadow:0 8px 30px #0000001f;border-color:#667eea}.mode-icon{width:80px;height:80px;border-radius:50%;display:flex;align-items:center;justify-content:center;margin:0 auto 20px}.mode-icon.quiz{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.mode-icon.chat{background:linear-gradient(135deg,#10b981,#059669);color:#fff}.mode-card h3{font-size:20px;font-weight:600;color:#1a1a2e;margin-bottom:12px}.mode-card p{font-size:14px;color:#666;line-height:1.6;margin-bottom:16px}.mode-meta{display:flex;justify-content:center;gap:16px;margin-bottom:20px}.mode-meta span{font-size:13px;color:#888;background:#f5f5f5;padding:4px 12px;border-radius:20px}.mode-btn{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;padding:12px 24px;border-radius:25px;font-size:15px;font-weight:600;cursor:pointer;display:inline-flex;align-items:center;gap:8px;transition:all .2s}.mode-btn:hover{transform:scale(1.05);box-shadow:0 4px 15px #667eea66}.assessment-tips{background:#fff;border-radius:12px;padding:24px;box-shadow:0 2px 12px #0000000f}.assessment-tips h4{font-size:16px;color:#333;margin-bottom:12px}.assessment-tips ul{margin:0;padding-left:20px}.assessment-tips li{font-size:14px;color:#666;line-height:1.8}.assessment-quiz{max-width:700px;margin:0 auto}.quiz-header{background:#fff;border-radius:12px;padding:20px;margin-bottom:24px;box-shadow:0 2px 12px #0000000f}.quiz-header .back-btn{display:inline-flex;align-items:center;gap:8px;background:none;border:none;padding:8px 12px;cursor:pointer;font-size:14px;color:#666;margin-bottom:12px}.quiz-header .back-btn:hover{color:#333}.progress-info{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}.category-tag{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:4px 12px;border-radius:20px;font-size:13px;font-weight:500}.progress-text{font-size:14px;color:#888}.progress-bar{height:6px;background:#e0e0e0;border-radius:3px;overflow:hidden}.progress-fill{height:100%;background:linear-gradient(90deg,#667eea,#764ba2);border-radius:3px;transition:width .3s ease}.quiz-content{background:#fff;border-radius:16px;padding:32px;box-shadow:0 4px 20px #00000014;margin-bottom:24px}.question-text{font-size:20px;font-weight:600;color:#1a1a2e;margin-bottom:24px;line-height:1.5}.options-grid{display:grid;gap:12px}.options-grid.multi-select{grid-template-columns:repeat(2,1fr)}.option-btn{display:flex;align-items:center;gap:12px;padding:16px 20px;background:#f8f9fa;border:2px solid transparent;border-radius:12px;cursor:pointer;text-align:left;transition:all .2s}.option-btn:hover{background:#f0f4ff;border-color:#667eea}.option-btn.selected{background:linear-gradient(135deg,#667eea15,#764ba215);border-color:#667eea}.option-btn .checkbox{width:24px;height:24px;border:2px solid #ddd;border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0}.option-btn.selected .checkbox{border-color:#667eea;color:#667eea}.option-label{font-size:15px;color:#333}.quiz-footer{display:flex;justify-content:space-between;gap:16px}.nav-btn{display:flex;align-items:center;gap:8px;padding:12px 24px;border-radius:25px;font-size:15px;font-weight:500;cursor:pointer;transition:all .2s}.nav-btn.prev{background:#fff;border:2px solid #ddd;color:#666}.nav-btn.prev:hover:not(:disabled){border-color:#999;color:#333}.nav-btn.next{background:linear-gradient(135deg,#667eea,#764ba2);border:none;color:#fff;margin-left:auto}.nav-btn.next:hover:not(:disabled){transform:scale(1.05);box-shadow:0 4px 15px #667eea66}.nav-btn:disabled{opacity:.5;cursor:not-allowed}.assessment-chat{max-width:700px;margin:0 auto}.chat-header{display:flex;align-items:center;gap:16px;margin-bottom:24px}.chat-header .back-btn{display:flex;align-items:center;gap:8px;background:#fff;border:none;padding:10px 16px;border-radius:8px;cursor:pointer;font-size:14px;color:#666}.chat-header h2{font-size:20px;color:#333}.chat-container{background:#fff;border-radius:16px;overflow:hidden;box-shadow:0 4px 20px #00000014}.chat-messages{min-height:400px;padding:24px}.message{display:flex;gap:12px;margin-bottom:16px}.message .avatar{width:40px;height:40px;border-radius:50%;background:#f0f0f0;display:flex;align-items:center;justify-content:center;font-size:20px;flex-shrink:0}.message .content{background:#f5f5f5;padding:12px 16px;border-radius:4px 16px 16px;max-width:80%}.message .content p{margin:0 0 8px;font-size:14px;line-height:1.6;color:#333}.message .content p:last-child{margin-bottom:0}.chat-input-area{display:flex;gap:12px;padding:16px 24px;border-top:1px solid #eee}.chat-input-area input{flex:1;padding:12px 16px;border:2px solid #e0e0e0;border-radius:25px;font-size:14px;outline:none}.chat-input-area input:focus{border-color:#667eea}.send-btn{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;padding:12px 24px;border-radius:25px;font-size:14px;font-weight:500;cursor:pointer}.chat-notice{text-align:center;padding:24px;background:#fff3cd;border-radius:12px;margin-top:24px}.chat-notice p{margin-bottom:12px;color:#856404}.switch-btn{background:#667eea;color:#fff;border:none;padding:10px 20px;border-radius:20px;cursor:pointer;font-size:14px}.assessment-result{max-width:700px;margin:0 auto}.result-header{text-align:center;margin-bottom:32px}.success-icon{width:100px;height:100px;background:linear-gradient(135deg,#10b981,#059669);border-radius:50%;display:flex;align-items:center;justify-content:center;margin:0 auto 20px;color:#fff}.result-header h1{font-size:28px;font-weight:700;color:#1a1a2e;margin-bottom:8px}.result-header p{font-size:16px;color:#666}.result-content{display:flex;flex-direction:column;gap:24px;margin-bottom:32px}.recommendation-card{background:linear-gradient(135deg,#667eea,#764ba2);border-radius:16px;padding:24px;color:#fff}.recommendation-card .card-header{display:flex;align-items:center;gap:12px;margin-bottom:20px}.recommendation-card h3{font-size:18px;font-weight:600;margin:0}.recommendation-body{background:#ffffff26;border-radius:12px;padding:20px}.focus-area,.weekly-plan{margin-bottom:16px}.recommendation-body .label{display:block;font-size:13px;opacity:.8;margin-bottom:4px}.recommendation-body .value{font-size:16px;font-weight:500}.tips-list ul{margin:8px 0 0;padding-left:20px}.tips-list li{font-size:14px;line-height:1.8}.profile-section{background:#fff;border-radius:16px;padding:24px;box-shadow:0 2px 12px #0000000f}.profile-section h3{display:flex;align-items:center;gap:8px;font-size:16px;font-weight:600;color:#333;margin:0 0 20px}.ability-bars{display:flex;flex-direction:column;gap:16px}.ability-item{display:grid;grid-template-columns:80px 1fr 60px;align-items:center;gap:16px}.ability-name{display:flex;align-items:center;gap:8px;font-size:14px;color:#666}.ability-bar{height:8px;background:#e0e0e0;border-radius:4px;overflow:hidden}.ability-fill{height:100%;border-radius:4px;transition:width .5s ease}.ability-fill.speaking{background:linear-gradient(90deg,#10b981,#059669)}.ability-fill.reading{background:linear-gradient(90deg,#3b82f6,#1d4ed8)}.ability-fill.writing{background:linear-gradient(90deg,#f59e0b,#d97706)}.ability-level{font-size:13px;color:#888;text-align:right}.interest-tags{display:flex;flex-wrap:wrap;gap:8px}.interest-tag{background:linear-gradient(135deg,#667eea15,#764ba215);color:#667eea;padding:6px 14px;border-radius:20px;font-size:13px}.habit-info{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}.habit-item{text-align:center;padding:16px;background:#f8f9fa;border-radius:12px}.habit-label{display:block;font-size:12px;color:#888;margin-bottom:8px}.habit-value{font-size:14px;font-weight:500;color:#333}.result-actions{display:flex;justify-content:center;gap:16px}.action-btn{display:flex;align-items:center;gap:8px;padding:14px 28px;border-radius:25px;font-size:15px;font-weight:600;cursor:pointer;transition:all .2s}.action-btn.primary{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none}.action-btn.primary:hover{transform:scale(1.05);box-shadow:0 4px 15px #667eea66}.action-btn.secondary{background:#fff;color:#667eea;border:2px solid #667eea}.action-btn.secondary:hover{background:#f5f4ff}.saving-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000}.saving-content{background:#fff;padding:40px 60px;border-radius:16px;text-align:center}.saving-spinner{width:50px;height:50px;border:4px solid #e0e0e0;border-top-color:#667eea;border-radius:50%;animation:spin 1s linear infinite;margin:0 auto 16px}.saving-content p{font-size:16px;color:#333}@media (max-width: 768px){.mode-cards,.options-grid.multi-select,.habit-info{grid-template-columns:1fr}.result-actions{flex-direction:column}.action-btn{width:100%;justify-content:center}}.chat-header .complete-btn{background:linear-gradient(135deg,#10b981,#059669);color:#fff;border:none;padding:8px 16px;border-radius:20px;font-size:14px;font-weight:500;cursor:pointer;display:flex;align-items:center;gap:6px;margin-left:auto}.chat-header .complete-btn:hover{transform:scale(1.05)}.message.typing{display:flex;align-items:center}.message.typing .content{display:flex;gap:4px;padding:16px 20px}.message.typing .dot{width:8px;height:8px;background:#667eea;border-radius:50%;animation:typing 1.4s infinite ease-in-out}.message.typing .dot:nth-child(1){animation-delay:0s}.message.typing .dot:nth-child(2){animation-delay:.2s}.message.typing .dot:nth-child(3){animation-delay:.4s}@keyframes typing{0%{transform:translateY(0);opacity:.5}50%{transform:translateY(-5px);opacity:1}to{transform:translateY(0);opacity:.5}}.chat-summary{background:linear-gradient(135deg,#667eea15,#764ba215);border-radius:12px;padding:16px;margin-top:16px}.chat-summary h4{font-size:14px;color:#333;margin:0 0 12px}.summary-items{display:flex;flex-wrap:wrap;gap:8px}.summary-tag{background:#fff;color:#667eea;padding:6px 12px;border-radius:16px;font-size:13px}.chat-input-area button:disabled{opacity:.5;cursor:not-allowed}.animate-spin{animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.speaking-page{max-width:1400px;margin:0 auto}.speaking-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--space-8);padding:var(--space-8);background:linear-gradient(135deg,#10b98114,#34d39914);border-radius:var(--radius-xl);border-left:4px solid var(--speaking)}.speaking-header-content{flex:1}.speaking-title{display:flex;align-items:center;gap:var(--space-3);font-size:28px;font-weight:700;color:var(--text-primary);margin-bottom:var(--space-2)}.speaking-icon{font-size:32px;animation:float 3s ease-in-out infinite}.speaking-subtitle{font-size:15px;color:var(--text-secondary)}.start-practice-btn{background:var(--gradient-speaking)!important;box-shadow:0 4px 15px #10b98166!important}.start-practice-btn:hover{box-shadow:0 6px 20px #10b98180!important}.speaking-section{margin-bottom:var(--space-8)}.section-title:before{content:"";width:4px;height:20px;background:var(--speaking);border-radius:var(--radius-full)}.practice-modes-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--space-5)}.practice-mode-card{background:linear-gradient(135deg,#f0fdf4,#dcfce7);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);transition:all .3s ease;border:1px solid #bbf7d0;overflow:hidden}.practice-mode-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-md);border-color:var(--speaking-light)}.practice-mode-card .card-content{padding:var(--space-6)}.mode-icon-wrapper{width:56px;height:56px;border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;margin-bottom:var(--space-4);box-shadow:0 4px 12px #0000001a}.mode-icon{font-size:28px}.mode-title{font-size:17px;font-weight:600;color:var(--text-primary);margin-bottom:var(--space-2)}.mode-description{font-size:14px;color:var(--text-secondary);line-height:1.6;margin-bottom:var(--space-4)}.mode-features{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:var(--space-5)}.mode-feature-tag{font-size:12px;padding:4px 10px;background:#10b98126;color:var(--speaking-dark);border-radius:var(--radius-full)}.mode-card-actions{margin-top:auto;padding-top:var(--space-2)}.mode-card-actions a{display:block}.scenarios-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--space-4)}.scenario-card{display:flex;flex-direction:column;align-items:center;gap:var(--space-3);padding:var(--space-6);background:linear-gradient(135deg,#fafafa,#f5f5f5);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);text-decoration:none;color:var(--text-primary);transition:all .3s ease;border:1px solid #e5e5e5}.scenario-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-md);border-color:var(--speaking-light)}.scenario-emoji{font-size:36px;transition:transform .3s ease}.scenario-card:hover .scenario-emoji{transform:scale(1.15)}.scenario-name{font-size:14px;font-weight:500}.topics-card{background:linear-gradient(135deg,#fafafa,#f5f5f5);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);border:1px solid #e5e5e5}.topics-card .card-content{padding:var(--space-4) var(--space-6)}.topics-list{display:flex;flex-direction:column}.topic-item{display:flex;align-items:center;gap:var(--space-4);padding:var(--space-4) 0;text-decoration:none;color:var(--text-primary);transition:all .2s ease;border-bottom:1px solid var(--border)}.topic-item:last-child{border-bottom:none}.topic-item:hover{background:transparent}.topic-item:hover .topic-name{color:var(--speaking)}.topic-number{width:28px;height:28px;display:flex;align-items:center;justify-content:center;background:var(--speaking);color:#fff;border-radius:50%;font-size:12px;font-weight:600;flex-shrink:0}.topic-name{flex:1;font-size:15px;transition:color .2s ease}.topic-item svg{flex-shrink:0;color:var(--text-muted)}.stats-preview{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--space-4)}.stat-card{background:linear-gradient(135deg,#f0fdf4,#dcfce7);border:1px solid #bbf7d0;border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);transition:all .3s ease;text-align:center}.stat-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-md)}.stat-card .card-content{padding:var(--space-6)}.stat-card .stat-icon{font-size:32px;margin-bottom:var(--space-3)}.stat-card .stat-value{font-size:28px;font-weight:700;color:var(--text-primary);margin-bottom:var(--space-1)}.stat-card .stat-label{font-size:13px;color:var(--text-secondary)}@media (max-width: 1200px){.practice-modes-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width: 1024px){.scenarios-grid,.stats-preview{grid-template-columns:repeat(2,1fr)}}@media (max-width: 768px){.speaking-header{flex-direction:column;gap:var(--space-5);text-align:center;padding:var(--space-6)}.speaking-title{font-size:24px;justify-content:center}.practice-modes-grid{grid-template-columns:1fr}.scenarios-grid,.stats-preview{grid-template-columns:repeat(2,1fr)}}@media (max-width: 480px){.scenarios-grid,.stats-preview{grid-template-columns:1fr}}.speaking-chat-page{display:flex;flex-direction:column;height:calc(100vh - 112px);background:linear-gradient(135deg,#fafafa,#f5f5f5);border-radius:var(--radius-xl);box-shadow:var(--shadow-lg);overflow:hidden;border:1px solid var(--border)}.chat-header{display:flex;justify-content:space-between;align-items:center;padding:var(--space-4) var(--space-6);border-bottom:1px solid var(--border);background:linear-gradient(135deg,#10b98114,#34d3990d)}.chat-header-info{display:flex;align-items:center;gap:var(--space-3)}.chat-avatar{width:48px;height:48px;background:var(--gradient-speaking);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:24px;box-shadow:0 4px 12px #10b9814d;animation:float 3s ease-in-out infinite}.chat-info{display:flex;flex-direction:column}.chat-title{font-size:18px;font-weight:600;color:var(--text-primary)}.chat-subtitle{font-size:13px;color:var(--text-secondary)}.chat-actions{display:flex;gap:var(--space-2)}.chat-action-btn{width:40px;height:40px;background:linear-gradient(135deg,#f8fafc,#f1f5f9);border:1px solid var(--border);border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;cursor:pointer;color:var(--text-secondary);transition:all .2s ease}.chat-action-btn:hover{background:var(--surface-hover);color:var(--speaking);border-color:var(--speaking-light);transform:translateY(-2px)}.chat-action-btn.active{background:#10b9811a;border-color:var(--speaking-light);color:var(--speaking)}.chat-messages{flex:1;overflow-y:auto;padding:var(--space-6);display:flex;flex-direction:column;gap:var(--space-4);background:linear-gradient(180deg,#fafafa,#fff)}.message{display:flex;gap:var(--space-3);max-width:85%;animation:fadeIn .3s ease-out}.message.user{align-self:flex-end;flex-direction:row-reverse}.message.ai{align-self:flex-start}.message-avatar{width:40px;height:40px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:20px;flex-shrink:0;box-shadow:0 2px 8px #0000001a}.message.user .message-avatar{background:var(--gradient-primary)}.message.ai .message-avatar{background:var(--gradient-speaking)}.message-content{display:flex;flex-direction:column;gap:4px}.message.user .message-content{align-items:flex-end}.message-bubble{padding:var(--space-3) var(--space-4);border-radius:var(--radius-lg);max-width:100%;word-wrap:break-word;box-shadow:var(--shadow-sm);transition:all .2s ease}.message.user .message-bubble{background:var(--gradient-primary);color:#fff;border-bottom-right-radius:4px}.message.ai .message-bubble{background:linear-gradient(135deg,#f8fafc,#f1f5f9);color:var(--text-primary);border-bottom-left-radius:4px;border:1px solid var(--border)}.message-bubble:hover{box-shadow:var(--shadow-md)}.message-text{font-size:15px;line-height:1.6;margin:0}.message-time{font-size:11px;color:var(--text-muted)}.message-meta{display:flex;align-items:center;gap:8px}.speak-btn{background:none;border:none;cursor:pointer;font-size:14px;padding:2px 4px;border-radius:4px;opacity:.6;transition:opacity .2s}.speak-btn:hover{opacity:1}.typing-indicator{display:flex;gap:4px;padding:var(--space-2) var(--space-3)}.typing-indicator span{width:8px;height:8px;background:var(--speaking);border-radius:50%;animation:typing 1.4s infinite ease-in-out both}@keyframes typing{0%,80%,to{transform:scale(.6);opacity:.5}40%{transform:scale(1);opacity:1}}.feedback-panel{padding:var(--space-4) var(--space-6);background:linear-gradient(135deg,#10b9810d,#34d39908);border-top:1px solid var(--border);border-bottom:1px solid var(--border)}.feedback-header{font-size:14px;font-weight:600;color:var(--text-primary);margin-bottom:var(--space-3);display:flex;align-items:center;gap:var(--space-2)}.feedback-header:before{content:"📊"}.feedback-metrics{display:flex;gap:var(--space-6)}.feedback-metric{display:flex;align-items:center;gap:var(--space-3);flex:1;padding:var(--space-2);background:linear-gradient(135deg,#f8fafc,#f1f5f9);border-radius:var(--radius-md);box-shadow:var(--shadow-sm);border:1px solid var(--border)}.metric-label{font-size:13px;color:var(--text-secondary);min-width:48px;font-weight:500}.metric-bar{flex:1;height:8px;background:var(--border);border-radius:var(--radius-full);overflow:hidden}.metric-fill{height:100%;background:var(--gradient-speaking);border-radius:var(--radius-full);transition:width .5s ease}.metric-value{font-size:14px;font-weight:600;color:var(--speaking-dark);min-width:32px;text-align:right}.chat-input-area{padding:var(--space-4) var(--space-6);background:linear-gradient(135deg,#f8fafc,#f1f5f9);border-top:1px solid var(--border)}.chat-input-wrapper{display:flex;align-items:center;gap:var(--space-3);background:var(--surface-hover);border-radius:var(--radius-xl);padding:var(--space-2);border:1px solid transparent;transition:all .2s ease}.chat-input-wrapper:focus-within{border-color:var(--speaking-light);background:#fff;box-shadow:0 0 0 4px #10b9811a}.chat-input{flex:1;background:transparent;border:none;padding:var(--space-2);font-size:15px;color:var(--text-primary);outline:none}.chat-input::placeholder{color:var(--text-muted)}.send-btn{width:44px;height:44px;background:var(--gradient-speaking);border:none;border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;color:#fff;transition:all .2s ease;flex-shrink:0;box-shadow:0 4px 12px #10b9814d}.send-btn:hover:not(:disabled){transform:scale(1.05);box-shadow:0 6px 16px #10b98166}.send-btn:disabled{background:var(--text-muted);cursor:not-allowed;box-shadow:none}.chat-empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;text-align:center;color:var(--text-secondary)}.chat-empty-state-icon{font-size:64px;margin-bottom:var(--space-4);opacity:.5}.input-mode-toggle{display:flex;gap:4px;margin-bottom:var(--space-3);background:#e2e8f0;border-radius:var(--radius-md);padding:3px;width:fit-content}.mode-toggle-btn{padding:6px 16px;border:none;background:transparent;border-radius:6px;font-size:13px;font-weight:500;color:var(--text-secondary);cursor:pointer;transition:all .2s ease}.mode-toggle-btn.active{background:#fff;color:var(--speaking-dark);box-shadow:0 1px 3px #0000001a}.voice-input-area{display:flex;flex-direction:column;align-items:center;gap:var(--space-3)}.voice-preview{width:100%;display:flex;align-items:center;gap:var(--space-2);padding:var(--space-3) var(--space-4);background:#fff;border-radius:var(--radius-lg);border:1px solid var(--border)}.voice-preview-text{flex:1;font-size:15px;color:var(--text-primary);line-height:1.5}.voice-clear-btn{width:28px;height:28px;border:none;background:#f1f5f9;border-radius:50%;cursor:pointer;font-size:14px;color:var(--text-secondary);display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:all .2s}.voice-clear-btn:hover{background:#fee2e2;color:#dc2626}.voice-buttons{display:flex;align-items:center;gap:var(--space-4)}.voice-record-btn{display:flex;flex-direction:column;align-items:center;gap:var(--space-2);background:none;border:none;cursor:pointer;padding:var(--space-2)}.voice-record-btn:disabled{opacity:.5;cursor:not-allowed}.record-btn-inner{width:72px;height:72px;border-radius:50%;background:var(--gradient-speaking);display:flex;align-items:center;justify-content:center;position:relative;box-shadow:0 4px 16px #10b98166;transition:all .3s ease}.voice-record-btn:hover:not(:disabled) .record-btn-inner{transform:scale(1.08);box-shadow:0 6px 24px #10b98180}.voice-record-btn.recording .record-btn-inner{background:linear-gradient(135deg,#ef4444,#dc2626);box-shadow:0 4px 16px #ef444466}.record-pulse{position:absolute;top:-8px;right:-8px;bottom:-8px;left:-8px;border-radius:50%;border:3px solid rgba(239,68,68,.4);animation:pulse-ring 1.5s ease-out infinite}@keyframes pulse-ring{0%{transform:scale(.9);opacity:1}to{transform:scale(1.3);opacity:0}}.record-icon{font-size:28px;z-index:1}.record-label{font-size:13px;color:var(--text-secondary);font-weight:500}.voice-send-btn{padding:12px 28px;background:var(--gradient-speaking);color:#fff;border:none;border-radius:var(--radius-lg);font-size:15px;font-weight:600;cursor:pointer;box-shadow:0 4px 12px #10b9814d;transition:all .2s ease}.voice-send-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 16px #10b98166}.voice-send-btn:disabled{opacity:.5;cursor:not-allowed}.voice-unsupported{font-size:14px;color:var(--text-secondary);text-align:center;padding:var(--space-3)}.voice-status{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-3) var(--space-6);background:linear-gradient(135deg,#10b9811a,#34d3990d);border-top:1px solid rgba(16,185,129,.2)}.voice-wave{display:flex;align-items:center;gap:3px;height:24px}.voice-wave span{width:3px;background:var(--speaking);border-radius:2px;animation:wave 1s ease-in-out infinite}.voice-wave span:nth-child(1){height:8px;animation-delay:0s}.voice-wave span:nth-child(2){height:16px;animation-delay:.1s}.voice-wave span:nth-child(3){height:24px;animation-delay:.2s}.voice-wave span:nth-child(4){height:16px;animation-delay:.3s}.voice-wave span:nth-child(5){height:8px;animation-delay:.4s}@keyframes wave{0%,to{transform:scaleY(.5)}50%{transform:scaleY(1)}}.voice-status-text{font-size:13px;color:var(--speaking-dark);font-weight:500}.voice-interim{font-size:13px;color:var(--text-muted);font-style:italic;flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}@media (max-width: 768px){.speaking-chat-page{border-radius:0;height:calc(100vh - 80px)}.chat-header{padding:var(--space-3) var(--space-4)}.chat-messages{padding:var(--space-4)}.message{max-width:90%}.feedback-metrics{flex-direction:column;gap:var(--space-2)}.chat-input-area{padding:var(--space-3) var(--space-4)}}.speaking-history-page{max-width:900px;margin:0 auto}.history-list{display:flex;flex-direction:column;gap:var(--space-4)}.history-card{background:linear-gradient(135deg,#f0fdf4,#dcfce7);border:1px solid #bbf7d0;border-radius:var(--radius-lg);cursor:pointer;transition:all .3s ease}.history-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-md);border-color:var(--speaking-light)}.history-card .card-content{display:flex;justify-content:space-between;align-items:center;padding:var(--space-5)}.history-info{flex:1}.history-topic{font-size:16px;font-weight:600;color:var(--text-primary);margin-bottom:var(--space-2)}.history-meta{display:flex;gap:var(--space-3);font-size:13px;align-items:center}.history-mode{background:#10b98126;color:var(--speaking-dark);padding:3px 10px;border-radius:var(--radius-full);font-weight:500}.history-date,.history-duration{color:var(--text-muted)}.history-score{text-align:center;padding-left:var(--space-6);border-left:1px solid var(--border);margin-left:var(--space-4)}.score-value{display:block;font-size:32px;font-weight:700;color:var(--speaking);line-height:1}.score-label{font-size:12px;color:var(--text-muted);margin-top:4px}@media (max-width: 640px){.history-card .card-content{flex-direction:column;align-items:flex-start;gap:var(--space-4)}.history-score{padding-left:0;border-left:none;margin-left:0;padding-top:var(--space-4);border-top:1px solid var(--border);width:100%;display:flex;align-items:center;gap:var(--space-2)}.score-label{margin-top:0}}.speaking-analysis-page{max-width:1200px;margin:0 auto}.analysis-grid{display:grid;grid-template-columns:1fr 2fr;gap:var(--space-6)}.analysis-card{background:linear-gradient(135deg,#f0fdf4,#dcfce7);border:1px solid #bbf7d0;border-radius:var(--radius-lg)}.analysis-card .card-content{padding:var(--space-8)}.card-title{font-size:16px;font-weight:600;color:var(--text-primary);margin-bottom:var(--space-5)}.overall-score{text-align:center;padding:var(--space-6) 0}.score-number{display:block;font-size:64px;font-weight:700;color:var(--speaking);line-height:1;margin-bottom:var(--space-3)}.score-level{font-size:18px;color:var(--text-secondary);font-weight:500}.metrics-list{display:flex;flex-direction:column;gap:var(--space-5)}.metric-item{display:flex;flex-direction:column;gap:var(--space-2)}.metric-name{font-size:14px;color:var(--text-secondary);font-weight:500}@media (max-width: 768px){.analysis-grid{grid-template-columns:1fr}}.reading-page{max-width:1400px;margin:0 auto;padding-bottom:var(--space-10)}.reading-hero{background:linear-gradient(135deg,#3b82f6,#1d4ed8,#1e40af);border-radius:24px;padding:var(--space-10);margin-bottom:var(--space-8);position:relative;overflow:hidden}.reading-hero:before{content:"";position:absolute;top:-50%;right:-20%;width:600px;height:600px;background:radial-gradient(circle,rgba(255,255,255,.1) 0%,transparent 70%);border-radius:50%}.hero-btn.primary{background:#fff!important;color:#3b82f6!important;box-shadow:0 4px 15px #0003!important}.vocab-section{margin-bottom:var(--space-8)}.vocab-card{background:linear-gradient(135deg,#f0f9ff,#e0f2fe);border-radius:24px;padding:var(--space-8);position:relative;overflow:hidden;border:1px solid #bae6fd}.vocab-bg-pattern{position:absolute;top:-100px;right:-100px;width:300px;height:300px;background:radial-gradient(circle,rgba(59,130,246,.1) 0%,transparent 70%);border-radius:50%}.vocab-content{display:flex;justify-content:space-between;align-items:center;position:relative;z-index:1}.vocab-left{display:flex;align-items:center;gap:var(--space-6)}.vocab-icon-wrapper{width:80px;height:80px;background:linear-gradient(135deg,#3b82f6,#1d4ed8);border-radius:24px;display:flex;align-items:center;justify-content:center;box-shadow:0 8px 24px #3b82f64d}.vocab-icon{font-size:40px}.vocab-info{flex:1}.vocab-title{font-size:24px;font-weight:700;color:#1e293b;margin:0 0 var(--space-2) 0}.vocab-desc{font-size:14px;color:#64748b;margin:0 0 var(--space-3) 0;max-width:400px}.vocab-levels{display:flex;gap:var(--space-2);flex-wrap:wrap}.level-tag{background:#fff;padding:6px 14px;border-radius:20px;font-size:12px;font-weight:500;color:#475569;border:1px solid #e2e8f0;transition:all .2s ease}.level-tag:hover{border-color:#3b82f6;color:#3b82f6}.vocab-action{text-align:center}.vocab-btn{background:linear-gradient(135deg,#3b82f6,#1d4ed8)!important;color:#fff!important;padding:14px 32px!important;border-radius:12px!important;font-size:16px!important;font-weight:600!important;box-shadow:0 4px 15px #3b82f666!important;transition:all .3s ease!important}.vocab-btn:hover{transform:translateY(-2px);box-shadow:0 6px 20px #3b82f680!important}.vocab-hint{margin:var(--space-2) 0 0;font-size:12px;color:#94a3b8}.articles-section{margin-bottom:var(--space-8)}.view-all-link{font-size:14px;color:#3b82f6;text-decoration:none;font-weight:500;transition:color .2s ease}.view-all-link:hover{color:#1d4ed8}.articles-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--space-5)}.article-card{background:#fff;border-radius:20px;overflow:hidden;box-shadow:0 4px 6px #0000000a;border:1px solid #e2e8f0;transition:all .3s ease}.article-card:hover{transform:translateY(-6px);box-shadow:0 20px 40px #0000001a;border-color:transparent}.article-header{padding:var(--space-4) var(--space-5);display:flex;justify-content:space-between;align-items:center}.article-topic-badge{display:flex;align-items:center;gap:var(--space-1);padding:6px 12px;border-radius:8px;font-size:12px;font-weight:600}.article-difficulty{padding:4px 10px;border-radius:6px;font-size:11px;font-weight:700;text-transform:uppercase}.difficulty-b1{background:#dcfce7;color:#16a34a}.difficulty-b2{background:#dbeafe;color:#2563eb}.difficulty-c1{background:#fef3c7;color:#d97706}.difficulty-c2{background:#fee2e2;color:#dc2626}.article-body{padding:0 var(--space-5) var(--space-4)}.article-title{font-size:17px;font-weight:700;color:#1e293b;margin:0 0 var(--space-2) 0;line-height:1.4}.article-excerpt{font-size:13px;color:#64748b;line-height:1.6;margin:0;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.article-footer{padding:var(--space-4) var(--space-5) var(--space-5);display:flex;justify-content:space-between;align-items:center;border-top:1px solid #f1f5f9}.article-meta{display:flex;align-items:center;gap:var(--space-2);font-size:12px;color:#94a3b8}.meta-divider{color:#e2e8f0}.article-btn{padding:10px 20px!important;border-radius:10px!important;font-size:13px!important;font-weight:600!important;color:#fff!important;transition:all .3s ease!important}.article-btn:hover{transform:scale(1.05);box-shadow:0 4px 12px #0003!important}.tips-card{display:flex;align-items:center;gap:var(--space-5);background:linear-gradient(135deg,#fefce8,#fef9c3);border-radius:16px;padding:var(--space-5) var(--space-6);border:1px solid #fde047}.tips-content h4{font-size:15px;font-weight:700;color:#854d0e;margin:0 0 var(--space-1) 0}.tips-content p{font-size:13px;color:#a16207;margin:0;line-height:1.6}@media (max-width: 1200px){.articles-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width: 1024px){.stats-grid{grid-template-columns:repeat(2,1fr)}.hero-illustration{display:none}.hero-content{justify-content:center}.hero-text{max-width:100%;text-align:center}.hero-features{max-width:500px;margin:0 auto var(--space-6)}.hero-actions{justify-content:center}.vocab-content{flex-direction:column;text-align:center;gap:var(--space-6)}.vocab-left{flex-direction:column}.vocab-desc{max-width:100%}}@media (max-width: 768px){.reading-hero{padding:var(--space-6)}.hero-title{font-size:28px;justify-content:center}.hero-features{grid-template-columns:1fr}.hero-actions{flex-direction:column}.hero-btn{width:100%;justify-content:center}.stats-grid{grid-template-columns:1fr}.stat-card{padding:var(--space-4)}.articles-grid{grid-template-columns:1fr}.vocab-card{padding:var(--space-5)}.article-footer{flex-direction:column;gap:var(--space-3)}.article-btn{width:100%}}.vocab-tracking-section{margin-bottom:var(--space-8)}.vocab-tracking-grid{display:grid;grid-template-columns:1fr 1.2fr 1fr;gap:var(--space-5)}.vocab-current-card{background:linear-gradient(135deg,#3b82f6,#1d4ed8);border-radius:20px;padding:var(--space-6);color:#fff;display:flex;flex-direction:column;justify-content:space-between}.current-level-badge{text-align:center;padding:var(--space-4)}.current-level-badge .level-label{display:block;font-size:12px;opacity:.8;margin-bottom:var(--space-1)}.current-level-badge .level-value{display:block;font-size:48px;font-weight:800;line-height:1}.current-level-badge .level-name{display:block;font-size:14px;opacity:.9;margin-top:var(--space-1)}.vocab-stats{display:flex;gap:var(--space-4);padding-top:var(--space-4);border-top:1px solid rgba(255,255,255,.2)}.vocab-stat{flex:1;text-align:center}.vocab-stat .stat-value{display:block;font-size:20px;font-weight:700}.vocab-stat .stat-value.positive{color:#86efac}.vocab-stat .stat-label{display:block;font-size:11px;opacity:.8}.vocab-trend-card{background:#fff;border-radius:20px;padding:var(--space-5);box-shadow:0 2px 12px #0000000f}.trend-title{font-size:14px;font-weight:600;color:#374151;margin:0 0 var(--space-4) 0}.trend-chart{display:flex;align-items:flex-end;justify-content:space-around;height:120px;padding:var(--space-3) 0;border-bottom:1px solid #e5e7eb}.trend-bar{width:50px;background:linear-gradient(180deg,#dbeafe,#bfdbfe);border-radius:8px 8px 0 0;display:flex;flex-direction:column;align-items:center;justify-content:flex-end;padding:var(--space-2);transition:all .3s ease}.trend-bar.active{background:linear-gradient(180deg,#3b82f6,#1d4ed8)}.trend-bar.active .bar-label,.trend-bar.active .bar-date{color:#fff}.trend-bar .bar-label{font-size:12px;font-weight:700;color:#3b82f6}.trend-bar .bar-date{font-size:10px;color:#6b7280;margin-top:2px}.trend-summary{display:flex;align-items:center;justify-content:center;gap:var(--space-2);padding-top:var(--space-3);font-size:13px;color:#059669}.vocab-history-card{background:#fff;border-radius:20px;padding:var(--space-5);box-shadow:0 2px 12px #0000000f}.history-title{font-size:14px;font-weight:600;color:#374151;margin:0 0 var(--space-3) 0}.history-list{display:flex;flex-direction:column;gap:var(--space-2)}.history-item{display:flex;align-items:center;padding:var(--space-2) var(--space-3);background:#f9fafb;border-radius:10px;font-size:13px}.history-item .item-date{width:50px;color:#6b7280;font-size:12px}.history-item .item-result{flex:1;display:flex;align-items:center;gap:var(--space-2)}.history-item .result-level{background:linear-gradient(135deg,#3b82f6,#1d4ed8);color:#fff;padding:2px 8px;border-radius:4px;font-size:11px;font-weight:600}.history-item .result-words{color:#6b7280;font-size:12px}.history-item .item-change{font-size:12px;font-weight:600;color:#6b7280}.history-item .item-change.positive{color:#059669}.start-test-btn{display:block;text-align:center;padding:var(--space-3);margin-top:var(--space-4);background:linear-gradient(135deg,#3b82f6,#1d4ed8);color:#fff;border-radius:10px;font-size:14px;font-weight:600;text-decoration:none;transition:all .2s ease}.start-test-btn:hover{transform:translateY(-2px);box-shadow:0 4px 12px #3b82f64d}.new-test-link{font-size:14px;color:#3b82f6;text-decoration:none;font-weight:500}.new-test-link:hover{text-decoration:underline}@media (max-width: 1024px){.vocab-tracking-grid{grid-template-columns:1fr 1fr}}@media (max-width: 768px){.vocab-tracking-grid{grid-template-columns:1fr}}.reading-library-page{padding:24px;max-width:1400px;margin:0 auto}.library-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:24px}.library-header .page-title{font-size:28px;font-weight:700;color:var(--text-primary);margin:0 0 8px}.library-header .page-subtitle{color:var(--text-secondary);font-size:15px;margin:0;max-width:500px}.user-level-badge{display:flex;flex-direction:column;align-items:center;padding:12px 24px;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:12px;color:#fff}.user-level-badge .level-label{font-size:12px;opacity:.9}.user-level-badge .level-value{font-size:24px;font-weight:700}.zpd-info-card{display:flex;gap:20px;padding:24px 28px;background:linear-gradient(135deg,#667eea14,#764ba214);border:1px solid rgba(102,126,234,.2);border-radius:16px;margin-bottom:24px}.zpd-icon{font-size:36px;flex-shrink:0}.zpd-content h3{font-size:18px;font-weight:600;color:var(--text-primary);margin:0 0 12px}.zpd-intro{font-size:14px;color:var(--text-secondary);margin:0 0 10px;line-height:1.7}.zpd-principle{font-size:14px;color:var(--text-secondary);margin:0 0 16px;line-height:1.7;padding:10px 14px;background:#667eea1a;border-radius:8px;border-left:3px solid #667eea}.zpd-content strong{color:#667eea}.zpd-levels{background:#fff9;border-radius:12px;padding:16px 20px;margin-bottom:14px}.zpd-levels h4{font-size:14px;font-weight:600;color:var(--text-primary);margin:0 0 12px}.level-from{color:var(--text-secondary);min-width:110px}.level-arrow{color:#667eea;font-weight:700}.level-to{color:var(--text-primary);font-weight:500;background:linear-gradient(135deg,#667eea26,#764ba226);padding:4px 12px;border-radius:6px}.zpd-note{font-size:13px;color:var(--text-secondary);margin:0;line-height:1.6}.library-filters{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:16px}.filter-btn{padding:8px 18px;border:none;border-radius:20px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s;background:#fffc;color:var(--text-secondary);border:1px solid var(--border)}.filter-btn:hover{background:#fff;color:var(--text-primary)}.filter-btn.active{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border-color:transparent;box-shadow:0 2px 8px #667eea4d}.topics-count{font-size:14px;color:var(--text-secondary);margin-bottom:20px}.topics-count strong{color:#667eea;font-weight:600}.topics-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(380px,1fr));gap:20px}.topic-card{background:#fffffff2!important;border:1px solid var(--border)!important;border-radius:16px!important;transition:all .3s ease;cursor:pointer;height:100%}.topic-card:hover{transform:translateY(-4px);box-shadow:0 12px 24px #0000001a!important;border-color:#667eea4d!important}.topic-card .card-content{padding:20px;display:flex;flex-direction:column;gap:12px;height:100%}.topic-header{display:flex;justify-content:space-between;align-items:center}.topic-icon{font-size:28px}.topic-category{font-size:12px;font-weight:500;padding:4px 12px;border-radius:12px}.topic-title{font-size:17px;font-weight:600;color:var(--text-primary);margin:0;line-height:1.4}.topic-summary{font-size:14px;color:var(--text-secondary);line-height:1.6;margin:0;flex:1}.topic-keywords{display:flex;flex-wrap:wrap;gap:6px}.keyword-tag{font-size:12px;padding:3px 10px;background:#667eea14;color:#667eea;border-radius:12px;font-weight:500}.topic-footer{display:flex;justify-content:space-between;align-items:center;margin-top:8px;padding-top:12px;border-top:1px solid var(--border)}.topic-meta{display:flex;gap:16px}.meta-item{display:flex;align-items:center;gap:4px;font-size:13px;color:var(--text-secondary)}.meta-icon{font-size:14px}.generate-btn{padding:8px 16px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:8px;font-size:13px;font-weight:500;cursor:pointer;transition:all .2s}.generate-btn:hover{transform:scale(1.05);box-shadow:0 4px 12px #667eea66}@media (max-width: 768px){.reading-library-page{padding:16px}.library-header{flex-direction:column;gap:16px}.user-level-badge{flex-direction:row;gap:12px;width:fit-content}.topics-grid{grid-template-columns:1fr}.zpd-info-card{flex-direction:column;text-align:center}.zpd-icon{font-size:28px}}.vocab-card{width:260px;min-width:260px;height:100px;background:linear-gradient(135deg,#f8f9fa,#fff);border:1px solid #e0e0e0;border-radius:12px;padding:14px 16px;display:flex;flex-direction:column;gap:6px;transition:all .2s ease;cursor:pointer;box-shadow:0 2px 8px #0000000a;flex-shrink:0}.vocab-card:hover{border-color:#667eea;transform:translateY(-3px);box-shadow:0 8px 20px #667eea26;background:linear-gradient(135deg,#f0f4ff,#fff)}.vocab-card-header{display:flex;justify-content:space-between;align-items:center}.vocab-word{font-size:1rem;font-weight:600;color:#1a1a2e;margin:0}.vocab-audio-btn{background:#667eea1a;border:none;color:#667eea;cursor:pointer;padding:6px;border-radius:50%;transition:all .2s;display:flex;align-items:center;justify-content:center}.vocab-audio-btn:hover{background-color:#667eea;color:#fff}.vocab-phonetic{font-size:.85rem;color:#667eea;font-family:Lucida Sans Unicode,Arial Unicode MS,sans-serif;background:#667eea14;padding:2px 8px;border-radius:4px;display:inline-block;width:fit-content}.vocab-meaning{font-size:.9rem;color:#4a5568;line-height:1.4;overflow:hidden;text-overflow:ellipsis;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical}@media (prefers-color-scheme: dark){.vocab-card{background:#1f1f1f;border-color:#333}.vocab-word{color:#cfd3dc}.vocab-phonetic{color:#888}.vocab-meaning{color:#aaa}}.reading-practice-page{padding:24px;max-width:1440px;margin:0 auto;min-height:100vh;background-color:#f5f7fa;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif}.reading-container{display:grid;grid-template-columns:8fr 4fr;gap:24px;margin-bottom:24px}@media (max-width: 1024px){.reading-container{grid-template-columns:7fr 5fr}}@media (max-width: 768px){.reading-container{grid-template-columns:1fr}}.article-card{background:#fff;border-radius:12px;box-shadow:0 4px 20px #00000014;border:1px solid #e8e8e8;overflow:visible}.article-card .card-content{padding:40px 48px}.article-title{font-size:1.75rem;font-weight:700;color:#1a1a2e;margin-bottom:32px;line-height:1.4;text-align:center;padding-bottom:20px;border-bottom:2px solid #f0f0f0}.article-content{font-size:1.05rem;line-height:2;color:#333;padding:0 16px}.article-paragraph{margin-bottom:24px;text-align:justify;text-indent:2em}.article-word{cursor:pointer;border-radius:2px;transition:background-color .15s;padding:1px 2px}.article-word:hover{background-color:#5b8ff926}.article-word.highlight{border-bottom:2px solid #5B8FF9;background-color:#5b8ff914}.article-content ::selection{background-color:#667eea4d}.text-highlight-yellow{background-color:#ffeb3b80!important;border-radius:2px;padding:1px 2px}.text-highlight-green{background-color:#4caf5066!important;border-radius:2px;padding:1px 2px}.text-highlight-blue{background-color:#2196f359!important;border-radius:2px;padding:1px 2px}.text-highlight-pink{background-color:#e91e634d!important;border-radius:2px;padding:1px 2px}.text-underline{text-decoration:underline;text-decoration-thickness:2px;text-underline-offset:3px}.text-underline.text-underline-yellow{text-decoration-color:#ffeb3b}.text-underline.text-underline-green{text-decoration-color:#4caf50}.text-underline.text-underline-blue{text-decoration-color:#2196f3}.text-underline.text-underline-pink{text-decoration-color:#e91e63}.annotation-toolbar{position:fixed;display:flex;align-items:center;gap:4px;padding:8px 12px;background:#fff;border-radius:8px;box-shadow:0 4px 20px #00000026;border:1px solid #e0e0e0;z-index:1000;animation:toolbarFadeIn .2s ease}@keyframes toolbarFadeIn{0%{opacity:0;transform:translateY(-5px)}to{opacity:1;transform:translateY(0)}}.annotation-btn{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border:none;border-radius:6px;cursor:pointer;transition:all .15s;background:transparent}.annotation-btn:hover{background:#f5f5f5}.annotation-btn.color-yellow{background:#ffeb3bcc}.annotation-btn.color-yellow:hover{background:#ffeb3b}.annotation-btn.color-green{background:#4caf50b3}.annotation-btn.color-green:hover{background:#4caf50}.annotation-btn.color-blue{background:#2196f399}.annotation-btn.color-blue:hover{background:#2196f3}.annotation-btn.color-pink{background:#e91e6380}.annotation-btn.color-pink:hover{background:#e91e63}.toolbar-divider{width:1px;height:24px;background:#e0e0e0;margin:0 4px}.toolbar-label{font-size:12px;color:#666;margin-right:8px;white-space:nowrap}.annotations-list{margin-top:24px;padding:16px;background:#fafafa;border-radius:8px;border:1px solid #f0f0f0}.annotations-list h4{font-size:14px;font-weight:600;color:#333;margin:0 0 12px;display:flex;align-items:center;gap:8px}.annotation-item{display:flex;align-items:flex-start;gap:12px;padding:10px 12px;background:#fff;border-radius:6px;margin-bottom:8px;border:1px solid #eee;font-size:13px}.annotation-item:last-child{margin-bottom:0}.annotation-color-dot{width:12px;height:12px;border-radius:50%;flex-shrink:0;margin-top:3px}.annotation-color-dot.highlight-yellow{background:#ffeb3b}.annotation-color-dot.highlight-green{background:#4caf50}.annotation-color-dot.highlight-blue{background:#2196f3}.annotation-color-dot.highlight-pink{background:#e91e63}.annotation-color-dot.underline-yellow{background:transparent;border:2px solid #FFEB3B}.annotation-color-dot.underline-green{background:transparent;border:2px solid #4CAF50}.annotation-color-dot.underline-blue{background:transparent;border:2px solid #2196F3}.annotation-color-dot.underline-pink{background:transparent;border:2px solid #E91E63}.annotation-text{flex:1;color:#333;line-height:1.5}.annotation-delete{padding:4px 8px;font-size:12px;color:#999;background:transparent;border:none;cursor:pointer;border-radius:4px}.annotation-delete:hover{background:#fee;color:#f44336}.reading-sidebar{position:sticky;top:24px;height:fit-content}.controls-card{background:#fff;border-radius:8px;box-shadow:0 2px 8px #0000000d;padding:24px;border:none}.article-meta{display:flex;justify-content:space-between;margin-bottom:24px;padding-bottom:16px;border-bottom:1px solid #F0F0F0}.meta-item{display:flex;flex-direction:column;align-items:center;gap:4px}.meta-label{font-size:.8rem;color:#909399}.meta-value{font-weight:600;color:#303133}.tag-CET-4{color:#52c41a}.tag-CET-6{color:#f5222d}.controls-tabs{display:flex;gap:8px;margin-bottom:24px;background:#f5f7fa;padding:4px;border-radius:8px}.tab-btn{flex:1;display:flex;align-items:center;justify-content:center;gap:6px;padding:8px 12px;border:none;background:transparent;color:#606266;font-size:.9rem;border-radius:6px;cursor:pointer;transition:all .2s}.tab-btn:hover{color:#5b8ff9;background:#ffffff80}.tab-btn.active{background:#fff;color:#5b8ff9;font-weight:600;box-shadow:0 2px 4px #0000000d}.tab-content{min-height:200px}.info-panel,.grammar-panel,.quiz-panel{animation:fadeInUp .3s ease}@keyframes fadeInUp{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.info-panel h3{font-size:1.1rem;margin-bottom:12px;color:#303133}.info-panel p{color:#606266;font-size:.95rem;line-height:1.6}.progress-hint{margin-top:24px;padding:12px;border-radius:6px;background:#f5f7fa}.score-badge{display:flex;align-items:center;gap:8px;color:#52c41a;font-weight:600}.todo-badge{color:#faad14;font-weight:500}.quiz-item{margin-bottom:24px}.quiz-question{font-weight:600;margin-bottom:12px;color:#303133}.quiz-options{display:flex;flex-direction:column;gap:8px}.quiz-option{display:flex;align-items:center;gap:8px;padding:10px;border:1px solid #E4E7ED;border-radius:6px;cursor:pointer;transition:all .2s}.quiz-option:hover:not(:disabled){border-color:#5b8ff9;background:#f0f7ff}.quiz-option input{accent-color:#5B8FF9}.quiz-option.correct{border-color:#52c41a;background:#f6ffed;color:#52c41a}.quiz-option.wrong{border-color:#f5222d;background:#fff1f0;color:#f5222d}.quiz-explanation{margin-top:8px;padding:12px;background:#f9f9f9;border-radius:6px;font-size:.9rem;color:#606266}.submit-btn,.retry-btn{width:100%;padding:12px;border-radius:8px;border:none;font-weight:600;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center;gap:8px}.submit-btn{background:#5b8ff9;color:#fff}.submit-btn:hover:not(:disabled){background:#4078f2;box-shadow:0 4px 12px #5b8ff94d}.submit-btn:disabled{background:#c0c4cc;cursor:not-allowed}.retry-btn{background:#fff;border:1px solid #D9D9D9;color:#606266;margin-top:16px}.retry-btn:hover{border-color:#5b8ff9;color:#5b8ff9}.quiz-result{text-align:center;margin-top:24px}.quiz-result .score{font-size:1.5rem;font-weight:700;color:#5b8ff9}.vocab-section{margin-top:48px}.section-title{font-size:1.25rem;margin-bottom:16px;color:#303133}.vocab-list-container{width:100%;overflow:hidden}.vocab-scroll-wrapper{display:flex;gap:24px;overflow-x:auto;padding:4px 4px 16px;scrollbar-width:thin}.vocab-scroll-wrapper::-webkit-scrollbar{height:8px}.vocab-scroll-wrapper::-webkit-scrollbar-track{background:#f5f7fa;border-radius:4px}.vocab-scroll-wrapper::-webkit-scrollbar-thumb{background:#dcdfe6;border-radius:4px}.vocab-popover{position:absolute;background:#fff;border-radius:8px;box-shadow:0 4px 16px #00000026;padding:16px;width:280px;z-index:100;border:1px solid #E4E7ED;animation:fadeIn .2s ease}@keyframes fadeIn{0%{opacity:0;transform:translateY(5px)}to{opacity:1;transform:translateY(0)}}.popover-header{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:8px;border-bottom:1px solid #F0F0F0;padding-bottom:8px}.popover-word{font-size:1.1rem;font-weight:700;color:#303133}.popover-phonetic{font-size:.85rem;color:#909399;font-family:Arial Unicode MS,sans-serif}.popover-meaning{font-size:.95rem;color:#606266}.reading-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:400px;gap:16px;color:#909399}.loading-hint{font-size:14px;color:#667eea}.loading-tip{font-size:12px;color:#909399}.empty-state{text-align:center;padding:40px 0;color:#c0c4cc}.empty-icon{font-size:3rem;margin-bottom:12px;opacity:.5}.topic-preview{display:flex;flex-direction:column;gap:24px}.topic-preview-card{background:#fff;border-radius:16px;box-shadow:0 4px 20px #00000014;padding:28px}.topic-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}.topic-icon{font-size:40px}.topic-category-badge{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:6px 16px;border-radius:20px;font-size:13px;font-weight:500}.topic-title{font-size:24px;font-weight:700;color:#1a1a2e;margin-bottom:12px}.topic-summary{font-size:15px;color:#4a5568;line-height:1.7;margin-bottom:16px}.topic-keywords-preview{display:flex;flex-wrap:wrap;gap:8px}.keyword-tag-preview{background:#667eea1a;color:#667eea;padding:4px 12px;border-radius:12px;font-size:12px;font-weight:500}.zpd-explanation-card{background:linear-gradient(135deg,#667eea0d,#764ba20d);border:1px solid rgba(102,126,234,.15);border-radius:16px;padding:24px}.zpd-header{display:flex;align-items:center;gap:12px;margin-bottom:20px}.zpd-icon{font-size:28px}.zpd-header h2{font-size:18px;font-weight:600;color:#1a1a2e;margin:0}.zpd-intro{background:#fff;padding:16px;border-radius:12px;margin-bottom:16px}.zpd-intro p{font-size:14px;color:#4a5568;line-height:1.7;margin:0 0 8px}.zpd-intro p:last-child{margin:0}.zpd-principle{background:#fff;padding:16px;border-radius:12px;margin-bottom:16px}.zpd-principle h4{font-size:14px;font-weight:600;color:#1a1a2e;margin:0 0 12px}.zpd-principle ul{list-style:none;padding:0;margin:0}.zpd-principle li{font-size:13px;color:#4a5568;padding:6px 0;border-bottom:1px solid #f0f0f0}.zpd-principle li:last-child{border-bottom:none;color:#667eea;font-weight:500}.zpd-levels{background:#fff;padding:16px;border-radius:12px;margin-bottom:16px}.zpd-levels h4{font-size:14px;font-weight:600;color:#1a1a2e;margin:0 0 12px}.level-mapping{display:flex;flex-direction:column;gap:8px}.level-row{display:flex;align-items:center;gap:12px;font-size:13px}.level-from{color:#718096;min-width:140px}.level-arrow{color:#667eea;font-weight:700;font-size:16px}.level-to{color:#1a1a2e;font-weight:500;background:linear-gradient(135deg,#667eea26,#764ba226);padding:4px 12px;border-radius:6px}.your-level-info{display:flex;align-items:center;justify-content:center;gap:12px;padding:16px;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:12px;color:#fff}.level-badge{padding:8px 16px;border-radius:8px;font-size:14px;font-weight:500}.level-badge.current{background:#fff3}.level-badge.target{background:#ffffff4d;font-weight:600}.exam-target-card{background:#fff;border-radius:16px;box-shadow:0 4px 20px #00000014;padding:24px}.exam-target-card h3{font-size:18px;font-weight:600;color:#1a1a2e;margin:0 0 8px}.exam-hint{font-size:13px;color:#718096;margin:0 0 20px}.exam-options{display:flex;gap:16px;margin-bottom:24px}.exam-option{flex:1;display:flex;align-items:center;gap:16px;padding:20px;border:2px solid #e2e8f0;border-radius:12px;background:#fff;cursor:pointer;transition:all .2s;position:relative}.exam-option:hover{border-color:#667eea;background:#667eea05}.exam-option.active{border-color:#667eea;background:#667eea0d}.exam-icon{font-size:32px}.exam-info{display:flex;flex-direction:column;gap:4px}.exam-name{font-size:15px;font-weight:600;color:#1a1a2e}.exam-words{font-size:13px;color:#718096}.check-mark{position:absolute;top:12px;right:12px;width:24px;height:24px;background:#667eea;color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:700}.generate-article-btn{width:100%;display:flex;align-items:center;justify-content:center;gap:8px;padding:14px 24px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:12px;font-size:16px;font-weight:600;cursor:pointer;transition:all .2s}.generate-article-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 8px 20px #667eea4d}.generate-article-btn:disabled{opacity:.5;cursor:not-allowed}.select-hint{text-align:center;color:#f59e0b;font-size:13px;margin-top:12px}.article-toolbar{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}.back-btn{display:flex;align-items:center;gap:8px;padding:10px 16px;background:#fff;border:1px solid #e2e8f0;border-radius:8px;color:#4a5568;font-size:14px;cursor:pointer;transition:all .2s}.back-btn:hover{background:#f7fafc;border-color:#667eea;color:#667eea}.regenerate-btn{display:flex;align-items:center;gap:8px;padding:10px 16px;background:#fff;border:1px solid #e2e8f0;border-radius:8px;color:#4a5568;font-size:14px;cursor:pointer;transition:all .2s}.regenerate-btn:hover{background:#f7fafc;border-color:#667eea;color:#667eea}.generated-badge{display:inline-flex;align-items:center;gap:8px;padding:8px 16px;background:linear-gradient(135deg,#667eea1a,#764ba21a);border:1px solid rgba(102,126,234,.2);border-radius:20px;font-size:13px;color:#667eea;margin-bottom:16px}.badge-icon{font-size:16px}@media (prefers-color-scheme: dark){.reading-practice-page{background-color:#121212}.article-card,.controls-card,.vocab-popover{background:#1f1f1f;box-shadow:0 2px 8px #0003}.article-title,.article-content,.meta-value{color:#cfd3dc}.controls-tabs{background:#2c2c2c}.tab-btn{color:#a0a0a0}.tab-btn.active{background:#3a3a3a;color:#5b8ff9}.quiz-question{color:#cfd3dc}.quiz-option{border-color:#444;color:#cfd3dc}.quiz-option:hover:not(:disabled){background:#2c2c2c}.article-word.highlight{background-color:#5b8ff933;border-bottom-color:#5b8ff9}.popover-word{color:#cfd3dc}.popover-meaning{color:#a0a0a0}.section-title{color:#cfd3dc}.vocab-scroll-wrapper::-webkit-scrollbar-track{background:#1f1f1f}.vocab-scroll-wrapper::-webkit-scrollbar-thumb{background:#444}}.reading-progress-page{max-width:1200px;margin:0 auto}.reading-progress-page .page-title{font-size:24px;font-weight:700;color:var(--text-primary);margin-bottom:8px}.reading-progress-page .page-subtitle{font-size:15px;color:var(--text-secondary);margin-bottom:28px}.progress-summary{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:28px}.summary-stat{display:flex;flex-direction:column;align-items:center;padding:20px 16px;background:#fff;border:1px solid #e2e8f0;border-radius:14px;text-align:center;transition:all .3s ease}.summary-stat:hover{transform:translateY(-2px);box-shadow:0 8px 20px #3b82f614}.summary-stat-icon{font-size:28px;margin-bottom:8px}.summary-stat-value{font-size:28px;font-weight:700;color:var(--text-primary);line-height:1.2}.summary-stat-label{font-size:13px;color:var(--text-muted);margin-top:4px}.progress-grid{display:grid;grid-template-columns:1fr 1fr;gap:24px}@media (max-width: 768px){.progress-grid{grid-template-columns:1fr}.progress-summary{grid-template-columns:repeat(2,1fr)}}@media (max-width: 480px){.progress-summary{grid-template-columns:1fr}}.progress-card{background:#fff!important;border:1px solid #e2e8f0!important;border-radius:16px!important;overflow:visible!important}.progress-card .card-content{padding:28px}.progress-card.wide{grid-column:1 / -1}.progress-card .card-title{font-size:18px;font-weight:600;color:var(--text-primary);margin-bottom:24px;display:flex;align-items:center;gap:8px}.weekly-stats{display:flex;justify-content:space-between;align-items:flex-end;height:200px;padding-top:20px}.day-stat{display:flex;flex-direction:column;align-items:center;gap:8px;flex:1}.day-name{font-size:13px;color:var(--text-muted);font-weight:500}.day-bar-container{width:36px;height:120px;background:#f1f5f9;border-radius:8px;position:relative;overflow:hidden}.day-bar{position:absolute;bottom:0;left:0;right:0;background:linear-gradient(180deg,#60a5fa,#3b82f6);border-radius:8px;transition:height .5s ease;min-height:4px}.day-value{font-size:12px;color:var(--text-secondary);font-weight:600}.skills-list{display:flex;flex-direction:column;gap:20px}.skill-item{display:flex;flex-direction:column;gap:8px}.skill-name{font-size:14px;color:var(--text-secondary);font-weight:500}.achievements{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}@media (max-width: 768px){.achievements{grid-template-columns:1fr}}.achievement{display:flex;flex-direction:column;align-items:center;text-align:center;padding:24px 16px;background:linear-gradient(135deg,#eff6ff,#dbeafe);border:1px solid #bfdbfe;border-radius:14px;transition:all .3s ease}.achievement:hover{transform:translateY(-2px);box-shadow:0 6px 16px #3b82f61f}.achievement-icon{font-size:44px;margin-bottom:14px}.achievement-name{font-size:16px;font-weight:600;color:var(--text-primary);margin-bottom:6px}.achievement-desc{font-size:13px;color:var(--text-muted);line-height:1.5}.vocab-assessment-page{max-width:900px;margin:0 auto;padding:var(--space-8)}.vocab-intro-card{text-align:center;padding:var(--space-16) var(--space-12);background:linear-gradient(135deg,#dbeafe,#bfdbfe);border:2px solid #93c5fd;border-radius:var(--radius-2xl);box-shadow:var(--shadow-xl);margin-bottom:var(--space-10)}.vocab-intro-icon{width:100px;height:100px;background:linear-gradient(135deg,#3b82f6,#2563eb);border-radius:50%;display:flex;align-items:center;justify-content:center;margin:0 auto var(--space-8);font-size:48px;box-shadow:0 12px 32px #3b82f659;animation:float 3s ease-in-out infinite}.vocab-intro-title{font-size:36px;font-weight:800;color:var(--text-primary);margin-bottom:var(--space-4);letter-spacing:-.02em}.vocab-intro-desc{font-size:18px;color:var(--text-secondary);line-height:1.7;max-width:650px;margin:0 auto var(--space-10)}.vocab-start-section{margin-top:var(--space-8)}.vocab-start-btn{display:inline-flex;align-items:center;gap:var(--space-4);background:linear-gradient(135deg,#3b82f6,#1d4ed8);color:#fff;border:none;border-radius:20px;padding:var(--space-4) var(--space-8);cursor:pointer;transition:all .3s ease;box-shadow:0 8px 32px #3b82f666;position:relative;overflow:hidden}.vocab-start-btn:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.2),transparent);transition:left .5s ease}.vocab-start-btn:hover:before{left:100%}.vocab-start-btn:hover{transform:translateY(-4px) scale(1.02);box-shadow:0 12px 40px #3b82f680}.vocab-start-btn:active{transform:translateY(-2px) scale(1.01)}.vocab-start-btn:disabled{opacity:.7;cursor:not-allowed;transform:none}.btn-icon-wrapper{width:52px;height:52px;background:#fff3;border-radius:16px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.btn-icon{width:24px;height:24px;margin-left:3px}.btn-content{display:flex;flex-direction:column;align-items:flex-start;text-align:left}.btn-text{font-size:18px;font-weight:700;letter-spacing:.5px}.btn-hint{font-size:12px;color:#ffffffbf;margin-top:2px}.btn-loading-spinner{width:24px;height:24px;border:3px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin 1s linear infinite}.vocab-start-note{margin-top:var(--space-4);font-size:13px;color:var(--text-muted)}.vocab-error-message{display:flex;align-items:center;justify-content:center;gap:var(--space-2);margin-top:var(--space-4);padding:var(--space-3) var(--space-4);background:#fef2f2;border:1px solid #fecaca;border-radius:12px;color:#dc2626;font-size:14px}.vocab-error-message .error-icon{font-size:16px}.vocab-features-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--space-6);margin-bottom:var(--space-10)}.vocab-feature-card{background:linear-gradient(135deg,#f8fafc,#f1f5f9);border:1px solid #e2e8f0;border-radius:var(--radius-xl);box-shadow:var(--shadow-md);padding:var(--space-8);text-align:center;transition:all .3s ease}.vocab-feature-card:hover{transform:translateY(-6px);box-shadow:var(--shadow-xl);border-color:var(--reading-light)}.vocab-feature-icon{width:72px;height:72px;border-radius:var(--radius-lg);display:flex;align-items:center;justify-content:center;margin:0 auto var(--space-5);font-size:36px}.vocab-feature-icon.target{background:linear-gradient(135deg,#dcfce7,#bbf7d0)}.vocab-feature-icon.trending{background:linear-gradient(135deg,#f3e8ff,#e9d5ff)}.vocab-feature-icon.book{background:linear-gradient(135deg,#fef3c7,#fde68a)}.vocab-feature-title{font-size:20px;font-weight:700;color:var(--text-primary);margin-bottom:var(--space-3)}.vocab-feature-desc{font-size:15px;color:var(--text-secondary);line-height:1.6}.vocab-test-container{max-width:650px;margin:0 auto}.vocab-progress-bar{margin-bottom:var(--space-8)}.vocab-progress-info{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--space-3);font-size:15px;color:var(--text-secondary)}.vocab-progress-info strong{color:var(--reading);font-weight:600}.vocab-word-card{background:linear-gradient(135deg,#eff6ff,#dbeafe);border:2px solid #93c5fd;border-radius:var(--radius-2xl);box-shadow:var(--shadow-xl);padding:var(--space-16) var(--space-12);text-align:center}.vocab-word{font-size:56px;font-weight:800;color:var(--text-primary);margin-bottom:var(--space-3);letter-spacing:1px}.vocab-phonetic{font-size:26px;color:var(--text-secondary);margin-bottom:var(--space-10);font-family:var(--font-mono)}.vocab-question{font-size:20px;color:var(--text-secondary);margin-bottom:var(--space-10)}.vocab-actions{display:flex;gap:var(--space-5);justify-content:center}.vocab-btn{display:flex;align-items:center;justify-content:center;padding:var(--space-5) var(--space-10);border-radius:var(--radius-xl);font-size:18px;font-weight:600;cursor:pointer;transition:all .3s ease;border:2px solid transparent;min-width:160px}.vocab-btn:disabled{opacity:.5;cursor:not-allowed}.vocab-btn-unknown{background:linear-gradient(135deg,#fef2f2,#fee2e2);color:var(--error);border-color:#fecaca}.vocab-btn-unknown:hover:not(:disabled){background:linear-gradient(135deg,#fee2e2,#fecaca);transform:translateY(-3px);box-shadow:0 8px 20px #ef444440}.vocab-btn-known{background:linear-gradient(135deg,#10b981,#059669);color:#fff;border-color:transparent;box-shadow:0 6px 20px #10b98159}.vocab-btn-known:hover:not(:disabled){background:linear-gradient(135deg,#059669,#047857);transform:translateY(-3px);box-shadow:0 10px 28px #10b98173}.vocab-result-card{background:linear-gradient(135deg,#fef3c7,#fde68a);border:2px solid #fcd34d;border-radius:var(--radius-2xl);box-shadow:var(--shadow-xl);padding:var(--space-16) var(--space-12);text-align:center;margin-bottom:var(--space-10)}.vocab-result-icon{width:100px;height:100px;background:linear-gradient(135deg,#f59e0b,#d97706);border-radius:50%;display:flex;align-items:center;justify-content:center;margin:0 auto var(--space-8);font-size:48px;box-shadow:0 12px 32px #f59e0b59;animation:float 3s ease-in-out infinite}.vocab-result-title{font-size:32px;font-weight:800;color:var(--text-primary);margin-bottom:var(--space-8)}.vocab-result-stats{display:flex;justify-content:center;align-items:center;gap:var(--space-10);margin-bottom:var(--space-10)}.vocab-result-stat{text-align:center}.vocab-result-stat-divider{width:2px;height:80px;background:linear-gradient(to bottom,transparent,rgba(0,0,0,.15),transparent)}.vocab-result-stat-value{font-size:56px;font-weight:800;color:var(--reading);line-height:1;margin-bottom:var(--space-2)}.vocab-result-stat-value.vocab-size{color:var(--success)}.vocab-result-stat-label{font-size:16px;color:var(--text-secondary);font-weight:500;margin-bottom:var(--space-2)}.vocab-confidence{font-size:14px;color:var(--text-muted);margin-top:var(--space-2)}.vocab-result-actions{display:flex;gap:var(--space-5);justify-content:center;margin-top:var(--space-8)}.vocab-result-actions .btn-restart{background:linear-gradient(135deg,#fef3c7,#fde68a);color:#92400e;border:2px solid #f59e0b;padding:var(--space-4) var(--space-8);border-radius:var(--radius-xl);font-size:16px;font-weight:600;cursor:pointer;transition:all .3s ease;display:flex;align-items:center;gap:var(--space-2)}.vocab-result-actions .btn-restart:hover{background:linear-gradient(135deg,#fde68a,#fcd34d);transform:translateY(-2px);box-shadow:0 8px 20px #f59e0b4d}.vocab-result-actions .btn-learning{background:linear-gradient(135deg,#10b981,#059669);color:#fff;border:none;padding:var(--space-4) var(--space-8);border-radius:var(--radius-xl);font-size:16px;font-weight:600;cursor:pointer;transition:all .3s ease;display:flex;align-items:center;gap:var(--space-2);box-shadow:0 6px 20px #10b98159}.vocab-result-actions .btn-learning:hover{background:linear-gradient(135deg,#059669,#047857);transform:translateY(-2px);box-shadow:0 10px 28px #10b98173}.vocab-stats-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--space-6)}.vocab-stats-card{background:linear-gradient(135deg,#f8fafc,#f1f5f9);border:1px solid #e2e8f0;border-radius:var(--radius-xl);box-shadow:var(--shadow-md);padding:var(--space-8)}.vocab-stats-title{font-size:20px;font-weight:700;color:var(--text-primary);margin-bottom:var(--space-6);padding-bottom:var(--space-4);border-bottom:2px solid var(--border)}.vocab-stat-row{display:flex;justify-content:space-between;align-items:center;padding:var(--space-4) 0;border-bottom:1px solid var(--border)}.vocab-stat-row:last-child{border-bottom:none}.vocab-stat-name{font-size:15px;color:var(--text-secondary)}.vocab-stat-value{font-size:18px;font-weight:600;color:var(--text-primary)}.vocab-level-item{display:flex;align-items:center;gap:var(--space-4);margin-bottom:var(--space-4)}.vocab-level-name{width:50px;font-size:15px;font-weight:600;color:var(--text-primary)}.vocab-level-bar{flex:1;height:12px;background:var(--border);border-radius:var(--radius-full);overflow:hidden}.vocab-level-fill{height:100%;border-radius:var(--radius-full);transition:width .5s ease}.vocab-level-count{width:70px;text-align:right;font-size:14px;color:var(--text-secondary);font-weight:500}.vocab-history-card{background:linear-gradient(135deg,#f8fafc,#f1f5f9);border:1px solid #e2e8f0;border-radius:var(--radius-xl);box-shadow:var(--shadow-md);margin-top:var(--space-10)}.vocab-history-title{font-size:20px;font-weight:700;color:var(--text-primary);padding:var(--space-6) var(--space-8);border-bottom:2px solid var(--border)}.vocab-history-list{padding:var(--space-4)}.vocab-history-item{display:flex;justify-content:space-between;align-items:center;padding:var(--space-4) var(--space-5);border-radius:var(--radius-lg);transition:all .2s ease}.vocab-history-item:hover{background:var(--surface-hover)}.vocab-history-info{display:flex;align-items:center;gap:var(--space-4)}.vocab-history-level{padding:6px 16px;background:var(--gradient-reading);color:#fff;border-radius:var(--radius-full);font-size:14px;font-weight:600}.vocab-history-size{font-size:15px;color:var(--text-secondary)}.vocab-history-date{font-size:14px;color:var(--text-muted)}@media (max-width: 768px){.vocab-assessment-page{padding:var(--space-5)}.vocab-features-grid{grid-template-columns:1fr}.vocab-intro-card,.vocab-word-card,.vocab-result-card{padding:var(--space-8) var(--space-6)}.vocab-word{font-size:40px}.vocab-result-stats{flex-direction:column;gap:var(--space-6)}.vocab-result-stat-divider{width:80px;height:2px}.vocab-stats-grid{grid-template-columns:1fr}.vocab-actions{flex-direction:column}.vocab-btn{width:100%}}.vocab-learning-page{min-height:100vh;background:linear-gradient(135deg,#f8fafc,#f1f5f9);padding:2rem;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica,Arial,sans-serif}.vocab-container{max-width:1200px;margin:0 auto}.vocab-header-section{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem;flex-wrap:wrap;gap:1.5rem}.vocab-title-block{flex:1}.vocab-title{display:flex;align-items:center;gap:.75rem;font-size:2rem;font-weight:800;color:#1e293b;margin-bottom:.5rem}.vocab-title svg{color:#3b82f6}.vocab-subtitle{color:#64748b;font-size:1rem}.vocab-daily-progress{background:#fff;padding:1rem 1.5rem;border-radius:16px;box-shadow:0 4px 6px -1px #0000000d;min-width:250px;display:flex;flex-direction:column;gap:.5rem}.progress-label{display:flex;align-items:center;gap:.5rem;font-size:.875rem;font-weight:600;color:#475569}.progress-bar-container{height:8px;background:#e2e8f0;border-radius:4px;overflow:hidden}.progress-bar{height:100%;background:linear-gradient(90deg,#3b82f6,#2563eb);border-radius:4px;transition:width .5s ease}.progress-stats{font-size:.875rem;color:#64748b;text-align:right;display:flex;justify-content:flex-end;align-items:center}.vocab-controls-section{display:flex;flex-direction:column;gap:1.5rem;margin-bottom:2rem}.vocab-search-row{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:1rem}.vocab-search-box{position:relative;flex:1;max-width:300px}.vocab-search-box input{width:100%;padding:.75rem 1rem .75rem 2.75rem;border:1px solid #cbd5e1;border-radius:12px;background:#fff;font-size:.95rem;transition:all .2s}.vocab-search-box input:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.search-icon{position:absolute;left:1rem;top:50%;transform:translateY(-50%);color:#94a3b8;width:1.25rem;height:1.25rem}.vocab-sort-box{position:relative}.vocab-select{-webkit-appearance:none;-moz-appearance:none;appearance:none;padding:.75rem 2.5rem .75rem 1rem;border:1px solid #cbd5e1;border-radius:12px;background:#fff;font-size:.95rem;color:#475569;cursor:pointer;background-image:url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 20 20'%3e%3cpath stroke='%236b7280' stroke-linecap='round' stroke-linejoin='round' stroke-width='1.5' d='M6 8l4 4 4-4'/%3e%3c/svg%3e");background-position:right .5rem center;background-repeat:no-repeat;background-size:1.5em 1.5em}.vocab-select:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.vocab-mode-tabs{display:flex;background:#fff;padding:.375rem;border-radius:12px;border:1px solid #e2e8f0;gap:.25rem;overflow-x:auto}.mode-tab{display:flex;align-items:center;gap:.5rem;padding:.625rem 1rem;border-radius:8px;border:none;background:transparent;color:#64748b;font-weight:600;font-size:.9rem;cursor:pointer;transition:all .2s;white-space:nowrap}.mode-tab:hover{background:#f1f5f9;color:#334155}.mode-tab.active{background:#eff6ff;color:#2563eb}.vocab-levels-row{display:flex;flex-wrap:wrap;gap:.75rem}.level-chip{padding:.5rem 1rem;border-radius:20px;font-size:.875rem;font-weight:600;border:1px solid transparent;background:#fff;color:#64748b;cursor:pointer;transition:all .2s;box-shadow:0 1px 2px #0000000d}.level-chip:hover{transform:translateY(-1px);box-shadow:0 2px 4px #0000000d}.level-chip.active{background:#3b82f6;color:#fff;border-color:#3b82f6}.level-chip.a1.active{background:#22c55e;border-color:#22c55e}.level-chip.a2.active{background:#10b981;border-color:#10b981}.level-chip.b1.active{background:#3b82f6;border-color:#3b82f6}.level-chip.b2.active{background:#6366f1;border-color:#6366f1}.level-chip.c1.active{background:#8b5cf6;border-color:#8b5cf6}.level-chip.c2.active{background:#ec4899;border-color:#ec4899}.level-chip.cet-4.active{background:#f97316;border-color:#f97316}.level-chip.cet-6.active{background:#ef4444;border-color:#ef4444}.vocab-word-list{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1.5rem}.vocab-word-card{background:#fff;border-radius:16px;border:1px solid #e2e8f0;padding:1.5rem;transition:all .2s;display:flex;flex-direction:column}.vocab-word-card:hover{transform:translateY(-2px);box-shadow:0 10px 20px -5px #0000000d;border-color:#cbd5e1}.vocab-word-main{display:flex;flex-direction:column;flex:1}.vocab-word-info{flex:1}.vocab-word-header{display:flex;align-items:center;gap:.75rem;margin-bottom:.5rem;flex-wrap:wrap}.vocab-word-text{font-size:1.5rem;font-weight:700;color:#1e293b}.vocab-phonetics{display:flex;gap:.5rem;font-family:Lucida Sans Unicode,Arial Unicode MS,sans-serif;color:#64748b;font-size:.85rem}.phonetic-tag{background:#f8fafc;padding:2px 6px;border-radius:4px;border:1px solid #e2e8f0}.vocab-word-badge{padding:.25rem .625rem;border-radius:6px;font-size:.75rem;font-weight:700;text-transform:uppercase;background:#f1f5f9;color:#64748b;margin-left:auto}.vocab-word-badge.cet-4{background:#fff7ed;color:#c2410c}.vocab-word-badge.cet-6{background:#fef2f2;color:#b91c1c}.vocab-mastered-badge{display:flex;align-items:center;gap:.25rem;font-size:.75rem;color:#16a34a;background:#dcfce7;padding:.25rem .5rem;border-radius:6px;font-weight:600}.vocab-word-meaning{font-size:1rem;color:#334155;line-height:1.6;margin-bottom:.75rem;font-weight:500}.vocab-pos-tag{display:inline-block;font-size:.75rem;color:#64748b;font-style:italic;margin-right:.5rem;font-weight:400}.vocab-rich-preview{font-size:.875rem;color:#64748b;display:flex;flex-direction:column;gap:.5rem}.vocab-word-example{font-style:italic;padding-left:.75rem;border-left:2px solid #e2e8f0;color:#475569}.vocab-memory-tip-preview{display:flex;align-items:flex-start;gap:.5rem;font-size:.8rem;background:#fffbeb;padding:.5rem;border-radius:6px;color:#b45309}.vocab-word-actions{display:flex;justify-content:flex-end;gap:.5rem;margin-top:1rem;padding-top:1rem;border-top:1px solid #f1f5f9}.vocab-action-btn{width:36px;height:36px;display:flex;align-items:center;justify-content:center;border-radius:50%;border:1px solid #e2e8f0;background:#fff;color:#64748b;cursor:pointer;transition:all .2s}.vocab-action-btn:hover{background:#f8fafc;color:#3b82f6;border-color:#cbd5e1}.vocab-action-btn.bookmarked{background:#eff6ff;color:#3b82f6;border-color:#bfdbfe}.vocab-flashcard-container{display:flex;flex-direction:column;align-items:center;gap:2rem;padding:2rem 0}.vocab-flashcard{width:100%;max-width:600px;min-height:450px;background:#fff;border-radius:24px;box-shadow:0 20px 40px -10px #0000001a;cursor:pointer;transition:transform .3s ease,box-shadow .3s ease;perspective:1000px;position:relative;border:1px solid #e2e8f0}.vocab-flashcard:hover{transform:translateY(-5px);box-shadow:0 25px 50px -12px #00000026}.vocab-flashcard-content{padding:3rem;height:100%;display:flex;flex-direction:column}.vocab-flashcard-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem}.vocab-freq-badge{font-size:.75rem;background:#fef3c7;color:#d97706;padding:2px 8px;border-radius:12px;display:flex;align-items:center;gap:4px;font-weight:600}.vocab-flashcard-word{font-size:3.5rem;font-weight:800;color:#1e293b;text-align:center;margin-bottom:.5rem}.vocab-flashcard-phonetics{display:flex;justify-content:center;gap:1.5rem;color:#64748b;font-size:1.1rem;margin-bottom:3rem;font-family:Lucida Sans Unicode,Arial Unicode MS,sans-serif}.vocab-flashcard-meaning-section{text-align:center;animation:fadeIn .3s ease;flex:1;display:flex;flex-direction:column}.vocab-flashcard-meaning{font-size:1.5rem;color:#334155;margin-bottom:2rem;line-height:1.4;font-weight:600}.vocab-rich-data{text-align:left;background:#f8fafc;padding:1.5rem;border-radius:12px;margin-bottom:1.5rem;font-size:.95rem;display:flex;flex-direction:column;gap:.75rem}.rich-row{color:#475569}.rich-row strong{color:#1e293b;margin-right:.5rem}.rich-row.memory-tip{color:#b45309;background:#fffbeb;padding:.5rem;border-radius:6px;margin-top:.5rem}.rich-row.source{font-size:.85rem;color:#64748b;border-top:1px dashed #e2e8f0;padding-top:.5rem;margin-top:.25rem}.vocab-examples-list{text-align:left;border-left:3px solid #3b82f6;padding-left:1rem}.vocab-flashcard-example{margin-bottom:1rem;font-size:1rem;color:#334155;line-height:1.5}.vocab-click-hint{text-align:center;color:#94a3b8;margin-top:auto;font-size:.9rem}.vocab-flashcard-controls-bar{display:flex;gap:1rem;align-items:center}.vocab-control-btn{display:flex;align-items:center;gap:.5rem;padding:.75rem 1.5rem;border-radius:12px;font-weight:600;cursor:pointer;transition:all .2s;border:none}.vocab-control-btn.prev,.vocab-control-btn.next{background:#fff;border:1px solid #e2e8f0;color:#64748b}.vocab-control-btn:disabled{opacity:.5;cursor:not-allowed}.vocab-control-btn.master{background:#22c55e;color:#fff;padding:.75rem 2rem;font-size:1.1rem;box-shadow:0 4px 12px #22c55e4d}.vocab-control-btn.master:hover{background:#16a34a;transform:translateY(-2px)}.vocab-quiz-container{display:flex;justify-content:center;padding:2rem 0}.vocab-quiz-card{width:100%;max-width:600px;background:#fff;border-radius:24px;padding:3rem;box-shadow:0 10px 30px -5px #0000001a;text-align:center}.vocab-quiz-header{display:flex;justify-content:space-between;margin-bottom:2rem;color:#64748b;font-size:.9rem}.vocab-quiz-word{font-size:2.5rem;font-weight:800;color:#1e293b;margin-bottom:.5rem}.vocab-quiz-phonetics{color:#64748b;font-size:1.1rem;margin-bottom:2.5rem}.vocab-quiz-options{display:flex;flex-direction:column;gap:1rem}.vocab-quiz-option{padding:1.25rem;border:2px solid #e2e8f0;border-radius:12px;background:#fff;color:#334155;font-size:1.1rem;cursor:pointer;transition:all .2s;display:flex;align-items:center;text-align:left}.vocab-quiz-option:hover:not(:disabled){border-color:#3b82f6;background:#eff6ff}.vocab-quiz-option.correct{background:#dcfce7;border-color:#22c55e;color:#15803d}.vocab-quiz-option.wrong{background:#fee2e2;border-color:#ef4444;color:#b91c1c}.vocab-quiz-feedback{margin-top:2rem;padding-top:2rem;border-top:1px solid #f1f5f9;display:flex;justify-content:space-between;align-items:center;animation:slideUp .3s ease}.feedback-success{color:#16a34a;font-weight:700;display:flex;align-items:center;gap:.5rem}.feedback-error{color:#dc2626;font-weight:700;display:flex;align-items:center;gap:.5rem}.vocab-next-btn{padding:.5rem 1.5rem;background:#3b82f6;color:#fff;border:none;border-radius:8px;font-weight:600;cursor:pointer;display:flex;align-items:center;gap:.5rem}.vocab-spelling-container{display:flex;justify-content:center;padding:2rem 0}.vocab-spelling-card{width:100%;max-width:600px;background:#fff;border-radius:24px;padding:3rem;box-shadow:0 10px 30px -5px #0000001a;text-align:center}.vocab-play-btn{width:80px;height:80px;border-radius:50%;background:#3b82f6;color:#fff;border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;margin:0 auto 1.5rem;transition:transform .2s;box-shadow:0 10px 20px #3b82f64d}.vocab-play-btn:hover{transform:scale(1.05);background:#2563eb}.vocab-spelling-meaning{font-size:1.25rem;color:#334155;margin-bottom:2rem}.vocab-spelling-input{width:100%;padding:1rem;font-size:1.5rem;text-align:center;border:2px solid #e2e8f0;border-radius:12px;margin-bottom:1rem;letter-spacing:2px}.vocab-spelling-input:focus{outline:none;border-color:#3b82f6}.vocab-spelling-input.correct{border-color:#22c55e;background:#f0fdf4;color:#15803d}.vocab-spelling-input.wrong{border-color:#ef4444;background:#fef2f2;color:#b91c1c}.vocab-check-btn{width:100%;padding:1rem;background:#0f172a;color:#fff;border:none;border-radius:12px;font-size:1.1rem;font-weight:600;cursor:pointer}.vocab-hint-btn{margin-top:1rem;background:transparent;border:none;color:#94a3b8;text-decoration:underline;cursor:pointer}.vocab-completion-container{display:flex;justify-content:center;padding:2rem 0}.vocab-completion-card{width:100%;max-width:600px;background:#fff;border-radius:24px;padding:3rem;box-shadow:0 10px 30px -5px #0000001a}.vocab-completion-header{display:flex;justify-content:space-between;margin-bottom:2rem;align-items:center}.vocab-mode-badge{display:flex;align-items:center;gap:.5rem;font-weight:600;color:#3b82f6;background:#eff6ff;padding:.5rem 1rem;border-radius:20px}.vocab-sentence-box{background:#f8fafc;padding:2rem;border-radius:16px;margin-bottom:2rem;border:1px solid #e2e8f0}.vocab-sentence-en{font-size:1.25rem;color:#1e293b;line-height:1.6;margin-bottom:1rem;font-weight:500}.vocab-sentence-zh{font-size:1rem;color:#64748b}.vocab-completion-input-area{display:flex;gap:1rem;margin-bottom:1.5rem}.vocab-completion-input{flex:1;padding:1rem;border:2px solid #e2e8f0;border-radius:12px;font-size:1.1rem}.vocab-completion-input:focus{outline:none;border-color:#3b82f6}.vocab-completion-input.correct{border-color:#22c55e;background:#f0fdf4;color:#15803d}.vocab-completion-input.wrong{border-color:#ef4444;background:#fef2f2;color:#b91c1c}.vocab-completion-feedback{display:flex;justify-content:space-between;align-items:center;padding-top:1.5rem;border-top:1px solid #f1f5f9;animation:slideUp .3s ease}.vocab-hint-area{margin-top:1.5rem;text-align:center}@keyframes slideUp{0%{transform:translateY(10px);opacity:0}to{transform:translateY(0);opacity:1}}.vocab-pagination{display:flex;justify-content:center;align-items:center;gap:1rem;margin-top:3rem}.page-btn{width:40px;height:40px;border-radius:50%;border:1px solid #e2e8f0;background:#fff;display:flex;align-items:center;justify-content:center;cursor:pointer;color:#64748b}.page-btn:disabled{opacity:.5;cursor:not-allowed}.page-btn:not(:disabled):hover{border-color:#3b82f6;color:#3b82f6}.vocab-empty-state{text-align:center;padding:4rem;color:#94a3b8;grid-column:1 / -1;display:flex;flex-direction:column;align-items:center;gap:1rem}.vocab-empty-state svg{width:4rem;height:4rem;opacity:.5}.wp-page{max-width:1200px;margin:0 auto;padding:var(--space-6)}.wp-hero{position:relative;background:linear-gradient(135deg,#f59e0b14,#fbbf241f 40%,#f59e0b0f);border-radius:var(--radius-2xl);border:1px solid rgba(245,158,11,.15);padding:var(--space-12) var(--space-10);margin-bottom:var(--space-10);overflow:hidden;display:flex;align-items:center;justify-content:space-between;gap:var(--space-8)}.wp-hero-glow{position:absolute;top:-30%;right:-10%;width:500px;height:500px;background:radial-gradient(circle,rgba(245,158,11,.12) 0%,transparent 70%);border-radius:50%;pointer-events:none}.wp-hero-content{position:relative;z-index:1;flex:1}.wp-hero-badge{display:inline-flex;align-items:center;gap:var(--space-2);background:#f59e0b1f;border:1px solid rgba(245,158,11,.2);border-radius:var(--radius-full);padding:6px 16px;font-size:13px;font-weight:600;color:var(--writing-dark);margin-bottom:var(--space-5)}.wp-hero-badge-icon{font-size:14px}.wp-hero-title{font-size:32px;font-weight:800;color:var(--text-primary);line-height:1.35;margin:0 0 var(--space-4) 0;letter-spacing:-.02em}.wp-hero-divider{color:var(--writing)}.wp-hero-subtitle{font-size:15px;color:var(--text-secondary);line-height:1.75;margin:0 0 var(--space-8) 0;max-width:560px}.wp-hero-actions{display:flex;gap:var(--space-4);flex-wrap:wrap}.wp-hero-btn-primary,.wp-hero-btn-primary.button{background:var(--gradient-writing)!important;color:#fff!important;box-shadow:0 4px 20px #f59e0b59!important;font-weight:700!important;padding:14px 28px!important;font-size:15px!important;display:inline-flex!important;align-items:center;gap:var(--space-2);transition:all .3s ease}.wp-hero-btn-primary:hover{box-shadow:0 6px 28px #f59e0b73!important;transform:translateY(-2px)}.wp-hero-btn-secondary,.wp-hero-btn-secondary.button{border:2px solid var(--writing-light)!important;color:var(--writing-dark)!important;font-weight:600!important;padding:12px 28px!important;font-size:15px!important;display:inline-flex!important;align-items:center;gap:var(--space-2);transition:all .3s ease;background:#fff9!important}.wp-hero-btn-secondary:hover{background:#f59e0b14!important;border-color:var(--writing)!important}.wp-btn-icon{font-size:18px;line-height:1}.wp-hero-visual{position:relative;z-index:1;flex-shrink:0}.wp-hero-step-preview{display:flex;align-items:center;gap:var(--space-3);background:#fff9;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border:1px solid rgba(245,158,11,.15);border-radius:var(--radius-xl);padding:var(--space-5) var(--space-8)}.wp-hero-step-icon{font-size:36px;line-height:1;animation:wp-float 3s ease-in-out infinite}.wp-hero-step-icon:nth-child(3){animation-delay:.4s}.wp-hero-step-icon:nth-child(5){animation-delay:.8s}.wp-hero-step-arrow{width:32px;height:2px;background:linear-gradient(90deg,var(--writing-light),var(--writing));border-radius:1px;position:relative}.wp-hero-step-arrow:after{content:"";position:absolute;right:-4px;top:-3px;width:0;height:0;border-top:4px solid transparent;border-bottom:4px solid transparent;border-left:6px solid var(--writing)}@keyframes wp-float{0%,to{transform:translateY(0)}50%{transform:translateY(-6px)}}.wp-section{margin-bottom:var(--space-10)}.wp-section-title{font-size:20px;font-weight:700;color:var(--text-primary);margin:0 0 var(--space-2) 0;display:flex;align-items:center;gap:var(--space-3)}.wp-section-title-bar{width:5px;height:22px;background:linear-gradient(180deg,var(--writing) 0%,var(--writing-light) 100%);border-radius:var(--radius-full);flex-shrink:0}.wp-section-desc{font-size:14px;color:var(--text-tertiary);margin:0 0 var(--space-6) 0;padding-left:calc(5px + var(--space-3))}.wp-flow{display:flex;align-items:stretch;gap:0}.wp-flow-step{flex:1;background:#fff;border:1px solid var(--border-subtle);border-radius:var(--radius-xl);padding:var(--space-6);display:flex;flex-direction:column;align-items:center;text-align:center;position:relative;cursor:pointer;transition:all .3s ease;min-width:0}.wp-flow-step:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg);border-color:var(--writing-light)}.wp-flow-step:focus-visible{outline:2px solid var(--writing);outline-offset:2px}.wp-flow-step--auto{cursor:default;background:linear-gradient(145deg,#fafafa,#f5f5f5)}.wp-flow-step--auto:hover{transform:none;box-shadow:none;border-color:var(--border-subtle)}.wp-flow-step--highlight{background:linear-gradient(145deg,#fffbf0,#fff8e6);border-color:#f59e0b4d;box-shadow:0 4px 16px #f59e0b1f}.wp-flow-step--highlight:hover{box-shadow:0 8px 28px #f59e0b33;border-color:var(--writing)}.wp-flow-step-number{position:absolute;top:var(--space-3);left:var(--space-3);width:24px;height:24px;border-radius:50%;background:var(--bg-tertiary);color:var(--text-tertiary);font-size:12px;font-weight:700;display:flex;align-items:center;justify-content:center}.wp-flow-step--highlight .wp-flow-step-number{background:var(--writing);color:#fff}.wp-flow-step-icon-wrap{width:56px;height:56px;border-radius:50%;background:var(--bg-tertiary);display:flex;align-items:center;justify-content:center;margin-bottom:var(--space-4);transition:all .3s ease}.wp-flow-step--highlight .wp-flow-step-icon-wrap{background:#f59e0b1f}.wp-flow-step:hover .wp-flow-step-icon-wrap{transform:scale(1.1)}.wp-flow-step-icon{font-size:28px;line-height:1}.wp-flow-step-content{flex:1;display:flex;flex-direction:column;align-items:center}.wp-flow-step-title{font-size:16px;font-weight:700;color:var(--text-primary);margin:0 0 2px}.wp-flow-step-title-en{font-size:12px;color:var(--text-tertiary);margin:0 0 var(--space-3) 0;font-weight:500}.wp-flow-step-desc{font-size:13px;color:var(--text-secondary);line-height:1.6;margin:0}.wp-flow-step-action{display:flex;align-items:center;gap:4px;margin-top:var(--space-4);font-size:13px;font-weight:600;color:var(--writing);transition:gap .2s ease}.wp-flow-step:hover .wp-flow-step-action{gap:8px}.wp-flow-step-auto-badge{display:flex;align-items:center;gap:4px;margin-top:var(--space-4);font-size:12px;font-weight:500;color:var(--text-tertiary)}.wp-flow-step-highlight-badge{position:absolute;top:var(--space-3);right:var(--space-3);background:var(--writing);color:#fff;font-size:11px;font-weight:700;padding:2px 10px;border-radius:var(--radius-full)}.wp-flow-connector{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:0 4px;min-width:36px;flex-shrink:0}.wp-flow-connector-line{width:2px;flex:1;background:linear-gradient(180deg,transparent 0%,var(--writing-light) 30%,var(--writing-light) 70%,transparent 100%)}.wp-flow-connector-arrow{color:var(--writing);flex-shrink:0;margin:2px 0}.wp-flow-hierarchical{display:flex;align-items:stretch;gap:var(--space-4)}.wp-phase{flex:1;background:#fff;border-radius:var(--radius-xl);border:1px solid var(--border);padding:var(--space-6);display:flex;flex-direction:column}.wp-phase-header{display:flex;align-items:flex-start;gap:var(--space-4);margin-bottom:var(--space-5)}.wp-phase-number{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:50%;background:var(--gradient-writing);color:#fff;font-weight:800;font-size:16px;flex-shrink:0}.wp-phase-title{font-size:18px;font-weight:700;color:var(--text-primary);margin:0 0 4px}.wp-phase-desc{font-size:13px;color:var(--text-secondary);margin:0}.wp-phase-steps{display:flex;flex-direction:column;gap:var(--space-3)}.wp-mini-step{display:flex;align-items:center;gap:var(--space-3);padding:12px 16px;background:#fafafa;border-radius:var(--radius-lg);cursor:pointer;transition:all .2s ease;border:1px solid transparent}.wp-mini-step:hover{background:#f59e0b0f;border-color:#f59e0b26}.wp-mini-step-icon{font-size:22px;flex-shrink:0}.wp-mini-step-title{display:block;font-weight:600;font-size:14px;color:var(--text-primary)}.wp-mini-step-desc{display:block;font-size:12px;color:var(--text-secondary);margin-top:2px}.wp-mini-step-arrow{margin-left:auto;flex-shrink:0;color:var(--text-tertiary);opacity:0;transition:opacity .2s ease}.wp-mini-step:hover .wp-mini-step-arrow{opacity:1}.wp-phase-connector{display:flex;align-items:center;justify-content:center;flex-shrink:0;color:var(--writing)}@media (max-width: 768px){.wp-flow-hierarchical{flex-direction:column}.wp-phase-connector{transform:rotate(90deg)}}.wp-stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--space-5)}.wp-stat-card{background:#fff;border:1px solid var(--border-subtle);border-radius:var(--radius-xl);box-shadow:none;transition:all .3s ease}.wp-stat-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-md)}.wp-stat-card .card-content{display:flex;align-items:center;gap:var(--space-4);padding:var(--space-5) var(--space-6)!important}.wp-stat-icon{width:48px;height:48px;border-radius:var(--radius-lg);display:flex;align-items:center;justify-content:center;font-size:22px;flex-shrink:0}.wp-stat-info{display:flex;flex-direction:column;min-width:0}.wp-stat-value{font-size:22px;font-weight:800;color:var(--text-primary);line-height:1.2}.wp-stat-label{font-size:13px;color:var(--text-tertiary);font-weight:500;margin-top:2px}.wp-bottom-grid{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-6)}.wp-activity-panel{background:#fff;border:1px solid var(--border-subtle);border-radius:var(--radius-xl);padding:var(--space-6);min-height:260px}.wp-activity-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-5)}.wp-activity-title{display:flex;align-items:center;gap:var(--space-2);font-size:16px;font-weight:700;color:var(--text-primary);margin:0}.wp-activity-title-icon{font-size:20px}.wp-activity-more{display:flex;align-items:center;gap:4px;font-size:13px;font-weight:600;color:var(--writing);background:none;border:none;cursor:pointer;padding:4px 8px;border-radius:var(--radius-sm);transition:all .2s ease}.wp-activity-more:hover{background:#f59e0b14}.wp-activity-list{display:flex;flex-direction:column;gap:var(--space-3)}.wp-activity-item{display:flex;align-items:center;justify-content:space-between;gap:var(--space-4);padding:var(--space-3) var(--space-4);border-radius:var(--radius-lg);cursor:pointer;transition:all .2s ease}.wp-activity-item:hover{background:var(--bg-secondary)}.wp-activity-item-main{min-width:0;flex:1}.wp-activity-item-title{display:block;font-size:14px;font-weight:600;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-bottom:4px}.wp-activity-item-meta{display:flex;align-items:center;gap:var(--space-3);flex-wrap:wrap}.wp-activity-item-time{font-size:12px;color:var(--text-tertiary);white-space:nowrap;flex-shrink:0}.wp-activity-item-type,.wp-activity-item-words{font-size:12px;color:var(--text-tertiary)}.wp-status-tag{display:inline-flex;align-items:center;font-size:11px;font-weight:600;padding:2px 8px;border-radius:var(--radius-full);white-space:nowrap}.wp-status-draft{background:#f59e0b1a;color:#b45309}.wp-status-submitted{background:#3b82f61a;color:#1d4ed8}.wp-status-reviewed{background:#10b9811a;color:#047857}.wp-status-revising{background:#8b5cf61a;color:#6d28d9}.wp-activity-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--space-3);padding:var(--space-10) 0;color:var(--text-tertiary);font-size:14px}.wp-spinner{width:24px;height:24px;border:3px solid var(--border-subtle);border-top-color:var(--writing);border-radius:50%;animation:wp-spin .8s linear infinite}@keyframes wp-spin{to{transform:rotate(360deg)}}.wp-activity-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--space-10) 0;text-align:center}.wp-activity-empty-icon{font-size:40px;margin-bottom:var(--space-3);opacity:.6}.wp-activity-empty p{color:var(--text-tertiary);font-size:14px;margin:0 0 var(--space-4) 0}@media (max-width: 1200px){.wp-flow{flex-wrap:wrap;justify-content:center}.wp-flow-step{flex:0 0 calc(33.333% - 24px);min-width:180px}.wp-flow-connector{display:none}}@media (max-width: 1024px){.wp-page{padding:var(--space-5)}.wp-hero{padding:var(--space-8);flex-direction:column;text-align:center}.wp-hero-subtitle{margin-left:auto;margin-right:auto}.wp-hero-actions{justify-content:center}.wp-hero-visual{display:none}.wp-stats-grid{grid-template-columns:repeat(2,1fr)}.wp-flow-step{flex:0 0 calc(50% - 16px)}}@media (max-width: 768px){.wp-page{padding:var(--space-4)}.wp-hero{padding:var(--space-6);margin-bottom:var(--space-6)}.wp-hero-title{font-size:24px}.wp-hero-subtitle{font-size:14px}.wp-section{margin-bottom:var(--space-6)}.wp-flow-step{flex:0 0 100%}.wp-flow-connector{display:flex;flex-direction:row;width:100%;min-width:unset;padding:var(--space-1) 0}.wp-flow-connector-line{height:2px;width:auto;flex:1;background:linear-gradient(90deg,transparent 0%,var(--writing-light) 30%,var(--writing-light) 70%,transparent 100%)}.wp-bottom-grid{grid-template-columns:1fr}.wp-stat-card .card-content{padding:var(--space-4)!important}.wp-stat-icon{width:40px;height:40px;font-size:18px}.wp-stat-value{font-size:18px}}@media (max-width: 480px){.wp-page{padding:var(--space-3)}.wp-hero{padding:var(--space-5)}.wp-hero-title{font-size:22px}.wp-hero-actions{flex-direction:row;flex-wrap:nowrap;gap:8px}.wp-hero-actions .button{flex:1;min-width:0;padding:10px 12px!important;font-size:13px!important;white-space:nowrap}.wp-stats-grid{grid-template-columns:repeat(2,1fr);gap:var(--space-3)}.wp-activity-panel{padding:var(--space-4)}}.wp-pretest-banner{display:flex;align-items:center;justify-content:space-between;gap:16px;margin:0 0 var(--space-6) 0;padding:16px 20px;background:linear-gradient(135deg,#fffbeb,#fef3c7);border:1px solid #fde68a;border-radius:12px}.wp-pretest-banner-left{display:flex;align-items:center;gap:14px}.wp-pretest-banner-icon{font-size:32px;flex-shrink:0}.wp-pretest-banner-title{font-size:16px;font-weight:600;color:#92400e;margin-bottom:2px}.wp-pretest-banner-desc{font-size:13px;color:#b45309;margin:0}.wp-pretest-banner-btn{flex-shrink:0;padding:10px 20px;background:linear-gradient(135deg,#f59e0b,#f97316);color:#fff;border:none;border-radius:10px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s ease;white-space:nowrap}.wp-pretest-banner-btn:hover{transform:translateY(-1px);box-shadow:0 4px 12px #f59e0b66}@media (max-width: 640px){.wp-pretest-banner{flex-direction:column;align-items:stretch;text-align:center}.wp-pretest-banner-left{flex-direction:column;gap:8px}.wp-pretest-banner-btn{width:100%}}.writing-editor-page{max-width:1400px;margin:0 auto;padding:var(--space-6)}.editor-header{display:flex;justify-content:space-between;align-items:center;padding:var(--space-5) var(--space-6);background:linear-gradient(135deg,#fffbeb,#fef3c7);border:1px solid #fcd34d;border-radius:var(--radius-xl);margin-bottom:var(--space-6);box-shadow:0 2px 8px #f59e0b1a}.editor-header-left{display:flex;align-items:center;gap:var(--space-5);flex:1}.back-link{display:flex;align-items:center;gap:var(--space-2);color:var(--text-secondary);text-decoration:none;font-size:14px;font-weight:500;padding:var(--space-2) var(--space-3);border-radius:var(--radius-md);transition:all .2s ease}.back-link:hover{color:var(--writing);background:#f59e0b1a}.title-wrapper{display:flex;align-items:center;gap:var(--space-4);flex:1;max-width:600px}.title-input{flex:1;font-size:20px;font-weight:600;border:none;outline:none;color:var(--text-primary);background:transparent;padding:var(--space-2) var(--space-3);border-radius:var(--radius-md);transition:all .2s ease}.title-input:hover{background:#ffffff80}.title-input:focus{background:#fff;box-shadow:0 0 0 2px var(--writing-light)}.title-input::placeholder{color:var(--text-muted)}.type-badge{padding:var(--space-2) var(--space-4);background:#f59e0b33;color:var(--writing-dark);border-radius:var(--radius-full);font-size:13px;font-weight:600;white-space:nowrap}.editor-header-right{display:flex;align-items:center;gap:12px;flex-shrink:0;flex-wrap:wrap}.word-count{display:flex;align-items:center;gap:6px;font-size:14px;font-weight:500;color:var(--text-secondary);padding:6px 12px;background:#0000000d;border-radius:var(--radius-md);white-space:nowrap}.editor-header-right button{min-width:100px;padding:8px 20px;font-size:14px;font-weight:600;border-radius:8px;white-space:nowrap}.editor-header-right button:hover{transform:translateY(-1px);box-shadow:0 2px 8px #0000001f}.word-count svg{opacity:.6}.editor-layout{display:grid;grid-template-columns:300px 1fr;gap:var(--space-6);min-height:calc(100vh - 220px)}.editor-sidebar{display:flex;flex-direction:column;background:linear-gradient(135deg,#fff,#fafafa);border:1px solid #e5e5e5;border-radius:var(--radius-xl);overflow:hidden;box-shadow:0 2px 8px #0000000a}.sidebar-tabs{display:flex;border-bottom:1px solid var(--border);background:linear-gradient(135deg,#fafafa,#f5f5f5)}.sidebar-tab{flex:1;padding:var(--space-4);border:none;background:transparent;font-size:14px;font-weight:600;color:var(--text-secondary);cursor:pointer;transition:all .2s ease;position:relative}.sidebar-tab:hover{color:var(--text-primary);background:#f59e0b0d}.sidebar-tab.active{color:var(--writing);background:#fff}.sidebar-tab.active:after{content:"";position:absolute;bottom:0;left:0;right:0;height:3px;background:var(--writing);border-radius:var(--radius-full) var(--radius-full) 0 0}.sidebar-content{padding:var(--space-6);flex:1;overflow-y:auto}.writing-tips h3,.outline-section h3{font-size:15px;font-weight:700;color:var(--text-primary);margin-bottom:var(--space-5);display:flex;align-items:center;gap:var(--space-2)}.writing-tips h3:before,.outline-section h3:before{content:"";width:4px;height:16px;background:var(--writing);border-radius:var(--radius-full)}.writing-tips ul{list-style:none;padding:0;margin:0}.writing-tips li{padding:var(--space-3) 0;padding-left:var(--space-5);position:relative;font-size:14px;color:var(--text-secondary);line-height:1.6;border-bottom:1px solid rgba(0,0,0,.05)}.writing-tips li:last-child{border-bottom:none}.writing-tips li:before{content:"";position:absolute;left:0;top:50%;transform:translateY(-50%);width:8px;height:8px;background:var(--writing-light);border-radius:50%}.outline-item{margin-bottom:var(--space-5)}.outline-label{display:block;font-size:13px;font-weight:600;color:var(--text-secondary);margin-bottom:var(--space-2)}.outline-item input{width:100%;padding:var(--space-3) var(--space-4);border:1px solid var(--border);border-radius:var(--radius-md);font-size:14px;outline:none;transition:all .2s ease;background:#fff}.outline-item input:focus{border-color:var(--writing);box-shadow:0 0 0 3px #f59e0b26}.feedback-section{text-align:center;padding:var(--space-10) var(--space-4)}.feedback-placeholder{font-size:14px;color:var(--text-muted);background:#00000005;padding:var(--space-6);border-radius:var(--radius-lg);border:1px dashed var(--border)}.editor-main{display:flex;flex-direction:column;background:#fff;border:1px solid #e5e5e5;border-radius:var(--radius-xl);overflow:hidden;box-shadow:0 2px 8px #0000000a}.formatting-toolbar{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-3) var(--space-4);background:linear-gradient(135deg,#fafafa,#f5f5f5);border-bottom:1px solid #e5e5e5;flex-wrap:wrap}.toolbar-group{display:flex;align-items:center;gap:var(--space-1)}.toolbar-divider{width:1px;height:24px;background:#d1d5db;margin:0 var(--space-2)}.font-select,.font-size-select,.line-height-select{padding:var(--space-2) var(--space-3);border:1px solid var(--border);border-radius:var(--radius-md);font-size:13px;background:#fff;color:var(--text-primary);cursor:pointer;outline:none;transition:all .2s ease}.font-select{min-width:130px}.font-size-select,.line-height-select{min-width:65px}.font-select:hover,.font-size-select:hover,.line-height-select:hover{border-color:var(--writing)}.font-select:focus,.font-size-select:focus,.line-height-select:focus{border-color:var(--writing);box-shadow:0 0 0 2px #f59e0b26}.format-btn{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border:none;background:transparent;border-radius:var(--radius-md);color:var(--text-secondary);cursor:pointer;transition:all .2s ease}.format-btn:hover{background:#f59e0b1a;color:var(--writing)}.format-btn.active{background:var(--writing);color:#fff}.format-btn:active{transform:scale(.95)}.editor-content-wrapper{flex:1;padding:var(--space-4);background:linear-gradient(135deg,#fafafa,#fff)}.editor-textarea{width:100%;min-height:500px;height:calc(100vh - 380px);padding:var(--space-6) var(--space-8);background:#fff;border-radius:var(--radius-lg);box-shadow:inset 0 1px 3px #0000000f;border:1px solid #e5e5e5;outline:none;font-size:16px;line-height:1.8;color:var(--text-primary);resize:none;transition:all .2s ease}.editor-textarea:focus{box-shadow:inset 0 1px 3px #0000000f,0 0 0 3px #f59e0b26;border-color:var(--writing-light)}.editor-textarea::placeholder{color:var(--text-muted);font-style:italic}@media (max-width: 1200px){.editor-layout{grid-template-columns:260px 1fr;gap:var(--space-5)}}@media (max-width: 1024px){.writing-editor-page{padding:var(--space-4)}.editor-layout{grid-template-columns:1fr}.editor-sidebar{order:-1;max-height:280px}.formatting-toolbar{overflow-x:auto;padding-bottom:var(--space-2)}}@media (max-width: 768px){.editor-header{flex-direction:column;gap:var(--space-4);padding:var(--space-4);align-items:stretch}.editor-header-left{flex-direction:column;align-items:stretch;gap:var(--space-3)}.title-wrapper{flex-direction:column;align-items:stretch;max-width:none;gap:var(--space-2)}.title-input{font-size:18px;text-align:center}.type-badge{text-align:center}.editor-header-right{justify-content:center;flex-wrap:wrap;gap:var(--space-3)}.formatting-toolbar{justify-content:center}.toolbar-divider{display:none}.editor-content-wrapper{padding:var(--space-3)}.editor-textarea{min-height:350px;padding:var(--space-4);font-size:15px}}@media (max-width: 480px){.writing-editor-page,.editor-header{padding:var(--space-3)}.sidebar-content{padding:var(--space-4)}.formatting-toolbar{gap:var(--space-1);padding:var(--space-2)}.font-select{min-width:100px}.format-btn{width:32px;height:32px}}.save-msg{font-size:13px;font-weight:500;padding:4px 12px;border-radius:6px;animation:fadeIn .2s ease}.save-msg.success{color:#16a34a;background:#f0fdf4}.save-msg.error{color:#dc2626;background:#fef2f2}.feedback-overall-score{display:flex;flex-direction:column;align-items:center;gap:8px;padding:20px 0;margin-bottom:16px;border-bottom:1px solid #e2e8f0}.score-circle{width:80px;height:80px;border-radius:50%;border:4px solid;display:flex;align-items:baseline;justify-content:center;gap:2px}.score-number{font-size:28px;font-weight:700}.score-total{font-size:14px;color:#94a3b8}.score-label{font-size:15px;font-weight:600}.feedback-dimension-scores{display:flex;flex-direction:column;gap:10px;margin-bottom:20px}.dimension-item{display:flex;align-items:center;gap:10px}.dimension-label{font-size:13px;color:#64748b;min-width:60px;text-align:right}.dimension-bar-bg{flex:1;height:8px;background:#f1f5f9;border-radius:4px;overflow:hidden}.dimension-bar-fill{height:100%;border-radius:4px;transition:width .5s ease}.dimension-score{font-size:13px;font-weight:600;min-width:28px;text-align:right}.feedback-block{margin-bottom:16px;padding-bottom:16px;border-bottom:1px solid #f1f5f9}.feedback-block h4{font-size:14px;font-weight:600;margin-bottom:8px;color:#334155}.feedback-block p{font-size:13px;line-height:1.6;color:#475569}.feedback-block ul{list-style:none;padding:0;margin:0}.feedback-block ul li{font-size:13px;line-height:1.6;color:#475569;padding:4px 0 4px 16px;position:relative}.feedback-block ul li:before{content:"•";position:absolute;left:0;color:#94a3b8}.corrected-text{font-size:13px;line-height:1.8;color:#334155;background:#f8fafc;padding:12px;border-radius:8px;border:1px solid #e2e8f0;white-space:pre-wrap}.feedback-badge{display:inline-flex;align-items:center;justify-content:center;width:14px;height:14px;font-size:10px;font-weight:700;color:#fff;background:#ef4444;border-radius:50%;margin-left:4px}.feedback-placeholder{text-align:center;padding:40px 20px;color:#94a3b8}.feedback-placeholder p{font-size:14px;line-height:1.6}.writing-drafts-page{max-width:900px;margin:0 auto}.drafts-list{display:flex;flex-direction:column;gap:var(--space-4)}.draft-card{background:linear-gradient(135deg,#fafafa,#f5f5f5);border:1px solid #e5e5e5;border-radius:var(--radius-lg);transition:all .3s ease}.draft-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-md);border-color:var(--writing-light)}.draft-card .card-content{display:flex;justify-content:space-between;align-items:center;gap:var(--space-6);padding:20px 24px}.draft-info{flex:1;min-width:0}.draft-title{font-size:16px;font-weight:600;color:var(--text-primary);margin-bottom:var(--space-2);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.draft-meta{display:flex;align-items:center;gap:var(--space-3);font-size:13px;flex-wrap:wrap}.draft-type{color:var(--writing-dark);font-weight:500;background:#f59e0b1a;padding:2px 10px;border-radius:var(--radius-full)}.draft-status{padding:3px 10px;border-radius:var(--radius-full);font-weight:500}.draft-status.status-drafting{background:#f59e0b26;color:var(--writing-dark)}.draft-status.status-revising{background:#3b82f626;color:var(--reading-dark)}.draft-wordcount,.draft-updated{color:var(--text-muted)}.draft-actions{flex-shrink:0;display:flex;align-items:center;gap:8px}.draft-actions .btn{padding:8px 20px;font-size:14px;font-weight:600;border-radius:8px;white-space:nowrap}.draft-actions .btn:hover{transform:translateY(-1px);box-shadow:0 2px 8px #0000001f}@media (max-width: 640px){.draft-card .card-content{flex-direction:column;align-items:flex-start;gap:var(--space-4)}.draft-actions{width:100%}.draft-actions a{display:block}.draft-actions .btn{width:100%}}.wf-page{max-width:900px;margin:0 auto;padding:var(--space-6) var(--space-4)}.wf-page-title{font-size:24px;font-weight:700;color:var(--text-primary);margin-bottom:var(--space-6)}.wf-loading{display:flex;flex-direction:column;align-items:center;gap:var(--space-3);padding:3rem;color:var(--text-secondary)}.wf-spinner{width:36px;height:36px;border:3px solid var(--border);border-top-color:var(--writing-dark, #f59e0b);border-radius:50%;animation:wf-spin .8s linear infinite}@keyframes wf-spin{to{transform:rotate(360deg)}}.wf-error{color:#ef4444;text-align:center;padding:2rem}.wf-empty{display:flex;flex-direction:column;align-items:center;gap:var(--space-3);padding:3rem;color:var(--text-secondary)}.wf-empty-icon{font-size:48px}.wf-btn{padding:8px 20px;border-radius:var(--radius-md);font-size:14px;font-weight:500;cursor:pointer;border:none;transition:all .2s}.wf-btn-primary{background:var(--writing-dark, #f59e0b);color:#fff}.wf-btn-primary:hover{filter:brightness(1.1)}.wf-btn-outline{background:transparent;border:1px solid var(--border);color:var(--text-secondary)}.wf-btn-outline:hover{border-color:var(--writing-dark, #f59e0b);color:var(--writing-dark, #f59e0b)}.wf-toggle-btn{margin-left:12px;padding:2px 10px;font-size:12px;border:1px solid var(--border);border-radius:var(--radius-sm);background:transparent;color:var(--text-secondary);cursor:pointer}.wf-doc-list{display:flex;flex-direction:column;gap:var(--space-4)}.wf-doc-card{border:1px solid #e5e5e5;border-radius:var(--radius-lg);transition:all .3s ease}.wf-doc-card:hover{box-shadow:var(--shadow-md)}.wf-doc-card .card-content{padding:var(--space-5)}.wf-doc-header{display:flex;justify-content:space-between;align-items:center;cursor:pointer;-webkit-user-select:none;user-select:none}.wf-doc-header-left{display:flex;flex-direction:column;gap:4px}.wf-doc-title{font-size:16px;font-weight:600;color:var(--text-primary)}.wf-doc-date{font-size:12px;color:var(--text-secondary)}.wf-doc-header-right{display:flex;align-items:center;gap:12px}.wf-score-badge{font-size:20px;font-weight:700;border:2px solid;border-radius:12px;padding:4px 14px}.wf-score-badge small{font-size:12px;font-weight:400}.wf-expand-icon{font-size:12px;color:var(--text-secondary);transition:transform .3s}.wf-expand-icon--open{transform:rotate(180deg)}.wf-detail{margin-top:var(--space-6);display:flex;flex-direction:column;gap:var(--space-6);border-top:1px solid var(--border);padding-top:var(--space-6)}.wf-score-hero{display:flex;justify-content:center;padding:var(--space-4) 0}.wf-score-ring{position:relative;width:160px;height:160px}.wf-score-svg{width:100%;height:100%}.wf-score-center{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;flex-direction:column;align-items:center;justify-content:center}.wf-score-number{font-size:36px;font-weight:800;color:var(--score-color, var(--text-primary))}.wf-score-label{font-size:14px;color:var(--text-secondary);font-weight:500}.wf-dimensions{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-4)}.wf-dim-item{display:flex;flex-direction:column;gap:6px}.wf-dim-header{display:flex;align-items:center;gap:6px;font-size:13px}.wf-dim-icon{font-size:14px}.wf-dim-label{color:var(--text-secondary);flex:1}.wf-dim-value{font-weight:700;font-size:14px}.wf-dim-bar{height:8px;background:#f0f0f0;border-radius:4px;overflow:hidden}.wf-dim-fill{height:100%;border-radius:4px;transition:width .6s ease}.wf-section-title{font-size:16px;font-weight:600;color:var(--text-primary);margin-bottom:var(--space-3);display:flex;align-items:center;gap:8px}.wf-comments{font-size:14px;line-height:1.8;color:var(--text-secondary);background:#fafafa;padding:var(--space-4);border-radius:var(--radius-md);border-left:3px solid var(--writing-dark, #f59e0b)}.wf-three-col{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--space-4)}.wf-col{padding:var(--space-4);border-radius:var(--radius-md);font-size:13px;line-height:1.6}.wf-col h4{font-size:14px;margin-bottom:var(--space-2)}.wf-col ul{list-style:none;padding:0;margin:0}.wf-col li{padding:4px 0 4px 16px;position:relative}.wf-col li:before{content:"•";position:absolute;left:0;font-weight:700}.wf-col--green{background:#10b9810f}.wf-col--green h4{color:#10b981}.wf-col--green li:before{color:#10b981}.wf-col--red{background:#ef44440f}.wf-col--red h4{color:#ef4444}.wf-col--red li:before{color:#ef4444}.wf-col--blue{background:#3b82f60f}.wf-col--blue h4{color:#3b82f6}.wf-col--blue li:before{color:#3b82f6}.wf-annotations{display:flex;flex-direction:column;gap:var(--space-3)}.wf-annotation{padding:var(--space-4);background:#fafafa;border-radius:var(--radius-md);border:1px solid #eee}.wf-ann-header{margin-bottom:var(--space-2)}.wf-ann-type{font-size:11px;font-weight:600;color:var(--writing-dark, #f59e0b);background:#f59e0b1f;padding:2px 10px;border-radius:var(--radius-full)}.wf-ann-original{font-size:13px;padding:6px 10px;background:#ef44440f;border-radius:6px;margin-bottom:6px}.wf-ann-suggestion{font-size:13px;padding:6px 10px;background:#22c55e0f;border-radius:6px;margin-bottom:6px}.wf-ann-explanation{font-size:13px;padding:6px 10px;background:#3b82f60f;border-radius:6px;color:var(--text-secondary)}.wf-label{font-weight:600;color:var(--text-primary);margin-right:6px}.wf-corrected{font-size:14px;line-height:1.8;white-space:pre-wrap;padding:var(--space-4);background:#f0fdf4;border:1px solid #bbf7d0;border-radius:var(--radius-md);color:var(--text-primary)}.wf-actions{display:flex;justify-content:flex-end;gap:var(--space-3);padding-top:var(--space-4);border-top:1px solid var(--border)}@media (max-width: 640px){.wf-dimensions,.wf-three-col{grid-template-columns:1fr}}.wf-top-bar{display:flex;align-items:center;gap:var(--space-4);margin-bottom:var(--space-6);flex-wrap:wrap}.wf-cefr-tag{font-size:12px;font-weight:600;color:var(--writing-dark, #f59e0b);background:#f59e0b1f;padding:4px 12px;border-radius:var(--radius-full)}.wf-btn-ghost{padding:8px 16px;border:none;background:transparent;color:var(--text-secondary);cursor:pointer;font-size:14px;border-radius:var(--radius-md)}.wf-btn-ghost:hover{color:var(--text-primary);background:#f5f5f5}.wf-version-tabs{display:flex;gap:8px;margin-bottom:var(--space-3)}.wf-tab{padding:6px 16px;border:1px solid var(--border);border-radius:var(--radius-md);background:transparent;color:var(--text-secondary);cursor:pointer;font-size:13px;transition:all .2s}.wf-tab:hover{border-color:var(--writing-dark, #f59e0b)}.wf-tab--active{background:var(--writing-dark, #f59e0b);color:#fff;border-color:var(--writing-dark, #f59e0b)}.wf-tab-hint{font-size:12px;color:var(--text-secondary);display:flex;align-items:center}.wf-original-text{font-size:14px;line-height:1.8;white-space:pre-wrap;padding:var(--space-4);background:#fefce8;border:1px solid #fef08a;border-radius:var(--radius-md);color:var(--text-primary)}.wf-loop-actions{display:flex;justify-content:center;gap:var(--space-4);padding:var(--space-6) 0;margin-top:var(--space-4);border-top:1px solid var(--border)}.writing-portfolio-page{max-width:1100px;margin:0 auto}.page-title{font-size:22px;font-weight:700;color:var(--text-primary);margin-bottom:var(--space-6)}.portfolio-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--space-4);margin-bottom:var(--space-8)}.portfolio-stat-card{text-align:center;background:linear-gradient(135deg,#fffbeb,#fef3c7);border:1px solid #fcd34d;border-radius:var(--radius-lg);transition:all .3s ease}.portfolio-stat-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-md)}.portfolio-stat-card .card-content{padding:var(--space-6)}.portfolio-stat-card .stat-icon{font-size:32px;display:block;margin-bottom:var(--space-3)}.portfolio-stat-card .stat-value{display:block;font-size:24px;font-weight:700;color:var(--text-primary);margin-bottom:var(--space-1)}.portfolio-stat-card .stat-label{font-size:13px;color:var(--text-secondary)}.section-title{font-size:18px;font-weight:600;color:var(--text-primary);margin-bottom:var(--space-5);display:flex;align-items:center;gap:var(--space-2)}.section-title:before{content:"";width:4px;height:20px;background:var(--writing);border-radius:var(--radius-full)}.works-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--space-5)}.work-card{background:linear-gradient(135deg,#fafafa,#f5f5f5);border:1px solid #e5e5e5;border-radius:var(--radius-lg);cursor:pointer;transition:all .3s ease}.work-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-md);border-color:var(--writing-light)}.work-card .card-content{padding:var(--space-5)}.work-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--space-3)}.work-type{font-size:12px;font-weight:600;color:var(--writing-dark);background:#f59e0b26;padding:4px 12px;border-radius:var(--radius-full)}.work-score{font-size:20px;font-weight:700;color:var(--speaking)}.work-title{font-size:16px;font-weight:600;color:var(--text-primary);margin-bottom:var(--space-3);line-height:1.4}.work-meta{display:flex;align-items:center;gap:var(--space-2);font-size:13px;color:var(--text-muted)}@media (max-width: 1024px){.portfolio-stats{grid-template-columns:repeat(2,1fr)}}@media (max-width: 768px){.works-grid{grid-template-columns:1fr}}@media (max-width: 640px){.portfolio-stats{grid-template-columns:1fr}}.xiaoyu-teacher{display:flex;flex-direction:column;height:100%;background:#fff;overflow:hidden}.xiaoyu-header{display:flex;align-items:center;padding:10px 20px;background:#fff;border-bottom:1px solid #f3f4f6;flex-shrink:0}.xiaoyu-avatar{position:relative;width:32px;height:32px;margin-right:12px}.avatar-icon{width:100%;height:100%;border-radius:50%;background:linear-gradient(135deg,#a78bfa,#818cf8);display:flex;align-items:center;justify-content:center;font-size:16px;color:#fff}.avatar-status{position:absolute;bottom:0;right:0;width:8px;height:8px;border-radius:50%;background:#10b981;border:1.5px solid white}.xiaoyu-info{flex:1}.xiaoyu-name{font-size:14px;font-weight:600;margin:0 0 2px;color:#1f2937}.xiaoyu-subtitle{font-size:11px;color:#6b7280;margin:0}.xiaoyu-progress-bar{position:relative;height:3px;background:#0000001a;flex-shrink:0}.progress-fill{height:100%;background:#4ade80;transition:width .5s ease}.progress-text,.current-stage-indicator{display:none}.stage-panel{padding:16px 20px;background:#fefce8;border-bottom:1px solid #fde68a;animation:slideDown .3s ease;flex-shrink:0}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.stage-panel h4{margin:0 0 12px;font-size:12px;color:#92400e;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.stages-list{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:16px}.stage-item{display:flex;align-items:center;gap:6px;padding:6px 12px;border-radius:20px;background:#ffffffb3;font-size:12px;color:#78716c;transition:all .2s ease;border:1px solid transparent}.stage-item:hover{background:#ffffffe6}.stage-item.completed{background:#dcfce7;color:#16a34a;border-color:#86efac}.stage-item.current{background:#8b5cf6;color:#fff;border-color:#7c3aed;box-shadow:0 2px 8px #8b5cf64d}.stage-item .stage-badge{font-size:10px;padding:2px 6px;background:#ffffff4d;border-radius:8px}.stage-actions{display:flex;gap:8px}.advance-stage-btn,.complete-btn{flex:1;padding:10px 16px;border:none;border-radius:8px;font-size:13px;cursor:pointer;transition:all .2s ease;font-weight:500}.advance-stage-btn{background:linear-gradient(135deg,#8b5cf6,#6d28d9);color:#fff;box-shadow:0 2px 8px #8b5cf64d}.complete-btn{background:#22c55e;color:#fff;box-shadow:0 2px 8px #22c55e4d}.advance-stage-btn:hover,.complete-btn:hover{transform:translateY(-1px);box-shadow:0 4px 12px #00000026}.advance-stage-btn:disabled{opacity:.5;cursor:not-allowed;transform:none}.stage-toggle-btn{display:none}.messages-container{flex:1;overflow-y:auto;padding:24px;background:#fff}.welcome-message{text-align:center;padding:60px 24px;color:#64748b}.welcome-avatar{width:72px;height:72px;margin:0 auto 20px;border-radius:50%;background:linear-gradient(135deg,#a78bfa,#818cf8);display:flex;align-items:center;justify-content:center;font-size:36px;box-shadow:0 8px 24px #a78bfa4d}.welcome-message h4{margin:0 0 12px;font-size:18px;color:#1f2937;font-weight:600}.welcome-message p{margin:6px 0;font-size:14px;line-height:1.7}.message{display:flex;gap:16px;margin-bottom:24px;animation:messageIn .3s ease;max-width:100%}@keyframes messageIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.message.assistant{align-items:flex-start;justify-content:flex-start}.message.user{align-items:flex-start;justify-content:flex-end;flex-direction:row}.message-avatar{width:40px;height:40px;border-radius:50%;background:linear-gradient(135deg,#a78bfa,#818cf8);color:#fff;display:flex;align-items:center;justify-content:center;font-size:18px;flex-shrink:0;box-shadow:0 2px 8px #a78bfa40}.message-avatar.user{background:linear-gradient(135deg,#8b5cf6,#6d28d9);color:#fff;font-size:14px;font-weight:600;box-shadow:0 2px 8px #8b5cf64d}.message-content{max-width:70%;padding:16px 20px;border-radius:20px;background:#fff;box-shadow:0 4px 16px #0000000a;border:1px solid #f3f4f6}.message.assistant .message-content{border-top-left-radius:4px;background:#f8fafc;border:1px solid #e2e8f0}.message.user .message-content{background:linear-gradient(135deg,#a78bfa,#818cf8);color:#fff;border:none;border-top-right-radius:4px;box-shadow:0 4px 16px #a78bfa33}.message.stage_transition .message-content{background:#fefce8;border:1px solid #fde68a;border-radius:16px}.message.error .message-content{background:#fef2f2;border:1px solid #fecaca}.message-content .stage-badge{display:inline-block;padding:3px 10px;border-radius:12px;font-size:11px;font-weight:600;margin-bottom:10px}.message-text{font-size:14px;line-height:1.7}.message-text p{margin:0 0 8px}.message-text p:last-child{margin-bottom:0}.message.user .message-text{color:#fff}.message-time{display:block;font-size:10px;color:#a3a3a3;margin-top:8px}.message.user .message-time{color:#ffffffb3;text-align:right}.typing-indicator{display:flex;gap:4px;padding:8px 4px}.typing-indicator span{width:8px;height:8px;border-radius:50%;background:#a78bfa;animation:typing 1.4s infinite ease-in-out both}.typing-indicator span:nth-child(1){animation-delay:-.32s}.typing-indicator span:nth-child(2){animation-delay:-.16s}@keyframes typing{0%,80%,to{transform:scale(.6);opacity:.4}40%{transform:scale(1);opacity:1}}.quick-tips{display:flex;align-items:center;gap:8px;padding:12px 20px;background:#ffffffe6;border-top:1px solid #f5f5f4;overflow-x:auto;flex-shrink:0}.tips-label{font-size:11px;color:#a3a3a3;flex-shrink:0;display:none}.tip-btn{padding:6px 14px;border:none;border-radius:20px;background:#f5f5f4;font-size:12px;color:#57534e;cursor:pointer;white-space:nowrap;transition:all .2s ease}.tip-btn:hover{background:#8b5cf6;color:#fff;transform:translateY(-1px);box-shadow:0 4px 12px #8b5cf633}.input-container{display:flex;gap:16px;padding:20px 24px;background:#fff;border-top:1px solid #e5e7eb;box-shadow:0 -10px 30px #00000008;flex-shrink:0;align-items:flex-end}.input-container textarea{flex:1;padding:16px 20px;border:1px solid #d1d5db;border-radius:20px;font-size:15px;resize:none;outline:none;transition:all .3s ease;font-family:inherit;min-height:56px;max-height:150px;line-height:1.6;background:#f9fafb;box-shadow:inset 0 2px 4px #00000005}.input-container textarea::placeholder{color:#9ca3af}.input-container textarea:focus{border-color:#8b5cf6;background:#fff;box-shadow:0 0 0 4px #8b5cf61a}.input-container textarea:disabled{background:#f3f4f6;cursor:not-allowed}.send-btn{width:56px;height:56px;border:none;border-radius:20px;background:linear-gradient(135deg,#8b5cf6,#6d28d9);color:#fff;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .3s ease;box-shadow:0 4px 12px #8b5cf64d;flex-shrink:0}.send-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 16px #8b5cf666}.send-btn:disabled{background:#e5e7eb;color:#9ca3af;box-shadow:none;cursor:not-allowed;transform:none}.loading-dots{font-weight:700;letter-spacing:2px;animation:pulse 1.5s infinite}@keyframes pulse{0%,to{opacity:.5}50%{opacity:1}}.xiaoyu-footer{display:none}@media (max-width: 768px){.xiaoyu-header{padding:10px 16px}.xiaoyu-avatar{width:36px;height:36px}.messages-container{padding:16px}.message-content{max-width:80%}.quick-tips{padding:10px 16px}.tip-btn{padding:5px 12px;font-size:11px}.input-container{padding:12px 16px}.input-container textarea{min-height:48px;padding:12px 16px}.send-btn{width:48px;height:48px}.welcome-message{padding:40px 16px}.welcome-avatar{width:56px;height:56px;font-size:28px}}.messages-container::-webkit-scrollbar{width:6px}.messages-container::-webkit-scrollbar-track{background:transparent}.messages-container::-webkit-scrollbar-thumb{background:#8b5cf64d;border-radius:3px}.messages-container::-webkit-scrollbar-thumb:hover{background:#8b5cf680}@keyframes fadeInUp{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}.writing-with-xiaoyu-page{display:flex;flex-direction:column;height:calc(100vh - 56px);background:#f8fafc;overflow:hidden}.page-header{display:flex;justify-content:space-between;align-items:center;padding:12px 24px;background:#fff;border-bottom:1px solid #f1f5f9;flex-shrink:0;box-shadow:0 1px 2px #00000005;z-index:5}.header-left{display:flex;align-items:center;gap:16px}.header-left h1{margin:0;font-size:18px;font-weight:700;color:#1f2937;display:flex;align-items:center;gap:8px}.task-info-badge{display:flex;align-items:center;gap:8px;padding:4px 12px;background:#6366f11a;border-radius:20px;border:1px solid rgba(99,102,241,.2)}.task-info-badge .task-title{font-size:12px;font-weight:600;color:#4f46e5;max-width:200px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.task-info-badge .task-difficulty{font-size:10px;padding:2px 8px;background:#6366f1;color:#fff;border-radius:10px;font-weight:500}.header-subtitle{margin:0;font-size:13px;color:#64748b;display:flex;align-items:center;gap:8px}.stage-badge{padding:3px 10px;border-radius:12px;font-weight:600;font-size:11px}.header-actions{display:flex;gap:8px}.toggle-panel-btn,.new-session-btn{padding:8px 16px;border:none;border-radius:8px;font-size:13px;cursor:pointer;transition:all .2s ease;font-weight:500}.toggle-panel-btn{background:#f1f5f9;color:#475569;border:1px solid #e2e8f0}.toggle-panel-btn:hover{background:#e2e8f0;border-color:#cbd5e1}.new-session-btn{background:linear-gradient(135deg,#8b5cf6,#6d28d9);color:#fff;box-shadow:0 2px 8px #8b5cf64d}.new-session-btn:hover{transform:translateY(-1px);box-shadow:0 4px 12px #8b5cf666}.xiaoyu-main-content{display:flex;flex:1;overflow:hidden;position:relative;background:transparent}.chat-section{flex:1;display:flex;flex-direction:column;position:relative;min-width:0;transition:all .3s ease}.xiaoyu-main-content.with-panel .chat-section{margin-right:0}.stages-panel{width:320px;background:#fff;border-left:1px solid #f3f4f6;display:flex;flex-direction:column;box-shadow:-4px 0 24px #00000005;animation:slideInRight .3s ease;flex-shrink:0;z-index:10}@keyframes slideInRight{0%{transform:translate(20px);opacity:0}to{transform:translate(0);opacity:1}}.completion-overlay{position:absolute;top:0;left:0;right:0;bottom:0;background:#fffffff2;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);display:flex;align-items:center;justify-content:center;z-index:100;animation:fadeIn .5s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.completion-card{text-align:center;padding:40px;background:#fff;border-radius:20px;box-shadow:0 20px 40px #0000001a;max-width:360px;animation:scaleIn .4s ease}@keyframes scaleIn{0%{transform:scale(.9);opacity:0}to{transform:scale(1);opacity:1}}.completion-icon{font-size:56px;margin-bottom:16px}.completion-card h3{margin:0 0 8px;font-size:22px;color:#1f2937}.completion-card p{margin:0 0 20px;font-size:14px;color:#64748b}.completion-actions{display:flex;gap:12px;justify-content:center}.primary-btn,.secondary-btn{padding:12px 20px;border:none;border-radius:10px;font-size:14px;cursor:pointer;transition:all .2s ease;font-weight:500}.primary-btn{background:linear-gradient(135deg,#8b5cf6,#6d28d9);color:#fff;box-shadow:0 4px 12px #8b5cf64d}.primary-btn:hover{transform:translateY(-2px);box-shadow:0 6px 16px #8b5cf666}.secondary-btn{background:#f1f5f9;color:#475569;border:1px solid #e2e8f0}.secondary-btn:hover{background:#e2e8f0}.page-footer{padding:8px 24px;background:#fff9;border-top:1px solid rgba(245,158,11,.1);flex-shrink:0}.xiaoyu-principles{display:flex;justify-content:center;align-items:center;gap:16px;flex-wrap:wrap}.principle{font-size:12px;color:#94a3b8}.separator{color:#d1d5e9}.loading-container{display:flex;align-items:center;justify-content:center;min-height:400px;background:#fff;border-radius:16px;box-shadow:0 4px 20px #00000014}.loading-container p{color:#64748b;font-size:14px}@media (max-width: 1200px){.stages-panel{width:280px}}@media (max-width: 1024px){.main-content{flex-direction:column}.chat-section{flex:none;height:60vh}.stages-panel{width:100%;height:40vh;border-left:none;border-top:1px solid rgba(245,158,11,.15);box-shadow:0 -4px 20px #0000000d;animation:slideInUp .3s ease}@keyframes slideInUp{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}}@media (max-width: 768px){.page-header{flex-direction:column;gap:12px;padding:12px 16px}.header-left{width:100%;flex-wrap:wrap;gap:8px}.header-left h1{font-size:16px;width:100%;justify-content:center}.task-info-badge{width:100%;justify-content:center}.task-info-badge .task-title{max-width:150px}.header-actions{width:100%;justify-content:center}.xiaoyu-principles{gap:8px}.separator{display:none}.completion-card{padding:24px;margin:16px}.completion-actions{flex-direction:column}.chat-section{height:55vh}.stages-panel{height:45vh}}.chat-section::-webkit-scrollbar,.stages-panel::-webkit-scrollbar{width:6px}.chat-section::-webkit-scrollbar-track,.stages-panel::-webkit-scrollbar-track{background:transparent}.chat-section::-webkit-scrollbar-thumb,.stages-panel::-webkit-scrollbar-thumb{background:#8b5cf633;border-radius:3px}.chat-section::-webkit-scrollbar-thumb:hover,.stages-panel::-webkit-scrollbar-thumb:hover{background:#8b5cf666}.back-btn-header{padding:6px 12px;border:1px solid #e2e8f0;border-radius:8px;background:#f8fafc;color:#475569;cursor:pointer;font-size:13px;transition:all .2s}.back-btn-header:hover{background:#e2e8f0}.stages-panel-inner{padding:20px;display:flex;flex-direction:column;gap:20px;overflow-y:auto;height:100%}.progress-section{background:#f8fafc;border-radius:12px;padding:16px}.progress-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px}.progress-header h3{margin:0;font-size:15px;font-weight:700;color:#1f2937}.progress-pct{font-size:20px;font-weight:800;color:#8b5cf6}.progress-bar-track{height:8px;background:#e5e7eb;border-radius:4px;overflow:hidden;margin-bottom:8px}.progress-bar-fill{height:100%;border-radius:4px;transition:width .5s ease,background .5s ease}.progress-labels{display:flex;justify-content:space-between;font-size:12px;color:#6b7280}.progress-labels strong{color:#8b5cf6}.stages-list{display:flex;flex-direction:column;gap:6px}.stage-row{display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:10px;background:#f9fafb;border:1px solid transparent;transition:all .2s}.stage-row.current{background:#8b5cf60f;border-color:#8b5cf626}.stage-row.completed{background:#10b9810f}.stage-row-icon{font-size:16px;width:24px;text-align:center}.stage-row.completed .stage-row-icon{color:#10b981}.stage-row-label{flex:1;font-size:14px;font-weight:500;color:#374151}.stage-row.current .stage-row-label{color:#8b5cf6;font-weight:700}.stage-row-badge{font-size:11px;padding:2px 8px;background:#8b5cf61a;color:#8b5cf6;border-radius:10px;font-weight:600}.stage-row-check{color:#10b981;font-weight:700}.completion-actions-panel{background:linear-gradient(135deg,#8b5cf60f,#6366f10f);border:1px solid rgba(139,92,246,.15);border-radius:12px;padding:16px;display:flex;flex-direction:column;gap:8px}.completion-actions-panel h4{margin:0 0 8px;font-size:15px;text-align:center;color:#1f2937}.completion-actions-panel .primary-btn,.completion-actions-panel .secondary-btn{width:100%;text-align:center}.pretest-page{max-width:640px;margin:0 auto;padding:24px}.pretest-intro{text-align:center;padding:40px 32px}.pretest-intro-icon{font-size:56px;margin-bottom:16px}.pretest-intro h1{font-size:28px;font-weight:700;margin-bottom:12px;color:var(--text-primary)}.pretest-intro-desc{font-size:15px;color:var(--text-secondary);line-height:1.8;margin-bottom:28px}.pretest-intro-info{display:flex;justify-content:center;gap:32px;margin-bottom:28px}.pretest-info-item{display:flex;flex-direction:column;align-items:center;gap:4px}.pretest-info-num{font-size:28px;font-weight:700;color:var(--writing, #f59e0b)}.pretest-info-label{font-size:13px;color:var(--text-secondary)}.pretest-dimensions{text-align:left;background:var(--surface-secondary, #f8fafc);border-radius:12px;padding:16px 20px;margin-bottom:20px}.pretest-dim{display:flex;align-items:center;gap:10px;padding:8px 0;font-size:14px;color:var(--text-primary)}.pretest-dim-icon{font-size:20px;flex-shrink:0}.pretest-intro-note{font-size:13px;color:var(--text-muted, #94a3b8);margin-bottom:24px}.pretest-start-btn{min-width:200px}.pretest-skip{display:block;margin:12px auto 0;background:none;border:none;color:var(--text-muted, #94a3b8);font-size:13px;cursor:pointer;padding:4px}.pretest-skip:hover{color:var(--text-secondary);text-decoration:underline}.pretest-quiz{padding:24px 0}.pretest-progress-row{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}.pretest-progress-label{font-size:14px;font-weight:600;color:var(--writing, #f59e0b)}.pretest-progress-count{font-size:13px;color:var(--text-secondary)}.pretest-progress-bar{height:6px;background:var(--surface-hover, #e2e8f0);border-radius:3px;overflow:hidden;margin-bottom:32px}.pretest-progress-fill{height:100%;background:linear-gradient(90deg,#f59e0b,#f97316);border-radius:3px;transition:width .3s ease}.pretest-question-card{background:var(--surface-primary, white);border:1px solid var(--border, #e2e8f0);border-radius:16px;padding:32px 24px;margin-bottom:24px}.pretest-question-text{font-size:18px;font-weight:600;color:var(--text-primary);line-height:1.6;margin-bottom:24px;text-align:center}.pretest-likert{display:flex;flex-direction:column;gap:10px}.pretest-likert-option{display:flex;align-items:center;gap:12px;padding:12px 16px;border:2px solid var(--border, #e2e8f0);border-radius:10px;background:var(--surface-primary, white);cursor:pointer;transition:all .2s ease;font-size:14px;color:var(--text-primary)}.pretest-likert-option:hover{border-color:var(--writing-light, #fbbf24);background:#f59e0b0a}.pretest-likert-option.selected{border-color:var(--writing, #f59e0b);background:#f59e0b14}.pretest-likert-num{display:flex;align-items:center;justify-content:center;width:28px;height:28px;border-radius:50%;background:var(--surface-hover, #e2e8f0);font-weight:600;font-size:13px;flex-shrink:0;transition:all .2s ease}.pretest-likert-option.selected .pretest-likert-num{background:var(--writing, #f59e0b);color:#fff}.pretest-likert-label{flex:1}.pretest-nav{display:flex;justify-content:space-between;gap:12px}.pretest-nav .button{min-width:120px}.pretest-result{text-align:center;padding:40px 32px}.pretest-result-icon{font-size:56px;margin-bottom:16px}.pretest-result h1{font-size:28px;font-weight:700;margin-bottom:8px;color:var(--text-primary)}.pretest-result-subtitle{font-size:15px;color:var(--text-secondary);margin-bottom:28px}.pretest-result-scores{display:flex;flex-direction:column;gap:16px;margin-bottom:24px;text-align:left}.pretest-result-dim-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:6px;font-size:14px;font-weight:500}.pretest-result-dim-value{font-size:18px;font-weight:700}.pretest-result-bar-bg{height:10px;background:var(--surface-hover, #e2e8f0);border-radius:5px;overflow:hidden}.pretest-result-bar-fill{height:100%;border-radius:5px;transition:width .6s ease}.pretest-result-overall{font-size:18px;color:var(--text-primary);margin-bottom:28px}.pretest-result-overall strong{font-size:24px;color:var(--writing, #f59e0b)}@media (max-width: 480px){.pretest-page{padding:16px}.pretest-intro,.pretest-result{padding:24px 16px}.pretest-intro h1,.pretest-result h1{font-size:22px}.pretest-question-text{font-size:16px}.pretest-likert-option{padding:10px 12px;font-size:13px}.pretest-intro-info{gap:20px}.pretest-info-num{font-size:22px}}.task-selection-page{min-height:100vh;background:linear-gradient(135deg,#667eea,#764ba2);padding:20px}.task-selection-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100vh;color:#fff}.loading-spinner{width:40px;height:40px;border:3px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin 1s linear infinite}.task-selection-header{display:flex;align-items:center;gap:20px;margin-bottom:24px;padding:16px 24px;background:#ffffff1a;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:16px}.back-btn{background:#fff3;border:none;color:#fff;padding:10px 20px;border-radius:8px;cursor:pointer;font-size:14px;transition:all .2s}.back-btn:hover{background:#ffffff4d}.header-content h1{color:#fff;font-size:24px;margin:0}.header-content p{color:#fffc;margin:4px 0 0;font-size:14px}.filter-bar{display:flex;align-items:center;gap:12px;margin-bottom:24px;padding:12px 20px;background:#ffffff1a;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:12px}.filter-label{color:#ffffffe6;font-size:14px}.filter-btn{background:#ffffff26;border:none;color:#fffc;padding:8px 16px;border-radius:20px;cursor:pointer;font-size:13px;transition:all .2s}.filter-btn:hover{background:#ffffff40}.filter-btn.active{background:#fff;color:#667eea;font-weight:600}.tasks-container{display:grid;grid-template-columns:1fr 380px;gap:24px;min-height:500px}.tasks-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:16px;align-content:start}.task-card{background:#fffffff2;border-radius:16px;padding:20px;cursor:pointer;transition:all .3s ease;border:3px solid transparent;position:relative}.task-card:hover{transform:translateY(-4px);box-shadow:0 12px 24px #00000026}.task-card.selected{border-color:#667eea;box-shadow:0 8px 24px #667eea4d}.task-card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}.task-category-icon{font-size:28px}.task-difficulty{font-size:11px;font-weight:600;color:#fff;padding:4px 10px;border-radius:12px;text-transform:uppercase}.task-title{font-size:16px;font-weight:700;color:#2d3748;margin:0 0 6px;line-height:1.3}.task-title-cn{font-size:13px;color:#718096;margin:0 0 12px}.task-meta{display:flex;gap:16px;font-size:12px;color:#a0aec0}.meta-item{display:flex;align-items:center;gap:4px}.selected-indicator{position:absolute;top:12px;right:12px;background:#667eea;color:#fff;font-size:11px;font-weight:600;padding:4px 8px;border-radius:4px}.task-detail-panel{background:#fffffffa;border-radius:20px;padding:24px;position:sticky;top:20px;display:flex;flex-direction:column;box-shadow:0 8px 32px #0000001a}.task-detail-content{flex:1}.task-detail-content h3{font-size:20px;color:#2d3748;margin:0 0 8px}.task-detail-desc-en{color:#1f2937;font-size:15px;line-height:1.7;margin:0 0 12px;font-weight:500}.task-detail-desc-cn{color:#6b7280;font-size:13px;line-height:1.6;margin:0 0 20px}.task-requirements{margin-bottom:20px}.task-requirements h4{font-size:14px;color:#2d3748;margin:0 0 10px}.task-requirements ul{margin:0;padding-left:20px}.task-requirements li{font-size:13px;color:#4a5568;margin-bottom:6px;line-height:1.5}.task-vocabulary{margin-bottom:20px}.task-vocabulary h4{font-size:14px;color:#2d3748;margin:0 0 10px}.vocab-tags{display:flex;flex-wrap:wrap;gap:8px}.vocab-tag{font-size:12px;padding:4px 10px;border-radius:12px;font-weight:500}.vocab-tag.noun{background:#e3f2fd;color:#1565c0}.vocab-tag.adj{background:#f3e5f5;color:#7b1fa2}.vocab-tag.verb{background:#e8f5e9;color:#2e7d32}.start-writing-btn{width:100%;padding:16px 24px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:12px;font-size:16px;font-weight:600;cursor:pointer;transition:all .3s ease;margin-top:20px}.start-writing-btn:hover{transform:translateY(-2px);box-shadow:0 8px 24px #667eea66}.task-selection-tips{margin-top:24px}.tip-card{display:flex;align-items:flex-start;gap:16px;background:#ffffff1a;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:12px;padding:16px 20px}.tip-icon{font-size:24px}.tip-content strong{color:#fff;font-size:14px;display:block;margin-bottom:4px}.tip-content p{color:#fffc;font-size:13px;margin:0;line-height:1.5}@media (max-width: 1024px){.tasks-container{grid-template-columns:1fr}.task-detail-panel{position:static;order:-1}}@media (max-width: 640px){.task-selection-header{flex-direction:column;text-align:center}.header-content h1{font-size:20px}.tasks-grid{grid-template-columns:1fr}}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 20px;text-align:center;color:#fff}.empty-state .empty-icon{font-size:48px;margin-bottom:16px}.empty-state h3{font-size:20px;font-weight:600;margin-bottom:8px;color:#fff}.empty-state p{font-size:14px;color:#fffc;margin-bottom:20px}.empty-state .filter-btn{background:#fff3;border:1px solid rgba(255,255,255,.3);color:#fff}.listening-page{max-width:1400px;margin:0 auto;padding-bottom:var(--space-10)}.listening-hero{background:linear-gradient(135deg,#8b5cf6,#7c3aed,#6d28d9);border-radius:24px;padding:var(--space-10);margin-bottom:var(--space-8);position:relative;overflow:hidden}.listening-hero:before{content:"";position:absolute;top:-50%;right:-20%;width:600px;height:600px;background:radial-gradient(circle,rgba(255,255,255,.1) 0%,transparent 70%);border-radius:50%}.hero-content{display:flex;justify-content:space-between;align-items:center;position:relative;z-index:1}.hero-text{flex:1;max-width:600px}.hero-title{display:flex;align-items:center;gap:var(--space-3);font-size:36px;font-weight:800;color:#fff;margin:0 0 var(--space-3) 0}.hero-icon{font-size:40px;animation:float 3s ease-in-out infinite}.hero-subtitle{font-size:16px;color:#ffffffd9;margin:0 0 var(--space-6) 0;letter-spacing:.5px}.hero-features{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--space-3);margin-bottom:var(--space-6)}.hero-feature-item{display:flex;align-items:center;gap:var(--space-3);background:#ffffff1a;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);padding:var(--space-3) var(--space-4);border-radius:12px;transition:all .3s ease}.hero-feature-item:hover{background:#ffffff26;transform:translate(4px)}.feature-icon{font-size:24px}.feature-text{display:flex;flex-direction:column}.feature-title{font-size:14px;font-weight:600;color:#fff}.feature-desc{font-size:12px;color:#ffffffb3}.hero-actions{display:flex;gap:var(--space-3)}.hero-btn{padding:14px 28px!important;border-radius:12px!important;font-size:15px!important;font-weight:600!important;display:flex;align-items:center;gap:var(--space-2);transition:all .3s ease!important}.hero-btn.primary{background:#fff!important;color:#8b5cf6!important;box-shadow:0 4px 15px #0003!important}.hero-btn.primary:hover{transform:translateY(-2px);box-shadow:0 6px 20px #0000004d!important}.hero-btn.secondary{background:#ffffff26!important;color:#fff!important;border:1px solid rgba(255,255,255,.3)!important}.hero-btn.secondary:hover{background:#ffffff40!important}.hero-illustration{position:relative;width:300px;height:200px}.illustration-card{position:absolute;background:#fff;border-radius:16px;padding:var(--space-4) var(--space-5);box-shadow:0 10px 40px #0003;display:flex;flex-direction:column;align-items:center;gap:var(--space-2);animation:cardFloat 4s ease-in-out infinite}.illustration-card span:first-child{font-size:32px}.card-label{font-size:12px;font-weight:600;color:#64748b}.illustration-card.card-1{top:0;left:20px;animation-delay:0s}.illustration-card.card-2{top:60px;right:0;animation-delay:.5s}.illustration-card.card-3{bottom:0;left:60px;animation-delay:1s}@keyframes cardFloat{0%,to{transform:translateY(0) rotate(0)}50%{transform:translateY(-8px) rotate(2deg)}}.stats-section{margin-bottom:var(--space-8)}.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--space-4)}.stat-card{border-radius:20px;padding:var(--space-5);display:flex;align-items:center;gap:var(--space-4);transition:all .3s ease;border:1px solid rgba(0,0,0,.05)}.stat-card:hover{transform:translateY(-4px);box-shadow:0 12px 24px #0000001a}.stat-icon-wrapper{width:56px;height:56px;border-radius:16px;background:#fff;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 12px #00000014}.stat-icon{font-size:28px}.stat-value-row{display:flex;align-items:baseline;gap:2px;margin-bottom:2px}.stat-value{font-size:28px;font-weight:800;line-height:1}.stat-unit{font-size:14px;color:#64748b;font-weight:500}.stat-label{font-size:13px;color:#64748b}.modes-section{margin-bottom:var(--space-8)}.section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--space-5)}.section-title{display:flex;align-items:center;gap:var(--space-2);font-size:20px;font-weight:700;color:#1e293b;margin:0}.title-icon{font-size:24px}.view-all-link{font-size:14px;color:#8b5cf6;text-decoration:none;font-weight:500;transition:color .2s ease}.view-all-link:hover{color:#7c3aed}.modes-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--space-5)}.mode-card{background:#fff;border-radius:20px;overflow:hidden;box-shadow:0 4px 6px #0000000a;border:1px solid #e2e8f0;transition:all .3s ease}.mode-card:hover{transform:translateY(-6px);box-shadow:0 20px 40px #0000001a;border-color:transparent}.mode-header{display:flex;align-items:center;gap:var(--space-4);padding:var(--space-5)}.mode-icon-wrapper{width:60px;height:60px;border-radius:16px;display:flex;align-items:center;justify-content:center;font-size:28px;box-shadow:0 4px 12px #00000026}.mode-info{flex:1}.mode-title{font-size:18px;font-weight:700;color:#1e293b;margin:0 0 var(--space-1) 0}.mode-description{font-size:14px;color:#64748b;margin:0}.mode-features{display:flex;flex-wrap:wrap;gap:6px;padding:0 var(--space-5);margin-bottom:var(--space-4)}.mode-feature-tag{font-size:12px;font-weight:500;padding:4px 10px;background:#8b5cf61a;border-radius:20px}.mode-action{padding:0 var(--space-5) var(--space-5)}.mode-btn{width:100%;padding:12px 24px!important;border-radius:12px!important;font-size:15px!important;font-weight:600!important;color:#fff!important;transition:all .3s ease!important}.mode-btn:hover{transform:scale(1.02);box-shadow:0 4px 15px #8b5cf666!important}.recent-section{margin-bottom:var(--space-8)}.recent-list{background:#fff;border-radius:16px;border:1px solid #e2e8f0;overflow:hidden}.recent-item{display:flex;align-items:center;gap:var(--space-4);padding:var(--space-4) var(--space-5);border-bottom:1px solid #f1f5f9;transition:background .2s ease}.recent-item:last-child{border-bottom:none}.recent-item:hover{background:#fafafa}.recent-icon{width:48px;height:48px;background:linear-gradient(135deg,#f3e8ff,#e9d5ff);border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:24px}.recent-info{flex:1}.recent-title{font-size:15px;font-weight:600;color:#1e293b;margin:0 0 2px}.recent-type{font-size:13px;color:#64748b}.recent-score{font-size:18px;font-weight:700}.recent-date{font-size:13px;color:#94a3b8;min-width:60px;text-align:right}.tips-section{margin-bottom:var(--space-8)}.tips-card{display:flex;align-items:flex-start;gap:var(--space-5);background:linear-gradient(135deg,#f5f3ff,#ede9fe);border-radius:16px;padding:var(--space-5) var(--space-6);border:1px solid #ddd6fe}.tips-icon{font-size:40px;flex-shrink:0}.tips-content h4{font-size:15px;font-weight:700;color:#6d28d9;margin:0 0 var(--space-3) 0}.tips-list{display:flex;flex-direction:column;gap:var(--space-2)}.tip-item{display:flex;align-items:center;gap:var(--space-2);font-size:13px;color:#7c3aed}.tip-icon{font-size:16px}@media (max-width: 1200px){.modes-grid{grid-template-columns:1fr}}@media (max-width: 1024px){.stats-grid{grid-template-columns:repeat(2,1fr)}.hero-illustration{display:none}.hero-content{justify-content:center}.hero-text{max-width:100%;text-align:center}.hero-features{max-width:500px;margin:0 auto var(--space-6)}.hero-actions{justify-content:center}}@media (max-width: 768px){.listening-hero{padding:var(--space-6)}.hero-title{font-size:28px;justify-content:center}.hero-features{grid-template-columns:1fr}.hero-actions{flex-direction:column}.hero-btn{width:100%;justify-content:center}.stats-grid{grid-template-columns:1fr}.stat-card{padding:var(--space-4)}.recent-item{flex-wrap:wrap}.recent-date{width:100%;text-align:left;margin-top:var(--space-2)}.tips-card{flex-direction:column;text-align:center}}.listening-create-page{max-width:1000px;margin:0 auto;padding:24px}.story-builder{background:#fffc;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:20px;padding:24px;border:1px solid rgba(139,92,246,.1);box-shadow:0 4px 20px #8b5cf61a}.element-section{margin-bottom:24px}.section-title{font-size:16px;color:#374151;margin-bottom:12px;display:flex;align-items:center;gap:8px}.section-icon{font-size:20px}.element-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}.element-card{background:#fff;border:2px solid #e5e7eb;border-radius:12px;padding:16px;cursor:pointer;transition:all .2s ease;text-align:center}.element-card:hover{border-color:#8b5cf6;transform:translateY(-2px);box-shadow:0 4px 12px #8b5cf626}.element-card.selected{border-color:#8b5cf6;background:linear-gradient(135deg,#f5f3ff,#ede9fe);box-shadow:0 4px 12px #8b5cf633}.element-emoji{font-size:28px;display:block;margin-bottom:8px}.element-label{font-size:13px;color:#4b5563}.story-preview{background:linear-gradient(135deg,#f5f3ff,#ede9fe);border-radius:12px;padding:20px;margin-top:24px}.story-preview h3{font-size:16px;color:#6d28d9;margin-bottom:12px}.preview-content{display:flex;flex-wrap:wrap;gap:8px}.preview-tag{background:#fff;padding:8px 12px;border-radius:20px;font-size:13px;color:#4b5563;border:1px solid #c4b5fd}.preview-tag.empty{color:#9ca3af;border-style:dashed}.generate-section{text-align:center;margin-top:24px}.generate-btn{background:linear-gradient(135deg,#8b5cf6,#6366f1);color:#fff;border:none;padding:16px 48px;border-radius:30px;font-size:18px;font-weight:600;cursor:pointer;transition:all .3s ease}.generate-btn:disabled{background:#d1d5db;cursor:not-allowed}.generate-btn.active:hover:not(:disabled){transform:scale(1.05);box-shadow:0 8px 24px #8b5cf666}.generated-story-section{margin-top:32px;background:#fff;border-radius:20px;padding:24px;border:1px solid #e5e7eb;box-shadow:0 4px 20px #0000000d}.story-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px;padding-bottom:16px;border-bottom:1px solid #e5e7eb}.story-header h2{font-size:20px;color:#1f2937}.audio-controls{display:flex;align-items:center;gap:16px}.speed-control{display:flex;align-items:center;gap:8px}.speed-control label{font-size:14px;color:#6b7280}.speed-control select{padding:6px 12px;border-radius:8px;border:1px solid #d1d5db;font-size:14px}.play-btn{background:linear-gradient(135deg,#8b5cf6,#6366f1);color:#fff;border:none;padding:10px 24px;border-radius:20px;font-weight:500;cursor:pointer;transition:all .2s ease}.play-btn:hover{transform:scale(1.05)}.play-btn.playing{background:linear-gradient(135deg,#10b981,#059669)}.story-content{line-height:1.8;color:#374151;font-size:15px}.story-content h3{color:#6d28d9;margin:20px 0 12px}.story-content strong{color:#1f2937}.story-content hr{border:none;border-top:1px solid #e5e7eb;margin:16px 0}.story-actions{display:flex;gap:12px;margin-top:24px;padding-top:16px;border-top:1px solid #e5e7eb}.action-btn{background:#f3f4f6;color:#4b5563;border:none;padding:10px 20px;border-radius:10px;cursor:pointer;font-size:14px;transition:all .2s ease}.action-btn:hover{background:#e5e7eb}.action-btn.primary{background:linear-gradient(135deg,#8b5cf6,#6366f1);color:#fff}@media (max-width: 768px){.element-grid{grid-template-columns:repeat(2,1fr)}.story-header{flex-direction:column;gap:16px}.audio-controls{flex-wrap:wrap;justify-content:center}.story-actions{flex-wrap:wrap}}.listening-sort-page{max-width:1000px;margin:0 auto;padding:24px}.page-header .back-link{display:inline-block;color:#8b5cf6;text-decoration:none;margin-bottom:16px;font-size:14px;background:none;border:none;cursor:pointer}.material-selection{margin-top:24px}.material-selection h2{font-size:20px;color:#1f2937;margin-bottom:20px}.materials-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:20px}.material-card{background:#ffffffe6;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:16px;padding:24px;border:1px solid rgba(139,92,246,.1);cursor:pointer;transition:all .3s ease}.material-card:hover{transform:translateY(-4px);box-shadow:0 8px 24px #8b5cf626;border-color:#8b5cf6}.material-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}.material-difficulty{background:linear-gradient(135deg,#8b5cf6,#6366f1);color:#fff;padding:4px 12px;border-radius:12px;font-size:12px;font-weight:500}.material-icon{font-size:24px}.material-card h3{font-size:18px;color:#1f2937;margin-bottom:8px}.material-card p{font-size:14px;color:#6b7280;margin-bottom:12px}.material-meta{font-size:13px;color:#9ca3af;margin-bottom:16px}.start-btn{background:linear-gradient(135deg,#8b5cf6,#6366f1);color:#fff;border:none;padding:10px 24px;border-radius:10px;width:100%;font-weight:500;cursor:pointer;transition:all .2s ease}.start-btn:hover{opacity:.9}.exercise-mode .page-header{text-align:left;display:flex;flex-wrap:wrap;align-items:center;gap:16px}.exercise-info{display:flex;align-items:center;gap:12px}.difficulty-badge{background:linear-gradient(135deg,#8b5cf6,#6366f1);color:#fff;padding:4px 12px;border-radius:12px;font-size:12px}.attempt-info{font-size:13px;color:#6b7280}.audio-section{background:linear-gradient(135deg,#f5f3ff,#ede9fe);border-radius:16px;padding:24px;margin-bottom:24px}.audio-player{display:flex;align-items:center;gap:16px}.audio-player .play-btn{background:linear-gradient(135deg,#8b5cf6,#6366f1);color:#fff;border:none;padding:12px 32px;border-radius:25px;font-size:16px;font-weight:500;cursor:pointer;transition:all .2s ease}.audio-player .play-btn:hover{transform:scale(1.05)}.audio-player .play-btn.playing{background:linear-gradient(135deg,#10b981,#059669)}.audio-progress{flex:1;height:8px;background:#8b5cf633;border-radius:4px;overflow:hidden}.audio-progress .progress-bar{height:100%;width:0;background:linear-gradient(90deg,#8b5cf6,#6366f1);border-radius:4px;transition:width .3s ease}.audio-progress .progress-bar.playing{animation:progress 3s linear forwards}@keyframes progress{0%{width:0}to{width:100%}}.hint-text{margin-top:12px;font-size:14px;color:#6d28d9}.sorting-area{display:grid;grid-template-columns:1fr 1fr;gap:24px;margin-bottom:24px}.answer-area h3,.segment-pool h3{font-size:16px;color:#374151;margin-bottom:12px}.drop-zone{min-height:300px;background:#8b5cf60d;border:2px dashed #c4b5fd;border-radius:12px;padding:16px;transition:all .2s ease}.drop-zone:hover{border-color:#8b5cf6;background:#8b5cf61a}.drop-zone.correct{border-color:#10b981;background:#10b9811a}.drop-zone.incorrect{border-color:#ef4444;background:#ef44441a}.drop-zone .placeholder{color:#9ca3af;text-align:center;padding:40px 20px}.ordered-segments{display:flex;flex-direction:column;gap:8px}.pool-container{min-height:300px;background:#f9fafb;border-radius:12px;padding:16px}.pool-container .placeholder{color:#9ca3af;text-align:center;padding:40px 20px}.pool-segments{display:flex;flex-direction:column;gap:8px}.segment-item{background:#fff;border:1px solid #e5e7eb;border-radius:10px;padding:12px 16px;cursor:grab;transition:all .2s ease;display:flex;align-items:center;gap:12px}.segment-item:hover{border-color:#8b5cf6;box-shadow:0 2px 8px #8b5cf626}.segment-item.in-order{background:linear-gradient(135deg,#f5f3ff,#ede9fe)}.segment-item.in-order.correct{border-color:#10b981;background:linear-gradient(135deg,#d1fae5,#a7f3d0)}.segment-item.in-order.wrong{border-color:#ef4444;background:linear-gradient(135deg,#fee2e2,#fecaca)}.order-number{width:28px;height:28px;background:linear-gradient(135deg,#8b5cf6,#6366f1);color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:600;flex-shrink:0}.segment-content{flex:1;font-size:14px;color:#374151}.remove-hint{color:#9ca3af;font-size:14px;opacity:0;transition:opacity .2s ease}.segment-item:hover .remove-hint{opacity:1}.drag-handle{color:#9ca3af;font-size:16px}.result-message{margin-top:16px;padding:16px;border-radius:12px;display:flex;align-items:center;gap:12px}.result-message.success{background:linear-gradient(135deg,#d1fae5,#a7f3d0);color:#065f46}.result-message.error{background:linear-gradient(135deg,#fef3c7,#fde68a);color:#92400e}.action-buttons{display:flex;justify-content:center;gap:16px}.reset-btn,.check-btn,.next-btn{padding:12px 32px;border-radius:25px;font-size:16px;font-weight:500;cursor:pointer;transition:all .2s ease;border:none}.reset-btn{background:#f3f4f6;color:#4b5563}.reset-btn:hover{background:#e5e7eb}.check-btn{background:linear-gradient(135deg,#8b5cf6,#6366f1);color:#fff}.check-btn:hover:not(:disabled){transform:scale(1.05)}.check-btn:disabled{opacity:.5;cursor:not-allowed}.next-btn{background:linear-gradient(135deg,#10b981,#059669);color:#fff;text-decoration:none}@media (max-width: 768px){.materials-grid,.sorting-area{grid-template-columns:1fr}.action-buttons{flex-wrap:wrap}}.listening-history-page{max-width:900px;margin:0 auto;padding:24px}.page-header{text-align:center;margin-bottom:32px}.page-header .back-link{display:inline-block;color:#8b5cf6;text-decoration:none;margin-bottom:16px;font-size:14px}.page-header h1{font-size:28px;color:#1f2937;margin-bottom:8px}.page-header p{color:#6b7280;font-size:16px}.stats-overview{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:32px}.stat-card{background:#ffffffe6;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:16px;padding:20px;display:flex;align-items:center;gap:16px;border:1px solid rgba(139,92,246,.1)}.stat-icon{font-size:32px}.stat-value{font-size:24px;font-weight:700;color:#6d28d9}.stat-label{font-size:13px;color:#6b7280}.filter-bar{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px;padding:16px;background:#fffc;border-radius:12px;border:1px solid #e5e7eb}.filter-group{display:flex;gap:8px}.filter-btn{padding:8px 16px;border-radius:20px;border:1px solid #e5e7eb;background:#fff;color:#6b7280;cursor:pointer;transition:all .2s ease;font-size:14px}.filter-btn:hover{border-color:#8b5cf6;color:#8b5cf6}.filter-btn.active{background:linear-gradient(135deg,#8b5cf6,#6366f1);color:#fff;border-color:transparent}.sort-group{display:flex;align-items:center;gap:8px}.sort-group label{font-size:14px;color:#6b7280}.sort-group select{padding:8px 12px;border-radius:8px;border:1px solid #d1d5db;font-size:14px}.history-list{display:flex;flex-direction:column;gap:12px}.history-item{background:#ffffffe6;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:16px;padding:20px;display:grid;grid-template-columns:auto 1fr auto auto auto;align-items:center;gap:16px;border:1px solid #e5e7eb;transition:all .2s ease}.history-item:hover{border-color:#c4b5fd;box-shadow:0 4px 12px #8b5cf61a}.item-icon{font-size:28px}.item-info{display:flex;flex-direction:column;gap:8px}.item-title{font-size:16px;font-weight:600;color:#1f2937}.item-meta{display:flex;gap:8px;flex-wrap:wrap}.type-tag{background:linear-gradient(135deg,#f5f3ff,#ede9fe);color:#6d28d9;padding:4px 10px;border-radius:12px;font-size:12px}.difficulty-tag{background:#e0e7ff;color:#3730a3;padding:4px 10px;border-radius:12px;font-size:12px}.duration{font-size:12px;color:#9ca3af}.item-score{font-size:24px;font-weight:700}.item-date{font-size:13px;color:#9ca3af;text-align:right}.item-action{padding:8px 16px;border-radius:20px;border:1px solid #8b5cf6;background:#fff;color:#8b5cf6;cursor:pointer;font-size:13px;transition:all .2s ease}.item-action:hover{background:#8b5cf6;color:#fff}.empty-state{text-align:center;padding:60px 20px;background:#ffffff80;border-radius:20px;border:2px dashed #e5e7eb}.empty-icon{font-size:48px;display:block;margin-bottom:16px}.empty-state p{color:#6b7280;margin-bottom:20px}.start-link{display:inline-block;background:linear-gradient(135deg,#8b5cf6,#6366f1);color:#fff;padding:12px 32px;border-radius:25px;text-decoration:none;font-weight:500;transition:all .2s ease}.start-link:hover{transform:scale(1.05)}@media (max-width: 768px){.stats-overview{grid-template-columns:repeat(2,1fr)}.filter-bar{flex-direction:column;gap:16px}.history-item{grid-template-columns:auto 1fr;gap:12px}.item-score,.item-date,.item-action{grid-column:2}.item-meta{flex-direction:column;gap:4px}}.analysis-page{min-height:100vh;padding:24px;max-width:1440px;margin:0 auto;animation:fadeIn .5s ease-out}.analysis-header{background:linear-gradient(135deg,#6366f1,#8b5cf6,#a855f7);border-radius:20px;padding:32px 40px;color:#fff;position:relative;overflow:hidden;margin-bottom:24px;box-shadow:0 20px 60px #6366f140}.header-bg-decoration{position:absolute;top:0;right:0;bottom:0;left:0;overflow:hidden;pointer-events:none}.decoration-circle{position:absolute;border-radius:50%;background:radial-gradient(circle,rgba(255,255,255,.1) 0%,transparent 70%)}.circle-1{width:500px;height:500px;top:-250px;right:-100px}.circle-2,.circle-3{display:none}.header-content{display:flex;justify-content:space-between;align-items:flex-start;position:relative;z-index:2}.header-left{flex:1}.title-wrapper{display:flex;align-items:center;gap:16px}.title-icon{font-size:40px;line-height:1;filter:drop-shadow(0 2px 8px rgba(0,0,0,.15))}.title-text{display:flex;flex-direction:column}.analysis-title{font-family:var(--font-heading);font-size:32px;font-weight:800;margin:0;letter-spacing:-.02em}.analysis-subtitle{font-size:15px;opacity:.9;margin-top:6px;line-height:1.5}.header-right{display:flex;flex-direction:column;align-items:flex-end;gap:12px}.level-badge{display:flex;align-items:center;gap:12px;background:#ffffff26;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);padding:10px 18px;border-radius:16px;border:1px solid rgba(255,255,255,.2)}.level-icon{font-size:24px}.level-info{display:flex;flex-direction:column}.level-label{font-size:11px;opacity:.8;text-transform:uppercase;letter-spacing:.5px}.level-value{font-size:15px;font-weight:700}.update-time{display:flex;align-items:center;gap:6px;font-size:12px;opacity:.85;background:#ffffff1a;padding:6px 12px;border-radius:20px}.time-icon{font-size:14px}.stats-section{margin-bottom:24px;animation:slideUp .5s ease-out .1s both}.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}.stat-card{background:#fff;border:1px solid #f1f5f9;border-radius:16px;padding:20px;display:flex;flex-direction:column;gap:12px;transition:all .25s ease;position:relative;overflow:hidden}.stat-card:before{content:"";position:absolute;top:0;left:0;right:0;height:4px;opacity:0;transition:opacity .25s ease}.stat-card-blue:before{background:linear-gradient(90deg,#3b82f6,#60a5fa)}.stat-card-orange:before{background:linear-gradient(90deg,#f59e0b,#fbbf24)}.stat-card-green:before{background:linear-gradient(90deg,#10b981,#34d399)}.stat-card-purple:before{background:linear-gradient(90deg,#8b5cf6,#a78bfa)}.stat-card:hover{transform:translateY(-4px);box-shadow:0 12px 32px #00000014;border-color:transparent}.stat-card:hover:before{opacity:1}.stat-header{display:flex;align-items:center;justify-content:space-between}.stat-icon-wrapper{width:48px;height:48px;border-radius:12px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.stat-card-blue .stat-icon-wrapper{background:linear-gradient(135deg,#eff6ff,#dbeafe)}.stat-card-orange .stat-icon-wrapper{background:linear-gradient(135deg,#fffbeb,#fef3c7)}.stat-card-green .stat-icon-wrapper{background:linear-gradient(135deg,#ecfdf5,#d1fae5)}.stat-card-purple .stat-icon-wrapper{background:linear-gradient(135deg,#f5f3ff,#ede9fe)}.stat-icon{font-size:24px;line-height:1}.stat-trend{display:flex;align-items:center;gap:4px;font-size:12px;font-weight:600;padding:4px 10px;border-radius:20px}.trend-up{background:#ecfdf5;color:#10b981}.trend-down{background:#fef2f2;color:#ef4444}.trend-arrow{font-size:10px}.trend-value{font-size:11px}.stat-value-row{display:flex;align-items:baseline;gap:4px}.stat-value{font-family:var(--font-heading);font-size:36px;font-weight:700;color:#1f2937;letter-spacing:-.02em;line-height:1.1}.stat-unit{font-size:14px;font-weight:500;color:#9ca3af}.stat-label{font-size:13px;color:#6b7280;margin-top:4px;display:block}.analysis-main-content{display:grid;grid-template-columns:1fr 360px;gap:24px;margin-bottom:24px}.left-column,.right-column{display:flex;flex-direction:column;gap:24px}.analysis-section{animation:slideUp .5s ease-out}.section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}.section-title{font-family:var(--font-heading);font-size:18px;font-weight:700;color:#1f2937;display:flex;align-items:center;gap:12px;letter-spacing:-.01em}.title-bar{width:4px;height:20px;background:linear-gradient(180deg,#6366f1,#8b5cf6);border-radius:2px}.section-badge{font-size:11px;font-weight:500;color:#9ca3af;background:#f8fafc;padding:4px 12px;border-radius:20px;border:1px solid #f1f5f9}.section-hint{font-size:12px;color:#9ca3af}.view-all-link{font-size:13px;font-weight:500;color:#6366f1;text-decoration:none;transition:color .2s ease}.view-all-link:hover{color:#4f46e5}.glass-card{background:#fff;border:1px solid #f1f5f9;box-shadow:0 4px 16px #0000000a}.radar-section .radar-card{border-radius:16px}.radar-section .card-content{padding:24px}.radar-container{display:flex;justify-content:center;margin-bottom:24px}.radar-legend{display:grid;grid-template-columns:repeat(2,1fr);gap:12px}.legend-item{display:flex;align-items:center;gap:10px}.legend-label{font-size:13px;font-weight:500;color:#6b7280;width:50px;flex-shrink:0}.legend-bar{flex:1;height:6px;background:#f1f5f9;border-radius:3px;overflow:hidden}.legend-fill{height:100%;background:linear-gradient(90deg,#6366f1,#8b5cf6);border-radius:3px;transition:width .5s ease}.legend-value{font-size:13px;font-weight:600;color:#6366f1;width:36px;text-align:right}.modules-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:16px}.module-card{border-radius:16px;transition:all .25s ease;position:relative;overflow:hidden}.module-card:before{content:"";position:absolute;top:0;left:0;right:0;height:4px}.speaking-card:before{background:linear-gradient(90deg,#10b981,#34d399)}.reading-card:before{background:linear-gradient(90deg,#3b82f6,#60a5fa)}.writing-card:before{background:linear-gradient(90deg,#f59e0b,#fbbf24)}.listening-card:before{background:linear-gradient(90deg,#8b5cf6,#a78bfa)}.module-card:hover{transform:translateY(-4px);box-shadow:0 12px 32px #00000014}.module-card .card-content{padding:20px}.module-header{display:flex;align-items:center;gap:12px;margin-bottom:16px}.module-icon{width:44px;height:44px;border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:22px;flex-shrink:0}.speaking-icon{background:linear-gradient(135deg,#ecfdf5,#d1fae5)}.reading-icon{background:linear-gradient(135deg,#eff6ff,#dbeafe)}.writing-icon{background:linear-gradient(135deg,#fffbeb,#fef3c7)}.listening-icon{background:linear-gradient(135deg,#f5f3ff,#ede9fe)}.module-info{flex:1}.module-name{font-size:15px;font-weight:600;color:#1f2937;margin:0 0 4px}.module-level{font-size:11px;font-weight:500;color:#6b7280;background:#f8fafc;padding:2px 8px;border-radius:10px;display:inline-block}.module-score{display:flex;align-items:baseline;gap:2px}.score-value{font-family:var(--font-heading);font-size:28px;font-weight:700;color:#1f2937}.score-unit{font-size:13px;font-weight:500;color:#9ca3af}.module-progress{margin-bottom:16px}.progress-bar{height:8px;background:#f1f5f9;border-radius:4px;overflow:hidden;margin-bottom:8px;position:relative}.progress-fill{height:100%;border-radius:4px;transition:width .5s ease}.speaking-fill{background:linear-gradient(90deg,#10b981,#34d399)}.reading-fill{background:linear-gradient(90deg,#3b82f6,#60a5fa)}.writing-fill{background:linear-gradient(90deg,#f59e0b,#fbbf24)}.listening-fill{background:linear-gradient(90deg,#8b5cf6,#a78bfa)}.progress-labels{display:flex;justify-content:space-between;font-size:10px;color:#9ca3af;padding:0 2px}.progress-labels .current-level{color:#6366f1;font-weight:600}.module-stats{display:flex;justify-content:space-between;padding-top:12px;border-top:1px solid #f1f5f9}.module-stat{text-align:center}.module-stat .stat-num{display:block;font-size:16px;font-weight:700;color:#1f2937}.module-stat .stat-text{font-size:10px;color:#9ca3af;margin-top:2px}.trends-section .trends-tabs{display:flex;gap:8px;margin-bottom:16px;flex-wrap:wrap}.trend-tab{display:flex;align-items:center;gap:6px;padding:8px 14px;font-size:13px;font-weight:500;color:#6b7280;background:#fff;border:1px solid #f1f5f9;border-radius:10px;cursor:pointer;transition:all .2s ease}.trend-tab:hover{background:#f8fafc;border-color:#e2e8f0}.trend-tab.active{background:linear-gradient(135deg,#6366f1,#8b5cf6);color:#fff;border-color:transparent;box-shadow:0 4px 12px #6366f140}.tab-icon{font-size:14px}.trend-chart-card{border-radius:16px}.trend-chart-card .card-content{padding:20px}.chart-container{width:100%;margin-bottom:16px}.chart-summary{display:flex;justify-content:space-around;padding-top:16px;border-top:1px solid #f1f5f9}.summary-item{text-align:center}.summary-label{display:block;font-size:11px;color:#9ca3af;margin-bottom:4px}.summary-value{font-size:18px;font-weight:700;color:#1f2937}.summary-value.highlight{color:#6366f1}.summary-value.positive{color:#10b981}.activities-card{border-radius:16px}.activities-card .card-content{padding:16px}.activities-list{display:flex;flex-direction:column;gap:8px}.activity-item{display:flex;align-items:center;gap:12px;padding:12px;border-radius:12px;transition:background .2s ease}.activity-item:hover{background:#f8fafc}.activity-icon{width:40px;height:40px;border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:18px;flex-shrink:0}.activity-content{flex:1;min-width:0}.activity-title{font-size:13px;font-weight:500;color:#1f2937;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.activity-meta{display:flex;align-items:center;gap:8px;font-size:11px;color:#9ca3af;margin-top:4px}.activity-dot{font-size:6px}.activity-duration{background:#f1f5f9;padding:2px 8px;border-radius:6px}.achievements-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:10px}.achievement-card{display:flex;align-items:flex-start;gap:12px;padding:14px;background:#fff;border:1px solid #f1f5f9;border-radius:12px;transition:all .25s ease;position:relative;overflow:hidden}.achievement-glow{position:absolute;top:0;left:0;bottom:0;width:3px}.achievement-card:hover{transform:translateY(-2px);box-shadow:0 8px 24px #0000000f}.rarity-common .achievement-glow{background:#9ca3af}.rarity-rare .achievement-glow{background:linear-gradient(180deg,#3b82f6,#8b5cf6)}.rarity-epic .achievement-glow{background:linear-gradient(180deg,#f59e0b,#ef4444)}.rarity-legendary .achievement-glow{background:linear-gradient(180deg,#fbbf24,#f59e0b)}.achievement-icon{font-size:28px;flex-shrink:0}.achievement-content{flex:1;min-width:0}.achievement-title{font-size:12px;font-weight:600;color:#1f2937;margin-bottom:2px}.achievement-desc{font-size:10px;color:#6b7280;margin-bottom:4px}.achievement-date{font-size:10px;color:#9ca3af}.weak-points-section{animation:slideUp .5s ease-out .3s both}.weak-points-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}.weak-point-card{border-radius:16px;transition:all .25s ease}.weak-point-card:hover{transform:translateY(-4px);box-shadow:0 12px 32px #00000014}.weak-point-card .card-content{padding:20px;display:flex;flex-direction:column;height:100%}.weak-point-header{display:flex;align-items:center;gap:12px;padding-bottom:12px;margin-bottom:16px;border-bottom:2px solid #f1f5f9}.weak-point-icon{width:40px;height:40px;border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:20px}.weak-point-category{font-size:15px;font-weight:600;color:#1f2937;margin:0}.weak-point-list{list-style:none;margin:0;padding:0;flex:1}.weak-point-item{display:flex;align-items:center;gap:8px;font-size:13px;color:#6b7280;padding:8px 0}.item-dot{width:6px;height:6px;border-radius:50%;flex-shrink:0}.practice-btn{display:flex;align-items:center;justify-content:center;gap:8px;width:100%;padding:12px;font-size:13px;font-weight:600;color:#fff;border:none;border-radius:10px;cursor:pointer;transition:all .2s ease;margin-top:16px}.practice-btn:hover{transform:translateY(-2px);box-shadow:0 8px 20px #00000026;filter:brightness(1.05)}.btn-arrow{transition:transform .2s ease}.practice-btn:hover .btn-arrow{transform:translate(4px)}.recommendations-section{animation:slideUp .5s ease-out .4s both}.recommendations-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}.recommendation-card{border-radius:16px;transition:all .25s ease}.recommendation-card:hover{transform:translateY(-4px);box-shadow:0 12px 32px #00000014}.recommendation-card .card-content{padding:20px}.rec-icon{width:48px;height:48px;border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:24px;margin-bottom:16px}.rec-title{font-size:15px;font-weight:600;color:#1f2937;margin:0 0 8px}.rec-description{font-size:13px;color:#6b7280;line-height:1.6;margin:0 0 16px}.rec-action{display:inline-flex;align-items:center;gap:6px;font-size:13px;font-weight:600;text-decoration:none;transition:gap .2s ease}.rec-action:hover{gap:10px}.action-arrow{transition:transform .2s ease}.rec-action:hover .action-arrow{transform:translate(4px)}@media (max-width: 1400px){.stats-grid,.weak-points-grid,.recommendations-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width: 1200px){.analysis-main-content{grid-template-columns:1fr}.right-column{display:grid;grid-template-columns:repeat(2,1fr);gap:24px}.modules-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width: 1024px){.stats-grid,.modules-grid,.weak-points-grid{grid-template-columns:repeat(2,1fr)}.achievements-grid,.recommendations-grid{grid-template-columns:1fr}}@media (max-width: 768px){.analysis-page{padding:16px}.analysis-header{padding:20px;border-radius:16px}.header-content{flex-direction:column;gap:16px}.header-right{align-items:flex-start;flex-direction:row;gap:12px}.title-wrapper{flex-direction:column;gap:8px;align-items:flex-start}.title-icon{font-size:32px}.analysis-title{font-size:24px}.analysis-subtitle{font-size:13px}.stats-grid{grid-template-columns:repeat(2,1fr);gap:12px}.stat-card{padding:16px}.stat-value{font-size:28px}.right-column{grid-template-columns:1fr}.section-title{font-size:16px}.weak-points-grid,.modules-grid{grid-template-columns:1fr}.weak-point-card .card-content{padding:16px}}@media (max-width: 480px){.stats-grid{grid-template-columns:1fr}.module-stats{flex-wrap:wrap;gap:8px}.module-stat{flex:1;min-width:80px}.achievements-grid{grid-template-columns:1fr}.achievement-card{padding:12px}.achievement-icon{font-size:24px}.level-badge{padding:8px 12px}.level-icon{font-size:20px}.trends-tabs{justify-content:center}.trend-tab{padding:6px 10px;font-size:12px}}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.stats-section .stat-card:nth-child(1){animation:slideUp .5s ease-out .1s both}.stats-section .stat-card:nth-child(2){animation:slideUp .5s ease-out .15s both}.stats-section .stat-card:nth-child(3){animation:slideUp .5s ease-out .2s both}.stats-section .stat-card:nth-child(4){animation:slideUp .5s ease-out .25s both}.modules-grid .module-card:nth-child(1){animation:slideUp .5s ease-out .2s both}.modules-grid .module-card:nth-child(2){animation:slideUp .5s ease-out .25s both}.modules-grid .module-card:nth-child(3){animation:slideUp .5s ease-out .3s both}.modules-grid .module-card:nth-child(4){animation:slideUp .5s ease-out .35s both}.weak-points-grid .weak-point-card:nth-child(1){animation:slideUp .5s ease-out .3s both}.weak-points-grid .weak-point-card:nth-child(2){animation:slideUp .5s ease-out .35s both}.weak-points-grid .weak-point-card:nth-child(3){animation:slideUp .5s ease-out .4s both}.weak-points-grid .weak-point-card:nth-child(4){animation:slideUp .5s ease-out .45s both}.recommendations-grid .recommendation-card:nth-child(1){animation:slideUp .5s ease-out .4s both}.recommendations-grid .recommendation-card:nth-child(2){animation:slideUp .5s ease-out .45s both}.recommendations-grid .recommendation-card:nth-child(3){animation:slideUp .5s ease-out .5s both}.admin-loading,.admin-error{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:400px;gap:16px}.admin-spinner{width:48px;height:48px;border:3px solid rgba(255,255,255,.1);border-top-color:#6366f1;border-radius:50%;animation:spin 1s linear infinite}.admin-error span{font-size:48px}.admin-error p{color:#f87171;font-size:18px}.admin-error button{background:#6366f1;color:#fff;border:none;padding:10px 24px;border-radius:8px;cursor:pointer;transition:background .2s}.admin-error button:hover{background:#4f46e5}.admin-tabs{display:flex;gap:8px;margin-bottom:24px;background:#1e293b80;padding:6px;border-radius:12px;width:fit-content}.admin-tab{background:transparent;border:none;color:#94a3b8;padding:10px 20px;border-radius:8px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s}.admin-tab:hover{color:#e2e8f0;background:#ffffff0d}.admin-tab.active{background:#6366f1;color:#fff}.admin-stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;margin-bottom:24px}.admin-stat-card{border-radius:16px;padding:24px;display:flex;align-items:flex-start;gap:16px;box-shadow:0 4px 20px #0003}.stat-icon{font-size:36px;opacity:.9}.stat-content{flex:1}.stat-title{color:#fffc;font-size:14px;margin:0 0 8px}.stat-value{color:#fff;font-size:32px;font-weight:700;margin:0 0 4px}.stat-subtitle{color:#ffffffb3;font-size:12px;margin:0}.stat-trend{color:#ffffffe6;font-size:12px;margin:4px 0 0;padding:4px 8px;background:#fff3;border-radius:4px;display:inline-block}.admin-section{background:#1e293b80;border:1px solid rgba(255,255,255,.1);border-radius:16px;padding:24px;margin-bottom:24px}.admin-section-title{color:#f1f5f9;font-size:18px;font-weight:600;margin:0 0 20px}.admin-role-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}.admin-role-card{display:flex;align-items:center;gap:16px;padding:20px;border-radius:12px;border:1px solid}.role-icon{font-size:32px}.role-info{flex:1}.role-label{font-size:14px;margin:0 0 4px;opacity:.8}.role-count{font-size:28px;font-weight:700;margin:0}.admin-two-column{display:grid;grid-template-columns:1fr 1fr;gap:24px}.admin-quick-actions{display:grid;grid-template-columns:repeat(2,1fr);gap:12px}.admin-action-btn{display:flex;align-items:center;gap:12px;padding:16px;background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:12px;text-decoration:none;transition:all .2s}.admin-action-btn:hover{background:#6366f126;border-color:#6366f14d;transform:translateY(-2px)}.action-icon{font-size:24px}.action-text{flex:1}.action-title{display:block;color:#f1f5f9;font-size:14px;font-weight:600;margin-bottom:4px}.action-desc{display:block;color:#94a3b8;font-size:12px}.admin-logs-list{max-height:300px;overflow-y:auto}.admin-log-item{display:flex;align-items:center;gap:12px;padding:12px;border-radius:8px;margin-bottom:8px;background:#ffffff08}.admin-log-item.level-info{border-left:3px solid #3b82f6}.admin-log-item.level-warning{border-left:3px solid #f59e0b}.admin-log-item.level-error{border-left:3px solid #ef4444}.log-level{font-size:10px;font-weight:600;text-transform:uppercase;padding:2px 6px;border-radius:4px;background:#ffffff1a;color:#94a3b8}.log-message{flex:1;color:#e2e8f0;font-size:13px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.log-time{color:#64748b;font-size:11px;white-space:nowrap}.admin-no-data{color:#64748b;text-align:center;padding:40px}.admin-view-all{display:block;text-align:center;color:#6366f1;text-decoration:none;margin-top:16px;font-size:14px;transition:color .2s}.admin-view-all:hover{color:#818cf8}.admin-learning-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;margin-bottom:24px}.admin-learning-card{background:#1e293b80;border:1px solid rgba(255,255,255,.1);border-radius:16px;overflow:hidden}.learning-header{display:flex;align-items:center;gap:12px;padding:16px 20px;border-bottom:3px solid;background:#ffffff08}.learning-icon{font-size:24px}.learning-title{color:#f1f5f9;font-size:16px;font-weight:600}.learning-stats{padding:20px;display:flex;flex-direction:column;gap:16px}.learning-stat{display:flex;justify-content:space-between;align-items:center}.learning-stat .stat-label{color:#94a3b8;font-size:14px}.learning-stat .stat-value{font-size:20px;font-weight:700}.admin-info-box{background:#3b82f61a;border:1px solid rgba(59,130,246,.2);border-radius:12px;padding:20px;color:#93c5fd}.admin-info-box p{margin:0 0 12px}.admin-info-box ul{margin:12px 0;padding-left:20px}.admin-info-box li{margin-bottom:8px}.admin-status-cards{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;margin-bottom:24px}.admin-status-card{background:#1e293b80;border:1px solid rgba(255,255,255,.1);border-radius:16px;padding:20px}.status-header{display:flex;align-items:center;gap:12px;margin-bottom:16px}.status-icon{font-size:24px}.status-title{color:#f1f5f9;font-size:14px;font-weight:600}.status-content{display:flex;align-items:center;gap:12px}.status-indicator{width:12px;height:12px;border-radius:50%}.status-indicator.online{background:#10b981;box-shadow:0 0 10px #10b98180}.status-indicator.offline{background:#ef4444;box-shadow:0 0 10px #ef444480}.status-text{color:#94a3b8;font-size:13px}.disk-usage-bar{flex:1;height:8px;background:#ffffff1a;border-radius:4px;overflow:hidden}.disk-usage-fill{height:100%;background:linear-gradient(90deg,#10b981,#f59e0b 70%,#ef4444 90%);transition:width .3s}.admin-info-table{display:flex;flex-direction:column;gap:12px}.info-row{display:flex;justify-content:space-between;align-items:center;padding:12px 16px;background:#ffffff08;border-radius:8px}.info-label{color:#94a3b8;font-size:14px}.info-value{color:#f1f5f9;font-size:14px;font-weight:500}@media (max-width: 1200px){.admin-stats-grid,.admin-learning-grid,.admin-status-cards{grid-template-columns:repeat(2,1fr)}}@media (max-width: 768px){.admin-stats-grid,.admin-learning-grid,.admin-status-cards,.admin-role-grid,.admin-quick-actions,.admin-two-column{grid-template-columns:1fr}.admin-tabs{flex-wrap:wrap}.admin-tab{flex:1;text-align:center}}.user-management{display:flex;flex-direction:column;gap:24px}.filter-bar{display:flex;justify-content:space-between;align-items:center;padding:16px 20px;background:#1e293b80;border:1px solid rgba(255,255,255,.1);border-radius:12px}.filter-left{display:flex;gap:12px}.search-input{background:#0000004d;border:1px solid rgba(255,255,255,.2);border-radius:8px;padding:10px 16px;color:#f1f5f9;font-size:14px;width:280px}.search-input:focus{outline:none;border-color:#6366f1}.search-input::placeholder{color:#64748b}.role-select{background:#0000004d;border:1px solid rgba(255,255,255,.2);border-radius:8px;padding:10px 16px;color:#f1f5f9;font-size:14px;cursor:pointer}.role-select:focus{outline:none;border-color:#6366f1}.user-count{color:#64748b;font-size:14px}.user-table-container{background:#1e293b80;border:1px solid rgba(255,255,255,.1);border-radius:16px;overflow:hidden}.user-table{width:100%;border-collapse:collapse}.user-table th{background:#6366f133;color:#c7d2fe;font-size:13px;font-weight:600;text-align:left;padding:14px 16px;border-bottom:1px solid rgba(255,255,255,.1)}.user-table td{padding:14px 16px;color:#e2e8f0;font-size:14px;border-bottom:1px solid rgba(255,255,255,.05)}.user-table tbody tr:hover{background:#ffffff08}.username{font-weight:600;color:#f1f5f9}.email{color:#94a3b8}.institution{font-size:13px}.major{color:#64748b;font-size:12px}.date{color:#94a3b8;font-size:13px}.role-badge,.status-badge{display:inline-block;padding:4px 10px;border-radius:20px;font-size:12px;font-weight:500}.status-badge.active{background:#10b98133;color:#6ee7b7}.status-badge.inactive{background:#ef444433;color:#fca5a5}.consent-badge{display:inline-block;width:24px;height:24px;line-height:24px;text-align:center;border-radius:50%;font-size:14px;font-weight:700}.consent-badge.given{background:#10b98133;color:#6ee7b7}.consent-badge.not-given{background:#ef444433;color:#fca5a5}.actions{display:flex;gap:8px}.action-btn{padding:6px 12px;border-radius:6px;font-size:12px;cursor:pointer;transition:all .2s}.action-btn.edit{background:#6366f133;border:1px solid rgba(99,102,241,.3);color:#a5b4fc}.action-btn.edit:hover{background:#6366f14d}.action-btn.delete{background:#ef444433;border:1px solid rgba(239,68,68,.3);color:#fca5a5}.action-btn.delete:hover{background:#ef44444d}.edit-modal{background:#1e293b;border:1px solid rgba(255,255,255,.1);border-radius:16px;width:90%;max-width:480px;overflow:hidden}.modal-body{padding:24px}.reset-info{color:#94a3b8;font-size:14px;margin:0 0 20px}.reset-info strong{color:#f1f5f9}.form-group{margin-bottom:20px}.form-group:last-child{margin-bottom:0}.form-group label{display:block;color:#94a3b8;font-size:13px;margin-bottom:8px}.form-group input,.form-group select{width:100%;background:#0000004d;border:1px solid rgba(255,255,255,.2);border-radius:8px;padding:12px 14px;color:#f1f5f9;font-size:14px}.form-group input.disabled{background:#00000080;color:#64748b;cursor:not-allowed}.modal-footer{display:flex;gap:12px;padding:20px 24px;border-top:1px solid rgba(255,255,255,.1)}.btn-cancel,.btn-confirm,.btn-reset-pwd{flex:1;padding:12px 20px;border-radius:8px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s}.btn-cancel{background:#ffffff1a;border:1px solid rgba(255,255,255,.2);color:#94a3b8}.btn-cancel:hover{background:#ffffff26}.btn-confirm{background:#6366f1;border:none;color:#fff}.btn-confirm:hover{background:#4f46e5}.btn-reset-pwd{background:#f59e0b33;border:1px solid rgba(245,158,11,.3);color:#fcd34d}.btn-reset-pwd:hover{background:#f59e0b4d}@media (max-width: 1024px){.user-table-container{overflow-x:auto}.user-table{min-width:900px}}@media (max-width: 768px){.filter-bar{flex-direction:column;gap:12px}.filter-left{width:100%;flex-direction:column}.search-input,.user-count{width:100%}}.system-logs{display:flex;flex-direction:column;gap:24px}.logs-toolbar{display:flex;justify-content:space-between;align-items:center;padding:16px 20px;background:#1e293b80;border:1px solid rgba(255,255,255,.1);border-radius:12px}.filter-group{display:flex;gap:12px;align-items:center}.filter-select{background:#0000004d;border:1px solid rgba(255,255,255,.2);border-radius:8px;padding:8px 14px;color:#f1f5f9;font-size:14px;cursor:pointer}.filter-select:focus{outline:none;border-color:#6366f1}.refresh-btn{background:#6366f133;border:1px solid rgba(99,102,241,.3);color:#a5b4fc;padding:8px 16px;border-radius:8px;font-size:14px;cursor:pointer;transition:all .2s}.refresh-btn:hover{background:#6366f14d}.logs-count{color:#64748b;font-size:14px}.no-logs{text-align:center;padding:80px 20px;background:#1e293b80;border:1px solid rgba(255,255,255,.1);border-radius:16px}.no-logs-icon{font-size:48px;display:block;margin-bottom:16px;opacity:.5}.no-logs p{color:#64748b;margin:0}.logs-container{display:flex;flex-direction:column;gap:12px;max-height:calc(100vh - 300px);overflow-y:auto}.log-item{background:#1e293b80;border:1px solid rgba(255,255,255,.1);border-radius:12px;padding:16px 20px;cursor:pointer;transition:all .2s;border-left:4px solid}.log-item:hover{background:#1e293bb3;transform:translate(4px)}.log-item.level-info{border-left-color:#3b82f6}.log-item.level-warning{border-left-color:#f59e0b}.log-item.level-error{border-left-color:#ef4444}.log-item.level-critical{border-left-color:#dc2626;background:#ef44441a}.log-item.level-debug{border-left-color:#64748b}.log-header{display:flex;align-items:center;gap:12px;margin-bottom:8px;flex-wrap:wrap}.log-level{font-size:10px;font-weight:600;text-transform:uppercase;padding:3px 8px;border-radius:4px}.log-level.level-info{background:#3b82f633;color:#93c5fd}.log-level.level-warning{background:#f59e0b33;color:#fcd34d}.log-level.level-error{background:#ef444433;color:#fca5a5}.log-level.level-critical{background:#dc26264d;color:#fca5a5}.log-level.level-debug{background:#64748b33;color:#94a3b8}.log-module{background:#ffffff1a;color:#94a3b8;padding:2px 8px;border-radius:4px;font-size:12px}.log-action{color:#6366f1;font-size:13px;font-weight:500}.log-time{color:#64748b;font-size:12px;margin-left:auto}.log-message{color:#e2e8f0;font-size:14px;line-height:1.5}.log-detail-modal{background:#1e293b;border:1px solid rgba(255,255,255,.1);border-radius:16px;width:90%;max-width:600px;max-height:80vh;overflow-y:auto}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:20px 24px;border-bottom:1px solid rgba(255,255,255,.1)}.modal-header h3{color:#f1f5f9;margin:0;font-size:18px}.close-btn{background:transparent;border:none;color:#94a3b8;font-size:20px;cursor:pointer;padding:4px}.close-btn:hover{color:#f1f5f9}.modal-body{padding:20px 24px}.detail-row{display:flex;flex-direction:column;gap:4px;margin-bottom:16px}.detail-label{color:#64748b;font-size:12px;text-transform:uppercase;letter-spacing:.5px}.detail-value{color:#f1f5f9;font-size:14px}.error-details{background:#0000004d;border:1px solid rgba(255,255,255,.1);border-radius:8px;padding:12px;color:#fca5a5;font-size:12px;font-family:Monaco,Menlo,monospace;white-space:pre-wrap;overflow-x:auto;margin:0}@media (max-width: 768px){.logs-toolbar{flex-direction:column;gap:12px}.filter-group{flex-wrap:wrap;width:100%}.filter-select{flex:1;min-width:100px}.log-header{gap:8px}.log-time{margin-left:0;width:100%}}.data-export{display:flex;flex-direction:column;gap:24px;max-width:900px}.warning-banner{display:flex;gap:16px;padding:20px 24px;background:#f59e0b1a;border:1px solid rgba(245,158,11,.3);border-radius:12px}.warning-icon{font-size:28px;flex-shrink:0}.warning-content h3{color:#fcd34d;font-size:16px;margin:0 0 12px}.warning-content ul{margin:0;padding-left:20px;color:#fcd34d;font-size:14px;line-height:1.8}.export-types{display:grid;grid-template-columns:repeat(2,1fr);gap:16px}.export-type-card{position:relative;display:flex;flex-direction:column;align-items:flex-start;padding:24px;background:#1e293b80;border:2px solid rgba(255,255,255,.1);border-radius:16px;cursor:pointer;transition:all .2s;text-align:left}.export-type-card:hover{background:#1e293bb3;border-color:var(--accent-color, rgba(255, 255, 255, .2))}.export-type-card.active{background:#6366f126;border-color:#6366f1}.type-icon{font-size:36px;margin-bottom:12px}.type-label{color:#f1f5f9;font-size:18px;font-weight:600;margin-bottom:8px}.type-desc{color:#64748b;font-size:13px;line-height:1.5}.check-mark{position:absolute;top:16px;right:16px;width:24px;height:24px;background:#6366f1;border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;font-size:14px}.export-action{display:flex;justify-content:center;padding:16px 0}.export-btn{background:linear-gradient(135deg,#6366f1,#4f46e5);border:none;color:#fff;padding:14px 40px;border-radius:12px;font-size:16px;font-weight:600;cursor:pointer;transition:all .2s;display:flex;align-items:center;gap:8px;box-shadow:0 4px 15px #6366f166}.export-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 20px #6366f180}.export-btn:disabled{opacity:.7;cursor:not-allowed}.btn-spinner{width:18px;height:18px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin 1s linear infinite}.export-result{background:#10b9811a;border:1px solid rgba(16,185,129,.3);border-radius:16px;padding:24px}.result-header{display:flex;align-items:center;gap:12px;margin-bottom:20px}.result-icon{font-size:24px}.result-header h3{color:#6ee7b7;margin:0;font-size:18px}.result-body{display:flex;flex-direction:column;gap:16px}.result-item{display:flex;flex-direction:column;gap:8px}.result-label{color:#64748b;font-size:12px;text-transform:uppercase;letter-spacing:.5px}.result-value{color:#f1f5f9;font-size:14px;font-family:Monaco,Menlo,monospace;background:#0003;padding:8px 12px;border-radius:6px}.record-counts{display:flex;flex-wrap:wrap;gap:12px}.count-item{display:flex;align-items:center;gap:8px;background:#0003;padding:8px 14px;border-radius:8px}.count-key{color:#94a3b8;font-size:13px}.count-value{color:#6ee7b7;font-size:14px;font-weight:600}@media (max-width: 768px){.export-types{grid-template-columns:1fr}.warning-banner{flex-direction:column}}.system-config{max-width:900px}.config-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px}.config-header h2{color:#f1f5f9;font-size:20px;margin:0}.add-config-btn{background:#6366f1;color:#fff;border:none;padding:10px 20px;border-radius:8px;font-size:14px;cursor:pointer;transition:background .2s}.add-config-btn:hover{background:#4f46e5}.no-config{text-align:center;padding:60px 20px;background:#1e293b80;border-radius:16px;border:1px solid rgba(255,255,255,.1)}.no-config p{color:#94a3b8;margin:0 0 8px}.no-config .hint{font-size:14px;opacity:.7}.config-category{margin-bottom:24px}.category-title{color:#94a3b8;font-size:14px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;margin:0 0 12px;padding-bottom:8px;border-bottom:1px solid rgba(255,255,255,.1)}.config-list{display:flex;flex-direction:column;gap:12px}.config-item{background:#1e293b80;border:1px solid rgba(255,255,255,.1);border-radius:12px;padding:16px 20px}.config-info{margin-bottom:12px}.config-key{color:#f1f5f9;font-size:15px;font-weight:600;font-family:Monaco,Menlo,monospace;display:flex;align-items:center;gap:8px}.secret-badge{background:#ef444433;color:#fca5a5;font-size:10px;padding:2px 6px;border-radius:4px;font-weight:500}.config-desc{color:#64748b;font-size:13px;margin-top:4px}.config-value-row{display:flex;justify-content:space-between;align-items:center}.config-value{color:#94a3b8;font-size:14px;font-family:Monaco,Menlo,monospace;background:#0003;padding:6px 12px;border-radius:6px}.config-actions{display:flex;gap:8px}.edit-btn,.delete-btn{padding:6px 12px;border-radius:6px;font-size:13px;cursor:pointer;transition:all .2s}.edit-btn{background:#6366f133;border:1px solid rgba(99,102,241,.3);color:#a5b4fc}.edit-btn:hover:not(:disabled){background:#6366f14d}.edit-btn:disabled{opacity:.5;cursor:not-allowed}.delete-btn{background:#ef444433;border:1px solid rgba(239,68,68,.3);color:#fca5a5}.delete-btn:hover{background:#ef44444d}.config-edit{display:flex;gap:8px;align-items:center}.edit-input{flex:1;background:#0000004d;border:1px solid rgba(255,255,255,.2);border-radius:6px;padding:8px 12px;color:#f1f5f9;font-family:Monaco,Menlo,monospace;font-size:14px}.edit-input:focus{outline:none;border-color:#6366f1}.save-btn,.cancel-btn{padding:8px 16px;border-radius:6px;font-size:13px;cursor:pointer;transition:all .2s}.save-btn{background:#10b981;border:none;color:#fff}.save-btn:hover{background:#059669}.cancel-btn{background:#ffffff1a;border:1px solid rgba(255,255,255,.2);color:#94a3b8}.cancel-btn:hover{background:#ffffff26}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:1000}.modal{background:#1e293b;border:1px solid rgba(255,255,255,.1);border-radius:16px;padding:24px;width:90%;max-width:500px}.modal h3{color:#f1f5f9;margin:0 0 20px;font-size:18px}.form-group{margin-bottom:16px}.form-group label{display:block;color:#94a3b8;font-size:13px;margin-bottom:6px}.form-group input,.form-group select{width:100%;background:#0000004d;border:1px solid rgba(255,255,255,.2);border-radius:8px;padding:10px 14px;color:#f1f5f9;font-size:14px}.form-group input:focus,.form-group select:focus{outline:none;border-color:#6366f1}.form-group.checkbox label{display:flex;align-items:center;gap:8px;cursor:pointer}.form-group.checkbox input{width:auto}.modal-actions{display:flex;gap:12px;margin-top:24px}.confirm-btn{flex:1;background:#6366f1;border:none;color:#fff;padding:10px 20px;border-radius:8px;font-size:14px;cursor:pointer;transition:background .2s}.confirm-btn:hover{background:#4f46e5}.learning-data{display:flex;flex-direction:column;gap:24px}.summary-cards{display:grid;grid-template-columns:repeat(6,1fr);gap:16px}.summary-card{background:#1e293b80;border:1px solid rgba(255,255,255,.1);border-radius:12px;padding:16px;display:flex;align-items:center;gap:12px}.summary-icon{font-size:28px}.summary-info{display:flex;flex-direction:column}.summary-value{color:#f1f5f9;font-size:24px;font-weight:700}.summary-label{color:#64748b;font-size:12px}.data-toolbar{display:flex;justify-content:space-between;align-items:center;gap:16px}.search-box input{background:#1e293b80;border:1px solid rgba(255,255,255,.1);border-radius:8px;padding:10px 16px;color:#f1f5f9;font-size:14px;width:300px}.search-box input:focus{outline:none;border-color:#6366f1}.search-box input::placeholder{color:#64748b}.export-btn{background:#10b98133;border:1px solid rgba(16,185,129,.3);color:#6ee7b7;padding:10px 20px;border-radius:8px;font-size:14px;cursor:pointer;transition:all .2s}.export-btn:hover{background:#10b9814d}.data-table-container{background:#1e293b80;border:1px solid rgba(255,255,255,.1);border-radius:16px;overflow:hidden}.data-table{width:100%;border-collapse:collapse}.data-table th{background:#6366f133;color:#c7d2fe;font-size:13px;font-weight:600;text-align:left;padding:14px 16px;border-bottom:1px solid rgba(255,255,255,.1)}.data-table th.sortable{cursor:pointer;-webkit-user-select:none;user-select:none}.data-table th.sortable:hover{background:#6366f14d}.data-table td{padding:14px 16px;color:#e2e8f0;font-size:14px;border-bottom:1px solid rgba(255,255,255,.05)}.data-table tbody tr:hover{background:#ffffff08}.data-table .username{font-weight:600;color:#f1f5f9}.role-badge{display:inline-block;padding:4px 10px;border-radius:20px;font-size:12px;font-weight:500}.role-badge.admin{background:#ef444433;color:#fca5a5}.role-badge.teacher{background:#3b82f633;color:#93c5fd}.role-badge.student{background:#10b98133;color:#6ee7b7}.no-data{text-align:center;padding:60px;color:#64748b}@media (max-width: 1200px){.summary-cards{grid-template-columns:repeat(3,1fr)}}@media (max-width: 768px){.summary-cards{grid-template-columns:repeat(2,1fr)}.data-toolbar{flex-direction:column}.search-box input{width:100%}.data-table-container{overflow-x:auto}.data-table{min-width:800px}}.classroom-page{min-height:100vh;background:linear-gradient(135deg,#f8fafc,#f1f5f9,#f8fafc);padding:1.5rem}.classroom-container{max-width:1200px;margin:0 auto}.classroom-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem}.classroom-header-content{flex:1}.classroom-title{font-size:2rem;font-weight:700;color:#1e293b;display:flex;align-items:center;gap:.75rem;margin-bottom:.5rem}.classroom-subtitle{color:#64748b;font-size:1rem}.classroom-content-card{background:#fff;border-radius:20px;padding:1.5rem;box-shadow:0 2px 8px #0000000f;border:1px solid #f1f5f9;margin-bottom:1.5rem}.classroom-content-card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem}.classroom-content-title{font-size:1.25rem;font-weight:600;color:#1e293b;display:flex;align-items:center;gap:.5rem}.classroom-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1.5rem}.classroom-class-card{background:#fff;border-radius:20px;padding:1.5rem;box-shadow:0 2px 8px #0000000f;border:1px solid #f1f5f9;transition:all .3s ease}.classroom-class-card:hover{transform:translateY(-4px);box-shadow:0 12px 32px #0000001a}.classroom-class-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:1rem}.classroom-class-name{font-size:1.25rem;font-weight:600;color:#1e293b}.classroom-class-teacher{font-size:.875rem;color:#64748b}.classroom-class-badge{display:inline-flex;padding:.375rem .875rem;background:#dbeafe;color:#1d4ed8;border-radius:9999px;font-size:.8rem;font-weight:600}.classroom-class-desc{font-size:.95rem;color:#64748b;margin-bottom:1rem;line-height:1.5}.classroom-class-meta{display:flex;gap:1rem;font-size:.875rem;color:#64748b;margin-bottom:1rem}.classroom-class-footer{display:flex;justify-content:space-between;align-items:center;padding-top:1rem;border-top:1px solid #f1f5f9}.classroom-class-date{font-size:.75rem;color:#94a3b8}.classroom-class-link{font-size:.875rem;color:#3b82f6;font-weight:500;cursor:pointer;transition:color .2s}.classroom-class-link:hover{color:#1d4ed8}.classroom-tasks-card{margin-bottom:1.5rem}.classroom-task-item{display:flex;align-items:center;gap:1rem;padding:1rem 1.25rem;background:linear-gradient(135deg,#eef2ff,#e0e7ff);border-radius:12px;margin-bottom:.75rem;transition:all .2s ease}.classroom-task-item:hover{transform:translate(4px)}.classroom-task-icon{font-size:1.5rem}.classroom-task-info{flex:1}.classroom-task-title{font-size:.95rem;font-weight:500;color:#1e293b}.classroom-task-meta{font-size:.8rem;color:#64748b}.classroom-task-status{padding:.375rem .875rem;border-radius:9999px;font-size:.75rem;font-weight:600}.classroom-task-status.urgent{background:#fef2f2;color:#dc2626}.classroom-task-status.today{background:#fef9c3;color:#ca8a04}.classroom-task-status.soon{background:#fef3c7;color:#d97706}.classroom-task-status.later{background:#dcfce7;color:#16a34a}.classroom-task-status.none{background:#f1f5f9;color:#64748b}.classroom-join-form{max-width:500px;margin:0 auto}.classroom-join-card{background:#fff;border-radius:24px;padding:2.5rem;box-shadow:0 10px 40px #00000014;text-align:center}.classroom-join-icon{font-size:4rem;margin-bottom:1.5rem}.classroom-join-title{font-size:1.75rem;font-weight:700;color:#1e293b;margin-bottom:.5rem}.classroom-join-desc{color:#64748b;margin-bottom:2rem}.classroom-join-input{width:100%;padding:1rem 1.25rem;border:2px solid #e2e8f0;border-radius:12px;font-size:1.125rem;text-align:center;letter-spacing:.1em;transition:all .2s ease;margin-bottom:1.5rem}.classroom-join-input:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 4px #3b82f61a}.classroom-join-input::placeholder{letter-spacing:normal;color:#94a3b8}.classroom-btn{display:inline-flex;align-items:center;gap:.5rem;padding:.75rem 1.5rem;border-radius:12px;font-weight:500;cursor:pointer;transition:all .2s ease;border:none;font-size:.95rem}.classroom-btn-primary{background:linear-gradient(135deg,#3b82f6,#2563eb);color:#fff;box-shadow:0 4px 12px #3b82f64d}.classroom-btn-primary:hover{transform:translateY(-2px);box-shadow:0 6px 16px #3b82f666}.classroom-btn-outline{background:#fff;color:#475569;border:2px solid #e2e8f0}.classroom-btn-outline:hover{border-color:#3b82f6;color:#3b82f6}.classroom-empty-state{text-align:center;padding:4rem 2rem;background:#fff;border-radius:20px;box-shadow:0 2px 8px #0000000f}.classroom-empty-icon{font-size:4rem;margin-bottom:1rem;display:block}.classroom-empty-text{font-size:1rem;color:#64748b;margin-bottom:1.5rem}.classroom-empty-link{color:#3b82f6;font-weight:500;cursor:pointer}.classroom-empty-link:hover{text-decoration:underline}.classroom-loading{display:flex;align-items:center;justify-content:center;min-height:60vh}.classroom-loading-spinner{width:3rem;height:3rem;border:3px solid #e2e8f0;border-top-color:#3b82f6;border-radius:50%;animation:spin 1s linear infinite}.classroom-loading-text{margin-left:1rem;font-size:1.125rem;color:#64748b}.join-class-page{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:2rem;position:relative;overflow:hidden}.join-class-container{width:100%;max-width:440px;position:relative;z-index:1}.back-button{display:inline-flex;align-items:center;gap:.5rem;padding:.625rem 1rem;background:#fffc;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.5);border-radius:10px;font-size:.875rem;font-weight:500;color:#475569;cursor:pointer;transition:all .3s ease;margin-bottom:1.5rem}.back-button:hover{background:#fff;color:#6366f1;transform:translate(-4px);box-shadow:0 4px 12px #00000014}.join-card{background:#ffffffe6;backdrop-filter:blur(24px);-webkit-backdrop-filter:blur(24px);border:1px solid rgba(255,255,255,.6);border-radius:24px;padding:2.5rem;box-shadow:0 20px 60px #00000014;text-align:center;animation:slideUp .5s ease-out}.join-icon-wrapper{margin-bottom:1.5rem}.join-icon{width:80px;height:80px;margin:0 auto;border-radius:24px;background:linear-gradient(135deg,#6366f1,#a855f7);display:flex;align-items:center;justify-content:center;color:#fff;box-shadow:0 12px 32px #6366f159;animation:float 3s ease-in-out infinite}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-8px)}}.join-header{margin-bottom:2rem}.join-title{font-size:1.75rem;font-weight:700;color:#0f172a;margin-bottom:.5rem;letter-spacing:-.02em}.join-subtitle{font-size:.95rem;color:#475569;line-height:1.5}.join-form{display:flex;flex-direction:column;gap:1.25rem}.input-group{text-align:left}.input-label{display:flex;align-items:center;gap:.5rem;font-size:.875rem;font-weight:600;color:#0f172a;margin-bottom:.75rem}.input-label svg{color:#6366f1}.input-wrapper{position:relative}.invite-input{width:100%;padding:1rem 1.25rem;text-align:center;font-size:1.5rem;font-weight:600;letter-spacing:.5em;background:#fafafa;border:2px solid #e2e8f0;border-radius:14px;color:#0f172a;transition:all .3s ease;caret-color:#6366f1}.invite-input::placeholder{letter-spacing:normal;font-size:1rem;font-weight:400;color:#94a3b8}.invite-input:focus{outline:none;border-color:#6366f1;background:#fff;box-shadow:0 0 0 4px #6366f11a}.invite-input.input-error{border-color:#ef4444;background:#fef2f2}.invite-input.input-success{border-color:#10b981;background:#f0fdf4}.invite-input:disabled{cursor:not-allowed;opacity:.7}.input-decoration{display:flex;justify-content:center;gap:.5rem;margin-top:1rem}.char-box{width:40px;height:48px;display:flex;align-items:center;justify-content:center;background:#fff;border:2px solid #e2e8f0;border-radius:10px;font-size:1.25rem;font-weight:700;color:#0f172a;transition:all .2s ease}.char-box.filled{border-color:#6366f1;background:linear-gradient(135deg,#faf5ff,#f3e8ff);color:#6366f1}.char-box.error{border-color:#ef4444;background:#fef2f2;color:#ef4444}.char-box.success{border-color:#10b981;background:#f0fdf4;color:#10b981}.message{display:flex;align-items:center;justify-content:center;gap:.5rem;padding:.875rem 1rem;border-radius:12px;font-size:.9rem;font-weight:500;animation:fadeIn .3s ease-out}@keyframes fadeIn{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.message-error{background:#fef2f2;color:#dc2626;border:1px solid #fecaca}.message-success{background:#f0fdf4;color:#16a34a;border:1px solid #bbf7d0}.submit-btn{display:flex;align-items:center;justify-content:center;gap:.5rem;width:100%;padding:1rem;background:linear-gradient(135deg,#6366f1,#a855f7);color:#fff;border:none;border-radius:14px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .3s ease;box-shadow:0 4px 16px #6366f14d}.submit-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 8px 24px #6366f166}.submit-btn:active:not(:disabled){transform:translateY(0)}.submit-btn:disabled{opacity:.6;cursor:not-allowed;transform:none}.submit-btn.loading{background:linear-gradient(135deg,#6366f1,#818cf8)}.submit-btn.success{background:linear-gradient(135deg,#10b981,#34d399);box-shadow:0 4px 16px #10b9814d}.spin-animation{animation:spin 1s linear infinite}.help-section{margin-top:2rem;padding-top:1.5rem;border-top:1px solid #f1f5f9}.help-item{display:flex;align-items:center;justify-content:center;gap:.5rem;font-size:.85rem;color:#64748b}.help-item svg{color:#a855f7;flex-shrink:0}.decoration-circle{position:absolute;border-radius:50%;pointer-events:none;z-index:0}.decoration-1{width:300px;height:300px;background:radial-gradient(circle,rgba(99,102,241,.1) 0%,transparent 70%);top:-100px;right:-100px}.decoration-2{width:200px;height:200px;background:radial-gradient(circle,rgba(168,85,247,.08) 0%,transparent 70%);bottom:-50px;left:-50px}.decoration-3{width:150px;height:150px;background:radial-gradient(circle,rgba(59,130,246,.06) 0%,transparent 70%);top:50%;left:-80px;transform:translateY(-50%)}.my-classes-page{min-height:100vh;padding:2rem;max-width:1200px;margin:0 auto;animation:fadeIn .5s ease-out}.page-header-section{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem;padding-bottom:1.5rem;border-bottom:1px solid #e2e8f0}.header-content{display:flex;align-items:center;gap:1rem}.header-icon{width:56px;height:56px;border-radius:16px;background:linear-gradient(135deg,#6366f1,#a855f7);display:flex;align-items:center;justify-content:center;color:#fff;box-shadow:0 8px 24px #6366f14d}.header-text{display:flex;flex-direction:column;gap:.25rem}.my-classes-page .page-title{font-size:1.75rem;font-weight:700;color:#0f172a;letter-spacing:-.02em}.my-classes-page .page-subtitle{font-size:.95rem;color:#475569}.join-class-btn{display:flex;align-items:center;gap:.5rem;padding:.75rem 1.5rem;background:linear-gradient(135deg,#6366f1,#a855f7);color:#fff;border:none;border-radius:12px;font-size:.95rem;font-weight:600;cursor:pointer;transition:all .3s ease;box-shadow:0 4px 12px #6366f14d}.join-class-btn:hover{transform:translateY(-2px);box-shadow:0 6px 20px #6366f166}.stats-overview{display:grid;grid-template-columns:repeat(3,1fr);gap:1.25rem;margin-bottom:2rem}.stat-card{background:#fffc;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border:1px solid rgba(255,255,255,.5);border-radius:16px;padding:1.25rem;display:flex;align-items:center;gap:1rem;transition:all .3s ease;box-shadow:0 4px 16px #0000000a}.stat-card:hover{transform:translateY(-4px);box-shadow:0 8px 24px #00000014}.stat-icon{width:48px;height:48px;border-radius:12px;display:flex;align-items:center;justify-content:center}.stat-card-classes .stat-icon{background:linear-gradient(135deg,#dbeafe,#bfdbfe);color:#2563eb}.stat-card-tasks .stat-icon{background:linear-gradient(135deg,#fef3c7,#fde68a);color:#d97706}.stat-card-students .stat-icon{background:linear-gradient(135deg,#dcfce7,#bbf7d0);color:#16a34a}.stat-info{display:flex;flex-direction:column}.stat-value{font-size:1.75rem;font-weight:700;color:#0f172a;line-height:1}.stat-label{font-size:.85rem;color:#64748b;margin-top:.25rem}.section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.25rem}.section-title{display:flex;align-items:center;gap:.5rem;font-size:1.125rem;font-weight:600;color:#0f172a}.section-icon{color:#6366f1}.tasks-section{background:#fffc;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border:1px solid rgba(255,255,255,.5);border-radius:20px;padding:1.5rem;margin-bottom:2rem;box-shadow:0 4px 20px #0000000a}.task-count-badge{padding:.375rem .875rem;background:linear-gradient(135deg,#fef3c7,#fde68a);color:#92400e;border-radius:20px;font-size:.8rem;font-weight:600}.tasks-list{display:flex;flex-direction:column;gap:.75rem}.task-item{display:flex;align-items:center;gap:1rem;padding:1rem 1.25rem;background:linear-gradient(135deg,#fafafa,#f5f5f5);border-radius:14px;transition:all .3s ease;cursor:pointer;border:1px solid transparent}.task-item:hover{transform:translate(6px);background:linear-gradient(135deg,#f0f9ff,#e0f2fe);border-color:#3b82f633}.task-item.task-urgent{background:linear-gradient(135deg,#fef2f2,#fee2e2);border:1px solid rgba(239,68,68,.2)}.task-item.task-urgent:hover{background:linear-gradient(135deg,#fee2e2,#fecaca)}.task-icon-wrapper{width:44px;height:44px;border-radius:12px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.task-content{flex:1;min-width:0}.task-header{display:flex;justify-content:space-between;align-items:center;gap:.75rem;margin-bottom:.375rem}.task-title{font-size:.95rem;font-weight:600;color:#0f172a;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.task-status{padding:.25rem .75rem;border-radius:20px;font-size:.75rem;font-weight:600;white-space:nowrap;flex-shrink:0}.task-status-overdue{background:#fef2f2;color:#dc2626}.task-status-today{background:#fef9c3;color:#ca8a04}.task-status-soon{background:#fef3c7;color:#d97706}.task-status-later{background:#dcfce7;color:#16a34a}.task-status-none{background:#f1f5f9;color:#64748b}.task-meta{display:flex;align-items:center;gap:.75rem}.task-class{font-size:.8rem;color:#64748b}.task-type-tag{padding:.125rem .5rem;border-radius:6px;font-size:.7rem;font-weight:600}.task-arrow{color:#94a3b8;flex-shrink:0;transition:transform .3s ease}.task-item:hover .task-arrow{transform:translate(4px);color:#6366f1}.classes-section{margin-bottom:2rem}.classes-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1.5rem}.class-card{background:#ffffffd9;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border:1px solid rgba(255,255,255,.5);border-radius:20px;padding:1.5rem;transition:all .3s ease;box-shadow:0 4px 16px #0000000a}.class-card:hover{transform:translateY(-6px);box-shadow:0 12px 32px #0000001a;border-color:#6366f133}.class-card-header{display:flex;align-items:flex-start;gap:1rem;margin-bottom:1rem}.class-avatar{width:52px;height:52px;border-radius:14px;background:linear-gradient(135deg,#6366f1,#a855f7);display:flex;align-items:center;justify-content:center;color:#fff;flex-shrink:0;box-shadow:0 4px 12px #6366f140}.class-header-info{flex:1;min-width:0}.class-name{font-size:1.125rem;font-weight:600;color:#0f172a;margin-bottom:.25rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.class-teacher{font-size:.85rem;color:#64748b;display:flex;align-items:center;gap:.5rem}.teacher-label{color:#94a3b8}.teacher-label:after{content:":"}.student-count-badge{display:flex;align-items:center;gap:.375rem;padding:.375rem .75rem;background:linear-gradient(135deg,#dbeafe,#bfdbfe);color:#1d4ed8;border-radius:20px;font-size:.8rem;font-weight:600;flex-shrink:0}.class-description{font-size:.9rem;color:#475569;line-height:1.6;margin-bottom:1rem;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.class-meta{display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:1rem}.meta-tag{display:flex;align-items:center;gap:.375rem;padding:.375rem .75rem;background:#f8fafc;border:1px solid #e2e8f0;border-radius:8px;font-size:.8rem;color:#475569;transition:all .2s ease}.class-card:hover .meta-tag{background:#f1f5f9;border-color:#cbd5e1}.class-card-footer{display:flex;justify-content:space-between;align-items:center;padding-top:1rem;border-top:1px solid #f1f5f9}.join-date{display:flex;align-items:center;gap:.375rem;font-size:.8rem;color:#94a3b8}.join-date svg{color:#10b981}.view-detail-btn{display:flex;align-items:center;gap:.25rem;padding:.5rem .875rem;background:transparent;border:1px solid #e2e8f0;border-radius:8px;font-size:.85rem;font-weight:500;color:#6366f1;cursor:pointer;transition:all .2s ease}.view-detail-btn:hover{background:#6366f1;color:#fff;border-color:#6366f1}.view-detail-btn svg{transition:transform .2s ease}.view-detail-btn:hover svg{transform:translate(2px)}.empty-state{text-align:center;padding:4rem 2rem;background:#fffc;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border:1px solid rgba(255,255,255,.5);border-radius:20px;box-shadow:0 4px 20px #0000000a}.empty-icon{width:96px;height:96px;margin:0 auto 1.5rem;border-radius:24px;background:linear-gradient(135deg,#faf5ff,#f3e8ff);display:flex;align-items:center;justify-content:center;color:#a855f7}.empty-title{font-size:1.25rem;font-weight:600;color:#0f172a;margin-bottom:.5rem}.empty-description{font-size:.95rem;color:#475569;margin-bottom:1.5rem;max-width:320px;margin-left:auto;margin-right:auto}.empty-action-btn{display:inline-flex;align-items:center;gap:.5rem;padding:.875rem 1.75rem;background:linear-gradient(135deg,#6366f1,#a855f7);color:#fff;border:none;border-radius:12px;font-size:.95rem;font-weight:600;cursor:pointer;transition:all .3s ease;box-shadow:0 4px 16px #6366f14d}.empty-action-btn:hover{transform:translateY(-2px);box-shadow:0 8px 24px #6366f166}.loading-container{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:60vh;gap:1rem}.loading-spinner{width:48px;height:48px;border:3px solid #e2e8f0;border-top-color:#6366f1;border-radius:50%;animation:spin 1s linear infinite}.loading-text{font-size:1rem;color:#64748b}@media (max-width: 1024px){.classes-grid{grid-template-columns:1fr}}@media (max-width: 768px){.classroom-page{padding:1rem}.classroom-title{font-size:1.5rem}.classroom-header{flex-direction:column;gap:1rem;align-items:flex-start}.classroom-grid{grid-template-columns:1fr}.classroom-join-card{padding:1.5rem}.join-class-page{padding:2rem 1rem 1rem;align-items:flex-start}.join-card{padding:2rem 1.5rem;border-radius:20px}.join-icon{width:64px;height:64px;border-radius:18px}.join-icon svg{width:28px;height:28px}.join-title{font-size:1.5rem}.join-subtitle{font-size:.875rem}.invite-input{font-size:1.25rem;padding:.875rem 1rem}.char-box{width:36px;height:44px;font-size:1.125rem}.submit-btn{padding:.875rem;font-size:.95rem}.decoration-circle{display:none}.my-classes-page{padding:1.25rem}.page-header-section{flex-direction:column;gap:1.25rem;align-items:flex-start}.header-content{width:100%}.join-class-btn{width:100%;justify-content:center}.stats-overview{grid-template-columns:1fr;gap:1rem}.stat-card{padding:1rem}.stat-value{font-size:1.5rem}.task-header{flex-direction:column;align-items:flex-start;gap:.5rem}.class-card-header{flex-wrap:wrap}.student-count-badge{order:-1;align-self:flex-start}.class-card-footer{flex-direction:column;gap:.75rem;align-items:flex-start}.view-detail-btn{width:100%;justify-content:center}}@media (max-width: 480px){.char-box{width:32px;height:40px;font-size:1rem;border-radius:8px}.input-decoration{gap:.375rem}.page-title{font-size:1.5rem}.header-icon{width:48px;height:48px}.header-icon svg{width:24px;height:24px}.tasks-section,.class-card,.empty-state{padding:1.25rem}.task-item{padding:.875rem 1rem}.task-icon-wrapper{width:40px;height:40px}}/*! tailwindcss v4.2.2 | MIT License | https://tailwindcss.com */@layer properties{@supports (((-webkit-hyphens:none)) and (not (margin-trim:inline))) or ((-moz-orient:inline) and (not (color:rgb(from red r g b)))){*,:before,:after,::backdrop{--tw-rotate-x:initial;--tw-rotate-y:initial;--tw-rotate-z:initial;--tw-skew-x:initial;--tw-skew-y:initial;--tw-space-y-reverse:0;--tw-space-x-reverse:0;--tw-border-style:solid;--tw-gradient-position:initial;--tw-gradient-from:#0000;--tw-gradient-via:#0000;--tw-gradient-to:#0000;--tw-gradient-stops:initial;--tw-gradient-via-stops:initial;--tw-gradient-from-position:0%;--tw-gradient-via-position:50%;--tw-gradient-to-position:100%;--tw-leading:initial;--tw-font-weight:initial;--tw-shadow:0 0 #0000;--tw-shadow-color:initial;--tw-shadow-alpha:100%;--tw-inset-shadow:0 0 #0000;--tw-inset-shadow-color:initial;--tw-inset-shadow-alpha:100%;--tw-ring-color:initial;--tw-ring-shadow:0 0 #0000;--tw-inset-ring-color:initial;--tw-inset-ring-shadow:0 0 #0000;--tw-ring-inset:initial;--tw-ring-offset-width:0px;--tw-ring-offset-color:#fff;--tw-ring-offset-shadow:0 0 #0000;--tw-outline-style:solid;--tw-blur:initial;--tw-brightness:initial;--tw-contrast:initial;--tw-grayscale:initial;--tw-hue-rotate:initial;--tw-invert:initial;--tw-opacity:initial;--tw-saturate:initial;--tw-sepia:initial;--tw-drop-shadow:initial;--tw-drop-shadow-color:initial;--tw-drop-shadow-alpha:100%;--tw-drop-shadow-size:initial;--tw-backdrop-blur:initial;--tw-backdrop-brightness:initial;--tw-backdrop-contrast:initial;--tw-backdrop-grayscale:initial;--tw-backdrop-hue-rotate:initial;--tw-backdrop-invert:initial;--tw-backdrop-opacity:initial;--tw-backdrop-saturate:initial;--tw-backdrop-sepia:initial;--tw-duration:initial;--tw-ease:initial}}}@layer theme{:root,:host{--font-sans:ui-sans-serif, system-ui, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji";--font-mono:ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;--color-red-100:oklch(93.6% .032 17.717);--color-red-600:oklch(57.7% .245 27.325);--color-red-700:oklch(50.5% .213 27.518);--color-red-800:oklch(44.4% .177 26.899);--color-orange-100:oklch(95.4% .038 75.164);--color-orange-500:oklch(70.5% .213 47.604);--color-orange-600:oklch(64.6% .222 41.116);--color-orange-700:oklch(55.3% .195 38.402);--color-amber-600:oklch(66.6% .179 58.318);--color-yellow-100:oklch(97.3% .071 103.193);--color-yellow-500:oklch(79.5% .184 86.047);--color-yellow-600:oklch(68.1% .162 75.834);--color-yellow-700:oklch(55.4% .135 66.442);--color-yellow-800:oklch(47.6% .114 61.907);--color-green-50:oklch(98.2% .018 155.826);--color-green-100:oklch(96.2% .044 156.743);--color-green-200:oklch(92.5% .084 155.995);--color-green-300:oklch(87.1% .15 154.449);--color-green-500:oklch(72.3% .219 149.579);--color-green-600:oklch(62.7% .194 149.214);--color-green-700:oklch(52.7% .154 150.069);--color-green-800:oklch(44.8% .119 151.328);--color-blue-50:oklch(97% .014 254.604);--color-blue-100:oklch(93.2% .032 255.585);--color-blue-400:oklch(70.7% .165 254.624);--color-blue-500:oklch(62.3% .214 259.815);--color-blue-600:oklch(54.6% .245 262.881);--color-blue-700:oklch(48.8% .243 264.376);--color-blue-800:oklch(42.4% .199 265.638);--color-indigo-50:oklch(96.2% .018 272.314);--color-indigo-100:oklch(93% .034 272.788);--color-indigo-500:oklch(58.5% .233 277.117);--color-indigo-600:oklch(51.1% .262 276.966);--color-indigo-700:oklch(45.7% .24 277.023);--color-indigo-800:oklch(39.8% .195 277.366);--color-indigo-900:oklch(35.9% .144 278.697);--color-purple-50:oklch(97.7% .014 308.299);--color-purple-500:oklch(62.7% .265 303.9);--color-purple-600:oklch(55.8% .288 302.321);--color-purple-900:oklch(38.1% .176 304.987);--color-pink-400:oklch(71.8% .202 349.761);--color-pink-800:oklch(45.9% .187 3.815);--color-gray-50:oklch(98.5% .002 247.839);--color-gray-100:oklch(96.7% .003 264.542);--color-gray-200:oklch(92.8% .006 264.531);--color-gray-300:oklch(87.2% .01 258.338);--color-gray-400:oklch(70.7% .022 261.325);--color-gray-500:oklch(55.1% .027 264.364);--color-gray-600:oklch(44.6% .03 256.802);--color-gray-700:oklch(37.3% .034 259.733);--color-gray-800:oklch(27.8% .033 256.848);--color-black:#000;--color-white:#fff;--spacing:.25rem;--container-md:28rem;--container-lg:32rem;--container-2xl:42rem;--container-4xl:56rem;--container-7xl:80rem;--text-xs:.75rem;--text-xs--line-height:calc(1 / .75);--text-sm:.875rem;--text-sm--line-height:calc(1.25 / .875);--text-base:1rem;--text-base--line-height: 1.5 ;--text-lg:1.125rem;--text-lg--line-height:calc(1.75 / 1.125);--text-xl:1.25rem;--text-xl--line-height:calc(1.75 / 1.25);--text-2xl:1.5rem;--text-2xl--line-height:calc(2 / 1.5);--text-3xl:1.875rem;--text-3xl--line-height: 1.2 ;--text-4xl:2.25rem;--text-4xl--line-height:calc(2.5 / 2.25);--text-5xl:3rem;--text-5xl--line-height:1;--font-weight-medium:500;--font-weight-semibold:600;--font-weight-bold:700;--leading-relaxed:1.625;--radius-sm:.25rem;--radius-md:.375rem;--radius-lg:.5rem;--radius-xl:.75rem;--radius-2xl:1rem;--shadow-sm:0 1px 3px 0 #0000001a, 0 1px 2px -1px #0000001a;--shadow-md:0 4px 6px -1px #0000001a, 0 2px 4px -2px #0000001a;--shadow-lg:0 10px 15px -3px #0000001a, 0 4px 6px -4px #0000001a;--shadow-xl:0 20px 25px -5px #0000001a, 0 8px 10px -6px #0000001a;--ease-out:cubic-bezier(0, 0, .2, 1);--animate-spin:spin 1s linear infinite;--animate-pulse:pulse 2s cubic-bezier(.4, 0, .6, 1) infinite;--animate-bounce:bounce 1s infinite;--blur-lg:16px;--default-transition-duration:.15s;--default-transition-timing-function:cubic-bezier(.4, 0, .2, 1);--default-font-family:var(--font-sans);--default-mono-font-family:var(--font-mono)}}@layer base{*,:after,:before,::backdrop{box-sizing:border-box;border:0 solid;margin:0;padding:0}::file-selector-button{box-sizing:border-box;border:0 solid;margin:0;padding:0}html,:host{-webkit-text-size-adjust:100%;-moz-tab-size:4;tab-size:4;line-height:1.5;font-family:var(--default-font-family,ui-sans-serif, system-ui, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji");font-feature-settings:var(--default-font-feature-settings,normal);font-variation-settings:var(--default-font-variation-settings,normal);-webkit-tap-highlight-color:transparent}hr{height:0;color:inherit;border-top-width:1px}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;-webkit-text-decoration:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,samp,pre{font-family:var(--default-mono-font-family,ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace);font-feature-settings:var(--default-mono-font-feature-settings,normal);font-variation-settings:var(--default-mono-font-variation-settings,normal);font-size:1em}small{font-size:80%}sub,sup{vertical-align:baseline;font-size:75%;line-height:0;position:relative}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}:-moz-focusring{outline:auto}progress{vertical-align:baseline}summary{display:list-item}ol,ul,menu{list-style:none}img,svg,video,canvas,audio,iframe,embed,object{vertical-align:middle;display:block}img,video{max-width:100%;height:auto}button,input,select,optgroup,textarea{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}::file-selector-button{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}:where(select:is([multiple],[size])) optgroup{font-weight:bolder}:where(select:is([multiple],[size])) optgroup option{padding-inline-start:20px}::file-selector-button{margin-inline-end:4px}::placeholder{opacity:1}@supports (not ((-webkit-appearance:-apple-pay-button))) or (contain-intrinsic-size:1px){::placeholder{color:currentColor}@supports (color:color-mix(in lab,red,red)){::placeholder{color:color-mix(in oklab,currentcolor 50%,transparent)}}}textarea{resize:vertical}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-date-and-time-value{min-height:1lh;text-align:inherit}::-webkit-datetime-edit{display:inline-flex}::-webkit-datetime-edit-fields-wrapper{padding:0}::-webkit-datetime-edit{padding-block:0}::-webkit-datetime-edit-year-field{padding-block:0}::-webkit-datetime-edit-month-field{padding-block:0}::-webkit-datetime-edit-day-field{padding-block:0}::-webkit-datetime-edit-hour-field{padding-block:0}::-webkit-datetime-edit-minute-field{padding-block:0}::-webkit-datetime-edit-second-field{padding-block:0}::-webkit-datetime-edit-millisecond-field{padding-block:0}::-webkit-datetime-edit-meridiem-field{padding-block:0}::-webkit-calendar-picker-indicator{line-height:1}:-moz-ui-invalid{box-shadow:none}button,input:where([type=button],[type=reset],[type=submit]){-webkit-appearance:button;-moz-appearance:button;appearance:button}::file-selector-button{-webkit-appearance:button;-moz-appearance:button;appearance:button}::-webkit-inner-spin-button{height:auto}::-webkit-outer-spin-button{height:auto}[hidden]:where(:not([hidden=until-found])){display:none!important}}@layer components;@layer utilities{.absolute{position:absolute}.fixed{position:fixed}.relative{position:relative}.sticky{position:sticky}.inset-0{inset:calc(var(--spacing) * 0)}.start{inset-inline-start:var(--spacing)}.end{inset-inline-end:var(--spacing)}.top-0{top:calc(var(--spacing) * 0)}.z-10{z-index:10}.z-50{z-index:50}.container{width:100%}@media (min-width:40rem){.container{max-width:40rem}}@media (min-width:48rem){.container{max-width:48rem}}@media (min-width:64rem){.container{max-width:64rem}}@media (min-width:80rem){.container{max-width:80rem}}@media (min-width:96rem){.container{max-width:96rem}}.mx-4{margin-inline:calc(var(--spacing) * 4)}.mx-auto{margin-inline:auto}.my-4{margin-block:calc(var(--spacing) * 4)}.mt-1{margin-top:calc(var(--spacing) * 1)}.mt-2{margin-top:calc(var(--spacing) * 2)}.mt-3{margin-top:calc(var(--spacing) * 3)}.mt-4{margin-top:calc(var(--spacing) * 4)}.mt-6{margin-top:calc(var(--spacing) * 6)}.mt-12{margin-top:calc(var(--spacing) * 12)}.mr-1{margin-right:calc(var(--spacing) * 1)}.mr-2{margin-right:calc(var(--spacing) * 2)}.mr-3{margin-right:calc(var(--spacing) * 3)}.mb-1{margin-bottom:calc(var(--spacing) * 1)}.mb-2{margin-bottom:calc(var(--spacing) * 2)}.mb-3{margin-bottom:calc(var(--spacing) * 3)}.mb-4{margin-bottom:calc(var(--spacing) * 4)}.mb-6{margin-bottom:calc(var(--spacing) * 6)}.mb-8{margin-bottom:calc(var(--spacing) * 8)}.mb-12{margin-bottom:calc(var(--spacing) * 12)}.ml-2{margin-left:calc(var(--spacing) * 2)}.ml-auto{margin-left:auto}.line-clamp-2{-webkit-line-clamp:2;-webkit-box-orient:vertical;display:-webkit-box;overflow:hidden}.block{display:block}.flex{display:flex}.grid{display:grid}.hidden{display:none}.inline{display:inline}.inline-flex{display:inline-flex}.h-0\.5{height:calc(var(--spacing) * .5)}.h-1\.5{height:calc(var(--spacing) * 1.5)}.h-1\/2{height:50%}.h-2{height:calc(var(--spacing) * 2)}.h-3{height:calc(var(--spacing) * 3)}.h-4{height:calc(var(--spacing) * 4)}.h-5{height:calc(var(--spacing) * 5)}.h-6{height:calc(var(--spacing) * 6)}.h-8{height:calc(var(--spacing) * 8)}.h-10{height:calc(var(--spacing) * 10)}.h-12{height:calc(var(--spacing) * 12)}.h-16{height:calc(var(--spacing) * 16)}.h-20{height:calc(var(--spacing) * 20)}.h-24{height:calc(var(--spacing) * 24)}.h-full{height:100%}.h-screen{height:100vh}.max-h-60{max-height:calc(var(--spacing) * 60)}.max-h-\[90vh\]{max-height:90vh}.min-h-\[60vh\]{min-height:60vh}.min-h-screen{min-height:100vh}.w-1\/2{width:50%}.w-2{width:calc(var(--spacing) * 2)}.w-3{width:calc(var(--spacing) * 3)}.w-4{width:calc(var(--spacing) * 4)}.w-5{width:calc(var(--spacing) * 5)}.w-6{width:calc(var(--spacing) * 6)}.w-8{width:calc(var(--spacing) * 8)}.w-10{width:calc(var(--spacing) * 10)}.w-12{width:calc(var(--spacing) * 12)}.w-16{width:calc(var(--spacing) * 16)}.w-20{width:calc(var(--spacing) * 20)}.w-24{width:calc(var(--spacing) * 24)}.w-32{width:calc(var(--spacing) * 32)}.w-full{width:100%}.max-w-2xl{max-width:var(--container-2xl)}.max-w-4xl{max-width:var(--container-4xl)}.max-w-7xl{max-width:var(--container-7xl)}.max-w-\[70\%\]{max-width:70%}.max-w-lg{max-width:var(--container-lg)}.max-w-md{max-width:var(--container-md)}.min-w-\[200px\]{min-width:200px}.flex-1{flex:1}.-rotate-90{rotate:-90deg}.transform{transform:var(--tw-rotate-x,) var(--tw-rotate-y,) var(--tw-rotate-z,) var(--tw-skew-x,) var(--tw-skew-y,)}.animate-bounce{animation:var(--animate-bounce)}.animate-pulse{animation:var(--animate-pulse)}.animate-spin{animation:var(--animate-spin)}.cursor-pointer{cursor:pointer}.grid-cols-1{grid-template-columns:repeat(1,minmax(0,1fr))}.grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.flex-col{flex-direction:column}.flex-wrap{flex-wrap:wrap}.items-center{align-items:center}.items-start{align-items:flex-start}.justify-between{justify-content:space-between}.justify-center{justify-content:center}.justify-end{justify-content:flex-end}.justify-start{justify-content:flex-start}.gap-1{gap:calc(var(--spacing) * 1)}.gap-2{gap:calc(var(--spacing) * 2)}.gap-3{gap:calc(var(--spacing) * 3)}.gap-4{gap:calc(var(--spacing) * 4)}.gap-6{gap:calc(var(--spacing) * 6)}:where(.space-y-2>:not(:last-child)){--tw-space-y-reverse:0;margin-block-start:calc(calc(var(--spacing) * 2) * var(--tw-space-y-reverse));margin-block-end:calc(calc(var(--spacing) * 2) * calc(1 - var(--tw-space-y-reverse)))}:where(.space-y-3>:not(:last-child)){--tw-space-y-reverse:0;margin-block-start:calc(calc(var(--spacing) * 3) * var(--tw-space-y-reverse));margin-block-end:calc(calc(var(--spacing) * 3) * calc(1 - var(--tw-space-y-reverse)))}:where(.space-y-4>:not(:last-child)){--tw-space-y-reverse:0;margin-block-start:calc(calc(var(--spacing) * 4) * var(--tw-space-y-reverse));margin-block-end:calc(calc(var(--spacing) * 4) * calc(1 - var(--tw-space-y-reverse)))}:where(.space-y-6>:not(:last-child)){--tw-space-y-reverse:0;margin-block-start:calc(calc(var(--spacing) * 6) * var(--tw-space-y-reverse));margin-block-end:calc(calc(var(--spacing) * 6) * calc(1 - var(--tw-space-y-reverse)))}:where(.-space-x-2>:not(:last-child)){--tw-space-x-reverse:0;margin-inline-start:calc(calc(var(--spacing) * -2) * var(--tw-space-x-reverse));margin-inline-end:calc(calc(var(--spacing) * -2) * calc(1 - var(--tw-space-x-reverse)))}.overflow-hidden{overflow:hidden}.overflow-x-auto{overflow-x:auto}.overflow-y-auto{overflow-y:auto}.rounded{border-radius:.25rem}.rounded-2xl{border-radius:var(--radius-2xl)}.rounded-full{border-radius:3.40282e38px}.rounded-lg{border-radius:var(--radius-lg)}.rounded-xl{border-radius:var(--radius-xl)}.rounded-br-md{border-bottom-right-radius:var(--radius-md)}.rounded-bl-md{border-bottom-left-radius:var(--radius-md)}.border{border-style:var(--tw-border-style);border-width:1px}.border-2{border-style:var(--tw-border-style);border-width:2px}.border-t{border-top-style:var(--tw-border-style);border-top-width:1px}.border-b{border-bottom-style:var(--tw-border-style);border-bottom-width:1px}.border-b-2{border-bottom-style:var(--tw-border-style);border-bottom-width:2px}.border-blue-500{border-color:var(--color-blue-500)}.border-blue-600{border-color:var(--color-blue-600)}.border-gray-100{border-color:var(--color-gray-100)}.border-gray-200{border-color:var(--color-gray-200)}.border-gray-300{border-color:var(--color-gray-300)}.border-green-200{border-color:var(--color-green-200)}.border-indigo-100{border-color:var(--color-indigo-100)}.border-indigo-500{border-color:var(--color-indigo-500)}.border-indigo-600{border-color:var(--color-indigo-600)}.border-transparent{border-color:#0000}.border-white\/20{border-color:#fff3}@supports (color:color-mix(in lab,red,red)){.border-white\/20{border-color:color-mix(in oklab,var(--color-white) 20%,transparent)}}.border-white\/30{border-color:#ffffff4d}@supports (color:color-mix(in lab,red,red)){.border-white\/30{border-color:color-mix(in oklab,var(--color-white) 30%,transparent)}}.bg-amber-600{background-color:var(--color-amber-600)}.bg-black\/50{background-color:#00000080}@supports (color:color-mix(in lab,red,red)){.bg-black\/50{background-color:color-mix(in oklab,var(--color-black) 50%,transparent)}}.bg-blue-50{background-color:var(--color-blue-50)}.bg-blue-100{background-color:var(--color-blue-100)}.bg-blue-500{background-color:var(--color-blue-500)}.bg-gray-50{background-color:var(--color-gray-50)}.bg-gray-100{background-color:var(--color-gray-100)}.bg-gray-200{background-color:var(--color-gray-200)}.bg-gray-300{background-color:var(--color-gray-300)}.bg-gray-400{background-color:var(--color-gray-400)}.bg-green-100{background-color:var(--color-green-100)}.bg-green-300{background-color:var(--color-green-300)}.bg-green-500{background-color:var(--color-green-500)}.bg-indigo-100{background-color:var(--color-indigo-100)}.bg-indigo-500{background-color:var(--color-indigo-500)}.bg-orange-100{background-color:var(--color-orange-100)}.bg-purple-500{background-color:var(--color-purple-500)}.bg-red-100{background-color:var(--color-red-100)}.bg-white{background-color:var(--color-white)}.bg-white\/10{background-color:#ffffff1a}@supports (color:color-mix(in lab,red,red)){.bg-white\/10{background-color:color-mix(in oklab,var(--color-white) 10%,transparent)}}.bg-white\/80{background-color:#fffc}@supports (color:color-mix(in lab,red,red)){.bg-white\/80{background-color:color-mix(in oklab,var(--color-white) 80%,transparent)}}.bg-yellow-100{background-color:var(--color-yellow-100)}.bg-yellow-500{background-color:var(--color-yellow-500)}.bg-gradient-to-br{--tw-gradient-position:to bottom right in oklab;background-image:linear-gradient(var(--tw-gradient-stops))}.bg-gradient-to-r{--tw-gradient-position:to right in oklab;background-image:linear-gradient(var(--tw-gradient-stops))}.from-blue-500{--tw-gradient-from:var(--color-blue-500);--tw-gradient-stops:var(--tw-gradient-via-stops,var(--tw-gradient-position), var(--tw-gradient-from) var(--tw-gradient-from-position), var(--tw-gradient-to) var(--tw-gradient-to-position))}.from-green-50{--tw-gradient-from:var(--color-green-50);--tw-gradient-stops:var(--tw-gradient-via-stops,var(--tw-gradient-position), var(--tw-gradient-from) var(--tw-gradient-from-position), var(--tw-gradient-to) var(--tw-gradient-to-position))}.from-green-500{--tw-gradient-from:var(--color-green-500);--tw-gradient-stops:var(--tw-gradient-via-stops,var(--tw-gradient-position), var(--tw-gradient-from) var(--tw-gradient-from-position), var(--tw-gradient-to) var(--tw-gradient-to-position))}.from-indigo-50{--tw-gradient-from:var(--color-indigo-50);--tw-gradient-stops:var(--tw-gradient-via-stops,var(--tw-gradient-position), var(--tw-gradient-from) var(--tw-gradient-from-position), var(--tw-gradient-to) var(--tw-gradient-to-position))}.from-indigo-500{--tw-gradient-from:var(--color-indigo-500);--tw-gradient-stops:var(--tw-gradient-via-stops,var(--tw-gradient-position), var(--tw-gradient-from) var(--tw-gradient-from-position), var(--tw-gradient-to) var(--tw-gradient-to-position))}.from-indigo-900{--tw-gradient-from:var(--color-indigo-900);--tw-gradient-stops:var(--tw-gradient-via-stops,var(--tw-gradient-position), var(--tw-gradient-from) var(--tw-gradient-from-position), var(--tw-gradient-to) var(--tw-gradient-to-position))}.from-orange-500{--tw-gradient-from:var(--color-orange-500);--tw-gradient-stops:var(--tw-gradient-via-stops,var(--tw-gradient-position), var(--tw-gradient-from) var(--tw-gradient-from-position), var(--tw-gradient-to) var(--tw-gradient-to-position))}.from-pink-400{--tw-gradient-from:var(--color-pink-400);--tw-gradient-stops:var(--tw-gradient-via-stops,var(--tw-gradient-position), var(--tw-gradient-from) var(--tw-gradient-from-position), var(--tw-gradient-to) var(--tw-gradient-to-position))}.from-purple-500{--tw-gradient-from:var(--color-purple-500);--tw-gradient-stops:var(--tw-gradient-via-stops,var(--tw-gradient-position), var(--tw-gradient-from) var(--tw-gradient-from-position), var(--tw-gradient-to) var(--tw-gradient-to-position))}.via-purple-900{--tw-gradient-via:var(--color-purple-900);--tw-gradient-via-stops:var(--tw-gradient-position), var(--tw-gradient-from) var(--tw-gradient-from-position), var(--tw-gradient-via) var(--tw-gradient-via-position), var(--tw-gradient-to) var(--tw-gradient-to-position);--tw-gradient-stops:var(--tw-gradient-via-stops)}.to-blue-50{--tw-gradient-to:var(--color-blue-50);--tw-gradient-stops:var(--tw-gradient-via-stops,var(--tw-gradient-position), var(--tw-gradient-from) var(--tw-gradient-from-position), var(--tw-gradient-to) var(--tw-gradient-to-position))}.to-blue-600{--tw-gradient-to:var(--color-blue-600);--tw-gradient-stops:var(--tw-gradient-via-stops,var(--tw-gradient-position), var(--tw-gradient-from) var(--tw-gradient-from-position), var(--tw-gradient-to) var(--tw-gradient-to-position))}.to-green-600{--tw-gradient-to:var(--color-green-600);--tw-gradient-stops:var(--tw-gradient-via-stops,var(--tw-gradient-position), var(--tw-gradient-from) var(--tw-gradient-from-position), var(--tw-gradient-to) var(--tw-gradient-to-position))}.to-orange-600{--tw-gradient-to:var(--color-orange-600);--tw-gradient-stops:var(--tw-gradient-via-stops,var(--tw-gradient-position), var(--tw-gradient-from) var(--tw-gradient-from-position), var(--tw-gradient-to) var(--tw-gradient-to-position))}.to-pink-800{--tw-gradient-to:var(--color-pink-800);--tw-gradient-stops:var(--tw-gradient-via-stops,var(--tw-gradient-position), var(--tw-gradient-from) var(--tw-gradient-from-position), var(--tw-gradient-to) var(--tw-gradient-to-position))}.to-purple-50{--tw-gradient-to:var(--color-purple-50);--tw-gradient-stops:var(--tw-gradient-via-stops,var(--tw-gradient-position), var(--tw-gradient-from) var(--tw-gradient-from-position), var(--tw-gradient-to) var(--tw-gradient-to-position))}.to-purple-500{--tw-gradient-to:var(--color-purple-500);--tw-gradient-stops:var(--tw-gradient-via-stops,var(--tw-gradient-position), var(--tw-gradient-from) var(--tw-gradient-from-position), var(--tw-gradient-to) var(--tw-gradient-to-position))}.to-purple-600{--tw-gradient-to:var(--color-purple-600);--tw-gradient-stops:var(--tw-gradient-via-stops,var(--tw-gradient-position), var(--tw-gradient-from) var(--tw-gradient-from-position), var(--tw-gradient-to) var(--tw-gradient-to-position))}.bg-clip-text{-webkit-background-clip:text;background-clip:text}.object-contain{object-fit:contain}.object-cover{object-fit:cover}.p-1{padding:calc(var(--spacing) * 1)}.p-2{padding:calc(var(--spacing) * 2)}.p-3{padding:calc(var(--spacing) * 3)}.p-4{padding:calc(var(--spacing) * 4)}.p-6{padding:calc(var(--spacing) * 6)}.p-8{padding:calc(var(--spacing) * 8)}.p-12{padding:calc(var(--spacing) * 12)}.px-2{padding-inline:calc(var(--spacing) * 2)}.px-2\.5{padding-inline:calc(var(--spacing) * 2.5)}.px-3{padding-inline:calc(var(--spacing) * 3)}.px-4{padding-inline:calc(var(--spacing) * 4)}.px-5{padding-inline:calc(var(--spacing) * 5)}.px-6{padding-inline:calc(var(--spacing) * 6)}.px-7{padding-inline:calc(var(--spacing) * 7)}.px-8{padding-inline:calc(var(--spacing) * 8)}.py-0\.5{padding-block:calc(var(--spacing) * .5)}.py-1{padding-block:calc(var(--spacing) * 1)}.py-2{padding-block:calc(var(--spacing) * 2)}.py-2\.5{padding-block:calc(var(--spacing) * 2.5)}.py-3{padding-block:calc(var(--spacing) * 3)}.py-4{padding-block:calc(var(--spacing) * 4)}.py-12{padding-block:calc(var(--spacing) * 12)}.pb-3{padding-bottom:calc(var(--spacing) * 3)}.text-center{text-align:center}.text-left{text-align:left}.text-right{text-align:right}.text-2xl{font-size:var(--text-2xl);line-height:var(--tw-leading,var(--text-2xl--line-height))}.text-3xl{font-size:var(--text-3xl);line-height:var(--tw-leading,var(--text-3xl--line-height))}.text-4xl{font-size:var(--text-4xl);line-height:var(--tw-leading,var(--text-4xl--line-height))}.text-5xl{font-size:var(--text-5xl);line-height:var(--tw-leading,var(--text-5xl--line-height))}.text-base{font-size:var(--text-base);line-height:var(--tw-leading,var(--text-base--line-height))}.text-lg{font-size:var(--text-lg);line-height:var(--tw-leading,var(--text-lg--line-height))}.text-sm{font-size:var(--text-sm);line-height:var(--tw-leading,var(--text-sm--line-height))}.text-xl{font-size:var(--text-xl);line-height:var(--tw-leading,var(--text-xl--line-height))}.text-xs{font-size:var(--text-xs);line-height:var(--tw-leading,var(--text-xs--line-height))}.leading-relaxed{--tw-leading:var(--leading-relaxed);line-height:var(--leading-relaxed)}.font-bold{--tw-font-weight:var(--font-weight-bold);font-weight:var(--font-weight-bold)}.font-medium{--tw-font-weight:var(--font-weight-medium);font-weight:var(--font-weight-medium)}.font-semibold{--tw-font-weight:var(--font-weight-semibold);font-weight:var(--font-weight-semibold)}.whitespace-pre-wrap{white-space:pre-wrap}.text-\[var\(--reading\)\]{color:var(--reading)}.text-\[var\(--speaking\)\]{color:var(--speaking)}.text-\[var\(--writing\)\]{color:var(--writing)}.text-blue-100{color:var(--color-blue-100)}.text-blue-500{color:var(--color-blue-500)}.text-blue-600{color:var(--color-blue-600)}.text-blue-700{color:var(--color-blue-700)}.text-blue-800{color:var(--color-blue-800)}.text-gray-400{color:var(--color-gray-400)}.text-gray-500{color:var(--color-gray-500)}.text-gray-600{color:var(--color-gray-600)}.text-gray-700{color:var(--color-gray-700)}.text-gray-800{color:var(--color-gray-800)}.text-green-500{color:var(--color-green-500)}.text-green-600{color:var(--color-green-600)}.text-green-700{color:var(--color-green-700)}.text-green-800{color:var(--color-green-800)}.text-indigo-600{color:var(--color-indigo-600)}.text-indigo-700{color:var(--color-indigo-700)}.text-indigo-900{color:var(--color-indigo-900)}.text-orange-700{color:var(--color-orange-700)}.text-purple-600{color:var(--color-purple-600)}.text-red-600{color:var(--color-red-600)}.text-red-700{color:var(--color-red-700)}.text-red-800{color:var(--color-red-800)}.text-transparent{color:#0000}.text-white{color:var(--color-white)}.text-white\/40{color:#fff6}@supports (color:color-mix(in lab,red,red)){.text-white\/40{color:color-mix(in oklab,var(--color-white) 40%,transparent)}}.text-white\/60{color:#fff9}@supports (color:color-mix(in lab,red,red)){.text-white\/60{color:color-mix(in oklab,var(--color-white) 60%,transparent)}}.text-white\/80{color:#fffc}@supports (color:color-mix(in lab,red,red)){.text-white\/80{color:color-mix(in oklab,var(--color-white) 80%,transparent)}}.text-yellow-500{color:var(--color-yellow-500)}.text-yellow-600{color:var(--color-yellow-600)}.text-yellow-700{color:var(--color-yellow-700)}.text-yellow-800{color:var(--color-yellow-800)}.underline{text-decoration-line:underline}.decoration-1{text-decoration-thickness:1px}.decoration-2{text-decoration-thickness:2px}.decoration-3{text-decoration-thickness:3px}.shadow{--tw-shadow:0 1px 3px 0 var(--tw-shadow-color,#0000001a), 0 1px 2px -1px var(--tw-shadow-color,#0000001a);box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}.shadow-2xl{--tw-shadow:0 25px 50px -12px var(--tw-shadow-color,#00000040);box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}.shadow-lg{--tw-shadow:0 10px 15px -3px var(--tw-shadow-color,#0000001a), 0 4px 6px -4px var(--tw-shadow-color,#0000001a);box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}.shadow-md{--tw-shadow:0 4px 6px -1px var(--tw-shadow-color,#0000001a), 0 2px 4px -2px var(--tw-shadow-color,#0000001a);box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}.shadow-sm{--tw-shadow:0 1px 3px 0 var(--tw-shadow-color,#0000001a), 0 1px 2px -1px var(--tw-shadow-color,#0000001a);box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}.shadow-xl{--tw-shadow:0 20px 25px -5px var(--tw-shadow-color,#0000001a), 0 8px 10px -6px var(--tw-shadow-color,#0000001a);box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}.outline{outline-style:var(--tw-outline-style);outline-width:1px}.blur{--tw-blur:blur(8px);filter:var(--tw-blur,) var(--tw-brightness,) var(--tw-contrast,) var(--tw-grayscale,) var(--tw-hue-rotate,) var(--tw-invert,) var(--tw-saturate,) var(--tw-sepia,) var(--tw-drop-shadow,)}.filter{filter:var(--tw-blur,) var(--tw-brightness,) var(--tw-contrast,) var(--tw-grayscale,) var(--tw-hue-rotate,) var(--tw-invert,) var(--tw-saturate,) var(--tw-sepia,) var(--tw-drop-shadow,)}.backdrop-blur{--tw-backdrop-blur:blur(8px);-webkit-backdrop-filter:var(--tw-backdrop-blur,) var(--tw-backdrop-brightness,) var(--tw-backdrop-contrast,) var(--tw-backdrop-grayscale,) var(--tw-backdrop-hue-rotate,) var(--tw-backdrop-invert,) var(--tw-backdrop-opacity,) var(--tw-backdrop-saturate,) var(--tw-backdrop-sepia,);backdrop-filter:var(--tw-backdrop-blur,) var(--tw-backdrop-brightness,) var(--tw-backdrop-contrast,) var(--tw-backdrop-grayscale,) var(--tw-backdrop-hue-rotate,) var(--tw-backdrop-invert,) var(--tw-backdrop-opacity,) var(--tw-backdrop-saturate,) var(--tw-backdrop-sepia,)}.backdrop-blur-lg{--tw-backdrop-blur:blur(var(--blur-lg));-webkit-backdrop-filter:var(--tw-backdrop-blur,) var(--tw-backdrop-brightness,) var(--tw-backdrop-contrast,) var(--tw-backdrop-grayscale,) var(--tw-backdrop-hue-rotate,) var(--tw-backdrop-invert,) var(--tw-backdrop-opacity,) var(--tw-backdrop-saturate,) var(--tw-backdrop-sepia,);backdrop-filter:var(--tw-backdrop-blur,) var(--tw-backdrop-brightness,) var(--tw-backdrop-contrast,) var(--tw-backdrop-grayscale,) var(--tw-backdrop-hue-rotate,) var(--tw-backdrop-invert,) var(--tw-backdrop-opacity,) var(--tw-backdrop-saturate,) var(--tw-backdrop-sepia,)}.transition{transition-property:color,background-color,border-color,outline-color,text-decoration-color,fill,stroke,--tw-gradient-from,--tw-gradient-via,--tw-gradient-to,opacity,box-shadow,transform,translate,scale,rotate,filter,-webkit-backdrop-filter,backdrop-filter,display,content-visibility,overlay,pointer-events;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function));transition-duration:var(--tw-duration,var(--default-transition-duration))}.transition-all{transition-property:all;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function));transition-duration:var(--tw-duration,var(--default-transition-duration))}.transition-colors{transition-property:color,background-color,border-color,outline-color,text-decoration-color,fill,stroke,--tw-gradient-from,--tw-gradient-via,--tw-gradient-to;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function));transition-duration:var(--tw-duration,var(--default-transition-duration))}.transition-shadow{transition-property:box-shadow;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function));transition-duration:var(--tw-duration,var(--default-transition-duration))}.duration-200{--tw-duration:.2s;transition-duration:.2s}.duration-500{--tw-duration:.5s;transition-duration:.5s}.ease-out{--tw-ease:var(--ease-out);transition-timing-function:var(--ease-out)}@media (hover:hover){.hover\:border-blue-400:hover{border-color:var(--color-blue-400)}.hover\:bg-blue-50:hover{background-color:var(--color-blue-50)}.hover\:bg-blue-600:hover{background-color:var(--color-blue-600)}.hover\:bg-gray-50:hover{background-color:var(--color-gray-50)}.hover\:bg-gray-100:hover{background-color:var(--color-gray-100)}.hover\:bg-gray-300:hover{background-color:var(--color-gray-300)}.hover\:bg-indigo-50:hover{background-color:var(--color-indigo-50)}.hover\:bg-white\/15:hover{background-color:#ffffff26}@supports (color:color-mix(in lab,red,red)){.hover\:bg-white\/15:hover{background-color:color-mix(in oklab,var(--color-white) 15%,transparent)}}.hover\:bg-white\/20:hover{background-color:#fff3}@supports (color:color-mix(in lab,red,red)){.hover\:bg-white\/20:hover{background-color:color-mix(in oklab,var(--color-white) 20%,transparent)}}.hover\:bg-white\/90:hover{background-color:#ffffffe6}@supports (color:color-mix(in lab,red,red)){.hover\:bg-white\/90:hover{background-color:color-mix(in oklab,var(--color-white) 90%,transparent)}}.hover\:text-gray-800:hover{color:var(--color-gray-800)}.hover\:text-indigo-800:hover{color:var(--color-indigo-800)}.hover\:text-red-600:hover{color:var(--color-red-600)}.hover\:text-red-800:hover{color:var(--color-red-800)}.hover\:shadow-2xl:hover{--tw-shadow:0 25px 50px -12px var(--tw-shadow-color,#00000040);box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}.hover\:shadow-lg:hover{--tw-shadow:0 10px 15px -3px var(--tw-shadow-color,#0000001a), 0 4px 6px -4px var(--tw-shadow-color,#0000001a);box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}.hover\:shadow-md:hover{--tw-shadow:0 4px 6px -1px var(--tw-shadow-color,#0000001a), 0 2px 4px -2px var(--tw-shadow-color,#0000001a);box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}}.focus\:border-transparent:focus{border-color:#0000}.focus\:ring-2:focus{--tw-ring-shadow:var(--tw-ring-inset,) 0 0 0 calc(2px + var(--tw-ring-offset-width)) var(--tw-ring-color,currentcolor);box-shadow:var(--tw-inset-shadow),var(--tw-inset-ring-shadow),var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}.focus\:ring-blue-500:focus{--tw-ring-color:var(--color-blue-500)}.focus\:ring-indigo-500:focus{--tw-ring-color:var(--color-indigo-500)}.focus\:outline-none:focus{--tw-outline-style:none;outline-style:none}.disabled\:border-gray-300:disabled{border-color:var(--color-gray-300)}.disabled\:bg-gray-100:disabled{background-color:var(--color-gray-100)}.disabled\:bg-gray-300:disabled{background-color:var(--color-gray-300)}.disabled\:text-gray-300:disabled{color:var(--color-gray-300)}.disabled\:opacity-50:disabled{opacity:.5}@media (min-width:40rem){.sm\:grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.sm\:flex-row{flex-direction:row}}@media (min-width:48rem){.md\:grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.md\:grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}.md\:grid-cols-4{grid-template-columns:repeat(4,minmax(0,1fr))}}@media (min-width:64rem){.lg\:col-span-2{grid-column:span 2/span 2}.lg\:grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.lg\:grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}.lg\:grid-cols-4{grid-template-columns:repeat(4,minmax(0,1fr))}}}:root{--primary-gradient:linear-gradient(135deg, #6366f1 0%, #a855f7 100%);--primary:#6366f1;--primary-light:#a855f7;--primary-dark:#4c1d95;--speaking-gradient:linear-gradient(135deg, #f093fb 0%, #f5576c 100%);--speaking:#10b981;--speaking-light:#6ee7b7;--speaking-dark:#059669;--gradient-speaking:linear-gradient(135deg, #10b981 0%, #34d399 100%);--reading-gradient:linear-gradient(135deg, #4facfe 0%, #00f2fe 100%);--reading:#3b82f6;--reading-dark:#1d4ed8;--writing-gradient:linear-gradient(135deg, #43e97b 0%, #38f9d7 100%);--writing:#f59e0b;--writing-light:#fcd34d;--writing-dark:#d97706;--gradient-writing:linear-gradient(135deg, #f59e0b 0%, #fbbf24 100%);--success:#10b981;--warning:#f59e0b;--error:#ef4444;--info:#3b82f6;--bg-primary:#fff;--bg-secondary:#f8fafc;--bg-tertiary:#f1f5f9;--bg-elevated:#fff;--text-primary:#0f172a;--text-secondary:#475569;--text-tertiary:#64748b;--text-inverse:#fff;--border-subtle:#e2e8f0;--border-default:#cbd5e1;--border-strong:#94a3b8;--border:#e2e8f0;--gradient-primary:linear-gradient(135deg, #6366f1 0%, #a855f7 100%);--gradient-reading:linear-gradient(135deg, #3b82f6 0%, #60a5fa 100%);--text-muted:#64748b;--surface-hover:#f1f5f9;--reading-light:#93c5fd;--shadow-xs:0 1px 2px #0000000a;--shadow-sm:0 1px 3px #0000001a, 0 1px 2px #0000000f;--shadow-md:0 4px 6px -1px #0000001a, 0 2px 4px -2px #0000000f;--shadow-lg:0 10px 15px -3px #0000001a, 0 4px 6px -4px #0000000f;--shadow-xl:0 20px 25px -5px #0000001a, 0 10px 10px -5px #0000000a;--shadow-glow:0 0 20px #6366f14d;--glass-bg:#ffffffb3;--glass-bg-hover:#ffffffd9;--glass-border:#ffffff80;--glass-blur:24px;--radius-xs:4px;--radius-sm:8px;--radius-md:12px;--radius-lg:16px;--radius-xl:20px;--radius-2xl:24px;--radius-full:9999px;--space-0:0;--space-1:4px;--space-2:8px;--space-3:12px;--space-4:16px;--space-5:20px;--space-6:24px;--space-8:32px;--space-10:40px;--space-12:48px;--space-16:64px;--space-20:80px;--font-sans:-apple-system, BlinkMacSystemFont, "Segoe UI", "SF Pro Display", system-ui, sans-serif;--font-heading:-apple-system, BlinkMacSystemFont, "Segoe UI", "SF Pro Display", system-ui, sans-serif;--font-mono:"SF Mono", "JetBrains Mono", "Fira Code", Consolas, monospace;--transition-fast:.15s cubic-bezier(.4, 0, .2, 1);--transition-base:.25s cubic-bezier(.4, 0, .2, 1);--transition-slow:.35s cubic-bezier(.4, 0, .2, 1)}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizelegibility;font-size:16px}body{font-family:var(--font-sans);background:var(--bg-secondary);color:var(--text-primary);-webkit-tap-highlight-color:transparent;min-height:100vh;line-height:1.6}#root{min-height:100vh;position:relative}body:before{content:"";background:var(--primary-gradient);border-radius:0 0 0 50% 50% / 100% 100px;z-index:-1;opacity:.08;pointer-events:none;height:400px;position:fixed;top:0;left:0;right:0}body:after{content:"";background:radial-gradient(circle,var(--reading) 0%,transparent 70%);opacity:.1;z-index:-1;pointer-events:none;width:300px;height:300px;position:fixed;bottom:0;right:0}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--border-default);border-radius:var(--radius-full);transition:background var(--transition-fast)}::-webkit-scrollbar-thumb:hover{background:var(--border-strong)}::selection{background:var(--primary);color:var(--text-inverse)}@keyframes fadeIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes scaleIn{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}@keyframes shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}@keyframes pulse-soft{0%,to{opacity:1}50%{opacity:.7}}.container{max-width:1440px;padding:0 var(--space-6);margin:0 auto}.flex{display:flex}.flex-col{flex-direction:column}.flex-row{flex-direction:row}.items-center{align-items:center}.items-start{align-items:flex-start}.items-end{align-items:flex-end}.justify-center{justify-content:center}.justify-between{justify-content:space-between}.justify-end{justify-content:flex-end}.gap-1{gap:var(--space-1)}.gap-2{gap:var(--space-2)}.gap-3{gap:var(--space-3)}.gap-4{gap:var(--space-4)}.gap-6{gap:var(--space-6)}.gap-8{gap:var(--space-8)}.text-center{text-align:center}.text-left{text-align:left}.text-right{text-align:right}.text-gradient{background:var(--primary-gradient);-webkit-text-fill-color:transparent;color:#0000;-webkit-background-clip:text;background-clip:text}.sr-only{clip:rect(0,0,0,0);white-space:nowrap;border:0;width:1px;height:1px;margin:-1px;padding:0;position:absolute;overflow:hidden}.btn{justify-content:center;align-items:center;gap:var(--space-2);padding:var(--space-3) var(--space-5);font-family:var(--font-sans);border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-base);-webkit-user-select:none;user-select:none;border:none;font-size:14px;font-weight:600;line-height:1.5;text-decoration:none;display:inline-flex}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-sm{padding:var(--space-2) var(--space-3);font-size:13px}.btn-lg{padding:var(--space-4) var(--space-8);font-size:16px}.btn-xl{padding:var(--space-5) var(--space-10);font-size:18px}.btn-primary{background:var(--primary-gradient);color:var(--text-inverse);box-shadow:var(--shadow-md)}.btn-primary:hover:not(:disabled){box-shadow:var(--shadow-lg),var(--shadow-glow);transform:translateY(-2px)}.btn-secondary{background:var(--bg-elevated);color:var(--text-primary);border:1px solid var(--border-default);box-shadow:var(--shadow-sm)}.btn-secondary:hover:not(:disabled){background:var(--bg-tertiary);border-color:var(--border-strong)}.btn-ghost{color:var(--text-primary);background:0 0}.btn-ghost:hover:not(:disabled){background:var(--bg-tertiary)}.card{background:var(--glass-bg);-webkit-backdrop-filter:blur(var(--glass-blur));border:1px solid var(--glass-border);border-radius:var(--radius-xl);box-shadow:var(--shadow-lg);transition:all var(--transition-base);overflow:hidden}.card:hover{background:var(--glass-bg-hover);box-shadow:var(--shadow-xl)}.card-elevated{background:var(--bg-elevated);border:1px solid var(--border-subtle);box-shadow:var(--shadow-lg)}.input{width:100%;padding:var(--space-3) var(--space-4);font-family:var(--font-sans);color:var(--text-primary);background:var(--glass-bg);-webkit-backdrop-filter:blur(var(--glass-blur));border:1px solid var(--border-default);border-radius:var(--radius-md);transition:all var(--transition-base);font-size:14px;line-height:1.5}.input::placeholder{color:var(--text-tertiary)}.input:focus{border-color:var(--primary);background:#ffffffe6;outline:none;box-shadow:0 0 0 3px #6366f11a}.tag{padding:var(--space-1) var(--space-3);border-radius:var(--radius-full);transition:all var(--transition-fast);align-items:center;font-size:12px;font-weight:500;display:inline-flex}.tag-sm{padding:2px var(--space-2);font-size:11px}.badge{min-width:20px;height:20px;padding:0 var(--space-1);border-radius:var(--radius-full);background:var(--primary);color:var(--text-inverse);justify-content:center;align-items:center;font-size:11px;font-weight:600;display:inline-flex}.badge-lg{min-width:24px;height:24px;font-size:12px}.progress-bar{background:var(--bg-tertiary);border-radius:var(--radius-full);height:8px;overflow:hidden}.progress-fill{background:var(--primary-gradient);border-radius:var(--radius-full);height:100%;transition:width var(--transition-slow)}.skeleton{background:linear-gradient(90deg,var(--bg-tertiary) 25%,var(--bg-secondary) 50%,var(--bg-tertiary) 75%);border-radius:var(--radius-md);background-size:200% 100%;animation:1.5s infinite shimmer}.page{min-height:100vh;padding:var(--space-8)}.page-header{margin-bottom:var(--space-8);animation:.5s ease-out fadeIn}.page-title{font-family:var(--font-heading);color:var(--text-primary);letter-spacing:-.02em;margin-bottom:var(--space-2);font-size:32px;font-weight:700}.page-subtitle{color:var(--text-secondary);font-size:16px;font-weight:400}.page-content{animation:.5s ease-out slideUp}.module-card{background:var(--glass-bg);-webkit-backdrop-filter:blur(var(--glass-blur));border:1px solid var(--glass-border);border-radius:var(--radius-xl);padding:var(--space-6);transition:all var(--transition-base);cursor:pointer}.module-card:hover{box-shadow:var(--shadow-xl);background:var(--glass-bg-hover);transform:translateY(-4px)}.module-card-primary{background:var(--primary-gradient);color:var(--text-inverse);border:none}.module-card-primary:hover{box-shadow:var(--shadow-xl),var(--shadow-glow);transform:translateY(-4px)scale(1.02)}.stat-card{background:var(--bg-elevated);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);padding:var(--space-5);transition:all var(--transition-base)}.stat-card:hover{border-color:var(--border-default);box-shadow:var(--shadow-md);transform:translateY(-2px)}.stat-value{font-family:var(--font-heading);color:var(--text-primary);letter-spacing:-.01em;font-size:28px;font-weight:700}.stat-label{color:var(--text-secondary);margin-top:var(--space-1);font-size:13px}@media (max-width:1024px){.container{padding:0 var(--space-4)}.page{padding:var(--space-6)}}@media (max-width:768px){:root{--space-16:48px;--space-20:64px}.page-title,.stat-value{font-size:24px}}@media (max-width:640px){.btn-lg{width:100%}.stat-card{padding:var(--space-4)}}@media print{body:before,body:after{display:none}.no-print{display:none!important}}@media (prefers-color-scheme:dark){:root{--bg-primary:#1a1a2e;--bg-secondary:#16162a;--bg-tertiary:#1f2937;--bg-elevated:#1e1e2f;--text-primary:#f1f5f9;--text-secondary:#cbd5e1;--text-tertiary:#94a3b8;--border-subtle:#ffffff0d;--border-default:#ffffff1a;--border-strong:#fff3;--glass-bg:#00000080;--glass-bg-hover:#0009}}.progress-fill{background:var(--primary-gradient)}.progress-fill-speaking{background:var(--speaking-gradient)}.progress-fill-reading{background:var(--reading-gradient)}.progress-fill-writing{background:var(--writing-gradient)}@property --tw-rotate-x{syntax:"*";inherits:false}@property --tw-rotate-y{syntax:"*";inherits:false}@property --tw-rotate-z{syntax:"*";inherits:false}@property --tw-skew-x{syntax:"*";inherits:false}@property --tw-skew-y{syntax:"*";inherits:false}@property --tw-space-y-reverse{syntax:"*";inherits:false;initial-value:0}@property --tw-space-x-reverse{syntax:"*";inherits:false;initial-value:0}@property --tw-border-style{syntax:"*";inherits:false;initial-value:solid}@property --tw-gradient-position{syntax:"*";inherits:false}@property --tw-gradient-from{syntax:"<color>";inherits:false;initial-value:#0000}@property --tw-gradient-via{syntax:"<color>";inherits:false;initial-value:#0000}@property --tw-gradient-to{syntax:"<color>";inherits:false;initial-value:#0000}@property --tw-gradient-stops{syntax:"*";inherits:false}@property --tw-gradient-via-stops{syntax:"*";inherits:false}@property --tw-gradient-from-position{syntax:"<length-percentage>";inherits:false;initial-value:0%}@property --tw-gradient-via-position{syntax:"<length-percentage>";inherits:false;initial-value:50%}@property --tw-gradient-to-position{syntax:"<length-percentage>";inherits:false;initial-value:100%}@property --tw-leading{syntax:"*";inherits:false}@property --tw-font-weight{syntax:"*";inherits:false}@property --tw-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-shadow-color{syntax:"*";inherits:false}@property --tw-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-inset-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-inset-shadow-color{syntax:"*";inherits:false}@property --tw-inset-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-ring-color{syntax:"*";inherits:false}@property --tw-ring-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-inset-ring-color{syntax:"*";inherits:false}@property --tw-inset-ring-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-ring-inset{syntax:"*";inherits:false}@property --tw-ring-offset-width{syntax:"<length>";inherits:false;initial-value:0}@property --tw-ring-offset-color{syntax:"*";inherits:false;initial-value:#fff}@property --tw-ring-offset-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-outline-style{syntax:"*";inherits:false;initial-value:solid}@property --tw-blur{syntax:"*";inherits:false}@property --tw-brightness{syntax:"*";inherits:false}@property --tw-contrast{syntax:"*";inherits:false}@property --tw-grayscale{syntax:"*";inherits:false}@property --tw-hue-rotate{syntax:"*";inherits:false}@property --tw-invert{syntax:"*";inherits:false}@property --tw-opacity{syntax:"*";inherits:false}@property --tw-saturate{syntax:"*";inherits:false}@property --tw-sepia{syntax:"*";inherits:false}@property --tw-drop-shadow{syntax:"*";inherits:false}@property --tw-drop-shadow-color{syntax:"*";inherits:false}@property --tw-drop-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-drop-shadow-size{syntax:"*";inherits:false}@property --tw-backdrop-blur{syntax:"*";inherits:false}@property --tw-backdrop-brightness{syntax:"*";inherits:false}@property --tw-backdrop-contrast{syntax:"*";inherits:false}@property --tw-backdrop-grayscale{syntax:"*";inherits:false}@property --tw-backdrop-hue-rotate{syntax:"*";inherits:false}@property --tw-backdrop-invert{syntax:"*";inherits:false}@property --tw-backdrop-opacity{syntax:"*";inherits:false}@property --tw-backdrop-saturate{syntax:"*";inherits:false}@property --tw-backdrop-sepia{syntax:"*";inherits:false}@property --tw-duration{syntax:"*";inherits:false}@property --tw-ease{syntax:"*";inherits:false}@keyframes spin{to{transform:rotate(360deg)}}@keyframes pulse{50%{opacity:.5}}@keyframes bounce{0%,to{animation-timing-function:cubic-bezier(.8,0,1,1);transform:translateY(-25%)}50%{animation-timing-function:cubic-bezier(0,0,.2,1);transform:none}}
