@import url("https://fonts.googleapis.com/css2?family=Doto:wght@400;600;700&family=Space+Grotesk:wght@300;400;500;700&family=Space+Mono:wght@400;700&display=swap");:root{--black:#f5f5f5;--surface:#ffffff;--surface-raised:#f0f0f0;--border:#e8e8e8;--border-visible:#cccccc;--text-disabled:#999999;--text-secondary:#666666;--text-primary:#1a1a1a;--text-display:#000000;--accent:#d71921;--care-pink:#e05a87;--success:#4a9e5c;--warning:#d4a843;--ambient-glow:rgba(0,0,0,0.05);--dot-color:rgba(0,0,0,0.1);--panel-translucent:rgba(255,255,255,0.78);--nav-bg:rgba(255,255,255,0.96);--photo-line:rgba(255,255,255,0.36);--capture-gradient:linear-gradient(0deg,rgba(0,0,0,0.82),transparent 58%);--space-xs:4px;--space-sm:8px;--space-md:16px;--space-lg:24px;--space-xl:32px;--space-2xl:48px;--radius-compact:8px;--radius-panel:16px}*{box-sizing:border-box}html{background:var(--black)}body{min-height:100vh;margin:0;color:var(--text-primary);background:radial-gradient(circle at 50% 0,var(--ambient-glow),transparent 24rem),var(--black);font-family:Space Grotesk,DM Sans,system-ui,sans-serif}button,input,textarea{font:inherit}button{color:inherit;cursor:pointer}.app-shell{min-height:100vh;display:grid;place-items:center;padding:24px;color:var(--text-primary);background:radial-gradient(circle at 50% 0,var(--ambient-glow),transparent 24rem),var(--black)}.app-shell[data-theme=dark]{--black:#000000;--surface:#111111;--surface-raised:#1a1a1a;--border:#222222;--border-visible:#333333;--text-disabled:#666666;--text-secondary:#999999;--text-primary:#e8e8e8;--text-display:#ffffff;--ambient-glow:rgba(255,255,255,0.08);--dot-color:rgba(255,255,255,0.09);--panel-translucent:rgba(17,17,17,0.72);--nav-bg:rgba(17,17,17,0.96)}.phone-frame{position:relative;width:min(100%,430px);height:min(920px,calc(100vh - 48px));min-height:720px;overflow:hidden;border:1px solid var(--border-visible);border-radius:34px;background:var(--black)}.phone-frame:before{content:"";position:absolute;inset:0;pointer-events:none;background-image:radial-gradient(circle,var(--dot-color) .5px,transparent .5px);background-size:14px 14px;-webkit-mask-image:linear-gradient(180deg,#000,transparent 42%);mask-image:linear-gradient(180deg,#000,transparent 42%);opacity:.75}.screen{position:relative;z-index:1;height:100%;overflow-y:auto;padding:32px 18px 112px;scrollbar-width:none}.screen::-webkit-scrollbar{display:none}.screen--loading{display:grid;align-content:center;justify-items:start;grid-gap:var(--space-sm);gap:var(--space-sm)}.storage-warning{position:absolute;z-index:6;top:14px;right:14px;left:14px;padding:12px 14px;border:1px solid var(--accent);border-radius:var(--radius-compact);background:var(--surface);color:var(--accent);font-size:13px;line-height:1.45}.loading-mark{color:var(--text-display);font-family:Doto,Space Mono,monospace;font-size:82px;font-weight:700;line-height:.9}.meter__header,.plant-portrait__overlay,.section-heading,.topbar{display:flex;align-items:center;justify-content:space-between}.topbar{gap:var(--md);margin-bottom:var(--space-lg)}.eyebrow,.hero-caption,.log-form span,.manual-grid span,.meter__header,.plant-form span,.plant-row__id,.section-heading,.timeline-item>span{color:var(--text-secondary);font-family:Space Mono,monospace;font-size:11px;letter-spacing:.08em;line-height:1.2;text-transform:uppercase}h1,h2,p{margin:0}h1{margin-top:4px;font-size:32px;letter-spacing:0;line-height:1.05}h1,h2{color:var(--text-display);font-weight:500}h2{margin-top:8px;font-size:28px;line-height:1.1}.garden-name-button,.garden-name-input{display:block;width:min(100%,260px);margin-top:4px;padding:0;border:0;outline:0;background:transparent;color:var(--text-display);font-family:Space Grotesk,DM Sans,system-ui,sans-serif;font-size:48px;font-weight:700;letter-spacing:0;line-height:1.05;text-align:left}.garden-name-input{border-bottom:1px solid var(--border-visible)}.icon-button,.section-heading>button:not(.section-action){width:44px;height:44px;display:inline-grid;place-items:center;border:1px solid var(--border-visible);border-radius:999px;background:var(--surface)}.icon-button.is-active,.section-heading>button:not(.section-action).is-active{background:var(--text-display);color:var(--black)}.inline-panel{display:grid;grid-template-columns:repeat(2,1fr);grid-gap:var(--space-sm);gap:var(--space-sm);margin-bottom:var(--space-md)}.inline-panel div{display:grid;grid-gap:8px;gap:8px;padding:12px;border:1px solid var(--border);border-radius:var(--radius-compact);background:var(--surface)}.theme-switch{width:-moz-fit-content;width:fit-content;min-height:32px;padding:0 12px;border:1px solid var(--border-visible);border-radius:999px;background:var(--text-display);color:var(--black);font-weight:700;letter-spacing:.06em}.inline-panel span,.theme-switch{font-family:Space Mono,monospace;font-size:11px}.inline-panel span{color:var(--text-secondary);letter-spacing:.08em;text-transform:uppercase}.inline-panel strong{color:var(--text-display);font-size:14px;font-weight:500}.hero-panel{padding:18px;border:1px solid var(--border-visible);border-radius:var(--radius-panel);background-color:var(--surface)}.dot-grid{background-image:radial-gradient(circle,var(--border-visible) 1px,transparent 1px);background-size:16px 16px}.hero-stats{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));grid-gap:var(--space-lg);gap:var(--space-lg)}.hero-number{color:var(--text-display);font-family:Doto,Space Mono,monospace;font-size:82px;font-weight:700;letter-spacing:0;line-height:.88}.hero-number--garden{color:var(--success)}.hero-number--care{color:var(--care-pink)}.save-button,.section-action{min-height:44px;display:inline-flex;align-items:center;justify-content:center;gap:8px;border:0;border-radius:999px;background:var(--text-display);color:var(--black);font-family:Space Mono,monospace;font-size:12px;font-weight:700;letter-spacing:.06em}.section-action{padding:0 18px}.section-action:disabled{opacity:.36}.section-action--ghost{border:1px solid var(--border-visible);background:var(--surface);color:var(--text-display)}.section-actions{display:inline-flex;gap:8px}.section-block{display:grid;grid-gap:var(--space-md);gap:var(--space-md);margin-top:var(--space-xl)}.section-block--last{padding-bottom:var(--space-xl)}.section-heading{min-height:28px}.empty-state,.meters,.plant-form,.plant-list,.timeline{display:grid;grid-gap:var(--space-sm);gap:var(--space-sm)}.empty-state,.plant-form{padding:18px;border:1px solid var(--border-visible);border-radius:var(--radius-panel);background:var(--panel-translucent)}.plant-modal-backdrop{position:absolute;z-index:5;inset:0;display:grid;place-items:center;padding:18px;background:radial-gradient(circle,var(--dot-color) .7px,transparent .7px),color-mix(in srgb,var(--black) 88%,transparent);background-size:14px 14px,auto}.plant-form--modal{position:relative;width:min(100%,368px);max-height:calc(100% - 36px);overflow-y:auto;background:var(--surface);border-color:var(--text-display);border-radius:var(--radius-panel);gap:14px;padding:16px}.plant-form--modal:before{content:"";position:absolute;top:18px;right:64px;width:8px;height:8px;border-radius:999px;background:var(--accent)}.plant-form__header{display:flex;align-items:flex-start;justify-content:space-between;gap:var(--space-md);padding-bottom:4px}.plant-form__header h2{margin-top:2px;font-size:30px;line-height:.95}.plant-form__header .icon-button{width:36px;height:36px;border-color:var(--text-display);border-radius:var(--radius-compact);color:var(--text-display);font-family:Space Mono,monospace;font-size:22px;line-height:1}.plant-form__fields{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));grid-gap:10px;gap:10px}.empty-state--large{min-height:420px;align-content:center}.empty-state strong{color:var(--text-display);font-size:22px;font-weight:500}.empty-state p{color:var(--text-secondary);font-size:14px;line-height:1.55}.plant-form label{display:grid;grid-gap:8px;gap:8px}.plant-form input{width:100%;min-height:44px;padding:0 12px;border:1px solid var(--border);border-radius:4px;outline:0;background:var(--black);color:var(--text-display);font-family:Space Mono,monospace;font-size:13px}.plant-form input:focus{border-color:var(--text-display)}.plant-form input::placeholder{color:var(--text-disabled)}.file-picker{min-height:46px;display:grid;place-items:center;border:1px dashed var(--border-visible);border-radius:var(--radius-compact);background:var(--surface)}.capture-button input,.file-picker input,.photo-picker input{display:none}.photo-picker{position:relative;display:grid;padding:16px 18px 18px;border:1px solid var(--text-display);border-radius:12px;background:var(--black)}.photo-picker:before{content:"CAMERA / PLANT-01";position:absolute;z-index:1;top:24px;left:28px;padding:3px 6px;background:var(--text-display);color:var(--black);font-family:Space Mono,monospace;font-size:10px;letter-spacing:.08em}.photo-picker__frame{min-height:210px;display:grid;grid-gap:12px;gap:12px;align-content:center;justify-items:center;padding:28px 16px 16px;border:1px solid var(--border);border-radius:8px;background:var(--surface)}.photo-picker img{width:100%;max-height:170px;aspect-ratio:16/9;border:0;border-radius:6px;object-fit:cover;background:var(--surface);filter:saturate(.82) contrast(1.06)}.photo-picker img.photo-picker__placeholder{width:min(88%,270px);max-height:190px;margin:8px 0 22px;object-fit:cover;padding:0;transform:scale(1.35)}.photo-picker span{justify-self:center;min-height:30px;display:inline-flex;align-items:center;justify-content:center;padding:0 10px;border:1px dashed var(--text-secondary);border-radius:999px;color:var(--text-secondary);font-family:Space Mono,monospace;font-size:11px;letter-spacing:.06em}.capture-panel__text small,.photo-picker small{color:var(--accent);font-family:Space Mono,monospace;font-size:10px;letter-spacing:.06em}.save-button:disabled{opacity:.36}.plant-row{position:relative;width:100%;display:grid;grid-template-columns:104px 1fr 20px;align-items:center;grid-gap:14px;gap:14px;min-height:132px;padding:14px;border:1px solid var(--border);border-radius:16px;background:var(--panel-translucent);text-align:left}.plant-row.is-active{border-color:var(--border-visible)}.plant-row img{width:104px;height:104px;border-radius:12px;object-fit:cover;filter:saturate(.82) contrast(1.05)}.status-light{position:absolute;top:16px;left:106px;width:10px;height:10px;border:2px solid var(--black);border-radius:999px;background:var(--success)}.status-light.is-watch{background:var(--warning)}.status-light.is-urgent{background:var(--accent)}.plant-row__text{min-width:0;display:grid;grid-gap:4px;gap:4px}.plant-row strong{overflow:hidden;color:var(--text-display);font-size:21px;font-weight:500;text-overflow:ellipsis;white-space:nowrap}.plant-row small{color:var(--text-secondary);font-size:14px}.plant-portrait{position:relative;height:264px;overflow:hidden;border:1px solid var(--border-visible);border-radius:var(--radius-panel);background:var(--surface)}.capture-panel img,.plant-portrait img{width:100%;height:100%;object-fit:cover;filter:saturate(.9) contrast(1.05)}.plant-portrait__overlay{position:absolute;right:12px;bottom:12px;left:12px;padding-top:12px;border-top:1px solid var(--photo-line);color:var(--text-display);font-family:Space Mono,monospace;font-size:11px;letter-spacing:.08em}.gallery-button{position:absolute;right:14px;bottom:54px;z-index:1;width:48px;height:48px;display:grid;place-items:center;border:1px solid var(--text-display);border-radius:999px;background:var(--text-display);color:var(--black)}.detail-hero{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));align-items:start;grid-gap:var(--space-sm);gap:var(--space-sm);margin-top:var(--space-xl)}.detail-metric{min-width:0;display:grid;grid-gap:8px;gap:8px;padding:12px 0;border-top:1px solid var(--border);border-bottom:1px solid var(--border)}.detail-metric__value{display:block;overflow-wrap:anywhere;color:var(--text-display);font-family:Space Mono,monospace;font-size:24px;font-weight:700;letter-spacing:.02em;line-height:1}.quick-care{position:relative;display:grid;grid-gap:14px;gap:14px;margin-top:var(--space-xl);padding:14px;border:1px solid var(--border-visible);border-radius:var(--radius-panel);background:radial-gradient(circle,var(--dot-color) .8px,transparent .8px),var(--panel-translucent);background-size:16px 16px}.quick-care.is-due:after{content:"";position:absolute;top:14px;right:14px;width:8px;height:8px;border-radius:999px;background:var(--accent)}.quick-care__body,.quick-care__header,.quick-care__status{display:flex;align-items:center;justify-content:space-between;gap:var(--space-md)}.quick-care__header strong{display:block;margin-top:4px;color:var(--text-display);font-size:28px;font-weight:500;line-height:1}.quick-care__status button,.quick-care__toggle{min-height:34px;padding:0 12px;border:1px solid var(--border-visible);border-radius:999px;background:var(--surface);color:var(--text-display);font-family:Space Mono,monospace;font-size:11px}.quick-care__body{align-items:end}.quick-care__body span,.quick-care__status{color:var(--text-secondary);font-family:Space Mono,monospace;font-size:11px;letter-spacing:.08em;text-transform:uppercase}.quick-care__body strong{display:block;margin-top:5px;color:var(--text-display);font-family:Space Mono,monospace;font-size:18px;line-height:1}.quick-care__complete{min-height:46px;display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:0 18px;border:1px solid var(--text-display);border-radius:999px;background:var(--text-display);color:var(--black);font-weight:700}.quick-care__editor{display:grid;grid-gap:var(--space-sm);gap:var(--space-sm);padding-top:var(--space-sm);border-top:1px solid var(--border)}.quick-care__actions{display:grid;grid-template-columns:repeat(4,1fr);grid-gap:6px;gap:6px}.quick-care__actions button{min-height:58px;display:grid;place-items:center;grid-gap:5px;gap:5px;padding:8px 4px;border:1px solid var(--border);border-radius:var(--radius-compact);background:var(--surface);color:var(--text-secondary);font-size:11px}.quick-care__actions button.is-selected{border-color:var(--text-display);color:var(--text-display)}.quick-care__editor textarea{width:100%;resize:none;padding:12px;border:1px solid var(--border-visible);border-radius:var(--radius-compact);outline:0;background:var(--surface);color:var(--text-display);font-family:Space Mono,monospace;font-size:13px;line-height:1.45}.quick-care__status{padding-top:var(--space-sm);border-top:1px solid var(--border)}.quick-care__status button{min-height:28px;color:var(--accent)}.meter{padding:14px;border:1px solid var(--border);border-radius:var(--radius-compact);background:var(--panel-translucent)}.meter__header{margin-bottom:12px}.meter__header strong{color:var(--text-display);font-family:Space Mono,monospace;font-size:16px}.meter__header small{color:var(--text-secondary);font-size:10px}.meter__segments{display:grid;grid-template-columns:repeat(10,1fr);grid-gap:2px;gap:2px}.meter__segments span{height:10px;background:var(--border)}.meter__segments .is-filled{background:var(--text-display)}.meter__segments--good .is-filled{background:var(--success)}.meter__segments--warning .is-filled{background:var(--warning)}.meter__segments--danger .is-filled{background:var(--accent)}.observation{padding:16px;border:1px solid var(--border);border-radius:var(--radius-compact);color:var(--text-primary);background:var(--panel-translucent);font-size:15px;line-height:1.55}.timeline-item{display:grid;grid-template-columns:56px 1fr;grid-gap:var(--space-md);gap:var(--space-md);padding:14px 0;border-top:1px solid var(--border)}.timeline-item strong{display:block;color:var(--text-display);font-size:16px;font-weight:500}.timeline-item small{display:block;margin-top:4px;color:var(--text-secondary);font-family:Space Mono,monospace;font-size:11px}.timeline-item p{margin-top:8px;color:var(--text-secondary);font-size:14px;line-height:1.45}.gallery-title{text-align:right}.gallery-list{display:grid;grid-gap:var(--space-lg);gap:var(--space-lg);padding-bottom:var(--space-xl)}.gallery-item{display:grid;grid-gap:var(--space-sm);gap:var(--space-sm);padding-bottom:var(--space-lg);border-bottom:1px solid var(--border)}.gallery-item img{width:100%;aspect-ratio:4/3;border:1px solid var(--border-visible);border-radius:var(--radius-panel);object-fit:cover}.gallery-item div{display:flex;align-items:center;justify-content:space-between;gap:var(--space-md)}.gallery-item span{color:var(--text-secondary);font-family:Space Mono,monospace;font-size:11px;letter-spacing:.08em}.gallery-item strong{color:var(--text-display);font-size:18px;font-weight:500}.capture-panel{position:relative;height:300px;overflow:hidden;border:1px solid var(--border-visible);border-radius:22px;background:var(--surface)}.capture-panel:after{content:"";position:absolute;inset:0;background:var(--capture-gradient)}.capture-button{position:absolute;z-index:1;right:16px;bottom:16px;width:64px;height:64px;display:grid;place-items:center;border:1px solid var(--text-display);border-radius:999px;background:var(--text-display);color:var(--black);cursor:pointer}.capture-button.is-captured{background:var(--success);border-color:var(--success);color:var(--black)}.capture-panel__text{position:absolute;z-index:1;left:18px;bottom:20px;display:grid;grid-gap:4px;gap:4px}.capture-panel__text span{color:var(--text-secondary);font-family:Space Mono,monospace;font-size:11px;letter-spacing:.08em}.capture-panel__text strong{color:var(--text-display);font-size:26px;font-weight:500}.action-grid{display:grid;grid-template-columns:repeat(3,1fr);grid-gap:var(--space-sm);gap:var(--space-sm)}.action-grid button{min-height:78px;display:grid;place-items:center;grid-gap:8px;gap:8px;border:1px solid var(--border);border-radius:12px;background:var(--surface);color:var(--text-secondary)}.action-grid button.is-selected{border-color:var(--text-display);color:var(--text-display)}.action-grid span{font-family:Space Mono,monospace;font-size:11px;letter-spacing:.08em;text-transform:uppercase}.log-form{display:grid;grid-gap:var(--space-md);gap:var(--space-md);margin-top:var(--space-xl);padding-bottom:var(--space-xl)}.log-form label{display:grid;grid-gap:8px;gap:8px}.log-form input,.log-form textarea{width:100%;border:1px solid var(--border-visible);border-radius:var(--radius-compact);outline:0;background:var(--surface);color:var(--text-display);font-family:Space Mono,monospace;font-size:14px}.log-form textarea{resize:none;padding:14px;line-height:1.45}.log-form input{min-height:48px;padding:0 14px}.form-row{display:grid;grid-template-columns:repeat(2,1fr);grid-gap:var(--space-sm);gap:var(--space-sm)}.save-button{width:100%;padding:0 18px}.manual-page{min-height:620px;padding:24px;border:1px solid var(--border-visible);border-radius:var(--radius-panel);background:linear-gradient(var(--border) 1px,transparent 1px),linear-gradient(90deg,var(--border) 1px,transparent 1px),var(--surface);background-size:24px 24px}.manual-page p{margin-top:16px;color:var(--text-secondary);font-size:15px;line-height:1.6}.manual-grid{display:grid;grid-template-columns:repeat(2,1fr);grid-gap:var(--space-sm);gap:var(--space-sm);margin-top:var(--space-xl)}.manual-grid div{display:grid;grid-gap:10px;gap:10px;padding:14px;border:1px solid var(--border-visible);border-radius:var(--radius-compact);background:var(--black)}.manual-grid strong{color:var(--text-display);font-family:Space Mono,monospace;font-size:20px}.bottom-nav{position:absolute;z-index:4;left:50%;bottom:14px;width:min(240px,calc(100% - 28px));display:grid;grid-template-columns:repeat(2,1fr);grid-gap:6px;gap:6px;padding:8px;transform:translateX(-50%);border:1px solid var(--border-visible);border-radius:999px;background:var(--nav-bg)}.phone-frame:has(.plant-modal-backdrop) .bottom-nav{opacity:0;pointer-events:none}.bottom-nav button{min-width:0;min-height:52px;display:grid;place-items:center;grid-gap:4px;gap:4px;border:0;border-radius:999px;background:transparent;color:var(--text-disabled)}.bottom-nav button.is-active{background:var(--text-display);color:var(--black)}.bottom-nav svg{transform:translateY(3px)}.bottom-nav span{font-family:Space Mono,monospace;font-size:9px;font-weight:700;letter-spacing:.04em}@media (max-width:520px){.app-shell{padding:0}.phone-frame{width:100%;height:100vh;min-height:100vh;border:0;border-radius:0}}@media (max-width:360px){.screen{padding-inline:14px}.hero-number{font-size:70px}.plant-row{grid-template-columns:84px 1fr 18px;min-height:112px;padding:12px}.plant-row img{width:84px;height:84px}.action-grid{grid-template-columns:repeat(2,1fr)}}