:root{font-family:system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:light dark;color:#ffffffde;background-color:#242424;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{font-weight:500;color:#646cff;text-decoration:inherit}a:hover{color:#535bf2}body{margin:0;display:flex;place-items:center;min-width:320px;min-height:100vh}#root{width:100%;min-height:100vh}h1{font-size:3.2em;line-height:1.1}button{border-radius:8px;border:1px solid transparent;padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;background-color:#1a1a1a;cursor:pointer;transition:border-color .25s}button:hover{border-color:#646cff}button:focus,button:focus-visible{outline:4px auto -webkit-focus-ring-color}@media(prefers-color-scheme:light){:root{color:#213547;background-color:#fff}a:hover{color:#747bff}button{background-color:#f9f9f9}}body.gradient-bg{background:linear-gradient(270deg,#667eea,#764ba2,#f093fb,#f5576c,#4facfe,#00f2fe);background-size:400% 400%;animation:globalGradient 8s ease infinite}@keyframes globalGradient{0%{background-position:0% 50%}50%{background-position:100% 50%}to{background-position:0% 50%}}body.gradient-bg .homeView{background-color:#ffffffe0!important}body.gradient-bg .availability-container{background-color:#ffffffeb!important}body.gradient-bg .sidebar{background-color:#fffffff2!important}body.gradient-bg .pageContainer{background:transparent}.labView{display:flex;flex-direction:column;min-height:100vh;width:100%;background-color:#fff;overflow-x:hidden}.labs-container{flex:1;overflow:hidden;padding:40px 0;margin-left:5vw}.labs-content{width:90%;max-width:1000px;display:flex;flex-direction:column;min-height:0}.labs-scroll{max-height:calc(100vh - 190px);overflow-y:auto;padding-right:6px}.labs-scroll::-webkit-scrollbar{width:6px}.labs-scroll::-webkit-scrollbar-thumb{background:#0003;border-radius:999px}.labs-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:30px}.highlights-btn{background-color:#fff;color:#333;border:1px solid #efefef;border-radius:20px;padding:8px 16px;cursor:pointer}.lab-card{display:flex;gap:24px;border:1px solid #efefef;border-radius:20px;padding:24px;margin-bottom:24px;background:#fff}.lab-image{width:140px;height:120px;border-radius:12px;object-fit:cover}.lab-card-info{flex:1;position:relative;display:flex;flex-direction:column}.tags-wrapper{position:absolute;top:0;right:0;display:flex;gap:8px}.tag{font-size:11px;font-weight:600;padding:4px 12px;border-radius:20px}.tag-instr{background:#fff5eb;color:#fd7e14}.tag-tech{background:#e7f5ff;color:#228be6}.lab-title{font-size:20px;margin:0 0 12px;color:#1a1a1a}.lab-meta{color:#888;font-size:14px;margin-bottom:20px}.meta-item{display:flex;align-items:center;gap:8px;margin-bottom:4px}.lab-footer{display:flex;align-items:center;gap:16px;margin-top:auto}.price{font-weight:700;color:#2d8cf0}.progress-bg{flex:1;height:8px;background:#eee;border-radius:4px;overflow:hidden}.progress-fill{height:100%;background:#000;transition:width .3s}.reg-btn{background:#2d8cf0;color:#fff;border:none;padding:10px 24px;border-radius:10px;cursor:pointer}.reg-btn:disabled{background:#e0e0e0;cursor:not-allowed}.lab-footer{display:flex;align-items:center;gap:15px;margin-top:auto}.progress-track{flex:1;height:8px;background:#eee;border-radius:10px;overflow:hidden}.percent-text{font-size:12px;color:#888;min-width:35px;font-weight:500;text-align:right}.labs-status{font-size:14px;color:#888;padding:20px 0}.labs-status--error{color:#e03131}.welcome-container{display:flex;flex-direction:column;font-family:Inter,Arial,sans-serif;min-width:0}.welcome-title{margin:0;margin-top:3.3vh;font-size:30px;font-family:Inter,sans-serif;font-weight:500;color:#111827;white-space:nowrap}.welcome-subtitle{margin:0;margin-top:.6vh;color:#9ca3af;font-size:18px;font-family:Inter,sans-serif;font-weight:400}.ad-banner{display:flex;flex-direction:row;align-items:stretch;margin-top:4vh;width:100%;min-width:0;border-radius:16px;background:#f5f6f7;box-shadow:0 2px 12px #00000012;overflow:hidden;min-height:110px}.ad-banner-left{flex:1 1 auto;min-width:0;display:flex;flex-direction:column;justify-content:center;gap:6px;padding:24px 28px}.ad-banner-tag{font-size:11px;font-weight:700;letter-spacing:.08em;color:#9ca3af;text-transform:uppercase}.ad-banner-heading{margin:0;font-size:18px;font-weight:700;color:#111827;line-height:1.3}.ad-banner-sub{margin:0;font-size:13px;color:#9ca3af;line-height:1.5}.ad-banner-right{position:relative;flex:0 0 160px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;padding:20px 16px;background:#1a2535;overflow:hidden}.ad-banner-right:before{content:"";position:absolute;inset:0;background:repeating-linear-gradient(-45deg,transparent,transparent 7px,rgba(255,255,255,.04) 7px,rgba(255,255,255,.04) 14px);pointer-events:none}.ad-banner-pts{position:relative;font-size:52px;font-weight:800;color:#fff;line-height:1;letter-spacing:-2px}.ad-banner-pts-label{position:relative;font-size:12px;color:#6b7280;font-weight:500;margin-bottom:8px}.ad-banner-btn{position:relative;padding:7px 18px;border-radius:8px;border:1.5px solid rgba(255,255,255,.9);background:#fff;color:#1a2535;font-size:13px;font-weight:600;font-family:Inter,sans-serif;cursor:pointer;transition:background .2s,color .2s;white-space:nowrap}.ad-banner-btn:hover{background:transparent;color:#fff;border-color:#fff}.homeView{display:flex;flex-direction:row;width:100%;min-height:100%;background-color:#fff;padding-right:29px;box-sizing:border-box}.homeLeftPanel{flex:1 1 auto;min-width:0;min-width:280px;margin-top:.3vh;margin-left:5vw;overflow:hidden}.stats{display:flex;width:100%;min-width:0;margin-top:1.3vh;margin-bottom:2.7vh}.homeRightPanel{flex:0 0 auto;flex-shrink:0;display:flex;flex-direction:column;gap:16px;padding-top:37px;padding-bottom:40px;margin-left:29px}.homeSearchWrapper{width:clamp(400px,28vw,440px)}.homeSearchInput{width:100%;padding:12px 18px;border:1.5px solid #E2E8F0;border-radius:12px;font-size:14px;font-family:Inter,sans-serif;color:#1e293b;background:#f8fafc;outline:none;transition:border-color .2s,box-shadow .2s;box-sizing:border-box}.homeSearchInput:focus{border-color:#94a3b8;box-shadow:0 0 0 3px #94a3b826;background:#fff}.homeSearchInput::placeholder{color:#cbd5e1}.availability-container{display:flex;flex-direction:column;width:clamp(400px,28vw,440px);padding:24px;gap:19px;background-color:#fff;font-family:Inter,sans-serif;box-shadow:0 4px 20px #0000000d;border-radius:16px}.calendar-header{display:flex;align-items:center;justify-content:space-between;width:100%;margin-bottom:19px}.arrow-button{display:flex;align-items:center;justify-content:center;background:#f1f5f9;width:36px;height:36px;border-radius:50%;cursor:pointer}.days-wrapper{display:flex;flex-direction:row;gap:8px;overflow-x:auto}.day-item{display:flex;flex-direction:column;align-items:center;text-align:center;cursor:pointer;padding:19px 0;border-radius:18px;transition:.3s;background-color:#f5f5f5;min-width:55px;flex-shrink:0}.day-item.active{background-color:#ff6b6b}.lab-section{display:flex;flex-direction:column}.lab-title{font-size:19px;color:#1e293b;margin-bottom:10px;margin-left:1vw}.lab-list{display:flex;flex-direction:column;gap:12px;width:100%;padding:12px}.av-empty-state{padding:20px;color:#94a3b8;text-align:center;font-size:14px;font-family:Inter,sans-serif}.progress-container{width:100%;height:8px;background:#0000000d;border-radius:10px;overflow:hidden}.container{width:100%;height:clamp(68px,7.5vh,85px)}.HStack{display:flex;flex-direction:row;justify-content:space-between;padding:16px;width:100%;gap:12px;flex-shrink:0}.iconCover{display:flex;width:40px;height:40px;border-radius:20px;align-items:center;justify-content:center;flex-shrink:0}.VStack{display:flex;flex-direction:column;width:100%;gap:5px}.innerHStack{display:flex;flex-direction:row;justify-content:space-between}.ProgressBar{width:100%;height:8px;background:#0000000d;border-radius:10px;overflow:hidden}.progress-bar{height:100%;border-radius:10px;transition:width 1s cubic-bezier(.1,.5,.3,1)}.stats-section{display:flex;flex-direction:row;gap:16px;width:100%;min-width:0}.stats-card{display:flex;flex-direction:column;flex:1 1 0;min-width:0;background:#fff;border-radius:8px;box-shadow:0 2px 10px #0000000f;position:relative;overflow:hidden}.stats-header{display:flex;justify-content:space-between;padding:16px 14px 0 16px;align-items:center}.stats-header span{font-size:13px;font-weight:500;font-family:Inter,sans-serif;color:#6b7280;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.stats-card h2{margin-top:10px;padding:0 16px 16px;font-size:28px;font-weight:600;color:#111827}.buttonEllipsis{background-color:transparent;border:none;flex-shrink:0}.student-checkin-page{display:flex;gap:2vw;width:100%;min-height:100vh;box-sizing:border-box;padding:3vh 2vw;background:#f8fafc}.student-checkin-left{width:30vw;min-width:320px}.student-checkin-right{flex:1;min-width:0}.student-checkin-header{margin-bottom:3vh}.student-checkin-header h1{margin:0;font-size:2vw;font-weight:700;color:#0f172a}.student-checkin-header p{margin-top:.7vh;font-size:.95vw;color:#94a3b8}.student-checkin-form-card{background:#fff;border:1px solid #e2e8f0;border-radius:1.2vw;padding:2.2vh 1.4vw;box-sizing:border-box}.form-title{font-size:1vw;font-weight:700;color:#0f172a;margin-bottom:.5vh}.form-subtitle{font-size:.8vw;color:#94a3b8;margin-bottom:2vh}.input-label{display:block;font-size:.9vw;font-weight:600;color:#475569;margin-bottom:.8vh}.labs-label{margin-top:2vh}.cyber-input{width:100%;padding:1.2vh .9vw;background:#fff;border:1.5px solid #e2e8f0;border-radius:.8vw;color:#1e293b;font-size:.9vw;outline:none;box-sizing:border-box}.cyber-input:focus{border-color:#3b82f6}.cyber-scroll-box{max-height:28vh;overflow-y:auto;padding-right:.2vw;margin-bottom:1vh}.cyber-scroll-box::-webkit-scrollbar{width:.3vw}.cyber-scroll-box::-webkit-scrollbar-thumb{background:#e2e8f0;border-radius:999px}.lab-card-button{width:100%;border:none;background:transparent;padding:0;margin:0 0 .6vh;cursor:pointer;text-align:left;border-radius:1vw;transition:all .15s ease}.lab-card-button:hover{filter:brightness(.98)}.lab-card-button:active{transform:scale(.99);filter:brightness(.95)}.selected-lab{outline:.15vw solid #3b82f6;outline-offset:.1vw}.lab-card{display:flex;align-items:center;gap:.6vw;padding:.9vh .7vw;border-radius:1vw}.lab-card.blue{background:#f0f7ff}.lab-card.pink{background:#fff1f2}.lab-card.purple{background:#f5f3ff}.lab-card.green{background:#f0fdf4}.lab-icon{background:#fff;padding:.8vh .6vw;border-radius:.6vw;display:flex;align-items:center;justify-content:center}.lab-content{flex:1}.lab-row{display:flex;justify-content:space-between;font-size:.85vw;font-weight:700;margin-bottom:.35vh;color:#0f172a}.progress-bg{width:100%;height:.7vh;background:#e2e8f0;border-radius:999px}.progress-bar{height:100%;border-radius:999px}.blue-text{color:#3b82f6}.pink-text{color:#e11d48}.purple-text{color:#6366f1}.green-text{color:#22c55e}.blue-bar{background:#3b82f6}.pink-bar{background:#e11d48}.purple-bar{background:#6366f1}.green-bar{background:#22c55e}.checkin-button,.checkout-button{width:100%;padding:1.5vh 0;border:none;border-radius:.8vw;font-size:.95vw;font-weight:700;cursor:pointer;transition:all .15s ease;color:#fff}.checkin-button{background:#6ee7b7}.checkout-button{margin-top:2vh;background:#e11d48}.checkin-button:hover:not(:disabled){filter:brightness(.92)}.checkout-button:hover:not(:disabled){filter:brightness(.92)}.checkin-button:active:not(:disabled){transform:scale(.98);filter:brightness(.82)}.checkout-button:active:not(:disabled){transform:scale(.98);filter:brightness(.82)}.checkin-button:disabled,.checkout-button:disabled{opacity:.45;cursor:not-allowed}.tab-wrapper{display:flex;width:100%;background:#eef2f7;border-radius:999px;padding:.25vw;margin-bottom:2vh;box-sizing:border-box}.tab-button{flex:1;border:none;border-radius:999px;padding:1.2vh 0;cursor:pointer;background:transparent;color:#64748b;font-weight:600;font-size:.95vw}.active-tab{background:#fff;color:#0f172a;box-shadow:0 1px 4px #00000014}.student-card{background:#fff;border:1px solid #e2e8f0;border-radius:1.2vw;padding:2vh 1.5vw;min-height:30vh;box-sizing:border-box}.history-list{display:flex;flex-direction:column;gap:1vh}.history-card{min-height:auto}.student-card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.6vh}.student-name{font-size:1.5vw;font-weight:500;color:#0f172a}.status-badge{background:#22c55e;color:#fff;padding:.5vh .8vw;border-radius:999px;font-size:.75vw;font-weight:700}.history-badge{background:#94a3b8;color:#fff;padding:.5vh .8vw;border-radius:999px;font-size:.75vw;font-weight:700}.student-info{font-size:.95vw;color:#475569;margin-bottom:1vh}.history-empty-card{background:#fff;border:1px solid #e2e8f0;border-radius:1.2vw;min-height:30vh;display:flex;flex-direction:column;align-items:center;justify-content:center;color:#94a3b8}.history-empty-title{font-size:1.3vw;font-weight:700;color:#334155;margin-bottom:1vh}.history-empty-text{font-size:.9vw}.student-stats-row{display:flex;gap:1vw;margin-top:2vh}.student-stat-card{flex:1;background:#fff;border:1px solid #e2e8f0;border-radius:1.2vw;padding:1.8vh 1.2vw;box-sizing:border-box}.student-stat-number{font-size:2vw;font-weight:700;margin-bottom:.8vh}.student-stat-label{font-size:.95vw;color:#475569;font-weight:500}.green-number{color:#22c55e}.blue-number{color:#3b82f6}*{margin:0;padding:0;box-sizing:border-box}body{background:#f8f9fa;font-family:Inter,sans-serif}.page-wrapper{padding:40px 2.5%;min-height:100vh}.main-layout{display:flex;gap:28px;align-items:flex-start}.left-panel{width:250px;flex-shrink:0}.main-heading{font-size:32px;font-weight:850;line-height:1;margin-bottom:40px;color:#000;letter-spacing:-1px}.sidebar-card{background:#fff;padding:24px;border-radius:24px;box-shadow:0 10px 40px #00000008;border:1px solid #f0f0f0}.section-label{font-size:13px;font-weight:700;margin-bottom:16px;color:#333}.status-label{margin-top:24px}.nav-item{width:100%;padding:12px 16px;margin-bottom:8px;border-radius:12px;border:1px solid #f0f0f0;background:#fff;text-align:left;cursor:pointer;font-size:14px;color:#444;transition:all .2s ease}.nav-item.active,.nav-item:hover{background:#2d9cdb!important;color:#fff!important;border-color:#2d9cdb!important;font-weight:500}.right-panel{flex:1;padding-top:5px;min-width:0}.products-scroll{max-height:calc(100vh - 220px);overflow-y:auto;padding-right:4px;padding-bottom:20px}.products-scroll::-webkit-scrollbar{width:6px}.products-scroll::-webkit-scrollbar-thumb{background:#00000026;border-radius:999px}.top-tabs{display:flex;gap:12px;margin-bottom:24px}.top-tab-button{padding:8px 18px;border-radius:999px;border:1px solid #e0e0e0;background:#fff;cursor:pointer;font-size:14px;color:#444;transition:all .2s ease}.top-tab-button.active,.top-tab-button:hover{background:#2d9cdb;color:#fff;border-color:#2d9cdb}.current-category-name{font-size:32px;font-weight:700;margin-bottom:15px;color:#000;white-space:nowrap}.header-divider{border:0;border-top:1px solid #eaeaea;margin-bottom:40px;width:100%}.products-container{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:20px}@media(max-width:1280px){.products-container{grid-template-columns:repeat(auto-fit,minmax(210px,1fr))}}@media(max-width:960px){.products-container{grid-template-columns:repeat(2,minmax(0,1fr))}}@media(max-width:640px){.products-container{grid-template-columns:1fr}}.equipment-card{background:#fff;border-radius:16px;padding:18px 18px 16px;box-shadow:0 10px 30px #00000008;border:1px solid #f0f0f0;display:flex;flex-direction:column;gap:8px;min-height:260px}.equipment-title-row{display:flex;justify-content:space-between;align-items:center;gap:12px;margin-top:8px}.equipment-image-wrapper{width:100%;height:120px;border-radius:14px;background:#f7f8fb;display:flex;align-items:center;justify-content:center;overflow:hidden}.equipment-image{max-width:80%;max-height:80%;object-fit:contain}.equipment-name{font-size:16px;font-weight:600;color:#111}.equipment-code{font-size:12px;font-weight:500;color:#888}.equipment-category{font-size:13px;color:#666}.equipment-footer{margin-top:auto;padding-top:12px;display:flex;flex-direction:row;align-items:center;justify-content:space-between;gap:12px;min-height:40px}.equipment-status{font-size:13px;line-height:1;height:40px;display:inline-flex;align-items:center}.equipment-status--available{color:#27ae60}.equipment-checkout-button{flex-shrink:0;height:40px;padding:0 16px;border-radius:999px;border:none;background:#111;color:#fff;font-size:13px;font-family:inherit;line-height:1;display:inline-flex;align-items:center;justify-content:center;cursor:pointer;transition:background .2s ease;box-sizing:border-box}.equipment-checkout-button:hover{background:#000}.equipment-card--bag .equipment-remove-button{margin-top:auto;padding:8px 14px;border-radius:10px;border:1px solid #e74c3c;background:#fff;color:#e74c3c;font-size:13px;cursor:pointer;transition:background .2s ease,color .2s ease}.equipment-card--bag .equipment-remove-button:hover{background:#e74c3c;color:#fff}.products-container.bag-grid{grid-template-columns:repeat(auto-fit,minmax(220px,1fr))}.empty-msg{color:#999;font-size:14px}ec-full-wrapper{background-color:"transparent";min-height:100vh;width:100vw;margin:0;padding:40px;display:flex;justify-content:center;align-items:flex-start;box-sizing:border-box;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica,Arial,sans-serif}.ec-main-container{display:flex;background-color:#fff;width:100%;max-width:none;padding:50px;gap:60px;border-radius:4px}.ec-left-panel{flex:2.5}.ec-main-heading{font-size:32px;font-weight:600;margin:0 0 40px;color:#1a1a1a}.ec-header-flex{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}.ec-sub-heading{font-size:22px;font-weight:600;margin:0 0 40px;color:#1a1a1a}.ec-link-continue{font-size:14px;font-weight:600;color:#1a1a1a;text-decoration:underline;cursor:pointer}.ec-table{width:100%;border-collapse:collapse}.ec-table th{text-align:left;padding:15px 10px;border-bottom:1px solid #d1d5db;border-top:1px solid #d1d5db;font-size:13px;font-weight:600;color:#1a1a1a}.ec-clear-btn{color:#ff6b6b!important;font-style:italic;cursor:pointer;text-align:right!important}.ec-table-row td{padding:25px 10px;border-bottom:1px solid #f9fafb}.ec-product-info{display:flex;align-items:center;gap:20px}.ec-product-image{width:65px;height:55px;object-fit:cover;border-radius:8px;border:1px solid #eee}.ec-prod-name{font-weight:700;font-size:15px;margin:0 0 5px;color:#1a1a1a}.ec-prod-owner{font-size:12px;color:#6b7280;margin:0}.ec-qty-controls{display:flex;justify-content:center;align-items:center;gap:15px}.ec-qty-circle{width:30px;height:30px;border-radius:50%;border:none;background-color:#f3f4f6;font-size:16px;color:#4b5563;cursor:pointer;display:flex;justify-content:center;align-items:center;transition:.2s}.ec-qty-circle:hover{background-color:#e5e7eb}.ec-qty-num{font-weight:600;font-size:15px}.ec-remove-icon{background:none;border:none;font-size:22px;color:#9ca3af;cursor:pointer;transition:color .2s}.ec-remove-icon:hover{color:#ef4444}.ec-totals-area{margin-top:20px;width:100%;display:flex;flex-direction:column;align-items:flex-end;border-top:1px solid #e5e7eb;border-bottom:1px solid #e5e7eb;padding:20px 0}.ec-totals-row{display:flex;justify-content:space-between;width:200px;padding:8px 10px;font-size:14px}.ec-totals-label{color:#1a1a1a;font-weight:500}.ec-promo-label{color:#e74c3c}.ec-promo-discount{color:#e74c3c;font-weight:700}.ec-totals-total{border-top:1px solid #e5e7eb;margin-top:4px}.ec-total-value{color:#2ecc71}.ec-right-panel{flex:1;min-width:350px;background-color:#fff;border-radius:8px;padding:40px;box-shadow:0 4px 24px #0000000f;display:flex;flex-direction:column;gap:30px}.ec-fines-box{margin-bottom:10px}.ec-fine-title{font-weight:600;font-size:15px;color:#1a1a1a;margin-bottom:20px;position:relative}.ec-fine-title:after{content:"";position:absolute;left:0;bottom:-10px;width:20px;height:3px;background-color:#f39c12;border-radius:2px}.ec-fine-list{display:flex;flex-direction:column}.ec-fine-item{display:flex;justify-content:space-between;padding:12px 15px;font-size:13px;color:#4b5563;cursor:pointer;border-radius:4px;transition:all .2s ease}.ec-fine-item:hover{background-color:#f9fafb}.ec-highlight{background-color:#eef8fc!important;font-weight:600;color:#1a1a1a}.ec-label{display:block;font-size:13px;font-weight:600;color:#1a1a1a;margin-bottom:8px}.ec-input-flex{display:flex;gap:15px;margin-bottom:20px}.ec-input{width:100%;padding:12px 15px;background-color:#f9fafb;border:1px solid #f3f4f6;border-radius:6px;font-size:13px;color:#4b5563;outline:none;transition:.2s;font-family:inherit}.ec-input:focus{border-color:#cbd5e1}.ec-promo-input{margin-bottom:20px}.ec-promo-valid{border-color:#e74c3c!important;box-shadow:0 0 0 2px #e74c3c33}.ec-promo-badge{margin-left:8px;background:#e74c3c;color:#fff;font-size:11px;font-weight:700;padding:2px 7px;border-radius:10px;vertical-align:middle}.ec-promo-row{display:flex;gap:10px;align-items:center}.ec-promo-row .ec-promo-input{flex:1;margin-bottom:0}.ec-promo-apply-btn{flex-shrink:0;height:44px;padding:0 18px;border:none;border-radius:6px;background-color:#1a1a1a;color:#fff;font-size:13px;font-weight:600;cursor:pointer;transition:background .2s;font-family:inherit}.ec-promo-apply-btn:hover:not(:disabled){background-color:#333}.ec-promo-apply-btn:disabled{background-color:#2ecc71;cursor:default}.ec-buttons-box{display:flex;flex-direction:column;gap:15px}.ec-btn{width:100%;padding:16px;border:none;border-radius:6px;font-weight:600;font-size:15px;color:#fff;cursor:pointer;transition:all .3s ease}.ec-btn-red{background-color:#ff6b6b}.ec-btn-red:hover{background-color:#ff4757;transform:translateY(-2px)}.ec-btn-green{background-color:#2ecc71}.ec-btn-green:hover{background-color:#27ae60;transform:translateY(-2px)}.text-center{text-align:center}.text-right{text-align:right}.font-bold{font-weight:700;color:#1a1a1a}.text-red{color:#e74c3c}.text-green{color:#2ecc71}.appContainer{display:flex;height:100vh;width:100vw;overflow:hidden;background-color:transparent}.pageContainer{flex:1;overflow:auto}.sidebar{width:64px;height:100vh;background-color:#fff;border-right:1.5px solid #EAECF0;display:flex;flex-direction:column;overflow:hidden;flex-shrink:0;transition:width .35s cubic-bezier(.4,0,.2,1);z-index:2}.sidebar.expanded{width:260px}.sidebarHeader{display:flex;flex-direction:row;align-items:center;height:72px;flex-shrink:0;white-space:nowrap}.sidebarToggle{width:64px;flex-shrink:0;display:flex;align-items:center;justify-content:center;cursor:pointer}.sidebarToggleBtn{width:36px;height:36px;border-radius:50%;background:linear-gradient(135deg,#0ba5ec,#0369a1);display:flex;align-items:center;justify-content:center;box-shadow:0 2px 10px #0ba5ec73;transition:transform .2s ease,box-shadow .2s ease}.sidebarToggle:hover .sidebarToggleBtn{transform:scale(1.1);box-shadow:0 4px 16px #0ba5ec99}.toggleIcon{color:#fff;width:18px;height:18px;transition:transform .35s cubic-bezier(.4,0,.2,1)}.toggleIcon.rotated{transform:rotate(180deg)}.sidebarBrand{display:flex;flex-direction:row;align-items:center;gap:6px;opacity:0;transition:opacity .1s ease}.sidebar.expanded .sidebarBrand{opacity:1;transition:opacity .2s ease .2s}.brandLogo{width:36px;height:36px;border-radius:50%;overflow:hidden;flex-shrink:0}.brandLogo img{width:100%;height:100%;object-fit:cover}.uniName{color:#0ba5ec;font-family:Inter,sans-serif;font-size:20px;font-weight:700;margin:0;white-space:nowrap}.webName{color:#344054;font-family:Inter,sans-serif;font-size:20px;font-weight:700;margin:0;white-space:nowrap}.sidebarNav{display:flex;flex-direction:column;gap:2px;flex:1;padding:8px 0}.sidebarIndependent{display:flex;flex-direction:column;gap:2px;padding:8px 0}.navItem{display:flex;flex-direction:row;align-items:center;height:42px;cursor:pointer;border-radius:8px;margin:0 8px;color:#667085;white-space:nowrap;transition:background .18s ease;flex-shrink:0}.navItem:hover:not(.active){background:#f0f9ff}.navItem.active{background:#0ba5ec;color:#fff}.navIconWrap{width:48px;flex-shrink:0;display:flex;align-items:center;justify-content:center}.navIcon{width:22px;height:22px;color:inherit}.navLabel{font-family:Inter,sans-serif;font-size:15px;font-weight:500;color:inherit;opacity:0;transition:opacity .1s ease}.sidebar.expanded .navLabel{opacity:1;transition:opacity .2s ease .2s}.sidebarBottom{flex-shrink:0}.profileSection{display:flex;flex-direction:row;align-items:center;border-top:1px solid #EAECF0;height:65px;white-space:nowrap;flex-shrink:0}.profileAvatar{width:38px;height:38px;border-radius:50%;object-fit:cover}.profileContent{display:flex;flex-direction:row;align-items:center;flex:1;gap:8px;padding-right:12px;min-width:0;opacity:0;transition:opacity .1s ease}.sidebar.expanded .profileContent{opacity:1;transition:opacity .2s ease .2s}.profileInfo{flex:1;display:flex;flex-direction:column;min-width:0}.profileName{margin:0;font-family:Inter,sans-serif;font-size:14px;font-weight:500;color:#344054;overflow:hidden;text-overflow:ellipsis}.profileEmail{margin:0;font-family:Inter,sans-serif;font-size:12px;color:#667085;overflow:hidden;text-overflow:ellipsis}.logoutBtn{cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0;color:#667085}.logoutIcon{width:20px;height:20px;color:inherit}.pv-page{display:flex;justify-content:center;align-items:flex-start;min-height:100%;padding:40px 24px 60px;background:#fff;box-sizing:border-box;font-family:Inter,system-ui,sans-serif}.pv-card{width:100%;max-width:680px;border-radius:20px;overflow:hidden;background:#161b2e;box-shadow:0 24px 60px #00000080}.pv-header{display:flex;align-items:center;justify-content:space-between;padding:32px 32px 28px;background:linear-gradient(135deg,#38bdf8,#3b82f6,#6366f1)}.pv-header-title{margin:0;font-size:26px;font-weight:700;color:#fff;letter-spacing:-.3px}.pv-header-sub{margin:6px 0 0;font-size:14px;color:#fffc;font-weight:400}.pv-edit-btn{display:flex;align-items:center;gap:8px;padding:10px 20px;border-radius:12px;border:none;background:#ffffff2e;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);color:#fff;font-size:14px;font-weight:600;font-family:inherit;cursor:pointer;transition:background .2s;white-space:nowrap}.pv-edit-btn:hover{background:#ffffff47;border-color:transparent}.pv-edit-icon{font-size:15px}.pv-body{padding:32px;display:flex;flex-direction:column;gap:24px}.pv-identity{display:flex;align-items:center;gap:20px}.pv-avatar{width:80px;height:80px;border-radius:50%;background:linear-gradient(135deg,#38bdf8,#6366f1);display:flex;align-items:center;justify-content:center;flex-shrink:0}.pv-avatar-icon{width:46px;height:46px}.pv-identity-info{display:flex;flex-direction:column;gap:6px}.pv-name-row{display:flex;align-items:center;gap:10px}.pv-full-name{font-size:22px;font-weight:700;color:#f1f5f9}.pv-badge{padding:3px 12px;border-radius:999px;background:#8b5cf6;color:#fff;font-size:12px;font-weight:600}.pv-student-id-label{font-size:14px;color:#64748b}.pv-divider{height:1px;background:#ffffff12}.pv-fields{display:flex;flex-direction:column;gap:20px}.pv-field-row{display:flex;gap:16px}.pv-field-row .pv-field-group{flex:1}.pv-field-group{display:flex;flex-direction:column;gap:8px}.pv-label{font-size:13px;font-weight:500;color:#94a3b8}.pv-input{width:100%;padding:14px 16px;background:#1e2740;border:1.5px solid transparent;border-radius:12px;font-size:15px;font-family:inherit;color:#f1f5f9;outline:none;box-sizing:border-box;transition:border-color .2s,background .2s}.pv-input:not([readonly]):focus{border-color:#3b82f6;background:#1e2d4a}.pv-input[readonly]{cursor:default;color:#cbd5e1}.pv-rating-card{background:#1e2740;border-radius:12px;padding:20px;display:flex;flex-direction:column;gap:14px}.pv-rating-top{display:flex;align-items:center;justify-content:space-between}.pv-rating-title{font-size:16px;font-weight:700;color:#f1f5f9}.pv-rating-score{display:flex;align-items:baseline;gap:4px}.pv-star{font-size:22px;color:#f59e0b}.pv-rating-value{font-size:22px;font-weight:700;color:#f1f5f9}.pv-rating-max{font-size:15px;color:#64748b}.pv-progress-track{width:100%;height:10px;border-radius:999px;background:#2d3a55;overflow:hidden}.pv-progress-fill{height:100%;border-radius:999px;background:linear-gradient(90deg,#f59e0b,#fbbf24);transition:width .9s cubic-bezier(.1,.5,.3,1)}.pv-cancel-btn{align-self:flex-start;padding:8px 20px;border-radius:10px;border:1.5px solid rgba(255,255,255,.12);background:transparent;color:#94a3b8;font-size:13px;font-weight:500;font-family:inherit;cursor:pointer;transition:border-color .2s,color .2s}.pv-cancel-btn:hover{border-color:#ffffff40;color:#e2e8f0}.settings-page{position:relative;min-height:100vh;width:100vw;background:#0f0f1a;display:flex;justify-content:center;align-items:flex-start;padding:60px 24px 80px;overflow:hidden;font-family:Inter,system-ui,sans-serif}.settings-glow-top{position:absolute;top:-120px;left:50%;transform:translate(-50%);width:600px;height:600px;border-radius:50%;background:radial-gradient(circle,rgba(102,126,234,.25) 0%,transparent 70%);pointer-events:none}.settings-glow-bottom{position:absolute;bottom:-200px;right:-100px;width:500px;height:500px;border-radius:50%;background:radial-gradient(circle,rgba(240,147,251,.18) 0%,transparent 70%);pointer-events:none}.settings-content{position:relative;z-index:1;width:100%;max-width:620px;display:flex;flex-direction:column;gap:24px}.settings-header{display:flex;align-items:center;gap:16px;margin-bottom:8px}.settings-logo{font-size:36px;line-height:1;filter:drop-shadow(0 0 12px rgba(102,126,234,.7))}.settings-title{margin:0;font-size:32px;font-weight:700;color:#fff;letter-spacing:-.5px}.settings-subtitle{margin:4px 0 0;font-size:14px;color:#6b7280}.settings-card{background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:20px;padding:28px;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px)}.settings-card-header{display:flex;align-items:center;gap:16px;margin-bottom:20px}.settings-card-icon{font-size:28px;width:52px;height:52px;border-radius:14px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.appearance-icon{background:linear-gradient(135deg,#667eea40,#f093fb40)}.notif-icon{background:linear-gradient(135deg,#fbbf2440,#f5656540)}.about-icon{background:linear-gradient(135deg,#10b98140,#3b82f640)}.settings-card-title{margin:0;font-size:18px;font-weight:600;color:#f1f5f9}.settings-card-desc{margin:4px 0 0;font-size:13px;color:#6b7280}.settings-divider{height:1px;background:#ffffff12;margin:16px 0}.settings-row{display:flex;align-items:center;justify-content:space-between;gap:16px}.settings-row-text{display:flex;flex-direction:column;gap:3px}.settings-row-label{font-size:15px;font-weight:500;color:#e2e8f0}.settings-row-hint{font-size:12px;color:#6b7280}.settings-toggle{position:relative;width:52px;height:28px;border-radius:14px;border:none;cursor:pointer;flex-shrink:0;transition:background .3s ease;padding:0}.settings-toggle.on{background:linear-gradient(135deg,#667eea,#764ba2)}.settings-toggle.off{background:#ffffff1f}.settings-toggle:disabled{opacity:.4;cursor:not-allowed}.settings-toggle-knob{position:absolute;top:3px;width:22px;height:22px;border-radius:50%;background:#fff;box-shadow:0 2px 6px #0000004d;transition:left .3s cubic-bezier(.4,0,.2,1)}.settings-toggle.on .settings-toggle-knob{left:27px}.settings-toggle.off .settings-toggle-knob{left:3px}.settings-preview-bar{margin:4px 0 8px}.settings-preview-label{font-size:12px;color:#6b7280;margin-bottom:8px;display:block}.settings-gradient-preview{height:10px;border-radius:10px;background:linear-gradient(270deg,#667eea,#764ba2,#f093fb,#f5576c,#4facfe,#00f2fe);background-size:400% 400%;animation:previewShift 4s ease infinite}@keyframes previewShift{0%{background-position:0% 50%}50%{background-position:100% 50%}to{background-position:0% 50%}}.settings-field-group{display:flex;flex-direction:column;gap:8px}.settings-field-label{font-size:14px;font-weight:600;color:#e2e8f0}.settings-field-hint{font-size:12px;color:#6b7280;margin:0}.settings-input-row{display:flex;gap:12px;align-items:stretch}.settings-input{flex:1;padding:12px 16px;background:#ffffff12;border:1px solid rgba(255,255,255,.12);border-radius:10px;font-size:14px;font-family:inherit;color:#f1f5f9;outline:none;transition:border-color .2s,background .2s}.settings-input:focus{border-color:#667eeab3;background:#667eea14}.settings-input::placeholder{color:#4b5563}.settings-apply-btn{padding:0 22px;border:none;border-radius:10px;font-size:14px;font-weight:600;font-family:inherit;cursor:pointer;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;white-space:nowrap;transition:opacity .2s,transform .2s}.settings-apply-btn:hover:not(:disabled){opacity:.9;transform:translateY(-1px)}.settings-apply-btn:disabled{opacity:.4;cursor:not-allowed;transform:none}.settings-apply-btn.saved{background:linear-gradient(135deg,#10b981,#059669)}.settings-reset-link{background:none;border:none;padding:0;font-size:12px;color:#ef4444;cursor:pointer;font-family:inherit;text-decoration:underline;text-underline-offset:2px;width:fit-content}.settings-reset-link:hover{color:#f87171;border-color:transparent}.settings-about-grid{display:flex;flex-direction:column;gap:12px}.settings-about-item{display:flex;justify-content:space-between;align-items:center}.about-key{font-size:14px;color:#6b7280}.about-val{font-size:14px;font-weight:500;color:#e2e8f0}.auth-toast{position:fixed;top:2.4vh;left:50%;transform:translate(-50%);z-index:9999;display:flex;align-items:center;gap:12px;background:#0f172a;border-left:4px solid #ef4444;color:#f1f5f9;padding:14px 18px;border-radius:14px;box-shadow:0 8px 32px #00000059;min-width:300px;max-width:460px;animation:toastIn .35s cubic-bezier(.34,1.56,.64,1) forwards}@keyframes toastIn{0%{opacity:0;transform:translate(-50%) translateY(-28px) scale(.95)}to{opacity:1;transform:translate(-50%) translateY(0) scale(1)}}.auth-toast-icon{font-size:22px;color:#ef4444;flex-shrink:0}.auth-toast-message{flex:1;font-size:13.5px;line-height:1.5;font-weight:500}.auth-toast-close{font-size:18px;color:#64748b;cursor:pointer;display:flex;align-items:center;flex-shrink:0;transition:color .2s}.auth-toast-close:hover{color:#f1f5f9}.auth-page{min-height:100vh;width:100%;display:flex;flex-direction:row;justify-content:center;align-items:center;padding:4vh 3vw;background:linear-gradient(135deg,#3b82f6,#60a5fa 45%,#f9a8d4)}.auth-card{width:46vw;max-width:760px;min-width:340px;background:#fff;border-radius:2vw;box-shadow:0 1.5vh 4vh #00000024;padding:4vh 4vw;display:flex;flex-direction:column;align-items:center}.auth-logo-box{margin-bottom:2vh}.auth-logo-img{width:120px;height:120px;object-fit:cover;border-radius:16px;margin:0 auto;display:block}.auth-title{margin:0;font-size:3vw;font-weight:700;color:#0f172a;text-align:center}.auth-subtitle{margin-top:1vh;margin-bottom:3vh;font-size:1.4vw;color:#64748b;text-align:center}.auth-field{width:100%;margin-bottom:2.2vh}.auth-label{display:block;margin-bottom:.9vh;font-size:1.2vw;font-weight:600;color:#334155}.auth-input-wrapper{position:relative;width:100%}.auth-input{width:100%;padding:1.5vh 1.2vw;padding-right:3.6vw;border-radius:1vw;border:.12vw solid #e2e8f0;background:#f8fafc;font-size:1.1vw;color:#0f172a;outline:none}.auth-input:focus{border-color:#3b82f6;background:#fff}.auth-input::placeholder{color:#94a3b8}.auth-eye{position:absolute;top:50%;right:1vw;color:#334155;cursor:pointer}.auth-error{width:100%;margin-bottom:1.2vh;color:#dc2626;font-size:1.05vw;text-align:center}.auth-options{width:100%;display:flex;justify-content:space-between;align-items:center;margin-top:.6vh;margin-bottom:2.4vh}.remember-area{display:flex;align-items:center;gap:.8vw}.remember-toggle{width:2.8vw;min-width:36px;height:1.6vw;min-height:20px;border-radius:999px;background:#cbd5e1;padding:.2vw;display:flex;align-items:center;cursor:pointer;transition:all .3s ease}.toggle-on{background:#2563eb;justify-content:flex-end}.toggle-circle{width:1.1vw;min-width:14px;height:1.1vw;min-height:14px;border-radius:50%;background:#fff}.remember-text,.forgot-password,.auth-footer span,.auth-link{font-size:1.05vw}.remember-text{color:#475569}.forgot-password{color:#2563eb;cursor:pointer}.auth-main-action{width:100%;text-align:center;padding:1.5vh 0;border-radius:1vw;background:#2563eb;color:#fff;font-size:1.3vw;font-weight:700;cursor:pointer;box-shadow:0 .8vh 2vh #2563eb33;transition:transform .2s ease,background .2s ease,box-shadow .2s ease;-webkit-user-select:none;user-select:none}.auth-main-action:hover{background:#1d4ed8;transform:scale(1.02);box-shadow:0 1vh 2.4vh #2563eb47}.auth-main-action:active{transform:scale(.98)}@keyframes pulseButton{0%{transform:scale(1);box-shadow:0 .8vh 2vh #2563eb33}50%{transform:scale(1.02);box-shadow:0 1vh 2.4vh #2563eb4d}to{transform:scale(1);box-shadow:0 .8vh 2vh #2563eb33}}.auth-divider{width:100%;display:flex;align-items:center;gap:1vw;margin:3vh 0;color:#94a3b8;font-size:1vw}.divider-line{flex:1;height:.1vh;background:#e2e8f0}.auth-footer{display:flex;gap:.4vw;align-items:center;justify-content:center;flex-wrap:wrap}.auth-footer span{color:#475569}.auth-link{color:#2563eb;font-weight:600;cursor:pointer}@media(max-width:900px){.auth-card{width:90vw;border-radius:20px;padding:4vh 6vw}.auth-logo{width:24vw;height:24vw;font-size:6vw}.auth-title{font-size:7vw}.auth-subtitle,.auth-label{font-size:4vw}.auth-input{font-size:4vw;padding:1.8vh 4vw;padding-right:12vw;border-radius:12px}.auth-eye{right:4vw;font-size:4vw}.auth-options{flex-direction:row;align-items:center;gap:3vw}.remember-text,.forgot-password,.auth-footer span,.auth-link{font-size:3.8vw}.auth-main-action{font-size:4.2vw;border-radius:12px}.auth-divider{font-size:3.5vw}}*{box-sizing:border-box}[role=button]{outline:none}.signup-page{min-height:100vh;display:flex;justify-content:center;align-items:center;background:linear-gradient(135deg,#4da3ff,#f7a8c7);padding:4vh 4vw}.signup-card{background:#fff;width:44vw;max-width:760px;min-width:340px;border-radius:2vw;padding:4vh 4vw;box-shadow:0 1vh 3vh #0000001f;text-align:center}.signup-logo{width:10vw;max-width:130px;min-width:90px;border-radius:1vw;margin-bottom:2vh}.signup-title{font-size:2.6vw;font-weight:700;color:#1e293b;margin:0}.signup-subtitle{font-size:1.3vw;color:#64748b;margin-top:1vh;margin-bottom:3vh}.auth-field{text-align:left;margin-bottom:2vh}.auth-label{display:block;font-size:1vw;font-weight:600;color:#334155;margin-bottom:.8vh}.auth-input-wrapper{position:relative}.auth-input{width:100%;padding:1.5vh 1vw;padding-right:3.5vw;border:1px solid #e2e8f0;border-radius:1vw;font-size:1vw;background:#f8fafc;outline:none}.auth-input:focus{border-color:#4f46e5}.auth-eye{position:absolute;top:50%;right:1vw;transform:translateY(-50%);cursor:pointer;font-size:1.1vw}.signup-agreement{display:flex;flex-wrap:wrap;justify-content:center;gap:.25vw;text-align:center;font-size:1vw;color:#475569;margin:2vh 0}.signup-link-inline{color:#4f46e5;cursor:pointer;font-weight:500}.signup-main-action{width:100%;background:#4f46e5;color:#fff;padding:1.6vh 0;border-radius:1vw;font-size:1.2vw;font-weight:600;cursor:pointer;text-align:center;transition:transform .2s ease,box-shadow .2s ease,background .2s ease}.signup-main-action:hover{transform:scale(1.02);background:#4338ca;box-shadow:0 1vh 2vh #4f46e533}.signup-main-action:active{transform:scale(.98)}.signup-divider{display:flex;align-items:center;gap:1vw;margin:3vh 0;color:#64748b;font-size:1vw}.divider-line{flex:1;height:1px;background:#e2e8f0}.signup-footer{display:flex;justify-content:center;gap:.4vw;font-size:1vw;color:#475569;flex-wrap:wrap}.signup-link{color:#4f46e5;cursor:pointer;font-weight:600}@media(max-width:900px){.signup-card{width:90vw;border-radius:20px;padding:4vh 6vw}.signup-logo{width:24vw}.signup-title{font-size:7vw}.signup-subtitle,.auth-label,.auth-input,.signup-agreement,.signup-divider,.signup-footer,.signup-main-action{font-size:4vw}.auth-eye{right:4vw;font-size:4vw}}
