@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}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;overflow-x:hidden}::-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:auto 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)}
