:root{--color-bg:#f7f4ef;--color-surface:#fff;--color-surface-alt:#f0ede6;--color-sidebar:#fff;--color-modal:#fff;--color-text-primary:#2c2c2c;--color-text-secondary:#6b6b5f;--color-text-disabled:#b0ada5;--color-accent:#5c7a5c;--color-accent-hover:#4a6449;--color-accent-warm:#a67c5b;--color-status-green:#4a7c59;--color-status-green-bg:#e8f4ec;--color-status-yellow:#c4921f;--color-status-yellow-bg:#fdf4e3;--color-status-red:#b85c38;--color-status-red-bg:#faeae4;--color-border:#e0ddd6;--color-border-focus:#5c7a5c;--color-overlay:#2c2c2c73;--color-skeleton-base:#f0ede6;--color-skeleton-highlight:#e8e4dc;--shadow-card:0 2px 8px #2c2c2c0f;--shadow-card-hover:0 6px 20px #2c2c2c1f;--font-body:"DM Sans", sans-serif;--font-display:"Playfair Display", serif;--space-xs:4px;--space-sm:8px;--space-md:16px;--space-lg:24px;--space-xl:32px;--space-2xl:48px;--space-3xl:64px;--radius-card:12px;--radius-input:8px;--radius-pill:24px;--radius-circle:50%;--transition-base:all .2s ease;--transition-spring:all .4s cubic-bezier(.34, 1.56, .64, 1);--max-content-width:1280px;--sidebar-width:240px}[data-theme=dark]{--color-bg:#1a1815;--color-surface:#242220;--color-surface-alt:#2c2a26;--color-sidebar:#1f1d1a;--color-modal:#2c2a26;--color-text-primary:#ede8df;--color-text-secondary:#9b9489;--color-text-disabled:#5a5650;--color-accent:#7eaf7e;--color-accent-hover:#91be91;--color-accent-warm:#c2956a;--color-status-green:#6eb88a;--color-status-green-bg:#1a2f22;--color-status-yellow:#e8b94a;--color-status-yellow-bg:#2b220d;--color-status-red:#e07a60;--color-status-red-bg:#2e1a14;--color-border:#3c3830;--color-border-focus:#7eaf7e;--color-overlay:#000000a6;--color-skeleton-base:#2c2a26;--color-skeleton-highlight:#383530;--shadow-card:0 2px 12px #00000059;--shadow-card-hover:0 6px 20px #0006}@media (prefers-color-scheme:dark){:root:not([data-theme=light]){--color-bg:#1a1815;--color-surface:#242220;--color-surface-alt:#2c2a26;--color-sidebar:#1f1d1a;--color-modal:#2c2a26;--color-text-primary:#ede8df;--color-text-secondary:#9b9489;--color-text-disabled:#5a5650;--color-accent:#7eaf7e;--color-accent-hover:#91be91;--color-accent-warm:#c2956a;--color-status-green:#6eb88a;--color-status-green-bg:#1a2f22;--color-status-yellow:#e8b94a;--color-status-yellow-bg:#2b220d;--color-status-red:#e07a60;--color-status-red-bg:#2e1a14;--color-border:#3c3830;--color-border-focus:#7eaf7e;--color-overlay:#000000a6;--color-skeleton-base:#2c2a26;--color-skeleton-highlight:#383530;--shadow-card:0 2px 12px #00000059;--shadow-card-hover:0 6px 20px #0006}}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-size:16px}body{font-family:var(--font-body);color:var(--color-text-primary);background-color:var(--color-bg);line-height:1.5}h1,h2,h3{font-family:var(--font-display);font-weight:600}a{color:var(--color-accent);text-decoration:none}a:hover{text-decoration:underline}button{font-family:var(--font-body);cursor:pointer;background:0 0;border:none}input,textarea,select{font-family:var(--font-body)}:focus-visible{outline:2px solid var(--color-border-focus);outline-offset:2px}html:not(.no-transition) *,html:not(.no-transition) :before,html:not(.no-transition) :after{transition:background-color .3s,color .2s,border-color .2s}@keyframes shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.skeleton{background:linear-gradient(90deg, var(--color-skeleton-base) 25%, var(--color-skeleton-highlight) 50%, var(--color-skeleton-base) 75%);border-radius:var(--radius-input);background-size:200px 100%;animation:1.5s infinite shimmer}.toast-container{z-index:9999;flex-direction:column;gap:8px;display:flex;position:fixed;top:16px;right:16px}.toast{background:var(--color-text-primary);color:#fff;border-radius:var(--radius-input);box-shadow:var(--shadow-card-hover);border-left:4px solid var(--color-accent);max-width:360px;padding:12px 20px;font-size:14px;animation:.3s slideIn}.toast.toast-error{border-left-color:var(--color-status-red)}.toast.toast-success{border-left-color:var(--color-status-green)}@keyframes slideIn{0%{opacity:0;transform:translate(100%)}to{opacity:1;transform:translate(0)}}@media (prefers-reduced-motion:reduce){*,:before,:after{transition-duration:.01ms!important;animation-duration:.01ms!important;animation-iteration-count:1!important}}html.no-transition *,html.no-transition :before,html.no-transition :after{transition:none!important}.sidebar{width:var(--sidebar-width);background:var(--color-sidebar);border-right:1px solid var(--color-border);z-index:100;flex-direction:column;height:100vh;transition:transform .3s;display:flex;position:fixed;top:0;left:0}.sidebar-overlay,.sidebar-close{display:none}.sidebar-header{justify-content:space-between;align-items:center;padding:24px;display:flex}.sidebar-logo{font-family:var(--font-display);color:var(--color-text-primary);align-items:center;gap:10px;font-size:18px;font-weight:600;text-decoration:none;display:flex}.sidebar-nav{flex-direction:column;flex:1;gap:4px;padding:8px 12px;display:flex}.sidebar-link{color:var(--color-text-secondary);transition:var(--transition-base);border-radius:8px;align-items:center;gap:12px;padding:10px 12px;font-size:14px;font-weight:500;text-decoration:none;display:flex}.sidebar-link:hover{color:var(--color-text-primary);background:#5c7a5c0f;text-decoration:none}[data-theme=dark] .sidebar-link:hover{background:#ffffff0a}.sidebar-link.active{color:var(--color-accent);border-left:4px solid var(--color-accent);background:#5c7a5c14;padding-left:8px}.sidebar-badge{background:var(--color-status-red);color:#fff;text-align:center;border-radius:24px;min-width:18px;margin-left:auto;padding:2px 7px;font-size:11px;font-weight:600;line-height:1.3}[data-theme=dark] .sidebar-badge{color:#1a1815}.sidebar-footer{border-top:1px solid var(--color-border);flex-direction:column;gap:12px;padding:16px;display:flex}.sidebar-user{align-items:center;gap:10px;display:flex}.sidebar-avatar{background:var(--color-accent);color:#fff;border-radius:50%;justify-content:center;align-items:center;width:32px;height:32px;font-size:12px;font-weight:600;display:flex}.sidebar-username{color:var(--color-text-primary);text-overflow:ellipsis;white-space:nowrap;font-size:13px;font-weight:500;overflow:hidden}.sidebar-logout{color:var(--color-text-secondary);cursor:pointer;background:0 0;border:none;align-items:center;gap:8px;padding:6px 0;font-size:13px;display:flex}.sidebar-logout:hover{color:var(--color-status-red)}@media (width<=1023px){.sidebar{transform:translate(-100%)}.sidebar-open{transform:translate(0)}.sidebar-overlay{background:var(--color-overlay);z-index:99;display:block;position:fixed;inset:0}.sidebar-close{color:var(--color-text-secondary);cursor:pointer;background:0 0;border:none;justify-content:center;align-items:center;padding:4px;display:flex}}.app-shell{min-height:100vh;display:flex}.app-main{margin-left:var(--sidebar-width);flex-direction:column;flex:1;min-height:100vh;display:flex}.app-topbar{background:var(--color-surface);border-bottom:1px solid var(--color-border);padding:12px 16px;display:none}.hamburger-btn{cursor:pointer;color:var(--color-text-primary);background:0 0;border:none;justify-content:center;align-items:center;padding:4px;display:flex}.app-content{max-width:var(--max-content-width);flex:1;width:100%;margin:0 auto;padding:32px}@media (width<=1023px){.app-main{margin-left:0}.app-topbar{display:flex}.app-content{padding:24px}}@media (width<=767px){.app-content{padding:16px}}.input-group{flex-direction:column;gap:6px;display:flex}.input-label{color:var(--color-text-primary);font-size:14px;font-weight:500}.input-required{color:var(--color-status-red)}.input-wrapper{position:relative}.input-field{border:1.5px solid var(--color-border);background:var(--color-surface);width:100%;height:44px;color:var(--color-text-primary);transition:var(--transition-base);border-radius:8px;padding:0 14px;font-size:15px}.input-field::placeholder{color:var(--color-text-disabled)}.input-field:focus{border-color:var(--color-border-focus);outline:none;box-shadow:0 0 0 3px #5c7a5c26}[data-theme=dark] .input-field:focus{box-shadow:0 0 0 3px #7eaf7e40}.input-field.input-error{border-color:var(--color-status-red)}.input-field.input-error:focus{box-shadow:0 0 0 3px #b85c3826}[data-theme=dark] .input-field.input-error{background:#2e1a14}[data-theme=dark] .input-field.input-error:focus{box-shadow:0 0 0 3px #e07a6033}.input-field:disabled{background:var(--color-surface-alt);color:var(--color-text-disabled);cursor:not-allowed}.input-toggle-password{cursor:pointer;color:var(--color-text-secondary);background:0 0;border:none;align-items:center;padding:4px;display:flex;position:absolute;top:50%;right:8px;transform:translateY(-50%)}.input-error-text{color:var(--color-status-red);font-size:12px}textarea.input-field{resize:vertical;height:auto;min-height:80px;font-family:var(--font-body);padding:10px 14px}.btn{cursor:pointer;transition:var(--transition-base);white-space:nowrap;border:none;border-radius:8px;justify-content:center;align-items:center;gap:8px;padding:10px 20px;font-size:14px;font-weight:600;line-height:1;display:inline-flex}.btn:active:not(:disabled){transform:scale(.97)}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-full{width:100%}.btn-small{padding:6px 14px;font-size:13px}.btn-primary{background:var(--color-accent);color:#fff}.btn-primary:hover:not(:disabled){background:var(--color-accent-hover)}[data-theme=dark] .btn-primary{color:#1a1815}.btn-secondary{color:var(--color-accent);border:1.5px solid var(--color-accent);background:0 0}.btn-secondary:hover:not(:disabled){background:#5c7a5c14}[data-theme=dark] .btn-secondary:hover:not(:disabled){background:#7eaf7e14}.btn-danger{background:var(--color-status-red);color:#fff}.btn-danger:hover:not(:disabled){background:#a04f30}[data-theme=dark] .btn-danger{color:#1a1815}.btn-ghost{color:var(--color-text-secondary);background:0 0}.btn-ghost:hover:not(:disabled){background:#6b6b5f14}[data-theme=dark] .btn-ghost:hover:not(:disabled){background:#ffffff0f}.btn-icon{color:var(--color-text-secondary);background:0 0;border-radius:50%;width:32px;height:32px;padding:8px}.btn-icon:hover:not(:disabled){background:var(--color-surface-alt)}[data-theme=dark] .btn-icon:hover:not(:disabled){background:#ffffff14}[data-theme=dark] .btn:focus-visible{box-shadow:0 0 0 3px #7eaf7e59}.btn-spinner{border:2px solid #ffffff4d;border-top-color:#fff;border-radius:50%;width:18px;height:18px;animation:.6s linear infinite spin}[data-theme=dark] .btn-primary .btn-spinner{border-color:#1a1815 #1a18154d #1a18154d}.btn-secondary .btn-spinner{border-color:#5c7a5c4d;border-top-color:var(--color-accent)}.btn-ghost .btn-spinner{border-color:#6b6b5f4d;border-top-color:var(--color-text-secondary)}@keyframes spin{to{transform:rotate(360deg)}}.login-page{min-height:100vh;display:flex}.login-brand-panel{background:var(--color-accent-hover);justify-content:center;align-items:center;width:40%;display:flex;position:relative;overflow:hidden}[data-theme=dark] .login-brand-panel{background:#2a2620}.login-brand-content{text-align:center;color:#fff;z-index:1}.login-brand-title{font-family:var(--font-display);margin:16px 0 8px;font-size:36px}.login-brand-tagline{opacity:.85;font-size:16px}.login-brand-leaf{opacity:.5;width:300px;height:300px;position:absolute;bottom:-20px;right:-20px}.login-form-panel{background:var(--color-bg);flex:1;justify-content:center;align-items:center;padding:32px;display:flex}.login-form-container{width:100%;max-width:420px}.login-mobile-logo{font-family:var(--font-display);color:var(--color-text-primary);justify-content:center;align-items:center;gap:10px;margin-bottom:32px;font-size:22px;font-weight:600;display:none}.login-tabs{background:var(--color-border);border-radius:24px;margin-bottom:32px;padding:4px;display:flex}.login-tab{color:var(--color-text-secondary);cursor:pointer;transition:var(--transition-base);background:0 0;border:none;border-radius:20px;flex:1;padding:10px 16px;font-size:14px;font-weight:500}.login-tab.active{background:var(--color-surface);color:var(--color-text-primary);box-shadow:0 1px 4px #2c2c2c1a}[data-theme=dark] .login-tab.active{background:#242220}[data-theme=dark] .login-tabs{background:#2c2a26}.login-form{flex-direction:column;gap:20px;display:flex}.login-form-error{background:var(--color-status-red-bg);color:var(--color-status-red);border-radius:8px;padding:12px 16px;font-size:14px}.login-submit{height:48px;margin-top:4px}.login-switch{text-align:center;color:var(--color-text-secondary);margin-top:24px;font-size:14px}.login-switch-link{color:var(--color-accent);cursor:pointer;background:0 0;border:none;font-size:14px;text-decoration:none}.login-switch-link:hover{text-decoration:underline}@media (width<=1023px){.login-brand-panel{width:30%}.login-form-panel{width:70%}}@media (width<=767px){.login-brand-panel{display:none}.login-form-panel{padding:24px}.login-mobile-logo{display:flex}}.status-badge{white-space:nowrap;border-radius:24px;align-items:center;gap:4px;padding:4px 12px;font-size:12px;font-weight:500;display:inline-flex}.status-badge-with-icon{padding:4px 10px 4px 8px}.status-badge-icon{flex-shrink:0}.status-badge-on-track{background:var(--color-status-green-bg);color:var(--color-status-green)}.status-badge-due-today{background:var(--color-status-yellow-bg);color:var(--color-status-yellow)}.status-badge-overdue{background:var(--color-status-red-bg);color:var(--color-status-red)}.status-badge-not-set{background:var(--color-surface-alt);color:var(--color-text-disabled)}.plant-card{background:var(--color-surface);border-radius:var(--radius-card);box-shadow:var(--shadow-card);cursor:pointer;transition:var(--transition-base);flex-direction:column;min-height:280px;display:flex;overflow:hidden}.plant-card:hover{box-shadow:var(--shadow-card-hover);transform:translateY(-2px)}.plant-card-photo{width:100%;height:180px;overflow:hidden}.plant-card-photo img{object-fit:cover;width:100%;height:100%}.plant-card-placeholder{background:var(--color-status-green-bg);justify-content:center;align-items:center;width:100%;height:100%;display:flex}[data-theme=dark] .plant-card-placeholder{background:#1a2f22}.plant-card-body{flex:1;padding:16px}.plant-card-name{color:var(--color-text-primary);font-size:16px;font-weight:600;font-family:var(--font-body);text-overflow:ellipsis;white-space:nowrap;margin-bottom:2px;overflow:hidden}.plant-card-type{color:var(--color-text-secondary);margin-bottom:10px;font-size:13px;font-style:italic}.plant-card-badges{flex-wrap:wrap;gap:6px;display:flex}.plant-card-footer{justify-content:flex-end;gap:4px;padding:8px 16px 16px;display:flex}.plant-card-action{cursor:pointer;width:32px;height:32px;color:var(--color-text-secondary);transition:var(--transition-base);background:0 0;border:none;border-radius:50%;justify-content:center;align-items:center;display:flex}.plant-card-action:hover{background:var(--color-surface-alt);color:var(--color-text-primary)}.plant-card-skeleton{background:var(--color-surface);border-radius:var(--radius-card);min-height:280px;overflow:hidden}.plant-card-skeleton .skeleton-photo{height:180px}.plant-card-skeleton .skeleton-body{flex-direction:column;gap:8px;padding:16px;display:flex}.plant-card-skeleton .skeleton-line{border-radius:4px;height:16px}.plant-card-skeleton .skeleton-line-short{width:60%}.plant-card-skeleton .skeleton-badge{border-radius:24px;width:80px;height:24px}.modal-overlay{background:var(--color-overlay);z-index:200;justify-content:center;align-items:center;padding:16px;display:flex;position:fixed;inset:0}.modal-card{background:var(--color-surface);width:100%;max-height:85vh;box-shadow:var(--shadow-card-hover);border-radius:12px;padding:32px;overflow-y:auto}.modal-header{justify-content:space-between;align-items:flex-start;margin-bottom:20px;display:flex}.modal-title{font-size:18px;font-weight:600;font-family:var(--font-body);color:var(--color-text-primary)}.modal-close{cursor:pointer;color:var(--color-text-secondary);background:0 0;border:none;border-radius:50%;align-items:center;padding:4px;display:flex}.modal-close:hover{background:var(--color-surface-alt)}.modal-body{flex-direction:column;gap:16px;display:flex}@media (width<=767px){.modal-overlay{align-items:flex-end;padding:0}.modal-card{border-radius:16px 16px 0 0;min-height:60vh;max-height:90vh}}.plant-search-filter{margin-bottom:24px}.psf-search-container{max-width:480px;margin-bottom:12px;position:relative}.psf-search-icon{color:var(--color-text-secondary);pointer-events:none;position:absolute;top:50%;left:14px;transform:translateY(-50%)}.psf-search-input{border:1.5px solid var(--color-border);background:var(--color-surface);width:100%;height:44px;color:var(--color-text-primary);border-radius:8px;padding:0 40px 0 42px;font-family:DM Sans,sans-serif;font-size:15px;transition:border-color .15s,box-shadow .15s}.psf-search-input::placeholder{color:var(--color-text-disabled)}.psf-search-input:focus{border-color:var(--color-border-focus);outline:none;box-shadow:0 0 0 3px #5c7a5c26}.psf-search-input::-webkit-search-cancel-button{appearance:none}.psf-clear-btn{background:var(--color-surface-alt);width:24px;height:24px;color:var(--color-text-secondary);cursor:pointer;border:none;border-radius:50%;justify-content:center;align-items:center;min-width:44px;min-height:44px;margin:-10px -10px -10px 0;padding:0;transition:background .15s,color .15s;display:flex;position:absolute;top:50%;right:12px;transform:translateY(-50%)}.psf-clear-btn:hover{background:var(--color-border);color:var(--color-text-primary)}.psf-filter-row{justify-content:space-between;align-items:center;margin-bottom:24px;display:flex}.psf-tablist{-ms-overflow-style:none;scrollbar-width:none;flex-wrap:nowrap;gap:8px;display:flex;overflow-x:auto}.psf-tablist::-webkit-scrollbar{display:none}.psf-tab{white-space:nowrap;border:1.5px solid var(--color-border);background:var(--color-surface);height:36px;color:var(--color-text-secondary);cursor:pointer;border-radius:24px;justify-content:center;align-items:center;min-width:44px;min-height:44px;padding:0 16px;font-size:14px;font-weight:500;transition:all .15s;display:flex}.psf-tab:hover:not(.psf-tab--active){background:var(--color-surface-alt);border-color:var(--color-accent-primary);color:var(--color-text-primary)}.psf-tab--active{border-color:#0000}.psf-result-count{color:var(--color-text-secondary);opacity:0;white-space:nowrap;font-size:14px;transition:opacity .15s}.psf-result-count--visible{opacity:1}.psf-error-banner{color:#b85c38;background:#faeae4;border:1px solid #b85c38;border-radius:8px;align-items:center;gap:10px;margin-bottom:16px;padding:12px 16px;font-size:14px;display:flex}.psf-error-banner .btn{flex-shrink:0;margin-left:auto}.psf-empty-state{text-align:center;flex-direction:column;align-items:center;gap:12px;padding:60px 24px;display:flex}.psf-empty-heading{color:var(--color-text-primary);margin:4px 0 0;font-family:DM Sans,sans-serif;font-size:18px;font-weight:600}.psf-empty-subtext{color:var(--color-text-secondary);max-width:360px;font-size:14px}.psf-empty-actions{gap:12px;margin-top:8px;display:flex}.psf-skeleton-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:12px;overflow:hidden}.psf-skeleton-photo{background:var(--color-surface-alt);border-radius:12px 12px 0 0;height:180px}.psf-skeleton-body{flex-direction:column;gap:8px;padding:16px;display:flex}.psf-skeleton-line{background:var(--color-surface-alt);border-radius:4px;height:14px}.psf-skeleton-badge{background:var(--color-surface-alt);border-radius:24px;width:30%;height:20px;margin-top:4px}@media (prefers-reduced-motion:reduce){.skeleton{opacity:.5;animation:none}}@media (width<=1023px){.psf-search-container{max-width:100%}.psf-filter-row{flex-direction:column;align-items:flex-start;gap:8px}.psf-tablist{width:100%}.psf-result-count{font-size:13px}}@media (width<=767px){.psf-result-count{font-size:12px}.psf-empty-actions{flex-direction:column;width:100%}.psf-empty-actions .btn{width:100%}.psf-tablist{padding-bottom:4px;-webkit-mask-image:linear-gradient(90deg,#000 90%,#0000 100%);mask-image:linear-gradient(90deg,#000 90%,#0000 100%)}}.inventory-page{width:100%}.inventory-header{flex-wrap:wrap;justify-content:space-between;align-items:flex-start;gap:16px;margin-bottom:32px;display:flex}.inventory-title{font-family:var(--font-display);color:var(--color-text-primary);font-size:32px}.inventory-count{color:var(--color-text-secondary);margin-top:4px;font-size:14px}.inventory-actions{align-items:center;gap:12px;display:flex}.inventory-search{position:relative}.search-icon{color:var(--color-text-disabled);pointer-events:none;position:absolute;top:50%;left:12px;transform:translateY(-50%)}.search-input{border:1.5px solid var(--color-border);background:var(--color-surface);width:240px;height:40px;transition:var(--transition-base);border-radius:20px;padding:0 14px 0 38px;font-size:14px}.search-input:focus{border-color:var(--color-border-focus);outline:none;box-shadow:0 0 0 3px #5c7a5c26}.inventory-grid{grid-template-columns:repeat(3,1fr);gap:24px;display:grid}.inventory-empty{text-align:center;flex-direction:column;justify-content:center;align-items:center;gap:16px;padding:80px 24px;display:flex}.inventory-empty-title{font-family:var(--font-display);color:var(--color-text-primary);font-size:24px}.inventory-empty-text{color:var(--color-text-secondary);max-width:320px;font-size:14px}.inventory-error{text-align:center;color:var(--color-text-secondary);flex-direction:column;align-items:center;gap:16px;padding:60px 24px;font-size:15px;display:flex}.inventory-no-results{text-align:center;color:var(--color-text-secondary);padding:40px 24px;font-size:14px}.clear-search{color:var(--color-accent);cursor:pointer;background:0 0;border:none;margin-top:8px;font-size:14px}.clear-search:hover{text-decoration:underline}.add-plant-icon-only{display:none}@media (width<=1023px){.inventory-grid{grid-template-columns:repeat(2,1fr)}}@media (width<=767px){.inventory-header{flex-direction:row;align-items:center}.inventory-actions{flex-shrink:0}.inventory-grid{grid-template-columns:1fr}.add-plant-label{display:none}.add-plant-icon-only{font-size:20px;font-weight:700;line-height:1;display:inline}}.photo-upload-zone{border:2px dashed var(--color-border);background:var(--color-surface-alt);cursor:pointer;width:100%;height:220px;transition:var(--transition-base);border-radius:12px;justify-content:center;align-items:center;display:flex;position:relative;overflow:hidden}.photo-upload-compact .photo-upload-zone{height:140px}.photo-upload-zone.drag-active{border-color:var(--color-accent);background:#5c7a5c0d}[data-theme=dark] .photo-upload-zone.drag-active{background:#1a2f22}.photo-upload-zone:hover{border-color:var(--color-text-disabled)}.photo-upload-preview{object-fit:cover;width:100%;height:100%}.photo-upload-overlay{background:var(--color-overlay);color:#fff;opacity:0;flex-direction:column;justify-content:center;align-items:center;gap:4px;font-size:13px;transition:opacity .2s;display:flex;position:absolute;inset:0}[data-theme=dark] .photo-upload-overlay{color:#ede8df}.photo-upload-zone:hover .photo-upload-overlay{opacity:1}.photo-upload-empty{text-align:center;flex-direction:column;align-items:center;gap:8px;display:flex}.photo-upload-text{color:var(--color-text-primary);font-size:14px;font-weight:500}.photo-upload-hint{color:var(--color-text-secondary);font-size:12px}.photo-upload-remove{color:var(--color-status-red);cursor:pointer;background:0 0;border:none;align-items:center;gap:4px;margin-top:8px;font-size:13px;display:inline-flex}.photo-upload-remove:hover{text-decoration:underline}.photo-upload-error{color:var(--color-status-red);margin-top:6px;font-size:12px;display:block}.care-schedule-section{border-bottom:1px solid var(--color-border);padding:16px 0}.care-schedule-section:last-child{border-bottom:none}.care-schedule-toggle{color:var(--color-accent);cursor:pointer;background:0 0;border:none;align-items:center;gap:8px;padding:8px 0;font-size:14px;font-weight:500;display:flex}.care-schedule-toggle:hover{color:var(--color-accent-hover)}.care-schedule-header{justify-content:space-between;align-items:center;margin-bottom:12px;display:flex}.care-schedule-label{color:var(--color-text-primary);font-size:16px;font-weight:600}.care-required{color:var(--color-status-red)}.care-schedule-collapse{color:var(--color-status-red);cursor:pointer;background:0 0;border:none;font-size:13px}.care-schedule-collapse:hover{text-decoration:underline}.care-schedule-fields{flex-direction:column;gap:12px;display:flex}.care-frequency-row{align-items:center;gap:8px;display:flex}.care-frequency-label{color:var(--color-text-secondary);white-space:nowrap;font-size:14px}.care-frequency-input{border:1.5px solid var(--color-border);text-align:center;border-radius:8px;width:80px;height:40px;padding:0 12px;font-size:14px}.care-frequency-input:focus{border-color:var(--color-border-focus);outline:none;box-shadow:0 0 0 3px #5c7a5c26}.care-frequency-input.input-error{border-color:var(--color-status-red)}.care-frequency-select{border:1.5px solid var(--color-border);background:var(--color-surface);height:40px;color:var(--color-text-primary);cursor:pointer;border-radius:8px;padding:0 12px;font-size:14px}.care-frequency-select:focus{border-color:var(--color-border-focus);outline:none;box-shadow:0 0 0 3px #5c7a5c26}.care-date-row{flex-direction:column;gap:4px;display:flex}.care-date-label{color:var(--color-text-secondary);font-size:13px}.care-date-input{border:1.5px solid var(--color-border);border-radius:8px;max-width:200px;height:40px;padding:0 12px;font-size:14px}.care-date-input:focus{border-color:var(--color-border-focus);outline:none;box-shadow:0 0 0 3px #5c7a5c26}.care-error{color:var(--color-status-red);font-size:12px}.ai-filled{transition:background 2s,border-color 2s;border-color:var(--color-accent)!important;background:#5c7a5c14!important}.ai-badge{color:var(--color-accent);font-size:11px;font-weight:500}.advice-panel-backdrop{background:var(--color-overlay);z-index:300;animation:.2s forwards backdropIn;position:fixed;inset:0}.advice-panel-backdrop-out{animation:.2s forwards backdropOut}@keyframes backdropIn{0%{opacity:0}to{opacity:1}}@keyframes backdropOut{0%{opacity:1}to{opacity:0}}.advice-panel{background:var(--color-surface);z-index:301;border-radius:16px 0 0 16px;flex-direction:column;width:480px;height:100vh;animation:.28s cubic-bezier(.4,0,.2,1) forwards panelSlideIn;display:flex;position:fixed;top:0;right:0;overflow:hidden;box-shadow:0 8px 40px #2c2c2c2e}.advice-panel-out{animation:.24s forwards panelSlideOut}@keyframes panelSlideIn{0%{transform:translate(480px)}to{transform:translate(0)}}@keyframes panelSlideOut{0%{transform:translate(0)}to{transform:translate(480px)}}.advice-panel-drag-handle{display:none}.advice-panel-header{flex-shrink:0;justify-content:space-between;align-items:flex-start;padding:24px 24px 16px;display:flex}.advice-panel-title{font-family:var(--font-display);color:var(--color-text-primary);margin-bottom:4px;font-size:22px;font-weight:600}.advice-panel-subtitle{color:var(--color-text-secondary);font-size:14px}.advice-panel-close{cursor:pointer;color:var(--color-text-secondary);background:0 0;border:none;border-radius:50%;flex-shrink:0;align-items:center;padding:6px;display:flex}.advice-panel-close:hover{background:var(--color-surface-alt)}.advice-panel-tabs{flex-shrink:0;gap:8px;padding:0 24px 16px;display:flex}.advice-tab{cursor:pointer;background:var(--color-surface-alt);color:var(--color-text-secondary);border:none;border-radius:24px;flex:1;justify-content:center;align-items:center;gap:6px;padding:10px 16px;font-size:14px;font-weight:500;transition:background .15s,color .15s;display:flex}.advice-tab-active{background:var(--color-accent);color:#fff}.advice-tab:disabled{opacity:.5;cursor:not-allowed}.advice-panel-content{flex:1;padding:0 24px 24px;overflow-y:auto}.advice-input-label{color:var(--color-text-primary);margin-bottom:8px;font-size:14px;font-weight:500;display:block}.advice-text-input{border:1.5px solid var(--color-border);width:100%;font-size:16px;font-family:var(--font-body);color:var(--color-text-primary);background:var(--color-surface);border-radius:8px;padding:10px 14px;transition:border-color .15s}.advice-text-input:focus{border-color:var(--color-accent);outline:none}.advice-text-input:disabled{opacity:.6}.advice-char-counter{text-align:right;color:var(--color-text-disabled);margin-top:4px;font-size:12px;display:block}.advice-submit-btn{margin-top:12px}.advice-upload-zone{border:2px dashed var(--color-border);background:var(--color-bg);border-radius:12px;flex-direction:column;align-items:center;gap:8px;padding:32px 24px;transition:border-color .15s;display:flex}.advice-upload-zone-active{border-color:var(--color-accent)}.advice-upload-icon{color:var(--color-text-disabled)}.advice-upload-text{color:var(--color-text-secondary);font-size:16px}.advice-upload-or{color:var(--color-text-disabled);font-size:14px}.advice-file-preview{background:var(--color-surface-alt);border-radius:8px;align-items:center;gap:12px;padding:12px;display:flex}.advice-file-thumb{object-fit:cover;border-radius:8px;flex-shrink:0;width:80px;height:80px}.advice-file-info{flex-direction:column;gap:2px;min-width:0;display:flex}.advice-file-name{color:var(--color-text-secondary);white-space:nowrap;text-overflow:ellipsis;font-size:13px;overflow:hidden}.advice-file-size{color:var(--color-text-disabled);font-size:13px}.advice-file-remove{cursor:pointer;color:var(--color-text-secondary);background:0 0;border:none;border-radius:50%;margin-left:auto;padding:4px;display:flex}.advice-file-remove:hover{background:var(--color-border)}.advice-file-error{color:var(--color-status-red);margin-top:6px;font-size:13px}.advice-skeleton{flex-direction:column;gap:12px;padding:16px 0;display:flex}.skeleton-row{background:linear-gradient(90deg, var(--color-skeleton-base) 25%, var(--color-skeleton-highlight) 50%, var(--color-skeleton-base) 75%);background-size:200px 100%;border-radius:4px;height:20px;animation:1.5s infinite shimmer}.skeleton-row-wide{border-radius:10px;width:100%;height:48px}.skeleton-row-medium{width:80%}.skeleton-row-narrow{width:60%}.advice-results{animation:.2s forwards fadeInResults}@keyframes fadeInResults{0%{opacity:0}to{opacity:1}}.advice-search-again{color:var(--color-text-secondary);cursor:pointer;background:0 0;border:none;align-items:center;gap:4px;margin-bottom:12px;padding:4px 0;font-size:13px;display:inline-flex}.advice-search-again:hover{color:var(--color-text-primary)}.advice-plant-banner{background:var(--color-status-green-bg);border-radius:10px;justify-content:space-between;align-items:center;gap:12px;margin-bottom:8px;padding:14px 16px;display:flex}.advice-plant-banner-left{align-items:center;gap:12px;display:flex}.advice-plant-label{color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.05em;font-size:12px;display:block}.advice-plant-name{font-family:var(--font-display);color:var(--color-text-primary);font-size:18px;font-weight:600;display:block}.confidence-badge{white-space:nowrap;border-radius:24px;padding:4px 10px;font-size:12px;font-weight:500}.confidence-high{background:var(--color-status-green-bg);color:var(--color-status-green)}.confidence-medium{background:var(--color-status-yellow-bg);color:var(--color-status-yellow)}.confidence-low{background:var(--color-status-red-bg);color:var(--color-status-red)}.advice-disclaimer{color:var(--color-text-disabled);margin-bottom:8px;font-size:12px;font-style:italic}.advice-section-heading{font-size:14px;font-weight:600;font-family:var(--font-body);color:var(--color-text-primary);margin-top:20px;margin-bottom:8px}.advice-care-rows{flex-direction:column;display:flex}.care-row{border-bottom:1px solid var(--color-border);align-items:center;gap:12px;padding:10px 0;display:flex}.care-row:last-child{border-bottom:none}.care-row-icon{text-align:center;flex-shrink:0;width:24px;font-size:20px}.care-row-label{color:var(--color-text-secondary);font-size:14px;font-weight:500}.care-row-value{color:var(--color-text-primary);text-align:right;margin-left:auto;font-size:14px;font-weight:500}.care-row-null{color:var(--color-text-disabled);font-style:italic}.advice-tips-block{color:var(--color-text-primary);background:var(--color-bg);border-left:3px solid var(--color-accent);border-radius:8px;padding:14px;font-size:14px;line-height:1.6}.advice-cta-divider{border-top:1px solid var(--color-border);margin-top:24px}.advice-cta-footer{flex-direction:column;gap:8px;margin-top:16px;display:flex}.advice-dismiss-btn{font-weight:600}.advice-error-container{background:var(--color-status-red-bg);border:1px solid #f5c4b4;border-radius:10px;flex-direction:column;align-items:flex-start;gap:8px;margin-top:16px;padding:16px;display:flex}[data-theme=dark] .advice-error-container{border-color:#5a2e24}.advice-error-icon{color:var(--color-status-red)}.advice-error-text{color:var(--color-status-red);font-size:14px}.advice-retry-btn{margin-top:4px}.advice-switch-btn{margin-top:0}[data-theme=dark] .advice-panel{background:#1e1e1a;box-shadow:0 8px 40px #0006}[data-theme=dark] .advice-text-input{color:var(--color-text-primary);background:#2a2a25;border-color:#3a3a34}[data-theme=dark] .advice-text-input:focus{border-color:var(--color-accent)}[data-theme=dark] .advice-upload-zone{background:#252520;border-color:#3a3a34}[data-theme=dark] .advice-plant-banner{background:#1e2e22}[data-theme=dark] .advice-tips-block{background:#252520}[data-theme=dark] .care-row{border-bottom-color:#2e2e28}@media (width>=768px) and (width<=1023px){.advice-panel{width:400px}@keyframes panelSlideIn{0%{transform:translate(400px)}to{transform:translate(0)}}@keyframes panelSlideOut{0%{transform:translate(0)}to{transform:translate(400px)}}}@media (width<=767px){.advice-panel{border-radius:16px 16px 0 0;width:100%;height:auto;max-height:90vh;animation:.3s cubic-bezier(.4,0,.2,1) forwards sheetSlideUp;inset:auto 0 0;box-shadow:0 -8px 40px #2c2c2c2e}.advice-panel-out{animation:.25s forwards sheetSlideDown}@keyframes sheetSlideUp{0%{transform:translateY(100%)}to{transform:translateY(0)}}@keyframes sheetSlideDown{0%{transform:translateY(0)}to{transform:translateY(100%)}}.advice-panel-drag-handle{justify-content:center;padding:8px 0 4px;display:flex}.drag-handle-pill{background:var(--color-border);border-radius:2px;width:32px;height:4px}.advice-panel-header{padding:16px 20px 12px}.advice-panel-tabs{padding:0 20px 12px}.advice-panel-content{padding:0 20px 20px}}@media (prefers-reduced-motion:reduce){.advice-panel,.advice-panel-out{animation:none;transform:none}.advice-panel-backdrop,.advice-panel-backdrop-out{animation:none}.advice-results{animation-duration:.3s}.skeleton-row{animation:none}}.plant-form-page{max-width:720px;margin:0 auto}.plant-form-title{font-family:var(--font-display);color:var(--color-text-primary);margin-bottom:8px;font-size:32px}.plant-form-subtitle{color:var(--color-text-secondary);margin-bottom:32px;font-size:14px}.plant-form{flex-direction:column;gap:32px;display:flex}.plant-form-error{background:var(--color-status-red-bg);color:var(--color-status-red);border-radius:8px;padding:12px 16px;font-size:14px}.plant-form-section{flex-direction:column;gap:20px;display:flex}.plant-form-section-title{font-size:18px;font-weight:600;font-family:var(--font-body);color:var(--color-text-primary)}.ai-advice-card-section{background:var(--color-surface-alt);border-radius:12px;padding:24px}.ai-advice-prompt{justify-content:space-between;align-items:flex-start;gap:16px;display:flex}.ai-advice-heading{font-size:16px;font-weight:600;font-family:var(--font-body);align-items:center;gap:8px;margin-bottom:8px;display:flex}.ai-advice-desc{color:var(--color-text-secondary);font-size:13px}.ai-advice-trigger{display:flex}.plant-form-actions{border-top:1px solid var(--color-border);justify-content:flex-end;gap:12px;padding:16px 0;display:flex}.ai-filled-input .input-field{border-color:var(--color-accent);background:#5c7a5c14}.plant-form-skeleton{flex-direction:column;gap:24px;max-width:720px;margin:0 auto;display:flex}.plant-form-skeleton .skeleton-title{width:250px;height:36px;margin-bottom:8px}.plant-form-skeleton .skeleton-field{width:100%;height:44px}.plant-form-skeleton .skeleton-textarea{width:100%;height:80px}.plant-form-skeleton .skeleton-photo{border-radius:12px;width:100%;height:220px}@media (width<=767px){.ai-advice-prompt{flex-direction:column}.plant-form-actions{background:var(--color-bg);flex-direction:column-reverse;margin:0 -16px;padding:16px;position:sticky;bottom:0}.plant-form-actions .btn{width:100%}}.detail-page{max-width:860px;margin:0 auto}.detail-header{background:var(--color-surface);border-radius:var(--radius-card);gap:32px;margin-bottom:32px;padding:32px;display:flex}.detail-photo-container{flex-shrink:0}.detail-photo{border-radius:var(--radius-card);object-fit:cover;width:240px;height:240px}.detail-photo-placeholder{border-radius:var(--radius-card);background:var(--color-status-green-bg);justify-content:center;align-items:center;width:240px;height:240px;display:flex}[data-theme=dark] .detail-photo-placeholder{background:#1a2f22}.detail-info{flex-direction:column;flex:1;display:flex}.detail-name{font-family:var(--font-display);color:var(--color-text-primary);font-size:36px}.detail-type{color:var(--color-text-secondary);margin-top:4px;font-size:16px;font-style:italic}.detail-date{color:var(--color-text-disabled);margin-top:8px;font-size:13px}.detail-notes{margin-top:16px}.detail-notes-label{color:var(--color-text-secondary);margin-bottom:4px;font-size:13px;font-weight:500;display:block}.detail-notes-text{background:var(--color-bg);color:var(--color-text-primary);border-radius:8px;padding:12px 16px;font-size:14px}.detail-actions{gap:8px;margin-top:auto;padding-top:16px;display:flex}.detail-care-section{margin-bottom:32px}.detail-section-title{font-size:18px;font-weight:600;font-family:var(--font-body);margin-bottom:16px}.detail-care-grid{grid-template-columns:repeat(2,1fr);gap:16px;display:grid}.care-card{background:var(--color-surface);border-radius:var(--radius-card);border:1.5px solid var(--color-border);flex-direction:column;gap:8px;padding:24px;display:flex}.care-card-empty{opacity:.6}.care-card-header{justify-content:space-between;align-items:center;display:flex}.care-card-label{align-items:center;gap:8px;font-size:16px;font-weight:600;display:flex}.care-card-frequency{color:var(--color-text-secondary);font-size:14px}.care-card-last-done,.care-card-next-due{color:var(--color-text-secondary);font-size:13px}.text-yellow{color:var(--color-status-yellow);font-weight:500}.care-card-add-link{color:var(--color-accent);cursor:pointer;text-align:left;background:0 0;border:none;padding:4px 0;font-size:14px;font-weight:500}.care-card-add-link:hover{text-decoration:underline}.care-mark-btn{height:44px;margin-top:8px}.care-done-btn{cursor:default;border-radius:8px;width:100%;height:44px;margin-top:8px;font-size:14px;font-weight:600}.care-done-success{background:var(--color-status-green-bg);color:var(--color-status-green);border:1.5px solid var(--color-status-green);animation:.4s cubic-bezier(.34,1.56,.64,1) pulseScale}[data-theme=dark] .care-done-success{color:#6eb88a;background:#1a2f22;border-color:#3a5c43}@keyframes pulseScale{0%{transform:scale(1)}50%{transform:scale(1.04)}to{transform:scale(1)}}.care-undo-btn{color:var(--color-text-secondary);cursor:pointer;text-align:center;background:0 0;border:none;padding:4px 0;font-size:13px}.care-undo-btn:hover{color:var(--color-accent);text-decoration:underline}.detail-activity{margin-bottom:32px}.activity-list{flex-direction:column;gap:8px;display:flex}.activity-item{color:var(--color-text-secondary);border-bottom:1px solid var(--color-border);align-items:center;gap:10px;padding:8px 0;font-size:13px;display:flex}.activity-item:last-child{border-bottom:none}.activity-time{color:var(--color-text-disabled);margin-left:auto;font-size:12px}.activity-empty{color:var(--color-text-disabled);font-size:13px}.skeleton-header{gap:32px;display:flex}.detail-photo-skeleton{border-radius:12px;width:240px;height:240px}.detail-info-skeleton{flex-direction:column;flex:1;display:flex}.delete-modal-actions{justify-content:flex-end;gap:12px;margin-top:8px;display:flex}.plant-not-found{text-align:center;flex-direction:column;align-items:center;gap:16px;padding:60px 24px;display:flex}.plant-not-found h2{font-size:20px;font-family:var(--font-body)}.plant-not-found p{color:var(--color-text-secondary)}@media (width<=1023px){.detail-care-grid{grid-template-columns:1fr}}@media (width<=767px){.detail-header{flex-direction:column;padding:24px}.detail-photo,.detail-photo-placeholder{width:100%;height:180px}.detail-name{font-size:28px}}.delete-modal-overlay{background:var(--color-overlay);z-index:1000;justify-content:center;align-items:center;padding:16px;display:flex;position:fixed;inset:0}.delete-modal-card{background:var(--color-modal);border-radius:12px;flex-direction:column;align-items:center;width:calc(100% - 32px);max-width:480px;padding:32px;display:flex;box-shadow:0 8px 32px #0000004d}.delete-modal-icon{margin-bottom:16px}.delete-modal-heading{font-family:var(--font-display);color:var(--color-text-primary);text-align:center;margin:0;font-size:24px;font-weight:600}.delete-modal-body{font-family:var(--font-body);color:var(--color-text-secondary);text-align:center;margin-top:12px;margin-bottom:0;font-size:15px;line-height:1.6}.delete-modal-password-group{width:100%;margin-top:20px}.delete-modal-password-label{color:var(--color-text-primary);margin-bottom:6px;font-size:14px;font-weight:500;display:block}.delete-modal-password-wrapper{width:100%;position:relative}.delete-modal-password-input{border:1.5px solid var(--color-border);background:var(--color-surface);width:100%;height:44px;color:var(--color-text-primary);font-size:15px;font-family:var(--font-body);box-sizing:border-box;border-radius:8px;padding:0 44px 0 14px}.delete-modal-password-input:focus{border-color:var(--color-border-focus);outline:none;box-shadow:0 0 0 3px #5c7a5c26}.delete-modal-password-input--error{border-color:var(--color-status-red)}.delete-modal-password-input:disabled{opacity:.6;cursor:not-allowed}.delete-modal-password-toggle{cursor:pointer;background:0 0;border:none;justify-content:center;align-items:center;padding:0;display:flex;position:absolute;top:50%;right:12px;transform:translateY(-50%)}.delete-modal-password-toggle:disabled{opacity:.6;cursor:not-allowed}.delete-modal-password-error{color:var(--color-status-red);margin-top:6px;font-size:13px;display:block}.delete-modal-error{color:var(--color-status-red);text-align:center;background:var(--color-status-red-bg);border-radius:8px;width:100%;margin-top:12px;padding:8px 16px;font-size:13px}.delete-modal-actions{justify-content:center;gap:12px;width:100%;margin-top:24px;display:flex}.delete-modal-cancel{min-width:120px}.delete-modal-confirm{min-width:160px}@media (width<=767px){.delete-modal-card{width:100%}.delete-modal-actions{flex-direction:column}.delete-modal-cancel,.delete-modal-confirm{width:100%;min-width:unset}}.theme-toggle-section{flex-direction:column;gap:12px;display:flex}.theme-toggle-label{color:var(--color-text-secondary);font-size:13px;font-weight:500}.theme-toggle-control{border:1.5px solid var(--color-border);background:var(--color-surface-alt);border-radius:8px;display:inline-flex;overflow:hidden}.theme-toggle-option{color:var(--color-text-secondary);cursor:pointer;background:0 0;border:none;align-items:center;gap:6px;padding:8px 16px;font-size:13px;font-weight:500;transition:background .15s,color .15s;display:inline-flex}.theme-toggle-option:hover:not(.theme-toggle-option--active){color:var(--color-text-primary);background:#0000000a}[data-theme=dark] .theme-toggle-option:hover:not(.theme-toggle-option--active){background:#ffffff0a}.theme-toggle-option--active{background:var(--color-surface);color:var(--color-text-primary);box-shadow:0 1px 3px #0000001a}.profile-page{max-width:640px;margin:0 auto}.profile-title{font-family:var(--font-display);color:var(--color-text-primary);margin-bottom:32px;font-size:32px}.profile-card{background:var(--color-surface);border-radius:var(--radius-card);align-items:center;gap:24px;margin-bottom:24px;padding:32px;display:flex}.profile-avatar{background:var(--color-accent);color:#fff;width:88px;height:88px;font-family:var(--font-display);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:36px;font-weight:600;display:flex}[data-theme=dark] .profile-avatar{color:#ede8df;background:#2a4a2a}.profile-details{flex-direction:column;gap:4px;display:flex}.profile-name{font-family:var(--font-display);font-size:24px;font-weight:600}.profile-email{color:var(--color-text-secondary);font-size:14px}.profile-member{color:var(--color-text-disabled);align-items:center;gap:6px;margin-top:4px;font-size:13px;display:flex}.profile-stats{grid-template-columns:repeat(3,1fr);gap:16px;margin-bottom:24px;display:grid}.stat-tile{background:var(--color-bg);border-radius:var(--radius-card);text-align:center;flex-direction:column;align-items:center;gap:8px;padding:24px;display:flex}.stat-number{font-family:var(--font-display);color:var(--color-accent);font-size:40px;font-weight:600}.stat-label{color:var(--color-text-secondary);font-size:13px}.profile-appearance-card{background:var(--color-surface);border:1.5px solid var(--color-border);border-radius:var(--radius-card);margin-bottom:24px;padding:24px}.profile-actions-card{flex-direction:column;align-items:flex-start;gap:12px;display:flex}.profile-delete-btn{color:var(--color-status-red);cursor:pointer;transition:var(--transition-base);background:0 0;border:none;margin-top:4px;padding:0;font-size:13px;font-weight:500}.profile-delete-btn:hover{opacity:.8}.profile-history-link{color:var(--color-accent);transition:var(--transition-base);margin-bottom:16px;font-size:13px;font-weight:500;text-decoration:none}.profile-history-link:hover{opacity:.8}.profile-error{text-align:center;color:var(--color-text-secondary);flex-direction:column;align-items:center;gap:16px;padding:40px;display:flex}@media (width<=767px){.profile-card{text-align:center;flex-direction:column}.profile-stats{grid-template-columns:1fr}.profile-actions-card{align-items:stretch}.profile-actions-card .btn{width:100%}}.care-history-page{max-width:720px;margin:0 auto;padding:40px 32px}.care-history-title{font-family:var(--font-display);color:var(--color-text-primary);margin-bottom:8px;font-size:32px;font-weight:600}.care-history-subtitle{color:var(--color-text-secondary);margin-bottom:24px;font-size:14px}.care-history-filter-bar{justify-content:space-between;align-items:center;gap:16px;margin-bottom:16px;display:flex}.care-history-filter-group{align-items:center;gap:8px;display:flex}.care-history-filter-label{color:var(--color-text-secondary);white-space:nowrap;font-size:13px}.care-history-filter-select{background:var(--color-surface);border:1.5px solid var(--color-border);color:var(--color-text-primary);cursor:pointer;min-width:200px;font-size:14px;font-family:var(--font-body);appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath d='M2 4l4 4 4-4' stroke='%236B6B5F' stroke-width='1.5' fill='none' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");background-position:right 12px center;background-repeat:no-repeat;border-radius:8px;padding:8px 32px 8px 12px}.care-history-filter-select:focus{border-color:var(--color-accent);outline-offset:2px;outline:2px solid #5c7a5c33}.care-history-result-count{color:var(--color-text-disabled);white-space:nowrap;font-size:13px}.care-history-list{margin-top:16px}.care-history-item{align-items:center;gap:16px;padding:16px 0;display:flex}.care-history-item+.care-history-item{border-top:1px solid var(--color-border)}.care-history-icon-circle{border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:44px;height:44px;display:flex}.care-history-item-info{flex-direction:column;flex:1;min-width:0;display:flex}.care-history-plant-name{color:var(--color-text-primary);text-overflow:ellipsis;white-space:nowrap;font-size:15px;font-weight:500;overflow:hidden}.care-history-action-label{color:var(--color-text-secondary);margin-top:2px;font-size:13px}.care-history-timestamp{text-align:right;color:var(--color-text-secondary);flex-shrink:0;font-size:13px}.care-history-load-more{justify-content:center;margin-top:24px;display:flex}.care-history-centered-state{text-align:center;flex-direction:column;align-items:center;padding:64px 24px;display:flex}.care-history-empty-illustration{margin-bottom:0}.care-history-state-heading{font-family:var(--font-display);color:var(--color-text-primary);margin-top:24px;font-size:22px;font-weight:600}.care-history-state-heading--filtered{font-size:20px}.care-history-state-body{color:var(--color-text-secondary);margin-top:8px;font-size:14px;line-height:1.6}.care-history-centered-state .btn{margin-top:24px}.care-history-skeleton-list{margin-top:16px}.care-history-skeleton-row{align-items:center;gap:16px;padding:16px 0;display:flex}.care-history-skeleton-row+.care-history-skeleton-row{border-top:1px solid var(--color-border)}.skeleton-circle{border-radius:50%;flex-shrink:0;width:44px;height:44px}.skeleton-text-group{flex:1;min-width:0}.skeleton-line{border-radius:4px;height:14px}.skeleton-line-sm{border-radius:4px;height:12px}.skeleton-timestamp{border-radius:4px;flex-shrink:0;width:72px;height:12px}.care-history-skeleton-list .skeleton{background:linear-gradient(90deg, var(--color-skeleton-base) 25%, var(--color-skeleton-highlight) 50%, var(--color-skeleton-base) 75%);background-size:200% 100%;animation:1.4s ease-in-out infinite shimmer}@media (width<=767px){.care-history-page{padding:24px 16px}.care-history-filter-bar{flex-direction:column;align-items:stretch}.care-history-result-count{order:-1}.care-history-filter-group{width:100%}.care-history-filter-select{width:100%;min-width:0}.care-history-plant-name{max-width:150px}}.care-due-page{max-width:800px;margin:0 auto;padding:40px 32px}.care-due-title{font-family:var(--font-display);color:var(--color-text-primary);margin:0 0 8px;font-size:32px;font-weight:600}.care-due-subtitle{font-family:var(--font-body);color:var(--color-text-secondary);margin:0 0 32px;font-size:14px}.care-due-section{margin-bottom:32px}.care-due-section-header{align-items:center;gap:10px;margin-bottom:16px;display:flex}.care-due-section-title{font-family:var(--font-body);text-transform:uppercase;letter-spacing:.08em;margin:0;font-size:13px;font-weight:600}.care-due-section-count{border-radius:24px;padding:2px 8px;font-size:11px;font-weight:600}.care-due-section-empty{background:var(--color-bg);border:1px dashed var(--color-border);text-align:center;border-radius:12px;margin-bottom:10px;padding:20px 24px}.care-due-section-empty p{font-family:var(--font-body);color:var(--color-text-disabled);margin:0;font-size:14px}.care-due-item-list{margin:0;padding:0;list-style:none}.care-due-card{background:var(--color-surface);border:1px solid var(--color-border);box-shadow:var(--shadow-card);border-radius:12px;align-items:center;gap:16px;margin-bottom:10px;padding:16px 20px;transition:box-shadow .2s,border-color .2s,opacity .3s,max-height .3s,margin .3s,padding .3s;display:flex}.care-due-card:hover{box-shadow:var(--shadow-card-hover);border-color:var(--color-border)}.care-due-card--removing{opacity:0;max-height:0;margin-bottom:0;padding-top:0;padding-bottom:0;overflow:hidden}@media (prefers-reduced-motion:reduce){.care-due-card--removing{transition:none}}.care-due-card-icon{border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:44px;height:44px;display:flex}.care-due-card-info{flex-direction:column;flex:1;min-width:0;display:flex}.care-due-card-plant-name{font-family:var(--font-body);color:var(--color-text-primary);white-space:nowrap;text-overflow:ellipsis;font-size:15px;font-weight:500;overflow:hidden}.care-due-card-care-type{font-family:var(--font-body);color:var(--color-text-secondary);margin-top:2px;font-size:13px}.care-due-card-urgency{font-family:var(--font-body);margin-top:4px;font-size:12px;font-weight:500}.care-due-mark-done-btn{font-family:var(--font-body);border:1px solid var(--color-border);background:var(--color-surface);color:var(--color-text-primary);cursor:pointer;transition:var(--transition-base);text-align:center;border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;min-width:110px;padding:8px 16px;font-size:13px;display:flex}.care-due-mark-done-btn:hover:not(:disabled){background:var(--color-bg);border-color:var(--color-border)}.care-due-mark-done-btn:disabled{cursor:not-allowed;opacity:.7}.care-due-mark-spinner{border:2px solid #5c7a5c33;border-top-color:var(--color-accent);border-radius:50%;width:14px;height:14px;animation:.8s linear infinite care-due-spin;display:inline-block}[data-theme=dark] .care-due-mark-spinner{border-color:#7eaf7e33;border-top-color:var(--color-accent)}@media (prefers-reduced-motion:reduce){.care-due-mark-spinner{border-top-color:#0000;border-right-color:var(--color-accent);animation:none}}@keyframes care-due-spin{to{transform:rotate(360deg)}}.care-due-centered-state{text-align:center;padding:80px 24px}.care-due-state-heading{font-family:var(--font-display);color:var(--color-text-primary);margin:20px 0 0;font-size:22px}.care-due-state-heading--error{margin-top:20px}.care-due-state-body{font-family:var(--font-body);color:var(--color-text-secondary);margin:8px 0 0;font-size:14px}.care-due-all-clear{max-width:480px;margin:0 auto}.care-due-all-clear-illustration{margin-bottom:0}.care-due-all-clear-heading{font-family:var(--font-display);color:var(--color-text-primary);margin-top:28px;font-size:26px;font-weight:600}.care-due-all-clear-body{font-family:var(--font-body);color:var(--color-text-secondary);margin-top:10px;font-size:15px;line-height:1.6}.care-due-skeletons{flex-direction:column;gap:32px;display:flex}.care-due-skeleton-section{flex-direction:column;gap:10px;display:flex}.care-due-skeleton-header{border-radius:4px;width:120px;height:14px;margin-bottom:6px}.care-due-skeleton-card{background:var(--color-surface-alt);border:1px solid var(--color-border);border-radius:12px;align-items:center;gap:16px;padding:16px 20px;display:flex}.care-due-skeleton-circle{border-radius:50%;flex-shrink:0;width:44px;height:44px}.care-due-skeleton-text{flex:1;min-width:0}.care-due-skeleton-line{border-radius:4px;height:14px}.care-due-skeleton-line-sm{border-radius:4px;height:12px}.care-due-skeleton-line-xs{border-radius:4px;height:11px}.care-due-skeleton-btn{border-radius:8px;flex-shrink:0;width:110px;height:34px}.skeleton{background:linear-gradient(90deg, var(--color-skeleton-base) 25%, var(--color-skeleton-highlight) 50%, var(--color-skeleton-base) 75%);background-size:200% 100%;animation:1.4s ease-in-out infinite shimmer}@media (prefers-reduced-motion:reduce){.skeleton{background:var(--color-skeleton-highlight);animation:none}}@media (width<=1023px){.care-due-page{padding:32px 24px}}@media (width<=767px){.care-due-page{padding:24px 16px}.care-due-title{font-size:26px}.care-due-card{flex-wrap:wrap}.care-due-card-info{flex:1;min-width:0}.care-due-mark-done-btn{flex-basis:100%;margin-top:12px}.care-due-skeleton-card{flex-wrap:wrap}.care-due-skeleton-btn{flex-basis:100%;margin-top:8px}}.stat-tile{background:var(--color-surface);border:1px solid var(--color-border);box-shadow:var(--card-shadow);border-radius:12px;padding:24px}.stat-tile-label{color:var(--color-text-secondary);align-items:center;gap:8px;font-family:DM Sans,sans-serif;font-size:13px;font-weight:500;display:flex}.stat-tile-value{color:var(--color-accent-primary);-webkit-line-clamp:2;-webkit-box-orient:vertical;margin:8px 0 4px;font-family:Playfair Display,serif;font-size:40px;font-weight:600;line-height:1.1;display:-webkit-box;overflow:hidden}.stat-tile-sub{color:var(--color-text-secondary);font-family:DM Sans,sans-serif;font-size:12px}.care-donut-container{flex:0 0 55%;min-width:0}.care-donut-heading{color:var(--color-text-primary);margin:0 0 20px;font-family:DM Sans,sans-serif;font-size:16px;font-weight:600}.care-donut-card{background:var(--color-surface);border:1px solid var(--color-border);box-shadow:var(--card-shadow);border-radius:12px;padding:24px}.care-donut-layout{align-items:center;gap:24px;display:flex}.care-donut-chart-wrapper{flex-shrink:0}.care-donut-svg{max-width:100%;height:auto;display:block}.care-donut-center-value{fill:var(--color-text-primary);font-family:Playfair Display,serif;font-size:28px;font-weight:600}.care-donut-center-label{fill:var(--color-text-secondary);font-family:DM Sans,sans-serif;font-size:12px}.care-donut-legend{flex-direction:column;gap:10px;margin:0;padding:0;list-style:none;display:flex}.care-donut-legend-row{align-items:center;gap:8px;display:flex}.care-donut-legend-dot{border-radius:50%;flex-shrink:0;width:10px;height:10px}.care-donut-legend-label{color:var(--color-text-primary);flex:1;font-family:DM Sans,sans-serif;font-size:14px;font-weight:500}.care-donut-legend-count{color:var(--color-text-primary);text-align:right;min-width:24px;font-family:DM Sans,sans-serif;font-size:14px;font-weight:600}.care-donut-legend-pct{color:var(--color-text-secondary);margin-left:6px;font-family:DM Sans,sans-serif;font-size:12px}@media (width<=1023px){.care-donut-container{flex:100%}.care-donut-layout{flex-direction:column}}.activity-feed-container{flex:0 0 45%;min-width:0}.activity-feed-heading{color:var(--color-text-primary);margin:0 0 20px;font-family:DM Sans,sans-serif;font-size:16px;font-weight:600}.activity-feed-card{background:var(--color-surface);border:1px solid var(--color-border);box-shadow:var(--card-shadow);border-radius:12px;height:100%;padding:24px;overflow-y:auto}.activity-feed-list{flex-direction:column;margin:0;padding:0;list-style:none;display:flex}.activity-feed-row{align-items:center;gap:12px;padding:12px 0;display:flex}.activity-feed-row-bordered{border-bottom:1px solid var(--color-border)}.activity-feed-icon{border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:32px;height:32px;display:flex}.activity-feed-info{flex-direction:column;flex:1;min-width:0;display:flex}.activity-feed-plant{color:var(--color-text-primary);text-overflow:ellipsis;white-space:nowrap;font-family:DM Sans,sans-serif;font-size:14px;font-weight:500;line-height:1.3;overflow:hidden}.activity-feed-type{color:var(--color-text-secondary);font-family:DM Sans,sans-serif;font-size:12px}.activity-feed-time{color:var(--color-text-disabled,var(--color-text-secondary));white-space:nowrap;flex-shrink:0;font-family:DM Sans,sans-serif;font-size:11px}@media (width<=1023px){.activity-feed-container{flex:100%}.activity-feed-card{height:auto}}.plant-freq-container{width:100%}.plant-freq-heading{color:var(--color-text-primary);margin:0 0 16px;font-family:DM Sans,sans-serif;font-size:16px;font-weight:600}.plant-freq-card{background:var(--color-surface);border:1px solid var(--color-border);box-shadow:var(--card-shadow);border-radius:12px;padding:24px}.plant-freq-scroll{max-height:400px;overflow-y:auto}.plant-freq-table{border-collapse:collapse;width:100%}.plant-freq-th{text-transform:uppercase;letter-spacing:.06em;color:var(--color-text-secondary);border-bottom:1px solid var(--color-border);text-align:left;padding-bottom:12px;font-family:DM Sans,sans-serif;font-size:11px;font-weight:600}.plant-freq-td{color:var(--color-text-primary);padding:14px 0;font-family:DM Sans,sans-serif;font-size:14px}.plant-freq-row-bordered td{border-bottom:1px solid var(--color-border)}.plant-freq-name{align-items:center;gap:8px;width:35%;font-weight:500;display:flex}.plant-freq-name span{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.plant-freq-last-cared{color:var(--color-text-secondary);width:25%;font-size:13px}.plant-freq-actions{align-items:center;gap:12px;width:40%;display:flex}.plant-freq-count{color:var(--color-text-primary);text-align:right;min-width:28px;font-size:14px;font-weight:600}.plant-freq-bar-track{background:var(--color-border);border-radius:3px;flex:1;height:6px;overflow:hidden}.plant-freq-bar-fill{background:var(--color-accent-primary);border-radius:3px;height:100%;transition:width .3s}@media (width<=767px){.plant-freq-th-last-cared,.plant-freq-last-cared{display:none}.plant-freq-name{width:45%}.plant-freq-actions{width:55%}}.analytics-page{width:100%}.analytics-content{max-width:960px;margin:0 auto;padding:40px 32px}.analytics-title{color:var(--color-text-primary);margin:0;font-family:Playfair Display,serif;font-size:32px;font-weight:600}.analytics-subtitle{color:var(--color-text-secondary);margin:4px 0 32px;font-family:DM Sans,sans-serif;font-size:14px}.analytics-stats-grid{grid-template-columns:repeat(3,1fr);gap:16px;margin-bottom:24px;display:grid}.analytics-middle-grid{gap:24px;margin-bottom:24px;display:flex}.analytics-skeleton-wrapper{width:100%}.analytics-skeleton{background:linear-gradient(90deg, var(--color-border) 25%, var(--color-surface-alt,var(--color-surface)) 50%, var(--color-border) 75%);background-size:200% 100%;animation:1.5s ease-in-out infinite shimmer}@media (prefers-reduced-motion:reduce){.analytics-skeleton{background:var(--color-surface-alt,var(--color-border));animation:none}}.analytics-skeleton-tile{background:var(--color-surface);border:1px solid var(--color-border);border-radius:12px;flex-direction:column;justify-content:center;height:108px;padding:24px;display:flex}.analytics-skeleton-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:12px}.analytics-empty{text-align:center;flex-direction:column;align-items:center;max-width:420px;margin:64px auto;display:flex}.analytics-empty-heading{color:var(--color-text-primary);margin:24px 0 0;font-family:Playfair Display,serif;font-size:24px;font-weight:600}.analytics-empty-body{color:var(--color-text-secondary);margin:8px 0 0;font-family:DM Sans,sans-serif;font-size:15px;line-height:1.6}.analytics-empty-cta{background:var(--color-accent-primary,#5c7a5c);color:#fff;cursor:pointer;border:none;border-radius:8px;margin-top:24px;padding:10px 24px;font-family:DM Sans,sans-serif;font-size:14px;font-weight:600;transition:opacity .15s}.analytics-empty-cta:hover{opacity:.9}.analytics-empty-cta:focus-visible{outline:2px solid var(--color-accent-primary,#5c7a5c);outline-offset:2px}.analytics-error{text-align:center;flex-direction:column;align-items:center;max-width:420px;margin:64px auto;display:flex}.analytics-error-heading{color:var(--color-text-primary);margin:20px 0 0;font-family:Playfair Display,serif;font-size:22px}.analytics-error-body{color:var(--color-text-secondary);margin:8px 0 0;font-family:DM Sans,sans-serif;font-size:14px}.analytics-retry-btn{color:var(--color-text-primary);border:1px solid var(--color-border);cursor:pointer;background:0 0;border-radius:8px;margin-top:24px;padding:10px 24px;font-family:DM Sans,sans-serif;font-size:14px;font-weight:600;transition:background .15s}.analytics-retry-btn:hover{background:var(--color-surface-alt,var(--color-surface))}.analytics-retry-btn:focus-visible{outline:2px solid var(--color-accent-primary,#5c7a5c);outline-offset:2px}.sr-only{clip:rect(0, 0, 0, 0);white-space:nowrap;border:0;width:1px;height:1px;margin:-1px;padding:0;position:absolute;overflow:hidden}@media (width<=1023px){.analytics-middle-grid{flex-direction:column}}@media (width<=767px){.analytics-content{padding:24px 16px}.analytics-stats-grid{grid-template-columns:1fr}.analytics-middle-grid{flex-direction:column}}
