﻿/* gb/common.css â€” design tokens, canonical typography, shell, components (part 1) */

:root {
  /* Brand */
  --gb-primary: #b82779;
  --gb-primary-dark: #1a1a1a;
  --gb-primary-fg: #ffffff;
  --gb-primary-light: #f8e8f0;
  --gb-accent: #e8e8e8;
  --gb-accent-soft: #f8e8f0;
  --gb-text: #1a1a1a;
  --gb-text-muted: #5c5c5c;
  --gb-text-light: #8a8a8a;
  --gb-bg: #f7f7f7;
  --gb-surface: #ffffff;
  --gb-border: #e8e8e8;
  --gb-border-light: #e8e8e8;
  --gb-font-heading: 'PT Serif', Georgia, serif;
  --gb-font-body: 'Inter', ui-sans-serif, system-ui, sans-serif;
  --gb-font-weight: 400;
  --gb-font-weight-medium: 500;
  --gb-font-weight-semibold: 600;
  --gb-font-weight-bold: 700;
  --gb-text-xs: 12px;
  --gb-text-sm: 14px;
  --gb-text-base: 16px;
  --gb-text-lg: 18px;
  --gb-text-xl: 20px;
  --gb-text-2xl: 24px;
  --gb-text-3xl: 30px;
  --gb-text-4xl: 36px;
  --gb-line-height-tight: 1.25;
  --gb-line-height-normal: 1.5;
  --gb-line-height-relaxed: 1.625;
  --gb-tracking-tight: -0.025em;
  --gb-tracking-wide: 0.025em;
  --gb-tracking-widest: 0.1em;
  --gb-sp-1: 4px;
  --gb-sp-2: 8px;
  --gb-sp-3: 12px;
  --gb-sp-4: 16px;
  --gb-sp-5: 20px;
  --gb-sp-6: 24px;
  --gb-sp-8: 32px;
  --gb-sp-10: 40px;
  --gb-sp-12: 48px;
  --gb-radius-sm: 4px;
  --gb-radius-md: 8px;
  --gb-radius-lg: 12px;
  --gb-radius-xl: 20px;
  --gb-radius-full: 9999px;
  --gb-shadow-sm: 0 1px 3px rgba(0, 0, 0, 0.07);
  --gb-shadow-md: 0 4px 12px rgba(0, 0, 0, 0.09);
  --gb-shadow-lg: 0 8px 24px rgba(0, 0, 0, 0.1);
  --gb-transition: 0.2s ease;
  --dc-header-primary: #b82779;
  --dc-header-foreground: #1a1a1a;
  --dc-header-muted: #5c5c5c;
  --dc-header-border: #e8e8e8;
  --dc-header-topbar-bg: #e8e8e8;
  --dc-header-topbar-fg: #1a1a1a;
  --dc-header-bg: #ffffff;
  --dc-header-max: 1440px;
  --dc-header-font: var(--gb-font-body);
  /*
   * Stacking order (low → high). Tune here only.
   * 1–9 page, 200–299 header, 300–399 drawer, 4000+ modals/overlays
   */
  --dc-z-page: 0;
  --dc-z-category-hero: 1;
  --dc-z-category-content: 2;
  --dc-z-header: 200;
  /* Within header.site-header — top bar must beat main nav row */
  --dc-z-header-main-row: 10;
  --dc-z-header-topbar: 50;
  --dc-z-header-nav-dropdown: 15;
  --dc-z-header-topbar-dropdown: 60;
  --dc-z-header-search-dropdown: 60;
  --dc-z-drawer-backdrop: 300;
  --dc-z-drawer-panel: 310;
  --dc-z-drawer-header: 320;
  --dc-z-modal-backdrop: 4000;
  --dc-z-modal: 4010;
  --dc-z-modal-close: 4020;
  --dc-z-delivery-overlay: 4100;
  --dc-z-places-autocomplete: 4200;
  --dc-z-skip-link: 10000;

  /* Checkout v3 template aliases (Reference/new-shipping-pg-ui-v3.html) */
  --color-brand-bg: var(--gb-bg);
  --color-brand-fg: var(--gb-text);
  --color-brand-primary: var(--gb-primary);
  --color-brand-primary-fg: var(--gb-primary-fg);
  --color-brand-border: var(--gb-border);
  --color-brand-accent: var(--gb-primary-light);
  --font-elegant-heading: var(--gb-font-heading);
  --font-elegant-body: var(--gb-font-body);
}

/* Canonical typography — single source of truth (reference: brand elegant / Inter body) */
body {
  font-family: var(--gb-font-body);
  font-size: var(--gb-text-base);
  font-weight: var(--gb-font-weight);
  line-height: var(--gb-line-height-normal);
  color: var(--gb-text);
  background-color: var(--gb-bg);
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

h1,
.page-title,
.gb-heading-display {
  font-family: var(--gb-font-heading);
  font-size: var(--gb-text-4xl);
  font-weight: var(--gb-font-weight);
  letter-spacing: var(--gb-tracking-tight);
  line-height: var(--gb-line-height-tight);
  color: var(--gb-text);
}

h2,
.sidebar-title,
.gb-heading-section {
  font-family: var(--gb-font-heading);
  font-size: var(--gb-text-2xl);
  font-weight: var(--gb-font-weight);
  line-height: 1.3;
  color: var(--gb-text);
}

h3:not(.gb-section-label) {
  font-family: var(--gb-font-heading);
  font-size: var(--gb-text-base);
  font-weight: var(--gb-font-weight);
  line-height: 1.3;
  color: var(--gb-text);
}

h4 {
  font-family: var(--gb-font-heading);
  font-size: var(--gb-text-sm);
  font-weight: var(--gb-font-weight);
  line-height: 1.35;
  color: var(--gb-text);
}

h5,
h6 {
  font-family: var(--gb-font-body);
  font-size: var(--gb-text-sm);
  font-weight: var(--gb-font-weight-semibold);
  line-height: var(--gb-line-height-normal);
  color: var(--gb-text);
}

.product-title {
  font-family: var(--gb-font-heading);
  font-size: var(--gb-text-lg);
  font-weight: var(--gb-font-weight);
  line-height: 1.35;
}

.product-price {
  font-family: var(--gb-font-body);
  font-size: var(--gb-text-lg);
  font-weight: var(--gb-font-weight-medium);
  color: var(--gb-primary);
}

p,
.gb-body-sm {
  font-size: var(--gb-text-sm);
  line-height: var(--gb-line-height-relaxed);
  color: var(--gb-text);
}

.gb-text-muted,
p.gb-text-muted {
  color: var(--gb-text-muted);
}

.gb-lead {
  font-size: var(--gb-text-lg);
  line-height: var(--gb-line-height-relaxed);
  color: var(--gb-text-muted);
}

h3.gb-section-label,
h4.gb-section-label,
.gb-section-label {
  font-family: var(--gb-font-body);
  font-size: var(--gb-text-sm);
  font-weight: var(--gb-font-weight-medium);
  letter-spacing: var(--gb-tracking-widest);
  text-transform: uppercase;
  line-height: 1.3;
  color: var(--gb-text);
}

.gb-nav-label {
  font-size: var(--gb-text-sm);
  font-weight: var(--gb-font-weight-medium);
  letter-spacing: var(--gb-tracking-wide);
  text-transform: uppercase;
  line-height: var(--gb-line-height-tight);
}

.gb-breadcrumb-trail,
.page-breadcrumb {
  font-size: var(--gb-text-xs);
  font-weight: var(--gb-font-weight);
  letter-spacing: var(--gb-tracking-widest);
  text-transform: uppercase;
  line-height: 1.3;
}

.gb-breadcrumb-trail a,
.page-breadcrumb a {
  color: var(--gb-text-muted);
  text-decoration: none;
}

.gb-breadcrumb-trail a:hover,
.page-breadcrumb a:hover {
  color: var(--gb-primary);
}

.gb-breadcrumb-trail .is-current,
.gb-breadcrumb-trail .is-current a,
.gb-breadcrumb-trail .is-current span,
.category-v2-breadcrumb-item.is-current,
.category-v2-breadcrumb-item.is-current span,
.page-breadcrumb > li:last-child,
.page-breadcrumb > li:last-child a {
  color: var(--gb-primary);
  font-weight: var(--gb-font-weight-medium);
}

.gb-field-label {
  font-size: var(--gb-text-xs);
  font-weight: var(--gb-font-weight-medium);
  letter-spacing: var(--gb-tracking-widest);
  text-transform: uppercase;
  line-height: 1.3;
  color: var(--gb-text-muted);
}

small,
.gb-text-xs {
  font-size: var(--gb-text-xs);
  line-height: var(--gb-line-height-normal);
}

a {
  color: var(--gb-primary);
}

a:hover {
  color: var(--gb-primary-dark);
}

/* Global shell (from new-ui.css) */
body.no-scroll {
  overflow: hidden;
}

html::-webkit-scrollbar {
  display: none;
}

html {
  -ms-overflow-style: none;
  scrollbar-width: none;
}

#top {
  background-color: var(--gb-surface);
}

.breadcrumb {
  margin: 0 auto 20px;
  padding: 8px 0;
  border: none;
  background: #ffffff;
  max-width: 1400px;
}

.breadcrumb > li:not(:last-child)::after {
  position: absolute;
  top: 50%;
  right: -10px;
  content: "\f101";
  font: normal normal normal 14px / 1 FontAwesome;
  text-rendering: auto;
  -webkit-font-smoothing: antialiased;
  transform: translate(0, -50%);
  height: auto;
  width: auto;
  border: none;
}

.breadcrumb > li:last-child::after {
  content: none;
}

.breadcrumb > li a {
  color: #8e8e8e;
}

.breadcrumb > li:first-child {
  padding-left: 10px;
}

.container {
  width: 100% !important;
  max-width: 1400px;
  margin: auto !important;
}

div#top {
  max-width: unset;
}

.dropdown-backdrop {
  z-index: 0 !important;
}

@media (max-width: 767px) {
  .max-over {
    overflow: auto !important;
  }
}

.custom-megamenu {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(150px, 1fr));
  font-size: 14px;
  color: #333;
  padding: 0 15px;
}

.custom-country-col {
  display: flex;
  flex-direction: column;
  padding: 10px 10px 30px;
}

.custom-country-col:nth-child(even) {
  background: #fff;
}

.custom-country-title {
  font-weight: bold;
  margin-bottom: 10px;
  font-size: 15px;
  border-bottom: 1px solid #ccc;
  padding-bottom: 2px;
  width: fit-content;
}

.custom-category-list,
.custom-other-countries {
  list-style: none;
  padding: 0;
  margin: 0;
}

.custom-category-list li,
.custom-other-countries li {
  margin-bottom: 6px;
}

.custom-category-list li a,
.custom-other-countries li a {
  text-decoration: none;
  color: #333;
  transition: color 0.3s ease;
}

.custom-category-list li a:hover,
.custom-other-countries li a:hover {
  color: var(--gb-primary);
}

@media (max-width: 1023px) {
  .header_menu #menu .nav > li.drop-down,
  .header_menu #menu .nav > li.dc-nav-item {
    position: relative;
  }
}

.header_menu #menu .nav > li > a.button_:not(.dc-nav-link--parent):after {
  content: none;
}

.swiper-wrapper {
  height: auto !important;
}
/* ==========================================================================
   Buttons
   ========================================================================== */

.btn,
.step__footer__continue-btn,
input[type="button"].btn,
input[type="submit"].btn,
button.btn {
  display: inline-block;
  background: var(--gb-primary);
  color: var(--gb-primary-fg) !important;
  border: none;
  border-radius: var(--gb-radius-sm);
  padding: 13px 28px;
  font-family: var(--gb-font-body);
  font-size: var(--gb-text-sm);
  font-weight: 500;
  line-height: 1;
  cursor: pointer;
  transition: background var(--gb-transition), box-shadow var(--gb-transition);
  text-align: center;
  text-decoration: none;
  letter-spacing: 0.01em;
}

.btn:hover,
.step__footer__continue-btn:hover,
input[type="button"].btn:hover,
input[type="submit"].btn:hover,
button.btn:hover {
  background: var(--gb-primary-dark) !important;
  color: var(--gb-primary-fg) !important;
  box-shadow: 0 2px 8px rgba(42,157,204,.3);
  text-decoration: none;
}

.btn:focus,
.step__footer__continue-btn:focus {
  outline: 2px solid var(--gb-primary);
  outline-offset: 2px;
}

.btn-outline {
  background: transparent;
  color: var(--gb-primary) !important;
  border: 1px solid var(--gb-primary);
}
.btn-outline:hover {
  background: var(--gb-primary-light) !important;
  color: var(--gb-primary) !important;
}

/* step__footer__continue-btn without btn class (checkout pages) */
.step__footer__continue-btn:not(.btn) {
  display: inline-block;
  background: var(--gb-primary);
  color: var(--gb-primary-fg) !important;
  border: none;
  border-radius: var(--gb-radius-sm);
  padding: 13px 28px;
  font-family: var(--gb-font-body);
  font-size: var(--gb-text-sm);
  font-weight: 500;
  cursor: pointer;
  transition: background var(--gb-transition);
}
.step__footer__continue-btn:not(.btn):hover {
  background: var(--gb-primary-dark) !important;
  color: var(--gb-primary-fg) !important;
}

/* ==========================================================================
   Form Inputs
   ========================================================================== */

/* gb-input: border-bottom style from reference */
.gb-input,
.gb-field input,
.gb-field select,
.gb-field textarea {
  font-family: var(--gb-font-body);
  font-size: var(--gb-text-sm);
  color: var(--gb-text);
  border: none;
  border-bottom: 1px solid var(--gb-border);
  padding: var(--gb-sp-3) 0;
  background: transparent;
  width: 100%;
  transition: border-color var(--gb-transition);
  outline: none;
  border-radius: 0;
}

.gb-input:focus,
.gb-field input:focus,
.gb-field select:focus,
.gb-field textarea:focus {
  border-bottom-color: var(--gb-primary);
}

.gb-input::placeholder,
.gb-field input::placeholder {
  color: var(--gb-text-muted);
}

/* ==========================================================================
   Cards
   ========================================================================== */

.gb-card {
  background: var(--gb-surface);
  border: 1px solid var(--gb-border);
  border-radius: var(--gb-radius-md);
  padding: var(--gb-sp-6);
  box-shadow: var(--gb-shadow-sm);
}

.gb-card + .gb-card {
  margin-top: var(--gb-sp-4);
}

/* ==========================================================================
   Checkout page overrides (shipping_address, shipping_method, payment_billing)
   These use the Jay theme shell â€” override key classes here.
   ========================================================================== */

/* Section titles */
.section__title {
  font-family: var(--gb-font-heading) !important;
  font-size: var(--gb-text-xl) !important;
  color: var(--gb-text) !important;
  font-weight: 700;
  margin-bottom: var(--gb-sp-2);
}

.section__text {
  font-size: var(--gb-text-sm);
  color: var(--gb-text-muted);
  margin-top: 0;
}

/* Content boxes â†’ card style */
.content-box {
  border-radius: var(--gb-radius-md) !important;
  border-color: var(--gb-border) !important;
  box-shadow: var(--gb-shadow-sm);
}

/* Breadcrumb */
.breadcrumb__link {
  font-family: var(--gb-font-body);
  font-size: var(--gb-text-sm);
  color: var(--gb-primary);
}
.breadcrumb__item--current {
  font-family: var(--gb-font-body);
  font-size: var(--gb-text-sm);
  color: var(--gb-text);
  font-weight: 500;
}

/* MDL text fields â€” align with design system */
.mdl-textfield__label {
  font-family: var(--gb-font-body) !important;
  font-size: var(--gb-text-sm) !important;
  color: var(--gb-text-muted) !important;
}
.mdl-textfield__input {
  font-family: var(--gb-font-body) !important;
  font-size: var(--gb-text-sm) !important;
  color: var(--gb-text) !important;
}

/* Order summary sidebar */
.order-summary__emphasis {
  font-family: var(--gb-font-body);
  font-weight: 600;
  color: var(--gb-text);
}
.order-summary__small-text {
  font-family: var(--gb-font-body);
  font-size: var(--gb-text-xs);
  color: var(--gb-text-muted);
}

/* Total lines */
.total-line__name,
.total-line__price {
  font-family: var(--gb-font-body);
  font-size: var(--gb-text-sm);
  color: var(--gb-text);
}

/* Step footer */
.step__footer {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding-top: var(--gb-sp-6);
  border-top: 1px solid var(--gb-border-light);
  margin-top: var(--gb-sp-6);
  flex-wrap: wrap;
  gap: var(--gb-sp-4);
}

.step__footer__previous-link {
  font-family: var(--gb-font-body);
  font-size: var(--gb-text-sm);
  color: var(--gb-text-muted);
  text-decoration: none;
  display: flex;
  align-items: center;
  gap: var(--gb-sp-1);
}
.step__footer__previous-link:hover {
  color: var(--gb-primary);
  text-decoration: none;
}
/* ==========================================================================
   Shipping method â€” vendor shipment card
   ========================================================================== */

.shipment-card {
  background: var(--gb-primary-light);
  border: 1px solid var(--gb-border);
  border-radius: var(--gb-radius-md);
  padding: var(--gb-sp-4);
  margin-bottom: var(--gb-sp-3);
}
/**
 * Site header â€” matches Reference/new-cart-page-ui.html
 * Top bar + main bar (logo | nav | actions), breakpoints at 1024px (lg)
 */

/* —— Sticky shell —— */
body > header.site-header {
  position: sticky;
  top: 0;
  z-index: var(--dc-z-header);
  background: var(--dc-header-bg);
  box-shadow: 0 1px 2px rgba(0, 0, 0, 0.05);
  font-family: var(--dc-header-font);
}

body > header.site-header a {
  color: inherit;
  text-decoration: none;
}

/* â”€â”€ Top promo bar â”€â”€ */
.coupon-flash-bar {
  display: inline-block;
  font-weight: 600;
}

.coupon-flash-bar--success {
  color: var(--color-brand-primary, #c04a81);
}

.coupon-flash-bar--error {
  color: #b42318;
}

.header-msg-padding > div:first-child:has(.coupon-flash-bar) {
  display: block !important;
  text-align: center;
  width: 100%;
}

@media (min-width: 1024px) {
  .header-msg-padding > div:first-child:has(.coupon-flash-bar) {
    text-align: left;
  }
}

.header-msg-bg {
  background-color: var(--dc-header-topbar-bg);
  color: var(--dc-header-topbar-fg);
  position: relative;
  z-index: var(--dc-z-header-topbar);
  /* Contain position:fixed country mega-menu in the top-bar layer */
  transform: translateZ(0);
  overflow: visible;
  border-bottom: 1px solid rgba(0, 0, 0, 0.06);
}

.header-msg-padding {
  overflow: visible;
  max-width: var(--dc-header-max);
  margin: 0 auto;
  padding: 8px 16px;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
  font-size: 11px;
  font-weight: 500;
  line-height: 1.4;
}

.header-msg-padding > div:first-child {
  display: none;
  text-align: center;
}

.header-msg-padding > div:first-child a {
  text-decoration: underline;
  color: var(--dc-header-foreground);
}

.header-msg-padding > div:first-child a:hover,
.dc-topbar-promo-link:hover {
  color: var(--dc-header-primary);
}

.dc-topbar-promo-link {
  text-decoration: underline;
  color: var(--dc-header-foreground);
}

.header-msg-right-side {
  display: none;
  align-items: center;
  justify-content: flex-end;
  flex-wrap: wrap;
  gap: 16px;
  flex: 1;
  position: relative;
  z-index: var(--dc-z-header-topbar-dropdown);
}

.header-msg-right-side,
.header-msg-right-side * {
  font-size: 12px !important;
  font-weight: 500;
  color: var(--dc-header-topbar-fg) !important;
}

.header-msg-right-side a:hover,
.header-msg-right-side .main-link:hover {
  color: var(--dc-header-primary) !important;
}

.header-msg-right-side .fa {
  font-size: 12px !important;
}

.header-msg-more-dropdown {
  position: relative;
  display: inline-block;
}

.header-msg-more-menu {
  display: none;
  position: absolute;
  min-width: 180px;
  z-index: var(--dc-z-header-topbar-dropdown);
  border-radius: 8px;
  right: 0;
  top: 100%;
  margin-top: 0;
  border: 1px solid var(--dc-header-border);
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.08);
  overflow: visible;
}

/* Invisible bridge: keeps :hover active while moving from "More" to menu items */
.header-msg-more-menu::before {
  content: '';
  position: absolute;
  left: 0;
  right: 0;
  top: -10px;
  height: 10px;
}

.header-msg-more-menu a {
  color: var(--dc-header-foreground) !important;
  padding: 10px 16px;
  display: block;
  background: var(--dc-header-bg);
  font-size: 14px !important;
}

.header-msg-more-menu a:hover {
  background: #f9fafb;
  color: var(--dc-header-primary) !important;
}

.header-msg-more-dropdown:hover .header-msg-more-menu {
  display: block;
}

.header-msg-right-side .dropdown-menu {
  left: unset;
  right: 0;
  z-index: var(--dc-z-header-topbar-dropdown) !important;
  border-radius: 8px;
  border: 1px solid var(--dc-header-border);
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.08);
}

/* Language / currency: links (not buttons) in top bar */
.header-msg-bg .dc-topbar-dropdown-toggle {
  display: inline-block;
  padding: 0;
  border: none;
  background: none;
  font-size: 12px !important;
  font-weight: 500;
  color: var(--dc-header-topbar-fg) !important;
  text-decoration: none;
  cursor: pointer;
  line-height: inherit;
  font-family: inherit;
}

.header-msg-bg .dc-topbar-dropdown-toggle strong {
  font-weight: 600;
}

.header-msg-bg .dc-topbar-dropdown-toggle:hover,
.header-msg-bg .dc-topbar-dropdown-toggle:focus {
  color: var(--dc-header-primary) !important;
  text-decoration: none;
}

/* Top bar currency/language: Bootstrap dropdown inside <form> */
.header-msg-bg .dc-topbar-dropdown {
  position: relative;
  vertical-align: top;
}

.header-msg-bg .dc-topbar-dropdown > .dropdown-menu {
  display: none;
  position: absolute;
  top: 100%;
  right: 0;
  left: auto;
  margin-top: 0;
  min-width: 160px;
}

.header-msg-bg .dc-topbar-dropdown.open > .dropdown-menu,
.header-msg-bg .dc-topbar-dropdown:hover > .dropdown-menu,
.header-msg-bg .dc-topbar-dropdown:focus-within > .dropdown-menu {
  display: block !important;
  pointer-events: auto;
}

.header-msg-bg .dc-topbar-dropdown > .dropdown-menu::before {
  content: '';
  position: absolute;
  left: 0;
  right: 0;
  top: -8px;
  height: 8px;
}

.header-msg-bg .dropdown-menu > li > a.language-select,
.header-msg-bg .dropdown-menu > li > a.currency-select,
.header-msg-bg .dropdown-menu > li > button.language-select,
.header-msg-bg .dropdown-menu > li > button.currency-select {
  display: block;
  width: 100%;
  padding: 10px 16px;
  border: none;
  background: var(--dc-header-bg);
  font-size: 14px !important;
  font-weight: 500;
  line-height: 1.4;
  color: var(--dc-header-foreground) !important;
  text-align: left;
  text-decoration: none;
  white-space: nowrap;
  cursor: pointer;
}

.header-msg-bg .dropdown-menu > li > a.language-select:hover,
.header-msg-bg .dropdown-menu > li > a.currency-select:hover,
.header-msg-bg .dropdown-menu > li > a.language-select:focus,
.header-msg-bg .dropdown-menu > li > a.currency-select:focus,
.header-msg-bg .dropdown-menu > li > button.language-select:hover,
.header-msg-bg .dropdown-menu > li > button.currency-select:hover {
  background: #f9fafb;
  color: var(--dc-header-primary) !important;
  text-decoration: none;
}

.header-msg-bg .dropdown-menu > li > a.language-select img {
  margin-right: 6px;
  vertical-align: middle;
}

/* Top bar: language, currency, delivery country, More — above main nav row */
.header-msg-bg .dropdown-menu,
.header-msg-bg .country_dropdown-content,
.header-msg-bg .country_dropdown-content.nav-open,
.header-msg-bg .header-msg-more-menu,
.header-msg-bg .btn-group.open,
.header-msg-bg .btn-group.open .dropdown-menu {
  z-index: var(--dc-z-header-topbar-dropdown) !important;
}

/* Main header row: search dropdown */
.dc-header-actions .dropdown-menu,
.header-msg-more-search-box {
  z-index: var(--dc-z-header-search-dropdown) !important;
}

@media (min-width: 768px) {
  .header-msg-padding {
    flex-direction: row;
    padding: 8px 24px;
    font-size: 12px;
  }
}

@media (min-width: 1024px) {
  .header-msg-padding > div:first-child {
    display: block;
    text-align: left;
    flex: 1;
  }

  .header-msg-right-side {
    display: flex;
  }
}

/* â”€â”€ Main header row â”€â”€ */
body > header.site-header #top {
  position: relative;
  z-index: var(--dc-z-header-main-row);
  background: var(--dc-header-bg);
  border-bottom: 1px solid var(--dc-header-border);
  max-width: 100%;
  width: 100%;
  margin: 0;
  padding: 0;
}

body > header.site-header #top.container {
  max-width: 100%;
  padding: 0;
}

.row.modified-header.header_menu.dc-site-header-inner {
  display: grid !important;
  grid-template-columns: auto 1fr auto;
  align-items: center;
  gap: 16px 24px;
  max-width: var(--dc-header-max);
  margin: 0 auto;
  padding: 0 16px;
  min-height: 64px;
  width: 100%;
  position: relative;
}

.row.modified-header.header_menu.dc-site-header-inner::before,
.row.modified-header.header_menu.dc-site-header-inner::after {
  content: none;
}

.row.modified-header.header_menu.dc-site-header-inner > div,
.row.modified-header.header_menu.dc-site-header-inner > nav,
.row.modified-header.header_menu.dc-site-header-inner > button {
  flex: unset;
  float: none;
}

/* Logo */
.dc-site-header-inner .dc-logo-wrap {
  grid-column: 1;
  grid-row: 1;
  justify-self: start;
  z-index: 2;
}

.dc-site-header-inner #logo {
  margin: 0;
  display: flex;
  align-items: center;
  height: 40px;
}

.dc-site-header-inner #logo img,
.dc-site-header-inner img.logo {
  max-height: 40px;
  width: auto;
  height: auto;
  min-width: 0;
  object-fit: contain;
}

.dc-site-header-inner #logo h1 {
  margin: 0;
  font-size: 20px;
  font-weight: 700;
  line-height: 1.2;
}

.dc-site-header-inner #logo h1 a {
  color: var(--dc-header-foreground);
}

/* Primary nav */
.dc-site-header-inner .dc-primary-nav {
  grid-column: 2;
  grid-row: 1;
  justify-self: start;
  width: 100%;
  min-width: 0;
  display: flex;
  align-items: center;
}

#top,
body > header.site-header,
.dc-site-header-inner,
.dc-primary-nav,
.dc-primary-nav #menu {
  overflow: visible;
}

.dc-primary-nav #menu,
.dc-primary-nav nav#menu {
  margin: 0;
  width: 100%;
  backdrop-filter: none;
}

.dc-primary-nav #menu > .container,
.dc-primary-nav #menu > .container.sticky,
body > header.site-header #menu > .container.sticky,
body > header.site-header div.container.sticky {
  width: 100%;
  max-width: none;
  padding: 0;
  overflow: visible;
  position: static !important;
  top: auto !important;
  left: auto !important;
  right: auto !important;
  bottom: auto !important;
  z-index: auto !important;
}

.dc-primary-nav #menu .nav.navbar-nav,
.dc-primary-nav #menu .navbar-nav {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 24px;
  margin: 0;
  padding: 0;
  list-style: none;
}

.dc-primary-nav #menu .nav > li,
.dc-primary-nav #menu .navbar-nav > li {
  margin: 0 !important;
  float: none;
}

.dc-primary-nav #menu .nav > li > a,
.dc-primary-nav #menu .navbar-nav > li > a,
.dc-primary-nav #menu .dc-nav-link {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  padding: 10px 0 !important;
  font-family: var(--gb-font-body) !important;
  font-size: var(--gb-text-sm) !important;
  font-weight: var(--gb-font-weight-medium);
  letter-spacing: var(--gb-tracking-wide);
  text-transform: uppercase;
  line-height: var(--gb-line-height-tight);
  color: rgba(26, 26, 26, 0.8) !important;
  text-shadow: none;
  text-decoration: none;
  white-space: nowrap;
  transition: color 0.15s ease, box-shadow 0.15s ease;
  box-shadow: inset 0 -2px 0 transparent;
}

.dc-primary-nav #menu .nav > li > a:hover,
.dc-primary-nav #menu .navbar-nav > li > a:hover,
.dc-primary-nav #menu .nav > li > a:focus-visible,
.dc-primary-nav #menu .navbar-nav > li > a:focus-visible,
.dc-primary-nav #menu .dc-nav-link--parent:hover,
.dc-primary-nav #menu .dc-nav-link:not(.dc-nav-link--view-all):hover {
  color: var(--dc-header-primary) !important;
  text-decoration: none;
  box-shadow: inset 0 -2px 0 var(--dc-header-primary);
}

.dc-primary-nav #menu .dc-nav-item--active > .dc-nav-link--parent,
.dc-primary-nav #menu .dc-nav-item--active > .dc-nav-link:not(.dc-nav-link--view-all),
.dc-primary-nav #menu .dc-nav-link--active.dc-nav-link--parent {
  color: var(--dc-header-primary) !important;
  box-shadow: inset 0 -2px 0 var(--dc-header-primary);
}

.dc-primary-nav #menu .nav > li > a::after,
.dc-primary-nav #menu .navbar-nav > li > a::after {
  content: none;
}

.dc-primary-nav #menu li.drop-down > .dc-nav-link--parent::after,
.dc-primary-nav #menu li.dc-nav-item > .dc-nav-link--parent::after,
.dc-primary-nav #menu li.dc-nav-more > .dc-nav-link--parent::after {
  content: "\f107";
  font-family: FontAwesome;
  font-size: 12px;
  color: var(--dc-header-muted);
  margin-left: 2px;
  transition: color 0.15s ease;
}

.dc-primary-nav #menu li.drop-down > .dc-nav-link--parent:hover::after,
.dc-primary-nav #menu li.dc-nav-item > .dc-nav-link--parent:hover::after,
.dc-primary-nav #menu li.dc-nav-more > .dc-nav-link--parent:hover::after,
.dc-primary-nav #menu li.dc-nav-item--active > .dc-nav-link--parent::after {
  color: var(--dc-header-primary);
}

.dc-primary-nav #menu span#category {
  display: none !important;
}

.dc-primary-nav .btn.btn-navbar.navbar-toggle {
  display: none;
}

/* Nav dropdown panels */
.dc-primary-nav #menu .dropdown-menu,
.dc-primary-nav #menu ul.dropdown,
.dc-primary-nav #menu ul.dc-nav-dropdown,
.dc-primary-nav .dropdown-menu,
.header_menu #menu li.drop-down > ul,
.header_menu #menu li.drop-down > ul.dropdown,
.header_menu #menu li.dc-nav-item > ul,
.header_menu #menu li.dc-nav-item > ul.dropdown,
li.drop-down > ul,
li.drop-down > ul.dropdown {
  z-index: var(--dc-z-header-nav-dropdown) !important;
  background: var(--dc-header-bg) !important;
  border: 1px solid var(--gb-border);
  border-radius: 8px;
  box-shadow: 0 8px 24px rgba(0, 0, 0, 0.12);
}

.header_menu #menu li.drop-down > ul,
.header_menu #menu li.drop-down > ul.dropdown,
.header_menu #menu li.dc-nav-item > ul,
.header_menu #menu li.dc-nav-item > ul.dropdown,
.header_menu #menu li.dc-nav-more > ul,
.dc-primary-nav #menu li.drop-down > ul.dropdown,
.dc-primary-nav #menu li.dc-nav-item > ul.dropdown,
.dc-primary-nav #menu ul.dc-nav-dropdown,
li.drop-down > ul,
li.drop-down > ul.dropdown {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(180px, 1fr));
  gap: 4px;
  max-width: min(720px, 92vw);
  position: absolute;
  top: 100%;
  left: 0;
  margin: 4px 0 0;
  padding: 12px 16px;
  width: max-content;
  min-width: 220px;
  max-height: calc(100vh - 120px);
  overflow-x: hidden;
  overflow-y: auto;
  list-style: none;
  opacity: 0;
  visibility: hidden;
  transform: translateY(6px);
  pointer-events: none;
  transition: opacity 0.2s ease, transform 0.2s ease, visibility 0.2s ease;
}

.header_menu #menu li.drop-down > ul > li,
.header_menu #menu li.dc-nav-item > ul > li,
.header_menu #menu li.dc-nav-more > ul > li,
li.drop-down > ul > li {
  list-style: none;
  background: transparent;
  margin: 0 !important;
  padding: 0;
}

.header_menu #menu li.drop-down > ul > li > a.button_,
.header_menu #menu li.dc-nav-item > ul > li > a.button_,
.header_menu #menu li.dc-nav-more > ul > li > a.button_,
.header_menu #menu li.drop-down > ul .dc-nav-link,
.header_menu #menu li.dc-nav-item > ul .dc-nav-link,
li.drop-down > ul > li > a.button_,
li.drop-down > ul .dc-nav-link {
  display: block;
  padding: 10px 12px;
  font-size: var(--gb-text-sm);
  font-weight: var(--gb-font-weight-medium);
  line-height: 1.35;
  color: rgba(10, 10, 10, 0.85) !important;
  text-decoration: none;
  text-transform: none;
  letter-spacing: normal;
  border-radius: 6px;
  box-shadow: none;
  transition: color 0.2s ease, background 0.2s ease;
}

.header_menu #menu li.drop-down > ul > li > a.button_:hover,
.header_menu #menu li.dc-nav-item > ul > li > a.button_:hover,
.header_menu #menu li.dc-nav-more > ul > li > a.button_:hover,
.header_menu #menu li.drop-down > ul .dc-nav-link:hover,
.header_menu #menu li.dc-nav-item > ul .dc-nav-link:hover,
li.drop-down > ul > li > a.button_:hover,
li.drop-down > ul .dc-nav-link:hover,
.header_menu #menu li.drop-down > ul > li > a.button_:focus-visible,
.header_menu #menu li.dc-nav-item > ul > li > a.button_:focus-visible,
.header_menu #menu li.drop-down > ul .dc-nav-link:focus-visible,
.header_menu #menu li.dc-nav-item > ul .dc-nav-link:focus-visible,
li.drop-down > ul > li > a.button_:focus-visible,
li.drop-down > ul .dc-nav-link:focus-visible {
  color: var(--dc-header-primary) !important;
  background: var(--gb-primary-light);
  text-decoration: none;
  box-shadow: none;
}

.dc-nav-dropdown__view-all {
  grid-column: 1 / -1;
  margin-bottom: 4px;
  padding-bottom: 8px;
  border-bottom: 1px solid var(--gb-border-light);
}

.dc-nav-link--view-all {
  font-weight: var(--gb-font-weight-semibold) !important;
  color: var(--dc-header-primary) !important;
  text-transform: none !important;
  letter-spacing: normal !important;
}

.dc-nav-link--view-all:hover,
.dc-nav-link--view-all:focus-visible {
  background: var(--gb-primary-light) !important;
}

.dc-nav-dropdown .dc-nav-link--active {
  color: var(--dc-header-primary) !important;
  background: var(--gb-primary-light);
  font-weight: var(--gb-font-weight-semibold);
}

/* Desktop mega-menu hover (giftblooms.com pattern) */
@media (min-width: 1024px) {
  .dc-primary-nav .navbar-collapse.collapse {
    display: block !important;
    height: auto !important;
    visibility: visible !important;
    overflow: visible !important;
  }

  .dc-primary-nav #menu .navbar-header {
    display: none;
  }

  #dc-primary-nav-list > li.float-left {
    float: none !important;
  }

  .row.modified-header.header_menu.dc-site-header-inner,
  .row.modified-header.header_menu.dc-site-header-inner > .dc-logo-wrap,
  .row.modified-header.header_menu.dc-site-header-inner > .dc-primary-nav,
  .dc-primary-nav #menu,
  .dc-primary-nav nav#menu.navbar,
  .dc-primary-nav #menu .nav > li,
  .dc-primary-nav #menu .navbar-nav > li {
    position: static;
  }

  .header_menu #menu li.drop-down,
  .header_menu #menu li.dc-nav-item,
  .header_menu #menu li.dc-nav-more {
    position: relative;
  }

  .header_menu #menu li.drop-down > ul,
  .header_menu #menu li.drop-down > ul.dropdown,
  .header_menu #menu li.dc-nav-item > ul,
  .header_menu #menu li.dc-nav-item > ul.dropdown,
  .dc-primary-nav #menu .navbar-nav > li > ul.dropdown,
  li.drop-down > ul {
    left: 0;
    z-index: var(--dc-z-header-nav-dropdown) !important;
  }

  .header_menu #menu li.drop-down:hover > ul,
  .header_menu #menu li.drop-down:hover > ul.dropdown,
  .header_menu #menu li.dc-nav-item:hover > ul,
  .header_menu #menu li.dc-nav-item:hover > ul.dropdown,
  .header_menu #menu li.drop-down.dc-nav-hover > ul,
  .header_menu #menu li.drop-down.dc-nav-hover > ul.dropdown,
  .header_menu #menu li.dc-nav-item.dc-nav-hover > ul,
  .header_menu #menu li.dc-nav-item.dc-nav-hover > ul.dropdown,
  .header_menu #menu li.dc-nav-more.dc-nav-hover > ul,
  .header_menu #menu li.dc-nav-more:hover > ul,
  .header_menu #menu li.drop-down > a:hover + ul,
  .header_menu #menu li.drop-down > a:hover + ul.dropdown,
  .header_menu #menu li.drop-down > ul:hover,
  .header_menu #menu li.drop-down > ul.dropdown:hover,
  .header_menu #menu li.dc-nav-item > a:hover + ul,
  .header_menu #menu li.dc-nav-item > a:hover + ul.dropdown,
  .header_menu #menu li.dc-nav-item > ul:hover,
  .header_menu #menu li.dc-nav-item > ul.dropdown:hover,
  .header_menu #menu li.dc-nav-more > ul:hover,
  .dc-primary-nav #menu .navbar-nav > li > a:hover + ul.dropdown,
  .dc-primary-nav #menu .navbar-nav > li > ul.dropdown:hover,
  li.drop-down:hover > ul,
  li.drop-down > a:hover + ul,
  li.drop-down > ul:hover {
    opacity: 1;
    visibility: visible;
    transform: translateY(0);
    pointer-events: auto;
  }

  .header_menu #menu li.dc-nav-item.dc-nav-align-end > ul,
  .header_menu #menu li.dc-nav-item.dc-nav-align-end > ul.dropdown,
  .header_menu #menu li.drop-down.dc-nav-align-end > ul,
  .header_menu #menu li.dc-nav-more.dc-nav-align-end > ul {
    left: auto;
    right: 0;
  }

  /* Hover bridge between top link and panel */
  .header_menu #menu li.drop-down::after,
  .header_menu #menu li.dc-nav-item::after,
  .header_menu #menu li.dc-nav-more::after {
    content: "";
    position: absolute;
    left: 0;
    right: 0;
    top: 100%;
    height: 10px;
    display: none;
  }

  .header_menu #menu li.drop-down:hover::after,
  .header_menu #menu li.dc-nav-item:hover::after,
  .header_menu #menu li.drop-down.dc-nav-hover::after,
  .header_menu #menu li.dc-nav-item.dc-nav-hover::after,
  .header_menu #menu li.dc-nav-more:hover::after,
  .header_menu #menu li.dc-nav-more.dc-nav-hover::after {
    display: block;
  }
}

.dc-nav-more[hidden] {
  display: none !important;
}

/* Mobile submenu expand control — hidden on desktop (chevron via ::after) */
.dc-primary-nav .dc-nav-expand,
.dc-primary-nav .mobile-plus {
  display: none;
}

/* Header actions (search, track, login, cart) */
.dc-site-header-inner #top-links {
  grid-column: 3;
  grid-row: 1;
  justify-self: end;
  z-index: 2;
}

.dc-site-header-inner #top-links .list-inline {
  display: flex;
  align-items: center;
  gap: 12px;
  margin: 0;
  padding: 0;
  float: none;
  list-style: none;
}

.dc-site-header-inner #top-links .list-inline > li {
  padding: 0;
  margin: 0;
}

.dc-header-action-btn {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 4px;
  min-width: 36px;
  padding: 4px 2px;
  color: rgba(10, 10, 10, 0.9);
  transition: color 0.15s ease;
  background: none;
  border: none;
  cursor: pointer;
}

.dc-header-action-btn:hover,
.dc-header-action-btn:focus {
  color: var(--dc-header-primary);
  text-decoration: none;
}

.dc-header-action-btn i {
  font-size: 20px;
  line-height: 1;
  width: 20px;
  text-align: center;
}

.dc-header-action-label {
  display: none;
  font-size: 11px;
  font-weight: 500;
  line-height: 1;
}

.header-msg-more-search-toggle {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 4px;
  color: rgba(10, 10, 10, 0.9) !important;
}

.header-msg-more-search-toggle:hover {
  color: var(--dc-header-primary) !important;
}

.header-msg-more-search-toggle i {
  font-size: 20px;
}

.header-msg-more-search-box {
  padding: 12px;
  min-width: 260px;
  border: 1px solid var(--dc-header-border);
  border-radius: 8px;
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.1);
  right: 0;
  left: auto;
  top: calc(100% + 8px);
}

.header-msg-more-search-box input[type="text"],
.header-msg-more-search-box input[type="search"] {
  width: 100%;
  padding: 8px 12px;
  font-size: 14px;
  border: 1px solid var(--dc-header-border);
  border-radius: 6px;
}

.header-link-font {
  font-size: 12px;
  color: var(--dc-header-muted);
  max-width: 100px;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.dc-header-profile .dc-header-profile-name {
  display: block;
  max-width: 72px;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  text-align: center;
  color: var(--dc-header-muted);
}

/* Cart badge â€” reference primary pill */
.cart-icon-wrapper {
  position: relative;
}

.cart-icon-wrapper .dc-header-action-btn {
  position: relative;
}

.cart-icon-wrapper .cart-bubble,
.header-msg-right-side .cart-bubble {
  position: absolute;
  top: -6px;
  right: -8px;
  min-width: 16px;
  height: 16px;
  padding: 0 4px;
  background: var(--dc-header-primary);
  color: #fff;
  font-size: 10px;
  font-weight: 500;
  line-height: 16px;
  border-radius: 9999px;
  border: 2px solid var(--dc-header-bg);
  text-align: center;
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 1;
}

/* Mobile menu toggle */
.dc-nav-toggle {
  display: inline-flex;
  grid-column: 1;
  grid-row: 1;
  justify-self: start;
  align-items: center;
  justify-content: center;
  width: 40px;
  height: 40px;
  margin: 0 0 0 -8px;
  padding: 0;
  border: none;
  border-radius: 6px;
  background: transparent;
  color: var(--dc-header-foreground);
  font-size: 24px;
  line-height: 1;
  cursor: pointer;
  position: relative;
  z-index: 10;
  touch-action: manipulation;
  -webkit-tap-highlight-color: transparent;
  transition: color 0.15s ease;
}

.dc-nav-toggle:hover {
  color: var(--dc-header-primary);
}

/* Top bar row always above main nav row (language/currency/country/More) */
body > header.site-header .header-msg-bg {
  z-index: var(--dc-z-header-topbar) !important;
}

body > header.site-header #top {
  z-index: var(--dc-z-header-main-row) !important;
}

body > header.site-header #top .dc-primary-nav ul.dropdown,
body > header.site-header #top #menu ul.dropdown,
body > header.site-header #top .dc-primary-nav .dropdown-menu,
body > header.site-header #top #menu .dropdown-menu {
  z-index: var(--dc-z-header-nav-dropdown) !important;
}

/* Category page: sit below sticky header (see gb/pages/category.css) */
.category-v2-hero,
.category-v2-page,
.dc-dyncategory-main {
  position: relative;
  z-index: var(--dc-z-category-hero);
}

.category-v2-layout,
.category-v2-content {
  position: relative;
  z-index: var(--dc-z-category-content);
}

/* Country mega-menu (top bar) */
.country__dropdown {
  position: relative;
  display: inline-block;
  vertical-align: top;
  z-index: var(--dc-z-header-topbar-dropdown);
}

.deliveryLink {
  display: inline-block;
}

.country_dropdown-content {
  visibility: hidden;
  opacity: 0;
  position: fixed;
  right: 50%;
  transform: translate(50%, 12px);
  background: var(--dc-header-bg);
  box-shadow: 0 8px 24px rgba(0, 0, 0, 0.12);
  z-index: var(--dc-z-header-topbar-dropdown);
  transition: opacity 0.2s ease, visibility 0.2s ease;
  display: flex;
  flex-direction: column;
  width: 100%;
  max-width: var(--dc-header-max);
  max-height: calc(100vh - 80px);
  overflow: auto;
  border: 1px solid var(--dc-header-border);
  border-radius: 8px;
}

.country_dropdown-content.nav-open {
  visibility: visible;
  opacity: 1 !important;
}

.country_dropdown-content a:hover p {
  color: var(--dc-header-primary);
}

.country_dropdown-content .more-btn {
  align-self: center;
  width: 180px;
  display: block;
  margin: 20px auto;
  text-align: center;
  background: var(--dc-header-primary);
  padding: 12px 15px;
  color: #fff;
  font-size: 14px;
  border-radius: 6px;
  text-transform: uppercase;
  letter-spacing: 1.3px;
  text-decoration: none;
  transition: background 0.2s ease, letter-spacing 0.2s ease;
}

.country_dropdown-content .more-btn:hover,
.country_dropdown-content .more-btn:focus {
  background: #c91858;
  color: #fff;
  letter-spacing: 1.5px;
}

.country_dropdown-content .custom-megamenu {
  gap: 12px;
}

.country_dropdown-content .custom-country-col {
  padding: 8px 12px;
}

.country_dropdown-content .custom-category-list a {
  padding: 4px 0;
}

.country_dropdown-content .custom-category-list a:hover,
.country_dropdown-content .custom-other-countries a:hover {
  color: var(--dc-header-primary);
}

.country_dropdown-content a span {
  width: 25px;
  height: 20px;
  box-shadow: 1px 2px 2px rgba(0, 0, 0, 0.25);
}

.country_dropdown-content a span img {
  width: 100%;
  height: 100%;
}

.country_dropdown-content a p {
  color: var(--dc-header-foreground);
}

img.img-responsive.logo.store-0 {
  min-width: 120px;
  max-width: 185px;
}

.pull-left {
  float: none !important;
}

.alert.alert-success.alert-dismissible {
  display: none;
}

/* Mobile drawer */
body.dc-drawer-open::before {
  content: "";
  position: fixed;
  inset: 0;
  background: rgba(0, 0, 0, 0.35);
  z-index: var(--dc-z-drawer-backdrop);
  pointer-events: auto;
}

body.dc-drawer-open {
  overflow: hidden;
}

body.dc-drawer-open > header.site-header {
  z-index: var(--dc-z-drawer-header);
}

/* â”€â”€ Desktop (lg: 1024px+) â”€â”€ */
@media (min-width: 1024px) {
  .row.modified-header.header_menu.dc-site-header-inner {
    min-height: 80px;
    padding: 0 24px;
    gap: 24px 32px;
  }

  .dc-site-header-inner #logo,
  .dc-site-header-inner #logo img {
    max-height: 48px;
    height: 48px;
  }

  .dc-nav-toggle {
    display: none;
  }

  .dc-site-header-inner .dc-logo-wrap {
    position: static;
    transform: none;
    grid-column: 1;
    justify-self: start;
  }

  .dc-site-header-inner .dc-primary-nav {
    display: flex;
    grid-column: 2;
  }

  .dc-site-header-inner #top-links {
    grid-column: 3;
  }

  .dc-header-action-label {
    display: block;
  }

  #top-links .list-inline {
    gap: 20px;
  }
}

/* â”€â”€ Mobile / tablet (< 1024px) â”€â”€ */
@media (max-width: 1023px) {
  .row.modified-header.header_menu.dc-site-header-inner {
    min-height: 64px;
    gap: 8px;
  }

  .dc-site-header-inner .dc-logo-wrap {
    position: absolute;
    left: 50%;
    top: 50%;
    transform: translate(-50%, -50%);
    grid-column: 1 / -1;
    justify-self: center;
    pointer-events: none;
  }

  .dc-site-header-inner .dc-logo-wrap a,
  .dc-site-header-inner .dc-logo-wrap #logo {
    pointer-events: auto;
  }

  .dc-site-header-inner #top-links {
    grid-column: 3;
    justify-self: end;
  }

  .dc-site-header-inner:not(.dc-drawer-open) .dc-primary-nav {
    display: none !important;
    visibility: hidden !important;
    pointer-events: none !important;
  }

  .dc-site-header-inner .dc-primary-nav {
    grid-column: auto;
    position: fixed;
    top: 0;
    right: 0;
    left: auto;
    width: min(360px, 92vw) !important;
    max-width: 92vw !important;
    height: 100vh;
    overflow-y: auto;
    background: var(--dc-header-bg);
    z-index: var(--dc-z-drawer-panel);
    padding: 56px 20px 24px;
    box-shadow: -4px 0 24px rgba(0, 0, 0, 0.12);
    flex-direction: column;
    align-items: stretch;
  }

  .dc-site-header-inner.dc-drawer-open .dc-primary-nav {
    display: flex !important;
    visibility: visible !important;
    pointer-events: auto !important;
    padding-top: max(16px, env(safe-area-inset-top, 0px));
    box-shadow: -6px 0 32px rgba(0, 0, 0, 0.14);
  }

  .dc-site-header-inner.dc-drawer-open .dc-nav-toggle {
    position: relative;
    z-index: calc(var(--dc-z-drawer-panel) + 5);
  }

  .dc-site-header-inner.dc-drawer-open .dc-primary-nav #menu .nav.navbar-nav,
  .dc-site-header-inner.dc-drawer-open .dc-primary-nav #menu .navbar-nav,
  .dc-site-header-inner.dc-drawer-open .dc-primary-nav nav .nav > li {
    display: block !important;
    float: none !important;
    width: 100%;
  }

  .dc-site-header-inner.dc-drawer-open .dc-primary-nav #menu .nav > li > a {
    padding: 12px 0 !important;
    border-bottom: 1px solid var(--dc-header-border);
  }

  .dc-site-header-inner.dc-drawer-open .dc-primary-nav li.drop-down > .dc-nav-link--parent,
  .dc-site-header-inner.dc-drawer-open .dc-primary-nav li.dc-nav-item > .dc-nav-link--parent,
  .dc-site-header-inner.dc-drawer-open .dc-primary-nav li.dc-nav-more > .dc-nav-link--parent {
    display: block;
    width: 100%;
    box-sizing: border-box;
    padding-right: 52px !important;
    white-space: normal;
  }

  .dc-site-header-inner.dc-drawer-open .dc-primary-nav li.drop-down,
  .dc-site-header-inner.dc-drawer-open .dc-primary-nav li.dc-nav-item,
  .dc-site-header-inner.dc-drawer-open .dc-primary-nav li.dc-nav-more {
    position: relative;
  }

  .dc-site-header-inner.dc-drawer-open .dc-primary-nav span.mobile-plus:not(button) {
    font-size: 0;
    line-height: 0;
    color: transparent;
    overflow: hidden;
  }

  .dc-site-header-inner.dc-drawer-open .dc-primary-nav li.drop-down > .dc-nav-expand,
  .dc-site-header-inner.dc-drawer-open .dc-primary-nav li.dc-nav-item > .dc-nav-expand,
  .dc-site-header-inner.dc-drawer-open .dc-primary-nav li.dc-nav-more > .dc-nav-expand,
  .dc-site-header-inner.dc-drawer-open .dc-primary-nav li.drop-down > .mobile-plus,
  .dc-site-header-inner.dc-drawer-open .dc-primary-nav li.dc-nav-item > .mobile-plus,
  .dc-site-header-inner.dc-drawer-open .dc-primary-nav li.dc-nav-more > .mobile-plus {
    display: flex;
    align-items: center;
    justify-content: center;
    position: absolute;
    top: 50%;
    right: 0;
    width: 44px;
    height: 44px;
    margin-top: -22px;
    z-index: 3;
    padding: 0;
    border: 1px solid var(--dc-header-border);
    border-radius: 50%;
    background: var(--dc-header-bg);
    cursor: pointer;
    color: var(--dc-header-muted);
    transition: transform 0.2s ease, border-color 0.2s ease;
    appearance: none;
    -webkit-appearance: none;
  }

  .dc-site-header-inner.dc-drawer-open .dc-primary-nav .dc-nav-expand::before,
  .dc-site-header-inner.dc-drawer-open .dc-primary-nav .mobile-plus::before {
    content: "";
    display: block;
    width: 12px;
    height: 12px;
    border-right: 2px solid currentColor;
    border-bottom: 2px solid currentColor;
    transform: rotate(45deg) translate(-2px, -2px);
    transition: transform 0.2s ease;
  }

  .dc-site-header-inner.dc-drawer-open .dc-primary-nav li.dc-nav-open > .dc-nav-expand::before,
  .dc-site-header-inner.dc-drawer-open .dc-primary-nav li.dc-nav-open > .mobile-plus::before {
    transform: rotate(-135deg) translate(-2px, -2px);
  }

  .dc-site-header-inner.dc-drawer-open .dc-primary-nav li.drop-down > a::after,
  .dc-site-header-inner.dc-drawer-open .dc-primary-nav li.dc-nav-item > a::after,
  .dc-site-header-inner.dc-drawer-open .dc-primary-nav li.dc-nav-more > a::after {
    content: none;
  }

  .dc-site-header-inner.dc-drawer-open .dc-primary-nav .navbar-collapse.collapse {
    display: block !important;
    height: auto !important;
    visibility: visible !important;
    overflow: visible !important;
  }

  .dc-site-header-inner.dc-drawer-open .dc-primary-nav #menu > .container {
    width: 100%;
    max-width: none;
    padding: 0;
  }

  .dc-site-header-inner.dc-drawer-open .dc-primary-nav #menu .navbar-header {
    display: none;
  }

  .dc-site-header-inner.dc-drawer-open .dc-primary-nav li.drop-down > ul,
  .dc-site-header-inner.dc-drawer-open .dc-primary-nav li.dc-nav-item > ul,
  .dc-site-header-inner.dc-drawer-open .dc-primary-nav li.dc-nav-more > ul {
    position: static;
    display: none;
    max-height: none;
    width: 100%;
    max-width: none;
    min-width: 0;
    margin: 0;
    padding: 0 0 0 16px;
    box-shadow: none;
    border: 0;
    grid-template-columns: 1fr;
    opacity: 1;
    visibility: visible;
    transform: none;
    pointer-events: auto;
  }

  .dc-site-header-inner.dc-drawer-open .dc-primary-nav li.dc-nav-open > ul {
    display: grid;
    padding-bottom: 12px;
  }

  .dc-site-header-inner.dc-drawer-open .dc-primary-nav li.dc-nav-open > .dc-nav-expand,
  .dc-site-header-inner.dc-drawer-open .dc-primary-nav li.dc-nav-open > .mobile-plus {
    border-color: var(--dc-header-primary);
    color: var(--dc-header-primary);
  }

  .dc-site-header-inner.dc-drawer-open .dc-primary-nav .dc-nav-dropdown__view-all {
    border-bottom-color: var(--dc-header-border);
    margin-bottom: 8px;
    padding-bottom: 10px;
  }

  #top-links .list-inline {
    gap: 8px;
  }

  .dc-site-header-inner .header-link-font {
    display: none;
  }
}

@media (max-width: 500px) {
  .header-msg-padding {
    padding: 8px 12px;
  }

  .header-msg-right-side .dropdown-menu {
    right: -50%;
    transform: translateX(50%);
  }
}

/* Legacy OpenCart product grid (layout only; typography in canon block above) */
.product-thumb {
  border: 1px solid #ddd;
  margin-bottom: 20px;
  overflow: auto;
}
.product-thumb .image {
  text-align: center;
}
.product-thumb .image a {
  display: block;
}
.product-thumb .image a:hover {
  opacity: 0.8;
}
.product-thumb .image img {
  margin-left: auto;
  margin-right: auto;
}
.product-grid .product-thumb .image {
  float: none;
}
@media (min-width: 767px) {
  .product-list .product-thumb .image {
    float: left;
    padding: 0 15px;
  }
}
.product-thumb .caption {
  padding: 0 20px;
  min-height: 180px;
}
.product-list .product-thumb .caption {
  margin-left: 230px;
}
@media (max-width: 1200px) {
  .product-grid .product-thumb .caption {
    min-height: 210px;
    padding: 0 10px;
  }
}
@media (max-width: 767px) {
  .product-list .product-thumb .caption,
  .product-grid .product-thumb .caption {
    min-height: 0;
    margin-left: 0;
    padding: 0 10px;
  }
}
.product-thumb .rating {
  padding-bottom: 10px;
}
.rating .fa-stack {
  font-size: 8px;
}
.rating .fa-star-o {
  color: #999;
  font-size: 15px;
}
.rating .fa-star {
  color: #fc0;
  font-size: 15px;
}
.rating .fa-star + .fa-star-o {
  color: #e69500;
}
h2.price {
  margin: 0;
}
.product-thumb .price {
  color: #444;
}
.product-thumb .price-new {
  font-weight: 600;
}
.product-thumb .price-old {
  color: #999;
  text-decoration: line-through;
  margin-left: 10px;
}
.product-thumb .price-tax {
  color: #999;
  font-size: 12px;
  display: block;
}
.product-thumb .button-group {
  border-top: 1px solid #ddd;
  background-color: #eee;
  overflow: auto;
}
.product-list .product-thumb .button-group {
  border-left: 1px solid #ddd;
}
@media (max-width: 768px) {
  .product-list .product-thumb .button-group {
    border-left: none;
  }
}
.product-thumb .button-group button {
  width: 60%;
  border: none;
  display: inline-block;
  float: left;
  background-color: #eee;
  color: #888;
  line-height: 38px;
  font-weight: bold;
  text-align: center;
  text-transform: uppercase;
}
.product-thumb .button-group button + button {
  width: 20%;
  border-left: 1px solid #ddd;
}
.product-thumb .button-group button:hover {
  color: #444;
  background-color: #ddd;
  text-decoration: none;
  cursor: pointer;
}
@media (max-width: 1200px) {
  .product-thumb .button-group button,
  .product-thumb .button-group button + button {
    width: 33.33%;
  }
}
@media (max-width: 767px) {
  .product-thumb .button-group button,
  .product-thumb .button-group button + button {
    width: 33.33%;
  }
}
.thumbnails {
  overflow: auto;
  clear: both;
  list-style: none;
  padding: 0;
  margin: 0 0 0 -20px;
}
.thumbnails > li {
  margin-left: 20px;
}
.thumbnails > img {
  width: 100%;
}
.image-additional a {
  margin-bottom: 20px;
  padding: 5px;
  display: block;
  border: 1px solid #ddd;
}
.image-additional {
  max-width: 78px;
}
.thumbnails .image-additional {
  float: left;
  margin-left: 20px;
}
@media (min-width: 1200px) {
  #content .col-lg-2:nth-child(6n+1),
  #content .col-lg-3:nth-child(4n+1),
  #content .col-lg-4:nth-child(3n+1),
  #content .col-lg-6:nth-child(2n+1) {
    clear: left;
  }
}
@media (min-width: 992px) and (max-width: 1199px) {
  #content .col-md-2:nth-child(6n+1),
  #content .col-md-3:nth-child(4n+1),
  #content .col-md-4:nth-child(3n+1),
  #content .col-md-6:nth-child(2n+1) {
    clear: left;
  }
}
@media (min-width: 768px) and (max-width: 991px) {
  #content .col-sm-2:nth-child(6n+1),
  #content .col-sm-3:nth-child(4n+1),
  #content .col-sm-4:nth-child(3n+1),
  #content .col-sm-6:nth-child(2n+1) {
    clear: left;
  }
}
@media (min-width: 768px) {
  #column-left .product-layout .col-md-3 {
    width: 100%;
  }
  #column-left + #content .product-layout .col-md-3 {
    width: 50%;
  }
  #column-left + #content + #column-right .product-layout .col-md-3,
  #content + #column-right .product-layout .col-md-3 {
    width: 100%;
  }
}
#column-left .product-layout,
#column-right .product-layout {
  width: 100%;
}

/* ==========================================================================
   Modals & overlays (above header + category page)
   ========================================================================== */

.modal-backdrop {
  z-index: var(--dc-z-modal-backdrop) !important;
}

.modal,
#myModal.modal {
  z-index: var(--dc-z-modal) !important;
}

#myModal .modal-dialog {
  z-index: var(--dc-z-modal);
  position: relative;
}

#myModal .discount-popup-cross,
#myModal .fa.fa-close.discount-popup-cross {
  z-index: var(--dc-z-modal-close);
}

/* Delivery location modal (localization_model.twig) */
.delivery-location-overlay {
  display: none;
  position: fixed;
  inset: 0;
  z-index: var(--dc-z-delivery-overlay);
  background: rgba(0, 0, 0, 0.5);
  overflow-x: hidden;
  overflow-y: auto;
  padding: 24px 16px;
  box-sizing: border-box;
}

.delivery-location-overlay.is-open {
  display: block;
}

body.delivery-modal-open {
  overflow: hidden;
}

.delivery-location-panel {
  max-width: 500px;
  margin: 0 auto;
  position: relative;
  z-index: 1;
}

.pac-container {
  z-index: var(--dc-z-places-autocomplete) !important;
}

/* Accessibility skip link (category pages) */
.dc-skip-link {
  z-index: var(--dc-z-skip-link);
}
.input-group .form-control[name^='quantity'] {
  min-width: 50px;
}
