*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--blue:#2563eb;--blue-dark:#1d4ed8;--blue-hover:#1e40af;--blue-light:#eff6ff;--blue-mid:#dbeafe;--text:#111827;--muted:#6b7280;--border:#e5e7eb;--white:#fff;--bg:#f9fafb;--yellow:#f59e0b;--yellow-bg:#fffbeb;--yellow-border:#fde68a;--dark:#111827;--radius:16px;--shadow-sm:0 1px 2px 0 #0000000d;--shadow-md:0 4px 6px -1px #0000001a, 0 2px 4px -1px #0000000f;--shadow-lg:0 10px 30px -3px #00000014, 0 4px 6px -2px #0000000d;--shadow-blue:0 10px 15px -3px #2563eb33}html{scroll-behavior:smooth}body{color:var(--text);background:#f1f5f9;padding-top:80px;font-family:Inter,sans-serif;font-size:15px;line-height:1.5}input,textarea,select{border:1px solid var(--border);width:100%;color:var(--text);background:#fff;border-radius:10px;outline:none;padding:12px 16px;font-family:Inter,sans-serif;font-size:.95rem;transition:all .2s}input::placeholder,textarea::placeholder{color:#9ca3af}input:focus,textarea:focus,select:focus{border-color:var(--blue);box-shadow:0 0 0 4px #2563eb14}label{color:#1f2937;margin-bottom:10px;font-size:.9rem;font-weight:700;display:block}.navbar{z-index:200;background:var(--white);border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;height:64px;padding:0 48px;display:flex;position:sticky;top:0}.nav-logo{align-items:center;gap:10px;text-decoration:none;display:flex}.nav-logo-icon{width:32px;height:32px}.nav-logo-text{color:var(--text);font-size:1.1rem;font-weight:700}.nav-menu{flex-wrap:wrap;align-items:center;gap:8px 32px;list-style:none;display:flex}.nav-menu a{color:var(--muted);font-size:.9rem;font-weight:500;text-decoration:none;transition:color .2s}.nav-menu a:hover,.nav-menu a.active{color:var(--text)}.nav-session{border-left:1px solid var(--border);flex-wrap:wrap;align-items:center;gap:10px;margin-left:4px;padding-left:8px;display:flex}.nav-session-text{color:var(--text);white-space:nowrap;text-overflow:ellipsis;max-width:160px;font-size:.82rem;font-weight:600;overflow:hidden}.nav-role-pill{background:var(--blue-light);color:var(--blue);vertical-align:middle;border-radius:999px;margin-left:4px;padding:2px 8px;font-size:.72rem;font-weight:800;display:inline-block}.nav-session-link{color:var(--blue);font-size:.85rem;font-weight:600;text-decoration:none}.nav-session-link:hover{text-decoration:underline}.nav-logout-btn{border:1px solid var(--border);background:var(--white);color:var(--muted);cursor:pointer;border-radius:999px;padding:6px 12px;font-family:Inter,sans-serif;font-size:.8rem;font-weight:600;transition:background .2s,color .2s,border-color .2s}.nav-logout-btn:hover{color:#b91c1c;background:#fee2e2;border-color:#fca5a5}.btn-blue{background:var(--blue);color:#fff;cursor:pointer;border-radius:var(--radius);border:none;align-items:center;gap:8px;padding:12px 28px;font-family:Inter,sans-serif;font-size:.93rem;font-weight:600;text-decoration:none;transition:background .2s;display:inline-flex}.btn-blue:hover{background:var(--blue-dark)}.btn-white-outline{color:#fff;cursor:pointer;border-radius:var(--radius);background:0 0;border:2px solid #ffffffb3;align-items:center;gap:8px;padding:10px 26px;font-family:Inter,sans-serif;font-size:.93rem;font-weight:600;text-decoration:none;transition:border-color .2s,background .2s;display:inline-flex}.btn-white-outline:hover{background:#ffffff1f;border-color:#fff}.btn-white-solid{color:var(--blue);cursor:pointer;border-radius:var(--radius);background:#fff;border:2px solid #fff;align-items:center;gap:8px;padding:10px 26px;font-family:Inter,sans-serif;font-size:.93rem;font-weight:600;text-decoration:none;transition:background .2s;display:inline-flex}.btn-white-solid:hover{background:#eff6ff}.section{padding:64px 48px}.section-bg{background:var(--bg)}.section-white{background:var(--white)}.section-title{color:var(--text);text-align:center;font-size:1.85rem;font-weight:800}.section-sub{text-align:center;color:var(--muted);max-width:600px;margin-top:8px;margin-left:auto;margin-right:auto;font-size:.9rem}.cta-strip{background:var(--bg);text-align:center;border-top:1px solid var(--border);padding:72px 48px}.cta-strip h2{color:var(--text);font-size:2rem;font-weight:800}.cta-strip p{color:var(--muted);margin-top:8px;font-size:.95rem}.cta-strip .btn-blue{margin-top:28px;padding:13px 36px;font-size:1rem}footer{background:var(--dark);color:#ffffffb3;padding:52px 48px 24px}.footer-grid{grid-template-columns:2fr 1.5fr 1fr;gap:48px;display:grid}.footer-brand-name{color:#fff;margin-bottom:10px;font-size:1.05rem;font-weight:700}.footer-brand p{max-width:280px;font-size:.85rem;line-height:1.7}.footer-social{gap:10px;margin-top:16px;display:flex}.soc{cursor:pointer;background:#ffffff14;border-radius:6px;place-items:center;width:32px;height:32px;transition:background .2s;display:grid}.soc:hover{background:var(--blue)}.soc svg{fill:#fff;width:15px;height:15px}.footer-col h4{color:#fff;margin-bottom:14px;font-size:.88rem;font-weight:700}.footer-col ul{flex-direction:column;gap:9px;list-style:none;display:flex}.footer-col a{color:#fff9;font-size:.85rem;text-decoration:none;transition:color .2s}.footer-col a:hover{color:#fff}.footer-contact-item{color:#ffffffa6;align-items:flex-start;gap:10px;margin-bottom:11px;font-size:.85rem;display:flex}.footer-contact-item svg{fill:#ffffff80;flex-shrink:0;width:16px;height:16px;margin-top:2px}.footer-bottom{text-align:center;color:#fff6;border-top:1px solid #ffffff14;margin-top:40px;padding-top:18px;font-size:.8rem}.toast{background:var(--dark);color:#fff;z-index:9999;opacity:0;pointer-events:none;border-radius:10px;padding:13px 20px;font-size:.87rem;transition:all .35s;position:fixed;bottom:24px;right:24px;transform:translateY(60px);box-shadow:0 4px 20px #00000040}.toast.show{opacity:1;transform:translateY(0)}@media (width<=900px){.navbar{padding:0 20px}.section,.cta-strip,footer{padding-left:20px;padding-right:20px}.footer-grid{grid-template-columns:1fr;gap:28px}}@media (width<=640px){.navbar{flex-wrap:wrap;align-items:flex-start;gap:10px;height:auto;min-height:64px;padding-top:12px;padding-bottom:12px}.nav-menu{flex:100%;justify-content:flex-end;gap:14px 18px}.nav-session{border-left:none;justify-content:flex-start;width:100%;margin-left:0;padding-left:0}}@keyframes fadeInUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.reveal{animation:.6s ease-out forwards fadeInUp}@keyframes dropdownItemSlideIn{0%{opacity:0;transform:translate(10px)}to{opacity:1;transform:translate(0)}}.stagger-item{opacity:0;animation:.3s ease-out forwards dropdownItemSlideIn}@keyframes progressBarGrow{0%{width:0}}.progress-fill{animation:1.5s cubic-bezier(.65,0,.35,1) forwards progressBarGrow}@keyframes pulse-subtle{0%,to{opacity:1}50%{opacity:.8}}.pulse{animation:2s ease-in-out infinite pulse-subtle}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.animate-slide-down{animation:.3s ease-out slideDown}.glass{-webkit-backdrop-filter:blur(10px);background:#ffffffb3!important;border:1px solid #ffffff4d!important}.card-hover{transition:all .3s cubic-bezier(.4,0,.2,1)!important}.card-hover:hover{transform:translateY(-8px)scale(1.02);border-color:var(--blue)!important;box-shadow:0 20px 40px #2563eb26!important}.gradient-text{background:linear-gradient(130deg,#2563eb 0%,#3b82f6 100%);-webkit-text-fill-color:transparent;-webkit-background-clip:text;font-weight:800}.hero{color:#fff;background:linear-gradient(130deg,#1a35a8 0%,#2563eb 55%,#3b7ef8 100%);grid-template-columns:1.2fr .8fr;align-items:center;gap:40px;padding:80px 48px 100px;display:grid;overflow:hidden}.hero-content{animation:.8s ease-out fadeInUp}.hero h1{margin-bottom:20px;font-size:clamp(2.2rem,5vw,3.5rem);font-weight:800;line-height:1.1}.hero p{opacity:.95;max-width:600px;margin-bottom:32px;font-size:1.1rem;line-height:1.7}.hero-btns{flex-wrap:wrap;gap:16px;display:flex}.hero-image-container{animation:1s ease-out fadeInUp;position:relative}.hero-image-container img{border:4px solid #ffffff1a;border-radius:24px;width:100%;transition:transform .5s;transform:perspective(1000px)rotateY(-5deg)rotateX(2deg);box-shadow:0 30px 60px #0000004d}.hero-image-container:hover img{transform:perspective(1000px)rotateY(0)rotateX(0)scale(1.02)}@media (width<=1000px){.hero{text-align:center;grid-template-columns:1fr;padding:60px 24px}.hero p{margin-left:auto;margin-right:auto}.hero-btns{justify-content:center}.hero-image-container{max-width:500px;margin-top:40px;margin-left:auto;margin-right:auto}}.stats-bar{background:var(--white);border-bottom:1px solid var(--border);flex-wrap:wrap;justify-content:center;gap:0;display:flex}.stat-item{text-align:center;border-right:1px solid var(--border);padding:24px 48px}.stat-item:last-child{border-right:none}.stat-num{color:var(--blue);font-size:1.7rem;font-weight:800}.stat-label{color:var(--muted);margin-top:3px;font-size:.8rem}.courses-grid{grid-template-columns:repeat(3,1fr);gap:20px;margin-top:40px;display:grid}.course-card{background:var(--white);border:1px solid var(--border);text-align:center;border-radius:10px;padding:28px 22px;transition:box-shadow .2s,border-color .2s}.course-card:hover{border-color:#bfdbfe;box-shadow:0 4px 20px #2563eb1a}.course-card h3{color:var(--text);font-size:1rem;font-weight:700}.course-card p{color:var(--muted);margin-top:6px;font-size:.82rem;line-height:1.6}.course-card .duration{color:var(--muted);margin-top:10px;font-size:.78rem}.ach-grid{grid-template-columns:repeat(3,1fr);gap:20px;margin-top:40px;display:grid}.ach-card{background:var(--yellow-bg);border:1px solid var(--yellow-border);border-radius:10px;align-items:flex-start;gap:16px;padding:22px;display:flex}.ach-trophy{background:var(--yellow);border-radius:50%;flex-shrink:0;place-items:center;width:44px;height:44px;font-size:20px;display:grid}.ach-name{color:var(--text);font-size:.95rem;font-weight:700}.ach-exam{color:var(--blue);margin-top:2px;font-size:.82rem;font-weight:600}.ach-stats{gap:28px;margin-top:10px;display:flex}.ach-stat label{color:var(--muted);font-size:.75rem;font-weight:600;display:block}.ach-stat span{color:var(--text);font-size:.9rem;font-weight:700}.faculty-grid{grid-template-columns:repeat(4,1fr);gap:20px;margin-top:40px;display:grid}.faculty-card{background:var(--white);border:1px solid var(--border);text-align:center;border-radius:10px;padding:28px 20px;transition:box-shadow .2s}.faculty-card:hover{box-shadow:0 4px 16px #00000014}.f-avatar{background:#e5e7eb;border-radius:50%;justify-content:center;align-items:center;width:72px;height:72px;margin:0 auto 16px;display:flex}.f-avatar svg{width:36px;height:36px}.f-name{color:var(--text);font-size:.95rem;font-weight:700}.f-sub{color:var(--blue);margin-top:4px;font-size:.82rem;font-weight:600}.f-exp{color:var(--muted);margin-top:6px;font-size:.78rem}@media (width<=960px){.courses-grid{grid-template-columns:repeat(2,1fr)}.ach-grid{grid-template-columns:1fr 1fr}.faculty-grid{grid-template-columns:repeat(2,1fr)}.stat-item{padding:18px 28px}}@media (width<=600px){.hero{padding:48px 20px 56px}.courses-grid,.ach-grid{grid-template-columns:1fr}.faculty-grid{grid-template-columns:repeat(2,1fr)}.stats-bar{flex-direction:column}.stat-item{border-right:none;border-bottom:1px solid var(--border)}}.dashboard-grid{grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:24px;margin-top:32px;display:grid}.dash-card{border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-md);background:#fff;padding:32px;transition:all .3s cubic-bezier(.4,0,.2,1);position:relative;overflow:hidden}.dash-card:hover{box-shadow:var(--shadow-lg);border-color:var(--blue-mid);transform:translateY(-4px)}.dash-card:active{transition:transform .1s;transform:translateY(-2px)scale(.99)}.action-card{border:1px solid var(--border);cursor:pointer;box-shadow:var(--shadow-sm);color:inherit;background:#fff;border-radius:16px;align-items:center;gap:16px;padding:24px;text-decoration:none;transition:all .3s cubic-bezier(.4,0,.2,1);display:flex}.action-card:hover{box-shadow:var(--shadow-lg);border-color:var(--blue);transform:translateY(-5px)}.action-card:hover .action-card-icon{background:var(--blue);color:#fff;transform:rotate(-5deg)}.action-card:active{transform:scale(.96)}.action-card-icon{background:var(--blue-light);width:48px;height:48px;color:var(--blue);border-radius:12px;place-items:center;font-size:1.25rem;transition:all .3s;display:grid}.action-card-title{color:var(--text);font-size:.95rem;font-weight:800}.dash-card-icon{background:var(--blue-light);width:48px;height:48px;color:var(--blue);border-radius:12px;place-items:center;margin-bottom:20px;font-size:1.5rem;display:grid}.dash-card h3{color:var(--text);margin-bottom:8px;font-size:1.25rem;font-weight:800}.dash-card p{color:var(--muted);font-size:.95rem;line-height:1.6}.profile-avatar{background:var(--blue);color:#fff;cursor:pointer;width:44px;height:44px;box-shadow:var(--shadow-sm);-webkit-user-select:none;user-select:none;border:3px solid #fff;border-radius:50%;place-items:center;font-size:1.1rem;font-weight:800;transition:all .3s cubic-bezier(.4,0,.2,1);display:grid}.profile-avatar:hover{box-shadow:var(--shadow-md);border-color:var(--blue-light);transform:translateY(-2px)}.profile-avatar:active{transform:scale(.95)}.profile-avatar.active-ring{box-shadow:0 0 0 3px var(--blue-light), var(--shadow-md);border-color:var(--blue)}.dropdown-menu{border:1px solid var(--border);z-index:1000;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#fff;border-radius:20px;flex-direction:column;min-width:260px;padding:8px;display:flex;position:absolute;top:calc(100% + 12px);right:0;overflow:hidden;box-shadow:0 15px 50px #00000026}.dropdown-header{border-bottom:1px solid var(--border);background:#f8fafc;border-radius:12px 12px 0 0;margin-bottom:8px;padding:16px}.dropdown-name{color:var(--text);font-size:1rem;font-weight:800;display:block}.dropdown-email{color:var(--muted);margin-top:2px;font-size:.8rem;display:block}.dropdown-item{color:var(--text);cursor:pointer;border-radius:12px;align-items:center;gap:12px;padding:12px 16px;font-size:.9rem;font-weight:600;text-decoration:none;transition:all .2s;display:flex}.dropdown-item:hover{background:var(--blue-light);color:var(--blue);transform:translate(5px)}.dropdown-item.logout{color:#ef4444;border-top:1px solid var(--border);margin-top:6px;padding-top:14px}.dropdown-item.logout:hover{color:#dc2626;background:#fef2f2;transform:none}.badge{background:var(--blue-light);color:var(--blue);text-transform:uppercase;letter-spacing:.5px;border-radius:999px;align-items:center;padding:4px 12px;font-size:.7rem;font-weight:800;display:inline-flex}.btn-blue,.btn-outline{transition:all .2s cubic-bezier(.175,.885,.32,1.275)!important}.btn-blue:hover{filter:brightness(1.1);transform:scale(1.02);box-shadow:0 10px 20px #2563eb33}.btn-outline:hover{background:var(--blue-light);border-color:var(--blue);color:var(--blue)}.portal-layout{grid-template-columns:var(--sidebar-width,280px) 1fr;min-height:calc(100vh - 64px);transition:grid-template-columns .4s cubic-bezier(.4,0,.2,1);display:grid}.sidebar{width:var(--sidebar-width,280px);z-index:100;background:#0f172a;border-right:1px solid #ffffff0d;flex-direction:column;height:calc(100vh - 64px);transition:all .4s cubic-bezier(.4,0,.2,1);display:flex;position:sticky;top:64px;left:0;box-shadow:10px 0 30px #0000001a}.sidebar-toggle-btn{background:var(--blue);color:#fff;cursor:pointer;z-index:110;border:2px solid #0f172a;border-radius:50%;place-items:center;width:24px;height:24px;transition:transform .3s;display:grid;position:absolute;top:32px;right:-12px}.sidebar-toggle-btn:hover{background:var(--blue-dark);transform:scale(1.1)}.sidebar-header{border-bottom:1px solid #ffffff0d;align-items:center;gap:14px;padding:32px 20px;display:flex;overflow:hidden}.sidebar-user-avatar{background:linear-gradient(135deg, var(--blue), #3b82f6);color:#fff;border-radius:12px;place-items:center;width:44px;min-width:44px;height:44px;font-size:1.25rem;font-weight:900;display:grid;box-shadow:0 4px 12px #2563eb4d}.sidebar-user-info{flex-direction:column;transition:opacity .3s,transform .3s;display:flex}.sidebar-username{color:#fff;white-space:nowrap;font-size:.95rem;font-weight:700}.sidebar-user-role{color:#94a3b8;text-transform:uppercase;letter-spacing:.8px;margin-top:1px;font-size:.7rem;font-weight:600}.sidebar-section-title{color:#475569;text-transform:uppercase;letter-spacing:1.2px;padding:24px 24px 12px;font-size:.68rem;font-weight:800;transition:opacity .3s}.sidebar-nav{flex-direction:column;flex:1;gap:4px;padding:0 12px;display:flex}.sidebar-link{color:#94a3b8;cursor:pointer;background:0 0;border:none;border-radius:12px;align-items:center;gap:14px;width:100%;padding:12px 16px;font-size:.9rem;font-weight:600;text-decoration:none;transition:all .25s;display:flex}.sidebar-link:hover{color:#fff;background:#ffffff08}.sidebar-link.active{color:var(--blue);background:#2563eb1a;position:relative}.sidebar-link.active:after{content:"";background:var(--blue);border-radius:0 4px 4px 0;width:3px;height:16px;position:absolute;left:0}.sidebar-link-icon{justify-content:center;min-width:24px;font-size:1.25rem;display:flex}.sidebar-link-text{white-space:nowrap;transition:opacity .3s,transform .3s}.sidebar-badge{background:var(--blue);color:#fff;border-radius:6px;margin-left:auto;padding:2px 7px;font-size:.65rem;font-weight:800}.sidebar-footer{border-top:1px solid #ffffff0d;padding:16px 12px}.sidebar-logout{color:#f87171}.sidebar-logout:hover{color:#ef4444;background:#ef444414}.sidebar.collapsed{--sidebar-width:84px}.sidebar.collapsed .sidebar-header{justify-content:center;padding:32px 0}.sidebar.collapsed .sidebar-user-info,.sidebar.collapsed .sidebar-section-title,.sidebar.collapsed .sidebar-link-text,.sidebar.collapsed .sidebar-badge{opacity:0;pointer-events:none;width:0;margin:0;padding:0;transform:translate(-10px)}.sidebar.collapsed .sidebar-nav{padding:0 16px}.sidebar.collapsed .sidebar-footer{justify-content:center;display:flex}@media (width<=1024px){.portal-layout{grid-template-columns:1fr}.sidebar{display:none}}.whatsapp-fab{z-index:1000;background-color:#25d366;border-radius:50%;justify-content:center;align-items:center;width:60px;height:60px;text-decoration:none;transition:all .3s cubic-bezier(.175,.885,.32,1.275);display:flex;position:fixed;bottom:30px;right:30px;box-shadow:0 4px 15px #25d3664d}.whatsapp-fab:hover{transform:scale(1.1)rotate(5deg);box-shadow:0 6px 20px #25d36666}.whatsapp-fab svg{fill:#fff;width:32px;height:32px}.whatsapp-fab:after{content:"9604880222";color:#333;opacity:0;pointer-events:none;white-space:nowrap;border:1px solid var(--border);background:#fff;border-radius:8px;padding:6px 12px;font-size:.85rem;font-weight:700;transition:all .3s;position:absolute;right:70px;transform:translate(10px);box-shadow:0 4px 12px #0000001a}.whatsapp-fab:hover:after{opacity:1;transform:translate(0)}.subject-card{transition:all .4s cubic-bezier(.4,0,.2,1)}.subject-card:hover{transform:translateY(-5px)scale(1.03);border-color:var(--blue)!important;box-shadow:0 20px 25px -5px #2563eb1a,0 10px 10px -5px #0000000a!important}.subject-card:hover h4{color:var(--blue)!important}.modal-overlay{animation:.3s ease-out forwards modalFadeIn}@keyframes modalFadeIn{0%{opacity:0;-webkit-backdrop-filter:blur();backdrop-filter:blur()}to{opacity:1;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}}.modal-content{animation:.4s cubic-bezier(.34,1.56,.64,1) forwards modalSlideUp}@keyframes modalSlideUp{0%{opacity:0;transform:translateY(30px)scale(.95)}to{opacity:1;transform:translateY(0)scale(1)}}.topic-item{transition:all .3s}.topic-item:hover{transform:translate(8px);background:var(--blue-light)!important;border-color:var(--blue-mid)!important}
