:root{--font-sans:"Inter", system-ui, -apple-system, sans-serif;--color-bg:#f8f9fc;--color-surface:#fff;--color-sidebar:#fff;--color-border:#e8eaef;--color-border-light:#f0f2f7;--color-text-primary:#111827;--color-text-secondary:#6b7280;--color-text-muted:#9ca3af;--color-indigo-50:#eef2ff;--color-indigo-100:#e0e7ff;--color-indigo-500:#6366f1;--color-indigo-600:#4f46e5;--color-indigo-700:#4338ca;--color-red-50:#fef2f2;--color-red-100:#fee2e2;--color-red-500:#ef4444;--color-red-600:#dc2626;--color-green-50:#f0fdf4;--color-green-100:#dcfce7;--color-green-500:#22c55e;--color-green-600:#16a34a;--color-blue-50:#eff6ff;--color-blue-100:#dbeafe;--color-blue-500:#3b82f6;--color-blue-600:#2563eb;--color-amber-50:#fffbeb;--color-amber-100:#fef3c7;--color-amber-500:#f59e0b;--shadow-xs:0 1px 2px #0000000a;--shadow-sm:0 1px 3px #00000012, 0 1px 2px #0000000d;--shadow-md:0 4px 12px #00000012, 0 2px 4px #0000000a;--shadow-lg:0 10px 30px #0000001a, 0 4px 10px #0000000d;--shadow-card-hover:0 12px 36px #6366f11f, 0 4px 12px #0000000f;--radius-sm:8px;--radius-md:12px;--radius-lg:16px;--radius-xl:20px;--radius-full:9999px;--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;--transition-fast:.15s cubic-bezier(.4, 0, .2, 1);--transition-normal:.25s cubic-bezier(.4, 0, .2, 1);--transition-slow:.4s cubic-bezier(.4, 0, .2, 1);--sidebar-width:280px;--topbar-height:68px}*,: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-color:var(--color-bg);color:var(--color-text-primary);min-height:100vh;line-height:1.6}#root{min-height:100vh}.text-xs{font-size:11px}.text-sm{font-size:13px}.text-base{font-size:15px}.text-lg{font-size:17px}.text-xl{font-size:20px}.text-2xl{font-size:24px}.text-3xl{font-size:30px}.font-medium{font-weight:500}.font-semibold{font-weight:600}.font-bold{font-weight:700}.font-extrabold{font-weight:800}.text-primary{color:var(--color-text-primary)}.text-secondary{color:var(--color-text-secondary)}.text-muted{color:var(--color-text-muted)}.text-indigo{color:var(--color-indigo-600)}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--color-border);border-radius:var(--radius-full)}::-webkit-scrollbar-thumb:hover{background:var(--color-text-muted)}@keyframes fadeInUp{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideInLeft{0%{opacity:0;transform:translate(-20px)}to{opacity:1;transform:translate(0)}}@keyframes pulse-soft{0%,to{opacity:1}50%{opacity:.5}}@keyframes shimmer{0%{background-position:-400px 0}to{background-position:400px 0}}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@keyframes progressFill{0%{width:0%}to{width:var(--target-width)}}.animate-fade-in-up{animation:fadeInUp var(--transition-slow) both}.animate-fade-in{animation:fadeIn var(--transition-normal) both}.stagger-1{animation-delay:0s}.stagger-2{animation-delay:80ms}.stagger-3{animation-delay:.16s}.stagger-4{animation-delay:.24s}.stagger-5{animation-delay:.32s}.stagger-6{animation-delay:400px}.app-root{background:var(--color-bg);flex-direction:column;min-height:100vh;display:flex}.app-body{padding-top:var(--topbar-height);min-height:calc(100vh - var(--topbar-height));flex:1;display:flex}.app-nav{width:var(--sidebar-width);background:var(--color-sidebar);border-right:1px solid var(--color-border);height:calc(100vh - var(--topbar-height));top:var(--topbar-height);flex-direction:column;flex-shrink:0;display:flex;position:sticky;overflow-y:auto}.side-nav{padding:var(--space-4) var(--space-3);gap:var(--space-1);border-bottom:1px solid var(--color-border-light);flex-direction:column;display:flex}.side-nav-item{align-items:center;gap:var(--space-3);padding:var(--space-3) var(--space-3);border-radius:var(--radius-sm);font-family:var(--font-sans);color:var(--color-text-secondary);cursor:pointer;transition:all var(--transition-fast);text-align:left;background:0 0;border:none;width:100%;font-size:13.5px;font-weight:500;display:flex}.side-nav-item:hover{background:var(--color-bg);color:var(--color-text-primary)}.side-nav-item--active{background:var(--color-indigo-50);color:var(--color-indigo-600);font-weight:600}.side-nav-item--active .side-nav-icon{color:var(--color-indigo-500)}.side-nav-icon{color:var(--color-text-muted);transition:color var(--transition-fast);flex-shrink:0;align-items:center;display:flex}.side-nav-label{flex:1}.main-content{padding:var(--space-8);flex:1;min-height:100%;overflow-y:auto}.error-banner{align-items:center;gap:var(--space-3);background:var(--color-red-50);border:1px solid var(--color-red-100);color:var(--color-red-600);padding:var(--space-3) var(--space-4);border-radius:var(--radius-md);margin-bottom:var(--space-6);font-size:13px;font-weight:500;display:flex}.error-dismiss{cursor:pointer;color:var(--color-red-500);padding:2px var(--space-2);border-radius:var(--radius-sm);transition:background var(--transition-fast);background:0 0;border:none;margin-left:auto;font-size:12px}.error-dismiss:hover{background:var(--color-red-100)}.empty-state{justify-content:center;align-items:center;min-height:60vh;display:flex}.empty-state-illustration{text-align:center;align-items:center;gap:var(--space-4);flex-direction:column;max-width:480px;display:flex}.empty-state-icon-ring{background:linear-gradient(135deg, var(--color-indigo-50), #f5f3ff);border:2px solid var(--color-indigo-100);width:96px;height:96px;color:var(--color-indigo-500);margin-bottom:var(--space-2);border-radius:50%;justify-content:center;align-items:center;display:flex;box-shadow:0 4px 20px #6366f11f}.empty-state-title{color:var(--color-text-primary);letter-spacing:-.5px;font-size:24px;font-weight:700}.empty-state-desc{color:var(--color-text-secondary);max-width:380px;font-size:14px;line-height:1.7}.empty-state-features{gap:var(--space-3);margin-top:var(--space-4);text-align:left;flex-direction:column;width:100%;display:flex}.empty-feature{align-items:flex-start;gap:var(--space-3);padding:var(--space-4);border-radius:var(--radius-md);border:1px solid var(--color-border);box-shadow:var(--shadow-xs);transition:box-shadow var(--transition-fast);background:#fff;display:flex}.empty-feature:hover{box-shadow:var(--shadow-sm)}.empty-feature-icon{flex-shrink:0;margin-top:1px;font-size:20px;line-height:1}.empty-feature-title{color:var(--color-text-primary);font-size:13px;font-weight:600}.empty-feature-desc{color:var(--color-text-muted);margin-top:2px;font-size:12px}.plan-view{flex-direction:column;max-width:900px;display:flex}.plan-header{margin-bottom:var(--space-6);justify-content:space-between;align-items:flex-end;display:flex}.plan-header-left{flex-direction:column;gap:4px;display:flex}.plan-title{color:var(--color-text-primary);letter-spacing:-.7px;font-size:26px;font-weight:800}.plan-date{color:var(--color-text-muted);font-size:13px;font-weight:500}.plan-regenerate-btn{align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-4);border:1.5px solid var(--color-border);border-radius:var(--radius-sm);font-family:var(--font-sans);color:var(--color-text-secondary);cursor:pointer;transition:all var(--transition-fast);box-shadow:var(--shadow-xs);background:#fff;font-size:12px;font-weight:600;display:flex}.plan-regenerate-btn:hover{border-color:var(--color-indigo-500);color:var(--color-indigo-600);background:var(--color-indigo-50)}.task-grid{gap:var(--space-4);grid-template-columns:repeat(auto-fill,minmax(280px,1fr));display:grid}.no-tasks{color:var(--color-text-muted);text-align:center;padding:var(--space-10);font-size:14px}.topbar-controls-hidden{display:none}@media (width<=900px){.app-body{flex-direction:column}.app-nav{border-right:none;border-bottom:1px solid var(--color-border);width:100%;height:auto;position:static}.side-nav{padding:var(--space-3);flex-direction:row;overflow-x:auto}.side-nav-item{white-space:nowrap}.main-content{padding:var(--space-5)}.topbar-input{width:150px}}.topbar{z-index:100;height:var(--topbar-height);-webkit-backdrop-filter:blur(16px);border-bottom:1px solid var(--color-border);padding:0 var(--space-6);justify-content:space-between;align-items:center;gap:var(--space-4);box-shadow:var(--shadow-xs);background:#ffffffeb;display:flex;position:fixed;top:0;left:0;right:0}.topbar-brand{align-items:center;gap:var(--space-3);flex-shrink:0;display:flex}.topbar-logo{background:linear-gradient(135deg, var(--color-indigo-500), var(--color-indigo-700));border-radius:var(--radius-sm);color:#fff;flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;display:flex;box-shadow:0 2px 8px #6366f159}.topbar-brand-text{flex-direction:column;gap:1px;display:flex}.topbar-title{color:var(--color-text-primary);letter-spacing:-.3px;font-size:15px;font-weight:700}.topbar-subtitle{color:var(--color-text-muted);letter-spacing:.2px;font-size:11px;font-weight:500}.topbar-controls{align-items:center;gap:var(--space-3);flex:1;justify-content:flex-end;display:flex}.topbar-input-group{flex-direction:column;gap:2px;display:flex}.topbar-label{color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.5px;font-size:10px;font-weight:600}.topbar-input{height:36px;padding:0 var(--space-3);border:1.5px solid var(--color-border);border-radius:var(--radius-sm);background:var(--color-bg);font-family:var(--font-sans);color:var(--color-text-primary);transition:border-color var(--transition-fast), box-shadow var(--transition-fast);outline:none;width:220px;font-size:13px}.topbar-input--narrow{width:80px}.topbar-input::placeholder{color:var(--color-text-muted)}.topbar-input:focus{border-color:var(--color-indigo-500);background:#fff;box-shadow:0 0 0 3px #6366f11f}.topbar-btn{align-items:center;gap:var(--space-2);height:36px;padding:0 var(--space-5);background:linear-gradient(135deg, var(--color-indigo-500), var(--color-indigo-600));color:#fff;border-radius:var(--radius-sm);font-family:var(--font-sans);cursor:pointer;transition:all var(--transition-fast);white-space:nowrap;border:none;flex-shrink:0;align-self:flex-end;font-size:13px;font-weight:600;display:flex;box-shadow:0 2px 8px #6366f159}.topbar-btn:hover:not(:disabled){background:linear-gradient(135deg, var(--color-indigo-600), var(--color-indigo-700));transform:translateY(-1px);box-shadow:0 4px 14px #6366f173}.topbar-btn:active:not(:disabled){transform:translateY(0);box-shadow:0 2px 6px #6366f14d}.topbar-btn:disabled{opacity:.6;cursor:not-allowed}.topbar-btn--loading{pointer-events:none}.topbar-btn-spinner{border:2px solid #ffffff59;border-top-color:#fff;border-radius:50%;flex-shrink:0;width:13px;height:13px;animation:.75s linear infinite spin}.topbar-student-chip{align-items:center;gap:var(--space-2);background:var(--color-indigo-50);border:1.5px solid var(--color-indigo-100);border-radius:var(--radius-md);padding:5px var(--space-3) 5px 6px;flex-shrink:0;display:flex}.topbar-student-avatar{background:linear-gradient(135deg, var(--color-indigo-500), var(--color-indigo-700));color:#fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:28px;height:28px;font-size:13px;font-weight:700;display:flex}.topbar-student-info{flex-direction:column;gap:1px;display:flex}.topbar-student-name{color:var(--color-indigo-700);font-size:13px;font-weight:600;line-height:1.2}.topbar-student-meta{color:var(--color-indigo-400);text-transform:uppercase;letter-spacing:.3px;font-size:10px;font-weight:500}.topbar-no-student{align-items:center;gap:var(--space-2);color:var(--color-text-muted);background:var(--color-bg);border:1.5px dashed var(--color-border);border-radius:var(--radius-sm);padding:6px var(--space-3);white-space:nowrap;font-size:12px;font-weight:500;display:flex}.sidebar{width:var(--sidebar-width);background:var(--color-sidebar);border-right:1px solid var(--color-border);height:calc(100vh - var(--topbar-height));top:var(--topbar-height);padding:var(--space-6);gap:var(--space-5);animation:slideInLeft var(--transition-slow) both;flex-direction:column;flex-shrink:0;display:flex;position:sticky;overflow-y:auto}.sidebar-student-card{align-items:center;gap:var(--space-3);padding:var(--space-4);background:linear-gradient(135deg, var(--color-indigo-50), #f5f3ff);border-radius:var(--radius-md);border:1px solid var(--color-indigo-100);display:flex}.sidebar-avatar{background:linear-gradient(135deg, var(--color-indigo-500), var(--color-indigo-700));color:#fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:40px;height:40px;font-size:17px;font-weight:700;display:flex;box-shadow:0 2px 8px #6366f14d}.sidebar-student-info{flex:1;min-width:0}.sidebar-student-name{color:var(--color-text-primary);white-space:nowrap;text-overflow:ellipsis;font-size:14px;font-weight:600;overflow:hidden}.sidebar-student-meta{color:var(--color-text-muted);margin-top:2px;font-size:11px}.sidebar-stats-row{padding:var(--space-3) var(--space-4);background:var(--color-bg);border-radius:var(--radius-md);border:1px solid var(--color-border-light);justify-content:space-between;align-items:center;display:flex}.sidebar-stat{flex-direction:column;flex:1;align-items:center;gap:2px;display:flex}.sidebar-stat-value{color:var(--color-text-primary);letter-spacing:-.5px;font-size:18px;font-weight:700;line-height:1}.sidebar-stat-label{color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.3px;font-size:10px;font-weight:500}.sidebar-stat-divider{background:var(--color-border);width:1px;height:30px}.sidebar-divider{background:var(--color-border-light);height:1px;margin:0 calc(-1 * var(--space-6))}.sidebar-section{gap:var(--space-3);flex-direction:column;display:flex}.sidebar-section-title{letter-spacing:.6px;text-transform:uppercase;color:var(--color-text-muted);font-size:11px;font-weight:700}.sidebar-progress-list{gap:var(--space-4);flex-direction:column;display:flex}.sidebar-empty-state{align-items:center;gap:var(--space-2);padding:var(--space-6) var(--space-4);text-align:center;flex-direction:column;display:flex}.sidebar-empty-icon{font-size:28px}.sidebar-empty-state p{color:var(--color-text-muted);font-size:12px;line-height:1.5}.sidebar-tips{gap:var(--space-3);flex-direction:column;display:flex}.sidebar-tip{align-items:flex-start;gap:var(--space-2);padding:var(--space-3);background:var(--color-bg);border-radius:var(--radius-sm);border:1px solid var(--color-border-light);display:flex}.sidebar-tip span{flex-shrink:0;margin-top:1px;font-size:14px}.sidebar-tip p{color:var(--color-text-secondary);font-size:12px;line-height:1.5}.progress-item{gap:var(--space-1);flex-direction:column;display:flex}.progress-header{align-items:center;gap:var(--space-2);margin-bottom:2px;display:flex}.progress-icon{flex-shrink:0;font-size:14px;line-height:1}.progress-subject{color:var(--color-text-primary);flex:1;font-size:13px;font-weight:500}.progress-pct{letter-spacing:.2px;font-size:12px;font-weight:700}.progress-track{background:var(--color-border-light);border-radius:var(--radius-full);height:6px;overflow:hidden}.progress-fill{border-radius:var(--radius-full);height:100%;width:var(--target-width);animation:.9s cubic-bezier(.4,0,.2,1) .2s both progressFill}.task-card{background:var(--color-surface);border-radius:var(--radius-lg);border:1px solid var(--color-border);box-shadow:var(--shadow-sm);transition:transform var(--transition-normal), box-shadow var(--transition-normal), border-color var(--transition-normal);cursor:default;position:relative;overflow:hidden}.task-card:hover{box-shadow:var(--shadow-card-hover);border-color:#0000;transform:translateY(-4px)}.task-card-accent-bar{border-radius:var(--radius-sm) 0 0 var(--radius-sm);width:4px;height:100%;position:absolute;top:0;left:0}.task-card-inner{padding:var(--space-5) var(--space-5) var(--space-4) calc(var(--space-5) + 4px);gap:var(--space-3);flex-direction:column;display:flex}.task-card-header{justify-content:space-between;align-items:center;gap:var(--space-3);display:flex}.task-subject-badge{align-items:center;gap:var(--space-2);padding:var(--space-1) var(--space-3);border-radius:var(--radius-full);font-size:12px;font-weight:600;display:inline-flex}.task-subject-icon{font-size:13px;line-height:1}.task-subject-name{letter-spacing:.1px}.task-tag{letter-spacing:.5px;padding:3px var(--space-2);border-radius:var(--radius-sm);text-transform:uppercase;flex-shrink:0;font-size:10px;font-weight:700}.tag--weak{background:var(--color-red-50);color:var(--color-red-600);border:1px solid var(--color-red-100)}.tag--new{background:var(--color-blue-50);color:var(--color-blue-600);border:1px solid var(--color-blue-100)}.tag--revision{background:var(--color-green-50);color:var(--color-green-600);border:1px solid var(--color-green-100)}.tag--default{background:var(--color-indigo-50);color:var(--color-indigo-600);border:1px solid var(--color-indigo-100)}.task-card-body{gap:var(--space-1);flex-direction:column;display:flex}.task-topic{color:var(--color-text-primary);letter-spacing:-.2px;font-size:15px;font-weight:600;line-height:1.4}.task-description{color:var(--color-text-secondary);font-size:13px;line-height:1.6}.task-card-footer{margin-top:var(--space-1);padding-top:var(--space-3);border-top:1px solid var(--color-border-light);justify-content:space-between;align-items:center;display:flex}.task-duration{color:var(--color-text-muted);align-items:center;gap:5px;font-size:12px;font-weight:500;display:flex}.task-btn-mark{padding:5px var(--space-3);border:1.5px solid var(--color-border);border-radius:var(--radius-full);font-family:var(--font-sans);color:var(--color-text-secondary);cursor:pointer;transition:all var(--transition-fast);background:0 0;align-items:center;gap:5px;font-size:11px;font-weight:600;display:flex}.task-btn-mark:hover{border-color:var(--color-green-500);color:var(--color-green-600);background:var(--color-green-50)}.focus-summary{border:1px solid var(--color-indigo-100);border-radius:var(--radius-xl);padding:var(--space-6) var(--space-8);justify-content:space-between;align-items:center;gap:var(--space-6);margin-bottom:var(--space-6);background:linear-gradient(135deg,#eef2ff 0%,#f5f3ff 50%,#eff6ff 100%);display:flex;box-shadow:0 2px 12px #6366f114}.focus-summary-left{gap:var(--space-2);flex-direction:column;display:flex}.focus-summary-greeting{align-items:center;gap:var(--space-2);display:flex}.focus-emoji{font-size:18px;line-height:1}.focus-greeting-text{color:var(--color-text-secondary);font-size:13px;font-weight:500}.focus-headline{color:var(--color-text-primary);letter-spacing:-.5px;font-size:22px;font-weight:700;line-height:1.3}.focus-highlight{color:var(--color-indigo-600)}.focus-sub{color:var(--color-text-secondary);font-size:13px}.focus-sub strong{color:var(--color-text-primary);font-weight:600}.focus-summary-chips{gap:var(--space-3);flex-wrap:wrap;flex-shrink:0;justify-content:flex-end;display:flex}.focus-chip{padding:var(--space-3) var(--space-4);border-radius:var(--radius-md);text-align:center;flex-direction:column;align-items:center;gap:2px;min-width:70px;display:flex}.focus-chip span{text-transform:uppercase;letter-spacing:.3px;font-size:11px;font-weight:600}.focus-chip-num{letter-spacing:-.5px!important;font-size:24px!important;font-weight:800!important;line-height:1!important}.focus-chip--red{background:var(--color-red-50);border:1px solid var(--color-red-100);color:var(--color-red-600)}.focus-chip--blue{background:var(--color-blue-50);border:1px solid var(--color-blue-100);color:var(--color-blue-600)}.focus-chip--green{background:var(--color-green-50);border:1px solid var(--color-green-100);color:var(--color-green-600)}@media (width<=768px){.focus-summary{flex-direction:column;align-items:flex-start}.focus-summary-chips{justify-content:flex-start}}.loading-container{align-items:center;gap:var(--space-8);padding:var(--space-10) 0;flex-direction:column;width:100%;display:flex}.loading-cards{gap:var(--space-4);flex-direction:column;width:100%;display:flex}.loading-skeleton-card{border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--space-5);gap:var(--space-3);background:#fff;flex-direction:column;animation:1.5s ease-in-out infinite pulse-soft;display:flex}.skeleton-row{border-radius:var(--radius-full);background:linear-gradient(90deg, var(--color-border-light) 25%, var(--color-border) 50%, var(--color-border-light) 75%);background-size:400px 100%;height:12px;animation:1.5s linear infinite shimmer}.skeleton-row--short{width:30%}.skeleton-row--medium{width:55%}.skeleton-row--long{width:85%}.loading-text-block{align-items:center;gap:var(--space-3);flex-direction:column;display:flex}.loading-spinner-ring{border:3px solid var(--color-indigo-100);border-top-color:var(--color-indigo-500);border-radius:50%;width:36px;height:36px;animation:.8s linear infinite spin}.loading-text{color:var(--color-text-muted);text-align:center;font-size:13px;font-weight:500}.sm-container{width:100%;max-width:760px}.sm-header{margin-bottom:var(--space-6)}.sm-title{color:var(--color-text-primary);letter-spacing:-.6px;font-size:26px;font-weight:800}.sm-subtitle{color:var(--color-text-secondary);margin-top:4px;font-size:14px}.sm-tabs{gap:var(--space-2);margin-bottom:var(--space-5);border-bottom:1px solid var(--color-border);padding-bottom:0;display:flex}.sm-tab{align-items:center;gap:var(--space-2);padding:var(--space-3) var(--space-4);font-family:var(--font-sans);color:var(--color-text-muted);cursor:pointer;transition:all var(--transition-fast);background:0 0;border:none;border-bottom:2px solid #0000;margin-bottom:-1px;font-size:13px;font-weight:500;display:flex}.sm-tab:hover{color:var(--color-text-primary)}.sm-tab--active{color:var(--color-indigo-600);border-bottom-color:var(--color-indigo-500);font-weight:600}.sm-panel{border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--space-6);box-shadow:var(--shadow-sm);background:#fff}.sm-form{gap:var(--space-5);flex-direction:column;display:flex}.sm-field-row{gap:var(--space-4);display:flex}.sm-field{gap:var(--space-2);flex-direction:column;flex:1;display:flex}.sm-field--narrow{flex:0 0 140px}.sm-label{color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.4px;font-size:12px;font-weight:600}.sm-input{height:40px;padding:0 var(--space-3);border:1.5px solid var(--color-border);border-radius:var(--radius-sm);background:var(--color-bg);font-family:var(--font-sans);color:var(--color-text-primary);transition:border-color var(--transition-fast), box-shadow var(--transition-fast);outline:none;width:100%;font-size:14px}.sm-input:focus{border-color:var(--color-indigo-500);background:#fff;box-shadow:0 0 0 3px #6366f11a}.sm-input--grow{flex:1}.sm-input--narrow-fixed{width:120px}.subject-editor{gap:var(--space-3);background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:var(--space-4);flex-direction:column;display:flex}.subject-editor-row{align-items:center;gap:var(--space-3);display:flex}.subject-editor-name{color:var(--color-text-primary);flex-shrink:0;width:100px;font-size:13px;font-weight:500}.subject-editor-controls{align-items:center;gap:var(--space-2);flex:1;display:flex}.subject-slider{height:4px;accent-color:var(--color-indigo-500);cursor:pointer;flex:1}.subject-pct{color:var(--color-indigo-600);text-align:right;flex-shrink:0;width:36px;font-size:12px;font-weight:700}.subject-remove-btn{cursor:pointer;color:var(--color-text-muted);border-radius:var(--radius-sm);transition:all var(--transition-fast);background:0 0;border:none;padding:2px 4px;font-size:11px}.subject-remove-btn:hover{color:var(--color-red-500);background:var(--color-red-50)}.subject-add-btn{border:1.5px dashed var(--color-border);border-radius:var(--radius-sm);font-family:var(--font-sans);color:var(--color-text-muted);cursor:pointer;padding:var(--space-2) var(--space-3);transition:all var(--transition-fast);background:0 0;align-self:flex-start;font-size:12px;font-weight:600}.subject-add-btn:hover{border-color:var(--color-indigo-400);color:var(--color-indigo-600)}.sm-error{background:var(--color-red-50);color:var(--color-red-600);border:1px solid var(--color-red-100);border-radius:var(--radius-sm);padding:var(--space-3) var(--space-4);font-size:13px;font-weight:500}.sm-success{align-items:center;gap:var(--space-2);background:var(--color-green-50);color:var(--color-green-700);border:1px solid var(--color-green-100);border-radius:var(--radius-sm);padding:var(--space-3) var(--space-4);font-size:13px;font-weight:500;display:flex}.sm-success--row{justify-content:space-between}.sm-goto-btn{background:var(--color-indigo-500);color:#fff;border-radius:var(--radius-sm);font-family:var(--font-sans);cursor:pointer;transition:all var(--transition-fast);white-space:nowrap;border:none;flex-shrink:0;align-items:center;gap:4px;padding:4px 12px;font-size:12px;font-weight:600;display:inline-flex}.sm-goto-btn:hover{background:var(--color-indigo-600);transform:translate(2px)}.sm-id-copy{color:var(--color-indigo-600);word-break:break-all;font-size:12px}.sm-submit-btn{align-items:center;gap:var(--space-2);height:40px;padding:0 var(--space-6);background:linear-gradient(135deg, var(--color-indigo-500), var(--color-indigo-600));color:#fff;border-radius:var(--radius-sm);font-family:var(--font-sans);cursor:pointer;transition:all var(--transition-fast);border:none;align-self:flex-start;font-size:14px;font-weight:600;display:inline-flex;box-shadow:0 2px 8px #6366f14d}.sm-submit-btn:hover:not(:disabled){background:linear-gradient(135deg, var(--color-indigo-600), var(--color-indigo-700));transform:translateY(-1px);box-shadow:0 4px 14px #6366f166}.sm-submit-btn:disabled{opacity:.6;cursor:not-allowed}.sm-spinner{border:2px solid #fff6;border-top-color:#fff;border-radius:50%;flex-shrink:0;width:14px;height:14px;animation:.75s linear infinite spin}.sm-lookup-row{gap:var(--space-3);margin-bottom:var(--space-4);display:flex}.sm-lookup-btn{height:40px;padding:0 var(--space-5);background:var(--color-indigo-500);color:#fff;border-radius:var(--radius-sm);font-family:var(--font-sans);cursor:pointer;transition:all var(--transition-fast);border:none;flex-shrink:0;font-size:13px;font-weight:600}.sm-lookup-btn:hover:not(:disabled){background:var(--color-indigo-600)}.sm-lookup-btn:disabled{opacity:.6;cursor:not-allowed}.sm-loaded{gap:var(--space-5);flex-direction:column;display:flex}.sm-loaded-header{align-items:center;gap:var(--space-3);padding:var(--space-4);background:var(--color-indigo-50);border-radius:var(--radius-md);border:1px solid var(--color-indigo-100);display:flex}.sm-loaded-avatar{background:linear-gradient(135deg, var(--color-indigo-500), var(--color-indigo-700));color:#fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:40px;height:40px;font-size:18px;font-weight:700;display:flex}.sm-loaded-name{color:var(--color-text-primary);font-size:15px;font-weight:600}.sm-loaded-id{color:var(--color-text-muted);word-break:break-all;font-size:11px}.la-container{width:100%;max-width:880px}.la-header{margin-bottom:var(--space-6)}.la-title{color:var(--color-text-primary);letter-spacing:-.6px;font-size:26px;font-weight:800}.la-subtitle{color:var(--color-text-secondary);margin-top:4px;font-size:14px}.la-layout{gap:var(--space-6);grid-template-columns:1fr 300px;align-items:start;display:grid}@media (width<=800px){.la-layout{grid-template-columns:1fr}}.la-form-card{border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--space-6);box-shadow:var(--shadow-sm);background:#fff}.la-form{gap:var(--space-5);flex-direction:column;display:flex}.la-field-row{gap:var(--space-4);grid-template-columns:1fr 1fr;display:grid}.la-field{gap:var(--space-2);flex-direction:column;display:flex}.la-label{color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.4px;font-size:12px;font-weight:600}.la-input{height:40px;padding:0 var(--space-3);border:1.5px solid var(--color-border);border-radius:var(--radius-sm);background:var(--color-bg);font-family:var(--font-sans);color:var(--color-text-primary);transition:border-color var(--transition-fast), box-shadow var(--transition-fast);outline:none;width:100%;font-size:14px}.la-input:focus{border-color:var(--color-indigo-500);background:#fff;box-shadow:0 0 0 3px #6366f11a}.la-select{cursor:pointer}.la-toggle-row{gap:var(--space-3);display:flex}.la-toggle-btn{align-items:center;gap:var(--space-2);border-radius:var(--radius-sm);height:44px;font-family:var(--font-sans);cursor:pointer;transition:all var(--transition-fast);border:2px solid var(--color-border);background:var(--color-bg);color:var(--color-text-muted);flex:1;justify-content:center;font-size:14px;font-weight:600;display:flex}.la-toggle-btn--correct:hover{border-color:var(--color-green-400);color:var(--color-green-600)}.la-toggle-btn--incorrect:hover{border-color:var(--color-red-400);color:var(--color-red-600)}.la-toggle-btn--active-correct{border-color:var(--color-green-500);background:var(--color-green-50);color:var(--color-green-600)}.la-toggle-btn--active-incorrect{border-color:var(--color-red-500);background:var(--color-red-50);color:var(--color-red-600)}.la-error{background:var(--color-red-50);color:var(--color-red-600);border:1px solid var(--color-red-100);border-radius:var(--radius-sm);padding:var(--space-3) var(--space-4);font-size:13px;font-weight:500}.la-success{align-items:center;gap:var(--space-2);background:var(--color-green-50);color:var(--color-green-700);border:1px solid var(--color-green-100);border-radius:var(--radius-sm);padding:var(--space-3) var(--space-4);font-size:13px;font-weight:500;line-height:1.5;display:flex}.la-submit-btn{align-items:center;gap:var(--space-2);height:42px;padding:0 var(--space-6);background:linear-gradient(135deg, var(--color-indigo-500), var(--color-indigo-600));color:#fff;border-radius:var(--radius-sm);font-family:var(--font-sans);cursor:pointer;transition:all var(--transition-fast);border:none;font-size:14px;font-weight:600;display:inline-flex;box-shadow:0 2px 8px #6366f14d}.la-submit-btn:hover:not(:disabled){background:linear-gradient(135deg, var(--color-indigo-600), var(--color-indigo-700));transform:translateY(-1px)}.la-submit-btn:disabled{opacity:.6;cursor:not-allowed}.la-spinner{border:2px solid #ffffff59;border-top-color:#fff;border-radius:50%;width:13px;height:13px;animation:.75s linear infinite spin}.la-history{border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--space-5);box-shadow:var(--shadow-sm);background:#fff}.la-history-title{color:var(--color-text-primary);margin-bottom:var(--space-4);text-transform:uppercase;letter-spacing:.5px;font-size:13px;font-weight:700}.la-history-empty{align-items:center;gap:var(--space-2);padding:var(--space-6) 0;text-align:center;flex-direction:column;display:flex}.la-history-empty span{font-size:28px}.la-history-empty p{color:var(--color-text-muted);font-size:12px}.la-history-list{gap:var(--space-2);flex-direction:column;display:flex}.la-history-item{align-items:center;gap:var(--space-3);padding:var(--space-3);border-radius:var(--radius-sm);border:1px solid var(--color-border-light);display:flex}.la-history-item--correct{background:#f0fdf4}.la-history-item--wrong{background:#fef2f2}.la-history-dot{border-radius:50%;flex-shrink:0;width:7px;height:7px}.la-history-item--correct .la-history-dot{background:var(--color-green-500)}.la-history-item--wrong .la-history-dot{background:var(--color-red-500)}.la-history-info{flex-direction:column;flex:1;gap:1px;min-width:0;display:flex}.la-history-subject{color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.3px;font-size:11px;font-weight:700}.la-history-topic{color:var(--color-text-primary);white-space:nowrap;text-overflow:ellipsis;font-size:13px;font-weight:500;overflow:hidden}.la-history-badge{flex-shrink:0;font-size:13px;font-weight:700}.la-history-badge--correct{color:var(--color-green-600)}.la-history-badge--wrong{color:var(--color-red-600)}.la-hint{color:var(--color-text-muted);margin-top:2px;font-size:11px}.la-hint--warn{color:#d97706;font-weight:600}.la-select--disabled,.la-input:disabled{background:var(--color-bg,#f8f8f8);color:var(--color-text-muted,#9ca3af);cursor:not-allowed;opacity:.65;border-style:dashed}.la-topic-select{animation:.18s la-topic-appear}@keyframes la-topic-appear{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.wt-container{width:100%;max-width:860px}.wt-header{margin-bottom:var(--space-6)}.wt-title{color:var(--color-text-primary);letter-spacing:-.6px;font-size:26px;font-weight:800}.wt-subtitle{color:var(--color-text-secondary);margin-top:4px;font-size:14px}.wt-lookup-card{border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--space-5) var(--space-6);box-shadow:var(--shadow-sm);margin-bottom:var(--space-6);background:#fff}.wt-lookup-row{gap:var(--space-3);display:flex}.wt-input{height:42px;padding:0 var(--space-4);border:1.5px solid var(--color-border);border-radius:var(--radius-sm);background:var(--color-bg);font-family:var(--font-sans);color:var(--color-text-primary);transition:border-color var(--transition-fast), box-shadow var(--transition-fast);outline:none;flex:1;font-size:14px}.wt-input:focus{border-color:var(--color-indigo-500);background:#fff;box-shadow:0 0 0 3px #6366f11a}.wt-analyze-btn{align-items:center;gap:var(--space-2);height:42px;padding:0 var(--space-5);background:linear-gradient(135deg, var(--color-indigo-500), var(--color-indigo-600));color:#fff;border-radius:var(--radius-sm);font-family:var(--font-sans);cursor:pointer;transition:all var(--transition-fast);border:none;flex-shrink:0;font-size:13px;font-weight:600;display:flex;box-shadow:0 2px 8px #6366f14d}.wt-analyze-btn:hover:not(:disabled){background:linear-gradient(135deg, var(--color-indigo-600), var(--color-indigo-700));transform:translateY(-1px)}.wt-analyze-btn:disabled{opacity:.6;cursor:not-allowed}.wt-spinner{border:2px solid #ffffff59;border-top-color:#fff;border-radius:50%;width:13px;height:13px;animation:.75s linear infinite spin}.wt-error{background:var(--color-red-50);color:var(--color-red-600);border:1px solid var(--color-red-100);border-radius:var(--radius-sm);padding:var(--space-3) var(--space-4);margin-bottom:var(--space-4);font-size:13px}.wt-summary-row{gap:var(--space-4);margin-bottom:var(--space-5);display:flex}.wt-summary-chip{padding:var(--space-4) var(--space-5);border-radius:var(--radius-md);text-align:center;border:1px solid #0000;flex-direction:column;flex:1;align-items:center;gap:2px;display:flex}.wt-summary-chip span:last-child{text-transform:uppercase;letter-spacing:.3px;font-size:11px;font-weight:600}.wt-summary-num{letter-spacing:-.5px!important;font-size:28px!important;font-weight:800!important;line-height:1!important}.wt-summary-chip--total{background:var(--color-indigo-50);border-color:var(--color-indigo-100);color:var(--color-indigo-600)}.wt-summary-chip--weak{background:var(--color-red-50);border-color:var(--color-red-100);color:var(--color-red-600)}.wt-summary-chip--ok{background:var(--color-green-50);border-color:var(--color-green-100);color:var(--color-green-600)}.wt-filter-tabs{gap:var(--space-2);margin-bottom:var(--space-5);display:flex}.wt-filter-tab{padding:var(--space-2) var(--space-4);border-radius:var(--radius-full);border:1.5px solid var(--color-border);font-family:var(--font-sans);color:var(--color-text-secondary);cursor:pointer;transition:all var(--transition-fast);background:#fff;font-size:13px;font-weight:500}.wt-filter-tab:hover{border-color:var(--color-indigo-300);color:var(--color-indigo-600)}.wt-filter-tab--active{background:var(--color-indigo-500);border-color:var(--color-indigo-500);color:#fff;font-weight:600}.wt-subject-group{margin-bottom:var(--space-6)}.wt-subject-heading{text-transform:uppercase;letter-spacing:.6px;color:var(--color-text-muted);margin-bottom:var(--space-3);padding-left:var(--space-2);font-size:13px;font-weight:700}.wt-rows{gap:var(--space-2);flex-direction:column;display:flex}.wt-row{align-items:center;gap:var(--space-4);padding:var(--space-4);border:1px solid var(--color-border);border-radius:var(--radius-md);box-shadow:var(--shadow-xs);transition:all var(--transition-fast);background:#fff;display:flex}.wt-row:hover{box-shadow:var(--shadow-sm)}.wt-row--weak{border-left:3px solid var(--color-red-400)}.wt-row-left{align-items:center;gap:var(--space-3);flex:0 0 180px;display:flex}.wt-weakness-dot{border-radius:50%;flex-shrink:0;width:8px;height:8px}.wt-weakness-dot--weak{background:var(--color-red-500)}.wt-weakness-dot--ok{background:var(--color-green-500)}.wt-row-info{flex-direction:column;gap:1px;min-width:0;display:flex}.wt-subject{text-transform:uppercase;letter-spacing:.4px;color:var(--color-text-muted);font-size:10px;font-weight:700}.wt-topic{color:var(--color-text-primary);white-space:nowrap;text-overflow:ellipsis;font-size:14px;font-weight:600;overflow:hidden}.wt-row-center{align-items:center;gap:var(--space-3);flex:1;display:flex}.wt-acc-track{background:var(--color-border-light);border-radius:var(--radius-full);flex:1;height:6px;overflow:hidden}.wt-acc-fill{border-radius:var(--radius-full);height:100%;width:var(--target-width);animation:.9s cubic-bezier(.4,0,.2,1) both progressFill}.wt-acc-fill--weak{background:var(--color-red-400)}.wt-acc-fill--ok{background:var(--color-green-500)}.wt-acc-label{color:var(--color-text-muted);white-space:nowrap;flex-shrink:0;font-size:12px;font-weight:600}.wt-row-right{align-items:center;gap:var(--space-3);flex-shrink:0;display:flex}.wt-attempts{color:var(--color-text-muted);gap:4px;font-size:12px;display:flex}.wt-incorrect{color:var(--color-red-500);font-weight:600}.wt-sep{color:var(--color-text-muted)}.wt-total{font-weight:500}.wt-badge{letter-spacing:.5px;border-radius:var(--radius-full);padding:3px 8px;font-size:10px;font-weight:700}.wt-badge--weak{background:var(--color-red-50);color:var(--color-red-600);border:1px solid var(--color-red-100)}.wt-badge--ok{background:var(--color-green-50);color:var(--color-green-600);border:1px solid var(--color-green-100)}.wt-placeholder{align-items:center;gap:var(--space-3);padding:var(--space-12) 0;text-align:center;color:var(--color-text-muted);flex-direction:column;display:flex}.wt-placeholder-icon{font-size:40px}.wt-placeholder p{font-size:14px}.wt-empty{color:var(--color-text-muted);padding:var(--space-6);text-align:center;font-size:13px}
