/* =====================================================================
   VIKING IN THE KITCHEN — Theme  (Nordic Noir)
   Design tokens + custom theme layered over Bootstrap 5.3.
   Swap the :root token block to change the whole palette.
   ===================================================================== */

/* ---------- PALETTE: NORDIC NOIR (active) --------------------------- */
:root {
  --vk-bg:        #16130F;                 /* page canvas, warm near-black */
  --vk-bg-2:      #1C1813;                 /* alt band                     */
  --vk-surface:   #221D16;                 /* cards, raised sections       */
  --vk-surface-2: #2A241C;                 /* hover / nested surface       */
  --vk-bone:      #F4EFE6;                 /* primary text / wordmark      */
  --vk-muted:     #B0A691;                 /* secondary text               */
  --vk-faint:     #7C7362;                 /* tertiary / meta              */
  --vk-brass:     #B08D57;                 /* accent, rules, active        */
  --vk-brass-lt:  #D8B87E;                 /* brass hover / focus glow     */
  --vk-oxblood:   #7A2318;                 /* rare emphasis flag           */
  --vk-line:      rgba(244, 239, 230, .12);/* hairline dividers            */
  --vk-line-strong: rgba(244, 239, 230, .22);

  --vk-font-display: "Fraunces", Georgia, "Times New Roman", serif;
  --vk-font-body:    "Hanken Grotesk", -apple-system, "Segoe UI", sans-serif;

  --vk-shadow: 0 24px 60px -28px rgba(0, 0, 0, .75);
  --vk-radius: 3px;                         /* nearly square = editorial   */
  --vk-maxw: 1240px;
}

/* ---------- PALETTE: SCANDI IVORY (bright luxe) — swap to use ---------
:root {
  --vk-bg:#F7F3EC; --vk-bg-2:#F1EBDF; --vk-surface:#FFFFFF; --vk-surface-2:#F3EEE3;
  --vk-bone:#14110E; --vk-muted:#5A5245; --vk-faint:#8C8474;
  --vk-brass:#2E4034; --vk-brass-lt:#3E5647; --vk-oxblood:#8A3B22;
  --vk-line:rgba(20,17,14,.12); --vk-line-strong:rgba(20,17,14,.22);
  --vk-shadow:0 22px 50px -30px rgba(46,64,52,.35);
}
------------------------------------------------------------------------ */

/* ---------- PALETTE: FORGE & HEARTH (warm rustic-luxe) — swap to use --
:root {
  --vk-bg:#22282B; --vk-bg-2:#282F32; --vk-surface:#2E3538; --vk-surface-2:#39413F;
  --vk-bone:#E8E0D0; --vk-muted:#B4AB98; --vk-faint:#84806E;
  --vk-brass:#C05A2A; --vk-brass-lt:#E07D46; --vk-oxblood:#7A2318;
  --vk-line:rgba(232,224,208,.12); --vk-line-strong:rgba(232,224,208,.22);
}
------------------------------------------------------------------------ */

/* ---------- BASE ---------------------------------------------------- */
* { box-sizing: border-box; }

body {
  background-color: var(--vk-bg);
  color: var(--vk-bone);
  font-family: var(--vk-font-body);
  font-weight: 400;
  font-size: 1.0625rem;
  line-height: 1.7;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
  overflow-x: hidden;
}

/* Subtle film-grain atmosphere over the whole page */
body::before {
  content: "";
  position: fixed;
  inset: 0;
  z-index: 1;
  pointer-events: none;
  opacity: .04;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='140' height='140'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}

.vk-shell { position: relative; z-index: 2; }

a { color: var(--vk-brass-lt); text-decoration: none; transition: color .25s ease; }
a:hover { color: var(--vk-bone); }

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

::selection { background: var(--vk-brass); color: var(--vk-bg); }

/* Fraunces optical + soft axes for warmth */
h1, h2, h3, h4, .vk-display {
  font-family: var(--vk-font-display);
  font-weight: 500;
  font-optical-sizing: auto;
  font-variation-settings: "SOFT" 40, "WONK" 0, "opsz" 60;
  line-height: 1.06;
  letter-spacing: -0.01em;
  color: var(--vk-bone);
}

/* ---------- UTIL: eyebrow label ------------------------------------ */
.vk-eyebrow {
  font-family: var(--vk-font-body);
  font-weight: 600;
  font-size: .72rem;
  letter-spacing: .28em;
  text-transform: uppercase;
  color: var(--vk-brass);
  display: inline-block;
}

.vk-container { max-width: var(--vk-maxw); margin-inline: auto; padding-inline: 1.5rem; }

/* ---------- UTIL: rune / hairline divider -------------------------- */
.vk-rule {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 1rem;
  color: var(--vk-brass);
}
.vk-rule::before, .vk-rule::after {
  content: "";
  height: 1px;
  width: min(120px, 22vw);
  background: linear-gradient(90deg, transparent, var(--vk-brass));
}
.vk-rule::after { background: linear-gradient(90deg, var(--vk-brass), transparent); }
.vk-rune { font-size: .95rem; letter-spacing: .35em; opacity: .85; }

/* ---------- BUTTONS ------------------------------------------------ */
.vk-btn {
  --b: var(--vk-brass);
  display: inline-flex;
  align-items: center;
  gap: .7rem;
  font-family: var(--vk-font-body);
  font-weight: 600;
  font-size: .78rem;
  letter-spacing: .18em;
  text-transform: uppercase;
  color: var(--vk-bone);
  background: transparent;
  border: 1px solid var(--b);
  padding: .95rem 1.9rem;
  border-radius: var(--vk-radius);
  cursor: pointer;
  transition: background .3s ease, color .3s ease, border-color .3s ease;
}
.vk-btn:hover { background: var(--b); color: var(--vk-bg); }
.vk-btn--solid { background: var(--vk-brass); color: var(--vk-bg); border-color: var(--vk-brass); }
.vk-btn--solid:hover { background: var(--vk-brass-lt); border-color: var(--vk-brass-lt); }
.vk-btn__arrow { transition: transform .3s ease; }
.vk-btn:hover .vk-btn__arrow { transform: translateX(4px); }

/* =====================================================================
   NAVBAR
   ===================================================================== */
.vk-nav {
  position: fixed;
  inset: 0 0 auto 0;
  z-index: 100;
  padding: 0.7rem 0 1.4rem;
  transition: background .4s ease, padding .4s ease, border-color .4s ease, backdrop-filter .4s ease;
  border-bottom: 1px solid transparent;
}
.vk-nav.is-scrolled {
  background: rgba(16, 13, 10, .82);
  backdrop-filter: blur(14px) saturate(120%);
  border-bottom-color: var(--vk-line);
  padding: .85rem 0;
}
.vk-nav__inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1.5rem;
}
.vk-wordmark {
  font-family: var(--vk-font-display);
  font-weight: 600;
  font-variation-settings: "SOFT" 0, "opsz" 40;
  font-size: 1.18rem;
  letter-spacing: .16em;
  text-transform: uppercase;
  color: var(--vk-bone);
  line-height: 1;
  white-space: nowrap;
}
.vk-wordmark:hover { color: var(--vk-bone); }
.vk-wordmark small {
  display: block;
  font-family: var(--vk-font-body);
  font-size: .52rem;
  letter-spacing: .5em;
  color: var(--vk-brass);
  margin-top: .35rem;
  padding-left: .16em;
}
.vk-nav__links { display: flex; align-items: center; gap: 2rem; list-style: none; margin: 0; padding: 0; }
.vk-nav__links a {
  font-size: .78rem;
  font-weight: 500;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: var(--vk-muted);
  position: relative;
  padding-bottom: 4px;
}
.vk-nav__links a::after {
  content: "";
  position: absolute;
  left: 0; bottom: 0;
  height: 1px; width: 0;
  background: var(--vk-brass);
  transition: width .3s ease;
}
.vk-nav__links a:hover, .vk-nav__links a.is-active { color: var(--vk-bone); }
.vk-nav__links a:hover::after, .vk-nav__links a.is-active::after { width: 100%; }

.vk-nav__search {
  background: none; border: none; color: var(--vk-muted);
  cursor: pointer; padding: .3rem; transition: color .25s ease;
}
.vk-nav__search:hover { color: var(--vk-brass-lt); }

.vk-nav__toggle { display: none; background: none; border: none; color: var(--vk-bone); cursor: pointer; }

/* =====================================================================
   HERO (home)
   ===================================================================== */
.vk-hero {
  position: relative;
  min-height: 100svh;
  display: flex;
  align-items: center;
  justify-content: center;
  text-align: center;
  overflow: hidden;
}
.vk-hero__media { position: absolute; inset: 0; z-index: 0; }
.vk-hero__media img { width: 100%; height: 100%; object-fit: cover; filter: saturate(.85) contrast(1.02); }
.vk-hero__media::after {
  content: "";
  position: absolute; inset: 0;
  background:
    radial-gradient(120% 90% at 50% 30%, rgba(16,13,10,.35), rgba(16,13,10,.86) 78%),
    linear-gradient(180deg, rgba(16,13,10,.55), rgba(16,13,10,.35) 40%, var(--vk-bg));
}
.vk-hero__inner { position: relative; z-index: 2; padding: 8rem 1.5rem 4rem; max-width: 820px; }
.vk-hero__title {
  font-size: clamp(2.9rem, 8vw, 6.2rem);
  font-weight: 400;
  font-variation-settings: "SOFT" 60, "WONK" 1, "opsz" 144;
  margin: 1.6rem 0;
  text-shadow: 0 2px 40px rgba(0,0,0,.5);
}
.vk-hero__title em { font-style: italic; color: var(--vk-brass-lt); font-variation-settings: "WONK" 1; }
.vk-hero__tagline {
  font-size: 1.02rem;
  letter-spacing: .32em;
  text-transform: uppercase;
  color: var(--vk-muted);
  margin-bottom: 2.6rem;
}
.vk-hero__scroll {
  position: absolute; left: 50%; bottom: 2rem; transform: translateX(-50%);
  z-index: 2; color: var(--vk-faint); font-size: .68rem; letter-spacing: .3em; text-transform: uppercase;
  display: flex; flex-direction: column; align-items: center; gap: .6rem;
}
.vk-hero__scroll span { width: 1px; height: 46px; background: linear-gradient(var(--vk-brass), transparent); animation: vkPulse 2.4s ease-in-out infinite; }
@keyframes vkPulse { 0%,100% { opacity: .3; transform: scaleY(.6); } 50% { opacity: 1; transform: scaleY(1);} }

/* =====================================================================
   SECTION SCAFFOLD
   ===================================================================== */
.vk-section { padding: clamp(4rem, 9vw, 8rem) 0; position: relative; }
.vk-section--alt { background: var(--vk-bg-2); }
.vk-section__head { margin-bottom: 3.2rem; }
.vk-section__title { font-size: clamp(1.9rem, 4vw, 3rem); margin: .6rem 0 0; }
.vk-section__head--center { text-align: center; }
.vk-section__head--split {
  display: flex; align-items: flex-end; justify-content: space-between; gap: 1.5rem; flex-wrap: wrap;
  border-bottom: 1px solid var(--vk-line); padding-bottom: 1.4rem;
}

/* ---------- FEATURED editorial split -------------------------------- */
.vk-featured { display: grid; grid-template-columns: 1.15fr 1fr; gap: 0; align-items: stretch; background: var(--vk-surface); border: 1px solid var(--vk-line); border-radius: var(--vk-radius); overflow: hidden; box-shadow: var(--vk-shadow); }
.vk-featured__media { position: relative; overflow: hidden; min-height: 420px; }
.vk-featured__media img { width: 100%; height: 100%; object-fit: cover; transition: transform 1s cubic-bezier(.2,.7,.2,1); }
.vk-featured:hover .vk-featured__media img { transform: scale(1.05); }
.vk-featured__flag {
  position: absolute; top: 1.2rem; left: 1.2rem;
  background: var(--vk-oxblood); color: var(--vk-bone);
  font-size: .64rem; letter-spacing: .24em; text-transform: uppercase; font-weight: 600;
  padding: .5rem .9rem; border-radius: 2px;
}
.vk-featured__body { padding: clamp(2rem, 4vw, 3.4rem); display: flex; flex-direction: column; justify-content: center; }
.vk-featured__title { font-size: clamp(2rem, 3.4vw, 3rem); margin: 1rem 0 1.2rem; }
.vk-featured__title a { color: var(--vk-bone); }
.vk-featured__title a:hover { color: var(--vk-brass-lt); }
.vk-featured__excerpt { color: var(--vk-muted); font-size: 1.08rem; margin-bottom: 2rem; max-width: 46ch; }

/* =====================================================================
   RECIPE CARD GRID
   ===================================================================== */
.vk-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 2.2rem 2rem; }
.vk-card { position: relative; display: flex; flex-direction: column; }
.vk-card__media {
  position: relative; overflow: hidden; border-radius: var(--vk-radius);
  aspect-ratio: 4 / 5; background: var(--vk-surface);
}
.vk-card__media img { width: 100%; height: 100%; object-fit: cover; transition: transform .9s cubic-bezier(.2,.7,.2,1); }
.vk-card:hover .vk-card__media img { transform: scale(1.06); }
.vk-card__media::after {
  content: ""; position: absolute; inset: 0;
  background: linear-gradient(180deg, transparent 45%, rgba(16,13,10,.55));
  opacity: .7; transition: opacity .4s ease;
}
.vk-card:hover .vk-card__media::after { opacity: 1; }
.vk-card__index {
  position: absolute; top: 1rem; right: 1rem; z-index: 2;
  font-family: var(--vk-font-display); font-size: .9rem; color: var(--vk-brass-lt);
  opacity: .7;
}
.vk-card__cat { margin-top: 1.2rem; }
.vk-card__title {
  font-size: 1.5rem; margin: .5rem 0 0; line-height: 1.15;
}
.vk-card__title a { color: var(--vk-bone); display: inline; background-image: linear-gradient(var(--vk-brass), var(--vk-brass)); background-size: 0% 1px; background-repeat: no-repeat; background-position: 0 100%; transition: background-size .4s ease, color .3s ease; padding-bottom: 2px; }
.vk-card:hover .vk-card__title a { background-size: 100% 1px; }
.vk-card__meta { margin-top: .7rem; color: var(--vk-faint); font-size: .82rem; letter-spacing: .06em; display: flex; gap: .8rem; }
.vk-card__meta span { position: relative; }
.vk-card__meta span + span::before { content: "·"; position: absolute; left: -.55rem; color: var(--vk-faint); }

/* =====================================================================
   CATEGORY TILES
   ===================================================================== */
.vk-cats { display: grid; grid-template-columns: repeat(4, 1fr); gap: 1rem; }
.vk-cat {
  display: flex; align-items: center; justify-content: space-between; gap: 1rem;
  padding: 1.5rem 1.6rem; background: var(--vk-surface); border: 1px solid var(--vk-line);
  border-radius: var(--vk-radius); transition: border-color .3s ease, background .3s ease, transform .3s ease;
}
.vk-cat:hover { border-color: var(--vk-brass); background: var(--vk-surface-2); transform: translateY(-3px); }
.vk-cat__name { font-family: var(--vk-font-display); font-size: 1.2rem; color: var(--vk-bone); }
.vk-cat__count { font-size: .78rem; color: var(--vk-brass); font-variant-numeric: tabular-nums; }

/* =====================================================================
   FOOTER
   ===================================================================== */
.vk-footer { border-top: 1px solid var(--vk-line); padding: 4.5rem 0 2.5rem; background: var(--vk-bg-2); }
.vk-footer__grid { display: grid; grid-template-columns: 1.4fr 1fr 1fr; gap: 2.5rem; }
.vk-footer__brand .vk-wordmark { font-size: 1.5rem; }
.vk-footer__about { color: var(--vk-muted); margin-top: 1.2rem; max-width: 34ch; }
.vk-footer__col h5 { font-family: var(--vk-font-body); font-size: .72rem; letter-spacing: .24em; text-transform: uppercase; color: var(--vk-brass); margin-bottom: 1.2rem; }
.vk-footer__col ul { list-style: none; margin: 0; padding: 0; display: grid; gap: .7rem; }
.vk-footer__col a { color: var(--vk-muted); font-size: .95rem; }
.vk-footer__col a:hover { color: var(--vk-bone); }
.vk-footer__bottom { border-top: 1px solid var(--vk-line); margin-top: 3.5rem; padding-top: 1.8rem; display: flex; justify-content: space-between; gap: 1rem; flex-wrap: wrap; color: var(--vk-faint); font-size: .8rem; letter-spacing: .06em; }

/* =====================================================================
   RECIPE PAGE
   ===================================================================== */
.vk-recipe-hero { padding: 9rem 0 0; text-align: center; }
.vk-recipe-hero__cat { margin-bottom: 1.3rem; }
.vk-recipe-hero__title { font-size: clamp(2.4rem, 6vw, 4.8rem); font-variation-settings: "SOFT" 60, "WONK" 1, "opsz" 144; max-width: 18ch; margin: 0 auto; }
.vk-recipe-hero__meta { display: flex; gap: 1.6rem; justify-content: center; margin-top: 1.8rem; color: var(--vk-faint); font-size: .8rem; letter-spacing: .18em; text-transform: uppercase; }
.vk-recipe-hero__meta span + span { position: relative; }
.vk-recipe-hero__meta span + span::before { content: ""; position: absolute; left: -.85rem; top: 50%; width: 4px; height: 4px; background: var(--vk-brass); border-radius: 50%; transform: translateY(-50%); }
.vk-recipe-hero__figure { margin-top: 3rem; position: relative; max-width: var(--vk-maxw); margin-inline: auto; padding-inline: 1.5rem; }
.vk-recipe-hero__figure img { width: 100%; max-height: 66vh; object-fit: cover; border-radius: var(--vk-radius); box-shadow: var(--vk-shadow); }

.vk-recipe-intro { max-width: 720px; margin: 3rem auto 0; padding-inline: 1.5rem; text-align: center; }
.vk-recipe-intro p { font-family: var(--vk-font-display); font-style: italic; font-size: clamp(1.25rem, 2.4vw, 1.7rem); line-height: 1.5; color: var(--vk-bone); font-variation-settings: "SOFT" 60; }

.vk-recipe-body { display: grid; grid-template-columns: 340px 1fr; gap: 3.5rem; align-items: start; }
@media (min-width: 992px) { .vk-recipe-body { grid-template-columns: 360px 1fr; gap: 4.5rem; } }

/* Ingredients panel (sticky) */
.vk-ingredients { position: sticky; top: 6.5rem; background: var(--vk-surface); border: 1px solid var(--vk-line); border-radius: var(--vk-radius); padding: 2rem 1.9rem; }
.vk-ingredients__head { display: flex; align-items: center; justify-content: space-between; border-bottom: 1px solid var(--vk-line-strong); padding-bottom: 1rem; margin-bottom: 1.4rem; }
.vk-ingredients__head h2 { font-size: 1.35rem; margin: 0; }
.vk-panel-actions { display: flex; gap: .5rem; }
.vk-icon-btn { background: none; border: 1px solid var(--vk-line-strong); color: var(--vk-muted); width: 34px; height: 34px; border-radius: 2px; cursor: pointer; display: grid; place-items: center; transition: all .25s ease; }
.vk-icon-btn:hover { color: var(--vk-bg); background: var(--vk-brass); border-color: var(--vk-brass); }
.vk-ingredients__group + .vk-ingredients__group { margin-top: 1.6rem; }
.vk-ingredients__group h3 { font-family: var(--vk-font-body); font-size: .72rem; letter-spacing: .2em; text-transform: uppercase; color: var(--vk-brass); margin-bottom: .8rem; }
.vk-ingredients ul { list-style: none; margin: 0; padding: 0; }
.vk-ingredients li { position: relative; padding: .55rem 0 .55rem 1.6rem; border-bottom: 1px dashed var(--vk-line); color: var(--vk-bone); font-size: .98rem; line-height: 1.5; }
.vk-ingredients li:last-child { border-bottom: none; }
.vk-ingredients li::before { content: ""; position: absolute; left: 0; top: 1.05rem; width: 7px; height: 7px; border: 1px solid var(--vk-brass); transform: rotate(45deg); }
.vk-ingredients li a { color: var(--vk-brass-lt); text-decoration: underline; text-decoration-color: var(--vk-line-strong); text-underline-offset: 3px; }

/* Method / The Build */
.vk-method h2 { font-size: clamp(1.7rem, 3vw, 2.4rem); margin: 0 0 2rem; }
.vk-method__group-title { font-family: var(--vk-font-display); font-size: 1.35rem; color: var(--vk-brass-lt); margin: 2.6rem 0 1.2rem; }
.vk-steps { list-style: none; counter-reset: step; margin: 0; padding: 0; }
.vk-steps > li { position: relative; padding: 0 0 2rem 4.2rem; }
.vk-steps > li::before {
  counter-increment: step; content: counter(step, decimal-leading-zero);
  position: absolute; left: 0; top: -.15rem;
  font-family: var(--vk-font-display); font-size: 1.5rem; color: var(--vk-brass);
  font-variation-settings: "opsz" 60;
}
.vk-steps > li::after { content: ""; position: absolute; left: 1.05rem; top: 2.2rem; bottom: .4rem; width: 1px; background: var(--vk-line); }
.vk-steps > li:last-child::after { display: none; }
.vk-steps p { margin: 0; color: var(--vk-bone); }
.vk-method figure { margin: 1.5rem 0 0; }
.vk-method figure img { border-radius: var(--vk-radius); border: 1px solid var(--vk-line); }
.vk-method figcaption { color: var(--vk-faint); font-size: .82rem; margin-top: .6rem; font-style: italic; }

/* Recipe footer nav / related */
.vk-related-head { text-align: center; margin-bottom: 3rem; }
.vk-prevnext { display: flex; justify-content: space-between; gap: 1rem; border-top: 1px solid var(--vk-line); border-bottom: 1px solid var(--vk-line); padding: 1.6rem 0; margin-bottom: 4rem; }
.vk-prevnext a { display: flex; flex-direction: column; gap: .3rem; color: var(--vk-muted); }
.vk-prevnext a:hover { color: var(--vk-bone); }
.vk-prevnext .lbl { font-size: .68rem; letter-spacing: .22em; text-transform: uppercase; color: var(--vk-brass); }
.vk-prevnext .nm { font-family: var(--vk-font-display); font-size: 1.15rem; }
.vk-prevnext .n--next { text-align: right; align-items: flex-end; }

/* =====================================================================
   CATEGORY / LISTING PAGE
   ===================================================================== */
.vk-page-hero { padding: 9rem 0 3rem; text-align: center; border-bottom: 1px solid var(--vk-line); }
.vk-page-hero__title { font-size: clamp(2.6rem, 6vw, 4.6rem); }
.vk-page-hero__sub { color: var(--vk-muted); margin-top: 1rem; }
.vk-filterbar { display: flex; flex-wrap: wrap; gap: .6rem; justify-content: center; margin-top: 2.4rem; }
.vk-chip { font-size: .74rem; letter-spacing: .12em; text-transform: uppercase; color: var(--vk-muted); border: 1px solid var(--vk-line-strong); padding: .55rem 1.1rem; border-radius: 100px; transition: all .25s ease; }
.vk-chip:hover, .vk-chip.is-active { color: var(--vk-bg); background: var(--vk-brass); border-color: var(--vk-brass); }

/* =====================================================================
   REVEAL ANIMATION
   ===================================================================== */
.vk-reveal { opacity: 0; transform: translateY(24px); transition: opacity .8s ease, transform .8s cubic-bezier(.2,.7,.2,1); }
.vk-reveal.is-in { opacity: 1; transform: none; }

/* =====================================================================
   RESPONSIVE
   ===================================================================== */
@media (max-width: 991px) {
  .vk-featured { grid-template-columns: 1fr; }
  .vk-featured__media { min-height: 300px; }
  .vk-grid { grid-template-columns: repeat(2, 1fr); }
  .vk-cats { grid-template-columns: repeat(2, 1fr); }
  .vk-footer__grid { grid-template-columns: 1fr 1fr; }
  .vk-recipe-body { grid-template-columns: 1fr; gap: 2.5rem; }
  .vk-ingredients { position: static; }
}
@media (max-width: 640px) {
  body { font-size: 1rem; }
  .vk-nav__links { display: none; }
  .vk-nav__toggle { display: inline-flex; }
  .vk-grid { grid-template-columns: 1fr; }
  .vk-cats { grid-template-columns: 1fr; }
  .vk-footer__grid { grid-template-columns: 1fr; }
  .vk-recipe-hero__meta { flex-wrap: wrap; gap: 1rem 1.6rem; }
}

/* Mobile drawer */
.vk-drawer { position: fixed; inset: 0; z-index: 200; background: rgba(16,13,10,.97); backdrop-filter: blur(8px); display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 1.8rem; opacity: 0; pointer-events: none; transition: opacity .35s ease; }
.vk-drawer.is-open { opacity: 1; pointer-events: auto; }
.vk-drawer a { font-family: var(--vk-font-display); font-size: 2rem; color: var(--vk-bone); }
.vk-drawer a:hover { color: var(--vk-brass-lt); }
.vk-drawer__close { position: absolute; top: 1.6rem; right: 1.6rem; background: none; border: none; color: var(--vk-bone); cursor: pointer; }

/* =====================================================================
   DYNAMIC SITE ADDITIONS (backend build)
   ===================================================================== */

/* Rendered ingredients: group headings from Markdown sub-headings */
.vk-ingredients__body .vk-ig-group { font-family: var(--vk-font-body); font-size: .72rem; letter-spacing: .2em; text-transform: uppercase; color: var(--vk-brass); margin: 1.6rem 0 .8rem; }
.vk-ingredients__body .vk-ig-group:first-child { margin-top: 0; }

/* Longform fallback (recipes without a clean Ingredients/Build split) */
.vk-longform { max-width: 760px; margin-inline: auto; }
.vk-longform h1, .vk-longform h2, .vk-longform h3, .vk-longform h4 { margin: 2rem 0 1rem; }
.vk-longform ul, .vk-longform ol { padding-left: 1.3rem; }
.vk-longform li { margin-bottom: .5rem; }

/* Forms / inputs */
.vk-input { width: 100%; background: var(--vk-bg); color: var(--vk-bone); border: 1px solid var(--vk-line-strong); border-radius: var(--vk-radius); padding: .85rem 1rem; font-family: var(--vk-font-body); font-size: 1rem; transition: border-color .25s ease; }
.vk-input:focus { outline: none; border-color: var(--vk-brass); }
.vk-input::placeholder { color: var(--vk-faint); }
textarea.vk-input { resize: vertical; }
.vk-input--lg { font-size: 1.15rem; padding: 1.1rem 1.3rem; }
.vk-hp { position: absolute !important; left: -9999px !important; width: 1px; height: 1px; opacity: 0; }

/* Newsletter (footer) */
.vk-newsletter { margin-top: 2rem; }
.vk-newsletter__row { display: flex; gap: .6rem; }
.vk-newsletter__row .vk-input { flex: 1; }
.vk-newsletter__note { color: var(--vk-faint); font-size: .78rem; margin: .7rem 0 0; }

/* Flash messages */
.vk-flash { border-radius: var(--vk-radius); padding: .8rem 1.1rem; margin: 0 0 1.2rem; font-size: .92rem; border: 1px solid; }
.vk-flash--ok { color: var(--vk-brass-lt); border-color: var(--vk-brass); background: rgba(176,141,87,.08); }
.vk-flash--err { color: #E7A79A; border-color: var(--vk-oxblood); background: rgba(122,35,24,.14); }

/* Ratings */
.vk-stars { color: var(--vk-faint); letter-spacing: .1em; font-size: .95rem; }
.vk-stars .vk-star.is-on { color: var(--vk-brass); }
.vk-rating-summary { display: flex; align-items: center; gap: .6rem; justify-content: center; margin-top: 1.2rem; color: var(--vk-muted); font-size: .85rem; }
.vk-rating-summary .vk-stars { font-size: 1.05rem; }

/* Star input (reversed so hover/checked fills leftwards) */
.vk-stars-input { display: inline-flex; flex-direction: row-reverse; gap: .2rem; margin-top: .5rem; }
.vk-stars-input input { position: absolute; opacity: 0; width: 0; }
.vk-stars-input label { font-size: 1.6rem; color: var(--vk-faint); cursor: pointer; transition: color .15s ease; }
.vk-stars-input label:hover, .vk-stars-input label:hover ~ label,
.vk-stars-input input:checked ~ label { color: var(--vk-brass); }

/* Comments */
.vk-comments__inner { max-width: 780px; }
.vk-comments__empty { text-align: center; color: var(--vk-faint); font-style: italic; }
.vk-comment-list { list-style: none; margin: 0 0 3rem; padding: 0; }
.vk-comment { padding: 1.5rem 0; border-bottom: 1px solid var(--vk-line); }
.vk-comment__head { display: flex; align-items: center; gap: 1rem; margin-bottom: .5rem; flex-wrap: wrap; }
.vk-comment__author { font-family: var(--vk-font-display); font-size: 1.15rem; color: var(--vk-bone); }
.vk-comment__date { color: var(--vk-faint); font-size: .78rem; letter-spacing: .05em; }
.vk-comment__body { color: var(--vk-muted); margin: 0; }
.vk-comment-form { background: var(--vk-surface); border: 1px solid var(--vk-line); border-radius: var(--vk-radius); padding: 2rem; }
.vk-comment-form h3 { font-size: 1.6rem; margin: 0 0 1.4rem; }
.vk-comment-form .vk-input { margin-bottom: 1rem; }
.vk-form-row { display: flex; gap: 1rem; }
.vk-form-row .vk-input { flex: 1; }
.vk-rating-input { margin-bottom: 1.2rem; }

/* Search */
.vk-search-form { display: flex; gap: .8rem; max-width: 640px; margin: 2rem auto 0; }
.vk-search-form .vk-input { flex: 1; }

/* Pagination */
.vk-pagination { display: flex; justify-content: center; gap: .5rem; margin-top: 3.5rem; }
.vk-page-link { display: grid; place-items: center; min-width: 42px; height: 42px; padding: 0 .6rem; border: 1px solid var(--vk-line-strong); border-radius: var(--vk-radius); color: var(--vk-muted); font-size: .9rem; font-variant-numeric: tabular-nums; transition: all .2s ease; }
.vk-page-link:hover { border-color: var(--vk-brass); color: var(--vk-bone); }
.vk-page-link.is-active { background: var(--vk-brass); border-color: var(--vk-brass); color: var(--vk-bg); }

@media (max-width: 640px) {
  .vk-form-row { flex-direction: column; gap: 0; }
  .vk-newsletter__row { flex-direction: column; }
}

/* Cloudflare Turnstile widget spacing */
.vk-turnstile { margin: 0 0 1.2rem; }
.vk-comment-form .vk-turnstile { margin-top: .4rem; }

/* Header logo (replaces the text wordmark when a logo is set) */
.vk-wordmark--logo { display: inline-flex; flex-direction: column; align-items: flex-start; gap: 0; }
.vk-logo { height: 48px; width: auto; display: block; transition: height .4s ease; }
.vk-nav.is-scrolled .vk-logo { height: 36px; }
.vk-wordmark--logo small { margin-top: .4rem; padding-left: .1em; }
@media (max-width: 640px) { .vk-logo { height: 18px; } .vk-nav.is-scrolled .vk-logo { height: 16px; } }
