@import "https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800&display=swap";
@font-face{font-family:Yesteryear;font-style:normal;font-weight:400;font-display:swap;src:url(../media/118152b4472b221d-s.19e39cfc.woff2)format("woff2");unicode-range:U+100-2BA,U+2BD-2C5,U+2C7-2CC,U+2CE-2D7,U+2DD-2FF,U+304,U+308,U+329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:Yesteryear;font-style:normal;font-weight:400;font-display:swap;src:url(../media/54a650d2d03b3c91-s.p.d2863dde.woff2)format("woff2");unicode-range:U+??,U+131,U+152-153,U+2BB-2BC,U+2C6,U+2DA,U+2DC,U+304,U+308,U+329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}@font-face{font-family:Yesteryear Fallback;src:local(Arial);ascent-override:129.66%;descent-override:65.06%;line-gap-override:0.0%;size-adjust:75.36%}.yesteryear_4bdc13dd-module__mfI6GG__className{font-family:Yesteryear,Yesteryear Fallback;font-style:normal;font-weight:400}.yesteryear_4bdc13dd-module__mfI6GG__variable{--font-yesteryear:"Yesteryear","Yesteryear Fallback"}
:root{--bg-primary:#fff;--bg-secondary:#f8fafc;--bg-card:#fff;--bg-card-hover:#f1f5f9;--bg-glass:#ffffffd9;--text-primary:#0f172a;--text-secondary:#334155;--text-muted:#64748b;--accent:#0a1628;--accent-light:#1e293b;--accent-dim:#0a16280d;--accent-glow:#0a162826;--success:#2563eb;--warning:#f59e0b;--error:#ef4444;--border:#0f172a1f;--border-active:#0a16284d;--gradient-hero:linear-gradient(135deg,#f8fafc 0%,#e2e8f0 100%);--gradient-card:linear-gradient(145deg,#fff 0%,#f8fafc 100%);--gradient-accent:linear-gradient(135deg,#0a1628 0%,#1e293b 100%);--gradient-shimmer:linear-gradient(90deg,transparent,#0a16280d,transparent);--shadow-sm:0 1px 2px #0a16280d;--shadow-md:0 4px 12px #0a162814;--shadow-lg:0 8px 32px #0a16281f;--shadow-glow:0 0 20px #0a16281a;--radius-sm:8px;--radius-md:12px;--radius-lg:16px;--radius-xl:24px;--transition-fast:.15s cubic-bezier(.4,0,.2,1);--transition-normal:.3s cubic-bezier(.4,0,.2,1);--transition-slow:.5s cubic-bezier(.4,0,.2,1)}*{box-sizing:border-box;margin:0;padding:0}html,body{background:var(--bg-primary);height:100%;color:var(--text-primary);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-family:Inter,-apple-system,BlinkMacSystemFont,sans-serif}@keyframes appFocusIn{0%{opacity:0;filter:blur(4px);transform:scale(.98)}to{opacity:1;filter:blur();transform:scale(1)}}.app-container{flex-direction:column;min-height:100vh;display:flex}.app-fade-in{animation:.8s cubic-bezier(.16,1,.3,1) forwards appFocusIn}.app-header{background:var(--accent);color:#fff;z-index:100;box-shadow:var(--shadow-sm);justify-content:center;align-items:center;padding:16px 32px;display:flex;position:sticky;top:0}.app-logo{color:#fff;letter-spacing:-.5px;font-size:24px;font-weight:800}.app-subtitle{color:var(--text-muted);font-size:13px;font-weight:400}.app-main{background-color:var(--bg-secondary);flex:1;justify-content:center;width:100%;margin:0 auto;padding:40px 16px;display:flex}.app-sidebar{background:var(--accent);color:#fff;z-index:10;border-right:1px solid #ffffff0d;flex-direction:column;gap:32px;width:280px;padding:40px 28px;transition:transform .3s cubic-bezier(.16,1,.3,1),width .3s cubic-bezier(.16,1,.3,1);display:flex;overflow:hidden;box-shadow:4px 0 24px #0000001a}.app-sidebar.collapsed{border-right:none;width:0;padding:0;transform:translate(-100%)}.hamburger-btn{color:#fff;cursor:pointer;background:0 0;border:none;border-radius:0;justify-content:center;align-items:center;padding:8px 12px;transition:background .2s;display:flex;position:absolute;left:0}.hamburger-btn:hover{background:#ffffff1a}.premium-select-wrapper{position:relative}.premium-select-wrapper:after{content:"▼";color:#ffffff80;pointer-events:none;font-size:10px;position:absolute;top:50%;right:16px;transform:translateY(-50%)}.premium-select{color:#fff;cursor:pointer;appearance:none;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background-color:#ffffff0a;border:1px solid #ffffff1a;border-radius:8px;outline:none;width:100%;padding:14px 16px;font-size:14px;transition:all .3s}.premium-select:hover,.premium-select:focus{background-color:#ffffff14;border-color:#fff3}.premium-select option{background-color:var(--accent);color:#fff}.btn-premium-ghost{letter-spacing:.5px;color:#fff;cursor:pointer;background:0 0;border:1px solid #fff3;border-radius:8px;justify-content:center;align-items:center;gap:8px;width:100%;padding:14px;font-size:15px;font-weight:500;transition:all .3s cubic-bezier(.16,1,.3,1);display:flex}.btn-premium-ghost:hover{background:#ffffff1a;border-color:#ffffff4d;transform:translateY(-2px);box-shadow:0 4px 12px #0003}.btn-premium-ghost:active{transform:translateY(0)}.btn-premium-ghost:active .btn{border-radius:var(--radius-sm);cursor:pointer;transition:all var(--transition-fast);letter-spacing:.5px;border:1px solid #0000;outline:none;justify-content:center;align-items:center;gap:8px;height:48px;padding:12px 24px;font-family:inherit;font-size:14px;font-weight:600;display:inline-flex}.btn-premium-ghost:active .btn:disabled{opacity:.5;cursor:not-allowed;pointer-events:none}.btn-premium-ghost:active .btn-primary{background:var(--accent);color:#fff;box-shadow:0 4px 12px #43537433}.btn-premium-ghost:active .btn-primary:not(:disabled):hover{background:#364461;transform:translateY(-1px);box-shadow:0 6px 16px #4353744d}.btn-premium-ghost:active .btn-secondary{background:var(--bg-secondary);color:var(--text-primary);border-color:var(--border)}.btn-premium-ghost:active .btn-secondary:not(:disabled):hover{background:var(--bg-card);border-color:var(--border-active);color:var(--accent)}.wizard-container{background:var(--bg-card);border-radius:var(--radius-lg);width:100%;max-width:800px;box-shadow:var(--shadow-md);border:1px solid var(--border);padding:40px}.wizard-nav{border-bottom:1px solid var(--border);gap:12px;margin-bottom:32px;padding-bottom:24px;display:flex}.wizard-step-btn{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-md);color:var(--text-muted);cursor:pointer;transition:all var(--transition-normal);flex:1;align-items:center;gap:10px;padding:14px 16px;font-family:inherit;font-size:14px;font-weight:500;display:flex}.wizard-step-btn:hover:not(:disabled){background:var(--bg-card-hover);color:var(--text-secondary)}.wizard-step-btn.active{background:var(--accent-dim);border-color:var(--border-active);color:var(--accent);box-shadow:var(--shadow-glow)}.wizard-step-btn.completed{color:var(--success);border-color:#2563eb4d}.wizard-step-btn:disabled{opacity:.4;cursor:not-allowed}.step-number{background:var(--bg-secondary);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:28px;height:28px;font-size:13px;font-weight:700;display:flex}.wizard-step-btn.active .step-number{background:var(--accent);color:var(--bg-primary)}.wizard-step-btn.completed .step-number{background:var(--success);color:var(--bg-primary)}.section-title{color:var(--text-primary);margin-bottom:8px;font-size:22px;font-weight:700}.section-desc{color:var(--text-secondary);margin-bottom:28px;font-size:14px;line-height:1.6}.card{background:var(--gradient-card);border:1px solid var(--border);border-radius:var(--radius-lg);transition:all var(--transition-normal);padding:24px}.card:hover{border-color:var(--border-active);box-shadow:var(--shadow-glow)}.upload-grid{grid-template-columns:repeat(5,1fr);gap:12px;margin-bottom:24px;display:grid}.upload-slot{aspect-ratio:1;border:2px dashed var(--border);border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-normal);background:var(--bg-card);flex-direction:column;justify-content:center;align-items:center;gap:6px;display:flex;position:relative;overflow:hidden}.upload-slot:hover{border-color:var(--accent);background:var(--accent-dim)}.upload-slot.has-image{border-style:solid;border-color:var(--success);padding:0}.upload-slot.has-image img{object-fit:cover;width:100%;height:100%}.upload-slot-label{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;font-size:11px;font-weight:600}.upload-slot-icon{color:var(--text-muted);font-size:20px}.upload-slot-remove{color:#fff;cursor:pointer;width:28px;height:28px;transition:background var(--transition-fast);background:#000000b3;border:none;border-radius:50%;justify-content:center;align-items:center;font-size:14px;display:flex;position:absolute;top:8px;right:8px}.upload-slot-remove:hover{background:var(--error)}.form-row{flex-wrap:wrap;gap:20px;margin-bottom:28px;display:flex}.form-group{flex-direction:column;gap:6px;min-width:180px;display:flex}.form-label{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.8px;font-size:12px;font-weight:600}.form-select,.form-input{background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-primary);cursor:pointer;transition:border-color var(--transition-fast);appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%2394a3c4' stroke-width='2'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");background-position:right 12px center;background-repeat:no-repeat;padding:10px 36px 10px 14px;font-family:inherit;font-size:14px}.form-select:focus,.form-input:focus{border-color:var(--accent);box-shadow:0 0 0 2px var(--accent-dim);outline:none}.grade-display{flex-wrap:wrap;align-items:flex-start;gap:24px;display:flex}.grade-badge{background:var(--gradient-accent);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;font-size:48px;font-weight:800;line-height:1}.grade-scale{flex-wrap:wrap;gap:6px;margin:16px 0;display:flex}.grade-scale-item{border-radius:var(--radius-sm);background:var(--bg-secondary);color:var(--text-muted);border:1px solid var(--border);transition:all var(--transition-fast);padding:6px 12px;font-size:12px;font-weight:600}.grade-scale-item.current{background:var(--accent-dim);color:var(--accent);border-color:var(--border-active);box-shadow:var(--shadow-glow)}.zone-assessment-grid{grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:16px;margin-top:24px;display:grid}.zone-assessment-card{background:var(--bg-secondary);border-radius:var(--radius-md);border:1px solid var(--border);padding:16px}.zone-assessment-title{color:var(--accent);text-transform:uppercase;letter-spacing:.5px;margin-bottom:6px;font-size:13px;font-weight:700}.zone-assessment-text{color:var(--text-secondary);font-size:13px;line-height:1.5}.graft-config-grid{flex-direction:column;gap:16px;display:flex}.zone-config-row{background:var(--bg-secondary);border-radius:var(--radius-md);border:1px solid var(--border);transition:all var(--transition-fast);align-items:center;gap:16px;padding:16px 20px;display:flex}.zone-config-row.selected{border-color:var(--border-active);background:var(--accent-dim)}.zone-checkbox{border:2px solid var(--text-muted);cursor:pointer;width:22px;height:22px;transition:all var(--transition-fast);color:#0000;background:0 0;border-radius:6px;flex-shrink:0;justify-content:center;align-items:center;font-size:12px;display:flex}.zone-checkbox.checked{background:var(--accent);border-color:var(--accent);color:var(--bg-primary)}.zone-config-name{color:var(--text-primary);flex:1;font-size:15px;font-weight:600}.zone-config-name.dimmed{color:var(--text-muted)}.total-grafts-bar{background:var(--gradient-card);border:1px solid var(--border-active);border-radius:var(--radius-lg);box-shadow:var(--shadow-glow);justify-content:space-between;align-items:center;margin-top:24px;padding:20px 24px;display:flex}.total-grafts-label{color:var(--text-secondary);text-transform:uppercase;letter-spacing:1px;font-size:14px;font-weight:600}.total-grafts-value{background:var(--gradient-accent);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;font-size:32px;font-weight:800}.results-grid{grid-template-columns:repeat(2,1fr);gap:24px;display:grid}.result-panel{border-radius:var(--radius-lg);border:1px solid var(--border);background:var(--bg-card);overflow:hidden}.result-panel-header{border-bottom:1px solid var(--border);text-transform:uppercase;letter-spacing:.5px;color:var(--accent);background:var(--bg-secondary);padding:12px 16px;font-size:13px;font-weight:700}.result-images{grid-template-columns:1fr 1fr;display:grid}.result-image-slot{aspect-ratio:3/4;position:relative;overflow:hidden}.result-image-slot img{object-fit:cover;width:100%;height:100%}.result-image-label{text-transform:uppercase;letter-spacing:.5px;text-align:center;padding:6px 10px;font-size:11px;font-weight:700;position:absolute;bottom:0;left:0;right:0}.result-image-label.before{color:var(--text-secondary);background:#000000b3}.result-image-label.after{color:var(--accent);background:#dc262633}.result-placeholder{aspect-ratio:3/4;color:var(--text-muted);background:var(--bg-secondary);justify-content:center;align-items:center;font-size:13px;display:flex}.loading-spinner{flex-direction:column;align-items:center;gap:16px;padding:48px;display:flex}.spinner{border:3px solid var(--border);border-top-color:var(--accent);border-radius:50%;width:40px;height:40px;animation:.8s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.loading-text{color:var(--text-secondary);font-size:14px}.btn{border-radius:var(--radius-sm);cursor:pointer;transition:all var(--transition-normal);border:none;justify-content:center;align-items:center;gap:8px;padding:12px 28px;font-family:inherit;font-size:14px;font-weight:600;display:inline-flex}.btn-primary{background:var(--gradient-accent);color:var(--bg-primary)}.btn-primary:hover:not(:disabled){box-shadow:var(--shadow-glow),0 4px 16px #dc26264d;transform:translateY(-1px)}.btn-primary:disabled{opacity:.4;cursor:not-allowed;transform:none}.btn-secondary{background:var(--bg-card);color:var(--text-primary);border:1px solid var(--border)}.btn-secondary:hover{border-color:var(--border-active);background:var(--bg-card-hover)}.btn-row{flex-wrap:wrap;justify-content:center;gap:16px;margin-top:32px;display:flex}.disclaimer{border-radius:var(--radius-md);color:var(--warning);background:#fbbf2414;border:1px solid #fbbf2440;margin-top:24px;padding:16px 20px;font-size:12px;line-height:1.6}@media (max-width:768px){.app-main{padding:16px}.wizard-nav{flex-direction:column}.upload-grid{grid-template-columns:repeat(3,1fr)}.form-row{flex-direction:column}.results-grid{grid-template-columns:1fr}.grade-display{flex-direction:column}.total-grafts-bar{text-align:center;flex-direction:column;gap:8px}}@keyframes bootUpFade{0%{opacity:0}20%{opacity:1}80%{opacity:1}to{opacity:0}}@keyframes slideUpFade{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@keyframes bootFadeIn{0%{opacity:0}to{opacity:1}}@keyframes bootLogoReveal{0%{opacity:0;letter-spacing:24px;filter:blur(12px);transform:translateY(16px)}60%{opacity:1;filter:blur()}to{opacity:1;letter-spacing:14px;transform:translateY(0)}}@keyframes bootSubReveal{0%{opacity:0;letter-spacing:8px;filter:blur(4px);transform:translateY(6px)}to{opacity:.6;letter-spacing:3px;filter:blur();transform:translateY(0)}}@keyframes bootTaglineIn{0%{opacity:0;filter:blur(4px);transform:translateY(12px)}to{opacity:1;filter:blur();transform:translateY(0)}}@keyframes bootTaglineOut{0%{opacity:1;filter:blur();transform:translateY(0)}to{opacity:0;filter:blur(3px);transform:translateY(-10px)}}@keyframes bootProgress{0%{width:0%}30%{width:40%}60%{width:70%}85%{width:90%}to{width:100%}}@keyframes floatA{0%,to{opacity:.06;transform:translate(0)scale(1)}50%{opacity:.12;transform:translate(22px,-18px)scale(1.1)}}@keyframes floatB{0%,to{opacity:.05;transform:translate(0)scale(1)}50%{opacity:.1;transform:translate(-18px,20px)scale(.9)}}@keyframes floatC{0%,to{opacity:.04;transform:translate(0)}50%{opacity:.09;transform:translate(14px,12px)}}@keyframes scanLine{0%{opacity:0;transform:translateY(-100%)}5%{opacity:1}95%{opacity:1}to{opacity:0;transform:translateY(100vh)}}@keyframes logoPulse{0%,to{text-shadow:0 0 40px #ffffff14}50%{text-shadow:0 0 80px #ffffff2e,0 0 120px #ffffff12}}.boot-screen{background:var(--accent);color:#fff;z-index:9999;flex-direction:column;justify-content:center;align-items:center;animation:.5s forwards bootFadeIn;display:flex;position:fixed;inset:0;overflow:hidden}@keyframes bootFadeOutAnim{0%{opacity:1}to{opacity:0}}.boot-screen.fade-out{pointer-events:none;animation:.5s forwards bootFadeOutAnim}.boot-screen:before,.boot-screen:after{content:"";pointer-events:none;border-radius:50%;position:absolute}.boot-screen:before{background:radial-gradient(circle,#ffffff0f 0%,#0000 70%);width:600px;height:600px;animation:9s ease-in-out infinite floatA;top:-15%;left:-12%}.boot-screen:after{background:radial-gradient(circle,#ffffff0d 0%,#0000 70%);width:500px;height:500px;animation:12s ease-in-out infinite floatB;bottom:-10%;right:-10%}.boot-scan{pointer-events:none;background:linear-gradient(90deg,#0000,#ffffff1f,#0000);height:2px;animation:5s linear infinite scanLine;position:absolute;top:0;left:0;right:0}.boot-orb{pointer-events:none;background:radial-gradient(circle,#ffffff0a 0%,#0000 70%);border-radius:50%;width:320px;height:320px;animation:8s ease-in-out infinite floatC;position:absolute;top:55%;left:40%}.boot-wordmark{text-align:center;z-index:2;cursor:default;flex-direction:column;align-items:center;gap:0;width:80vw;max-width:1100px;display:flex;position:relative}.boot-logo-text{letter-spacing:14px;color:#fff;-webkit-user-select:none;user-select:none;font-family:Inter,sans-serif;font-size:clamp(64px,12vw,160px);font-weight:800;line-height:1;transition:letter-spacing .6s,text-shadow .4s;animation:1.4s cubic-bezier(.16,1,.3,1) .2s both bootLogoReveal,5s ease-in-out 2s infinite logoPulse}.boot-logo-text:hover{letter-spacing:20px;text-shadow:0 0 60px #ffffff40,0 0 120px #ffffff1a}.boot-logo-sub{font-family:var(--font-yesteryear),"Inter",serif;letter-spacing:3px;color:#fff9;-webkit-user-select:none;user-select:none;margin-top:4px;font-size:clamp(22px,3.5vw,48px);font-weight:400;transition:color .4s,letter-spacing .5s;animation:1.2s cubic-bezier(.16,1,.3,1) 1s both bootSubReveal}.boot-wordmark:hover .boot-logo-sub{color:#ffffffd9;letter-spacing:5px}.boot-taglines{z-index:2;text-align:center;width:80vw;height:2.2em;margin-top:48px;position:relative}.boot-tagline{letter-spacing:1.5px;color:#ffffffb3;pointer-events:none;font-size:clamp(16px,2.2vw,26px);font-weight:300;position:absolute;left:0;right:0}.boot-tagline.entering{animation:1.2s cubic-bezier(.16,1,.3,1) forwards bootTaglineIn}.boot-tagline.leaving{animation:1s cubic-bezier(.4,0,1,1) forwards bootTaglineOut}.boot-progress-wrap{z-index:3;width:min(360px,60vw);position:fixed;bottom:52px;left:50%;transform:translate(-50%)}.boot-logo{letter-spacing:6px;color:#fff;margin-bottom:40px;font-size:52px;font-weight:700}.boot-text{color:#ffffffbf;letter-spacing:.5px;opacity:0;text-align:center;margin-top:16px;font-size:18px;font-weight:400;animation:.8s cubic-bezier(.16,1,.3,1) forwards slideUpFade}.boot-progress-wrap{width:320px;position:fixed;bottom:48px;left:50%;transform:translate(-50%)}.boot-progress-label{color:#ffffff73;letter-spacing:2px;text-transform:uppercase;text-align:center;margin-bottom:10px;font-size:12px}.boot-progress-track{background:#ffffff26;border-radius:99px;width:100%;height:3px;overflow:hidden}.boot-progress-bar{background:#ffffffd9;border-radius:99px;height:100%;animation:5s ease-in-out forwards bootProgress}
