@import "https://fonts.googleapis.com/css2?family=Outfit:wght@300;400;500;600;700;800&family=Plus+Jakarta+Sans:ital,wght@0,300;0,400;0,500;0,600;0,700;0,800;1,400&display=swap";:root{--font-display:"Outfit", "Plus Jakarta Sans", system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;--font-body:"Plus Jakarta Sans", "Inter", system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;--hue-green:142;--hue-gold:42;--hue-blue:200;--hue-air:180;--hue-red:350;--color-sunlight:hsl(var(--hue-gold), 95%, 45%);--color-sunlight-light:hsl(var(--hue-gold), 90%, 55%);--color-sunlight-glow:hsla(var(--hue-gold), 95%, 45%, .12);--color-primary:hsl(var(--hue-green), 60%, 26%);--color-primary-light:hsl(var(--hue-green), 50%, 42%);--color-primary-glow:hsla(var(--hue-green), 60%, 42%, .12);--color-water:hsl(var(--hue-blue), 85%, 45%);--color-water-light:hsl(var(--hue-blue), 80%, 55%);--color-water-glow:hsla(var(--hue-blue), 85%, 45%, .12);--color-air:hsl(var(--hue-air), 65%, 42%);--color-air-light:hsl(var(--hue-air), 60%, 52%);--color-air-glow:hsla(var(--hue-air), 65%, 42%, .12);--color-fertilizer:#e06b06;--color-fertilizer-glow:#e06b061f;--color-danger:hsl(var(--hue-red), 80%, 55%);--color-danger-glow:hsla(var(--hue-red), 80%, 55%, .15);--bg-gradient:linear-gradient(135deg, #fffdf2 0%, #f1fcf5 50%, #ecfdfa 100%);--bg-app:#f6fdfa;--card-bg:#ffffff73;--card-border:#fff9;--card-shadow:0 10px 40px -10px #7896871f, 0 1px 3px 0 #7896870d;--glass-blur:blur(24px);--text-main:#17261f;--text-muted:#60766b;--text-inverse:#fff;--border-light:#78968726;--border-focus:hsl(var(--hue-green), 50%, 42%);--transition-smooth:all .3s cubic-bezier(.25, .8, .25, 1);--transition-bounce:all .5s cubic-bezier(.34, 1.56, .64, 1)}[data-theme=dark]{--color-sunlight:hsl(var(--hue-gold), 95%, 55%);--color-sunlight-light:hsl(var(--hue-gold), 90%, 65%);--color-sunlight-glow:hsla(var(--hue-gold), 95%, 55%, .2);--color-primary:hsl(var(--hue-green), 55%, 45%);--color-primary-light:hsl(var(--hue-green), 45%, 58%);--color-primary-glow:hsla(var(--hue-green), 55%, 45%, .2);--color-water:hsl(var(--hue-blue), 85%, 55%);--color-water-light:hsl(var(--hue-blue), 80%, 65%);--color-water-glow:hsla(var(--hue-blue), 85%, 55%, .2);--color-air:hsl(var(--hue-air), 65%, 52%);--color-air-light:hsl(var(--hue-air), 60%, 62%);--color-air-glow:hsla(var(--hue-air), 65%, 52%, .2);--color-fertilizer:#f48525;--color-fertilizer-glow:#f4852533;--color-danger:hsl(var(--hue-red), 85%, 60%);--color-danger-glow:hsla(var(--hue-red), 85%, 60%, .25);--bg-gradient:linear-gradient(135deg, #090e0c 0%, #0d1713 50%, #081418 100%);--bg-app:#080d0b;--card-bg:#0d161273;--card-border:#ffffff0d;--card-shadow:0 10px 40px -10px #00000080, 0 1px 3px 0 #0003;--text-main:#dce5e0;--text-muted:#8b9c94;--text-inverse:#080d0b;--border-light:#ffffff0f;--border-focus:hsl(var(--hue-green), 55%, 45%)}*{box-sizing:border-box;margin:0;padding:0}html,body{width:100%;min-height:100vh;font-family:var(--font-body);color:var(--text-main);background:var(--bg-app);background-image:var(--bg-gradient);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-attachment:fixed;line-height:1.5;transition:background .5s,color .3s;overflow-x:hidden}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--border-light);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:var(--color-primary-light)}#root{flex-direction:column;width:100%;min-height:100vh;display:flex}a{color:inherit;text-decoration:none}button,input,select,textarea{color:inherit;font-family:inherit}.glass-panel{background:var(--card-bg);border:1px solid var(--card-border);box-shadow:var(--card-shadow);-webkit-backdrop-filter:var(--glass-blur);border-radius:20px}.breeze-float{animation:8s ease-in-out infinite alternate breezeFloat}@keyframes breezeFloat{0%{box-shadow:var(--card-shadow);transform:translateY(0)}to{transform:translateY(-6px);box-shadow:0 16px 48px -8px #78968733,0 3px 8px #78968714}}.plant-breeze-sway{transform-origin:150px 155px;animation:6s ease-in-out infinite alternate plantSway}.plant-breeze-sway-delayed{transform-origin:150px 155px;animation:8s ease-in-out -2s infinite alternate-reverse plantSway}@keyframes plantSway{0%{transform:rotate(-1.5deg)scaleX(.99)}50%{transform:rotate(.5deg)skew(.5deg)}to{transform:rotate(1.5deg)scaleX(1.01)}}.solar-glow{animation:4s ease-in-out infinite alternate solarRadiance}@keyframes solarRadiance{0%{filter:drop-shadow(0 0 2px #f59e0b33)}to{filter:drop-shadow(0 0 12px #f59e0b80)}}.liquid-flow{animation:4s linear infinite liquidFlow;background-size:200% 100%!important}@keyframes liquidFlow{0%{background-position:0%}to{background-position:-200%}}.wind-sway-icon{animation:4s ease-in-out infinite alternate windSwayIcon;display:inline-block}@keyframes windSwayIcon{0%{transform:rotate(-8deg)translate(-1px)}to{transform:rotate(8deg)translate(1px)}}.droplet-pulse{animation:2s cubic-bezier(.4,0,.6,1) infinite dropPulse}@keyframes dropPulse{0%,to{opacity:1;transform:scale(1)translateY(0)}50%{opacity:.7;transform:scale(.9)translateY(2px)}}.app-container{flex-direction:column;width:100%;max-width:1200px;min-height:100vh;margin:0 auto;padding:0 1rem;display:flex}header{border-bottom:1px solid var(--border-light);justify-content:space-between;align-items:center;padding:1.5rem 0;display:flex;position:relative}.brand{align-items:center;gap:.75rem;display:flex}.brand h1{font-family:var(--font-display);color:var(--color-primary-light);letter-spacing:-.5px;font-size:1.6rem;font-weight:800}.brand-icon{color:var(--color-primary-light);filter:drop-shadow(0 0 4px var(--color-primary-glow));animation:6s ease-in-out infinite alternate plantSway}.user-nav{align-items:center;gap:1rem;display:flex}.theme-toggle,.btn-icon{background:var(--card-bg);border:1px solid var(--card-border);cursor:pointer;transition:var(--transition-smooth);border-radius:12px;justify-content:center;align-items:center;padding:.5rem;display:flex}.theme-toggle:hover,.btn-icon:hover{background:var(--color-primary-glow);border-color:var(--color-primary-light);transform:translateY(-2px);box-shadow:0 4px 12px #7896871a}.btn-primary{background:linear-gradient(135deg, var(--color-primary) 0%, var(--color-primary-light) 100%);color:#fff;cursor:pointer;box-shadow:0 4px 14px var(--color-primary-glow);transition:var(--transition-bounce);border:none;border-radius:14px;align-items:center;gap:.5rem;padding:.65rem 1.3rem;font-weight:700;display:flex}.btn-primary:hover{box-shadow:0 8px 24px -4px var(--color-primary-light), 0 4px 10px -4px var(--color-primary-glow);transform:translateY(-3px)}.btn-secondary{background:var(--card-bg);border:1px solid var(--border-light);cursor:pointer;-webkit-backdrop-filter:var(--glass-blur);transition:var(--transition-smooth);border-radius:14px;align-items:center;gap:.5rem;padding:.65rem 1.3rem;font-weight:700;display:flex}.btn-secondary:hover{background:var(--color-primary-glow);border-color:var(--color-primary-light);color:var(--color-primary-light);transform:translateY(-2px);box-shadow:0 4px 12px #7896871a}.hero-banner{justify-content:space-between;align-items:center;margin:1.5rem 0;padding:1.5rem;display:flex;position:relative;overflow:hidden}.hero-banner:before{content:"";background:radial-gradient(circle, var(--color-primary-glow) 0%, transparent 70%);z-index:0;pointer-events:none;width:150px;height:150px;position:absolute;top:0;right:0}.hero-banner button,.hero-banner .btn-primary,.hero-banner .btn-secondary,.hero-content{z-index:1;position:relative}.hero-content h2{font-family:var(--font-display);color:var(--text-main);margin-bottom:.5rem;font-size:1.8rem;font-weight:700}.hero-content p{color:var(--text-muted)}.header-divider{background-color:var(--border-light);flex-shrink:0;width:1px;height:20px}.header-quote-container{flex:1;align-items:center;gap:.5rem;min-width:0;max-width:480px;display:flex;position:relative;overflow:hidden}@media (width<=900px){.header-divider,.header-quote-container{display:none}}.quote-bullet-icon{opacity:.8;flex-shrink:0;font-size:.9rem;animation:2s infinite alternate bounceSprout}.header-quote-wrapper{width:100%;min-width:0;animation:.8s cubic-bezier(.16,1,.3,1) forwards quoteFadeSlide}.header-quote-text{font-family:var(--font-body);color:var(--text-muted);white-space:nowrap;text-overflow:ellipsis;text-align:left;font-size:.85rem;font-style:italic;font-weight:500;line-height:1.4;display:block;overflow:hidden}.header-progress-bar{background:linear-gradient(90deg, transparent, var(--color-primary-light), transparent);opacity:.35;z-index:10;width:0%;height:1.5px;animation:20s linear forwards quoteProgress;position:absolute;bottom:-1px;left:0}@keyframes quoteProgress{0%{width:0%}to{width:100%}}@keyframes quoteFadeSlide{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}@keyframes bounceSprout{0%{transform:translateY(0)scale(1)}to{transform:translateY(-2px)scale(1.05)}}.spaces-section{margin-bottom:2rem}.spaces-bar{scrollbar-width:none;align-items:center;gap:.75rem;padding:.5rem 0;display:flex;overflow-x:auto}.spaces-bar::-webkit-scrollbar{display:none}.space-tab{background:var(--card-bg);border:1px solid var(--card-border);cursor:pointer;white-space:nowrap;transition:var(--transition-smooth);border-radius:14px;align-items:center;gap:.5rem;padding:.6rem 1.2rem;font-weight:600;display:flex;box-shadow:0 2px 10px #00000005}.space-tab:hover{border-color:var(--color-primary-light);background:var(--color-primary-glow)}.space-tab.active{background:linear-gradient(135deg, var(--color-primary) 0%, var(--color-primary-light) 100%);color:#fff;border-color:#0000;box-shadow:0 4px 15px #16653426}.btn-add-space{border:1px dashed var(--color-primary-light);color:var(--color-primary-light);cursor:pointer;transition:var(--transition-smooth);background:0 0;border-radius:14px;align-items:center;gap:.25rem;padding:.6rem 1rem;font-weight:600;display:flex}.btn-add-space:hover{background:var(--color-primary-glow);transform:scale(1.03)}.space-info-card{background:var(--card-bg);border:1px solid var(--card-border);box-shadow:var(--card-shadow);border-radius:16px;justify-content:space-between;align-items:center;margin-bottom:1.75rem;padding:1.25rem 1.5rem;font-size:.95rem;display:flex}.space-env-badge{gap:.75rem;margin-top:.5rem;display:flex}.env-tag{background:var(--card-bg);border:1px solid var(--border-light);transition:var(--transition-smooth);border-radius:10px;align-items:center;gap:.35rem;padding:.35rem .75rem;font-size:.8rem;font-weight:700;display:inline-flex;box-shadow:0 2px 6px #7896870a}.env-tag:hover{transform:translateY(-2px)}.env-tag.sunlight-tag{color:var(--color-sunlight);background:var(--color-sunlight-glow);border-color:#f59e0b40}.env-tag.air-tag{color:var(--color-air);background:var(--color-air-glow);border-color:#06b6d440}.plants-grid{grid-template-columns:repeat(auto-fill,minmax(290px,1fr));gap:1.75rem;margin-bottom:3.5rem;display:grid}.plant-card{transition:var(--transition-bounce);flex-direction:column;animation:8s ease-in-out infinite alternate breezeFloat;display:flex;position:relative;overflow:hidden}.plants-grid>.plant-card:nth-child(2n){animation-duration:9.5s;animation-delay:-1.5s}.plants-grid>.plant-card:nth-child(3n){animation-duration:7s;animation-delay:-3.2s}.plants-grid>.plant-card:nth-child(4n){animation-duration:11s;animation-delay:-.5s}.plant-card:hover{box-shadow:0 20px 40px -10px var(--color-primary-glow), 0 0 0 1.5px var(--color-primary-light);border-color:#0000;transform:translateY(-8px)scale(1.01)}.plant-image-container{background-color:var(--border-light);border-bottom:1px solid var(--border-light);width:100%;height:210px;position:relative;overflow:hidden}.plant-img{object-fit:cover;width:100%;height:100%;transition:transform .6s cubic-bezier(.25,.8,.25,1)}.plant-card:hover .plant-img{transform:scale(1.08)}.status-badge{-webkit-backdrop-filter:blur(12px);color:#fff;z-index:5;border:1px solid #ffffff26;border-radius:20px;align-items:center;gap:.3rem;padding:.35rem .75rem;font-size:.75rem;font-weight:700;display:flex;position:absolute;top:14px;right:14px;box-shadow:0 4px 15px #0000001f}.status-badge.water-now{background:linear-gradient(135deg, hsl(var(--hue-red), 80%, 45%) 0%, var(--color-danger) 100%);animation:2s infinite pulse-border}.status-badge.healthy{background:linear-gradient(135deg, hsl(var(--hue-green), 60%, 35%) 0%, var(--color-primary-light) 100%)}.plant-card-body{flex-direction:column;flex-grow:1;padding:1.4rem;display:flex}.plant-header{justify-content:space-between;align-items:start;margin-bottom:.6rem;display:flex}.plant-title{font-family:var(--font-display);color:var(--text-main);letter-spacing:-.2px;font-size:1.25rem;font-weight:700}.plant-category-tag{background:var(--color-primary-glow);color:var(--color-primary-light);border:1px solid rgba(var(--hue-green), 60%, 42%, .1);border-radius:20px;margin-top:.25rem;padding:.2rem .6rem;font-size:.75rem;font-weight:700;display:inline-block}.plant-notes-snippet{color:var(--text-muted);-webkit-line-clamp:2;-webkit-box-orient:vertical;height:2.6rem;margin-bottom:1.25rem;font-size:.85rem;line-height:1.35;display:-webkit-box;overflow:hidden}.care-indicator-list{flex-direction:column;gap:.9rem;margin-top:auto;margin-bottom:1.4rem;display:flex}.care-progress-row{flex-direction:column;gap:.35rem;display:flex}.care-progress-info{justify-content:space-between;font-size:.75rem;font-weight:700;display:flex}.care-progress-bar-bg{background:var(--border-light);border-radius:10px;width:100%;height:7px;overflow:hidden}.care-progress-fill{border-radius:10px;height:100%;transition:width .8s cubic-bezier(.25,.8,.25,1)}.care-progress-fill.water{background:linear-gradient(90deg, var(--color-water) 0%, var(--color-water-light) 50%, var(--color-water) 100-percent);background-color:var(--color-water);background-size:200% 100%;animation:4s linear infinite liquidFlow;position:relative;overflow:hidden}.care-progress-fill.water:after{content:"";opacity:.4;background-image:linear-gradient(-45deg,#fff3 25%,#0000 25% 50%,#fff3 50% 75%,#0000 75%,#0000);background-size:14px 14px;animation:2s linear infinite waveBar;position:absolute;inset:0}@keyframes waveBar{0%{background-position:0 0}to{background-position:28px 0}}.care-progress-fill.fertilizer{background:linear-gradient(90deg, var(--color-fertilizer) 0%, var(--color-sunlight-light) 50%, var(--color-fertilizer) 100%);background-color:var(--color-fertilizer);box-shadow:0 0 6px var(--color-fertilizer-glow);background-size:200% 100%;animation:6s ease-in-out infinite liquidFlow}.plant-card-actions{border-top:1px solid var(--border-light);gap:.6rem;padding-top:.9rem;display:flex}.btn-card-action{border:1px solid var(--border-light);background:var(--card-bg);cursor:pointer;transition:var(--transition-smooth);border-radius:10px;flex:1;justify-content:center;align-items:center;gap:.3rem;padding:.45rem;font-size:.8rem;font-weight:700;display:flex}.btn-card-action.water:hover{background:var(--color-water-glow);color:var(--color-water-light);border-color:var(--color-water-light);box-shadow:0 4px 12px var(--color-water-glow)}.btn-card-action.water:hover svg{animation:1.5s cubic-bezier(.4,0,.6,1) infinite dropPulse}.btn-card-action.fertilize:hover{background:var(--color-fertilizer-glow);color:var(--color-sunlight);border-color:var(--color-sunlight);box-shadow:0 4px 12px var(--color-fertilizer-glow)}.btn-card-action.fertilize:hover svg{animation:2s ease-in-out infinite alternate solarRadiance}.care-progress-fill.overdue{box-shadow:0 0 8px #ef444473;background:linear-gradient(135deg, hsl(var(--hue-red), 80%, 45%) 0%, var(--color-danger) 100%)!important}.modal-overlay{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:1000;background:#0006;justify-content:center;align-items:center;padding:1rem;display:flex;position:fixed;inset:0}.modal-content{width:100%;max-width:500px;max-height:90vh;padding:2rem;animation:.3s cubic-bezier(.16,1,.3,1) forwards modal-enter;position:relative;overflow-y:auto}.modal-content.large{max-width:800px}.modal-header{justify-content:space-between;align-items:center;margin-bottom:1.5rem;display:flex}.modal-title{font-family:var(--font-display);font-size:1.5rem;font-weight:700}.btn-close{cursor:pointer;color:var(--text-muted);transition:var(--transition-smooth);background:0 0;border:none}.btn-close:hover{color:var(--color-danger);transform:rotate(90deg)}.form-group{flex-direction:column;gap:.4rem;margin-bottom:1.25rem;display:flex}.form-group label{color:var(--text-muted);font-size:.85rem;font-weight:600}.form-control{border:1px solid var(--border-light);background:var(--card-bg);transition:var(--transition-smooth);border-radius:12px;outline:none;padding:.75rem 1rem;font-size:.95rem}.form-control:focus{border-color:var(--border-focus);box-shadow:0 0 0 3px var(--color-primary-glow)}.form-row{grid-template-columns:1fr 1fr;gap:1rem;display:grid}.image-upload-wrapper{border:2px dashed var(--border-light);text-align:center;cursor:pointer;background:var(--color-primary-glow);transition:var(--transition-smooth);border-radius:12px;padding:1.5rem;position:relative}.image-upload-wrapper:hover{border-color:var(--color-primary-light)}.image-preview{object-fit:cover;border-radius:8px;width:100%;max-height:200px}.image-upload-input{opacity:0;cursor:pointer;position:absolute;inset:0}.modal-actions{justify-content:flex-end;gap:.75rem;margin-top:2rem;display:flex}.detail-layout{grid-template-columns:1fr 1.2fr;gap:2rem;display:grid}@media (width<=768px){.detail-layout{grid-template-columns:1fr}}.plant-profile{flex-direction:column;gap:1.25rem;display:flex}.detail-img-wrapper{width:100%;height:250px;box-shadow:var(--card-shadow);border-radius:16px;position:relative;overflow:hidden}.detail-img{object-fit:cover;width:100%;height:100%}.detail-care-grid{grid-template-columns:repeat(2,1fr);gap:.75rem;display:grid}.detail-care-card{background:var(--card-bg);border:1px solid var(--card-border);text-align:center;transition:var(--transition-smooth);border-radius:16px;padding:1.1rem;box-shadow:0 4px 10px #78968708}.detail-care-card:hover{transform:translateY(-3px);box-shadow:0 8px 20px #78968714}.detail-care-card h4{color:var(--text-muted);margin-bottom:.35rem;font-size:.75rem;font-weight:700}.detail-care-card p{font-size:1.1rem;font-weight:800}.detail-care-card.water{background:var(--color-water-glow);border-color:#3b82f640}.detail-care-card.fertilize{background:var(--color-fertilizer-glow);border-color:#f59e0b40}.detail-care-card.clickable{cursor:pointer}.detail-care-card.clickable.water:hover{background:var(--color-water-glow);border-color:var(--color-water)}.detail-care-card.clickable.fertilize:hover{background:var(--color-fertilizer-glow);border-color:var(--color-fertilizer)}.timeline-section{flex-direction:column;gap:1.25rem;display:flex}.timeline-container{border-left:2px solid var(--border-light);flex-direction:column;gap:1.5rem;max-height:450px;margin-left:.5rem;padding-left:1.5rem;padding-right:.5rem;display:flex;overflow-y:auto}.timeline-node{position:relative}.timeline-dot{background:var(--color-primary-light);border:2px solid var(--bg-app);width:12px;height:12px;box-shadow:0 0 0 2px var(--color-primary-glow);border-radius:50%;position:absolute;top:6px;left:-29px}.timeline-node.watering .timeline-dot{background:var(--color-water)}.timeline-node.fertilizing .timeline-dot{background:var(--color-fertilizer)}.timeline-card{border-radius:12px;padding:1rem}.timeline-meta{color:var(--text-muted);justify-content:space-between;align-items:center;margin-bottom:.5rem;font-size:.75rem;display:flex}.timeline-type-tag{text-transform:uppercase;font-weight:700}.timeline-text{font-size:.9rem}.timeline-photo{object-fit:contain;background:var(--color-primary-glow);border-radius:8px;width:100%;height:auto;max-height:320px;margin-top:.5rem;box-shadow:0 2px 8px #0000000d}footer{text-align:center;color:var(--text-muted);border-top:1px solid var(--border-light);margin-top:auto;padding:2rem 0;font-size:.8rem}.demo-banner{color:#fff;text-align:center;letter-spacing:.5px;background:linear-gradient(90deg,#b45309 0%,#d97706 100%);padding:.3rem;font-size:.75rem;font-weight:700}@keyframes pulse-border{0%{box-shadow:0 0 #ef444466}70%{box-shadow:0 0 0 8px #ef444400}to{box-shadow:0 0 #ef444400}}@keyframes modal-enter{0%{opacity:0;transform:translateY(20px)scale(.95)}to{opacity:1;transform:translateY(0)scale(1)}}.user-avatar{border:2px solid var(--color-primary-light);object-fit:cover;border-radius:50%;width:32px;height:32px;transition:transform .2s;box-shadow:0 2px 8px #00000026}.user-avatar:hover{transform:scale(1.08)}.user-avatar-fallback{border:2px solid var(--color-primary-light);background:var(--color-primary-glow);width:32px;height:32px;color:var(--color-primary-light);border-radius:50%;justify-content:center;align-items:center;font-size:.85rem;font-weight:700;display:flex}
