:root{--bg:#f4ede3;--surface:#faf6f0;--fg:#2c2518;--muted:#9e9484;--border:#d8cfc0;--accent:#b8860b;--accent-dim:#b8860b14;--font-display:Georgia, "Times New Roman", serif;--font-body:-apple-system, BlinkMacSystemFont, "Segoe UI", system-ui, sans-serif}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html,body{height:100%}body{font-family:var(--font-body);background:var(--bg);color:var(--fg);-webkit-font-smoothing:antialiased;overflow-x:hidden}canvas#dots{z-index:0;pointer-events:none;width:100%;height:100%;position:fixed;inset:0}a{color:var(--accent);border-bottom:1px solid #0000;text-decoration:none;transition:border-color .2s}a:hover{border-bottom-color:currentColor}.btn{font-family:var(--font-body);cursor:pointer;white-space:nowrap;border:1px solid #0000;border-radius:6px;flex-shrink:0;align-items:center;gap:.375rem;padding:.5rem 1rem;font-size:.8125rem;font-weight:500;transition:opacity .2s,transform .1s;display:inline-flex}.btn:hover{opacity:.9}.btn:active{transform:scale(.97)}.btn svg{width:14px;height:14px}.btn-primary{color:#fffdf8;background:var(--accent)}.btn-ghost{color:var(--fg);border-color:var(--border);background:0 0}.btn-ghost:hover{background:var(--accent-dim);color:var(--accent);border-color:var(--accent)}.btn-danger{color:#fffdf8;background:#c0392b;border-color:#c0392b}.icon-btn{border:1px solid var(--border);width:34px;height:34px;color:var(--muted);cursor:pointer;background:0 0;border-radius:6px;flex-shrink:0;justify-content:center;align-items:center;transition:opacity .2s,transform .1s;display:flex}.icon-btn:hover{opacity:.75}.icon-btn:active{transform:scale(.93)}.icon-btn svg{width:16px;height:16px}.tag{letter-spacing:.04em;text-transform:uppercase;background:var(--accent-dim);color:var(--accent);cursor:pointer;-webkit-user-select:none;user-select:none;border-radius:3px;align-items:center;gap:.25rem;padding:.1875rem .5rem;font-size:.625rem;font-weight:500;transition:background .15s,color .15s;display:inline-flex}.tag:hover{background:var(--accent);color:#fffdf8}.tag.hidden-tag{display:none}.tag-expand-btn,.tag-collapse-btn{width:20px;height:20px;color:var(--muted);cursor:pointer;background:0 0;border:none;border-radius:3px;justify-content:center;align-items:center;padding:0;font-size:.75rem;line-height:1;transition:color .15s,background .15s;display:none}.tag-expand-btn:hover,.tag-collapse-btn:hover{color:var(--accent);background:var(--accent-dim)}.tags.has-more .tag-expand-btn{display:inline-flex}.tags.expanded .tag-expand-btn{display:none}.tags.expanded .tag-collapse-btn{display:inline-flex}.tags.expanded .tag.hidden-tag{display:inline-block}.search-input{min-width:0;font-family:var(--font-body);border:1px solid var(--border);background:var(--surface);color:var(--fg);border-radius:6px;outline:none;flex:1;padding:.5rem 4.5rem .5rem 2.375rem;font-size:.875rem;transition:border-color .2s,box-shadow .2s}.search-input::placeholder{color:var(--muted);opacity:.7}.search-input:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-dim)}.search-tag{letter-spacing:.02em;background:var(--accent-dim);color:var(--accent);border-radius:4px;align-items:center;gap:.25rem;padding:.1875rem .5rem;font-size:.6875rem;font-weight:500;animation:.2s tagIn;display:inline-flex}@keyframes tagIn{0%{opacity:0;transform:scale(.9)}to{opacity:1;transform:scale(1)}}.search-tag .remove-tag{width:14px;height:14px;color:var(--accent);cursor:pointer;opacity:.6;background:0 0;border:none;border-radius:50%;justify-content:center;align-items:center;margin-left:.125rem;font-size:.75rem;line-height:1;transition:opacity .15s;display:inline-flex}.search-tag .remove-tag:hover{opacity:1}.clear-tags-btn{letter-spacing:.02em;color:var(--muted);cursor:pointer;border:1px dashed var(--border);background:0 0;border-radius:4px;align-items:center;gap:.25rem;padding:.1875rem .5rem;font-size:.6875rem;font-weight:500;transition:color .15s,border-color .15s;display:inline-flex}.clear-tags-btn:hover{color:var(--accent);border-color:var(--accent)}.modal-backdrop{z-index:100;-webkit-backdrop-filter:blur(8px);background:#2c25184d;justify-content:center;align-items:center;animation:.2s fadeIn;display:none;position:fixed;inset:0}.modal-backdrop.open{display:flex}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal-card{background:var(--surface);border:1px solid var(--border);border-radius:12px;width:calc(100% - 2rem);max-width:380px;padding:2rem;animation:.25s modalIn;box-shadow:0 20px 60px #2c251826}@keyframes modalIn{0%{opacity:0;transform:scale(.95)translateY(8px)}to{opacity:1;transform:scale(1)translateY(0)}}.modal-title{font-family:var(--font-display);color:var(--fg);margin-bottom:.5rem;font-size:1.25rem}.modal-body{color:var(--muted);margin-bottom:1.5rem;font-size:.875rem;line-height:1.5}.modal-actions{justify-content:flex-end;align-items:center;gap:.75rem;display:flex}.modal-cancel,.modal-confirm{font-family:var(--font-body);cursor:pointer;border-radius:6px;min-width:90px;padding:.5rem 1.25rem;font-size:.8125rem;font-weight:500;line-height:1;transition:background .15s,color .15s}.modal-cancel{border:1px solid var(--border);color:var(--fg);background:0 0}.modal-cancel:hover{background:var(--bg)}.modal-confirm{color:#fffdf8;background:#c0392b;border:none}.modal-confirm:hover{opacity:.9}.modal-actions .submit-btn{color:#fffdf8;background:var(--accent);cursor:pointer;border:none;border-radius:6px;width:auto;min-width:90px;margin:0;padding:.5rem 1.25rem;font-size:.8125rem;font-weight:500;line-height:1;transition:opacity .2s,transform .1s}.modal-actions .submit-btn:hover{opacity:.9}.modal-actions .submit-btn:active{transform:scale(.985)}.modal-actions .submit-btn:disabled{opacity:.5;cursor:not-allowed;background:var(--accent)}.modal-actions .submit-btn:disabled:after{content:""}.modal-actions .submit-btn.valid{background:#2da44e;border-color:#2da44e}.modal-actions .submit-btn.valid:after{content:" ✓"}.modal-action-btn{background:var(--accent);border:1px solid var(--accent);color:#fffdf8;font-family:var(--font-body);cursor:pointer;border-radius:6px;padding:.5rem 1.25rem;font-size:.8125rem;font-weight:500;transition:opacity .15s}.modal-action-btn:hover{opacity:.85}.macro{color:var(--muted);align-items:center;gap:.25rem;font-size:.6875rem;display:flex}.macro strong{color:var(--fg);font-variant-numeric:tabular-nums;font-weight:600}.section-divider{align-items:center;gap:1rem;margin:2rem 0 1.25rem;display:flex}.section-divider:after{content:"";background:var(--border);flex:1;height:1px}.section-heading{font-family:var(--font-display);white-space:nowrap;font-size:1.25rem;font-weight:400}.recipe-card{background:var(--surface);border:1px solid var(--border);cursor:default;border-radius:8px;grid-template-columns:minmax(250px,50%) 1fr;gap:0;min-height:140px;margin-bottom:1rem;padding:0;transition:box-shadow .2s,transform .15s,height .25s;display:grid;overflow:hidden}.recipe-card:hover{border-color:var(--accent);transform:translateY(-1px);box-shadow:0 4px 20px #2c25180f}.card-image-link{border-bottom:none!important}.card-image{background:linear-gradient(135deg, var(--border) 0%, #e8dfd4 100%);width:100%;height:100%;min-height:0;color:var(--muted);letter-spacing:.04em;text-transform:uppercase;justify-content:center;align-self:stretch;align-items:center;font-size:.6875rem;display:flex;position:relative;overflow:hidden}.card-image:after{content:"";background:linear-gradient(to right, transparent 0%, var(--surface) 100%);pointer-events:none;width:60%;position:absolute;top:0;bottom:0;right:0}.card-image img{object-fit:cover;width:100%;height:100%;position:absolute;inset:0}.card-body{flex-direction:column;gap:.5rem;min-width:0;padding:1rem 1rem 1rem .5rem;display:flex}.card-title{font-family:var(--font-display);color:var(--fg);white-space:nowrap;text-overflow:ellipsis;font-size:1.0625rem;font-weight:400;line-height:1.3;overflow:hidden}.card-meta{color:var(--muted);gap:1rem;font-size:.75rem;display:flex}.card-meta span{align-items:center;gap:.25rem;display:inline-flex}.card-meta svg{opacity:.6;flex-shrink:0;width:13px;height:13px}.recipe-hero{grid-template-columns:1fr 1fr;gap:1.5rem;margin-bottom:2rem;display:grid}.hero-image-wrap{aspect-ratio:1;background:linear-gradient(135deg, var(--border) 0%, #e8dfd4 100%);color:var(--muted);letter-spacing:.06em;text-transform:uppercase;border:1px solid var(--border);cursor:pointer;border-radius:8px;justify-content:center;align-items:center;font-size:.75rem;transition:border-color .2s,box-shadow .2s;display:flex;overflow:hidden}.hero-image-wrap:hover{border-color:var(--accent);box-shadow:0 0 0 1px var(--accent-dim)}.hero-image-wrap img{object-fit:cover;width:100%;height:100%}.hero-info{flex-direction:column;gap:1rem;padding-top:.25rem;display:flex}.recipe-title{font-family:var(--font-display);color:var(--fg);font-size:1.75rem;line-height:1.2}.meta-row{gap:1.25rem;padding-top:.25rem;display:flex}.meta-item{color:var(--muted);align-items:center;gap:.375rem;font-size:.8125rem;display:flex}.meta-item svg{opacity:.6;flex-shrink:0;width:14px;height:14px}.macros-row{grid-template-columns:repeat(4,1fr);gap:.5rem;padding-top:.25rem;display:grid}.macro-card{text-align:center;background:var(--surface);border:1px solid var(--border);border-radius:6px;padding:.625rem .375rem}.macro-value{color:var(--fg);font-variant-numeric:tabular-nums;font-size:1.125rem;font-weight:700;line-height:1.2;display:block}.macro-label{letter-spacing:.04em;text-transform:uppercase;color:var(--muted);margin-top:.1875rem;font-size:.625rem;display:block}.ingredients-list{flex-direction:column;gap:.5rem;list-style:none;display:flex}.ingredients-list li{background:var(--surface);border:1px solid var(--border);border-radius:6px;align-items:baseline;gap:.75rem;padding:.625rem .75rem;font-size:.9375rem;line-height:1.4;display:flex}.instructions-list{counter-reset:step;flex-direction:column;gap:1rem;list-style:none;display:flex}.instruction-step{background:var(--surface);border:1px solid var(--border);cursor:pointer;-webkit-user-select:none;user-select:none;border-radius:6px;grid-template-columns:28px 1fr;gap:.75rem;padding:.75rem;font-size:.9375rem;line-height:1.6;transition:opacity .2s,background .2s,border-color .2s,box-shadow .2s,transform .15s;display:grid}.instruction-step:hover{border-color:var(--accent);transform:translateY(-1px);box-shadow:0 4px 20px #2c25180f}.instruction-step.completed{opacity:.45;background:var(--bg)}.step-num{width:28px;height:28px;color:var(--accent);background:var(--accent-dim);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:.75rem;font-weight:600;transition:background .2s,color .2s;display:flex}.instruction-step.completed .step-num{background:var(--accent);color:#fff}.step-text{min-width:0}.show-more-btn{width:100%;max-width:720px;font-family:var(--font-display);color:var(--accent);border:1px dashed var(--border);cursor:pointer;background:0 0;border-radius:8px;margin:1.5rem auto 0;padding:.875rem 1.5rem;font-size:1rem;transition:color .2s,border-color .2s,background .2s;display:block}.show-more-btn:hover{color:var(--fg);border-color:var(--accent);background:var(--accent-dim)}.field{flex-direction:column;gap:.375rem;margin-bottom:1.25rem;display:flex}.field label{letter-spacing:.04em;text-transform:uppercase;color:var(--muted);font-size:.75rem;font-weight:500}.field input{font-family:var(--font-body);border:1px solid var(--border);color:var(--fg);background:#fffdf8;border-radius:3px;outline:none;padding:.625rem .75rem;font-size:.9375rem;transition:border-color .2s,box-shadow .2s}.field input::placeholder{color:var(--muted);opacity:.6}.field input:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-dim)}.submit-btn{width:100%;font-family:var(--font-body);letter-spacing:.02em;color:#fffdf8;background:var(--accent);cursor:pointer;border:none;border-radius:3px;margin-top:.5rem;padding:.6875rem;font-size:.875rem;font-weight:500;transition:opacity .2s,transform .1s}.submit-btn:hover{opacity:.9}.submit-btn:active{transform:scale(.985)}.submit-btn:disabled{background:var(--accent);cursor:not-allowed;opacity:.5}.submit-btn:disabled:after{content:" ?"}.submit-btn:disabled:hover{opacity:.7}.submit-btn.valid{background:#2da44e}.submit-btn.valid:after{content:" ✓"}.footer-text{text-align:center;color:var(--muted);margin-top:1.5rem;font-size:.75rem}.error-msg{color:#c0392b;margin-top:-.5rem;margin-bottom:.75rem;font-size:.75rem;display:none}.error-msg.visible{display:block}.field-error{color:#c0392b;margin-top:-.25rem;margin-bottom:.5rem;font-size:.6875rem;display:none}.modal-overlay{z-index:100;-webkit-backdrop-filter:blur(8px);background:#2c251859;justify-content:center;align-items:center;display:none;position:fixed;inset:0}.modal-overlay.active{display:flex}.image-modal-card{background:#000;border-radius:8px;max-width:90vw;max-height:90vh;animation:.25s modalIn;position:relative;overflow:hidden}.image-modal-card img{object-fit:contain;max-width:100%;max-height:90vh;display:block}.image-modal-close{color:#fff;cursor:pointer;background:#0009;border:none;border-radius:50%;justify-content:center;align-items:center;width:32px;height:32px;font-size:1.25rem;transition:background .15s;display:flex;position:absolute;top:12px;right:12px}.image-modal-close:hover{background:#000c}.field-error.visible{display:block}.main{z-index:1;max-width:720px;margin:0 auto;padding:1.5rem 1.25rem 4rem;position:relative}.section-label{letter-spacing:.08em;text-transform:uppercase;color:var(--muted);margin-bottom:1rem;padding-left:.25rem;font-size:.6875rem}.topbar{z-index:10;-webkit-backdrop-filter:blur(12px);border-bottom:1px solid var(--border);background:#f4ede3d9;align-items:flex-start;gap:.75rem;padding:.75rem 1.25rem;display:flex;position:sticky;top:0}.topbar-logo,.logo{font-family:var(--font-display);color:var(--fg);white-space:nowrap;flex-shrink:0;align-items:center;height:34px;font-size:1.125rem;text-decoration:none;display:flex}.topbar-logo span,.logo span{color:var(--accent)}.topbar-logo:hover,.logo:hover{border-bottom-color:#0000}.search-wrap{flex:1;grid-template-rows:auto 1fr;align-items:start;min-width:0;display:grid}.search-row{align-items:center;gap:.375rem;min-width:0;display:flex;position:relative}.search-wrap svg.search-icon{width:16px;height:16px;color:var(--muted);pointer-events:none;z-index:1;position:absolute;top:50%;left:.75rem;transform:translateY(-50%)}.search-actions{align-items:center;gap:.125rem;display:flex;position:absolute;top:50%;right:.375rem;transform:translateY(-50%)}.search-btn,.tag-add-btn{width:26px;height:26px;color:var(--muted);cursor:pointer;background:0 0;border:none;border-radius:4px;justify-content:center;align-items:center;padding:0;transition:background .15s,color .15s;display:inline-flex}.search-btn:hover,.tag-add-btn:hover{background:var(--accent-dim);color:var(--accent)}.search-btn svg,.tag-add-btn svg{width:16px;height:16px}.search-hint{color:var(--muted);opacity:.5;letter-spacing:.02em;white-space:nowrap;-webkit-user-select:none;user-select:none;font-size:.5625rem;line-height:1}.search-tags{flex-wrap:wrap;align-content:flex-start;gap:.375rem;min-height:0;display:flex}.topbar-actions{flex-shrink:0;align-items:center;gap:.5rem;display:flex}.topbar-sep{background:var(--border);align-self:center;width:1px;height:24px;margin:0 .25rem}@media (width<=640px){.topbar{gap:.625rem;padding:.625rem .75rem}.logo,.topbar-logo{display:none}.recipe-card{grid-template-columns:100px 1fr;gap:.75rem;padding:.75rem}.main{padding:1rem .75rem 3rem}.show-more-btn{max-width:calc(100% - 1.5rem)}.recipe-hero{grid-template-columns:1fr;gap:1rem}.hero-image-wrap{aspect-ratio:auto;border-radius:8px;max-height:280px}.macros-row{grid-template-columns:repeat(2,1fr)}.recipe-title{font-size:1.375rem}.step-actions,.ingredient-actions{display:inline-flex!important}}
