:root{--bg: #F7F3ED;--surface: #FFF;--surface2: #EDE8DF;--border: #D5CDBE;--text: #2C2416;--text-secondary: #5C5345;--muted: #9B917F;--green: #4A7C59;--green-light: #D4E8D0;--green-dark: #2D5A3A;--brown: #8B6E4E;--accent: #C17531;--accent-light: #F5E6D4;--danger: #C25550;--danger-light: #F5D5D3;--serif: "DM Serif Display", serif;--sans: "DM Sans", sans-serif;--shadow-sm: 0 1px 3px rgba(44,36,22,.06);--shadow-md: 0 4px 16px rgba(44,36,22,.08);--shadow-lg: 0 12px 40px rgba(44,36,22,.12);--radius: 16px}*{margin:0;padding:0;box-sizing:border-box}.app-shell{font-family:var(--sans);background:var(--bg);min-height:100vh;color:var(--text);padding-bottom:60px}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:24px;background:linear-gradient(135deg,#ede8df,#d4e8d0 50%,#e8d8c4)}.login-card{background:var(--surface);border-radius:24px;padding:40px 36px;max-width:420px;width:100%;box-shadow:var(--shadow-lg)}.login-error{background:var(--danger-light);color:var(--danger);padding:10px 14px;border-radius:10px;font-size:13px;font-weight:500;margin-bottom:14px;text-align:center}.app-header{background:var(--surface);border-bottom:1px solid var(--border);padding:14px 24px;display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:10px;position:sticky;top:0;z-index:50}.app-logo{display:flex;align-items:center;gap:12px;cursor:pointer}.app-logo h1{font-family:var(--serif);font-size:26px;font-weight:400;letter-spacing:-.3px}.logo-icon{width:36px;height:36px;background:var(--green);border-radius:10px;display:flex;align-items:center;justify-content:center}.header-actions{display:flex;gap:8px;align-items:center;flex-wrap:wrap}.user-pill{display:flex;align-items:center;gap:8px;background:var(--surface2);border-radius:20px;padding:5px 14px 5px 5px}.user-pill-avatar{width:28px;height:28px;border-radius:50%;background:var(--green);color:#fff;display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:700}.user-pill-name{font-size:13px;font-weight:600}.user-pill-role{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;padding:2px 7px;border-radius:6px}.role-admin{background:var(--accent-light);color:var(--accent)}.role-user{background:var(--green-light);color:var(--green-dark)}.btn-logout{border:none;background:none;cursor:pointer;color:var(--muted);padding:6px;border-radius:8px;display:flex;align-items:center}.btn-logout:hover{color:var(--danger);background:var(--danger-light)}.stats-bar{display:flex;gap:24px;padding:14px 28px;background:var(--surface);border-bottom:1px solid var(--border);flex-wrap:wrap}.stat-item{display:flex;align-items:center;gap:8px;font-size:13px;color:var(--text-secondary);font-weight:500}.stat-num{font-family:var(--serif);font-size:22px;color:var(--text);line-height:1}.content{max-width:1100px;margin:0 auto;padding:24px 20px}.page-title{font-family:var(--serif);font-size:28px;font-weight:400;margin-bottom:4px}.page-subtitle{color:var(--muted);font-size:14px;margin-bottom:20px}.search-bar{display:flex;align-items:center;gap:10px;background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:10px 16px;margin-bottom:12px}.search-input{flex:1;border:none;outline:none;font-size:14px;font-family:var(--sans);color:var(--text);background:transparent}.search-input::placeholder{color:var(--muted)}.search-clear{border:none;background:var(--surface2);width:22px;height:22px;border-radius:50%;cursor:pointer;font-size:14px;color:var(--muted);display:flex;align-items:center;justify-content:center}.filter-bar{display:flex;gap:6px;margin-bottom:20px;flex-wrap:wrap}.filter-chip{border:1px solid var(--border);background:var(--surface);border-radius:20px;padding:5px 14px;font-size:12px;font-weight:600;cursor:pointer;color:var(--muted);font-family:var(--sans);display:inline-flex;align-items:center;gap:4px;transition:all .2s}.filter-chip:hover{border-color:var(--green);color:var(--green)}.filter-active{background:var(--green-light);color:var(--green-dark);border-color:var(--green)}.filter-fav.filter-active{background:var(--accent-light);color:var(--accent);border-color:var(--accent)}.plant-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:18px}.variety-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:16px}.plant-card{background:var(--surface);border-radius:var(--radius);overflow:hidden;cursor:pointer;transition:transform .2s,box-shadow .2s;box-shadow:var(--shadow-sm);animation:cardIn .4s ease both}.plant-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-md)}.card-img{width:100%;height:180px;background-size:cover;background-position:center;background-color:var(--surface2)}.card-img-placeholder{display:flex;align-items:center;justify-content:center}.card-body{padding:14px 16px 16px}.card-title{font-family:var(--serif);font-size:18px;font-weight:400;margin-bottom:2px}.card-subtitle{font-size:12px;color:var(--muted);font-weight:500}.variety-card{background:var(--surface);border-radius:var(--radius);overflow:hidden;transition:transform .2s,box-shadow .2s;box-shadow:var(--shadow-sm);display:flex;align-items:stretch;animation:cardIn .4s ease both}.variety-card:hover{transform:translateY(-3px);box-shadow:var(--shadow-md)}.vcard-img{width:110px;min-height:110px;background-size:cover;background-position:center;background-color:var(--surface2);flex-shrink:0}.variety-title{font-family:var(--serif);font-size:16px;font-weight:400}.badge-seed{display:inline-flex;align-items:center;gap:4px;background:var(--surface2);border-radius:20px;padding:3px 10px;font-size:12px;font-weight:600}.badge-growing{display:inline-flex;align-items:center;gap:4px;background:var(--green-light);border-radius:20px;padding:3px 10px;font-size:11px;font-weight:700;color:var(--green-dark);text-transform:uppercase}.badge-growing-dot{width:6px;height:6px;border-radius:50%;background:var(--green);display:inline-block;animation:pulse 2s ease infinite}.habit-badge{display:inline-block;font-size:10px;font-weight:700;letter-spacing:.6px;text-transform:uppercase;background:var(--accent-light);color:var(--accent);padding:2px 8px;border-radius:6px;margin-top:4px}.habit-badge-lg{font-size:11px;font-weight:700;text-transform:uppercase;background:var(--accent);color:#fff;padding:5px 12px;border-radius:8px}.grow-guide,.companion-section{background:var(--bg);border:1px solid var(--border);border-radius:14px;padding:18px;margin-top:14px}.grow-guide-title{font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.8px;color:var(--accent);margin-bottom:14px;padding-bottom:10px;border-bottom:1px solid var(--border)}.grow-guide-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:10px}.grow-guide-item{background:var(--surface);border-radius:10px;padding:10px 12px;box-shadow:var(--shadow-sm)}.grow-guide-value{font-size:13px;font-weight:600;line-height:1.3}.grow-guide-label{font-size:11px;color:var(--muted);margin-top:2px}.companion-tags{display:flex;flex-wrap:wrap;gap:6px}.companion-good{background:var(--green-light);color:var(--green-dark);padding:4px 10px;border-radius:8px;font-size:12px;font-weight:600}.companion-bad{background:var(--danger-light);color:var(--danger);padding:4px 10px;border-radius:8px;font-size:12px;font-weight:600}.autofill-row{display:flex;align-items:center;gap:10px;margin-bottom:14px;flex-wrap:wrap}.autofill-url-wrap{display:flex;align-items:center;gap:8px;flex:1;min-width:200px;background:var(--bg);border:1px solid var(--border);border-radius:10px;padding:8px 12px}.autofill-url-wrap:focus-within{border-color:var(--accent)}.autofill-url-input{flex:1;border:none;outline:none;font-size:13px;font-family:var(--sans);color:var(--text);background:transparent;min-width:0}.btn-autofill{display:inline-flex;align-items:center;gap:8px;background:linear-gradient(135deg,var(--accent),#D4863C);color:#fff;border:none;border-radius:10px;padding:9px 18px;font-family:var(--sans);font-size:13px;font-weight:600;cursor:pointer;white-space:nowrap}.btn-autofill:disabled{opacity:.75;cursor:wait}.cal-row{display:flex;align-items:center;gap:16px;background:var(--surface);border-radius:14px;padding:14px 18px;box-shadow:var(--shadow-sm);border-left:4px solid var(--border)}.cal-soon{border-left-color:var(--accent)}.cal-past{border-left-color:var(--muted);opacity:.7}.cal-plant-info{display:flex;align-items:center;gap:10px;min-width:160px}.cal-dates{display:flex;gap:16px;flex:1;flex-wrap:wrap}.cal-date-label{font-size:10px;font-weight:700;text-transform:uppercase;color:var(--muted)}.cal-date-val{font-size:14px;font-weight:600}.cal-countdown{font-size:12px;font-weight:700;padding:4px 10px;border-radius:8px;white-space:nowrap}.cal-countdown-upcoming{background:var(--green-light);color:var(--green-dark)}.cal-countdown-soon{background:var(--accent-light);color:var(--accent)}.cal-countdown-past{background:var(--surface2);color:var(--muted)}.cal-mini{display:flex;gap:12px;flex-wrap:wrap;margin-bottom:14px;padding:12px;background:var(--bg);border-radius:10px;border:1px solid var(--border)}.cal-mini-label{font-size:10px;font-weight:700;text-transform:uppercase;color:var(--muted)}.cal-mini-val{font-size:14px;font-weight:600;color:var(--green-dark)}.cart-btn{position:relative;border:none;background:var(--surface2);width:40px;height:40px;border-radius:12px;cursor:pointer;display:flex;align-items:center;justify-content:center;color:var(--text)}.cart-btn:hover{background:var(--border)}.cart-badge{position:absolute;top:-4px;right:-4px;background:var(--accent);color:#fff;font-size:10px;font-weight:700;width:20px;height:20px;border-radius:50%;display:flex;align-items:center;justify-content:center;border:2px solid var(--surface)}.cart-add-btn{border:none;background:var(--green-light);width:44px;display:flex;align-items:center;justify-content:center;cursor:pointer;color:var(--green-dark);flex-shrink:0;border-left:1px solid var(--border);font-weight:700;font-size:18px}.cart-add-btn:hover,.cart-add-btn.in-cart{background:var(--green);color:#fff}.cart-row{display:flex;align-items:center;gap:14px;background:var(--surface);border-radius:14px;padding:14px 18px;box-shadow:var(--shadow-sm)}.cart-remove{border:none;background:none;cursor:pointer;color:var(--muted);font-size:18px;padding:4px 8px;border-radius:8px}.cart-remove:hover{color:var(--danger);background:var(--danger-light)}.qty-control{display:flex;align-items:center;background:var(--surface2);border-radius:10px;overflow:hidden}.qty-btn{border:none;background:transparent;width:32px;height:32px;cursor:pointer;font-size:16px;font-weight:700}.qty-btn:hover{background:var(--border)}.qty-value{width:32px;text-align:center;font-size:14px;font-weight:700}.cart-footer{margin-top:24px;padding:20px 24px;background:var(--surface);border-radius:16px;display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:16px;box-shadow:var(--shadow-sm)}.request-card{background:var(--surface);border-radius:16px;padding:20px;box-shadow:var(--shadow-sm)}.request-header{display:flex;align-items:center;gap:12px;margin-bottom:14px;padding-bottom:14px;border-bottom:1px solid var(--surface2)}.status-select{padding:6px 12px;border:2px solid;border-radius:8px;font-size:12px;font-family:var(--sans);font-weight:700;background:var(--bg);cursor:pointer;text-transform:uppercase}.request-items{display:flex;flex-wrap:wrap;gap:8px}.request-item{display:flex;align-items:center;gap:6px;background:var(--bg);border-radius:10px;padding:8px 14px}.request-item-var{font-size:13px;font-weight:600}.request-item-qty{font-size:12px;font-weight:700;color:var(--accent);background:var(--accent-light);padding:2px 8px;border-radius:6px}.notif-dot{position:absolute;top:-2px;right:-2px;background:var(--danger);color:#fff;font-size:9px;font-weight:700;width:18px;height:18px;border-radius:50%;display:flex;align-items:center;justify-content:center;border:2px solid var(--surface)}.user-row{display:flex;align-items:center;gap:14px;background:var(--surface);border-radius:14px;padding:14px 18px;box-shadow:var(--shadow-sm)}.user-avatar{width:40px;height:40px;border-radius:50%;background:var(--green);color:#fff;display:flex;align-items:center;justify-content:center;font-size:17px;font-weight:700;flex-shrink:0}.role-select{padding:6px 10px;border:1px solid var(--border);border-radius:8px;font-size:12px;font-family:var(--sans);font-weight:600;background:var(--bg);cursor:pointer}.role-select:disabled{opacity:.5}.toast{position:fixed;bottom:24px;left:50%;transform:translate(-50%);background:var(--text);color:#fff;padding:12px 24px;border-radius:12px;font-size:14px;font-weight:600;z-index:200;box-shadow:var(--shadow-lg)}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#2c241673;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);z-index:100;display:flex;align-items:center;justify-content:center;padding:24px;animation:fadeIn .2s ease}.modal-content{background:var(--surface);border-radius:20px;max-width:520px;width:100%;max-height:85vh;overflow-y:auto;box-shadow:var(--shadow-lg);position:relative;animation:modalIn .3s ease}.modal-close{position:absolute;top:14px;right:14px;width:34px;height:34px;border-radius:50%;border:none;background:#ffffffd9;cursor:pointer;font-size:18px;color:var(--text);z-index:2;display:flex;align-items:center;justify-content:center}.modal-img{width:100%;height:240px;background-size:cover;background-position:center;background-color:var(--surface2);border-radius:20px 20px 0 0}.modal-img-placeholder{display:flex;align-items:center;justify-content:center}.modal-body{padding:24px}.modal-title{font-family:var(--serif);font-size:24px;font-weight:400;margin-bottom:10px}.modal-section{margin-bottom:14px}.modal-label{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.8px;color:var(--muted);margin-bottom:4px}.modal-text{font-size:14px;line-height:1.6;color:var(--text-secondary)}.confirm-dialog{background:var(--surface);border-radius:16px;padding:28px;max-width:380px;width:100%;box-shadow:var(--shadow-lg);animation:modalIn .3s ease}.confirm-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#2c24168c;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);z-index:200;display:flex;align-items:center;justify-content:center;padding:24px;animation:fadeIn .2s ease}.btn{font-family:var(--sans);font-size:13px;font-weight:600;padding:9px 20px;border-radius:10px;border:none;cursor:pointer;transition:all .2s;display:inline-flex;align-items:center;gap:6px}.btn-lg{padding:12px 28px;font-size:14px;border-radius:12px}.btn-primary{background:var(--green);color:#fff}.btn-primary:hover{background:var(--green-dark)}.btn-secondary{background:var(--surface2);color:var(--text);position:relative}.btn-secondary:hover{background:var(--border)}.btn-danger{background:var(--danger-light);color:var(--danger)}.btn-danger:hover{background:var(--danger);color:#fff}.btn-back{border:none;background:none;font-family:var(--sans);font-size:14px;font-weight:600;color:var(--green);cursor:pointer;padding:4px 0}.form-page{animation:fadeIn .3s ease}.form-header{display:flex;align-items:center;gap:16px;margin-bottom:24px}.form-grid{display:flex;flex-direction:column;gap:20px}.form-card{background:var(--surface);border-radius:var(--radius);padding:24px;box-shadow:var(--shadow-sm)}.form-card-title{font-family:var(--serif);font-size:20px;font-weight:400;margin-bottom:16px;padding-bottom:12px;border-bottom:1px solid var(--surface2)}.form-fields{display:flex;flex-direction:column;gap:14px}.form-label{font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:var(--text-secondary);display:block;margin-bottom:4px}.form-input{width:100%;padding:10px 14px;border:1px solid var(--border);border-radius:10px;font-size:14px;font-family:var(--sans);color:var(--text);background:var(--bg);outline:none}.form-input:focus{border-color:var(--green)}.form-input-sm{padding:7px 10px;font-size:13px}.form-toggle-group{display:flex;margin-bottom:16px;background:var(--surface2);border-radius:10px;overflow:hidden}.form-toggle{flex:1;padding:10px;border:none;background:transparent;font-family:var(--sans);font-size:13px;font-weight:600;cursor:pointer;color:var(--muted)}.form-toggle:disabled{opacity:.4}.form-toggle.active{background:var(--surface);color:var(--green);box-shadow:var(--shadow-sm);border-radius:8px;margin:3px}.grow-form-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:12px}.grow-form-item{background:var(--bg);border-radius:12px;padding:10px 12px}.zone-btn{display:flex;flex-direction:column;align-items:center;gap:2px;padding:8px 14px;border:2px solid var(--border);border-radius:12px;background:var(--surface);cursor:pointer;transition:all .2s;font-family:var(--sans);min-width:64px}.zone-btn:hover,.zone-active{border-color:var(--green);background:var(--green-light)}.zone-btn-num{font-size:18px;font-weight:700;color:var(--text);line-height:1}.zone-btn-desc{font-size:9px;font-weight:600;color:var(--muted);text-transform:uppercase;letter-spacing:.3px}.zone-active .zone-btn-num,.zone-active .zone-btn-desc{color:var(--green-dark)}.timeline-chart{background:var(--bg);border:1px solid var(--border);border-radius:14px;padding:18px;margin-bottom:14px;overflow:hidden}.tl-key{display:flex;flex-wrap:wrap;gap:10px 14px;margin:-2px 0 10px;padding-left:90px}.tl-key-item{display:inline-flex;align-items:center;gap:6px;font-size:10px;font-weight:700;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.3px}.tl-key-swatch{width:10px;height:10px;border-radius:3px;display:inline-block}.tl-months{display:flex;position:relative;height:22px;margin-bottom:4px}.tl-months-track{position:relative;width:calc(100% - 90px);margin-left:90px;height:100%}.tl-month-label{position:absolute;text-align:center;font-size:10px;font-weight:600;color:var(--muted);text-transform:uppercase;letter-spacing:.3px}.tl-body{position:relative}.tl-track-overlay{position:absolute;top:0;bottom:0;left:90px;right:0;pointer-events:none}.tl-grid{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none}.tl-gridline{position:absolute;top:0;bottom:0;width:1px;background:var(--border);opacity:.5}.tl-now{position:absolute;top:-6px;bottom:0;width:2px;background:var(--accent);opacity:.8;z-index:2;border-radius:1px}.tl-now:after{content:"";position:absolute;top:0;left:-4px;width:10px;height:10px;background:var(--accent);border-radius:50%}.tl-row{display:flex;align-items:center;gap:0;margin-bottom:4px;height:32px}.tl-row-label{width:90px;font-size:11px;font-weight:600;color:var(--text-secondary);flex-shrink:0;padding-right:8px;text-align:right}.tl-row-track{flex:1;position:relative;height:26px;background:var(--surface);border-radius:6px;overflow:hidden}.tl-bar{position:absolute;top:3px;bottom:3px;border-radius:5px;opacity:.9;transition:opacity .2s;min-width:8px;display:flex;align-items:center;justify-content:center;overflow:hidden}.tl-bar:hover{opacity:1}.tl-footer{font-size:11px;color:var(--muted);margin-top:10px;text-align:center}.dropzone{border:2px dashed var(--border);border-radius:14px;cursor:pointer;transition:all .2s;overflow:hidden;background:var(--bg);min-height:120px}.dropzone:hover{border-color:var(--green);background:var(--green-light)}.dropzone-active{border-color:var(--green);background:var(--green-light);border-style:solid;transform:scale(1.01)}.dropzone-has-image{border:none;min-height:auto}.dropzone-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;padding:28px 16px;text-align:center}.dropzone-label{font-size:13px;color:var(--muted);font-weight:500}.dropzone-drop-text{font-size:15px;font-weight:700;color:var(--green-dark)}.dropzone-preview{position:relative;width:100%;max-height:220px;overflow:hidden;border-radius:12px}.dropzone-img{width:100%;height:auto;max-height:220px;object-fit:cover;display:block;border-radius:12px}.dropzone-overlay{position:absolute;top:0;right:0;bottom:0;left:0;background:#00000059;display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .2s;border-radius:12px}.dropzone-preview:hover .dropzone-overlay{opacity:1}.dropzone-overlay span{color:#fff;font-size:13px;font-weight:600}.dropzone-clear{position:absolute;top:8px;right:8px;width:26px;height:26px;border-radius:50%;border:none;background:#00000080;color:#fff;font-size:14px;cursor:pointer;display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .2s;z-index:2}.dropzone-preview:hover .dropzone-clear{opacity:1}.dropzone-clear:hover{background:var(--danger)}.empty-state{text-align:center;padding:60px 20px}.detail-header{display:flex;align-items:center;gap:16px;margin:12px 0 8px;flex-wrap:wrap}.loader{width:36px;height:36px;border:3px solid var(--surface2);border-top-color:var(--green);border-radius:50%;animation:spin .8s linear infinite}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes cardIn{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}@keyframes modalIn{0%{opacity:0;transform:scale(.95) translateY(10px)}to{opacity:1;transform:scale(1) translateY(0)}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.4}}@keyframes spin{to{transform:rotate(360deg)}}.fade-in{animation:fadeIn .3s ease}@media (max-width: 600px){.app-header{padding:14px 12px}.app-logo h1{font-size:20px}.content{padding:16px 12px}.plant-grid{grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:12px}.card-img{height:140px}.stats-bar{padding:10px 16px;gap:16px}.form-card{padding:16px}.modal-content{border-radius:16px}.modal-img{height:180px}.grow-form-grid{grid-template-columns:1fr}.grow-guide-grid{grid-template-columns:1fr 1fr}.detail-header{flex-direction:column;align-items:flex-start}.header-actions{gap:6px}.user-pill-name{display:none}.login-card{padding:28px 24px}.cart-row,.cal-row{flex-wrap:wrap}.autofill-row{flex-direction:column}.autofill-url-wrap{min-width:100%}.tl-key{padding-left:70px}.tl-row-label{width:70px;font-size:10px}.tl-month-label{font-size:8px}.zone-btn{min-width:54px;padding:6px 10px}.zone-btn-num{font-size:15px}}
