*,*:before,*:after{margin:0;padding:0;box-sizing:border-box}:root{--bg: #f4f5f7;--card: #ffffff;--primary: #4f46e5;--primary-hover: #4338ca;--primary-light: #eef2ff;--primary-faint: #f5f3ff;--text: #1e293b;--text-muted: #64748b;--text-light: #94a3b8;--border: #e2e8f0;--border-focus: #a5b4fc;--green: #10b981;--green-bg: #ecfdf5;--blue: #3b82f6;--blue-bg: #eff6ff;--amber: #f59e0b;--amber-bg: #fffbeb;--red: #ef4444;--red-bg: #fef2f2;--radius: 12px;--shadow-sm: 0 1px 2px rgba(0, 0, 0, .04);--shadow: 0 1px 3px rgba(0, 0, 0, .06), 0 1px 2px rgba(0, 0, 0, .04);--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .07), 0 2px 4px -2px rgba(0, 0, 0, .05);--font: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;--mono: "JetBrains Mono", "Fira Code", "SF Mono", monospace;--sidebar-w: 260px}html{font-size:16px;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{font-family:var(--font);background:var(--bg);color:var(--text);line-height:1.6;min-height:100vh}.admin-hotspot{position:fixed;right:.5rem;bottom:.5rem;width:20px;height:20px;border:none;background:transparent;opacity:0;cursor:default;z-index:220}.admin-panel{position:fixed;right:.9rem;bottom:.9rem;width:min(340px,calc(100vw - 1.8rem));background:var(--card);border:1px solid var(--border);border-radius:12px;box-shadow:var(--shadow-md);padding:.9rem;z-index:230}.admin-panel h3{font-size:.95rem;margin-bottom:.3rem}.admin-panel p{color:var(--text-muted);font-size:.8rem}.admin-note{margin-bottom:.45rem}.admin-panel-close{position:absolute;top:.4rem;right:.45rem;border:none;background:transparent;color:var(--text-light);font-size:1.2rem;line-height:1;cursor:pointer}.admin-form{display:flex;flex-direction:column;gap:.6rem;margin-top:.35rem}.admin-field{display:flex;flex-direction:column;gap:.25rem}.admin-field span{font-size:.75rem;font-weight:500;color:var(--text-muted)}.admin-field input{border:1.5px solid var(--border);border-radius:8px;padding:.55rem .7rem;outline:none;font-size:.9rem;font-family:var(--font)}.admin-field input:focus{border-color:var(--primary);box-shadow:0 0 0 3px #4f46e51a}.auth-submit{margin-top:.2rem;border:none;border-radius:8px;background:var(--primary);color:#fff;font-weight:600;font-size:.92rem;font-family:var(--font);padding:.7rem .95rem;cursor:pointer;transition:background .15s ease}.auth-submit:hover{background:var(--primary-hover)}.auth-submit:disabled{opacity:.7;cursor:wait}.auth-error{color:var(--red);font-size:.75rem;margin-top:.45rem}.layout{display:flex;min-height:100vh}.main-content{flex:1;min-width:0}.app{max-width:680px;margin:0 auto;padding:2rem 1.5rem 4rem}.admin-meta{color:var(--text-muted);font-size:.78rem;margin:.3rem 0 .4rem}.admin-actions{display:flex;align-items:center;gap:.5rem;justify-content:flex-start}.sync-badge{border-radius:9999px;padding:.2rem .6rem;background:var(--primary-light);color:var(--primary);font-weight:600;font-size:.72rem}.logout-btn{border:1px solid var(--border);border-radius:6px;background:#fff;color:var(--text-muted);padding:.25rem .55rem;font-family:var(--font);font-size:.75rem;cursor:pointer}.logout-btn:hover{color:var(--red);border-color:var(--red)}.sync-error{margin-top:.45rem;font-size:.75rem;color:var(--red)}.sidebar{width:var(--sidebar-w);flex-shrink:0;background:var(--card);border-right:1px solid var(--border);height:100vh;position:sticky;top:0;display:flex;flex-direction:column;overflow:hidden}.sidebar-header{display:flex;align-items:center;justify-content:space-between;padding:1.25rem 1rem .75rem;border-bottom:1px solid var(--border)}.sidebar-header h2{font-size:.85rem;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em}.new-btn{font-family:var(--font);font-size:.75rem;font-weight:500;color:var(--primary);background:var(--primary-light);border:none;border-radius:6px;padding:.3rem .65rem;cursor:pointer;transition:all .15s ease}.new-btn:hover{background:var(--primary);color:#fff}.session-list{flex:1;overflow-y:auto;padding:.5rem}.session-empty{padding:1.5rem .75rem;font-size:.8rem;color:var(--text-light);text-align:center;line-height:1.5}.session-card{display:flex;align-items:center;gap:.25rem;padding:.65rem .75rem;border-radius:8px;cursor:pointer;transition:all .12s ease;margin-bottom:.25rem;-webkit-tap-highlight-color:transparent;touch-action:manipulation}@media(hover:hover){.session-card:hover{background:var(--bg)}}.session-card.active{background:var(--primary-light)}.session-card-body{flex:1;min-width:0}.session-card-name{font-size:.82rem;font-weight:500;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.session-card.active .session-card-name{color:var(--primary)}.session-card-meta{display:flex;align-items:center;gap:.4rem;margin-top:.15rem}.session-card-gpa{font-family:var(--mono);font-size:.72rem;color:var(--text-light);font-weight:500}.session-card-letter{font-size:.65rem;font-weight:600;padding:.05rem .35rem;border-radius:4px}.sl-A{background:var(--green-bg);color:var(--green)}.sl-B{background:var(--blue-bg);color:var(--blue)}.sl-C{background:var(--amber-bg);color:var(--amber)}.sl-D,.sl-F{background:var(--red-bg);color:var(--red)}.session-delete{font-family:var(--font);font-size:1.1rem;line-height:1;color:var(--text-light);background:none;border:none;border-radius:4px;width:24px;height:24px;display:flex;align-items:center;justify-content:center;cursor:pointer;opacity:0;transition:all .12s ease;flex-shrink:0}@media(hover:hover){.session-card:hover .session-delete{opacity:1}.session-delete:hover{color:var(--red);background:var(--red-bg)}}@media(hover:none){.session-delete{opacity:.7}}.sidebar-toggle,.sidebar-overlay{display:none}.name-bar{display:flex;align-items:center;gap:.75rem;margin-bottom:1rem}.name-input{flex:1;padding:.6rem .85rem;border:1.5px solid var(--border);border-radius:8px;font-family:var(--font);font-size:.95rem;font-weight:500;color:var(--text);background:var(--card);outline:none;transition:border-color .15s ease,box-shadow .15s ease}.name-input::placeholder{color:var(--text-light);font-weight:400}.name-input:focus{border-color:var(--primary);box-shadow:0 0 0 3px #4f46e51a}.name-hint{font-size:.72rem;font-weight:500;color:var(--text-light);white-space:nowrap;padding:.2rem .5rem;border-radius:4px;background:var(--bg)}.name-hint.saved{color:var(--green);background:var(--green-bg)}.header{text-align:center;margin-bottom:1.5rem}.header h1{font-size:1.75rem;font-weight:700;letter-spacing:-.02em;color:var(--text)}.subtitle{color:var(--text-muted);font-size:.875rem;margin-top:.25rem}.card{background:var(--card);border-radius:var(--radius);box-shadow:var(--shadow);padding:1.5rem;margin-bottom:1rem}.card h2{font-size:1rem;font-weight:600;margin-bottom:.5rem;display:flex;align-items:center;gap:.5rem}.hint{font-size:.8rem;color:var(--text-muted);margin-bottom:1rem;line-height:1.4}.badge{font-size:.75rem;font-weight:500;padding:.125rem .5rem;border-radius:9999px;background:var(--primary-light);color:var(--primary)}.lo-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(72px,1fr));gap:.5rem;margin-bottom:1rem}.lo-toggle{position:relative;cursor:pointer;-webkit-user-select:none;user-select:none}.lo-toggle input{position:absolute;opacity:0;width:0;height:0}.lo-label{display:flex;align-items:center;justify-content:center;padding:.5rem .25rem;border-radius:8px;border:1.5px solid var(--border);font-size:.8rem;font-weight:500;color:var(--text-muted);transition:all .15s ease;background:var(--card)}.lo-toggle:hover .lo-label{border-color:var(--border-focus)}.lo-toggle.active .lo-label{background:var(--primary);border-color:var(--primary);color:#fff;box-shadow:0 1px 3px #4f46e54d}.lo-points{font-size:.85rem;color:var(--text-muted);padding-top:.25rem;border-top:1px solid var(--border)}.lo-points strong{color:var(--primary);font-weight:600}.lo-table{display:grid;grid-template-columns:repeat(4,1fr);gap:.25rem;margin-top:.75rem;font-size:.7rem;color:var(--text-light)}.lo-table-item{display:flex;justify-content:space-between;padding:.2rem .4rem;border-radius:4px;background:var(--bg)}.lo-table-item.current{background:var(--primary-light);color:var(--primary);font-weight:600}.lo-table-item span:first-child{opacity:.7}.input-group{display:grid;grid-template-columns:repeat(3,1fr);gap:.75rem}.input-group.single{grid-template-columns:1fr;max-width:220px}.input-group label{display:flex;flex-direction:column;gap:.35rem}.input-group label>span{font-size:.8rem;font-weight:500;color:var(--text-muted)}.pct-input{position:relative;display:flex;align-items:center}.pct-input input[type=number]{width:100%;padding:.55rem 2rem .55rem .75rem;border:1.5px solid var(--border);border-radius:8px;font-size:1rem;font-family:var(--mono);font-weight:500;color:var(--text);background:var(--card);outline:none;transition:border-color .15s ease,box-shadow .15s ease;-moz-appearance:textfield}.pct-input input[type=number]::-webkit-inner-spin-button,.pct-input input[type=number]::-webkit-outer-spin-button{opacity:1}.pct-input input[type=number]:focus{border-color:var(--primary);box-shadow:0 0 0 3px #4f46e51a}.pct-suffix{position:absolute;right:.65rem;font-size:.85rem;font-weight:500;color:var(--text-light);pointer-events:none}.gp-preview{font-size:.75rem;font-family:var(--mono);color:var(--primary);font-weight:500;margin-top:-.1rem}.contribution{font-size:.72rem;color:var(--text-light);margin-top:.35rem}.contribution strong{font-family:var(--mono);color:var(--text-muted);font-weight:600}.ec-grid{display:grid;grid-template-columns:repeat(6,1fr);gap:.5rem}.formula-card{background:var(--bg);border:1px solid var(--border);box-shadow:none}.formula{font-family:var(--mono);font-size:.78rem;line-height:2;overflow-x:auto}.formula-line{white-space:nowrap;color:var(--text-muted)}.formula-line.label-line{color:var(--text);font-weight:500}.formula-line .val{color:var(--primary);font-weight:500}.formula-line.final{color:var(--text);font-weight:600;font-size:.85rem;margin-top:.25rem;padding-top:.5rem;border-top:1px dashed var(--border)}.grade-card{text-align:center;padding:2rem;transition:background .3s ease,border-color .3s ease;border:2px solid transparent}.grade-card.grade-A{background:var(--green-bg);border-color:var(--green)}.grade-card.grade-B{background:var(--blue-bg);border-color:var(--blue)}.grade-card.grade-C{background:var(--amber-bg);border-color:var(--amber)}.grade-card.grade-D,.grade-card.grade-F{background:var(--red-bg);border-color:var(--red)}.grade-display{display:flex;align-items:baseline;justify-content:center;gap:1rem;margin-bottom:1rem}.gpa{font-family:var(--mono);font-size:3rem;font-weight:700;letter-spacing:-.03em;line-height:1}.letter{font-size:2rem;font-weight:700;opacity:.6}.grade-A .gpa,.grade-A .letter{color:var(--green)}.grade-B .gpa,.grade-B .letter{color:var(--blue)}.grade-C .gpa,.grade-C .letter{color:var(--amber)}.grade-D .gpa,.grade-D .letter,.grade-F .gpa,.grade-F .letter{color:var(--red)}.grade-scale{display:flex;justify-content:center;gap:.75rem;font-size:.75rem;color:var(--text-light);flex-wrap:wrap}.grade-scale span{padding:.15rem .5rem;border-radius:4px;transition:all .15s ease}.grade-scale span.active{background:var(--text);color:var(--card);font-weight:600}.reset-bar{text-align:right;margin-bottom:.5rem}.reset-btn{font-family:var(--font);font-size:.75rem;color:var(--text-light);background:none;border:1px solid var(--border);border-radius:6px;padding:.3rem .75rem;cursor:pointer;transition:all .15s ease}.reset-btn:hover{color:var(--red);border-color:var(--red);background:var(--red-bg)}@media(max-width:840px){.sidebar{position:fixed;left:0;top:0;z-index:100;transform:translate(-100%);transition:transform .25s ease;box-shadow:none}.sidebar.open{transform:translate(0);box-shadow:4px 0 24px #0000001f}.sidebar-toggle{display:flex;align-items:center;gap:.4rem;position:fixed;top:.75rem;left:.75rem;z-index:90;font-family:var(--font);font-size:.8rem;font-weight:500;color:var(--text-muted);background:var(--card);border:1px solid var(--border);border-radius:8px;padding:.4rem .75rem;cursor:pointer;box-shadow:var(--shadow);transition:all .15s ease}.sidebar-toggle span{font-size:1.1rem;line-height:1}.sidebar-toggle:hover{border-color:var(--primary);color:var(--primary)}.sidebar-overlay{display:block;position:fixed;top:0;right:0;bottom:0;left:0;z-index:99;background:#0003;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.app{padding-top:3.5rem}}@media(max-width:520px){.app{padding:3.5rem .75rem 3rem}.header h1{font-size:1.35rem}.input-group{grid-template-columns:1fr}.ec-grid{grid-template-columns:repeat(3,1fr)}.lo-grid{grid-template-columns:repeat(4,1fr)}.formula{font-size:.68rem}.gpa{font-size:2.5rem}.lo-table{grid-template-columns:repeat(3,1fr)}}
