html{--mat-sys-background: #faf9fd;--mat-sys-error: #ba1a1a;--mat-sys-error-container: #ffdad6;--mat-sys-inverse-on-surface: #f2f0f4;--mat-sys-inverse-primary: #abc7ff;--mat-sys-inverse-surface: #2f3033;--mat-sys-on-background: #1a1b1f;--mat-sys-on-error: #ffffff;--mat-sys-on-error-container: #93000a;--mat-sys-on-primary: #ffffff;--mat-sys-on-primary-container: #00458f;--mat-sys-on-primary-fixed: #001b3f;--mat-sys-on-primary-fixed-variant: #00458f;--mat-sys-on-secondary: #ffffff;--mat-sys-on-secondary-container: #3e4759;--mat-sys-on-secondary-fixed: #131c2b;--mat-sys-on-secondary-fixed-variant: #3e4759;--mat-sys-on-surface: #1a1b1f;--mat-sys-on-surface-variant: #44474e;--mat-sys-on-tertiary: #ffffff;--mat-sys-on-tertiary-container: #0000ef;--mat-sys-on-tertiary-fixed: #00006e;--mat-sys-on-tertiary-fixed-variant: #0000ef;--mat-sys-outline: #74777f;--mat-sys-outline-variant: #c4c6d0;--mat-sys-primary: #005cbb;--mat-sys-primary-container: #d7e3ff;--mat-sys-primary-fixed: #d7e3ff;--mat-sys-primary-fixed-dim: #abc7ff;--mat-sys-scrim: #000000;--mat-sys-secondary: #565e71;--mat-sys-secondary-container: #dae2f9;--mat-sys-secondary-fixed: #dae2f9;--mat-sys-secondary-fixed-dim: #bec6dc;--mat-sys-shadow: #000000;--mat-sys-surface: #faf9fd;--mat-sys-surface-bright: #faf9fd;--mat-sys-surface-container: #efedf0;--mat-sys-surface-container-high: #e9e7eb;--mat-sys-surface-container-highest: #e3e2e6;--mat-sys-surface-container-low: #f4f3f6;--mat-sys-surface-container-lowest: #ffffff;--mat-sys-surface-dim: #dbd9dd;--mat-sys-surface-tint: #005cbb;--mat-sys-surface-variant: #e0e2ec;--mat-sys-tertiary: #343dff;--mat-sys-tertiary-container: #e0e0ff;--mat-sys-tertiary-fixed: #e0e0ff;--mat-sys-tertiary-fixed-dim: #bec2ff;--mat-sys-neutral-variant20: #2d3038;--mat-sys-neutral10: #1a1b1f;--mat-sys-level0: 0px 0px 0px 0px rgba(0, 0, 0, .2), 0px 0px 0px 0px rgba(0, 0, 0, .14), 0px 0px 0px 0px rgba(0, 0, 0, .12);--mat-sys-level1: 0px 2px 1px -1px rgba(0, 0, 0, .2), 0px 1px 1px 0px rgba(0, 0, 0, .14), 0px 1px 3px 0px rgba(0, 0, 0, .12);--mat-sys-level2: 0px 3px 3px -2px rgba(0, 0, 0, .2), 0px 3px 4px 0px rgba(0, 0, 0, .14), 0px 1px 8px 0px rgba(0, 0, 0, .12);--mat-sys-level3: 0px 3px 5px -1px rgba(0, 0, 0, .2), 0px 6px 10px 0px rgba(0, 0, 0, .14), 0px 1px 18px 0px rgba(0, 0, 0, .12);--mat-sys-level4: 0px 5px 5px -3px rgba(0, 0, 0, .2), 0px 8px 10px 1px rgba(0, 0, 0, .14), 0px 3px 14px 2px rgba(0, 0, 0, .12);--mat-sys-level5: 0px 7px 8px -4px rgba(0, 0, 0, .2), 0px 12px 17px 2px rgba(0, 0, 0, .14), 0px 5px 22px 4px rgba(0, 0, 0, .12);--mat-sys-body-large: 400 1rem / 1.5rem Roboto;--mat-sys-body-large-font: Roboto;--mat-sys-body-large-line-height: 1.5rem;--mat-sys-body-large-size: 1rem;--mat-sys-body-large-tracking: .031rem;--mat-sys-body-large-weight: 400;--mat-sys-body-medium: 400 .875rem / 1.25rem Roboto;--mat-sys-body-medium-font: Roboto;--mat-sys-body-medium-line-height: 1.25rem;--mat-sys-body-medium-size: .875rem;--mat-sys-body-medium-tracking: .016rem;--mat-sys-body-medium-weight: 400;--mat-sys-body-small: 400 .75rem / 1rem Roboto;--mat-sys-body-small-font: Roboto;--mat-sys-body-small-line-height: 1rem;--mat-sys-body-small-size: .75rem;--mat-sys-body-small-tracking: .025rem;--mat-sys-body-small-weight: 400;--mat-sys-display-large: 400 3.562rem / 4rem Roboto;--mat-sys-display-large-font: Roboto;--mat-sys-display-large-line-height: 4rem;--mat-sys-display-large-size: 3.562rem;--mat-sys-display-large-tracking: -.016rem;--mat-sys-display-large-weight: 400;--mat-sys-display-medium: 400 2.812rem / 3.25rem Roboto;--mat-sys-display-medium-font: Roboto;--mat-sys-display-medium-line-height: 3.25rem;--mat-sys-display-medium-size: 2.812rem;--mat-sys-display-medium-tracking: 0;--mat-sys-display-medium-weight: 400;--mat-sys-display-small: 400 2.25rem / 2.75rem Roboto;--mat-sys-display-small-font: Roboto;--mat-sys-display-small-line-height: 2.75rem;--mat-sys-display-small-size: 2.25rem;--mat-sys-display-small-tracking: 0;--mat-sys-display-small-weight: 400;--mat-sys-headline-large: 400 2rem / 2.5rem Roboto;--mat-sys-headline-large-font: Roboto;--mat-sys-headline-large-line-height: 2.5rem;--mat-sys-headline-large-size: 2rem;--mat-sys-headline-large-tracking: 0;--mat-sys-headline-large-weight: 400;--mat-sys-headline-medium: 400 1.75rem / 2.25rem Roboto;--mat-sys-headline-medium-font: Roboto;--mat-sys-headline-medium-line-height: 2.25rem;--mat-sys-headline-medium-size: 1.75rem;--mat-sys-headline-medium-tracking: 0;--mat-sys-headline-medium-weight: 400;--mat-sys-headline-small: 400 1.5rem / 2rem Roboto;--mat-sys-headline-small-font: Roboto;--mat-sys-headline-small-line-height: 2rem;--mat-sys-headline-small-size: 1.5rem;--mat-sys-headline-small-tracking: 0;--mat-sys-headline-small-weight: 400;--mat-sys-label-large: 500 .875rem / 1.25rem Roboto;--mat-sys-label-large-font: Roboto;--mat-sys-label-large-line-height: 1.25rem;--mat-sys-label-large-size: .875rem;--mat-sys-label-large-tracking: .006rem;--mat-sys-label-large-weight: 500;--mat-sys-label-large-weight-prominent: 700;--mat-sys-label-medium: 500 .75rem / 1rem Roboto;--mat-sys-label-medium-font: Roboto;--mat-sys-label-medium-line-height: 1rem;--mat-sys-label-medium-size: .75rem;--mat-sys-label-medium-tracking: .031rem;--mat-sys-label-medium-weight: 500;--mat-sys-label-medium-weight-prominent: 700;--mat-sys-label-small: 500 .688rem / 1rem Roboto;--mat-sys-label-small-font: Roboto;--mat-sys-label-small-line-height: 1rem;--mat-sys-label-small-size: .688rem;--mat-sys-label-small-tracking: .031rem;--mat-sys-label-small-weight: 500;--mat-sys-title-large: 400 1.375rem / 1.75rem Roboto;--mat-sys-title-large-font: Roboto;--mat-sys-title-large-line-height: 1.75rem;--mat-sys-title-large-size: 1.375rem;--mat-sys-title-large-tracking: 0;--mat-sys-title-large-weight: 400;--mat-sys-title-medium: 500 1rem / 1.5rem Roboto;--mat-sys-title-medium-font: Roboto;--mat-sys-title-medium-line-height: 1.5rem;--mat-sys-title-medium-size: 1rem;--mat-sys-title-medium-tracking: .009rem;--mat-sys-title-medium-weight: 500;--mat-sys-title-small: 500 .875rem / 1.25rem Roboto;--mat-sys-title-small-font: Roboto;--mat-sys-title-small-line-height: 1.25rem;--mat-sys-title-small-size: .875rem;--mat-sys-title-small-tracking: .006rem;--mat-sys-title-small-weight: 500;--mat-sys-corner-extra-large: 28px;--mat-sys-corner-extra-large-top: 28px 28px 0 0;--mat-sys-corner-extra-small: 4px;--mat-sys-corner-extra-small-top: 4px 4px 0 0;--mat-sys-corner-full: 9999px;--mat-sys-corner-large: 16px;--mat-sys-corner-large-end: 0 16px 16px 0;--mat-sys-corner-large-start: 16px 0 0 16px;--mat-sys-corner-large-top: 16px 16px 0 0;--mat-sys-corner-medium: 12px;--mat-sys-corner-none: 0;--mat-sys-corner-small: 8px;--mat-sys-dragged-state-layer-opacity: .16;--mat-sys-focus-state-layer-opacity: .12;--mat-sys-hover-state-layer-opacity: .08;--mat-sys-pressed-state-layer-opacity: .12}:root{--color-primary: #3A3A3A;--color-secondary: #69bc90;--color-accent: #212121;--color-success: #69bc90;--color-warning: #f9be8f;--color-error: #ed8086;--color-info: #2196F3;--bg-primary: #eae6da;--bg-secondary: #f5f2e9;--bg-surface: rgba(255, 255, 255, .75);--bg-card: rgba(255, 255, 255, .9);--font-family-primary: Quicksand, sans-serif;--font-family-secondary: -apple-system, BlinkMacSystemFont, Segoe UI, Roboto, sans-serif;--space-1: .25rem;--space-2: .5rem;--space-3: .75rem;--space-4: 1rem;--space-5: 1.25rem;--space-6: 1.5rem;--space-8: 2rem;--space-12: 3rem;--space-16: 4rem;--radius-sm: .25rem;--radius-base: .5rem;--radius-md: .75rem;--radius-lg: 1rem;--radius-xl: 1.25rem;--shadow-sm: 0 1px 2px 0 rgba(0, 0, 0, .05);--shadow-base: 0 1px 3px 0 rgba(0, 0, 0, .1), 0 1px 2px 0 rgba(0, 0, 0, .06);--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .1), 0 2px 4px -1px rgba(0, 0, 0, .06);--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .1), 0 4px 6px -2px rgba(0, 0, 0, .05);--transition-fast: .15s ease;--transition-base: .2s ease;--transition-slow: .3s ease}[data-theme=dark]{--color-primary: #f5f5f5;--bg-primary: #212121;--bg-secondary: #424242;--bg-surface: rgba(97, 97, 97, .8);--bg-card: rgba(66, 66, 66, .9)}[data-theme=light]{--color-primary: #3A3A3A;--bg-primary: #eae6da;--bg-secondary: #f5f2e9;--bg-surface: rgba(255, 255, 255, .75);--bg-card: rgba(255, 255, 255, .9)}*,*:before,*:after{box-sizing:border-box}*{margin:0}body{line-height:1.5;-webkit-font-smoothing:antialiased}img,picture,video,canvas,svg{display:block;max-width:100%}input,button,textarea,select{font:inherit}p,h1,h2,h3,h4,h5,h6{overflow-wrap:break-word}#root,#__next{isolation:isolate}button{background:none;border:none;padding:0;cursor:pointer}ul,ol{list-style:none;padding:0;margin:0}a{color:inherit;text-decoration:none}*:focus-visible{outline:2px solid var(--color-secondary);outline-offset:2px}body{font-family:Quicksand,sans-serif;font-size:1rem;font-weight:400;line-height:1.6;color:#3a3a3a}h1,h2,h3,h4,h5,h6{font-family:Quicksand,sans-serif;font-weight:600;line-height:1.25;color:#3a3a3a;margin:0}h1{font-size:2.25rem;margin-bottom:1.5rem}@media (min-width: 768px){h1{font-size:3rem}}h2{font-size:1.875rem;margin-bottom:1.25rem}h3{font-size:1.5rem;margin-bottom:1rem}h4{font-size:1.25rem;margin-bottom:.75rem}h5{font-size:1.125rem;margin-bottom:.75rem}h6{font-size:1rem;margin-bottom:.5rem}p{margin-bottom:1rem}p:last-child{margin-bottom:0}.text-sm{font-size:.875rem}.text-lg{font-size:1.125rem}.text-xl{font-size:1.25rem}.font-light{font-weight:300}.font-normal{font-weight:400}.font-medium{font-weight:500}.font-semibold{font-weight:600}.font-bold{font-weight:700}.text-primary{color:#3a3a3a}.text-secondary,.text-success{color:#69bc90}.text-warning{color:#f9be8f}.text-error{color:#ed8086}.text-gray-500{color:#9e9e9e}.text-gray-600{color:#757575}.text-left{text-align:left}.text-right{text-align:right}.container{max-width:1200px;margin:0 auto;padding:0 1rem;width:100%}@media (min-width: 768px){.container{padding:0 1.5rem}}.page-container{min-height:100vh;position:relative;background:#eae6da;display:flex;flex-direction:column}.page-container:before{content:"";position:absolute;inset:0;background-image:url("data:image/svg+xml,%3Csvg width='60' height='60' viewBox='0 0 60 60' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='none' fill-rule='evenodd'%3E%3Cg fill='%23000000' fill-opacity='0.05'%3E%3Cpath d='M30 30c0-11.046-8.954-20-20-20s-20 8.954-20 20 8.954 20 20 20 20-8.954 20-20zm0 0c0-11.046 8.954-20 20-20s20 8.954 20 20-8.954 20-20 20-20-8.954-20-20z'/%3E%3C/g%3E%3C/g%3E%3C/svg%3E");opacity:.1;pointer-events:none}.page-header{background:#fff;color:#3a3a3a;padding:60px 1.25rem 1.25rem;box-shadow:0 1px 2px #0000000d;position:relative;z-index:1}@media (min-width: 768px){.page-header{padding:80px 1.5rem 1.5rem}}.page-header h1{margin-bottom:0}.page-content{flex:1;padding:1.5rem 1.25rem;margin-bottom:80px}@media (min-width: 768px){.page-content{padding:2rem 1.5rem}}.card-container{display:grid;gap:1.5rem}@media (min-width: 768px){.card-container{grid-template-columns:repeat(auto-fit,minmax(300px,1fr))}}.section{margin-bottom:3rem}.section:last-child{margin-bottom:0}.section-header{margin-bottom:1.5rem}.section-header h2{margin-bottom:.5rem}.section-header p{color:#757575;margin-bottom:0}.wrapper{max-width:800px;margin:0 auto;padding:0 1rem}@media (min-width: 768px){.wrapper{padding:0 1.5rem}}.full-width{width:100%}.max-w-sm{max-width:384px}.max-w-md{max-width:448px}.max-w-lg{max-width:512px}.max-w-xl{max-width:576px}.max-w-2xl{max-width:672px}.max-w-4xl{max-width:896px}.flex{display:flex}.inline-flex{display:inline-flex}.flex-col{flex-direction:column}.flex-row{flex-direction:row}.flex-wrap{flex-wrap:wrap}.flex-nowrap{flex-wrap:nowrap}.items-start{align-items:flex-start}.items-center{align-items:center}.items-end{align-items:flex-end}.items-stretch{align-items:stretch}.justify-start{justify-content:flex-start}.justify-center{justify-content:center}.justify-end{justify-content:flex-end}.justify-between{justify-content:space-between}.justify-around{justify-content:space-around}.justify-evenly{justify-content:space-evenly}.flex-1{flex:1 1 0%}.flex-auto{flex:1 1 auto}.flex-initial{flex:0 1 auto}.flex-none{flex:none}.grid{display:grid}.grid-cols-1{grid-template-columns:repeat(1,minmax(0,1fr))}.grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}.grid-cols-4{grid-template-columns:repeat(4,minmax(0,1fr))}.grid-cols-6{grid-template-columns:repeat(6,minmax(0,1fr))}.grid-cols-12{grid-template-columns:repeat(12,minmax(0,1fr))}@media (min-width: 640px){.sm\:grid-cols-1{grid-template-columns:repeat(1,minmax(0,1fr))}.sm\:grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.sm\:grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}}@media (min-width: 768px){.md\:grid-cols-1{grid-template-columns:repeat(1,minmax(0,1fr))}.md\:grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.md\:grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}.md\:grid-cols-4{grid-template-columns:repeat(4,minmax(0,1fr))}}@media (min-width: 1024px){.lg\:grid-cols-1{grid-template-columns:repeat(1,minmax(0,1fr))}.lg\:grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.lg\:grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}.lg\:grid-cols-4{grid-template-columns:repeat(4,minmax(0,1fr))}.lg\:grid-cols-6{grid-template-columns:repeat(6,minmax(0,1fr))}}.gap-1{gap:.25rem}.gap-2{gap:.5rem}.gap-3{gap:.75rem}.gap-4{gap:1rem}.gap-5{gap:1.25rem}.gap-6{gap:1.5rem}.gap-8{gap:2rem}.gap-10{gap:2.5rem}.gap-12{gap:3rem}.btn{display:inline-flex;align-items:center;justify-content:center;padding:.75rem 1.5rem;border:none;border-radius:.75rem;font-family:Quicksand,sans-serif;font-weight:500;font-size:1rem;line-height:1.5;text-decoration:none;cursor:pointer;transition:all .2s ease}.btn:disabled{opacity:.6;cursor:not-allowed}.btn--primary{background:#69bc90;color:#fff}.btn--primary:hover:not(:disabled){background:#5fa982;transform:translateY(-1px)}.btn--primary:active{transform:translateY(0)}.btn--secondary{background:#3a3a3a;color:#fff}.btn--secondary:hover:not(:disabled){background:#343434;transform:translateY(-1px)}.btn--outline{background:transparent;border:1px solid #3A3A3A;color:#3a3a3a}.btn--outline:hover:not(:disabled){background:#3a3a3a;color:#fff}.btn--ghost{background:transparent;color:#3a3a3a}.btn--ghost:hover:not(:disabled){background:#3a3a3a1a}.btn--warning{background:#f9be8f;color:#3a3a3a}.btn--warning:hover:not(:disabled){background:#e0ab81}.btn--error{background:#ed8086;color:#fff}.btn--error:hover:not(:disabled){background:#d57379}.btn--sm{padding:.5rem 1rem;font-size:.875rem}.btn--lg{padding:1rem 2rem;font-size:1.125rem}.btn--xl{padding:1.25rem 2.5rem;font-size:1.25rem}.btn--full{width:100%}.btn--icon{padding:.75rem;border-radius:50%}.btn--icon.btn--sm{padding:.5rem}.btn--icon.btn--lg{padding:1rem}.btn--loading{position:relative;color:transparent}.btn--loading:after{content:"";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:16px;height:16px;border:2px solid currentColor;border-radius:50%;border-top-color:transparent;animation:spin 1s linear infinite}.btn-group{display:inline-flex}.btn-group .btn{border-radius:0}.btn-group .btn:first-child{border-top-left-radius:.75rem;border-bottom-left-radius:.75rem}.btn-group .btn:last-child{border-top-right-radius:.75rem;border-bottom-right-radius:.75rem}.btn-group .btn:not(:last-child){border-right:1px solid rgba(255,255,255,.2)}@keyframes spin{to{transform:translate(-50%,-50%) rotate(360deg)}}.card{background:#ffffffe6;border-radius:1rem;box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;padding:1.5rem;transition:transform .2s ease}.card:hover{transform:translateY(-2px);box-shadow:0 10px 15px -3px #0000001a,0 4px 6px -2px #0000000d}.card--elevated{box-shadow:0 10px 15px -3px #0000001a,0 4px 6px -2px #0000000d}.card--flat{box-shadow:none;border:1px solid #eeeeee}.card--interactive{cursor:pointer}.card--interactive:hover{transform:translateY(-4px);box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a}.card--sm{padding:1rem}.card--lg{padding:2rem}.card__image{margin:-1.5rem -1.5rem 1rem;border-radius:1rem 1rem 0 0;overflow:hidden}.card__image img{width:100%;height:auto;display:block}.card__header{margin-bottom:1rem}.card__header h3{margin-bottom:.25rem}.card__header p{color:#757575;font-size:.875rem;margin:0}.card__content{margin-bottom:1rem}.card__content:last-child{margin-bottom:0}.card__footer{margin-top:1rem;padding-top:1rem;border-top:1px solid #eeeeee;display:flex;align-items:center;justify-content:space-between}.card__actions{display:flex;gap:.5rem;margin-top:1rem}.card__actions--center{justify-content:center}.card__actions--end{justify-content:flex-end}.plant-card{background:#ffffffe6;border-radius:1rem;box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;padding:1.5rem;transition:transform .2s ease;position:relative;overflow:hidden}.plant-card:hover{transform:translateY(-2px);box-shadow:0 10px 15px -3px #0000001a,0 4px 6px -2px #0000000d}.plant-card__status{position:absolute;top:1rem;right:1rem;width:12px;height:12px;border-radius:50%}.plant-card__status--healthy{background:#69bc90}.plant-card__status--warning{background:#f9be8f}.plant-card__status--critical{background:#ed8086}.plant-card__status--offline{background:#bdbdbd}.plant-card__name{font-size:1.125rem;font-weight:600;margin-bottom:.5rem}.plant-card__species{color:#757575;font-size:.875rem;margin-bottom:1rem}.plant-card__metrics{display:grid;grid-template-columns:repeat(3,1fr);gap:.75rem;margin-bottom:1rem}.plant-card__metric{text-align:center}.plant-card__metric-label{font-size:.75rem;color:#9e9e9e;margin-bottom:.25rem;text-transform:uppercase;letter-spacing:.05em}.plant-card__metric-value{font-size:1.125rem;font-weight:600;color:#3a3a3a}.stat-card{background:#ffffffe6;border-radius:1rem;box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;padding:1.5rem;transition:transform .2s ease;text-align:center}.stat-card:hover{transform:translateY(-2px);box-shadow:0 10px 15px -3px #0000001a,0 4px 6px -2px #0000000d}.stat-card__icon{width:48px;height:48px;margin:0 auto 1rem;background:#69bc901a;border-radius:50%;display:flex;align-items:center;justify-content:center;color:#69bc90;font-size:1.25rem}.stat-card__value{font-size:1.875rem;font-weight:700;color:#3a3a3a;margin-bottom:.5rem}.stat-card__label{color:#757575;font-size:.875rem}.stat-card__change{font-size:.875rem;margin-top:.5rem}.stat-card__change--positive{color:#69bc90}.stat-card__change--negative{color:#ed8086}.form{display:flex;flex-direction:column;gap:1.25rem}.form--inline{flex-direction:row;align-items:flex-end}.form-group{display:flex;flex-direction:column;gap:.5rem}.form-group--inline{flex-direction:row;align-items:center;gap:1rem}.form-label{font-weight:500;color:#3a3a3a;font-size:.875rem}.form-label--required:after{content:" *";color:#ed8086}.form-input{width:100%;padding:.75rem 1rem;border:1px solid #e0e0e0;border-radius:.75rem;font-family:Quicksand,sans-serif;font-size:1rem;background:#fff;transition:border-color .2s ease,box-shadow .2s ease}.form-input:focus{outline:none;border-color:#69bc90;box-shadow:0 0 0 3px #69bc901a}.form-input::placeholder{color:#9e9e9e}.form-input--error{border-color:#ed8086}.form-input--error:focus{border-color:#ed8086;box-shadow:0 0 0 3px #ed80861a}.form-input--success{border-color:#69bc90}.form-input--success:focus{border-color:#69bc90;box-shadow:0 0 0 3px #69bc901a}.form-input--sm{padding:.5rem .75rem;font-size:.875rem}.form-input--lg{padding:1rem 1.25rem;font-size:1.125rem}.form-textarea{width:100%;padding:.75rem 1rem;border:1px solid #e0e0e0;border-radius:.75rem;font-family:Quicksand,sans-serif;font-size:1rem;background:#fff;transition:border-color .2s ease,box-shadow .2s ease;min-height:100px;resize:vertical}.form-textarea:focus{outline:none;border-color:#69bc90;box-shadow:0 0 0 3px #69bc901a}.form-textarea::placeholder{color:#9e9e9e}.form-select{width:100%;padding:.75rem 2.5rem .75rem 1rem;border:1px solid #e0e0e0;border-radius:.75rem;font-family:Quicksand,sans-serif;font-size:1rem;background:#fff;transition:border-color .2s ease,box-shadow .2s ease;background-image:url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 20 20'%3e%3cpath stroke='%236b7280' stroke-linecap='round' stroke-linejoin='round' stroke-width='1.5' d='m6 8 4 4 4-4'/%3e%3c/svg%3e");background-position:right .75rem center;background-repeat:no-repeat;background-size:16px 12px;appearance:none}.form-select:focus{outline:none;border-color:#69bc90;box-shadow:0 0 0 3px #69bc901a}.form-select::placeholder{color:#9e9e9e}.form-checkbox,.form-radio{appearance:none;width:20px;height:20px;border:2px solid #e0e0e0;background:#fff;cursor:pointer;position:relative}.form-checkbox:checked,.form-radio:checked{background:#69bc90;border-color:#69bc90}.form-checkbox:checked:after,.form-radio:checked:after{content:"";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.form-checkbox:focus,.form-radio:focus{outline:2px solid #69bc90;outline-offset:2px}.form-checkbox{border-radius:.25rem}.form-checkbox:checked:after{width:6px;height:10px;border:2px solid white;border-top:0;border-left:0;transform:translate(-50%,-60%) rotate(45deg)}.form-radio{border-radius:50%}.form-radio:checked:after{width:8px;height:8px;background:#fff;border-radius:50%}.form-help{font-size:.875rem;color:#757575;margin-top:.25rem}.form-error{font-size:.875rem;color:#ed8086;margin-top:.25rem;display:flex;align-items:center;gap:.25rem}.form-success{font-size:.875rem;color:#69bc90;margin-top:.25rem;display:flex;align-items:center;gap:.25rem}.input-group{position:relative;display:flex}.input-group__icon{position:absolute;top:50%;transform:translateY(-50%);color:#9e9e9e;pointer-events:none}.input-group__icon--left{left:.75rem}.input-group__icon--right{right:.75rem}.input-group .form-input--icon-left{padding-left:2.5rem}.input-group .form-input--icon-right{padding-right:2.5rem}.form-switch{position:relative;display:inline-block;width:44px;height:24px}.form-switch input{opacity:0;width:0;height:0}.form-switch input:checked+.switch-slider{background:#69bc90}.form-switch input:checked+.switch-slider:before{transform:translate(20px)}.form-switch input:focus+.switch-slider{outline:2px solid #69bc90;outline-offset:2px}.form-switch .switch-slider{position:absolute;cursor:pointer;inset:0;background:#e0e0e0;transition:.2s ease;border-radius:50%}.form-switch .switch-slider:before{position:absolute;content:"";height:18px;width:18px;left:3px;bottom:3px;background:#fff;transition:.2s ease;border-radius:50%}*{font-family:Quicksand,sans-serif}.settings-subpage-container{min-height:100vh;background:#eae6da;display:flex;flex-direction:column;position:relative}.settings-subpage-container:before{content:"";position:absolute;inset:0;background-image:url("data:image/svg+xml,%3Csvg width='60' height='60' viewBox='0 0 60 60' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='none' fill-rule='evenodd'%3E%3Cg fill='%23000000' fill-opacity='0.05'%3E%3Cpath d='M30 30c0-11.046-8.954-20-20-20s-20 8.954-20 20 8.954 20 20 20 20-8.954 20-20zm0 0c0-11.046 8.954-20 20-20s20 8.954 20 20-8.954 20-20 20-20-8.954-20-20z'/%3E%3C/g%3E%3C/g%3E%3C/svg%3E");opacity:.1;pointer-events:none}.settings-subpage-container:before{content:"";position:absolute;inset:0;background-image:url('data:image/svg+xml,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 100 100" fill="none"><path d="M20 30 Q30 20 40 30 L60 50 Q70 60 80 50 L90 60" stroke="%23C8C4BA" stroke-width="0.5" fill="none" opacity="0.3"/><path d="M10 70 Q20 60 30 70 L50 90 Q60 100 70 90 L80 100" stroke="%23C8C4BA" stroke-width="0.5" fill="none" opacity="0.3"/></svg>');background-size:12.5rem 12.5rem;background-repeat:repeat;opacity:.1;pointer-events:none;z-index:0}.settings-header{background:#fff;color:#3a3a3a;padding:3.75rem 1.25rem 1.25rem;display:flex;justify-content:space-between;align-items:center;position:relative;z-index:1;box-shadow:0 1px 2px #0000000d}.header-content{width:100%;display:flex;align-items:center;justify-content:space-between}.back-btn{background:none;border:none;border-radius:50%;width:2.75rem;height:2.75rem;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:background-color .2s ease}.back-btn:hover{background:#f5f5f5}.header-title{margin:0;font-size:1.25rem;font-weight:600;text-align:center;flex-grow:1}.header-spacer{width:2.75rem}.settings-content{padding:1.25rem;display:flex;flex-direction:column;gap:1.25rem;position:relative;z-index:1;max-width:50rem;margin:0 auto;width:100%;box-sizing:border-box;margin-bottom:5rem}.success-message{background-color:#3a3a3a;color:#fff;padding:.75rem 1rem;border-radius:.75rem;margin-bottom:1rem;text-align:center;animation:fadeIn .3s ease-out}@keyframes fadeIn{0%{opacity:0;transform:translateY(-.625rem)}to{opacity:1;transform:translateY(0)}}.form-card{background:#ffffffe6;border-radius:1rem;box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;padding:1.5rem;transition:transform .2s ease;background:#ffffffbf;margin-bottom:1rem}.form-card:hover{transform:translateY(-2px);box-shadow:0 10px 15px -3px #0000001a,0 4px 6px -2px #0000000d}.form-header{margin-bottom:1rem}.form-header h3{font-size:1.125rem;font-weight:600;margin:0 0 .5rem;color:#3a3a3a}.form-description{font-size:.875rem;color:#757575;margin:0}.form-group{margin-bottom:1rem}.form-group label{display:block;font-size:.875rem;font-weight:500;color:#3a3a3a;margin-bottom:.5rem}.form-input{width:100%;padding:.75rem 1rem;font-size:1rem;border:1px solid #e0e0e0;border-radius:.75rem;background:#fafafa;box-sizing:border-box;transition:border .2s ease,box-shadow .2s ease}.form-input:focus{outline:none;border-color:#3a3a3a;box-shadow:0 0 0 2px #3a3a3a1a;background:#fff}.input-with-counter{position:relative;width:100%}.input-with-counter .form-input{padding-right:3.75rem}.input-with-counter .char-count{position:absolute;right:.75rem;top:50%;transform:translateY(-50%);font-size:.75rem;color:#9e9e9e;pointer-events:none;font-weight:500}.plant-image-container{position:relative;width:9.375rem;height:9.375rem;margin:0 auto 2rem;display:flex;align-items:center;justify-content:center}.plant-image{width:9.375rem;height:9.375rem;border-radius:50%;overflow:hidden;display:flex;align-items:center;justify-content:center;background-color:#f5f5f5;box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f}.plant-image img{width:100%;height:100%;object-fit:cover}.edit-image-btn{position:absolute;bottom:0;right:0;width:2.25rem;height:2.25rem;background:#3a3a3a;border:none;border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;z-index:2;transition:.2s ease}.edit-image-btn app-icon{color:#fff}.edit-image-btn.changed{background:#757575;animation:pulse-green 1.5s infinite ease-in-out}.edit-image-btn:hover{background:#2d2d2d}@keyframes pulse-green{0%,to{background-color:#3a3a3a}50%{background-color:#757575}}.button-container{display:flex;justify-content:flex-end;margin-top:1.25rem;padding:0 .5rem}.primary-button{background:#3a3a3a;color:#fff;border:none;border-radius:.75rem;padding:.75rem 1.25rem;font-size:1rem;font-weight:500;cursor:pointer;transition:background .2s ease}.primary-button:hover{background:#4c4c4c}.primary-button:active{background:#303030}.text-center{text-align:center}@media (max-width: 768px){.settings-header{padding:3.4375rem 1rem 1rem}.header-title{font-size:1.125rem}.settings-content{padding:1rem;gap:1rem;margin-bottom:3.75rem}.form-card{padding:1rem;margin-bottom:.75rem}.form-header h3{font-size:1rem;margin-bottom:.25rem}.form-description{font-size:.75rem}.primary-button{padding:.5rem 1rem;font-size:.9375rem}}@media (max-width: 640px){.settings-header{padding:3.125rem .875rem .875rem}.header-title{font-size:1.125rem}.back-btn{width:2.5rem;height:2.5rem}.settings-content{padding:.875rem;gap:.875rem;margin-bottom:3.125rem}.form-card{padding:.875rem;border-radius:.875rem;margin-bottom:.5rem}.form-header{margin-bottom:.75rem}.form-input{padding:.5rem .875rem;font-size:.9375rem}.primary-button{padding:.5rem .875rem;font-size:.875rem}}@media (max-width: 22.5rem){.settings-header{padding:2.8125rem .75rem .75rem}.header-title{font-size:1.0625rem}.back-btn{width:2.375rem;height:2.375rem}.settings-content{padding:.75rem;margin-bottom:2.5rem}.form-card{padding:.75rem;border-radius:.75rem}.form-input{padding:.5rem .75rem;font-size:.875rem}}.m-0{margin:0}.m-1{margin:.25rem}.m-2{margin:.5rem}.m-3{margin:.75rem}.m-4{margin:1rem}.m-5{margin:1.25rem}.m-6{margin:1.5rem}.m-8{margin:2rem}.m-10{margin:2.5rem}.m-12{margin:3rem}.m-16{margin:4rem}.mt-0{margin-top:0}.mt-1{margin-top:.25rem}.mt-2{margin-top:.5rem}.mt-3{margin-top:.75rem}.mt-4{margin-top:1rem}.mt-5{margin-top:1.25rem}.mt-6{margin-top:1.5rem}.mt-8{margin-top:2rem}.mt-12{margin-top:3rem}.mb-0{margin-bottom:0}.mb-1{margin-bottom:.25rem}.mb-2{margin-bottom:.5rem}.mb-3{margin-bottom:.75rem}.mb-4{margin-bottom:1rem}.mb-5{margin-bottom:1.25rem}.mb-6{margin-bottom:1.5rem}.mb-8{margin-bottom:2rem}.mb-12{margin-bottom:3rem}.ml-0{margin-left:0}.ml-1{margin-left:.25rem}.ml-2{margin-left:.5rem}.ml-3{margin-left:.75rem}.ml-4{margin-left:1rem}.ml-auto{margin-left:auto}.mr-0{margin-right:0}.mr-1{margin-right:.25rem}.mr-2{margin-right:.5rem}.mr-3{margin-right:.75rem}.mr-4{margin-right:1rem}.mr-auto{margin-right:auto}.mx-auto{margin-left:auto;margin-right:auto}.my-auto{margin-top:auto;margin-bottom:auto}.p-0{padding:0}.p-1{padding:.25rem}.p-2{padding:.5rem}.p-3{padding:.75rem}.p-4{padding:1rem}.p-5{padding:1.25rem}.p-6{padding:1.5rem}.p-8{padding:2rem}.p-10{padding:2.5rem}.p-12{padding:3rem}.pt-0{padding-top:0}.pt-1{padding-top:.25rem}.pt-2{padding-top:.5rem}.pt-3{padding-top:.75rem}.pt-4{padding-top:1rem}.pt-5{padding-top:1.25rem}.pt-6{padding-top:1.5rem}.pt-8{padding-top:2rem}.pb-0{padding-bottom:0}.pb-1{padding-bottom:.25rem}.pb-2{padding-bottom:.5rem}.pb-3{padding-bottom:.75rem}.pb-4{padding-bottom:1rem}.pb-5{padding-bottom:1.25rem}.pb-6{padding-bottom:1.5rem}.pb-8{padding-bottom:2rem}.pl-0{padding-left:0}.pl-1{padding-left:.25rem}.pl-2{padding-left:.5rem}.pl-3{padding-left:.75rem}.pl-4{padding-left:1rem}.pl-5{padding-left:1.25rem}.pl-6{padding-left:1.5rem}.pr-0{padding-right:0}.pr-1{padding-right:.25rem}.pr-2{padding-right:.5rem}.pr-3{padding-right:.75rem}.pr-4{padding-right:1rem}.pr-5{padding-right:1.25rem}.pr-6{padding-right:1.5rem}.block{display:block}.inline-block{display:inline-block}.inline{display:inline}.hidden{display:none}.relative{position:relative}.absolute{position:absolute}.fixed{position:fixed}.sticky{position:sticky}.w-full{width:100%}.w-auto{width:auto}.w-fit{width:fit-content}.h-full{height:100%}.h-screen{height:100vh}.h-auto{height:auto}.rounded-none{border-radius:0}.rounded-sm{border-radius:.25rem}.rounded{border-radius:.5rem}.rounded-md{border-radius:.75rem}.rounded-lg{border-radius:1rem}.rounded-xl{border-radius:1.25rem}.rounded-full{border-radius:50%}.shadow-none{box-shadow:none}.shadow-sm{box-shadow:0 1px 2px #0000000d}.shadow{box-shadow:0 1px 3px #0000001a,0 1px 2px #0000000f}.shadow-md{box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f}.shadow-lg{box-shadow:0 10px 15px -3px #0000001a,0 4px 6px -2px #0000000d}.shadow-xl{box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a}.bg-transparent{background:transparent}.bg-white{background:#fff}.bg-primary{background:#eae6da}.bg-secondary{background:#f5f2e9}.bg-surface{background:#ffffffbf}.bg-card{background:#ffffffe6}.opacity-0{opacity:0}.opacity-25{opacity:.25}.opacity-50{opacity:.5}.opacity-75{opacity:.75}.opacity-100{opacity:1}.overflow-hidden{overflow:hidden}.overflow-auto{overflow:auto}.overflow-scroll{overflow:scroll}.overflow-visible{overflow:visible}.cursor-pointer{cursor:pointer}.cursor-not-allowed{cursor:not-allowed}.cursor-default{cursor:default}.select-none{-webkit-user-select:none;user-select:none}.select-text{-webkit-user-select:text;user-select:text}.select-all{-webkit-user-select:all;user-select:all}.transition{transition:all .2s ease}.transition-colors{transition:color .2s ease,background-color .2s ease,border-color .2s ease}.transition-transform{transition:transform .2s ease}.transition-opacity{transition:opacity .2s ease}.transform{transform:translateZ(0)}.translate-y-1{transform:translateY(-.25rem)}.translate-y-2{transform:translateY(-.5rem)}.hover\:translate-y-1:hover{transform:translateY(-.25rem)}.hover\:translate-y-2:hover{transform:translateY(-.5rem)}.z-0{z-index:0}.z-10{z-index:10}.z-20{z-index:20}.z-30{z-index:30}.z-40{z-index:40}.z-50{z-index:50}@media (min-width: 640px){.sm\:block{display:block}.sm\:hidden{display:none}.sm\:flex{display:flex}}@media (min-width: 768px){.md\:block{display:block}.md\:hidden{display:none}.md\:flex{display:flex}.md\:grid{display:grid}}@media (min-width: 1024px){.lg\:block{display:block}.lg\:hidden{display:none}.lg\:flex{display:flex}}html,body{height:100%}body{margin:0;font-family:Quicksand,sans-serif;background:#eae6da;color:#3a3a3a}
