:root{font-family:system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:light dark;color:#ffffffde;background-color:#242424;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{font-weight:500;color:#646cff;text-decoration:inherit}a:hover{color:#535bf2}body{margin:0;display:flex;place-items:center;min-width:320px;min-height:100vh}h1{font-size:3.2em;line-height:1.1}button{border-radius:8px;border:1px solid transparent;padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;background-color:#1a1a1a;cursor:pointer;transition:border-color .25s}button:hover{border-color:#646cff}button:focus,button:focus-visible{outline:4px auto -webkit-focus-ring-color}@media(prefers-color-scheme:light){:root{color:#213547;background-color:#fff}a:hover{color:#747bff}button{background-color:#f9f9f9}}html,body,#root,.landing-page{margin:0;padding:0;min-height:100%;width:100%;background-color:#020605!important}*,*:before,*:after{box-sizing:border-box}html{height:100%;font-size:14px}body{margin:0;padding:0;min-height:100%;font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;background:#ecfdf4;color:#022c22}#root{min-height:100vh}.app-root{display:grid;grid-template-columns:260px minmax(0,1fr);min-height:100vh;background:radial-gradient(circle at top left,#bbf7d0,#ecfdf3 55%)}.sidebar{background:#064e3b;color:#ecfdf5;padding:16px 12px;border-right:1px solid #065f46;display:flex;flex-direction:column}.main{padding:20px 24px 32px;display:flex;flex-direction:column;gap:16px;max-width:1240px;margin:0 auto}.main-header{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:4px}.main-header h1{font-size:1.4rem;font-weight:600;margin:0;color:#064e3b}.subheader-text{font-size:.8rem;color:#4b5563;margin-top:2px}.header-right{display:flex;align-items:center;gap:8px}.badge{display:inline-flex;align-items:center;padding:3px 8px;border-radius:999px;font-size:.75rem;background:#dcfce7;color:#166534}.card{background:#fff;border-radius:12px;border:1px solid #d1fae5;box-shadow:0 8px 20px #16653414;padding:14px 16px;display:flex;flex-direction:column;gap:8px}.card-flex{display:flex;flex-direction:column;gap:10px}.card-header{display:flex;align-items:center;justify-content:space-between}.card-title{font-size:.95rem;font-weight:600;color:#065f46;display:flex;align-items:center;gap:6px}.card-body{display:flex;flex-direction:column;gap:10px}.cards-row{display:grid;grid-template-columns:minmax(0,1.4fr) minmax(0,1fr);gap:12px}.section{margin-top:8px;display:flex;flex-direction:column;gap:10px}.section>h2{font-size:1rem;font-weight:600;margin:0 0 4px;color:#065f46}.small-text{font-size:.75rem;color:#6b7280}.greenhouse-card{background:none;border:none;box-shadow:none;padding:10px 4px 16px}.greenhouse-card .card-title{color:#ecfdf5;font-size:.95rem;margin-bottom:10px}.greenhouse-card .list{list-style:none;margin:0;padding:0 4px 0 0;display:flex;flex-direction:column;gap:8px;max-height:calc(100vh - 120px);overflow-y:auto}.greenhouse-card .list-item{padding:10px 12px;border-radius:12px;background:#022c22;border:1px solid #065f46;font-size:.9rem;cursor:pointer;display:flex;flex-direction:column;gap:2px;color:#ecfdf5;transition:background .12s ease,border-color .12s ease,transform .06s ease,color .12s ease}.greenhouse-card .list-item:hover{background:#064e3b;border-color:#16a34a;transform:translateY(-1px)}.greenhouse-card .list-item.selected{background:linear-gradient(135deg,#22c55e,#16a34a);border-color:transparent;color:#ecfdf5}.greenhouse-card .list-item .list-item-title{font-weight:600;font-size:.9rem}.greenhouse-card .list-item .list-item-sub{font-size:.75rem;color:#9ca3af}.greenhouse-card .list-item.selected .list-item-sub{color:#f0fdf4}.positions-list{list-style:none;margin:6px 0 0;padding:0;display:flex;flex-wrap:wrap;gap:8px}.position-pill{padding:5px 12px;border-radius:999px;border:1px solid #bbf7d0;background:#f0fdf4;font-size:.8rem;cursor:pointer;transition:background .12s ease,border-color .12s ease,transform .06s ease,color .12s ease}.position-pill:hover{background:#dcfce7;border-color:#86efac;transform:translateY(-1px)}.position-pill.selected{background:#16a34a;border-color:#15803d;color:#f0fdf4}.no-positions{font-size:.8rem;color:#6b7280}.time-pills{display:flex;flex-wrap:wrap;gap:6px}.pill-button{border-radius:999px;border:1px solid #bbf7d0;font-size:.8rem;padding:5px 10px;background:#f0fdf4;cursor:pointer;color:#065f46;display:inline-flex;align-items:center;gap:4px}.pill-button:hover{background:#dcfce7}.pill-button.active{background:#16a34a;color:#f0fdf4;border-color:#15803d}.pill-button.auto-refresh{font-weight:500}.pill-button.auto-refresh.on{background:#16a34a;border-color:#15803d;color:#ecfdf5}.pill-button.small{padding:3px 8px;font-size:.75rem}.time-label-pill{font-size:.75rem;padding:3px 8px;border-radius:999px;background:#dcfce7;color:#166534}.time-custom-block{display:flex;flex-direction:column;gap:6px}.time-custom-inputs{display:flex;gap:8px;flex-wrap:wrap}.time-custom-inputs label{display:block;font-size:.78rem;color:#6b7280;margin-bottom:2px}.time-custom-inputs input[type=datetime-local]{font-size:.78rem;padding:4px 6px;border-radius:8px;border:1px solid #bbf7d0;background:#f9fafb}.time-custom-preview{font-size:.78rem;color:#4b5563}.time-extra{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.time-extra-note{font-size:.78rem;color:#4b5563}.time-extra-select{font-size:.78rem;padding:3px 6px;border-radius:8px;border:1px solid #bbf7d0;background:#f0fdf4}.sensor-grid{display:grid;grid-template-columns:minmax(0,1fr);gap:14px}.sensor-card-outer{padding:12px}.sensor-card-header{display:flex;justify-content:space-between;align-items:center}.sensor-card-title{font-size:.95rem;font-weight:600;color:#065f46}.sensor-card-sub{font-size:.8rem;color:#6b7280}.sensor-subcards{display:grid;grid-template-columns:minmax(0,1.2fr) minmax(0,1.6fr);grid-template-rows:auto;gap:10px;margin-top:8px}.sensor-subcard{border-radius:10px;border:1px solid #d1fae5;background:#f0fdf4;padding:10px}.sensor-subcard-latest{background:#ecfdf5}.sensor-subcard-graph{background:#fff}.sensor-subcard-hourly{grid-column:1 / span 2}.sub-card-header{display:flex;align-items:center;justify-content:space-between;gap:6px;margin-bottom:6px}.sub-card-title{font-size:.85rem;font-weight:600;color:#065f46}.sub-card-subtitle{font-size:.75rem;color:#6b7280}.sensor-latest-header-right{display:flex;align-items:center;gap:6px}.sensor-latest-ts{font-size:.75rem;color:#6b7280;font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace}.sensor-graph-header{align-items:flex-start}.sensor-graph-header-right{display:flex;flex-direction:column;align-items:flex-end;gap:2px}.sensor-graph-range{font-size:.75rem;color:#6b7280;font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace}.sensor-metrics-row{display:flex;flex-wrap:wrap;gap:6px}.sensor-metric-tile{flex:1 1 80px;min-width:80px;padding:6px 8px;border-radius:10px;background:#fff;border:1px solid #d1fae5;cursor:pointer}.sensor-metric-tile:hover{border-color:#86efac;background:#f0fdf4}.sensor-metric-tile.active{border-color:#16a34a;background:#dcfce7}.sensor-metric-label{font-size:.78rem;color:#6b7280;margin-bottom:2px}.sensor-metric-value{font-size:1rem;font-weight:600;color:#022c22}.sensor-metric-unit{font-size:.78rem;color:#6b7280}.sensor-card-chart{margin-top:4px}.sensor-card-nochart{font-size:.8rem;color:#9ca3af}.hourly-table-wrapper{--hourly-row-height: 24px;max-height:calc(var(--hourly-row-height) * 10 + 32px);overflow-y:auto;border-radius:8px;border:1px solid #d1fae5;background:#fff}.hourly-table{width:100%;border-collapse:collapse;font-size:.78rem}.hourly-table thead{background:#ecfdf5;position:sticky;top:0;z-index:1}.hourly-table th,.hourly-table td{padding:4px 6px;border-bottom:1px solid #e5e7eb;text-align:right;white-space:nowrap}.hourly-table tbody tr{height:var(--hourly-row-height)}.hourly-table th{font-weight:500;color:#166534}.hourly-table td{color:#374151}.hourly-table th:first-child,.hourly-table td:first-child{text-align:left}.hourly-table tbody tr:nth-child(2n) td{background:#f0fdf4}.hourly-table tbody tr:hover td{background:#dcfce7}.camera-latest-image{width:100%;border-radius:10px;border:1px solid #d1fae5;object-fit:cover;max-height:220px}.camera-thumbs-row{margin-top:6px;display:grid;grid-template-columns:repeat(4,minmax(72px,1fr));gap:6px;max-height:240px;overflow-y:auto;padding-right:4px}.camera-thumb{width:72px;height:72px;border-radius:8px;border:1px solid #d1fae5;object-fit:cover;cursor:pointer}.camera-thumb:hover{border-color:#16a34a}.camera-more-text{margin-top:4px;font-size:.78rem;color:#6b7280}.error{font-size:.8rem;color:#b91c1c}@media(max-width:900px){.app-root{grid-template-columns:1fr}.sidebar{border-right:none;border-bottom:1px solid #065f46}.cards-row,.sensor-subcards{grid-template-columns:minmax(0,1fr)}.sensor-subcard-hourly{grid-column:auto}}.sensor-expand-btn{border-radius:999px;border:1px solid #bbf7d0;background:#f0fdf4;padding:3px 10px;font-size:.78rem;cursor:pointer;display:inline-flex;align-items:center;gap:4px;color:#065f46}.sensor-expand-btn:hover{background:#dcfce7;border-color:#86efac}.camera-latest-image-mini{width:100%;max-height:140px;object-fit:cover;border-radius:10px;border:1px solid #e5e7eb}.camera-thumb-active{border-color:#22c55e;box-shadow:0 0 0 2px #22c55e59}.sensor-card-subtext{margin-top:6px;font-size:11px;color:#6b7280}.sensor-subcards.single-col{grid-template-columns:minmax(0,1fr)}.sensor-subcards.single-col .sensor-subcard-latest{grid-column:1 / -1}.sensor-card-outer{width:100%;box-sizing:border-box}.sensor-graph-legend{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:6px}.sensor-legend-pill{display:inline-flex;align-items:center;gap:4px;padding:3px 8px;border-radius:999px;background:#f3f4f6;border:1px solid #e5e7eb;font-size:11px;color:#374151}.sensor-legend-dot{width:8px;height:8px;border-radius:999px;flex-shrink:0}.sensor-legend-label{font-weight:500}.sensor-legend-unit{font-size:10px;color:#6b7280}.sensor-tooltip{background:#fff;border-radius:8px;border:1px solid #e5e7eb;padding:6px 8px;box-shadow:0 10px 25px #0f172a29;font-size:11px;max-width:220px}.sensor-tooltip-ts{font-weight:600;color:#111827;margin-bottom:4px}.sensor-tooltip-row{display:flex;align-items:center;gap:4px;margin-top:2px}.sensor-tooltip-label{font-weight:500;color:#111827}.sensor-tooltip-unit{font-size:10px;color:#6b7280}.sensor-tooltip-value{margin-left:auto;font-weight:600;color:#111827}:root{--landing-bg: #050b09;--landing-bg-soft: #111c18;--landing-accent: #a6ff7a;--landing-accent-soft: rgba(166, 255, 122, .18);--landing-ink: #ffffff;--landing-muted: #c4d3cc;--landing-border: rgba(255, 255, 255, .06);--landing-chip-bg: rgba(255, 255, 255, .06);--landing-warning: #ffcc66}.landing-page{min-height:100vh;width:100%;margin:0;background:radial-gradient(1200px 700px at 0% 0%,rgba(166,255,122,.08),transparent 65%),radial-gradient(900px 600px at 100% 10%,rgba(72,179,224,.14),transparent 70%),linear-gradient(180deg,#050b09,#050b09 30%,#020605);color:var(--landing-ink);font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;padding:20px 24px 32px}.landing-nav{max-width:1120px;margin:0 auto 32px;display:flex;align-items:center;justify-content:space-between;gap:16px}.landing-logo-box{display:flex;align-items:center;gap:10px}.landing-logo-img{width:165px;height:72px;object-fit:contain;border-radius:0;border:none;background:transparent}.landing-logo-text{display:flex;flex-direction:column}.landing-logo-title{font-weight:700;letter-spacing:.04em;text-transform:uppercase;font-size:17px}.landing-logo-subtitle{font-size:12px;color:var(--landing-muted)}.landing-nav-right{display:flex;align-items:center;gap:14px}.landing-nav-link{font-size:14px;color:var(--landing-muted);text-decoration:none;padding:6px 10px;border-radius:8px;transition:background .15s ease,color .15s ease}.landing-nav-link:hover{background:#ffffff0f;color:var(--landing-ink)}.landing-nav-btn{font-size:14px;font-weight:600;padding:8px 14px;border-radius:999px;border:1px solid var(--landing-accent);text-decoration:none;color:#020604;background:var(--landing-accent);box-shadow:0 0 20px #a6ff7a40;transition:transform .15s ease,box-shadow .15s ease}.landing-nav-btn:hover{transform:translateY(-1px);box-shadow:0 0 26px #a6ff7a59}.landing-main{max-width:1120px;margin:0 auto}.landing-hero{display:grid;grid-template-columns:minmax(0,1.4fr) minmax(0,1fr);gap:32px;align-items:start;padding:16px 0 40px}.landing-hero-pill{display:inline-flex;align-items:center;gap:8px;padding:6px 11px;border-radius:999px;border:1px solid rgba(255,255,255,.12);background-color:#ffffff08;font-size:12px;color:var(--landing-muted)}.pill-dot{width:9px;height:9px;border-radius:50%;background:var(--landing-accent);box-shadow:0 0 12px #a6ff7ab3}.landing-hero-title{margin:18px 0 12px;font-size:clamp(32px,4vw,44px);line-height:1.1;letter-spacing:-.03em}.landing-hero-gradient{display:block;background:linear-gradient(120deg,#a6ff7a,#65ffc7,#fff);-webkit-background-clip:text;background-clip:text;color:transparent}.landing-hero-lead{margin:8px 0 20px;color:var(--landing-muted);font-size:15px;max-width:560px}.landing-hero-cta{display:flex;flex-wrap:wrap;gap:10px;margin-bottom:18px}.btn-primary,.btn-ghost{display:inline-flex;align-items:center;justify-content:center;padding:11px 18px;border-radius:999px;border:1px solid transparent;font-size:14px;font-weight:600;text-decoration:none;cursor:pointer;transition:background .16s ease,transform .16s ease,box-shadow .16s ease,border-color .16s ease,color .16s ease}.btn-primary{background:var(--landing-accent);color:#020604;box-shadow:0 0 20px #a6ff7a42}.btn-primary:hover{transform:translateY(-1px);box-shadow:0 0 28px #a6ff7a59}.btn-ghost{background:#ffffff08;color:var(--landing-ink);border-color:#ffffff2e}.btn-ghost:hover{background:#ffffff14}.btn-full{width:100%;justify-content:center}.landing-hero-metadata{display:flex;flex-wrap:wrap;gap:14px;margin-top:12px}.metadata-item{padding:8px 10px;border-radius:10px;border:1px solid rgba(255,255,255,.08);background:#010705cc;min-width:180px}.metadata-label{display:block;font-size:11px;text-transform:uppercase;letter-spacing:.08em;color:var(--landing-muted);margin-bottom:4px}.metadata-value{font-size:13px}.landing-hero-right{display:flex;flex-direction:column;gap:18px;max-width:460px;margin-left:auto}.landing-hero-image-wrapper{position:relative;width:100%;aspect-ratio:16 / 9;border-radius:24px;overflow:hidden;border:1px solid rgba(255,255,255,.08);background:radial-gradient(circle at 0 0,rgba(166,255,122,.08),transparent 60%)}.landing-hero-image{width:100%;height:100%;display:block;object-fit:cover}.landing-hero-image-badge{position:absolute;left:16px;bottom:16px;padding:6px 12px;border-radius:999px;font-size:12px;display:inline-flex;align-items:center;gap:8px;background:#0009;color:var(--landing-ink);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.landing-hero-telemetry-wrapper{width:100%}.landing-preview-card{width:100%;border-radius:24px;border:1px solid rgba(255,255,255,.12);background:radial-gradient(circle at top left,rgba(166,255,122,.08),transparent 55%),radial-gradient(circle at bottom right,rgba(72,179,224,.16),transparent 55%),#08100efa;padding:16px 16px 14px;box-shadow:0 20px 40px #00000073;-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px)}.preview-header{display:flex;flex-direction:column;gap:6px;margin-bottom:12px}.preview-badge{align-self:flex-start;font-size:11px;padding:4px 9px;border-radius:999px;border:1px solid rgba(166,255,122,.7);color:var(--landing-accent);background:#0a1812e6}.preview-title{font-size:14px;color:var(--landing-muted)}.preview-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:10px;margin-bottom:14px}.preview-metric{padding:8px;border-radius:10px;border:1px solid rgba(255,255,255,.08);background:#010705e6}.preview-label{display:block;font-size:11px;color:var(--landing-muted);margin-bottom:2px}.preview-value{display:block;font-size:16px;font-weight:600}.preview-chip{margin-top:4px;display:inline-flex;align-items:center;padding:2px 7px;border-radius:999px;font-size:10px;background:var(--landing-chip-bg);color:var(--landing-muted)}.preview-chip.warning{background:#ffcc6629;color:var(--landing-warning)}.preview-chip.neutral{background:#ffffff0f}.preview-chart-placeholder{margin:4px 0 12px;padding:8px 8px 10px;border-radius:12px;border:1px dashed rgba(255,255,255,.14);background:#010705f2}.preview-chart-label{font-size:11px;display:flex;justify-content:space-between;gap:8px;color:var(--landing-muted);margin-bottom:6px}.preview-chart-sub{opacity:.8}.preview-chart-bars{display:flex;align-items:flex-end;gap:6px;height:42px}.bar{flex:1;border-radius:999px;background:linear-gradient(180deg,#a6ff7ae6,#0a1e1433)}.bar-low{height:35%}.bar-medium{height:65%}.bar-high{height:95%;background:linear-gradient(180deg,#ffcc66f2,#2814044d)}.preview-footer{display:flex;justify-content:space-between;align-items:center;font-size:11px;color:var(--landing-muted)}.preview-footer-badges{display:inline-flex;align-items:center;gap:6px}.badge-dot{width:7px;height:7px;border-radius:50%;background:var(--landing-accent)}.badge-dot-yellow{background:#fc6}.badge-dot-blue{background:#48b3e0}.landing-section{padding:24px 0 10px}.landing-section-header{max-width:640px;margin-bottom:16px}.landing-section-header h2{margin:0 0 8px;font-size:24px}.landing-section-header p{margin:0;font-size:14px;color:var(--landing-muted)}.landing-cards{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:16px}.landing-card{padding:16px 14px 14px;border-radius:14px;border:1px solid var(--landing-border);background:#050c0af5}.landing-card-icon{width:30px;height:30px;border-radius:11px;border:1px solid rgba(255,255,255,.16);display:grid;place-items:center;margin-bottom:10px;font-size:17px}.landing-card h3{margin:0 0 6px;font-size:16px}.landing-card p{margin:0;font-size:13px;color:var(--landing-muted)}.landing-how{display:flex;gap:40px;align-items:flex-start}.landing-how-left{flex:1 1 0}.landing-how-left h2{margin:0 0 8px;font-size:22px}.landing-how-left p{margin:0 0 12px;font-size:14px;color:var(--landing-muted)}.landing-list{list-style:none;margin:0;padding:0;display:grid;gap:10px}.landing-list li{display:grid;grid-template-columns:auto minmax(0,1fr);gap:10px}.list-dot{width:10px;height:10px;border-radius:50%;background:var(--landing-accent);margin-top:6px}.landing-list strong{font-size:14px}.landing-list p{margin:2px 0 0;font-size:13px;color:var(--landing-muted)}.landing-how-right{display:flex;flex-direction:column;gap:18px;max-width:460px;margin-left:auto}.landing-rollup-card{border-radius:24px;overflow:hidden;border:1px solid rgba(255,255,255,.1);background:radial-gradient(circle at 0 0,rgba(166,255,122,.06),transparent 55%);width:100%;aspect-ratio:16 / 9}.landing-rollup-image{width:100%;height:100%;object-fit:cover;display:block}.landing-dashboard-callout{width:100%;border-radius:24px;padding:18px 20px;border:1px solid rgba(255,255,255,.08);background:linear-gradient(145deg,#a6ff7a29,#050c0afa)}.landing-dashboard-callout h3{margin:0 0 8px}.landing-dashboard-callout p{margin:0 0 14px;font-size:14px;color:var(--landing-muted)}.landing-cta-band{padding-top:14px}.cta-band-inner{border-radius:18px;border:1px solid rgba(255,255,255,.16);background:linear-gradient(130deg,#a6ff7a29,#000000e6);padding:18px 18px 14px;display:flex;flex-wrap:wrap;gap:14px;align-items:center;justify-content:space-between}.cta-band-inner h2{margin:0 0 6px;font-size:20px}.cta-band-inner p{margin:0;font-size:14px;color:var(--landing-muted)}.cta-band-actions{display:flex;flex-wrap:wrap;gap:10px}.landing-footer{margin-top:32px;border-top:1px solid rgba(255,255,255,.08);padding-top:16px}.landing-footer-inner{max-width:1120px;margin:0 auto;font-size:13px;color:var(--landing-muted)}.landing-footer-inner a{color:#48b3e0;text-decoration:none}.landing-footer-inner a:hover{text-decoration:underline}.footer-main{display:flex;flex-wrap:wrap;gap:4px}.footer-copy{margin-top:4px;font-size:12px}@media(max-width:900px){.landing-hero{grid-template-columns:minmax(0,1fr)}.landing-hero-right{order:-1;max-width:100%}.landing-how{flex-direction:column}.landing-how-right{max-width:100%;margin-left:0}.landing-nav{flex-direction:column;align-items:flex-start}.landing-nav-right{align-self:stretch;justify-content:flex-start;flex-wrap:wrap}.landing-cards{grid-template-columns:minmax(0,1fr)}}@media(max-width:600px){.landing-page{padding-inline:16px}.landing-hero-image-wrapper,.landing-rollup-card{aspect-ratio:4 / 3}.cta-band-inner{align-items:flex-start}}
