:root{--primary:#1a1a2e;--secondary:#16213e;--accent:#0f3460;--highlight:#e94560;--success:#00b894;--warning:#fdcb6e;--bg:#0f0f1a;--card:#1a1a2e;--text:#eee;--muted:#888;--border:#2a2a4a;--A:#00b894;--B:#00cec9;--C:#fdcb6e;--D:#e17055;--E:#d63031;--F:#636e72}*{margin:0;padding:0;box-sizing:border-box}body{font-family:Segoe UI,system-ui,-apple-system,sans-serif;background:var(--bg);color:var(--text);min-height:100vh;line-height:1.5}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:var(--bg)}::-webkit-scrollbar-thumb{background:var(--accent);border-radius:3px}.app{max-width:1200px;margin:0 auto;padding:20px}.header{text-align:center;padding:30px 20px;margin-bottom:30px;background:linear-gradient(135deg,var(--secondary),var(--accent));border-radius:16px;border:1px solid var(--border);position:relative;overflow:hidden}.header:before{content:"";position:absolute;top:-50%;left:-50%;width:200%;height:200%;background:radial-gradient(circle,rgba(233,69,96,.05) 0,transparent 60%);animation:pulse 4s ease-in-out infinite}@keyframes pulse{0%,to{transform:scale(1)}50%{transform:scale(1.1)}}.header h1{font-size:2rem;font-weight:700;position:relative}.header h1 span{color:var(--highlight)}.header p{color:var(--muted);margin-top:6px;position:relative;font-size:.95rem}.dashboard{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));grid-gap:16px;gap:16px;margin-bottom:30px}.stat-card{background:var(--card);border:1px solid var(--border);border-radius:12px;padding:20px;text-align:center;transition:transform .2s,border-color .2s}.stat-card:hover{transform:translateY(-2px);border-color:var(--highlight)}.stat-card .label{font-size:.8rem;color:var(--muted);text-transform:uppercase;letter-spacing:1px}.stat-card .value{font-size:2rem;font-weight:700;margin:6px 0}.stat-card .sub{font-size:.85rem;color:var(--muted)}.cgpa-val{color:var(--highlight)}.class-val{color:var(--success)}.tabs{display:flex;gap:8px;margin-bottom:20px;flex-wrap:wrap;background:var(--card);padding:8px;border-radius:12px;border:1px solid var(--border)}.tab{padding:10px 20px;border:none;background:transparent;color:var(--muted);cursor:pointer;border-radius:8px;font-size:.9rem;font-weight:500;transition:all .2s;white-space:nowrap}.tab:hover{color:var(--text);background:rgba(255,255,255,.05)}.tab.active{background:var(--highlight);color:white}.mode-toggle{display:flex;gap:8px;margin-bottom:20px;background:var(--card);padding:6px;border-radius:10px;border:1px solid var(--border);width:-moz-fit-content;width:fit-content}.mode-btn{padding:8px 18px;border:none;background:transparent;color:var(--muted);cursor:pointer;border-radius:7px;font-size:.85rem;font-weight:500;transition:all .2s}.mode-btn.active{background:var(--accent);color:white}.semester-section{background:var(--card);border:1px solid var(--border);border-radius:12px;margin-bottom:20px;overflow:hidden}.semester-header{padding:16px 20px;background:rgba(255,255,255,.03);border-bottom:1px solid var(--border);display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:10px}.semester-header h3{font-size:1rem;font-weight:600}.semester-gpa{font-size:.9rem;padding:4px 14px;border-radius:20px;font-weight:600}.course-table{width:100%;border-collapse:collapse}.course-table th{text-align:left;padding:12px 16px;font-size:.75rem;color:var(--muted);text-transform:uppercase;letter-spacing:1px;border-bottom:1px solid var(--border);background:rgba(255,255,255,.02)}.course-table td{padding:10px 16px;border-bottom:1px solid rgba(255,255,255,.03);font-size:.9rem;vertical-align:middle}.course-table tr:last-child td{border-bottom:none}.course-table tr:hover{background:rgba(255,255,255,.02)}.course-code{font-weight:600;color:var(--highlight);font-size:.85rem;white-space:nowrap}.course-title{color:var(--text)}.course-units{font-weight:600;border-radius:6px;padding:2px 10px;display:inline-block;font-size:.85rem}.course-units,.score-input{text-align:center;background:rgba(255,255,255,.05)}.score-input{width:60px;padding:6px 8px;border:1px solid var(--border);border-radius:6px;color:var(--text);font-size:.9rem;transition:border-color .2s}.score-input:focus{outline:none;border-color:var(--highlight);background:rgba(233,69,96,.08)}.score-input::placeholder{color:#555}.grade-select{padding:6px 10px;border:1px solid var(--border);border-radius:6px;background:rgba(255,255,255,.05);color:var(--text);font-size:.9rem;cursor:pointer}.grade-select:focus{outline:none;border-color:var(--highlight)}.grade-select option{background:var(--primary)}.grade-badge{display:inline-flex;align-items:center;justify-content:center;min-width:36px;padding:4px 12px;border-radius:6px;font-weight:700;font-size:.9rem;letter-spacing:.5px}.grade-A{background:rgba(0,184,148,.15);color:var(--A)}.grade-B{background:rgba(0,206,201,.15);color:var(--B)}.grade-C{background:rgba(253,203,110,.15);color:var(--C)}.grade-D{background:rgba(225,112,85,.15);color:var(--D)}.grade-E{background:rgba(214,48,49,.15);color:var(--E)}.grade-F{background:rgba(99,110,114,.15);color:var(--F)}.grade-none{background:rgba(255,255,255,.05);color:var(--muted)}.suggested{font-size:.8rem;color:var(--muted);margin-top:3px}.suggested span{color:var(--success);font-weight:500}.progress-container{margin-bottom:30px}.progress-label{display:flex;justify-content:space-between;margin-bottom:8px;font-size:.85rem}.progress-bar{height:10px;background:var(--border);border-radius:5px;overflow:hidden;position:relative}.progress-fill{height:100%;border-radius:5px;transition:width .5s ease,background .3s}.progress-markers{display:flex;justify-content:space-between;margin-top:6px;font-size:.7rem;color:var(--muted);padding:0 2px}.insights{background:var(--card);border:1px solid var(--border);border-radius:12px;padding:20px;margin-bottom:20px}.insights h3{font-size:1rem;margin-bottom:14px;display:flex;align-items:center;gap:8px}.insight-item{padding:10px 14px;border-radius:8px;margin-bottom:8px;font-size:.9rem;line-height:1.5}.insight-good{background:rgba(0,184,148,.1);border-left:3px solid var(--success)}.insight-warn{background:rgba(253,203,110,.1);border-left:3px solid var(--warning)}.insight-bad{background:rgba(233,69,96,.1);border-left:3px solid var(--highlight)}.insight-info{background:rgba(15,52,96,.3);border-left:3px solid var(--accent)}.save-indicator{position:fixed;bottom:20px;right:20px;padding:10px 20px;background:var(--success);color:white;border-radius:8px;font-size:.85rem;font-weight:500;opacity:0;transform:translateY(10px);transition:all .3s;z-index:100;pointer-events:none}.save-indicator.show{opacity:1;transform:translateY(0)}.clear-btn{padding:8px 18px;border:1px solid var(--border);background:transparent;color:var(--muted);border-radius:8px;cursor:pointer;font-size:.8rem;transition:all .2s}.clear-btn:hover{border-color:var(--highlight);color:var(--highlight)}.footer{padding:30px 20px;font-size:.8rem}.copyright,.footer{text-align:center;color:var(--muted)}.copyright{padding:0 20px 30px;font-size:.75rem;opacity:.7}.copyright-link{color:var(--highlight);text-decoration:none}.copyright-link:hover{text-decoration:underline}@media (max-width:768px){.app{padding:12px}.header h1{font-size:1.4rem}.dashboard{grid-template-columns:repeat(2,1fr)}.course-table td,.course-table th{padding:8px 10px;font-size:.8rem}.score-input{width:50px;padding:5px 4px;font-size:.8rem}.course-title{max-width:120px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.tab{padding:8px 14px;font-size:.8rem}}.login-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:var(--bg);z-index:9999;display:flex;align-items:center;justify-content:center;animation:fadeIn .3s ease}.login-box{background:var(--card);border:1px solid var(--border);border-radius:16px;padding:40px;max-width:400px;width:90%;text-align:center;position:relative;overflow:hidden}.login-box:before{content:"";position:absolute;top:-50%;left:-50%;width:200%;height:200%;background:radial-gradient(circle,rgba(233,69,96,.06) 0,transparent 60%);animation:pulse 4s ease-in-out infinite;pointer-events:none}.login-box h2{font-size:1.6rem;margin-bottom:6px;position:relative}.login-box h2 span{color:var(--highlight)}.login-box .login-sub{color:var(--muted);font-size:.9rem;margin-bottom:28px;position:relative}.login-input{width:100%;padding:14px 18px;margin-bottom:12px;border:1px solid var(--border);border-radius:10px;background:rgba(255,255,255,.05);color:var(--text);font-size:1rem;text-align:center;letter-spacing:2px;transition:border-color .2s;position:relative}.login-input:focus{outline:none;border-color:var(--highlight);background:rgba(233,69,96,.08)}.login-input::placeholder{color:#555;letter-spacing:0}.login-btn{width:100%;padding:14px;border:none;border-radius:10px;background:linear-gradient(135deg,var(--highlight),#c0392b);color:white;font-size:1rem;font-weight:600;cursor:pointer;margin-top:16px;transition:transform .2s,opacity .2s;position:relative}.login-btn:hover{transform:translateY(-1px);opacity:.9}.login-btn:active{transform:translateY(0)}.login-error{color:var(--highlight);font-size:.85rem;min-height:20px}.login-confirm-row,.login-error{margin-top:12px;position:relative}.lock-btn{padding:6px 14px;border:1px solid var(--border);background:transparent;color:var(--muted);border-radius:8px;cursor:pointer;font-size:.8rem;transition:all .2s;position:absolute;top:14px;right:14px}.lock-btn:hover{border-color:var(--highlight);color:var(--highlight)}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.semester-section{animation:fadeIn .3s ease}.level-100{color:#74b9ff}.level-200{color:#a29bfe}.level-300{color:#fd79a8}.total-row td{font-weight:600;border-top:2px solid var(--border);background:rgba(255,255,255,.02)}.overflow-x{overflow-x:auto}.action-row{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:10px;margin-bottom:16px}.unit-counter{font-size:.8rem;padding:4px 12px;border-radius:20px;font-weight:600;border:1px solid var(--border);white-space:nowrap}.unit-counter.ok{background:rgba(0,184,148,.1);color:var(--success);border-color:rgba(0,184,148,.3)}.unit-counter.warn{background:rgba(253,203,110,.1);color:var(--warning);border-color:rgba(253,203,110,.3)}.unit-counter.full{background:rgba(233,69,96,.1);color:var(--highlight);border-color:rgba(233,69,96,.3)}.co-pending{padding:14px 20px;border-top:1px dashed var(--border);background:rgba(233,69,96,.03)}.co-pending-title{font-size:.85rem;font-weight:600;color:var(--warning);margin-bottom:10px;display:flex;align-items:center;gap:6px}.co-item{justify-content:space-between;padding:10px 14px;margin-bottom:6px;background:rgba(255,255,255,.03);border:1px solid var(--border);border-radius:8px}.co-item,.co-item-info{display:flex;align-items:center;gap:10px;flex-wrap:wrap}.co-item-info{font-size:.85rem}.co-tag{display:inline-block;padding:2px 8px;border-radius:4px;font-size:.7rem;font-weight:700;letter-spacing:.5px;background:rgba(253,203,110,.15);color:var(--warning);white-space:nowrap}.co-tag-from{font-size:.75rem;color:var(--muted);white-space:nowrap}.co-add-btn{padding:6px 16px;border:1px solid var(--success);background:rgba(0,184,148,.1);color:var(--success);border-radius:6px;cursor:pointer;font-size:.8rem;font-weight:600;transition:all .2s;white-space:nowrap}.co-add-btn:hover{background:rgba(0,184,148,.2);transform:translateY(-1px)}.co-add-btn:disabled{border-color:var(--border);background:transparent;color:var(--muted);cursor:not-allowed;transform:none}.co-remove-btn{padding:2px 8px;border:1px solid rgba(233,69,96,.3);background:rgba(233,69,96,.08);color:var(--highlight);border-radius:4px;cursor:pointer;font-size:.75rem;font-weight:600;transition:all .2s;white-space:nowrap}.co-remove-btn:hover{background:rgba(233,69,96,.2)}.co-cascade-note{font-size:.78rem;color:var(--warning);font-style:italic;white-space:nowrap}.co-row td{background:rgba(253,203,110,.03)}