/* ============================================================
   The Cookbook — Design System
   Editorial · Warm · Quietly luxurious
   ============================================================ */

:root {
  /* Palette — warmer take on khardori.com (navy + gold signature) */
  --bg:        #FAF6EE;   /* warm linen — softer than his pure white */
  --bg-soft:   #F2ECDD;
  --surface:   #FFFFFF;   /* clean card */
  --surface-2: #FDFAF3;
  --ink:       #1F1F1F;   /* charcoal body text */
  --ink-2:     #3A3A3A;
  --muted:     #6E6E6E;   /* his muted gray */
  --muted-2:   #9A9A9A;
  --line:      #E7E0CF;   /* warm hairline */
  --line-2:    #D6CCB1;
  --navy:      #03203D;   /* khardori signature navy */
  --navy-d:    #021629;
  --gold:      #B19057;   /* khardori signature gold/bronze */
  --gold-d:    #8E724A;
  --gold-soft: #D4B985;   /* lighter gold for warmth */
  --accent:    #03203D;   /* navy as primary accent */
  --accent-d:  #021629;

  /* Typography — nodding to khardori.com (Old Standard TT + Poppins) */
  --serif:  "Fraunces", "Old Standard TT", "Iowan Old Style", Georgia, serif;
  --sans:   "Inter", "Poppins", -apple-system, BlinkMacSystemFont, "Segoe UI", system-ui, sans-serif;

  /* Spacing scale */
  --s-1: 4px; --s-2: 8px; --s-3: 12px; --s-4: 16px; --s-5: 24px;
  --s-6: 32px; --s-7: 48px; --s-8: 64px; --s-9: 96px;

  /* Radius */
  --r-1: 6px; --r-2: 12px; --r-3: 20px; --r-4: 28px;

  /* Shadow */
  --shadow-1: 0 1px 2px rgba(27,23,20,.04), 0 4px 12px rgba(27,23,20,.04);
  --shadow-2: 0 4px 16px rgba(27,23,20,.06), 0 12px 40px rgba(27,23,20,.08);
  --shadow-3: 0 24px 80px rgba(27,23,20,.12);

  /* Motion */
  --ease: cubic-bezier(.2,.7,.2,1);
}

* { box-sizing: border-box; }
html, body { margin: 0; padding: 0; }
[hidden] { display: none !important; }
html { -webkit-font-smoothing: antialiased; -moz-osx-font-smoothing: grayscale; }
body {
  background: var(--bg);
  color: var(--ink);
  font-family: var(--sans);
  font-size: 16px;
  line-height: 1.55;
  font-feature-settings: "ss01", "cv11", "ss03";
  text-rendering: optimizeLegibility;
}

img { max-width: 100%; display: block; }
a { color: inherit; }

button { font-family: inherit; cursor: pointer; border: none; background: transparent; color: inherit; }

/* Subtle paper texture using a layered gradient */
body::before {
  content: "";
  position: fixed; inset: 0;
  pointer-events: none;
  background:
    radial-gradient(1200px 600px at 80% -10%, rgba(177,144,87,.07), transparent 60%),
    radial-gradient(900px 500px at -10% 110%, rgba(3,32,61,.04), transparent 60%);
  z-index: 0;
}

.view { display: none; min-height: 100vh; position: relative; z-index: 1; }
.view.active { display: block; }

/* ============================================================
   TOPBAR
   ============================================================ */
.topbar {
  position: sticky; top: 0; z-index: 50;
  background: rgba(246, 241, 231, 0.96);
  border-bottom: 1px solid var(--line);
}
.topbar__inner {
  max-width: 1240px;
  margin: 0 auto;
  padding: 14px 32px;
  display: flex; align-items: center; justify-content: space-between;
  gap: 24px;
}
.brand { display: flex; align-items: center; gap: 10px; }
.brand__name {
  font-family: var(--serif);
  font-weight: 500;
  font-size: 20px;
  letter-spacing: -0.015em;
  color: var(--ink);
}
.brand__name {
  color: var(--navy);
}
.topbar__nav { display: flex; align-items: center; gap: 6px; }
.iconbtn {
  width: 36px; height: 36px;
  border-radius: 999px;
  display: inline-flex; align-items: center; justify-content: center;
  color: var(--ink-2);
  transition: background .2s var(--ease), color .2s var(--ease);
}
.iconbtn:hover { background: var(--bg-soft); color: var(--ink); }

.addbtn {
  margin-left: 6px;
  display: inline-flex; align-items: center; gap: 8px;
  padding: 9px 16px;
  background: var(--ink);
  color: var(--bg);
  border-radius: 999px;
  font-size: 13.5px; font-weight: 500;
  letter-spacing: -0.005em;
  transition: transform .2s var(--ease), background .2s var(--ease);
}
.addbtn:hover { background: var(--accent); transform: translateY(-1px); }

.topbar--detail .topbar__detail-title {
  font-family: var(--serif);
  font-weight: 500;
  font-size: 17px;
  color: var(--ink);
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}

.backbtn {
  display: inline-flex; align-items: center; gap: 6px;
  font-size: 14px; color: var(--muted);
  padding: 8px 12px 8px 8px;
  border-radius: 999px;
  transition: background .2s var(--ease), color .2s var(--ease);
}
.backbtn:hover { background: var(--bg-soft); color: var(--ink); }

.cookbtn {
  margin-left: 6px;
  display: inline-flex; align-items: center; gap: 8px;
  padding: 9px 16px;
  background: var(--accent);
  color: white;
  border-radius: 999px;
  font-size: 13.5px; font-weight: 500;
  letter-spacing: -0.005em;
  transition: transform .2s var(--ease), background .2s var(--ease);
}
.cookbtn:hover { background: var(--accent-d); transform: translateY(-1px); }

/* ============================================================
   LIBRARY · HERO
   ============================================================ */
.library {
  max-width: 1240px;
  margin: 0 auto;
  padding: 40px 32px 80px;
}

.hero {
  display: grid;
  grid-template-columns: 1.05fr 1fr;
  gap: 56px;
  align-items: center;
  padding: 72px 0 56px;
}

.eyebrow {
  display: inline-block;
  font-size: 12px;
  font-weight: 600;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--gold-d);
  margin-bottom: 18px;
}

.hero__title {
  font-family: var(--serif);
  font-weight: 400;
  font-size: clamp(40px, 5.6vw, 64px);
  line-height: 1.02;
  letter-spacing: -0.025em;
  margin: 0 0 22px;
  color: var(--ink);
  font-variation-settings: "opsz" 144, "SOFT" 50;
}
.hero__title em {
  font-style: italic;
  font-weight: 400;
  color: var(--gold-d);
  font-variation-settings: "opsz" 144;
}

.hero__sub {
  font-size: 17px;
  line-height: 1.6;
  color: var(--muted);
  max-width: 480px;
  margin: 0 0 32px;
}

.hero__stats {
  display: flex; gap: 42px;
  padding-top: 26px;
  border-top: 1px solid var(--line);
}
.hero__stats > div {
  display: flex; flex-direction: column; gap: 4px;
}
.hero__stats .num {
  font-family: var(--serif);
  font-size: 32px; font-weight: 400;
  line-height: 1;
  color: var(--ink);
  font-feature-settings: "tnum";
}
.hero__stats .lbl {
  font-size: 12px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--muted);
}

.hero__art {
  position: relative;
  border-radius: var(--r-4);
  overflow: hidden;
  aspect-ratio: 4/5;
  box-shadow: var(--shadow-3);
}
.hero__art img {
  width: 100%; height: 100%; object-fit: cover;
  transition: transform .8s var(--ease);
}
.hero__art:hover img { transform: scale(1.03); }
.hero__chip {
  position: absolute; left: 18px; bottom: 18px;
  padding: 8px 14px;
  background: rgba(253, 251, 246, 0.97);
  border-radius: 999px;
  font-size: 12px; font-weight: 500;
  letter-spacing: 0.02em;
  color: var(--ink);
}

/* ============================================================
   FILTERS
   ============================================================ */
.filters {
  display: flex; align-items: center; justify-content: space-between;
  gap: 24px;
  padding: 0 0 28px;
  border-bottom: 1px solid var(--line);
  margin-bottom: 36px;
  flex-wrap: wrap;
}
.filters__chips { display: flex; gap: 8px; flex-wrap: wrap; }
.chip {
  padding: 8px 16px;
  font-size: 13.5px; font-weight: 500;
  letter-spacing: -0.005em;
  color: var(--muted);
  border-radius: 999px;
  border: 1px solid var(--line);
  background: var(--surface);
  transition: all .2s var(--ease);
}
.chip:hover { color: var(--ink); border-color: var(--line-2); }
.chip--active {
  background: var(--ink);
  color: var(--bg);
  border-color: var(--ink);
}

.filters__sort {
  display: flex; align-items: center; gap: 10px;
  font-size: 13px; color: var(--muted);
}
.sortwrap { position: relative; }
.sortbtn {
  display: inline-flex; align-items: center; gap: 6px;
  padding: 8px 14px;
  font-size: 13px; font-weight: 500;
  color: var(--ink);
  border: 1px solid var(--line);
  border-radius: 999px;
  background: var(--surface);
  transition: border-color .2s var(--ease);
  cursor: pointer;
}
.sortbtn:hover { border-color: var(--line-2); }
.sortbtn[aria-expanded="true"] { border-color: var(--ink); }

.sortmenu {
  position: absolute;
  top: calc(100% + 6px); right: 0;
  min-width: 240px;
  list-style: none; padding: 6px; margin: 0;
  background: var(--surface);
  border: 1px solid var(--line);
  border-radius: 12px;
  box-shadow: var(--shadow-2);
  z-index: 20;
}
.sortmenu li {
  padding: 9px 12px;
  font-size: 13px;
  color: var(--ink-2);
  border-radius: 8px;
  cursor: pointer;
  transition: background .15s var(--ease), color .15s var(--ease);
}
.sortmenu li:hover { background: var(--bg-soft); color: var(--ink); }
.sortmenu li.is-current {
  background: var(--ink); color: var(--bg);
}
.sortmenu li.is-current::after {
  content: " ✓";
  font-weight: 700;
}

/* Notes editor */
.note--editor {
  grid-column: 1 / -1;
  display: flex; flex-direction: column; gap: 10px;
  padding: 18px 20px;
  background: var(--surface);
  border: 1.5px solid var(--navy);
  border-radius: var(--r-2);
}
.note--editor textarea {
  width: 100%;
  min-height: 80px;
  padding: 10px 12px;
  border: 1px solid var(--line-2);
  border-radius: 8px;
  font-family: var(--serif);
  font-size: 15px;
  font-style: italic;
  line-height: 1.5;
  color: var(--ink-2);
  background: var(--bg);
  resize: vertical;
}
.note--editor textarea:focus {
  outline: 2px solid var(--navy);
  outline-offset: 1px;
  border-color: var(--navy);
}
.note__editor-actions {
  display: flex; gap: 8px; justify-content: flex-end;
}
.note__btn {
  font-size: 13px; font-weight: 500;
  padding: 7px 14px;
  border-radius: 999px;
  cursor: pointer;
}
.note__btn--save {
  background: var(--navy);
  color: white;
  border: 1px solid var(--navy);
}
.note__btn--save:hover { background: var(--navy-d); }
.note__btn--cancel {
  background: transparent;
  color: var(--muted);
  border: 1px solid var(--line-2);
}
.note__btn--cancel:hover { color: var(--ink); border-color: var(--ink); }
.note__delete {
  position: absolute; top: 10px; right: 10px;
  width: 22px; height: 22px;
  border-radius: 999px;
  background: transparent;
  color: var(--muted-2);
  font-size: 14px; line-height: 1;
  display: inline-flex; align-items: center; justify-content: center;
  opacity: 0;
  transition: opacity .2s;
}
.note:hover .note__delete { opacity: 1; }
.note__delete:hover { background: var(--bg-soft); color: var(--accent); }

/* ============================================================
   GRID · RECIPE CARDS
   ============================================================ */
.grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 32px;
}

.card {
  text-decoration: none;
  color: inherit;
  display: flex; flex-direction: column;
  background: var(--surface);
  border-radius: var(--r-3);
  overflow: hidden;
  border: 1px solid var(--line);
  transition: transform .35s var(--ease), box-shadow .35s var(--ease), border-color .35s var(--ease);
}
.card:hover {
  transform: translateY(-3px);
  box-shadow: var(--shadow-2);
  border-color: var(--line-2);
}
.card__img {
  position: relative;
  aspect-ratio: 4/3;
  overflow: hidden;
  background: var(--bg-soft);
}
.card__img img {
  width: 100%; height: 100%; object-fit: cover;
  transition: transform .8s var(--ease);
}
.card:hover .card__img img { transform: scale(1.06); }

.card__time {
  position: absolute; top: 12px; right: 12px;
  padding: 6px 11px;
  background: rgba(253, 251, 246, 0.97);
  border-radius: 999px;
  font-size: 11.5px; font-weight: 600;
  letter-spacing: 0.02em;
  color: var(--ink);
  font-feature-settings: "tnum";
}

.card__body { padding: 22px 22px 24px; display: flex; flex-direction: column; gap: 8px; }
.card__tag {
  font-size: 11.5px; font-weight: 600;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--gold-d);
}
.card__title {
  font-family: var(--serif);
  font-weight: 500;
  font-size: 24px;
  line-height: 1.15;
  letter-spacing: -0.02em;
  margin: 4px 0 6px;
  color: var(--ink);
  font-variation-settings: "opsz" 36;
}
.card__meta {
  display: flex; align-items: center; gap: 8px;
  font-size: 13.5px;
  color: var(--muted);
}
.card__meta .dot { color: var(--muted-2); }
.card__meta .rating { color: var(--gold); letter-spacing: 1px; font-size: 12px; }

/* No-photo card — clean text-only treatment */
.card--no-photo {
  background: linear-gradient(180deg, var(--surface-2), var(--surface));
  border-color: var(--line);
}
.card--no-photo .card__body {
  padding: 28px 22px 26px;
  min-height: 180px;
  display: flex; flex-direction: column; gap: 8px;
}
.card--no-photo .card__title {
  font-size: 26px;
  margin-top: 6px;
}
.card--no-photo:hover {
  background: linear-gradient(180deg, var(--surface), var(--surface-2));
}

.card--empty {
  display: flex; flex-direction: column;
  align-items: center; justify-content: center;
  padding: 40px 24px;
  border: 1.5px dashed var(--line-2);
  background: transparent;
  text-align: center;
  gap: 14px;
  min-height: 320px;
}
.card--empty:hover { border-color: var(--accent); transform: none; box-shadow: none; }
.card__plus {
  width: 48px; height: 48px;
  border-radius: 999px;
  background: var(--bg-soft);
  display: flex; align-items: center; justify-content: center;
  color: var(--accent);
}
.card--empty p {
  margin: 0;
  font-family: var(--serif);
  font-size: 18px; font-weight: 500;
  color: var(--ink);
  letter-spacing: -0.01em;
}
.card__hint {
  font-size: 13px;
  color: var(--muted);
  font-style: italic;
}

.library__foot {
  margin-top: 80px;
  padding-top: 28px;
  border-top: 1px solid var(--line);
  font-size: 13px;
  color: var(--muted-2);
  text-align: center;
}

/* ============================================================
   RECIPE DETAIL
   ============================================================ */
.recipe { max-width: 1240px; margin: 0 auto; padding: 0 32px 120px; }

.recipe__hero {
  display: grid;
  grid-template-columns: 1fr 1.1fr;
  gap: 64px;
  padding: 64px 0 56px;
  align-items: center;
  border-bottom: 1px solid var(--line);
}
.recipe__hero--no-photo {
  grid-template-columns: 1fr;
  max-width: 720px;
}

.recipe__title {
  font-family: var(--serif);
  font-weight: 400;
  font-size: clamp(40px, 5.5vw, 68px);
  line-height: 1.0;
  letter-spacing: -0.028em;
  margin: 0 0 18px;
  font-variation-settings: "opsz" 144, "SOFT" 30;
}

.recipe__lede {
  font-size: 18px;
  line-height: 1.55;
  color: var(--ink-2);
  margin: 0 0 32px;
  max-width: 520px;
  font-weight: 400;
}

.recipe__meta {
  display: grid;
  grid-template-columns: repeat(4, auto);
  gap: 32px;
  padding: 22px 0;
  border-top: 1px solid var(--line);
  border-bottom: 1px solid var(--line);
  margin-bottom: 22px;
}
.meta { display: flex; flex-direction: column; gap: 4px; }
.meta__lbl {
  font-size: 11px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--muted);
}
.meta__val {
  font-family: var(--serif);
  font-size: 20px;
  font-weight: 500;
  color: var(--ink);
  letter-spacing: -0.01em;
  font-feature-settings: "tnum";
}
.meta__val.rating, .recipe__meta .meta:last-child .meta__val { color: var(--gold); letter-spacing: 0.05em; }

.recipe__source {
  font-size: 13px;
  color: var(--muted);
  display: flex; gap: 8px; align-items: center;
}
.recipe__source a { color: var(--accent); text-decoration: none; border-bottom: 1px solid currentColor; padding-bottom: 1px; }
.recipe__source .dot { color: var(--muted-2); }

.recipe__heroArt {
  border-radius: var(--r-4);
  overflow: hidden;
  aspect-ratio: 5/6;
  box-shadow: var(--shadow-3);
}
.recipe__heroArt img { width: 100%; height: 100%; object-fit: cover; }

/* Body — two column */
.recipe__body {
  display: grid;
  grid-template-columns: 320px 1fr;
  gap: 72px;
  padding-top: 56px;
}

/* Left column = Essentials (optional) + Ingredients, sticky together */
.left-col {
  position: sticky; top: 88px;
  align-self: start;
  display: flex; flex-direction: column; gap: 40px;
}
.right-col { display: flex; flex-direction: column; }

/* Shared section title */
.section-title {
  font-family: var(--serif);
  font-size: 26px; font-weight: 500;
  letter-spacing: -0.02em;
  margin: 0 0 14px;
  padding-bottom: 12px;
  border-bottom: 1.5px solid var(--ink);
  color: var(--ink);
}

/* Essentials block */
.essentials__list { list-style: none; padding: 0; margin: 0; }
.essentials__list li {
  padding: 10px 0;
  border-bottom: 1px dashed var(--line);
  font-size: 14px;
  color: var(--ink-2);
  line-height: 1.6;
}
.essentials__list li:last-child { border-bottom: none; }
.essentials__list strong {
  color: var(--navy);
  font-weight: 600;
  margin-right: 4px;
}

/* Ingredients */
.ingredients__head {
  margin-bottom: 4px;
}
.ingredients__list { list-style: none; padding: 0; margin: 0; }
.ingredients__list li {
  display: grid;
  grid-template-columns: 18px 76px 1fr;
  gap: 12px;
  align-items: baseline;
  padding: 12px 0;
  border-bottom: 1px dashed var(--line);
  font-size: 14.5px;
  cursor: pointer;
  transition: opacity .25s var(--ease);
}
.ingredients__list li:last-child { border-bottom: none; }
.ingredients__list li.checked { opacity: 0.4; }
.ingredients__list li.checked .ingredients__name { text-decoration: line-through; text-decoration-thickness: 1px; }

.ingredients__check {
  width: 16px; height: 16px;
  border: 1.5px solid var(--line-2);
  border-radius: 3px;
  display: inline-flex; align-items: center; justify-content: center;
  transition: all .2s var(--ease);
  background: var(--surface);
}
.ingredients__list li.checked .ingredients__check {
  background: var(--navy);
  border-color: var(--navy);
}
.ingredients__list li.checked .ingredients__check::after {
  content: "✓"; color: white; font-size: 11px; font-weight: 700; line-height: 1;
}
.ingredients__qty {
  font-family: var(--serif);
  font-size: 15px;
  font-weight: 500;
  color: var(--ink);
  font-feature-settings: "tnum", "frac";
}
.ingredients__name { color: var(--ink-2); line-height: 1.4; }
.ingredients__name em {
  font-style: italic;
  color: var(--muted);
}
.ingredients__list li.ingredients__divider {
  display: block;
  border: none;
  padding: 14px 0 6px;
  cursor: default;
}
.ingredients__divider-text {
  font-family: var(--sans);
  font-size: 11px;
  font-weight: 600;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--gold-d);
}
.card__from-mom {
  font-size: 11px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--gold-d);
  font-weight: 600;
}

/* Method — bulleted, with bold action-verb leads */
.method__list { list-style: none; padding: 0; margin: 0; }
.method__list li {
  padding: 18px 0;
  border-bottom: 1px solid var(--line);
  font-size: 16px;
  line-height: 1.65;
  color: var(--ink-2);
  display: grid;
  grid-template-columns: 14px 1fr;
  gap: 14px;
  align-items: baseline;
}
.method__list li::before {
  content: "";
  width: 6px; height: 6px;
  background: var(--gold-d);
  border-radius: 50%;
  margin-top: 10px;
}
.method__list li:last-child { border-bottom: none; }
/* Inline measurements bolded inside step body */
.method__list strong {
  color: var(--ink);
  font-weight: 600;
  letter-spacing: -0.005em;
}
/* Step header (action verb) — navy, slightly heavier */
.method__list .method__action {
  color: var(--navy);
  font-weight: 700;
  letter-spacing: -0.005em;
}

/* Tips — same family, slightly softer */
.tips { margin-top: 48px; padding-top: 32px; border-top: 1px solid var(--line); }
.tips__list { list-style: none; padding: 0; margin: 0; }
.tips__list li {
  padding: 12px 0;
  font-size: 15px;
  line-height: 1.6;
  color: var(--ink-2);
  display: grid;
  grid-template-columns: 14px 1fr;
  gap: 14px;
  align-items: baseline;
}
.tips__list li::before {
  content: "";
  width: 5px; height: 5px;
  background: var(--gold);
  border-radius: 50%;
  margin-top: 10px;
}
.tips__list strong {
  color: var(--navy);
  font-weight: 600;
}

/* From Mom badge */
.recipe__from-mom {
  display: inline-block;
  margin: 0 0 16px;
  padding: 5px 12px;
  font-size: 11px;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--gold-d);
  border: 1px solid var(--gold);
  border-radius: 999px;
  font-weight: 600;
}

/* Family filter chip */
.chip--family {
  border-color: var(--gold);
  color: var(--gold-d);
}
.chip--family:hover { color: var(--gold-d); border-color: var(--gold-d); }

/* Search bar */
.searchbar {
  display: flex; align-items: center; gap: 10px;
  padding: 12px 16px;
  background: var(--surface);
  border: 1px solid var(--line);
  border-radius: 999px;
  margin-bottom: 18px;
  color: var(--muted);
}
.searchbar svg { flex-shrink: 0; color: var(--muted); }
.searchbar input {
  flex: 1; min-width: 0;
  border: none; outline: none; background: transparent;
  font-family: var(--sans);
  font-size: 15px;
  color: var(--ink);
}
.searchbar input::placeholder { color: var(--muted-2); }
.searchclose {
  flex-shrink: 0;
  width: 22px; height: 22px;
  border-radius: 999px;
  font-size: 17px; line-height: 1;
  color: var(--muted);
  background: var(--bg-soft);
  display: inline-flex; align-items: center; justify-content: center;
  cursor: pointer;
}
.searchclose:hover { color: var(--ink); background: var(--line); }

/* Multi-select chip — same active style works for any number of active chips */
.chip--family.chip--active {
  background: var(--gold-d);
  color: white;
  border-color: var(--gold-d);
}

/* When multi-select is active, show a small clear-all hint */
.filters__clear {
  display: none;
  font-size: 12px;
  color: var(--muted);
  background: transparent;
  border: none;
  padding: 4px 8px;
  cursor: pointer;
  text-decoration: underline;
  text-underline-offset: 2px;
}
.filters__clear:hover { color: var(--accent); }
.filters.has-active-filters .filters__clear { display: inline-block; }

/* Notes section */
.notes { margin-top: 48px; padding-top: 32px; border-top: 1px solid var(--line); }
.notes__cards { display: grid; gap: 14px; grid-template-columns: 1fr 1fr; }
.note {
  padding: 22px 24px;
  background: var(--surface);
  border: 1px solid var(--line);
  border-radius: var(--r-2);
  position: relative;
  text-align: left;
  transition: border-color .2s var(--ease);
}
.note:hover { border-color: var(--line-2); }
.note__date {
  font-size: 11px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--gold-d);
  font-weight: 600;
}
.note p {
  margin: 8px 0 0;
  font-family: var(--serif);
  font-size: 16px;
  font-style: italic;
  line-height: 1.5;
  color: var(--ink-2);
}
.note--add {
  display: flex; align-items: center; justify-content: center;
  gap: 8px;
  background: transparent;
  border: 1.5px dashed var(--line-2);
  color: var(--muted);
  font-size: 13.5px;
  font-weight: 500;
  cursor: pointer;
  font-family: var(--sans);
  font-style: normal;
  min-height: 96px;
}
.note--add:hover { color: var(--accent); border-color: var(--accent); }

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width: 980px) {
  .topbar__inner { padding: 12px 22px; }
  .library, .recipe { padding-left: 22px; padding-right: 22px; }
  .hero { grid-template-columns: 1fr; gap: 36px; padding: 48px 0 36px; }
  .hero__art { aspect-ratio: 16/10; }
  .hero__sub { font-size: 16px; }
  .grid { grid-template-columns: repeat(2, 1fr); gap: 22px; }
  .recipe__hero { grid-template-columns: 1fr; gap: 32px; padding: 40px 0 36px; }
  .recipe__heroArt { aspect-ratio: 16/10; order: -1; }
  .recipe__body { grid-template-columns: 1fr; gap: 48px; padding-top: 36px; }
  .left-col { position: static; }
  .recipe__meta { gap: 24px; grid-template-columns: repeat(2, 1fr); }
  .notes__cards { grid-template-columns: 1fr; }
}

@media (max-width: 640px) {
  .topbar__inner { padding: 11px 16px; gap: 8px; }
  .topbar__nav .iconbtn:nth-child(2) { display: none; } /* hide filter on mobile */
  .addbtn span { display: none; }
  .addbtn { padding: 9px 11px; }
  .topbar--detail .topbar__detail-title { display: none; }
  .cookbtn span { display: none; }
  .cookbtn { padding: 9px 11px; }

  .library, .recipe { padding-left: 18px; padding-right: 18px; padding-bottom: 56px; }
  .hero { padding: 32px 0 28px; gap: 28px; }
  .hero__title { font-size: 36px; }
  .hero__sub { font-size: 15.5px; margin-bottom: 24px; }
  .hero__stats { gap: 26px; }
  .hero__stats .num { font-size: 26px; }

  .filters { padding: 18px 0; gap: 14px; }
  .filters__chips { gap: 6px; }
  .chip { padding: 7px 13px; font-size: 12.5px; }
  .filters__sort { font-size: 12px; }

  .grid { grid-template-columns: 1fr; gap: 18px; }
  .card__title { font-size: 22px; }
  .card__body { padding: 18px 18px 22px; }

  .recipe__hero { padding: 28px 0 28px; gap: 24px; }
  .recipe__title { font-size: 38px; }
  .recipe__lede { font-size: 16px; margin-bottom: 22px; }
  .recipe__meta { padding: 16px 0; gap: 16px 24px; }
  .meta__val { font-size: 17px; }

  .section-title { font-size: 22px; }
  .ingredients__list li { grid-template-columns: 16px 64px 1fr; gap: 10px; padding: 11px 0; font-size: 14px; }
  .method__list li { padding: 14px 0; font-size: 15px; gap: 12px; }
  .tips__list li { padding: 10px 0; font-size: 14.5px; }
}

/* ============================================================
   LOGIN
   ============================================================ */
.login {
  min-height: 100vh;
  display: flex; flex-direction: column;
  align-items: center; justify-content: center;
  padding: 40px 24px;
  gap: 10px;
  text-align: center;
}
.login__brand {
  margin-bottom: 28px;
}
.login__brand .brand__name {
  font-family: var(--serif);
  font-size: 22px;
  font-weight: 500;
  letter-spacing: -0.015em;
  color: var(--navy);
}
.login__title {
  font-family: var(--serif);
  font-size: clamp(34px, 5vw, 44px);
  font-weight: 400;
  letter-spacing: -0.025em;
  margin: 0;
  color: var(--ink);
}
.login__sub {
  color: var(--muted);
  margin: 0 0 24px;
  font-size: 15px;
}
.login__form {
  display: flex; flex-direction: column;
  gap: 12px;
  width: 100%;
  max-width: 320px;
}
.login__form input {
  font-family: var(--sans);
  font-size: 16px;        /* >= 16 prevents iOS Safari zoom on focus */
  padding: 14px 18px;
  border: 1px solid var(--line-2);
  border-radius: 12px;
  background: var(--surface);
  color: var(--ink);
  text-align: center;
  letter-spacing: 0.12em;
}
.login__form input:focus {
  outline: 2px solid var(--navy);
  outline-offset: 1px;
  border-color: var(--navy);
}
.login__btn {
  padding: 13px 20px;
  background: var(--ink);
  color: var(--bg);
  border-radius: 999px;
  font-size: 14px;
  font-weight: 500;
  letter-spacing: -0.005em;
  cursor: pointer;
  transition: background .2s var(--ease);
}
.login__btn:hover { background: var(--navy); }
.login__btn:disabled { opacity: 0.5; cursor: not-allowed; }
.login__error {
  background: rgba(176, 90, 43, 0.08);
  color: var(--accent);
  padding: 10px 14px;
  border-radius: 10px;
  font-size: 13px;
  text-align: center;
}

/* ============================================================
   GROCERY LIST
   ============================================================ */

/* Cart icon with badge */
.cartbtn { position: relative; }
.cartbtn__badge {
  position: absolute;
  top: -2px; right: -2px;
  background: var(--accent);
  color: white;
  font-size: 10px; font-weight: 700;
  min-width: 16px; height: 16px;
  border-radius: 999px;
  display: inline-flex; align-items: center; justify-content: center;
  padding: 0 4px;
  line-height: 1;
  box-shadow: 0 0 0 2px var(--bg);
}

/* "Add to Grocery List" button on recipe page */
.recipe__actions { margin-top: 18px; }
.add-grocery-btn {
  display: inline-flex; align-items: center; gap: 8px;
  padding: 10px 18px;
  background: var(--ink);
  color: var(--bg);
  border-radius: 999px;
  font-size: 13.5px; font-weight: 500;
  letter-spacing: -0.005em;
  transition: background .2s var(--ease), transform .2s var(--ease), color .2s var(--ease);
}
.add-grocery-btn:hover { background: var(--accent); transform: translateY(-1px); }
.add-grocery-btn.is-added {
  background: transparent;
  color: var(--ink);
  border: 1px solid var(--line-2);
}
.add-grocery-btn.is-added:hover {
  background: var(--bg-soft);
  border-color: var(--ink);
  color: var(--ink);
  transform: none;
}
.add-grocery-btn.is-added svg { display: none; }

/* Email button in grocery topbar */
.emailbtn {
  display: inline-flex; align-items: center; gap: 8px;
  padding: 9px 16px;
  background: var(--accent);
  color: white;
  border-radius: 999px;
  font-size: 13.5px; font-weight: 500;
  transition: background .2s var(--ease), transform .2s var(--ease);
}
.emailbtn:hover { background: var(--accent-d); transform: translateY(-1px); }
.emailbtn:disabled {
  background: var(--bg-soft);
  color: var(--muted);
  cursor: not-allowed;
}

/* Grocery view layout */
.grocery { max-width: 760px; margin: 0 auto; padding: 48px 32px 80px; }
.grocery__head {
  padding-bottom: 22px;
  border-bottom: 1.5px solid var(--ink);
  margin-bottom: 22px;
}
.grocery__title {
  font-family: var(--serif);
  font-size: clamp(36px, 4vw, 48px);
  font-weight: 500;
  letter-spacing: -0.025em;
  margin: 0;
  color: var(--ink);
}
.grocery__sub {
  font-size: 13.5px;
  color: var(--muted);
  margin: 6px 0 0;
}

.grocery__email-line {
  display: flex; align-items: center; flex-wrap: wrap;
  gap: 8px;
  font-size: 13px;
  color: var(--muted);
  padding: 14px 0;
  margin-bottom: 24px;
  border-bottom: 1px solid var(--line);
}
.grocery__email-line a {
  color: var(--navy);
  text-decoration: none;
  border-bottom: 1px dashed var(--navy);
  padding-bottom: 1px;
}
.emaillink {
  font-size: 12px;
  color: var(--accent);
  text-decoration: underline;
  text-underline-offset: 2px;
  background: none; border: none;
  padding: 0; cursor: pointer;
}
.emaillink:hover { color: var(--accent-d); }
.emailedit {
  display: inline-flex; align-items: center; gap: 6px;
}
.emailedit input {
  font-family: var(--sans);
  font-size: 13px;
  padding: 4px 10px;
  border: 1px solid var(--line-2);
  border-radius: 6px;
  background: var(--surface);
  color: var(--ink);
  min-width: 220px;
}
.emailedit input:focus {
  outline: 2px solid var(--navy);
  outline-offset: 1px;
  border-color: var(--navy);
}

/* Aisle sections */
.aisle { margin-bottom: 28px; }
.aisle__title {
  font-family: var(--sans);
  font-size: 11.5px; font-weight: 700;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--gold-d);
  margin: 0 0 8px;
  padding-bottom: 6px;
  border-bottom: 1px solid var(--line);
}
.aisle__items { list-style: none; padding: 0; margin: 0; }
.aisle__items li {
  display: grid;
  grid-template-columns: 18px 96px 1fr;
  gap: 14px;
  align-items: baseline;
  padding: 12px 0;
  border-bottom: 1px dashed var(--line);
  cursor: pointer;
  transition: opacity .25s;
}
.aisle__items li:last-child { border-bottom: none; }
.aisle__items li.checked { opacity: 0.4; }
.aisle__items li.checked .aisle__name { text-decoration: line-through; text-decoration-thickness: 1px; }
.aisle__check {
  width: 16px; height: 16px;
  border: 1.5px solid var(--line-2);
  border-radius: 3px;
  background: var(--surface);
  display: inline-flex; align-items: center; justify-content: center;
}
.aisle__items li.checked .aisle__check { background: var(--navy); border-color: var(--navy); }
.aisle__items li.checked .aisle__check::after {
  content: '✓'; color: white; font-size: 11px; font-weight: 700; line-height: 1;
}
.aisle__qty {
  font-family: var(--serif);
  font-size: 15px; font-weight: 500;
  color: var(--ink);
  font-feature-settings: 'tnum';
}
.aisle__name {
  color: var(--ink-2);
  font-size: 14.5px;
  line-height: 1.4;
}
.aisle__name em {
  font-style: italic;
  color: var(--muted);
}
.aisle__sources {
  display: block;
  font-size: 11px;
  letter-spacing: 0.04em;
  color: var(--muted);
  margin-top: 3px;
  font-style: italic;
}

/* Empty state */
.grocery__empty {
  text-align: center;
  padding: 56px 20px;
  color: var(--muted);
}
.grocery__empty p { margin: 4px 0; font-size: 15px; }
.grocery__empty .hint { font-size: 13px; color: var(--muted-2); }

.grocery__foot {
  margin-top: 36px;
  padding-top: 20px;
  border-top: 1px solid var(--line);
  text-align: center;
}
.clearbtn {
  font-size: 13px;
  color: var(--muted);
  padding: 6px 14px;
  border-radius: 999px;
  border: 1px solid var(--line-2);
  background: transparent;
  transition: all .2s var(--ease);
}
.clearbtn:hover { color: var(--accent); border-color: var(--accent); }

/* Responsive — grocery */
@media (max-width: 640px) {
  .grocery { padding: 28px 18px 56px; }
  .grocery__title { font-size: 32px; }
  .emailbtn span { display: none; }
  .emailbtn { padding: 9px 11px; }
  .aisle__items li { grid-template-columns: 16px 80px 1fr; gap: 10px; padding: 10px 0; }
  .aisle__qty { font-size: 14px; }
  .aisle__name { font-size: 14px; }
  .emailedit input { min-width: 180px; }
}

/* ============================================================
   PRINT — clean kitchen sheet (B&W, single column, no chrome)
   ============================================================ */
@media print {
  /* Page setup — small margins */
  @page { margin: 0.5in 0.6in; size: auto; }

  /* Reset paper */
  body { background: white !important; color: black !important; }
  body::before { display: none !important; }

  /* Hide all UI chrome */
  .topbar, .filters, .grid, .library__foot,
  .recipe__heroArt, .notes, .note--add,
  .recipe__actions, #view-library, #view-grocery { display: none !important; }

  /* Force the recipe view to show even if not active */
  #view-recipe { display: block !important; }

  /* Tighten the recipe layout */
  .recipe { padding: 0 !important; max-width: none !important; }
  .recipe__hero {
    display: block !important;
    padding: 0 0 14px !important;
    border-bottom: 1.5px solid black !important;
    margin-bottom: 16px !important;
  }
  .recipe__heroText { display: block !important; }
  .eyebrow {
    color: #444 !important;
    font-size: 9.5px !important;
    margin-bottom: 6px !important;
    letter-spacing: 0.16em !important;
  }
  .recipe__title {
    color: black !important;
    font-size: 26px !important;
    line-height: 1.05 !important;
    margin: 0 0 8px !important;
    letter-spacing: -0.02em !important;
  }
  .recipe__lede {
    color: #222 !important;
    font-size: 12px !important;
    line-height: 1.45 !important;
    margin: 0 0 12px !important;
    max-width: none !important;
  }
  .recipe__from-mom {
    color: #444 !important;
    border: 1px solid #444 !important;
    margin-bottom: 10px !important;
    padding: 3px 9px !important;
    font-size: 9px !important;
  }
  .recipe__meta {
    padding: 8px 0 !important;
    gap: 16px !important;
    grid-template-columns: repeat(3, auto) !important;
    border-top: 1px solid #999 !important;
    border-bottom: 1px solid #999 !important;
  }
  .meta__lbl { color: #444 !important; font-size: 8.5px !important; }
  .meta__val { color: black !important; font-size: 13px !important; }
  .recipe__source {
    font-size: 10px !important;
    color: #555 !important;
    margin-top: 6px !important;
  }
  .recipe__source a {
    color: #555 !important;
    border-bottom: none !important;
  }
  .recipe__source a::after {
    content: " (" attr(href) ")";
    font-size: 9px;
    color: #888;
  }

  /* Body — single column on print */
  .recipe__body {
    display: block !important;
    grid-template-columns: 1fr !important;
    padding-top: 14px !important;
  }
  .left-col, .right-col { position: static !important; display: block !important; gap: 0 !important; }

  /* Section titles — flat black bars */
  .section-title {
    color: black !important;
    font-size: 14px !important;
    margin: 16px 0 6px !important;
    padding-bottom: 4px !important;
    border-bottom: 1px solid black !important;
    break-after: avoid;
  }

  /* Essentials, ingredients, method, tips — compact */
  .essentials__list li,
  .ingredients__list li,
  .method__list li,
  .tips__list li {
    padding: 4px 0 !important;
    font-size: 11px !important;
    line-height: 1.4 !important;
    color: black !important;
    border-color: #bbb !important;
    break-inside: avoid;
  }
  .essentials__list strong,
  .method__list strong,
  .tips__list strong {
    color: black !important;
    font-weight: 700 !important;
  }

  .ingredients__list li {
    grid-template-columns: 10px 60px 1fr !important;
    gap: 8px !important;
    cursor: default !important;
  }
  .ingredients__check {
    width: 9px !important; height: 9px !important;
    border: 1px solid #444 !important;
    background: white !important;
  }
  .ingredients__qty { color: black !important; font-size: 11px !important; }
  .ingredients__name { color: black !important; }

  .method__list li {
    grid-template-columns: 8px 1fr !important;
    gap: 8px !important;
    padding: 6px 0 !important;
  }
  .method__list li::before {
    background: black !important;
    width: 4px !important; height: 4px !important;
    margin-top: 8px !important;
  }
  .tips__list li {
    grid-template-columns: 8px 1fr !important;
    gap: 8px !important;
  }
  .tips__list li::before { background: black !important; width: 3px !important; height: 3px !important; }

  /* Don't break sections across pages awkwardly */
  .essentials, .ingredients, .method, .tips { break-inside: avoid-page; }
}
