:root{--bg-page:#dde3e8;--bg-card:#f0f0f0;--text-primary:#232323;--text-secondary:#2d5b4e;--accent-main:#7eac97;--accent-light:#eab8a1;--accent-green:#2d5b4e;--border-color:#bfcad1;--overlay-bg:#e7c8a12e;--menu-bg:#b7d3c4d9;--max-width:1200px;--gutter:1rem;--font-size-base:1rem;--ratio:1.2;--radius:1rem;--padding:1.5rem;--success-color:#00c49f;--error-color:#ff4d4f}[data-theme=dark]{--bg-page:#232323;--bg-card:#2d5b4e;--text-primary:#f5f2ec;--text-secondary:#eab8a1;--accent-main:#f7d58a;--accent-light:#eab8a1;--accent-green:#7eac97;--border-color:#e7c8a1;--overlay-bg:#eab8a11a;--menu-bg:#2d5b4eb3}*,:after,:before{box-sizing:border-box;margin:0;padding:0}html{font-family:Inter,sans-serif;font-size:1rem;font-size:var(--font-size-base);line-height:1.6}a{text-decoration:none}a,body{color:#232323;color:var(--text-primary)}body{background-color:#dde3e8;background-color:var(--bg-page);transition:background-color .3s,color .3s}@media (min-width:600px){html{font-size:1.125rem;font-size:calc(var(--font-size-base)*1.125)}}@media (min-width:900px){html{font-size:1.25rem;font-size:calc(var(--font-size-base)*1.25)}}.navbar{align-items:center;background:#fff;border-bottom:1px solid var(--accent-main);box-shadow:0 2px 4px #0000001a;display:flex;gap:1rem;justify-content:space-between;left:0;padding:1rem 2rem;right:0;top:0}.navbar h2{font-size:1.5rem;margin:0}.navbar h2 a{color:#2196f3;text-decoration:none}.navbar-logo-container{display:flex;flex:1 1;justify-content:flex-start;padding-left:1rem}.navbar-logo-container a{align-items:center;display:flex;height:40px;margin:0}.navbar-logo-container .navbar-logo-image{border-radius:50%;height:40px;object-fit:cover;width:40px}.menu-toggle{cursor:pointer;margin-right:auto;padding:.5rem;z-index:1101}.hamburger,.menu-toggle{background:none;border:none;display:block}.hamburger{height:22px;position:relative;width:28px}.hamburger span,.hamburger:after,.hamburger:before{background:#333;border-radius:2px;content:"";height:3px;left:0;position:absolute;transition:all .3s;width:28px}.hamburger span{top:9.5px}.hamburger:before{top:2px}.hamburger:after{bottom:2px}.menu-toggle[aria-expanded=true] .hamburger span{background:#0000}.menu-toggle[aria-expanded=true] .hamburger:before{background:#0000;transform:rotate(45deg)}.menu-toggle[aria-expanded=true] .hamburger:after{background:#0000;transform:rotate(-45deg)}.nav-menu{display:none}.nav-list{align-items:flex-start;display:flex;flex-direction:column;gap:2rem;gap:1.5rem;justify-content:flex-start;list-style:none;margin:0;padding:0}.nav-item a{color:#333;font-weight:500;text-decoration:none;transition:color .3s}.nav-item a:hover{zoom:1.1;color:var(--accent-main)}.user-avatar{height:40px;overflow:hidden;width:40px}.avatar-image{height:100%;object-fit:cover;width:100%}.menu-overlay{background:#00000080;bottom:0;display:none;left:0;position:fixed;right:0;top:0;z-index:999}@media (max-width:1023px){.navbar{align-items:center;flex-direction:row;gap:.5rem;justify-content:space-between}.navbar-logo-container{justify-content:flex-end;padding-left:0;padding-right:1rem}.navbar-logo-container .navbar-logo-image{height:50px;width:50px}.close-menu{align-items:center;animation:fadeInCloseBtn .4s .1s forwards;border:none;border-radius:50%;box-shadow:0 2px 8px #2d5b4e1a;color:var(--accent-green);cursor:pointer;display:block;font-size:2.2rem;font-weight:700;height:40px;justify-content:center;opacity:1;position:absolute;right:1.2rem;top:1.2rem;transition:background .2s,box-shadow .2s,color .2s,transform .2s;width:40px;z-index:1102}.close-menu,.nav-menu{background:#ffffffd9;display:flex}.nav-menu{align-items:flex-start;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border-bottom-right-radius:24px;border-top-right-radius:24px;box-shadow:4px 0 24px #0000002e;flex-direction:column;height:100vh;justify-content:flex-start;left:-100%;max-width:300px;padding:2rem 1.5rem;position:fixed;top:0;transition:left .3s cubic-bezier(.77,0,.18,1);width:80%;z-index:1000}.nav-menu.open{left:0}.nav-list{align-items:flex-start;flex-direction:column;font-size:1.15rem;gap:1.5rem;justify-content:flex-start;margin-top:0;padding-top:0;width:100%}.nav-item a{border-radius:.7rem;display:block;font-size:1.15rem;font-weight:600;padding:.7rem 1rem;transition:background .2s,color .2s}.nav-item a:hover{background:#e3f2fd;color:#2196f3}}@media (min-width:1024px){.navbar{gap:2rem}.menu-toggle{display:none}.close-menu{display:none!important}.nav-menu{animation:fadeInMenu .6s forwards;background:#0000;border-radius:0;box-shadow:none;display:flex!important;height:auto;opacity:0;position:static}.nav-list,.nav-menu{align-items:center;padding:0;width:auto}.nav-list{display:flex;flex-direction:row;font-size:.75rem;gap:.5rem;justify-content:flex-end;margin:0}.nav-item+.nav-item{margin:0 0 0 1.5rem}.nav-item a{font-size:.75rem;transition:background .2s,color .2s,box-shadow .2s,transform .2s}.nav-item a:hover{background:#e3f2fd;box-shadow:0 4px 16px #e3f2fd;color:var(--accent-main);transform:translateY(-4px) scale(1.07)}.navbar-logo-container .navbar-logo-image{height:60px;width:60px}}@keyframes fadeInMenu{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeInCloseBtn{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.alerts-link{align-items:center;display:flex!important;gap:.5rem;position:relative}.alerts-badge{align-items:center;background-color:#f44336;border-radius:50px;color:#fff;display:flex;font-size:.7rem;font-weight:700;height:1.2rem;justify-content:center;min-width:1.2rem;padding:.2rem .5rem}.profile-link{align-items:center;display:flex!important;gap:.5rem}.profile-icon{color:inherit;font-size:1rem!important}@media (max-width:768px){.navbar{gap:.5rem}}.card{background-color:var(--bg-card);border:1px solid var(--accent-main);border-radius:var(--radius);box-shadow:0 2px 4px #0000000d;margin:0 0 1.5rem;overflow:hidden;padding:1.5rem;position:relative;transition:all .3s ease;width:100%}.card:hover{box-shadow:0 4px 8px #0000001a;transform:translateY(-2px)}.card-header{align-items:flex-start;display:flex;justify-content:space-between;margin-bottom:1rem}.card-header-text{display:flex;flex-direction:column;gap:.25rem}.card-header-label{color:var(--text-secondary);font-size:.875rem;font-weight:500;letter-spacing:.5px;text-transform:uppercase}.card-header-title{color:var(--text-primary);font-size:1.75rem;font-weight:600;line-height:1.2;margin:0}.card-icon{align-items:center;background-color:var(--accent-pink);border-radius:.75rem;color:#fff;display:flex;height:2.5rem;justify-content:center;transition:transform .2s ease;width:2.5rem}.card-icon svg{height:1.5rem;width:1.5rem}.card:hover .card-icon{transform:scale(1.05)}.card-body{border-top:1px solid #0000000d;margin-top:1rem;padding-top:1rem}.card-change{align-items:center;border-radius:1rem;display:inline-flex;font-size:.875rem;font-weight:500;gap:.5rem;margin-top:.5rem;transition:all .2s ease}.card-change svg{height:1.25rem;width:1.25rem}.card-change.success{background-color:rgba(var(--success-color-rgb),.1);border:1px solid rgba(var(--success-color-rgb),.2);color:var(--success-color)}.card-change.error{background-color:rgba(var(--error-color-rgb),.1);border:1px solid rgba(var(--error-color-rgb),.2);color:var(--error-color)}.card-change span{font-size:1.25rem}.water-area-chart-container{background:var(--bg-card);border:1px solid var(--accent-main);border-radius:var(--radius);box-shadow:0 4px 24px #00000012;box-sizing:border-box;margin-bottom:1.5rem;max-width:500px;min-width:220px;padding:1.5rem;transition:max-width .3s,padding .3s;width:100%}.water-area-chart-container,.water-area-chart-title{align-items:center;display:flex;flex-direction:column}.water-area-chart-title{color:var(--text-primary);font-size:1.1rem;gap:.5rem;margin:0 0 1.5rem;text-align:center}@media (max-width:600px){.water-area-chart-container{max-width:98vw;padding-left:.5rem;padding-right:.5rem}}@media (min-width:600px){.water-area-chart-container{max-width:700px;padding:2rem}}@media (min-width:1024px){.water-area-chart-container{max-width:900px;padding:2.5rem}}.water-bar-chart-card{border:1px solid var(--accent-main);border-radius:var(--radius);box-shadow:0 4px 24px #00000012;box-sizing:border-box;margin-bottom:1.5rem;max-width:500px;min-width:220px;padding:1.5rem;transition:max-width .3s,padding .3s;width:100%}.water-bar-chart-card,.water-bar-chart-title{align-items:center;display:flex;flex-direction:column}.water-bar-chart-title{color:var(--text-primary);font-size:1.1rem;gap:.5rem;margin:0 0 1.5rem;text-align:center}.limit-info{color:var(--text-secondary);font-size:.9rem;font-weight:400}@media (min-width:600px){.water-bar-chart-card{max-width:700px;padding:2rem}}@media (min-width:1024px){.water-bar-chart-card{max-width:900px;padding:2.5rem}}@media (max-width:600px){.water-bar-chart-card{max-width:98vw;padding-left:.5rem;padding-right:.5rem}}.monthly-comparison-container{align-items:center;background:var(--bg-card);border:1px solid var(--accent-main);border-radius:var(--radius);box-shadow:0 4px 24px #00000012;box-sizing:border-box;display:flex;flex-direction:column;margin-bottom:1.5rem;max-width:500px;min-width:220px;padding:1.5rem;transition:max-width .3s,padding .3s;width:100%}.monthly-comparison-title{color:var(--text-primary);font-size:1.1rem;margin:0 0 1rem;text-align:center}.savings-info{align-items:center;display:flex;flex-direction:column;gap:.5rem;margin-bottom:1.5rem}.savings-percentage{color:var(--success-color);font-size:1.2rem;font-weight:700}.savings-amount{color:var(--text-secondary);font-size:.9rem}.custom-tooltip{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius);box-shadow:0 2px 8px #0000001a;padding:.5rem 1rem}.custom-tooltip .label{color:var(--text-primary);font-size:.9rem;margin:0}@media (min-width:600px){.monthly-comparison-container{max-width:700px;padding:2rem}}@media (min-width:1024px){.monthly-comparison-container{max-width:900px;padding:2.5rem}}.bill-prediction-section{background:linear-gradient(135deg,#3b82f60d,#10b9810d);border:1px solid #3b82f633;border-radius:var(--radius);margin-top:2rem;padding:1.5rem}.prediction-header{align-items:center;display:flex;gap:.5rem;margin-bottom:1rem}.prediction-icon{color:var(--accent-main);font-size:1.2rem}.prediction-title{color:var(--text-primary);font-size:1rem;font-weight:600;margin:0}.prediction-content{display:flex;flex-direction:column;gap:1rem}.predicted-bill{align-items:center;background:var(--bg-card);border:2px solid var(--accent-main);border-radius:var(--radius);display:flex;flex-direction:column;padding:1rem}.bill-amount{color:var(--accent-main);font-size:2rem;font-weight:700;line-height:1}.bill-label{color:var(--text-secondary);font-size:.9rem;margin-top:.25rem}.bill-comparison{align-items:center;background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius);display:flex;gap:.5rem;padding:.75rem}.trend-icon{font-size:1.1rem}.trend-icon.trend-up{color:var(--error-color)}.trend-icon.trend-down{color:var(--success-color)}.trend-icon.trend-stable{color:var(--warning-color)}.comparison-text{flex:1 1;font-size:.9rem;font-weight:500}.comparison-text.increase{color:var(--error-color)}.comparison-text.decrease{color:var(--success-color)}.comparison-text.stable{color:var(--warning-color)}.difference-amount{font-size:.9rem;font-weight:700}.difference-amount.increase{color:var(--error-color)}.difference-amount.decrease{color:var(--success-color)}.prediction-details{grid-gap:.5rem;background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius);display:grid;gap:.5rem;grid-template-columns:1fr;padding:1rem}.detail-item{align-items:center;display:flex;justify-content:space-between;padding:.25rem 0}.detail-label{color:var(--text-secondary);font-size:.85rem}.detail-value{color:var(--text-primary);font-size:.85rem;font-weight:600}.confidence-indicator{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius);display:flex;flex-direction:column;gap:.5rem;padding:.75rem}.confidence-badge{font-size:.8rem;font-weight:700;letter-spacing:.5px;text-transform:uppercase}.confidence-badge.high{color:var(--success-color)}.confidence-badge.medium{color:var(--warning-color)}.confidence-badge.low{color:var(--error-color)}.confidence-message{color:var(--text-secondary);font-size:.8rem;font-style:italic}@media (min-width:600px){.prediction-content{gap:1.5rem}.predicted-bill{padding:1.5rem}.bill-amount{font-size:2.5rem}.prediction-details{grid-template-columns:repeat(2,1fr);padding:1.5rem}.confidence-indicator{align-items:center;flex-direction:row;justify-content:space-between}}@media (max-width:600px){.monthly-comparison-container{max-width:98vw;padding-left:.5rem;padding-right:.5rem}.bill-prediction-section{margin-top:1.5rem;padding:1rem}.predicted-bill{padding:.75rem}.bill-amount{font-size:1.75rem}.prediction-details{padding:.75rem}}.view-toggle{position:fixed;right:1rem;top:4.5rem;z-index:1000}.toggle-button{border:none;border-radius:20px;box-shadow:0 2px 4px #0000001a;cursor:pointer;font-weight:500;padding:.5rem 1rem;transition:all .3s ease}.toggle-button.real{background-color:var(--accent-main);color:#fff}.toggle-button.simulated{background-color:var(--accent-light);color:var(--text-primary)}.toggle-button:hover{box-shadow:0 4px 8px #00000026;transform:translateY(-2px)}@media (max-width:768px){.view-toggle{bottom:1rem;right:1rem;top:auto}}.filter-panel-compact{background:var(--bg-card);border:1px solid var(--border-color);border-radius:.5rem;box-shadow:0 2px 4px #0000000d;margin-bottom:1rem;overflow:hidden;padding:.75rem;position:relative}.filter-panel-compact:before{background:var(--accent-main);border-radius:.5rem .5rem 0 0;content:"";height:2px;left:0;position:absolute;right:0;top:0}.filter-row{align-items:flex-end;display:flex;gap:1rem}.filter-group{flex:1 1;min-width:0}.filter-label{align-items:center;color:var(--text-secondary);display:flex;font-size:.7rem;font-weight:600;gap:.375rem;letter-spacing:.5px;margin-bottom:.375rem;text-transform:uppercase}.filter-select-wrapper{position:relative}.filter-select{appearance:none;-webkit-appearance:none;-moz-appearance:none;background:var(--bg-card);border:1px solid var(--border-color);border-radius:.375rem;color:var(--text-primary);cursor:pointer;font-size:.8rem;font-weight:500;padding:.5rem 2rem .5rem .75rem;transition:all .2s ease;width:100%}.filter-select:hover{border-color:var(--accent-main);box-shadow:0 1px 4px #7eac9726}.filter-select:focus{border-color:var(--accent-green);box-shadow:0 0 0 2px #7eac9733;outline:none}.filter-select-icon{color:var(--text-secondary);font-size:1rem;pointer-events:none;position:absolute;right:.5rem;top:50%;transform:translateY(-50%);transition:transform .2s ease}.filter-select:focus+.filter-select-icon{color:var(--accent-green);transform:translateY(-50%) rotate(180deg)}.filter-select option{background:var(--bg-card);color:var(--text-primary);padding:.375rem}@media (max-width:768px){.filter-panel-compact{margin-bottom:.875rem;padding:.625rem}.filter-row{gap:.75rem}.filter-label{font-size:.65rem;gap:.25rem;margin-bottom:.25rem}.filter-select{font-size:.75rem;padding:.4rem 1.75rem .4rem .6rem}.filter-select-icon{font-size:.9rem;right:.5rem}}@media (max-width:480px){.filter-panel-compact{margin-bottom:.75rem;padding:.5rem}.filter-row{align-items:stretch;flex-direction:column;gap:.75rem}.filter-group{flex:none}.filter-label{font-size:.6rem;gap:.2rem;margin-bottom:.2rem}.filter-select{font-size:.75rem;padding:.4rem 1.75rem .4rem .6rem}.filter-select-icon{font-size:.85rem}}[data-theme=dark] .filter-panel-compact{background:var(--bg-card);border-color:var(--border-color)}[data-theme=dark] .filter-panel-compact:before{background:var(--accent-main)}[data-theme=dark] .filter-label{color:var(--text-secondary)}[data-theme=dark] .filter-select{background:var(--bg-card);border-color:var(--border-color);color:var(--text-primary)}[data-theme=dark] .filter-select:hover{border-color:var(--accent-main)}[data-theme=dark] .filter-select option{background:var(--bg-card);color:var(--text-primary)}[data-theme=dark] .filter-select-icon{color:var(--text-secondary)}@keyframes slideInDown{0%{opacity:0;transform:translateY(-5px)}to{opacity:1;transform:translateY(0)}}.filter-panel-compact{animation:slideInDown .2s ease-out}.title{font-weight:700;letter-spacing:1px;margin-bottom:0;padding:var(--gutter)}.dashboard-container{gap:2rem;padding:var(--gutter)}.cards-row,.dashboard-container{display:flex;flex-direction:column}.cards-row{gap:1.5rem}.charts-row{align-items:center}@media (min-width:900px){.dashboard-container{grid-gap:2rem;display:grid;gap:2rem;grid-template-columns:1fr 2fr;margin:0 auto;max-width:var(--max-width)}.cards-row{flex:1 1 320px;grid-column:1;grid-row:1;max-width:350px}.charts-row{flex:3 1 700px;grid-column:2;grid-row:1;min-width:0}.monthly-comparison-row{grid-column:2;grid-row:2;margin-top:0}}.dashboard-container{margin:0 auto;max-width:var(--max-width);padding:1rem}.cards-row{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));margin-bottom:2rem}.charts-row{display:flex;flex-direction:column;gap:2rem}.charts-row>*{min-height:400px;width:100%}.title{color:var(--text-primary);font-size:1.5rem;font-weight:600;margin:1rem 0 0;text-align:center}.filter-container{margin:0 auto;max-width:var(--max-width);padding:0 var(--gutter)}.monthly-comparison-row{display:flex;justify-content:center;margin-top:1.5rem;width:100%}@media (min-width:900px){.dashboard-container{grid-gap:2rem;display:grid;gap:2rem;grid-template-columns:1fr 2fr}.cards-row{grid-column:1;grid-row:1}.charts-row{grid-column:2;grid-row:1}.monthly-comparison-row{grid-column:2;grid-row:2;margin-top:0}}@media (max-width:768px){.cards-row{grid-template-columns:1fr}}@media (max-width:600px){.monthly-comparison-row{margin-top:1rem}}.device-selector{background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000001a;margin-bottom:1.5rem;padding:1.5rem}.device-selector.compact{margin-bottom:1rem;padding:1rem}.device-selector-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:1rem}.device-selector h3{color:#333;font-size:1.2rem;font-weight:600;margin:0 0 1rem}.refresh-btn{align-items:center;background:#f8f9fa;border:1px solid #e9ecef;border-radius:8px;color:#495057;cursor:pointer;display:flex;justify-content:center;padding:.5rem;transition:all .3s ease}.refresh-btn:hover{background:#e9ecef;color:#667eea}.refresh-btn.refreshing svg{animation:spin 1s linear infinite}.devices-list{display:flex;flex-direction:column;gap:1rem}.device-card{background:#fafafa;border:2px solid #e9ecef;border-radius:12px;cursor:pointer;padding:1rem;transition:all .3s ease}.device-card:hover{background:#fff;border-color:#667eea;box-shadow:0 4px 12px #667eea26;transform:translateY(-2px)}.device-card.selected{background:linear-gradient(135deg,#667eea10,#764ba210);border-color:#667eea;box-shadow:0 4px 12px #667eea33}.device-header{align-items:flex-start;display:flex;justify-content:space-between;margin-bottom:.75rem}.device-info h4{color:#333;font-size:1.1rem;font-weight:600;margin:0 0 .25rem}.device-location{color:#666;font-size:.9rem}.device-status{align-items:center;display:flex;gap:.5rem}.status-icon{font-size:1.2rem!important}.status-icon.online{color:#28a745}.status-icon.offline{color:#dc3545}.signal-icon{font-size:1.1rem!important}.signal-icon.strong{color:#28a745}.signal-icon.medium{color:#ffc107}.signal-icon.weak{color:#dc3545}.device-details{display:flex;flex-direction:column;gap:.5rem;margin-bottom:.75rem}.device-stat{align-items:center;display:flex;font-size:.9rem;justify-content:space-between}.stat-label{color:#666;font-weight:500}.stat-value{color:#333;font-weight:600}.stat-value.valve-open{color:#28a745}.stat-value.valve-closed{color:#dc3545}.stat-value.valve-unknown{color:#6c757d}.device-id{border-top:1px solid #e9ecef;color:#999;font-size:.8rem;margin-top:.5rem;padding-top:.5rem;text-align:right}.selected-device-info{background:linear-gradient(135deg,#667eea,#764ba2);border-radius:8px;color:#fff;margin-top:1rem;padding:.75rem;text-align:center}.selected-device-info h4{font-size:.9rem;font-weight:500;margin:0 0 .5rem;opacity:.9}.selected-device-info span{font-weight:600}.error-message,.loading-message,.no-devices-message{align-items:center;color:#666;display:flex;flex-direction:column;justify-content:center;padding:2rem;text-align:center}.loading-icon{color:#667eea;font-size:2rem!important;margin-bottom:1rem}.no-devices-icon{color:#ccc;font-size:3rem!important;margin-bottom:1rem}.no-devices-message h4{color:#333;margin:0 0 .5rem}.no-devices-message p{color:#666;font-size:.9rem;margin:0 0 1rem}.retry-btn{background:#dc3545;border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:.9rem;margin-left:.5rem;padding:.5rem 1rem}.retry-btn:hover{background:#c82333}@media (max-width:768px){.device-selector{padding:1rem}.device-card{padding:.75rem}.device-header{align-items:flex-start;flex-direction:column;gap:.5rem}.device-status{align-self:flex-end}.device-stat{align-items:flex-start;flex-direction:column;gap:.25rem}}@media (max-width:480px){.device-selector-header{align-items:flex-start;flex-direction:column;gap:.5rem}.device-selector h3{margin-bottom:0}}.container{background-color:var(--bg-page);padding:0 1rem}.container,.valveContainer{align-items:center;display:flex;flex-direction:column}.valveContainer{background:var(--bg-card);border-radius:var(--radius);box-shadow:0 4px 24px #0000001a;margin:0 0 1.5rem;max-width:400px;padding:1.5rem 1.5rem 1rem;width:100%}.valve-svg{background:var(--bg-page);border-radius:1rem;box-shadow:0 2px 12px #0000001a;display:block;height:auto;margin:0 auto;max-width:340px;width:100%}.valveIndicator{color:var(--accent-main);font-size:1.1rem;font-weight:600;margin-top:1rem}.statusContainer{background-color:var(--bg-card);border-radius:var(--radius);box-shadow:0 2px 12px #00000014;margin-bottom:1.5rem;max-width:400px;padding:1.2rem 1.5rem;text-align:center;width:100%}.statusLabel{color:var(--text-secondary);font-size:1rem;margin-bottom:4px}.statusValue{color:var(--success-color);font-size:1.2rem;font-weight:700}.controlsContainer{display:flex;flex-direction:row;gap:1rem;justify-content:center;margin-bottom:2rem;max-width:400px;width:100%}.button{background-color:var(--accent-main);border:none;border-radius:.7rem;box-shadow:0 2px 8px #0000001a;color:#fff;cursor:pointer;font-size:1rem;font-weight:600;outline:none;padding:.9rem 1.5rem;text-align:center;transition:background-color .3s,box-shadow .3s}.activeButton,.button:hover{background-color:var(--accent-green);box-shadow:0 4px 16px #e9789d26}.buttonText{color:inherit;font-size:1rem;font-weight:600}.valveContainer{height:200px;margin:20px 0;perspective:1000px;position:relative;width:200px}.valve{transform-style:preserve-3d;transition:transform 1s ease-in-out}.valve,.valveBody{height:100%;position:relative;width:100%}.valveBody{background:#2c3e50;border-radius:50%;box-shadow:0 0 20px #0000004d}.valveHandle{background:#e74c3c;border-radius:10px;height:100px;left:50%;position:absolute;top:50%;transform:translate(-50%,-100%);transform-origin:bottom center;transition:transform 1s ease-in-out;width:20px}.valve.open .valveHandle{transform:translate(-50%,-100%) rotate(90deg)}.valve.semi-open .valveHandle{transform:translate(-50%,-100%) rotate(45deg)}.valve.closed .valveHandle{transform:translate(-50%,-100%) rotate(0deg)}.valveBody:after{animation:shine 2s infinite;background:linear-gradient(45deg,#0000,#ffffff1a,#0000);border-radius:50%;bottom:10%;content:"";left:10%;position:absolute;right:10%;top:10%}@keyframes shine{0%{transform:translateX(-100%) rotate(45deg)}to{transform:translateX(100%) rotate(45deg)}}.valveIndicator{bottom:-30px;color:#666;font-size:14px;left:50%;position:absolute;text-align:center;transform:translateX(-50%);width:100%}.connectionStatus{align-items:center;background:var(--bg-card);border-radius:2rem;box-shadow:0 2px 8px #00000014;display:flex;gap:.5rem;justify-content:center;margin:1rem 0;padding:.5rem 1rem}.statusIndicator{border-radius:50%;height:10px;width:10px}.statusIndicator.connected{background-color:#4caf50}.statusIndicator.error{background-color:#f44336}.statusIndicator.disconnected{background-color:#ffc107}.statusText{color:var(--text-secondary);font-size:.9rem}.errorMessage{background-color:#ffebee;border-left:4px solid #f44336;border-radius:.5rem;color:#c62828;margin:1rem 0;max-width:400px;padding:.75rem 1rem;width:100%}.button.disabled,.button:disabled{background-color:#ccc;cursor:not-allowed;opacity:.5}.securityInfo{background-color:#e3f2fd;border-left:4px solid #2196f3;border-radius:.5rem;margin-top:2rem;max-width:400px;padding:1rem;width:100%}.infoText{color:#1565c0;font-size:.9rem;margin:0}.infoText strong,.toggleButton{font-weight:600}.toggleButton{align-items:center;border:none;border-radius:2rem;box-shadow:0 4px 16px #0000001a;cursor:pointer;display:flex;font-size:1.1rem;gap:.75rem;justify-content:center;min-width:200px;outline:none;padding:1rem 2rem;position:relative;transition:all .3s ease}.toggleButton.open{background:linear-gradient(135deg,#4caf50,#45a049);color:#fff}.toggleButton.closed{background:linear-gradient(135deg,#f44336,#e53935);color:#fff}.toggleButton:hover:not(.disabled){box-shadow:0 6px 20px #00000026;transform:translateY(-2px)}.toggleButton.disabled{background:#ccc;cursor:not-allowed;opacity:.6;transform:none}.toggleIndicator{background:#ffffffe6;border-radius:50%;box-shadow:0 2px 4px #0003;height:12px;transition:all .3s ease;width:12px}.toggleButton.open .toggleIndicator{background:#c8e6c9;box-shadow:0 0 8px #4caf5080}.toggleButton.closed .toggleIndicator{background:#ffcdd2;box-shadow:0 0 8px #f4433680}@media (max-width:600px){.controlsContainer,.errorMessage,.securityInfo,.statusContainer,.valveContainer{max-width:98vw;padding-left:.5rem;padding-right:.5rem}.valve-svg{max-width:98vw}.controlsContainer{flex-direction:column}.button,.toggleButton{min-width:auto;width:100%}}.alert-notification{background-color:#fff;border-left:4px solid #ccc;border-radius:8px;box-shadow:0 2px 4px #0000001a;margin:1rem 0;padding:1rem}.alert-notification.warning{background-color:#fff3e0;border-left-color:#ff9800}.alert-notification.info{background-color:#e3f2fd;border-left-color:#2196f3}.alert-notification.water{background-color:#e0f7fa;border-left-color:#00bcd4}.alert-notification.time{background-color:#f3e5f5;border-left-color:#9c27b0}.alert-header{align-items:center;display:flex;gap:.5rem;margin-bottom:.5rem}.alert-icon{font-size:1.5rem}.alert-icon.warning{color:#ff9800}.alert-icon.info{color:#2196f3}.alert-icon.water{color:#00bcd4}.alert-icon.time{color:#9c27b0}.alert-header h3{font-size:1.1rem;font-weight:600;margin:0}.alert-timestamp{color:#666;margin-left:auto}.alert-message{color:#333;line-height:1.4;margin:0}.alert-notification.new-alert{animation:newAlertGlow 2s ease-in-out infinite alternate;border-left-width:6px;box-shadow:0 4px 12px #f4433626}@keyframes newAlertGlow{0%{box-shadow:0 4px 12px #f4433626}to{box-shadow:0 4px 20px #f4433640}}.alert-notification.example-alert{border-left-width:4px;border-style:dashed;opacity:.8}.alert-notification.read-alert{background-color:#f9f9f9;border-left-color:#bbb;opacity:.7}.alert-notification.read-alert.info,.alert-notification.read-alert.time,.alert-notification.read-alert.warning,.alert-notification.read-alert.water{background-color:#f5f5f5}.example-badge,.new-badge,.read-badge{border-radius:4px;color:#fff;font-size:.6rem;font-weight:700;margin-right:.5rem;padding:.2rem .4rem}.new-badge{background-color:#f44336}.example-badge{background-color:#9e9e9e}.read-badge{background-color:#4caf50}.alert-actions{border-top:1px solid #e0e0e0;display:flex;justify-content:flex-end;margin-top:1rem;padding-top:.75rem}.mark-read-btn{align-items:center;background-color:#2196f3;border:none;border-radius:4px;color:#fff;cursor:pointer;display:flex;font-size:.8rem;gap:.3rem;padding:.5rem 1rem;transition:background-color .3s ease,transform .1s ease}.mark-read-btn:hover{background-color:#1976d2;transform:translateY(-1px)}.mark-read-btn:active{transform:translateY(0)}.active-alerts-container{margin:20px 0;width:100%}.alerts-header{margin-bottom:15px}.alerts-header h3{color:var(--text-primary);font-size:1.2rem;font-weight:600;margin:0}.alerts-loading{color:var(--text-secondary);padding:20px;text-align:center}.alerts-list{gap:12px}.alert-card{align-items:flex-start;background:var(--bg-card);border-left:4px solid;border-radius:8px;box-shadow:0 2px 8px #0000001a;display:flex;padding:15px;transition:transform .2s,box-shadow .2s}.alert-card:hover{box-shadow:0 4px 12px #00000026;transform:translateY(-2px)}.alert-critical{background:#ff44440d;border-left-color:#f44}.alert-warning{background:#ffaa000d;border-left-color:#fa0}.alert-info{background:#4488ff0d;border-left-color:#48f}.alert-icon{align-items:center;display:flex;flex-shrink:0;justify-content:center;margin-right:12px}.alert-content{flex:1 1;min-width:0}.alert-title{color:var(--text-primary);font-size:.95rem;font-weight:600;margin-bottom:6px;text-transform:capitalize}.alert-message{color:var(--text-secondary);font-size:.9rem;line-height:1.5;margin-bottom:8px}.alert-recommendation{background:#7eac971a;border-left:3px solid var(--accent-main);border-radius:6px;color:var(--text-primary);font-size:.85rem;margin-bottom:8px;padding:10px}.alert-timestamp{color:var(--text-muted);font-size:.8rem;font-style:italic}.alert-close-btn{align-items:center;background:#0000;border:none;border-radius:4px;color:var(--text-secondary);cursor:pointer;display:flex;flex-shrink:0;justify-content:center;margin-left:8px;padding:4px;transition:color .2s,background .2s}.alert-close-btn:hover{background:#0000000d;color:var(--error-color)}@media (max-width:768px){.alert-card{padding:12px}.alert-title{font-size:.9rem}.alert-message{font-size:.85rem}.alert-recommendation{font-size:.8rem;padding:8px}}.alerts-container{margin:0 auto;max-width:1200px;padding:2rem}.alerts-header{align-items:center;display:flex;flex-wrap:wrap;gap:1rem;justify-content:space-between;margin-bottom:2rem}.alerts-container h1{color:#333;font-size:1.8rem;margin:0}.mark-all-read-btn{align-items:center;background-color:#4caf50;border:none;border-radius:6px;box-shadow:0 2px 4px #4caf5033;color:#fff;cursor:pointer;display:flex;font-size:.9rem;font-weight:500;gap:.5rem;padding:.75rem 1.5rem;transition:background-color .3s ease,transform .1s ease}.mark-all-read-btn:hover{background-color:#45a049;box-shadow:0 4px 8px #4caf504d;transform:translateY(-1px)}.mark-all-read-btn:active{transform:translateY(0)}.alerts-section{margin-bottom:3rem}.section-title{border-bottom:2px solid #e0e0e0;color:#333;font-size:1.3rem;margin-bottom:1.5rem;padding-bottom:.5rem}.new-alerts-title{border-bottom-color:#f44336;color:#f44336}.examples-title{border-bottom-color:#ccc;color:#666}.examples-section{background-color:#fafafa;border:1px solid #e0e0e0;border-radius:8px;padding:1.5rem}.alerts-list{display:flex;flex-direction:column;gap:1rem}@media (min-width:768px){.alerts-list{grid-gap:2rem;display:grid;gap:2rem;grid-template-columns:1fr 1fr}}@media (min-width:1200px){.alerts-list{gap:2.5rem;grid-template-columns:1fr 1fr 1fr}}@media (max-width:768px){.alerts-container{padding:1rem}.alerts-header{align-items:stretch;flex-direction:column;text-align:center}.alerts-container h1{font-size:1.5rem}.mark-all-read-btn{align-self:center;width:fit-content}}.user-info-card{align-items:flex-start;background:#fff;border-radius:10px;box-shadow:0 2px 4px #0000001a;display:flex;gap:2rem;padding:2rem}.user-avatar{align-items:center;background:#f0f0f0;border-radius:50%;display:flex;height:100px;justify-content:center;width:100px}.avatar-icon{color:#666;font-size:3rem}.user-details{flex:1 1}.user-details h2{color:#333;margin:0 0 1rem}.info-item{align-items:center;color:#666;display:flex;gap:.5rem;margin-bottom:.5rem}.info-icon{color:#2196f3}@media (max-width:768px){.user-info-card{align-items:center;flex-direction:column;text-align:center}.info-item{justify-content:center}}.user-stats{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));margin:2rem 0}.stat-card{align-items:center;background:#fff;border-radius:10px;box-shadow:0 2px 4px #0000001a;display:flex;gap:1rem;padding:1.5rem;transition:transform .2s}.stat-card:hover{transform:translateY(-5px)}.stat-icon{align-items:center;background:#e3f2fd;border-radius:10px;color:#2196f3;display:flex;font-size:1.5rem;height:50px;justify-content:center;width:50px}.stat-info h3{color:#666;font-size:.9rem;margin:0}.stat-info p{color:#333;font-size:1.5rem;font-weight:600;margin:.5rem 0 0}@media (max-width:768px){.user-stats{grid-template-columns:1fr}}.data-period-info{background:#fff;border-radius:var(--radius);box-shadow:0 2px 8px #0000001a;margin-bottom:1.5rem;padding:1.5rem}.data-period-info h3{color:var(--text-primary);font-size:1.1rem;margin-bottom:1rem}.period-details{display:flex;flex-direction:column;gap:.5rem}.period-dates,.period-text{margin:0}.loading-period{color:var(--text-secondary)}.loading-period p{font-style:italic;margin:0}@media (max-width:600px){.data-period-info{padding:1rem}}.profile-container{background:var(--bg-card);border-radius:var(--radius);box-shadow:0 4px 24px #00000012;color:var(--text-primary);margin:2rem auto;max-width:1024px;padding:2rem;width:90%}.profile-container h1{color:var(--text-primary);margin-bottom:2rem}.settings-section{border-top:1px solid var(--border-color);margin-top:3rem;padding-top:2rem}.settings-section h2{color:var(--text-primary);margin-bottom:1.5rem}.household-section{background:#fff;border-radius:var(--radius);box-shadow:0 2px 8px #0000001a;padding:2rem}.household-section h3{color:var(--text-primary);margin-bottom:1.5rem}.household-input{margin-bottom:1.5rem}.household-input label{color:var(--text-secondary);display:block;margin-bottom:.5rem}.household-input input,.household-input select{background:var(--bg-input);border:1px solid var(--border-color);border-radius:var(--radius);color:var(--text-primary);font-size:1rem;padding:.75rem;transition:border-color .3s ease;width:100%}.household-input input:focus,.household-input select:focus{border-color:var(--accent-main);outline:none}.unit-select{-webkit-appearance:none;appearance:none;background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='currentColor' 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 1rem center;background-repeat:no-repeat;background-size:1em;padding-right:2.5rem}.household-info{background:var(--bg-info);border-radius:var(--radius);color:var(--text-secondary);font-size:.9rem;line-height:1.5;margin-top:1rem;padding:1rem}.reports-section{border-top:1px solid var(--border-color);margin-top:3rem;padding-top:2rem}.reports-section h2{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,var(--accent-main),var(--accent-light));-webkit-background-clip:text;background-clip:text;color:var(--text-primary);margin-bottom:1.5rem}.report-download-section{background:#fff;border-radius:var(--radius);box-shadow:0 2px 8px #0000001a;padding:2rem}.report-download-section h3{color:var(--text-primary);font-size:1.4rem;font-weight:600;margin-bottom:.5rem}.report-download-section p{color:var(--text-secondary);font-size:1.1rem;margin-bottom:1.5rem}.report-controls{display:flex;justify-content:flex-start;margin-bottom:2rem}.generate-report-btn{align-items:center;background:var(--accent-main);border:none;border-radius:12px;box-shadow:0 4px 12px #3b82f64d;color:#fff;cursor:pointer;display:flex;font-size:1rem;font-weight:600;gap:12px;padding:14px 28px;transition:all .3s ease}.generate-report-btn:hover:not(:disabled){box-shadow:0 6px 20px #3b82f666;transform:translateY(-2px)}.generate-report-btn:active:not(:disabled){transform:translateY(0)}.generate-report-btn:disabled{cursor:not-allowed;opacity:.7;transform:none}.loading-spinner{animation:spin 1s linear infinite;border:2px solid #0000;border-radius:50%;border-top-color:currentcolor;height:16px;width:16px}.pdf-icon{font-size:1.2rem}@keyframes spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.period-info{max-width:400px}.period-details{background:var(--bg-card);border:1px solid var(--border-color);border-radius:8px;padding:16px}.period-badge{border-radius:20px;display:inline-block;font-size:.8rem;font-weight:600;letter-spacing:.5px;margin-bottom:12px;padding:4px 12px;text-transform:uppercase}.period-badge.real{background:linear-gradient(135deg,#10b981,#34d399);color:#fff}.period-badge.simulated{background:linear-gradient(135deg,#f59e0b,#fbbf24);color:#fff}.period-text{color:var(--text-primary);font-size:1rem;margin-bottom:8px}.period-dates{color:var(--text-secondary);font-family:monospace;font-size:.9rem;margin-bottom:8px}.data-points{color:var(--accent-main);font-size:.85rem;font-weight:600;margin-bottom:0}.period-note{color:var(--text-secondary);font-size:.9rem;font-style:italic;margin-bottom:0}.report-preview{background:#fff;padding:40px;width:210mm}.charts-container{display:flex;flex-direction:column;gap:30px}.chart-section{background:#fff;border-radius:8px;box-shadow:0 2px 8px #0000001a;padding:20px}.chart-section h3{color:#1f2937;font-size:1.4rem;font-weight:600;margin-bottom:16px;text-align:center}.user-session-section{background:#fff;border:2px solid #f8f9fa;border-radius:12px;box-shadow:0 2px 8px #0000001a;margin-top:2rem;padding:2rem}.user-session-section h2{color:#333;font-size:1.3rem;font-weight:600;margin-bottom:1.5rem}.current-user-info{align-items:center;background:linear-gradient(135deg,#f8f9fa,#e9ecef);border:1px solid #dee2e6;border-radius:10px;display:flex;justify-content:space-between;margin-bottom:1rem;padding:1.5rem}.user-details{align-items:center;display:flex;gap:1rem}.user-avatar-icon{background:#fff;border-radius:50%;box-shadow:0 2px 8px #667eea33;color:#667eea;font-size:3rem!important;padding:.5rem}.user-text-info h3{color:#333;font-size:1.2rem;font-weight:600;margin:0 0 .25rem}.user-email{color:#666;font-size:.9rem;margin:0 0 .25rem}.user-role{background:#fff;border:1px solid #e9ecef;border-radius:15px;color:#495057;display:inline-block;font-size:.85rem;font-weight:500;margin:0;padding:.25rem .75rem}.logout-button,.session-actions{align-items:center;display:flex}.logout-button{background:#0000;border:1px solid #dee2e6;border-radius:6px;color:#6c757d;cursor:pointer;font-size:.9rem;font-weight:400;gap:.5rem;padding:.5rem 1rem;transition:all .2s ease}.logout-button:hover{background:#f8f9fa;border-color:#adb5bd;color:#495057}.logout-button svg{font-size:1rem!important}.session-info{background:#fff3cd;border:1px solid #ffeaa7;border-radius:8px;margin-top:1rem;padding:1rem}.session-note{color:#856404;font-size:.9rem;line-height:1.4;margin:0}@media (max-width:600px){.profile-container{padding:1rem}.household-section,.report-download-section{padding:1.5rem}.generate-report-btn{justify-content:center;width:100%}.period-info{max-width:none}.current-user-info{gap:1rem}.current-user-info,.user-details{flex-direction:column;text-align:center}.user-session-section{padding:1.5rem}}.recommendation-card{background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000001a;display:flex;gap:16px;padding:20px;transition:transform .2s ease}.recommendation-card:hover{transform:translateY(-2px)}.recommendation-icon{align-items:center;color:#2196f3;display:flex;font-size:24px;justify-content:center}.recommendation-content{flex:1 1}.recommendation-content h3{color:#333;font-size:1.1rem;margin:0 0 8px}.recommendation-content p{color:#666;font-size:.9rem;line-height:1.4;margin:0 0 12px}.recommendation-impact{background:#e3f2fd;border-radius:4px;color:#1976d2;display:inline-block;font-size:.8rem;padding:4px 8px}.recommendation-category{color:#666;font-size:.8rem;margin-top:8px}.recommendations-container{margin:0 auto;max-width:1200px;padding:2rem}.recommendations-container h1{color:#333;font-size:2rem;margin-bottom:1rem}.user-metrics-summary{background:#f5f9ff;border:1px solid #e3f2fd;border-radius:12px;margin-bottom:2rem;padding:1.5rem}.user-metrics-summary h2{color:#1976d2;font-size:1.3rem;margin:0 0 .5rem}.user-metrics-summary p{color:#666;font-size:1.1rem;margin:0}.recommendations-intro{color:#666;font-size:1.1rem;line-height:1.5;margin-bottom:2rem}.recommendations-grid{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));margin-top:2rem}@media (max-width:768px){.recommendations-container{padding:1rem}.recommendations-grid{grid-template-columns:1fr}.user-metrics-summary{padding:1rem}}.login-container{align-items:center;background:#dde3e8;display:flex;justify-content:center;min-height:100vh;padding:20px}.login-card{animation:slideUp .4s ease-out;background:#fff;border:1px solid #bfcad1;border-radius:20px;box-shadow:0 8px 32px #2d5b4e26;max-width:420px;padding:40px;width:100%}.login-header{margin-bottom:30px;text-align:center}.login-header h1{color:#2d5b4e;font-size:32px;font-weight:700;margin:10px 0 5px}.login-header p{color:#7eac97;font-size:16px;font-weight:500;margin:0}.login-form{display:flex;flex-direction:column;gap:20px}.form-group{gap:8px}.success-message{background-color:#e8f5e8;font-size:14px;padding:12px 16px}.login-footer{margin-top:20px;text-align:center}.login-footer p{color:#2d5b4e;font-size:14px;margin:10px 0}.login-footer a{color:#7eac97;font-weight:600;text-decoration:none;transition:color .3s ease}.login-footer a:hover{color:#2d5b4e;text-decoration:underline}@media (max-width:480px){.login-card{padding:30px 20px}.login-header h1{font-size:28px}.logo-image{height:60px;width:60px}}.register-container{align-items:center;background:#dde3e8;display:flex;justify-content:center;min-height:100vh;padding:20px}.register-card{animation:slideUp .4s ease-out;background:#fff;border:1px solid #bfcad1;border-radius:20px;box-shadow:0 8px 32px #2d5b4e26;max-width:450px;padding:40px;width:100%}.register-header{margin-bottom:30px;text-align:center}.register-header h1{color:#2d5b4e;font-size:32px;font-weight:700;margin:10px 0 5px}.register-header p{color:#7eac97;font-size:16px;font-weight:500;margin:0}.register-form{display:flex;flex-direction:column;gap:18px}.form-group{gap:6px}.form-group label{font-size:14px}.form-group input{background:#f0f0f0;border:2px solid #bfcad1;border-radius:12px;font-family:inherit;font-size:16px;padding:12px 16px;transition:all .3s ease}.form-group input:focus{background:#fff;border-color:#7eac97;box-shadow:0 0 0 3px #7eac9733;outline:none}.form-group input:disabled{background-color:#dde3e8;cursor:not-allowed;opacity:.7}.form-hint{color:#7eac97;font-size:12px;font-weight:500;margin-top:-2px}.error-message{background-color:#ffebee;font-size:14px;padding:12px 16px}.success-message{padding:20px}.success-icon{align-items:center;animation:scaleIn .5s ease-out;background:linear-gradient(135deg,#00c49f,#2d5b4e);border-radius:50%;color:#fff;display:flex;font-size:48px;height:80px;justify-content:center;margin:0 auto 20px;width:80px}@keyframes scaleIn{0%{transform:scale(0)}to{transform:scale(1)}}.success-message h2{color:#2d5b4e;font-size:24px;margin:0 0 10px}.success-message p{color:#7eac97;margin:5px 0}.redirect-text{color:#7eac97!important;font-weight:600;margin-top:15px!important}.btn-primary{box-shadow:0 4px 16px #7eac974d;font-size:16px;padding:14px 24px}.btn-primary:hover:not(:disabled){box-shadow:0 6px 20px #7eac9766}.btn-primary:active:not(:disabled){transform:translateY(0)}.register-footer{margin-top:15px;text-align:center}.register-footer p{color:#2d5b4e;font-size:14px;margin:10px 0}.register-footer a{color:#7eac97;font-weight:600;text-decoration:none;transition:color .3s ease}.register-footer a:hover{color:#2d5b4e;text-decoration:underline}@media (max-width:480px){.register-card{padding:30px 20px}.register-header h1{font-size:28px}.logo-image{height:60px;width:60px}}.password-requirements{background:#f8f9fa;border:1px solid #e9ecef;border-radius:10px}.password-requirements h4{color:#495057}.password-requirements li{color:#6c757d}.password-requirements li:before{color:#dc3545}.password-requirements li.valid,.password-requirements li.valid:before{color:#28a745}.new-password-container{align-items:center;background:#dde3e8;display:flex;justify-content:center;min-height:100vh;padding:20px}.new-password-card{animation:slideUp .6s ease-out;background:#fff;border:1px solid #bfcad1;border-radius:20px;box-shadow:0 8px 32px #2d5b4e26;max-width:500px;padding:40px;width:100%}.new-password-header{margin-bottom:30px;text-align:center}.logo-image{height:80px;width:80px}.new-password-header h1{color:#2d5b4e;font-size:1.8rem;font-weight:700;margin:0 0 10px}.new-password-header p{color:#7eac97;font-size:1rem;font-weight:500;margin:0 0 15px}.user-info{background:#f0f0f0;border:1px solid #bfcad1;border-radius:12px;padding:12px 16px}.user-info span{color:#2d5b4e;font-size:.9rem;font-weight:600}.new-password-form{display:flex;flex-direction:column;gap:20px}.password-input-container{align-items:center;display:flex;position:relative}.password-input-container input{background:#f0f0f0;border:2px solid #bfcad1;border-radius:12px;font-size:1rem;padding:12px 45px 12px 15px;transition:all .3s ease;width:100%}.password-input-container input:focus{background:#fff;border-color:#7eac97;box-shadow:0 0 0 3px #7eac9733;outline:none}.password-input-container input:disabled{background-color:#dde3e8;cursor:not-allowed;opacity:.7}.password-toggle{align-items:center;background:none;border:none;color:#666;cursor:pointer;display:flex;justify-content:center;padding:5px;position:absolute;right:12px;transition:color .3s ease}.password-toggle:hover{color:#7eac97}.password-toggle:disabled{cursor:not-allowed;opacity:.5}.password-requirements{background:#f0f0f0;border:1px solid #bfcad1;border-radius:12px;padding:15px}.password-requirements h4{color:#2d5b4e;font-size:.9rem;font-weight:600;margin:0 0 10px}.password-requirements ul{list-style:none;margin:0;padding-left:20px}.password-requirements li{color:#7eac97;font-size:.85rem;margin:5px 0;padding-left:20px;position:relative}.password-requirements li:before{color:#ff4d4f;content:"✗";font-weight:700;left:0;position:absolute}.password-requirements li.valid{color:#00c49f}.password-requirements li.valid:before{color:#00c49f;content:"✓"}.button-group{display:flex;gap:15px;margin-top:10px}.btn-primary,.btn-secondary{border:none;border-radius:10px;cursor:pointer;flex:1 1;font-size:1rem;font-weight:500;padding:12px 20px;text-align:center;transition:all .3s ease}.btn-secondary{background:#f0f0f0;border:2px solid #bfcad1;color:#2d5b4e}.btn-secondary:hover:not(:disabled){background:#dde3e8;border-color:#7eac97;color:#2d5b4e}.btn-secondary:disabled{cursor:not-allowed;opacity:.6}@media (max-width:768px){.new-password-container{padding:15px}.new-password-card{padding:30px 25px}.new-password-header h1{font-size:1.5rem}.button-group{flex-direction:column}.btn-primary,.btn-secondary{flex:none}}@media (max-width:480px){.new-password-card{padding:25px 20px}.new-password-header h1{font-size:1.3rem}.password-requirements{padding:12px}.password-requirements li{font-size:.8rem}}.confirm-email-container{align-items:center;background:#dde3e8;display:flex;justify-content:center;min-height:100vh;padding:20px}.confirm-email-card{animation:slideUp .6s ease-out;background:#fff;border:1px solid #bfcad1;border-radius:20px;box-shadow:0 8px 32px #2d5b4e26;max-width:500px;padding:40px;width:100%}@keyframes slideUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.confirm-email-header{margin-bottom:30px;text-align:center}.logo-container{align-items:center;display:flex;gap:15px;justify-content:center}.logo-image{border-radius:50%;box-shadow:0 4px 16px #2d5b4e33;height:70px;object-fit:cover;width:70px}.email-icon{animation:bounce 2s infinite;color:#00c49f;font-size:2rem!important}@keyframes bounce{0%,20%,50%,80%,to{transform:translateY(0)}40%{transform:translateY(-10px)}60%{transform:translateY(-5px)}}.confirm-email-header h1{color:#2d5b4e;font-size:1.8rem;font-weight:700;margin:0 0 15px}.confirm-email-header p{color:#7eac97;font-size:1rem;font-weight:500;margin:0 0 10px}.confirm-email-header .instruction{color:#2d5b4e;font-size:.9rem;font-weight:500;margin-top:15px}.email-info{background:#f0f0f0;border:1px solid #bfcad1;border-radius:12px;margin:15px 0;padding:12px 16px}.email-info span{color:#2d5b4e;font-size:1rem;font-weight:600}.confirm-email-form{gap:20px}.confirm-email-form,.form-group{display:flex;flex-direction:column}.form-group label{color:#2d5b4e;font-size:.9rem;font-weight:600;margin-bottom:8px}.verification-input{background:#f0f0f0;border:2px solid #bfcad1;border-radius:12px;font-size:1.5rem;font-weight:600;letter-spacing:.5em;padding:15px;text-align:center;transition:all .3s ease;width:100%}.verification-input:focus{background:#fff;border-color:#7eac97;box-shadow:0 0 0 3px #7eac9733;outline:none}.verification-input:disabled{background-color:#dde3e8;cursor:not-allowed;opacity:.7}.verification-input::placeholder{color:#7eac97;font-weight:400}.error-message{background:#ffebee;border:1px solid #ffcdd2;border-left:4px solid #ff4d4f;border-radius:12px;color:#c62828}.error-message,.success-message{font-size:.9rem;padding:12px 15px;text-align:center}.success-message{background:#e8f5e8;border:1px solid #c8e6c9;border-left:4px solid #00c49f;border-radius:12px;color:#2d5b4e}.btn-primary{background:linear-gradient(135deg,#7eac97,#2d5b4e);border:none;border-radius:12px;color:#fff;cursor:pointer;font-size:1rem;font-weight:600;padding:15px 20px;transition:all .3s ease;width:100%}.btn-primary:hover:not(:disabled){background:linear-gradient(135deg,#2d5b4e,#7eac97);box-shadow:0 8px 25px #7eac9766;transform:translateY(-2px)}.btn-primary:disabled{background:#bfcad1;box-shadow:none;cursor:not-allowed;opacity:.6;transform:none}.resend-section{border-bottom:1px solid #bfcad1;border-top:1px solid #bfcad1;padding:20px 0;text-align:center}.resend-section p{color:#7eac97;margin:0 0 15px}.btn-resend,.resend-section p{font-size:.9rem;font-weight:500}.btn-resend{align-items:center;background:#f0f0f0;border:2px solid #bfcad1;border-radius:12px;color:#2d5b4e;cursor:pointer;display:inline-flex;gap:8px;padding:10px 20px;transition:all .3s ease}.btn-resend:hover:not(:disabled){background:#dde3e8;border-color:#7eac97;color:#2d5b4e}.btn-resend:disabled{cursor:not-allowed;opacity:.6}.resend-icon{font-size:1rem!important}.back-section{margin-top:10px;text-align:center}.btn-back{background:none;border:none;color:#7eac97;cursor:pointer;font-size:.9rem;font-weight:500;padding:10px 15px;text-decoration:underline;transition:color .3s ease}.btn-back:hover:not(:disabled){color:#2d5b4e}.btn-back:disabled{cursor:not-allowed;opacity:.6}.help-section{background:#f0f0f0;border:1px solid #bfcad1;border-radius:12px;margin-top:30px;padding:20px}.help-section h4{color:#2d5b4e;font-size:1rem;font-weight:600;margin:0 0 15px}.help-section ul{color:#7eac97;margin:0;padding-left:20px}.help-section li{font-size:.85rem;font-weight:500;line-height:1.4;margin:8px 0}@media (max-width:768px){.confirm-email-container{padding:15px}.confirm-email-card{padding:30px 25px}.confirm-email-header h1{font-size:1.5rem}.verification-input{font-size:1.3rem;padding:12px}}@media (max-width:480px){.confirm-email-card{padding:25px 20px}.confirm-email-header h1{font-size:1.3rem}.verification-input{font-size:1.2rem;letter-spacing:.3em}.help-section{padding:15px}.help-section li{font-size:.8rem}}
/*# sourceMappingURL=main.0ce961ea.css.map*/