/* ============================================================
   SAVEUR-style theme for Annette's recipe collection
   Worldly travel-magazine: stately serif, full-bleed food
   photography, cream base, deep ink, coral-vermillion accent.
   Light backgrounds only. Mood from photos + serif + accents.
   ============================================================ */

:root{
  /* --- palette (light/cream only) --- */
  --paper:      #faf6ee;   /* warm ivory page */
  --paper-2:    #f3ecdf;   /* slightly deeper band */
  --paper-3:    #efe6d6;   /* card wash / inset */
  --ink:        #1d1a16;   /* near-black headline ink */
  --ink-soft:   #423c33;   /* body text */
  --ink-mute:   #7a7163;   /* captions, meta */
  --coral:      #d9512c;   /* signature Saveur vermillion */
  --coral-deep: #b8401f;
  --olive:      #5c6049;   /* muted worldly green accent */
  --rule:       #d8cdb8;   /* hairline keylines on paper */
  --rule-soft:  #e6ddcc;
  --gold:       #9a7b3f;

  /* --- type --- */
  --display: "Playfair Display", "Times New Roman", serif;
  --serif:   "EB Garamond", Georgia, "Times New Roman", serif;
  --label:   "Saira Semi Condensed", "Arial Narrow", sans-serif;

  /* --- container --- */
  --wrap: min(92%, 1280px);
  --wrap-wide: min(94%, 1560px);
}

*{ box-sizing:border-box; }
html,body{ margin:0; padding:0; }
html{ -webkit-text-size-adjust:100%; }

body{
  background:var(--paper);
  color:var(--ink-soft);
  font-family:var(--serif);
  font-size:19px;
  line-height:1.65;
  font-feature-settings:"liga" 1, "kern" 1, "onum" 1;
  text-rendering:optimizeLegibility;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden; /* belt-and-suspenders; real causes fixed below */
}

img{ display:block; max-width:100%; height:auto; }
a{ color:inherit; text-decoration:none; }

.wrap{ width:var(--wrap); margin-inline:auto; }
.wrap-wide{ width:var(--wrap-wide); margin-inline:auto; }

/* shared kicker / label style — tracked-out condensed caps */
.kicker{
  font-family:var(--label);
  text-transform:uppercase;
  letter-spacing:.26em;
  font-weight:600;
  font-size:.72rem;
  color:var(--coral);
}
.eyebrow{
  font-family:var(--label);
  text-transform:uppercase;
  letter-spacing:.32em;
  font-weight:500;
  font-size:.7rem;
  color:var(--ink-mute);
}

/* ============================================================
   TOP BAR
   ============================================================ */
.topbar{
  background:var(--paper);
  border-bottom:1px solid var(--rule);
}
.topbar__inner{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:1rem;
  padding:.85rem 0;
}
.topbar__brand{
  font-family:var(--display);
  font-weight:700;
  letter-spacing:.30em;
  text-transform:uppercase;
  font-size:1.02rem;
  color:var(--ink);
  white-space:nowrap;
}
.topbar__nav{
  display:flex;
  gap:1.6rem;
  font-family:var(--label);
  text-transform:uppercase;
  letter-spacing:.2em;
  font-size:.72rem;
  font-weight:500;
  color:var(--ink-mute);
  flex-wrap:wrap;
  justify-content:flex-end;
}
.topbar__nav a{ transition:color .2s; }
.topbar__nav a:hover{ color:var(--coral); }
.topbar__date{
  font-family:var(--label);
  text-transform:uppercase;
  letter-spacing:.22em;
  font-size:.66rem;
  color:var(--ink-mute);
}

/* ============================================================
   MASTHEAD HERO (homepage) — giant wordmark over full-bleed photo
   ============================================================ */
.masthead{
  position:relative;
  width:100%;
  isolation:isolate;
  background:var(--ink);   /* fallback while photo loads; covered by image */
  overflow:hidden;
}
.masthead__photo{
  position:absolute;
  inset:0;
  width:100%;
  height:100%;
  object-fit:cover;
  z-index:-2;
}
/* a soft warm wash so the cream wordmark reads, never a dark UI panel */
.masthead::after{
  content:"";
  position:absolute;
  inset:0;
  z-index:-1;
  background:
    radial-gradient(120% 90% at 50% 30%, rgba(20,16,10,.10), rgba(20,16,10,.34) 70%),
    linear-gradient(180deg, rgba(20,16,10,.18), rgba(20,16,10,.30));
}
.masthead__inner{
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  text-align:center;
  padding:clamp(3.5rem,9vw,8rem) 0 clamp(2.5rem,6vw,5rem);
  min-height:clamp(340px,62vh,640px);
}
.wordmark{
  font-family:var(--display);
  font-weight:800;
  color:#f6efe0;
  line-height:.86;
  letter-spacing:.02em;
  margin:0;
  font-size:clamp(3.6rem, 17vw, 15rem);
  text-shadow:0 2px 30px rgba(0,0,0,.28);
  width:100%;
}
.wordmark__rule{
  display:flex;
  align-items:center;
  gap:1.2rem;
  width:min(92%,640px);
  margin:clamp(.6rem,2vw,1.4rem) auto 0;
}
.wordmark__rule::before,
.wordmark__rule::after{
  content:"";
  height:1px;
  flex:1;
  background:rgba(246,239,224,.55);
}
.wordmark__tag{
  font-family:var(--serif);
  font-style:italic;
  font-size:clamp(1.05rem,2.4vw,1.5rem);
  color:#f3ead9;
  letter-spacing:.02em;
  white-space:nowrap;
}
.masthead__scroll{
  margin-top:auto;
  padding-top:clamp(1.5rem,4vw,2.5rem);
  font-family:var(--label);
  text-transform:uppercase;
  letter-spacing:.3em;
  font-size:.66rem;
  color:rgba(246,239,224,.8);
}

/* intro strip under the masthead */
.intro{
  background:var(--paper);
  border-bottom:1px solid var(--rule);
  text-align:center;
  padding:clamp(2.2rem,5vw,3.4rem) 0;
}
.intro__lead{
  font-family:var(--serif);
  font-size:clamp(1.25rem,2.4vw,1.7rem);
  line-height:1.5;
  color:var(--ink-soft);
  max-width:50ch;
  margin:.6rem auto 0;
}
.intro__lead em{ color:var(--ink); }

/* ============================================================
   SECTION HEADERS — "What We're Loving Now" editorial style
   ============================================================ */
.section{ padding:clamp(2.6rem,6vw,4.6rem) 0; }
.section--band{ background:var(--paper-2); border-block:1px solid var(--rule); }

.section-head{
  display:flex;
  align-items:flex-end;
  justify-content:space-between;
  gap:1.5rem;
  margin-bottom:clamp(1.6rem,3.5vw,2.6rem);
  border-bottom:2px solid var(--ink);
  padding-bottom:.9rem;
}
.section-head__title{
  font-family:var(--display);
  font-weight:700;
  color:var(--ink);
  font-size:clamp(1.7rem,4vw,2.9rem);
  line-height:1.05;
  margin:0;
  letter-spacing:.005em;
}
.section-head__meta{
  font-family:var(--label);
  text-transform:uppercase;
  letter-spacing:.22em;
  font-size:.72rem;
  color:var(--ink-mute);
  white-space:nowrap;
  padding-bottom:.25rem;
}

/* ============================================================
   FEATURED — asymmetric hero feature (big left, stacked right)
   ============================================================ */
.featured{
  display:grid;
  grid-template-columns:1.55fr 1fr;
  gap:clamp(1.4rem,3vw,2.6rem);
  align-items:stretch;
}
.feat-lead{ display:flex; flex-direction:column; }
.feat-lead__media{
  position:relative;
  aspect-ratio:16/10;
  overflow:hidden;
  background:var(--paper-3);
}
.feat-lead__media img{
  width:100%; height:100%; object-fit:cover;
  transition:transform .9s cubic-bezier(.2,.7,.2,1);
}
.feat-lead:hover .feat-lead__media img{ transform:scale(1.045); }
.feat-lead__body{ padding:1.3rem .2rem 0; }
.feat-lead__title{
  font-family:var(--display);
  font-weight:700;
  color:var(--ink);
  font-size:clamp(1.7rem,3.4vw,2.7rem);
  line-height:1.08;
  margin:.5rem 0 .55rem;
}
.feat-lead:hover .feat-lead__title{ color:var(--coral-deep); }
.feat-lead__dek{
  font-family:var(--serif);
  font-style:italic;
  font-size:clamp(1.05rem,1.7vw,1.35rem);
  color:var(--ink-soft);
  line-height:1.5;
  max-width:46ch;
  margin:0 0 .7rem;
}

.feat-side{
  display:flex;
  flex-direction:column;
  gap:1.4rem;
  justify-content:space-between;
}
.feat-mini{
  display:grid;
  grid-template-columns:96px 1fr;
  gap:1rem;
  align-items:start;
  padding-bottom:1.4rem;
  border-bottom:1px solid var(--rule);
}
.feat-side .feat-mini:last-child{ border-bottom:0; padding-bottom:0; }
.feat-mini__media{
  aspect-ratio:1/1;
  overflow:hidden;
  background:var(--paper-3);
}
.feat-mini__media img{ width:100%; height:100%; object-fit:cover; transition:transform .7s ease; }
.feat-mini:hover .feat-mini__media img{ transform:scale(1.06); }
.feat-mini__title{
  font-family:var(--display);
  font-weight:700;
  color:var(--ink);
  font-size:1.12rem;
  line-height:1.18;
  margin:.3rem 0 .25rem;
}
.feat-mini:hover .feat-mini__title{ color:var(--coral-deep); }
.feat-mini__dek{
  font-family:var(--serif);
  font-style:italic;
  font-size:.95rem;
  color:var(--ink-mute);
  line-height:1.4;
  display:-webkit-box;
  -webkit-line-clamp:2;
  -webkit-box-orient:vertical;
  overflow:hidden;
}

.meta-line{
  font-family:var(--label);
  text-transform:uppercase;
  letter-spacing:.18em;
  font-size:.68rem;
  color:var(--ink-mute);
  display:flex;
  gap:.6rem;
  align-items:center;
  flex-wrap:wrap;
}
.meta-line .dot{ width:3px;height:3px;border-radius:50%;background:var(--coral); flex:none; }

/* ============================================================
   CATEGORY FILTER RAIL
   ============================================================ */
.filters{
  display:flex;
  flex-wrap:wrap;
  gap:.55rem;
  align-items:center;
}
.filter{
  font-family:var(--label);
  text-transform:uppercase;
  letter-spacing:.16em;
  font-size:.72rem;
  font-weight:500;
  color:var(--ink-soft);
  background:transparent;
  border:1px solid var(--rule);
  border-radius:999px;
  padding:.5rem 1.05rem;
  cursor:pointer;
  transition:all .2s ease;
  white-space:nowrap;
}
.filter:hover{ border-color:var(--ink); color:var(--ink); }
.filter[aria-pressed="true"]{
  background:var(--ink);
  border-color:var(--ink);
  color:var(--paper);
}
.filter[aria-pressed="true"]:hover{ background:var(--coral-deep); border-color:var(--coral-deep); }

/* ============================================================
   THE COLLECTION GRID
   ============================================================ */
.grid{
  display:grid;
  grid-template-columns:repeat(auto-fill, minmax(min(100%, 300px), 1fr));
  gap:clamp(1.6rem,3vw,2.6rem) clamp(1.4rem,2.4vw,2.2rem);
}
.card{
  display:flex;
  flex-direction:column;
  background:transparent;
}
.card__media{
  position:relative;
  aspect-ratio:4/3;
  overflow:hidden;
  background:var(--paper-3);
}
.card__media img{
  width:100%; height:100%; object-fit:cover;
  transition:transform .8s cubic-bezier(.2,.7,.2,1);
}
.card:hover .card__media img{ transform:scale(1.05); }
.card__num{
  position:absolute;
  top:0; left:0;
  background:var(--paper);
  color:var(--ink);
  font-family:var(--display);
  font-weight:700;
  font-size:.92rem;
  padding:.3rem .62rem;
  letter-spacing:.02em;
  border-bottom-right-radius:2px;
}
.card__body{ padding:.95rem .1rem 0; }
.card__kicker{ margin-bottom:.45rem; }
.card__title{
  font-family:var(--display);
  font-weight:700;
  color:var(--ink);
  font-size:1.3rem;
  line-height:1.16;
  margin:0 0 .4rem;
  letter-spacing:.004em;
}
.card:hover .card__title{ color:var(--coral-deep); }
.card__dek{
  font-family:var(--serif);
  font-style:italic;
  font-size:1.02rem;
  color:var(--ink-mute);
  line-height:1.42;
  margin:0 0 .7rem;
  display:-webkit-box;
  -webkit-line-clamp:2;
  -webkit-box-orient:vertical;
  overflow:hidden;
}
.card__meta{
  margin-top:auto;
  padding-top:.55rem;
  border-top:1px solid var(--rule-soft);
}
.empty{
  grid-column:1/-1;
  text-align:center;
  font-family:var(--serif);
  font-style:italic;
  font-size:1.2rem;
  color:var(--ink-mute);
  padding:2.5rem 0;
}

/* ============================================================
   FOOTER
   ============================================================ */
.foot{
  background:var(--paper-2);
  border-top:1px solid var(--rule);
  margin-top:clamp(2rem,5vw,4rem);
  padding:clamp(2.6rem,6vw,4rem) 0 2.4rem;
  text-align:center;
}
.foot__mark{
  font-family:var(--display);
  font-weight:800;
  letter-spacing:.14em;
  font-size:clamp(2rem,7vw,4.2rem);
  color:var(--ink);
  line-height:1;
  margin:0;
}
.foot__tag{
  font-family:var(--serif);
  font-style:italic;
  color:var(--ink-mute);
  font-size:1.1rem;
  margin:.7rem 0 1.4rem;
}
.foot__line{
  font-family:var(--label);
  text-transform:uppercase;
  letter-spacing:.24em;
  font-size:.68rem;
  color:var(--ink-mute);
}

/* ============================================================
   RECIPE PAGE
   ============================================================ */
.r-top{ background:var(--paper); border-bottom:1px solid var(--rule); }

.r-hero{
  display:grid;
  grid-template-columns:1.05fr 1fr;
  gap:clamp(1.6rem,3.4vw,3rem);
  align-items:center;
  padding:clamp(2.2rem,5vw,4rem) 0 clamp(1.8rem,4vw,3rem);
}
.r-hero__media{
  position:relative;
  aspect-ratio:4/5;
  overflow:hidden;
  background:var(--paper-3);
  box-shadow:0 30px 60px -30px rgba(40,28,12,.4);
}
.r-hero__media img{ width:100%; height:100%; object-fit:cover; }
.r-hero__body{ }
.r-back{
  font-family:var(--label);
  text-transform:uppercase;
  letter-spacing:.2em;
  font-size:.72rem;
  color:var(--ink-mute);
  display:inline-flex;
  align-items:center;
  gap:.45rem;
  margin-bottom:1.1rem;
  transition:color .2s;
}
.r-back:hover{ color:var(--coral); }
.r-kicker{ margin-bottom:1rem; }
.r-title{
  font-family:var(--display);
  font-weight:800;
  color:var(--ink);
  font-size:clamp(2.3rem,5.4vw,4.2rem);
  line-height:1.02;
  margin:0 0 1rem;
  letter-spacing:.004em;
}
.r-dek{
  font-family:var(--serif);
  font-style:italic;
  font-size:clamp(1.2rem,2.2vw,1.6rem);
  line-height:1.45;
  color:var(--ink-soft);
  max-width:42ch;
  margin:0 0 1.6rem;
}
.r-meta{
  display:flex;
  flex-wrap:wrap;
  gap:0;
  border-top:1px solid var(--rule);
  border-bottom:1px solid var(--rule);
}
.r-meta__item{
  flex:1 1 auto;
  min-width:120px;
  padding:1rem 1.2rem 1rem 0;
  border-right:1px solid var(--rule);
}
.r-meta__item:last-child{ border-right:0; padding-right:0; }
.r-meta__k{
  font-family:var(--label);
  text-transform:uppercase;
  letter-spacing:.22em;
  font-size:.64rem;
  color:var(--ink-mute);
  display:block;
  margin-bottom:.3rem;
}
.r-meta__v{
  font-family:var(--display);
  font-weight:700;
  color:var(--ink);
  font-size:1.15rem;
  line-height:1.1;
}

/* body two-column: ingredients (sticky aside) + directions */
.r-body{
  display:grid;
  grid-template-columns:minmax(0,1fr) minmax(0,1.7fr);
  gap:clamp(2rem,5vw,4.5rem);
  padding:clamp(2.2rem,5vw,4rem) 0;
  align-items:start;
}
.r-sectiontitle{
  font-family:var(--display);
  font-weight:700;
  color:var(--ink);
  font-size:clamp(1.4rem,2.6vw,1.9rem);
  margin:0 0 1.1rem;
  padding-bottom:.6rem;
  border-bottom:2px solid var(--ink);
}

.ingredients{ position:sticky; top:1.4rem; }
.ing-group{ margin-bottom:1.4rem; }
.ing-group__name{
  font-family:var(--label);
  text-transform:uppercase;
  letter-spacing:.18em;
  font-size:.72rem;
  font-weight:600;
  color:var(--coral);
  margin:0 0 .6rem;
}
.ing-list{ list-style:none; margin:0; padding:0; }
.ing-list li{
  display:flex;
  gap:.85rem;
  padding:.55rem 0;
  border-bottom:1px solid var(--rule-soft);
  align-items:baseline;
  line-height:1.4;
}
.ing-list li:last-child{ border-bottom:0; }
.ing-qty{
  font-family:var(--label);
  font-weight:600;
  letter-spacing:.03em;
  color:var(--ink);
  flex:none;
  min-width:4.2em;
  font-size:.92rem;
}
.ing-item{ color:var(--ink-soft); font-size:1.02rem; }

.directions{ counter-reset:step; }
.dir-list{ list-style:none; margin:0; padding:0; counter-reset:step; }
.dir-list li{
  position:relative;
  padding:0 0 1.5rem 3.4rem;
  margin-bottom:0;
  line-height:1.66;
  color:var(--ink-soft);
  font-size:1.08rem;
  border-bottom:1px solid var(--rule-soft);
  padding-top:.1rem;
}
.dir-list li:not(:first-child){ padding-top:1.5rem; }
.dir-list li:last-child{ border-bottom:0; padding-bottom:0; }
.dir-list li::before{
  counter-increment:step;
  content:counter(step);
  position:absolute;
  left:0;
  top:1.4rem;
  font-family:var(--display);
  font-weight:700;
  font-size:1.3rem;
  color:var(--paper);
  background:var(--coral);
  width:2.3rem; height:2.3rem;
  border-radius:50%;
  display:flex; align-items:center; justify-content:center;
  line-height:1;
}
.dir-list li:first-child::before{ top:0; }

.r-extras{
  border-top:1px solid var(--rule);
  padding:clamp(2rem,4vw,3rem) 0;
}
.r-notes{
  background:var(--paper-3);
  border-left:3px solid var(--coral);
  padding:1.4rem 1.6rem;
  margin-bottom:1.6rem;
  border-radius:2px;
}
.r-notes__label{
  font-family:var(--label);
  text-transform:uppercase;
  letter-spacing:.2em;
  font-size:.7rem;
  color:var(--coral);
  margin:0 0 .5rem;
  display:block;
}
.r-notes p{ margin:0; font-style:italic; color:var(--ink-soft); }
.r-nutrition{
  font-family:var(--serif);
  color:var(--ink-mute);
  font-size:.95rem;
  white-space:pre-line;
  line-height:1.6;
}
.r-nutrition h4, .r-notes + .r-source, .r-source__label{}
.r-source{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:1rem;
  flex-wrap:wrap;
  border-top:1px solid var(--rule);
  margin-top:1.6rem;
  padding-top:1.6rem;
}
.r-source__txt{
  font-family:var(--serif);
  font-style:italic;
  color:var(--ink-mute);
  font-size:1rem;
}
.btn-source{
  font-family:var(--label);
  text-transform:uppercase;
  letter-spacing:.18em;
  font-size:.74rem;
  font-weight:600;
  color:var(--paper);
  background:var(--coral);
  padding:.7rem 1.4rem;
  border-radius:999px;
  transition:background .2s, transform .2s;
  white-space:nowrap;
}
.btn-source:hover{ background:var(--coral-deep); transform:translateY(-1px); }

.r-more{
  background:var(--paper-2);
  border-top:1px solid var(--rule);
  padding:clamp(2.4rem,5vw,4rem) 0;
}

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width:900px){
  .featured{ grid-template-columns:1fr; }
  .feat-side{ flex-direction:column; }
  .r-hero{ grid-template-columns:1fr; gap:1.6rem; }
  .r-hero__media{ aspect-ratio:4/3; }
  .r-body{ grid-template-columns:1fr; gap:2.2rem; }
  .ingredients{ position:static; }
}
@media (max-width:620px){
  body{ font-size:18px; }
  .topbar__inner{ flex-wrap:wrap; gap:.4rem .8rem; }
  .topbar__date{ display:none; }
  .section-head{ flex-direction:column; align-items:flex-start; gap:.5rem; }
  .section-head__meta{ padding-bottom:0; }
  .r-meta__item{ flex:1 1 45%; border-right:0; padding-right:1rem; }
  .r-source{ flex-direction:column; align-items:flex-start; }
}
@media (max-width:420px){
  .feat-mini{ grid-template-columns:74px 1fr; gap:.8rem; }
  .ing-qty{ min-width:3.6em; }
}

/* reduce motion */
@media (prefers-reduced-motion:reduce){
  *{ animation:none !important; transition:none !important; }
}

/* ============================================================
   PRINT — recipes print beautifully
   ============================================================ */
@media print{
  body{ background:#fff; color:#000; font-size:12pt; }
  .topbar, .r-back, .r-more, .foot, .btn-source, .masthead__scroll{ display:none !important; }
  .r-hero{ grid-template-columns:1fr; }
  .r-hero__media{ box-shadow:none; aspect-ratio:16/9; max-height:3in; }
  .r-body{ grid-template-columns:1fr 2fr; gap:.6in; }
  .dir-list li::before{ background:#000; color:#fff; }
  a{ color:#000; }
}
