:root{--color-bg: #EAE4D9;--color-surface: #F5F1E9;--color-surface-alt: #EDE8DE;--color-nav: #1A2A1A;--color-nav-border: #243324;--color-ink: #1C1C14;--color-muted: #7A7060;--color-faint: #C4BCAD;--color-border: #D4CBBA;--color-primary: #B8722A;--color-primary-dark: #9E5E1E;--color-primary-pale: #F5E8D5;--color-danger: #A83228;--color-success: #3D6B42;--font-display: "Cormorant Garamond", Georgia, serif;--font-ui: "DM Sans", system-ui, -apple-system, sans-serif;--space-xs: 4px;--space-sm: 8px;--space-md: 16px;--space-lg: 24px;--space-xl: 36px;--space-2xl: 52px;--radius-sm: 6px;--radius-md: 12px;--radius-lg: 18px;--radius-full: 9999px;--shadow-sm: 0 1px 4px rgba(30,20,10,.08);--shadow-md: 0 4px 16px rgba(30,20,10,.11);--shadow-lg: 0 10px 32px rgba(30,20,10,.14);--shadow-card: 0 2px 8px rgba(30,20,10,.09), 0 0 1px rgba(30,20,10,.06);--nav-height: 66px}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;-webkit-text-size-adjust:100%;scroll-behavior:smooth}body{font-family:var(--font-ui);font-weight:400;background-color:var(--color-bg);color:var(--color-ink);line-height:1.6;min-height:100vh;min-height:-webkit-fill-available;overflow-x:hidden;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='300' height='300'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.75' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='300' height='300' filter='url(%23n)' opacity='0.04'/%3E%3C/svg%3E")}img{max-width:100%;height:auto;display:block}a{color:inherit;text-decoration:none}button{cursor:pointer;font-family:var(--font-ui);font-size:inherit}input,select,textarea{font-family:var(--font-ui);font-size:16px}#app{max-width:640px;margin:0 auto;min-height:100vh;position:relative}.page{padding:var(--space-md);padding-bottom:calc(var(--nav-height) + var(--space-xl) + env(safe-area-inset-bottom));min-height:100vh}.page-header{display:flex;align-items:baseline;justify-content:space-between;margin-bottom:var(--space-lg);padding-top:var(--space-sm)}.page-title{font-family:var(--font-display);font-size:2.2rem;font-weight:600;line-height:1.1;letter-spacing:-.01em;color:var(--color-ink)}.bottom-nav{position:fixed;bottom:0;left:50%;transform:translate(-50%);width:100%;max-width:640px;height:calc(var(--nav-height) + env(safe-area-inset-bottom));background:var(--color-nav);border-top:1px solid var(--color-nav-border);display:flex;align-items:flex-start;justify-content:space-around;padding-top:10px;padding-bottom:env(safe-area-inset-bottom);z-index:100}.nav-item{display:flex;flex-direction:column;align-items:center;gap:3px;padding:4px 16px;min-width:64px;min-height:44px;border:none;background:none;color:#f0e8d273;font-family:var(--font-ui);font-size:.62rem;font-weight:500;letter-spacing:.04em;text-transform:uppercase;transition:color .15s ease;-webkit-tap-highlight-color:transparent;text-decoration:none}.nav-item:active{opacity:.7}.nav-item.active{color:#c9a96e}.nav-item svg{width:22px;height:22px;stroke-width:1.75}.recipe-list{display:flex;flex-direction:column;gap:var(--space-md)}.recipe-grid{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-md)}.recipe-card{display:grid;grid-template-columns:1fr;border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-card);background:var(--color-nav);text-decoration:none;color:inherit;transition:transform .18s ease,box-shadow .18s ease;-webkit-tap-highlight-color:transparent;min-height:200px}.recipe-card:active{transform:scale(.985);box-shadow:var(--shadow-sm)}.recipe-card-image{grid-row:1;grid-column:1;width:100%;height:200px;object-fit:cover;display:block}.recipe-card-image-placeholder{grid-row:1;grid-column:1;width:100%;height:200px;display:flex;align-items:center;justify-content:center;font-size:3.5rem;background:linear-gradient(140deg,#2a3d2a,#1a2a1a)}.recipe-card-body{grid-row:1;grid-column:1;align-self:end;z-index:1;padding:48px var(--space-md) var(--space-md);background:linear-gradient(to top,rgba(18,24,18,.95) 0%,rgba(18,24,18,.75) 50%,transparent 100%)}.recipe-card-title{font-family:var(--font-display);font-size:1.3rem;font-weight:600;line-height:1.2;color:#f0ead8;margin-bottom:5px;letter-spacing:.01em}.recipe-card-meta{display:flex;align-items:center;gap:var(--space-sm);flex-wrap:wrap;font-size:.75rem;color:#dcd0b4b3}.recipe-card-category{background:#b8722a59;color:#c9a96e;border:1px solid rgba(201,169,110,.3);padding:2px 8px;border-radius:var(--radius-full);font-size:.7rem;font-weight:500;letter-spacing:.03em;text-transform:uppercase}.card{background:var(--color-surface);border-radius:var(--radius-lg);border:1px solid var(--color-border);overflow:hidden;box-shadow:var(--shadow-sm)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-sm);padding:12px 22px;border-radius:var(--radius-md);font-family:var(--font-ui);font-size:.9rem;font-weight:500;letter-spacing:.02em;border:none;cursor:pointer;min-height:44px;transition:opacity .15s,transform .1s,background .15s;-webkit-tap-highlight-color:transparent;white-space:nowrap}.btn:active{transform:scale(.97);opacity:.85}.btn:disabled{opacity:.45;cursor:not-allowed}.btn-primary{background:var(--color-primary);color:#fff8ee}.btn-primary:hover{background:var(--color-primary-dark)}.btn-secondary{background:var(--color-primary-pale);color:var(--color-primary-dark);border:1px solid rgba(184,114,42,.25)}.btn-ghost{background:transparent;color:var(--color-ink);border:1px solid var(--color-border)}.btn-ghost:hover{background:var(--color-surface-alt)}.btn-danger{background:var(--color-danger);color:#fff}.btn-dark{background:var(--color-nav);color:#f0ead8}.btn-sm{padding:7px 14px;font-size:.8rem;min-height:34px;border-radius:var(--radius-sm)}.btn-full{width:100%}.btn-icon{padding:10px;border-radius:var(--radius-full);min-width:44px;min-height:44px}.fab{position:fixed;bottom:calc(var(--nav-height) + var(--space-md) + env(safe-area-inset-bottom));right:var(--space-md);width:54px;height:54px;border-radius:var(--radius-full);background:var(--color-nav);color:#c9a96e;border:none;box-shadow:var(--shadow-lg),0 0 0 1px #c9a96e33;display:flex;align-items:center;justify-content:center;font-size:1.5rem;cursor:pointer;z-index:50;transition:transform .15s,box-shadow .15s;-webkit-tap-highlight-color:transparent;text-decoration:none}.fab:active{transform:scale(.93);box-shadow:var(--shadow-md)}.form-group{display:flex;flex-direction:column;gap:6px;margin-bottom:var(--space-md)}.form-label{font-size:.8rem;font-weight:600;letter-spacing:.05em;text-transform:uppercase;color:var(--color-muted)}.form-hint{font-size:.75rem;color:var(--color-faint)}.input,.select,.textarea{width:100%;padding:12px 14px;border:1.5px solid var(--color-border);border-radius:var(--radius-md);font-family:var(--font-ui);font-size:16px;color:var(--color-ink);background:var(--color-surface);transition:border-color .15s,box-shadow .15s;-moz-appearance:none;appearance:none;-webkit-appearance:none;min-height:44px}.input:focus,.select:focus,.textarea:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px #b8722a1f}.input::placeholder,.textarea::placeholder{color:var(--color-faint)}.textarea{resize:vertical;min-height:100px;line-height:1.6}.select{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%237A7060' stroke-width='2'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center;padding-right:40px}.checkbox-row{display:flex;align-items:flex-start;gap:var(--space-sm);padding:var(--space-sm) 0;cursor:pointer}.checkbox-row input[type=checkbox]{width:20px;height:20px;min-width:20px;accent-color:var(--color-primary);cursor:pointer;margin-top:2px}.badge{display:inline-flex;align-items:center;padding:3px 10px;border-radius:var(--radius-full);font-size:.7rem;font-weight:500;letter-spacing:.04em;text-transform:uppercase;background:var(--color-surface-alt);color:var(--color-muted);border:1px solid var(--color-border)}.badge-primary{background:var(--color-primary-pale);color:var(--color-primary-dark);border-color:#b8722a40}.chips{display:flex;gap:var(--space-sm);overflow-x:auto;padding-bottom:var(--space-xs);scrollbar-width:none;-ms-overflow-style:none}.chips::-webkit-scrollbar{display:none}.chip{display:inline-flex;align-items:center;padding:7px 15px;border-radius:var(--radius-full);font-size:.8rem;font-weight:500;white-space:nowrap;border:1.5px solid var(--color-border);background:var(--color-surface);color:var(--color-muted);cursor:pointer;transition:all .15s;min-height:36px;-webkit-tap-highlight-color:transparent;letter-spacing:.01em}.chip.active{background:var(--color-nav);color:#c9a96e;border-color:var(--color-nav)}.chip:active{transform:scale(.96)}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:var(--space-xl) var(--space-md);gap:var(--space-md)}.empty-state-icon{font-size:3.5rem;line-height:1;opacity:.6}.empty-state-title{font-family:var(--font-display);font-size:1.5rem;font-weight:600;color:var(--color-ink)}.empty-state-text{color:var(--color-muted);font-size:.9rem;max-width:260px;line-height:1.6}.divider{height:1px;background:var(--color-border);margin:var(--space-md) 0}.spinner{width:22px;height:22px;border:2.5px solid var(--color-border);border-top-color:var(--color-primary);border-radius:50%;animation:spin .7s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.loading-center{display:flex;justify-content:center;padding:var(--space-xl)}.alert{padding:var(--space-md);border-radius:var(--radius-md);font-size:.875rem;line-height:1.5}.alert-error{background:#faf0ee;color:#7a2420;border:1px solid #E8C4BE}.alert-success{background:#eff6f0;color:#2d5430;border:1px solid #B8D8BB}.alert-info{background:var(--color-primary-pale);color:var(--color-primary-dark);border:1px solid rgba(184,114,42,.25)}.section-title{font-family:var(--font-display);font-size:1.15rem;font-weight:600;color:var(--color-ink);margin-bottom:var(--space-sm);letter-spacing:.01em}.row-with-remove{display:flex;gap:var(--space-sm);align-items:flex-start}.row-with-remove .input,.row-with-remove .select{flex:1}.btn-remove{min-width:44px;min-height:44px;border:none;background:none;color:var(--color-faint);cursor:pointer;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-md);padding:0;flex-shrink:0;transition:color .15s,background .15s}.btn-remove:hover{background:#faf0ee;color:var(--color-danger)}.cook-mode{background:var(--color-nav);min-height:100vh;color:#f0ead8}.cook-step{font-family:var(--font-display);font-size:1.35rem;line-height:1.7;font-weight:400;padding:var(--space-xl) var(--space-md)}.upload-area{border:2px dashed var(--color-border);border-radius:var(--radius-lg);padding:var(--space-xl) var(--space-md);text-align:center;cursor:pointer;transition:border-color .2s,background .2s;color:var(--color-muted);background:var(--color-surface)}.upload-area:hover,.upload-area.drag-over{border-color:var(--color-primary);background:var(--color-primary-pale);color:var(--color-primary-dark)}.tabs{display:flex;border-bottom:1.5px solid var(--color-border);gap:0;overflow-x:auto;scrollbar-width:none}.tabs::-webkit-scrollbar{display:none}.tab{padding:10px 16px;border:none;background:none;font-family:var(--font-ui);font-size:.85rem;font-weight:500;color:var(--color-muted);cursor:pointer;white-space:nowrap;border-bottom:2px solid transparent;margin-bottom:-1.5px;transition:color .15s,border-color .15s;min-height:44px;letter-spacing:.01em}.tab.active{color:var(--color-ink);border-bottom-color:var(--color-primary)}.nutrition-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--space-sm);text-align:center}.nutrition-item{background:var(--color-surface-alt);border-radius:var(--radius-md);padding:var(--space-sm) var(--space-xs);border:1px solid var(--color-border)}.nutrition-value{font-family:var(--font-display);font-size:1.3rem;font-weight:600;color:var(--color-primary);line-height:1.1}.nutrition-label{font-size:.65rem;letter-spacing:.05em;text-transform:uppercase;color:var(--color-muted);margin-top:3px}.serving-scaler{display:flex;align-items:center;gap:var(--space-md);background:var(--color-surface-alt);border-radius:var(--radius-md);padding:var(--space-sm) var(--space-md);border:1px solid var(--color-border)}.serving-scaler button{width:36px;height:36px;border-radius:50%;border:1.5px solid var(--color-border);background:var(--color-surface);font-size:1.25rem;display:flex;align-items:center;justify-content:center;cursor:pointer;flex-shrink:0;-webkit-tap-highlight-color:transparent;color:var(--color-ink);transition:background .15s,border-color .15s}.serving-scaler button:active{background:var(--color-primary-pale);border-color:var(--color-primary)}.serving-scaler .serving-count{font-family:var(--font-display);font-size:1.4rem;font-weight:600;min-width:60px;text-align:center;color:var(--color-ink)}.stars{display:flex;gap:3px}.star{font-size:1.2rem;cursor:pointer;color:var(--color-border);transition:color .1s,transform .1s;-webkit-tap-highlight-color:transparent}.star.filled{color:#c9a96e}.star:active{transform:scale(1.2)}
