@import url("https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700;800&family=Poppins:wght@600;700;800&display=swap");:root{--gr-font:"Inter",-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;--gr-font-heading:"Poppins",var(--gr-font);--gr-primary:#667eea;--gr-primary-dark:#764ba2;--gr-gradient:linear-gradient(135deg,#667eea,#764ba2);--inst-color:#0a4d8c;--inst-gradient:linear-gradient(160deg,#0a3566,#0a4d8c 55%,#1565c0);--student-color:#5d27a9;--student-gradient:linear-gradient(160deg,#432371,#5d27a9 60%,#7c3aed);--teacher-color:#059669;--teacher-gradient:linear-gradient(160deg,#064e3b,#059669 60%,#10b981);--gr-success:#10b981;--gr-warning:#f59e0b;--gr-danger:#ef4444;--gr-info:#3b82f6;--gr-bg:#f4f6fb;--gr-border:#e5e7eb;--gr-text:#111827;--gr-text-muted:#6b7280;--gr-radius:12px;--gr-radius-sm:8px;--gr-radius-lg:16px;--gr-radius-xl:20px;--gr-shadow-sm:0 1px 4px rgba(0,0,0,0.06);--gr-shadow:0 2px 12px rgba(0,0,0,0.08);--gr-shadow-md:0 4px 24px rgba(0,0,0,0.11);--gr-shadow-lg:0 8px 40px rgba(0,0,0,0.14);--gr-transition:all 0.2s cubic-bezier(0.4,0,0.2,1)}*,:after,:before{box-sizing:border-box}body{font-family:var(--gr-font);color:var(--gr-text);background:#fff;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.gr-hero{background:var(--gr-gradient);color:white;padding:90px 0;position:relative;overflow:hidden}.gr-hero:before{top:-50%;right:-8%;width:640px;height:640px;background:rgba(255,255,255,.05)}.gr-hero:after,.gr-hero:before{content:"";position:absolute;border-radius:50%;pointer-events:none}.gr-hero:after{bottom:-30%;left:-5%;width:400px;height:400px;background:rgba(255,255,255,.04)}.gr-hero-badge{display:inline-flex;align-items:center;gap:6px;background:rgba(255,255,255,.15);color:#fff;padding:6px 16px;border-radius:50px;font-size:.83rem;font-weight:500;margin-bottom:20px;backdrop-filter:blur(4px);border:1px solid rgba(255,255,255,.18)}.gr-hero-title{font-family:var(--gr-font-heading);font-size:clamp(2rem,5vw,3rem);font-weight:800;line-height:1.2;color:#fff}.gr-hero-subtitle{font-size:1.05rem;opacity:.92;line-height:1.75;color:rgba(255,255,255,.9)}.gr-btn-white{display:inline-flex;align-items:center;gap:7px;background:#fff;color:#667eea;padding:12px 24px;border-radius:var(--gr-radius-sm);font-weight:600;text-decoration:none;font-size:.93rem;transition:var(--gr-transition);box-shadow:0 2px 12px rgba(0,0,0,.12)}.gr-btn-white:hover{background:rgba(255,255,255,.93);color:#764ba2;transform:translateY(-2px);box-shadow:0 4px 20px rgba(0,0,0,.15)}.gr-btn-outline{display:inline-flex;align-items:center;gap:7px;background:rgba(255,255,255,.1);color:#fff;padding:12px 24px;border-radius:var(--gr-radius-sm);font-weight:600;text-decoration:none;font-size:.93rem;transition:var(--gr-transition);border:1.5px solid rgba(255,255,255,.4);backdrop-filter:blur(4px)}.gr-btn-outline:hover{background:rgba(255,255,255,.2);color:#fff;transform:translateY(-2px)}.gr-btn-primary{background:var(--gr-gradient);color:#fff;padding:12px 24px;border-radius:var(--gr-radius-sm);font-weight:600;text-decoration:none;font-size:.93rem;transition:var(--gr-transition);border:none;display:inline-flex;align-items:center;gap:7px;box-shadow:0 2px 12px rgba(102,126,234,.35)}.gr-btn-primary:hover{opacity:.92;transform:translateY(-2px);color:#fff;box-shadow:0 4px 20px rgba(102,126,234,.45)}.gr-section{padding:72px 0}.gr-section-badge{display:inline-flex;align-items:center;gap:6px;background:rgba(102,126,234,.1);color:var(--gr-primary);padding:6px 16px;border-radius:50px;font-size:.8rem;font-weight:600;margin-bottom:14px;border:1px solid rgba(102,126,234,.18)}.gr-section-title{font-family:var(--gr-font-heading);font-size:2rem;font-weight:700;color:#0f172a;margin-bottom:12px}.gr-section-subtitle{font-size:1.02rem;color:var(--gr-text-muted);max-width:600px;margin:0 auto;line-height:1.7}.gr-feature-card{background:#fff;border-radius:var(--gr-radius-lg);padding:32px 28px;transition:var(--gr-transition);border:1px solid var(--gr-border);height:100%}.gr-feature-card:hover{transform:translateY(-5px);box-shadow:var(--gr-shadow-md);border-color:transparent}.gr-icon-box{width:56px;height:56px;border-radius:14px;display:flex;align-items:center;justify-content:center;font-size:1.45rem;color:#fff;margin-bottom:18px}.gr-icon-box-primary{background:var(--gr-gradient)}.gr-icon-box-success{background:linear-gradient(135deg,#10b981,#059669)}.gr-icon-box-danger{background:linear-gradient(135deg,#ef4444,#dc2626)}.gr-icon-box-warning{background:linear-gradient(135deg,#f59e0b,#d97706)}.gr-icon-box-info{background:linear-gradient(135deg,#3b82f6,#2563eb)}.gr-icon-box-purple{background:linear-gradient(135deg,#8b5cf6,#7c3aed)}.gr-role-card{border-radius:var(--gr-radius-lg);color:#fff;overflow:hidden}.gr-role-card .card-body{padding:32px 28px}.gr-role-icon{width:64px;height:64px;background:rgba(255,255,255,.2);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:1.8rem;margin:0 auto 16px}.gr-road-step{background:#fff;border-radius:var(--gr-radius-lg);padding:32px 24px;text-align:center;border:1px solid var(--gr-border);transition:var(--gr-transition)}.gr-road-step:hover{transform:translateY(-4px);box-shadow:var(--gr-shadow-md)}.gr-road-step-badge{display:inline-block;background:var(--gr-gradient);color:#fff;padding:4px 14px;border-radius:50px;font-size:.75rem;font-weight:600;margin-bottom:16px}.gr-road-step-icon{width:70px;height:70px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:1.8rem;margin:0 auto 16px;color:#fff}.gr-road-step-primary{background:var(--gr-gradient)}.gr-road-step-warning{background:linear-gradient(135deg,#f59e0b,#d97706)}.gr-road-step-success{background:linear-gradient(135deg,#10b981,#059669)}.gr-cta{background:var(--gr-gradient);padding:80px 0}.gr-check-list{list-style:none;padding:0;margin:0}.gr-check-list li{display:flex;align-items:center;gap:10px;padding:6px 0;font-size:.93rem}.gr-check-list li i{color:var(--gr-success);font-size:1rem;flex-shrink:0}.gr-accordion .accordion-item{border:1px solid var(--gr-border);border-radius:var(--gr-radius)!important;margin-bottom:10px;overflow:hidden}.gr-accordion .accordion-button{font-weight:600;font-size:.93rem}.gr-accordion .accordion-button:not(.collapsed){background:rgba(102,126,234,.07);color:var(--gr-primary)}.gr-text-primary{color:var(--gr-primary)!important}.gr-ui-card{background:#fff;border-radius:var(--gr-radius-lg);padding:28px;border:1px solid var(--gr-border)}.gr-ui-icon{width:56px;height:56px;background:var(--gr-gradient);border-radius:14px;display:flex;align-items:center;justify-content:center;font-size:1.5rem;color:#fff;margin-bottom:16px}.gr-page-shell{min-height:60vh}.gr-page-hero{background:var(--gr-gradient);color:#fff;padding:64px 0}.gr-page-kicker{display:inline-flex;align-items:center;gap:6px;background:rgba(255,255,255,.15);color:#fff;padding:6px 16px;border-radius:50px;font-size:.8rem;font-weight:600;margin-bottom:16px}.gr-page-title{font-family:var(--gr-font-heading);font-size:2.1rem;font-weight:800;color:#fff;line-height:1.3;margin-bottom:12px}.gr-page-lead{font-size:1.02rem;color:rgba(255,255,255,.9);max-width:700px;line-height:1.7}.gr-page-section{padding:56px 0}.gr-contact-card{background:#fff;border-radius:var(--gr-radius-lg);border:1px solid var(--gr-border);transition:var(--gr-transition)}.gr-contact-card:hover{box-shadow:var(--gr-shadow-md);transform:translateY(-3px)}.gr-contact-icon{width:64px;height:64px;border-radius:50%;font-size:1.6rem;margin:0 auto 16px}.gr-contact-icon,.gr-social-btn{display:flex;align-items:center;justify-content:center;color:#fff}.gr-social-btn{width:42px;height:42px;border-radius:10px;font-size:1.2rem;flex-shrink:0;transition:var(--gr-transition)}.gr-social-btn:hover{transform:translateY(-3px)}.gr-social-fb{background:#1877f2}.gr-social-yt{background:#ff0000}.gr-social-li{background:#0a66c2}.gr-social-gh{background:#333}.gr-card{background:#fff;border-radius:var(--gr-radius-lg);border:1px solid var(--gr-border);box-shadow:var(--gr-shadow-sm)}.gr-form .form-control,.gr-form .form-select{border-radius:var(--gr-radius-sm);border:2px solid var(--gr-border);padding:10px 16px}.gr-form .form-control:focus,.gr-form .form-select:focus{border-color:var(--gr-primary);box-shadow:0 0 0 3px rgba(102,126,234,.12)}.gr-page-header{background:var(--gr-gradient);color:#fff;padding:48px 0}.gr-page-header h1{font-family:var(--gr-font-heading);font-size:2rem;font-weight:800;margin-bottom:8px}.gr-page-header p{opacity:.9;font-size:1.02rem}.gr-sidebar{width:260px;min-height:100vh;position:fixed;top:0;left:0;z-index:1040;display:flex;flex-direction:column;overflow-y:auto;overflow-x:hidden;transition:transform .28s cubic-bezier(.4,0,.2,1);scrollbar-width:thin;scrollbar-color:rgba(255,255,255,.15) transparent}.gr-sidebar::-webkit-scrollbar{width:3px}.gr-sidebar::-webkit-scrollbar-thumb{background:rgba(255,255,255,.18);border-radius:4px}.gr-sidebar-brand{padding:20px 18px 16px;border-bottom:1px solid rgba(255,255,255,.1);flex-shrink:0}.gr-sidebar-nav{flex:1;padding:10px 0 8px}.gr-nav-section{font-size:.65rem;font-weight:700;letter-spacing:.1em;color:rgba(255,255,255,.38);padding:14px 18px 5px;text-transform:uppercase}.gr-nav-link{display:flex;align-items:center;gap:10px;padding:9px 12px 9px 16px;color:rgba(255,255,255,.72);text-decoration:none;font-size:.855rem;font-weight:500;margin:1px 8px;border-radius:10px;transition:var(--gr-transition);position:relative}.gr-nav-link:hover{background:rgba(255,255,255,.12);color:#fff;transform:translateX(3px)}.gr-nav-link.active,.gr-nav-link[aria-current=page]{background:rgba(255,255,255,.18);color:#fff;font-weight:600;box-shadow:0 2px 10px rgba(0,0,0,.15)}.gr-nav-link.active:before{content:"";position:absolute;left:0;top:50%;transform:translateY(-50%);width:3px;height:60%;background:rgba(255,255,255,.8);border-radius:0 3px 3px 0}.gr-nav-link i{font-size:1rem;width:22px;flex-shrink:0;text-align:center;opacity:.85}.gr-nav-link.active i,.gr-nav-link:hover i{opacity:1}.gr-sidebar-footer{padding:12px 8px;border-top:1px solid rgba(255,255,255,.1);flex-shrink:0}.gr-sidebar-footer .gr-nav-link{color:rgba(255,255,255,.55)}.gr-sidebar-footer .gr-nav-link:hover{color:#fca5a5;background:rgba(239,68,68,.15)}.gr-main{margin-left:260px;min-height:100vh;display:flex;flex-direction:column;background:var(--gr-bg)}.gr-topbar{background:rgba(255,255,255,.9);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-bottom:1px solid rgba(229,231,235,.8);padding:0 22px;height:60px;display:flex;align-items:center;justify-content:space-between;position:sticky;top:0;z-index:1030;box-shadow:0 1px 6px rgba(0,0,0,.04)}.gr-topbar-divider{width:4px;height:22px;border-radius:4px;flex-shrink:0}.gr-content{padding:22px;flex:1}.gr-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,.45);z-index:1039;backdrop-filter:blur(2px)}.gr-overlay.show{display:block;animation:fadeIn .2s ease}.gr-bottom-nav{display:none;position:fixed;bottom:0;left:0;right:0;z-index:1035;background:rgba(255,255,255,.95);border-top:1px solid rgba(229,231,235,.9);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);box-shadow:0 -2px 16px rgba(0,0,0,.08)}.gr-bottom-nav-inner{display:flex;justify-content:space-around;align-items:center;padding:4px 0 env(safe-area-inset-bottom,0)}.gr-bnav-item{display:flex;flex-direction:column;align-items:center;gap:2px;padding:7px 10px;color:#9ca3af;text-decoration:none;font-size:.62rem;font-weight:600;border-radius:10px;transition:var(--gr-transition);min-width:48px;letter-spacing:.02em}.gr-bnav-item i{font-size:1.35rem}.gr-bnav-item:hover{color:var(--gr-primary)}.card{border:none!important;border-radius:var(--gr-radius)!important;box-shadow:var(--gr-shadow-sm);background:#fff}.card:hover{box-shadow:var(--gr-shadow)}.card-header{background:#fff!important;border-bottom:1px solid #f1f3f5!important;font-weight:600;padding:16px 20px;border-radius:var(--gr-radius) var(--gr-radius) 0 0!important}.gr-stat-card{background:#fff;border-radius:var(--gr-radius);padding:20px 18px;box-shadow:var(--gr-shadow-sm);transition:var(--gr-transition);border:1px solid rgba(0,0,0,.03);position:relative;overflow:hidden}.gr-stat-card:after{content:"";position:absolute;top:0;left:0;right:0;height:3px;border-radius:var(--gr-radius) var(--gr-radius) 0 0}.gr-stat-card:hover{transform:translateY(-3px);box-shadow:var(--gr-shadow-md)}.gr-stat-icon{width:44px;height:44px;border-radius:11px;display:flex;align-items:center;justify-content:center;font-size:1.1rem;margin-bottom:12px}.gr-stat-value{font-size:1.75rem;font-weight:800;line-height:1;margin-bottom:4px;font-family:var(--gr-font-heading)}.gr-stat-label{font-size:.78rem;color:var(--gr-text-muted);font-weight:500}.table{--bs-table-hover-bg:rgba(0,0,0,0.02)}.table thead th{background:#f8f9fc;border-bottom:2px solid #eef0f3!important;font-weight:700;text-transform:uppercase;font-size:.72rem;color:#8896ab;letter-spacing:.06em;white-space:nowrap;padding:11px 14px}.table tbody td{vertical-align:middle;border-bottom:1px solid #f5f6f8;font-size:.875rem;padding:11px 14px}.table tbody tr:last-child td{border-bottom:none}.badge{padding:5px 11px;font-weight:600;border-radius:7px;font-size:.73rem;letter-spacing:.01em}.badge.rounded-pill{border-radius:50px!important}.form-control,.form-select{border-radius:var(--gr-radius-sm);border:1.5px solid #e2e8f0;padding:9px 14px;font-size:.9rem;transition:var(--gr-transition);background:#fafbfc}.form-control:focus,.form-select:focus{border-color:var(--gr-primary);box-shadow:0 0 0 3px rgba(102,126,234,.1);background:#fff;outline:none}.form-label{font-weight:600;font-size:.85rem;color:#374151;margin-bottom:6px}.btn{border-radius:var(--gr-radius-sm);font-weight:600;transition:var(--gr-transition);font-size:.875rem}.btn:active{transform:scale(.97)}.btn-primary{background:var(--gr-gradient);border:none;color:#fff;box-shadow:0 2px 8px rgba(102,126,234,.3)}.btn-primary:focus,.btn-primary:hover{background:linear-gradient(135deg,#5a6fd6,#6a3f92);box-shadow:0 4px 16px rgba(102,126,234,.4);color:#fff}.btn-success{background:linear-gradient(135deg,#10b981,#059669);border:none;color:#fff}.btn-danger{background:linear-gradient(135deg,#ef4444,#dc2626);border:none;color:#fff}.btn-warning{background:linear-gradient(135deg,#f59e0b,#d97706);border:none;color:#fff}.btn-info{background:linear-gradient(135deg,#3b82f6,#2563eb);border:none;color:#fff}.btn-outline-primary{border:1.5px solid var(--gr-primary);color:var(--gr-primary)}.btn-outline-primary:hover{background:var(--gr-primary);color:#fff}@media (max-width:991.98px){.gr-sidebar{transform:translateX(-100%);box-shadow:none;width:260px}.gr-sidebar.show{transform:translateX(0);box-shadow:6px 0 32px rgba(0,0,0,.22)}.gr-main{margin-left:0!important;padding-bottom:70px}.gr-bottom-nav{display:block}.gr-content{padding:16px}.gr-topbar{padding:0 16px}}@media (min-width:992px){.gr-sidebar{transform:translateX(0)!important}.gr-content{padding:24px 26px}}@media (max-width:576px){.gr-stat-value{font-size:1.4rem}.card{border-radius:10px!important}}@keyframes fadeInDown{0%{opacity:0;transform:translateY(-18px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeInUp{0%{opacity:0;transform:translateY(18px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideInLeft{0%{opacity:0;transform:translateX(-20px)}to{opacity:1;transform:translateX(0)}}@keyframes pulse-dot{0%,to{transform:scale(1);opacity:1}50%{transform:scale(1.3);opacity:.7}}.animate-fade-in-down{animation:fadeInDown .5s ease both}.animate-fade-in-up{animation:fadeInUp .5s ease both}.animate-fade-in{animation:fadeIn .4s ease both}.animate-slide-in-left{animation:slideInLeft .45s ease both}.gr-ellipsis{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.gr-divider{border:none;border-top:1px solid var(--gr-border);margin:16px 0}.gr-skeleton{background:linear-gradient(90deg,#f1f3f5 25%,#e9ecef 50%,#f1f3f5 75%);background-size:200% 100%;animation:skeleton-shimmer 1.5s infinite;border-radius:6px}@keyframes skeleton-shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.gr-dot-live{display:inline-block;width:8px;height:8px;border-radius:50%;background:#10b981;animation:pulse-dot 1.8s ease-in-out infinite}img.gr-avatar{-o-object-fit:cover;object-fit:cover;border-radius:50%}img.gr-logo{-o-object-fit:contain;object-fit:contain}.gr-main-institute .gr-bnav-item.active,.gr-main-institute .gr-bnav-item[data-active=true]{color:#0a4d8c}.gr-main-student .gr-bnav-item.active,.gr-main-student .gr-bnav-item[data-active=true]{color:#5d27a9}.gr-main-teacher .gr-bnav-item.active,.gr-main-teacher .gr-bnav-item[data-active=true]{color:#059669}.gr-main-admin .gr-bnav-item.active,.gr-main-admin .gr-bnav-item[data-active=true]{color:#4f46e5}.gr-page-heading{font-family:var(--gr-font-heading);font-size:1.3rem;font-weight:700;color:#0f172a;display:flex;align-items:center;gap:10px;margin-bottom:0}.gr-page-heading i{font-size:1.2rem}.gr-empty-state{text-align:center;padding:48px 24px}.gr-empty-icon{width:72px;height:72px;background:#f3f4f6;font-size:1.8rem;margin:0 auto 16px;color:#9ca3af}.gr-empty-icon,.gr-fab{border-radius:50%;display:flex;align-items:center;justify-content:center}.gr-fab{position:fixed;bottom:82px;right:18px;width:52px;height:52px;background:var(--gr-gradient);color:#fff;font-size:1.4rem;box-shadow:0 4px 20px rgba(102,126,234,.4);z-index:1034;text-decoration:none;transition:var(--gr-transition)}.gr-fab:hover{transform:scale(1.08) rotate(8deg);color:#fff}@media (min-width:992px){.gr-fab{display:none}}.gr-topbar-label{font-weight:700;font-size:.9rem;letter-spacing:.01em}.table-sticky thead th{position:sticky;top:0;z-index:2;background:#f8f9fc}.form-floating>.form-control:not(:-moz-placeholder){padding-top:1.25rem;padding-bottom:.25rem}.form-floating>.form-control:focus,.form-floating>.form-control:not(:placeholder-shown){padding-top:1.25rem;padding-bottom:.25rem}.alert{border:none;border-radius:var(--gr-radius);font-size:.875rem}.alert-success{background:#ecfdf5;color:#065f46}.alert-danger{background:#fef2f2;color:#991b1b}.alert-warning{background:#fffbeb;color:#92400e}.alert-info{background:#eff6ff;color:#1e40af}.modal-content{border:none;border-radius:var(--gr-radius-lg);box-shadow:var(--gr-shadow-lg)}.modal-header{border-bottom:1px solid #f1f3f5;border-radius:var(--gr-radius-lg) var(--gr-radius-lg) 0 0}.modal-footer{border-top:1px solid #f1f3f5}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:#d1d5db;border-radius:6px}::-webkit-scrollbar-thumb:hover{background:#9ca3af}