@import "https://fonts.googleapis.com/css2?family=Figtree:ital,wght@0,300..900;1,300..900&display=swap";@import "https://fonts.googleapis.com/css2?family=Figtree:ital,wght@0,300..900;1,300..900&display=swap";@import "https://fonts.googleapis.com/css2?family=Figtree:ital,wght@0,300..900;1,300..900&display=swap";@import "https://fonts.googleapis.com/css2?family=Figtree:ital,wght@0,300..900;1,300..900&display=swap";@import "https://fonts.googleapis.com/css2?family=Figtree:ital,wght@0,300..900;1,300..900&display=swap";@import "https://fonts.googleapis.com/css2?family=Figtree:ital,wght@0,300..900;1,300..900&display=swap";@import "https://fonts.googleapis.com/css2?family=Figtree:ital,wght@0,300..900;1,300..900&display=swap";.auth-brand{color:#1a1a1a;align-items:center;margin-bottom:.5rem;font-size:1.125rem;font-weight:700;display:flex}.auth-error{color:#c51605;margin-bottom:1rem;padding:1rem;font-size:1rem}.form-row{grid-template-columns:1fr 1fr;gap:1rem;display:grid}.form-field{flex-direction:column;gap:.5rem;display:flex}.form-field__password-wrapper{position:relative}.form-field__password-wrapper input{padding-right:4rem}.form-field__show-btn{color:#4a6741;cursor:pointer;background:0 0;border:none;padding:0;font-size:.875rem;font-weight:600;transition:all .2s ease-in-out;position:absolute;top:50%;right:.75rem;transform:translateY(-50%)}.form-field__show-btn:hover{opacity:.75}.form-field__hint{color:#6b6b6b;font-size:.75rem}.register-page{background:#edeae4;border-radius:20px;grid-template-columns:1fr 1fr;justify-content:center;align-items:center;max-width:1200px;min-height:600px;margin:2rem auto;display:grid;overflow:hidden;box-shadow:0 8px 48px #0000001f}@media (width<=768px){.register-page{grid-template-columns:1fr;margin:1rem}}.register-page__form-side{background:#fff;justify-content:center;align-items:flex-start;padding:3rem;display:flex;overflow-y:auto}.register-page__inner{width:100%;max-width:400px}.register-page__title{color:#1a1a1a;margin-bottom:.5rem;font-size:2rem;font-weight:700}.register-page__subtitle{color:#6b6b6b;margin-bottom:1.5rem;font-size:1rem}.register-page__form{flex-direction:column;gap:1rem;display:flex}.register-page__submit{color:#fff;cursor:pointer;background:#2d4a2d;border:none;border-radius:8px;margin-top:.5rem;padding:1rem;font-size:1rem;font-weight:600;transition:opacity .15s ease-in-out}.register-page__submit:hover:not(:disabled){opacity:.9}.register-page__submit:disabled{opacity:.5;cursor:not-allowed}.register-page__signin{text-align:center;color:#6b6b6b;margin-top:1rem;font-size:.875rem}.register-page__signin a{color:#4a6741;font-weight:600;text-decoration:none;transition:all .2s ease-in-out}.register-page__signin a:hover{text-decoration:underline}.register-page__panel{background:#2d4a2d;justify-content:center;align-items:center;height:100%;padding:3rem;display:flex}@media (width<=768px){.register-page__panel{display:none}}.register-page__panel-inner{flex-direction:column;gap:2rem;width:100%;max-width:380px;display:flex}.register-page__panel-eyebrow{color:#ffffffd9;background:#ffffff1a;border-radius:8px;align-items:center;gap:.5rem;width:fit-content;padding:.5rem 1rem;font-size:1rem;font-weight:600;display:inline-flex}.register-page__panel-dot{background:#7a9e6e;border-radius:50%;width:7px;height:7px;display:inline-block}.register-page__panel-headline{color:#fff;margin:0;font-size:clamp(1.75rem,3vw,2.25rem);font-weight:700;line-height:1.2}.register-page__zone-card{background:#fff;border-radius:12px;padding:1.25rem 1.5rem}.register-page__zone-header{color:#1a1a1a;align-items:center;gap:.5rem;margin-bottom:1rem;font-size:1rem;font-weight:600;display:flex}.register-page__zone-dot{background:#4a6741;border-radius:50%;width:8px;height:8px}.register-page__live{color:#4a6741;letter-spacing:.05em;background:#4a67411a;border-radius:8px;margin-left:auto;padding:.2rem .5rem;font-size:.875rem;font-weight:700}.register-page__zone-body{align-items:center;gap:1.5rem;display:flex}.register-page__moisture-ring{border:5px solid #7a9e6e;border-radius:50%;flex-direction:column;flex-shrink:0;justify-content:center;align-items:center;width:80px;height:80px;display:flex}.register-page__moisture-value{color:#1a1a1a;font-size:1.25rem;font-weight:700;line-height:1}.register-page__moisture-label{letter-spacing:.05em;color:#6b6b6b;margin-top:.2rem;font-size:.5rem;font-weight:600}.register-page__zone-stats{flex-direction:column;gap:.4rem;width:100%;margin:0;padding:0;font-size:.85rem;list-style:none;display:flex}.register-page__zone-stats li{color:#6b6b6b;justify-content:space-between;display:flex}.register-page__zone-highlight{color:#4a6741;font-weight:600}.register-page__bullets{flex-direction:column;gap:.85rem;margin:0;padding:0;list-style:none;display:flex}.register-page__bullets li{color:#ffffffd9;align-items:center;gap:.75rem;font-size:1rem;display:flex}.register-page__check{color:#7a9e6e;background:#7a9e6e40;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:22px;height:22px;font-size:.75rem;font-weight:700;display:inline-flex}.auth-success{color:#4a6741;background:#7a9e6e26;border-radius:8px;margin-bottom:1rem;padding:.75rem 1rem;font-size:.875rem}.login-page{background:#edeae4;border-radius:20px;grid-template-columns:1fr 1fr;max-width:1200px;min-height:600px;margin:5rem auto;display:grid;overflow:hidden;box-shadow:0 8px 48px #0000001f}@media (width<=768px){.login-page{grid-template-columns:1fr;margin:1rem}}.login-page__form-side{background:#fff;justify-content:center;align-items:center;padding:3rem;display:flex;overflow-y:auto}.login-page__inner{width:100%;max-width:400px}.login-page__title{color:#1a1a1a;margin-bottom:.5rem;font-size:2rem;font-weight:700}.login-page__subtitle{color:#6b6b6b;margin-bottom:1.5rem;font-size:1rem}.login-page__form{flex-direction:column;gap:1rem;display:flex}.login-page__submit{color:#fff;cursor:pointer;background:#2d4a2d;border:none;border-radius:8px;margin-top:.5rem;padding:1rem;font-size:1rem;font-weight:600;transition:opacity .15s ease-in-out}.login-page__submit:hover:not(:disabled){opacity:.9}.login-page__submit:disabled{opacity:.5;cursor:not-allowed}.login-page__register{text-align:center;color:#6b6b6b;margin-top:1rem;font-size:.875rem}.login-page__register a{color:#4a6741;font-weight:600;text-decoration:none;transition:all .2s ease-in-out}.login-page__register a:hover{text-decoration:underline}.login-page__panel{background:#2d4a2d;justify-content:center;align-items:center;height:100%;padding:3rem;display:flex}@media (width<=768px){.login-page__panel{display:none}}.login-page__panel-inner{flex-direction:column;gap:2rem;width:100%;max-width:380px;display:flex}.login-page__panel-headline{color:#fff;margin:0;font-size:clamp(1.75rem,3vw,2.25rem);font-weight:700;line-height:1.2}.app-layout{flex-direction:column;height:100dvh;display:flex}.app-layout__body{flex:1;display:flex;overflow:hidden}.app-layout__content{flex:1;padding:1.5rem;overflow-y:auto}.navbar{border-bottom:1px solid #e0e0e0;justify-content:space-between;align-items:center;padding:1rem 1.5rem;display:flex}.navbar__brand{color:#5c715e;font-weight:600}.navbar__user{align-items:center;gap:1rem;display:flex}.sidebar{border-right:1px solid #e0e0e0;flex-direction:column;width:220px;padding:1rem;display:flex}.sidebar__link{color:inherit;border-radius:4px;padding:.5rem .75rem;text-decoration:none;transition:all .2s ease-in-out}.sidebar__link:hover:not(:disabled){opacity:.9}.sidebar__link:disabled{opacity:.6}.sidebar__link--active{color:#edeae4;background-color:#5c715e;font-weight:600}.farms-list-page{padding:1rem 0}.farms-list-page h1{margin-bottom:1.5rem}.farms-list-page__error{color:#b00020}.farms-list-page__list{grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:1rem;margin:0;padding:0;list-style:none;display:grid}.farms-list-page__item{cursor:pointer;border:1px solid #e0e0e0;border-radius:8px;padding:1rem;transition:box-shadow .15s,border-color .15s}.farms-list-page__item:hover{border-color:#b0b0b0;box-shadow:0 2px 8px #00000014}.farms-list-page__item h3{margin:0 0 .5rem}.farms-list-page__item p{color:#666;margin:0 0 .75rem;font-size:.9rem}.farms-list-page__item span{color:#888;font-size:.85rem}.farm-dashboard-page{flex-direction:column;gap:20px;display:flex}.farm-dashboard-page__meta{flex-direction:column;display:flex}.device-list{grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:1rem;margin-top:10px;display:grid}.device-list__empty{color:#b0b0b0;margin-top:10px}.device-card{cursor:pointer;background-color:#faf8f7;border:2px solid #e0e0e0;border-radius:8px;padding:1rem;transition:box-shadow .15s ease-in-out,border-color .15s ease-in-out}.device-card:hover{border-color:#b0b0b0;box-shadow:0 2px 8px #00000014}.device-card__header{justify-content:space-between;align-items:center;gap:.5rem;margin-bottom:.5rem;display:flex}.device-card__header h3{text-overflow:ellipsis;white-space:nowrap;min-width:0;margin:0;overflow:hidden}.device-card__serial,.device-card__sensors{color:#888;margin:.25rem 0 0;font-size:.85rem}.device-card__status{border-radius:12px;padding:.2rem .5rem;font-size:.75rem;font-weight:600}.device-card__status--online{color:#2e7d32;background:#edeae4}.device-card__status--offline{color:#888;background:#edeae4}.device-dashboard-page{padding:1rem 0}.device-dashboard-page__loading,.device-dashboard-page__error{padding:1rem}.device-dashboard-page__error{color:#b00020}.device-dashboard-page__header{justify-content:space-between;align-items:flex-start;margin-bottom:2rem;display:flex}.device-dashboard-page__header h1{text-overflow:ellipsis;white-space:nowrap;min-width:0;margin:0 0 .25rem;overflow:hidden}.device-dashboard-page__serial{color:#888;margin:0;font-size:.85rem}.device-dashboard-page__meta{flex-direction:column;align-items:flex-end;gap:.5rem;display:flex}.device-dashboard-page__firmware{color:#888;font-size:.8rem}.device-dashboard-page__status{border-radius:12px;padding:.3rem .75rem;font-size:.85rem;font-weight:600}.device-dashboard-page__status--online{color:#2e7d32;background:#e8f5e9}.device-dashboard-page__status--offline{color:#888;background:#fafafa}.device-dashboard-page__section h2{margin:0 0 1rem}.zone-list{grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:1rem;margin-top:10px;display:grid}.zone-list__empty{color:#b0b0b0;margin-top:10px}.zone-card{cursor:pointer;background-color:#faf8f7;border:2px solid #e0e0e0;border-radius:8px;padding:1rem;transition:box-shadow .15s ease-in-out,border-color .15s ease-in-out}.zone-card:hover{border-color:#b0b0b0;box-shadow:0 2px 8px #00000014}.zone-card__header{justify-content:space-between;align-items:center;gap:.5rem;margin-bottom:.5rem;display:flex}.zone-card__header h3{text-overflow:ellipsis;white-space:nowrap;min-width:0;margin:0;overflow:hidden}.zone-card__threshold{color:#b0b0b0;margin:.25rem 0 0;font-size:.85rem}.zone-card__status{border-radius:12px;padding:.2rem .5rem;font-size:.75rem;font-weight:600}.zone-card__status--active{color:#2e7d32;background:#edeae4}.zone-card__status--inactive{color:#888;background:#edeae4}.sensor-list{grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:1rem;display:grid}.sensor-list__empty{color:#888}.sensor-card{cursor:pointer;border:1px solid #e0e0e0;border-radius:8px;padding:1rem;transition:box-shadow .15s,border-color .15s}.sensor-card:hover{border-color:#b0b0b0;box-shadow:0 2px 8px #00000014}.sensor-card__header{justify-content:space-between;align-items:center;gap:.5rem;margin-bottom:.5rem;display:flex}.sensor-card__header h3{text-overflow:ellipsis;white-space:nowrap;min-width:0;margin:0;overflow:hidden}.sensor-card__type{color:#888;margin:0 0 .5rem;font-size:.85rem}.sensor-card__thresholds{flex-direction:column;gap:.25rem;margin-top:.5rem;display:flex}.sensor-card__threshold{border-radius:4px;padding:.15rem .4rem;font-size:.8rem}.sensor-card__threshold--warning{color:#f57f17;background:#fff8e1}.sensor-card__threshold--critical{color:#b00020;background:#fdecea}.sensor-card__status{white-space:nowrap;border-radius:12px;padding:.2rem .5rem;font-size:.75rem;font-weight:600}.sensor-card__status--active{color:#2e7d32;background:#e8f5e9}.sensor-card__status--inactive{color:#888;background:#fafafa}.sensor-detail-page{padding:1rem 0}.sensor-detail-page__loading,.sensor-detail-page__error{padding:1rem}.sensor-detail-page__error{color:#b00020}.sensor-detail-page__header{justify-content:space-between;align-items:flex-start;margin-bottom:2rem;display:flex}.sensor-detail-page__header h1{text-overflow:ellipsis;white-space:nowrap;min-width:0;margin:0 0 .25rem;overflow:hidden}.sensor-detail-page__type{color:#888;margin:0;font-size:.9rem}.sensor-detail-page__status{white-space:nowrap;border-radius:12px;padding:.3rem .75rem;font-size:.85rem;font-weight:600}.sensor-detail-page__status--active{color:#2e7d32;background:#e8f5e9}.sensor-detail-page__status--inactive{color:#888;background:#fafafa}.sensor-detail-page__current,.sensor-detail-page__thresholds,.sensor-detail-page__history{margin-bottom:2rem}.sensor-detail-page__current h2,.sensor-detail-page__thresholds h2,.sensor-detail-page__history h2{margin:0 0 1rem}.sensor-detail-page__reading{align-items:baseline;gap:1rem;display:flex}.sensor-detail-page__value{font-size:2.5rem;font-weight:700}.sensor-detail-page__timestamp{color:#888;font-size:.85rem}*{box-sizing:border-box;margin:0;padding:0}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:#edeae4;font-family:Figtree,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif}body a{color:inherit;text-decoration:none}.btn{color:#fff;cursor:pointer;border:none;border-radius:8px;padding:8px 16px;font-size:.875rem;font-weight:600;transition:all .2s ease-in-out}.btn:hover:not(:disabled){opacity:.8}.btn:disabled{cursor:not-allowed;opacity:.6}.btn-primary{background-color:#4a6741}.btn-logout{background-color:#5c715e}.btn-ghost{color:#1a1a1a}label{color:#1a1a19;font-size:.875rem;font-weight:600}select,input{color:#1a1a1a;background:#faf8f7;border:1px solid #e0e0e0;border-radius:8px;outline:none;width:100%;padding:1rem;font-size:1rem;transition:border-color .15s ease-in-out,background .15s ease-in-out}select::placeholder,input::placeholder{color:#6b6b6b}select:focus,input:focus{background:#fff;border-color:#4a6741}input::placeholder{color:#b0b0b0;font-size:.75rem;font-weight:600}.landing-nav{z-index:100;background:#edeae4;border-bottom:2px solid #e0e0e0;justify-content:space-between;align-items:center;padding:1rem 3rem;display:flex;position:sticky;top:0}.landing-nav__brand{align-items:center;font-size:1.25rem;font-weight:700;display:flex}.landing-nav__links{color:#4a6741;gap:2rem;font-size:1rem;font-weight:600;display:flex}.landing-nav__links a{transition:opacity .2s ease-in-out}.landing-nav__links a:hover{opacity:.9}@media (width<=768px){.landing-nav__links{display:none}}.landing-nav__actions{align-items:center;gap:1rem;display:flex}.landing-nav__signin{color:#4a6741;font-size:.875rem;font-weight:700;transition:opacity .2s ease-in-out}.landing-nav__signin:hover{opacity:.9}.hero{grid-template-columns:1fr 1fr;align-items:center;gap:3rem;max-width:1400px;margin:0 auto;padding:3rem;display:grid}@media (width<=768px){.hero{grid-template-columns:1fr}}.hero__eyebrow{color:#4a6741;background:#4a67411a;border-radius:8px;margin-bottom:1.5rem;padding:6px 12px;font-size:1rem;font-weight:600;display:inline-flex}.hero__headline{color:#1a1a1a;max-width:460px;margin-bottom:1.5rem;font-size:3rem;font-weight:700;line-height:1.05}.hero__body{color:#6b6b6b;max-width:460px;margin-bottom:1.5rem;font-size:1.25rem}.hero__actions{flex-wrap:wrap;align-items:center;gap:1.25rem;margin-bottom:1.5rem;display:flex}.hero__perks{color:#1a1a1a;gap:1.5rem;font-size:.85rem;list-style:none;display:flex}.hero__perks li{color:#6b6b6b;font-weight:600}.hero__perks li:before{content:"/";color:#4a6741;margin-right:.4rem;font-weight:700}.hero__visual{background-image:url(/assets/wet-plants-DzyHuJVC.jpg);background-position:50%;background-size:cover;border-radius:20px;justify-content:flex-start;align-items:flex-end;min-height:480px;display:flex;position:relative;overflow:hidden}.hero__visual:after{content:"";pointer-events:none;background:linear-gradient(#0000 40%,#00000059 100%);border-radius:20px;position:absolute;inset:0}@media (width<=768px){.hero__visual{display:none}}.hero__card{z-index:1;-webkit-backdrop-filter:blur(2px);background:#00000080;border-radius:12px;width:280px;margin:1.5rem;padding:1.25rem;position:relative}.hero__card-header{align-items:center;gap:.5rem;margin-bottom:1.25rem;font-size:1rem;font-weight:600;display:flex}.hero__zone{color:#fff}.hero__zone-dot{background:#7a9e6e;border-radius:50%;width:8px;height:8px}.hero__live{color:#c51605;letter-spacing:.05em;background:#1a1a1a66;border-radius:4px;margin-left:auto;padding:.2rem .5rem;font-size:.75rem;font-weight:700}.hero__card-body{align-items:center;gap:1.5rem;margin-bottom:1.25rem;display:flex}.hero__moisture-ring{border:6px solid #7a9e6e;border-radius:50%;flex-direction:column;flex-shrink:0;justify-content:center;align-items:center;width:90px;height:90px;display:flex}.hero__moisture-value{color:#fff;font-size:1.25rem;font-weight:700;line-height:1}.hero__moisture-label{letter-spacing:.05em;color:#fff;margin-top:.15rem;font-size:.55rem;font-weight:700}.hero__stats{flex-direction:column;gap:.5rem;width:100%;margin:0;padding:0;font-size:.75rem;font-weight:600;list-style:none;display:flex}.hero__stats li{color:#fff;justify-content:space-between;display:flex}.hero__next-water{color:#7a9e6e;font-weight:600}
