/* AIRecipeLive · Editorial Food Magazine Aesthetic */

:root {
  --bg: #FAF7F2;
  --surf: #FFFFFF;
  --tomato: #C73E1D;
  --honey: #D4A574;
  --olive: #6B7F3E;
  --ink: #1A1A1A;
  --muted: #6B6B6B;
  --bord: #E8DDD0;
  --bord-l: #F1E9DC;

  --serif: 'Playfair Display', 'Noto Serif TC', 'Songti TC', serif;
  --sans: 'Inter', 'Noto Sans TC', system-ui, sans-serif;
  --mono: 'JetBrains Mono', ui-monospace, monospace;
}

* { box-sizing: border-box; margin: 0; padding: 0; }
html, body { background: var(--bg); color: var(--ink); font-family: var(--sans); font-size: 16px; line-height: 1.55; -webkit-font-smoothing: antialiased; }
img { display: block; max-width: 100%; }
button { font-family: inherit; cursor: pointer; background: none; border: none; color: inherit; }
a { color: inherit; text-decoration: none; cursor: pointer; }
em { font-style: italic; }

/* ─────────── PAGE ─────────── */
.page { background: var(--bg); min-height: 100%; }
.page--d { font-size: 16px; }
.page--m { font-size: 14px; }

/* ─────────── HEADER ─────────── */
.hdr {
  display: flex; align-items: center; gap: 32px;
  padding: 18px 48px; background: rgba(250,247,242,0.92); backdrop-filter: blur(12px);
  border-bottom: 1px solid var(--bord-l); position: sticky; top: 0; z-index: 50;
}
.hdr__logo { font-family: var(--serif); font-size: 26px; font-weight: 900; letter-spacing: -0.02em; cursor: pointer; }
.hdr__logo em { color: var(--tomato); font-weight: 400; font-style: italic; }
.hdr__tag { display: inline-block; margin-left: 10px; font-family: var(--sans); font-size: 9px; font-weight: 600; letter-spacing: 0.2em; text-transform: uppercase; color: var(--muted); padding: 3px 7px; border: 1px solid var(--bord); border-radius: 2px; vertical-align: middle; }
.hdr__nav { display: flex; gap: 28px; margin-left: auto; }
.hdr__a { font-size: 14px; font-weight: 500; color: var(--ink); position: relative; padding: 4px 0; }
.hdr__a:hover { color: var(--tomato); }
.hdr__a.is-active { color: var(--tomato); }
.hdr__a.is-active::after { content: ''; position: absolute; left: 0; right: 0; bottom: -2px; height: 2px; background: var(--tomato); }
.hdr__r { display: flex; gap: 8px; align-items: center; }

.hdr--m { padding: 14px 18px; gap: 12px; justify-content: space-between; }
.hdr--m .hdr__logo { font-size: 20px; }

.ico-btn { width: 38px; height: 38px; border-radius: 100%; display: inline-flex; align-items: center; justify-content: center; color: var(--ink); transition: background 180ms; }
.ico-btn:hover { background: var(--bord-l); }
.ico-btn--sm { width: 32px; height: 32px; }

/* ─────────── BUTTONS ─────────── */
.btn { display: inline-flex; align-items: center; justify-content: center; gap: 8px; padding: 13px 22px; font-size: 14px; font-weight: 600; border-radius: 4px; transition: all 180ms; min-height: 44px; line-height: 1; }
.btn--primary { background: var(--tomato); color: #fff; }
.btn--primary:hover { background: #a8331a; box-shadow: 0 6px 18px -8px rgba(199,62,29,0.5); }
.btn--ghost { background: transparent; color: var(--tomato); border: 1px solid var(--tomato); }
.btn--ghost:hover { background: var(--tomato); color: #fff; }
.btn--sm { padding: 8px 14px; font-size: 12px; min-height: 36px; }

/* ─────────── EYEBROW / DIVIDERS ─────────── */
.eyebrow { display: inline-block; font-size: 11px; font-weight: 600; text-transform: uppercase; letter-spacing: 0.25em; color: var(--tomato); margin-bottom: 14px; }
.div { display: flex; align-items: center; gap: 16px; margin: 32px 0; }
.div__l { flex: 1; height: 1px; background: var(--bord); }
.div__t { font-family: var(--serif); font-style: italic; color: var(--muted); }

/* ─────────── HERO ─────────── */
.hero { display: grid; grid-template-columns: 1.05fr 1fr; gap: 64px; padding: 64px 48px 80px; align-items: center; }
.hero--m { grid-template-columns: 1fr; padding: 32px 18px 48px; gap: 24px; }
.hero__h1 { font-family: var(--serif); font-size: 76px; line-height: 0.98; font-weight: 900; letter-spacing: -0.03em; margin-bottom: 22px; }
.hero__h1 em { font-weight: 400; color: var(--tomato); font-style: italic; }
.hero--m .hero__h1 { font-size: 42px; }
.hero__p { font-size: 16px; color: var(--muted); max-width: 480px; line-height: 1.65; margin-bottom: 28px; }
.hero__form { background: var(--surf); padding: 24px; border-radius: 8px; border: 1px solid var(--bord); box-shadow: 0 24px 60px -32px rgba(26,26,26,0.18); }
.hero__actions { display: flex; gap: 10px; margin-top: 14px; flex-wrap: wrap; }
.hero__quick { margin-top: 18px; padding-top: 18px; border-top: 1px dashed var(--bord); }
.quick__label { display: block; font-size: 11px; font-weight: 600; letter-spacing: 0.18em; text-transform: uppercase; color: var(--muted); margin-bottom: 10px; }
.quick__row { display: flex; gap: 8px; flex-wrap: wrap; }
.hero__pantry { display: flex; align-items: center; gap: 8px; margin-top: 16px; padding: 10px 12px; background: #FBF4EA; border-radius: 4px; font-size: 12px; color: var(--muted); }
.hero__pantry a { color: var(--tomato); margin-left: auto; font-weight: 600; }

.hero__r { position: relative; }
.hero__img { position: relative; aspect-ratio: 4/5; border-radius: 6px; overflow: hidden; box-shadow: 0 30px 80px -40px rgba(0,0,0,0.4); }
.hero__img img { width: 100%; height: 100%; object-fit: cover; }
.hero__cap { position: absolute; left: 20px; bottom: 20px; right: 20px; color: #fff; display: flex; align-items: baseline; gap: 14px; }
.cap__num { font-family: var(--serif); font-style: italic; font-size: 56px; font-weight: 400; line-height: 1; opacity: 0.9; }
.cap__t { font-size: 13px; font-weight: 600; letter-spacing: 0.05em; text-shadow: 0 2px 8px rgba(0,0,0,0.5); }
.hero__stat { display: grid; grid-template-columns: repeat(3, 1fr); gap: 20px; margin-top: 20px; padding: 18px; background: var(--surf); border: 1px solid var(--bord); border-radius: 6px; }
.hero__stat > div { text-align: center; }
.hero__stat b { font-family: var(--serif); font-size: 28px; font-weight: 700; display: block; }
.hero__stat span { font-size: 11px; color: var(--muted); letter-spacing: 0.05em; }

/* ─────────── TAG INPUT ─────────── */
.tagin { position: relative; }
.tagin__bar { display: flex; align-items: center; gap: 12px; padding: 12px 14px; border: 2px solid var(--bord); border-radius: 6px; background: var(--bg); transition: border-color 180ms; }
.tagin.is-focus .tagin__bar { border-color: var(--tomato); background: var(--surf); }
.tagin__tags { display: flex; flex-wrap: wrap; gap: 6px; flex: 1; align-items: center; min-height: 28px; }
.tagin__tags input { flex: 1; min-width: 100px; border: none; outline: none; background: transparent; font-size: 15px; font-family: inherit; color: var(--ink); }
.tagin__count { font-size: 11px; color: var(--muted); font-variant-numeric: tabular-nums; }
.tagin__sug { position: absolute; top: calc(100% + 4px); left: 0; right: 0; background: var(--surf); border: 1px solid var(--bord); border-radius: 4px; padding: 6px; box-shadow: 0 12px 32px -16px rgba(0,0,0,0.2); z-index: 5; display: flex; flex-wrap: wrap; gap: 4px; }
.tagin__sug button { padding: 6px 10px; border-radius: 3px; font-size: 13px; }
.tagin__sug button:hover { background: var(--bord-l); }

/* ─────────── TAGS / CHIPS ─────────── */
.tag { display: inline-flex; align-items: center; gap: 6px; padding: 4px 4px 4px 10px; background: var(--honey); color: var(--ink); font-size: 13px; font-weight: 500; border-radius: 4px; }
.tag button { width: 18px; height: 18px; border-radius: 100%; display: inline-flex; align-items: center; justify-content: center; opacity: 0.6; }
.tag button:hover { opacity: 1; background: rgba(0,0,0,0.1); }
.tag--lg { padding: 7px 8px 7px 14px; font-size: 15px; font-weight: 600; }
.tag--accent { background: #FCE9D9; color: var(--tomato); }
.tag--add { background: transparent; border: 1px dashed var(--bord); padding: 7px 14px; color: var(--muted); cursor: pointer; }
.tag--add:hover { border-color: var(--tomato); color: var(--tomato); }

.chip { padding: 7px 14px; font-size: 13px; font-weight: 500; border: 1px solid var(--bord); background: var(--surf); color: var(--ink); border-radius: 100px; transition: all 150ms; }
.chip:hover { border-color: var(--tomato); color: var(--tomato); }
.chip.is-on { background: var(--tomato); color: #fff; border-color: var(--tomato); }

.pill { padding: 6px 12px; font-size: 12px; font-weight: 500; color: var(--muted); border-radius: 100px; }
.pill:hover { color: var(--ink); }
.pill.is-on { background: var(--ink); color: var(--bg); }

/* ─────────── SECTIONS ─────────── */
.sec { padding: 64px 48px; }
.sec--alt { background: #F4EEE3; }
.sec--feat { padding: 80px 48px; }
.sec__head { margin-bottom: 36px; }
.sec__head--row { display: flex; justify-content: space-between; align-items: flex-end; }
.sec__h { font-family: var(--serif); font-size: 40px; font-weight: 700; letter-spacing: -0.02em; line-height: 1.1; }
.page--m .sec { padding: 40px 18px; }
.page--m .sec__h { font-size: 26px; }
.sec__more { font-size: 13px; font-weight: 600; color: var(--tomato); display: inline-flex; align-items: center; gap: 4px; }

/* ─────────── FEATURED ─────────── */
.feat { display: grid; grid-template-columns: 1.1fr 1fr; gap: 56px; align-items: center; cursor: pointer; }
.feat--m { grid-template-columns: 1fr; gap: 24px; }
.feat__img { aspect-ratio: 4/3; border-radius: 4px; overflow: hidden; }
.feat__img img { width: 100%; height: 100%; object-fit: cover; transition: transform 600ms ease; }
.feat:hover .feat__img img { transform: scale(1.04); }
.feat__cat { font-size: 11px; font-weight: 600; letter-spacing: 0.18em; color: var(--tomato); text-transform: uppercase; margin-bottom: 14px; display: block; }
.feat__t { font-family: var(--serif); font-size: 56px; line-height: 1; font-weight: 700; letter-spacing: -0.02em; margin-bottom: 18px; }
.feat--m .feat__t { font-size: 32px; }
.feat__lead { font-family: var(--serif); font-style: italic; font-size: 22px; color: var(--ink); margin-bottom: 18px; line-height: 1.4; }
.feat__p { color: var(--muted); margin-bottom: 22px; line-height: 1.75; max-width: 520px; }
.feat__sig { font-family: var(--serif); font-style: italic; color: var(--muted); margin-bottom: 22px; }

/* ─────────── CARDS / GRID ─────────── */
.grid { display: grid; gap: 32px 28px; }
.grid--d { grid-template-columns: repeat(3, 1fr); }
.grid--m { grid-template-columns: repeat(2, 1fr); gap: 18px; }
.grid--res.grid--d { grid-template-columns: repeat(3, 1fr); }

.card { cursor: pointer; }
.card__img { position: relative; aspect-ratio: 4/3; border-radius: 4px; overflow: hidden; margin-bottom: 14px; }
.card__img img { width: 100%; height: 100%; object-fit: cover; transition: transform 500ms ease; }
.card:hover .card__img img { transform: scale(1.05); }
.card__cat { position: absolute; left: 12px; bottom: 12px; background: rgba(250,247,242,0.95); color: var(--ink); font-size: 10px; font-weight: 600; letter-spacing: 0.15em; text-transform: uppercase; padding: 5px 10px; border-radius: 2px; }
.card__pick { position: absolute; top: 12px; right: 12px; background: var(--ink); color: var(--bg); font-size: 9px; font-weight: 700; letter-spacing: 0.18em; padding: 5px 9px; border-radius: 2px; }
.card__t { font-family: var(--serif); font-size: 22px; font-weight: 700; letter-spacing: -0.01em; line-height: 1.2; margin-bottom: 6px; }
.card__sub { font-size: 13px; color: var(--muted); line-height: 1.5; margin-bottom: 10px; }
.card__meta { display: flex; gap: 14px; font-size: 12px; color: var(--muted); align-items: center; }
.card__meta span { display: inline-flex; align-items: center; gap: 4px; }
.card__miss { margin-top: 8px; font-size: 12px; color: var(--tomato); padding: 6px 10px; background: #FCE9D9; border-radius: 3px; }
.card__subhint { color: var(--olive); margin-left: 4px; }
.page--m .card__t { font-size: 16px; }

.match { position: absolute; top: 12px; left: 12px; font-size: 10px; font-weight: 700; letter-spacing: 0.1em; padding: 5px 9px; border-radius: 2px; }
.match--full { background: var(--olive); color: #fff; }
.match--mid { background: var(--honey); color: var(--ink); }
.match--low { background: #999; color: #fff; }

/* ─────────── CATEGORIES ─────────── */
.cats { display: grid; gap: 18px; }
.cats--d { grid-template-columns: repeat(6, 1fr); }
.cats--m { grid-template-columns: repeat(3, 1fr); gap: 12px; }
.cat { display: block; cursor: pointer; }
.cat__img { aspect-ratio: 1; border-radius: 100%; overflow: hidden; margin-bottom: 12px; transition: transform 200ms; }
.cat__img img { width: 100%; height: 100%; object-fit: cover; }
.cat:hover .cat__img { transform: translateY(-4px); }
.cat__t { font-family: var(--serif); font-size: 18px; font-weight: 700; text-align: center; }
.cat__n { font-size: 11px; color: var(--muted); text-align: center; margin-top: 2px; }

/* ─────────── MOOD ─────────── */
.moods { display: grid; gap: 14px; }
.moods--d { grid-template-columns: repeat(5, 1fr); }
.moods--m { grid-template-columns: repeat(2, 1fr); }
.mood { padding: 24px 18px; background: var(--surf); border: 1px solid var(--bord); border-radius: 6px; display: flex; flex-direction: column; gap: 6px; align-items: flex-start; text-align: left; transition: all 200ms; }
.mood:hover { border-color: var(--tomato); transform: translateY(-3px); box-shadow: 0 12px 24px -16px rgba(0,0,0,0.15); }
.mood__e { font-size: 32px; margin-bottom: 6px; }
.mood__t { font-family: var(--serif); font-size: 18px; font-weight: 700; }
.mood__d { font-size: 12px; color: var(--muted); }

/* ─────────── NEWSLETTER ─────────── */
.news { padding: 80px 48px; text-align: center; background: var(--ink); color: var(--bg); }
.news__h { font-family: var(--serif); font-size: 48px; font-weight: 700; letter-spacing: -0.02em; line-height: 1.1; margin: 14px auto 18px; }
.page--m .news__h { font-size: 28px; }
.news__p { color: #aaa; max-width: 480px; margin: 0 auto 28px; }
.news__f { display: flex; gap: 8px; max-width: 460px; margin: 0 auto; }
.news__f input { flex: 1; padding: 14px 18px; border-radius: 4px; border: 1px solid #444; background: transparent; color: var(--bg); font-family: inherit; font-size: 15px; outline: none; }
.news__f input:focus { border-color: var(--honey); }
.news__note { display: block; font-size: 11px; color: #888; margin-top: 14px; }

/* ─────────── FOOTER ─────────── */
.ftr { background: var(--bg); border-top: 1px solid var(--bord); padding: 48px 48px 24px; }
.page--m .ftr { padding: 32px 18px 18px; }
.ftr__top { display: grid; grid-template-columns: 1fr 2fr; gap: 48px; margin-bottom: 36px; }
.page--m .ftr__top { grid-template-columns: 1fr; }
.ftr__logo { font-family: var(--serif); font-size: 24px; font-weight: 900; }
.ftr__logo em { color: var(--tomato); font-style: italic; font-weight: 400; }
.ftr__brand p { font-size: 13px; color: var(--muted); margin-top: 8px; max-width: 360px; line-height: 1.6; }
.ftr__cols { display: grid; grid-template-columns: repeat(4, 1fr); gap: 24px; }
.page--m .ftr__cols { grid-template-columns: repeat(2, 1fr); }
.ftr__cols h5 { font-size: 11px; font-weight: 600; letter-spacing: 0.18em; text-transform: uppercase; color: var(--ink); margin-bottom: 14px; }
.ftr__cols a { display: block; font-size: 13px; color: var(--muted); margin-bottom: 8px; }
.ftr__cols a:hover { color: var(--tomato); }
.ftr__bot { display: flex; justify-content: space-between; padding-top: 18px; border-top: 1px solid var(--bord); font-size: 11px; color: var(--muted); }

/* ─────────── SEARCH HEADER ─────────── */
.srhd { padding: 48px 48px 32px; }
.srhd--m { padding: 24px 18px; }
.bcrumb { font-size: 12px; color: var(--muted); margin-bottom: 18px; }
.bcrumb a:hover { color: var(--tomato); }
.bcrumb span { color: var(--ink); }
.srhd__h { font-family: var(--serif); font-size: 56px; font-weight: 700; letter-spacing: -0.02em; line-height: 1.15; margin-bottom: 28px; }
.srhd__h em { color: var(--tomato); font-style: italic; }
.srhd--m .srhd__h { font-size: 28px; }
.srhd__tags { display: inline-flex; gap: 6px; flex-wrap: wrap; vertical-align: middle; margin: 0 8px; }
.srhd__bar { display: flex; justify-content: space-between; align-items: center; padding-top: 18px; border-top: 1px solid var(--bord); }
.srhd__sort { display: flex; gap: 4px; align-items: center; flex-wrap: wrap; }
.srhd__lab { font-size: 11px; font-weight: 600; letter-spacing: 0.18em; text-transform: uppercase; color: var(--muted); margin-right: 8px; }

/* ─────────── SEARCH RESULTS ─────────── */
.sr { display: grid; grid-template-columns: 240px 1fr; gap: 48px; padding: 0 48px 64px; }
.sr--m { grid-template-columns: 1fr; padding: 0 18px 32px; }
.filt { font-size: 13px; }
.fg { padding: 18px 0; border-bottom: 1px solid var(--bord-l); }
.fg__h { font-size: 12px; font-weight: 600; letter-spacing: 0.18em; text-transform: uppercase; color: var(--ink); margin-bottom: 12px; }
.fg__o { display: flex; align-items: center; gap: 10px; padding: 5px 0; cursor: pointer; color: var(--muted); }
.fg__o:hover { color: var(--ink); }
.fg__o.is-on { color: var(--ink); font-weight: 600; }
.fg__o input { display: none; }
.fg__box { width: 14px; height: 14px; border: 1.5px solid var(--bord); border-radius: 2px; flex-shrink: 0; transition: all 150ms; }
.fg__o.is-on .fg__box { background: var(--tomato); border-color: var(--tomato); position: relative; }
.fg__o.is-on .fg__box::after { content: ''; position: absolute; left: 3px; top: 1px; width: 4px; height: 7px; border: solid #fff; border-width: 0 1.5px 1.5px 0; transform: rotate(45deg); }
.filt__hint { display: flex; gap: 8px; align-items: flex-start; padding: 14px; background: #FBF4EA; border-radius: 4px; margin-top: 18px; color: var(--muted); font-size: 12px; line-height: 1.5; }
.filt__hint svg { color: var(--honey); margin-top: 2px; flex-shrink: 0; }
.sr__more { text-align: center; margin-top: 48px; }

/* ─────────── RECIPE DETAIL ─────────── */
.rd { padding: 32px 48px 48px; max-width: 1280px; margin: 0 auto; }
.rd--m { padding: 18px; }
.rd__hd { max-width: 800px; margin: 24px auto 36px; text-align: center; }
.rd__cat { font-size: 11px; font-weight: 600; letter-spacing: 0.25em; color: var(--tomato); text-transform: uppercase; }
.rd__h1 { font-family: var(--serif); font-size: 76px; line-height: 1; font-weight: 700; letter-spacing: -0.02em; margin: 14px 0 18px; }
.rd--m .rd__h1 { font-size: 36px; }
.rd__sub { font-family: var(--serif); font-style: italic; font-size: 22px; color: var(--muted); margin-bottom: 24px; }
.rd__meta { display: flex; justify-content: center; gap: 36px; padding-top: 18px; border-top: 1px solid var(--bord); align-items: center; flex-wrap: wrap; }
.rd__author { display: flex; gap: 10px; align-items: center; text-align: left; }
.rd__av { width: 36px; height: 36px; border-radius: 100%; background: var(--honey); color: var(--ink); font-family: var(--serif); font-weight: 700; display: inline-flex; align-items: center; justify-content: center; font-size: 16px; }
.rd__author b { display: block; font-size: 13px; }
.rd__author span { display: block; font-size: 11px; color: var(--muted); }
.rd__rate { display: flex; gap: 4px; align-items: center; color: var(--tomato); font-size: 12px; }
.rd__rate svg { fill: var(--tomato); }
.rd__rate span { color: var(--muted); margin-left: 6px; }

.rd__hero { position: relative; aspect-ratio: 16/9; border-radius: 6px; overflow: hidden; margin-bottom: 36px; }
.rd__hero img { width: 100%; height: 100%; object-fit: cover; }
.rd__tools { position: absolute; right: 18px; bottom: 18px; display: flex; gap: 6px; padding: 6px; background: rgba(255,255,255,0.95); border-radius: 100px; }

.rd__tldr { background: #FBF4EA; border-left: 3px solid var(--honey); padding: 22px 26px; border-radius: 0 4px 4px 0; margin-bottom: 32px; max-width: 800px; margin-left: auto; margin-right: auto; }
.rd__tldr h4 { font-size: 11px; font-weight: 600; letter-spacing: 0.25em; color: var(--honey); text-transform: uppercase; margin-bottom: 10px; }
.rd__tldr ul { padding-left: 20px; font-size: 14px; line-height: 1.7; }
.rd__tldr li { margin-bottom: 4px; }

.rd__qf { display: grid; grid-template-columns: repeat(6, 1fr); gap: 0; padding: 24px 0; border-top: 1px solid var(--bord); border-bottom: 1px solid var(--bord); margin-bottom: 48px; max-width: 800px; margin-left: auto; margin-right: auto; }
.rd--m .rd__qf { grid-template-columns: repeat(3, 1fr); gap: 18px; }
.rd__qf > div { text-align: center; border-right: 1px solid var(--bord-l); }
.rd__qf > div:last-child { border-right: none; }
.qf__l { display: block; font-size: 10px; font-weight: 600; letter-spacing: 0.18em; text-transform: uppercase; color: var(--muted); margin-bottom: 6px; }
.rd__qf b { font-family: var(--serif); font-size: 18px; font-weight: 700; }

.rd__body { display: grid; grid-template-columns: 1fr 1.2fr; gap: 56px; align-items: start; max-width: 1100px; margin: 0 auto; }
.rd__body--m { grid-template-columns: 1fr; gap: 36px; }
.rd__sh { margin-bottom: 18px; }
.rd__sh h2 { font-family: var(--serif); font-size: 32px; font-weight: 700; letter-spacing: -0.02em; }

.serv { display: flex; align-items: center; gap: 10px; padding: 12px 16px; background: var(--surf); border: 1px solid var(--bord); border-radius: 4px; margin-bottom: 18px; }
.serv__l { font-size: 11px; font-weight: 600; letter-spacing: 0.15em; text-transform: uppercase; color: var(--muted); }
.serv button { width: 28px; height: 28px; border-radius: 100%; background: var(--bg); font-size: 16px; font-weight: 600; }
.serv button:hover { background: var(--tomato); color: #fff; }
.serv b { font-family: var(--serif); font-size: 18px; }
.serv__hint { font-size: 11px; color: var(--muted); margin-left: auto; }

.ing { list-style: none; padding: 0; }
.ing li { display: flex; align-items: center; gap: 14px; padding: 14px 0; border-bottom: 1px solid var(--bord-l); cursor: pointer; transition: opacity 150ms; }
.ing li.is-done { opacity: 0.4; }
.ing li.is-done .ing__n { text-decoration: line-through; }
.ing__cb { width: 22px; height: 22px; border-radius: 100%; border: 1.5px solid var(--bord); display: inline-flex; align-items: center; justify-content: center; flex-shrink: 0; transition: all 150ms; color: #fff; }
.ing li.is-done .ing__cb { background: var(--olive); border-color: var(--olive); }
.ing__n { flex: 1; font-size: 15px; }
.ing__q { font-family: var(--serif); font-size: 16px; color: var(--muted); }
.ing__q b { color: var(--ink); font-weight: 700; margin-right: 4px; }
.rd__addcart { margin-top: 18px; }

.steps { list-style: none; padding: 0; counter-reset: step; }
.steps li { display: flex; gap: 24px; padding: 24px 0; border-bottom: 1px solid var(--bord-l); }
.steps__n { font-family: var(--serif); font-size: 36px; font-weight: 400; color: var(--tomato); font-style: italic; line-height: 1; flex-shrink: 0; }
.steps__b { flex: 1; }
.steps__b p { font-size: 16px; line-height: 1.7; margin-bottom: 10px; }
.timer { display: inline-flex; align-items: center; gap: 6px; padding: 7px 12px; background: var(--ink); color: var(--bg); border-radius: 100px; font-size: 12px; font-weight: 500; font-variant-numeric: tabular-nums; }
.timer:hover { background: var(--tomato); }

.rd__tips blockquote { border-left: 3px solid var(--tomato); padding: 18px 24px; background: var(--surf); border-radius: 0 4px 4px 0; }
.rd__tips blockquote p { font-family: var(--serif); font-style: italic; font-size: 18px; line-height: 1.6; color: var(--ink); margin-bottom: 12px; }
.rd__tips cite { font-size: 12px; color: var(--muted); font-style: normal; letter-spacing: 0.05em; }

.nutr { display: grid; grid-template-columns: repeat(6, 1fr); gap: 12px; padding: 18px; background: var(--surf); border: 1px solid var(--bord); border-radius: 4px; }
.rd--m .nutr { grid-template-columns: repeat(3, 1fr); }
.nutr > div { text-align: center; }
.nutr b { font-family: var(--serif); font-size: 22px; display: block; }
.nutr small { font-size: 11px; font-weight: 400; color: var(--muted); margin-left: 2px; }
.nutr span { font-size: 11px; color: var(--muted); }

.faq { border-bottom: 1px solid var(--bord-l); cursor: pointer; }
.faq__q { display: flex; justify-content: space-between; align-items: center; padding: 18px 0; font-weight: 600; }
.faq__q svg { transition: transform 200ms; color: var(--muted); }
.faq.is-open .faq__q svg { transform: rotate(180deg); }
.faq__a { padding: 0 0 18px; color: var(--muted); line-height: 1.7; }

.rd__rel { margin-top: 64px; }
.rd__rel h2 { font-family: var(--serif); font-size: 32px; font-weight: 700; margin: 8px 0 24px; }

/* ─────────── PANTRY / MEALPLAN / SHOPPING ─────────── */
.pant, .mp, .sl { padding: 48px 48px 64px; max-width: 1100px; margin: 0 auto; }
.pant--m, .mp--m, .sl--m { padding: 24px 18px; }
.pant__h, .mp__h, .sl__h { font-family: var(--serif); font-size: 56px; font-weight: 700; line-height: 1.05; letter-spacing: -0.02em; margin-bottom: 14px; }
.pant--m .pant__h, .mp--m .mp__h, .sl--m .sl__h { font-size: 30px; }
.pant__h em, .mp__h em, .sl__h em { color: var(--tomato); font-style: italic; }
.pant__p, .mp__p, .sl__p { color: var(--muted); margin-bottom: 36px; max-width: 600px; line-height: 1.7; }
.pant__cols { display: grid; grid-template-columns: 1fr 1fr; gap: 32px; }
.pant--m .pant__cols { grid-template-columns: 1fr; }
.pant__col { padding: 28px; background: var(--surf); border: 1px solid var(--bord); border-radius: 6px; }
.pant__sh { font-family: var(--serif); font-size: 22px; font-weight: 700; display: flex; align-items: center; gap: 10px; margin-bottom: 8px; }
.pant__sh span { margin-left: auto; font-family: var(--sans); font-size: 11px; color: var(--muted); font-weight: 500; letter-spacing: 0.1em; }
.pant__hint { font-size: 13px; color: var(--muted); margin-bottom: 18px; }
.pant__tags { display: flex; flex-wrap: wrap; gap: 8px; margin-bottom: 18px; }
.pant__add { display: flex; gap: 4px; align-items: center; padding: 6px; border: 1px dashed var(--bord); border-radius: 4px; }
.pant__add input { border: none; outline: none; padding: 6px 10px; flex: 1; font-family: inherit; font-size: 13px; background: transparent; }
.pant__add button { width: 28px; height: 28px; border-radius: 4px; background: var(--ink); color: var(--bg); display: inline-flex; align-items: center; justify-content: center; }
.pant__cta { width: 100%; margin-top: 12px; }

.mp__pref { display: flex; align-items: center; gap: 8px; flex-wrap: wrap; padding: 16px; background: var(--surf); border: 1px solid var(--bord); border-radius: 6px; margin-bottom: 28px; }
.mp__lab { font-size: 11px; font-weight: 600; letter-spacing: 0.18em; text-transform: uppercase; color: var(--muted); }
.mp__grid { display: grid; grid-template-columns: 80px repeat(7, 1fr); gap: 6px; margin-bottom: 28px; }
.mp__head { }
.mp__day { font-size: 11px; font-weight: 600; letter-spacing: 0.15em; text-transform: uppercase; color: var(--muted); padding: 8px 4px; text-align: center; border-bottom: 1px solid var(--bord); }
.mp__meal { font-family: var(--serif); font-size: 16px; font-weight: 700; padding: 10px 0; align-self: center; }
.mp__cell { background: var(--surf); border: 1px solid var(--bord-l); border-radius: 4px; padding: 8px; cursor: pointer; transition: all 150ms; }
.mp__cell:hover { border-color: var(--tomato); }
.mp__cell img { width: 100%; aspect-ratio: 4/3; object-fit: cover; border-radius: 2px; margin-bottom: 6px; }
.mp__t { display: block; font-family: var(--serif); font-size: 13px; font-weight: 700; line-height: 1.2; margin-bottom: 4px; }
.mp__m { display: block; font-size: 10px; color: var(--muted); }
.mp__list { display: flex; flex-direction: column; gap: 18px; margin-bottom: 28px; }
.mp__row { background: var(--surf); border: 1px solid var(--bord); border-radius: 6px; padding: 14px; }
.mp__row h4 { font-family: var(--serif); font-size: 16px; margin-bottom: 10px; padding-bottom: 8px; border-bottom: 1px solid var(--bord-l); }
.mp__rcell { display: flex; gap: 10px; padding: 8px 0; align-items: center; }
.mp__rcell img { width: 56px; height: 56px; object-fit: cover; border-radius: 4px; flex-shrink: 0; }
.mp__rcell div { flex: 1; }
.mp__rm { display: block; font-size: 10px; font-weight: 600; letter-spacing: 0.2em; color: var(--tomato); text-transform: uppercase; }
.mp__rcell b { display: block; font-family: var(--serif); font-size: 14px; }
.mp__rcell span { font-size: 11px; color: var(--muted); }
.mp__foot { display: flex; align-items: center; gap: 32px; padding: 22px; background: var(--ink); color: var(--bg); border-radius: 6px; }
.mp__foot > div b { font-family: var(--serif); font-size: 26px; display: block; }
.mp__foot > div span { font-size: 11px; color: #aaa; letter-spacing: 0.1em; }
.mp__foot button { margin-left: auto; }

.sl__bar { display: flex; align-items: center; gap: 24px; padding: 16px 18px; background: var(--surf); border: 1px solid var(--bord); border-radius: 6px; margin-bottom: 24px; }
.sl__prog { flex: 1; }
.sl__prog span { display: block; font-family: var(--serif); font-size: 16px; font-weight: 700; margin-bottom: 6px; }
.sl__pb { height: 4px; background: var(--bord); border-radius: 100px; overflow: hidden; }
.sl__pb > div { height: 100%; background: var(--olive); transition: width 300ms; }
.sl__acts { display: flex; gap: 6px; }
.sl__list { display: flex; flex-direction: column; gap: 28px; }
.sl__cat { background: var(--surf); border: 1px solid var(--bord); border-radius: 6px; overflow: hidden; }
.sl__ch { font-size: 11px; font-weight: 600; letter-spacing: 0.25em; text-transform: uppercase; color: var(--tomato); padding: 14px 18px; background: #FBF4EA; }
.sl__it { display: flex; align-items: center; gap: 14px; padding: 14px 18px; border-bottom: 1px solid var(--bord-l); cursor: pointer; transition: opacity 150ms; }
.sl__it:last-child { border-bottom: none; }
.sl__it.is-done { opacity: 0.4; }
.sl__it.is-done .sl__nm b { text-decoration: line-through; }
.sl__it.is-done .ing__cb { background: var(--olive); border-color: var(--olive); }
.sl__nm { flex: 1; }
.sl__nm b { display: block; font-size: 14px; }
.sl__nm span { display: block; font-size: 11px; color: var(--muted); margin-top: 2px; }
.sl__q { font-family: var(--serif); font-size: 15px; font-weight: 700; }
.sl__aff { display: flex; align-items: center; gap: 14px; padding: 18px; background: var(--surf); border: 1px solid var(--bord); border-radius: 6px; margin-top: 28px; }
.sl__aff svg { color: var(--tomato); }
.sl__aff div { flex: 1; }
.sl__aff b { display: block; font-family: var(--serif); font-size: 16px; }
.sl__aff span { display: block; font-size: 11px; color: var(--muted); }

/* hero stats inside results */
.hero__pantry a { cursor: pointer; }

/* ─────────── CURRENCY SWITCH ─────────── */
.ccy { position: relative; }
.ccy__btn { display: inline-flex; align-items: center; gap: 6px; padding: 7px 12px; border-radius: 100px; border: 1px solid var(--bord); background: var(--surf); font-size: 12px; font-weight: 600; color: var(--ink); transition: all 150ms; }
.ccy__btn:hover { border-color: var(--tomato); color: var(--tomato); }
.ccy__sym { font-family: var(--serif); font-weight: 700; }
.ccy__code { letter-spacing: 0.05em; }
.ccy__menu { position: absolute; top: calc(100% + 6px); right: 0; background: var(--surf); border: 1px solid var(--bord); border-radius: 6px; box-shadow: 0 16px 40px -16px rgba(0,0,0,0.2); width: 240px; z-index: 100; padding: 6px; }
.ccy__hd { font-size: 10px; font-weight: 600; letter-spacing: 0.2em; text-transform: uppercase; color: var(--muted); padding: 8px 10px 4px; }
.ccy__opt { display: flex; align-items: center; gap: 12px; padding: 10px; width: 100%; border-radius: 4px; text-align: left; transition: background 120ms; }
.ccy__opt:hover { background: var(--bord-l); }
.ccy__opt.is-on { background: #FBF4EA; }
.ccy__optsym { font-family: var(--serif); font-weight: 700; font-size: 18px; width: 36px; color: var(--tomato); }
.ccy__optname { flex: 1; }
.ccy__optname b { display: block; font-size: 13px; font-weight: 600; }
.ccy__optname em { display: block; font-style: normal; font-size: 11px; color: var(--muted); }
.ccy__opt svg { color: var(--olive); }
.ccy__ft { font-size: 10px; color: var(--muted); padding: 8px 10px; border-top: 1px solid var(--bord-l); margin-top: 4px; }

/* ─────────── MODAL ─────────── */
.modal { position: fixed; inset: 0; background: rgba(26,26,26,0.5); backdrop-filter: blur(4px); display: flex; align-items: center; justify-content: center; z-index: 200; padding: 20px; }
.modal__b { background: var(--surf); border-radius: 8px; padding: 32px; max-width: 480px; width: 100%; position: relative; box-shadow: 0 30px 80px -20px rgba(0,0,0,0.4); }
.modal__x { position: absolute; top: 14px; right: 14px; width: 32px; height: 32px; border-radius: 100%; display: inline-flex; align-items: center; justify-content: center; color: var(--muted); }
.modal__x:hover { background: var(--bord-l); color: var(--ink); }
.modal__t { font-family: var(--serif); font-size: 24px; font-weight: 700; margin-bottom: 18px; padding-right: 32px; }

/* ─────────── BACKUP CODE ─────────── */
.bkup { display: grid; grid-template-columns: 1fr 1fr; gap: 32px; padding: 32px; margin-top: 36px; background: var(--ink); color: var(--bg); border-radius: 8px; align-items: center; }
.pant--m .bkup { grid-template-columns: 1fr; padding: 24px; gap: 20px; }
.bkup .eyebrow { color: var(--honey); }
.bkup__h { font-family: var(--serif); font-size: 28px; font-weight: 700; line-height: 1.2; margin-bottom: 12px; letter-spacing: -0.01em; }
.bkup__p { color: #bbb; font-size: 13px; line-height: 1.65; }
.bkup__r { display: flex; flex-direction: column; gap: 12px; }
.bkup__code { padding: 22px; background: rgba(255,255,255,0.06); border: 1px dashed rgba(255,255,255,0.2); border-radius: 6px; text-align: center; }
.bkup__lab { display: block; font-size: 10px; font-weight: 600; letter-spacing: 0.25em; text-transform: uppercase; color: var(--honey); margin-bottom: 8px; }
.bkup__code b { display: block; font-family: var(--mono, monospace); font-size: 36px; font-weight: 700; letter-spacing: 0.1em; color: var(--bg); margin-bottom: 8px; }
.bkup__hint { font-size: 11px; color: #888; }
.bkup__actions { display: flex; gap: 8px; }
.bkup__actions .btn { flex: 1; }
.bkup__actions .btn--ghost { color: var(--bg); border-color: rgba(255,255,255,0.3); }
.bkup__actions .btn--ghost:hover { background: var(--bg); color: var(--ink); border-color: var(--bg); }

/* ─────────── QR / RESTORE ─────────── */
.qr { display: flex; gap: 24px; align-items: center; }
.qr__box { flex-shrink: 0; padding: 14px; background: var(--surf); border: 1px solid var(--bord); border-radius: 4px; }
.qr__r { flex: 1; }
.qr__lab { font-size: 10px; font-weight: 600; letter-spacing: 0.2em; text-transform: uppercase; color: var(--muted); display: block; }
.qr__r b { font-family: var(--mono, monospace); font-size: 22px; font-weight: 700; letter-spacing: 0.08em; display: block; margin: 4px 0 14px; color: var(--tomato); }
.qr__r p { font-size: 13px; color: var(--muted); line-height: 1.6; margin-bottom: 10px; }
.qr__exp { font-size: 11px; color: var(--olive); }

.rest { display: flex; flex-direction: column; gap: 14px; }
.rest__p { font-size: 14px; color: var(--muted); line-height: 1.6; }
.rest__in { padding: 14px 18px; border: 2px solid var(--bord); border-radius: 4px; font-family: var(--mono, monospace); font-size: 18px; font-weight: 600; letter-spacing: 0.1em; text-transform: uppercase; outline: none; transition: border-color 150ms; }
.rest__in:focus { border-color: var(--tomato); }
.rest__sec { font-size: 11px; color: var(--muted); text-align: center; }
.rest__opt { display: flex; gap: 8px; align-items: center; font-size: 12px; color: var(--muted); }
.rest--ok { text-align: center; align-items: center; }
.rest__check { width: 64px; height: 64px; border-radius: 100%; background: var(--olive); color: #fff; display: inline-flex; align-items: center; justify-content: center; margin-bottom: 8px; }
.rest--ok h4 { font-family: var(--serif); font-size: 22px; font-weight: 700; }
.rest--ok p { font-size: 13px; color: var(--muted); }

/* ─────────── MEAL PLAN ADDITIONS ─────────── */
.mp__foot { flex-wrap: wrap; }
.mp__foot-acts { display: flex; gap: 8px; margin-left: auto; }
.mp__nosignup { display: flex; gap: 10px; align-items: center; padding: 14px 18px; background: #F4EEE3; border-radius: 4px; margin-top: 18px; font-size: 13px; color: var(--muted); }
.mp__nosignup svg { color: var(--olive); flex-shrink: 0; }
.mp__nosignup a { color: var(--tomato); font-weight: 600; cursor: pointer; }

/* ─────────── SHOPPING ADDITIONS ─────────── */
.sl__tot { padding: 0 18px; border-left: 1px solid var(--bord); border-right: 1px solid var(--bord); text-align: center; }
.sl--m .sl__tot { border: none; padding: 0; }
.sl__totl { display: block; font-size: 10px; font-weight: 600; letter-spacing: 0.2em; text-transform: uppercase; color: var(--muted); }
.sl__tot b { font-family: var(--serif); font-size: 22px; font-weight: 700; color: var(--tomato); display: block; }
.sl__totu { display: block; font-size: 10px; color: var(--muted); }
.sl__price { font-size: 11px; color: var(--muted); font-variant-numeric: tabular-nums; margin-right: 14px; }
.sl__rate { display: flex; align-items: center; gap: 8px; padding: 12px 14px; margin-top: 18px; background: #FBF4EA; border-radius: 4px; font-size: 11px; color: var(--muted); }
.sl__rate svg { color: var(--honey); flex-shrink: 0; }

/* Hide bar items neatly on mobile */
.sl--m .sl__bar { flex-wrap: wrap; gap: 12px; }
.sl--m .sl__prog { flex-basis: 100%; }

/* ─────────── ABOUT ─────────── */
.abt { padding: 48px 48px 64px; max-width: 960px; margin: 0 auto; }
.page--m .abt { padding: 24px 18px; }
.abt__h { font-family: var(--serif); font-size: 56px; font-weight: 700; line-height: 1.05; letter-spacing: -0.02em; margin: 14px 0 20px; }
.page--m .abt__h { font-size: 32px; }
.abt__h em { color: var(--tomato); font-style: italic; }
.abt__lead { font-family: var(--serif); font-style: italic; font-size: 22px; line-height: 1.55; color: var(--ink); margin-bottom: 48px; max-width: 720px; }
.abt__sh { font-family: var(--serif); font-size: 28px; font-weight: 700; margin-bottom: 24px; }
.abt__team { margin-bottom: 56px; }
.abt__people { display: grid; grid-template-columns: repeat(3, 1fr); gap: 24px; }
.page--m .abt__people { grid-template-columns: 1fr; }
.abt__p { padding: 24px; background: var(--surf); border: 1px solid var(--bord); border-radius: 6px; }
.abt__av { width: 56px; height: 56px; border-radius: 100%; background: var(--honey); color: var(--ink); font-family: var(--serif); font-weight: 700; display: inline-flex; align-items: center; justify-content: center; font-size: 24px; margin-bottom: 14px; }
.abt__p h4 { font-family: var(--serif); font-size: 20px; font-weight: 700; margin-bottom: 4px; }
.abt__p span { display: block; font-size: 11px; color: var(--muted); letter-spacing: 0.05em; margin-bottom: 12px; }
.abt__p p { font-size: 13px; color: var(--muted); line-height: 1.6; }
.abt__values { margin-bottom: 56px; }
.abt__vlist { display: grid; grid-template-columns: repeat(2, 1fr); gap: 18px; }
.page--m .abt__vlist { grid-template-columns: 1fr; }
.abt__vlist > div { padding: 20px; border-left: 3px solid var(--tomato); background: #FBF4EA; border-radius: 0 4px 4px 0; }
.abt__vlist b { display: block; font-family: var(--serif); font-size: 18px; margin-bottom: 6px; }
.abt__vlist span { font-size: 13px; color: var(--muted); line-height: 1.6; }
.abt__contact { padding: 32px; background: var(--ink); color: var(--bg); border-radius: 6px; text-align: center; }
.abt__contact h3 { font-family: var(--serif); font-size: 24px; font-weight: 700; margin-bottom: 8px; }
.abt__contact p { color: #aaa; }
.abt__contact a { color: var(--honey); border-bottom: 1px solid var(--honey); }

