:root,[data-theme=dark]{--bg:#0f1115;--surface:#181c23;--surface-2:#222833;--surface-3:#1b212b;--border:#ffffff12;--border-soft:#ffffff0d;--text:#f5f7fa;--muted:#8a95a8;--accent:#5b8cff;--accent-dim:#5b8cff1f;--purple:#7b61ff;--green:#32d583;--green-bg:#32d5831f;--red:#ff6b6b;--red-bg:#ff6b6b1f;--amber:#f5b942;--amber-bg:#f5b9421f;--shadow-sm:0 4px 16px #0003;--shadow-md:0 8px 30px #00000040;--shadow-lg:0 20px 60px #00000073;--shadow-accent:0 6px 20px #5b8cff4d;--bg-gradient:radial-gradient(circle at top left, #5b8cff14, transparent 30%), radial-gradient(circle at bottom right, #32d5830f, transparent 30%);--sidebar-bg:linear-gradient(180deg, #ffffff05, #fff0), #0f1115eb;--card-bg:linear-gradient(180deg, #ffffff05, transparent), var(--surface);--input-bg:#ffffff12;--input-bg-focus:#ffffff1a}[data-theme=light]{--bg:#f0f2f8;--surface:#fff;--surface-2:#e8ebf4;--surface-3:#edf0f8;--border:#00000017;--border-soft:#0000000f;--text:#111827;--muted:#6b7280;--accent:#4a7aef;--accent-dim:#4a7aef1f;--purple:#6b52e8;--green:#16a34a;--green-bg:#16a34a1a;--red:#dc2626;--red-bg:#dc26261a;--amber:#b45309;--amber-bg:#b453091a;--shadow-sm:0 2px 8px #00000012;--shadow-md:0 4px 16px #00000017;--shadow-lg:0 12px 40px #00000021;--shadow-accent:0 4px 16px #4a7aef33;--bg-gradient:radial-gradient(circle at top left, #4a7aef0d, transparent 30%), radial-gradient(circle at bottom right, #16a34a0a, transparent 30%);--sidebar-bg:#fff;--card-bg:#fff;--input-bg:#0000000a;--input-bg-focus:#4a7aef0f}:root{--radius:16px;--radius-sm:10px;--radius-xs:8px;--font-sans:"DM Sans", system-ui, sans-serif;--font-mono:"DM Mono", "Fira Code", monospace;--sidebar-width:300px;--topbar-height:60px;--transition:all .18s ease;--transition-slow:all .28s cubic-bezier(.4, 0, .2, 1)}*,:before,:after{box-sizing:border-box;-webkit-tap-highlight-color:transparent;margin:0;padding:0}html{overscroll-behavior:none;background-color:#0f1115;width:100%;height:100%;min-height:100%}body{font-family:var(--font-sans);background-color:var(--bg);color:var(--text);overscroll-behavior:none;min-height:100dvh;overflow-x:hidden}body:before{content:"";pointer-events:none;z-index:-1;background-image:radial-gradient(circle at 0 0,#5b8cff14,#0000 30%),radial-gradient(circle at 100% 100%,#32d5830f,#0000 30%);position:fixed;inset:0}a{color:inherit;text-decoration:none}button{font-family:var(--font-sans)}input[type=number]::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}input[type=number]::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}input[type=number]{appearance:textfield}.hidden{display:none!important}.ambient-bg:before{content:"";pointer-events:none;z-index:-1;background-image:radial-gradient(circle at 0 0,#5b8cff14,#0000 30%),radial-gradient(circle at 100% 100%,#32d5830f,#0000 30%);position:fixed;inset:0}.top-auth{top:max(16px, env(safe-area-inset-top));right:max(16px, env(safe-area-inset-right));z-index:1000;align-items:center;gap:8px;display:flex;position:fixed}.sync-status{transition:var(--transition);border-radius:999px;align-items:center;gap:6px;padding:7px 13px;font-size:12px;font-weight:600;display:inline-flex}.sync-status.saved{background:var(--green-bg);color:var(--green);border:1px solid #32d58333}.sync-status.saving{background:var(--amber-bg);color:var(--amber);border:1px solid #f5b94233}.sync-status.error{background:var(--red-bg);color:var(--red);border:1px solid #ff6b6b33}html.theme-transitioning,html.theme-transitioning *,html.theme-transitioning :before,html.theme-transitioning :after{transition:background-color .3s,border-color .3s,color .2s!important}.theme-toggle-btn{border:1px solid var(--border);cursor:pointer;width:42px;height:42px;transition:var(--transition);color:var(--muted);background:#ffffff0d;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;display:flex}.theme-toggle-btn:hover{border-color:var(--accent);color:var(--accent);background:var(--accent-dim)}.theme-toggle-btn svg{pointer-events:none;width:18px;height:18px}.theme-toggle-btn.sidebar-theme-btn{border-radius:var(--radius-xs);border:1px solid var(--border-soft);background:#ffffff08;width:36px;height:36px;padding:0}.theme-toggle-btn.sidebar-theme-btn:hover{background:var(--accent-dim);color:var(--text);border-color:#5b8cff40}.theme-toggle-btn.topbar-theme-btn{border:1px solid var(--border);background:var(--surface);border-radius:13px;width:40px;height:40px}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes cardIn{0%{opacity:0;transform:scale(.97)translateY(8px)}to{opacity:1;transform:scale(1)translateY(0)}}@keyframes menuIn{0%{opacity:0;transform:translateY(-6px)scale(.97)}to{opacity:1;transform:translateY(0)scale(1)}}@keyframes rowIn{0%{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:translateY(0)}}@keyframes errorIn{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}@keyframes toastIn{0%{opacity:0;transform:translate(-50%)translateY(10px)}to{opacity:1;transform:translate(-50%)translateY(0)}}@keyframes spin{to{transform:rotate(360deg)}}.account-btn,.account-btn-text{cursor:pointer;transition:var(--transition);font-family:var(--font-sans)}.account-btn{-webkit-backdrop-filter:blur(12px);width:42px;height:42px;box-shadow:var(--shadow-sm);color:var(--accent);background:#ffffff0d;border:1px solid #ffffff1a;border-radius:50%;justify-content:center;align-items:center;display:flex}.account-btn:hover{background:#5b8cff1a;border-color:#5b8cff66}.account-btn .account-icon{width:20px;height:20px;display:block}.account-btn-text{border-radius:var(--radius-xs);border:1px solid var(--border-soft);width:100%;color:var(--text);text-align:left;background:#ffffff08;padding:10px 12px;font-size:13px;font-weight:600}.account-btn-text:hover{background:#ffffff12;border-color:#5b8cff40}.account-menu{background:var(--surface);-webkit-backdrop-filter:blur(18px);width:190px;box-shadow:var(--shadow-lg);z-index:1001;border:1px solid #ffffff14;border-radius:14px;flex-direction:column;gap:2px;padding:6px;animation:.16s menuIn;display:flex;position:absolute}.account-menu.hidden,.hidden{display:none!important}.top-auth .account-menu{top:52px;right:0}.sidebar-footer .account-wrapper{position:relative}.sidebar-footer .account-menu{width:100%;inset:auto 0 calc(100% + 8px)}.account-menu button{width:100%;color:var(--text);text-align:left;border-radius:var(--radius-xs);cursor:pointer;font-family:var(--font-sans);background:0 0;border:none;padding:10px 12px;font-size:13px;font-weight:600;transition:background .15s}.account-menu button:hover{background:#ffffff0f}#menuLogout{color:var(--red)}#menuLogout:hover{background:#ff6b6b1a}.auth-modal{z-index:2000;-webkit-backdrop-filter:blur(5px);padding:calc(env(safe-area-inset-top) + 50px) calc(env(safe-area-inset-right) + 50px) calc(env(safe-area-inset-bottom) + 50px) calc(env(safe-area-inset-left) + 50px);background:#000000b8;justify-content:center;align-items:center;animation:.15s fadeIn;display:flex;position:fixed;inset:-50px}.auth-modal.hidden{display:none!important}.auth-card{border-radius:var(--radius);background:var(--surface);-webkit-backdrop-filter:blur(20px);width:340px;box-shadow:var(--shadow-lg);border:1px solid #ffffff17;flex-direction:column;gap:0;padding:28px 24px 22px;animation:.18s cardIn;display:flex}.auth-title{letter-spacing:-.5px;color:var(--text);margin-bottom:20px;font-size:20px;font-weight:700}.auth-input{border-radius:var(--radius-sm);background:var(--input-bg);width:100%;color:var(--text);font-size:16px;font-family:var(--font-sans);box-sizing:border-box;appearance:none;border:1px solid #ffffff14;outline:none;margin-bottom:10px;padding:11px 14px;transition:border-color .15s,background .15s}.auth-input:focus{background:#5b8cff0d;border-color:#5b8cff80}.auth-input::placeholder{color:var(--muted)}.auth-input-wrap{width:100%;margin-bottom:10px;position:relative}.auth-input-pw{width:100%;margin-bottom:0;padding-right:44px}.pw-toggle{cursor:pointer;color:var(--muted);background:0 0;border:none;justify-content:center;align-items:center;min-width:44px;min-height:44px;padding:0;transition:color .15s;display:flex;position:absolute;top:50%;right:12px;transform:translateY(-50%)}.pw-toggle:hover{color:var(--text)}.pw-toggle svg,.eye-svg{width:17px;height:17px}.eye-slash{stroke-dasharray:30;stroke-dashoffset:0;opacity:1;transition:stroke-dashoffset .25s,opacity .18s}.pw-toggle.active .eye-slash{opacity:0;stroke-dashoffset:30px}.pw-toggle svg{transition:transform .22s,opacity .18s}.pw-toggle.active svg{transform:scale(1.08)}.auth-error{border-radius:var(--radius-sm);background:var(--red-bg);color:var(--red);border:1px solid #ff6b6b4d;margin-bottom:10px;padding:10px 13px;font-size:13px;font-weight:500;animation:.18s errorIn}.auth-error.hidden{display:none!important}.auth-btn{border-radius:var(--radius-sm);cursor:pointer;width:100%;font-size:14px;font-weight:600;font-family:var(--font-sans);transition:var(--transition);color:var(--text);border:none;min-height:44px;margin-top:6px;padding:11px}.auth-btn.primary{background:linear-gradient(135deg, var(--accent), var(--purple));box-shadow:0 4px 16px #5b8cff4d}.auth-btn.primary:hover{transform:translateY(-1px);box-shadow:0 6px 22px #5b8cff73}.auth-btn.primary:active{transform:translateY(0)}.auth-btn:not(.primary){color:var(--muted);border:1px solid var(--border-soft);background:#ffffff0d}.auth-btn:not(.primary):hover{color:var(--text);background:#ffffff17}.account-btn-text .account-btn-avatar{object-fit:cover;vertical-align:middle;border:1px solid #ffffff26;border-radius:50%;width:20px;height:20px;margin-right:2px}@media (width<=600px){.auth-card{width:calc(100vw - 24px);max-width:360px}}.app-layout{align-items:flex-start;width:100%;min-height:100dvh;display:flex}.sidebar{width:var(--sidebar-width);background:var(--sidebar-bg);-webkit-backdrop-filter:blur(20px);z-index:100;border-right:1px solid #ffffff0d;flex-direction:column;flex-shrink:0;height:100svh;min-height:100%;padding:22px 16px;transition:width .25s,padding .25s;display:flex;position:sticky;top:0;overflow:hidden}.sidebar-top{flex-shrink:0;justify-content:space-between;align-items:center;gap:12px;margin-bottom:14px;display:flex}.logo-wrap{align-items:center;gap:12px;min-width:0;display:flex}.logo-icon{background:linear-gradient(135deg,#5b8cff,#7b61ff);border-radius:14px;flex-shrink:0;justify-content:center;align-items:center;width:42px;height:42px;font-size:20px;display:flex;box-shadow:0 8px 24px #5b8cff4d}.logo-title{letter-spacing:-.5px;white-space:nowrap;text-overflow:ellipsis;font-size:16px;font-weight:700;overflow:hidden}.logo-sub{color:var(--muted);margin-top:2px;font-size:12px}.sidebar-back-link{color:var(--muted);opacity:.7;border-radius:10px;flex-shrink:0;align-items:center;gap:7px;margin-bottom:10px;padding:7px 10px;font-size:12px;font-weight:600;text-decoration:none;transition:all .18s;display:flex}.sidebar-back-link svg{flex-shrink:0;width:14px;height:14px}.sidebar-back-link:hover{color:var(--text);opacity:1;background:#ffffff0d}.sidebar-new-subject-btn,.sidebar-add-btn{width:100%;color:var(--accent);cursor:pointer;background:#5b8cff14;border:1px solid #5b8cff40;border-radius:13px;flex-shrink:0;align-items:center;gap:8px;margin-bottom:16px;padding:11px 14px;font-family:DM Sans,sans-serif;font-size:13px;font-weight:700;transition:all .18s;display:flex}.sidebar-new-subject-btn:hover,.sidebar-add-btn:hover{background:#5b8cff26;border-color:#5b8cff80;transform:translateY(-1px)}.sidebar-new-subject-btn .btn-icon{background:#5b8cff33;border-radius:7px;flex-shrink:0;justify-content:center;align-items:center;width:22px;height:22px;font-size:16px;line-height:1;display:flex}.sidebar-section-label{letter-spacing:.1em;text-transform:uppercase;color:var(--muted);opacity:.6;flex-shrink:0;margin-bottom:8px;padding:0 4px;font-size:10px;font-weight:700}.subjects-sidebar-list{-webkit-overflow-scrolling:touch;flex-direction:column;flex:1;gap:6px;margin-bottom:16px;padding-right:2px;display:flex;overflow:hidden auto}.subjects-sidebar-list::-webkit-scrollbar{width:4px}.subjects-sidebar-list::-webkit-scrollbar-thumb{background:#ffffff14;border-radius:999px}.subject-sidebar-item{cursor:pointer;border:1px solid #0000;border-radius:13px;justify-content:space-between;align-items:center;gap:8px;min-width:0;padding:10px 12px;transition:all .18s;display:flex}.subject-sidebar-item:hover{background:#ffffff0d;border-color:#ffffff0a}.subject-sidebar-item.active{background:linear-gradient(135deg,#5b8cff2e,#7b61ff1a);border-color:#5b8cff33}.subject-sidebar-left{flex:1;align-items:center;gap:10px;min-width:0;display:flex}.subject-sidebar-icon{background:#ffffff0d;border-radius:11px;flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;font-size:17px;display:flex}.subject-sidebar-info{flex:1;min-width:0}.subject-sidebar-name{white-space:nowrap;text-overflow:ellipsis;font-size:13px;font-weight:600;overflow:hidden}.subject-sidebar-avg{color:var(--muted);margin-top:2px;font-size:11px}.subject-sidebar-actions{opacity:0;flex-shrink:0;align-items:center;gap:4px;transition:opacity .18s;display:flex}.subject-sidebar-item:hover .subject-sidebar-actions{opacity:1}.subject-sidebar-edit,.subject-sidebar-delete{width:26px;height:26px;color:var(--muted);cursor:pointer;background:0 0;border:none;border-radius:8px;justify-content:center;align-items:center;transition:all .15s;display:flex}.subject-sidebar-edit svg{width:13px;height:13px}.subject-sidebar-edit:hover{color:var(--accent);background:#5b8cff1f}.subject-sidebar-delete:hover{color:var(--red);background:#ff6b6b1f}@media (width<=980px){.subject-sidebar-actions{opacity:1}}.sidebar-footer{border-top:1px solid #ffffff0d;flex-shrink:0;padding-top:16px}.sidebar-collapse-btn{width:32px;height:32px;color:var(--muted);cursor:pointer;background:#ffffff08;border:1px solid #ffffff0f;border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;transition:all .18s;display:flex}.sidebar-collapse-btn:hover{color:var(--text);background:#ffffff14;border-color:#5b8cff4d}.sidebar-collapse-btn svg{width:15px;height:15px;transition:transform .25s}.app-layout.sidebar-collapsed .sidebar{border-right:1px solid #ffffff0d;width:52px;padding:16px 10px;overflow:hidden}.app-layout.sidebar-collapsed .sidebar>:not(.sidebar-top){opacity:0;pointer-events:none}.app-layout.sidebar-collapsed .sidebar-top{justify-content:center}.app-layout.sidebar-collapsed .logo-wrap{display:none}.app-layout.sidebar-collapsed .sidebar-collapse-btn{color:var(--accent);background:#ffffff0a;border-color:#ffffff14}.app-layout.sidebar-collapsed .sidebar-collapse-btn:hover{color:var(--accent);background:#5b8cff1f;border-color:#5b8cff4d}.app-layout.sidebar-collapsed .workspace .mobile-topbar{display:flex}.app-layout.sidebar-collapsed .sidebar-collapse-btn svg{transform:rotate(180deg)}.workspace{min-width:0;padding-top:calc(env(safe-area-inset-top) + 24px);flex:1;padding-bottom:16px;padding-left:16px;padding-right:16px}.mobile-topbar{align-items:center;gap:12px;margin-bottom:22px;display:none}.mobile-menu-btn{background:var(--surface);width:40px;height:40px;color:var(--text);cursor:pointer;border:1px solid #ffffff0f;border-radius:13px;flex-shrink:0;justify-content:center;align-items:center;min-width:44px;min-height:44px;font-size:17px;display:flex}.mobile-current-subject{letter-spacing:-.5px;white-space:nowrap;text-overflow:ellipsis;flex:1;min-width:0;font-size:17px;font-weight:700;overflow:hidden}.mobile-home-btn{background:var(--surface);width:40px;height:40px;color:var(--muted);border:1px solid #ffffff0f;border-radius:13px;flex-shrink:0;justify-content:center;align-items:center;min-width:44px;min-height:44px;text-decoration:none;transition:all .18s;display:flex}.mobile-home-btn svg{width:17px;height:17px}.mobile-home-btn:hover,.mobile-home-btn:active{color:var(--accent);background:#5b8cff1f;border-color:#5b8cff4d}.subject-header{justify-content:space-between;align-items:flex-start;gap:18px;margin-bottom:22px;display:flex}.subject-header-left{flex:1;align-items:center;gap:16px;min-width:0;display:flex}.subject-icon{background:linear-gradient(135deg,#5b8cff2e,#7b61ff1a);border-radius:18px;flex-shrink:0;justify-content:center;align-items:center;width:62px;height:62px;font-size:30px;display:flex}.subject-name-input{color:var(--text);letter-spacing:-1.2px;background:0 0;border:none;outline:none;width:100%;min-width:0;font-size:34px;font-weight:700}.setting-bar,.settings-bar{flex-wrap:wrap;align-items:center;gap:8px;padding:0 0 18px;display:flex}.setting-pill{background:var(--surface-3);-webkit-backdrop-filter:blur(12px);border:1px solid #ffffff0f;border-radius:999px;align-items:center;gap:8px;padding:8px 14px;font-size:12px;transition:border-color .18s,box-shadow .18s,transform .18s;display:flex;box-shadow:0 4px 20px #0000002e,inset 0 1px #ffffff08}.setting-pill:hover{border-color:#5b8cff59}.setting-pill:focus-within{border-color:#5b8cff8c;transform:translateY(-1px);box-shadow:0 0 0 4px #5b8cff29,0 8px 24px #00000040}.setting-pill label{cursor:pointer;color:var(--muted);white-space:nowrap;font-weight:600}.setting-pill input[type=number]{color:var(--text);text-align:center;letter-spacing:-.2px;background:0 0;border:none;outline:none;min-width:0;font-size:13px;font-weight:600}.setting-pill select,.sg-mode-select{background-color:var(--surface-2);font-family:var(--font-sans);color:var(--text);cursor:pointer;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 24 24' fill='none' stroke='%2398A2B3' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'%3E%3C/polyline%3E%3C/svg%3E");background-position:right 10px center;background-repeat:no-repeat;background-size:12px;border:1px solid #ffffff0d;border-radius:10px;outline:none;padding:6px 30px 6px 10px;font-size:12px;font-weight:600;transition:all .18s}.setting-pill select:hover,.sg-mode-select:hover{border-color:#5b8cff4d}.setting-pill select:focus,.sg-mode-select:focus{border-color:var(--accent);box-shadow:0 0 0 4px #5b8cff1f}.grouped-pill{gap:10px}.pill-divider{background:#ffffff14;flex-shrink:0;width:1px;height:18px}.result-card{border-radius:var(--radius);background:linear-gradient(180deg, #ffffff05, transparent), var(--surface);-webkit-backdrop-filter:blur(14px);border:1px solid #ffffff0f;margin-bottom:16px;padding:18px;transition:all .22s;box-shadow:0 8px 30px #00000038,inset 0 1px #ffffff08}.result-card.pass{background:linear-gradient(180deg, #32d58314, transparent), var(--surface);border-color:#32d58359}.result-card.fail{background:linear-gradient(180deg, #ff6b6b14, transparent), var(--surface);border-color:#ff6b6b59}.result-card.empty{opacity:.6}.result-top{justify-content:space-between;align-items:flex-start;gap:12px;display:flex}.result-avg{font-family:var(--font-mono);letter-spacing:-2px;font-size:clamp(32px,8vw,48px);font-weight:500;line-height:1}.result-avg.pass{color:var(--green)}.result-avg.fail{color:var(--red)}.result-avg.empty{color:var(--muted)}.result-status{letter-spacing:.06em;text-transform:uppercase;white-space:nowrap;border-radius:999px;padding:5px 12px;font-size:11px;font-weight:700;display:inline-block}.result-status.pass{background:var(--green-bg);color:var(--green)}.result-status.fail{background:var(--red-bg);color:var(--red)}.result-status.empty{color:var(--muted);background:#ffffff0a}.result-detail{flex-wrap:wrap;gap:8px;margin-top:14px;display:flex}.stat-chip{color:var(--muted);background:#ffffff0a;border-radius:999px;align-items:center;gap:4px;padding:5px 11px;font-size:11px;display:flex}.stat-chip b{color:var(--text);font-weight:700}.needs-badge{border-radius:var(--radius-sm);margin-top:12px;padding:10px 14px;font-size:12px;line-height:1.4;display:none}.needs-badge.show{display:block}.section-head{justify-content:space-between;align-items:center;gap:8px;margin-bottom:12px;display:flex}.section-title{letter-spacing:.08em;text-transform:uppercase;color:var(--muted);font-size:11px;font-weight:700}.pct-total{border-radius:999px;padding:4px 11px;font-size:11px;font-weight:700}.pct-total.ok{background:var(--green-bg);color:var(--green)}.grades-list{flex-direction:column;gap:10px;display:flex}.grade-row{background:var(--surface-3);border-radius:var(--radius);-webkit-backdrop-filter:blur(12px);border:1px solid #ffffff0d;grid-template-columns:1fr auto auto auto;align-items:center;gap:10px;padding:14px;transition:all .18s;animation:.18s rowIn;display:grid}.grade-row.highlight-pass{border-left:3px solid var(--green)}.grade-row.highlight-fail{border-left:3px solid var(--red)}.subgroup-row{border-left:3px solid var(--accent)!important;grid-template-columns:unset!important;padding:14px!important;display:block!important}.sg-header{justify-content:space-between;align-items:flex-start;gap:8px;margin-bottom:10px;display:flex}.sg-header-left{flex:1;align-items:center;gap:8px;min-width:0;display:flex}.sg-header-right{flex-shrink:0;align-items:center;gap:10px;display:flex}.sg-icon{opacity:.5;flex-shrink:0;font-size:18px}.sg-avg-badge{font-family:var(--font-mono);text-align:right;min-width:52px;color:var(--muted);font-size:20px;font-weight:500}.sg-avg-badge.pass{color:var(--green)}.sg-avg-badge.fail{color:var(--red)}.sg-controls{color:var(--muted);flex-wrap:wrap;align-items:center;gap:10px;margin-bottom:12px;font-size:12px;display:flex}.sg-mode-select{background-color:var(--surface-2);font-family:var(--font-sans);color:var(--text);cursor:pointer;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 24 24' fill='none' stroke='%2398A2B3' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'%3E%3C/polyline%3E%3C/svg%3E");background-position:right 10px center;background-repeat:no-repeat;background-size:12px;border:1px solid #ffffff0d;border-radius:10px;outline:none;padding:6px 30px 6px 10px;font-size:12px;font-weight:600;transition:all .18s}.sg-mode-select:hover{border-color:#5b8cff4d}.sg-mode-select:focus{border-color:var(--accent);box-shadow:0 0 0 3px #5b8cff26}.sg-keepn-wrap,.sg-pond-wrap{color:var(--muted);align-items:center;gap:5px;font-size:12px;display:flex}.sg-pond-wrap{margin-left:auto}.sg-items{flex-wrap:wrap;align-items:center;gap:8px;display:flex}.sg-item-row{align-items:center;gap:4px;display:flex}.sg-item-input{width:68px!important;padding:7px 6px!important;font-size:16px!important}.sg-item-del{width:22px;height:22px;color:var(--muted);cursor:pointer;background:0 0;border:none;border-radius:50%;justify-content:center;align-items:center;min-width:32px;min-height:32px;font-size:15px;line-height:1;transition:all .15s;display:flex}.sg-item-del:hover{color:var(--red);background:#ff6b6b1f}.sg-add-item-btn{font-family:var(--font-sans);color:var(--muted);cursor:pointer;background:0 0;border:1px dashed #ffffff1f;border-radius:999px;min-height:36px;padding:5px 12px;font-size:11px;font-weight:600;transition:all .15s}.sg-add-item-btn:hover{border-color:var(--accent);color:#fff}.grade-label-input{font-family:var(--font-sans);color:var(--text);background:0 0;border:none;outline:none;width:100%;font-size:14px;font-weight:600}.grade-label-input::placeholder{color:var(--muted)}.grade-sub{color:var(--muted);margin-top:3px;font-size:11px}.num-input,.pct-input{font-family:var(--font-mono);background:var(--input-bg);color:#fff;text-align:center;appearance:textfield;-webkit-appearance:none;border:1px solid #ffffff1a;border-radius:12px;outline:none;transition:all .15s;box-shadow:inset 0 1px #ffffff0a}.num-input{width:75px;padding:8px 6px;font-size:19px;font-weight:700}.pct-input{width:46px;padding:6px 4px;font-size:14px}.num-input:focus,.pct-input:focus{background:#ffffff1a;border-color:#6ea8ff;box-shadow:0 0 0 4px #5b8cff2e}.num-input.error{border-color:var(--red);background:#ff6b6b14}.del-btn{width:30px;height:30px;color:var(--muted);cursor:pointer;background:0 0;border:none;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;min-width:40px;min-height:40px;font-size:18px;transition:all .15s;display:flex}.del-btn:hover{color:var(--red);background:#ff6b6b1f}.add-btns-row{gap:8px;margin-top:10px;display:flex}.add-btn{border-radius:var(--radius);width:100%;font-family:var(--font-sans);color:var(--muted);cursor:pointer;background:#ffffff05;border:1px dashed #ffffff1f;justify-content:center;align-items:center;gap:6px;min-height:50px;margin-top:10px;padding:14px;font-size:13px;font-weight:600;transition:all .18s;display:flex}.add-btn:hover{border-color:var(--accent);color:#fff;background:#5b8cff14}.add-btn-sg{color:var(--accent);border-style:solid;border-color:#5b8cff40}.add-btn-sg:hover{border-color:var(--accent);color:#fff;background:#5b8cff14}.clear-all-btn{font-family:var(--font-sans);color:var(--muted);cursor:pointer;white-space:nowrap;background:0 0;border:none;border-radius:10px;min-height:36px;padding:6px 10px;font-size:12px;font-weight:600;transition:all .15s}.clear-all-btn:hover{color:var(--red);background:#ff6b6b14}.save-btn{font-family:var(--font-sans);color:var(--green);cursor:pointer;white-space:nowrap;background:#32d58314;border:1px solid #32d5834d;border-radius:999px;align-items:center;gap:5px;padding:5px 12px;font-size:12px;font-weight:600;transition:all .15s;display:flex}.save-btn:hover{background:#32d58326;border-color:#32d58380}.save-btn.hidden{display:none!important}.save-indicator{white-space:nowrap;border-radius:999px;padding:4px 12px;font-size:11px;font-weight:600;transition:all .2s}.save-indicator.saving{background:var(--amber-bg);color:var(--amber);border:1px solid #f5b94240}.save-indicator.saved{background:var(--green-bg);color:var(--green);border:1px solid #32d58340}.save-indicator.error{background:var(--red-bg);color:var(--red);border:1px solid #ff6b6b40}.save-indicator.hidden{display:none!important}.empty-workspace{justify-content:center;align-items:center;width:100%;padding:48px 20px;display:flex}.empty-workspace.hidden{display:none!important}.empty-hero{text-align:center;max-width:420px}.empty-emoji{margin-bottom:18px;font-size:72px}.empty-title{letter-spacing:-1px;margin-bottom:10px;font-size:34px;font-weight:700}.empty-sub{color:var(--muted);margin-bottom:26px;font-size:15px;line-height:1.6}.empty-create-btn{font-family:var(--font-sans);color:#fff;cursor:pointer;background:linear-gradient(135deg,#5b8cff,#7b61ff);border:none;border-radius:14px;min-height:50px;padding:14px 22px;font-size:14px;font-weight:700;transition:all .18s;box-shadow:0 6px 20px #5b8cff40}.empty-create-btn:hover{transform:translateY(-1px);box-shadow:0 10px 30px #5b8cff59}.modal-overlay{padding:max(20px, env(safe-area-inset-top)) max(20px, env(safe-area-inset-right)) max(20px, env(safe-area-inset-bottom)) max(20px, env(safe-area-inset-left));z-index:2001;-webkit-backdrop-filter:blur(4px);background:#0009;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.modal-overlay.hidden{display:none!important}.modal-card{background:linear-gradient(180deg, #ffffff05, #fff0), var(--surface);border:1px solid #ffffff0f;border-radius:24px;flex-direction:column;width:100%;max-width:420px;max-height:85dvh;padding:24px;animation:.18s cardIn;display:flex;overflow:hidden;box-shadow:0 20px 60px #00000073}.modal-title{letter-spacing:-1px;flex-shrink:0;margin-bottom:8px;font-size:24px;font-weight:700}.modal-sub{color:var(--muted);flex-shrink:0;margin-bottom:22px;font-size:14px;line-height:1.5}.modal-field{margin-bottom:18px}.modal-field label{letter-spacing:.04em;text-transform:uppercase;color:var(--muted);flex-shrink:0;margin-bottom:10px;font-size:12px;font-weight:700;display:block}.modal-field input{background:var(--input-bg);width:100%;color:var(--text);font-family:var(--font-sans);appearance:none;border:1px solid #ffffff0f;border-radius:14px;outline:none;flex-shrink:0;padding:14px 16px;font-size:16px;transition:border-color .15s}.modal-field input:focus{background:#5b8cff0a;border-color:#5b8cff66}.icon-picker{-webkit-overflow-scrolling:touch;scrollbar-width:thin;scrollbar-color:#ffffff14 transparent;grid-template-columns:repeat(auto-fill,minmax(52px,1fr));gap:8px;max-height:280px;padding-right:2px;display:grid;overflow:hidden auto}.icon-picker::-webkit-scrollbar{width:4px}.icon-picker::-webkit-scrollbar-thumb{background:#ffffff14;border-radius:99px}.icon-picker button{aspect-ratio:1;cursor:pointer;touch-action:manipulation;background:#ffffff08;border:1px solid #ffffff0f;border-radius:14px;justify-content:center;align-items:center;font-size:22px;transition:all .15s;display:flex}.icon-picker button:hover,.icon-picker button.selected{background:#5b8cff1f;border-color:#5b8cff73;transform:translateY(-1px)}.modal-actions{flex-shrink:0;justify-content:flex-end;gap:10px;margin-top:20px;padding-top:4px;display:flex}.modal-cancel-btn,.modal-create-btn{font-family:var(--font-sans);cursor:pointer;border:none;border-radius:14px;min-height:44px;padding:12px 18px;font-size:13px;font-weight:700;transition:all .15s}.modal-cancel-btn{color:var(--muted);background:#ffffff0a}.modal-cancel-btn:hover{color:var(--text);background:#ffffff14}.modal-create-btn{color:#fff;background:linear-gradient(135deg,#5b8cff,#7b61ff);box-shadow:0 4px 14px #5b8cff40}.modal-create-btn:hover{transform:translateY(-1px);box-shadow:0 6px 20px #5b8cff59}.confirm-modal-card{max-width:400px;max-height:none;overflow:visible}.confirm-modal-header{align-items:center;gap:14px;margin-bottom:12px;display:flex}.confirm-modal-icon{background:#ff6b6b1a;border:1px solid #ff6b6b2e;border-radius:14px;flex-shrink:0;justify-content:center;align-items:center;width:46px;height:46px;display:flex}.confirm-modal-title{letter-spacing:-.5px;color:var(--text);margin:0;font-size:20px;font-weight:700}.confirm-modal-card .modal-sub{color:var(--muted);margin-bottom:0;font-size:14px;line-height:1.55}.confirm-modal-card .modal-field:last-of-type{flex:unset;min-height:unset;display:block}.modal-actions-confirm{flex-shrink:0;justify-content:flex-end;gap:10px;margin-top:22px;display:flex}#confirmOkBtn{color:#ff6b6b;box-shadow:none;font-family:var(--font-sans);cursor:pointer;background:#ff6b6b26;border:1px solid #ff6b6b4d;border-radius:14px;min-height:44px;padding:12px 24px;font-size:13px;font-weight:700;transition:all .18s}#confirmOkBtn:hover{background:#ff6b6b40;border-color:#ff6b6b80;transform:translateY(-1px);box-shadow:0 4px 16px #ff6b6b2e}#confirmOkBtn:active{transform:translateY(0)}.sidebar-overlay{z-index:1999;background:#0000008c;display:none;position:fixed;inset:-50px}.sidebar-overlay.visible{display:block}.sidebar-user-actions{flex-direction:column;gap:8px;margin-bottom:16px;display:flex}.profile-selector-footer{margin-bottom:10px}.profile-selector-footer select{width:100%;color:var(--text);cursor:pointer;appearance:none;background-color:#ffffff0a;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%2398A2B3' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'%3E%3C/polyline%3E%3C/svg%3E");background-position:right 10px center;background-repeat:no-repeat;background-size:11px;border:1px solid #ffffff14;border-radius:10px;outline:none;padding:8px 30px 8px 12px;font-family:DM Sans,sans-serif;font-size:12px;font-weight:600;transition:all .15s}.profile-selector-footer select:hover{border-color:#5b8cff4d}.profile-selector-footer select:focus{border-color:#5b8cff73;box-shadow:0 0 0 3px #5b8cff1f}.profile-selector-footer select option{color:var(--text);background:#12161efa}.general-avg-box{background:#ffffff05;border:1px solid #ffffff0d;border-radius:13px;margin-bottom:16px;padding:12px 14px}.general-avg-box.hidden{display:none!important}.general-avg-header{justify-content:space-between;align-items:center;margin-bottom:4px;display:flex}.general-avg-label{letter-spacing:.1em;text-transform:uppercase;color:var(--muted);opacity:.6;font-size:10px;font-weight:700}.general-avg-toggle{cursor:pointer;width:20px;height:20px;color:var(--muted);opacity:.4;background:0 0;border:none;flex-shrink:0;justify-content:center;align-items:center;padding:0;transition:opacity .15s;display:flex}.general-avg-toggle:hover{opacity:.9}.general-avg-toggle svg{width:13px;height:13px}.general-avg-number{font-family:var(--font-mono);letter-spacing:-1px;color:var(--muted);text-align:center;font-size:28px;font-weight:500;transition:color .2s}.general-avg-collapsed{justify-content:space-between;align-items:center;margin-bottom:16px;padding:6px 4px;display:none}.general-avg-collapsed.visible{display:flex}@media (width>=981px){.sidebar{transition:width .25s,padding .25s;overflow:hidden}.app-layout.sidebar-collapsed .workspace .mobile-topbar{display:flex}.app-layout:not(.sidebar-collapsed) .workspace .mobile-topbar,.mobile-topbar .mobile-home-btn{display:none}.sidebar-overlay{display:none!important}}@media (width<=980px){.sidebar{z-index:2000;height:100%;min-height:100%;padding-top:max(22px, env(safe-area-inset-top));padding-left:max(16px, env(safe-area-inset-left));padding-right:16px;padding-bottom:calc(env(safe-area-inset-bottom) + 16px);position:fixed;top:0;transform:translate(-100%);width:min(var(--sidebar-width), 85vw)!important;transition:transform .28s cubic-bezier(.4,0,.2,1)!important;left:0!important}.sidebar.open{transform:translate(0)}.sidebar-back-link{display:none}.sidebar-overlay{z-index:1999;background:#00000080;display:none;position:fixed;inset:0}.sidebar-overlay.visible{display:block}.workspace{width:100%;padding-top:calc(max(12px, env(safe-area-inset-top)) + 66px);padding-right:max(16px, env(safe-area-inset-right));padding-bottom:max(40px, calc(env(safe-area-inset-bottom) + 32px));padding-left:max(16px, env(safe-area-inset-left))}.mobile-topbar{z-index:500;padding-top:max(12px, env(safe-area-inset-top));padding-bottom:10px;padding-left:max(16px, env(safe-area-inset-left));padding-right:max(16px, env(safe-area-inset-right));-webkit-backdrop-filter:blur(20px);background:#0f1115eb;border-bottom:1px solid #ffffff0d;align-items:center;gap:12px;margin:0;top:0;left:0;right:0;display:flex!important;position:fixed!important}.settings-bar{gap:6px;padding:0 0 14px}.sidebar-collapse-btn{display:none}.modal-card{max-height:90dvh}}@media (width<=600px){.subject-header{flex-direction:column}.subject-header-left{width:100%}.subject-icon{width:50px;height:50px;font-size:24px}.subject-name-input{font-size:26px}.result-avg{font-size:34px}.grade-row{gap:8px;padding:12px}.num-input{width:62px;font-size:16px}.pct-input{width:40px;font-size:13px}.settings-bar{flex-wrap:wrap;gap:6px;display:flex}.setting-pill{gap:5px;padding:7px 11px;font-size:11px}.setting-pill label{font-size:11px}.setting-pill select{padding:5px 22px 5px 8px;font-size:11px}.setting-pill input[type=number]{font-size:16px}.add-btn{padding:12px;font-size:13px}.sg-item-input{width:58px!important;font-size:16px!important}.empty-title{font-size:28px}.empty-sub{font-size:14px}.modal-card{border-radius:20px;padding:20px 18px}.icon-picker button{font-size:20px}}@media (width<=380px){.result-avg{font-size:30px}.num-input{width:56px;font-size:15px}.setting-pill label{display:none}.subject-name-input{font-size:22px}}
