@import"https://fonts.googleapis.com/css2?family=Outfit:wght@300;400;500;600;700&family=Inter:wght@300;400;500;600;700&display=swap";.attendance-page-wrapper{display:flex;justify-content:center;align-items:flex-start;padding:40px 20px;min-height:calc(100vh - 80px)}.attendance-main-card{background:#14141499;backdrop-filter:blur(24px);-webkit-backdrop-filter:blur(24px);border:1px solid rgba(255,255,255,.1);border-radius:24px;padding:40px;width:100%;max-width:1100px;box-shadow:0 20px 40px #0006}.attendance-header-section{text-align:center;margin-bottom:40px}.attendance-header-section h1{font-size:2.5rem;font-weight:700;margin-bottom:8px;background:linear-gradient(135deg,#fff,#cbd5e1);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;display:flex;align-items:center;justify-content:center;gap:12px}.attendance-header-section p{color:#888;font-size:1.1rem}.attendance-table-container{background:#0003;border-radius:20px;border:1px solid rgba(255,255,255,.05);overflow-x:auto}.attendance-modern-table{width:100%;border-collapse:collapse}.attendance-modern-table th{padding:16px 12px;text-align:center;font-size:.8rem;font-weight:700;color:#999;text-transform:uppercase;border-bottom:1px solid rgba(255,255,255,.05);background:#ffffff05}.attendance-modern-table td{padding:14px 12px;color:#ccc;border-bottom:1px solid rgba(255,255,255,.03);font-size:.85rem;text-align:center}.attendance-modern-table tr:last-child td{border-bottom:none}.attendance-modern-table .course-code-cell{font-weight:700;color:#fff}.attendance-modern-table .course-name-cell{font-weight:600;color:#ddd;text-align:left}.attendance-modern-table .percentage-cell{font-weight:700}.attendance-good{color:#4ade80!important}.attendance-medium{color:#facc15!important}.attendance-low{color:#f87171!important}.attendance-view-toggle{display:flex;justify-content:center;margin-bottom:40px}.attendance-toggle-wrapper{background:#ffffff08;padding:8px 16px;border-radius:99px;display:flex;align-items:center;gap:16px;border:1px solid rgba(255,255,255,.05)}.attendance-toggle-label{font-size:.9rem;color:#666;font-weight:500;transition:color .3s}.attendance-toggle-label.active{color:#fff}.switch{position:relative;display:inline-block;width:44px;height:24px}.switch input{opacity:0;width:0;height:0}.slider{position:absolute;cursor:pointer;inset:0;background-color:#ffffff1a;transition:.4s;border-radius:24px}.slider:before{position:absolute;content:"";height:18px;width:18px;left:3px;bottom:3px;background-color:#7c3aed;transition:.4s;border-radius:50%;box-shadow:0 0 10px #7c3aed80}input:checked+.slider:before{transform:translate(20px)}.detailed-view-title{text-align:center;color:#fff;font-size:1.5rem;font-weight:700;margin-top:40px;margin-bottom:20px}.short-text{display:none}@media(max-width:900px){.attendance-page-wrapper{padding:20px 5px}.attendance-main-card{padding:15px 5px}.attendance-modern-table th:nth-child(10),.attendance-modern-table td:nth-child(10){display:none}.attendance-modern-table{font-size:.65rem;table-layout:auto;width:100%}.attendance-modern-table td,.attendance-modern-table th{padding:8px 3px;white-space:normal;word-wrap:break-word}.attendance-modern-table th{letter-spacing:-.2px}.attendance-modern-table .course-name-cell{min-width:65px;max-width:90px;line-height:1.3;text-align:left}.full-text{display:none}.short-text{display:inline}}.attendance-sync-wrapper{display:flex;justify-content:center;align-items:center;min-height:calc(100vh - 100px);width:100%;padding:20px}.attendance-sync-card{background:#141419b3;backdrop-filter:blur(24px);-webkit-backdrop-filter:blur(24px);border:1px solid rgba(255,255,255,.1);border-radius:32px;padding:60px 40px;width:100%;max-width:480px;text-align:center;box-shadow:0 40px 100px #00000080;position:relative;overflow:hidden}.attendance-sync-card:before{content:"";position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,transparent,var(--primary),transparent)}.sync-icon-container{margin-bottom:32px;display:flex;justify-content:center;align-items:center}.sync-glow-ring{padding:20px;border-radius:50%;background:#3b82f60d;border:1px solid rgba(59,130,246,.1);box-shadow:0 0 30px #3b82f61a}.sync-title{font-size:2rem;font-weight:700;margin-bottom:16px;background:linear-gradient(135deg,#fff,#cbd5e1);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}.sync-description{color:#94a3b8;font-size:1.05rem;line-height:1.6;margin-bottom:32px}.sync-status-indicator{display:inline-flex;align-items:center;gap:10px;padding:8px 16px;background:#ffffff0d;border-radius:99px;border:1px solid rgba(255,255,255,.05);margin-bottom:32px}.sync-dot{width:8px;height:8px;background-color:var(--primary);border-radius:50%;box-shadow:0 0 8px var(--primary);animation:sync-pulse 1.5s infinite}@keyframes sync-pulse{0%{transform:scale(1);opacity:1}50%{transform:scale(1.5);opacity:.5}to{transform:scale(1);opacity:1}}.sync-status-text{font-size:.85rem;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:1px}.sync-retry-btn{width:100%;padding:14px;background:var(--primary);color:#fff;border:none;border-radius:14px;font-weight:600;font-size:1rem;cursor:pointer;transition:all .3s ease;box-shadow:0 4px 12px #3b82f633}.sync-retry-btn:hover{filter:brightness(1.1);transform:translateY(-2px);box-shadow:0 8px 20px #3b82f64d}@media(max-width:500px){.attendance-sync-card{padding:40px 20px;border-radius:24px}.sync-title{font-size:1.5rem}.sync-description{font-size:.95rem}}.modal-overlay{position:fixed;bottom:32px;right:32px;display:flex;align-items:flex-end;justify-content:flex-end;z-index:2000;pointer-events:none}.modal-content{background:#171717f2;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border:1px solid rgba(255,255,255,.1);border-radius:20px;padding:24px;max-width:400px;width:auto;box-shadow:0 20px 40px -10px #00000080;animation:modalSlideIn .5s cubic-bezier(.16,1,.3,1);position:relative;overflow:hidden;pointer-events:auto}.modal-content:before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:linear-gradient(90deg,#6366f1,#a855f7,#ec4899)}.modal-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:20px}.modal-header h2{margin:0;font-size:1.5rem;color:#fff;font-weight:700;letter-spacing:-.025em}.close-button{background:#ffffff0d;border:none;color:#94a3b8;font-size:1.25rem;cursor:pointer;transition:all .2s;width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;margin-top:-4px;margin-right:-4px}.close-button:hover{background:#ffffff1a;color:#fff}.modal-body{color:#94a3b8;line-height:1.6;font-size:1.05rem}.modal-footer{margin-top:32px;display:flex;justify-content:flex-end}.primary-button{background:linear-gradient(135deg,#6366f1,#a855f7);color:#fff;border:none;padding:12px 28px;border-radius:12px;font-weight:600;cursor:pointer;transition:all .2s cubic-bezier(.16,1,.3,1);box-shadow:0 4px 15px #6366f14d}.primary-button:hover{transform:translateY(-2px);box-shadow:0 8px 25px #6366f166;filter:brightness(1.1)}.primary-button:active{transform:translateY(0)}@keyframes modalSlideIn{0%{transform:translate(100%) scale(.9);opacity:0}to{transform:translate(0) scale(1);opacity:1}}.gpa-page-wrapper{display:flex;justify-content:center;align-items:flex-start;padding:40px 20px;min-height:calc(100vh - 80px)}.gpa-card{background:#14141499;backdrop-filter:blur(24px);-webkit-backdrop-filter:blur(24px);border:1px solid rgba(255,255,255,.1);border-radius:24px;padding:40px;width:100%;max-width:1000px;box-shadow:0 20px 40px #0006}.gpa-header-section{text-align:center;margin-bottom:40px}.gpa-header-section h1{font-size:2.5rem;font-weight:700;margin-bottom:8px;background:linear-gradient(135deg,#fff,#cbd5e1);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}.gpa-header-section p{color:#888;font-size:1.1rem}.summary-cards-row{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-bottom:40px}.gpa-summary-card{background:#ffffff08;border:1px solid rgba(255,255,255,.05);border-radius:16px;padding:24px;text-align:center;transition:transform .3s ease}.gpa-summary-card:hover{transform:translateY(-5px);background:#ffffff0d}.summary-label{font-size:.85rem;font-weight:600;text-transform:uppercase;color:#888;margin-bottom:12px;letter-spacing:1px}.summary-value{font-size:2.2rem;font-weight:700;color:var(--primary)}.summary-value.gpa-accent{color:var(--success)}.summary-value.courses-accent{color:var(--accent)}.table-section-glass{background:#0003;border-radius:20px;border:1px solid rgba(255,255,255,.05);overflow:hidden}.gpa-modern-table{width:100%;border-collapse:collapse}.gpa-modern-table th{padding:20px;text-align:left;font-size:.85rem;font-weight:700;color:#999;text-transform:uppercase;border-bottom:1px solid rgba(255,255,255,.05);background:#ffffff05}.gpa-modern-table td{padding:16px 20px;color:#ccc;border-bottom:1px solid rgba(255,255,255,.03);font-size:.95rem}.gpa-modern-table tr:last-child td{border-bottom:none}.sem-badge{display:inline-flex;align-items:center;justify-content:center;width:28px;height:28px;background:#ffffff1a;border-radius:50%;font-size:.8rem;font-weight:700;color:#fff}.course-code-cell{font-weight:600;color:#aaa}.course-name-cell{font-weight:500;color:#eee}.credits-badge-modern{background:#3b82f626;color:var(--primary);padding:4px 12px;border-radius:8px;font-weight:700;font-size:.9rem}.grade-cell{font-weight:700;color:#eee;text-align:right}.completed-badge{color:#888;font-weight:500;font-size:.9rem}@media(max-width:768px){.gpa-page-wrapper{padding:20px 8px}.gpa-card{padding:20px 10px;border-radius:16px}.gpa-header-section h1{font-size:1.6rem}.gpa-header-section p{font-size:.9rem}.summary-cards-row{grid-template-columns:1fr;gap:10px;margin-bottom:25px}.gpa-summary-card{padding:12px 16px;display:flex;justify-content:space-between;align-items:center;text-align:left}.summary-label{font-size:.7rem;margin-bottom:0}.summary-value{font-size:1.3rem}.table-section-glass{overflow-x:hidden;background:#0003;border-radius:12px}.gpa-modern-table{min-width:100%;table-layout:fixed}.full-text{display:none}.short-text{display:inline}.gpa-modern-table th{padding:12px 4px;font-size:.65rem;letter-spacing:0;text-align:center}.gpa-modern-table td{padding:10px 4px;font-size:.75rem;text-align:center}.gpa-modern-table th:nth-child(1),.gpa-modern-table td:nth-child(1){width:12%}.gpa-modern-table th:nth-child(2),.gpa-modern-table td:nth-child(2){width:22%}.gpa-modern-table th:nth-child(3),.gpa-modern-table td:nth-child(3){width:34%}.gpa-modern-table th:nth-child(4),.gpa-modern-table td:nth-child(4){width:16%}.gpa-modern-table th:nth-child(5),.gpa-modern-table td:nth-child(5){width:16%}.sem-badge{width:20px;height:20px;font-size:.65rem}.credits-badge-modern{padding:2px 4px;font-size:.7rem;border-radius:4px}.course-name-cell{white-space:normal;line-height:1.2;text-align:left!important;font-size:.7rem!important}.course-code-cell{font-size:.7rem}.grade-cell{text-align:center!important;font-weight:800}}.excluded-row{opacity:.4;filter:grayscale(.8);transition:all .3s ease}.modern-checkbox{display:block;position:relative;width:20px;height:20px;cursor:pointer;margin:0 auto}.checkmark{position:absolute;top:0;left:0;height:20px;width:20px;background-color:#ffffff1a;border:1px solid rgba(255,255,255,.2);border-radius:6px;transition:all .2s cubic-bezier(.4,0,.2,1)}.modern-checkbox:hover input~.checkmark{background-color:#ffffff26;border-color:#3b82f6}.modern-checkbox input:checked~.checkmark{background-color:#3b82f6;border-color:#3b82f6;box-shadow:0 0 10px #3b82f680}.modern-checkbox .checkmark:after{left:6px;top:3px;width:5px;height:10px;border:solid white;border-width:0 2px 2px 0;transform:rotate(45deg)}.checkbox-cell{padding-left:10px!important;padding-right:10px!important}.cgpa-page-wrapper{display:flex;justify-content:center;align-items:flex-start;padding:40px 20px;min-height:calc(100vh - 80px)}.cgpa-card{background:#1e1e1e;border-radius:20px;padding:40px;width:100%;max-width:800px;box-shadow:0 10px 30px #00000080;display:flex;flex-direction:column;gap:30px}.cgpa-summary{text-align:center;color:#fff}.cgpa-summary h2{font-size:1.5rem;font-weight:600;margin-bottom:10px;letter-spacing:.5px}.table-section{width:100%;border-radius:12px;overflow:hidden;border:1px solid #333}.cgpa-table{width:100%;border-collapse:collapse;background:#252525}.cgpa-table th{background:#333;color:#fff;padding:15px;font-size:.85rem;font-weight:700;text-transform:uppercase;text-align:center;border-bottom:1px solid #444}.cgpa-table td{padding:15px;color:#ccc;text-align:center;border-bottom:1px solid #333;font-size:.95rem}.cgpa-table tr:last-child td{border-bottom:none}.chart-section{background:#252525;border-radius:12px;padding:20px;border:1px solid #333}.chart-title{text-align:center;color:#fff;font-size:1.1rem;font-weight:600;margin-bottom:20px}.chart-container{position:relative;height:350px;width:100%}@media(max-width:768px){.cgpa-page-wrapper{padding:20px 8px}.cgpa-card{padding:20px 10px;border-radius:16px;gap:15px}.cgpa-summary{background:#ffffff08;border:1px solid rgba(255,255,255,.05);border-radius:12px;padding:15px;text-align:left}.cgpa-summary h2{font-size:.9rem;margin-bottom:6px;display:flex;justify-content:space-between;align-items:center}.cgpa-summary h2:last-child{margin-top:10px;padding-top:10px;border-top:1px solid rgba(255,255,255,.1);font-size:1.1rem;color:var(--primary)}.table-section{overflow-x:hidden;background:#252525;border:1px solid #333;border-radius:10px}.cgpa-table{min-width:100%;table-layout:fixed}.cgpa-table th{padding:12px 4px;font-size:.7rem}.cgpa-table td{padding:12px 4px;font-size:.85rem;text-align:center;border-bottom:1px solid #333;display:table-cell;width:auto}.cgpa-table th:nth-child(1),.cgpa-table td:nth-child(1){width:25%}.cgpa-table th:nth-child(2),.cgpa-table td:nth-child(2){width:37.5%}.cgpa-table th:nth-child(3),.cgpa-table td:nth-child(3){width:37.5%}.chart-section{padding:10px;border-radius:10px}.chart-container{height:250px}}.cgpa-content-grid{display:grid;grid-template-columns:1fr 1.8fr;gap:25px;align-items:start}@media(max-width:1024px){.cgpa-content-grid{grid-template-columns:1fr}}.section-title{color:#888;font-size:.9rem;margin-bottom:12px;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.subjects-section{background:#252525;border-radius:12px;border:1px solid #333;padding:20px;overflow:hidden}.subjects-scroll-area{max-height:400px;overflow-y:auto;border-radius:8px;border:1px solid #1a1a1a;background:#1a1a1a}.subjects-table{width:100%;border-collapse:collapse}.subjects-table th{background:#111;color:#666;font-size:.7rem;font-weight:700;text-transform:uppercase;padding:12px 10px;position:sticky;top:0;z-index:10;text-align:left;border-bottom:1px solid #222}.subjects-table td{padding:12px 10px;border-bottom:1px solid #222;color:#ccc;font-size:.8rem}.course-code{font-family:JetBrains Mono,monospace;color:#888;font-size:.75rem}.course-title{color:#eee;font-weight:500}.grade-ra{color:#ff5c5c!important;font-weight:700}.text-error{color:#ff5c5c!important}.excluded-row{opacity:.25;filter:grayscale(1)}.modern-checkbox{display:block;position:relative;width:18px;height:18px;cursor:pointer}.modern-checkbox input{position:absolute;opacity:0;cursor:pointer;height:0;width:0}.checkmark{position:absolute;top:0;left:0;height:18px;width:18px;background-color:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:4px;transition:all .2s cubic-bezier(.4,0,.2,1)}.modern-checkbox:hover input~.checkmark{background-color:#ffffff1a;border-color:#4dd0e1}.modern-checkbox input:checked~.checkmark{background-color:#4dd0e1;border-color:#4dd0e1}.checkmark:after{content:"";position:absolute;display:none}.modern-checkbox input:checked~.checkmark:after{display:block}.modern-checkbox .checkmark:after{left:6px;top:2px;width:4px;height:8px;border:solid #121212;border-width:0 2px 2px 0;transform:rotate(45deg)}.subjects-scroll-area::-webkit-scrollbar{width:6px}.subjects-scroll-area::-webkit-scrollbar-track{background:#111}.subjects-scroll-area::-webkit-scrollbar-thumb{background:#333;border-radius:10px}.subjects-scroll-area::-webkit-scrollbar-thumb:hover{background:#444}.about-page-container{color:var(--text-primary)}.about-section{text-align:center;padding:6rem 2rem 2rem;margin:20px;border-radius:10px}.about-section h2{font-size:2.5rem;font-weight:700;margin-bottom:1rem;background:linear-gradient(135deg,#fff,#cbd5e1);background-clip:text;-webkit-background-clip:text;-webkit-text-fill-color:transparent}.about-section p{font-size:1rem;color:var(--text-secondary);max-width:800px;margin:0 auto;line-height:1.6}.team-section{text-align:center;padding:2rem;margin:20px;border-radius:10px}.team-section h3{font-size:2rem;color:var(--text-primary);margin-bottom:2rem}.team-members{display:flex;justify-content:center;align-items:center;gap:2rem;flex-wrap:wrap;padding:20px}.card{width:300px;height:200px;padding:15px;border-radius:20px;display:flex;flex-direction:column;align-items:center;position:relative;text-align:center;background:var(--glass-bg);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border:1px solid var(--glass-border);box-shadow:var(--shadow-sm);--rotate-animation: rotate(45deg);--scale-animation: scale(0);--bg-instagram: linear-gradient(to right, #8a2387, #e94057, #f27121);--bg-github: rgb(62, 63, 81);--bg-linkedin: rgb(30, 48, 131)}.card:before{content:"";height:110%;width:110%;position:absolute;top:-5%;left:-5%;z-index:-1;background:transparent;filter:blur(30px)}.card__hover{color:#fff;width:100%;margin:0;font-size:30px;font-weight:600;position:absolute;top:50%;left:0;text-align:center;letter-spacing:2px;pointer-events:none;transform:scale(1) translateY(-50%);font-family:inherit;transition:transform .5s}.card:hover .card__hover{transform:scale(0)}.card__figure{width:100%;height:65%;border-radius:10px;overflow:hidden;transform:var(--rotate-animation) var(--scale-animation);transition:transform .6s ease .1s;margin:0;display:flex;justify-content:center;align-items:center}.card:hover .card__figure{--rotate-animation: rotate(0);--scale-animation: scale(1)}.card__figure svg{height:100%;width:100%;object-fit:cover;filter:drop-shadow(0 0 2px #0f0c29)}.card__info{display:flex;flex-direction:column;transform:var(--scale-animation);transition:transform .6s ease .1s;width:100%}.card:hover .card__info{--scale-animation: scale(1)}.card__name{color:var(--text-primary);font-size:28px;letter-spacing:1px;font-family:inherit;font-weight:700}.card__ocupation{color:var(--text-secondary);font-family:inherit;text-transform:uppercase;font-size:18px;letter-spacing:2px}.card__links{width:100%;display:flex;align-items:center;justify-content:center;gap:1rem;margin-top:1rem;--transform-animation: translateY(-10px)}.card__links svg{height:55px;width:55px;padding:10px;background-color:#80808036;border-radius:15px;cursor:pointer;transition:background .3s ease,transform .2s ease}.card__links svg:hover{transform:var(--transform-animation);box-shadow:0 0 10px #00000080}.card__links .instagram-link:hover svg{background:var(--bg-instagram)}.card__links .github-link:hover svg{background:var(--bg-github)}.card__links .linkedin-link:hover svg{background:var(--bg-linkedin)}.not-found-container{display:flex;justify-content:center;align-items:center;min-height:calc(100vh - 160px);padding:2rem}.not-found-content{background:var(--glass-bg);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border:1px solid var(--glass-border);border-radius:24px;padding:4rem 2rem;text-align:center;max-width:500px;width:100%;box-shadow:var(--shadow-md)}.not-found-icon{color:var(--primary);margin-bottom:1.5rem;display:inline-flex;padding:1.5rem;background:#3b82f61a;border-radius:20px}.not-found-title{font-size:5rem;font-weight:800;margin-bottom:.5rem;background:linear-gradient(135deg,#fff,#cbd5e1);background-clip:text;-webkit-background-clip:text;-webkit-text-fill-color:transparent}.not-found-subtitle{color:var(--text-secondary);font-size:1.1rem;margin-bottom:2.5rem}.back-home-btn{display:inline-flex;align-items:center;gap:.75rem;padding:.875rem 1.5rem;background:linear-gradient(135deg,var(--primary) 0%,#7c3aed 100%);border-radius:12px;color:#fff;text-decoration:none;font-weight:600;transition:all .3s ease;box-shadow:0 4px 12px #7c3aed4d}.back-home-btn:hover{transform:translateY(-2px);box-shadow:0 6px 16px #7c3aed66;filter:brightness(1.1)}:root{--bg-dark: #000000;--bg-gradient-start: #0f172a;--bg-gradient-end: #000000;--primary: #3b82f6;--primary-glow: rgba(59, 130, 246, .5);--secondary: #60a5fa;--accent: #0ea5e9;--text-primary: #f8fafc;--text-secondary: #94a3b8;--text-tertiary: #64748b;--glass-bg: rgba(20, 20, 20, .6);--glass-bg-hover: rgba(30, 30, 30, .8);--glass-border: rgba(255, 255, 255, .1);--glass-popover: rgba(10, 10, 10, .95);--shadow-sm: 0 4px 6px -1px rgba(0, 0, 0, .3), 0 2px 4px -1px rgba(0, 0, 0, .15);--shadow-md: 0 10px 15px -3px rgba(0, 0, 0, .4), 0 4px 6px -2px rgba(0, 0, 0, .2);--shadow-glow: 0 0 20px rgba(59, 130, 246, .15);--success: #22c55e;--warning: #eab308;--danger: #ef4444}*{box-sizing:border-box;margin:0;padding:0}body{font-family:Outfit,Inter,system-ui,-apple-system,sans-serif;background-color:var(--bg-dark);background-image:linear-gradient(to bottom,#000,#111);background-attachment:fixed;min-height:100vh;color:var(--text-primary);padding-top:80px;overflow-x:hidden;-webkit-font-smoothing:antialiased}::-webkit-scrollbar{width:8px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:#ffffff1a;border-radius:4px}::-webkit-scrollbar-thumb:hover{background:#fff3}.navbar{background:#09090b99;backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border-bottom:1px solid var(--glass-border);padding:1rem 1.5rem;display:flex;justify-content:space-between;align-items:center;position:fixed;top:0;left:0;right:0;z-index:1000;transition:all .3s ease}.navbar .logo{font-size:1.25rem;font-weight:700;color:var(--text-primary);text-decoration:none;background:linear-gradient(135deg,#fff,#cbd5e1);background-clip:text;-webkit-background-clip:text;-webkit-text-fill-color:transparent;letter-spacing:-.5px}.navbar-links{display:flex;gap:1rem;align-items:center}.navbar-links a,.navbar-links button{color:var(--text-secondary);text-decoration:none;font-weight:500;font-size:.9rem;padding:.5rem 1rem;border-radius:99px;background:transparent;border:none;cursor:pointer;font-family:inherit;transition:all .2s ease;display:flex;align-items:center;gap:.5rem}.navbar-links a:hover,.navbar-links button:hover{color:var(--text-primary);background:var(--glass-bg-hover)}.navbar-links a.active{color:var(--text-primary);background:#3b82f626;border:1px solid rgba(59,130,246,.3)}.user-greeting{color:var(--text-primary);font-size:.9rem;font-weight:600;padding:.5rem 1rem;display:flex;align-items:center;gap:.5rem;background:#ffffff0d;border-radius:99px;border:1px solid var(--glass-border);margin-right:.5rem}.user-greeting span{max-width:150px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}@media(max-width:768px){.user-greeting span{max-width:80px}.user-greeting{padding:.5rem .75rem;margin-right:0}}.login-wrapper{display:flex;justify-content:center;align-items:center;min-height:calc(100vh - 80px);padding:20px;position:relative;z-index:2}.login-container{width:100%;max-width:420px;padding:2.5rem;background:#141419b3;backdrop-filter:blur(24px);-webkit-backdrop-filter:blur(24px);border-radius:24px;border:1px solid var(--glass-border);box-shadow:var(--shadow-md);text-align:center;position:relative;overflow:hidden}.login-container:before{content:"";position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,rgba(255,255,255,.2),transparent)}.welcome-text{font-size:2rem;font-weight:700;color:var(--text-primary);margin-bottom:.5rem;letter-spacing:-.5px}.subtitle{color:var(--text-secondary);font-size:.95rem;margin-bottom:2rem}.form-group{position:relative;margin-bottom:1rem}.input-wrapper{position:relative;display:flex;align-items:center}.input-icon{position:absolute;left:1rem;color:var(--text-tertiary);pointer-events:none;transition:color .3s ease}.input-field{width:100%;padding:.875rem 1rem .875rem 2.75rem;background:#0003;border:1px solid var(--glass-border);border-radius:12px;color:var(--text-primary);font-size:.95rem;font-family:inherit;transition:all .2s ease}.input-field:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 4px #8b5cf61a;background:#0000004d}.input-field:focus+.input-icon{color:var(--primary)}.login-btn{width:100%;padding:.875rem;margin-top:1rem;background:linear-gradient(135deg,var(--primary) 0%,#7c3aed 100%);border:none;border-radius:12px;color:#fff;font-size:.95rem;font-weight:600;cursor:pointer;transition:all .3s ease;box-shadow:0 4px 12px #7c3aed4d}.login-btn:hover{transform:translateY(-1px);box-shadow:0 6px 16px #7c3aed66;filter:brightness(1.1)}.login-btn:disabled{opacity:.7;cursor:not-allowed;transform:none}.password-toggle-btn{position:absolute;right:1rem;background:none;border:none;color:var(--text-tertiary);cursor:pointer;padding:0;display:flex;align-items:center;transition:color .3s ease}.password-toggle-btn:hover{color:var(--primary)}.input-field{padding-right:3rem}.login-type-toggle{display:flex;background:#0003;padding:4px;border-radius:14px;margin-bottom:2rem;gap:4px}.login-type-btn{flex:1;display:flex;align-items:center;justify-content:center;gap:8px;padding:10px;border-radius:10px;border:none;background:transparent;color:var(--text-secondary);font-size:.9rem;font-weight:500;cursor:pointer;transition:all .2s cubic-bezier(.4,0,.2,1)}.login-type-btn.active{background:var(--glass-bg-hover);color:var(--text-primary);box-shadow:0 1px 3px #0000001a}.dashboard-container{width:100%;max-width:1200px;margin:0 auto;padding:2rem;min-height:calc(100vh - 80px);display:flex;align-items:center;justify-content:center}.dashboard-options{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:1.5rem;width:100%}.dashboard-card{background:var(--glass-bg);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border:1px solid var(--glass-border);border-radius:20px;padding:2rem;display:flex;flex-direction:column;align-items:center;text-align:center;text-decoration:none;transition:all .3s cubic-bezier(.4,0,.2,1);overflow:hidden}.dashboard-card:hover{transform:translateY(-4px);background:var(--glass-bg-hover);border-color:#ffffff26;box-shadow:var(--shadow-md),var(--shadow-glow)}.dashboard-icon-wrapper{width:64px;height:64px;border-radius:16px;background:#3b82f61a;color:var(--primary);display:flex;align-items:center;justify-content:center;margin-bottom:1.25rem;transition:all .3s ease}.dashboard-card:hover .dashboard-icon-wrapper{background:var(--primary);color:#fff;transform:scale(1.1) rotate(3deg)}.dashboard-title{font-size:1.1rem;font-weight:600;color:var(--text-primary);margin-bottom:.5rem}.dashboard-description{font-size:.85rem;color:var(--text-secondary);line-height:1.5}.content-card{background:var(--glass-bg);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border:1px solid var(--glass-border);border-radius:24px;padding:2rem;box-shadow:var(--shadow-sm);width:100%;margin-bottom:2rem}.table-container{width:100%;overflow-x:auto;border-radius:12px;border:1px solid var(--glass-border);margin-top:1rem;background:#1a1a1a}table.attendance-table{width:100%;border-collapse:collapse;color:var(--text-primary)}table.attendance-table th{background:#262626;padding:12px 8px;text-align:center;font-weight:700;color:var(--text-primary);font-size:.9rem;border:1px solid var(--glass-border);white-space:nowrap}table.attendance-table td{padding:12px 8px;border:1px solid var(--glass-border)}table.attendance-table th:nth-child(2),table.attendance-table td.course-name-cell{text-align:left}td.course-name-cell{text-transform:uppercase;font-weight:700;color:var(--text-primary);font-size:.85rem}td.course-code-cell{font-weight:800;text-align:center;color:var(--text-primary);font-size:.9rem}.centered-bold-cell{text-align:center;font-weight:700;color:var(--text-primary);font-size:.95rem}table.attendance-table tr:nth-child(2n) td{background:#ffffff05}table.attendance-table tr:hover td{background:#ffffff0d}.loading-overlay{position:fixed;inset:0;background:#09090bcc;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:9999;display:flex;justify-content:center;align-items:center}.loader{width:64px;height:64px;position:relative;display:flex;justify-content:center;align-items:center}.loader:before,.loader:after{content:"";position:absolute;border-radius:50%;border:3px solid transparent}.loader:before{width:100%;height:100%;border-top-color:var(--primary);border-right-color:var(--primary);filter:drop-shadow(0 0 4px var(--primary));animation:spin 1.5s cubic-bezier(.68,-.55,.27,1.55) infinite}.loader:after{width:65%;height:65%;border-bottom-color:var(--accent);border-left-color:var(--accent);filter:drop-shadow(0 0 4px var(--accent));animation:spin-reverse 2s cubic-bezier(.68,-.55,.27,1.55) infinite}@keyframes spin{to{transform:rotate(360deg)}}@keyframes spin-reverse{to{transform:rotate(-360deg)}}.text-success{color:var(--success)}.text-warning{color:var(--warning)}.text-danger{color:var(--danger)}.show-mobile{display:none}.page-header{text-align:center;margin-bottom:2.5rem}.page-header h1{font-size:2.5rem;font-weight:700;margin-bottom:.5rem;background:linear-gradient(135deg,#fff,#cbd5e1);background-clip:text;-webkit-background-clip:text;-webkit-text-fill-color:transparent}.page-header p{color:var(--text-secondary)}.view-toggle-container{display:flex;justify-content:center;margin-bottom:2rem}.toggle-wrapper{background:#0003;padding:.5rem;border-radius:99px;display:flex;align-items:center;gap:1rem;border:1px solid var(--glass-border)}.view-toggle-switch{position:relative;width:44px;height:24px;background:#ffffff1a;border-radius:99px;cursor:pointer;transition:background .3s}.view-toggle-switch input{opacity:0;width:0;height:0}.view-toggle-slider{position:absolute;top:2px;left:2px;width:20px;height:20px;background:#fff;border-radius:50%;transition:transform .3s}.view-toggle-switch input:checked+.view-toggle-slider{transform:translate(20px)}.view-toggle-label.active{color:var(--text-primary);font-weight:600}.view-toggle-label{color:var(--text-secondary);font-size:.9rem;cursor:pointer;-webkit-user-select:none;user-select:none}.cards-container{display:flex;flex-direction:column;gap:1.5rem;align-items:center}.attendance-card{background:var(--glass-bg);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border:1px solid var(--glass-border);border-radius:20px;padding:2rem;width:100%;max-width:600px;transition:transform .3s;position:relative;overflow:hidden}.attendance-card:hover{transform:translateY(-4px);background:var(--glass-bg-hover);box-shadow:var(--shadow-md)}.attendance-card:before{content:"";position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,var(--primary),var(--secondary))}.course-header{text-align:center;margin-bottom:1.5rem;padding-bottom:1rem;border-bottom:1px solid var(--glass-border)}.course-name{font-size:1.25rem;font-weight:600;color:var(--text-primary);margin-bottom:.25rem}.course-code{font-size:.9rem;color:var(--text-tertiary)}.attendance-stats{display:grid;grid-template-columns:1fr 1fr;gap:1rem;margin-bottom:1rem}.stat-item{background:#0003;border-radius:12px;padding:1rem;text-align:center;border:1px solid var(--glass-border)}.stat-label{font-size:.75rem;text-transform:uppercase;color:var(--text-tertiary);margin-bottom:.5rem;letter-spacing:.5px}.stat-value{font-size:1.25rem;font-weight:700;color:var(--text-primary)}.status-section{margin-top:1.5rem;background:#ffffff05;border-radius:12px;padding:1rem}.status-item{display:flex;justify-content:space-between;font-size:.95rem;color:var(--text-secondary)}.status-value{font-weight:600;color:var(--text-primary)}.attendance-good{color:var(--success)!important}.attendance-medium{color:var(--warning)!important}.attendance-low{color:var(--danger)!important}.info-icon-btn{background:none;border:none;color:var(--text-tertiary);cursor:pointer;vertical-align:middle;margin-left:.5rem;padding:4px;border-radius:50%;transition:all .2s;display:inline-flex}.info-icon-btn:hover{color:var(--primary);background:#3b82f61a}.popup{position:fixed;bottom:24px;right:24px;display:flex;justify-content:flex-end;align-items:flex-end;z-index:2000;pointer-events:none}.popup-content{background:var(--glass-popover);border:1px solid var(--glass-border);padding:1.5rem;border-radius:16px;max-width:350px;text-align:left;position:relative;pointer-events:auto;box-shadow:var(--shadow-md);animation:slideInRight .3s ease-out forwards;display:flex;gap:12px;align-items:flex-start}.popup-icon{font-size:1.25rem;margin-bottom:0;flex-shrink:0}.popup-text{font-size:.9rem;line-height:1.5;color:var(--text-secondary);padding-right:12px}.close-btn{position:absolute;top:8px;right:8px;background:none;border:none;color:var(--text-tertiary);font-size:1.25rem;cursor:pointer;padding:4px;border-radius:4px;line-height:1}.close-btn:hover{color:var(--text-primary);background:#ffffff1a}@keyframes slideInRight{0%{opacity:0;transform:translate(20px)}to{opacity:1;transform:translate(0)}}.gpa-container,.cgpa-container{width:100%;max-width:1000px;margin:0 auto;padding:2rem}.cgpa-header{text-align:center;margin-bottom:2rem;padding:2rem;background:var(--glass-bg);border:1px solid var(--glass-border);border-radius:20px}.cgpa-header h2{font-size:1.5rem;margin-bottom:.5rem;color:var(--text-primary)}.summary-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1.5rem;margin-bottom:3rem}.summary-card{background:var(--glass-bg);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border:1px solid var(--glass-border);border-radius:16px;padding:1.5rem;text-align:center;position:relative;overflow:hidden}.summary-card:after{content:"";position:absolute;bottom:0;left:0;right:0;height:3px;background:linear-gradient(90deg,transparent,var(--primary),transparent);opacity:.5}.summary-label{font-size:.85rem;color:var(--text-tertiary);text-transform:uppercase;letter-spacing:1px;margin-bottom:.5rem}.summary-value{font-size:2rem;font-weight:700;color:var(--text-primary)}.summary-value.gpa-value{background:linear-gradient(135deg,var(--primary),var(--secondary));background-clip:text;-webkit-background-clip:text;-webkit-text-fill-color:transparent}.credits-badge{display:inline-block;padding:4px 12px;background:#ffffff0d;border-radius:6px;font-size:.9rem;color:var(--text-secondary)}.grade-badge{display:inline-block;padding:4px 12px;border-radius:6px;font-weight:600;min-width:40px;text-align:center}.grade-S,.grade-O{background:#22c55e1a;color:#22c55e;border:1px solid rgba(34,197,94,.2)}.grade-A{background:#3b82f61a;color:#3b82f6;border:1px solid rgba(59,130,246,.2)}.grade-B{background:#eab3081a;color:#eab308;border:1px solid rgba(234,179,8,.2)}.grade-C,.grade-D,.grade-E{background:#f973161a;color:#f97316;border:1px solid rgba(249,115,22,.2)}.grade-F{background:#ef44441a;color:#ef4444;border:1px solid rgba(239,68,68,.2)}@media(max-width:768px){body{padding-top:70px}.navbar{padding:.75rem 1rem}.navbar .logo{font-size:1.1rem}.navbar-links{gap:.5rem}.navbar-links a,.navbar-links button{padding:.5rem;font-size:.85rem}.hide-mobile{display:none}.dashboard-container{padding:1rem;align-items:flex-start}.dashboard-options{grid-template-columns:repeat(2,1fr);gap:1rem}.dashboard-card{padding:1.5rem}.dashboard-icon-wrapper{width:48px;height:48px;margin-bottom:.75rem}.dashboard-title{font-size:.95rem}.dashboard-description{font-size:.75rem}.table-container{border-radius:12px;overflow-x:auto;-webkit-overflow-scrolling:touch}.show-mobile{display:inline}table.attendance-table th,table.attendance-table td{padding:8px 4px;font-size:.6rem;white-space:nowrap;text-align:center}table.attendance-table td.course-name-cell{white-space:normal;min-width:80px;max-width:120px;line-height:1.2;text-align:left}table.attendance-table td.course-code-cell{display:table-cell;font-size:.55rem;color:var(--text-tertiary);max-width:50px;overflow:hidden;text-overflow:ellipsis}th:first-child{display:table-cell}.login-container{padding:1.5rem;width:95%}.welcome-text{font-size:1.5rem}.page-header h1{font-size:1.75rem}}@media(max-width:480px){.dashboard-options{grid-template-columns:1fr}.navbar-links a,.navbar-links button{padding:.4rem}}
