@import url(https://cdnjs.cloudflare.com/ajax/libs/font-awesome/6.4.0/css/all.min.css);@import url(https://fonts.googleapis.com/css2?family=Inter:wght@300;400;600;700&display=swap);: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{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;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}.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}.trend-summary{align-items:center;border-radius:var(--radius);display:flex;font-size:.9rem;font-weight:500;gap:.5rem;margin-bottom:1rem;padding:.75rem 1rem}.trend-summary.increasing{background:#f443361a;border:1px solid #f443364d;color:var(--error-color)}.trend-summary.decreasing{background:#4caf501a;border:1px solid #4caf504d;color:var(--success-color)}.months-legend{background:var(--bg-page);border-radius:var(--radius);display:flex;flex-wrap:wrap;gap:1rem;justify-content:center;margin-top:1rem;padding:.75rem}.legend-item{color:var(--text-secondary);font-size:.85rem}.legend-color{border-radius:3px;height:12px;width:12px}.legend-text{font-weight:500}.prediction-main{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:1fr 1fr}.predicted-consumption{align-items:center;background:var(--bg-card);border:2px solid var(--success-color);border-radius:var(--radius);display:flex;flex-direction:column;padding:1rem}.consumption-amount{color:var(--success-color);font-size:1.5rem;font-weight:700;line-height:1}.consumption-label{color:var(--text-secondary);font-size:.85rem;margin-top:.25rem}.detail-row{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:1fr 1fr}.custom-tooltip .value{color:var(--text-primary);font-size:1rem;font-weight:600;margin:.25rem 0}.custom-tooltip .cost{font-size:.9rem;font-weight:500;margin:0}@media (max-width:600px){.detail-row,.prediction-main{grid-template-columns:1fr}.detail-row{gap:.5rem}.months-legend{align-items:flex-start;flex-direction:column;gap:.5rem}}@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{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}}.container{align-items:center;background-color:var(--bg-page);display:flex;flex-direction:column;min-height:100%;padding:0 1rem}.title{color:var(--text-primary);margin-bottom:1rem}.connection-status{align-items:center;background:var(--bg-card);border-radius:2rem;box-shadow:0 2px 8px #00000014;display:flex;font-size:.9rem;gap:.5rem;margin-bottom:1rem;padding:.5rem 1rem}.connection-status .status-dot{border-radius:50%;height:10px;transition:background-color .3s;width:10px}.connection-status.connected .status-dot{background-color:#4caf50;box-shadow:0 0 8px #4caf5080}.connection-status.error .status-dot{background-color:#f44336;box-shadow:0 0 8px #f4433680}.connection-status.disconnected .status-dot{background-color:#ff9800;box-shadow:0 0 8px #ff980080}.connection-status .status-text{color:var(--text-secondary);font-weight:500}.connection-status .last-update{color:var(--text-secondary);font-size:.8rem;opacity:.8}.warning-banner{background:#fff3e0;border-left:4px solid #ff9800;color:#e65100;font-size:.9rem;margin-bottom:1rem;padding:.75rem 1rem;text-align:center}.valveContainer,.warning-banner{border-radius:var(--radius);max-width:400px;width:100%}.valveContainer{align-items:center;background:var(--bg-card);box-shadow:0 4px 24px #0000001a;display:flex;flex-direction:column;margin:0 0 1.5rem;padding:1.5rem}.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;transition:filter .3s;width:100%}.valve-svg.animating{filter:drop-shadow(0 0 10px rgba(255,152,0,.5))}.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{font-size:1.4rem;font-weight:700;transition:color .3s}.flowInfo{color:var(--accent-main);font-size:.9rem;font-weight:500;margin-top:.5rem}.error-message{border-left:4px solid #f44336;border-radius:var(--radius);margin-bottom:1rem;max-width:400px;padding:.75rem 1rem;width:100%}.controlsContainer{align-items:center;display:flex;flex-direction:column;margin-bottom:2rem;max-width:400px}.button-group,.controlsContainer{gap:1rem;width:100%}.valve-button{align-items:center;border:2px solid #0000;border-radius:var(--radius);cursor:pointer;display:flex;flex:1 1;flex-direction:column;font-size:.9rem;font-weight:600;gap:.5rem;justify-content:center;min-height:80px;outline:none;padding:1rem;transition:all .3s ease}.valve-button.open{background:linear-gradient(135deg,#4caf501a,#4caf500d);border-color:#4caf50;color:#4caf50}.valve-button.open:hover:not(:disabled){background:linear-gradient(135deg,#4caf50,#45a049);box-shadow:0 4px 16px #4caf504d;color:#fff;transform:translateY(-2px)}.valve-button.open.active{background:linear-gradient(135deg,#4caf50,#45a049);box-shadow:0 0 16px #4caf5066;color:#fff}.valve-button.close{background:linear-gradient(135deg,#f443361a,#f443360d);border-color:#f44336;color:#f44336}.valve-button.close:hover:not(:disabled){background:linear-gradient(135deg,#f44336,#e53935);box-shadow:0 4px 16px #f443364d;color:#fff;transform:translateY(-2px)}.valve-button.close.active{background:linear-gradient(135deg,#f44336,#e53935);box-shadow:0 0 16px #f4433666;color:#fff}.valve-button:disabled{box-shadow:none!important;cursor:not-allowed;opacity:.5;transform:none!important}.valve-button .button-icon{font-size:1.5rem}.valve-button .button-text{font-size:.85rem}.toggleButton{align-items:center;border:none;border-radius:2rem;box-shadow:0 4px 16px #0000001a;cursor:pointer;display:flex;font-size:1rem;font-weight:600;gap:.75rem;justify-content:center;outline:none;padding:1rem 2rem;position:relative;transition:all .3s ease;width:100%}.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}.buttonText{font-size:1rem;font-weight:600}.info-section{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius);margin-top:1rem;max-width:400px;padding:1.5rem;width:100%}.info-section h3{color:var(--text-primary);font-size:1rem;margin:0 0 1rem}.info-section ul{color:var(--text-secondary);font-size:.9rem;line-height:1.8;margin:0;padding-left:1.5rem}.info-section li{margin-bottom:.5rem}.info-section code{background:var(--bg-page);border-radius:4px;color:var(--accent-main);font-size:.85rem;padding:.2rem .4rem}@media (max-width:600px){.container{padding:0 .5rem}.controlsContainer,.error-message,.info-section,.statusContainer,.valveContainer,.warning-banner{max-width:98vw}.valve-svg{max-width:100%}.button-group{flex-direction:column}.valve-button{flex-direction:row;min-height:auto;padding:.75rem 1rem}.valve-button .button-icon{font-size:1.2rem}.toggleButton{font-size:.9rem;padding:.75rem 1.5rem}}.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;border-radius:10px;box-shadow:0 2px 4px #0000001a;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}}.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}.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}}.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{border:2px solid #0000;border-top-color:currentcolor;height:16px;width:16px}.pdf-icon{font-size:1.2rem}.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}}.daily-consumption-card{animation:fadeInSlide .3s ease-out;background:#f8faf9;border:1px solid #e8ede9;border-radius:16px;box-sizing:border-box;cursor:pointer;display:flex;flex-direction:column;flex-shrink:0;gap:0;min-width:0;padding:1.5rem;transition:all .3s ease;width:100%}.daily-consumption-card:hover{background:#fff;border-color:#a8d5a3;box-shadow:0 2px 8px #4caf501a;transform:translateY(-1px)}.daily-consumption-card.selected{background:#fff;border-color:#4caf50;border-width:2px;box-shadow:0 4px 16px #4caf5026}.card-header{align-items:flex-start;display:flex;justify-content:space-between;margin-bottom:0}.card-date{display:flex;flex-direction:column}.date-label{color:#2d3748;font-size:1rem;font-weight:600;margin-bottom:.25rem;text-transform:capitalize}.date-value{color:#718096;font-size:.8rem;font-weight:400}.card-consumption{align-items:flex-end;display:flex;flex-direction:column;gap:.25rem}.card-icon{color:#4caf50;font-size:1.75rem!important;opacity:.9}.consumption-value{color:#2d3748;font-size:1.5rem;font-weight:700;margin-top:.25rem}.card-details{grid-gap:1rem;border-top:1px solid #e8ede9;display:grid;gap:1rem;grid-template-columns:1fr 1fr;margin-top:1rem;padding-top:1rem;width:100%}.detail-item{display:flex;flex-direction:column;gap:.3rem}.detail-icon{color:#66bb6a;font-size:1.1rem!important;margin-bottom:.25rem}.detail-content{display:flex;flex-direction:column}.detail-label{color:#718096;font-size:.75rem;font-weight:500;letter-spacing:.5px;text-transform:uppercase}.detail-value{color:#2d3748;font-size:.95rem;font-weight:600}.selected-indicator{border-top:1px solid #e8ede9;margin-top:1rem;padding-top:.75rem;text-align:right}.selected-indicator span{color:#4caf50;font-size:.8rem;font-weight:600}@keyframes fadeInSlide{0%{opacity:0;transform:translateX(-10px)}to{opacity:1;transform:translateX(0)}}@media (max-width:768px){.daily-consumption-card{padding:1rem}.card-header{flex-direction:column;gap:1rem}.card-consumption{align-items:center;flex-direction:row;justify-content:space-between;width:100%}.date-label{font-size:1rem}.consumption-value{font-size:1.25rem}.card-details{gap:.75rem}.detail-label{font-size:.7rem}.detail-value{font-size:.9rem}}.hourly-breakdown-chart{padding:1rem;width:100%}.chart-title{color:var(--text-primary);font-size:1rem;font-weight:600;margin:0 0 1.5rem;text-align:center}.custom-tooltip{background:#fff;border:1px solid #e8ede9;border-radius:12px;box-shadow:0 4px 16px #4caf5026;padding:1rem}.tooltip-label{color:#2d3748;font-size:.9rem;font-weight:600;margin:0 0 .5rem}.tooltip-value{color:#718096;font-size:.85rem;margin:.25rem 0 0}.tooltip-value strong{color:#4caf50;font-weight:600}.chart-legend{border-top:1px solid #e0e0e0;display:flex;flex-wrap:wrap;gap:1rem;justify-content:center;margin-top:1.5rem;padding-top:1rem}.legend-item{align-items:center;display:flex;font-size:.875rem;gap:.5rem}.legend-color{border-radius:4px;display:inline-block;height:20px;width:20px}.legend-label{color:var(--text-secondary)}@media (max-width:768px){.hourly-breakdown-chart{padding:.5rem}.chart-title{font-size:.9rem}.chart-legend{align-items:flex-start;flex-direction:column;gap:.5rem}.legend-item{font-size:.8rem}.legend-color{height:16px;width:16px}}main{padding:2rem}.history-header{display:flex;flex-direction:column;gap:1.5rem;margin-bottom:2rem}.date-range-selector{align-items:center;display:flex;gap:1rem}.date-range-selector label{color:var(--text-primary);font-weight:600}.date-range-select{background-color:#fff;border:1px solid #e8ede9;border-radius:12px;color:#2d3748;cursor:pointer;font-size:.95rem;font-weight:500;padding:.625rem 1rem;transition:all .3s}.date-range-select:hover{border-color:#a8d5a3;box-shadow:0 2px 8px #4caf5014}.date-range-select:focus{border-color:#4caf50;box-shadow:0 0 0 3px #4caf501a;outline:none}.date-range-select:disabled{cursor:not-allowed;opacity:.6}.loading-indicator{animation:pulse 1.5s ease-in-out infinite;color:#4caf50;font-size:.9rem;font-weight:500}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.range-warning{background-color:#fff3e0;border-left:3px solid #ff9800;border-radius:6px;color:#ff9800;font-size:.85rem;font-weight:500;padding:.25rem .5rem}.history-stats{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}.stat-card{align-items:flex-start;background:#fff;border:1px solid #e8ede9;border-radius:16px;box-shadow:0 2px 8px #4caf5014;display:flex;flex-direction:column;gap:.75rem;padding:1.75rem;transition:all .3s ease}.stat-card:hover{box-shadow:0 4px 12px #4caf501f;transform:translateY(-2px)}.stat-icon{background:#e8f5e9;border-radius:12px;color:#4caf50;font-size:2.5rem!important;opacity:.85;padding:.75rem}.stat-content{display:flex;flex-direction:column;width:100%}.stat-label{color:#718096;font-size:.75rem;font-weight:500;letter-spacing:.5px;margin-bottom:.5rem;text-transform:uppercase}.stat-value{color:#2d3748;font-size:1.75rem;font-weight:700}.history-content{grid-gap:2rem;align-items:start;display:grid;gap:2rem;grid-template-columns:1fr 2fr;margin-top:2rem;width:100%}.daily-list-container,.hourly-breakdown-container{background:#fff;border:1px solid #e8ede9;border-radius:16px;box-shadow:0 2px 8px #4caf500f;box-sizing:border-box;min-width:0;padding:1.75rem;width:100%}.section-title{color:#2d3748;font-size:1.1rem;font-size:.9rem;font-weight:600;letter-spacing:.5px;margin:0 0 1.5rem;text-transform:uppercase}.daily-list{display:flex;flex-direction:column;gap:.75rem;max-height:80vh;overflow-y:auto;padding-right:.5rem;width:100%}.daily-list>*{width:100%}.daily-list::-webkit-scrollbar{width:6px}.daily-list::-webkit-scrollbar-track{background:#f1f1f1;border-radius:10px}.daily-list::-webkit-scrollbar-thumb{background:#66bb6a;border-radius:10px}.daily-list::-webkit-scrollbar-thumb:hover{background:#4caf50}.no-data-message{align-items:center;color:var(--text-secondary);display:flex;flex-direction:column;justify-content:center;padding:3rem;text-align:center}.hourly-table-container{margin-top:2rem;overflow-x:auto}.hourly-table{border-collapse:collapse;font-size:.9rem;width:100%}.hourly-table thead{background:#f0f7f0;color:#2d3748}.hourly-table th{color:#4a5568;font-size:.8rem;font-weight:600;letter-spacing:.5px;padding:1rem;text-align:left;text-transform:uppercase}.hourly-table tbody tr{border-bottom:1px solid #e8ede9;transition:background-color .2s}.hourly-table tbody tr:hover{background-color:#f8faf9}.hourly-table td{color:#4a5568;padding:.875rem 1rem}.hourly-table td strong{color:#2d3748;font-weight:600}.error-container,.loading-container{align-items:center;display:flex;flex-direction:column;justify-content:center;padding:4rem 2rem;text-align:center}.loading-spinner{animation:spin 1s linear infinite;border:4px solid #f3f3f3;border-radius:50%;border-top:4px solid var(--primary-color);height:50px;margin-bottom:1rem;width:50px}@keyframes spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.error-message{color:var(--error-color);font-size:1.1rem;margin:0}@media (max-width:1200px){main{padding:1.5rem}.history-content{grid-template-columns:1fr}.daily-list{max-height:70vh}}@media (max-width:768px){main{padding:1rem}.history-header{gap:1rem}.history-stats{grid-template-columns:1fr}.stat-card{padding:1rem}.stat-icon{font-size:2rem!important}.stat-value{font-size:1.25rem}.date-range-selector{align-items:flex-start;flex-direction:column}.date-range-select{width:100%}.daily-list{max-height:60vh}}@media (max-width:480px){main{padding:.75rem}.daily-list{max-height:55vh}}.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}}.landing-info-wrapper{--primary-color:#4a9b6e;--primary-dark:#357a51;--primary-light:#6ab58a;--secondary-color:#2c5f4a;--accent-color:#5fbf85;--text-primary:#1a1a1a;--text-secondary:#666;--text-light:#999;--bg-light:#f8f9fa;--bg-white:#fff;--shadow-sm:0 2px 4px #0000001a;--shadow-md:0 4px 12px #00000026;--shadow-lg:0 8px 24px #0003;--transition:all 0.3s cubic-bezier(0.4,0,0.2,1);background-color:var(--bg-white);color:var(--text-primary);font-family:Inter,sans-serif;line-height:1.6}.landing-info-wrapper *{box-sizing:border-box;margin:0;padding:0}.landing-container{margin:0 auto;max-width:1200px;padding:0 20px}.landing-info-wrapper h1,.landing-info-wrapper h2,.landing-info-wrapper h3,.landing-info-wrapper h4,.landing-info-wrapper h5,.landing-info-wrapper h6{font-weight:700;line-height:1.2;margin-bottom:1rem}.landing-info-wrapper h1{font-size:clamp(2rem,5vw,3.5rem)}.landing-info-wrapper h2{font-size:clamp(1.75rem,4vw,2.5rem)}.landing-info-wrapper h3{font-size:clamp(1.25rem,3vw,1.75rem)}.landing-info-wrapper p{color:var(--text-secondary);margin-bottom:1rem}.landing-navbar{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#fffffff2;box-shadow:0 2px 20px #0000001a;position:fixed;top:0;transition:var(--transition);width:100%;z-index:1000}.landing-navbar.scrolled{background:#fffffffa}.landing-nav-wrapper{align-items:center;display:flex;justify-content:space-between;padding:1rem 0}.landing-logo{align-items:center;color:var(--primary-color);display:flex;font-size:1.5rem;font-weight:700;gap:.75rem;text-decoration:none;transition:var(--transition)}.landing-logo:hover{transform:translateY(-2px)}.landing-logo img{height:50px;object-fit:contain;position:relative;width:auto;z-index:1001}.landing-nav-menu{align-items:center;display:flex;gap:2rem;list-style:none}.landing-nav-link{color:var(--text-primary);font-weight:500;position:relative;text-decoration:none;transition:var(--transition)}.landing-nav-link:after{background:var(--primary-color);bottom:-5px;content:"";height:2px;left:0;position:absolute;transition:width .3s ease;width:0}.landing-nav-link.active:after,.landing-nav-link:hover:after{width:100%}.landing-nav-link.active{color:var(--primary-color);font-weight:600}.landing-btn-app{background:var(--primary-color);border-radius:50px;box-shadow:var(--shadow-sm);color:#fff;font-weight:600;padding:.5rem 1.5rem;text-decoration:none;transition:var(--transition)}.landing-btn-app:hover{background:var(--primary-dark);box-shadow:var(--shadow-md);transform:translateY(-2px)}.landing-nav-toggle{background:none;border:none;cursor:pointer;display:none;flex-direction:column;gap:4px;padding:.5rem;z-index:1002}.landing-nav-toggle span{background:var(--primary-color);height:3px;transition:var(--transition);width:25px}.landing-nav-toggle.active span:first-child{transform:rotate(45deg) translateY(8px)}.landing-nav-toggle.active span:nth-child(2){opacity:0}.landing-nav-toggle.active span:nth-child(3){transform:rotate(-45deg) translateY(-8px)}.landing-hero{background:linear-gradient(135deg,#f5f7fa,#c3cfe2);margin-top:80px;overflow:hidden;padding:4rem 0 0;position:relative}.landing-hero-content{padding:3rem 0 5rem;position:relative;text-align:center;z-index:2}.landing-hero-title{color:var(--text-primary);margin-bottom:1.5rem}.landing-text-accent{color:var(--primary-color);position:relative}.landing-hero-subtitle{color:var(--text-secondary);font-size:1.25rem;margin:0 auto 2rem;max-width:600px}.landing-hero-buttons{display:flex;flex-wrap:wrap;gap:1rem;justify-content:center}.landing-btn{align-items:center;border:2px solid #0000;border-radius:50px;display:inline-flex;font-weight:600;gap:.5rem;overflow:hidden;padding:.75rem 2rem;position:relative;text-decoration:none;transition:var(--transition)}.landing-btn-primary{background:var(--primary-color);box-shadow:var(--shadow-sm);color:#fff}.landing-btn-primary:hover{background:var(--primary-dark);box-shadow:var(--shadow-md);transform:translateY(-3px)}.landing-btn-secondary{background:#0000;border-color:var(--primary-color);color:var(--primary-color)}.landing-btn-secondary:hover{background:var(--primary-color);color:#fff}.landing-btn-large{font-size:1.125rem;padding:1rem 3rem}.landing-hero-image{height:300px;margin-bottom:-100px;position:relative}.landing-floating-element{animation:landing-float 6s ease-in-out infinite;color:var(--primary-color);font-size:3rem;opacity:.3;position:absolute}.landing-floating-element:first-child{left:10%;top:20%}.landing-floating-element:nth-child(2){right:15%;top:50%}.landing-floating-element:nth-child(3){bottom:30%;left:50%}.landing-wave-container{bottom:-1px;left:0;line-height:0;position:absolute;width:100%}.landing-wave-container svg{height:auto;width:100%}.landing-about{background:var(--bg-light);padding:5rem 0}.landing-section-title{color:var(--text-primary);margin-bottom:1rem;position:relative;text-align:center}.landing-section-title:after{background:var(--primary-color);border-radius:2px;bottom:-10px;content:"";height:4px;left:50%;position:absolute;transform:translateX(-50%);width:60px}.landing-section-subtitle{color:var(--primary-color);font-size:1.75rem;font-weight:600;margin-bottom:3rem;text-align:center}.landing-values-grid{grid-gap:2rem;display:grid;gap:2rem;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));margin-top:3rem}.landing-value-card{background:#fff;border-radius:20px;box-shadow:var(--shadow-sm);padding:2.5rem;text-align:center;transition:var(--transition)}.landing-value-card:hover{box-shadow:var(--shadow-lg);transform:translateY(-10px)}.landing-value-icon{align-items:center;background:linear-gradient(135deg,var(--primary-light),var(--primary-color));border-radius:50%;color:#fff;display:flex;font-size:2rem;height:80px;justify-content:center;margin:0 auto 1.5rem;width:80px}.landing-value-card h3{color:var(--text-primary);margin-bottom:1rem}.landing-products{background:#fff;padding:5rem 0}.landing-products-grid{grid-gap:3rem;display:grid;gap:3rem;grid-template-columns:repeat(auto-fit,minmax(350px,1fr));margin-top:3rem}.landing-nisameter-container{background:linear-gradient(135deg,#fff,#f8f9fa);border:1px solid #4a9b6e1a;border-radius:24px;box-shadow:0 4px 20px #00000014,0 1px 3px #0000000d;margin-top:3rem;overflow:hidden;padding:3.5rem;position:relative;transition:var(--transition)}.landing-nisameter-container:before{background:linear-gradient(90deg,var(--primary-color),var(--primary-light));content:"";height:4px;left:0;opacity:.8;position:absolute;right:0;top:0}.landing-nisameter-container:hover{box-shadow:0 8px 30px #0000001f,0 2px 6px #00000014;transform:translateY(-2px)}.landing-nisameter-title{color:var(--primary-color);font-size:2.25rem;font-weight:700;letter-spacing:-.5px;margin-bottom:3rem;padding-bottom:1.5rem;position:relative;text-align:center}.landing-nisameter-title:after{background:linear-gradient(90deg,var(--primary-color),var(--primary-light));border-radius:3px;bottom:-15px;content:"";height:5px;left:50%;position:absolute;transform:translateX(-50%);width:80px}.landing-nisameter-container .landing-products-grid{gap:2.5rem;margin-top:0}.landing-products-unified-container{background:#fff;border-radius:20px;box-shadow:var(--shadow-md);display:flex;gap:0;margin-left:auto;margin-right:auto;margin-top:3rem;max-width:1000px;overflow:hidden;transition:var(--transition)}.landing-products-unified-container:hover{box-shadow:var(--shadow-lg);transform:translateY(-5px)}.landing-products-unified-container .landing-product-card{border-radius:0;border-right:2px solid #4a9b6e26;box-shadow:none;display:flex;flex:1 1;flex-direction:column;padding:0;transition:var(--transition)}.landing-products-unified-container .landing-product-card:last-child{border-right:none}.landing-products-unified-container .landing-product-card:hover{background:#4a9b6e05;box-shadow:none;transform:none}.landing-products-unified-container .landing-product-image{height:240px}.landing-products-unified-container .landing-product-content{display:flex;flex:1 1;flex-direction:column;padding:2rem}.landing-products-unified-container .landing-product-content p{flex:1 1;margin-bottom:1.5rem;margin-top:0}.landing-products-unified-container .landing-product-features{margin-top:auto}.landing-product-card{background:#fff;border:1px solid #4a9b6e14;border-radius:20px;box-shadow:0 4px 15px #0000001a,0 2px 5px #0000000d;overflow:hidden;position:relative;transition:all .4s cubic-bezier(.4,0,.2,1)}.landing-product-badge{background:linear-gradient(135deg,var(--primary-color),var(--primary-dark));border-radius:25px;box-shadow:0 4px 12px #4a9b6e4d;color:#fff;font-size:.875rem;font-weight:600;padding:.6rem 1.25rem;position:absolute;right:1.25rem;top:1.25rem;transition:var(--transition);z-index:10}.landing-product-card:hover .landing-product-badge{box-shadow:0 6px 16px #4a9b6e66;transform:scale(1.05)}.landing-product-card:hover{border-color:#4a9b6e33;box-shadow:0 12px 35px #00000026,0 4px 10px #0000001a;transform:translateY(-12px)}.landing-product-image{align-items:center;background:linear-gradient(135deg,#f8f9fa,#e9ecef);display:flex;height:260px;justify-content:center;overflow:hidden;position:relative;transition:var(--transition)}.landing-product-image:before{background:linear-gradient(135deg,#4a9b6e08,#4a9b6e03);bottom:0;content:"";left:0;opacity:0;position:absolute;right:0;top:0;transition:var(--transition);z-index:1}.landing-product-card:hover .landing-product-image:before{opacity:1}.landing-product-image img{border-radius:8px;height:100%;object-fit:contain;position:relative;transition:transform .6s cubic-bezier(.4,0,.2,1);width:100%;z-index:2}.landing-product-card:hover .landing-product-image img{transform:scale(1.08)}.landing-product-content{background:#fff;padding:2.25rem}.landing-product-content h3{color:var(--text-primary);margin-bottom:1rem}.landing-product-content p{color:var(--text-secondary);line-height:1.7}.landing-product-features{border-top:1px solid #4a9b6e1a;list-style:none;margin:1.75rem 0 0;padding-top:1.5rem}.landing-product-features li{align-items:center;color:var(--text-secondary);display:flex;padding:.65rem 0;transition:var(--transition)}.landing-product-features li:hover{color:var(--primary-color);transform:translateX(5px)}.landing-product-features i{color:var(--primary-color);font-size:.9rem;margin-right:.75rem;transition:var(--transition)}.landing-product-features li:hover i{transform:scale(1.2)}.landing-stats{background:linear-gradient(135deg,var(--primary-color),var(--primary-dark));color:#fff;padding:4rem 0}.landing-stats-grid{grid-gap:2rem;display:grid;gap:2rem;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));text-align:center}.landing-stat-item i{font-size:3rem;margin-bottom:1rem;opacity:.8}.landing-stat-number{font-size:3rem;font-weight:700;margin-bottom:.5rem}.landing-stat-item p{color:#ffffffe6}.landing-cta{background:var(--bg-light);padding:5rem 0;text-align:center}.landing-cta-content h2{margin-bottom:1rem}.landing-cta-content p{font-size:1.25rem;margin-bottom:2rem;margin-left:auto;margin-right:auto;max-width:600px}.landing-footer{background:var(--secondary-color);color:#fff;padding:3rem 0 1rem}.landing-footer-content{grid-gap:2rem;display:grid;gap:2rem;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));margin-bottom:2rem}.landing-footer-logo{align-items:center;display:flex;font-size:1.5rem;font-weight:700;gap:.75rem;margin-bottom:1rem}.landing-footer-section h4{color:#fff;margin-bottom:1rem}.landing-footer-section ul{list-style:none}.landing-footer-section ul li{color:#fffc;padding:.5rem 0}.landing-footer-section a{color:#fffc;text-decoration:none;transition:var(--transition)}.landing-footer-section a:hover{color:#fff}.landing-social-links{display:flex;gap:1rem}.landing-social-links a{align-items:center;background:#ffffff1a;border-radius:50%;display:flex;height:40px;justify-content:center;transition:var(--transition);width:40px}.landing-social-links a:hover{background:var(--primary-color);transform:translateY(-3px)}.landing-footer-bottom{border-top:1px solid #ffffff1a;color:#fff9;padding-top:2rem;text-align:center}.landing-loading{align-items:center;background:#fff;display:flex;height:100%;justify-content:center;left:0;position:fixed;top:0;transition:opacity .3s ease;width:100%;z-index:9999}.landing-loading-spinner{animation:landing-spin 1s linear infinite;border:3px solid var(--bg-light);border-radius:50%;border-top-color:var(--primary-color);height:50px;width:50px}@keyframes landing-float{0%,to{transform:translateY(0) rotate(0deg)}50%{transform:translateY(-20px) rotate(10deg)}}@keyframes landing-spin{to{transform:rotate(1turn)}}@keyframes landing-fade-up{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}@keyframes landing-fade-left{0%{opacity:0;transform:translateX(30px)}to{opacity:1;transform:translateX(0)}}.landing-animate-fade-up{animation:landing-fade-up .8s ease-out forwards}.landing-animate-fade-left{animation:landing-fade-left .8s ease-out forwards}.landing-animate-on-scroll{opacity:0;transform:translateY(30px);transition:all .8s ease-out}.landing-animate-on-scroll.visible{opacity:1;transform:translateY(0)}@media (max-width:768px){.landing-logo img{height:35px}.landing-nav-toggle{display:flex}.landing-nav-menu{background:#fff;box-shadow:var(--shadow-lg);flex-direction:column;left:-100%;padding:2rem 0;position:fixed;top:70px;transition:.3s;width:100%}.landing-nav-menu.active{left:0}.landing-hero-buttons{align-items:center;flex-direction:column}.landing-products-grid,.landing-values-grid{grid-template-columns:1fr}.landing-nisameter-container{border-radius:20px;margin-top:2rem;padding:2rem 1.25rem}.landing-nisameter-title{font-size:1.75rem;margin-bottom:2rem;padding-bottom:1.25rem}.landing-nisameter-title:after{height:4px;width:60px}.landing-nisameter-container .landing-products-grid{gap:2rem}.landing-product-content{padding:1.75rem}.landing-product-badge{font-size:.8rem;padding:.5rem 1rem;right:1rem;top:1rem}.landing-products-unified-container{flex-direction:column;max-width:100%}.landing-products-unified-container .landing-product-card{border-bottom:2px solid #4a9b6e26;border-right:none}.landing-products-unified-container .landing-product-card:last-child{border-bottom:none}.landing-products-unified-container .landing-product-image{height:220px}.landing-products-unified-container .landing-product-content{padding:1.5rem}.landing-stats-grid{grid-template-columns:repeat(2,1fr)}.landing-footer-content{grid-template-columns:1fr;text-align:center}.landing-social-links{justify-content:center}}html{scroll-behavior:smooth}.landing-info-wrapper ::selection{background:var(--primary-color);color:#fff}.landing-info-wrapper ::-moz-selection{background:var(--primary-color);color:#fff}
/*# sourceMappingURL=main.6b557e96.css.map*/