*{box-sizing:border-box}*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--green-dark:#2d5a1b;--green-mid:#4a7c2e;--green-light:#6aaa3e;--green-pale:#e8f5e2;--brown:#8b5e3c;--text:#1a2e10;--text-soft:#4a5c3a;--border:#c5deb0;--white:#fff;--radius:12px;--shadow:0 2px 12px #00000014;--shadow-lg:0 8px 32px #0000001f}body{background:var(--green-pale);color:var(--text);min-height:100vh;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;line-height:1.6}.app{flex-direction:column;min-height:100vh;display:flex}.app-header{background:var(--green-dark);color:var(--white);z-index:100;justify-content:space-between;align-items:center;padding:.875rem 1.5rem;display:flex;position:sticky;top:0;box-shadow:0 2px 8px #0003}.logo{align-items:center;gap:.5rem;font-size:1.3rem;display:flex}.logo-icon{font-size:1.5rem}.logo-text strong{font-weight:700}.app-main{flex:1;width:100%;max-width:960px;margin:0 auto;padding:2rem 1rem}.hero{text-align:center;margin-bottom:2.5rem}.hero h1{color:var(--green-dark);font-size:clamp(2rem,5vw,3.2rem);font-weight:800;line-height:1.15}.hero h1 span{color:var(--green-light)}.hero p{color:var(--text-soft);margin-top:1rem;max-width:520px;margin-inline:auto;font-size:1.1rem}.loading-screen{text-align:center;padding:5rem 1rem}.loading-animation{justify-content:center;gap:.75rem;margin-bottom:1.5rem;font-size:2.5rem;display:flex}.loading-animation span{animation:1.2s infinite bounce}.loading-animation span:nth-child(2){animation-delay:.2s}.loading-animation span:nth-child(3){animation-delay:.4s}@keyframes bounce{0%,to{transform:translateY(0)}50%{transform:translateY(-12px)}}.loading-screen h2{color:var(--green-dark);font-size:1.5rem}.loading-screen p{color:var(--text-soft);margin-top:.5rem}.form-container{max-width:600px;margin:0 auto}.step-indicator{justify-content:center;gap:0;margin-bottom:2rem;display:flex;position:relative}.step-indicator:before{content:"";background:var(--border);z-index:0;height:2px;position:absolute;top:18px;left:15%;right:15%}.step-dot{z-index:1;flex-direction:column;flex:1;align-items:center;gap:6px;display:flex;position:relative}.step-dot span{background:var(--white);border:2px solid var(--border);width:36px;height:36px;color:var(--text-soft);border-radius:50%;justify-content:center;align-items:center;font-size:.85rem;font-weight:700;transition:all .2s;display:flex}.step-dot label{color:var(--text-soft);white-space:nowrap;font-size:.72rem}.step-dot.active span{background:var(--green-mid);border-color:var(--green-mid);color:#fff}.step-dot.done span{background:var(--green-light);border-color:var(--green-light);color:#fff}.step-dot.active label{color:var(--green-dark);font-weight:600}.form-card{background:var(--white);border-radius:var(--radius);box-shadow:var(--shadow-lg);padding:2rem}.form-step h2{color:var(--green-dark);margin-bottom:.4rem;font-size:1.4rem}.form-step p{color:var(--text-soft);margin-bottom:1.5rem}.field{margin-bottom:1.2rem}.field-hint{color:var(--text-soft);margin-top:.5rem;font-size:.82rem;line-height:1.5}.field-hint a{color:var(--green-dark);font-weight:600;text-decoration:underline}.field label{color:var(--text-soft);text-transform:uppercase;letter-spacing:.04em;margin-bottom:.4rem;font-size:.85rem;font-weight:600;display:block}.field label a{color:var(--green-mid);text-transform:none;font-weight:400}input[type=text],input[type=number],select{border:1.5px solid var(--border);width:100%;color:var(--text);background:var(--white);border-radius:8px;padding:.7rem 1rem;font-size:1rem;transition:border-color .15s}input:focus,select:focus{border-color:var(--green-mid);outline:none;box-shadow:0 0 0 3px #4a7c2e1a}.field-row{grid-template-columns:1fr 1fr;gap:1rem;display:grid}.garden-preview{background:var(--green-pale);border-radius:8px;justify-content:center;align-items:center;min-height:120px;margin-top:1rem;padding:1.5rem;display:flex}.garden-rect{border:2px solid var(--green-mid);background:#c8e6b8;border-radius:4px;flex-direction:column;justify-content:center;align-items:center;min-width:60px;min-height:40px;transition:all .2s;display:flex}.garden-rect span{color:var(--green-dark);font-size:1rem;font-weight:700}.garden-rect small{color:var(--text-soft);font-size:.75rem}.option-grid{grid-template-columns:1fr 1fr;gap:.5rem;display:grid}.option-btn{border:1.5px solid var(--border);background:var(--white);cursor:pointer;text-align:left;color:var(--text);border-radius:8px;padding:.6rem .75rem;font-size:.9rem;transition:all .15s}.option-btn:hover{border-color:var(--green-mid);background:var(--green-pale)}.option-btn.selected{border-color:var(--green-mid);background:var(--green-pale);color:var(--green-dark);font-weight:600}.goal-grid{grid-template-columns:1fr 1fr;gap:.6rem;display:grid}.goal-btn{border:1.5px solid var(--border);background:var(--white);cursor:pointer;color:var(--text);text-align:left;border-radius:8px;padding:.75rem 1rem;font-size:.95rem;transition:all .15s}.goal-btn:hover{border-color:var(--green-mid);background:var(--green-pale)}.goal-btn.selected{border-color:var(--green-mid);background:var(--green-mid);color:#fff;font-weight:600}.form-nav{border-top:1px solid var(--border);justify-content:flex-end;gap:.75rem;margin-top:2rem;padding-top:1.5rem;display:flex}.btn-primary{background:var(--green-mid);color:#fff;cursor:pointer;border:none;border-radius:8px;align-items:center;gap:.5rem;padding:.75rem 1.75rem;font-size:1rem;font-weight:600;transition:background .15s,transform .1s;display:flex}.btn-primary:hover{background:var(--green-dark)}.btn-primary:active{transform:scale(.98)}.btn-primary:disabled{cursor:not-allowed;background:#aac89a}.btn-generate{padding:.85rem 2rem;font-size:1.05rem}.btn-secondary{color:var(--green-mid);border:1.5px solid var(--green-mid);cursor:pointer;background:0 0;border-radius:8px;padding:.65rem 1.25rem;font-size:.95rem;font-weight:600;transition:all .15s}.btn-secondary:hover{background:var(--green-pale)}.btn-text{color:#fffc;cursor:pointer;background:0 0;border:none;border-radius:6px;padding:.4rem .75rem;font-size:.95rem;transition:background .15s}.btn-text:hover{color:#fff;background:#ffffff1a}.spinner{border:2px solid #fff6;border-top-color:#fff;border-radius:50%;width:16px;height:16px;animation:.6s linear infinite spin;display:inline-block}@keyframes spin{to{transform:rotate(360deg)}}.error-banner{color:#991b1b;text-align:center;background:#fee2e2;border:1px solid #fca5a5;border-radius:8px;margin-top:1rem;padding:.875rem 1rem}.plan-container{width:100%}.plan-header{flex-wrap:wrap;justify-content:space-between;align-items:flex-start;gap:1rem;margin-bottom:1.25rem;display:flex}.plan-header h1{color:var(--green-dark);font-size:1.8rem}.plan-subtitle{color:var(--text-soft);margin-top:.2rem;font-size:.95rem}.plan-summary{background:var(--white);border-left:4px solid var(--green-light);border-radius:0 var(--radius) var(--radius) 0;color:var(--text-soft);box-shadow:var(--shadow);margin-bottom:1.5rem;padding:1rem 1.25rem;font-size:1rem}.tab-bar{border-bottom:2px solid var(--border);-webkit-overflow-scrolling:touch;scrollbar-width:none;gap:.25rem;margin-bottom:1.5rem;display:flex;overflow-x:auto}.tab-bar button{color:var(--text-soft);cursor:pointer;white-space:nowrap;background:0 0;border:none;border-bottom:2px solid #0000;margin-bottom:-2px;padding:.65rem 1.1rem;font-size:.9rem;font-weight:600;transition:all .15s}.tab-bar button:hover{color:var(--green-mid)}.tab-bar button.active{color:var(--green-dark);border-bottom-color:var(--green-mid)}.tab-bar::-webkit-scrollbar{display:none}.tab-bar-wrap{position:relative}.tab-bar-wrap:after{content:"";background:linear-gradient(to right, transparent, var(--bg));pointer-events:none;width:32px;position:absolute;top:0;bottom:2px;right:0}.plant-grid{grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:1rem;display:grid}.zone-section{margin-bottom:2rem}.zone-section h3{color:var(--green-dark);margin-bottom:.25rem;font-size:1.1rem}.zone-desc{color:var(--text-soft);margin-bottom:.875rem;font-size:.85rem}.plant-card{background:var(--white);border-radius:var(--radius);box-shadow:var(--shadow);cursor:pointer;border:2px solid #0000;transition:transform .15s,box-shadow .15s;overflow:hidden}.plant-card:hover{box-shadow:var(--shadow-lg);transform:translateY(-2px)}.plant-card.selected{border-color:var(--green-mid)}.plant-photo{width:100%;height:140px;position:relative;overflow:hidden}.plant-photo img{object-fit:cover;object-position:center;filter:brightness(1.02)saturate(1.08);width:100%;height:100%;transition:filter .2s}.plant-card:hover .plant-photo img{filter:brightness(1.05)saturate(1.12)}.photo-placeholder{justify-content:center;align-items:center;width:100%;height:100%;display:flex}.plant-initial{opacity:.6;font-size:3rem;font-weight:800}.plant-photo:after{content:"";pointer-events:none;background:radial-gradient(#0000 55%,#0000002e 100%);position:absolute;inset:0}.photo-attribution{color:#ffffffe6;white-space:nowrap;text-overflow:ellipsis;background:linear-gradient(#0000,#0000008c);padding:.5rem .4rem .25rem;font-size:.65rem;text-decoration:none;transition:background .15s;display:block;position:absolute;bottom:0;left:0;right:0;overflow:hidden}.photo-attribution:hover{color:#fff;background:linear-gradient(#0000,#000000bf)}.unsplash-credit{color:var(--text-soft);font-size:.78rem;text-decoration:none}.unsplash-credit:hover{color:var(--green-mid);text-decoration:underline}.plant-badge{color:#fff;border-radius:99px;padding:2px 8px;font-size:.75rem;font-weight:700;position:absolute;top:8px;right:8px}.plant-info{padding:.875rem 1rem}.plant-info h3{color:var(--green-dark);margin-bottom:2px;font-size:1rem}.plant-info em{color:var(--text-soft);font-size:.78rem}.plant-meta{color:var(--text-soft);flex-wrap:wrap;gap:.75rem;margin:.5rem 0;font-size:.8rem;display:flex}.why-chosen{color:var(--text-soft);font-size:.85rem;line-height:1.5}.plant-details{border-top:1px solid var(--border);margin-top:1rem;padding-top:1rem}.detail-section{margin-bottom:.75rem}.detail-section strong{text-transform:uppercase;letter-spacing:.05em;color:var(--text-soft);margin-bottom:2px;font-size:.78rem;display:block}.detail-section p{color:var(--text);font-size:.88rem}.visual-desc{background:#f0fdf4;border-radius:8px;padding:.6rem .75rem}.visual-desc strong{color:var(--green-mid)!important}.visual-desc p{font-style:italic}.where-to-buy{background:#fefce8;border-radius:8px;padding:.6rem .75rem}.where-to-buy strong{color:#854d0e!important}.where-local{color:var(--text-soft);margin-bottom:.4rem;font-size:.83rem}.where-local a{color:var(--green-mid);margin-left:.3rem;font-weight:600;text-decoration:none}.where-local a:hover{text-decoration:underline}.where-online{color:var(--text-soft);flex-direction:column;gap:.3rem;font-size:.83rem;display:flex}.where-online span{font-weight:600}.online-nurseries{flex-wrap:wrap;gap:.3rem;margin-top:.2rem;display:flex}.nursery-tag{color:#854d0e;background:#fff;border:1px solid #fde047;border-radius:6px;padding:.2rem .5rem;font-size:.75rem;font-weight:600;text-decoration:none;transition:background .1s}.nursery-tag:hover{background:#fef9c3}.btn-unlock-premium{border-color:var(--green-light)!important;background:#f0fdf4!important}.btn-swap{border:1.5px dashed var(--border);width:100%;color:var(--text-soft);cursor:pointer;background:0 0;border-radius:8px;margin-top:.75rem;padding:.5rem;font-size:.85rem;transition:all .15s}.btn-swap:hover{border-color:var(--green-mid);color:var(--green-mid)}.canvas-container{background:var(--white);border-radius:var(--radius);box-shadow:var(--shadow);margin-bottom:1.5rem;padding:1.5rem}.canvas-header{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:.75rem;margin-bottom:.25rem;display:flex}.canvas-header h3{color:var(--green-dark);font-size:1.1rem}.canvas-hint{color:var(--text-soft);margin-bottom:1rem;font-size:.82rem}.view-toggle{background:var(--green-pale);border-radius:8px;gap:.25rem;padding:3px;display:flex}.view-toggle button{cursor:pointer;color:var(--text-soft);background:0 0;border:none;border-radius:6px;padding:.35rem .875rem;font-size:.85rem;font-weight:600;transition:all .15s}.view-toggle button.active{background:var(--white);color:var(--green-dark);box-shadow:0 1px 4px #0000001a}.svg-wrapper{border-radius:8px;overflow:hidden}.canvas-legend{border-top:1px solid var(--border);flex-wrap:wrap;gap:.5rem;margin-top:1rem;padding-top:1rem;display:flex}.legend-item{cursor:pointer;color:var(--text-soft);border-radius:6px;align-items:center;gap:.4rem;padding:.25rem .5rem;font-size:.82rem;transition:background .1s;display:flex}.legend-item:hover{background:var(--green-pale)}.legend-item.selected{background:var(--green-pale);color:var(--green-dark);font-weight:600}.legend-dot{cursor:pointer;border:2px solid #fff9;border-radius:50%;flex-shrink:0;width:24px;height:24px;box-shadow:0 1px 3px #0003}.legend-swatch-wrap{flex-shrink:0;align-items:center;display:flex;position:relative}.legend-photo{object-fit:cover;cursor:pointer;filter:brightness(1.05)saturate(1.1);border:2px solid #ffffffb3;border-radius:50%;width:28px;height:28px;box-shadow:0 1px 3px #0003}.legend-color-input{opacity:0;cursor:pointer;border:none;width:100%;height:100%;padding:0;position:absolute;top:0;left:0}.selected-plant-detail{max-width:360px;margin-top:1rem}.timeline-tab{grid-template-columns:1fr 1fr;gap:1rem;display:grid}.season-card{background:var(--white);border-radius:var(--radius);box-shadow:var(--shadow);padding:1.25rem}.season-header{align-items:center;gap:.5rem;margin-bottom:.75rem;display:flex}.season-icon{font-size:1.4rem}.season-header h3{color:var(--green-dark);font-size:1rem;font-weight:700}.season-card p{color:var(--text-soft);font-size:.9rem;line-height:1.6}.tips-list{flex-direction:column;gap:.875rem;list-style:none;display:flex}.tip-item{background:var(--white);border-radius:var(--radius);box-shadow:var(--shadow);align-items:flex-start;gap:1rem;padding:1rem 1.25rem;display:flex}.tip-number{background:var(--green-light);color:#fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:28px;height:28px;font-size:.85rem;font-weight:800;display:flex}.tip-item p{color:var(--text-soft);font-size:.95rem;line-height:1.6}.layout-desc{background:var(--white);border-radius:var(--radius);box-shadow:var(--shadow);margin-top:1.25rem;padding:1.25rem}.layout-desc h3{color:var(--green-dark);margin-bottom:.5rem;font-size:1rem}.layout-desc p{color:var(--text-soft);font-size:.9rem;line-height:1.6}.header-right{align-items:center;gap:.75rem;display:flex}.tier-badge{color:#fff;background:#ffffff26;border-radius:99px;padding:.3rem .75rem;font-size:.8rem;font-weight:700}.free-tier-banner{border-radius:var(--radius);color:#713f12;background:#fefce8;border:1px solid #fde047;flex-wrap:wrap;justify-content:space-between;align-items:center;gap:1rem;margin-bottom:1.25rem;padding:.875rem 1.25rem;font-size:.9rem;display:flex}.banner-actions{flex-wrap:wrap;gap:.5rem;display:flex}.btn-banner-unlock{color:#fff;cursor:pointer;white-space:nowrap;background:#ca8a04;border:none;border-radius:8px;padding:.5rem 1.1rem;font-size:.875rem;font-weight:700;transition:background .15s}.btn-banner-unlock:hover{background:#a16207}.btn-banner-premium{background:var(--green-mid);color:#fff;cursor:pointer;white-space:nowrap;border:none;border-radius:8px;padding:.5rem 1.1rem;font-size:.875rem;font-weight:700;transition:background .15s}.btn-banner-premium:hover{background:var(--green-dark)}.tab-locked{opacity:.6}.tab-lock-icon{font-size:.75rem}.blurred-content{filter:blur(4px);-webkit-user-select:none;user-select:none;pointer-events:none}.free-hint{color:var(--text-soft);margin-top:.5rem;font-size:.78rem;font-style:italic}.paywall-overlay{justify-content:center;padding:1rem 0 2rem;display:flex}.paywall-card{background:var(--white);box-shadow:var(--shadow-lg);text-align:center;border:1px solid var(--border);border-radius:16px;width:100%;max-width:720px;padding:2.5rem 2rem}.paywall-lock{margin-bottom:.75rem;font-size:2.5rem}.paywall-card h2{color:var(--green-dark);margin-bottom:.5rem;font-size:1.4rem}.paywall-card>p{color:var(--text-soft);margin-bottom:1.25rem}.paywall-features{text-align:left;background:var(--green-pale);color:var(--text);border-radius:10px;flex-direction:column;flex:1;gap:.45rem;margin-bottom:1.25rem;padding:.9rem 1.1rem;font-size:.85rem;list-style:none;display:flex}.paywall-tiers{grid-template-columns:1fr 28px 1fr;align-items:stretch;gap:.75rem;margin-bottom:1rem;display:grid}.paywall-tier{background:var(--green-pale);text-align:left;border-radius:12px;flex-direction:column;gap:.75rem;padding:1.25rem 1rem;display:flex}.paywall-tier-premium{border:2px solid var(--green-light);background:#f0fdf4;position:relative}.paywall-divider{color:var(--text-soft);justify-content:center;align-items:center;font-size:.78rem;font-weight:700;display:flex}.tier-label{text-transform:uppercase;letter-spacing:.07em;color:var(--text-soft);text-align:center;font-size:.72rem;font-weight:800}.tier-label-premium{color:var(--green-mid)}.paywall-actions{flex-direction:column;gap:.75rem;margin-bottom:1rem;display:flex}.btn-unlock-primary,.btn-unlock-secondary{cursor:pointer;text-align:center;border:none;border-radius:10px;flex-direction:column;align-items:center;gap:.15rem;width:100%;margin-top:auto;padding:.875rem 1rem;transition:all .15s;display:flex}.btn-unlock-primary{background:var(--green-mid);color:#fff}.btn-unlock-primary:hover{background:var(--green-dark)}.btn-unlock-secondary{border:2px solid var(--green-light);color:var(--text);background:#fff}.btn-unlock-secondary:hover{border-color:var(--green-mid);background:#f0fdf4}.unlock-price{font-size:1.4rem;font-weight:800;line-height:1}.unlock-price small{font-size:.8rem;font-weight:600}.unlock-label{font-size:.9rem;font-weight:700}.unlock-sub{opacity:.7;font-size:.72rem}.paywall-compact{background:var(--green-pale);border:1px solid var(--border);border-radius:10px;flex-wrap:wrap;align-items:center;gap:.75rem;padding:.875rem 1rem;display:flex}.paywall-compact .lock-icon{font-size:1.25rem}.paywall-compact p{color:var(--text);flex:1;min-width:120px;margin:0;font-size:.875rem}.btn-unlock-sm{background:var(--green-mid);color:#fff;cursor:pointer;white-space:nowrap;border:none;border-radius:8px;padding:.5rem 1rem;font-size:.85rem;font-weight:700}.btn-unlock-sm:hover{background:var(--green-dark)}.paywall-zone-tip{color:var(--text-soft);text-align:center;margin:.5rem 0 .25rem;font-size:.82rem}.paywall-zone-tip a{color:var(--green-dark);font-weight:600;text-decoration:underline}.paywall-note{color:var(--text-soft);margin-top:.5rem;font-size:.78rem}.btn-print{border:1.5px solid var(--border);color:var(--text-soft);cursor:pointer;background:0 0;border-radius:8px;padding:.55rem 1rem;font-size:.88rem;font-weight:600;transition:all .15s}.btn-print:hover{border-color:var(--green-mid);color:var(--green-mid)}.plan-header-actions{align-items:center;gap:.75rem;display:flex}.print-plan{display:none}@media print{.app-header,.tab-bar,.plan-header,.plan-summary,.free-tier-banner,.paywall-overlay,.plants-tab,.canvas-tab,.timeline-tab,.tips-tab,.btn-print,.btn-secondary,.btn-text{display:none!important}body{background:#fff;font-size:11pt}.print-plan{display:block!important}.print-header{border-bottom:2px solid #2d5a1b;justify-content:space-between;align-items:baseline;margin-bottom:.75rem;padding-bottom:.5rem;display:flex}.print-logo{color:#2d5a1b;font-size:1.2rem;font-weight:800}.print-meta{color:#555;font-size:.8rem}.print-summary{color:#444;margin-bottom:1rem;font-size:.9rem;font-style:italic}.print-section-title{color:#2d5a1b;text-transform:uppercase;letter-spacing:.05em;border-bottom:1px solid #c5deb0;margin:1rem 0 .5rem;padding-bottom:.2rem;font-size:1rem}.print-plant-table{border-collapse:collapse;width:100%;font-size:.8rem}.print-plant-table th{color:#2d5a1b;text-align:left;background:#e8f5e2;border:1px solid #c5deb0;padding:.3rem .5rem;font-size:.75rem}.print-plant-table td{vertical-align:top;border:1px solid #e0e0e0;padding:.3rem .5rem}.print-plant-table tr:nth-child(2n) td{background:#f9fdf7}.print-care-grid{grid-template-columns:1fr 1fr;gap:.5rem;display:grid}.print-care-card{break-inside:avoid;border:1px solid #c5deb0;border-radius:4px;padding:.5rem .75rem;font-size:.8rem}.print-care-header{border-left:3px solid #4a7c2e;margin-bottom:.25rem;padding-left:.4rem}.print-care-card p{color:#444;margin:.2rem 0}.print-zones{grid-template-columns:1fr 1fr;gap:.5rem;margin-top:.5rem;display:grid}.print-zone{break-inside:avoid;background:#f9fdf7;border:1px solid #c5deb0;border-radius:4px;padding:.5rem .75rem;font-size:.8rem}.print-zone p{color:#555;margin:.2rem 0}.print-timeline{grid-template-columns:1fr 1fr;gap:.5rem;display:grid}.print-season{break-inside:avoid;border:1px solid #c5deb0;border-radius:4px;padding:.5rem .75rem;font-size:.8rem}.print-season-title{color:#2d5a1b;margin-bottom:.25rem;font-weight:700}.print-season p{color:#444;margin:0}.print-tips{color:#444;padding-left:1.2rem;font-size:.85rem;line-height:1.7}.print-footer{color:#999;text-align:center;border-top:1px solid #c5deb0;margin-top:1.5rem;padding-top:.5rem;font-size:.7rem}}@media (width<=768px){.app-main{padding:1.25rem .875rem}.plan-header h1{font-size:1.4rem}.plant-grid{grid-template-columns:repeat(auto-fill,minmax(200px,1fr))}}@media (width<=600px){.app-header{padding:.75rem 1rem}.app-header .logo{font-size:1.1rem}.header-right{gap:.5rem}.header-right .tier-badge{display:none}.app-main{padding:1rem .75rem}.free-tier-banner{flex-direction:column;align-items:flex-start;gap:.75rem}.banner-actions{width:100%}.banner-actions button{flex:1;padding:.5rem;font-size:.78rem}.form-card{padding:1.25rem 1rem}.step-dot span{font-size:.65rem}.option-btn,.goal-btn{min-height:44px}.form-nav{flex-wrap:wrap;gap:.5rem}.btn-generate{justify-content:center;width:100%}.tab-bar button{min-height:44px;padding:.65rem .875rem;font-size:.8rem}.plant-grid{grid-template-columns:1fr}.paywall-card{padding:1.25rem .875rem}.paywall-tiers{grid-template-columns:1fr}.paywall-divider{padding:.25rem 0}.paywall-tier{text-align:left}.paywall-features{font-size:.82rem}.bloom-grid{grid-template-columns:repeat(6,1fr)}.canvas-hint{font-size:.78rem}.selected-plant-detail{margin-top:.75rem}}@media (width<=375px){.app-header .logo{font-size:1rem}.form-card{padding:1rem .75rem}.bloom-grid{grid-template-columns:repeat(4,1fr)}.paywall-card{padding:1rem .75rem}}.modal-backdrop{z-index:200;background:#00000080;justify-content:center;align-items:center;padding:1rem;display:flex;position:fixed;inset:0}.modal-card{background:var(--white);width:100%;max-width:420px;box-shadow:var(--shadow-lg);border-radius:16px;padding:2rem;position:relative}.modal-close{cursor:pointer;color:var(--text-soft);background:0 0;border:none;border-radius:6px;padding:.25rem .5rem;font-size:1.1rem;position:absolute;top:1rem;right:1rem}.modal-close:hover{background:var(--green-pale)}.modal-header{text-align:center;margin-bottom:1.5rem}.modal-header h2{color:var(--green-dark);margin:.5rem 0 .25rem;font-size:1.3rem}.modal-header p{color:var(--text-soft);font-size:.9rem}.modal-tabs{background:var(--green-pale);border-radius:8px;margin-bottom:1.25rem;padding:3px;display:flex}.modal-tabs button{cursor:pointer;color:var(--text-soft);background:0 0;border:none;border-radius:6px;flex:1;padding:.5rem;font-size:.9rem;font-weight:600;transition:all .15s}.modal-tabs button.active{background:var(--white);color:var(--green-dark);box-shadow:0 1px 4px #0000001a}.auth-form{flex-direction:column;gap:.875rem;display:flex}.auth-error{color:#991b1b;background:#fee2e2;border-radius:8px;padding:.6rem .875rem;font-size:.85rem}.auth-message{background:var(--green-pale);color:var(--green-dark);text-align:center;border-radius:8px;padding:.875rem 1rem;font-size:.9rem;line-height:1.5}.dashboard{width:100%}.dashboard-header{flex-wrap:wrap;justify-content:space-between;align-items:flex-start;gap:1rem;margin-bottom:2rem;display:flex}.dashboard-header h1{color:var(--green-dark);font-size:1.8rem}.dashboard-subtitle{color:var(--text-soft);margin-top:.2rem}.dashboard-actions{gap:.75rem;display:flex}.dashboard-loading{text-align:center;padding:3rem}.dashboard-loading p{color:var(--text-soft);margin-top:.5rem}.dashboard-empty{text-align:center;flex-direction:column;align-items:center;gap:.75rem;padding:4rem 1rem;display:flex}.dashboard-empty h2{color:var(--green-dark)}.dashboard-empty p{color:var(--text-soft);max-width:320px}.plans-grid{grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:1rem;display:grid}.plan-tile{background:var(--white);border-radius:var(--radius);box-shadow:var(--shadow);cursor:pointer;border:2px solid #0000;padding:1.25rem;transition:transform .15s,box-shadow .15s;position:relative}.plan-tile:hover{box-shadow:var(--shadow-lg);border-color:var(--border);transform:translateY(-2px)}.plan-tile-latest{border-color:var(--green-light)}.plan-tile-badge{background:var(--green-light);color:#fff;text-transform:uppercase;letter-spacing:.05em;border-radius:99px;padding:2px 10px;font-size:.7rem;font-weight:700;position:absolute;top:-10px;left:1rem}.plan-tile-icon{margin-bottom:.5rem;font-size:2rem}.plan-tile h3{color:var(--green-dark);margin-bottom:.25rem;font-size:1rem}.plan-tile-location{color:var(--text-soft);margin-bottom:.2rem;font-size:.85rem}.plan-tile-meta{color:var(--text-soft);font-size:.8rem}.plan-tile-goals{color:var(--text-soft);white-space:nowrap;text-overflow:ellipsis;margin-top:.25rem;font-size:.78rem;overflow:hidden}.plan-tile-footer{border-top:1px solid var(--border);color:var(--text-soft);justify-content:space-between;align-items:center;margin-top:1rem;padding-top:.75rem;font-size:.78rem;display:flex}.plan-tile-delete{cursor:pointer;background:0 0;border:none;border-radius:6px;padding:.2rem .4rem;font-size:1rem;transition:background .1s}.plan-tile-delete:hover{background:#fee2e2}.autosave-notice{background:var(--green-pale);color:var(--green-dark);text-align:center;border-radius:8px;margin-bottom:1rem;padding:.5rem 1rem;font-size:.85rem;font-weight:600}.success-page{text-align:center;flex-direction:column;align-items:center;gap:1rem;padding:5rem 1rem;display:flex}.success-page h2{color:var(--green-dark);font-size:1.5rem}.success-page p{color:var(--text-soft);max-width:400px}.bloom-calendar{flex-direction:column;gap:2rem;display:flex}.bloom-grid{grid-template-columns:repeat(12,1fr);gap:.5rem;display:grid;overflow-x:auto}.bloom-month{flex-direction:column;align-items:center;gap:.35rem;min-width:52px;display:flex}.bloom-month-label{color:var(--text-soft);text-transform:uppercase;letter-spacing:.04em;font-size:.75rem;font-weight:700}.bloom-bars{background:var(--green-pale);border-radius:8px;flex-direction:column;justify-content:flex-start;align-items:center;gap:3px;width:100%;min-height:80px;padding:6px 4px;display:flex}.bloom-bar{opacity:.85;border-radius:4px;width:100%;height:10px;transition:opacity .15s}.bloom-bar:hover{opacity:1}.bloom-month-gap .bloom-bars{border:1px dashed var(--border);background:#fafafa}.bloom-gap-indicator{color:var(--border);margin-top:auto;margin-bottom:auto;font-size:1.25rem;line-height:1}.bloom-count{color:var(--text-soft);text-align:center;font-size:.7rem}.bloom-count-zero{color:#ccc}.bloom-legend h4{color:var(--green-dark);margin-bottom:.75rem;font-size:.95rem}.bloom-legend-items{grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:.5rem;display:grid}.bloom-legend-item{background:var(--white);border:1px solid var(--border);border-radius:8px;align-items:center;gap:.6rem;padding:.5rem .75rem;display:flex}.bloom-legend-swatch{border-radius:50%;flex-shrink:0;width:14px;height:14px}.bloom-legend-info{flex-direction:column;gap:1px;display:flex}.bloom-legend-name{color:var(--text);font-size:.85rem;font-weight:600}.bloom-legend-months{color:var(--text-soft);font-size:.75rem}.bloom-advice{grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:1rem;display:grid}.bloom-advice-card{border-radius:var(--radius);border-left:4px solid #0000;padding:1.25rem}.bloom-advice-card h4{margin-bottom:.5rem;font-size:.9rem;font-weight:700}.bloom-advice-card p{color:var(--text);margin:0;font-size:.9rem;line-height:1.55}.bloom-advice-strategy{background:#f0fdf4;border-color:#4ade80}.bloom-advice-strategy h4{color:#166534}.bloom-advice-gaps{background:#fffbeb;border-color:#fbbf24}.bloom-advice-gaps h4{color:#92400e}.bloom-advice-succession{background:#eff6ff;border-color:#60a5fa}.bloom-advice-succession h4{color:#1e40af}@media (width<=700px){.bloom-grid{grid-template-columns:repeat(6,1fr)}}@media (width<=420px){.bloom-grid{grid-template-columns:repeat(4,1fr)}}.placement-ok{color:#166534;background:#f0fdf4;border:1px solid #86efac;border-radius:8px;margin-top:.75rem;padding:.65rem 1rem;font-size:.85rem}.placement-warnings{border-radius:8px;margin-top:.75rem;font-size:.85rem;overflow:hidden}.placement-warnings.has-errors{background:#fff5f5;border:1px solid #fca5a5}.placement-warnings.has-warns{background:#fffbeb;border:1px solid #fde68a}.placement-warnings-title{padding:.5rem 1rem;font-size:.85rem;font-weight:700}.has-errors .placement-warnings-title{color:#991b1b;background:#fee2e2}.has-warns .placement-warnings-title{color:#92400e;background:#fef3c7}.placement-warnings-list{flex-direction:column;gap:.35rem;margin:0;padding:.5rem 1rem;list-style:none;display:flex}.pw-item{align-items:baseline;gap:.5rem;display:flex}.pw-plant{white-space:nowrap;flex-shrink:0;font-weight:700}.pw-error .pw-plant{color:#b91c1c}.pw-warn .pw-plant{color:#92400e}.pw-msg{color:var(--text)}.placement-warnings-hint{color:var(--text-soft);margin:0;padding:.35rem 1rem .6rem;font-size:.78rem}.legend-item.legend-error{background:#fff5f5;border-color:#fca5a5}.legend-item.legend-warn{background:#fffbeb;border-color:#fde68a}.legend-warn-icon{margin-left:auto;font-size:.85rem}.plant-photo svg{width:100%;height:100%;display:block}.btn-view-photo{cursor:pointer;color:var(--green-dark);white-space:nowrap;background:#ffffffeb;border:1px solid #0000001f;border-radius:20px;padding:3px 9px;font-size:.72rem;font-weight:600;line-height:1.6;transition:background .15s,transform .1s;position:absolute;bottom:6px;right:6px;box-shadow:0 1px 4px #0000001f}.btn-view-photo:hover{background:#fff;transform:scale(1.05)}.btn-view-photo.loading{opacity:.7;cursor:wait}.bloom-empty{text-align:center;flex-direction:column;align-items:center;gap:.75rem;padding:3rem 1.5rem;display:flex}.bloom-empty-icon{font-size:3rem}.bloom-empty h3{color:var(--green-dark);font-size:1.1rem}.bloom-empty p{color:var(--text-soft);max-width:380px;font-size:.9rem;line-height:1.55}
