:root{--navy-900:#0a1628;--navy-800:#0f1d36;--navy-700:#152847;--navy-600:#1c3461;--navy-500:#1e3a5f;--navy-400:#2a4a7f;--navy-300:#3d6098;--red-600:#c41e24;--red-500:#d4272e;--red-400:#e03338;--red-300:#ef5350;--silver-400:#8a8c91;--silver-300:#a8a9ad;--silver-200:#c4c5c9;--silver-100:#e8e9ed;--green-500:#2e7d32;--green-400:#43a047;--gold-500:#c49a2a;--gold-400:#d4aa3a;--white:#fff;--off-white:#f8f9fc;--text-primary:#1a1d23;--text-secondary:#5a5e6a;--text-muted:#8e92a0;--shadow-sm:0 1px 3px #0a162814;--shadow-md:0 4px 16px #0a16281f;--shadow-lg:0 8px 32px #0a162829;--shadow-xl:0 16px 48px #0a162833;--shadow-glow:0 0 40px #d4272e26;--font-display:"Playfair Display",Georgia,serif;--font-body:"Inter",-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;--space-xs:4px;--space-sm:8px;--space-md:16px;--space-lg:24px;--space-xl:32px;--space-2xl:48px;--space-3xl:64px;--radius-sm:6px;--radius-md:10px;--radius-lg:16px;--radius-xl:24px;--radius-full:9999px;--transition-fast:150ms cubic-bezier(0.4,0,0.2,1);--transition-base:250ms cubic-bezier(0.4,0,0.2,1);--transition-slow:400ms cubic-bezier(0.4,0,0.2,1)}*,:after,:before{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;scroll-behavior:smooth}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:#0a1628;background:var(--navy-900);color:#1a1d23;color:var(--text-primary);font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-family:var(--font-body);line-height:1.6;overflow-x:hidden}button,input,select,textarea{font-family:inherit;font-size:inherit}a{color:inherit;text-decoration:none}img{display:block;max-width:100%}.login-page{min-height:100vh}.login-brand-panel,.login-page{display:flex;overflow:hidden;position:relative}.login-brand-panel{align-items:center;background:linear-gradient(160deg,var(--navy-900) 0,var(--navy-700) 40%,var(--navy-600) 100%);flex:1 1;flex-direction:column;justify-content:center;padding:var(--space-3xl)}.login-brand-panel:before{animation:pulse-glow 8s ease-in-out infinite;background:radial-gradient(circle,#d4272e14 0,#0000 70%);border-radius:50%;content:"";height:60%;left:-10%;position:absolute;top:-20%;width:60%}.login-brand-panel:after{animation:pulse-glow 10s ease-in-out infinite reverse;background:radial-gradient(circle,#2a4a7f26 0,#0000 70%);border-radius:50%;bottom:-15%;content:"";height:50%;position:absolute;right:-15%;width:50%}@keyframes pulse-glow{0%,to{opacity:.5;transform:scale(1)}50%{opacity:1;transform:scale(1.05)}}@keyframes slide-stats{0%{transform:translateX(0)}to{transform:translateX(-50%)}}.brand-pattern{background-image:linear-gradient(#ffffff05 1px,#0000 0),linear-gradient(90deg,#ffffff05 1px,#0000 0);background-size:60px 60px}.brand-pattern,.floating-shapes{inset:0;pointer-events:none;position:absolute}.floating-shapes{overflow:hidden}.shape{animation:float-shape 20s ease-in-out infinite;border:1px solid #a8a9ad14;border-radius:var(--radius-md);position:absolute}.shape-1{animation-delay:0s;background:#a8a9ad0a;height:100px;left:15%;top:10%;width:80px}.shape-1,.shape-2{clip-path:polygon(50% 0,100% 25%,100% 75%,50% 100%,0 75%,0 25%)}.shape-2{animation-delay:-5s;background:#d4272e0a;bottom:20%;height:150px;left:10%;width:120px}.shape-3{animation-delay:-10s;background:#2a4a7f0f;height:75px;right:15%;top:30%;width:60px}.shape-3,.shape-4{clip-path:polygon(50% 0,100% 25%,100% 75%,50% 100%,0 75%,0 25%)}.shape-4{animation-delay:-15s;background:#a8a9ad08;bottom:10%;height:110px;right:20%;width:90px}@keyframes float-shape{0%,to{transform:translateY(0) rotate(0deg)}25%{transform:translateY(-20px) rotate(5deg)}50%{transform:translateY(-10px) rotate(-3deg)}75%{transform:translateY(-25px) rotate(3deg)}}.brand-content{max-width:480px;position:relative;text-align:center;z-index:2}.brand-logo-container{animation:fade-in-up .8s ease-out;background:var(--white);border-radius:var(--radius-xl);box-shadow:var(--shadow-md);display:inline-block;margin-bottom:var(--space-xl);padding:var(--space-sm) var(--space-lg)}.brand-logo{height:auto;margin:0 auto;transition:transform var(--transition-slow);width:260px}.brand-logo:hover{transform:scale(1.05)}.brand-title{animation:fade-in-up .8s ease-out .2s both;color:var(--white);font-family:var(--font-display);font-size:2.75rem;font-weight:700;letter-spacing:2px;line-height:1.2;margin-bottom:var(--space-sm)}.brand-title span{display:block}.brand-divider{animation:fade-in-up .8s ease-out .3s both;background:linear-gradient(90deg,var(--red-500),var(--red-400));border-radius:var(--radius-full);height:3px;margin:var(--space-md) auto;width:80px}.brand-subtitle{animation:fade-in-up .8s ease-out .4s both;background:var(--red-500);border-radius:var(--radius-sm);color:var(--white);display:inline-block;font-family:var(--font-body);font-size:.95rem;font-weight:600;letter-spacing:3px;padding:var(--space-sm) var(--space-lg);text-transform:uppercase}.brand-tagline{animation:fade-in-up .8s ease-out .5s both;color:var(--silver-300);font-size:1rem;font-weight:300;letter-spacing:.5px;margin-top:var(--space-xl)}.brand-tagline em{color:var(--gold-400);font-style:normal;font-weight:500}.brand-stats{animation:fade-in-up .8s ease-out .7s both;border-radius:12px;bottom:var(--space-xl);left:0;margin:0 auto;max-width:600px;overflow:hidden;padding:0;position:absolute;right:0;width:90%;z-index:2}.stats-scroll-container{align-items:center;animation:slide-stats 28s linear infinite;display:flex;gap:var(--space-2xl);justify-content:center}.stat-item{flex-shrink:0;min-width:fit-content;text-align:center}.stat-number{color:var(--white);font-family:var(--font-display);font-size:1.75rem;font-weight:700}.stat-label{color:var(--silver-400);font-size:.72rem;letter-spacing:1.5px;margin-top:2px;text-transform:uppercase}.login-form-panel{align-items:center;background:var(--white);display:flex;flex-direction:column;justify-content:center;min-width:520px;padding:var(--space-3xl) var(--space-2xl);position:relative;width:520px}.login-form-panel:before{background:linear-gradient(90deg,var(--red-500),var(--red-400),var(--gold-500));content:"";height:4px;left:0;position:absolute;right:0;top:0}.login-form-wrapper{max-width:380px;width:100%}.mobile-logo{display:none;margin-bottom:var(--space-xl);text-align:center}.mobile-logo img{margin:0 auto var(--space-sm);width:80px}.mobile-logo-title{color:var(--navy-800);font-family:var(--font-display);font-size:1.25rem;font-weight:700}.login-header{animation:fade-in-up .6s ease-out;margin-bottom:var(--space-xl)}.login-welcome{color:var(--red-500);font-size:.85rem;font-weight:500;letter-spacing:2px;margin-bottom:var(--space-xs);text-transform:uppercase}.login-heading{color:var(--navy-800);font-family:var(--font-display);font-size:2rem;font-weight:700;line-height:1.3}.login-description{color:var(--text-secondary);font-size:.9rem;margin-top:var(--space-sm)}.role-selector{animation:fade-in-up .6s ease-out .1s both;background:var(--off-white);border-radius:var(--radius-md);display:flex;margin-bottom:var(--space-lg);padding:4px}.role-tab{background:#0000;border:none;border-radius:var(--radius-sm);color:var(--text-secondary);cursor:pointer;flex:1 1;font-size:.82rem;font-weight:500;padding:var(--space-sm) var(--space-md);position:relative;transition:all var(--transition-base)}.role-tab:hover{color:var(--navy-700)}.role-tab.active{background:var(--white);box-shadow:var(--shadow-sm);color:var(--navy-800);font-weight:600}.role-tab.active:after{background:var(--red-500);border-radius:var(--radius-full);bottom:0;content:"";height:2px;left:50%;position:absolute;transform:translateX(-50%);width:20px}.form-group{animation:fade-in-up .6s ease-out calc(.15s*var(--i)) both;margin-bottom:var(--space-md)}.form-label{color:var(--navy-800);display:block;font-size:.82rem;font-weight:600;letter-spacing:.3px;margin-bottom:var(--space-sm)}.input-wrapper{position:relative}.input-icon{color:var(--silver-400);height:18px;left:14px;pointer-events:none;position:absolute;top:50%;transform:translateY(-50%);transition:color var(--transition-fast);width:18px}.form-input{background:var(--white);border:1.5px solid var(--silver-100);border-radius:var(--radius-md);color:var(--text-primary);font-size:.9rem;outline:none;padding:13px 14px 13px 44px;transition:all var(--transition-base);width:100%}.form-input::placeholder{color:var(--text-muted);font-weight:400}.form-input:hover{border-color:var(--silver-300)}.form-input:focus{border-color:var(--navy-500);box-shadow:0 0 0 3px #1e3a5f1a}.form-input:focus~.input-icon{color:var(--navy-500)}.password-toggle{align-items:center;background:none;border:none;color:var(--silver-400);cursor:pointer;display:flex;justify-content:center;padding:4px;position:absolute;right:12px;top:50%;transform:translateY(-50%);transition:color var(--transition-fast)}.password-toggle:hover{color:var(--navy-500)}.form-options{align-items:center;animation:fade-in-up .6s ease-out .4s both;display:flex;justify-content:space-between;margin-bottom:var(--space-lg)}.remember-checkbox{align-items:center;cursor:pointer;display:flex;gap:var(--space-sm)}.remember-checkbox input[type=checkbox]{accent-color:var(--navy-600);cursor:pointer;height:16px;width:16px}.remember-checkbox span{color:var(--text-secondary);font-size:.82rem}.forgot-link{background:none;border:none;color:var(--red-500);cursor:pointer;font-size:.82rem;font-weight:500;transition:color var(--transition-fast)}.forgot-link:hover{color:var(--red-600);text-decoration:underline}.login-btn{animation:fade-in-up .6s ease-out .45s both;background:linear-gradient(135deg,var(--navy-700) 0,var(--navy-800) 100%);border:none;border-radius:var(--radius-md);color:var(--white);cursor:pointer;font-size:.95rem;font-weight:600;letter-spacing:.5px;overflow:hidden;padding:14px;position:relative;transition:all var(--transition-base);width:100%}.login-btn:before{background:linear-gradient(135deg,var(--red-500) 0,var(--red-600) 100%);content:"";height:100%;left:-100%;position:absolute;top:0;transition:left var(--transition-slow);width:100%}.login-btn:hover:before{left:0}.login-btn:hover{box-shadow:var(--shadow-lg);transform:translateY(-1px)}.login-btn:active{transform:translateY(0)}.login-btn span{align-items:center;display:flex;gap:var(--space-sm);justify-content:center;position:relative;z-index:1}.btn-spinner{animation:spin .6s linear infinite;border:2px solid #ffffff4d;border-radius:50%;border-top:2px solid var(--white);height:18px;width:18px}.login-divider{align-items:center;animation:fade-in-up .6s ease-out .5s both;display:flex;gap:var(--space-md);margin:var(--space-lg) 0}.login-divider:after,.login-divider:before{background:var(--silver-100);content:"";flex:1 1;height:1px}.login-divider span{color:var(--text-muted);font-size:.78rem;font-weight:500;letter-spacing:1px;text-transform:uppercase}.login-help{animation:fade-in-up .6s ease-out .55s both;text-align:center}.login-help p{color:var(--text-secondary);font-size:.82rem}.login-help a{color:var(--navy-600);font-weight:600;transition:color var(--transition-fast)}.login-help a:hover{color:var(--red-500)}.login-footer{bottom:var(--space-lg);left:50%;position:absolute;text-align:center;transform:translateX(-50%);white-space:nowrap}.login-footer p{color:var(--text-muted);font-size:.72rem}@keyframes fade-in-up{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}.error-message{align-items:center;animation:shake .4s ease-in-out;background:#fef2f2;border:1px solid #fecaca;border-radius:var(--radius-sm);display:flex;gap:var(--space-sm);margin-bottom:var(--space-md);padding:var(--space-sm) var(--space-md)}.error-message svg{color:var(--red-500);flex-shrink:0}.error-message p{color:var(--red-600);font-size:.82rem;font-weight:500}@keyframes shake{0%,to{transform:translateX(0)}25%{transform:translateX(-5px)}75%{transform:translateX(5px)}}.success-overlay{align-items:center;animation:fade-in .3s ease-out;background:#0a1628d9;display:flex;inset:0;justify-content:center;position:fixed;z-index:100}@keyframes fade-in{0%{opacity:0}to{opacity:1}}.success-content{animation:scale-in .4s ease-out;background:var(--white);border-radius:var(--radius-lg);box-shadow:var(--shadow-xl);max-width:360px;padding:var(--space-2xl);text-align:center}@keyframes scale-in{0%{opacity:0;transform:scale(.9)}to{opacity:1;transform:scale(1)}}.success-icon{align-items:center;background:linear-gradient(135deg,var(--green-400),var(--green-500));border-radius:50%;display:flex;height:64px;justify-content:center;margin:0 auto var(--space-md);width:64px}.success-icon svg{color:var(--white)}.success-content h3{color:var(--navy-800);font-family:var(--font-display);font-size:1.3rem;margin-bottom:var(--space-sm)}.success-content p{color:var(--text-secondary);font-size:.88rem}@media (max-width:1024px){.login-brand-panel{display:none}.login-form-panel{background:linear-gradient(170deg,var(--off-white) 0,var(--white) 100%);min-height:100vh;min-width:0;min-width:auto;width:100%}.mobile-logo{display:block}.brand-stats{display:none}}@media (max-width:480px){.login-form-panel{padding:var(--space-xl) var(--space-md)}.login-heading{font-size:1.6rem}.role-selector{flex-wrap:wrap}}.search-filters-row{align-items:center;display:flex;flex-wrap:wrap;gap:var(--space-lg);margin-bottom:var(--space-lg)}.search-filters-row .search-bar{flex:1 1;margin-bottom:0;min-width:300px}.filter-controls{display:flex;gap:var(--space-sm)}.fee-filter-row{grid-gap:var(--space-lg);align-items:stretch;display:grid;gap:var(--space-lg);grid-template-columns:repeat(2,minmax(0,1fr))}.fee-filter-row .search-bar{min-width:0;width:100%}.fee-filter-controls{grid-gap:var(--space-md);display:grid;gap:var(--space-md);grid-column:1/-1;grid-template-columns:repeat(5,minmax(0,1fr));width:100%}.fee-filter-controls .filter-apply-btn,.fee-filter-controls .filter-clear-btn,.fee-filter-controls .filter-select{min-width:0;width:100%}.fee-filter-controls .filter-apply-btn,.fee-filter-controls .filter-clear-btn{justify-content:center}.student-record-filter-row{grid-gap:var(--space-lg);align-items:stretch;display:grid;gap:var(--space-lg);grid-template-columns:1fr}.student-record-filter-row .search-bar{min-width:0;width:100%}.student-record-filter-controls{grid-gap:var(--space-md);display:grid;gap:var(--space-md);grid-template-columns:repeat(6,minmax(0,1fr));width:100%}.student-record-filter-controls .btn-danger,.student-record-filter-controls .csv-download-btn,.student-record-filter-controls .filter-apply-btn,.student-record-filter-controls .filter-clear-btn,.student-record-filter-controls .filter-select{min-width:0;width:100%}.student-record-filter-controls .btn-danger,.student-record-filter-controls .csv-download-btn,.student-record-filter-controls .filter-apply-btn,.student-record-filter-controls .filter-clear-btn{justify-content:center}.filter-select{background:var(--white);border:1.5px solid var(--silver-100);border-radius:var(--radius-md);color:var(--text-primary);cursor:pointer;font-size:.88rem;outline:none;padding:11px 16px;transition:all var(--transition-base)}@media (max-width:900px){.fee-filter-row{grid-template-columns:1fr}.fee-filter-controls,.student-record-filter-controls{grid-template-columns:repeat(2,minmax(0,1fr))}}@media (max-width:560px){.fee-filter-controls,.student-record-filter-controls{grid-template-columns:1fr}}.filter-select:hover{border-color:var(--silver-300)}.filter-select:focus{border-color:var(--navy-500);box-shadow:0 0 0 3px #1e3a5f1a}.action-buttons{display:flex;gap:var(--space-xs)}.delete-btn-small,.edit-btn-small,.withdraw-btn-small{align-items:center;border:none;border-radius:var(--radius-sm);cursor:pointer;display:flex;height:34px;justify-content:center;transition:all var(--transition-base);width:34px}.edit-btn-small{background:var(--off-white);color:var(--navy-600)}.edit-btn-small:hover{background:var(--navy-50);color:var(--navy-800);transform:translateY(-2px)}.delete-btn-small{background:#fef2f2;color:var(--red-500)}.delete-btn-small:hover{background:#fee2e2;color:var(--red-600);transform:translateY(-2px)}.withdraw-btn-small{background:#fffbeb;color:#b45309}.withdraw-btn-small:hover{background:#fef3c7;color:#92400e;transform:translateY(-2px)}.delete-btn-small svg,.edit-btn-small svg,.withdraw-btn-small svg{height:16px;width:16px}.withdrawal-modal{max-width:620px}.withdrawal-modal-body{grid-gap:var(--space-md);display:grid;gap:var(--space-md)}.withdrawal-student-summary{align-items:center;background:var(--off-white);border:1px solid var(--silver-100);border-radius:var(--radius-md);display:flex;gap:var(--space-md);justify-content:space-between;padding:var(--space-md)}.withdrawal-student-summary strong{color:var(--navy-800);font-size:.98rem}.withdrawal-student-summary span{color:var(--text-secondary);font-size:.85rem;font-weight:700}.withdrawal-textarea{min-height:110px;resize:vertical}.withdrawal-note{background:#fffbeb;border-left:3px solid var(--gold-500);border-radius:var(--radius-sm);color:var(--text-secondary);margin:0;padding:var(--space-sm) var(--space-md)}.csv-preview-note{color:var(--text-secondary);font-size:.86rem;font-weight:600;margin:var(--space-md) var(--space-lg) var(--space-lg)}.dashboard{background:var(--off-white);display:flex;min-height:100vh}.sidebar{background:linear-gradient(180deg,var(--navy-900) 0,var(--navy-800) 100%);bottom:0;display:flex;flex-direction:column;left:0;min-width:270px;overflow:hidden;position:fixed;top:0;transition:transform var(--transition-base);width:270px;z-index:50}.sidebar-header{align-items:center;border-bottom:1px solid #ffffff14;display:flex;gap:var(--space-md);padding:var(--space-lg) var(--space-lg)}.sidebar-logo{filter:drop-shadow(0 2px 8px rgba(0,0,0,.3));height:48px;object-fit:contain;width:48px}.sidebar-brand{flex:1 1}.sidebar-brand h2{color:var(--white);font-family:var(--font-display);font-size:1rem;font-weight:700;line-height:1.2}.sidebar-brand span{color:var(--red-400);font-size:.68rem;font-weight:600;letter-spacing:1.5px;text-transform:uppercase}.sidebar-nav{-ms-overflow-style:none;flex:1 1;overflow-y:auto;padding:var(--space-lg) var(--space-md) var(--space-xl);scrollbar-width:none}.sidebar-nav::-webkit-scrollbar{display:none;height:0;width:0}.nav-section-title{color:var(--silver-400);font-size:.68rem;font-weight:600;letter-spacing:1.5px;margin-bottom:var(--space-sm);margin-top:var(--space-lg);padding:0 var(--space-sm);text-transform:uppercase}.nav-section-title:first-child{margin-top:0}.nav-item{align-items:center;background:none;border:none;border-radius:var(--radius-md);color:var(--silver-200);cursor:pointer;display:flex;font-size:.88rem;font-weight:500;gap:var(--space-md);min-height:44px;overflow:hidden;padding:11px var(--space-md);position:relative;text-align:left;transition:all var(--transition-fast);width:100%}.nav-item:hover{background:#ffffff0f;color:var(--white)}.nav-item.active{background:#ffffff14;box-shadow:inset 3px 0 0 var(--red-500);color:var(--white)}.nav-item.active:before{display:none}.nav-item svg{flex-shrink:0;height:20px;opacity:.8;width:20px}.nav-item.active svg,.nav-item:hover svg{opacity:1}.nav-badge{background:var(--red-500);border-radius:var(--radius-full);color:var(--white);font-size:.68rem;font-weight:700;margin-left:auto;min-width:22px;padding:2px 8px;text-align:center}.sidebar-footer{border-top:1px solid #ffffff14;padding:var(--space-md)}.sidebar-user{gap:var(--space-md);padding:var(--space-sm)}.sidebar-user,.user-avatar{align-items:center;display:flex}.user-avatar{background:linear-gradient(135deg,var(--navy-500),var(--navy-400));border-radius:50%;color:var(--white);font-size:.9rem;font-weight:700;height:40px;justify-content:center;width:40px}.user-info{flex:1 1;min-width:0}.user-info h4{color:var(--white);font-size:.85rem;font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.user-info span{color:var(--silver-400);font-size:.72rem}.logout-btn{align-items:center;background:none;border:none;border-radius:var(--radius-md);color:var(--silver-300);cursor:pointer;display:flex;font-size:.85rem;font-weight:500;gap:var(--space-sm);margin-top:var(--space-sm);padding:10px var(--space-md);transition:all var(--transition-fast);width:100%}.logout-btn:hover{background:#d4272e1f;color:var(--red-400)}.logout-btn svg{flex-shrink:0;height:18px;width:18px}.card-header-flex{align-items:center;display:flex;justify-content:space-between;margin-bottom:1rem}.main-content{display:flex;flex:1 1;flex-direction:column;margin-left:270px;min-height:100vh}.topbar{background:var(--white);border-bottom:1px solid var(--silver-100);padding:var(--space-md) var(--space-xl);z-index:40}.topbar-left{gap:var(--space-md)}.menu-toggle{border-radius:var(--radius-sm);color:var(--navy-800);padding:var(--space-sm)}.menu-toggle:hover{background:var(--off-white)}.page-title{color:var(--navy-800);font-family:var(--font-display);font-size:1.35rem;font-weight:700}.topbar-right{gap:var(--space-md)}.topbar-date{color:var(--text-secondary);font-size:.82rem;gap:var(--space-sm)}.topbar-date svg{color:var(--silver-400);height:16px;width:16px}.campus-detail-container,.dashboard-content{flex:1 1;padding:var(--space-xl)}.detail-title{font-weight:700}.detail-content{grid-gap:2rem;display:grid;gap:2rem;grid-template-columns:1fr 1fr;margin-top:2rem}.detail-section{background:#fff;border-radius:12px;box-shadow:0 2px 8px #00000014}.dashboard-content.dashboard-home{display:flex;flex-direction:column;gap:var(--space-xl);margin:0;max-width:none;padding:var(--space-xl);width:100%}.dashboard-overview-hero{align-items:center;background:linear-gradient(135deg,#0f1d36fa,#1e3a5feb),linear-gradient(90deg,#c49a2a2e,#d4272e1f);border-radius:var(--radius-lg);box-shadow:0 18px 42px #0f172a24;color:var(--white);display:flex;min-height:220px;padding:var(--space-xl)}.dashboard-overview-kicker,.dashboard-section-kicker{color:var(--gold-400);display:inline-block;font-size:.74rem;font-weight:800;letter-spacing:.08em;margin-bottom:8px;text-transform:uppercase}.dashboard-overview-copy h2{color:var(--white);font-family:var(--font-display);font-size:2rem;line-height:1.15;margin:0 0 10px}.dashboard-overview-copy p{color:#ffffffd6;font-size:1rem;margin:0;max-width:720px}.dashboard-overview-meta{align-items:center;color:#ffffffb8;display:flex;flex-wrap:wrap;font-size:.82rem;font-weight:700;gap:var(--space-md);margin-top:var(--space-lg)}.dashboard-overview-panel{background:#ffffff1a;border:1px solid #ffffff2e;border-radius:var(--radius-lg);padding:var(--space-lg)}.dashboard-overview-panel strong{display:block;font-family:var(--font-display);font-size:2.4rem;line-height:1}.dashboard-overview-panel span{color:#ffffffc7;display:block;font-size:.78rem;font-weight:800;letter-spacing:.05em;margin-top:8px;text-transform:uppercase}.dashboard-overview-panel p{color:#ffffffc2;font-size:.88rem;margin:var(--space-md) 0 0}.dashboard-section{display:flex;flex-direction:column;gap:var(--space-md)}.dashboard-section-header{align-items:flex-end;display:flex;gap:var(--space-md);justify-content:space-between}.dashboard-section-header h2{color:var(--navy-900);font-family:var(--font-display);font-size:1.42rem;line-height:1.2;margin:0}.dashboard-section-kicker{color:var(--red-500)}.dashboard-stats-grid{grid-template-columns:repeat(4,minmax(180px,1fr));margin-bottom:0}.dashboard-stats-grid .stat-card{align-items:center;display:flex;gap:var(--space-md);min-height:150px;padding:var(--space-lg)}.dashboard-stats-grid .stat-card-icon{flex:0 0 auto;margin-bottom:0}.dashboard-stats-grid .stat-card h3{margin-bottom:4px}.dashboard-action-grid{grid-template-columns:repeat(4,minmax(210px,1fr));margin-bottom:0}.dashboard-action-grid .action-card{min-height:210px}.welcome-banner{align-items:center;animation:fade-in-up .6s ease-out;background:linear-gradient(135deg,var(--navy-800) 0,var(--navy-600) 100%);border-radius:var(--radius-lg);display:flex;justify-content:space-between;margin-bottom:var(--space-xl);overflow:hidden;padding:var(--space-xl) var(--space-2xl);position:relative}.welcome-banner:before{background:radial-gradient(circle,#d4272e1f 0,#0000 70%);border-radius:50%;content:"";height:300px;position:absolute;right:-10%;top:-50%;width:300px}.welcome-text h2{color:var(--white);font-family:var(--font-display);font-size:1.6rem;font-weight:700;margin-bottom:var(--space-xs)}.welcome-text p{color:var(--silver-200);font-size:.9rem}.welcome-badge{align-items:center;background:#d4272e33;border:1px solid #d4272e4d;border-radius:var(--radius-full);color:var(--red-300);display:inline-flex;font-size:.78rem;font-weight:600;gap:var(--space-sm);margin-top:var(--space-md);padding:6px 14px}.welcome-badge .dot{animation:blink 2s ease-in-out infinite;background:var(--red-400);border-radius:50%;height:6px;width:6px}@keyframes blink{0%,to{opacity:1}50%{opacity:.3}}.stats-grid{grid-gap:var(--space-md);display:grid;gap:var(--space-md);grid-template-columns:repeat(4,1fr);margin-bottom:var(--space-xl)}.stat-card{animation:fade-in-up .6s ease-out calc(.1s*var(--i)) both;background:var(--white);border:1px solid var(--silver-100);border-radius:var(--radius-lg);overflow:hidden;padding:var(--space-lg);position:relative;transition:all var(--transition-base)}.stat-card:hover{box-shadow:var(--shadow-md);transform:translateY(-3px)}.stat-card-icon{align-items:center;border-radius:var(--radius-md);display:flex;height:44px;justify-content:center;margin-bottom:var(--space-md);width:44px}.stat-card-icon svg{color:var(--white);height:22px;width:22px}.stat-card-icon.blue{background:linear-gradient(135deg,var(--navy-500),var(--navy-400))}.stat-card-icon.red{background:linear-gradient(135deg,var(--red-500),var(--red-400))}.stat-card-icon.green{background:linear-gradient(135deg,var(--green-500),var(--green-400))}.stat-card-icon.gold{background:linear-gradient(135deg,var(--gold-500),var(--gold-400))}.stat-card h3{color:var(--navy-800);font-family:var(--font-display);font-size:1.75rem;font-weight:700;margin-bottom:2px}.stat-card p{color:var(--text-secondary);font-size:.82rem;font-weight:500}.section-title{color:var(--navy-800);font-family:var(--font-display);font-size:1.15rem;font-weight:700;gap:var(--space-sm);margin-bottom:var(--space-md)}.section-title .accent-line{background:var(--red-500);border-radius:var(--radius-full);height:3px;width:24px}.action-cards{grid-gap:var(--space-lg);display:grid;gap:var(--space-lg);grid-template-columns:repeat(auto-fill,minmax(280px,1fr));margin-bottom:var(--space-xl)}.action-card{animation:fade-in-up .6s ease-out calc(.1s*var(--i)) both;background:var(--white);border:1px solid var(--silver-100);border-radius:var(--radius-lg);cursor:pointer;overflow:hidden;padding:var(--space-xl);position:relative;transition:all var(--transition-base)}.action-card:after{background:var(--silver-100);bottom:0;content:"";height:3px;left:0;position:absolute;right:0;transition:background var(--transition-base)}.action-card:hover{border-color:#0000;box-shadow:var(--shadow-lg);transform:translateY(-4px)}.action-card:hover:after{background:var(--red-500);background:var(--accent-color,var(--red-500))}.action-card-icon{align-items:center;border-radius:var(--radius-lg);display:flex;height:56px;justify-content:center;margin-bottom:var(--space-md);transition:transform var(--transition-base);width:56px}.action-card:hover .action-card-icon{transform:scale(1.08)}.action-card-icon svg{color:var(--white);height:26px;width:26px}.action-card-icon.register{--accent-color:var(--green-500);background:linear-gradient(135deg,var(--green-500),var(--green-400))}.action-card-icon.delete{--accent-color:var(--red-500);background:linear-gradient(135deg,var(--red-500),var(--red-400))}.action-card-icon.view{--accent-color:var(--navy-500);background:linear-gradient(135deg,var(--navy-500),var(--navy-400))}.action-card-icon.fee{--accent-color:var(--gold-500);background:linear-gradient(135deg,var(--gold-500),var(--gold-400))}.action-card h3{color:var(--navy-800);font-family:var(--font-display);font-size:1.1rem;font-weight:700;margin-bottom:var(--space-xs)}.action-card p{color:var(--text-secondary);font-size:.85rem;line-height:1.5}.action-card .card-arrow{align-items:center;background:var(--off-white);border-radius:50%;display:flex;height:32px;justify-content:center;position:absolute;right:var(--space-lg);top:var(--space-lg);transition:all var(--transition-base);width:32px}.action-card .card-arrow svg{color:var(--silver-400);height:16px;transition:all var(--transition-base);width:16px}.action-card:hover .card-arrow{background:var(--navy-800)}.action-card:hover .card-arrow svg{color:var(--white);transform:translateX(2px)}.form-page{background:linear-gradient(180deg,var(--off-white) 0,#f6f8fc 100%);flex:1 1;padding:var(--space-xl)}.form-page-header{animation:fade-in-up .5s ease-out;gap:var(--space-md);margin-bottom:var(--space-xl);margin-left:auto;margin-right:auto;max-width:1000px}.back-btn,.form-page-header{align-items:center;display:flex}.back-btn{background:var(--white);border:1px solid var(--silver-100);border-radius:var(--radius-md);color:var(--navy-800);cursor:pointer;height:40px;justify-content:center;transition:all var(--transition-fast);width:40px}.back-btn:hover{background:var(--navy-800);border-color:var(--navy-800);color:var(--white)}.back-btn svg{height:20px;width:20px}.form-page-header h2{color:var(--navy-800);font-family:var(--font-display);font-size:1.35rem;font-weight:700}.form-page-header p{color:var(--text-secondary);font-size:.85rem}.form-card{animation:fade-in-up .6s ease-out .1s both;background:var(--white);border:1px solid var(--silver-100);border-radius:var(--radius-lg);box-shadow:0 12px 28px #10182814;margin:0 auto;max-width:1000px;overflow:hidden}.form-card-header{align-items:center;background:linear-gradient(135deg,var(--navy-800) 0,var(--navy-700) 100%);display:flex;gap:var(--space-md);padding:var(--space-lg) var(--space-xl)}.form-card-header-icon{align-items:center;background:#ffffff26;border-radius:var(--radius-md);display:flex;height:42px;justify-content:center;width:42px}.form-card-header-icon svg{color:var(--white);height:22px;width:22px}.form-card-header h3{color:var(--white);font-family:var(--font-display);font-size:1.1rem;font-weight:700}.form-card-header p{color:var(--silver-300);font-size:.78rem}.bulk-upload-bar{align-items:center;background:var(--navy-50);border-bottom:1px solid var(--navy-200);display:flex;flex-wrap:wrap;gap:12px;justify-content:flex-start;padding:16px 24px}.bulk-upload-left h4{color:var(--navy-800);font-size:.96rem;font-weight:700;margin:0}.bulk-upload-status{color:var(--text-secondary);display:inline-block;font-size:.8rem;margin-top:4px}.bulk-upload-status.uploading{color:var(--navy-700)}.bulk-upload-status.success{color:var(--green-600)}.bulk-upload-status.warning{color:#b7791f}.bulk-upload-status.error{color:var(--red-500)}.bulk-upload-btn{background:linear-gradient(135deg,var(--navy-700) 0,var(--navy-800) 100%);border:none;border-radius:var(--radius-md);color:var(--white);cursor:pointer;font-size:.86rem;font-weight:600;padding:10px 16px;transition:all var(--transition-fast);white-space:nowrap}.bulk-upload-btn:hover:not(:disabled){box-shadow:0 8px 18px #10182829;transform:translateY(-1px)}.bulk-upload-btn:disabled{cursor:not-allowed;opacity:.75}.bulk-upload-btn-secondary{background:var(--white);border:1px solid var(--navy-200);color:var(--navy-700)}.bulk-upload-btn-secondary:hover:not(:disabled){box-shadow:0 6px 14px #1018281a}.bulk-upload-card{align-items:center;animation:fade-in-up .55s ease-out .08s both;background:#fff;border:1px solid #d7dde8;border-radius:10px;box-shadow:0 10px 24px #1018280f;display:flex;gap:var(--space-lg);justify-content:space-between;margin:0 auto var(--space-lg);max-width:1000px;padding:18px}.bulk-upload-content{align-items:flex-start;display:flex;flex:1 1;gap:var(--space-md);min-width:0}.bulk-upload-icon{background:#eef2f7;border:1px solid #dbe3ef;border-radius:8px;color:var(--navy-700);display:grid;flex-shrink:0;height:44px;place-items:center;width:44px}.bulk-upload-icon svg{height:22px;width:22px}.bulk-upload-copy h3{color:var(--navy-800);font-family:var(--font-display);font-size:1rem;font-weight:800;margin:0 0 4px}.bulk-upload-copy p{color:var(--text-secondary);font-size:.84rem;line-height:1.5;margin:0 0 7px;max-width:620px}.bulk-upload-controls{align-items:center;display:flex;flex-wrap:wrap;gap:var(--space-sm);justify-content:flex-end}.bulk-upload-campus{font-size:.84rem;min-height:42px;min-width:220px;width:220px}.form-card-body{grid-gap:2px;display:grid;gap:2px;padding:var(--space-xl)}.form-row{grid-gap:var(--space-lg);display:grid;gap:var(--space-lg);grid-template-columns:1fr 1fr;padding:2px 0}.form-row.single{grid-template-columns:1fr}.reg-form-group{margin-bottom:var(--space-md);position:relative}.reg-form-label{color:var(--navy-800);display:block;font-size:.8rem;font-weight:600;letter-spacing:.45px;margin-bottom:var(--space-sm);text-transform:uppercase}.reg-form-label .required{color:var(--red-500);margin-left:2px}.reg-input{background:#fbfcff;border:1.5px solid var(--silver-100);border-radius:var(--radius-md);color:var(--text-primary);font-size:.9rem;min-height:44px;outline:none;padding:11px 14px;transition:all var(--transition-base);width:100%}.reg-input::placeholder{color:var(--text-muted)}.reg-input:hover{background:var(--white);border-color:#bfc8da}.reg-input:focus{background:var(--white);border-color:var(--navy-500);box-shadow:0 0 0 4px #1e3a5f1f}.reg-input.error,.reg-select.error{border-color:var(--red-400);box-shadow:0 0 0 3px #d4272e1a}.field-error{color:var(--red-500);display:block;font-size:.78rem;font-weight:500;margin-top:4px}.reg-select{appearance:none;background-color:#fbfcff;background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%238e92a0' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E");background-position:right 14px center;background-repeat:no-repeat;border:1.5px solid var(--silver-100);border-radius:var(--radius-md);color:var(--text-primary);cursor:pointer;font-size:.9rem;min-height:44px;outline:none;padding:11px 40px 11px 14px;transition:all var(--transition-base);width:100%}.reg-select:hover{background-color:var(--white);border-color:#bfc8da}.reg-select:focus{background-color:var(--white);border-color:var(--navy-500);box-shadow:0 0 0 4px #1e3a5f1f}.form-card-footer{align-items:center;background:linear-gradient(180deg,#f8fafc 0,var(--off-white) 100%);border-top:1px solid var(--silver-100);display:flex;gap:var(--space-md);justify-content:flex-end;padding:var(--space-lg) var(--space-xl)}.btn-secondary{background:var(--white);border:1.5px solid var(--silver-200);border-radius:var(--radius-md);color:var(--text-secondary);cursor:pointer;font-size:.88rem;font-weight:600;padding:11px 24px;transition:all var(--transition-fast)}.btn-secondary:hover{border-color:var(--navy-500);box-shadow:0 4px 12px #0c142114;color:var(--navy-700);transform:translateY(-1px)}.btn-primary{background:linear-gradient(135deg,var(--navy-700) 0,var(--navy-800) 100%);border-radius:var(--radius-md);color:var(--white);font-size:.88rem;gap:var(--space-sm);overflow:hidden;padding:11px 28px;position:relative;transition:all var(--transition-base)}.btn-primary:before{background:linear-gradient(135deg,var(--green-500) 0,var(--green-400) 100%);content:"";height:100%;left:-100%;position:absolute;top:0;transition:left var(--transition-slow);width:100%}.btn-primary:hover:before{left:0}.btn-primary:hover{box-shadow:0 10px 20px #10182829;transform:translateY(-1px)}.btn-primary:disabled{box-shadow:none;cursor:not-allowed;opacity:.78;transform:none}.btn-primary:disabled:before{left:-100%}.btn-primary span{align-items:center;display:flex;gap:var(--space-sm);position:relative;z-index:1}.btn-primary svg{height:18px;width:18px}.registration-success-overlay{align-items:center;animation:fade-in .22s ease-out;background:#0a1628b8;display:flex;inset:0;justify-content:center;padding:var(--space-lg);position:fixed;z-index:180}.registration-success-card{animation:registration-pop .46s cubic-bezier(.2,1.2,.2,1) both;background:var(--white);border-radius:var(--radius-lg);box-shadow:var(--shadow-xl);padding:var(--space-2xl);text-align:center;width:min(380px,100%)}.registration-success-ring{animation:registration-pulse 1.15s ease-out infinite;background:#2e7d321f;border-radius:50%;display:grid;height:92px;margin:0 auto var(--space-lg);place-items:center;width:92px}.registration-success-icon{animation:registration-check .52s ease-out .12s both;background:linear-gradient(135deg,var(--green-400),var(--green-500));border-radius:50%;color:var(--white);display:grid;height:64px;place-items:center;width:64px}.registration-success-card h3{color:var(--navy-800);font-family:var(--font-display);font-size:1.2rem;font-weight:700;margin:0 0 var(--space-sm)}.registration-success-card p{color:var(--text-secondary);font-size:.9rem;margin:0}@keyframes registration-pop{0%{opacity:0;transform:translateY(18px) scale(.92)}to{opacity:1;transform:translateY(0) scale(1)}}@keyframes registration-pulse{0%{box-shadow:0 0 0 0 #2e7d3238}to{box-shadow:0 0 0 22px #2e7d3200}}@keyframes registration-check{0%{opacity:0;transform:scale(.5) rotate(-14deg)}to{opacity:1;transform:scale(1) rotate(0)}}.delete-section{margin:0 auto;max-width:1000px}.search-bar{animation:fade-in-up .5s ease-out .1s both;display:flex;gap:var(--space-md);margin-bottom:var(--space-lg)}.search-input-wrapper{flex:1 1;position:relative}.search-input-wrapper svg{color:var(--silver-400);height:18px;left:14px;pointer-events:none;position:absolute;top:50%;transform:translateY(-50%);width:18px}.search-input{background:var(--white);border:1.5px solid var(--silver-100);border-radius:var(--radius-md);color:var(--text-primary);font-size:.9rem;outline:none;padding:12px 16px 12px 44px;transition:all var(--transition-base);width:100%}.search-input:focus{border-color:var(--navy-500);box-shadow:0 0 0 3px #1e3a5f1a}.search-btn{background:var(--navy-800);border:none;border-radius:var(--radius-md);color:var(--white);cursor:pointer;font-size:.88rem;font-weight:600;padding:12px 24px;transition:all var(--transition-fast);white-space:nowrap}.search-btn:hover{background:var(--navy-700)}.student-table-card{animation:fade-in-up .5s ease-out .2s both;background:var(--white);border:1px solid var(--silver-100);border-radius:var(--radius-lg);overflow:hidden}.student-filter-panel{align-items:center;background:#fff;border:1px solid #d7dde8;border-radius:10px;box-shadow:0 8px 20px #1018280d;display:flex;gap:var(--space-md);justify-content:space-between;margin-bottom:var(--space-md);padding:16px 18px}.student-filter-panel h3{color:var(--navy-800);font-family:var(--font-display);font-size:1rem;font-weight:800;margin:0 0 4px}.student-filter-panel p{color:var(--text-secondary);font-size:.84rem;margin:0}.student-result-count{background:#f8fafc;border:1px solid #dbe3ef;border-radius:var(--radius-full);color:#334155;flex-shrink:0;font-size:.78rem;font-weight:800;padding:6px 12px}.filter-apply-btn,.filter-clear-btn{flex:0 0 auto;min-height:42px;white-space:nowrap}.filter-clear-btn:disabled{box-shadow:none;cursor:not-allowed;opacity:.55;transform:none}.filtered-student-table{animation:filtered-results-in .36s ease-out both}@keyframes filtered-results-in{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@keyframes spin{to{transform:rotate(1turn)}}.student-loading-state{align-items:center;background:#fff;display:flex;flex-direction:column;justify-content:center;min-height:260px;padding:var(--space-3xl) var(--space-xl);text-align:center}.student-loading-spinner{animation:spin .75s linear infinite;border:3px solid #dbe3ef;border-radius:50%;border-top:3px solid var(--navy-700);height:42px;margin-bottom:var(--space-md);width:42px}.student-loading-state h3{color:var(--navy-800);font-family:var(--font-display);font-size:1.05rem;font-weight:800;margin:0 0 6px}.student-loading-state p{color:var(--text-secondary);font-size:.86rem;margin:0}.delete-progress-overlay{align-items:center;animation:fade-in .2s ease-out;background:#0a1628b8;display:flex;inset:0;justify-content:center;padding:var(--space-lg);position:fixed;z-index:220}.delete-progress-card{animation:registration-pop .32s ease-out both;background:#fff;border-radius:10px;box-shadow:var(--shadow-xl);padding:var(--space-2xl);text-align:center;width:min(360px,100%)}.delete-progress-spinner{animation:spin .75s linear infinite;border:4px solid #fee2e2;border-radius:50%;border-top:4px solid var(--red-500);height:52px;margin:0 auto var(--space-md);width:52px}.delete-progress-card h3{color:var(--navy-800);font-family:var(--font-display);font-size:1.08rem;font-weight:800;margin:0 0 6px}.delete-progress-card p{color:var(--text-secondary);font-size:.88rem;margin:0}.student-filter-empty{background:linear-gradient(180deg,#fff,#f8fafc)}.student-table thead{background:var(--off-white)}.student-table th{color:var(--navy-800);font-size:.78rem;font-weight:700;letter-spacing:1px}.student-table td,.student-table th{border-bottom:1px solid var(--silver-100);padding:14px var(--space-lg)}.student-table td{color:var(--text-primary);font-size:.88rem}.student-table tr:last-child td{border-bottom:none}.student-table tr:hover td{background:#f8f9fccc}.class-badge{background:#1e3a5f1a;border-radius:var(--radius-full);color:var(--navy-600);display:inline-block;font-size:.78rem;font-weight:600;padding:3px 12px}.delete-btn{align-items:center;background:#0000;border:1px solid var(--red-400);border-radius:var(--radius-sm);color:var(--red-500);cursor:pointer;display:inline-flex;font-size:.82rem;font-weight:600;gap:6px;padding:7px 16px;transition:all var(--transition-fast)}.delete-btn:hover{background:var(--red-500);border-color:var(--red-500);color:var(--white)}.delete-btn svg{height:14px;width:14px}.empty-state{padding:var(--space-3xl) var(--space-xl)}.empty-state-icon{align-items:center;background:var(--off-white);border-radius:50%;display:flex;height:64px;justify-content:center;margin:0 auto var(--space-md);width:64px}.empty-state-icon svg{color:var(--silver-400);height:28px;width:28px}.empty-state h3{color:var(--navy-800);font-family:var(--font-display);font-size:1.1rem;font-weight:700;margin-bottom:var(--space-xs)}.empty-state p{color:var(--text-secondary);font-size:.88rem}.modal-overlay{align-items:center;animation:fade-in .2s ease-out;background:#0a1628b3;display:flex;inset:0;justify-content:center;position:fixed;z-index:100}.modal-content{animation:scale-in .3s ease-out;background:var(--white);border-radius:var(--radius-lg);box-shadow:var(--shadow-xl);max-height:95vh;max-width:550px;overflow-y:auto;overflow:hidden;padding:0;position:relative;width:100%}.modal-content:before{background:linear-gradient(90deg,var(--red-500),var(--red-400),var(--gold-500));content:"";height:4px;left:0;position:absolute;right:0;top:0}.modal-header{align-items:center;border-bottom:1px solid var(--silver-100);display:flex;justify-content:space-between;padding:var(--space-lg) var(--space-xl) var(--space-md)}.modal-header h3{color:var(--navy-800);font-family:var(--font-display);font-size:1.2rem;font-weight:700;margin:0}.modal-close-btn{align-items:center;background:none;border:none;color:var(--silver-400);cursor:pointer;display:flex;font-size:28px;height:32px;justify-content:center;padding:0;transition:color var(--transition-fast);width:32px}.modal-close-btn:hover{color:var(--navy-800)}.modal-body{padding:var(--space-lg)}.modal-icon{align-items:center;border-radius:50%;display:flex;height:56px;justify-content:center;margin:0 auto var(--space-md);width:56px}.modal-icon.danger{background:linear-gradient(135deg,var(--red-500),var(--red-400))}.modal-icon.success{background:linear-gradient(135deg,var(--green-500),var(--green-400))}.modal-icon svg{color:var(--white);height:24px;width:24px}.modal-content h3{color:var(--navy-800);font-family:var(--font-display);font-size:1.2rem;font-weight:700;margin-bottom:var(--space-sm)}.modal-content p{color:var(--text-secondary);font-size:.88rem;margin-bottom:var(--space-lg)}.modal-actions{background:var(--off-white);border-top:1px solid var(--silver-100);display:flex;gap:var(--space-md);justify-content:flex-end;padding:var(--space-md) var(--space-lg)}.modal-actions .btn-secondary{flex:0 1 auto;min-width:120px}.modal-actions .btn-primary{flex:0 1 auto;min-width:140px}.challan-overlay{align-items:center;justify-content:center;overflow-y:auto;padding:18px}.challan-modal{background:#fff;border-radius:10px;max-height:95vh;max-width:940px;overflow:hidden;padding:0;width:min(940px,100%)}.challan-modal:before{display:none}.challan-header{background:#f8fafc;border-bottom:1px solid #d7dde8;justify-content:space-between;padding:22px 26px}.challan-brand,.challan-header{align-items:center;display:flex;gap:18px}.challan-brand{min-width:0}.challan-logo{background:#fff;border:1px solid #e2e8f0;border-radius:6px;flex-shrink:0;height:66px;object-fit:contain;padding:6px;width:112px}.challan-kicker{color:#64748b;font-size:.72rem;font-weight:800;letter-spacing:1.5px;margin:0 0 4px;text-transform:uppercase}.challan-header h2{color:#0f172a;font-size:1.18rem;font-weight:800;margin:0}.challan-id{color:#475569;font-size:.82rem;font-weight:600;margin:5px 0 0}.challan-close-btn{background:#fff;border:1px solid #cbd5e1;border-radius:6px;color:#334155;cursor:pointer;display:grid;height:36px;place-items:center;transition:all var(--transition-fast);width:36px}.challan-close-btn:hover{background:#eef2f7;color:#0f172a}.challan-close-btn svg{height:17px;width:17px}.challan-body{max-height:calc(95vh - 168px);overflow-x:hidden;overflow-y:auto;padding:22px 26px}.challan-loading{color:#475569;font-weight:700;padding:54px 0;text-align:center}.challan-meta-grid{grid-gap:1px;background:#d7dde8;border:1px solid #d7dde8;border-radius:8px;display:grid;gap:1px;grid-template-columns:repeat(4,minmax(0,1fr));margin-bottom:20px;overflow:hidden}.challan-meta-item{background:#fff;min-width:0;padding:13px 14px}.challan-meta-item span{color:#64748b;display:block;font-size:.7rem;font-weight:800;letter-spacing:.9px;margin-bottom:5px;text-transform:uppercase}.challan-meta-item strong{color:#0f172a;display:block;font-size:.9rem;overflow-wrap:anywhere;white-space:normal}.challan-table-wrap{border:1px solid #d7dde8;border-radius:8px;margin-bottom:18px;overflow-x:auto}.challan-table{border-collapse:collapse;color:#1f2937;font-size:.82rem;min-width:820px;width:100%}.challan-table th{background:#f1f5f9;border-bottom:1px solid #d7dde8;color:#475569;font-size:.7rem;font-weight:800;letter-spacing:.8px;padding:11px 12px;text-align:left;text-transform:uppercase}.challan-table td{background:#fff;border-bottom:1px solid #edf1f7;padding:12px}.challan-table tbody tr:last-child td{border-bottom:none}.challan-table .amount-cell{text-align:right;white-space:nowrap}.challan-table .deduction{color:#166534;font-weight:800}.challan-table .fine{color:#9f1239;font-weight:800}.challan-table .total{background:#f8fafc;color:#0f172a;font-weight:900}.challan-cleared-panel{background:#f0fdf4;border:1px solid #bbf7d0;border-radius:8px;color:#14532d;margin-bottom:18px;padding:18px;text-align:center}.challan-cleared-panel div{font-size:1rem;font-weight:900}.challan-cleared-panel p{color:#166534;font-size:.82rem;margin:6px 0 0}.challan-summary{grid-gap:12px;display:grid;gap:12px;grid-template-columns:repeat(4,minmax(0,1fr));margin-bottom:18px}.challan-summary div{background:#fff;border:1px solid #d7dde8;border-radius:8px;padding:14px}.challan-summary span{color:#64748b;display:block;font-size:.72rem;font-weight:800;letter-spacing:.8px;margin-bottom:6px;text-transform:uppercase}.challan-summary strong{color:#0f172a;display:block;font-size:1.08rem;font-weight:900}.challan-summary .payable{background:#fff7f8;border-color:#fecdd3}.challan-summary .payable strong{color:#9f1239}.challan-summary .cleared{background:#f0fdf4;border-color:#bbf7d0}.challan-summary .cleared strong{color:#166534}.challan-footer-note{border-top:1px solid #e2e8f0;color:#64748b;font-size:.76rem;line-height:1.5;padding-top:12px}.challan-footer-note p{color:inherit;margin:0}.challan-footer-note p:first-child{color:#334155;font-weight:700}.challan-actions{background:#f8fafc;border-top:1px solid #d7dde8;padding:14px 26px}.challan-actions .btn-primary,.challan-actions .btn-secondary{border-radius:6px;min-width:132px}@media (max-width:760px){.challan-overlay{align-items:flex-start;padding:10px}.challan-header{align-items:flex-start;padding:18px}.challan-brand{align-items:flex-start;gap:12px}.challan-logo{height:52px;width:82px}.challan-header h2{font-size:1rem}.challan-body{max-height:none;padding:18px}.challan-meta-grid,.challan-summary{grid-template-columns:1fr}.challan-actions{flex-direction:column-reverse;padding:12px 18px}.challan-actions .btn-primary,.challan-actions .btn-secondary{justify-content:center;width:100%}}.fee-details-overlay{background:#0f172aad;overflow-y:auto;padding:18px!important}.fee-details-modal{background:#fff;border:1px solid #d9e0ea;border-radius:10px;max-height:95vh;max-width:1040px!important;overflow:hidden!important;padding:0!important;width:min(1040px,100%)!important}.fee-details-modal:before{display:none}.fee-details-header{align-items:center!important;background:#f8fafc!important;border-bottom:1px solid #d9e0ea!important;color:#0f172a!important;display:flex!important;gap:18px!important;padding:22px 26px!important}.fee-details-logo{background:#fff;border:1px solid #e2e8f0;border-radius:6px;flex-shrink:0;height:66px!important;object-fit:contain;padding:6px;width:112px!important}.fee-details-title{min-width:0}.fee-details-title h2{color:#0f172a!important;font-size:1.18rem!important;font-weight:800!important;margin:0 0 5px!important}.fee-details-title p{color:#475569!important;font-size:.86rem!important;font-weight:600;margin:0!important}.fee-details-header .challan-close-btn{background:#fff!important;border:1px solid #cbd5e1!important;color:#334155!important;flex-shrink:0;font-size:0!important}.fee-details-header .challan-close-btn:after{content:"x";font-size:18px;line-height:1}.fee-details-body{background:#fff;max-height:calc(95vh - 170px);overflow-y:auto;padding:22px 26px!important}.fee-details-loading{color:#475569;display:grid;font-weight:800;min-height:210px;place-items:center}.fee-details-loading:before{animation:spin .8s linear infinite;border:3px solid #dbe3ef;border-radius:50%;border-top-color:#1d4ed8;content:"";height:34px;margin-bottom:12px;width:34px}.fee-details-info-grid{grid-gap:1px!important;background:#d9e0ea!important;border:1px solid #d9e0ea!important;border-radius:8px!important;display:grid!important;gap:1px!important;grid-template-columns:repeat(3,minmax(0,1fr));margin-bottom:20px!important;overflow:hidden;padding:0!important}.fee-details-info-grid>div{background:#fff!important;min-width:0;padding:14px 16px!important}.fee-details-info-grid>div[style*="width: 1px"]{display:none!important}.fee-details-info-grid p:first-child{color:#64748b!important;font-size:.7rem!important;font-weight:800!important;letter-spacing:.9px;margin:0 0 5px!important}.fee-details-info-grid p:last-child{color:#0f172a!important;font-size:.92rem!important;font-weight:800!important;margin:0!important}.fee-details-summary-grid{grid-gap:12px!important;display:grid!important;gap:12px!important;grid-template-columns:repeat(3,minmax(0,1fr))!important;margin-bottom:24px!important}.fee-summary-card{background:#fff!important;border:1px solid #d9e0ea!important;border-left:4px solid #64748b!important;border-radius:8px!important;min-width:0;padding:15px!important;text-align:left!important}.fee-summary-card p:first-child{color:#64748b!important;font-size:.72rem!important;font-weight:800!important;letter-spacing:.8px;margin:0 0 7px!important;text-transform:uppercase}.fee-summary-card p:last-child{color:#0f172a!important;font-size:1.15rem!important;font-weight:850!important;margin:0!important;overflow-wrap:anywhere}.fee-summary-card.cleared,.fee-summary-card.paid-fee,.fee-summary-card.scholarship-fee{border-left-color:#15803d!important}.fee-summary-card.late-fee{border-left-color:#b45309!important}.fee-summary-card.payable-fee{border-left-color:#1d4ed8!important}.fee-summary-card.balance-fee.has-balance{border-left-color:#b91c1c!important}.fee-summary-card.cleared p:last-child,.fee-summary-card.paid-fee p:last-child,.fee-summary-card.scholarship-fee p:last-child{color:#15803d!important}.fee-summary-card.late-fee p:last-child{color:#92400e!important}.fee-summary-card.payable-fee p:last-child{color:#1d4ed8!important}.fee-summary-card.balance-fee.has-balance p:last-child{color:#b91c1c!important}.fee-details-section-title{color:#0f172a!important;font-size:1rem!important;font-weight:800!important;margin:0 0 12px!important}.fee-history-table-wrap{border:1px solid #d9e0ea;border-radius:8px;overflow-x:auto}.fee-history-table{border-collapse:collapse;color:#1f2937;font-size:.82rem!important;min-width:980px;width:100%}.fee-history-table th{background:#f1f5f9!important;border:0!important;border-bottom:1px solid #d9e0ea!important;color:#475569!important;font-size:.7rem!important;font-weight:800!important;letter-spacing:.7px;padding:11px 12px!important;text-transform:uppercase}.fee-history-table td{background:#fff!important;border:0!important;border-bottom:1px solid #eef2f7!important;color:#1f2937!important;padding:12px!important}.fee-history-table tbody tr:hover td{background:#f8fafc!important}.fee-history-table tbody tr:last-child td{border-bottom:0!important}.fee-history-table td:nth-child(4){color:#15803d!important;font-weight:800!important}.fee-history-table td:nth-child(8){background:#f8fafc!important;color:#0f172a!important;font-weight:850!important}.fee-history-table td span{align-items:center;border-radius:999px!important;display:inline-flex;font-size:.72rem!important;font-weight:800!important;justify-content:center;min-width:72px;padding:5px 10px!important}.fee-details-empty{background:#f8fafc!important;border:1px dashed #cbd5e1;border-radius:8px;color:#64748b;padding:42px 18px!important;text-align:center}.fee-details-empty p{margin:0}.fee-details-empty.error{background:#fff7f7!important;border-color:#fecaca}.fee-details-footer{align-items:center!important;background:#f8fafc!important;border-top:1px solid #d9e0ea!important;display:flex!important;gap:14px!important;justify-content:space-between!important;padding:16px 26px!important}.fee-details-updated{color:#64748b!important;font-size:.76rem!important;font-weight:700!important}.fee-details-actions{display:flex!important;flex-shrink:0;gap:10px!important}.fee-details-actions .btn-primary,.fee-details-actions .btn-secondary{border-radius:6px!important;font-size:.84rem!important;font-weight:800!important;min-height:40px;padding:10px 15px!important}.fee-details-actions .btn-primary{background:#1d4ed8!important;border:1px solid #1d4ed8!important;color:#fff!important}.fee-details-actions .btn-secondary{background:#fff!important;border:1px solid #cbd5e1!important;color:#334155!important}@media (max-width:860px){.fee-details-body,.fee-details-footer,.fee-details-header{padding-left:16px!important;padding-right:16px!important}.fee-details-logo{height:54px!important;width:88px!important}.fee-details-info-grid,.fee-details-summary-grid{grid-template-columns:1fr!important}.fee-details-footer{align-items:stretch!important}.fee-details-actions,.fee-details-footer{flex-direction:column}}.btn-danger{background:linear-gradient(135deg,var(--red-500),var(--red-600));border:none;border-radius:var(--radius-md);color:var(--white);cursor:pointer;flex:1 1;font-size:.88rem;font-weight:600;padding:11px 24px;transition:all var(--transition-fast)}.btn-danger:hover{box-shadow:var(--shadow-md);transform:translateY(-1px)}.toast{align-items:center;animation:slide-in-right .4s ease-out;background:var(--white);border-left:4px solid var(--green-500);border-radius:var(--radius-md);bottom:var(--space-xl);box-shadow:var(--shadow-xl);display:flex;gap:var(--space-md);padding:var(--space-md) var(--space-lg);position:fixed;right:var(--space-xl);z-index:200}.toast.error{border-left-color:var(--red-500)}@keyframes slide-in-right{0%{opacity:0;transform:translateX(40px)}to{opacity:1;transform:translateX(0)}}.toast-icon{align-items:center;border-radius:50%;display:flex;flex-shrink:0;height:32px;justify-content:center;width:32px}.toast-icon.success{background:#2e7d321a;color:var(--green-500)}.toast-icon.error{background:#d4272e1a;color:var(--red-500)}.toast-text h4{color:var(--navy-800);font-size:.88rem;font-weight:600}.toast-text p{color:var(--text-secondary);font-size:.78rem}@media (max-width:1024px){.sidebar{transform:translateX(-100%)}.sidebar.open{transform:translateX(0)}.main-content{margin-left:0}.menu-toggle{display:flex}.stats-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width:640px){.form-page{padding:var(--space-md)}.form-page-header{margin-bottom:var(--space-md)}.bulk-upload-bar{align-items:flex-start;flex-direction:column;padding:14px 16px}.bulk-upload-card{align-items:stretch;flex-direction:column;padding:16px}.bulk-upload-content{align-items:flex-start}.bulk-upload-controls{justify-content:stretch;width:100%}.bulk-upload-campus{min-width:0;width:100%}.bulk-upload-btn{width:100%}.form-card-body,.form-card-footer,.form-card-header{padding-left:var(--space-md);padding-right:var(--space-md)}.dashboard-action-grid,.dashboard-overview-hero,.dashboard-stats-grid,.form-row,.stats-grid{grid-template-columns:1fr}.student-filter-panel{align-items:flex-start;flex-direction:column}.student-result-count{align-self:flex-start}.filter-apply-btn,.filter-clear-btn,.filter-controls,.filter-select{width:100%}.action-cards{grid-template-columns:1fr}.dashboard-content,.dashboard-content.dashboard-home{padding:var(--space-md)}.welcome-banner{padding:var(--space-lg)}}.role-badge-small{border-radius:4px;display:inline-block;font-size:.65rem;font-weight:700;letter-spacing:.5px;padding:2px 8px;text-transform:uppercase}.role-badge-small.superadmin{background:linear-gradient(135deg,gold,#daa520);box-shadow:0 2px 4px #daa5204d;color:#000}.role-badge-small.admin{background:linear-gradient(135deg,#3498db,#2980b9);color:#fff}.role-badge-small.controller{background:linear-gradient(135deg,#16a085,#0e7c66);color:#fff}.role-badge-small.viewer{background:linear-gradient(135deg,#95a5a6,#7f8c8d);color:#fff}.section-header{margin-bottom:1.5rem}.viewer-analytics-page{display:flex;flex-direction:column;gap:var(--space-lg)}.viewer-analytics-hero{align-items:center;background:linear-gradient(135deg,#0f1d36f5,#1e3a5fe6),linear-gradient(90deg,#c49a2a38,#d4272e29);border:1px solid #1e3a5f24;border-radius:var(--radius-lg);box-shadow:0 18px 42px #0f172a24;color:var(--white);display:flex;gap:var(--space-xl);justify-content:space-between;min-height:150px;padding:var(--space-xl)}.viewer-analytics-kicker{color:var(--gold-400);display:inline-block;font-size:.74rem;font-weight:800;letter-spacing:.08em;margin-bottom:8px;text-transform:uppercase}.viewer-analytics-hero h2{color:var(--white);font-family:var(--font-display);font-size:1.7rem;line-height:1.2;margin:0 0 8px}.viewer-analytics-hero p{color:#ffffffd1;font-size:.94rem;margin:0}.viewer-analytics-metrics{grid-gap:var(--space-sm);display:grid;gap:var(--space-sm);grid-template-columns:repeat(3,minmax(96px,1fr));min-width:min(430px,45%)}.viewer-analytics-metric{background:#ffffff1a;border:1px solid #ffffff2e;border-radius:var(--radius-md);padding:14px 16px}.viewer-analytics-metric.muted{background:#ffffff12}.viewer-analytics-metric strong{display:block;font-family:var(--font-display);font-size:1.55rem;line-height:1}.viewer-analytics-metric span{color:#ffffffbd;display:block;font-size:.76rem;font-weight:700;letter-spacing:.04em;margin-top:6px;text-transform:uppercase}.viewer-campus-toolbar{align-items:flex-end;background:var(--white);border:1px solid #dbe3ef;border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);display:flex;gap:var(--space-md);justify-content:space-between;padding:var(--space-md)}.viewer-filter-field{display:flex;flex-direction:column;gap:7px}.viewer-filter-field label{color:var(--navy-800);font-size:.76rem;font-weight:800;letter-spacing:.04em;text-transform:uppercase}.viewer-dropdown-filter,.viewer-search-filter{flex:1 1;min-width:280px}.viewer-campus-search{position:relative}.viewer-campus-search svg{color:var(--silver-400);height:18px;left:14px;position:absolute;top:50%;transform:translateY(-50%);width:18px}.viewer-campus-search input{background:#fbfcff;border:1.5px solid var(--silver-100);border-radius:var(--radius-md);color:var(--text-primary);min-height:44px;outline:none;padding:11px 14px 11px 44px;transition:border-color var(--transition-fast),box-shadow var(--transition-fast);width:100%}.viewer-campus-search input:focus{border-color:var(--navy-500);box-shadow:0 0 0 4px #1e3a5f1a}.viewer-dropdown-filter select{appearance:none;background-color:#fbfcff;background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%238e92a0' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E");background-position:right 14px center;background-repeat:no-repeat;border:1.5px solid var(--silver-100);border-radius:var(--radius-md);color:var(--text-primary);cursor:pointer;min-height:44px;outline:none;padding:11px 40px 11px 14px;transition:border-color var(--transition-fast),box-shadow var(--transition-fast);width:100%}.viewer-dropdown-filter select:focus{border-color:var(--navy-500);box-shadow:0 0 0 4px #1e3a5f1a}.viewer-results-row{align-items:center;color:var(--text-secondary);display:flex;font-size:.84rem;font-weight:700;gap:var(--space-md);justify-content:space-between}.viewer-results-row button{background:#0000;border:none;color:var(--red-500);cursor:pointer;font-weight:800}.viewer-empty-state{background:#f8fafc;border:1px dashed #cbd5e1;border-radius:var(--radius-lg);padding:var(--space-xl);text-align:center}.viewer-empty-state h3{color:var(--navy-900);font-size:1.1rem;margin:0 0 8px}.viewer-empty-state p{color:var(--text-secondary);margin:0}.viewer-campus-grid{margin-top:0}.viewer-campus-card{display:flex;flex-direction:column;min-height:268px}.viewer-campus-card.dashboard-missing{border-top-color:var(--silver-300)}.viewer-campus-card-header{align-items:flex-start}.viewer-campus-title{flex:1 1;min-width:0}.viewer-campus-title h3{color:var(--navy-900);line-height:1.25;margin:0 0 8px}.viewer-dashboard-status{align-items:center;border-radius:var(--radius-full);display:inline-flex;font-size:.72rem;font-weight:800;min-height:24px;padding:4px 9px}.viewer-dashboard-status.ready{background:#2e7d321a;color:var(--green-500)}.viewer-dashboard-status.missing{background:#8a8c911f;color:var(--text-secondary)}@media (max-width:900px){.viewer-analytics-hero{align-items:stretch;flex-direction:column}.viewer-analytics-metrics{min-width:0;width:100%}.viewer-campus-toolbar{align-items:stretch;flex-direction:column}.viewer-dropdown-filter,.viewer-search-filter{flex:1 1 auto;min-width:0;width:100%}}@media (max-width:560px){.viewer-analytics-hero{padding:var(--space-lg)}.viewer-analytics-metrics{grid-template-columns:1fr}.viewer-results-row{align-items:flex-start;flex-direction:column}}.campus-management-page{display:flex;flex-direction:column;gap:var(--space-lg)}.campus-management-hero{align-items:center;background:linear-gradient(135deg,#fff,#f8fafc 58%,#eef2f7);border:1px solid #1e3a5f24;border-radius:var(--radius-lg);box-shadow:var(--shadow-md);display:flex;gap:var(--space-xl);justify-content:space-between;min-height:150px;padding:var(--space-xl)}.campus-management-kicker{color:var(--red-500);display:inline-block;font-size:.74rem;font-weight:800;letter-spacing:.08em;margin-bottom:8px;text-transform:uppercase}.campus-management-hero h2{color:var(--navy-900);font-family:var(--font-display);font-size:1.72rem;line-height:1.2;margin:0 0 8px}.campus-management-hero p{color:var(--text-secondary);font-size:.94rem;margin:0;max-width:620px}.campus-management-metrics{grid-gap:var(--space-sm);display:grid;gap:var(--space-sm);grid-template-columns:repeat(3,minmax(100px,1fr));min-width:min(440px,46%)}.campus-management-metric{background:#fff;border:1px solid #dbe3ef;border-radius:var(--radius-md);box-shadow:var(--shadow-sm);padding:14px 16px}.campus-management-metric.muted{background:#f8fafc}.campus-management-metric strong{color:var(--navy-900);display:block;font-family:var(--font-display);font-size:1.55rem;line-height:1}.campus-management-metric span{color:var(--text-secondary);display:block;font-size:.74rem;font-weight:800;letter-spacing:.04em;margin-top:6px;text-transform:uppercase}.campus-management-toolbar{grid-gap:var(--space-md);align-items:end;background:#fff;border:1px solid #dbe3ef;border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);display:grid;gap:var(--space-md);grid-template-columns:minmax(240px,1fr) minmax(240px,1fr) auto;padding:var(--space-md)}.campus-management-toolbar-actions{display:flex;justify-content:flex-end}.campus-management-results{padding:0 2rem}.campus-management{padding:2rem}.campus-grid{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));margin-top:1rem}.campus-card{background:var(--white);border-radius:12px;border-top:4px solid var(--navy-500);box-shadow:var(--shadow-md);padding:1.5rem;transition:transform .3s ease,box-shadow .3s ease}.campus-card:hover{box-shadow:0 18px 38px #0f172a1f;transform:translateY(-5px)}.campus-card-header{align-items:center;display:flex;gap:1rem;margin-bottom:1rem}.campus-icon{align-items:center;background:var(--navy-50);border-radius:10px;color:var(--navy-600);display:flex;height:40px;justify-content:center;width:40px}.campus-card-header h3{color:var(--navy-900);line-height:1.25;margin:0}.campus-card-body p{color:var(--text-secondary);font-size:.9rem;margin-bottom:.5rem}.campus-date{color:var(--text-muted)!important;font-size:.75rem!important;margin-top:1rem}.campus-card-footer{align-items:center;border-top:1px solid var(--silver-100);display:flex;gap:var(--space-md);justify-content:space-between;margin-top:1.5rem;padding-top:1rem}.viewer-campus-card-footer{justify-content:flex-end;margin-top:auto}.viewer-campus-card .btn-text-analytics{background:#eef2f7;border-radius:var(--radius-md);padding:9px 14px}.viewer-campus-card .btn-text-analytics:hover{background:#dbe3ef;text-decoration:none}.viewer-campus-card .btn-text-analytics:disabled{color:var(--text-muted);cursor:not-allowed;opacity:.72}.viewer-campus-card .btn-text-analytics:disabled:hover{background:#eef2f7}.btn-text,.btn-text-analytics{color:var(--navy-600);font-weight:600}.btn-text-analytics{background:#f8fafc;border:1px solid #dbe3ef;border-radius:var(--radius-md);cursor:pointer;min-height:34px;padding:7px 11px}.btn-text-danger{color:var(--red-500);font-weight:600}.btn-text-analytics:hover,.btn-text-danger:hover,.btn-text:hover{text-decoration:underline}.btn-text-analytics:hover{background:#eef2f7;text-decoration:none}@media (max-width:980px){.campus-management-hero{align-items:stretch;flex-direction:column}.campus-management-metrics{min-width:0;width:100%}.campus-management-toolbar{grid-template-columns:1fr}.campus-management-toolbar-actions{justify-content:stretch}.campus-management-toolbar-actions .btn-primary{justify-content:center;width:100%}}.user-management-page{display:flex;flex-direction:column;gap:var(--space-lg)}.user-management-hero{align-items:center;background:linear-gradient(135deg,#fff,#f8fafc 58%,#eef2f7),linear-gradient(90deg,#d4272e14,#c49a2a14);border:1px solid #1e3a5f24;border-radius:var(--radius-lg);box-shadow:var(--shadow-md);display:flex;gap:var(--space-xl);justify-content:space-between;min-height:158px;padding:var(--space-xl)}.user-management-kicker{color:var(--red-500);display:inline-block;font-size:.74rem;font-weight:800;letter-spacing:.08em;margin-bottom:8px;text-transform:uppercase}.user-management-hero h2{color:var(--navy-900);font-family:var(--font-display);font-size:1.72rem;line-height:1.2;margin:0 0 8px}.user-management-hero p{color:var(--text-secondary);font-size:.94rem;margin:0;max-width:620px}.user-management-metrics{grid-gap:var(--space-sm);display:grid;gap:var(--space-sm);grid-template-columns:repeat(4,minmax(96px,1fr));min-width:min(560px,52%)}.user-management-metric{background:#fff;border:1px solid #dbe3ef;border-radius:var(--radius-md);box-shadow:var(--shadow-sm);padding:14px 16px}.user-management-metric.muted{background:#f8fafc}.user-management-metric strong{color:var(--navy-900);display:block;font-family:var(--font-display);font-size:1.48rem;line-height:1}.user-management-metric span{color:var(--text-secondary);display:block;font-size:.7rem;font-weight:800;letter-spacing:.04em;margin-top:6px;text-transform:uppercase}.user-management-toolbar{grid-gap:var(--space-md);align-items:end;background:#fff;border:1px solid #dbe3ef;border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);display:grid;gap:var(--space-md);grid-template-columns:minmax(260px,1.2fr) minmax(160px,.7fr) minmax(160px,.7fr) auto;padding:var(--space-md)}.user-filter-field{display:flex;flex-direction:column;gap:8px}.user-filter-field label{color:var(--navy-800);font-size:.75rem;font-weight:800;letter-spacing:.05em;text-transform:uppercase}.user-search-input-wrap{align-items:center;display:flex;position:relative}.user-search-input-wrap svg{color:var(--text-muted);font-size:1.12rem;left:14px;pointer-events:none;position:absolute}.user-filter-field input,.user-filter-field select{background:#f8fafc;border:1px solid #dbe3ef;border-radius:var(--radius-md);color:var(--text-primary);font-size:.9rem;min-height:44px;outline:none;padding:0 14px;transition:border-color var(--transition-fast),box-shadow var(--transition-fast),background var(--transition-fast);width:100%}.user-search-input-wrap input{padding-left:42px}.user-filter-field input:focus,.user-filter-field select:focus{background:#fff;border-color:var(--navy-500);box-shadow:0 0 0 3px #1e3a5f1a}.user-management-toolbar-actions{display:flex;gap:var(--space-sm);justify-content:flex-end}.user-management-toolbar-actions .btn-primary,.user-management-toolbar-actions .btn-secondary{align-items:center;display:inline-flex;gap:8px;justify-content:center;min-height:44px;white-space:nowrap}.user-management-results{color:var(--text-secondary);font-size:.84rem;font-weight:700;padding:0 4px}.user-management-table-card{box-shadow:var(--shadow-sm)}.user-management-table td:last-child,.user-management-table th:last-child{text-align:right}.user-cell{align-items:center;display:flex;gap:12px;min-width:190px}.user-avatar-token{align-items:center;background:linear-gradient(135deg,var(--navy-700),var(--navy-500));border-radius:12px;color:#fff;display:inline-flex;flex:0 0 42px;font-size:.82rem;font-weight:900;height:42px;justify-content:center;letter-spacing:.03em;width:42px}.user-name-cell{display:flex;flex-direction:column;gap:3px}.user-name-cell strong{color:var(--navy-900);font-size:.94rem}.user-name-cell small{color:var(--text-muted);font-size:.74rem;font-weight:700}.user-access-cell{color:var(--text-secondary);display:inline-block;line-height:1.45;max-width:360px}.user-status-pill{align-items:center;border-radius:var(--radius-full);display:inline-flex;font-size:.75rem;font-weight:800;min-height:26px;padding:4px 12px}.user-status-pill.active{background:#2d873e1a;border:1px solid #2d873e2e;color:#2d873e}.user-status-pill.inactive{background:#d4272e1a;border:1px solid #d4272e2e;color:var(--red-500)}.user-manage-link{background:#f8fafc;border:1px solid #dbe3ef;border-radius:var(--radius-md);min-height:34px;padding:7px 12px}.user-manage-link:hover{background:#eef2f7;text-decoration:none}.user-empty-state{align-items:center;background:linear-gradient(180deg,#fff,#f8fafc);display:flex;flex-direction:column;gap:var(--space-sm);justify-content:center;min-height:260px;padding:var(--space-3xl) var(--space-lg);text-align:center}.user-empty-state h3{color:var(--navy-900);font-family:var(--font-display);font-size:1.18rem;margin:0}.user-empty-state p{color:var(--text-secondary);font-size:.9rem;margin:0 0 6px}@media (max-width:1180px){.user-management-hero{align-items:stretch;flex-direction:column}.user-management-metrics{min-width:0;width:100%}.user-management-toolbar{grid-template-columns:1fr 1fr}.user-management-toolbar-actions,.user-search-field{grid-column:1/-1}.user-management-toolbar-actions{justify-content:flex-end}}@media (max-width:720px){.user-management-hero,.user-management-toolbar{padding:var(--space-md)}.user-management-metrics,.user-management-toolbar{grid-template-columns:1fr}.user-management-toolbar-actions{flex-direction:column}.user-management-toolbar-actions .btn-primary,.user-management-toolbar-actions .btn-secondary{width:100%}}.analytics-modal-content{max-width:1240px;overflow:hidden;width:min(92vw,calc(168vh - 144.48px))}.analytics-modal-header{padding:14px 34px 12px}.analytics-modal-header h3{font-size:1.05rem;line-height:1.2}.analytics-modal-actions{align-items:center;display:flex;gap:10px}.analytics-download-btn{align-items:center;background:#fff;border:1px solid #cbd5e1;border-radius:var(--radius-md);color:var(--navy-700);cursor:pointer;display:inline-flex;font-size:.82rem;font-weight:800;gap:8px;min-height:36px;padding:8px 13px}.analytics-download-btn:hover{background:#eef2f7;color:var(--navy-900)}.analytics-download-btn:disabled{color:var(--text-muted);cursor:not-allowed;opacity:.68}.analytics-download-btn:disabled:hover{background:#fff;color:var(--text-muted)}.analytics-download-btn svg{height:16px;width:16px}.analytics-iframe-wrap{background:var(--off-white);border-radius:var(--radius-md);height:min(72vh,690px);min-height:500px;overflow:hidden;width:100%}.analytics-iframe-wrap iframe{border:0;display:block;height:100%;width:100%}.analytics-snapshot-bar{align-items:center;background:#f8fafc;border-top:1px solid var(--silver-100);display:flex;gap:var(--space-md);justify-content:space-between;padding:12px 34px 16px}.analytics-snapshot-bar span{color:var(--navy-800);flex:0 0 auto;font-size:.82rem;font-weight:800}.analytics-snapshot-bar p{color:var(--text-secondary);font-size:.78rem;margin:0;text-align:right}.analytics-snapshot-tray{background:#fff;border-top:1px solid var(--silver-100);display:flex;flex-wrap:wrap;gap:10px;padding:12px 34px 18px}.analytics-snapshot-pill{align-items:center;background:#f8fafc;border:1px solid #dbe3ef;border-radius:var(--radius-md);column-gap:10px;display:inline-grid;grid-template-columns:auto auto;min-height:42px;padding:7px 8px 7px 12px;row-gap:2px}.analytics-snapshot-pill span{color:var(--navy-800);font-size:.8rem;font-weight:800}.analytics-snapshot-pill small{color:var(--text-muted);font-size:.68rem;grid-column:1}.analytics-snapshot-pill button{align-items:center;background:#fff;border:none;border-radius:var(--radius-md);color:var(--red-500);cursor:pointer;display:inline-flex;grid-column:2;grid-row:1/span 2;height:30px;justify-content:center;width:30px}.analytics-snapshot-pill button:hover{background:#d4272e14}.system-report-page{display:flex;flex-direction:column;gap:8px;height:calc(100vh - 88px);overflow:hidden;padding-left:8px;padding-right:8px}.powerbi-report-hero{align-items:center;background:linear-gradient(135deg,#1e3a5ff5,#2d5484eb),linear-gradient(90deg,#2f855a52,#d4272e2e);border:1px solid #1e3a5f1f;border-radius:var(--radius-lg);box-shadow:0 18px 42px #0f172a24;color:var(--white);display:flex;flex:0 0 auto;gap:var(--space-lg);justify-content:space-between;min-height:54px;padding:10px 18px}.powerbi-kicker{color:var(--gold-300);display:inline-block;font-size:.62rem;font-weight:800;letter-spacing:.08em;margin-bottom:3px;text-transform:uppercase}.powerbi-report-hero h2{color:var(--white);font-family:var(--font-display);font-size:1.12rem;line-height:1.2;margin:0}.powerbi-report-hero p{color:#ffffffd1;font-size:.72rem;line-height:1.35;margin:0;max-width:760px}.powerbi-hero-badge{align-items:center;background:#ffffff1a;border:1px solid #fff3;border-radius:var(--radius-md);color:var(--white);display:flex;flex:0 0 auto;font-size:.82rem;font-weight:800;gap:7px;justify-content:center;min-width:132px;padding:7px 10px}.powerbi-hero-badge svg{height:15px;width:15px}.system-report-actions{align-items:center;display:flex;flex:0 0 auto;flex-wrap:wrap;gap:6px;justify-content:flex-end;max-width:760px}.system-report-action-btn{background:#fffffff5;border-color:#ffffff47;font-size:.76rem;min-height:30px;padding:6px 10px}.system-floating-snapshot-tray,.system-hero-snapshot-tray,.system-snapshot-bar,.system-snapshot-tray{border:1px solid var(--silver-100);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm)}.system-snapshot-tray{margin-top:calc(var(--space-lg)*-1)}.system-floating-snapshot-tray{background:#fff;max-height:142px;overflow:auto;padding:8px;position:absolute;right:18px;top:12px;width:min(520px,80vw);z-index:20}.system-hero-snapshot-tray{background:#fffffff5;max-height:54px;max-width:360px;overflow:auto;padding:5px;width:auto}.system-hero-snapshot-tray .analytics-snapshot-pill{min-height:34px;padding:5px 6px 5px 10px}.system-hero-snapshot-tray .analytics-snapshot-pill span{font-size:.72rem}.system-hero-snapshot-tray .analytics-snapshot-pill small{font-size:.62rem}.system-hero-snapshot-tray .analytics-snapshot-pill button{height:26px;width:26px}.powerbi-fullpage-frame{background:var(--white);border:1px solid var(--silver-100);border-radius:var(--radius-sm);box-shadow:var(--shadow-md);flex:1 1 auto;height:auto;min-height:0;overflow:hidden;position:relative;width:100%}.powerbi-fullpage-frame iframe{border:0;display:block;height:100%;width:100%}@media (max-width:768px){.powerbi-report-hero{align-items:stretch}.system-report-actions{justify-content:flex-start;max-width:none}.powerbi-hero-badge,.system-report-action-btn{width:100%}.analytics-modal-content{width:96vw}.analytics-modal-actions{flex-wrap:wrap;justify-content:flex-start}.analytics-download-btn{flex:1 1 170px;justify-content:center}.analytics-iframe-wrap{height:72vh;min-height:420px}.analytics-snapshot-bar{align-items:flex-start;flex-direction:column;padding-left:18px;padding-right:18px}.analytics-snapshot-bar p{text-align:left}.powerbi-report-hero{align-items:flex-start;flex-direction:column}.powerbi-hero-badge{width:100%}.powerbi-fullpage-frame{height:72vh;min-height:500px}.system-report-page .powerbi-fullpage-frame{flex:1 1 auto;height:auto;min-height:0}}.report-charts-grid{grid-gap:var(--space-xl);display:grid;gap:var(--space-xl);grid-template-columns:repeat(2,1fr);margin-bottom:var(--space-2xl)}.chart-card{background:var(--white);border:1px solid var(--silver-100);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);display:flex;flex-direction:column;padding:var(--space-xl)}.chart-card h3{color:var(--navy-800);font-family:var(--font-display);font-size:1.15rem;font-weight:700;margin-bottom:4px}.chart-subtitle{color:var(--text-secondary);font-size:.85rem;margin-bottom:var(--space-lg)}.chart-container{height:300px;width:100%}@media (max-width:1024px){.detail-content,.report-charts-grid{grid-template-columns:1fr}.detail-section{padding:1.5rem}}.admin-manage-overlay{background:#0f172aad;overflow-y:auto;padding:18px}.admin-manage-modal{background:#fff;border:1px solid #d9e0ea;border-radius:10px;display:flex;flex-direction:column;max-height:95vh;max-width:860px;overflow:hidden;width:min(860px,100%)}.admin-manage-modal:before{display:none}.admin-manage-header{align-items:flex-start;background:#f8fafc;border-bottom:1px solid #d9e0ea;display:flex;gap:18px;justify-content:space-between;padding:22px 26px}.admin-manage-header h3{color:#0f172a;font-size:1.24rem;font-weight:800;margin:2px 0 5px}.admin-manage-header p{color:#64748b;font-size:.88rem;margin:0;max-width:520px}.admin-manage-kicker{color:#64748b;display:block;font-size:.72rem;font-weight:800;letter-spacing:1.2px;text-transform:uppercase}.admin-manage-body{grid-gap:16px;background:#fff;display:grid;flex:1 1;gap:16px;max-height:calc(95vh - 150px);overflow-y:auto;padding:20px 26px 22px}.admin-manage-section{background:#fff;border:1px solid #d9e0ea;border-radius:8px;padding:18px}.admin-section-heading{align-items:flex-start;display:flex;gap:14px;justify-content:space-between;margin-bottom:16px}.admin-section-heading h4{color:#0f172a;font-size:1rem;font-weight:800;margin:0 0 4px}.admin-section-heading p{color:#64748b;font-size:.84rem;margin:0}.admin-count-badge{background:#f8fafc;border:1px solid #cbd5e1;border-radius:999px;color:#334155;flex-shrink:0;font-size:.76rem;font-weight:800;padding:6px 10px}.admin-campus-list{grid-gap:8px;display:grid;gap:8px;margin-bottom:16px}.admin-campus-item{align-items:center;background:#f8fafc;border:1px solid #e2e8f0;border-radius:7px;color:#0f172a;display:flex;font-size:.9rem;font-weight:700;gap:12px;justify-content:space-between;padding:11px 12px}.admin-link-danger{background:#0000;border:0;color:#b91c1c;cursor:pointer;font-size:.82rem;font-weight:800}.admin-link-danger:hover{color:#7f1d1d;text-decoration:underline}.admin-field-label{color:#475569;display:block;font-size:.78rem;font-weight:800;letter-spacing:.3px;margin:0 0 7px;text-transform:uppercase}.admin-empty-note{background:#f8fafc;border:1px dashed #cbd5e1;border-radius:7px;color:#64748b;font-size:.86rem;margin:0 0 14px;padding:12px 14px}.admin-inline-actions{display:flex;flex-wrap:wrap;gap:8px;justify-content:flex-end}.admin-manage-modal .admin-action-light{background:#fff!important;border:1px solid #cbd5e1!important;border-radius:6px!important;color:#334155!important;cursor:pointer;font-size:0!important;font-weight:800!important;min-width:76px;padding:8px 12px!important}.admin-manage-modal .admin-inline-actions .admin-action-light:first-child:after{content:"Edit";font-size:.82rem}.admin-manage-modal .admin-inline-actions .admin-action-light:first-child.active:after{content:"Done"}.admin-manage-modal .admin-inline-actions .admin-action-light:last-child:after{content:"Show";font-size:.82rem}.admin-manage-modal .admin-inline-actions .admin-action-light:last-child.active:after{content:"Hide"}.admin-manage-modal .admin-action-light:hover{background:#f1f5f9!important;color:#0f172a!important}.admin-credential-panel{background:#f8fafc;border-radius:8px;padding:14px}.admin-credential-panel div[style*=font-family],.admin-credential-panel input[style],.admin-edit-input,.admin-readonly-field,.admin-temp-password{background:#fff!important;border:1px solid #cbd5e1!important;border-radius:7px!important;box-sizing:border-box;color:#0f172a;font-family:Consolas,Courier New,monospace;font-size:.9rem!important;overflow-wrap:anywhere;padding:11px 12px!important;width:100%}.admin-temp-password{background:#f1f5f9!important;border-color:#94a3b8!important;font-weight:800!important}.admin-credential-panel label[style]{color:#475569!important;display:block!important;font-size:.78rem!important;font-weight:800!important;letter-spacing:.3px;margin:0 0 7px!important;text-transform:uppercase}.admin-edit-block{margin-bottom:14px}.admin-edit-block:last-child{margin-bottom:0}.admin-edit-block.with-divider{border-top:1px solid #d9e0ea;padding-top:16px}.admin-edit-input{display:block;margin-bottom:10px}.admin-edit-input:focus{border-color:#2563eb!important;box-shadow:0 0 0 3px #2563eb1f;outline:none}.admin-credential-panel p[style*="#d32f2f"],.admin-credential-panel p[style*="211, 47, 47"],.admin-security-note{color:#9f1239!important;font-size:0!important;font-weight:700;margin:8px 0 0!important}.admin-credential-panel p[style*="#d32f2f"]:after,.admin-credential-panel p[style*="211, 47, 47"]:after{content:"Share this password securely. The admin should change it on first login.";font-size:.8rem}.admin-manage-modal .admin-action-danger,.admin-manage-modal .admin-action-primary,.admin-manage-modal .admin-action-secondary{border-radius:6px!important;cursor:pointer;font-size:.86rem!important;font-weight:800!important;min-height:40px;padding:10px 15px!important;transition:background var(--transition-fast),border-color var(--transition-fast),color var(--transition-fast)}.admin-manage-modal .admin-action-primary{background:#1d4ed8!important;border:1px solid #1d4ed8!important;color:#fff!important;margin-top:2px}.admin-manage-modal .admin-action-primary:hover{background:#1e40af!important}.admin-manage-actions{background:#f8fafc;border-top:1px solid #d9e0ea;display:flex;flex-wrap:wrap;gap:10px;justify-content:flex-end;padding:16px 26px}.admin-manage-modal .admin-action-secondary{background:#fff!important;border:1px solid #cbd5e1!important;color:#334155!important;font-size:0!important}.admin-manage-modal .admin-action-secondary:after{content:"Reset Password";font-size:.86rem}.admin-manage-modal .admin-action-secondary:hover{background:#eef2f7!important;border-color:#94a3b8!important;color:#0f172a!important}.admin-manage-modal .admin-action-danger{background:#b91c1c!important;border:1px solid #b91c1c!important;color:#fff!important;font-size:0!important}.admin-manage-modal .admin-action-danger:after{content:"Delete Admin";font-size:.86rem}.admin-manage-modal .admin-action-danger:hover{background:#991b1b!important;border-color:#991b1b!important}.admin-manage-close{background:#f8fafc;display:flex;justify-content:flex-end;padding:0 26px 22px}@media (max-width:680px){.admin-manage-actions,.admin-manage-body,.admin-manage-close,.admin-manage-header{padding-left:16px;padding-right:16px}.admin-section-heading{flex-direction:column}.admin-inline-actions,.admin-manage-actions{justify-content:stretch}.admin-manage-close .btn-secondary,.admin-manage-modal .admin-action-danger,.admin-manage-modal .admin-action-light,.admin-manage-modal .admin-action-primary,.admin-manage-modal .admin-action-secondary{width:100%}}@media print{.back-btn,.btn-primary,.btn-secondary,.dashboard-content,.form-page,.main-content,.modal-actions,.sidebar,.topbar,button{display:none!important}body,html{background:#fff;margin:0;padding:0;width:380px}.modal-overlay{align-items:flex-start!important;background:#fff!important;display:flex!important;height:auto!important;justify-content:center!important}.modal-content,.modal-overlay{margin:0!important;padding:0!important;position:static!important;width:380px!important}.modal-content{animation:none!important;border:none!important;border-radius:0!important;box-shadow:none!important;max-width:380px!important;page-break-after:always;transform:none!important}@page{size:80mm auto;margin:0}*{color-adjust:exact!important;-webkit-print-color-adjust:exact!important;print-color-adjust:exact!important}div{box-shadow:none!important}h1,h2,h3,h4,h5,h6,p,span{page-break-inside:avoid}}.topbar{background:#fff;border-bottom:1px solid #e2e8f0;height:70px;justify-content:space-between;padding:0 2rem;position:sticky;top:0;z-index:100}.topbar,.topbar-left{align-items:center;display:flex}.topbar-left{gap:1rem}.topbar-right{align-items:center;display:flex;gap:1.5rem}.menu-toggle{background:none;border:none;border-radius:6px;cursor:pointer;display:none;padding:.5rem;transition:background .2s}.menu-toggle:hover{background:#f7fafc}.page-icon-badge{align-items:center;background:#ebf8ff;border-radius:8px;color:#3182ce;display:flex;height:38px;justify-content:center;width:38px}.page-title{color:#2d3748;font-size:1.25rem;font-weight:600;margin:0}.topbar-date{background:#f7fafc;border-radius:6px;color:#718096;font-size:.875rem;gap:.5rem;padding:.5rem 1rem}.topbar-date,.topbar-user{align-items:center;display:flex}.topbar-user{border-left:1px solid #e2e8f0;border-right:1px solid #e2e8f0;gap:.75rem;padding:.25rem .75rem}.user-avatar-small{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:50%;color:#fff;display:flex;flex-shrink:0;font-size:14px;font-weight:600;height:36px;justify-content:center;width:36px}.user-info-small{display:flex;flex-direction:column;line-height:1.2}.user-name{color:#2d3748;font-size:13px;font-weight:500}.role-badge-header{border-radius:10px;display:inline-block;font-size:10px;font-weight:600;letter-spacing:.5px;padding:1px 8px;text-transform:uppercase}.role-badge-header.superadmin{background:#fed7d7;color:#c53030}.role-badge-header.admin{background:#bee3f8;color:#2b6cb0}.role-badge-header.controller{background:#c6f6d5;color:#276749}.role-badge-header.viewer{background:#feebc8;color:#c05621}.logout-btn-header{align-items:center;background:#fc8181;border:none;border-radius:6px;color:#fff;cursor:pointer;display:flex;font-size:13px;font-weight:500;gap:.5rem;padding:.5rem 1rem;transition:all .2s ease}.logout-btn-header:hover{background:#f56565;box-shadow:0 4px 12px #f565654d;transform:translateY(-1px)}.logout-btn-header:active{transform:translateY(0)}.logout-btn-header svg{height:18px;width:18px}@media (max-width:768px){.menu-toggle{display:block}.topbar{padding:0 1rem}.topbar-right{gap:.75rem}.topbar-date{font-size:.75rem;padding:.25rem .5rem}.topbar-date svg{height:16px;width:16px}.topbar-user{border-left:none;border-right:none;padding:.25rem .5rem}.logout-btn-header span,.user-info-small{display:none}.logout-btn-header{border-radius:50%;height:36px;justify-content:center;padding:.5rem;width:36px}.logout-btn-header svg{height:20px;width:20px}.page-title{font-size:1rem}.page-icon-badge{height:32px;width:32px}}@media (max-width:480px){.topbar-date{display:none}.topbar-user{border:none;padding:0}}.campus-card.clickable{cursor:pointer;transition:all .2s ease}.campus-card.clickable:hover{box-shadow:0 8px 25px #0000001a;transform:translateY(-4px)}.header-left{gap:1rem}.btn-back,.header-left{align-items:center;display:flex}.btn-back{background:#f7fafc;border:1px solid #e2e8f0;border-radius:6px;color:#4a5568;cursor:pointer;font-size:.875rem;gap:.5rem;padding:.5rem 1rem;transition:all .2s ease}.btn-back:hover{background:#edf2f7;border-color:#cbd5e0}.class-management,.session-management{padding:2rem}.management-header{margin-bottom:1.5rem}.management-header h3{font-size:1.3rem}.management-header button{align-items:center;background:var(--navy-600);border:none;border-radius:var(--radius-md);color:#fff;cursor:pointer;display:flex;font-weight:600;gap:.5rem;padding:.6rem 1.2rem;transition:background .2s ease}.management-header button:hover{background:var(--navy-700)}.back-button{align-items:center;background:none;border:none;border-radius:var(--radius-md);color:var(--navy-600);cursor:pointer;display:flex;font-size:.95rem;font-weight:600;gap:.5rem;padding:.5rem 1rem;transition:all .2s ease}.back-button:hover{background:#1e3a8a14;color:var(--navy-800);text-decoration:none}.session-grid{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));margin-top:1.5rem}.session-card{background:#fff;border-radius:12px;box-shadow:0 2px 8px #00000014;overflow:hidden;transition:all .2s ease}.session-card:hover{box-shadow:0 4px 16px #0000001f;transform:translateY(-2px)}.session-card-header{align-items:center;background:#f7fafc;border-bottom:1px solid #e2e8f0;display:flex;justify-content:space-between;padding:1rem 1.5rem}.session-card-header h3{color:#2d3748;font-size:1.1rem;margin:0}.session-status{align-items:center;display:flex}.status-badge.active{background:#c6f6d5}.status-badge.inactive{background:#fed7d7;color:#c53030}.session-card-body{padding:1rem 1.5rem}.session-card-body p{color:#4a5568;font-size:.9rem;margin:.25rem 0}.session-card-footer{background:#f7fafc;border-top:1px solid #e2e8f0;display:flex;flex-wrap:wrap;gap:.5rem;padding:.75rem 1.5rem}.class-grid{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));margin-top:1.5rem}.class-card{background:#fff;border-radius:12px;box-shadow:0 2px 8px #00000014;overflow:hidden;transition:all .2s ease}.class-card:hover{box-shadow:0 4px 16px #0000001f;transform:translateY(-2px)}.class-card-header{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;display:flex;justify-content:space-between;padding:1rem 1.5rem}.class-card-header h3{font-size:1.1rem;margin:0}.section-badge{background:#fff3;font-weight:600}.class-card-body{padding:1rem 1.5rem}.class-card-body p{color:#4a5568;font-size:.9rem;margin:0}.class-card-footer{background:#f7fafc;border-top:1px solid #e2e8f0;display:flex;flex-wrap:wrap;gap:.5rem;padding:.75rem 1.5rem}.btn-text-primary{border-radius:4px;transition:all .2s ease}.btn-text-primary:hover{background:#ebf8ff}.btn-text{border-radius:4px;transition:all .2s ease}.btn-text:hover{background:#edf2f7}.btn-text-danger{border-radius:4px;transition:all .2s ease}.btn-text-danger:hover{background:#fff5f5;color:#c53030}.student-table-container{background:#fff;border-radius:12px;box-shadow:0 2px 8px #00000014;margin-top:1.5rem;overflow:hidden}.student-table{border-collapse:collapse;width:100%}.student-table thead{background:#f7fafc}.student-table th{border-bottom:2px solid #e2e8f0;color:#4a5568;font-size:.8rem;font-weight:600;letter-spacing:.5px;padding:.75rem 1.5rem;text-align:left;text-transform:uppercase}.student-table td{border-bottom:1px solid #e2e8f0;color:#2d3748;padding:.75rem 1.5rem}.student-table tbody tr:hover{background:#f7fafc}.status-badge-small{border-radius:12px;font-size:.75rem;font-weight:600;padding:.2rem .6rem}.status-badge-small.active{background:#c6f6d5;color:#276749}.status-badge-small.withdrawn{background:#fed7d7;color:#c53030}.loading-state{color:#718096;padding:3rem;text-align:center}.analytics-placeholder{align-items:center;color:#718096;display:flex;flex-direction:column;height:100%;justify-content:center;min-height:400px}.analytics-placeholder svg{height:64px;margin-bottom:1rem;opacity:.5;width:64px}.analytics-placeholder p{font-size:1.1rem;margin:.5rem 0}.analytics-placeholder small{color:#a0aec0}@media (max-width:768px){.class-grid,.session-grid{grid-template-columns:1fr}.header-left{flex-wrap:wrap}.btn-back{justify-content:center;width:100%}.class-card-footer,.session-card-footer{flex-direction:column}.class-card-footer button,.session-card-footer button{justify-content:center;width:100%}.student-table-container{overflow-x:auto}.student-table{font-size:.875rem}.student-table td,.student-table th{padding:.5rem .75rem}}.plus-icon{font-size:1.2rem;font-weight:700;line-height:1}.campus-detail-container{padding:1.5rem}.campus-detail-header{gap:1rem;margin-bottom:2rem}.campus-detail-header .back-button{background:none;padding:.5rem 1rem}.campus-detail-header .back-button:hover{background:#f7fafc}.detail-title{font-size:1.8rem}.campus-management-cards{grid-gap:2rem;display:grid;gap:2rem;grid-template-columns:repeat(auto-fit,minmax(320px,1fr));padding:1rem 0}.management-card{align-items:center;background:#fff;border:2px solid #0000;border-radius:16px;box-shadow:0 4px 12px #00000014;cursor:pointer;display:flex;flex-direction:column;overflow:hidden;padding:2rem;position:relative;text-align:center;transition:all .3s ease}.management-card:hover{box-shadow:0 8px 24px #0000001f;transform:translateY(-4px)}.management-card.sessions-card:hover{border-color:#4299e1}.management-card.classes-card:hover{border-color:#48bb78}.management-card .card-icon{align-items:center;border-radius:50%;display:flex;font-size:2rem;height:72px;justify-content:center;margin-bottom:1.25rem;width:72px}.sessions-card .card-icon{background:#ebf8ff;color:#4299e1}.classes-card .card-icon{background:#f0fff4;color:#48bb78}.management-card .card-content h3{color:#2d3748;font-size:1.5rem;font-weight:600;margin:0 0 .5rem}.management-card .card-content p{color:#718096;font-size:.95rem;margin:0 0 1rem}.management-card .card-stats{margin-bottom:1.25rem}.management-card .stat-badge{background:#f7fafc;border-radius:20px;color:#4a5568;font-size:.85rem;font-weight:500;padding:.25rem 1rem}.sessions-card .stat-badge{background:#ebf8ff;color:#2b6cb0}.classes-card .stat-badge{background:#f0fff4;color:#276749}.management-card .card-action-btn{border:none;border-radius:8px;cursor:pointer;font-size:.95rem;font-weight:500;padding:.5rem 1.5rem;transition:all .2s}.sessions-card .card-action-btn{background:#ebf8ff;color:#2b6cb0}.sessions-card .card-action-btn:hover{background:#bee3f8}.classes-card .card-action-btn{background:#f0fff4;color:#276749}.classes-card .card-action-btn:hover{background:#c6f6d5}.class-management-full,.session-management-full{margin:0 auto;max-width:1200px;padding:1.5rem}.management-header .back-button{background:none;padding:.5rem 1rem}.management-header .back-button:hover{background:#f7fafc}.management-header h3{color:#2d3748;font-size:1.5rem;font-weight:600;margin:0}.class-grid,.session-grid{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fill,minmax(300px,1fr))}.class-card,.session-card{background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000000f;overflow:hidden;transition:all .2s}.class-card:hover,.session-card:hover{box-shadow:0 4px 16px #0000001a}.class-card-header,.session-card-header{align-items:center;border-bottom:1px solid #e2e8f0;display:flex;justify-content:space-between;padding:1.25rem 1.5rem}.class-card-header h3,.session-card-header h3{color:#2d3748;font-size:1.1rem;font-weight:600;margin:0}.class-card-body,.session-card-body{padding:1.25rem 1.5rem}.class-card-body p,.session-card-body p{color:#4a5568;font-size:.9rem;margin:.25rem 0}.class-card-footer,.session-card-footer{border-top:1px solid #e2e8f0;display:flex;gap:.5rem;justify-content:flex-end;padding:.75rem 1.5rem}.section-badge,.status-badge{font-size:.75rem}@media (max-width:768px){.campus-management-cards{grid-template-columns:1fr}.management-header{align-items:flex-start;flex-direction:column;gap:1rem}.management-header .header-left{flex-wrap:wrap}.class-grid,.session-grid{grid-template-columns:1fr}}.campus-detail-container{max-width:1200px;padding:2rem}.campus-detail-header{align-items:center;border-bottom:2px solid #e2e8f0;display:flex;gap:1.5rem;margin-bottom:3rem;padding-bottom:1rem}.campus-detail-header .back-button{align-items:center;background:#f7fafc;border:1px solid #e2e8f0;border-radius:8px;color:#4a5568;cursor:pointer;display:flex;font-size:.9rem;gap:.5rem;padding:.5rem 1.25rem;transition:all .2s}.campus-detail-header .back-button:hover{background:#edf2f7;border-color:#cbd5e0}.detail-title{color:#2d3748;font-size:2rem;font-weight:600;margin:0}.campus-cards-container{grid-gap:2rem;display:grid;gap:2rem;grid-template-columns:repeat(3,minmax(0,1fr));padding:1rem 0}@media (max-width:768px){.campus-cards-container{grid-template-columns:1fr}}.campus-option-card{align-items:center;background:#fff;border:2px solid #0000;border-radius:20px;box-shadow:0 4px 20px #00000014;cursor:pointer;display:flex;flex-direction:column;overflow:hidden;padding:2.5rem;position:relative;text-align:center;transition:all .3s ease}.campus-option-card:before{content:"";height:4px;left:0;position:absolute;right:0;top:0;transition:height .3s ease}.campus-option-card:hover{box-shadow:0 8px 30px #0000001f;transform:translateY(-6px)}.campus-option-card.sessions-card:before{background:#4299e1}.campus-option-card.classes-card:before{background:#48bb78}.campus-option-card.assignments-card:before{background:#7c3aed}.campus-option-card.sessions-card:hover{border-color:#4299e1}.campus-option-card.classes-card:hover{border-color:#48bb78}.campus-option-card.assignments-card:hover{border-color:#7c3aed}.campus-option-card .card-icon-wrapper{align-items:center;border-radius:50%;display:flex;height:80px;justify-content:center;margin-bottom:1.5rem;transition:transform .3s ease;width:80px}.campus-option-card:hover .card-icon-wrapper{transform:scale(1.05)}.sessions-card .card-icon-wrapper{background:#ebf8ff;color:#4299e1}.classes-card .card-icon-wrapper{background:#f0fff4;color:#48bb78}.assignments-card .card-icon-wrapper{background:#f3e8ff;color:#7c3aed}.campus-option-card .card-icon{font-size:2.5rem}.campus-option-card .card-info h3{color:#2d3748;font-size:1.75rem;font-weight:600;margin:0 0 .5rem}.campus-option-card .card-info p{color:#718096;font-size:1rem;margin:0 0 1.5rem}.campus-option-card .card-stats{align-items:center;background:#f7fafc;border-radius:12px;display:flex;flex-direction:column;margin-bottom:1.5rem;min-width:120px;padding:.5rem 1.5rem}.sessions-card .card-stats{background:#ebf8ff}.classes-card .card-stats{background:#f0fff4}.assignments-card .card-stats{background:#f3e8ff}.campus-option-card .stat-count{color:#2d3748;font-size:2rem;font-weight:700;line-height:1.2}.sessions-card .stat-count{color:#2b6cb0}.classes-card .stat-count{color:#276749}.assignments-card .stat-count{color:#5b21b6}.campus-option-card .stat-label{color:#718096;font-size:.8rem;font-weight:500}.sessions-card .stat-label{color:#2b6cb0}.classes-card .stat-label{color:#276749}.assignments-card .stat-label{color:#5b21b6}.campus-option-card .card-button{border:none;border-radius:10px;cursor:pointer;font-size:.95rem;font-weight:600;max-width:200px;padding:.6rem 2rem;transition:all .3s ease;width:100%}.sessions-card .card-button{background:#4299e1;color:#fff}.sessions-card .card-button:hover{background:#2b6cb0;transform:scale(1.02)}.classes-card .card-button{background:#48bb78;color:#fff}.classes-card .card-button:hover{background:#276749;transform:scale(1.02)}.assignments-card .card-button{background:#7c3aed;color:#fff}.assignments-card .card-button:hover{background:#5b21b6;transform:scale(1.02)}.assignments-subview{background:linear-gradient(135deg,#f5f3ff,#fff)}.assignment-session-panel{margin:1.25rem 0}.campus-section-heading{align-items:center;color:#2d3748;display:flex;font-weight:700;gap:1rem;justify-content:space-between;margin-bottom:1rem}.campus-section-heading strong{color:#7c3aed}.assignment-session-grid{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(auto-fit,minmax(220px,1fr))}.assignment-session-card{background:#fff;border:1px solid #e2e8f0;border-radius:12px;box-shadow:0 2px 10px #0f172a0f;display:flex;gap:1rem;justify-content:space-between;min-height:112px;padding:1rem}.assignment-session-card h3{color:#2d3748;font-size:1rem;margin:.25rem 0 0}.assignment-session-meta{align-items:flex-end;color:#4a5568;display:flex;flex-direction:column;font-size:.85rem;justify-content:space-between;white-space:nowrap}.assignment-session-meta span{border-radius:999px;font-weight:700;padding:.25rem .6rem}.assignment-session-meta .active{background:#dcfce7;color:#166534}.assignment-session-meta .inactive{background:#f1f5f9;color:#64748b}.assignment-table-wrap{background:#fff;border:1px solid #e2e8f0;border-radius:12px;box-shadow:0 2px 10px #0f172a0f;overflow-x:auto}.assignment-table{border-collapse:collapse;min-width:760px;width:100%}.assignment-table td,.assignment-table th{border-bottom:1px solid #edf2f7;padding:.9rem 1rem;text-align:left;vertical-align:middle}.assignment-table th{background:#f8fafc;color:#475569;font-size:.78rem;letter-spacing:.04em;text-transform:uppercase}.assignment-table td{color:#2d3748}.assignment-table td span,.assignment-table td strong{display:block}.assignment-table td span{color:#718096;font-size:.85rem;margin-top:.2rem}.assignment-table select{background:#fff;border:1px solid #cbd5e1;border-radius:8px;color:#1e293b;min-width:190px;padding:.6rem .75rem;width:100%}.assignment-save-button{align-items:center;display:inline-flex;gap:.4rem;justify-content:center;min-width:104px}.assignment-save-button:disabled{cursor:not-allowed;opacity:.55}.management-page{margin:0 auto;max-width:1200px;padding:2rem}.management-header{border-bottom:2px solid #e2e8f0;flex-wrap:wrap;justify-content:space-between;margin-bottom:2rem;padding-bottom:1rem}.management-header,.management-header .header-left{align-items:center;display:flex;gap:1rem}.management-header .back-button{align-items:center;background:#f7fafc;border:1px solid #e2e8f0;border-radius:8px;color:#4a5568;cursor:pointer;display:flex;font-size:.9rem;gap:.5rem;padding:.5rem 1.25rem;transition:all .2s}.management-header .back-button:hover{background:#edf2f7;border-color:#cbd5e0}.management-header h2{color:#2d3748;font-size:1.5rem;font-weight:600;margin:0}.items-grid{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fill,minmax(320px,1fr))}.item-card{background:#fff;border-radius:12px;box-shadow:0 2px 10px #0000000f;overflow:hidden;transition:all .2s}.item-card:hover{box-shadow:0 4px 20px #0000001a}.item-card-header{align-items:center;border-bottom:1px solid #e2e8f0;display:flex;flex-wrap:wrap;gap:.5rem;justify-content:space-between;padding:1.25rem 1.5rem}.item-card-header h3{color:#2d3748;font-size:1.1rem;font-weight:600;margin:0}.item-card-body{padding:1.25rem 1.5rem}.item-card-body p{color:#4a5568;font-size:.9rem;margin:.35rem 0}.item-card-footer{border-top:1px solid #e2e8f0;display:flex;flex-wrap:wrap;gap:.5rem;justify-content:flex-end;padding:.75rem 1.5rem}.status-badge{border-radius:20px;font-size:.7rem;font-weight:600;padding:.25rem .75rem;text-transform:uppercase}.status-badge.active{background:#f0fff4;color:#276749}.status-badge.inactive{background:#fff5f5;color:#9b2c2c}.section-badge{background:#ebf8ff;border-radius:20px;color:#2b6cb0;font-size:.7rem;font-weight:500;padding:.25rem .75rem}.btn-text{align-items:center;background:none;border:none;color:#4a5568;cursor:pointer;display:flex;font-size:.85rem;gap:.25rem;padding:.25rem .5rem;transition:color .2s}.btn-text:hover{color:#2d3748}.btn-text-primary{align-items:center;background:none;border:none;color:#4299e1;cursor:pointer;display:flex;font-size:.85rem;gap:.25rem;padding:.25rem .5rem;transition:color .2s}.btn-text-primary:hover{color:#2b6cb0}.btn-text-danger{align-items:center;background:none;border:none;color:#fc8181;cursor:pointer;display:flex;font-size:.85rem;gap:.25rem;padding:.25rem .5rem;transition:color .2s}.btn-text-danger:hover{color:#e53e3e}.empty-state{background:#f7fafc;border-radius:12px;color:#718096;grid-column:1/-1;padding:3rem;text-align:center}.empty-state p{font-size:1rem;margin:0}@media (max-width:768px){.campus-cards-container{grid-template-columns:1fr}.campus-option-card{padding:1.5rem}.management-header{align-items:flex-start;flex-direction:column}.items-grid{grid-template-columns:1fr}}.campus-subview-page.management-page{display:flex;flex-direction:column;gap:var(--space-lg);max-width:1240px;padding:var(--space-xl)}.campus-subview-hero{align-items:stretch;background:linear-gradient(135deg,#fff,#f8fafc 62%,#eef2f7);border:1px solid #1e3a5f24;border-radius:var(--radius-lg);border-top:4px solid var(--navy-500);box-shadow:var(--shadow-md);display:flex;gap:var(--space-xl);justify-content:space-between;padding:var(--space-xl)}.campus-subview-hero.classes-subview{border-top-color:var(--gold-500)}.campus-subview-title{min-width:0}.campus-subview-back.back-button{background:#fff;border-color:#dbe3ef;color:var(--navy-700);margin-bottom:var(--space-md);width:fit-content}.campus-subview-back.back-button:hover{background:#f8fafc;border-color:var(--navy-300);color:var(--navy-900)}.campus-subview-kicker{color:var(--red-500);display:inline-block;font-size:.74rem;font-weight:800;letter-spacing:.08em;margin-bottom:8px;text-transform:uppercase}.campus-subview-title h2{color:var(--navy-900);font-family:var(--font-display);font-size:1.72rem;line-height:1.2;margin:0 0 8px}.campus-subview-title p{color:var(--text-secondary);font-size:.94rem;line-height:1.5;margin:0;max-width:560px}.campus-subview-actions{align-items:stretch;display:flex;gap:var(--space-md);justify-content:flex-end;min-width:min(520px,48%)}.campus-subview-metrics{grid-gap:var(--space-sm);display:grid;flex:1 1;gap:var(--space-sm);grid-template-columns:repeat(3,minmax(96px,1fr))}.campus-subview-metric{background:#fff;border:1px solid #dbe3ef;border-radius:var(--radius-md);box-shadow:var(--shadow-sm);min-height:96px;padding:14px 16px}.campus-subview-metric svg{color:var(--navy-500);font-size:1.15rem}.campus-subview-metric.success svg{color:#2d873e}.campus-subview-metric.muted{background:#f8fafc}.campus-subview-metric.muted svg{color:var(--text-muted)}.campus-subview-metric strong{color:var(--navy-900);display:block;font-family:var(--font-display);font-size:1.5rem;line-height:1;margin-top:8px}.campus-subview-metric span{color:var(--text-secondary);display:block;font-size:.72rem;font-weight:800;letter-spacing:.04em;margin-top:6px;text-transform:uppercase}.campus-hero-action.btn-primary{align-self:stretch;justify-content:center;min-width:138px}.campus-subview-toolbar{grid-gap:var(--space-md);align-items:end;background:#fff;border:1px solid #dbe3ef;border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);display:grid;gap:var(--space-md);grid-template-columns:minmax(280px,1fr) minmax(220px,280px);padding:var(--space-md)}.campus-filter-field{display:flex;flex-direction:column;gap:8px}.campus-filter-field label{align-items:center;color:var(--navy-800);display:inline-flex;font-size:.75rem;font-weight:800;gap:6px;letter-spacing:.05em;text-transform:uppercase}.campus-search-input-wrap{align-items:center;display:flex;position:relative}.campus-search-input-wrap svg{color:var(--text-muted);font-size:1.12rem;left:14px;pointer-events:none;position:absolute}.campus-filter-field input,.campus-filter-field select{background:#f8fafc;border:1px solid #dbe3ef;border-radius:var(--radius-md);color:var(--text-primary);font-size:.9rem;min-height:44px;outline:none;padding:0 14px;transition:border-color var(--transition-fast),box-shadow var(--transition-fast),background var(--transition-fast);width:100%}.campus-search-input-wrap input{padding-left:42px}.campus-filter-field input:focus,.campus-filter-field select:focus{background:#fff;border-color:var(--navy-500);box-shadow:0 0 0 3px #1e3a5f1a}.campus-results-summary{color:var(--text-secondary);font-size:.84rem;font-weight:700;padding:0 4px}.campus-card-grid.items-grid{gap:var(--space-lg);grid-template-columns:repeat(auto-fill,minmax(310px,1fr))}.campus-table-card{background:#fff;border:1px solid #dbe3ef;border-radius:var(--radius-md);box-shadow:var(--shadow-sm);overflow:hidden}.campus-table-scroll{overflow-x:auto;width:100%}.campus-management-table{border-collapse:collapse;min-width:920px;width:100%}.campus-management-table td,.campus-management-table th{border-bottom:1px solid #eef2f7;padding:14px 16px;text-align:left;vertical-align:middle}.campus-management-table th{background:#f8fafc;color:var(--text-secondary);font-size:.72rem;font-weight:900;letter-spacing:.06em;text-transform:uppercase;white-space:nowrap}.campus-management-table td{color:var(--navy-900);font-size:.9rem}.campus-management-table tbody tr{transition:background var(--transition-fast)}.campus-management-table tbody tr:hover{background:#fbfdff}.campus-management-table tbody tr:last-child td{border-bottom:0}.campus-table-title{align-items:center;display:flex;gap:10px;min-width:0}.campus-table-title strong{color:var(--navy-900);font-family:var(--font-display);font-size:.96rem;line-height:1.3;overflow-wrap:anywhere}.campus-table-icon{align-items:center;background:#eef2f7;border-radius:8px;color:var(--navy-600);display:inline-flex;flex:0 0 34px;font-size:1.08rem;height:34px;justify-content:center;width:34px}.campus-table-icon.class-icon{background:#fff8e1;color:#9a6b00}.campus-table-actions-heading{text-align:right!important}.campus-table-actions{align-items:center;display:flex;flex-wrap:wrap;gap:6px;justify-content:flex-end}.campus-management-card.item-card{background:#fff;border:1px solid #dbe3ef;border-radius:var(--radius-md);border-top:4px solid var(--navy-500);box-shadow:var(--shadow-sm);display:flex;flex-direction:column;min-height:304px;transition:border-color var(--transition-fast),box-shadow var(--transition-fast),transform var(--transition-fast)}.campus-management-card.class-card{border-top-color:var(--gold-500)}.campus-management-card.item-card:hover{border-color:#bfc8da;box-shadow:var(--shadow-md);transform:translateY(-3px)}.campus-item-card-top{align-items:flex-start;border-bottom:1px solid #eef2f7;display:flex;gap:12px;padding:var(--space-md)}.campus-item-avatar{align-items:center;background:#eef2f7;border-radius:var(--radius-md);color:var(--navy-600);display:inline-flex;flex:0 0 44px;font-size:1.35rem;height:44px;justify-content:center;width:44px}.campus-item-avatar.class-avatar{background:#fff8e1;color:#9a6b00}.campus-item-title-block{flex:1 1;min-width:0}.campus-card-eyebrow{color:var(--text-muted);display:block;font-size:.7rem;font-weight:800;letter-spacing:.05em;margin-bottom:4px;text-transform:uppercase}.campus-item-title-block h3{color:var(--navy-900);font-family:var(--font-display);font-size:1.08rem;line-height:1.3;margin:0;overflow-wrap:anywhere}.campus-section-badge.section-badge,.campus-status-badge.status-badge{align-items:center;border:1px solid #0000;border-radius:var(--radius-full);display:inline-flex;gap:5px;min-height:28px;padding:5px 10px;white-space:nowrap}.campus-status-badge.status-badge.active{background:#2d873e1a;border-color:#2d873e33;color:#2d873e}.campus-status-badge.status-badge.inactive{background:#d4272e17;border-color:#d4272e2e;color:var(--red-500)}.campus-section-badge.section-badge{background:#fff8e1;border-color:#c49a2a38;color:#8a6100;font-weight:800}.campus-card-details{grid-gap:12px;display:grid;flex:1 1;gap:12px;padding:var(--space-md)}.campus-detail-line{align-items:flex-start;display:flex;gap:10px;min-width:0}.campus-detail-line>svg{color:var(--navy-500);flex:0 0 18px;font-size:1.12rem;margin-top:2px}.class-card .campus-detail-line>svg{color:#9a6b00}.campus-detail-line span{color:var(--text-muted);display:block;font-size:.7rem;font-weight:800;letter-spacing:.04em;margin-bottom:3px;text-transform:uppercase}.campus-detail-line strong{color:var(--navy-900);display:block;font-size:.92rem;line-height:1.35;overflow-wrap:anywhere}.campus-muted-value{color:var(--text-muted)!important}.campus-item-meta{display:flex;flex-wrap:wrap;gap:8px;padding:0 var(--space-md) var(--space-md)}.campus-chip,.session-stage{align-items:center;background:#eef2f7;border-radius:var(--radius-full);color:var(--text-secondary);display:inline-flex;font-size:.76rem;font-weight:800;min-height:28px;padding:5px 10px}.session-stage.in-progress{background:#2d873e1a;color:#2d873e}.session-stage.upcoming{background:#1e3a5f1a;color:var(--navy-600)}.session-stage.completed{background:#5a5e6a1a;color:var(--text-secondary)}.session-stage.muted{background:#f1f5f9;color:var(--text-muted)}.campus-card-actions.item-card-footer{align-items:center;background:#f8fafc;border-top:1px solid #eef2f7;justify-content:space-between;margin-top:auto;padding:var(--space-sm) var(--space-md)}.campus-action-group{align-items:center;display:flex;flex-wrap:wrap;gap:6px}.campus-action-button{border-radius:8px;font-weight:800;min-height:34px;padding:7px 10px}.campus-action-button.primary{background:#fff;border:1px solid #dbe3ef;color:var(--navy-700)}.campus-action-button.primary:hover{background:#eef2f7;border-color:var(--navy-300);color:var(--navy-900);text-decoration:none}.campus-action-button.danger:hover{background:#d4272e14;text-decoration:none}.campus-empty-state.empty-state{align-items:center;background:linear-gradient(180deg,#fff,#f8fafc);border:1px dashed #cbd5e1;border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);color:var(--text-secondary);display:flex;flex-direction:column;gap:var(--space-sm);justify-content:center;min-height:260px;padding:var(--space-3xl) var(--space-lg)}.campus-empty-icon{align-items:center;background:#eef2f7;border-radius:var(--radius-md);color:var(--navy-500);display:inline-flex;font-size:1.65rem;height:56px;justify-content:center;width:56px}.campus-empty-state h3{color:var(--navy-900);font-family:var(--font-display);font-size:1.12rem;margin:0}.campus-empty-state p{color:var(--text-secondary);font-size:.9rem;margin:0}.campus-form-modal.modal-content{border:1px solid #1e3a5f1a}.btn-primary:disabled,.btn-secondary:disabled,.btn-text-danger:disabled,.btn-text-primary:disabled,.btn-text:disabled{box-shadow:none;cursor:not-allowed;opacity:.58;transform:none}@media (max-width:1080px){.campus-subview-hero{flex-direction:column}.campus-subview-actions{min-width:0;width:100%}}@media (max-width:760px){.campus-subview-hero,.campus-subview-page.management-page,.campus-subview-toolbar{padding:var(--space-md)}.campus-subview-actions,.campus-subview-metrics,.campus-subview-toolbar{grid-template-columns:1fr}.campus-subview-actions{flex-direction:column}.campus-hero-action.btn-primary{min-height:44px}.campus-card-grid.items-grid{grid-template-columns:1fr}.campus-table-card{background:#0000;border:0;box-shadow:none}.campus-table-scroll{overflow:visible}.campus-management-table{min-width:0}.campus-management-table thead{display:none}.campus-management-table,.campus-management-table tbody,.campus-management-table td,.campus-management-table tr{display:block;width:100%}.campus-management-table tr{background:#fff;border:1px solid #dbe3ef;border-radius:var(--radius-md);box-shadow:var(--shadow-sm);margin-bottom:var(--space-md);overflow:hidden}.campus-management-table td{grid-gap:12px;align-items:center;display:grid;gap:12px;grid-template-columns:minmax(104px,38%) minmax(0,1fr);min-height:48px;padding:12px 14px}.campus-management-table td:before{color:var(--text-muted);content:attr(data-label);font-size:.7rem;font-weight:900;letter-spacing:.05em;text-transform:uppercase}.campus-table-actions-heading{text-align:left!important}.campus-table-actions{justify-content:flex-start}.campus-card-actions.item-card-footer{align-items:stretch;flex-direction:column}.campus-action-button,.campus-action-group{justify-content:center;width:100%}}.enrollment-shell{background:linear-gradient(180deg,#f8fafc,#fff);display:flex;min-height:0}.enrollment-rail{background:linear-gradient(180deg,#102b4ee0,#122a4ceb),var(--navy-900);border-right:3px solid var(--gold-500);color:#fff;display:flex;flex-direction:column;min-height:calc(100vh - 73px);padding:36px 34px 28px}.enrollment-brand{align-items:center;display:flex;gap:14px;margin-bottom:44px}.enrollment-brand img{background:#fff;border-radius:12px;height:50px;object-fit:contain;padding:6px;width:50px}.enrollment-brand strong{color:#fff;display:block;font-family:var(--font-display);font-size:1.08rem;line-height:1.15}.enrollment-brand span{color:var(--gold-400);display:block;font-size:.68rem;font-weight:900;letter-spacing:.12em;margin-top:4px;text-transform:uppercase}.enrollment-welcome{margin-bottom:30px}.enrollment-welcome h1{color:#fff;font-family:var(--font-display);font-size:1.48rem;line-height:1.2;margin:0 0 10px;max-width:280px}.enrollment-welcome p{color:#ffffffb8;font-size:.88rem;line-height:1.45;margin:0;max-width:290px}.enrollment-steps{align-items:stretch;display:flex;gap:10px}.enrollment-step{align-items:center;background:#fff;border:1px solid #dde5ef;border-radius:12px;color:var(--text-secondary);cursor:default;display:flex;gap:10px;min-height:58px;min-width:168px;padding:10px 12px;position:relative;text-align:left;transition:border-color var(--transition-fast),background var(--transition-fast),box-shadow var(--transition-fast)}.enrollment-step:not(:last-child):after{display:none}.enrollment-step.active,.enrollment-step.complete{color:var(--navy-900);cursor:pointer}.enrollment-step.active{background:#fffbeb;border-color:#c49a2a73;box-shadow:0 8px 18px #c49a2a1f}.enrollment-step.complete{background:#2d873e0f;border-color:#2d873e3d}.enrollment-step-icon{align-items:center;background:#f8fafc;border:1px solid #dbe3ef;border-radius:10px;color:var(--navy-600);display:inline-flex;flex:0 0 34px;font-size:1.05rem;height:34px;justify-content:center;position:relative;width:34px;z-index:1}.enrollment-step.active .enrollment-step-icon,.enrollment-step.complete .enrollment-step-icon{background:linear-gradient(135deg,var(--gold-500),#b98512);border-color:#c49a2a4d;color:var(--navy-900)}.enrollment-step small{color:inherit;display:block;font-size:.68rem;font-weight:900;letter-spacing:.08em;opacity:.78;text-transform:uppercase}.enrollment-step strong{color:inherit;display:block;font-size:.86rem;line-height:1.25;margin-top:2px}.enrollment-step em{color:#ffffff85;display:block;font-size:.76rem;font-style:normal;font-weight:700;margin-top:3px}.enrollment-import-card{align-items:center;display:flex;gap:10px}.enrollment-import-card input,.enrollment-import-card p,.enrollment-import-card span{display:none}.enrollment-import-card button{align-items:center;background:var(--navy-900);border:1px solid #dbe3ef;border-radius:9px;color:#fff;cursor:pointer;display:inline-flex;font-weight:800;gap:7px;justify-content:center;margin-top:0;min-height:40px;padding:0 16px;width:auto}.enrollment-import-card button:disabled{cursor:not-allowed;opacity:.62}.enrollment-back-link{align-items:center;background:#fff;border:1px solid #dbe3ef;border-radius:10px;color:var(--text-secondary);cursor:pointer;display:inline-flex;font-size:.86rem;font-weight:800;gap:8px;min-height:42px;padding:0 14px}.enrollment-back-link:hover{background:#f8fafc;border-color:#cbd5e1;color:var(--navy-900)}.enrollment-main{align-items:stretch;display:flex;min-width:0;padding:0;width:100%}.enrollment-card{background:#fff;border:0;display:flex;flex-direction:column;min-height:0;width:100%}.enrollment-header{align-items:center;background:#fff;border-bottom:1px solid #e8edf5;display:flex;justify-content:flex-end;padding:12px 28px}.enrollment-header-copy span{color:var(--gold-500);display:block;font-size:.7rem;font-weight:900;letter-spacing:.12em;margin-bottom:6px;text-transform:uppercase}.enrollment-header-copy h2{color:var(--navy-900);font-family:var(--font-display);font-size:1.28rem;line-height:1.2;margin:0}.enrollment-header-copy p{color:var(--text-secondary);font-size:.84rem;margin:6px 0 0}.enrollment-header-actions{align-items:center;display:flex;flex-wrap:wrap;gap:10px;justify-content:flex-end}.enrollment-content{margin:0 auto;padding:16px 0 18px;width:min(960px,calc(100% - 72px))}.enrollment-step-label{color:var(--gold-500);font-size:.74rem;font-weight:900;letter-spacing:.12em;margin-bottom:12px;text-transform:uppercase}.enrollment-title-row{align-items:center;display:flex;gap:24px;justify-content:space-between;margin-bottom:14px}.enrollment-title-row h2{color:var(--navy-900);font-family:var(--font-display);font-size:1.45rem;line-height:1.15;margin:0}.enrollment-title-row p{color:var(--text-secondary);font-size:.88rem;margin:7px 0 0}.enrollment-title-icon{align-items:center;background:#f8fafc;border-radius:14px;color:var(--navy-600);display:inline-flex;flex:0 0 40px;font-size:1.35rem;height:40px;justify-content:center;width:40px}.enrollment-form-grid{grid-gap:12px 18px;display:grid;gap:12px 18px;grid-template-columns:repeat(2,minmax(0,1fr))}.enrollment-field{display:flex;flex-direction:column;gap:6px;min-width:0}.enrollment-divider.span-2,.enrollment-field.span-2,.enrollment-review.span-2{grid-column:1/-1}.enrollment-field label{color:var(--text-secondary);font-size:.7rem;font-weight:900;letter-spacing:.06em;text-transform:uppercase}.enrollment-field input,.enrollment-field select{background:#fff;border:1px solid #dde3ec;border-radius:10px;color:var(--navy-900);font-size:.88rem;min-height:39px;outline:none;padding:0 14px;transition:border-color var(--transition-fast),box-shadow var(--transition-fast),background var(--transition-fast);width:100%}.enrollment-field input::placeholder{color:#8b95a7}.enrollment-field input:focus,.enrollment-field select:focus{border-color:var(--navy-500);box-shadow:0 0 0 3px #1e3a5f1a}.enrollment-field input.has-error,.enrollment-field select.has-error{background:#d4272e08;border-color:var(--red-500)}.enrollment-error{color:var(--red-500);font-size:.75rem;font-weight:800}.enrollment-divider{align-items:center;border-top:1px solid #edf1f7;color:var(--navy-800);display:flex;font-size:.84rem;font-weight:900;gap:8px;margin-top:8px;min-height:34px;padding-top:14px}.enrollment-review{grid-gap:12px;display:grid;gap:12px;grid-template-columns:repeat(2,minmax(0,1fr))}.enrollment-review-item{background:#f8fafc;border:1px solid #e3e8f0;border-radius:12px;min-height:72px;padding:14px 16px}.enrollment-review-item span{color:var(--text-muted);display:block;font-size:.7rem;font-weight:900;letter-spacing:.05em;margin-bottom:6px;text-transform:uppercase}.enrollment-review-item strong{color:var(--navy-900);display:block;font-size:.92rem;line-height:1.35;overflow-wrap:anywhere}.enrollment-actions{border-top:1px solid #e9edf4;display:flex;gap:16px;justify-content:space-between;margin:0 auto;padding:14px 0 20px;width:min(765px,calc(100% - 96px))}.enrollment-primary-btn,.enrollment-secondary-btn{align-items:center;border-radius:10px;cursor:pointer;display:inline-flex;font-size:.86rem;font-weight:900;gap:9px;justify-content:center;min-height:42px;transition:transform var(--transition-fast),box-shadow var(--transition-fast),background var(--transition-fast),border-color var(--transition-fast)}.enrollment-secondary-btn{background:#fff;border:1px solid #e0e6ef;color:var(--text-secondary);min-width:112px;padding:0 18px}.enrollment-secondary-btn:hover{background:#f8fafc;border-color:#cbd5e1}.enrollment-primary-btn{background:var(--navy-900);border:0;box-shadow:0 12px 24px #0a162833;color:#fff;min-width:138px;padding:0 22px}.enrollment-primary-btn:hover{background:var(--navy-800);transform:translateY(-1px)}.enrollment-primary-btn:disabled,.enrollment-secondary-btn:disabled{cursor:not-allowed;opacity:.62;transform:none}.enrollment-success-overlay{align-items:center;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);background:#0a16289e;display:flex;inset:0;justify-content:center;position:fixed;z-index:120}.enrollment-success-card{background:#fff;border-radius:18px;box-shadow:var(--shadow-xl);padding:38px 42px;text-align:center;width:min(360px,calc(100vw - 32px))}.enrollment-success-icon{align-items:center;background:#2d873e1f;border-radius:50%;color:#2d873e;display:inline-flex;font-size:2rem;height:70px;justify-content:center;margin:0 auto 18px;width:70px}.enrollment-success-card h3{color:var(--navy-900);font-family:var(--font-display);font-size:1.12rem;margin:0 0 8px}.enrollment-success-card p{color:var(--text-secondary);font-size:.9rem;margin:0}@media (max-width:1180px){.enrollment-header{align-items:stretch;grid-template-columns:1fr}.enrollment-steps{display:grid;grid-template-columns:repeat(3,minmax(0,1fr))}.enrollment-step{min-width:0}.enrollment-header-actions{justify-content:flex-end}.enrollment-import-card{width:auto}.enrollment-content{width:min(860px,calc(100% - 56px))}}@media (max-width:860px){.enrollment-steps{grid-template-columns:1fr}.enrollment-header{padding:18px 16px}.enrollment-header-actions,.enrollment-title-row{align-items:stretch;flex-direction:column}.enrollment-title-row{gap:12px}.enrollment-card{min-height:auto}.enrollment-actions,.enrollment-content{width:calc(100% - 32px)}.enrollment-content{padding:16px 0 22px}.enrollment-actions{padding:18px 0 34px}}@media (max-width:620px){.enrollment-form-grid,.enrollment-review{grid-template-columns:1fr}.enrollment-title-row{align-items:center}.enrollment-title-row h2{font-size:1.42rem}.enrollment-title-icon{display:none}.enrollment-actions{flex-direction:column-reverse}.enrollment-step{min-height:54px}.enrollment-step em{display:none}.enrollment-back-link,.enrollment-primary-btn,.enrollment-secondary-btn{justify-content:center;width:100%}}.dashboard-content{margin:0 auto;max-width:1200px;padding:20px}.section-header{flex-wrap:wrap;gap:16px;justify-content:space-between;margin-bottom:30px}.section-header,.section-title{align-items:center;display:flex}.section-title{color:#333;font-size:28px;font-weight:600;gap:12px;margin:0}.accent-line{border-radius:2px;display:inline-block;height:28px;width:4px}.accent-line,.btn-primary{background:linear-gradient(135deg,#007bff,#0056b3)}.btn-primary{align-items:center;border:none;border-radius:6px;color:#fff;cursor:pointer;display:flex;font-size:14px;font-weight:600;gap:8px;padding:10px 20px;transition:all .3s ease;white-space:nowrap}.btn-primary:hover{box-shadow:0 4px 12px #007bff4d;transform:translateY(-2px)}.btn-primary:active{transform:translateY(0)}@media (max-width:768px){.dashboard-content{padding:15px}.section-header{align-items:flex-start;flex-direction:column}.section-title{font-size:22px}.btn-primary{justify-content:center;width:100%}}@media (max-width:480px){.dashboard-content{padding:10px}.section-title{font-size:18px}.btn-primary{font-size:12px;padding:8px 16px}}@media (min-width:861px) and (min-height:720px){body.campus-detail-page-active{overflow-y:hidden}body.campus-detail-page-active .main-content{height:100vh;min-height:100vh;overflow:hidden}}.campus-detail-container{margin:0 auto;padding:14px 0 18px!important;width:min(1180px,calc(100% - 48px))}.campus-detail-container .campus-detail-hero{align-items:stretch;background:#fff;border:1px solid #dfe6f0;border-radius:8px;box-shadow:0 8px 24px #0f1b2d0f;display:flex;gap:18px;justify-content:space-between;padding:18px}.campus-detail-container .campus-hero-main{align-items:flex-start;display:flex;gap:16px;min-width:0}.campus-detail-container .back-button{align-items:center;background:#f8fafc;border:1px solid #dbe3ee;border-radius:8px;color:#334155;cursor:pointer;display:inline-flex;font-size:14px;font-weight:700;gap:8px;min-height:42px;padding:0 16px;transition:background .18s ease,border-color .18s ease,transform .18s ease;white-space:nowrap}.campus-detail-container .back-button:hover{background:#eef5ff;border-color:#b9c9dd;transform:translateX(-2px)}.campus-detail-container .campus-eyebrow{color:#8a6c1f;display:block;font-size:11px;font-weight:800;letter-spacing:.08em;margin-bottom:6px;text-transform:uppercase}.campus-detail-container .detail-title{color:#0f1b2d;font-size:clamp(26px,2.6vw,34px);font-weight:800;line-height:1.12;margin:0}.campus-detail-container .campus-detail-subtitle{color:#64748b;font-size:15px;line-height:1.55;margin:6px 0 0;max-width:620px}.campus-detail-container .campus-hero-stats{grid-gap:10px;display:grid;gap:10px;grid-template-columns:repeat(3,minmax(92px,1fr));min-width:330px}.campus-detail-container .hero-stat{background:#f8fafc;border:1px solid #e4eaf2;border-radius:8px;display:flex;flex-direction:column;gap:4px;justify-content:center;min-height:76px;padding:12px;text-align:center}.campus-detail-container .hero-stat span{color:#10213b;font-size:28px;font-weight:800;line-height:1}.campus-detail-container .hero-stat strong{color:#64748b;font-size:11px;font-weight:800;letter-spacing:.04em;text-transform:uppercase}.campus-detail-container .campus-progress-strip{grid-gap:18px;align-items:center;background:#fff;border:1px solid #e2e8f0;border-radius:8px;display:grid;gap:18px;grid-template-columns:minmax(220px,.8fr) minmax(240px,1.4fr) auto;margin-top:12px;padding:12px 16px}.campus-detail-container .campus-progress-strip strong{color:#0f1b2d;display:block;font-size:15px}.campus-detail-container .campus-progress-strip small{color:#64748b;font-size:12px;font-weight:700;white-space:nowrap}.campus-detail-container .campus-progress-track{background:#edf2f7;border-radius:999px;height:10px;overflow:hidden}.campus-detail-container .campus-progress-track span{background:#2a4a7f;border-radius:inherit;display:block;height:100%;min-width:4px}.campus-detail-container .campus-cards-container{grid-gap:14px!important;display:grid;gap:14px!important;grid-template-columns:repeat(3,minmax(0,1fr));margin-top:12px;padding:0!important}.campus-detail-container .campus-option-card{align-items:stretch!important;background:#fff;border:1px solid #dfe6f0;border-radius:8px!important;border-top:4px solid #2a4a7f;box-shadow:0 8px 24px #0f1b2d0f;cursor:pointer;display:flex;flex-direction:column;gap:14px;min-height:220px!important;padding:18px!important;position:relative;transition:border-color .18s ease,box-shadow .18s ease,transform .18s ease}.campus-detail-container .campus-option-card:hover{border-color:#b8c6d8;box-shadow:0 14px 32px #0f1b2d1f;transform:translateY(-3px)}.campus-detail-container .sessions-card{border-top-color:#0891b2}.campus-detail-container .classes-card{border-top-color:#16a34a}.campus-detail-container .assignments-card{border-top-color:#7c3aed}.campus-detail-container .card-topline{align-items:flex-start;display:flex;gap:16px;justify-content:space-between}.campus-detail-container .card-icon-wrapper{background:#e6f6fb;border-radius:8px;color:#0891b2;display:grid;height:52px!important;place-items:center;width:52px!important}.campus-detail-container .classes-card .card-icon-wrapper{background:#e9f8ef;color:#16a34a}.campus-detail-container .assignments-card .card-icon-wrapper{background:#f0e7ff;color:#7c3aed}.campus-detail-container .card-icon{display:grid;font-size:28px!important;place-items:center}.campus-detail-container .card-icon svg{display:block}.campus-detail-container .card-stats{background:#f8fafc;border:1px solid #e2e8f0;border-radius:8px;min-width:106px;padding:8px 10px!important;text-align:right}.campus-detail-container .stat-count{color:#0f1b2d;display:block;font-size:24px!important;font-weight:800;line-height:1}.campus-detail-container .stat-label{color:#64748b;display:block;font-size:10px;font-weight:800;letter-spacing:.05em;margin-top:6px;text-transform:uppercase}.campus-detail-container .card-info{flex:1 1}.campus-detail-container .card-info h3{color:#0f1b2d;font-size:20px!important;font-weight:800;line-height:1.2;margin:0}.campus-detail-container .card-info p{color:#64748b;font-size:14px;line-height:1.55;margin:7px 0 0}.campus-detail-container .card-button{align-items:center;background:#0f1b2d;border:none;border-radius:8px;color:#fff;cursor:pointer;display:inline-flex;font-size:14px;font-weight:800;gap:8px;justify-content:center;min-height:40px!important;padding:0 16px;transition:background .18s ease,transform .18s ease;width:100%}.campus-detail-container .sessions-card .card-button{background:#0891b2}.campus-detail-container .classes-card .card-button{background:#15803d}.campus-detail-container .assignments-card .card-button{background:#6d28d9}.campus-detail-container .card-button:hover{transform:translateY(-1px)}.campus-detail-container .card-button svg{font-size:18px}@media (max-width:1120px){.campus-detail-hero,.campus-hero-main{flex-direction:column}.campus-hero-stats{min-width:0;width:100%}}@media (max-width:860px){.campus-detail-container{padding-top:18px;width:min(100% - 28px,1180px)}.campus-cards-container,.campus-progress-strip{grid-template-columns:1fr}.campus-progress-strip{gap:10px}}@media (max-width:560px){.campus-detail-hero{padding:18px}.campus-hero-stats{grid-template-columns:1fr}.campus-option-card{min-height:auto}.card-topline{flex-direction:column}.card-stats{text-align:left;width:100%}}
/*# sourceMappingURL=main.8613ce25.css.map*/