@import"https://fonts.googleapis.com/css2?family=Montserrat:wght@300;400;500;600;700&family=Outfit:wght@300;400;500;600;700&family=Playfair+Display:ital,wght@0,400;0,700;1,400&family=Tinos:ital,wght@0,400;0,700;1,400&family=Science+Gothic:wght@300..700&display=swap";@import"https://fonts.googleapis.com/css2?family=Google+Sans:wght@400;500;700&display=swap";@import"https://fonts.googleapis.com/css2?family=Outfit:wght@300;400;500;600;700&display=swap";:root{--primary-blue: #0056b3;--primary-blue-hover: #004494;--secondary-blue: #e7f1ff;--text-dark: #1a1a1a;--text-gray: #666666;--bg-light: #f8f9fa;--bg-white: #ffffff;--border-color: #e0e0e0;--error-red: #dc3545;--success-green: #28a745;--shadow-sm: 0 2px 4px rgba(0, 0, 0, .05);--shadow-md: 0 4px 6px rgba(0, 0, 0, .1);--shadow-lg: 0 10px 15px rgba(0, 0, 0, .1);--font-sans: "Outfit", sans-serif;--font-serif: "Tinos", serif;--font-heading: "Montserrat", sans-serif;--font-size-h1: clamp(2rem, 5vw + 1rem, 3.5rem);--font-size-h2: clamp(1.5rem, 4vw + .5rem, 2.5rem);--font-size-h3: clamp(1.2rem, 3vw + .2rem, 1.8rem);--font-size-body: clamp(.9rem, 2vw + .5rem, 1.1rem);--spacing-container: clamp(1rem, 5vw, 2.5rem);--width-container: min(90%, 400px)}*{box-sizing:border-box;margin:0;padding:0}html,body,#root{height:100%;width:100%;margin:0;padding:0;overflow-x:hidden}body{font-family:var(--font-sans);background-color:var(--bg-light);color:var(--text-dark);line-height:1.6;-webkit-font-smoothing:antialiased}h1,h2,h3,h4,h5,h6{font-weight:600;color:var(--text-dark)}button{cursor:pointer;font-family:var(--font-sans)}.container{max-width:1200px;margin:0 auto;padding:0 20px}.card{background:var(--bg-white);border-radius:12px;padding:24px;box-shadow:var(--shadow-sm);transition:transform .2s ease,box-shadow .2s ease}.card:hover{transform:translateY(-2px);box-shadow:var(--shadow-md)}.btn{display:inline-flex;align-items:center;justify-content:center;padding:10px 20px;border-radius:8px;font-weight:500;border:none;transition:all .2s ease}.btn-primary{background-color:var(--primary-blue);color:#fff}.btn-primary:hover{background-color:var(--primary-blue-hover)}.btn-outline{background-color:transparent;border:1px solid var(--primary-blue);color:var(--primary-blue)}.btn-outline:hover{background-color:var(--secondary-blue)}.input-group{margin-bottom:16px}.input-label{display:block;margin-bottom:8px;font-weight:500;color:var(--text-gray)}.input-field{width:100%;padding:12px;border:1px solid var(--border-color);border-radius:8px;font-family:var(--font-sans);font-size:16px;transition:border-color .2s ease}.input-field:focus{outline:none;border-color:var(--primary-blue);box-shadow:0 0 0 3px var(--secondary-blue)}.page-layout{min-height:100vh;display:flex;flex-direction:column}.main-content{flex:1;padding:40px 0}.footer{background-color:var(--bg-white);border-top:1px solid var(--border-color);padding:20px 0;text-align:center;color:var(--text-gray);font-size:.9rem}.btn-outline-dim{border:none!important;transition:background-color .3s ease}.btn-outline-dim:hover{background-color:#fff3!important}.link-hover-underline{text-decoration:none!important;transition:opacity .2s}.link-hover-underline:hover{text-decoration:underline!important;opacity:.8}.custom-checkbox-container{display:flex;align-items:center;cursor:pointer;position:relative;padding-left:25px;-webkit-user-select:none;user-select:none}.custom-checkbox-container input{position:absolute;opacity:0;cursor:pointer;height:0;width:0}.checkmark{position:absolute;top:0;left:0;height:16px;width:16px;background-color:transparent;border:1px solid rgba(255,255,255,.6);border-radius:3px;transition:all .2s ease}.custom-checkbox-container:hover input~.checkmark{border-color:#ffffffe6}.custom-checkbox-container input:checked~.checkmark{background-color:transparent;border-color:#fff}.checkmark:after{content:"";position:absolute;display:none}.custom-checkbox-container input:checked~.checkmark:after{display:block}.custom-checkbox-container .checkmark:after{left:5px;top:1px;width:4px;height:9px;border:solid white;border-width:0 2px 2px 0;transform:rotate(45deg)}.dashboard-container{min-height:100dvh;width:100%;background-color:var(--bg-main);background-attachment:fixed;transition:background-color .3s ease,color .3s ease;display:flex;padding-top:env(safe-area-inset-top);padding-bottom:env(safe-area-inset-bottom);padding-left:env(safe-area-inset-left);padding-right:env(safe-area-inset-right)}.view-all{font-size:.9rem;color:var(--brand-blue);cursor:pointer;font-weight:500;padding:6px 12px;border-radius:20px;transition:background .2s}.view-all:hover{background-color:#e8f0fe}.course-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:24px}.course-card{background-color:var(--card-bg);border-radius:20px;padding:24px;box-shadow:0 2px 8px #0000000a;border:1px solid transparent;transition:all .3s cubic-bezier(.4,0,.2,1);position:relative;overflow:hidden}.course-card:hover{transform:translateY(-5px);box-shadow:0 12px 24px #00000014}.course-tag{font-size:.75rem;padding:6px 12px;border-radius:8px;display:inline-block;margin-bottom:16px;font-weight:600;letter-spacing:.02em}.tag-purple{background:var(--tag-bg-purple);color:var(--tag-text-purple)}.tag-orange{background:var(--tag-bg-orange);color:var(--tag-text-orange)}.tag-blue{background:var(--tag-bg-blue);color:var(--tag-text-blue)}.tag-green{background:var(--tag-bg-green);color:var(--tag-text-green)}.course-title{font-weight:600;font-size:var(--font-size-body);margin-bottom:16px;color:var(--text-primary);line-height:1.4}.course-meta{display:flex;align-items:center;gap:10px;font-size:.9rem;color:var(--text-secondary);margin-bottom:8px}.exam-table-container{background-color:var(--card-bg);border-radius:20px;padding:24px;box-shadow:0 2px 8px #0000000a;border:1px solid transparent}.exam-table{width:100%;border-collapse:separate;border-spacing:0 8px}.exam-table th{text-align:left;font-size:.8rem;color:var(--text-secondary);padding:0 16px 12px;font-weight:600;text-transform:uppercase;letter-spacing:.05em}.exam-table td{padding:16px;background-color:#f8f9fa;font-size:.95rem;color:var(--text-primary)}.exam-table tr td:first-child{border-top-left-radius:12px;border-bottom-left-radius:12px}.exam-table tr td:last-child{border-top-right-radius:12px;border-bottom-right-radius:12px}.status-badge{padding:6px 12px;border-radius:20px;font-size:.8rem;font-weight:600}.status-upcoming{background:var(--tag-bg-blue);color:var(--tag-text-blue)}.status-completed{background:var(--tag-bg-green);color:var(--tag-text-green)}.widget-card{background-color:var(--card-bg);border-radius:20px;padding:24px;box-shadow:0 2px 8px #0000000a}.calendar-widget{text-align:center}.calendar-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:15px}.calendar-header h4{margin:0;color:var(--text-primary)}.calendar-nav{display:flex;gap:5px}.calendar-nav-btn{background:transparent;border:none;cursor:pointer;padding:5px;color:var(--text-secondary)}.calendar-days-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:5px;font-size:.8rem;color:#64748b;text-align:center}.calendar-day-name{font-weight:700;padding-bottom:5px}.calendar-date{padding:8px 0;border-radius:50%;background:transparent;color:inherit;position:relative;cursor:pointer;display:flex;justify-content:center;align-items:center}.calendar-date.today{background:#1e293b;color:#fff}.calendar-date.selected{border:2px solid var(--brand-blue)}.calendar-event-dot{position:absolute;bottom:2px;width:4px;height:4px;border-radius:50%;background-color:#ef4444}[data-theme=dark] .calendar-days-grid{color:var(--text-secondary)}[data-theme=dark] .calendar-date.today{background:#4285f4;color:#fff}[data-theme=dark] .calendar-nav-btn{color:var(--text-primary)}[data-theme=dark] .search-bar{background-color:var(--bg-main);box-shadow:0 4px 15px #0000004d}[data-theme=dark] .search-bar:focus-within{box-shadow:0 4px 15px #000;border-color:transparent}[data-theme=dark] .search-bar input{color:var(--text-primary)}[data-theme=dark] .search-bar input::placeholder{color:var(--text-secondary)}.homework-item{padding:20px;border:1px solid transparent;border-radius:16px;margin-bottom:16px;background:#fff;box-shadow:0 2px 8px #00000008;transition:all .2s}.homework-item:hover{transform:scale(1.02);box-shadow:0 8px 16px #0000000f}.homework-header{display:flex;justify-content:space-between;margin-bottom:8px;align-items:center}.homework-subject{font-weight:600;font-size:.95rem;color:var(--text-primary)}.homework-status{font-size:.7rem;padding:4px 8px;border-radius:6px;font-weight:600;text-transform:uppercase}.status-not-started{background:#ffebee;color:#c62828}.status-in-progress{background:#fff3e0;color:#ef6c00}.homework-desc{font-size:.9rem;color:var(--text-secondary);margin-bottom:8px;line-height:1.4}.homework-date{font-size:.8rem;color:#747775;display:flex;align-items:center;gap:6px}.grade-report-container{width:100%;max-width:1200px;margin:0 auto;animation:fadeIn .5s ease-out}.grade-report-main-card{background:var(--bg-light);border-radius:24px;padding:30px;box-shadow:0 4px 20px #0000000d;border:none;margin-bottom:30px}[data-theme=dark] .grade-report-main-card{background:var(--bg-main);border:1px solid rgba(255,255,255,.02);box-shadow:0 4px 20px #0000000d}.grade-input-section{background:transparent;border:none;padding:0;margin-bottom:30px}.grade-input-group{display:grid;grid-template-columns:1fr 1fr 140px;gap:20px;align-items:end;margin-bottom:0}.grade-label{display:block;margin-bottom:8px;font-size:.85rem;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em}.grade-input,.grade-select{width:100%;padding:16px 20px;border:1px solid transparent;border-radius:16px;outline:none;font-size:1rem;background:#f0f2f5;color:var(--text-primary);transition:all .2s ease;font-family:Outfit,sans-serif}[data-theme=dark] .grade-input,[data-theme=dark] .grade-select{background:#252626;border-color:#ffffff1a}.grade-input:focus,.grade-select:focus{background:#fff;border-color:#b0b0b0;box-shadow:0 0 0 4px #0000000d}[data-theme=dark] .grade-input:focus,[data-theme=dark] .grade-select:focus{background:#2d2e2e;border-color:#ffffff4d;box-shadow:0 0 0 4px #ffffff0d}.grade-fetch-btn{width:100%;padding:18px;background:#333;color:#fff;border:none;border-radius:16px;font-size:1rem;font-weight:600;cursor:pointer;box-shadow:0 4px 12px #0000001a;transition:all .3s cubic-bezier(.4,0,.2,1);position:relative;overflow:hidden}[data-theme=dark] .grade-fetch-btn{background:#e6e6e6;color:#000;box-shadow:0 4px 12px #ffffff1a}.grade-fetch-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 8px 20px #0b57d066}.grade-fetch-btn:disabled{opacity:.7;cursor:not-allowed}.grade-result-container{margin-top:30px;animation:slideUp .5s ease-out}.grade-result-header{display:flex;gap:20px;margin-bottom:24px}.cgpa-card{flex:1;background:linear-gradient(135deg,#4285f4,#34a853);padding:24px;border-radius:20px;color:#fff;position:relative;overflow:hidden;box-shadow:0 8px 24px #34a85340}.cgpa-card:after{content:"";position:absolute;top:0;right:0;width:100%;height:100%;background:linear-gradient(rgba(255,255,255,.1),transparent);pointer-events:none}.cgpa-label{font-size:.9rem;opacity:.9;margin-bottom:4px;font-weight:500}.cgpa-value{font-size:3rem;font-weight:800;letter-spacing:-.02em}.download-btn{padding:0 30px;background:var(--card-bg);color:var(--text-primary);border:1px solid rgba(0,0,0,.1);border-radius:20px;cursor:pointer;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;transition:all .2s ease}[data-theme=dark] .download-btn{border-color:#ffffff1a;background:#ffffff0d;box-shadow:0 4px 12px #0000004d}.download-btn:hover{background:var(--bg-main);transform:translateY(-2px);box-shadow:0 4px 12px #0000001a}.grade-table-card{background:transparent;box-shadow:none;border:none;padding:0;overflow:visible}[data-theme=dark] .grade-table-card{background:transparent;border:none}.grade-table{width:100%;border-collapse:separate;border-spacing:0}.grade-table th{text-align:left;padding:16px;color:var(--text-secondary);font-size:.85rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;border-bottom:1px solid rgba(0,0,0,.05)}[data-theme=dark] .grade-table th{border-bottom-color:#ffffff0d}.grade-table td{padding:20px 16px;color:var(--text-primary);font-weight:500;border-bottom:1px solid rgba(0,0,0,.03)}[data-theme=dark] .grade-table td{border-bottom-color:#ffffff08}.grade-table tr:last-child td{border-bottom:none}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.grade-results-wrapper{display:grid;grid-template-columns:300px 1fr;gap:24px;align-items:start;background:transparent;box-shadow:none;border:none;padding:30px 0 0;margin-top:30px;border-top:1px solid rgba(0,0,0,.05)}.notifications-dropdown{position:absolute;top:70px;right:20px;width:320px;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:12px;box-shadow:0 8px 30px #0003;z-index:1000;overflow:hidden}.dropdown-header{padding:15px 20px;border-bottom:1px solid var(--border-color);background:var(--bg-light)}.dropdown-header h4{margin:0;font-size:1rem;color:var(--text-primary)}.dropdown-content{max-height:400px;overflow-y:auto}.notification-item{display:flex;gap:15px;padding:15px 20px;border-bottom:1px solid var(--border-color);transition:background .2s}.notification-item:last-child{border-bottom:none}.notification-item:hover{background:var(--bg-light)}.notif-icon{font-size:1.2rem}.notif-text h5{margin:0 0 5px;font-size:.95rem;color:var(--text-primary)}.notif-text p{margin:0 0 5px;font-size:.85rem;color:var(--text-secondary);line-height:1.4}.notif-time{font-size:.75rem;color:var(--text-tertiary)}.no-data{padding:30px;text-align:center;color:var(--text-secondary);font-style:italic}[data-theme=dark] .grade-results-wrapper{background:transparent;border:none;box-shadow:none;border-top-color:#ffffff1a}@media(max-width:900px){.grade-results-wrapper{grid-template-columns:1fr}}.student-info-card{background:transparent;box-shadow:none;border:none;padding:0}[data-theme=dark] .student-info-card{background:transparent;border:none}.info-row{display:flex;flex-direction:column;margin-bottom:16px;padding-bottom:16px;border-bottom:1px solid rgba(0,0,0,.05)}.student-details-header{margin-bottom:20px;color:#333}[data-theme=dark] .student-details-header{color:#e3e3e3}.greeting-text{color:var(--text-primary)}[data-theme=dark] .greeting-text{color:#69f0ae}.info-row{border-bottom-color:#ffffff0d}.info-row:last-child{border-bottom:none;margin-bottom:0;padding-bottom:0}.info-label{font-size:.75rem;text-transform:uppercase;letter-spacing:.05em;color:var(--text-secondary);font-weight:600;margin-bottom:4px}.info-value{font-size:1rem;color:var(--text-primary);font-weight:500;word-break:break-word}.grade-visuals{display:flex;gap:20px;margin-bottom:24px}.student-photo-card{flex:1;background:transparent;border-radius:20px;padding:0;display:flex;align-items:center;justify-content:center;position:relative;overflow:hidden;box-shadow:0 4px 12px #0000001a}.photo-wrapper{width:150px;height:150px;border-radius:50%;overflow:hidden;border:4px solid #ffffff;box-shadow:0 8px 24px #00000026}[data-theme=dark] .photo-wrapper{border-color:#2d2e2e;box-shadow:0 8px 24px #0000004d}.student-photo{width:100%;height:100%;object-fit:cover;object-position:top center}#printable-grade-report{position:fixed;top:0;left:0;z-index:-1;width:794px;min-height:1123px;background:#fff;color:#000;font-family:Playfair Display,serif}.print-container{padding:40px;border:2px solid #333;margin:20px;height:100%;box-sizing:border-box;display:flex;flex-direction:column}.print-header{text-align:center;margin-bottom:40px;border-bottom:2px solid #eee;padding-bottom:20px}.print-header h1{font-size:24px;color:#000;margin:0 0 10px;font-weight:700}.print-header h2{font-size:18px;color:#666;margin:0;font-weight:500;text-transform:uppercase;letter-spacing:2px}.print-section{margin-bottom:30px}.print-section h3{font-size:16px;color:#333;border-bottom:1px solid #333;padding-bottom:5px;margin-bottom:15px;text-transform:uppercase}.print-table{width:100%;border-collapse:collapse;font-size:12px}.print-table th{text-align:left;background:#f5f5f5;padding:8px;border-bottom:1px solid #ddd;font-weight:700;color:#000}.print-table td{padding:8px;border-bottom:1px solid #eee;color:#333}.print-label{font-weight:600;width:150px;color:#555}.print-footer{margin-top:auto;text-align:center;padding-top:20px;border-top:1px solid #eee}.print-cgpa{font-size:18px;font-weight:700;margin-bottom:20px;color:#000;font-family:Science Gothic,sans-serif}.print-brand{font-family:Montserrat,sans-serif;font-weight:700;font-size:12px;color:#000;opacity:.7}.circular-progress{position:relative;width:100px;height:100px;border-radius:50%;background:conic-gradient(#4285F4 var(--progress-deg, 0deg),rgba(0,0,0,.1) 0deg);display:flex;align-items:center;justify-content:center;transition:background .5s ease-out}.circular-progress:before{content:"";position:absolute;width:84px;height:84px;border-radius:50%;background:var(--bg-light)}[data-theme=dark] .circular-progress:before{background:var(--bg-main)}.circular-progress span{position:relative;font-size:1.5rem;font-weight:700;color:var(--text-primary);font-family:Science Gothic,sans-serif}[data-theme=dark] .circular-progress{background:conic-gradient(#69f0ae var(--progress-deg, 0deg),rgba(255,255,255,.1) 0deg)}.liquid-glass-panel{position:fixed;top:80px;right:20px;width:360px;max-height:500px;overflow-y:auto;border-radius:24px;z-index:1000;padding:20px;background:#ffffff1a;backdrop-filter:blur(5px) url(#container-glass);-webkit-backdrop-filter:blur(5px) url(#container-glass);will-change:transform;box-shadow:0 0 15px #0000000d,0 4px 10px #0000001a,inset 0 0 8px #0000001a,inset 0 0 15px #ffffff80;transition:all .3s ease;transform-origin:top right}.liquid-glass-panel.dragging{backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);background:#fff3;box-shadow:0 10px 25px #0003}[data-theme=dark] .liquid-glass-panel{background:#0003;box-shadow:0 0 15px #0003,0 4px 10px #0000004d,inset 0 0 8px #ffffff0d,inset 0 0 15px #ffffff1a}.liquid-glass-panel .dropdown-header{background:#ffffffe6;border-bottom:1px solid rgba(0,0,0,.05);margin:-20px -20px 15px;padding:15px 20px;border-radius:24px 24px 0 0}[data-theme=dark] .liquid-glass-panel .dropdown-header{background:#0009;border-bottom:1px solid rgba(255,255,255,.1)}.liquid-glass-panel .dropdown-header h4{color:var(--text-primary);font-weight:700;margin:0;text-shadow:0 1px 2px rgba(255,255,255,.5)}[data-theme=dark] .liquid-glass-panel .dropdown-header h4{text-shadow:0 1px 2px rgba(0,0,0,.5);color:#fff}.liquid-glass-panel .notification-item{background:#fff6;border-radius:12px;margin-bottom:8px;padding:12px;border:1px solid rgba(255,255,255,.3);transition:transform .2s ease,background .2s ease}[data-theme=dark] .liquid-glass-panel .notification-item{background:#1e1e1e66;border:1px solid rgba(255,255,255,.1)}.liquid-glass-panel .notification-item:hover{transform:scale(1.02);background:#fff9}[data-theme=dark] .liquid-glass-panel .notification-item:hover{background:#32323299}.dashboard-footer-container{position:fixed;bottom:0;left:0;width:100%;z-index:100;background-color:var(--bg-main)}.ai-chat-container{display:flex;flex-direction:column;height:100%;background-color:#fff;border-radius:0;box-shadow:none;overflow:hidden;border:none;font-family:Google Sans,Outfit,sans-serif}.ai-chat-header{padding:20px 40px;border-bottom:1px solid transparent;background-color:#fff;z-index:10}.ai-chat-header h3{margin:0 0 4px;color:#1f1f1f;font-size:1.25rem;font-weight:500}.ai-chat-header p{margin:0;color:#444746;font-size:.9rem}.ai-chat-messages{flex:1;padding:24px 40px;overflow-y:auto;display:flex;flex-direction:column;gap:32px;background-color:#fff}.message-wrapper{display:flex;gap:16px;max-width:85%}.message-user{align-self:flex-end;justify-content:flex-end}.message-ai{align-self:flex-start}.ai-avatar{width:32px;height:32px;flex-shrink:0;margin-top:4px}.ai-avatar svg{width:100%;height:100%;animation:spin-slow 10s linear infinite}@keyframes spin-slow{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.message-content{display:flex;flex-direction:column;max-width:100%}.message-bubble{font-size:1rem;line-height:1.6;position:relative;word-wrap:break-word}.message-user .message-bubble{background-color:#e8f0fe;color:#1f1f1f;padding:14px 24px;border-radius:24px 24px 4px;font-weight:500}.message-ai .message-bubble{background-color:transparent;color:#1f1f1f;padding:0;border:none;box-shadow:none}.message-time{font-size:.7rem;color:#8e918f;margin-top:6px;opacity:.8}.message-user .message-time{text-align:right;margin-right:4px}.message-user .message-footer{justify-content:flex-end}.ai-chat-input-area{padding:20px 40px;background-color:#fff;display:flex;justify-content:center;align-items:flex-end;position:relative}.input-wrapper{flex:1;display:flex;align-items:flex-end;background-color:#fff;border-radius:24px;padding:4px 12px;gap:8px;transition:box-shadow .2s;border:1px solid #e1e3e1}.input-wrapper:focus-within{background-color:#fff;border-color:#d3d3d3;box-shadow:0 1px 6px #0000001a}.ai-chat-input-area textarea{flex:1;background-color:transparent;border:none;border-radius:0;padding:8px;font-family:inherit;font-size:.95rem;resize:none;outline:none;max-height:150px;color:#1f1f1f;box-shadow:none;line-height:1.4}.ai-chat-input-area textarea:focus{background-color:transparent;border-color:transparent;box-shadow:none}.attach-btn{background-color:transparent;color:#444746;border:none;width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s;flex-shrink:0;margin:0 0 4px}.attach-btn:hover{background-color:#f0f4f9;color:#1f1f1f}.send-btn{position:static;background-color:transparent;color:#0b57d0;border:none;padding:6px 14px;width:auto;height:32px;border-radius:20px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:background-color .2s;flex-shrink:0;margin:0 0 4px;font-weight:500;font-size:.95rem}.send-btn:hover{background-color:#c2e7fd}.send-btn:disabled{color:#c4c7c5;background-color:transparent;cursor:not-allowed}.typing-indicator{display:flex;align-items:center;gap:6px;padding:10px 0}.typing-indicator span{width:8px;height:8px;background:linear-gradient(135deg,#4285f4,#9b72cb,#d96570);border-radius:50%;animation:bounce 1.4s infinite ease-in-out both}.typing-indicator span:nth-child(1){animation-delay:-.32s}.typing-indicator span:nth-child(2){animation-delay:-.16s}.message-bubble p{margin:0 0 16px}.message-bubble p:last-child{margin-bottom:0}.message-bubble ul,.message-bubble ol{margin:0 0 16px;padding-left:24px}.message-bubble li{margin-bottom:8px}.message-bubble h1,.message-bubble h2,.message-bubble h3{margin:24px 0 12px;font-weight:500;color:#1f1f1f}.message-bubble h1{font-size:1.5rem}.message-bubble h2{font-size:1.25rem}.message-bubble h3{font-size:1.1rem}.message-bubble h1:first-child,.message-bubble h2:first-child,.message-bubble h3:first-child{margin-top:0}.message-bubble code{background-color:#f0f4f9;padding:2px 6px;border-radius:4px;font-family:Roboto Mono,monospace;font-size:.9em;color:#1f1f1f}.message-bubble pre{background-color:#f0f4f9;padding:16px;border-radius:12px;overflow-x:auto;margin:16px 0;border:1px solid #e1e3e1}.message-bubble pre code{background-color:transparent;padding:0;color:#1f1f1f}.message-bubble strong{font-weight:600}.message-bubble a{color:#0b57d0;text-decoration:none}.message-bubble a:hover{text-decoration:underline}.ai-chat-messages::-webkit-scrollbar{width:8px}.ai-chat-messages::-webkit-scrollbar-track{background:transparent}.ai-chat-messages::-webkit-scrollbar-thumb{background-color:#dadce0;border-radius:4px}.ai-chat-messages::-webkit-scrollbar-thumb:hover{background-color:#bdc1c6}.drag-overlay{position:absolute;inset:0;background-color:#4285f41a;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:100;border:3px dashed #4285F4;border-radius:16px}.drag-content{text-align:center;color:#4285f4}.drag-content svg{width:64px;height:64px;margin-bottom:16px}.drag-content p{font-size:1.2rem;font-weight:500;margin:0}.image-preview-container{padding:0 40px 16px;background-color:#fff}.image-preview{position:relative;display:inline-block;max-width:200px;border-radius:12px;overflow:hidden;border:2px solid #e1e3e1}.image-preview img{width:100%;height:auto;display:block}.remove-image-btn{position:absolute;top:8px;right:8px;background-color:#0009;color:#fff;border:none;width:28px;height:28px;border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:background-color .2s}.remove-image-btn:hover{background-color:#000c}.remove-image-btn svg{width:16px;height:16px}.message-image{margin-bottom:12px;border-radius:12px;overflow:hidden;max-width:300px}.message-image img{width:100%;height:auto;display:block;border-radius:12px}.message-footer{display:flex;align-items:center;gap:12px;margin-top:6px}.model-badge{font-size:.7rem;color:#4285f4;background-color:#e8f0fe;padding:4px 10px;border-radius:12px;font-weight:500;display:inline-block}@media(max-width:768px){.ai-chat-messages{padding:16px 20px;gap:24px}.ai-chat-input-area{padding:16px 20px 20px}.send-btn{right:30px;bottom:32px}.message-wrapper{max-width:95%}.image-preview-container{padding:0 20px 8px}.image-preview{max-width:100px;border-radius:8px}.remove-image-btn{width:30px;height:30px;top:4px;right:4px}.remove-image-btn svg{width:14px;height:14px}.drag-content svg{width:48px;height:48px}.drag-content p{font-size:1rem}}.streaming-message{position:relative;display:inline-block}.cursor-blink{display:inline-block;color:#4285f4;animation:blink 1s step-end infinite;margin-left:2px;font-weight:700}@keyframes blink{0%,50%{opacity:1}51%,to{opacity:0}}.streaming-message p{display:inline}.streaming-message p:last-child{margin-bottom:0}.table-container{overflow-x:auto;margin:16px 0;border-radius:8px;border:1px solid #e1e3e1}.message-bubble table{width:100%;border-collapse:collapse;font-size:.9rem;background-color:#fff}.message-bubble th,.message-bubble td{padding:12px 16px;text-align:left;border-bottom:1px solid #f0f0f0}.message-bubble th{background-color:#f8f9fa;font-weight:600;color:#444746}.message-bubble tr:last-child td{border-bottom:none}.message-bubble tr:hover{background-color:#f8f9fa}.mermaid-container{display:flex;justify-content:center;background-color:#fff;padding:20px;border-radius:12px;margin:16px 0;border:1px solid #e1e3e1;overflow-x:auto}.mermaid-error{color:#d93025;padding:12px;background-color:#fce8e6;border-radius:8px;font-size:.9rem}.code-block-wrapper{margin:16px 0;border-radius:12px;overflow:hidden;border:1px solid #e1e3e1;background-color:#f0f4f9}.code-block-header{display:flex;justify-content:space-between;align-items:center;padding:8px 16px;background-color:#e1e3e1;color:#444746;font-size:.8rem;font-weight:500;text-transform:uppercase}.message-bubble pre{margin:0;border:none;border-radius:0;background-color:transparent}[data-theme=dark] .ai-chat-container,[data-theme=dark] .ai-chat-header,[data-theme=dark] .ai-chat-messages,[data-theme=dark] .ai-chat-input-area{background-color:var(--bg-main);color:var(--text-primary)}[data-theme=dark] .ai-chat-header h3,[data-theme=dark] .ai-chat-header p,[data-theme=dark] .message-bubble,[data-theme=dark] .ai-chat-input-area textarea{color:var(--text-primary)}[data-theme=dark] .input-wrapper{background-color:var(--card-bg);border-color:#444}[data-theme=dark] .input-wrapper:focus-within{background-color:var(--card-bg);border-color:#666}[data-theme=dark] .message-user .message-bubble{background-color:#2d3748;color:#e3e3e3}[data-theme=dark] .message-ai .message-bubble{color:#e3e3e3}[data-theme=dark] .code-block-wrapper{background-color:#2d2e2e;border-color:#444}[data-theme=dark] .code-block-header{background-color:#1e1f1f;color:#c4c7c5}[data-theme=dark] .message-bubble code{background-color:#2d2e2e;color:#e3e3e3}[data-theme=dark] .message-bubble pre{background-color:#2d2e2e;border-color:#444}[data-theme=dark] .message-bubble th{background-color:#2d2e2e;color:#e3e3e3;border-bottom-color:#444}[data-theme=dark] .message-bubble td{border-bottom-color:#444}[data-theme=dark] .table-container{border-color:#444}[data-theme=dark] .message-bubble table{background-color:transparent}[data-theme=dark] .attach-btn{color:#c4c7c5}[data-theme=dark] .attach-btn:hover{background-color:#ffffff1a;color:#e3e3e3}[data-theme=dark] .mermaid-container{background-color:#2d2e2e;border-color:#444}[data-theme=dark] .send-btn{color:#e3e3e3}:root{--wa-teal: #008069;--wa-teal-dark: #00a884;--wa-bg-light: #efeae2;--wa-bg-dark: #0b141a;--wa-sidebar-light: #ffffff;--wa-sidebar-dark: #111b21;--wa-header-light: #f0f2f5;--wa-header-dark: #202c33;--wa-bubble-sent-light: #d9fdd3;--wa-bubble-sent-dark: #005c4b;--wa-bubble-received-light: #ffffff;--wa-bubble-received-dark: #202c33;--wa-text-primary-light: #111b21;--wa-text-primary-dark: #e9edef;--wa-text-secondary-light: #667781;--wa-text-secondary-dark: #8696a0;--wa-border-light: #e9edef;--wa-border-dark: #222d34;--wa-input-bg-light: #ffffff;--wa-input-bg-dark: #2a3942}.user-chat-container{display:flex;height:calc(100vh - 100px);background:var(--wa-bg-light);border-radius:24px;overflow:hidden;box-shadow:0 10px 30px #0000001a;border:1px solid var(--wa-border-light);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica,Arial,sans-serif}[data-theme=dark] .user-chat-container{background:var(--wa-bg-dark);border-color:var(--wa-border-dark)}.chat-sidebar{width:30%;min-width:300px;border-right:1px solid var(--wa-border-light);display:flex;flex-direction:column;background:var(--wa-sidebar-light)}[data-theme=dark] .chat-sidebar{background:var(--wa-sidebar-dark);border-right-color:var(--wa-border-dark)}.chat-sidebar-header{padding:10px 16px;background:var(--wa-header-light);border-bottom:1px solid var(--wa-border-light);display:flex;flex-direction:column;gap:10px}[data-theme=dark] .chat-sidebar-header{background:var(--wa-header-dark);border-bottom-color:var(--wa-border-dark)}.chat-sidebar-header h3{margin:0;font-size:1.1rem;color:var(--wa-text-primary-light);font-weight:600}[data-theme=dark] .chat-sidebar-header h3{color:var(--wa-text-primary-dark)}.search-wrapper{position:relative;background:var(--wa-input-bg-light);border-radius:8px;padding:0}[data-theme=dark] .search-wrapper{background:var(--wa-header-dark)}.contact-search-input{width:100%;padding:8px 12px 8px 35px;border-radius:8px;border:none;background:var(--wa-header-light);color:var(--wa-text-primary-light);font-size:.9rem;outline:none;transition:all .2s}[data-theme=dark] .contact-search-input{background:var(--wa-input-bg-dark);color:var(--wa-text-primary-dark)}.contact-search-input:focus{box-shadow:none}.contacts-list{flex:1;overflow-y:auto}.contact-item{display:flex;align-items:center;gap:15px;padding:12px 16px;cursor:pointer;transition:background .2s;border-bottom:1px solid var(--wa-border-light)}[data-theme=dark] .contact-item{border-bottom-color:var(--wa-border-dark)}.contact-item:hover{background:var(--wa-header-light)}[data-theme=dark] .contact-item:hover{background:var(--wa-header-dark)}.contact-item.active{background:#f0f2f5}[data-theme=dark] .contact-item.active{background:#2a3942}.contact-avatar{width:49px;height:49px;border-radius:50%;background:#dfe5e7;color:#fff;display:flex;align-items:center;justify-content:center;font-weight:500;font-size:1.2rem;overflow:hidden}[data-theme=dark] .contact-avatar{background:#667781}.contact-info{flex:1;overflow:hidden;display:flex;flex-direction:column;justify-content:center}.contact-name{font-weight:400;font-size:1.05rem;color:var(--wa-text-primary-light);margin-bottom:4px}[data-theme=dark] .contact-name{color:var(--wa-text-primary-dark)}.chat-main{flex:1;display:flex;flex-direction:column;background-image:url(https://user-images.githubusercontent.com/15075759/28719144-86dc0f70-73b1-11e7-911d-60d70fcded21.png);background-color:var(--wa-bg-light);background-blend-mode:overlay;position:relative}[data-theme=dark] .chat-main{background-color:var(--wa-bg-dark);background-blend-mode:soft-light}.chat-header{padding:10px 16px;background:var(--wa-header-light);border-bottom:1px solid var(--wa-border-light);display:flex;align-items:center;gap:15px;z-index:10}[data-theme=dark] .chat-header{background:var(--wa-header-dark);border-bottom-color:var(--wa-border-dark)}.header-avatar{width:40px;height:40px;border-radius:50%;background:#dfe5e7;color:#fff;display:flex;align-items:center;justify-content:center;font-weight:500}[data-theme=dark] .header-avatar{background:#667781}.header-info h4{margin:0;font-size:1rem;color:var(--wa-text-primary-light);font-weight:500}[data-theme=dark] .header-info h4{color:var(--wa-text-primary-dark)}.chat-messages{flex:1;padding:20px 5%;overflow-y:auto;display:flex;flex-direction:column;gap:8px}.message-wrapper{display:flex;flex-direction:column;max-width:65%;position:relative}.message-wrapper.sent{align-self:flex-end;align-items:flex-end}.message-wrapper.received{align-self:flex-start;align-items:flex-start}.message-bubble{padding:6px 7px 8px 9px;border-radius:7.5px;font-size:.9rem;line-height:1.4;position:relative;box-shadow:0 1px .5px #00000021}.message-wrapper.sent .message-bubble{background:var(--wa-bubble-sent-light);color:var(--wa-text-primary-light);border-top-right-radius:0}[data-theme=dark] .message-wrapper.sent .message-bubble{background:var(--wa-bubble-sent-dark);color:var(--wa-text-primary-dark)}.message-wrapper.received .message-bubble{background:var(--wa-bubble-received-light);color:var(--wa-text-primary-light);border-top-left-radius:0}[data-theme=dark] .message-wrapper.received .message-bubble{background:var(--wa-bubble-received-dark);color:var(--wa-text-primary-dark)}.message-time{font-size:.68rem;color:var(--wa-text-secondary-light);margin-top:2px;text-align:right;float:right;margin-left:10px;position:relative;top:4px}[data-theme=dark] .message-time{color:var(--wa-text-secondary-dark)}.chat-input-area{padding:10px 16px;background:var(--wa-header-light);display:flex;align-items:center;gap:10px}[data-theme=dark] .chat-input-area{background:var(--wa-header-dark)}.chat-input-area input{flex:1;padding:9px 12px;border-radius:8px;border:none;background:var(--wa-input-bg-light);outline:none;color:var(--wa-text-primary-light);font-size:.95rem}[data-theme=dark] .chat-input-area input{background:var(--wa-input-bg-dark);color:var(--wa-text-primary-dark)}.chat-input-area button{width:40px;height:40px;border-radius:50%;border:none;background:transparent;color:var(--wa-text-secondary-light);display:flex;align-items:center;justify-content:center;cursor:pointer}.chat-input-area button:hover{background:#0000000d}.chat-input-area button svg{width:24px;height:24px;fill:currentColor}.chat-input-area button.send-btn,[data-theme=dark] .chat-input-area button.send-btn{color:var(--wa-teal-dark)}.no-chat-selected{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;background:var(--wa-header-light);border-bottom:6px solid #43c960;color:var(--wa-text-secondary-light)}[data-theme=dark] .no-chat-selected{background:var(--wa-bg-dark);color:var(--wa-text-secondary-dark);border-bottom-color:var(--wa-teal-dark)}@media(max-width:768px){.user-chat-container{height:calc(100vh - 140px);border-radius:0;border:none}.chat-sidebar,.chat-main{width:100%;min-width:0;flex:1}.chat-sidebar.hidden,.chat-main.hidden{display:none}.back-btn{background:transparent;border:none;color:var(--wa-text-primary-light);padding:8px;margin-right:5px;cursor:pointer;display:flex;align-items:center;justify-content:center}[data-theme=dark] .back-btn{color:var(--wa-text-primary-dark)}.back-btn svg{width:24px;height:24px}.message-wrapper{max-width:85%}}.syllabus-page-header{text-align:center;margin-bottom:20px}.syllabus-page-header h1{font-size:2.5rem;color:var(--text-primary);margin-bottom:5px;font-weight:700}.syllabus-page-header p{font-size:1.1rem;color:var(--text-secondary);font-style:italic;margin:0}.syllabus-tabs{display:flex;justify-content:center;gap:15px;margin-bottom:20px}.syllabus-tab{padding:12px 24px;border:none;background:transparent;color:var(--text-secondary);border-radius:12px;font-weight:600;cursor:pointer;transition:all .3s ease}.syllabus-tab.active{background:transparent;color:#ff6b6b;box-shadow:none;transform:none}.syllabus-item{background:transparent;border-radius:16px;margin-bottom:16px;border:none;overflow:hidden;transition:all .3s ease}.syllabus-item:hover{background:#ffffff05}.syllabus-item.expanded .syllabus-title,[data-theme=light] .syllabus-item.expanded .syllabus-title{color:#4dabf7}.syllabus-header{padding:20px 0;display:flex;justify-content:space-between;align-items:center;cursor:pointer;border-bottom:none}.syllabus-title-group{display:flex;align-items:center;gap:15px}.syllabus-code{background:rgba(var(--primary-rgb),.1);color:var(--primary-color);padding:6px 12px;border-radius:8px;font-size:.9rem;font-weight:600}.syllabus-title{margin:0;font-size:1.1rem;color:var(--text-primary)}.syllabus-meta{display:flex;align-items:center;gap:20px}.syllabus-credits{color:var(--text-secondary);font-size:.9rem}.syllabus-toggle-icon{font-size:1.5rem;color:var(--text-secondary);width:24px;height:24px;display:flex;align-items:center;justify-content:center;transition:transform .4s cubic-bezier(.68,-.55,.265,1.55),color .3s ease}.syllabus-toggle-icon.expanded{color:#ff6b6b;transform:rotate(135deg)}[data-theme=light] .syllabus-toggle-icon.expanded{color:#e03131}.syllabus-details{padding:0 20px 20px;border-top:none;animation:slideDown .3s ease-out}.syllabus-marks{display:flex;gap:10px;margin:20px 0}.mark-badge{padding:4px 12px;border-radius:6px;font-size:.85rem;font-weight:500}.mark-badge.cie{background:#ffc10726;color:#ffc107}.mark-badge.see{background:#4caf5026;color:#4caf50}.unit-card{background:#0003;border-radius:12px;padding:20px;margin-bottom:15px}.unit-header h4{color:var(--primary-color);margin:0 0 15px;font-size:1rem}.unit-part h5{color:var(--text-secondary);margin:10px 0;font-size:.95rem}.topic-list{list-style:none;padding:0;margin:0}.topic-list li{color:var(--text-secondary);padding:4px 0 4px 20px;position:relative;font-size:.9rem;line-height:1.5}.topic-list li:before{content:"•";color:var(--primary-color);position:absolute;left:0}.unit-parts{display:flex;gap:20px}.unit-part{flex:1}.topics-container{display:flex;gap:20px}.topics-column{flex:1}.syllabus-resources{margin-top:30px;display:flex;flex-direction:column;gap:20px}.resource-section{width:100%}.resource-section h4{color:var(--text-primary);margin-bottom:15px;border-bottom:2px solid var(--primary-color);display:inline-block;padding-bottom:5px}.resource-section ul{padding-left:20px;color:var(--text-secondary)}.resource-section li{margin-bottom:8px;font-size:.9rem}.project-card{background:transparent;border:none;padding:15px 0;border-bottom:1px solid rgba(255,255,255,.1);display:flex;justify-content:space-between;align-items:center;border-radius:0}.project-card:last-child{border-bottom:none}.project-header h3{margin:0 0 5px;color:var(--text-primary);font-size:1.1rem;display:flex;align-items:center;gap:10px}.project-code{color:var(--text-secondary);font-size:.9rem;font-weight:400}.project-meta{display:flex;gap:10px}.meta-badge{background:#ffffff1a;padding:6px 12px;border-radius:8px;font-size:.9rem;color:var(--text-primary)}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}@media(max-width:768px){.syllabus-resources{grid-template-columns:1fr}.syllabus-header{flex-direction:column;align-items:flex-start;gap:10px}.syllabus-meta{width:100%;justify-content:space-between}.project-card{flex-direction:column;align-items:flex-start;gap:15px}}.topic-list.ordered{list-style:decimal;padding-left:25px;margin-top:10px}.topic-list.ordered li{padding-left:5px;color:var(--text-secondary);margin-bottom:8px}.topic-list.ordered li:before{content:none}.marks-section{margin-bottom:30px}.marks-section h3{color:var(--text-primary);margin-bottom:15px;font-size:1.2rem}.table-responsive{overflow-x:auto;border-radius:12px;border:1px solid rgba(255,255,255,.1)}.marks-table{width:100%;border-collapse:collapse;background:#ffffff0d;color:var(--text-secondary)}.marks-table th,.marks-table td{padding:12px 16px;text-align:left;border-bottom:1px solid rgba(255,255,255,.1)}.marks-table th{background:#0003;color:var(--primary-color);font-weight:600;font-size:.95rem}.marks-table td{font-size:.9rem}.marks-table tr:last-child td{border-bottom:none}.marks-table tr:hover{background:#ffffff14}.code-col{font-family:monospace;color:var(--primary-color);font-weight:600}.projects-list h3{color:var(--text-primary);margin-bottom:15px;font-size:1.2rem}.syllabus-branch-vertical{position:fixed;right:0;left:auto;top:50%;transform:translateY(-50%) rotate(180deg);writing-mode:vertical-rl;background:transparent;color:#ffffff4d;padding:30px 10px;font-weight:800;font-size:1.1rem;border-radius:12px 0 0 12px;z-index:1000;letter-spacing:3px;text-transform:uppercase;cursor:default;pointer-events:none}[data-theme=light] .syllabus-branch-vertical{color:#0000004d}@media(max-width:768px){.syllabus-branch-vertical{display:none}}.schedule-container{padding:20px;height:100%;overflow-y:auto;color:var(--text-primary);font-family:var(--font-sans);scrollbar-width:thin;scrollbar-color:rgba(0,0,0,.2) transparent}.schedule-container::-webkit-scrollbar{width:6px}.schedule-container::-webkit-scrollbar-track{background:transparent}.schedule-container::-webkit-scrollbar-thumb{background-color:#0003;border-radius:20px}.schedule-header{margin-bottom:25px;display:flex;align-items:center;justify-content:space-between;border-bottom:1px solid rgba(0,0,0,.05);padding-bottom:15px}.schedule-title{margin:0;font-size:1.8rem;color:#000;font-family:var(--font-heading);font-weight:700;letter-spacing:-.5px}[data-theme=dark] .schedule-title{color:#fff}.schedule-card{background:#ffffffb3;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border-radius:16px;box-shadow:0 4px 6px -1px #0000000d,0 2px 4px -1px #00000008,inset 0 0 0 1px #ffffff80;overflow:hidden;border:1px solid rgba(255,255,255,.3);transition:box-shadow .3s ease}[data-theme=dark] .schedule-card{background:#1e1e1e99;border:1px solid rgba(255,255,255,.05);box-shadow:0 4px 20px #0003}.schedule-card:hover{box-shadow:0 10px 15px -3px #00000014,0 4px 6px -2px #0000000a,inset 0 0 0 1px #fff9}.table-responsive{overflow-x:auto}.schedule-table{width:100%;border-collapse:separate;border-spacing:0;min-width:700px}.schedule-table th{background-color:#0b57d00d;color:var(--brand-blue);padding:16px 20px;font-weight:600;text-align:left;font-size:.9rem;text-transform:uppercase;letter-spacing:.5px;border-bottom:1px solid rgba(0,0,0,.05)}[data-theme=dark] .schedule-table th{background-color:#ffffff0d;color:var(--text-primary);border-bottom:1px solid rgba(255,255,255,.05)}.schedule-table td{padding:16px 20px;font-size:.95rem;border-bottom:1px solid rgba(0,0,0,.03);color:var(--text-secondary);transition:background-color .2s ease}[data-theme=dark] .schedule-table td{border-bottom:1px solid rgba(255,255,255,.03)}.schedule-row{transition:transform .2s ease,background-color .2s ease}.schedule-row:hover td{background-color:#0b57d005}[data-theme=dark] .schedule-row:hover td{background-color:#ffffff05}.schedule-row:last-child td{border-bottom:none}.status-chip{display:inline-flex;align-items:center;padding:4px 10px;border-radius:20px;font-size:.8rem;font-weight:500;white-space:nowrap}.status-exam{background-color:#dc35451a;color:#dc3545;border:1px solid rgba(220,53,69,.2)}.status-holiday{background-color:#1987541a;color:#198754;border:1px solid rgba(25,135,84,.2)}.status-instruction{background-color:#0d6efd1a;color:#0d6efd;border:1px solid rgba(13,110,253,.2)}.status-event{background-color:#ffc1071a;color:#ffc107;border:1px solid rgba(255,193,7,.2)}[data-theme=dark] .status-event{color:#ffca2c}.row-highlight{background-color:#0b57d008}[data-theme=dark] .row-highlight{background-color:#ffffff08}@media(max-width:768px){.schedule-container{padding:15px}.schedule-title{font-size:1.5rem}.schedule-table th,.schedule-table td{padding:12px 15px}}.semester-progress-container{margin-bottom:30px;background:#0000000d;border-radius:12px;padding:15px;border:1px solid rgba(0,0,0,.05)}[data-theme=dark] .semester-progress-container{background:#ffffff0d;border:1px solid rgba(255,255,255,.05)}.progress-label{display:flex;justify-content:space-between;margin-bottom:8px;font-size:.9rem;font-weight:600;color:var(--text-secondary)}.progress-track{height:10px;background:#0000001a;border-radius:5px;overflow:hidden;position:relative}[data-theme=dark] .progress-track{background:#ffffff1a}.progress-fill{height:100%;background:linear-gradient(90deg,var(--brand-blue),#4285f4);border-radius:5px;transition:width 1s ease-in-out;position:relative}.progress-glow{position:absolute;top:0;right:0;bottom:0;width:20px;background:#ffffff80;filter:blur(5px);animation:progress-pulse 2s infinite}@keyframes progress-pulse{0%{opacity:.5;transform:translate(0)}50%{opacity:1;transform:translate(5px)}to{opacity:.5;transform:translate(0)}}.schedule-row.active-period{background-color:#0b57d014!important;position:relative;z-index:1;box-shadow:0 4px 12px #0b57d01a;border-left:4px solid var(--brand-blue)}[data-theme=dark] .schedule-row.active-period{background-color:#4285f426!important;box-shadow:0 4px 12px #4285f433;border-left:4px solid #4285f4}.active-indicator{display:inline-block;width:8px;height:8px;background-color:var(--brand-blue);border-radius:50%;margin-right:8px;animation:pulse 2s infinite}@keyframes pulse{0%{box-shadow:0 0 #0b57d066}70%{box-shadow:0 0 0 6px #0b57d000}to{box-shadow:0 0 #0b57d000}}.schedule-row{transform-style:preserve-3d;perspective:1000px}.schedule-row:hover{transform:scale(1.01) translateZ(10px);background-color:#fff;box-shadow:0 8px 20px #00000014;z-index:10;position:relative}[data-theme=dark] .schedule-row:hover{background-color:#2c2c2c;box-shadow:0 8px 20px #0000004d}.interactive-hover-button{position:relative;display:inline-flex;align-items:center;justify-content:center;gap:.5rem;width:10rem;height:3.5rem;padding:.5rem;background-color:var(--bg-white, #fff);border:1px solid var(--border-color, #e0e0e0);border-radius:9999px;cursor:pointer;overflow:hidden;transition:all .3s ease;font-family:var(--font-sans, sans-serif);font-weight:600;color:var(--text-dark, #1a1a1a)}.interactive-hover-button:disabled{opacity:.6;cursor:not-allowed}[data-theme=dark] .interactive-hover-button{background-color:transparent;border-color:#000;color:#fff}.interactive-hover-button .button-text{display:inline-block;transition:all .3s ease;transform:translate(0);opacity:1}.interactive-hover-button:hover:not(:disabled) .button-text{transform:translate(3rem);opacity:0}.interactive-hover-button .button-icon-container{position:absolute;top:0;left:0;width:100%;height:100%;display:flex;align-items:center;justify-content:center;gap:.5rem;opacity:0;transform:translate(-3rem);transition:all .3s ease;color:#fff;z-index:10}.interactive-hover-button:hover:not(:disabled) .button-icon-container{opacity:1;transform:translate(0)}.interactive-hover-button .button-background{position:absolute;left:20%;top:40%;width:.5rem;height:.5rem;background-color:var(--primary-blue, #0056b3);border-radius:50%;transform:scale(1);transition:all .3s ease;z-index:0}.interactive-hover-button:hover:not(:disabled) .button-background{left:0;top:0;width:100%;height:100%;border-radius:0;transform:scale(1.8)}:root{--sidebar-bg: transparent;--sidebar-text: #444746;--sidebar-text-active: #0b57d0;--sidebar-bg-active: #e8f0fe;--bg-main: #ffffff;--card-bg: #f8f9fa;--text-primary: #1f1f1f;--text-secondary: #444746;--brand-blue: #0b57d0;--brand-blue-hover: #0842a0;--tag-bg-blue: #c2e7ff;--tag-text-blue: #001d35;--tag-bg-purple: #e8def8;--tag-text-purple: #1d192b;--tag-bg-green: #c4eed0;--tag-text-green: #072711;--tag-bg-orange: #ffdbcf;--tag-text-orange: #2b150f}[data-theme=dark]{--bg-main: #121212;--sidebar-bg: transparent;--sidebar-text: #e3e3e3;--card-bg: #1e1e1e;--text-primary: #e3e3e3;--text-secondary: #a0a0a0;--sidebar-bg-active: #2c2c2c}.theme-toggle-new{width:70px;height:34px;background-color:#87ceeb;border-radius:34px;position:relative;cursor:pointer;transition:background-color .5s ease,box-shadow .5s ease,border-color .5s ease;box-shadow:inset 0 2px 5px #00000059,inset 0 -2px 5px #fff6,0 4px 10px #0000001a;overflow:hidden;border:2px solid rgba(255,255,255,.6)}.theme-toggle-new.dark{background-color:#1a1b26;border-color:#fff9;box-shadow:inset 0 3px 6px #000000b3,inset 0 -1px 2px #fff3,0 0 10px #ffffff0d}.toggle-spot{position:absolute;top:3.5px;left:4px;width:24px;height:24px;border-radius:50%;background-color:#fdb813;border:1px solid rgba(255,255,255,.805);transition:transform .5s cubic-bezier(.68,-.55,.27,1.55),background-color .5s ease,box-shadow .5s ease,border-color .5s ease;box-shadow:0 0 10px #fdb813cc,0 0 0 6px #fdb8134d,0 0 0 12px #fdb81333,0 0 0 18px #fdb8131a,0 0 0 24px #fdb8130d;z-index:10;overflow:visible}.toggle-spot:before,.toggle-spot:after{display:none}.theme-toggle-new.dark .toggle-spot{transform:translate(36px);background-color:#fbfcfe;border-color:transparent;box-shadow:0 0 10px #fff6,inset -4px -2px #9aa0a8,0 0 0 6px #fff3,0 0 0 12px #ffffff26,0 0 0 18px #ffffff1a,0 0 0 24px #ffffff0d}.crater{position:absolute;background-color:#9aa0a8;border-radius:50%;opacity:0;transition:opacity .3s ease;box-shadow:0 0 8px 2px #fff}.crater-1{width:8px;height:8px;top:4px;left:8px}.crater-2{width:4px;height:4px;top:14px;left:14px}.crater-3{width:3px;height:3px;top:12px;left:4px}.theme-toggle-new.dark .crater{opacity:1}.toggle-cloud{position:absolute;background:#fff;border-radius:10px;opacity:1;transition:transform .5s ease,opacity .3s ease;box-shadow:0 2px 4px #0000001a}.cloud-1{width:22px;height:12px;top:12px;left:38px;z-index:5}.cloud-2{width:16px;height:10px;top:20px;left:52px;z-index:4}.cloud-3{width:14px;height:8px;top:8px;left:54px;z-index:6}.cloud-4,.cloud-5{display:none}.theme-toggle-new.dark .toggle-cloud{transform:translateY(20px) scale(.5);opacity:0}.toggle-star{position:absolute;background:#fff;clip-path:polygon(50% 0%,65% 40%,100% 50%,65% 60%,50% 100%,35% 60%,0% 50%,35% 40%);opacity:0;transition:opacity .5s ease .2s,transform .5s ease;transform:translateY(-10px) rotate(-45deg);box-shadow:none;border-radius:0}.star-1{width:8px;height:8px;top:8px;left:8px}.star-2{width:6px;height:6px;top:18px;left:20px}.star-3{width:5px;height:5px;top:10px;left:29px}.star-4{width:9px;height:9px;top:15px;left:45px}.star-5{width:4px;height:4px;top:24px;left:35px}.star-6{width:5px;height:5px;top:4px;left:20px}.theme-toggle-new.dark .toggle-star{opacity:1;transform:translateY(0) rotate(0)}body{background-color:var(--bg-main);font-family:Outfit,sans-serif;overflow-x:hidden;color:var(--text-primary);min-height:100vh;background-attachment:fixed}.dashboard-container{min-height:100vh;background-color:var(--bg-main);background-attachment:fixed;transition:background-color .3s ease,color .3s ease;display:flex;width:100%}.sidebar{position:fixed;top:0;left:0;height:100vh;z-index:1000;width:260px;background:#fff9;backdrop-filter:blur(20px) saturate(180%);-webkit-backdrop-filter:blur(20px) saturate(180%);color:var(--sidebar-text);display:flex;flex-direction:column;padding:20px 16px;flex-shrink:0;transition:width .3s cubic-bezier(.4,0,.2,1),background-color .3s ease,color .3s ease;overflow:hidden;border-right:none;box-shadow:none;-webkit-mask-image:linear-gradient(to right,black 70%,transparent 100%);mask-image:linear-gradient(to right,black 70%,transparent 100%)}[data-theme=dark] .sidebar{background:#14141499;border-right:none;box-shadow:none;-webkit-mask-image:linear-gradient(to right,black 70%,rgba(0,0,0,.8) 80%,rgba(0,0,0,.4) 90%,transparent 100%);mask-image:linear-gradient(to right,black 70%,rgba(0,0,0,.8) 80%,rgba(0,0,0,.4) 90%,transparent 100%)}.sidebar.collapsed{width:70px;padding:20px 10px;background:transparent!important;backdrop-filter:none!important;-webkit-backdrop-filter:none!important;mask-image:none!important;-webkit-mask-image:none!important;box-shadow:none!important}.sidebar.collapsed .nav-section{display:block}.sidebar.collapsed .nav-title{display:none}.sidebar.collapsed .nav-item{padding:7px 0;justify-content:center;gap:0}.sidebar-logo-container{display:flex;align-items:center;padding-left:5px;margin-bottom:30px;cursor:pointer;transition:padding-left .3s cubic-bezier(.4,0,.2,1)}.sidebar-logo-container img{width:30px;height:30px}.sidebar.collapsed .sidebar-logo-container{padding-left:26px;padding-right:0;padding-top:10px;justify-content:flex-start}.header-brand-text{font-family:Outfit,sans-serif;font-size:1.5rem;font-weight:700;color:#333;margin-right:20px;margin-left:-20px;line-height:1;padding-top:1px}[data-theme=dark] .sidebar-logo-container img{filter:brightness(1.5) saturate(1.5)}[data-theme=dark] .header-brand-text{color:#ff6b6b!important}.logo-text{transition:opacity .3s cubic-bezier(.4,0,.2,1),max-width .3s cubic-bezier(.4,0,.2,1);opacity:1;max-width:200px;overflow:hidden}.sidebar.collapsed .logo-text{opacity:0;max-width:0;margin:0}.nav-section{margin-bottom:32px}.nav-title{font-size:.75rem;text-transform:uppercase;letter-spacing:.08em;margin-bottom:12px;font-weight:600;color:#747775;padding-left:12px;white-space:nowrap;transition:opacity .2s ease,height .2s ease,margin .2s ease;opacity:1;height:auto;overflow:hidden}.sidebar.collapsed .nav-title{opacity:0;visibility:hidden;white-space:nowrap}.nav-item{display:flex;align-items:center;gap:16px;padding:12px 16px;border-radius:50px;cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1);color:var(--sidebar-text);text-decoration:none;font-size:.95rem;font-weight:500;margin-bottom:4px;white-space:nowrap;overflow:hidden;border:1px solid transparent}.nav-text{transition:opacity .3s cubic-bezier(.4,0,.2,1),max-width .3s cubic-bezier(.4,0,.2,1);opacity:1;max-width:200px}.sidebar.collapsed .nav-text{opacity:0;max-width:0}.nav-item:hover{background-color:#e8f3ff;color:#1e1f1f;transform:translate(4px)}.nav-item.active{font-weight:600;position:relative}.nav-item-dashboard.active{background-color:#e8f0fe;color:#0b57d0}.nav-item-schedule.active{background-color:#e6f4ea;color:#137333}.nav-item-exams.active{background-color:#f3e8fd;color:#9334e6}.nav-item-homework.active{background-color:#feefc3;color:#ea8600}.nav-item-grades.active{background-color:#e0f2f1;color:#00695c}.nav-item-ai.active{background-color:#e8eaf6;color:#3f51b5}.nav-item-settings:active,.nav-item-settings.active{background-color:#f1f3f4;color:#5f6368}[data-theme=dark] .nav-item:hover{background-color:transparent!important}[data-theme=dark] .nav-item-dashboard:hover{border-color:#e8f0fe;color:#e8f0fe}[data-theme=dark] .nav-item-schedule:hover{border-color:#e6f4ea;color:#e6f4ea}[data-theme=dark] .nav-item-exams:hover{border-color:#f3e8fd;color:#f3e8fd}[data-theme=dark] .nav-item-homework:hover{border-color:#feefc3;color:#feefc3}[data-theme=dark] .nav-item-grades:hover{border-color:#e0f2f1;color:#e0f2f1}[data-theme=dark] .nav-item-ai:hover{border-color:#e8eaf6;color:#e8eaf6}[data-theme=dark] .nav-item-settings:hover{border-color:#f1f3f4;color:#f1f3f4}.sidebar.collapsed .nav-item:hover{transform:none}.nav-item.active:before{display:none}.nav-item svg{width:22px;height:22px}.main-content{flex:1;display:flex;flex-direction:column;overflow:hidden;background-color:var(--bg-main);margin-left:80px;transition:margin-left .3s ease}.dashboard-footer{font-family:Outfit,sans-serif;font-size:.85rem;color:var(--text-secondary)}[data-theme=dark] .dashboard-footer{color:#fff6}.top-header{height:auto;background-color:transparent;display:flex;align-items:center;justify-content:space-between;padding:0 20px 10px;flex-shrink:0;margin-top:-15px}.search-bar{display:flex;align-items:center;background-color:#fff;padding:8px 20px;border-radius:28px;width:400px;box-shadow:0 1px 3px #00000017;border:1px solid transparent;transition:all .2s ease}.search-bar:focus-within{box-shadow:0 4px 12px #0000001a;border-color:#e0e0e0}.search-bar input{border:none;background:transparent;margin-left:12px;outline:none;width:100%;color:var(--text-primary);font-size:.95rem}.search-bar svg{width:20px;height:20px;color:var(--text-secondary);flex-shrink:0}.header-actions{display:flex;align-items:center;gap:16px}.icon-btn{background:#fff;border:none;width:42px;height:42px;border-radius:12px;display:flex;align-items:center;justify-content:center;cursor:pointer;color:#444746;transition:all .3s ease;position:relative;box-shadow:0 4px 12px #0000000d;--btn-bg: #ffffff}.icon-btn svg{width:22px;height:22px}.icon-btn:hover,.icon-btn.active{background:#f0f2f5;color:#1a1a1a;transform:translateY(-2px);box-shadow:0 6px 16px #0000001a;--btn-bg: #f0f2f5}[data-theme=dark] .icon-btn{background:#2d2e2e;color:#e3e3e3;box-shadow:0 4px 12px #0003;--btn-bg: #2d2e2e}[data-theme=dark] .icon-btn:hover,[data-theme=dark] .icon-btn.active{background:#333;color:#fff;--btn-bg: #333333}.user-profile{width:32px;height:32px;border-radius:50%;background:linear-gradient(135deg,#4285f4,#34a853);display:flex;align-items:center;justify-content:center;color:#fff;font-weight:600;font-size:1.1rem;box-shadow:0 2px 5px #0000001a}.content-scroll{flex:1;overflow-y:auto;padding:10px var(--spacing-container) 40px var(--spacing-container);display:flex;gap:40px}.center-panel{flex:2;min-width:0;display:flex;flex-direction:column;gap:32px}.right-panel{flex:1;min-width:320px;max-width:380px;display:flex;flex-direction:column;gap:32px}.welcome-banner{background:linear-gradient(120deg,#00c3ff,#c491ff);border-radius:24px;padding:var(--spacing-container);position:relative;overflow:hidden;color:#fff;box-shadow:0 10px 30px #4285f440;transition:transform .3s ease}.welcome-banner:hover{transform:translateY(-2px)}.banner-content h1{font-size:var(--font-size-h2);color:#fff;margin-bottom:12px;font-weight:600;letter-spacing:-.02em}.banner-content p{color:#ffffffe6;max-width:600px;line-height:1.6;font-size:1.05rem}.section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}.section-header h3{font-size:var(--font-size-h3);color:var(--text-primary);font-weight:600;letter-spacing:-.01em}
