/* =========================================================
   My Cuisine — Design Tokens
   Source: design.md
   ========================================================= */

:root {
  /* Primitive colors */
  --color-core-deep-green: #1F3D36;
  --color-core-cream: #F5F1E8;
  --color-core-accent-orange: #F25C2A;
  --color-core-accent-yellow: #F7C948;
  --color-core-white: #FFFFFF;
  --color-core-ink: #111111;

  --color-food-avocado: #A3B18A;
  --color-food-tomato: #E63946;
  --color-food-olive: #6B705C;
  --color-food-spice: #BC6C25;
  --color-food-basil: #2F6B4F;
  --color-food-honey: #E9B44C;
  --color-food-pistachio: #DDE7C7;
  --color-food-salmon: #F7A072;

  --color-neutral-950: #0B0B0B;
  --color-neutral-900: #111111;
  --color-neutral-800: #242424;
  --color-neutral-700: #3A3A3A;
  --color-neutral-600: #4F4F4F;
  --color-neutral-500: #6B6B6B;
  --color-neutral-400: #9A9A9A;
  --color-neutral-300: #CFCFCF;
  --color-neutral-200: #E4E1DA;
  --color-neutral-100: #F7F7F7;
  --color-neutral-50: #FBFAF6;

  --color-success: #4CAF50;
  --color-warning: #FFB703;
  --color-error: #E63946;
  --color-info: #2196F3;

  /* Semantic colors */
  --color-background-page: var(--color-core-cream);
  --color-background-surface: var(--color-core-white);
  --color-background-surface-soft: var(--color-neutral-50);
  --color-background-brand: var(--color-core-deep-green);
  --color-background-brand-soft: #E8F0EA;
  --color-background-accent: var(--color-core-accent-orange);
  --color-background-warning-soft: #FFF4D1;
  --color-background-error-soft: #FDECEC;
  --color-background-success-soft: #EAF6EC;
  --color-background-overlay: rgba(17, 17, 17, 0.56);

  --color-text-primary: var(--color-neutral-900);
  --color-text-heading: var(--color-core-deep-green);
  --color-text-secondary: var(--color-neutral-600);
  --color-text-muted: var(--color-neutral-500);
  --color-text-disabled: var(--color-neutral-400);
  --color-text-inverse: var(--color-core-white);
  --color-text-accent: var(--color-core-accent-orange);
  --color-text-success: var(--color-food-basil);
  --color-text-error: var(--color-error);

  --color-border-default: var(--color-neutral-200);
  --color-border-strong: var(--color-neutral-300);
  --color-border-brand: var(--color-core-deep-green);
  --color-border-accent: var(--color-core-accent-orange);
  --color-border-error: var(--color-error);
  --color-border-success: var(--color-success);

  /* Typography */
  --font-family-display: "Playfair Display", "Libre Baskerville", Georgia, serif;
  --font-family-body: Inter, "Satoshi", "Helvetica Neue", Arial, sans-serif;
  --font-family-mono: "IBM Plex Mono", "SFMono-Regular", monospace;

  --font-weight-light: 300;
  --font-weight-regular: 400;
  --font-weight-medium: 500;
  --font-weight-semibold: 600;
  --font-weight-bold: 700;
  --font-weight-extrabold: 800;
  --font-weight-black: 900;

  --font-display-xl-size: 80px;
  --font-display-xl-line: 88px;
  --font-display-lg-size: 64px;
  --font-display-lg-line: 70px;
  --font-display-md-size: 56px;
  --font-display-md-line: 62px;
  --font-heading-h1-size: 48px;
  --font-heading-h1-line: 56px;
  --font-heading-h2-size: 40px;
  --font-heading-h2-line: 48px;
  --font-heading-h3-size: 32px;
  --font-heading-h3-line: 40px;
  --font-heading-h4-size: 24px;
  --font-heading-h4-line: 32px;
  --font-heading-h5-size: 20px;
  --font-heading-h5-line: 28px;
  --font-heading-h6-size: 16px;
  --font-heading-h6-line: 24px;
  --font-body-lg-size: 18px;
  --font-body-lg-line: 28px;
  --font-body-md-size: 16px;
  --font-body-md-line: 24px;
  --font-body-sm-size: 14px;
  --font-body-sm-line: 20px;
  --font-caption-md-size: 12px;
  --font-caption-md-line: 16px;
  --font-caption-sm-size: 11px;
  --font-caption-sm-line: 14px;

  --letter-spacing-tight: -0.04em;
  --letter-spacing-heading: -0.02em;
  --letter-spacing-body: 0;
  --letter-spacing-label: 0.04em;
  --letter-spacing-button: 0.01em;

  /* Spacing */
  --space-0: 0px;
  --space-1: 4px;
  --space-2: 8px;
  --space-3: 12px;
  --space-4: 16px;
  --space-5: 20px;
  --space-6: 24px;
  --space-8: 32px;
  --space-10: 40px;
  --space-12: 48px;
  --space-16: 64px;
  --space-20: 80px;
  --space-24: 96px;
  --space-32: 128px;

  /* Layout */
  --layout-container-sm: 640px;
  --layout-container-md: 960px;
  --layout-container-lg: 1200px;
  --layout-container-xl: 1440px;
  --grid-gutter-desktop: 24px;
  --grid-gutter-tablet: 20px;
  --grid-gutter-mobile: 16px;

  /* Radius */
  --radius-none: 0;
  --radius-xs: 4px;
  --radius-sm: 8px;
  --radius-md: 12px;
  --radius-lg: 16px;
  --radius-xl: 24px;
  --radius-2xl: 32px;
  --radius-full: 999px;

  /* Elevation */
  --shadow-none: none;
  --shadow-xs: 0 1px 2px rgba(17, 17, 17, 0.04);
  --shadow-sm: 0 4px 12px rgba(17, 17, 17, 0.06);
  --shadow-md: 0 10px 28px rgba(17, 17, 17, 0.10);
  --shadow-lg: 0 20px 48px rgba(17, 17, 17, 0.14);
  --shadow-brand: 0 14px 32px rgba(31, 61, 54, 0.18);
  --shadow-accent: 0 14px 32px rgba(242, 92, 42, 0.20);

  /* Motion */
  --motion-duration-instant: 80ms;
  --motion-duration-fast: 150ms;
  --motion-duration-normal: 220ms;
  --motion-duration-slow: 320ms;
  --motion-duration-slower: 480ms;
  --motion-easing-standard: cubic-bezier(0.2, 0, 0, 1);
  --motion-easing-enter: cubic-bezier(0, 0, 0.2, 1);
  --motion-easing-exit: cubic-bezier(0.4, 0, 1, 1);
  --motion-easing-bounce-soft: cubic-bezier(0.34, 1.56, 0.64, 1);

  --z-dropdown: 100;
  --z-sticky: 200;
  --z-drawer: 400;
  --z-modal: 600;
  --z-toast: 800;
  --z-tooltip: 1000;

  /* Component tokens */
  --button-primary-background: var(--color-core-deep-green);
  --button-primary-background-hover: #28584D;
  --button-primary-background-active: #17302A;
  --button-primary-text: var(--color-text-inverse);
  --button-primary-radius: var(--radius-md);
  --button-accent-background: var(--color-core-accent-orange);
  --button-accent-background-hover: #D94716;
  --button-yellow-background: var(--color-core-accent-yellow);
  --button-yellow-text: var(--color-core-deep-green);
  --button-secondary-border: var(--color-core-deep-green);
  --button-secondary-text: var(--color-core-deep-green);

  --card-background-default: var(--color-background-surface);
  --card-background-soft: var(--color-background-surface-soft);
  --card-border-default: var(--color-border-default);
  --card-radius-default: var(--radius-lg);
  --card-radius-featured: var(--radius-xl);
  --card-shadow-default: var(--shadow-sm);
  --card-shadow-hover: var(--shadow-md);
  --card-padding-compact: var(--space-3);
  --card-padding-default: var(--space-4);
  --card-padding-featured: var(--space-6);
  --card-image-radius: var(--radius-md);

  --nav-header-background: rgba(255, 255, 255, 0.88);
  --nav-header-border: var(--color-border-default);
  --nav-link-color-default: var(--color-text-primary);
  --nav-link-color-hover: var(--color-text-accent);
  --nav-link-color-active: var(--color-text-heading);

  --input-height-md: 44px;
  --input-background-default: var(--color-background-surface);
  --input-border-default: var(--color-border-default);
  --input-border-focus: var(--color-border-brand);
  --input-radius: 10px;
  --chip-background-default: var(--color-neutral-100);
  --chip-background-hover: var(--color-background-brand-soft);
  --chip-background-active: var(--color-core-deep-green);

  /* Legacy aliases used by existing theme CSS */
  --color-primary: var(--color-core-deep-green);
  --color-primary-hover: #28584D;
  --color-primary-light: var(--color-background-brand-soft);
  --color-primary-shadow: rgba(31, 61, 54, 0.18);
  --color-secondary: var(--color-core-accent-orange);
  --color-secondary-hover: #D94716;
  --color-secondary-light: rgba(242, 92, 42, 0.10);
  --color-bg: var(--color-background-page);
  --color-bg-alt: var(--color-background-surface-soft);
  --color-bg-hero: linear-gradient(135deg, var(--color-background-surface-soft) 0%, var(--color-background-brand-soft) 100%);
  --color-bg-newsletter: linear-gradient(135deg, var(--color-core-deep-green) 0%, var(--color-food-basil) 100%);
  --color-bg-sky: var(--color-background-brand-soft);
  --color-surface: var(--color-background-surface);
  --color-border: var(--color-border-default);
  --color-border-light: var(--color-neutral-100);
  --color-easy: var(--color-food-basil);
  --color-easy-bg: var(--color-background-success-soft);
  --color-medium: var(--color-food-spice);
  --color-medium-bg: var(--color-background-warning-soft);
  --color-hard: var(--color-error);
  --color-hard-bg: var(--color-background-error-soft);
  --color-accent-green: var(--color-core-deep-green);
  --shadow-card: var(--card-shadow-default);
  --shadow-card-hover: var(--card-shadow-hover);
  --shadow-button: var(--shadow-brand);
  --shadow-elevated: var(--shadow-lg);
  --radius-card: var(--card-radius-default);
  --radius-image: var(--card-image-radius);
  --radius-input: var(--input-radius);
  --radius-button: var(--button-primary-radius);
  --radius-pill: var(--radius-full);
  --container-max: var(--layout-container-lg);
  --container-pad: var(--space-12);
  --container-pad-mobile: var(--space-4);
  --t-fast: var(--motion-duration-fast) var(--motion-easing-standard);
  --t-base: var(--motion-duration-normal) var(--motion-easing-standard);
  --t-slow: var(--motion-duration-slow) var(--motion-easing-standard);
  --fl-primary: var(--color-text-primary);
  --fl-bg: var(--color-bg);
  --fl-surface: var(--color-bg-alt);
  --fl-surface-sky: var(--color-bg-sky);
  --fl-accent: var(--color-primary);
  --fl-accent-red: var(--color-secondary);
  --fl-accent-green: var(--color-accent-green);
  --fl-text-muted: var(--color-text-secondary);
  --fl-border-subtle: var(--color-border);
  --fl-radius-card: var(--radius-card);
  --fl-radius-button: var(--radius-button);
  --fl-shadow-rest: var(--shadow-card);
  --fl-shadow-hover: var(--shadow-card-hover);
}

html {
  background: var(--color-background-page);
  color: var(--color-text-primary);
  font-family: var(--font-family-body);
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}

body {
  background: var(--color-background-page) !important;
  color: var(--color-text-primary);
  font-family: var(--font-family-body);
  font-size: var(--font-body-md-size);
  line-height: 1.5;
}

h1,
h2,
h3,
.wp-block-heading,
.fl-hero__title,
.fl-section-head h2,
.fl-blog-hero h1,
.recipe-hero-title,
.recipe-section-title,
.fl-blog-section-title {
  color: var(--color-text-heading);
  font-family: var(--font-family-display) !important;
  letter-spacing: var(--letter-spacing-heading);
}

p,
li,
.wp-block-post-content,
.wp-block-post-excerpt,
.fl-hero__lead,
.fl-section-sub,
.recipe-hero-excerpt {
  color: var(--color-text-secondary);
}

a {
  color: var(--color-text-accent);
  text-decoration-thickness: 1px;
  text-underline-offset: 0.18em;
}

a:hover {
  color: var(--color-text-heading);
}

:focus-visible {
  outline: 2px solid var(--color-border-brand);
  outline-offset: 3px;
}

.text-accent {
  color: var(--color-text-accent);
}

.site-header {
  background: rgba(245, 241, 232, 0.92) !important;
  border-bottom-color: var(--nav-header-border);
  backdrop-filter: blur(16px);
  z-index: var(--z-sticky);
}

.site-header__inner {
  min-height: 46px;
  gap: clamp(18px, 2.4vw, 34px) !important;
}

.mc-site-logo {
  display: inline-flex;
  align-items: flex-end;
  gap: 2px;
  flex: 0 0 auto;
  color: var(--mc-green-900) !important;
  font-family: var(--mc-font-heading);
  font-size: clamp(24px, 2.35vw, 32px);
  font-weight: 800;
  line-height: 0.95;
  letter-spacing: -0.03em;
  text-decoration: none;
}

.mc-site-logo--image {
  align-items: center;
  width: clamp(116px, 12vw, 158px);
  height: 54px;
}

.mc-site-logo__img {
  width: 100%;
  height: 100%;
  object-fit: contain;
  object-position: left center;
}

.mc-site-logo__leaf {
  align-self: flex-start;
  margin-right: -4px;
  color: var(--mc-green-700);
  font-size: 16px;
  transform: translateY(-8px) rotate(-16deg);
}

.mc-logo-dot {
  color: var(--mc-orange-500);
}

.primary-nav a {
  color: var(--nav-link-color-default) !important;
}

.primary-nav a:hover,
.primary-nav a[aria-current="page"] {
  color: var(--mc-green-900) !important;
}

.primary-nav a[aria-current="page"]::after,
.primary-nav a:hover::after {
  background: var(--mc-green-900);
}

.header-actions {
  display: flex;
  align-items: center;
  gap: 14px;
  flex: 0 0 auto;
}

.header-actions .header-search {
  width: 260px;
  max-width: 28vw;
  height: 44px;
  min-height: 44px;
  padding: 0 14px 0 18px;
  border: 1px solid var(--mc-border) !important;
  border-radius: 999px;
  background: #FFFFFF !important;
}

.header-actions .header-search input {
  font-size: 12px;
}

.header-search__icon {
  flex: 0 0 20px;
  width: 20px;
  height: 20px;
}

.header-icon-btn {
  position: relative;
  display: grid;
  place-items: center;
  width: 38px;
  height: 38px;
  border-radius: 999px;
  color: var(--mc-green-900);
  font-size: 22px;
  text-decoration: none;
}

.header-icon-btn img {
  width: 22px;
  height: 22px;
}

.header-icon-btn:hover {
  background: var(--mc-cream-soft);
  color: var(--mc-green-900);
}

.header-cart-badge {
  position: absolute;
  top: 3px;
  right: 2px;
  display: grid;
  place-items: center;
  min-width: 16px;
  height: 16px;
  padding: 0 4px;
  border-radius: 999px;
  background: var(--mc-orange-500);
  color: #FFFFFF;
  font-size: 10px;
  font-weight: 800;
  line-height: 1;
}

.header-avatar {
  display: block;
  width: 42px;
  height: 42px;
  border: 2px solid #FFFFFF;
  border-radius: 999px;
  overflow: hidden;
  background: var(--mc-cream-soft);
  box-shadow: var(--shadow-sm);
}

.header-avatar img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

@media (max-width: 1120px) {
  .header-actions .header-search {
    width: 220px;
  }

  .primary-nav {
    gap: 18px;
  }
}

@media (max-width: 960px) {
  .primary-nav,
  .header-icon-btn,
  .header-avatar {
    display: none;
  }

  .header-actions {
    flex: 1 1 auto;
    justify-content: flex-end;
  }

  .header-actions .header-search {
    width: min(100%, 270px);
    max-width: 100%;
  }
}

@media (max-width: 520px) {
  .site-header {
    padding-right: 16px !important;
    padding-left: 16px !important;
  }

  .site-header__inner {
    gap: 12px !important;
  }

  .mc-site-logo {
    font-size: 18px;
  }

  .mc-site-logo--image {
    width: 106px;
    height: 42px;
  }

  .mc-site-logo__leaf {
    font-size: 11px;
    transform: translateY(-5px) rotate(-16deg);
  }

  .header-actions .header-search {
    min-width: 0;
    height: 44px;
    padding: 0 12px;
  }

  .header-actions .header-search input {
    font-size: 12px;
  }
}

.header-search,
.newsletter-form,
input[type="text"],
input[type="email"],
input[type="search"],
input[type="url"],
input[type="tel"],
input[type="number"],
textarea,
select,
.filter-select {
  min-height: var(--input-height-md);
  border-color: var(--input-border-default) !important;
  border-radius: var(--input-radius);
  background: var(--input-background-default) !important;
  color: var(--color-text-primary);
}

.header-search:focus-within,
input:focus,
textarea:focus,
select:focus,
.filter-select:focus {
  border-color: var(--input-border-focus) !important;
  box-shadow: 0 0 0 3px rgba(31, 61, 54, 0.12) !important;
  outline: none;
}

.wp-element-button,
.wp-block-button__link,
.fl-btn-dark,
.btn-primary,
.newsletter-form button,
.fl-shop-card__cta,
.comments-area .form-submit input,
button[type="submit"] {
  min-height: 44px;
  border: 0 !important;
  border-radius: var(--button-primary-radius) !important;
  background: var(--button-primary-background) !important;
  color: var(--button-primary-text) !important;
  box-shadow: var(--shadow-brand);
  font-family: var(--font-family-body) !important;
  font-weight: var(--font-weight-semibold) !important;
  letter-spacing: var(--letter-spacing-button) !important;
  transition:
    transform var(--t-fast),
    box-shadow var(--t-fast),
    background var(--t-fast);
}

.wp-element-button:hover,
.wp-block-button__link:hover,
.fl-btn-dark:hover,
.btn-primary:hover,
.newsletter-form button:hover,
.fl-shop-card__cta:hover,
.comments-area .form-submit input:hover,
button[type="submit"]:hover {
  background: var(--button-primary-background-hover) !important;
  box-shadow: var(--shadow-brand);
  transform: translateY(-1px);
}

.is-style-outline .wp-block-button__link,
.btn-action,
.btn-reset,
.fl-link-btn {
  border: 1px solid var(--button-secondary-border) !important;
  background: transparent !important;
  color: var(--button-secondary-text) !important;
  box-shadow: none;
}

.is-style-outline .wp-block-button__link:hover,
.btn-action:hover,
.btn-reset:hover,
.fl-link-btn:hover {
  background: var(--color-background-brand-soft) !important;
  color: var(--color-text-heading) !important;
  border-color: var(--color-border-brand) !important;
}

.hero-pill,
.fl-blog-hero__eyebrow,
.wp-block-post-terms a,
.category-pill a,
.badge,
.fl-blog-chip {
  border-radius: var(--radius-full);
  background: var(--chip-background-default) !important;
  color: var(--color-text-secondary) !important;
}

.hero-pill,
.fl-blog-hero__eyebrow,
.wp-block-post-terms a,
.category-pill a {
  background: var(--color-background-error-soft) !important;
  color: var(--color-text-accent) !important;
}

.fl-blog-chip:hover,
.fl-blog-chip.is-active {
  background: var(--chip-background-active) !important;
  color: var(--color-text-inverse) !important;
}

.fl-hero,
.newsletter-band,
.fl-contact-page,
.fl-blog-page,
.recipe-editorial {
  background:
    radial-gradient(circle at top left, rgba(247, 201, 72, 0.16), transparent 28%),
    var(--color-background-page) !important;
}

.fl-hero {
  border: 1px solid var(--color-border-default);
  border-radius: var(--radius-2xl);
  box-shadow: var(--shadow-sm);
}

.fl-hero__title {
  font-size: clamp(2.5rem, 5vw, var(--font-display-lg-size));
  line-height: 1.08;
}

.fl-hero__title strong,
.fl-hero__title em,
.recipe-hero-title strong,
.recipe-hero-title em {
  color: var(--color-text-accent);
}

.fl-meta-pill {
  background: rgba(255, 255, 255, 0.72);
  color: var(--color-text-heading);
  border: 1px solid rgba(31, 61, 54, 0.10);
}

.fl-badge-circle {
  background: var(--color-core-deep-green);
}

.fl-badge-circle::after {
  color: var(--color-core-accent-yellow);
}

.recipe-card,
.article-card,
.author-bio-card,
.recipe-ingredients-panel,
.rating-widget,
.recipe-filters,
.nutrition-card,
.related-mini,
.fl-shop-card,
.fl-ig-card,
.fl-contact-card,
.fl-contact-form-card,
.wp-block-comments,
.wp-block-comment-template > li {
  border: 1px solid var(--card-border-default) !important;
  border-radius: var(--card-radius-default) !important;
  background: var(--card-background-default) !important;
  box-shadow: var(--card-shadow-default) !important;
}

.recipe-card,
.fl-ig-card {
  background: var(--color-background-brand-soft) !important;
}

.recipe-card:hover,
.article-card:hover,
.fl-cat-card:hover,
.related-mini:hover,
.fl-ig-card:hover {
  box-shadow: var(--card-shadow-hover) !important;
  transform: translateY(-4px);
}

.recipe-card .wp-block-post-featured-image,
.article-card .wp-block-post-featured-image,
.fl-blog-spotlight .wp-block-post-featured-image,
.recipe-hero-image,
.single-recipe-layout > .wp-block-post-featured-image.alignwide {
  background: linear-gradient(135deg, var(--color-background-brand-soft), var(--color-background-surface-soft)) !important;
  border-radius: var(--card-image-radius) !important;
}

.recipe-card .wp-block-post-featured-image img,
.article-card .wp-block-post-featured-image img,
.fl-blog-spotlight .wp-block-post-featured-image img,
.recipe-hero-image img {
  transition: transform var(--motion-duration-normal) var(--motion-easing-standard);
}

.recipe-card .wp-block-post-featured-image:hover img,
.article-card .wp-block-post-featured-image:hover img,
.fl-blog-spotlight .wp-block-post-featured-image:hover img,
.recipe-hero-image:hover img {
  transform: scale(1.04);
}

.recipe-card .wp-block-post-title a,
.article-card .wp-block-post-title a,
.fl-blog-spotlight .wp-block-post-title a {
  color: var(--color-text-heading) !important;
}

.recipe-card .wp-block-post-title a:hover,
.article-card .wp-block-post-title a:hover,
.fl-blog-spotlight .wp-block-post-title a:hover {
  color: var(--color-text-accent) !important;
}

.fl-cat--breakfast,
.cat-breakfast {
  background: var(--color-background-warning-soft) !important;
}

.fl-cat--vegan,
.cat-vegan {
  background: var(--color-background-success-soft) !important;
}

.fl-cat--meat,
.cat-meat {
  background: var(--color-background-error-soft) !important;
}

.fl-cat--dessert,
.cat-dessert {
  background: #FFF4D1 !important;
}

.fl-cat--lunch,
.cat-lunch {
  background: var(--color-food-pistachio) !important;
}

.fl-cat--chocolate,
.cat-chocolate {
  background: var(--color-background-surface-soft) !important;
}

.recipe-meta-bar {
  border-color: var(--color-border-default);
  background: var(--color-background-surface-soft);
  box-shadow: var(--shadow-sm);
}

.recipe-meta-bar .emoji,
.recipe-meta-bar-wrap .btn-action,
.ingredient-list li {
  background: var(--color-background-surface) !important;
  border-color: var(--color-border-default) !important;
}

.recipe-meta-bar-wrap .btn-favoris,
.ingredient-list input[type=checkbox]:checked,
.btn-favoris.is-favori,
.btn-favoris-card.is-favori {
  background: var(--color-background-accent) !important;
  border-color: var(--color-border-accent) !important;
  color: var(--color-text-inverse) !important;
}

.ingredient-list input[type=checkbox] {
  border-color: var(--color-border-brand);
}

.ingredient-list li:hover {
  border-color: var(--color-border-accent) !important;
}

.star-btn:hover,
.star-btn.is-active {
  color: var(--color-core-accent-yellow);
}

.star-btn:focus-visible {
  outline-color: var(--color-core-accent-yellow);
}

.badge--diet,
.fl-difficulty--easy {
  background: var(--color-background-success-soft) !important;
  color: var(--color-text-success) !important;
}

.fl-difficulty--medium {
  background: var(--color-background-warning-soft) !important;
  color: var(--color-food-spice) !important;
}

.fl-difficulty--hard {
  background: var(--color-background-error-soft) !important;
  color: var(--color-text-error) !important;
}

.site-footer,
.healthy-card {
  background: var(--color-background-brand) !important;
  color: var(--color-text-inverse) !important;
}

.site-footer *,
.healthy-card * {
  color: inherit;
}

.site-footer a:hover {
  color: var(--color-core-accent-yellow) !important;
}

.newsletter-band {
  background:
    radial-gradient(circle at 18% 12%, rgba(247, 201, 72, 0.24), transparent 26%),
    linear-gradient(135deg, var(--color-core-deep-green), var(--color-food-basil)) !important;
  color: var(--color-text-inverse);
}

.newsletter-band h2,
.newsletter-band p {
  color: var(--color-text-inverse) !important;
}

.newsletter-form {
  background: var(--color-background-surface) !important;
  box-shadow: var(--shadow-lg);
}

.filter-label,
.fl-blog-chips__label,
.recipe-meta-bar dt {
  color: var(--color-text-muted);
  letter-spacing: var(--letter-spacing-label);
}

.recipe-card--skeleton .skeleton-img,
.recipe-card--skeleton .skeleton-line {
  background: linear-gradient(90deg, var(--color-neutral-100) 25%, var(--color-neutral-200) 50%, var(--color-neutral-100) 75%);
}

@media (max-width: 640px) {
  body {
    font-size: var(--font-body-md-size);
  }

  .fl-hero {
    border-radius: var(--radius-xl);
  }

  .recipe-card,
  .article-card {
    border-radius: var(--radius-lg) !important;
  }
}

@media (prefers-reduced-motion: reduce) {
  *,
  *::before,
  *::after {
    animation-duration: 0.01ms !important;
    animation-iteration-count: 1 !important;
    scroll-behavior: auto !important;
    transition-duration: 0.01ms !important;
  }
}

/* =========================================================
   MyCuisine / Foodieland premium recipe product page
   ========================================================= */

:root {
  --mc-cream-bg: #F5F1E8;
  --mc-cream-card: #FBFAF6;
  --mc-cream-soft: #E8F0EA;
  --mc-green-950: #17302A;
  --mc-green-900: #1F3D36;
  --mc-green-800: #28584D;
  --mc-green-700: #2F6B4F;
  --mc-orange-500: #F25C2A;
  --mc-orange-100: #FFE7DD;
  --mc-yellow-500: #F7C948;
  --mc-text-main: #111111;
  --mc-text-muted: #6B6B6B;
  --mc-border: rgba(31, 61, 54, 0.14);
  --mc-success: #4CAF50;
  --mc-error: #E63946;
  --mc-font-heading: "Playfair Display", "Libre Baskerville", Georgia, serif;
  --mc-font-body: Inter, "Satoshi", "Helvetica Neue", Arial, sans-serif;
  --mc-shadow-sm: 0 8px 24px rgba(6, 35, 31, 0.06);
  --mc-shadow-md: 0 18px 42px rgba(6, 35, 31, 0.10);
}

.mc-recipe-page {
  background:
    radial-gradient(circle at 0 6%, rgba(247, 201, 72, 0.10), transparent 28%),
    var(--mc-cream-bg);
  color: var(--mc-text-main);
  font-family: var(--mc-font-body);
  padding: 24px 0 72px;
}

.mc-container {
  width: min(100%, 1200px);
  margin: 0 auto;
  padding: 0 32px;
  box-sizing: border-box;
}

.mc-breadcrumb-wrap {
  margin-top: 4px;
}

.mc-breadcrumb-wrap .fl-breadcrumb {
  display: flex;
  gap: 8px;
  align-items: center;
  margin: 0;
  color: var(--mc-text-muted);
  font-size: 12px;
}

.mc-breadcrumb-wrap .fl-breadcrumb a {
  color: var(--mc-text-muted);
  text-decoration: none;
}

.mc-breadcrumb-wrap .fl-breadcrumb [aria-current="page"] {
  color: var(--mc-green-900);
  font-weight: 700;
}

.mc-recipe-hero {
  display: grid;
  grid-template-columns: minmax(0, 0.9fr) minmax(440px, 1.25fr);
  gap: clamp(42px, 5vw, 64px);
  align-items: center;
  margin: 42px 0 42px;
}

.mc-recipe-hero-content {
  min-width: 0;
}

.mc-svg-icon {
  display: block;
  width: auto;
  max-width: 100%;
  height: auto;
  flex: 0 0 auto;
}

.mc-inline-icon {
  display: inline-block;
  vertical-align: -0.15em;
}

.mc-badge-popular {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  margin-bottom: 28px;
  padding: 8px 12px;
  border-radius: 999px;
  background: var(--mc-orange-100);
  color: var(--mc-orange-500);
  font-size: 13px;
  font-weight: 800;
  line-height: 1;
}

.mc-badge-popular .mc-svg-icon {
  width: 18px;
  height: 18px;
}

.mc-recipe-title {
  max-width: 560px;
  margin: 0 0 24px;
  color: var(--mc-green-900);
  font-family: var(--mc-font-heading) !important;
  font-size: clamp(48px, 5vw, 72px);
  font-weight: 700;
  line-height: 0.98;
  letter-spacing: -0.045em;
}

.mc-recipe-intro {
  max-width: 470px;
  margin: 0 0 26px;
  color: #333333;
  font-size: 17px;
  line-height: 1.75;
}

.mc-rating-row {
  display: flex;
  align-items: center;
  gap: 10px;
  margin-bottom: 30px;
}

.mc-stars {
  display: inline-flex;
  align-items: center;
  gap: 2px;
  white-space: nowrap;
}

.mc-star-icon {
  width: 18px;
  height: 18px;
}

.mc-rating-text {
  color: var(--mc-text-muted);
  font-size: 14px;
}

.mc-recipe-meta {
  display: grid;
  grid-template-columns: repeat(4, max-content);
  gap: 24px;
  margin-bottom: 34px;
}

.mc-meta-item {
  display: flex;
  align-items: center;
  gap: 10px;
  min-width: 0;
}

.mc-meta-icon {
  display: grid;
  place-items: center;
  flex: 0 0 40px;
  width: 40px;
  height: 40px;
  border-radius: 999px;
  background: var(--mc-cream-soft);
  color: var(--mc-green-900);
  box-shadow: inset 0 0 0 1px rgba(31, 61, 54, 0.05);
}

.mc-meta-icon .mc-svg-icon {
  width: 22px;
  height: 22px;
}

.mc-meta-value {
  display: block;
  color: var(--mc-text-main);
  font-size: 14px;
  font-weight: 800;
  line-height: 1.1;
  white-space: nowrap;
}

.mc-meta-label {
  display: block;
  margin-top: 4px;
  color: var(--mc-text-muted);
  font-size: 11px;
  line-height: 1.1;
  white-space: nowrap;
}

.mc-action-row {
  display: flex;
  align-items: center;
  gap: 14px;
  flex-wrap: wrap;
}

.mc-btn-primary,
.mc-btn-secondary,
.mc-btn-light,
.mc-shopping-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  min-height: 50px;
  padding: 0 24px;
  border-radius: 10px;
  font-family: var(--mc-font-body);
  font-size: 14px;
  font-weight: 800;
  line-height: 1;
  text-decoration: none;
  cursor: pointer;
  box-sizing: border-box;
}

.mc-btn-primary {
  border: 0;
  background: var(--mc-green-900);
  color: #FFFFFF;
  box-shadow: 0 16px 28px rgba(6, 35, 31, 0.16);
}

.mc-btn-primary:hover {
  background: var(--mc-green-800);
  transform: translateY(-1px);
}

.mc-btn-secondary,
.mc-shopping-btn {
  border: 1px solid var(--mc-border);
  background: transparent;
  color: var(--mc-green-900);
}

.mc-btn-secondary:hover,
.mc-shopping-btn:hover {
  background: var(--mc-cream-soft);
}

.mc-icon-btn {
  display: grid;
  place-items: center;
  width: 46px;
  height: 46px;
  border: 1px solid var(--mc-border);
  border-radius: 999px;
  background: #FFFFFF;
  color: var(--mc-green-900);
  font-size: 15px;
  font-weight: 800;
  text-decoration: none;
}

.mc-hero-image-wrap {
  position: relative;
  min-width: 0;
  overflow: hidden;
  border-radius: 24px;
  background: var(--mc-cream-card);
  box-shadow: var(--mc-shadow-md);
}

.mc-hero-image {
  display: block;
  width: 100%;
  aspect-ratio: 1.25 / 1;
  object-fit: cover;
}

.mc-image-like {
  position: absolute;
  top: 22px;
  right: 22px;
  display: grid;
  place-items: center;
  width: 52px;
  height: 52px;
  border: 0;
  border-radius: 999px;
  background: #FFFFFF;
  color: var(--mc-green-900);
  box-shadow: 0 8px 24px rgba(0, 0, 0, 0.08);
  cursor: pointer;
}

.mc-author-card {
  position: absolute;
  right: 24px;
  bottom: 24px;
  display: flex;
  align-items: center;
  gap: 12px;
  max-width: calc(100% - 48px);
  padding: 14px 18px;
  border: 1px solid rgba(255, 255, 255, 0.72);
  border-radius: 18px;
  background: rgba(255, 255, 255, 0.94);
  box-shadow: var(--mc-shadow-md);
  backdrop-filter: blur(14px);
}

.mc-author-card img {
  width: 46px;
  height: 46px;
  border-radius: 999px;
  object-fit: cover;
}

.mc-author-label {
  display: block;
  color: var(--mc-text-muted);
  font-size: 11px;
}

.mc-author-name {
  display: block;
  color: var(--mc-green-900);
  font-size: 14px;
  font-weight: 800;
}

.mc-recipe-tabs {
  display: flex;
  gap: clamp(24px, 4.3vw, 54px);
  width: 100%;
  max-width: 100%;
  margin: 0 0 48px;
  border-bottom: 1px solid var(--mc-border);
  overflow-x: auto;
  overflow-y: hidden;
  box-sizing: border-box;
  contain: paint;
  scrollbar-width: none;
}

.mc-recipe-tabs::-webkit-scrollbar {
  display: none;
}

.mc-recipe-tabs a {
  position: relative;
  flex: 0 0 auto;
  padding: 18px 0;
  color: var(--mc-text-muted);
  font-size: 14px;
  font-weight: 800;
  text-decoration: none;
}

.mc-recipe-tabs a.is-active,
.mc-recipe-tabs a:hover {
  color: var(--mc-green-900);
}

.mc-recipe-tabs a.is-active::after {
  content: "";
  position: absolute;
  right: 0;
  bottom: -1px;
  left: 0;
  height: 2px;
  background: var(--mc-green-900);
}

.mc-recipe-main {
  display: grid;
  grid-template-columns: 240px minmax(500px, 1fr) 360px;
  gap: 32px;
  align-items: start;
}

.mc-section-title {
  margin: 0 0 24px;
  color: var(--mc-green-900);
  font-family: var(--mc-font-heading) !important;
  font-size: 32px;
  font-weight: 700;
  line-height: 1.1;
  letter-spacing: -0.025em;
}

.mc-section-headline {
  margin-bottom: 18px;
}

.mc-servings {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  margin-bottom: 28px;
  color: var(--mc-text-main);
  font-size: 13px;
  font-weight: 800;
}

.mc-stepper {
  display: inline-flex;
  align-items: center;
  height: 34px;
  overflow: hidden;
  border: 1px solid var(--mc-border);
  border-radius: 999px;
  background: #FFFFFF;
}

.mc-stepper .portions-btn {
  width: 34px;
  height: 34px;
  border: 0;
  border-radius: 0;
  background: transparent;
  color: var(--mc-green-900);
  font-size: 16px;
}

.mc-stepper .portions-count {
  display: grid;
  place-items: center;
  min-width: 36px;
  height: 34px;
  color: var(--mc-text-main);
  font-weight: 800;
}

.mc-ingredient-group {
  margin-bottom: 28px;
}

.mc-ingredient-group-title {
  margin: 0 0 14px;
  color: var(--mc-green-900);
  font-size: 14px;
  font-weight: 800;
}

.mc-ingredient-list {
  display: grid;
  gap: 14px;
  padding: 0;
  margin: 0;
  list-style: none;
}

.mc-ingredient-item {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  color: #333333;
  font-size: 14px;
  line-height: 1.45;
}

.mc-ingredient-check {
  appearance: none;
  flex: 0 0 16px;
  width: 16px;
  height: 16px;
  margin-top: 2px;
  border: 1px solid rgba(31, 61, 54, 0.35);
  border-radius: 999px;
  background: transparent;
  cursor: pointer;
}

.mc-ingredient-check:checked {
  border-color: var(--mc-green-900);
  background: radial-gradient(circle, var(--mc-green-900) 0 42%, transparent 46%);
}

.mc-ingredient-item label {
  cursor: pointer;
}

.mc-ingredient-item strong {
  margin-right: 4px;
  color: var(--mc-text-main);
  font-weight: 700;
}

.mc-ingredient-item em {
  display: block;
  margin-top: 2px;
  color: var(--mc-text-muted);
  font-style: normal;
  font-size: 12px;
}

.mc-shopping-btn {
  width: 100%;
  margin-top: 8px;
  background: #FFFFFF;
}

.mc-instructions {
  min-width: 0;
}

.mc-step-list {
  display: grid;
  gap: 26px;
  padding: 0;
  margin: 0;
  list-style: none;
}

.mc-step {
  position: relative;
  display: grid;
  grid-template-columns: 220px minmax(0, 1fr);
  gap: 24px;
  align-items: start;
}

.mc-step-number {
  position: absolute;
  top: 12px;
  left: 12px;
  z-index: 2;
  display: grid;
  place-items: center;
  width: 34px;
  height: 34px;
  border-radius: 999px;
  background: var(--mc-green-900);
  color: #FFFFFF;
  font-weight: 800;
}

.mc-step-image {
  width: 100%;
  aspect-ratio: 1.45 / 1;
  object-fit: cover;
  border-radius: 16px;
  background: var(--mc-cream-soft);
  box-shadow: var(--mc-shadow-sm);
}

.mc-step-copy {
  min-width: 0;
  padding-top: 2px;
}

.mc-step-title {
  margin: 0 0 8px;
  color: var(--mc-green-900);
  font-size: 18px;
  font-weight: 800;
  line-height: 1.25;
}

.mc-step-text,
.mc-step-text p,
.mc-post-content-fallback {
  color: #333333;
  font-size: 14px;
  line-height: 1.65;
}

.mc-step-text p {
  margin: 0 0 10px;
}

.mc-step-text p:last-child {
  margin-bottom: 0;
}

.mc-step-time {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  margin-top: 10px;
  padding: 5px 9px;
  border-radius: 999px;
  background: var(--mc-cream-soft);
  color: var(--mc-text-muted);
  font-size: 12px;
}

.mc-sidebar {
  display: grid;
  gap: 26px;
  align-self: start;
  position: sticky;
  top: 112px;
}

.mc-nutrition-card,
.mc-related-card,
.mc-faq-card,
.mc-review-card {
  border: 1px solid var(--mc-border);
  border-radius: 20px;
  background: var(--mc-cream-card);
  box-shadow: var(--mc-shadow-sm);
}

.mc-nutrition-card {
  overflow: hidden;
  padding: clamp(22px, 2.5vw, 32px);
  border-color: rgba(31, 61, 54, 0.08);
  border-radius: 30px;
  background:
    radial-gradient(circle at 14% 18%, rgba(247, 90, 36, 0.08), transparent 22%),
    linear-gradient(145deg, rgba(255, 255, 255, 0.92), rgba(255, 253, 248, 0.86));
  box-shadow:
    0 22px 52px rgba(31, 61, 54, 0.08),
    inset 0 1px 0 rgba(255, 255, 255, 0.72);
}

.mc-nutrition-head {
  display: grid;
  grid-template-columns: 88px minmax(0, 1fr);
  gap: 22px;
  align-items: center;
}

.mc-nutrition-leaf {
  display: grid;
  place-items: center;
  width: 88px;
  height: 88px;
  border-radius: 999px;
  background:
    radial-gradient(circle at 35% 28%, rgba(255, 255, 255, 0.72), transparent 32%),
    #FFEBD8;
  color: var(--mc-green-900);
}

.mc-nutrition-leaf svg {
  width: 44px;
  height: 44px;
}

.mc-nutrition-head h3 {
  margin: 0;
  color: var(--mc-green-900);
  font-family: var(--mc-font-heading);
  font-size: clamp(27px, 2.7vw, 38px);
  font-weight: 800;
  line-height: 1.03;
  letter-spacing: -0.03em;
}

.mc-nutrition-head a {
  display: inline-flex;
  align-items: center;
  gap: 12px;
  margin-top: 10px;
  color: var(--mc-orange-500);
  font-size: clamp(17px, 1.7vw, 24px);
  font-weight: 900;
  line-height: 1.1;
  text-decoration: none;
}

.mc-nutrition-head a span {
  font-size: 1.25em;
  line-height: 1;
}

.mc-nutrition-divider {
  height: 1px;
  margin: 28px 0;
  background: rgba(31, 61, 54, 0.12);
}

.mc-nutrition-grid {
  display: grid;
  grid-template-columns: 1.12fr repeat(3, 1fr);
  margin: 0;
}

.mc-nutrition-grid > div {
  min-width: 0;
}

.mc-nutrition-kcal {
  display: grid;
  align-content: center;
  padding-right: 24px;
}

.mc-nutrition-kcal dt {
  position: absolute;
  width: 1px;
  height: 1px;
  overflow: hidden;
  clip: rect(0 0 0 0);
  white-space: nowrap;
}

.mc-nutrition-kcal dd {
  margin: 0;
}

.mc-nutrition-kcal strong {
  display: block;
  color: var(--mc-green-900);
  font-family: var(--mc-font-heading);
  font-size: clamp(58px, 5.9vw, 78px);
  font-weight: 800;
  line-height: 0.92;
  letter-spacing: -0.045em;
}

.mc-nutrition-kcal span {
  display: block;
  margin-top: 8px;
  color: var(--mc-text-main);
  font-size: clamp(22px, 2.4vw, 32px);
  font-weight: 900;
  line-height: 1;
}

.mc-nutrition-macro {
  display: grid;
  justify-items: center;
  gap: 8px;
  padding: 0 18px;
  border-left: 1px solid rgba(31, 61, 54, 0.14);
  text-align: center;
}

.mc-nutrition-macro dt {
  display: grid;
  gap: 18px;
  justify-items: center;
  margin: 0;
  color: #565656;
  font-size: clamp(18px, 1.65vw, 25px);
  font-weight: 500;
  line-height: 1.1;
}

.mc-nutrition-macro dt span {
  width: 22px;
  height: 22px;
  border-radius: 999px;
  background: var(--mc-green-900);
}

.mc-nutrition-macro dd {
  margin: 0 0 16px;
  color: var(--mc-text-main);
  font-size: clamp(20px, 2.1vw, 28px);
  font-weight: 700;
  line-height: 1;
}

.mc-nutrition-macro-icon {
  display: grid;
  place-items: center;
  width: 72px;
  height: 72px;
  border-radius: 999px;
  background: #F4F0E3;
  color: var(--mc-green-900);
}

.mc-nutrition-macro-icon svg {
  width: 38px;
  height: 38px;
}

.mc-nutrition-macro.is-carbs dt span {
  background: var(--mc-orange-500);
}

.mc-nutrition-macro.is-carbs .mc-nutrition-macro-icon {
  background: #FFEBD8;
}

.mc-nutrition-macro.is-fat dt span {
  background: #9D6A32;
}

.mc-nutrition-macro.is-fat .mc-nutrition-macro-icon {
  background: #FFF1E4;
}

.mc-sidebar .mc-nutrition-card {
  padding: 24px;
  border-radius: 28px;
}

.mc-sidebar .mc-nutrition-head {
  grid-template-columns: 64px minmax(0, 1fr);
  gap: 16px;
}

.mc-sidebar .mc-nutrition-leaf {
  width: 64px;
  height: 64px;
}

.mc-sidebar .mc-nutrition-leaf svg {
  width: 34px;
  height: 34px;
}

.mc-sidebar .mc-nutrition-head h3 {
  font-size: 26px;
}

.mc-sidebar .mc-nutrition-head a {
  gap: 8px;
  margin-top: 8px;
  font-size: 15px;
}

.mc-sidebar .mc-nutrition-divider {
  margin: 22px 0;
}

.mc-sidebar .mc-nutrition-kcal {
  padding-right: 16px;
}

.mc-sidebar .mc-nutrition-kcal strong {
  font-size: 50px;
}

.mc-sidebar .mc-nutrition-kcal span {
  font-size: 20px;
}

.mc-sidebar .mc-nutrition-macro {
  padding: 0 8px;
}

.mc-sidebar .mc-nutrition-macro dt {
  gap: 11px;
  font-size: 14px;
}

.mc-sidebar .mc-nutrition-macro dt span {
  width: 17px;
  height: 17px;
}

.mc-sidebar .mc-nutrition-macro dd {
  margin-bottom: 12px;
  font-size: 18px;
}

.mc-sidebar .mc-nutrition-macro-icon {
  width: 48px;
  height: 48px;
}

.mc-sidebar .mc-nutrition-macro-icon svg {
  width: 27px;
  height: 27px;
}


.mc-save-card {
  position: relative;
  overflow: hidden;
  padding: 26px;
  border-radius: 20px;
  background:
    radial-gradient(circle at 100% 48%, rgba(247, 201, 72, 0.22), transparent 34%),
    var(--mc-green-900);
  color: #FFFFFF;
  box-shadow: var(--mc-shadow-md);
}

.mc-save-card h3 {
  max-width: 170px;
  margin: 0 0 10px;
  color: #FFFFFF;
  font-family: var(--mc-font-heading) !important;
  font-size: 26px;
  line-height: 1.05;
}

.mc-save-card p {
  max-width: 170px;
  margin: 0 0 18px;
  color: rgba(255, 255, 255, 0.78);
  font-size: 14px;
  line-height: 1.55;
}

.mc-save-card::after {
  content: "";
  position: absolute;
  right: -38px;
  bottom: -44px;
  width: 160px;
  height: 160px;
  border-radius: 999px;
  background: radial-gradient(circle, rgba(255, 255, 255, 0.20), transparent 64%);
}

.mc-btn-light {
  position: relative;
  z-index: 1;
  min-height: 44px;
  padding: 0 18px;
  border: 0;
  background: #FFFFFF;
  color: var(--mc-green-900);
}

.mc-related-card {
  padding: 24px;
}

.mc-related-list {
  display: grid;
  gap: 18px;
}

.mc-related-item {
  display: grid;
  grid-template-columns: 82px minmax(0, 1fr);
  gap: 14px;
  align-items: center;
  color: inherit;
  text-decoration: none;
}

.mc-related-item img {
  width: 82px;
  height: 82px;
  object-fit: cover;
  border-radius: 14px;
}

.mc-related-title {
  display: block;
  margin-bottom: 8px;
  color: var(--mc-green-900);
  font-size: 15px;
  font-weight: 800;
  line-height: 1.25;
}

.mc-related-meta {
  display: block;
  color: var(--mc-text-muted);
  font-size: 12px;
  line-height: 1.45;
}

.mc-related-rating {
  color: var(--mc-orange-500);
}

.mc-extra-section {
  display: grid;
  grid-template-columns: 1.1fr 0.9fr;
  gap: 28px;
  margin-top: 72px;
}

.mc-chef-notes {
  display: grid;
  grid-template-columns: 220px minmax(0, 1fr);
  overflow: hidden;
  border-radius: 22px;
  background: #F5EDE6;
  box-shadow: var(--mc-shadow-sm);
}

.mc-chef-notes > img {
  width: 100%;
  height: 100%;
  min-height: 320px;
  object-fit: cover;
}

.mc-chef-content {
  padding: 32px;
}

.mc-check-list {
  display: grid;
  gap: 12px;
  padding: 0;
  margin: 20px 0 26px;
  list-style: none;
}

.mc-check-list li {
  display: flex;
  gap: 10px;
  color: #333333;
  font-size: 14px;
  line-height: 1.55;
}

.mc-check-list span {
  color: var(--mc-success);
  font-weight: 900;
}

.mc-chef-signature {
  display: flex;
  align-items: center;
  gap: 10px;
}

.mc-chef-signature img,
.mc-avatar-placeholder {
  width: 38px;
  height: 38px;
  border-radius: 999px;
}

.mc-chef-signature img {
  object-fit: cover;
}

.mc-chef-signature strong,
.mc-review-author strong {
  display: block;
  color: var(--mc-green-900);
  font-size: 13px;
  font-weight: 800;
}

.mc-chef-signature small,
.mc-review-author small {
  display: block;
  color: var(--mc-text-muted);
  font-size: 11px;
}

.mc-faq-card {
  padding: 32px;
}

.mc-faq-card > p {
  margin: -12px 0 22px;
  color: var(--mc-text-main);
  font-weight: 700;
}

.mc-accordion-item {
  margin-bottom: 12px;
  padding: 16px 18px;
  border: 1px solid var(--mc-border);
  border-radius: 12px;
  background: #FFFFFF;
  color: var(--mc-text-main);
  font-size: 14px;
  font-weight: 800;
}

.mc-accordion-item summary {
  cursor: pointer;
}

.mc-accordion-item p {
  margin: 12px 0 0;
  color: #333333;
  font-weight: 400;
  line-height: 1.55;
}

.mc-reviews {
  display: grid;
  grid-template-columns: 220px minmax(0, 1fr);
  gap: 32px;
  margin: 64px 0;
}

.mc-reviews-summary strong {
  display: block;
  margin-bottom: 8px;
  color: var(--mc-orange-500);
  font-size: 24px;
}

.mc-reviews-summary p {
  color: var(--mc-text-muted);
  font-size: 13px;
}

.mc-review-cards {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 22px;
}

.mc-review-card {
  padding: 22px;
}

.mc-review-author {
  display: flex;
  align-items: center;
  gap: 12px;
  margin-bottom: 14px;
}

.mc-review-author img {
  width: 38px;
  height: 38px;
  border-radius: 999px;
}

.mc-avatar-placeholder {
  display: grid;
  place-items: center;
  background: var(--mc-orange-100);
  color: var(--mc-orange-500);
  font-weight: 900;
}

.mc-review-text {
  margin: 12px 0 0;
  color: #333333;
  font-size: 14px;
  line-height: 1.6;
}

.mc-comments-native {
  margin-top: 48px;
}

.mc-recipe-page + .newsletter-band,
.mc-recipe-page ~ .newsletter-band {
  margin: 0 auto;
  padding: 38px 56px !important;
  border-radius: 24px 24px 0 0;
  background:
    radial-gradient(circle at 0 50%, rgba(247, 201, 72, 0.18), transparent 24%),
    radial-gradient(circle at 100% 100%, rgba(242, 92, 42, 0.20), transparent 28%),
    var(--mc-green-900) !important;
}

.mc-recipe-page ~ .site-footer {
  background: var(--mc-cream-bg) !important;
  color: var(--mc-text-main) !important;
}

.mc-recipe-page ~ .site-footer h4,
.mc-recipe-page ~ .site-footer .wp-block-site-title a {
  color: var(--mc-green-900) !important;
}

.mc-recipe-page ~ .site-footer p,
.mc-recipe-page ~ .site-footer a,
.mc-recipe-page ~ .site-footer li {
  color: var(--mc-text-muted) !important;
}

@media (max-width: 1180px) {
  .mc-recipe-main {
    grid-template-columns: minmax(240px, 0.68fr) minmax(0, 1.1fr);
  }

  .mc-sidebar {
    grid-column: 1 / -1;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    position: static;
  }

  .mc-sidebar .mc-nutrition-card {
    grid-column: 1 / -1;
  }

  .mc-sidebar .mc-nutrition-head {
    grid-template-columns: 88px minmax(0, 1fr);
    gap: 22px;
  }

  .mc-sidebar .mc-nutrition-leaf {
    width: 88px;
    height: 88px;
  }

  .mc-sidebar .mc-nutrition-leaf svg {
    width: 44px;
    height: 44px;
  }

  .mc-sidebar .mc-nutrition-head h3 {
    font-size: clamp(30px, 4vw, 38px);
  }

  .mc-sidebar .mc-nutrition-head a {
    font-size: clamp(18px, 2.2vw, 24px);
  }

  .mc-sidebar .mc-nutrition-kcal strong {
    font-size: clamp(62px, 7vw, 78px);
  }

  .mc-sidebar .mc-nutrition-kcal span {
    font-size: clamp(24px, 3vw, 32px);
  }

  .mc-sidebar .mc-nutrition-macro {
    padding: 0 18px;
  }

  .mc-sidebar .mc-nutrition-macro dt {
    gap: 18px;
    font-size: clamp(18px, 2vw, 25px);
  }

  .mc-sidebar .mc-nutrition-macro dt span {
    width: 22px;
    height: 22px;
  }

  .mc-sidebar .mc-nutrition-macro dd {
    margin-bottom: 16px;
    font-size: clamp(20px, 2.5vw, 28px);
  }

  .mc-sidebar .mc-nutrition-macro-icon {
    width: 72px;
    height: 72px;
  }

  .mc-sidebar .mc-nutrition-macro-icon svg {
    width: 38px;
    height: 38px;
  }
}

@media (max-width: 1024px) {
  .mc-recipe-hero {
    grid-template-columns: 1fr;
  }

  .mc-recipe-main,
  .mc-extra-section,
  .mc-reviews {
    grid-template-columns: 1fr;
  }

  .mc-sidebar {
    grid-template-columns: 1fr;
  }

  .mc-step {
    grid-template-columns: minmax(180px, 0.45fr) minmax(0, 1fr);
  }

  .mc-review-cards {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 768px) {
  .mc-recipe-page {
    padding-top: 18px;
  }

  .mc-container {
    padding: 0 16px;
  }

  .mc-recipe-hero {
    gap: 30px;
    margin-top: 26px;
  }

  .mc-recipe-hero-content {
    order: 2;
  }

  .mc-hero-image-wrap {
    order: 1;
    border-radius: 18px;
  }

  .mc-recipe-title {
    font-size: 44px;
  }

  .mc-recipe-meta {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 18px 14px;
  }

  .mc-action-row {
    align-items: stretch;
  }

  .mc-btn-primary,
  .mc-btn-secondary {
    width: 100%;
  }

  .mc-icon-btn {
    flex: 1 1 0;
    width: auto;
  }

  .mc-author-card {
    right: 12px;
    bottom: 12px;
    padding: 10px 12px;
  }

  .mc-recipe-tabs {
    gap: 28px;
    margin-bottom: 36px;
  }

  .mc-step {
    grid-template-columns: 1fr;
    gap: 14px;
  }

  .mc-step-image {
    aspect-ratio: 1.45 / 1;
  }

  .mc-chef-notes {
    grid-template-columns: 1fr;
  }

  .mc-chef-notes > img {
    min-height: 220px;
    aspect-ratio: 16 / 9;
  }

  .mc-chef-content,
  .mc-faq-card {
    padding: 24px;
  }

  .mc-sidebar .mc-nutrition-card {
    padding: 24px;
    border-radius: 28px;
  }

  .mc-sidebar .mc-nutrition-head {
    grid-template-columns: 64px minmax(0, 1fr);
    gap: 16px;
  }

  .mc-sidebar .mc-nutrition-leaf {
    width: 64px;
    height: 64px;
  }

  .mc-sidebar .mc-nutrition-leaf svg {
    width: 34px;
    height: 34px;
  }

  .mc-sidebar .mc-nutrition-head h3 {
    font-size: 26px;
  }

  .mc-sidebar .mc-nutrition-head a {
    gap: 8px;
    margin-top: 8px;
    font-size: 15px;
  }

  .mc-sidebar .mc-nutrition-divider {
    margin: 22px 0;
  }

  .mc-sidebar .mc-nutrition-kcal strong {
    font-size: 50px;
  }

  .mc-sidebar .mc-nutrition-kcal span {
    font-size: 20px;
  }

  .mc-sidebar .mc-nutrition-macro {
    padding: 0 8px;
  }

  .mc-sidebar .mc-nutrition-macro dt {
    gap: 11px;
    font-size: 14px;
  }

  .mc-sidebar .mc-nutrition-macro dt span {
    width: 17px;
    height: 17px;
  }

  .mc-sidebar .mc-nutrition-macro dd {
    margin-bottom: 12px;
    font-size: 18px;
  }

  .mc-sidebar .mc-nutrition-macro-icon {
    width: 48px;
    height: 48px;
  }

  .mc-sidebar .mc-nutrition-macro-icon svg {
    width: 27px;
    height: 27px;
  }

  .mc-recipe-page + .newsletter-band,
  .mc-recipe-page ~ .newsletter-band {
    padding: 36px 20px !important;
    border-radius: 20px 20px 0 0;
  }
}

@media (max-width: 520px) {
  .mc-recipe-title {
    font-size: 40px;
  }

  .mc-meta-icon {
    width: 36px;
    height: 36px;
    flex-basis: 36px;
  }

  .mc-section-title {
    font-size: 28px;
  }
}

/* =========================================================
   MyCuisine / Foodieland editorial homepage
   ========================================================= */

:root {
  --mc-bg: #F5F1E8;
  --mc-surface: #FBFAF6;
  --mc-surface-soft: #E8F0EA;
  --mc-green-100: #E8F0EA;
  --mc-orange-600: #D94716;
  --mc-white: #FFFFFF;
  --mc-container-home: 1240px;
  --mc-container-padding: clamp(20px, 4vw, 40px);
  --mc-radius-sm: 10px;
  --mc-radius-md: 14px;
  --mc-radius-lg: 20px;
  --mc-radius-xl: 28px;
  --mc-radius-pill: 999px;
  --mc-section-sm: clamp(32px, 5vw, 56px);
  --mc-section-md: clamp(48px, 7vw, 80px);
  --mc-section-lg: clamp(64px, 9vw, 112px);
}

.mc-home {
  overflow: clip;
  background:
    radial-gradient(circle at 96% 8%, rgba(247, 201, 72, 0.14), transparent 24rem),
    radial-gradient(circle at 0 30%, rgba(242, 92, 42, 0.08), transparent 20rem),
    var(--mc-bg);
  color: var(--mc-text-main);
  font-family: var(--mc-font-body);
}

.mc-home *,
.mc-home *::before,
.mc-home *::after,
.mc-footer *,
.mc-footer *::before,
.mc-footer *::after {
  box-sizing: border-box;
}

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

.mc-home a {
  color: inherit;
  text-decoration: none;
}

.mc-home h1,
.mc-home h2,
.mc-home h3,
.mc-footer .mc-site-logo {
  font-family: var(--mc-font-heading) !important;
  color: var(--mc-green-900);
  letter-spacing: -0.03em;
}

.mc-home p {
  color: var(--mc-text-muted);
}

.mc-home .mc-btn-primary {
  color: #FFFFFF !important;
}

.mc-home .mc-btn-secondary,
.mc-home .mc-btn-light {
  color: var(--mc-green-900) !important;
}

.mc-home-section,
.mc-home-hero,
.mc-home-benefits,
.mc-home-editorial-trending,
.mc-home-bundle,
.mc-home-meal-plans,
.mc-home-community,
.mc-home-press,
.mc-home-newsletter {
  max-width: var(--mc-container-home);
  margin-inline: auto;
  padding-inline: var(--mc-container-padding);
}

.mc-home-section {
  margin-block: var(--mc-section-md);
}

.mc-home-section-header {
  display: flex;
  align-items: end;
  justify-content: space-between;
  gap: 24px;
  margin-bottom: 24px;
}

.mc-home-section-header h2,
.mc-home-ingredient-search h2 {
  margin: 0;
  font-size: clamp(30px, 3.1vw, 42px);
  line-height: 1.05;
}

.mc-home-section-header p,
.mc-home-ingredient-search p {
  max-width: 520px;
  margin: 8px 0 0;
  font-size: 14px;
  line-height: 1.65;
}

.mc-home-section-header > a,
.mc-home-editorial-panel > a,
.mc-home-trending-header a {
  color: var(--mc-orange-500);
  font-size: 13px;
  font-weight: 800;
  white-space: nowrap;
}

.mc-home-hero {
  display: grid;
  grid-template-columns: minmax(0, 0.86fr) minmax(0, 1.14fr);
  gap: clamp(36px, 5vw, 64px);
  align-items: center;
  min-height: 610px;
  padding-top: 48px;
  padding-bottom: 62px;
}

.mc-home-hero__copy {
  position: relative;
  z-index: 1;
}

.mc-home-badge {
  display: inline-flex;
  align-items: center;
  gap: 7px;
  border-radius: var(--mc-radius-pill);
  background: var(--mc-orange-100);
  color: var(--mc-orange-600);
  font-size: 12px;
  font-weight: 900;
  line-height: 1;
}

.mc-home-badge--warm {
  margin-bottom: 26px;
  padding: 9px 13px;
}

.mc-home-hero h1 {
  max-width: 620px;
  margin: 0 0 24px;
  font-size: clamp(56px, 6vw, 82px);
  line-height: 0.96;
  letter-spacing: -0.05em;
}

.mc-home-hero h1 span {
  color: var(--mc-orange-500);
}

.mc-home-hero p {
  max-width: 480px;
  margin: 0 0 30px;
  color: #333333;
  font-size: 17px;
  line-height: 1.72;
}

.mc-home-hero__actions {
  display: flex;
  align-items: center;
  gap: 16px;
  flex-wrap: wrap;
}

.mc-home-hero__visual {
  position: relative;
  min-width: 0;
}

.mc-home-hero__visual::before,
.mc-home-hero__visual::after {
  content: "";
  position: absolute;
  pointer-events: none;
  border-radius: 999px;
  z-index: 0;
}

.mc-home-hero__visual::before {
  inset: 7% 8% 4% 4%;
  background: #F5EDE1;
  filter: blur(0);
}

.mc-home-hero__visual::after {
  right: 2%;
  top: 4%;
  width: 92px;
  height: 92px;
  background: radial-gradient(circle, rgba(242, 92, 42, 0.24), transparent 68%);
}

.mc-home-hero__visual > img {
  position: relative;
  z-index: 1;
  width: min(100%, 720px);
  margin-left: auto;
  aspect-ratio: 1.18 / 1;
  object-fit: cover;
  border-radius: 44% 56% 48% 52% / 48% 42% 58% 52%;
  box-shadow: 0 26px 70px rgba(31, 61, 54, 0.14);
}

.mc-home-floating-recipe {
  position: absolute;
  right: 22px;
  bottom: 26px;
  z-index: 2;
  display: grid;
  grid-template-columns: 64px minmax(0, 1fr) auto;
  gap: 12px;
  align-items: center;
  width: min(320px, calc(100% - 44px));
  padding: 14px;
  border: 1px solid var(--mc-border);
  border-radius: 18px;
  background: rgba(255, 253, 248, 0.94);
  box-shadow: var(--mc-shadow-md);
  backdrop-filter: blur(14px);
}

.mc-home-floating-recipe img {
  width: 64px;
  height: 64px;
  border-radius: 14px;
  object-fit: cover;
}

.mc-home-floating-recipe small,
.mc-home-recipe-meta,
.mc-home-article-content small,
.mc-home-meal-card small,
.mc-home-related-item small {
  color: var(--mc-text-muted);
  font-size: 12px;
  line-height: 1.3;
}

.mc-home-floating-recipe strong {
  display: block;
  overflow: hidden;
  color: var(--mc-green-900);
  font-size: 14px;
  font-weight: 900;
  line-height: 1.25;
}

.mc-home-floating-recipe b {
  display: grid;
  place-items: center;
  width: 34px;
  height: 34px;
  border-radius: 999px;
  background: var(--mc-green-900);
  color: #FFFFFF;
}

.mc-home-benefits {
  display: flex;
  gap: clamp(18px, 4vw, 56px);
  margin-bottom: var(--mc-section-sm);
}

.mc-home-benefit {
  display: flex;
  align-items: center;
  gap: 14px;
  min-width: 0;
}

.mc-home-benefit > span {
  display: grid;
  place-items: center;
  flex: 0 0 44px;
  width: 44px;
  height: 44px;
  border-radius: 999px;
  background: var(--mc-green-100);
  color: var(--mc-green-900);
  font-size: 20px;
}

.mc-home-benefit > span img {
  width: 22px;
  height: 22px;
}

.mc-home-benefit:nth-child(3) > span {
  background: var(--mc-orange-100);
  color: var(--mc-orange-500);
}

.mc-home-benefit strong,
.mc-home-category-card strong,
.mc-home-meal-card strong,
.mc-home-related-item strong {
  display: block;
  color: var(--mc-green-900);
  font-size: 14px;
  font-weight: 900;
}

.mc-home-benefit small {
  display: block;
  color: var(--mc-text-muted);
  font-size: 12px;
}

.mc-home-category-row {
  display: grid;
  grid-template-columns: repeat(7, minmax(0, 1fr)) 52px;
  gap: 18px;
}

.mc-home-category-card,
.mc-home-category-next {
  display: grid;
  place-items: center;
  min-height: 142px;
  padding: 18px 12px;
  border: 1px solid var(--mc-border);
  border-radius: 18px;
  background: var(--mc-surface);
  box-shadow: var(--mc-shadow-sm);
  text-align: center;
  transition: transform var(--t-fast), box-shadow var(--t-fast), border-color var(--t-fast);
}

.mc-home-category-card:hover,
.mc-home-category-next:hover,
.mc-home-recipe-card:hover,
.mc-home-article-card:hover,
.mc-home-meal-card:hover {
  border-color: rgba(31, 61, 54, 0.24);
  box-shadow: var(--mc-shadow-md);
  transform: translateY(-3px);
}

.mc-home-category-icon {
  display: grid;
  place-items: center;
  width: 64px;
  height: 64px;
  margin-bottom: 12px;
  border-radius: 999px;
  background:
    radial-gradient(circle at 40% 35%, rgba(255, 255, 255, 0.8), transparent 34%),
    #F7EEDC;
  font-size: 29px;
}

.mc-home-category-card small {
  display: block;
  margin-top: 5px;
  color: var(--mc-text-muted);
  font-size: 12px;
}

.mc-home-category-next {
  min-height: 142px;
  color: var(--mc-green-900);
  font-size: 24px;
  font-weight: 900;
}

.mc-home-editorial-trending {
  display: grid;
  grid-template-columns: 0.92fr 1.05fr 2fr;
  margin-block: var(--mc-section-md);
  padding-inline: var(--mc-container-padding);
}

.mc-home-editorial-panel,
.mc-home-trending-panel {
  min-height: 370px;
}

.mc-home-editorial-panel {
  display: flex;
  flex-direction: column;
  justify-content: center;
  padding: 42px 34px;
  background: var(--mc-surface-soft);
}

.mc-eyebrow {
  display: block;
  margin-bottom: 14px;
  color: var(--mc-orange-500);
  font-size: 11px;
  font-weight: 900;
  letter-spacing: 0.12em;
  line-height: 1;
  text-transform: uppercase;
}

.mc-home-editorial-panel h2 {
  margin: 0 0 16px;
  font-size: clamp(34px, 3vw, 44px);
  line-height: 1.03;
}

.mc-home-editorial-panel p {
  margin: 0 0 22px;
  font-size: 14px;
  line-height: 1.72;
}

.mc-home-video-card {
  position: relative;
  min-height: 370px;
  overflow: hidden;
  background: var(--mc-cream-soft);
}

.mc-home-video-card img {
  width: 100%;
  height: 100%;
  min-height: 370px;
  object-fit: cover;
}

.mc-home-video-card span {
  position: absolute;
  inset: 0;
  display: grid;
  place-items: center;
  width: 68px;
  height: 68px;
  margin: auto;
  border-radius: 999px;
  background: #FFFFFF;
  color: var(--mc-green-900);
  box-shadow: var(--mc-shadow-md);
  font-size: 20px;
}

.mc-home-trending-panel {
  padding: 34px;
  background:
    radial-gradient(circle at 100% 0, rgba(247, 201, 72, 0.10), transparent 40%),
    var(--mc-green-900);
  color: #FFFFFF;
}

.mc-home-trending-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 18px;
  margin-bottom: 22px;
}

.mc-home-trending-header h2 {
  margin: 0;
  color: #FFFFFF;
  font-size: clamp(28px, 2.4vw, 34px);
}

.mc-home-trending-grid,
.mc-home-recipe-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 16px;
}

.mc-home-recipe-card {
  overflow: hidden;
  border: 1px solid var(--mc-border);
  border-radius: 18px;
  background: var(--mc-surface);
  box-shadow: var(--mc-shadow-sm);
  transition: transform var(--t-fast), box-shadow var(--t-fast), border-color var(--t-fast);
}

.mc-home-recipe-card__image {
  position: relative;
  display: block;
  overflow: hidden;
  background: var(--mc-cream-soft);
}

.mc-home-recipe-card__image img {
  width: 100%;
  aspect-ratio: 1.1 / 1;
  object-fit: cover;
  transition: transform var(--t-base);
}

.mc-home-recipe-card:hover .mc-home-recipe-card__image img {
  transform: scale(1.04);
}

.mc-home-recipe-card__image .mc-home-badge {
  position: absolute;
  top: 10px;
  left: 10px;
  z-index: 2;
  padding: 7px 10px;
  background: var(--mc-orange-500);
  color: #FFFFFF;
}

.mc-home-favorite {
  position: absolute;
  top: 10px;
  right: 10px;
  z-index: 2;
  display: grid;
  place-items: center;
  width: 38px;
  height: 38px;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.94);
  color: var(--mc-green-900);
  box-shadow: 0 8px 22px rgba(0, 0, 0, 0.08);
  font-size: 20px;
}

.mc-home-recipe-card__body {
  padding: 15px 14px 16px;
}

.mc-home-recipe-card h3 {
  margin: 0 0 12px;
  font-size: 20px;
  line-height: 1.14;
}

.mc-home-recipe-card h3 a:hover,
.mc-home-article-card h3 a:hover {
  color: var(--mc-orange-500);
}

.mc-home-recipe-meta {
  display: flex;
  flex-wrap: wrap;
  gap: 7px 12px;
}

.mc-home-rating {
  color: var(--mc-orange-500);
}

.mc-home-recipe-card.is-compact h3 {
  font-size: 17px;
}

.mc-home-recipe-card.is-compact .mc-home-recipe-meta {
  font-size: 11px;
}

.mc-home-ingredient-layout {
  display: grid;
  grid-template-columns: minmax(0, 0.9fr) minmax(0, 1.38fr);
  gap: 40px;
  align-items: end;
}

.mc-home-search-large {
  display: flex;
  align-items: center;
  width: 100%;
  height: 56px;
  margin-top: 22px;
  border: 1px solid var(--mc-border);
  border-radius: 14px;
  background: #FFFFFF;
  overflow: hidden;
}

.mc-home-search-large input[type="search"] {
  flex: 1 1 auto;
  min-width: 0;
  height: 100%;
  border: 0 !important;
  background: transparent !important;
  padding: 0 18px;
  box-shadow: none !important;
}

.mc-home-search-large button {
  display: grid;
  place-items: center;
  width: 54px;
  height: 54px;
  min-height: 54px;
  border-radius: 0 !important;
  background: transparent !important;
  color: var(--mc-green-900) !important;
  box-shadow: none !important;
  font-size: 22px;
}

.mc-home-search-large button img {
  width: 22px;
  height: 22px;
}

.mc-home-chip-row {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: 14px;
}

.mc-home-chip-row a {
  display: inline-flex;
  align-items: center;
  min-height: 32px;
  padding: 0 12px;
  border-radius: 999px;
  background: var(--mc-surface-soft);
  color: var(--mc-text-muted);
  font-size: 12px;
  font-weight: 800;
}

.mc-home-chip-row a:hover {
  background: var(--mc-green-900);
  color: #FFFFFF;
}

.mc-home-ingredient-cards {
  display: grid;
  grid-template-columns: repeat(6, minmax(0, 1fr));
  gap: 14px;
}

.mc-home-ingredient-cards a {
  display: grid;
  gap: 10px;
  justify-items: center;
  text-align: center;
}

.mc-home-ingredient-cards img {
  width: 100%;
  aspect-ratio: 1 / 1;
  border-radius: 999px;
  object-fit: cover;
  background: var(--mc-cream-soft);
  box-shadow: var(--mc-shadow-sm);
}

.mc-home-ingredient-cards strong {
  color: var(--mc-green-900);
  font-size: 12px;
  font-weight: 900;
}

.mc-home-bundle-inner {
  display: grid;
  grid-template-columns: 0.95fr 1.35fr 0.8fr;
  overflow: hidden;
  border: 1px solid var(--mc-border);
  border-radius: 24px;
  background: var(--mc-surface);
  box-shadow: var(--mc-shadow-sm);
}

.mc-home-bundle-copy {
  padding: 40px;
  background:
    radial-gradient(circle at 0 100%, rgba(247, 201, 72, 0.18), transparent 34%),
    var(--mc-green-900);
  color: #FFFFFF;
}

.mc-home-bundle-copy h2 {
  margin: 0 0 16px;
  color: #FFFFFF;
  font-size: clamp(34px, 3vw, 44px);
  line-height: 1.04;
}

.mc-home-bundle-copy h2 span {
  color: var(--mc-yellow-500);
}

.mc-home-bundle-copy p {
  margin: 0 0 24px;
  color: rgba(255, 255, 255, 0.78);
  line-height: 1.6;
}

.mc-home-packshots {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  align-items: end;
  gap: 16px;
  min-height: 250px;
  padding: 32px 28px;
  background:
    radial-gradient(circle at 52% 42%, rgba(247, 201, 72, 0.16), transparent 34%),
    linear-gradient(180deg, #FBFAF6, #E8F0EA);
}

.mc-home-packshots span {
  display: flex;
  align-items: end;
  justify-content: center;
  min-height: 168px;
  padding: 18px 14px 22px;
  border: 1px solid rgba(31, 61, 54, 0.12);
  border-radius: 18px 18px 38px 38px;
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.74), rgba(255, 255, 255, 0.18)),
    #CFE1D1;
  color: var(--mc-green-900);
  text-align: center;
  box-shadow: 0 18px 36px rgba(31, 61, 54, 0.10);
}

.mc-home-packshots span:nth-child(2) {
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.74), rgba(255, 255, 255, 0.18)),
    #F5AD83;
}

.mc-home-packshots span:nth-child(3) {
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.74), rgba(255, 255, 255, 0.18)),
    #F4DD99;
}

.mc-home-packshots b {
  max-width: 110px;
  font-size: 12px;
  text-transform: uppercase;
}

.mc-home-bundle-perks {
  display: grid;
  align-content: center;
  gap: 12px;
  padding: 32px;
}

.mc-promo-badge {
  display: grid;
  place-items: center;
  width: 94px;
  height: 94px;
  margin-bottom: 8px;
  border-radius: 999px;
  background: var(--mc-yellow-500);
  color: var(--mc-green-900);
  font-size: 12px;
  font-weight: 900;
  line-height: 1.05;
  text-align: center;
  text-transform: uppercase;
}

.mc-promo-badge strong {
  font-size: 28px;
}

.mc-home-bundle-perks p {
  margin: 0;
  color: var(--mc-green-900);
  font-size: 14px;
  font-weight: 900;
}

.mc-home-meal-plans {
  display: grid;
  grid-template-columns: minmax(0, 1.58fr) minmax(280px, 0.78fr);
  gap: 28px;
  margin-block: var(--mc-section-md);
}

.mc-home-meal-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 16px;
}

.mc-home-meal-card {
  overflow: hidden;
  border: 1px solid var(--mc-border);
  border-radius: 16px;
  background: var(--mc-surface);
  box-shadow: var(--mc-shadow-sm);
  transition: transform var(--t-fast), box-shadow var(--t-fast), border-color var(--t-fast);
}

.mc-home-meal-card img {
  width: 100%;
  aspect-ratio: 1.45 / 1;
  object-fit: cover;
}

.mc-home-meal-card span {
  display: block;
  padding: 14px;
}

.mc-home-meal-card small {
  display: block;
  margin-top: 6px;
}

.mc-home-personal-card {
  position: relative;
  overflow: hidden;
  align-self: stretch;
  min-height: 300px;
  padding: 34px;
  border-radius: 22px;
  background:
    radial-gradient(circle at 100% 100%, rgba(247, 201, 72, 0.20), transparent 36%),
    var(--mc-green-900);
  color: #FFFFFF;
}

.mc-home-personal-card h2 {
  max-width: 280px;
  margin: 0 0 16px;
  color: #FFFFFF;
  font-size: 32px;
  line-height: 1.08;
}

.mc-home-personal-card p {
  max-width: 290px;
  margin: 0 0 22px;
  color: rgba(255, 255, 255, 0.78);
  line-height: 1.62;
}

.mc-home-recommendations {
  margin-top: var(--mc-section-sm);
}

.mc-home-blog-grid {
  display: grid;
  grid-template-columns: 1.15fr repeat(4, minmax(0, 1fr));
  gap: 20px;
}

.mc-home-article-card {
  overflow: hidden;
  border: 1px solid var(--mc-border);
  border-radius: 18px;
  background: var(--mc-surface);
  box-shadow: var(--mc-shadow-sm);
  transition: transform var(--t-fast), box-shadow var(--t-fast), border-color var(--t-fast);
}

.mc-home-article-card__image {
  display: block;
  overflow: hidden;
  background: var(--mc-cream-soft);
}

.mc-home-article-card__image img {
  width: 100%;
  aspect-ratio: 1.3 / 1;
  object-fit: cover;
}

.mc-home-article-card.is-featured .mc-home-article-card__image img {
  aspect-ratio: 1.08 / 1;
}

.mc-home-article-content {
  padding: 18px;
}

.mc-home-article-category {
  display: block;
  margin-bottom: 10px;
  color: var(--mc-orange-500);
  font-size: 10px;
  font-weight: 900;
  letter-spacing: 0.10em;
  text-transform: uppercase;
}

.mc-home-article-card h3 {
  margin: 0 0 10px;
  font-size: 22px;
  line-height: 1.1;
}

.mc-home-article-card:not(.is-featured) h3 {
  font-size: 18px;
}

.mc-home-article-card p {
  margin: 0 0 12px;
  font-size: 14px;
  line-height: 1.55;
}

.mc-home-community {
  display: grid;
  grid-template-columns: 0.85fr 1.6fr 0.72fr;
  gap: 28px;
  align-items: center;
  margin-block: var(--mc-section-md);
}

.mc-home-community h2 {
  margin: 0 0 12px;
  font-size: clamp(30px, 3vw, 42px);
  line-height: 1.08;
}

.mc-home-community p {
  margin: 0 0 18px;
  font-size: 14px;
  line-height: 1.65;
}

.mc-home-socials,
.mc-footer-social div {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
}

.mc-home-socials a,
.mc-footer-social a {
  display: grid;
  place-items: center;
  width: 38px;
  height: 38px;
  border: 1px solid var(--mc-border);
  border-radius: 999px;
  background: #FFFFFF;
  color: var(--mc-green-900) !important;
  font-weight: 900;
  text-decoration: none;
}

.mc-home-social-gallery {
  display: grid;
  grid-template-columns: repeat(5, minmax(0, 1fr));
  gap: 14px;
}

.mc-home-social-gallery img {
  width: 100%;
  aspect-ratio: 1 / 1;
  border-radius: 14px;
  object-fit: cover;
  box-shadow: var(--mc-shadow-sm);
}

.mc-home-share-card {
  padding: 24px;
  border-radius: 18px;
  background: var(--mc-green-900);
  color: #FFFFFF;
}

.mc-home-share-card h3 {
  margin: 0 0 8px;
  color: #FFFFFF;
  font-size: 24px;
  line-height: 1.05;
}

.mc-home-share-card p,
.mc-home-share-card small {
  color: rgba(255, 255, 255, 0.78);
}

.mc-home-share-card strong {
  display: block;
  margin-top: 16px;
  color: var(--mc-yellow-500);
  font-size: 32px;
}

.mc-home-press {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 28px;
  padding-block: 28px;
  border-top: 1px solid var(--mc-border);
  border-bottom: 1px solid var(--mc-border);
}

.mc-home-press span {
  color: var(--mc-text-muted);
  font-size: 13px;
  white-space: nowrap;
}

.mc-home-press strong {
  color: var(--mc-green-900);
  font-family: var(--mc-font-heading);
  font-size: clamp(18px, 2vw, 24px);
  letter-spacing: -0.02em;
  opacity: 0.88;
  white-space: nowrap;
}

.mc-home-newsletter {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(320px, 520px);
  gap: 48px;
  align-items: center;
  margin-top: var(--mc-section-sm);
  padding-top: 38px;
  padding-bottom: 38px;
  border-radius: 24px 24px 0 0;
  background:
    url("/wp-content/themes/foodieland-fse/assets/brand/mycuisine/social/usage-green-banner.png") right bottom / auto 100% no-repeat,
    radial-gradient(circle at 0 80%, rgba(247, 201, 72, 0.18), transparent 28%),
    radial-gradient(circle at 100% 50%, rgba(242, 92, 42, 0.18), transparent 32%),
    var(--mc-green-900);
  color: #FFFFFF;
}

.mc-home-newsletter h2 {
  margin: 0 0 8px;
  color: #FFFFFF;
  font-size: clamp(30px, 3vw, 38px);
  line-height: 1.05;
}

.mc-home-newsletter p {
  margin: 0;
  color: rgba(255, 255, 255, 0.78);
}

.mc-home-newsletter-form {
  display: flex;
  height: 54px;
  padding: 6px;
  border-radius: 999px;
  background: #FFFFFF;
}

.mc-home-newsletter-form input {
  flex: 1 1 auto;
  min-width: 0;
  height: 100%;
  border: 0 !important;
  background: transparent !important;
  padding: 0 18px;
  box-shadow: none !important;
}

.mc-home-newsletter-form button {
  min-height: 42px;
  padding: 0 28px;
  border: 0 !important;
  border-radius: 999px !important;
  background: var(--mc-orange-500) !important;
  color: #FFFFFF !important;
  box-shadow: none !important;
  font-weight: 900;
}

.mc-footer {
  padding: 48px var(--mc-container-padding) 36px !important;
  background: var(--mc-bg) !important;
  color: var(--mc-text-main) !important;
}

.mc-footer-inner {
  display: grid;
  grid-template-columns: minmax(220px, 1.6fr) repeat(5, minmax(0, 1fr));
  gap: 36px;
  max-width: var(--mc-container-home);
  margin: 0 auto;
}

.mc-footer-brand p {
  max-width: 190px;
  margin: 18px 0 24px;
  color: var(--mc-text-muted) !important;
  font-size: 14px;
  line-height: 1.45;
}

.mc-footer-brand small {
  color: var(--mc-text-muted);
  font-size: 12px;
}

.mc-footer h4 {
  margin: 0 0 14px;
  color: var(--mc-text-main) !important;
  font-family: var(--mc-font-body) !important;
  font-size: 13px;
  font-weight: 900;
  letter-spacing: 0;
}

.mc-footer a {
  display: block;
  margin-bottom: 8px;
  color: var(--mc-text-muted) !important;
  font-size: 13px;
  text-decoration: none;
}

.mc-footer a:hover {
  color: var(--mc-green-900) !important;
}

.mc-bottom-nav {
  display: none;
}

@media (max-width: 1180px) {
  .mc-home-editorial-trending {
    grid-template-columns: 0.9fr 1fr;
  }

  .mc-home-trending-panel {
    grid-column: 1 / -1;
  }

  .mc-home-trending-grid {
    grid-template-columns: repeat(4, minmax(0, 1fr));
  }

  .mc-home-blog-grid {
    grid-template-columns: repeat(4, minmax(0, 1fr));
  }

  .mc-home-article-card.is-featured {
    grid-column: span 2;
  }
}

@media (max-width: 1024px) {
  .mc-home-hero,
  .mc-home-ingredient-layout,
  .mc-home-bundle-inner,
  .mc-home-meal-plans,
  .mc-home-community,
  .mc-home-newsletter {
    grid-template-columns: 1fr;
  }

  .mc-home-hero {
    min-height: 0;
    padding-top: 34px;
  }

  .mc-home-benefits {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }

  .mc-home-category-row {
    grid-template-columns: repeat(4, minmax(0, 1fr));
  }

  .mc-home-category-next {
    display: none;
  }

  .mc-home-ingredient-cards {
    grid-template-columns: repeat(6, minmax(110px, 1fr));
  }

  .mc-home-meal-grid,
  .mc-home-recipe-grid,
  .mc-home-blog-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .mc-home-article-card.is-featured {
    grid-column: auto;
  }

  .mc-footer-inner {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }

  .mc-footer-brand {
    grid-column: 1 / -1;
  }
}

@media (max-width: 768px) {
  body {
    padding-bottom: 76px;
  }

  .mc-home-section,
  .mc-home-hero,
  .mc-home-benefits,
  .mc-home-editorial-trending,
  .mc-home-bundle,
  .mc-home-meal-plans,
  .mc-home-community,
  .mc-home-press,
  .mc-home-newsletter {
    padding-inline: 20px;
  }

  .mc-home-section {
    margin-block: 48px;
  }

  .mc-home-section-header {
    align-items: flex-start;
    flex-direction: column;
    gap: 10px;
  }

  .mc-home-hero {
    gap: 28px;
    padding-top: 28px;
    padding-bottom: 42px;
  }

  .mc-home-hero h1 {
    font-size: clamp(44px, 13vw, 56px);
  }

  .mc-home-hero p {
    font-size: 16px;
  }

  .mc-home-hero__actions {
    align-items: stretch;
    flex-direction: column;
  }

  .mc-home-hero__actions .mc-btn-primary,
  .mc-home-hero__actions .mc-btn-secondary {
    width: 100%;
  }

  .mc-home-hero__visual > img {
    width: 100%;
    border-radius: 24px;
  }

  .mc-home-floating-recipe {
    position: static;
    width: auto;
    margin-top: 16px;
  }

  .mc-home-benefits {
    display: flex;
    overflow-x: auto;
    gap: 14px;
    margin-bottom: 44px;
    padding-bottom: 8px;
    scroll-snap-type: x mandatory;
  }

  .mc-home-benefit {
    flex: 0 0 245px;
    scroll-snap-align: start;
  }

  .mc-scroll-mobile {
    display: flex !important;
    overflow-x: auto;
    gap: 14px;
    padding-bottom: 10px;
    scroll-snap-type: x mandatory;
    scrollbar-width: none;
  }

  .mc-scroll-mobile::-webkit-scrollbar {
    display: none;
  }

  .mc-scroll-mobile > * {
    flex: 0 0 240px;
    min-width: 240px;
    scroll-snap-align: start;
  }

  .mc-home-category-card {
    min-height: 142px;
  }

  .mc-home-editorial-trending {
    display: grid;
    grid-template-columns: 1fr;
    margin-block: 48px;
  }

  .mc-home-editorial-panel,
  .mc-home-trending-panel {
    min-height: auto;
    padding: 28px;
  }

  .mc-home-video-card,
  .mc-home-video-card img {
    min-height: 0;
  }

  .mc-home-video-card img {
    aspect-ratio: 16 / 10;
  }

  .mc-home-trending-grid > *,
  .mc-home-recipe-grid > * {
    flex-basis: 230px;
    min-width: 230px;
  }

  .mc-home-ingredient-cards > * {
    flex-basis: 118px;
    min-width: 118px;
  }

  .mc-home-bundle-copy,
  .mc-home-bundle-perks,
  .mc-home-personal-card {
    padding: 28px;
  }

  .mc-home-packshots {
    min-height: 220px;
    padding: 24px;
  }

  .mc-home-meal-grid > * {
    flex-basis: 220px;
    min-width: 220px;
  }

  .mc-home-blog-grid {
    display: grid;
    grid-template-columns: 1fr;
  }

  .mc-home-community {
    margin-block: 48px;
  }

  .mc-home-social-gallery > * {
    flex-basis: 128px;
    min-width: 128px;
  }

  .mc-home-press {
    align-items: flex-start;
    flex-direction: column;
    overflow: hidden;
  }

  .mc-home-press strong {
    display: inline-block;
    margin-right: 22px;
  }

  .mc-home-newsletter {
    gap: 22px;
    border-radius: 20px 20px 0 0;
  }

  .mc-home-newsletter-form {
    height: auto;
    flex-direction: column;
    gap: 8px;
    padding: 8px;
    border-radius: 18px;
  }

  .mc-home-newsletter-form input {
    height: 46px;
  }

  .mc-home-newsletter-form button {
    width: 100%;
    min-height: 46px;
  }

  .mc-footer {
    padding-inline: 20px !important;
  }

  .mc-footer-inner {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 28px 22px;
  }

  .mc-footer-brand {
    grid-column: 1 / -1;
  }

  .mc-bottom-nav {
    position: fixed;
    right: 0;
    bottom: 0;
    left: 0;
    z-index: 500;
    display: grid;
    grid-template-columns: repeat(5, 1fr);
    padding: 8px 8px max(8px, env(safe-area-inset-bottom));
    border-top: 1px solid var(--mc-border);
    background: rgba(255, 253, 248, 0.96);
    backdrop-filter: blur(16px);
  }

  .mc-bottom-nav a {
    display: grid;
    place-items: center;
    gap: 3px;
    color: var(--mc-green-900);
    font-size: 11px;
    font-weight: 700;
    text-decoration: none;
  }

  .mc-bottom-nav span {
    font-size: 20px;
    line-height: 1;
  }
}

@media (max-width: 520px) {
  .mc-home-section-header h2,
  .mc-home-ingredient-search h2,
  .mc-home-community h2 {
    font-size: 30px;
  }

  .mc-home-packshots {
    grid-template-columns: 1fr;
  }

  .mc-home-packshots span {
    min-height: 112px;
    border-radius: 18px;
  }

  .mc-footer-inner {
    grid-template-columns: 1fr;
  }
}

/* =========================================================
   My Cuisine recipes archive catalogue
   ========================================================= */

.post-type-archive-recipe .primary-nav a[href="/receitas/"] {
  color: var(--mc-green-900) !important;
}

.post-type-archive-recipe .primary-nav a[href="/receitas/"]::after {
  background: var(--mc-green-900);
}

.mc-recipes-page {
  overflow: clip;
  background:
    radial-gradient(circle at 98% 7%, rgba(247, 90, 36, 0.10), transparent 22rem),
    var(--mc-bg);
  color: var(--mc-text-main);
  font-family: var(--mc-font-body);
}

.mc-recipes-page *,
.mc-recipes-page *::before,
.mc-recipes-page *::after {
  box-sizing: border-box;
}

.mc-recipes-page a {
  color: inherit;
  text-decoration: none;
}

.mc-recipes-page img {
  display: block;
  max-width: 100%;
}

.mc-recipes-hero {
  position: relative;
  display: grid;
  grid-template-columns: minmax(0, 0.78fr) minmax(0, 1.22fr);
  gap: 40px;
  align-items: center;
  max-width: var(--mc-container-home);
  min-height: 390px;
  margin-inline: auto;
  padding: 32px var(--mc-container-padding) 44px;
  overflow: hidden;
}

.mc-recipes-hero__content {
  position: relative;
  z-index: 2;
}

.mc-recipes-hero h1 {
  max-width: 560px;
  margin: 0 0 24px;
  color: #2A221E;
  font-family: var(--mc-font-heading) !important;
  font-size: clamp(56px, 6vw, 78px);
  font-weight: 800;
  line-height: 0.98;
  letter-spacing: -0.055em;
}

.mc-recipes-hero h1 span {
  position: relative;
  display: inline-block;
  color: var(--mc-green-900);
}

.mc-recipes-hero h1 span::after {
  content: "";
  position: absolute;
  left: 0.08em;
  right: 0.04em;
  bottom: -0.12em;
  height: 0.16em;
  border-radius: 999px;
  background:
    linear-gradient(90deg, transparent 0 4%, var(--mc-orange-500) 4% 92%, transparent 92%),
    linear-gradient(90deg, transparent 12%, var(--mc-orange-500) 12% 72%, transparent 72%);
  background-size: 100% 42%, 70% 34%;
  background-position: 50% 18%, 42% 84%;
  background-repeat: no-repeat;
  transform: rotate(-2deg);
}

.mc-recipes-hero p {
  max-width: 430px;
  margin: 0;
  color: var(--mc-text-soft, #3A3A3A);
  font-size: 16px;
  line-height: 1.75;
}

.mc-recipes-hero__visual {
  position: relative;
  height: 100%;
}

.mc-recipes-hero__visual::before {
  content: "";
  position: absolute;
  inset: 14% -14% 8% 8%;
  border-radius: 999px;
  background: #F6EBDD;
}

.mc-recipes-hero__visual::after {
  content: "";
  position: absolute;
  top: 18%;
  left: 6%;
  width: 120px;
  height: 150px;
  background:
    radial-gradient(circle at 20% 20%, var(--mc-orange-500) 0 3px, transparent 4px),
    radial-gradient(circle at 60% 34%, var(--mc-green-900) 0 5px, transparent 6px),
    radial-gradient(circle at 82% 66%, #9D6A32 0 4px, transparent 5px),
    radial-gradient(circle at 34% 82%, var(--mc-orange-500) 0 4px, transparent 5px);
  opacity: 0.9;
}

.mc-recipes-hero__visual img {
  position: relative;
  z-index: 1;
  width: 100%;
  height: 380px;
  object-fit: cover;
  object-position: center;
  border-radius: 999px 0 0 999px;
  box-shadow: 0 20px 58px rgba(31, 61, 54, 0.10);
}

.mc-catalog {
  display: grid;
  grid-template-columns: 250px minmax(0, 1fr);
  max-width: var(--mc-container-home);
  margin-inline: auto;
  border-top: 1px solid var(--mc-border);
  border-bottom: 1px solid var(--mc-border);
  background: rgba(255, 253, 248, 0.56);
}

.mc-catalog-sidebar {
  border-right: 1px solid var(--mc-border);
  padding: 24px 20px 32px var(--mc-container-padding);
}

.mc-catalog-main {
  min-width: 0;
  padding: 24px var(--mc-container-padding) 40px 24px;
}

.mc-filter-toggle,
.mc-mobile-filter-button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 12px;
  min-height: 46px;
  padding: 0 18px;
  border: 0;
  border-radius: 10px;
  background: var(--mc-green-900);
  color: #FFFFFF;
  font-size: 13px;
  font-weight: 900;
  cursor: pointer;
}

.mc-filter-title {
  margin: 28px 0 22px;
  color: var(--mc-text-main);
  font-family: var(--mc-font-body) !important;
  font-size: 17px;
  font-weight: 900;
  letter-spacing: 0;
}

.mc-filter-group {
  padding: 20px 0;
  border-top: 1px solid var(--mc-border);
}

.mc-filter-group__header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  margin-bottom: 14px;
  color: var(--mc-text-main);
  font-size: 13px;
  font-weight: 900;
}

.mc-filter-list {
  display: grid;
  gap: 11px;
}

.mc-filter-row,
.mc-checkbox-row {
  display: grid;
  grid-template-columns: 18px minmax(0, 1fr) auto;
  gap: 10px;
  align-items: center;
  color: var(--mc-text-muted);
  font-size: 13px;
  line-height: 1.25;
}

.mc-filter-row.is-active {
  color: var(--mc-green-900);
  font-weight: 900;
}

.mc-filter-dot {
  width: 11px;
  height: 11px;
  border-radius: 999px;
  border: 3px solid var(--mc-green-900);
  background: var(--mc-green-900);
}

.mc-checkbox-row input {
  width: 15px;
  height: 15px;
  margin: 0;
  accent-color: var(--mc-green-900);
}

.mc-filter-row__count {
  color: var(--mc-text-light, #9A9A9A);
  font-size: 12px;
}

.mc-show-more {
  justify-self: start;
  padding: 0;
  border: 0;
  background: transparent;
  color: var(--mc-text-muted);
  font-size: 13px;
  cursor: pointer;
}

.mc-range {
  margin-top: 18px;
}

.mc-range-track {
  position: relative;
  display: block;
  height: 4px;
  border-radius: 999px;
  background: rgba(31, 61, 54, 0.16);
}

.mc-range-track::before {
  content: "";
  position: absolute;
  left: 0;
  width: 92%;
  height: 4px;
  border-radius: 999px;
  background: var(--mc-green-900);
}

.mc-range-thumb {
  position: absolute;
  top: 50%;
  right: 0;
  width: 14px;
  height: 14px;
  border-radius: 999px;
  background: var(--mc-green-900);
  transform: translateY(-50%);
}

.mc-range small {
  display: flex;
  justify-content: space-between;
  margin-top: 9px;
  color: var(--mc-text-light, #9A9A9A);
  font-size: 10px;
  font-weight: 600;
}

.mc-level-dot {
  display: inline-block;
  width: 7px;
  height: 7px;
  margin-right: 9px;
  border-radius: 999px;
  vertical-align: middle;
}

.mc-level-dot--easy {
  background: #69B46D;
}

.mc-level-dot--medium {
  background: var(--mc-yellow-500);
}

.mc-level-dot--hard {
  background: #E63946;
}

.mc-filter-stars {
  color: var(--mc-yellow-500);
  letter-spacing: 2px;
}

.mc-filter-actions {
  display: grid;
  gap: 10px;
  padding-top: 20px;
  border-top: 1px solid var(--mc-border);
}

.mc-apply-filters,
.mc-clear-filters {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  min-height: 44px;
  border-radius: 10px;
  font-size: 13px;
  font-weight: 900;
  text-decoration: none;
}

.mc-apply-filters {
  border: 0;
  background: var(--mc-green-900);
  color: #FFFFFF;
}

.mc-clear-filters {
  border: 1px solid var(--mc-border);
  background: var(--mc-surface);
  color: var(--mc-text-soft, #3A3A3A);
}

.mc-catalog-toolbar {
  display: grid;
  grid-template-columns: minmax(280px, 1fr) auto auto;
  align-items: center;
  gap: 24px;
  margin-bottom: 28px;
}

.mc-catalog-search {
  display: flex;
  align-items: center;
  gap: 12px;
  width: 100%;
  max-width: 360px;
  height: 48px;
  padding: 0 14px 0 16px;
  border: 1px solid var(--mc-border);
  border-radius: 10px;
  background: var(--mc-surface);
}

.mc-catalog-search input {
  flex: 1 1 auto;
  min-width: 0;
  height: 100%;
  border: 0 !important;
  background: transparent !important;
  box-shadow: none !important;
  font-size: 13px;
}

.mc-catalog-search button {
  display: grid;
  place-items: center;
  width: 28px;
  height: 28px;
  min-height: 28px;
  padding: 0;
  border: 0 !important;
  background: transparent !important;
  box-shadow: none !important;
}

.mc-results-count {
  margin: 0;
  color: var(--mc-text-soft, #3A3A3A);
  font-size: 13px;
  white-space: nowrap;
}

.mc-sort {
  display: flex;
  align-items: center;
  gap: 8px;
  height: 48px;
  padding: 0 14px;
  border: 1px solid var(--mc-border);
  border-radius: 10px;
  background: var(--mc-surface);
  color: var(--mc-text-main);
  font-size: 13px;
  white-space: nowrap;
}

.mc-sort label {
  color: var(--mc-text-muted);
}

.mc-sort select {
  min-height: 0;
  border: 0 !important;
  background: transparent !important;
  color: var(--mc-text-main);
  font-weight: 900;
}

.mc-mobile-filter-sort {
  display: none;
}

.mc-chip-row {
  display: flex;
  align-items: center;
  gap: 12px;
  margin-bottom: 28px;
  overflow-x: auto;
  scrollbar-width: none;
}

.mc-chip-row::-webkit-scrollbar {
  display: none;
}

.mc-chip,
.mc-chip-arrow {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  height: 38px;
  white-space: nowrap;
}

.mc-chip {
  padding: 0 18px;
  border: 1px solid transparent;
  border-radius: 999px;
  background: var(--mc-surface-soft);
  color: var(--mc-text-soft, #3A3A3A);
  font-size: 13px;
  font-weight: 800;
}

.mc-chip.is-active {
  background: var(--mc-green-900);
  color: #FFFFFF;
}

.mc-chip-arrow {
  flex: 0 0 38px;
  width: 38px;
  border: 1px solid var(--mc-border);
  border-radius: 999px;
  background: var(--mc-surface);
  color: var(--mc-green-900);
  font-weight: 900;
}

.mc-recipe-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 26px 22px;
}

.mc-recipe-card {
  position: relative;
  overflow: hidden;
  border: 1px solid var(--mc-border);
  border-radius: 18px;
  background: var(--mc-surface);
  box-shadow: var(--mc-shadow-xs, 0 1px 2px rgba(17, 17, 17, 0.04));
  transition: transform 200ms ease, box-shadow 200ms ease, border-color 200ms ease;
}

.mc-recipe-card:hover {
  border-color: var(--mc-border-strong, rgba(31, 61, 54, 0.24));
  box-shadow: var(--mc-shadow-md);
  transform: translateY(-4px);
}

.mc-recipe-card__image {
  position: relative;
  display: block;
  overflow: hidden;
  background: var(--mc-surface-soft);
}

.mc-recipe-card__image img {
  width: 100%;
  aspect-ratio: 1.22 / 1;
  object-fit: cover;
  transition: transform 300ms ease;
}

.mc-recipe-card:hover .mc-recipe-card__image img {
  transform: scale(1.045);
}

.mc-recipe-badge {
  position: absolute;
  top: 12px;
  left: 12px;
  z-index: 2;
  display: inline-flex;
  align-items: center;
  height: 28px;
  padding: 0 10px;
  border-radius: 999px;
  font-size: 11px;
  font-weight: 900;
}

.mc-recipe-badge--popular,
.mc-recipe-badge--kid-friendly {
  background: var(--mc-orange-500);
  color: #FFFFFF;
}

.mc-recipe-badge--new {
  background: #DCEFD2;
  color: #4B8F3A;
}

.mc-recipe-badge--quick {
  background: var(--mc-yellow-500);
  color: var(--mc-green-900);
}

.mc-recipe-badge--vegan {
  background: #DDEED7;
  color: #387A38;
}

.mc-recipe-badge--meal-prep {
  background: #4D83C7;
  color: #FFFFFF;
}

.mc-recipe-badge--one-pot,
.mc-recipe-badge--low-carb,
.mc-recipe-badge--high-protein {
  background: #8FB27D;
  color: #FFFFFF;
}

.mc-recipe-favorite {
  position: absolute;
  top: 12px;
  right: 12px;
  z-index: 2;
  display: grid;
  place-items: center;
  width: 34px;
  height: 34px;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.94);
  color: var(--mc-orange-500);
  box-shadow: 0 6px 16px rgba(0, 0, 0, 0.08);
  font-size: 20px;
  line-height: 1;
}

.mc-recipe-favorite:hover,
.mc-recipe-favorite.is-active {
  background: var(--mc-orange-500);
  color: #FFFFFF;
}

.mc-recipe-card__body {
  padding: 18px 18px 16px;
}

.mc-recipe-card__title {
  margin: 0 0 14px;
  color: var(--mc-text-main);
  font-family: var(--mc-font-body) !important;
  font-size: 16px;
  font-weight: 900;
  line-height: 1.35;
  letter-spacing: 0;
}

.mc-recipe-card__title a:hover {
  color: var(--mc-orange-500);
}

.mc-recipe-card__meta {
  display: flex;
  flex-wrap: wrap;
  gap: 10px 14px;
  color: var(--mc-text-muted);
  font-size: 12px;
}

.mc-recipe-card__meta-item {
  display: inline-flex;
  align-items: center;
  gap: 5px;
}

.mc-recipe-card__rating .star {
  color: var(--mc-yellow-500);
}

.mc-no-recipes {
  grid-column: 1 / -1;
  margin: 40px 0;
  color: var(--mc-text-muted);
  text-align: center;
}

.mc-load-more-wrap {
  display: flex;
  justify-content: center;
  margin: 44px 0 52px;
}

.mc-load-more {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  min-width: 210px;
  height: 48px;
  border: 1px solid var(--mc-border);
  border-radius: 12px;
  background: var(--mc-surface);
  color: var(--mc-text-soft, #3A3A3A);
  font-size: 13px;
  font-weight: 900;
}

.mc-load-more:hover {
  background: var(--mc-surface-soft);
}

.mc-recommendation {
  position: relative;
  display: grid;
  grid-template-columns: minmax(0, 1fr) 200px 220px;
  gap: 28px;
  align-items: center;
  padding: 34px;
  border: 1px solid var(--mc-border);
  border-radius: 22px;
  background: linear-gradient(135deg, #FFF7EF, #FBF0E6);
  overflow: hidden;
}

.mc-recommendation h2,
.mc-collections h2,
.mc-newsletter h2 {
  margin: 0;
  color: var(--mc-green-900);
  font-family: var(--mc-font-heading) !important;
  letter-spacing: -0.03em;
}

.mc-recommendation h2 {
  margin-bottom: 10px;
  font-size: 32px;
  line-height: 1.1;
}

.mc-recommendation p {
  max-width: 360px;
  margin: 0 0 22px;
  color: var(--mc-text-muted);
  font-size: 14px;
  line-height: 1.6;
}

.mc-recommendation__images {
  display: grid;
  grid-template-columns: repeat(2, 84px);
  gap: 10px;
}

.mc-recommendation__images img {
  width: 84px;
  height: 84px;
  border-radius: 14px;
  object-fit: cover;
}

.mc-taste-profile {
  padding: 20px;
  border: 1px solid var(--mc-border);
  border-radius: 16px;
  background: var(--mc-surface);
  box-shadow: var(--mc-shadow-sm);
}

.mc-taste-profile h3 {
  margin: 0 0 12px;
  color: var(--mc-green-900);
  font-family: var(--mc-font-body) !important;
  font-size: 14px;
  font-weight: 900;
  letter-spacing: 0;
}

.mc-taste-profile p {
  margin: 8px 0;
  color: var(--mc-text-muted);
  font-size: 13px;
}

.mc-floating-chef-btn {
  position: absolute;
  top: 50%;
  right: 24px;
  display: grid;
  place-items: center;
  width: 64px;
  height: 64px;
  border-radius: 999px;
  background: var(--mc-orange-500);
  color: #FFFFFF;
  transform: translateY(-50%);
}

.mc-floating-chef-btn img {
  filter: brightness(0) invert(1);
}

.mc-collections {
  max-width: var(--mc-container-home);
  margin-inline: auto;
  padding: 54px var(--mc-container-padding) 60px;
  content-visibility: auto;
  contain-intrinsic-size: 520px;
}

.mc-collections-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 22px;
}

.mc-collection-card {
  position: relative;
  overflow: hidden;
  border: 1px solid var(--mc-border);
  border-radius: 18px;
  background: var(--mc-surface);
  box-shadow: var(--mc-shadow-xs, 0 1px 2px rgba(17, 17, 17, 0.04));
  transition: transform 200ms ease, box-shadow 200ms ease;
}

.mc-collection-card:hover {
  box-shadow: var(--mc-shadow-md);
  transform: translateY(-4px);
}

.mc-collection-card img {
  width: 100%;
  aspect-ratio: 1.8 / 1;
  object-fit: cover;
}

.mc-collection-icon {
  position: absolute;
  top: 10px;
  right: 10px;
  display: grid;
  place-items: center;
  width: 34px;
  height: 34px;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.94);
  color: var(--mc-orange-500);
  box-shadow: 0 6px 16px rgba(0, 0, 0, 0.08);
}

.mc-collection-card__body {
  display: block;
  padding: 16px;
}

.mc-collection-card strong {
  display: block;
  margin-bottom: 4px;
  color: var(--mc-text-main);
  font-size: 16px;
  font-weight: 900;
}

.mc-collection-card small {
  color: var(--mc-text-muted);
  font-size: 12px;
}

.mc-newsletter {
  background:
    url("/wp-content/themes/foodieland-fse/assets/brand/mycuisine/social/usage-green-banner.png") right bottom / auto 100% no-repeat,
    radial-gradient(circle at 0 80%, rgba(247, 201, 72, 0.18), transparent 28%),
    var(--mc-green-900);
  color: #FFFFFF;
  overflow: hidden;
  content-visibility: auto;
  contain-intrinsic-size: 240px;
}

.mc-newsletter__inner {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 460px;
  gap: 48px;
  align-items: center;
  max-width: var(--mc-container-home);
  margin-inline: auto;
  padding: 38px var(--mc-container-padding);
}

.mc-newsletter h2 {
  margin: 0 0 8px;
  color: #FFFFFF;
  font-size: 36px;
  line-height: 1.05;
}

.mc-newsletter p {
  margin: 0;
  color: rgba(255, 255, 255, 0.78);
  font-size: 14px;
}

.mc-newsletter-form {
  display: flex;
  height: 54px;
  padding: 6px;
  border-radius: 999px;
  background: #FFFFFF;
}

.mc-newsletter-form input {
  flex: 1 1 auto;
  min-width: 0;
  border: 0 !important;
  background: transparent !important;
  padding: 0 18px;
  box-shadow: none !important;
  font-size: 13px;
}

.mc-newsletter-form button {
  border: 0 !important;
  border-radius: 999px !important;
  background: var(--mc-orange-500) !important;
  color: #FFFFFF !important;
  box-shadow: none !important;
  padding: 0 26px;
  font-weight: 900;
}

.mc-filter-drawer {
  display: none;
}

.mc-filter-drawer__head {
  display: none;
}

@media (max-width: 1180px) {
  .mc-catalog {
    grid-template-columns: 230px minmax(0, 1fr);
  }

  .mc-recipe-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .mc-recommendation {
    grid-template-columns: 1fr;
  }

  .mc-floating-chef-btn {
    top: 24px;
    right: 24px;
    transform: none;
  }
}

@media (max-width: 768px) {
  .mc-recipes-hero {
    grid-template-columns: 1fr;
    min-height: auto;
    padding: 28px 20px 32px;
    gap: 24px;
  }

  .mc-recipes-hero h1 {
    max-width: 370px;
    font-size: clamp(44px, 13vw, 58px);
  }

  .mc-recipes-hero p {
    max-width: 340px;
    font-size: 15px;
  }

  .mc-recipes-hero__visual img {
    height: auto;
    aspect-ratio: 1.05 / 1;
    border-radius: 22px;
  }

  .mc-catalog {
    display: block;
    border-top: 1px solid var(--mc-border);
  }

  .mc-catalog-sidebar {
    display: none;
  }

  .mc-catalog-main {
    padding: 20px;
  }

  .mc-catalog-toolbar {
    grid-template-columns: 1fr;
    gap: 14px;
    margin-bottom: 18px;
  }

  .mc-catalog-search {
    max-width: none;
  }

  .mc-sort {
    display: none;
  }

  .mc-mobile-filter-sort {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 12px;
  }

  .mc-mobile-filter-sort > span {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 6px;
    min-height: 46px;
    border: 1px solid var(--mc-border);
    border-radius: 10px;
    background: var(--mc-surface);
    color: var(--mc-text-main);
    font-size: 13px;
  }

  .mc-results-count {
    order: 3;
    text-align: center;
    font-size: 12px;
  }

  .mc-chip-row {
    margin-inline: -20px;
    padding-inline: 20px;
    padding-bottom: 6px;
  }

  .mc-chip {
    height: 36px;
    padding-inline: 14px;
    font-size: 12px;
  }

  .mc-recipe-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 18px 14px;
  }

  .mc-recipe-card {
    border-radius: 16px;
  }

  .mc-recipe-card__image img {
    aspect-ratio: 1 / 1;
  }

  .mc-recipe-card__body {
    padding: 13px 12px 14px;
  }

  .mc-recipe-card__title {
    margin-bottom: 10px;
    font-size: 14px;
  }

  .mc-recipe-card__meta {
    gap: 7px 10px;
    font-size: 11px;
  }

  .mc-recipe-badge {
    top: 8px;
    left: 8px;
    height: 24px;
    padding-inline: 8px;
    font-size: 10px;
  }

  .mc-recipe-favorite {
    top: 8px;
    right: 8px;
    width: 30px;
    height: 30px;
  }

  .mc-recommendation {
    grid-template-columns: 1fr;
    gap: 22px;
    padding: 24px;
    margin-bottom: 48px;
  }

  .mc-recommendation h2 {
    max-width: 250px;
    font-size: 30px;
  }

  .mc-recommendation__images {
    grid-template-columns: repeat(4, 1fr);
  }

  .mc-recommendation__images img {
    width: 100%;
    height: auto;
    aspect-ratio: 1 / 1;
  }

  .mc-floating-chef-btn {
    width: 52px;
    height: 52px;
  }

  .mc-collections {
    padding: 44px 20px;
  }

  .mc-collections-grid {
    display: flex;
    gap: 14px;
    overflow-x: auto;
    margin-inline: -20px;
    padding-inline: 20px;
    scrollbar-width: none;
  }

  .mc-collections-grid::-webkit-scrollbar {
    display: none;
  }

  .mc-collection-card {
    flex: 0 0 240px;
    min-width: 240px;
  }

  .mc-newsletter__inner {
    grid-template-columns: 1fr;
    gap: 24px;
    padding: 34px 20px;
  }

  .mc-newsletter h2 {
    font-size: 30px;
  }

  .mc-newsletter-form {
    height: auto;
    flex-direction: column;
    gap: 8px;
    border-radius: 18px;
    padding: 8px;
  }

  .mc-newsletter-form input {
    height: 44px;
  }

  .mc-newsletter-form button {
    min-height: 46px;
  }

  .mc-filter-drawer {
    position: fixed;
    inset: auto 0 0;
    z-index: 999;
    display: block;
    max-height: 86dvh;
    overflow: auto;
    padding: 24px 20px calc(24px + env(safe-area-inset-bottom));
    border-radius: 28px 28px 0 0;
    background: var(--mc-surface);
    box-shadow: 0 -20px 60px rgba(0, 0, 0, 0.18);
    transform: translateY(100%);
    transition: transform 260ms ease;
  }

  .mc-filter-drawer.is-open {
    transform: translateY(0);
  }

  .mc-filter-open body::after,
  .mc-filter-open::after {
    content: "";
    position: fixed;
    inset: 0;
    z-index: 998;
    background: rgba(6, 35, 31, 0.28);
  }

  .mc-filter-drawer__head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-bottom: 16px;
  }

  .mc-filter-drawer__head strong {
    color: var(--mc-green-900);
    font-size: 18px;
    font-weight: 900;
  }

  .mc-filter-drawer__head button {
    width: 38px;
    height: 38px;
    border: 1px solid var(--mc-border);
    border-radius: 999px;
    background: #FFFFFF;
    color: var(--mc-green-900);
    font-size: 22px;
  }

  .mc-filter-drawer .mc-filter-toggle,
  .mc-filter-drawer .mc-filter-title {
    display: none;
  }

  .mc-filter-drawer .mc-filter-actions {
    position: sticky;
    bottom: -24px;
    margin: 0 -20px calc(-24px - env(safe-area-inset-bottom));
    padding: 16px 20px calc(24px + env(safe-area-inset-bottom));
    background: linear-gradient(to top, var(--mc-surface) 72%, rgba(255, 253, 248, 0));
  }
}

@media (max-width: 390px) {
  .mc-recipe-grid {
    gap: 16px 10px;
  }

  .mc-recipe-card__title {
    font-size: 13px;
  }

  .mc-recipe-card__meta {
    font-size: 10px;
  }
}

/* =========================================================
   My Cuisine premium single article page
   ========================================================= */

.single-post .primary-nav a[href="/blog/"] {
  position: relative;
  color: var(--mc-green-900) !important;
}

.single-post .primary-nav a[href="/blog/"]::after {
  content: "";
  position: absolute;
  right: 0;
  bottom: -9px;
  left: 0;
  height: 2px;
  border-radius: 999px;
  background: var(--mc-green-900);
}

.mc-article {
  overflow: clip;
  padding: 0 !important;
  background:
    radial-gradient(circle at 94% 8%, rgba(242, 92, 42, 0.08), transparent 24rem),
    var(--mc-bg) !important;
  color: var(--mc-text, #111111);
  font-family: var(--mc-font-body) !important;
}

.mc-article *,
.mc-article *::before,
.mc-article *::after {
  box-sizing: border-box;
}

.mc-article-shell,
.mc-article-hero,
.mc-article-layout,
.mc-article-pair,
.mc-featured-in {
  width: min(100%, var(--mc-container, 1240px)) !important;
  max-width: var(--mc-container, 1240px) !important;
  margin-inline: auto !important;
  padding-inline: var(--mc-container-padding) !important;
}

.mc-article .mc-breadcrumb {
  margin: 14px 0 0;
  padding: 0;
  color: var(--mc-text-muted);
  font-size: 11px;
  gap: 8px;
}

.mc-article .mc-breadcrumb a {
  color: var(--mc-text-muted);
  text-decoration: none;
}

.mc-article .mc-breadcrumb .is-current {
  color: var(--mc-text-soft, #3A3A3A);
  font-weight: 600;
}

.mc-article-hero {
  display: grid !important;
  grid-template-columns: minmax(0, 0.82fr) minmax(0, 1.18fr) !important;
  gap: 56px !important;
  align-items: center !important;
  margin: 0 auto !important;
  padding-block: 48px 56px !important;
}

.mc-article-hero__text {
  padding-top: 0 !important;
}

.mc-article-eyebrow,
.mc-article-eyebrow a {
  margin: 0 0 18px !important;
  color: var(--mc-orange-500) !important;
  font-size: 11px !important;
  font-weight: 900 !important;
  letter-spacing: 0.12em !important;
  text-transform: uppercase;
}

.mc-article-title.wp-block-post-title {
  max-width: 560px;
  margin: 0 0 24px !important;
  color: var(--mc-green-900) !important;
  font-family: var(--mc-font-heading) !important;
  font-size: clamp(52px, 5.7vw, 76px) !important;
  font-weight: 800 !important;
  line-height: 0.98 !important;
  letter-spacing: -0.055em !important;
}

.mc-article-lead.wp-block-post-excerpt,
.mc-article-lead.wp-block-post-excerpt p {
  max-width: 460px;
  margin: 0 0 28px !important;
  color: var(--mc-text-soft, #3A3A3A) !important;
  font-size: 16px !important;
  line-height: 1.7 !important;
}

.mc-article-byline {
  gap: 12px !important;
  margin-bottom: 28px !important;
}

.mc-article-byline__name {
  color: var(--mc-green-900) !important;
  font-size: 13px !important;
  font-weight: 900 !important;
}

.mc-article-byline__sub,
.mc-article-byline__sub p {
  color: var(--mc-text-muted) !important;
  font-size: 12px !important;
}

.mc-article-actions {
  gap: 18px !important;
}

.mc-article-share-label {
  color: var(--mc-text-soft, #3A3A3A) !important;
  font-size: 13px !important;
  font-weight: 800;
}

.mc-share-btn {
  width: 38px !important;
  height: 38px !important;
  border: 1px solid var(--mc-border) !important;
  background: var(--mc-surface) !important;
  color: var(--mc-green-900) !important;
}

.mc-article-hero__media {
  position: relative;
  min-height: 520px;
}

.mc-article-hero__image.wp-block-post-featured-image {
  height: 520px;
  margin: 0 !important;
  overflow: hidden;
  border-radius: 0 0 24px 24px !important;
  background: var(--mc-surface-soft);
  box-shadow: none !important;
}

.mc-article-hero__image img {
  width: 100%;
  height: 100% !important;
  object-fit: cover;
  object-position: center;
  border-radius: 0 0 24px 24px !important;
}

.mc-article-jump {
  right: 32px !important;
  bottom: 44px !important;
  width: 230px !important;
  padding: 22px !important;
  border: 1px solid var(--mc-border);
  border-radius: 18px !important;
  background: rgba(255, 253, 248, 0.96) !important;
  box-shadow: var(--mc-shadow-md) !important;
}

.mc-article-jump__title {
  margin-bottom: 14px !important;
  color: var(--mc-green-900) !important;
  font-size: 13px !important;
  font-weight: 900 !important;
}

.mc-article-jump__list {
  gap: 10px !important;
  counter-reset: none !important;
}

.mc-article-jump__list li {
  padding-left: 14px !important;
  color: var(--mc-text-soft, #3A3A3A) !important;
  font-size: 12px !important;
}

.mc-article-jump__list li::before {
  content: "" !important;
  top: 0.55em;
  width: 6px;
  height: 6px;
  border-radius: 999px;
  background: var(--mc-orange-500);
}

.mc-article-layout {
  display: grid !important;
  grid-template-columns: 190px minmax(0, 620px) 300px !important;
  gap: 44px !important;
  align-items: start;
  margin-bottom: 64px !important;
}

.mc-article-aside {
  top: 96px !important;
  gap: 24px !important;
}

.mc-toc,
.mc-checklist-card,
.mc-article .mc-author-card,
.mc-article .mc-related-card,
.mc-tags-card,
.mc-faq-card {
  border: 1px solid var(--mc-border) !important;
  border-radius: 18px !important;
  background: var(--mc-surface) !important;
  box-shadow: var(--mc-shadow-xs, 0 1px 2px rgba(17,17,17,.04)) !important;
}

.mc-toc {
  padding: 22px !important;
}

.mc-toc__title,
.mc-author-card__head,
.mc-related-card__head,
.mc-tags-card__head {
  margin-bottom: 16px !important;
  color: var(--mc-green-900) !important;
  font-size: 11px !important;
  font-weight: 900 !important;
  letter-spacing: 0.08em !important;
}

.mc-toc__list {
  gap: 12px !important;
  padding-left: 16px !important;
  list-style: decimal;
  counter-reset: none !important;
}

.mc-toc__list li {
  padding-left: 0 !important;
  color: var(--mc-text-soft, #3A3A3A) !important;
  font-size: 12px !important;
  line-height: 1.35;
  counter-increment: none !important;
}

.mc-toc__list li::before {
  content: none !important;
}

.mc-checklist-card {
  padding: 24px !important;
  background: var(--mc-green-100) !important;
}

.mc-checklist-card__title {
  color: var(--mc-green-900) !important;
  font-family: var(--mc-font-heading) !important;
  font-size: 24px !important;
  line-height: 1.1 !important;
}

.mc-article-section__title,
.mc-tools-card__head h2,
.mc-comments-card__head h2,
.mc-faq-card__title {
  color: var(--mc-green-900) !important;
  font-family: var(--mc-font-heading) !important;
  letter-spacing: -0.035em;
}

.mc-article-section__title {
  margin-bottom: 18px !important;
  font-size: 34px !important;
  line-height: 1.12 !important;
}

.mc-article-section p {
  color: var(--mc-text-soft, #3A3A3A) !important;
  font-size: 15px !important;
  line-height: 1.8 !important;
}

.mc-article-video {
  margin: 28px 0 32px !important;
  aspect-ratio: 1.95 / 1 !important;
  border-radius: 18px !important;
}

.mc-article-video__play {
  width: 68px !important;
  height: 68px !important;
  background: var(--mc-white, #FFFFFF) !important;
  color: var(--mc-green-900) !important;
  box-shadow: var(--mc-shadow-md) !important;
}

.mc-habit {
  grid-template-columns: 34px 1fr 90px 24px !important;
  gap: 14px !important;
  padding: 14px !important;
  border: 1px solid var(--mc-border) !important;
  border-radius: 14px !important;
  background: var(--mc-surface) !important;
}

.mc-habit__num {
  width: 30px !important;
  height: 30px !important;
  background: var(--mc-green-900) !important;
  color: #FFFFFF !important;
  font-weight: 900 !important;
}

.mc-habit__title {
  color: var(--mc-green-900) !important;
  font-size: 14px !important;
  font-weight: 900 !important;
}

.mc-habit__text {
  color: var(--mc-text-muted) !important;
  font-size: 12px !important;
}

.mc-habit__thumb {
  width: 90px !important;
  height: 62px !important;
  border-radius: 10px !important;
}

.mc-habits-more {
  color: var(--mc-green-900) !important;
  font-size: 13px !important;
  font-weight: 900 !important;
}

.mc-article .mc-author-card,
.mc-article .mc-related-card,
.mc-tags-card,
.mc-faq-card {
  padding: 24px !important;
}

.mc-related-item {
  grid-template-columns: 70px 1fr !important;
}

.mc-related-item img {
  width: 70px !important;
  height: 70px !important;
  border-radius: 12px !important;
}

.mc-related-item h4 {
  color: var(--mc-green-900) !important;
  font-size: 13px !important;
  font-weight: 900 !important;
}

.mc-tags a {
  min-height: 28px;
  padding: 6px 10px !important;
  background: var(--mc-surface-soft) !important;
  color: var(--mc-text-muted) !important;
  font-size: 11px !important;
  font-weight: 800 !important;
}

.mc-article-pair {
  gap: 28px !important;
  margin-block: 52px !important;
}

.mc-article-pair > *,
.mc-article-layout > *,
.mc-quote-card > * {
  min-width: 0;
}

.mc-quote-card {
  grid-template-columns: 0.95fr 1.05fr !important;
  border-radius: 18px !important;
  background: var(--mc-green-900) !important;
}

.mc-quote-card__media img {
  height: 230px;
}

.mc-quote-card__content {
  padding: 38px !important;
}

.mc-quote-card__text {
  color: #FFFFFF !important;
  font-size: 30px !important;
  line-height: 1.18 !important;
}

.mc-quote-card__author {
  color: var(--mc-orange-500) !important;
  font-family: var(--mc-font-body) !important;
  font-size: 13px !important;
  font-style: normal !important;
  font-weight: 900 !important;
}

.mc-newsletter-inline {
  border: 1px solid var(--mc-border);
  border-radius: 18px !important;
  background: linear-gradient(135deg, var(--mc-surface-soft), var(--mc-green-100)) !important;
}

.mc-tools-grid {
  grid-template-columns: repeat(5, minmax(0, 1fr)) !important;
  gap: 14px !important;
}

.mc-tool {
  border: 1px solid var(--mc-border) !important;
  border-radius: 16px !important;
  background: var(--mc-surface) !important;
}

.mc-tool__stars,
.mc-comment__stars {
  color: var(--mc-yellow-500) !important;
}

.mc-comments-list {
  grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
  gap: 16px !important;
}

.mc-comment {
  border: 1px solid var(--mc-border) !important;
  border-radius: 16px !important;
  background: var(--mc-surface) !important;
}

.mc-shop-card {
  min-height: 280px !important;
  border-radius: 18px !important;
}

.mc-shop-card__overlay {
  background: linear-gradient(to top, rgba(6, 35, 31, .78), rgba(6, 35, 31, .12)) !important;
}

.mc-featured-in {
  display: flex !important;
  align-items: center;
  justify-content: space-between;
  gap: 32px;
  margin: 8px auto 0 !important;
  padding-block: 28px !important;
  border-top: 1px solid var(--mc-border);
  border-bottom: 1px solid var(--mc-border);
}

.mc-featured-in__label {
  color: var(--mc-text-muted) !important;
  font-size: 13px !important;
}

.mc-featured-in__list {
  flex: 1;
  color: var(--mc-green-900) !important;
}

.mc-cta-band {
  margin-top: 0 !important;
  padding: 38px var(--mc-container-padding) !important;
  background: var(--mc-green-900) !important;
  box-sizing: border-box;
  overflow: hidden;
}

.mc-cta-band__inner {
  width: min(100%, var(--mc-container, 1240px)) !important;
  max-width: var(--mc-container, 1240px) !important;
  grid-template-columns: 1fr 460px !important;
}

.mc-cta-band__form {
  min-height: 54px;
  padding: 6px;
  border-radius: var(--mc-radius-pill);
  background: #FFFFFF;
}

.mc-cta-band__form input {
  border-radius: var(--mc-radius-pill) !important;
}

.mc-tools-card,
.mc-comments-card,
.mc-featured-in,
.mc-cta-band {
  content-visibility: auto;
  contain-intrinsic-size: 600px;
}

@media (max-width: 1180px) {
  .mc-article-hero {
    grid-template-columns: 1fr !important;
  }

  .mc-article-layout {
    grid-template-columns: 180px minmax(0, 1fr) 280px !important;
    gap: 28px !important;
  }
}

@media (max-width: 1024px) {
  .mc-article-layout {
    display: flex !important;
    flex-direction: column;
    gap: 32px !important;
  }

  .mc-article-aside {
    position: static !important;
  }

  .mc-article-aside--left {
    display: contents;
  }

  .mc-toc {
    order: 1;
  }

  .mc-article-main {
    order: 2;
  }

  .mc-checklist-card {
    order: 3;
  }

  .mc-article-aside--right {
    order: 4;
    width: 100%;
  }

  .mc-article-pair,
  .mc-article-pair--tools,
  .mc-article-pair--comments {
    grid-template-columns: 1fr !important;
  }

  .mc-comments-list {
    grid-template-columns: 1fr !important;
  }
}

@media (max-width: 768px) {
  .mc-article-shell,
  .mc-article-hero,
  .mc-article-layout,
  .mc-article-pair,
  .mc-featured-in {
    padding-inline: 20px !important;
  }

  .mc-article .mc-breadcrumb {
    overflow-x: auto;
    white-space: nowrap;
  }

  .mc-article-hero {
    gap: 28px !important;
    padding-block: 32px 40px !important;
  }

  .mc-article-title.wp-block-post-title {
    font-size: clamp(42px, 12vw, 56px) !important;
    line-height: 1 !important;
  }

  .mc-article-hero__media {
    min-height: auto;
  }

  .mc-article-hero__image.wp-block-post-featured-image {
    height: auto;
    aspect-ratio: 1.1 / 1;
    border-radius: 22px !important;
  }

  .mc-article-hero__image img {
    border-radius: 22px !important;
  }

  .mc-article-jump {
    position: static !important;
    display: block !important;
    width: auto !important;
    margin-top: 14px;
  }

  .mc-article-actions {
    flex-wrap: wrap;
  }

  .mc-article-save {
    width: 100%;
  }

  .mc-toc {
    position: sticky;
    top: 68px;
    z-index: 40;
    width: 100vw;
    max-width: 100vw;
    margin-inline: calc(50% - 50vw);
    overflow-x: auto;
    border-right: 0 !important;
    border-left: 0 !important;
    border-radius: 0 !important;
    background: rgba(255, 253, 248, .96) !important;
    backdrop-filter: blur(12px);
  }

  .mc-toc__title {
    display: none;
  }

  .mc-toc__list {
    display: flex !important;
    gap: 10px !important;
    padding: 10px 20px !important;
    list-style: none !important;
  }

  .mc-toc__list li {
    flex: 0 0 auto;
  }

  .mc-toc__list a {
    display: inline-flex;
    align-items: center;
    min-height: 34px;
    padding-inline: 12px;
    border-radius: 999px;
    background: var(--mc-surface-soft);
    font-size: 12px;
    font-weight: 800;
  }

  .mc-article-section__title {
    font-size: 30px !important;
  }

  .mc-article-video {
    aspect-ratio: 1.35 / 1 !important;
  }

  .mc-habit {
    grid-template-columns: 34px 1fr 24px !important;
  }

  .mc-habit__thumb {
    grid-column: 2 / 4;
    width: 100% !important;
    height: auto !important;
    aspect-ratio: 1.7 / 1;
    margin-top: 8px;
  }

  .mc-quote-card {
    grid-template-columns: 1fr !important;
  }

  .mc-quote-card__media img {
    height: auto;
    aspect-ratio: 1.5 / 1;
  }

  .mc-quote-card__content {
    padding: 28px !important;
  }

  .mc-quote-card__text {
    font-size: 26px !important;
  }

  .mc-tools-grid {
    display: flex !important;
    gap: 14px !important;
    margin-inline: -20px;
    padding-inline: 20px;
    overflow-x: auto;
    scroll-snap-type: x mandatory;
  }

  .mc-tools-card {
    width: 100%;
    max-width: 100%;
    overflow: hidden;
  }

  .mc-quote-card,
  .mc-quote-card__media,
  .mc-quote-card__content {
    width: 100%;
    max-width: 100%;
  }

  .mc-tool {
    min-width: 170px;
    scroll-snap-align: start;
  }

  .mc-comments-card__head {
    display: block !important;
  }

  .mc-comments-card__sort {
    margin: 10px 0 0 !important;
  }

  .mc-comments-card__form {
    grid-template-columns: 1fr !important;
  }

  .mc-related-item {
    grid-template-columns: 82px 1fr !important;
  }

  .mc-related-item img {
    width: 82px !important;
    height: 82px !important;
  }

  .mc-featured-in {
    display: block !important;
  }

  .mc-featured-in__list {
    flex-wrap: nowrap !important;
    justify-content: flex-start !important;
    margin-top: 16px !important;
    overflow-x: auto;
    white-space: nowrap;
  }

  .mc-cta-band__inner {
    grid-template-columns: 1fr !important;
  }

  .mc-cta-band__form {
    grid-template-columns: 1fr !important;
    min-height: 0;
    border-radius: 18px;
  }
}
