.landing-root,.landing-root *,.landing-root *:before,.landing-root *:after{box-sizing:border-box}.landing-root{--green: #16a34a;--green-light: #22c55e;--green-pale: #f0fdf4;--green-mid: #dcfce7;--text: #0f172a;--text-muted: #64748b;--text-subtle: #94a3b8;--border: #e2e8f0;--white: #ffffff;--bg: #f8fafc;--accent: #0ea5e9;--accent-pale: #f0f9ff;--gold: #f59e0b;--gold-pale: #fffbeb;font-family:Inter,sans-serif;color:var(--text);background:var(--white);overflow-x:hidden;line-height:1.6}.landing-root nav.lp-nav{position:fixed;top:0;left:0;right:0;z-index:100;background:#ffffffeb;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);border-bottom:1px solid var(--border)}.landing-root .nav-inner{max-width:1200px;margin:0 auto;padding:0 2rem;min-height:84px;display:flex;align-items:center;justify-content:space-between}.landing-root .logo{font-family:Space Grotesk,sans-serif;font-weight:700;font-size:1.4rem;color:var(--text);display:inline-flex;align-items:center;gap:.5rem;text-decoration:none}.landing-root .logo img{display:block}.landing-root .nav-links{display:flex;gap:2rem;list-style:none;margin:0;padding:0}.landing-root .nav-links a{text-decoration:none;color:var(--text-muted);font-size:.9rem;font-weight:500;transition:color .2s}.landing-root .nav-links a:hover{color:var(--green)}.landing-root .nav-cta{background:var(--green);color:#fff;padding:.55rem 1.4rem;border-radius:8px;font-size:.9rem;font-weight:600;text-decoration:none;transition:background .2s,transform .15s;white-space:nowrap}.landing-root .nav-cta:hover{background:#15803d;transform:translateY(-1px)}.landing-root .hero{min-height:100vh;display:flex;align-items:center;padding:100px 2rem 60px;background:linear-gradient(160deg,#f0fdf4,#fff 45%,#f0f9ff);position:relative;overflow:hidden}.landing-root .hero-grid{position:absolute;top:0;right:0;bottom:0;left:0;opacity:.035;background-image:linear-gradient(var(--green) 1px,transparent 1px),linear-gradient(90deg,var(--green) 1px,transparent 1px);background-size:48px 48px}.landing-root .hero-inner{max-width:1200px;margin:0 auto;width:100%;display:grid;grid-template-columns:1fr 1fr;gap:4rem;align-items:center;position:relative}.landing-root .badge{display:inline-flex;align-items:center;gap:.4rem;background:var(--gold-pale);border:1px solid #fde68a;color:#92400e;font-size:.78rem;font-weight:600;padding:.35rem .85rem;border-radius:100px;margin-bottom:1.5rem;animation:lp-pulse-badge 2.5s ease-in-out infinite}@keyframes lp-pulse-badge{0%,to{box-shadow:0 0 #f59e0b40}50%{box-shadow:0 0 0 6px #f59e0b00}}.landing-root .badge-dot{width:7px;height:7px;background:var(--gold);border-radius:50%}.landing-root h1{font-family:Space Grotesk,sans-serif;font-size:clamp(2.4rem,5vw,3.6rem);font-weight:800;line-height:1.12;letter-spacing:-.02em;color:var(--text);margin:0 0 1.25rem}.landing-root h1 .accent{color:var(--green)}.landing-root .hero-sub{font-size:1.1rem;color:var(--text-muted);line-height:1.7;max-width:520px;margin:0 0 2.5rem}.landing-root .hero-actions{display:flex;gap:1rem;flex-wrap:wrap;align-items:center}.landing-root .btn-primary{background:var(--green);color:#fff;padding:.85rem 2rem;border-radius:10px;font-size:1rem;font-weight:700;text-decoration:none;transition:all .2s;display:inline-flex;align-items:center;gap:.5rem;box-shadow:0 4px 14px #16a34a59;border:none;cursor:pointer}.landing-root .btn-primary:hover{background:#15803d;transform:translateY(-2px);box-shadow:0 6px 20px #16a34a73}.landing-root .btn-secondary{background:#fff;color:var(--text);border:1.5px solid var(--border);padding:.85rem 1.75rem;border-radius:10px;font-size:1rem;font-weight:600;text-decoration:none;transition:all .2s;display:inline-flex;align-items:center;gap:.5rem}.landing-root .btn-secondary:hover{border-color:var(--green);color:var(--green);transform:translateY(-2px)}.landing-root .btn-whatsapp{background:#25d366;color:#fff;padding:.95rem 2.2rem;border-radius:12px;font-size:1rem;font-weight:700;text-decoration:none;transition:all .2s;display:inline-flex;align-items:center;gap:.6rem;box-shadow:0 4px 14px #25d36666;border:none;cursor:pointer}.landing-root .btn-whatsapp:hover{background:#1ebe5a;transform:translateY(-2px);box-shadow:0 6px 22px #25d3668c}.landing-root .hero-trust{margin-top:2.5rem;display:flex;gap:1.5rem;flex-wrap:wrap}.landing-root .trust-item{display:flex;align-items:center;gap:.4rem;font-size:.82rem;color:var(--text-muted);font-weight:500}.landing-root .trust-icon{font-size:1rem}.landing-root .hero-visual{position:relative;display:flex;justify-content:center;align-items:center}.landing-root .dashboard-card{background:#fff;border-radius:20px;box-shadow:0 20px 60px #0000001a,0 4px 16px #0000000f;padding:1.5rem;width:100%;max-width:460px;border:1px solid var(--border);animation:lp-float 4s ease-in-out infinite}@keyframes lp-float{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}.landing-root .dash-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1.2rem}.landing-root .dash-title{font-weight:700;font-size:.95rem}.landing-root .dash-live{display:flex;align-items:center;gap:.3rem;font-size:.72rem;color:var(--green);font-weight:600}.landing-root .live-dot{width:7px;height:7px;background:var(--green);border-radius:50%;animation:lp-blink 1.4s ease-in-out infinite}@keyframes lp-blink{0%,to{opacity:1}50%{opacity:.3}}.landing-root .dash-stats{display:grid;grid-template-columns:1fr 1fr 1fr;gap:.75rem;margin-bottom:1.2rem}.landing-root .stat-box{background:var(--bg);border-radius:12px;padding:.85rem;text-align:center;border:1px solid var(--border)}.landing-root .stat-val{font-size:1.4rem;font-weight:800;line-height:1}.landing-root .stat-lbl{font-size:.68rem;color:var(--text-muted);margin-top:.25rem;font-weight:500}.landing-root .stat-box.green .stat-val{color:var(--green)}.landing-root .stat-box.blue .stat-val{color:var(--accent)}.landing-root .stat-box.gold .stat-val{color:var(--gold)}.landing-root .dash-chart-label{font-size:.75rem;color:var(--text-muted);font-weight:600;margin-bottom:.5rem}.landing-root .bar-group{display:flex;gap:4px;align-items:flex-end;height:64px}.landing-root .bar{flex:1;border-radius:4px 4px 0 0;background:linear-gradient(to top,var(--green),var(--green-light));opacity:.7;transition:opacity .2s}.landing-root .bar:hover,.landing-root .bar.active{opacity:1}.landing-root .dash-zones{margin-top:1.2rem;display:flex;flex-direction:column;gap:.5rem}.landing-root .zone-row{display:flex;align-items:center;gap:.75rem;padding:.6rem .85rem;border-radius:10px;background:var(--bg);border:1px solid var(--border)}.landing-root .zone-icon{font-size:1rem}.landing-root .zone-name{font-size:.8rem;font-weight:600;flex:1}.landing-root .zone-status{font-size:.7rem;font-weight:700;padding:.2rem .5rem;border-radius:100px}.landing-root .zone-status.on{background:var(--green-mid);color:#15803d}.landing-root .zone-status.off{background:var(--border);color:var(--text-muted)}.landing-root .zone-status.sched{background:var(--accent-pale);color:#0369a1}.landing-root .float-badge{position:absolute;background:#fff;border-radius:14px;padding:.7rem 1rem;box-shadow:0 8px 24px #0000001a;border:1px solid var(--border);display:flex;align-items:center;gap:.5rem;font-size:.78rem;font-weight:600;white-space:nowrap}.landing-root .float-badge.top-left{top:10%;left:-5%;animation:lp-float2 3.5s ease-in-out infinite}.landing-root .float-badge.bottom-right{bottom:12%;right:-3%;animation:lp-float3 4s ease-in-out infinite}@keyframes lp-float2{0%,to{transform:translateY(0)}50%{transform:translateY(-8px)}}@keyframes lp-float3{0%,to{transform:translateY(0)}50%{transform:translateY(8px)}}.landing-root .social-proof{background:var(--bg);border-top:1px solid var(--border);border-bottom:1px solid var(--border);padding:2rem}.landing-root .social-inner{max-width:1100px;margin:0 auto;text-align:center}.landing-root .social-label{font-size:.78rem;color:var(--text-subtle);font-weight:600;letter-spacing:.08em;text-transform:uppercase;margin-bottom:1.2rem}.landing-root .logo-strip{display:flex;justify-content:center;gap:3rem;flex-wrap:wrap;align-items:center}.landing-root .logo-strip span{font-family:Space Grotesk,sans-serif;font-weight:700;font-size:1rem;color:#cbd5e1;letter-spacing:-.01em}.landing-root section{padding:100px 2rem}.landing-root .section-inner{max-width:1200px;margin:0 auto}.landing-root .section-label{font-size:.78rem;color:var(--green);font-weight:700;letter-spacing:.1em;text-transform:uppercase;margin-bottom:.75rem}.landing-root .section-title{font-family:Space Grotesk,sans-serif;font-size:clamp(1.9rem,3.5vw,2.75rem);font-weight:800;line-height:1.15;letter-spacing:-.02em;color:var(--text);margin:0 0 1rem}.landing-root .section-sub{font-size:1.05rem;color:var(--text-muted);max-width:600px;line-height:1.7}.landing-root .features-bg{background:#fff}.landing-root .features-header{text-align:center;margin-bottom:4rem}.landing-root .features-header .section-sub{margin:0 auto}.landing-root .features-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem}.landing-root .feature-card{background:var(--white);border:1.5px solid var(--border);border-radius:20px;padding:2rem;transition:all .3s;position:relative;overflow:hidden}.landing-root .feature-card:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(135deg,var(--green-pale),transparent);opacity:0;transition:opacity .3s}.landing-root .feature-card:hover{border-color:var(--green-light);transform:translateY(-4px);box-shadow:0 12px 32px #16a34a1a}.landing-root .feature-card:hover:before{opacity:1}.landing-root .feat-icon{width:52px;height:52px;border-radius:14px;display:flex;align-items:center;justify-content:center;font-size:1.5rem;margin-bottom:1.25rem;position:relative;z-index:1}.landing-root .feat-icon.green{background:var(--green-mid)}.landing-root .feat-icon.blue{background:#dbeafe}.landing-root .feat-icon.purple{background:#ede9fe}.landing-root .feat-icon.gold{background:var(--gold-pale)}.landing-root .feat-icon.teal{background:#ccfbf1}.landing-root .feat-icon.rose{background:#ffe4e6}.landing-root .feat-title{font-weight:700;font-size:1.05rem;margin-bottom:.5rem;position:relative;z-index:1}.landing-root .feat-desc{font-size:.88rem;color:var(--text-muted);line-height:1.65;position:relative;z-index:1}.landing-root .feat-tag{display:inline-block;margin-top:1rem;font-size:.72rem;font-weight:700;padding:.2rem .6rem;border-radius:6px;background:var(--green-mid);color:#15803d;position:relative;z-index:1}.landing-root .feat-tag.blue{background:#dbeafe;color:#1d4ed8}.landing-root .feat-tag.purple{background:#ede9fe;color:#7c3aed}.landing-root .how-bg{background:linear-gradient(180deg,var(--bg) 0%,white 100%)}.landing-root .how-grid{display:grid;grid-template-columns:1fr 1fr;gap:5rem;align-items:center}.landing-root .steps{display:flex;flex-direction:column;gap:0}.landing-root .step{display:flex;gap:1.25rem;border-left:2px solid var(--border);padding:1.5rem 0 1.5rem 2rem;position:relative;transition:border-color .3s}.landing-root .step:first-child{padding-top:0}.landing-root .step:last-child{border-left-color:transparent}.landing-root .step:hover{border-left-color:var(--green)}.landing-root .step-num{position:absolute;left:-14px;top:1.5rem;width:26px;height:26px;border-radius:50%;background:#fff;border:2px solid var(--border);display:flex;align-items:center;justify-content:center;font-size:.72rem;font-weight:800;color:var(--text-muted);flex-shrink:0;transition:all .3s}.landing-root .step:hover .step-num{background:var(--green);border-color:var(--green);color:#fff}.landing-root .step-content{flex:1}.landing-root .step-title{font-weight:700;font-size:1rem;margin-bottom:.35rem}.landing-root .step-desc{font-size:.875rem;color:var(--text-muted);line-height:1.65}.landing-root .retrofit-visual{background:#fff;border-radius:20px;border:1.5px solid var(--border);padding:2rem;box-shadow:0 8px 32px #0000000f}.landing-root .rv-title{font-weight:700;font-size:.9rem;margin-bottom:1.25rem}.landing-root .compat-list{display:flex;flex-direction:column;gap:.6rem}.landing-root .compat-item{display:flex;align-items:center;gap:.75rem;padding:.7rem 1rem;border-radius:10px;background:var(--bg);border:1px solid var(--border)}.landing-root .compat-icon{font-size:1.1rem}.landing-root .compat-name{font-size:.85rem;font-weight:600;flex:1}.landing-root .compat-badge{font-size:.68rem;font-weight:700;padding:.18rem .5rem;border-radius:6px}.landing-root .compat-badge.compatible{background:var(--green-mid);color:#15803d}.landing-root .compat-badge.legacy{background:#fef9c3;color:#854d0e}.landing-root .arrow-row{display:flex;align-items:center;justify-content:center;gap:1rem;margin:1rem 0;font-size:.8rem;color:var(--text-muted)}.landing-root .arrow-line{flex:1;height:1px;background:var(--border)}.landing-root .arrow-text{display:flex;align-items:center;gap:.3rem;font-weight:600;color:var(--green)}.landing-root .retrofit-final{background:var(--green-pale);border:1.5px solid var(--green-light);border-radius:12px;padding:1rem;text-align:center;margin-top:.5rem}.landing-root .retrofit-final-title{font-weight:800;color:var(--green);font-size:1rem}.landing-root .retrofit-final-sub{font-size:.8rem;color:var(--text-muted);margin-top:.25rem}.landing-root .guarantee-bg{background:var(--green)}.landing-root .guarantee-inner{max-width:1000px;margin:0 auto;text-align:center}.landing-root .guarantee-icon{font-size:3.5rem;margin-bottom:1.5rem}.landing-root .guarantee-inner .section-label{color:#ffffffb3}.landing-root .guarantee-inner .section-title{color:#fff}.landing-root .guarantee-inner .section-sub{color:#fffc;margin:0 auto 3rem}.landing-root .guarantee-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem}.landing-root .guarantee-card{background:#ffffff1f;border:1px solid rgba(255,255,255,.2);border-radius:16px;padding:1.75rem;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.landing-root .guarantee-card h3{color:#fff;font-size:1.05rem;font-weight:700;margin:0 0 .5rem}.landing-root .guarantee-card p{color:#ffffffbf;font-size:.875rem;line-height:1.6;margin:0}.landing-root .guarantee-card .gc-icon{font-size:1.75rem;margin-bottom:.75rem}.landing-root .pricing-bg{background:#fff}.landing-root .pricing-header{text-align:center;margin-bottom:3.5rem}.landing-root .pricing-header .section-sub{margin:0 auto 1.5rem}.landing-root .pricing-note{display:inline-flex;align-items:center;gap:.5rem;background:var(--gold-pale);border:1px solid #fde68a;color:#92400e;font-size:.82rem;font-weight:600;padding:.5rem 1.1rem;border-radius:100px}.landing-root .modules-grid{display:grid;grid-template-columns:1fr 1fr 1fr;gap:1.25rem;margin-bottom:1.5rem}.landing-root .irrigation-hero{border:2px solid var(--green);border-radius:20px;background:var(--green-pale);padding:2rem 2.25rem;margin-bottom:1.5rem;position:relative;overflow:hidden}.landing-root .irrigation-hero:after{content:"";position:absolute;right:-40px;top:-40px;width:200px;height:200px;border-radius:50%;background:radial-gradient(circle,rgba(34,197,94,.12),transparent 70%)}.landing-root .ih-top{display:flex;align-items:flex-start;justify-content:space-between;flex-wrap:wrap;gap:1.5rem;margin-bottom:1.5rem;position:relative}.landing-root .ih-left .module-icon{font-size:2.25rem;margin-bottom:.5rem}.landing-root .ih-left .module-name{font-size:1.25rem;font-weight:800;margin-bottom:.4rem}.landing-root .ih-left .module-desc{font-size:.875rem;color:var(--text-muted);max-width:420px;line-height:1.6}.landing-root .ih-pricing{text-align:right;flex-shrink:0}.landing-root .ih-pricing-row{display:flex;align-items:baseline;gap:.4rem;justify-content:flex-end;margin-bottom:.35rem}.landing-root .ih-price-big{font-family:Space Grotesk,sans-serif;font-weight:900;font-size:2.2rem;color:var(--green);line-height:1}.landing-root .ih-price-orig-row{text-align:right;font-size:.8rem;color:var(--text-subtle);text-decoration:line-through;margin-bottom:.3rem}.landing-root .ih-price-unit{font-size:.85rem;color:var(--text-muted);font-weight:500}.landing-root .ih-price-add{font-size:.82rem;color:var(--text-muted);margin-top:.1rem}.landing-root .ih-price-add strong{color:var(--green);font-size:.95rem}.landing-root .ih-price-add .strike{text-decoration:line-through;color:var(--text-subtle);font-size:.8rem;font-weight:400}.landing-root .ih-install{display:inline-flex;align-items:center;gap:.4rem;background:#fef9c3;border:1px solid #fde68a;color:#78350f;font-size:.75rem;font-weight:700;padding:.3rem .75rem;border-radius:8px;margin-top:.5rem}.landing-root .ih-tiers{display:grid;grid-template-columns:repeat(3,1fr);gap:.75rem;border-top:1.5px solid rgba(22,163,74,.2);padding-top:1.25rem;position:relative}.landing-root .ih-tier{background:#fff;border-radius:12px;padding:.85rem 1rem;border:1px solid rgba(22,163,74,.2);text-align:center;position:relative}.landing-root .ih-tier-label{font-size:.72rem;color:var(--text-muted);font-weight:600;text-transform:uppercase;letter-spacing:.06em;margin-bottom:.4rem}.landing-root .ih-tier-price{font-family:Space Grotesk,sans-serif;font-weight:800;font-size:1.05rem;color:var(--green)}.landing-root .ih-tier-orig{font-size:.72rem;color:var(--text-subtle);text-decoration:line-through;margin-top:.15rem}.landing-root .ih-tier-note{font-size:.7rem;color:var(--text-subtle);margin-top:.2rem}.landing-root .ih-tier-discount{display:inline-block;margin-top:.35rem;background:var(--green);color:#fff;font-size:.68rem;font-weight:800;padding:.2rem .5rem;border-radius:6px}.landing-root .ih-tier.deal{border-color:var(--green);background:#fff}.landing-root .ih-tier.best{border-color:#f59e0b;background:#fffbeb}.landing-root .ih-tier.best .ih-tier-price{color:#b45309}.landing-root .ih-tier.best .ih-tier-discount{background:#f59e0b;color:#fff}.landing-root .ih-tier-badge{position:absolute;top:-10px;left:50%;transform:translate(-50%);background:#f59e0b;color:#fff;font-size:.65rem;font-weight:800;padding:.18rem .6rem;border-radius:100px;white-space:nowrap}.landing-root .ih-tier.deal .ih-tier-badge{background:var(--green)}.landing-root .module-card{border:1.5px solid var(--border);border-radius:16px;padding:1.5rem;transition:all .2s;cursor:pointer;position:relative}.landing-root .module-card:hover{border-color:var(--green);box-shadow:0 6px 20px #16a34a14}.landing-root .module-icon{font-size:1.75rem;margin-bottom:.75rem}.landing-root .module-name{font-weight:700;font-size:.95rem;margin-bottom:.35rem}.landing-root .module-desc{font-size:.8rem;color:var(--text-muted);line-height:1.5;margin-bottom:1rem}.landing-root .module-price{font-family:Space Grotesk,sans-serif;font-weight:800;font-size:1.3rem;color:var(--green)}.landing-root .module-price span{font-size:.75rem;color:var(--text-muted);font-weight:400;font-family:Inter,sans-serif}.landing-root .module-orig{font-size:.78rem;color:var(--text-subtle);text-decoration:line-through;margin-top:.1rem}.landing-root .pricing-cta-box{background:linear-gradient(135deg,var(--green-pale),var(--accent-pale));border:1.5px solid var(--green-light);border-radius:20px;padding:2.5rem;display:flex;align-items:center;justify-content:space-between;gap:2rem;flex-wrap:wrap}.landing-root .pcta-left h3{font-family:Space Grotesk,sans-serif;font-size:1.4rem;font-weight:800;margin:0 0 .5rem}.landing-root .pcta-left p{font-size:.9rem;color:var(--text-muted);margin:0}.landing-root .pcta-right{display:flex;flex-direction:column;gap:.75rem;align-items:flex-end;flex-shrink:0}.landing-root .pcta-savings{background:#25d366;color:#fff;padding:.85rem 2rem;border-radius:12px;font-weight:700;font-size:1rem;text-align:center;white-space:nowrap;text-decoration:none;transition:transform .2s}.landing-root .pcta-savings:hover{transform:translateY(-2px)}.landing-root .pcta-savings small{display:block;font-size:.72rem;opacity:.9;font-weight:400}.landing-root .pcta-fineprint{font-size:.78rem;color:var(--text-subtle);text-align:right}.landing-root .early-bg{background:linear-gradient(135deg,#0f172a,#1e293b);position:relative;overflow:hidden}.landing-root .early-bg:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background-image:radial-gradient(circle at 20% 50%,rgba(22,163,74,.15) 0%,transparent 50%),radial-gradient(circle at 80% 50%,rgba(14,165,233,.1) 0%,transparent 50%)}.landing-root .early-inner{max-width:800px;margin:0 auto;text-align:center;position:relative}.landing-root .countdown-chips{display:flex;justify-content:center;gap:1rem;margin-bottom:2.5rem;flex-wrap:wrap}.landing-root .countdown-chip{background:#ffffff14;border:1px solid rgba(255,255,255,.15);border-radius:12px;padding:1rem 1.5rem;min-width:80px;text-align:center}.landing-root .countdown-chip .num{font-family:Space Grotesk,sans-serif;font-size:2rem;font-weight:800;color:#fff;display:block;line-height:1}.landing-root .countdown-chip .lbl{font-size:.68rem;color:#ffffff80;text-transform:uppercase;letter-spacing:.1em;margin-top:.25rem}.landing-root .early-inner .section-label{color:var(--gold)}.landing-root .early-inner .section-title{color:#fff;margin-bottom:1rem}.landing-root .early-inner .section-sub{color:#ffffffb3;margin:0 auto 2.5rem}.landing-root .early-cta-wrap{display:flex;justify-content:center}.landing-root .early-disclaimer{font-size:.8rem;color:#ffffff80;margin-top:1.25rem}.landing-root .testi-bg{background:var(--bg)}.landing-root .testi-header{text-align:center;margin-bottom:3rem}.landing-root .testi-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem}.landing-root .testi-card{background:#fff;border-radius:20px;padding:1.75rem;border:1.5px solid var(--border);transition:transform .2s,box-shadow .2s}.landing-root .testi-card:hover{transform:translateY(-3px);box-shadow:0 10px 28px #00000014}.landing-root .stars{color:var(--gold);font-size:.85rem;margin-bottom:1rem;letter-spacing:.1em}.landing-root .testi-quote{font-size:.9rem;line-height:1.7;color:var(--text-muted);margin:0 0 1.25rem}.landing-root .testi-author{display:flex;align-items:center;gap:.75rem}.landing-root .testi-avatar{width:40px;height:40px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:1rem;font-weight:700;color:#fff;flex-shrink:0}.landing-root .testi-name{font-weight:700;font-size:.875rem}.landing-root .testi-role{font-size:.75rem;color:var(--text-subtle)}.landing-root .faq-bg{background:#fff}.landing-root .faq-header{text-align:center;margin-bottom:1rem}.landing-root .faq-grid{display:grid;grid-template-columns:1fr 1fr;gap:1rem;margin-top:3rem}.landing-root .faq-item{border:1.5px solid var(--border);border-radius:14px;overflow:hidden}.landing-root .faq-q{padding:1.25rem 1.5rem;font-weight:700;font-size:.9rem;cursor:pointer;display:flex;justify-content:space-between;align-items:center;transition:background .2s;background:none;border:none;width:100%;text-align:left;color:inherit;font-family:inherit}.landing-root .faq-q:hover{background:var(--bg)}.landing-root .faq-a{padding:0 1.5rem 1.25rem;font-size:.875rem;color:var(--text-muted);line-height:1.7;display:none}.landing-root .faq-item.open .faq-a{display:block}.landing-root .faq-item.open .faq-q{background:var(--green-pale);color:var(--green)}.landing-root .faq-chevron{transition:transform .3s;font-style:normal}.landing-root .faq-item.open .faq-chevron{transform:rotate(180deg)}.landing-root footer{background:var(--text);color:#fff9;padding:4rem 2rem 2rem}.landing-root .footer-inner{max-width:1200px;margin:0 auto}.landing-root .footer-top{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:3rem;margin-bottom:3rem}.landing-root .footer-brand .logo{color:#fff;margin-bottom:1rem;display:flex}.landing-root .footer-brand p{font-size:.875rem;line-height:1.65;max-width:260px;margin:0}.landing-root .footer-col h4{color:#fff;font-size:.875rem;font-weight:700;margin:0 0 1.25rem}.landing-root .footer-col ul{list-style:none;display:flex;flex-direction:column;gap:.6rem;margin:0;padding:0}.landing-root .footer-col ul li a{color:#ffffff8c;text-decoration:none;font-size:.85rem;transition:color .2s}.landing-root .footer-col ul li a:hover{color:var(--green-light)}.landing-root .footer-bottom{border-top:1px solid rgba(255,255,255,.1);padding-top:1.75rem;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:1rem}.landing-root .footer-bottom p{font-size:.8rem;margin:0}.landing-root .sticky-banner{position:fixed;bottom:1.5rem;left:50%;transform:translate(-50%);background:var(--text);color:#fff;padding:.85rem 1.5rem;border-radius:14px;box-shadow:0 8px 32px #00000040;display:flex;align-items:center;gap:1rem;font-size:.85rem;z-index:99;white-space:nowrap;animation:lp-slideUp .5s ease 1s backwards}@keyframes lp-slideUp{0%{transform:translate(-50%) translateY(20px);opacity:0}to{transform:translate(-50%) translateY(0);opacity:1}}.landing-root .sticky-banner strong{color:var(--gold)}.landing-root .sticky-banner a{color:#4ade80;font-weight:700;text-decoration:none}.landing-root .sticky-close{background:none;border:none;color:#ffffff80;cursor:pointer;font-size:1rem;padding:0;margin-left:.5rem}@media (max-width: 900px){.landing-root .hero-inner{grid-template-columns:1fr}.landing-root .hero-visual{display:none}.landing-root .features-grid{grid-template-columns:1fr 1fr}.landing-root .how-grid,.landing-root .guarantee-cards{grid-template-columns:1fr}.landing-root .modules-grid{grid-template-columns:1fr 1fr}.landing-root .ih-top{flex-direction:column}.landing-root .testi-grid,.landing-root .faq-grid{grid-template-columns:1fr}.landing-root .footer-top{grid-template-columns:1fr 1fr}}@media (max-width: 600px){.landing-root .features-grid,.landing-root .modules-grid,.landing-root .ih-tiers{grid-template-columns:1fr}.landing-root .ih-pricing{text-align:left}.landing-root .footer-top{grid-template-columns:1fr}.landing-root .nav-links{display:none}}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--bg: #0f2d17;--surface: #1a3d22;--surface2: #234d2c;--border: #2e6b38;--accent: #3ddc68;--accent-dim: #2aa84e;--danger: #e05c5c;--warning: #e0a84a;--text: #e8f5eb;--text-muted: #8aad92;--radius: 10px;--shadow: 0 2px 12px rgba(0,0,0,.4)}html,body{background:var(--bg);color:var(--text);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;line-height:1.5;min-height:100vh;-webkit-tap-highlight-color:transparent}html{font-size:18px}html[data-font-size=small]{font-size:16px}html[data-font-size=medium]{font-size:18px}html[data-font-size=large]{font-size:22px}html[data-theme=light]{--bg: #f4f7f3;--surface: #ffffff;--surface2: #eaf1eb;--border: #c0d4c5;--accent: #1f8a3d;--accent-dim: #176d2f;--danger: #c33b46;--warning: #b27414;--text: #0f2d17;--text-muted: #5a6e5e;--shadow: 0 2px 10px rgba(0,0,0,.08)}html[data-theme=light] .valve-card.open{background:#e3f5e8}html[data-theme=light] .status-badge.open{background:#d6efdc;color:var(--accent)}html[data-theme=light] .status-badge.closed{background:#e6e6e6;color:var(--text-muted)}html[data-theme=light] .status-badge.unknown{background:#fbecc6;color:var(--warning)}html[data-theme=light] .status-badge.error{background:#f7d8da;color:var(--danger)}html[data-theme=light] .toggle-btn.close,html[data-theme=light] .btn-primary,html[data-theme=light] .profile-avatar{color:#fff}html[data-theme=light] .error-msg{background:#fbe5e7}html[data-theme=light] .success-msg{background:#e3f5e8}html[data-theme=light] .pump-illo{background:linear-gradient(180deg,#c5dbef,#9fbcd6);border-color:#7fa3c2}html[data-theme=light] .water-body{fill:#2e8bd3}html[data-theme=light] .flow-orb,html[data-theme=light] .water-drop,html[data-theme=light] .splash-drop{fill:#fff}html[data-theme=light] .water-puddle{fill:#2e8bd3}html[data-theme=light] .pump-illo.on .water-body{opacity:.75}html[data-theme=high-contrast]{--bg: #000000;--surface: #0a1f0f;--surface2: #14331c;--border: #6fd587;--accent: #5dff8a;--accent-dim: #3ddc68;--danger: #ff6b6b;--warning: #ffc14a;--text: #ffffff;--text-muted: #c9e6cf}html[data-theme=high-contrast] body{font-weight:500}html[data-theme=high-contrast] input,html[data-theme=high-contrast] select,html[data-theme=high-contrast] .card,html[data-theme=high-contrast] .valve-card,html[data-theme=high-contrast] .bottom-nav{border-width:2px}html[data-theme=high-contrast] .bottom-nav{border-top-width:2px}html[data-theme=high-contrast] th{color:var(--text)}a{color:var(--accent);text-decoration:none}button{cursor:pointer;border:none;border-radius:var(--radius);font-size:1rem;font-weight:600;transition:opacity .15s,transform .1s}button:active{transform:scale(.97)}button:disabled{opacity:.45;cursor:not-allowed}input,select{background:var(--surface2);border:1px solid var(--border);border-radius:var(--radius);color:var(--text);font-size:1rem;padding:10px 14px;width:100%;outline:none}input:focus,select:focus{border-color:var(--accent)}.app-shell{display:flex;flex-direction:column;min-height:100vh}.main-content{flex:1;padding:16px;padding-bottom:calc(80px + env(safe-area-inset-bottom,0px));max-width:600px;margin:0 auto;width:100%}.bottom-nav{position:fixed;bottom:0;left:0;right:0;background:var(--surface);border-top:1px solid var(--border);display:flex;justify-content:space-around;padding:8px 0 env(safe-area-inset-bottom,8px);z-index:100}.bottom-nav a{display:flex;flex-direction:column;align-items:center;gap:2px;color:var(--text-muted);font-size:.7rem;padding:6px 16px;border-radius:8px;text-decoration:none}.bottom-nav a.active{color:var(--accent)}.bottom-nav a svg{width:22px;height:22px}.page-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px}.page-header h1{font-size:1.4rem}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:16px;box-shadow:var(--shadow)}.valve-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:12px}.valve-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:14px 12px;display:flex;flex-direction:column;align-items:center;gap:10px;box-shadow:var(--shadow)}.valve-card.open{border-color:var(--accent);background:#1d4a27}.valve-card.error{border-color:var(--danger)}.valve-number{font-size:.75rem;color:var(--text-muted)}.valve-name{font-size:.9rem;font-weight:600;text-align:center}.status-badge{font-size:.7rem;font-weight:700;padding:3px 10px;border-radius:20px;letter-spacing:.05em;text-transform:uppercase}.status-badge.open{background:#1e5c30;color:var(--accent)}.status-badge.closed{background:#2a2a2a;color:var(--text-muted)}.status-badge.unknown{background:#3a3010;color:var(--warning)}.status-badge.error{background:#3a1010;color:var(--danger)}.toggle-btn{width:100%;padding:8px;font-size:.85rem}.toggle-btn.open{background:var(--danger);color:#fff}.toggle-btn.close{background:var(--accent);color:#0f2d17}.toggle-btn.unknown{background:var(--surface2);color:var(--text-muted)}.btn-primary{background:var(--accent);color:#0f2d17;padding:12px 20px}.btn-primary:hover{background:var(--accent-dim)}.btn-danger{background:var(--danger);color:#fff;padding:8px 14px;font-size:.85rem}.btn-ghost{background:transparent;border:1px solid var(--border);color:var(--text);padding:8px 14px}.form-group{display:flex;flex-direction:column;gap:6px;margin-bottom:16px}.form-group label{font-size:.85rem;color:var(--text-muted)}.table-scroll{overflow-x:auto}table{width:100%;border-collapse:collapse;font-size:.85rem}th,td{padding:10px 8px;border-bottom:1px solid var(--border);text-align:left}th{color:var(--text-muted);font-weight:600;font-size:.75rem;text-transform:uppercase}tr:hover td{background:var(--surface2)}.alert-row{background:var(--surface);border-left:3px solid var(--warning);border-radius:var(--radius);padding:12px 16px;margin-bottom:10px;display:flex;align-items:flex-start;justify-content:space-between;gap:10px}.alert-row.resolved{opacity:.5;border-color:var(--border)}.loader{text-align:center;padding:40px;color:var(--text-muted)}.error-msg{color:var(--danger);background:#3a1010;border-radius:var(--radius);padding:12px 16px;margin-bottom:16px;font-size:.9rem}.success-msg{color:var(--accent);background:#1a3d22;border-radius:var(--radius);padding:12px 16px;margin-bottom:16px;font-size:.9rem}.banner{display:flex;align-items:center;gap:10px;padding:10px 14px;border-radius:10px;font-size:.9rem;margin-bottom:12px;border:1px solid transparent}.banner-warning{background:color-mix(in srgb,var(--warning) 15%,var(--surface));border-color:color-mix(in srgb,var(--warning) 40%,transparent);color:var(--warning)}.banner-danger{background:color-mix(in srgb,var(--danger) 12%,var(--surface));border-color:color-mix(in srgb,var(--danger) 40%,transparent);color:var(--danger);margin-top:12px;margin-bottom:0}.motor-header{display:flex;justify-content:space-between;align-items:center;gap:12px}.motor-status{min-width:0;flex:1}.motor-label{font-size:.75rem;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:var(--text-muted);margin-bottom:6px}.motor-state-row{display:flex;align-items:center;gap:8px}.motor-dot{width:11px;height:11px;border-radius:50%;flex-shrink:0}.motor-dot.on{background:var(--accent);box-shadow:0 0 0 4px color-mix(in srgb,var(--accent) 25%,transparent)}.motor-dot.off{background:var(--text-muted)}.motor-state{font-size:1.1rem;font-weight:700;letter-spacing:.01em}.motor-state.on{color:var(--accent)}.motor-state.off{color:var(--text-muted)}.motor-action-btn{padding:10px 18px;border-radius:10px;font-weight:700;font-size:.9rem;border:none;cursor:pointer;white-space:nowrap;flex-shrink:0;min-width:92px}.motor-action-btn.start{background:var(--accent);color:var(--bg)}.motor-action-btn.stop{background:var(--danger);color:#fff}.motor-action-btn:disabled{opacity:.6;cursor:not-allowed}.pump-illo{margin:12px auto 4px;padding:6px 8px;background:linear-gradient(180deg,color-mix(in srgb,#aac6e8 18%,var(--surface)) 0%,var(--surface) 70%);border:1px solid var(--border);border-radius:10px;overflow:hidden;max-width:260px}.pump-illo svg{width:100%;height:auto;display:block;max-height:120px}.pump-illo.off svg{filter:saturate(.55) brightness(.92)}.pump-illo.on .impeller{animation:pump-spin .35s linear infinite}.water-body,.flow-orb,.water-drop,.water-puddle,.splash-drop{opacity:0}.water-drop{fill:#fff}.water-puddle{fill:#6dbef0}.splash-drop{fill:#fff}.pump-illo.on .water-body{opacity:1}.flow-orb{offset-rotate:auto;offset-distance:0%}.flow-orb.p-up{offset-path:path("M 252 26 C 298 26 344 44 382 84")}.flow-orb.p-mid{offset-path:path("M 252 32 C 298 32 348 56 388 100 C 408 122 416 148 418 162")}.flow-orb.p-low{offset-path:path("M 252 40 C 296 44 340 72 376 124 C 392 148 402 168 404 174")}.pump-illo.on .flow-orb{animation:flow-along .9s linear infinite}.pump-illo.on .flow-orb.p1{animation-delay:0s}.pump-illo.on .flow-orb.p2{animation-delay:-.3s}.pump-illo.on .flow-orb.p3{animation-delay:-.6s}.pump-illo.on .flow-orb.m1{animation-delay:-.05s}.pump-illo.on .flow-orb.m2{animation-delay:-.27s}.pump-illo.on .flow-orb.m3{animation-delay:-.5s}.pump-illo.on .flow-orb.m4{animation-delay:-.72s}.pump-illo.on .flow-orb.l1{animation-delay:-.15s}.pump-illo.on .flow-orb.l2{animation-delay:-.45s}.pump-illo.on .flow-orb.l3{animation-delay:-.7s}.pump-illo.on .water-drop{animation:water-emit .9s ease-out infinite}.pump-illo.on .water-drop.d1{animation-delay:0s}.pump-illo.on .water-drop.d2{animation-delay:.18s}.pump-illo.on .water-drop.d3{animation-delay:.36s}.pump-illo.on .water-drop.d4{animation-delay:.55s}.pump-illo.on .water-puddle{animation:water-puddle 1s ease-out infinite;transform-origin:404px 178px}.pump-illo.on .splash-drop{animation:splash-bounce 1.2s ease-out infinite}.pump-illo.on .splash-drop.sd1{animation-delay:.1s}.pump-illo.on .splash-drop.sd2{animation-delay:.5s}@keyframes pump-spin{to{transform:rotate(360deg)}}@keyframes flow-along{0%{offset-distance:0%;opacity:0}10%{opacity:.85}85%{opacity:.85}to{offset-distance:100%;opacity:0}}@keyframes water-emit{0%{transform:translate(-12px,-6px) scale(.6);opacity:0}25%{opacity:.95}to{transform:translate(8px,14px) scale(1.1);opacity:0}}@keyframes splash-bounce{0%{transform:translate(0) scale(.6);opacity:0}30%{transform:translateY(-10px) scale(1);opacity:.95}to{transform:translateY(4px) scale(.8);opacity:0}}@keyframes water-puddle{0%{transform:scaleX(.6);opacity:.35}60%{transform:scaleX(1.15);opacity:.7}to{transform:scaleX(.75);opacity:.4}}.device-status{display:inline-flex;align-items:center;gap:6px;padding:4px 10px;border-radius:999px;font-size:.75rem;font-weight:600;background:var(--surface);border:1px solid var(--border);white-space:nowrap}.device-status.online{color:var(--accent);border-color:var(--accent-dim)}.device-status.stale{color:var(--warning);border-color:var(--warning);background:#2a1f0a}.device-status.offline{color:var(--text-muted)}.device-status-spinner{width:12px;height:12px;border-radius:50%;border:2px solid var(--accent-dim);border-top-color:var(--accent);animation:device-spin .9s linear infinite;flex-shrink:0}.device-status.stale .device-status-spinner{border-color:#e0a84a59;border-top-color:var(--warning);animation-duration:1.6s}.device-status-dot{width:8px;height:8px;border-radius:50%;background:var(--danger);flex-shrink:0}@keyframes device-spin{to{transform:rotate(360deg)}}.profile-page{display:flex;flex-direction:column;gap:20px}.profile-card{display:flex;align-items:center;gap:16px}.profile-avatar{width:64px;height:64px;border-radius:50%;background:var(--accent);color:#0f2d17;display:flex;align-items:center;justify-content:center;font-size:1.6rem;font-weight:700;flex-shrink:0}.profile-info{display:flex;flex-direction:column;gap:4px;min-width:0}.profile-farm{font-size:1.05rem;font-weight:700;color:var(--accent)}.profile-email{font-size:.95rem;color:var(--text);word-break:break-all}.role-badge{align-self:flex-start;margin-top:4px;font-size:.7rem;font-weight:700;letter-spacing:.05em;text-transform:uppercase;background:var(--surface2);color:var(--accent);padding:2px 8px;border-radius:20px}.settings-section{display:flex;flex-direction:column;gap:10px}.settings-title{font-size:1.05rem;font-weight:600}.settings-hint{font-size:.85rem;color:var(--text-muted)}.font-size-options{display:grid;grid-template-columns:repeat(3,1fr);gap:10px}.font-size-option{background:var(--surface);border:2px solid var(--border);color:var(--text);border-radius:var(--radius);padding:14px 8px;display:flex;flex-direction:column;align-items:center;gap:6px}.font-size-option.selected{border-color:var(--accent);background:color-mix(in srgb,var(--accent) 14%,var(--surface));color:var(--accent)}.font-size-sample{font-weight:700;line-height:1}.font-size-option.font-small .font-size-sample{font-size:1rem}.font-size-option.font-medium .font-size-sample{font-size:1.4rem}.font-size-option.font-large .font-size-sample{font-size:1.9rem}.font-size-label{font-size:.8rem;color:var(--text-muted)}.font-size-option.selected .font-size-label{color:var(--accent)}.theme-options{display:flex;flex-direction:column;gap:10px}.theme-option{background:var(--surface);border:2px solid var(--border);color:var(--text);border-radius:var(--radius);padding:12px;display:flex;align-items:center;gap:12px;text-align:left}.theme-option.selected{border-color:var(--accent);background:color-mix(in srgb,var(--accent) 14%,var(--surface))}.theme-swatch{width:44px;height:44px;border-radius:8px;display:flex;align-items:center;justify-content:center;flex-shrink:0;font-weight:700}.theme-swatch.swatch-dark{background:#1a3d22;border:1px solid #2e6b38;color:#3ddc68}.theme-swatch.swatch-light{background:#fff;border:1px solid #c0d4c5;color:#1f8a3d}.theme-swatch.swatch-high-contrast{background:#000;border:2px solid #5dff8a;color:#fff}.swatch-text{font-size:1rem;line-height:1}.theme-text{display:flex;flex-direction:column;gap:2px;min-width:0}.theme-label{font-weight:600;font-size:.95rem}.theme-hint{font-size:.78rem;color:var(--text-muted)}.theme-option.selected .theme-hint{color:var(--accent)}.logout-btn{width:100%;padding:14px;font-size:1rem}@keyframes pulse{0%,to{opacity:.5}50%{opacity:1}}
