@font-face{font-family:Manrope;src:url(/fonts/Manrope-Regular.ttf) format("truetype");font-weight:400}@font-face{font-family:Manrope;src:url(/fonts/Manrope-Medium.ttf) format("truetype");font-weight:500}@font-face{font-family:Manrope;src:url(/fonts/Manrope-SemiBold.ttf) format("truetype");font-weight:600}@font-face{font-family:Manrope;src:url(/fonts/Manrope-Bold.ttf) format("truetype");font-weight:700}@font-face{font-family:SpaceGrotesk;src:url(/fonts/SpaceGrotesk-Medium.ttf) format("truetype");font-weight:500}@font-face{font-family:SpaceGrotesk;src:url(/fonts/SpaceGrotesk-SemiBold.ttf) format("truetype");font-weight:600}:root{font-family:Manrope,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;color:#161d19;background:#f4fbf4;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;--primary: #006c49;--on-primary: #ffffff;--primary-container: #10b981;--secondary: #57605e;--tertiary: #a43a3a;--tertiary-soft: rgb(252 124 120 / 20%);--danger: #ba1a1a;--danger-soft: #ffdad6;--background: #f4fbf4;--surface: #f4fbf4;--surface-lowest: #ffffff;--surface-low: #eef6ee;--surface-container: #e8f0e9;--surface-high: #dde4dd;--text: #161d19;--text-muted: #3c4a42;--outline: #6c7a71;--outline-variant: #bbcabf;--shadow: 0 4px 12px rgb(16 185 129 / 8%)}*{box-sizing:border-box}html{background:var(--background)}body{margin:0;min-width:320px;min-height:100vh;background:var(--background)}a{color:inherit;text-decoration:none}button,input{font:inherit}button{cursor:pointer}button:disabled,input:disabled{cursor:not-allowed;opacity:.55}input{width:100%;border:1px solid var(--outline-variant);border-radius:12px;background:var(--surface-low);color:var(--text);padding:14px 16px;outline:none}input:focus{border-color:var(--primary);background:var(--surface-lowest)}input[type=range]{accent-color:var(--primary);padding-inline:0}input[type=file]{background:var(--surface-lowest)}h1,h2,h3,p{margin:0}h1{color:var(--text);font-size:32px;font-weight:700;letter-spacing:-.3px;line-height:40px}h2{color:var(--text);font-size:18px;font-weight:600;line-height:24px}.center-screen,.center-card,.empty-state{min-height:60vh;display:grid;place-items:center;gap:16px;text-align:center;padding:32px}.loading-screen{min-height:calc(100vh - 62px - env(safe-area-inset-bottom));display:grid;place-items:center;align-content:center;gap:16px;padding:32px;background:var(--background);color:var(--primary)}.native-spinner{width:36px;height:36px;border:3px solid rgb(0 108 73 / 18%);border-top-color:var(--primary);border-radius:999px;animation:spin .8s linear infinite}.loading-label{color:var(--text-muted);font-size:14px;font-weight:500}@keyframes spin{to{transform:rotate(360deg)}}.center-card,.empty-state,.card-section,.card-form,.notice-card,.warn-card,.profile-empty{background:var(--surface-lowest);border:1px solid rgb(221 228 221 / 90%);border-radius:16px;box-shadow:var(--shadow)}.app-shell{min-height:100vh;padding-bottom:calc(62px + env(safe-area-inset-bottom));background:var(--background)}.page-shell{width:min(640px,100%);margin:0 auto;padding:env(safe-area-inset-top) 0 24px}.glass-tab-bar{position:fixed;right:0;bottom:0;left:0;z-index:30;padding-bottom:env(safe-area-inset-bottom);background:#f4fbf4;-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px)}.tab-border{height:1px;background:#10b98133}.tab-blur{position:relative;display:flex;min-height:62px;overflow:hidden;background:#f4fbf4b8;-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px)}.tab-blur:before{position:absolute;inset:0;content:"";background:#f4fbf48c;pointer-events:none}.tab-item{position:relative;z-index:1;flex:1;display:grid;place-items:center;align-content:center;gap:3px;min-width:0;border:0;background:transparent;color:var(--secondary);padding:8px 4px 6px;font-size:10px;font-weight:600;letter-spacing:.1px}.tab-item.active{color:var(--primary)}.auth-screen{min-height:100vh;display:grid;align-items:center;background:var(--background);padding:calc(24px + env(safe-area-inset-top)) 24px calc(24px + env(safe-area-inset-bottom))}.auth-card{width:min(440px,100%);margin:0 auto}.auth-card h1{margin-top:8px;margin-bottom:8px}.form,.card-form,.stack,.inline-form,.detail-stack{display:grid;gap:16px}.auth-card .form{margin-top:40px}.card-form,.card-section{padding:16px}.card-section{display:grid;gap:10px}.narrow{width:min(560px,100%);margin:0 auto;padding-inline:24px}label,.field-label{display:grid;gap:6px;color:var(--text-muted);font-size:13px;font-weight:600}.button,.ghost-button,.danger-button,.icon-button,.delete-button{display:inline-flex;align-items:center;justify-content:center;border:1px solid transparent;font-weight:600;transition:opacity .16s ease,transform .16s ease}.button:active,.ghost-button:active,.danger-button:active,.icon-button:active,.delete-button:active,.plant-card:active{opacity:.88;transform:scale(.98)}.button{min-height:54px;border-radius:16px;color:var(--on-primary);background:var(--primary);box-shadow:var(--shadow);padding:0 24px}.ghost-button{min-height:44px;border-radius:999px;color:var(--primary);background:var(--surface-low);padding:0 16px}.danger-button,.delete-button{min-height:52px;border-radius:16px;color:var(--danger);background:var(--danger-soft);padding:0 18px}.icon-button{width:40px;height:40px;border-radius:999px;color:var(--text);background:transparent}.small{min-height:38px;padding-inline:14px;font-size:.9rem}.eyebrow{color:var(--primary);font-family:SpaceGrotesk,Manrope,sans-serif;font-size:12px;font-weight:500;letter-spacing:.6px;line-height:12px;text-transform:uppercase}.muted{color:var(--text-muted);line-height:26px}.error-text{color:var(--danger);font-size:12px;font-weight:400}.page-header,.detail-header,.section-header,.plant-card-footer,.humidity-bar-label,.top-bar,.action-row,.metric-card,.notice-card,.sheet-option,.timeline-item-content,.resend-row,.loading-row{display:flex;align-items:center}.page-header{justify-content:space-between;gap:16px;padding:24px 24px 0}.add-button{width:38px;height:38px;border-radius:999px;color:var(--on-primary);background:var(--primary);box-shadow:var(--shadow)}.notice-card,.warn-card{gap:16px;padding:16px}.notice-card{background:var(--surface-low)}.warn-card{align-items:flex-start;background:var(--tertiary-soft)}.notice-icon-circle{flex:0 0 auto;display:grid;place-items:center;width:40px;height:40px;border-radius:999px;color:var(--primary);background:#10b98133}.plant-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:16px;padding:0 24px 16px}.plant-card{min-width:0;overflow:hidden;background:var(--surface-lowest);border-radius:16px;box-shadow:var(--shadow);transition:opacity .16s ease,transform .16s ease}.plant-card-image-wrap{position:relative;aspect-ratio:1;background:var(--surface-high)}.plant-card-image{width:100%;height:100%;object-fit:cover;display:block}.plant-card-body{display:grid;gap:2px;padding:8px}.plant-card-body h2{overflow:hidden;font-size:15px;font-weight:600;line-height:20px;text-overflow:ellipsis;white-space:nowrap}.plant-card-body p{overflow:hidden;color:var(--text-muted);font-size:10px;font-weight:500;letter-spacing:.5px;line-height:14px;text-overflow:ellipsis;text-transform:uppercase;white-space:nowrap}.scientific-name{overflow:hidden;margin-top:2px;color:var(--text-muted);font-family:SpaceGrotesk,Manrope,sans-serif;font-size:16px;font-weight:500;letter-spacing:.1px;line-height:22px;text-overflow:ellipsis;text-transform:capitalize;white-space:nowrap}.pill,.tag{display:inline-flex;align-items:center;width:fit-content;border-radius:999px;background:var(--surface-container);color:var(--text-muted);font-size:10px;font-weight:500;letter-spacing:.5px;text-transform:uppercase}.plant-card .pill{position:absolute;top:8px;right:8px;gap:3px;padding:4px 8px}.pill.alert{color:#711419;background:var(--danger-soft)}.pill.today{color:var(--primary);background:#d9e2df}.pill-dot{width:4px;height:4px;border-radius:999px;background:var(--outline-variant)}.pill.alert .pill-dot{background:var(--danger)}.pill.today .pill-dot{background:var(--primary)}.tag-row,.metrics-grid{display:flex;flex-wrap:wrap;gap:10px}.tag{gap:6px;padding:6px 10px}.tag:before{width:6px;height:6px;border-radius:999px;background:var(--primary);content:""}.empty-state{margin:0 24px;background:transparent;border:0;box-shadow:none;color:var(--secondary)}.plant-detail{background:var(--background)}.hero{position:relative;overflow:hidden;height:330px;background:var(--surface-high)}.hero-image{width:100%;height:100%;object-fit:cover;display:block}.hero:after{position:absolute;inset:auto 0 0;height:46%;content:"";background:linear-gradient(180deg,transparent,rgb(0 0 0 / 42%))}.hero-actions{position:fixed;top:calc(8px + env(safe-area-inset-top));right:max(16px,calc((100vw - 640px)/2 + 16px));left:max(16px,calc((100vw - 640px)/2 + 16px));z-index:2;display:flex;align-items:center;justify-content:space-between}.hero-action{display:grid;place-items:center;width:44px;height:44px;border:0;border-radius:999px;color:var(--text);background:#ffffff94;box-shadow:0 4px 12px #00000014;-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px)}.detail-content{display:grid;gap:24px;padding:24px}.detail-header{justify-content:space-between;align-items:flex-start;gap:16px}.top-actions-row{display:flex;justify-content:flex-end;gap:10px;margin-top:-44px}.action-chip{display:grid;place-items:center;width:44px;height:44px;border:0;border-radius:999px;color:var(--primary);background:var(--surface-lowest);box-shadow:var(--shadow)}.metrics-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr))}.metric-card{flex-direction:column;justify-content:flex-start;gap:8px;min-width:0;padding:16px;text-align:center;background:var(--surface-lowest);border-radius:16px;box-shadow:var(--shadow)}.metric-icon{display:grid;place-items:center;width:36px;height:36px;border-radius:999px;color:var(--primary);background:var(--surface-container)}.metric-card strong{font-size:13px;font-weight:600;line-height:18px}.humidity-card{display:grid;gap:18px;padding:18px;border:0;border-radius:24px;background:var(--surface-lowest);box-shadow:var(--shadow);text-align:left}.watering-card{display:grid;gap:20px;padding:18px;border-radius:24px;background:var(--surface-lowest);box-shadow:var(--shadow)}.watering-actions{display:grid;grid-template-columns:1fr 1fr;gap:10px}.watering-actions .button,.watering-actions .ghost-button{min-height:52px;padding-inline:12px;font-size:14px;text-align:center}.watering-dates{display:grid;gap:16px}.watering-dates div{display:grid;gap:6px}.watering-dates p{color:var(--text-muted);line-height:24px}.humidity-card-title{display:flex;align-items:center;justify-content:space-between;color:var(--text-muted);font-size:14px}.humidity-bar-block{display:grid;gap:8px}.humidity-bar-label{justify-content:space-between;gap:12px;color:var(--text-muted);font-size:14px}.humidity-bar-label strong{color:var(--primary);font-size:18px}.humidity-bar-track{overflow:hidden;height:12px;border-radius:999px;background:var(--surface-high)}.humidity-bar-fill{height:100%;border-radius:inherit;background:var(--primary)}.muted-fill{opacity:.35}.action-row{flex-wrap:wrap;gap:10px}.action-row .button,.action-row .ghost-button{flex:1 1 180px}.small-copy{color:var(--text-muted);font-size:12px;line-height:18px}.timeline{display:grid;gap:14px}.timeline-item{display:grid;grid-template-columns:36px 1fr;gap:12px;align-items:start}.timeline-dot{display:grid;place-items:center;width:36px;height:36px;border-radius:999px;color:var(--primary);background:var(--surface-container)}.timeline-item p{color:var(--text-muted);font-size:12px}.top-bar{justify-content:space-between;padding:8px 16px}.top-bar-title{font-size:18px;font-weight:600}.preview-image,.plant-image-preview{width:100%;height:260px;object-fit:cover;border-radius:24px;background:var(--surface-high)}.file-choice{display:grid;gap:10px}.file-choice input{position:absolute;width:1px;height:1px;overflow:hidden;clip:rect(0,0,0,0)}.suggestion-card{display:grid;gap:4px;padding:16px;border:1px solid var(--surface-high);border-radius:16px;background:var(--surface-low)}.suggestion-card strong{font-family:SpaceGrotesk,Manrope,sans-serif;font-size:16px;font-weight:500}.divider{height:1px;background:var(--outline-variant);margin-block:8px}.otp-row{display:grid;grid-template-columns:repeat(6,1fr);gap:8px}.otp-row input{aspect-ratio:1;padding:0;text-align:center;font-family:SpaceGrotesk,Manrope,sans-serif;font-size:22px;font-weight:600;border-width:1.5px;background:var(--surface-lowest)}.back-link{position:absolute;top:calc(24px + env(safe-area-inset-top));left:24px;color:var(--text-muted);font-size:16px}.resend-row,.loading-row{justify-content:center;gap:8px;color:var(--text-muted);font-size:14px}.resend-row button{border:0;background:transparent;color:var(--primary);font-weight:600}.profile-page{display:grid;gap:16px;padding:24px}.profile-header{display:flex;align-items:center;justify-content:space-between;gap:16px}.profile-edit-button{display:inline-flex;align-items:center;gap:5px;min-height:34px;border:1px solid rgb(0 108 73 / 19%);border-radius:999px;background:#006c4914;color:var(--primary);padding:0 14px;font-size:13px;font-weight:600}.profile-hero{display:grid;justify-items:center;gap:6px;padding:8px 0}.profile-avatar{display:grid;place-items:center;width:72px;height:72px;margin-bottom:4px;border:2px solid rgb(0 108 73 / 13%);border-radius:999px;background:#10b9812e;color:var(--primary);font-size:28px;font-weight:700}.profile-email{color:var(--text-muted);font-size:16px}.profile-verified{display:inline-flex;align-items:center;gap:4px;color:var(--primary);font-size:12px}.profile-card{overflow:hidden;border-radius:16px;background:var(--surface-lowest);box-shadow:var(--shadow)}.profile-field-row{display:flex;align-items:center;justify-content:space-between;gap:16px;width:100%;min-height:52px;border:0;background:transparent;padding:14px 16px;text-align:left}.profile-field-border{border-bottom:1px solid var(--surface-high)}.profile-field-label{flex:1;color:var(--secondary);font-size:13px;font-weight:600}.profile-field-value,.profile-field-input{flex:2;color:var(--text);font-size:16px;text-align:right}.profile-field-input{min-width:0;border:0;border-radius:0;background:transparent;padding:0}.profile-field-input:focus{background:transparent}.profile-picker-field{cursor:pointer}.profile-picker-value-row{flex:2;display:inline-flex;align-items:center;justify-content:flex-end;gap:4px;color:var(--outline)}.profile-field-value.is-placeholder{color:var(--outline)}.profile-actions{display:grid;gap:8px}.profile-save-button{width:100%}.profile-cancel-button,.profile-picker-cancel{border:0;background:transparent;color:var(--outline);padding:10px;font-size:16px}.profile-member-since{margin-top:4px;color:var(--outline);font-size:12px;text-align:center}.button-spinner{width:18px;height:18px;border:2px solid rgb(255 255 255 / 35%);border-top-color:var(--on-primary);border-radius:999px;animation:spin .8s linear infinite}.profile-picker-backdrop{position:fixed;inset:0;z-index:50;display:flex;align-items:flex-end;justify-content:center;background:#0000003d}.profile-picker-sheet{width:min(640px,100%);max-height:calc(100vh - 48px);overflow:hidden;border-radius:24px 24px 0 0;background:var(--surface-lowest);padding:10px 20px calc(10px + env(safe-area-inset-bottom));box-shadow:0 -18px 48px #161d192e}.profile-picker-handle{width:40px;height:4px;margin:0 auto 14px;border-radius:999px;background:var(--surface-high)}.profile-picker-sheet h2{margin-bottom:8px;text-align:center}.profile-picker-options{max-height:280px;overflow-y:auto}.profile-picker-option{display:flex;align-items:center;justify-content:space-between;width:100%;border:0;border-bottom:1px solid var(--surface-high);background:transparent;color:var(--text);padding:14px 4px;text-align:left}.profile-picker-option svg{color:var(--primary)}.profile-picker-empty{padding:16px 0;color:var(--outline);text-align:center}@media(min-width:760px){.page-shell{padding-top:24px}.plant-grid{grid-template-columns:repeat(3,minmax(0,1fr))}.glass-tab-bar{right:50%;left:auto;width:min(640px,100%);transform:translate(50%)}}@media(max-width:420px){.metrics-grid{grid-template-columns:1fr}}
