*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizelegibility}body{background:var(--bg,#faf8f5);color:var(--text,#1c1714);min-height:100svh;font-family:Inter,system-ui,-apple-system,sans-serif;line-height:1.6;transition:background .2s,color .2s}#root{flex-direction:column;min-height:100svh;display:flex}img{max-width:100%;display:block}button{font-family:inherit}a{color:inherit}:root{--bg:#faf8f5;--surface:#fff;--surface-2:#f5f1ec;--surface-3:#ede8e1;--border:#e8e2da;--border-2:#d6cec5;--text:#1c1714;--text-2:#6b5f58;--text-3:#a3958e;--accent:#b85c38;--accent-2:#fdf2ed;--accent-3:#f3d5c5;--accent-dark:#92421f;--serif:"Playfair Display", Georgia, "Times New Roman", serif;--sans:"Inter", system-ui, -apple-system, sans-serif;--shadow-xs:0 1px 2px #0000000d;--shadow-sm:0 1px 4px #00000012, 0 1px 2px #0000000a;--shadow-md:0 4px 16px #00000014, 0 2px 4px #0000000a;--r-xs:3px;--r-sm:6px;--r-md:10px;--r-lg:16px;--r-xl:24px;--r-pill:9999px}[data-theme=dark]{--bg:#141218;--surface:#1c1a22;--surface-2:#242230;--surface-3:#2e2b3a;--border:#3a3748;--border-2:#4e4a62;--text:#ede8f5;--text-2:#a89fbd;--text-3:#6b6380}html{transition:background-color .35s}*,:before,:after{transition:background-color .35s,color .35s,border-color .35s,box-shadow .35s,fill .35s}@media (width<=600px){.app-shell{padding:1.5rem 1rem 3rem}.rv-wrapper{padding:0 1rem}.rv-controls{flex-direction:column;align-items:flex-start;gap:.6rem}.rv-unit-toggle{justify-content:center;align-self:stretch}.rv-hero-img-wrap{aspect-ratio:16/7}.rv-step{padding:1rem .75rem}.rv-step-chips{padding:.4rem 0 .5rem}}.app-shell{flex-direction:column;align-items:center;min-height:100svh;padding:3rem 1.25rem 5rem;display:flex}.app-logo-wrap{place-items:center;margin-bottom:.3rem;display:grid}.app-logo{opacity:1;grid-area:1/1;width:auto;height:72px;transition:opacity .4s!important}.app-logo--dark,[data-theme=dark] .app-logo--light{opacity:0}[data-theme=dark] .app-logo--dark{opacity:1}.app-tagline{color:var(--text-3);text-align:center;letter-spacing:.01em;margin-bottom:2rem;font-size:.875rem}.url-form{background:var(--surface);border:1.5px solid var(--border);border-radius:var(--r-pill);width:100%;max-width:580px;box-shadow:var(--shadow-md);align-items:center;gap:.5rem;margin-bottom:1.75rem;padding:.4rem .4rem .4rem 1.1rem;transition:border-color .2s,box-shadow .2s;display:flex}.url-form:focus-within{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-2), var(--shadow-md)}.url-form-icon{width:16px;height:16px;color:var(--text-3);flex-shrink:0;transition:color .2s}.url-form:focus-within .url-form-icon{color:var(--accent)}.url-form input{font-size:.9rem;font-family:var(--sans);color:var(--text);background:0 0;border:none;outline:none;flex:1;min-width:0;padding:.45rem 0}.url-form input::placeholder{color:var(--text-3);font-style:italic}.url-form button{background:var(--accent);color:#fff;border-radius:var(--r-pill);font-size:.825rem;font-weight:600;font-family:var(--sans);letter-spacing:.03em;cursor:pointer;white-space:nowrap;border:none;flex-shrink:0;padding:.55rem 1.2rem;transition:background .15s!important}.url-form button:hover:not(:disabled){background:var(--accent-dark)}.url-form button:disabled{opacity:.4;cursor:not-allowed}.app-status{color:var(--text-3);align-items:center;gap:.5rem;margin-bottom:.75rem;font-size:.875rem;font-style:italic;display:flex}.app-status:before{content:"";border:2px solid var(--accent-3);border-top-color:var(--accent);border-radius:50%;flex-shrink:0;width:14px;height:14px;animation:.8s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.app-error{color:#b91c1c;border-radius:var(--r-md);background:#fef2f2;border:1px solid #fecaca;width:100%;max-width:560px;padding:.75rem 1rem;font-size:.875rem}.rv-wrapper{width:100%;max-width:1200px;padding:0 1.25rem}.rv-hero{margin-bottom:2rem}.rv-hero-img-wrap{aspect-ratio:16/6;border-radius:var(--r-xl);background:var(--surface-3);width:100%;margin-bottom:1.75rem;overflow:hidden}.rv-hero-img{object-fit:cover;width:100%;height:100%;transition:transform .7s cubic-bezier(.4,0,.2,1)}.rv-hero-img-wrap:hover .rv-hero-img{transform:scale(1.03)}.rv-cuisine{font-family:var(--sans);text-transform:uppercase;letter-spacing:.12em;color:var(--accent);margin-bottom:.6rem;font-size:.7rem;font-weight:700}.rv-title{font-family:var(--serif);color:var(--text);letter-spacing:-.025em;margin-bottom:1.25rem;font-size:clamp(1.8rem,4vw,2.8rem);font-weight:700;line-height:1.18}.rv-meta{flex-wrap:wrap;gap:2.5rem;display:flex}.rv-meta-item{flex-direction:column;gap:.2rem;display:flex}.rv-meta-label{text-transform:uppercase;letter-spacing:.1em;color:var(--text-3);font-size:.65rem;font-weight:700}.rv-meta-value{color:var(--text);font-size:.9rem;font-weight:500}.rv-yield-badge{color:var(--accent);background:var(--accent-2);border-radius:var(--r-xs);vertical-align:middle;margin-right:.25rem;padding:.05rem .35rem;font-size:.7rem;font-weight:700;display:inline-block}.rv-controls{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);box-shadow:var(--shadow-xs);flex-wrap:wrap;justify-content:space-between;align-items:center;gap:.75rem;margin-bottom:2.5rem;padding:.85rem 1.1rem;display:flex}.rv-controls-left{align-items:center;gap:.75rem;display:flex}.rv-controls-label{color:var(--text-3);text-transform:uppercase;letter-spacing:.08em;white-space:nowrap;font-size:.75rem;font-weight:600}.rv-scale-group{background:var(--surface-2);border-radius:var(--r-pill);gap:2px;padding:3px;display:flex}.rv-scale-btn{border-radius:var(--r-pill);color:var(--text-2);cursor:pointer;letter-spacing:.01em;background:0 0;border:none;padding:.28rem .8rem;font-size:.8rem;font-weight:600;transition:background .15s,color .15s,box-shadow .15s}.rv-scale-btn:hover:not(.active){background:var(--surface-3)}.rv-scale-btn.active{background:var(--surface);color:var(--accent);box-shadow:var(--shadow-sm)}.rv-unit-toggle{border:1.5px solid var(--border);border-radius:var(--r-pill);background:var(--surface);cursor:pointer;align-items:center;gap:.4rem;padding:.3rem .85rem;transition:border-color .15s;display:flex}.rv-unit-toggle:hover{border-color:var(--accent-3)}.rv-unit-toggle.active{border-color:var(--accent)}.rv-unit-toggle:disabled{opacity:.5;cursor:default}.rv-unit-opt{color:var(--text-3);font-size:.8rem;font-weight:500;transition:color .15s,font-weight .15s}.rv-unit-opt.on{color:var(--accent);font-weight:700}.rv-unit-dot{color:var(--border-2);font-size:.7rem;line-height:1}.rv-body{grid-template-columns:1fr;gap:2.5rem;display:grid}@media (width>=860px){.rv-body{grid-template-columns:320px 1fr;align-items:start;gap:3.5rem}}@media (width>=1080px){.rv-body{grid-template-columns:360px 1fr}}.rv-step-chips{flex-wrap:wrap;gap:.4rem;padding:.5rem 0 .6rem;display:flex}.rv-step-chip{background:var(--surface);border:1.5px solid var(--accent-3);border-radius:var(--r-pill);cursor:pointer;white-space:nowrap;flex-shrink:0;align-items:center;gap:.3rem;padding:.25rem .6rem .25rem .4rem;font-size:.78rem;transition:background .12s,opacity .15s,border-color .12s;display:inline-flex}.rv-step-chip:hover{background:var(--accent-2);border-color:var(--accent)}.rv-step-chip.checked{opacity:.45;background:var(--surface-2);border-color:var(--border)}.rv-chip-amount{color:var(--accent);background:var(--accent-2);border-radius:var(--r-xs);padding:.05rem .35rem;font-weight:700}.rv-step-chip.checked .rv-chip-amount{color:var(--text-3);background:var(--surface-3)}.rv-chip-name{color:var(--text-2)}.rv-step-content{flex:1;min-width:0}.rv-ing-toggle{display:none}.rv-ing-desktop-title,.rv-ing-body{display:block}@media (width<=859px){.rv-ing-toggle{border:none;border-bottom:1px solid var(--border);cursor:pointer;text-transform:uppercase;letter-spacing:.12em;width:100%;color:var(--text-3);background:0 0;justify-content:space-between;align-items:center;margin-bottom:0;padding:.75rem 0;font-size:.7rem;font-weight:700;display:flex}.rv-ing-toggle-arrow{color:var(--text-3);font-size:1rem;line-height:1;transition:transform .2s;transform:rotate(90deg)}.rv-ing-toggle-arrow.open{transform:rotate(-90deg)}.rv-ing-desktop-title{display:none}.rv-ing-body{padding-top:.75rem;display:none}.rv-ing-body.open{display:block}}@media (width>=860px){.rv-ingredients{scrollbar-width:thin;scrollbar-color:var(--border) transparent;max-height:calc(100vh - 3rem);position:sticky;top:1.5rem;overflow-y:auto}.rv-ingredients::-webkit-scrollbar{width:4px}.rv-ingredients::-webkit-scrollbar-track{background:0 0}.rv-ingredients::-webkit-scrollbar-thumb{background:var(--border);border-radius:var(--r-pill)}}.rv-section-title{font-family:var(--sans);text-transform:uppercase;letter-spacing:.12em;color:var(--text-3);border-bottom:1px solid var(--border);margin-bottom:1rem;padding-bottom:.6rem;font-size:.7rem;font-weight:700}.rv-ing-group{border-bottom:1px solid var(--border);margin-bottom:1rem;padding-bottom:1rem}.rv-ing-group:last-child{border-bottom:none;margin-bottom:0;padding-bottom:0}.rv-ing-group-name{text-transform:uppercase;letter-spacing:.1em;color:var(--accent);margin-bottom:.4rem;font-size:.7rem;font-weight:700}.rv-ing-list{flex-direction:column;gap:2px;list-style:none;display:flex}.rv-ing-item{border-radius:var(--r-sm);cursor:pointer;-webkit-user-select:none;user-select:none;align-items:center;gap:.6rem;min-height:2.2rem;padding:.45rem .5rem;transition:background .12s;display:flex}.rv-ing-item:hover{background:var(--surface-2)}.rv-ing-item.highlighted{background:var(--accent-2);border-left:2.5px solid var(--accent);border-radius:0 var(--r-sm) var(--r-sm) 0;padding-left:calc(.5rem - 2.5px)}.rv-ing-item.highlighted .rv-ing-amount{background:var(--accent-3)}.rv-ing-check{border:1.5px solid var(--border-2);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:16px;height:16px;transition:background .15s,border-color .15s;display:flex}.rv-ing-item.checked .rv-ing-check{background:var(--accent);border-color:var(--accent)}.rv-ing-item.checked .rv-ing-check:after{content:"";border:1.5px solid #fff;border-top:none;border-left:none;width:4px;height:7px;transform:rotate(45deg)translate(-1px,-1px)}.rv-ing-amount{background:var(--accent-2);color:var(--accent);border-radius:var(--r-xs);white-space:nowrap;text-align:center;font-variant-numeric:tabular-nums;flex-shrink:0;min-width:3rem;padding:.15rem .5rem;font-size:.78rem;font-weight:600;transition:background .15s;display:inline-block}.rv-ing-item:hover .rv-ing-amount{background:var(--accent-3)}.rv-ing-name{color:var(--text);font-size:.9rem;line-height:1.3;transition:color .2s}.rv-ing-note{color:var(--text-3);font-size:.82em;font-style:italic}.rv-ing-item.checked{opacity:.42}.rv-ing-item.checked .rv-ing-name{text-decoration:line-through;-webkit-text-decoration-color:var(--text-3);text-decoration-color:var(--text-3)}.rv-steps{flex-direction:column;gap:.4rem;list-style:none;display:flex}.rv-step{border-radius:var(--r-md);cursor:pointer;border-left:3px solid #0000;align-items:flex-start;gap:1.1rem;padding:1.1rem 1rem;transition:background .15s,border-color .15s;display:flex}.rv-step:hover{background:var(--surface-2)}.rv-step.active{background:var(--accent-2);border-left-color:var(--accent)}.rv-step-num{background:var(--surface-3);width:26px;height:26px;color:var(--text-3);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;margin-top:.15rem;font-size:.72rem;font-weight:700;transition:background .15s,color .15s;display:flex}.rv-step:hover .rv-step-num{background:var(--surface-3);color:var(--text-2)}.rv-step.active .rv-step-num{background:var(--accent);color:#fff}.rv-step-text{color:var(--text);font-size:.975rem;line-height:1.7}.rv-scale-notice{color:var(--text-3);background:var(--surface-2);border-left:3px solid var(--border-2);border-radius:0 var(--r-sm) var(--r-sm) 0;margin-bottom:1.25rem;padding:.5rem .75rem;font-size:.78rem;line-height:1.5}.rv-step-heading{font-family:var(--serif);color:var(--text);letter-spacing:-.01em;cursor:default;border-top:1px solid var(--border);margin-top:.25rem;padding:1.25rem 1rem .35rem;font-size:1rem;font-weight:600;list-style:none}.rv-steps>.rv-step-heading:first-child{border-top:none;margin-top:0;padding-top:0}.rv-warning{color:#92400e;border-radius:var(--r-sm);background:#fffbeb;border:1px solid #fde68a;margin-top:2rem;padding:.65rem 1rem;font-size:.82rem}.settings-btn{z-index:200;border:1.5px solid var(--border);background:var(--surface);width:36px;height:36px;color:var(--text-3);cursor:pointer;box-shadow:var(--shadow-sm);border-radius:50%;justify-content:center;align-items:center;font-size:1rem;transition:color .15s,border-color .15s,background .15s;display:flex;position:fixed;top:1rem;right:1rem}.settings-btn:hover{color:var(--accent);border-color:var(--accent);background:var(--accent-2)}.vgate-backdrop{z-index:400;background:#00000073;animation:.15s fade-in;position:fixed;inset:0}.vgate-modal{z-index:500;background:var(--surface);border:1px solid var(--border);border-radius:var(--r-xl);box-shadow:var(--shadow-md);text-align:center;width:min(380px,90vw);padding:2.5rem 2rem 2rem;animation:.2s cubic-bezier(.34,1.56,.64,1) vgate-in;position:fixed;top:50%;left:50%;transform:translate(-50%,-50%)}@keyframes vgate-in{0%{opacity:0;transform:translate(-50%,-46%)}to{opacity:1;transform:translate(-50%,-50%)}}.vgate-close{color:var(--text-3);cursor:pointer;background:0 0;border:none;padding:.25rem;font-size:1rem;line-height:1;position:absolute;top:1rem;right:1rem}.vgate-close:hover{color:var(--text)}.vgate-icon{color:var(--accent);margin-bottom:.75rem;font-size:2rem}.vgate-title{font-family:var(--serif);color:var(--text);margin-bottom:.75rem;font-size:1.3rem;font-weight:700}.vgate-body{color:var(--text-2);margin-bottom:.5rem;font-size:.9rem;line-height:1.5}.vgate-coming-soon{color:var(--text-3);margin-bottom:1.75rem;font-size:.78rem;line-height:1.5}.vgate-btn{background:var(--accent);color:#fff;border-radius:var(--r-md);cursor:pointer;border:none;width:100%;padding:.75rem;font-size:.95rem;font-weight:600;transition:background .15s!important}.vgate-btn:hover{background:var(--accent-dark)}.settings-backdrop{z-index:300;background:#0000004d;animation:.15s fade-in;position:fixed;inset:0}@keyframes fade-in{0%{opacity:0}to{opacity:1}}.settings-drawer{background:var(--surface);border-left:1px solid var(--border);width:min(320px,90vw);box-shadow:var(--shadow-md);z-index:400;flex-direction:column;transition:transform .25s cubic-bezier(.4,0,.2,1);display:flex;position:fixed;top:0;bottom:0;right:0;overflow-y:auto;transform:translate(100%)}.settings-drawer.open{transform:translate(0)}.settings-header{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:1.25rem 1.25rem 1rem;display:flex}.settings-title{text-transform:uppercase;letter-spacing:.1em;color:var(--text-3);font-size:.8rem;font-weight:700}.settings-close{color:var(--text-3);cursor:pointer;background:0 0;border:none;padding:.2rem;font-size:1rem;line-height:1;transition:color .15s}.settings-close:hover{color:var(--text)}.settings-section{padding:1.25rem 1.25rem 0}.settings-section:last-child{padding-bottom:1.25rem}.settings-label{text-transform:uppercase;letter-spacing:.1em;color:var(--text-3);margin-bottom:.75rem;font-size:.72rem;font-weight:700}.settings-seg{background:var(--surface-2);border-radius:var(--r-pill);gap:2px;padding:3px;display:flex}.settings-seg-btn{border-radius:var(--r-pill);color:var(--text-2);cursor:pointer;background:0 0;border:none;flex:1;padding:.3rem .75rem;font-size:.82rem;font-weight:600;transition:background .15s,color .15s,box-shadow .15s}.settings-seg-btn.active{background:var(--surface);color:var(--accent);box-shadow:var(--shadow-sm)}.settings-swatches{gap:.6rem;margin-bottom:.5rem;display:flex}.settings-swatch{cursor:pointer;border:2.5px solid #0000;border-radius:50%;outline:none;width:28px;height:28px;transition:transform .15s,box-shadow .15s}.settings-swatch:hover{transform:scale(1.15)}.settings-swatch.active{box-shadow:0 0 0 2px var(--surface), 0 0 0 4px var(--accent)}.settings-swatch-label{color:var(--text-3);min-height:1rem;font-size:.75rem}.settings-row{cursor:pointer;justify-content:space-between;align-items:center;gap:1rem;display:flex}.settings-row-text{flex-direction:column;gap:.2rem;display:flex}.settings-row-text span:first-child{color:var(--text);font-size:.9rem;font-weight:500}.settings-row-hint{color:var(--text-3);font-size:.75rem}.settings-toggle{border-radius:var(--r-pill);background:var(--border-2);cursor:pointer;flex-shrink:0;width:42px;height:24px;transition:background .2s;position:relative}.settings-toggle:after{content:"";width:18px;height:18px;box-shadow:var(--shadow-xs);background:#fff;border-radius:50%;transition:transform .2s;position:absolute;top:3px;left:3px}.settings-toggle.on{background:var(--accent)}.settings-toggle.on:after{transform:translate(18px)}
