.elementor-kit-4{--e-global-color-primary:#6EC1E4;--e-global-color-secondary:#54595F;--e-global-color-text:#7A7A7A;--e-global-color-accent:#61CE70;--e-global-typography-primary-font-family:"Playfair Display";--e-global-typography-primary-font-weight:700;--e-global-typography-secondary-font-family:"Montserrat";--e-global-typography-secondary-font-weight:600;--e-global-typography-text-font-family:"Open Sans";--e-global-typography-text-font-weight:400;--e-global-typography-accent-font-family:"Montserrat";--e-global-typography-accent-font-weight:700;}.elementor-kit-4 e-page-transition{background-color:#FFBC7D;}.elementor-section.elementor-section-boxed > .elementor-container{max-width:1140px;}.e-con{--container-max-width:1140px;}.elementor-widget:not(:last-child){--kit-widget-spacing:20px;}.elementor-element{--widgets-spacing:20px 20px;--widgets-spacing-row:20px;--widgets-spacing-column:20px;}{}h1.entry-title{display:var(--page-title-display);}.site-header .site-branding{flex-direction:column;align-items:stretch;}.site-header{padding-inline-end:0px;padding-inline-start:0px;}.site-footer .site-branding{flex-direction:column;align-items:stretch;}@media(max-width:1024px){.elementor-section.elementor-section-boxed > .elementor-container{max-width:1024px;}.e-con{--container-max-width:1024px;}}@media(max-width:767px){.elementor-section.elementor-section-boxed > .elementor-container{max-width:767px;}.e-con{--container-max-width:767px;}}
/* Start custom CSS *//* ============================================================
   DISCOUNT TILE BRISBANE — PREMIUM DESIGN SYSTEM
   Version: 1.0  |  June 2026
   ─────────────────────────────────────────────────────────────
   HOW TO INSTALL
   1. WordPress Admin → Elementor → Site Settings → Custom CSS
   2. Paste the entire contents of this file
   3. Save & Update

   FONTS — add to Elementor → Site Settings → Typography
   Headings : Playfair Display  (Google Fonts)
   Sub-heads : Montserrat       (Google Fonts)
   Body      : Open Sans        (Google Fonts)
   ============================================================ */


/* ═══════════════════════════════════════════════════════════
   1. DESIGN TOKENS
   ═══════════════════════════════════════════════════════════ */
:root {
  /* Brand colours */
  --dtw-navy:          #1B3A6B;
  --dtw-navy-deep:     #0F2347;
  --dtw-navy-mid:      #2A4F8C;
  --dtw-gold:          #C9A84C;
  --dtw-gold-pale:     #E8D5A3;
  --dtw-terracotta:    #C17B5A;
  --dtw-terra-deep:    #A05E42;

  /* Neutrals */
  --dtw-ink:           #141820;
  --dtw-body:          #2C2C2C;
  --dtw-muted:         #6A6A6A;
  --dtw-border:        #E3DDD7;
  --dtw-surface:       #F8F7F5;
  --dtw-white:         #FFFFFF;

  /* Typography */
  --dtw-serif:   'Playfair Display', Georgia, serif;
  --dtw-sans:    'Open Sans', system-ui, sans-serif;
  --dtw-mid:     'Montserrat', 'Helvetica Neue', sans-serif;

  /* Spacing & shape */
  --dtw-radius:    6px;
  --dtw-radius-lg: 14px;

  /* Shadows */
  --dtw-shadow-xs: 0 1px 4px rgba(27,58,107,0.07);
  --dtw-shadow-sm: 0 4px 16px rgba(27,58,107,0.09);
  --dtw-shadow-md: 0 10px 32px rgba(27,58,107,0.13);
  --dtw-shadow-lg: 0 20px 56px rgba(27,58,107,0.18);

  /* Motion */
  --dtw-ease:      cubic-bezier(0.25, 0.46, 0.45, 0.94);
  --dtw-duration:  0.32s;
}


/* ═══════════════════════════════════════════════════════════
   2. GLOBAL TYPOGRAPHY & BASE
   ═══════════════════════════════════════════════════════════ */
body {
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  color: var(--dtw-body);
}

/* Headings — serif, navy */
h1, h2, h3 {
  font-family: var(--dtw-serif) !important;
  color: var(--dtw-navy) !important;
  text-wrap: balance;
  letter-spacing: -0.02em;
}

h4, h5, h6 {
  font-family: var(--dtw-mid) !important;
  color: var(--dtw-navy) !important;
}

/* Elementor heading widget */
.elementor-widget-heading .elementor-heading-title {
  font-family: var(--dtw-serif) !important;
  color: var(--dtw-navy) !important;
  text-wrap: balance;
}

/* Body / paragraph text */
p, li, td, th {
  font-family: var(--dtw-sans) !important;
  line-height: 1.72;
}

/* Anchor colour */
a {
  color: var(--dtw-navy);
  text-decoration-color: transparent;
  transition: color var(--dtw-duration) var(--dtw-ease),
              text-decoration-color var(--dtw-duration) var(--dtw-ease);
}
a:hover {
  color: var(--dtw-gold);
  text-decoration-color: var(--dtw-gold);
}


/* ═══════════════════════════════════════════════════════════
   3. GLOBAL BUTTON POLISH
   ═══════════════════════════════════════════════════════════ */
.elementor-button {
  font-family: var(--dtw-mid) !important;
  font-weight: 700 !important;
  letter-spacing: 0.1em !important;
  text-transform: uppercase !important;
  border-radius: var(--dtw-radius) !important;
  transition: all var(--dtw-duration) var(--dtw-ease) !important;
}

/* Primary filled button */
.elementor-button.elementor-button-primary,
.elementor-button[class*="elementor-size-"] {
  background-color: var(--dtw-navy) !important;
  color: var(--dtw-white) !important;
  border: 2px solid var(--dtw-navy) !important;
}
.elementor-button.elementor-button-primary:hover,
.elementor-button[class*="elementor-size-"]:hover {
  background-color: var(--dtw-navy-deep) !important;
  border-color: var(--dtw-navy-deep) !important;
  box-shadow: 0 8px 28px rgba(27,58,107,0.28) !important;
  transform: translateY(-2px) !important;
}

/* Gold CTA button — add class "dtw-cta" in Elementor Advanced → CSS Classes */
.elementor-button.dtw-cta {
  background-color: var(--dtw-gold) !important;
  color: var(--dtw-ink) !important;
  border-color: var(--dtw-gold) !important;
}
.elementor-button.dtw-cta:hover {
  background-color: transparent !important;
  color: var(--dtw-gold) !important;
  border-color: var(--dtw-gold) !important;
  box-shadow: 0 8px 28px rgba(201,168,76,0.35) !important;
  transform: translateY(-2px) !important;
}


/* ═══════════════════════════════════════════════════════════
   4. NAVIGATION POLISH
   ═══════════════════════════════════════════════════════════ */
.elementor-nav-menu .elementor-item,
.elementor-nav-menu--main .elementor-item {
  font-family: var(--dtw-mid) !important;
  font-size: 0.8rem !important;
  font-weight: 600 !important;
  letter-spacing: 0.07em !important;
  text-transform: uppercase !important;
  transition: color 0.2s ease !important;
}

.elementor-nav-menu .elementor-item:hover,
.elementor-nav-menu .elementor-item.elementor-item-active {
  color: var(--dtw-gold) !important;
}


/* ═══════════════════════════════════════════════════════════
   5. HERO SLIDER — PREMIUM TREATMENT
   ─────────────────────────────────────────────────────────
   Works with: Elementor Slides widget (built-in)
   ═══════════════════════════════════════════════════════════ */

/* Full viewport height */
.elementor-widget-slides .elementor-slides-wrapper,
.elementor-widget-slides .swiper-container,
.elementor-widget-slides .swiper {
  min-height: 88vh !important;
}

/* Cinematic overlay — gradient, not flat black */
.elementor-slide-overlay {
  background: linear-gradient(
    125deg,
    rgba(10, 18, 38, 0.82) 0%,
    rgba(15, 35, 71, 0.55) 55%,
    rgba(193, 123, 90, 0.18) 100%
  ) !important;
}

/* Slide content — tighten vertical alignment */
.elementor-slide-content {
  padding: 0 clamp(24px, 6vw, 80px) !important;
}

/* Heading — editorial, serif, cinematic scale */
.elementor-slide-heading {
  font-family: var(--dtw-serif) !important;
  font-size: clamp(2.75rem, 5.5vw, 5.5rem) !important;
  font-weight: 700 !important;
  line-height: 1.08 !important;
  letter-spacing: -0.025em !important;
  color: #FFFFFF !important;
  text-shadow: 0 2px 24px rgba(0,0,0,0.25) !important;
  text-wrap: balance !important;
  margin-bottom: 20px !important;
}

/* Description */
.elementor-slide-description {
  font-family: var(--dtw-sans) !important;
  font-size: clamp(1rem, 1.6vw, 1.25rem) !important;
  font-weight: 400 !important;
  line-height: 1.65 !important;
  letter-spacing: 0.01em !important;
  color: rgba(255,255,255,0.85) !important;
  max-width: 540px !important;
  text-shadow: 0 1px 8px rgba(0,0,0,0.2) !important;
  margin-bottom: 36px !important;
}

/* Primary slide button — gold filled */
.elementor-slide-button {
  font-family: var(--dtw-mid) !important;
  font-size: 0.8125rem !important;
  font-weight: 700 !important;
  letter-spacing: 0.12em !important;
  text-transform: uppercase !important;
  padding: 17px 40px !important;
  border-radius: 3px !important;
  background-color: var(--dtw-gold) !important;
  border: 2px solid var(--dtw-gold) !important;
  color: var(--dtw-ink) !important;
  text-decoration: none !important;
  transition: background-color 0.28s ease,
              color 0.28s ease,
              box-shadow 0.28s ease,
              transform 0.28s ease !important;
  display: inline-block !important;
}
.elementor-slide-button:hover {
  background-color: transparent !important;
  color: #FFFFFF !important;
  border-color: rgba(255,255,255,0.8) !important;
  box-shadow: none !important;
  transform: translateY(-2px) !important;
}

/* Secondary ghost button — add it via Elementor Slides > Button 2 */
.elementor-slide-button + .elementor-slide-button {
  background-color: transparent !important;
  border: 2px solid rgba(255,255,255,0.55) !important;
  color: #FFFFFF !important;
  margin-left: 12px !important;
}
.elementor-slide-button + .elementor-slide-button:hover {
  background-color: rgba(255,255,255,0.1) !important;
  border-color: rgba(255,255,255,0.9) !important;
}

/* Navigation arrows — glass circles */
.elementor-swiper-button {
  width: 50px !important;
  height: 50px !important;
  background: rgba(255,255,255,0.10) !important;
  border: 1px solid rgba(255,255,255,0.28) !important;
  border-radius: 50% !important;
  backdrop-filter: blur(10px) !important;
  -webkit-backdrop-filter: blur(10px) !important;
  transition: background var(--dtw-duration) var(--dtw-ease),
              border-color var(--dtw-duration) var(--dtw-ease) !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
}
.elementor-swiper-button:hover {
  background: rgba(201,168,76,0.28) !important;
  border-color: var(--dtw-gold) !important;
}
.elementor-swiper-button svg {
  width: 18px !important;
  height: 18px !important;
  color: #fff !important;
  fill: #fff !important;
}

/* Pagination dots — pill on active */
.elementor-widget-slides .swiper-pagination-bullet {
  width: 7px !important;
  height: 7px !important;
  background: rgba(255,255,255,0.38) !important;
  opacity: 1 !important;
  border-radius: 4px !important;
  transition: width 0.35s var(--dtw-ease),
              background 0.35s var(--dtw-ease) !important;
}
.elementor-widget-slides .swiper-pagination-bullet-active {
  width: 36px !important;
  background: var(--dtw-gold) !important;
}

/* Animated scroll indicator line */
.elementor-widget-slides {
  position: relative !important;
}
.elementor-widget-slides::after {
  content: '';
  position: absolute;
  bottom: 28px;
  left: 50%;
  transform: translateX(-50%);
  width: 1px;
  height: 52px;
  background: linear-gradient(to bottom, rgba(255,255,255,0.7), transparent);
  animation: dtw-scroll-cue 2.2s ease-in-out infinite;
  z-index: 20;
  pointer-events: none;
}
@keyframes dtw-scroll-cue {
  0%   { opacity: 0; transform: translateX(-50%) scaleY(0); transform-origin: top; }
  40%  { opacity: 1; transform: translateX(-50%) scaleY(1); transform-origin: top; }
  80%  { opacity: 0; transform: translateX(-50%) scaleY(1); transform-origin: top; }
  100% { opacity: 0; }
}


/* ═══════════════════════════════════════════════════════════
   6. WOOCOMMERCE — SHOP / ARCHIVE PAGE
   ─────────────────────────────────────────────────────────
   Product listing grid, cards, badges, sort bar
   ═══════════════════════════════════════════════════════════ */

/* Page heading */
.woocommerce-products-header__title,
.woocommerce-products-header h1 {
  font-family: var(--dtw-serif) !important;
  font-size: clamp(2rem, 3.5vw, 3.25rem) !important;
  color: var(--dtw-navy) !important;
  letter-spacing: -0.02em !important;
  margin-bottom: 8px !important;
}

/* Sort bar */
.woocommerce-ordering select {
  font-family: var(--dtw-sans) !important;
  font-size: 0.875rem !important;
  color: var(--dtw-body) !important;
  border: 1.5px solid var(--dtw-border) !important;
  border-radius: var(--dtw-radius) !important;
  padding: 9px 36px 9px 12px !important;
  background-color: var(--dtw-white) !important;
  appearance: auto !important;
  cursor: pointer !important;
}
.woocommerce-result-count {
  font-family: var(--dtw-sans) !important;
  font-size: 0.875rem !important;
  color: var(--dtw-muted) !important;
}

/* ── Product grid ── */
.woocommerce ul.products {
  display: grid !important;
  grid-template-columns: repeat(auto-fill, minmax(260px, 1fr)) !important;
  gap: 28px !important;
  margin: 0 !important;
  padding: 0 !important;
  list-style: none !important;
}

/* ── Product card ── */
.woocommerce ul.products li.product {
  background: var(--dtw-white) !important;
  border-radius: var(--dtw-radius-lg) !important;
  border: 1px solid var(--dtw-border) !important;
  overflow: hidden !important;
  box-shadow: var(--dtw-shadow-xs) !important;
  transition: transform var(--dtw-duration) var(--dtw-ease),
              box-shadow var(--dtw-duration) var(--dtw-ease),
              border-color var(--dtw-duration) var(--dtw-ease) !important;
  display: flex !important;
  flex-direction: column !important;
  margin: 0 !important;
  padding: 0 !important;
}
.woocommerce ul.products li.product:hover {
  transform: translateY(-6px) !important;
  box-shadow: var(--dtw-shadow-lg) !important;
  border-color: rgba(201,168,76,0.35) !important;
}

/* Image wrapper — clips zoom */
.woocommerce ul.products li.product .woocommerce-loop-product__link {
  display: block !important;
  overflow: hidden !important;
}

/* Product image — square, fills card */
.woocommerce ul.products li.product .woocommerce-loop-product__link img,
.woocommerce ul.products li.product a > img {
  display: block !important;
  width: 100% !important;
  aspect-ratio: 1 / 1 !important;
  object-fit: cover !important;
  transition: transform 0.55s var(--dtw-ease) !important;
}
.woocommerce ul.products li.product:hover .woocommerce-loop-product__link img,
.woocommerce ul.products li.product:hover a > img {
  transform: scale(1.05) !important;
}

/* Card body padding */
.woocommerce ul.products li.product .woocommerce-loop-product__link {
  flex: 1 !important;
  display: flex !important;
  flex-direction: column !important;
}

/* Product title */
.woocommerce ul.products li.product .woocommerce-loop-product__title {
  font-family: var(--dtw-mid) !important;
  font-size: 0.9375rem !important;
  font-weight: 600 !important;
  color: var(--dtw-body) !important;
  letter-spacing: 0 !important;
  text-transform: none !important;
  padding: 16px 16px 4px !important;
  margin: 0 !important;
  line-height: 1.35 !important;
}

/* Price */
.woocommerce ul.products li.product .price {
  font-family: var(--dtw-mid) !important;
  font-size: 1.0625rem !important;
  font-weight: 700 !important;
  color: var(--dtw-navy) !important;
  padding: 0 16px 14px !important;
  display: block !important;
}
.woocommerce ul.products li.product .price del {
  color: var(--dtw-muted) !important;
  font-weight: 400 !important;
  font-size: 0.875rem !important;
  margin-right: 6px !important;
}
.woocommerce ul.products li.product .price ins {
  text-decoration: none !important;
  color: var(--dtw-terracotta) !important;
}

/* Add to cart — bottom of card */
.woocommerce ul.products li.product .button,
.woocommerce ul.products li.product a.button {
  display: block !important;
  margin: 0 16px 16px !important;
  padding: 11px 16px !important;
  font-family: var(--dtw-mid) !important;
  font-size: 0.8rem !important;
  font-weight: 700 !important;
  letter-spacing: 0.08em !important;
  text-transform: uppercase !important;
  text-align: center !important;
  text-decoration: none !important;
  color: var(--dtw-navy) !important;
  background: transparent !important;
  border: 1.5px solid var(--dtw-navy) !important;
  border-radius: var(--dtw-radius) !important;
  transition: background var(--dtw-duration) var(--dtw-ease),
              color var(--dtw-duration) var(--dtw-ease) !important;
  width: auto !important;
}
.woocommerce ul.products li.product .button:hover,
.woocommerce ul.products li.product a.button:hover {
  background: var(--dtw-navy) !important;
  color: var(--dtw-white) !important;
}

/* Sale badge */
.woocommerce ul.products li.product .onsale,
.woocommerce span.onsale {
  background: var(--dtw-terracotta) !important;
  color: var(--dtw-white) !important;
  font-family: var(--dtw-mid) !important;
  font-size: 0.6875rem !important;
  font-weight: 700 !important;
  letter-spacing: 0.09em !important;
  text-transform: uppercase !important;
  padding: 5px 11px !important;
  border-radius: 3px !important;
  min-height: auto !important;
  min-width: auto !important;
  line-height: 1.5 !important;
  top: 12px !important;
  left: 12px !important;
  margin: 0 !important;
}

/* ── Breadcrumbs ── */
.woocommerce .woocommerce-breadcrumb {
  font-family: var(--dtw-sans) !important;
  font-size: 0.8125rem !important;
  color: var(--dtw-muted) !important;
}
.woocommerce .woocommerce-breadcrumb a {
  color: var(--dtw-muted) !important;
  text-decoration: none !important;
}
.woocommerce .woocommerce-breadcrumb a:hover {
  color: var(--dtw-navy) !important;
}


/* ═══════════════════════════════════════════════════════════
   7. WOOCOMMERCE — SINGLE PRODUCT PAGE
   ═══════════════════════════════════════════════════════════ */

/* Outer layout — two columns */
.woocommerce div.product {
  display: grid !important;
  grid-template-columns: 1fr 1fr !important;
  column-gap: 64px !important;
  row-gap: 0 !important;
  align-items: start !important;
  padding-top: 48px !important;
}

/* Both columns span full width for tabs + related */
.woocommerce div.product .woocommerce-tabs,
.woocommerce div.product .up-sells,
.woocommerce .related.products {
  grid-column: 1 / -1 !important;
}

/* Sticky image gallery */
.woocommerce div.product div.images {
  position: sticky !important;
  top: 90px !important;
}

/* Main product image */
.woocommerce div.product .woocommerce-product-gallery__image > a img,
.woocommerce div.product .woocommerce-product-gallery__image img {
  border-radius: var(--dtw-radius-lg) !important;
  width: 100% !important;
  display: block !important;
}

/* Thumbnail strip */
.woocommerce div.product .flex-control-thumbs {
  display: flex !important;
  gap: 10px !important;
  margin-top: 14px !important;
  flex-wrap: wrap !important;
  padding: 0 !important;
  list-style: none !important;
}
.woocommerce div.product .flex-control-thumbs li {
  width: calc(25% - 8px) !important;
  margin: 0 !important;
}
.woocommerce div.product .flex-control-thumbs li img {
  border-radius: var(--dtw-radius) !important;
  border: 2px solid transparent !important;
  cursor: pointer !important;
  aspect-ratio: 1 / 1 !important;
  object-fit: cover !important;
  width: 100% !important;
  transition: border-color 0.2s ease, opacity 0.2s ease !important;
  opacity: 0.72 !important;
}
.woocommerce div.product .flex-control-thumbs li img:hover,
.woocommerce div.product .flex-control-thumbs li img.flex-active {
  border-color: var(--dtw-gold) !important;
  opacity: 1 !important;
}

/* Product title */
.woocommerce div.product h1.product_title {
  font-family: var(--dtw-serif) !important;
  font-size: clamp(1.75rem, 3vw, 2.875rem) !important;
  font-weight: 700 !important;
  line-height: 1.12 !important;
  letter-spacing: -0.025em !important;
  color: var(--dtw-navy) !important;
  text-wrap: balance !important;
  margin-bottom: 14px !important;
}

/* Star rating row */
.woocommerce div.product .woocommerce-product-rating {
  display: flex !important;
  align-items: center !important;
  gap: 10px !important;
  margin-bottom: 20px !important;
}
.woocommerce .star-rating span::before,
.woocommerce .star-rating::before {
  color: var(--dtw-gold) !important;
}
.woocommerce .woocommerce-review-link {
  font-family: var(--dtw-sans) !important;
  font-size: 0.875rem !important;
  color: var(--dtw-muted) !important;
  text-decoration: none !important;
}

/* Price */
.woocommerce div.product p.price,
.woocommerce div.product span.price {
  font-family: var(--dtw-serif) !important;
  font-size: 2.125rem !important;
  font-weight: 700 !important;
  color: var(--dtw-navy) !important;
  display: block !important;
  line-height: 1 !important;
  padding-bottom: 20px !important;
  margin-bottom: 20px !important;
  border-bottom: 1px solid var(--dtw-border) !important;
  position: relative !important;
}
/* Gold accent bar under price */
.woocommerce div.product p.price::after {
  content: '';
  position: absolute;
  bottom: -1px;
  left: 0;
  width: 52px;
  height: 2px;
  background: var(--dtw-gold);
  border-radius: 2px;
}

/* Short description */
.woocommerce div.product .woocommerce-product-details__short-description {
  font-family: var(--dtw-sans) !important;
  font-size: 1rem !important;
  line-height: 1.75 !important;
  color: var(--dtw-muted) !important;
  margin-bottom: 28px !important;
}
.woocommerce div.product .woocommerce-product-details__short-description p {
  margin-bottom: 10px !important;
}

/* Add to cart row */
.woocommerce div.product form.cart {
  display: flex !important;
  gap: 12px !important;
  align-items: stretch !important;
  margin-bottom: 28px !important;
  flex-wrap: wrap !important;
}

/* Quantity input */
.woocommerce div.product form.cart .qty {
  width: 76px !important;
  height: 52px !important;
  font-family: var(--dtw-mid) !important;
  font-size: 1rem !important;
  font-weight: 600 !important;
  text-align: center !important;
  color: var(--dtw-body) !important;
  background: var(--dtw-white) !important;
  border: 1.5px solid var(--dtw-border) !important;
  border-radius: var(--dtw-radius) !important;
  transition: border-color 0.2s ease !important;
}
.woocommerce div.product form.cart .qty:focus {
  outline: none !important;
  border-color: var(--dtw-navy) !important;
}

/* Add to cart button */
.woocommerce div.product form.cart .single_add_to_cart_button {
  flex: 1 !important;
  height: 52px !important;
  padding: 0 32px !important;
  font-family: var(--dtw-mid) !important;
  font-size: 0.875rem !important;
  font-weight: 700 !important;
  letter-spacing: 0.1em !important;
  text-transform: uppercase !important;
  background: var(--dtw-navy) !important;
  color: var(--dtw-white) !important;
  border: 2px solid var(--dtw-navy) !important;
  border-radius: var(--dtw-radius) !important;
  cursor: pointer !important;
  transition: background var(--dtw-duration) var(--dtw-ease),
              box-shadow var(--dtw-duration) var(--dtw-ease),
              transform var(--dtw-duration) var(--dtw-ease) !important;
}
.woocommerce div.product form.cart .single_add_to_cart_button:hover {
  background: var(--dtw-navy-deep) !important;
  border-color: var(--dtw-navy-deep) !important;
  box-shadow: 0 10px 32px rgba(27,58,107,0.3) !important;
  transform: translateY(-2px) !important;
}

/* Product meta (SKU, category, tags) */
.woocommerce div.product .product_meta {
  border-top: 1px solid var(--dtw-border) !important;
  padding-top: 22px !important;
  margin-top: 22px !important;
  font-family: var(--dtw-sans) !important;
  font-size: 0.8125rem !important;
  color: var(--dtw-muted) !important;
  display: flex !important;
  flex-direction: column !important;
  gap: 6px !important;
}
.woocommerce div.product .product_meta a {
  color: var(--dtw-navy) !important;
  font-weight: 600 !important;
  text-decoration: none !important;
}
.woocommerce div.product .product_meta a:hover {
  color: var(--dtw-terracotta) !important;
}

/* ── Tabs (Description / Specifications / Reviews) ── */
.woocommerce div.product .woocommerce-tabs {
  margin-top: 72px !important;
  padding-top: 56px !important;
  border-top: 1px solid var(--dtw-border) !important;
}

.woocommerce div.product .woocommerce-tabs ul.tabs {
  display: flex !important;
  gap: 0 !important;
  border-bottom: 1px solid var(--dtw-border) !important;
  padding: 0 !important;
  margin: 0 0 36px !important;
  list-style: none !important;
}
.woocommerce div.product .woocommerce-tabs ul.tabs::before,
.woocommerce div.product .woocommerce-tabs ul.tabs li::before,
.woocommerce div.product .woocommerce-tabs ul.tabs li::after {
  display: none !important;
}
.woocommerce div.product .woocommerce-tabs ul.tabs li {
  background: none !important;
  border: none !important;
  border-radius: 0 !important;
  margin: 0 !important;
  padding: 0 !important;
  float: none !important;
}
.woocommerce div.product .woocommerce-tabs ul.tabs li a {
  font-family: var(--dtw-mid) !important;
  font-size: 0.8125rem !important;
  font-weight: 700 !important;
  letter-spacing: 0.09em !important;
  text-transform: uppercase !important;
  color: var(--dtw-muted) !important;
  padding: 0 28px 18px !important;
  display: block !important;
  text-decoration: none !important;
  border-bottom: 2px solid transparent !important;
  margin-bottom: -1px !important;
  transition: color 0.2s ease, border-color 0.2s ease !important;
}
.woocommerce div.product .woocommerce-tabs ul.tabs li.active a,
.woocommerce div.product .woocommerce-tabs ul.tabs li a:hover {
  color: var(--dtw-navy) !important;
  border-bottom-color: var(--dtw-gold) !important;
}
.woocommerce div.product .woocommerce-tabs ul.tabs li:first-child a {
  padding-left: 0 !important;
}

/* Tab content */
.woocommerce div.product .woocommerce-tabs .panel {
  font-family: var(--dtw-sans) !important;
  font-size: 1rem !important;
  line-height: 1.8 !important;
  color: var(--dtw-body) !important;
  border: none !important;
  padding: 0 !important;
  margin: 0 !important;
  background: transparent !important;
  box-shadow: none !important;
}
.woocommerce div.product .woocommerce-tabs .panel h2 {
  font-size: 1.25rem !important;
  margin-bottom: 16px !important;
}

/* WooCommerce attributes table */
.woocommerce table.shop_attributes {
  width: 100% !important;
  border-collapse: collapse !important;
}
.woocommerce table.shop_attributes th,
.woocommerce table.shop_attributes td {
  font-family: var(--dtw-sans) !important;
  font-size: 0.9375rem !important;
  padding: 12px 0 !important;
  border-bottom: 1px solid var(--dtw-border) !important;
  vertical-align: top !important;
}
.woocommerce table.shop_attributes th {
  font-weight: 700 !important;
  color: var(--dtw-navy) !important;
  width: 38% !important;
  background: transparent !important;
}
.woocommerce table.shop_attributes td {
  color: var(--dtw-muted) !important;
}

/* Related / Upsell products */
.woocommerce .related.products,
.woocommerce .up-sells.upsells {
  margin-top: 72px !important;
  padding-top: 64px !important;
  border-top: 1px solid var(--dtw-border) !important;
}
.woocommerce .related.products > h2,
.woocommerce .up-sells.upsells > h2 {
  font-family: var(--dtw-serif) !important;
  font-size: clamp(1.5rem, 2.5vw, 2.25rem) !important;
  color: var(--dtw-navy) !important;
  letter-spacing: -0.02em !important;
  margin-bottom: 32px !important;
}


/* ═══════════════════════════════════════════════════════════
   8. BLOG — LISTING PAGE
   ─────────────────────────────────────────────────────────
   Works with: Elementor Posts widget (skin: Cards)
   ═══════════════════════════════════════════════════════════ */

/* Card */
.elementor-posts--skin-cards .elementor-post__card {
  background: var(--dtw-white) !important;
  border: 1px solid var(--dtw-border) !important;
  border-radius: var(--dtw-radius-lg) !important;
  overflow: hidden !important;
  box-shadow: var(--dtw-shadow-xs) !important;
  transition: transform var(--dtw-duration) var(--dtw-ease),
              box-shadow var(--dtw-duration) var(--dtw-ease),
              border-color var(--dtw-duration) var(--dtw-ease) !important;
  display: flex !important;
  flex-direction: column !important;
  height: 100% !important;
}
.elementor-posts--skin-cards .elementor-post__card:hover {
  transform: translateY(-5px) !important;
  box-shadow: var(--dtw-shadow-lg) !important;
  border-color: rgba(201,168,76,0.25) !important;
}

/* Thumbnail */
.elementor-posts--skin-cards .elementor-post__thumbnail {
  overflow: hidden !important;
  display: block !important;
}
.elementor-posts--skin-cards .elementor-post__thumbnail img {
  width: 100% !important;
  aspect-ratio: 16 / 10 !important;
  object-fit: cover !important;
  display: block !important;
  transition: transform 0.55s var(--dtw-ease) !important;
}
.elementor-posts--skin-cards .elementor-post__card:hover .elementor-post__thumbnail img {
  transform: scale(1.05) !important;
}

/* Text area */
.elementor-posts--skin-cards .elementor-post__text {
  padding: 24px 24px 28px !important;
  flex: 1 !important;
  display: flex !important;
  flex-direction: column !important;
}

/* Category badge */
.elementor-posts--skin-cards .elementor-post__badge {
  font-family: var(--dtw-mid) !important;
  font-size: 0.6875rem !important;
  font-weight: 700 !important;
  letter-spacing: 0.12em !important;
  text-transform: uppercase !important;
  color: var(--dtw-terracotta) !important;
  display: block !important;
  margin-bottom: 10px !important;
}

/* Post title */
.elementor-posts--skin-cards .elementor-post__title a {
  font-family: var(--dtw-serif) !important;
  font-size: 1.25rem !important;
  font-weight: 700 !important;
  line-height: 1.3 !important;
  letter-spacing: -0.015em !important;
  color: var(--dtw-navy) !important;
  text-decoration: none !important;
  display: block !important;
  margin-bottom: 10px !important;
  transition: color 0.2s ease !important;
}
.elementor-posts--skin-cards .elementor-post__title a:hover {
  color: var(--dtw-terracotta) !important;
}

/* Meta (date · author) */
.elementor-posts--skin-cards .elementor-post__meta-data {
  font-family: var(--dtw-sans) !important;
  font-size: 0.8125rem !important;
  color: var(--dtw-muted) !important;
  margin-bottom: 12px !important;
}

/* Excerpt */
.elementor-posts--skin-cards .elementor-post__excerpt p {
  font-family: var(--dtw-sans) !important;
  font-size: 0.9375rem !important;
  line-height: 1.68 !important;
  color: var(--dtw-muted) !important;
  margin-bottom: 0 !important;
  flex: 1 !important;
}

/* Read More — animated arrow */
.elementor-posts--skin-cards .elementor-post__read-more {
  font-family: var(--dtw-mid) !important;
  font-size: 0.8rem !important;
  font-weight: 700 !important;
  letter-spacing: 0.09em !important;
  text-transform: uppercase !important;
  color: var(--dtw-navy) !important;
  text-decoration: none !important;
  display: inline-flex !important;
  align-items: center !important;
  gap: 6px !important;
  margin-top: 20px !important;
  transition: color 0.2s ease, gap 0.2s ease !important;
}
.elementor-posts--skin-cards .elementor-post__read-more::after {
  content: '→' !important;
  display: inline-block !important;
  transition: transform 0.2s ease !important;
}
.elementor-posts--skin-cards .elementor-post__read-more:hover {
  color: var(--dtw-gold) !important;
  gap: 10px !important;
}
.elementor-posts--skin-cards .elementor-post__read-more:hover::after {
  transform: translateX(3px) !important;
}

/* ── Blog single post ── */
.single-post .entry-title,
.single-post h1.entry-title {
  font-family: var(--dtw-serif) !important;
  font-size: clamp(2rem, 4.5vw, 3.75rem) !important;
  font-weight: 700 !important;
  line-height: 1.1 !important;
  letter-spacing: -0.025em !important;
  color: var(--dtw-navy) !important;
  text-wrap: balance !important;
  margin-bottom: 28px !important;
}

.single-post .entry-content {
  font-family: var(--dtw-sans) !important;
  font-size: 1.0625rem !important;
  line-height: 1.82 !important;
  color: var(--dtw-body) !important;
  max-width: 70ch !important;
}
.single-post .entry-content h2 {
  font-size: clamp(1.5rem, 2.5vw, 2rem) !important;
  margin-top: 52px !important;
  margin-bottom: 18px !important;
}
.single-post .entry-content h3 {
  font-size: clamp(1.2rem, 2vw, 1.5rem) !important;
  margin-top: 36px !important;
  margin-bottom: 14px !important;
}
.single-post .entry-content p {
  margin-bottom: 1.5em !important;
}
.single-post .entry-content blockquote {
  border-left: 3px solid var(--dtw-gold) !important;
  padding: 16px 0 16px 24px !important;
  margin: 32px 0 !important;
  font-style: italic !important;
  color: var(--dtw-navy) !important;
}

.single-post .entry-meta {
  font-family: var(--dtw-sans) !important;
  font-size: 0.875rem !important;
  color: var(--dtw-muted) !important;
  margin-bottom: 40px !important;
  display: flex !important;
  gap: 20px !important;
  flex-wrap: wrap !important;
  align-items: center !important;
  padding-bottom: 28px !important;
  border-bottom: 1px solid var(--dtw-border) !important;
}


/* ═══════════════════════════════════════════════════════════
   9. FAQ PAGE — ACCORDION
   ─────────────────────────────────────────────────────────
   Works with: Elementor Accordion widget
   ═══════════════════════════════════════════════════════════ */

.elementor-accordion {
  border: none !important;
}

/* Each FAQ item */
.elementor-accordion .elementor-accordion-item {
  border: none !important;
  border-bottom: 1px solid var(--dtw-border) !important;
  border-radius: 0 !important;
  background: transparent !important;
  margin: 0 !important;
}
.elementor-accordion .elementor-accordion-item:first-child {
  border-top: 1px solid var(--dtw-border) !important;
}

/* Question row */
.elementor-accordion .elementor-tab-title {
  font-family: var(--dtw-mid) !important;
  font-size: 1rem !important;
  font-weight: 600 !important;
  color: var(--dtw-navy) !important;
  padding: 24px 0 !important;
  cursor: pointer !important;
  display: flex !important;
  justify-content: space-between !important;
  align-items: center !important;
  background: transparent !important;
  border: none !important;
  user-select: none !important;
  transition: color 0.2s ease !important;
}
.elementor-accordion .elementor-tab-title:hover {
  color: var(--dtw-terracotta) !important;
}

/* Icon — gold + , becomes × when open */
.elementor-accordion .elementor-accordion-icon {
  color: var(--dtw-gold) !important;
  flex-shrink: 0 !important;
  margin-left: 20px !important;
  font-size: 1.375rem !important;
  line-height: 1 !important;
  transition: transform 0.32s var(--dtw-ease),
              color 0.2s ease !important;
}
.elementor-accordion .elementor-active .elementor-accordion-icon {
  transform: rotate(45deg) !important;
  color: var(--dtw-terracotta) !important;
}
.elementor-accordion .elementor-tab-title.elementor-active .elementor-accordion-icon {
  transform: rotate(45deg) !important;
  color: var(--dtw-terracotta) !important;
}

/* Answer */
.elementor-accordion .elementor-tab-content {
  font-family: var(--dtw-sans) !important;
  font-size: 1rem !important;
  line-height: 1.78 !important;
  color: var(--dtw-muted) !important;
  padding: 0 48px 24px 0 !important;
  border: none !important;
  background: transparent !important;
}
.elementor-accordion .elementor-tab-content p {
  margin-bottom: 12px !important;
}
.elementor-accordion .elementor-tab-content p:last-child {
  margin-bottom: 0 !important;
}


/* ═══════════════════════════════════════════════════════════
   10. CONTACT PAGE
   ─────────────────────────────────────────────────────────
   Works with: Elementor Form widget + Icon Box widget
   ═══════════════════════════════════════════════════════════ */

/* Field label */
.elementor-form .elementor-field-label {
  font-family: var(--dtw-mid) !important;
  font-size: 0.8rem !important;
  font-weight: 700 !important;
  letter-spacing: 0.07em !important;
  text-transform: uppercase !important;
  color: var(--dtw-navy) !important;
  display: block !important;
  margin-bottom: 8px !important;
}

/* Field group spacing */
.elementor-form .elementor-field-group {
  margin-bottom: 22px !important;
}

/* Inputs + Textarea */
.elementor-form .elementor-field,
.elementor-form input[type="text"],
.elementor-form input[type="email"],
.elementor-form input[type="tel"],
.elementor-form input[type="url"],
.elementor-form select,
.elementor-form textarea {
  font-family: var(--dtw-sans) !important;
  font-size: 0.9375rem !important;
  color: var(--dtw-body) !important;
  background: var(--dtw-white) !important;
  border: 1.5px solid var(--dtw-border) !important;
  border-radius: var(--dtw-radius) !important;
  padding: 14px 16px !important;
  width: 100% !important;
  transition: border-color 0.2s ease, box-shadow 0.2s ease !important;
  outline: none !important;
}
.elementor-form .elementor-field:focus,
.elementor-form input[type="text"]:focus,
.elementor-form input[type="email"]:focus,
.elementor-form input[type="tel"]:focus,
.elementor-form textarea:focus {
  border-color: var(--dtw-navy) !important;
  box-shadow: 0 0 0 3px rgba(27,58,107,0.08) !important;
}
.elementor-form textarea {
  min-height: 148px !important;
  resize: vertical !important;
}

/* Placeholder colour — must pass 4.5:1 */
.elementor-form input::placeholder,
.elementor-form textarea::placeholder {
  color: #909090 !important;
}

/* Submit button */
.elementor-form .elementor-button[type="submit"] {
  font-family: var(--dtw-mid) !important;
  font-size: 0.875rem !important;
  font-weight: 700 !important;
  letter-spacing: 0.1em !important;
  text-transform: uppercase !important;
  background: var(--dtw-navy) !important;
  color: var(--dtw-white) !important;
  border: 2px solid var(--dtw-navy) !important;
  border-radius: var(--dtw-radius) !important;
  padding: 16px 44px !important;
  cursor: pointer !important;
  transition: background var(--dtw-duration) var(--dtw-ease),
              box-shadow var(--dtw-duration) var(--dtw-ease),
              transform var(--dtw-duration) var(--dtw-ease) !important;
  width: 100% !important;
  display: block !important;
}
.elementor-form .elementor-button[type="submit"]:hover {
  background: var(--dtw-navy-deep) !important;
  border-color: var(--dtw-navy-deep) !important;
  box-shadow: 0 10px 32px rgba(27,58,107,0.28) !important;
  transform: translateY(-2px) !important;
}

/* Contact info icon boxes */
.elementor-widget-icon-box .elementor-icon {
  color: var(--dtw-gold) !important;
}
.elementor-widget-icon-box .elementor-icon-box-title {
  font-family: var(--dtw-mid) !important;
  font-size: 0.8rem !important;
  font-weight: 700 !important;
  letter-spacing: 0.08em !important;
  text-transform: uppercase !important;
  color: var(--dtw-muted) !important;
  margin-bottom: 6px !important;
}
.elementor-widget-icon-box .elementor-icon-box-description {
  font-family: var(--dtw-sans) !important;
  font-size: 1rem !important;
  color: var(--dtw-body) !important;
  line-height: 1.55 !important;
}


/* ═══════════════════════════════════════════════════════════
   11. REDUCED MOTION — Required for a11y
   ═══════════════════════════════════════════════════════════ */
@media (prefers-reduced-motion: reduce) {
  *,
  *::before,
  *::after {
    animation-duration: 0.01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.01ms !important;
  }

  .elementor-widget-slides::after {
    display: none !important;
  }

  .woocommerce ul.products li.product:hover,
  .elementor-posts--skin-cards .elementor-post__card:hover {
    transform: none !important;
  }
}


/* ═══════════════════════════════════════════════════════════
   12. RESPONSIVE
   ═══════════════════════════════════════════════════════════ */

/* Tablet (≤1024px) */
@media (max-width: 1024px) {
  .woocommerce ul.products {
    grid-template-columns: repeat(auto-fill, minmax(220px, 1fr)) !important;
    gap: 20px !important;
  }

  .woocommerce div.product {
    grid-template-columns: 1fr !important;
    column-gap: 0 !important;
  }
  .woocommerce div.product div.images {
    position: static !important;
  }
}

/* Mobile (≤768px) */
@media (max-width: 768px) {
  .elementor-widget-slides .elementor-slides-wrapper,
  .elementor-widget-slides .swiper-container,
  .elementor-widget-slides .swiper {
    min-height: 80vh !important;
  }

  .elementor-slide-heading {
    font-size: clamp(2rem, 9vw, 2.75rem) !important;
  }

  .elementor-slide-description {
    font-size: 0.9375rem !important;
    max-width: 100% !important;
  }

  .woocommerce ul.products {
    grid-template-columns: repeat(2, 1fr) !important;
    gap: 14px !important;
  }

  .elementor-posts--skin-cards .elementor-post__text {
    padding: 18px 18px 22px !important;
  }

  .woocommerce div.product form.cart {
    flex-direction: column !important;
  }
  .woocommerce div.product form.cart .qty {
    width: 100% !important;
  }
}

/* Small mobile (≤480px) */
@media (max-width: 480px) {
  .woocommerce ul.products {
    grid-template-columns: 1fr !important;
    gap: 16px !important;
  }
}/* End custom CSS */