:root{font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;line-height:1.5;font-weight:400;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;--bg-primary: #ffffff;--bg-secondary: #fafafa;--bg-tertiary: #f8f9fa;--text-primary: #333333;--text-secondary: #666666;--text-muted: #888888;--border-color: #e0e0e0;--border-light: #f0f0f0;--shadow-light: rgba(0, 0, 0, .1);--shadow-medium: rgba(0, 0, 0, .15);--accent-primary: #007bff;--accent-hover: #0056b3;--accent-secondary: #6c757d;--accent-secondary-hover: #545b62;--input-bg: #ffffff;--input-border: #e0e0e0;--input-focus: #007bff;--card-bg: #ffffff;--card-shadow: 0 2px 4px rgba(0, 0, 0, .1);--header-bg: #ffffff;--header-border: #e0e0e0;--header-shadow: 0 1px 3px rgba(0, 0, 0, .1)}[data-theme=dark]{--bg-primary: #1a1a1a;--bg-secondary: #2d2d2d;--bg-tertiary: #3a3a3a;--text-primary: #ffffff;--text-secondary: #e0e0e0;--text-muted: #b0b0b0;--border-color: #404040;--border-light: #505050;--shadow-light: rgba(0, 0, 0, .3);--shadow-medium: rgba(0, 0, 0, .4);--accent-primary: #4dabf7;--accent-hover: #74c0fc;--accent-secondary: #868e96;--accent-secondary-hover: #adb5bd;--input-bg: #2d2d2d;--input-border: #404040;--input-focus: #4dabf7;--card-bg: #2d2d2d;--card-shadow: 0 2px 8px rgba(0, 0, 0, .3);--header-bg: #2d2d2d;--header-border: #404040;--header-shadow: 0 1px 3px rgba(0, 0, 0, .3)}*{box-sizing:border-box}.loading-container{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100vh;background:var(--color-background);color:var(--color-text)}.loading-spinner{width:40px;height:40px;border:4px solid var(--color-border);border-top:4px solid var(--color-primary);border-radius:50%;animation:spin 1s linear infinite;margin-bottom:16px}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.app-wrapper{min-height:100vh;display:flex;flex-direction:column}.app-footer{margin-top:auto;padding:20px 0;background:var(--color-background);border-top:1px solid var(--color-border);text-align:center}.footer-content{max-width:1200px;margin:0 auto;padding:0 20px}.social-links{display:flex;justify-content:center;gap:16px;margin-bottom:12px}.social-link{display:flex;align-items:center;justify-content:center;width:40px;height:40px;border-radius:50%;background:var(--color-background);border:1px solid var(--color-border);color:var(--color-text);text-decoration:none;transition:all .3s ease;font-size:20px}.social-link:hover{background:var(--color-primary);color:#fff;border-color:var(--color-primary);transform:translateY(-2px);box-shadow:0 4px 12px #00000026}.social-link.linkedin:hover{background:#0077b5;border-color:#0077b5}.social-link.github:hover{background:#333;border-color:#333}.footer-text{color:var(--text-secondary);font-size:14px;font-style:italic}.footer-text p{margin:0}body{margin:0;padding:0;min-height:100vh;background-color:var(--bg-secondary);color:var(--text-primary);transition:background-color .3s ease,color .3s ease}h1,h2,h3,h4,h5,h6{margin:0 0 16px;font-weight:600;color:var(--text-primary);transition:color .3s ease}h2{font-size:1.5rem;margin-bottom:20px}h3{font-size:1.25rem;margin-bottom:12px}p{margin:0 0 12px;color:var(--text-secondary);transition:color .3s ease}input{width:100%;padding:12px 16px;border:1px solid var(--input-border);border-radius:8px;font-size:16px;font-family:inherit;background-color:var(--input-bg);color:var(--text-primary);transition:all .3s ease}input:focus{outline:none;border-color:var(--input-focus);box-shadow:0 0 0 3px #4dabf71a}input::placeholder{color:var(--text-muted)}.form-row{display:flex;gap:16px;margin-bottom:16px}.form-group{flex:1}.form-group label{display:block;margin-bottom:8px;font-weight:500;color:var(--text-primary);font-size:14px}.form-select{width:100%;padding:12px 16px;border:1px solid var(--input-border);border-radius:8px;font-size:16px;font-family:inherit;background-color:var(--input-bg);color:var(--text-primary);transition:all .3s ease;cursor:pointer}.form-select:focus{outline:none;border-color:var(--input-focus);box-shadow:0 0 0 3px #4dabf71a}.form-select option{background-color:var(--input-bg);color:var(--text-primary)}button{border-radius:8px;border:1px solid var(--border-color);padding:12px 20px;font-size:16px;font-weight:500;font-family:inherit;background-color:var(--bg-primary);color:var(--text-primary);cursor:pointer;transition:all .3s ease;text-decoration:none;display:inline-flex;align-items:center;justify-content:center;min-height:44px}button:hover{background-color:var(--bg-tertiary);border-color:var(--accent-primary);color:var(--accent-primary)}button:active{transform:translateY(1px)}button.primary{background-color:var(--accent-primary);color:#fff;border-color:var(--accent-primary)}button.primary:hover{background-color:var(--accent-hover);border-color:var(--accent-hover);color:#fff}button.secondary{background-color:var(--accent-secondary);color:#fff;border-color:var(--accent-secondary)}button.secondary:hover{background-color:var(--accent-secondary-hover);border-color:var(--accent-secondary-hover);color:#fff}.theme-toggle{background:transparent;border:1px solid var(--border-color);border-radius:50%;width:44px;height:44px;padding:0;display:flex;align-items:center;justify-content:center;color:var(--text-primary);transition:all .3s ease;margin-right:8px}.theme-toggle:hover{background-color:var(--bg-tertiary);border-color:var(--accent-primary);color:var(--accent-primary);transform:scale(1.05)}.theme-toggle:active{transform:scale(.95)}.card{background-color:var(--card-bg);border-radius:8px;padding:16px;box-shadow:var(--card-shadow);border:1px solid var(--border-color);margin-bottom:16px;transition:all .3s ease}.card-header{font-weight:600;color:var(--text-primary);margin-bottom:8px;transition:color .3s ease}.card-content{color:var(--text-secondary);line-height:1.4;transition:color .3s ease}.container{max-width:600px;margin:0 auto;padding:20px}.page-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px;padding-bottom:16px;border-bottom:1px solid var(--border-color);transition:border-color .3s ease}.page-title{margin:0;font-size:1.75rem;font-weight:600}.page-subtitle{margin:8px 0 0;font-size:1rem;color:var(--text-secondary);font-weight:400}.action-buttons{display:flex;gap:8px;align-items:center}.app-header{background-color:var(--header-bg);border-bottom:1px solid var(--header-border);padding:16px 20px;display:flex;justify-content:space-between;align-items:center;box-shadow:var(--header-shadow);transition:all .3s ease}.header-left,.header-right{display:flex;align-items:center;gap:8px}.login-header{background-color:var(--header-bg);border-bottom:1px solid var(--header-border);padding:16px 20px;box-shadow:var(--header-shadow);transition:all .3s ease}.login-header-content{max-width:600px;margin:0 auto;display:flex;justify-content:space-between;align-items:center}.login-header-content h1{margin:0;font-size:1.5rem;font-weight:600;color:var(--text-primary)}.captcha-container{margin-bottom:20px}.captcha-loading{width:150px;height:50px;background-color:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:8px;display:flex;align-items:center;justify-content:center;color:var(--text-muted);font-size:14px;margin-bottom:12px;transition:all .3s ease}.captcha-image{width:150px;height:50px;border:1px solid var(--border-color);border-radius:8px;object-fit:contain;margin-bottom:12px;transition:border-color .3s ease;background-color:#fff}.captcha-input{width:200px!important;margin-top:8px}.timetable-day{margin-bottom:32px}.timetable-day h3{color:var(--text-primary);font-size:1.25rem;margin-bottom:16px;padding-bottom:8px;border-bottom:2px solid var(--border-light);transition:all .3s ease}.class-block{background-color:var(--card-bg);border:1px solid var(--border-color);border-radius:8px;padding:16px;margin-bottom:12px;box-shadow:var(--card-shadow);transition:all .3s ease}.class-name{font-weight:600;color:var(--text-primary);margin-bottom:4px;transition:color .3s ease}.class-time{color:var(--text-secondary);font-size:14px;transition:color .3s ease}.class-card{background-color:var(--card-bg);border:1px solid var(--border-color);border-radius:8px;padding:20px;margin-bottom:20px;box-shadow:var(--card-shadow);transition:all .3s ease}.class-card h2{margin-bottom:12px;font-size:1.25rem;color:var(--text-primary);transition:color .3s ease}.class-card-content{font-size:1.1rem;color:var(--text-secondary);line-height:1.4;transition:color .3s ease}@media (max-width: 768px){.container{padding:16px}.page-header{flex-direction:column;align-items:flex-start;gap:16px}.action-buttons{width:100%;justify-content:space-between}.action-buttons button{flex:1;margin:0 4px}.action-buttons button:first-child{margin-left:0}.action-buttons button:last-child{margin-right:0}button.full-width-mobile{width:100%;margin-top:16px}button+button{margin-top:16px}.captcha-input{width:100%!important}.app-header{padding:12px 16px}.app-header button{padding:8px 12px;font-size:14px}.theme-toggle{width:40px;height:40px}}@media (max-width: 480px){.container{padding:12px}h2{font-size:1.25rem}.class-card{padding:16px}.class-block{padding:12px}.header-right{gap:4px}.form-row{flex-direction:column;gap:12px}}.subjects-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:16px;margin-bottom:24px}.subject-card{background-color:var(--card-bg);border:1px solid var(--border-color);border-radius:8px;padding:16px;box-shadow:var(--card-shadow);transition:all .3s ease}.subject-code{font-weight:600;color:var(--text-primary);margin-bottom:12px;font-size:1.1rem;word-break:break-all}.subject-name{font-size:1rem;color:var(--text-secondary);margin-bottom:12px;min-height:24px;display:flex;align-items:center}.subject-name-input{width:100%;margin-bottom:12px;text-transform:uppercase}.subject-actions{display:flex;gap:8px}.subject-actions button{flex:1;padding:8px 12px;font-size:14px;min-height:auto}.subject-edit,.subject-display{margin-top:8px}button.small{padding:6px 12px;font-size:12px;min-height:32px}.page-actions{margin-top:24px;text-align:center}@media (max-width: 768px){.subjects-grid{grid-template-columns:1fr;gap:12px}.subject-card{padding:12px}.subject-actions{flex-direction:column}.subject-actions button{margin-bottom:4px}}.today-subjects{display:flex;flex-direction:column;gap:8px}.subject-item{display:flex;align-items:center;gap:8px;padding:8px 0;border-bottom:1px solid var(--border-light)}.subject-item:last-child{border-bottom:none}.subject-display-name{font-weight:600;color:var(--text-primary);font-size:1rem}.subject-original-code{color:var(--text-muted);font-size:.9rem;font-style:italic}.loading{color:var(--text-muted);font-style:italic;transition:color .3s ease}.text-center{text-align:center}.mb-16{margin-bottom:16px}.mb-20{margin-bottom:20px}.mt-16{margin-top:16px}.mt-20{margin-top:20px}.toast{position:fixed;top:20px;right:20px;z-index:1000;max-width:400px;min-width:300px;transform:translate(100%);opacity:0;transition:all .3s ease}.toast-visible{transform:translate(0);opacity:1}.toast-content{display:flex;align-items:center;gap:12px;padding:16px 20px;border-radius:8px;box-shadow:0 4px 12px #00000026;border:1px solid var(--border-color);background-color:var(--card-bg);color:var(--text-primary)}.toast-success{border-left:4px solid #28a745}.toast-error{border-left:4px solid #dc3545}.toast-info{border-left:4px solid var(--accent-primary)}.toast-icon{flex-shrink:0;color:var(--text-primary)}.toast-success .toast-icon{color:#28a745}.toast-error .toast-icon{color:#dc3545}.toast-info .toast-icon{color:var(--accent-primary)}.toast-message{flex:1;font-weight:500;line-height:1.4}.toast-close{flex-shrink:0;background:transparent;border:none;padding:4px;border-radius:4px;color:var(--text-muted);cursor:pointer;transition:all .2s ease;min-height:auto}.toast-close:hover{background-color:var(--bg-tertiary);color:var(--text-primary)}@media (max-width: 768px){.toast{top:10px;right:10px;left:10px;max-width:none;min-width:auto}.toast-content{padding:14px 16px}}*{transition:background-color .3s ease,color .3s ease,border-color .3s ease,box-shadow .3s ease}.button-container{display:flex;flex-direction:column;gap:20px;margin-top:24px}@media (min-width: 768px){.button-container{gap:24px}}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 20px;text-align:center}.empty-state-content h2{margin-bottom:16px;color:var(--text-secondary)}.empty-state-content p{margin-bottom:32px;color:var(--text-muted)}.maddys-list{display:flex;flex-direction:column;gap:20px;margin-bottom:32px}.maddy-card{background:var(--card-bg);border:1px solid var(--border-color);border-radius:12px;padding:20px;box-shadow:var(--card-shadow);transition:all .2s ease}.maddy-card:hover{box-shadow:0 4px 12px var(--shadow-medium);transform:translateY(-2px)}.maddy-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}.maddy-header h3{margin:0;font-size:1.2rem;font-weight:600;color:var(--text-primary)}.maddy-actions{display:flex;gap:8px}.action-btn{background:none;border:none;font-size:1.2rem;padding:8px;border-radius:8px;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center;min-width:40px;height:40px}.action-btn:hover{background:var(--bg-tertiary);transform:scale(1.1)}.action-btn.delete:hover{background:#ffebee;color:#d32f2f}[data-theme=dark] .action-btn.delete:hover{background:#3d1f1f;color:#ff6b6b}.maddy-info{margin-bottom:16px}.semester-info{margin:0;font-size:.9rem;color:var(--text-muted)}.class-info{display:flex;flex-direction:column;gap:8px}.class-item{display:flex;justify-content:space-between;align-items:flex-start;padding:8px 0;border-bottom:1px solid var(--border-light)}.class-item:last-child{border-bottom:none}.class-label{font-weight:500;color:var(--text-secondary);min-width:80px;text-align:left}.class-value{color:var(--text-primary);text-align:right;flex:1;margin-left:16px}.modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px}.modal-content{background:var(--card-bg);border-radius:12px;box-shadow:0 8px 32px var(--shadow-medium);max-width:500px;width:100%;max-height:90vh;overflow-y:auto}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:20px 24px;border-bottom:1px solid var(--border-color)}.modal-header h2{margin:0;font-size:1.3rem;color:var(--text-primary)}.close-btn{background:none;border:none;font-size:1.5rem;color:var(--text-muted);cursor:pointer;padding:4px;border-radius:4px;transition:all .2s ease}.close-btn:hover{color:var(--text-primary);background:var(--bg-tertiary)}.modal-body{padding:24px}.modal-actions{display:flex;gap:12px;justify-content:flex-end;margin-top:24px}.captcha-image-container{width:150px;height:50px;margin-bottom:8px;display:flex;align-items:center;justify-content:center;border:1px solid var(--border-color);background-color:var(--bg-tertiary);border-radius:4px;overflow:hidden}[data-theme=dark] .captcha-image-container{background-color:#fff}@media (max-width: 768px){.maddy-header{flex-direction:column;align-items:flex-start;gap:12px}.maddy-actions{align-self:flex-end}.class-item{flex-direction:column;gap:4px}.class-label{min-width:auto}.class-value{margin-left:0;text-align:left}.modal-content{margin:20px;max-height:calc(100vh - 40px)}.modal-actions{flex-direction:column}.modal-actions button{width:100%}}.attendance-container{display:flex;flex-direction:column;gap:20px}.attendance-card{background:var(--card-bg);border:1px solid var(--border-color);border-radius:12px;padding:20px;box-shadow:var(--card-shadow)}.course-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:16px;padding-bottom:12px;border-bottom:1px solid var(--border-light)}.course-name{font-size:18px;font-weight:600;color:var(--text-primary);margin:0;flex:1}.course-code{font-size:14px;color:var(--text-muted);background:var(--bg-tertiary);padding:4px 8px;border-radius:6px;margin-left:12px}.total-attendance-box{display:flex;justify-content:space-between;align-items:center;padding:12px;background:var(--bg-secondary);border-radius:8px;border:1px solid var(--border-light);margin-bottom:16px}.total-info{display:flex;flex-direction:column;gap:4px}.total-badge{background:var(--accent-primary);color:#fff;padding:4px 8px;border-radius:4px;font-size:12px;font-weight:600;text-align:center;min-width:60px}.total-label{font-size:14px;font-weight:500;color:var(--text-primary)}.total-stats{display:flex;flex-direction:column;align-items:flex-end;gap:4px}.total-percentage{font-size:18px;font-weight:700}.total-details{font-size:12px;color:var(--text-secondary)}.sections-container{display:flex;flex-direction:column;gap:12px}.section-item{display:flex;justify-content:space-between;align-items:center;padding:12px;background:var(--bg-secondary);border-radius:8px;border:1px solid var(--border-light)}.section-info{display:flex;align-items:center;gap:12px}.ltps-badge{background:var(--accent-primary);color:#fff;padding:4px 8px;border-radius:4px;font-size:12px;font-weight:600;min-width:24px;text-align:center}.section-name{font-size:14px;color:var(--text-primary);font-weight:500}.attendance-stats{display:flex;flex-direction:column;align-items:flex-end;gap:4px}.percentage{font-size:18px;font-weight:700}.attendance-details{display:flex;flex-direction:column;align-items:flex-end;gap:2px;font-size:12px;color:var(--text-secondary)}.absent-count{color:var(--text-muted)}@media (max-width: 768px){.course-header{flex-direction:column;align-items:flex-start;gap:8px}.course-code{margin-left:0}.total-attendance-box{flex-direction:column;align-items:flex-start;gap:12px}.total-stats{align-items:flex-start;width:100%}.section-item{flex-direction:column;align-items:flex-start;gap:8px}.attendance-stats{align-items:flex-start;width:100%}.attendance-details{align-items:flex-start}}.calculator-btn{padding:12px;border:1px solid var(--border-color);border-radius:6px;font-size:16px;font-weight:600;cursor:pointer;transition:all .2s ease;background:var(--bg-secondary);color:var(--text-primary)}.calculator-btn:hover{background:var(--bg-tertiary);border-color:var(--accent-primary)}.calculator-btn.number{background:var(--card-bg)}.calculator-btn.operation{background:var(--accent-primary);color:#fff;border-color:var(--accent-primary)}.calculator-btn.operation:hover{background:var(--accent-hover)}.calculator-btn.equals{background:var(--accent-secondary);color:#fff;border-color:var(--accent-secondary)}.calculator-btn.equals:hover{background:var(--accent-secondary-hover)}.calculator-btn.special{background:#ff6b6b;color:#fff;border-color:#ff6b6b}.calculator-btn.special:hover{background:#ff5252}.calculator-btn.secondary{background:var(--bg-tertiary);color:var(--text-secondary)}.calculator-btn.secondary:hover{background:var(--border-color)}.calculator-icon-btn{position:fixed;bottom:20px;right:20px;width:56px;height:56px;border-radius:50%;background:var(--accent-primary);color:#fff;border:none;box-shadow:0 4px 12px #0000004d;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:24px;transition:all .3s ease;z-index:100}.calculator-icon-btn:hover{background:var(--accent-hover);transform:scale(1.1);box-shadow:0 6px 16px #0006}.calculator-icon-btn:active{transform:scale(.95)}.timetable-container{display:flex;flex-direction:column;gap:24px;margin-bottom:32px}.no-classes{text-align:center;color:var(--text-muted);font-style:italic;padding:20px}
