@import "https://fonts.googleapis.com/css2?family=Outfit:wght@300;400;500;600;700;800&display=swap";:root{--bg-base:#0a0915;--bg-surface:#121024a6;--bg-card:#19163373;--border-light:#ffffff14;--border-active:#7c4dff4d;--primary:#8b5cf6;--primary-glow:#8b5cf666;--secondary:#10b981;--secondary-glow:#10b98166;--text-primary:#f3f4f6;--text-secondary:#9ca3af;--text-muted:#6b7280;--accent-blue:#3b82f6;--accent-amber:#f59e0b;--accent-red:#ef4444;--glass-blur:blur(16px);--shadow-premium:0 8px 32px 0 #0000005e;--transition-smooth:all .3s cubic-bezier(.4, 0, .2, 1)}*{box-sizing:border-box;margin:0;padding:0}input[type=number]{text-align:center;transition:border-color .2s,background-color .2s;padding-right:18px!important}input::-webkit-outer-spin-button{opacity:0;cursor:pointer;transition:opacity .2s ease-in-out}input::-webkit-inner-spin-button{opacity:0;cursor:pointer;transition:opacity .2s ease-in-out}input:hover::-webkit-outer-spin-button{opacity:.7}input:hover::-webkit-inner-spin-button{opacity:.7}input:focus::-webkit-outer-spin-button{opacity:.7}input:focus::-webkit-inner-spin-button{opacity:.7}html,body{width:100%!important;max-width:100%!important;overflow-x:hidden!important}body{background-color:var(--bg-base);color:var(--text-primary);background-image:radial-gradient(at 10% 20%,#3b82f614 0,#0000 50%),radial-gradient(at 90% 80%,#8b5cf614 0,#0000 50%);min-height:100vh;font-family:Outfit,sans-serif;line-height:1.5}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:var(--bg-base)}::-webkit-scrollbar-thumb{background:#ffffff1a;border-radius:4px}::-webkit-scrollbar-thumb:hover{background:var(--primary)}.app-container{max-width:1400px;margin:0 auto;padding:2.5rem 1.5rem}.glass-panel{background:var(--bg-surface);-webkit-backdrop-filter:var(--glass-blur);border:1px solid var(--border-light);box-shadow:var(--shadow-premium);transition:var(--transition-smooth);border-radius:20px}.glass-panel:hover{border-color:var(--border-active);box-shadow:0 12px 40px #7c4dff26}.app-header{justify-content:space-between;align-items:center;margin-bottom:2.5rem;padding:1.25rem 2rem;display:flex}.logo-container{align-items:center;gap:.75rem;display:flex}.logo-icon{background:linear-gradient(135deg, var(--primary), var(--accent-blue));color:#fff;width:40px;height:40px;box-shadow:0 0 15px var(--primary-glow);border-radius:12px;justify-content:center;align-items:center;font-size:1.5rem;font-weight:800;display:flex}.logo-text h1{background:linear-gradient(to right, #fff, var(--text-secondary));-webkit-text-fill-color:transparent;letter-spacing:-.5px;-webkit-background-clip:text;font-size:1.6rem;font-weight:700}.logo-text p{color:var(--text-secondary);font-size:.8rem}.deployment-status{color:var(--secondary);background:#10b9811a;border:1px solid #10b98133;border-radius:99px;align-items:center;gap:.5rem;padding:.5rem 1rem;font-size:.85rem;font-weight:500;display:flex}.status-dot{background-color:var(--secondary);width:8px;height:8px;box-shadow:0 0 8px var(--secondary);border-radius:50%;animation:2s infinite pulse}.stats-grid{grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:1.5rem;margin-bottom:2.5rem;display:grid}.main-grid{grid-template-columns:1.8fr 1.2fr;align-items:start;gap:2rem;display:grid}@media (width<=1024px){.main-grid{grid-template-columns:1fr}}.stat-card{justify-content:space-between;align-items:center;padding:1.5rem;display:flex;position:relative;overflow:hidden}.stat-card:after{content:"";z-index:0;background:radial-gradient(circle,#8b5cf60d 0%,#0000 70%);width:100px;height:100px;position:absolute;top:0;right:0}.stat-info{z-index:1}.stat-label{color:var(--text-secondary);margin-bottom:.25rem;font-size:.9rem;font-weight:500}.stat-value{letter-spacing:-.5px;font-size:2rem;font-weight:700}.stat-sub{color:var(--text-muted);margin-top:.25rem;font-size:.8rem}.stat-icon-wrapper{z-index:1;border-radius:12px;justify-content:center;align-items:center;width:50px;height:50px;font-size:1.5rem;display:flex}.theme-primary .stat-value{color:#fff}.theme-primary .stat-icon-wrapper{color:var(--primary);background:#8b5cf626}.theme-secondary .stat-value{color:var(--secondary)}.theme-secondary .stat-icon-wrapper{color:var(--secondary);background:#10b98126}.theme-blue .stat-value{color:var(--accent-blue)}.theme-blue .stat-icon-wrapper{color:var(--accent-blue);background:#3b82f626}.theme-amber .stat-value{color:var(--accent-amber)}.theme-amber .stat-icon-wrapper{color:var(--accent-amber);background:#f59e0b26}.panel-title-bar{border-bottom:1px solid var(--border-light);justify-content:space-between;align-items:center;padding:1.5rem 2rem;display:flex}.panel-title{align-items:center;gap:.5rem;font-size:1.25rem;font-weight:600;display:flex}.badge{border-radius:99px;padding:.25rem .6rem;font-size:.75rem;font-weight:600}.badge-info{color:var(--accent-blue);background:#3b82f61a;border:1px solid #3b82f633}.badge-count{color:var(--primary);background:#8b5cf61a;border:1px solid #8b5cf633}.table-responsive{width:100%;overflow-x:auto}.course-list{flex-direction:column;gap:.75rem;padding:1rem;display:flex}.course-card{background:var(--bg-card);border:1px solid var(--border-light);transition:var(--transition-smooth);border-radius:14px;grid-template-columns:1fr 15px 220px 100px 110px;align-items:center;gap:1rem;padding:1rem 1.25rem;display:grid}.course-card.excluded{opacity:.5;background:#0a091533;border-color:#ffffff08}.course-card:hover{border-color:#7c4dff40;transform:translateY(-2px)}.course-status-col{align-items:center;display:flex}.course-info-col{flex-direction:column;min-width:200px;display:flex}.course-code-tag{color:var(--primary);margin-bottom:.15rem;font-family:monospace;font-size:.75rem;font-weight:600}.course-name-cn{white-space:nowrap;font-size:.95rem;font-weight:500}.course-name-en{color:var(--text-secondary);white-space:normal;word-break:break-word;font-size:.75rem}.course-meta-tags{flex-wrap:wrap;gap:.4rem;margin-top:.25rem;display:flex}.meta-tag{border-radius:4px;padding:.1rem .4rem;font-size:.7rem;font-weight:500}.tag-compulsory{color:var(--accent-red);background:#ef44441a}.tag-general{color:var(--accent-amber);background:#f59e0b1a}.tag-credits{color:var(--text-secondary);background:#ffffff0f}.tag-remark{color:var(--accent-blue);background:#3b82f61a}.course-grade-control{align-items:center;gap:.75rem;display:flex}.grade-slider{appearance:none;cursor:pointer;height:6px;transition:var(--transition-smooth);background:#ffffff1a;border-radius:99px;outline:none;flex-grow:1}.grade-slider::-webkit-slider-thumb{appearance:none;background:var(--primary);width:14px;height:14px;box-shadow:0 0 8px var(--primary-glow);transition:var(--transition-smooth);border-radius:50%}.grade-slider::-webkit-slider-thumb:hover{transform:scale(1.3)}.grade-input-box{border:1px solid var(--border-light);width:70px;color:var(--text-primary);text-align:center;transition:var(--transition-smooth);background:#ffffff0d;border-radius:8px;outline:none;padding:.3rem 0;font-family:inherit;font-size:.95rem;font-weight:600}.grade-input-box:focus{border-color:var(--primary);background:#8b5cf60d}.grade-color-indicator{border-radius:2px;width:4px;height:24px}.color-excellent{background-color:var(--secondary);box-shadow:0 0 8px var(--secondary-glow)}.color-good{background-color:var(--accent-blue)}.color-passing{background-color:var(--accent-amber)}.color-failed{background-color:var(--accent-red)}.switch{width:38px;height:20px;display:inline-block;position:relative}.switch input{opacity:0;width:0;height:0}.slider-switch{cursor:pointer;background-color:#ffffff1a;border-radius:34px;transition:all .4s;position:absolute;inset:0}.slider-switch:before{content:"";background-color:#fff;border-radius:50%;width:14px;height:14px;transition:all .4s;position:absolute;bottom:3px;left:3px}input:checked+.slider-switch{background-color:var(--primary)}input:checked+.slider-switch:before{transform:translate(18px)}.delete-btn{color:var(--text-muted);cursor:pointer;transition:var(--transition-smooth);background:0 0;border:none;border-radius:8px;justify-content:center;align-items:center;padding:.4rem;font-size:1.1rem;display:flex}.delete-btn:hover{color:var(--accent-red);background:#ef44441a}.add-course-trigger{justify-content:center;padding:1.5rem;display:flex}.btn-add{color:var(--primary);cursor:pointer;transition:var(--transition-smooth);background:#8b5cf61a;border:1px dashed #8b5cf64d;border-radius:12px;justify-content:center;align-items:center;gap:.5rem;width:100%;padding:.75rem 2rem;font-weight:600;display:flex}.btn-add:hover{background:#8b5cf633;border-style:solid}.modal-overlay{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:100;background:#0009;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.modal-content{width:90%;max-width:480px;padding:2rem}.modal-header{margin-bottom:1.5rem}.modal-header h3{font-size:1.4rem;font-weight:700}.form-group{margin-bottom:1.25rem}.form-group label{color:var(--text-secondary);margin-bottom:.5rem;font-size:.85rem;font-weight:500;display:block}.form-input{border:1px solid var(--border-light);width:100%;color:var(--text-primary);transition:var(--transition-smooth);background:#ffffff0d;border-radius:10px;outline:none;padding:.75rem 1rem;font-family:inherit}.form-input:focus{border-color:var(--primary);background:#8b5cf60d}.form-row{grid-template-columns:1fr 1fr;gap:1rem;display:grid}.modal-actions{justify-content:flex-end;gap:1rem;margin-top:2rem;display:flex}.btn-cancel{border:1px solid var(--border-light);color:var(--text-secondary);cursor:pointer;transition:var(--transition-smooth);background:0 0;border-radius:8px;padding:.6rem 1.5rem}.btn-cancel:hover{color:#fff;background:#ffffff0d}.btn-submit{background:var(--primary);color:#fff;cursor:pointer;box-shadow:0 4px 14px var(--primary-glow);transition:var(--transition-smooth);border:none;border-radius:8px;padding:.6rem 1.5rem;font-weight:600}.btn-submit:hover{box-shadow:0 6px 20px var(--primary-glow);transform:translateY(-1px)}.sensitivity-card{background:var(--bg-card);border:1px solid var(--border-light);transition:var(--transition-smooth);border-radius:12px;justify-content:space-between;align-items:center;margin-bottom:.75rem;padding:1rem 1.25rem;display:flex}.sensitivity-card:hover{border-color:var(--border-active)}.sensitivity-info{flex-direction:column;display:flex}.sensitivity-course-name{font-size:.9rem;font-weight:600}.sensitivity-math{color:var(--text-secondary);margin-top:.15rem;font-size:.75rem}.sensitivity-impact-badge{text-align:right;border-radius:8px;padding:.3rem .65rem;font-size:.8rem;font-weight:700}.impact-high{color:var(--secondary);background:#10b98126;border:1px solid #10b98133}.impact-med{color:var(--accent-blue);background:#3b82f626;border:1px solid #3b82f633}.impact-low{color:var(--text-secondary);border:1px solid var(--border-light);background:#ffffff0f}.gauge-container{flex-direction:column;justify-content:center;align-items:center;padding:2rem;display:flex;position:relative}.circular-gauge-wrapper{width:200px;height:200px;position:relative}.progress-ring{transform:rotate(-90deg)}.progress-ring__circle{transform-origin:50%;stroke-dasharray:565.48;stroke-dashoffset:565.48px;transition:stroke-dashoffset .35s}.gauge-center-text{text-align:center;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.gauge-value{font-size:2.75rem;font-weight:800;line-height:1}.gauge-label{color:var(--text-secondary);letter-spacing:.5px;margin-top:.25rem;font-size:.8rem;font-weight:500}.save-action-bar{border-bottom:1px solid var(--border-light);justify-content:center;padding:1.5rem;display:flex}.btn-save-db{background:linear-gradient(135deg, var(--primary), var(--accent-blue));color:#fff;cursor:pointer;width:100%;box-shadow:0 4px 15px var(--primary-glow);transition:var(--transition-smooth);border:none;border-radius:14px;justify-content:center;align-items:center;gap:.6rem;padding:.85rem;font-size:1rem;font-weight:600;display:flex}.btn-save-db:hover{box-shadow:0 6px 22px var(--primary-glow);transform:translateY(-2px)}.btn-save-db:disabled{opacity:.6;cursor:not-allowed;transform:none}.history-list{flex-direction:column;gap:.75rem;max-height:380px;padding:1rem;display:flex;overflow-y:auto}.history-item{border:1px solid var(--border-light);transition:var(--transition-smooth);background:#ffffff05;border-radius:12px;justify-content:space-between;align-items:center;padding:.9rem 1.1rem;display:flex}.history-item:hover{border-color:var(--border-active);background:#ffffff0a}.history-details{flex-direction:column;display:flex}.history-date{color:var(--text-secondary);font-size:.75rem}.history-summary{margin-top:.15rem;font-size:.9rem;font-weight:600}.history-actions{gap:.5rem;display:flex}.btn-history-restore{color:var(--accent-blue);cursor:pointer;transition:var(--transition-smooth);background:#3b82f626;border:1px solid #3b82f633;border-radius:6px;padding:.35rem .75rem;font-size:.75rem;font-weight:600}.btn-history-restore:hover{background:#3b82f64d}.btn-history-delete{color:var(--text-muted);cursor:pointer;transition:var(--transition-smooth);background:0 0;border:none;border-radius:6px;justify-content:center;align-items:center;padding:.35rem;font-size:.9rem;display:flex}.btn-history-delete:hover{color:var(--accent-red);background:#ef44441a}.empty-state{text-align:center;color:var(--text-muted);padding:2.5rem;font-size:.9rem}@keyframes pulse{0%{transform:scale(.95);box-shadow:0 0 #10b981b3}70%{transform:scale(1);box-shadow:0 0 0 6px #10b98100}to{transform:scale(.95);box-shadow:0 0 #10b98100}}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.fade-in-up{animation:.4s ease-out forwards fadeIn}@media (width<=768px){.app-header{flex-direction:column;align-items:flex-start;gap:1rem}.course-card{grid-template-rows:auto auto;grid-template-columns:auto 1fr auto;gap:.5rem 1rem}.course-status-col{grid-area:1/1}.course-info-col{grid-area:1/2}.delete-btn{grid-area:1/3}.course-grade-control{grid-area:2/1/auto/span 3;width:100%;margin-top:.5rem}}.components-panel{border-top:1px solid var(--border-light);flex-direction:column;grid-column:1/-1;gap:.85rem;margin-top:.75rem;padding-top:1.25rem;animation:.3s cubic-bezier(.4,0,.2,1) forwards fadeIn;display:flex}.components-header{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:.5rem;margin-bottom:.25rem;display:flex}.components-title{color:var(--primary);align-items:center;gap:.4rem;font-size:.85rem;font-weight:600;display:flex}.components-list{flex-direction:column;gap:.6rem;display:flex}.component-item{grid-template-columns:2fr 110px 3.5fr 35px;align-items:center;gap:.75rem;display:grid}@media (width<=768px){.component-item{grid-template-columns:1.5fr 80px 2fr 30px;gap:.5rem}}.comp-input{border:1px solid var(--border-light);color:var(--text-primary);transition:var(--transition-smooth);background:#ffffff0a;border-radius:6px;outline:none;padding:.4rem .6rem;font-family:inherit;font-size:.85rem}.comp-input:focus{border-color:var(--primary);background:#8b5cf608}.btn-add-comp{color:var(--secondary);cursor:pointer;transition:var(--transition-smooth);background:#10b9811a;border:1px dashed #10b9814d;border-radius:6px;padding:.35rem .85rem;font-size:.75rem;font-weight:600}.btn-add-comp:hover{background:#10b9812e;border-style:solid}.btn-calc-toggle{border:1px solid var(--border-light);color:var(--text-secondary);cursor:pointer;transition:var(--transition-smooth);background:#ffffff0d;border-radius:8px;align-items:center;gap:.3rem;padding:.35rem .75rem;font-size:.75rem;font-weight:500;display:flex}.btn-calc-toggle:hover{color:var(--primary);background:#8b5cf61a;border-color:#8b5cf640}.btn-calc-toggle.active{color:var(--primary);background:#8b5cf626;border-color:#8b5cf64d}.warning-badge{border-radius:4px;padding:.2rem .5rem;font-size:.7rem;font-weight:600}.warning-badge.error{color:var(--accent-red);background:#ef44441a;border:1px solid #ef444426}.warning-badge.success{color:var(--secondary);background:#10b9811a;border:1px solid #10b98126}.subscores-panel{border:1px solid #ffffff0a;border-left:3px solid var(--primary);background:#0000002e;border-radius:10px;flex-direction:column;grid-column:1/-1;gap:.65rem;margin-top:.4rem;margin-bottom:.4rem;margin-left:1.5rem;padding:.85rem 1.25rem;animation:.25s ease-out forwards fadeIn;display:flex}.subscores-header{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:.5rem;margin-bottom:.15rem;display:flex}.subscore-item{grid-template-columns:2.5fr 3.5fr 35px;align-items:center;gap:.75rem;display:grid}@media (width<=768px){.subscore-item{grid-template-columns:2fr 3fr 30px;gap:.5rem}}.btn-subscore-toggle{color:var(--text-secondary);cursor:pointer;transition:var(--transition-smooth);background:0 0;border:none;border-radius:4px;align-items:center;gap:.2rem;width:fit-content;margin-top:.2rem;padding:.15rem .4rem;font-size:.7rem;display:flex}.btn-subscore-toggle:hover{color:var(--primary);background:#8b5cf614}.btn-add-subscore{color:var(--accent-blue);cursor:pointer;transition:var(--transition-smooth);background:#3b82f61a;border:1px dashed #3b82f64d;border-radius:5px;padding:.25rem .65rem;font-size:.7rem;font-weight:600}.btn-add-subscore:hover{background:#3b82f62e;border-style:solid}.subscore-item.dropped{opacity:.65;border-left:2px dashed var(--accent-red);padding-left:.5rem}.subscore-item.dropped input,.subscore-item.dropped span{-webkit-text-decoration:line-through var(--accent-red);text-decoration:line-through var(--accent-red);color:var(--text-secondary)}.dropped-badge{color:var(--accent-red);background:#ef44441f;border:1px solid #ef444433;border-radius:4px;margin-left:.5rem;padding:.15rem .4rem;font-size:.65rem;font-weight:600;display:inline-block;text-decoration:none!important}.status-btn{border:1px solid var(--border-light);cursor:pointer;transition:var(--transition-smooth);background:0 0;border-radius:6px;align-items:center;gap:.25rem;width:fit-content;padding:.25rem .5rem;font-size:.7rem;font-weight:600;display:flex}.status-btn.confirmed{color:var(--secondary);background:#10b98114;border-color:#10b98140}.status-btn.confirmed:hover{background:#10b98126}.status-btn.estimated{color:var(--accent-amber);background:#f59e0b0a;border:1px dashed #f59e0b40}.status-btn.estimated:hover{background:#f59e0b1f}.course-confirm-bar{background:#ffffff0d;border-radius:2px;width:80px;height:4px;margin-top:.25rem;overflow:hidden}.course-confirm-progress{background-color:var(--secondary);height:100%;box-shadow:0 0 4px var(--secondary-glow);transition:var(--transition-smooth)}.semester-select-container{border:1px solid var(--border-light);transition:var(--transition-smooth);background:#ffffff08;border-radius:12px;align-items:center;padding:.4rem .8rem;display:flex;box-shadow:inset 0 1px 1px #ffffff0d}.semester-select-container:hover{border-color:var(--border-active);background:#ffffff0f}.semester-select-dropdown{color:var(--text-primary);cursor:pointer;background:0 0;border:none;outline:none;padding-right:.5rem;font-family:inherit;font-size:.9rem;font-weight:600}.semester-select-dropdown option{color:var(--text-primary);background:#0f0e24}.btn-add-semester-pill{color:var(--primary);cursor:pointer;transition:var(--transition-smooth);background:linear-gradient(135deg,#8b5cf626 0%,#3b82f626 100%);border:1px solid #8b5cf64d;border-radius:99px;padding:.35rem .8rem;font-size:.75rem;font-weight:600}.btn-add-semester-pill:hover{border-color:var(--primary);background:linear-gradient(135deg,#8b5cf640 0%,#3b82f640 100%);transform:translateY(-1px);box-shadow:0 0 10px #8b5cf64d}.cumulative-metrics-row{border:1px solid var(--border-light);background:#ffffff05;border-radius:12px;grid-template-columns:repeat(3,1fr);gap:.75rem;margin-top:1rem;margin-bottom:1.25rem;padding:.75rem;display:grid}.cum-metric{text-align:center;flex-direction:column;justify-content:center;align-items:center;display:flex}.cum-metric-label{color:var(--text-muted);margin-bottom:.2rem;font-size:.7rem;font-weight:500}.cum-metric-val{letter-spacing:-.2px;font-size:.95rem;font-weight:700}.historical-semester-card{background:var(--bg-card);border:1px solid var(--border-light);transition:var(--transition-smooth);border-radius:14px;padding:.85rem;position:relative;overflow:hidden}.historical-semester-card:hover{background:#191633a6;border-color:#ffffff26;transform:translate(2px)}.historical-semester-card.active-sem{border-color:var(--border-active);background:#7c4dff14;box-shadow:0 4px 15px #7c4dff1a}.historical-semester-card.active-sem:after{content:"";background:linear-gradient(to bottom, var(--primary), var(--accent-blue));width:4px;height:100%;position:absolute;top:0;left:0}.badge{border-radius:4px;padding:.15rem .4rem;font-size:.65rem;font-weight:600;line-height:1}.badge-active-type{color:var(--accent-blue);background:#3b82f61a;border:1px solid #3b82f640}.badge-summary-type{color:var(--accent-amber);background:#f59e0b1a;border:1px solid #f59e0b40}.badge-editing{color:var(--secondary);background:#10b9811a;border:1px solid #10b98140}.btn-sem-action{border:1px solid var(--border-light);color:var(--text-primary);cursor:pointer;width:26px;height:26px;transition:var(--transition-smooth);background:#ffffff0d;border-radius:6px;justify-content:center;align-items:center;font-size:.8rem;font-weight:700;display:inline-flex}.btn-sem-action:hover{background:#ffffff26;border-color:#ffffff4d}.btn-sem-switch{width:auto;color:var(--primary);background:#7c4dff1a;border-color:#7c4dff33;padding:0 .5rem;font-size:.7rem;font-weight:600}.btn-sem-switch:hover{background:var(--primary);color:#fff;border-color:var(--primary);box-shadow:0 0 8px var(--primary-glow)}.btn-sem-edit{color:var(--accent-amber);background:#f59e0b14;border-color:#f59e0b26}.btn-sem-edit:hover{background:var(--accent-amber);color:#0f0e24;border-color:var(--accent-amber)}.btn-sem-delete{color:var(--accent-red);background:#ef444414;border-color:#ef444426}.btn-sem-delete:hover{background:var(--accent-red);color:#fff;border-color:var(--accent-red)}@media (width<=768px){.app-header{flex-direction:column;align-items:flex-start;gap:1.25rem}.app-header>div{flex-direction:column;justify-content:space-between;width:100%;align-items:flex-start!important;gap:1rem!important}.semester-select-container{width:100%}.semester-select-dropdown{flex-grow:1}}.status-select{border:1px solid var(--border-light);color:var(--text-primary);cursor:pointer;transition:var(--transition-smooth);background:#ffffff0a;border-radius:6px;outline:none;width:fit-content;padding:.15rem .4rem;font-family:inherit;font-size:.7rem;font-weight:600}.status-select:hover{background:#ffffff14;border-color:#fff3}.status-select option{color:var(--text-primary);background:#0f0e24}.status-select.estimated{color:var(--accent-amber);background:#f59e0b0f;border-color:#f59e0b40}.status-select.confirmed{color:var(--secondary);background:#10b9810f;border-color:#10b98140}.status-select.withdrawn{color:var(--accent-red);background:#ef44440f;border-color:#ef444440}.status-select.waiver{color:var(--accent-blue);background:#3b82f60f;border-color:#3b82f640}.pass-fail-select{border:1px solid var(--border-light);color:var(--text-primary);cursor:pointer;transition:var(--transition-smooth);text-align-last:center;background:#ffffff0a;border-radius:8px;outline:none;width:100%;max-width:140px;padding:.35rem .65rem;font-family:inherit;font-size:.8rem;font-weight:600}.pass-fail-select:hover:not(:disabled){background:#ffffff14;border-color:#fff3}.pass-fail-select:disabled{opacity:.5;cursor:not-allowed}.pass-fail-select option{color:var(--text-primary);background:#0f0e24}.pass-fail-select.pass{color:var(--secondary);background:#10b98114;border-color:#10b9814d}.pass-fail-select.fail{color:var(--accent-red);background:#ef444414;border-color:#ef44444d}.status-placeholder-badge{border:1px solid var(--border-light);text-align:center;width:100%;max-width:160px;-webkit-backdrop-filter:var(--glass-blur);backdrop-filter:var(--glass-blur);border-radius:8px;justify-content:center;align-items:center;padding:.4rem .9rem;font-size:.8rem;font-weight:600;display:inline-flex;box-shadow:inset 0 1px 1px #ffffff08}.status-placeholder-badge.withdrawn{color:var(--accent-red);background:#ef44440d;border-color:#ef444433}.status-placeholder-badge.waiver{color:var(--accent-blue);background:#3b82f60d;border-color:#3b82f633}.color-neutral{background-color:var(--text-muted);opacity:.45;box-shadow:none}.lock-screen-overlay{background-color:var(--bg-base);z-index:9999;-webkit-backdrop-filter:blur(25px);background-image:radial-gradient(at 10% 20%,#7c4dff14 0,#0000 50%),radial-gradient(at 90% 80%,#3b82f614 0,#0000 50%);justify-content:center;align-items:center;padding:1.5rem;display:flex;position:fixed;inset:0}.lock-box{text-align:center;background:var(--bg-surface);border:1px solid #ffffff14;border-radius:24px;width:100%;max-width:420px;padding:2.5rem;box-shadow:0 20px 50px #00000080}.lock-header{margin-bottom:2rem}.lock-icon-shield{filter:drop-shadow(0 0 10px #7c4dff4d);margin-bottom:.75rem;font-size:3rem;animation:2s ease-in-out infinite pulseShield;display:inline-block}.lock-header h2{background:linear-gradient(to right, #fff, var(--text-secondary));-webkit-text-fill-color:transparent;-webkit-background-clip:text;margin-bottom:.4rem;font-size:1.6rem;font-weight:700}.lock-header p{color:var(--text-secondary);font-size:.85rem}.lock-form{flex-direction:column;display:flex}@keyframes shake{0%,to{transform:translate(0)}10%,30%,50%,70%,90%{transform:translate(-6px)}20%,40%,60%,80%{transform:translate(6px)}}.shake{animation:.45s cubic-bezier(.36,.07,.19,.97) both shake;border-color:#ef444473!important;box-shadow:0 0 25px #ef444433!important}@keyframes pulseShield{0%{filter:drop-shadow(0 0 8px #7c4dff4d);transform:scale(1)}50%{filter:drop-shadow(0 0 16px #7c4dff8c);transform:scale(1.08)}to{filter:drop-shadow(0 0 8px #7c4dff4d);transform:scale(1)}}.ranking-table{border-collapse:collapse;width:100%;margin-top:.5rem}.ranking-table th{text-transform:uppercase;letter-spacing:.5px;padding:.65rem .5rem;font-size:.72rem;font-weight:600}.ranking-table td{vertical-align:middle;padding:.65rem .5rem;font-size:.8rem}.ranking-row{transition:background-color .2s}.ranking-row:hover{background-color:#ffffff05}.badge-rank{text-align:center;letter-spacing:.5px;white-space:nowrap;border-radius:99px;justify-content:center;align-items:center;padding:.2rem .6rem;font-size:.72rem;font-weight:600;display:inline-flex}.badge-rank.badge-locked{color:var(--secondary);background:#10b9811a;border:1px solid #10b98140;box-shadow:0 0 8px #10b9810d}.badge-rank.badge-estimated{color:var(--accent-amber);background:#f59e0b1a;border:1px solid #f59e0b40;box-shadow:0 0 8px #f59e0b0d}.ranking-tab-btn{transition:all .25s cubic-bezier(.4,0,.2,1)!important}.ranking-tab-btn:hover{color:#fff!important;background-color:#ffffff0d!important}.ranking-tab-btn.active-tab{box-shadow:0 4px 12px var(--primary-glow)!important}@media (width<=768px){.app-container{padding:1rem .5rem!important}.glass-panel{border-radius:16px!important;padding:1rem!important}.app-header{text-align:center!important;flex-direction:column!important;align-items:center!important;gap:1.25rem!important;padding:1.25rem 1rem!important}.logo-container{flex-direction:column!important;gap:.35rem!important}.app-header>div:last-child{flex-direction:column!important;align-items:stretch!important;gap:.85rem!important;width:100%!important}.semester-select-container{justify-content:space-between!important;width:100%!important;margin-right:0!important}.semester-select-dropdown{flex-grow:1!important;font-size:.85rem!important}.deployment-status{justify-content:center!important;width:100%!important;font-size:.8rem!important}.course-card{border-left:4px solid var(--border-light)!important;grid-template-rows:auto auto auto!important;grid-template-columns:1fr auto!important;align-items:center!important;gap:.75rem 1rem!important;padding:1rem 1.15rem!important;display:grid!important}.course-card .course-info-col{grid-area:1/1!important;width:100%!important}.course-card .course-indicator-col{grid-area:3/2!important;justify-content:flex-end!important;display:flex!important}.course-card .course-control-col{grid-area:2/1/auto/span 2!important;width:100%!important}.course-card .course-credits-col{grid-area:3/1!important;align-items:flex-start!important}.course-card .course-actions-col{grid-area:1/2!important;justify-content:flex-end!important}.stats-grid{gap:1rem!important;margin-bottom:1.5rem!important}.stat-card{padding:1rem 1.25rem!important}}@media (width<=580px){.component-item{border:1px solid var(--border-light)!important;background:#ffffff03!important;border-radius:10px!important;flex-direction:column!important;align-items:stretch!important;gap:.65rem!important;padding:.85rem!important;display:flex!important;position:relative!important}.component-item>div:first-child{width:100%!important;padding-right:25px!important}.component-item>div:nth-child(2){justify-content:space-between!important;width:100%!important}.component-item>div:nth-child(2):before{content:"權重配比:";color:var(--text-secondary);font-size:.8rem;font-weight:500}.component-item>div:nth-child(3){width:100%!important}.component-item>div:nth-child(4){position:absolute!important;top:.85rem!important;right:.85rem!important}.subscore-item{border:1px dashed var(--border-light)!important;background:#ffffff01!important;border-radius:8px!important;flex-direction:column!important;align-items:stretch!important;gap:.5rem!important;padding:.75rem!important;display:flex!important;position:relative!important}.subscore-item>div:first-child{width:100%!important;padding-right:25px!important}.subscore-item>div:nth-child(2){justify-content:space-between!important;width:100%!important}.subscore-item>div:nth-child(2):before{content:"得分 / 總分:";color:var(--text-secondary);font-size:.8rem;font-weight:500}.subscore-item>div:nth-child(3){position:absolute!important;top:.75rem!important;right:.75rem!important}}@media (width<=480px){.form-row{grid-template-columns:1fr!important;gap:.75rem!important}.cumulative-metrics-row{grid-template-columns:1fr!important;gap:.5rem!important}.modal-content{padding:1.25rem 1rem!important}.modal-actions{flex-direction:column-reverse!important;gap:.5rem!important}.modal-actions button{width:100%!important}.ranking-table th,.ranking-table td{padding:.45rem .25rem!important;font-size:.75rem!important}}.ranking-desktop-view{display:flex}.ranking-mobile-view{display:none}.mobile-rank-cards-grid{grid-template-columns:repeat(auto-fit,minmax(130px,1fr));gap:.75rem;display:grid}.mobile-rank-card{border:1px solid var(--border-light);transition:var(--transition-smooth);background:#ffffff05;border-radius:14px;flex-direction:column;gap:.65rem;padding:.85rem;display:flex;position:relative;box-shadow:0 4px 15px #0000001a}.mobile-rank-card:hover{border-color:var(--border-active);background:#ffffff08}.rank-card-header{justify-content:space-between;align-items:center;display:flex}.rank-card-sem{color:var(--text-secondary);text-transform:uppercase;font-size:.72rem;font-weight:700}.rank-card-score-box{text-align:center;background:#ffffff06;border:1px solid #ffffff08;border-radius:10px;padding:.5rem .25rem}.rank-score-val{color:#fff;letter-spacing:-.5px;text-shadow:0 0 10px #ffffff1a;font-size:1.15rem;font-weight:800}.rank-score-lbl{color:var(--text-muted);margin-top:.1rem;font-size:.62rem;font-weight:600}.rank-card-details{border-top:1px solid #ffffff0d;justify-content:space-between;align-items:center;padding-top:.25rem;display:flex}.rank-detail-item{flex-direction:column;flex:1;align-items:center;min-width:0;display:flex}.rank-detail-val{color:var(--primary);font-size:.85rem;font-weight:700}.rank-detail-lbl{color:var(--text-muted);margin-top:.1rem;font-size:.6rem;font-weight:600}.rank-divider{background:#ffffff1a;width:1px;height:16px}@media (width<=768px){.ranking-desktop-view{display:none!important}.ranking-mobile-view{display:flex!important}}.btn-export-card{position:relative;overflow:hidden;transition:all .3s cubic-bezier(.4,0,.2,1)!important}.btn-export-card:hover{transform:translateY(-2px);background:linear-gradient(135deg,#8b5cf666 0%,#3b82f666 100%)!important;border-color:#8b5cf699!important;box-shadow:0 0 18px #8b5cf659!important}.btn-export-card:active{transform:translateY(0)}.share-card-modal-content img{transition:transform .4s cubic-bezier(.4,0,.2,1)}.share-card-modal-content img:hover{transform:scale(1.03)}
