:root{--primary:#2a9d8f;--secondary:#264653;--accent:#e9c46a;--light:#f8f9fa;--dark:#212529;--success:#38b000;--error:#e63946}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-family:Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;width:100%}#root{height:100vh;width:100%}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}*{box-sizing:border-box;font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif;margin:0;padding:0}body{background-color:var(--light);color:var(--dark);display:flex;flex-direction:column;min-height:100vh}.portal-container{display:flex;flex:1 1;height:100vh}.portal-visual{align-items:center;background:linear-gradient(135deg,#264653f2,#2a9d8fe6);color:#fff;display:flex;flex:1 1;justify-content:center;overflow:hidden;padding:2rem;position:relative}.visual-content{max-width:600px;position:relative;text-align:center;z-index:2}.portal-visual h1{font-size:3rem;font-weight:700;margin-bottom:1.5rem}.portal-visual p{font-size:1.2rem;line-height:1.6;margin-bottom:2rem;opacity:.9}.visual-overlay{background:radial-gradient(circle at center,#2a9d8f33 0,#26465399 100%);height:100%;left:0;position:absolute;top:0;width:100%;z-index:1}.eco-stats{display:flex;gap:2rem;justify-content:center;margin-top:2rem}.stat-item{text-align:center}.stat-number{color:var(--accent);font-size:2.5rem;font-weight:700;margin-bottom:.5rem}.stat-label{font-size:1rem;opacity:.9}.portal-bubbles{height:100%;left:0;overflow:hidden;position:absolute;top:0;width:100%;z-index:1}.bubble{animation:rise 15s ease-in infinite;background-color:#ffffff1a;border-radius:50%;bottom:-100px;position:absolute;z-index:0}.bubble:first-child{animation-duration:12s;height:40px;left:10%;width:40px}.bubble:nth-child(2){animation-delay:1s;animation-duration:18s;height:70px;left:25%;width:70px}.bubble:nth-child(3){animation-delay:2s;animation-duration:15s;height:50px;left:45%;width:50px}.bubble:nth-child(4){animation-delay:3s;animation-duration:20s;height:80px;left:65%;width:80px}.bubble:nth-child(5){animation-delay:4s;animation-duration:14s;height:35px;left:85%;width:35px}@keyframes rise{0%{bottom:-100px;opacity:1;transform:translateX(0) scale(1)}50%{opacity:.8;transform:translateX(-20px) scale(1.2)}to{bottom:1080px;opacity:0;transform:translateX(-40px) scale(.8)}}.portal-login{background-color:#fff;box-shadow:-10px 0 30px #0000001a;display:flex;flex:0 0 500px;flex-direction:column;justify-content:center;overflow:hidden;padding:3rem;position:relative}.login-container{max-width:400px;position:relative;width:100%;z-index:2}.portal-logo{align-items:center;display:flex;justify-content:center;margin-bottom:.5rem}.logo{display:block;height:auto}.logo-icon{font-size:2.5rem;margin-right:.8rem}.logo-text{color:var(--primary);font-size:2.2rem;font-weight:700}.login-heading{color:var(--secondary);font-size:1.8rem;font-weight:600;margin-bottom:1.5rem}.login-subheading{color:#6c757d;font-size:1.1rem;line-height:1.6}.login-form,.login-subheading{margin-bottom:2rem}.form-group{margin-bottom:1.5rem}.form-label{color:var(--secondary);font-weight:500;margin-bottom:.5rem}.form-input{border:1px solid #ced4da;border-radius:8px;font-size:1rem;padding:.8rem 1rem}.form-input:focus{border-color:var(--primary);box-shadow:0 0 0 3px #2a9d8f33}.form-options{justify-content:space-between;margin-bottom:2rem}.form-options,.remember-me{align-items:center;display:flex}.checkbox-input{accent-color:var(--primary);margin-right:.5rem}.forgot-password{color:var(--primary);font-weight:500;text-decoration:none;transition:color .3s ease}.forgot-password:hover{color:#226f66}.login-button{background:linear-gradient(135deg,var(--primary),#1d7d74);border:none;border-radius:8px;box-shadow:0 4px 15px #2a9d8f4d;color:#fff;cursor:pointer;font-size:1.1rem;font-weight:600;padding:.9rem;transition:all .3s ease;width:100%}.login-button:hover{background:linear-gradient(135deg,#30b5a5,#25968a);box-shadow:0 6px 20px #2a9d8f66;transform:translateY(-2px)}.sso-options{margin-top:1.5rem;text-align:center}.sso-divider{align-items:center;display:flex;margin-bottom:1.5rem}.divider-line{background-color:#ced4da;flex:1 1;height:1px}.divider-text{color:#6c757d;font-size:.9rem;padding:0 1rem}.sso-buttons{display:flex;gap:1rem}.sso-button{align-items:center;background-color:#fff;border:1px solid #ced4da;border-radius:8px;cursor:pointer;display:flex;flex:1 1;justify-content:center;padding:.8rem;transition:all .3s ease}.sso-button:hover{background-color:#f8f9fa;border-color:#adb5bd}.sso-icon{font-size:1.5rem;margin-right:.5rem}.bg-pattern{background-color:#2a9d8f0d;height:600px;right:-300px;top:-300px;width:600px}.bg-pattern,.bg-pattern-2{border-radius:50%;position:absolute;z-index:1}.bg-pattern-2{background-color:#e9c46a0d;bottom:-200px;height:400px;left:-200px;width:400px}.portal-footer{color:#6c757d;font-size:.9rem;text-align:center}.portal-footer a{color:var(--primary);font-weight:500;text-decoration:none;transition:color .3s ease}.portal-footer a:hover{color:#226f66}.fade-in{animation:fadeIn 1s ease-in-out}.slide-up{animation:slideUp .8s ease-in-out}@media (max-width:1200px){.portal-login{flex:0 0 450px}}@media (max-width:992px){.portal-container{flex-direction:column;height:auto}.portal-visual{height:400px;padding:2rem 1rem}.portal-login{flex:0 0 auto;padding:2rem}.eco-stats{flex-wrap:wrap;gap:1rem}}@media (max-width:576px){.portal-visual h1{font-size:2.2rem}.stat-number{font-size:2rem}.login-container{max-width:100%}}.d-none{display:none}.loading-overlay{align-items:center;background:#fffc;display:flex;flex-direction:column;height:100%;justify-content:center;left:0;position:fixed;top:0;width:100%;z-index:9999}.loading-spinner{animation:spin 1s linear infinite;border:6px solid #f3f3f3;border-radius:50%;border-top-color:#3498db;height:60px;margin-bottom:1rem;width:60px}@keyframes spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.dashboard-container{background:#fff;height:100%;left:0;position:fixed;top:0;width:100%;z-index:9999}.dashboard-wrapper{display:flex;flex-direction:column;height:100%;width:100%}.dashboard-header{align-items:center;background:#078c9d;box-shadow:0 2px 8px #0000001a;color:#fff;display:flex;justify-content:space-between;min-height:64px;padding:0 24px}.dashboard-logo{align-items:center;background:#0000;display:flex;padding:4px 0}.dashboard-logo-icon{font-size:1.8rem;margin-right:.5rem}.dashboard-logo-text{font-size:1.4rem;font-weight:600}.dashboard-nav{align-items:center;display:flex;gap:1rem}.nav-link{color:#fff;text-decoration:none;transition:opacity .2s ease}.nav-link:hover{opacity:.8}.user-avatar{background:var(--primary);font-weight:600;height:40px;width:40px}.dashboard-content{background:#f5f5f5;flex:1 1;overflow:auto;padding:.5rem}.content-title{color:var(--secondary);margin-bottom:1.5rem}.dashboard-card{background:#fff;border-radius:10px;box-shadow:0 4px 20px #00000014;height:100%;margin-bottom:2rem;padding:.5rem}.card-title{color:var(--secondary);margin-bottom:1rem}.report-placeholder{align-items:center;background:#f1f8f7;border-radius:8px;color:#888;display:flex;height:100%;justify-content:center;width:100%}@media (max-width:768px){.dashboard-header{min-height:56px;padding:12px 16px}.logo-dashboard{height:32px}.dashboard-nav{gap:.5rem}.dashboard-content{padding:1rem}}.welcome-text{color:#fff;font-size:1rem;margin-right:1rem}.logout-button{background-color:#fff;border:2px solid #fff;border-radius:4px;color:#078c9d;cursor:pointer;font-weight:600;margin:8px 16px;padding:8px 16px;transition:all .3s ease}.logout-button:hover{background-color:initial;color:#fff}.logout-button:active{background-color:#1d7d74}.powerbi-embed{height:100%;width:100%}.logo-dashboard{display:block;height:40px;transition:transform .2s ease}.logo-dashboard:hover{transform:scale(1.05)}.logo-dashboard-icon{font-size:2.5rem;margin-right:.8rem}.logo-dashboard-text{color:var(--primary);font-size:2.2rem;font-weight:700}.button-group{display:flex;flex-wrap:wrap;gap:12px;justify-content:flex-start}.custom-btn{background-color:#2c9dac;border:2px solid #2c9dac;border-radius:4px;color:#fff;cursor:pointer;font-size:14px;font-weight:600;margin:8px 0;overflow:hidden;padding:8px 16px;text-align:center;text-overflow:ellipsis;transition:all .3s ease;white-space:nowrap;width:280px}.custom-btn:hover{background-color:#fff;border-color:#078c9d;color:#078c9d}.custom-btn.selected{background-color:#fff;border-color:#fff;color:#078c9d;font-weight:700}.dashboard-logo-section{align-items:center;display:flex;gap:1rem}.user-avatar-container{display:inline-block;position:relative}.user-avatar{align-items:center;background:linear-gradient(135deg,#2a9d8f,#1d7d74);border:3px solid #fffc;border-radius:50%;box-shadow:0 3px 12px #0003;cursor:pointer;display:flex;height:42px;justify-content:center;transition:all .3s ease;width:42px}.user-avatar:hover{background:linear-gradient(135deg,#30b5a5,#25968a);border-color:#fff;box-shadow:0 5px 16px #0000004d;transform:translateY(-2px)}.user-initials{color:#fff;font-size:15px;font-weight:700;letter-spacing:.5px;text-shadow:0 1px 2px #0003;text-transform:uppercase}.user-dropdown{animation:dropdownFadeIn .2s ease-out;background:#fff;border:1px solid #00000014;border-radius:12px;box-shadow:0 8px 32px #00000026;min-width:200px;overflow:hidden;position:absolute;right:0;top:50px;z-index:1000}@keyframes dropdownFadeIn{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.dropdown-header{background:linear-gradient(135deg,#f8f9ff,#f0f2ff);border-bottom:1px solid #0000000f;padding:16px 20px}.dropdown-username{color:#2d3748;display:block;font-size:14px;font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.dropdown-divider{background:#0000000f;height:1px;margin:0}.dropdown-item{align-items:center;background:#fff;border:none;color:#4a5568;cursor:pointer;display:flex;font-size:14px;font-weight:500;gap:12px;padding:12px 20px;text-align:left;transition:all .2s ease;width:100%}.dropdown-item:hover{background:#f8f9ff;color:#2d3748}.dropdown-item.logout:hover{background:#fff5f5;color:#e53e3e}.dropdown-icon{align-items:center;display:flex;font-size:16px;justify-content:center;width:16px}@media (max-width:768px){.user-dropdown{min-width:180px;right:-10px}.dropdown-item{font-size:15px;padding:14px 16px}.user-avatar{height:36px;width:36px}.user-initials{font-size:13px}}.modal-overlay{align-items:center;animation:fadeIn .3s ease-out;background:#00000080;bottom:0;display:flex;justify-content:center;left:0;padding:20px;position:fixed;right:0;top:0;z-index:2000}.modal-container{animation:slideUp .3s ease-out;background:#fff;border-radius:16px;box-shadow:0 20px 60px #0003;max-height:90vh;max-width:480px;overflow:hidden;width:100%}.modal-container,.modal-content{position:relative}.modal-header{align-items:center;background:linear-gradient(135deg,#f8f9ff,#f0f2ff);border-bottom:1px solid #00000014;display:flex;justify-content:space-between;padding:24px 24px 16px}.modal-title{color:#2d3748;font-size:20px;font-weight:600;margin:0}.modal-close{align-items:center;background:none;border:none;border-radius:8px;color:#718096;cursor:pointer;display:flex;font-size:24px;height:32px;justify-content:center;transition:all .2s ease;width:32px}.modal-close:hover{background:#0000000d;color:#2d3748}.change-password-form{padding:24px}.form-group{margin-bottom:20px}.form-label{color:#2d3748;display:block;font-size:14px;font-weight:600;letter-spacing:.025em;margin-bottom:8px}.form-input{background:#fff;border:2px solid #e2e8f0;border-radius:12px;box-sizing:border-box;color:#2d3748;font-size:16px;padding:12px 16px;transition:all .3s ease;width:100%}.form-input:focus{background:#fafbff;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a;outline:none}.form-input:disabled{background:#f7fafc;cursor:not-allowed;opacity:.6}.form-input::placeholder{color:#a0aec0}.error-message{background:linear-gradient(135deg,#fed7d7,#feb2b2);border:1px solid #fca5a5;border-radius:8px;color:#c53030}.error-message,.success-message{font-size:14px;font-weight:500;margin-bottom:20px;padding:12px 16px}.success-message{background:linear-gradient(135deg,#c6f6d5,#9ae6b4);border:1px solid #68d391;border-radius:8px;color:#2f855a}.modal-actions{border-top:1px solid #00000014;display:flex;gap:12px;margin-top:32px;padding-top:20px}.cancel-button{background:#fff;border:2px solid #e2e8f0;border-radius:12px;color:#4a5568;cursor:pointer;flex:1 1;font-size:16px;font-weight:600;padding:12px 24px;transition:all .3s ease}.cancel-button:hover:not(:disabled){background:#f7fafc;border-color:#cbd5e0;transform:translateY(-1px)}.change-password-button{background:linear-gradient(135deg,#2a9d8f,#1d7d74);border:none;border-radius:12px;box-shadow:0 4px 15px #2a9d8f4d;color:#fff;cursor:pointer;flex:1 1;font-size:16px;font-weight:600;padding:12px 24px;transition:all .3s ease}.change-password-button:hover:not(:disabled){background:linear-gradient(135deg,#30b5a5,#25968a);box-shadow:0 6px 20px #2a9d8f66;transform:translateY(-2px)}.cancel-button:disabled,.change-password-button:disabled{cursor:not-allowed;opacity:.6;transform:none}@media (max-width:768px){.modal-overlay{padding:16px}.modal-container{border-radius:12px;max-width:100%}.modal-header{padding:20px 20px 16px}.modal-title{font-size:18px}.change-password-form{padding:20px}.modal-actions{flex-direction:column}.cancel-button,.change-password-button{width:100%}.form-input{font-size:16px}}.auto-logout-overlay{align-items:center;animation:fadeIn .3s ease-out;background:#00000080;bottom:0;display:flex;justify-content:center;left:0;padding:20px;position:fixed;right:0;top:0;z-index:10000}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.auto-logout-modal{animation:slideUp .3s ease-out;background:#fff;border-radius:16px;box-shadow:0 20px 60px #0003;max-height:90vh;max-width:480px;overflow:hidden;position:relative;width:100%}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.auto-logout-header{align-items:center;background:linear-gradient(135deg,#f8f9ff,#f0f2ff);border-bottom:1px solid #00000014;display:flex;flex-direction:column;justify-content:center;padding:24px 24px 16px;text-align:center}.auto-logout-icon{display:flex;justify-content:center;margin-bottom:16px}.auto-logout-title{color:#2d3748;font-size:20px;font-weight:600;margin:0;text-align:center}.auto-logout-body{padding:24px;text-align:center}.auto-logout-message{color:#374151;font-size:16px;line-height:1.5;margin:0 0 24px}.auto-logout-countdown{background:linear-gradient(135deg,#2a9d8f1a,#078c9d1a);border:2px solid var(--primary);border-radius:12px;margin:24px 0;padding:24px;text-align:center}.countdown-display{color:var(--primary);font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif;font-size:48px;font-weight:700;margin-bottom:8px;text-shadow:0 2px 4px #2a9d8f1a}.countdown-separator{animation:blink 1s infinite;color:var(--primary)}@keyframes blink{0%,50%{opacity:1}51%,to{opacity:.3}}.countdown-label{color:var(--secondary);font-size:14px;font-weight:600;letter-spacing:.5px;text-transform:uppercase}.auto-logout-description{color:#6b7280;font-size:14px;line-height:1.5;margin:0}.auto-logout-footer{border-top:1px solid #00000014;display:flex;gap:12px;margin-top:32px;padding:20px 24px 24px}.auto-logout-btn{border-radius:12px;cursor:pointer;flex:1 1;font-size:16px;font-weight:600;padding:12px 24px;text-align:center;transition:all .3s ease}.auto-logout-btn:focus{box-shadow:0 0 0 3px #2a9d8f1a;outline:none}.auto-logout-btn-primary{background:linear-gradient(135deg,var(--primary),#1d7d74);border:none;box-shadow:0 4px 15px #2a9d8f4d;color:#fff}.auto-logout-btn-primary:hover:not(:disabled){background:linear-gradient(135deg,#30b5a5,#25968a);box-shadow:0 6px 20px #2a9d8f66;transform:translateY(-2px)}.auto-logout-btn-primary:active{box-shadow:0 4px 15px #2a9d8f4d;transform:translateY(0)}.auto-logout-btn-secondary{background:#fff;border:2px solid #e2e8f0;color:#4a5568}.auto-logout-btn-secondary:hover:not(:disabled){background:#f7fafc;border-color:#cbd5e0;transform:translateY(-1px)}.auto-logout-btn-secondary:active{transform:translateY(0)}@media (max-width:768px){.auto-logout-overlay{padding:16px}.auto-logout-modal{margin:16px;width:calc(100% - 32px)}.auto-logout-header{padding:20px 20px 12px}.auto-logout-title{font-size:18px}.auto-logout-body{padding:20px}.countdown-display{font-size:36px}.auto-logout-footer{flex-direction:column;padding:12px 20px 20px}.auto-logout-btn{width:100%}}@media (max-width:576px){.auto-logout-modal{width:calc(100% - 32px)}.countdown-display{font-size:32px}.auto-logout-btn{font-size:14px;padding:14px 20px}}
/*# sourceMappingURL=main.a7a79c87.css.map*/