/* ==========================================================================
   MAIN.CSS - Consolidated & Reorganized Application Overrides
   Site: Hard Row to Hoe Vineyards
   Sections: 1 to 14 (Header & Footer grouped at the bottom)
   ========================================================================== */

/* ==========================================================================
   SECTION 1: GOOGLE WEB FONTS & ICON DECLARATIONS
   ========================================================================== */

@import url("https://fonts.googleapis.com/css2?family=Inter:wght@400;500;700&family=Montserrat:wght@700;800;900&family=Work+Sans:wght@300;400;500;600;700;800;900&display=swap");

@font-face {
  font-family: "Font Awesome 5 Brands";
  font-style: normal;
  font-weight: 400;
  font-display: block;
  src: url("https://orderport-webstore.b-cdn.net/YonahMountainVineyards/fonts/fa-brands-400.eot");
  src: url("https://orderport-webstore.b-cdn.net/YonahMountainVineyards/fonts/fa-brands-400.eot?#iefix") format("embedded-opentype"),
    url("https://orderport-webstore.b-cdn.net/YonahMountainVineyards/fonts/fa-brands-400.woff2") format("woff2"),
    url("https://orderport-webstore.b-cdn.net/YonahMountainVineyards/fonts/fa-brands-400.woff") format("woff"),
    url("https://orderport-webstore.b-cdn.net/YonahMountainVineyards/fonts/fa-brands-400.ttf") format("truetype"),
    url("https://orderport-webstore.b-cdn.net/YonahMountainVineyards/fonts/fa-brands-400.svg#fontawesome") format("svg");
}

@font-face {
  font-family: "Font Awesome 5 Pro";
  font-style: normal;
  font-weight: 400;
  font-display: block;
  src: url("https://orderport-webstore.b-cdn.net/YonahMountainVineyards/fonts/fa-regular-400.eot");
  src: url("https://orderport-webstore.b-cdn.net/YonahMountainVineyards/fonts/fa-regular-400.eot?#iefix") format("embedded-opentype"),
    url("https://orderport-webstore.b-cdn.net/YonahMountainVineyards/fonts/fa-regular-400.woff") format("woff"),
    url("https://orderport-webstore.b-cdn.net/YonahMountainVineyards/fonts/fa-regular-400.ttf") format("truetype"),
    url("https://orderport-webstore.b-cdn.net/YonahMountainVineyards/fonts/fa-regular-400.svg#fontawesome") format("svg");
}

@font-face {
  font-family: "Font Awesome 5 Pro";
  font-style: normal;
  font-weight: 900;
  font-display: block;
  src: url("https://orderport-webstore.b-cdn.net/YonahMountainVineyards/fonts/fa-solid-900.eot");
  src: url("https://orderport-webstore.b-cdn.net/YonahMountainVineyards/fonts/fa-solid-900.eot?#iefix") format("embedded-opentype"),
    url("https://orderport-webstore.b-cdn.net/YonahMountainVineyards/fonts/fa-solid-900.woff2") format("woff2"),
    url("https://orderport-webstore.b-cdn.net/YonahMountainVineyards/fonts/fa-solid-900.woff") format("woff"),
    url("https://orderport-webstore.b-cdn.net/YonahMountainVineyards/fonts/fa-solid-900.ttf") format("truetype"),
    url("https://orderport-webstore.b-cdn.net/YonahMountainVineyards/fonts/fa-solid-900.svg#fontawesome") format("svg");
}

/* ==========================================================================
   SECTION 2: DESIGN SYSTEM & CSS VARIABLES
   ========================================================================== */

/* ========================================
   ROOT VARIABLES - Design System
   ======================================== */
:root {
  /* ========== GOOGLE FONT WORK SANS DESIGN TOKENS ========== */
  --base-font-size: 16px;
  --heading-font-font-family: "Work Sans";
  --heading-font-font-style: normal;
  --heading-font-font-weight: 600;
  --heading-font-text-transform: none;
  --heading-font-letter-spacing: .01em;
  --heading-font-line-height: 1.2em;
  --body-font-font-family: "Work Sans";
  --body-font-font-style: normal;
  --body-font-font-weight: 500;
  --body-font-text-transform: none;
  --body-font-letter-spacing: 0em;
  --body-font-line-height: 1.6em;
  --meta-font-font-family: "Work Sans";
  --meta-font-font-style: normal;
  --meta-font-font-weight: 500;
  --meta-font-text-transform: uppercase;
  --meta-font-letter-spacing: 0em;
  --meta-font-line-height: .8em;
  --heading-1-size: 4.2rem;
  --heading-1-size-value: 4.2;
  --heading-2-size: 2.7rem;
  --heading-2-size-value: 2.7;
  --heading-3-size: 1.7rem;
  --heading-3-size-value: 1.7;
  --heading-4-size: 1.4rem;
  --heading-4-size-value: 1.4;
  --large-text-size: 1.2rem;
  --large-text-size-value: 1.2;
  --normal-text-size: 1rem;
  --normal-text-size-value: 1;
  --small-text-size: .9rem;
  --small-text-size-value: .9;
  --normal-meta-size: .9rem;
  --normal-meta-size-value: .9;

  --primary-button-font-font-family: "Work Sans";
  --primary-button-font-font-style: normal;
  --primary-button-font-font-weight: 500;
  --primary-button-font-text-transform: uppercase;
  --primary-button-font-letter-spacing: .02em;
  --primary-button-font-line-height: 1.2em;
  --primary-button-font-font-size: 1rem;
  --primary-button-font-font-size-value: 1;

  --secondary-button-font-font-family: "Work Sans";
  --secondary-button-font-font-style: normal;
  --secondary-button-font-font-weight: 500;
  --secondary-button-font-text-transform: uppercase;
  --secondary-button-font-letter-spacing: .02em;
  --secondary-button-font-line-height: 1.2em;
  --secondary-button-font-font-size: 1.1rem;
  --secondary-button-font-font-size-value: 1.1;

  /* ========== TYPOGRAPHY ========== */
  /* Font Families - 2 Font Maximum */
  --font-display: "Montserrat";
  --font-body: "Inter";

  /* Font Sizes - Standardized Scale */
  --font-size-2xs: 11px;
  --font-size-xs: 12px;
  --font-size-sm: 14px;
  --font-size-base: 16px;
  --font-size-md: 18px;
  --font-size-lg: 20px;
  --font-size-xl: 24px;
  --font-size-2xl: 32px;

  /* Font Weights */
  --font-weight-normal: 400;
  --font-weight-medium: 500;

  /* Line Heights */
  --line-height-tight: 1.4;
  --line-height-normal: 1.6;

  /* ========== COLOR PALETTE ========== */
  /* Primary Brand Color - Wine/Burgundy */
  --color-primary: #ec6c38;
  --color-primary-dark: #502c18;
  --color-primary-light: #ec6c38;

  /* Neutral Colors */
  --color-white: #fff;
  --color-black: #000;
  --color-gray-50: #f7f8fa;
  --color-gray-100: #fdfcfa;
  --color-gray-200: #eee;
  --color-gray-300: #ccc;
  --color-gray-400: #999;
  --color-gray-500: #666;
  --color-gray-600: #5f5f5f;
  --color-gray-700: #4b4a59;
  --color-gray-800: #2b2b2b;
  --color-gray-900: #000;

  /* Semantic Colors */
  --color-text: var(--color-gray-600);
  --color-text-dark: var(--color-gray-800);
  --color-text-light: var(--color-gray-500);
  --color-background: var(--color-white);
  --color-border: var(--color-gray-300);
  --color-border-light: var(--color-gray-200);
  --color-error: #ff3333;

  /* ========== COMPONENT COLORS ========== */
  --color-input-bg: var(--color-white);
  --color-input-text: var(--color-gray-700);
  --color-input-border: var(--color-border);

  /* ========== OVERLAYS & TRANSPARENCY ========== */
  --overlay-subtle: rgba(0, 0, 0, 0.1);
  --overlay-light: rgba(167, 172, 183, 0.3);
  --overlay-medium: rgba(0, 0, 0, 0.16);
  --overlay-strong: rgba(0, 0, 0, 0.5);
  --overlay-dark: rgba(0, 0, 0, 0.8);
  --overlay-header: rgba(19, 24, 29, 0.12);

  /* ========== SPACING ========== */
  --border-width-thin: 1px;
  --border-radius-sm: 3px;
  --border-radius-md: 4px;
  --border-radius-lg: 5px;

  /* ========== SHADOWS ========== */
  --shadow-sm: none;
  --shadow-md: none;
  --shadow-lg: none;

  /* ========== GRADIENTS ========== */
  --gradient-primary: linear-gradient(
    135deg,
    var(--color-primary) 0%,
    var(--color-primary-dark) 100%
  );
  --gradient-error: linear-gradient(287deg, #f0280a 0%, #bc2610 100%);

  /* ========== LAYOUT ========== */
  --container-max-width: 1320px;
  --header-height: 150px;

  /* ========== LEGACY/COMPONENT PROPERTIES ========== */
  --btn-padding: 12px 15px;
  --btn-text-transform: uppercase;
  --btn-letter-spacing: 1px;
  --btn-border: var(--border-width-thin) solid var(--color-primary);
  --btn-hover-opacity: 1;
  --cart-summary-top: 150px;

  /* ========== NAVIGATION SPECIFIC ========== */
  --nav-bg-color: #502c18;
  --nav-text-color: #ffffff;
  --nav-link-color: #ffffff;
  --nav-link-hover-color: #ffffff;

  /* Brand Accent */
  --color-accent: #eae7e1;
  --color-accent-secondary: var(--color-primary);

  /* ========== SPACING SCALE ========== */
  --spacing-3xs: 4px;
  --spacing-2xs: 8px;
  --spacing-xs: 12px;
  --spacing-sm: 16px;
  --spacing-md: 20px;
  --spacing-lg: 24px;
  --spacing-xl: 32px;
  --spacing-2xl: 40px;
  --spacing-3xl: 48px;
  --spacing-4xl: 60px;

  /* ========== BORDER RADII SCALE ========== */
  --radius-xs: 0;
  --radius-sm: 0;
  --radius-md: 0;
  --radius-lg: 0;
  --radius-xl: 0;
  --radius-pill: 0;

  /* ========== FONT WEIGHTS (extended) ========== */
  --font-weight-semibold: 600;
}


/* ==========================================================================
   SECTION 3: BOOTSTRAP VARIABLE OVERRIDES
   ========================================================================== */

/* ========================================
   BOOTSTRAP VARIABLE OVERRIDES
   Align Bootstrap variables with design system
   ======================================== */
:root {
  /* Core Brand Colors */
  --purple: var(--color-primary);
  --maroon: var(--color-primary-dark);
  --orange: var(--color-primary-light);
  --light: var(--color-white);
  --darkkhaki: var(--color-primary-light);
  --black: var(--color-black);

  /* Typography */
  --font-family-primary: var(--font-body);
  --font-color: var(--color-text);
  --font-color-rgb: 136, 136, 136;

  /* Borders */
  --border-color: var(--color-border);
  --border: 1px solid var(--border-color);

  /* Primary Colors */
  --primary: var(--color-primary);
  --primary-rgb: 211, 30, 37;
  --primary-dark: var(--color-primary-dark);
  --primary-light: var(--color-white);

  /* Secondary Colors */
  --secondary: var(--color-primary-light);

  /* Background */
  --bg-color: transparent;
  --modal-bg-color: var(--color-white);
  --bg-input: var(--color-white);

  /* Button Styles */
  --btn-border-color: var(--color-accent);
  --btn-bg-color: var(--color-accent);
  --btn-color: var(--color-white);
  --btn-active-bg-color: var(--color-accent);
  --btn-active-color: var(--color-white);
  --btn-active-border-color: var(--color-accent);
  --btn-background-color: var(--color-accent);
  --btn-text-color: var(--color-white);
  --btn-hover-background-color: #3a5070;
  --btn-hover-text-color: var(--color-white);
  --box-shadow-primary: 0 0 0 0.2rem rgba(72, 100, 138, 0.25);

  /* Links */
  --lnk-color: var(--color-primary);
  --lnk-color-active: var(--color-primary-light);

  /* Headings */
  --head-color: var(--color-primary);

  /* Forms */
  --bg-color-checkbox: var(--color-black);
}

/* ==========================================================================
   SECTION 4: CONSOLIDATED BUTTON STYLES
   ========================================================================== */

/* ========================================
   BUTTON STYLES - Consolidated
   All button types, states, and variants
   ======================================== */
/* Base button element resets */
button {
  background-color: transparent;
  padding: 0;
  border: 0;
  cursor: pointer;
}

/* Primary button class */
.btn {
  display: inline-block;
  vertical-align: middle;
  text-decoration: none;
  border: 1px solid var(--color-primary-dark);
  background: var(--color-primary-dark);
  color: var(--color-white);
  border-radius: 0;
  padding: var(--btn-padding);
  cursor: pointer;
  transition: background-color 0.25s ease-in-out, color 0.25s ease-in-out, border-color 0.25s ease-in-out;
}

.btn:hover,
.btn:focus,
.btn:active {
  text-decoration: none;
  background: var(--color-white);
  color: var(--color-primary-dark);
  border: 1px solid var(--color-primary-dark);
}

/* Button element with btn class */
button.btn {
  border: 1px solid var(--color-primary-dark) !important;
  background: var(--color-primary-dark) !important;
  color: var(--color-white) !important;
  padding: var(--btn-padding) !important;
  cursor: pointer !important;
  transition: all 0.25s ease-in-out !important;
}

button.btn:hover,
button.btn:focus,
button.btn:active {
  background: var(--color-white) !important;
  color: var(--color-primary-dark) !important;
  border: 1px solid var(--color-primary-dark) !important;
}

/* Full-width block button */
.btn-block {
  display: block !important;
  width: 100% !important;
  border: 1px solid var(--color-primary-dark) !important;
  background: var(--color-primary-dark) !important;
  color: var(--color-white) !important;
  padding: var(--btn-padding) !important;
  cursor: pointer !important;
  transition: all 0.25s ease-in-out !important;
  text-align: center !important;
  font-weight: 600 !important;
}

.btn-block:hover,
.btn-block:focus,
.btn-block:active {
  background: var(--color-white) !important;
  color: var(--color-primary-dark) !important;
  border: 1px solid var(--color-primary-dark) !important;
}

.btn-close-wrap {
  flex-shrink: 0;
  height: 68px;
  position: relative;
  background: transparent;
  border-bottom: 1px solid rgba(255, 255, 255, 0.1);
  display: flex;
  align-items: center;
  justify-content: flex-end;
  padding: 0 var(--spacing-lg);
}

.btn-close-menu {
  cursor: pointer;
  color: #ffffff;
  background: none;
  border: none;
  padding: var(--spacing-sm);
  transition: opacity 0.2s, transform 0.2s;
  position: relative;
  top: auto;
  right: auto;
  display: flex;
  align-items: center;
  justify-content: center;
}

.btn-close-menu:hover {
  opacity: 0.7;
  transform: rotate(90deg);
}

.btn-close-menu svg {
  width: 28px;
  height: 28px;
  stroke: #ffffff;
  display: block;
}

.variations ul li a.btn {
  float:none;
}

.btns .btn {
  margin:0 var(--spacing-2xs) 0 0;
}

.wineclub-membership > div[class^="club-"] > a.btn {
  display:block !important;
  text-align:center !important;
  font-family:var(--font-body) !important;
  font-size:var(--font-size-sm) !important;
  font-weight:600 !important;
  text-transform:uppercase !important;
  letter-spacing:1.5px !important;
  background:var(--color-primary-dark) !important;
  color:var(--color-white) !important;
  border:none !important;
  border-radius: 0 !important;
  padding:var(--spacing-xs) var(--spacing-lg) !important;
  text-decoration:none !important;
  transition:all 0.3s cubic-bezier(0.16, 1, 0.3, 1) !important;
  box-shadow: none !important;
  margin-top:auto !important;
  order:3 !important;
  cursor:pointer !important;
}

.wineclub-membership > div[class^="club-"] > a.btn:hover {
  background: var(--color-white) !important;
  color: var(--color-primary-dark) !important;
  border: 1px solid var(--color-primary-dark) !important;
  transform:translateY(-2px) !important;
  box-shadow: none !important;
}

@media only screen and (max-width:479px) {
  .btn {
      margin-bottom: 0;
    }
}

button {
  background-color:transparent;
  padding:0;
  border:0;
  cursor:pointer;
}

/* ==========================================================================
   SECTION 5: GLOBAL RESETS & BASE ELEMENTS
   ========================================================================== */

html,
body {
  min-height:100%;
  background:var(--color-white);
  font-family:var(--font-body);
}

body {
  margin:0;
  padding:0;
  min-width:320px;
  background:var(--color-white) !important;
  font-family:var(--font-body);
  font-size:var(--font-size-base);
  font-weight:400;
  line-height:var(--line-height-normal);
  color:var(--color-text);
  -webkit-text-size-adjust:100%;
  -ms-text-size-adjust:none;
}

* {
  box-sizing:border-box;
  -moz-box-sizing:border-box;
  -webkit-box-sizing:border-box;
}

p {
  margin:0 0 var(--spacing-xs);
  font-family:var(--font-body);
  font-size:var(--font-size-base);
  font-weight:400;
  line-height:var(--line-height-normal);
  color:var(--color-text);
}

a {
  text-decoration:none;
  transition:color 0.25s ease-in-out;
}

h1, .shop-content h1 {
  font-family:var(--font-display);
  font-size:var(--font-size-2xl);
  line-height:54px;
  font-weight:400;
  color:var(--color-text);
  margin:0 0 var(--spacing-md);
}

h2 {
  font-family:var(--font-display);
  font-size:var(--font-size-xl);
  line-height:42px;
  font-weight:400;
  color:var(--color-text);
  margin:0 0 var(--spacing-sm);
}

h3 {
  font-family:var(--font-display);
  font-size:var(--font-size-lg);
  line-height:30px;
  font-weight:400;
  color:var(--color-text);
  margin:0 0 var(--spacing-xs);
}

h4 {
  font-family:var(--font-display);
  font-size:var(--font-size-md);
  line-height:var(--line-height-normal);
  font-weight:400;
  color:var(--color-text);
  margin:0 0 var(--spacing-xs);
}

h5,
h6 {
  font-family:var(--font-body);
  font-size:var(--font-size-base);
  line-height:22px;
  font-weight:600;
  color:var(--color-text);
  margin:0 0 var(--spacing-2xs);
}

input[type="radio"] {
  margin-right:var(--spacing-2xs);
}

.req:after {
  color: var(--color-error);
}

.rule {
  border-color:var(--color-border);
}

#box,
body.typeGenericPage,
form#aspnetForm {
  display:flex;
  flex-direction:column;
}

div#box,
form#aspnetForm {
  flex-grow:1;
}

.label,
label {
  font-weight:bold;
}

#pageContent {
  padding: var(--spacing-md) var(--spacing-xs);
  width: 100%;
  flex: 1 1 auto;
  min-height: 60vh !important;
}

.pageContentWidth {
  min-height:60vh !important;
  padding-top: var(--spacing-lg) !important;
}

.typeGenericPage #pageContentCenter {
  width:auto;
}

.product-search-options {
  display:none;
}

.search-label {
  padding-right:var(--spacing-lg);
  padding-bottom:2px;
}

#authPlaceHolder {
  color: var(--color-black) !important;
  font-weight: 400;
}

.mobile-shop-nav {
  font-size: var(--font-size-xs);
  text-transform: uppercase;
  letter-spacing: 1.5px;
  align-items: center;
  gap: var(--spacing-sm);
  display: flex;
}

.mobile-shop-nav a {
  color: var(--color-black);
  font-weight: 400;
  text-decoration: none;
  transition: color 0.2s;
}

.mobile-shop-nav a:hover {
  color: var(--color-primary);
}

/* ========================================
   HEADER RESPONSIVE DESIGN
   ======================================== */
@media only screen and (max-width: 1250px) {
  body.open {
      overflow: hidden;
    }
}

/* ========================================
   SHOP CONTENT TYPOGRAPHY
   ======================================== */
.shop-content h1 span {
  font-weight:400 !important;
}

.shop-content h2 {
  font-family:var(--font-display);
  font-size:var(--font-size-xl);
  line-height:42px;
  font-weight:400;
  color:var(--color-text);
  margin:var(--spacing-lg) 0 var(--spacing-sm);
}

.shop-content h3 {
  font-family:var(--font-display);
  font-size:var(--font-size-lg);
  line-height:30px;
  font-weight:400;
  color:var(--color-text);
  margin:var(--spacing-sm) 0 var(--spacing-xs);
}

.shop-content h4 {
  font-family:var(--font-display);
  font-size:var(--font-size-md);
  line-height:var(--line-height-normal);
  font-weight:400;
  color:var(--color-text);
  margin:var(--spacing-lg) 0 var(--spacing-2xs);
}

.shop-content p {
  font-family:var(--font-body);
  font-size:var(--font-size-base);
  font-weight:400;
  line-height:var(--line-height-normal);
  color:var(--color-text);
  margin:0 0 var(--spacing-sm);
}

.shop-content hr {
  border:none;
  border-top:1px solid var(--color-border);
  margin:var(--spacing-2xl) 0;
}

/* h2/h3 immediately after divider — hr already provides top spacing */
.shop-content hr + h2,
.shop-content hr + h3 {
  margin-top:0;
}

/* Restore list styling stripped by the global ul/ol reset */
.shop-content ul,
.shop-content ol {
  list-style:disc;
  padding-left:var(--spacing-lg);
  margin:0 0 var(--spacing-sm);
}

.shop-content ol {
  list-style:decimal;
}

.shop-content li {
  font-family:var(--font-body);
  font-size:var(--font-size-base);
  font-weight:400;
  line-height:var(--line-height-normal);
  color:var(--color-text);
  list-style-position:outside;
  padding-left:var(--spacing-3xs);
  margin-bottom:var(--spacing-2xs);
}

.shop-content li:last-child {
  margin-bottom: 0;
}

.shop-content strong,.shop-content b, .subtotal-cost-label {
  font-weight:600;
  color:var(--color-text);
}

.shop-content small {
  font-family:var(--font-body);
  font-size:var(--font-size-sm);
  line-height:20px;
  color:var(--color-text-light);
  display:inline-block;
}

.add-to-cart {
  border:none;
  padding:0;
  margin:0;
}

.add-to-cart legend {
  display:none;
}

.add-to-cart > table {
  margin:0 0 var(--spacing-xs);
}

.add-to-cart .qty-container {
  display:inline-block;
  vertical-align:middle;
}

/* Floating Cart Button */
.js-cart-drawer-toggle {
  position:fixed;
  right:0px;
  top:calc(100vh / 2);
  width:64px;
  height:64px;
  background:var(--color-primary-dark);
  color:var(--color-white);
  display:flex;
  align-items:center;
  justify-content:center;
  cursor:pointer;
  z-index:9999;
  box-shadow: none;
  transition:transform 0.3s ease, background 0.3s ease;
  border-top-left-radius: 0;
  border-bottom-left-radius: 0;
}

.js-cart-drawer-toggle:hover {
  transform: scale(1.1);
  background:var(--color-primary-dark);
}

.js-cart-drawer-toggle::before {
  content: "\f07a";
  font-family:"Font Awesome 5 Pro";
  font-weight:900;
  font-size:var(--font-size-lg);
}

.cart-items-label {
  order:1 !important;
  display:block !important;
  margin:var(--spacing-md) 0 var(--spacing-xs) !important;
  font-family:var(--font-body) !important;
  font-size:var(--font-size-2xs) !important;
  font-weight:600 !important;
  text-align:left !important;
  color:var(--color-gray-500) !important;
  text-transform:uppercase !important;
  letter-spacing:1.5px !important;
}

.cart-items-label .lblVal {
  color:inherit !important;
  font-size:inherit !important;
  text-transform:none;
  letter-spacing:0;
}

.cart-items-secondary-label {
  padding:var(--spacing-xl) 0 var(--spacing-sm) !important;
  text-align:center;
  display:block !important;
  width:100%;
}

.cart-items-secondary-label .rule {
  display:none;
}

.cart-items-secondary-label center {
  display:flex;
  align-items:center;
  gap:var(--spacing-sm);
}

.cart-items-secondary-label center::before,
.cart-items-secondary-label center::after {
  content: "";
  flex:1;
  height:1px;
  background:var(--color-gray-200);
}

.cart-items-secondary-label .lblVal {
  font-family:var(--font-body);
  font-size:var(--font-size-2xs);
  text-transform:uppercase;
  letter-spacing:1.5px;
  color:var(--color-gray-500);
}

/* Space and Rule Styling */
.space-after-items {
  order:4 !important;
  height:10px;
}

.rule {
  border-top:1px solid var(--color-gray-200);
  margin:var(--spacing-sm) 0;
  height:0;
}

.tr-empty-last {
  display:none !important;
}

/* Order Summary / Subtotal */
[id$="_pnlSumary"] {
  order:5 !important;
  margin-top:var(--spacing-sm);
  background:var(--color-white);
  border-top:1px solid var(--color-gray-200);
}

[id$="_pnlSumary"] .rule {
  display:none !important; /* Hide duplicate lines inside subtotal panel */
}

.subtotal-cost {
  display:flex;
  justify-content:space-between;
  align-items:center !important;
  padding:var(--spacing-md) 0 var(--spacing-lg) !important;
  border-top:none !important; /* Hide double border */
  margin-top:0 !important;
}

.subtotal-cost-label {
  font-family:var(--font-body) !important;
  font-size:var(--font-size-sm) !important;
  text-transform:uppercase !important;
  letter-spacing:1.5px !important;
  font-weight:600 !important;
  color:var(--color-gray-500) !important;
  margin:0 !important;
}

.subtotal-cost .numeric {
  font-family:var(--font-display) !important; /* Baskervville */
  font-weight:400 !important;
  color:var(--color-primary) !important;
  font-size:var(--font-size-xl) !important;
  line-height:1 !important;
}

h2.anounce {
  color:var(--color-text-dark) !important;
  font-size:var(--font-size-sm) !important;
  line-height:1.5 !important;
  text-align:left !important;
  margin:0 !important; /* Reset margin; container handles spacing */
  background:var(--color-gray-50) !important;
  padding:var(--spacing-sm) var(--spacing-md) !important;
  font-weight:500 !important;
  border-left:var(--spacing-3xs) solid var(--color-primary) !important;
  border-radius: 0;
  font-family:var(--font-body) !important;
  display:flex !important;
  align-items:center !important;
}

#announce br {
  display:none !important;
}

h2.anounce::before {
  content: "\f05a"; /* FontAwesome Info Circle */
  font-family:"Font Awesome 5 Pro";
  font-weight:900;
  font-size:var(--font-size-sm);
  color:var(--color-primary);
  margin-right:var(--spacing-xs);
  flex-shrink:0;
}

/* Keyframe Animations */
@keyframes cartFadeInUp {
  from {
    opacity:0;
    transform:translateY(12px);
  }
  to {
    opacity:1;
    transform:translateY(0);
  }
}

@keyframes cartFadeInDown {
  from {
    opacity:0;
    transform:translateY(-12px);
  }
  to {
    opacity:1;
    transform:translateY(0);
  }
}

.left-box-head.col a {
  font-size:var(--font-size-md);
  text-decoration:underline;
}

/***** productDetails *****/
#pageContentCenter,
#productDetails {
  width:100%;
  float:none !important;
}

.current-page-descr {
  margin:0 0 var(--spacing-2xs);
}

.prod-details .sub-title {
  font-family:var(--font-display);
  color:var(--color-text);
  display:block;
  font-size:var(--font-size-xl);
  line-height:38px;
  font-weight:400;
}

@keyframes imgFadeInZoom {
  from {
    opacity:0;
    transform:scale(0.96) translateY(12px);
  }
  to {
    opacity:1;
    transform:scale(1) translateY(0);
  }
}

/* Overview tab styling */
#tab_overview {
  grid-column:2 !important;
  grid-row:1 !important;
  display:flex !important;
  flex-direction:column !important;
  gap:var(--spacing-sm) !important;
  align-self:start !important;
  background:transparent !important;
  border:none !important;
  border-radius:0 !important;
  padding:0 !important;
}

#tab_overview .sub-title {
  font-family:var(--font-display) !important;
  font-size:72px !important;
  line-height:1.05 !important;
  font-weight:400 !important;
  letter-spacing:-1.5px !important;
  color:var(--color-text-dark) !important;
  margin:0 !important;
  text-transform:none !important;
  opacity:0;
  animation:detailsFadeInUp 1s cubic-bezier(0.16, 1, 0.3, 1) forwards;
  animation-delay:0.3s;
}

#tab_overview .prod-descr {
  line-height:1.8;
  color:var(--color-gray-700);
  font-size:var(--font-size-lg);
  margin:var(--spacing-3xs) 0 0;
  padding:0;
  max-width:750px;
  opacity:0;
  animation:detailsFadeInUp 1s cubic-bezier(0.16, 1, 0.3, 1) forwards;
  animation-delay:0.45s;
}

#tab_overview .prod-descr p {
  margin-bottom:var(--spacing-sm);
}

#tab_overview .prod-descr strong {
  font-weight:600;
  color:var(--color-text-dark);
}

/* Support for varied font sizes in description if manually set in CMS */
#tab_overview .prod-descr span[style*="font-size:var(--font-size-lg)"] {
  font-family: var(--font-display) !important; /* Baskervville */
  font-size:26px !important;
  display:block;
  margin-bottom:var(--spacing-sm);
  line-height:1.4;
  color:var(--color-text-dark);
  font-weight:500 !important;
  letter-spacing:-0.5px;
}

@keyframes detailsFadeInUp {
  from {
    opacity:0;
    transform:translateY(20px);
  }
  to {
    opacity:1;
    transform:translateY(0);
  }
}

/* Wine Specs Table Redesign */
#tab_wine_spec {
  grid-column:2 !important;
  grid-row:3 !important;
  margin-top:var(--spacing-md) !important;
  padding:0 !important;
  background:transparent !important;
  border:none !important;
  opacity:0;
  animation:detailsFadeInUp 1s cubic-bezier(0.16, 1, 0.3, 1) forwards;
  animation-delay:0.75s;
}

#tab_wine_spec .wine-information {
  width:100% !important;
  border-collapse:collapse !important;
  border:none !important;
}

#tab_wine_spec .wine-information tr {
  border-bottom:1px solid var(--color-border-light) !important;
  transition:background-color 0.25s ease;
}

#tab_wine_spec .wine-information tr:hover {
  background-color: rgba(224, 232, 220, 0.15) !important;
}

#tab_wine_spec .wine-information tr:last-child {
  border-bottom: none !important;
}

#tab_wine_spec .wine-information td {
  padding:var(--spacing-xs) 0 !important;
  font-family:var(--font-body) !important;
  font-size:var(--font-size-base) !important;
  color:var(--color-text) !important;
  background:transparent !important;
}

#tab_wine_spec .wine-information td:first-child {
  font-weight: 600 !important;
  text-transform:uppercase !important;
  letter-spacing:2px !important;
  font-size:var(--font-size-xs) !important;
  color:var(--color-gray-500) !important;
  width:40% !important;
}

#tab_wine_spec .wine-information td:last-child {
  text-align: right !important;
  color:var(--color-text-dark) !important;
  font-weight:500 !important;
}

#tab_wine_spec .wine-information tr.alt {
  background:transparent !important;
}

/* Reviews/Vineyards/Winemaker sections */
#tab_reviews, #tab_vineyards, #tab_winemaker {
  grid-column:2 !important;
  padding:0 !important;
  background:transparent !important;
  border:none !important;
  margin-top:var(--spacing-2xl) !important;
}

#tab_reviews { grid-row:4 !important; }

#tab_vineyards { grid-row:5 !important; }

#tab_winemaker { grid-row:6 !important; }

#tab_reviews h3, #tab_vineyards h3, #tab_winemaker h3 {
  font-family:var(--font-display) !important;
  font-size:var(--font-size-xl) !important;
  color:var(--color-text-dark) !important;
  margin-bottom:var(--spacing-md) !important;
  padding-bottom:var(--spacing-xs) !important;
  border-bottom:1px solid var(--color-gray-100) !important;
  font-weight:400 !important;
}

#tab_reviews p, #tab_vineyards p, #tab_winemaker p {
  font-size:17px !important;
  line-height:1.7 !important;
  color:var(--color-gray-700) !important;
}

@media (max-width: 1250px) {
  #tab_overview {
      grid-column:1 !important;
      grid-row:2 !important;
      padding:var(--spacing-lg) !important;
    }
  #tab_wine_spec {
      grid-column:1 !important;
      grid-row:4 !important;
      padding:var(--spacing-lg) !important;
    }
  #tab_reviews {
      grid-column:1 !important;
      grid-row:5 !important;
      padding:var(--spacing-lg) !important;
    }
  #tab_vineyards {
      grid-column:1 !important;
      grid-row:6 !important;
      padding:var(--spacing-lg) !important;
    }
  #tab_winemaker {
      grid-column:1 !important;
      grid-row:7 !important;
      padding:var(--spacing-lg) !important;
    }
}

@media (max-width: 1250px) {
  #tab_overview,
    #tab_wine_spec,
    #tab_reviews,
    #tab_vineyards,
    #tab_winemaker {
      padding:var(--spacing-sm) !important;
      gap:var(--spacing-sm) !important;
    }
  #tab_overview .sub-title {
      font-size:var(--font-size-xl) !important;
      line-height:42px !important;
    }
  #tab_overview .prod-descr {
      font-size:var(--font-size-base) !important;
      line-height:1.6 !important;
    }
  #tab_overview .prod-descr span[style*="font-size:var(--font-size-lg)"] {
      font-size: var(--font-size-md) !important;
      line-height:1.5 !important;
    }
  #tab_reviews > h3,
    #tab_vineyards > h3,
    #tab_winemaker > h3 {
      font-size:var(--font-size-base) !important;
    }
  #tab_reviews {
      grid-column:1;
      grid-row:5;
    }
  #tab_vineyards {
      grid-column:1;
      grid-row:6;
      margin-top:0;
    }
  #tab_winemaker {
      grid-column:1;
      grid-row:7;
    }
}

#tab_vintages {
  text-align:center;
}

#vintage-text {
  margin-bottom:var(--spacing-md);
}

#tab_vintages a {
  display:block;
  margin:0 0 var(--spacing-2xs);
}

#tab_wine_spec > div {
  overflow:hidden;
}

.wine-information {
  width:100%;
  border:1px solid var(--color-border);
}

.wine-information td {
  padding:var(--spacing-2xs);
  border:none;
  width:auto !important;
}

.wine-information tr.alt {
  background:var(--color-border-light);
}

/***** WINE CLUB *****/
.wineclub-membership > div > a > h3 {
  font-size:var(--font-size-md);
}

input[type="text"],
input[type="password"],
select,
textarea {
  -webkit-box-shadow:none;
  box-shadow:none;
  border-radius: 0;
  padding:var(--spacing-xs);
  border:1px solid var(--color-border);
  min-height:40px;
  background:var(--color-white);
  min-width:55px;
}

.txt,
.txtbig,
.ddl,
.select_box select {
  display:block;
  width:100%;
  min-height:40px;
  background:var(--color-white);
  border-radius: 0;
  padding:var(--spacing-xs);
  -webkit-box-shadow:none;
  box-shadow:none;
  border:1px solid var(--color-border);
}

textarea.txt {
  max-width:100%;
  min-width:100%;
  width:100% !important;
}

.forgot_pass {
  max-width:300px;
}

.shipping-info select.ddl {
  margin-top:var(--spacing-2xs);
}

.date_selects {
  overflow:hidden;
  margin:0 -var(--spacing-xs) 0 0;
}

.select_box {
  float:left;
  width:33.3%;
  padding:0 var(--spacing-xs) var(--spacing-xs) 0;
}

.productVersion {
  white-space:normal;
  color:var(--color-text-dark);
}

.msg div {
  max-width:100%;
  width:auto !important;
}

.label_box {
  margin:0 0 var(--spacing-2xs);
}

.lnkSignOut {
  text-transform:none;
  color:var(--color-white);
}

.lnk {
  text-decoration:underline;
  font-weight:bold;
}

.wineclub-membership {
  display:grid !important;
  grid-template-columns:repeat(auto-fit, minmax(320px, 1fr)) !important;
  gap:var(--spacing-xl) !important;
  width:100% !important;
  box-sizing:border-box !important;
  padding:var(--spacing-md) 0 !important;
}

.wineclub-membership > div[class^="club-"] {
  background:var(--color-white) !important;
  border:1px solid var(--color-border-light) !important;
  border-radius: 0 !important;
  padding:var(--spacing-2xl) var(--spacing-xl) !important;
  box-shadow: none !important;
  display:flex !important;
  flex-direction:column !important;
  align-items:stretch !important;
  margin:0 !important;
  transition:all 0.35s cubic-bezier(0.16, 1, 0.3, 1) !important;
  position:relative !important;
  box-sizing:border-box !important;
  font-size:0 !important;
}

.wineclub-membership > div[class^="club-"]:hover {
  transform:translateY(-4px) !important;
  box-shadow: none !important;
  border-color:var(--color-primary-light) !important;
}

.wineclub-membership > div[class^="club-"] > a:first-child {
  display: block !important;
  text-decoration:none !important;
  margin-bottom:var(--spacing-sm) !important;
  order:1 !important;
}

.wineclub-membership > div[class^="club-"] h3 {
  font-family:var(--font-display) !important;
  font-size:var(--font-size-lg) !important;
  font-weight:400 !important;
  color:var(--color-primary-dark) !important;
  line-height:1.3 !important;
  display:block !important;
  margin:0 !important;
}

.wineclub-membership > div[class^="club-"] p {
  font-family:var(--font-body) !important;
  font-size:var(--font-size-sm) !important;
  line-height:1.6 !important;
  color:var(--color-text-dark) !important;
  margin:0 0 var(--spacing-sm) 0 !important;
  order:2 !important;
}

.wineclub-membership > div[class^="club-"] p strong {
  font-weight:600 !important;
  color:var(--color-primary-dark) !important;
}

.wineclub-membership > div[class^="club-"] p em {
  font-size:var(--font-size-sm) !important;
  color:var(--color-gray-500) !important;
  font-style:italic !important;
  line-height:1.5 !important;
  display:block !important;
}

[id$="_divMess"].err {
  width:100% !important;
  box-sizing:border-box !important;
  font-family:var(--font-body) !important;
  font-size:var(--font-size-sm) !important;
}

[id$="_divMess"].err:not(:empty) {
  padding: 16px 20px !important;
  border-radius: 0 !important;
  background:#fff8f8 !important;
  border-left:var(--spacing-3xs) solid var(--color-error) !important;
  color:var(--color-error) !important;
  margin-bottom:var(--spacing-xl) !important;
}

@media only screen and (max-width: 1250px) {
  .wineclub-membership {
      grid-template-columns: 1fr !important;
      gap:var(--spacing-md) !important;
    }
}

/***** HELP *****/
.product-search {
  display:block;
}

.ui-widget-header {
  border:1px solid var(--color-border);
  border-radius:0;
  padding:var(--spacing-2xs) !important;
  text-align:center;
}

.warning {
  margin:0 0 var(--spacing-xs);
}

.change-password .col:first-child {
  padding: 0 10px 0 0;
  width:150px;
}

.change-password #div1 {
  text-align:center;
}

.change-password .lnk {
  text-decoration:none;
}

div.table .row.h > div {
  border:none;
}

@media only screen and (max-width:639px) {
  #cat-v1-1 {
      flex-direction:column;
    }
}

@media only screen and (max-width:569px) {
  .change-password .col {
      display:block;
    }
  .change-password .col:first-child {
      width: auto;
      padding:0;
    }
}

@media only screen and (max-width:479px) {
  .variations ul h3 {
      font-size:var(--font-size-sm);
    }
}

@media (min-width: 1251px) {
  .prod-image ~ div {
      flex-grow:1;
    }
}

.shop-content {
  display: flex;
  margin:0 auto;
  padding: 0px !important;
  width:100%;
  flex-direction: column;
}

form[action*="cart"] .shopping-suggestion .carousel-item .qty-selector {
  margin:0 auto;
}

/* loader in center of page on auth and cart page */
form[action*="cart"] #pageContent,
form[action*="auth"] #pageContent {
  position:relative;
}

.img-thumbnail {
  background-color:transparent;
}

/* One-across list layout style (Desktop) */
@media (min-width: 1251px) {
  .one-items-across .prod-name,
    .one-across .prod-name,
    .one-column .prod-name,
    .list-layout .prod-name {
      margin: 0 !important;
    }
  .one-items-across .prod-content,
    .one-across .prod-content,
    .one-column .prod-content,
    .list-layout .prod-content {
      margin: 0 !important;
    }
  .one-items-across .add-to-cart .cmd-container,
    .one-across .add-to-cart .cmd-container,
    .one-column .add-to-cart .cmd-container,
    .list-layout .add-to-cart .cmd-container {
      display: flex !important;
      justify-content: center !important;
      flex-wrap: wrap !important;
      gap: var(--spacing-xs) !important;
    }
  /* Date/variant picker table inside one-across addToCart */
  .one-across .tbl-color-size,
    .one-items-across .tbl-color-size {
      width: 100% !important;
      border: none !important;
      margin-bottom: var(--spacing-sm) !important;
    }
  .one-across .tbl-color-size td,
    .one-items-across .tbl-color-size td {
      padding: 2px 0 !important;
      vertical-align: middle !important;
    }
  .one-across .tbl-color-size label,
    .one-items-across .tbl-color-size label {
      font-size: var(--font-size-xs) !important;
      font-weight: var(--font-weight-semibold) !important;
      text-transform: uppercase !important;
      letter-spacing: 0.05em !important;
      color: var(--color-text-light) !important;
      white-space: nowrap !important;
      padding-right: var(--spacing-xs) !important;
    }
  .one-across .tbl-color-size select,
    .one-items-across .tbl-color-size select {
      width: 100% !important;
      padding: 6px 10px !important;
      border: 1px solid var(--color-border) !important;
      border-radius: 0 !important;
      font-size: var(--font-size-sm) !important;
      background: var(--color-white) !important;
      color: var(--color-text-dark) !important;
    }
}

@keyframes gridProductFadeIn {
  from {
    opacity:0;
    transform:translateY(24px);
  }
  to {
    opacity:1;
    transform:translateY(0);
  }
}

.qty-label {
  display: block !important;
}

/* product-card badges end */
body {
  font-size:var(--font-size-md);
  font-family:var(--font-body);
  line-height:var(--line-height-normal);
  font-weight:var(--font-weight-normal);
  background-color:var(--color-white);
}

/* authStatus overrides removed */
a {
  color:var(--color-primary);
}

a:hover {
  color: var(--color-primary);
}

img {
  max-width:100%;
}

body,
.ui-widget-content {
  color:var(--color-text);
}

h1, h2, h3, h4 {
  font-family:var(--font-display);
  font-weight:400;
}

h5, h6 {
  font-family:var(--font-body);
  font-weight:600;
}

#pageContent {
  max-width: var(--container-max-width) !important;
  box-sizing: border-box !important;
}

.txt,
.txtbig,
.ddl,
.select_box select,
input[type="text"],
input[type="password"],
select,
textarea {
  color:var(--color-input-text);
}

header p,
footer p {
  margin:0;
}

.menu-header {
  display:none !important;
}

@keyframes locationFadeInUp {
  from {
    opacity:0;
    transform:translateY(30px);
  }
  to {
    opacity:1;
    transform:translateY(0);
  }
}

/* ==========================================================================
   SECTION 6: SHOP CATEGORY SUB-NAVIGATION MENU
   ========================================================================== */

ul,ol, .vertical-menu .shop-left-menu ul {
  list-style:none;
  margin:0;
  padding:0;
}

/***** shop-left-menu *****/
#accountContent .header,
#checkout .header,
#basket .header {
  border-bottom: 1px solid transparent;
  text-align: center;
  padding: var(--spacing-xs) var(--spacing-sm);
  font-size: var(--font-size-md);
  line-height: var(--line-height-normal);
  font-family: inherit;
  color: var(--color-white);
  overflow: hidden;
}

/* ─── VERTICAL LAYOUT CONTAINER ─────────────────────────────────────────── */
.vertical-menu {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-sm);
  align-items: stretch;
}

@media (min-width: 1251px) {
  .vertical-menu {
    flex-direction: row;
    column-gap: var(--spacing-lg);
    align-items: flex-start;
  }
  .vertical-menu .shop-content {
    margin: 0;
  }
}

.shop-left-menu .three-items-across-menu > ul,
.shop-left-menu .four-items-across-menu > ul {
  padding: 0;
}

.shop-left-menu > span.four-items-across-menu,
.shop-left-menu > span.three-items-across-menu {
  text-align: left;
}

.shop-left-menu > span {
  display: block;
  font-size: var(--font-size-md);
}

/* ─── PANEL ──────────────────────────────────────────────────────────────── */
.vertical-menu.shop-left-menu,
.vertical-menu .shop-left-menu,
.shop-left-menu:not(.horizontal-menu) {
  width: 100%;
  background: var(--color-white);
  border: 1px solid var(--color-gray-100);
  border-top: 3px solid var(--color-primary-dark);
  padding: 0;
  overflow: visible;
}

@media (min-width: 1251px) {
  .vertical-menu.shop-left-menu,
  .vertical-menu .shop-left-menu {
    flex: 0 0 220px;
    position: sticky;
    top: var(--cart-summary-top);
  }
}

/* ─── CATEGORY HEADER (li.menu-header — first child of the ul) ──────────── */
.vertical-menu.shop-left-menu ul > li.menu-header,
.vertical-menu .shop-left-menu ul > li.menu-header,
.shop-left-menu:not(.horizontal-menu) ul > li.menu-header {
  display: block;
  padding: 13px 18px;
  font-family: var(--font-body);
  font-size: var(--font-size-xs);
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 2px;
  color: var(--color-white);
  background: var(--color-primary-dark);
  border-bottom: none;
  border-left: none;
  cursor: default;
}

/* ─── LIST ITEMS ─────────────────────────────────────────────────────────── */
.vertical-menu.shop-left-menu ul li,
.vertical-menu .shop-left-menu ul li,
.shop-left-menu:not(.horizontal-menu) ul li {
  display: block;
  position: relative;
  margin: 0;
  border-bottom: 1px solid var(--color-gray-100);
}

/* header li gets no divider underneath */
.vertical-menu.shop-left-menu ul > li.menu-header,
.vertical-menu .shop-left-menu ul > li.menu-header,
.shop-left-menu:not(.horizontal-menu) ul > li.menu-header {
  border-bottom: none;
}

/* ─── SUB-GROUP (L2) CONTAINER — collapsed; expands via .open ───────────── */
.vertical-menu.shop-left-menu ul li ul,
.vertical-menu .shop-left-menu ul li ul,
.shop-left-menu:not(.horizontal-menu) ul li ul {
  display: none;
  background: var(--color-gray-50);
  border-top: 1px solid var(--color-gray-100);
  margin: 0;
  padding: var(--spacing-3xs) 0;
}

.vertical-menu.shop-left-menu ul li.has-sub.open > ul,
.vertical-menu .shop-left-menu ul li.has-sub.open > ul,
.shop-left-menu:not(.horizontal-menu) ul li.has-sub.open > ul {
  display: block;
}

/* ─── L1 LINKS — flex so toggler sits flush right ───────────────────────── */
.vertical-menu.shop-left-menu > span > ul > li > a,
.vertical-menu .shop-left-menu > span > ul > li > a,
.shop-left-menu:not(.horizontal-menu) > span > ul > li > a {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 11px 18px;
  font-family: var(--font-body);
  font-size: var(--font-size-sm);
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 1px;
  line-height: var(--line-height-normal);
  color: var(--color-text-dark);
  text-decoration: none;
  border-left: 3px solid transparent;
  transition: color 0.15s ease, background 0.15s ease, border-color 0.15s ease;
}

.vertical-menu.shop-left-menu > span > ul > li > a:hover,
.vertical-menu .shop-left-menu > span > ul > li > a:hover,
.shop-left-menu:not(.horizontal-menu) > span > ul > li > a:hover {
  color: var(--color-primary-dark);
  background: var(--color-gray-50);
  border-left-color: var(--color-primary);
}

.vertical-menu.shop-left-menu > span > ul > li > a.selected,
.vertical-menu .shop-left-menu > span > ul > li > a.selected,
.shop-left-menu:not(.horizontal-menu) > span > ul > li > a.selected {
  color: var(--color-primary-dark);
  font-weight: 700;
  background: var(--color-gray-50);
  border-left-color: var(--color-primary-dark);
}

/* ─── OP-TOGGLER — visible + icon, rotates to × when open ──────────────── */
.vertical-menu.shop-left-menu .op-toggler,
.vertical-menu .shop-left-menu .op-toggler,
.shop-left-menu:not(.horizontal-menu) .op-toggler {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  width: 22px;
  height: 22px;
  color: var(--color-gray-400);
  pointer-events: auto;
  transition: color 0.15s ease;
}

.vertical-menu.shop-left-menu .op-toggler i,
.vertical-menu .shop-left-menu .op-toggler i,
.shop-left-menu:not(.horizontal-menu) .op-toggler i {
  font-size: 10px;
  transition: transform 0.2s ease;
}

/* rotate + to × when sub-group is open */
.vertical-menu.shop-left-menu li.has-sub.open > a .op-toggler i,
.vertical-menu .shop-left-menu li.has-sub.open > a .op-toggler i,
.shop-left-menu:not(.horizontal-menu) li.has-sub.open > a .op-toggler i {
  transform: rotate(45deg);
  color: var(--color-primary-dark);
}

.vertical-menu.shop-left-menu .toggle-menu,
.vertical-menu .shop-left-menu .toggle-menu,
.shop-left-menu:not(.horizontal-menu) .toggle-menu {
  display: none !important;
}

.vertical-menu.shop-left-menu span > ul > li.has-sub > a::after,
.vertical-menu .shop-left-menu span > ul > li.has-sub > a::after,
.shop-left-menu:not(.horizontal-menu) span > ul > li.has-sub > a::after {
  display: none !important;
}

/* ─── MOBILE COLLAPSE — menu-header becomes tap target, li.g items collapse ─ */
@media (max-width: 1250px) {
  .shop-left-menu:not(.horizontal-menu) ul > li.menu-header {
    cursor: pointer !important;
    user-select: none;
    justify-content: space-between;
    display: flex !important;
    align-items: center;
  }

  .shop-left-menu:not(.horizontal-menu) ul > li.menu-header::after {
    content: '';
    display: inline-block;
    width: 8px;
    height: 8px;
    border-right: 2px solid rgba(255, 255, 255, 0.8);
    border-bottom: 2px solid rgba(255, 255, 255, 0.8);
    transform: rotate(45deg);
    transition: transform 0.2s ease;
    flex-shrink: 0;
  }

  .shop-left-menu:not(.horizontal-menu) ul.open > li.menu-header::after {
    transform: rotate(-135deg);
  }

  .shop-left-menu:not(.horizontal-menu) > span > ul > li.g {
    display: none;
  }

  .shop-left-menu:not(.horizontal-menu) > span > ul.open > li.g {
    display: block;
  }
}

/* ─── L2 LINKS (sub-group items) ─────────────────────────────────────────── */
.vertical-menu.shop-left-menu ul li ul li a,
.vertical-menu .shop-left-menu ul li ul li a,
.shop-left-menu:not(.horizontal-menu) ul li ul li a {
  display: block;
  padding: 8px 18px 8px 30px;
  font-family: var(--font-body);
  font-size: var(--font-size-xs);
  font-weight: 400;
  color: var(--color-text);
  text-decoration: none;
  border-left: none;
  transition: color 0.15s ease;
}

.vertical-menu.shop-left-menu ul li ul li a:hover,
.vertical-menu.shop-left-menu ul li ul li a.selected,
.vertical-menu .shop-left-menu ul li ul li a:hover,
.vertical-menu .shop-left-menu ul li ul li a.selected,
.shop-left-menu:not(.horizontal-menu) ul li ul li a:hover,
.shop-left-menu:not(.horizontal-menu) ul li ul li a.selected {
  color: var(--color-primary-dark);
  background: transparent;
}

/* ─── GENERAL LINK FALLBACK ──────────────────────────────────────────────── */
.vertical-menu.shop-left-menu a,
.vertical-menu .shop-left-menu a,
.shop-left-menu:not(.horizontal-menu) a {
  text-decoration: none;
}

.horizontal-menu.shop-left-menu,
.horizontal-menu .shop-left-menu {
  text-align:center;
  margin-bottom:var(--spacing-2xl);
  padding:0;
  border:none;
  display:flex;
  justify-content:center;
  width:100%;
}

.horizontal-menu.shop-left-menu .menu-header,
.horizontal-menu .shop-left-menu .menu-header {
  display:none !important;
}

.horizontal-menu.shop-left-menu span,
.horizontal-menu .shop-left-menu span {
  display:block;
  background:transparent;
  border:none;
  box-shadow:none;
  padding:0;
  border-radius:0;
  width:auto;
}

.horizontal-menu.shop-left-menu span > ul,
.horizontal-menu .shop-left-menu span > ul {
  display:flex;
  align-items:center;
  justify-content:center;
  flex-wrap:wrap;
  gap:var(--spacing-2xs) var(--spacing-xs);
  padding:0;
  margin:0;
  list-style:none;
}

.horizontal-menu.shop-left-menu span > ul li,
.horizontal-menu .shop-left-menu span > ul li {
  margin:0;
  padding:0;
  display:inline-block;
}

.horizontal-menu.shop-left-menu span > ul li a,
.horizontal-menu .shop-left-menu span > ul li a {
  display:inline-block;
  padding:var(--spacing-2xs) var(--spacing-md);
  font-family:var(--font-body);
  font-size:var(--font-size-sm);
  font-weight:600;
  text-transform:uppercase;
  letter-spacing:1.5px;
  color:var(--color-gray-600);
  border-radius: 0;
  transition:all 0.25s cubic-bezier(0.16, 1, 0.3, 1);
  text-decoration:none;
}

.horizontal-menu.shop-left-menu span > ul > li > a.selected,
.horizontal-menu .shop-left-menu span > ul > li > a.selected {
  background-color:var(--color-primary) !important;
  color:var(--color-white) !important;
  border-radius: 0 !important;
}

.horizontal-menu.shop-left-menu span > ul > li > a:hover:not(.selected),
.horizontal-menu .shop-left-menu span > ul > li > a:hover:not(.selected) {
  background-color: var(--color-gray-100) !important;
  color:var(--color-text-dark) !important;
  border-radius: 0 !important;
}

/* Clean CSS-only chevron arrow for L1 items with submenus in horizontal menu */
.horizontal-menu.shop-left-menu span > ul > li.has-sub > a,
.horizontal-menu .shop-left-menu span > ul > li.has-sub > a {
  display: inline-flex !important;
  align-items: center;
  gap: var(--spacing-2xs); /* space between text and chevron */
  padding-right: var(--spacing-md) !important;
}

.horizontal-menu.shop-left-menu span > ul > li.has-sub > a::after,
.horizontal-menu .shop-left-menu span > ul > li.has-sub > a::after {
  content: "";
  display: inline-block;
  width: 5px;
  height: 5px;
  border-right: 1.5px solid currentColor;
  border-bottom: 1.5px solid currentColor;
  transform: rotate(45deg);
  transition: transform 0.25s ease;
  margin-top: -3px;
  flex-shrink: 0;
}

/* Rotate chevron when hovered or active */
.horizontal-menu.shop-left-menu span > ul > li.has-sub:hover > a::after,
.horizontal-menu.shop-left-menu span > ul > li.has-sub.menu-open > a::after,
.horizontal-menu .shop-left-menu span > ul > li:hover > a::after,
.horizontal-menu .shop-left-menu span > ul > li.menu-open > a::after {
  transform: rotate(-135deg);
  margin-top: 2px;
}

@media (min-width: 1251px) {
  .horizontal-menu.shop-left-menu span > ul li,
    .horizontal-menu .shop-left-menu span > ul li {
      position: relative;
    }
  .horizontal-menu.shop-left-menu span > ul li:hover > ul,
    .horizontal-menu .shop-left-menu span > ul li:hover > ul,
    .horizontal-menu.shop-left-menu span > ul li.menu-open > ul,
    .horizontal-menu .shop-left-menu span > ul li.menu-open > ul {
      display: block !important;
    }
  .horizontal-menu .shop-left-menu span > ul li ul {
      display:none !important;
      background-color:var(--color-white);
      border:1px solid var(--color-gray-200);
      z-index:1020;
      position:absolute;
      top:100%;
      left:50%;
      transform:translateX(-50%);
      min-width:200px;
      padding:var(--spacing-2xs) 0;
      margin-top:var(--spacing-2xs);
    }
  /* Hover bridge to prevent losing hover state when moving mouse over the gap */
  .horizontal-menu .shop-left-menu span > ul li ul::before {
      content: "";
      position: absolute;
      top: -20px;
      left: 0;
      right: 0;
      height: 20px;
      background: transparent;
    }
  .horizontal-menu .shop-left-menu span > ul li ul li {
      display:block;
      width:100%;
    }
  .horizontal-menu .shop-left-menu span > ul li ul li a {
      display:block;
      padding:var(--spacing-2xs) var(--spacing-md);
      font-family:var(--font-body);
      font-size:var(--font-size-sm);
      font-weight:500;
      font-style:normal;
      letter-spacing:1px;
      color:var(--color-gray-600);
      text-align:left;
      border-radius:0;
      text-transform:uppercase;
    }
  .horizontal-menu .shop-left-menu span > ul li ul li a:hover {
      background-color: var(--color-gray-50) !important;
      color:var(--color-primary) !important;
    }
  .horizontal-menu .shop-left-menu span > ul li ul li a.selected {
      background-color:transparent !important;
      color:var(--color-primary) !important;
    }
  .horizontal-menu .shop-left-menu span > ul li ul ul {
      left:100%;
      top:0;
      margin-top:0;
      margin-left:var(--spacing-3xs);
      transform:none;
    }
  .horizontal-menu .shop-left-menu span > ul > li ul a {
      white-space:nowrap;
    }
}

@media (max-width: 1250px) {
  /* Mobile: Stack horizontal menu vertically like the vertical menu */
  .horizontal-menu .shop-left-menu,
    .horizontal-menu.shop-left-menu {
      display: flex !important;
      flex-direction: column !important;
      width: 100% !important;
      background: var(--color-white) !important;
      border: 1px solid var(--color-gray-200) !important;
      border-radius: 0 !important;
      box-shadow: none !important;
      padding: 0 !important;
      margin-bottom: var(--spacing-2xl) !important;
      justify-content: flex-start !important;
      overflow-x: visible !important;
    }
  .horizontal-menu .shop-left-menu::-webkit-scrollbar {
      display: none;
    }
  .horizontal-menu .shop-left-menu span {
      width: 100% !important;
      display: block !important;
      background: transparent !important;
      border: none !important;
      box-shadow: none !important;
      padding: 0 !important;
      border-radius: 0 !important;
    }
  .horizontal-menu .shop-left-menu span > ul {
      display: flex !important;
      flex-direction: column !important;
      align-items: stretch !important;
      justify-content: flex-start !important;
      flex-wrap: nowrap !important;
      gap: 0 !important;
      padding: 0 !important;
      margin: 0 !important;
      list-style: none !important;
      width: 100% !important;
    }
  .horizontal-menu .shop-left-menu span > ul li {
      display: block !important;
      width: 100% !important;
      margin: 0 !important;
      padding: 0 !important;
      border-bottom: none !important;
      position: relative !important;
      overflow: visible !important;
    }
  /* Root-level links in mobile vertical layout */
  .horizontal-menu .shop-left-menu span > ul > li > a {
      display: block !important;
      padding: 8px var(--spacing-md) !important;
      font-family: var(--font-body) !important;
      font-size: var(--font-size-sm) !important;
      font-weight: 600 !important;
      line-height: 1.2 !important;
      color: var(--color-gray-900) !important;
      text-decoration: none !important;
      transition: all 0.2s ease !important;
      border-left: 3px solid transparent !important;
      background: transparent !important;
      white-space: normal !important;
      border: none !important;
      text-transform: none !important;
      letter-spacing: normal !important;
      border-radius: 0 !important;
      text-align: left !important;
    }
  .horizontal-menu .shop-left-menu span > ul > li > a:hover {
      color: var(--color-primary) !important;
      background: var(--color-gray-50) !important;
      border-left: 3px solid var(--color-primary) !important;
    }
  .horizontal-menu .shop-left-menu span > ul > li > a.selected {
      color: var(--color-primary) !important;
      font-weight: 600 !important;
      background: transparent !important;
      border-left: none !important;
    }
  /* Submenu container with left border connector (like vertical menu) */
  .horizontal-menu .shop-left-menu span > ul li ul {
      display: block !important;
      overflow: visible !important;
      background: var(--color-gray-50) !important;
      border-left: 3px solid var(--color-primary) !important;
      margin-left: 0 !important;
      padding-left: var(--spacing-md) !important;
      margin-top: 0 !important;
      margin-bottom: 0 !important;
    }
  /* Submenu leaf links */
  .horizontal-menu .shop-left-menu span > ul li ul li a {
      display: block !important;
      padding: var(--spacing-3xs) var(--spacing-md) !important;
      font-family: var(--font-body) !important;
      font-size: var(--font-size-sm) !important;
      font-weight: 400 !important;
      line-height: var(--line-height-normal) !important;
      color: var(--color-text) !important;
      text-decoration: none !important;
      transition: all 0.2s ease !important;
      border-left: none !important;
      text-transform: none !important;
      letter-spacing: normal !important;
      background: transparent !important;
      white-space: normal !important;
    }
  .horizontal-menu .shop-left-menu span > ul li ul li a:hover,
    .horizontal-menu .shop-left-menu span > ul li ul li a.selected {
      color: var(--color-primary) !important;
      background: transparent !important;
      transform: translateX(4px) !important;
    }
  /* Chevron arrow for items with submenus in mobile layout */
  .horizontal-menu .shop-left-menu span > ul > li.has-sub > a {
      display: flex !important;
      align-items: center !important;
      gap: var(--spacing-2xs) !important;
      justify-content: space-between !important;
      padding-right: var(--spacing-lg) !important;
    }
  .horizontal-menu .shop-left-menu span > ul > li.has-sub > a::after {
      content: "" !important;
      display: inline-block !important;
      width: 5px !important;
      height: 5px !important;
      border-right: 1.5px solid currentColor !important;
      border-bottom: 1.5px solid currentColor !important;
      transform: rotate(45deg) !important;
      transition: transform 0.25s ease !important;
      margin-top: -3px !important;
      flex-shrink: 0 !important;
      margin-left: auto !important;
    }
  /* Rotate chevron when menu item with submenus is active/hovered */
  .horizontal-menu .shop-left-menu span > ul > li.has-sub:hover > a::after,
    .horizontal-menu .shop-left-menu span > ul > li.has-sub.menu-open > a::after {
      transform: rotate(-135deg) !important;
      margin-top: 2px !important;
    }
}

/* ==========================================================================
   SECTION 7: PRODUCT CATALOG GRID & CARDS
   ========================================================================== */

/* Search product button */
.button-search-product {
  flex: 0 0 auto;
  position: static;
  transform: none;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 100px;
  background: var(--color-primary-dark);
  color: var(--color-white) !important;
  border: 1px solid var(--color-primary-dark);
  border-radius: 0 !important;
  font-family: var(--font-body);
  font-size: var(--font-size-sm);
  font-weight: 400;
  line-height: 1;
  letter-spacing: 0;
  text-decoration: none;
  white-space: nowrap;
  cursor: pointer;
  transition: background 0.2s ease;
  -webkit-font-smoothing: antialiased;
  padding-right: var(--spacing-xl) !important;
}

.button-search-product img {
  display: none;
}

.button-search-product:hover {
  background: var(--color-white);
  color: var(--color-primary-dark) !important;
  border: 1px solid var(--color-primary-dark) !important;
}

.txt-product-search,
.typeGenericPage #pageContentLeft,
a.sign-up,
a.quick-order,
a.sign-in {
  width:100%;
}

#divSearchWebstoreCatalog {
  display:flex !important;
  align-items:stretch;
  margin-bottom:var(--spacing-lg);
  gap:var(--spacing-xs);
}

.txt-product-search {
  flex:1 1 auto;
  min-width:0;
  border:none !important;
  background:transparent;
  box-shadow:none !important;
  outline:none;
  color:var(--color-text-dark) !important;
  border:1px solid var(--color-border-light) !important;
  border-radius:0 !important;
}

.button-search-product,
.product-search-options {
  z-index:1;
}

.txt-product-search {
  padding:var(--spacing-xs) var(--spacing-sm) !important;
  top:0px !important;
}

/***** cat-v1-1 *****/
#cat-v1-1 .no-data {
  font-size:var(--font-size-md);
  text-align:center;
  padding:90px 0;
}

.data-header {
  display:none;
  overflow:hidden;
  padding:0 0 var(--spacing-xs);
}

.data-header .pager {
  padding-top:17px;
  text-align:right;
  font-weight:bold;
}

.data-header .pager .c,
.data-header .pager .t {
  font-weight:bold;
}

.data-header .title {
  padding:var(--spacing-xs);
  text-align:center;
  display:none;
}

.prod-details .data {
  width:100%;
}

.prod-details .cmd-container,
.prod-details .price-container {
  margin:var(--spacing-sm) 0;
}

#tab_overview .prod-summary {
  margin:0;
  opacity:0;
  animation:detailsFadeInUp 1s cubic-bezier(0.16, 1, 0.3, 1) forwards;
  animation-delay:0.2s;
}

#tab_overview .prod-summary p {
  font-family:var(--font-body);
  font-size:var(--font-size-base);
  font-weight:600;
  letter-spacing:3px;
  text-transform:uppercase;
  color:var(--color-primary);
  margin:0;
}

@media only screen and (max-width:639px) {
  .data-header .pager {
      float:none;
    }
}

@media only screen and (max-width:479px) {
  .prod-img {
      text-align:center;
    }
  .two-items-across .addToCart {
      margin:0;
    }
  .addToCart,
    .two-items-across .addToCart {
      position:static;
      left:0;
      margin:0;
    }
}

/* listing css */
.two-items-across {
  --grid-max-cards:2;
}

.three-items-across {
  --grid-max-cards:3;
}

.four-items-across {
  --grid-max-cards:4;
}

.five-items-across {
  --grid-max-cards:5;
}

.data.one-across,
.data.one-items-across,
.data.one-column,
.data.list-layout {
  display: flex !important;
  flex-direction: column !important;
  gap: var(--spacing-sm) !important;
}

.pagination .pager,
.group-summary {
  padding:0 0 var(--spacing-md);
  grid-column-start:1;
  grid-column-end:-1;
}

.pagination .pager {
  width:100%;
  text-align:right;
  padding-bottom:0;
}

/* grid items across  */
.data.responsive-items-across {
  width:100%;
}

.two-items-across,
.three-items-across,
.four-items-across,
.five-items-across,
.responsive-items-across {
  display:grid;
  column-gap:var(--spacing-lg);
  row-gap:var(--spacing-xl);
}

@media (max-width: 1250px) {
  .two-items-across,
    .three-items-across,
    .four-items-across,
    .five-items-across,
    .responsive-items-across {
      row-gap: 24px;
      column-gap:var(--spacing-sm);
    }
}

.data.responsive-items-across {
  grid-template-columns:repeat(auto-fill, minmax(200px, 1fr));
}

.data.two-items-across {
  grid-template-columns:repeat(2, 1fr);
}

@media (min-width: 1251px) {
  .data {
      grid-template-columns: repeat(var(--grid-max-cards), 1fr);
    }
}

@media (min-width: 1251px) {
  .shop-content:not(.responsive-items-across-container) {
      width: 100%;
      display:flex;
      gap:var(--spacing-md);
    }
  .shop-content:not(.responsive-items-across-container) .shop-wrap {
      flex-grow: 1;
    }
  .four-items-across-container,
    .five-items-across-container {
      flex-grow:1;
    }
}

form[action*="cart"] .shopping-suggestion .carousel-item .price-container {
  display:block;
  margin-right:0;
}

.pager.col,
.row.catalog-controls {
  grid-column:1 / -1;
  justify-content:flex-end;
  text-align:right;
}

/* resets common.css */
.prod-img {
  padding:0 !important;
  background-color:transparent !important;
  margin:0 !important;
  min-height:unset !important;
}

.three-items-across .prod-content,
.responsive-items-across .price-container,
.five-items-across .price-container {
  display:block;
}

.responsive-items-across .cmd-container,
.five-items-across .cmd-container,
.four-items-across .add-to-cart .cmd-container,
.three-items-across .add-to-cart .cmd-container {
  display:flex;
  justify-content:center;
}

.three-items-across .productItem,
.four-items-across .productItem {
  width:100% !important;
  padding:0 !important;
}

/* hide items */
.three-items-across .add-to-cart .cmd-container label,
.four-items-across .add-to-cart .cmd-container label {
  display:none;
}

@media (min-width: 1251px) {
  .one-items-across .productItem,
    .one-across .productItem,
    .one-column .productItem,
    .list-layout .productItem {
      width: 100% !important;
      margin-bottom: var(--spacing-xl);
    }
  .one-items-across .pi-content,
    .one-across .pi-content,
    .one-column .pi-content,
    .list-layout .pi-content {
      display: flex !important;
      flex-direction: row !important;
      align-items: center !important;
      text-align: left !important;
      padding: var(--spacing-xl) var(--spacing-2xl) !important;
      gap: var(--spacing-2xl) !important;
      height: auto !important;
    }
  .one-items-across .prod-img,
    .one-across .prod-img,
    .one-column .prod-img,
    .list-layout .prod-img {
      flex: 0 0 200px !important;
      max-width: 200px !important;
      margin: 0 !important;
    }
  .one-items-across .prod-img img,
    .one-across .prod-img img,
    .one-column .prod-img img,
    .list-layout .prod-img img {
      max-height: 250px !important;
      width: auto !important;
      object-fit: contain !important;
    }
  .one-items-across .prod-summary,
    .one-across .prod-summary,
    .one-column .prod-summary,
    .list-layout .prod-summary {
      flex: 1 1 auto !important;
      text-align: left !important;
      margin: 0 !important;
      display: flex !important;
      flex-direction: column !important;
      align-items: flex-start !important;
      justify-content: center !important;
      gap: var(--spacing-xs) !important;
    }
  .one-items-across .addToCart,
    .one-across .addToCart,
    .one-column .addToCart,
    .list-layout .addToCart {
      flex: 0 0 300px !important;
      max-width: 300px !important;
      margin: 0 !important;
      align-self: center !important;
      border-left: 1px solid var(--color-border-light) !important;
      padding-left: var(--spacing-2xl) !important;
      text-align: left !important;
    }
  .one-items-across .productItem:hover,
    .one-across .productItem:hover,
    .one-column .productItem:hover,
    .list-layout .productItem:hover {
      transform: none !important;
    }
  /* Widen addToCart panel when it contains a date/variant picker (events) */
  .one-items-across .addToCart:has(.tbl-color-size),
    .one-across .addToCart:has(.tbl-color-size) {
      flex: 0 0 380px !important;
      max-width: 380px !important;
    }
}

/* product card related css - Premium Grid */
.productItem {
  width:100% !important;
  height:100% !important;
  position:relative;
  transition:transform 0.6s cubic-bezier(0.2, 1, 0.3, 1);
  z-index:1;
}

.productItem:hover {
  transform: translateY(-4px);
  z-index:2;
}

.productItem .pi-content {
  height: 100% !important;
}

/* Product card content contrast fixes */
.pi-content p {
  color: var(--color-text-dark) !important;
}

.pi-content .label,
.pi-content .qty-label {
  color: var(--color-text-dark) !important;
  font-weight: var(--font-weight-semibold) !important;
}

.pi-content .price-label {
  color: var(--color-text-dark) !important;
}

/* Coming Soon & Sold Out Badges */
.productItem .comingSoon,
.productItem .soldout {
  position: absolute;
  top: var(--spacing-2xl);
  left: 0;
  border-radius: 0;
  padding: var(--spacing-xs) var(--spacing-sm);
  background-color: var(--color-primary);
  color: var(--color-white);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-semibold);
  text-transform: uppercase;
  letter-spacing: 0.05em;
  z-index: 10;
}

.productItem .soldout {
  font-size: var(--font-size-xs) !important;
}

.productItem .comingSoon p {
  margin: 0 !important;
  line-height: 1.2;
  color: var(--color-white) !important;
  font-size: var(--font-size-xs) !important;
}

.productItem .soldout {
  background-image: var(--gradient-error);
  background-color: transparent;
}

.pi-content {
  display:flex !important;
  flex-direction:column !important;
  gap:0;
  background:var(--color-white);
  border:1px solid var(--color-gray-300);
  border-radius: 0;
  padding:var(--spacing-2xl) var(--spacing-lg);
  height:100% !important;
  transition:all 0.6s cubic-bezier(0.2, 1, 0.3, 1);
  box-shadow: none;
  text-align:center;
  opacity:0;
  animation:gridProductFadeIn 0.8s cubic-bezier(0.16, 1, 0.3, 1) forwards;
}

/* Staggered load delays for product cards */
.productItem:nth-child(1) .pi-content { animation-delay: 0.05s; }

.productItem:nth-child(2) .pi-content { animation-delay: 0.15s; }

.productItem:nth-child(3) .pi-content { animation-delay: 0.25s; }

.productItem:nth-child(4) .pi-content { animation-delay: 0.35s; }

.productItem:nth-child(5) .pi-content { animation-delay: 0.45s; }

.productItem:nth-child(6) .pi-content { animation-delay: 0.55s; }

.productItem:nth-child(7) .pi-content { animation-delay: 0.65s; }

.productItem:nth-child(8) .pi-content { animation-delay: 0.75s; }

.productItem:nth-child(9) .pi-content { animation-delay: 0.85s; }

.productItem:nth-child(10) .pi-content { animation-delay: 0.95s; }

.productItem:nth-child(11) .pi-content { animation-delay: 1.05s; }

.productItem:nth-child(12) .pi-content { animation-delay: 1.15s; }

.productItem:hover .pi-content {
  box-shadow: none;
  border-color:var(--color-gray-200);
}

.productItem .prod-img {
  margin:0 0 var(--spacing-xl) !important;
  padding:0 !important;
  background:transparent !important;
  flex:0 0 auto;
}

.productItem .prod-img img {
  width:100%;
  height:auto;
  max-height:380px;
  object-fit:contain;
  object-position:center;
  transition:transform 0.6s cubic-bezier(0.2, 1, 0.3, 1);
  
}

.productItem:hover .prod-img img {
  transform: scale(1.06);
  
}

.productItem .prod-summary {
  flex:1 0 auto;
  display:flex;
  flex-direction:column;
  justify-content:flex-start;
  margin-bottom:var(--spacing-lg);
}

.productItem h2 {
  margin:0 0 var(--spacing-xs) !important;
}

.productItem h2 a {
  font-family:var(--font-display) !important;
  font-size:26px !important;
  font-weight:400 !important;
  line-height:1.2 !important;
  color:var(--color-text-dark) !important;
  text-decoration:none;
  transition:color 0.3s ease;
  letter-spacing:-0.5px !important;
  text-transform:none !important;
}

.productItem:hover h2 a {
  color: var(--color-primary) !important;
}

.productItem .prod-content p {
  font-family:var(--font-body) !important;
  font-size:var(--font-size-base) !important;
  font-weight:400 !important;
  line-height:1.5 !important;
  color:var(--color-text-dark) !important;
  margin:0;
}

.productItem .addToCart {
  flex:0 0 auto;
  margin-top:auto;
  padding-top:var(--spacing-lg);
  border-top:1px solid var(--color-gray-50);
}

.productItem .addToCart fieldset.add-to-cart {
  display:flex !important;
  flex-direction:column !important;
  gap:var(--spacing-lg) !important;
}

/* Price styling in Grid */
.productItem .price-container {
  display:flex !important;
  justify-content:center !important;
  align-items:center !important;
}

.productItem .price-label {
  display:none !important;
}

.productItem .price {
  font-family:var(--font-display) !important;
  font-size:var(--font-size-xl) !important;
  line-height:1 !important;
  color:var(--color-primary) !important;
  font-weight:400 !important;
}

/* Command (Qty + Button) styling in Grid */
.productItem .cmd-container {
  display:flex !important;
  flex-direction:row !important;
  flex-wrap: wrap !important;
  justify-content:center !important;
  align-items:center !important;
  gap:var(--spacing-xs) !important;
  margin:0 !important;
}

.productItem .cmd-container .btn {
  flex: 0 0 100% !important;
  width: 100% !important;
  height: 50px !important;
}

.productItem .qty-container {
  display:flex !important;
  align-items:center !important;
  background:var(--color-gray-50) !important;
  border:1px solid var(--color-gray-200) !important;
  border-radius: 0 !important;
  padding:0 var(--spacing-xs) !important;
  height:50px !important;
  transition:all 0.3s ease !important;
}

.productItem .qty-container:focus-within {
  background: var(--color-white) !important;
  border-color:var(--color-primary) !important;
}

.productItem input[type="text"].number {
  width:45px !important;
  border:none !important;
  background:transparent !important;
  font-size:var(--font-size-md) !important;
  font-weight:500 !important;
  text-align:center !important;
  color:var(--color-text-dark) !important;
  padding:0 !important;
}

.productItem .btn,
.productItem button {
  height:50px !important;
  background:var(--color-primary-dark) !important;
  color:var(--color-white) !important;
  border:none !important;
  padding:0 28px !important;
  border-radius: 0 !important;
  font-family:var(--font-body) !important;
  font-weight:600 !important;
  font-size:var(--font-size-xs) !important;
  text-transform:uppercase !important;
  letter-spacing:1px !important;
  cursor:pointer !important;
  transition:all 0.4s ease !important;
  display:inline-flex;
  align-items:center !important;
  justify-content:center !important;
  box-shadow: none !important;
}

.productItem .btn:hover {
  background: var(--color-white) !important;
  color: var(--color-primary-dark) !important;
  border: 1px solid var(--color-primary-dark) !important;
  box-shadow: none !important;
  transform:translateY(-2px) !important;
}

.productItem .subtotal {
  display:none !important;
}

.responsive-items-across .productItem,
.five-items-across .productItem {
  margin-right:0;
}

@media only screen and (max-width: 1250px) {
  .productItem {
      margin-bottom: 0;
    }
  .pi-content {
      padding:var(--spacing-xl) var(--spacing-md);
      display:block !important;
      text-align:center;
    }
  .productItem h2 a {
      font-size:var(--font-size-lg) !important;
    }
  .productItem .price {
      font-size:var(--font-size-xl) !important;
    }
  .productItem .cmd-container {
      justify-content:center;
    }
}

@media (max-width:479px) {
  .productItem .prod-content {
      display: none;
    }
}

/* product-card badges start */
.productItem .comingSoon {
  border-radius: 0;
  padding:var(--spacing-3xs);
  position:absolute;
  top:var(--spacing-2xl);
  left:0;
  color:var(--color-white);
  font-size:var(--font-size-xs);
}

.productItem .comingSoon {
  background-color:var(--color-primary);
}

.productItem .comingSoon p {
  margin:0;
}

.productItem .comingSoon.soldout {
  background-image:var(--gradient-error);
}

.three-items-across-menu {
  /* border:1px solid black !important; */
  padding:var(--spacing-2xs) var(--spacing-2xs) !important;
  border-radius: 0 !important;
}

/* ==========================================================================
   SECTION 8: PRODUCT DETAILS PAGE
   ========================================================================== */

/***** tabs-product *****/
#tabs-product {
  background:none;
  border:0;
  padding:0;
  border-radius:0;
  margin-left:0;
}

/* Hide tab navigation — all content shown on one page */
#tabs-product > ul,
#tabs-product .ui-tabs-nav {
  display:none !important;
}

/* Display all tab panels */
#tabs-product .ui-tabs-panel {
  display:block !important;
  padding:0;
  border-radius:0;
}

#tabs-product .tabs-container {
  display:grid !important;
  grid-template-columns:1fr 1.5fr !important;
  grid-template-rows:repeat(10, auto) !important;
  gap:var(--spacing-2xl) var(--spacing-4xl) !important;
  width:100% !important;
  padding: 0 0 !important;
  border:none !important;
  overflow:visible !important;
  position:relative !important;
  height:auto !important;
}

#tabs-product .tabs-wrap {
  grid-column:1 / 3 !important;
  display:contents !important;
}

#tabs-product .tabs-content {
  display:contents !important;
}

/* Product image - left, spans multiple rows */
#tabs-product .prod-image {
  grid-column:1 !important;
  grid-row:1 / 10 !important;
  margin:0 !important;
  width:100% !important;
  position:sticky !important;
  top:140px !important;
  align-self:start !important;
}

#tabs-product .prod-image img {
  width:100%;
  height:auto !important;
  object-fit:contain;
  object-position:top center;
  max-width:100%;
  margin:0 auto;
  
  opacity:0;
  animation:imgFadeInZoom 1.2s cubic-bezier(0.16, 1, 0.3, 1) forwards;
  animation-delay:0.1s;
}

/* Add to Cart Section - Premium Redesign */
.tabs-container > .uc.addToCart {
  grid-column:2 !important;
  grid-row:2 !important;
  align-self:start !important;
  background:var(--color-white) !important;
  border:1px solid var(--color-gray-200) !important;
  border-radius: 0 !important;
  padding:var(--spacing-xl) !important;
  margin:var(--spacing-lg) 0 !important;
  display:flex !important;
  flex-direction:column !important;
  gap:var(--spacing-lg) !important;
  color:var(--color-text) !important;
  box-shadow: none !important;
  opacity:0;
  animation:detailsFadeInUp 1s cubic-bezier(0.16, 1, 0.3, 1) forwards;
  animation-delay:0.6s;
}

.tabs-container .uc.addToCart fieldset.add-to-cart {
  display:flex !important;
  flex-direction:column !important;
  gap:var(--spacing-lg) !important;
  border:none !important;
  padding:0 !important;
  margin:0 !important;
}

.tabs-container .uc.addToCart legend {
  display:none;
}

/* Date/variant picker table */
.tabs-container .uc.addToCart .tbl-color-size {
  width: 100% !important;
  border: none !important;
  margin: 0 !important;
  padding: 0 !important;
  border-collapse: collapse !important;
}

.tabs-container .uc.addToCart .tbl-color-size td {
  padding: 4px 0 !important;
  vertical-align: middle !important;
  border: none !important;
}

.tabs-container .uc.addToCart .tbl-color-size label {
  font-size: var(--font-size-xs) !important;
  font-weight: var(--font-weight-semibold) !important;
  text-transform: uppercase !important;
  letter-spacing: 0.05em !important;
  color: var(--color-text-light) !important;
  white-space: nowrap !important;
  padding-right: var(--spacing-sm) !important;
  display: block !important;
  margin-bottom: 4px !important;
}

.tabs-container .uc.addToCart .tbl-color-size select {
  width: 100% !important;
  padding: 8px 10px !important;
  border: 1px solid var(--color-border) !important;
  border-radius: 0 !important;
  font-size: var(--font-size-sm) !important;
  background: var(--color-white) !important;
  color: var(--color-text-dark) !important;
  font-family: var(--font-body) !important;
}

/* Price styling */
.tabs-container .uc.addToCart .price-container {
  margin:0 !important;
  padding-bottom:var(--spacing-sm) !important;
  border-bottom:1px solid var(--color-gray-100) !important;
  display:flex !important;
  flex-direction:row !important;
  align-items:center !important;
  gap: var(--spacing-md) !important;
}

.tabs-container .uc.addToCart .price-label {
  font-size:var(--font-size-sm) !important;
  text-transform:uppercase !important;
  letter-spacing:2px !important;
  color:var(--color-gray-500) !important;
  font-weight:600 !important;
}

.tabs-container .uc.addToCart .price,
.tabs-container .uc.addToCart .sale-price {
  font-family:var(--font-display) !important;
  font-size:var(--font-size-2xl) !important;
  line-height:1 !important;
  font-weight:400 !important;
  color:var(--color-primary) !important;
  background:transparent !important;
}

/* Quantity and command styling */
.tabs-container .uc.addToCart .cmd-container {
  display:flex !important;
  align-items:center !important;
  gap:var(--spacing-sm) !important;
  width:100% !important;
}

.tabs-container .uc.addToCart .qty-container {
  display:flex !important;
  align-items:center !important;
  background:var(--color-gray-50) !important;
  border:1px solid var(--color-gray-200) !important;
  border-radius: 0 !important;
  padding:var(--spacing-2xs) var(--spacing-md) !important;
  height:56px !important;
  transition:all 0.3s ease !important;
}

.tabs-container .uc.addToCart .qty-container:focus-within {
  background: var(--color-white) !important;
  border-color:var(--color-primary) !important;
  box-shadow: none !important;
}

.tabs-container .uc.addToCart input[type="text"].number {
  width:50px !important;
  border:none !important;
  background:transparent !important;
  font-size:var(--font-size-md) !important;
  font-weight:500 !important;
  text-align:center !important;
  color:var(--color-text-dark) !important;
  padding:0 !important;
  min-height:auto !important;
}

.tabs-container .uc.addToCart .btn,
.tabs-container .uc.addToCart button {
  height:56px !important;
  background:var(--color-primary-dark) !important;
  color:var(--color-white) !important;
  border:none !important;
  padding:0 var(--spacing-2xl) !important;
  border-radius: 0 !important;
  font-family:var(--font-body) !important;
  font-weight:600 !important;
  font-size:var(--font-size-base) !important;
  text-transform:uppercase !important;
  letter-spacing:2px !important;
  cursor:pointer !important;
  transition:all 0.4s ease !important;
  display:inline-flex;
  align-items:center !important;
  justify-content:center !important;
  box-shadow: none !important;
}

.tabs-container .uc.addToCart .btn.jqp {
  display:none;
}

.tabs-container .uc.addToCart .btn:hover {
  background: var(--color-white) !important;
  color: var(--color-primary-dark) !important;
  border: 1px solid var(--color-primary-dark) !important;
  box-shadow: none !important;
  transform:translateY(-2px) !important;
}

.tabs-container .uc.addToCart .subtotal {
  display:none !important;
}

/* Responsive layout */
@media (max-width:1400px) {
  #tabs-product .tabs-container {
      grid-template-columns: 300px 1fr !important;
      gap:var(--spacing-xl) !important;
      padding:var(--spacing-xl) 0 !important;
    }
}

@media (max-width: 1250px) {
  #tabs-product .tabs-container {
      grid-template-columns: 1fr !important;
      grid-template-rows:auto auto auto auto auto auto auto !important;
      gap:var(--spacing-lg) !important;
      padding:var(--spacing-lg) 0 !important;
    }
  .tabs-container > .uc.addToCart {
      grid-column:1 !important;
      grid-row:3 !important;
      padding:var(--spacing-lg) !important;
      margin-bottom:0 !important;
    }
  #tabs-product .prod-image {
      grid-column:1 !important;
      grid-row:1 !important;
      max-width:500px !important;
      margin:0 auto !important;
    }
}

@media (max-width: 1250px) {
  #tabs-product .tabs-container {
      grid-template-columns: 1fr !important;
      gap:var(--spacing-md) !important;
      padding:var(--spacing-md) 0 !important;
    }
  #tab_reviews, #tab_vineyards, #tab_winemaker, .tabs-container > .uc.addToCart {
    grid-column:1;
    grid-row:auto;
  }
  .tabs-container > .uc.addToCart {
      grid-column:1;
      grid-row:3;
    }
  #tabs-product .tabs-wrap {
      grid-column:1;
    }
  #tabs-product .tabs-content {
      grid-column:1;
    }
}

.tabs-container .addToCart > span {
  display:block;
}

.tabs-container .addToCart {
  padding:var(--spacing-xs) 0 0;
}

@media only screen and (max-width:900px) {
  .shop-content,
    #tabs-product .tabs-container {
      flex-direction:column;
    }
}

@media only screen and (max-width: 1250px) {
  #tabs-product .prod-image {
      display:block;
      float:none;
      margin:0 auto var(--spacing-xs);
      text-align:center;
      position: relative !important;
      top: auto !important;
    }
}

@media only screen and (max-width:639px) {
  .tabs-container .addToCart {
      position:static;
      background:none;
      border:0;
      padding:var(--spacing-xl) 0;
    }
  #tabs-product .tabs-container {
      padding:var(--spacing-xs) 0 0 !important;
      border:0;
    }
  #tabs-product .tabs-content {
      margin-right:0;
    }
  #tabs-product .ui-tabs-nav li {
      float:none;
      margin:0;
    }
  #tabs-product .ui-tabs-nav a {
      float:none;
      display:block;
    }
  #tabs-product .ui-tabs-nav li.ui-tabs-selected {
      margin:0;
    }
  #tabs-product .ui-tabs-nav li.ui-tabs-selected a {
      padding-bottom:var(--spacing-2xs);
    }
}

@media (min-width: 1251px) {
  #tabs-product .tabs-content {
      display: flex;
      gap:var(--spacing-xl);
    }
}

#tabs-product .tabs-container a.btn {
  color:var(--color-white);
}

#tabs-product .tabs-container a.btn:hover {
  background: var(--color-white);
  color: var(--color-primary-dark);
  border: 1px solid var(--color-primary-dark);
}

/* ==========================================================================
   SECTION 9: SHOPPING SUMMARY DRAWER (CART)
   ========================================================================== */

.activeCart-panel {
  position:fixed !important;
  top:0 !important;
  bottom:0 !important;
  right:0;
  width:100% !important;
  height:100vh !important;
  height:100dvh !important;
  background:var(--color-white);
  z-index:10001 !important;
  box-shadow: none !important;
  transform:translateX(100%);
  transition:transform 0.6s cubic-bezier(0.16, 1, 0.3, 1);
  margin:0 !important;
  padding:0 !important;
  display:flex !important;
  flex-direction:column;
}

.activeCart-panel.open {
  transform:translateX(0);
}

/***** activeCart *****/
.uc.activeCart {
  top:0 !important;
  border:none !important;
  border-radius:0 !important;
  height:100% !important;
  display:flex !important;
  flex-direction:column;
}

table.activeCart {
  border:none;
  width:100%;
  border-radius:0;
  overflow:hidden;
  height:100%;
  border-collapse:collapse;
  display:flex !important;
  flex-direction:column;
  background:var(--color-white);
}

table.activeCart > tbody {
  display:flex !important;
  flex-direction:column;
  flex:1;
  width:100%;
  min-height:0;
}

table.activeCart > tbody > tr:first-child {
  display: flex !important;
  flex-direction:column;
  flex:1;
  min-height:0;
}

.uc.activeCart table,
.uc.activeCart tbody,
.uc.activeCart tr {
	width:100% !important;
}

.uc.activeCart tr {
  display:flex !important;
  width:100% !important;
  box-sizing:border-box !important;
  padding:0;
}

.uc.activeCart td {
  display:flex !important;
  box-sizing:border-box !important;
  padding:0;
}

.activeCart .cartBody {
  padding:0 var(--spacing-xl) 0 !important; /* Adjust bottom padding as sticky elements will provide their own */
  flex:1;
  overflow:hidden !important; /* Hide overflow for the cart body itself, allowing children to scroll */
  width:100%;
  min-height:0;
  display:flex !important;
  flex-direction:column !important;
}

.activeCart .cartBody > * {
  flex-shrink:0;
}

.activeCart .cartBody br {
  display:none !important;
}

.activeCart .cartBody .empty-cart {
  padding: var(--spacing-xl) 0;
  text-align: center;
  width: 100%;
}

.activeCart .cartBody .empty-cart center {
  display: flex !important;
  flex-direction: column !important;
  align-items: center !important;
  justify-content: center !important;
  gap: var(--spacing-sm) !important;
  font-family: var(--font-body) !important;
  font-size: var(--font-size-base) !important;
  color: var(--color-text-light) !important;
  line-height: var(--line-height-normal) !important;
}

.activeCart .cartBody .empty-cart a.btn {
  display: inline-block !important;
  margin-top: var(--spacing-xs) !important;
  padding: var(--spacing-2xs) var(--spacing-lg) !important;
  background: var(--color-primary-dark) !important;
  color: var(--color-white) !important;
  border-radius: 0 !important;
  font-family: var(--font-body) !important;
  font-weight: var(--font-weight-semibold) !important;
  text-transform: uppercase !important;
  font-size: var(--font-size-sm) !important;
  transition: all 0.2s ease !important;
  border: 1px solid var(--color-primary-dark) !important;
}

.activeCart .cartBody .empty-cart a.btn:hover {
  background: var(--color-white) !important;
  color: var(--color-primary-dark) !important;
  border: 1px solid var(--color-primary-dark) !important;
}

.activeCartMainContainer {
  display:flex !important;
  flex-direction:column;
  height:100%;
  width:100%;
  min-height:0;
  flex:1;
}

.activeCart-panel.open {
  transform:translateX(0);
}

/* Cart Drawer Overlay */
.cart-drawer-overlay {
  position:fixed;
  top:0;
  left:0;
  width:100%;
  height:100%;
  background:rgba(0, 0, 0, 0.4);
  z-index:10000;
  opacity:0;
  visibility:hidden;
  transition:all 0.3s ease;
}

.cart-drawer-overlay.open {
  opacity:1;
  visibility:visible;
}

/* Header */
.activeCart .cartHeader {
  display:flex;
  justify-content:space-between;
  align-items:center;
  padding:var(--spacing-lg) var(--spacing-xl) !important;
  background:var(--color-primary-dark) !important;
  color:var(--color-white) !important;
  font-family:var(--font-display) !important; /* Baskervville */
  font-size: 24px !important;
  font-weight:400 !important;
  line-height:1.2 !important;
  text-transform:none !important;
  letter-spacing:0.5px !important;
  border-bottom:1px solid var(--color-primary-dark) !important;
}

.close-cart-drawer {
  display: flex;
  align-items: center;
  justify-content: center;
  cursor:pointer;
  font-size: 32px !important;
  font-weight:200;
  line-height:0.8;
  color:var(--color-white) !important;
  padding:0;
  transition:all 0.25s ease;
  opacity:0.8;
  min-height: 64px !important;
  max-height: 64px !important;
  min-width: 64px !important;
  max-width: 64px !important;
}

.close-cart-drawer:hover {
  opacity: 1;
  transform:scale(1.15) rotate(90deg);
}

/* Shopping Summary Styling */
.activeCart .cartBody .cart-checkout-container { /* Target specifically within cartBody */
  order:6 !important;
  position:relative !important;
  top:auto !important;
  z-index:1 !important;
  background:var(--color-white) !important;
  padding:0 0 var(--spacing-lg) !important;
  margin:0 !important;
  border-bottom:none !important;
  box-shadow:none !important;
}

.activeCart .cartBody .cart-checkout-container .btn {
  margin:0 !important;
}

.activeCart a:not(.basket):not(.btncontinueshopping):not(.btn),
.activeCart button,
.activeCart .btn {
  display: inline-block;
  width:auto;
  text-align:center;
  font-family:var(--font-body) !important;
  font-size:var(--font-size-sm) !important;
  font-weight:500 !important;
  line-height:1em !important;
  text-transform: uppercase !important;
  letter-spacing:0 !important;
  background:var(--color-primary-dark) !important;
  color:var(--color-white) !important;
  border: 1px solid var(--color-primary-dark) !important;
  border-radius: 0 !important;
  padding:var(--btn-padding) !important;
  text-decoration:none !important;
  transition:all 0.3s ease !important;
  box-sizing:border-box;
}

.activeCart a:not(.basket):not(.btncontinueshopping):not(.btn):hover,
.activeCart button:hover,
.activeCart .btn:hover,
.cart-checkout-container .btn:hover,
.activeCart .btncontinueshopping:hover,
.cart-item-line .btn.hvr:hover {
  background: var(--color-white) !important;
  color: var(--color-primary-dark) !important;
  border: 1px solid var(--color-primary-dark) !important;
  transform:translateY(-1px) !important;
}

.cart-checkout-container .btn,
.activeCart .btncontinueshopping {
  display:block;
  width:100%;
  text-align:center;
  font-family:var(--font-body) !important;
  font-size:var(--font-size-sm) !important;
  font-weight:600 !important;
  line-height:1 !important;
  text-transform:uppercase !important;
  letter-spacing:1.5px !important;
  background:var(--color-primary-dark) !important;
  color:var(--color-white) !important;
  border: 1px solid var(--color-primary-dark) !important;
  border-radius: 0 !important;
  padding:var(--spacing-sm) var(--spacing-xl) !important;
  text-decoration:none !important;
  transition:all 0.3s cubic-bezier(0.16, 1, 0.3, 1) !important;
  box-shadow: none !important;
  box-sizing:border-box;
}

.cart-checkout-container .btn:hover,
.activeCart .btncontinueshopping:hover {
  background: var(--color-white) !important;
  color: var(--color-primary-dark) !important;
  border: 1px solid var(--color-primary-dark) !important;
  transform:translateY(-2px) !important;
  box-shadow: none !important;
}

/* Secondary Button Outline Variant for Continue Shopping if displayed */
.activeCart .btncontinueshopping {
  background:transparent !important;
  color:var(--color-primary-dark) !important;
  border:1px solid var(--color-primary-dark) !important;
  box-shadow:none !important;
}

.activeCart .btncontinueshopping:hover {
  background: var(--color-white) !important;
  color: var(--color-primary-dark) !important;
  border: 1px solid var(--color-primary-dark) !important;
  box-shadow: none !important;
}

.cart-items-container {
  order:3 !important;
  width:100% !important;
  border-collapse:collapse;
  display:block !important;
  flex:1 !important; /* Allow it to grow and take available space */
  overflow-y:auto !important;
  overflow-x:hidden !important;
  min-height:0 !important;
  padding:0 !important; /* Reset padding for perfect alignment */
}

/* Custom Scrollbar for Cart Items Container */
.cart-items-container::-webkit-scrollbar {
  width: 5px;
}

.cart-items-container::-webkit-scrollbar-track {
  background: transparent;
}

.cart-items-container::-webkit-scrollbar-thumb {
  background: var(--color-gray-200);
  border-radius: 0;
}

.cart-items-container::-webkit-scrollbar-thumb:hover {
  background: var(--color-gray-300);
}

.cart-items-container tbody {
  display:block !important;
  width:100% !important;
}

.cart-item-line {
  display:flex !important; 
  flex-direction:row !important;
  align-items:flex-start !important; /* Align content to top for premium look */
  width:100% !important;
  border-bottom:1px solid var(--color-gray-100) !important;
  padding:var(--spacing-md) 0 !important;
  margin-bottom:0 !important;
  transition:all 0.25s ease;
}

.cart-item-line:hover {
  opacity: 1 !important;
}

.cart-item-line .thumb {
  width:70px !important;
  flex:0 0 70px !important;
  margin-right:var(--spacing-sm) !important;
  max-height:none !important;
  padding:0 !important;
}

.cart-item-line .thumb img {
  width:100%;
  height:auto;
  border-radius: 0;
  border:1px solid var(--color-border-light);
  max-height:none !important;
  object-fit:cover;
  box-shadow: none;
  transition:all 0.3s cubic-bezier(0.16, 1, 0.3, 1);
}

.cart-item-line:hover .thumb img {
  transform: translateY(-2px);
  box-shadow: none;
  border-color:var(--color-border);
}

.cart-item-line .prod-info {
  padding:0 !important;
  flex:1;
  display:flex !important;
  flex-direction:column !important;
  justify-content:flex-start !important;
  align-items:flex-start !important;
  gap:var(--spacing-2xs) !important;
  font-family:var(--font-body) !important;
}

/* Reset the legacy selector leak that targeted all `a` tags in `.prod-info` */
.cart-item-line .prod-info a {
  border:none !important;
  padding:0 !important;
  border-radius:0 !important;
  text-align:left !important;
  width:auto !important;
  display:inline-block !important;
  font-family:var(--font-body) !important;
  font-size:var(--font-size-sm) !important;
  font-weight:400 !important;
  line-height:inherit !important;
  color:inherit !important;
  letter-spacing:normal !important;
}

.cart-item-line .prod-info .title,
.cart-item-line .prod-info a.title {
  display:block !important;
  font-family:var(--font-display) !important; /* Baskervville */
  font-size:var(--font-size-md) !important;
  font-weight:400 !important;
  line-height:1.3 !important;
  margin-bottom:2px !important;
  color:var(--color-text-dark) !important;
  letter-spacing:0 !important;
  width:100% !important;
  border:none !important;
  padding:0 !important;
  border-radius:0 !important;
  text-align:left !important;
  text-decoration:none !important;
}

.cart-item-line .price {
  margin:0 !important;
  font-family:var(--font-body) !important;
  font-size:var(--font-size-base) !important;
  font-weight:500 !important;
  color:var(--color-primary) !important;
  text-align:left;
}

.cart-item-line .price-label {
  display:none;
}

.cart-item-line .qty {
  margin-top:var(--spacing-2xs) !important;
  display:flex !important;
  flex-direction:row !important;
  align-items:center !important;
  gap:var(--spacing-2xs) !important;
  width:100% !important;
}

.cart-item-line .qty-label {
  font-family:var(--font-body) !important;
  font-size:var(--font-size-2xs) !important;
  text-transform:uppercase !important;
  letter-spacing:0.5px !important;
  color:var(--color-gray-500) !important;
  font-weight:500 !important;
  margin:0 !important;
}

.cart-item-line .qty input {
  width:38px !important;
  height:28px !important;
  padding:0 !important;
  text-align:center !important;
  font-family:var(--font-body) !important;
  font-size:var(--font-size-sm) !important;
  font-weight:500 !important;
  color:var(--color-text-dark) !important;
  border:1px solid var(--color-border) !important;
  border-radius: 0 !important;
  background:var(--color-white) !important;
  box-shadow:none !important;
  transition:all 0.2s ease !important;
}

.cart-item-line .qty input:focus {
  border-color: var(--color-primary) !important;
  outline:none !important;
  box-shadow: none !important;
}

.cart-item-line .qty .lnk-update {
  display:inline-block !important;
  font-family:var(--font-body) !important;
  font-size:10px !important;
  font-weight:600 !important;
  text-transform:uppercase !important;
  letter-spacing:1px !important;
  color:var(--color-primary) !important;
  text-decoration:none !important;
  cursor:pointer !important;
  margin-left:var(--spacing-3xs) !important;
  border-bottom:1px solid transparent !important;
  transition:all 0.2s ease !important;
  padding:0 !important;
  background:transparent !important;
}

.cart-item-line .qty .lnk-update:hover {
  color: var(--color-primary-dark) !important;
  border-bottom-color:var(--color-primary-dark) !important;
}

.cart-item-line .btn.hvr {
  display:none !important; /* Hide standard hvr button styles for change/remove inside qty */
}

/* Remove button styled as a minimal, high-end text link on the far right */
.cart-item-line .qty a.remove {
  display:inline-flex !important;
  align-items:center !important;
  justify-content:center !important;
  width:auto !important;
  height:auto !important;
  background:transparent !important;
  color:var(--color-gray-400) !important;
  border:none !important;
  border-radius:0 !important;
  padding:0 !important;
  font-family:var(--font-body) !important;
  font-size:10px !important;
  font-weight:500 !important;
  text-transform:uppercase !important;
  letter-spacing:1px !important;
  text-decoration:none !important;
  margin-left:auto !important; /* Push remove button to the far right */
  border-bottom:1px solid transparent !important;
  transition:all 0.2s ease !important;
}

.cart-item-line .qty a.remove:hover {
  background: transparent !important;
  color:var(--color-primary) !important;
  border-bottom-color:var(--color-primary) !important;
  transform:none !important;
  box-shadow:none !important;
}

.cart-item-line .btn.basket {
  display:none !important;
}

.activeCart .cartBody > .rule {
  order:2 !important;
}

/* Announcement Layout Wrapper */
table.activeCart > tbody > tr:last-child {
  width: 100% !important;
  display:block !important;
  flex-shrink:0 !important;
  margin-top:auto !important;
}

table.activeCart > tbody > tr:last-child > td {
  width: 100% !important;
  padding:var(--spacing-md) var(--spacing-xl) var(--spacing-lg) !important;
  display:block !important;
  box-sizing:border-box !important;
}

[id$="ActiveCart1_pnlContinueShopping"] {
  order:7 !important;
}

[id$="ActiveCart1_pnlUpdateCart"] {
  order:8 !important;
}

/* --- Premium Staggered Pop-in Animations for Cart Elements --- */
/* Initial hidden state for elements inside the drawer to allow animation from opacity 0 */
.activeCart-panel .cartHeader,
.activeCart-panel .cart-items-label,
.activeCart-panel .cartBody > .rule,
.activeCart-panel .cart-items-container,
.activeCart-panel .cart-item-line,
.activeCart-panel [id$="ActiveCart1_pnlSumary"],
.activeCart-panel .cart-checkout-container,
.activeCart-panel table.activeCart > tbody > tr:last-child {
  opacity: 0;
}

/* Animations active state when drawer slides open */
.activeCart-panel.open .cartHeader {
  animation:cartFadeInDown 0.5s cubic-bezier(0.16, 1, 0.3, 1) forwards;
  animation-delay:0.1s;
}

.activeCart-panel.open .cart-items-label {
  animation:cartFadeInUp 0.5s cubic-bezier(0.16, 1, 0.3, 1) forwards;
  animation-delay:0.2s;
}

.activeCart-panel.open .cartBody > .rule {
  animation:cartFadeInUp 0.5s cubic-bezier(0.16, 1, 0.3, 1) forwards;
  animation-delay:0.25s;
}

.activeCart-panel.open .cart-items-container {
  animation:cartFadeInUp 0.5s cubic-bezier(0.16, 1, 0.3, 1) forwards;
  animation-delay:0.3s;
}

.activeCart-panel.open .cart-item-line {
  animation:cartFadeInUp 0.6s cubic-bezier(0.16, 1, 0.3, 1) forwards;
}

/* Staggered delay for cart items */
.activeCart-panel.open .cart-item-line:nth-child(1) { animation-delay: 0.35s; }

.activeCart-panel.open .cart-item-line:nth-child(2) { animation-delay: 0.45s; }

.activeCart-panel.open .cart-item-line:nth-child(3) { animation-delay: 0.55s; }

.activeCart-panel.open .cart-item-line:nth-child(4) { animation-delay: 0.65s; }

.activeCart-panel.open .cart-item-line:nth-child(5) { animation-delay: 0.75s; }

.activeCart-panel.open [id$="ActiveCart1_pnlSumary"] {
  animation:cartFadeInUp 0.5s cubic-bezier(0.16, 1, 0.3, 1) forwards;
  animation-delay:0.45s;
}

.activeCart-panel.open .cart-checkout-container {
  animation:cartFadeInUp 0.5s cubic-bezier(0.16, 1, 0.3, 1) forwards;
  animation-delay:0.5s;
}

.activeCart-panel.open table.activeCart > tbody > tr:last-child {
  animation: cartFadeInUp 0.5s cubic-bezier(0.16, 1, 0.3, 1) forwards;
  animation-delay:0.6s;
}

.page-signin .activeCart {
  width:100%;
}

@media only screen and (max-width: 1250px) {
  .activeCart-panel {
      max-width: 100%;
    }
  .page-account div.activeCart {
      width:100%;
    }
  .activeCart-panel {
      width:100%;
    }
}

/* Apply narrower max-width for larger screens (tablet and desktop) */
@media only screen and (min-width: 1251px) {
  .activeCart-panel {
      max-width: 420px !important;
    }
}

@media only screen and (max-width:639px) {
  .activeCart-panel {
      /* These rules are now handled by the global width:100% and the max-width: 768px media query */
      /* float: left; */
      /* width:100%; */
      /* margin:0; */
    }
  .activeCart {
      width:100%;
    }
  #activeCartContainer {
      margin:0;
    }
  .help_aside div.activeCart {
      width:100%;
    }
}

/* Active cart contrast fixes */
.activeCart center {
  color: var(--color-text-dark) !important;
}

.activeCart center a {
  color: var(--color-primary) !important;
}

.activeCart {
  color: var(--color-text-dark) !important;
}

.ui-widget-header,
.activeCart .cartHeader,
.shop-left-menu .menu-header,
#accountContent .header,
#checkout .header,
#basket .header,
.bootstrapWizard li.complete .step,
.bootstrapWizard li.active .step,
.bootstrapWizard li.active.complete .step,
#tabs-product ul a,
#tabs-product .ui-tabs-nav a {
  background:var(--color-primary-dark);
}

/* ==========================================================================
   SECTION 10: ADD-TO-CART TOAST POPUP
   ========================================================================== */

.add-to-cart-confirmation-message {
  position:fixed !important;
  top:var(--spacing-xl) !important;
  bottom:auto !important;
  left:50% !important;
  right:auto !important;
  transform:translate(-50%, 0) !important;
  z-index:99999 !important;
  background:rgba(255, 255, 255, 0.9) !important;
  backdrop-filter:blur(12px) !important;
  -webkit-backdrop-filter:blur(12px) !important;
  border:1px solid rgba(199, 210, 193, 0.5) !important;
  border-left:var(--spacing-3xs) solid var(--color-primary) !important;
  border-radius: 0 !important;
  padding:var(--spacing-lg) var(--spacing-2xl) var(--spacing-lg) 54px !important;
  width:90% !important;
  max-width:440px !important;
  box-shadow: none !important;
  color:var(--color-text-dark) !important;
  font-family:var(--font-body) !important;
  font-size:var(--font-size-base) !important;
  font-weight:var(--font-weight-medium) !important;
  line-height:1.4 !important;
  box-sizing:border-box !important;
  animation:toastPopDownFade 4.5s ease-in-out forwards !important;
}

.add-to-cart-confirmation-message::before {
  content: "\f058" !important;
  font-family:"Font Awesome 5 Pro" !important;
  font-weight:900 !important;
  font-size:var(--font-size-md) !important;
  color:var(--color-primary) !important;
  position:absolute !important;
  left:var(--spacing-md) !important;
  top:23px !important;
}

@keyframes toastPopDownFade {
  0% {
    transform:translate(-50%, -120px) scale(0.85);
    opacity:0;
  }
  /* Settle Pop-down */
  8% {
    transform:translate(-50%, 14px) scale(1.02);
    opacity:1;
  }
  12% {
    transform:translate(-50%, 0) scale(1);
    opacity:1;
  }
  /* Hold visible */
  88% {
    transform:translate(-50%, 0) scale(1);
    opacity:1;
  }
  /* Fade out & slide back up */
  100% {
    transform:translate(-50%, -24px) scale(0.95);
    opacity:0;
  }
}

.add-to-cart-confirmation-message.hiding {
  animation:toastFadeOutExit 0.3s ease-in forwards !important;
}

@keyframes toastFadeOutExit {
  from {
    transform:translate(-50%, 0) scale(1);
    opacity:1;
  }
  to {
    transform:translate(-50%, -24px) scale(0.95);
    opacity:0;
  }
}

@keyframes toastPopDownFadeMobile {
  0% {
    transform:translateY(-120px) scale(0.85);
    opacity:0;
  }
  /* Settle Pop-down */
  8% {
    transform:translateY(14px) scale(1.02);
    opacity:1;
  }
  12% {
    transform:translateY(0) scale(1);
    opacity:1;
  }
  /* Hold visible */
  88% {
    transform:translateY(0) scale(1);
    opacity:1;
  }
  /* Fade out & slide back up */
  100% {
    transform:translateY(-24px) scale(0.95);
    opacity:0;
  }
}

@keyframes toastFadeOutExitMobile {
  from {
    transform:translateY(0) scale(1);
    opacity:1;
  }
  to {
    transform:translateY(-24px) scale(0.95);
    opacity:0;
  }
}

@media only screen and (max-width:640px) {
  .add-to-cart-confirmation-message {
      top: 16px !important;
      bottom:auto !important;
      right:var(--spacing-sm) !important;
      left:var(--spacing-sm) !important;
      max-width:none !important;
      width:auto !important;
      transform:none !important;
      animation:toastPopDownFadeMobile 4.5s ease-in-out forwards !important;
    }
  .add-to-cart-confirmation-message.hiding {
      animation:toastFadeOutExitMobile 0.3s ease-in forwards !important;
    }
}

.add-to-cart-confirmation-message .btn-close {
  position:absolute !important;
  top:var(--spacing-sm) !important;
  right:var(--spacing-sm) !important;
  width:22px !important;
  height:22px !important;
  cursor:pointer !important;
  background:rgba(0, 0, 0, 0.03) !important;
  border:none !important;
  border-radius: 0 !important;
  opacity:0.5 !important;
  transition:all 0.25s cubic-bezier(0.16, 1, 0.3, 1) !important;
  display:flex !important;
  align-items:center !important;
  justify-content:center !important;
}

.add-to-cart-confirmation-message .btn-close:hover {
  background: var(--color-white) !important;
  color: var(--color-primary-dark) !important;
  border: 1px solid var(--color-primary-dark) !important;
  opacity:0.8 !important;
  transform:scale(1.05) rotate(90deg) !important;
}

.add-to-cart-confirmation-message .btn-close::before {
  content: "✕" !important;
  font-family:var(--font-body) !important;
  font-size:10px !important;
  font-weight:500 !important;
  color:var(--color-text-dark) !important;
  display:block !important;
  line-height:1 !important;
}

.add-to-cart-confirmation-message .add-to-cart-checkout {
  margin-top:var(--spacing-sm) !important;
  display:flex !important;
  width:100% !important;
}

.add-to-cart-confirmation-message .add-to-cart-checkout .btn {
  flex:1 !important;
  display:block !important;
  text-align:center !important;
  font-family:var(--font-body) !important;
  font-size:var(--font-size-2xs) !important;
  font-weight:600 !important;
  text-transform:uppercase !important;
  letter-spacing:1.5px !important;
  background:var(--color-primary-dark) !important;
  color:var(--color-white) !important;
  border:none !important;
  border-radius: 0 !important;
  padding:var(--spacing-xs) var(--spacing-sm) !important;
  text-decoration:none !important;
  transition:all 0.3s cubic-bezier(0.16, 1, 0.3, 1) !important;
  box-shadow: none !important;
}

.add-to-cart-confirmation-message .add-to-cart-checkout .btn:hover {
  background: var(--color-white) !important;
  color: var(--color-primary-dark) !important;
  border: 1px solid var(--color-primary-dark) !important;
  transform:translateY(-1px) !important;
  box-shadow: none !important;
}

/* ==========================================================================
   SECTION 11: TWEAKABLE PAGE-SPECIFIC LAYOUTS
   ========================================================================== */

#wine-clubs .btn {
  margin-bottom:var(--spacing-2xs);
}

.CustomerAccount {
  display:block;
  margin:0 0 var(--spacing-md);
}

form[action="/wine-club-join-thank-you.aspx"] #textContent > h1 span {
  font:var(--font-size-xl)/38px Arial,
    Helvetica,
    sans-serif !important;
}

#ctl00_Auth1_lblAccountGreeting,
#ctl00_Auth1_lblAccountGreetingGuest,
#ctl00_Auth1_lblAccountGreetingGuest + .splitter,
.popup #ctl00_cphBody_ciAddressInfo_trRegularEditSaveAsDefault + .row,
.addr-popup .edit-addr + br {
  display:none;
}

.join-wine-club-holder {
  width:100%;
}

.join-wine-club-holder:after, .paymentOptions_row:after,.fieldset_row:after, .signin_table .row:after, .signin_table .select_row:after, #checkout .bottom-section .btns:after {
  content: "";
  display:block;
  clear:both;
}

.join-wine-club-left,
.join-wine-club-right {
  float:left;
  width:50%;
  padding:0 var(--spacing-xs) 0 0;
}

.join-wine-club-right {
  float:right;
  padding:0 0 0 var(--spacing-xs);
}

.join-wine-club-content fieldset {
  margin:0 0 var(--spacing-xs);
  padding:var(--spacing-xs);
  border:1px solid var(--color-border);
}

.join-wine-club-content legend h3 {
  margin:0;
}

.wine-club-selections .prod-img {
  width:auto;
  margin:0 var(--spacing-xs) var(--spacing-xs) 0;
}

/***** SIGN IN *****/
.page-signin #contentContainer {
  display:flex;
}

.page-signin #pageContentCenter {
  flex:1 1 auto;
  margin-right:var(--spacing-xl);
}

.page-signin #pageContentLeft {
  display:none !important;
}

.page-signin #pageContentRight {
  flex:0 0 175px;
  float:none !important;
}

.signin_table .row {
  width:100%;
  margin:0 0 var(--spacing-sm);
}

.signin_table .col {
  float:left;
  width:50%;
  padding-right:var(--spacing-sm);
}

.signin_table .col.right {
  float:right;
}

.signin_table .select_row, .checkout-top-box.summary {
  width:100%;
  padding-bottom:var(--spacing-md);
}

.signin_table .select_box {
  padding:0 var(--spacing-sm) 0 0;
}

/***** MY ACCOUNT *****/
form[action="/account.aspx"] #pageContentCenter {
  display:inline-block !important;
  width:80% !important;
  float:none !important;
}

form[action="/account.aspx"] #pageContentRight {
  display:inline-block !important;
  width:20% !important;
  max-width:200px;
}

#accountContent .section,
#checkout .section,
#basket.section {
  margin:0 0 var(--spacing-lg);
  border:1px solid var(--color-border);
}

#accountContent .header,
#checkout .header,
#basket .header {
  text-align:left;
}

.account_address {
  overflow:hidden;
}

.section .content h3,
.section .content .account_address h3 {
  font-size:var(--font-size-md);
}

.account_address .column {
  float:left;
  width:50%;
  padding:0 0 0 var(--spacing-xs);
}

.account_address .column:first-child {
  padding: 0 10px 0 0;
}

.ciRegularView .row, .details_header,.details .item,.order_details .item, .edit-addr .row, .newsletter_table .row, .checkout-header, .basket_table .cart-header,.basket_table .item,.basket_table #divRowNoItems,.basket_table .footer, .change-password .row {
  display:table;
  width:100%;
  margin:0 0 var(--spacing-xs);
}

.edit-addr .col, .newsletter_table .col {
  display:table-cell;
  vertical-align:middle;
}

/***** NEWSLETTER *****/
form[action*="/newsletter"] #contentContainer,
form[action*="/newsletter"] #pageContentCenter,
form[action*="/newsletter"] #tableColumnsContainer,
form[action*="/newsletter"] .help_content,
form[action*="/newsletter"] .help_holder {
  width:100% !important;
  max-width:100% !important;
  float:none !important;
  display:flex !important;
  flex-direction:column !important;
  align-items:center !important;
  justify-content:center !important;
  box-sizing:border-box !important;
}

form[action*="/newsletter"] #tableColumnsContainer {
  padding:var(--spacing-4xl) 0 100px 0 !important;
}

form[action*="/newsletter"] #ctl00_cphBody_PageWrapper_Content_ContentAndSideBar_c1 {
  width:100% !important;
  max-width:680px !important;
  float:none !important;
  display:flex !important;
  flex-direction:column !important;
  align-items:center !important;
}

form[action*="/newsletter"] .uc.oPText h1 {
  font-family:var(--font-display) !important;
  font-size:38px !important;
  font-weight:400 !important;
  color:var(--color-primary) !important;
  text-align:center !important;
  margin-top:0 !important;
  margin-bottom:var(--spacing-sm) !important;
  line-height:1.2 !important;
}

form[action*="/newsletter"] .uc.oPText p {
  font-family:var(--font-body) !important;
  font-size:var(--font-size-base) !important;
  line-height:1.6 !important;
  color:var(--color-gray-500) !important;
  text-align:center !important;
  max-width:600px !important;
  margin:0 auto var(--spacing-2xl) !important;
}

.newsletter {
  background:var(--color-white) !important;
  border:1px solid var(--color-border-light) !important;
  border-radius: 0 !important;
  box-shadow: none !important;
  padding:var(--spacing-2xl) !important;
  max-width:560px !important;
  width:100% !important;
  box-sizing:border-box !important;
  margin:0 auto !important;
}

.newsletter_table {
  display:flex !important;
  flex-direction:column !important;
  gap:var(--spacing-md) !important;
  width:100% !important;
}

.newsletter_table .row {
  display:flex !important;
  flex-direction:column !important;
  align-items:stretch !important;
  margin:0 !important;
  width:100% !important;
}

.newsletter_table .col {
  display:block !important;
  width:100% !important;
  padding:0 !important;
}

.newsletter_table .col:first-child {
  width: 100% !important;
  text-align:left !important;
  padding:0 0 var(--spacing-2xs) 0 !important;
}

.newsletter_table label {
  font-family:var(--font-body) !important;
  font-size:var(--font-size-2xs) !important;
  font-weight:600 !important;
  text-transform:uppercase !important;
  letter-spacing:1.5px !important;
  color:var(--color-gray-500) !important;
  display:inline-block !important;
}

.newsletter_table label.req::after {
  content: " *" !important;
  color:var(--color-primary-dark) !important;
}

.newsletter_table input[type="text"],
.newsletter_table select {
  width:100% !important;
  height:46px !important;
  box-sizing:border-box !important;
  border:1px solid var(--color-border) !important;
  border-radius: 0 !important;
  padding:0 var(--spacing-sm) !important;
  font-family:var(--font-body) !important;
  font-size:var(--font-size-sm) !important;
  color:var(--color-text-dark) !important;
  background:var(--color-white) !important;
  transition:all 0.3s ease !important;
  box-shadow:none !important;
}

.newsletter_table input[type="text"]:focus,
.newsletter_table select:focus {
  border-color: var(--color-primary-dark) !important;
  outline:none !important;
  box-shadow: none !important;
}

/* Success/Error Message container */
[id$="_newsLetter_divMess"] {
  width:100% !important;
  box-sizing:border-box !important;
  font-family:var(--font-body) !important;
  font-size:var(--font-size-sm) !important;
  margin-bottom:0px !important;
}

[id$="_newsLetter_divMess"]:not(:empty) {
  padding:var(--spacing-sm) var(--spacing-md) !important;
  border-radius: 0 !important;
  background:var(--color-gray-50) !important;
  border-left:var(--spacing-3xs) solid var(--color-primary) !important;
  color:var(--color-text-dark) !important;
  margin-bottom:var(--spacing-md) !important;
}

/* Legend row ("* Required") */
.newsletter_table .row:nth-last-child(2) {
  text-align: left !important;
  color:var(--color-gray-400) !important;
  font-family:var(--font-body) !important;
  font-size:var(--font-size-xs) !important;
}

.newsletter_table .row:nth-last-child(2) br {
  display: none !important;
}

.newsletter_table .row:nth-last-child(2) .col {
  padding: 0 !important;
  display:block !important;
}

.newsletter_table .row:nth-last-child(2) .col:first-child {
  display: none !important;
}

.newsletter_table .submit-row {
  margin-top:var(--spacing-xs) !important;
  display:flex !important;
  justify-content:center !important;
}

.newsletter_table .submit-row .col {
  display:flex !important;
  justify-content:center !important;
}

.newsletter_table .submit-row .btn {
  display:inline-block !important;
  width:100% !important;
  max-width:240px !important;
  text-align:center !important;
  font-family:var(--font-body) !important;
  font-size:var(--font-size-sm) !important;
  font-weight:600 !important;
  text-transform:uppercase !important;
  letter-spacing:1.5px !important;
  background:var(--color-primary-dark) !important;
  color:var(--color-white) !important;
  border:none !important;
  border-radius: 0 !important;
  padding:var(--spacing-sm) 28px !important;
  text-decoration:none !important;
  transition:all 0.3s cubic-bezier(0.16, 1, 0.3, 1) !important;
  box-shadow: none !important;
  cursor:pointer !important;
}

.newsletter_table .submit-row .btn:hover {
  background: var(--color-white) !important;
  color: var(--color-primary-dark) !important;
  border: 1px solid var(--color-primary-dark) !important;
  transform:translateY(-2px) !important;
}

/***** WINE CLUB *****/
form[action*="/wine-club"] #contentContainer,
form[action*="/wine-club"] #pageContentCenter,
form[action*="/wine-club"] #tableColumnsContainer,
form[action*="/wine-club"] .help_content,
form[action*="/wine-club"] .help_holder {
  width:100% !important;
  max-width:100% !important;
  float:none !important;
  display:flex !important;
  flex-direction:column !important;
  align-items:center !important;
  justify-content:center !important;
  box-sizing:border-box !important;
}

form[action*="/wine-club"] #tableColumnsContainer {
  padding:var(--spacing-2xl) 0 80px 0 !important;
}

form[action*="/wine-club"] #ctl00_cphBody_PageWrapper_Content_ContentAndSideBar_c1 {
  width:100% !important;
  max-width:1400px !important;
  float:none !important;
  display:flex !important;
  flex-direction:column !important;
  align-items:center !important;
}

#wine-clubs {
  width:100% !important;
  box-sizing:border-box !important;
}

form[action="/account.aspx"] #contentContainer {
  display:flex;
  justify-content:space-between;
}

form[action="/account.aspx"] #pageContentRight, .help_aside {
  max-width:200px;
  width:20%;
}

form[action="/account.aspx"] #pageContentCenter {
  flex-grow:1;
  margin-right:var(--spacing-xs);
}

@media only screen and (max-width:900px) {
  .account_address .column,.account_address .column:first-child,.addr-table .column,.addr-table .column:first-child, .join-wine-club-left,.join-wine-club-right, .addr-table .column,.addr-table .column:first-child {
    float: none;
    width:100%;
    padding:0;
  }
  .account_address .column:first-child,
    .addr-table .column:first-child {
      padding-bottom: 25px;
    }
}

@media only screen and (max-width: 1250px) {
  form[action="/account.aspx"] #contentContainer,
    form[action="/account"] #contentContainer,
    form[action="/newsletter.aspx"] #tableColumnsContainer,
    form[action="/newsletter"] #tableColumnsContainer {
      flex-direction:column;
    }
  form[action="/account.aspx"] #pageContentRight,form[action="/account"] #pageContentRight,form[action="/newsletter.aspx"] #tableColumnsContainer .help_content,form[action="/newsletter.aspx"] #tableColumnsContainer .help_aside,form[action="/newsletter"] #tableColumnsContainer .help_content,form[action="/newsletter"] #tableColumnsContainer .help_aside, form[action="/newsletter"] .help_content,form[action="/newsletter"] .help_aside {
    max-width:100%;
    width:100%;
  }
  form[action="/account"] #pageContentCenter,
    form[action="/account.aspx"] #pageContentCenter,
    form[action="/account"] #pageContentRight,
    form[action="/account.aspx"] #pageContentRight {
      display:block !important;
      width:100% !important;
      float:none;
      max-width:100%;
    }
  .signin_table .col,
    .signin_table .col.right {
      float:none;
      width:100%;
      padding:0 0 var(--spacing-sm);
    }
  .signin_table .row {
      margin:0;
    }
  .account-holder {
      margin-right:var(--spacing-xs);
    }
  .page-account #pageContentRight {
      margin-left:0;
      width:100%;
    }
  .newsletter {
      max-width:100%;
    }
  .page-signin #pageContentRight {
      margin:0;
      width:100%;
      max-width:100%;
    }
  .page-signin #pageContentCenter, .page-signin #pageContentCenter {
    float:none;
    display:inline-block;
    width:100%;
  }
}

@media only screen and (max-width:639px) {
  .page-signin #contentContainer {
      flex-direction: column;
    }
  .signin_wrap {
      margin:0 0 var(--spacing-md);
    }
  .signin_table .select_box {
      padding:0 0 0 var(--spacing-xs);
    }
  .signin_table .select_box:first-child {
      padding: 0;
    }
  #checkout .left-box-head, .newsletter_table .col:first-child {
    width: 100%;
    padding:0;
    text-align:left;
  }
  .wine-club-selections input[type="text"] {
      max-width:50px;
    }
  #wine-clubs > div {
      margin:0;
    }
}

@media only screen and (max-width:479px) {
  .wine-club-selections .table_header {
      display:none;
    }
  .wine-club-selections .prod-img {
      margin:0 auto var(--spacing-xs);
      display:block;
    }
  .newsletter_table .col {
      display:block;
    }
  .newsletter_table .submit-row {
      text-align:center;
    }
}

form[action*="signin"] #footer + .uc,
.hidden,
a[name="product-list-top"],
form[action*="account"] #pageContentLeft,
.break,
.h-split {
  display:none !important;
}

@media (min-width: 1251px) {
  form[action*="account"] #pageContentWidth {
      display: block;
      gap:var(--spacing-md);
    }
}

/* hide shopping summary on newsletter page */
#box > .banner,
.sort-products,
.catalog-controls:has(.sort-products:first-child:last-child),
form[action*="/newsletter"] .help_aside._column {
  display: none;
}

/* ========================================
   MERCHANDISE PAGE LAYOUT & SPACING
   ======================================== */
form[action*="/merchandise"] #contentContainer {
  display:flex !important;
  flex-direction:column !important;
  width:100% !important;
  max-width:var(--container-max-width) !important;
  margin:0 auto !important;
  gap:var(--spacing-xl) !important;
  box-sizing:border-box !important;
}

form[action*="/merchandise"] #pageContentCenter,
form[action*="/merchandise"] #pageContentLeft {
  width:100% !important;
  float:none !important;
  display:block !important;
  box-sizing:border-box !important;
}

form[action*="/merchandise"] #textContent {
  text-align:center;
  margin-bottom:0;
}

/* ========================================
   RESERVATIONS PAGE PREMIUM STYLE & LAYOUT
   ======================================== */
.reservations.landing {
  max-width:var(--container-max-width) !important;
  margin:0 auto !important;
  padding:80px var(--spacing-lg) !important;
  box-sizing:border-box !important;
}

.reservations.landing h1 {
  font-family:var(--font-display) !important;
  font-size:56px !important;
  font-weight:400 !important;
  color:var(--color-primary) !important;
  margin:0 auto var(--spacing-lg) !important;
  letter-spacing:-0.5px !important;
  text-align:center !important;
  position:relative !important;
  padding-bottom:var(--spacing-lg) !important;
  display:block !important;
  width:100% !important;
}

.reservations.landing h1::after {
  content: "" !important;
  position:absolute !important;
  bottom:0 !important;
  left:50% !important;
  transform:translateX(-50%) !important;
  width:80px !important;
  height:2px !important;
  background-color:var(--color-primary) !important;
  opacity:0.4 !important;
}

@media (max-width: 1250px) {
  .reservations.landing h1 {
      font-size: 38px !important;
      padding-bottom:var(--spacing-md) !important;
    }
}

.reservations.landing .row:nth-child(2) {
  text-align: center !important;
  margin-bottom:56px !important;
}

.reservations.landing .row:nth-child(2) p {
  font-family: var(--font-body) !important;
  font-size:var(--font-size-sm) !important;
  font-weight:500 !important;
  letter-spacing:0.5px !important;
  color:var(--color-gray-600) !important;
  background:var(--color-white) !important;
  padding:var(--spacing-xs) var(--spacing-xl) !important;
  border-radius: 0 !important;
  display:inline-flex !important;
  align-items:center !important;
  justify-content:center !important;
  border:1px solid var(--color-gray-200) !important;
  box-shadow: none !important;
  margin:0 auto !important;
}

.reservations.landing [id$="hlnkSignIn"] {
  color:var(--color-primary) !important;
  font-weight:600 !important;
  text-transform:uppercase !important;
  font-size:var(--font-size-xs) !important;
  letter-spacing:1px !important;
  text-decoration:none !important;
  margin-left:var(--spacing-2xs) !important;
  border-bottom:1px solid transparent !important;
  transition:all 0.2s ease !important;
}

.reservations.landing [id$="hlnkSignIn"]:hover {
  border-bottom-color:var(--color-primary) !important;
  color:var(--color-primary-dark) !important;
}

.reservations.landing .uc.oPText {
  text-align:center !important;
  max-width:680px !important;
  margin:0 auto 64px !important;
  position:relative !important;
}

.reservations.landing .uc.oPText p {
  font-family:var(--font-body) !important;
  font-size:var(--font-size-base) !important;
  line-height:1.8 !important;
  color:var(--color-gray-500) !important;
  margin:0 !important;
}

.reservations.landing .uc.oPText p b {
  font-family:var(--font-display) !important;
  font-size:var(--font-size-xl) !important;
  font-weight:400 !important;
  color:var(--color-text-dark) !important;
  display:block !important;
  margin-bottom:var(--spacing-sm) !important;
  letter-spacing:-0.5px !important;
}

/* Location Cards */
.reservations.landing .locations .row {
  background:var(--color-white) !important;
  border:1px solid var(--color-gray-200) !important;
  border-radius: 0 !important;
  box-shadow: none !important;
  overflow:hidden !important;
  margin-bottom:var(--spacing-3xl) !important;
  transition:all 0.6s cubic-bezier(0.16, 1, 0.3, 1) !important;
  opacity:0;
  animation:locationFadeInUp 0.8s cubic-bezier(0.16, 1, 0.3, 1) forwards;
  position:relative !important;
}

.reservations.landing .locations .row:hover {
  transform: translateY(-8px) !important;
  box-shadow: none !important;
  border-color:var(--color-gray-300) !important;
}

.reservations.landing .locations .row:nth-child(1) { animation-delay: 0.1s; }

.reservations.landing .locations .row:nth-child(2) { animation-delay: 0.25s; }

.reservations.landing .locations .row:nth-child(3) { animation-delay: 0.4s; }

@media (min-width: 1251px) {
  .reservations.landing .locations .row {
      display: flex !important;
      flex-direction:row !important;
      align-items:stretch !important;
    }
  .reservations.landing .locations .col-a {
      flex:0 0 41.666667% !important;
      max-width:41.666667% !important;
      display:flex !important;
      align-items:stretch !important;
      overflow:hidden !important;
    }
  .reservations.landing .locations .col-b {
      flex:0 0 58.333333% !important;
      max-width:58.333333% !important;
      display:flex !important;
      flex-direction:column !important;
      justify-content:center !important;
      padding:var(--spacing-3xl) var(--spacing-4xl) !important;
    }
  .reservations.landing .locations .location-link {
      width:100% !important;
      height:100% !important;
      display:block !important;
    }
}

/* Left Column (Image Wrapper & Fallback Backdrop) */
.reservations.landing .locations .col-a {
  position:relative !important;
  overflow:hidden !important;
  background:linear-gradient(135deg, var(--color-accent) 0%, #0D1D19 100%) !important;
}

.reservations.landing .locations .col-a::after {
  content: "" !important;
  position:absolute !important;
  top:0; left:0; right:0; bottom:0 !important;
  background-image:url("/Upload/YonahMountainVineyards/Images/logo.svg") !important;
  background-repeat:no-repeat !important;
  background-position:center !important;
  background-size:35% !important;
  opacity:0.12 !important;
  transition:transform 0.6s cubic-bezier(0.16, 1, 0.3, 1), opacity 0.6s ease !important;
  pointer-events:none !important;
}

.reservations.landing .locations .row:hover .col-a::after {
  transform: scale(1.1) !important;
  opacity:0.22 !important;
}

.reservations.landing .locations .row .img {
  width:100% !important;
  height:100% !important;
  object-fit:cover !important;
  object-position:center !important;
  transition:transform 0.8s cubic-bezier(0.16, 1, 0.3, 1), filter 0.6s ease !important;
  filter:brightness(0.95) contrast(1.02) !important;
}

.reservations.landing .locations .row:hover .img {
  transform: scale(1.06) !important;
  filter:brightness(1) contrast(1) !important;
}

/* Hide fallback unstyled missing-image placeholder */
.reservations.landing .locations .row img[src*="image-not-available"],
.reservations.landing .locations .row img[src=""] {
  opacity:0 !important;
}

/* Right Column Content styling */
.reservations.landing .locations .location-name::before {
  content: "Estate Experience" !important;
  display:block !important;
  font-family:var(--font-body) !important;
  font-size:var(--font-size-2xs) !important;
  font-weight:600 !important;
  letter-spacing:2.5px !important;
  text-transform:uppercase !important;
  color:var(--color-primary-dark) !important;
  margin-bottom:var(--spacing-xs) !important;
}

.reservations.landing .locations .location-name {
  font-family:var(--font-display) !important;
  font-size:var(--font-size-xl) !important;
  font-weight:400 !important;
  color:var(--color-text-dark) !important;
  padding-bottom:var(--spacing-lg) !important;
  border-bottom:1px solid var(--color-gray-200) !important;
  margin-bottom:var(--spacing-lg) !important;
  text-transform:none !important;
  letter-spacing:-0.5px !important;
  line-height:1.2 !important;
}

.reservations.landing .locations .description {
  font-family:var(--font-body) !important;
  font-size:var(--font-size-base) !important;
  line-height:1.8 !important;
  color:var(--color-gray-500) !important;
  margin-bottom:var(--spacing-xl) !important;
}

/* Fallback description when CMS provides empty strings */
.reservations.landing .locations .description:empty::before {
  content: "Join us for an exclusive, curated tasting of our award-winning estate wines. Nestled in the foothills of the Appalachian Mountains, our tasting room offers breathtaking views and unmatched hospitality." !important;
  display:block !important;
  font-style:normal !important;
  font-weight:300 !important;
  color:var(--color-gray-500) !important;
}

/* Reserve / Book Button */
.reservations.landing .locations .btn {
  display:inline-block !important;
  width:fit-content !important;
  background-color:var(--color-primary-dark) !important;
  color:var(--color-white) !important;
  border:1px solid var(--color-primary-dark) !important;
  border-radius: 0 !important;
  padding:var(--spacing-sm) var(--spacing-2xl) !important;
  font-family:var(--font-body) !important;
  font-size:var(--font-size-xs) !important;
  font-weight:600 !important;
  text-transform:uppercase !important;
  letter-spacing:2px !important;
  text-decoration:none !important;
  transition:all 0.4s cubic-bezier(0.16, 1, 0.3, 1) !important;
  margin-top:auto !important;
  box-shadow: none !important;
}

.reservations.landing .locations .btn::after {
  content: " \2192" !important;
  display:inline-block !important;
  margin-left:var(--spacing-2xs) !important;
  transition:transform 0.3s cubic-bezier(0.16, 1, 0.3, 1) !important;
}

.reservations.landing .locations .btn:hover {
  background: var(--color-white) !important;
  color: var(--color-primary-dark) !important;
  border: 1px solid var(--color-primary-dark) !important;
  transform:translateY(-3px) !important;
  box-shadow: none !important;
}

.reservations.landing .locations .btn:hover::after {
  transform: translateX(6px) !important;
}

/* Mobile Breakpoints override */
@media (max-width: 1250px) {
  .reservations.landing {
      padding: 40px 16px !important;
    }
  .reservations.landing .locations .row {
      margin-bottom:var(--spacing-xl) !important;
      border-radius: 0 !important;
    }
  .reservations.landing .locations .col-a {
      height:240px !important;
      width:100% !important;
    }
  .reservations.landing .locations .col-b {
      padding:var(--spacing-xl) var(--spacing-lg) !important;
      width:100% !important;
    }
  .reservations.landing .locations .location-name {
      font-size:26px !important;
      padding-bottom:var(--spacing-sm) !important;
      margin-bottom:var(--spacing-sm) !important;
    }
  .reservations.landing .locations .description {
      font-size:var(--font-size-sm) !important;
      margin-bottom:var(--spacing-lg) !important;
    }
  .reservations.landing .locations .btn {
      width:100% !important;
      text-align:center !important;
      box-sizing:border-box !important;
    }
}

/* ==========================================================================
   SECTION 12: CHECKOUT, BASKET & SYSTEM POPUPS
   ========================================================================== */

#jqpopupContainer.popup-body {
  padding-top:0;
}

.addr-popup {
  overflow:hidden;
}

.ui-dialog .ui-dialog-titlebar-close {
  outline:none;
}

.basket_table .item .col-2 a,
.order_details .item .col-2 a {
  font-size:var(--font-size-sm);
}

.uc.paymentOptions {
  overflow:hidden;
}

.secure-shopping,
.popup div.secure-shopping {
  width:50%;
  float:right;
  padding-left:var(--spacing-xs);
  padding-top:var(--spacing-md);
}

.popup div.secure-shopping {
  width:50% !important;
}

.paymentOptions .paymentOptions_table,
.popup .paymentOptions .paymentOptions_table {
  width:50% !important;
  float:left;
  padding-right:var(--spacing-xs);
}

.paymentOptions_row,
.fieldset_row {
  width:100%;
  margin:0 0 var(--spacing-2xs);
}

.paymentOptions_box {
  float:left;
  width:50%;
  padding-right:var(--spacing-xs);
}

.safe-secure-btm {
  overflow:hidden;
  margin:0 0 var(--spacing-xs);
}

.safe-secure-btm .floatLeft {
  float:left;
}

.bootstrapWizard li .title {
  font-size:var(--font-size-md);
}

.ciRegularView .col, .details_header>div,.details .item>div,.order_details .item>div, .checkout-header .col, .change-password .col {
  display:table-cell;
  vertical-align:top;
}

.ciRegularView .col:first-child {
  width: 90px;
}

.details_header > div {
  font-weight:bold;
}

.details .col-1 {
  width:15%;
}

.details .col-2, .details .col-3 {
  width:10%;
  text-align:center;
}

.details .col-4 {
  width:35%;
}

.details .col-5 {
  width:15%;
}

.details .col-6, .order_details .col-5, .basket_table .col-5 {
  width:15%;
  text-align:right;
}

.details .footer {
  border-top:1px solid var(--color-border);
  padding:var(--spacing-xs) 0 0;
  text-align:right;
}

.details .productVersion {
  white-space:normal;
}

.details .mobile-label,.order_details .mobile-label,.basket_table .mobile-label, .popup .addr-popup .addr-table>div .col .mobile-label {
  display:none;
  font-weight:bold;
}

.order_details .col-1 {
  width:10%;
}

.order_details .col-2 {
  width:30%;
}

.order_details .col-3 {
  width:30%;
}

.order_details .col-4 {
  width:15%;
}

.order_details .footer {
  display:table;
  width:100%;
  padding:var(--spacing-xs) 0;
  border-top:1px solid var(--color-border);
}

.order_details .footer .col:first-child {
  text-align: left;
}

.order_details .footer .col {
  text-align:right;
  display:table-cell;
}

.order_details .footer .col-center {
  text-align:center;
  font-size:var(--font-size-xs);
}

.order_details .col-3 .txt,
.order_details .text_apply {
  float:left;
}

.order_details .col-3 .txt {
  margin-right:var(--spacing-2xs);
}

.edit-addr .col:first-child {
  width: 130px;
}

.edit-addr .select_box {
  padding-bottom:0;
}

.edit-addr .row .btn {
  margin:0 var(--spacing-3xs);
}

.help_content {
  width:80%;
}

.help_holder > div {
  width:100% !important;
}

/***** CHECKOUT *****/
.checkout-header .error {
  margin:0 0 var(--spacing-xs);
}

#checkout .left-box-head {
  width:175px;
  padding:0 0 var(--spacing-md) var(--spacing-lg);
  vertical-align:bottom;
}

.checkout-section, .details.cof>div:first-child {
  display: table;
  width:100%;
  margin:0 0 var(--spacing-md);
}

.checkout-top-box {
  border:1px solid var(--color-border);
  display:table-cell;
  vertical-align:top;
}

.checkout-top-box.summary {
  width:200px;
}

.checkout-section .divider {
  width:25px;
  display:table-cell;
}

.addr-table {
  width:100%;
  overflow:hidden;
  padding-bottom:var(--spacing-xl);
}

.addr-table .column {
  float:left;
  width:50%;
  margin:0 0 var(--spacing-xs);
  padding:0 0 0 var(--spacing-xs);
}

.addr-table .column:first-child {
  padding: 0 10px 0 0;
}

.promo-content {
  overflow:hidden;
  margin:0 0 var(--spacing-md);
}

.promo-content .col-left {
  float:left;
  width:60%;
}

.promo-content .col-right {
  float:right;
}

.promo-content .txt {
  max-width:300px;
  display:inline-block;
}

.promo-content .label {
  display:inline-block;
  margin-right:var(--spacing-2xs);
}

#checkout .bottom-section .btns {
  width:100%;
  margin:0 0 var(--spacing-xs);
}

#checkout .bottom-section .btn-right {
  float:right;
}

/***** BASKET *****/
.basket_table .item,
.basket_table .footer {
  border-bottom:1px solid var(--color-border);
}

.basket_table .cart-header > div,
.basket_table .item > div,
.basket_table .footer > div {
  display:table-cell;
  vertical-align:top;
  padding-bottom:var(--spacing-xs);
}

.basket_table .cart-header > div {
  font-weight:bold;
}

.basket_table .col-center {
  text-align:center;
}

.basket_table .col-center h2 {
  font-weight:bold;
}

.basket_table .col-1 {
  width:10%;
}

.basket_table .col-2 {
  width:45%;
}

.basket_table .col-3 {
  width:15%;
}

.basket_table .col-4 {
  width:15%;
}

.basket_table .footer .col-1 {
  width:70%;
}

.basket_table .footer .col-2,
.basket_table .footer .col-3 {
  width:15%;
}

.basket_table .footer .col-3 {
  text-align:right;
}

.basket_table .footer_2 {
  padding:var(--spacing-xs) 0;
}

.basket_table .btn-print {
  float:right;
}

.details.cof > div:first-child > div {
  display: table-cell;
  width:15% !important;
}

.details.cof > div:first-child > div:first-child {
  width: 45% !important;
}

.details.cof > div:first-child > div:last-child {
  width: 25% !important;
}

.details.cof .btn {
  margin-top:var(--spacing-md);
}

.details.cof .item > div {
  width:15%;
}

.details.cof .item > div:first-child {
  width: 45%;
}

.details.cof .item > div:last-child {
  width: 25%;
}

.details.cof .wccc,
.details.cof .wccc:hover {
  padding: 10px !important;
}

/***** POPUPS *****/
.ui-dialog {
  border:solid 1px var(--color-border) !important;
  border-radius:0 !important;
  padding:var(--spacing-xs);
  background:var(--color-white);
}

.ui-dialog .ui-dialog-title {
  margin:0;
  font:bold var(--font-size-sm)/var(--font-size-md) var(--font-body);
  color:var(--color-white);
}

.popup h2 {
  margin:0 0 var(--spacing-2xs);
}

.popup p {
  margin:0 0 var(--spacing-2xs);
}

.addr-popup .btn-row {
  margin:0 0 var(--spacing-sm);
}

.popup .addr-popup .addr-table > div .col {
  font-size:var(--font-size-sm);
  border-left:1px solid var(--color-border);
}

.default-ship {
  display:flex;
  flex-wrap:wrap;
  width:100%;
  margin:0 0 var(--spacing-md);
  background-color:var(--color-border);
}

.checkout-top-box.summary .btn {
  padding:var(--spacing-xs);
}

.popup .addr-popup .addr-table > div .col {
  padding:var(--spacing-xs);
}

.popup .addr-popup .addr-table > div {
  display:flex;
  width:100%;
  flex-wrap:wrap;
}

.popup .addr-popup .addr-table > div .col:last-child .btn {
  margin: 5px auto;
}

.popup .addr-popup .addr-table > div .col,
.default-ship .col {
  width:30%;
  display:table-cell;
  vertical-align:top;
  padding:var(--spacing-xs);
}

.popup .addr-popup .addr-table > div .selection,
.default-ship .col .selection {
  display:flex;
  padding:0 0 0 var(--spacing-2xs);
  border-left:0;
  width:5% !important;
  margin:auto 0;
}

.popup .addr-popup .addr-table > div .col:last-child,
.default-ship .col:last-child {
  display: flex;
  vertical-align:middle;
  text-align:center;
  flex-direction:column;
  justify-content:center;
  width:25%;
  flex-grow:1;
}

.addr-popup .divRowHeader .headerCellContact {
  padding-left:21%;
}

.addr-popup .divRowHeader .headerCellAddress {
  padding-left:3%;
}

.popup .addr-popup .addr-table > div .col:first-child {
  border-left: none;
}

body.popup {
  min-width:0;
  width:100%;
  height:100%;
  background:var(--color-white);
}

.ui-dialog .ui-dialog-titlebar-close {
  background:var(--color-border);
}

.addr-popup .divRowHeader .headerCellContact {
  padding-left:17%;
}

.addr-popup .divRowHeader .headerCellAddress {
  padding-left:7%;
}

@media only screen and (max-width: 1250px) {
  .popup .addr-popup .addr-table > div {
      display:flex;
      width:100%;
      flex-wrap:wrap;
      margin-bottom:var(--spacing-xs);
    }
  .addr-popup .divRowHeader div:nth-child(2) {
      padding-left: 17%;
    }
  .popup div.secure-shopping, .paymentOptions .paymentOptions_table,.popup .paymentOptions .paymentOptions_table {
    float:none;
    width:100% !important;
    padding:0;
  }
  .secure-shopping {
      width:100%;
      padding:0;
    }
  .promo-content .col-left,
    .promo-content .col-right {
      float:none;
      width:100%;
    }
}

@media only screen and (max-width:639px) {
  .popup form[action="/WineryShippingRestricted.aspx"] {
      line-height:1 !important;
    }
  .paymentOptions_box {
      float:none;
      width:100%;
      padding:0 0 var(--spacing-2xs);
    }
  .paymentOptions_row {
      margin:0;
    }
  .help_aside {
      width:100%;
      margin:0;
    }
  .help_holder {
      margin:0 0 var(--spacing-md);
    }
  .details_header {
      display:none;
    }
  .details .item > div,
    .order_details .item > div,
    .basket_table .item > div,
    .basket_table .footer > div {
      display:inline-block;
      margin:0 -var(--spacing-3xs) var(--spacing-xs) 0;
    }
  .details .mobile-label,
    .order_details .mobile-label,
    .basket_table .mobile-label {
      display:block;
      margin:0 0 var(--spacing-xs);
    }
  .details .item {
      border-bottom:1px solid var(--color-border);
    }
  .details .col-1 {
      width:20%;
    }
  .details .col-2 {
      width:15%;
    }
  .details .col-3 {
      width:15%;
    }
  .details .col-4 {
      width:50%;
    }
  .details .col-5,
    .details .col-6 {
      width:50%;
      border-top:1px solid var(--color-border);
      padding-top:var(--spacing-xs);
    }
  .details .footer {
      padding:0;
      border-top:0;
    }
  .order_details .col-1 {
      width:20%;
    }
  .order_details .col-2 {
      width:80%;
    }
  .order_details .col-3 {
      width:100%;
    }
  .order_details .col-4,
    .order_details .col-5 {
      width:50%;
      border:solid var(--color-border);
      border-width:1px 0;
      padding:var(--spacing-xs) 0;
    }
  .basket_table .cart-header {
      display:none;
    }
  .basket_table .item {
      border-bottom:1px solid var(--color-border);
    }
  .basket_table .col-1 {
      width:20%;
    }
  .basket_table .col-2 {
      width:80%;
    }
  .basket_table .col-3 {
      width:50%;
    }
  .basket_table .col-4, .basket_table .footer .col-2 {
    width:50%;
    text-align:right;
  }
  .basket_table .col-5, .basket_table .footer .col-3 {
    width:100%;
    text-align:center;
  }
  .basket_table .footer .col-1 {
      width:50%;
    }
  .basket_table .footer_2 {
      text-align:center;
    }
  .basket_table .footer_2 .btn {
      margin:0 0 var(--spacing-xs);
    }
  .basket_table .btn-print {
      float:none;
    }
  .promo-content .txt {
      margin:0 0 var(--spacing-xs);
    }
  .promo-content .label {
      display:block;
    }
  .checkout-top-box {
      display:block;
    }
  .checkout-top-box:first-child {
      margin-bottom: var(--spacing-md);
    }
  .checkout-section .divider {
      display:none;
    }
  .checkout-header .col {
      display:block;
    }
  .ui-dialog {
      width:300px !important;
    }
  .popup form[action="/WineryShippingRestricted.aspx"] {
      line-height:1 !important;
    }
}

@media only screen and (max-width:569px) {
  .ui-dialog .ui-dialog-title {
      font-size: var(--font-size-md);
      line-height:20px;
    }
  .default-ship {
      border:1px solid var(--color-border);
    }
  .default-ship .col {
      display:block;
      border-top:1px solid var(--color-border);
      border-left:0;
    }
  .default-ship .col:first-child {
      border: 0;
    }
}

@media only screen and (max-width:479px) {
  .popup .addr-popup .addr-table > div .col {
      padding:var(--spacing-xs);
      width:100%;
    }
  .safe-secure-btm .floatLeft {
      float:none;
      margin:0 0 var(--spacing-xs);
    }
  .safe-secure-btm .floatRight {
      float:none;
      text-align:center;
    }
  .ciRegularView .col:first-child {
      width: 100%;
    }
  .details .col-1 {
      width:40%;
    }
  .details .col-2,
    .details .col-3 {
      width:30%;
    }
  .details .col-4 {
      width:100%;
      display:table-header-group !important;
    }
  .details .col-4 .holder {
      border-bottom:1px solid var(--color-border);
      padding-bottom:var(--spacing-xs);
      margin-bottom:var(--spacing-xs);
    }
  .details .col-4 .mobile-label {
      display:none;
    }
  .edit-addr .col:first-child {
      width: 100%;
    }
  .edit-addr .col {
      display:block;
    }
  #checkout .bottom-section .btns {
      text-align:center;
    }
  #checkout .bottom-section .btn-right {
      float:none;
      padding-top:var(--spacing-xs);
    }
  /***** #divInProgress *****/
  body #divInProgress {
      width:280px !important;
      background:var(--color-gray-900) !important;
      -webkit-box-shadow: none;
      box-shadow: none;
      padding:var(--spacing-xs);
      border-radius: 0;
    }
  .details.cof > div:first-child {
      display: none;
    }
  .details.cof .item > div {
      width:100% !important;
    }
  .details.cof .item > div:last-child {
      text-align: left !important;
    }
}

.popup h1,
.popup h2,
.popup h3,
.popup h4,
.popup h5,
.popup h6 {
  color:var(--color-text);
}
/* ==========================================================================
   SECTION 13: HEADER & NAVIGATION (GROUPED AT BOTTOM)
   ========================================================================== */

#headerContainer, #cat-v1-1 {
  width: 100%;
  position: relative;
}

.header-wrapper {
  background: rgb(82, 47, 25) !important;
  position: relative;
  z-index: 100;
  box-shadow: none;
  border-bottom: none;
}

/* Ensure the entire header uses 16px "Work Sans" */
.header-wrapper,
.header-wrapper a,
.header-wrapper button,
.header-wrapper div,
.header-wrapper span,
.header-wrapper li,
#authStatus,
#authStatus a,
#authStatus div,
#authStatus span {
  font-family: "Work Sans", sans-serif !important;
  font-size: 18px !important; /* 25% smaller than 24px */
}

/* Auth & Cart Bar */
.auth-wrapper {
  display: block;
  background: var(--color-primary-dark);
  border-bottom: 1px solid rgba(255, 255, 255, 0.2);
  padding: 8px 0;
}

.auth-wrapper .ord-container {
  max-width: var(--container-max-width);
  margin: 0 auto;
  padding: 0 20px;
  box-sizing: border-box;
}

#authStatus {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: 12px;
  font-size: var(--font-size-sm);
  font-family: var(--font-body);
  color: #ffffff;
}

/* Reset any page-level absolute positioning when inside the auth bar */
.auth-wrapper #authStatus {
  position: static !important;
  top: auto !important;
  left: auto !important;
  right: auto !important;
  width: auto !important;
  background: transparent !important;
  padding: 0 !important;
  z-index: auto !important;
}

/* Cart and view-cart span: inline flex so basket + checkout sit side by side */
#authStatus #updViewCart {
  display: inline-flex;
  align-items: center;
  gap: 8px;
}

/* All links inside the auth bar */
#authStatus a,
#authStatus .basket,
#authStatus .btn-signin-top {
  color: #ffffff;
  text-decoration: none;
  font-weight: 500;
  transition: opacity 0.2s ease;
}

#authStatus a:hover,
#authStatus .basket:hover,
#authStatus .btn-signin-top:hover {
  opacity: 0.75;
}

/* The checkout link inherits .btn styles — override to look like a plain link in the auth bar */
#authStatus .btn.checkout {
  display: inline;
  background: none !important;
  border: none !important;
  padding: 0 !important;
  color: #ffffff !important;
  font-size: inherit;
  font-weight: 500;
  text-decoration: none;
}

#authStatus .btn.checkout:hover {
  background: none !important;
  color: rgba(255, 255, 255, 0.75) !important;
}

#authStatus .splitter,
#authStatus .theme-color {
  color: rgba(255, 255, 255, 0.6);
}

/* Header Main Navigation */
.header-main {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 18.4px 46px;
  background: transparent;
  max-width: 1320px;
  margin: 0 auto;
  width: 100%;
  box-sizing: border-box;
}

/* Logo Wrap - Center Logo Container */
.logo-wrap {
  display: flex;
  align-items: center;
  justify-content: flex-start;
  flex: 0 0 auto;
  order: 0;
  margin-right: 20px; /* Proper margin to prevent bleeding when compacted */
}

.logo {
  flex: 0 0 auto;
  display: flex;
  align-items: center;
}

.logo a {
  display: flex;
  align-items: center;
  text-decoration: none;
  transition: transform 0.3s ease;
}

.logo a:hover {
  transform: scale(1.08);
}

.logo img {
  max-height: 48px; /* Restored to original size (1.25x smaller than 60px) */
  width: auto;
  display: block;
}

.header-actions {
  flex: 0 0 auto;
  display: flex;
  align-items: center;
  justify-content: flex-end;
  order: 2;
  gap: 20px;
}

.btn-menu-wrap {
  flex: 0 0 auto;
  display: flex;
  justify-content: flex-end;
}

/* CTA Button */
.header-actions-action--cta .btn {
  padding: 12.8px 21.376px;
  background-color: rgb(255, 255, 255);
  color: rgb(82, 47, 25);
  font-family: var(--font-body);
  font-size: 22px; /* Increased header font size */
  font-weight: 700;
  border: 0px solid rgb(82, 47, 25);
  text-transform: none;
  letter-spacing: normal;
}
.header-actions-action--cta .btn:hover {
  background-color: rgb(82, 47, 25);
  color: #fff;
}

/* Main Menu Styling */
.main-menu {
  display: flex;
  flex-direction: row;
  flex-wrap: wrap; /* Wrap menu items when compacted */
  list-style: none;
  padding: 0;
  margin: 0;
  gap: 10px 18.4px; /* Row gap 10px, column gap 18.4px */
  align-items: center;
}

.main-menu li {
  position: relative;
  list-style: none;
}

.main-menu a {
  display: block;
  padding: 2px 0;
  text-decoration: none;
  color: #ffffff;
  font-size: 21px; /* Decreased menu font size by 1px */
  font-family: "Work Sans", sans-serif;
  font-weight: 500;
  text-transform: none;
  letter-spacing: normal;
  transition: all 0.3s ease;
  border-radius: 0;
  white-space: nowrap;
}

.main-menu a:hover {
  color: #ffffff; /* Keep original color on hover */
  background: transparent;
  text-shadow: none;
}

/* Wines Link with Dropdown Button */
.main-menu li.has-child a {
  display: flex;
  align-items: center;
  gap: 8px;
}

.btn-toggle-sub-menu {
  display: none !important;
}

.btn-toggle-sub-menu svg {
  width: 100%;
  height: 100%;
  stroke: currentColor;
}

.main-menu li.has-child:hover .btn-toggle-sub-menu,
.main-menu li.has-child.open .btn-toggle-sub-menu {
  transform: rotate(180deg);
  color: #ffd700;
}

/* Submenu Dropdown */
.sub-menu {
  position: absolute;
  top: 100%;
  left: 0;
  display: none;
  flex-direction: column;
  background: rgb(82, 47, 25);
  border: none;
  box-shadow: none;
  z-index: 1000;
  min-width: 180px;
  list-style: none;
  padding: 12px 0;
  margin: 0;
  border-radius: 0;
  margin-top: 0px;
}

.main-menu li:hover > .sub-menu,
.main-menu li.open > .sub-menu {
  display: flex;
}

.sub-menu li {
  list-style: none;
  border: none;
}

.sub-menu a {
  display: block;
  padding: 5px 20px; /* Reduced vertical spacing from 10px to 5px */
  font-size: 18px; /* 25% smaller than 24px */
  text-transform: none;
  letter-spacing: normal;
  color: #fff;
  transition: all 0.3s ease;
}

.sub-menu a:hover {
  background: transparent; /* No hover highlight or effect */
  color: #fff;
}

/* Main Menu Positioning */
.main-menu-right {
  order: 1;
  flex: 1 1 auto;
  justify-content: flex-end;
  margin-right: 5px;
}

/* Burger Menu Button */
.mobile-toggle,
.burger {
  background: none;
  border: 2px solid #ffffff;
  cursor: pointer;
  padding: 8px;
  display: none;
  z-index: 1041;
  transition: all 0.3s ease;
  border-radius: 0;
  color: #ffffff;
}

.mobile-toggle:hover,
.burger:hover {
  background: rgba(255, 255, 255, 0.15);
  box-shadow: none;
}

.burger-box {
  position: relative;
  display: flex;
  justify-content: center;
  align-items: center;
  width: 28px;
  height: 24px;
}

.burger-inner {
  position: relative;
  width: 24px;
  height: 18px;
}

.burger-inner .line {
  position: absolute;
  display: block;
  left: 0;
  width: 100%;
  height: 2px;
  background-color: #ffffff;
  transition: all 250ms cubic-bezier(0.2, 0.6, 0.3, 1);
  will-change: transform, opacity;
}

.burger-inner .top-bun {
  top: 0;
}

.burger-inner .patty {
  top: 50%;
  transform: translateY(-50%);
}

.burger-inner .bottom-bun {
  bottom: 0;
}

.burger.open .burger-inner .top-bun {
  transform: translateY(8px) rotate(45deg);
}

.burger.open .burger-inner .patty {
  opacity: 0;
}

.burger.open .burger-inner .bottom-bun {
  transform: translateY(-8px) rotate(-45deg);
}

/* ── MOBILE NAVIGATION DRAWER (slides from right) ──────────────────── */
.mobile-navigation {
  z-index: 1041;
  background-color: var(--color-primary-dark);
  flex-direction: column;
  width: 100%;
  height: 100vh;
  transition: transform .35s cubic-bezier(.2, .6, .3, 1);
  display: flex;
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  overflow-y: auto;
  transform: translateX(100%);
}

body.open .mobile-navigation {
  transform: translateX(0);
}

/* Logo section */
.nav-log {
  text-align: center;
  border-bottom: 1px solid rgba(255, 255, 255, 0.1);
  padding: 20px 24px 20px;
}

.nav-log a {
  display: inline-block;
}

.nav-log img {
  max-width: 200px;
  height: auto;
  filter: brightness(0) invert(1);
}

/* Account / Cart quick bar */
.nav-top {
  border-bottom: 1px solid rgba(255, 255, 255, 0.1);
  justify-content: center;
  align-items: center;
  padding: 14px 24px;
  display: flex;
}

.mobile-navigation .mobile-shop-nav a {
  color: #ffffff;
  font-weight: 600;
}

.mobile-navigation .mobile-shop-nav a:hover {
  opacity: 0.7;
  color: #ffffff;
}

.mobile-navigation .mobile-shop-nav .nav-divider {
  color: rgba(255, 255, 255, 0.3);
}

/* Main menu list — white background with dark text */
.mobile-navigation .main-menu {
  flex-direction: column;
  flex: 1;
  align-items: stretch;
  gap: 0;
  padding: 0;
  margin: 0;
  list-style: none;
  background: var(--color-white);
}

.mobile-navigation .main-menu > li {
  border-bottom: 1px solid var(--color-gray-100);
}

.mobile-navigation .main-menu > li > a {
  font-family: var(--font-body);
  text-transform: uppercase;
  letter-spacing: 1px;
  color: var(--color-text-dark);
  padding: 18px 28px;
  font-size: var(--font-size-sm);
  font-weight: 600;
  text-decoration: none;
  transition: color 0.15s, background 0.15s;
  display: flex;
  align-items: center;
  justify-content: space-between;
}

.mobile-navigation .main-menu > li > a:hover {
  color: var(--color-primary-dark);
  background: var(--color-gray-50);
}

/* Chevron for items with children */
.mobile-navigation .main-menu li.menu-item-with-children > a::after {
  content: "";
  display: inline-block;
  width: 10px;
  height: 10px;
  border-right: 2px solid currentColor;
  border-bottom: 2px solid currentColor;
  transform: rotate(-45deg);
  transition: transform 0.25s ease;
  margin-left: auto;
  flex-shrink: 0;
  opacity: 0.5;
}

.mobile-navigation .main-menu li.menu-item-with-children.expanded > a::after {
  transform: rotate(45deg);
  opacity: 1;
}

/* Sub-menus — collapsed until .expanded */
.mobile-navigation .main-menu li.menu-item-with-children > ul {
  display: none;
  list-style: none;
  padding: 0;
  margin: 0;
  background: var(--color-gray-50);
  border-top: 1px solid var(--color-gray-100);
}

.mobile-navigation .main-menu li.menu-item-with-children.expanded > ul {
  display: block;
}

.mobile-navigation .main-menu li.menu-item-with-children ul li {
  border: none;
}

.mobile-navigation .main-menu li.menu-item-with-children ul li a {
  display: block;
  padding: 11px 28px 11px 44px;
  color: var(--color-text);
  font-size: var(--font-size-xs);
  font-weight: 400;
  text-decoration: none;
  text-transform: none;
  letter-spacing: normal;
  transition: color 0.15s, padding-left 0.15s;
}

.mobile-navigation .main-menu li.menu-item-with-children ul li a:hover {
  color: var(--color-primary-dark);
  padding-left: 52px;
}

/* Overlay */
.ord-overlay {
  z-index: 1000;
  opacity: 0;
  background: rgba(0, 0, 0, 0.5);
  transition: opacity .3s;
  display: none;
  position: fixed;
  inset: 0;
}

body.open .ord-overlay {
  opacity: 1;
  display: block;
}

/* ========================================
   HEADER RESPONSIVE DESIGN
   ======================================== */

@media only screen and (max-width: 1250px) {
  .header-main {
    display: flex !important;
    flex-direction: row !important;
    flex-wrap: nowrap !important;
    padding: 15px 20px !important;
    justify-content: space-between !important;
    align-items: center !important;
    gap: 15px !important;
  }

  .logo-wrap {
    display: flex !important;
    align-items: center !important;
    justify-content: flex-start !important;
    flex: 0 0 auto !important;
    width: auto !important;
    order: unset !important;
  }

  .logo {
    flex: 0 0 auto;
  }

  .header-actions {
    display: flex !important;
    align-items: center !important;
    justify-content: flex-end !important;
    flex: 0 0 auto !important;
    margin-left: auto !important;
  }

  .header-actions-action--cta {
    display: none !important;
  }

  .main-menu-1,
  .main-menu-2,
  .header-main .main-menu-right {
    display: none !important;
  }

  .mobile-toggle,
  .burger {
    display: flex;
  }

  body.open {
    overflow: hidden;
  }
}

@media only screen and (min-width: 1251px) {
  .header-main {
    display: grid;
    grid-template-columns: auto 1fr auto;
    align-items: center;
    padding: 25px 20px;
    gap: 10px; /* Reduced gap from 40px to 24px to bring navigation closer to CTA button */
  }

  .main-menu-1,
  .main-menu-2,
  .main-menu-right {
    display: flex;
    justify-content: flex-end !important; /* Align navigation items to the right */
  }

  .burger,
  .mobile-toggle,
  .mobile-navigation {
    display: none !important;
  }

  .main-menu-1 {
    justify-content: flex-end;
  }

  .main-menu-2 {
    justify-content: flex-start;
  }

  .logo-wrap {
    display: flex;
    align-items: center;
    justify-content: flex-start;
  }

  .header-empty {
    display: none;
  }

  .logo {
    flex: 0 0 auto;
  }

  .btn-menu-wrap {
    display: none;
  }
}


/* ==========================================================================
   SECTION 14: FOOTER STYLES (GROUPED AT BOTTOM)
   ========================================================================== */

#footer {
  flex: 0 0 0px;
}

/* Hide the sustainability section from the page */
[data-section-id="64eb8a303d2fc621d4b65f6b"]:not(#footer-tear-divider),
section[data-section-id="64eb8a303d2fc621d4b65f6b"]:not(#footer-tear-divider) {
  display: none !important;
  height: 0 !important;
  min-height: 0 !important;
  padding: 0 !important;
  margin: 0 !important;
  overflow: hidden !important;
  visibility: hidden !important;
}

/* Force parent footer wrappers to span the full window width */
body #footer,
body #footerContainer,
body .footer {
  max-width: 100% !important;
  width: 100% !important;
  padding: 0 !important;
  margin: 0 !important;
}
#page-divider {
  margin: 0 !important;
  margin-bottom: -3px !important;
  display: block !important;
  position: relative !important;
  z-index: 10 !important;
  width: 100vw !important;
  max-width: 100vw !important;
  left: 50% !important;
  right: 50% !important;
  margin-left: -50vw !important;
  margin-right: -50vw !important;
  height: auto !important;
  transform: scaleY(0.75) !important; /* Scale height only by 75% */
  transform-origin: bottom !important; /* Keep base aligned with footer background */
}

/* SVG Page Tear Divider Colors */
.page-divider__bg {
  fill: #eae7e1 !important; /* Matches footer background to eliminate visual gap */
  fill-opacity: 1 !important;
}

.page-divider__zigzag {
  fill: #eae7e1 !important; /* Grey fill color */
  fill-opacity: 1 !important;
  stroke: var(--color-primary-dark) !important; /* Brown stroke */
  stroke-width: 3px !important; 
  stroke-linecap: square;
  stroke-miterlimit: 0;
  stroke-linejoin: miter;
}

#social-icons-svg-defs {
  display: none !important;
}

/* Main Footer Container */
#footer-sections {
  position: relative !important;
  width: 100vw !important; /* Break out to full viewport width */
  left: 50% !important;
  right: 50% !important;
  margin-top: auto !important; /* Pushes footer to the bottom of the flex page wrapper */
  margin-left: -50vw !important;
  margin-right: -50vw !important;
  background-color: #eae7e1 !important; /* Beige background */
  color: var(--color-primary-dark) !important; /* Dark brown text */
  padding: 0 0 40px 0 !important; /* Removed top padding to close the gap under the page divider */
  z-index: 1 !important;
  box-sizing: border-box !important;

  /* Force font family variables locally for the footer */
  --heading-font-font-family: "Work Sans", sans-serif;
  --body-font-font-family: "Work Sans", sans-serif;
  --primary-button-font-font-family: "Work Sans", sans-serif;
  --secondary-button-font-font-family: "Work Sans", sans-serif;

  /* Set font weight variables locally for the footer to 500 */
  --heading-font-font-weight: 500;
  --body-font-font-weight: 500;
  --primary-button-font-font-weight: 500;
  --secondary-button-font-font-weight: 500;

  /* Set footer base font size to 16.67px */
  font-size: 16.67px !important;
  --font-size-2xs: 16.67px;
  --font-size-xs: 16.67px;
  --font-size-sm: 16.67px;
  --font-size-base: 16.67px;
  --font-size-md: 16.67px;
  --font-size-lg: 16.67px;
  --font-size-xl: 16.67px;
  --font-size-2xl: 16.67px;
}

#footer-sections .page-section,
#footer-sections .section-border,
#footer-sections .section-background {
  background-color: transparent !important;
  background: transparent !important;
}

#footer-sections .page-section {
  padding-top: 0 !important;
  margin-top: 0 !important;
}

#footer-sections .content-wrapper {
  max-width: 1320px !important;
  margin: 0 auto !important;
  padding: 0 20px !important;
  box-sizing: border-box !important;
  width: 100% !important;
}

/* Force all text in the footer to use the Work Sans font */
#footer-sections,
#footer-sections * {
  font-family: "Work Sans", sans-serif !important;
}

#footer-sections h2,
#footer-sections h3,
#footer-sections h4,
#footer-sections p,
#footer-sections a,
#footer-sections span,
#footer-sections label {
  color: #502c18 !important; /* Dark brown */
}

/* Apply Body Font system to general footer texts */
#footer-sections p,
#footer-sections a,
#footer-sections span,
#footer-sections label,
#footer-sections input,
#footer-sections textarea,
#footer-sections select,
#footer-sections .follow-text,
#footer-sections .sub-label,
#footer-sections .required-sub,
#footer-sections .required-label {
  font-family: var(--body-font-font-family), sans-serif !important;
  font-style: var(--body-font-font-style) !important;
  font-weight: var(--body-font-font-weight) !important;
  text-transform: var(--body-font-text-transform) !important;
  letter-spacing: var(--body-font-letter-spacing) !important;
  line-height: var(--body-font-line-height) !important;
}

/* Apply Heading Font system to headings */
#footer-sections h2,
#footer-sections h3,
#footer-sections h4 {
  font-family: var(--heading-font-font-family), sans-serif !important;
  font-style: var(--heading-font-font-style) !important;
  font-weight: var(--heading-font-font-weight) !important;
  text-transform: var(--heading-font-text-transform) !important;
  letter-spacing: var(--heading-font-letter-spacing) !important;
  line-height: var(--heading-font-line-height) !important;
}

/* Grid Layout support for OrderPort footer template */
.sqs-row {
  display: flex !important;
  flex-wrap: wrap !important;
  margin-left: -15px !important;
  margin-right: -15px !important;
}

.sqs-row .col {
  padding-left: 15px !important;
  padding-right: 15px !important;
  box-sizing: border-box !important;
}

.sqs-col-12 {
  width: 100% !important;
}

@media (min-width: 768px) {
  .sqs-col-5 {
    width: 41.6667% !important;
  }
  .sqs-col-4 {
    width: 33.3333% !important;
  }
  .sqs-col-3 {
    width: 25% !important;
  }
}

@media (max-width: 767px) {
  .sqs-row .col {
    width: 100% !important;
    margin-bottom: 30px !important;
  }
}

/* Form block styling */
#block-yui_3_17_2_1_1638808029237_5705 form {
  display: flex !important;
  flex-direction: column !important;
  gap: 15px !important;
}

#block-yui_3_17_2_1_1638808029237_5705 .form-item {
  display: flex !important;
  flex-direction: column !important;
  gap: 5px !important;
}

#block-yui_3_17_2_1_1638808029237_5705 label.title {
  font-size: 30px !important;
  font-weight: var(--heading-font-font-weight) !important;
  color: #502c18 !important;
  font-family: var(--heading-font-font-family), sans-serif !important;
  text-transform: var(--heading-font-text-transform) !important;
  letter-spacing: var(--heading-font-letter-spacing) !important;
}

#block-yui_3_17_2_1_1638808029237_5705 .field-element {
  width: 100% !important;
  padding: 12px !important;
  border: 1px solid #502c18 !important; /* Dark brown border */
  border-radius: 0 !important; /* Square corners */
  font-size: 26.25px !important;
  font-family: var(--body-font-font-family), sans-serif !important;
  box-sizing: border-box !important;
  background-color: #fff !important;
  color: #502c18 !important;
}

#block-yui_3_17_2_1_1638808029237_5705 textarea.field-element {
  min-height: 120px !important;
  resize: vertical !important;
}

#block-yui_3_17_2_1_1638808029237_5705 button.button {
  align-self: flex-start !important;
  padding: 12px 28px !important;
  background-color: #502c18 !important; /* Dark brown background */
  color: #e8e4e0 !important; /* Beige text */
  border: none !important;
  border-radius: 0 !important; /* Square corners */
  font-weight: var(--primary-button-font-font-weight) !important;
  font-family: var(--primary-button-font-font-family), sans-serif !important;
  text-transform: var(--primary-button-font-text-transform) !important;
  letter-spacing: var(--primary-button-font-letter-spacing) !important;
  line-height: var(--primary-button-font-line-height) !important;
  font-size: 25px !important;
  cursor: pointer !important;
  transition: opacity 0.2s !important;
}

#block-yui_3_17_2_1_1638808029237_5705 button.button:hover {
  opacity: 0.9 !important;
}

/* Split Name Fields Styling */
.name-fields {
  display: flex !important;
  gap: 15px !important;
  width: 100% !important;
  margin-top: 5px !important;
}

.name-field-sub {
  display: flex !important;
  flex-direction: column !important;
  gap: 5px !important;
  flex: 1 !important;
}

.name-field-sub .sub-label {
  font-size: 25px !important;
  font-weight: 500 !important;
  color: #502c18 !important;
}

.name-field-sub .required-sub,
.required-label {
  font-size: 22.5px !important;
  color: #502c18 !important;
  opacity: 0.7 !important;
  font-weight: 500 !important;
}

/* Footer Contact Button Column Styling */
.footer-contact-wrapper {
  display: flex !important;
  flex-direction: column !important;
  gap: 15px !important;
}

.footer-contact-title {
  font-size: 16.67px !important;
  font-weight: var(--heading-font-font-weight) !important;
  color: #502c18 !important;
  font-family: var(--heading-font-font-family), sans-serif !important;
  text-transform: var(--heading-font-text-transform) !important;
  letter-spacing: var(--heading-font-letter-spacing) !important;
  line-height: var(--heading-font-line-height) !important;
}

#footer-sections .footer-contact-btn {
  display: inline-block !important;
  padding: 15px 25px !important;
  background-color: #502c18 !important; /* Dark brown background */
  color: #ffffff !important; /* White text */
  text-decoration: none !important;
  font-weight: var(--primary-button-font-font-weight) !important;
  font-size: 16.67px !important;
  font-family: var(--primary-button-font-font-family), sans-serif !important;
  text-transform: var(--primary-button-font-text-transform) !important;
  letter-spacing: var(--primary-button-font-letter-spacing) !important;
  line-height: var(--primary-button-font-line-height) !important;
  text-align: center !important;
  border: none !important;
  border-radius: 0 !important; /* Square corners */
  transition: opacity 0.2s !important;
  align-self: flex-start !important; /* Don't stretch button */
}

#footer-sections .footer-contact-btn:hover {
  opacity: 0.9 !important;
}

/* Horizontal Rule divider in footer */
#block-yui_3_17_2_1_1641432937331_179009 hr {
  border: 0 !important;
  height: 3px !important; /* Thicker separator line (3px instead of 1.5px) */
  background: #502c18 !important; /* Dark brown rule */
  margin: 25px 0 !important;
  opacity: 0.3 !important;
}

/* Text and Links styling in footer */
#footer-sections .sqsrte-text-color--accent {
  color: #502c18 !important; /* Force all footer text to dark brown */
}

#block-acbe506b3f05cb5af7f6 p,
#block-089eda4ca9cb4a744325 p,
#block-yui_3_17_2_1_1641432937331_185816 p,
#block-yui_3_17_2_1_1641432937331_188124 p {
  font-size: 16.67px !important;
  line-height: 1.6 !important;
  margin: 0 0 15px 0 !important;
  color: #502c18 !important;
}

#footer-sections .sqsrte-large {
  font-size: 16.67px !important;
}

#block-acbe506b3f05cb5af7f6 a,
#block-089eda4ca9cb4a744325 a {
  color: #502c18 !important;
  text-decoration: underline !important;
  text-underline-offset: 3px !important;
  transition: opacity 0.2s !important;
}

#block-acbe506b3f05cb5af7f6 a:hover,
#block-089eda4ca9cb4a744325 a:hover {
  opacity: 0.7 !important;
}

/* Restructured Column 3 (Right) layout classes */
.footer-right-container {
  display: flex !important;
  justify-content: space-between !important;
  gap: 20px !important;
  width: 100% !important;
}

.footer-right-left-part {
  display: flex !important;
  flex-direction: column !important;
  gap: 40px !important;
  flex: 1 !important;
}

.logo-follow-wrapper {
  display: flex !important;
  align-items: center !important;
  gap: 15px !important;
}

.footer-logo-circle {
  width: 70px !important;
  height: 70px !important;
  border-radius: 0 !important;
  overflow: hidden !important;
  flex-shrink: 0 !important;
}

.footer-logo-circle img {
  width: 100% !important;
  height: 100% !important;
  object-fit: cover !important;
}

.follow-text {
  font-size: 16.67px !important;
  font-weight: 500 !important;
  line-height: 1.4 !important;
  color: #502c18 !important;
  max-width: 225px !important;
}

.stay-in-touch-wrapper {
  display: flex !important;
  flex-direction: column !important;
  gap: 15px !important;
}

.stay-in-touch-title {
  font-size: 16.67px !important;
  font-weight: var(--heading-font-font-weight) !important;
  color: #502c18 !important;
  font-family: var(--heading-font-font-family), sans-serif !important;
  text-transform: var(--heading-font-text-transform) !important;
  letter-spacing: var(--heading-font-letter-spacing) !important;
  line-height: var(--heading-font-line-height) !important;
}

#footer-sections .newsletter-btn {
  display: inline-block !important;
  padding: 15px 25px !important;
  background-color: #502c18 !important; /* Dark brown background */
  color: #ffffff !important; /* White text */
  text-decoration: none !important;
  font-weight: var(--primary-button-font-font-weight) !important;
  font-size: 16.67px !important;
  font-family: var(--primary-button-font-font-family), sans-serif !important;
  text-transform: var(--primary-button-font-text-transform) !important;
  letter-spacing: var(--primary-button-font-letter-spacing) !important;
  line-height: 1.4 !important; /* Improved line-height for wrapped text */
  text-align: center !important;
  border: none !important;
  border-radius: 0 !important; /* Square corners */
  transition: opacity 0.2s !important;
  max-width: 420px !important; /* Increased max-width to 420px */
}

#footer-sections .newsletter-btn:hover {
  opacity: 0.9 !important;
}

.follow-text-social-container {
  display: flex !important;
  flex-direction: column !important;
  gap: 12px !important;
}

.horizontal-social-list {
  display: flex !important;
  flex-direction: row !important;
  gap: 15px !important;
  align-items: center !important;
}

/* Social icons outline and transitions */
body #footer-sections .sqs-svg-icon--wrapper {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  width: 48px !important;
  height: 48px !important;
  border-radius: 0 !important;
  border: 3px solid #2a2928 !important; /* Dark grey outline, thickened x2 */
  background-color: transparent !important; /* Transparent background */
  transition: transform 0.2s background-color 0.2s !important;
  padding: 3px !important; /* 1.5x bigger inner icon (36px content box instead of 24px) */
  box-sizing: border-box !important;
}

body #footer-sections .sqs-svg-icon--wrapper svg,
body #footer-sections .sqs-svg-icon--wrapper path {
  width: 100% !important;
  height: 100% !important;
  fill: #2a2928 !important; /* Dark grey icon */
  transition: fill 0.2s !important;
}

body #footer-sections .sqs-svg-icon--wrapper svg {
  transform: scale(1.5) !important;
  transform-origin: center !important;
}

body #footer-sections .sqs-svg-icon--wrapper:hover {
  transform: translateY(-3px) !important;
  background-color: #2a2928 !important; /* Dark grey fill on hover */
}

body #footer-sections .sqs-svg-icon--wrapper:hover svg,
body #footer-sections .sqs-svg-icon--wrapper:hover path {
  fill: #e8e4e0 !important; /* Beige icon on hover */
}

@media (max-width: 1200px) {
  #footer-sections .sqs-row .col {
    width: 100% !important;
    margin-bottom: 40px !important;
  }
  #footer-sections .footer-right-container {
    flex-direction: column !important;
    gap: 30px !important;
  }

  /* Make the logo image take up its own row and get bigger when compacted */
  #footer-sections .logo-follow-wrapper {
    flex-direction: column !important;
    align-items: center !important;
    text-align: center !important;
    gap: 20px !important;
  }
  #footer-sections .footer-logo-circle {
    width: 210px !important;
    height: 210px !important;
  }
  #footer-sections .follow-text-social-container {
    display: flex !important;
    flex-direction: column !important;
    align-items: center !important;
    gap: 15px !important;
  }
  #footer-sections .follow-text {
    max-width: 100% !important;
    text-align: center !important;
  }
}

#block-acbe506b3f05cb5af7f6 a[href^="mailto:"] {
  white-space: nowrap !important;
}

@media (max-width: 767px) {
  #footer-sections .content-wrapper {
    padding: 0 16px !important;
  }
}

@media (max-width: 640px) {
  #block-acbe506b3f05cb5af7f6 a[href^="mailto:"] {
    font-size: 16px !important;
  }
}

/* ========================================
   4. SHOP-LEFT-MENU.CSS
   ======================================== */

.menu-header {
  display: none;
}

.three-items-across-menu {
  /* border: 1px solid black !important; */
  padding: 6px 6px !important;
  border-radius: 0 !important;
}

.shop-left-menu .three-items-across-menu > ul,
.shop-left-menu .four-items-across-menu > ul {
  padding: 0;
}

.shop-left-menu > span.four-items-across-menu,
.shop-left-menu > span.three-items-across-menu {
  text-align: left;
}

.shop-left-menu > span {
  display: block;
  font-size: var(--font-size-lg);
}

.vertical-menu .shop-left-menu {
  width: 100%;
  background: var(--color-gray-50);
  border: none;
  border-radius: 0;
  overflow: hidden;
}

.vertical-menu .four-items-across-menu .menu-header,
.vertical-menu .three-items-across-menu .menu-header {
  display: block;
}

@media (min-width: 1250px) {
  .vertical-menu .shop-left-menu {
    flex: 0 0 220px;
    position: sticky;
    top: var(--cart-summary-top);
  }
}

.vertical-menu .shop-left-menu ul {
  list-style: none;
  padding: 0;
  margin: 0;
}

.vertical-menu .shop-left-menu ul li {
  border-bottom: 1px solid var(--color-border-light);
  margin-bottom: 0;
}

.vertical-menu .shop-left-menu ul li:last-child {
  border-bottom: none;
}

.vertical-menu .shop-left-menu ul li:first-child {
  margin-top: 0;
}

.vertical-menu .shop-left-menu .menu-header {
  background: var(--color-primary);
  color: var(--color-white);
  padding: 18px 20px;
  font-weight: 700;
  font-size: var(--font-size-base);
  letter-spacing: 0.5px;
  text-transform: uppercase;
  margin: 0;
}


.vertical-menu .shop-left-menu a:hover {
  background-color: var(--color-gray-50);
  color: var(--color-primary);
  border-left-color: var(--color-primary);
  padding-left: 20px;
}

.vertical-menu .shop-left-menu a.selected {
  background-color: rgba(241, 68, 59, 0.08);
  color: var(--color-primary);
  border-left-color: var(--color-primary);
  font-weight: 600;
}

.vertical-menu .shop-left-menu ul li.has-sub ul a:hover,
.vertical-menu .shop-left-menu ul li.has-sub ul a.selected {
  padding-left: 36px;
  border-left-color: transparent;
}

.horizontal-menu .shop-left-menu {
  text-align: center;
  margin-bottom: 25px;
  padding-bottom: 25px;
  border-bottom: 1px solid var(--color-border-light);
}

.horizontal-menu .shop-left-menu span > ul {
  display: flex;
  align-items: flex-start;
  justify-content: center;
  flex-wrap: wrap;
  gap: 15px;
}

.horizontal-menu .shop-left-menu span > ul li a {
  color: var(--color-gray-500);
  font-size: var(--font-size-md);
}

.horizontal-menu .shop-left-menu span > ul > li > a {
  display: inline-block;
  padding: 10px 20px;
  border-radius: 0;
  transition: all 0.3s ease;
}

.horizontal-menu .shop-left-menu span > ul > li > a.selected,
.horizontal-menu .shop-left-menu span > ul > li > a:hover {
  color: var(--color-white);
  background-color: var(--color-primary);
  border-bottom: none;
}

@media (min-width: 1250px) {
  .horizontal-menu .shop-left-menu span > ul li {
    position: relative;
  }

  .horizontal-menu .shop-left-menu span > ul li:hover > ul {
    display: block;
  }

  .horizontal-menu .shop-left-menu span > ul li ul {
    display: none;
    background-color: var(--color-white);
    border-radius: 0;
    border: 1px solid transparent;
    box-shadow: none;
    z-index: 1020;
    position: absolute;
    top: 100%;
    left: 0;
    min-width: 100%;
    padding: 5px 10px;
  }

  .horizontal-menu .shop-left-menu span > ul li ul ul {
    left: 100%;
    top: 0;
  }

  .horizontal-menu .shop-left-menu span > ul > li ul a {
    white-space: nowrap;
  }
}

/* Ensure the main page form wrapper stretches to full viewport height and acts as a flex container */
body,
body > form {
  display: flex !important;
  flex-direction: column !important;
  min-height: 100vh !important;
}

#pageContent {
  flex: 1 0 auto !important;
}