/*
 Theme Name:   Twenty Twenty Child
 Theme URI:    https://wordpress.org/themes/twentytwenty/
 Description: Twenty Twenty Child Theme
 Author:       Your Name
 Author URI:   https://yourwebsite.com
 Template:     twentytwenty
 Version:      1.0.0
*/

/* ========== GLOBAL RESPONSIVE BASE ========== */
:root {
  --ppg-container-padding: 24px;
  --ppg-section-padding: 48px;
  --ppg-gap: 24px;
  /* Typography: Montserrat only (web safe) */
  --ppg-font: 'Montserrat', sans-serif;
  --ppg-font-headline: 'Montserrat', sans-serif;
  --ppg-font-subheader: 'Montserrat', sans-serif;
  --ppg-font-body: 'Montserrat', sans-serif;
  --ppg-font-cta: 'Montserrat', sans-serif;
  /* Official color system – black dominant, purple controlled */
  --ppg-black: #0D0D0D;
  --ppg-graphite: #1A1A1A;
  --ppg-purple: #520975;
  /* #0047FF: micro-level ONLY (small icons, focus rings, dots, tiny highlights). NOT for buttons, cards, backgrounds, sections. */
  --ppg-blue-glow: #0047FF;
  --ppg-text: #FFFFFF;
  --ppg-text-secondary: #D9D9D9;
  --ppg-text-muted: #888888;
}

/* Prevent horizontal scroll and ensure touch zoom */
html {
  box-sizing: border-box;
  -webkit-text-size-adjust: 100%;
  font-family: 'Montserrat', sans-serif;
}

*,
*::before,
*::after {
  box-sizing: inherit;
}

/* Fixed header overlays content - no body padding so hero extends to top */
body {
  padding-top: 0 !important;
  overflow-x: hidden;
  margin: 0;
  background: #0D0D0D;
  color: #FFFFFF;
}

/* Allow main content to scroll; prevent horizontal overflow only */
main,
.ppg-main {
  overflow-x: hidden;
  overflow-y: visible;
  max-width: 100vw;
}

/* Remove any unwanted bottom scroll */
.ppg-footer,
footer {
  overflow: hidden;
}

/* Flexible images: scale without distortion */
img {
  max-width: 100%;
  height: auto;
  vertical-align: middle;
}

/* Add your custom CSS below */

/* ========== TEXT DECORATION: NONE GLOBALLY ========== */
a,
button,
[role="button"],
label,
.ppg-card__title a,
.ppg-cardslider__title a,
.ppg-footer__col a,
.ppg-nav__link,
.ppg-signup-link a,
.ppg-forgot,
.ppg-login-page__forgot,
.ppg-faq-accordion__body a,
.ppg-product-card a,
.ppg-add,
input[type="submit"],
.ppg-btn,
.ppg-btn--primary,
.ppg-btn--secondary {
  text-decoration: none !important;
}

a:hover,
button:hover,
.ppg-card__title a:hover,
.ppg-footer__col a:hover,
.ppg-signup-link a:hover,
.ppg-forgot:hover,
.ppg-login-page__forgot:hover {
  text-decoration: none !important;
}

/* ========== TYPOGRAPHY: MONTSERRAT ONLY ========== */
/* Body: Montserrat Regular, sentence case, line-height 120–130% */
body,
main,
.ppg-main,
p,
input,
textarea,
select,
label {
  font-family: var(--ppg-font-body);
  font-weight: 400;
  line-height: 1.25;
}

/* Headlines: Montserrat Bold, Uppercase, letter-spacing 2–4%, line-height 110% */
h1,
h2,
h3,
h4,
h5,
h6,
.ppg-hero__title,
.ppg-section__title,
.ppg-subscription-page__title,
.ppg-faq__title,
.ppg-delivery-calendar__heading,
.ppg-login-page__title,
.ppg-signup-page__title,
.archive-title,
.entry-title {
  font-family: var(--ppg-font-headline);
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.03em;
  line-height: 1.1;
}

/* Subheaders: Montserrat SemiBold, title case, line-height 115% */
.ppg-section__subtitle,
.ppg-subscription-page__subtitle,
.ppg-subscription-form__step-title,
.ppg-step__title,
.ppg-card__title,
.ppg-product-card__title,
.ppg-mealpack-card__title,
.ppg-modal__title,
.ppg-profile-section__title,
.archive-subtitle {
  font-family: var(--ppg-font-subheader);
  font-weight: 600;
  text-transform: capitalize;
  line-height: 1.15;
}

/* CTA: Montserrat Bold, Uppercase */
.ppg-btn,
.ppg-btn--primary,
.ppg-btn--secondary,
.ppg-hero__cta,
.ppg-banner__cta,
.ppg-offerCard__btn,
.ppg-newsletter__btn,
.ppg-product-card__btn,
.ppg-header__cta-btn,
.ppg-subscription-cta__btn,
.ppg-subscription-page__btn,
.ppg-login-page__submit,
.ppg-signup-page__submit,
.ppg-cutoff-timer__btn,
.ppg-add,
button[type="submit"],
input[type="submit"],
.wc-block-components-button,
.ppg-subscription-form__option,
.ppg-members-list-controls__btn,
.ppg-edit-member-modal__btn,
.ppg-mealpack-card__info-btn,
.ppg-select-meals__btn {
  font-family: var(--ppg-font-cta);
  font-weight: 700;
  text-transform: uppercase;
}

h2.ppg-section__title {
  max-width: 668px !important;
  margin: 0 auto !important;
}

/* ========== BUTTON HOVER EFFECTS DISABLED ========== */
/* All hover animations, pulse, glow, and style changes removed */
/* Buttons remain static on hover */

/* ========== BUTTONS: MAX 4px BORDER RADIUS (Visual Hierarchy) ========== */
button,
input[type="button"],
input[type="submit"],
input[type="reset"],
[role="button"],
.ppg-btn,
.ppg-btn--primary,
.ppg-btn--secondary,
.ppg-btn--ghost,
.ppg-hero__cta,
.ppg-hero__cta--primary,
.ppg-hero__cta--secondary,
.ppg-add,
.ppg-cutoff-timer__btn,
.ppg-banner__cta,
.ppg-offerCard__btn,
.ppg-cardslider__btn,
.ppg-newsletter__btn,
.ppg-product-card__btn,
.ppg-header__cta-btn,
.ppg-pref-modal__btn,
.ppg-pref-modal__btn--cancel,
.ppg-pref-modal__btn--save,
.ppg-qty__btn,
.ppg-faq__q,
.ppg-profile-btn,
.ppg-profile-btn--glow,
.ppg-profile-btn--secondary,
.ppg-profile-btn--edit,
.ppg-profile-btn--add-card,
.ppg-profile-btn--cart,
.ppg-profile-btn--invite,
.ppg-randomly-select-meal-page__add-btn,
.ppg-randomly-select-meal-page__view-btn,
.ppg-randomly-select-meal-page__clear-btn,
.ppg-randomly-select-meal-page__back,
.ppg-before-finishing__btn--no,
.ppg-before-finishing__btn--yes,
.ppg-before-finishing__close,
.ppg-subscription-cta__btn,
.ppg-subscription-form__option,
.ppg-subscription-form__date-tile,
.ppg-members-list-controls__btn,
.ppg-edit-member-modal__btn,
.ppg-mealpack-card__info-btn,
.ppg-select-meals__btn,
.ppg-password-modal__close,
.ppg-calendar__nav,
.ppg-calendar__day,
.ppg-pref-modal__tag,
.ppg-pref-modal__card {
  border-radius: 4px !important;
}

.ppg-slider__dots {
  display: none !important;
}

/* Global form inputs and textarea */
input[type="text"],
input[type="password"],
input[type="email"],
input[type="url"],
input[type="date"],
input[type="month"],
input[type="time"],
input[type="datetime"],
input[type="datetime-local"],
input[type="week"],
input[type="number"],
input[type="search"],
input[type="tel"],
input[type="color"],
textarea {
  -webkit-appearance: none;
  -moz-appearance: none;
  background: #fff;
  border-radius: 0;
  border-style: solid;
  border-width: 0.1rem;
  box-shadow: none;
  display: block;
  font-size: 1.6rem;
  letter-spacing: -0.015em;
  max-width: 100%;
  padding: 1.5rem 3.8rem;
  width: 100%;
}

/* ========== Header: Two-tier dark design (screenshot style) ========== */
.ppg-header--dark {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  z-index: 200;
  background: #000;
}

.ppg-header__top {
  background: #1a1a1a;
  padding: 10px 24px;
}

.ppg-header__top-inner {
  max-width: 1200px;
  width: 100%;
  margin: 0 auto;
  display: flex;
  align-items: center;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: 8px;
}

.ppg-header__social {
  display: flex;
  align-items: center;
  gap: 6px;
}

.ppg-header__social-btn {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 36px;
  height: 36px;
  background: #520975;
  border-radius: 6px;
  color: #fff;
  transition: opacity 0.2s, transform 0.2s;
}

.ppg-header__social-btn:hover {
  opacity: 0.9;
  transform: scale(1.05);
}

.ppg-header__social-btn img {
  width: 16px;
  height: 16px;
  display: block;
}

.ppg-header__top-right {
  display: flex;
  align-items: center;
  gap: 12px;
}

.ppg-header__cta-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 14px 18px;
  background: #520975;
  color: #fff !important;
  font-weight: 700;
  font-size: 12px;
  letter-spacing: 0.5px;
  text-transform: uppercase;
  text-decoration: none !important;
  border-radius: 4px;
  border: none;
  transition: background 0.2s, box-shadow 0.2s;
  white-space: nowrap;
  height: auto;
  line-height: 1.2;
}

.ppg-header__cta-btn:hover {
  background: #520975;
  box-shadow: 0 0 0 2px rgba(0, 71, 255, 0.4);
}

/* ========== LIGHT BLUE HOVER ON ALL BUTTONS (same as primary/train button) ========== */
button:hover,
input[type="submit"]:hover,
input[type="button"]:hover,
[role="button"]:hover,
.ppg-btn:hover,
.ppg-btn--primary:hover,
.ppg-btn--secondary:hover,
.ppg-add:hover,
.ppg-hero__cta:hover,
.ppg-banner__cta:hover,
.ppg-offerCard__btn:hover,
.ppg-product-card__btn:hover,
.ppg-cardslider__btn:hover,
.ppg-newsletter__btn:hover,
.ppg-cutoff-timer__btn:hover,
.ppg-subscription-cta__btn:hover,
.ppg-subscription-page__btn:hover,
.ppg-login-page__submit:hover,
.ppg-signup-page__submit:hover,
.ppg-load-more-btn:hover,
.ppg-meal-pack-back:hover,
.ppg-profile-btn:hover,
.ppg-members-list-controls__btn:hover,
.ppg-edit-member-modal__btn:hover,
.ppg-mealpack-card__info-btn:hover,
.ppg-select-meals__btn:hover,
.ppg-subscription-form__option:hover,
.ppg-subscription-form__date-tile:hover,
.ppg-modal__add-btn:hover,
.ppg-date-select__sort:hover,
.ppg-date-select__reorder:hover,
.ppg-qty__btn:hover {
  box-shadow: 0 0 0 2px rgba(0, 71, 255, 0.4) !important;
}

/* Password toggle (eye) – no blue border, no layout shift on hover */
.ppg-login-page__toggle-pwd:hover,
.ppg-login-page__toggle-pwd:focus,
.ppg-signup-page__toggle-pwd:hover,
.ppg-signup-page__toggle-pwd:focus {
  box-shadow: none !important;
  outline: none !important;
  border: none !important;
}

/* ========== BUTTON STYLING (No Layout-Shifting Active States) ========== */
/* Buttons use hover effects only - no click-based active states that cause layout jumps */

/* Ensure buttons have smooth transitions for hover effects only */
.ppg-btn,
.ppg-btn--primary,
.ppg-btn--secondary,
.ppg-add,
.ppg-hero__cta,
.ppg-cutoff-timer__btn,
.ppg-banner__cta,
.ppg-offerCard__btn,
.ppg-product-card__btn,
.ppg-cardslider__btn,
.ppg-date-select__reorder,
.ppg-subscription-cta__btn,
.ppg-newsletter__btn {
  position: relative;
  transition: background-color 0.2s ease, box-shadow 0.2s ease !important;
}

/* Prevent FAQ and other informational elements from getting unwanted active states */
.ppg-faq__q,
.ppg-faq__item,
.ppg-why-bar__item,
.ppg-step,
.ppg-pickup-card,
.ppg-trust-bar__item,
.ppg-mealpack-card {
  background-color: inherit;
  transition: none !important;
}

/* Ensure clicking FAQ questions doesn't change background */
.ppg-faq__q:active,
.ppg-faq__q:focus,
.ppg-faq__item:active,
.ppg-faq__item:focus {
  background-color: inherit !important;
  outline: none;
}

/* Meal pack cards - no background change on click */
.ppg-mealpack-card:active,
.ppg-mealpack-card:focus {
  background-color: inherit !important;
}

/* Info cards should not have click-based color changes */
.ppg-why-bar__item:active,
.ppg-why-bar__item:focus,
.ppg-step:active,
.ppg-step:focus,
.ppg-pickup-card:active,
.ppg-pickup-card:focus,
.ppg-trust-bar__item:active,
.ppg-trust-bar__item:focus {
  background-color: inherit !important;
  transform: none !important;
}

.ppg-header__main {
  background: transparent !important;
  padding: 20px 24px 16px;
  border-top: 1px solid rgba(255, 255, 255, 0.15);
  display: flex;
  flex-direction: column;
  align-items: center;
}

.ppg-header__main-inner {
  max-width: 1240px !important;
  width: 100%;
  margin: 0 auto;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 24px;
  flex-wrap: wrap;
}

/* Left: logo (and mobile menu) */
.ppg-header__left {
  display: flex;
  align-items: center;
  gap: 12px;
  flex: 1 1 0;
  min-width: 0;
  justify-content: flex-start;
}

.ppg-header__main-inner .ppg-nav__menu--mobile {
  width: 40px;
  height: 40px;
  min-width: 40px;
  min-height: 40px;
  display: none;
  align-items: center;
  justify-content: center;
  background: transparent;
  border: none;
  cursor: pointer;
  padding: 0;
  flex-shrink: 0;
}

.ppg-header__main-inner .ppg-nav__menu--mobile img {
  width: 22px;
  height: 22px;
  filter: brightness(0) invert(1);
}

.ppg-logo--header {
  display: flex;
  align-items: center;
  text-decoration: none;
  flex-shrink: 0;
}

.ppg-logo--header .ppg-logo__mark {
  width: 40px;
  height: 40px;
  filter: none;
  margin-right: 0 !important;
}

/* Center: nav links (centered in header) */
.ppg-header__center {
  flex: 0 0 auto;
  display: flex;
  align-items: center;
  justify-content: center;
  margin-left: 65px !important;
  min-width: 0;
}

.ppg-nav__links--center {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 14px;
  flex-wrap: wrap;
  padding: 0 8px;
}

/* Desktop: all nav links on single line */
@media (min-width: 1025px) {
  .ppg-nav__links--center {
    flex-wrap: nowrap;
    gap: 16px;
    padding: 0 12px;
  }

  .ppg-nav__links--center .ppg-nav__link {
    white-space: nowrap;
    flex-shrink: 0;
  }
}

/* Right: search + cart */
.ppg-header__right {
  display: flex;
  align-items: center;
  gap: 8px;
  flex: 1 1 0;
  min-width: 0;
  justify-content: flex-end;
}

.ppg-header__main-inner .ppg-nav__icon--search-header {
  width: 40px;
  height: 40px;
  min-width: 40px;
  min-height: 40px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: transparent;
  border: none;
  cursor: pointer;
  padding: 0;
  flex-shrink: 0;
}

.ppg-header__main-inner .ppg-nav__icon--search-header img {
  width: 22px;
  height: 22px;
  filter: brightness(0) invert(1);
}

.ppg-header__right .ppg-nav__cart-wrap {
  position: relative;
  flex-shrink: 0;
}

.ppg-header__right .ppg-nav__icon--profile {
  width: 40px;
  height: 40px;
  min-width: 40px;
  min-height: 40px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: transparent;
  border: none;
  padding: 0;
  margin: 0;
  cursor: pointer;
  text-decoration: none;
  flex-shrink: 0;
}

.ppg-header__right .ppg-nav__icon--profile img {
  width: 22px;
  height: 22px;
  filter: brightness(0) invert(1);
}

.ppg-header__right .ppg-nav__icon--logout {
  width: 40px;
  height: 40px;
  min-width: 40px;
  min-height: 40px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: #000 !important;
  border: none;
  padding: 0;
  margin: 0;
  cursor: pointer;
  text-decoration: none;
}

.ppg-header__right .ppg-nav__icon--logout img {
  width: 22px;
  height: 22px;
  filter: brightness(0) invert(1);
}

.ppg-header__right .ppg-nav__icon--cart {
  width: 40px;
  height: 40px;
  min-width: 40px;
  min-height: 40px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: transparent;
  border: none;
  padding: 0;
  margin: 0;
  cursor: pointer;
}

.ppg-header__right .ppg-nav__icon--cart img {
  width: 22px;
  height: 22px;
  filter: brightness(0) invert(1);
}

.ppg-header__right .ppg-nav__cart-badge {
  position: absolute;
  top: -4px;
  right: -4px;
  min-width: 20px;
  height: 20px;
  padding: 0 6px;
  border-radius: 10px;
  background: #520975;
  color: #fff;
  font-size: 11px;
  font-weight: 700;
  display: flex;
  align-items: center;
  justify-content: center;
}

.ppg-faq__content {
  background: #0D0D0D !important;
  border: 1px solid rgba(255, 255, 255, 0.12);
}

.footer-nav-widgets-wrapper {
  display: none !important;
}

.wc-block-components-checkout-place-order-button {
  background-color: var(--ppg-purple2, #8b5cf6) !important;
}

.wc-blocks-components-select .wc-blocks-components-select__container {
  background: #000000 !important;

}

.wc-block-cart__submit-button {
  border: 1px solid #ffffff8a;
  border-radius: 10px;
}

.post-27 .wp-block-woocommerce-checkout {
  margin-top: 36px !important;
}

.ppg-mealpack__grid {
  margin-top: 84px !important;
}

.ppg-faq-page {
  padding: 212px 24px 64px !important;

}

.post-27 header.entry-header {
  padding-top: 0 !important;
}

section.ppg-banner.is-in {
  display: none;
}

.singular .entry-header {
  background-color: transparent;
  padding: 4rem 0;
  margin-top: 135px;
  padding: 0 !important;
}

.ppg-header--dark .ppg-nav__link {
  color: #fff !important;
  font-size: 15px;
  font-weight: 400;
  text-decoration: none;
  transition: color 0.2s, background 0.2s, opacity 0.2s;
  padding: 8px 12px;
  border-radius: 6px;
}

.ppg-header--dark .ppg-nav__link:hover {
  color: #d37cfc !important;
  background: transparent !important;
  opacity: 1;
}

.ppg-header--dark .ppg-nav__link--active {
  color: #d37cfc !important;
}

.ppg-header--dark .ppg-nav__link--primary {
  font-weight: 600;
}

.ppg-header__divider {
  max-width: 1200px;
  margin: 16px auto 0;
  border: none;
  border-top: 1px solid rgba(255, 255, 255, 0.12);
}

/* Header search overlay */
.ppg-header-search {
  position: absolute;
  left: 0;
  right: 0;
  top: 100%;
  background: #07060b;
  border-bottom: 1px solid rgba(255, 255, 255, 0.12);
  padding: 12px 24px 16px;
  max-height: 0;
  overflow: hidden;
  opacity: 0;
  transition: max-height 0.25s ease, opacity 0.2s ease, padding 0.2s ease;
  z-index: 100;
}

.ppg-header-search.ppg-header-search--open {
  max-height: 120px;
  opacity: 1;
}

.ppg-header-search__form {
  display: flex;
  align-items: center;
  gap: 12px;
  max-width: 600px;
  margin: 0 auto;
  position: relative;
}

.ppg-header-search__label {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  border: 0;
}

.ppg-header-search__input {
  flex: 1;
  min-width: 0;
  height: 44px;
  padding: 0 16px;
  border: 1px solid rgba(255, 255, 255, 0.2);
  border-radius: 8px;
  background: #1A1A1A;
  color: #FFFFFF;
  font-size: 16px;
}

.ppg-header-search__input::placeholder {
  color: #888888;
}

.ppg-header-search__input:focus {
  outline: none;
  border-color: rgba(255, 255, 255, 0.35);
  box-shadow: 0 0 0 2px rgba(0, 71, 255, 0.4);
  background: #1A1A1A;
}

.ppg-header-search__submit {
  height: 44px;
  padding: 0 20px;
  border: none;
  border-radius: 4px;
  background: #520975;
  color: #fff;
  font-weight: 700;
  font-size: 14px;
  cursor: pointer;
  flex-shrink: 0;
}

.ppg-header-search__submit:hover {
  box-shadow: none;
}

.ppg-header-search__submit:disabled {
  opacity: 0.5;
  cursor: not-allowed;
}

.ppg-header-search__close {
  position: absolute;
  top: 12px;
  right: 24px;
  width: 40px;
  height: 40px;
  border: none;
  background: transparent;
  color: rgba(255, 255, 255, 0.7);
  font-size: 24px;
  line-height: 1;
  cursor: pointer;
  padding: 0;
}

.ppg-header-search__close:hover {
  color: #fff;
}

@media (max-width: 640px) {
  .ppg-header-search__form {
    max-width: 100%;
  }

  .ppg-header-search__submit {
    padding: 0 14px;
  }
}

@media (max-width: 1024px) {
  .ppg-header__center {
    display: block;
    width: 100%;
    order: 3;
    max-height: 0;
    overflow: hidden;
    opacity: 0;
    padding: 0;
    margin: 0;
    border-top: none;
    transition: max-height 0.35s cubic-bezier(0.4, 0, 0.2, 1),
      opacity 0.3s ease,
      padding 0.3s ease,
      margin 0.3s ease;
  }

  .ppg-header__main-inner .ppg-nav__menu--mobile {
    display: flex;
  }

  .ppg-header__main-inner .ppg-nav__icon--search-header {
    display: none;
  }

  .ppg-header--dark .ppg-header__main-inner {
    flex-wrap: wrap;
  }

  .ppg-header--dark.ppg-header--menu-open .ppg-header__center {
    display: block;
    max-height: 500px;
    opacity: 1;
    padding-top: 16px;
    border-top: 1px solid rgba(255, 255, 255, 0.12);
    margin-top: 12px;
  }

  .ppg-header__center .ppg-nav__links--center {
    display: flex;
    flex-direction: column;
    width: 100%;
    gap: 4px;
    padding: 0;
  }

  .ppg-header--dark.ppg-header--menu-open .ppg-nav__link {
    padding: 14px 16px;
    font-size: 16px;
    border-radius: 8px;
    transition: background 0.2s, color 0.2s;
  }

  .ppg-header--dark.ppg-header--menu-open .ppg-nav__link:hover {
    background: transparent !important;
  }

  /* Hamburger to cross (×) icon transition */
  .ppg-nav__menu--mobile {
    position: relative;
    width: 36px;
    height: 36px;
    min-width: 36px;
    min-height: 36px;
  }

  .ppg-nav__menu--mobile img {
    transition: opacity 0.2s ease;
  }

  .ppg-header--menu-open .ppg-nav__menu--mobile img {
    opacity: 0;
  }

  .ppg-nav__menu--mobile::before,
  .ppg-nav__menu--mobile::after {
    content: "";
    position: absolute;
    top: 50%;
    left: 50%;
    width: 20px;
    height: 2px;
    background: #fff;
    border-radius: 2px;
    opacity: 0;
    transition: opacity 0.2s ease, transform 0.2s ease;
  }

  .ppg-nav__menu--mobile::before {
    transform: translate(-50%, -50%) rotate(45deg);
  }

  .ppg-nav__menu--mobile::after {
    transform: translate(-50%, -50%) rotate(-45deg);
  }

  .ppg-header--menu-open .ppg-nav__menu--mobile::before,
  .ppg-header--menu-open .ppg-nav__menu--mobile::after {
    opacity: 1;
  }
}

@media (max-width: 640px) {
  .ppg-header__social {
    display: none;
  }

  .ppg-header__top {
    padding: 6px 12px;
  }

  .ppg-header__top-inner {
    justify-content: center;
  }

  .ppg-header__top-right {
    width: 100%;
    justify-content: center;
  }

  .ppg-header__cta-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    text-align: center;
    width: auto;
    padding: 6px 14px;
    font-size: 11px;
    margin: 0 auto;
  }

  .ppg-header__main {
    padding: 10px 12px;
  }

  .ppg-header__main-inner {
    gap: 12px;
  }

  .ppg-header__left {
    gap: 8px;
  }

  .ppg-logo--header .ppg-logo__mark {
    width: 32px;
    height: 32px;
  }
}

/* Prevent horizontal scroll on all pages + Smooth scrolling */
html {
  overflow-x: hidden;
  max-width: 100vw;
  scroll-behavior: smooth;
  -webkit-overflow-scrolling: touch;
}

body {
  overflow-x: hidden;
  max-width: 100vw;
  -webkit-overflow-scrolling: touch;
}

body {
  overflow-y: auto;
}

section.ppg-banner.is-in {
  margin-top: 257px;
}

/* Banner: fixed background image (parallax) */
.ppg-banner {
  background-attachment: scroll, fixed !important;
  background-position: center center !important;
  background-repeat: no-repeat !important;
  background-size: cover !important;
}

/* Banner text readability */
.ppg-banner__text {
  position: relative;
  z-index: 2;
}

.ppg-banner__text::before {
  content: "";
  position: absolute;
  inset: -12px -16px -12px -16px;
  background: rgba(13, 13, 13, .3);
  border-radius: 12px;
  z-index: -1;
  pointer-events: none;
}

.ppg-banner__text h3 {
  color: #fff !important;
  text-shadow: 0 2px 4px rgba(0, 0, 0, .6), 0 4px 20px rgba(0, 0, 0, .5) !important;
  font-weight: 900 !important;
}

.ppg-banner__text p {
  color: rgba(255, 255, 255, .98) !important;
  text-shadow: 0 1px 4px rgba(0, 0, 0, .6), 0 2px 10px rgba(0, 0, 0, .4) !important;
}

.ppg-deco {
  padding-top: 0;
}

.ppg-cardslider__card {
  background-color: #1A1A1A !important;
}

.ppg-card {
  background-color: #1A1A1A !important;
}

.ppg-qty {
  width: 150px;
}

button.ppg-qty__btn {
  padding: 0px !important;
}

.follow-us {
  padding-bottom: 0;
}

/* main/ppg-main overflow set in responsive base above */
#meals {
  padding-top: 0;
}

.ppg-qty__input {
  background-color: transparent !important;
}

#meals {
  padding-top: 80px;
}

#meals {
  padding-top: 136px !important;
}

.ppg-product-offers {
  border-radius: 56px;
}

.ppg-logo__mark {
  margin-right: 0 !important;
  background: none !important;
  background-color: transparent !important;
}

.ppg-slider__arrows {
  display: none;
}

/* ========== Pro Plus Gym Brand Colors ========== */
/* Button colors – #0047FF not used for buttons (micro-only) */
:root {
  --ppg-accent: #520975;
  --ppg-accent-text: #ffffff;
}

/* Primary CTA buttons */
.ppg-slide__cta {
  background: #520975 !important;
  color: var(--ppg-accent-text) !important;
}

.ppg-slide__cta:hover {
  background: #520975 !important;
  box-shadow: none;
  color: var(--ppg-accent-text) !important;
}

/* Banner CTA */
.ppg-banner__cta {
  background: #fff !important;
  color: #1a1a1a !important;
  border-color: #fff !important;
}

.ppg-banner__cta:hover {
  box-shadow: none;
  color: #1a1a1a !important;
  border-color: #fff !important;
}

/* Add to cart: teal/emerald (distinct from purple theme) */
button.ppg-add {
  background: #520975 !important;
  color: #fff !important;
  border: 1px solid #520975 !important;
  border-radius: 4px;
  font-weight: 700;
  text-transform: uppercase;
}

button.ppg-add:hover {
  background: #520975 !important;
  box-shadow: none;
}

.ppg-add {
  display: inline-flex !important;
  align-items: center;
  justify-content: center;
  gap: 8px;
}

.ppg-add::before {
  content: "";
  display: inline-block;
  width: 18px;
  height: 18px;
  background: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='%23fff'%3E%3Cpath d='M7 18c-1.1 0-1.99.9-1.99 2S5.9 22 7 22s2-.9 2-2-.9-2-2-2zM1 2v2h2l3.6 7.59-1.35 2.45c-.16.28-.25.61-.25.96 0 1.1.9 2 2 2h12v-2H7.42c-.14 0-.25-.11-.25-.25l.03-.12.9-1.63h7.45c.75 0 1.41-.41 1.75-1.03l3.58-6.49c.08-.14.12-.31.12-.48 0-.55-.45-1-1-1H5.21l-.94-2H1zm16 16c-1.1 0-1.99.9-1.99 2s.89 2 1.99 2 2-.9 2-2-.9-2-2-2z'/%3E%3C/svg%3E") no-repeat center;
  background-size: contain;
}

.ppg-newsletter__btn,
.ppg-offerCard__btn,
.ppg-product-card__btn,
.ppg-date-select__reorder,
.ppg-btn--primary {
  background: #520975 !important;
  color: #fff !important;
  border-color: #520975 !important;
}

button.ppg-add:hover {
  background: #520975 !important;
  color: #fff !important;
  border-color: #520975 !important;
  box-shadow: none;
}

.ppg-add:hover::before {
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='%23fff'%3E%3Cpath d='M7 18c-1.1 0-1.99.9-1.99 2S5.9 22 7 22s2-.9 2-2-.9-2-2-2zM1 2v2h2l3.6 7.59-1.35 2.45c-.16.28-.25.61-.25.96 0 1.1.9 2 2 2h12v-2H7.42c-.14 0-.25-.11-.25-.25l.03-.12.9-1.63h7.45c.75 0 1.41-.41 1.75-1.03l3.58-6.49c.08-.14.12-.31.12-.48 0-.55-.45-1-1-1H5.21l-.94-2H1zm16 16c-1.1 0-1.99.9-1.99 2s.89 2 1.99 2 2-.9 2-2-.9-2-2-2z'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: center;
  background-size: contain;
}

.ppg-newsletter__btn:hover,
.ppg-offerCard__btn:hover,
.ppg-product-card:hover .ppg-product-card__btn,
.ppg-date-select__reorder:hover,
.ppg-btn--primary:hover {
  background: #520975 !important;
  color: var(--ppg-accent-text) !important;
  border-color: #520975 !important;
  box-shadow: none;
}

/* Card slider nav buttons: white arrows and white round border */
.ppg-cardslider__nav .ppg-cardslider__btn {
  width: 48px;
  height: 55px;
  border-radius: 4px;
  border: 1px solid #ffffff !important;
  background: #1A1A1A !important;
  color: #ffffff !important;
  font-size: 20px;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: all var(--ppg-transition);
}

.ppg-cardslider__nav .ppg-cardslider__btn:hover {
  background: #1A1A1A !important;
  color: #ffffff !important;
  border-color: #ffffff !important;
  box-shadow: none;
}

/* Add to Cart – solid #520975, hover blue glow */
.ppg-add {
  background: #520975 !important;
  color: #fff !important;
  border: 1px solid #520975 !important;
}

.ppg-add:hover {
  background: #520975 !important;
  color: #fff !important;
  border-color: #520975 !important;
  box-shadow: none;
}

.ppg-cartRow {
  margin-top: 12px;
  gap: 10px;
}

/* Date select sort button */
.ppg-date-select__sort {
  border-color: #520975 !important;
  color: #520975 !important;
}

.ppg-date-select__sort:hover {
  background: #1A1A1A !important;
  box-shadow: none;
}

/* Qty buttons, nav links hover */
.ppg-qty__btn:hover,
.ppg-nav__link:hover,
.ppg-nav__link--primary:hover {
  color: #520975 !important;
}

.ppg-qty__btn:hover {
  border-color: #520975 !important;
  background: #1A1A1A !important;
  box-shadow: none;
}

/* Stat value – accent color only */
.ppg-stat__val {
  color: #520975 !important;
}

/* Accent text colors */
.ppg-cardslider__price {
  color: #fff !important;
}

.ppg-card__price {
  color: #fff !important;
}

.ppg-flow__num,
.ppg-hierarchy__list strong,
.ppg-metrics__val,
.ppg-faq__q::after,
.ppg-footer__col a:hover {
  color: #520975 !important;
}

.ppg-macro--cal .ppg-macro__val {
  color: #520975 !important;
}

/* Nav cart badge, price tags */
.ppg-nav__cart-badge,
.ppg-offerCard__priceTag,
.ppg-product-card__price-tag {
  background: #520975 !important;
  color: #fff !important;
}

/* Slider dot active state */
.ppg-slider__dot.active {
  background: #520975 !important;
  border-color: #fff !important;
}

/* Date card selected state – white text on purple */
.ppg-date-card--selected {
  border-color: #520975 !important;
  color: #FFFFFF !important;
}

.ppg-date-card--selected .ppg-date-card__day,
.ppg-date-card--selected .ppg-date-card__num {
  color: #FFFFFF !important;
}

/* Slider arrow / nav icon hover – no blue glow (micro-only) */
.ppg-slider__arrow:hover {
  box-shadow: none;
}

.ppg-nav__icon--search:hover,
.ppg-nav__icon--cart:hover,
.ppg-nav__menu--mobile:hover {
  box-shadow: none;
}

/* ========== FOOTER – matches Home page style and layout ========== */
.ppg-footer {
  background: #0D0D0D;
  position: relative;
  overflow: hidden;
  margin-top: 0 !important;
  padding: 64px 36px 40px;
  border-top: 1px solid rgba(255, 255, 255, 0.08);
}

.ppg-footer::before,
.ppg-footer::after {
  display: none;
}

.ppg-footer__wrap {
  max-width: 1200px;
  width: 100%;
  margin: 0 auto;
  position: relative;
  z-index: 1;
  box-sizing: border-box;
}

.ppg-footer__top {
  display: grid;
  grid-template-columns: 1fr;
  gap: 48px;
  padding-bottom: 48px;
  margin-bottom: 32px;
  border-bottom: 1px solid rgba(255, 255, 255, 0.08);
}

@media (min-width: 768px) {
  .ppg-footer__top {
    grid-template-columns: 2fr 1fr 1fr 1fr;
    gap: 40px;
  }
}

.ppg-footer__brand .ppg-logo {
  margin-bottom: 20px;
}

.ppg-footer__brand p {
  color: rgba(255, 255, 255, 0.75);
  font-size: 14px;
  line-height: 1.65;
  margin: 0 0 24px;
  max-width: 320px;
}

.ppg-footer__social {
  display: flex;
  gap: 14px;
}

.ppg-footer__social a {
  width: 44px;
  height: 44px;
  border-radius: 12px;
  background: #1A1A1A;
  border: 1px solid rgba(255, 255, 255, 0.08);
  display: flex;
  align-items: center;
  justify-content: center;
  color: #fff;
  font-size: 16px;
  text-decoration: none;
  transition: background 0.2s, border-color 0.2s, box-shadow 0.2s, transform 0.2s;
}

.ppg-footer__social a:hover {
  background: #1A1A1A !important;
  border-color: rgba(255, 255, 255, 0.25) !important;
  box-shadow: none;
}

.ppg-footer__col h4 {
  font-size: 13px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  margin: 0 0 20px;
  color: #fff !important;
}

.ppg-footer__col ul {
  list-style: none;
  padding: 0;
  margin: 0;
}

.ppg-footer__col li {
  margin-bottom: 12px;
  margin-left: 0;
}

.ppg-footer__col li:last-child {
  margin-bottom: 0;
}

.ppg-footer__col a {
  color: rgba(255, 255, 255, 0.85) !important;
  text-decoration: none;
  font-size: 14px;
  font-weight: 500;
  transition: color 0.2s;
}

.ppg-footer__col a:hover {
  color: #d37cfc !important;
}

.ppg-footer__bottom {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  align-items: center;
  gap: 16px;
  padding-top: 32px;
  text-align: center;
}

.ppg-footer__bottom p {
  margin: 0;
  color: rgba(255, 255, 255, 0.55);
  font-size: 13px;
  font-weight: 500;
}

/* Footer logo: keep white on dark background (no invert) */
.ppg-logo--footer .ppg-logo__mark {
  filter: none;
}

/* Anchor scroll offset for fixed header */
#meals,
#faq,
#subscription {
  scroll-margin-top: 160px;
}

/* ========== WOOCOMMERCE CART & CHECKOUT – THEME-MATCHING BG ========== */
body.woocommerce-cart,
body.woocommerce-checkout {
  background: #07060b !important;
  color: #FFFFFF;
}

body.woocommerce-cart main,
body.woocommerce-checkout main,
body.woocommerce-cart .site-main,
body.woocommerce-checkout .site-main {
  background: transparent;
  color: inherit;
}

/* WooCommerce content wrapper */
body.woocommerce-cart .woocommerce,
body.woocommerce-checkout .woocommerce {
  background: transparent;
  color: inherit;
}

/* Headings and text */
body.woocommerce-cart h1,
body.woocommerce-cart h2,
body.woocommerce-checkout h1,
body.woocommerce-checkout h2,
body.woocommerce-cart .woocommerce-breadcrumb,
body.woocommerce-checkout .woocommerce-breadcrumb {
  color: #FFFFFF !important;
}

body.woocommerce-cart .woocommerce-breadcrumb a,
body.woocommerce-checkout .woocommerce-breadcrumb a {
  color: rgba(243, 242, 247, 0.85);
}

body.woocommerce-cart .woocommerce-breadcrumb a:hover,
body.woocommerce-checkout .woocommerce-breadcrumb a:hover {
  color: #a36aff;
}

/* Cart table, order review, totals – dark cards */
body.woocommerce-cart .cart_totals,
body.woocommerce-checkout .woocommerce-checkout-review-order,
body.woocommerce-checkout .woocommerce-checkout-payment,
body.woocommerce-cart table.shop_table,
body.woocommerce-checkout table.shop_table {
  background: rgba(255, 255, 255, 0.04) !important;
  border: 1px solid rgba(255, 255, 255, 0.11);
  color: #FFFFFF;
}

body.woocommerce-cart table.shop_table th,
body.woocommerce-checkout table.shop_table th,
body.woocommerce-cart table.shop_table td,
body.woocommerce-checkout table.shop_table td {
  border-color: rgba(255, 255, 255, 0.08);
  color: inherit;
}

body.woocommerce-cart .cart_totals h2,
body.woocommerce-checkout .woocommerce-checkout-review-order-table+h3,
body.woocommerce-checkout #payment h3 {
  color: #FFFFFF !important;
}

/* Notices */
body.woocommerce-cart .woocommerce-info,
body.woocommerce-checkout .woocommerce-info,
body.woocommerce-cart .woocommerce-message,
body.woocommerce-checkout .woocommerce-message {
  background: rgba(82, 9, 117, 0.15) !important;
  border-color: rgba(82, 9, 117, 0.35);
  color: #FFFFFF !important;
}

/* Form inputs on cart/checkout */
body.woocommerce-cart input[type="text"],
body.woocommerce-cart input[type="number"],
body.woocommerce-cart input[type="email"],
body.woocommerce-cart select,
body.woocommerce-cart textarea,
body.woocommerce-checkout input[type="text"],
body.woocommerce-checkout input[type="number"],
body.woocommerce-checkout input[type="email"],
body.woocommerce-checkout input[type="tel"],
body.woocommerce-checkout select,
body.woocommerce-checkout textarea {
  background: rgba(255, 255, 255, 0.06) !important;
  border-color: rgba(255, 255, 255, 0.15) !important;
  color: #FFFFFF !important;
}

body.woocommerce-cart input::placeholder,
body.woocommerce-checkout input::placeholder {
  color: rgba(243, 242, 247, 0.5);
}

/* Select dropdown options – theme-matched (native select where supported) */
body.woocommerce-cart select option,
body.woocommerce-checkout select option {
  background: #07060b !important;
  color: #FFFFFF !important;
}

body.woocommerce-cart select optgroup,
body.woocommerce-checkout select optgroup {
  background: #07060b !important;
  color: #FFFFFF !important;
}

/* Select2/SelectWoo – selection box (the visible input showing selected value) */
body.woocommerce-cart .select2-container--default .select2-selection--single,
body.woocommerce-checkout .select2-container--default .select2-selection--single {
  background: rgba(255, 255, 255, 0.06) !important;
  border-color: rgba(255, 255, 255, 0.15) !important;
  color: #FFFFFF !important;
}

body.woocommerce-cart .select2-container--default .select2-selection--single .select2-selection__rendered,
body.woocommerce-checkout .select2-container--default .select2-selection--single .select2-selection__rendered {
  color: #FFFFFF !important;
}

body.woocommerce-cart .select2-container--default .select2-selection--single .select2-selection__placeholder,
body.woocommerce-checkout .select2-container--default .select2-selection--single .select2-selection__placeholder {
  color: rgba(243, 242, 247, 0.5) !important;
}

body.woocommerce-cart .select2-container--default .select2-selection--single .select2-selection__arrow,
body.woocommerce-checkout .select2-container--default .select2-selection--single .select2-selection__arrow {
  border-left-color: rgba(255, 255, 255, 0.3) !important;
}

body.woocommerce-cart .select2-container--default .select2-selection--single .select2-selection__arrow b,
body.woocommerce-checkout .select2-container--default .select2-selection--single .select2-selection__arrow b {
  border-color: #FFFFFF transparent transparent transparent !important;
}

body.woocommerce-cart .select2-container--default.select2-container--focus .select2-selection--single,
body.woocommerce-cart .select2-container--default.select2-container--open .select2-selection--single,
body.woocommerce-checkout .select2-container--default.select2-container--focus .select2-selection--single,
body.woocommerce-checkout .select2-container--default.select2-container--open .select2-selection--single {
  border-color: rgba(82, 9, 117, 0.5) !important;
}

/* Select2/SelectWoo dropdown – theme-matched (country/state on shortcode checkout) */
body.woocommerce-cart .select2-container--default .select2-dropdown,
body.woocommerce-checkout .select2-container--default .select2-dropdown {
  background: #07060b !important;
  border-color: rgba(255, 255, 255, 0.15) !important;
}

body.woocommerce-cart .select2-container--default .select2-results__options,
body.woocommerce-checkout .select2-container--default .select2-results__options {
  background: #07060b !important;
}

body.woocommerce-cart .select2-container--default .select2-results__option,
body.woocommerce-checkout .select2-container--default .select2-results__option {
  background: #07060b !important;
  color: #FFFFFF !important;
}

body.woocommerce-cart .select2-container--default .select2-results__option--highlighted[aria-selected],
body.woocommerce-cart .select2-container--default .select2-results__option--highlighted[data-selected],
body.woocommerce-checkout .select2-container--default .select2-results__option--highlighted[aria-selected],
body.woocommerce-checkout .select2-container--default .select2-results__option--highlighted[data-selected] {
  background: rgba(82, 9, 117, 0.6) !important;
  color: #fff !important;
}

body.woocommerce-cart .select2-container--default .select2-search--dropdown .select2-search__field,
body.woocommerce-checkout .select2-container--default .select2-search--dropdown .select2-search__field {
  background: #1A1A1A !important;
  border-color: rgba(255, 255, 255, 0.15) !important;
  color: #FFFFFF !important;
}

body.woocommerce-cart .select2-container--default .select2-results__message,
body.woocommerce-checkout .select2-container--default .select2-results__message {
  color: rgba(243, 242, 247, 0.8) !important;
}

/* Buttons – #520975, hover blue glow */
body.woocommerce-cart .button,
body.woocommerce-checkout .button,
body.woocommerce-cart button.button,
body.woocommerce-checkout button.button {
  background: #520975 !important;
  border-color: #520975 !important;
  color: #fff !important;
  border-radius: 4px;
}

body.woocommerce-cart .button:hover,
body.woocommerce-checkout .button:hover,
body.woocommerce-cart button.button:hover,
body.woocommerce-checkout button.button:hover {
  background: #520975 !important;
  box-shadow: none;
}

body.woocommerce-cart .wc-block-components-totals-coupon__form .wc-block-components-totals-coupon__button,
body.woocommerce-cart .wc-block-components-totals-coupon__button,
body.woocommerce-cart button[name="apply_coupon"] {
  background: #520975 !important;
  border-color: #520975 !important;
  color: #fff !important;
  border-radius: 4px;
}

body.woocommerce-cart .wc-block-components-totals-coupon__form .wc-block-components-totals-coupon__button:hover,
body.woocommerce-cart .wc-block-components-totals-coupon__button:hover,
body.woocommerce-cart button[name="apply_coupon"]:hover {
  background: #520975 !important;
  box-shadow: none;
}

/* Checkout payment methods list */
body.woocommerce-checkout #payment ul.payment_methods {
  border-color: rgba(255, 255, 255, 0.11);
  background: transparent;
}

body.woocommerce-checkout #payment .payment_methods li {
  border-color: rgba(255, 255, 255, 0.08);
  color: #FFFFFF;
}

body.woocommerce-checkout #payment .payment_methods label {
  color: #FFFFFF !important;
}

/* Links */
body.woocommerce-cart a:not(.button),
body.woocommerce-checkout a:not(.button) {
  color: rgba(243, 242, 247, 0.9);
}

body.woocommerce-cart a:not(.button):hover,
body.woocommerce-checkout a:not(.button):hover {
  color: #520975;
}

/* Checkout block: billing/shipping address card – proper white text on dark theme */
body.woocommerce-checkout .wc-block-components-address-card,
body.woocommerce-checkout .wc-block-components-address-card address {
  color: #fff !important;
}

body.woocommerce-checkout .wc-block-components-address-card address .wc-block-components-address-card__address-section--primary,
body.woocommerce-checkout .wc-block-components-address-card address .wc-block-components-address-card__address-section--secondary {
  color: #fff !important;
}

body.woocommerce-checkout .wc-block-components-address-card__edit {
  color: #fff !important;
}

body.woocommerce-checkout .wc-block-components-address-card__edit:hover {
  color: #520975 !important;
}

/* Checkout block steps: step titles and labels in white */
body.woocommerce-checkout .wc-block-components-checkout-step__title,
body.woocommerce-checkout .wc-block-components-checkout-step__heading-content,
body.woocommerce-checkout .wc-block-components-checkout-step .wc-block-components-select__label,
body.woocommerce-checkout .wc-block-components-checkout-step .wc-block-components-text-input__label {
  color: #fff !important;
}

/* ========== SEARCH / ARCHIVE: theme-matching dark background + text visibility ========== */
main.ppg-search-archive,
.ppg-search-archive#site-content {
  background: #0d0d0f;
  color: rgba(243, 242, 247, 0.95);
  padding-top: var(--ppg-section-padding, 48px);
  padding-bottom: var(--ppg-section-padding, 48px);
}

/* Override parent theme white background on archive header (page title area) */
.ppg-search-archive .archive-header {
  background-color: transparent;
  color: rgba(243, 242, 247, 0.95);
}

.ppg-search-archive .archive-header,
.ppg-search-archive .archive-header-inner,
.ppg-search-archive .archive-title,
.ppg-search-archive .archive-subtitle,
.ppg-search-archive .intro-text {
  color: rgba(243, 242, 247, 0.95);
}

.ppg-search-archive .archive-title .color-accent {
  color: #a36aff;
}

.ppg-search-archive .entry-header .entry-title,
.ppg-search-archive .entry-title a,
.ppg-search-archive .entry-content,
.ppg-search-archive .entry-summary {
  color: rgba(243, 242, 247, 0.9);
}

.ppg-search-archive a {
  color: rgba(82, 9, 117, 0.95);
}

.ppg-search-archive a:hover {
  color: #a36aff;
}

.ppg-search-archive .post-separator.styled-separator {
  border-color: rgba(255, 255, 255, 0.11);
}

.ppg-search-archive .no-search-results-form input[type="search"],
.ppg-search-archive .no-search-results-form label {
  color: rgba(243, 242, 247, 0.9);
}

.ppg-search-archive .no-search-results-form input[type="search"] {
  background: #1A1A1A;
  border-color: rgba(255, 255, 255, 0.15);
}

.ppg-search-archive .pagination a,
.ppg-search-archive .pagination .current {
  color: rgba(243, 242, 247, 0.95);
}

/* ========== CART EMPTY: hide "New in store" products section ========== */
body.woocommerce-cart .wp-block-woocommerce-empty-cart-block .wp-block-separator.is-style-dots,
body.woocommerce-cart .wp-block-woocommerce-empty-cart-block h2.wp-block-heading:not(.wc-block-cart__empty-cart__title),
body.woocommerce-cart .wp-block-woocommerce-empty-cart-block .wp-block-woocommerce-product-new {
  display: none !important;
}

.contact-section {
  position: relative;
  background: url('city-bg.jpg') center/cover no-repeat;
  padding: 100px 20px;
  color: #fff;
}

.contact-overlay {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: rgba(0, 0, 0, 0.7);
}

.contact-container {
  position: relative;
  max-width: 1100px;
  margin: auto;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 60px;
}

.contact-left {
  max-width: 500px;
}

.contact-left h2 {
  font-size: 32px;
  margin-bottom: 10px;
}

.contact-left p {
  font-size: 14px;
  margin-bottom: 30px;
  color: #ddd;
}

.contact-info {
  display: flex;
  flex-direction: column;
  gap: 20px;
}

.contact-item {
  display: flex;
  align-items: flex-start;
  gap: 15px;
}

.contact-item .icon {
  background: #fff;
  color: #000;
  width: 40px;
  height: 40px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 18px;
}

.contact-item strong {
  font-size: 15px;
}

.contact-item p {
  margin: 3px 0 0;
  font-size: 13px;
  color: #ccc;
}

.contact-form-box {
  background: #fff;
  padding: 35px;
  width: 320px;
  border-radius: 3px;
  color: #333;
}

.contact-form-box h3 {
  margin-bottom: 20px;
  font-size: 20px;
}

.contact-form-box input,
.contact-form-box textarea {
  width: 100%;
  border: none;
  border-bottom: 1px solid #ccc;
  padding: 10px 0;
  margin-bottom: 20px;
  font-size: 14px;
  outline: none;
}

.contact-form-box button {
  background: #62c5d7;
  border: none;
  padding: 10px 20px;
  color: #fff;
  font-size: 14px;
  cursor: pointer;
  border-radius: 2px;
}

.contact-form-box button:hover {
  opacity: 0.9;
}

/* ── WooCommerce cart / checkout: subscription item meta structured display ── */

.woocommerce-cart .wc-item-meta,
.woocommerce-checkout .wc-item-meta,
.woocommerce-cart dl.variation,
.woocommerce-checkout dl.variation {
  display: block;
  margin: 6px 0 0;
  padding: 0;
  list-style: none;
}

.woocommerce-cart .wc-item-meta li,
.woocommerce-checkout .wc-item-meta li {
  display: block;
  margin: 2px 0;
  font-size: 0.85em;
  line-height: 1.5;
}

.woocommerce-cart .wc-item-meta li strong,
.woocommerce-checkout .wc-item-meta li strong,
.woocommerce-cart dl.variation dt,
.woocommerce-checkout dl.variation dt {
  display: inline;
  font-weight: 700;
  color: #e0e0e0;
}

.woocommerce-cart dl.variation dt,
.woocommerce-checkout dl.variation dt {
  float: none;
  clear: both;
  margin: 2px 0 0;
}

.woocommerce-cart dl.variation dd,
.woocommerce-checkout dl.variation dd {
  display: inline;
  margin: 0 0 0 4px;
  font-size: 0.85em;
  color: #c0c0c0;
}

.woocommerce-cart dl.variation dt::after,
.woocommerce-checkout dl.variation dt::after {
  content: '';
}

.woocommerce-cart dl.variation dt p,
.woocommerce-cart dl.variation dd p,
.woocommerce-checkout dl.variation dt p,
.woocommerce-checkout dl.variation dd p {
  display: inline;
  margin: 0;
}

/* Responsive */

@media(max-width:900px) {

  .contact-container {
    flex-direction: column;
    text-align: center;
  }

  .contact-left {
    max-width: 100%;
  }

  .contact-item {
    justify-content: center;
  }

}



.wc_payment_method .payment_box p {
  color: #fff;
}

.payment_box.payment_method_stripe {
  background-color: #07060b !important;
}

.p-HeightObserverProvider-container .AccordionItem {
  background-color: #07060b !important;
}

.wc_payment_method .payment_box fieldset {
  background: #07060b !important;
}