.cgpa-calculator-page{min-height:100vh;color:var(--text-primary);box-sizing:border-box;background:linear-gradient(135deg,#1a1a1a 0%,#2d2d2d 100%);padding:1rem;overflow-x:hidden}.cgpa-calculator-page *,.cgpa-calculator-page :before,.cgpa-calculator-page :after{box-sizing:border-box}.cgpa-calculator-page .container{width:100%;max-width:1200px;margin:0 auto}.calculator-hero{text-align:center;padding:80px 0 60px;position:relative}.calculator-hero:before{content:"";z-index:1;background:radial-gradient(circle at 25% 30%,#ff6b6b1a 0%,#0000 50%),radial-gradient(circle at 75% 70%,#ff6b6b1a 0%,#0000 50%);position:absolute;inset:0}.calculator-hero h1{color:var(--text-primary);z-index:2;margin-bottom:24px;font-size:clamp(2.5rem,5vw,3.5rem);font-weight:700;position:relative}.calculator-tagline{color:var(--text-secondary);z-index:2;max-width:600px;margin:0 auto;font-size:clamp(1.1rem,2.5vw,1.4rem);font-style:italic;position:relative}.toast-container{z-index:9999;flex-direction:column;gap:.5rem;max-width:400px;display:flex;position:fixed;top:90px;right:20px}.toast{color:#fff;cursor:pointer;background:linear-gradient(135deg,#e74c3c,#c0392b);border-radius:8px;align-items:center;gap:1rem;padding:1rem 1.5rem;transition:all .3s;animation:.3s slideInRight;display:flex;box-shadow:0 4px 15px #e74c3c66}.toast:hover{transform:translate(-5px);box-shadow:0 6px 20px #e74c3c80}.toast-icon{flex-shrink:0;font-size:1.5rem}.toast-message{flex:1;font-size:.9rem}.toast-close{color:#fff;cursor:pointer;background:0 0;border:none;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:24px;height:24px;padding:0;font-size:1.5rem;transition:background-color .2s;display:flex}.toast-close:hover{background-color:#fff3}@keyframes slideInRight{0%{opacity:0;transform:translate(100%)}to{opacity:1;transform:translate(0)}}@media (max-width:768px){.toast-container{max-width:none;left:10px;right:10px}}.error-boundary{background-color:var(--bg-secondary);text-align:center;border:2px solid #e74c3c;border-radius:12px;max-width:600px;margin:2rem auto;padding:3rem 2rem}.error-boundary h2{color:#e74c3c;margin-bottom:1rem;font-size:2rem}.error-boundary p{color:var(--text-secondary);margin-bottom:2rem;font-size:1.1rem}.system-selection{background-color:var(--bg-secondary);border:1px solid var(--border-color);border-radius:12px;margin-bottom:2rem;padding:2rem}.system-selection h3{color:var(--text-primary);margin-bottom:1.5rem;font-size:1.2rem}.system-buttons{flex-wrap:wrap;gap:1rem;display:flex}.system-btn{background-color:var(--bg-primary);color:var(--text-secondary);border:2px solid var(--border-color);cursor:pointer;border-radius:8px;padding:12px 24px;font-size:1rem;font-weight:500;transition:all .3s}.system-btn:hover{border-color:var(--accent-color);color:var(--text-primary)}.system-btn.active{background-color:var(--accent-color);color:var(--bg-primary);border-color:var(--accent-color)}.custom-system-config{background-color:var(--bg-secondary);border:1px solid var(--border-color);border-radius:12px;margin-bottom:2rem;padding:2rem}.custom-system-config h3{color:var(--text-primary);margin-bottom:1.5rem}.custom-grades-grid{grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:1rem;margin-bottom:1.5rem;display:grid}.custom-grade-item{background-color:var(--bg-primary);border:1px solid var(--border-color);border-radius:8px;flex-direction:column;gap:.5rem;padding:1rem;transition:all .3s;display:flex;position:relative}.custom-grade-item:hover{border-color:var(--accent-color);box-shadow:0 2px 8px #0000001a}.grade-header{justify-content:space-between;align-items:flex-start;margin-bottom:.5rem;display:flex}.grade-actions{opacity:0;gap:.25rem;transition:opacity .3s;display:flex}.custom-grade-item:hover .grade-actions{opacity:1}.grade-action-btn{cursor:pointer;color:var(--text-secondary);background:0 0;border:none;border-radius:6px;justify-content:center;align-items:center;min-width:32px;min-height:32px;padding:8px;font-size:.9rem;transition:all .2s;display:flex}.grade-action-btn:hover{background-color:var(--bg-secondary);transform:scale(1.05)}.grade-action-btn.delete:hover{color:#e74c3c;background-color:#e74c3c26;transform:scale(1.05)}.grade-action-btn.edit:hover{color:#3498db;background-color:#3498db26;transform:scale(1.05)}.grade-name-input{color:var(--text-primary);text-align:center;background-color:#0000;border:1px solid #0000;border-radius:4px;min-width:0;padding:4px 8px;font-size:.9rem;font-weight:600;transition:all .3s}.grade-name-input:focus{border-color:var(--accent-color);background-color:var(--bg-secondary);outline:none}.grade-name-input:hover{border-color:var(--border-color)}.grade-points-input{background-color:var(--bg-secondary);color:var(--text-primary);border:1px solid var(--border-color);text-align:center;appearance:textfield;border-radius:6px;padding:8px 12px;font-size:.9rem;transition:all .3s}.grade-points-input::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}.grade-points-input::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}.grade-points-input:focus{border-color:var(--accent-color);outline:none;box-shadow:0 0 0 2px #3498db1a}.add-grade-container{justify-content:center;margin-top:1rem;display:flex}.add-grade-btn{color:#fff;cursor:pointer;background:linear-gradient(135deg,#3498db,#2980b9);border:none;border-radius:8px;align-items:center;gap:8px;padding:12px 24px;font-size:.9rem;font-weight:600;transition:all .3s;display:flex;box-shadow:0 4px 15px #3498db4d}.add-grade-btn:before{content:"+";font-size:1rem;font-weight:700}.add-grade-btn:hover{background:linear-gradient(135deg,#2980b9,#1e6091);transform:translateY(-2px);box-shadow:0 6px 20px #3498db66}.add-grade-btn:active{transform:translateY(0);box-shadow:0 2px 10px #3498db4d}.grade-management-header{justify-content:space-between;align-items:center;margin-bottom:1rem;display:flex}.grade-management-actions{gap:.5rem;display:flex}.reset-grades-btn{color:#fff;cursor:pointer;background:linear-gradient(135deg,#f39c12,#e67e22);border:none;border-radius:8px;padding:12px 24px;font-size:.9rem;font-weight:600;transition:all .3s;box-shadow:0 4px 15px #f39c124d}.reset-grades-btn:hover{background:linear-gradient(135deg,#e67e22,#d35400);transform:translateY(-2px);box-shadow:0 6px 20px #f39c1266}.reset-grades-btn:active{transform:translateY(0);box-shadow:0 2px 10px #f39c124d}.save-grades-btn{color:#fff;cursor:pointer;background:linear-gradient(135deg,#27ae60,#229954);border:none;border-radius:8px;padding:12px 24px;font-size:.9rem;font-weight:600;transition:all .3s;box-shadow:0 4px 15px #27ae604d}.save-grades-btn:hover{background:linear-gradient(135deg,#229954,#1e8449);transform:translateY(-2px);box-shadow:0 6px 20px #27ae6066}.save-grades-btn:active{transform:translateY(0);box-shadow:0 2px 10px #27ae604d}.clear-saved-btn{color:#fff;cursor:pointer;background:linear-gradient(135deg,#95a5a6,#7f8c8d);border:none;border-radius:8px;padding:12px 24px;font-size:.9rem;font-weight:600;transition:all .3s;box-shadow:0 4px 15px #95a5a64d}.clear-saved-btn:hover{background:linear-gradient(135deg,#7f8c8d,#566573);transform:translateY(-2px);box-shadow:0 6px 20px #95a5a666}.clear-saved-btn:active{transform:translateY(0);box-shadow:0 2px 10px #95a5a64d}.grade-reference{background-color:var(--bg-secondary);border:1px solid var(--border-color);border-radius:12px;margin-bottom:2rem;padding:2rem}.grade-reference h3{color:var(--text-primary);margin-bottom:1.5rem}.grade-table{grid-template-columns:repeat(auto-fit,minmax(100px,1fr));gap:.5rem;max-width:600px;display:grid}.grade-row{background-color:var(--bg-primary);border:1px solid var(--border-color);border-radius:6px;justify-content:space-between;align-items:center;padding:8px 12px;display:flex}.grade-row .grade{color:var(--accent-color);font-weight:600}.grade-row .points{color:var(--text-primary)}.calculator-section{background-color:var(--bg-secondary);border:1px solid var(--border-color);border-radius:12px;margin-bottom:2rem;padding:2rem}.calculator-header{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:1rem;margin-bottom:2rem;display:flex}.calculator-header h3{color:var(--text-primary);margin:0}.calculator-actions{gap:1rem;display:flex}.add-btn,.reset-btn,.save-btn{cursor:pointer;border:none;border-radius:8px;font-weight:600;transition:all .3s;position:relative;overflow:hidden}.add-btn{color:#fff;background:linear-gradient(135deg,#3498db,#2980b9);padding:12px 24px;font-size:.9rem;box-shadow:0 4px 15px #3498db4d}.add-btn:hover{background:linear-gradient(135deg,#2980b9,#1e6091);transform:translateY(-2px);box-shadow:0 6px 20px #3498db66}.add-btn:active{transform:translateY(0);box-shadow:0 2px 10px #3498db4d}.save-btn{color:#fff;background:linear-gradient(135deg,#27ae60,#229954);padding:12px 24px;font-size:.9rem;box-shadow:0 4px 15px #27ae604d}.save-btn:hover{background:linear-gradient(135deg,#229954,#1e8449);transform:translateY(-2px);box-shadow:0 6px 20px #27ae6066}.save-btn:active{transform:translateY(0);box-shadow:0 2px 10px #27ae604d}.reset-btn{color:#fff;background:linear-gradient(135deg,#f39c12,#e67e22);border:none;padding:12px 24px;font-size:.9rem;font-weight:600;box-shadow:0 4px 15px #f39c124d}.reset-btn:hover{background:linear-gradient(135deg,#e67e22,#d35400);transform:translateY(-2px);box-shadow:0 6px 20px #f39c1266}.reset-btn:active{transform:translateY(0);box-shadow:0 2px 10px #f39c124d}.subjects-container{border:1px solid var(--border-color);border-radius:8px;overflow:hidden}.subjects-header{background-color:var(--bg-primary);color:var(--text-primary);border-bottom:1px solid var(--border-color);grid-template-columns:2fr 1fr 1fr 1fr 1fr;gap:1rem;padding:1rem;font-weight:600;display:grid}.subject-row{border-bottom:1px solid var(--border-color);grid-template-columns:2fr 1fr 1fr 1fr 1fr;align-items:center;gap:1rem;padding:1rem;display:grid}.subject-row:last-child{border-bottom:none}.subject-input,.credits-input,.grade-select{background-color:var(--bg-primary);color:var(--text-primary);border:1px solid var(--border-color);border-radius:6px;padding:8px 12px;font-size:.9rem}.credits-input{appearance:textfield}.credits-input::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}.credits-input::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}.subject-input:focus,.credits-input:focus,.grade-select:focus{border-color:var(--accent-color);outline:none}.grade-points-display{color:var(--accent-color);text-align:center;font-weight:600}.remove-btn{color:#fff;cursor:pointer;background:linear-gradient(135deg,#e74c3c,#c0392b);border:none;border-radius:8px;padding:12px 24px;font-size:.9rem;font-weight:600;transition:all .3s;box-shadow:0 4px 15px #e74c3c4d}.remove-btn:hover:not(:disabled){background:linear-gradient(135deg,#c0392b,#a93226);transform:translateY(-2px);box-shadow:0 6px 20px #e74c3c66}.remove-btn:active:not(:disabled){transform:translateY(0);box-shadow:0 2px 10px #e74c3c4d}.remove-btn:disabled{background:var(--text-secondary);cursor:not-allowed;opacity:.5;transform:none;box-shadow:0 2px 10px #e74c3c4d}.results-section{background-color:var(--bg-secondary);border:1px solid var(--border-color);border-radius:12px;margin-bottom:2rem;padding:2rem}.results-grid{grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:2rem;margin-bottom:2rem;display:grid}.result-card{background-color:var(--bg-primary);border:1px solid var(--border-color);text-align:center;border-radius:12px;padding:2rem;transition:transform .3s}.result-card:hover{transform:translateY(-5px)}.result-card h3{color:var(--accent-color);margin-bottom:1rem;font-size:1.2rem}.result-value{color:var(--text-primary);margin-bottom:.5rem;font-size:2.5rem;font-weight:700}.result-card p{color:var(--text-secondary);font-size:.9rem}.performance-indicator{margin-top:2rem}.performance-indicator h3{color:var(--text-primary);text-align:center;margin-bottom:1rem}.performance-bar{background-color:var(--bg-primary);border-radius:10px;width:100%;height:20px;margin-bottom:.5rem;overflow:hidden}.performance-fill{background:linear-gradient(90deg,#e74c3c 0%,#f39c12 25%,#f1c40f 50%,#27ae60 75%,#2ecc71 100%);border-radius:10px;height:100%;transition:width .5s}.performance-labels{color:var(--text-secondary);justify-content:space-between;margin-bottom:1rem;font-size:.8rem;display:flex}.performance-text{text-align:center;color:var(--accent-color);font-size:1.1rem;font-weight:600}.instructions{background-color:var(--bg-secondary);border:1px solid var(--border-color);border-radius:12px;padding:2rem}.instructions h3{color:var(--text-primary);margin-bottom:1.5rem}.instructions ol{color:var(--text-secondary);padding-left:1.5rem;line-height:1.8}.instructions li{margin-bottom:.5rem}.cgpa-summary{margin-bottom:2rem}.summary-card{background-color:var(--bg-primary);border:2px solid var(--accent-color);border-radius:12px;padding:1.5rem}.summary-card h4{color:var(--accent-color);text-align:center;margin-bottom:1rem;font-size:1.2rem}.summary-details{justify-content:space-around;gap:2rem;display:flex}.summary-item{flex-direction:column;align-items:center;gap:.5rem;display:flex}.summary-label{color:var(--text-secondary);font-size:.9rem}.summary-value{color:var(--text-primary);font-size:1.5rem;font-weight:700}.semester-container{background-color:var(--bg-primary);border:1px solid var(--border-color);border-radius:12px;margin-bottom:2rem;overflow:hidden}.semester-header{background-color:var(--bg-secondary);border-bottom:1px solid var(--border-color);flex-wrap:wrap;align-items:center;gap:1rem;padding:1.5rem;display:flex}.semester-name-input{background-color:var(--bg-primary);color:var(--text-primary);border:1px solid var(--border-color);border-radius:6px;min-width:150px;padding:8px 12px;font-size:1.1rem;font-weight:600}.semester-name-input:focus{border-color:var(--accent-color);outline:none}.semester-stats{gap:1.5rem;margin-left:auto;display:flex}.semester-gpa,.semester-credits{color:var(--text-primary);font-size:.9rem;font-weight:600}.semester-actions{gap:.5rem;display:flex}.add-subject-btn,.remove-semester-btn{cursor:pointer;border:none;border-radius:8px;font-weight:600;transition:all .3s;position:relative;overflow:hidden}.add-subject-btn{color:#fff;background:linear-gradient(135deg,#3498db,#2980b9);padding:12px 24px;font-size:.9rem;box-shadow:0 4px 15px #3498db4d}.add-subject-btn:before{content:"+";margin-right:4px;font-size:.9rem;font-weight:600}.add-subject-btn:hover{background:linear-gradient(135deg,#2980b9,#1e6091);transform:translateY(-2px);box-shadow:0 6px 20px #3498db66}.add-subject-btn:active{transform:translateY(0);box-shadow:0 2px 10px #3498db4d}.remove-semester-btn{color:#fff;background:linear-gradient(135deg,#e74c3c,#c0392b);padding:12px 24px;font-size:.9rem;box-shadow:0 4px 15px #e74c3c4d}.remove-semester-btn:hover:not(:disabled){background:linear-gradient(135deg,#c0392b,#a93226);transform:translateY(-2px);box-shadow:0 6px 20px #e74c3c66}.remove-semester-btn:active:not(:disabled){transform:translateY(0);box-shadow:0 2px 10px #e74c3c4d}.remove-semester-btn:disabled{background:var(--text-secondary);cursor:not-allowed;opacity:.5;transform:none;box-shadow:0 2px 10px #e74c3c4d}@media (max-width:768px){.cgpa-calculator-page{padding:.75rem}.calculator-hero{padding:40px 0 30px}.semester-header{flex-direction:column;align-items:stretch;gap:1rem;padding:1rem}.semester-stats{flex-wrap:wrap;justify-content:center;margin-left:0}.semester-actions{flex-wrap:wrap;justify-content:center}.summary-details{flex-direction:column;gap:1rem}.calculator-header{flex-direction:column;align-items:stretch}.calculator-actions{flex-wrap:wrap;justify-content:center}.calculator-actions button{flex:1;min-width:120px}.add-subject-btn{justify-content:center;width:100%;padding:12px 16px;font-size:.9rem}.remove-semester-btn{padding:10px 16px;font-size:.9rem}.add-subject-btn:hover,.remove-semester-btn:hover:not(:disabled){transform:none}.system-buttons{flex-direction:column}.system-btn{text-align:center;width:100%}.subjects-header,.subject-row{grid-template-columns:1fr;gap:.5rem}.subjects-header{display:none}.subject-row{flex-direction:column;padding:1rem;display:flex}.custom-grades-grid{grid-template-columns:repeat(auto-fit,minmax(140px,1fr))}.grade-management-header{flex-direction:column;align-items:stretch;gap:1rem}.grade-management-header h3{text-align:center}.grade-management-actions{flex-wrap:wrap;justify-content:center}.grade-management-actions button{flex:1;min-width:120px}.custom-grade-item{padding:.75rem}.grade-actions{opacity:1}.add-grade-btn{justify-content:center;width:100%}.grade-table{grid-template-columns:repeat(auto-fit,minmax(80px,1fr))}.results-grid{grid-template-columns:1fr;gap:1rem}.system-selection,.custom-system-config,.grade-reference,.calculator-section,.results-section,.instructions{padding:1.5rem 1rem}.semester-container{margin-bottom:1.5rem}}@media (max-width:480px){.cgpa-calculator-page{padding:.5rem .25rem}.calculator-hero{padding:30px 0 20px}.calculator-hero h1{font-size:1.8rem}.calculator-tagline{font-size:1rem}.system-selection,.custom-system-config,.grade-reference,.calculator-section,.results-section,.instructions{margin-bottom:1rem;padding:1rem .75rem}.result-value{font-size:1.8rem}.result-card{padding:1.5rem 1rem}.calculator-actions button,.grade-management-actions button{min-width:100px;padding:10px 12px;font-size:.85rem}.add-btn,.reset-btn,.save-btn,.clear-saved-btn,.reset-grades-btn,.save-grades-btn{padding:10px 16px;font-size:.85rem}.add-subject-btn,.remove-semester-btn{padding:10px 14px;font-size:.85rem}.custom-grades-grid{grid-template-columns:1fr;gap:.75rem}.semester-header{padding:.75rem}.semester-name-input{font-size:1rem}.semester-stats{gap:1rem;font-size:.85rem}.subject-row{padding:.75rem}.subject-input,.credits-input,.grade-select{box-sizing:border-box;width:100%;padding:8px 10px;font-size:.85rem}.semester-name-input{box-sizing:border-box;width:100%}.grade-management-header h3,.custom-system-config h3,.calculator-header h3,.results-section h3{font-size:1.1rem}.toast-container{top:10px;left:10px;right:10px}.toast{padding:.75rem 1rem;font-size:.85rem}}
