@import "https://fonts.googleapis.com/css2?family=Outfit:wght@300;400;500;600;700&display=swap";:root{--bg-dark:#0f0f13;--bg-panel:#19191e99;--primary-gradient:linear-gradient(135deg, #3b82f6, #0ea5e9);--text-main:#f8f9fa;--text-muted:#9ca3af;--border-color:#ffffff14;--status-taken:#10b981;--status-taken-bg:#10b9811f;--status-ip:#3b82f6;--status-ip-bg:#3b82f61f;--status-planned:#0ea5e9;--status-planned-bg:#0ea5e91f;--status-failed:#ef4444;--status-failed-bg:#ef44441f;--font-family:"Outfit", -apple-system, BlinkMacSystemFont, sans-serif}*{box-sizing:border-box;margin:0;padding:0}body{background-color:var(--bg-dark);color:var(--text-main);font-family:var(--font-family);-webkit-font-smoothing:antialiased;min-height:100vh;overflow-x:hidden}body:before{content:"";z-index:-1;pointer-events:none;background:radial-gradient(circle,#0ea5e914 0%,#0000 70%);width:50%;height:50%;position:fixed;top:-20%;left:-10%}body:after{content:"";z-index:-1;pointer-events:none;background:radial-gradient(circle,#3b82f614 0%,#0000 70%);width:50%;height:50%;position:fixed;bottom:-20%;right:-10%}body.light{--bg-dark:#f8fafc;--bg-panel:#ffffffd9;--text-main:#0f172a;--text-muted:#64748b;--border-color:#0000001a;--status-taken-bg:#10b98126;--status-ip-bg:#3b82f626;--status-planned-bg:#0ea5e926;--status-failed-bg:#ef444426}body.light .glass-panel{box-shadow:0 8px 32px #0000000d}body.light .input-field,body.light .calc-units-input,body.light .calc-grade-select{color:#0f172a;background:#ffffffe6;border-color:#00000026}body.light .btn-secondary{color:var(--text-main);background:#0000000d;border-color:#0000001a}body.light .btn-secondary:hover{background:#0000001a}.app-container{flex-direction:column;min-height:100vh;display:flex}.privacy-banner{text-align:center;color:#a7f3d0;background:linear-gradient(90deg,#10b9812e,#0ea5e924);border-bottom:1px solid #10b98159;flex-wrap:wrap;justify-content:center;align-items:center;gap:12px;padding:12px 20px;font-size:.9rem;line-height:1.45;display:flex}.privacy-banner-icon{color:#34d399;flex-shrink:0}.privacy-banner-text{max-width:52rem;margin:0}.privacy-banner strong{color:#6ee7b7;font-weight:700}body.light .privacy-banner{color:#065f46;background:linear-gradient(90deg,#10b98124,#0ea5e91a);border-bottom-color:#05966959}body.light .privacy-banner-icon{color:#059669}body.light .privacy-banner strong{color:#047857}.navbar{border-bottom:1px solid var(--border-color);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);z-index:100;background:#0f0f13cc;position:sticky;top:0}body.light .navbar{background:#ffffffd9}.nav-content{justify-content:space-between;align-items:center;max-width:80vw;height:64px;margin:0 auto;padding:0 24px;display:flex}.nav-brand{align-items:center;gap:12px;display:flex}.logo-icon{background:var(--primary-gradient);border-radius:8px;justify-content:center;align-items:center;width:32px;height:32px;font-weight:700;display:flex;box-shadow:0 4px 12px #0ea5e94d}.logo-text{background:var(--primary-gradient);-webkit-text-fill-color:transparent;letter-spacing:-.5px;-webkit-background-clip:text;font-size:1.25rem;font-weight:700}.nav-actions{gap:12px;display:flex}.mobile-menu-btn{color:var(--text-main);cursor:pointer;background:0 0;border:none;padding:4px;display:none}body.light .mobile-menu-btn{color:#0f172a}@media (width<=768px){.mobile-menu-btn{justify-content:center;align-items:center;display:flex}.nav-actions{border-bottom:1px solid var(--border-color);background:#0f0f13f2;flex-direction:column;width:100%;padding:16px;display:none;position:absolute;top:100%;left:0;box-shadow:0 4px 12px #0003}body.light .nav-actions{background:#fffffffa}.nav-actions.open{display:flex}}.btn{cursor:pointer;border:none;border-radius:8px;outline:none;align-items:center;gap:8px;padding:8px 16px;font-family:inherit;font-size:.9rem;font-weight:500;transition:all .2s;display:flex}.btn-primary{background:var(--primary-gradient);color:#fff;box-shadow:0 4px 12px #0ea5e94d}.btn-primary:hover{filter:brightness(1.1);transform:translateY(-1px)}.btn-secondary{color:var(--text-main);border:1px solid var(--border-color);background:#ffffff0d}.btn-secondary:hover{background:#ffffff1a}.btn-danger{color:#ef4444;background:#ef44441a;border:1px solid #ef444433}.btn-danger:hover{background:#ef444433}.main-layout{grid-template-columns:1fr;gap:32px;max-width:80vw;margin:0 auto;padding:32px 24px;display:grid}@media (width>=1100px){.main-layout{grid-template-columns:320px 1fr}}.disclaimer-banner{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#f59e0b1a;border:1px solid #f59e0b33;border-radius:12px;grid-column:1/-1;align-items:flex-start;gap:14px;padding:14px 20px;display:flex}.disclaimer-icon{color:#f59e0b;flex-shrink:0;margin-top:2px}.disclaimer-text{color:#fbbf24;font-size:.85rem;line-height:1.5}.disclaimer-heading{color:#ef4444;text-transform:uppercase;letter-spacing:.5px}body.light .disclaimer-banner{background:#f59e0b14;border-color:#f59e0b4d}body.light .disclaimer-text{color:#92400e}.column-left,.column-right{flex-direction:column;gap:24px;min-width:0;display:flex}.glass-panel{background:var(--bg-panel);border:1px solid var(--border-color);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:16px;padding:24px;position:relative;overflow:hidden;box-shadow:0 8px 32px #0003}.glass-panel h2{align-items:center;gap:8px;margin-bottom:20px;font-size:1.05rem;font-weight:600;display:flex}.panel-glow{opacity:0;pointer-events:none;background:linear-gradient(135deg,#0ea5e90a,#3b82f60a);transition:opacity .3s;position:absolute;inset:0}.glass-panel:hover .panel-glow{opacity:1}.upload-hint{color:var(--text-muted);margin-bottom:16px;font-size:.8rem;line-height:1.4}.upload-hint a{color:#38bdf8;font-weight:500;text-decoration:none}.upload-hint a:hover{text-decoration:underline}.icon-sky{color:#0ea5e9}.icon-blue{color:#3b82f6}.icon-green{color:#10b981}.icon-amber{color:#f59e0b}.drop-zone{cursor:pointer;border:2px dashed #ffffff1f;border-radius:12px;flex-direction:column;justify-content:center;align-items:center;gap:16px;padding:28px;transition:all .3s;display:flex}.drop-zone:hover{background:#ffffff05;border-color:#0ea5e980}.drop-zone.dragging{background:#0ea5e90d;border-color:#0ea5e9;transform:scale(1.01)}.drop-icon{color:var(--text-muted);background:#0000004d;border-radius:50%;padding:12px}.drop-text{text-align:center}.drop-title{font-size:.9rem;font-weight:500}.drop-subtitle{color:var(--text-muted);margin-top:4px;font-size:.8rem}.hidden-input{display:none}.gpa-glow{filter:blur(50px);pointer-events:none;background:#0ea5e933;border-radius:50%;width:150px;height:150px;position:absolute;top:-50px;right:-50px}.gpa-title{color:var(--text-muted);margin-bottom:8px!important}.gpa-value{background:var(--primary-gradient);-webkit-text-fill-color:transparent;-webkit-background-clip:text;font-size:3.5rem;font-weight:700;line-height:1}.gpa-subtitle{color:var(--text-muted);margin-top:16px;font-size:.875rem}.gpa-breakdown{border-top:1px solid var(--border-color);text-align:center;margin-top:20px;padding-top:16px}.gpa-breakdown-row{letter-spacing:.02em;grid-template-columns:1fr 1fr 1fr;gap:8px;font-size:.72rem;display:grid}.gpa-breakdown-header{color:var(--text-muted);text-transform:uppercase;margin-bottom:8px;font-weight:500}.gpa-breakdown-values{color:var(--text-main);font-variant-numeric:tabular-nums;font-size:.95rem;font-weight:600}.section-hint{color:var(--text-muted);margin-bottom:16px;font-size:.8rem}.calculator-list{flex-direction:column;gap:8px;display:flex}.calc-course-row{border:1px solid var(--border-color);background:#ffffff08;border-radius:8px;align-items:center;gap:10px;padding:8px 12px;display:flex}.calc-course-id{flex:1;font-size:.875rem;font-weight:600}.calc-units-input,.calc-grade-select{border:1px solid var(--border-color);color:#fff;background:#0000004d;border-radius:6px;outline:none;padding:5px 8px;font-family:inherit;font-size:.85rem;transition:border-color .2s}.calc-units-input:focus,.calc-grade-select:focus{border-color:#0ea5e9}.calc-units-input{width:64px}.calc-units-input.variable-units{color:#3b82f6;border-color:#3b82f680;font-style:italic}.planner-form{flex-direction:column;gap:12px;display:flex}.planner-term-row{gap:10px;display:flex}.planner-term-row .input-field{flex:1}.input-field{border:1px solid var(--border-color);color:var(--text-main);background:#0003;border-radius:8px;outline:none;width:100%;padding:10px 14px;font-family:inherit;font-size:.9rem;transition:border-color .2s}.input-field:focus{border-color:#0ea5e9}.honors-section-header{justify-content:space-between;align-items:flex-start;gap:12px;margin-bottom:4px;display:flex}.honors-section-header h2{flex:1;margin-bottom:0!important}.honors-enable-toggle{cursor:pointer;flex-shrink:0;width:44px;height:24px;display:inline-flex;position:relative}.honors-enable-toggle input{opacity:0;width:0;height:0;position:absolute}.honors-enable-slider{background:#ffffff1f;border-radius:999px;transition:background .2s;position:absolute;inset:0}.honors-enable-slider:before{content:"";background:#94a3b8;border-radius:50%;width:18px;height:18px;transition:transform .2s,background .2s;position:absolute;top:3px;left:3px}.honors-enable-toggle input:checked+.honors-enable-slider{background:#f59e0b59}.honors-enable-toggle input:checked+.honors-enable-slider:before{background:#fbbf24;transform:translate(20px)}body.light .honors-enable-slider{background:#0000001f}.honors-disabled-hint{color:var(--text-muted);font-size:.85rem;line-height:1.45}.honors-credits-row{margin-bottom:16px}.honors-field-label{text-transform:uppercase;letter-spacing:.04em;color:var(--text-muted);margin-bottom:6px;font-size:.78rem;font-weight:600;display:block}.honors-credits-input{max-width:120px}.honors-progress-wrap{margin-bottom:18px}.honors-progress-labels{color:var(--text-muted);justify-content:space-between;margin-bottom:6px;font-size:.8rem;display:flex}.honors-progress-bar{background:#ffffff14;border-radius:999px;height:8px;overflow:hidden}body.light .honors-progress-bar{background:#00000014}.honors-progress-fill{background:linear-gradient(90deg,#f59e0b,#fbbf24);border-radius:999px;height:100%;transition:width .3s}.honors-subheading{color:var(--text-main);margin-bottom:10px;font-size:.82rem;font-weight:600}.honors-flagged-list{margin-bottom:18px}.honors-empty-hint{color:var(--text-muted);font-size:.8rem;line-height:1.4}.honors-flagged-item{background:#f59e0b14;border:1px solid #f59e0b38;border-radius:8px;margin-bottom:8px;padding:10px 12px}body.light .honors-flagged-item{background:#f59e0b1a;border-color:#d977064d}.honors-flagged-top{justify-content:space-between;align-items:center;margin-bottom:4px;display:flex}.honors-flagged-id{font-size:.85rem;font-weight:700}.honors-flagged-units{color:#fbbf24;font-size:.75rem;font-weight:600}body.light .honors-flagged-units{color:#d97706}.honors-flagged-meta{color:var(--text-muted);justify-content:space-between;font-size:.75rem;display:flex}.honors-status-tag{text-transform:uppercase;border-radius:4px;padding:2px 6px;font-size:.68rem;font-weight:600}.tag-taken{background:var(--status-taken-bg);color:#6ee7b7}.tag-in-progress{background:var(--status-ip-bg);color:#93c5fd}.tag-planned{background:var(--status-planned-bg);color:#38bdf8}body.light .tag-taken{color:#059669}body.light .tag-in-progress{color:#2563eb}body.light .tag-planned{color:#0284c7}.honors-petition-form{flex-direction:column;gap:10px;margin-bottom:14px;display:flex}.honors-petition-hint{color:var(--text-muted);margin-top:-4px;font-size:.78rem;line-height:1.35}.honors-petition-credits-row{gap:10px;display:flex}.honors-petition-credits-row .input-field{flex:1}.honors-petition-credits-row .btn{flex-shrink:0}.honors-petition-list{flex-direction:column;gap:8px;margin:0 0 16px;padding:0;list-style:none;display:flex}.honors-petition-item{border:1px solid var(--border-color);background:#ffffff08;border-radius:8px;justify-content:space-between;align-items:flex-start;gap:10px;padding:10px 12px;display:flex}.honors-petition-desc{margin-bottom:2px;font-size:.85rem;font-weight:500}.honors-petition-meta{color:var(--text-muted);font-size:.75rem}.honors-remaining{border-top:1px solid var(--border-color);flex-direction:column;gap:4px;margin-top:8px;padding-top:14px;display:flex}.honors-remaining-label{text-transform:uppercase;letter-spacing:.04em;color:var(--text-muted);font-size:.78rem;font-weight:600}.honors-remaining-value{color:#fbbf24;font-size:1.35rem;font-weight:700}body.light .honors-remaining-value{color:#d97706}.fcard-honors{box-shadow:inset 0 0 0 1px #fbbf2473}.fcard-honors-check{text-transform:uppercase;letter-spacing:.04em;color:#fbbf24;cursor:pointer;-webkit-user-select:none;user-select:none;align-items:center;gap:6px;margin-bottom:8px;font-size:.68rem;font-weight:600;display:flex}body.light .fcard-honors-check{color:#d97706}.fcard-honors-check input{accent-color:#f59e0b;cursor:pointer;width:14px;height:14px}.planned-section{overflow:visible}.planned-flowsheet{scrollbar-width:thin;scrollbar-color:#a855f74d transparent;gap:16px;padding-bottom:12px;display:flex;overflow-x:auto}.planned-flowsheet::-webkit-scrollbar{height:6px}.planned-flowsheet::-webkit-scrollbar-track{background:0 0}.planned-flowsheet::-webkit-scrollbar-thumb{background:#0ea5e94d;border-radius:3px}.planned-term-col{background:#0ea5e90a;border:1px solid #0ea5e926;border-radius:12px;flex:0 0 160px;min-height:80px;padding:12px;transition:border-color .2s,background .2s}.planned-term-col.drop-target{background:#0ea5e91a;border-color:#0ea5e9;box-shadow:0 0 0 2px #0ea5e933}.planned-term-header{border-bottom:1px solid #0ea5e933;justify-content:space-between;align-items:center;margin-bottom:10px;padding-bottom:8px;display:flex}.planned-term-label{color:#38bdf8;letter-spacing:.5px;font-size:.78rem;font-weight:700}.planned-term-units{color:var(--text-muted);font-size:.72rem}.planned-cards{flex-direction:column;gap:8px;display:flex}.planned-card{cursor:grab;background:#0ea5e914;border:1px solid #0ea5e933;border-radius:8px;padding:10px;transition:transform .15s,box-shadow .15s,border-color .15s;position:relative}.planned-card:hover{border-color:#0ea5e980;transform:translateY(-2px);box-shadow:0 4px 16px #0ea5e933}.planned-card:active{cursor:grabbing}.planned-card-actions{justify-content:flex-end;gap:4px;margin-bottom:6px;display:flex}.card-action-btn{cursor:pointer;background:#ffffff0d;border:none;border-radius:5px;justify-content:center;align-items:center;width:22px;height:22px;transition:all .15s;display:flex}.move-btn{color:#93c5fd}.move-btn:hover{color:#3b82f6;background:#3b82f633}.delete-btn{color:#fca5a5}.delete-btn:hover{color:#ef4444;background:#ef444433}.planned-card-id{color:#38bdf8;margin-bottom:3px;font-size:.85rem;font-weight:700}.planned-card-title{color:var(--text-muted);margin-bottom:6px;font-size:.75rem;line-height:1.3}.planned-card-units{color:#38bdf8;background:#0ea5e926;border-radius:10px;padding:2px 7px;font-size:.7rem;font-weight:600;display:inline-block}.flowsheet-columns{scrollbar-width:thin;scrollbar-color:#10b9814d transparent;align-items:flex-start;gap:12px;padding-bottom:12px;display:flex;overflow-x:auto}.flowsheet-columns::-webkit-scrollbar{height:6px}.flowsheet-columns::-webkit-scrollbar-track{background:0 0}.flowsheet-columns::-webkit-scrollbar-thumb{background:#10b9814d;border-radius:3px}.flowsheet-col{background:#10b98108;border:1px solid #10b9811f;border-radius:12px;flex-direction:column;flex:0 0 220px;display:flex;overflow:hidden}.flowsheet-col-header{background:#10b98114;border-bottom:1px solid #10b98126;padding:12px 14px}.flowsheet-col-term{color:#6ee7b7;margin-bottom:4px;font-size:.85rem;font-weight:700}.flowsheet-col-units{color:var(--text-muted);font-size:.75rem}.flowsheet-col-cards{flex-direction:column;gap:8px;padding:10px;display:flex}.flowsheet-card{background:#ffffff05;border:1px solid #ffffff0d;border-radius:8px;padding:14px 16px;transition:transform .15s,background .15s}.flowsheet-card:hover{background:#ffffff0d;transform:translateY(-2px)}body.light .flowsheet-card{background:#00000005;border-color:#00000014}body.light .flowsheet-card:hover{background:#0000000d}.fcard-taken{background:var(--status-taken-bg)!important;border:1px solid #10b9814d!important}.fcard-in-progress{background:var(--status-ip-bg)!important;border:1px solid #3b82f64d!important}.fcard-failed{background:var(--status-failed-bg)!important;border:1px solid #ef44444d!important}.fcard-planned{background:var(--status-planned-bg)!important;border:1px dashed var(--status-planned)!important}.fcard-top{justify-content:space-between;align-items:center;margin-bottom:6px;display:flex}.fcard-id{color:var(--text-main);font-size:.85rem;font-weight:700}.fcard-status-dot{border-radius:50%;flex-shrink:0;width:8px;height:8px}.dot-taken{background:#10b981;box-shadow:0 0 4px #10b98199}.dot-in-progress{background:#3b82f6;box-shadow:0 0 4px #3b82f699}.dot-failed{background:#ef4444;box-shadow:0 0 4px #ef444499}.dot-planned{background:#0ea5e9}.fcard-title{color:#9ca3af;-webkit-line-clamp:2;-webkit-box-orient:vertical;margin-bottom:10px;font-size:.78rem;line-height:1.4;display:-webkit-box;overflow:hidden}body.light .fcard-title{color:#475569}.fcard-bottom{justify-content:space-between;align-items:center;display:flex}.fcard-units{color:var(--text-muted);font-size:.75rem}.fcard-grade{color:#6ee7b7;font-size:.8rem;font-weight:700}body.light .fcard-grade,body.light .flowsheet-col-term{color:#059669}body.light .flowsheet-col{background:#10b9810d;border-color:#10b9814d}.flowsheet-section-heading{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:16px;margin-bottom:16px;display:flex}.flowsheet-section-heading h2{margin-bottom:0}.flowsheet-toolbar{flex-wrap:wrap;justify-content:flex-end;align-items:center;gap:10px;display:flex}.flowsheet-grade-toggle.active{background:#10b9811f;border-color:#10b98173}body.light .flowsheet-grade-toggle.active{background:#10b98126;border-color:#05966966}.flowsheet-export-actions{flex-wrap:wrap;gap:8px;display:flex}.flowsheet-export-btn{padding:7px 12px!important;font-size:.82rem!important}.flowsheet-capture-area{background:#121216eb;border:1px solid #ffffff0f;border-radius:12px;padding:12px}body.light .flowsheet-capture-area{background:#fffffff2;border-color:#00000014}.legend{flex-wrap:wrap;gap:16px;margin-bottom:24px;font-size:.8rem;display:flex}.legend-item{align-items:center;gap:8px;display:flex}.indicator{border-radius:50%;width:10px;height:10px}.indicator-taken{background:var(--status-taken-bg);border:1px solid var(--status-taken)}.indicator-ip{background:var(--status-ip-bg);border:1px solid var(--status-ip)}.indicator-planned{background:var(--status-planned-bg);border:1px dashed var(--status-planned)}.indicator-failed{background:var(--status-failed-bg);border:1px solid var(--status-failed)}.flowsheet-empty{min-height:200px}.empty-state{color:var(--text-muted);text-align:center;flex-direction:column;justify-content:center;align-items:center;padding:32px 0;display:flex}.empty-icon{opacity:.2;margin-bottom:16px}.modal-overlay{z-index:200;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#0009;justify-content:center;align-items:center;animation:.15s fadeIn;display:flex;position:fixed;inset:0}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal{background:#14141cf2;border:1px solid #0ea5e94d;border-radius:16px;width:360px;padding:28px;animation:.2s slideUp;box-shadow:0 24px 64px #00000080,0 0 0 1px #0ea5e91a}body.light .modal{background:#fffffffa;box-shadow:0 24px 64px #00000026,0 0 0 1px #0ea5e926}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.modal-header{justify-content:space-between;align-items:center;margin-bottom:8px;display:flex}.modal-header h3{font-size:1.1rem;font-weight:600}.modal-course-id{color:#38bdf8}.modal-close{color:var(--text-muted);cursor:pointer;background:0 0;border:none;border-radius:6px;align-items:center;padding:4px;transition:color .15s,background .15s;display:flex}.modal-close:hover{color:#fff;background:#ffffff14}body.light .modal-close:hover{color:#0f172a;background:#00000014}.modal-subtitle{color:var(--text-muted);margin-bottom:20px;font-size:.85rem}.modal-selects{gap:10px;margin-bottom:20px;display:flex}.modal-selects .input-field{flex:1}.modal-actions{justify-content:flex-end;gap:10px;display:flex}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:var(--bg-dark)}::-webkit-scrollbar-thumb{background:#ffffff14;border-radius:3px}::-webkit-scrollbar-thumb:hover{background:#ffffff26}.app-footer{text-align:center;color:var(--text-muted);border-top:1px solid var(--border-color);background:#0f0f1366;margin-top:auto;padding:32px 24px;font-size:.9rem}body.light .app-footer{background:#fff6}.app-footer a{color:#38bdf8;font-weight:500;text-decoration:none;transition:color .2s}.app-footer a:hover{color:#0ea5e9;text-decoration:underline}
