*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{color-scheme:dark;--bg: #07040f;--bg-2: #0d0820;--surface: rgba(255,255,255,.055);--surface-2: rgba(255,255,255,.09);--surface-hover: rgba(255,255,255,.115);--border: rgba(255,255,255,.09);--border-strong: rgba(255,255,255,.17);--text: #f2eeff;--text-dim: #c4bce8;--text-muted: #6e668f;--accent: #d946ef;--accent-2: #f0a0ff;--accent-soft: rgba(217,70,239,.15);--accent-glow: rgba(217,70,239,.5);--violet: #8b5cf6;--cyan: #22d3ee;--indigo: #6366f1;--green: #34d399;--ok: #34d399;--danger: #f87171;--warn: #fbbf24;--purple: #c084fc;--radius: 13px;--glow-op: .22;--glow-opacity: .22;--texture-bg: radial-gradient(circle, rgba(255,255,255,.055) 1px, transparent 1px);--texture-size: 28px 28px;--sidebar-bg: rgba(7,3,18,.99);--mobile-header-bg: rgba(7,3,18,.92);--progress-track: rgba(255,255,255,.07);--progress-grad: linear-gradient(90deg, #6366f1, #8b5cf6, #22d3ee);--badge-neutral-bg: rgba(255,255,255,.07);--badge-neutral-border: rgba(255,255,255,.12);--prompt-bg: linear-gradient(135deg, rgba(99,102,241,.1), rgba(139,92,246,.06));--prompt-border: rgba(99,102,241,.3);--prompt-icon-bg: rgba(99,102,241,.18);--logo-a: #6366f1;--logo-b: #8b5cf6;--logo-c: #22d3ee;--logo-shadow: rgba(99,102,241,.45);--avatar-grad: linear-gradient(135deg, #c026d3 0%, #7b41b8 100%);--avatar-border: rgba(217,70,239,.55);--avatar-glow: rgba(217,70,239,.4);--chip-urgent-text: #fca5a5;--chip-urgent-bg: rgba(239,68,68,.14);--chip-urgent-border: rgba(239,68,68,.28);--chip-soon-text: #fde68a;--chip-soon-bg: rgba(251,191,36,.12);--chip-soon-border: rgba(251,191,36,.25);--chip-ok-text: #6ee7b7;--chip-ok-bg: rgba(52,211,153,.1);--chip-ok-border: rgba(52,211,153,.25)}.light{color-scheme:light;--bg: #f7f5ff;--bg-2: #ede9fc;--surface: #ffffff;--surface-2: #ffffff;--surface-hover:rgba(109,40,217,.05);--border: rgba(0,0,0,.07);--border-strong:rgba(0,0,0,.12);--text: #18122e;--text-dim: #2f2650;--text-muted: #7a6e9e;--danger: #dc2626;--warn: #b45309;--green: #059669;--ok: #059669;--glow-op: .07;--sidebar-bg: #ece8ff;--mobile-header-bg: #ece8ff;--chip-urgent-text: #b91c1c;--chip-urgent-bg: rgba(239,68,68,.1);--chip-urgent-border: rgba(239,68,68,.28);--chip-soon-text: #92400e;--chip-soon-bg: rgba(251,191,36,.14);--chip-soon-border: rgba(180,83,9,.28);--chip-ok-text: #15803d;--chip-ok-bg: rgba(22,163,74,.1);--chip-ok-border: rgba(22,163,74,.28);--progress-track: rgba(0,0,0,.08);--badge-neutral-bg: rgba(0,0,0,.05);--badge-neutral-border: rgba(0,0,0,.13)}body.light{--accent: #7c3aed;--accent-2: #5b21b6;--accent-soft: rgba(124,58,237,.09);--accent-glow: rgba(124,58,237,.18)}.light .sidebar{background:var(--sidebar-bg);box-shadow:1px 0 0 var(--border)}.light .card{background:#fff;border-color:#00000012;box-shadow:0 2px 14px #00000012,0 1px 3px #0000000a}.light .card:hover{box-shadow:0 6px 28px #0000001a,0 2px 6px #0000000d}.light .btn-secondary{background:#fff;color:var(--text-dim);border-color:#0000001a;box-shadow:0 1px 4px #0000001a,0 0 0 1px #00000012}.light .btn-secondary:hover:not(:disabled){background:#7c3aed14;color:var(--accent);border-color:var(--accent)}.light .btn-primary{box-shadow:0 4px 18px -5px #7c3aed73}.light .btn-danger{background:#dc26261a;color:#b91c1c;border-color:#dc262640}.light .btn-danger:hover:not(:disabled){background:#dc262629}.light .badge-green{background:#16a34a1f;color:#166534;border-color:#16a34a4d}.light .badge-red{background:#dc26261a;color:#b91c1c;border-color:#dc262647}.light .badge-yellow{background:#b453091a;color:#92400e;border-color:#b4530947}.light .badge-blue,.light .badge-indigo{background:#6366f11f;color:#4338ca;border-color:#6366f147}.light .badge-gray{background:#0000000f;color:var(--text-muted);border-color:#00000024}.light .badge-purple{background:#6d28d91a;color:#6d28d9;border-color:#6d28d940}.light .badge-cyan{background:#0891b21a;color:#0e7490;border-color:#0891b242}.light .data-table th{background:#00000006;color:var(--text-dim)}.light .data-table tbody tr:hover td{background:#7c3aed09}.light .empty-state{background:#fff;border-color:#0000001a}.light .section-heading{color:var(--text-dim)}.light .error-msg{background:#dc262614;color:#b91c1c;border-color:#dc262640}.light .success-msg{background:#16a34a14;color:#15803d;border-color:#16a34a38}.light .deadline-card{box-shadow:0 4px 16px #7c3aed1a,0 2px 6px #0000000f!important}.light .deadline-card:hover{box-shadow:0 8px 26px #7c3aed29,0 3px 10px #00000014!important}body{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;background:var(--bg);color:var(--text);line-height:1.6;font-size:14px;-webkit-font-smoothing:antialiased;font-feature-settings:"cv02","cv03","cv04","cv11";min-height:100vh;overflow-x:hidden}body:before{content:"";position:fixed;top:0;right:0;bottom:0;left:0;z-index:-2;pointer-events:none;background:radial-gradient(ellipse 900px 720px at 16% 8%,rgba(217,70,239,var(--glow-op)) 0%,transparent 55%),radial-gradient(ellipse 760px 640px at 90% 92%,rgba(139,92,246,calc(var(--glow-op)*.8)) 0%,transparent 55%),radial-gradient(ellipse 620px 420px at 70% -2%,rgba(99,102,241,calc(var(--glow-op)*.65)) 0%,transparent 52%),radial-gradient(ellipse 540px 520px at 4% 96%,rgba(236,72,153,calc(var(--glow-op)*.55)) 0%,transparent 55%)}body:after{content:"";position:fixed;top:0;right:0;bottom:0;left:0;z-index:-1;pointer-events:none;background-image:var(--texture-bg);background-size:var(--texture-size);opacity:.7}body.light:before{background:radial-gradient(ellipse 800px 600px at 12% 6%,rgba(124,58,237,.07) 0%,transparent 60%),radial-gradient(ellipse 600px 400px at 88% 90%,rgba(109,40,217,.05) 0%,transparent 60%)}body.light:after{background-image:radial-gradient(circle,rgba(0,0,0,.035) 1px,transparent 1px);background-size:28px 28px}a{color:var(--accent-2);text-decoration:none}a:hover{text-decoration:underline;color:var(--accent)}button{cursor:pointer;font-family:inherit}input,textarea,select{font-family:inherit;font-size:14px}::selection{background:var(--accent-soft);color:#fff}.btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;padding:9px 18px;border-radius:var(--radius);font-size:13px;font-weight:700;border:none;transition:transform .18s ease,box-shadow .18s ease,background .18s,border-color .18s,color .18s;letter-spacing:-.01em;text-decoration:none!important;white-space:nowrap;cursor:pointer;font-family:inherit}.btn:disabled{opacity:.38;cursor:not-allowed}.btn-primary{background:linear-gradient(135deg,var(--accent),color-mix(in oklch,var(--accent) 70%,white));color:#fff;box-shadow:0 4px 18px -5px var(--accent-glow)}.btn-primary:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 6px 24px -5px var(--accent-glow)}.btn-secondary{background:var(--surface-2);color:var(--text-dim);border:1px solid var(--border-strong);box-shadow:0 1px 6px #00000040;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.btn-secondary:hover:not(:disabled){background:var(--surface-hover);color:var(--text);border-color:var(--accent);box-shadow:0 2px 10px #0000004d}.btn-danger{background:#f871712e;color:#fca5a5;border:1px solid rgba(248,113,113,.28)}.btn-danger:hover:not(:disabled){background:#f8717147}.btn-sm{padding:6px 13px;font-size:12px;border-radius:9px}.btn-lg{padding:12px 28px;font-size:15px}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);position:relative;overflow:hidden;transition:transform .2s,box-shadow .2s,border-color .2s;box-shadow:0 4px 24px #00000052,inset 0 1px #ffffff0f}.card:before{content:"";position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent 0%,rgba(255,255,255,.1) 50%,transparent 100%);pointer-events:none}.light .card,.light .btn-secondary{backdrop-filter:none;-webkit-backdrop-filter:none}.badge{display:inline-flex;align-items:center;padding:2px 8px;border-radius:999px;font-size:10px;font-weight:700;letter-spacing:.05em;text-transform:uppercase;border:1px solid transparent}.badge-green{background:#34d39924;color:#6ee7b7;border-color:#34d39947}.badge-red{background:#f8717124;color:#fca5a5;border-color:#f8717147}.badge-yellow{background:#fbbf2424;color:#fde68a;border-color:#fbbf2447}.badge-blue,.badge-indigo{background:#7c7dfa2e;color:#a5a8ff;border-color:#7c7dfa52}.badge-gray{background:#ffffff12;color:var(--text-muted);border-color:#ffffff1f}.badge-purple{background:#c084fc29;color:#e9d5ff;border-color:#c084fc47}.badge-cyan{background:#22d3ee21;color:#67e8f9;border-color:#22d3ee42}.spinner{width:20px;height:20px;border:2px solid var(--border-strong);border-top-color:var(--accent);border-radius:50%;animation:spin .6s linear infinite;display:inline-block;flex-shrink:0}@keyframes spin{to{transform:rotate(360deg)}}.error-msg{background:#f871711a;color:#fca5a5;border:1px solid rgba(248,113,113,.25);border-radius:var(--radius);padding:10px 14px;font-size:13px}.success-msg{background:#34d3991a;color:#6ee7b7;border:1px solid rgba(52,211,153,.25);border-radius:var(--radius);padding:10px 14px;font-size:13px}.form-group{display:flex;flex-direction:column;gap:6px}.form-group label{font-size:11px;font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em}.form-group input{padding:10px 14px;background:var(--surface-2);border:1px solid var(--border-strong);border-radius:var(--radius);color:var(--text);font-size:14px;outline:none;transition:border-color .15s,background .15s}.form-group input::placeholder{color:var(--text-muted)}.form-group input:focus{border-color:var(--accent);background:#d946ef0f}.form-group select{-moz-appearance:none;appearance:none;-webkit-appearance:none;padding:10px 36px 10px 14px;background:var(--surface-2);background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6' viewBox='0 0 10 6'%3E%3Cpath d='M1 1l4 4 4-4' stroke='%239b96ca' stroke-width='1.6' fill='none' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center;border:1px solid var(--border-strong);border-radius:var(--radius);color:var(--text);font-size:14px;outline:none;transition:border-color .15s,background .15s;cursor:pointer;width:100%}.form-group select:focus{border-color:var(--accent);background-color:#d946ef0f}.form-group select option{background:var(--bg-2);color:var(--text)}.input{padding:10px 14px;background:var(--surface-2);border:1px solid var(--border-strong);border-radius:var(--radius);color:var(--text);font-size:14px;outline:none;transition:border-color .15s,background .15s,box-shadow .15s;width:100%}.input::placeholder{color:var(--text-muted)}.input:focus{border-color:var(--accent);background:#d946ef0f;box-shadow:0 0 0 3px var(--accent-soft)}.select{-moz-appearance:none;appearance:none;-webkit-appearance:none;padding:7px 30px 7px 12px;background:var(--surface-2);background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6' viewBox='0 0 10 6'%3E%3Cpath d='M1 1l4 4 4-4' stroke='%239b96ca' stroke-width='1.6' fill='none' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 10px center;border:1px solid var(--border-strong);border-radius:8px;color:var(--text);font-size:12px;font-weight:600;cursor:pointer;outline:none;transition:border-color .15s}.select:hover{border-color:var(--accent)}.select:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}.select option{background:var(--bg-2);color:var(--text)}.page{display:flex;flex-direction:column;gap:14px}.page-header{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;flex-wrap:wrap}.page-header-actions{display:flex;gap:8px;flex-shrink:0}.page-title{font-size:26px;font-weight:900;color:var(--text);letter-spacing:-.035em;line-height:1.1}.page-subtitle{font-size:12px;color:var(--text-muted);margin-top:4px;font-weight:500}.section-heading{font-size:10.5px;font-weight:700;color:var(--text-dim);letter-spacing:.07em;text-transform:uppercase;margin-bottom:12px;margin-top:4px;display:flex;align-items:center;gap:9px}.section-heading:before{content:"";width:3px;height:14px;border-radius:2px;background:linear-gradient(180deg,var(--accent-2),var(--accent));flex-shrink:0;box-shadow:0 0 10px var(--accent-glow)}.data-table{width:100%;border-collapse:collapse;font-size:13px}.data-table th{padding:10px 14px;text-align:left;font-size:10px;font-weight:800;color:var(--text-dim);text-transform:uppercase;letter-spacing:.07em;border-bottom:1px solid var(--border-strong);white-space:nowrap;background:#ffffff0b}.data-table td{padding:11px 14px;border-bottom:1px solid var(--border);vertical-align:middle;color:var(--text-dim)}.data-table tbody tr:last-child td{border-bottom:none}.data-table tbody tr:hover td{background:#ffffff0f;transition:background .12s}.empty-state{text-align:center;padding:56px 24px;color:var(--text-muted);font-size:14px;background:var(--surface);border:1.5px dashed var(--border-strong);border-radius:var(--radius);display:flex;flex-direction:column;align-items:center;gap:8px}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{transform:translateY(14px)}to{transform:none}}@keyframes pageEnter{0%{transform:translateY(10px)}to{transform:none}}@keyframes fadeScale{0%{opacity:0;transform:scale(.97)}to{opacity:1;transform:scale(1)}}@keyframes shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.45}}.skeleton{background:linear-gradient(90deg,var(--surface) 0%,var(--surface-2) 50%,var(--surface) 100%);background-size:200% 100%;animation:shimmer 1.4s linear infinite;border-radius:6px}.anim-1{animation:slideUp .38s cubic-bezier(.4,0,.2,1) 0ms}.anim-2{animation:slideUp .38s cubic-bezier(.4,0,.2,1) 55ms}.anim-3{animation:slideUp .38s cubic-bezier(.4,0,.2,1) .11s}.anim-4{animation:slideUp .38s cubic-bezier(.4,0,.2,1) 165ms}.anim-5{animation:slideUp .38s cubic-bezier(.4,0,.2,1) .22s}.anim-6{animation:slideUp .38s cubic-bezier(.4,0,.2,1) 275ms}.anim-7{animation:slideUp .38s cubic-bezier(.4,0,.2,1) .33s}::-webkit-scrollbar{width:5px;height:5px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--border-strong);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:#ffffff38}input[type=range].range-themed{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:100%;height:6px;border-radius:999px;background:var(--surface-2);outline:none;cursor:pointer}input[type=range].range-themed:disabled{opacity:.5;cursor:not-allowed}input[type=range].range-themed::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:16px;height:16px;border-radius:50%;background:var(--accent-2);border:2px solid var(--accent);box-shadow:0 0 0 4px var(--accent-soft);transition:box-shadow .15s}input[type=range].range-themed:hover:not(:disabled)::-webkit-slider-thumb{box-shadow:0 0 0 6px var(--accent-soft)}input[type=range].range-themed::-moz-range-track{height:6px;border-radius:999px;background:transparent}input[type=range].range-themed::-moz-range-thumb{width:16px;height:16px;border-radius:50%;background:var(--accent-2);border:2px solid var(--accent);box-shadow:0 0 0 4px var(--accent-soft)}.page-center{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:24px}@media(prefers-reduced-motion:reduce){.anim-1,.anim-2,.anim-3,.anim-4,.anim-5,.anim-6,.anim-7{animation:none;transform:none}}@media(max-width:600px){body{font-size:13px}.card{border-radius:10px}.error-msg,.success-msg{font-size:12px}.btn-lg{padding:11px 22px;font-size:14px}.page-title{font-size:20px}}@media(max-width:560px){.hide-sm{display:none!important}}@media(max-width:390px){body{overflow-x:hidden}#root{max-width:100vw;overflow-x:hidden}}.table-scroll{overflow-x:auto;-webkit-overflow-scrolling:touch}.grad-text{background:linear-gradient(120deg,var(--accent-2) 0%,var(--cyan) 100%);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;color:transparent}.brand-grad{background:linear-gradient(120deg,#f0a0ff,#d946ef 55%,#a78bfa);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;color:transparent;filter:drop-shadow(0 0 16px rgba(217,70,239,.45))}.btn:focus-visible,button:focus-visible,a:focus-visible,[role=button]:focus-visible,[tabindex]:focus-visible{outline:2px solid var(--accent);outline-offset:2px;border-radius:inherit}html[data-skin=warm],body[data-skin=warm]{--accent: #E07A53;--accent-deep: color-mix(in oklab, var(--accent) 74%, #2a1408);--accent-soft: color-mix(in oklab, var(--accent) 15%, transparent);--accent-glow: color-mix(in oklab, var(--accent) 42%, transparent);--good-soft: color-mix(in oklab, var(--good) 16%, transparent);--warn-soft: color-mix(in oklab, var(--warn) 18%, transparent);--bad-soft: color-mix(in oklab, var(--bad) 15%, transparent);--text: var(--ink);--text-dim: var(--ink-dim);--text-muted: var(--ink-muted);--green: var(--good);--ok: var(--good);--danger: var(--bad);--purple: var(--accent-2);--violet: var(--accent-2);--indigo: var(--accent);--cyan: var(--warn);--radius: 18px;--radius-sm: calc(var(--radius) * .62);--radius-lg: calc(var(--radius) * 1.35);--gap: 16px;--pad: 22px;--fs: 1;--chip-urgent-text: var(--bad);--chip-urgent-bg: var(--bad-soft);--chip-urgent-border: color-mix(in oklab, var(--bad) 32%, transparent);--chip-soon-text: var(--warn);--chip-soon-bg: var(--warn-soft);--chip-soon-border: color-mix(in oklab, var(--warn) 34%, transparent);--chip-ok-text: var(--good);--chip-ok-bg: var(--good-soft);--chip-ok-border: color-mix(in oklab, var(--good) 32%, transparent);--progress-track: var(--surface-3);--progress-grad: linear-gradient(90deg, var(--accent), var(--warn));--prompt-bg: var(--accent-tint);--prompt-border: color-mix(in oklab, var(--accent) 30%, transparent);--prompt-icon-bg: var(--accent-soft);--logo-a: var(--accent);--logo-b: color-mix(in oklab, var(--accent) 58%, var(--warn));--logo-c: var(--warn);--logo-shadow: var(--accent-glow);--avatar-grad: linear-gradient(140deg, var(--accent), color-mix(in oklab, var(--accent) 50%, var(--warn)));--avatar-border: color-mix(in oklab, var(--accent) 55%, transparent);--avatar-glow: var(--accent-glow);--texture-bg: radial-gradient(color-mix(in oklab, var(--ink) 7%, transparent) 1px, transparent 1px);--texture-size: 26px 26px}body[data-skin=warm].light{--bg: #FBF6EC;--bg-2: #F3E9D9;--surface: #FFFDF8;--surface-2: #F6EFE2;--surface-3: #EFE6D5;--surface-hover: #F6EFE2;--ink: #352A1E;--ink-dim: #6A5C49;--ink-muted: #A2937D;--border: rgba(126,98,60,.16);--border-strong: rgba(126,98,60,.28);--line: rgba(126,98,60,.1);--accent-2: var(--accent-deep);--accent-tint: color-mix(in oklab, var(--accent) 9%, var(--surface));--good: #5E9A5B;--warn: #D99021;--bad: #D2603F;--sidebar-bg: #FFFDF8;--mobile-header-bg: rgba(255,253,248,.92);--shadow: 0 1px 2px rgba(90,60,30,.05), 0 10px 30px -14px rgba(120,80,40,.3);--shadow-lift: 0 2px 6px rgba(90,60,30,.07), 0 22px 48px -18px rgba(120,80,40,.42);--glow-op: .05;--glow-opacity: .05;color-scheme:light}body[data-skin=warm]:not(.light){--bg: #191309;--bg-2: #221809;--surface: #241B0F;--surface-2: #2E2313;--surface-3: #382B18;--surface-hover: #2E2313;--ink: #F3E9D8;--ink-dim: #C9B79C;--ink-muted: #8E7C61;--border: rgba(255,225,180,.12);--border-strong: rgba(255,225,180,.22);--line: rgba(255,225,180,.07);--accent-2: color-mix(in oklab, var(--accent) 66%, white);--accent-tint: color-mix(in oklab, var(--accent) 18%, var(--surface));--good: #6FBE6B;--warn: #ECB23E;--bad: #ED7A55;--sidebar-bg: color-mix(in oklab, #241B0F 86%, black);--mobile-header-bg: rgba(25,19,9,.92);--shadow: 0 1px 2px rgba(0,0,0,.4), 0 12px 32px -14px rgba(0,0,0,.7);--shadow-lift: 0 2px 6px rgba(0,0,0,.45), 0 26px 54px -18px rgba(0,0,0,.8);--glow-op: .12;--glow-opacity: .12;color-scheme:dark}body[data-skin=warm]{font-family:Nunito,system-ui,-apple-system,sans-serif;font-feature-settings:normal}[data-skin=warm] #node-field{display:none!important}body[data-skin=warm]:before{background:radial-gradient(120% 90% at 50% -10%,color-mix(in oklab,var(--accent) 7%,transparent) 0%,transparent 55%)!important}body[data-skin=warm]:after{background-image:radial-gradient(color-mix(in oklab,var(--ink) 7%,transparent) 1px,transparent 1px),radial-gradient(color-mix(in oklab,var(--ink) 5%,transparent) 1px,transparent 1px)!important;background-size:26px 26px,26px 26px!important;background-position:0 0,13px 13px!important;opacity:.5!important}body[data-skin=warm] ::selection{background:var(--accent-soft);color:var(--accent-deep)}body[data-skin=warm] .card{background:var(--surface);border:2px solid var(--ink);border-radius:var(--radius);padding:var(--pad);box-shadow:5px 5px color-mix(in oklab,var(--accent) 26%,transparent);backdrop-filter:none;-webkit-backdrop-filter:none;transition:transform .35s cubic-bezier(.2,.8,.2,1),box-shadow .35s,border-color .35s,background .5s}body[data-skin=warm]:not(.light) .card{border-color:var(--border-strong)}body[data-skin=warm] .card:before{display:none}body[data-skin=warm] .card.hoverable:hover{transform:translate(-2px,-2px);box-shadow:8px 8px color-mix(in oklab,var(--accent) 40%,transparent)}body[data-skin=warm] .btn{border-radius:99px;font-weight:800}body[data-skin=warm] .btn-primary{background:var(--accent);color:#fff;box-shadow:0 8px 20px -8px var(--accent-glow)}body[data-skin=warm] .btn-primary:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 12px 26px -8px var(--accent-glow)}body[data-skin=warm] .btn-secondary{background:var(--surface-2);color:var(--ink-dim);border:1px solid var(--border);box-shadow:none;backdrop-filter:none;-webkit-backdrop-filter:none}body[data-skin=warm] .btn-secondary:hover:not(:disabled){background:var(--surface-3);color:var(--ink);border-color:var(--border-strong)}body[data-skin=warm] .btn-danger{background:var(--bad-soft);color:var(--bad);border:1px solid color-mix(in oklab,var(--bad) 32%,transparent)}body[data-skin=warm] .btn-danger:hover:not(:disabled){background:color-mix(in oklab,var(--bad) 24%,transparent)}body[data-skin=warm] .badge{border-radius:99px;letter-spacing:.02em}body[data-skin=warm] .badge-green{background:var(--good-soft);color:var(--good);border-color:color-mix(in oklab,var(--good) 32%,transparent)}body[data-skin=warm] .badge-red{background:var(--bad-soft);color:var(--bad);border-color:color-mix(in oklab,var(--bad) 32%,transparent)}body[data-skin=warm] .badge-yellow{background:var(--warn-soft);color:var(--warn);border-color:color-mix(in oklab,var(--warn) 34%,transparent)}body[data-skin=warm] .badge-blue,body[data-skin=warm] .badge-indigo,body[data-skin=warm] .badge-purple{background:var(--accent-soft);color:var(--accent-2);border-color:color-mix(in oklab,var(--accent) 30%,transparent)}body[data-skin=warm] .badge-cyan{background:var(--warn-soft);color:var(--warn);border-color:color-mix(in oklab,var(--warn) 30%,transparent)}body[data-skin=warm] .badge-gray{background:var(--surface-2);color:var(--ink-muted);border-color:var(--border)}body[data-skin=warm] .form-group input:focus,body[data-skin=warm] .input:focus,body[data-skin=warm] .form-group select:focus,body[data-skin=warm] .select:focus{border-color:var(--accent);background-color:var(--accent-soft);box-shadow:0 0 0 3px var(--accent-soft)}body[data-skin=warm] .error-msg{background:var(--bad-soft);color:var(--bad);border-color:color-mix(in oklab,var(--bad) 28%,transparent)}body[data-skin=warm] .success-msg{background:var(--good-soft);color:var(--good);border-color:color-mix(in oklab,var(--good) 28%,transparent)}body[data-skin=warm] .data-table th{background:var(--surface-2);color:var(--ink-dim);border-bottom-color:var(--border-strong)}body[data-skin=warm] .data-table tbody tr:hover td{background:var(--surface-2)}[data-skin=warm] .brand-grad{background:linear-gradient(120deg,var(--accent),color-mix(in oklab,var(--accent) 55%,var(--warn)));-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;color:transparent;filter:none}[data-skin=warm] .grad-text{background:linear-gradient(120deg,var(--accent-deep),var(--accent));-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;color:transparent}body[data-skin=warm] .skeleton{background:linear-gradient(90deg,var(--surface-2) 0%,var(--surface-3) 50%,var(--surface-2) 100%);background-size:200% 100%}body[data-skin=warm] .app{display:flex;align-items:flex-start;min-height:100vh;background:var(--bg);position:relative;font-size:calc(14px * var(--fs));line-height:1.55}body[data-skin=warm] .app:before,body[data-skin=warm] .app:after{content:"";position:fixed;top:0;right:0;bottom:0;left:0;pointer-events:none;z-index:0}body[data-skin=warm] .app:before{background:radial-gradient(120% 90% at 50% -10%,color-mix(in oklab,var(--accent) 7%,transparent) 0%,transparent 55%)}body[data-skin=warm] .app:after{background-image:radial-gradient(color-mix(in oklab,var(--ink) 7%,transparent) 1px,transparent 1px),radial-gradient(color-mix(in oklab,var(--ink) 5%,transparent) 1px,transparent 1px);background-size:26px 26px,26px 26px;background-position:0 0,13px 13px;opacity:.5}body[data-skin=warm] .scroll{position:relative;z-index:1;flex:1;min-width:0}body[data-skin=warm] .canvas{max-width:1180px;margin:0 auto;padding:clamp(20px,3vw,40px) clamp(16px,3.2vw,44px) 64px}body[data-skin=warm] .sidebar{position:sticky;top:16px;align-self:flex-start;z-index:5;flex-shrink:0;width:244px;display:flex;flex-direction:column;gap:4px;margin:16px 0 16px 16px;height:calc(100vh - 32px);padding:18px 13px 14px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow);overflow-y:auto}body[data-skin=warm]:not(.light) .sidebar{background:color-mix(in oklab,var(--surface) 86%,black)}body[data-skin=warm] .brand{display:flex;align-items:center;gap:11px;padding:4px 8px 14px}body[data-skin=warm] .brand-logo{width:34px;height:34px;border-radius:11px;flex-shrink:0;background:linear-gradient(140deg,var(--accent),color-mix(in oklab,var(--accent) 55%,var(--warn)));display:grid;place-items:center;color:#fff;box-shadow:0 6px 16px -6px var(--accent-glow);transition:transform .5s cubic-bezier(.3,1.5,.4,1)}body[data-skin=warm] .brand:hover .brand-logo{transform:rotate(-10deg) scale(1.06)}body[data-skin=warm] .brand-logo svg{width:21px;height:21px}body[data-skin=warm] .brand-word{font-size:20px;font-weight:900;letter-spacing:-.04em;color:var(--ink);white-space:nowrap}body[data-skin=warm] .brand-word b{color:var(--accent-deep);font-weight:900}body[data-skin=warm]:not(.light) .brand-word b{color:color-mix(in oklab,var(--accent) 62%,white)}body[data-skin=warm] .user-chip{display:flex;align-items:center;gap:10px;padding:9px;border-radius:14px;margin-bottom:12px;background:var(--accent-tint);border:1px solid color-mix(in oklab,var(--accent) 22%,transparent)}body[data-skin=warm] .avatar{width:36px;height:36px;border-radius:11px;flex-shrink:0;background:linear-gradient(140deg,var(--accent),color-mix(in oklab,var(--accent) 50%,var(--warn)));display:grid;place-items:center;color:#fff;font-weight:900;font-size:16px;box-shadow:0 4px 12px -4px var(--accent-glow)}body[data-skin=warm] .user-meta{min-width:0;display:flex;flex-direction:column;gap:3px}body[data-skin=warm] .user-meta .email{font-size:12px;font-weight:700;color:var(--ink);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:150px}body[data-skin=warm] .nav-label{font-size:9.5px;font-weight:800;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-muted);padding:8px 12px 5px;white-space:nowrap}body[data-skin=warm] .nav{display:flex;flex-direction:column;gap:3px}body[data-skin=warm] .nav-item{position:relative;display:flex;align-items:center;gap:12px;padding:9px 12px;border-radius:12px;font-size:13.5px;font-weight:700;color:var(--ink-dim);cursor:pointer;border:1px solid transparent;transition:background .2s,color .2s,transform .2s;text-decoration:none;white-space:nowrap}body[data-skin=warm] .nav-item .nav-ic{width:22px;height:22px;flex-shrink:0;display:grid;place-items:center;color:var(--ink-muted);transition:color .2s,transform .35s cubic-bezier(.3,1.4,.5,1)}body[data-skin=warm] .nav-item .nav-ic svg{width:19px;height:19px}body[data-skin=warm] .nav-item:hover{background:var(--surface-2);color:var(--ink);transform:translate(3px);text-decoration:none}body[data-skin=warm] .nav-item:hover .nav-ic{color:var(--accent-deep);transform:rotate(-7deg) scale(1.1)}body[data-skin=warm] .nav-item.active{background:var(--accent-soft);color:var(--accent-deep);border-color:color-mix(in oklab,var(--accent) 26%,transparent)}body[data-skin=warm]:not(.light) .nav-item.active{color:color-mix(in oklab,var(--accent) 62%,white)}body[data-skin=warm] .nav-item.active .nav-ic{color:var(--accent-deep)}body[data-skin=warm]:not(.light) .nav-item.active .nav-ic{color:color-mix(in oklab,var(--accent) 62%,white)}body[data-skin=warm] .nav-item.active:before{content:"";position:absolute;left:-13px;top:50%;transform:translateY(-50%);width:4px;height:22px;border-radius:0 4px 4px 0;background:var(--accent);box-shadow:0 0 12px var(--accent-glow)}body[data-skin=warm] .nav-item .count{margin-left:auto;font-size:10.5px;font-weight:800;padding:1px 8px;border-radius:99px;background:var(--accent);color:#fff;line-height:1.5}body[data-skin=warm] .nav-item.active .count{background:var(--accent-deep)}body[data-skin=warm] .sidebar-spacer{flex:1;min-height:8px}body[data-skin=warm] .sidebar-divider{height:1px;background:var(--line);margin:8px 6px}body[data-skin=warm] .side-btn{display:flex;align-items:center;gap:11px;padding:9px 12px;border-radius:12px;width:100%;font-family:inherit;font-size:12.5px;font-weight:700;color:var(--ink-dim);background:none;border:1px solid transparent;cursor:pointer;text-align:left;transition:background .2s,color .2s;white-space:nowrap}body[data-skin=warm] .side-btn svg{width:18px;height:18px;flex-shrink:0}body[data-skin=warm] .side-btn:hover{background:var(--surface-2);color:var(--ink)}body[data-skin=warm] .side-btn.logout:hover{background:var(--bad-soft);color:var(--bad)}body[data-skin=warm] .greeting{display:flex;align-items:flex-end;justify-content:space-between;gap:20px;flex-wrap:wrap;margin-bottom:clamp(18px,2.4vw,28px)}body[data-skin=warm] .greeting>div:first-child{min-width:0}body[data-skin=warm] .greeting h1{font-size:clamp(25px,3.3vw,36px);font-weight:900;letter-spacing:-.035em;line-height:1.14;color:var(--ink);text-wrap:balance}body[data-skin=warm] .greeting .date-row{display:flex;align-items:center;gap:9px;margin-top:9px;color:var(--ink-muted);font-weight:700;font-size:calc(13px*var(--fs))}body[data-skin=warm] .greeting .date-row svg{width:16px;height:16px;color:var(--accent-deep)}body[data-skin=warm] .greeting-actions{display:flex;align-items:center;gap:9px}body[data-skin=warm] .sync-chip{display:inline-flex;align-items:center;gap:7px;padding:7px 13px;border-radius:99px;background:var(--surface);border:1px solid var(--border);box-shadow:var(--shadow);font-size:calc(12px*var(--fs));font-weight:700;color:var(--ink-dim)}body[data-skin=warm] .sync-chip .dot{width:7px;height:7px;border-radius:50%;background:var(--good);box-shadow:0 0 0 0 var(--good);animation:pingdot 2.4s ease-out infinite}@keyframes pingdot{0%{box-shadow:0 0 color-mix(in oklab,var(--good) 55%,transparent)}70%,to{box-shadow:0 0 0 7px transparent}}body[data-skin=warm] .chip{display:inline-grid;place-items:center;width:38px;height:38px;border-radius:12px;background:var(--accent-soft);color:var(--accent-deep);flex-shrink:0;transition:transform .4s cubic-bezier(.3,1.4,.5,1),background .3s}body[data-skin=warm]:not(.light) .chip{color:color-mix(in oklab,var(--accent) 60%,white)}body[data-skin=warm] .card.hoverable:hover .chip{transform:rotate(-8deg) scale(1.08)}body[data-skin=warm] .chip svg{width:20px;height:20px}body[data-skin=warm] .chip.chip-good{background:var(--good-soft);color:var(--good)}body[data-skin=warm] .chip.chip-warn{background:var(--warn-soft);color:var(--warn)}body[data-skin=warm] .chip.chip-bad{background:var(--bad-soft);color:var(--bad)}body[data-skin=warm] .card-head{display:flex;align-items:center;gap:12px;margin-bottom:16px}body[data-skin=warm] .card-head h3{font-size:calc(15px * var(--fs));font-weight:800;letter-spacing:-.01em;color:var(--ink);flex:1;line-height:1.2;margin:0}body[data-skin=warm] .head-link{font-size:calc(12px * var(--fs));font-weight:800;color:var(--accent-deep);display:inline-flex;align-items:center;gap:3px;padding:5px 9px;border-radius:99px;transition:background .2s,gap .2s;cursor:pointer;text-decoration:none;white-space:nowrap}body[data-skin=warm] .head-link:hover{background:var(--accent-soft);gap:7px;text-decoration:none}body[data-skin=warm]:not(.light) .head-link{color:color-mix(in oklab,var(--accent) 55%,white)}body[data-skin=warm] .pill{display:inline-flex;align-items:center;gap:5px;padding:3px 10px;border-radius:99px;font-size:calc(10.5px * var(--fs));font-weight:800;letter-spacing:.02em;border:1px solid transparent;white-space:nowrap}body[data-skin=warm] .pill-accent{background:var(--accent-soft);color:var(--accent-deep);border-color:color-mix(in oklab,var(--accent) 30%,transparent)}body[data-skin=warm]:not(.light) .pill-accent{color:color-mix(in oklab,var(--accent) 55%,white)}body[data-skin=warm] .pill-good{background:var(--good-soft);color:var(--good);border-color:color-mix(in oklab,var(--good) 32%,transparent)}body[data-skin=warm] .pill-warn{background:var(--warn-soft);color:var(--warn);border-color:color-mix(in oklab,var(--warn) 34%,transparent)}body[data-skin=warm] .pill-bad{background:var(--bad-soft);color:var(--bad);border-color:color-mix(in oklab,var(--bad) 32%,transparent)}body[data-skin=warm] .pill-muted{background:var(--surface-2);color:var(--ink-muted);border-color:var(--border)}body[data-skin=warm] .btn-ghost{background:var(--surface-2);color:var(--ink-dim);border:1px solid var(--border);box-shadow:none}body[data-skin=warm] .btn-ghost:hover{background:var(--surface-3);color:var(--ink);border-color:var(--border-strong)}body[data-skin=warm] .btn-ghost svg{width:16px;height:16px}@keyframes rise{0%{transform:translateY(15px)}to{transform:none}}body[data-skin=warm] .rise{animation:rise .55s cubic-bezier(.2,.8,.2,1) both}@media(prefers-reduced-motion:reduce){body[data-skin=warm] .rise{animation:none}}body[data-skin=warm] input[type=range].rng{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:100%;height:8px;border-radius:99px;background:var(--surface-3);outline:none;cursor:pointer}body[data-skin=warm] input[type=range].rng::-webkit-slider-thumb{-webkit-appearance:none;width:20px;height:20px;border-radius:50%;background:var(--accent);border:3px solid var(--surface);box-shadow:0 2px 8px -2px var(--accent-glow),0 0 0 1px var(--accent);transition:transform .15s}body[data-skin=warm] input[type=range].rng::-webkit-slider-thumb:hover{transform:scale(1.18)}body[data-skin=warm] input[type=range].rng::-moz-range-thumb{width:20px;height:20px;border-radius:50%;background:var(--accent);border:3px solid var(--surface)}body[data-skin=warm] .confetti-pc{position:fixed;z-index:9999;pointer-events:none;will-change:transform,opacity;border-radius:2px}body[data-skin=warm] .bento{display:grid;gap:var(--gap);grid-template-columns:repeat(auto-fit,minmax(min(100%,380px),1fr));align-items:start}body[data-skin=warm] .b-gpa,body[data-skin=warm] .b-deadlines,body[data-skin=warm] .b-announce,body[data-skin=warm] .b-mates{grid-column:auto;grid-row:auto}body[data-skin=warm] .gpa-card{overflow:hidden}body[data-skin=warm] .gpa-blob{position:absolute;right:-40px;top:-50px;width:240px;height:240px;z-index:0;color:var(--accent);opacity:.12;pointer-events:none;transition:transform .6s cubic-bezier(.2,.8,.2,1)}body[data-skin=warm] .gpa-card.hoverable:hover .gpa-blob{transform:rotate(18deg) scale(1.08)}body[data-skin=warm] .gpa-body{position:relative;z-index:1;display:flex;gap:clamp(18px,3vw,40px);flex-wrap:wrap;align-items:center}body[data-skin=warm] .gpa-number{display:flex;flex-direction:column}body[data-skin=warm] .gpa-big{font-size:clamp(54px,8vw,78px);font-weight:900;line-height:.9;letter-spacing:-.05em;color:var(--accent-deep);cursor:pointer;width:max-content;transition:transform .25s}body[data-skin=warm]:not(.light) .gpa-big{color:color-mix(in oklab,var(--accent) 70%,white)}body[data-skin=warm] .gpa-big:hover{transform:scale(1.04)}body[data-skin=warm] .gpa-big sub{font-size:.32em;font-weight:800;color:var(--ink-muted);letter-spacing:0;vertical-align:baseline;margin-left:4px}body[data-skin=warm] .gpa-label{font-size:calc(11px*var(--fs));font-weight:800;text-transform:uppercase;letter-spacing:.08em;color:var(--ink-muted);margin-top:8px}body[data-skin=warm] .gpa-stats{display:flex;gap:18px;margin-top:14px;flex-wrap:wrap}body[data-skin=warm] .gpa-stat .v{font-size:calc(20px*var(--fs));font-weight:900;color:var(--ink);letter-spacing:-.02em}body[data-skin=warm] .gpa-stat .k{font-size:calc(11px*var(--fs));color:var(--ink-muted);font-weight:700}body[data-skin=warm] .ring-wrap{position:relative;width:132px;height:132px;flex-shrink:0;display:grid;place-items:center}body[data-skin=warm] .ring-wrap svg{transform:rotate(-90deg);width:132px;height:132px}body[data-skin=warm] .ring-bg{fill:none;stroke:var(--surface-3);stroke-width:12}body[data-skin=warm] .ring-fg{fill:none;stroke:url(#ringgrad);stroke-width:12;stroke-linecap:round;transition:stroke-dashoffset 1.3s cubic-bezier(.3,.9,.3,1)}body[data-skin=warm] .ring-center{position:absolute;text-align:center}body[data-skin=warm] .ring-center .pct{font-size:26px;font-weight:900;color:var(--ink);letter-spacing:-.03em}body[data-skin=warm] .ring-center .lab{font-size:9.5px;font-weight:800;color:var(--ink-muted);text-transform:uppercase;letter-spacing:.06em}body[data-skin=warm] .recent-grades{margin-top:18px;padding-top:16px;border-top:1px solid var(--line);display:flex;flex-direction:column;gap:8px}body[data-skin=warm] .rg-row{display:flex;align-items:center;gap:10px}body[data-skin=warm] .rg-name{font-size:calc(13px*var(--fs));color:var(--ink-dim);font-weight:700;flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}body[data-skin=warm] .rg-bar{width:84px;height:7px;border-radius:99px;background:var(--surface-3);overflow:hidden;flex-shrink:0}body[data-skin=warm] .rg-bar>span{display:block;height:100%;border-radius:99px;transition:width 1s cubic-bezier(.3,.9,.3,1)}body[data-skin=warm] .rg-grade{font-size:calc(15px*var(--fs));font-weight:900;width:36px;text-align:right;flex-shrink:0;letter-spacing:-.02em}body[data-skin=warm] .dl-list{display:flex;flex-direction:column}body[data-skin=warm] .dl-item{position:relative;display:flex;gap:13px;padding:12px 4px 12px 0;cursor:pointer;border-radius:var(--radius-sm);transition:background .2s,transform .2s,padding .2s;text-decoration:none}body[data-skin=warm] .dl-item:hover{background:var(--surface-2);transform:translate(3px);padding-left:8px;text-decoration:none}body[data-skin=warm] .dl-rail{position:relative;width:14px;flex-shrink:0;display:flex;justify-content:center}body[data-skin=warm] .dl-rail:before{content:"";position:absolute;top:0;bottom:-24px;width:2px;background:var(--line)}body[data-skin=warm] .dl-list .dl-item:last-child .dl-rail:before{display:none}body[data-skin=warm] .dl-node{position:relative;z-index:1;width:13px;height:13px;border-radius:50%;margin-top:4px;border:3px solid var(--surface);box-shadow:0 0 0 2px currentColor}body[data-skin=warm] .dl-main{flex:1;min-width:0}body[data-skin=warm] .dl-title{font-size:calc(13px*var(--fs));font-weight:800;color:var(--ink);line-height:1.3;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}body[data-skin=warm] .dl-course{font-size:calc(11.5px*var(--fs));color:var(--ink-muted);font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}body[data-skin=warm] .dl-meta{display:flex;align-items:center;gap:7px;margin-top:5px}body[data-skin=warm] .dl-when{text-align:right;flex-shrink:0}body[data-skin=warm] .dl-when .cd{font-size:calc(12px*var(--fs));font-weight:800;white-space:nowrap}body[data-skin=warm] .dl-when .dt{font-size:calc(10px*var(--fs));color:var(--ink-muted);font-weight:600}body[data-skin=warm] .an-list{display:flex;flex-direction:column}body[data-skin=warm] .an-item{display:flex;gap:12px;padding:12px 0;border-bottom:1px solid var(--line);cursor:pointer;text-decoration:none;transition:padding .2s}body[data-skin=warm] .an-item:last-child{border-bottom:none}body[data-skin=warm] .an-item:hover{padding-left:5px;text-decoration:none}body[data-skin=warm] .an-item:hover .an-title{color:var(--accent-deep)}body[data-skin=warm]:not(.light) .an-item:hover .an-title{color:color-mix(in oklab,var(--accent) 60%,white)}body[data-skin=warm] .an-dot{width:9px;height:9px;border-radius:50%;margin-top:6px;flex-shrink:0;background:var(--accent)}body[data-skin=warm] .an-unread .an-dot{box-shadow:0 0 0 4px var(--accent-soft)}body[data-skin=warm] .an-title{font-size:calc(13px*var(--fs));font-weight:700;color:var(--ink);line-height:1.35;transition:color .2s}body[data-skin=warm] .an-meta{font-size:calc(11px*var(--fs));color:var(--ink-muted);font-weight:600;margin-top:3px}body[data-skin=warm] .mates-top{display:flex;align-items:center;gap:14px}body[data-skin=warm] .mates-num{font-size:clamp(34px,5vw,46px);font-weight:900;letter-spacing:-.04em;color:var(--accent-deep);line-height:1}body[data-skin=warm]:not(.light) .mates-num{color:color-mix(in oklab,var(--accent) 68%,white)}body[data-skin=warm] .mates-sub{font-size:calc(12.5px*var(--fs));color:var(--ink-dim);font-weight:600;line-height:1.4}body[data-skin=warm] .mate-course{display:flex;flex-direction:column;gap:3px;padding:9px 0;border-top:1px solid var(--line)}body[data-skin=warm] .mate-course-head{display:flex;align-items:center;justify-content:space-between;gap:8px}body[data-skin=warm] .mate-cn{font-size:calc(12.5px*var(--fs));font-weight:800;color:var(--ink);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}body[data-skin=warm] .mate-avs{display:flex;align-items:center}body[data-skin=warm] .mate-av{width:24px;height:24px;border-radius:50%;margin-left:-7px;flex-shrink:0;display:grid;place-items:center;font-size:10px;font-weight:800;color:#fff;border:2px solid var(--surface);transition:transform .25s}body[data-skin=warm] .mate-course:hover .mate-av{transform:translateY(-2px)}body[data-skin=warm] .mate-names{font-size:calc(11px*var(--fs));color:var(--ink-muted);font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}body[data-skin=warm] .b-sim>*{width:100%}body[data-skin=warm] .mobile-bar{display:none}@media(max-width:780px){body[data-skin=warm] .app{overflow-x:clip}body[data-skin=warm] .sidebar{position:fixed;top:16px;left:16px;height:calc(100dvh - 32px);width:250px;margin:0;border-radius:var(--radius-lg);z-index:60;transform:translate(calc(-100% - 60px));transition:transform .3s cubic-bezier(.4,0,.2,1);box-shadow:var(--shadow-lift);border:1px solid var(--border)}body[data-skin=warm] .app.menu-open .sidebar{transform:none}body[data-skin=warm] .mobile-bar{display:flex;align-items:center;gap:12px;padding:11px 16px;background:var(--surface);border-bottom:1px solid var(--border);position:relative;z-index:2}body[data-skin=warm] .mobile-bar .mobile-tab-label{margin-left:auto;font-size:calc(12px * var(--fs));font-weight:800;color:var(--ink-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:45vw}body[data-skin=warm] .scrim{position:fixed;top:0;right:0;bottom:0;left:0;background:#140c0473;z-index:55}}body[data-skin=warm] .page-head{display:flex;align-items:flex-end;justify-content:space-between;gap:20px;flex-wrap:wrap;margin-bottom:clamp(16px,2.2vw,24px)}body[data-skin=warm] .page-head>div:first-child{min-width:0}body[data-skin=warm] .page-head h1{font-size:clamp(24px,3vw,34px);font-weight:900;letter-spacing:-.035em;line-height:1.12;color:var(--ink);text-wrap:balance;margin:0}body[data-skin=warm] .page-head .sub{display:flex;align-items:center;gap:9px;margin-top:8px;color:var(--ink-muted);font-weight:700;font-size:calc(12.5px * var(--fs))}body[data-skin=warm] .page-head .sub svg{width:15px;height:15px;color:var(--accent-deep)}body[data-skin=warm] .page-head-actions{display:flex;align-items:center;gap:9px;flex-shrink:0}body[data-skin=warm] .sec-head{display:flex;align-items:center;gap:10px;font-size:calc(11px * var(--fs));font-weight:800;letter-spacing:.08em;text-transform:uppercase;color:var(--ink-muted);margin:6px 2px 12px}body[data-skin=warm] .sec-head:before{content:"";width:4px;height:15px;border-radius:99px;background:var(--accent);box-shadow:0 0 10px var(--accent-glow);flex-shrink:0}body[data-skin=warm] .sec-head .count-pill{font-size:calc(10.5px * var(--fs));font-weight:800;padding:2px 9px;border-radius:99px;background:var(--accent-soft);color:var(--accent-deep);border:1px solid color-mix(in oklab,var(--accent) 28%,transparent);letter-spacing:0}body[data-skin=warm] .page-stack{display:flex;flex-direction:column;gap:var(--gap)}body[data-skin=warm] .table-wrap{overflow-x:auto;border-radius:var(--radius)}body[data-skin=warm] .utable{width:100%;border-collapse:collapse;font-size:calc(13px * var(--fs))}body[data-skin=warm] .utable th{padding:11px 16px;text-align:left;white-space:nowrap;font-size:calc(10px * var(--fs));font-weight:800;letter-spacing:.07em;text-transform:uppercase;color:var(--ink-muted);background:var(--surface-2);border-bottom:1px solid var(--border-strong)}body[data-skin=warm] .utable td{padding:12px 16px;vertical-align:middle;color:var(--ink-dim);border-bottom:1px solid var(--line)}body[data-skin=warm] .utable tbody tr:last-child td{border-bottom:none}body[data-skin=warm] .utable tbody tr{transition:background .15s}body[data-skin=warm] .utable tbody tr:hover td{background:var(--surface-2)}body[data-skin=warm] .utable code{font-family:ui-monospace,SF Mono,Menlo,monospace;font-size:calc(11px * var(--fs));color:var(--ink-muted);letter-spacing:.02em}body[data-skin=warm] .grade-val{font-weight:900;font-size:calc(15px * var(--fs));letter-spacing:-.02em}body[data-skin=warm] .tag-new{margin-left:8px;font-size:calc(9.5px * var(--fs));font-weight:800;background:var(--good);color:#fff;border-radius:5px;padding:1px 6px;letter-spacing:.02em}body[data-skin=warm] .grade-hero{display:grid;grid-template-columns:repeat(auto-fit,minmax(190px,1fr));gap:clamp(18px,3vw,32px);align-items:center}body[data-skin=warm] .gauge{display:flex;flex-direction:column;align-items:center;gap:6px}body[data-skin=warm] .gauge svg{width:100%;max-width:190px;display:block}body[data-skin=warm] .gauge-cap{font-size:calc(11.5px * var(--fs));color:var(--ink-muted);font-weight:700;text-align:center}body[data-skin=warm] .gauge-num{font-weight:900;letter-spacing:-.04em}body[data-skin=warm] .stat-list{display:flex;flex-direction:column;gap:2px;padding:14px 18px;border-radius:var(--radius);background:var(--accent-tint);border:1px solid color-mix(in oklab,var(--accent) 18%,transparent)}body[data-skin=warm] .stat-row{display:flex;justify-content:space-between;align-items:center;padding:8px 0;border-bottom:1px solid var(--line)}body[data-skin=warm] .stat-row:last-child{border-bottom:none}body[data-skin=warm] .stat-row .k{color:var(--ink-muted);font-size:calc(11.5px * var(--fs));font-weight:700;padding-right:12px}body[data-skin=warm] .stat-row .v{font-weight:900;font-size:calc(15px * var(--fs));letter-spacing:-.02em;color:var(--ink);white-space:nowrap}body[data-skin=warm] .wtoggle{display:flex;flex-direction:column;gap:5px;align-items:flex-end}body[data-skin=warm] .wtoggle .lab{font-size:calc(9.5px * var(--fs));color:var(--ink-muted);letter-spacing:.07em;text-transform:uppercase;font-weight:800}body[data-skin=warm] .wseg{position:relative;display:inline-flex;padding:3px;border-radius:99px;background:var(--surface-3);border:1px solid var(--border)}body[data-skin=warm] .wseg .thumb{position:absolute;top:3px;bottom:3px;width:calc(50% - 3px);border-radius:99px;background:var(--accent);box-shadow:0 4px 12px -3px var(--accent-glow);transition:left .22s cubic-bezier(.4,0,.2,1)}body[data-skin=warm] .wseg button{position:relative;z-index:1;min-width:52px;padding:5px 12px;background:none;border:none;cursor:pointer;font-family:inherit;font-size:calc(12px * var(--fs));font-weight:800;color:var(--ink-muted);transition:color .2s}body[data-skin=warm] .wseg button.on{color:var(--accent-on, #fff)}body[data-skin=warm] .sem-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(190px,1fr));gap:var(--gap)}body[data-skin=warm] .sem-card{padding:15px 17px;display:flex;flex-direction:column;gap:9px;border-left:4px solid var(--c, var(--accent))}body[data-skin=warm] .sem-card .top{display:flex;justify-content:space-between;align-items:baseline}body[data-skin=warm] .sem-card .top .s{font-size:calc(12px * var(--fs));color:var(--ink-muted);font-weight:800}body[data-skin=warm] .sem-card .top .meta{font-size:calc(11px * var(--fs));color:var(--ink-muted);font-weight:600}body[data-skin=warm] .sem-card .body{display:flex;align-items:center;gap:11px}body[data-skin=warm] .sem-card .gpa{font-size:calc(26px * var(--fs));font-weight:900;letter-spacing:-.03em;color:var(--c, var(--accent));min-width:56px}body[data-skin=warm] .sem-card .bar{flex:1;height:7px;border-radius:99px;background:var(--surface-3);overflow:hidden}body[data-skin=warm] .sem-card .bar>i{display:block;height:100%;border-radius:99px;background:var(--c, var(--accent));transition:width .8s cubic-bezier(.3,.9,.3,1)}body[data-skin=warm] .histo{display:grid;grid-template-columns:repeat(6,1fr);gap:12px;align-items:end;height:170px}body[data-skin=warm] .histo .col{display:flex;flex-direction:column;align-items:center;gap:6px;height:100%;justify-content:flex-end}body[data-skin=warm] .histo .v{font-size:calc(11px * var(--fs));color:var(--ink-muted);font-weight:700;min-height:15px}body[data-skin=warm] .histo .bar{width:100%;border-radius:7px 7px 0 0;transition:height .8s cubic-bezier(.3,.9,.3,1)}body[data-skin=warm] .histo .k{font-size:calc(13px * var(--fs));font-weight:800;color:var(--ink-dim)}body[data-skin=warm] .upsell{display:flex;align-items:center;gap:16px;flex-wrap:wrap;padding:16px 20px;background:var(--accent-tint);border:1px solid color-mix(in oklab,var(--accent) 26%,transparent)}body[data-skin=warm] .upsell .ic{width:42px;height:42px;border-radius:12px;flex-shrink:0;display:grid;place-items:center;background:var(--accent-soft);color:var(--accent-deep)}body[data-skin=warm] .upsell .txt{flex:1;min-width:160px}body[data-skin=warm] .upsell .txt .t{font-weight:800;font-size:calc(13px * var(--fs));color:var(--ink)}body[data-skin=warm] .upsell .txt .d{color:var(--ink-muted);font-size:calc(12px * var(--fs));font-weight:600;margin-top:2px}body[data-skin=warm] .up-strip{display:flex;gap:var(--gap);overflow-x:auto;padding-bottom:6px;scrollbar-width:thin}body[data-skin=warm] .up-card{min-width:178px;max-width:210px;flex-shrink:0;padding:15px 16px;display:flex;flex-direction:column;gap:9px;cursor:pointer;border-left:4px solid var(--c, var(--accent))}body[data-skin=warm] .up-card .ttl{font-size:calc(13px * var(--fs));font-weight:800;color:var(--ink);line-height:1.35;flex:1}body[data-skin=warm] .up-card .crs{font-size:calc(11px * var(--fs));color:var(--ink-muted);font-weight:600}body[data-skin=warm] .up-card .foot{border-top:1px solid var(--line);padding-top:9px;display:flex;flex-direction:column;gap:4px}body[data-skin=warm] .up-card.sel{border-color:var(--c, var(--accent));box-shadow:0 0 0 2px color-mix(in oklab,var(--c, var(--accent)) 40%,transparent)}body[data-skin=warm] .dchip{display:inline-flex;align-items:center;gap:4px;padding:3px 10px;border-radius:99px;font-size:calc(10.5px * var(--fs));font-weight:800;white-space:nowrap;border:1px solid transparent}body[data-skin=warm] .dchip svg{width:12px;height:12px}body[data-skin=warm] .dchip.urgent{background:var(--bad-soft);color:var(--bad);border-color:color-mix(in oklab,var(--bad) 32%,transparent)}body[data-skin=warm] .dchip.soon{background:var(--warn-soft);color:var(--warn);border-color:color-mix(in oklab,var(--warn) 34%,transparent)}body[data-skin=warm] .dchip.ok{background:var(--good-soft);color:var(--good);border-color:color-mix(in oklab,var(--good) 32%,transparent)}body[data-skin=warm] .dwhen{font-size:calc(10px * var(--fs));color:var(--ink-muted);font-weight:600}body[data-skin=warm] .cgroup{overflow:hidden;padding:0}body[data-skin=warm] .cgroup-btn{width:100%;display:flex;align-items:center;gap:13px;padding:15px 18px;background:none;border:none;cursor:pointer;text-align:left;font-family:inherit;transition:background .15s}body[data-skin=warm] .cgroup-btn:hover{background:var(--surface-2)}body[data-skin=warm] .cgroup-btn .nm{flex:1;min-width:0}body[data-skin=warm] .cgroup-btn .nm .t{font-weight:800;font-size:calc(13.5px * var(--fs));color:var(--ink)}body[data-skin=warm] .cgroup-btn .nm .m{font-size:calc(11px * var(--fs));color:var(--ink-muted);font-weight:600;margin-top:2px;display:flex;gap:9px;flex-wrap:wrap}body[data-skin=warm] .cgroup-btn .chev{flex-shrink:0;color:var(--ink-muted);transition:transform .2s}body[data-skin=warm] .cgroup-btn .chev.open{transform:rotate(180deg)}body[data-skin=warm] .cgroup-body{border-top:1px solid var(--border)}body[data-skin=warm] .drow{display:flex;align-items:flex-start;gap:13px;padding:13px 18px 13px 15px;border-bottom:1px solid var(--line);transition:background .15s}body[data-skin=warm] .drow:last-child{border-bottom:none}body[data-skin=warm] .drow:hover{background:var(--surface-2)}body[data-skin=warm] .drow.sel{background:var(--accent-tint)}body[data-skin=warm] .drow .rail{width:4px;align-self:stretch;border-radius:99px;background:var(--c, var(--accent));flex-shrink:0;margin-top:2px}body[data-skin=warm] .drow .main{flex:1;min-width:0}body[data-skin=warm] .drow .main .t{font-weight:800;font-size:calc(13px * var(--fs));color:var(--ink);line-height:1.35}body[data-skin=warm] .drow .main .dmeta{display:flex;flex-wrap:wrap;gap:3px 12px;margin-top:5px}body[data-skin=warm] .drow .main .dmeta span{display:inline-flex;align-items:center;gap:4px;font-size:calc(11px * var(--fs));font-weight:700;color:var(--ink-muted);min-width:0}body[data-skin=warm] .drow .main .dmeta svg{color:var(--accent-deep);flex-shrink:0}body[data-skin=warm] .drow .main .raw{font-size:calc(11.5px * var(--fs));color:var(--ink-muted);margin-top:4px;line-height:1.5;cursor:pointer;font-style:italic}body[data-skin=warm] .drow .main .raw .more{margin-left:5px;font-size:calc(10px * var(--fs));color:var(--accent-deep);font-style:normal;font-weight:800}body[data-skin=warm] .drow .right{text-align:right;flex-shrink:0;display:flex;flex-direction:column;align-items:flex-end;gap:4px}body[data-skin=warm] .drow .ddate{flex-shrink:0;display:flex;flex-direction:column;align-items:center;justify-content:center;min-width:46px;padding:5px 8px;border-radius:12px;background:var(--surface-2);border:1px solid var(--line);margin-top:1px;line-height:1}body[data-skin=warm] .drow .ddate-wd{font-size:calc(9.5px * var(--fs));font-weight:800;color:var(--ink-muted);text-transform:uppercase;letter-spacing:.05em}body[data-skin=warm] .drow .ddate-day{font-size:calc(20px * var(--fs));font-weight:800;color:var(--ink);margin:1px 0}body[data-skin=warm] .drow .ddate-mo{font-size:calc(10px * var(--fs));font-weight:800;color:var(--accent-deep);text-transform:uppercase;letter-spacing:.04em}body[data-skin=warm] .drow .dtype{font-size:calc(11px * var(--fs));color:var(--ink-muted);font-weight:700}body[data-skin=warm] .drow.masked{align-items:center;gap:12px;opacity:.55}body[data-skin=warm] .drow.masked svg{color:var(--ink-muted);flex-shrink:0}body[data-skin=warm] .drow.masked span{font-size:calc(12px * var(--fs));color:var(--ink-muted);font-style:italic}body[data-skin=warm] .acc{overflow:hidden;padding:0}body[data-skin=warm] .acc-btn{width:100%;display:flex;align-items:center;gap:13px;padding:15px 18px;background:none;border:none;cursor:pointer;text-align:left;font-family:inherit;transition:background .15s}body[data-skin=warm] .acc-btn:hover{background:var(--surface-2)}body[data-skin=warm] .acc-btn .dot{width:9px;height:9px;border-radius:50%;flex-shrink:0}body[data-skin=warm] .acc-btn .date{font-size:calc(11px * var(--fs));color:var(--ink-muted);white-space:nowrap;flex-shrink:0;font-weight:600}body[data-skin=warm] .acc-btn .t{flex:1;font-weight:700;font-size:calc(13.5px * var(--fs));color:var(--ink);line-height:1.4}body[data-skin=warm] .acc-btn .chev{flex-shrink:0;color:var(--ink-muted);transition:transform .2s}body[data-skin=warm] .acc-btn .chev.open{transform:rotate(180deg)}body[data-skin=warm] .acc-body{padding:14px 20px 18px;border-top:1px solid var(--border);font-size:calc(13px * var(--fs));color:var(--ink-dim);line-height:1.75;animation:warmFadeInUp .25s ease both}body[data-skin=warm] .acc-body p{margin:0 0 8px}body[data-skin=warm] .acc-body ul{margin:6px 0 6px 18px}body[data-skin=warm] .acc-body li{margin:2px 0}@keyframes warmFadeInUp{0%{opacity:0;transform:translateY(4px)}to{opacity:1;transform:none}}body[data-skin=warm] .lb-banner{display:flex;align-items:center;gap:clamp(20px,4vw,40px);flex-wrap:wrap;padding:20px 24px;background:var(--accent-tint);border:1px solid color-mix(in oklab,var(--accent) 24%,transparent)}body[data-skin=warm] .lb-stat{display:flex;flex-direction:column;gap:3px}body[data-skin=warm] .lb-stat .k{font-size:calc(10.5px * var(--fs));color:var(--ink-muted);letter-spacing:.06em;text-transform:uppercase;font-weight:800}body[data-skin=warm] .lb-stat .v{font-size:clamp(26px,3.4vw,34px);font-weight:900;line-height:1;letter-spacing:-.03em;color:var(--ink)}body[data-skin=warm] .lb-stat .v.accent{color:var(--accent-deep)}body[data-skin=warm]:not(.light) .lb-stat .v.accent{color:color-mix(in oklab,var(--accent) 66%,white)}body[data-skin=warm] .lb-rank{font-weight:900;font-variant-numeric:tabular-nums}body[data-skin=warm] .lb-row-me td{background:var(--accent-tint)!important;font-weight:800}body[data-skin=warm] .lb-row-me td:first-child{box-shadow:inset 3px 0 0 var(--accent)}body[data-skin=warm] .lb-bar{height:6px;border-radius:99px;background:var(--surface-3);overflow:hidden;min-width:60px;flex:1}body[data-skin=warm] .lb-bar>i{display:block;height:100%;border-radius:99px;transition:width .8s cubic-bezier(.3,.9,.3,1)}body[data-skin=warm] .set-card{padding:22px 24px;display:flex;flex-direction:column;gap:15px}body[data-skin=warm] .set-card h3{font-size:calc(15px * var(--fs));font-weight:800;color:var(--ink);letter-spacing:-.01em;margin:0}body[data-skin=warm] .set-card .desc{font-size:calc(12px * var(--fs));color:var(--ink-muted);line-height:1.6;margin-top:3px;font-weight:600}body[data-skin=warm] .set-card.danger{border-color:color-mix(in oklab,var(--bad) 34%,var(--border))}body[data-skin=warm] .inforow{display:flex;align-items:center;gap:12px;font-size:calc(13px * var(--fs))}body[data-skin=warm] .inforow .k{color:var(--ink-muted);min-width:96px;font-size:calc(10.5px * var(--fs));font-weight:800;text-transform:uppercase;letter-spacing:.05em}body[data-skin=warm] .inforow .v{color:var(--ink-dim);font-weight:600}body[data-skin=warm] .seg-2{display:flex;gap:9px}body[data-skin=warm] .seg-opt{flex:1;padding:11px 14px;border-radius:var(--radius-sm);border:1px solid var(--border);background:var(--surface-2);font-family:inherit;font-size:calc(13px * var(--fs));font-weight:800;cursor:pointer;color:var(--ink-muted);transition:all .18s;display:inline-flex;align-items:center;justify-content:center;gap:7px}body[data-skin=warm] .seg-opt:hover{color:var(--ink);border-color:var(--border-strong)}body[data-skin=warm] .seg-opt.on{border-color:color-mix(in oklab,var(--accent) 45%,transparent);background:var(--accent-soft);color:var(--accent-deep)}body[data-skin=warm]:not(.light) .seg-opt.on{color:color-mix(in oklab,var(--accent) 62%,white)}body[data-skin=warm] .field{padding:10px 13px;background:var(--surface-2);border:1px solid var(--border-strong);border-radius:var(--radius-sm);color:var(--ink);font-size:calc(13px * var(--fs));font-family:inherit;outline:none;transition:border-color .18s;width:100%}body[data-skin=warm] .field:focus{border-color:var(--accent)}body[data-skin=warm] .field-mono{font-family:ui-monospace,SF Mono,Menlo,monospace;font-size:calc(12px * var(--fs));color:var(--ink-muted)}body[data-skin=warm] .check-row{display:flex;align-items:center;gap:10px;cursor:pointer;font-size:calc(13px * var(--fs));color:var(--ink-dim);font-weight:600}body[data-skin=warm] .check-row input{width:17px;height:17px;accent-color:var(--accent);cursor:pointer}body[data-skin=warm] .field-lab{font-size:calc(10.5px * var(--fs));font-weight:800;color:var(--ink-muted);text-transform:uppercase;letter-spacing:.05em;margin-bottom:6px;display:block}body[data-skin=warm] .success-note{background:var(--good-soft);color:var(--good);border:1px solid color-mix(in oklab,var(--good) 30%,transparent);border-radius:var(--radius-sm);padding:10px 14px;font-size:calc(12.5px * var(--fs));font-weight:700}body[data-skin=warm] .ref-grid{display:flex;gap:9px;flex-wrap:wrap}body[data-skin=warm] .ref-tier{flex:1;min-width:82px;padding:10px 12px;border-radius:var(--radius-sm);text-align:center;border:1px solid var(--border);background:var(--surface-2);font-size:calc(12px * var(--fs))}body[data-skin=warm] .ref-tier.done{border-color:color-mix(in oklab,var(--good) 35%,transparent);background:var(--good-soft)}body[data-skin=warm] .ref-tier .n{font-weight:800;color:var(--ink-muted);margin-bottom:2px}body[data-skin=warm] .ref-tier.done .n,body[data-skin=warm] .ref-tier.done .l{color:var(--good)}body[data-skin=warm] .ref-tier .l{color:var(--ink-muted)}body[data-skin=warm] .books-empty{text-align:center;padding:clamp(40px,8vw,80px) 28px;display:flex;flex-direction:column;align-items:center;gap:16px;border:1.5px dashed var(--border-strong);box-shadow:none}body[data-skin=warm] .books-empty .ic{width:72px;height:72px;border-radius:22px;display:grid;place-items:center;background:var(--accent-soft);color:var(--accent-deep)}body[data-skin=warm] .books-empty .ic svg{width:34px;height:34px}body[data-skin=warm] .books-empty h2{font-size:clamp(20px,2.6vw,26px);font-weight:900;letter-spacing:-.03em;color:var(--ink);margin:0}body[data-skin=warm] .books-empty p{color:var(--ink-muted);font-size:calc(13.5px * var(--fs));font-weight:600;max-width:380px;line-height:1.6;margin:0}body[data-skin=warm] .books-empty .pill{margin-top:4px}body[data-skin=warm] .sim-grid{display:grid;grid-template-columns:1.4fr 1fr;gap:clamp(18px,3vw,32px);align-items:center}@media(max-width:720px){body[data-skin=warm] .sim-grid{grid-template-columns:1fr}}body[data-skin=warm] .sim-rows{display:flex;flex-direction:column;gap:16px}body[data-skin=warm] .sim-row{display:grid;grid-template-columns:1fr auto;gap:6px 12px;align-items:center}body[data-skin=warm] .sim-rn{font-size:calc(13px*var(--fs));font-weight:800;color:var(--ink)}body[data-skin=warm] .sim-re{font-size:calc(11px*var(--fs));color:var(--ink-muted);font-weight:600}body[data-skin=warm] .sim-val{font-size:calc(17px*var(--fs));font-weight:900;color:var(--accent-deep);min-width:40px;text-align:right;letter-spacing:-.02em}body[data-skin=warm]:not(.light) .sim-val{color:color-mix(in oklab,var(--accent) 66%,white)}body[data-skin=warm] .sim-row input[type=range]{grid-column:1 / -1}body[data-skin=warm] .sim-out{text-align:center;padding:18px;border-radius:var(--radius);background:var(--accent-tint);border:1px dashed color-mix(in oklab,var(--accent) 32%,transparent)}body[data-skin=warm] .sim-out .proj{font-size:clamp(40px,6vw,58px);font-weight:900;color:var(--accent-deep);letter-spacing:-.04em;line-height:1}body[data-skin=warm]:not(.light) .sim-out .proj{color:color-mix(in oklab,var(--accent) 70%,white)}body[data-skin=warm] .sim-out .lab{font-size:calc(11px*var(--fs));font-weight:800;text-transform:uppercase;letter-spacing:.07em;color:var(--ink-muted);margin-top:8px}body[data-skin=warm] .sim-delta{display:inline-flex;align-items:center;gap:5px;margin-top:12px;font-size:calc(13px*var(--fs));font-weight:800}@media(max-width:560px){html[data-skin=warm],body[data-skin=warm]{--pad: 16px;--gap: 13px}body[data-skin=warm] .canvas{padding:18px 14px 40px}body[data-skin=warm] .greeting{margin-bottom:16px}body[data-skin=warm] .greeting h1{font-size:clamp(22px,5.6vw,25px)}body[data-skin=warm] .gpa-big{font-size:clamp(42px,12.5vw,54px)}body[data-skin=warm] .ring-wrap,body[data-skin=warm] .ring-wrap svg{width:116px;height:116px}body[data-skin=warm] .mates-num{font-size:clamp(28px,7vw,34px)}body[data-skin=warm] .page-head{margin-bottom:14px}body[data-skin=warm] .page-head h1{font-size:clamp(22px,6vw,24px)}body[data-skin=warm] .page-head-actions{flex-wrap:wrap}body[data-skin=warm] .histo{height:150px;gap:8px}body[data-skin=warm] .lb-banner{padding:16px;gap:18px}body[data-skin=warm] .set-card{padding:18px 16px}body[data-skin=warm] .utable th,body[data-skin=warm] .utable td{padding:10px 12px}body[data-skin=warm] .inforow{flex-direction:column;align-items:flex-start;gap:4px}body[data-skin=warm] .inforow .k{min-width:0}}body[data-skin=warm] .btn:focus-visible,body[data-skin=warm] button:focus-visible,body[data-skin=warm] a:focus-visible,body[data-skin=warm] .nav-item:focus-visible,body[data-skin=warm] [role=button]:focus-visible,body[data-skin=warm] [tabindex]:focus-visible{outline:2px solid var(--accent);outline-offset:2px}._page_2w6h9_2{min-height:100vh;display:flex;flex-direction:column;position:relative;z-index:1;width:100%;max-width:100%;overflow-x:clip}._wrap_2w6h9_14{max-width:1200px;margin:0 auto;padding:0 32px;width:100%}._nav_2w6h9_22{position:sticky;top:0;z-index:60;background:#07040fb8;backdrop-filter:blur(24px) saturate(160%);-webkit-backdrop-filter:blur(24px) saturate(160%);border-bottom:1px solid var(--border)}._navIn_2w6h9_31{display:flex;align-items:center;justify-content:space-between;height:68px;max-width:1200px;margin:0 auto;padding:0 32px}._brand_2w6h9_40{display:inline-flex;align-items:center;gap:11px;text-decoration:none}._brandWord_2w6h9_46{font-size:19px;font-weight:900;letter-spacing:-.045em;color:var(--text)}._navLinks_2w6h9_52{display:flex;align-items:center;gap:28px}._link_2w6h9_57{font-size:14px;font-weight:600;color:var(--text-muted);text-decoration:none;transition:color .16s}._link_2w6h9_57:hover{color:var(--text)}._arr_2w6h9_65{transition:transform .2s ease;display:inline-block}._btnGhost_2w6h9_68{display:inline-flex;align-items:center;justify-content:center;gap:9px;padding:14px 22px;font-size:15px;font-weight:700;font-family:inherit;color:var(--text-dim);background:var(--surface-2);border:1px solid var(--border-strong);border-radius:13px;cursor:pointer;text-decoration:none;white-space:nowrap;letter-spacing:-.01em;transition:color .18s,background .18s,border-color .18s}._btnGhost_2w6h9_68:hover{color:var(--text);border-color:var(--accent);background:var(--surface-hover);text-decoration:none}._hero_2w6h9_95{display:grid;grid-template-columns:1.02fr .98fr;gap:64px;align-items:center;padding:84px 0 96px}._heroL_2w6h9_102{display:flex;flex-direction:column;gap:26px;min-width:0}._heroRWrap_2w6h9_108,._heroR_2w6h9_108{position:relative}._eyebrow_2w6h9_116{display:inline-flex;align-items:center;gap:10px;align-self:flex-start;padding:7px 14px 7px 11px;border-radius:999px;background:var(--accent-soft);border:1px solid rgba(217,70,239,.25);font-size:12px;font-weight:600;letter-spacing:.01em;color:var(--accent-2)}._dot_2w6h9_130{width:7px;height:7px;border-radius:50%;background:var(--green);box-shadow:0 0 10px #34d399b3;flex-shrink:0;animation:_pulse_2w6h9_1 2.2s ease-in-out infinite}@keyframes _pulse_2w6h9_1{0%,to{opacity:1}50%{opacity:.45}}._heroH_2w6h9_142{font-size:clamp(46px,6vw,78px);font-weight:900;line-height:.98;letter-spacing:-.045em}._ln_2w6h9_148{display:block}._heroLede_2w6h9_151{font-size:17.5px;line-height:1.62;color:var(--text-dim);max-width:500px}._heroLede_2w6h9_151 strong{color:var(--text);font-weight:700}._heroCta_2w6h9_160{display:flex;align-items:center;gap:14px;flex-wrap:wrap}._heroMeta_2w6h9_168{display:flex;align-items:center;gap:16px;flex-wrap:wrap;font-size:12.5px;color:var(--text-muted);font-weight:500}._heroMeta_2w6h9_168 strong{color:var(--text-dim);font-weight:700}._sep_2w6h9_178{width:4px;height:4px;border-radius:50%;background:var(--border-strong);flex-shrink:0}._preview_2w6h9_187{position:relative;background:linear-gradient(180deg,#ffffff0d,#ffffff06);border:1px solid var(--border-strong);border-radius:20px;padding:22px;backdrop-filter:blur(22px);-webkit-backdrop-filter:blur(22px);box-shadow:0 40px 90px -34px #000000d9,inset 0 1px #ffffff12;animation:_floaty_2w6h9_1 7s ease-in-out infinite}@keyframes _floaty_2w6h9_1{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}._preview_2w6h9_187:before{content:"";position:absolute;top:0;left:0;right:0;height:1px;border-radius:20px 20px 0 0;background:linear-gradient(90deg,transparent,rgba(255,255,255,.16) 50%,transparent)}._pvHead_2w6h9_208{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;padding-bottom:16px;border-bottom:1px solid var(--border);margin-bottom:18px}._pvTtl_2w6h9_217{font-size:15px;font-weight:800;letter-spacing:-.02em}._pvSub_2w6h9_218{font-size:11.5px;color:var(--text-muted);margin-top:2px}._pvSync_2w6h9_219{display:inline-flex;align-items:center;gap:6px;font-size:10.5px;font-weight:700;letter-spacing:.05em;text-transform:uppercase;color:var(--green);padding:4px 9px;border-radius:999px;background:#34d3991a;border:1px solid rgba(52,211,153,.25);flex-shrink:0}._pvDot_2w6h9_234{width:5px;height:5px;border-radius:50%;background:var(--green);box-shadow:0 0 8px #34d399b3;animation:_pulse_2w6h9_1 1.6s ease-in-out infinite}._pvTop_2w6h9_243{display:grid;grid-template-columns:auto 1fr;gap:22px;align-items:center;margin-bottom:18px}._gauge_2w6h9_250{width:124px;height:124px;flex-shrink:0}._pvStats_2w6h9_256{display:flex;flex-direction:column;gap:10px}._pvStat_2w6h9_256{display:flex;align-items:center;justify-content:space-between;border-bottom:1px solid var(--border);padding-bottom:9px}._pvStat_2w6h9_256:last-child{border-bottom:none;padding-bottom:0}._pvK_2w6h9_265{font-size:12px;color:var(--text-muted)}._pvV_2w6h9_266{font-size:14px;font-weight:800;color:var(--text)}._pvAccent_2w6h9_267{color:var(--accent-2)!important}._pvCourses_2w6h9_270{display:flex;flex-direction:column;gap:2px}._pvCourse_2w6h9_270{display:grid;grid-template-columns:1fr auto;gap:12px;align-items:center;padding:9px 4px;border-radius:8px;transition:background .16s}._pvCourse_2w6h9_270:hover{background:var(--surface)}._pvCi_2w6h9_281{display:flex;flex-direction:column;gap:6px;min-width:0}._pvCn_2w6h9_282{font-size:12.5px;font-weight:500;color:var(--text-dim);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}._pvBar_2w6h9_290{height:3px;border-radius:3px;background:#ffffff12;overflow:hidden}._pvBar_2w6h9_290 i{display:block;height:100%;border-radius:3px}._pvG_2w6h9_301{font-size:16px;font-weight:800;min-width:30px;text-align:right;letter-spacing:-.02em}._gHi_2w6h9_308{color:var(--green)}._pvBar_2w6h9_290 .gHi{background:var(--green);box-shadow:0 0 6px #34d39980}._gMid_2w6h9_310{color:var(--accent-2)}._pvBar_2w6h9_290 .gMid{background:var(--accent);box-shadow:0 0 6px var(--accent-glow)}._pvDeadline_2w6h9_314{position:absolute;right:-20px;bottom:-26px;width:220px;background:#0d0b1cf5;backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border:1px solid rgba(217,70,239,.3);border-radius:14px;padding:13px 15px;box-shadow:0 24px 54px -16px #000c,0 0 26px -8px var(--accent-glow);animation:_floaty2_2w6h9_1 6s ease-in-out infinite}@keyframes _floaty2_2w6h9_1{0%,to{transform:translateY(0)}50%{transform:translateY(-9px)}}._pvDlTop_2w6h9_329{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px}._pvDlLbl_2w6h9_335{font-size:9.5px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--text-muted)}._pvDlUrg_2w6h9_342{display:inline-flex;align-items:center;gap:5px;font-size:10.5px;font-weight:800;color:#fca5a5}._pvDlDot_2w6h9_350{width:5px;height:5px;border-radius:50%;background:#f87171;box-shadow:0 0 8px #f87171b3;animation:_pulse_2w6h9_1 1s ease-in-out infinite}._pvDlTitle_2w6h9_358{font-size:14.5px;font-weight:800;letter-spacing:-.02em;margin-bottom:2px}._pvDlMeta_2w6h9_364{font-size:11px;color:var(--text-muted)}._pvDlPbar_2w6h9_365{margin-top:10px;height:3px;border-radius:3px;background:#ffffff14;overflow:hidden}._pvDlPbarFill_2w6h9_372{display:block;height:100%;border-radius:3px;width:0;background:linear-gradient(90deg,var(--accent),var(--cyan));animation:_dlbar_2w6h9_1 2.4s ease-out .4s forwards}@keyframes _dlbar_2w6h9_1{to{width:74%}}._stats_2w6h9_383{padding:26px 0;border-top:1px solid var(--border);border-bottom:1px solid var(--border);background:#ffffff03}._statsG_2w6h9_389{display:grid;grid-template-columns:repeat(4,1fr)}._stat_2w6h9_383{padding:8px 28px;border-left:1px solid var(--border)}._stat_2w6h9_383:first-child{border-left:none;padding-left:0}._statN_2w6h9_398{font-size:44px;font-weight:900;letter-spacing:-.04em;line-height:1;font-variant-numeric:tabular-nums}._statU_2w6h9_405{font-size:.46em;color:var(--text-muted);font-weight:700;margin-left:2px}._statL_2w6h9_411{font-size:12px;color:var(--text-muted);margin-top:8px;font-weight:500}._sec_2w6h9_419{padding:96px 0 0}._secHead_2w6h9_422{display:flex;flex-direction:column;gap:16px;max-width:680px;margin-bottom:44px}._secHead_2w6h9_422 h2{font-size:clamp(32px,4vw,50px);font-weight:900;letter-spacing:-.04em;line-height:1.04}._secHead_2w6h9_422 p{font-size:16px;color:var(--text-dim);line-height:1.6}._sectionTag_2w6h9_440{font-size:12px;font-weight:700;letter-spacing:.04em;color:var(--accent-2);text-transform:uppercase;display:inline-flex;align-items:center;gap:10px}._sectionTag_2w6h9_440:before{content:"";width:22px;height:2px;border-radius:2px;background:var(--accent);box-shadow:0 0 8px var(--accent-glow)}._featG_2w6h9_460{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}._feat_2w6h9_460{display:flex;flex-direction:column;gap:14px;padding:26px 24px 24px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);position:relative;overflow:hidden;transition:transform .22s ease,border-color .22s,box-shadow .22s,background .22s}._feat_2w6h9_460:before{content:"";position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,rgba(255,255,255,.12) 50%,transparent)}._feat_2w6h9_460:hover{transform:translateY(-4px);background:var(--surface-2);border-color:#d946ef52;box-shadow:0 20px 48px -18px #000000b3}._feat_2w6h9_460 h3{font-size:19px;font-weight:800;letter-spacing:-.025em}._feat_2w6h9_460 p{font-size:14px;color:var(--text-dim);line-height:1.62;flex:1}._feat_2w6h9_460 p strong{color:var(--text);font-weight:700}._featIc_2w6h9_494{width:46px;height:46px;border-radius:13px;display:flex;align-items:center;justify-content:center;color:var(--accent-2);background:var(--accent-soft);border:1px solid rgba(217,70,239,.26)}._featIcCy_2w6h9_505{color:var(--cyan);background:#22d3ee1f;border-color:#22d3ee42}._featIcVi_2w6h9_510{color:#d8b4fe;background:#8b5cf624;border-color:#8b5cf64d}._featFoot_2w6h9_516{display:flex;align-items:center;justify-content:space-between;padding-top:14px;margin-top:4px;border-top:1px solid var(--border)}._featPriceFree_2w6h9_524{font-size:17px;font-weight:800;letter-spacing:-.02em;color:var(--green)}._featPrice_2w6h9_524{font-size:17px;font-weight:800;letter-spacing:-.02em}._per_2w6h9_535{font-size:11px;color:var(--text-muted);font-weight:500}._featTag_2w6h9_540{font-size:10px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--text-muted);padding:4px 9px;border-radius:999px;border:1px solid var(--border)}._stepsG_2w6h9_552{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}._step_2w6h9_552{padding:26px 24px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);display:flex;flex-direction:column;gap:12px}._step_2w6h9_552 h4{font-size:17px;font-weight:800;letter-spacing:-.025em;line-height:1.25}._step_2w6h9_552 p{font-size:13.5px;color:var(--text-dim);line-height:1.6}._stepN_2w6h9_568{width:36px;height:36px;border-radius:11px;display:flex;align-items:center;justify-content:center;font-size:15px;font-weight:900;color:var(--accent-2);background:var(--accent-soft);border:1px solid rgba(217,70,239,.26)}._cta_2w6h9_583{padding:120px 32px 130px;text-align:center;position:relative}._ctaW_2w6h9_588{max-width:660px;margin:0 auto;width:100%;display:flex;flex-direction:column;align-items:center;gap:26px}._cta_2w6h9_583 h2{font-size:clamp(40px,6vw,68px);font-weight:900;letter-spacing:-.045em;line-height:.98}._cta_2w6h9_583 p{font-size:17px;color:var(--text-dim);max-width:460px}._footer_2w6h9_606{border-top:1px solid var(--border);padding:30px 0}._foot_2w6h9_606{display:flex;align-items:center;justify-content:space-between;gap:16px;flex-wrap:wrap}._footBrand_2w6h9_617{display:inline-flex;align-items:center;gap:10px;text-decoration:none}._footWord_2w6h9_623{font-size:17px;font-weight:900;letter-spacing:-.045em;color:var(--text)}._footC_2w6h9_629{font-size:12.5px;color:var(--text-muted)}._footR_2w6h9_630{display:inline-flex;align-items:center;gap:8px;font-size:12.5px;color:var(--text-muted)}._footDot_2w6h9_637{width:6px;height:6px;border-radius:50%;background:var(--green);box-shadow:0 0 8px #34d39999;animation:_pulse_2w6h9_1 2s ease-in-out infinite}._rv_2w6h9_647{opacity:0;transform:translateY(20px);transition:opacity .7s ease,transform .7s cubic-bezier(.4,0,.2,1)}._on_2w6h9_652{opacity:1;transform:none}.light ._nav_2w6h9_22{background:#f7f5ffeb;border-bottom-color:#00000014}@media(max-width:980px){._hero_2w6h9_95{grid-template-columns:1fr;gap:56px;padding:60px 0 80px}._heroRWrap_2w6h9_108{display:none}._statsG_2w6h9_389{grid-template-columns:repeat(2,1fr);gap:26px 0}._stat_2w6h9_383:nth-child(3){border-left:none;padding-left:0}._featG_2w6h9_460,._stepsG_2w6h9_552{grid-template-columns:1fr}._navLinks_2w6h9_52 ._link_2w6h9_57{display:none}}@media(max-width:560px){._wrap_2w6h9_14,._navIn_2w6h9_31{padding:0 20px}._cta_2w6h9_583{padding:88px 20px 96px}._hero_2w6h9_95{padding:48px 0 64px}._sec_2w6h9_419{padding:72px 0 0}._heroCta_2w6h9_160{width:100%}._statsG_2w6h9_389{grid-template-columns:1fr 1fr}._stat_2w6h9_383{padding:8px 16px}._statN_2w6h9_398{font-size:36px}}@media(max-width:400px){._wrap_2w6h9_14,._navIn_2w6h9_31{padding:0 16px}._cta_2w6h9_583{padding:80px 16px 88px}._heroH_2w6h9_142{font-size:clamp(38px,11vw,46px)}._heroH_2w6h9_142 ._ln_2w6h9_148,._heroLede_2w6h9_151,._secHead_2w6h9_422 h2,._cta_2w6h9_583 h2{overflow-wrap:break-word}}@media(prefers-reduced-motion:reduce){._rv_2w6h9_647{opacity:1;transform:none}._preview_2w6h9_187,._pvDeadline_2w6h9_314,._dot_2w6h9_130,._pvDot_2w6h9_234,._pvDlDot_2w6h9_350,._footDot_2w6h9_637{animation:none}}[data-skin=warm] ._nav_2w6h9_22{background:color-mix(in oklab,var(--surface) 82%,transparent);border-bottom-color:var(--border)}[data-skin=warm] ._eyebrow_2w6h9_116{background:var(--accent-soft);border-color:color-mix(in oklab,var(--accent) 30%,transparent);color:var(--accent-2)}[data-skin=warm] ._preview_2w6h9_187{background:var(--surface);border:1px solid var(--border);backdrop-filter:none;-webkit-backdrop-filter:none;box-shadow:var(--shadow-lift)}[data-skin=warm] ._preview_2w6h9_187:before{display:none}[data-skin=warm] ._pvBar_2w6h9_290{background:var(--surface-3)}[data-skin=warm] ._pvCourse_2w6h9_270:hover{background:var(--surface-2)}[data-skin=warm] ._pvDeadline_2w6h9_314{background:var(--surface);border:1px solid color-mix(in oklab,var(--accent) 28%,transparent);backdrop-filter:none;-webkit-backdrop-filter:none;box-shadow:var(--shadow-lift),0 0 26px -10px var(--accent-glow)}[data-skin=warm] ._pvDlUrg_2w6h9_342{color:var(--bad)}[data-skin=warm] ._pvDlDot_2w6h9_350{background:var(--bad);box-shadow:0 0 8px var(--accent-glow)}[data-skin=warm] ._pvDlPbar_2w6h9_365{background:var(--surface-3)}[data-skin=warm] ._stats_2w6h9_383{background:color-mix(in oklab,var(--surface-2) 40%,transparent)}[data-skin=warm] ._feat_2w6h9_460:before{display:none}[data-skin=warm] ._feat_2w6h9_460:hover{background:var(--surface-2);border-color:color-mix(in oklab,var(--accent) 32%,transparent);box-shadow:var(--shadow-lift)}[data-skin=warm] ._featIc_2w6h9_494{color:var(--accent-2);background:var(--accent-soft);border-color:color-mix(in oklab,var(--accent) 26%,transparent)}[data-skin=warm] ._featIcCy_2w6h9_505{color:var(--warn);background:var(--warn-soft);border-color:color-mix(in oklab,var(--warn) 30%,transparent)}[data-skin=warm] ._featIcVi_2w6h9_510{color:var(--good);background:var(--good-soft);border-color:color-mix(in oklab,var(--good) 30%,transparent)}[data-skin=warm] ._stepN_2w6h9_568{color:var(--accent-2);background:var(--accent-soft);border-color:color-mix(in oklab,var(--accent) 26%,transparent)}._card_45p9v_1{width:100%;max-width:400px;padding:36px 32px;display:flex;flex-direction:column;gap:20px;border-color:var(--border-strong)!important}._logo_45p9v_10{font-size:22px;font-weight:800;color:var(--text)!important;text-decoration:none!important;text-align:center;letter-spacing:-.03em}._title_45p9v_18{font-size:20px;font-weight:700;text-align:center;color:var(--text);margin-top:-8px;letter-spacing:-.02em}._form_45p9v_26{display:flex;flex-direction:column;gap:14px}._forgotLink_45p9v_28{text-align:right;margin-top:-6px}._forgotLink_45p9v_28 a{font-size:12px;color:var(--text-muted);text-decoration:none}._forgotLink_45p9v_28 a:hover{color:var(--accent)}._switch_45p9v_39{text-align:center;font-size:13px;color:var(--text-muted)}._divider_45p9v_46{display:flex;align-items:center;gap:12px;color:var(--text-muted);font-size:12px;margin:2px 0}._divider_45p9v_46:before,._divider_45p9v_46:after{content:"";flex:1;height:1px;background:var(--border)}._socialButtons_45p9v_63{display:flex;flex-direction:column;gap:10px}._socialBtn_45p9v_69{display:flex;align-items:center;justify-content:center;gap:10px;width:100%;padding:10px 16px;border-radius:10px;border:1px solid var(--border-strong);background:var(--surface);color:var(--text);font-size:14px;font-weight:500;cursor:pointer;transition:background .15s,border-color .15s;font-family:inherit}._socialBtn_45p9v_69:hover{background:#ffffff12;border-color:#fff3}._socialBtn_45p9v_69:disabled{opacity:.5;cursor:not-allowed}._socialBtn_45p9v_69 svg{flex-shrink:0}[data-skin=warm] ._socialBtn_45p9v_69{background:var(--surface);border-color:var(--border-strong);color:var(--ink)}[data-skin=warm] ._socialBtn_45p9v_69:hover{background:var(--surface-2);border-color:var(--accent)}._page_1csfl_1{min-height:100vh;display:flex;flex-direction:column}._nav_1csfl_3{display:flex;align-items:center;justify-content:space-between;padding:16px 40px;background:#0c0b14cc;border-bottom:1px solid var(--border);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px)}._logo_1csfl_11{font-size:20px;font-weight:800;color:var(--text);text-decoration:none;letter-spacing:-.03em}._navLinks_1csfl_12{display:flex;align-items:center;gap:12px}._content_1csfl_14{flex:1;padding:70px 24px 60px;display:flex;flex-direction:column;align-items:center;gap:28px}._content_1csfl_14 h1{font-size:40px;font-weight:800;color:var(--text);letter-spacing:-.03em}._sub_1csfl_28{color:var(--text-muted);font-size:17px}._plans_1csfl_30{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:20px;max-width:700px;width:100%}._plan_1csfl_30{padding:32px;display:flex;flex-direction:column;gap:16px;position:relative}._planFeatured_1csfl_46{border-color:#6366f180!important;background:linear-gradient(135deg,rgba(99,102,241,.1),var(--surface))!important;box-shadow:0 0 40px -15px var(--accent-glow),0 1px #ffffff0f inset;overflow:visible}._popularBadge_1csfl_55{position:absolute;top:-13px;left:50%;transform:translate(-50%);background:linear-gradient(135deg,#6366f1,#818cf8);color:#fff;font-size:11px;font-weight:700;padding:4px 14px;border-radius:999px;white-space:nowrap;box-shadow:0 4px 12px -4px var(--accent-glow);letter-spacing:.03em;text-transform:uppercase}._planName_1csfl_72{font-size:14px;font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:.08em}._planPrice_1csfl_79{font-size:44px;font-weight:800;color:var(--text);letter-spacing:-.04em;line-height:1}._planPrice_1csfl_79 span{font-size:16px;font-weight:500;color:var(--text-muted)}._planFeatures_1csfl_88{list-style:none;display:flex;flex-direction:column;gap:10px;flex:1}._planFeatures_1csfl_88 li{font-size:13px;color:var(--text-dim);line-height:1.5;display:flex;align-items:flex-start;gap:8px}._featCheck_1csfl_90{color:var(--accent-2, #818cf8);flex-shrink:0;margin-top:2px}._featX_1csfl_91{color:var(--text-muted);flex-shrink:0;margin-top:2px}._muted_1csfl_92{color:var(--text-muted)!important;opacity:.5}._note_1csfl_94{font-size:12px;color:var(--text-muted);text-align:center}._billingToggle_1csfl_97{display:inline-flex;align-self:center;gap:2px;background:var(--progress-track, rgba(255,255,255,.06));border:1px solid var(--border);border-radius:999px;padding:4px}._billingBtn_1csfl_102{border:none;background:transparent;cursor:pointer;font-family:inherit;font-size:13px;font-weight:700;padding:8px 20px;border-radius:999px;color:var(--text-muted);transition:background .18s,color .18s;display:inline-flex;align-items:center;gap:7px}._billingBtn_1csfl_102[data-active=true]{background:var(--accent);color:#fff;box-shadow:0 0 14px var(--accent-glow)}._saveBadge_1csfl_111{font-size:10px;font-weight:800;padding:2px 6px;border-radius:999px;background:#fff3;letter-spacing:.02em;line-height:1.2}._billingBtn_1csfl_102:not([data-active=true]) ._saveBadge_1csfl_111{background:var(--accent-soft, rgba(99,102,241,.18));color:var(--accent-2, #818cf8)}._priceSub_1csfl_118{font-size:12px;color:var(--text-muted);margin-top:6px;line-height:1.4}._priceSub_1csfl_118 strong{color:var(--accent-2, #818cf8);font-weight:800}._eclassWarning_1csfl_122{display:flex;align-items:flex-start;gap:14px;background:#6366f11a;border:1px solid rgba(99,102,241,.35);border-radius:12px;padding:16px 20px;max-width:700px;width:100%;text-align:left}._eclassWarning_1csfl_122 strong{display:block;font-size:14px;color:var(--text);margin-bottom:4px}._eclassWarning_1csfl_122 p{font-size:13px;color:var(--text-muted);margin:0;line-height:1.5}._eclassWarningIcon_1csfl_136{font-size:22px;flex-shrink:0;margin-top:1px}@media(max-width:600px){._nav_1csfl_3{padding:12px 16px}._content_1csfl_14 h1{font-size:28px}._sub_1csfl_28{font-size:15px}._plans_1csfl_30{grid-template-columns:1fr}}[data-skin=warm] ._nav_1csfl_3{background:color-mix(in oklab,var(--surface) 82%,transparent);border-bottom-color:var(--border)}[data-skin=warm] ._planFeatured_1csfl_46{border-color:color-mix(in oklab,var(--accent) 45%,transparent)!important;background:linear-gradient(135deg,var(--accent-soft),var(--surface))!important;box-shadow:0 0 40px -16px var(--accent-glow)!important}[data-skin=warm] ._popularBadge_1csfl_55{background:linear-gradient(135deg,var(--accent),color-mix(in oklab,var(--accent) 60%,var(--warn)));box-shadow:0 6px 16px -6px var(--accent-glow)}[data-skin=warm] ._eclassWarning_1csfl_122{background:var(--accent-tint);border-color:color-mix(in oklab,var(--accent) 32%,transparent)}._layout_1y1fa_1{display:flex;min-height:100vh}._sidebar_1y1fa_7{width:230px;flex-shrink:0;background:radial-gradient(ellipse 220px 200px at 30% 8%,rgba(217,70,239,.14) 0%,transparent 65%),linear-gradient(175deg,#0e071efc,#06020efc);border-right:1px solid var(--border-strong);backdrop-filter:blur(40px);-webkit-backdrop-filter:blur(40px);display:flex;flex-direction:column;padding:22px 12px 18px;gap:3px;height:100%}.light ._sidebar_1y1fa_7{background:var(--sidebar-bg);border-right:1px solid var(--border);box-shadow:1px 0 0 var(--border)}._sidebarLogoWrap_1y1fa_31{display:flex;align-items:center;gap:10px;padding:2px 8px 14px}._sidebarLogo_1y1fa_31{font-size:20px;font-weight:900;letter-spacing:-.045em;color:var(--text)}._sidebarUser_1y1fa_45{display:flex;align-items:center;gap:10px;padding:9px 8px;border-radius:11px;background:var(--accent-soft);border:1px solid color-mix(in srgb,var(--accent) 28%,transparent);box-shadow:0 2px 12px #0000002e;margin-bottom:10px}.light ._sidebarUser_1y1fa_45{background:#6d28d914;border-color:#6d28d938;box-shadow:none}._navLabel_1y1fa_63{font-size:9px;font-weight:700;color:color-mix(in srgb,var(--text-muted) 70%,transparent);letter-spacing:.12em;text-transform:uppercase;padding:2px 12px 4px;margin-bottom:2px}._sidebarUserInfo_1y1fa_72{display:flex;flex-direction:column;gap:4px;min-width:0}._sidebarEmail_1y1fa_78{font-size:11px;color:var(--text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:140px}._nav_1y1fa_63{display:flex;flex-direction:column;gap:2px}._navItem_1y1fa_90{display:flex;align-items:center;gap:10px;padding:9px 12px;border-radius:10px;font-size:13px;font-weight:600;color:var(--text-muted);text-decoration:none;transition:background .15s,color .15s,transform .15s;position:relative;border:1px solid transparent;letter-spacing:-.01em}._navItem_1y1fa_90:hover{background:var(--surface-hover);color:var(--text-dim);text-decoration:none;transform:translate(2px)}._navBadge_1y1fa_113{margin-left:auto;min-width:18px;padding:1px 6px;border-radius:999px;background:var(--accent);color:#fff;font-size:10px;font-weight:800;text-align:center;line-height:1.5}._navItemActive_1y1fa_126{background:linear-gradient(90deg,var(--accent-soft) 0%,color-mix(in srgb,var(--accent) 5%,transparent) 100%)!important;color:var(--accent-2)!important;border-color:color-mix(in srgb,var(--accent) 30%,transparent)!important;box-shadow:0 2px 18px color-mix(in srgb,var(--accent) 14%,transparent),inset 0 1px #ffffff12;font-weight:600}.light ._navItemActive_1y1fa_126{background:linear-gradient(90deg,#6d28d91f,#6d28d90a)!important;color:#5b21b6!important;border-color:#6d28d942!important;box-shadow:0 2px 12px #6d28d91a}._navItemActive_1y1fa_126:before{content:"";position:absolute;left:0;top:12%;height:76%;width:3px;background:linear-gradient(180deg,var(--accent-2),var(--accent));border-radius:0 3px 3px 0;box-shadow:0 0 14px var(--accent-glow),0 0 6px var(--accent-glow)}.light ._navItemActive_1y1fa_126:before{background:linear-gradient(180deg,#7c3aed,#5b21b6);box-shadow:0 0 10px #7c3aed47}._navIcon_1y1fa_153{width:20px;display:flex;align-items:center;justify-content:center;flex-shrink:0}._sidebarDivider_1y1fa_162{height:1px;background:var(--border);margin:6px 4px}._themeBtn_1y1fa_168{display:flex;align-items:center;gap:8px;width:100%;padding:8px 12px;border-radius:9px;font-size:12px;font-weight:600;color:var(--text-muted);background:none;border:1px solid transparent;cursor:pointer;transition:background .15s,color .15s,border-color .15s;text-align:left;font-family:inherit}._themeBtn_1y1fa_168:hover{background:var(--surface-hover);color:var(--text-dim);border-color:var(--border)}._logoutBtn_1y1fa_191{display:flex;align-items:center;gap:8px;width:100%;padding:8px 12px;border-radius:9px;font-size:12px;font-weight:600;color:var(--text-muted);background:none;border:1px solid transparent;cursor:pointer;transition:background .15s,color .15s,border-color .15s;text-align:left;font-family:inherit;margin-top:2px}._logoutBtn_1y1fa_191:hover{background:#f871711a;color:#fca5a5;border-color:#f8717133}._layoutRight_1y1fa_216{flex:1;display:flex;flex-direction:column;min-width:0}._main_1y1fa_223{flex:1;padding:32px 36px;min-width:0;overflow-x:hidden;animation:_pageEnter_1y1fa_1 .32s cubic-bezier(.4,0,.2,1)}._globalScanWrap_1y1fa_233{padding:16px 36px 0;animation:_pageEnter_1y1fa_1 .32s cubic-bezier(.4,0,.2,1)}@media(max-width:900px){._globalScanWrap_1y1fa_233{padding:14px 16px 0}}@media(max-width:600px){._globalScanWrap_1y1fa_233{padding:12px 12px 0}}@keyframes _pageEnter_1y1fa_1{0%{transform:translateY(10px)}to{transform:none}}._sidebarDesktop_1y1fa_243{display:block;position:sticky;top:0;height:100vh;flex-shrink:0}._mobileHeader_1y1fa_252,._overlay_1y1fa_253,._hamburger_1y1fa_254,._sidebarDrawer_1y1fa_255{display:none}@media(max-width:768px){._layout_1y1fa_1{flex-direction:column}._sidebarDesktop_1y1fa_243{display:none}._mobileHeader_1y1fa_252{display:flex;align-items:center;justify-content:space-between;padding:0 16px;height:54px;background:var(--mobile-header-bg);border-bottom:1px solid var(--border);backdrop-filter:blur(24px);-webkit-backdrop-filter:blur(24px);position:sticky;top:0;z-index:100;flex-shrink:0}._mobileBrand_1y1fa_277{display:inline-flex;align-items:center;gap:8px}._mobileLogo_1y1fa_282{font-size:17px;font-weight:900;letter-spacing:-.04em;color:var(--text)}._mobilePageLabel_1y1fa_289{display:inline-flex;align-items:center;font-size:13px;font-weight:600;color:var(--text-dim);position:absolute;left:50%;transform:translate(-50%);max-width:calc(100vw - 230px);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}._hamburger_1y1fa_254{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:9px;border:1px solid var(--border-strong);background:var(--surface-2);color:var(--text);cursor:pointer;transition:background .15s;z-index:1}._hamburger_1y1fa_254:hover{background:var(--surface-hover)}._sidebarDrawer_1y1fa_255{display:block;position:fixed;top:0;left:0;height:100dvh;width:260px;z-index:200;transform:translate(-100%);transition:transform .25s cubic-bezier(.4,0,.2,1)}._sidebarDrawerOpen_1y1fa_333{transform:translate(0)}._sidebarDrawer_1y1fa_255 ._sidebar_1y1fa_7{width:260px;padding:28px 14px 20px;border-right:1px solid var(--border-strong)}._overlay_1y1fa_253{display:block;position:fixed;top:0;right:0;bottom:0;left:0;background:#0000008c;z-index:150;backdrop-filter:blur(2px);-webkit-backdrop-filter:blur(2px)}._main_1y1fa_223{padding:20px 16px}}@media(max-width:480px){._main_1y1fa_223{padding:16px 12px}}
