:root{--bg:#fbf7ef;--surface:#fff;--ink:#2a2620;--ink-mute:#6b5f4d;--line:#d6c9ac;--line-soft:#e8dfcc;--brand:#1f5f47;--brand-deep:#174a36;--brand-soft:#eaf3ee;--warm:#f2e7cc;--warm-ink:#6b4a1e;--gold:#c99a2e;--eyebrow:#8a6e3a;--radius:14px;--radius-lg:18px}*{box-sizing:border-box}body,html{margin:0;padding:0;background:var(--bg);color:var(--ink);font-family:Inter,system-ui,sans-serif;-webkit-font-smoothing:antialiased}body{min-height:100dvh}.serif{font-family:Fraunces,Georgia,serif;font-weight:500;letter-spacing:-.01em}.eyebrow{font-size:11px;font-weight:600;letter-spacing:.12em;text-transform:uppercase;color:var(--eyebrow)}.muted{color:var(--ink-mute)}.page{max-width:1100px;margin:0 auto;padding:16px 18px 80px}@media (min-width:720px){.page{padding:24px 28px 80px}}.header{display:flex;align-items:center;justify-content:space-between;padding-bottom:14px;border-bottom:.5px solid var(--line);margin-bottom:20px;gap:12px;flex-wrap:wrap}.brand{display:flex;align-items:baseline;gap:10px}.brand .name{font-family:Fraunces,Georgia,serif;font-weight:500;font-size:24px;color:var(--brand)}.brand .tag{font-size:12px;color:var(--ink-mute)}.profile-switch{display:flex;gap:6px}.avatar{width:34px;height:34px;border-radius:50%;display:inline-flex;align-items:center;justify-content:center;font-size:13px;font-weight:600;color:var(--bg);border:2px solid var(--bg);cursor:pointer;transition:transform .12s}.avatar:hover{transform:scale(1.05)}.avatar.active{box-shadow:0 0 0 2px var(--ink)}.tabs{display:flex;gap:4px;padding:4px;background:var(--surface);border:.5px solid var(--line);border-radius:999px;margin-bottom:20px;overflow-x:auto}.tab{background:transparent;border:0;padding:8px 16px;border-radius:999px;font-size:13px;font-weight:500;color:var(--ink-mute);cursor:pointer;white-space:nowrap;font-family:inherit}.tab.active{background:var(--ink);color:var(--bg)}.card{background:var(--surface);border:.5px solid var(--line);border-radius:var(--radius);padding:14px;transition:all .15s;cursor:pointer}.card:hover{transform:translateY(-1px)}.card.picked,.card:hover{border-color:var(--brand)}.card.picked{box-shadow:inset 0 0 0 1.5px var(--brand);background:var(--brand-soft)}.pill{font-size:11px;padding:3px 9px;border-radius:999px;background:var(--warm);color:var(--warm-ink);font-weight:500;display:inline-block}.pill.brand{background:var(--brand);color:var(--bg)}.pill.red{background:#fbe3dc;color:#6e2a18}.stars{color:var(--gold);font-size:13px;letter-spacing:1px}.stars .empty{color:var(--line)}.btn-primary{background:var(--brand);color:var(--bg);border:0;padding:11px 18px;border-radius:999px;font:500 13px Inter,sans-serif;cursor:pointer}.btn-primary:hover{background:var(--brand-deep)}.btn-ghost{background:var(--surface);color:var(--ink);border:.5px solid var(--line);padding:9px 16px;border-radius:999px;font:500 13px Inter,sans-serif;cursor:pointer}.btn-ghost:hover{border-color:var(--brand)}.grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(210px,1fr));grid-gap:10px;gap:10px}.row{gap:8px}.hero,.row{display:flex;align-items:center;justify-content:space-between}.hero{background:var(--brand);color:var(--bg);padding:22px 24px;border-radius:var(--radius-lg);margin-bottom:24px;flex-wrap:wrap;gap:12px}.hero .h-eye{font-size:11px;font-weight:600;letter-spacing:.12em;text-transform:uppercase;opacity:.7}.hero .h-title{font-family:Fraunces,Georgia,serif;font-weight:500;font-size:26px;margin:4px 0}.hero .h-sub{font-size:13px;opacity:.85}.hero .btn-primary{background:var(--bg);color:var(--brand)}.hero .btn-primary:hover{background:var(--warm)}.chips{display:flex;gap:6px;margin-bottom:14px;flex-wrap:wrap}.chip{font:500 12px Inter,sans-serif;padding:6px 12px;border-radius:999px;border:.5px solid var(--line);background:var(--surface);color:var(--ink);cursor:pointer}.chip.on{background:var(--ink);color:var(--bg);border-color:var(--ink)}.input{width:100%;padding:11px 14px;border-radius:12px;border:.5px solid var(--line);background:var(--surface);font:14px Inter,sans-serif;color:var(--ink)}.input:focus{outline:none;border-color:var(--brand)}.stat{background:var(--surface);border:.5px solid var(--line);padding:12px;border-radius:12px;text-align:center}.stat .v{font-family:Fraunces,Georgia,serif;font-size:22px;color:var(--brand);margin-top:4px}.ing-section{font-size:11px;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--brand);margin:16px 0 8px;padding-bottom:4px;border-bottom:.5px solid var(--line-soft)}.check{cursor:pointer;-webkit-user-select:none;-moz-user-select:none;user-select:none;font-size:14px;padding:6px 0;line-height:1.5}.check.done{text-decoration:line-through;color:var(--ink-mute);opacity:.6}.step{display:grid;grid-template-columns:32px 1fr;grid-gap:14px;gap:14px;padding:14px 0;border-bottom:.5px dashed var(--line-soft)}.step:last-child{border-bottom:0}.step-num{width:28px;height:28px;border-radius:50%;background:var(--brand);color:var(--bg);display:flex;align-items:center;justify-content:center;font:600 13px Fraunces,serif}a{color:inherit;text-decoration:none}.welcome{min-height:100dvh;justify-content:center;padding:24px}.welcome,.welcome-inner{display:flex;align-items:center}.welcome-inner{flex-direction:column;max-width:720px;width:100%}.brand-mark{padding:4px 14px;border:.5px solid var(--line);border-radius:999px;background:var(--surface)}.welcome-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));grid-gap:12px;gap:12px;width:100%;max-width:600px}.welcome-card{background:var(--surface);border:.5px solid var(--line);border-radius:var(--radius-lg);padding:24px 12px;cursor:pointer;display:flex;flex-direction:column;align-items:center;transition:all .15s;font-family:inherit}.welcome-card:hover{border-color:var(--brand);transform:translateY(-2px)}.welcome-avatar{width:64px;height:64px;border-radius:50%;display:inline-flex;align-items:center;justify-content:center;font-size:24px;font-weight:600;color:var(--bg)}.welcome-name{font-size:18px;margin-top:14px}@media (max-width:720px){.hero{padding:18px}.hero .h-title{font-size:22px}.header{padding-bottom:10px;margin-bottom:14px}.avatar{width:32px;height:32px}.recipe-cols{grid-template-columns:1fr!important}}