:root{--green-dark: #2d6a4f;--green-mid: #52b788;--green-light: #b7e4c7;--green-pale: #f0faf4;--orange: #f4a261;--yellow: #f9c74f;--red: #e63946;--text-dark: #1a2e1f;--text-mid: #4a6155;--text-light: #8fa899;--white: #ffffff;--bg: #f5fbf7;--card-bg: #ffffff;--border: #e0ede6;--shadow-sm: 0 1px 4px rgba(0,0,0,.08);--shadow-md: 0 4px 16px rgba(0,0,0,.12);--radius: 14px;--radius-sm: 8px;--nav-height: 64px}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;-webkit-text-size-adjust:100%}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background:var(--bg);color:var(--text-dark);-webkit-font-smoothing:antialiased;min-height:100dvh;overscroll-behavior-y:none}a{text-decoration:none;color:inherit}button{font-family:inherit;cursor:pointer}input,textarea,select{font-family:inherit}img{display:block;width:100%;height:100%;object-fit:cover}.page{max-width:480px;margin:0 auto;padding:16px 16px calc(var(--nav-height) + env(safe-area-inset-bottom) + 16px);min-height:100dvh}.page-detail{padding:0 0 calc(var(--nav-height) + env(safe-area-inset-bottom) + 16px)}.page-loading{display:flex;align-items:center;justify-content:center;min-height:60vh;color:var(--text-light);font-size:1.1rem}.page-header{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:env(safe-area-inset-top) 0 20px;padding-top:max(env(safe-area-inset-top),16px)}.page-title{font-size:1.6rem;font-weight:700;color:var(--text-dark)}.page-subtitle{font-size:.9rem;color:var(--text-light);margin-top:2px}.bottom-nav{position:fixed;bottom:0;left:0;right:0;height:calc(var(--nav-height) + env(safe-area-inset-bottom));padding-bottom:env(safe-area-inset-bottom);background:var(--white);border-top:1px solid var(--border);display:flex;align-items:center;justify-content:space-around;z-index:100;box-shadow:0 -2px 12px #0000000f}.nav-item{display:flex;flex-direction:column;align-items:center;gap:3px;flex:1;padding:8px 0;color:var(--text-light);font-size:.68rem;font-weight:500;transition:color .15s;-webkit-tap-highlight-color:transparent}.nav-item.active{color:var(--green-dark)}.nav-item:active{opacity:.7}.nav-add{color:var(--green-dark);font-weight:600}.nav-add svg{color:var(--green-dark)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;padding:12px 20px;border-radius:var(--radius-sm);border:none;font-size:.95rem;font-weight:600;background:var(--border);color:var(--text-mid);transition:opacity .15s,transform .1s;-webkit-tap-highlight-color:transparent;white-space:nowrap}.btn:active{opacity:.8;transform:scale(.97)}.btn:disabled{opacity:.5;pointer-events:none}.btn-sm{padding:8px 14px;font-size:.85rem}.btn-full{width:100%}.btn-primary{background:var(--green-dark);color:var(--white)}.btn-water{background:#dbeafe;color:#1d4ed8;width:100%;margin-top:10px}.btn-fertilize{background:#dcfce7;color:var(--green-dark);width:100%;margin-top:10px}.icon-btn{display:inline-flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:50%;border:none;background:transparent;color:var(--text-mid);-webkit-tap-highlight-color:transparent}.icon-btn-light{background:#ffffffd9;color:var(--text-dark)}.icon-btn-danger{color:var(--red)}.badge{display:inline-flex;align-items:center;gap:4px;padding:3px 8px;border-radius:99px;font-size:.72rem;font-weight:600}.badge-green{background:#d1fae5;color:var(--green-dark)}.badge-yellow{background:#fef9c3;color:#854d0e}.badge-orange{background:#ffedd5;color:#c2410c}.badge-red{background:#fee2e2;color:#b91c1c}.plant-list{display:flex;flex-direction:column;gap:12px}.plant-card{display:flex;background:var(--card-bg);border-radius:var(--radius);box-shadow:var(--shadow-sm);overflow:hidden;border:1px solid var(--border);-webkit-tap-highlight-color:transparent;transition:transform .1s,box-shadow .1s}.plant-card:active{transform:scale(.98);box-shadow:var(--shadow-md)}.plant-card-photo{width:88px;min-height:88px;flex-shrink:0;background:var(--green-pale);overflow:hidden}.plant-card-placeholder{width:100%;height:100%;min-height:88px;display:flex;align-items:center;justify-content:center;font-size:2.2rem}.plant-card-body{flex:1;padding:12px;display:flex;flex-direction:column;gap:4px}.plant-card-name{font-size:1rem;font-weight:700;color:var(--text-dark)}.plant-card-location{display:flex;align-items:center;gap:3px;font-size:.78rem;color:var(--text-light)}.plant-card-badges{display:flex;gap:6px;flex-wrap:wrap;margin-top:4px}.form{display:flex;flex-direction:column;gap:16px;padding-bottom:16px}.form-photo-area{width:100%;height:200px;border-radius:var(--radius);border:2px dashed var(--border);overflow:hidden;background:var(--green-pale);cursor:pointer;display:flex;align-items:center;justify-content:center;-webkit-tap-highlight-color:transparent}.form-photo-preview{width:100%;height:100%;object-fit:cover}.form-photo-placeholder{display:flex;flex-direction:column;align-items:center;gap:8px;color:var(--green-mid);font-size:.9rem}.form-group{display:flex;flex-direction:column;gap:6px}.form-label{font-size:.85rem;font-weight:600;color:var(--text-mid)}.form-input{width:100%;padding:12px 14px;border-radius:var(--radius-sm);border:1.5px solid var(--border);background:var(--white);font-size:.95rem;color:var(--text-dark);outline:none;transition:border-color .15s}.form-input:focus{border-color:var(--green-mid)}.form-textarea{resize:vertical;min-height:80px}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:12px}.form-input-inline{display:flex;align-items:center;gap:8px}.form-unit{font-size:.85rem;color:var(--text-light);white-space:nowrap}.form-divider{height:1px;background:var(--border)}.alert{padding:12px 14px;border-radius:var(--radius-sm);font-size:.9rem}.alert-error{background:#fee2e2;color:#b91c1c}.error-msg{color:var(--red);font-size:.85rem;margin-top:4px}.login-page{min-height:100dvh;display:flex;align-items:center;justify-content:center;background:linear-gradient(160deg,var(--green-pale) 0%,var(--white) 60%);padding:24px}.login-card{width:100%;max-width:320px;background:var(--white);border-radius:var(--radius);box-shadow:var(--shadow-md);padding:36px 28px;display:flex;flex-direction:column;align-items:center;gap:8px}.login-icon{font-size:3rem}.login-title{font-size:1.8rem;font-weight:800;color:var(--green-dark)}.login-subtitle{font-size:.9rem;color:var(--text-light);margin-bottom:8px}.login-form{width:100%;display:flex;flex-direction:column;gap:12px;margin-top:8px}.pin-input{width:100%;padding:14px;text-align:center;letter-spacing:.4em;font-size:1.4rem;border-radius:var(--radius-sm);border:2px solid var(--border);background:var(--bg);outline:none;transition:border-color .15s}.pin-input:focus{border-color:var(--green-dark)}.pin-input-error{border-color:var(--red)}.dashboard-section{margin-bottom:24px}.section-title{font-size:.85rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;margin-bottom:10px}.section-urgent{color:var(--red)}.section-soon{color:var(--orange)}.section-ok{color:var(--green-dark)}.all-good{display:flex;flex-direction:column;align-items:center;gap:8px;padding:48px 24px;text-align:center;color:var(--text-mid)}.all-good-icon{font-size:3rem}.all-good h2{font-size:1.3rem;color:var(--green-dark)}.empty-state{display:flex;flex-direction:column;align-items:center;gap:16px;padding:60px 24px;text-align:center;color:var(--text-light)}.empty-icon{font-size:3rem}.search-bar{position:relative;margin-bottom:16px}.search-icon{position:absolute;left:12px;top:50%;transform:translateY(-50%);color:var(--text-light);pointer-events:none}.search-input{width:100%;padding:11px 14px 11px 36px;border-radius:var(--radius-sm);border:1.5px solid var(--border);background:var(--white);font-size:.9rem;outline:none}.search-input:focus{border-color:var(--green-mid)}.detail-hero{position:relative;width:100%;height:260px;background:var(--green-pale);overflow:hidden}.detail-photo{width:100%;height:100%;object-fit:cover}.detail-photo-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;font-size:5rem}.detail-hero-overlay{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:flex-start;justify-content:space-between;padding:max(env(safe-area-inset-top),12px) 12px 12px;background:linear-gradient(to bottom,rgba(0,0,0,.35) 0%,transparent 50%)}.detail-hero-actions{display:flex;gap:8px}.detail-content{padding:20px 16px}.detail-name{font-size:1.8rem;font-weight:800;color:var(--text-dark)}.detail-location{font-size:.9rem;color:var(--text-light);margin-top:4px}.detail-notes{font-size:.9rem;color:var(--text-mid);margin-top:8px;line-height:1.5}.detail-section{margin-top:28px}.section-heading{font-size:1rem;font-weight:700;color:var(--text-dark);margin-bottom:12px;padding-bottom:8px;border-bottom:2px solid var(--border)}.care-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}.care-card{background:var(--card-bg);border-radius:var(--radius);border:1.5px solid var(--border);padding:14px}.care-card-header{display:flex;align-items:center;gap:6px;font-weight:600;font-size:.9rem;color:var(--text-mid);margin-bottom:8px}.care-interval{font-size:.78rem;color:var(--text-light)}.care-status{font-size:.9rem;font-weight:700;margin-top:4px}.care-last{font-size:.72rem;color:var(--text-light);margin-top:2px}.care-card.status-overdue .care-status,.care-card.status-never .care-status{color:var(--red)}.care-card.status-today .care-status{color:var(--orange)}.care-card.status-soon .care-status{color:#ca8a04}.care-card.status-ok .care-status{color:var(--green-dark)}.hc-upload-area{margin-bottom:20px}.hc-photo-btn{display:flex;flex-direction:column;align-items:center;gap:10px;width:100%;padding:28px 20px;border-radius:var(--radius);border:2px dashed var(--green-light);background:var(--green-pale);color:var(--green-dark);font-size:.9rem;font-weight:600;-webkit-tap-highlight-color:transparent}.hc-preview{display:flex;flex-direction:column;gap:10px}.hc-preview-img{width:100%;max-height:220px;object-fit:cover;border-radius:var(--radius)}.hc-preview-actions{display:flex;gap:10px}.hc-history-title{font-size:.85rem;font-weight:600;color:var(--text-light);margin-bottom:8px}.hc-item{border-radius:var(--radius-sm);border:1px solid var(--border);overflow:hidden;margin-bottom:8px}.hc-item-header{display:flex;align-items:center;justify-content:space-between;width:100%;padding:12px 14px;background:var(--white);border:none;-webkit-tap-highlight-color:transparent}.hc-item-meta{display:flex;align-items:center;gap:8px}.hc-status-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}.hc-status-label{font-weight:600;font-size:.9rem}.hc-date{font-size:.78rem;color:var(--text-light)}.hc-item-body{padding:14px;background:var(--bg);border-top:1px solid var(--border)}.hc-thumb{width:100%;max-height:180px;object-fit:cover;border-radius:var(--radius-sm);margin-bottom:12px}.hc-analysis{font-size:.88rem;line-height:1.65;color:var(--text-dark)}.hc-analysis strong{color:var(--green-dark)}
