﻿@import url("https://fonts.googleapis.com/css2?family=Cairo:wght@400;600;700;800&family=Dancing+Script:wght@400;500;600;700&family=Open+Sans:wght@400;600;700&display=swap");
:root {
  --site-header-height: 108px;
  --bg-color: #ffffff;
}

html[data-theme="dark"] {
  --bg-color: #121212;
  --dark-surface: #171513;
  --dark-surface-elevated: #1f1b16;
  --dark-surface-soft: rgba(255, 248, 232, 0.065);
  --dark-surface-strong: rgba(255, 248, 232, 0.11);
  --dark-border: rgba(242, 199, 107, 0.22);
  --dark-border-strong: rgba(242, 199, 107, 0.48);
  --dark-text: #fff8e8;
  --dark-text-soft: #e5d8c3;
  --dark-text-muted: #c7b89f;
  --dark-gold: #f2c76b;
  --dark-gold-strong: #ffe09a;
  --dark-shadow: 0 18px 42px rgba(0, 0, 0, 0.34);
}

html {
  scroll-behavior: smooth;
  scroll-padding-top: calc(var(--site-header-height) + 18px);
}

body {
  font-family: "Open Sans", sans-serif;
  color: #0c0c0c;
  background-color: var(--bg-color, #ffffff);
  overflow-x: hidden;
}

body.checkout-page [hidden],
body.admin-orders-page [hidden] {
  display: none !important;
}

.layout_padding {
  padding: 90px 0;
}

.layout_padding2 {
  padding: 75px 0;
}

.layout_padding2-top {
  padding-top: 75px;
}

.layout_padding2-bottom {
  padding-bottom: 75px;
}

.layout_padding-top {
  padding-top: 90px;
}

.layout_padding-bottom {
  padding-bottom: 90px;
}

h1,
h2 {
  font-family: 'Dancing Script', cursive;
}

.heading_container {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-box-align: start;
      -ms-flex-align: start;
          align-items: flex-start;
}

.heading_container h2 {
  position: relative;
  margin-bottom: 0;
  font-size: 2.5rem;
  font-weight: bold;
}

.heading_container h2 span {
  color: #ffbe33;
}

.heading_container p {
  margin-top: 10px;
  margin-bottom: 0;
}

.heading_container.heading_center {
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  text-align: center;
}

a,
a:hover,
a:focus {
  text-decoration: none;
}

a:hover,
a:focus {
  color: initial;
}

.btn,
.btn:focus {
  outline: none !important;
  -webkit-box-shadow: none;
          box-shadow: none;
}

/*header section*/
.hero_area {
  position: relative;
  min-height: 100vh;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
  padding-top: calc(var(--site-header-height) + 10px);
}

.bg-box {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  overflow: hidden;
}

.bg-box img {
  display: block;
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  -o-object-position: center center;
     object-position: center center;
  -webkit-transform: none;
          transform: none;
}

.bg-box picture {
  display: block;
  width: 100%;
  height: 100%;
}

.bg-box::after {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(115deg, rgba(11, 11, 11, 0.44), rgba(11, 11, 11, 0.2));
  pointer-events: none;
}

.sub_page .hero_area {
  min-height: auto;
}

.sub_page .hero_area .bg-box {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}

.sub_page .hero_area .bg-box img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  -o-object-position: right top;
     object-position: right top;
}

.header_section {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  z-index: 90;
  padding: 15px 0;
  -webkit-transition: padding 0.3s ease, -webkit-transform 0.3s ease;
  transition: padding 0.3s ease, -webkit-transform 0.3s ease;
  transition: padding 0.3s ease, transform 0.3s ease;
  transition: padding 0.3s ease, transform 0.3s ease, -webkit-transform 0.3s ease;
}

.header_section .container {
  width: min(1240px, calc(100% - 24px));
  max-width: none;
  background: rgba(12, 12, 12, 0.5);
  border: 1px solid rgba(255, 255, 255, 0.14);
  border-radius: 18px;
  box-shadow: 0 4px 15px rgba(0, 0, 0, 0.2);
  padding-left: 22px;
  padding-right: 24px;
  -webkit-backdrop-filter: blur(8px);
          backdrop-filter: blur(8px);
  -webkit-transition: background-color 0.3s ease, border-color 0.3s ease, -webkit-box-shadow 0.3s ease, -webkit-backdrop-filter 0.3s ease;
  transition: background-color 0.3s ease, border-color 0.3s ease, -webkit-box-shadow 0.3s ease, -webkit-backdrop-filter 0.3s ease;
  transition: background-color 0.3s ease, border-color 0.3s ease, box-shadow 0.3s ease, backdrop-filter 0.3s ease;
  transition: background-color 0.3s ease, border-color 0.3s ease, box-shadow 0.3s ease, backdrop-filter 0.3s ease, -webkit-box-shadow 0.3s ease, -webkit-backdrop-filter 0.3s ease;
}

.header_section .container-fluid {
  padding-right: 25px;
  padding-left: 25px;
}

.header_section.is_scrolled .container {
  background: rgba(12, 12, 12, 0.68);
  border-color: rgba(255, 255, 255, 0.12);
  box-shadow: 0 8px 20px rgba(0, 0, 0, 0.22);
}

.navbar-brand {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 14px;
  font-family: 'Dancing Script', cursive;
}

.navbar-brand img {
  width: 64px;
  height: 64px;
  padding: 7px;
  border-radius: 18px;
  object-fit: contain;
  background: #ffffff;
  border: 1px solid rgba(12, 12, 12, 0.12);
  box-shadow: 0 10px 24px rgba(0, 0, 0, 0.28);
  flex-shrink: 0;
}

.navbar-brand picture {
  display: inline-flex;
  flex-shrink: 0;
}

.navbar-brand span {
  font-weight: bold;
  font-size: 40px;
  color: #ffffff;
  line-height: 1;
  text-shadow: 0 2px 8px rgba(0, 0, 0, 0.35);
}

.custom_nav-container {
  padding: 0;
  width: 100%;
}

.custom_nav-container .navbar-collapse {
  flex-grow: 1;
  align-items: center;
}

.custom_nav-container .navbar-nav {
  padding-left: 0;
  margin: 0 auto;
  gap: 2px;
}

.custom_nav-container .navbar-nav .nav-item .nav-link {
  padding: 5px 20px;
  color: #ffffff;
  text-align: center;
  text-transform: uppercase;
  border-radius: 5px;
  font-weight: 600;
  text-shadow: 0 2px 8px rgba(0, 0, 0, 0.34);
  -webkit-transition: all 0.3s;
  transition: all 0.3s;
}

.custom_nav-container .navbar-nav .nav-item:hover .nav-link, .custom_nav-container .navbar-nav .nav-item.active .nav-link {
  color: #ffbe33;
}

.custom_nav-container .nav_search-btn {
  width: auto;
  height: auto;
  padding: 0;
  border: none;
  color: #ffffff;
  margin: 0 10px;
  text-shadow: 0 2px 8px rgba(0, 0, 0, 0.34);
}

.custom_nav-container .nav_search-btn:hover {
  color: #ffbe33;
}

.user_option {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: end;
      -ms-flex-pack: end;
          justify-content: flex-end;
  margin-left: auto;
}

.user_option a {
  margin: 0 10px;
}

.user_option .user_link {
  color: #ffffff;
  text-shadow: 0 2px 8px rgba(0, 0, 0, 0.34);
}

.user_option .user_link:hover {
  color: #ffbe33;
}

.user_option .cart_link {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}

.user_option .cart_link svg {
  width: 17px;
  height: auto;
  fill: #ffffff;
  margin-bottom: 2px;
  filter: drop-shadow(0 2px 6px rgba(0, 0, 0, 0.35));
}

.user_option .cart_link:hover svg {
  fill: #ffbe33;
}

.user_option .order_online {
  display: inline-block;
  padding: 8px 30px;
  background-color: #ffbe33;
  color: #ffffff;
  border-radius: 45px;
  font-weight: 700;
  box-shadow: 0 10px 22px rgba(0, 0, 0, 0.22);
  -webkit-transition: all 0.3s;
  transition: all 0.3s;
  border: none;
}

.user_option .order_online:hover {
  background-color: #e69c00;
}

.custom_nav-container .navbar-toggler {
  outline: none;
}

.custom_nav-container .navbar-toggler {
  padding: 0;
  width: 37px;
  height: 42px;
  -webkit-transition: all 0.3s;
  transition: all 0.3s;
}

.custom_nav-container .navbar-toggler span {
  display: block;
  width: 35px;
  height: 4px;
  background-color: #ffffff;
  margin: 7px 0;
  -webkit-transition: all 0.3s;
  transition: all 0.3s;
  position: relative;
  border-radius: 5px;
  transition: all 0.3s;
}

.custom_nav-container .navbar-toggler span::before, .custom_nav-container .navbar-toggler span::after {
  content: "";
  position: absolute;
  left: 0;
  height: 100%;
  width: 100%;
  background-color: #ffffff;
  top: -10px;
  border-radius: 5px;
  -webkit-transition: all 0.3s;
  transition: all 0.3s;
}

.custom_nav-container .navbar-toggler span::after {
  top: 10px;
}

.custom_nav-container .navbar-toggler[aria-expanded="true"] {
  -webkit-transform: rotate(360deg);
          transform: rotate(360deg);
}

.custom_nav-container .navbar-toggler[aria-expanded="true"] span {
  -webkit-transform: rotate(45deg);
          transform: rotate(45deg);
}

.custom_nav-container .navbar-toggler[aria-expanded="true"] span::before, .custom_nav-container .navbar-toggler[aria-expanded="true"] span::after {
  -webkit-transform: rotate(90deg);
          transform: rotate(90deg);
  top: 0;
}

/*end header section*/
/* slider section */
.slider_section {
  -webkit-box-flex: 1;
      -ms-flex: 1;
          flex: 1;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  position: relative;
  padding: 45px 0 75px 0;
}

.slider_section .row {
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}

.slider_section #customCarousel1 {
  width: 100%;
  position: relative;
}

.slider_section .carousel-inner {
  width: 100%;
}

.slider_section .carousel-item {
  min-height: 360px;
}

.slider_section .carousel-item .container,
.slider_section .carousel-item .row {
  min-height: inherit;
}

.slider_section .detail-box {
  color: #ffffff;
  margin-bottom: 145px;
  position: relative;
  overflow: hidden;
  background: linear-gradient(135deg, rgba(10, 16, 28, 0.68), rgba(10, 16, 28, 0.3));
  border: 1px solid rgba(255, 255, 255, 0.18);
  border-radius: 20px;
  -webkit-backdrop-filter: blur(2px);
  backdrop-filter: blur(2px);
  box-shadow: 0 16px 38px rgba(0, 0, 0, 0.26);
  padding: 24px 26px;
  max-width: 640px;
  min-height: 336px;
}

.slider_section .detail-box::before {
  content: "";
  position: absolute;
  inset: 0;
  border-radius: inherit;
  background: radial-gradient(circle at top left, rgba(255, 255, 255, 0.18), transparent 44%);
  pointer-events: none;
}

.slider_section .detail-box::after {
  content: "";
  position: absolute;
  width: 220px;
  height: 220px;
  right: -70px;
  top: -110px;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(255, 190, 51, 0.22), rgba(255, 190, 51, 0));
  filter: blur(10px);
  pointer-events: none;
}

.slider_section .detail-box h1 {
  position: relative;
  z-index: 1;
  font-size: 3.5rem;
  font-weight: bold;
  margin-bottom: 15px;
  line-height: 1.08;
  letter-spacing: 0.01em;
  text-shadow: 0 8px 24px rgba(0, 0, 0, 0.34);
}

.slider_section .detail-box p {
  position: relative;
  z-index: 1;
  font-size: 15px;
  line-height: 1.7;
  color: rgba(255, 255, 255, 0.92);
  text-shadow: 0 2px 10px rgba(0, 0, 0, 0.28);
}

.slider_section .detail-box a {
  position: relative;
  z-index: 1;
  display: inline-block;
  padding: 10px 45px;
  background-color: #ffbe33;
  color: #ffffff;
  border-radius: 45px;
  -webkit-transition: all 0.3s;
  transition: all 0.3s;
  border: none;
  margin-top: 10px;
  box-shadow: 0 10px 22px rgba(255, 190, 51, 0.18);
}

.slider_section .detail-box a:hover {
  background-color: #e69c00;
}

.slider_section .img-box img {
  width: 100%;
}

.hero-slider .hero-arrow {
  position: absolute;
  top: 50%;
  width: 46px;
  height: 46px;
  padding: 0;
  border-radius: 50%;
  border: 1px solid rgba(245, 189, 50, 0.28);
  background: rgba(20, 18, 14, 0.45);
  -webkit-backdrop-filter: blur(14px);
          backdrop-filter: blur(14px);
  color: #f6c453;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  cursor: pointer;
  opacity: 0.36;
  z-index: 5;
  -webkit-transform: translateY(-50%) scale(0.96);
          transform: translateY(-50%) scale(0.96);
  -webkit-box-shadow: 0 10px 26px rgba(0, 0, 0, 0.18), inset 0 1px 0 rgba(255, 255, 255, 0.08);
          box-shadow: 0 10px 26px rgba(0, 0, 0, 0.18), inset 0 1px 0 rgba(255, 255, 255, 0.08);
  -webkit-transition: opacity 0.25s ease, background-color 0.25s ease, border-color 0.25s ease, color 0.25s ease, -webkit-transform 0.25s ease, -webkit-box-shadow 0.25s ease;
  transition: opacity 0.25s ease, background-color 0.25s ease, border-color 0.25s ease, color 0.25s ease, -webkit-transform 0.25s ease, -webkit-box-shadow 0.25s ease;
  transition: opacity 0.25s ease, transform 0.25s ease, background-color 0.25s ease, border-color 0.25s ease, box-shadow 0.25s ease, color 0.25s ease;
  transition: opacity 0.25s ease, transform 0.25s ease, background-color 0.25s ease, border-color 0.25s ease, box-shadow 0.25s ease, color 0.25s ease, -webkit-transform 0.25s ease, -webkit-box-shadow 0.25s ease;
}

.hero-slider .hero-arrow i {
  line-height: 1;
}

.hero-slider .hero-arrow:hover,
.hero-slider .hero-arrow:focus {
  color: #ffd97a;
  background: rgba(245, 189, 50, 0.14);
  border-color: rgba(245, 189, 50, 0.55);
  -webkit-transform: translateY(-50%) scale(1.06);
          transform: translateY(-50%) scale(1.06);
  -webkit-box-shadow: 0 12px 28px rgba(0, 0, 0, 0.25), 0 0 24px rgba(246, 196, 83, 0.18);
          box-shadow: 0 12px 28px rgba(0, 0, 0, 0.25), 0 0 24px rgba(246, 196, 83, 0.18);
  outline: none;
}

.hero-slider:hover .hero-arrow,
.hero-slider:focus-within .hero-arrow,
.hero-slider.is-interacting .hero-arrow {
  opacity: 1;
  -webkit-transform: translateY(-50%) scale(1);
          transform: translateY(-50%) scale(1);
}

.hero-slider .hero-arrow.prev {
  left: 18px;
}

.hero-slider .hero-arrow.next {
  right: 18px;
}

.slider_section .carousel-indicators {
  position: unset;
  margin: 0;
  -webkit-box-pack: start;
      -ms-flex-pack: start;
          justify-content: flex-start;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}

.slider_section .carousel-indicators li {
  background-color: #ffffff;
  width: 12px;
  height: 12px;
  border-radius: 100%;
  opacity: 1;
}

.slider_section .carousel-indicators li.active {
  width: 20px;
  height: 20px;
  background-color: #ffbe33;
}

@media (max-width: 768px) {
  .hero-slider .hero-arrow {
    width: 38px;
    height: 38px;
    font-size: 13px;
    opacity: 0.32;
  }

  .hero-slider:hover .hero-arrow,
  .hero-slider:focus-within .hero-arrow,
  .hero-slider.is-interacting .hero-arrow {
    opacity: 1;
  }

  .hero-slider .hero-arrow.prev {
    left: 10px;
  }

  .hero-slider .hero-arrow.next {
    right: 10px;
  }
}

.food_section .filters_menu {
  padding: 0;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  list-style-type: none;
  margin: 45px 0 20px 0;
}

.food_section .filters_menu li {
  padding: 7px 25px;
  cursor: pointer;
  border-radius: 25px;
}

.food_section .filters_menu li.active {
  background-color: #222831;
  color: #ffffff;
}

.food_section .box {
  position: relative;
  margin-top: 25px;
  background-color: #ffffff;
  border-radius: 10px;
  color: #ffffff;
  border-radius: 15px;
  overflow: hidden;
  background: linear-gradient(to bottom, #f1f2f3 25px, #222831 25px);
}

.food_section .box.product-card {
  width: 100%;
  height: auto;
  display: block;
  border: 1px solid rgba(212, 175, 55, 0.18);
  box-shadow: 0 10px 28px rgba(0, 0, 0, 0.18);
  transition: transform 0.25s ease, box-shadow 0.25s ease;
  cursor: pointer;
}

.food_section .filters-content .all {
  display: block;
}

.food_section .box.product-card > div {
  display: flex;
  flex-direction: column;
  width: 100%;
  min-height: auto;
}

.food_section .box.product-card:hover {
  transform: none;
  box-shadow: 0 16px 36px rgba(0, 0, 0, 0.28);
}

.food_section .box.product-card .img-box {
  position: relative;
  background: #f1f2f3;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  height: 240px;
  border-radius: 0 0 0 45px;
  margin: -1px;
  padding: 14px;
  overflow: hidden;
}

.product-wishlist-btn,
.product-share-btn {
  position: absolute;
  top: 14px;
  z-index: 3;
  width: 38px;
  height: 38px;
  border: none;
  border-radius: 50%;
  background: #ffffff;
  color: #222831;
  display: -webkit-inline-box;
  display: -ms-inline-flexbox;
  display: inline-flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-shadow: 0 12px 22px rgba(0, 0, 0, 0.16);
          box-shadow: 0 12px 22px rgba(0, 0, 0, 0.16);
  cursor: pointer;
  -webkit-transition: background 0.2s ease, color 0.2s ease, -webkit-transform 0.2s ease;
  transition: background 0.2s ease, color 0.2s ease, -webkit-transform 0.2s ease;
  transition: background 0.2s ease, color 0.2s ease, transform 0.2s ease;
  transition: background 0.2s ease, color 0.2s ease, transform 0.2s ease, -webkit-transform 0.2s ease;
}

.product-wishlist-btn {
  right: 14px;
}

.product-share-btn {
  left: 14px;
}

.product-wishlist-btn:hover,
.product-wishlist-btn:focus,
.product-wishlist-btn.is_active,
.product-share-btn:hover,
.product-share-btn:focus {
  background: #ffbe33;
  color: #111111;
}

.product-wishlist-btn:hover,
.product-share-btn:hover {
  -webkit-transform: translateY(-1px);
          transform: translateY(-1px);
}

.food_section .box.product-card .img-box img {
  width: 100%;
  height: 100%;
  object-fit: contain;
  object-position: center;
  display: block;
  -webkit-transition: transform 0.32s ease;
  transition: transform 0.32s ease;
  -webkit-backface-visibility: hidden;
  backface-visibility: hidden;
  -webkit-transform-origin: center center;
  transform-origin: center center;
  will-change: transform;
}

.food_section .box.product-card .img-box picture {
  display: block;
  width: 100%;
  height: 100%;
}

.food_section .box.product-card .detail-box {
  flex: 1;
  display: flex;
  flex-direction: column;
  gap: 9px;
  padding: 18px 18px 16px;
}

.food_section .box.product-card .detail-box h5 {
  font-weight: 600;
  margin: 0;
  min-height: 44px;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

.food_section .box.product-card .detail-box h5.product_card_title {
  position: relative;
  cursor: pointer;
}

.food_section .box.product-card .detail-box h5.product_card_title a {
  outline-offset: 4px;
}

.product_title_tooltip {
  position: fixed;
  z-index: 260;
  width: max-content;
  max-width: min(360px, calc(100vw - 24px));
  padding: 12px 15px;
  border-radius: 14px;
  background: linear-gradient(135deg, rgba(255, 255, 255, 0.9), rgba(250, 244, 232, 0.78));
  border: 1px solid rgba(255, 255, 255, 0.68);
  color: #211a12;
  box-shadow: 0 18px 42px rgba(29, 21, 10, 0.18), inset 0 1px 0 rgba(255, 255, 255, 0.72);
  -webkit-backdrop-filter: blur(18px) saturate(145%);
          backdrop-filter: blur(18px) saturate(145%);
  font-size: 14px;
  font-weight: 700;
  line-height: 1.45;
  text-align: center;
  pointer-events: none;
  opacity: 0;
  visibility: hidden;
  transform: translateY(8px) scale(0.98);
  transition: opacity 0.2s ease, transform 0.2s ease, visibility 0.2s ease;
}

.product_title_tooltip::before {
  content: "";
  position: absolute;
  left: 50%;
  top: -6px;
  width: 12px;
  height: 12px;
  background: inherit;
  border-left: 1px solid rgba(255, 255, 255, 0.68);
  border-top: 1px solid rgba(255, 255, 255, 0.68);
  transform: translateX(-50%) rotate(45deg);
}

.product_title_tooltip:not(.is_below)::before {
  top: auto;
  bottom: -6px;
  border: none;
  border-right: 1px solid rgba(255, 255, 255, 0.68);
  border-bottom: 1px solid rgba(255, 255, 255, 0.68);
}

.product_title_tooltip.is_visible {
  opacity: 1;
  visibility: visible;
  transform: translateY(0) scale(1);
}

.product_title_tooltip.is_measuring {
  transition: none;
}

.food_section .box.product-card .detail-box p {
  font-size: 14px;
  margin: 0;
  min-height: 42px;
  line-height: 1.5;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

.food_section .box.product-card .detail-box h6 {
  margin: 0;
}

.food_section .box.product-card .options {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
  justify-content: space-between;
  margin-top: auto;
  padding-top: 3px;
}

.food_section .box .options a {
  width: 40px;
  height: 40px;
  border-radius: 100%;
  background: #ffbe33;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}

.food_section .box .options .product-link-btn {
  width: auto;
  height: auto;
  border-radius: 28px;
  padding: 8px 16px;
  color: #ffffff;
  font-size: 13px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.04em;
}

.food_section .box .options .product-link-btn svg {
  display: none;
}

.food_section .box .options .product-link-btn::after {
  content: none;
}

.food_section .box .options a svg {
  width: 18px;
  height: auto;
  fill: #ffffff;
}

.food_section .box.product-card:hover .img-box img {
  -webkit-transform: scale(1.08);
          transform: scale(1.08);
}

@media (hover: hover) and (pointer: fine) {
  .food_section .box.product-card:hover .img-box img,
  .food_section .box.product-card:focus-within .img-box img {
    -webkit-transform: scale(1.08);
            transform: scale(1.08);
  }
}

/* Make the product image link fill the image container without breaking layout */
.product-card-image-link {
  display: block;
  width: 100%;
  height: 100%;
  text-decoration: none;
  color: #ffffff;
}

.product-card-image-link .product-image-inner {
  display: block;
  width: 100%;
  height: 100%;
}

.product-card-image-link picture,
.product-card-image-link img {
  width: 100%;
  height: 100%;
}

.product-card-image-link picture {
  display: block;
}

.product-card-image-link img {
  object-fit: contain;
  object-position: center;
  display: block;
  -webkit-transition: transform 0.32s ease;
  transition: transform 0.32s ease;
}

/* Product card text colors â€” explicit to avoid black/inherit on dark backgrounds */
.food_section .box.product-card,
.food_section .box.product-card .detail-box {
  color: #ffffff !important;
}

/* Title â€” white */
.food_section .box.product-card .detail-box h5,
.food_section .box.product-card .detail-box h5 a {
  color: #ffffff !important;
}

/* Description â€” light gray */
.food_section .box.product-card .detail-box p {
  color: #cfcfcf !important;
}

/* Price and options â€” white */
.food_section .box.product-card .detail-box h6,
.food_section .box.product-card .detail-box .options h6,
.food_section .box.product-card .options h6 {
  color: #ffffff !important;
}

/* Rating text */
.product_card_rating_text {
  color: rgba(255,255,255,0.82) !important;
}

/* Links inside product cards â€” keep white (title overrides to blue) */
.food_section .box.product-card a,
.food_section .box.product-card a:link,
.food_section .box.product-card a:visited,
.food_section .box.product-card a:hover,
.food_section .box.product-card a:focus {
  color: #ffffff !important;
  text-decoration: none;
}

.food_section .box.product-card .options .product-link-btn,
.food_section .box.product-card .options .product-link-btn:link,
.food_section .box.product-card .options .product-link-btn:visited,
.food_section .box.product-card .options .product-link-btn:hover,
.food_section .box.product-card .options .product-link-btn:focus {
  color: #16110a !important;
}

.food_section .box.product-card[data-product-id="zumra-sushi-nori-sheets"] .img-box,
.food_section .box.product-card[data-product-url*="zumra-sushi-nori-sheets"] .img-box {
  padding: 8px;
}

.food_section .box.product-card[data-product-id="zumra-sushi-nori-sheets"] .img-box img,
.food_section .box.product-card[data-product-url*="zumra-sushi-nori-sheets"] .img-box img {
  -webkit-transform: scale(1.45);
          transform: scale(1.45);
  -webkit-transform-origin: center;
          transform-origin: center;
}

.food_section .box.product-card[data-product-id="zumra-sushi-nori-sheets"]:hover .img-box img,
.food_section .box.product-card[data-product-url*="zumra-sushi-nori-sheets"]:hover .img-box img {
  -webkit-transform: scale(1.5);
          transform: scale(1.5);
}

.about_section {
  background: #222831;
  color: #ffffff;
}

.about_section .row {
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}

.about_section .img-box {
  position: relative;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
}

.about_section .img-box img {
  width: 100%;
  max-width: 445px;
  position: relative;
  z-index: 2;
}

.about_section .img-box picture {
  display: inline-block;
  position: relative;
  z-index: 2;
}

.about_section .detail-box p {
  margin-top: 15px;
}

.about_section .detail-box a {
  display: inline-block;
  padding: 10px 45px;
  background-color: #ffbe33;
  color: #ffffff;
  border-radius: 45px;
  -webkit-transition: all 0.3s;
  transition: all 0.3s;
  border: none;
  margin-top: 15px;
}

.about_section .detail-box a:hover {
  background-color: #e69c00;
}

.about_article_section {
  background: #f7f7f4;
  color: #1f2733;
}

.about_article_section .container {
  max-width: 1180px;
}

.about_article_hero {
  max-width: 850px;
  margin: 0 auto 55px;
  text-align: center;
}

.about_article_hero h1 {
  margin: 14px 0 18px;
  color: #222831;
  font-size: 4.4rem;
  font-weight: bold;
  line-height: 0.98;
}

.about_article_hero p {
  max-width: 780px;
  margin: 0 auto;
  color: #4c5561;
  font-size: 1.1rem;
  line-height: 1.85;
}

.about_article_label {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 7px 16px;
  background: rgba(255, 190, 51, 0.15);
  border: 1px solid rgba(255, 190, 51, 0.38);
  border-radius: 45px;
  color: #9a690c;
  font-size: 0.84rem;
  font-weight: 700;
  letter-spacing: 0;
  text-transform: uppercase;
}

.about_article_grid {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 340px;
  gap: 34px;
  align-items: start;
}

.about_article_content {
  min-width: 0;
}

.about_article_content h2 {
  font-family: "Open Sans", sans-serif;
  margin-bottom: 14px;
  color: #222831;
  font-size: 1.45rem;
  font-weight: 700;
  line-height: 1.35;
}

.about_article_content p {
  margin-bottom: 18px;
  color: #4c5561;
  line-height: 1.85;
}

.about_article_block {
  padding-bottom: 34px;
  border-bottom: 1px solid rgba(34, 40, 49, 0.12);
}

.about_article_block + .about_article_block {
  padding-top: 34px;
}

.about_article_block:last-child {
  padding-bottom: 0;
  border-bottom: none;
}

.about_product_grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 14px;
  margin: 22px 0 20px;
}

.about_product_item {
  min-height: 150px;
  padding: 18px;
  background: #ffffff;
  border: 1px solid rgba(34, 40, 49, 0.1);
  border-radius: 8px;
  box-shadow: 0 12px 30px rgba(34, 40, 49, 0.06);
}

.about_product_item h3 {
  font-family: "Open Sans", sans-serif;
  margin-bottom: 9px;
  color: #222831;
  font-size: 1rem;
  font-weight: 700;
  line-height: 1.35;
}

.about_product_item p {
  margin-bottom: 0;
  font-size: 0.95rem;
  line-height: 1.7;
}

.about_article_sidebar {
  position: sticky;
  top: calc(var(--site-header-height) + 28px);
  display: grid;
  gap: 18px;
}

.about_image_panel,
.about_highlight_panel {
  overflow: hidden;
  background: #ffffff;
  border: 1px solid rgba(34, 40, 49, 0.1);
  border-radius: 8px;
  box-shadow: 0 14px 34px rgba(34, 40, 49, 0.08);
}

.about_image_panel {
  padding: 24px;
  text-align: center;
}

.about_image_panel img {
  width: 100%;
  max-width: 280px;
}

.about_image_panel picture {
  display: inline-block;
  width: 100%;
  max-width: 280px;
}

.about_highlight_panel {
  padding: 24px;
}

.about_highlight_panel h2 {
  font-family: "Open Sans", sans-serif;
  margin-bottom: 16px;
  color: #222831;
  font-size: 1.12rem;
  font-weight: 700;
  line-height: 1.35;
}

.about_highlight_panel p {
  margin: 18px 0 0;
  color: #56616e;
  font-size: 0.95rem;
  line-height: 1.75;
}

.about_highlight_panel ul {
  display: grid;
  gap: 10px;
  padding: 0;
  margin: 0;
  list-style: none;
}

.about_highlight_panel li {
  position: relative;
  padding-left: 24px;
  color: #303843;
  line-height: 1.55;
}

.about_highlight_panel li::before {
  content: "";
  position: absolute;
  top: 0.65em;
  left: 0;
  width: 8px;
  height: 8px;
  background: #ffbe33;
  border-radius: 50%;
  box-shadow: 0 0 0 4px rgba(255, 190, 51, 0.16);
}

.about_check_list {
  display: grid;
  gap: 12px;
  padding: 0;
  margin: 18px 0 0;
  list-style: none;
}

.about_check_list li {
  position: relative;
  padding-left: 30px;
  color: #303843;
  line-height: 1.7;
}

.about_check_list li::before {
  content: "";
  position: absolute;
  top: 0.72em;
  left: 0;
  width: 9px;
  height: 9px;
  background: #ffbe33;
  border-radius: 50%;
  box-shadow: 0 0 0 5px rgba(255, 190, 51, 0.16);
}

.about_cta_section {
  padding: 72px 0;
  background: #222831;
  color: #ffffff;
}

.about_cta_inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 28px;
}

.about_cta_inner h2 {
  font-family: "Open Sans", sans-serif;
  max-width: 760px;
  margin: 0;
  font-size: 1.65rem;
  font-weight: 700;
  line-height: 1.45;
}

.about_cta_inner a {
  display: inline-block;
  padding: 12px 32px;
  background-color: #ffbe33;
  color: #ffffff;
  border-radius: 45px;
  -webkit-transition: all 0.3s;
  transition: all 0.3s;
  border: none;
  flex-shrink: 0;
  font-weight: 700;
}

.about_cta_inner a:hover {
  background-color: #e69c00;
}

@media (max-width: 991px) {
  .about_article_grid {
    grid-template-columns: 1fr;
  }

  .about_article_sidebar {
    position: static;
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .about_image_panel {
    display: flex;
    align-items: center;
    justify-content: center;
  }

  .about_cta_inner {
    align-items: flex-start;
    flex-direction: column;
  }
}

@media (max-width: 767px) {
  .about_article_hero {
    margin-bottom: 40px;
  }

  .about_article_hero h1 {
    font-size: 3.2rem;
  }

  .about_article_hero p {
    font-size: 1rem;
    line-height: 1.75;
  }

  .about_article_content h2 {
    font-size: 1.3rem;
  }

  .about_product_grid,
  .about_article_sidebar {
    grid-template-columns: 1fr;
  }

  .about_cta_section {
    padding: 54px 0;
  }

  .about_cta_inner h2 {
    font-size: 1.35rem;
  }
}

@media (max-width: 430px) {
  .about_article_hero h1 {
    font-size: 2.75rem;
  }

  .about_product_item,
  .about_highlight_panel {
    padding: 20px;
  }
}

.how_to_order_section {
  position: relative;
  background: #ffffff;
}

.home_order_section {
  background: #f7f7f7;
}

.how_to_order_section .heading_container {
  margin-bottom: 25px;
}

.how_to_order_intro {
  max-width: 720px;
  margin: 10px 0 0;
  color: #555555;
  line-height: 1.7;
}

.order_section_title {
  margin: 0;
  color: #222831;
  font-size: 1.25rem;
  font-weight: 700;
}

.order_steps_grid {
  display: grid;
  grid-template-columns: repeat(5, minmax(0, 1fr));
  gap: 16px;
  margin-top: 30px;
}

.order_step_item {
  height: 100%;
  padding: 22px 18px;
  border-radius: 8px;
  background: #ffffff;
  border: 1px solid #ededed;
  -webkit-box-shadow: 0 10px 24px rgba(0, 0, 0, 0.06);
          box-shadow: 0 10px 24px rgba(0, 0, 0, 0.06);
  -webkit-transition: all 0.3s;
  transition: all 0.3s;
}

.order_step_item:hover {
  -webkit-transform: translateY(-4px);
          transform: translateY(-4px);
  border-color: rgba(255, 190, 51, 0.45);
  -webkit-box-shadow: 0 14px 30px rgba(0, 0, 0, 0.09);
          box-shadow: 0 14px 30px rgba(0, 0, 0, 0.09);
}

.order_step_icon {
  width: 48px;
  height: 48px;
  margin-bottom: 16px;
  border-radius: 50%;
  background: #222831;
  color: #ffbe33;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  font-size: 20px;
}

.order_step_item h5 {
  margin: 0 0 10px;
  color: #222831;
  font-size: 1rem;
  font-weight: 700;
  line-height: 1.35;
}

.order_step_item p {
  margin: 0;
  color: #555555;
  font-size: 0.95rem;
  line-height: 1.6;
}

.delivery_schedule_panel {
  margin-top: 40px;
  padding: 30px;
  border-radius: 8px;
  background: #222831;
  color: #ffffff;
}

.delivery_schedule_panel .heading_container {
  margin-bottom: 20px;
}

.delivery_schedule_panel .heading_container h2 {
  color: #ffffff;
}

.delivery_schedule_panel .heading_container p {
  color: #d6d6d6;
}

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

.delivery_schedule_item {
  min-height: 112px;
  padding: 18px;
  border-radius: 8px;
  background: rgba(255, 255, 255, 0.08);
  border: 1px solid rgba(255, 255, 255, 0.12);
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
}

.delivery_schedule_item span {
  margin-bottom: 12px;
  color: #ffbe33;
  font-weight: 700;
}

.delivery_schedule_item strong {
  color: #ffffff;
  font-size: 1rem;
  line-height: 1.4;
}

.wholesale_order_box {
  margin-top: 30px;
  padding: 28px;
  border-radius: 8px;
  background: #f7f7f7;
  border: 1px solid #ececec;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  gap: 24px;
}

.wholesale_order_kicker {
  color: #e69c00;
  font-size: 0.8rem;
  font-weight: 700;
  letter-spacing: 0;
  text-transform: uppercase;
}

.wholesale_order_box h3 {
  margin: 8px 0 10px;
  color: #222831;
  font-size: 1.35rem;
  font-weight: 700;
  line-height: 1.35;
}

.wholesale_order_box p {
  margin: 0;
  color: #555555;
  line-height: 1.7;
}

.wholesale_contact_btn,
.how_to_order_cta a {
  display: -webkit-inline-box;
  display: -ms-inline-flexbox;
  display: inline-flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  gap: 10px;
  padding: 12px 24px;
  border-radius: 45px;
  color: #ffffff;
  font-weight: 700;
  white-space: nowrap;
  -webkit-transition: all 0.3s;
  transition: all 0.3s;
}

.wholesale_contact_btn {
  -webkit-box-flex: 0;
      -ms-flex: 0 0 auto;
          flex: 0 0 auto;
  background: linear-gradient(135deg, #24201a, #11100e);
  border: 1px solid rgba(212, 175, 55, 0.36);
  color: #f7d577;
}

.wholesale_contact_btn:hover {
  background: linear-gradient(135deg, #f7d577, #b9872c);
  color: #16110a;
}

.how_to_order_cta {
  margin-top: 30px;
}

.how_to_order_cta a {
  background: #ffbe33;
}

.how_to_order_cta a:hover {
  background: #e69c00;
  color: #ffffff;
}

@media (max-width: 1199px) {
  .order_steps_grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }

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

@media (max-width: 767px) {
  .order_steps_grid,
  .delivery_schedule_grid {
    grid-template-columns: 1fr;
  }

  .delivery_schedule_panel,
  .wholesale_order_box {
    padding: 22px;
  }

  .wholesale_order_box {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    -webkit-box-align: stretch;
        -ms-flex-align: stretch;
            align-items: stretch;
  }

  .wholesale_contact_btn,
  .how_to_order_cta a {
    width: 100%;
    white-space: normal;
    text-align: center;
  }
}

/* client section start */
.client_section .heading_container {
  margin-bottom: 30px;
}

.client_section .box {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  margin: 15px;
}

.client_section .box .img-box {
  position: relative;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  width: 115px;
  position: relative;
  margin-top: 30px;
}

.client_section .box .img-box img {
  border-radius: 100%;
  border: 5px solid #ffbe33;
  position: relative;
}

.client_section .box .img-box .client_icon {
  width: 95px;
  height: 95px;
  border-radius: 50%;
  border: 5px solid #ffbe33;
  background: #ffffff;
  color: #222831;
  position: relative;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  font-size: 34px;
  -webkit-box-shadow: 0 8px 18px rgba(0, 0, 0, 0.08);
          box-shadow: 0 8px 18px rgba(0, 0, 0, 0.08);
}

.client_section .box .img-box::before {
  content: "";
  position: absolute;
  left: 50%;
  top: 0;
  width: 20px;
  height: 20px;
  background-color: #ffbe33;
  -webkit-transform: rotate(45deg) translateX(-50%);
          transform: rotate(45deg) translateX(-50%);
}

.client_section .box .detail-box {
  background-color: #222831;
  color: #ffffff;
  padding: 25px 25px 15px 25px;
  border-radius: 5px;
  min-height: 220px;
}

.client_section .box .detail-box h6 {
  font-weight: 600;
  font-size: 18px;
  margin: 15px 0 5px 0;
}

.client_section .box .detail-box p {
  margin-bottom: 0;
  font-size: 15px;
  margin-bottom: 10px;
  line-height: 1.7;
}

.client_section .box .detail-box h6 + p {
  color: #ffbe33;
  font-size: 14px;
  font-weight: 600;
  line-height: 1.4;
}

.client_section .owl-carousel .owl-nav {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  margin-top: 45px;
  padding: 0 15px;
}

.client_section .owl-carousel .owl-nav .owl-prev,
.client_section .owl-carousel .owl-nav .owl-next {
  width: 45px;
  height: 45px;
  background-color: #ffbe33;
  color: #ffffff;
  outline: none;
  bottom: 0px;
  font-size: 24px;
  margin: 0 5px;
  border-radius: 100%;
}

@media (max-width: 767px) {
  .client_section .box .detail-box {
    min-height: auto;
  }

  .client_section .box .img-box .client_icon {
    width: 84px;
    height: 84px;
    font-size: 30px;
  }
}

/* client section end */
.mobile_app_section {
  position: relative;
  padding: 28px 0 34px;
  overflow: hidden;
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0), rgba(255, 248, 232, 0.72)),
    #ffffff;
}

.mobile_app_section .container {
  position: relative;
  z-index: 1;
}

.mobile_app_card {
  position: relative;
  overflow: hidden;
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  align-items: center;
  gap: 22px;
  max-width: 980px;
  margin: 0 auto;
  padding: 22px 26px;
  border: 1px solid rgba(188, 132, 32, 0.18);
  border-radius: 22px;
  background:
    linear-gradient(135deg, rgba(255, 255, 255, 0.84), rgba(255, 248, 232, 0.62)),
    rgba(255, 255, 255, 0.62);
  -webkit-backdrop-filter: blur(16px) saturate(135%);
          backdrop-filter: blur(16px) saturate(135%);
  box-shadow:
    0 14px 34px rgba(53, 36, 8, 0.12),
    inset 0 1px 0 rgba(255, 255, 255, 0.76);
}

.mobile_app_card::before {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(90deg, rgba(255, 190, 51, 0.16), transparent 46%);
  pointer-events: none;
}

.mobile_app_content,
.mobile_app_store_badges {
  position: relative;
  z-index: 1;
}

.mobile_app_badge {
  display: inline-flex;
  align-items: center;
  min-height: 24px;
  padding: 0 10px;
  border: 1px solid rgba(188, 132, 32, 0.34);
  border-radius: 999px;
  background: rgba(255, 190, 51, 0.14);
  color: #8a5c09;
  font-size: 10px;
  font-weight: 900;
  letter-spacing: 0.12em;
}

.mobile_app_content h2 {
  margin: 8px 0 6px;
  color: #191611;
  font-family: "Open Sans", sans-serif;
  font-size: clamp(1.55rem, 2.5vw, 2rem);
  font-weight: 800;
  line-height: 1.12;
}

.mobile_app_content p {
  max-width: 540px;
  margin: 0;
  color: #5e5344;
  font-size: 0.95rem;
  line-height: 1.55;
}

.mobile_app_store_badges {
  display: flex;
  justify-content: flex-end;
  gap: 10px;
}

.mobile_app_store_badge {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  min-width: 142px;
  min-height: 48px;
  padding: 7px 13px;
  border: 1px solid rgba(22, 18, 12, 0.12);
  border-radius: 14px;
  background: #16120c;
  color: #ffffff;
  box-shadow: 0 10px 22px rgba(22, 18, 12, 0.18);
  cursor: not-allowed;
  opacity: 0.92;
}

.mobile_app_store_badge i {
  width: 20px;
  font-size: 20px;
  line-height: 1;
}

.mobile_app_store_badge span {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  color: inherit;
  font-size: 13px;
  font-weight: 800;
  line-height: 1.12;
}

.mobile_app_store_badge small {
  margin-bottom: 2px;
  color: #ffcf72;
  font-size: 9px;
  font-weight: 900;
  letter-spacing: 0.1em;
  text-transform: uppercase;
}

html[data-theme="dark"] .mobile_app_section,
body.theme_dark .mobile_app_section,
body.dark-mode .mobile_app_section {
  background:
    linear-gradient(180deg, rgba(17, 16, 14, 0), rgba(31, 24, 16, 0.8)),
    #11100e;
}

html[data-theme="dark"] .mobile_app_card,
body.theme_dark .mobile_app_card,
body.dark-mode .mobile_app_card {
  border-color: rgba(242, 199, 107, 0.18);
  background:
    linear-gradient(135deg, rgba(36, 29, 22, 0.86), rgba(24, 20, 16, 0.68)),
    rgba(25, 20, 15, 0.74);
  box-shadow:
    0 16px 36px rgba(0, 0, 0, 0.3),
    inset 0 1px 0 rgba(255, 255, 255, 0.06);
}

html[data-theme="dark"] .mobile_app_badge,
body.theme_dark .mobile_app_badge,
body.dark-mode .mobile_app_badge {
  border-color: rgba(242, 199, 107, 0.36);
  background: rgba(242, 199, 107, 0.13);
  color: #ffe09a;
}

html[data-theme="dark"] .mobile_app_content h2,
body.theme_dark .mobile_app_content h2,
body.dark-mode .mobile_app_content h2 {
  color: #fff8e8;
}

html[data-theme="dark"] .mobile_app_content p,
body.theme_dark .mobile_app_content p,
body.dark-mode .mobile_app_content p {
  color: rgba(255, 248, 232, 0.72);
}

html[data-theme="dark"] .mobile_app_store_badge,
body.theme_dark .mobile_app_store_badge,
body.dark-mode .mobile_app_store_badge {
  border-color: rgba(242, 199, 107, 0.22);
  background: rgba(5, 4, 3, 0.86);
  box-shadow: 0 16px 34px rgba(0, 0, 0, 0.34);
}

@media (max-width: 991px) {
  .mobile_app_card {
    grid-template-columns: 1fr;
    gap: 16px;
  }

  .mobile_app_store_badges {
    justify-content: flex-start;
  }
}

@media (max-width: 575px) {
  .mobile_app_section {
    padding: 10px 0 14px;
  }

  .mobile_app_card {
    gap: 14px;
    padding: 18px;
    border-radius: 18px;
  }

  .mobile_app_store_badges {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 8px;
  }

  .mobile_app_store_badge {
    width: 100%;
    min-width: 0;
    min-height: 44px;
    padding: 7px 10px;
    justify-content: center;
  }

  .mobile_app_store_badge span {
    font-size: 12px;
  }
}

.contact_section .heading_container {
  margin-bottom: 45px;
}

.contact_section .form_container .form-group {
  margin-bottom: 25px;
}

.contact_section .form_container input {
  width: 100%;
  border: none;
  height: 50px;
  padding-left: 25px;
  background-color: transparent;
  border: 1px solid #ccc;
  outline: none;
  color: #1f2733;
  border-radius: 5px;
}

.contact_section .form_container input::-webkit-input-placeholder {
  color: #222222;
}

.contact_section .form_container input:-ms-input-placeholder {
  color: #222222;
}

.contact_section .form_container input::-ms-input-placeholder {
  color: #222222;
}

.contact_section .form_container input::placeholder {
  color: #222222;
}

.contact_section .form_container input.message-box {
  height: 120px;
  border-radius: 5px;
}

.contact_section .form_container .btn-box {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
}

.contact_section .form_container button {
  margin-top: 10px;
  border: none;
  text-transform: uppercase;
  display: inline-block;
  padding: 10px 55px;
  background-color: #ffbe33;
  color: #ffffff;
  border-radius: 0px;
  -webkit-transition: all 0.3s;
  transition: all 0.3s;
  border: none;
}

.contact_section .form_container button:hover {
  background-color: #e69c00;
}

/* footer section*/
.footer_section {
  background-color: #222831;
  color: #ffffff;
  padding: 75px 0 40px 0;
  text-align: center;
}

.footer_section h4 {
  font-size: 28px;
}

.footer_section h4,
.footer_section .footer-logo {
  font-weight: 600;
  margin-bottom: 20px;
  font-family: 'Dancing Script', cursive;
}

.footer_section p {
  color: #dbdbdb;
}

.footer_section .footer-col {
  margin-bottom: 30px;
}

.footer_section .footer_contact .contact_link_box {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
}

.footer_section .footer_contact .contact_link_box a {
  margin: 5px 0;
  color: #ffffff;
}

.footer_section .footer_contact .contact_link_box a i {
  margin-right: 5px;
}

.footer_section .footer_contact .contact_link_box a:hover {
  color: #ffbe33;
}

.footer_section .footer-logo {
  display: block;
  font-weight: bold;
  font-size: 38px;
  line-height: 1;
  color: #ffffff;
}

.footer_section .footer_social {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  margin-top: 20px;
  margin-bottom: 10px;
}

.footer_section .footer_social a {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  color: #222831;
  width: 30px;
  height: 30px;
  border-radius: 100%;
  background-color: #ffffff;
  border-radius: 100%;
  margin: 0 2.5px;
  font-size: 18px;
}

.footer_section .footer_social a:hover {
  color: #ffbe33;
}

.footer_section .footer-info {
  text-align: center;
  margin-top: 25px;
}

.footer_section .footer-info p {
  color: #ffffff;
  margin: 0;
}

.footer_section .footer-info p a {
  color: #ffffff;
}

.product_details_section {
  background: #0f0f0f;
}

.product_gallery,
.product_info_card {
  background: #1a1a1a;
  border: 1px solid rgba(212, 175, 55, 0.22);
  border-radius: 18px;
  padding: 24px;
}

.product_main_image {
  position: relative;
  background: #ffffff;
  border-radius: 14px;
  height: 380px;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 14px;
  overflow: hidden;
  cursor: zoom-in;
}

.product_main_image img {
  width: 100%;
  height: 100%;
  max-width: 100%;
  max-height: 100%;
  object-fit: contain;
  object-position: center;
  transform: scale(1.18);
  transform-origin: center center;
  transition: transform 0.4s ease;
  will-change: transform;
}

.product_main_image picture {
  display: block;
  width: 100%;
  height: 100%;
}

.product_main_image:hover img {
  transform: scale(1.24);
}

.product_main_image[data-product-id^="bamboo-sushi-rolling-mat"] img {
  transform: scale(1.02);
}

.product_main_image[data-product-id^="bamboo-sushi-rolling-mat"]:hover img {
  transform: scale(1.08);
}

@media (prefers-reduced-motion: reduce) {
  .product_main_image img {
    transition: none;
  }

  .product_main_image:hover img {
    transform: scale(1.18);
  }
}

.product_thumbs {
  margin-top: 16px;
  display: flex;
  gap: 12px;
  flex-wrap: wrap;
}

.thumb_btn {
  border: 1px solid rgba(212, 175, 55, 0.25);
  background: #111111;
  border-radius: 10px;
  width: 82px;
  height: 82px;
  padding: 8px;
}

.thumb_btn.active {
  border-color: #d4af37;
}

.thumb_btn img {
  width: 100%;
  height: 100%;
  object-fit: contain;
  object-position: center;
}

.thumb_btn picture {
  display: block;
  width: 100%;
  height: 100%;
}

.product_lightbox {
  position: fixed;
  inset: 0;
  z-index: 140;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 24px;
}

.product_lightbox_backdrop {
  position: absolute;
  inset: 0;
  background: rgba(4, 6, 11, 0.78);
  -webkit-backdrop-filter: blur(6px);
          backdrop-filter: blur(6px);
}

.product_lightbox_dialog {
  position: relative;
  z-index: 1;
  width: min(1180px, 100%);
  height: min(88vh, 920px);
  display: flex;
  flex-direction: column;
  padding: 18px;
  border-radius: 28px;
  background: rgba(13, 13, 13, 0.94);
  border: 1px solid rgba(255, 255, 255, 0.14);
  box-shadow: 0 24px 60px rgba(0, 0, 0, 0.32);
  overflow: hidden;
}

.product_lightbox_toolbar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  margin-bottom: 14px;
}

.product_lightbox_zoom_group {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 6px;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.08);
  border: 1px solid rgba(255, 255, 255, 0.12);
}

.product_lightbox_control,
.product_lightbox_close {
  width: 44px;
  height: 44px;
  border: 1px solid rgba(255, 255, 255, 0.14);
  border-radius: 50%;
  background: rgba(255, 255, 255, 0.08);
  color: #ffffff;
  display: inline-flex;
  align-items: center;
  justify-content: center;
}

.product_lightbox_control:hover,
.product_lightbox_control:focus,
.product_lightbox_close:hover,
.product_lightbox_close:focus {
  background: rgba(255, 190, 51, 0.18);
  border-color: rgba(255, 190, 51, 0.3);
  color: #ffffff;
}

.product_lightbox_zoom_value {
  min-width: 62px;
  text-align: center;
  color: #f4efe3;
  font-size: 14px;
  font-weight: 700;
}

.product_lightbox_stage {
  flex: 1;
  min-height: 0;
  overflow: auto;
  border-radius: 22px;
  background: rgba(255, 255, 255, 0.03);
  padding: 24px;
  display: flex;
  align-items: center;
  justify-content: center;
}

.product_lightbox_stage img {
  display: block;
  width: auto;
  max-width: min(100%, 1100px);
  height: auto;
  border-radius: 18px;
  background: #ffffff;
  box-shadow: 0 18px 38px rgba(0, 0, 0, 0.24);
}

.product_info_card h1 {
  color: #f4efe3;
  font-family: 'Kaushan Script', cursive;
  font-size: 2.1rem;
  font-weight: 400;
  letter-spacing: 0.5px;
  line-height: 1.2;
  margin-bottom: 8px;
}

.product_info_card p {
  color: #d6d6d6;
}

#productDescription {
  margin: 0 0 8px;
  line-height: 1.8;
}

.product_meta_section {
  margin-top: 22px;
  padding-top: 20px;
  border-top: 1px solid rgba(212, 175, 55, 0.18);
}

.product_meta_title {
  margin: 0;
  color: #f4efe3;
  font-family: 'Kaushan Script', cursive;
  font-size: 1rem;
  font-weight: 400;
  letter-spacing: 0.5px;
  line-height: 1.2;
}

.product_feature_list,
.product_story_list {
  margin: 14px 0 0;
  padding: 0;
  list-style: none;
  display: grid;
  gap: 10px;
}

.product_feature_list li,
.product_story_list li {
  position: relative;
  padding-left: 18px;
  color: #d6d6d6;
  line-height: 1.7;
}

.product_feature_list li::before,
.product_story_list li::before {
  content: "";
  position: absolute;
  top: 0.7em;
  left: 0;
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: #d4af37;
  box-shadow: 0 0 0 4px rgba(212, 175, 55, 0.12);
}

.product_spec_list {
  margin: 14px 0 0;
  display: grid;
  gap: 10px;
}

.product_spec_row {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 16px;
  padding: 14px 16px;
  border-radius: 16px;
  background: #111111;
  border: 1px solid rgba(255, 255, 255, 0.04);
}

.product_spec_row dt {
  margin: 0;
  color: #f4efe3;
  font-weight: 700;
}

.product_spec_row dd {
  margin: 0;
  color: #d6d6d6;
  text-align: right;
}

.product_unit_price,
.product_total_price {
  font-size: 1.2rem;
  color: #f4efe3 !important;
  margin-top: 16px;
  margin-bottom: 12px;
}

.product_unit_price span,
.product_total_price span {
  color: #d4af37;
  font-weight: 700;
}

.quantity_wrap {
  margin-top: 18px;
}

.quantity_wrap span {
  color: #f4efe3;
  font-weight: 600;
}

.qty_controls {
  margin-top: 10px;
  display: inline-flex;
  align-items: center;
  border: 1px solid rgba(212, 175, 55, 0.25);
  border-radius: 999px;
  overflow: hidden;
}

.qty_controls button {
  width: 42px;
  height: 42px;
  border: none;
  background: #111111;
  color: #f4efe3;
  font-size: 24px;
  line-height: 1;
}

.qty_controls input {
  width: 60px;
  border: none;
  background: #161616;
  color: #ffffff;
  text-align: center;
  font-weight: 700;
}

.product_checkout_btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 9px;
  min-height: 48px;
  padding: 12px 20px;
  border: 1px solid rgba(242, 199, 107, 0.46);
  border-radius: 999px;
  background: linear-gradient(135deg, #f7d577, #b9872c);
  color: #16110a;
  font-weight: 800;
  line-height: 1.1;
  box-shadow: 0 14px 30px rgba(185, 135, 44, 0.2);
  cursor: pointer;
  transition: transform 0.2s ease, box-shadow 0.2s ease, border-color 0.2s ease;
}

.product_checkout_btn:hover,
.product_checkout_btn:focus {
  color: #11100e;
  border-color: rgba(255, 230, 166, 0.76);
  box-shadow: 0 18px 34px rgba(185, 135, 44, 0.28);
  transform: translateY(-2px);
}

body.search_open,
body.cart_open,
body.delivery_schedule_open,
body.checkout_open,
body.lightbox_open {
  overflow: hidden;
}

.user_option {
  gap: 12px;
  flex-wrap: nowrap;
  overflow: visible;
}

.user_option a,
.user_option form,
.user_option .auth_shell {
  margin: 0;
  -ms-flex-negative: 0;
      flex-shrink: 0;
}

.user_option form,
.user_option .auth_shell {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}

.user_option .cart_link {
  position: relative;
  overflow: visible;
  width: 44px;
  min-height: 44px;
  border-radius: 50%;
  background: rgba(255, 255, 255, 0.08);
  border: 1px solid rgba(255, 255, 255, 0.18);
  -webkit-box-shadow: 0 8px 20px rgba(0, 0, 0, 0.18);
          box-shadow: 0 8px 20px rgba(0, 0, 0, 0.18);
}

.user_option .cart_link,
.user_option .nav_search-btn,
.user_option .order_online {
  display: -webkit-inline-box;
  display: -ms-inline-flexbox;
  display: inline-flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
}

.user_option .cart_link:hover,
.user_option .nav_search-btn:hover {
  background: rgba(255, 190, 51, 0.16);
  border-color: rgba(255, 190, 51, 0.4);
  color: #ffffff;
}

.user_option .cart_link svg {
  margin-bottom: 0;
}

.user_option .nav_search-btn {
  width: 44px;
  min-height: 44px;
  margin: 0;
  border-radius: 50%;
  background: rgba(255, 255, 255, 0.08);
  border: 1px solid rgba(255, 255, 255, 0.18);
  -webkit-box-shadow: 0 8px 20px rgba(0, 0, 0, 0.18);
          box-shadow: 0 8px 20px rgba(0, 0, 0, 0.18);
}

.user_option .nav_search-btn i {
  line-height: 1;
}

.user_option .order_online {
  min-height: 44px;
  white-space: nowrap;
  padding: 8px 24px;
}

.cart_count_badge {
  position: absolute;
  top: -8px;
  right: -12px;
  z-index: 10;
  min-width: 20px;
  height: 20px;
  padding: 0 5px;
  border-radius: 999px;
  border: 1px solid #ffffff;
  background: #ff3b30;
  color: #ffffff;
  font-size: 11.5px;
  font-weight: 700;
  line-height: 18px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  box-shadow: 0 8px 18px rgba(255, 59, 48, 0.42), 0 2px 6px rgba(0, 0, 0, 0.28);
  text-align: center;
}

.wishlist_nav_link {
  position: relative;
}

.wishlist_count_badge {
  position: absolute;
  top: 0;
  right: 8px;
  min-width: 18px;
  height: 18px;
  padding: 0 5px;
  border-radius: 999px;
  background: #ffbe33;
  color: #111111;
  font-size: 11px;
  font-weight: 800;
  line-height: 18px;
  text-align: center;
  -webkit-box-shadow: 0 8px 16px rgba(255, 190, 51, 0.24);
          box-shadow: 0 8px 16px rgba(255, 190, 51, 0.24);
}

.auth_shell {
  position: relative;
}

.auth_button {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  min-height: 44px;
  padding: 6px 14px 6px 8px;
  border-radius: 999px;
  border: 1px solid rgba(255, 255, 255, 0.2);
  background: rgba(255, 255, 255, 0.08);
  color: #ffffff;
  box-shadow: 0 8px 20px rgba(0, 0, 0, 0.18);
  cursor: pointer;
}

.auth_button:hover,
.auth_button:focus {
  color: #ffffff;
}

.auth_avatar,
.auth_dropdown_user_avatar,
.review_notice_avatar,
.review_card_avatar {
  width: 34px;
  height: 34px;
  flex-shrink: 0;
  border-radius: 50%;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: rgba(255, 255, 255, 0.15);
  color: #ffffff;
  overflow: hidden;
}

.auth_avatar img,
.auth_dropdown_user_avatar img,
.review_notice_avatar img,
.review_card_avatar img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.auth_button_text {
  max-width: 140px;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  font-size: 14px;
  font-weight: 600;
}

.auth_chevron {
  font-size: 14px;
  opacity: 0.8;
}

.auth_dropdown {
  position: absolute;
  right: 0;
  top: calc(100% + 12px);
  left: auto;
  width: min(220px, calc(100vw - 24px));
  z-index: 30;
}

.auth_dropdown_card {
  padding: 12px;
  border: 1px solid rgba(34, 40, 49, 0.1);
  border-radius: 14px;
  background: #ffffff;
  color: #222831;
  box-shadow: 0 16px 34px rgba(24, 18, 9, 0.16);
}

.auth_dropdown_card p {
  margin-bottom: 12px;
  color: #5f6775;
  font-size: 12.5px;
  line-height: 1.5;
}

.auth_dropdown_card_user {
  display: flex;
  flex-direction: column;
  gap: 10px;
}

.auth_dropdown_user {
  display: flex;
  gap: 9px;
  align-items: center;
  min-width: 0;
}

.auth_dropdown_card_user .auth_dropdown_user_avatar {
  width: 32px;
  height: 32px;
  border: 1px solid rgba(166, 113, 24, 0.12);
  background: rgba(255, 190, 51, 0.18);
  color: #8a5a00;
  box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.72);
}

.auth_dropdown_user_meta {
  min-width: 0;
}

.auth_dropdown_user strong,
.review_notice_card strong {
  display: block;
  font-size: 13.5px;
  color: #1f2733;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.auth_dropdown_user span,
.review_notice_card p {
  display: block;
  font-size: 11.5px;
  color: #667085;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.auth_dropdown_btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 38px;
  padding: 10px 14px;
  border-radius: 12px;
  border: none;
  background: #ffbe33;
  color: #111111;
  font-weight: 700;
  box-shadow: 0 12px 24px rgba(255, 190, 51, 0.26);
}

.auth_dropdown_actions {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 6px;
}

.auth_dropdown_icon_button {
  display: inline-flex;
  min-width: 0;
  min-height: 36px;
  align-items: center;
  justify-content: center;
  gap: 5px;
  padding: 7px 6px;
  border: 1px solid rgba(34, 40, 49, 0.1);
  border-radius: 10px;
  background: #fffaf0;
  color: #222831;
  font-size: 11px;
  font-weight: 800;
  line-height: 1;
  cursor: pointer;
  transition: background-color 0.18s ease, border-color 0.18s ease, color 0.18s ease;
}

.auth_dropdown_icon_button i {
  flex: 0 0 auto;
  color: #bd7d08;
  font-size: 13px;
  line-height: 1;
}

.auth_dropdown_icon_button span {
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.auth_dropdown_icon_button:hover,
.auth_dropdown_icon_button:focus {
  border-color: rgba(255, 190, 51, 0.34);
  background: #fff1cb;
  color: #111111;
  outline: none;
}

.auth_dropdown_link {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 42px;
  padding: 10px 16px;
  border-radius: 999px;
  border: 1px solid rgba(34, 40, 49, 0.12);
  background: #fffaf0;
  color: #222831;
  font-weight: 800;
}

.auth_dropdown_link:hover,
.auth_dropdown_link:focus {
  color: #111111;
  background: #fff3d3;
}

.auth_dropdown_btn:hover,
.auth_dropdown_btn:focus {
  color: #111111;
  background: #f2b019;
}

.auth_dropdown_btn_secondary {
  background: #eef2f7;
  box-shadow: none;
  color: #222831;
}

.site_search_panel,
.offers_page_section {
  background: #0f0f0f;
}

.offers_page_header {
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  gap: 20px;
  margin-bottom: 34px;
}

.offers_page_header .heading_container h1 {
  margin: 0;
  color: #f4efe3;
  font-family: 'Kaushan Script', cursive;
  font-size: 2.7rem;
  line-height: 1.1;
}

.offers_page_header .heading_container p {
  margin: 12px 0 0;
  color: #d6d6d6;
  line-height: 1.7;
}

.offers_page_count {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 40px;
  padding: 0 16px;
  border: 1px solid rgba(255, 190, 51, 0.32);
  border-radius: 999px;
  background: rgba(255, 190, 51, 0.1);
  color: #ffda84;
  font-size: 13px;
  font-weight: 900;
  white-space: nowrap;
}

.offers_page_grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(min(100%, 320px), 1fr));
  gap: 22px;
}

.offers_page_card {
  min-width: 0;
  overflow: hidden;
  border: 1px solid rgba(255, 190, 51, 0.18);
  border-radius: 22px;
  background: linear-gradient(180deg, rgba(255, 248, 232, 0.08), rgba(255, 248, 232, 0.03)), #171717;
  box-shadow: 0 18px 38px rgba(0, 0, 0, 0.22);
  cursor: pointer;
}

.offers_page_image {
  position: relative;
  min-height: 250px;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 22px;
  background: linear-gradient(180deg, #ffffff, #f6efe1);
}

.offers_page_image img {
  width: 100%;
  max-width: 210px;
  max-height: 200px;
  -o-object-fit: contain;
     object-fit: contain;
}

.offers_page_image picture {
  display: block;
  width: 100%;
  height: 100%;
}

.offers_page_badge {
  position: absolute;
  top: 16px;
  left: 16px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 30px;
  padding: 0 12px;
  border-radius: 999px;
  background: linear-gradient(135deg, #ff3f3f, #a70f18);
  color: #ffffff;
  font-size: 12px;
  font-weight: 900;
  line-height: 1;
  text-transform: uppercase;
  box-shadow: 0 10px 22px rgba(167, 15, 24, 0.24);
}

.offers_page_body {
  display: flex;
  flex-direction: column;
  gap: 12px;
  min-height: 260px;
  padding: 22px;
}

.offers_page_category {
  color: #d4af37;
  font-size: 12px;
  font-weight: 900;
  letter-spacing: 0.06em;
  line-height: 1.35;
  text-transform: uppercase;
}

.offers_page_body h3 {
  display: -webkit-box;
  min-height: 62px;
  margin: 0;
  overflow: hidden;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 2;
  color: #fff8e8;
  font-size: 1.35rem;
  font-weight: 800;
  line-height: 1.28;
  letter-spacing: 0;
}

.offers_page_price_row {
  display: flex;
  flex-wrap: wrap;
  align-items: baseline;
  gap: 10px 14px;
  margin-top: auto;
  padding: 14px 16px;
  border: 1px solid rgba(255, 190, 51, 0.16);
  border-radius: 16px;
  background: rgba(255, 248, 232, 0.07);
}

.offers_page_price_row del {
  color: #b9aa94;
  font-size: 14px;
  font-weight: 700;
}

.offers_page_price_row strong {
  color: #ffe09a;
  font-size: 1.2rem;
  line-height: 1.1;
}

.offers_page_view_btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 44px;
  width: 100%;
  padding: 0 18px;
  border-radius: 999px;
  background: linear-gradient(135deg, #ffd875, #f2b019);
  color: #16110a;
  font-weight: 900;
  line-height: 1;
  box-shadow: 0 14px 28px rgba(242, 176, 25, 0.2);
}

.offers_page_view_btn:hover,
.offers_page_view_btn:focus {
  background: linear-gradient(135deg, #ffe09a, #e7a60f);
  color: #16110a;
}

.offers_page_empty {
  grid-column: 1 / -1;
  min-height: 260px;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-direction: column;
  padding: 34px;
  border: 1px dashed rgba(255, 190, 51, 0.28);
  border-radius: 22px;
  background: rgba(255, 248, 232, 0.06);
  text-align: center;
}

.offers_page_empty_icon {
  width: 62px;
  height: 62px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  margin-bottom: 16px;
  border-radius: 50%;
  background: rgba(255, 190, 51, 0.14);
  color: #ffbe33;
  font-size: 24px;
}

.offers_page_empty strong {
  color: #fff8e8;
  font-size: 1.1rem;
}

.offers_page_empty p {
  margin: 8px 0 0;
  color: #c9bca9;
  line-height: 1.6;
}

/* Offers page contrast guardrails */
.offers_page_section {
  color: #fff8e8;
}

.offers_page_header .heading_container h1,
.offers_page_body h3,
.offers_page_empty strong {
  color: #fff8e8;
}

.offers_page_header .heading_container p,
.offers_page_empty p {
  color: #d9cfbf;
}

.offers_page_count {
  background: rgba(255, 190, 51, 0.14);
  border-color: rgba(255, 218, 132, 0.48);
  color: #fff1bd;
}

.offers_page_card {
  background:
    linear-gradient(180deg, rgba(36, 29, 23, 0.97), rgba(22, 18, 14, 0.96)),
    #17120e;
  border-color: rgba(245, 192, 78, 0.36);
  color: #fff8e8;
}

.offers_page_body {
  color: #fff8e8;
}

.offers_page_category {
  color: #f4c96d;
}

.offers_page_price_row {
  background: rgba(255, 248, 232, 0.085);
  border-color: rgba(245, 192, 78, 0.28);
}

.offers_page_price_row del {
  color: #dacbb7;
}

.offers_page_price_row strong {
  color: #fff0bf;
}

.offers_page_badge {
  color: #ffffff;
}

.offers_page_view_btn,
.offers_page_view_btn:link,
.offers_page_view_btn:visited,
.offers_page_view_btn:hover,
.offers_page_view_btn:focus {
  color: #17120b !important;
  text-decoration: none;
  text-shadow: none;
}

.offers_page_view_btn i,
.offers_page_view_btn svg,
.offers_page_badge i,
.offers_page_badge svg,
.offers_page_count i,
.offers_page_count svg {
  color: currentColor;
  fill: currentColor;
}

html[data-theme="dark"] .offers_page_section,
body.theme_dark .offers_page_section {
  background:
    radial-gradient(circle at 18% 0%, rgba(245, 192, 78, 0.1), transparent 34%),
    linear-gradient(180deg, #12100d 0%, #0c0b09 100%);
  color: #fff8e8;
}

html[data-theme="dark"] .offers_page_card,
body.theme_dark .offers_page_card {
  background:
    linear-gradient(180deg, rgba(36, 29, 23, 0.98), rgba(18, 15, 12, 0.97)),
    #15110d;
  border-color: rgba(245, 192, 78, 0.48);
  box-shadow:
    0 18px 42px rgba(0, 0, 0, 0.42),
    0 0 0 1px rgba(245, 192, 78, 0.1);
}

html[data-theme="dark"] .offers_page_header .heading_container h1,
html[data-theme="dark"] .offers_page_body h3,
body.theme_dark .offers_page_header .heading_container h1,
body.theme_dark .offers_page_body h3 {
  color: #fff8e8;
}

html[data-theme="dark"] .offers_page_header .heading_container p,
body.theme_dark .offers_page_header .heading_container p {
  color: #d9cfbf;
}

html[data-theme="dark"] .offers_page_category,
body.theme_dark .offers_page_category {
  color: #f4c96d;
}

html[data-theme="dark"] .offers_page_price_row,
body.theme_dark .offers_page_price_row {
  background: rgba(255, 248, 232, 0.095);
  border-color: rgba(245, 192, 78, 0.34);
}

html[data-theme="dark"] .offers_page_price_row del,
body.theme_dark .offers_page_price_row del {
  color: #dacbb7;
}

html[data-theme="dark"] .offers_page_price_row strong,
body.theme_dark .offers_page_price_row strong {
  color: #fff0bf;
}

html[data-theme="dark"] .offers_page_count,
body.theme_dark .offers_page_count {
  background: rgba(245, 192, 78, 0.16);
  border-color: rgba(255, 218, 132, 0.58);
  color: #fff1bd;
}

html[data-theme="dark"] .offers_page_badge,
body.theme_dark .offers_page_badge {
  color: #ffffff;
}

html[data-theme="dark"] .offers_page_view_btn,
html[data-theme="dark"] .offers_page_view_btn:link,
html[data-theme="dark"] .offers_page_view_btn:visited,
html[data-theme="dark"] .offers_page_view_btn:hover,
html[data-theme="dark"] .offers_page_view_btn:focus,
body.theme_dark .offers_page_view_btn,
body.theme_dark .offers_page_view_btn:link,
body.theme_dark .offers_page_view_btn:visited,
body.theme_dark .offers_page_view_btn:hover,
body.theme_dark .offers_page_view_btn:focus {
  background: linear-gradient(135deg, #ffd875, #f2b019);
  color: #17120b !important;
}

.delivery_schedule_dialog {
  position: relative;
  width: min(540px, 100%);
  max-height: calc(100vh - 40px);
  overflow-y: auto;
  padding: 30px;
  border-radius: 26px;
  background: -webkit-gradient(linear, left top, left bottom, from(#ffffff), to(#f7f8fb));
  background: linear-gradient(180deg, #ffffff, #f7f8fb);
  color: #1f2733;
  -webkit-box-shadow: 0 30px 70px rgba(0, 0, 0, 0.24);
          box-shadow: 0 30px 70px rgba(0, 0, 0, 0.24);
}

.delivery_schedule_close {
  position: absolute;
  top: 18px;
  right: 18px;
  width: 42px;
  height: 42px;
  border: none;
  border-radius: 50%;
  background: #eef2f7;
  color: #1f2733;
}

.delivery_schedule_kicker {
  display: inline-block;
  margin-right: 46px;
  color: #ff9d00;
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
}

.delivery_schedule_dialog h3 {
  margin: 8px 46px 12px 0;
  color: #1f2733;
  font-size: 1.85rem;
  line-height: 1.18;
}

.delivery_schedule_dialog p {
  margin: 0;
  color: #667085;
  line-height: 1.7;
}

.delivery_city_selector {
  padding: 0;
  margin: 22px 0 16px;
  border: 0;
}

.delivery_city_selector legend {
  margin-bottom: 12px;
  color: #1f2733;
  font-size: 0.95rem;
  font-weight: 800;
}

.delivery_city_options {
  display: -ms-grid;
  display: grid;
  -ms-grid-columns: minmax(0, 1fr) 12px minmax(0, 1fr);
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px;
}

.delivery_city_card {
  position: relative;
  display: -ms-grid;
  display: grid;
  -ms-grid-columns: auto 12px minmax(0, 1fr);
  grid-template-columns: auto minmax(0, 1fr);
  gap: 12px;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  min-height: 86px;
  padding: 15px;
  margin: 0;
  border-radius: 18px;
  border: 1px solid rgba(17, 24, 39, 0.08);
  background: linear-gradient(145deg, rgba(255, 255, 255, 0.92), rgba(255, 248, 232, 0.58)), rgba(255, 255, 255, 0.72);
  -webkit-box-shadow: 0 12px 28px rgba(15, 23, 42, 0.07), inset 0 1px 0 rgba(255, 255, 255, 0.8);
          box-shadow: 0 12px 28px rgba(15, 23, 42, 0.07), inset 0 1px 0 rgba(255, 255, 255, 0.8);
  cursor: pointer;
  -webkit-transition: border-color 0.22s ease, background-color 0.22s ease, -webkit-transform 0.22s ease, -webkit-box-shadow 0.22s ease;
  transition: border-color 0.22s ease, background-color 0.22s ease, -webkit-transform 0.22s ease, -webkit-box-shadow 0.22s ease;
  transition: transform 0.22s ease, border-color 0.22s ease, background-color 0.22s ease, box-shadow 0.22s ease;
  transition: transform 0.22s ease, border-color 0.22s ease, background-color 0.22s ease, box-shadow 0.22s ease, -webkit-transform 0.22s ease, -webkit-box-shadow 0.22s ease;
}

.delivery_city_card:hover,
.delivery_city_card:focus-within {
  border-color: rgba(255, 190, 51, 0.48);
  -webkit-box-shadow: 0 16px 34px rgba(15, 23, 42, 0.1), 0 0 22px rgba(255, 190, 51, 0.12), inset 0 1px 0 rgba(255, 255, 255, 0.9);
          box-shadow: 0 16px 34px rgba(15, 23, 42, 0.1), 0 0 22px rgba(255, 190, 51, 0.12), inset 0 1px 0 rgba(255, 255, 255, 0.9);
  -webkit-transform: translateY(-1px);
          transform: translateY(-1px);
}

.delivery_city_card input {
  position: absolute;
  opacity: 0;
  pointer-events: none;
}

.delivery_city_check {
  width: 22px;
  height: 22px;
  border-radius: 50%;
  border: 2px solid rgba(255, 190, 51, 0.42);
  background: #ffffff;
  -webkit-box-shadow: inset 0 0 0 5px #ffffff;
          box-shadow: inset 0 0 0 5px #ffffff;
  -webkit-transition: background-color 0.22s ease, border-color 0.22s ease, -webkit-box-shadow 0.22s ease;
  transition: background-color 0.22s ease, border-color 0.22s ease, -webkit-box-shadow 0.22s ease;
  transition: background-color 0.22s ease, border-color 0.22s ease, box-shadow 0.22s ease;
  transition: background-color 0.22s ease, border-color 0.22s ease, box-shadow 0.22s ease, -webkit-box-shadow 0.22s ease;
}

.delivery_city_copy {
  display: -ms-grid;
  display: grid;
  gap: 4px;
  min-width: 0;
}

.delivery_city_copy strong {
  color: #1f2733;
  font-size: 1rem;
  line-height: 1.2;
}

.delivery_city_copy span {
  color: #667085;
  font-size: 0.86rem;
  line-height: 1.35;
}

.delivery_city_card.is_selected {
  border-color: rgba(255, 190, 51, 0.76);
  background: linear-gradient(145deg, rgba(255, 246, 224, 0.96), rgba(255, 255, 255, 0.72)), rgba(255, 255, 255, 0.82);
  -webkit-box-shadow: 0 16px 36px rgba(255, 190, 51, 0.14), 0 0 0 1px rgba(255, 190, 51, 0.12), inset 0 1px 0 rgba(255, 255, 255, 0.92);
          box-shadow: 0 16px 36px rgba(255, 190, 51, 0.14), 0 0 0 1px rgba(255, 190, 51, 0.12), inset 0 1px 0 rgba(255, 255, 255, 0.92);
}

.delivery_city_card.is_selected .delivery_city_check {
  border-color: #ffbe33;
  background: #ffbe33;
  -webkit-box-shadow: inset 0 0 0 5px #ffffff, 0 0 0 4px rgba(255, 190, 51, 0.14);
          box-shadow: inset 0 0 0 5px #ffffff, 0 0 0 4px rgba(255, 190, 51, 0.14);
}

.delivery_schedule_validation {
  margin: 0 0 12px;
  padding: 11px 13px;
  border-radius: 14px;
  background: rgba(255, 190, 51, 0.12);
  border: 1px solid rgba(255, 190, 51, 0.26);
  color: #8a5c09;
  font-size: 0.9rem;
  font-weight: 800;
}

.delivery_schedule_validation[hidden] {
  display: none;
}

.delivery_schedule_list {
  display: grid;
  gap: 10px;
  padding: 0;
  margin: 22px 0;
  list-style: none;
}

.delivery_schedule_list li {
  position: relative;
  padding: 12px 14px 12px 36px;
  border-radius: 14px;
  background: #ffffff;
  border: 1px solid rgba(17, 24, 39, 0.08);
  -webkit-box-shadow: 0 10px 22px rgba(15, 23, 42, 0.05);
          box-shadow: 0 10px 22px rgba(15, 23, 42, 0.05);
  color: #303843;
  line-height: 1.55;
}

.delivery_schedule_list li::before {
  content: "";
  position: absolute;
  top: 20px;
  left: 16px;
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: #ffbe33;
  -webkit-box-shadow: 0 0 0 4px rgba(255, 190, 51, 0.16);
          box-shadow: 0 0 0 4px rgba(255, 190, 51, 0.16);
}

.delivery_schedule_agreement {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: start;
      -ms-flex-align: start;
          align-items: flex-start;
  gap: 12px;
  padding: 15px;
  margin: 0;
  border-radius: 16px;
  background: rgba(255, 190, 51, 0.12);
  border: 1px solid rgba(255, 190, 51, 0.28);
  color: #303843;
  font-weight: 700;
  line-height: 1.55;
  cursor: pointer;
}

.delivery_schedule_agreement input {
  width: 18px;
  height: 18px;
  margin-top: 3px;
  -ms-flex-negative: 0;
      flex-shrink: 0;
  accent-color: #ffbe33;
}

.delivery_schedule_actions {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: end;
      -ms-flex-pack: end;
          justify-content: flex-end;
  gap: 12px;
  margin-top: 22px;
}

.delivery_schedule_cancel,
.delivery_schedule_continue {
  min-height: 46px;
  padding: 0 22px;
  border-radius: 999px;
  font-weight: 700;
}

.delivery_schedule_continue_wrap {
  display: -webkit-inline-box;
  display: -ms-inline-flexbox;
  display: inline-flex;
  border-radius: 999px;
}

.delivery_schedule_cancel {
  border: 1px solid rgba(17, 24, 39, 0.12);
  background: #ffffff;
  color: #1f2733;
}

.delivery_schedule_continue {
  border: none;
  background: #ffbe33;
  color: #111111;
  -webkit-box-shadow: 0 14px 28px rgba(255, 190, 51, 0.22);
          box-shadow: 0 14px 28px rgba(255, 190, 51, 0.22);
}

.delivery_schedule_continue:disabled {
  opacity: 0.45;
  cursor: not-allowed;
  -webkit-box-shadow: none;
          box-shadow: none;
  pointer-events: none;
}

@media (max-width: 575px) {
  .delivery_schedule_dialog {
    padding: 24px 18px;
    border-radius: 22px;
  }

  .delivery_schedule_dialog h3 {
    font-size: 1.55rem;
  }

  .delivery_city_options {
    -ms-grid-columns: 1fr;
    grid-template-columns: 1fr;
  }

  .delivery_city_card {
    min-height: 76px;
    padding: 14px;
  }

  .delivery_schedule_actions {
    -webkit-box-orient: vertical;
    -webkit-box-direction: reverse;
        -ms-flex-direction: column-reverse;
            flex-direction: column-reverse;
  }

  .delivery_schedule_cancel,
  .delivery_schedule_continue_wrap,
  .delivery_schedule_continue {
    width: 100%;
  }
}

.site_search_dialog {
  position: relative;
  width: min(680px, calc(100% - 30px));
  margin: 80px auto 0;
  padding: 26px;
  border-radius: 28px;
  background: linear-gradient(180deg, #ffffff, #f7f8fb);
  box-shadow: 0 30px 70px rgba(0, 0, 0, 0.2);
}

.site_search_header,
.reviews_panel_head,
.cart_drawer_header {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 16px;
}

.site_search_header h3,
.reviews_panel_head h3,
.reviews_summary_card h2,
.cart_drawer_header h3 {
  margin: 6px 0 0;
  color: #1f2733;
  font-size: 1.8rem;
  line-height: 1.15;
}

.site_search_kicker,
.reviews_kicker,
.cart_drawer_kicker {
  display: inline-block;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  font-size: 12px;
  font-weight: 700;
  color: #ff9d00;
}

.site_search_close,
.cart_drawer_close {
  width: 44px;
  height: 44px;
  border: none;
  border-radius: 50%;
  background: #eef2f7;
  color: #1f2733;
}

.site_search_input_wrap {
  margin-top: 22px;
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 0 18px;
  min-height: 62px;
  border-radius: 999px;
  background: #eef2f7;
  border: 1px solid rgba(34, 40, 49, 0.08);
}

.site_search_input_wrap i {
  color: #667085;
}

.site_search_input_wrap input {
  width: 100%;
  border: none;
  background: transparent;
  color: #1f2733;
  font-size: 16px;
}

.site_search_input_wrap input:focus {
  outline: none;
}

.site_search_hint {
  margin: 16px 2px 0;
  color: #667085;
  font-size: 14px;
}

.site_search_results {
  margin-top: 20px;
  display: grid;
  gap: 12px;
}

.site_search_result {
  display: grid;
  grid-template-columns: 74px 1fr;
  gap: 14px;
  align-items: center;
  padding: 12px;
  border-radius: 18px;
  background: #ffffff;
  border: 1px solid rgba(17, 24, 39, 0.06);
  box-shadow: 0 10px 22px rgba(15, 23, 42, 0.06);
}

.site_search_result img {
  width: 74px;
  height: 74px;
  object-fit: contain;
  border-radius: 14px;
  background: #f8fafc;
  padding: 8px;
}

.site_search_result picture {
  display: block;
  width: 74px;
  height: 74px;
}

.site_search_result strong,
.cart_item_header strong {
  display: block;
  color: #1f2733;
  font-size: 16px;
}

.site_search_result span,
.cart_item_price {
  color: #667085;
  font-size: 14px;
}

.cart_drawer_panel {
  position: absolute;
  top: 0;
  right: 0;
  width: min(440px, 100%);
  height: 100%;
  background: #ffffff;
  padding: 26px;
  display: flex;
  flex-direction: column;
  box-shadow: -24px 0 50px rgba(0, 0, 0, 0.18);
}

.cart_drawer_body {
  flex: 1;
  overflow-y: auto;
  margin: 24px 0;
}

.cart_empty_state,
.review_empty_state {
  min-height: 220px;
  border-radius: 22px;
  background: #f8fafc;
  border: 1px dashed rgba(148, 163, 184, 0.5);
  display: flex;
  align-items: center;
  justify-content: center;
  flex-direction: column;
  padding: 28px;
  text-align: center;
  color: #667085;
}

.cart_empty_icon,
.review_empty_icon {
  width: 64px;
  height: 64px;
  border-radius: 50%;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: rgba(255, 190, 51, 0.14);
  color: #ff9d00;
  font-size: 26px;
  margin-bottom: 16px;
}

.cart_items,
.reviews_list {
  display: grid;
  gap: 14px;
}

.cart_item,
.review_card {
  border-radius: 20px;
  background: #ffffff;
  border: 1px solid rgba(17, 24, 39, 0.08);
  box-shadow: 0 12px 24px rgba(15, 23, 42, 0.06);
}

.cart_item {
  display: grid;
  grid-template-columns: 88px 1fr;
  gap: 14px;
  padding: 14px;
}

.cart_item_image {
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 18px;
  background: #f8fafc;
}

.cart_item_image img {
  width: 100%;
  max-width: 72px;
  max-height: 72px;
  object-fit: contain;
}

.cart_item_image picture,
.checkout_order_item picture,
body.checkout-page .checkout_cart_item_image picture,
body.cart-page .cart_page_item_image picture {
  display: flex;
  width: 100%;
  height: 100%;
  align-items: center;
  justify-content: center;
}

.cart_item_header {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 12px;
}

.cart_remove_btn {
  border: none;
  background: transparent;
  color: #ef4444;
  font-size: 13px;
  font-weight: 700;
}

.cart_qty_controls {
  margin-top: 12px;
  display: inline-flex;
  align-items: center;
  gap: 10px;
  padding: 6px 10px;
  border-radius: 999px;
  background: #f8fafc;
}

.cart_qty_controls button {
  width: 28px;
  height: 28px;
  border: none;
  border-radius: 50%;
  background: #222831;
  color: #ffffff;
}

.cart_drawer_footer {
  border-top: 1px solid rgba(15, 23, 42, 0.08);
  padding-top: 18px;
}

.cart_subtotal_row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  color: #1f2733;
  font-size: 16px;
  margin-bottom: 18px;
}

.cart_drawer_actions {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
}

.return_menu_btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  min-height: 46px;
  padding: 0 22px;
  border-radius: 999px;
  font-weight: 700;
  white-space: nowrap;
  transition: background-color 0.25s ease, border-color 0.25s ease, color 0.25s ease, box-shadow 0.25s ease;
}

.cart_drawer_actions .cart_clear_btn,
.cart_drawer_actions .return_menu_btn {
  flex: 1 1 calc(50% - 6px);
}

.cart_drawer_actions .cart_checkout_btn {
  flex: 1 1 100%;
}

.cart_drawer_actions .return_menu_btn {
  border: 1px solid rgba(255, 190, 51, 0.35);
  background: #fff7e2;
  color: #7a5200;
  box-shadow: 0 10px 20px rgba(255, 190, 51, 0.12);
}

.cart_drawer_actions .return_menu_btn:hover,
.cart_drawer_actions .return_menu_btn:focus {
  background: #ffe7ab;
  border-color: rgba(255, 190, 51, 0.5);
  color: #5d3d00;
}

.cart_clear_btn,
.review_delete_btn {
  min-height: 46px;
  padding: 0 20px;
  border-radius: 999px;
  border: 1px solid rgba(17, 24, 39, 0.12);
  background: #ffffff;
  color: #1f2733;
  font-weight: 700;
}

.cart_checkout_btn,
.review_submit_btn,
.product_cart_primary_btn,
.product_share_detail_btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  min-height: 46px;
  padding: 0 22px;
  border-radius: 999px;
  border: none;
  background: #ffbe33;
  color: #111111;
  font-weight: 700;
  box-shadow: 0 14px 28px rgba(255, 190, 51, 0.22);
  cursor: pointer;
}

.cart_checkout_btn:hover,
.cart_checkout_btn:focus,
.review_submit_btn:hover,
.review_submit_btn:focus,
.product_cart_primary_btn:hover,
.product_cart_primary_btn:focus {
  color: #111111;
  background: #f2b019;
}

.cart_checkout_btn.is_disabled {
  pointer-events: none;
  opacity: 0.45;
  box-shadow: none;
}

.cart_checkout_btn {
  color: #111111;
  line-height: 1.2;
  text-align: center;
}

.cart_checkout_btn::before {
  content: "\f09d";
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-family: "FontAwesome";
  font-size: 18px;
  font-weight: normal;
  line-height: 1;
  color: currentColor;
  flex: 0 0 auto;
}

.site_toast_stack {
  position: fixed;
  right: 20px;
  bottom: 20px;
  z-index: 150;
  display: grid;
  gap: 10px;
}

.back_to_top_btn {
  position: fixed;
  right: 24px;
  bottom: 86px;
  z-index: 88;
  width: 54px;
  height: 54px;
  border: 1px solid rgba(255, 224, 154, 0.58);
  border-radius: 50%;
  background:
    radial-gradient(circle at 32% 24%, rgba(255, 255, 255, 0.34), transparent 28%),
    linear-gradient(145deg, #f6d678 0%, #c89022 48%, #15110c 100%);
  color: #17110a;
  box-shadow: 0 18px 38px rgba(16, 12, 8, 0.26), 0 0 0 6px rgba(246, 214, 120, 0.11);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
  transform: translateY(16px) scale(0.9);
  transition: opacity 0.22s ease, visibility 0.22s ease, transform 0.22s ease, box-shadow 0.22s ease;
}

.back_to_top_btn[hidden] {
  display: inline-flex;
}

.back_to_top_btn.is_visible {
  opacity: 1;
  visibility: visible;
  pointer-events: auto;
  transform: translateY(0) scale(1);
}

.back_to_top_btn i {
  font-size: 20px;
  line-height: 1;
  filter: drop-shadow(0 1px 0 rgba(255, 255, 255, 0.35));
}

.back_to_top_btn:hover,
.back_to_top_btn:focus {
  color: #100c08;
  transform: translateY(-3px) scale(1.04);
  box-shadow: 0 22px 44px rgba(16, 12, 8, 0.3), 0 0 0 8px rgba(246, 214, 120, 0.15);
}

.back_to_top_btn:active {
  transform: translateY(0) scale(0.96);
}

body.cart_open .back_to_top_btn,
body.search_open .back_to_top_btn,
body.delivery_schedule_open .back_to_top_btn,
body.lightbox_open .back_to_top_btn {
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
  transform: translateY(16px) scale(0.9);
}

body.theme_dark .back_to_top_btn,
html[data-theme="dark"] .back_to_top_btn {
  border-color: rgba(242, 199, 107, 0.5);
  background:
    radial-gradient(circle at 32% 24%, rgba(255, 248, 232, 0.2), transparent 30%),
    linear-gradient(145deg, #f2c76b 0%, #9f6e19 45%, #090807 100%);
  color: #fff8e8;
  box-shadow: 0 18px 38px rgba(0, 0, 0, 0.38), 0 0 0 6px rgba(242, 199, 107, 0.12);
}

.site_toast {
  min-width: 220px;
  padding: 14px 18px;
  border-radius: 16px;
  background: #111827;
  color: #ffffff;
  box-shadow: 0 18px 36px rgba(0, 0, 0, 0.2);
  opacity: 0;
  transform: translateY(10px);
  transition: opacity 0.25s ease, transform 0.25s ease;
}

.site_toast.is_visible {
  opacity: 1;
  transform: translateY(0);
}

.site_toast_success {
  background: #166534;
}

.site_toast_error {
  background: #991b1b;
}

.food_section .box .options {
  align-items: center;
  gap: 12px;
  flex-wrap: wrap;
}

.food_section .box .options h6 {
  margin: 0;
}

.product_action_group {
  margin-left: auto;
  display: flex;
  align-items: center;
  gap: 10px;
}

.product-cart-btn {
  width: 42px;
  height: 42px;
  border: none;
  border-radius: 50%;
  background: #ffffff;
  color: #222831;
  box-shadow: 0 12px 22px rgba(0, 0, 0, 0.14);
}

.product-cart-btn:hover,
.product-cart-btn:focus {
  background: #ffbe33;
  color: #111111;
}

.product_card_rating {
  display: flex;
  align-items: center;
  gap: 8px;
  margin-top: 0;
  margin-bottom: 2px;
  color: #f4efe3;
}

.product_card_rating_text {
  font-size: 13px;
  color: rgba(255, 255, 255, 0.82);
}

.wishlist_section {
  background: #f7f7f7;
}

.wishlist_header {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: end;
      -ms-flex-align: end;
          align-items: flex-end;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  gap: 18px;
  margin-bottom: 26px;
}

.wishlist_header .heading_container p {
  margin: 10px 0 0;
  color: #667085;
  font-weight: 600;
}

.wishlist_clear_btn,
.wishlist_empty_btn,
.wishlist_view_btn,
.wishlist_add_btn,
.wishlist_remove_btn {
  min-height: 42px;
  border-radius: 999px;
  display: -webkit-inline-box;
  display: -ms-inline-flexbox;
  display: inline-flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  gap: 8px;
  padding: 10px 16px;
  font-size: 14px;
  font-weight: 800;
}

.wishlist_clear_btn,
.wishlist_remove_btn {
  border: 1px solid rgba(34, 40, 49, 0.14);
  background: #ffffff;
  color: #222831;
}

.wishlist_clear_btn:hover,
.wishlist_remove_btn:hover {
  background: #fff4d8;
  color: #111111;
}

.wishlist_empty_state {
  padding: 46px 24px;
  border-radius: 18px;
  background: #ffffff;
  text-align: center;
  -webkit-box-shadow: 0 18px 35px rgba(0, 0, 0, 0.08);
          box-shadow: 0 18px 35px rgba(0, 0, 0, 0.08);
}

.wishlist_empty_icon {
  width: 70px;
  height: 70px;
  margin: 0 auto 18px;
  border-radius: 50%;
  background: #fff4d8;
  color: #d98200;
  display: -webkit-inline-box;
  display: -ms-inline-flexbox;
  display: inline-flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  font-size: 26px;
}

.wishlist_empty_state h3 {
  margin-bottom: 10px;
  color: #222831;
}

.wishlist_empty_state p {
  margin: 0 auto 20px;
  max-width: 420px;
  color: #667085;
  line-height: 1.7;
}

.wishlist_empty_btn,
.wishlist_add_btn {
  border: none;
  background: #ffbe33;
  color: #111111;
}

.wishlist_empty_btn:hover,
.wishlist_view_btn:hover,
.wishlist_add_btn:hover {
  background: #e69c00;
  color: #ffffff;
}

.wishlist_grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(255px, 1fr));
  gap: 24px;
}

.wishlist_card {
  overflow: hidden;
  border-radius: 16px;
  background: #222831;
  color: #ffffff;
  -webkit-box-shadow: 0 16px 34px rgba(0, 0, 0, 0.18);
          box-shadow: 0 16px 34px rgba(0, 0, 0, 0.18);
}

.wishlist_card_image {
  height: 220px;
  padding: 18px;
  background: #f1f2f3;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
}

.wishlist_card_image img {
  width: 100%;
  height: 100%;
  -o-object-fit: contain;
     object-fit: contain;
}

.wishlist_card_image picture {
  display: block;
  width: 100%;
  height: 100%;
}

.wishlist_card_body {
  min-height: 280px;
  padding: 22px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  gap: 18px;
}

.wishlist_card_category {
  display: block;
  margin-bottom: 8px;
  color: #ffbe33;
  font-size: 12px;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0;
}

.wishlist_card h3 {
  margin: 0 0 10px;
  font-size: 1.15rem;
}

.wishlist_card h3 a {
  color: #ffffff;
}

.wishlist_card p {
  margin: 0;
  color: rgba(255, 255, 255, 0.78);
  line-height: 1.6;
}

.wishlist_card_footer strong {
  display: block;
  margin-bottom: 14px;
  color: #ffbe33;
  font-size: 1.05rem;
}

.wishlist_card_actions {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  gap: 10px;
}

.wishlist_view_btn {
  background: rgba(255, 255, 255, 0.1);
  color: #ffffff;
  border: 1px solid rgba(255, 255, 255, 0.18);
}

.wishlist_remove_btn {
  color: #b42318;
}

.rating_stars,
.rating_stars_wrap {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  color: #d4af37;
}

.rating_stars.compact i {
  font-size: 13px;
}

.rating_stars.large i,
.rating_stars_wrap .rating_stars.large i {
  font-size: 19px;
}

.product_rating_meta {
  display: inline-flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 8px 12px;
  width: fit-content;
  max-width: 100%;
  margin: 0 0 14px;
  padding: 7px 12px;
  border-radius: 999px;
  background: rgba(212, 175, 55, 0.09);
  border: 1px solid rgba(212, 175, 55, 0.16);
  color: #8b8172;
  font-size: 13px;
  font-weight: 700;
  line-height: 1.2;
}

.product_rating_meta .rating_stars_wrap,
.product_rating_meta .rating_stars {
  color: #d4af37;
}

.product_rating_meta .rating_stars.compact i,
.product_rating_meta .rating_stars_wrap .rating_stars.compact i {
  font-size: 14px;
}

.product_rating_meta span {
  color: inherit;
}

.product_action_row {
  display: flex;
  flex-wrap: wrap;
  gap: 14px;
  margin-top: 22px;
}

.product_action_row .return_menu_btn {
  border: 1px solid rgba(255, 255, 255, 0.18);
  background: rgba(255, 255, 255, 0.08);
  color: #f4efe3;
  box-shadow: 0 12px 24px rgba(0, 0, 0, 0.16);
}

.product_share_detail_btn {
  border: 1px solid rgba(255, 255, 255, 0.18);
  background: rgba(255, 255, 255, 0.08);
  color: #f4efe3;
  box-shadow: 0 12px 24px rgba(0, 0, 0, 0.16);
}

.product_action_row .return_menu_btn:hover,
.product_action_row .return_menu_btn:focus,
.product_share_detail_btn:hover,
.product_share_detail_btn:focus {
  background: rgba(255, 190, 51, 0.14);
  border-color: rgba(255, 190, 51, 0.34);
  color: #ffffff;
}

.product_story_section,
.product_recommendations_section {
  background: #0f0f0f;
}

.product_story_card {
  border-radius: 26px;
  padding: 30px;
  background: linear-gradient(180deg, #fffaf0, #ffffff);
  box-shadow: 0 20px 40px rgba(0, 0, 0, 0.12);
}

.product_story_card .heading_container {
  margin-bottom: 12px;
}

.product_story_card .heading_container h2 {
  color: #1f2733;
  font-family: 'Kaushan Script', cursive;
  font-weight: 400;
  letter-spacing: 0.5px;
  line-height: 1.2;
}

.product_story_title {
  margin: 0;
  color: #1f2733;
  font-family: 'Kaushan Script', cursive;
  font-size: 2rem;
  font-weight: 400;
  letter-spacing: 0.5px;
  line-height: 1.2;
}

.product_story_lead {
  margin: 14px 0 0;
  color: #4b5563;
  line-height: 1.9;
  font-size: 1.02rem;
}

.product_story_body {
  display: grid;
  gap: 22px;
  margin-top: 24px;
}

.product_story_block {
  padding-top: 22px;
  border-top: 1px solid rgba(15, 23, 42, 0.08);
}

.product_story_block:first-child {
  padding-top: 0;
  border-top: none;
}

.product_story_block h4 {
  margin: 0 0 14px;
  color: #1f2733;
  font-family: 'Kaushan Script', cursive;
  font-size: 1.1rem;
  font-weight: 400;
  letter-spacing: 0.5px;
  line-height: 1.2;
}

.product_story_block p {
  margin: 0;
  color: #4b5563;
  line-height: 1.9;
}

.product_story_link {
  color: #d98200;
  font-weight: 700;
  text-decoration: underline;
  text-underline-offset: 3px;
}

.product_story_link:hover {
  color: #b76e00;
}

.product_story_list li {
  color: #4b5563;
}

.product_recommendations_section .heading_container {
  margin-bottom: 24px;
}

.product_recommendations_section .heading_container h2 {
  color: #f4efe3;
  font-family: 'Kaushan Script', cursive;
  font-weight: 400;
  letter-spacing: 0.5px;
  line-height: 1.2;
}

.product_recommendations_section .heading_container p {
  margin-top: 14px;
  max-width: 680px;
  color: rgba(244, 239, 227, 0.72);
}

.recommendations_grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 24px;
}

.recommendation_card,
.recommendations_empty {
  border-radius: 26px;
  background: #ffffff;
  box-shadow: 0 20px 40px rgba(0, 0, 0, 0.12);
  overflow: hidden;
}

.recommendation_card {
  display: flex;
  flex-direction: column;
  height: 100%;
  cursor: pointer;
}

.product-card {
  cursor: pointer;
}

.recommendation_card_image {
  min-height: 220px;
  padding: 24px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: linear-gradient(180deg, #fffaf0, #f8fafc);
}

.recommendation_card_image img {
  max-width: 100%;
  max-height: 180px;
  object-fit: contain;
}

.recommendation_card_image picture {
  display: block;
  width: 100%;
  height: 100%;
}

.recommendation_card_body {
  flex: 1;
  padding: 22px;
  display: grid;
  gap: 16px;
}

.recommendation_card_label {
  display: inline-flex;
  align-items: center;
  width: max-content;
  min-height: 32px;
  padding: 0 12px;
  border-radius: 999px;
  background: rgba(255, 190, 51, 0.16);
  color: #8a6110;
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.recommendation_card_copy h3 {
  margin: 0;
  font-size: 1.3rem;
}

.recommendation_card_copy h3 a {
  color: #1f2733;
}

.recommendation_card_copy p {
  margin: 10px 0 0;
  color: #667085;
  line-height: 1.7;
}

.recommendation_card_rating {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 10px;
  color: #667085;
  font-size: 14px;
}

.recommendation_card_footer {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  margin-top: auto;
}

.recommendation_card_price {
  color: #1f2733;
  font-size: 1.25rem;
  font-weight: 700;
}

.recommendation_card_actions {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
}

.recommendation_link,
.recommendation_add_btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 44px;
  padding: 0 18px;
  border-radius: 999px;
  font-weight: 700;
}

.recommendation_link {
  background: #f8fafc;
  color: #1f2733;
}

.recommendation_link:hover,
.recommendation_link:focus {
  background: #eef2f7;
  color: #1f2733;
}

.recommendation_add_btn {
  border: none;
  background: #ffbe33;
  color: #111111;
  box-shadow: 0 14px 28px rgba(255, 190, 51, 0.22);
}

.recommendation_add_btn:hover,
.recommendation_add_btn:focus {
  background: #f2b019;
  color: #111111;
}

.recommendations_empty {
  min-height: 220px;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 28px;
  text-align: center;
  color: #667085;
}

.product_reviews_section {
  background: linear-gradient(180deg, #0f0f0f, #14171d);
}

.reviews_summary_card,
.reviews_panel {
  height: 100%;
  border-radius: 26px;
  padding: 28px;
  background: #ffffff;
  box-shadow: 0 20px 40px rgba(0, 0, 0, 0.12);
}

.reviews_summary_card {
  background: linear-gradient(180deg, #fffaf0, #ffffff);
}

.rating_overview {
  display: flex;
  align-items: center;
  gap: 16px;
  margin: 22px 0 18px;
}

.rating_overview_score {
  font-size: 3.4rem;
  font-weight: 700;
  line-height: 1;
  color: #1f2733;
}

.rating_overview_meta p,
.reviews_panel_head p,
.reviews_summary_text {
  margin: 8px 0 0;
  color: #667085;
  line-height: 1.7;
}

.review_auth_notice {
  margin-top: 22px;
}

.review_notice_card {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 14px;
  padding: 16px 18px;
  border-radius: 20px;
  background: #f8fafc;
  border: 1px solid rgba(148, 163, 184, 0.18);
}

.review_notice_card .auth_dropdown_btn {
  margin-left: auto;
}

.review_notice_card p {
  margin: 2px 0 0;
}

.review_form {
  margin-top: 24px;
}

.review_field {
  margin-bottom: 20px;
}

.review_field label {
  display: block;
  margin-bottom: 10px;
  color: #1f2733;
  font-weight: 700;
}

.review_star_picker {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.review_star_btn {
  width: 46px;
  height: 46px;
  border-radius: 14px;
  border: 1px solid rgba(17, 24, 39, 0.12);
  background: #ffffff;
  color: #cbd5e1;
  font-size: 18px;
}

.review_star_btn:disabled {
  opacity: 0.55;
  cursor: not-allowed;
}

.review_star_btn.is_active {
  color: #ffbe33;
  background: rgba(255, 190, 51, 0.12);
  border-color: rgba(255, 190, 51, 0.35);
}

.review_field textarea {
  width: 100%;
  min-height: 140px;
  border-radius: 20px;
  border: 1px solid rgba(17, 24, 39, 0.1);
  background: #f8fafc;
  padding: 16px 18px;
  color: #1f2733;
  resize: vertical;
}

.review_field textarea:focus {
  outline: none;
  border-color: rgba(255, 190, 51, 0.5);
  box-shadow: 0 0 0 4px rgba(255, 190, 51, 0.15);
}

.review_form_actions {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  align-items: center;
}

.review_form_status {
  margin: 14px 0 0;
  color: #667085;
  line-height: 1.6;
}

.review_card {
  padding: 18px 20px;
}

.review_card.is_current_user {
  border-color: rgba(255, 190, 51, 0.32);
  box-shadow: 0 14px 28px rgba(255, 190, 51, 0.12);
}

.review_card_header,
.review_card_identity,
.review_card_meta {
  display: flex;
  align-items: center;
  gap: 12px;
}

.review_card_header {
  justify-content: space-between;
  margin-bottom: 12px;
  flex-wrap: wrap;
}

.review_card_identity strong {
  display: block;
  color: #1f2733;
}

.review_card_identity span {
  color: #667085;
  font-size: 13px;
}

.review_card p {
  margin: 0;
  color: #475467;
  line-height: 1.7;
}

.review_owner_badge {
  display: inline-flex;
  align-items: center;
  min-height: 28px;
  padding: 0 10px;
  border-radius: 999px;
  background: rgba(255, 190, 51, 0.14);
  color: #a16207;
  font-size: 12px;
  font-weight: 700;
}

/* Premium shared header */
:root {
  --site-header-height: 84px;
}

body.theme_dark {
  color: #f4f1ea;
  background: #0d1110;
}

.header_section {
  padding: 10px 0;
}

.header_section .container {
  width: min(1320px, calc(100% - 28px));
  min-height: 64px;
  padding: 8px 14px 8px 16px;
  border-radius: 20px;
  background: linear-gradient(135deg, rgba(12, 15, 14, 0.82), rgba(24, 20, 16, 0.66));
  border: 1px solid rgba(255, 255, 255, 0.16);
  box-shadow: 0 18px 42px rgba(0, 0, 0, 0.28), inset 0 1px 0 rgba(255, 255, 255, 0.08);
  -webkit-backdrop-filter: blur(18px) saturate(135%);
          backdrop-filter: blur(18px) saturate(135%);
}

.header_section.is_scrolled .container {
  background: linear-gradient(135deg, rgba(8, 10, 10, 0.9), rgba(22, 18, 13, 0.76));
  border-color: rgba(255, 190, 51, 0.2);
  box-shadow: 0 16px 38px rgba(0, 0, 0, 0.32), inset 0 1px 0 rgba(255, 255, 255, 0.07);
}

.custom_nav-container {
  min-height: 48px;
  align-items: center;
}

.navbar-brand {
  gap: 10px;
  min-width: max-content;
  padding: 0;
}

.navbar-brand img {
  width: 46px;
  height: 46px;
  padding: 5px;
  border-radius: 14px;
  box-shadow: 0 10px 24px rgba(0, 0, 0, 0.26);
}

.navbar-brand span {
  font-size: 30px;
  line-height: 1;
}

.custom_nav-container .navbar-collapse,
.custom_nav-container .navbar-nav {
  align-items: center;
}

.custom_nav-container .navbar-nav {
  gap: 4px;
}

.custom_nav-container .navbar-nav .nav-item .nav-link {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 40px;
  padding: 8px 12px;
  color: rgba(255, 255, 255, 0.86);
  border-radius: 999px;
  font-size: 12px;
  font-weight: 800;
  line-height: 1;
  letter-spacing: 0;
  white-space: nowrap;
  text-shadow: none;
}

.custom_nav-container .navbar-nav .nav-item:hover .nav-link,
.custom_nav-container .navbar-nav .nav-item.active .nav-link {
  color: #ffbe33;
  background: rgba(255, 190, 51, 0.11);
  box-shadow: inset 0 0 0 1px rgba(255, 190, 51, 0.16);
}

.wishlist_count_badge {
  margin-left: 6px;
}

.user_option {
  align-items: center;
  gap: 8px;
  margin-left: 12px;
}

.user_option .auth_shell {
  order: 1;
}

.user_option .cart_link {
  order: 2;
}

.user_option .site_search_toggle_form,
.user_option form {
  order: 3;
}

.user_option .theme_toggle {
  order: 4;
}

.user_option .order_online {
  order: 5;
}

.auth_button,
.user_option .cart_link,
.user_option .nav_search-btn,
.user_option .theme_toggle {
  width: 40px;
  min-width: 40px;
  min-height: 40px;
  height: 40px;
  border-radius: 999px;
  color: #ffffff;
  background: rgba(255, 255, 255, 0.09);
  border: 1px solid rgba(255, 255, 255, 0.16);
  box-shadow: none;
  text-shadow: none;
  transition: background-color 0.2s ease, border-color 0.2s ease, color 0.2s ease, transform 0.2s ease;
}

.auth_button {
  width: auto;
  max-width: 168px;
  padding: 4px 10px 4px 4px;
}

.auth_avatar {
  width: 30px;
  height: 30px;
}

.auth_button_text {
  max-width: 82px;
  font-size: 13px;
}

.auth_button:hover,
.auth_button:focus,
.user_option .cart_link:hover,
.user_option .cart_link:focus,
.user_option .nav_search-btn:hover,
.user_option .nav_search-btn:focus,
.user_option .theme_toggle:hover,
.user_option .theme_toggle:focus {
  color: #ffbe33;
  background: rgba(255, 190, 51, 0.14);
  border-color: rgba(255, 190, 51, 0.42);
  transform: translateY(-1px);
}

.user_option .cart_link svg {
  width: 17px;
  fill: currentColor;
  filter: none;
}

.user_option .nav_search-btn,
.user_option .theme_toggle {
  padding: 0;
  margin: 0;
}

.user_option .theme_toggle {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
}

.user_option .order_online {
  min-height: 40px;
  padding: 8px 18px;
  border-radius: 999px;
  background: linear-gradient(135deg, #ffcf5d, #ffad22);
  color: #15110a;
  font-size: 13px;
  font-weight: 800;
  line-height: 1;
  box-shadow: 0 12px 26px rgba(255, 190, 51, 0.22);
}

.user_option .order_online:hover,
.user_option .order_online:focus {
  background: linear-gradient(135deg, #ffd875, #e99b07);
  color: #15110a;
  transform: translateY(-1px);
}

.cart_count_badge {
  top: -5px;
  right: -7px;
  border: 2px solid rgba(15, 13, 10, 0.92);
}

.custom_nav-container .navbar-toggler {
  width: 42px;
  height: 42px;
  padding: 0;
  border-radius: 14px;
  border: 1px solid rgba(255, 255, 255, 0.16);
  background: rgba(255, 255, 255, 0.08);
}

.custom_nav-container .navbar-toggler span {
  width: 20px;
  height: 2px;
  margin: 0 auto;
}

.custom_nav-container .navbar-toggler span::before,
.custom_nav-container .navbar-toggler span::after {
  height: 2px;
}

.custom_nav-container .navbar-toggler span::before {
  top: -7px;
}

.custom_nav-container .navbar-toggler span::after {
  top: 7px;
}

/* Search, navbar, and theme refinement */
html[data-theme="dark"] body,
body.theme_dark {
  color: #f7f0e2;
  background:
    radial-gradient(circle at 20% 0%, rgba(191, 142, 42, 0.12), transparent 32rem),
    linear-gradient(180deg, #15110d 0%, #1b1611 42%, #11100e 100%);
}

.header_section .container {
  background: linear-gradient(135deg, rgba(22, 20, 17, 0.66), rgba(34, 27, 19, 0.48));
  border-color: rgba(255, 255, 255, 0.13);
  box-shadow: 0 12px 28px rgba(0, 0, 0, 0.18), inset 0 1px 0 rgba(255, 255, 255, 0.08);
}

.header_section.is_scrolled .container {
  background: linear-gradient(135deg, rgba(17, 15, 13, 0.78), rgba(32, 25, 18, 0.62));
  border-color: rgba(255, 190, 51, 0.16);
  box-shadow: 0 10px 24px rgba(0, 0, 0, 0.2), inset 0 1px 0 rgba(255, 255, 255, 0.08);
}

.navbar-brand img {
  box-shadow: 0 8px 18px rgba(0, 0, 0, 0.2);
}

.navbar-brand span {
  text-shadow: 0 1px 4px rgba(0, 0, 0, 0.24);
}

.custom_nav-container .navbar-nav {
  gap: 6px;
}

.custom_nav-container .navbar-nav .nav-item .nav-link {
  min-height: 38px;
  padding: 8px 14px;
  font-size: 13px;
  color: rgba(255, 255, 255, 0.9);
}

.custom_nav-container .navbar-nav .nav-item:hover .nav-link,
.custom_nav-container .navbar-nav .nav-item.active .nav-link {
  color: #ffd36a;
  background: rgba(255, 190, 51, 0.1);
  box-shadow: inset 0 0 0 1px rgba(255, 210, 110, 0.2);
}

.auth_button,
.user_option .cart_link,
.user_option .nav_search-btn,
.user_option .theme_toggle {
  background: rgba(255, 255, 255, 0.075);
  border-color: rgba(255, 255, 255, 0.14);
}

.user_option .theme_toggle {
  position: relative;
  overflow: hidden;
}

.theme_toggle_orbit {
  position: relative;
  width: 24px;
  height: 24px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
}

.theme_toggle_disc {
  width: 18px;
  height: 18px;
  border-radius: 50%;
  background: radial-gradient(circle at 35% 30%, #fff6c9 0 18%, #ffd36a 19% 58%, #bc8420 59% 100%);
  box-shadow: 0 0 0 2px rgba(255, 211, 106, 0.12), 0 0 16px rgba(255, 190, 51, 0.36);
  transition: transform 0.28s ease, background 0.28s ease, box-shadow 0.28s ease;
}

.theme_toggle_spark {
  position: absolute;
  width: 4px;
  height: 4px;
  border-radius: 50%;
  background: #ffdd88;
  box-shadow: 0 0 10px rgba(255, 221, 136, 0.6);
  transition: transform 0.28s ease, opacity 0.28s ease;
}

.theme_toggle_spark_one {
  top: 2px;
  right: 3px;
}

.theme_toggle_spark_two {
  bottom: 3px;
  left: 2px;
  opacity: 0.7;
}

.theme_toggle[aria-pressed="true"] .theme_toggle_disc {
  background:
    radial-gradient(circle at 68% 30%, #1b1713 0 25%, transparent 26%),
    linear-gradient(135deg, #ffdc85, #9f7020);
  transform: rotate(-24deg) scale(0.95);
  box-shadow: 0 0 0 2px rgba(255, 211, 106, 0.1), 0 0 18px rgba(255, 190, 51, 0.26);
}

.theme_toggle[aria-pressed="true"] .theme_toggle_spark_one {
  transform: translate(-14px, 14px) scale(0.7);
  opacity: 0.45;
}

.theme_toggle[aria-pressed="true"] .theme_toggle_spark_two {
  transform: translate(14px, -12px) scale(1.25);
  opacity: 1;
}

.user_option .theme_toggle:hover .theme_toggle_disc,
.user_option .theme_toggle:focus .theme_toggle_disc {
  transform: rotate(18deg) scale(1.06);
}

.site_search_backdrop {
  background: rgba(14, 12, 10, 0.42);
  -webkit-backdrop-filter: blur(14px) saturate(128%);
          backdrop-filter: blur(14px) saturate(128%);
}

.site_search_dialog {
  color: #211a12;
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.92), rgba(248, 244, 236, 0.86));
  border: 1px solid rgba(255, 255, 255, 0.72);
  box-shadow: 0 24px 58px rgba(36, 27, 15, 0.18);
  -webkit-backdrop-filter: blur(22px) saturate(145%);
          backdrop-filter: blur(22px) saturate(145%);
}

.site_search_input_wrap {
  background: rgba(255, 255, 255, 0.72);
  border-color: rgba(188, 132, 32, 0.16);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.7);
}

.site_search_section_label {
  margin-top: 16px;
  color: #a86f06;
  font-size: 12px;
  font-weight: 800;
  letter-spacing: 0.1em;
  text-transform: uppercase;
}

.site_search_results {
  max-height: min(52vh, 520px);
  overflow-y: auto;
  padding-right: 4px;
}

.site_search_result {
  grid-template-columns: 78px minmax(0, 1fr) auto;
  color: inherit;
  background: rgba(255, 255, 255, 0.78);
  border-color: rgba(188, 132, 32, 0.12);
  box-shadow: 0 10px 24px rgba(48, 34, 13, 0.08);
  transition: transform 0.2s ease, border-color 0.2s ease, box-shadow 0.2s ease, background-color 0.2s ease;
}

.site_search_result:hover,
.site_search_result:focus,
.site_search_result.is_active {
  color: inherit;
  background: #ffffff;
  border-color: rgba(255, 190, 51, 0.38);
  box-shadow: 0 16px 32px rgba(48, 34, 13, 0.14);
  transform: translateY(-2px);
}

.site_search_result_body {
  min-width: 0;
}

.site_search_result_category,
.site_search_result_meta {
  display: block;
}

.site_search_result_category {
  margin-bottom: 3px;
  color: #bc8420;
  font-size: 11px;
  font-weight: 800;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.site_search_result_meta {
  margin-top: 5px;
  color: #6b6258;
  font-size: 13px;
}

.site_search_result_action {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 34px;
  padding: 0 12px;
  border-radius: 999px;
  background: rgba(255, 190, 51, 0.16);
  color: #7a5200;
  font-size: 12px;
  font-weight: 800;
  white-space: nowrap;
}

.site_search_empty_state {
  min-height: 210px;
  padding: 28px;
  border-radius: 22px;
  background: rgba(255, 255, 255, 0.58);
  border: 1px dashed rgba(188, 132, 32, 0.28);
  color: #6b6258;
  text-align: center;
}

.site_search_empty_icon {
  width: 56px;
  height: 56px;
  margin: 0 auto 14px;
  border-radius: 50%;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: rgba(255, 190, 51, 0.16);
  color: #bc8420;
  font-size: 22px;
}

.site_search_empty_state strong {
  display: block;
  color: #211a12;
  font-size: 18px;
}

.site_search_empty_state p {
  max-width: 390px;
  margin: 8px auto 0;
  line-height: 1.6;
}

html[data-theme="dark"] .header_section .container,
body.theme_dark .header_section .container {
  background: linear-gradient(135deg, rgba(25, 20, 15, 0.72), rgba(40, 30, 20, 0.54));
  border-color: rgba(255, 210, 110, 0.15);
  box-shadow: 0 12px 30px rgba(0, 0, 0, 0.22), inset 0 1px 0 rgba(255, 255, 255, 0.06);
}

html[data-theme="dark"] .site_search_dialog,
body.theme_dark .site_search_dialog,
body.theme_dark .auth_dropdown_card,
body.theme_dark .cart_drawer_panel,
body.theme_dark .delivery_schedule_dialog,
body.theme_dark .product_gallery,
body.theme_dark .product_info_card,
body.theme_dark .product_story_card,
body.theme_dark .review_card,
body.theme_dark .reviews_summary_card,
body.theme_dark .review_form_card,
body.theme_dark .wishlist_card {
  background: linear-gradient(180deg, rgba(36, 29, 22, 0.9), rgba(24, 20, 16, 0.88));
  border-color: rgba(255, 211, 106, 0.16);
  color: #f7f0e2;
  box-shadow: 0 18px 42px rgba(0, 0, 0, 0.24);
}

html[data-theme="dark"] .site_search_backdrop,
body.theme_dark .site_search_backdrop {
  background: rgba(10, 8, 6, 0.58);
}

html[data-theme="dark"] .site_search_header h3,
body.theme_dark .site_search_header h3,
body.theme_dark .cart_drawer_header h3,
body.theme_dark .delivery_schedule_dialog h3,
body.theme_dark .auth_dropdown_user strong,
body.theme_dark .review_notice_card strong {
  color: #f7f0e2;
}

html[data-theme="dark"] .site_search_hint,
html[data-theme="dark"] .site_search_result_meta,
body.theme_dark .site_search_hint,
body.theme_dark .site_search_result_meta,
body.theme_dark .auth_dropdown_card p,
body.theme_dark .auth_dropdown_user span,
body.theme_dark .delivery_schedule_dialog p,
body.theme_dark .cart_item_price {
  color: #c9bca6;
}

html[data-theme="dark"] .site_search_input_wrap,
body.theme_dark .site_search_input_wrap,
body.theme_dark .cart_qty_controls,
body.theme_dark .cart_empty_state,
body.theme_dark .review_empty_state {
  background: rgba(255, 246, 229, 0.07);
  border-color: rgba(255, 211, 106, 0.14);
}

html[data-theme="dark"] .site_search_input_wrap input,
body.theme_dark .site_search_input_wrap input {
  color: #f7f0e2;
}

html[data-theme="dark"] .site_search_input_wrap input::placeholder,
body.theme_dark .site_search_input_wrap input::placeholder {
  color: rgba(247, 240, 226, 0.55);
}

html[data-theme="dark"] .site_search_result,
body.theme_dark .site_search_result,
body.theme_dark .cart_item,
body.theme_dark .delivery_schedule_list li,
body.theme_dark .product_spec_row {
  background: rgba(255, 246, 229, 0.06);
  border-color: rgba(255, 211, 106, 0.13);
}

html[data-theme="dark"] .site_search_result:hover,
html[data-theme="dark"] .site_search_result:focus,
html[data-theme="dark"] .site_search_result.is_active,
body.theme_dark .site_search_result:hover,
body.theme_dark .site_search_result:focus,
body.theme_dark .site_search_result.is_active {
  background: rgba(255, 246, 229, 0.1);
  border-color: rgba(255, 211, 106, 0.34);
}

html[data-theme="dark"] .site_search_result img,
body.theme_dark .site_search_result img,
body.theme_dark .cart_item_image,
body.theme_dark .product_main_image,
body.theme_dark .food_section .box.product-card .img-box {
  background: rgba(255, 255, 255, 0.9);
}

html[data-theme="dark"] .site_search_result strong,
body.theme_dark .site_search_result strong,
body.theme_dark .cart_item_header strong,
body.theme_dark .product_spec_row dt,
body.theme_dark .product_unit_price,
body.theme_dark .product_total_price {
  color: #f7f0e2;
}

html[data-theme="dark"] .site_search_close,
body.theme_dark .site_search_close,
body.theme_dark .cart_drawer_close,
body.theme_dark .delivery_schedule_close,
body.theme_dark .cart_clear_btn,
body.theme_dark .review_delete_btn,
body.theme_dark .auth_dropdown_link,
body.theme_dark .auth_dropdown_btn_secondary {
  background: rgba(255, 246, 229, 0.08);
  color: #f7f0e2;
  border-color: rgba(255, 211, 106, 0.14);
}

body.theme_dark .auth_dropdown_link:hover,
body.theme_dark .auth_dropdown_link:focus {
  background: rgba(255, 246, 229, 0.14);
  color: #fff3d3;
}

html[data-theme="dark"] .site_search_empty_state,
body.theme_dark .site_search_empty_state {
  background: rgba(255, 246, 229, 0.06);
  border-color: rgba(255, 211, 106, 0.22);
  color: #c9bca6;
}

html[data-theme="dark"] .site_search_empty_state strong,
body.theme_dark .site_search_empty_state strong {
  color: #f7f0e2;
}

body.theme_dark .food_section,
body.theme_dark .about_section,
body.theme_dark .book_section,
body.theme_dark .product_details_section,
body.theme_dark .product_story_section,
body.theme_dark .product_recommendations_section,
body.theme_dark .product_reviews_section,
body.theme_dark .wishlist_section {
  background: transparent;
}

body.theme_dark .food_section .box.product-card {
  background: linear-gradient(180deg, rgba(38, 31, 24, 0.92), rgba(24, 20, 16, 0.94));
  border-color: rgba(255, 211, 106, 0.16);
  box-shadow: 0 14px 34px rgba(0, 0, 0, 0.24);
}

body.theme_dark .food_section .box.product-card .detail-box h5,
body.theme_dark .food_section .box.product-card .detail-box h5 a,
body.theme_dark .food_section .box.product-card .detail-box p,
body.theme_dark .food_section .box.product-card .detail-box h6 {
  color: #f7f0e2;
}

html[data-theme="dark"] .product_title_tooltip,
body.theme_dark .product_title_tooltip {
  background: linear-gradient(135deg, rgba(39, 31, 23, 0.92), rgba(23, 19, 15, 0.86));
  border-color: rgba(255, 211, 106, 0.18);
  color: #f7f0e2;
  box-shadow: 0 18px 44px rgba(0, 0, 0, 0.34), inset 0 1px 0 rgba(255, 255, 255, 0.06);
}

html[data-theme="dark"] .product_title_tooltip::before,
body.theme_dark .product_title_tooltip::before {
  border-color: rgba(255, 211, 106, 0.18);
}

body.theme_dark .product_feature_list li,
body.theme_dark .product_story_list li,
body.theme_dark .product_info_card p,
body.theme_dark .product_story_body,
body.theme_dark .product_story_body p,
body.theme_dark .product_spec_row dd {
  color: #d7cbb7;
}

/* Dark mode premium readability and product polish */
:root {
  --dark-text-primary: #fff8e8;
  --dark-text-secondary: #d8cbb8;
  --dark-text-muted: #b9aa94;
  --dark-accent-gold: #f2c76b;
  --dark-accent-gold-deep: #b9872c;
  --dark-glass: rgba(255, 248, 232, 0.075);
  --dark-glass-strong: rgba(255, 248, 232, 0.11);
  --dark-border: rgba(242, 199, 107, 0.18);
}

html[data-theme="dark"] body,
body.theme_dark {
  color: var(--dark-text-primary);
}

html[data-theme="dark"] h1,
html[data-theme="dark"] h2,
html[data-theme="dark"] h3,
html[data-theme="dark"] h4,
html[data-theme="dark"] h5,
html[data-theme="dark"] h6,
body.theme_dark h1,
body.theme_dark h2,
body.theme_dark h3,
body.theme_dark h4,
body.theme_dark h5,
body.theme_dark h6 {
  color: var(--dark-text-primary);
}

html[data-theme="dark"] p,
html[data-theme="dark"] li,
html[data-theme="dark"] label,
html[data-theme="dark"] span,
body.theme_dark p,
body.theme_dark li,
body.theme_dark label,
body.theme_dark span {
  color: inherit;
}

html[data-theme="dark"] a,
body.theme_dark a {
  color: var(--dark-accent-gold);
}

html[data-theme="dark"] a:hover,
html[data-theme="dark"] a:focus,
body.theme_dark a:hover,
body.theme_dark a:focus {
  color: #ffe09a;
}

.custom_nav-container .navbar-nav .nav-item .nav-link {
  font-size: 13.5px;
}

.user_option {
  gap: 10px;
}

.auth_button,
.user_option .cart_link,
.user_option .nav_search-btn,
.user_option .theme_toggle {
  box-shadow: 0 8px 18px rgba(0, 0, 0, 0.14);
}

.auth_button:hover,
.auth_button:focus,
.user_option .cart_link:hover,
.user_option .cart_link:focus,
.user_option .nav_search-btn:hover,
.user_option .nav_search-btn:focus {
  box-shadow: 0 10px 22px rgba(0, 0, 0, 0.18);
}

html[data-theme="dark"] .auth_button,
body.theme_dark .auth_button,
html[data-theme="dark"] .user_option .cart_link,
body.theme_dark .user_option .cart_link,
html[data-theme="dark"] .user_option .nav_search-btn,
body.theme_dark .user_option .nav_search-btn {
  background: rgba(255, 248, 232, 0.065);
  border-color: rgba(242, 199, 107, 0.14);
  color: var(--dark-text-primary);
  box-shadow: 0 8px 18px rgba(0, 0, 0, 0.12);
}

html[data-theme="dark"] .auth_button:hover,
body.theme_dark .auth_button:hover,
html[data-theme="dark"] .auth_button:focus,
body.theme_dark .auth_button:focus,
html[data-theme="dark"] .user_option .cart_link:hover,
body.theme_dark .user_option .cart_link:hover,
html[data-theme="dark"] .user_option .cart_link:focus,
body.theme_dark .user_option .cart_link:focus,
html[data-theme="dark"] .user_option .nav_search-btn:hover,
body.theme_dark .user_option .nav_search-btn:hover,
html[data-theme="dark"] .user_option .nav_search-btn:focus,
body.theme_dark .user_option .nav_search-btn:focus {
  background: rgba(242, 199, 107, 0.13);
  border-color: rgba(242, 199, 107, 0.34);
  color: #ffe09a;
  box-shadow: 0 10px 22px rgba(0, 0, 0, 0.16);
}

.user_option .theme_toggle {
  background:
    linear-gradient(145deg, rgba(255, 233, 171, 0.16), rgba(19, 16, 13, 0.9)),
    #17130f;
  border-color: rgba(242, 199, 107, 0.34);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.12), 0 8px 18px rgba(0, 0, 0, 0.18);
}

.theme_toggle_orbit {
  width: 26px;
  height: 26px;
}

.theme_toggle_ring {
  position: absolute;
  inset: 1px;
  border-radius: 50%;
  border: 1px solid rgba(242, 199, 107, 0.42);
  background: radial-gradient(circle at 50% 50%, rgba(242, 199, 107, 0.08), transparent 62%);
  transition: border-color 0.28s ease, transform 0.28s ease, opacity 0.28s ease;
}

.theme_toggle_disc {
  position: relative;
  z-index: 2;
  width: 17px;
  height: 17px;
  background: radial-gradient(circle at 32% 28%, #fff9d6 0 17%, #f7d577 18% 58%, #af7d27 59% 100%);
  box-shadow: inset -3px -4px 6px rgba(111, 72, 15, 0.28), 0 0 0 2px rgba(242, 199, 107, 0.1);
}

.theme_toggle_shadow {
  position: absolute;
  z-index: 3;
  width: 15px;
  height: 15px;
  border-radius: 50%;
  background: #17130f;
  transform: translate(10px, -9px) scale(0);
  transform-origin: center;
  transition: transform 0.28s ease;
}

.theme_toggle_spark {
  z-index: 4;
  background: #f7d577;
  box-shadow: 0 0 8px rgba(247, 213, 119, 0.5);
}

.theme_toggle[aria-pressed="true"] .theme_toggle_ring {
  border-color: rgba(255, 230, 163, 0.5);
  transform: rotate(-18deg);
}

.theme_toggle[aria-pressed="true"] .theme_toggle_disc {
  background: linear-gradient(135deg, #ffe6a3, #b9872c);
  transform: rotate(-18deg) scale(0.98);
  box-shadow: inset -4px -5px 7px rgba(93, 60, 13, 0.32), 0 0 0 2px rgba(242, 199, 107, 0.1);
}

.theme_toggle[aria-pressed="true"] .theme_toggle_shadow {
  transform: translate(6px, -5px) scale(1);
}

.user_option .theme_toggle:hover,
.user_option .theme_toggle:focus {
  background:
    linear-gradient(145deg, rgba(255, 233, 171, 0.22), rgba(19, 16, 13, 0.9)),
    #17130f;
  border-color: rgba(255, 224, 154, 0.58);
  box-shadow: 0 0 18px rgba(242, 199, 107, 0.2), inset 0 1px 0 rgba(255, 255, 255, 0.14);
}

.user_option .theme_toggle:hover .theme_toggle_ring,
.user_option .theme_toggle:focus .theme_toggle_ring {
  transform: rotate(18deg) scale(1.04);
}

.product_details_section .row {
  row-gap: 24px;
}

.product_gallery,
.product_info_card {
  height: 100%;
}

.product_info_card {
  display: flex;
  flex-direction: column;
}

body.theme_dark .product_gallery,
body.theme_dark .product_info_card,
body.theme_dark .product_story_card,
body.theme_dark .recommendation_card,
body.theme_dark .recommendations_empty,
body.theme_dark .reviews_summary_card,
body.theme_dark .reviews_panel,
body.theme_dark .review_notice_card,
body.theme_dark .review_card {
  background: linear-gradient(180deg, rgba(39, 32, 24, 0.86), rgba(20, 17, 14, 0.92));
  border-color: var(--dark-border);
  box-shadow: 0 22px 50px rgba(0, 0, 0, 0.24), inset 0 1px 0 rgba(255, 248, 232, 0.045);
}

body.theme_dark .product_info_card h1,
body.theme_dark .product_story_card .heading_container h2,
body.theme_dark .product_story_title,
body.theme_dark .product_story_block h4,
body.theme_dark .product_meta_title,
body.theme_dark .reviews_summary_card h2,
body.theme_dark .reviews_panel_head h3,
body.theme_dark .rating_overview_score,
body.theme_dark .review_card_identity strong {
  color: var(--dark-text-primary);
}

body.theme_dark .product_info_card p,
body.theme_dark #productDescription,
body.theme_dark .product_story_lead,
body.theme_dark .product_story_body,
body.theme_dark .product_story_body p,
body.theme_dark .product_story_list li,
body.theme_dark .product_feature_list li,
body.theme_dark .product_rating_meta,
body.theme_dark .reviews_summary_text,
body.theme_dark .reviews_panel_head p,
body.theme_dark .review_notice_card p,
body.theme_dark .review_form_status,
body.theme_dark .review_card p,
body.theme_dark .review_card_identity span,
body.theme_dark .recommendation_card_rating,
body.theme_dark .recommendation_card_body p,
body.theme_dark .wishlist_card p {
  color: var(--dark-text-secondary);
}

body.theme_dark #productDescription {
  font-size: 1rem;
  line-height: 1.8;
  margin: 0 0 8px;
}

body.theme_dark .product_rating_meta {
  background: rgba(242, 199, 107, 0.105);
  border-color: rgba(242, 199, 107, 0.18);
  color: var(--dark-text-muted);
}

body.theme_dark .product_rating_meta .rating_stars_wrap,
body.theme_dark .product_rating_meta .rating_stars {
  color: var(--dark-accent-gold);
}

body.theme_dark .product_story_card {
  color: var(--dark-text-primary);
}

body.theme_dark .product_story_block {
  border-top-color: rgba(242, 199, 107, 0.13);
}

body.theme_dark .product_story_link {
  color: var(--dark-accent-gold);
}

body.theme_dark .product_story_link:hover,
body.theme_dark .product_story_link:focus {
  color: #ffe09a;
}

body.theme_dark .product_meta_section {
  border-top-color: rgba(242, 199, 107, 0.15);
}

.product_spec_row {
  align-items: center;
  min-height: 58px;
}

body.theme_dark .product_spec_row {
  background: linear-gradient(135deg, rgba(255, 248, 232, 0.08), rgba(255, 248, 232, 0.035));
  border-color: rgba(242, 199, 107, 0.16);
  box-shadow: inset 0 1px 0 rgba(255, 248, 232, 0.05);
}

body.theme_dark .product_spec_row dt {
  color: var(--dark-text-primary);
}

body.theme_dark .product_spec_row dd {
  color: var(--dark-text-secondary);
}

.quantity_wrap {
  margin-top: 22px;
  padding-top: 18px;
  border-top: 1px solid rgba(212, 175, 55, 0.14);
}

.quantity_wrap span {
  display: block;
  margin-bottom: 10px;
}

.qty_controls {
  min-height: 46px;
}

.qty_controls button,
.qty_controls input {
  height: 46px;
}

body.theme_dark .quantity_wrap {
  border-top-color: rgba(242, 199, 107, 0.14);
}

body.theme_dark .quantity_wrap span {
  color: var(--dark-text-primary);
}

body.theme_dark .qty_controls {
  background: var(--dark-glass);
  border-color: rgba(242, 199, 107, 0.22);
}

body.theme_dark .qty_controls button {
  background: rgba(255, 248, 232, 0.055);
  color: var(--dark-text-primary);
}

body.theme_dark .qty_controls button:hover,
body.theme_dark .qty_controls button:focus {
  background: rgba(242, 199, 107, 0.16);
  color: #ffe09a;
}

body.theme_dark .qty_controls input {
  background: rgba(255, 248, 232, 0.08);
  color: var(--dark-text-primary);
}

.product_unit_price,
.product_total_price {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: 16px;
  margin: 18px 0 0;
  padding: 14px 16px;
  border-radius: 16px;
  background: rgba(255, 255, 255, 0.04);
}

body.theme_dark .product_unit_price,
body.theme_dark .product_total_price {
  background: var(--dark-glass);
  border: 1px solid rgba(242, 199, 107, 0.13);
  color: var(--dark-text-primary) !important;
}

body.theme_dark .product_unit_price span,
body.theme_dark .product_total_price span {
  color: var(--dark-accent-gold);
}

.product_action_row {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px;
  margin-top: 24px;
}

.product_action_row .return_menu_btn,
.product_cart_primary_btn,
.product_checkout_btn,
.product_share_detail_btn {
  width: 100%;
  min-height: 50px;
  margin: 0;
  padding: 0 18px;
  border-radius: 16px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  line-height: 1.15;
  text-align: center;
}

.product_action_row i {
  width: 18px;
  min-width: 18px;
  font-size: 17px;
  line-height: 1;
  text-align: center;
}

.product_cart_primary_btn {
  background: linear-gradient(135deg, #ffd875, #f2b019);
  color: #16110a;
  box-shadow: 0 14px 28px rgba(242, 176, 25, 0.2);
}

.product_action_row .return_menu_btn,
.product_share_detail_btn {
  border: 1px solid rgba(255, 255, 255, 0.14);
  background: rgba(255, 255, 255, 0.065);
  color: #f8f0df;
}

.product_action_row .return_menu_btn:hover,
.product_action_row .return_menu_btn:focus,
.product_share_detail_btn:hover,
.product_share_detail_btn:focus {
  background: rgba(242, 199, 107, 0.14);
  border-color: rgba(242, 199, 107, 0.36);
  color: #ffe09a;
}

body.theme_dark .site_search_dialog {
  background: linear-gradient(180deg, rgba(36, 29, 22, 0.96), rgba(20, 17, 14, 0.94));
}

body.theme_dark .site_search_result_category,
body.theme_dark .site_search_section_label {
  color: var(--dark-accent-gold);
}

body.theme_dark .site_search_result_meta,
body.theme_dark .site_search_hint {
  color: var(--dark-text-muted);
}

body.theme_dark .site_search_result_action {
  background: rgba(242, 199, 107, 0.16);
  color: #ffe09a;
}

body.theme_dark .wishlist_header .heading_container p,
body.theme_dark .wishlist_empty_state p,
body.theme_dark .wishlist_card_category,
body.theme_dark .product_card_rating_text {
  color: var(--dark-text-muted);
}

body.theme_dark .wishlist_empty_state {
  background: linear-gradient(180deg, rgba(36, 29, 22, 0.9), rgba(24, 20, 16, 0.9));
  border: 1px solid var(--dark-border);
}

body.theme_dark .wishlist_empty_icon {
  background: rgba(242, 199, 107, 0.14);
  color: var(--dark-accent-gold);
}

body.theme_dark .wishlist_card h3 a,
body.theme_dark .recommendation_card h3 a {
  color: var(--dark-text-primary);
}

body.theme_dark .wishlist_card_footer strong,
body.theme_dark .recommendation_card_price {
  color: var(--dark-accent-gold);
}

body.theme_dark .food_section .box.product-card .detail-box h5,
body.theme_dark .food_section .box.product-card .detail-box h5 a {
  color: var(--dark-text-primary);
}

body.theme_dark .food_section .box.product-card .detail-box p {
  color: var(--dark-text-secondary);
}

body.theme_dark .food_section .box.product-card .detail-box h6 {
  color: var(--dark-accent-gold);
}

body.theme_dark .recommendation_card_image {
  background: rgba(255, 255, 255, 0.9);
}

body.theme_dark .recommendation_card_label,
body.theme_dark .reviews_kicker,
body.theme_dark .review_owner_badge {
  background: rgba(242, 199, 107, 0.15);
  color: #ffe09a;
}

body.theme_dark .recommendation_link {
  background: var(--dark-glass);
  color: var(--dark-text-primary);
  border: 1px solid rgba(242, 199, 107, 0.14);
}

body.theme_dark .recommendation_link:hover,
body.theme_dark .recommendation_link:focus {
  background: rgba(242, 199, 107, 0.14);
  color: #ffe09a;
}

body.theme_dark .review_field label {
  color: var(--dark-text-primary);
}

body.theme_dark .review_field textarea {
  background: rgba(255, 248, 232, 0.07);
  border-color: rgba(242, 199, 107, 0.18);
  color: var(--dark-text-primary);
}

body.theme_dark .review_field textarea::placeholder {
  color: rgba(216, 203, 184, 0.62);
}

/* Premium products heading */
.food_section .heading_container.heading_center {
  align-items: center;
  max-width: 820px;
  margin: 0 auto;
  text-align: center;
}

.food_section .heading_container h2 {
  color: #1f2733;
  font-family: 'Kaushan Script', cursive;
  font-size: 2.85rem;
  font-weight: 400;
  letter-spacing: 0.2px;
}

.food_section .heading_container h2::after {
  content: "";
  display: block;
  width: 86px;
  height: 3px;
  margin: 14px auto 0;
  border-radius: 999px;
  background: linear-gradient(90deg, transparent, #d4af37, transparent);
}

.products_heading_subtitle {
  max-width: 680px;
  margin: 16px auto 0;
  color: #68717d;
  font-size: 1rem;
  line-height: 1.75;
  font-weight: 600;
}

.food_section .filters_menu {
  gap: 10px;
  margin: 34px auto 28px;
  padding: 8px;
  width: fit-content;
  max-width: 100%;
  border-radius: 24px;
  background: rgba(34, 40, 49, 0.04);
  border: 1px solid rgba(34, 40, 49, 0.08);
}

.food_section .filters_menu li {
  min-height: 40px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 9px 18px;
  border-radius: 999px;
  color: #26303c;
  font-size: 14px;
  font-weight: 800;
  line-height: 1.1;
  border: 1px solid transparent;
  transition: background-color 0.2s ease, border-color 0.2s ease, color 0.2s ease, transform 0.2s ease;
}

.food_section .filters_menu li:hover {
  color: #9a6a10;
  background: rgba(255, 190, 51, 0.12);
  border-color: rgba(212, 175, 55, 0.18);
  transform: translateY(-1px);
}

.food_section .filters_menu li.active {
  background: linear-gradient(135deg, #24201a, #11100e);
  color: #f7d577;
  border-color: rgba(212, 175, 55, 0.34);
  box-shadow: 0 12px 24px rgba(17, 16, 14, 0.18);
}

.food_section .filters-content {
  margin-top: 8px;
}

body.theme_dark .food_section .heading_container h2 {
  color: var(--dark-text-primary);
}

body.theme_dark .products_heading_subtitle {
  color: var(--dark-text-secondary);
}

body.theme_dark .food_section .filters_menu {
  background: rgba(255, 248, 232, 0.055);
  border-color: rgba(242, 199, 107, 0.14);
}

body.theme_dark .food_section .filters_menu li {
  color: var(--dark-text-secondary);
}

body.theme_dark .food_section .filters_menu li:hover {
  color: #ffe09a;
  background: rgba(242, 199, 107, 0.12);
  border-color: rgba(242, 199, 107, 0.22);
}

body.theme_dark .food_section .filters_menu li.active {
  background: linear-gradient(135deg, #f7d577, #b9872c);
  color: #16110a;
  border-color: rgba(255, 224, 154, 0.42);
  box-shadow: 0 12px 26px rgba(242, 199, 107, 0.16);
}

body:not(.sub_page) #products.food_section.layout_padding-bottom {
  padding-bottom: 46px;
}

body:not(.sub_page) #products + .about_section.layout_padding {
  padding-top: 54px;
}

.products_view_more {
  display: flex;
  justify-content: center;
  margin-top: 34px;
}

.products_view_more_btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  min-height: 50px;
  min-width: 168px;
  padding: 13px 28px;
  border-radius: 999px;
  background: linear-gradient(135deg, #24201a, #11100e);
  border: 1px solid rgba(212, 175, 55, 0.45);
  color: #f7d577;
  font-size: 15px;
  font-weight: 800;
  letter-spacing: 0;
  line-height: 1.1;
  box-shadow: 0 14px 30px rgba(17, 16, 14, 0.2);
  transition: transform 0.2s ease, box-shadow 0.2s ease, border-color 0.2s ease, background-color 0.2s ease;
}

.products_view_more_btn:hover,
.products_view_more_btn:focus {
  color: #11100e;
  background: linear-gradient(135deg, #f7d577, #b9872c);
  border-color: rgba(185, 135, 44, 0.64);
  box-shadow: 0 18px 34px rgba(185, 135, 44, 0.26);
  transform: translateY(-2px);
}

.products_view_more_btn i {
  font-size: 18px;
  line-height: 1;
}

body.sub_page .food_section .products_end_state {
  width: min(100%, 520px);
  display: grid;
  justify-items: center;
  gap: 8px;
  margin: 34px auto 0;
  padding: 22px 18px;
  border: 1px solid rgba(180, 125, 25, 0.24);
  border-radius: 18px;
  background: linear-gradient(180deg, #fffaf0, #ffffff);
  color: #2b2114;
  text-align: center;
  box-shadow: 0 16px 34px rgba(40, 28, 10, 0.1);
}

body.sub_page .food_section .products_end_icon {
  width: 42px;
  height: 42px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 50%;
  background: linear-gradient(135deg, #f7d577, #b9872c);
  color: #16110a;
  font-size: 17px;
  box-shadow: 0 12px 24px rgba(185, 135, 44, 0.2);
}

body.sub_page .food_section .products_end_state strong {
  color: #2b2114;
  font-size: 1rem;
  font-weight: 900;
  line-height: 1.3;
}

body.sub_page .food_section .products_end_state p {
  margin: 0;
  color: #7a5200;
  font-size: 0.92rem;
  line-height: 1.45;
}

html[data-theme="dark"] body.sub_page .food_section .products_end_state,
body.theme_dark.sub_page .food_section .products_end_state {
  border-color: rgba(242, 199, 107, 0.22);
  background: linear-gradient(180deg, rgba(39, 32, 24, 0.92), rgba(18, 15, 12, 0.94));
  color: #fff8e8;
  box-shadow: 0 18px 38px rgba(0, 0, 0, 0.24);
}

html[data-theme="dark"] body.sub_page .food_section .products_end_state strong,
body.theme_dark.sub_page .food_section .products_end_state strong {
  color: #fff8e8;
}

html[data-theme="dark"] body.sub_page .food_section .products_end_state p,
body.theme_dark.sub_page .food_section .products_end_state p {
  color: rgba(255, 248, 232, 0.68);
}

@media (max-width: 575px) {
  body.sub_page .food_section .products_end_state {
    margin-top: 24px;
    padding: 18px 14px;
    border-radius: 16px;
  }
}

body.theme_dark .products_view_more_btn,
html[data-theme="dark"] .products_view_more_btn {
  background: linear-gradient(135deg, #f7d577, #b9872c);
  border-color: rgba(255, 224, 154, 0.48);
  color: #16110a;
  box-shadow: 0 16px 32px rgba(242, 199, 107, 0.16);
}

body.theme_dark .products_view_more_btn:hover,
body.theme_dark .products_view_more_btn:focus,
html[data-theme="dark"] .products_view_more_btn:hover,
html[data-theme="dark"] .products_view_more_btn:focus {
  background: linear-gradient(135deg, #ffe6a6, #d4af37);
  color: #11100e;
  border-color: rgba(255, 230, 166, 0.7);
}

/* Minimal premium navbar after removing duplicate products CTA */
.custom_nav-container .navbar-nav {
  gap: 8px;
}

.custom_nav-container,
.custom_nav-container .user_option,
.custom_nav-container .user_option .cart_link {
  overflow: visible;
}

.user_option {
  gap: 10px;
  margin-left: 18px;
}

.user_option .auth_shell,
.user_option .cart_link,
.user_option .site_search_toggle_form,
.user_option form,
.user_option .theme_toggle {
  margin: 0;
}

.auth_button,
.user_option .cart_link,
.user_option .nav_search-btn,
.user_option .theme_toggle {
  box-shadow: 0 8px 18px rgba(0, 0, 0, 0.12);
}

body.theme_dark .auth_button,
body.theme_dark .user_option .cart_link,
body.theme_dark .user_option .nav_search-btn,
body.theme_dark .user_option .theme_toggle {
  box-shadow: 0 8px 18px rgba(0, 0, 0, 0.14);
}

/* Premium compact navbar proportions */
.header_section {
  padding: 12px 0;
}

.header_section .container {
  width: min(1180px, calc(100% - 56px));
  min-height: 62px;
  padding: 7px 14px 7px 16px;
  border-radius: 18px;
}

.custom_nav-container {
  min-height: 46px;
}

.navbar-brand {
  gap: 9px;
}

.navbar-brand img {
  width: 44px;
  height: 44px;
  padding: 5px;
  border-radius: 13px;
}

.navbar-brand span {
  font-size: 28px;
}

.custom_nav-container .navbar-collapse {
  gap: 14px;
}

.custom_nav-container .navbar-nav {
  gap: 4px;
  margin-left: auto;
  margin-right: auto;
}

.custom_nav-container .navbar-nav .nav-item .nav-link {
  min-height: 38px;
  padding: 8px 11px;
  font-size: 12.5px;
}

.user_option {
  gap: 8px;
  margin-left: 12px;
}

.auth_button,
.user_option .cart_link,
.user_option .nav_search-btn,
.user_option .theme_toggle {
  width: 38px;
  min-width: 38px;
  min-height: 38px;
  height: 38px;
}

.auth_button {
  width: auto;
  max-width: 146px;
  padding: 4px 9px 4px 4px;
}

.auth_avatar {
  width: 28px;
  height: 28px;
}

.auth_button_text {
  max-width: 72px;
  font-size: 12.5px;
}

.user_option .cart_link svg {
  width: 16px;
}

.user_option .offers_nav_btn,
.custom_nav-container > .offers_nav_btn {
  position: relative;
  order: 2;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 7px;
  min-width: 86px;
  min-height: 38px;
  height: 38px;
  margin: 0;
  padding: 0 13px;
  flex-shrink: 0;
  border: 1px solid rgba(255, 211, 106, 0.42);
  border-radius: 999px;
  background:
    linear-gradient(135deg, rgba(255, 217, 125, 0.22), rgba(111, 74, 11, 0.2)),
    rgba(255, 255, 255, 0.08);
  color: #fff4da;
  font-size: 12.5px;
  font-family: inherit;
  font-weight: 900;
  line-height: 1;
  letter-spacing: 0;
  white-space: nowrap;
  text-decoration: none;
  text-shadow: none;
  cursor: pointer;
  box-shadow: 0 10px 24px rgba(255, 190, 51, 0.12), inset 0 1px 0 rgba(255, 255, 255, 0.12);
  transition: background-color 0.2s ease, border-color 0.2s ease, color 0.2s ease, transform 0.2s ease, box-shadow 0.2s ease;
}

.user_option .offers_nav_btn i,
.custom_nav-container > .offers_nav_btn i {
  color: #ffd66f;
  font-size: 14px;
  line-height: 1;
}

.user_option .offers_nav_btn:hover,
.user_option .offers_nav_btn:focus,
.user_option .offers_nav_btn.is_active,
.custom_nav-container > .offers_nav_btn:hover,
.custom_nav-container > .offers_nav_btn:focus,
.custom_nav-container > .offers_nav_btn.is_active {
  border-color: rgba(255, 220, 128, 0.7);
  background:
    linear-gradient(135deg, rgba(255, 217, 125, 0.32), rgba(111, 74, 11, 0.26)),
    rgba(255, 255, 255, 0.1);
  color: #ffe09a;
  box-shadow: 0 14px 30px rgba(255, 190, 51, 0.16), 0 0 18px rgba(255, 190, 51, 0.12), inset 0 1px 0 rgba(255, 255, 255, 0.14);
  outline: none;
  transform: translateY(-1px);
}

.offers_nav_badge {
  position: absolute;
  top: -7px;
  right: -7px;
  min-width: 19px;
  height: 19px;
  padding: 0 5px;
  border: 2px solid rgba(15, 13, 10, 0.94);
  border-radius: 999px;
  background: linear-gradient(135deg, #ff3f3f, #a70f18);
  color: #ffffff;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 10.5px;
  font-weight: 900;
  line-height: 1;
  box-shadow: 0 8px 16px rgba(167, 15, 24, 0.28), 0 0 0 1px rgba(255, 218, 115, 0.35);
}

.offers_nav_badge[hidden] {
  display: none;
}

.user_option .auth_shell {
  order: 1;
}

.user_option .cart_link {
  order: 3;
}

.user_option .site_search_toggle_form,
.user_option form {
  order: 4;
}

.user_option .theme_toggle {
  order: 5;
}

.user_option .custom-language-switcher {
  order: 6;
}

@media (max-width: 991px) {
  .custom_nav-container > .offers_nav_btn {
    order: 0;
    width: 38px;
    min-width: 38px;
    max-width: 38px;
    height: 38px;
    min-height: 38px;
    padding: 0;
    gap: 0;
    border-radius: 13px;
  }

  .custom_nav-container > .offers_nav_btn .offers_nav_label {
    display: none;
  }

  .custom_nav-container > .offers_nav_btn i {
    font-size: 15px;
  }

  .custom_nav-container > .offers_nav_btn .offers_nav_badge {
    top: -6px;
    right: -6px;
  }
}

@media (max-width: 575px) {
  .site_search_result {
    grid-template-columns: 64px minmax(0, 1fr);
  }

  .site_search_result img {
    width: 64px;
    height: 64px;
  }

  .site_search_result_action {
    grid-column: 1 / -1;
    width: 100%;
  }
}

/* Final UI audit polish: dark readability and footer */
.footer_section {
  position: relative;
  overflow: hidden;
  padding: 78px 0 34px;
  text-align: left;
  background:
    radial-gradient(circle at 12% 0%, rgba(242, 199, 107, 0.13), transparent 34%),
    linear-gradient(135deg, rgba(31, 35, 39, 0.96), rgba(13, 17, 16, 0.98));
  border-top: 1px solid rgba(242, 199, 107, 0.24);
  color: #fff8e8;
}

.footer_section::before {
  content: "";
  position: absolute;
  inset: 0 0 auto;
  height: 1px;
  background: linear-gradient(90deg, transparent, rgba(242, 199, 107, 0.72), transparent);
}

.footer_section .container {
  position: relative;
  z-index: 1;
}

.footer_section .row {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 34px;
  align-items: start;
  margin: 0;
}

.footer_section .row > [class*="col-"] {
  width: auto;
  max-width: none;
  padding: 0;
  -webkit-box-flex: initial;
      -ms-flex: initial;
          flex: initial;
}

.footer_section .footer-col {
  min-width: 0;
  margin-bottom: 0;
}

.footer_section h4 {
  position: relative;
  display: inline-flex;
  align-items: center;
  gap: 10px;
  margin: 0 0 22px;
  color: #f2c76b;
  font-family: "Open Sans", sans-serif;
  font-size: 0.84rem;
  font-weight: 800;
  letter-spacing: 0.08em;
  line-height: 1.3;
  text-transform: uppercase;
}

.footer_section h4::after {
  content: "";
  width: 34px;
  height: 1px;
  border-radius: 999px;
  background: rgba(242, 199, 107, 0.62);
}

.footer_section p {
  margin: 0 0 12px;
  color: #d9cfbd;
  font-size: 0.95rem;
  line-height: 1.75;
}

.footer_section .footer_contact .contact_link_box {
  gap: 10px;
}

.footer_section .footer_contact .contact_link_box a {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 11px;
  min-height: 44px;
  margin: 0;
  padding: 8px 12px;
  border: 1px solid rgba(242, 199, 107, 0.16);
  border-radius: 8px;
  background: rgba(255, 248, 232, 0.06);
  color: #fff8e8;
  line-height: 1.35;
  -webkit-transition: border-color 0.22s ease, background-color 0.22s ease, color 0.22s ease, -webkit-transform 0.22s ease;
  transition: border-color 0.22s ease, background-color 0.22s ease, color 0.22s ease, -webkit-transform 0.22s ease;
  transition: border-color 0.22s ease, background-color 0.22s ease, color 0.22s ease, transform 0.22s ease;
  transition: border-color 0.22s ease, background-color 0.22s ease, color 0.22s ease, transform 0.22s ease, -webkit-transform 0.22s ease;
}

.footer_section .footer_contact .contact_link_box a i {
  display: -webkit-inline-box;
  display: -ms-inline-flexbox;
  display: inline-flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  width: 30px;
  height: 30px;
  margin-right: 0;
  border-radius: 50%;
  background: rgba(242, 199, 107, 0.14);
  color: #f2c76b;
  -ms-flex-negative: 0;
      flex-shrink: 0;
}

.footer_section .footer_contact .contact_link_box a span {
  color: inherit;
}

.footer_section .footer_contact .contact_link_box a:hover,
.footer_section .footer_contact .contact_link_box a:focus {
  border-color: rgba(242, 199, 107, 0.38);
  background: rgba(242, 199, 107, 0.1);
  color: #ffe09a;
  -webkit-transform: translateY(-2px);
          transform: translateY(-2px);
}

.footer_section .footer_detail {
  max-width: 360px;
  margin: 0 auto;
  text-align: center;
}

.footer_section .footer-logo {
  display: inline-block;
  margin: 0 0 18px;
  color: #fff8e8;
  font-size: 2.45rem;
  line-height: 1;
  text-shadow: 0 12px 28px rgba(0, 0, 0, 0.28);
}

.footer_section .footer-logo:hover,
.footer_section .footer-logo:focus {
  color: #ffe09a;
}

.footer_section .footer_social {
  gap: 10px;
  justify-content: center;
  margin: 22px 0 0;
}

.footer_section .footer_social a {
  width: 38px;
  height: 38px;
  margin: 0;
  border: 1px solid rgba(242, 199, 107, 0.2);
  border-radius: 50%;
  background: rgba(255, 248, 232, 0.08);
  color: #fff8e8;
  font-size: 16px;
  -webkit-transition: border-color 0.22s ease, background-color 0.22s ease, color 0.22s ease, -webkit-transform 0.22s ease;
  transition: border-color 0.22s ease, background-color 0.22s ease, color 0.22s ease, -webkit-transform 0.22s ease;
  transition: border-color 0.22s ease, background-color 0.22s ease, color 0.22s ease, transform 0.22s ease;
  transition: border-color 0.22s ease, background-color 0.22s ease, color 0.22s ease, transform 0.22s ease, -webkit-transform 0.22s ease;
}

.footer_section .footer_social a:hover,
.footer_section .footer_social a:focus {
  border-color: rgba(242, 199, 107, 0.5);
  background: rgba(242, 199, 107, 0.15);
  color: #ffe09a;
  -webkit-transform: translateY(-2px);
          transform: translateY(-2px);
}

.footer_section .footer-col:last-child p {
  padding: 12px 14px;
  border: 1px solid rgba(242, 199, 107, 0.15);
  border-radius: 8px;
  background: rgba(255, 248, 232, 0.055);
  color: #eadfca;
}

.delivery-list.simple-footer-list {
  display: flex;
  flex-direction: column;
  gap: 12px;
}

.delivery-item {
  display: flex;
  align-items: center;
  gap: 14px;
  min-height: 58px;
  padding: 14px 18px;
  background: rgba(255, 255, 255, 0.045);
  border: 1px solid rgba(212, 160, 23, 0.25);
  border-radius: 12px;
  color: #e8e0d0;
  text-align: left;
  transition: transform 0.25s ease, border-color 0.25s ease, background-color 0.25s ease;
}

.footer_section .footer-col:last-child .delivery-item p {
  margin: 0;
  padding: 0;
  border: 0;
  border-radius: 0;
  background: transparent;
  color: #e8e0d0;
  font-size: 16px;
  line-height: 1.5;
  font-weight: 500;
  text-align: left;
}

.delivery-item strong {
  color: #ffffff;
  font-weight: 700;
}

.delivery-item .footer-icon {
  width: 38px;
  height: 38px;
  min-width: 38px;
  border-radius: 50%;
  background: rgba(245, 197, 66, 0.18);
  color: #f5c542;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 15px;
}

.delivery-item:hover {
  border-color: rgba(245, 197, 66, 0.55);
  background: rgba(255, 255, 255, 0.065);
  transform: translateY(-2px);
}

.footer_section .footer-info {
  margin-top: 38px;
  padding-top: 24px;
  border-top: 1px solid rgba(242, 199, 107, 0.14);
  text-align: center;
}

.footer_section .footer-info p,
.footer_section .footer-info p a {
  color: rgba(255, 248, 232, 0.72);
}

body.theme_dark .about_article_section,
body.theme_dark .how_to_order_section,
body.theme_dark .home_order_section {
  background:
    radial-gradient(circle at 18% 0%, rgba(242, 199, 107, 0.08), transparent 32%),
    linear-gradient(180deg, #101311 0%, #0c100f 100%);
  color: var(--dark-text-primary);
}

body.theme_dark .about_article_hero h1,
body.theme_dark .about_article_content h2,
body.theme_dark .about_highlight_panel h2,
body.theme_dark .about_product_item h3,
body.theme_dark .how_to_order_section .heading_container h2,
body.theme_dark .order_section_title,
body.theme_dark .order_step_item h5,
body.theme_dark .wholesale_order_box h3 {
  color: var(--dark-text-primary);
}

body.theme_dark .about_article_hero p,
body.theme_dark .about_article_content p,
body.theme_dark .about_product_item p,
body.theme_dark .about_highlight_panel p,
body.theme_dark .about_highlight_panel li,
body.theme_dark .about_check_list li,
body.theme_dark .how_to_order_intro,
body.theme_dark .order_step_item p,
body.theme_dark .wholesale_order_box p {
  color: var(--dark-text-secondary);
}

body.theme_dark .about_article_label,
body.theme_dark .wholesale_order_kicker {
  background: rgba(242, 199, 107, 0.14);
  border-color: rgba(242, 199, 107, 0.3);
  color: #ffe09a;
}

body.theme_dark .about_article_block {
  border-bottom-color: rgba(242, 199, 107, 0.14);
}

body.theme_dark .about_product_item,
body.theme_dark .about_image_panel,
body.theme_dark .about_highlight_panel,
body.theme_dark .order_step_item,
body.theme_dark .wholesale_order_box {
  background: linear-gradient(180deg, rgba(38, 31, 24, 0.9), rgba(20, 17, 14, 0.94));
  border-color: var(--dark-border);
  color: var(--dark-text-primary);
  -webkit-box-shadow: 0 18px 42px rgba(0, 0, 0, 0.24), inset 0 1px 0 rgba(255, 248, 232, 0.045);
          box-shadow: 0 18px 42px rgba(0, 0, 0, 0.24), inset 0 1px 0 rgba(255, 248, 232, 0.045);
}

body.theme_dark .order_step_item:hover {
  border-color: rgba(242, 199, 107, 0.38);
  -webkit-box-shadow: 0 22px 48px rgba(0, 0, 0, 0.3), 0 0 18px rgba(242, 199, 107, 0.08);
          box-shadow: 0 22px 48px rgba(0, 0, 0, 0.3), 0 0 18px rgba(242, 199, 107, 0.08);
}

body.theme_dark .order_step_icon {
  background: rgba(242, 199, 107, 0.14);
  border: 1px solid rgba(242, 199, 107, 0.24);
  color: var(--dark-accent-gold);
}

body.theme_dark .delivery_schedule_panel {
  background:
    linear-gradient(135deg, rgba(242, 199, 107, 0.08), transparent 42%),
    linear-gradient(180deg, rgba(35, 29, 22, 0.96), rgba(16, 14, 12, 0.98));
  border: 1px solid var(--dark-border);
  -webkit-box-shadow: 0 20px 46px rgba(0, 0, 0, 0.28);
          box-shadow: 0 20px 46px rgba(0, 0, 0, 0.28);
}

body.theme_dark .delivery_schedule_panel .heading_container h2,
body.theme_dark .delivery_schedule_item strong {
  color: var(--dark-text-primary);
}

body.theme_dark .delivery_schedule_panel .heading_container p {
  color: var(--dark-text-secondary);
}

body.theme_dark .delivery_schedule_item {
  background: rgba(255, 248, 232, 0.07);
  border-color: rgba(242, 199, 107, 0.16);
}

body.theme_dark .delivery_schedule_item span {
  color: var(--dark-accent-gold);
}

body.theme_dark .about_cta_section {
  background:
    radial-gradient(circle at 82% 0%, rgba(242, 199, 107, 0.12), transparent 34%),
    linear-gradient(135deg, #171b19, #0d1110);
}

body.theme_dark .about_cta_inner h2 {
  color: var(--dark-text-primary);
}

body.theme_dark .about_cta_inner a,
body.theme_dark .how_to_order_cta a {
  background: linear-gradient(135deg, #ffd875, #f2b019);
  color: #16110a;
}

body.theme_dark .about_cta_inner a:hover,
body.theme_dark .about_cta_inner a:focus,
body.theme_dark .how_to_order_cta a:hover,
body.theme_dark .how_to_order_cta a:focus {
  background: linear-gradient(135deg, #ffe09a, #e7a60f);
  color: #16110a;
}

body.theme_dark .wholesale_contact_btn {
  background: linear-gradient(135deg, #f7d577, #b9872c);
  color: #16110a;
}

body.theme_dark .wholesale_contact_btn:hover,
body.theme_dark .wholesale_contact_btn:focus {
  background: linear-gradient(135deg, #ffe09a, #e7a60f);
  color: #16110a;
}

body.theme_dark .auth_dropdown_btn,
body.theme_dark .recommendation_add_btn,
body.theme_dark .review_submit_btn,
body.theme_dark .cart_checkout_btn,
body.theme_dark .delivery_schedule_continue,
body.theme_dark .product_cart_primary_btn,
body.theme_dark .product_checkout_btn {
  color: #111111;
}

body.theme_dark .auth_dropdown_btn:hover,
body.theme_dark .auth_dropdown_btn:focus,
body.theme_dark .recommendation_add_btn:hover,
body.theme_dark .recommendation_add_btn:focus,
body.theme_dark .review_submit_btn:hover,
body.theme_dark .review_submit_btn:focus,
body.theme_dark .cart_checkout_btn:hover,
body.theme_dark .cart_checkout_btn:focus,
body.theme_dark .delivery_schedule_continue:hover,
body.theme_dark .delivery_schedule_continue:focus,
body.theme_dark .product_cart_primary_btn:hover,
body.theme_dark .product_cart_primary_btn:focus,
body.theme_dark .product_checkout_btn:hover,
body.theme_dark .product_checkout_btn:focus {
  color: #111111;
}

body.theme_dark .auth_dropdown_btn_secondary,
body.theme_dark .product_action_row .return_menu_btn,
body.theme_dark .product_share_detail_btn {
  color: var(--dark-text-primary);
}

body.theme_dark .food_section .box.product-card .options .product-link-btn {
  color: #16110a !important;
}

body.theme_dark .footer_section {
  background:
    radial-gradient(circle at 12% 0%, rgba(242, 199, 107, 0.1), transparent 34%),
    linear-gradient(135deg, rgba(17, 21, 20, 0.98), rgba(8, 11, 10, 0.99));
}

@media (max-width: 767px) {
  .footer_section {
    padding: 58px 0 30px;
    text-align: center;
  }

  .footer_section .row {
    grid-template-columns: 1fr;
    gap: 32px;
  }

  .footer_section h4 {
    justify-content: center;
  }

  .footer_section .footer_contact .contact_link_box a {
    justify-content: flex-start;
    text-align: left;
  }

  .footer_section .footer_detail {
    max-width: 100%;
  }

}

.custom-language-switcher {
  position: fixed;
  left: 28px;
  bottom: 28px;
  z-index: 999999;
}

.language-btn {
  background: rgba(25, 20, 15, 0.96);
  color: #fff;
  border: 1px solid #c89b2c;
  border-radius: 999px;
  padding: 12px 18px;
  display: flex;
  align-items: center;
  gap: 8px;
  font-weight: 700;
  cursor: pointer;
  box-shadow: 0 10px 25px rgba(0,0,0,0.35);
  transition: transform 0.2s ease, box-shadow 0.2s ease, border-color 0.2s ease, color 0.2s ease;
}

.language-btn:hover {
  transform: translateY(-2px);
  box-shadow: 0 14px 30px rgba(0,0,0,0.45);
}

.language-btn:focus {
  outline: none;
  border-color: #f5c542;
  color: #f5c542;
}

.language-menu {
  position: absolute;
  bottom: 58px;
  left: 0;
  min-width: 150px;
  background: rgba(25, 20, 15, 0.98);
  border: 1px solid #c89b2c;
  border-radius: 16px;
  padding: 8px;
  display: none;
  box-shadow: 0 12px 30px rgba(0,0,0,0.4);
}

.language-menu.active {
  display: block;
}

.language-menu button {
  width: 100%;
  background: transparent;
  color: #fff;
  border: none;
  padding: 10px 12px;
  border-radius: 10px;
  text-align: left;
  cursor: pointer;
  font-weight: 600;
}

.language-menu button:hover,
.language-menu button:focus {
  background: rgba(200, 155, 44, 0.18);
  color: #f5c542;
  outline: none;
}

@media (max-width: 575px) {
  .custom-language-switcher {
    left: 16px;
    bottom: 16px;
  }

  .language-btn {
    padding: 10px 14px;
  }
}

/* Luxury footer and language switcher refinement */
.footer_section {
  position: relative;
  --footer-text-font: "Open Sans", sans-serif;
  --footer-text-size: 0.9rem;
  --footer-text-weight: 600;
  --footer-text-line-height: 1.45;
  --footer-copy-size: 0.94rem;
  --footer-copy-weight: 400;
  --footer-copy-line-height: 1.7;
  overflow: hidden;
  padding: 82px 0 38px;
  text-align: left;
  background: radial-gradient(circle at 11% 0%, rgba(245, 189, 50, 0.16), transparent 35%), radial-gradient(circle at 88% 18%, rgba(245, 189, 50, 0.08), transparent 28%), linear-gradient(135deg, #101413 0%, #171d1c 48%, #0b0f0e 100%);
  border-top: 1px solid rgba(245, 189, 50, 0.25);
  color: #f7efe2;
  font-family: var(--footer-text-font);
  letter-spacing: 0;
}

.footer_section::before {
  content: "";
  position: absolute;
  inset: 0 0 auto;
  height: 1px;
  background: linear-gradient(90deg, transparent, rgba(245, 189, 50, 0.84), transparent);
}

.footer_section::after {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  opacity: 0.24;
  background-image: linear-gradient(rgba(255, 255, 255, 0.025) 1px, transparent 1px), linear-gradient(90deg, rgba(255, 255, 255, 0.018) 1px, transparent 1px);
  background-size: 34px 34px;
  -webkit-mask-image: linear-gradient(to bottom, rgba(0, 0, 0, 0.65), transparent 82%);
          mask-image: linear-gradient(to bottom, rgba(0, 0, 0, 0.65), transparent 82%);
}

.footer_section .container {
  position: relative;
  z-index: 1;
  max-width: 1180px;
  padding: 46px;
  border: 1px solid rgba(245, 189, 50, 0.16);
  border-radius: 28px;
  background: linear-gradient(135deg, rgba(255, 255, 255, 0.055), rgba(255, 255, 255, 0.018)), rgba(255, 255, 255, 0.035);
  -webkit-box-shadow: 0 24px 70px rgba(0, 0, 0, 0.32), inset 0 1px 0 rgba(255, 255, 255, 0.045);
          box-shadow: 0 24px 70px rgba(0, 0, 0, 0.32), inset 0 1px 0 rgba(255, 255, 255, 0.045);
  -webkit-backdrop-filter: blur(18px);
          backdrop-filter: blur(18px);
}

.footer_section .row {
  display: grid;
  grid-template-columns: minmax(0, 0.95fr) minmax(260px, 1.18fr) minmax(0, 0.95fr);
  gap: 36px;
  align-items: stretch;
  margin: 0;
}

.footer_section .row > [class*=col-] {
  width: auto;
  max-width: none;
  padding: 0;
  -webkit-box-flex: initial;
      -ms-flex: initial;
          flex: initial;
}

.footer_section .footer-col {
  min-width: 0;
  margin-bottom: 0;
}

.footer_section .footer-col:not(:nth-child(2)) {
  padding: 22px;
  border: 1px solid rgba(245, 189, 50, 0.12);
  border-radius: 18px;
  background: rgba(255, 255, 255, 0.028);
  -webkit-box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.04);
          box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.04);
}

.footer_section h4 {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  align-items: center;
  gap: 11px;
  margin: 0 0 20px;
  color: #f5c96b;
  font-family: "Open Sans", sans-serif;
  font-size: 0.82rem;
  font-weight: 800;
  letter-spacing: 0.11em;
  line-height: 1.3;
  text-transform: uppercase;
}

.footer_section h4::after {
  content: "";
  -webkit-box-flex: 1;
      -ms-flex: 1;
          flex: 1;
  max-width: 54px;
  height: 1px;
  border-radius: 999px;
  background: linear-gradient(90deg, rgba(245, 189, 50, 0.68), transparent);
}

.footer_section p {
  margin: 0;
  color: #d9cfbd;
  font-family: var(--footer-text-font);
  font-size: var(--footer-copy-size);
  font-weight: var(--footer-copy-weight);
  line-height: var(--footer-copy-line-height);
  letter-spacing: 0;
  text-transform: none;
}

.footer_section .footer_contact .contact_link_box {
  gap: 10px;
}

.footer_section .footer_contact .contact_link_box a {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  align-items: center;
  gap: 12px;
  min-height: 48px;
  margin: 0;
  padding: 8px 10px;
  border: 1px solid rgba(245, 189, 50, 0.12);
  border-radius: 14px;
  background: rgba(255, 255, 255, 0.035);
  color: #eee4d2;
  font-family: var(--footer-text-font);
  font-size: var(--footer-text-size);
  font-weight: var(--footer-text-weight);
  line-height: var(--footer-text-line-height);
  letter-spacing: 0;
  text-transform: none;
  -webkit-box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.035);
          box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.035);
  -webkit-transition: border-color 0.22s ease, background-color 0.22s ease, color 0.22s ease, -webkit-transform 0.22s ease;
  transition: border-color 0.22s ease, background-color 0.22s ease, color 0.22s ease, -webkit-transform 0.22s ease;
  transition: border-color 0.22s ease, background-color 0.22s ease, color 0.22s ease, transform 0.22s ease;
  transition: border-color 0.22s ease, background-color 0.22s ease, color 0.22s ease, transform 0.22s ease, -webkit-transform 0.22s ease;
}

.footer_section .footer_contact .contact_link_box a span {
  color: inherit;
  font: inherit;
  letter-spacing: inherit;
  line-height: inherit;
  text-transform: inherit;
}

.footer_section .footer_contact .contact_link_box a i {
  display: -webkit-inline-box;
  display: -ms-inline-flexbox;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 31px;
  height: 31px;
  margin-right: 0;
  border: 1px solid rgba(245, 189, 50, 0.46);
  border-radius: 50%;
  background: transparent;
  color: #f5c96b;
  font-size: 13px;
  -ms-flex-negative: 0;
      flex-shrink: 0;
}

.footer_section .footer_contact .contact_link_box a:hover,
.footer_section .footer_contact .contact_link_box a:focus {
  border-color: rgba(245, 189, 50, 0.28);
  background: rgba(245, 189, 50, 0.075);
  color: #fff3d8;
  -webkit-transform: translateY(-1px);
          transform: translateY(-1px);
}

.footer_section .footer_detail {
  height: 100%;
  max-width: 390px;
  margin: 0 auto;
  padding: 30px 24px;
  border-inline: 1px solid rgba(245, 189, 50, 0.12);
  text-align: center;
}

.footer_section .footer-logo {
  position: relative;
  display: -webkit-inline-box;
  display: -ms-inline-flexbox;
  display: inline-flex;
  flex-direction: column;
  align-items: center;
  gap: 14px;
  margin: 0 0 18px;
  color: #fff6df;
  font-size: 2.55rem;
  line-height: 1;
  text-shadow: 0 14px 30px rgba(0, 0, 0, 0.35);
}

.footer_section .footer-logo::after {
  content: "";
  width: 92px;
  height: 8px;
  border-block: 1px solid rgba(245, 189, 50, 0.46);
  background: radial-gradient(circle, rgba(245, 189, 50, 0.88) 0 2px, transparent 3px);
}

.footer_section .footer-logo:hover,
.footer_section .footer-logo:focus {
  color: #ffe09a;
}

.footer_section .footer_detail p {
  max-width: 330px;
  margin: 0 auto;
  color: #d9cfbd;
}

.footer_section .footer_social {
  gap: 11px;
  justify-content: center;
  margin: 26px 0 0;
}

.footer_section .footer_social a {
  width: 40px;
  height: 40px;
  margin: 0;
  border: 1px solid rgba(245, 189, 50, 0.32);
  border-radius: 50%;
  background: rgba(255, 255, 255, 0.035);
  color: #f7efe2;
  font-size: 15px;
  -webkit-box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.045);
          box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.045);
  -webkit-transition: border-color 0.22s ease, background-color 0.22s ease, color 0.22s ease, box-shadow 0.22s ease, -webkit-transform 0.22s ease;
  transition: border-color 0.22s ease, background-color 0.22s ease, color 0.22s ease, box-shadow 0.22s ease, -webkit-transform 0.22s ease;
  transition: border-color 0.22s ease, background-color 0.22s ease, color 0.22s ease, box-shadow 0.22s ease, transform 0.22s ease;
  transition: border-color 0.22s ease, background-color 0.22s ease, color 0.22s ease, box-shadow 0.22s ease, transform 0.22s ease, -webkit-transform 0.22s ease;
}

.footer_section .footer_social a:hover,
.footer_section .footer_social a:focus {
  border-color: rgba(245, 189, 50, 0.72);
  background: rgba(245, 189, 50, 0.11);
  color: #ffe09a;
  -webkit-box-shadow: 0 0 22px rgba(245, 189, 50, 0.16), inset 0 1px 0 rgba(255, 255, 255, 0.08);
          box-shadow: 0 0 22px rgba(245, 189, 50, 0.16), inset 0 1px 0 rgba(255, 255, 255, 0.08);
  -webkit-transform: translateY(-2px);
          transform: translateY(-2px);
}

.delivery-list.simple-footer-list {
  gap: 0;
  overflow: hidden;
  border: 1px solid rgba(245, 189, 50, 0.12);
  border-radius: 16px;
  background: rgba(255, 255, 255, 0.03);
}

.delivery-item {
  display: grid;
  grid-template-columns: 24px minmax(0, 1fr);
  gap: 11px;
  min-height: 0;
  padding: 13px 14px;
  border: 0;
  border-bottom: 1px solid rgba(245, 189, 50, 0.11);
  border-radius: 0;
  background: transparent;
  color: #e9decb;
  text-align: left;
  -webkit-transition: background-color 0.22s ease, color 0.22s ease;
  transition: background-color 0.22s ease, color 0.22s ease;
}

.delivery-item:last-child {
  border-bottom: 0;
}

.delivery-item .footer-icon {
  width: 24px;
  min-width: 24px;
  height: 24px;
  border: 1px solid rgba(245, 189, 50, 0.32);
  border-radius: 50%;
  background: transparent;
  color: #f5c96b;
  font-size: 10px;
}

.footer_section .footer-col:last-child p,
.footer_section .footer-col:last-child .delivery-item p {
  display: grid;
  grid-template-columns: minmax(96px, 0.9fr) minmax(0, 1.1fr);
  gap: 10px;
  align-items: baseline;
  margin: 0;
  padding: 0;
  border: 0;
  border-radius: 0;
  background: transparent;
  color: #d9cfbd;
  font-family: var(--footer-text-font);
  font-size: var(--footer-text-size);
  line-height: var(--footer-text-line-height);
  font-weight: var(--footer-text-weight);
  letter-spacing: 0;
  text-transform: none;
  text-align: right;
}

.delivery-item strong {
  color: #fff0c8;
  font-weight: 800;
  letter-spacing: 0;
  line-height: var(--footer-text-line-height);
  text-transform: none;
  text-align: left;
}

.delivery-item:hover {
  border-color: rgba(245, 189, 50, 0.11);
  background: rgba(245, 189, 50, 0.07);
  -webkit-transform: none;
          transform: none;
}

.footer_section .footer-info {
  margin-top: 34px;
  padding-top: 22px;
  border-top: 1px solid rgba(245, 189, 50, 0.13);
  text-align: center;
}

.footer_section .footer-info p,
.footer_section .footer-info p a {
  color: rgba(247, 239, 226, 0.64);
  font-size: 0.86rem;
  font-family: var(--footer-text-font);
  font-weight: var(--footer-copy-weight);
  line-height: var(--footer-copy-line-height);
  letter-spacing: 0;
  text-transform: none;
}

.custom-language-switcher {
  position: fixed;
  left: auto;
  right: 24px;
  bottom: 24px;
  z-index: 999999;
  width: -webkit-max-content;
  width: -moz-max-content;
  width: max-content;
}

.custom_nav-container > .custom-language-switcher,
.user_option .custom-language-switcher {
  position: relative;
  inset: auto;
  z-index: 20;
  -ms-flex-negative: 0;
      flex-shrink: 0;
}

.custom_nav-container > .custom-language-switcher {
  margin-left: auto;
  margin-right: 8px;
}

.user_option .custom-language-switcher {
  margin-left: 2px;
}

.language-btn {
  height: 44px;
  min-width: 86px;
  padding: 0 14px;
  border: 1px solid rgba(245, 189, 50, 0.45);
  border-radius: 999px;
  background: linear-gradient(135deg, rgba(20, 18, 14, 0.92), rgba(38, 34, 26, 0.88));
  color: #f7efe2;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  font-weight: 800;
  letter-spacing: 0.02em;
  cursor: pointer;
  -webkit-box-shadow: 0 12px 30px rgba(0, 0, 0, 0.28), inset 0 1px 0 rgba(255, 255, 255, 0.08);
          box-shadow: 0 12px 30px rgba(0, 0, 0, 0.28), inset 0 1px 0 rgba(255, 255, 255, 0.08);
  -webkit-backdrop-filter: blur(14px);
          backdrop-filter: blur(14px);
  -webkit-transition: border-color 0.2s ease, color 0.2s ease, background-color 0.2s ease, box-shadow 0.2s ease, -webkit-transform 0.2s ease;
  transition: border-color 0.2s ease, color 0.2s ease, background-color 0.2s ease, box-shadow 0.2s ease, -webkit-transform 0.2s ease;
  transition: transform 0.2s ease, box-shadow 0.2s ease, border-color 0.2s ease, color 0.2s ease, background-color 0.2s ease;
  transition: transform 0.2s ease, box-shadow 0.2s ease, border-color 0.2s ease, color 0.2s ease, background-color 0.2s ease, -webkit-transform 0.2s ease;
}

.lang-icon {
  display: -webkit-inline-box;
  display: -ms-inline-flexbox;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 18px;
  height: 18px;
  color: #f5c96b;
  font-size: 0;
}

.lang-icon::before {
  content: "\f0ac";
  font-family: FontAwesome;
  font-size: 14px;
  line-height: 1;
}

.lang-arrow {
  color: rgba(245, 201, 107, 0.82);
  font-size: 11px;
  -webkit-transform: translateY(-1px);
          transform: translateY(-1px);
}

.language-btn:hover,
.language-btn:focus {
  border-color: rgba(245, 189, 50, 0.78);
  color: #fff4d9;
  -webkit-box-shadow: 0 14px 34px rgba(0, 0, 0, 0.34), 0 0 18px rgba(245, 189, 50, 0.13), inset 0 1px 0 rgba(255, 255, 255, 0.1);
          box-shadow: 0 14px 34px rgba(0, 0, 0, 0.34), 0 0 18px rgba(245, 189, 50, 0.13), inset 0 1px 0 rgba(255, 255, 255, 0.1);
  -webkit-transform: translateY(-1px);
          transform: translateY(-1px);
  outline: none;
}

.language-menu {
  position: absolute;
  right: 0;
  left: auto;
  bottom: calc(100% + 10px);
  min-width: 168px;
  padding: 8px;
  border: 1px solid rgba(245, 189, 50, 0.28);
  border-radius: 16px;
  background: rgba(18, 18, 15, 0.96);
  -webkit-box-shadow: 0 18px 45px rgba(0, 0, 0, 0.35), inset 0 1px 0 rgba(255, 255, 255, 0.045);
          box-shadow: 0 18px 45px rgba(0, 0, 0, 0.35), inset 0 1px 0 rgba(255, 255, 255, 0.045);
  -webkit-backdrop-filter: blur(18px);
          backdrop-filter: blur(18px);
  display: block;
  opacity: 0;
  visibility: hidden;
  -webkit-transform: translateY(8px) scale(0.98);
          transform: translateY(8px) scale(0.98);
  -webkit-transform-origin: bottom right;
          transform-origin: bottom right;
  pointer-events: none;
  -webkit-transition: opacity 0.18s ease, visibility 0.18s ease, -webkit-transform 0.18s ease;
  transition: opacity 0.18s ease, visibility 0.18s ease, -webkit-transform 0.18s ease;
  transition: opacity 0.18s ease, transform 0.18s ease, visibility 0.18s ease;
  transition: opacity 0.18s ease, transform 0.18s ease, visibility 0.18s ease, -webkit-transform 0.18s ease;
}

.custom_nav-container .language-menu,
.user_option .language-menu {
  top: calc(100% + 10px);
  bottom: auto;
  -webkit-transform-origin: top right;
          transform-origin: top right;
  -webkit-transform: translateY(-6px) scale(0.98);
          transform: translateY(-6px) scale(0.98);
}

.language-menu.active {
  opacity: 1;
  visibility: visible;
  -webkit-transform: translateY(0) scale(1);
          transform: translateY(0) scale(1);
  pointer-events: auto;
}

.language-menu button {
  position: relative;
  width: 100%;
  min-height: 38px;
  padding: 9px 34px 9px 12px;
  border: none;
  border-radius: 11px;
  background: transparent;
  color: #f0e6d4;
  text-align: left;
  cursor: pointer;
  font-weight: 700;
}

.language-menu button::after {
  content: "";
  position: absolute;
  right: 13px;
  top: 50%;
  width: 7px;
  height: 7px;
  border-radius: 50%;
  background: transparent;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
}

.language-menu button:hover,
.language-menu button:focus {
  background: rgba(245, 189, 50, 0.13);
  color: #ffe09a;
  outline: none;
}

.language-menu button.is-active {
  color: #ffe09a;
  background: rgba(245, 189, 50, 0.09);
}

.language-menu button.is-active::after {
  background: #f5c96b;
  -webkit-box-shadow: 0 0 12px rgba(245, 189, 50, 0.42);
          box-shadow: 0 0 12px rgba(245, 189, 50, 0.42);
}

@media (max-width: 991px) {
  .footer_section {
    padding: 62px 14px 28px;
  }
  .footer_section .container {
    padding: 28px;
    border-radius: 22px;
  }
  .footer_section .row {
    grid-template-columns: 1fr;
    gap: 18px;
  }
  .footer_section .footer-col:not(:nth-child(2)),
  .footer_section .footer_detail {
    padding: 22px;
    border: 1px solid rgba(245, 189, 50, 0.12);
    border-radius: 18px;
    background: rgba(255, 255, 255, 0.028);
  }
  .footer_section .footer_detail {
    max-width: none;
    -webkit-box-ordinal-group: 0;
        -ms-flex-order: -1;
            order: -1;
  }
  .custom_nav-container > .custom-language-switcher {
    margin-left: auto;
    margin-right: 8px;
  }
  .custom_nav-container > .custom-language-switcher .language-btn {
    height: 38px;
    min-width: 74px;
    padding: 0 10px;
  }
}

@media (max-width: 575px) {
  .footer_section {
    padding-inline: 8px;
  }
  .footer_section .container {
    padding: 20px;
    border-radius: 20px;
  }
  .footer_section .footer-logo {
    font-size: 2.25rem;
  }
  .footer_section .footer-col:last-child p,
  .footer_section .footer-col:last-child .delivery-item p {
    grid-template-columns: 1fr;
    gap: 3px;
    text-align: left;
  }
  .language-btn {
    height: 38px;
    min-width: 72px;
    padding: 0 10px;
    gap: 6px;
    font-size: 12px;
  }
  .language-menu {
    min-width: 150px;
  }
}

/* Premium navbar control polish */
html,
body {
  -webkit-transition: background-color 0.28s ease, color 0.28s ease;
  transition: background-color 0.28s ease, color 0.28s ease;
}

.custom_nav-container > .theme_toggle {
  position: relative;
  z-index: 20;
  -ms-flex-negative: 0;
      flex-shrink: 0;
}

.custom_nav-container > .custom-language-switcher,
.custom_nav-container > .theme_toggle,
.user_option .custom-language-switcher,
.user_option .theme_toggle {
  margin-left: 0;
}

.custom-language-switcher {
  font-family: "Open Sans", sans-serif;
}

.language-btn,
.user_option .theme_toggle,
.custom_nav-container > .theme_toggle {
  height: 40px;
  min-height: 40px;
  border: 1px solid rgba(255, 210, 112, 0.34);
  background:
    linear-gradient(135deg, rgba(255, 255, 255, 0.13), rgba(255, 255, 255, 0.045)),
    rgba(18, 16, 13, 0.72);
  color: #fff2d2;
  -webkit-box-shadow: 0 12px 28px rgba(0, 0, 0, 0.22), 0 0 0 1px rgba(255, 255, 255, 0.035) inset;
          box-shadow: 0 12px 28px rgba(0, 0, 0, 0.22), 0 0 0 1px rgba(255, 255, 255, 0.035) inset;
  -webkit-backdrop-filter: blur(16px) saturate(140%);
          backdrop-filter: blur(16px) saturate(140%);
  -webkit-transition: border-color 0.22s ease, color 0.22s ease, background-color 0.22s ease, box-shadow 0.22s ease, -webkit-transform 0.22s ease;
  transition: border-color 0.22s ease, color 0.22s ease, background-color 0.22s ease, box-shadow 0.22s ease, -webkit-transform 0.22s ease;
  transition: transform 0.22s ease, border-color 0.22s ease, color 0.22s ease, background-color 0.22s ease, box-shadow 0.22s ease;
  transition: transform 0.22s ease, border-color 0.22s ease, color 0.22s ease, background-color 0.22s ease, box-shadow 0.22s ease, -webkit-transform 0.22s ease;
}

.language-btn {
  min-width: 104px;
  padding: 0 12px;
  gap: 7px;
  font-size: 11px;
  line-height: 1;
  letter-spacing: 0.05em;
  text-transform: uppercase;
}

.lang-icon {
  width: 17px;
  height: 17px;
}

.lang-icon::before {
  content: "\f1ab";
  color: #ffd26a;
  font-size: 14px;
}

.lang-code {
  color: rgba(255, 244, 218, 0.58);
  font-size: 11px;
  font-weight: 900;
}

.lang-code.is-current {
  color: #ffd26a;
  text-shadow: 0 0 16px rgba(255, 190, 51, 0.28);
}

.lang-divider {
  color: rgba(255, 210, 112, 0.44);
  font-size: 10px;
  font-weight: 800;
}

.lang-arrow {
  color: rgba(255, 210, 112, 0.72);
  font-size: 10px;
}

.language-btn:hover,
.language-btn:focus,
.user_option .theme_toggle:hover,
.user_option .theme_toggle:focus,
.custom_nav-container > .theme_toggle:hover,
.custom_nav-container > .theme_toggle:focus {
  color: #fff9ea;
  border-color: rgba(255, 210, 112, 0.72);
  background:
    linear-gradient(135deg, rgba(255, 210, 112, 0.18), rgba(255, 255, 255, 0.055)),
    rgba(22, 18, 13, 0.82);
  -webkit-box-shadow: 0 14px 34px rgba(0, 0, 0, 0.28), 0 0 22px rgba(255, 190, 51, 0.16), 0 0 0 1px rgba(255, 255, 255, 0.055) inset;
          box-shadow: 0 14px 34px rgba(0, 0, 0, 0.28), 0 0 22px rgba(255, 190, 51, 0.16), 0 0 0 1px rgba(255, 255, 255, 0.055) inset;
  -webkit-transform: translateY(-1px);
          transform: translateY(-1px);
  outline: none;
}

.user_option .theme_toggle,
.custom_nav-container > .theme_toggle {
  width: 40px;
  min-width: 40px;
  padding: 0;
  border-radius: 14px;
}

.theme_toggle_icon {
  color: #ffd26a;
  font-size: 0;
  line-height: 1;
  text-shadow: 0 0 16px rgba(255, 190, 51, 0.28);
  -webkit-transition: color 0.22s ease, -webkit-transform 0.22s ease;
  transition: color 0.22s ease, -webkit-transform 0.22s ease;
  transition: transform 0.22s ease, color 0.22s ease;
  transition: transform 0.22s ease, color 0.22s ease, -webkit-transform 0.22s ease;
}

.theme_toggle_icon::before {
  content: "\f185";
  font-family: FontAwesome;
  font-size: 15px;
}

.theme_toggle_icon.fa-moon::before {
  content: "\f186";
}

.theme_toggle:hover .theme_toggle_icon,
.theme_toggle:focus .theme_toggle_icon {
  -webkit-transform: rotate(12deg) scale(1.05);
          transform: rotate(12deg) scale(1.05);
}

@media (max-width: 991px) {
  .header_section .container {
    width: min(100% - 18px, 1320px);
    padding: 7px 8px 7px 10px;
    border-radius: 18px;
  }

  .custom_nav-container {
    gap: 7px;
    min-height: 46px;
    -ms-flex-wrap: nowrap;
        flex-wrap: nowrap;
  }

  .navbar-brand {
    min-width: 0;
    margin-right: auto;
    gap: 8px;
  }

  .navbar-brand img {
    width: 42px;
    height: 42px;
    border-radius: 13px;
  }

  .navbar-brand span {
    font-size: 25px;
    white-space: nowrap;
  }

  .custom_nav-container > .custom-language-switcher {
    margin-left: 6px;
    margin-right: 0;
  }

  .custom_nav-container > .theme_toggle {
    margin-left: 0;
    margin-right: 0;
  }

  .custom_nav-container > .custom-language-switcher .language-btn,
  .custom_nav-container > .theme_toggle,
  .custom_nav-container .navbar-toggler {
    height: 38px;
    min-height: 38px;
  }

  .custom_nav-container > .custom-language-switcher .language-btn {
    min-width: 78px;
    padding: 0 8px;
    gap: 5px;
    font-size: 10px;
    border-color: rgba(255, 196, 72, 0.16);
    background: rgba(255, 255, 255, 0.06);
    -webkit-box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.04);
            box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.04);
  }

  .custom_nav-container > .theme_toggle,
  .custom_nav-container .navbar-toggler {
    width: 38px;
    min-width: 38px;
    border-radius: 13px;
  }

  .custom_nav-container .navbar-collapse {
    margin-top: 10px;
  }
}

@media (max-width: 420px) {
  .header_section .container {
    width: min(100% - 12px, 1320px);
    padding-inline: 7px;
  }

  .custom_nav-container {
    gap: 5px;
  }

  .navbar-brand {
    gap: 6px;
  }

  .navbar-brand img {
    width: 38px;
    height: 38px;
    padding: 4px;
  }

  .navbar-brand span {
    font-size: 21px;
  }

  .custom_nav-container > .custom-language-switcher .language-btn {
    min-width: 70px;
    padding: 0 7px;
    gap: 5px;
  }

  .lang-icon {
    width: 14px;
  }

  .lang-icon::before,
  .theme_toggle_icon::before {
    font-size: 13px;
  }
}

@media (max-width: 360px) {
  .navbar-brand span {
    font-size: 0;
    width: 0;
    overflow: hidden;
  }

  .custom_nav-container > .custom-language-switcher .language-btn {
    min-width: 78px;
  }
}

/* Premium mobile hamburger drawer */
@media (max-width: 991px) {
  body.mobile_menu_open {
    overflow: hidden;
  }

  body.mobile_menu_open::before {
    content: "";
    position: fixed;
    inset: 0;
    z-index: 80;
    background:
      radial-gradient(circle at 50% 0%, rgba(242, 199, 107, 0.12), transparent 34%),
      rgba(5, 5, 5, 0.68);
    -webkit-backdrop-filter: blur(6px);
            backdrop-filter: blur(6px);
    -webkit-animation: mobileMenuBackdropIn 0.22s ease both;
            animation: mobileMenuBackdropIn 0.22s ease both;
  }

  .custom_nav-container .navbar-toggler {
    position: relative;
    z-index: 90;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 0;
    overflow: hidden;
  }

  .custom_nav-container .navbar-toggler span {
    width: 19px;
    height: 2px;
    margin: 0;
    background-color: #fff4da;
    border-radius: 999px;
    transform-origin: center;
  }

  .custom_nav-container .navbar-toggler span::before,
  .custom_nav-container .navbar-toggler span::after {
    left: 0;
    height: 2px;
    background-color: #fff4da;
    border-radius: 999px;
    transform-origin: center;
  }

  .custom_nav-container .navbar-toggler span::before {
    top: -7px;
  }

  .custom_nav-container .navbar-toggler span::after {
    top: 7px;
  }

  .custom_nav-container .navbar-toggler[aria-expanded="true"] {
    border-color: rgba(255, 196, 72, 0.24);
    background: rgba(255, 255, 255, 0.08);
    box-shadow: 0 6px 16px rgba(0, 0, 0, 0.12), inset 0 1px 0 rgba(255, 255, 255, 0.05);
    -webkit-transform: none;
            transform: none;
  }

  .custom_nav-container .navbar-toggler[aria-expanded="true"] span {
    -webkit-transform: rotate(45deg);
            transform: rotate(45deg);
  }

  .custom_nav-container .navbar-toggler[aria-expanded="true"] span::before,
  .custom_nav-container .navbar-toggler[aria-expanded="true"] span::after {
    top: 0;
    -webkit-transform: rotate(90deg);
            transform: rotate(90deg);
  }

  .custom_nav-container .navbar-collapse {
    position: fixed;
    top: calc(var(--site-header-height) + 10px);
    left: 14px;
    right: 14px;
    z-index: 85;
    width: auto;
    max-height: calc(100vh - var(--site-header-height) - 30px);
    margin: 0;
    padding: 18px;
    border: 1px solid rgba(245, 189, 50, 0.24);
    border-radius: 24px;
    background:
      radial-gradient(circle at top right, rgba(245, 189, 50, 0.15), transparent 36%),
      radial-gradient(circle at bottom left, rgba(255, 255, 255, 0.055), transparent 34%),
      rgba(19, 17, 14, 0.93);
    -webkit-box-shadow: 0 24px 60px rgba(0, 0, 0, 0.45), inset 0 1px 0 rgba(255, 255, 255, 0.06);
            box-shadow: 0 24px 60px rgba(0, 0, 0, 0.45), inset 0 1px 0 rgba(255, 255, 255, 0.06);
    -webkit-backdrop-filter: blur(22px) saturate(142%);
            backdrop-filter: blur(22px) saturate(142%);
    overflow-x: hidden;
    overflow-y: auto;
    -webkit-transform: translateY(-10px) scale(0.98);
            transform: translateY(-10px) scale(0.98);
    opacity: 0;
    will-change: opacity, transform;
  }

  .custom_nav-container .navbar-collapse.collapsing {
    display: block;
    height: auto !important;
    min-height: 0;
    opacity: 0;
    -webkit-transform: translateY(-10px) scale(0.98);
            transform: translateY(-10px) scale(0.98);
    -webkit-transition: opacity 0.24s ease, -webkit-transform 0.24s ease;
    transition: opacity 0.24s ease, -webkit-transform 0.24s ease;
    transition: opacity 0.24s ease, transform 0.24s ease;
    transition: opacity 0.24s ease, transform 0.24s ease, -webkit-transform 0.24s ease;
  }

  body.mobile_menu_open .custom_nav-container .navbar-collapse.collapsing {
    opacity: 1;
    -webkit-transform: translateY(0) scale(1);
            transform: translateY(0) scale(1);
  }

  .custom_nav-container .navbar-collapse:not(.show) {
    display: none;
  }

  .custom_nav-container .navbar-collapse.show {
    display: block;
    opacity: 1;
    -webkit-transform: translateY(0) scale(1);
            transform: translateY(0) scale(1);
    -webkit-animation: mobileMenuPanelIn 0.24s cubic-bezier(0.2, 0.8, 0.2, 1) both;
            animation: mobileMenuPanelIn 0.24s cubic-bezier(0.2, 0.8, 0.2, 1) both;
  }

  .custom_nav-container .navbar-nav {
    width: 100%;
    margin: 0;
    padding: 0;
    gap: 10px;
    align-items: stretch;
  }

  .custom_nav-container .navbar-nav .nav-item {
    width: 100%;
  }

  .custom_nav-container .navbar-nav .nav-item .nav-link {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 100%;
    min-height: 48px;
    margin: 0;
    padding: 0 18px;
    border: 1px solid rgba(255, 255, 255, 0.085);
    border-radius: 999px;
    background: rgba(255, 255, 255, 0.048);
    color: #f7efe2;
    font-size: 12px;
    font-weight: 900;
    letter-spacing: 0.04em;
    line-height: 1;
    text-align: center;
    text-shadow: none;
    text-transform: uppercase;
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.035);
  }

  .custom_nav-container .navbar-nav .nav-item .nav-link:hover,
  .custom_nav-container .navbar-nav .nav-item .nav-link:focus {
    border-color: rgba(245, 189, 50, 0.45);
    background: rgba(245, 189, 50, 0.12);
    color: #f6c453;
    outline: none;
    -webkit-transform: translateY(-1px);
            transform: translateY(-1px);
  }

  .custom_nav-container .navbar-nav .nav-item.active .nav-link,
  .custom_nav-container .navbar-nav .nav-item .nav-link[aria-current="page"] {
    border-color: rgba(245, 189, 50, 0.58);
    background: linear-gradient(135deg, rgba(246, 196, 83, 0.32), rgba(155, 109, 24, 0.32));
    color: #ffd66f;
    box-shadow: 0 12px 26px rgba(245, 189, 50, 0.1), inset 0 1px 0 rgba(255, 255, 255, 0.12);
  }

  .custom_nav-container .navbar-collapse .user_option {
    width: 100%;
    display: flex;
    justify-content: center;
    align-items: center;
    flex-wrap: nowrap;
    gap: 14px;
    margin: 16px 0 0;
    padding-top: 16px;
    border-top: 1px solid rgba(245, 189, 50, 0.18);
  }

  .custom_nav-container .navbar-collapse .user_option .auth_shell,
  .custom_nav-container .navbar-collapse .user_option .offers_nav_btn,
  .custom_nav-container .navbar-collapse .user_option .site_search_toggle_form,
  .custom_nav-container .navbar-collapse .user_option form {
    margin: 0;
  }

  .custom_nav-container .navbar-collapse .user_option .auth_button,
  .custom_nav-container .navbar-collapse .user_option .offers_nav_btn,
  .custom_nav-container .navbar-collapse .user_option .cart_link,
  .custom_nav-container .navbar-collapse .user_option .nav_search-btn {
    width: 38px;
    min-width: 38px;
    max-width: 38px;
    height: 38px;
    min-height: 38px;
    padding: 0;
    border: 1px solid rgba(255, 196, 72, 0.16);
    border-radius: 50%;
    background: rgba(255, 255, 255, 0.06);
    color: #f7efe2;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    overflow: visible;
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.04);
  }

  .custom_nav-container .navbar-collapse .user_option .auth_button:hover,
  .custom_nav-container .navbar-collapse .user_option .auth_button:focus,
  .custom_nav-container .navbar-collapse .user_option .offers_nav_btn:hover,
  .custom_nav-container .navbar-collapse .user_option .offers_nav_btn:focus,
  .custom_nav-container .navbar-collapse .user_option .cart_link:hover,
  .custom_nav-container .navbar-collapse .user_option .cart_link:focus,
  .custom_nav-container .navbar-collapse .user_option .nav_search-btn:hover,
  .custom_nav-container .navbar-collapse .user_option .nav_search-btn:focus {
    border-color: rgba(255, 196, 72, 0.28);
    background: rgba(255, 196, 72, 0.1);
    color: #f6c453;
    -webkit-transform: translateY(-2px);
            transform: translateY(-2px);
    outline: none;
  }

  .custom_nav-container .navbar-collapse .auth_button_text,
  .custom_nav-container .navbar-collapse .auth_chevron,
  .custom_nav-container .navbar-collapse .offers_nav_label,
  .custom_nav-container .navbar-collapse .user_option .order_online,
  .custom_nav-container .navbar-collapse .custom-language-switcher,
  .custom_nav-container .navbar-collapse .theme_toggle {
    display: none !important;
  }

  .custom_nav-container .navbar-collapse .auth_avatar {
    position: relative;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 100%;
    min-width: 0;
    height: 100%;
    border: 0;
    border-radius: 0;
    background: transparent;
    color: currentColor;
    overflow: hidden;
  }

  .custom_nav-container .navbar-collapse .auth_avatar::before {
    content: "\f007";
    font-family: FontAwesome;
    color: currentColor;
    font-size: 17px;
    line-height: 1;
  }

  .custom_nav-container .navbar-collapse .auth_avatar img,
  .custom_nav-container .navbar-collapse .auth_avatar i {
    display: none !important;
  }

  .custom_nav-container .navbar-collapse .user_option .nav_search-btn i {
    color: currentColor;
    font-size: 17px;
    line-height: 1;
  }

  .custom_nav-container .navbar-collapse .user_option .offers_nav_btn i {
    color: currentColor;
    font-size: 16px;
    line-height: 1;
  }

  .custom_nav-container .navbar-collapse .user_option .cart_link svg {
    width: 17px;
    height: 17px;
    fill: currentColor;
  }

  .custom_nav-container .navbar-collapse .cart_count_badge {
    top: -8px;
    right: -8px;
    z-index: 20;
  }

  .custom_nav-container .navbar-collapse .offers_nav_badge {
    top: -5px;
    right: -5px;
    border-color: rgba(19, 17, 14, 0.96);
  }

  @-webkit-keyframes mobileMenuBackdropIn {
    from {
      opacity: 0;
    }
    to {
      opacity: 1;
    }
  }

  @keyframes mobileMenuBackdropIn {
    from {
      opacity: 0;
    }
    to {
      opacity: 1;
    }
  }

  @-webkit-keyframes mobileMenuPanelIn {
    from {
      opacity: 0;
      -webkit-transform: translateY(-12px) scale(0.98);
              transform: translateY(-12px) scale(0.98);
    }
    to {
      opacity: 1;
      -webkit-transform: translateY(0) scale(1);
              transform: translateY(0) scale(1);
    }
  }

  @keyframes mobileMenuPanelIn {
    from {
      opacity: 0;
      -webkit-transform: translateY(-12px) scale(0.98);
              transform: translateY(-12px) scale(0.98);
    }
    to {
      opacity: 1;
      -webkit-transform: translateY(0) scale(1);
              transform: translateY(0) scale(1);
    }
  }
}

@media (max-width: 420px) {
  .custom_nav-container .navbar-collapse {
    left: 10px;
    right: 10px;
    padding: 15px;
    border-radius: 22px;
  }

  .custom_nav-container .navbar-nav {
    gap: 9px;
  }

  .custom_nav-container .navbar-nav .nav-item .nav-link {
    min-height: 46px;
    font-size: 11px;
  }
}

/* Compact premium mobile footer */
@media (max-width: 768px) {
  .footer_section {
    padding: 28px 8px 16px;
    overflow-x: hidden;
  }

  .footer_section::after {
    background-size: 26px 26px;
    opacity: 0.16;
  }

  .footer_section .container {
    width: 100%;
    max-width: 100%;
    padding: 14px 12px 12px;
    border-radius: 22px;
  }

  .footer_section .row {
    display: grid;
    grid-template-columns: 1fr;
    gap: 9px;
    align-items: start;
  }

  .footer_section .row > [class*=col-] {
    width: 100%;
    max-width: none;
    padding: 0;
  }

  .footer_section .footer-col,
  .footer_section .footer-col:not(:nth-child(2)),
  .footer_section .footer_detail {
    margin: 0;
    padding: 11px;
    border-radius: 16px;
  }

  .footer_section .footer_detail {
    max-width: none;
    border: 1px solid rgba(245, 189, 50, 0.12);
    background: rgba(255, 255, 255, 0.028);
  }

  .footer_section h4 {
    gap: 8px;
    margin-bottom: 8px;
    font-size: 0.72rem;
    letter-spacing: 0.08em;
    line-height: 1.2;
  }

  .footer_section h4::after {
    max-width: 42px;
  }

  .footer_section p,
  .footer_section .footer_detail p {
    font-size: 0.82rem;
    line-height: 1.45;
  }

  .footer_section .footer_contact .contact_link_box {
    gap: 6px;
  }

  .footer_section .footer_contact .contact_link_box a {
    min-height: 38px;
    gap: 8px;
    padding: 6px 8px;
    border-radius: 12px;
    font-size: 0.8rem;
  }

  .footer_section .footer_contact .contact_link_box a i,
  .delivery-item .footer-icon {
    width: 26px;
    min-width: 26px;
    height: 26px;
    font-size: 10px;
  }

  .footer_section .footer-logo {
    gap: 7px;
    margin-bottom: 7px;
    font-size: 1.85rem;
    text-shadow: 0 10px 22px rgba(0, 0, 0, 0.3);
  }

  .footer_section .footer-logo::after {
    width: 62px;
    height: 5px;
  }

  .footer_section .footer_social {
    gap: 7px;
    margin-top: 10px;
  }

  .footer_section .footer_social a {
    width: 31px;
    height: 31px;
    font-size: 12px;
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.045);
  }

  .delivery-list.simple-footer-list {
    border-radius: 14px;
  }

  .delivery-item {
    grid-template-columns: 26px minmax(0, 1fr);
    gap: 8px;
    min-height: 36px;
    padding: 7px 8px;
  }

  .footer_section .footer-col:last-child p,
  .footer_section .footer-col:last-child .delivery-item p {
    display: block;
    font-size: 0.78rem;
    line-height: 1.28;
    text-align: left;
  }

  .delivery-item strong {
    display: inline;
  }

  .footer_section .footer-info {
    margin-top: 9px;
    padding-top: 9px;
    padding-right: 50px;
    padding-left: 50px;
  }

  .footer_section .footer-info p,
  .footer_section .footer-info p a {
    font-size: 0.74rem;
    line-height: 1.3;
  }

  .back_to_top_btn {
    right: 14px;
    bottom: 14px;
    width: 46px;
    height: 46px;
    border-radius: 14px;
    box-shadow: 0 10px 22px rgba(0, 0, 0, 0.2), 0 0 12px rgba(255, 190, 51, 0.1);
  }

  .back_to_top_btn i {
    font-size: 16px;
  }

  .back_to_top_btn:hover,
  .back_to_top_btn:focus {
    box-shadow: 0 12px 26px rgba(0, 0, 0, 0.24), 0 0 16px rgba(255, 190, 51, 0.14);
  }
}

@media (max-width: 420px) {
  .footer_section {
    padding-inline: 6px;
  }

  .footer_section .container {
    padding: 12px 9px 10px;
    border-radius: 20px;
  }

  .footer_section .footer-col,
  .footer_section .footer-col:not(:nth-child(2)),
  .footer_section .footer_detail {
    padding: 10px;
  }

  .footer_section .footer_social a {
    width: 30px;
    height: 30px;
  }
}

/* Mobile homepage hero/product teaser composition */
@media (max-width: 768px) {
  .hero_area .bg-box {
    background-image: url("../images/hero-bg.webp");
    background-size: cover;
    background-position: center center;
    background-repeat: no-repeat;
  }

  .hero_area .bg-box picture,
  .hero_area .bg-box > img {
    display: none;
  }

  body:not(.sub_page) .hero_area {
    min-height: calc(100svh - 34px);
    height: calc(100svh - 34px);
    padding-top: calc(var(--site-header-height) + 8px);
    padding-bottom: 14px;
    overflow: hidden;
  }

  body:not(.sub_page) .slider_section {
    min-height: 0;
    flex: 1 1 auto;
    align-items: center;
    padding: 8px 0 48px;
  }

  body:not(.sub_page) .slider_section #customCarousel1,
  body:not(.sub_page) .slider_section .carousel-inner,
  body:not(.sub_page) .slider_section .carousel-item,
  body:not(.sub_page) .slider_section .carousel-item .container,
  body:not(.sub_page) .slider_section .carousel-item .row {
    min-height: 0;
  }

  body:not(.sub_page) .slider_section .detail-box {
    max-width: min(100%, 430px);
    min-height: 0;
    margin: 0 auto 12px;
    padding: 16px;
    border-radius: 18px;
  }

  body:not(.sub_page) .slider_section .detail-box h1 {
    font-size: clamp(1.82rem, 8vw, 2.22rem);
    line-height: 1.12;
    margin-bottom: 10px;
  }

  body:not(.sub_page) .slider_section .detail-box p {
    font-size: 0.9rem;
    line-height: 1.52;
    margin-bottom: 10px;
  }

  body:not(.sub_page) .slider_section .detail-box a {
    margin-top: 2px;
    padding: 9px 28px;
  }

  body:not(.sub_page) .slider_section .carousel-indicators {
    justify-content: center;
    margin-top: 4px;
    margin-bottom: 0;
  }

  body:not(.sub_page) .slider_section .carousel-indicators li {
    width: 9px;
    height: 9px;
  }

  body:not(.sub_page) .slider_section .carousel-indicators li.active {
    width: 17px;
    height: 17px;
  }

  body:not(.sub_page) #products.food_section {
    position: relative;
    z-index: 3;
    margin-top: -86px;
    padding-top: 42px;
    border-radius: 28px 28px 0 0;
    background: linear-gradient(180deg, rgba(255, 255, 255, 0.97), #ffffff 130px);
    box-shadow: 0 -18px 42px rgba(19, 17, 14, 0.16), inset 0 1px 0 rgba(255, 255, 255, 0.72);
    scroll-margin-top: calc(var(--site-header-height) + 18px);
  }

  body.theme_dark:not(.sub_page) #products.food_section,
  html[data-theme="dark"] body:not(.sub_page) #products.food_section {
    background: linear-gradient(180deg, rgba(22, 18, 13, 0.97), rgba(17, 16, 14, 1) 130px);
    box-shadow: 0 -18px 42px rgba(0, 0, 0, 0.32), inset 0 1px 0 rgba(255, 255, 255, 0.06);
  }

  body:not(.sub_page) #products .heading_container.heading_center {
    padding-top: 0;
    margin-bottom: 0;
  }

  body:not(.sub_page) #products .heading_container h2 {
    margin-top: 0;
    margin-bottom: 0;
    font-size: clamp(2.1rem, 10vw, 2.55rem);
  }

  body:not(.sub_page) #products .products_heading_subtitle {
    margin-top: 8px;
    font-size: 0.9rem;
    line-height: 1.45;
  }

  body:not(.sub_page) #products .filters_menu {
    margin-top: 28px;
  }
}

@media (max-width: 380px) {
  body:not(.sub_page) .slider_section .detail-box {
    padding: 14px;
  }

  body:not(.sub_page) .slider_section .detail-box h1 {
    font-size: 1.74rem;
  }

  body:not(.sub_page) .slider_section .detail-box p {
    font-size: 0.84rem;
    line-height: 1.45;
  }

  body:not(.sub_page) #products.food_section {
    margin-top: -78px;
    padding-top: 38px;
  }
}

/* Original navbar theme switch - premium sun/moon redesign */
.user_option .theme_toggle,
.custom_nav-container > .theme_toggle {
  position: relative;
  isolation: isolate;
  overflow: hidden;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 40px;
  min-width: 40px;
  height: 40px;
  min-height: 40px;
  padding: 0;
  margin: 0;
  border: 1px solid rgba(255, 210, 112, 0.44);
  border-radius: 14px;
  background:
    linear-gradient(145deg, rgba(255, 255, 255, 0.18), rgba(255, 255, 255, 0.045)),
    rgba(20, 17, 13, 0.74);
  color: #ffd46c;
  box-shadow: 0 12px 30px rgba(0, 0, 0, 0.24), 0 0 0 1px rgba(255, 255, 255, 0.045) inset;
  -webkit-backdrop-filter: blur(16px) saturate(150%);
          backdrop-filter: blur(16px) saturate(150%);
  cursor: pointer;
  outline: none;
  transition: transform 0.24s ease, border-color 0.24s ease, box-shadow 0.24s ease, background-color 0.24s ease;
}

.user_option .theme_toggle::before,
.custom_nav-container > .theme_toggle::before {
  content: "";
  position: absolute;
  inset: 4px;
  z-index: -1;
  border-radius: 11px;
  background:
    radial-gradient(circle at 34% 28%, rgba(255, 233, 171, 0.35), transparent 38%),
    linear-gradient(145deg, rgba(255, 190, 51, 0.12), rgba(255, 255, 255, 0.035));
  opacity: 0.82;
  transition: opacity 0.24s ease, transform 0.24s ease;
}

.user_option .theme_toggle:hover,
.user_option .theme_toggle:focus,
.custom_nav-container > .theme_toggle:hover,
.custom_nav-container > .theme_toggle:focus {
  border-color: rgba(255, 219, 139, 0.78);
  background:
    linear-gradient(145deg, rgba(255, 233, 171, 0.2), rgba(255, 255, 255, 0.055)),
    rgba(24, 19, 14, 0.84);
  box-shadow: 0 14px 34px rgba(0, 0, 0, 0.28), 0 0 24px rgba(255, 190, 51, 0.18), 0 0 0 1px rgba(255, 255, 255, 0.06) inset;
  transform: translateY(-1px);
}

.user_option .theme_toggle:hover::before,
.user_option .theme_toggle:focus::before,
.custom_nav-container > .theme_toggle:hover::before,
.custom_nav-container > .theme_toggle:focus::before {
  opacity: 1;
  transform: scale(1.04);
}

.theme_toggle_orbit {
  position: relative;
  z-index: 1;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 26px;
  height: 26px;
}

.theme_toggle_halo {
  position: absolute;
  inset: 2px;
  border-radius: 50%;
  background:
    radial-gradient(circle at 38% 32%, rgba(255, 255, 238, 0.78), rgba(255, 204, 92, 0.58) 34%, rgba(255, 190, 51, 0.12) 62%, transparent 72%);
  box-shadow: 0 0 18px rgba(255, 190, 51, 0.3);
  animation: themeToggleBreath 3.4s ease-in-out infinite;
  transition: background 0.28s ease, box-shadow 0.28s ease, transform 0.28s ease;
}

.theme_toggle_icon {
  position: relative;
  z-index: 2;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 18px;
  height: 18px;
  color: #22170a;
  font-size: 0;
  line-height: 1;
  filter: drop-shadow(0 0 8px rgba(255, 220, 142, 0.45));
  text-shadow: none;
  transition: color 0.28s ease, filter 0.28s ease, transform 0.28s ease;
}

.theme_toggle_icon::before {
  font-family: FontAwesome;
  font-size: 15px;
  line-height: 1;
}

.theme_toggle_icon.fa-sun::before {
  content: "\f185";
}

.theme_toggle_icon.fa-moon::before {
  content: "\f186";
}

.theme_toggle_spark {
  position: absolute;
  z-index: 3;
  width: 3px;
  height: 3px;
  border-radius: 50%;
  background: #fff1bd;
  box-shadow: 0 0 9px rgba(255, 232, 172, 0.68);
  transition: opacity 0.28s ease, transform 0.28s ease;
}

.theme_toggle_spark_one {
  top: 3px;
  right: 4px;
}

.theme_toggle_spark_two {
  bottom: 4px;
  left: 3px;
  opacity: 0.66;
}

.theme_toggle[aria-pressed="true"] .theme_toggle_halo {
  background:
    radial-gradient(circle at 63% 31%, rgba(20, 17, 13, 0.96) 0 26%, transparent 27%),
    radial-gradient(circle at 42% 42%, rgba(255, 235, 179, 0.84), rgba(230, 179, 79, 0.5) 45%, rgba(255, 190, 51, 0.1) 68%, transparent 76%);
  box-shadow: 0 0 16px rgba(255, 219, 139, 0.26), 0 0 28px rgba(129, 167, 255, 0.1);
  transform: rotate(-16deg) scale(0.96);
}

.theme_toggle[aria-pressed="true"] .theme_toggle_icon {
  color: #ffe8a8;
  filter: drop-shadow(0 0 9px rgba(255, 223, 154, 0.44));
  transform: rotate(-14deg) translateY(1px);
}

.theme_toggle[aria-pressed="true"] .theme_toggle_spark_one {
  transform: translate(-15px, 15px) scale(0.72);
  opacity: 0.42;
}

.theme_toggle[aria-pressed="true"] .theme_toggle_spark_two {
  transform: translate(14px, -12px) scale(1.18);
  opacity: 0.95;
}

.theme_toggle:hover .theme_toggle_icon,
.theme_toggle:focus .theme_toggle_icon {
  transform: rotate(12deg) scale(1.06);
}

.theme_toggle[aria-pressed="true"]:hover .theme_toggle_icon,
.theme_toggle[aria-pressed="true"]:focus .theme_toggle_icon {
  transform: rotate(-4deg) translateY(1px) scale(1.06);
}

@keyframes themeToggleBreath {
  0%,
  100% {
    opacity: 0.82;
    transform: scale(1);
  }

  50% {
    opacity: 1;
    transform: scale(1.06);
  }
}

@media (prefers-reduced-motion: reduce) {
  .user_option .theme_toggle,
  .custom_nav-container > .theme_toggle,
  .user_option .theme_toggle::before,
  .custom_nav-container > .theme_toggle::before,
  .theme_toggle_halo,
  .theme_toggle_icon,
  .theme_toggle_spark {
    animation: none;
    transition: none;
  }
}

/* Dark mode luxury contrast polish */
html[data-theme="dark"] body,
body.theme_dark {
  background:
    linear-gradient(135deg, #181512 0%, #111827 50%, #1b1612 100%);
  color: #f7f0e2;
}

html:not([data-theme="dark"]) .food_section .box.product-card,
body:not(.theme_dark) .food_section .box.product-card,
html:not([data-theme="dark"]) .recommendation_card,
body:not(.theme_dark) .recommendation_card,
html:not([data-theme="dark"]) .wishlist_card,
body:not(.theme_dark) .wishlist_card {
  border: 1.5px solid rgba(180, 125, 25, 0.28);
  box-shadow:
    0 12px 28px rgba(40, 28, 10, 0.1),
    0 0 0 1px rgba(180, 125, 25, 0.08);
  transition: transform 0.25s ease, border-color 0.25s ease, box-shadow 0.25s ease;
}

html:not([data-theme="dark"]) .food_section .box.product-card:hover,
html:not([data-theme="dark"]) .food_section .box.product-card:focus-within,
body:not(.theme_dark) .food_section .box.product-card:hover,
body:not(.theme_dark) .food_section .box.product-card:focus-within,
html:not([data-theme="dark"]) .recommendation_card:hover,
html:not([data-theme="dark"]) .recommendation_card:focus-within,
body:not(.theme_dark) .recommendation_card:hover,
body:not(.theme_dark) .recommendation_card:focus-within,
html:not([data-theme="dark"]) .wishlist_card:hover,
html:not([data-theme="dark"]) .wishlist_card:focus-within,
body:not(.theme_dark) .wishlist_card:hover,
body:not(.theme_dark) .wishlist_card:focus-within {
  border-color: rgba(180, 125, 25, 0.52);
  box-shadow:
    0 16px 36px rgba(40, 28, 10, 0.16),
    0 0 0 1px rgba(180, 125, 25, 0.16);
}

html[data-theme="dark"] .food_section .box.product-card,
body.theme_dark .food_section .box.product-card,
html[data-theme="dark"] .recommendation_card,
body.theme_dark .recommendation_card {
  background:
    linear-gradient(180deg, rgba(36, 29, 23, 0.97), rgba(29, 25, 21, 0.96)),
    #1d1915;
  border: 1.5px solid rgba(245, 192, 78, 0.42);
  box-shadow:
    0 10px 28px rgba(0, 0, 0, 0.38),
    0 0 0 1px rgba(245, 192, 78, 0.12),
    0 0 20px rgba(245, 192, 78, 0.08);
  transition: transform 0.25s ease, border-color 0.25s ease, box-shadow 0.25s ease;
}

html[data-theme="dark"] .food_section .box.product-card:hover,
html[data-theme="dark"] .food_section .box.product-card:focus-within,
body.theme_dark .food_section .box.product-card:hover,
body.theme_dark .food_section .box.product-card:focus-within,
html[data-theme="dark"] .recommendation_card:hover,
html[data-theme="dark"] .recommendation_card:focus-within,
body.theme_dark .recommendation_card:hover,
body.theme_dark .recommendation_card:focus-within {
  border-color: rgba(245, 192, 78, 0.78);
  box-shadow:
    0 14px 34px rgba(0, 0, 0, 0.45),
    0 0 0 1px rgba(245, 192, 78, 0.24),
    0 0 26px rgba(245, 192, 78, 0.16);
}

html[data-theme="dark"] .food_section .box.product-card .img-box,
body.theme_dark .food_section .box.product-card .img-box,
html[data-theme="dark"] .wishlist_card_image,
body.theme_dark .wishlist_card_image,
html[data-theme="dark"] .recommendation_card_image,
body.theme_dark .recommendation_card_image {
  background: #f5f2ea;
}

html[data-theme="dark"] .product-wishlist-btn,
body.theme_dark .product-wishlist-btn,
html[data-theme="dark"] .product-share-btn,
body.theme_dark .product-share-btn {
  background: rgba(255, 255, 255, 0.92);
  border: 1px solid rgba(245, 192, 78, 0.35);
  color: #8a5c09;
  box-shadow:
    0 10px 22px rgba(0, 0, 0, 0.28),
    0 0 16px rgba(245, 192, 78, 0.12);
}

html[data-theme="dark"] .product-wishlist-btn:hover,
html[data-theme="dark"] .product-wishlist-btn:focus,
html[data-theme="dark"] .product-wishlist-btn.is_active,
body.theme_dark .product-wishlist-btn:hover,
body.theme_dark .product-wishlist-btn:focus,
body.theme_dark .product-wishlist-btn.is_active,
html[data-theme="dark"] .product-share-btn:hover,
html[data-theme="dark"] .product-share-btn:focus,
body.theme_dark .product-share-btn:hover,
body.theme_dark .product-share-btn:focus {
  background: rgba(255, 248, 232, 0.98);
  border-color: rgba(245, 192, 78, 0.68);
  color: #f5c04e;
  box-shadow:
    0 12px 26px rgba(0, 0, 0, 0.34),
    0 0 22px rgba(245, 192, 78, 0.24);
  transform: translateY(-1px) scale(1.04);
}

html[data-theme="dark"] .wishlist_nav_link,
body.theme_dark .wishlist_nav_link {
  background: rgba(255, 255, 255, 0.06);
  border: 1px solid rgba(245, 192, 78, 0.35);
  color: #f5c04e !important;
  box-shadow: 0 0 18px rgba(245, 192, 78, 0.08);
}

html[data-theme="dark"] .wishlist_nav_link:hover,
html[data-theme="dark"] .wishlist_nav_link:focus,
body.theme_dark .wishlist_nav_link:hover,
body.theme_dark .wishlist_nav_link:focus,
body.theme_dark .custom_nav-container .navbar-nav .nav-item.active .wishlist_nav_link {
  background: rgba(245, 192, 78, 0.14);
  border-color: rgba(245, 192, 78, 0.6);
  color: #ffe09a !important;
  box-shadow:
    inset 0 0 0 1px rgba(255, 226, 156, 0.12),
    0 0 22px rgba(245, 192, 78, 0.18);
  transform: translateY(-1px);
}

html[data-theme="dark"] .wishlist_count_badge,
body.theme_dark .wishlist_count_badge {
  background: linear-gradient(135deg, #ffe09a, #f5c04e);
  color: #17120b;
  border: 1px solid rgba(255, 244, 218, 0.38);
  box-shadow:
    0 8px 18px rgba(0, 0, 0, 0.24),
    0 0 16px rgba(245, 192, 78, 0.34);
}

html[data-theme="dark"] .wishlist_card,
body.theme_dark .wishlist_card {
  background:
    linear-gradient(180deg, rgba(36, 29, 23, 0.97), rgba(29, 25, 21, 0.96)),
    #1d1915;
  border: 1.5px solid rgba(245, 192, 78, 0.42);
  box-shadow:
    0 10px 28px rgba(0, 0, 0, 0.38),
    0 0 0 1px rgba(245, 192, 78, 0.12),
    0 0 20px rgba(245, 192, 78, 0.08);
}

html[data-theme="dark"] .wishlist_card:hover,
html[data-theme="dark"] .wishlist_card:focus-within,
body.theme_dark .wishlist_card:hover,
body.theme_dark .wishlist_card:focus-within {
  border-color: rgba(245, 192, 78, 0.78);
  box-shadow:
    0 14px 34px rgba(0, 0, 0, 0.45),
    0 0 0 1px rgba(245, 192, 78, 0.24),
    0 0 26px rgba(245, 192, 78, 0.16);
}

html[data-theme="dark"] .wishlist_view_btn,
body.theme_dark .wishlist_view_btn,
html[data-theme="dark"] .wishlist_remove_btn,
body.theme_dark .wishlist_remove_btn {
  background: rgba(255, 255, 255, 0.06);
  border: 1px solid rgba(245, 192, 78, 0.35);
  color: #f5c04e;
  box-shadow: 0 0 16px rgba(245, 192, 78, 0.08);
}

html[data-theme="dark"] .wishlist_view_btn:hover,
html[data-theme="dark"] .wishlist_view_btn:focus,
html[data-theme="dark"] .wishlist_remove_btn:hover,
html[data-theme="dark"] .wishlist_remove_btn:focus,
body.theme_dark .wishlist_view_btn:hover,
body.theme_dark .wishlist_view_btn:focus,
body.theme_dark .wishlist_remove_btn:hover,
body.theme_dark .wishlist_remove_btn:focus {
  background: rgba(245, 192, 78, 0.14);
  border-color: rgba(245, 192, 78, 0.6);
  color: #ffe09a;
  box-shadow: 0 0 22px rgba(245, 192, 78, 0.18);
  transform: translateY(-1px);
}

/* Light mode product card border clarity */
html[data-theme="light"] .product-card,
body.light-mode .product-card,
html[data-theme="light"] .recommendation_card,
body.light-mode .recommendation_card,
html[data-theme="light"] .wishlist_card,
body.light-mode .wishlist_card {
  border: 1.6px solid rgba(180, 125, 25, 0.42) !important;
  box-shadow:
    0 12px 30px rgba(40, 28, 10, 0.12),
    0 0 0 1px rgba(180, 125, 25, 0.1) !important;
}

html[data-theme="light"] .product-card:hover,
html[data-theme="light"] .product-card:focus-within,
body.light-mode .product-card:hover,
body.light-mode .product-card:focus-within,
html[data-theme="light"] .recommendation_card:hover,
html[data-theme="light"] .recommendation_card:focus-within,
body.light-mode .recommendation_card:hover,
body.light-mode .recommendation_card:focus-within,
html[data-theme="light"] .wishlist_card:hover,
html[data-theme="light"] .wishlist_card:focus-within,
body.light-mode .wishlist_card:hover,
body.light-mode .wishlist_card:focus-within {
  border-color: rgba(180, 125, 25, 0.68) !important;
  box-shadow:
    0 16px 38px rgba(40, 28, 10, 0.18),
    0 0 0 1px rgba(180, 125, 25, 0.2),
    0 0 22px rgba(180, 125, 25, 0.1) !important;
}

/* Footer delivery schedule row alignment */
.footer_section .delivery-list.simple-footer-list {
  gap: 0;
}

.footer_section .delivery-list.simple-footer-list .delivery-item {
  display: flex;
  align-items: center;
  gap: 14px;
  min-height: 64px;
  padding: 13px 16px;
  border-bottom: 1px solid rgba(245, 192, 78, 0.12);
}

.footer_section .delivery-list.simple-footer-list .delivery-item:last-child {
  border-bottom: none;
}

.footer_section .delivery-icon {
  width: 34px;
  min-width: 34px;
  height: 34px;
  margin: 0;
  border: 1px solid rgba(245, 192, 78, 0.35);
  border-radius: 50%;
  background: rgba(245, 192, 78, 0.08);
  color: #f5c04e;
  display: flex;
  align-items: center;
  justify-content: center;
  box-shadow: 0 0 16px rgba(245, 192, 78, 0.1);
}

.footer_section .delivery-text {
  display: flex;
  flex-direction: column;
  gap: 3px;
  min-width: 0;
  text-align: left;
}

.footer_section .delivery-text strong {
  color: #f7efe2;
  font-family: var(--footer-text-font);
  font-size: var(--footer-text-size);
  font-weight: 800;
  line-height: var(--footer-text-line-height);
  letter-spacing: 0;
  text-transform: none;
  white-space: normal;
}

.footer_section .delivery-text span {
  color: #cfc3b2;
  font-family: var(--footer-text-font);
  font-size: var(--footer-text-size);
  font-weight: var(--footer-text-weight);
  line-height: var(--footer-text-line-height);
  letter-spacing: 0;
  text-transform: none;
}

.footer_section .footer_policy_links {
  display: grid;
  gap: 8px;
  margin: 18px 0 0;
}

.footer_section .footer_policy_links a {
  display: inline-flex;
  align-items: center;
  width: fit-content;
  max-width: 100%;
  color: #f7d577;
  font-family: var(--footer-text-font);
  font-size: var(--footer-text-size);
  font-weight: var(--footer-text-weight);
  line-height: var(--footer-text-line-height);
  letter-spacing: 0;
  text-transform: none;
  text-decoration: none;
  transition: color 0.2s ease, transform 0.2s ease;
}

.footer_section .footer_policy_links a::before {
  content: "";
  width: 6px;
  height: 6px;
  margin-right: 8px;
  border-radius: 50%;
  background: currentColor;
  opacity: 0.7;
}

.footer_section .footer_policy_links a:hover,
.footer_section .footer_policy_links a:focus {
  color: #ffe6a6;
  transform: translateX(2px);
  outline: none;
}

.policy_page_main {
  background:
    radial-gradient(circle at top left, rgba(212, 160, 23, 0.12), transparent 34%),
    linear-gradient(180deg, #fff9ec 0%, #ffffff 58%, #fff7e6 100%);
  color: #1f2733;
}

.policy_hero_section,
.policy_content_section {
  padding: 42px 0;
}

.policy_hero_card,
.policy_content_card {
  max-width: 920px;
  margin: 0 auto;
  border: 1px solid rgba(180, 125, 25, 0.18);
  border-radius: 22px;
  background: rgba(255, 255, 255, 0.86);
  box-shadow: 0 22px 60px rgba(40, 28, 10, 0.12);
  backdrop-filter: blur(14px);
}

.policy_hero_card {
  padding: 34px;
}

.policy_content_card {
  display: grid;
  gap: 24px;
  padding: 34px;
}

.policy_kicker {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  margin-bottom: 10px;
  color: #b9872c;
  font-size: 12px;
  font-weight: 800;
  letter-spacing: 0.12em;
  text-transform: uppercase;
}

.policy_hero_card h1 {
  margin: 0 0 12px;
  color: #1a1a1a;
  font-size: clamp(2rem, 5vw, 3.35rem);
  font-weight: 800;
  line-height: 1.05;
}

.policy_hero_card p,
.policy_section p,
.policy_section li {
  color: #5f6672;
  font-size: 15px;
  line-height: 1.75;
}

.policy_meta {
  display: inline-flex;
  margin-top: 18px;
  padding: 8px 12px;
  border: 1px solid rgba(180, 125, 25, 0.22);
  border-radius: 999px;
  background: rgba(212, 160, 23, 0.09);
  color: #8a5c09;
  font-size: 13px;
  font-weight: 700;
}

.policy_section {
  padding-bottom: 22px;
  border-bottom: 1px solid rgba(180, 125, 25, 0.14);
}

.policy_section:last-child {
  padding-bottom: 0;
  border-bottom: 0;
}

.policy_section h2 {
  margin: 0 0 10px;
  color: #1a1a1a;
  font-size: 1.25rem;
  font-weight: 800;
}

.policy_section p {
  margin: 0 0 12px;
}

.policy_section ul {
  display: grid;
  gap: 8px;
  margin: 0;
  padding-left: 20px;
}

.policy_notice {
  padding: 16px 18px;
  border: 1px solid rgba(180, 125, 25, 0.24);
  border-radius: 16px;
  background: rgba(212, 160, 23, 0.1);
}

.policy_notice strong {
  color: #7a5200;
}

html[data-theme="dark"] .policy_page_main,
body.theme_dark .policy_page_main,
body.dark-mode .policy_page_main {
  background:
    radial-gradient(circle at top left, rgba(242, 199, 107, 0.12), transparent 34%),
    linear-gradient(180deg, #101010 0%, #17120c 100%);
  color: #f7f0e2;
}

html[data-theme="dark"] .policy_hero_card,
html[data-theme="dark"] .policy_content_card,
body.theme_dark .policy_hero_card,
body.theme_dark .policy_content_card,
body.dark-mode .policy_hero_card,
body.dark-mode .policy_content_card {
  border-color: rgba(242, 199, 107, 0.18);
  background: rgba(31, 26, 20, 0.88);
  box-shadow: 0 22px 60px rgba(0, 0, 0, 0.28);
}

html[data-theme="dark"] .policy_hero_card h1,
html[data-theme="dark"] .policy_section h2,
body.theme_dark .policy_hero_card h1,
body.theme_dark .policy_section h2,
body.dark-mode .policy_hero_card h1,
body.dark-mode .policy_section h2 {
  color: #fff8e8;
}

html[data-theme="dark"] .policy_hero_card p,
html[data-theme="dark"] .policy_section p,
html[data-theme="dark"] .policy_section li,
body.theme_dark .policy_hero_card p,
body.theme_dark .policy_section p,
body.theme_dark .policy_section li,
body.dark-mode .policy_hero_card p,
body.dark-mode .policy_section p,
body.dark-mode .policy_section li {
  color: rgba(255, 248, 232, 0.74);
}

html[data-theme="light"] .footer_section .footer_policy_links a,
body.light-mode .footer_section .footer_policy_links a {
  color: #8a5c09 !important;
}

html[data-theme="light"] .footer_section .footer_policy_links a:hover,
html[data-theme="light"] .footer_section .footer_policy_links a:focus,
body.light-mode .footer_section .footer_policy_links a:hover,
body.light-mode .footer_section .footer_policy_links a:focus {
  color: #5f3f03 !important;
}

@media (min-width: 992px) {
  .footer_section .delivery-text strong {
    white-space: nowrap;
  }
}

/* Light mode premium footer palette */
html[data-theme="light"] .footer_section,
body.light-mode .footer_section,
html[data-theme="light"] .footer,
body.light-mode .footer,
html[data-theme="light"] .site-footer,
body.light-mode .site-footer {
  background:
    radial-gradient(circle at top left, rgba(214, 168, 63, 0.16), transparent 34%),
    radial-gradient(circle at 88% 18%, rgba(214, 168, 63, 0.08), transparent 28%),
    linear-gradient(135deg, #ffffff 0%, #f8f4ec 100%) !important;
  border-top-color: rgba(180, 125, 25, 0.2) !important;
  color: #241f18 !important;
}

html[data-theme="light"] .footer_section::before,
body.light-mode .footer_section::before {
  background: linear-gradient(90deg, transparent, rgba(180, 125, 25, 0.42), transparent) !important;
}

html[data-theme="light"] .footer_section::after,
body.light-mode .footer_section::after {
  opacity: 0.16 !important;
  background-image:
    linear-gradient(rgba(180, 125, 25, 0.055) 1px, transparent 1px),
    linear-gradient(90deg, rgba(180, 125, 25, 0.04) 1px, transparent 1px) !important;
}

html[data-theme="light"] .footer_section .container,
body.light-mode .footer_section .container,
html[data-theme="light"] .footer-inner,
body.light-mode .footer-inner,
html[data-theme="light"] .footer-card,
body.light-mode .footer-card {
  background: rgba(255, 255, 255, 0.78) !important;
  border-color: rgba(180, 125, 25, 0.24) !important;
  -webkit-box-shadow:
    0 24px 60px rgba(40, 28, 10, 0.12),
    inset 0 1px 0 rgba(255, 255, 255, 0.75) !important;
          box-shadow:
    0 24px 60px rgba(40, 28, 10, 0.12),
    inset 0 1px 0 rgba(255, 255, 255, 0.75) !important;
  -webkit-backdrop-filter: blur(16px);
          backdrop-filter: blur(16px);
}

html[data-theme="light"] .footer_section .footer-col:not(:nth-child(2)),
body.light-mode .footer_section .footer-col:not(:nth-child(2)),
html[data-theme="light"] .footer_section .footer_detail,
body.light-mode .footer_section .footer_detail {
  background: rgba(255, 255, 255, 0.62) !important;
  border-color: rgba(180, 125, 25, 0.18) !important;
  -webkit-box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.72) !important;
          box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.72) !important;
}

html[data-theme="light"] .footer_section h2,
html[data-theme="light"] .footer_section h3,
html[data-theme="light"] .footer_section h4,
html[data-theme="light"] .footer-title,
body.light-mode .footer_section h2,
body.light-mode .footer_section h3,
body.light-mode .footer_section h4,
body.light-mode .footer-title {
  color: #9b6d18 !important;
}

html[data-theme="light"] .footer_section h4::after,
body.light-mode .footer_section h4::after {
  background: linear-gradient(90deg, rgba(180, 125, 25, 0.48), transparent) !important;
}

html[data-theme="light"] .footer_section .footer-logo::after,
body.light-mode .footer_section .footer-logo::after {
  border-color: rgba(180, 125, 25, 0.36) !important;
  background: radial-gradient(circle, rgba(180, 125, 25, 0.72) 0 2px, transparent 3px) !important;
}

html[data-theme="light"] .footer_section p,
html[data-theme="light"] .footer_section span,
html[data-theme="light"] .footer_section a,
body.light-mode .footer_section p,
body.light-mode .footer_section span,
body.light-mode .footer_section a {
  color: #3a3126 !important;
}

html[data-theme="light"] .footer_section .footer_detail p,
html[data-theme="light"] .footer_section .footer-info p,
html[data-theme="light"] .footer_section .footer-info p a,
html[data-theme="light"] .footer_section .delivery-text span,
html[data-theme="light"] .footer_section .muted,
html[data-theme="light"] .footer-description,
body.light-mode .footer_section .footer_detail p,
body.light-mode .footer_section .footer-info p,
body.light-mode .footer_section .footer-info p a,
body.light-mode .footer_section .delivery-text span,
body.light-mode .footer_section .muted,
body.light-mode .footer-description {
  color: #6d6254 !important;
}

html[data-theme="light"] .footer_section .footer-logo,
body.light-mode .footer_section .footer-logo {
  color: #241f18 !important;
  text-shadow: 0 12px 28px rgba(40, 28, 10, 0.12) !important;
}

html[data-theme="light"] .footer_section .footer-logo:hover,
html[data-theme="light"] .footer_section .footer-logo:focus,
body.light-mode .footer_section .footer-logo:hover,
body.light-mode .footer_section .footer-logo:focus {
  color: #9b6d18 !important;
}

html[data-theme="light"] .footer_section .footer_contact .contact_link_box a,
html[data-theme="light"] .footer_section .delivery-list.simple-footer-list,
html[data-theme="light"] .footer_section .footer-info-item,
html[data-theme="light"] .footer_section .delivery-item,
body.light-mode .footer_section .footer_contact .contact_link_box a,
body.light-mode .footer_section .delivery-list.simple-footer-list,
body.light-mode .footer_section .footer-info-item,
body.light-mode .footer_section .delivery-item {
  background: rgba(255, 255, 255, 0.7) !important;
  border-color: rgba(180, 125, 25, 0.22) !important;
  -webkit-box-shadow: 0 10px 24px rgba(40, 28, 10, 0.08) !important;
          box-shadow: 0 10px 24px rgba(40, 28, 10, 0.08) !important;
}

html[data-theme="light"] .footer_section .delivery-list.simple-footer-list .delivery-item,
body.light-mode .footer_section .delivery-list.simple-footer-list .delivery-item {
  border-bottom-color: rgba(180, 125, 25, 0.18) !important;
  -webkit-box-shadow: none !important;
          box-shadow: none !important;
}

html[data-theme="light"] .footer_section .footer_contact .contact_link_box a i,
html[data-theme="light"] .footer_section .footer-icon,
html[data-theme="light"] .footer_section .delivery-icon,
html[data-theme="light"] .footer_section .footer_social a,
html[data-theme="light"] .footer_section .social-icon,
body.light-mode .footer_section .footer_contact .contact_link_box a i,
body.light-mode .footer_section .footer-icon,
body.light-mode .footer_section .delivery-icon,
body.light-mode .footer_section .footer_social a,
body.light-mode .footer_section .social-icon {
  background: rgba(214, 168, 63, 0.12) !important;
  border-color: rgba(180, 125, 25, 0.35) !important;
  color: #9b6d18 !important;
  -webkit-box-shadow: 0 8px 18px rgba(40, 28, 10, 0.08) !important;
          box-shadow: 0 8px 18px rgba(40, 28, 10, 0.08) !important;
}

html[data-theme="light"] .footer_section .footer_contact .contact_link_box a:hover,
html[data-theme="light"] .footer_section .footer_contact .contact_link_box a:focus,
html[data-theme="light"] .footer_section .footer_social a:hover,
html[data-theme="light"] .footer_section .footer_social a:focus,
html[data-theme="light"] .footer_section .delivery-item:hover,
body.light-mode .footer_section .footer_contact .contact_link_box a:hover,
body.light-mode .footer_section .footer_contact .contact_link_box a:focus,
body.light-mode .footer_section .footer_social a:hover,
body.light-mode .footer_section .footer_social a:focus,
body.light-mode .footer_section .delivery-item:hover {
  background: rgba(214, 168, 63, 0.14) !important;
  border-color: rgba(180, 125, 25, 0.34) !important;
  color: #9b6d18 !important;
}

html[data-theme="light"] .footer_section .delivery-text strong,
html[data-theme="light"] .footer_section .delivery-item strong,
body.light-mode .footer_section .delivery-text strong,
body.light-mode .footer_section .delivery-item strong {
  color: #2f271d !important;
}

html[data-theme="light"] .footer_section .footer-info,
html[data-theme="light"] .copyright,
html[data-theme="light"] .footer-copy,
body.light-mode .footer_section .footer-info,
body.light-mode .copyright,
body.light-mode .footer-copy {
  color: #6d6254 !important;
  border-top-color: rgba(180, 125, 25, 0.18) !important;
}

/* Permanent product card borders and premium scroll controls */
.product-card,
.recommendation_card,
.wishlist_card {
  border: 1.6px solid rgba(190, 135, 35, 0.55) !important;
}

.food_section .box.product-card {
  min-height: auto;
}

.food_section .box.product-card > div {
  min-height: auto;
}

.food_section .box.product-card .img-box {
  height: 240px;
}

.food_section .box.product-card .detail-box {
  gap: 9px;
  padding: 18px 18px 16px;
}

.food_section .box.product-card .detail-box h5 {
  min-height: 44px;
}

.food_section .box.product-card .detail-box p {
  min-height: 42px;
  font-size: 14px;
  line-height: 1.5;
  -webkit-line-clamp: 2;
          line-clamp: 2;
}

.food_section .box.product-card .options {
  padding-top: 3px;
}

.product-card:hover,
.product-card:focus-within,
.recommendation_card:hover,
.recommendation_card:focus-within,
.wishlist_card:hover,
.wishlist_card:focus-within {
  border-color: rgba(214, 168, 63, 0.85) !important;
}

body.dark-mode .product-card,
body.theme_dark .product-card,
html[data-theme="dark"] .product-card,
body.dark-mode .recommendation_card,
body.theme_dark .recommendation_card,
html[data-theme="dark"] .recommendation_card,
body.dark-mode .wishlist_card,
body.theme_dark .wishlist_card,
html[data-theme="dark"] .wishlist_card {
  border: 1.6px solid rgba(245, 192, 78, 0.52) !important;
}

body.dark-mode .product-card:hover,
body.dark-mode .product-card:focus-within,
body.theme_dark .product-card:hover,
body.theme_dark .product-card:focus-within,
html[data-theme="dark"] .product-card:hover,
html[data-theme="dark"] .product-card:focus-within,
body.dark-mode .recommendation_card:hover,
body.dark-mode .recommendation_card:focus-within,
body.theme_dark .recommendation_card:hover,
body.theme_dark .recommendation_card:focus-within,
html[data-theme="dark"] .recommendation_card:hover,
html[data-theme="dark"] .recommendation_card:focus-within,
body.dark-mode .wishlist_card:hover,
body.dark-mode .wishlist_card:focus-within,
body.theme_dark .wishlist_card:hover,
body.theme_dark .wishlist_card:focus-within,
html[data-theme="dark"] .wishlist_card:hover,
html[data-theme="dark"] .wishlist_card:focus-within {
  border-color: rgba(245, 192, 78, 0.9) !important;
}

.scroll-to-top,
.scroll-down {
  position: fixed;
  right: 22px !important;
  z-index: 88;
  width: 46px !important;
  min-width: 46px;
  height: 46px !important;
  min-height: 46px;
  padding: 0;
  border: 1px solid rgba(245, 192, 78, 0.55);
  border-radius: 50%;
  background: rgba(20, 18, 14, 0.78);
  color: #f6c453;
  -webkit-backdrop-filter: blur(14px) saturate(140%);
          backdrop-filter: blur(14px) saturate(140%);
  box-shadow:
    0 10px 25px rgba(0, 0, 0, 0.28),
    0 0 18px rgba(245, 192, 78, 0.18);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
  transform: translateY(12px) scale(0.94);
  transition: opacity 0.22s ease, visibility 0.22s ease, transform 0.22s ease, background-color 0.22s ease, border-color 0.22s ease, box-shadow 0.22s ease;
}

.scroll-to-top,
.scroll-down {
  bottom: 22px !important;
}

.scroll-to-top[hidden],
.scroll-down[hidden] {
  display: inline-flex;
}

.scroll-to-top.is_visible,
.scroll-down.is_visible {
  opacity: 1;
  visibility: visible;
  pointer-events: auto;
  transform: translateY(0) scale(1);
}

.scroll-to-top i,
.scroll-down i {
  color: currentColor;
  font-size: 16px;
  line-height: 1;
  filter: drop-shadow(0 0 8px rgba(245, 192, 78, 0.3));
}

.scroll-to-top:hover,
.scroll-to-top:focus,
.scroll-down:hover,
.scroll-down:focus {
  color: #ffe09a;
  background: rgba(245, 192, 78, 0.18);
  border-color: rgba(245, 192, 78, 0.85);
  box-shadow:
    0 14px 30px rgba(0, 0, 0, 0.34),
    0 0 24px rgba(245, 192, 78, 0.26);
  transform: translateY(-3px) scale(1.02);
  outline: none;
}

.scroll-to-top:active,
.scroll-down:active {
  transform: translateY(0) scale(0.96);
}

body.cart_open .scroll-to-top,
body.cart_open .scroll-down,
body.search_open .scroll-to-top,
body.search_open .scroll-down,
body.delivery_schedule_open .scroll-to-top,
body.delivery_schedule_open .scroll-down,
body.lightbox_open .scroll-to-top,
body.lightbox_open .scroll-down {
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
  transform: translateY(12px) scale(0.94);
}

@media (max-width: 576px) {
  .scroll-to-top,
  .scroll-down {
    right: 14px !important;
    width: 42px !important;
    min-width: 42px;
    height: 42px !important;
    min-height: 42px;
  }

  .scroll-to-top,
  .scroll-down {
    bottom: 16px !important;
  }

  .scroll-to-top i,
  .scroll-down i {
    font-size: 15px;
  }
}

/* Compact premium search modal. */
.site_search_panel {
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 24px;
}

.site_search_panel[hidden] {
  display: none !important;
}

.site_search_backdrop {
  background: rgba(9, 8, 7, 0.38);
  -webkit-backdrop-filter: blur(12px) saturate(120%);
          backdrop-filter: blur(12px) saturate(120%);
}

.site_search_dialog {
  position: relative;
  display: flex;
  flex-direction: column;
  width: min(700px, calc(100% - 48px));
  max-height: 72vh;
  margin: 0;
  padding: 22px;
  overflow: hidden;
  border: 1px solid rgba(255, 196, 72, 0.18);
  border-radius: 28px;
  background: rgba(255, 255, 255, 0.88);
  color: #211a12;
  box-shadow: 0 10px 35px rgba(0, 0, 0, 0.14);
  -webkit-backdrop-filter: blur(18px);
          backdrop-filter: blur(18px);
}

.site_search_header {
  flex-shrink: 0;
  gap: 12px;
  align-items: flex-start;
}

.site_search_header h3 {
  margin: 4px 0 0;
  font-size: 1.38rem;
  line-height: 1.18;
}

.site_search_kicker {
  color: #b9780a;
  font-size: 10.5px;
  letter-spacing: 0.1em;
}

.site_search_close {
  width: 36px;
  min-width: 36px;
  height: 36px;
  border: 1px solid rgba(188, 132, 32, 0.14);
  background: rgba(255, 255, 255, 0.64);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.72);
}

.site_search_input_wrap {
  flex-shrink: 0;
  min-height: 48px;
  margin-top: 16px;
  padding: 0 14px;
  gap: 10px;
  border: 1px solid rgba(188, 132, 32, 0.16);
  border-radius: 18px;
  background: rgba(255, 255, 255, 0.78);
  box-shadow: 0 6px 18px rgba(40, 28, 10, 0.06), inset 0 1px 0 rgba(255, 255, 255, 0.7);
}

.site_search_input_wrap:focus-within {
  border-color: rgba(255, 196, 72, 0.48);
  box-shadow: 0 0 0 3px rgba(255, 196, 72, 0.12), 0 8px 22px rgba(40, 28, 10, 0.08), inset 0 1px 0 rgba(255, 255, 255, 0.75);
}

.site_search_input_wrap input {
  font-size: 14px;
}

.site_search_hint {
  flex-shrink: 0;
  margin: 10px 2px 0;
  font-size: 12.5px;
  line-height: 1.45;
}

.site_search_section_label {
  flex-shrink: 0;
  margin-top: 12px;
  font-size: 10.5px;
  letter-spacing: 0.08em;
}

.site_search_results {
  display: grid;
  flex: 1 1 auto;
  min-height: 0;
  max-height: 340px;
  margin-top: 10px;
  padding: 1px 4px 1px 1px;
  gap: 8px;
  overflow-y: auto;
}

.site_search_result {
  grid-template-columns: 56px minmax(0, 1fr) auto;
  gap: 12px;
  padding: 12px 14px;
  border-radius: 18px;
  background: rgba(255, 255, 255, 0.72);
  border-color: rgba(188, 132, 32, 0.12);
  box-shadow: 0 6px 16px rgba(48, 34, 13, 0.06);
}

.site_search_result:hover,
.site_search_result:focus,
.site_search_result.is_active {
  background: rgba(255, 255, 255, 0.9);
  border-color: rgba(255, 196, 72, 0.32);
  box-shadow: 0 10px 24px rgba(48, 34, 13, 0.1);
  transform: translateY(-1px);
}

.site_search_result img {
  width: 56px;
  height: 56px;
  padding: 6px;
  border-radius: 12px;
}

.site_search_result strong {
  display: -webkit-box;
  overflow: hidden;
  color: #211a12;
  font-size: 14px;
  line-height: 1.25;
  -webkit-line-clamp: 2;
          line-clamp: 2;
  -webkit-box-orient: vertical;
}

.site_search_result_category {
  margin-bottom: 2px;
  font-size: 10px;
  letter-spacing: 0.06em;
}

.site_search_result_meta {
  display: -webkit-box;
  overflow: hidden;
  margin-top: 3px;
  font-size: 12px;
  line-height: 1.3;
  -webkit-line-clamp: 1;
          line-clamp: 1;
  -webkit-box-orient: vertical;
}

.site_search_result_action {
  min-height: 28px;
  padding: 0 10px;
  font-size: 11px;
}

.site_search_empty_state {
  min-height: 150px;
  padding: 20px;
  border-radius: 18px;
}

.site_search_empty_icon {
  width: 44px;
  height: 44px;
  margin-bottom: 10px;
  font-size: 18px;
}

.site_search_empty_state strong {
  font-size: 15px;
}

.site_search_empty_state p {
  margin-top: 6px;
  font-size: 13px;
  line-height: 1.5;
}

html[data-theme="dark"] .site_search_dialog,
body.dark-mode .site_search_dialog,
body.theme_dark .site_search_dialog {
  background: rgba(28, 24, 20, 0.88);
  border-color: rgba(255, 196, 72, 0.18);
  color: #f7f0e2;
  box-shadow: 0 10px 35px rgba(0, 0, 0, 0.28);
  -webkit-backdrop-filter: blur(18px);
          backdrop-filter: blur(18px);
}

html[data-theme="dark"] .site_search_backdrop,
body.dark-mode .site_search_backdrop,
body.theme_dark .site_search_backdrop {
  background: rgba(8, 7, 6, 0.46);
}

html[data-theme="dark"] .site_search_input_wrap,
body.dark-mode .site_search_input_wrap,
body.theme_dark .site_search_input_wrap {
  background: rgba(255, 246, 229, 0.08);
  border-color: rgba(255, 196, 72, 0.16);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.05);
}

html[data-theme="dark"] .site_search_input_wrap:focus-within,
body.dark-mode .site_search_input_wrap:focus-within,
body.theme_dark .site_search_input_wrap:focus-within {
  border-color: rgba(255, 196, 72, 0.46);
  box-shadow: 0 0 0 3px rgba(255, 196, 72, 0.12), inset 0 1px 0 rgba(255, 255, 255, 0.06);
}

html[data-theme="dark"] .site_search_result,
body.dark-mode .site_search_result,
body.theme_dark .site_search_result {
  background: rgba(255, 246, 229, 0.06);
  border-color: rgba(255, 196, 72, 0.12);
  box-shadow: 0 6px 16px rgba(0, 0, 0, 0.16);
}

html[data-theme="dark"] .site_search_result:hover,
html[data-theme="dark"] .site_search_result:focus,
html[data-theme="dark"] .site_search_result.is_active,
body.dark-mode .site_search_result:hover,
body.dark-mode .site_search_result:focus,
body.dark-mode .site_search_result.is_active,
body.theme_dark .site_search_result:hover,
body.theme_dark .site_search_result:focus,
body.theme_dark .site_search_result.is_active {
  background: rgba(255, 246, 229, 0.1);
  border-color: rgba(255, 196, 72, 0.32);
  box-shadow: 0 10px 24px rgba(0, 0, 0, 0.22);
}

html[data-theme="dark"] .site_search_close,
body.dark-mode .site_search_close,
body.theme_dark .site_search_close {
  background: rgba(255, 246, 229, 0.08);
  border-color: rgba(255, 196, 72, 0.14);
}

/* Fixed viewport search modal. */
.site_search_panel {
  position: fixed;
  inset: 0;
  z-index: 10050;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  min-height: 100dvh;
  padding: 24px;
  background: transparent;
}

.site_search_panel[hidden] {
  display: none !important;
}

.site_search_backdrop {
  position: fixed;
  inset: 0;
  background: rgba(5, 5, 5, 0.68);
  -webkit-backdrop-filter: blur(10px) saturate(125%);
          backdrop-filter: blur(10px) saturate(125%);
}

.site_search_dialog {
  position: relative;
  z-index: 1;
  width: calc(100% - 32px);
  max-width: 520px;
  max-height: 80vh;
  margin: 0;
  padding: 22px;
  overflow-y: auto;
  border: 1px solid rgba(255, 190, 51, 0.24);
  border-radius: 24px;
  background: linear-gradient(180deg, rgba(35, 38, 45, 0.98), rgba(18, 18, 18, 0.98));
  color: #f8f0df;
  box-shadow: 0 30px 80px rgba(0, 0, 0, 0.42), inset 0 1px 0 rgba(255, 255, 255, 0.06);
}

.site_search_header h3 {
  color: #ffffff;
}

.site_search_kicker,
.site_search_section_label {
  color: #ffbe33;
}

.site_search_close {
  background: rgba(255, 190, 51, 0.12);
  border: 1px solid rgba(255, 190, 51, 0.24);
  color: #ffda84;
}

.site_search_close:hover,
.site_search_close:focus {
  background: #ffbe33;
  color: #111111;
}

.site_search_input_wrap {
  background: rgba(255, 255, 255, 0.08);
  border-color: rgba(255, 190, 51, 0.22);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.06);
}

.site_search_input_wrap:focus-within {
  border-color: rgba(255, 190, 51, 0.72);
  box-shadow: 0 0 0 3px rgba(255, 190, 51, 0.14), inset 0 1px 0 rgba(255, 255, 255, 0.08);
}

.site_search_input_wrap i {
  color: #ffda84;
}

.site_search_input_wrap input {
  color: #ffffff;
}

.site_search_input_wrap input::placeholder,
.site_search_hint,
.site_search_result_meta {
  color: rgba(248, 240, 223, 0.68);
}

.site_search_results {
  max-height: none;
  overflow: visible;
}

.site_search_result {
  background: rgba(255, 255, 255, 0.07);
  border-color: rgba(255, 190, 51, 0.16);
  color: #f8f0df;
}

.site_search_result:hover,
.site_search_result:focus,
.site_search_result.is_active {
  background: rgba(255, 190, 51, 0.12);
  border-color: rgba(255, 190, 51, 0.44);
  color: #ffffff;
  transform: translateY(-1px);
}

.site_search_result strong {
  color: #ffffff;
}

.site_search_result_category {
  color: #ffbe33;
}

.site_search_result_action {
  background: rgba(255, 190, 51, 0.18);
  color: #ffda84;
}

.site_search_empty_state {
  background: rgba(255, 255, 255, 0.06);
  border-color: rgba(255, 190, 51, 0.24);
  color: rgba(248, 240, 223, 0.72);
}

.site_search_empty_state strong {
  color: #ffffff;
}

/* Theme-aware search overlay */
.site_search_panel {
  --search-backdrop: rgba(66, 54, 35, 0.34);
  --search-surface: linear-gradient(180deg, rgba(255, 253, 248, 0.98), rgba(248, 241, 229, 0.98));
  --search-panel-text: #211a12;
  --search-heading: #18130d;
  --search-muted: #6f6251;
  --search-soft-text: #7c705f;
  --search-gold: #b8790a;
  --search-gold-strong: #7a5200;
  --search-border: rgba(166, 113, 24, 0.18);
  --search-border-strong: rgba(255, 190, 51, 0.42);
  --search-input-bg: #ffffff;
  --search-input-icon: #9b762b;
  --search-result-bg: rgba(255, 255, 255, 0.9);
  --search-result-hover: #ffffff;
  --search-result-image-bg: #fff8ec;
  --search-action-bg: linear-gradient(135deg, #ffbe33, #d49a24);
  --search-action-text: #1d1405;
  --search-empty-bg: rgba(255, 255, 255, 0.72);
  --search-shadow: 0 30px 72px rgba(59, 42, 18, 0.2), inset 0 1px 0 rgba(255, 255, 255, 0.78);
  --search-card-shadow: 0 10px 24px rgba(48, 34, 13, 0.08);
  --search-card-hover-shadow: 0 14px 30px rgba(48, 34, 13, 0.14);
}

html[data-theme="dark"] .site_search_panel,
body.dark-mode .site_search_panel,
body.theme_dark .site_search_panel {
  --search-backdrop: rgba(8, 7, 6, 0.58);
  --search-surface: linear-gradient(180deg, rgba(36, 29, 22, 0.96), rgba(22, 18, 14, 0.97));
  --search-panel-text: #f7f0e2;
  --search-heading: #fff8e8;
  --search-muted: #d7cbb7;
  --search-soft-text: #b9aa94;
  --search-gold: #f2c76b;
  --search-gold-strong: #ffe09a;
  --search-border: rgba(242, 199, 107, 0.18);
  --search-border-strong: rgba(255, 190, 51, 0.44);
  --search-input-bg: rgba(255, 248, 232, 0.08);
  --search-input-icon: #ffda84;
  --search-result-bg: rgba(255, 248, 232, 0.07);
  --search-result-hover: rgba(255, 190, 51, 0.12);
  --search-result-image-bg: rgba(255, 248, 232, 0.1);
  --search-action-bg: rgba(255, 190, 51, 0.18);
  --search-action-text: #ffda84;
  --search-empty-bg: rgba(255, 248, 232, 0.06);
  --search-shadow: 0 30px 80px rgba(0, 0, 0, 0.42), inset 0 1px 0 rgba(255, 255, 255, 0.06);
  --search-card-shadow: 0 10px 24px rgba(0, 0, 0, 0.2);
  --search-card-hover-shadow: 0 14px 30px rgba(0, 0, 0, 0.26);
}

.site_search_backdrop {
  background: var(--search-backdrop);
}

.site_search_dialog {
  display: flex;
  flex-direction: column;
  max-width: 620px;
  max-height: min(720px, calc(100dvh - 48px));
  overflow: hidden;
  border-color: var(--search-border);
  background: var(--search-surface);
  color: var(--search-panel-text);
  box-shadow: var(--search-shadow);
}

.site_search_header {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 18px;
}

.site_search_header h3 {
  color: var(--search-heading);
}

.site_search_kicker,
.site_search_section_label {
  color: var(--search-gold);
}

.site_search_close {
  background: var(--search-input-bg);
  border-color: var(--search-border);
  color: var(--search-heading);
}

.site_search_close:hover,
.site_search_close:focus {
  background: var(--search-action-bg);
  border-color: transparent;
  color: var(--search-action-text);
}

.site_search_input_wrap {
  background: var(--search-input-bg);
  border-color: var(--search-border);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.45);
}

.site_search_input_wrap:focus-within {
  border-color: var(--search-border-strong);
  box-shadow: 0 0 0 3px rgba(255, 190, 51, 0.16), inset 0 1px 0 rgba(255, 255, 255, 0.45);
}

.site_search_input_wrap i {
  color: var(--search-input-icon);
}

.site_search_input_wrap input {
  color: var(--search-heading);
}

.site_search_input_wrap input::placeholder,
.site_search_hint {
  color: var(--search-soft-text);
}

.site_search_results {
  max-height: min(48vh, 420px);
  overflow-y: auto;
  gap: 8px;
  padding: 2px 4px 2px 1px;
}

.site_search_result {
  display: grid;
  grid-template-columns: 58px minmax(0, 1fr) auto;
  align-items: center;
  gap: 12px;
  min-height: 76px;
  padding: 10px 12px;
  border-color: var(--search-border);
  border-radius: 16px;
  background: var(--search-result-bg);
  color: var(--search-panel-text);
  box-shadow: var(--search-card-shadow);
  transition: transform 0.16s ease, border-color 0.16s ease, box-shadow 0.16s ease, background 0.16s ease;
}

.site_search_result:hover,
.site_search_result:focus,
.site_search_result.is_active {
  background: var(--search-result-hover);
  border-color: var(--search-border-strong);
  color: var(--search-panel-text);
  box-shadow: var(--search-card-hover-shadow);
  transform: translateY(-1px);
}

.site_search_result:active {
  transform: translateY(0) scale(0.99);
}

.site_search_result img {
  width: 58px;
  height: 58px;
  padding: 7px;
  border-radius: 14px;
  background: var(--search-result-image-bg);
  object-fit: contain;
}

.site_search_result_body {
  min-width: 0;
  display: grid;
  gap: 2px;
}

.site_search_result_category,
.site_search_result_meta {
  display: block;
}

.site_search_result_category {
  margin: 0;
  color: var(--search-gold);
  font-size: 10px;
  font-weight: 900;
  letter-spacing: 0.07em;
  line-height: 1.25;
  text-transform: uppercase;
}

.site_search_result strong {
  color: var(--search-heading);
  font-size: 13.5px;
  line-height: 1.25;
}

.site_search_result_meta {
  margin: 0;
  color: var(--search-muted);
  font-size: 12.5px;
  font-weight: 800;
  line-height: 1.25;
}

.site_search_result_action {
  min-width: 48px;
  min-height: 32px;
  padding: 0 12px;
  border-radius: 999px;
  background: var(--search-action-bg);
  color: var(--search-action-text);
  font-size: 12px;
  font-weight: 900;
}

.site_search_empty_state {
  min-height: 150px;
  background: var(--search-empty-bg);
  border: 1px dashed var(--search-border);
  color: var(--search-muted);
}

.site_search_empty_icon {
  background: var(--search-result-image-bg);
  color: var(--search-gold);
}

.site_search_empty_state strong {
  color: var(--search-heading);
}

@media (max-width: 576px) {
  .site_search_panel {
    padding: 12px;
  }

  .site_search_dialog {
    width: 100%;
    max-height: calc(100dvh - 24px);
    padding: 14px;
    border-radius: 18px;
  }

  .site_search_header h3 {
    font-size: 1.08rem;
  }

  .site_search_close {
    width: 34px;
    min-width: 34px;
    height: 34px;
  }

  .site_search_input_wrap {
    min-height: 44px;
    margin-top: 12px;
    padding: 0 12px;
  }

  .site_search_results {
    max-height: min(54vh, 430px);
    gap: 6px;
  }

  .site_search_result {
    grid-template-columns: 48px minmax(0, 1fr) auto;
    gap: 9px;
    min-height: 64px;
    padding: 8px;
    border-radius: 14px;
  }

  .site_search_result img {
    width: 48px;
    height: 48px;
    padding: 5px;
    border-radius: 12px;
  }

  .site_search_result_category {
    font-size: 9px;
  }

  .site_search_result strong {
    font-size: 12.5px;
    -webkit-line-clamp: 1;
            line-clamp: 1;
  }

  .site_search_result_meta {
    font-size: 11.5px;
  }

  .site_search_result_action {
    min-width: 44px;
    min-height: 30px;
    padding: 0 10px;
    font-size: 11px;
  }

  .site_search_empty_state {
    min-height: 128px;
    padding: 16px;
  }
}

/* Fixed cart drawer overlay. */
.cart_drawer {
  position: fixed;
  inset: 0;
  z-index: 10045;
  display: flex;
  align-items: center;
  justify-content: flex-end;
  padding: 24px;
}

.cart_drawer[hidden] {
  display: none !important;
}

.cart_drawer_backdrop {
  position: fixed;
  inset: 0;
  background: rgba(5, 5, 5, 0.68);
  -webkit-backdrop-filter: blur(10px) saturate(125%);
          backdrop-filter: blur(10px) saturate(125%);
}

.cart_drawer_panel {
  position: relative;
  z-index: 1;
  display: flex;
  flex-direction: column;
  width: min(440px, calc(100% - 32px));
  max-height: 85vh;
  height: auto;
  min-height: 0;
  padding: 22px;
  overflow: hidden;
  border: 1px solid rgba(255, 190, 51, 0.24);
  border-radius: 26px;
  background: linear-gradient(180deg, rgba(35, 38, 45, 0.98), rgba(18, 18, 18, 0.98));
  color: #f8f0df;
  box-shadow: 0 30px 80px rgba(0, 0, 0, 0.42), inset 0 1px 0 rgba(255, 255, 255, 0.06);
}

.cart_drawer_header {
  flex: 0 0 auto;
}

.cart_drawer_header h3 {
  color: #ffffff;
}

.cart_drawer_kicker {
  color: #ffbe33;
}

.cart_drawer_close {
  flex: 0 0 40px;
  width: 40px;
  height: 40px;
  border: 1px solid rgba(255, 190, 51, 0.24);
  background: rgba(255, 190, 51, 0.12);
  color: #ffda84;
}

.cart_drawer_close:hover,
.cart_drawer_close:focus {
  background: #ffbe33;
  color: #111111;
}

.cart_drawer_body {
  flex: 1 1 auto;
  min-height: 0;
  margin: 18px 0;
  overflow-y: auto;
  padding-right: 4px;
}

.cart_empty_state {
  min-height: 180px;
  border-color: rgba(255, 190, 51, 0.24);
  background: rgba(255, 255, 255, 0.06);
  color: rgba(248, 240, 223, 0.72);
}

.cart_empty_icon {
  background: rgba(255, 190, 51, 0.16);
  color: #ffbe33;
}

.cart_item {
  grid-template-columns: 82px minmax(0, 1fr);
  background: rgba(255, 255, 255, 0.07);
  border-color: rgba(255, 190, 51, 0.16);
  box-shadow: 0 12px 28px rgba(0, 0, 0, 0.18);
}

.cart_item_image {
  min-height: 82px;
  background: rgba(255, 255, 255, 0.92);
}

.cart_item_header strong {
  color: #ffffff;
  line-height: 1.25;
}

.cart_item_header a {
  min-width: 0;
  text-decoration: none;
}

.cart_item_price {
  color: rgba(248, 240, 223, 0.7);
}

.cart_remove_btn {
  flex: 0 0 auto;
  color: #ff8f7d;
}

.cart_qty_controls {
  background: rgba(255, 255, 255, 0.08);
  border: 1px solid rgba(255, 190, 51, 0.14);
  color: #ffffff;
}

.cart_qty_controls button {
  background: #ffbe33;
  color: #111111;
}

.cart_drawer_footer {
  flex: 0 0 auto;
  border-top-color: rgba(255, 190, 51, 0.18);
}

.cart_subtotal_row {
  color: rgba(248, 240, 223, 0.78);
}

.cart_subtotal_row strong {
  color: #ffffff;
}

.cart_clear_btn {
  border-color: rgba(255, 190, 51, 0.22);
  background: rgba(255, 255, 255, 0.08);
  color: #f8f0df;
}

.cart_drawer_actions .return_menu_btn {
  border-color: rgba(255, 190, 51, 0.34);
  background: rgba(255, 190, 51, 0.12);
  color: #ffda84;
  cursor: pointer;
}

.cart_drawer_actions .return_menu_btn:hover,
.cart_drawer_actions .return_menu_btn:focus,
.cart_clear_btn:hover,
.cart_clear_btn:focus {
  background: rgba(255, 190, 51, 0.2);
  color: #ffffff;
}

.cart_drawer_actions .cart_checkout_btn {
  background: #ffbe33;
  color: #111111;
}

.cart_drawer_actions .cart_checkout_btn:hover,
.cart_drawer_actions .cart_checkout_btn:focus {
  background: #f2b019;
  color: #111111;
}

/* Fixed checkout / delivery confirmation overlay. */
.delivery_schedule_modal {
  position: fixed;
  inset: 0;
  z-index: 10070;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  min-height: 100dvh;
  padding: 24px;
}

.delivery_schedule_modal[hidden] {
  display: none !important;
}

.delivery_schedule_backdrop {
  position: fixed;
  inset: 0;
  background: rgba(5, 5, 5, 0.72);
  -webkit-backdrop-filter: blur(10px) saturate(125%);
          backdrop-filter: blur(10px) saturate(125%);
}

.delivery_schedule_dialog {
  position: relative;
  z-index: 1;
  width: calc(100% - 24px);
  max-width: 560px;
  max-height: 85vh;
  margin: 0;
  overflow-y: auto;
  border: 1px solid rgba(255, 190, 51, 0.24);
  background: linear-gradient(180deg, rgba(35, 38, 45, 0.98), rgba(18, 18, 18, 0.98));
  color: #f8f0df;
  box-shadow: 0 30px 80px rgba(0, 0, 0, 0.42), inset 0 1px 0 rgba(255, 255, 255, 0.06);
}

.delivery_schedule_close {
  background: rgba(255, 190, 51, 0.12);
  border: 1px solid rgba(255, 190, 51, 0.24);
  color: #ffda84;
}

.delivery_schedule_close:hover,
.delivery_schedule_close:focus {
  background: #ffbe33;
  color: #111111;
}

.delivery_schedule_kicker,
.delivery_city_selector legend {
  color: #ffbe33;
}

.delivery_schedule_dialog h3 {
  color: #ffffff;
}

.delivery_schedule_dialog p,
.delivery_city_copy span,
.checkout_order_note {
  color: rgba(248, 240, 223, 0.72);
}

.delivery_city_options {
  gap: 10px;
}

.delivery_city_card {
  min-width: 0;
  background: rgba(255, 255, 255, 0.07);
  border-color: rgba(255, 190, 51, 0.16);
  box-shadow: 0 12px 28px rgba(0, 0, 0, 0.16);
}

.delivery_city_card:hover,
.delivery_city_card:focus-within,
.delivery_city_card.is_selected {
  background: rgba(255, 190, 51, 0.12);
  border-color: rgba(255, 190, 51, 0.44);
}

.delivery_city_copy strong {
  color: #ffffff;
}

.delivery_selected_day {
  margin: -4px 0 14px;
  padding: 11px 13px;
  border-radius: 14px;
  background: rgba(255, 190, 51, 0.12);
  border: 1px solid rgba(255, 190, 51, 0.22);
  color: #ffda84;
  font-weight: 800;
  line-height: 1.35;
}

.checkout_customer_fields {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px;
  margin: 14px 0;
}

.checkout_customer_fields label {
  display: grid;
  gap: 6px;
  margin: 0;
  color: rgba(248, 240, 223, 0.78);
  font-size: 12px;
  font-weight: 800;
}

.checkout_customer_address {
  grid-column: 1 / -1;
}

.checkout_customer_fields input,
.checkout_customer_fields textarea {
  width: 100%;
  min-width: 0;
  border: 1px solid rgba(255, 190, 51, 0.18);
  border-radius: 14px;
  background: rgba(255, 255, 255, 0.08);
  color: #ffffff;
  padding: 11px 12px;
  outline: none;
  resize: vertical;
}

.checkout_customer_fields input:focus,
.checkout_customer_fields textarea:focus {
  border-color: rgba(255, 190, 51, 0.64);
  box-shadow: 0 0 0 3px rgba(255, 190, 51, 0.12);
}

.checkout_customer_fields input::placeholder,
.checkout_customer_fields textarea::placeholder {
  color: rgba(248, 240, 223, 0.42);
}

.checkout_order_summary {
  display: grid;
  gap: 8px;
  margin: 14px 0;
  padding: 13px;
  border-radius: 16px;
  background: rgba(255, 255, 255, 0.06);
  border: 1px solid rgba(255, 190, 51, 0.16);
}

.checkout_order_summary_head,
.checkout_order_item {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 12px;
}

.checkout_order_summary_head span,
.checkout_order_item span {
  min-width: 0;
  color: rgba(248, 240, 223, 0.78);
}

.checkout_order_summary_head strong,
.checkout_order_item strong {
  flex: 0 0 auto;
  color: #ffffff;
}

.checkout_order_items {
  display: grid;
  gap: 7px;
}

.checkout_order_empty {
  color: rgba(248, 240, 223, 0.72);
}

.delivery_schedule_validation {
  color: #ffda84;
}

.delivery_schedule_agreement {
  background: rgba(255, 190, 51, 0.12);
  border-color: rgba(255, 190, 51, 0.28);
  color: #f8f0df;
}

.delivery_schedule_cancel {
  border-color: rgba(255, 190, 51, 0.24);
  background: rgba(255, 255, 255, 0.08);
  color: #f8f0df;
}

.delivery_schedule_cancel:hover,
.delivery_schedule_cancel:focus {
  background: rgba(255, 190, 51, 0.18);
  color: #ffffff;
}

.delivery_schedule_continue {
  background: #ffbe33;
  color: #111111;
}

.delivery_schedule_continue:not(:disabled):hover,
.delivery_schedule_continue:not(:disabled):focus {
  background: #f2b019;
  color: #111111;
}

/* Mobile auth modal */
.mobile_auth_modal {
  position: fixed;
  inset: 0;
  z-index: 10020;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 20px;
}

.mobile_auth_modal[hidden] {
  display: none !important;
}

.mobile_auth_backdrop {
  position: absolute;
  inset: 0;
  background: rgba(7, 6, 5, 0.68);
  -webkit-backdrop-filter: blur(14px) saturate(130%);
          backdrop-filter: blur(14px) saturate(130%);
}

.mobile_auth_dialog {
  position: relative;
  z-index: 1;
  width: min(360px, 100%);
  padding: 26px 20px 22px;
  border: 1px solid rgba(255, 210, 112, 0.34);
  border-radius: 24px;
  background:
    radial-gradient(circle at top right, rgba(255, 196, 72, 0.18), transparent 34%),
    linear-gradient(145deg, rgba(255, 255, 255, 0.13), rgba(255, 255, 255, 0.045)),
    rgba(18, 16, 13, 0.92);
  color: #fff4da;
  text-align: center;
  box-shadow: 0 28px 72px rgba(0, 0, 0, 0.48), inset 0 1px 0 rgba(255, 255, 255, 0.08);
  -webkit-backdrop-filter: blur(22px) saturate(145%);
          backdrop-filter: blur(22px) saturate(145%);
  outline: none;
}

.mobile_auth_close {
  position: absolute;
  top: 12px;
  right: 12px;
  width: 36px;
  height: 36px;
  padding: 0;
  border: 1px solid rgba(255, 210, 112, 0.18);
  border-radius: 13px;
  background: rgba(255, 255, 255, 0.07);
  color: #ffe5a6;
  display: inline-flex;
  align-items: center;
  justify-content: center;
}

.mobile_auth_icon {
  width: 56px;
  height: 56px;
  margin: 0 auto 14px;
  border: 1px solid rgba(255, 210, 112, 0.36);
  border-radius: 18px;
  background: rgba(255, 196, 72, 0.12);
  color: #ffd66f;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 22px;
  box-shadow: 0 12px 28px rgba(255, 190, 51, 0.12), inset 0 1px 0 rgba(255, 255, 255, 0.08);
}

.mobile_auth_dialog h3 {
  margin: 0;
  color: #fff8e8;
  font-size: 1.35rem;
  font-weight: 900;
  line-height: 1.2;
}

.mobile_auth_dialog p {
  margin: 8px 0 18px;
  color: rgba(255, 244, 218, 0.72);
  font-size: 0.95rem;
  line-height: 1.45;
}

.mobile_auth_google_btn {
  width: 100%;
  min-height: 50px;
  padding: 0 18px;
  border: 1px solid rgba(255, 210, 112, 0.38);
  border-radius: 16px;
  background: linear-gradient(135deg, #ffd66f, #ffb931);
  color: #21170a;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  font-size: 0.98rem;
  font-weight: 900;
  line-height: 1;
  box-shadow: 0 14px 32px rgba(255, 190, 51, 0.22), inset 0 1px 0 rgba(255, 255, 255, 0.34);
}

.mobile_auth_google_btn:hover,
.mobile_auth_google_btn:focus,
.mobile_auth_close:hover,
.mobile_auth_close:focus {
  outline: none;
  transform: translateY(-1px);
}

.mobile_auth_google_btn:focus,
.mobile_auth_close:focus {
  box-shadow: 0 0 0 3px rgba(255, 210, 112, 0.22), 0 14px 32px rgba(255, 190, 51, 0.22);
}

body.mobile_auth_open {
  overflow: hidden;
}

/* Offers counter stays attached across desktop and mobile navbar placements. */
.offers_nav_btn {
  position: relative !important;
  overflow: visible !important;
}

.offers_nav_badge {
  position: absolute !important;
  top: -6px !important;
  right: -6px !important;
  min-width: 18px !important;
  width: auto !important;
  height: 18px !important;
  padding: 0 5px !important;
  border-radius: 999px !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  background: #ff2b2b !important;
  color: #ffffff !important;
  font-size: 11px !important;
  font-weight: 700 !important;
  line-height: 1 !important;
  border: 2px solid rgba(20, 20, 20, 0.95) !important;
  box-shadow: 0 4px 12px rgba(255, 0, 0, 0.35), 0 0 8px rgba(255, 50, 50, 0.4) !important;
  z-index: 9999 !important;
  pointer-events: none !important;
}

.offers_nav_badge[hidden] {
  display: none !important;
}

@media (max-width: 768px) {
  .offers_nav_badge {
    top: -5px !important;
    right: -5px !important;
    min-width: 16px !important;
    height: 16px !important;
    font-size: 10px !important;
  }
}

/* Mobile fixed navbar utility grouping */
@media (max-width: 991px) {
  .custom_nav-container {
    justify-content: flex-start;
  }

  .navbar-brand {
    flex: 0 1 auto;
    margin-right: 18px;
  }

  .mobile-navbar-right {
    display: flex;
    align-items: center;
    justify-content: flex-end;
    gap: 8px;
    margin-left: auto;
    flex: 0 0 auto;
    min-width: 0;
  }

  .mobile-navbar-right .form-inline,
  .mobile-navbar-right .custom-language-switcher {
    margin: 0;
    flex: 0 0 auto;
  }

  .mobile-navbar-right .offers_nav_btn,
  .mobile-navbar-right .nav_search-btn,
  .mobile-navbar-right .theme_toggle,
  .mobile-navbar-right .navbar-toggler {
    width: 38px;
    min-width: 38px;
    max-width: 38px;
    height: 38px;
    min-height: 38px;
    padding: 0;
    border-radius: 13px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    margin: 0;
    border: 1px solid rgba(255, 196, 72, 0.16);
    background: rgba(255, 255, 255, 0.06);
    color: #f7efe2;
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.04);
  }

  .mobile-navbar-right .custom-language-switcher .language-btn {
    height: 38px;
    min-height: 38px;
    min-width: 66px;
    max-width: 74px;
    padding: 0 10px;
    border-radius: 18px;
    gap: 5px;
    font-size: 12px;
    letter-spacing: 0;
  }

  .mobile-navbar-right .language-btn i,
  .mobile-navbar-right .lang-icon,
  .mobile-navbar-right .lang-icon::before {
    width: 12px;
    height: 12px;
    font-size: 12px;
    line-height: 1;
  }

  .mobile-navbar-right .lang-code {
    font-size: 12px;
  }

  .mobile-navbar-right .lang-divider,
  .mobile-navbar-right .lang-arrow {
    font-size: 9px;
  }

  .mobile-navbar-right .offers_nav_btn .offers_nav_label {
    display: none;
  }

  .mobile-navbar-right .nav_search-btn i,
  .mobile-navbar-right .offers_nav_btn i,
  .mobile-navbar-right .theme_toggle_icon::before {
    font-size: 13px;
  }
}

@media (max-width: 420px) {
  .navbar-brand {
    margin-right: 12px;
  }

  .mobile-navbar-right {
    gap: 6px;
  }
}

@media (max-width: 360px) {
  .mobile-navbar-right {
    gap: 5px;
  }

  .mobile-navbar-right .custom-language-switcher .language-btn {
    min-width: 62px;
    max-width: 66px;
    padding: 0 8px;
  }
}
/*# sourceMappingURL=style.css.map */

.checkout_modal {
  position: fixed;
  inset: 0;
  z-index: 130;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 24px;
}

.checkout_modal[hidden] {
  display: none;
}

.checkout_backdrop {
  position: absolute;
  inset: 0;
  background: rgba(8, 7, 6, 0.74);
  backdrop-filter: blur(8px);
}

.checkout_dialog {
  position: relative;
  width: min(1120px, 100%);
  max-height: min(90vh, 920px);
  overflow: auto;
  padding: 28px;
  border-radius: 24px;
  background: linear-gradient(145deg, #17120c, #090807);
  border: 1px solid rgba(242, 199, 107, 0.25);
  box-shadow: 0 28px 70px rgba(0, 0, 0, 0.45);
  color: #fff8e8;
}

.checkout_close {
  position: absolute;
  top: 18px;
  right: 18px;
  width: 42px;
  height: 42px;
  border: 1px solid rgba(242, 199, 107, 0.2);
  border-radius: 50%;
  background: rgba(255, 248, 232, 0.08);
  color: #f7d577;
  cursor: pointer;
}

.checkout_header {
  max-width: 720px;
  padding-right: 52px;
  margin-bottom: 22px;
}

.checkout_kicker {
  display: block;
  margin-bottom: 8px;
  color: #f7d577;
  font-size: 12px;
  font-weight: 800;
  letter-spacing: 0;
  text-transform: uppercase;
}

.checkout_header h3 {
  margin: 0;
  color: #ffffff;
  font-size: 30px;
  font-weight: 800;
}

.checkout_header p {
  margin: 10px 0 0;
  color: rgba(255, 248, 232, 0.72);
  line-height: 1.65;
}

.checkout_grid {
  display: grid;
  grid-template-columns: minmax(0, 0.92fr) minmax(0, 1.08fr);
  gap: 18px;
}

.checkout_panel {
  padding: 18px;
  border-radius: 18px;
  background: rgba(255, 248, 232, 0.055);
  border: 1px solid rgba(242, 199, 107, 0.16);
}

.checkout_panel h4 {
  margin: 0 0 14px;
  color: #f7d577;
  font-size: 16px;
  font-weight: 800;
}

.checkout_delivery_panel {
  grid-column: 1 / -1;
}

.checkout_fields {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 13px;
}

.checkout_fields span,
.checkout_city_selector legend {
  display: block;
  margin-bottom: 7px;
  color: rgba(255, 248, 232, 0.86);
  font-size: 13px;
  font-weight: 800;
}

.checkout_fields em {
  color: rgba(255, 248, 232, 0.52);
  font-style: normal;
  font-weight: 700;
}

.checkout_fields input,
.checkout_fields textarea,
.checkout_fields select {
  width: 100%;
  min-height: 46px;
  padding: 11px 13px;
  border-radius: 12px;
  border: 1px solid rgba(242, 199, 107, 0.18);
  background: rgba(255, 248, 232, 0.08);
  color: #ffffff;
  outline: none;
}

.checkout_fields textarea {
  resize: vertical;
}

.checkout_fields select option {
  color: #16110a;
}

.checkout_fields input:focus,
.checkout_fields textarea:focus,
.checkout_fields select:focus {
  border-color: rgba(247, 213, 119, 0.64);
  box-shadow: 0 0 0 3px rgba(247, 213, 119, 0.12);
}

.checkout_full_width {
  grid-column: 1 / -1;
}

.checkout_city_selector {
  margin: 0 0 14px;
  padding: 0;
  border: 0;
}

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

.checkout_city_card,
.checkout_payment_option {
  display: grid;
  grid-template-columns: auto minmax(0, 1fr);
  gap: 11px;
  align-items: center;
  padding: 13px;
  border-radius: 14px;
  border: 1px solid rgba(242, 199, 107, 0.16);
  background: rgba(255, 248, 232, 0.055);
  cursor: pointer;
}

.checkout_city_card.is_selected,
.checkout_payment_option:has(input:checked) {
  border-color: rgba(247, 213, 119, 0.62);
  background: rgba(247, 213, 119, 0.12);
}

.checkout_city_card input,
.checkout_payment_option input {
  accent-color: #d4af37;
}

.checkout_city_card strong,
.checkout_payment_option strong {
  display: block;
  color: #ffffff;
  font-size: 14px;
}

.checkout_city_card small,
.checkout_payment_option small {
  display: block;
  margin-top: 3px;
  color: rgba(255, 248, 232, 0.66);
  line-height: 1.35;
}

.checkout_order_summary {
  display: grid;
  gap: 10px;
}

.checkout_order_item {
  display: grid;
  grid-template-columns: 58px minmax(0, 1fr) auto;
  gap: 12px;
  align-items: center;
  padding: 10px;
  border-radius: 14px;
  background: rgba(255, 248, 232, 0.06);
  border: 1px solid rgba(242, 199, 107, 0.11);
}

.checkout_order_item img {
  width: 58px;
  height: 58px;
  object-fit: contain;
  border-radius: 12px;
  background: #f1f2f3;
}

.checkout_order_item strong,
.checkout_order_item b {
  color: #ffffff;
}

.checkout_order_item span {
  display: block;
  margin-top: 4px;
  color: rgba(255, 248, 232, 0.64);
  font-size: 13px;
}

.checkout_qty_controls {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 7px;
  margin-top: 9px;
}

.checkout_qty_controls button {
  min-width: 30px;
  height: 30px;
  padding: 0 10px;
  border: 1px solid rgba(242, 199, 107, 0.18);
  border-radius: 999px;
  background: rgba(255, 248, 232, 0.08);
  color: #f7d577;
  font-size: 12px;
  font-weight: 800;
  cursor: pointer;
}

.checkout_qty_controls span {
  margin: 0;
  color: #ffffff;
  font-weight: 800;
}

.checkout_qty_controls .checkout_remove_btn {
  color: #fecaca;
  border-color: rgba(248, 113, 113, 0.22);
}

.checkout_payment_panel {
  display: grid;
  gap: 14px;
}

.checkout_payment_icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 42px;
  height: 42px;
  border-radius: 50%;
  background: linear-gradient(135deg, #f7d577, #b9872c);
  color: #16110a;
}

.checkout_total_row {
  display: flex;
  justify-content: space-between;
  gap: 12px;
  padding-top: 14px;
  border-top: 1px solid rgba(242, 199, 107, 0.16);
  color: rgba(255, 248, 232, 0.76);
  font-weight: 800;
}

.checkout_total_row strong {
  color: #f7d577;
  font-size: 20px;
}

.checkout_validation {
  margin: 0;
  padding: 10px 12px;
  border-radius: 12px;
  background: rgba(239, 68, 68, 0.12);
  border: 1px solid rgba(248, 113, 113, 0.28);
  color: #fecaca;
  font-weight: 700;
}

.checkout_confirm_btn {
  min-height: 50px;
  border: 0;
  border-radius: 999px;
  background: linear-gradient(135deg, #f7d577, #b9872c);
  color: #16110a;
  font-weight: 900;
  cursor: pointer;
  box-shadow: 0 16px 32px rgba(242, 199, 107, 0.18);
}

.checkout_confirm_btn:hover,
.checkout_confirm_btn:focus {
  background: linear-gradient(135deg, #ffe6a6, #d4af37);
}

/* Checkout step flow redesign */
.checkout_modal {
  align-items: center;
  padding: 14px;
  box-sizing: border-box;
  width: 100vw;
  max-width: 100vw;
  overflow: hidden;
}

.checkout_dialog {
  width: min(720px, 100%);
  max-width: calc(100vw - 28px);
  max-height: min(92dvh, 820px);
  display: flex;
  flex-direction: column;
  box-sizing: border-box;
  overflow: auto;
  padding: 20px;
  border-radius: 22px;
  background:
    radial-gradient(circle at 18% 0%, rgba(242, 199, 107, 0.13), transparent 34%),
    linear-gradient(145deg, #17120c, #090807);
  scrollbar-gutter: stable;
}

.checkout_header {
  max-width: none;
  margin-bottom: 14px;
  padding-right: 48px;
}

.checkout_kicker {
  margin-bottom: 6px;
  color: #f7d577;
  font-size: 11px;
  letter-spacing: 0.08em;
}

.checkout_header h3 {
  font-size: clamp(1.55rem, 4vw, 2rem);
  line-height: 1.1;
}

.checkout_header p {
  margin-top: 7px;
  font-size: 0.92rem;
  line-height: 1.5;
}

.checkout_steps {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 8px;
  margin: 0 0 14px;
  padding: 0;
  list-style: none;
}

.checkout_step {
  box-sizing: border-box;
  min-width: 0;
  display: grid;
  justify-items: center;
  gap: 6px;
  padding: 9px 6px;
  border-radius: 14px;
  border: 1px solid rgba(242, 199, 107, 0.12);
  background: rgba(255, 248, 232, 0.045);
  color: rgba(255, 248, 232, 0.58);
  font-size: 11px;
  font-weight: 800;
  line-height: 1.15;
  text-align: center;
}

.checkout_step_number {
  width: 24px;
  height: 24px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 999px;
  background: rgba(255, 248, 232, 0.08);
  color: inherit;
  font-size: 12px;
}

.checkout_step.is_active {
  border-color: rgba(247, 213, 119, 0.52);
  background: rgba(247, 213, 119, 0.13);
  color: #fff8e8;
}

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

.checkout_panel,
.checkout_step_panel,
.checkout_order_summary,
.checkout_order_item,
.checkout_steps {
  min-width: 0;
  max-width: 100%;
}

.checkout_step.is_complete {
  color: #f7d577;
  border-color: rgba(247, 213, 119, 0.32);
}

.checkout_step.is_active .checkout_step_number,
.checkout_step.is_complete .checkout_step_number {
  background: linear-gradient(135deg, #f7d577, #b9872c);
  color: #16110a;
}

.checkout_form,
.checkout_step_panel {
  min-width: 0;
}

.checkout_step_panel[hidden] {
  display: none;
}

.checkout_panel {
  padding: 16px;
  border-radius: 18px;
  background: rgba(255, 248, 232, 0.06);
}

.checkout_panel_head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 14px;
  margin-bottom: 14px;
}

.checkout_panel_head h4 {
  margin: 3px 0 0;
  color: #fff8e8;
  font-size: 1.08rem;
}

.checkout_panel_head > strong {
  color: #f7d577;
  font-size: 1rem;
  line-height: 1.3;
  white-space: nowrap;
}

.checkout_step_label {
  display: block;
  color: #f7d577;
  font-size: 11px;
  font-weight: 900;
  letter-spacing: 0.08em;
  line-height: 1.2;
  text-transform: uppercase;
}

.checkout_order_summary {
  max-height: min(42dvh, 320px);
  overflow: auto;
  padding-right: 4px;
}

.checkout_order_item {
  grid-template-columns: 50px minmax(0, 1fr) auto;
  gap: 10px;
  padding: 9px;
  border-radius: 13px;
}

.checkout_order_item img {
  width: 50px;
  height: 50px;
  border-radius: 11px;
}

.checkout_order_item strong {
  font-size: 0.88rem;
  line-height: 1.28;
}

.checkout_order_item span {
  font-size: 0.78rem;
}

.checkout_order_item b {
  font-size: 0.88rem;
  white-space: nowrap;
}

.checkout_qty_controls {
  gap: 6px;
  margin-top: 7px;
}

.checkout_qty_controls button {
  min-width: 28px;
  height: 28px;
  padding: 0 9px;
  font-size: 11px;
}

.checkout_city_selector {
  margin: 0;
}

.checkout_city_options {
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 9px;
}

.checkout_city_card {
  min-height: 58px;
  padding: 11px;
  border-radius: 14px;
  gap: 10px;
}

.checkout_city_card strong {
  font-size: 0.9rem;
}

.checkout_city_check {
  width: 18px;
  height: 18px;
  border-radius: 50%;
  border: 2px solid rgba(247, 213, 119, 0.42);
}

.checkout_city_card.is_selected .checkout_city_check {
  background: #f7d577;
  box-shadow: inset 0 0 0 4px #17120c;
}

.checkout_selected_city {
  display: grid;
  gap: 3px;
  margin-bottom: 13px;
  padding: 11px 12px;
  border: 1px solid rgba(242, 199, 107, 0.16);
  border-radius: 14px;
  background: rgba(247, 213, 119, 0.08);
}

.checkout_selected_city strong {
  color: #fff8e8;
  font-size: 0.92rem;
}

.checkout_selected_city span {
  color: rgba(255, 248, 232, 0.62);
  font-size: 0.78rem;
  line-height: 1.35;
}

.checkout_step_panel.is_locked .checkout_address_fields {
  display: none;
}

.checkout_fields {
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px;
}

.checkout_fields span,
.checkout_city_selector legend {
  margin-bottom: 5px;
  font-size: 12px;
}

.checkout_fields input,
.checkout_fields textarea,
.checkout_fields select {
  min-height: 40px;
  padding: 9px 11px;
  border-radius: 10px;
  font-size: 0.9rem;
}

.checkout_fields textarea {
  min-height: 74px;
}

.checkout_review_cards {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px;
}

.checkout_review_card {
  min-width: 0;
  padding: 11px 12px;
  border: 1px solid rgba(242, 199, 107, 0.14);
  border-radius: 14px;
  background: rgba(255, 248, 232, 0.045);
}

.checkout_review_card span {
  display: block;
  margin-bottom: 5px;
  color: #f7d577;
  font-size: 11px;
  font-weight: 900;
  letter-spacing: 0.06em;
  text-transform: uppercase;
}

.checkout_review_card strong {
  display: block;
  color: #fff8e8;
  font-size: 0.86rem;
  line-height: 1.45;
}

.checkout_payment_panel {
  gap: 12px;
}

.checkout_payment_option {
  position: relative;
  padding: 12px;
  border-radius: 15px;
}

.checkout_payment_option input {
  position: absolute;
  opacity: 0;
  pointer-events: none;
}

.checkout_payment_icon {
  width: 38px;
  height: 38px;
}

.checkout_payment_option strong {
  font-size: 0.92rem;
}

.checkout_payment_option small {
  font-size: 0.78rem;
}

.checkout_total_row {
  align-items: center;
  padding-top: 12px;
  font-size: 0.9rem;
}

.checkout_total_row strong {
  font-size: 1.15rem;
}

.checkout_validation {
  margin: 0 0 12px;
  padding: 9px 11px;
  font-size: 0.86rem;
  line-height: 1.45;
}

.checkout_nav_row {
  display: flex;
  justify-content: space-between;
  gap: 10px;
  margin-top: 14px;
}

.checkout_back_btn,
.checkout_next_btn,
.checkout_confirm_btn {
  min-height: 42px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0 18px;
  border-radius: 999px;
  font-size: 0.9rem;
  font-weight: 900;
  cursor: pointer;
}

.checkout_back_btn {
  border: 1px solid rgba(242, 199, 107, 0.2);
  background: rgba(255, 248, 232, 0.07);
  color: #f7d577;
}

.checkout_next_btn,
.checkout_confirm_btn {
  border: 0;
  background: linear-gradient(135deg, #f7d577, #b9872c);
  color: #16110a;
  box-shadow: 0 14px 28px rgba(242, 199, 107, 0.16);
}

.checkout_back_btn:hover,
.checkout_back_btn:focus {
  background: rgba(247, 213, 119, 0.12);
  color: #ffe6a6;
}

.checkout_next_btn:hover,
.checkout_next_btn:focus,
.checkout_confirm_btn:hover,
.checkout_confirm_btn:focus {
  background: linear-gradient(135deg, #ffe6a6, #d4af37);
  color: #11100e;
}

/* Product details page polish */
body.product-page {
  background: #0f0f0f;
}

body.product-page .product_details_section {
  padding: 56px 0 38px;
  background: radial-gradient(circle at top left, rgba(212, 175, 55, 0.1), transparent 34%), #0f0f0f;
  overflow-x: hidden;
}

body.product-page .product_details_layout {
  align-items: start;
  row-gap: 22px;
}

body.product-page .product_gallery,
body.product-page .product_info_card,
body.product-page .product_story_card,
body.product-page .reviews_summary_card,
body.product-page .reviews_panel,
body.product-page .recommendation_card {
  border-radius: 18px;
  border: 1px solid rgba(242, 199, 107, 0.18);
  background: linear-gradient(180deg, rgba(39, 32, 24, 0.9), rgba(20, 17, 14, 0.94));
  box-shadow: 0 18px 42px rgba(0, 0, 0, 0.24);
}

body.product-page .product_gallery,
body.product-page .product_info_card {
  height: auto;
  min-height: 0;
  padding: 18px;
}

body.product-page .product_main_image {
  height: clamp(280px, 38vw, 430px);
  aspect-ratio: 1 / 1;
  max-height: 430px;
  width: 100%;
  border-radius: 16px;
  background: linear-gradient(180deg, #ffffff, #f3f4f6);
  padding: 18px;
  border: 1px solid rgba(242, 199, 107, 0.12);
}

body.product-page .product_main_image img {
  transform: none;
  object-fit: contain;
}

body.product-page .product_main_image:hover img {
  transform: scale(1.035);
}

body.product-page .product_thumbs {
  margin-top: 12px;
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(64px, 1fr));
  gap: 10px;
}

body.product-page .thumb_btn {
  width: 100%;
  height: 68px;
  border-radius: 12px;
  padding: 7px;
  background: rgba(255, 248, 232, 0.055);
}

body.product-page .thumb_btn img {
  width: 100%;
  height: 100%;
  object-fit: contain;
}

body.product-page .product_info_card {
  gap: 12px;
}

body.product-page .product_info_card h1 {
  margin: 0;
  color: #fff8e8;
  font-size: clamp(1.75rem, 3vw, 2.3rem);
  line-height: 1.12;
  letter-spacing: 0;
}

body.product-page .product_rating_meta {
  width: fit-content;
  max-width: 100%;
  margin: 0;
  padding: 7px 10px;
  border-radius: 999px;
  background: rgba(242, 199, 107, 0.1);
  border: 1px solid rgba(242, 199, 107, 0.16);
  font-size: 13px;
}

body.product-page #productDescription {
  margin: 0;
  color: rgba(255, 248, 232, 0.72);
  font-size: 0.98rem;
  line-height: 1.65;
}

body.product-page .product_meta_section {
  margin-top: 4px;
  padding-top: 14px;
}

body.product-page .product_feature_list,
body.product-page .product_spec_list {
  gap: 8px;
}

body.product-page .product_spec_row {
  min-height: 0;
  padding: 10px 12px;
  border-radius: 12px;
}

body.product-page .product_unit_price,
body.product-page .product_total_price {
  margin: 0;
  padding: 11px 13px;
  border-radius: 13px;
  font-size: 1rem;
}

body.product-page .quantity_wrap {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 14px;
  margin: 0;
  padding-top: 12px;
}

body.product-page .quantity_wrap span {
  margin: 0;
  font-size: 0.95rem;
}

body.product-page .qty_controls {
  min-height: 38px;
  margin: 0;
  flex: 0 0 auto;
}

body.product-page .qty_controls button,
body.product-page .qty_controls input {
  height: 38px;
}

body.product-page .qty_controls button {
  width: 38px;
  font-size: 18px;
}

body.product-page .qty_controls input {
  width: 48px;
}

body.product-page .product_action_row {
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px;
  margin-top: 4px;
}

body.product-page .product_action_row .return_menu_btn,
body.product-page .product_cart_primary_btn,
body.product-page .product_checkout_btn,
body.product-page .product_share_detail_btn {
  min-height: 44px;
  padding: 0 12px;
  border-radius: 13px;
  gap: 7px;
  font-size: 13px;
}

body.product-page .product_action_row i {
  width: 15px;
  min-width: 15px;
  font-size: 14px;
}

body.product-page .product_story_section,
body.product-page .product_reviews_section,
body.product-page .product_recommendations_section {
  padding-bottom: 38px;
  overflow-x: hidden;
}

body.product-page .product_story_card,
body.product-page .reviews_summary_card,
body.product-page .reviews_panel {
  padding: 20px;
}

body.product-page .product_story_card .heading_container h2,
body.product-page .product_recommendations_section .heading_container h2,
body.product-page .reviews_summary_card h2,
body.product-page .reviews_panel_head h3 {
  margin: 0;
  font-size: clamp(1.45rem, 4vw, 2rem);
  line-height: 1.15;
}

body.product-page .product_story_title {
  margin: 12px 0 8px;
  font-size: 1.15rem;
  line-height: 1.35;
}

body.product-page .product_story_lead,
body.product-page .product_story_body,
body.product-page .product_story_body p,
body.product-page .reviews_summary_text,
body.product-page .reviews_panel_head p {
  line-height: 1.6;
}

body.product-page .product_story_body {
  gap: 14px;
}

body.product-page .product_story_block {
  padding-top: 14px;
}

body.product-page .product_reviews_section .row {
  row-gap: 18px;
}

body.product-page .rating_overview {
  margin: 14px 0;
}

body.product-page .rating_overview_score {
  font-size: 2.7rem;
}

body.product-page .review_star_picker {
  gap: 6px;
}

body.product-page .review_star_btn {
  width: 34px;
  height: 34px;
  font-size: 14px;
}

body.product-page .review_field textarea {
  min-height: 108px;
}

body.product-page .reviews_list {
  gap: 12px;
}

body.product-page .review_card {
  border-radius: 14px;
  padding: 14px;
}

body.product-page .product_recommendations_section .heading_container {
  margin-bottom: 18px;
}

body.product-page .product_recommendations_section .heading_container p {
  margin-top: 8px;
  line-height: 1.55;
}

body.product-page #recommendedProducts.recommendations_grid {
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 18px;
}

body.product-page .recommendation_card {
  border-radius: 16px;
  overflow: hidden;
}

body.product-page .recommendation_card_image {
  min-height: 170px;
  height: 170px;
  padding: 16px;
}

body.product-page .recommendation_card_image img {
  max-height: 140px;
}

body.product-page .recommendation_card_body {
  padding: 15px;
  gap: 10px;
}

body.product-page .recommendation_card_label {
  min-height: 24px;
  padding: 0 9px;
  font-size: 10px;
  letter-spacing: 0;
}

body.product-page .recommendation_card_copy h3 {
  font-size: 1rem;
  line-height: 1.25;
}

body.product-page .recommendation_card_copy p {
  margin-top: 6px;
  font-size: 13px;
  line-height: 1.45;
}

body.product-page .recommendation_card_rating {
  gap: 6px;
  font-size: 12px;
}

body.product-page .recommendation_card_footer {
  gap: 10px;
}

body.product-page .recommendation_card_price {
  font-size: 1rem;
}

/* Product details page theme tokens and light-mode readability */
body.product-page {
  --product-page-bg: #fff9ec;
  --product-page-section-bg: linear-gradient(180deg, #fffaf0 0%, #ffffff 54%, #fff8e8 100%);
  --product-page-panel: linear-gradient(180deg, #ffffff, #fffaf0);
  --product-page-panel-solid: #ffffff;
  --product-page-image-bg: linear-gradient(180deg, #ffffff, #f7f3ea);
  --product-page-heading: #1f2733;
  --product-page-text: #303843;
  --product-page-muted: #667085;
  --product-page-card-text: #344054;
  --product-page-price: #7a5200;
  --product-page-label: #8a5c09;
  --product-page-gold: #d4af37;
  --product-page-gold-strong: #b47d19;
  --product-page-border: rgba(180, 125, 25, 0.22);
  --product-page-border-strong: rgba(180, 125, 25, 0.42);
  --product-page-soft: rgba(255, 190, 51, 0.13);
  --product-page-shadow: 0 18px 42px rgba(40, 28, 10, 0.11);
  background: var(--product-page-bg);
}

html[data-theme="dark"] body.product-page,
body.product-page.theme_dark,
body.theme_dark.product-page {
  --product-page-bg: #11100e;
  --product-page-section-bg: radial-gradient(circle at top left, rgba(212, 175, 55, 0.1), transparent 34%), #0f0f0f;
  --product-page-panel: linear-gradient(180deg, rgba(39, 32, 24, 0.9), rgba(20, 17, 14, 0.94));
  --product-page-panel-solid: #1d1915;
  --product-page-image-bg: linear-gradient(180deg, #fffaf0, #f5f2ea);
  --product-page-heading: #fff8e8;
  --product-page-text: #f7f0e2;
  --product-page-muted: #d8cbb8;
  --product-page-card-text: #d7cbb7;
  --product-page-price: #ffe09a;
  --product-page-label: #f2c76b;
  --product-page-gold: #f2c76b;
  --product-page-gold-strong: #ffe09a;
  --product-page-border: rgba(242, 199, 107, 0.18);
  --product-page-border-strong: rgba(245, 192, 78, 0.42);
  --product-page-soft: rgba(242, 199, 107, 0.105);
  --product-page-shadow: 0 22px 50px rgba(0, 0, 0, 0.24);
}

html:not([data-theme="dark"]) body.product-page .product_details_section,
html:not([data-theme="dark"]) body.product-page .product_story_section,
html:not([data-theme="dark"]) body.product-page .product_reviews_section,
html:not([data-theme="dark"]) body.product-page .product_recommendations_section {
  background: var(--product-page-section-bg);
}

html:not([data-theme="dark"]) body.product-page .product_gallery,
html:not([data-theme="dark"]) body.product-page .product_info_card,
html:not([data-theme="dark"]) body.product-page .product_story_card,
html:not([data-theme="dark"]) body.product-page .reviews_summary_card,
html:not([data-theme="dark"]) body.product-page .reviews_panel,
html:not([data-theme="dark"]) body.product-page .recommendation_card,
html:not([data-theme="dark"]) body.product-page .recommendations_empty {
  background: var(--product-page-panel);
  border-color: var(--product-page-border);
  box-shadow: var(--product-page-shadow);
}

html[data-theme="dark"] body.product-page .product_details_section,
html[data-theme="dark"] body.product-page .product_story_section,
html[data-theme="dark"] body.product-page .product_reviews_section,
html[data-theme="dark"] body.product-page .product_recommendations_section,
body.theme_dark.product-page .product_details_section,
body.theme_dark.product-page .product_story_section,
body.theme_dark.product-page .product_reviews_section,
body.theme_dark.product-page .product_recommendations_section {
  background: var(--product-page-section-bg);
}

html[data-theme="dark"] body.product-page .product_gallery,
html[data-theme="dark"] body.product-page .product_info_card,
html[data-theme="dark"] body.product-page .product_story_card,
html[data-theme="dark"] body.product-page .reviews_summary_card,
html[data-theme="dark"] body.product-page .reviews_panel,
html[data-theme="dark"] body.product-page .review_card,
html[data-theme="dark"] body.product-page .review_form,
html[data-theme="dark"] body.product-page .recommendation_card,
body.theme_dark.product-page .product_gallery,
body.theme_dark.product-page .product_info_card,
body.theme_dark.product-page .product_story_card,
body.theme_dark.product-page .reviews_summary_card,
body.theme_dark.product-page .reviews_panel,
body.theme_dark.product-page .review_card,
body.theme_dark.product-page .review_form,
body.theme_dark.product-page .recommendation_card,
body.dark-mode.product-page .product_gallery,
body.dark-mode.product-page .product_info_card,
body.dark-mode.product-page .product_story_card,
body.dark-mode.product-page .reviews_summary_card,
body.dark-mode.product-page .reviews_panel,
body.dark-mode.product-page .review_card,
body.dark-mode.product-page .review_form,
body.dark-mode.product-page .recommendation_card {
  background: #1e1e1e;
  border-color: #333;
  color: #f0f0f0;
}

html[data-theme="dark"] body.product-page .product_main_image,
html[data-theme="dark"] body.product-page .product_lightbox_dialog,
html[data-theme="dark"] body.product-page .product_lightbox_stage,
html[data-theme="dark"] body.product-page .thumb_btn,
html[data-theme="dark"] body.product-page .product_rating_meta,
html[data-theme="dark"] body.product-page .product_spec_row,
html[data-theme="dark"] body.product-page .product_meta_section,
body.theme_dark.product-page .product_main_image,
body.theme_dark.product-page .product_lightbox_dialog,
body.theme_dark.product-page .product_lightbox_stage,
body.theme_dark.product-page .thumb_btn,
body.theme_dark.product-page .product_rating_meta,
body.theme_dark.product-page .product_spec_row,
body.theme_dark.product-page .product_meta_section,
body.dark-mode.product-page .product_main_image,
body.dark-mode.product-page .product_lightbox_dialog,
body.dark-mode.product-page .product_lightbox_stage,
body.dark-mode.product-page .thumb_btn,
body.dark-mode.product-page .product_rating_meta,
body.dark-mode.product-page .product_spec_row,
body.dark-mode.product-page .product_meta_section {
  background: #181818;
  border-color: #333;
}

html[data-theme="dark"] body.product-page .product_info_card h1,
html[data-theme="dark"] body.product-page .product_info_card h2,
html[data-theme="dark"] body.product-page .product_info_card h3,
html[data-theme="dark"] body.product-page .product_story_card h2,
html[data-theme="dark"] body.product-page .product_story_card h3,
html[data-theme="dark"] body.product-page .product_story_card h4,
html[data-theme="dark"] body.product-page .reviews_summary_card h2,
html[data-theme="dark"] body.product-page .reviews_panel h3,
html[data-theme="dark"] body.product-page #productName,
html[data-theme="dark"] body.product-page #productDescription,
html[data-theme="dark"] body.product-page #unitPrice,
html[data-theme="dark"] body.product-page #totalPrice,
html[data-theme="dark"] body.product-page #originalPrice,
html[data-theme="dark"] body.product-page .product_total_price,
html[data-theme="dark"] body.product-page .product_category_label,
html[data-theme="dark"] body.product-page .product_meta_title,
html[data-theme="dark"] body.product-page .product_story_lead,
html[data-theme="dark"] body.product-page .product_story_body,
html[data-theme="dark"] body.product-page .product_story_body p,
html[data-theme="dark"] body.product-page .product_story_list li,
html[data-theme="dark"] body.product-page .product_feature_list li,
html[data-theme="dark"] body.product-page .product_spec_row dt,
html[data-theme="dark"] body.product-page .product_spec_row dd,
html[data-theme="dark"] body.product-page .review_card p,
html[data-theme="dark"] body.product-page .review_card_identity strong,
html[data-theme="dark"] body.product-page .review_card_identity span,
html[data-theme="dark"] body.product-page .reviews_summary_text,
html[data-theme="dark"] body.product-page .recommendation_card_copy h3,
html[data-theme="dark"] body.product-page .recommendation_card_copy h3 a,
html[data-theme="dark"] body.product-page .recommendation_card_price,
body.theme_dark.product-page .product_info_card h1,
body.theme_dark.product-page .product_info_card h2,
body.theme_dark.product-page .product_info_card h3,
body.theme_dark.product-page .product_story_card h2,
body.theme_dark.product-page .product_story_card h3,
body.theme_dark.product-page .product_story_card h4,
body.theme_dark.product-page .reviews_summary_card h2,
body.theme_dark.product-page .reviews_panel h3,
body.theme_dark.product-page #productName,
body.theme_dark.product-page #productDescription,
body.theme_dark.product-page #unitPrice,
body.theme_dark.product-page #totalPrice,
body.theme_dark.product-page #originalPrice,
body.theme_dark.product-page .product_total_price,
body.theme_dark.product-page .product_category_label,
body.theme_dark.product-page .product_meta_title,
body.theme_dark.product-page .product_story_lead,
body.theme_dark.product-page .product_story_body,
body.theme_dark.product-page .product_story_body p,
body.theme_dark.product-page .product_story_list li,
body.theme_dark.product-page .product_feature_list li,
body.theme_dark.product-page .product_spec_row dt,
body.theme_dark.product-page .product_spec_row dd,
body.theme_dark.product-page .review_card p,
body.theme_dark.product-page .review_card_identity strong,
body.theme_dark.product-page .review_card_identity span,
body.theme_dark.product-page .reviews_summary_text,
body.theme_dark.product-page .recommendation_card_copy h3,
body.theme_dark.product-page .recommendation_card_copy h3 a,
body.theme_dark.product-page .recommendation_card_price,
body.dark-mode.product-page .product_info_card h1,
body.dark-mode.product-page .product_info_card h2,
body.dark-mode.product-page .product_info_card h3,
body.dark-mode.product-page .product_story_card h2,
body.dark-mode.product-page .product_story_card h3,
body.dark-mode.product-page .product_story_card h4,
body.dark-mode.product-page .reviews_summary_card h2,
body.dark-mode.product-page .reviews_panel h3,
body.dark-mode.product-page #productName,
body.dark-mode.product-page #productDescription,
body.dark-mode.product-page #unitPrice,
body.dark-mode.product-page #totalPrice,
body.dark-mode.product-page #originalPrice,
body.dark-mode.product-page .product_total_price,
body.dark-mode.product-page .product_category_label,
body.dark-mode.product-page .product_meta_title,
body.dark-mode.product-page .product_story_lead,
body.dark-mode.product-page .product_story_body,
body.dark-mode.product-page .product_story_body p,
body.dark-mode.product-page .product_story_list li,
body.dark-mode.product-page .product_feature_list li,
body.dark-mode.product-page .product_spec_row dt,
body.dark-mode.product-page .product_spec_row dd,
body.dark-mode.product-page .review_card p,
body.dark-mode.product-page .review_card_identity strong,
body.dark-mode.product-page .review_card_identity span,
body.dark-mode.product-page .reviews_summary_text,
body.dark-mode.product-page .recommendation_card_copy h3,
body.dark-mode.product-page .recommendation_card_copy h3 a,
body.dark-mode.product-page .recommendation_card_price {
  color: #f0f0f0;
}

html[data-theme="dark"] body.product-page .product_info_card p,
html[data-theme="dark"] body.product-page .recommendation_card_copy p,
html[data-theme="dark"] body.product-page .recommendation_card_label,
html[data-theme="dark"] body.product-page .recommendation_card_rating,
body.theme_dark.product-page .product_info_card p,
body.theme_dark.product-page .recommendation_card_copy p,
body.theme_dark.product-page .recommendation_card_label,
body.theme_dark.product-page .recommendation_card_rating,
body.dark-mode.product-page .product_info_card p,
body.dark-mode.product-page .recommendation_card_copy p,
body.dark-mode.product-page .recommendation_card_label,
body.dark-mode.product-page .recommendation_card_rating,
html[data-theme="dark"] .food_section .box.product-card .detail-box p,
html[data-theme="dark"] .wishlist_card p,
body.theme_dark .food_section .box.product-card .detail-box p,
body.theme_dark .wishlist_card p,
body.dark-mode .food_section .box.product-card .detail-box p,
body.dark-mode .wishlist_card p {
  color: #cccccc;
}

html[data-theme="dark"] .food_section .box.product-card,
html[data-theme="dark"] .wishlist_card,
html[data-theme="dark"] .recommendation_card,
body.theme_dark .food_section .box.product-card,
body.theme_dark .wishlist_card,
body.theme_dark .recommendation_card,
body.dark-mode .food_section .box.product-card,
body.dark-mode .wishlist_card,
body.dark-mode .recommendation_card {
  background: #1a1a1a;
  border-color: #333;
}

html[data-theme="dark"] .food_section .box.product-card .detail-box h5,
html[data-theme="dark"] .food_section .box.product-card .detail-box h5 a,
html[data-theme="dark"] .food_section .box.product-card .detail-box h6,
html[data-theme="dark"] .food_section .box.product-card .options h6,
html[data-theme="dark"] .wishlist_card h3 a,
html[data-theme="dark"] .wishlist_card_footer strong,
body.theme_dark .food_section .box.product-card .detail-box h5,
body.theme_dark .food_section .box.product-card .detail-box h5 a,
body.theme_dark .food_section .box.product-card .detail-box h6,
body.theme_dark .food_section .box.product-card .options h6,
body.theme_dark .wishlist_card h3 a,
body.theme_dark .wishlist_card_footer strong,
body.dark-mode .food_section .box.product-card .detail-box h5,
body.dark-mode .food_section .box.product-card .detail-box h5 a,
body.dark-mode .food_section .box.product-card .detail-box h6,
body.dark-mode .food_section .box.product-card .options h6,
body.dark-mode .wishlist_card h3 a,
body.dark-mode .wishlist_card_footer strong {
  color: #f0f0f0;
}

html[data-theme="dark"] .food_section .box.product-card .options .product-link-btn,
html[data-theme="dark"] .wishlist_view_btn,
html[data-theme="dark"] .wishlist_add_btn,
html[data-theme="dark"] .wishlist_remove_btn,
html[data-theme="dark"] body.product-page .product_cart_primary_btn,
html[data-theme="dark"] body.product-page .product_checkout_btn,
body.theme_dark .food_section .box.product-card .options .product-link-btn,
body.theme_dark .wishlist_view_btn,
body.theme_dark .wishlist_add_btn,
body.theme_dark .wishlist_remove_btn,
body.theme_dark.product-page .product_cart_primary_btn,
body.theme_dark.product-page .product_checkout_btn,
body.dark-mode .food_section .box.product-card .options .product-link-btn,
body.dark-mode .wishlist_view_btn,
body.dark-mode .wishlist_add_btn,
body.dark-mode .wishlist_remove_btn,
body.dark-mode.product-page .product_cart_primary_btn,
body.dark-mode.product-page .product_checkout_btn {
  background: #2a2a2a;
  color: #f0f0f0;
  border-color: #444;
}

html[data-theme="dark"] .food_section .box.product-card .options .product-link-btn:hover,
html[data-theme="dark"] .wishlist_view_btn:hover,
html[data-theme="dark"] .wishlist_add_btn:hover,
html[data-theme="dark"] .wishlist_remove_btn:hover,
html[data-theme="dark"] body.product-page .product_cart_primary_btn:hover,
html[data-theme="dark"] body.product-page .product_checkout_btn:hover,
body.theme_dark .food_section .box.product-card .options .product-link-btn:hover,
body.theme_dark .wishlist_view_btn:hover,
body.theme_dark .wishlist_add_btn:hover,
body.theme_dark .wishlist_remove_btn:hover,
body.theme_dark.product-page .product_cart_primary_btn:hover,
body.theme_dark.product-page .product_checkout_btn:hover,
body.dark-mode .food_section .box.product-card .options .product-link-btn:hover,
body.dark-mode .wishlist_view_btn:hover,
body.dark-mode .wishlist_add_btn:hover,
body.dark-mode .wishlist_remove_btn:hover,
body.dark-mode.product-page .product_cart_primary_btn:hover,
body.dark-mode.product-page .product_checkout_btn:hover {
  background: #333;
  color: #f0f0f0;
  border-color: #555;
}

html[data-theme="dark"] .footer_section .footer_policy_links a,
html[data-theme="dark"] .about_highlight_panel,
html[data-theme="dark"] .delivery_schedule_panel,
html[data-theme="dark"] .wishlist_empty_btn,
body.theme_dark .footer_section .footer_policy_links a,
body.theme_dark .about_highlight_panel,
body.theme_dark .delivery_schedule_panel,
body.theme_dark .wishlist_empty_btn,
body.dark-mode .footer_section .footer_policy_links a,
body.dark-mode .about_highlight_panel,
body.dark-mode .delivery_schedule_panel,
body.dark-mode .wishlist_empty_btn {
  background-color: #1e1e1e;
  color: #f0f0f0;
  border-color: #333;
}

body.product-page .product_info_card,
body.product-page .product_story_card,
body.product-page .reviews_summary_card,
body.product-page .reviews_panel,
body.product-page .recommendation_card_body {
  color: var(--product-page-text);
}

body.product-page .product_info_card h1,
body.product-page .product_meta_title,
body.product-page .product_story_card .heading_container h2,
body.product-page .product_story_title,
body.product-page .product_story_block h4,
body.product-page .product_recommendations_section .heading_container h2,
body.product-page .reviews_summary_card h2,
body.product-page .reviews_panel_head h3,
body.product-page .rating_overview_score,
body.product-page .review_field label,
body.product-page .review_card_identity strong {
  color: var(--product-page-heading);
}

body.product-page #productDescription,
body.product-page .product_info_card p,
body.product-page .product_story_lead,
body.product-page .product_story_body,
body.product-page .product_story_body p,
body.product-page .product_story_list li,
body.product-page .product_feature_list li,
body.product-page .product_spec_row dd,
body.product-page .reviews_summary_text,
body.product-page .reviews_panel_head p,
body.product-page .review_form_status,
body.product-page .review_card p,
body.product-page .review_card_identity span,
body.product-page .product_recommendations_section .heading_container p,
body.product-page .recommendation_card_copy p,
body.product-page .recommendation_card_rating,
body.product-page .recommendations_empty {
  color: var(--product-page-muted);
}

body.product-page #productDescription,
body.product-page .product_story_lead {
  font-size: 1rem;
  line-height: 1.78;
}

body.product-page .product_story_body p,
body.product-page .product_story_list li,
body.product-page .product_feature_list li {
  font-size: 0.98rem;
  line-height: 1.72;
}

body.product-page .product_gallery,
body.product-page .product_info_card {
  padding: clamp(18px, 2.4vw, 26px);
}

body.product-page .product_main_image,
body.product-page .recommendation_card_image {
  background: var(--product-page-image-bg);
}

body.product-page .thumb_btn {
  background: var(--product-page-panel-solid);
  border-color: var(--product-page-border);
}

html[data-theme="dark"] body.product-page .thumb_btn,
body.theme_dark.product-page .thumb_btn {
  background: rgba(255, 248, 232, 0.055);
}

body.product-page .thumb_btn.active {
  border-color: var(--product-page-gold);
  box-shadow: 0 0 0 3px rgba(212, 175, 55, 0.16);
}

body.product-page .product_rating_meta,
body.product-page .product_unit_price,
body.product-page .product_total_price,
body.product-page .product_spec_row,
body.product-page .review_notice_card {
  background: var(--product-page-soft);
  border-color: var(--product-page-border);
}

body.product-page .product_rating_meta {
  color: var(--product-page-muted);
  line-height: 1.35;
}

body.product-page .product_spec_row {
  gap: 18px;
}

body.product-page .product_spec_row dt,
body.product-page .quantity_wrap span {
  color: var(--product-page-heading);
  font-size: 0.92rem;
  line-height: 1.35;
}

body.product-page .product_spec_row dd {
  color: var(--product-page-card-text);
  font-size: 0.92rem;
  line-height: 1.45;
}

body.product-page .product_unit_price,
body.product-page .product_total_price {
  color: var(--product-page-text) !important;
  line-height: 1.35;
}

body.product-page .product_unit_price span,
body.product-page .product_total_price span,
body.product-page .recommendation_card_price {
  color: var(--product-page-price);
  font-weight: 800;
}

body.product-page .qty_controls {
  background: var(--product-page-panel-solid);
  border-color: var(--product-page-border-strong);
}

body.product-page .qty_controls button {
  background: #222831;
  color: #ffffff;
}

body.product-page .qty_controls input {
  background: #ffffff;
  color: var(--product-page-heading);
}

body.product-page .product_action_row .return_menu_btn,
body.product-page .product_share_detail_btn {
  border: 1px solid rgba(138, 92, 9, 0.58);
  background: linear-gradient(135deg, #2b2114, #7a5200);
  color: #fff8e8;
  opacity: 1;
  text-decoration: none;
  box-shadow: 0 14px 28px rgba(40, 28, 10, 0.22);
  cursor: pointer;
  transition: transform 0.2s ease, box-shadow 0.2s ease, background 0.2s ease, border-color 0.2s ease, color 0.2s ease;
}

body.product-page .product_action_row .return_menu_btn i,
body.product-page .product_share_detail_btn i {
  color: #f2c76b;
}

body.product-page .product_action_row .return_menu_btn:hover,
body.product-page .product_action_row .return_menu_btn:focus,
body.product-page .product_share_detail_btn:hover,
body.product-page .product_share_detail_btn:focus {
  border-color: rgba(180, 125, 25, 0.82);
  background: linear-gradient(135deg, #3a2a14, #9a6b0d);
  color: #ffffff;
  box-shadow: 0 18px 34px rgba(40, 28, 10, 0.28);
  transform: translateY(-2px);
}

body.product-page .product_action_row .return_menu_btn:hover i,
body.product-page .product_action_row .return_menu_btn:focus i,
body.product-page .product_share_detail_btn:hover i,
body.product-page .product_share_detail_btn:focus i {
  color: #ffe09a;
}

html[data-theme="dark"] body.product-page .qty_controls,
body.theme_dark.product-page .qty_controls {
  background: rgba(255, 248, 232, 0.055);
}

html[data-theme="dark"] body.product-page .qty_controls input,
body.theme_dark.product-page .qty_controls input {
  background: rgba(255, 248, 232, 0.08);
  color: var(--product-page-heading);
}

html[data-theme="dark"] body.product-page .product_action_row .return_menu_btn,
html[data-theme="dark"] body.product-page .product_share_detail_btn,
body.theme_dark.product-page .product_action_row .return_menu_btn,
body.theme_dark.product-page .product_share_detail_btn {
  border-color: rgba(242, 199, 107, 0.46);
  background: linear-gradient(135deg, rgba(42, 32, 19, 0.98), rgba(126, 86, 14, 0.94));
  color: #fff8e8;
  box-shadow: 0 16px 32px rgba(0, 0, 0, 0.28);
}

html[data-theme="dark"] body.product-page .product_action_row .return_menu_btn:hover,
html[data-theme="dark"] body.product-page .product_action_row .return_menu_btn:focus,
html[data-theme="dark"] body.product-page .product_share_detail_btn:hover,
html[data-theme="dark"] body.product-page .product_share_detail_btn:focus,
body.theme_dark.product-page .product_action_row .return_menu_btn:hover,
body.theme_dark.product-page .product_action_row .return_menu_btn:focus,
body.theme_dark.product-page .product_share_detail_btn:hover,
body.theme_dark.product-page .product_share_detail_btn:focus {
  border-color: rgba(255, 224, 154, 0.78);
  background: linear-gradient(135deg, rgba(58, 42, 20, 0.98), rgba(154, 107, 13, 0.96));
  color: #ffffff;
}

body.product-page .product_story_card {
  display: grid;
  gap: 14px;
}

body.product-page .product_story_block {
  border-top-color: var(--product-page-border);
}

body.product-page .product_story_block h4 {
  font-family: "Open Sans", sans-serif;
  font-size: 1rem;
  font-weight: 800;
  letter-spacing: 0;
}

/* Dedicated checkout page */
body.checkout-page {
  background:
    radial-gradient(circle at 12% 0%, rgba(212, 175, 55, 0.13), transparent 32%),
    linear-gradient(180deg, #10100f 0%, #17130d 52%, #0f0f0f 100%);
  color: #fff8e8;
}

body.checkout-page .checkout_page_section {
  padding: 42px 0 64px;
}

body.checkout-page .checkout_page_header {
  max-width: 720px;
  margin-bottom: 22px;
}

body.checkout-page .checkout_page_header span,
body.checkout-page .checkout_step_label {
  display: block;
  color: #f2c76b;
  font-size: 12px;
  font-weight: 900;
  letter-spacing: 0.08em;
  line-height: 1.2;
  text-transform: uppercase;
}

body.checkout-page .checkout_page_header h1 {
  margin: 8px 0 8px;
  color: #fff8e8;
  font-family: "Dancing Script", cursive;
  font-size: clamp(2.2rem, 10vw, 4rem);
  line-height: 1;
}

body.checkout-page .checkout_page_header p {
  margin: 0;
  color: rgba(255, 248, 232, 0.72);
  font-size: 1rem;
  line-height: 1.7;
}

body.checkout-page .checkout_page_shell,
body.checkout-page .checkout_page_empty,
body.checkout-page .checkout_page_loading {
  border: 1px solid rgba(242, 199, 107, 0.22);
  border-radius: 22px;
  background: linear-gradient(180deg, rgba(39, 32, 24, 0.95), rgba(18, 15, 12, 0.96));
  box-shadow: 0 24px 60px rgba(0, 0, 0, 0.3);
}

body.checkout-page .checkout_page_shell {
  padding: 14px;
}

body.checkout-page .checkout_page_empty,
body.checkout-page .checkout_page_loading {
  display: grid;
  justify-items: center;
  gap: 10px;
  padding: 32px 18px;
  text-align: center;
}

body.checkout-page .checkout_page_empty[hidden],
body.checkout-page .checkout_page_loading[hidden] {
  display: none;
}

body.checkout-page .checkout_page_empty_icon,
body.checkout-page .checkout_page_loading_icon {
  width: 58px;
  height: 58px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 18px;
  background: rgba(242, 199, 107, 0.14);
  color: #f2c76b;
  font-size: 24px;
}

body.checkout-page .checkout_page_empty h2,
body.checkout-page .checkout_page_loading h2 {
  margin: 4px 0 0;
  color: #fff8e8;
  font-size: 1.35rem;
}

body.checkout-page .checkout_page_empty p,
body.checkout-page .checkout_page_loading p {
  margin: 0;
  color: rgba(255, 248, 232, 0.7);
}

body.checkout-page .checkout_menu_btn {
  min-height: 44px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  margin-top: 8px;
  padding: 0 20px;
  border-radius: 999px;
  background: linear-gradient(135deg, #f7d577, #b9872c);
  color: #16110a;
  font-weight: 900;
}

body.checkout-page .checkout_steps {
  display: grid;
  grid-template-columns: 1fr;
  gap: 8px;
  margin: 0 0 14px;
  padding: 0;
  list-style: none;
}

body.checkout-page .checkout_step {
  min-width: 0;
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 10px;
  border-radius: 14px;
  border: 1px solid rgba(242, 199, 107, 0.14);
  background: rgba(255, 248, 232, 0.045);
  color: rgba(255, 248, 232, 0.62);
  font-size: 12px;
  font-weight: 900;
  line-height: 1.2;
}

body.checkout-page .checkout_step_number {
  width: 28px;
  height: 28px;
  flex: 0 0 28px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 999px;
  background: rgba(255, 248, 232, 0.08);
  color: inherit;
}

body.checkout-page .checkout_step.is_active {
  border-color: rgba(247, 213, 119, 0.52);
  background: rgba(247, 213, 119, 0.13);
  color: #fff8e8;
}

body.checkout-page .checkout_step.is_complete {
  border-color: rgba(247, 213, 119, 0.34);
  color: #f7d577;
}

body.checkout-page .checkout_step.is_active .checkout_step_number,
body.checkout-page .checkout_step.is_complete .checkout_step_number {
  background: linear-gradient(135deg, #f7d577, #b9872c);
  color: #16110a;
}

body.checkout-page .checkout_page_form,
body.checkout-page .checkout_page_panel {
  min-width: 0;
}

body.checkout-page .checkout_page_panel[hidden] {
  display: none;
}

body.checkout-page .checkout_page_panel {
  padding: 16px;
  border-radius: 18px;
  background: rgba(255, 248, 232, 0.055);
}

body.checkout-page .checkout_panel_head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 12px;
  margin-bottom: 14px;
}

body.checkout-page .checkout_panel_head h2 {
  margin: 4px 0 0;
  color: #fff8e8;
  font-size: 1.16rem;
  line-height: 1.25;
}

body.checkout-page .checkout_panel_head > strong,
body.checkout-page .checkout_total_row strong {
  color: #f7d577;
  font-size: 1.05rem;
  line-height: 1.3;
  white-space: nowrap;
}

body.checkout-page .checkout_cart_items {
  display: grid;
  gap: 10px;
}

body.checkout-page .checkout_cart_item {
  display: grid;
  grid-template-columns: 72px minmax(0, 1fr);
  gap: 12px;
  padding: 10px;
  border: 1px solid rgba(242, 199, 107, 0.14);
  border-radius: 16px;
  background: rgba(16, 13, 10, 0.62);
}

body.checkout-page .checkout_cart_item_image {
  width: 72px;
  height: 72px;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 14px;
  background: #fffaf0;
  overflow: hidden;
}

body.checkout-page .checkout_cart_item_image img {
  width: 100%;
  height: 100%;
  object-fit: contain;
  padding: 6px;
}

body.checkout-page .checkout_cart_item_body {
  min-width: 0;
  display: grid;
  gap: 8px;
}

body.checkout-page .checkout_cart_item_head {
  min-width: 0;
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 8px;
}

body.checkout-page .checkout_cart_item_head a {
  min-width: 0;
  color: #fff8e8;
  font-size: 0.95rem;
  font-weight: 900;
  line-height: 1.35;
}

body.checkout-page .checkout_item_remove {
  flex: 0 0 auto;
  min-height: 30px;
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 0 10px;
  border: 1px solid rgba(255, 119, 119, 0.34);
  border-radius: 999px;
  background: rgba(255, 119, 119, 0.1);
  color: #ffd6d6;
  font-size: 12px;
  font-weight: 800;
  cursor: pointer;
}

body.checkout-page .checkout_item_remove i {
  color: #ffb4b4;
}

body.checkout-page .checkout_cart_item_meta {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  color: rgba(255, 248, 232, 0.68);
  font-size: 0.86rem;
}

body.checkout-page .checkout_cart_item_meta strong {
  color: #f7d577;
  font-size: 0.95rem;
}

body.checkout-page .checkout_item_qty {
  display: inline-flex;
  align-items: center;
  justify-self: start;
  border: 1px solid rgba(242, 199, 107, 0.26);
  border-radius: 999px;
  overflow: hidden;
  background: rgba(255, 248, 232, 0.055);
}

body.checkout-page .checkout_item_qty button,
body.checkout-page .checkout_item_qty span {
  min-width: 34px;
  height: 32px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
}

body.checkout-page .checkout_item_qty button {
  border: 0;
  background: rgba(242, 199, 107, 0.14);
  color: #fff8e8;
  font-size: 18px;
  line-height: 1;
  cursor: pointer;
}

body.checkout-page .checkout_item_qty span {
  color: #fff8e8;
  font-weight: 900;
}

body.checkout-page .checkout_total_row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  margin-top: 16px;
  padding-top: 14px;
  border-top: 1px solid rgba(242, 199, 107, 0.16);
  color: rgba(255, 248, 232, 0.76);
  font-weight: 800;
}

body.checkout-page .checkout_city_selector {
  margin: 0;
  border: 0;
  padding: 0;
}

body.checkout-page .checkout_city_selector legend {
  margin-bottom: 10px;
  color: #f2c76b;
  font-size: 12px;
  font-weight: 900;
  letter-spacing: 0.06em;
  text-transform: uppercase;
}

body.checkout-page .checkout_city_options {
  display: grid;
  grid-template-columns: 1fr;
  gap: 10px;
}

body.checkout-page .checkout_city_card {
  min-height: 58px;
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 12px;
  border: 1px solid rgba(242, 199, 107, 0.18);
  border-radius: 15px;
  background: rgba(16, 13, 10, 0.56);
  color: #fff8e8;
  cursor: pointer;
}

body.checkout-page .checkout_city_card input {
  position: absolute;
  opacity: 0;
  pointer-events: none;
}

body.checkout-page .checkout_city_card strong {
  color: #fff8e8;
  font-size: 0.96rem;
}

body.checkout-page .checkout_city_check {
  width: 20px;
  height: 20px;
  flex: 0 0 20px;
  border: 2px solid rgba(247, 213, 119, 0.48);
  border-radius: 50%;
}

body.checkout-page .checkout_city_card.is_selected {
  border-color: rgba(247, 213, 119, 0.68);
  background: rgba(247, 213, 119, 0.12);
}

body.checkout-page .checkout_city_card.is_selected .checkout_city_check {
  background: #f7d577;
  box-shadow: inset 0 0 0 4px #17120c;
}

body.checkout-page .checkout_selected_city {
  display: grid;
  gap: 3px;
  margin-bottom: 14px;
  padding: 12px;
  border: 1px solid rgba(242, 199, 107, 0.18);
  border-radius: 15px;
  background: rgba(247, 213, 119, 0.08);
}

body.checkout-page .checkout_selected_city strong {
  color: #fff8e8;
}

body.checkout-page .checkout_selected_city span {
  color: rgba(255, 248, 232, 0.62);
  font-size: 0.84rem;
  line-height: 1.45;
}

body.checkout-page .checkout_saved_address_bar {
  display: grid;
  gap: 10px;
  margin-bottom: 14px;
  padding: 12px;
  border: 1px solid rgba(247, 213, 119, 0.22);
  border-radius: 15px;
  background: rgba(16, 13, 10, 0.5);
}

body.checkout-page .checkout_saved_address_bar[hidden],
body.checkout-page .checkout_clear_saved_btn[hidden] {
  display: none;
}

body.checkout-page .checkout_saved_address_bar span {
  color: rgba(255, 248, 232, 0.78);
  font-size: 0.86rem;
  font-weight: 800;
  line-height: 1.45;
}

body.checkout-page .checkout_clear_saved_btn {
  min-height: 38px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  justify-self: start;
  padding: 0 14px;
  border: 1px solid rgba(242, 199, 107, 0.28);
  border-radius: 999px;
  background: rgba(255, 248, 232, 0.07);
  color: #f7d577;
  font-size: 0.84rem;
  font-weight: 900;
  cursor: pointer;
}

body.checkout-page .checkout_clear_saved_btn:hover,
body.checkout-page .checkout_clear_saved_btn:focus {
  background: rgba(247, 213, 119, 0.12);
  color: #ffe6a6;
}

body.checkout-page .checkout_fields {
  display: grid;
  grid-template-columns: 1fr;
  gap: 12px;
}

body.checkout-page .checkout_fields label {
  min-width: 0;
  display: grid;
  gap: 6px;
}

body.checkout-page .checkout_fields span {
  color: #f2c76b;
  font-size: 12px;
  font-weight: 900;
}

body.checkout-page .checkout_fields em {
  color: rgba(255, 248, 232, 0.52);
  font-style: normal;
  font-weight: 700;
}

body.checkout-page .checkout_fields input,
body.checkout-page .checkout_fields textarea {
  width: 100%;
  min-height: 44px;
  border: 1px solid rgba(242, 199, 107, 0.2);
  border-radius: 12px;
  background: rgba(16, 13, 10, 0.62);
  color: #fff8e8;
  padding: 10px 12px;
  outline: none;
}

body.checkout-page .checkout_fields textarea {
  min-height: 84px;
  resize: vertical;
}

body.checkout-page .checkout_fields input:focus,
body.checkout-page .checkout_fields textarea:focus {
  border-color: rgba(247, 213, 119, 0.7);
  box-shadow: 0 0 0 3px rgba(247, 213, 119, 0.12);
}

body.checkout-page .checkout_review_cards {
  display: grid;
  grid-template-columns: 1fr;
  gap: 10px;
  margin-bottom: 12px;
}

body.checkout-page .checkout_review_card {
  min-width: 0;
  padding: 12px;
  border: 1px solid rgba(242, 199, 107, 0.15);
  border-radius: 15px;
  background: rgba(16, 13, 10, 0.56);
}

body.checkout-page .checkout_review_card span {
  display: block;
  margin-bottom: 6px;
  color: #f2c76b;
  font-size: 11px;
  font-weight: 900;
  letter-spacing: 0.06em;
  text-transform: uppercase;
}

body.checkout-page .checkout_review_card strong {
  display: block;
  color: #fff8e8;
  font-size: 0.92rem;
  line-height: 1.5;
}

body.checkout-page .checkout_payment_option {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 12px;
  border: 1px solid rgba(247, 213, 119, 0.36);
  border-radius: 16px;
  background: rgba(247, 213, 119, 0.1);
}

body.checkout-page .checkout_payment_option input {
  position: absolute;
  opacity: 0;
  pointer-events: none;
}

body.checkout-page .checkout_payment_icon {
  width: 42px;
  height: 42px;
  flex: 0 0 42px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 14px;
  background: linear-gradient(135deg, #f7d577, #b9872c);
  color: #16110a;
  font-size: 18px;
}

body.checkout-page .checkout_payment_option strong,
body.checkout-page .checkout_payment_option small {
  display: block;
}

body.checkout-page .checkout_payment_option strong {
  color: #fff8e8;
  font-size: 0.98rem;
}

body.checkout-page .checkout_payment_option small {
  margin-top: 2px;
  color: rgba(255, 248, 232, 0.64);
  font-size: 0.82rem;
  line-height: 1.45;
}

body.checkout-page .checkout_validation {
  margin: 0 0 12px;
  padding: 10px 12px;
  border: 1px solid rgba(255, 119, 119, 0.26);
  border-radius: 14px;
  background: rgba(255, 119, 119, 0.1);
  color: #ffd6d6;
  font-weight: 800;
  line-height: 1.45;
}

body.checkout-page .checkout_validation[hidden] {
  display: none;
}

body.checkout-page .checkout_nav_row {
  display: grid;
  grid-template-columns: 1fr;
  gap: 10px;
  margin-top: 16px;
}

body.checkout-page .checkout_back_btn,
body.checkout-page .checkout_next_btn,
body.checkout-page .checkout_confirm_btn {
  min-height: 44px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0 18px;
  border-radius: 999px;
  font-weight: 900;
  text-align: center;
  cursor: pointer;
}

body.checkout-page .checkout_back_btn {
  border: 1px solid rgba(242, 199, 107, 0.24);
  background: rgba(255, 248, 232, 0.07);
  color: #f7d577;
}

body.checkout-page .checkout_next_btn,
body.checkout-page .checkout_confirm_btn {
  border: 0;
  background: linear-gradient(135deg, #f7d577, #b9872c);
  color: #16110a;
  box-shadow: 0 14px 28px rgba(242, 199, 107, 0.16);
}

body.checkout-page .checkout_back_btn:hover,
body.checkout-page .checkout_back_btn:focus {
  background: rgba(247, 213, 119, 0.12);
  color: #ffe6a6;
}

body.checkout-page .checkout_next_btn:hover,
body.checkout-page .checkout_next_btn:focus,
body.checkout-page .checkout_confirm_btn:hover,
body.checkout-page .checkout_confirm_btn:focus,
body.checkout-page .checkout_menu_btn:hover,
body.checkout-page .checkout_menu_btn:focus {
  background: linear-gradient(135deg, #ffe6a6, #d4af37);
  color: #11100e;
}

body.checkout-page .checkout_back_btn:disabled,
body.checkout-page .checkout_next_btn:disabled,
body.checkout-page .checkout_confirm_btn:disabled {
  cursor: wait;
  opacity: 0.68;
}

body.checkout-page .checkout_confirm_btn.is_loading {
  gap: 9px;
}

body.checkout-page .checkout_confirm_btn.is_loading::before {
  width: 16px;
  height: 16px;
  content: "";
  border: 2px solid rgba(22, 17, 10, 0.24);
  border-top-color: #16110a;
  border-radius: 999px;
  animation: checkout_button_spin 0.75s linear infinite;
}

@keyframes checkout_button_spin {
  to {
    transform: rotate(360deg);
  }
}

/* Paymob result pages */
body.payment-result-page {
  background:
    radial-gradient(circle at 12% 0%, rgba(255, 190, 51, 0.16), transparent 32%),
    linear-gradient(180deg, #fffaf0 0%, #f7efe2 54%, #fffdf8 100%);
  color: #1a1a1a;
}

body.payment-result-page .payment_result_section {
  padding: 48px 0 70px;
}

body.payment-result-page .payment_result_card {
  max-width: 760px;
  margin: 0 auto;
  padding: 28px;
  border: 1px solid rgba(166, 113, 24, 0.18);
  border-radius: 22px;
  background: #ffffff;
  box-shadow: 0 24px 58px rgba(68, 46, 17, 0.12);
  text-align: center;
}

body.payment-result-page .payment_result_icon {
  width: 64px;
  height: 64px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  margin-bottom: 14px;
  border-radius: 20px;
  color: #10100f;
  font-size: 28px;
}

body.payment-success-page .payment_result_icon {
  background: linear-gradient(135deg, #86efac, #22c55e);
}

body.payment-failed-page .payment_result_icon {
  background: linear-gradient(135deg, #fecaca, #ef4444);
}

body.payment-result-page .payment_result_kicker {
  display: block;
  color: #f2c76b;
  font-size: 12px;
  font-weight: 900;
  letter-spacing: 0.08em;
  line-height: 1.2;
  text-transform: uppercase;
}

body.payment-result-page .payment_result_card h1 {
  margin: 10px 0 10px;
  color: #1a1a1a;
  font-family: "Dancing Script", cursive;
  font-size: clamp(2.2rem, 10vw, 4rem);
  line-height: 1;
}

body.payment-result-page .payment_result_card p {
  max-width: 610px;
  margin: 0 auto 18px;
  color: #6f6251;
  font-size: 1rem;
  line-height: 1.7;
}

body.payment-result-page .payment_result_meta {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px;
  margin: 22px 0;
  text-align: left;
}

body.payment-result-page .payment_result_meta div {
  min-width: 0;
  padding: 14px;
  border: 1px solid rgba(166, 113, 24, 0.18);
  border-radius: 16px;
  background: #fff9ef;
}

body.payment-result-page .payment_result_meta dt {
  margin-bottom: 7px;
  color: #6f6251;
  font-size: 12px;
  font-weight: 900;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

body.payment-result-page .payment_result_meta dd {
  margin: 0;
  color: #8f6200;
  font-weight: 900;
  overflow-wrap: anywhere;
}

body.payment-result-page .payment_result_actions {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px;
}

body.payment-result-page .payment_result_primary,
body.payment-result-page .payment_result_secondary {
  min-height: 44px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0 18px;
  border-radius: 999px;
  font-weight: 900;
  text-align: center;
}

body.payment-result-page .payment_result_primary {
  background: linear-gradient(135deg, #f7d577, #b9872c);
  color: #16110a;
}

body.payment-result-page .payment_result_secondary {
  border: 1px solid rgba(166, 113, 24, 0.18);
  background: #fff8ec;
  color: #7a5200;
}

body.payment-result-page .payment_result_primary:hover,
body.payment-result-page .payment_result_primary:focus {
  background: linear-gradient(135deg, #ffe6a6, #d4af37);
  color: #11100e;
}

body.payment-result-page .payment_result_secondary:hover,
body.payment-result-page .payment_result_secondary:focus {
  background: rgba(255, 190, 51, 0.16);
  color: #1a1a1a;
}

html[data-theme="dark"] body.payment-result-page,
body.dark-mode.payment-result-page {
  background:
    radial-gradient(circle at 12% 0%, rgba(212, 175, 55, 0.13), transparent 32%),
    linear-gradient(180deg, #10100f 0%, #17130d 52%, #0f0f0f 100%);
  color: #fff8e8;
}

html[data-theme="dark"] body.payment-result-page .payment_result_card,
body.dark-mode.payment-result-page .payment_result_card {
  border-color: rgba(242, 199, 107, 0.22);
  background: linear-gradient(180deg, rgba(39, 32, 24, 0.96), rgba(18, 15, 12, 0.98));
  box-shadow: 0 24px 60px rgba(0, 0, 0, 0.3);
}

html[data-theme="dark"] body.payment-result-page .payment_result_card h1,
body.dark-mode.payment-result-page .payment_result_card h1 {
  color: #fff8e8;
}

html[data-theme="dark"] body.payment-result-page .payment_result_card p,
body.dark-mode.payment-result-page .payment_result_card p {
  color: rgba(255, 248, 232, 0.74);
}

html[data-theme="dark"] body.payment-result-page .payment_result_meta div,
body.dark-mode.payment-result-page .payment_result_meta div {
  border-color: rgba(242, 199, 107, 0.14);
  background: rgba(255, 248, 232, 0.055);
}

html[data-theme="dark"] body.payment-result-page .payment_result_meta dt,
body.dark-mode.payment-result-page .payment_result_meta dt {
  color: rgba(255, 248, 232, 0.62);
}

html[data-theme="dark"] body.payment-result-page .payment_result_meta dd,
body.dark-mode.payment-result-page .payment_result_meta dd {
  color: #f7d577;
}

html[data-theme="dark"] body.payment-result-page .payment_result_secondary,
body.dark-mode.payment-result-page .payment_result_secondary {
  border-color: rgba(242, 199, 107, 0.24);
  background: rgba(255, 248, 232, 0.07);
  color: #f7d577;
}

html[data-theme="dark"] body.payment-result-page .payment_result_secondary:hover,
html[data-theme="dark"] body.payment-result-page .payment_result_secondary:focus,
body.dark-mode.payment-result-page .payment_result_secondary:hover,
body.dark-mode.payment-result-page .payment_result_secondary:focus {
  background: rgba(247, 213, 119, 0.12);
  color: #ffe6a6;
}

@media (max-width: 575px) {
  body.payment-result-page .payment_result_card {
    padding: 22px 16px;
  }

  body.payment-result-page .payment_result_meta,
  body.payment-result-page .payment_result_actions {
    grid-template-columns: 1fr;
  }
}

/* Customer-visible orders page */
body.orders-page {
  background:
    radial-gradient(circle at 12% 0%, rgba(212, 175, 55, 0.13), transparent 32%),
    linear-gradient(180deg, #10100f 0%, #17130d 52%, #0f0f0f 100%);
  color: #fff8e8;
}

body.orders-page .orders_page_section {
  padding: 42px 0 64px;
}

body.orders-page .orders_page_header {
  max-width: 760px;
  margin-bottom: 22px;
}

body.orders-page .orders_page_header span {
  display: block;
  color: #f2c76b;
  font-size: 12px;
  font-weight: 900;
  letter-spacing: 0.08em;
  line-height: 1.2;
  text-transform: uppercase;
}

body.orders-page .orders_page_header h1 {
  margin: 8px 0;
  color: #fff8e8;
  font-family: "Dancing Script", cursive;
  font-size: clamp(2.2rem, 10vw, 4rem);
  line-height: 1;
}

body.orders-page .orders_page_header p {
  margin: 0;
  color: rgba(255, 248, 232, 0.72);
  font-size: 1rem;
  line-height: 1.7;
}

body.orders-page .orders_page_shell {
  padding: 14px;
  border: 1px solid rgba(242, 199, 107, 0.22);
  border-radius: 22px;
  background: linear-gradient(180deg, rgba(39, 32, 24, 0.95), rgba(18, 15, 12, 0.96));
  box-shadow: 0 24px 60px rgba(0, 0, 0, 0.3);
}

body.orders-page .orders_state {
  display: grid;
  justify-items: center;
  gap: 10px;
  padding: 32px 18px;
  text-align: center;
}

body.orders-page .orders_state[hidden],
body.orders-page .orders_list[hidden] {
  display: none;
}

body.orders-page .orders_state_icon {
  width: 58px;
  height: 58px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 18px;
  background: rgba(242, 199, 107, 0.14);
  color: #f2c76b;
  font-size: 24px;
}

body.orders-page .orders_state:first-child .orders_state_icon i {
  animation: checkout_button_spin 0.9s linear infinite;
}

body.orders-page .orders_state h2 {
  margin: 4px 0 0;
  color: #fff8e8;
  font-size: 1.35rem;
}

body.orders-page .orders_state p,
body.orders-page .orders_item_empty,
body.orders-page .orders_item_more {
  margin: 0;
  color: rgba(255, 248, 232, 0.7);
  line-height: 1.55;
}

body.orders-page .orders_state_error {
  border: 1px solid rgba(255, 119, 119, 0.28);
  border-radius: 16px;
  background: rgba(255, 119, 119, 0.1);
  color: #ffd6d6;
  font-weight: 800;
}

body.orders-page .orders_primary_link {
  min-height: 44px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  margin-top: 8px;
  padding: 0 20px;
  border-radius: 999px;
  background: linear-gradient(135deg, #f7d577, #b9872c);
  color: #16110a;
  font-weight: 900;
}

body.orders-page .orders_list {
  display: grid;
  gap: 12px;
}

body.orders-page .orders_card {
  min-width: 0;
  padding: 16px;
  border: 1px solid rgba(242, 199, 107, 0.16);
  border-radius: 16px;
  background: rgba(255, 248, 232, 0.055);
}

body.orders-page .orders_card_head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 14px;
}

body.orders-page .orders_card_head span,
body.orders-page .orders_meta span {
  display: block;
  color: #f2c76b;
  font-size: 11px;
  font-weight: 900;
  letter-spacing: 0.06em;
  text-transform: uppercase;
}

body.orders-page .orders_card_head h2 {
  margin: 6px 0 0;
  color: #fff8e8;
  font-size: 1rem;
  line-height: 1.35;
  overflow-wrap: anywhere;
}

body.orders-page .orders_card_head > strong {
  flex: 0 0 auto;
  color: #f7d577;
  font-size: 1.08rem;
}

body.orders-page .orders_badges,
body.orders-page .orders_meta {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: 14px;
}

body.orders-page .orders_badge {
  display: inline-flex;
  min-height: 30px;
  align-items: center;
  padding: 0 11px;
  border-radius: 999px;
  border: 1px solid rgba(242, 199, 107, 0.24);
  color: #fff8e8;
  font-size: 12px;
  font-weight: 900;
  text-transform: capitalize;
}

body.orders-page .orders_badge_payment {
  background: rgba(247, 213, 119, 0.1);
}

body.orders-page .orders_badge_order {
  background: rgba(247, 213, 119, 0.1);
}

body.orders-page .orders_badge_paid,
body.orders-page .orders_badge_delivered {
  border-color: rgba(34, 197, 94, 0.28);
  background: rgba(34, 197, 94, 0.13);
}

body.orders-page .orders_badge_failed,
body.orders-page .orders_badge_cancelled {
  border-color: rgba(255, 119, 119, 0.34);
  background: rgba(255, 119, 119, 0.12);
  color: #ffd6d6;
}

body.orders-page .orders_badge_out_for_delivery {
  border-color: rgba(96, 165, 250, 0.32);
  background: rgba(96, 165, 250, 0.12);
}

body.orders-page .orders_meta {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

body.orders-page .orders_meta div {
  min-width: 0;
  padding: 12px;
  border: 1px solid rgba(242, 199, 107, 0.14);
  border-radius: 14px;
  background: rgba(16, 13, 10, 0.46);
}

body.orders-page .orders_meta strong {
  display: block;
  margin-top: 6px;
  color: #fff8e8;
  font-size: 0.92rem;
  line-height: 1.4;
  text-transform: capitalize;
}

body.orders-page .orders_item_list {
  display: grid;
  gap: 8px;
  margin: 14px 0 0;
  padding: 0;
  list-style: none;
}

body.orders-page .orders_item_list li {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  color: rgba(255, 248, 232, 0.76);
  line-height: 1.45;
}

body.orders-page .orders_item_list strong {
  color: #f7d577;
}

body.orders-page .orders_item_empty,
body.orders-page .orders_item_more {
  margin-top: 12px;
}

@media (max-width: 575px) {
  body.orders-page .orders_card {
    padding: 14px;
  }

  body.orders-page .orders_card_head,
  body.orders-page .orders_meta {
    grid-template-columns: 1fr;
  }

  body.orders-page .orders_card_head {
    display: grid;
  }

  body.orders-page .orders_card_head > strong {
    justify-self: start;
  }
}

/* Admin orders dashboard */
body.admin-orders-page .admin_orders_section {
  padding: 42px 0 68px;
}

body.admin-orders-page .admin_orders_header {
  max-width: 860px;
}

body.admin-orders-page .admin_orders_shell {
  border-radius: 20px;
}

body.admin-orders-page .admin_orders_dashboard[hidden],
body.admin-orders-page .admin_orders_list[hidden] {
  display: none;
}

body.admin-orders-page .admin_orders_dashboard {
  display: grid;
  gap: 16px;
}

body.admin-orders-page .admin_orders_toolbar {
  display: grid;
  gap: 14px;
}

body.admin-orders-page .admin_orders_stats {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 10px;
}

body.admin-orders-page .admin_orders_stats div {
  min-width: 0;
  padding: 14px;
  border: 1px solid rgba(242, 199, 107, 0.16);
  border-radius: 14px;
  background: rgba(16, 13, 10, 0.5);
}

body.admin-orders-page .admin_orders_stats span,
body.admin-orders-page .admin_order_head span,
body.admin-orders-page .admin_order_meta span,
body.admin-orders-page .admin_order_items_block > span,
body.admin-orders-page .admin_order_status_form span {
  display: block;
  color: #f2c76b;
  font-size: 11px;
  font-weight: 900;
  letter-spacing: 0.06em;
  line-height: 1.2;
  text-transform: uppercase;
}

body.admin-orders-page .admin_orders_stats strong {
  display: block;
  margin-top: 6px;
  color: #fff8e8;
  font-size: 1.35rem;
  line-height: 1.2;
}

body.admin-orders-page .admin_orders_filters {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

body.admin-orders-page .admin_orders_filters button,
body.admin-orders-page .admin_order_status_form button {
  min-height: 40px;
  border: 1px solid rgba(242, 199, 107, 0.24);
  border-radius: 999px;
  background: rgba(255, 248, 232, 0.06);
  color: #fff8e8;
  font-size: 13px;
  font-weight: 900;
  transition: background 0.2s ease, border-color 0.2s ease, color 0.2s ease;
}

body.admin-orders-page .admin_orders_filters button {
  padding: 0 14px;
}

body.admin-orders-page .admin_orders_filters button:hover,
body.admin-orders-page .admin_orders_filters button:focus,
body.admin-orders-page .admin_orders_filters button.is_active {
  border-color: rgba(247, 213, 119, 0.72);
  background: linear-gradient(135deg, #f7d577, #b9872c);
  color: #16110a;
}

body.admin-orders-page .admin_orders_list {
  display: grid;
  gap: 14px;
}

body.admin-orders-page .admin_order_card {
  min-width: 0;
  padding: 16px;
  border: 1px solid rgba(242, 199, 107, 0.16);
  border-radius: 16px;
  background: rgba(255, 248, 232, 0.055);
}

body.admin-orders-page .admin_order_head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 14px;
}

body.admin-orders-page .admin_order_head h2 {
  margin: 6px 0 0;
  color: #fff8e8;
  font-size: 1rem;
  line-height: 1.35;
  overflow-wrap: anywhere;
}

body.admin-orders-page .admin_order_head > strong {
  flex: 0 0 auto;
  color: #f7d577;
  font-size: 1.1rem;
  line-height: 1.35;
}

body.admin-orders-page .admin_order_meta {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 10px;
  margin-top: 14px;
}

body.admin-orders-page .admin_order_meta div,
body.admin-orders-page .admin_order_items_block {
  min-width: 0;
  padding: 12px;
  border: 1px solid rgba(242, 199, 107, 0.14);
  border-radius: 14px;
  background: rgba(16, 13, 10, 0.46);
}

body.admin-orders-page .admin_order_meta .admin_order_meta_full {
  grid-column: span 2;
}

body.admin-orders-page .admin_order_meta strong {
  display: block;
  margin-top: 6px;
  color: #fff8e8;
  font-size: 0.92rem;
  line-height: 1.45;
  overflow-wrap: anywhere;
}

body.admin-orders-page .admin_order_items_block {
  margin-top: 14px;
}

body.admin-orders-page .admin_order_items {
  display: grid;
  gap: 8px;
  margin: 10px 0 0;
  padding: 0;
  list-style: none;
}

body.admin-orders-page .admin_order_items li {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 12px;
  color: rgba(255, 248, 232, 0.76);
  line-height: 1.45;
}

body.admin-orders-page .admin_order_items strong {
  flex: 0 0 auto;
  color: #f7d577;
  font-size: 0.9rem;
}

body.admin-orders-page .admin_order_status_form {
  display: flex;
  align-items: flex-end;
  gap: 10px;
  margin-top: 14px;
}

body.admin-orders-page .admin_order_status_form label {
  flex: 1 1 260px;
  min-width: 0;
  margin: 0;
}

body.admin-orders-page .admin_order_status_form select {
  width: 100%;
  min-height: 42px;
  margin-top: 7px;
  padding: 0 42px 0 13px;
  border: 1px solid rgba(242, 199, 107, 0.26);
  border-radius: 12px;
  background: #18130d;
  color: #fff8e8;
  font-weight: 800;
}

body.admin-orders-page .admin_order_status_form button {
  min-width: 118px;
  padding: 0 18px;
  background: linear-gradient(135deg, #f7d577, #b9872c);
  color: #16110a;
}

body.admin-orders-page .admin_order_status_form button:disabled {
  cursor: not-allowed;
  border-color: rgba(242, 199, 107, 0.14);
  background: rgba(255, 248, 232, 0.08);
  color: rgba(255, 248, 232, 0.56);
}

@media (max-width: 991px) {
  body.admin-orders-page .admin_order_meta {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 575px) {
  body.admin-orders-page .admin_orders_stats,
  body.admin-orders-page .admin_order_meta {
    grid-template-columns: 1fr;
  }

  body.admin-orders-page .admin_order_meta .admin_order_meta_full {
    grid-column: auto;
  }

  body.admin-orders-page .admin_order_head,
  body.admin-orders-page .admin_order_status_form,
  body.admin-orders-page .admin_order_items li {
    display: grid;
  }

  body.admin-orders-page .admin_order_head > strong,
  body.admin-orders-page .admin_order_items strong {
    justify-self: start;
  }

  body.admin-orders-page .admin_order_status_form button {
    width: 100%;
  }
}

/* Dedicated cart page */
body.cart-page {
  background:
    radial-gradient(circle at 12% 0%, rgba(212, 175, 55, 0.13), transparent 32%),
    linear-gradient(180deg, #10100f 0%, #17130d 52%, #0f0f0f 100%);
  color: #fff8e8;
}

body.cart-page .cart_page_section {
  padding: 42px 0 64px;
}

body.cart-page .cart_page_header {
  max-width: 760px;
  margin-bottom: 22px;
}

body.cart-page .cart_page_header span,
body.cart-page .cart_page_panel_head span {
  display: block;
  color: #f2c76b;
  font-size: 12px;
  font-weight: 900;
  letter-spacing: 0.08em;
  line-height: 1.2;
  text-transform: uppercase;
}

body.cart-page .cart_page_header h1 {
  margin: 8px 0;
  color: #fff8e8;
  font-family: "Dancing Script", cursive;
  font-size: clamp(2.2rem, 10vw, 4rem);
  line-height: 1;
}

body.cart-page .cart_page_header p {
  margin: 0;
  color: rgba(255, 248, 232, 0.72);
  font-size: 1rem;
  line-height: 1.7;
}

body.cart-page .cart_page_empty,
body.cart-page .cart_page_loading,
body.cart-page .cart_page_items_panel,
body.cart-page .cart_page_summary_card {
  border: 1px solid rgba(242, 199, 107, 0.22);
  border-radius: 22px;
  background: linear-gradient(180deg, rgba(39, 32, 24, 0.95), rgba(18, 15, 12, 0.96));
  box-shadow: 0 24px 60px rgba(0, 0, 0, 0.3);
}

body.cart-page .cart_page_empty,
body.cart-page .cart_page_loading {
  display: grid;
  justify-items: center;
  gap: 10px;
  padding: 32px 18px;
  text-align: center;
}

body.cart-page .cart_page_empty[hidden],
body.cart-page .cart_page_loading[hidden],
body.cart-page .cart_page_shell[hidden] {
  display: none;
}

body.cart-page .cart_page_empty_icon,
body.cart-page .cart_page_loading_icon {
  width: 58px;
  height: 58px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 18px;
  background: rgba(242, 199, 107, 0.14);
  color: #f2c76b;
  font-size: 24px;
}

body.cart-page .cart_page_empty h2,
body.cart-page .cart_page_loading h2 {
  margin: 4px 0 0;
  color: #fff8e8;
  font-size: 1.35rem;
}

body.cart-page .cart_page_empty p,
body.cart-page .cart_page_loading p,
body.cart-page .cart_page_summary_card p {
  margin: 0;
  color: rgba(255, 248, 232, 0.68);
  line-height: 1.55;
}

body.cart-page .cart_page_shell {
  display: grid;
  gap: 16px;
}

body.cart-page .cart_page_items_panel,
body.cart-page .cart_page_summary_card {
  padding: 14px;
}

body.cart-page .cart_page_panel_head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 12px;
  margin-bottom: 14px;
}

body.cart-page .cart_page_panel_head h2 {
  margin: 4px 0 0;
  color: #fff8e8;
  font-size: 1.16rem;
  line-height: 1.25;
}

body.cart-page .cart_page_panel_head > strong {
  color: #f7d577;
  font-size: 1.05rem;
  line-height: 1.3;
  white-space: nowrap;
}

body.cart-page .cart_page_items {
  display: grid;
  gap: 10px;
}

body.cart-page .cart_page_item {
  display: grid;
  grid-template-columns: 76px minmax(0, 1fr);
  gap: 12px;
  padding: 10px;
  border: 1px solid rgba(242, 199, 107, 0.14);
  border-radius: 16px;
  background: rgba(16, 13, 10, 0.62);
}

body.cart-page .cart_page_item_image {
  width: 76px;
  height: 76px;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 14px;
  background: #fffaf0;
  overflow: hidden;
}

body.cart-page .cart_page_item_image img {
  width: 100%;
  height: 100%;
  object-fit: contain;
  padding: 6px;
}

body.cart-page .cart_page_item_body {
  min-width: 0;
  display: grid;
  gap: 8px;
}

body.cart-page .cart_page_item_head {
  min-width: 0;
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 8px;
}

body.cart-page .cart_page_item_head a {
  min-width: 0;
  color: #fff8e8;
  font-size: 0.95rem;
  font-weight: 900;
  line-height: 1.35;
}

body.cart-page .cart_page_remove_btn {
  flex: 0 0 auto;
  min-height: 30px;
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 0 10px;
  border: 1px solid rgba(255, 119, 119, 0.34);
  border-radius: 999px;
  background: rgba(255, 119, 119, 0.1);
  color: #ffd6d6;
  font-size: 12px;
  font-weight: 800;
  cursor: pointer;
}

body.cart-page .cart_page_remove_btn i {
  color: #ffb4b4;
}

body.cart-page .cart_page_item_prices,
body.cart-page .cart_page_item_bottom {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
}

body.cart-page .cart_page_item_prices span,
body.cart-page .cart_page_line_label {
  color: rgba(255, 248, 232, 0.66);
  font-size: 0.84rem;
  line-height: 1.3;
}

body.cart-page .cart_page_item_prices strong {
  color: #f7d577;
  font-size: 0.98rem;
  line-height: 1.3;
  white-space: nowrap;
}

body.cart-page .cart_page_qty {
  display: inline-flex;
  align-items: center;
  border: 1px solid rgba(242, 199, 107, 0.26);
  border-radius: 999px;
  overflow: hidden;
  background: rgba(255, 248, 232, 0.055);
}

body.cart-page .cart_page_qty button,
body.cart-page .cart_page_qty span {
  min-width: 34px;
  height: 32px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
}

body.cart-page .cart_page_qty button {
  border: 0;
  background: rgba(242, 199, 107, 0.14);
  color: #fff8e8;
  font-size: 18px;
  line-height: 1;
  cursor: pointer;
}

body.cart-page .cart_page_qty span {
  color: #fff8e8;
  font-weight: 900;
}

body.cart-page .cart_page_summary_card {
  display: grid;
  gap: 12px;
}

body.cart-page .cart_page_summary_card > span {
  color: #f2c76b;
  font-size: 12px;
  font-weight: 900;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

body.cart-page .cart_page_summary_card > strong {
  color: #f7d577;
  font-size: 1.55rem;
  line-height: 1.1;
}

body.cart-page .cart_page_actions {
  display: grid;
  gap: 10px;
  margin-top: 4px;
}

body.cart-page .cart_page_primary_link,
body.cart-page .cart_page_secondary_link,
body.cart-page .cart_page_clear_btn,
body.cart-page .cart_page_checkout_btn {
  min-height: 44px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0 18px;
  border-radius: 999px;
  font-weight: 900;
  text-align: center;
  cursor: pointer;
}

body.cart-page .cart_page_primary_link,
body.cart-page .cart_page_checkout_btn {
  border: 0;
  background: linear-gradient(135deg, #f7d577, #b9872c);
  color: #16110a;
  box-shadow: 0 14px 28px rgba(242, 199, 107, 0.16);
}

body.cart-page .cart_page_secondary_link,
body.cart-page .cart_page_clear_btn {
  border: 1px solid rgba(242, 199, 107, 0.24);
  background: rgba(255, 248, 232, 0.07);
  color: #f7d577;
}

body.cart-page .cart_page_checkout_btn:disabled,
body.cart-page .cart_page_clear_btn:disabled {
  opacity: 0.56;
  cursor: not-allowed;
}

body.cart-page .cart_page_primary_link:hover,
body.cart-page .cart_page_primary_link:focus,
body.cart-page .cart_page_checkout_btn:hover,
body.cart-page .cart_page_checkout_btn:focus {
  background: linear-gradient(135deg, #ffe6a6, #d4af37);
  color: #11100e;
}

body.cart-page .cart_page_secondary_link:hover,
body.cart-page .cart_page_secondary_link:focus,
body.cart-page .cart_page_clear_btn:hover,
body.cart-page .cart_page_clear_btn:focus {
  background: rgba(247, 213, 119, 0.12);
  color: #ffe6a6;
}

/* Dedicated cart page theme tokens */
body.cart-page {
  --cart-page-bg: radial-gradient(circle at 12% 0%, rgba(255, 190, 51, 0.18), transparent 32%),
    linear-gradient(180deg, #fffaf0 0%, #f7efe2 54%, #fffdf8 100%);
  --cart-page-text: #211a12;
  --cart-page-heading: #17120d;
  --cart-page-muted: #6f6251;
  --cart-page-kicker: #b8790a;
  --cart-page-price: #8f6200;
  --cart-page-panel: #ffffff;
  --cart-page-panel-soft: #fff9ef;
  --cart-page-row: rgba(255, 255, 255, 0.86);
  --cart-page-border: rgba(166, 113, 24, 0.18);
  --cart-page-border-strong: rgba(255, 190, 51, 0.4);
  --cart-page-shadow: 0 24px 58px rgba(68, 46, 17, 0.12);
  --cart-page-primary-bg: linear-gradient(135deg, #ffbe33, #d49a24);
  --cart-page-primary-text: #181107;
  --cart-page-secondary-bg: #fff8ec;
  --cart-page-secondary-text: #7a5200;
  --cart-page-danger-bg: #fff1f1;
  --cart-page-danger-border: rgba(185, 28, 28, 0.2);
  --cart-page-danger-text: #9f1d1d;
  --cart-page-danger-hover-bg: #9f1d1d;
  --cart-page-danger-hover-text: #ffffff;
  --cart-page-qty-bg: #fffaf0;
  --cart-page-qty-button-bg: rgba(255, 190, 51, 0.22);
  --cart-page-image-bg: #fffaf0;
  --cart-page-primary-hover-bg: linear-gradient(135deg, #ffe6a6, #d4af37);
  --cart-page-primary-hover-text: #11100e;
  --cart-page-primary-shadow: 0 14px 28px rgba(185, 135, 44, 0.18);
}

html[data-theme="dark"] body.cart-page,
body.dark-mode.cart-page,
body.theme_dark.cart-page {
  --cart-page-bg: radial-gradient(circle at 12% 0%, rgba(212, 175, 55, 0.13), transparent 32%),
    linear-gradient(180deg, #10100f 0%, #17130d 52%, #0f0f0f 100%);
  --cart-page-text: #fff8e8;
  --cart-page-heading: #fff8e8;
  --cart-page-muted: rgba(255, 248, 232, 0.72);
  --cart-page-kicker: #f2c76b;
  --cart-page-price: #f7d577;
  --cart-page-panel: linear-gradient(180deg, rgba(39, 32, 24, 0.95), rgba(18, 15, 12, 0.96));
  --cart-page-panel-soft: rgba(242, 199, 107, 0.14);
  --cart-page-row: rgba(16, 13, 10, 0.62);
  --cart-page-border: rgba(242, 199, 107, 0.22);
  --cart-page-border-strong: rgba(242, 199, 107, 0.34);
  --cart-page-shadow: 0 24px 60px rgba(0, 0, 0, 0.3);
  --cart-page-primary-bg: linear-gradient(135deg, #f7d577, #b9872c);
  --cart-page-primary-text: #16110a;
  --cart-page-secondary-bg: rgba(255, 248, 232, 0.07);
  --cart-page-secondary-text: #f7d577;
  --cart-page-danger-bg: rgba(255, 119, 119, 0.1);
  --cart-page-danger-border: rgba(255, 119, 119, 0.34);
  --cart-page-danger-text: #ffd6d6;
  --cart-page-danger-hover-bg: #ffd6d6;
  --cart-page-danger-hover-text: #231412;
  --cart-page-qty-bg: rgba(255, 248, 232, 0.055);
  --cart-page-qty-button-bg: rgba(242, 199, 107, 0.14);
  --cart-page-image-bg: #fffaf0;
  --cart-page-primary-hover-bg: linear-gradient(135deg, #ffe6a6, #d4af37);
  --cart-page-primary-hover-text: #11100e;
  --cart-page-primary-shadow: 0 14px 28px rgba(242, 199, 107, 0.16);
}

body.cart-page {
  background: var(--cart-page-bg);
  color: var(--cart-page-text);
}

body.cart-page .cart_page_main {
  background: var(--cart-page-bg);
}

body.cart-page .cart_page_header span,
body.cart-page .cart_page_panel_head span,
body.cart-page .cart_page_summary_card > span {
  color: var(--cart-page-kicker);
}

body.cart-page .cart_page_header h1,
body.cart-page .cart_page_empty h2,
body.cart-page .cart_page_loading h2,
body.cart-page .cart_page_panel_head h2,
body.cart-page .cart_page_item_head a {
  color: var(--cart-page-heading);
}

body.cart-page .cart_page_header p,
body.cart-page .cart_page_empty p,
body.cart-page .cart_page_loading p,
body.cart-page .cart_page_summary_card p,
body.cart-page .cart_page_item_prices span,
body.cart-page .cart_page_line_label {
  color: var(--cart-page-muted);
}

body.cart-page .cart_page_empty,
body.cart-page .cart_page_loading,
body.cart-page .cart_page_items_panel,
body.cart-page .cart_page_summary_card {
  border-color: var(--cart-page-border);
  background: var(--cart-page-panel);
  box-shadow: var(--cart-page-shadow);
}

body.cart-page .cart_page_empty_icon,
body.cart-page .cart_page_loading_icon {
  background: var(--cart-page-panel-soft);
  color: var(--cart-page-kicker);
}

body.cart-page .cart_page_panel_head > strong,
body.cart-page .cart_page_item_prices strong,
body.cart-page .cart_page_summary_card > strong {
  color: var(--cart-page-price);
}

body.cart-page .cart_page_item {
  border-color: var(--cart-page-border);
  background: var(--cart-page-row);
}

body.cart-page .cart_page_item_image {
  border: 1px solid var(--cart-page-border);
  background: var(--cart-page-image-bg);
}

body.cart-page .cart_page_remove_btn {
  border-color: var(--cart-page-danger-border);
  background: var(--cart-page-danger-bg);
  color: var(--cart-page-danger-text);
}

body.cart-page .cart_page_remove_btn i {
  color: var(--cart-page-danger-text);
}

body.cart-page .cart_page_remove_btn:hover,
body.cart-page .cart_page_remove_btn:focus {
  background: var(--cart-page-danger-hover-bg);
  border-color: var(--cart-page-danger-hover-bg);
  color: var(--cart-page-danger-hover-text);
}

body.cart-page .cart_page_remove_btn:hover i,
body.cart-page .cart_page_remove_btn:focus i {
  color: var(--cart-page-danger-hover-text);
}

body.cart-page .cart_page_qty {
  border-color: var(--cart-page-border-strong);
  background: var(--cart-page-qty-bg);
}

body.cart-page .cart_page_qty button {
  background: var(--cart-page-qty-button-bg);
  color: var(--cart-page-heading);
}

body.cart-page .cart_page_qty button:hover,
body.cart-page .cart_page_qty button:focus {
  background: var(--cart-page-primary-bg);
  color: var(--cart-page-primary-text);
}

body.cart-page .cart_page_qty span {
  color: var(--cart-page-heading);
}

body.cart-page .cart_page_primary_link,
body.cart-page .cart_page_checkout_btn {
  background: var(--cart-page-primary-bg);
  color: var(--cart-page-primary-text);
  box-shadow: var(--cart-page-primary-shadow);
}

body.cart-page .cart_page_secondary_link,
body.cart-page .cart_page_clear_btn {
  border-color: var(--cart-page-border-strong);
  background: var(--cart-page-secondary-bg);
  color: var(--cart-page-secondary-text);
}

body.cart-page .cart_page_primary_link:hover,
body.cart-page .cart_page_primary_link:focus,
body.cart-page .cart_page_checkout_btn:hover,
body.cart-page .cart_page_checkout_btn:focus {
  background: var(--cart-page-primary-hover-bg);
  color: var(--cart-page-primary-hover-text);
  transform: translateY(-1px);
}

body.cart-page .cart_page_secondary_link:hover,
body.cart-page .cart_page_secondary_link:focus,
body.cart-page .cart_page_clear_btn:hover,
body.cart-page .cart_page_clear_btn:focus {
  background: var(--cart-page-primary-bg);
  border-color: transparent;
  color: var(--cart-page-primary-text);
}

.custom_nav-container .user_option .cart_link {
  overflow: visible !important;
}

.custom_nav-container .cart_count_badge,
.user_option .cart_link .cart_count_badge {
  position: absolute;
  top: -9px;
  right: -9px;
  z-index: 50;
  min-width: 20px;
  height: 20px;
  padding: 0 5px;
  border: 1px solid #ffffff;
  border-radius: 999px;
  background: #ff3b30;
  color: #ffffff;
  font-size: 11.5px;
  font-weight: 700;
  line-height: 18px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  text-align: center;
  box-shadow: 0 8px 18px rgba(255, 59, 48, 0.42), 0 2px 6px rgba(0, 0, 0, 0.28);
}

@media (min-width: 576px) {
  body.checkout-page .checkout_steps,
  body.checkout-page .checkout_city_options,
  body.checkout-page .checkout_review_cards {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  body.checkout-page .checkout_fields {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  body.checkout-page .checkout_full_width {
    grid-column: 1 / -1;
  }

  body.checkout-page .checkout_nav_row {
    grid-template-columns: repeat(2, minmax(0, auto));
    justify-content: space-between;
  }

  body.checkout-page .checkout_saved_address_bar {
    grid-template-columns: minmax(0, 1fr) auto;
    align-items: center;
  }

  body.cart-page .cart_page_actions {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  body.cart-page .cart_page_checkout_btn {
    grid-column: 1 / -1;
  }
}

@media (min-width: 992px) {
  body.checkout-page .checkout_page_section {
    padding: 58px 0 82px;
  }

  body.checkout-page .checkout_page_shell {
    padding: 18px;
  }

  body.checkout-page .checkout_steps {
    grid-template-columns: repeat(4, minmax(0, 1fr));
  }

  body.checkout-page .checkout_step {
    justify-content: center;
    text-align: center;
  }

  body.checkout-page .checkout_page_panel {
    padding: 22px;
  }

  body.checkout-page .checkout_cart_item {
    grid-template-columns: 92px minmax(0, 1fr);
    gap: 16px;
  }

  body.checkout-page .checkout_cart_item_image {
    width: 92px;
    height: 92px;
  }

  body.checkout-page .checkout_cart_item_head a {
    font-size: 1.04rem;
  }

  body.cart-page .cart_page_section {
    padding: 58px 0 82px;
  }

  body.cart-page .cart_page_shell {
    grid-template-columns: minmax(0, 1fr) 340px;
    align-items: start;
  }

  body.cart-page .cart_page_items_panel,
  body.cart-page .cart_page_summary_card {
    padding: 22px;
  }

  body.cart-page .cart_page_summary {
    position: sticky;
    top: 18px;
  }

  body.cart-page .cart_page_item {
    grid-template-columns: 96px minmax(0, 1fr);
    gap: 16px;
  }

  body.cart-page .cart_page_item_image {
    width: 96px;
    height: 96px;
  }

  body.cart-page .cart_page_item_head a {
    font-size: 1.04rem;
  }
}

body.product-page .product_story_link {
  color: var(--product-page-gold-strong);
}

body.product-page .product_story_link:hover,
body.product-page .product_story_link:focus {
  color: var(--product-page-price);
}

body.product-page .product_recommendations_section .heading_container {
  padding-bottom: 4px;
}

body.product-page .product_recommendations_section .heading_container p {
  max-width: 760px;
  font-size: 0.98rem;
}

body.product-page .recommendation_card {
  background: var(--product-page-panel);
}

body.product-page .recommendation_card_body {
  gap: 12px;
}

body.product-page .recommendation_card_label {
  background: var(--product-page-soft);
  color: var(--product-page-label);
  border: 1px solid var(--product-page-border);
  font-weight: 900;
  line-height: 1.2;
}

body.product-page .recommendation_card_copy h3,
body.product-page .recommendation_card_copy h3 a,
body.product-page .product-title,
body.product-page .product-title a {
  color: var(--product-page-heading);
}

body.product-page .recommendation_card_copy h3 {
  font-family: "Open Sans", sans-serif;
  font-weight: 800;
  letter-spacing: 0;
}

body.product-page .recommendation_card_copy p,
body.product-page .product-description {
  color: var(--product-page-card-text);
}

body.product-page .recommendation_card_rating .rating_stars,
body.product-page .recommendation_card_rating .rating_stars_wrap {
  color: var(--product-page-gold);
}

body.product-page .recommendation_card_footer {
  padding-top: 10px;
  border-top: 1px solid var(--product-page-border);
}

body.product-page .recommendation_link {
  background: #fff7e2;
  color: #6f4a00;
  border: 1px solid rgba(180, 125, 25, 0.22);
}

body.product-page .recommendation_link:hover,
body.product-page .recommendation_link:focus {
  background: #ffe7ab;
  color: #4f3500;
}

body.product-page .recommendation_add_btn {
  background: linear-gradient(135deg, #ffcf5d, #ffad22);
  color: #15110a;
}

body.product-page .recommendation_add_btn:hover,
body.product-page .recommendation_add_btn:focus {
  background: linear-gradient(135deg, #ffd875, #e99b07);
  color: #15110a;
}

html[data-theme="dark"] body.product-page .recommendation_link,
body.theme_dark.product-page .recommendation_link {
  background: rgba(255, 248, 232, 0.075);
  color: var(--product-page-gold);
  border-color: var(--product-page-border-strong);
}

html[data-theme="dark"] body.product-page .recommendation_link:hover,
html[data-theme="dark"] body.product-page .recommendation_link:focus,
body.theme_dark.product-page .recommendation_link:hover,
body.theme_dark.product-page .recommendation_link:focus {
  background: rgba(242, 199, 107, 0.15);
  color: #ffe09a;
}

@media (max-width: 768px) {
  body.product-page .product_details_section {
    padding-top: 34px;
    padding-bottom: 28px;
  }

  body.product-page .product_info_card {
    gap: 14px;
  }

  body.product-page .product_info_card h1 {
    font-size: clamp(1.55rem, 8vw, 2rem);
    line-height: 1.18;
  }

  body.product-page #productDescription,
  body.product-page .product_story_lead,
  body.product-page .product_recommendations_section .heading_container p {
    font-size: 0.95rem;
    line-height: 1.65;
  }

  body.product-page .product_meta_title {
    font-size: 0.95rem;
  }

  body.product-page .product_spec_row {
    align-items: flex-start;
    padding: 12px;
  }

  body.product-page .product_story_card,
  body.product-page .reviews_summary_card,
  body.product-page .reviews_panel {
    padding: 18px;
  }

  body.product-page .recommendation_card_body {
    padding: 13px;
    gap: 11px;
  }

  body.product-page .recommendation_card_copy h3,
  body.product-page .product-title {
    font-size: 0.92rem !important;
    line-height: 1.32 !important;
  }

  body.product-page .recommendation_card_copy p,
  body.product-page .product-description {
    color: var(--product-page-card-text);
    font-size: 0.8rem !important;
    line-height: 1.45 !important;
  }

  body.product-page .recommendation_card_price {
    font-size: 0.98rem;
  }

  body.product-page .recommendation_card_footer {
    gap: 9px;
  }
}

/* Feedback / Contact page */
body.feedback-page {
  --feedback-bg: linear-gradient(180deg, #fff8ea 0%, #fffdf7 48%, #fff7e6 100%);
  --feedback-surface: rgba(255, 255, 255, 0.86);
  --feedback-surface-strong: #ffffff;
  --feedback-soft: #fff3d6;
  --feedback-text: #251a0e;
  --feedback-heading: #17110a;
  --feedback-muted: #6d604f;
  --feedback-gold: #d4a12a;
  --feedback-gold-strong: #9b6a08;
  --feedback-border: rgba(158, 105, 21, 0.18);
  --feedback-border-strong: rgba(212, 161, 42, 0.42);
  --feedback-input-bg: rgba(255, 255, 255, 0.94);
  --feedback-input-text: #21170c;
  --feedback-shadow: 0 24px 62px rgba(86, 57, 19, 0.14);
  --feedback-glow: 0 14px 36px rgba(212, 161, 42, 0.2);
  --feedback-primary: linear-gradient(135deg, #ffdd7a 0%, #f4b531 48%, #b77a12 100%);
  --feedback-primary-hover: linear-gradient(135deg, #ffe8a3 0%, #ffc64d 46%, #c48615 100%);
  background: var(--feedback-bg);
  color: var(--feedback-text);
}

html[data-theme="dark"] body.feedback-page,
body.theme_dark.feedback-page {
  --feedback-bg: linear-gradient(180deg, #11100d 0%, #16120e 48%, #0c0b09 100%);
  --feedback-surface: rgba(31, 25, 18, 0.86);
  --feedback-surface-strong: rgba(23, 18, 13, 0.96);
  --feedback-soft: rgba(242, 199, 107, 0.12);
  --feedback-text: #fff6df;
  --feedback-heading: #fff8e8;
  --feedback-muted: rgba(255, 246, 223, 0.72);
  --feedback-gold: #f2c76b;
  --feedback-gold-strong: #ffdc88;
  --feedback-border: rgba(242, 199, 107, 0.2);
  --feedback-border-strong: rgba(242, 199, 107, 0.42);
  --feedback-input-bg: rgba(255, 248, 232, 0.08);
  --feedback-input-text: #fff8e8;
  --feedback-shadow: 0 24px 68px rgba(0, 0, 0, 0.36);
  --feedback-glow: 0 18px 44px rgba(242, 199, 107, 0.12);
  --feedback-primary: linear-gradient(135deg, #ffe08c 0%, #d8a236 50%, #8d5d10 100%);
  --feedback-primary-hover: linear-gradient(135deg, #fff0b6 0%, #efbd56 48%, #a76e13 100%);
}

body.feedback-page .feedback_page_main {
  overflow: hidden;
  background: var(--feedback-bg);
}

body.feedback-page .feedback_hero_section {
  position: relative;
  padding: 72px 0 60px;
}

body.feedback-page .feedback_hero_section::before {
  content: "";
  position: absolute;
  inset: 0 0 auto;
  height: 220px;
  background: linear-gradient(180deg, rgba(255, 190, 51, 0.14), rgba(255, 190, 51, 0));
  pointer-events: none;
}

body.feedback-page .feedback_hero_section > .container,
body.feedback-page .feedback_appreciation_section > .container {
  position: relative;
  max-width: 1180px;
}

body.feedback-page .feedback_hero_header {
  max-width: 830px;
  margin: 0 auto 36px;
  text-align: center;
}

body.feedback-page .feedback_kicker,
body.feedback-page .feedback_form_intro span,
body.feedback-page .feedback_direct_support span {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  color: var(--feedback-gold-strong);
  font-size: 0.84rem;
  font-weight: 900;
  line-height: 1.2;
  letter-spacing: 0;
  text-transform: uppercase;
}

body.feedback-page .feedback_kicker {
  min-height: 32px;
  padding: 0 14px;
  border: 1px solid var(--feedback-border-strong);
  border-radius: 8px;
  background: var(--feedback-soft);
  box-shadow: var(--feedback-glow);
}

body.feedback-page .feedback_hero_header h1 {
  margin: 18px 0 14px;
  color: var(--feedback-heading);
  font-size: 4rem;
  font-weight: 700;
  line-height: 1.05;
  letter-spacing: 0;
  overflow-wrap: break-word;
}

body.feedback-page .feedback_hero_header p {
  max-width: 760px;
  margin: 0 auto;
  color: var(--feedback-muted);
  font-size: 1.05rem;
  line-height: 1.75;
}

body.feedback-page .feedback_heading_tail {
  display: inline;
}

body.feedback-page .feedback_layout {
  display: grid;
  grid-template-columns: minmax(300px, 0.82fr) minmax(0, 1.18fr);
  gap: 28px;
  align-items: stretch;
}

body.feedback-page .feedback_layout > * {
  min-width: 0;
}

body.feedback-page .feedback_info_panel,
body.feedback-page .feedback_form_card {
  min-width: 0;
  border: 1px solid var(--feedback-border);
  border-radius: 8px;
  background: var(--feedback-surface);
  box-shadow: var(--feedback-shadow);
  -webkit-backdrop-filter: blur(18px) saturate(135%);
          backdrop-filter: blur(18px) saturate(135%);
}

body.feedback-page .feedback_info_panel {
  display: flex;
  flex-direction: column;
  gap: 18px;
  padding: 28px;
}

body.feedback-page .feedback_logo_mark {
  width: 94px;
  height: 94px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border: 1px solid var(--feedback-border-strong);
  border-radius: 8px;
  background: #ffffff;
  box-shadow: 0 18px 34px rgba(92, 62, 22, 0.16);
}

body.feedback-page .feedback_logo_mark picture,
body.feedback-page .feedback_logo_mark img {
  display: block;
  width: 74px;
  height: 74px;
}

body.feedback-page .feedback_logo_mark img {
  object-fit: contain;
}

body.feedback-page .feedback_info_panel h2,
body.feedback-page .feedback_form_intro h2,
body.feedback-page .feedback_appreciation_inner h2 {
  margin: 0;
  color: var(--feedback-heading);
  font-family: "Open Sans", sans-serif;
  font-weight: 900;
  line-height: 1.18;
  letter-spacing: 0;
}

body.feedback-page .feedback_info_panel h2 {
  font-size: 1.72rem;
}

body.feedback-page .feedback_info_panel p,
body.feedback-page .feedback_form_footer p,
body.feedback-page .feedback_appreciation_inner p {
  margin: 0;
  color: var(--feedback-muted);
  line-height: 1.7;
  overflow-wrap: break-word;
}

body.feedback-page .feedback_support_list {
  display: grid;
  gap: 12px;
  margin: 4px 0 0;
  padding: 0;
  list-style: none;
}

body.feedback-page .feedback_support_list li {
  display: grid;
  grid-template-columns: 38px minmax(0, 1fr);
  gap: 12px;
  align-items: center;
  min-height: 48px;
  padding: 10px 0;
  border-top: 1px solid var(--feedback-border);
  color: var(--feedback-text);
  font-weight: 800;
  line-height: 1.4;
}

body.feedback-page .feedback_support_list span {
  min-width: 0;
  overflow-wrap: break-word;
}

body.feedback-page .feedback_support_list i {
  width: 38px;
  height: 38px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 8px;
  background: var(--feedback-soft);
  color: var(--feedback-gold-strong);
  font-size: 17px;
}

body.feedback-page .feedback_direct_support {
  margin-top: auto;
  padding-top: 18px;
  border-top: 1px solid var(--feedback-border);
}

body.feedback-page .feedback_direct_support a {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 9px;
  min-height: 44px;
  margin-top: 10px;
  padding: 0 16px;
  border: 1px solid var(--feedback-border-strong);
  border-radius: 8px;
  background: var(--feedback-surface-strong);
  color: var(--feedback-gold-strong);
  font-weight: 900;
  line-height: 1.2;
  box-shadow: 0 10px 24px rgba(31, 20, 8, 0.08);
  transition: transform 0.22s ease, box-shadow 0.22s ease, background-color 0.22s ease;
}

body.feedback-page .feedback_direct_support a:hover,
body.feedback-page .feedback_direct_support a:focus {
  color: var(--feedback-heading);
  transform: translateY(-2px);
  box-shadow: var(--feedback-glow);
}

body.feedback-page .feedback_form_card {
  padding: 30px;
}

body.feedback-page .feedback_form_intro {
  margin-bottom: 24px;
}

body.feedback-page .feedback_form_intro h2 {
  margin-top: 8px;
  font-size: 1.58rem;
}

body.feedback-page .feedback_form {
  display: grid;
  gap: 18px;
}

body.feedback-page .feedback_form[aria-busy="true"] .feedback_field select,
body.feedback-page .feedback_form[aria-busy="true"] .feedback_field .nice-select {
  pointer-events: none;
}

body.feedback-page .feedback_field_grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 16px;
}

body.feedback-page .feedback_field {
  display: grid;
  gap: 8px;
}

body.feedback-page .feedback_field label {
  margin: 0;
  color: var(--feedback-heading);
  font-size: 0.92rem;
  font-weight: 900;
  line-height: 1.3;
  letter-spacing: 0;
}

body.feedback-page .feedback_field input,
body.feedback-page .feedback_field select,
body.feedback-page .feedback_field textarea,
body.feedback-page .feedback_field .nice-select {
  width: 100%;
  min-height: 52px;
  padding: 0 15px;
  border: 1px solid var(--feedback-border);
  border-radius: 8px;
  background: var(--feedback-input-bg);
  color: var(--feedback-input-text);
  font: inherit;
  font-size: 0.96rem;
  font-weight: 700;
  letter-spacing: 0;
  outline: none;
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.38);
  transition: border-color 0.2s ease, box-shadow 0.2s ease, background-color 0.2s ease;
}

body.feedback-page .feedback_field textarea {
  min-height: 138px;
  max-height: 260px;
  padding-top: 14px;
  padding-bottom: 14px;
  line-height: 1.65;
  resize: none;
  overflow-y: auto;
}

body.feedback-page .feedback_field input::placeholder,
body.feedback-page .feedback_field textarea::placeholder {
  color: color-mix(in srgb, var(--feedback-muted) 78%, transparent);
  font-weight: 600;
}

body.feedback-page .feedback_field input:focus,
body.feedback-page .feedback_field select:focus,
body.feedback-page .feedback_field textarea:focus,
body.feedback-page .feedback_field .nice-select.open,
body.feedback-page .feedback_field .nice-select:focus {
  border-color: var(--feedback-border-strong);
  box-shadow: 0 0 0 4px rgba(212, 161, 42, 0.13), inset 0 1px 0 rgba(255, 255, 255, 0.42);
}

body.feedback-page .feedback_field input[aria-invalid="true"],
body.feedback-page .feedback_field textarea[aria-invalid="true"],
body.feedback-page .feedback_field select[aria-invalid="true"],
body.feedback-page .feedback_field .nice-select.is_invalid {
  border-color: rgba(185, 28, 28, 0.72);
  box-shadow: 0 0 0 4px rgba(185, 28, 28, 0.1);
}

body.feedback-page .feedback_field .nice-select {
  float: none;
  display: flex;
  align-items: center;
  line-height: 1.2;
}

body.feedback-page .feedback_field .nice-select::after {
  right: 17px;
  border-color: var(--feedback-gold-strong);
}

body.feedback-page .feedback_field .nice-select .current {
  display: block;
  max-width: calc(100% - 22px);
  overflow: hidden;
  color: var(--feedback-input-text);
  text-overflow: ellipsis;
  white-space: nowrap;
}

body.feedback-page .feedback_field .nice-select .list {
  width: 100%;
  max-height: 236px;
  overflow-y: auto;
  border: 1px solid var(--feedback-border);
  border-radius: 8px;
  background: var(--feedback-surface-strong);
  box-shadow: var(--feedback-shadow);
}

body.feedback-page .feedback_field .nice-select .option {
  min-height: 42px;
  color: var(--feedback-text);
  font-weight: 800;
  line-height: 42px;
}

body.feedback-page .feedback_field .nice-select .option:hover,
body.feedback-page .feedback_field .nice-select .option.focus,
body.feedback-page .feedback_field .nice-select .option.selected.focus {
  background: var(--feedback-soft);
  color: var(--feedback-heading);
}

body.feedback-page .feedback_honeypot {
  position: absolute;
  left: -9999px;
  width: 1px;
  height: 1px;
  opacity: 0;
  pointer-events: none;
}

body.feedback-page .feedback_status {
  margin: 0;
  padding: 13px 15px;
  border: 1px solid var(--feedback-border);
  border-radius: 8px;
  background: var(--feedback-soft);
  color: var(--feedback-text);
  font-weight: 800;
  line-height: 1.45;
}

body.feedback-page .feedback_status[hidden] {
  display: none;
}

body.feedback-page .feedback_status_success {
  border-color: rgba(22, 101, 52, 0.28);
  background: rgba(22, 101, 52, 0.12);
  color: #166534;
}

body.feedback-page .feedback_status_error {
  border-color: rgba(185, 28, 28, 0.3);
  background: rgba(185, 28, 28, 0.1);
  color: #9f1d1d;
}

body.feedback-page .feedback_status_info {
  border-color: var(--feedback-border-strong);
  color: var(--feedback-gold-strong);
}

html[data-theme="dark"] body.feedback-page .feedback_status_success,
body.theme_dark.feedback-page .feedback_status_success {
  border-color: rgba(92, 221, 139, 0.28);
  background: rgba(92, 221, 139, 0.1);
  color: #a7f3c4;
}

html[data-theme="dark"] body.feedback-page .feedback_status_error,
body.theme_dark.feedback-page .feedback_status_error {
  border-color: rgba(255, 127, 127, 0.28);
  background: rgba(255, 127, 127, 0.12);
  color: #ffd0d0;
}

body.feedback-page .feedback_form_footer {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 18px;
  align-items: center;
  padding-top: 4px;
}

body.feedback-page .feedback_form_footer p {
  font-size: 0.92rem;
}

body.feedback-page .feedback_submit_btn {
  position: relative;
  min-width: 178px;
  min-height: 52px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  padding: 0 24px;
  border: 0;
  border-radius: 8px;
  background: var(--feedback-primary);
  color: #1c1308;
  cursor: pointer;
  font-size: 0.98rem;
  font-weight: 900;
  line-height: 1.1;
  letter-spacing: 0;
  box-shadow: 0 16px 30px rgba(183, 122, 18, 0.24), 0 0 0 1px rgba(255, 244, 200, 0.44) inset;
  transition: transform 0.22s ease, box-shadow 0.22s ease, background 0.22s ease, opacity 0.22s ease;
}

body.feedback-page .feedback_submit_btn:hover,
body.feedback-page .feedback_submit_btn:focus {
  background: var(--feedback-primary-hover);
  color: #17110a;
  transform: translateY(-2px);
  box-shadow: 0 20px 40px rgba(183, 122, 18, 0.28), 0 0 0 1px rgba(255, 244, 200, 0.52) inset;
}

body.feedback-page .feedback_submit_btn:disabled {
  cursor: wait;
  opacity: 0.78;
  transform: none;
}

body.feedback-page .feedback_spinner {
  width: 18px;
  height: 18px;
  display: none;
  border: 2px solid rgba(28, 19, 8, 0.28);
  border-top-color: #1c1308;
  border-radius: 50%;
  animation: feedbackSpinner 0.75s linear infinite;
}

body.feedback-page .feedback_submit_btn.is_sending .feedback_spinner {
  display: inline-flex;
}

@keyframes feedbackSpinner {
  to {
    transform: rotate(360deg);
  }
}

body.feedback-page .feedback_appreciation_section {
  padding: 0 0 86px;
}

body.feedback-page .feedback_appreciation_inner {
  max-width: 900px;
  margin: 0 auto;
  padding: 36px 28px 0;
  border-top: 1px solid var(--feedback-border);
  text-align: center;
}

body.feedback-page .feedback_divider {
  width: 96px;
  height: 3px;
  display: block;
  margin: 0 auto 22px;
  border-radius: 8px;
  background: linear-gradient(90deg, transparent, var(--feedback-gold), transparent);
}

body.feedback-page .feedback_appreciation_inner h2 {
  font-family: "Dancing Script", cursive;
  font-size: 3rem;
  font-weight: 700;
}

body.feedback-page .feedback_appreciation_inner p {
  max-width: 760px;
  margin: 12px auto 0;
  font-size: 1.03rem;
}

@media (max-width: 991px) {
  body.feedback-page .feedback_hero_section {
    padding: 58px 0 48px;
  }

  body.feedback-page .feedback_hero_header h1 {
    font-size: 3.1rem;
  }

  body.feedback-page .feedback_layout {
    grid-template-columns: 1fr;
  }

  body.feedback-page .feedback_info_panel {
    min-height: auto;
  }
}

@media (max-width: 768px) {
  body.feedback-page .feedback_hero_section {
    padding: 46px 0 40px;
  }

  body.feedback-page .feedback_hero_header {
    margin-bottom: 24px;
  }

  body.feedback-page .feedback_hero_header h1 {
    max-width: 360px;
    margin-left: auto;
    margin-right: auto;
    font-size: 2.1rem;
    line-height: 1.16;
  }

  body.feedback-page .feedback_heading_tail {
    display: block;
  }

  body.feedback-page .feedback_hero_header p {
    max-width: 340px;
    font-size: 0.96rem;
    line-height: 1.65;
  }

  body.feedback-page .feedback_info_panel,
  body.feedback-page .feedback_form_card {
    padding: 22px;
  }

  body.feedback-page .feedback_field_grid,
  body.feedback-page .feedback_form_footer {
    grid-template-columns: 1fr;
  }

  body.feedback-page .feedback_submit_btn {
    width: 100%;
  }

  body.feedback-page .feedback_appreciation_section {
    padding-bottom: 64px;
  }

  body.feedback-page .feedback_appreciation_inner {
    padding: 30px 0 0;
  }

  body.feedback-page .feedback_appreciation_inner h2 {
    font-size: 2.2rem;
  }
}

@media (max-width: 480px) {
  body.feedback-page .feedback_hero_section {
    padding-top: 34px;
  }

  body.feedback-page .feedback_hero_header h1 {
    max-width: 320px;
    margin-left: auto;
    margin-right: auto;
    font-size: 1.82rem;
    line-height: 1.22;
  }

  body.feedback-page .feedback_hero_header p {
    max-width: 330px;
  }

  body.feedback-page .feedback_info_panel,
  body.feedback-page .feedback_form_card {
    padding: 18px;
  }

  body.feedback-page .feedback_support_list li {
    grid-template-columns: 34px minmax(0, 1fr);
    gap: 10px;
    font-size: 0.92rem;
  }

  body.feedback-page .feedback_support_list i {
    width: 34px;
    height: 34px;
    font-size: 15px;
  }

  body.feedback-page .feedback_field input,
  body.feedback-page .feedback_field select,
  body.feedback-page .feedback_field textarea,
  body.feedback-page .feedback_field .nice-select {
    min-height: 48px;
    font-size: 0.92rem;
  }

  body.feedback-page .feedback_field textarea {
    min-height: 126px;
  }
}

/* App-style navbar and Google AI Studio inspired side drawer */
.custom_nav-container.minimal_navbar {
  gap: 14px !important;
  position: relative !important;
  display: flex !important;
  align-items: center !important;
}

.custom_nav-container.minimal_navbar .minimal_nav_actions {
  display: flex !important;
  align-items: center !important;
  justify-content: flex-end !important;
  gap: 7px !important;
  position: absolute !important;
  top: 50% !important;
  right: 0 !important;
  width: max-content !important;
  margin-left: 0 !important;
  transform: translateY(-50%) !important;
}

.custom_nav-container.minimal_navbar .minimal_nav_actions > .auth_shell {
  position: relative !important;
  display: inline-flex !important;
  flex: 0 0 auto !important;
  margin: 0 !important;
}

.custom_nav-container.minimal_navbar .minimal_nav_actions > .custom-language-switcher {
  position: relative !important;
  left: auto !important;
  right: auto !important;
  bottom: auto !important;
  z-index: 25 !important;
  display: inline-flex !important;
  flex: 0 0 auto !important;
  margin: 0 !important;
}

.custom_nav-container.minimal_navbar .minimal_nav_actions .cart_link,
.custom_nav-container.minimal_navbar .minimal_nav_actions .nav_search-btn,
.custom_nav-container.minimal_navbar .minimal_nav_actions .theme_toggle,
.custom_nav-container.minimal_navbar .minimal_nav_actions .auth_button,
.custom_nav-container.minimal_navbar .minimal_nav_actions .language-btn,
.custom_nav-container.minimal_navbar .minimal_nav_actions .navbar-toggler {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  width: 40px !important;
  min-width: 40px !important;
  max-width: 40px !important;
  height: 40px !important;
  min-height: 40px !important;
  padding: 0 !important;
  border: 1px solid rgba(166, 113, 24, 0.18) !important;
  border-radius: 12px !important;
  background: rgba(255, 250, 239, 0.93) !important;
  color: #a96f05 !important;
  line-height: 1 !important;
  box-shadow: 0 8px 22px rgba(66, 42, 12, 0.13) !important;
  backdrop-filter: blur(12px) !important;
}

.custom_nav-container.minimal_navbar .minimal_nav_actions .cart_link:hover,
.custom_nav-container.minimal_navbar .minimal_nav_actions .cart_link:focus,
.custom_nav-container.minimal_navbar .minimal_nav_actions .nav_search-btn:hover,
.custom_nav-container.minimal_navbar .minimal_nav_actions .nav_search-btn:focus,
.custom_nav-container.minimal_navbar .minimal_nav_actions .theme_toggle:hover,
.custom_nav-container.minimal_navbar .minimal_nav_actions .theme_toggle:focus,
.custom_nav-container.minimal_navbar .minimal_nav_actions .auth_button:hover,
.custom_nav-container.minimal_navbar .minimal_nav_actions .auth_button:focus,
.custom_nav-container.minimal_navbar .minimal_nav_actions .language-btn:hover,
.custom_nav-container.minimal_navbar .minimal_nav_actions .language-btn:focus,
.custom_nav-container.minimal_navbar .minimal_nav_actions .navbar-toggler:hover,
.custom_nav-container.minimal_navbar .minimal_nav_actions .navbar-toggler:focus {
  border-color: rgba(255, 190, 51, 0.54) !important;
  background: rgba(255, 243, 214, 0.98) !important;
  color: #8a5a00 !important;
  transform: translateY(-1px) !important;
  outline: none !important;
}

.custom_nav-container.minimal_navbar .minimal_nav_actions .auth_button_text,
.custom_nav-container.minimal_navbar .minimal_nav_actions .auth_chevron,
.custom_nav-container.minimal_navbar .minimal_nav_actions #currentLangText,
.custom_nav-container.minimal_navbar .minimal_nav_actions .lang-arrow,
.custom_nav-container.minimal_navbar .minimal_nav_actions .lang-divider,
.custom_nav-container.minimal_navbar .minimal_nav_actions .lang-code {
  display: none !important;
}

.custom_nav-container.minimal_navbar .minimal_nav_actions .auth_button {
  gap: 0 !important;
}

.custom_nav-container.minimal_navbar .minimal_nav_actions .auth_avatar {
  width: 28px !important;
  min-width: 28px !important;
  height: 28px !important;
  border: 0 !important;
  background: rgba(255, 190, 51, 0.18) !important;
  color: #8a5a00 !important;
}

.custom_nav-container.minimal_navbar .minimal_nav_actions .auth_avatar img {
  border-radius: 50% !important;
}

.custom_nav-container.minimal_navbar .minimal_nav_actions .auth_avatar i {
  color: currentColor !important;
  font-size: 15px !important;
}

.auth_initials {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  height: 100%;
  color: currentColor;
  font-size: 11px;
  font-weight: 900;
  line-height: 1;
  letter-spacing: 0;
}

.custom_nav-container.minimal_navbar .minimal_nav_actions .lang-icon {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  width: 18px !important;
  height: 18px !important;
  font-size: 0 !important;
}

.custom_nav-container.minimal_navbar .minimal_nav_actions .lang-icon::before {
  color: currentColor !important;
  font-size: 15px !important;
}

.custom_nav-container.minimal_navbar .minimal_nav_actions .language-menu {
  right: 0 !important;
  left: auto !important;
  top: calc(100% + 10px) !important;
  bottom: auto !important;
}

.custom_nav-container.minimal_navbar .minimal_nav_actions .auth_dropdown {
  right: 0 !important;
  left: auto !important;
  top: calc(100% + 10px) !important;
  width: min(220px, calc(100vw - 24px)) !important;
  transform: none !important;
}

.site_drawer_overlay {
  position: fixed;
  inset: 0;
  z-index: 140;
  background: rgba(13, 10, 7, 0.52);
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
  transition: opacity 0.24s ease, visibility 0.24s ease;
}

.site_drawer_overlay.is_visible {
  opacity: 1;
  visibility: visible;
  pointer-events: auto;
}

.site_drawer_overlay[hidden],
.site_side_drawer[hidden] {
  display: none !important;
}

.site_side_drawer {
  position: fixed;
  top: 0;
  right: 0;
  left: auto;
  z-index: 141;
  display: flex;
  flex-direction: column;
  width: min(55vw, 260px);
  height: 100vh;
  height: 100dvh;
  max-height: none;
  padding: 10px 8px;
  overflow: hidden;
  border-left: 1px solid rgba(166, 113, 24, 0.16);
  background: linear-gradient(180deg, #fffdf8 0%, #fff7e8 100%);
  color: #21170d;
  box-shadow: -22px 0 54px rgba(33, 23, 13, 0.18);
  transform: translateX(100%);
  transition: transform 0.28s cubic-bezier(0.2, 0.8, 0.2, 1);
  will-change: transform;
}

.site_side_drawer.is_open {
  transform: translateX(0);
}

body.side_drawer_open {
  overflow: hidden;
}

body.side_drawer_open .back_to_top_btn,
body.side_drawer_open .scroll-to-top,
body.side_drawer_open .scroll-down {
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
}

.side_drawer_header {
  flex: 0 0 auto;
  padding: 2px 0 12px;
  margin-bottom: 4px;
  position: relative;
}

.side_drawer_header::after {
  content: "";
  position: absolute;
  right: 8px;
  bottom: 0;
  left: 8px;
  height: 2px;
  border-radius: 999px;
  background: linear-gradient(90deg, rgba(255, 190, 51, 0), rgba(255, 190, 51, 0.82), rgba(255, 190, 51, 0));
}

.side_drawer_brand {
  display: grid;
  grid-template-columns: 42px minmax(0, 1fr) 16px;
  align-items: center;
  gap: 10px;
  min-height: 54px;
  padding: 6px 8px;
  border-radius: 12px;
  color: #24180b;
}

.side_drawer_brand:hover,
.side_drawer_brand:focus {
  background: rgba(255, 190, 51, 0.12);
  color: #1f160a;
  outline: none;
}

.side_drawer_brand_mark {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 42px;
  height: 42px;
  border: 1px solid rgba(166, 113, 24, 0.14);
  border-radius: 10px;
  background: #ffffff;
  overflow: hidden;
  box-shadow: 0 8px 18px rgba(86, 55, 12, 0.12);
}

.side_drawer_brand_mark img {
  width: 100%;
  height: 100%;
  padding: 4px;
  object-fit: contain;
}

.side_drawer_brand_name {
  min-width: 0;
  overflow: hidden;
  color: inherit;
  font-size: 17px;
  font-weight: 700;
  line-height: 1.15;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.side_drawer_brand_arrow {
  color: #b77908;
  font-size: 14px;
  text-align: center;
}

.side_drawer_middle {
  flex: 1 1 auto;
  min-height: 0;
  padding: 4px 0;
}

.side_drawer_nav {
  display: grid;
  gap: 3px;
}

.side_drawer_link {
  position: relative;
  display: grid;
  grid-template-columns: 28px minmax(0, 1fr) auto;
  align-items: center;
  gap: 6px;
  min-height: 36px;
  padding: 0 9px;
  border: 1px solid transparent;
  border-radius: 10px;
  color: #342719;
  font-size: 13.5px;
  font-weight: 700;
  line-height: 1;
  transition: background-color 0.18s ease, border-color 0.18s ease, color 0.18s ease;
}

.side_drawer_link:hover,
.side_drawer_link:focus {
  border-color: rgba(255, 190, 51, 0.2);
  background: rgba(255, 190, 51, 0.12);
  color: #21170d;
  outline: none;
}

.side_drawer_link.is_active,
.side_drawer_link[aria-current="page"] {
  border-color: rgba(255, 190, 51, 0.22);
  background: rgba(255, 190, 51, 0.18);
  color: #1f160a;
}

.side_drawer_icon {
  display: inline-flex;
  justify-content: center;
  color: #c8890d;
  font-size: 15px;
  line-height: 1;
}

.side_drawer_link span:not(.side_drawer_badge) {
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.side_drawer_badge {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 20px;
  height: 20px;
  padding: 0 6px;
  border-radius: 999px;
  background: #ffbe33;
  color: #24180b;
  font-size: 11px;
  font-weight: 900;
  line-height: 1;
}

.side_drawer_footer {
  flex: 0 0 auto;
  margin-top: auto;
  padding: 9px 0 0;
  border-top: 1px solid rgba(166, 113, 24, 0.14);
}

.side_drawer_account_row {
  display: grid;
  grid-template-columns: 34px minmax(0, 1fr);
  align-items: center;
  gap: 9px;
  width: 100%;
  min-height: 46px;
  padding: 6px 8px;
  border: 1px solid transparent;
  border-radius: 12px;
  background: transparent;
  color: #2a1d10;
  text-align: left;
  cursor: pointer;
}

.side_drawer_account_row:hover,
.side_drawer_account_row:focus {
  border-color: rgba(255, 190, 51, 0.2);
  background: rgba(255, 190, 51, 0.12);
  color: #1f160a;
  outline: none;
}

.side_drawer_account_avatar {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 34px;
  height: 34px;
  border-radius: 50%;
  background: rgba(255, 190, 51, 0.18);
  color: #8a5a00;
  overflow: hidden;
}

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

.side_drawer_account_text {
  min-width: 0;
  display: grid;
  gap: 2px;
}

.side_drawer_account_text strong,
.side_drawer_account_text small {
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.side_drawer_account_text strong {
  color: inherit;
  font-size: 13.5px;
  font-weight: 800;
  line-height: 1.15;
}

.side_drawer_account_text small {
  color: rgba(52, 39, 25, 0.66);
  font-size: 11.5px;
  font-weight: 700;
  line-height: 1.2;
}

html[data-theme="dark"] .custom_nav-container.minimal_navbar .minimal_nav_actions .cart_link,
body.theme_dark .custom_nav-container.minimal_navbar .minimal_nav_actions .cart_link,
html[data-theme="dark"] .custom_nav-container.minimal_navbar .minimal_nav_actions .nav_search-btn,
body.theme_dark .custom_nav-container.minimal_navbar .minimal_nav_actions .nav_search-btn,
html[data-theme="dark"] .custom_nav-container.minimal_navbar .minimal_nav_actions .theme_toggle,
body.theme_dark .custom_nav-container.minimal_navbar .minimal_nav_actions .theme_toggle,
html[data-theme="dark"] .custom_nav-container.minimal_navbar .minimal_nav_actions .auth_button,
body.theme_dark .custom_nav-container.minimal_navbar .minimal_nav_actions .auth_button,
html[data-theme="dark"] .custom_nav-container.minimal_navbar .minimal_nav_actions .language-btn,
body.theme_dark .custom_nav-container.minimal_navbar .minimal_nav_actions .language-btn,
html[data-theme="dark"] .custom_nav-container.minimal_navbar .minimal_nav_actions .navbar-toggler,
body.theme_dark .custom_nav-container.minimal_navbar .minimal_nav_actions .navbar-toggler {
  border-color: rgba(242, 199, 107, 0.18) !important;
  background: rgba(37, 30, 22, 0.9) !important;
  color: #f2c76b !important;
  box-shadow: 0 10px 24px rgba(0, 0, 0, 0.24) !important;
}

html[data-theme="dark"] .site_side_drawer,
body.theme_dark .site_side_drawer {
  border-left-color: rgba(242, 199, 107, 0.18);
  background: linear-gradient(180deg, #211a12 0%, #17120d 100%);
  color: #fff8e8;
  box-shadow: -22px 0 58px rgba(0, 0, 0, 0.32);
}

html[data-theme="dark"] .site_drawer_overlay,
body.theme_dark .site_drawer_overlay {
  background: rgba(6, 5, 4, 0.62);
}

html[data-theme="dark"] .side_drawer_brand,
body.theme_dark .side_drawer_brand,
html[data-theme="dark"] .side_drawer_link,
body.theme_dark .side_drawer_link,
html[data-theme="dark"] .side_drawer_account_row,
body.theme_dark .side_drawer_account_row {
  color: #fff4de;
}

html[data-theme="dark"] .side_drawer_brand:hover,
body.theme_dark .side_drawer_brand:hover,
html[data-theme="dark"] .side_drawer_brand:focus,
body.theme_dark .side_drawer_brand:focus,
html[data-theme="dark"] .side_drawer_link:hover,
body.theme_dark .side_drawer_link:hover,
html[data-theme="dark"] .side_drawer_link:focus,
body.theme_dark .side_drawer_link:focus,
html[data-theme="dark"] .side_drawer_account_row:hover,
body.theme_dark .side_drawer_account_row:hover,
html[data-theme="dark"] .side_drawer_account_row:focus,
body.theme_dark .side_drawer_account_row:focus,
html[data-theme="dark"] .side_drawer_link.is_active,
body.theme_dark .side_drawer_link.is_active {
  border-color: rgba(242, 199, 107, 0.2);
  background: rgba(242, 199, 107, 0.12);
  color: #fff8e8;
}

html[data-theme="dark"] .side_drawer_icon,
body.theme_dark .side_drawer_icon,
html[data-theme="dark"] .side_drawer_brand_arrow,
body.theme_dark .side_drawer_brand_arrow {
  color: #f2c76b;
}

html[data-theme="dark"] .side_drawer_footer,
body.theme_dark .side_drawer_footer {
  border-top-color: rgba(242, 199, 107, 0.15);
}

html[data-theme="dark"] .side_drawer_account_text small,
body.theme_dark .side_drawer_account_text small {
  color: rgba(255, 248, 232, 0.62);
}

@media (max-width: 575px) {
  .header_section .container {
    width: calc(100% - 12px);
    padding-left: 8px;
    padding-right: 8px;
  }

  .custom_nav-container.minimal_navbar {
    gap: 6px !important;
  }

  .custom_nav-container.minimal_navbar .navbar-brand {
    gap: 6px !important;
  }

  .custom_nav-container.minimal_navbar .navbar-brand img {
    width: 36px !important;
    height: 36px !important;
  }

  .custom_nav-container.minimal_navbar .navbar-brand span {
    max-width: 0;
    width: 0;
    overflow: hidden;
    font-size: 0 !important;
    text-overflow: ellipsis;
    white-space: nowrap;
  }

  .custom_nav-container.minimal_navbar .minimal_nav_actions {
    gap: 4px !important;
    position: fixed !important;
    top: 21px !important;
    right: 14px !important;
    left: auto !important;
    transform: none !important;
    z-index: 98 !important;
  }

  .custom_nav-container.minimal_navbar .minimal_nav_actions .cart_link,
  .custom_nav-container.minimal_navbar .minimal_nav_actions .nav_search-btn,
  .custom_nav-container.minimal_navbar .minimal_nav_actions .theme_toggle,
  .custom_nav-container.minimal_navbar .minimal_nav_actions .auth_button,
  .custom_nav-container.minimal_navbar .minimal_nav_actions .language-btn,
  .custom_nav-container.minimal_navbar .minimal_nav_actions .navbar-toggler {
    width: 34px !important;
    min-width: 34px !important;
    max-width: 34px !important;
    height: 34px !important;
    min-height: 34px !important;
    border-radius: 10px !important;
  }

  .custom_nav-container.minimal_navbar .minimal_nav_actions .auth_avatar {
    width: 24px !important;
    min-width: 24px !important;
    height: 24px !important;
  }

  .custom_nav-container.minimal_navbar .minimal_nav_actions .cart_link svg {
    width: 15px !important;
    height: 15px !important;
  }

  .custom_nav-container.minimal_navbar .minimal_nav_actions .nav_search-btn i,
  .custom_nav-container.minimal_navbar .minimal_nav_actions .theme_toggle_icon::before,
  .custom_nav-container.minimal_navbar .minimal_nav_actions .lang-icon::before,
  .custom_nav-container.minimal_navbar .minimal_nav_actions .auth_avatar i {
    font-size: 13px !important;
  }
}

@media (max-width: 380px) {
  .custom_nav-container.minimal_navbar .navbar-brand span {
    max-width: 0;
    width: 0;
  }
}

/* Final dark-mode surface normalization */
html[data-theme="dark"] body,
body.theme_dark,
body.dark-mode {
  background-color: var(--bg-color, #121212);
  color: var(--dark-text, #fff8e8);
}

html[data-theme="dark"] .product_details_section,
html[data-theme="dark"] .product_story_section,
html[data-theme="dark"] .product_reviews_section,
html[data-theme="dark"] .product_recommendations_section,
html[data-theme="dark"] .wishlist_section,
html[data-theme="dark"] .offers_page_section,
body.theme_dark .product_details_section,
body.theme_dark .product_story_section,
body.theme_dark .product_reviews_section,
body.theme_dark .product_recommendations_section,
body.theme_dark .wishlist_section,
body.theme_dark .offers_page_section,
body.dark-mode .product_details_section,
body.dark-mode .product_story_section,
body.dark-mode .product_reviews_section,
body.dark-mode .product_recommendations_section,
body.dark-mode .wishlist_section,
body.dark-mode .offers_page_section {
  background: radial-gradient(circle at top left, rgba(242, 199, 107, 0.1), transparent 34%), #121212 !important;
  color: var(--dark-text, #fff8e8) !important;
}

html[data-theme="dark"] .product_gallery,
html[data-theme="dark"] .product_info_card,
html[data-theme="dark"] .product_story_card,
html[data-theme="dark"] .reviews_summary_card,
html[data-theme="dark"] .reviews_panel,
html[data-theme="dark"] .review_card,
html[data-theme="dark"] .food_section .box.product-card,
html[data-theme="dark"] .recommendation_card,
html[data-theme="dark"] .wishlist_card,
html[data-theme="dark"] .wishlist_empty_state,
html[data-theme="dark"] .offers_page_card,
html[data-theme="dark"] .offers_page_empty,
body.theme_dark .product_gallery,
body.theme_dark .product_info_card,
body.theme_dark .product_story_card,
body.theme_dark .reviews_summary_card,
body.theme_dark .reviews_panel,
body.theme_dark .review_card,
body.theme_dark .food_section .box.product-card,
body.theme_dark .recommendation_card,
body.theme_dark .wishlist_card,
body.theme_dark .wishlist_empty_state,
body.theme_dark .offers_page_card,
body.theme_dark .offers_page_empty,
body.dark-mode .product_gallery,
body.dark-mode .product_info_card,
body.dark-mode .product_story_card,
body.dark-mode .reviews_summary_card,
body.dark-mode .reviews_panel,
body.dark-mode .review_card,
body.dark-mode .food_section .box.product-card,
body.dark-mode .recommendation_card,
body.dark-mode .wishlist_card,
body.dark-mode .wishlist_empty_state,
body.dark-mode .offers_page_card,
body.dark-mode .offers_page_empty {
  background: linear-gradient(180deg, rgba(31, 27, 22, 0.98), rgba(20, 18, 16, 0.98)) !important;
  border-color: var(--dark-border, rgba(242, 199, 107, 0.22)) !important;
  box-shadow: var(--dark-shadow, 0 18px 42px rgba(0, 0, 0, 0.34)) !important;
  color: var(--dark-text, #fff8e8) !important;
}

html[data-theme="dark"] .product_main_image,
html[data-theme="dark"] .product_thumbs .thumb_btn,
html[data-theme="dark"] .product_rating_meta,
html[data-theme="dark"] .product_meta_section,
html[data-theme="dark"] .product_spec_row,
html[data-theme="dark"] .product_lightbox_dialog,
html[data-theme="dark"] .recommendation_card_body,
html[data-theme="dark"] .wishlist_card_body,
html[data-theme="dark"] .offers_page_body,
body.theme_dark .product_main_image,
body.theme_dark .product_thumbs .thumb_btn,
body.theme_dark .product_rating_meta,
body.theme_dark .product_meta_section,
body.theme_dark .product_spec_row,
body.theme_dark .product_lightbox_dialog,
body.theme_dark .recommendation_card_body,
body.theme_dark .wishlist_card_body,
body.theme_dark .offers_page_body,
body.dark-mode .product_main_image,
body.dark-mode .product_thumbs .thumb_btn,
body.dark-mode .product_rating_meta,
body.dark-mode .product_meta_section,
body.dark-mode .product_spec_row,
body.dark-mode .product_lightbox_dialog,
body.dark-mode .recommendation_card_body,
body.dark-mode .wishlist_card_body,
body.dark-mode .offers_page_body {
  background: var(--dark-surface-soft, rgba(255, 248, 232, 0.065)) !important;
  border-color: var(--dark-border, rgba(242, 199, 107, 0.22)) !important;
  color: var(--dark-text, #fff8e8) !important;
}

html[data-theme="dark"] .product_info_card h1,
html[data-theme="dark"] .product_info_card h2,
html[data-theme="dark"] .product_info_card h3,
html[data-theme="dark"] .product_info_card h4,
html[data-theme="dark"] .product_info_card h5,
html[data-theme="dark"] .product_info_card h6,
html[data-theme="dark"] .product_story_card h2,
html[data-theme="dark"] .product_story_card h3,
html[data-theme="dark"] .product_story_card h4,
html[data-theme="dark"] .reviews_summary_card h2,
html[data-theme="dark"] .reviews_panel h3,
html[data-theme="dark"] .food_section .box.product-card .detail-box h5,
html[data-theme="dark"] .food_section .box.product-card .detail-box h5 a,
html[data-theme="dark"] .food_section .box.product-card .detail-box h6,
html[data-theme="dark"] .recommendation_card_copy h3,
html[data-theme="dark"] .recommendation_card_copy h3 a,
html[data-theme="dark"] .recommendation_card_price,
html[data-theme="dark"] .wishlist_card h3,
html[data-theme="dark"] .wishlist_card h3 a,
html[data-theme="dark"] .wishlist_card_footer strong,
html[data-theme="dark"] .wishlist_empty_state h3,
html[data-theme="dark"] .offers_page_body h3,
html[data-theme="dark"] .offers_page_price_row strong,
html[data-theme="dark"] #unitPrice,
html[data-theme="dark"] #totalPrice,
body.theme_dark .product_info_card h1,
body.theme_dark .product_info_card h2,
body.theme_dark .product_info_card h3,
body.theme_dark .product_info_card h4,
body.theme_dark .product_info_card h5,
body.theme_dark .product_info_card h6,
body.theme_dark .product_story_card h2,
body.theme_dark .product_story_card h3,
body.theme_dark .product_story_card h4,
body.theme_dark .reviews_summary_card h2,
body.theme_dark .reviews_panel h3,
body.theme_dark .food_section .box.product-card .detail-box h5,
body.theme_dark .food_section .box.product-card .detail-box h5 a,
body.theme_dark .food_section .box.product-card .detail-box h6,
body.theme_dark .recommendation_card_copy h3,
body.theme_dark .recommendation_card_copy h3 a,
body.theme_dark .recommendation_card_price,
body.theme_dark .wishlist_card h3,
body.theme_dark .wishlist_card h3 a,
body.theme_dark .wishlist_card_footer strong,
body.theme_dark .wishlist_empty_state h3,
body.theme_dark .offers_page_body h3,
body.theme_dark .offers_page_price_row strong,
body.theme_dark #unitPrice,
body.theme_dark #totalPrice,
body.dark-mode .product_info_card h1,
body.dark-mode .product_info_card h2,
body.dark-mode .product_info_card h3,
body.dark-mode .product_info_card h4,
body.dark-mode .product_info_card h5,
body.dark-mode .product_info_card h6,
body.dark-mode .product_story_card h2,
body.dark-mode .product_story_card h3,
body.dark-mode .product_story_card h4,
body.dark-mode .reviews_summary_card h2,
body.dark-mode .reviews_panel h3,
body.dark-mode .food_section .box.product-card .detail-box h5,
body.dark-mode .food_section .box.product-card .detail-box h5 a,
body.dark-mode .food_section .box.product-card .detail-box h6,
body.dark-mode .recommendation_card_copy h3,
body.dark-mode .recommendation_card_copy h3 a,
body.dark-mode .recommendation_card_price,
body.dark-mode .wishlist_card h3,
body.dark-mode .wishlist_card h3 a,
body.dark-mode .wishlist_card_footer strong,
body.dark-mode .wishlist_empty_state h3,
body.dark-mode .offers_page_body h3,
body.dark-mode .offers_page_price_row strong,
body.dark-mode #unitPrice,
body.dark-mode #totalPrice {
  color: var(--dark-text, #fff8e8) !important;
}

html[data-theme="dark"] .product_info_card p,
html[data-theme="dark"] .product_story_body,
html[data-theme="dark"] .product_story_body p,
html[data-theme="dark"] .product_story_list li,
html[data-theme="dark"] .product_feature_list li,
html[data-theme="dark"] .product_spec_row dd,
html[data-theme="dark"] .reviews_summary_text,
html[data-theme="dark"] .review_card p,
html[data-theme="dark"] .food_section .box.product-card .detail-box p,
html[data-theme="dark"] .recommendation_card_copy p,
html[data-theme="dark"] .recommendation_card_rating,
html[data-theme="dark"] .wishlist_card p,
html[data-theme="dark"] .wishlist_empty_state p,
html[data-theme="dark"] .offers_page_category,
html[data-theme="dark"] .offers_page_rating,
html[data-theme="dark"] .offers_page_price_row del,
body.theme_dark .product_info_card p,
body.theme_dark .product_story_body,
body.theme_dark .product_story_body p,
body.theme_dark .product_story_list li,
body.theme_dark .product_feature_list li,
body.theme_dark .product_spec_row dd,
body.theme_dark .reviews_summary_text,
body.theme_dark .review_card p,
body.theme_dark .food_section .box.product-card .detail-box p,
body.theme_dark .recommendation_card_copy p,
body.theme_dark .recommendation_card_rating,
body.theme_dark .wishlist_card p,
body.theme_dark .wishlist_empty_state p,
body.theme_dark .offers_page_category,
body.theme_dark .offers_page_rating,
body.theme_dark .offers_page_price_row del,
body.dark-mode .product_info_card p,
body.dark-mode .product_story_body,
body.dark-mode .product_story_body p,
body.dark-mode .product_story_list li,
body.dark-mode .product_feature_list li,
body.dark-mode .product_spec_row dd,
body.dark-mode .reviews_summary_text,
body.dark-mode .review_card p,
body.dark-mode .food_section .box.product-card .detail-box p,
body.dark-mode .recommendation_card_copy p,
body.dark-mode .recommendation_card_rating,
body.dark-mode .wishlist_card p,
body.dark-mode .wishlist_empty_state p,
body.dark-mode .offers_page_category,
body.dark-mode .offers_page_rating,
body.dark-mode .offers_page_price_row del {
  color: var(--dark-text-soft, #e5d8c3) !important;
}

html[data-theme="dark"] .product_category_label,
html[data-theme="dark"] .recommendation_card_label,
html[data-theme="dark"] .wishlist_card_category,
html[data-theme="dark"] .offers_page_badge,
html[data-theme="dark"] .offers_page_count,
body.theme_dark .product_category_label,
body.theme_dark .recommendation_card_label,
body.theme_dark .wishlist_card_category,
body.theme_dark .offers_page_badge,
body.theme_dark .offers_page_count,
body.dark-mode .product_category_label,
body.dark-mode .recommendation_card_label,
body.dark-mode .wishlist_card_category,
body.dark-mode .offers_page_badge,
body.dark-mode .offers_page_count {
  background: rgba(242, 199, 107, 0.14) !important;
  border-color: var(--dark-border, rgba(242, 199, 107, 0.22)) !important;
  color: var(--dark-gold-strong, #ffe09a) !important;
}

html[data-theme="dark"] .product-link-btn,
html[data-theme="dark"] .recommendation_link,
html[data-theme="dark"] .recommendation_add_btn,
html[data-theme="dark"] .offers_page_view_btn,
html[data-theme="dark"] .wishlist_empty_btn,
html[data-theme="dark"] .wishlist_view_btn,
html[data-theme="dark"] .wishlist_add_btn,
html[data-theme="dark"] .wishlist_remove_btn,
html[data-theme="dark"] .product_cart_primary_btn,
html[data-theme="dark"] .product_checkout_btn,
html[data-theme="dark"] .footer_section .footer_policy_links a,
body.theme_dark .product-link-btn,
body.theme_dark .recommendation_link,
body.theme_dark .recommendation_add_btn,
body.theme_dark .offers_page_view_btn,
body.theme_dark .wishlist_empty_btn,
body.theme_dark .wishlist_view_btn,
body.theme_dark .wishlist_add_btn,
body.theme_dark .wishlist_remove_btn,
body.theme_dark .product_cart_primary_btn,
body.theme_dark .product_checkout_btn,
body.theme_dark .footer_section .footer_policy_links a,
body.dark-mode .product-link-btn,
body.dark-mode .recommendation_link,
body.dark-mode .recommendation_add_btn,
body.dark-mode .offers_page_view_btn,
body.dark-mode .wishlist_empty_btn,
body.dark-mode .wishlist_view_btn,
body.dark-mode .wishlist_add_btn,
body.dark-mode .wishlist_remove_btn,
body.dark-mode .product_cart_primary_btn,
body.dark-mode .product_checkout_btn,
body.dark-mode .footer_section .footer_policy_links a {
  background: linear-gradient(135deg, rgba(242, 199, 107, 0.22), rgba(180, 125, 25, 0.16)) !important;
  border: 1px solid var(--dark-border-strong, rgba(242, 199, 107, 0.48)) !important;
  color: var(--dark-gold-strong, #ffe09a) !important;
  box-shadow: 0 10px 24px rgba(0, 0, 0, 0.24), inset 0 1px 0 rgba(255, 248, 232, 0.08) !important;
  text-shadow: none !important;
}

html[data-theme="dark"] .product-link-btn:hover,
html[data-theme="dark"] .product-link-btn:focus,
html[data-theme="dark"] .recommendation_link:hover,
html[data-theme="dark"] .recommendation_link:focus,
html[data-theme="dark"] .recommendation_add_btn:hover,
html[data-theme="dark"] .recommendation_add_btn:focus,
html[data-theme="dark"] .offers_page_view_btn:hover,
html[data-theme="dark"] .offers_page_view_btn:focus,
html[data-theme="dark"] .wishlist_empty_btn:hover,
html[data-theme="dark"] .wishlist_empty_btn:focus,
html[data-theme="dark"] .wishlist_view_btn:hover,
html[data-theme="dark"] .wishlist_view_btn:focus,
html[data-theme="dark"] .wishlist_add_btn:hover,
html[data-theme="dark"] .wishlist_add_btn:focus,
html[data-theme="dark"] .wishlist_remove_btn:hover,
html[data-theme="dark"] .wishlist_remove_btn:focus,
html[data-theme="dark"] .product_cart_primary_btn:hover,
html[data-theme="dark"] .product_cart_primary_btn:focus,
html[data-theme="dark"] .product_checkout_btn:hover,
html[data-theme="dark"] .product_checkout_btn:focus,
html[data-theme="dark"] .footer_section .footer_policy_links a:hover,
html[data-theme="dark"] .footer_section .footer_policy_links a:focus,
body.theme_dark .product-link-btn:hover,
body.theme_dark .product-link-btn:focus,
body.theme_dark .recommendation_link:hover,
body.theme_dark .recommendation_link:focus,
body.theme_dark .recommendation_add_btn:hover,
body.theme_dark .recommendation_add_btn:focus,
body.theme_dark .offers_page_view_btn:hover,
body.theme_dark .offers_page_view_btn:focus,
body.theme_dark .wishlist_empty_btn:hover,
body.theme_dark .wishlist_empty_btn:focus,
body.theme_dark .wishlist_view_btn:hover,
body.theme_dark .wishlist_view_btn:focus,
body.theme_dark .wishlist_add_btn:hover,
body.theme_dark .wishlist_add_btn:focus,
body.theme_dark .wishlist_remove_btn:hover,
body.theme_dark .wishlist_remove_btn:focus,
body.theme_dark .product_cart_primary_btn:hover,
body.theme_dark .product_cart_primary_btn:focus,
body.theme_dark .product_checkout_btn:hover,
body.theme_dark .product_checkout_btn:focus,
body.theme_dark .footer_section .footer_policy_links a:hover,
body.theme_dark .footer_section .footer_policy_links a:focus,
body.dark-mode .product-link-btn:hover,
body.dark-mode .product-link-btn:focus,
body.dark-mode .recommendation_link:hover,
body.dark-mode .recommendation_link:focus,
body.dark-mode .recommendation_add_btn:hover,
body.dark-mode .recommendation_add_btn:focus,
body.dark-mode .offers_page_view_btn:hover,
body.dark-mode .offers_page_view_btn:focus,
body.dark-mode .wishlist_empty_btn:hover,
body.dark-mode .wishlist_empty_btn:focus,
body.dark-mode .wishlist_view_btn:hover,
body.dark-mode .wishlist_view_btn:focus,
body.dark-mode .wishlist_add_btn:hover,
body.dark-mode .wishlist_add_btn:focus,
body.dark-mode .wishlist_remove_btn:hover,
body.dark-mode .wishlist_remove_btn:focus,
body.dark-mode .product_cart_primary_btn:hover,
body.dark-mode .product_cart_primary_btn:focus,
body.dark-mode .product_checkout_btn:hover,
body.dark-mode .product_checkout_btn:focus,
body.dark-mode .footer_section .footer_policy_links a:hover,
body.dark-mode .footer_section .footer_policy_links a:focus {
  background: linear-gradient(135deg, rgba(242, 199, 107, 0.34), rgba(180, 125, 25, 0.24)) !important;
  border-color: rgba(255, 224, 154, 0.72) !important;
  color: #fff8e8 !important;
  box-shadow: 0 14px 30px rgba(0, 0, 0, 0.32), 0 0 22px rgba(242, 199, 107, 0.14) !important;
}

html[data-theme="dark"] .product-wishlist-btn,
html[data-theme="dark"] .product-share-btn,
html[data-theme="dark"] .product_favorite_detail_btn,
html[data-theme="dark"] .product_share_detail_btn,
html[data-theme="dark"] .offers_page_wishlist_btn,
html[data-theme="dark"] .recommendation_wishlist_btn,
html[data-theme="dark"] .wishlist_empty_icon,
body.theme_dark .product-wishlist-btn,
body.theme_dark .product-share-btn,
body.theme_dark .product_favorite_detail_btn,
body.theme_dark .product_share_detail_btn,
body.theme_dark .offers_page_wishlist_btn,
body.theme_dark .recommendation_wishlist_btn,
body.theme_dark .wishlist_empty_icon,
body.dark-mode .product-wishlist-btn,
body.dark-mode .product-share-btn,
body.dark-mode .product_favorite_detail_btn,
body.dark-mode .product_share_detail_btn,
body.dark-mode .offers_page_wishlist_btn,
body.dark-mode .recommendation_wishlist_btn,
body.dark-mode .wishlist_empty_icon {
  background: rgba(31, 27, 22, 0.94) !important;
  border-color: var(--dark-border-strong, rgba(242, 199, 107, 0.48)) !important;
  color: var(--dark-gold-strong, #ffe09a) !important;
  box-shadow: 0 10px 24px rgba(0, 0, 0, 0.3) !important;
}

html[data-theme="dark"] .product-wishlist-btn:hover,
html[data-theme="dark"] .product-wishlist-btn:focus,
html[data-theme="dark"] .product-wishlist-btn.is_active,
html[data-theme="dark"] .product-share-btn:hover,
html[data-theme="dark"] .product-share-btn:focus,
html[data-theme="dark"] .product_favorite_detail_btn:hover,
html[data-theme="dark"] .product_favorite_detail_btn:focus,
html[data-theme="dark"] .product_favorite_detail_btn.is_active,
html[data-theme="dark"] .product_share_detail_btn:hover,
html[data-theme="dark"] .product_share_detail_btn:focus,
body.theme_dark .product-wishlist-btn:hover,
body.theme_dark .product-wishlist-btn:focus,
body.theme_dark .product-wishlist-btn.is_active,
body.theme_dark .product-share-btn:hover,
body.theme_dark .product-share-btn:focus,
body.theme_dark .product_favorite_detail_btn:hover,
body.theme_dark .product_favorite_detail_btn:focus,
body.theme_dark .product_favorite_detail_btn.is_active,
body.theme_dark .product_share_detail_btn:hover,
body.theme_dark .product_share_detail_btn:focus,
body.dark-mode .product-wishlist-btn:hover,
body.dark-mode .product-wishlist-btn:focus,
body.dark-mode .product-wishlist-btn.is_active,
body.dark-mode .product-share-btn:hover,
body.dark-mode .product-share-btn:focus,
body.dark-mode .product_favorite_detail_btn:hover,
body.dark-mode .product_favorite_detail_btn:focus,
body.dark-mode .product_favorite_detail_btn.is_active,
body.dark-mode .product_share_detail_btn:hover,
body.dark-mode .product_share_detail_btn:focus {
  background: rgba(242, 199, 107, 0.18) !important;
  border-color: rgba(255, 224, 154, 0.72) !important;
  color: #fff8e8 !important;
  box-shadow: 0 12px 28px rgba(0, 0, 0, 0.34), 0 0 20px rgba(242, 199, 107, 0.18) !important;
}

html[data-theme="dark"] .product-wishlist-btn i,
html[data-theme="dark"] .product-share-btn i,
html[data-theme="dark"] .product_favorite_detail_btn i,
html[data-theme="dark"] .product_share_detail_btn i,
html[data-theme="dark"] .wishlist_empty_icon i,
body.theme_dark .product-wishlist-btn i,
body.theme_dark .product-share-btn i,
body.theme_dark .product_favorite_detail_btn i,
body.theme_dark .product_share_detail_btn i,
body.theme_dark .wishlist_empty_icon i,
body.dark-mode .product-wishlist-btn i,
body.dark-mode .product-share-btn i,
body.dark-mode .product_favorite_detail_btn i,
body.dark-mode .product_share_detail_btn i,
body.dark-mode .wishlist_empty_icon i {
  color: currentColor !important;
}

/* Mobile dark-mode contrast fixes for product cards, footer links, product detail, and empty states */
html[data-theme="dark"] .food_section .box.product-card .options .product-link-btn,
html[data-theme="dark"] .product-card .product-link-btn,
html[data-theme="dark"] .product-card .recommendation_link,
html[data-theme="dark"] .product-card [class*="view"],
html[data-theme="dark"] .product-card [class*="details"],
body.theme_dark .food_section .box.product-card .options .product-link-btn,
body.theme_dark .product-card .product-link-btn,
body.theme_dark .product-card .recommendation_link,
body.theme_dark .product-card [class*="view"],
body.theme_dark .product-card [class*="details"],
body.dark-mode .food_section .box.product-card .options .product-link-btn,
body.dark-mode .product-card .product-link-btn,
body.dark-mode .product-card .recommendation_link,
body.dark-mode .product-card [class*="view"],
body.dark-mode .product-card [class*="details"] {
  background: rgba(255, 255, 255, 0.12) !important;
  border: 1.5px solid rgba(255, 255, 255, 0.2) !important;
  color: #f0f0f0 !important;
  box-shadow: none !important;
}

html[data-theme="dark"] .food_section .box.product-card .options .product-link-btn:hover,
html[data-theme="dark"] .product-card .product-link-btn:hover,
html[data-theme="dark"] .product-card .product-link-btn:focus,
html[data-theme="dark"] .product-card .recommendation_link:hover,
html[data-theme="dark"] .product-card .recommendation_link:focus,
body.theme_dark .food_section .box.product-card .options .product-link-btn:hover,
body.theme_dark .product-card .product-link-btn:hover,
body.theme_dark .product-card .product-link-btn:focus,
body.theme_dark .product-card .recommendation_link:hover,
body.theme_dark .product-card .recommendation_link:focus,
body.dark-mode .food_section .box.product-card .options .product-link-btn:hover,
body.dark-mode .product-card .product-link-btn:hover,
body.dark-mode .product-card .product-link-btn:focus,
body.dark-mode .product-card .recommendation_link:hover,
body.dark-mode .product-card .recommendation_link:focus {
  background: rgba(255, 255, 255, 0.2) !important;
  color: #ffffff !important;
}

html[data-theme="dark"] .product-card .recommendation_add_btn,
html[data-theme="dark"] .product-card [class*="add"],
body.theme_dark .product-card .recommendation_add_btn,
body.theme_dark .product-card [class*="add"],
body.dark-mode .product-card .recommendation_add_btn,
body.dark-mode .product-card [class*="add"] {
  background: #ffbe33 !important;
  border: none !important;
  color: #ffffff !important;
}

html[data-theme="dark"] .footer_section .footer_policy_links a,
body.theme_dark .footer_section .footer_policy_links a,
body.dark-mode .footer_section .footer_policy_links a {
  background: rgba(255, 255, 255, 0.06) !important;
  border-color: rgba(255, 255, 255, 0.15) !important;
  color: #e0e0e0 !important;
}

html[data-theme="dark"] .footer_section .footer_policy_links a::before,
body.theme_dark .footer_section .footer_policy_links a::before,
body.dark-mode .footer_section .footer_policy_links a::before {
  background: #ffbe33 !important;
  opacity: 1 !important;
}

html[data-theme="dark"] .footer_section .footer_policy_links a:hover,
html[data-theme="dark"] .footer_section .footer_policy_links a:focus,
body.theme_dark .footer_section .footer_policy_links a:hover,
body.theme_dark .footer_section .footer_policy_links a:focus,
body.dark-mode .footer_section .footer_policy_links a:hover,
body.dark-mode .footer_section .footer_policy_links a:focus {
  background: rgba(255, 255, 255, 0.1) !important;
  color: #ffffff !important;
}

html[data-theme="dark"] body.product-page,
body.theme_dark.product-page,
body.dark-mode.product-page {
  background: #121212 !important;
  color: #e0e0e0 !important;
}

html[data-theme="dark"] body.product-page .product_details_section,
html[data-theme="dark"] body.product-page .product_story_section,
html[data-theme="dark"] body.product-page .product_reviews_section,
html[data-theme="dark"] body.product-page .product_recommendations_section,
body.theme_dark.product-page .product_details_section,
body.theme_dark.product-page .product_story_section,
body.theme_dark.product-page .product_reviews_section,
body.theme_dark.product-page .product_recommendations_section,
body.dark-mode.product-page .product_details_section,
body.dark-mode.product-page .product_story_section,
body.dark-mode.product-page .product_reviews_section,
body.dark-mode.product-page .product_recommendations_section {
  background: #121212 !important;
  color: #e0e0e0 !important;
}

html[data-theme="dark"] body.product-page .product_gallery,
html[data-theme="dark"] body.product-page .product_info_card,
html[data-theme="dark"] body.product-page .product_story_card,
html[data-theme="dark"] body.product-page .reviews_summary_card,
html[data-theme="dark"] body.product-page .reviews_panel,
html[data-theme="dark"] body.product-page .review_card,
body.theme_dark.product-page .product_gallery,
body.theme_dark.product-page .product_info_card,
body.theme_dark.product-page .product_story_card,
body.theme_dark.product-page .reviews_summary_card,
body.theme_dark.product-page .reviews_panel,
body.theme_dark.product-page .review_card,
body.dark-mode.product-page .product_gallery,
body.dark-mode.product-page .product_info_card,
body.dark-mode.product-page .product_story_card,
body.dark-mode.product-page .reviews_summary_card,
body.dark-mode.product-page .reviews_panel,
body.dark-mode.product-page .review_card {
  background: rgba(255, 255, 255, 0.04) !important;
  border-color: rgba(255, 255, 255, 0.08) !important;
  color: #e0e0e0 !important;
}

html[data-theme="dark"] body.product-page .product_main_image,
html[data-theme="dark"] body.product-page .thumb_btn,
html[data-theme="dark"] body.product-page .product_meta_section,
html[data-theme="dark"] body.product-page .product_spec_row,
html[data-theme="dark"] body.product-page .product_rating_meta,
body.theme_dark.product-page .product_main_image,
body.theme_dark.product-page .thumb_btn,
body.theme_dark.product-page .product_meta_section,
body.theme_dark.product-page .product_spec_row,
body.theme_dark.product-page .product_rating_meta,
body.dark-mode.product-page .product_main_image,
body.dark-mode.product-page .thumb_btn,
body.dark-mode.product-page .product_meta_section,
body.dark-mode.product-page .product_spec_row,
body.dark-mode.product-page .product_rating_meta {
  background: #2a2a2a !important;
  border-color: rgba(255, 255, 255, 0.12) !important;
  color: #cccccc !important;
}

html[data-theme="dark"] body.product-page .thumb_btn.active,
html[data-theme="dark"] body.product-page .thumb_btn.is_active,
body.theme_dark.product-page .thumb_btn.active,
body.theme_dark.product-page .thumb_btn.is_active,
body.dark-mode.product-page .thumb_btn.active,
body.dark-mode.product-page .thumb_btn.is_active {
  border-color: #ffbe33 !important;
}

html[data-theme="dark"] body.product-page h1,
html[data-theme="dark"] body.product-page h2,
html[data-theme="dark"] body.product-page h3,
html[data-theme="dark"] body.product-page h4,
html[data-theme="dark"] body.product-page .product_story_title,
html[data-theme="dark"] body.product-page .rating_overview_score,
html[data-theme="dark"] body.product-page .review_card_identity strong,
body.theme_dark.product-page h1,
body.theme_dark.product-page h2,
body.theme_dark.product-page h3,
body.theme_dark.product-page h4,
body.theme_dark.product-page .product_story_title,
body.theme_dark.product-page .rating_overview_score,
body.theme_dark.product-page .review_card_identity strong,
body.dark-mode.product-page h1,
body.dark-mode.product-page h2,
body.dark-mode.product-page h3,
body.dark-mode.product-page h4,
body.dark-mode.product-page .product_story_title,
body.dark-mode.product-page .rating_overview_score,
body.dark-mode.product-page .review_card_identity strong {
  color: #f0f0f0 !important;
}

html[data-theme="dark"] body.product-page #productDescription,
html[data-theme="dark"] body.product-page .product_story_lead,
html[data-theme="dark"] body.product-page .product_story_body,
html[data-theme="dark"] body.product-page .product_story_body p,
html[data-theme="dark"] body.product-page .product_story_body li,
html[data-theme="dark"] body.product-page .product_feature_list li,
html[data-theme="dark"] body.product-page .product_spec_row,
html[data-theme="dark"] body.product-page .product_spec_row dt,
html[data-theme="dark"] body.product-page .product_spec_row dd,
html[data-theme="dark"] body.product-page .reviews_summary_text,
html[data-theme="dark"] body.product-page .review_card p,
body.theme_dark.product-page #productDescription,
body.theme_dark.product-page .product_story_lead,
body.theme_dark.product-page .product_story_body,
body.theme_dark.product-page .product_story_body p,
body.theme_dark.product-page .product_story_body li,
body.theme_dark.product-page .product_feature_list li,
body.theme_dark.product-page .product_spec_row,
body.theme_dark.product-page .product_spec_row dt,
body.theme_dark.product-page .product_spec_row dd,
body.theme_dark.product-page .reviews_summary_text,
body.theme_dark.product-page .review_card p,
body.dark-mode.product-page #productDescription,
body.dark-mode.product-page .product_story_lead,
body.dark-mode.product-page .product_story_body,
body.dark-mode.product-page .product_story_body p,
body.dark-mode.product-page .product_story_body li,
body.dark-mode.product-page .product_feature_list li,
body.dark-mode.product-page .product_spec_row,
body.dark-mode.product-page .product_spec_row dt,
body.dark-mode.product-page .product_spec_row dd,
body.dark-mode.product-page .reviews_summary_text,
body.dark-mode.product-page .review_card p {
  color: #cccccc !important;
}

html[data-theme="dark"] body.product-page .product_meta_section,
body.theme_dark.product-page .product_meta_section,
body.dark-mode.product-page .product_meta_section {
  border-left-color: #ffbe33 !important;
}

html[data-theme="dark"] body.product-page .product_detail_tab,
body.theme_dark.product-page .product_detail_tab,
body.dark-mode.product-page .product_detail_tab {
  background: rgba(255, 255, 255, 0.06) !important;
  border-color: rgba(255, 255, 255, 0.1) !important;
  color: #bbbbbb !important;
}

html[data-theme="dark"] body.product-page .product_detail_tab.active,
body.theme_dark.product-page .product_detail_tab.active,
body.dark-mode.product-page .product_detail_tab.active {
  background: #1a1a1a !important;
  border-color: #ffbe33 !important;
  color: #ffffff !important;
}

html[data-theme="dark"] body.product-page .product_story_block,
body.theme_dark.product-page .product_story_block,
body.dark-mode.product-page .product_story_block {
  border-top-color: rgba(255, 255, 255, 0.08) !important;
}

html[data-theme="dark"] body.product-page .product_story_link,
body.theme_dark.product-page .product_story_link,
body.dark-mode.product-page .product_story_link {
  color: #ffbe33 !important;
}

html[data-theme="dark"] body.product-page .review_card_identity span,
html[data-theme="dark"] body.product-page .review_form_status,
html[data-theme="dark"] body.product-page .review_notice_card p,
html[data-theme="dark"] body.product-page .rating_overview_meta p,
body.theme_dark.product-page .review_card_identity span,
body.theme_dark.product-page .review_form_status,
body.theme_dark.product-page .review_notice_card p,
body.theme_dark.product-page .rating_overview_meta p,
body.dark-mode.product-page .review_card_identity span,
body.dark-mode.product-page .review_form_status,
body.dark-mode.product-page .review_notice_card p,
body.dark-mode.product-page .rating_overview_meta p {
  color: #888888 !important;
}

html[data-theme="dark"] body.product-page .review_form,
html[data-theme="dark"] body.product-page .review_notice_card,
body.theme_dark.product-page .review_form,
body.theme_dark.product-page .review_notice_card,
body.dark-mode.product-page .review_form,
body.dark-mode.product-page .review_notice_card {
  background: rgba(255, 255, 255, 0.04) !important;
  border-color: rgba(255, 255, 255, 0.08) !important;
  border-radius: 16px !important;
}

html[data-theme="dark"] body.product-page .review_field label,
body.theme_dark.product-page .review_field label,
body.dark-mode.product-page .review_field label {
  color: #bbbbbb !important;
}

html[data-theme="dark"] body.product-page .review_field textarea,
body.theme_dark.product-page .review_field textarea,
body.dark-mode.product-page .review_field textarea {
  background: rgba(255, 255, 255, 0.06) !important;
  border-color: rgba(255, 255, 255, 0.12) !important;
  color: #e0e0e0 !important;
}

html[data-theme="dark"] body.product-page .review_field textarea::placeholder,
body.theme_dark.product-page .review_field textarea::placeholder,
body.dark-mode.product-page .review_field textarea::placeholder {
  color: rgba(255, 255, 255, 0.3) !important;
}

html[data-theme="dark"] body.product-page .review_google_signin_btn,
html[data-theme="dark"] body.product-page .review_notice_card .auth_dropdown_btn,
body.theme_dark.product-page .review_google_signin_btn,
body.theme_dark.product-page .review_notice_card .auth_dropdown_btn,
body.dark-mode.product-page .review_google_signin_btn,
body.dark-mode.product-page .review_notice_card .auth_dropdown_btn {
  background: rgba(255, 255, 255, 0.06) !important;
  border-color: rgba(255, 255, 255, 0.15) !important;
  color: #e0e0e0 !important;
}

html[data-theme="dark"] body.product-page .review_star_btn,
body.theme_dark.product-page .review_star_btn,
body.dark-mode.product-page .review_star_btn {
  background: rgba(255, 255, 255, 0.06) !important;
  border-color: rgba(255, 255, 255, 0.12) !important;
  color: #555555 !important;
  opacity: 1 !important;
}

html[data-theme="dark"] body.product-page .review_star_btn.is_active,
html[data-theme="dark"] body.product-page .review_star_btn:hover,
html[data-theme="dark"] body.product-page .review_star_btn:focus,
body.theme_dark.product-page .review_star_btn.is_active,
body.theme_dark.product-page .review_star_btn:hover,
body.theme_dark.product-page .review_star_btn:focus,
body.dark-mode.product-page .review_star_btn.is_active,
body.dark-mode.product-page .review_star_btn:hover,
body.dark-mode.product-page .review_star_btn:focus {
  border-color: rgba(255, 190, 51, 0.45) !important;
  color: #ffbe33 !important;
}

html[data-theme="dark"] body.product-page .rating_stars .fa-star-o,
html[data-theme="dark"] body.product-page .rating_stars_wrap .fa-star-o,
body.theme_dark.product-page .rating_stars .fa-star-o,
body.theme_dark.product-page .rating_stars_wrap .fa-star-o,
body.dark-mode.product-page .rating_stars .fa-star-o,
body.dark-mode.product-page .rating_stars_wrap .fa-star-o {
  color: #555555 !important;
  opacity: 1 !important;
}

html[data-theme="dark"] body.product-page .review_empty_state,
body.theme_dark.product-page .review_empty_state,
body.dark-mode.product-page .review_empty_state {
  background: rgba(255, 255, 255, 0.04) !important;
  border-color: rgba(255, 255, 255, 0.06) !important;
  color: #aaaaaa !important;
}

html[data-theme="dark"] body.product-page .review_empty_state p,
body.theme_dark.product-page .review_empty_state p,
body.dark-mode.product-page .review_empty_state p {
  color: #888888 !important;
}

html[data-theme="dark"] body.product-page .recommendation_card,
html[data-theme="dark"] body.product-page .related-products .product-card,
body.theme_dark.product-page .recommendation_card,
body.theme_dark.product-page .related-products .product-card,
body.dark-mode.product-page .recommendation_card,
body.dark-mode.product-page .related-products .product-card {
  background: #2a2a2a !important;
  border-color: rgba(255, 255, 255, 0.08) !important;
}

html[data-theme="dark"] .wishlist_empty_state,
html[data-theme="dark"] [class*="empty-state"],
body.theme_dark .wishlist_empty_state,
body.theme_dark [class*="empty-state"],
body.dark-mode .wishlist_empty_state,
body.dark-mode [class*="empty-state"] {
  background: rgba(255, 255, 255, 0.04) !important;
  border-color: rgba(255, 255, 255, 0.08) !important;
}

html[data-theme="dark"] .wishlist_empty_btn,
html[data-theme="dark"] [class*="wishlist"] [class*="browse"],
html[data-theme="dark"] [class*="favorites"] [class*="browse"],
body.theme_dark .wishlist_empty_btn,
body.theme_dark [class*="wishlist"] [class*="browse"],
body.theme_dark [class*="favorites"] [class*="browse"],
body.dark-mode .wishlist_empty_btn,
body.dark-mode [class*="wishlist"] [class*="browse"],
body.dark-mode [class*="favorites"] [class*="browse"] {
  background: transparent !important;
  border: 2px solid #ffbe33 !important;
  color: #ffbe33 !important;
  font-weight: 600 !important;
}

html[data-theme="dark"] .wishlist_empty_btn:hover,
html[data-theme="dark"] .wishlist_empty_btn:focus,
body.theme_dark .wishlist_empty_btn:hover,
body.theme_dark .wishlist_empty_btn:focus,
body.dark-mode .wishlist_empty_btn:hover,
body.dark-mode .wishlist_empty_btn:focus {
  background: #ffbe33 !important;
  color: #ffffff !important;
}

html[data-theme="dark"] .wishlist_empty_state h3,
html[data-theme="dark"] .wishlist_empty_state p,
html[data-theme="dark"] [class*="empty-state"] h3,
html[data-theme="dark"] [class*="empty-state"] p,
body.theme_dark .wishlist_empty_state h3,
body.theme_dark .wishlist_empty_state p,
body.theme_dark [class*="empty-state"] h3,
body.theme_dark [class*="empty-state"] p,
body.dark-mode .wishlist_empty_state h3,
body.dark-mode .wishlist_empty_state p,
body.dark-mode [class*="empty-state"] h3,
body.dark-mode [class*="empty-state"] p {
  color: #bbbbbb !important;
}

