@import"https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700&display=swap";*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--accent: #22c55e;--accent-light: #4ade80;--accent-dim: rgba(34,197,94,.15);--accent-border: rgba(34,197,94,.3);--bg: #0a0f0d;--bg-02: #0d1410;--surface: rgba(255,255,255,.04);--surface-hover: rgba(255,255,255,.07);--surface-border: rgba(255,255,255,.08);--text-1: #f0fdf4;--text-2: #d1fae5;--text-3: #9ca3af;--text-4: #6b7280;--phase-actual: #3b82f6;--phase-forecast: #f59e0b;--phase-clim: #9ca3af;--error: #ef4444;--warn: #f59e0b;--success: #22c55e;--conf-high: #22c55e;--conf-medium: #f59e0b;--conf-low: #ef4444;--r-sm: 6px;--r-md: 12px;--r-lg: 18px;--r-xl: 24px;--t-fast: .15s ease;--t-base: .25s ease}html{font-size:16px;scroll-behavior:smooth}body{font-family:Inter,system-ui,-apple-system,sans-serif;background:var(--bg);color:var(--text-1);min-height:100vh;line-height:1.6;-webkit-font-smoothing:antialiased}.app{display:flex;flex-direction:column;min-height:100vh}.app-main{flex:1;max-width:1400px;margin:0 auto;width:100%;padding:1.5rem 1.25rem 2rem;display:flex;flex-direction:column;gap:1.5rem}.app-header{background:linear-gradient(135deg,#0a0f0dfa,#142319fa);border-bottom:1px solid var(--accent-border);padding:1rem 1.25rem;position:sticky;top:0;z-index:50;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.header-inner{max-width:1400px;margin:0 auto;display:flex;align-items:center;justify-content:space-between;gap:1rem}.tab-bar{max-width:1400px;margin:1rem auto -1rem;display:flex;gap:.5rem}.tab-btn{background:transparent;border:none;color:var(--text-3);padding:.5rem 1rem;font-size:.95rem;font-weight:500;cursor:pointer;border-bottom:2px solid transparent;transition:all var(--t-fast)}.tab-btn:hover{color:var(--text-2);background:var(--surface);border-radius:var(--r-sm) var(--r-sm) 0 0}.tab-btn.active{color:var(--accent-light);border-bottom-color:var(--accent)}.logo{display:flex;align-items:center;gap:.875rem}.logo-icon{font-size:2rem;filter:drop-shadow(0 0 12px rgba(34,197,94,.6))}.logo h1{font-size:1.25rem;font-weight:700;color:var(--text-1);line-height:1.2}.logo p{font-size:.75rem;color:var(--text-3)}.header-meta{font-size:.7rem;color:var(--text-4);font-weight:500}.two-col{display:grid;grid-template-columns:340px 1fr;gap:1.5rem;align-items:start}@media (max-width: 900px){.two-col{grid-template-columns:1fr}}.card{background:var(--surface);border:1px solid var(--surface-border);border-radius:var(--r-xl);padding:1.25rem;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);transition:border-color var(--t-base)}.card:hover{border-color:#ffffff1f}.card h3{font-size:.8rem;font-weight:600;text-transform:uppercase;letter-spacing:.07em;color:var(--text-3);margin-bottom:.875rem}.input-panel{display:flex;flex-direction:column;gap:1rem;position:sticky;top:80px}.input-group{display:flex;flex-direction:column;gap:.35rem;position:relative}.input-group label{font-size:.8rem;font-weight:600;color:var(--text-2);letter-spacing:.02em}.input-group small{font-size:.7rem;color:var(--text-4)}.field-error{font-size:.72rem;color:var(--error);margin-top:.15rem}input[type=text],input[type=number],input[type=date],select{background:#ffffff0d;border:1px solid var(--surface-border);border-radius:var(--r-md);color:var(--text-1);padding:.55rem .875rem;font-family:inherit;font-size:.875rem;width:100%;transition:border-color var(--t-fast),box-shadow var(--t-fast);outline:none}input:focus,select:focus{border-color:var(--accent-border);box-shadow:0 0 0 3px #22c55e1f}input[type=date]::-webkit-calendar-picker-indicator{filter:invert(1) brightness(.6)}select option{background:#1a2e20}select optgroup{color:var(--accent-light);font-weight:600}.search-wrapper{position:relative;display:flex;align-items:center}.search-input{padding-right:2.5rem}.search-input.selected{border-color:var(--accent-border);color:var(--accent-light)}.search-spinner{position:absolute;right:.75rem;width:16px;height:16px;border:2px solid transparent;border-top-color:var(--accent);border-radius:50%;animation:spin .7s linear infinite}.clear-btn{position:absolute;right:.75rem;background:none;border:none;color:var(--text-4);cursor:pointer;font-size:.875rem;line-height:1;padding:.2rem;transition:color var(--t-fast)}.clear-btn:hover{color:var(--error)}.dropdown{position:absolute;top:calc(100% + 4px);left:0;right:0;background:#121e16;border:1px solid var(--accent-border);border-radius:var(--r-md);z-index:100;list-style:none;max-height:220px;overflow-y:auto;box-shadow:0 8px 32px #00000080}.dropdown-item{padding:.6rem .875rem;cursor:pointer;display:flex;flex-direction:column;gap:.1rem;transition:background var(--t-fast);border-bottom:1px solid rgba(255,255,255,.04)}.dropdown-item:last-child{border-bottom:none}.dropdown-item:hover,.dropdown-item:focus{background:var(--accent-dim);outline:none}.loc-name{font-size:.875rem;font-weight:500}.loc-region{font-size:.72rem;color:var(--text-3)}.location-badge{display:flex;justify-content:space-between;align-items:center;font-size:.75rem;padding:.35rem .6rem;background:var(--accent-dim);border:1px solid var(--accent-border);border-radius:var(--r-sm);color:var(--accent-light);gap:.5rem}.coords{color:var(--text-4);font-size:.68rem;white-space:nowrap}.variety-hint{display:flex;flex-direction:column;gap:.15rem;font-size:.72rem;color:var(--text-3);padding:.35rem .6rem;background:var(--surface);border-radius:var(--r-sm);border-left:2px solid var(--accent-border)}.variety-hint strong{color:var(--accent-light)}.custom-gdd{display:flex;flex-direction:column;gap:.25rem;padding-top:.25rem}.custom-gdd label{font-size:.75rem;color:var(--text-3)}.custom-gdd small{font-size:.68rem;color:var(--text-4)}.radio-group{display:flex;flex-wrap:wrap;gap:.4rem}.radio-option{display:flex;align-items:center;gap:.25rem;padding:.35rem .65rem;border:1px solid var(--surface-border);border-radius:var(--r-md);cursor:pointer;font-size:.8rem;transition:all var(--t-fast);-webkit-user-select:none;user-select:none;color:var(--text-3)}.radio-option:hover{border-color:var(--accent-border);color:var(--text-1)}.radio-option.selected{background:var(--accent-dim);border-color:var(--accent-border);color:var(--accent-light);font-weight:600}.radio-option input{display:none}.predict-btn{padding:.75rem 1.25rem;background:linear-gradient(135deg,var(--accent),#16a34a);border:none;border-radius:var(--r-lg);color:#fff;font-family:inherit;font-size:1rem;font-weight:700;cursor:pointer;letter-spacing:.02em;display:flex;align-items:center;justify-content:center;gap:.5rem;transition:all var(--t-base);box-shadow:0 4px 16px #22c55e4d;margin-top:.25rem}.predict-btn:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 8px 24px #22c55e66}.predict-btn:active:not(:disabled){transform:translateY(0)}.predict-btn:disabled{opacity:.45;cursor:not-allowed;box-shadow:none;transform:none}.predict-btn.loading{background:linear-gradient(135deg,#1d4ed8,#1e40af)}.btn-spinner{width:16px;height:16px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .7s linear infinite}.predict-hint{font-size:.72rem;color:var(--text-4);text-align:center}.accuracy-card{background:#22c55e0d;border-color:var(--accent-border)}.accuracy-details{display:flex;flex-direction:column;gap:.75rem}.acc-row{display:flex;justify-content:space-between;align-items:center;font-size:.9rem}.acc-row span{color:var(--text-3)}.acc-row strong{color:var(--text-1)}.accuracy-badge{display:inline-flex;align-items:center;justify-content:center;padding:.5rem 1rem;border-radius:var(--r-md);font-weight:600;font-size:.9rem;margin-top:.5rem;text-align:center}.accuracy-good{background:#22c55e26;color:#4ade80;border:1px solid rgba(34,197,94,.3)}.accuracy-moderate{background:#f59e0b26;color:#fbbf24;border:1px solid rgba(245,158,11,.3)}.accuracy-off{background:#ef444426;color:#f87171;border:1px solid rgba(239,68,68,.3)}.loading-progress{background:var(--surface);border:1px solid var(--surface-border);border-radius:var(--r-xl);padding:1.25rem;display:flex;flex-direction:column;gap:.875rem}.loading-bar-track{height:6px;background:#ffffff14;border-radius:99px;overflow:hidden}.loading-bar-fill{height:100%;background:linear-gradient(90deg,var(--accent),var(--accent-light));border-radius:99px;transition:width .5s ease;box-shadow:0 0 10px #22c55e80}.loading-phases{display:flex;gap:.5rem;flex-wrap:wrap}.loading-phase{display:flex;align-items:center;gap:.35rem;font-size:.72rem;color:var(--text-4);padding:.25rem .6rem;border-radius:99px;border:1px solid transparent;transition:all var(--t-base)}.loading-phase.active{color:var(--accent-light);border-color:var(--accent-border);background:var(--accent-dim)}.loading-phase.done{color:var(--success)}.phase-dot{width:18px;height:18px;border-radius:50%;background:#ffffff1a;display:flex;align-items:center;justify-content:center;font-size:.65rem;font-weight:700}.loading-phase.active .phase-dot{background:var(--accent);color:#fff}.loading-phase.done .phase-dot{background:var(--success);color:#fff}.loading-text{font-size:.78rem;color:var(--text-3);text-align:center}.results-panel{display:flex;flex-direction:column;gap:1rem}.harvest-card{background:linear-gradient(135deg,#22c55e1a,#10b9810d);border:1px solid var(--accent-border);border-radius:var(--r-xl);padding:1.5rem;display:flex;flex-direction:column;gap:.875rem}.harvest-card.card-mature{background:linear-gradient(135deg,#ef44441a,#dc26260d);border-color:#ef44444d}.harvest-headline{display:flex;align-items:center;gap:1rem}.harvest-icon{font-size:2.5rem;filter:drop-shadow(0 0 8px rgba(34,197,94,.5))}.harvest-label{font-size:.72rem;font-weight:600;text-transform:uppercase;letter-spacing:.07em;color:var(--accent);margin-bottom:.2rem}.harvest-date{font-size:1.75rem;font-weight:700;color:var(--text-1);line-height:1.1}.harvest-window{font-size:.78rem;color:var(--text-3);padding:.35rem .75rem;background:#ffffff0a;border-radius:var(--r-sm)}.confidence{display:flex;align-items:center;gap:.5rem;padding:.4rem .75rem;border-radius:var(--r-md);background:#0003;width:fit-content}.conf-dots{display:flex;gap:4px}.conf-dot{width:10px;height:10px;border-radius:50%;background:#ffffff1f;transition:background var(--t-base)}.conf-high .conf-dot.filled{background:var(--conf-high);box-shadow:0 0 6px #22c55e99}.conf-medium .conf-dot.filled{background:var(--conf-medium);box-shadow:0 0 6px #f59e0b80}.conf-low .conf-dot.filled{background:var(--conf-low);box-shadow:0 0 6px #ef444480}.conf-label{font-size:.78rem;font-weight:600}.conf-high .conf-label{color:var(--conf-high)}.conf-medium .conf-label{color:var(--conf-medium)}.conf-low .conf-label{color:var(--conf-low)}.conf-score{font-size:.68rem;color:var(--text-4)}.progress-track{height:14px;background:#ffffff12;border-radius:99px;overflow:hidden;margin-bottom:.5rem}.progress-fill{height:100%;background:linear-gradient(90deg,#3b82f6,var(--accent));border-radius:99px;transition:width .8s cubic-bezier(.34,1.56,.64,1);box-shadow:0 0 12px #22c55e66}.progress-labels{display:flex;justify-content:space-between;font-size:.75rem;color:var(--text-3)}.progress-labels strong{color:var(--text-1);font-size:.875rem}.key-dates{display:flex;flex-direction:column;gap:.5rem}.key-date{display:flex;justify-content:space-between;align-items:center;padding:.45rem .75rem;background:#ffffff08;border-radius:var(--r-sm);gap:.5rem}.kd-label{font-size:.78rem;color:var(--text-3)}.kd-value{font-size:.875rem;font-weight:600;color:var(--text-1)}.phase-bar{height:18px;border-radius:99px;overflow:hidden;display:flex;margin-bottom:1rem;background:#ffffff0d}.phase-bar-segment{transition:width .8s cubic-bezier(.34,1.56,.64,1)}.phase-actual{background:var(--phase-actual)}.phase-forecast{background:var(--phase-forecast)}.phase-clim{background:var(--phase-clim)}.phase-table{width:100%;border-collapse:collapse;font-size:.82rem}.phase-table th{text-align:left;padding:.35rem .5rem;font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--text-4);border-bottom:1px solid var(--surface-border)}.phase-table td{padding:.45rem .5rem;color:var(--text-2)}.phase-table tr:not(:last-child) td{border-bottom:1px solid rgba(255,255,255,.04)}.phase-total td{color:var(--text-1);border-top:1px solid var(--surface-border)!important}.phase-dot-sm{display:inline-block;width:8px;height:8px;border-radius:50%;margin-right:.4rem;vertical-align:middle}.calculation-explainer{display:flex;flex-direction:column;gap:.9rem}.calc-intro{font-size:.82rem;color:var(--text-3);line-height:1.65}.calc-formula{font-size:.8rem;color:var(--text-2);background:#ffffff08;border:1px solid var(--surface-border);border-radius:var(--r-md);padding:.55rem .75rem}.calc-summary-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:.5rem}.calc-pill{display:flex;flex-direction:column;gap:.2rem;padding:.5rem .6rem;border-radius:var(--r-sm);background:#ffffff08;border:1px solid rgba(255,255,255,.06)}.calc-pill span{font-size:.66rem;letter-spacing:.06em;text-transform:uppercase;color:var(--text-4)}.calc-pill strong{font-size:.82rem;color:var(--text-1)}.calc-table{width:100%;border-collapse:collapse;font-size:.78rem}.calc-table th{text-align:left;font-size:.66rem;letter-spacing:.06em;text-transform:uppercase;color:var(--text-4);padding:.4rem .45rem;border-bottom:1px solid var(--surface-border)}.calc-table td{padding:.45rem;color:var(--text-2);border-bottom:1px solid rgba(255,255,255,.04)}.calc-total td{color:var(--text-1);border-top:1px solid var(--surface-border)}.calc-meta{display:flex;flex-wrap:wrap;gap:.75rem 1rem;font-size:.76rem;color:var(--text-3)}.chart-card{padding:1.5rem}.chart-section{width:100%}.chart-tooltip{background:#0a0f0df2;border:1px solid var(--surface-border);border-radius:var(--r-md);padding:.6rem .875rem;font-size:.78rem;line-height:1.8;box-shadow:0 8px 24px #00000080;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.tt-date{font-weight:700;color:var(--text-1);margin-bottom:.15rem}.tt-phase{display:inline-block;margin-top:.25rem;font-size:.65rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;padding:.1rem .4rem;border-radius:3px}.tt-phase.phase-actual{background:#3b82f633;color:var(--phase-actual)}.tt-phase.phase-forecast{background:#f59e0b33;color:var(--phase-forecast)}.tt-phase.phase-climatology{background:#9ca3af33;color:var(--phase-clim)}.chart-data-summary{margin-top:1rem}.chart-data-summary summary{cursor:pointer;font-size:.75rem;color:var(--text-4);padding:.3rem 0;-webkit-user-select:none;user-select:none}.chart-data-summary summary:hover{color:var(--text-3)}.chart-table-scroll{overflow-x:auto;margin-top:.5rem;max-height:300px;overflow-y:auto}.chart-data-summary table{font-size:.72rem;border-collapse:collapse;min-width:500px}.chart-data-summary th,.chart-data-summary td{border:1px solid var(--surface-border);padding:.25rem .5rem;text-align:right}.chart-data-summary th{background:#ffffff0d;text-align:center}.variety-table-card{padding:0}.collapsible-header{display:flex;justify-content:space-between;align-items:center;width:100%;padding:1.1rem 1.25rem;background:none;border:none;color:var(--text-2);font-family:inherit;font-size:.875rem;font-weight:600;cursor:pointer;text-align:left;border-radius:var(--r-xl);transition:background var(--t-fast)}.collapsible-header:hover{background:var(--surface-hover)}.chevron{font-size:.75rem;color:var(--text-4)}.table-scroll{overflow-x:auto;padding:0 1.25rem 1.25rem}.table-scroll table{width:100%;border-collapse:collapse;font-size:.8rem}.table-scroll th{text-align:left;padding:.4rem .6rem;font-size:.68rem;text-transform:uppercase;letter-spacing:.07em;color:var(--text-4);border-bottom:1px solid var(--surface-border);white-space:nowrap}.table-scroll td{padding:.45rem .6rem;border-bottom:1px solid rgba(255,255,255,.04);color:var(--text-2)}.table-scroll tr:hover td{background:#ffffff08}.row-selected td{background:var(--accent-dim)!important;border-color:var(--accent-border)}.season-badge{font-size:.65rem;font-weight:600;padding:.15rem .45rem;border-radius:99px;text-transform:uppercase;letter-spacing:.05em;white-space:nowrap}.season-early{background:#fbbf2426;color:#fbbf24}.season-mid{background:#fb923c26;color:#fb923c}.season-main{background:#22c55e26;color:#22c55e}.season-late{background:#ef444426;color:#ef4444}.season-very-late{background:#8b5cf626;color:#a78bfa}.error-banner{display:flex;align-items:center;justify-content:space-between;gap:.75rem;padding:.75rem 1rem;background:#ef44441a;border:1px solid rgba(239,68,68,.3);border-radius:var(--r-lg);font-size:.83rem;color:#fca5a5}.error-actions{display:flex;gap:.5rem;flex-shrink:0}.error-actions button{background:#ef444433;border:1px solid rgba(239,68,68,.4);border-radius:var(--r-sm);color:#fca5a5;font-family:inherit;font-size:.78rem;padding:.25rem .6rem;cursor:pointer}.error-actions button:hover{background:#ef44444d}.warn-banner{padding:.6rem .875rem;background:#f59e0b1a;border:1px solid rgba(245,158,11,.25);border-radius:var(--r-md);font-size:.78rem;color:#fcd34d}.warn-info{background:#3b82f61a;border-color:#3b82f640;color:#93c5fd}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:3rem 2rem;text-align:center;gap:.875rem;background:var(--surface);border:1px solid var(--surface-border);border-radius:var(--r-xl)}.empty-icon{font-size:3rem;filter:drop-shadow(0 0 16px rgba(34,197,94,.3))}.empty-state h2{font-size:1.25rem;font-weight:700;color:var(--text-1)}.empty-state p{font-size:.875rem;color:var(--text-3);max-width:340px;line-height:1.7}.empty-steps{display:flex;flex-direction:column;gap:.35rem;margin-top:.5rem;width:100%;max-width:260px}.step{padding:.35rem .75rem;border-radius:var(--r-sm);font-size:.78rem;color:var(--text-4);background:#ffffff08;border:1px solid transparent;transition:all var(--t-base)}.step.done{color:var(--accent);border-color:var(--accent-border);background:var(--accent-dim)}.app-footer{border-top:1px solid var(--surface-border);padding:1rem 1.25rem;text-align:center;font-size:.72rem;color:var(--text-4)}.app-footer a{color:var(--accent);text-decoration:none}.app-footer a:hover{text-decoration:underline}.pw-gate{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--bg);padding:1.5rem}.pw-box{background:var(--surface);border:1px solid var(--accent-border);border-radius:var(--r-xl);padding:2.5rem 2rem;max-width:400px;width:100%;display:flex;flex-direction:column;align-items:center;gap:1rem;box-shadow:0 8px 48px #0009;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.pw-logo{font-size:3rem;filter:drop-shadow(0 0 16px rgba(34,197,94,.5))}.pw-title{font-size:1.15rem;font-weight:700;color:var(--text-1);text-align:center}.pw-subtitle{font-size:.8rem;color:var(--text-3);text-align:center}.pw-form{display:flex;flex-direction:column;gap:.75rem;width:100%;margin-top:.5rem}.pw-input{width:100%;background:#ffffff0f;border:1px solid var(--surface-border);border-radius:var(--r-md);color:var(--text-1);padding:.65rem 1rem;font-family:inherit;font-size:1rem;outline:none;transition:border-color var(--t-fast),box-shadow var(--t-fast);text-align:center;letter-spacing:.1em}.pw-input:focus{border-color:var(--accent-border);box-shadow:0 0 0 3px #22c55e1f}.pw-input-error{border-color:var(--error)!important}.pw-error{font-size:.75rem;color:var(--error);text-align:center}.pw-btn{padding:.7rem 1.25rem;background:linear-gradient(135deg,var(--accent),#16a34a);border:none;border-radius:var(--r-lg);color:#fff;font-family:inherit;font-size:.95rem;font-weight:700;cursor:pointer;transition:all var(--t-base);box-shadow:0 4px 16px #22c55e4d}.pw-btn:hover{transform:translateY(-1px);box-shadow:0 8px 24px #22c55e66}.pw-btn:active{transform:none}@keyframes shake{0%,to{transform:translate(0)}20%,60%{transform:translate(-8px)}40%,80%{transform:translate(8px)}}.shake{animation:shake .5s ease}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:#ffffff08}::-webkit-scrollbar-thumb{background:#ffffff1f;border-radius:3px}::-webkit-scrollbar-thumb:hover{background:#fff3}@keyframes spin{to{transform:rotate(360deg)}}@keyframes fadeIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.results-panel,.chart-section{animation:fadeIn .3s ease}@media (prefers-reduced-motion: reduce){*,*:before,*:after{animation-duration:.01ms!important;transition-duration:.01ms!important}}@media (max-width: 600px){.app-main{padding:1rem .875rem}.harvest-date{font-size:1.4rem}.logo h1{font-size:1.05rem}.chart-card{padding:1rem .75rem}.input-panel{position:static}.calc-summary-grid{grid-template-columns:1fr}}
