*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--green: #1D9E75;--green-dark: #0F6E56;--green-light: #E1F5EE;--green-mid: #9FE1CB;--amber: #BA7517;--amber-light: #FAEEDA;--red: #A32D2D;--red-light: #FCEBEB;--gray-50: #F7F6F3;--gray-100: #EDEBE6;--gray-300: #C4C2B8;--gray-500: #888780;--gray-700: #444441;--gray-900: #1A1A19;--white: #FFFFFF;--radius-sm: 6px;--radius-md: 10px;--radius-lg: 16px;--radius-xl: 24px;--shadow-sm: 0 1px 3px rgba(0,0,0,.06);--shadow-md: 0 4px 12px rgba(0,0,0,.08);--font-display: "Fraunces", Georgia, serif;--font-body: "DM Sans", system-ui, sans-serif;--nav-height: 60px}html{scroll-behavior:smooth}body{font-family:var(--font-body);background:var(--gray-50);color:var(--gray-900);min-height:100vh;line-height:1.6;-webkit-font-smoothing:antialiased}.nav{position:sticky;top:0;z-index:100;height:var(--nav-height);background:var(--white);border-bottom:1px solid var(--gray-100);display:flex;align-items:center;justify-content:space-between;padding:0 1.5rem;box-shadow:var(--shadow-sm)}.nav-logo{font-family:var(--font-display);font-size:1.25rem;color:var(--green-dark);text-decoration:none;display:flex;align-items:center;gap:8px}.nav-logo .leaf{font-size:1rem}.nav-links{display:flex;gap:4px}.nav-link{padding:6px 12px;border-radius:var(--radius-sm);font-size:.875rem;font-weight:500;color:var(--gray-700);text-decoration:none;transition:background .15s,color .15s}.nav-link:hover{background:var(--gray-100);color:var(--gray-900)}.nav-link.active{background:var(--green-light);color:var(--green-dark)}.page{max-width:900px;margin:0 auto;padding:2rem 1.5rem 4rem}.page-wide{max-width:1100px;margin:0 auto;padding:2rem 1.5rem 4rem}.page-header{margin-bottom:2rem}.page-header h1{font-family:var(--font-display);font-size:2rem;font-weight:500;color:var(--gray-900);line-height:1.2}.page-header p{color:var(--gray-500);margin-top:6px;font-size:.9375rem}.card{background:var(--white);border-radius:var(--radius-lg);border:1px solid var(--gray-100);box-shadow:var(--shadow-sm);overflow:hidden}.card-padded{padding:1.5rem}.badge{display:inline-flex;align-items:center;font-size:.75rem;font-weight:500;padding:3px 9px;border-radius:20px}.badge-green{background:var(--green-light);color:var(--green-dark)}.badge-amber{background:var(--amber-light);color:var(--amber)}.badge-red{background:var(--red-light);color:var(--red)}.badge-gray{background:var(--gray-100);color:var(--gray-700)}.btn{display:inline-flex;align-items:center;gap:6px;padding:9px 18px;border-radius:var(--radius-md);font-family:var(--font-body);font-size:.875rem;font-weight:500;cursor:pointer;border:none;transition:all .15s;text-decoration:none}.btn-primary{background:var(--green);color:var(--white)}.btn-primary:hover{background:var(--green-dark)}.btn-secondary{background:var(--white);color:var(--gray-700);border:1px solid var(--gray-300)}.btn-secondary:hover{background:var(--gray-50)}.btn-ghost{background:transparent;color:var(--gray-500)}.btn-ghost:hover{color:var(--gray-900);background:var(--gray-100)}.btn-sm{padding:5px 12px;font-size:.8125rem}.btn-danger{background:var(--red-light);color:var(--red)}.btn-danger:hover{background:#f7c1c1}input[type=text],input[type=search],select,textarea{font-family:var(--font-body);font-size:.9375rem;padding:9px 12px;border:1px solid var(--gray-300);border-radius:var(--radius-md);background:var(--white);color:var(--gray-900);outline:none;transition:border-color .15s;width:100%}input:focus,select:focus,textarea:focus{border-color:var(--green)}.divider{height:1px;background:var(--gray-100);margin:1.25rem 0}.flex{display:flex}.flex-center{display:flex;align-items:center}.flex-between{display:flex;align-items:center;justify-content:space-between}.gap-2{gap:.5rem}.gap-3{gap:.75rem}.gap-4{gap:1rem}.mt-1{margin-top:.25rem}.mt-2{margin-top:.5rem}.mt-3{margin-top:.75rem}.mt-4{margin-top:1rem}.muted{color:var(--gray-500);font-size:.875rem}.strong{font-weight:500}.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:1rem}@media (max-width: 640px){.grid-2{grid-template-columns:1fr}}.loading{display:flex;align-items:center;justify-content:center;min-height:200px;color:var(--gray-500);font-size:.9375rem}.empty{text-align:center;padding:3rem 1rem;color:var(--gray-500)}.empty h3{font-family:var(--font-display);font-size:1.25rem;font-weight:400;color:var(--gray-700);margin-bottom:6px}.ingredient-list{list-style:none}.ingredient-list li{display:flex;gap:10px;padding:7px 0;border-bottom:1px solid var(--gray-100);font-size:.9375rem;line-height:1.4}.ingredient-list li:last-child{border-bottom:none}.ingredient-amt{color:var(--green-dark);font-weight:500;min-width:60px;flex-shrink:0}.ingredient-sep{color:var(--gray-300)}.step-list{list-style:none;counter-reset:steps}.step-list li{counter-increment:steps;display:grid;grid-template-columns:28px 1fr;gap:12px;padding:10px 0;border-bottom:1px solid var(--gray-100);font-size:.9375rem;line-height:1.6}.step-list li:last-child{border-bottom:none}.step-list li:before{content:counter(steps);width:26px;height:26px;background:var(--green-light);color:var(--green-dark);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.75rem;font-weight:500;flex-shrink:0}.tip-box{background:var(--green-light);border-radius:var(--radius-md);padding:12px 16px;font-size:.875rem;color:var(--green-dark)}.tip-box strong{font-weight:500}.kids-box{background:#fff8e1;border-radius:var(--radius-md);padding:12px 16px;font-size:.875rem;color:#7b5e00;margin-top:8px}.warn-box{background:var(--amber-light);border-radius:var(--radius-md);padding:12px 16px;font-size:.875rem;color:var(--amber)}.warn-box strong{font-weight:500}.section-label{font-size:.75rem;font-weight:500;letter-spacing:.06em;text-transform:uppercase;color:var(--gray-500);margin-bottom:12px}@media (max-width: 600px){.nav-links{gap:2px}.nav-link{padding:5px 8px;font-size:.8125rem}.page,.page-wide{padding:1.25rem 1rem 4rem}.page-header h1{font-size:1.625rem}}
