/*
Theme Name: leckivo
Theme URI: https://leckivo.com
Author: leckivo Team
Author URI: https://leckivo.com
Description: Premium German Recipe Theme – Heißluftfritteuse, Schnelle & Einfache Rezepte
Version: 1.2.1
Requires at least: 6.0
Tested up to: 6.5
Requires PHP: 8.0
License: GPL-2.0-or-later
License URI: https://www.gnu.org/licenses/gpl-2.0.html
Text Domain: leckivo
Tags: food, recipe, german, blog, custom-logo, custom-menu, featured-images, threaded-comments, translation-ready
*/

/* ============================================================
   0. LOCAL FONTS — @font-face (kein Google Fonts CDN)
   Alle Schriftarten kommen aus /assets/fonts/ (DSGVO-konform)
   ============================================================ */

@font-face {
  font-family: 'Inter';
  src: url('assets/fonts/inter-regular.woff2') format('woff2');
  font-weight: 400;
  font-style: normal;
  font-display: swap;
}
@font-face {
  font-family: 'Inter';
  src: url('assets/fonts/inter-medium.woff2') format('woff2');
  font-weight: 500;
  font-style: normal;
  font-display: swap;
}
@font-face {
  font-family: 'Inter';
  src: url('assets/fonts/inter-semibold.woff2') format('woff2');
  font-weight: 600;
  font-style: normal;
  font-display: swap;
}
@font-face {
  font-family: 'Inter';
  src: url('assets/fonts/inter-bold.woff2') format('woff2');
  font-weight: 700;
  font-style: normal;
  font-display: swap;
}
@font-face {
  font-family: 'Playfair Display';
  src: url('assets/fonts/playfair-regular.woff2') format('woff2');
  font-weight: 400;
  font-style: normal;
  font-display: swap;
}
@font-face {
  font-family: 'Playfair Display';
  src: url('assets/fonts/playfair-bold.woff2') format('woff2');
  font-weight: 700;
  font-style: normal;
  font-display: swap;
}

/* ============================================================
   LOGO COMPONENT
   ============================================================ */
.site-logo-wrap {
  display: flex;
  align-items: center;
  gap: 10px;
  text-decoration: none;
}
.site-logo-icon {
  width: 44px;
  height: 44px;
  flex-shrink: 0;
  border-radius: 50%;
  overflow: hidden;
  box-shadow: 0 3px 12px rgba(231,111,81,.4);
  transition: transform .25s cubic-bezier(.34,1.56,.64,1),
              box-shadow .25s ease;
}
.site-logo-icon img,
.site-logo-icon svg {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}
.site-logo-wrap:hover .site-logo-icon {
  transform: scale(1.08) rotate(-4deg);
  box-shadow: 0 6px 20px rgba(231,111,81,.5);
}
.site-logo-text {
  display: flex;
  flex-direction: column;
  line-height: 1.1;
}
.site-logo-text .logo-name {
  font-family: var(--ff-serif);
  font-size: 1.45rem;
  font-weight: 700;
  color: var(--clr-primary);
  letter-spacing: -0.02em;
}
.site-logo-text .logo-name span {
  color: var(--clr-secondary);
}
.site-logo-text .logo-tagline {
  font-size: 0.6rem;
  font-weight: 600;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: var(--clr-text-muted);
  margin-top: 1px;
}

/* ============================================================
   1. CSS CUSTOM PROPERTIES (DESIGN TOKENS)
   ============================================================ */
:root {
  --clr-primary:       #2D6A4F; /* Forest Green */
  --clr-primary-dark:  #1B4332;
  --clr-primary-light: #40916C;
  --clr-secondary:     #E76F51; /* Terracotta Accent */
  --clr-secondary-dark:#D65A3D;
  --clr-cta:           #F4A261; /* Warm Apricot/Gold CTA */
  --clr-cta-dark:      #E76F51;
  --clr-bg:            #FAF6F0; /* Soft warm cream */
  --clr-surface:       #FDFBF7;
  --clr-soft:          #F5EFE6;
  --clr-soft-2:        #EADEC9;
  --clr-text:          #212529; /* Deep charcoal */
  --clr-text-muted:    #6C757D;
  --clr-text-light:    #ADB5BD;
  --clr-border:        #E9ECEF;
  --clr-overlay:       rgba(33,37,41,0.45);

  --ff-sans:  'Inter', system-ui, -apple-system, sans-serif;
  --ff-serif: 'Playfair Display', Georgia, serif;

  --fw-regular: 400;
  --fw-medium:  500;
  --fw-semibold:600;
  --fw-bold:    700;
  --fw-black:   900;

  --fs-xs:  0.75rem;
  --fs-sm:  0.875rem;
  --fs-base:1rem;
  --fs-md:  1.125rem;
  --fs-lg:  1.25rem;
  --fs-xl:  1.5rem;
  --fs-2xl: 1.875rem;
  --fs-3xl: 2.25rem;
  --fs-4xl: 3rem;
  --fs-5xl: 3.75rem;

  --lh-tight:  1.2;
  --lh-snug:   1.35;
  --lh-normal: 1.6;
  --lh-loose:  1.8;

  --sp-1: 0.25rem;
  --sp-2: 0.5rem;
  --sp-3: 0.75rem;
  --sp-4: 1rem;
  --sp-5: 1.25rem;
  --sp-6: 1.5rem;
  --sp-8: 2rem;
  --sp-10:2.5rem;
  --sp-12:3rem;
  --sp-16:4rem;
  --sp-20:5rem;
  --sp-24:6rem;

  --radius-sm:  4px;
  --radius-md:  8px;
  --radius-lg:  12px;
  --radius-xl:  16px;
  --radius-2xl: 24px;
  --radius-full:9999px;

  --shadow-xs: 0 1px 2px rgba(0,0,0,0.05);
  --shadow-sm: 0 2px 8px rgba(0,0,0,0.08);
  --shadow-md: 0 4px 16px rgba(0,0,0,0.10);
  --shadow-lg: 0 8px 32px rgba(0,0,0,0.12);
  --shadow-xl: 0 20px 60px rgba(0,0,0,0.15);

  --transition-fast:  150ms ease;
  --transition-base:  250ms ease;
  --transition-slow:  400ms ease;

  --container-max:  1280px;
  --container-wide: 1440px;
  --container-text:  760px;

  --header-h: 72px;
}

/* ============================================================
   2. RESET & BASE
   ============================================================ */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%;font-size:16px}
body{
  font-family:var(--ff-sans);
  font-size:var(--fs-base);
  line-height:var(--lh-normal);
  color:var(--clr-text);
  background:var(--clr-bg);
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
}

/* ============================================================
   2.1 ENTRY CONTENT STYLING (Article Body)
   ============================================================ */
.entry-content {
  font-size: 1.15rem;
  line-height: 1.85;
  color: var(--clr-text);
  max-width: var(--container-text);
  margin-inline: auto;
}

.entry-content h2 {
  font-size: var(--fs-2xl);
  margin: 2.5rem 0 1.25rem;
  padding-bottom: 0.5rem;
  border-bottom: 2px solid var(--clr-soft-2);
  position: relative;
}

.entry-content h2::after {
  content: '';
  position: absolute;
  bottom: -2px;
  left: 0;
  width: 60px;
  height: 2px;
  background: var(--clr-primary);
}

.entry-content h3 {
  font-size: var(--fs-xl);
  margin: 2rem 0 1rem;
}

.entry-content p {
  margin-bottom: 1.5rem;
}

.entry-content ul, .entry-content ol {
  margin-bottom: 1.5rem;
  padding-left: 1.25rem;
}

.entry-content li {
  margin-bottom: 0.75rem;
  position: relative;
}

.entry-content ul li::before {
  content: '→';
  position: absolute;
  left: -1.25rem;
  color: var(--clr-primary);
  font-weight: bold;
}

.entry-content blockquote {
  margin: 2.5rem 0;
  padding: 2rem;
  background: var(--clr-soft);
  border-left: 5px solid var(--clr-primary);
  border-radius: 0 var(--radius-lg) var(--radius-lg) 0;
  font-style: italic;
  font-size: var(--fs-lg);
  color: var(--clr-primary-dark);
  position: relative;
}

.entry-content blockquote::before {
  content: '“';
  position: absolute;
  top: -10px;
  left: 10px;
  font-size: 4rem;
  opacity: 0.1;
  font-family: serif;
}

.entry-content img {
  border-radius: var(--radius-xl);
  box-shadow: var(--shadow-md);
  margin: 2rem 0;
}

.entry-content .wp-element-caption {
  text-align: center;
  font-size: var(--fs-xs);
  color: var(--clr-text-light);
  margin-top: -1.5rem;
  margin-bottom: 2rem;
  font-style: italic;
}

/* Dropcap for the first paragraph */
.entry-content > p:first-of-type::first-letter {
  float: left;
  font-family: var(--ff-serif);
  font-size: 4.5rem;
  line-height: 1;
  padding: 0.25rem 0.75rem 0 0;
  color: var(--clr-primary);
  font-weight: 900;
}

/* Alert Boxes for Content */
.entry-content .alert {
  padding: 1.5rem;
  border-radius: var(--radius-lg);
  margin: 2rem 0;
  display: flex;
  gap: 1rem;
  align-items: center;
}

.entry-content .alert--info {
  background: #f0f9ff;
  color: #0369a1;
  border-left: 4px solid #0ea5e9;
}

.entry-content .alert--success {
  background: #f0fdf4;
  color: #166534;
  border-left: 4px solid #22c55e;
}

.entry-content .alert--warning {
  background: #fffbeb;
  color: #92400e;
  border-left: 4px solid #f59e0b;
}
img,video{max-width:100%;height:auto;display:block}
a{color:inherit;text-decoration:none}
a:hover{color:var(--clr-primary)}
ul,ol{list-style:none}
button,input,textarea,select{font:inherit;border:none;outline:none;background:none}
button{cursor:pointer}
h1,h2,h3,h4,h5,h6{font-family:var(--ff-serif);font-weight:var(--fw-bold);line-height:var(--lh-tight);color:var(--clr-text)}
p{margin-bottom:var(--sp-4)}
p:last-child{margin-bottom:0}
:focus-visible{outline:2px solid var(--clr-primary);outline-offset:3px;border-radius:var(--radius-sm)}

/* ============================================================
   3. LAYOUT UTILITIES
   ============================================================ */
.container{width:100%;max-width:var(--container-max);margin-inline:auto;padding-inline:var(--sp-6)}
.container--wide{max-width:var(--container-wide)}
.container--text{max-width:var(--container-text)}
.section{padding-block:var(--sp-16)}
.section--lg{padding-block:var(--sp-24)}
.section--sm{padding-block:var(--sp-10)}
.grid{display:grid;gap:var(--sp-6)}
.grid-2{grid-template-columns:repeat(2,1fr)}
.grid-3{grid-template-columns:repeat(3,1fr)}
.grid-4{grid-template-columns:repeat(4,1fr)}
.grid-auto{grid-template-columns:repeat(auto-fill,minmax(280px,1fr))}
.flex{display:flex;align-items:center}
.flex-col{flex-direction:column}
.gap-2{gap:var(--sp-2)}
.gap-3{gap:var(--sp-3)}
.gap-4{gap:var(--sp-4)}
.gap-6{gap:var(--sp-6)}
.gap-8{gap:var(--sp-8)}
.justify-between{justify-content:space-between}
.justify-center{justify-content:center}
.text-center{text-align:center}
.text-right{text-align:right}
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}

/* ============================================================
   4. TYPOGRAPHY SCALE
   ============================================================ */
.heading-xl{font-size:clamp(2.5rem,5vw,var(--fs-5xl));font-family:var(--ff-serif);font-weight:var(--fw-black);line-height:var(--lh-tight)}
.heading-lg{font-size:clamp(2rem,4vw,var(--fs-4xl));font-family:var(--ff-serif);font-weight:var(--fw-bold);line-height:var(--lh-tight)}
.heading-md{font-size:clamp(1.5rem,3vw,var(--fs-3xl));font-family:var(--ff-serif);font-weight:var(--fw-bold);line-height:var(--lh-snug)}
.heading-sm{font-size:var(--fs-xl);font-family:var(--ff-serif);font-weight:var(--fw-bold)}
.text-muted{color:var(--clr-text-muted)}
.text-primary{color:var(--clr-primary)}
.text-secondary{color:var(--clr-secondary)}
.label{font-size:var(--fs-xs);font-weight:var(--fw-semibold);letter-spacing:0.08em;text-transform:uppercase;color:var(--clr-primary)}
.overline{font-size:var(--fs-xs);font-weight:var(--fw-semibold);letter-spacing:0.12em;text-transform:uppercase;color:var(--clr-secondary)}

/* ============================================================
   5. BUTTONS
   ============================================================ */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:var(--sp-2);
  padding:0.75rem 1.75rem;
  border-radius:var(--radius-full);
  font-weight:var(--fw-semibold);
  font-size:var(--fs-sm);
  letter-spacing:0.02em;
  transition:all var(--transition-base);
  white-space:nowrap;
  cursor:pointer;
  border:2px solid transparent;
}
.btn--primary{background:var(--clr-primary);color:#fff}
.btn--primary:hover{background:var(--clr-primary-dark);color:#fff;transform:translateY(-2px);box-shadow:var(--shadow-md)}
.btn--secondary{background:var(--clr-secondary);color:#fff}
.btn--secondary:hover{background:var(--clr-secondary-dark);color:#fff;transform:translateY(-2px);box-shadow:var(--shadow-md)}
.btn--cta{background:var(--clr-cta);color:#fff}
.btn--cta:hover{background:var(--clr-cta-dark);color:#fff;transform:translateY(-2px);box-shadow:0 8px 24px rgba(34,197,94,0.35)}
.btn--outline{background:transparent;border-color:var(--clr-primary);color:var(--clr-primary)}
.btn--outline:hover{background:var(--clr-primary);color:#fff;transform:translateY(-2px)}
.btn--ghost{background:rgba(255,255,255,0.15);color:#fff;border-color:rgba(255,255,255,0.3);backdrop-filter:blur(8px)}
.btn--ghost:hover{background:rgba(255,255,255,0.25);color:#fff}
.btn--sm{padding:0.5rem 1.25rem;font-size:var(--fs-xs)}
.btn--lg{padding:1rem 2.5rem;font-size:var(--fs-md)}
.btn--icon{width:44px;height:44px;padding:0;border-radius:var(--radius-full)}

/* ============================================================
   6. HEADER
   ============================================================ */
.site-header{
  position:sticky;top:0;z-index:999;
  background:rgba(250,246,240,0.85);
  backdrop-filter:blur(12px);
  -webkit-backdrop-filter:blur(12px);
  border-bottom:1px solid rgba(231,221,208,0.5);
  height:76px; /* Slightly lowered height for elegance */
  width:100%;
  margin:0;
  box-shadow:0 4px 30px rgba(0,0,0,0.02);
  transition:all 0.4s cubic-bezier(0.16, 1, 0.3, 1);
}
.site-header::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 3px;
  background: linear-gradient(90deg, var(--clr-primary), var(--clr-secondary), var(--clr-cta));
  z-index: 10;
}
.site-header.scrolled{
  height:68px;
  background:rgba(250,246,240,0.95);
  box-shadow:0 10px 30px rgba(43,37,32,0.06);
  border-bottom-color:rgba(231,221,208,0.8);
}
.header-inner{
  display:flex;align-items:center;justify-content:space-between;
  height:100%;gap:var(--sp-6);
  transition:height 0.4s cubic-bezier(0.16, 1, 0.3, 1);
}
.site-logo img,.site-logo svg{height:40px;width:auto}
.site-logo a{display:flex;align-items:center;gap:var(--sp-2);text-decoration:none}
.logo-text{font-family:var(--ff-serif);font-weight:var(--fw-black);font-size:var(--fs-xl);color:var(--clr-primary);letter-spacing:-0.02em}
.logo-text span{color:var(--clr-secondary)}

/* Primary Nav */
.primary-nav{
  display:flex;
  align-items:center;
  gap:var(--sp-1); /* Cleaned up spacing */
  list-style:none !important;
  margin:0;
  padding:0;
  height: 100%;
}
.primary-nav li {
  list-style:none !important;
  display:inline-flex;
  align-items:center;
}
.primary-nav a{
  padding: 8px 16px; /* Optimized padding */
  font-size: var(--fs-sm);
  font-weight: var(--fw-semibold);
  color: var(--clr-text);
  background: transparent;
  border-radius: var(--radius-full); /* Rounded pill style */
  transition: all 0.3s cubic-bezier(0.25, 1, 0.5, 1);
  position:relative;
  display:inline-flex;
  align-items:center;
  height: 40px; /* Vertically centered height matching actions */
}
.primary-nav a .nav-icon-wrapper {
  display:inline-flex;
  margin-right:6px;
  transition:transform 0.3s cubic-bezier(0.175, 0.885, 0.32, 1.275);
}
.primary-nav a:hover .nav-icon-wrapper {
  transform:scale(1.25) rotate(-5deg);
}
.primary-nav a:hover, .primary-nav .current-menu-item a {
  color:var(--clr-primary);
  background:rgba(45,106,79,0.06);
}
.primary-nav a::after {
  display: none; /* Hide bottom line to support cleaner, pill-based hover states */
}
.header-actions{
  display:flex;
  align-items:center;
  gap:var(--sp-2);
  height: 100%;
}
.search-toggle,.nav-toggle,.dark-mode-toggle{
  width:40px;
  height:40px;
  border-radius:var(--radius-full);
  display:flex;
  align-items:center;
  justify-content:center;
  background:var(--clr-soft);
  color:var(--clr-text);
  border:1px solid var(--clr-border);
  transition:all 0.3s cubic-bezier(0.25, 1, 0.5, 1);
  cursor:pointer;
  flex-shrink: 0;
}
.search-toggle:hover,.nav-toggle:hover,.dark-mode-toggle:hover{
  background:var(--clr-primary);
  color:#fff;
  border-color:var(--clr-primary);
  transform:translateY(-2px);
  box-shadow:0 4px 12px rgba(45,106,79,0.2);
}
.header-cta{display:none}
@media(min-width:1024px){
  .btn--cta.header-cta{
    display:inline-flex;
    background: linear-gradient(135deg, var(--clr-primary) 0%, #3a8562 100%) !important;
    color:#fff !important;
    border:none;
    font-weight:var(--fw-bold);
    padding:0 20px;
    height: 40px; /* Exactly aligns with nav links and search toggles */
    border-radius:var(--radius-full) !important;
    box-shadow:0 4px 12px rgba(45,106,79,0.2) !important;
    align-items: center;
    justify-content: center;
  }
  .btn--cta.header-cta:hover{
    transform:translateY(-2px);
    box-shadow:0 8px 20px rgba(45,106,79,0.3) !important;
    filter:brightness(1.05);
  }
}

/* ============================================================
   6b. MEGA MENU
   ============================================================ */
.mega-menu-wrap{position:relative;display:inline-flex;align-items:center;height:100%}
.mega-trigger{display:inline-flex;align-items:center}
.mega-trigger .mega-chevron{stroke:currentColor;fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round;transition:transform .25s ease}
.mega-menu-wrap.open .mega-trigger .mega-chevron{transform:rotate(180deg)}
.mega-menu-wrap.open .mega-trigger{color:var(--clr-primary);background:rgba(45,106,79,.06)}

.mega-menu{
  position:fixed;top:var(--header-h);left:0;right:0;z-index:900;
  background:var(--clr-surface);
  border-top:1px solid var(--clr-border);
  border-bottom:3px solid var(--clr-primary-light);
  box-shadow:0 20px 60px rgba(43,37,32,.12);
  opacity:0;visibility:hidden;
  transform:translateY(-8px);
  transition:opacity .3s cubic-bezier(.16,1,.3,1),transform .3s cubic-bezier(.16,1,.3,1),visibility 0s linear .3s;
  pointer-events:none;
}
.mega-menu-wrap.open .mega-menu{
  opacity:1;visibility:visible;transform:translateY(0);
  transition:opacity .3s cubic-bezier(.16,1,.3,1),transform .3s cubic-bezier(.16,1,.3,1),visibility 0s linear 0s;
  pointer-events:all;
}
.mega-menu__inner{
  display:grid;grid-template-columns:1.2fr 0.9fr 0.7fr;
  gap:var(--sp-8);padding:var(--sp-8) var(--sp-6);align-items:start;
}
.mega-menu__section-label{
  font-size:var(--fs-xs);font-weight:var(--fw-bold);
  letter-spacing:.1em;text-transform:uppercase;color:var(--clr-text-muted);
  margin-bottom:var(--sp-4);padding-bottom:var(--sp-3);border-bottom:1px solid var(--clr-border);
}
.mega-menu__cat-grid{display:flex;flex-direction:column;gap:var(--sp-2)}
.mega-cat-item{
  display:flex;align-items:center;gap:var(--sp-3);
  padding:var(--sp-3) var(--sp-4);border-radius:var(--radius-lg);
  transition:all .2s ease;text-decoration:none;color:var(--clr-text);
  border:1px solid transparent;
}
.mega-cat-item:hover{background:var(--clr-soft);border-color:var(--clr-border);transform:translateX(4px);color:var(--clr-primary)}
.mega-cat-icon{
  font-size:1.35rem;width:36px;height:36px;display:flex;align-items:center;justify-content:center;
  background:var(--clr-bg);border-radius:var(--radius-md);flex-shrink:0;
  transition:transform .25s cubic-bezier(.34,1.56,.64,1);
}
.mega-cat-item:hover .mega-cat-icon{transform:scale(1.15) rotate(-5deg)}
.mega-cat-body{display:flex;flex-direction:column;flex:1}
.mega-cat-name{font-weight:var(--fw-semibold);font-size:var(--fs-sm);line-height:1.2}
.mega-cat-desc{font-size:var(--fs-xs);color:var(--clr-text-muted);margin-top:2px}
.mega-cat-count{
  font-size:10px;font-weight:var(--fw-bold);background:var(--clr-primary);color:#fff;
  padding:2px 7px;border-radius:var(--radius-full);flex-shrink:0;
}
.mega-menu__all-link{
  display:inline-flex;align-items:center;gap:var(--sp-2);
  margin-top:var(--sp-4);font-size:var(--fs-sm);font-weight:var(--fw-bold);
  color:var(--clr-primary);transition:gap .2s ease;text-decoration:none;
}
.mega-menu__all-link:hover{gap:var(--sp-3);color:var(--clr-primary-dark)}
.mega-recipe-row{
  display:flex;align-items:center;gap:var(--sp-3);
  padding:var(--sp-3);border-radius:var(--radius-lg);
  transition:all .2s ease;text-decoration:none;color:var(--clr-text);
  border:1px solid transparent;margin-bottom:var(--sp-2);
}
.mega-recipe-row:hover{background:var(--clr-soft);border-color:var(--clr-border);color:var(--clr-primary)}
.mega-recipe-thumb{
  width:52px;height:52px;border-radius:var(--radius-md);overflow:hidden;
  flex-shrink:0;background:var(--clr-bg);display:flex;align-items:center;justify-content:center;
}
.mega-recipe-thumb img{width:100%;height:100%;object-fit:cover;transition:transform .3s ease}
.mega-recipe-row:hover .mega-recipe-thumb img{transform:scale(1.06)}
.mega-recipe-info{display:flex;flex-direction:column;flex:1;min-width:0}
.mega-recipe-title{
  font-weight:var(--fw-semibold);font-size:var(--fs-sm);line-height:1.3;
  display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;
}
.mega-recipe-time{font-size:var(--fs-xs);color:var(--clr-text-muted);margin-top:3px}
.mega-menu__promo{display:flex;align-items:center;justify-content:center}
.mega-promo-card{
  background:linear-gradient(135deg, var(--clr-primary-dark), var(--clr-primary));
  border-radius:var(--radius-xl);padding:var(--sp-8) var(--sp-6);
  text-align:center;color:#fff;width:100%;position:relative;overflow:hidden;
}
.mega-promo-card::before{
  content:'';position:absolute;top:-40px;right:-40px;
  width:140px;height:140px;border-radius:50%;
  background:radial-gradient(circle, rgba(255,255,255,.15) 0%, transparent 70%);
}
.mega-promo-icon{font-size:2.5rem;margin-bottom:var(--sp-3);display:block;animation:float 3s ease-in-out infinite}
.mega-promo-title{font-family:var(--ff-serif);font-size:var(--fs-lg);font-weight:var(--fw-bold);margin-bottom:var(--sp-2);color:#fff}
.mega-promo-sub{font-size:var(--fs-xs);opacity:.85;margin-bottom:var(--sp-5);line-height:1.6;color:#fff}
.mega-promo-btn{
  display:inline-flex;align-items:center;gap:var(--sp-2);
  background:rgba(255,255,255,.15);border:1px solid rgba(255,255,255,.3);
  backdrop-filter:blur(8px);color:#fff;font-weight:var(--fw-bold);font-size:var(--fs-sm);
  padding:var(--sp-3) var(--sp-5);border-radius:var(--radius-full);text-decoration:none;transition:all .25s ease;
}
.mega-promo-btn:hover{background:rgba(255,255,255,.25);transform:translateY(-2px);color:#fff}
@media(max-width:1023px){.mega-menu-wrap{display:none}}

/* Mobile Nav */

.nav-overlay{
  position:fixed;inset:0;background:var(--clr-overlay);
  z-index:998;opacity:0;pointer-events:none;
  transition:opacity var(--transition-base);
}
.nav-overlay.open{opacity:1;pointer-events:all}
.mobile-menu{
  position:fixed;top:0;right:-100%;width:min(360px,90vw);height:100%;
  background:var(--clr-surface);z-index:1000;
  padding:var(--sp-8) var(--sp-6);
  overflow-y:auto;
  transition:right var(--transition-slow);
  display:flex;flex-direction:column;gap:var(--sp-6);
}
.mobile-menu.open{right:0}
.mobile-menu-header{display:flex;align-items:center;justify-content:space-between}
.mobile-menu-close{
  width:40px;height:40px;border-radius:var(--radius-full);
  background:var(--clr-soft);border:none;cursor:pointer;
  display:flex;align-items:center;justify-content:center;
  transition:all var(--transition-fast);
}
.mobile-menu-close:hover{background:var(--clr-primary);color:#fff}
.mobile-nav a{
  display:flex;align-items:center;gap:var(--sp-3);
  padding:var(--sp-4);border-radius:var(--radius-lg);
  font-weight:var(--fw-semibold);color:var(--clr-text);
  transition:all var(--transition-fast);
  border-bottom:1px solid var(--clr-border);
}
.mobile-nav a:hover{background:var(--clr-soft);color:var(--clr-primary);padding-left:var(--sp-6)}
.mobile-nav a .nav-icon{font-size:1.25rem;width:28px;text-align:center}

/* Search Overlay */
.search-overlay{
  position:fixed;inset:0;background:rgba(17,17,17,0.8);
  z-index:1100;display:flex;align-items:flex-start;justify-content:center;
  padding-top:120px;
  opacity:0;pointer-events:none;
  transition:opacity var(--transition-base);
  backdrop-filter:blur(8px);
}
.search-overlay.open{opacity:1;pointer-events:all}
.search-box{
  width:100%;max-width:640px;
  background:var(--clr-surface);
  border-radius:var(--radius-xl);
  padding:var(--sp-6);
  box-shadow:var(--shadow-xl);
  transform:translateY(-20px);
  transition:transform var(--transition-base);
}
.search-overlay.open .search-box{transform:translateY(0)}
.search-form{display:flex;gap:var(--sp-3);align-items:center}
.search-input{
  flex:1;padding:var(--sp-4) var(--sp-5);
  border:2px solid var(--clr-border);border-radius:var(--radius-full);
  font-size:var(--fs-md);background:var(--clr-soft);
  transition:border-color var(--transition-fast);
}
.search-input:focus{border-color:var(--clr-primary);background:#fff}
.search-close{
  position:absolute;top:var(--sp-4);right:var(--sp-4);
  width:40px;height:40px;border-radius:var(--radius-full);
  background:var(--clr-soft);border:none;cursor:pointer;font-size:1.25rem;
  display:flex;align-items:center;justify-content:center;
}

/* ============================================================
   7. HERO SECTION
   ============================================================ */
.hero{
  position:relative;
  min-height:85vh;
  display:flex;align-items:center;
  overflow:hidden;
  background:var(--clr-bg);
}
.hero::before{
  content:'';position:absolute;inset:0;
  background:radial-gradient(circle at 80% 20%, rgba(211,97,53,0.06) 0%, transparent 50%),
              radial-gradient(circle at 20% 80%, rgba(53,94,59,0.05) 0%, transparent 60%);
}
.hero-inner{
  position:relative;z-index:2;
  display:grid;
  grid-template-columns:1.1fr 0.9fr;
  align-items:center;
  text-align:left;
  gap:var(--sp-10);
  padding-block:var(--sp-16) var(--sp-12);
}
.hero-content{
  color:var(--clr-text);
  max-width:850px;
  display:flex;
  flex-direction:column;
  align-items:flex-start;
  text-align:left;
}
.hero-badge{
  display:inline-flex;align-items:center;gap:var(--sp-2);
  background:rgba(53,94,59,0.06);
  border:1px solid rgba(53,94,59,0.18);
  padding:var(--sp-2) var(--sp-5);
  border-radius:var(--radius-full);
  font-size:var(--fs-xs);font-weight:var(--fw-semibold);
  letter-spacing:0.08em;text-transform:uppercase;
  color:var(--clr-primary);
  margin-bottom:var(--sp-6);
}
.hero-badge-dot{width:6px;height:6px;border-radius:50%;background:var(--clr-secondary);animation:pulse 2s infinite}
@keyframes pulse{0%,100%{opacity:1;transform:scale(1)}50%{opacity:0.7;transform:scale(1.2)}}
.hero-title{
  font-size:clamp(3rem,6vw,4.8rem);
  font-family:var(--ff-serif);
  font-weight:var(--fw-black);
  line-height:1.1;
  color:var(--clr-text);
  margin-bottom:var(--sp-5);
  text-align:left;
}
.hero-title .highlight{
  color:var(--clr-secondary);
  background:linear-gradient(to right, #D36135, #E5A93C);
  -webkit-background-clip:text;
  -webkit-text-fill-color:transparent;
  position:relative;display:inline-block;
}
.hero-subtitle{
  font-size:var(--fs-lg);
  color:var(--clr-text-muted);
  line-height:var(--lh-loose);
  max-width:620px;
  margin-bottom:var(--sp-8);
  text-align:left;
}
.hero-actions{display:flex;gap:var(--sp-4);justify-content:flex-start;flex-wrap:wrap}
.hero-stats{
  display:flex;gap:var(--sp-12);margin-top:var(--sp-8);
  padding-top:var(--sp-6);border-top:1px solid var(--clr-border);
  justify-content:flex-start;
  width:100%;
  max-width:580px;
}
.hero-stat{color:var(--clr-text)}
.hero-stat-number{
  font-family:var(--ff-serif);font-size:var(--fs-2xl);
  font-weight:var(--fw-bold);line-height:1;
  margin-bottom:var(--sp-1);
  color:var(--clr-primary);
}
.hero-stat-label{font-size:var(--fs-xs);color:var(--clr-text-muted);text-transform:uppercase;letter-spacing:0.06em}

.hero-image{
  position:relative;
  width:100%;
  max-width:1200px;
}
.hero-image-frame{
  position:relative;border-radius:24px;
  overflow:hidden;
  aspect-ratio:16/10;
  box-shadow:0 25px 50px rgba(43,37,32,0.12);
  border:8px solid #fff;
}
.hero-image-frame img{width:100%;height:100%;object-fit:cover;transition:transform var(--transition-slow)}
.hero-image:hover .hero-image-frame img{transform:scale(1.03)}
.hero-image-badge{
  position:absolute;bottom:var(--sp-6);left:var(--sp-6);
  background:rgba(253,251,247,0.92);
  padding:var(--sp-4) var(--sp-5);
  border-radius:var(--radius-xl);
  display:flex;align-items:center;gap:var(--sp-3);
  box-shadow:0 10px 25px rgba(43,37,32,0.1);
  backdrop-filter:blur(20px);
  -webkit-backdrop-filter:blur(20px);
  border:1px solid var(--clr-border);
}
.hero-image-badge-icon{font-size:2rem}
.hero-image-badge-text{font-weight:var(--fw-semibold);font-size:var(--fs-sm);line-height:1.3;color:var(--clr-text)}
.hero-image-badge-text span{display:block;color:var(--clr-text-muted);font-size:var(--fs-xs);font-weight:var(--fw-regular)}
.hero-floating{
  position:absolute;top:var(--sp-6);right:-var(--sp-6);
  background:linear-gradient(135deg, #F4A261, #E76F51);
  color:#fff;
  border-radius:var(--radius-xl);padding:var(--sp-4);
  box-shadow:0 15px 35px rgba(231,111,81,0.25);
  text-align:center;min-width:95px;
  animation:float 4s ease-in-out infinite;
}
@keyframes float {
  0%, 100% { transform: translateY(0); }
  50% { transform: translateY(-8px); }
}
.hero-floating-num{font-family:var(--ff-serif);font-size:var(--fs-2xl);font-weight:var(--fw-bold);line-height:1}
.hero-floating-label{font-size:var(--fs-xs);opacity:0.9;font-weight:var(--fw-semibold)}

/* ============================================================
   8. SECTION HEADERS
   ============================================================ */
.section-header{margin-bottom:var(--sp-10);text-align:center}
.section-header--left{text-align:left}
.section-overline{
  display:inline-block;
  font-size:var(--fs-xs);font-weight:var(--fw-bold);
  letter-spacing:0.12em;text-transform:uppercase;
  color:var(--clr-secondary);
  margin-bottom:var(--sp-3);
}
.section-title{font-size:clamp(1.75rem,3vw,var(--fs-3xl));margin-bottom:var(--sp-4)}
.section-subtitle{font-size:var(--fs-md);color:var(--clr-text-muted);max-width:560px;margin-inline:auto}
.section-header--left .section-subtitle{margin-inline:0}
.section-link{font-size:var(--fs-sm);font-weight:var(--fw-semibold);color:var(--clr-primary);display:inline-flex;align-items:center;gap:var(--sp-1)}
.section-link:hover{color:var(--clr-primary-dark);gap:var(--sp-2)}
.section-link svg{transition:transform var(--transition-fast)}
.section-link:hover svg{transform:translateX(3px)}

/* ============================================================
   9. CATEGORY CARDS
   ============================================================ */
.categories-section{background:var(--clr-surface)}
.category-grid{
  display:grid;
  grid-template-columns:repeat(5, 1fr);
  gap:var(--sp-6);
}
.category-card{
  position:relative;overflow:hidden;
  display:flex;flex-direction:column;
  cursor:pointer;
  transition:transform 0.4s cubic-bezier(0.165, 0.84, 0.44, 1), box-shadow 0.4s ease, border-color 0.4s ease;
  box-shadow:0 10px 30px rgba(0,0,0,0.06);
  border:2px solid var(--clr-border);
  aspect-ratio:1/1 !important;
  border-radius:16px !important;
  justify-content:flex-end;
}
.category-card:hover{
  transform:translateY(-8px) scale(1.02);
  box-shadow:0 20px 40px rgba(0,0,0,0.12);
  border-color:var(--clr-secondary);
}
.category-card-img{
  position:absolute;inset:0;width:100%;height:100%;
  object-fit:cover;
  transition:transform 0.6s cubic-bezier(0.165, 0.84, 0.44, 1);
}
.category-card:hover .category-card-img{transform:scale(1.12)}
.category-card-overlay{
  position:absolute;inset:0;
  transition:all 0.4s ease;
  background:linear-gradient(to top, rgba(43,37,32,0.85) 0%, rgba(43,37,32,0.1) 60%, transparent 100%) !important;
}
.category-card:hover .category-card-overlay {
  opacity:0.95;
}
.category-card-body{
  position:relative;z-index:2;
  padding:var(--sp-4);
  width:100%;
  text-align:center;
}
.category-card-icon{
  font-size:2rem;
  margin-bottom:var(--sp-2);
  transition:transform 0.3s cubic-bezier(0.175, 0.885, 0.32, 1.275);
  display:inline-block;
}
.category-card:hover .category-card-icon {
  transform:scale(1.2) rotate(-5deg);
}
.category-card-title{
  font-family:var(--ff-serif);font-size:var(--fs-md);
  font-weight:var(--fw-bold);color:#fff;line-height:var(--lh-snug);
  margin-bottom:var(--sp-1);
}
.category-card-count{font-size:var(--fs-xs);color:rgba(255,255,255,0.85);font-weight:var(--fw-semibold)}
.category-card-badge{
  position:absolute;top:var(--sp-4);right:var(--sp-4);
  background:linear-gradient(135deg, #F4A261, #E76F51);
  color:#fff;
  font-size:var(--fs-xs);font-weight:var(--fw-bold);
  padding:4px 12px;border-radius:var(--radius-full);
  box-shadow:0 6px 15px rgba(231,111,81,0.35);
}

/* ============================================================
   10. RECIPE CARD
   ============================================================ */
.recipe-card {
  background: var(--clr-surface);
  border-radius: var(--radius-xl);
  overflow: hidden;
  box-shadow: 0 4px 16px rgba(43, 37, 32, 0.03);
  border: 1px solid rgba(231, 221, 208, 0.7);
  transition: transform 0.4s cubic-bezier(0.16, 1, 0.3, 1), box-shadow 0.4s cubic-bezier(0.16, 1, 0.3, 1), border-color 0.3s;
  display: flex;
  flex-direction: column;
}
.recipe-card:hover {
  box-shadow: 0 16px 36px rgba(43, 37, 32, 0.08);
  transform: translateY(-5px);
  border-color: var(--clr-primary-light);
}
.recipe-card-image {
  position: relative;
  aspect-ratio: 4/3;
  overflow: hidden;
  background-color: var(--clr-soft);
}
.recipe-card-image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 0.6s cubic-bezier(0.16, 1, 0.3, 1);
}
.recipe-card:hover .recipe-card-image img {
  transform: scale(1.04);
}
.recipe-card-tags {
  position: absolute;
  top: var(--sp-3);
  left: var(--sp-3);
  display: flex;
  gap: var(--sp-2);
  flex-wrap: wrap;
  z-index: 3;
}
.tag-badge {
  background: var(--clr-primary);
  color: #fff;
  font-size: 10px;
  font-weight: var(--fw-bold);
  padding: 4px 10px;
  border-radius: var(--radius-full);
  text-transform: uppercase;
  letter-spacing: 0.5px;
  box-shadow: var(--shadow-xs);
}
.tag-badge--secondary {
  background: var(--clr-secondary);
}
.tag-badge--cta {
  background: var(--clr-cta);
}
.recipe-card-save {
  position: absolute;
  top: var(--sp-3);
  right: var(--sp-3);
  width: 34px;
  height: 34px;
  border-radius: 50%;
  background: rgba(255, 255, 255, 0.9);
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
  display: flex;
  align-items: center;
  justify-content: center;
  border: 1px solid rgba(0,0,0,0.05);
  cursor: pointer;
  font-size: 0.95rem;
  color: var(--clr-text-muted);
  transition: all var(--transition-fast);
  z-index: 3;
}
.recipe-card-save:hover, .recipe-card-save.saved {
  background: var(--clr-secondary);
  color: #fff;
  transform: scale(1.1);
  border-color: var(--clr-secondary);
}
.recipe-card-body {
  padding: var(--sp-5);
  flex: 1;
  display: flex;
  flex-direction: column;
}
.recipe-card-meta {
  display: flex;
  align-items: center;
  gap: var(--sp-3);
  margin-bottom: var(--sp-3);
}
.recipe-card-category {
  font-size: 11px;
  font-weight: var(--fw-bold);
  color: var(--clr-secondary);
  text-transform: uppercase;
  letter-spacing: 0.08em;
  text-decoration: none;
  transition: color var(--transition-fast);
}
.recipe-card-category:hover {
  color: var(--clr-secondary-dark);
}
.recipe-card-time {
  display: flex;
  align-items: center;
  gap: 4px;
  font-size: var(--fs-xs);
  color: var(--clr-text-muted);
  margin-left: auto;
  font-weight: var(--fw-medium);
}
.recipe-card-title {
  font-family: var(--ff-serif);
  font-size: 1.2rem;
  font-weight: var(--fw-bold);
  line-height: var(--lh-snug);
  margin-bottom: var(--sp-3);
  color: var(--clr-text);
  transition: color var(--transition-fast);
}
.recipe-card-title a {
  color: inherit;
  text-decoration: none;
}
.recipe-card:hover .recipe-card-title {
  color: var(--clr-primary);
}
.recipe-card-excerpt {
  font-size: var(--fs-sm);
  color: var(--clr-text-muted);
  line-height: var(--lh-normal);
  margin-bottom: var(--sp-4);
  flex: 1;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}
.recipe-card-footer {
  display: flex;
  align-items: center;
  gap: var(--sp-3);
  padding-top: var(--sp-4);
  border-top: 1px solid rgba(231, 221, 208, 0.6);
  margin-top: auto;
}
.recipe-card-rating {
  display: flex;
  align-items: center;
  gap: 4px;
  font-size: var(--fs-xs);
  font-weight: var(--fw-bold);
  color: var(--clr-text-muted);
}
.stars {
  color: #E5A93C;
  letter-spacing: 1px;
}
.recipe-card-author {
  display: flex;
  align-items: center;
  gap: var(--sp-2);
  margin-left: auto;
  font-size: var(--fs-xs);
  color: var(--clr-text-muted);
  font-weight: var(--fw-medium);
}
.author-avatar {
  width: 24px;
  height: 24px;
  border-radius: 50%;
  object-fit: cover;
  border: 1px solid var(--clr-border);
}

/* Recipe Card – Horizontal */
.recipe-card--h {
  flex-direction: row;
}
.recipe-card--h .recipe-card-image {
  width: 160px;
  flex-shrink: 0;
  aspect-ratio: auto;
  height: auto;
}
.recipe-card--h .recipe-card-title {
  font-size: var(--fs-base);
}

/* Recipe Card – Featured */
.recipe-card--featured {
  position: relative;
  border-radius: var(--radius-xl);
  overflow: hidden;
  grid-column: span 2;
  aspect-ratio: 16/10;
  border-color: rgba(231, 221, 208, 0.4);
}
.recipe-card--featured .recipe-card-image {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  aspect-ratio: auto;
}
.recipe-card--featured .recipe-card-image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.recipe-card--featured .recipe-card-body {
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  background: linear-gradient(to top, rgba(31, 56, 36, 0.95) 0%, rgba(31, 56, 36, 0.6) 50%, transparent 100%);
  color: #fff;
  padding: var(--sp-8) var(--sp-6) var(--sp-6);
  z-index: 2;
}
.recipe-card--featured .recipe-card-title {
  color: #fff;
  font-size: 1.65rem;
  margin-bottom: var(--sp-2);
}
.recipe-card--featured .recipe-card-title a {
  color: #fff;
}
.recipe-card--featured:hover .recipe-card-title {
  color: var(--clr-cta);
}
.recipe-card--featured .recipe-card-excerpt {
  color: rgba(255, 255, 255, 0.85);
  margin-bottom: var(--sp-4);
}
.recipe-card--featured .recipe-card-category {
  color: var(--clr-cta);
}
.recipe-card--featured .recipe-card-time {
  color: rgba(255, 255, 255, 0.8);
}
.recipe-card--featured .recipe-card-footer {
  border-color: rgba(255, 255, 255, 0.15);
}
.recipe-card--featured .recipe-card-author {
  color: rgba(255, 255, 255, 0.8);
}

/* ============================================================
   11. SLIDER / CAROUSEL
   ============================================================ */
.slider-wrapper{position:relative;overflow:hidden}
.slider-track{
  display:flex;gap:var(--sp-5);
  transition:transform var(--transition-slow);
  will-change:transform;
}
.slider-track .recipe-card{width:300px;flex-shrink:0}
.slider-btn{
  position:absolute;top:50%;transform:translateY(-50%);
  width:48px;height:48px;border-radius:50%;
  background:var(--clr-surface);border:2px solid var(--clr-border);
  display:flex;align-items:center;justify-content:center;
  cursor:pointer;z-index:2;font-size:1.25rem;
  box-shadow:var(--shadow-md);
  transition:all var(--transition-fast);
}
.slider-btn:hover{background:var(--clr-primary);color:#fff;border-color:var(--clr-primary)}
.slider-btn--prev{left:-24px}
.slider-btn--next{right:-24px}
.slider-dots{display:flex;justify-content:center;gap:var(--sp-2);margin-top:var(--sp-6)}
.slider-dot{width:8px;height:8px;border-radius:50%;background:var(--clr-border);cursor:pointer;transition:all var(--transition-fast)}
.slider-dot.active{width:24px;border-radius:4px;background:var(--clr-primary)}

/* ============================================================
   12. PINTEREST CTA
   ============================================================ */
.pinterest-cta {
  background: linear-gradient(135deg, #B24C24 0%, #D36135 60%, #E5A93C 100%);
  border-radius: 28px;
  padding: var(--sp-12);
  color: #fff;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--sp-12);
  position: relative;
  overflow: hidden;
  box-shadow: 0 25px 60px rgba(211, 97, 53, 0.25);
  border: 1px solid rgba(255, 255, 255, 0.1);
}

.pinterest-cta::before {
  content: '';
  position: absolute;
  top: -100px;
  right: -100px;
  width: 400px;
  height: 400px;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(255,255,255,0.2) 0%, transparent 70%);
}

.pinterest-cta-content {
  flex: 1;
  max-width: 500px;
  z-index: 2;
}

.pinterest-cta-title {
  font-family: var(--ff-serif);
  font-size: var(--fs-3xl);
  font-weight: var(--fw-black);
  color: #fff;
  margin-bottom: var(--sp-4);
  line-height: 1.1;
  text-shadow: 0 2px 10px rgba(43,37,32,0.15);
}

.pinterest-cta-text {
  font-size: var(--fs-lg);
  opacity: 0.95;
  margin-bottom: var(--sp-8);
  line-height: var(--lh-loose);
  text-shadow: 0 1px 5px rgba(43,37,32,0.08);
}

.pinterest-btn {
  background: #fff;
  color: #D36135;
  font-weight: var(--fw-black);
  display: inline-flex;
  align-items: center;
  gap: var(--sp-3);
  padding: var(--sp-4) var(--sp-10);
  border-radius: var(--radius-full);
  font-size: var(--fs-md);
  text-transform: uppercase;
  letter-spacing: 0.05em;
  transition: all 0.4s cubic-bezier(0.175, 0.885, 0.32, 1.275);
  box-shadow: 0 10px 25px rgba(43,37,32,0.15);
}

.pinterest-btn:hover {
  transform: translateY(-4px) scale(1.03);
  box-shadow: 0 15px 30px rgba(43,37,32,0.25);
  color: #1F3824;
}

.pinterest-images {
  display: flex;
  gap: var(--sp-4);
  z-index: 1;
}

.pinterest-thumb {
  width: 140px;
  height: 200px;
  border-radius: 12px;
  overflow: hidden;
  box-shadow: 0 15px 35px rgba(43,37,32,0.25);
  transition: transform 0.6s cubic-bezier(0.165, 0.84, 0.44, 1), box-shadow 0.6s ease;
  border: 6px solid #fff;
  position: relative;
}

.pinterest-thumb::before {
  content: '📌';
  position: absolute;
  top: -2px;
  left: 50%;
  transform: translateX(-50%) rotate(15deg);
  font-size: 1.4rem;
  z-index: 10;
  filter: drop-shadow(0 2px 4px rgba(0,0,0,0.15));
}

.pinterest-thumb:nth-child(1) { transform: rotate(-6deg) translateY(15px); }
.pinterest-thumb:nth-child(2) { transform: rotate(4deg) translateY(-12px); }
.pinterest-thumb:nth-child(3) { transform: rotate(-3deg) translateY(20px); }
.pinterest-thumb:nth-child(4) { transform: rotate(5deg) translateY(-5px); }

.pinterest-cta:hover .pinterest-thumb {
  transform: rotate(0deg) translateY(-8px) scale(1.05);
  box-shadow: 0 25px 45px rgba(0, 0, 0, 0.35);
}

.pinterest-thumb img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

/* ============================================================
   13. NEWSLETTER
   ============================================================ */
/* ============================================================
   13. NEWSLETTER
   ============================================================ */
.newsletter-section {
  background: var(--clr-primary-dark);
  background-image: radial-gradient(circle at top right, rgba(211,97,53,0.12) 0%, transparent 50%),
                    radial-gradient(circle at bottom left, rgba(229,169,60,0.1) 0%, transparent 40%);
  position: relative;
  overflow: hidden;
  padding: var(--sp-16) 0;
  border-radius: 30px;
  margin-block: var(--sp-12);
  box-shadow: 0 20px 50px rgba(31,56,36,0.15);
}

.newsletter-section::before {
  content: '';
  position: absolute;
  inset: 0;
  background: url('assets/images/dots-pattern.svg') repeat;
  opacity: 0.02;
  mix-blend-mode: overlay;
}

.newsletter-inner {
  position: relative;
  z-index: 1;
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  gap: var(--sp-8);
  width: 100%;
}

.newsletter-content {
  color: #fff;
  max-width: 700px;
}

.newsletter-overline {
  color: var(--clr-secondary);
  font-size: var(--fs-sm);
  font-weight: var(--fw-bold);
  letter-spacing: 0.2em;
  text-transform: uppercase;
  margin-bottom: var(--sp-4);
  display: inline-block;
  background: rgba(211, 97, 53, 0.15);
  padding: var(--sp-1) var(--sp-4);
  border-radius: var(--radius-full);
}

.newsletter-title {
  font-family: var(--ff-serif);
  font-size: clamp(2.2rem, 5vw, var(--fs-4xl));
  color: #fff;
  font-weight: var(--fw-black);
  margin-bottom: var(--sp-4);
  line-height: 1.1;
  text-shadow: 0 2px 8px rgba(43,37,32,0.15);
}

.newsletter-text {
  color: rgba(250, 246, 240, 0.9);
  line-height: 1.8;
  font-size: var(--fs-lg);
  margin-bottom: 0;
}

.newsletter-form-container {
  width: 100%;
  max-width: 800px;
}

.newsletter-form-wrapper {
  background: rgba(253, 251, 247, 0.96);
  border: 1px solid var(--clr-border);
  border-radius: 24px;
  padding: var(--sp-8) var(--sp-10);
  box-shadow: 0 30px 60px rgba(43,37,32,0.15);
}

.newsletter-form {
  display: grid !important;
  grid-template-columns: 1fr 1fr !important;
  gap: var(--sp-5) !important;
  text-align: left !important;
  align-items: flex-end !important;
}

.newsletter-form > div {
  width: 100% !important;
}

.newsletter-form label {
  color: var(--clr-text);
  font-size: var(--fs-sm);
  font-weight: var(--fw-bold);
  margin-bottom: 6px;
  display: block;
}

.newsletter-form input {
  width: 100%;
  padding: var(--sp-4) var(--sp-5);
  border-radius: var(--radius-xl);
  border: 2px solid var(--clr-border);
  background: var(--clr-bg);
  color: var(--clr-text);
  font-size: var(--fs-base);
  transition: all 0.3s ease;
  height: 52px;
}

.newsletter-form input::placeholder { color: var(--clr-text-light); }

.newsletter-form input:focus {
  border-color: var(--clr-secondary);
  background: #fff;
  box-shadow: 0 0 0 4px rgba(211, 97, 53, 0.2);
  outline: none;
}

.newsletter-form .btn {
  grid-column: span 2 !important;
  width: 100% !important;
  padding: 0 var(--sp-8);
  font-size: var(--fs-md);
  border-radius: var(--radius-xl);
  font-weight: var(--fw-black);
  text-transform: uppercase;
  letter-spacing: 0.1em;
  background: linear-gradient(135deg, #F4A261 0%, #E76F51 100%);
  color: #fff;
  box-shadow: 0 8px 20px rgba(231, 111, 81, 0.3);
  border: none;
  transition: all 0.3s ease;
  height: 52px;
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
}
.newsletter-form .btn:hover {
  transform: translateY(-2px);
  box-shadow: 0 12px 25px rgba(231, 111, 81, 0.45);
}

.newsletter-disclaimer {
  grid-column: span 2 !important;
  font-size: var(--fs-xs);
  color: var(--clr-text-muted);
  margin-top: var(--sp-4);
  text-align: center;
  line-height: 1.5;
}

@media (max-width: 768px) {
  .newsletter-form {
    grid-template-columns: 1fr !important;
    gap: var(--sp-4) !important;
  }
  .newsletter-form .btn {
    grid-column: span 1 !important;
    width: 100% !important;
  }
}

@media (max-width: 992px) {
  .pinterest-cta { flex-direction: column; text-align: center; }
  .pinterest-images { justify-content: center; transform: scale(0.8); }
  .newsletter-inner { flex-direction: column; gap: var(--sp-12); }
  .newsletter-content { text-align: center; }
  .newsletter-form-container { max-width: 100%; width: 100%; }
}

/* ============================================================
   14. FOOTER
   ============================================================ */
.site-footer{
  background:var(--clr-primary-dark);color:rgba(250,246,240,0.75);
}
.footer-main{padding:var(--sp-16) 0;display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:var(--sp-10)}
.footer-brand .logo-text{color:#fff;font-size:var(--fs-xl)}
.footer-brand .logo-text span {color:var(--clr-secondary)}
.footer-desc{font-size:var(--fs-sm);line-height:var(--lh-loose);margin:var(--sp-4) 0 var(--sp-6);color:rgba(250,246,240,0.7)}
.footer-socials{display:flex;gap:var(--sp-3)}
.social-link{
  width:40px;height:40px;border-radius:50%;
  background:rgba(250,246,240,0.08);
  display:flex;align-items:center;justify-content:center;
  font-size:1.1rem;color:rgba(250,246,240,0.75);
  transition:all var(--transition-fast);
}
.social-link:hover{background:var(--clr-secondary);color:#fff;transform:translateY(-3px);box-shadow:0 8px 20px rgba(211,97,53,0.35)}
.footer-heading{
  font-family:var(--ff-sans);font-size:var(--fs-xs);
  font-weight:var(--fw-bold);letter-spacing:0.12em;
  text-transform:uppercase;color:#fff;
  margin-bottom:var(--sp-5);
}
.footer-links{display:flex;flex-direction:column;gap:var(--sp-3)}
.footer-links a{font-size:var(--fs-sm);color:rgba(250,246,240,0.65);transition:all var(--transition-fast);display:flex;align-items:center;gap:var(--sp-2)}
.footer-links a::before{content:'→';color:var(--clr-secondary);opacity:0;transform:translateX(-4px);transition:all var(--transition-fast)}
.footer-links a:hover{color:#fff;padding-left:var(--sp-3)}
.footer-links a:hover::before{opacity:1;transform:translateX(0)}
.footer-bottom{
  border-top:1px solid rgba(250,246,240,0.08);
  padding:var(--sp-6) 0;
  display:flex;align-items:center;justify-content:space-between;
  flex-wrap:wrap;gap:var(--sp-4);
  font-size:var(--fs-sm);color:rgba(250,246,240,0.45);
}
.footer-legal{display:flex;gap:var(--sp-5);flex-wrap:wrap}
.footer-legal a{color:rgba(250,246,240,0.45);font-size:var(--fs-xs);transition:color var(--transition-fast)}
.footer-legal a:hover{color:#fff}

/* ============================================================
   15. SINGLE RECIPE PAGE
   ============================================================ */
.recipe-hero{
  position:relative;max-height:70vh;overflow:hidden;
  border-radius:0 0 var(--radius-2xl) var(--radius-2xl);
}
.recipe-hero-img{width:100%;height:70vh;object-fit:cover}
.recipe-hero-overlay{
  position:absolute;inset:0;
  background:linear-gradient(to top,rgba(17,17,17,0.75) 0%,transparent 60%);
}

.single-recipe-layout{
  display:grid;
  grid-template-columns:1fr 340px;
  gap:var(--sp-10);
  padding-top:var(--sp-10);
}

/* Breadcrumbs */
.breadcrumbs{
  display:flex;align-items:center;gap:var(--sp-2);
  font-size:var(--fs-sm);color:var(--clr-text-muted);
  flex-wrap:wrap;margin-bottom:var(--sp-6);
}
.breadcrumbs a{color:var(--clr-primary)}
.breadcrumbs span{color:var(--clr-border)}

/* Recipe Header */
.recipe-header{margin-bottom:var(--sp-8)}
.recipe-title{font-size:clamp(2rem,4vw,var(--fs-4xl));margin-bottom:var(--sp-5)}
.recipe-meta-row{display:flex;align-items:center;gap:var(--sp-5);flex-wrap:wrap;margin-bottom:var(--sp-5)}
.recipe-rating-display{display:flex;align-items:center;gap:var(--sp-2)}
.rating-stars{color:#F59E0B;font-size:var(--fs-lg)}
.rating-val{font-weight:var(--fw-bold);font-size:var(--fs-md)}
.rating-count{font-size:var(--fs-sm);color:var(--clr-text-muted)}
.recipe-author-info{display:flex;align-items:center;gap:var(--sp-2);font-size:var(--fs-sm);color:var(--clr-text-muted)}
.recipe-date{font-size:var(--fs-sm);color:var(--clr-text-muted)}

/* Quick Info Bar */
.quick-info-bar{
  display:grid;grid-template-columns:repeat(6,1fr);
  background:var(--clr-soft);
  border-radius:var(--radius-xl);
  padding:var(--sp-5);gap:var(--sp-4);
  margin-bottom:var(--sp-8);
  border:1px solid var(--clr-border);
}
.quick-info-item{text-align:center;padding:var(--sp-3);border-radius:var(--radius-lg)}
.quick-info-icon{font-size:1.5rem;margin-bottom:var(--sp-2)}
.quick-info-label{font-size:var(--fs-xs);color:var(--clr-text-muted);text-transform:uppercase;letter-spacing:0.06em;display:block;margin-bottom:var(--sp-1)}
.quick-info-value{font-weight:var(--fw-bold);font-size:var(--fs-base);color:var(--clr-text)}

/* Recipe Action Buttons */
.recipe-actions{display:flex;gap:var(--sp-3);flex-wrap:wrap;margin-bottom:var(--sp-8)}

/* Ingredients */
.ingredients-box{
  background:var(--clr-soft);
  border-radius:var(--radius-xl);padding:var(--sp-6);
  border:1px solid var(--clr-border);
  margin-bottom:var(--sp-8);
}
.ingredients-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--sp-5)}
.ingredients-title{font-family:var(--ff-serif);font-size:var(--fs-xl);font-weight:var(--fw-bold)}
.servings-control{display:flex;align-items:center;gap:var(--sp-3)}
.servings-btn{
  width:32px;height:32px;border-radius:50%;border:2px solid var(--clr-primary);
  color:var(--clr-primary);font-weight:var(--fw-bold);display:flex;
  align-items:center;justify-content:center;cursor:pointer;font-size:1rem;
  transition:all var(--transition-fast);background:transparent;
}
.servings-btn:hover{background:var(--clr-primary);color:#fff}
.servings-count{font-weight:var(--fw-bold);min-width:24px;text-align:center}
.ingredient-list{display:grid;gap:var(--sp-2)}
.ingredient-item{
  display:flex;align-items:center;gap:var(--sp-3);
  padding:var(--sp-3);border-radius:var(--radius-md);
  transition:background var(--transition-fast);cursor:pointer;
}
.ingredient-item:hover{background:rgba(45,106,79,0.06)}
.ingredient-item.checked{opacity:0.5;text-decoration:line-through}
.ingredient-checkbox{
  width:20px;height:20px;border-radius:var(--radius-sm);
  border:2px solid var(--clr-border);flex-shrink:0;
  display:flex;align-items:center;justify-content:center;
  transition:all var(--transition-fast);
}
.ingredient-item.checked .ingredient-checkbox{background:var(--clr-primary);border-color:var(--clr-primary);color:#fff}
.ingredient-amount{font-weight:var(--fw-semibold);min-width:60px;color:var(--clr-primary)}
.ingredient-name{color:var(--clr-text)}

/* Steps */
.steps-list{counter-reset:step;display:grid;gap:var(--sp-6);margin-bottom:var(--sp-8)}
.step-item{
  display:flex;gap:var(--sp-5);
  padding:var(--sp-6);
  background:var(--clr-surface);
  border-radius:var(--radius-xl);
  border:1px solid var(--clr-border);
  position:relative;
}
.step-number{
  width:44px;height:44px;border-radius:50%;
  background:var(--clr-primary);color:#fff;
  display:flex;align-items:center;justify-content:center;
  font-family:var(--ff-serif);font-size:var(--fs-lg);font-weight:var(--fw-bold);
  flex-shrink:0;
}
.step-content{flex:1}
.step-title{font-weight:var(--fw-semibold);margin-bottom:var(--sp-2)}
.step-text{color:var(--clr-text-muted);line-height:var(--lh-loose)}

/* Nutrition Facts */
.nutrition-box{
  border:2px solid var(--clr-primary);
  border-radius:var(--radius-xl);padding:var(--sp-6);
  margin-bottom:var(--sp-8);
}
.nutrition-title{font-family:var(--ff-serif);font-size:var(--fs-xl);font-weight:var(--fw-bold);margin-bottom:var(--sp-5);text-align:center;border-bottom:4px solid var(--clr-text);padding-bottom:var(--sp-3)}
.nutrition-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--sp-3)}
.nutrition-item{display:flex;justify-content:space-between;align-items:center;padding:var(--sp-2) 0;border-bottom:1px solid var(--clr-border)}
.nutrition-label{font-size:var(--fs-sm);color:var(--clr-text-muted)}
.nutrition-value{font-weight:var(--fw-bold);font-size:var(--fs-sm)}
.nutrition-total{background:var(--clr-soft);padding:var(--sp-3);border-radius:var(--radius-md);display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--sp-4);font-weight:var(--fw-bold)}

/* Recipe Timer */
.timer-widget{
  background:linear-gradient(135deg,var(--clr-primary),var(--clr-primary-dark));
  border-radius:var(--radius-xl);padding:var(--sp-6);
  color:#fff;text-align:center;margin-bottom:var(--sp-6);
}
.timer-display{font-family:var(--ff-serif);font-size:3rem;font-weight:var(--fw-black);letter-spacing:5px;margin:var(--sp-4) 0}
.timer-controls{display:flex;justify-content:center;gap:var(--sp-3)}
.timer-btn{
  padding:var(--sp-3) var(--sp-6);border-radius:var(--radius-full);
  font-weight:var(--fw-semibold);font-size:var(--fs-sm);cursor:pointer;
  transition:all var(--transition-fast);border:2px solid rgba(255,255,255,0.3);
  background:rgba(255,255,255,0.15);color:#fff;
}
.timer-btn:hover{background:rgba(255,255,255,0.25)}
.timer-btn--start{background:var(--clr-cta);border-color:var(--clr-cta)}
.timer-btn--start:hover{background:var(--clr-cta-dark)}

/* Sticky Sidebar */
.recipe-sidebar{position:sticky;top:calc(var(--header-h) + var(--sp-6));height:fit-content}
.sidebar-card{
  background:var(--clr-surface);
  border-radius:var(--radius-xl);
  padding:var(--sp-6);
  border:1px solid var(--clr-border);
  margin-bottom:var(--sp-5);
}
.sidebar-card-title{
  font-family:var(--ff-serif);font-size:var(--fs-lg);
  font-weight:var(--fw-bold);margin-bottom:var(--sp-4);
  padding-bottom:var(--sp-3);border-bottom:2px solid var(--clr-soft);
}

/* AdSense placeholder */
.adsense-slot{
  background:var(--clr-soft);border:2px dashed var(--clr-border);
  border-radius:var(--radius-lg);display:flex;align-items:center;
  justify-content:center;color:var(--clr-text-light);font-size:var(--fs-xs);
  min-height:90px;margin:var(--sp-6) 0;
  text-align:center;
}
.adsense-slot--rectangle{min-height:250px}
.adsense-slot--banner{min-height:90px}
.adsense-slot--sidebar{min-height:600px}

/* Sticky mobile CTA */
.mobile-sticky-cta{
  display:none;position:fixed;bottom:0;left:0;right:0;z-index:500;
  background:var(--clr-surface);border-top:1px solid var(--clr-border);
  padding:var(--sp-3) var(--sp-4);
  display:flex;gap:var(--sp-3);align-items:center;
}

/* ============================================================
   41. PREMIUM TABLE OF CONTENTS (TOC)
   ============================================================ */
.table-of-contents {
  background: #f8fafc;
  border: 1px solid #e2e8f0;
  border-radius: 16px;
  padding: 0;
  margin: 32px 0;
  overflow: hidden;
  box-shadow: 0 4px 6px -1px rgba(0, 0, 0, 0.05);
}

.toc-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 16px 24px;
  background: #fff;
  border-bottom: 1px solid #e2e8f0;
}

.toc-title {
  font-size: 1.1rem !important;
  margin: 0 !important;
  font-weight: 700;
  color: #0f172a;
  display: flex;
  align-items: center;
  gap: 10px;
  border-bottom: none !important;
  padding: 0 !important;
}

.toc-toggle {
  background: #f1f5f9;
  border: none;
  padding: 4px 12px;
  border-radius: 6px;
  font-size: 0.85rem;
  font-weight: 600;
  color: #475569;
  cursor: pointer;
  transition: all 0.2s ease;
}

.toc-toggle:hover {
  background: #e2e8f0;
  color: #0f172a;
}

.toc-body {
  padding: 24px;
  transition: all 0.3s ease;
}

.table-of-contents.collapsed .toc-body {
  display: none;
}

.toc-list {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
  gap: 12px;
  list-style: none !important;
  padding: 0 !important;
  margin: 0 !important;
}

.toc-list li {
  margin: 0 !important;
}

.toc-list li a {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 8px 12px;
  background: #fff;
  border: 1px solid #f1f5f9;
  border-radius: 8px;
  color: #334155;
  text-decoration: none;
  font-size: 0.95rem;
  font-weight: 500;
  transition: all 0.2s ease;
}

.toc-list li a:hover {
  background: #2d6a4f;
  color: #fff;
  border-color: #2d6a4f;
  transform: translateX(4px);
}

.toc-list li.toc-core a {
  background: #f0fdf4;
  border-color: #dcfce7;
  color: #166534;
  font-weight: 700;
}

.toc-list li.toc-core a:hover {
  background: #2d6a4f;
  color: #fff;
}

html.dark-mode .table-of-contents {
  background: #1e293b;
  border-color: #334155;
}
html.dark-mode .toc-header {
  background: #1e293b;
  border-color: #334155;
}
html.dark-mode .toc-title { color: #f8fafc; }
html.dark-mode .toc-list li a { background: #0f172a; border-color: #1e293b; color: #cbd5e1; }
html.dark-mode .toc-list li.toc-core a { background: rgba(45,106,79,0.1); border-color: #2d6a4f; }

/* ============================================================
   16. ARCHIVE / CATEGORY PAGE
   ============================================================ */
.archive-hero{
  background:linear-gradient(135deg,var(--clr-primary-dark),var(--clr-primary));
  color:#fff;padding:var(--sp-16) 0;
  position:relative;overflow:hidden;
}
.archive-hero::after{
  content:'';position:absolute;right:-80px;top:-80px;
  width:400px;height:400px;border-radius:50%;
  background:rgba(255,255,255,0.04);
}
.archive-hero-title{font-family:var(--ff-serif);font-size:clamp(2rem,4vw,3.5rem);color:#fff;font-weight:var(--fw-black);margin-bottom:var(--sp-4)}
.archive-hero-desc{color:rgba(255,255,255,0.8);max-width:560px;line-height:var(--lh-loose);font-size:var(--fs-md)}

/* Filters */
.filters-bar{
  background:var(--clr-surface);border-bottom:1px solid var(--clr-border);
  padding:var(--sp-4) 0;position:sticky;top:var(--header-h);z-index:100;
}
.filters-inner{display:flex;align-items:center;gap:var(--sp-4);flex-wrap:wrap}
.filter-btn{
  padding:var(--sp-2) var(--sp-4);
  border-radius:var(--radius-full);border:2px solid var(--clr-border);
  font-size:var(--fs-sm);font-weight:var(--fw-medium);
  background:transparent;color:var(--clr-text-muted);cursor:pointer;
  transition:all var(--transition-fast);
}
.filter-btn:hover,.filter-btn.active{background:var(--clr-primary);border-color:var(--clr-primary);color:#fff}
.sort-select{
  padding:var(--sp-2) var(--sp-4);
  border:2px solid var(--clr-border);border-radius:var(--radius-full);
  font-size:var(--fs-sm);font-weight:var(--fw-medium);
  color:var(--clr-text);cursor:pointer;margin-left:auto;
  transition:border-color var(--transition-fast);
}
.sort-select:focus{border-color:var(--clr-primary)}

.archive-layout{display:grid;grid-template-columns:1fr 300px;gap:var(--sp-10);padding-block:var(--sp-10)}

/* Pagination */
.pagination{display:flex;align-items:center;justify-content:center;gap:var(--sp-2);margin-top:var(--sp-12)}
.page-link{
  width:44px;height:44px;border-radius:var(--radius-md);
  display:flex;align-items:center;justify-content:center;
  font-weight:var(--fw-semibold);font-size:var(--fs-sm);
  border:2px solid var(--clr-border);color:var(--clr-text-muted);
  transition:all var(--transition-fast);
}
.page-link:hover,.page-link.current{background:var(--clr-primary);border-color:var(--clr-primary);color:#fff}
.page-link--dots{border:none;cursor:default}
.page-link--prev,.page-link--next{font-size:1rem}

/* ============================================================
   17. SEARCH PAGE
   ============================================================ */
.search-results-header{padding:var(--sp-10) 0;border-bottom:1px solid var(--clr-border)}
.search-query{color:var(--clr-primary);font-family:var(--ff-serif)}
.search-count{color:var(--clr-text-muted);font-size:var(--fs-md);margin-top:var(--sp-2)}
.search-again-form{display:flex;gap:var(--sp-3);max-width:560px;margin-top:var(--sp-5)}

/* ============================================================
   18. 404 PAGE
   ============================================================ */
.page-404{
  min-height:80vh;
  display:flex;align-items:center;justify-content:center;
  text-align:center;padding:var(--sp-12) 0;
}
.page-404-number{
  font-family:var(--ff-serif);font-size:clamp(6rem,15vw,12rem);
  font-weight:var(--fw-black);
  color:var(--clr-soft-2);
  line-height:1;margin-bottom:var(--sp-6);
}
.page-404-icon{font-size:4rem;margin-bottom:var(--sp-4)}
.page-404-title{font-size:var(--fs-3xl);margin-bottom:var(--sp-4)}
.page-404-text{color:var(--clr-text-muted);max-width:480px;margin:0 auto var(--sp-8);line-height:var(--lh-loose)}
.page-404-actions{display:flex;gap:var(--sp-4);justify-content:center;flex-wrap:wrap}

/* ============================================================
   19. AUTHOR PAGE
   ============================================================ */
.author-hero{background:var(--clr-soft);padding:var(--sp-12) 0}
.author-hero-inner{display:flex;gap:var(--sp-8);align-items:center}
.author-avatar-lg{width:120px;height:120px;border-radius:50%;object-fit:cover;border:4px solid var(--clr-primary)}
.author-name{font-size:var(--fs-3xl);margin-bottom:var(--sp-3)}
.author-bio{color:var(--clr-text-muted);max-width:580px;line-height:var(--lh-loose);margin-bottom:var(--sp-5)}
.author-stats{display:flex;gap:var(--sp-8)}
.author-stat-num{font-family:var(--ff-serif);font-size:var(--fs-2xl);font-weight:var(--fw-bold);color:var(--clr-primary)}
.author-stat-label{font-size:var(--fs-sm);color:var(--clr-text-muted)}

/* ============================================================
   20. FAQ BLOCK
   ============================================================ */
.faq-block{margin-bottom:var(--sp-10)}
.faq-item{
  border:1px solid var(--clr-border);border-radius:var(--radius-lg);
  margin-bottom:var(--sp-3);overflow:hidden;
}
.faq-question{
  display:flex;align-items:center;justify-content:space-between;
  padding:var(--sp-5) var(--sp-6);
  cursor:pointer;font-weight:var(--fw-semibold);background:var(--clr-surface);
  transition:background var(--transition-fast);
}
.faq-question:hover{background:var(--clr-soft)}
.faq-icon{
  width:28px;height:28px;border-radius:50%;
  border:2px solid var(--clr-primary);
  display:flex;align-items:center;justify-content:center;
  color:var(--clr-primary);font-size:1rem;
  transition:all var(--transition-fast);flex-shrink:0;
}
.faq-item.open .faq-icon{background:var(--clr-primary);color:#fff;transform:rotate(45deg)}
.faq-answer{
  max-height:0;overflow:hidden;
  transition:max-height var(--transition-slow);
}
.faq-item.open .faq-answer{max-height:400px}
.faq-answer-inner{padding:var(--sp-5) var(--sp-6);border-top:1px solid var(--clr-border);color:var(--clr-text-muted);line-height:var(--lh-loose)}

/* ============================================================
   21. TIPS BOX
   ============================================================ */
.tips-box{
  background:linear-gradient(135deg,#FFF8F0,#FFF0DC);
  border:2px solid var(--clr-secondary);
  border-radius:var(--radius-xl);padding:var(--sp-6);
  margin-bottom:var(--sp-8);
}
.tips-title{display:flex;align-items:center;gap:var(--sp-3);font-family:var(--ff-serif);font-size:var(--fs-xl);font-weight:var(--fw-bold);margin-bottom:var(--sp-4);color:var(--clr-secondary-dark)}
.tips-list{display:grid;gap:var(--sp-3)}
.tip-item{display:flex;gap:var(--sp-3);align-items:flex-start}
.tip-icon{color:var(--clr-secondary);flex-shrink:0;margin-top:2px}

/* ============================================================
   22. STARS RATING
   ============================================================ */
.rating-input{display:flex;gap:4px;flex-direction:row-reverse;justify-content:flex-end}
.rating-input input{display:none}
.rating-input label{
  font-size:1.75rem;color:var(--clr-border);cursor:pointer;
  transition:color var(--transition-fast);
}
.rating-input label:hover,.rating-input label:hover~label,
.rating-input input:checked~label{color:#F59E0B}

/* ============================================================
   23. COMMENTS
   ============================================================ */
.comments-section {
  padding-top: var(--sp-8);
  border-top: 1px solid var(--clr-border);
  margin-top: var(--sp-8);
}

.comments-title {
  font-family: var(--ff-serif);
  font-size: var(--fs-2xl);
  font-weight: var(--fw-bold);
  margin-bottom: var(--sp-8);
  display: flex;
  align-items: center;
  gap: var(--sp-3);
}

.comment-list {
  display: grid;
  gap: var(--sp-6);
}

.comment {
  display: flex;
  gap: var(--sp-6);
  padding: var(--sp-6);
  background: var(--clr-surface);
  border: 1px solid var(--clr-border);
  border-radius: var(--radius-2xl);
  transition: transform 0.3s ease, box-shadow 0.3s ease;
  position: relative;
}

.comment:hover {
  transform: translateY(-2px);
  box-shadow: var(--shadow-md);
}

.comment-avatar {
  width: 48px;
  height: 48px;
  border-radius: 50%;
  border: 2px solid var(--clr-soft);
  flex-shrink: 0;
  object-fit: cover;
}

.comment-header {
  display: flex;
  align-items: baseline;
  gap: var(--sp-3);
  margin-bottom: var(--sp-2);
}

.comment-name {
  font-family: var(--ff-sans);
  font-size: var(--fs-base);
  font-weight: var(--fw-bold);
  color: var(--clr-text);
}

.comment-date {
  font-size: var(--fs-xs);
  color: var(--clr-text-muted);
  opacity: 0.8;
}

.comment-text {
  color: var(--clr-text-muted);
  line-height: 1.7;
  font-size: var(--fs-md);
}

.comment-reply {
  margin-top: var(--sp-4);
}

.comment-reply a {
  font-size: var(--fs-xs);
  font-weight: var(--fw-bold);
  color: var(--clr-primary);
  text-transform: uppercase;
  letter-spacing: 0.05em;
  text-decoration: none;
  display: inline-flex;
  align-items: center;
  gap: 4px;
}

.reply-comment {
  margin-left: var(--sp-12);
  background: var(--clr-soft);
}

/* Comment Form Design */
.comment-form {
  margin-top: var(--sp-12);
  padding: var(--sp-10);
  background: var(--clr-surface);
  border: 2px solid var(--clr-primary-light);
  border-radius: var(--radius-3xl);
  box-shadow: var(--shadow-lg);
  position: relative;
  overflow: hidden;
}

.comment-form::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 6px;
  background: linear-gradient(90deg, var(--clr-primary), var(--clr-secondary));
}

.comment-form-title {
  font-family: var(--ff-serif);
  font-size: var(--fs-2xl);
  font-weight: var(--fw-black);
  margin-bottom: var(--sp-8);
  color: var(--clr-text);
}

.form-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--sp-6);
  margin-bottom: var(--sp-6);
}

.form-field {
  display: flex;
  flex-direction: column;
  gap: var(--sp-2);
}

.form-field label {
  font-size: var(--fs-sm);
  font-weight: var(--fw-bold);
  color: var(--clr-text);
  margin-left: 2px;
}

.form-field input,
.form-field textarea {
  padding: var(--sp-4) var(--sp-5);
  background: var(--clr-soft);
  border: 1px solid var(--clr-border);
  border-radius: var(--radius-xl);
  font-family: var(--ff-sans);
  font-size: var(--fs-base);
  color: var(--clr-text);
  transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
}

.form-field input:focus,
.form-field textarea:focus {
  background: var(--clr-surface);
  border-color: var(--clr-primary);
  box-shadow: 0 0 0 4px rgba(45, 106, 79, 0.1);
  outline: none;
}

.form-field textarea {
  min-height: 180px;
  line-height: 1.6;
}

.form-field--full {
  grid-column: span 2;
}

.form-submit {
  margin-top: var(--sp-4);
  width: 100%;
}

.btn--comment-submit {
  width: 100%;
  border-radius: var(--radius-xl);
  box-shadow: var(--shadow-md);
  transition: all 0.3s ease;
}

.btn--comment-submit:hover {
  transform: translateY(-2px);
  box-shadow: var(--shadow-lg);
}

@media (max-width: 640px) {
  .comment { gap: var(--sp-4); padding: var(--sp-4); }
  .comment-avatar { width: 44px; height: 44px; }
  .reply-comment { margin-left: var(--sp-4); }
  .form-grid { grid-template-columns: 1fr; gap: var(--sp-4); }
  .comment-form { padding: var(--sp-6); }
}

/* ============================================================
   24. PAGE TEMPLATES (Impressum, Datenschutz, etc.)
   ============================================================ */
.legal-page{max-width:var(--container-text);margin:0 auto;padding:var(--sp-12) var(--sp-6)}
.legal-page h1{font-size:clamp(2rem,4vw,var(--fs-4xl));margin-bottom:var(--sp-8)}
.legal-page h2{font-size:var(--fs-2xl);margin:var(--sp-8) 0 var(--sp-4)}
.legal-page h3{font-size:var(--fs-xl);margin:var(--sp-6) 0 var(--sp-3)}
.legal-page p{color:var(--clr-text-muted);line-height:var(--lh-loose);margin-bottom:var(--sp-4)}
.legal-page ul{list-style:disc;padding-left:var(--sp-6);color:var(--clr-text-muted);margin-bottom:var(--sp-4)}
.legal-page ul li{margin-bottom:var(--sp-2)}
.legal-page a{color:var(--clr-primary);text-decoration:underline}
.legal-page .last-updated{font-size:var(--fs-sm);color:var(--clr-text-muted);margin-bottom:var(--sp-8);padding:var(--sp-3) var(--sp-4);background:var(--clr-soft);border-radius:var(--radius-md);display:inline-block}

/* Cookie Banner */
.cookie-banner{
  position:fixed;bottom:var(--sp-5);left:50%;transform:translateX(-50%);
  z-index:9999;width:min(640px,calc(100vw - 2rem));
  background:var(--clr-surface);
  border-radius:var(--radius-xl);
  padding:var(--sp-6);
  box-shadow:var(--shadow-xl);
  border:1px solid var(--clr-border);
  display:flex;gap:var(--sp-5);align-items:flex-start;
}
.cookie-banner.hidden{display:none}
.cookie-icon{font-size:2rem;flex-shrink:0}
.cookie-text{flex:1}
.cookie-text p{font-size:var(--fs-sm);color:var(--clr-text-muted);margin:var(--sp-2) 0 var(--sp-4)}
.cookie-actions{display:flex;gap:var(--sp-3);flex-wrap:wrap}

/* ============================================================
   25. SIDEBAR
   ============================================================ */
.sidebar{display:flex;flex-direction:column;gap:var(--sp-6)}
.widget{background:var(--clr-surface);border-radius:var(--radius-xl);padding:var(--sp-6);border:1px solid var(--clr-border)}
.widget-title{font-family:var(--ff-serif);font-size:var(--fs-lg);font-weight:var(--fw-bold);margin-bottom:var(--sp-4);padding-bottom:var(--sp-3);border-bottom:2px solid var(--clr-soft-2)}
.widget-recipe-list{display:grid;gap:var(--sp-4)}
.widget-recipe-item{display:flex;gap:var(--sp-3);align-items:center}
.widget-recipe-img{width:72px;height:72px;border-radius:var(--radius-md);object-fit:cover;flex-shrink:0}
.widget-recipe-title{font-weight:var(--fw-semibold);font-size:var(--fs-sm);line-height:var(--lh-snug);margin-bottom:4px}
.widget-recipe-meta{font-size:var(--fs-xs);color:var(--clr-text-muted)}
.tag-cloud{display:flex;flex-wrap:wrap;gap:var(--sp-2)}
.tag-pill{
  padding:var(--sp-1) var(--sp-3);border-radius:var(--radius-full);
  background:var(--clr-soft);border:1px solid var(--clr-border);
  font-size:var(--fs-xs);font-weight:var(--fw-medium);color:var(--clr-text-muted);
  transition:all var(--transition-fast);
}
.tag-pill:hover{background:var(--clr-primary);border-color:var(--clr-primary);color:#fff}

/* ============================================================
   26. BACK TO TOP & PREMIUM SCROLLBARS
   ============================================================ */
.back-to-top{
  position:fixed;bottom:var(--sp-8);right:var(--sp-6);z-index:400;
  width:50px;height:50px;border-radius:50%;
  background:linear-gradient(135deg, var(--clr-primary), var(--clr-primary-dark));
  color:#fff;
  display:flex;align-items:center;justify-content:center;
  box-shadow:0 8px 24px rgba(53, 94, 59, 0.25);
  opacity:0;pointer-events:none;
  transition:all 0.3s cubic-bezier(0.16, 1, 0.3, 1);
  border:1px solid rgba(255,255,255,0.05);cursor:pointer;
}
.back-to-top.visible{opacity:1;pointer-events:all}
.back-to-top:hover{
  background:linear-gradient(135deg, var(--clr-secondary), var(--clr-secondary-dark));
  transform:translateY(-4px) scale(1.05);
  box-shadow:0 10px 28px rgba(211, 97, 53, 0.35);
  color:#fff;
}

/* Custom Styled Premium Scrollbars */
::-webkit-scrollbar {
  width: 10px;
  height: 10px;
}
::-webkit-scrollbar-track {
  background: var(--clr-bg);
}
::-webkit-scrollbar-thumb {
  background: var(--clr-border);
  border: 2px solid var(--clr-bg);
  border-radius: var(--radius-full);
}
::-webkit-scrollbar-thumb:hover {
  background: var(--clr-primary-light);
}
html.dark-mode ::-webkit-scrollbar-thumb:hover {
  background: var(--clr-primary-light);
}

/* ============================================================
   27. UTILITY CLASSES
   ============================================================ */
.badge{display:inline-flex;align-items:center;gap:4px;padding:3px 10px;border-radius:var(--radius-full);font-size:var(--fs-xs);font-weight:var(--fw-semibold)}
.badge--primary{background:rgba(45,106,79,0.1);color:var(--clr-primary)}
.badge--secondary{background:rgba(244,162,97,0.15);color:var(--clr-secondary-dark)}
.badge--success{background:rgba(34,197,94,0.1);color:var(--clr-cta-dark)}
.badge--new{background:var(--clr-cta);color:#fff}
.divider{height:1px;background:var(--clr-border);margin:var(--sp-8) 0}
.reading-time{display:inline-flex;align-items:center;gap:4px;font-size:var(--fs-xs);color:var(--clr-text-muted)}
.skeleton{background:linear-gradient(90deg,var(--clr-soft) 25%,var(--clr-soft-2) 50%,var(--clr-soft) 75%);background-size:200%;animation:shimmer 1.5s infinite}
@keyframes shimmer{0%{background-position:200% 0}100%{background-position:-200% 0}}

/* SEO Text Block */
.seo-text-block {
  background: var(--clr-surface);
  border: 1px solid var(--clr-border);
  border-radius: 24px;
  padding: var(--sp-12);
  margin: var(--sp-16) 0;
  box-shadow: 0 10px 30px rgba(43,37,32,0.04);
  position: relative;
}

.seo-text-block::after {
  content: '';
  position: absolute;
  left: 0;
  top: 50%;
  transform: translateY(-50%);
  width: 5px;
  height: 35%;
  background: var(--clr-secondary);
  border-radius: 0 4px 4px 0;
}

.seo-text-block h2 {
  font-family: var(--ff-serif);
  font-size: var(--fs-3xl);
  font-weight: var(--fw-black);
  margin-bottom: var(--sp-8);
  color: var(--clr-text);
  line-height: 1.2;
}

.seo-content-grid {
  display: grid;
  grid-template-columns: 1.1fr 0.9fr;
  gap: var(--sp-12);
  align-items: start;
}

.seo-text-main p {
  line-height: 1.85;
  color: var(--clr-text-muted);
  font-size: var(--fs-lg);
  margin-bottom: var(--sp-6);
}

.seo-categories-title {
  font-family: var(--ff-sans);
  font-size: var(--fs-sm);
  font-weight: var(--fw-bold);
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: var(--clr-primary);
  margin-bottom: var(--sp-6);
  display: flex;
  align-items: center;
  gap: var(--sp-3);
}

.seo-categories-title::after {
  content: '';
  flex: 1;
  height: 1px;
  background: var(--clr-border);
}

.seo-categories-list {
  display: flex;
  flex-direction: column;
  gap: var(--sp-5);
}

.seo-cat-item {
  display: flex;
  gap: var(--sp-4);
  padding: var(--sp-5);
  background: var(--clr-soft);
  border-radius: 20px;
  border: 1px solid var(--clr-border);
  transition: all 0.35s cubic-bezier(0.165, 0.84, 0.44, 1);
}

.seo-cat-item:hover {
  background: var(--clr-surface);
  border-color: var(--clr-secondary);
  transform: translateX(8px) scale(1.01);
  box-shadow: 0 12px 25px rgba(43,37,32,0.06);
}

.seo-cat-icon {
  font-size: 1.75rem;
  width: 52px;
  height: 52px;
  background: #fff;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 50%;
  border: 2px solid var(--clr-border);
  box-shadow: 0 4px 10px rgba(0,0,0,0.04);
  flex-shrink: 0;
  transition: all 0.3s ease;
}

.seo-cat-item:hover .seo-cat-icon {
  transform: rotate(-10deg) scale(1.1);
  border-color: var(--clr-secondary);
}

.seo-cat-info {
  flex: 1;
}

.seo-cat-name {
  font-weight: var(--fw-bold);
  font-size: var(--fs-md);
  color: var(--clr-text);
  margin-bottom: 2px;
  display: block;
}

.seo-cat-desc {
  font-size: var(--fs-xs);
  color: var(--clr-text-muted);
  line-height: 1.5;
}

@media (max-width: 992px) {
  .seo-content-grid { grid-template-columns: 1fr; gap: var(--sp-8); }
  .seo-text-block { padding: var(--sp-8); }
}

/* Internal Links Block */
.internal-links{background:var(--clr-surface);border:1px solid var(--clr-border);border-radius:var(--radius-xl);padding:var(--sp-6);margin:var(--sp-8) 0}
.internal-links-title{font-weight:var(--fw-semibold);margin-bottom:var(--sp-4)}
.internal-links-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:var(--sp-3)}
.internal-link-item{padding:var(--sp-3) var(--sp-4);border-radius:var(--radius-md);background:var(--clr-soft);font-size:var(--fs-sm);font-weight:var(--fw-medium);color:var(--clr-primary);transition:all var(--transition-fast)}
.internal-link-item:hover{background:var(--clr-primary);color:#fff}

/* ============================================================
   28. ANIMATIONS
   ============================================================ */
@keyframes fadeInUp{from{opacity:0;transform:translateY(24px)}to{opacity:1;transform:translateY(0)}}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}
@keyframes scaleIn{from{opacity:0;transform:scale(0.95)}to{opacity:1;transform:scale(1)}}
.animate-fade-in-up{animation:fadeInUp 0.6s ease forwards}
.animate-fade-in{animation:fadeIn 0.4s ease forwards}
.delay-1{animation-delay:0.1s;opacity:0}
.delay-2{animation-delay:0.2s;opacity:0}
.delay-3{animation-delay:0.3s;opacity:0}
.delay-4{animation-delay:0.4s;opacity:0}

/* Intersection Observer animations */
[data-animate]{opacity:0;transform:translateY(20px);transition:opacity 0.6s ease,transform 0.6s ease}
[data-animate].is-visible{opacity:1;transform:translateY(0)}

/* ============================================================
   29. RESPONSIVE – TABLET
   ============================================================ */
@media(max-width:1024px){
  :root{--header-h:64px}
  .primary-nav,.header-cta{display:none}
  .nav-toggle{display:flex}
  .hero-inner{grid-template-columns:1fr;text-align:center;padding-block:var(--sp-16)}
  .hero-subtitle{margin-inline:auto}
  .hero-actions{justify-content:center}
  .hero-stats{justify-content:center}
  .hero-image{display:block; max-width:550px; margin:0 auto;}
  .category-grid{grid-template-columns:repeat(2,1fr)}
  .newsletter-inner{grid-template-columns:1fr}
  .footer-main{grid-template-columns:1fr 1fr;gap:var(--sp-8)}
  .single-recipe-layout{grid-template-columns:1fr}
  .quick-info-bar{grid-template-columns:repeat(3,1fr)}
  .archive-layout{grid-template-columns:1fr}
  .sidebar{display:none}
  .pinterest-cta{grid-template-columns:1fr}
  .pinterest-images{display:none}
  .grid-4{grid-template-columns:repeat(2,1fr)}
  .grid-3{grid-template-columns:repeat(2,1fr)}
}

/* ============================================================
   30. RESPONSIVE – MOBILE
   ============================================================ */
@media(max-width:640px){
  :root{--header-h:60px}
  .category-grid{grid-template-columns:repeat(2,1fr)}
  .grid-2,.grid-3,.grid-4{grid-template-columns:1fr}
  .quick-info-bar{grid-template-columns:repeat(2,1fr)}
  .form-grid{grid-template-columns:1fr}
  .form-field--full{grid-column:span 1}
  .footer-main{grid-template-columns:1fr}
  .recipe-actions{flex-direction:column}
  .hero-title{font-size:2.25rem}
  .hero-stats{flex-direction:column;gap:var(--sp-5)}
  .newsletter-form-wrapper{padding:var(--sp-5)}
  .section{padding-block:var(--sp-10)}
  .mobile-sticky-cta{display:flex}
  .back-to-top{bottom:calc(var(--sp-8) + 72px)}
  .recipe-card--featured{grid-column:span 1;aspect-ratio:1/1}
  .author-hero-inner{flex-direction:column;text-align:center}
  .author-stats{justify-content:center}
  .footer-bottom{flex-direction:column;text-align:center}
  .cookie-banner{flex-direction:column;bottom:0;border-radius:var(--radius-xl) var(--radius-xl) 0 0;width:100%;left:0;transform:none}
}

/* ============================================================
   31. PRINT STYLES
   ============================================================ */
@media print{
  .site-header,.site-footer,.mobile-sticky-cta,.back-to-top,
  .recipe-actions,.newsletter-section,.pinterest-cta,
  .comments-section,.sidebar,.adsense-slot{display:none!important}
  body{font-size:12pt;color:#000;background:#fff}
  .recipe-hero-img{max-height:300px;object-fit:cover}
  .quick-info-bar{grid-template-columns:repeat(3,1fr);border:1px solid #ccc}
  a{text-decoration:none;color:#000}
}

/* ============================================================
   32. READING PROGRESS BAR
   ============================================================ */
.reading-progress-bar{
  position:fixed;top:0;left:0;z-index:10000;
  height:3px;width:0%;
  background:linear-gradient(90deg,var(--clr-primary),var(--clr-secondary),var(--clr-cta));
  border-radius:0 2px 2px 0;
  transition:width 100ms linear;
  pointer-events:none;
}
@media(max-width:640px){.reading-progress-bar{height:2px}}

/* ============================================================
   33. DARK MODE TOGGLE SYSTEM
   ============================================================ */

/* Dark mode CSS variables — activated by .dark-mode on <html> */
html.dark-mode{
  --clr-bg:          #0D1117;
  --clr-surface:     #161B22;
  --clr-soft:        #1C2128;
  --clr-soft-2:      #21262D;
  --clr-text:        #E6EDF3;
  --clr-text-muted:  #8B949E;
  --clr-text-light:  #6E7681;
  --clr-border:      #30363D;
  --clr-overlay:     rgba(0,0,0,0.65);
  --shadow-sm:  0 2px 8px rgba(0,0,0,0.35);
  --shadow-md:  0 4px 16px rgba(0,0,0,0.4);
  --shadow-lg:  0 8px 32px rgba(0,0,0,0.5);
  --shadow-xl:  0 20px 60px rgba(0,0,0,0.6);
}
html.dark-mode body{color-scheme:dark}
html.dark-mode .site-header{
  background:rgba(13,17,23,0.85);
  backdrop-filter:blur(12px);
  -webkit-backdrop-filter:blur(12px);
  border-bottom-color:rgba(48,54,61,0.5);
}
html.dark-mode .site-header.scrolled{
  background:rgba(13,17,23,0.95);
  box-shadow:0 10px 30px rgba(0,0,0,0.4);
  border-bottom-color:rgba(48,54,61,0.8);
}
html.dark-mode .primary-nav a:hover{
  color:var(--clr-primary-light);
  background:rgba(96,134,102,0.1);
}
html.dark-mode .primary-nav .current-menu-item a{
  color:#fff;
  background:rgba(96,134,102,0.18);
}
html.dark-mode .search-toggle:hover,
html.dark-mode .nav-toggle:hover{
  background:var(--clr-primary-light);
  border-color:var(--clr-primary-light);
  box-shadow:0 4px 12px rgba(96,134,102,0.4);
}
html.dark-mode .site-footer{background:#010409}
html.dark-mode .recipe-card{background:var(--clr-surface);border-color:var(--clr-border)}
html.dark-mode .search-box{background:var(--clr-surface)}
html.dark-mode .search-input{background:var(--clr-soft);color:var(--clr-text);border-color:var(--clr-border)}
html.dark-mode .form-field input,
html.dark-mode .form-field textarea,
html.dark-mode .form-field select{background:var(--clr-soft);color:var(--clr-text);border-color:var(--clr-border)}
html.dark-mode .mobile-menu{background:var(--clr-surface)}
html.dark-mode .nav-overlay{background:rgba(0,0,0,0.75)}
html.dark-mode .cookie-banner{background:var(--clr-surface);border-color:var(--clr-border)}
html.dark-mode .widget{background:var(--clr-surface);border-color:var(--clr-border)}
html.dark-mode .sidebar-card{background:var(--clr-surface);border-color:var(--clr-border)}
html.dark-mode .ingredients-box{background:var(--clr-soft);border-color:var(--clr-border)}
html.dark-mode .step-item{background:var(--clr-soft);border-color:var(--clr-border)}
html.dark-mode .faq-item{border-color:var(--clr-border)}
html.dark-mode .faq-question{background:var(--clr-soft)}
html.dark-mode .faq-answer-inner{border-color:var(--clr-border)}
html.dark-mode .comment{background:var(--clr-soft);border-color:var(--clr-border)}
html.dark-mode .comment-form{background:var(--clr-soft);border-color:var(--clr-border)}
html.dark-mode .quick-info-bar{background:var(--clr-soft);border-color:var(--clr-border)}
html.dark-mode .legal-page .last-updated{background:var(--clr-soft)}
html.dark-mode .seo-text-block{background:var(--clr-soft)}
html.dark-mode .adsense-slot{background:var(--clr-soft);border-color:var(--clr-border)}
html.dark-mode .recipe-card--featured .recipe-card-body{background:linear-gradient(to top,rgba(0,0,0,.95),transparent)}
html.dark-mode .tag-pill{background:var(--clr-soft);border-color:var(--clr-border);color:var(--clr-text-muted)}
html.dark-mode .filter-btn{border-color:var(--clr-border);color:var(--clr-text-muted)}
html.dark-mode .sort-select{border-color:var(--clr-border);color:var(--clr-text);background:var(--clr-soft)}
html.dark-mode .nutrition-box{border-color:var(--clr-primary-light)}
html.dark-mode .tips-box{background:#1A1000;border-color:var(--clr-secondary)}
html.dark-mode .skeleton{background:linear-gradient(90deg,var(--clr-soft) 25%,var(--clr-soft-2) 50%,var(--clr-soft) 75%);background-size:200%}
html.dark-mode .page-404-number{color:var(--clr-soft-2)}
html.dark-mode .breadcrumbs span{color:var(--clr-border)}
html.dark-mode .mobile-sticky-cta{background:var(--clr-surface);border-color:var(--clr-border)}

/* Dark Mode Toggle Button */
.dark-mode-toggle{
  width:42px;height:42px;border-radius:var(--radius-full);
  background:var(--clr-soft);color:var(--clr-text);
  border:1px solid var(--clr-border);cursor:pointer;font-size:1.1rem;
  display:flex;align-items:center;justify-content:center;
  transition:all 0.3s cubic-bezier(0.25, 1, 0.5, 1);
  position:relative;overflow:hidden;
}
.dark-mode-toggle:hover{
  background:var(--clr-primary);color:#fff;
  border-color:var(--clr-primary);
  transform:translateY(-2px);
  box-shadow:0 4px 12px rgba(53, 94, 59, 0.25);
}
html.dark-mode .dark-mode-toggle:hover{
  background:var(--clr-primary-light);
  border-color:var(--clr-primary-light);
  box-shadow:0 4px 12px rgba(96, 134, 102, 0.4);
}
.dark-mode-toggle .dmt-sun{ transition:transform var(--transition-base),opacity var(--transition-base) }
.dark-mode-toggle .dmt-moon{ position:absolute;opacity:0;transform:translateY(100%);transition:transform var(--transition-base),opacity var(--transition-base) }
html.dark-mode .dark-mode-toggle .dmt-sun{opacity:0;transform:translateY(-100%)}
html.dark-mode .dark-mode-toggle .dmt-moon{opacity:1;transform:translateY(0)}

/* ============================================================
   34. MICRO-ANIMATIONS – Enhanced States
   ============================================================ */

/* Floating Label for Form Fields */
.form-field--float{position:relative}
.form-field--float label{
  position:absolute;top:var(--sp-4);left:var(--sp-4);
  font-size:var(--fs-base);color:var(--clr-text-muted);
  pointer-events:none;
  transition:all var(--transition-fast);
  background:transparent;padding:0 var(--sp-1);
}
.form-field--float input:focus ~ label,
.form-field--float input:not(:placeholder-shown) ~ label{
  top:-10px;left:var(--sp-3);
  font-size:var(--fs-xs);color:var(--clr-primary);
  background:var(--clr-surface);
  font-weight:var(--fw-semibold);
}

/* Improved Skeleton – more realistic shimmer */
.skeleton{
  background:linear-gradient(90deg,var(--clr-soft) 25%, var(--clr-soft-2) 37%,var(--clr-soft) 63%);
  background-size:400px 100%;
  animation:skeleton-shimmer 1.4s ease infinite;
  border-radius:var(--radius-md);
}
@keyframes skeleton-shimmer{
  0%{background-position:100% 50%}
  100%{background-position:0% 50%}
}
.skeleton-card{border-radius:var(--radius-xl);overflow:hidden;border:1px solid var(--clr-border)}
.skeleton-img{height:240px;background:var(--clr-soft-2)}
.skeleton-body{padding:var(--sp-5)}
.skeleton-line{height:14px;border-radius:4px;margin-bottom:var(--sp-3)}
.skeleton-line--sm{height:10px;width:60%}
.skeleton-line--title{height:18px;margin-bottom:var(--sp-2)}

/* Tooltip */
[data-tooltip]{position:relative}
[data-tooltip]::after{
  content:attr(data-tooltip);
  position:absolute;bottom:calc(100% + 8px);left:50%;
  transform:translateX(-50%);
  background:#111;color:#fff;
  font-size:var(--fs-xs);font-weight:var(--fw-medium);
  padding:var(--sp-2) var(--sp-3);
  border-radius:var(--radius-md);
  white-space:nowrap;pointer-events:none;
  opacity:0;transition:opacity var(--transition-fast);
  z-index:100;
}
[data-tooltip]::before{
  content:'';position:absolute;
  bottom:calc(100% + 2px);left:50%;transform:translateX(-50%);
  border:5px solid transparent;border-top-color:#111;
  pointer-events:none;opacity:0;transition:opacity var(--transition-fast);
}
[data-tooltip]:hover::after,[data-tooltip]:hover::before{opacity:1}

/* FAQ smooth height (replaces fixed max-height:400px) */
.faq-answer{
  display:grid;
  grid-template-rows:0fr;
  transition:grid-template-rows var(--transition-slow);
}
.faq-item.open .faq-answer{grid-template-rows:1fr}
.faq-answer-inner{overflow:hidden;min-height:0}

/* Quick Info Bar hover effect */
.quick-info-item{
  transition:background var(--transition-fast),transform var(--transition-fast);
  cursor:default;
}
.quick-info-item:hover{
  background:rgba(45,106,79,.06);
  transform:translateY(-2px);
  border-radius:var(--radius-lg);
}

/* Step item hover */
.step-item{transition:box-shadow var(--transition-fast),transform var(--transition-fast)}
.step-item:hover{box-shadow:var(--shadow-md);transform:translateX(4px)}

/* Ingredient item micro-feedback on check */
.ingredient-item{transition:background var(--transition-fast),opacity var(--transition-base)}

/* Better focus rings */
:focus-visible{
  outline:3px solid var(--clr-primary);
  outline-offset:3px;
  border-radius:var(--radius-sm);
}
button:focus-visible,a:focus-visible{border-radius:var(--radius-md)}

/* Pulse on new/trending badges */
.tag-badge--cta{animation:badge-pulse 3s ease-in-out infinite}
@keyframes badge-pulse{
  0%,100%{box-shadow:0 0 0 0 rgba(34,197,94,0.4)}
  70%{box-shadow:0 0 0 8px rgba(34,197,94,0)}
}

/* Stagger grid children animations */
.grid > [data-animate]:nth-child(1){animation-delay:.05s}
.grid > [data-animate]:nth-child(2){animation-delay:.1s}
.grid > [data-animate]:nth-child(3){animation-delay:.15s}
.grid > [data-animate]:nth-child(4){animation-delay:.2s}
.grid > [data-animate]:nth-child(5){animation-delay:.25s}
.grid > [data-animate]:nth-child(6){animation-delay:.3s}

/* Scroll-linked scale on hero */
@supports(animation-timeline:scroll()){
  .hero-image-frame{
    animation:hero-parallax linear both;
    animation-timeline:scroll(root);
    animation-range:0 300px;
  }
  @keyframes hero-parallax{
    from{transform:scale(1)}
    to{transform:scale(1.05) translateY(-10px)}
  }
}

/* Card image zoom on parent hover (smoother) */
.recipe-card .recipe-card-image img{will-change:transform}

/* Newsletter form shake on invalid email */
@keyframes shake{
  0%,100%{transform:translateX(0)}
  25%{transform:translateX(-6px)}
  75%{transform:translateX(6px)}
}
.newsletter-form input.invalid,.form-field input.invalid{
  border-color:#EF4444;
  animation:shake .3s ease;
}

/* ============================================================
   35. DARK MODE SYSTEM PREFERENCE (fallback when JS disabled)
   ============================================================ */
@media(prefers-color-scheme:dark){
  html:not(.light-mode){
    --clr-bg:         #0D1117;
    --clr-surface:    #161B22;
    --clr-soft:       #1C2128;
    --clr-soft-2:     #21262D;
    --clr-text:       #E6EDF3;
    --clr-text-muted: #8B949E;
    --clr-border:     #30363D;
  }
}

/* Step Images */
.step-content img { display: block; max-width: 100%; height: auto; border-radius: var(--radius-lg); margin: var(--sp-4) 0; box-shadow: 0 4px 6px rgba(0,0,0,0.05); }

/* ============================================================
   36. AUTHOR BOX PREMIUM
   ============================================================ */
.author-box-premium {
  position: relative;
  background: var(--clr-surface);
  border: 1px solid var(--clr-border);
  border-radius: var(--radius-2xl);
  overflow: hidden;
  margin-bottom: var(--sp-10);
  box-shadow: var(--shadow-md);
}

/* Gradient accent strip at the top */
.author-box-accent {
  height: 5px;
  background: linear-gradient(90deg, var(--clr-primary), var(--clr-secondary), var(--clr-cta));
}

.author-box-inner {
  display: flex;
  gap: var(--sp-6);
  padding: var(--sp-6);
  align-items: flex-start;
}

/* Avatar */
.author-box-avatar-wrap {
  flex-shrink: 0;
  position: relative;
  width: 120px;
}

.author-box-avatar {
  width: 120px !important;
  height: 120px !important;
  border-radius: 50% !important;
  object-fit: cover !important;
  border: 4px solid var(--clr-primary) !important;
  box-shadow: 0 0 0 4px rgba(45,106,79,0.12) !important;
  display: block;
}

.author-box-verified {
  position: absolute;
  bottom: 4px;
  right: 4px;
  width: 26px;
  height: 26px;
  border-radius: 50%;
  background: var(--clr-primary);
  color: #fff;
  display: flex;
  align-items: center;
  justify-content: center;
  border: 2px solid var(--clr-surface);
  box-shadow: 0 2px 6px rgba(0,0,0,0.15);
}

/* Info section */
.author-box-info {
  flex: 1;
  min-width: 0;
}

.author-box-label {
  font-size: var(--fs-xs);
  font-weight: var(--fw-bold);
  text-transform: uppercase;
  letter-spacing: 0.12em;
  color: var(--clr-primary);
  margin-bottom: var(--sp-2);
}

.author-box-name {
  font-family: var(--ff-serif);
  font-size: var(--fs-2xl);
  font-weight: var(--fw-bold);
  margin: 0 0 var(--sp-4) 0;
  line-height: 1.2;
}

.author-box-name a {
  color: var(--clr-text);
  text-decoration: none;
  transition: color var(--transition-fast);
}

.author-box-name a:hover { color: var(--clr-primary); }

/* Stats row */
.author-box-stats {
  display: flex;
  align-items: center;
  gap: var(--sp-4);
  margin-bottom: var(--sp-4);
  padding: var(--sp-3) var(--sp-4);
  background: var(--clr-soft);
  border-radius: var(--radius-lg);
  border: 1px solid var(--clr-border);
  flex-wrap: wrap;
}

.author-box-stat {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 2px;
}

.author-box-stat-num {
  font-weight: var(--fw-bold);
  font-size: var(--fs-md);
  color: var(--clr-text);
  white-space: nowrap;
}

.author-box-stat-lbl {
  font-size: var(--fs-xs);
  color: var(--clr-text-muted);
  text-transform: uppercase;
  letter-spacing: 0.05em;
  white-space: nowrap;
}

.author-box-stat-divider {
  width: 1px;
  height: 32px;
  background: var(--clr-border);
  flex-shrink: 0;
}

/* Description */
.author-box-desc {
  color: var(--clr-text-muted);
  font-size: var(--fs-md);
  line-height: var(--lh-loose);
  margin: 0 0 var(--sp-5) 0;
}

/* Action buttons */
.author-box-actions {
  display: flex;
  gap: var(--sp-3);
  flex-wrap: wrap;
}

.author-box-btn {
  display: inline-flex;
  align-items: center;
  gap: var(--sp-2);
  padding: var(--sp-3) var(--sp-5);
  border-radius: var(--radius-full);
  font-size: var(--fs-sm);
  font-weight: var(--fw-semibold);
  text-decoration: none;
  transition: all var(--transition-fast);
  border: 2px solid transparent;
  cursor: pointer;
}

.author-box-btn--primary {
  background: var(--clr-primary);
  color: #fff;
  border-color: var(--clr-primary);
}

.author-box-btn--primary:hover {
  background: var(--clr-primary-dark);
  border-color: var(--clr-primary-dark);
  transform: translateY(-1px);
  box-shadow: 0 4px 12px rgba(45,106,79,0.3);
  color: #fff;
}

.author-box-btn--ghost {
  background: transparent;
  color: var(--clr-text-muted);
  border-color: var(--clr-border);
}

.author-box-btn--ghost:hover {
  border-color: var(--clr-primary);
  color: var(--clr-primary);
  background: rgba(45,106,79,0.06);
}

/* Responsive */
@media(max-width:640px) {
  .author-box-inner {
    flex-direction: column;
    align-items: center;
    text-align: center;
    padding: var(--sp-6);
    gap: var(--sp-5);
  }
  .author-box-stats { flex-wrap: wrap; justify-content: center; }
  .author-box-actions { justify-content: center; }
}

/* Dark mode */
html.dark-mode .author-box-premium {
  background: var(--clr-surface);
  border-color: var(--clr-border);
}
html.dark-mode .author-box-stats {
  background: var(--clr-soft);
  border-color: var(--clr-border);
}
html.dark-mode .author-box-verified {
  border-color: var(--clr-surface);
}

/* AdSense Slots */
.adsense-container {
  margin: var(--sp-10) auto;
  text-align: center;
  position: relative;
  min-height: 100px;
}

.adsense-label {
  display: block;
  font-size: 10px;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: var(--clr-text-light);
  margin-bottom: var(--sp-2);
  text-align: center;
}

.adsense-middle {
  border-top: 1px solid var(--clr-border);
  border-bottom: 1px solid var(--clr-border);
  padding: var(--sp-8) 0;
}

.adsense-sidebar {
  background: var(--clr-soft);
  border-radius: var(--radius-xl);
  padding: var(--sp-6);
  border: 1px solid var(--clr-border);
}

html.dark-mode .adsense-container {
  opacity: 0.9;
}

/* ============================================================
   37. PERSONA CARDS (Sofia & Mia)
   ============================================================ */
.persona-card {
  background: var(--clr-surface);
  border: 1px solid var(--clr-border);
  border-radius: var(--radius-2xl);
  padding: var(--sp-8);
  display: flex;
  flex-direction: column;
  gap: var(--sp-6);
  transition: all var(--transition-base);
  box-shadow: var(--shadow-sm);
  text-align: left;
}

.persona-card:hover {
  transform: translateY(-5px);
  box-shadow: var(--shadow-lg);
  border-color: var(--clr-primary);
}

.persona-header {
  display: flex;
  align-items: center;
  gap: var(--sp-4);
}

.persona-avatar-wrap {
  position: relative;
  flex-shrink: 0;
}

.persona-avatar {
  width: 80px;
  height: 80px;
  border-radius: 50%;
  object-fit: cover;
  border: 3px solid var(--clr-primary);
  background: var(--clr-soft);
}

.persona-badge {
  position: absolute;
  bottom: -5px;
  left: 50%;
  transform: translateX(-50%);
  background: var(--clr-primary);
  color: #fff;
  font-size: 10px;
  font-weight: var(--fw-bold);
  text-transform: uppercase;
  padding: 2px 8px;
  border-radius: var(--radius-full);
  white-space: nowrap;
}

.persona-badge--alt { background: var(--clr-secondary); }

.persona-info { flex: 1; }

.persona-name {
  font-family: var(--ff-serif);
  font-size: var(--fs-xl);
  margin: 0;
  color: var(--clr-text);
}

.persona-role {
  font-size: var(--fs-xs);
  color: var(--clr-text-muted);
  text-transform: uppercase;
  letter-spacing: 0.05em;
  margin: 0;
}

.persona-body {
  display: flex;
  flex-direction: column;
  gap: var(--sp-4);
}

.persona-article-title {
  font-family: var(--ff-serif);
  font-size: var(--fs-lg);
  margin: 0;
  color: var(--clr-primary);
  line-height: 1.3;
}

.persona-text {
  font-size: var(--fs-sm);
  color: var(--clr-text-muted);
  line-height: var(--lh-loose);
  margin: 0;
}

@media (max-width: 768px) {
  .persona-header { flex-direction: column; text-align: center; }
  .grid-2 { grid-template-columns: 1fr; }
}

/* ============================================================
   38. UTILITIES
   ============================================================ */
.hidden {
  display: none !important;
}

/* Enhanced Persona Styles */
.persona-card {
  background: #ffffff;
  border: 1px solid rgba(0,0,0,0.05);
  border-radius: 24px;
  padding: 40px;
  display: flex;
  flex-direction: column;
  gap: 24px;
  transition: all 0.4s cubic-bezier(0.165, 0.84, 0.44, 1);
  box-shadow: 0 4px 20px rgba(0,0,0,0.03);
  position: relative;
  overflow: hidden;
  text-align: left;
}

.persona-card::after {
  content: '';
  position: absolute;
  top: 0; left: 0; width: 100%; height: 4px;
  background: var(--clr-primary);
  transform: scaleX(0);
  transition: transform 0.4s ease;
  transform-origin: left;
}

.persona-card:hover::after {
  transform: scaleX(1);
}

.persona-card:hover {
  transform: translateY(-10px);
  box-shadow: 0 20px 40px rgba(0,0,0,0.08);
  border-color: var(--clr-primary-light);
}

.persona-avatar {
  width: 90px;
  height: 90px;
  border-radius: 50%;
  object-fit: cover;
  border: 4px solid #fff;
  box-shadow: 0 8px 16px rgba(0,0,0,0.1);
  background: var(--clr-soft);
  transition: transform 0.4s ease;
}

.persona-card:hover .persona-avatar {
  transform: scale(1.1) rotate(5deg);
}

/* ============================================================
   BACK TO TOP
   ============================================================ */
.back-to-top {
  position: fixed;
  bottom: var(--sp-10);
  right: var(--sp-8);
  width: 48px;
  height: 48px;
  border-radius: 50%;
  background: var(--clr-primary);
  color: #fff;
  display: flex;
  align-items: center;
  justify-content: center;
  box-shadow: var(--shadow-lg);
  border: none;
  cursor: pointer;
  z-index: 500;
  opacity: 0;
  visibility: hidden;
  transform: translateY(20px);
  transition: all var(--transition-base);
}

.back-to-top.visible {
  opacity: 1;
  visibility: visible;
  transform: translateY(0);
}

.back-to-top:hover {
  background: var(--clr-primary-dark);
  transform: translateY(-5px);
  box-shadow: var(--shadow-xl);
}

/* ============================================================
   COMMENT STAR RATING INPUT
   ============================================================ */
.star-rating-input label {
  transition: transform 0.15s ease, color 0.15s ease;
}

.star-rating-input label:hover {
  transform: scale(1.2);
}

.star-rating-input input:checked ~ label {
  color: #F59E0B !important;
}

/* ============================================================
   40. FAQ ACCORDION
   ============================================================ */
.faq-block {
  margin-top: var(--sp-12);
  margin-bottom: var(--sp-12);
}

.faq-item {
  border: 1px solid var(--clr-border);
  border-radius: var(--radius-lg);
  margin-bottom: var(--sp-4);
  background: var(--clr-surface);
  overflow: hidden;
  transition: all var(--transition-base);
}

.faq-item:hover {
  border-color: var(--clr-primary-light);
  box-shadow: var(--shadow-sm);
}

.faq-question {
  width: 100%;
  padding: var(--sp-5) var(--sp-6);
  text-align: left;
  background: none;
  border: none;
  font-family: var(--ff-serif);
  font-size: var(--fs-lg);
  font-weight: var(--fw-bold);
  color: var(--clr-text);
  display: flex;
  justify-content: space-between;
  align-items: center;
  cursor: pointer;
  transition: background var(--transition-fast);
}

.faq-question:hover {
  background: var(--clr-soft);
}

.faq-icon {
  font-size: 1.5rem;
  color: var(--clr-primary);
  transition: transform 0.3s ease;
}

.faq-item.active .faq-icon {
  transform: rotate(45deg);
}

.faq-answer {
  max-height: 0;
  overflow: hidden;
  transition: max-height 0.3s ease-out;
  background: var(--clr-bg);
}

.faq-item.active .faq-answer {
  max-height: 500px; /* Adjust as needed */
  border-top: 1px solid var(--clr-border);
}

.faq-answer-inner {
  padding: var(--sp-6);
  line-height: var(--lh-loose);
  color: var(--clr-text);
}

html.dark-mode .faq-item {
  background: #1e293b;
  border-color: #334155;
}

html.dark-mode .faq-answer {
  background: #111827;
}

/* ============================================================
   41. AUTHOR STYLES
   ============================================================ */
.author-card {
  display: flex;
  gap: 1.5rem;
  align-items: flex-start;
  background: var(--clr-surface);
  border: 1px solid var(--clr-border);
  border-radius: var(--radius-lg);
  padding: 1.5rem;
  margin: 2rem 0;
  box-shadow: var(--shadow-sm);
}

.author-avatar {
  width: 80px;
  height: 80px;
  border-radius: 50%;
  overflow: hidden;
  flex-shrink: 0;
  border: 3px solid white;
  box-shadow: var(--shadow-sm);
}

.author-avatar img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.author-style-badge {
  display: inline-block;
  font-family: var(--font-ui);
  font-size: 0.72rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  padding: 0.2rem 0.6rem;
  border-radius: 50px;
  color: white;
}

.author-specialties {
  display: flex;
  gap: 0.4rem;
  flex-wrap: wrap;
  margin: 0.5rem 0;
}

.author-specialty-tag {
  font-family: var(--font-ui);
  font-size: 0.75rem;
  padding: 0.2rem 0.6rem;
  background: var(--clr-soft);
  border: 1px solid var(--clr-border);
  border-radius: 50px;
  color: var(--clr-text-muted);
}

.author-bio {
  font-size: 0.9rem;
  line-height: 1.7;
  color: var(--clr-text);
  margin: 0.5rem 0 0.75rem;
}

.author-social {
  display: flex;
  gap: 0.6rem;
  margin-bottom: 0.75rem;
}

.author-social a {
  font-family: var(--font-ui);
  font-size: 0.8rem;
  color: var(--clr-text-muted);
  text-decoration: none;
}

.author-social a:hover {
  color: var(--clr-primary);
}

.author-recipes-link {
  font-family: var(--font-ui);
  font-size: 0.85rem;
  font-weight: 600;
  color: var(--clr-primary);
  text-decoration: none;
}

.author-recipes-link:hover {
  text-decoration: underline;
}

/* Mini badge */
.author-mini {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  margin-bottom: 1.5rem;
  font-family: var(--font-ui);
  font-size: 0.82rem;
  color: var(--clr-text-muted);
}

.author-mini-avatar {
  width: 32px;
  height: 32px;
  border-radius: 50%;
  overflow: hidden;
  flex-shrink: 0;
  border: 1px solid var(--clr-border);
}

.author-mini-avatar img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.author-mini-name {
  font-weight: 600;
  color: var(--clr-text);
}

/* Author archive page */
.author-archive-header {
  background: var(--clr-soft);
  padding: 3rem 1.5rem;
  border-bottom: 1px solid var(--clr-border);
}

/* Responsive */
@media (max-width: 600px) {
  .author-card {
    flex-direction: column;
    align-items: center;
    text-align: center;
  }
  .author-specialties {
    justify-content: center;
  }
}

/* ============================================================
   42. PINTEREST CTA SECTION REDESIGN
   ============================================================ */
.pinterest-cta {
  background: linear-gradient(135deg, rgba(230, 0, 35, 0.08) 0%, rgba(250, 246, 240, 0.95) 100%);
  border: 1px solid rgba(230, 0, 35, 0.15);
  border-radius: var(--radius-2xl, 24px);
  padding: var(--sp-12);
  display: grid;
  grid-template-columns: 1.15fr 0.85fr;
  gap: var(--sp-8);
  align-items: center;
  overflow: hidden;
  box-shadow: 0 15px 40px rgba(230, 0, 35, 0.05);
  position: relative;
}

html.dark-mode .pinterest-cta {
  background: linear-gradient(135deg, rgba(230, 0, 35, 0.15) 0%, rgba(22, 27, 34, 0.95) 100%);
  border-color: rgba(230, 0, 35, 0.3);
  box-shadow: 0 15px 40px rgba(0, 0, 0, 0.4);
}

@media(max-width: 1024px) {
  .pinterest-cta {
    grid-template-columns: 1fr;
    padding: var(--sp-6);
  }
  .pinterest-images {
    display: none !important;
  }
}

.pinterest-cta-content {
  text-align: left;
}

.pinterest-cta-title {
  font-family: var(--ff-serif);
  font-size: var(--fs-3xl);
  color: #E60023;
  font-weight: var(--fw-black);
  margin-bottom: var(--sp-4);
}

html.dark-mode .pinterest-cta-title {
  color: #ff4d6d;
}

.pinterest-cta-text {
  color: var(--clr-text-muted);
  line-height: var(--lh-normal);
  margin-bottom: var(--sp-6);
  font-size: var(--fs-base);
}

.pinterest-btn {
  display: inline-flex;
  align-items: center;
  background: linear-gradient(135deg, #E60023, #BD081C);
  color: #fff;
  padding: 0.85rem 2.25rem;
  border-radius: var(--radius-full);
  font-weight: var(--fw-bold);
  box-shadow: 0 6px 20px rgba(230, 0, 35, 0.35);
  transition: all 0.4s cubic-bezier(0.165, 0.84, 0.44, 1);
  border: 1px solid rgba(255,255,255,0.1);
}

.pinterest-btn:hover {
  background: linear-gradient(135deg, #BD081C, #ad001a);
  transform: translateY(-3px) scale(1.02);
  box-shadow: 0 10px 28px rgba(230, 0, 35, 0.5);
  color: #fff;
}

/* Floating Polaroids Column */
.pinterest-images {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: var(--sp-4);
  position: relative;
  height: 240px;
}

.pinterest-thumb-wrapper {
  position: relative;
  transition: transform var(--transition-base), z-index var(--transition-base);
  cursor: pointer;
}

.pinterest-thumb-wrapper:nth-child(1) { transform: rotate(-5deg) translateY(-10px); }
.pinterest-thumb-wrapper:nth-child(2) { transform: rotate(3deg) translateY(15px); }
.pinterest-thumb-wrapper:nth-child(3) { transform: rotate(-3deg) translateY(-20px); }
.pinterest-thumb-wrapper:nth-child(4) { transform: rotate(5deg) translateY(10px); }

.pinterest-thumb-wrapper:hover {
  transform: scale(1.15) rotate(0deg) translateY(0);
  z-index: 10;
}

.pinterest-thumb {
  background: #fff;
  padding: 10px 10px 32px 10px;
  border-radius: var(--radius-sm, 4px);
  box-shadow: 0 10px 30px rgba(0, 0, 0, 0.08);
  border: 1px solid rgba(0,0,0,0.03);
  transition: all 0.4s cubic-bezier(0.165, 0.84, 0.44, 1);
}

html.dark-mode .pinterest-thumb {
  background: #1C2128;
  border-color: rgba(255,255,255,0.05);
  box-shadow: 0 10px 30px rgba(0, 0, 0, 0.5);
}

.pinterest-thumb img {
  width: 110px;
  height: 150px;
  object-fit: cover;
  border-radius: 2px;
}

/* 3D Pin Badge */
.pin-badge {
  position: absolute;
  top: -15px;
  left: 50%;
  transform: translateX(-50%);
  font-size: 1.5rem;
  z-index: 5;
  filter: drop-shadow(0 4px 8px rgba(0,0,0,0.15));
  animation: pin-float 3s ease-in-out infinite alternate;
}

@keyframes pin-float {
  0% { transform: translateX(-50%) translateY(0); }
  100% { transform: translateX(-50%) translateY(-5px); }
}

/* ============================================================
   43. SITE FOOTER REDESIGN
   ============================================================ */
.site-footer {
  background: radial-gradient(circle at 50% 0%, var(--clr-primary-dark) 0%, #172c1c 100%) !important;
  color: var(--clr-bg) !important;
  padding-block: var(--sp-20) var(--sp-10) !important;
  border-top: 2px solid rgba(229, 169, 60, 0.15) !important;
}

.footer-main {
  display: grid !important;
  grid-template-columns: 1.3fr 0.85fr 0.85fr !important;
  gap: var(--sp-12) !important;
  margin-bottom: var(--sp-16) !important;
}

@media (max-width: 992px) {
  .footer-main {
    grid-template-columns: 1fr 1fr !important;
    gap: var(--sp-10) !important;
  }
}

@media (max-width: 600px) {
  .footer-main {
    grid-template-columns: 1fr !important;
    gap: var(--sp-8) !important;
  }
}

.footer-brand .site-logo {
  display: inline-block !important;
  margin-bottom: var(--sp-6) !important;
  text-decoration: none;
}

.footer-brand .logo-text {
  font-family: var(--ff-serif) !important;
  font-size: 1.85rem !important;
  font-weight: var(--fw-bold) !important;
  color: var(--clr-bg) !important;
  letter-spacing: -0.02em;
}

.footer-brand .logo-text span {
  color: var(--clr-secondary) !important;
}

.footer-desc {
  color: rgba(250, 246, 240, 0.75) !important;
  font-size: var(--fs-sm) !important;
  line-height: var(--lh-normal) !important;
  margin-bottom: var(--sp-8) !important;
  max-width: 380px;
}

.footer-socials {
  display: flex !important;
  gap: var(--sp-3) !important;
}

.footer-socials .social-link {
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  width: 40px !important;
  height: 40px !important;
  border-radius: 50% !important;
  background: rgba(250, 246, 240, 0.08) !important;
  color: var(--clr-bg) !important;
  border: 1px solid rgba(250, 246, 240, 0.1) !important;
  transition: all 0.3s cubic-bezier(0.16, 1, 0.3, 1) !important;
}

.footer-socials .social-link svg {
  transition: transform 0.3s;
}

.footer-socials .social-link:hover {
  background: var(--clr-secondary) !important;
  border-color: var(--clr-secondary) !important;
  color: #fff !important;
  transform: translateY(-3px) !important;
  box-shadow: 0 6px 20px rgba(211, 97, 53, 0.3) !important;
}
.footer-socials .social-link:hover svg {
  transform: scale(1.1);
}

.footer-heading {
  font-family: var(--ff-serif) !important;
  font-size: var(--fs-md) !important;
  font-weight: var(--fw-bold) !important;
  color: var(--clr-bg) !important;
  margin-bottom: var(--sp-6) !important;
  position: relative !important;
  padding-bottom: var(--sp-3) !important;
}

.footer-heading::after {
  content: '' !important;
  position: absolute !important;
  bottom: 0 !important;
  left: 0 !important;
  width: 32px !important;
  height: 2px !important;
  background: var(--clr-secondary) !important;
  border-radius: 2px;
}

.footer-links {
  display: flex !important;
  flex-direction: column !important;
  gap: var(--sp-4) !important;
}

.footer-links a {
  color: rgba(250, 246, 240, 0.8) !important;
  font-size: var(--fs-sm) !important;
  text-decoration: none;
  transition: color 0.25s, padding-left 0.25s !important;
  display: inline-flex;
  align-items: center;
}

.footer-links a:hover {
  color: var(--clr-cta) !important;
  padding-left: 6px !important;
}

.footer-bottom {
  border-top: 1px solid rgba(250, 246, 240, 0.12) !important;
  padding-top: var(--sp-8) !important;
  display: flex !important;
  justify-content: space-between !important;
  align-items: center !important;
  flex-wrap: wrap !important;
  gap: var(--sp-6) !important;
  font-size: var(--fs-xs) !important;
  color: rgba(250, 246, 240, 0.55) !important;
  background: transparent !important;
}

.footer-bottom a {
  color: inherit !important;
  text-decoration: none;
  transition: color var(--transition-fast) !important;
}

.footer-bottom a:hover {
  color: var(--clr-cta) !important;
}

.footer-legal {
  display: flex !important;
  gap: var(--sp-4) !important;
  flex-wrap: wrap !important;
}

.footer-legal a {
  color: rgba(250, 246, 240, 0.55) !important;
  transition: color var(--transition-fast) !important;
}

/* ============================================================
   37. WARM ORGANIC PREMIUM HOMEPAGE
   ============================================================ */

.rz-homepage {
  background-color: var(--clr-bg);
  color: var(--clr-text);
  overflow-x: hidden;
}

/* --- Reveal Animations --- */
[data-rz-reveal] {
  opacity: 0;
  transform: translateY(30px);
  transition: opacity 0.8s cubic-bezier(0.16, 1, 0.3, 1), transform 0.8s cubic-bezier(0.16, 1, 0.3, 1);
  will-change: transform, opacity;
}
[data-rz-reveal].rz-revealed {
  opacity: 1;
  transform: translateY(0);
}
[data-rz-reveal="fade-left"] {
  transform: translateX(40px);
}
[data-rz-reveal="fade-left"].rz-revealed {
  transform: translateX(0);
}
[data-rz-reveal="fade-right"] {
  transform: translateX(-40px);
}
[data-rz-reveal="fade-right"].rz-revealed {
  transform: translateX(0);
}

/* Section Utilities */
.section {
  padding: var(--sp-16) 0;
}
.section--lg {
  padding: var(--sp-24) 0;
}
.section--sm {
  padding: var(--sp-10) 0;
}

/* --- Background Blobs --- */
.rz-hero {
  position: relative;
  padding: var(--sp-12) 0 var(--sp-16);
  background: radial-gradient(circle at 10% 20%, rgba(245, 239, 230, 0.5) 0%, rgba(253, 251, 247, 0.95) 90%);
  overflow: hidden;
  border-bottom: 1px solid var(--clr-border);
}
.rz-blob {
  position: absolute;
  border-radius: 50%;
  filter: blur(100px);
  -webkit-filter: blur(100px);
  z-index: 0;
  pointer-events: none;
  opacity: 0.5;
  animation: rzBlobFloat 18s ease-in-out infinite alternate;
}
.rz-blob--1 {
  width: 380px;
  height: 380px;
  background: radial-gradient(circle, rgba(74, 124, 89, 0.18) 0%, transparent 70%);
  top: -80px;
  left: -50px;
}
.rz-blob--2 {
  width: 450px;
  height: 450px;
  background: radial-gradient(circle, rgba(211, 97, 53, 0.12) 0%, transparent 70%);
  bottom: -50px;
  right: -80px;
  animation-delay: -5s;
}
.rz-blob--3 {
  width: 300px;
  height: 300px;
  background: radial-gradient(circle, rgba(229, 169, 60, 0.15) 0%, transparent 70%);
  top: 40%;
  left: 45%;
  animation-delay: -9s;
}

@keyframes rzBlobFloat {
  0% { transform: translate(0, 0) scale(1); }
  100% { transform: translate(30px, 40px) scale(1.15); }
}

/* --- Hero Layout --- */
.rz-hero__inner {
  display: grid;
  grid-template-columns: 1.1fr 0.9fr;
  gap: var(--sp-12);
  align-items: center;
  position: relative;
  z-index: 2;
}

/* Left Content */
.rz-eyebrow {
  display: inline-flex;
  align-items: center;
  gap: var(--sp-2);
  background: rgba(53, 94, 59, 0.08);
  color: var(--clr-primary);
  font-size: var(--fs-xs);
  font-weight: var(--fw-semibold);
  padding: 6px 14px;
  border-radius: var(--radius-full);
  margin-bottom: var(--sp-6);
  border: 1px solid rgba(53, 94, 59, 0.1);
}
.rz-eyebrow__dot {
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: var(--clr-primary);
  display: inline-block;
  animation: pulseDot 2s infinite;
}
@keyframes pulseDot {
  0% { transform: scale(0.95); box-shadow: 0 0 0 0 rgba(53, 94, 59, 0.7); }
  70% { transform: scale(1); box-shadow: 0 0 0 6px rgba(53, 94, 59, 0); }
  100% { transform: scale(0.95); box-shadow: 0 0 0 0 rgba(53, 94, 59, 0); }
}

.rz-hero__title {
  font-family: var(--ff-serif);
  font-size: clamp(2.5rem, 5vw, 4rem);
  font-weight: var(--fw-bold);
  line-height: var(--lh-tight);
  color: var(--clr-text);
  margin-bottom: var(--sp-4);
  letter-spacing: -0.01em;
}
.rz-hero__title-accent {
  color: var(--clr-secondary);
  position: relative;
  display: inline-block;
}
.rz-hero__title-accent::after {
  content: '';
  position: absolute;
  bottom: 4px;
  left: 0;
  width: 100%;
  height: 8px;
  background: rgba(229, 169, 60, 0.2);
  z-index: -1;
  border-radius: 4px;
}

.rz-hero__sub {
  font-size: var(--fs-md);
  color: var(--clr-text-muted);
  line-height: var(--lh-normal);
  margin-bottom: var(--sp-8);
  max-width: 520px;
}

/* Glassmorphic Search Form */
.rz-hero__search-wrap {
  margin-bottom: var(--sp-10);
  max-width: 550px;
}
.rz-hero__search-inner {
  display: flex;
  align-items: center;
  background: rgba(255, 255, 255, 0.8);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  border: 1px solid rgba(231, 221, 208, 0.8);
  border-radius: var(--radius-full);
  padding: 6px 6px 6px var(--sp-4);
  box-shadow: var(--shadow-sm);
  transition: all var(--transition-base);
}
.rz-hero__search-inner:focus-within {
  background: #fff;
  border-color: var(--clr-primary);
  box-shadow: var(--shadow-md);
}
.rz-hero__search-icon {
  color: var(--clr-text-light);
  margin-right: var(--sp-2);
  flex-shrink: 0;
}
.rz-hero__search-field {
  border: none !important;
  background: transparent !important;
  outline: none !important;
  font-size: var(--fs-sm);
  font-family: var(--ff-sans);
  color: var(--clr-text);
  width: 100%;
  padding: 6px 0 !important;
}
.rz-hero__search-btn {
  background: var(--clr-primary) !important;
  color: #fff !important;
  border: none !important;
  padding: 10px 24px !important;
  border-radius: var(--radius-full) !important;
  font-weight: var(--fw-semibold);
  font-size: var(--fs-sm);
  cursor: pointer;
  transition: background var(--transition-fast), transform var(--transition-fast);
}
.rz-hero__search-btn:hover {
  background: var(--clr-primary-dark) !important;
  transform: translateY(-1px);
}

.rz-hero__quick-cats {
  display: flex;
  flex-wrap: wrap;
  gap: var(--sp-2);
  margin-top: var(--sp-4);
}
.rz-quick-pill {
  font-size: var(--fs-xs);
  color: var(--clr-text-muted);
  background: rgba(255, 255, 255, 0.6);
  border: 1px solid var(--clr-border);
  padding: 5px 12px;
  border-radius: var(--radius-full);
  text-decoration: none;
  font-weight: var(--fw-medium);
  transition: all var(--transition-fast);
}
.rz-quick-pill:hover {
  color: var(--clr-primary);
  background: #fff;
  border-color: var(--clr-primary-light);
  transform: translateY(-1px);
  box-shadow: var(--shadow-xs);
}

/* Stats Row */
.rz-hero__stats {
  display: flex;
  align-items: center;
  gap: var(--sp-6);
}
.rz-stat__num {
  font-family: var(--ff-serif);
  font-size: var(--fs-2xl);
  font-weight: var(--fw-bold);
  color: var(--clr-primary);
  line-height: 1.1;
}
.rz-stat__label {
  font-size: var(--fs-xs);
  color: var(--clr-text-muted);
  margin-top: 2px;
}
.rz-stat__divider {
  width: 1px;
  height: 32px;
  background-color: var(--clr-border);
}

/* --- Right side: 3D stacked card --- */
.rz-hero__card-stack {
  position: relative;
  display: flex;
  justify-content: center;
  align-items: center;
}
.rz-stack-layer {
  position: absolute;
  width: 100%;
  height: 100%;
  border-radius: var(--radius-2xl);
  pointer-events: none;
  transition: transform var(--transition-base), opacity var(--transition-base);
}
.rz-stack-layer--1 {
  background: rgba(253, 251, 247, 0.6);
  border: 1px solid rgba(255, 255, 255, 0.5);
  transform: rotate(-3.5deg) scale(0.97) translate(-10px, 6px);
  box-shadow: 0 10px 30px rgba(43,37,32,0.04);
  z-index: 1;
}
.rz-stack-layer--2 {
  background: rgba(255, 255, 255, 0.4);
  border: 1px solid rgba(255, 255, 255, 0.3);
  transform: rotate(3deg) scale(0.94) translate(12px, 8px);
  box-shadow: 0 8px 25px rgba(43,37,32,0.03);
  z-index: 0;
}
.rz-hero__card-stack:hover .rz-stack-layer--1 {
  transform: rotate(-5deg) scale(0.98) translate(-15px, 10px);
}
.rz-hero__card-stack:hover .rz-stack-layer--2 {
  transform: rotate(4.5deg) scale(0.96) translate(18px, 12px);
}

.rz-hero-card {
  position: relative;
  z-index: 2;
  background: var(--clr-surface);
  border: 1px solid rgba(255, 255, 255, 0.7);
  border-radius: var(--radius-2xl);
  overflow: hidden;
  box-shadow: var(--shadow-lg);
  transition: transform var(--transition-base), box-shadow var(--transition-base);
  width: 100%;
  max-width: 440px;
}
.rz-hero__card-stack:hover .rz-hero-card {
  transform: translateY(-6px);
  box-shadow: var(--shadow-xl);
}

.rz-hero-card__badge-wrap {
  position: absolute;
  top: var(--sp-4);
  right: var(--sp-4);
  z-index: 10;
  width: 84px;
  height: 84px;
  background: rgba(255, 255, 255, 0.95);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  box-shadow: var(--shadow-md);
  border: 1px solid rgba(0,0,0,0.05);
}
.rz-rotating-badge {
  animation: rzRotateBadge 14s linear infinite;
}
.rz-rotating-badge text {
  font-family: var(--ff-sans);
  font-weight: var(--fw-bold);
  font-size: 8px;
  fill: var(--clr-text);
  letter-spacing: 1px;
}
@keyframes rzRotateBadge {
  0% { transform: rotate(0deg); }
  100% { transform: rotate(360deg); }
}

.rz-hero-card__image {
  position: relative;
  height: 260px;
  overflow: hidden;
}
.rz-hero-card__image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform var(--transition-slow);
}
.rz-hero-card:hover .rz-hero-card__image img {
  transform: scale(1.04);
}
.rz-hero-card__image-overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(to bottom, transparent 40%, rgba(43,37,32,0.4) 100%);
  z-index: 1;
}

.rz-hero-card__top-meta {
  position: absolute;
  top: var(--sp-4);
  left: var(--sp-4);
  z-index: 5;
  display: flex;
  gap: var(--sp-2);
}
.rz-hero-card__cat-pill {
  font-size: var(--fs-xs);
  font-weight: var(--fw-bold);
  color: #fff;
  background: var(--clr-primary);
  padding: 4px 12px;
  border-radius: var(--radius-full);
  box-shadow: var(--shadow-sm);
}
.rz-hero-card__cat-pill--time {
  background: rgba(43, 37, 32, 0.85);
  backdrop-filter: blur(4px);
  font-weight: var(--fw-medium);
}

.rz-hero-card__content {
  padding: var(--sp-6) var(--sp-6) var(--sp-8);
}
.rz-hero-card__rating {
  display: flex;
  align-items: center;
  gap: var(--sp-2);
  margin-bottom: var(--sp-3);
}
.rz-stars {
  color: #F4A261;
  letter-spacing: 2px;
}
.rz-stars--amber {
  color: #E5A93C;
}
.rz-rating-val {
  font-size: var(--fs-xs);
  font-weight: var(--fw-bold);
  color: var(--clr-text-muted);
}

.rz-hero-card__title {
  font-family: var(--ff-serif);
  font-size: 1.45rem;
  line-height: var(--lh-snug);
  margin-bottom: var(--sp-3);
}
.rz-hero-card__title a {
  color: var(--clr-text);
  text-decoration: none;
  transition: color var(--transition-fast);
}
.rz-hero-card__title a:hover {
  color: var(--clr-primary);
}

.rz-hero-card__excerpt {
  font-size: var(--fs-sm);
  color: var(--clr-text-muted);
  line-height: var(--lh-normal);
  margin-bottom: var(--sp-6);
}

.rz-hero-card__btn {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  color: var(--clr-secondary);
  font-size: var(--fs-sm);
  font-weight: var(--fw-bold);
  text-decoration: none;
  transition: color var(--transition-fast), transform var(--transition-fast);
}
.rz-hero-card__btn svg {
  transition: transform var(--transition-fast);
}
.rz-hero-card__btn:hover {
  color: var(--clr-secondary-dark);
}
.rz-hero-card__btn:hover svg {
  transform: translateX(4px);
}

.rz-hero-card__float-badge {
  position: absolute;
  bottom: var(--sp-6);
  right: var(--sp-6);
  background: var(--clr-soft);
  border: 1px solid var(--clr-border);
  padding: 6px 12px;
  border-radius: var(--radius-lg);
  display: flex;
  flex-direction: column;
  align-items: center;
  line-height: 1.1;
  box-shadow: var(--shadow-sm);
}
.rz-hero-card__float-num {
  font-weight: var(--fw-bold);
  font-size: var(--fs-base);
  color: var(--clr-text);
}
.rz-hero-card__float-label {
  font-size: 9px;
  text-transform: uppercase;
  color: var(--clr-text-muted);
  letter-spacing: 0.5px;
  margin-top: 1px;
}

/* --- Section Headers --- */
.rz-section-head {
  margin-bottom: var(--sp-12);
}
.rz-section-head--row {
  display: flex;
  justify-content: space-between;
  align-items: flex-end;
  gap: var(--sp-6);
}
.rz-section-head--center {
  text-align: center;
  max-width: 650px;
  margin-inline: auto;
}

.rz-overline {
  display: block;
  font-size: var(--fs-xs);
  font-weight: var(--fw-bold);
  color: var(--clr-secondary);
  text-transform: uppercase;
  letter-spacing: 0.15em;
  margin-bottom: var(--sp-2);
}
.rz-section-title {
  font-family: var(--ff-serif);
  font-size: clamp(1.8rem, 3.5vw, 2.5rem);
  font-weight: var(--fw-bold);
  color: var(--clr-text);
  line-height: var(--lh-tight);
}
.rz-section-sub {
  font-size: var(--fs-base);
  color: var(--clr-text-muted);
  margin-top: var(--sp-3);
}
.rz-section-link {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  color: var(--clr-primary);
  font-size: var(--fs-sm);
  font-weight: var(--fw-bold);
  text-decoration: none;
  transition: color var(--transition-fast);
  padding-bottom: 2px;
  border-bottom: 2px solid transparent;
}
.rz-section-link svg {
  transition: transform var(--transition-fast);
}
.rz-section-link:hover {
  color: var(--clr-primary-dark);
  border-color: var(--clr-primary);
}
.rz-section-link:hover svg {
  transform: translateX(3px);
}

/* --- Category Rail (Carousel) --- */
/* ── Category 5-column fixed grid ─────────────────────────────────── */
.rz-cat-rail {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: var(--sp-5);
  padding: var(--sp-2) 0 var(--sp-6);
}

@media (max-width: 1100px) {
  .rz-cat-rail {
    grid-template-columns: repeat(3, 1fr);
    gap: var(--sp-4);
  }
}
@media (max-width: 700px) {
  .rz-cat-rail {
    grid-template-columns: repeat(2, 1fr);
    gap: var(--sp-3);
  }
}
@media (max-width: 420px) {
  .rz-cat-rail {
    grid-template-columns: 1fr;
    gap: var(--sp-3);
  }
}

/* ── Category Card — premium editorial style ──────────────────────── */
.rz-cat-card {
  position: relative;
  /* Fill the grid column, no fixed flex-shrink */
  width: 100%;
  height: 320px;
  border-radius: var(--radius-xl);
  overflow: hidden;
  text-decoration: none;
  box-shadow: 0 4px 24px rgba(43,37,32,0.12);
  transition: transform 0.35s cubic-bezier(0.34, 1.35, 0.64, 1), box-shadow 0.35s ease;
  display: block;
}
.rz-cat-card:hover {
  transform: translateY(-8px) scale(1.02);
  box-shadow: 0 20px 48px rgba(43,37,32,0.22);
  z-index: 2;
}

/* Fallback gradient background when no image */
.rz-cat-card::before {
  content: '';
  position: absolute;
  inset: 0;
  background: var(--cat-grad, linear-gradient(135deg,#2D6A4F,#1B4332));
  z-index: 0;
  opacity: 0; /* Set to 0 so the image layer is fully visible */
}

.rz-cat-card__img {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 0.6s cubic-bezier(0.25, 0.46, 0.45, 0.94);
  z-index: 1; /* Raise index to draw on top of background gradient */
}
.rz-cat-card:hover .rz-cat-card__img {
  transform: scale(1.08);
}

/* Rich gradient overlay */
.rz-cat-card__overlay {
  position: absolute;
  inset: 0;
  background:
    linear-gradient(
      180deg,
      rgba(0,0,0,0.03) 0%,
      rgba(0,0,0,0.28) 45%,
      rgba(0,0,0,0.82) 100%
    );
  z-index: 2; /* Draw on top of image */
  transition: background 0.4s ease;
}
.rz-cat-card:hover .rz-cat-card__overlay {
  background:
    linear-gradient(
      180deg,
      rgba(0,0,0,0.06) 0%,
      rgba(0,0,0,0.32) 40%,
      rgba(0,0,0,0.90) 100%
    );
}

/* Accent color top-bar on hover */
.rz-cat-card::after {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 3px;
  background: var(--cat-clr, #2D6A4F);
  z-index: 3;
  transform: scaleX(0);
  transform-origin: left;
  transition: transform 0.35s ease;
}
.rz-cat-card:hover::after {
  transform: scaleX(1);
}

/* Badge */
.rz-cat-card__badge {
  position: absolute;
  top: var(--sp-4);
  left: var(--sp-4);
  background: var(--clr-secondary);
  color: #fff;
  font-size: 10px;
  font-weight: var(--fw-bold);
  padding: 4px 12px;
  border-radius: var(--radius-full);
  z-index: 3;
  box-shadow: 0 2px 8px rgba(0,0,0,0.25);
  text-transform: uppercase;
  letter-spacing: 0.08em;
  backdrop-filter: blur(6px);
}

/* Body text at bottom */
.rz-cat-card__body {
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  padding: var(--sp-6) var(--sp-5) var(--sp-5);
  z-index: 2;
  transform: translateY(0);
  transition: transform 0.35s ease;
}

/* Icon bubble */
.rz-cat-card__icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 44px;
  height: 44px;
  border-radius: 50%;
  background: rgba(255,255,255,0.15);
  backdrop-filter: blur(8px);
  font-size: var(--fs-xl);
  margin-bottom: var(--sp-3);
  transition: transform 0.4s cubic-bezier(0.34, 1.56, 0.64, 1), background 0.3s ease;
}
.rz-cat-card:hover .rz-cat-card__icon {
  transform: scale(1.15) translateY(-3px);
  background: rgba(255,255,255,0.25);
}

.rz-cat-card__name {
  font-family: var(--ff-serif);
  font-size: clamp(1rem, 1.5vw, var(--fs-lg));
  font-weight: var(--fw-bold);
  color: #fff;
  margin-bottom: 6px;
  line-height: var(--lh-tight);
  text-shadow: 0 1px 4px rgba(0,0,0,0.4);
}
.rz-cat-card__count {
  font-size: var(--fs-xs);
  color: rgba(255, 255, 255, 0.7);
  line-height: var(--lh-snug);
  font-weight: var(--fw-medium);
}

/* Arrow indicator */
.rz-cat-card__arrow {
  position: absolute;
  bottom: var(--sp-5);
  right: var(--sp-5);
  z-index: 2;
  width: 32px;
  height: 32px;
  border-radius: 50%;
  background: rgba(255,255,255,0.15);
  backdrop-filter: blur(6px);
  display: flex;
  align-items: center;
  justify-content: center;
  color: #fff;
  font-size: var(--fs-base);
  opacity: 0;
  transform: translateX(8px) scale(0.8);
  transition: all 0.35s cubic-bezier(0.34, 1.35, 0.64, 1);
}
.rz-cat-card:hover .rz-cat-card__arrow {
  opacity: 1;
  transform: translateX(0) scale(1);
  background: rgba(255,255,255,0.25);
}

/* --- Recipe Spotlight Block --- */
.rz-spotlight {
  background: #FAF8F5;
  border-top: 1px solid var(--clr-border);
  border-bottom: 1px solid var(--clr-border);
  padding: var(--sp-16) 0;
}
.rz-spotlight__inner {
  display: grid;
  grid-template-columns: 1.05fr 0.95fr;
  gap: var(--sp-12);
  align-items: center;
}

.rz-spotlight__image-wrap {
  position: relative;
  border-radius: var(--radius-2xl);
  overflow: hidden;
  box-shadow: var(--shadow-lg);
  height: 420px;
}
.rz-spotlight__img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform var(--transition-slow);
}
.rz-spotlight__image-wrap:hover .rz-spotlight__img {
  transform: scale(1.03);
}

.rz-spotlight__img-badge {
  position: absolute;
  top: var(--sp-6);
  left: var(--sp-6);
  background: var(--clr-surface);
  border: 1px solid var(--clr-border);
  padding: 8px 16px;
  border-radius: var(--radius-full);
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-size: var(--fs-xs);
  font-weight: var(--fw-bold);
  box-shadow: var(--shadow-sm);
}

.rz-spotlight__content {
  padding-right: var(--sp-4);
}
.rz-spotlight__cat {
  display: inline-block;
  font-size: var(--fs-xs);
  color: var(--clr-primary);
  font-weight: var(--fw-bold);
  text-transform: uppercase;
  letter-spacing: 1px;
  margin-bottom: var(--sp-2);
}
.rz-spotlight__title {
  font-family: var(--ff-serif);
  font-size: var(--fs-3xl);
  line-height: var(--lh-tight);
  margin-bottom: var(--sp-3);
}
.rz-spotlight__title a {
  color: var(--clr-text);
  text-decoration: none;
  transition: color var(--transition-fast);
}
.rz-spotlight__title a:hover {
  color: var(--clr-primary);
}

.rz-spotlight__rating {
  display: flex;
  align-items: center;
  gap: var(--sp-2);
  margin-bottom: var(--sp-4);
  font-size: var(--fs-sm);
  font-weight: var(--fw-semibold);
  color: var(--clr-text-muted);
}

.rz-spotlight__excerpt {
  color: var(--clr-text-muted);
  font-size: var(--fs-base);
  line-height: var(--lh-normal);
  margin-bottom: var(--sp-6);
}

.rz-spotlight__pills {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: var(--sp-4);
  margin-bottom: var(--sp-8);
}
.rz-info-pill {
  display: flex;
  align-items: center;
  gap: var(--sp-3);
  background: var(--clr-surface);
  padding: var(--sp-3) var(--sp-4);
  border-radius: var(--radius-lg);
  border: 1px solid var(--clr-border);
}
.rz-info-pill__icon {
  font-size: var(--fs-xl);
  background: var(--clr-soft);
  width: 40px;
  height: 40px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}
.rz-info-pill span {
  display: flex;
  flex-direction: column;
}
.rz-info-pill strong {
  font-size: var(--fs-sm);
  color: var(--clr-text);
}
.rz-info-pill small {
  font-size: 10px;
  color: var(--clr-text-muted);
  margin-top: 1px;
}

.rz-spotlight__btn {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  background: var(--clr-primary) !important;
  color: #fff !important;
  border: none !important;
  padding: 12px 28px !important;
  border-radius: var(--radius-full) !important;
  font-weight: var(--fw-semibold);
  font-size: var(--fs-sm);
  text-decoration: none;
  transition: background var(--transition-fast), transform var(--transition-fast);
  box-shadow: var(--shadow-sm);
}
.rz-spotlight__btn svg {
  transition: transform var(--transition-fast);
}
.rz-spotlight__btn:hover {
  background: var(--clr-primary-dark) !important;
  transform: translateY(-1px);
  box-shadow: var(--shadow-md);
}
.rz-spotlight__btn:hover svg {
  transform: translateX(4px);
}

/* --- Interactive Tabs --- */
.rz-tabs-nav {
  display: inline-flex;
  background: rgba(0, 0, 0, 0.03);
  padding: 6px;
  border-radius: var(--radius-full);
  border: 1px solid var(--clr-border);
  position: relative;
  margin-bottom: var(--sp-10);
  width: auto;
  max-width: 100%;
}
.rz-tabs-section .rz-section-head--center {
  margin-bottom: var(--sp-8);
}
.rz-tabs-nav-wrap {
  display: flex;
  justify-content: center;
}
.rz-tab-btn {
  background: transparent !important;
  border: none !important;
  color: var(--clr-text-muted) !important;
  padding: 12px 28px !important;
  font-weight: var(--fw-semibold);
  font-size: var(--fs-sm);
  border-radius: var(--radius-full) !important;
  cursor: pointer;
  transition: color var(--transition-fast);
  display: inline-flex;
  align-items: center;
  gap: var(--sp-2);
  z-index: 2;
  position: relative;
}
.rz-tab-btn__icon {
  font-size: var(--fs-base);
}
.rz-tab-btn--active {
  color: #fff !important;
}
.rz-tab-indicator {
  position: absolute;
  top: 6px;
  bottom: 6px;
  background: var(--clr-primary);
  border-radius: var(--radius-full);
  transition: all 0.35s cubic-bezier(0.34, 1.56, 0.64, 1);
  z-index: 1;
  box-shadow: 0 4px 12px rgba(53, 94, 59, 0.2);
}

.rz-tab-panel {
  display: none;
  opacity: 0;
  transform: translateY(15px);
  transition: opacity 0.4s ease, transform 0.4s ease;
}
.rz-tab-panel--active {
  display: block;
  opacity: 1;
  transform: translateY(0);
}

/* Grid Layout Systems */
.grid {
  display: grid;
  gap: var(--sp-8);
}
.grid-3 {
  grid-template-columns: repeat(3, 1fr);
}
.grid-auto {
  grid-template-columns: repeat(auto-fill, minmax(360px, 1fr));
}

/* --- Category Sections (Recipe Cards grid) --- */
.rz-cat-section {
  border-bottom: 1px solid var(--clr-border);
}

/* --- Chef Spotlight (Polaroid Design) --- */
.rz-chefs-section {
  background: radial-gradient(circle at 50% 50%, rgba(245, 239, 230, 0.4) 0%, rgba(253, 251, 247, 0.8) 100%);
}
.rz-chefs-grid {
  display: flex;
  flex-direction: column;
  gap: var(--sp-6);
}
.rz-chef-card {
  background: rgba(255, 255, 255, 0.75) !important;
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  border: 1px solid rgba(255, 255, 255, 0.5) !important;
  padding: var(--sp-6) !important;
  border-radius: 24px;
  box-shadow: 0 10px 30px rgba(0, 0, 0, 0.04);
  transition: transform 0.3s ease, box-shadow 0.3s ease;
  display: grid;
  grid-template-columns: 240px 1fr;
  gap: var(--sp-8);
  align-items: center;
}
.rz-chef-card:hover {
  transform: translateY(-5px);
  box-shadow: 0 15px 40px rgba(0, 0, 0, 0.08);
}
.rz-chef-card__photo-wrap {
  position: relative;
  border-radius: 20px;
  overflow: hidden;
  height: 240px;
  width: 240px;
  background-color: var(--clr-soft);
  box-shadow: 0 8px 20px rgba(0,0,0,0.06);
}
.rz-chef-card__photo {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 0.5s ease;
}
.rz-chef-card:hover .rz-chef-card__photo {
  transform: scale(1.05);
}
.rz-chef-card__style-badge {
  position: absolute;
  bottom: var(--sp-4);
  left: 50%;
  transform: translateX(-50%);
  background: var(--chef-accent, var(--clr-secondary));
  color: #fff;
  font-size: 10px;
  font-weight: var(--fw-bold);
  padding: 6px 14px;
  border-radius: var(--radius-full);
  box-shadow: 0 4px 10px rgba(0,0,0,0.15);
  text-transform: uppercase;
  letter-spacing: 0.5px;
  white-space: nowrap;
}

.rz-chef-card__content {
  position: relative;
  display: flex;
  flex-direction: column;
  justify-content: center;
  height: 100%;
}
.rz-chef-card__sig {
  position: absolute;
  top: -15px;
  right: var(--sp-4);
  font-family: 'Playfair Display', Georgia, serif;
  font-size: 2.8rem;
  color: var(--chef-accent, var(--clr-primary));
  opacity: 0.07;
  font-style: italic;
  pointer-events: none;
  user-select: none;
}
.rz-chef-card__name {
  font-family: var(--ff-serif);
  font-size: 1.6rem;
  font-weight: 800;
  color: var(--clr-text);
  margin-bottom: var(--sp-1);
}
.rz-chef-card__bio {
  font-size: 1.05rem;
  color: var(--clr-text-muted);
  line-height: 1.6;
  margin-bottom: var(--sp-4);
}
.rz-chef-card__tags {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-bottom: var(--sp-5);
}
.rz-chef-tag {
  font-size: 11px;
  font-weight: var(--fw-semibold);
  color: var(--chef-accent, var(--clr-primary));
  background: rgba(45, 106, 79, 0.08);
  border: 1px solid rgba(45, 106, 79, 0.15);
  padding: 4px 12px;
  border-radius: 8px;
}
.rz-chef-card__btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  background: transparent !important;
  border: 2px solid var(--chef-accent, var(--clr-primary)) !important;
  color: var(--chef-accent, var(--clr-primary)) !important;
  text-decoration: none;
  font-weight: 700;
  font-size: var(--fs-sm);
  padding: 12px 24px !important;
  border-radius: 50px;
  transition: all 0.25s ease;
  align-self: flex-start;
}
.rz-chef-card__btn:hover {
  background: var(--chef-accent, var(--clr-primary)) !important;
  color: #fff !important;
  box-shadow: 0 4px 12px rgba(45, 106, 79, 0.2);
}

/* Responsive adjustment for Mobile */
@media (max-width: 768px) {
  .rz-chef-card {
    grid-template-columns: 1fr;
    justify-items: center;
    text-align: center;
    padding: var(--sp-6) !important;
  }
  .rz-chef-card__photo-wrap {
    margin-bottom: var(--sp-4);
  }
  .rz-chef-card__btn {
    align-self: center;
  }
  .rz-chef-card__sig {
    display: none;
  }
}

/* --- Pinterest CTA Block --- */
.pinterest-cta {
  background: linear-gradient(135deg, #bd081c 0%, #e60023 100%);
  border-radius: var(--radius-2xl);
  padding: var(--sp-10) var(--sp-12);
  display: grid;
  grid-template-columns: 1fr 1fr;
  align-items: center;
  gap: var(--sp-8);
  color: #fff;
  box-shadow: var(--shadow-lg);
  overflow: hidden;
  position: relative;
}
.pinterest-cta-title {
  font-family: var(--ff-serif);
  font-size: var(--fs-2xl);
  font-weight: var(--fw-bold);
  margin-bottom: var(--sp-3);
  color: #fff;
}
.pinterest-cta-text {
  font-size: var(--fs-sm);
  line-height: var(--lh-normal);
  color: rgba(255, 255, 255, 0.9);
  margin-bottom: var(--sp-6);
  max-width: 420px;
}
.pinterest-btn {
  display: inline-flex;
  align-items: center;
  background: #fff;
  color: #e60023;
  padding: 12px 24px;
  border-radius: var(--radius-full);
  font-weight: var(--fw-bold);
  text-decoration: none;
  font-size: var(--fs-sm);
  box-shadow: var(--shadow-sm);
  transition: transform var(--transition-fast), box-shadow var(--transition-fast);
}
.pinterest-btn:hover {
  transform: translateY(-2px);
  box-shadow: var(--shadow-md);
  color: #bd081c;
}
.pinterest-images {
  display: flex;
  gap: var(--sp-4);
  justify-content: flex-end;
}
.pinterest-thumb-wrapper {
  position: relative;
  flex: 0 1 120px;
  transform: rotate(3deg);
  transition: transform 0.3s;
}
.pinterest-thumb-wrapper:nth-child(even) {
  transform: rotate(-3deg) translateY(10px);
}
.pinterest-thumb-wrapper:hover {
  transform: scale(1.05) rotate(0deg) translateY(-5px);
  z-index: 5;
}
.pin-badge {
  position: absolute;
  top: -8px;
  left: 50%;
  transform: translateX(-50%);
  z-index: 2;
  font-size: 1.2rem;
}
.pinterest-thumb {
  border-radius: var(--radius-md);
  overflow: hidden;
  box-shadow: var(--shadow-md);
  height: 180px;
  background: var(--clr-soft);
}
.pinterest-thumb img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

/* --- Newsletter Section --- */
.newsletter-section {
  background: linear-gradient(135deg, #0e1e15 0%, #173824 50%, #1e462d 100%);
  color: #fff;
  border-radius: var(--radius-2xl, 24px);
  margin: var(--sp-16) 0;
  padding: var(--sp-12) var(--sp-10);
  position: relative;
  overflow: hidden;
  box-shadow: 0 20px 50px rgba(14, 30, 21, 0.35);
}
.newsletter-section::before {
  content: '';
  position: absolute;
  top: -10%;
  right: -10%;
  width: 300px;
  height: 300px;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(229, 169, 60, 0.1) 0%, transparent 70%);
  pointer-events: none;
}
.newsletter-section::after {
  content: '';
  position: absolute;
  bottom: -20%;
  left: -10%;
  width: 400px;
  height: 400px;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(53, 94, 59, 0.25) 0%, transparent 60%);
  pointer-events: none;
}
.newsletter-inner {
  display: grid;
  grid-template-columns: 1fr 1.05fr;
  gap: var(--sp-12);
  align-items: center;
  position: relative;
  z-index: 2;
}
.newsletter-overline {
  color: var(--clr-cta);
  text-transform: uppercase;
  font-size: var(--fs-xs);
  font-weight: var(--fw-bold);
  letter-spacing: 2px;
  margin-bottom: var(--sp-2);
}
.newsletter-title {
  font-family: var(--ff-serif);
  font-size: var(--fs-3xl);
  font-weight: var(--fw-black);
  color: #fff;
  line-height: var(--lh-tight);
  margin-bottom: var(--sp-4);
}
.newsletter-text {
  color: rgba(255, 255, 255, 0.85);
  font-size: var(--fs-base);
  line-height: var(--lh-loose);
  max-width: 480px;
}

.newsletter-form-container {
  display: flex;
  justify-content: flex-end;
}
.newsletter-form-wrapper {
  background: rgba(255, 255, 255, 0.95);
  border: 1px solid rgba(255, 255, 255, 0.2);
  border-radius: var(--radius-2xl, 24px);
  padding: var(--sp-8) var(--sp-10);
  width: 100%;
  max-width: 480px;
  box-shadow: 0 30px 60px rgba(0, 0, 0, 0.25);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  transition: all 0.3s ease;
}
html.dark-mode .newsletter-form-wrapper {
  background: rgba(22, 27, 34, 0.92);
  border-color: rgba(255, 255, 255, 0.05);
  box-shadow: 0 30px 60px rgba(0, 0, 0, 0.5);
}
.newsletter-form {
  display: flex;
  flex-direction: column;
  gap: var(--sp-4);
}
.newsletter-form label {
  display: block;
  font-size: var(--fs-xs);
  font-weight: var(--fw-semibold);
  color: var(--clr-text);
  margin-bottom: 6px;
}
.newsletter-form input {
  width: 100%;
  border: 1.5px solid var(--clr-border);
  border-radius: var(--radius-lg, 12px);
  padding: 12px 16px;
  font-size: var(--fs-sm);
  color: var(--clr-text);
  background: var(--clr-soft);
  outline: none;
  transition: all 0.3s cubic-bezier(0.165, 0.84, 0.44, 1);
}
.newsletter-form input:focus {
  border-color: var(--clr-primary);
  background: #fff;
  box-shadow: 0 0 0 4px rgba(53, 94, 59, 0.15);
}
html.dark-mode .newsletter-form input:focus {
  border-color: var(--clr-primary-light);
  background: var(--clr-bg);
  box-shadow: 0 0 0 4px rgba(96, 134, 102, 0.25);
}
.newsletter-disclaimer {
  font-size: 11px;
  color: var(--clr-text-light);
  line-height: var(--lh-snug);
  text-align: center;
  margin-top: var(--sp-2);
}
.newsletter-disclaimer a {
  color: var(--clr-text-muted);
  text-decoration: underline;
}

/* --- SEO Text Block --- */
.seo-text-block {
  background: linear-gradient(145deg, var(--clr-surface), rgba(245, 239, 230, 0.45));
  border: 1px solid var(--clr-border);
  border-radius: var(--radius-2xl, 24px);
  padding: var(--sp-10) var(--sp-12);
  box-shadow: 0 10px 40px rgba(43, 37, 32, 0.03);
  position: relative;
  overflow: hidden;
  margin: var(--sp-12) 0;
}
html.dark-mode .seo-text-block {
  background: linear-gradient(145deg, rgba(22, 27, 34, 0.8), rgba(13, 17, 23, 0.45));
  border-color: rgba(48, 54, 61, 0.7);
  box-shadow: 0 10px 40px rgba(0, 0, 0, 0.3);
}
.seo-text-block::before {
  content: '';
  position: absolute;
  left: 0;
  top: 0;
  bottom: 0;
  width: 5px;
  background: linear-gradient(180deg, var(--clr-primary), var(--clr-secondary));
}
/* Disable the old vertical line on LTR */
.seo-text-block::after {
  display: none !important;
}
.seo-text-block h2 {
  font-family: var(--ff-serif);
  font-size: var(--fs-3xl);
  font-weight: var(--fw-black);
  color: var(--clr-text);
  margin-bottom: var(--sp-8);
  position: relative;
  display: block;
  line-height: 1.25;
}
.seo-text-block h2::after {
  content: '';
  display: block;
  width: 80px;
  height: 3px;
  background: linear-gradient(90deg, var(--clr-secondary), var(--clr-cta));
  margin-top: var(--sp-3);
  border-radius: var(--radius-full);
}
.seo-content-grid {
  display: grid;
  grid-template-columns: 1.15fr 0.85fr;
  gap: var(--sp-12);
  margin-top: var(--sp-8);
}
.seo-text-main p {
  font-size: var(--fs-base);
  color: var(--clr-text-muted);
  line-height: 1.85;
  margin-bottom: var(--sp-5);
  position: relative;
  padding-left: var(--sp-4);
}
.seo-text-main p::before {
  content: '“';
  position: absolute;
  left: 0;
  top: -4px;
  font-size: 2.2rem;
  color: var(--clr-primary);
  opacity: 0.15;
  font-family: var(--ff-serif);
}
html.dark-mode .seo-text-main p::before {
  color: var(--clr-primary-light);
}
.seo-categories-box {
  background: rgba(255, 255, 255, 0.45);
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
  border: 1px solid rgba(231, 221, 208, 0.8);
  border-radius: var(--radius-2xl, 24px);
  padding: var(--sp-8);
  box-shadow: 0 8px 32px rgba(43, 37, 32, 0.02);
  transition: all 0.3s ease;
}
html.dark-mode .seo-categories-box {
  background: rgba(22, 27, 34, 0.45);
  border-color: rgba(48, 54, 61, 0.6);
  box-shadow: 0 8px 32px rgba(0, 0, 0, 0.2);
}
.seo-categories-title {
  font-family: var(--ff-serif);
  font-size: var(--fs-lg);
  font-weight: var(--fw-bold);
  margin-bottom: var(--sp-6);
  color: var(--clr-text);
  position: relative;
  display: flex;
  align-items: center;
  gap: var(--sp-3);
}
.seo-categories-title::after {
  content: '';
  flex: 1;
  height: 1px;
  background: linear-gradient(90deg, var(--clr-border), transparent);
}
.seo-categories-list {
  display: flex;
  flex-direction: column;
  gap: var(--sp-4);
}
.seo-cat-item {
  display: flex;
  gap: var(--sp-4);
  padding: var(--sp-4.5) var(--sp-5);
  background: var(--clr-soft);
  border-radius: var(--radius-xl, 16px);
  border: 1px solid var(--clr-border);
  transition: all 0.4s cubic-bezier(0.16, 1, 0.3, 1);
  cursor: pointer;
}
.seo-cat-item:hover {
  background: var(--clr-surface);
  border-color: var(--clr-secondary);
  transform: translateX(6px) translateY(-2px);
  box-shadow: 0 10px 25px rgba(211, 97, 53, 0.08);
}
html.dark-mode .seo-cat-item:hover {
  box-shadow: 0 10px 25px rgba(0, 0, 0, 0.4);
}
.seo-cat-icon {
  font-size: 1.5rem;
  width: 46px;
  height: 46px;
  background: #fff;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 50%;
  border: 1px solid var(--clr-border);
  box-shadow: 0 4px 10px rgba(0,0,0,0.02);
  flex-shrink: 0;
  transition: all 0.3s cubic-bezier(0.165, 0.84, 0.44, 1);
}
html.dark-mode .seo-cat-icon {
  background: var(--clr-bg);
  border-color: var(--clr-border);
}
.seo-cat-item:hover .seo-cat-icon {
  transform: rotate(-12deg) scale(1.15);
  border-color: var(--clr-secondary);
  background: var(--clr-surface);
  box-shadow: 0 6px 15px rgba(211, 97, 53, 0.15);
}
.seo-cat-info {
  flex: 1;
}
.seo-cat-name {
  font-weight: var(--fw-bold);
  font-size: var(--fs-sm);
  color: var(--clr-text);
  display: block;
  margin-bottom: var(--sp-1);
  transition: color 0.3s ease;
}
.seo-cat-item:hover .seo-cat-name {
  color: var(--clr-primary);
}
html.dark-mode .seo-cat-item:hover .seo-cat-name {
  color: var(--clr-primary-light);
}
.seo-cat-desc {
  font-size: var(--fs-xs);
  color: var(--clr-text-muted);
  line-height: var(--lh-snug);
  margin: 0;
}

/* ============================================================
   RESPONSIVENESS OVERRIDES
   ============================================================ */
@media (max-width: 991px) {
  .rz-hero__inner {
    grid-template-columns: 1fr;
    gap: var(--sp-10);
    text-align: center;
  }
  .rz-eyebrow, .rz-hero__sub, .rz-hero__search-wrap, .rz-hero__stats {
    margin-inline: auto;
  }
  .rz-hero__stats {
    justify-content: center;
  }
  .rz-hero__card-stack {
    max-width: 440px;
    margin-inline: auto;
    width: 100%;
  }

  .rz-spotlight__inner {
    grid-template-columns: 1fr;
    gap: var(--sp-8);
  }
  .rz-spotlight__content {
    padding-right: 0;
  }

  .grid-3, .rz-chefs-grid {
    grid-template-columns: repeat(2, 1fr);
  }

  .pinterest-cta {
    grid-template-columns: 1fr;
    text-align: center;
  }
  .pinterest-cta-text {
    margin-inline: auto;
  }
  .pinterest-images {
    justify-content: center;
    margin-top: var(--sp-4);
  }

  .newsletter-inner {
    grid-template-columns: 1fr;
    gap: var(--sp-8);
    text-align: center;
  }
  .newsletter-text {
    margin-inline: auto;
  }
  .newsletter-form-container {
    justify-content: center;
  }

  .seo-content-grid {
    grid-template-columns: 1fr;
    gap: var(--sp-8);
  }
}

@media (max-width: 640px) {
  .grid-3, .rz-chefs-grid, .grid-auto {
    grid-template-columns: 1fr;
  }
  .rz-hero__stats {
    flex-wrap: wrap;
    justify-content: center;
    gap: var(--sp-4);
  }
  .rz-stat__divider {
    display: none;
  }
  .rz-spotlight__pills {
    grid-template-columns: 1fr;
  }
  .pinterest-images {
    display: none;
  }
}

/* ============================================================
   49b. STATS STRIP (above footer wave)
   ============================================================ */
.rz-stats-strip {
  background: linear-gradient(135deg, var(--clr-primary-dark) 0%, var(--clr-primary) 50%, var(--clr-primary-light) 100%);
  padding: var(--sp-6) 0;
  position: relative;
  overflow: hidden;
}
.rz-stats-strip::before {
  content: '';
  position: absolute;
  inset: 0;
  background: url("data:image/svg+xml,%3Csvg width='60' height='60' viewBox='0 0 60 60' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='none' fill-rule='evenodd'%3E%3Cg fill='%23ffffff' fill-opacity='0.03'%3E%3Cpath d='M36 34v-4h-2v4h-4v2h4v4h2v-4h4v-2h-4zm0-30V0h-2v4h-4v2h4v4h2V6h4V4h-4zM6 34v-4H4v4H0v2h4v4h2v-4h4v-2H6zM6 4V0H4v4H0v2h4v4h2V6h4V4H6z'/%3E%3C/g%3E%3C/g%3E%3C/svg%3E");
}
.rz-stats-strip__inner {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: var(--sp-8);
  flex-wrap: wrap;
  position: relative;
  z-index: 1;
}
.rz-strip-stat {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 2px;
  text-align: center;
}
.rz-strip-stat__num {
  font-family: var(--ff-serif);
  font-size: var(--fs-2xl);
  font-weight: var(--fw-black);
  color: #fff;
  line-height: 1;
  letter-spacing: -0.02em;
}
.rz-strip-stat__lbl {
  font-size: var(--fs-xs);
  color: rgba(255,255,255,.75);
  font-weight: var(--fw-medium);
  letter-spacing: .05em;
  white-space: nowrap;
}
.rz-strip-divider {
  width: 1px;
  height: 40px;
  background: rgba(255,255,255,.2);
  flex-shrink: 0;
}
@media (max-width: 640px) {
  .rz-strip-divider { display: none; }
  .rz-stats-strip__inner { gap: var(--sp-5); }
}

/* ============================================================
   49c. FOOTER RECIPE MINI-CARD (inside brand column)
   ============================================================ */
.rz-footer-recipe-card {
  display: flex;
  align-items: center;
  gap: var(--sp-3);
  padding: var(--sp-3) var(--sp-4);
  background: rgba(255,255,255,.05);
  border: 1px solid rgba(255,255,255,.1);
  border-radius: var(--radius-lg);
  text-decoration: none;
  color: var(--footer-text);
  margin-bottom: var(--sp-5);
  transition: all .25s ease;
  position: relative;
  overflow: hidden;
}
.rz-footer-recipe-card::before {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(90deg, transparent, rgba(255,255,255,.03));
  opacity: 0;
  transition: opacity .25s ease;
}
.rz-footer-recipe-card:hover {
  background: rgba(255,255,255,.09);
  border-color: rgba(233,185,73,.3);
  color: var(--footer-text-bright);
  transform: translateY(-2px);
}
.rz-footer-recipe-card:hover::before { opacity: 1; }
.rz-footer-recipe-card__thumb {
  width: 54px;
  height: 54px;
  border-radius: var(--radius-md);
  overflow: hidden;
  flex-shrink: 0;
  background: rgba(255,255,255,.08);
  display: flex;
  align-items: center;
  justify-content: center;
}
.rz-footer-recipe-card__thumb img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  border-radius: var(--radius-md);
  transition: transform .3s ease;
}
.rz-footer-recipe-card:hover .rz-footer-recipe-card__thumb img { transform: scale(1.06); }
.rz-footer-recipe-card__info {
  display: flex;
  flex-direction: column;
  flex: 1;
  min-width: 0;
}
.rz-footer-recipe-card__badge {
  font-size: 9px;
  font-weight: var(--fw-bold);
  text-transform: uppercase;
  letter-spacing: .1em;
  color: var(--footer-gold);
  margin-bottom: 2px;
}
.rz-footer-recipe-card__title {
  font-weight: var(--fw-semibold);
  font-size: var(--fs-sm);
  line-height: 1.3;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
  color: var(--footer-text-bright);
}
.rz-footer-recipe-card__meta {
  font-size: 11px;
  color: rgba(255,255,255,.4);
  margin-top: 3px;
}
.rz-footer-recipe-card__arrow {
  font-size: var(--fs-md);
  color: var(--footer-gold);
  opacity: 0;
  transform: translateX(-4px);
  transition: all .25s ease;
  flex-shrink: 0;
}
.rz-footer-recipe-card:hover .rz-footer-recipe-card__arrow {
  opacity: 1;
  transform: translateX(0);
}

/* ============================================================
   49d. SOCIAL BUTTONS — Brand colors on hover
   ============================================================ */
.rz-social-btn--pinterest:hover { background: #E60023; border-color: #E60023; }
.rz-social-btn--instagram:hover { background: linear-gradient(45deg,#f09433,#e6683c,#dc2743,#cc2366,#bc1888); border-color: #e6683c; }
.rz-social-btn--youtube:hover   { background: #FF0000; border-color: #FF0000; }
.rz-social-btn--tiktok:hover    { background: #010101; border-color: #010101; }
.rz-social-btn--facebook:hover  { background: #1877F2; border-color: #1877F2; }

/* ============================================================
   49e. FOOTER BOTTOM — Lang Badge & 3-column bottom bar
   ============================================================ */
.rz-footer-lang-badge {
  display: inline-flex;
  align-items: center;
  gap: var(--sp-2);
  font-size: 11px;
  font-weight: var(--fw-semibold);
  color: rgba(255,255,255,.4);
  background: rgba(255,255,255,.05);
  border: 1px solid rgba(255,255,255,.08);
  padding: 4px 12px;
  border-radius: var(--radius-full);
}
.rz-footer-bottom-center {
  display: flex;
  align-items: center;
  justify-content: center;
}

/* 3rd footer orb */
.rz-footer-orb--3 {
  width: 260px;
  height: 260px;
  top: 40%;
  left: 40%;
  transform: translate(-50%,-50%);
  background: radial-gradient(circle, rgba(233,185,73,.04) 0%, transparent 70%);
}

/* ============================================================
   50. PREMIUM FOOTER REDESIGN (rz-site-footer)
   ============================================================ */

:root {
  --footer-bg: #0E1E15;
  --footer-surface: rgba(255,255,255,0.04);
  --footer-border: rgba(255,255,255,0.07);
  --footer-text: rgba(240,235,226,0.75);
  --footer-text-bright: rgba(240,235,226,0.95);
  --footer-accent: #D3612B;
  --footer-gold: #E9B949;
}

/* Wave separator above footer */
.rz-footer-wave {
  display: block;
  line-height: 0;
  overflow: hidden;
  margin-bottom: -2px;
}
.rz-footer-wave svg {
  display: block;
  width: 100%;
  height: 60px;
}

/* Footer wrapper */
.rz-site-footer {
  background: var(--footer-bg);
  color: var(--footer-text);
  position: relative;
  overflow: hidden;
  padding-top: var(--sp-20);
  padding-bottom: var(--sp-8);
}

/* Top gold accent line */
.rz-footer-accent-line {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 3px;
  background: linear-gradient(90deg, transparent, var(--footer-gold) 30%, var(--footer-accent) 70%, transparent);
}

/* Decorative background orbs */
.rz-footer-orb {
  position: absolute;
  border-radius: 50%;
  pointer-events: none;
}
.rz-footer-orb--1 {
  width: 500px;
  height: 500px;
  top: -200px;
  right: -150px;
  background: radial-gradient(circle, rgba(45,106,79,0.12) 0%, transparent 70%);
}
.rz-footer-orb--2 {
  width: 380px;
  height: 380px;
  bottom: -100px;
  left: -100px;
  background: radial-gradient(circle, rgba(211,97,43,0.08) 0%, transparent 70%);
}

/* ── Footer Grid ────────────────────────────────────── */
.rz-footer-grid {
  display: grid;
  grid-template-columns: 1.4fr 1fr 1fr 1.2fr;
  gap: var(--sp-12);
  padding-bottom: var(--sp-16);
  border-bottom: 1px solid var(--footer-border);
}

/* ── Brand Column ───────────────────────────────────── */
.rz-footer-logo {
  display: inline-block;
  margin-bottom: var(--sp-5);
}
.rz-footer-logo-text {
  font-family: var(--ff-serif);
  font-size: var(--fs-2xl);
  font-weight: var(--fw-black);
  color: #fff;
  letter-spacing: -0.02em;
}
.rz-footer-logo-text span {
  color: var(--footer-gold);
}
.rz-footer-tagline {
  font-size: var(--fs-sm);
  line-height: var(--lh-loose);
  color: var(--footer-text);
  margin-bottom: var(--sp-6);
  max-width: 280px;
}

/* Trust badges */
.rz-footer-trust {
  display: flex;
  flex-wrap: wrap;
  gap: var(--sp-2);
  margin-bottom: var(--sp-6);
}
.rz-trust-badge {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  padding: 4px 10px;
  background: var(--footer-surface);
  border: 1px solid var(--footer-border);
  border-radius: var(--radius-full);
  font-size: 11px;
  color: var(--footer-text);
  font-weight: var(--fw-medium);
}

/* Social buttons */
.rz-footer-socials {
  display: flex;
  gap: var(--sp-2);
  flex-wrap: wrap;
}
.rz-social-btn {
  width: 40px;
  height: 40px;
  border-radius: 50%;
  background: var(--footer-surface);
  border: 1px solid var(--footer-border);
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--footer-text);
  transition: all var(--transition-fast);
}
.rz-social-btn:hover {
  background: var(--footer-accent);
  border-color: var(--footer-accent);
  color: #fff;
  transform: translateY(-3px);
  box-shadow: 0 8px 20px rgba(211,97,43,0.35);
}

/* ── Nav Columns ────────────────────────────────────── */
.rz-footer-col-title {
  display: flex;
  align-items: center;
  gap: var(--sp-2);
  font-family: var(--ff-sans);
  font-size: 10px;
  font-weight: var(--fw-bold);
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--footer-text-bright);
  margin-bottom: var(--sp-5);
}
.rz-footer-col-dot {
  width: 6px;
  height: 6px;
  border-radius: 50%;
  flex-shrink: 0;
}
.rz-footer-nav {
  display: flex;
  flex-direction: column;
  gap: var(--sp-3);
}
.rz-fnav-link {
  display: flex;
  align-items: center;
  gap: var(--sp-2);
  font-size: var(--fs-sm);
  color: var(--footer-text);
  transition: all var(--transition-fast);
  position: relative;
  padding-left: 0;
}
.rz-fnav-icon {
  font-size: 14px;
  flex-shrink: 0;
  opacity: 0.8;
}
.rz-fnav-link:hover {
  color: var(--footer-text-bright);
  transform: translateX(4px);
}
.rz-fnav-link--all {
  margin-top: var(--sp-2);
  color: var(--footer-gold);
  font-weight: var(--fw-semibold);
}
.rz-fnav-link--all:hover {
  color: #fff;
}

/* ── Newsletter Column ──────────────────────────────── */
.rz-footer-nl-desc {
  font-size: var(--fs-sm);
  line-height: var(--lh-loose);
  color: var(--footer-text);
  margin-bottom: var(--sp-5);
}
.rz-footer-nl-field {
  display: flex;
  align-items: stretch;
  background: rgba(255,255,255,0.07);
  border: 1px solid var(--footer-border);
  border-radius: var(--radius-lg);
  overflow: hidden;
  transition: border-color var(--transition-fast);
  margin-bottom: var(--sp-3);
}
.rz-footer-nl-field:focus-within {
  border-color: var(--footer-gold);
  box-shadow: 0 0 0 3px rgba(233,185,73,0.15);
}
.rz-footer-nl-input {
  flex: 1;
  background: transparent;
  border: none;
  padding: 12px 16px;
  font-size: var(--fs-sm);
  color: #fff;
  outline: none;
}
.rz-footer-nl-input::placeholder {
  color: rgba(255,255,255,0.35);
}
.rz-footer-nl-btn {
  padding: 12px 16px;
  background: var(--footer-accent);
  border: none;
  color: #fff;
  cursor: pointer;
  transition: background var(--transition-fast);
  display: flex;
  align-items: center;
  justify-content: center;
}
.rz-footer-nl-btn:hover {
  background: #b84e23;
}
.rz-footer-nl-disclaimer {
  font-size: 11px;
  color: rgba(255,255,255,0.35);
  line-height: var(--lh-snug);
}
.rz-footer-nl-disclaimer a {
  color: rgba(255,255,255,0.5);
  text-decoration: underline;
}

/* Stats in footer newsletter column */
.rz-footer-stats {
  display: flex;
  align-items: center;
  gap: var(--sp-5);
  margin-top: var(--sp-6);
  padding-top: var(--sp-5);
  border-top: 1px solid var(--footer-border);
}
.rz-fstat {
  text-align: center;
}
.rz-fstat-num {
  display: block;
  font-family: var(--ff-serif);
  font-size: var(--fs-lg);
  font-weight: var(--fw-bold);
  color: var(--footer-gold);
  line-height: 1;
  margin-bottom: 2px;
}
.rz-fstat-lbl {
  font-size: 10px;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: rgba(255,255,255,0.35);
}
.rz-fstat-divider {
  width: 1px;
  height: 32px;
  background: var(--footer-border);
}

/* ── Footer Bottom Bar ──────────────────────────────── */
.rz-footer-bottom {
  display: flex;
  align-items: center;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: var(--sp-4);
  padding-top: var(--sp-6);
}
.rz-footer-bottom-left {
  display: flex;
  flex-direction: column;
  gap: 4px;
}
.rz-footer-copy {
  font-size: var(--fs-xs);
  color: rgba(255,255,255,0.35);
}
.rz-footer-copy a {
  color: rgba(255,255,255,0.5);
  transition: color var(--transition-fast);
}
.rz-footer-copy a:hover {
  color: var(--footer-gold);
}
.rz-footer-made {
  font-size: 11px;
  color: rgba(255,255,255,0.25);
}
.rz-footer-bottom-right {
  display: flex;
  gap: var(--sp-5);
  flex-wrap: wrap;
}
.rz-footer-bottom-right a {
  font-size: var(--fs-xs);
  color: rgba(255,255,255,0.35);
  transition: color var(--transition-fast);
}
.rz-footer-bottom-right a:hover {
  color: var(--footer-text-bright);
}

/* ── Back to top button ─────────────────────────────── */
.rz-back-top {
  position: fixed;
  bottom: var(--sp-6);
  right: var(--sp-6);
  width: 48px;
  height: 48px;
  border-radius: 50%;
  background: var(--clr-primary);
  color: #fff;
  border: none;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  opacity: 0;
  transform: translateY(20px);
  transition: all var(--transition-base);
  z-index: 900;
  box-shadow: 0 4px 20px rgba(45,106,79,0.4);
}
.rz-back-top.visible {
  opacity: 1;
  transform: translateY(0);
}
.rz-back-top:hover {
  background: var(--clr-primary-dark);
  transform: translateY(-3px);
  box-shadow: 0 8px 28px rgba(45,106,79,0.5);
}

/* ── Footer Responsive ──────────────────────────────── */
@media (max-width: 1100px) {
  .rz-footer-grid {
    grid-template-columns: 1fr 1fr;
    gap: var(--sp-10);
  }
}
@media (max-width: 640px) {
  .rz-footer-grid {
    grid-template-columns: 1fr;
    gap: var(--sp-8);
  }
  .rz-footer-bottom {
    flex-direction: column;
    align-items: flex-start;
  }
}


/* ============================================================
   51. ARCHIVE / CATEGORY PAGE REDESIGN (rzcat-*)
   ============================================================ */

/* ── Category Hero ──────────────────────────────────── */
.rzcat-hero {
  position: relative;
  overflow: hidden;
  padding: var(--sp-20) 0 0;
  min-height: 380px;
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
}
.rzcat-hero-bg {
  position: absolute;
  inset: 0;
  background:
    radial-gradient(ellipse at 80% 50%, color-mix(in srgb, var(--cat-accent, #2D6A4F) 25%, transparent) 0%, transparent 60%),
    radial-gradient(circle at 20% 30%, rgba(255,255,255,0.03) 0%, transparent 50%),
    linear-gradient(135deg, var(--cat-clr, #1B4332) 0%, #0d1f18 100%);
  z-index: 0;
}

/* Decorative blobs */
.rzcat-hero-blob {
  position: absolute;
  border-radius: 50%;
  pointer-events: none;
  z-index: 1;
  opacity: 0.12;
  filter: blur(60px);
}
.rzcat-hero-blob--1 {
  width: 480px;
  height: 480px;
  top: -120px;
  right: -80px;
  background: var(--clr-secondary);
}
.rzcat-hero-blob--2 {
  width: 300px;
  height: 300px;
  bottom: 20px;
  left: -60px;
  background: var(--clr-primary);
}

.rzcat-hero-inner {
  position: relative;
  z-index: 2;
  padding-bottom: var(--sp-16);
}

/* Breadcrumbs in hero */
.rzcat-breadcrumbs {
  margin-bottom: var(--sp-6);
}
.rzcat-breadcrumbs .breadcrumbs,
.rzcat-breadcrumbs ol,
.rzcat-breadcrumbs span,
.rzcat-breadcrumbs a {
  color: rgba(255,255,255,0.55) !important;
  font-size: var(--fs-xs);
}
.rzcat-breadcrumbs a:hover {
  color: rgba(255,255,255,0.9) !important;
}

/* Hero content */
.rzcat-hero-content {
  max-width: 680px;
}
.rzcat-hero-icon {
  font-size: 3.8rem;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  margin-bottom: var(--sp-5);
  background: rgba(255, 255, 255, 0.07);
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
  border: 1px solid rgba(255,255,255,0.15);
  width: 82px;
  height: 82px;
  border-radius: 24px;
  box-shadow: 0 10px 30px rgba(0,0,0,0.15);
  animation: rz-icon-float 4s ease-in-out infinite alternate;
}
@keyframes rz-icon-float {
  0% { transform: translateY(0) rotate(-3deg); }
  100% { transform: translateY(-8px) rotate(3deg); }
}

.rzcat-hero-title {
  font-family: var(--ff-serif);
  font-size: clamp(2.2rem, 5vw, 3.8rem);
  font-weight: var(--fw-black);
  color: #fff;
  line-height: var(--lh-tight);
  margin-bottom: var(--sp-4);
  letter-spacing: -0.02em;
}
.rzcat-hero-desc {
  font-size: var(--fs-md);
  color: rgba(255,255,255,0.75);
  max-width: 560px;
  line-height: var(--lh-loose);
  margin-bottom: var(--sp-8);
}

/* Hero stats row */
.rzcat-hero-stats {
  display: flex;
  align-items: center;
  gap: var(--sp-5);
  flex-wrap: wrap;
}
.rzcat-stat {
  display: flex;
  flex-direction: column;
  gap: 2px;
}
.rzcat-stat-num {
  font-family: var(--ff-serif);
  font-size: var(--fs-xl);
  font-weight: var(--fw-black);
  color: #fff;
  line-height: 1;
}
.rzcat-stat-lbl {
  font-size: var(--fs-xs);
  color: rgba(255,255,255,0.5);
  text-transform: uppercase;
  letter-spacing: 0.08em;
}
.rzcat-stat-sep {
  width: 1px;
  height: 36px;
  background: rgba(255,255,255,0.15);
}

/* Wave at bottom of hero */
.rzcat-hero-wave {
  display: block;
  line-height: 0;
  position: relative;
  z-index: 2;
}
.rzcat-hero-wave svg {
  display: block;
  width: 100%;
  height: 56px;
}

/* ── Sticky Filters Bar ─────────────────────────────── */
.rzcat-filters-wrap {
  background: rgba(253, 251, 247, 0.85);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  border-bottom: 1px solid rgba(231, 221, 208, 0.6);
  padding: var(--sp-3.5) 0;
  position: sticky;
  top: 80px;
  z-index: 100;
  box-shadow: 0 4px 30px rgba(0,0,0,0.02);
  transition: all 0.3s ease;
}
html.dark-mode .rzcat-filters-wrap {
  background: rgba(13, 17, 23, 0.85);
  border-bottom-color: rgba(48, 54, 61, 0.6);
  box-shadow: 0 4px 30px rgba(0,0,0,0.3);
}
.rzcat-filters-row {
  display: flex;
  align-items: center;
  gap: var(--sp-4);
  flex-wrap: wrap;
}
.rzcat-filter-pills {
  display: flex;
  gap: var(--sp-2);
  flex-wrap: wrap;
}
.rzcat-pill {
  display: inline-flex;
  align-items: center;
  gap: var(--sp-1.5);
  padding: var(--sp-2) var(--sp-4.5);
  border-radius: var(--radius-full);
  border: 1px solid var(--clr-border);
  background: var(--clr-soft);
  color: var(--clr-text-muted);
  font-size: var(--fs-sm);
  font-weight: var(--fw-semibold);
  cursor: pointer;
  transition: all 0.3s cubic-bezier(0.16, 1, 0.3, 1);
  font-family: var(--ff-sans);
}
.rzcat-pill:hover {
  border-color: var(--clr-primary);
  color: var(--clr-primary);
  background: rgba(53, 94, 59, 0.08);
  transform: translateY(-2px);
}
html.dark-mode .rzcat-pill:hover {
  color: var(--clr-primary-light);
  border-color: var(--clr-primary-light);
  background: rgba(96, 134, 102, 0.12);
}
.rzcat-pill.active {
  background: var(--clr-primary);
  border-color: var(--clr-primary);
  color: #fff;
  transform: translateY(-2px);
  box-shadow: 0 6px 16px rgba(53, 94, 59, 0.3);
}
html.dark-mode .rzcat-pill.active {
  background: var(--clr-primary-light);
  border-color: var(--clr-primary-light);
  box-shadow: 0 6px 16px rgba(96, 134, 102, 0.4);
}

.rzcat-filters-divider {
  width: 1px;
  height: 24px;
  background: var(--clr-border);
  margin: 0 var(--sp-1);
}

/* Sort select */
.rzcat-sort-wrap {
  position: relative;
  display: flex;
  align-items: center;
}
.rzcat-sort-select {
  appearance: none;
  padding: 8px 36px 8px 14px;
  border: 1.5px solid var(--clr-border);
  border-radius: var(--radius-full);
  font-size: var(--fs-sm);
  font-weight: var(--fw-medium);
  color: var(--clr-text);
  background: transparent;
  cursor: pointer;
  transition: border-color var(--transition-fast);
  font-family: var(--ff-sans);
}
.rzcat-sort-select:focus {
  outline: none;
  border-color: var(--clr-primary);
}
.rzcat-sort-icon {
  position: absolute;
  right: 12px;
  pointer-events: none;
  color: var(--clr-text-muted);
}

/* Count badge */
.rzcat-count-badge {
  margin-left: auto;
  font-size: var(--fs-sm);
  color: var(--clr-text-muted);
  white-space: nowrap;
}
.rzcat-count-badge strong {
  color: var(--clr-primary);
  font-weight: var(--fw-bold);
}

/* ── Main Layout ────────────────────────────────────── */
.rzcat-layout {
  display: grid;
  grid-template-columns: 1fr 300px;
  gap: var(--sp-10);
}
.rzcat-recipe-item {
  transition: transform var(--transition-fast);
}

/* ── Pagination ─────────────────────────────────────── */
.rzcat-pagination {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: var(--sp-2);
  margin-top: var(--sp-12);
  flex-wrap: wrap;
}
.rzcat-page-btn {
  min-width: 44px;
  height: 44px;
  padding: 0 var(--sp-3);
  border-radius: var(--radius-md);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--sp-1);
  font-weight: var(--fw-semibold);
  font-size: var(--fs-sm);
  border: 1.5px solid var(--clr-border);
  color: var(--clr-text-muted);
  background: var(--clr-surface);
  transition: all var(--transition-fast);
}
.rzcat-page-btn:hover {
  border-color: var(--clr-primary);
  color: var(--clr-primary);
}
.rzcat-page-btn.active {
  background: var(--clr-primary);
  border-color: var(--clr-primary);
  color: #fff;
  box-shadow: 0 4px 12px rgba(45,106,79,0.3);
}
.rzcat-page-btn.dots {
  border: none;
  cursor: default;
  background: transparent;
}
.rzcat-page-btn--prev,
.rzcat-page-btn--next {
  gap: var(--sp-2);
  padding: 0 var(--sp-4);
  font-weight: var(--fw-semibold);
}

/* ── Empty state ────────────────────────────────────── */
.rzcat-empty-state {
  text-align: center;
  padding: var(--sp-20) 0;
}
.rzcat-empty-icon {
  font-size: 4rem;
  margin-bottom: var(--sp-4);
  display: block;
}

/* ── SEO Guide Section ──────────────────────────────── */
.rzcat-guide {
  margin-top: var(--sp-16);
  padding-top: var(--sp-12);
  border-top: 2px dashed var(--clr-border);
}

/* Guide Header */
.rzcat-guide-header {
  margin-bottom: var(--sp-10);
}
.rzcat-guide-eyebrow {
  display: inline-flex;
  align-items: center;
  gap: var(--sp-2);
  font-size: var(--fs-xs);
  font-weight: var(--fw-bold);
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--clr-primary);
  margin-bottom: var(--sp-3);
}
.rzcat-guide-dot {
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: currentColor;
  display: inline-block;
}
.rzcat-guide-title {
  font-family: var(--ff-serif);
  font-size: clamp(1.6rem, 3vw, 2.4rem);
  font-weight: var(--fw-bold);
  color: var(--clr-text);
  margin-bottom: var(--sp-4);
  line-height: var(--lh-tight);
}
.rzcat-guide-intro {
  font-size: var(--fs-md);
  color: var(--clr-text-muted);
  line-height: var(--lh-loose);
  max-width: 600px;
}

/* Guide Cards Grid */
.rzcat-guide-cards {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--sp-6);
  margin-bottom: var(--sp-12);
}
.rzcat-guide-card {
  padding: var(--sp-8);
  border-radius: var(--radius-2xl, 24px);
  background: var(--clr-surface);
  border: 1px solid var(--clr-border);
  transition: all 0.4s cubic-bezier(0.16, 1, 0.3, 1);
  position: relative;
  overflow: hidden;
  box-shadow: 0 4px 15px rgba(0,0,0,0.01);
}
.rzcat-guide-card::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 4px;
}
.rzcat-guide-card--primary::before { background: var(--clr-primary); }
.rzcat-guide-card--secondary::before { background: var(--clr-secondary); }
.rzcat-guide-card--tertiary::before { background: var(--footer-gold); }

.rzcat-guide-card:hover {
  transform: translateY(-6px);
  box-shadow: 0 12px 30px rgba(43, 37, 32, 0.06);
  border-color: rgba(211, 97, 53, 0.3);
}
html.dark-mode .rzcat-guide-card:hover {
  box-shadow: 0 12px 30px rgba(0,0,0,0.3);
  border-color: rgba(96, 134, 102, 0.3);
}
.rzcat-guide-card-icon {
  font-size: 2.2rem;
  margin-bottom: var(--sp-4);
  display: block;
}
.rzcat-guide-card h3 {
  font-size: var(--fs-base);
  font-weight: var(--fw-bold);
  margin-bottom: var(--sp-3);
  color: var(--clr-text);
}
.rzcat-guide-card p {
  font-size: var(--fs-sm);
  color: var(--clr-text-muted);
  line-height: var(--lh-normal);
  margin: 0;
}

/* Rich Text + Tips */
.rzcat-guide-richtext {
  margin-bottom: var(--sp-10);
}
.rzcat-guide-richtext h3 {
  font-family: var(--ff-serif);
  font-size: var(--fs-xl);
  margin-bottom: var(--sp-4);
  color: var(--clr-text);
}
.rzcat-guide-richtext p {
  font-size: var(--fs-base);
  color: var(--clr-text-muted);
  line-height: var(--lh-loose);
  margin-bottom: var(--sp-5);
}
.rzcat-tips-list {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: var(--sp-4);
}
.rzcat-tips-list li {
  display: flex;
  gap: var(--sp-3);
  align-items: flex-start;
  font-size: var(--fs-sm);
  color: var(--clr-text-muted);
  line-height: var(--lh-normal);
}
.rzcat-tip-icon {
  width: 24px;
  height: 24px;
  border-radius: 50%;
  background: linear-gradient(135deg, var(--clr-primary), var(--clr-primary-light));
  color: #fff;
  font-size: 11px;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  margin-top: 1px;
  font-weight: var(--fw-bold);
  box-shadow: 0 3px 8px rgba(53, 94, 59, 0.2);
}

/* Internal Link Hub */
.rzcat-link-hub {
  margin-bottom: var(--sp-10);
}
.rzcat-link-hub-inner {
  background: linear-gradient(135deg, var(--clr-soft) 0%, var(--clr-bg) 100%);
  border: 1px solid var(--clr-border);
  border-radius: var(--radius-2xl);
  padding: var(--sp-8);
  text-align: center;
}
.rzcat-link-hub-title {
  font-family: var(--ff-serif);
  font-size: var(--fs-xl);
  font-weight: var(--fw-bold);
  color: var(--clr-text);
  margin-bottom: var(--sp-6);
}
.rzcat-link-hub-pills {
  display: flex;
  justify-content: center;
  flex-wrap: wrap;
  gap: var(--sp-3);
}
.rzcat-hub-pill {
  display: inline-flex;
  align-items: center;
  gap: var(--sp-2);
  padding: var(--sp-2) var(--sp-5);
  background: var(--clr-surface);
  border: 1.5px solid var(--clr-border);
  border-radius: var(--radius-full);
  font-size: var(--fs-sm);
  color: var(--clr-text-muted);
  font-weight: var(--fw-medium);
  transition: all var(--transition-fast);
}
.rzcat-hub-pill:hover {
  background: var(--clr-primary);
  border-color: var(--clr-primary);
  color: #fff;
  transform: translateY(-2px);
  box-shadow: 0 6px 16px rgba(45,106,79,0.25);
}

/* ── FAQ Accordion ──────────────────────────────────── */
.rzcat-faq {
  margin-bottom: var(--sp-12);
}
.rzcat-faq-title {
  font-family: var(--ff-serif);
  font-size: var(--fs-2xl);
  font-weight: var(--fw-bold);
  color: var(--clr-text);
  margin-bottom: var(--sp-6);
}
.rzcat-faq-list {
  display: flex;
  flex-direction: column;
  gap: var(--sp-3);
}
.rzcat-faq-item {
  background: var(--clr-surface);
  border: 1px solid var(--clr-border);
  border-radius: var(--radius-xl);
  overflow: hidden;
  transition: box-shadow var(--transition-fast);
}
.rzcat-faq-item:has(.rzcat-faq-q[aria-expanded="true"]) {
  box-shadow: var(--shadow-md);
  border-color: var(--clr-primary);
}
.rzcat-faq-q {
  width: 100%;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--sp-4);
  padding: var(--sp-5) var(--sp-6);
  background: transparent;
  border: none;
  text-align: left;
  font-family: var(--ff-sans);
  font-size: var(--fs-base);
  font-weight: var(--fw-semibold);
  color: var(--clr-text);
  cursor: pointer;
  transition: color var(--transition-fast);
}
.rzcat-faq-q:hover {
  color: var(--clr-primary);
}
.rzcat-faq-toggle {
  flex-shrink: 0;
  color: var(--clr-text-muted);
  transition: transform var(--transition-fast);
}
.rzcat-faq-q[aria-expanded="true"] .rzcat-faq-toggle {
  transform: rotate(180deg);
  color: var(--clr-primary);
}
.rzcat-faq-a {
  max-height: 0;
  overflow: hidden;
  transition: max-height 0.35s ease;
}
.rzcat-faq-q[aria-expanded="true"] ~ .rzcat-faq-a {
  max-height: 300px;
}
.rzcat-faq-a-inner {
  padding: 0 var(--sp-6) var(--sp-5);
  font-size: var(--fs-sm);
  color: var(--clr-text-muted);
  line-height: var(--lh-loose);
}

/* ── Newsletter CTA Banner ──────────────────────────── */
.rzcat-nl-cta {
  display: flex;
  align-items: center;
  gap: var(--sp-6);
  background: linear-gradient(135deg, var(--clr-primary-dark) 0%, var(--clr-primary) 100%);
  color: #fff;
  padding: var(--sp-8);
  border-radius: var(--radius-2xl);
  flex-wrap: wrap;
  margin-top: var(--sp-4);
}
.rzcat-nl-cta-icon {
  font-size: 3rem;
  flex-shrink: 0;
  animation: rz-icon-float 5s ease-in-out infinite alternate;
}
.rzcat-nl-cta-body {
  flex: 1;
  min-width: 200px;
}
.rzcat-nl-cta-body h3 {
  font-size: var(--fs-xl);
  font-weight: var(--fw-bold);
  margin-bottom: var(--sp-2);
  color: #fff;
}
.rzcat-nl-cta-body p {
  color: rgba(255,255,255,0.75);
  font-size: var(--fs-sm);
  margin: 0;
}

/* ── Archive Responsive ─────────────────────────────── */
@media (max-width: 992px) {
  .rzcat-layout {
    grid-template-columns: 1fr;
  }
  #archive-sidebar {
    display: none;
  }
  .rzcat-guide-cards {
    grid-template-columns: repeat(2, 1fr);
  }
  .rzcat-hero-title {
    font-size: clamp(1.8rem, 5vw, 2.8rem);
  }
}
@media (max-width: 640px) {
  .rzcat-guide-cards {
    grid-template-columns: 1fr;
  }
  .rzcat-filters-row {
    gap: var(--sp-2);
  }
  .rzcat-filter-pills {
    gap: var(--sp-1);
  }
  .rzcat-count-badge {
    display: none;
  }
  .rzcat-nl-cta {
    flex-direction: column;
    text-align: center;
  }
}

/* ============================================================
   PINTEREST MEGA SECTION — Premium Redesign
   ============================================================ */
.pinterest-mega-section {
  position: relative;
  padding: var(--sp-20) 0;
  background: linear-gradient(140deg, #B24C24 0%, #D36135 40%, #E5A93C 75%, #C8652B 100%);
  overflow: hidden;
  margin-block: var(--sp-8);
  border-radius: 32px;
  isolation: isolate;
}
.pmeg-blob {
  position: absolute;
  border-radius: 50%;
  filter: blur(80px);
  opacity: 0.35;
  animation: blobFloat 8s ease-in-out infinite alternate;
  pointer-events: none;
}
.pmeg-blob--1 { width:500px;height:500px;background:rgba(255,255,255,0.18);top:-150px;right:-100px;animation-delay:0s; }
.pmeg-blob--2 { width:350px;height:350px;background:rgba(255,200,100,0.25);bottom:-100px;left:10%;animation-delay:2.5s; }
.pmeg-blob--3 { width:250px;height:250px;background:rgba(255,255,255,0.15);top:50%;left:40%;transform:translate(-50%,-50%);animation-delay:5s; }
@keyframes blobFloat {
  0%   { transform: translate(0,0) scale(1); }
  100% { transform: translate(30px,-40px) scale(1.15); }
}
.pmeg-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--sp-16);
  align-items: center;
}
.pmeg-content { color:#fff; position:relative; z-index:2; }
.pmeg-eyebrow {
  display: inline-flex;
  align-items: center;
  gap: var(--sp-2);
  background: rgba(255,255,255,0.18);
  backdrop-filter: blur(8px);
  border: 1px solid rgba(255,255,255,0.3);
  color: #fff;
  font-size: var(--fs-xs);
  font-weight: var(--fw-bold);
  letter-spacing: 0.12em;
  text-transform: uppercase;
  padding: var(--sp-2) var(--sp-5);
  border-radius: var(--radius-full);
  margin-bottom: var(--sp-6);
}
.pmeg-title {
  font-family: var(--ff-serif);
  font-size: clamp(2.4rem, 4vw, 3.6rem);
  font-weight: var(--fw-black);
  line-height: 1.05;
  color: #fff;
  margin-bottom: var(--sp-5);
  text-shadow: 0 3px 12px rgba(43,37,32,0.2);
}
.pmeg-title-accent {
  display: block;
  background: linear-gradient(90deg, #fff 0%, rgba(255,230,150,0.95) 100%);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}
.pmeg-desc {
  font-size: var(--fs-lg);
  line-height: 1.75;
  color: rgba(255,255,255,0.92);
  margin-bottom: var(--sp-8);
}
.pmeg-features { list-style:none;padding:0;margin:0 0 var(--sp-8);display:flex;flex-direction:column;gap:var(--sp-3); }
.pmeg-features li { display:flex;align-items:center;gap:var(--sp-3);font-size:var(--fs-base);color:rgba(255,255,255,0.9);font-weight:var(--fw-medium); }
.pmeg-feat-icon { width:32px;height:32px;background:rgba(255,255,255,0.18);border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:1rem;flex-shrink:0; }
.pmeg-cta-group { display:flex;align-items:center;gap:var(--sp-6);flex-wrap:wrap; }
.pmeg-btn--primary {
  display: inline-flex;
  align-items: center;
  gap: var(--sp-3);
  background: #fff;
  color: #C0392B;
  font-weight: var(--fw-black);
  font-size: var(--fs-base);
  padding: var(--sp-4) var(--sp-8);
  border-radius: var(--radius-full);
  text-transform: uppercase;
  letter-spacing: 0.06em;
  box-shadow: 0 12px 30px rgba(43,37,32,0.2);
  transition: all 0.35s cubic-bezier(0.175,0.885,0.32,1.275);
  text-decoration: none;
  white-space: nowrap;
}
.pmeg-btn--primary:hover { transform:translateY(-4px) scale(1.04);box-shadow:0 20px 40px rgba(43,37,32,0.3);color:#8B2220; }
.pmeg-followers { display:flex;align-items:center;gap:var(--sp-3); }
.pmeg-avatars { display:flex; }
.pmeg-av { width:32px;height:32px;border-radius:50%;border:2px solid #fff;display:flex;align-items:center;justify-content:center;font-size:0.7rem;font-weight:var(--fw-bold);color:#fff;margin-right:-8px; }
.pmeg-avatars .pmeg-av:last-child { margin-right:0; }
.pmeg-followers-text { font-size:var(--fs-sm);color:rgba(255,255,255,0.9);font-weight:var(--fw-bold);margin-left:var(--sp-4); }

.pmeg-mosaic { position:relative;display:grid;grid-template-columns:1fr 1fr;gap:var(--sp-4);z-index:2; }
.pmeg-pin { border-radius:16px;overflow:hidden;transition:transform 0.4s cubic-bezier(0.175,0.885,0.32,1.275); }
.pmeg-pin--1 { transform:rotate(-4deg) translateY(10px); }
.pmeg-pin--2 { transform:rotate(3deg) translateY(-15px); }
.pmeg-pin--3 { transform:rotate(-2deg) translateY(20px); }
.pmeg-pin--4 { transform:rotate(4deg) translateY(-8px); }
.pmeg-pin:hover { transform:rotate(0deg) translateY(-10px) scale(1.06) !important; z-index:10; }
.pmeg-pin-inner {
  position:relative;border-radius:16px;overflow:hidden;
  box-shadow:0 20px 45px rgba(43,37,32,0.35);
  border:4px solid rgba(255,255,255,0.7);
  transition:box-shadow 0.4s ease;
}
.pmeg-pin:hover .pmeg-pin-inner { box-shadow:0 30px 60px rgba(43,37,32,0.45); }
.pmeg-pin-inner img { width:100%;height:200px;object-fit:cover;display:block;transition:transform 0.6s ease; }
.pmeg-pin:hover .pmeg-pin-inner img { transform:scale(1.08); }
.pmeg-pin-overlay {
  position:absolute;bottom:0;left:0;right:0;
  background:linear-gradient(to top,rgba(43,37,32,0.85) 0%,transparent 100%);
  padding:var(--sp-3);display:flex;justify-content:space-between;align-items:flex-end;
  opacity:0;transform:translateY(6px);transition:all 0.3s ease;
}
.pmeg-pin:hover .pmeg-pin-overlay { opacity:1;transform:translateY(0); }
.pmeg-pin-tag { font-size:0.65rem;font-weight:var(--fw-bold);color:#fff;background:rgba(255,255,255,0.2);padding:2px 8px;border-radius:20px;backdrop-filter:blur(4px); }
.pmeg-pin-likes { font-size:0.65rem;color:rgba(255,255,255,0.9);font-weight:var(--fw-bold); }
.pmeg-pin-badge { position:absolute;top:10px;right:10px;width:28px;height:28px;background:#E60023;border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;box-shadow:0 4px 12px rgba(230,0,35,0.4); }

.pmeg-float-card {
  position:absolute;bottom:-20px;left:-24px;
  background:rgba(253,251,247,0.97);
  backdrop-filter:blur(16px);
  border:1px solid rgba(255,255,255,0.6);
  border-radius:20px;
  padding:var(--sp-3) var(--sp-5);
  display:flex;align-items:center;gap:var(--sp-3);
  box-shadow:0 15px 35px rgba(43,37,32,0.2);
  z-index:20;
  animation:floatBob 4s ease-in-out infinite;
}
@keyframes floatBob { 0%,100%{transform:translateY(0);}50%{transform:translateY(-8px);} }
.pmeg-float-icon { font-size:1.5rem; }
.pmeg-float-info { display:flex;flex-direction:column; }
.pmeg-float-info strong { font-size:var(--fs-sm);font-weight:var(--fw-black);color:var(--clr-text); }
.pmeg-float-info span { font-size:var(--fs-xs);color:var(--clr-text-light); }

@media (max-width:992px) {
  .pmeg-grid { grid-template-columns:1fr;gap:var(--sp-12); }
  .pmeg-mosaic { max-width:480px;margin:0 auto; }
  .pmeg-float-card { bottom:auto;top:-20px; }
}
@media (max-width:600px) {
  .pinterest-mega-section { padding:var(--sp-12) 0;border-radius:20px; }
  .pmeg-pin--1,.pmeg-pin--2,.pmeg-pin--3,.pmeg-pin--4 { transform:none !important; }
}

/* ============================================================
   NEWSLETTER MEGA SECTION — Premium Redesign
   ============================================================ */
.nl-mega-section {
  position:relative;
  padding:var(--sp-20) 0;
  background:var(--clr-primary-dark);
  overflow:hidden;
  margin-block:var(--sp-8);
  border-radius:32px;
  isolation:isolate;
}
.nl-bg-orb { position:absolute;border-radius:50%;pointer-events:none; }
.nl-bg-orb--1 { width:600px;height:600px;background:radial-gradient(circle,rgba(211,97,53,0.22) 0%,transparent 70%);top:-200px;right:-150px; }
.nl-bg-orb--2 { width:400px;height:400px;background:radial-gradient(circle,rgba(229,169,60,0.18) 0%,transparent 70%);bottom:-100px;left:-80px; }
.nl-bg-pattern {
  position:absolute;inset:0;pointer-events:none;
  background-image:repeating-linear-gradient(45deg,rgba(255,255,255,0.03) 0px,rgba(255,255,255,0.03) 1px,transparent 1px,transparent 40px);
}
.nl-mega-grid { display:grid;grid-template-columns:1fr 1fr;gap:var(--sp-16);align-items:center;position:relative;z-index:2; }
.nl-mega-visual { color:#fff; }
.nl-icon-ring { position:relative;width:90px;height:90px;margin-bottom:var(--sp-8); }
.nl-icon-pulse {
  position:absolute;inset:-8px;border-radius:50%;
  border:2px solid rgba(229,169,60,0.4);
  animation:nlPulse 2.5s ease-in-out infinite;
}
@keyframes nlPulse { 0%,100%{transform:scale(1);opacity:0.6;}50%{transform:scale(1.25);opacity:0;} }
.nl-icon-core {
  width:90px;height:90px;border-radius:50%;
  background:linear-gradient(135deg,#D36135 0%,#E5A93C 100%);
  display:flex;align-items:center;justify-content:center;
  font-size:2.2rem;
  box-shadow:0 20px 40px rgba(211,97,53,0.4);
  position:relative;
}
.nl-mega-title {
  font-family:var(--ff-serif);
  font-size:clamp(1.8rem,3.5vw,2.8rem);
  font-weight:var(--fw-black);
  color:#fff;line-height:1.15;
  margin-bottom:var(--sp-4);
  text-shadow:0 2px 10px rgba(43,37,32,0.2);
}
.nl-mega-subtitle { font-size:var(--fs-lg);color:rgba(250,246,240,0.82);line-height:1.75;margin-bottom:var(--sp-8); }
.nl-benefits { list-style:none;padding:0;margin:0 0 var(--sp-8);display:flex;flex-direction:column;gap:var(--sp-5); }
.nl-benefit { display:flex;align-items:flex-start;gap:var(--sp-4); }
.nl-benefit-icon {
  width:44px;height:44px;flex-shrink:0;
  background:rgba(255,255,255,0.1);
  border:1px solid rgba(255,255,255,0.15);
  border-radius:12px;
  display:flex;align-items:center;justify-content:center;
  font-size:1.3rem;
}
.nl-benefit div { display:flex;flex-direction:column;gap:2px; }
.nl-benefit strong { font-size:var(--fs-base);color:#fff;font-weight:var(--fw-bold); }
.nl-benefit span { font-size:var(--fs-sm);color:rgba(250,246,240,0.7); }
.nl-social-proof { display:flex;align-items:center;gap:var(--sp-4);padding-top:var(--sp-6);border-top:1px solid rgba(255,255,255,0.1); }
.nl-proof-avatars { display:flex; }
.nl-av { width:36px;height:36px;border-radius:50%;border:2px solid rgba(255,255,255,0.7);display:flex;align-items:center;justify-content:center;font-size:0.72rem;font-weight:var(--fw-black);color:#fff;margin-right:-10px; }
.nl-proof-avatars .nl-av:last-child { margin-right:0; }
.nl-proof-text { display:flex;flex-direction:column;margin-left:var(--sp-4); }
.nl-proof-text strong { font-size:var(--fs-base);color:var(--clr-secondary);font-weight:var(--fw-black); }
.nl-proof-text span { font-size:var(--fs-sm);color:rgba(250,246,240,0.75); }

.nl-mega-card {
  background:rgba(253,251,247,0.97);
  border-radius:28px;
  padding:var(--sp-8) var(--sp-10);
  box-shadow:0 30px 70px rgba(43,37,32,0.25),0 0 0 1px rgba(255,255,255,0.4) inset;
  position:relative;overflow:hidden;
}
.nl-mega-card::before {
  content:'';position:absolute;top:0;left:0;right:0;height:4px;
  background:linear-gradient(90deg,#D36135 0%,#E5A93C 50%,#E76F51 100%);
}
.nl-card-header { margin-bottom:var(--sp-7); }
.nl-card-badge {
  display:inline-block;
  background:linear-gradient(135deg,#FFF3CD,#FFE08A);
  color:#7C5200;
  font-size:var(--fs-xs);font-weight:var(--fw-black);
  padding:var(--sp-1) var(--sp-4);border-radius:var(--radius-full);
  letter-spacing:0.06em;margin-bottom:var(--sp-3);
}
.nl-card-title { font-family:var(--ff-serif);font-size:var(--fs-2xl);font-weight:var(--fw-black);color:var(--clr-text);margin-bottom:var(--sp-2); }
.nl-card-sub { font-size:var(--fs-sm);color:var(--clr-text-light); }
.nl-mega-form { display:flex;flex-direction:column;gap:var(--sp-5); }
.nl-field { display:flex;flex-direction:column;gap:var(--sp-2); }
.nl-label { display:flex;align-items:center;gap:var(--sp-2);font-size:var(--fs-sm);font-weight:var(--fw-bold);color:var(--clr-text); }
.nl-label-icon { font-size:1rem; }
.nl-required { color:var(--clr-secondary);font-weight:var(--fw-black);margin-left:2px; }
.nl-input {
  width:100%;padding:14px var(--sp-5);border-radius:var(--radius-xl);
  border:2px solid var(--clr-border);background:var(--clr-bg);
  color:var(--clr-text);font-size:var(--fs-base);
  transition:border-color 0.25s,box-shadow 0.25s,background 0.25s;height:54px;
}
.nl-input::placeholder { color:var(--clr-text-muted); }
.nl-input:focus { outline:none;border-color:var(--clr-secondary);background:#fff;box-shadow:0 0 0 4px rgba(211,97,53,0.15); }
.nl-submit-btn {
  display:flex;align-items:center;justify-content:center;gap:var(--sp-3);
  background:linear-gradient(135deg,#D36135 0%,#E76F51 100%);
  color:#fff;font-weight:var(--fw-black);font-size:var(--fs-md);
  text-transform:uppercase;letter-spacing:0.08em;
  padding:0 var(--sp-8);height:54px;border-radius:var(--radius-xl);
  border:none;cursor:pointer;
  box-shadow:0 10px 25px rgba(211,97,53,0.35);
  transition:all 0.3s cubic-bezier(0.175,0.885,0.32,1.275);
  width:100%;position:relative;overflow:hidden;
}
.nl-submit-btn::after { content:'';position:absolute;inset:0;background:linear-gradient(135deg,rgba(255,255,255,0.15) 0%,transparent 100%);opacity:0;transition:opacity 0.3s; }
.nl-submit-btn:hover { transform:translateY(-3px);box-shadow:0 18px 35px rgba(211,97,53,0.45); }
.nl-submit-btn:hover::after { opacity:1; }
.nl-submit-icon { font-size:1.2rem; }
.nl-arrow { transition:transform 0.3s ease;flex-shrink:0; }
.nl-submit-btn:hover .nl-arrow { transform:translateX(5px); }
.nl-message { padding:var(--sp-4);border-radius:var(--radius-lg);background:rgba(34,197,94,0.12);color:var(--clr-primary-dark);font-weight:var(--fw-bold);text-align:center;border:1px solid rgba(34,197,94,0.3); }
.nl-card-disclaimer { font-size:var(--fs-xs);color:var(--clr-text-muted);text-align:center;line-height:1.6;margin-top:var(--sp-2); }
.nl-card-disclaimer a { color:var(--clr-secondary);text-decoration:underline; }
.nl-trust-badges { display:flex;justify-content:center;flex-wrap:wrap;gap:var(--sp-3);margin-top:var(--sp-6);padding-top:var(--sp-6);border-top:1px solid var(--clr-border); }
.nl-trust-badge { font-size:var(--fs-xs);color:var(--clr-text-light);font-weight:var(--fw-medium);background:rgba(43,37,32,0.05);padding:var(--sp-1) var(--sp-3);border-radius:var(--radius-full);border:1px solid var(--clr-border); }

@media (max-width:992px) {
  .nl-mega-grid { grid-template-columns:1fr;gap:var(--sp-10); }
  .nl-mega-visual { text-align:center; }
  .nl-icon-ring { margin:0 auto var(--sp-8); }
  .nl-benefits { max-width:480px;margin:0 auto var(--sp-8); }
  .nl-benefit { text-align:left; }
  .nl-social-proof { justify-content:center; }
}
@media (max-width:600px) {
  .nl-mega-section { padding:var(--sp-12) 0;border-radius:20px; }
  .nl-mega-card { padding:var(--sp-6) var(--sp-5); }
  .nl-trust-badges { gap:var(--sp-2); }
}
.dark-mode .nl-mega-card { background:rgba(43,37,32,0.95);box-shadow:0 30px 70px rgba(0,0,0,0.4),0 0 0 1px rgba(255,255,255,0.06) inset; }
.dark-mode .nl-input { background:rgba(255,255,255,0.06);border-color:rgba(255,255,255,0.12);color:var(--clr-text); }
.dark-mode .nl-input:focus { background:rgba(255,255,255,0.1); }
.dark-mode .nl-card-title { color:var(--clr-text); }
.dark-mode .nl-trust-badge { background:rgba(255,255,255,0.06);border-color:rgba(255,255,255,0.1);color:rgba(250,246,240,0.65); }

/* ============================================================
   SKIP-TO-CONTENT — Accessibility & SEO
   ============================================================ */
.skip-to-content {
  position: absolute;
  top: -100px;
  left: var(--sp-4);
  z-index: 99999;
  background: var(--clr-primary-dark);
  color: #fff;
  font-weight: var(--fw-bold);
  font-size: var(--fs-sm);
  padding: var(--sp-3) var(--sp-6);
  border-radius: 0 0 var(--radius-lg) var(--radius-lg);
  text-decoration: none;
  transition: top 0.2s ease;
  box-shadow: 0 4px 16px rgba(0,0,0,0.25);
  outline: 3px solid var(--clr-secondary);
  outline-offset: 2px;
}
.skip-to-content:focus {
  top: 0;
}
#main-content:focus {
  outline: none;
}

/* ============================================================
   LECKIVO SPECIFIC VISUAL IDENTITY REDESIGN
   ============================================================ */
.site-logo-text .logo-name span {
  color: var(--clr-secondary);
}
.site-logo-icon {
  border: 2px solid var(--clr-primary);
  padding: 2px;
  background: #fff;
}
.btn--primary,
.rz-hero-card__btn,
.btn-primary {
  background: linear-gradient(135deg, var(--clr-primary) 0%, #3a8562 100%) !important;
  border: none;
  border-radius: var(--radius-xl) !important;
  box-shadow: 0 8px 20px rgba(45,106,79,0.25) !important;
  transition: transform 0.2s ease, box-shadow 0.2s ease !important;
}
.btn--primary:hover,
.rz-hero-card__btn:hover {
  transform: translateY(-2px);
  box-shadow: 0 12px 28px rgba(45,106,79,0.35) !important;
}
.rz-cat-card {
  border-radius: var(--radius-xl) !important;
  overflow: hidden;
}
.rz-cat-card:hover {
  transform: translateY(-6px) scale(1.02);
  box-shadow: 0 16px 36px rgba(45,106,79,0.25);
}
.rz-recipe-card {
  border-radius: var(--radius-xl) !important;
  box-shadow: var(--shadow-sm);
  border: 1px solid var(--clr-border);
}
.rz-recipe-card:hover {
  box-shadow: var(--shadow-lg);
  transform: translateY(-4px);
}
.rz-rotating-badge text {
  fill: var(--clr-primary) !important;
  font-weight: 700;
  letter-spacing: 0.04em;
}
.dark-mode .site-logo-icon {
  background: var(--clr-primary-dark);
}
.dark-mode .site-logo-text .logo-name span {
  color: var(--clr-secondary);
}
.dark-mode .rz-rotating-badge text {
  fill: #fff !important;
}

/* ============================================================
   LECKIVO HOMEPAGE REDESIGN (Hero, Carousel, Testimonials, Newsletter)
   ============================================================ */

/* 3D Stacked Card Hover Glow & Tilt Effects */
.rz-hero__card-stack {
  position: relative;
  display: flex;
  justify-content: center;
  align-items: center;
}
.rz-hero-card {
  position: relative;
  z-index: 10;
  transition: transform 0.4s cubic-bezier(0.165, 0.84, 0.44, 1), box-shadow 0.4s ease;
  transform: perspective(1000px) rotateX(2deg) rotateY(-2deg) translateZ(0);
}
.rz-hero-card:hover {
  transform: perspective(1000px) rotateX(0) rotateY(0) translateZ(10px) translateY(-5px);
  box-shadow: 0 30px 60px rgba(0,0,0,0.15), 0 0 40px rgba(74,124,89,0.2);
}
.rz-stack-layer {
  position: absolute;
  width: 95%;
  height: 95%;
  background: var(--clr-surface);
  border-radius: var(--radius-xl);
  border: 1px solid var(--clr-border);
  box-shadow: var(--shadow-sm);
  transition: transform 0.4s ease, opacity 0.4s ease;
}
.rz-stack-layer--1 {
  z-index: 5;
  transform: translateY(12px) scale(0.96) rotate(1deg);
  opacity: 0.9;
}
.rz-stack-layer--2 {
  z-index: 2;
  transform: translateY(24px) scale(0.92) rotate(-1.5deg);
  opacity: 0.7;
}
.rz-hero-card:hover ~ .rz-stack-layer--1 {
  transform: translateY(16px) scale(0.97) rotate(2deg);
}
.rz-hero-card:hover ~ .rz-stack-layer--2 {
  transform: translateY(32px) scale(0.94) rotate(-3deg);
}

/* Seasonal Carousel Section */
.rz-seasonal-carousel-sec {
  background: linear-gradient(180deg, var(--clr-surface) 0%, var(--clr-soft) 100%);
  padding: var(--sp-16) 0;
  overflow: hidden;
}
.rz-carousel-arrows {
  display: flex;
  gap: var(--sp-2);
}
.rz-arrow-btn {
  background: var(--clr-surface);
  border: 1px solid var(--clr-border);
  color: var(--clr-text);
  width: 44px;
  height: 44px;
  border-radius: var(--radius-full);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  font-weight: bold;
  box-shadow: var(--shadow-sm);
  transition: all 0.2s ease;
}
.rz-arrow-btn:hover {
  background: var(--clr-primary);
  color: #fff;
  border-color: var(--clr-primary);
  transform: scale(1.05);
}
.rz-seasonal-rail {
  display: flex;
  gap: var(--sp-6);
  overflow-x: auto;
  scroll-snap-type: x mandatory;
  padding: var(--sp-4) 0 var(--sp-8);
  margin: 0 calc(-1 * var(--sp-4));
  padding-left: var(--sp-4);
  scrollbar-width: none; /* Firefox */
}
.rz-seasonal-rail::-webkit-scrollbar {
  display: none; /* Chrome/Safari */
}
.rz-seasonal-card {
  flex: 0 0 280px;
  scroll-snap-align: start;
  background: var(--clr-surface);
  border-radius: var(--radius-xl);
  border: 1px solid var(--clr-border);
  box-shadow: var(--shadow-sm);
  overflow: hidden;
  transition: all 0.3s ease;
}
.rz-seasonal-card:hover {
  transform: translateY(-6px);
  box-shadow: var(--shadow-lg), 0 0 25px rgba(211,97,53,0.1);
  border-color: rgba(211,97,53,0.2);
}
.rz-seasonal-card__img-wrap {
  position: relative;
  height: 180px;
  overflow: hidden;
}
.rz-seasonal-card__img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 0.5s ease;
}
.rz-seasonal-card:hover .rz-seasonal-card__img {
  transform: scale(1.08);
}
.rz-seasonal-card__badge {
  position: absolute;
  top: var(--sp-3);
  left: var(--sp-3);
  background: rgba(211,97,53,0.9);
  color: #fff;
  font-size: 11px;
  font-weight: bold;
  padding: 4px 10px;
  border-radius: var(--radius-full);
  backdrop-filter: blur(4px);
}
.rz-seasonal-card__body {
  padding: var(--sp-5);
}
.rz-seasonal-card__meta {
  font-size: 12px;
  color: var(--clr-text-muted);
  display: flex;
  gap: var(--sp-2);
  margin-bottom: var(--sp-2);
}
.rz-seasonal-card__title {
  font-size: 16px;
  font-weight: var(--fw-bold);
  line-height: 1.4;
  margin: 0 0 var(--sp-4);
  height: 48px;
  overflow: hidden;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
}
.rz-seasonal-card__title a {
  color: var(--clr-text);
  text-decoration: none;
}
.rz-seasonal-card__title a:hover {
  color: var(--clr-primary);
}
.rz-seasonal-card__link {
  font-size: 13px;
  font-weight: var(--fw-bold);
  color: var(--clr-primary);
  text-decoration: none;
}
.rz-seasonal-card__link:hover {
  color: var(--clr-secondary);
}

/* User Testimonials Grid */
.rz-testimonials-section {
  background: var(--clr-soft);
  padding: var(--sp-16) 0;
}
.rz-testimonials-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
  gap: var(--sp-6);
  margin-top: var(--sp-8);
}
.rz-testimonial-card {
  background: var(--clr-surface);
  border: 1px solid var(--clr-border);
  border-radius: var(--radius-xl);
  padding: var(--sp-6);
  box-shadow: var(--shadow-sm);
  transition: all 0.3s ease;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
}
.rz-testimonial-card:hover {
  transform: translateY(-4px);
  box-shadow: var(--shadow-md);
  border-color: rgba(74,124,89,0.2);
}
.rz-testimonial-card__header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: var(--sp-4);
}
.rz-testimonial-card__verified {
  font-size: 11px;
  color: #4A7C59;
  font-weight: bold;
  background: rgba(74,124,89,0.1);
  padding: 2px 8px;
  border-radius: var(--radius-full);
}
.rz-testimonial-card__title {
  font-size: 16px;
  font-weight: var(--fw-bold);
  margin: 0 0 var(--sp-2);
  color: var(--clr-text);
}
.rz-testimonial-card__text {
  font-size: 14px;
  line-height: 1.6;
  color: var(--clr-text-muted);
  margin-bottom: var(--sp-6);
  flex-grow: 1;
}
.rz-testimonial-card__author {
  display: flex;
  align-items: center;
  gap: var(--sp-3);
  border-top: 1px solid var(--clr-border);
  padding-top: var(--sp-4);
}
.rz-testimonial-card__avatar {
  width: 40px;
  height: 40px;
  border-radius: var(--radius-full);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  color: #fff;
  font-weight: bold;
  font-size: 16px;
}
.rz-testimonial-card__author div {
  display: flex;
  flex-direction: column;
  line-height: 1.3;
}
.rz-testimonial-card__author strong {
  font-size: 14px;
  color: var(--clr-text);
}
.rz-testimonial-card__author span {
  font-size: 11px;
  color: var(--clr-text-muted);
}
