#app-view #grade-sheet-view .grade-layout{display:grid;grid-template-columns:1.45fr 1fr;gap:calc(1rem * var(--app-view-density));margin-top:calc(1rem * var(--app-view-density))}#app-view #grade-sheet-view .panel-card{border:1px solid var(--theme-border-subtle);border-radius:.92rem;background:var(--theme-surface-inset);padding:calc(.9rem * var(--app-view-density))}#app-view #grade-sheet-view .components-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:calc(.72rem * var(--app-view-density))}#app-view #grade-sheet-view .component-card{border:1px solid var(--theme-border-subtle);border-radius:.8rem;background:color-mix(in oklab,var(--theme-surface-elevated) 90%,var(--theme-panel-inset-bg));padding:calc(.75rem * var(--app-view-density));display:grid;gap:calc(.52rem * var(--app-view-density))}#app-view #grade-sheet-view .component-card h3{margin:0;font-size:1.02rem;line-height:1.2}#app-view #grade-sheet-view .component-meta{font-size:.79rem;opacity:.8}#app-view #grade-sheet-view .inputs-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(calc(120px * var(--app-view-density)),1fr));gap:calc(.52rem * var(--app-view-density))}#app-view #grade-sheet-view .input-group{display:grid;gap:.24rem}#app-view #grade-sheet-view .input-group label{font-size:.75rem;opacity:.88;font-weight:600}#app-view #grade-sheet-view .input-group input[type=number]{width:100%;padding:.42rem;border:1px solid var(--theme-button-secondary-border);border-radius:.46rem;background:color-mix(in oklab,var(--theme-surface-elevated) 88%,var(--theme-bg));color:var(--theme-text-strong);font-size:.86rem}#app-view #grade-sheet-view .drop-row{display:inline-flex;align-items:center;gap:.32rem;font-size:.72rem;opacity:.86}#app-view #grade-sheet-view .left-actions{margin-top:calc(.82rem * var(--app-view-density))}#app-view #grade-sheet-view .calculate-btn{width:100%;border:1px solid color-mix(in oklab,var(--theme-primary) 38%,transparent);border-radius:999px;padding:.72rem 1rem;background:var(--theme-cta-bg);color:var(--theme-on-primary);font-weight:800;letter-spacing:.02em;cursor:pointer;box-shadow:var(--theme-cta-shadow)}#app-view #grade-sheet-view .analytics-column{display:grid;gap:calc(.72rem * var(--app-view-density));align-content:start}#app-view #grade-sheet-view .grade-summary-card h3{margin:0;font-size:1.05rem}#app-view #grade-sheet-view .overall-grade{font-size:2.2rem;font-weight:800;margin:.6rem 0 .3rem}#app-view #grade-sheet-view .stacked-bar{display:flex;width:100%;height:22px;border-radius:999px;overflow:hidden;background:color-mix(in oklab,var(--theme-on-bg) 8%,var(--theme-surface-subtle, var(--theme-mix-base)));margin-top:.5rem}#app-view #grade-sheet-view .bar-green{background:#10b981}#app-view #grade-sheet-view .bar-gray{background:#94a3b8}#app-view #grade-sheet-view .bar-red{background:#ef4444}#app-view #grade-sheet-view .stats-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:.44rem;margin-top:.75rem}#app-view #grade-sheet-view .stat-box{border:1px solid var(--theme-border-subtle);border-radius:.64rem;background:color-mix(in oklab,var(--theme-surface-elevated) 92%,var(--theme-panel-inset-bg));padding:.58rem .45rem;text-align:center}#app-view #grade-sheet-view .stat-box .value{font-size:1.1rem;font-weight:800}#app-view #grade-sheet-view .value.secured{color:#059669}#app-view #grade-sheet-view .value.ungraded{color:color-mix(in oklab,var(--theme-on-bg) 58%,transparent)}#app-view #grade-sheet-view .value.lost{color:#dc2626}#app-view #grade-sheet-view .label{font-size:.76rem;opacity:.77}#app-view #grade-sheet-view .chart-card h3{margin:0 0 .55rem;font-size:1rem}#app-view #grade-sheet-view .chart-grid{display:grid;gap:.64rem}#app-view #grade-sheet-view .chart-box{border:1px solid var(--theme-border-subtle);border-radius:.72rem;background:var(--theme-surface-inset);padding:.52rem;min-height:170px;display:grid;place-items:center}#app-view #grade-sheet-view .chart-box canvas{width:100%;max-width:260px;height:150px}#app-view #grade-sheet-view .chart-box--wide canvas{width:100%;max-width:none;height:220px}#app-view #grade-sheet-view .component-list{margin-top:.7rem;display:grid;gap:.5rem}#app-view #grade-sheet-view .component-row{background:color-mix(in oklab,var(--theme-surface-elevated) 92%,var(--theme-panel-inset-bg));border:1px solid var(--theme-border-subtle);border-radius:.64rem;padding:.54rem .62rem;font-size:.82rem;line-height:1.42}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}#app-view #grade-sheet-view{--grades-control-height: 2.32rem}#app-view #grade-sheet-view .grades-icon-btn{width:1.58rem;height:1.58rem;min-width:1.58rem;min-height:1.58rem}#app-view #grade-sheet-view .grades-icon-btn svg{width:.76rem;height:.76rem}.grades-shell{display:grid;grid-template-columns:minmax(0,1fr);gap:.95rem;width:min(1120px,100%);margin-inline:auto}.grades-shell--empty{min-height:24rem;align-content:start}.grades-intro{display:flex;align-items:flex-start;justify-content:space-between;gap:.75rem}.grades-intro--active{padding-inline:.08rem}.grades-intro h2{margin:0;font-size:clamp(1.4rem,1.5vw,1.7rem)}.grades-intro .panel-subtitle{margin:0;max-width:30rem;font-size:.8rem;line-height:1.3}.grades-empty{border:1px dashed color-mix(in oklab,var(--theme-primary) 26%,var(--theme-mix-base));border-radius:1rem;background:linear-gradient(145deg,color-mix(in oklab,var(--theme-surface-elevated, var(--theme-surface-1)) 92%,white),color-mix(in oklab,var(--theme-surface-subtle, var(--theme-panel-inset-bg)) 90%,var(--theme-mix-base)));padding:1.35rem;display:grid;gap:1rem;justify-items:start}.grades-empty p{margin:0;max-width:38rem;line-height:1.5}.grades-header{display:grid;grid-template-columns:minmax(0,1fr);gap:.44rem;padding:.68rem .98rem .88rem;border:1px solid var(--theme-border-subtle);border-radius:1rem;background:var(--theme-surface-secondary);box-shadow:var(--theme-shadow-sm)}.grades-header__grid{display:grid;grid-template-columns:repeat(6,minmax(0,1fr));grid-template-areas:"course course course selector selector selector" "metrics metrics stats stats actions actions";gap:.56rem;align-items:start}.grades-header__grid--header-only{grid-template-areas:"course course course selector selector selector"}.grades-header__course-stack{grid-area:course;display:flex;flex-direction:column;align-items:flex-start;align-self:center;gap:.48rem;min-width:0;flex:1;overflow:hidden}.grades-header__course-stack--with-scale{align-self:start}#app-view #grade-sheet-view .grades-header .grade-course-badge{margin-top:0}.grades-header__selector,.grades-header__actions-wrap{display:flex;align-items:center;justify-content:flex-end;gap:.44rem;min-width:0}.grades-header__selector{grid-area:selector;align-self:start;justify-self:end;width:100%}.grades-header__actions-wrap{grid-area:actions;justify-self:end;align-self:center}.grades-scale-banner{display:flex;flex-wrap:wrap;align-items:center;gap:.5rem;max-width:100%}.grades-scale-flag-wrap{position:relative;display:inline-flex;align-items:center}.grades-scale-flag{display:inline-flex;align-items:center;gap:.38rem;min-height:2rem;padding:.36rem .62rem;border-radius:999px;border:1px solid color-mix(in oklab,#f59e0b 42%,var(--theme-mix-base));background:color-mix(in oklab,#f59e0b 12%,var(--theme-surface-1));color:color-mix(in oklab,#f59e0b 78%,var(--theme-on-bg));font:inherit;font-size:.74rem;font-weight:800;letter-spacing:.01em;cursor:help}.grades-scale-flag__icon{display:inline-flex;align-items:center;justify-content:center;width:1.1rem;height:1.1rem;border-radius:999px;background:color-mix(in oklab,#f59e0b 20%,var(--theme-surface-1));color:inherit;font-size:.72rem;line-height:1}.grades-scale-flag:focus-visible{outline:2px solid color-mix(in oklab,#f59e0b 58%,var(--theme-primary));outline-offset:3px}.grades-scale-banner__summary{font-size:.74rem;font-weight:700;color:color-mix(in oklab,var(--theme-on-bg) 84%,var(--theme-mix-base))}.grades-scale-tooltip{position:absolute;left:0;top:calc(100% + .7rem);width:min(24rem,calc(100vw - 2rem));display:grid;gap:.5rem;padding:.72rem;border-radius:.82rem;border:1px solid color-mix(in oklab,#f59e0b 24%,var(--theme-mix-base));background:color-mix(in oklab,var(--theme-surface-elevated, var(--theme-surface-1)) 96%,#0f172a);color:var(--theme-on-bg);box-shadow:0 14px 30px color-mix(in oklab,#031326 28%,transparent);opacity:0;pointer-events:none;transform:translateY(.2rem);transition:opacity .14s ease,transform .14s ease;visibility:hidden;z-index:5}.grades-scale-flag-wrap:hover .grades-scale-tooltip,.grades-scale-flag-wrap:focus-within .grades-scale-tooltip{opacity:1;visibility:visible;transform:translateY(0)}.grades-scale-tooltip__title{font-size:.82rem;font-weight:800}.grades-scale-tooltip__body,.grades-scale-tooltip__note{margin:0;font-size:.72rem;line-height:1.45;color:color-mix(in oklab,var(--theme-on-bg) 80%,var(--theme-mix-base))}.grades-scale-tooltip__grid{display:grid;gap:.34rem}.grades-scale-tooltip__row{display:flex;align-items:center;justify-content:space-between;gap:.75rem;padding:.44rem .5rem;border-radius:.62rem;border:1px solid rgba(255,255,255,.08);background:#ffffff08}.grades-scale-tooltip__letter{font-size:.72rem;font-weight:800}.grades-scale-tooltip__range{font-size:.76rem;line-height:1.2;text-align:right}.grades-header__actions{display:flex;align-items:center;gap:.44rem;flex-shrink:0;justify-content:flex-end}.grades-metrics{grid-area:metrics;display:flex;gap:.44rem;flex-wrap:nowrap;min-width:0;justify-self:start;align-self:center}.grades-metric{display:flex;align-items:center;gap:.34rem;padding:.3rem .58rem;border-radius:.68rem;border:1px solid var(--theme-border-subtle);background:var(--theme-surface-inset)}.grades-metric__label{font-size:.66rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;opacity:.62}.grades-metric__value{font-size:1rem;line-height:1}.grades-stats-row{grid-area:stats;display:flex;flex-wrap:nowrap;gap:.44rem;align-items:center;justify-content:center;min-width:0;width:-moz-max-content;width:max-content;max-width:100%;justify-self:center;align-self:center}.grades-stat-inline{display:inline-flex;align-items:center;gap:.34rem;padding:.34rem .6rem;border:1px solid var(--theme-border-subtle);border-radius:999px;background:var(--theme-surface-inset);font-size:.72rem;font-weight:700;color:color-mix(in oklab,var(--theme-on-bg) 80%,var(--theme-mix-base));white-space:nowrap}.grades-stat-inline strong{font-size:inherit;opacity:1;font-variant-numeric:tabular-nums;color:var(--theme-text-strong)}.grades-stat-inline--earned strong{color:#34d399}.grades-stat-inline--lost strong{color:#f87171}.grades-stat-sep{font-size:.72rem;opacity:.34}.grades-pill{display:inline-flex;align-items:center;padding:.12rem .46rem;border-radius:999px;font-size:.76rem;font-weight:800;border:1px solid transparent}.grades-pill--sm{font-size:.68rem;padding:.08rem .36rem}.grades-pill--good{background:color-mix(in oklab,#059669 12%,var(--theme-surface-1));border-color:color-mix(in oklab,#059669 26%,var(--theme-mix-base));color:#059669}.grades-pill--mid{background:color-mix(in oklab,#d97706 12%,var(--theme-surface-1));border-color:color-mix(in oklab,#d97706 26%,var(--theme-mix-base));color:#d97706}.grades-pill--poor{background:color-mix(in oklab,#dc2626 12%,var(--theme-surface-1));border-color:color-mix(in oklab,#dc2626 26%,var(--theme-mix-base));color:#dc2626}.grades-select{display:grid;gap:.32rem;font-size:1rem;font-weight:700;flex:0 1 clamp(20rem,34vw,28rem);width:min(100%,clamp(20rem,34vw,28rem));max-width:28rem}.grades-search input{width:100%;min-height:2.28rem;padding:.48rem .68rem;border-radius:.66rem;border:1px solid var(--theme-button-secondary-border);background:color-mix(in oklab,var(--theme-surface-elevated) 88%,var(--theme-bg));color:var(--theme-text-strong);font:inherit}.grades-select select{width:100%;min-height:var(--grades-control-height);padding:.5rem 2.2rem .5rem .68rem;border-radius:.64rem;border:1px solid var(--theme-button-secondary-border);background:color-mix(in oklab,var(--theme-surface-elevated) 88%,var(--theme-bg));color:var(--theme-text-strong);font:inherit;-moz-appearance:none;appearance:none;-webkit-appearance:none;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='%23888' stroke-width='1.5' fill='none' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right .72rem center}.grades-primary-btn,.grades-icon-btn{border-radius:999px;font:inherit;font-weight:800;cursor:pointer;transition:transform .18s ease,box-shadow .18s ease,opacity .18s ease}.grades-primary-btn{border:1px solid color-mix(in oklab,var(--theme-primary) 38%,transparent);min-height:var(--grades-control-height);height:var(--grades-control-height);padding:0 .9rem;display:inline-flex;align-items:center;justify-content:center;white-space:nowrap;background:var(--theme-cta-bg);color:var(--theme-on-primary);box-shadow:var(--theme-cta-shadow)}.grades-icon-btn{width:var(--grades-control-height);height:var(--grades-control-height);border:1px solid var(--theme-button-secondary-border);background:var(--theme-button-secondary-bg);color:var(--theme-text-strong);display:inline-flex;align-items:center;justify-content:center}.grades-icon-btn svg{width:.98rem;height:.98rem}.grades-primary-btn:hover,.grades-icon-btn:hover{transform:translateY(-1px)}.grades-primary-btn:disabled,.grades-icon-btn:disabled{opacity:.5;cursor:not-allowed;transform:none;box-shadow:none}.grades-toast{padding:.72rem .9rem;border-radius:.85rem;border:1px solid transparent;font-size:.84rem;font-weight:700}.grades-toast--info{background:color-mix(in oklab,var(--theme-primary) 10%,var(--theme-surface-1));border-color:color-mix(in oklab,var(--theme-primary) 24%,var(--theme-mix-base))}.grades-toast--success{background:color-mix(in oklab,#059669 10%,var(--theme-surface-1));border-color:color-mix(in oklab,#059669 24%,var(--theme-mix-base))}.grades-toast--error{background:color-mix(in oklab,#dc2626 10%,var(--theme-surface-1));border-color:color-mix(in oklab,#dc2626 24%,var(--theme-mix-base))}.grades-banner{padding:.72rem .88rem;border-radius:.82rem;border:1px solid var( --theme-border-soft, color-mix(in oklab, var(--theme-primary) 18%, transparent) );background:color-mix(in oklab,var(--theme-primary) 9%,var(--theme-surface-elevated, var(--theme-surface-1)));font-size:.84rem;font-weight:700}.grades-banner--demo-limit{border-color:color-mix(in oklab,var(--theme-primary) 28%,transparent)}.grades-banner-link{font-weight:800;color:var(--theme-primary);text-decoration:underline;text-underline-offset:.15em}.grades-analytics{border:1px solid var( --theme-border-soft, color-mix(in oklab, var(--theme-primary) 16%, var(--theme-mix-base)) );border-radius:.95rem;background:linear-gradient(145deg,color-mix(in oklab,var(--theme-surface-elevated, var(--theme-surface-1)) 96%,var(--theme-mix-base)),color-mix(in oklab,var(--theme-surface-subtle, var(--theme-panel-inset-bg)) 95%,var(--theme-mix-base)));padding:.82rem .88rem}.grades-chart-grid{display:grid;grid-template-columns:minmax(0,.6fr) minmax(0,1fr);gap:.72rem}.grades-chart-legend--desktop{grid-column:1 / -1}.grades-chart-legend.grades-chart-legend--mobile{display:none}.grades-chart-card{border:1px solid var( --theme-border-soft, color-mix(in oklab, var(--theme-primary) 14%, var(--theme-mix-base)) );border-radius:.82rem;background:var( --theme-surface-elevated, color-mix(in oklab, var(--theme-bg) 92%, var(--theme-mix-base)) );padding:.62rem;display:grid;gap:.44rem;overflow:visible;min-width:0}.grades-chart-card__header{display:flex;justify-content:space-between;gap:.4rem;align-items:center;min-width:0}.grades-chart-card__header h4{margin:0;font-size:.88rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;min-width:0}.grades-chart-card__header span{font-size:.72rem;font-weight:700;opacity:.72;white-space:nowrap;flex-shrink:0}.grades-chart-card__canvas{position:relative;height:calc(100dvh - 31rem);min-height:260px;display:grid;align-items:stretch}.grades-chart-card__canvas canvas{display:block;width:100%;height:100%!important}.grades-chart-canvas--hidden{visibility:hidden}.grades-chart-fallback{position:absolute;inset:0;display:grid;align-content:center;gap:.6rem;padding:.2rem}.grades-chart-fallback small{font-size:.72rem;color:color-mix(in oklab,var(--theme-on-bg) 68%,var(--theme-mix-base))}.grades-chart-fallback__stack{display:grid;gap:.48rem}.grades-chart-fallback__metric,.grades-chart-fallback__component{display:grid;gap:.24rem}.grades-chart-fallback__metric-head{display:flex;justify-content:space-between;gap:.6rem;align-items:center;font-size:.76rem;font-weight:700}.grades-chart-fallback__track{display:flex;height:.42rem;border-radius:999px;overflow:hidden;background:color-mix(in oklab,var(--theme-on-bg) 8%,var(--theme-surface-subtle, var(--theme-mix-base)))}.grades-chart-fallback__fill{height:100%;border-radius:inherit}.grades-chart-fallback__fill--earned{background:#10b981}.grades-chart-fallback__fill--ungraded{background:#94a3b8}.grades-chart-fallback__fill--lost{background:#ef4444}.grades-chart-fallback--components{gap:.48rem}.grades-clock-hands{--grades-clock-hands-color: color-mix(in oklab, var(--theme-on-bg) 88%, #000);position:absolute;inset:15%;width:70%;height:70%;pointer-events:none;z-index:1;overflow:visible}.grades-clock-hands__line{stroke:var(--grades-clock-hands-color);stroke-linecap:round;fill:none;filter:drop-shadow(0 0 1px rgba(255,255,255,.16))}.grades-clock-hands__line--red{stroke-width:2;opacity:.68}.grades-clock-hands__line--green{stroke-width:2.4;opacity:.88}.grades-clock-hands__hub{fill:var(--grades-clock-hands-color);filter:drop-shadow(0 0 1px rgba(255,255,255,.16))}[data-theme=dark] .grades-clock-hands{--grades-clock-hands-color: color-mix( in oklab, white 94%, var(--theme-on-bg) )}@media (prefers-color-scheme: dark){:root:not([data-theme=light]) .grades-clock-hands{--grades-clock-hands-color: color-mix( in oklab, white 94%, var(--theme-on-bg) )}}.grades-breakdown-row__track{display:flex;height:.5rem;border-radius:999px;overflow:hidden;background:color-mix(in oklab,var(--theme-on-bg) 8%,var(--theme-surface-subtle, var(--theme-mix-base)))}.grades-breakdown-row__segment{height:100%;flex-shrink:0}.grades-breakdown-row__segment--earned{background:#10b981}.grades-breakdown-row__segment--ungraded{background:#94a3b8}.grades-breakdown-row__segment--lost{background:#ef4444}.grades-table{border:1px solid var( --theme-border-soft, color-mix(in oklab, var(--theme-primary) 16%, var(--theme-mix-base)) );border-radius:.95rem;background:linear-gradient(145deg,color-mix(in oklab,var(--theme-surface-elevated, var(--theme-surface-1)) 96%,var(--theme-mix-base)),color-mix(in oklab,var(--theme-surface-subtle, var(--theme-panel-inset-bg)) 95%,var(--theme-mix-base)));padding:.82rem .88rem}.grades-toolbar{display:flex;flex-wrap:wrap;gap:.52rem;align-items:center;margin-bottom:.78rem}.grades-toolbar__search-wrap{display:flex;align-items:center;gap:.52rem;flex:1;min-width:160px}.grades-search{display:grid;gap:.32rem;flex:1;min-width:0}.grades-filter-pills{display:flex;flex-wrap:wrap;gap:.36rem}.grades-filter-pills button:not(.grades-filter-pills__quick-entry){border:1px solid var( --theme-border-soft, color-mix(in oklab, var(--theme-primary) 18%, var(--theme-mix-base)) );background:color-mix(in oklab,var(--theme-surface-subtle, var(--theme-surface-1)) 92%,var(--theme-mix-base));color:var(--theme-on-bg);border-radius:999px;min-height:2.12rem;padding:.46rem .7rem;font:inherit;font-size:.76rem;font-weight:800;cursor:pointer}.grades-filter-pills button:not(.grades-filter-pills__quick-entry).selected{background:color-mix(in oklab,var(--theme-primary) 20%,var(--theme-mix-base));border-color:color-mix(in oklab,var(--theme-primary) 34%,var(--theme-mix-base))}.grades-complete-chip{display:inline-flex;align-items:center;padding:.28rem .6rem;border-radius:999px;background:color-mix(in oklab,#059669 14%,var(--theme-surface-1));border:1px solid color-mix(in oklab,#059669 22%,var(--theme-mix-base));color:#059669;font-size:.72rem;font-weight:800;white-space:nowrap}.grades-accordion{display:grid;gap:.56rem}.grades-accordion__item{border:1px solid var( --theme-border-soft, color-mix(in oklab, var(--theme-primary) 26%, var(--theme-mix-base)) );border-radius:.82rem;background:color-mix(in oklab,var(--theme-surface-subtle, var(--theme-surface-1)) 94%,var(--theme-mix-base));overflow:visible;box-shadow:0 10px 20px color-mix(in oklab,#031326 8%,transparent)}.grades-accordion__item--collapsed{box-shadow:0 8px 16px color-mix(in oklab,#031326 6%,transparent)}.grades-accordion__header{position:relative;width:100%;padding:.66rem .76rem;cursor:default;z-index:1}.grades-accordion__title{display:flex;gap:.68rem;align-items:center}.grades-accordion__edit-btn{flex-shrink:0;color:color-mix(in oklab,var(--theme-on-bg) 78%,var(--theme-mix-base));opacity:.92}.grades-accordion__edit-btn--active{color:var(--theme-primary);border-color:color-mix(in oklab,var(--theme-primary) 42%,var(--theme-mix-base));background:color-mix(in oklab,var(--theme-primary) 12%,var(--theme-button-secondary-bg));box-shadow:0 0 0 1px color-mix(in oklab,var(--theme-primary) 12%,transparent)}.grades-accordion__edit-btn:disabled{cursor:not-allowed;opacity:.35}.grades-accordion__title h4{margin:0;font-size:.98rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.grades-accordion__title-left{display:grid;gap:.1rem;min-width:100px;overflow:hidden}.grades-accordion__weight{font-size:.7rem;opacity:.62;white-space:nowrap}.grades-accordion__track-wrap{position:relative;flex:1;min-width:48px;display:flex;align-items:center;padding:0;border:0;margin:0;-webkit-appearance:none;-moz-appearance:none;appearance:none;background:transparent;cursor:default;overflow:visible}.grades-accordion__track{display:flex;width:100%;height:.5rem;border-radius:999px;overflow:hidden;background:color-mix(in oklab,var(--theme-on-bg) 8%,var(--theme-surface-subtle, var(--theme-mix-base)))}.grades-accordion__track-wrap:focus-visible{outline:2px solid color-mix(in oklab,var(--theme-primary) 62%,#0ea5e9);outline-offset:4px;border-radius:999px;z-index:3}.grades-accordion__track-tooltip{position:absolute;left:50%;bottom:calc(100% + .6rem);transform:translate(-50%) translateY(.2rem);display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:.38rem;min-width:15rem;padding:.52rem;border-radius:.7rem;border:1px solid color-mix(in oklab,var(--theme-primary) 16%,var(--theme-mix-base));background:color-mix(in oklab,var(--theme-surface-elevated, var(--theme-surface-1)) 96%,#0f172a);color:var(--theme-on-bg);font-size:.72rem;line-height:1.4;text-align:left;white-space:nowrap;box-shadow:0 12px 24px color-mix(in oklab,#031326 24%,transparent);opacity:0;pointer-events:none;transition:opacity .14s ease,transform .14s ease;visibility:hidden;z-index:4}.grades-accordion__track-metric{display:grid;gap:.16rem;min-width:0;padding:.42rem .5rem;border-radius:.58rem;border:1px solid rgba(255,255,255,.08);background:#ffffff08}.grades-accordion__track-metric span{font-size:.64rem;font-weight:700;letter-spacing:.01em;opacity:.78}.grades-accordion__track-metric strong{font-size:.84rem;line-height:1.1}.grades-accordion__track-metric--secured strong{color:#10b981}.grades-accordion__track-metric--ungraded strong{color:#cbd5e1}.grades-accordion__track-metric--lost strong{color:#ef4444}.grades-accordion__track-wrap:hover .grades-accordion__track-tooltip,.grades-accordion__track-wrap:focus-visible .grades-accordion__track-tooltip{opacity:1;visibility:visible;transform:translate(-50%) translateY(0)}.grades-accordion__track-wrap:hover{z-index:3}.grades-accordion__score-info{display:flex;align-items:center;gap:.36rem;flex-shrink:0}.grades-accordion__score-summary{display:grid;gap:.05rem}.grades-accordion__score-value{display:inline-flex;align-items:center;gap:.32rem}.grades-accordion__score-label{font-size:.62rem;font-weight:700;letter-spacing:.01em;opacity:.7;text-transform:uppercase}.grades-accordion__score-pct{font-size:.88rem}.grades-accordion__progress-text{font-size:.7rem;color:color-mix(in oklab,var(--theme-on-bg) 68%,var(--theme-mix-base));white-space:nowrap}.grades-accordion__excluded-count{font-size:.68rem;opacity:.62}.grades-accordion__toggle{display:inline-flex;align-items:center;gap:.32rem;flex-shrink:0;min-height:2.1rem;padding:.42rem .68rem;border-radius:999px;border:1px solid var( --theme-border-soft, color-mix(in oklab, var(--theme-primary) 18%, var(--theme-mix-base)) );background:color-mix(in oklab,var(--theme-surface-elevated, var(--theme-surface-1)) 94%,var(--theme-mix-base));color:var(--theme-on-bg);font:inherit;font-size:.72rem;font-weight:800;cursor:pointer}.grades-accordion__toggle:hover{background:color-mix(in oklab,var(--theme-primary) 12%,var(--theme-surface-elevated, var(--theme-surface-1)))}.grades-accordion__toggle:focus-visible{outline:2px solid color-mix(in oklab,var(--theme-primary) 62%,#0ea5e9);outline-offset:2px}.grades-accordion__toggle-icon{width:.92rem;height:.92rem;transition:transform .16s ease}.grades-accordion__toggle[aria-expanded=false] .grades-accordion__toggle-icon{transform:rotate(-90deg)}.grades-accordion__body{border-top:1px solid color-mix(in oklab,var(--theme-primary) 10%,var(--theme-mix-base));padding:0 .76rem .76rem}.grades-rows{display:grid;gap:.46rem;padding-top:.68rem}.grades-row{display:grid;grid-template-columns:minmax(0,1fr) auto auto;gap:.46rem;align-items:center;padding:.52rem .6rem;border-radius:.72rem;border:1px solid var( --theme-border-soft, color-mix(in oklab, var(--theme-primary) 12%, var(--theme-mix-base)) );background:var( --theme-surface-elevated, color-mix(in oklab, var(--theme-bg) 94%, var(--theme-mix-base)) )}.grades-row--ungraded{border-color:color-mix(in oklab,#0ea5e9 18%,var(--theme-mix-base));background:color-mix(in oklab,#0ea5e9 8%,var(--theme-surface-subtle, var(--theme-surface-1)))}.grades-row--graded{opacity:.96}.grades-row--ignored{opacity:.62;background:color-mix(in oklab,var(--theme-surface-subtle, var(--theme-surface-1)) 86%,var(--theme-mix-base))}.grades-row--ignored .grades-row__title{text-decoration:line-through;opacity:.72}.grades-row--excluded{border-color:color-mix(in oklab,#64748b 22%,var(--theme-mix-base))}.grades-row__meta{display:flex;flex-direction:column;gap:.16rem;min-width:0}.grades-row__title{font-weight:700;font-size:.92rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.grades-row__due-inline{font-size:.68rem;opacity:.6;font-weight:600}.grades-row__score-wrap{display:flex;align-items:center;gap:.26rem}.grades-row__score{display:flex;align-items:center}.grades-row__score input{width:72px;min-height:2.1rem;padding:.38rem .5rem;border-radius:.58rem;border:1px solid var( --theme-border-soft, color-mix(in oklab, var(--theme-primary) 18%, var(--theme-mix-base)) );background:var( --theme-surface-elevated, color-mix(in oklab, var(--theme-bg) 92%, var(--theme-mix-base)) );color:var(--theme-on-bg);font:inherit;font-size:.88rem;text-align:right}.grades-row__score-denom{font-size:.72rem;opacity:.52;white-space:nowrap}.grades-row__clear-btn{display:inline-flex;align-items:center;justify-content:center;width:1.4rem;height:1.4rem;border-radius:50%;border:none;background:color-mix(in oklab,var(--theme-on-bg) 9%,var(--theme-surface-subtle, var(--theme-mix-base)));color:var(--theme-on-bg);font-size:.8rem;cursor:pointer;opacity:.6;transition:opacity .14s ease}.grades-row__clear-btn:hover{opacity:1}.grades-row__clear-btn--restore{background:color-mix(in oklab,var(--theme-primary) 18%,var(--theme-surface-subtle, var(--theme-mix-base)));color:var(--theme-primary)}.grades-row__status-label{display:inline-flex;align-items:center;padding:.2rem .56rem;border-radius:999px;font-size:.72rem;font-weight:800;border:1px solid transparent;white-space:nowrap}.grades-row__status-label--excluded{background:color-mix(in oklab,#64748b 14%,var(--theme-surface-1));border-color:color-mix(in oklab,#64748b 22%,var(--theme-mix-base));color:color-mix(in oklab,#334155 76%,var(--theme-on-bg))}.grades-row__toggle-btn{min-height:2rem;padding:.34rem .68rem;border-radius:.54rem;border:1px solid color-mix(in oklab,var(--theme-on-bg) 12%,var(--theme-surface-subtle, var(--theme-mix-base)));background:color-mix(in oklab,var(--theme-surface-elevated, var(--theme-surface-1)) 96%,white);color:var(--theme-on-bg);font:inherit;font-size:.74rem;font-weight:800;cursor:pointer;transition:transform .14s ease,opacity .14s ease,border-color .14s ease}.grades-row__toggle-btn:hover{transform:translateY(-1px)}.grades-row__toggle-btn:disabled{opacity:.5;cursor:not-allowed;transform:none}.grades-row__toggle-btn--active{background:color-mix(in oklab,#64748b 16%,var(--theme-surface-1));border-color:color-mix(in oklab,#64748b 28%,var(--theme-mix-base))}.grades-row--add-slot{grid-template-columns:1fr;padding:0;border:1px dashed color-mix(in oklab,var(--theme-primary) 28%,var(--theme-mix-base));border-radius:.72rem;background:color-mix(in oklab,var(--theme-primary) 6%,var(--theme-surface-subtle, var(--theme-surface-1)));box-shadow:none}.grades-accordion__add-slot-btn{display:flex;align-items:center;gap:6px;width:100%;padding:.72rem .84rem;text-align:left;font:inherit;font-size:.82rem;font-weight:700;color:var(--theme-primary);background:none;border:none;cursor:pointer;border-radius:.72rem;transition:background .1s ease,color .1s ease,opacity .1s ease}.grades-accordion__add-slot-btn:hover:not(:disabled){background:color-mix(in oklab,var(--theme-primary) 10%,var(--theme-surface-elevated, var(--theme-surface-1)))}.grades-accordion__add-slot-btn:disabled{opacity:.45;cursor:not-allowed}.grades-accordion__add-slot-label{color:var(--theme-on-bg)}.grades-accordion__add-slot-btn>span[aria-hidden=true]{display:inline-flex;align-items:center;justify-content:center;width:.92rem;height:.92rem;border-radius:999px;background:color-mix(in oklab,var(--theme-primary) 16%,var(--theme-surface-elevated, var(--theme-surface-1)));font-size:.68rem;line-height:1}.grades-row__score input:focus-visible,.grades-search input:focus-visible,.grades-select select:focus-visible,.grades-row__toggle-btn:focus-visible,.grades-accordion__edit-btn:focus-visible,.grades-accordion__add-slot-btn:focus-visible{outline:2px solid color-mix(in oklab,var(--theme-primary) 62%,#0ea5e9);outline-offset:2px}.grades-no-results{padding:.78rem .88rem;border-radius:.78rem;border:1px dashed color-mix(in oklab,var(--theme-primary) 18%,var(--theme-mix-base));background:color-mix(in oklab,var(--theme-surface-subtle, var(--theme-surface-1)) 94%,var(--theme-mix-base));font-size:.78rem;color:color-mix(in oklab,var(--theme-on-bg) 82%,var(--theme-mix-base))}.grades-no-results--section{margin-top:.9rem}.grades-chart-legend{display:grid;grid-template-columns:repeat(8,1fr);gap:.28rem .4rem;padding:.5rem .22rem .12rem}.legend-item{display:flex;align-items:center;justify-content:space-between;gap:.3rem;font-size:.68rem;background:var( --theme-surface-subtle, var(--theme-panel-bg, rgba(255, 255, 255, .05)) );border:1px solid var( --theme-border-soft, var(--theme-panel-border, rgba(255, 255, 255, .08)) );border-radius:.3rem;padding:.18rem .42rem;overflow:hidden}.legend-item__name{font-weight:600;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.legend-item__contrib{font-weight:700;white-space:nowrap;flex-shrink:0;font-variant-numeric:tabular-nums}[data-theme=light] .grades-filter-pills button:not(.grades-filter-pills__quick-entry){background:var(--theme-cta-bg);border-color:color-mix(in oklab,var(--theme-primary) 48%,var(--theme-mix-base));color:var(--theme-on-primary)}.grades-filter-pills button.grades-primary-btn.grades-filter-pills__quick-entry{border-color:color-mix(in oklab,var(--theme-primary) 38%,transparent);min-height:var(--grades-control-height);height:var(--grades-control-height);padding:0 .9rem;background:var(--theme-cta-bg);color:var(--theme-on-primary);box-shadow:var(--theme-cta-shadow);line-height:inherit;font-size:inherit;box-sizing:border-box;flex:0 0 auto}[data-theme=light] .grades-filter-pills button:not(.grades-filter-pills__quick-entry).selected{background:var(--theme-cta-bg-hover);border-color:color-mix(in oklab,var(--theme-primary) 60%,var(--theme-mix-base));color:var(--theme-on-primary)}[data-theme=light] .grades-icon-btn{background:var(--theme-cta-bg);border-color:color-mix(in oklab,var(--theme-primary) 48%,var(--theme-mix-base));color:var(--theme-on-primary)}.legend-item__weight{font-size:.62rem;opacity:.5;font-weight:500;margin-left:.12rem}[data-theme=dark] #app-view #grade-sheet-view .grade-course-badge{background:color-mix(in oklab,var(--theme-primary) 10%,var(--theme-surface-2));border-color:color-mix(in oklab,var(--theme-primary) 30%,transparent);color:var(--theme-on-bg)}@media (prefers-color-scheme: dark){:root:not([data-theme=light]) #app-view #grade-sheet-view .grade-course-badge{background:color-mix(in oklab,var(--theme-primary) 10%,var(--theme-surface-2));border-color:color-mix(in oklab,var(--theme-primary) 30%,transparent);color:var(--theme-on-bg)}}[data-theme=dark] .grades-metric{background:color-mix(in oklab,var(--theme-primary) 10%,var(--theme-surface-2));border-color:color-mix(in oklab,var(--theme-primary) 30%,transparent)}[data-theme=dark] .grades-stat-inline{background:color-mix(in oklab,var(--theme-primary) 10%,var(--theme-surface-2));border-color:color-mix(in oklab,var(--theme-primary) 20%,transparent)}[data-theme=dark] .grades-metric__label{opacity:.75;color:var(--theme-on-bg)}[data-theme=dark] .grades-metric__value{color:var(--theme-on-bg)}[data-theme=dark] .grades-pill--good{background:color-mix(in oklab,#22c55e 24%,var(--theme-surface-2));border-color:color-mix(in oklab,#22c55e 42%,var(--theme-mix-base));color:#d9fbe8;box-shadow:inset 0 1px #ffffff14}@media (prefers-color-scheme: dark){:root:not([data-theme=light]) .grades-metric{background:color-mix(in oklab,var(--theme-primary) 10%,var(--theme-surface-2));border-color:color-mix(in oklab,var(--theme-primary) 30%,transparent)}:root:not([data-theme=light]) .grades-stat-inline{background:color-mix(in oklab,var(--theme-primary) 10%,var(--theme-surface-2));border-color:color-mix(in oklab,var(--theme-primary) 20%,transparent)}:root:not([data-theme=light]) .grades-metric__label{opacity:.75;color:var(--theme-on-bg)}:root:not([data-theme=light]) .grades-metric__value{color:var(--theme-on-bg)}:root:not([data-theme=light]) .grades-pill--good{background:color-mix(in oklab,#22c55e 24%,var(--theme-surface-2));border-color:color-mix(in oklab,#22c55e 42%,var(--theme-mix-base));color:#d9fbe8;box-shadow:inset 0 1px #ffffff14}}[data-theme=dark] .grades-chart-card{background:color-mix(in oklab,var(--theme-surface-1) 78%,var(--theme-bg));border-color:var(--theme-border-soft)}@media (prefers-color-scheme: dark){:root:not([data-theme=light]) .grades-chart-card{background:color-mix(in oklab,var(--theme-surface-1) 78%,var(--theme-bg));border-color:var(--theme-border-soft)}}[data-theme=dark] .grades-accordion__header{background:color-mix(in oklab,var(--theme-primary) 22%,var(--theme-surface-1))}[data-theme=dark] .grades-accordion__title h4,[data-theme=dark] .grades-accordion__weight{color:var(--theme-on-bg)}@media (prefers-color-scheme: dark){:root:not([data-theme=light]) .grades-accordion__header{background:color-mix(in oklab,var(--theme-primary) 22%,var(--theme-surface-1))}:root:not([data-theme=light]) .grades-accordion__title h4,:root:not([data-theme=light]) .grades-accordion__weight{color:var(--theme-on-bg)}}[data-theme=dark] .grades-row{background:color-mix(in oklab,var(--theme-surface-1) 72%,var(--theme-bg));border-color:color-mix(in oklab,var(--theme-primary) 18%,var(--theme-surface-2))}@media (prefers-color-scheme: dark){:root:not([data-theme=light]) .grades-row{background:color-mix(in oklab,var(--theme-surface-1) 72%,var(--theme-bg));border-color:color-mix(in oklab,var(--theme-primary) 18%,var(--theme-surface-2))}}[data-theme=dark] .grades-select select,[data-theme=dark] .grades-search input{background:color-mix(in oklab,var(--theme-bg) 62%,var(--theme-surface-1));border-color:var(--theme-border-soft)}[data-theme=dark] .grades-select select{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='%23ecf6ff' stroke-width='1.5' fill='none' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right .72rem center}@media (prefers-color-scheme: dark){:root:not([data-theme=light]) .grades-select select,:root:not([data-theme=light]) .grades-search input{background:color-mix(in oklab,var(--theme-bg) 62%,var(--theme-surface-1));border-color:var(--theme-border-soft)}:root:not([data-theme=light]) .grades-select select{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='%23ecf6ff' stroke-width='1.5' fill='none' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right .72rem center}}@media (max-width: 1100px){.grades-chart-grid{grid-template-columns:1fr}}@media (max-width: 768px){.grades-shell{width:100%;gap:.78rem}.grades-header{padding:.72rem .78rem}.grades-chart-card__canvas{height:184px;min-height:184px}.grades-row{grid-template-columns:1fr;align-items:stretch}.grades-clock-hands{inset:13%;width:74%;height:74%}.grades-accordion__track{display:none}.grades-accordion__title{flex-wrap:wrap;align-items:flex-start}.grades-accordion__score-info{order:3;width:100%}.grades-accordion__toggle{margin-left:auto}.grades-header__grid,.grades-header__grid--header-only{grid-template-columns:1fr;grid-template-areas:"course" "selector" "metrics" "stats" "actions";align-items:stretch}.grades-header__selector,.grades-header__actions-wrap{width:100%;justify-content:flex-start}.grades-mobile-select{width:100%;max-width:100%}.grades-mobile-select select{width:100%;font-size:.9rem;min-height:2.6rem}.grades-scale-banner{width:100%;align-items:flex-start}.grades-metrics{display:flex;flex-direction:column;gap:.32rem}.grades-metric{padding:.38rem .62rem}.grades-metric__value{font-size:1.2rem}.grades-header__actions{width:100%;justify-content:flex-end}.grades-stats-row{width:100%;display:grid;grid-template-columns:repeat(3,1fr);gap:.4rem;text-align:center}#grade-sheet-view .mobile-course-chip-row{display:none}.grades-stat-inline{display:flex;flex-direction:column;align-items:center;gap:.12rem;font-size:.7rem;padding:.32rem .2rem;border:1px solid var(--theme-border-subtle);border-radius:.5rem;background:var(--theme-surface-inset)}.grades-stat-inline strong{font-size:.9rem}.grades-shell{display:contents}.grades-analytics{border:none;border-radius:0;background:none;padding:0}.grades-chart-grid{display:contents}.grades-chart-legend--mobile{display:grid}.grades-chart-legend--desktop{display:none}.grades-snap-section{scroll-snap-align:start;min-height:100dvh;display:flex;flex-direction:column;justify-content:flex-start;padding:.72rem;box-sizing:border-box}.grades-snap-section--header{gap:.72rem}.grades-snap-section--bar-chart,.grades-snap-section--donut-chart{gap:.72rem;justify-content:center}.grades-snap-section--accordion{gap:0}.grades-chart-card{overflow:hidden;width:100%;max-width:100%}.grades-chart-card__canvas{overflow:hidden;width:100%;max-width:100%;height:220px;min-height:220px}.grades-chart-card__canvas canvas{max-width:100%;width:100%;display:block}.grades-chart-legend{grid-template-columns:repeat(2,1fr);gap:.36rem}.grades-chart-legend .legend-item{grid-column:span 1!important}.legend-item{padding:.9rem .6rem;flex-direction:column;align-items:flex-start;gap:.2rem}.legend-item__name{font-size:.8rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:100%}.legend-item__contrib{font-size:.78rem}.grades-intro--snap-ghost{display:none}#grade-toast{position:fixed;bottom:calc(4rem + env(safe-area-inset-bottom,0px));left:50%;transform:translate(-50%);z-index:150;min-width:220px;max-width:calc(100vw - 2rem);text-align:center}}
