/*
 Theme Name:   STL Watches Child Theme
 Theme URI:    https://woopy.ancorathemes.com/
 Description:  STL Watches Child Theme
 Author:       AncoraThemes
 Author URI:   http://ancorathemes.com
 Template:     woopy
 Version:      1.0
 Tags:         flexible-header, custom-background, custom-colors, custom-header, custom-menu, featured-image-header, featured-images, full-width-template, microformats, post-formats, theme-options, threaded-comments, translation-ready
 Text Domain:  woopy
*/

/* =Child-Theme customization starts here
------------------------------------------------------------ */

input[type="file"] {
  border: 1px solid var(--border);
  border-radius: 0px;
  padding: 0.5rem 1rem;
  background: var(--cream);
  box-shadow: 0 2px 12px rgba(0, 0, 0, 0.05);
  margin-top: 1.5rem;
}

/* Generic content cards — Woopy palette: cream, warm ink, gold edge */
.card {
  --card-radius: 2px;
  --card-pad-y: 1.25rem;
  --card-pad-x: 1.5rem;
  box-sizing: border-box;
  position: relative;
  display: flex;
  flex-direction: column;
  min-height: 0;
  color: var(--ink-mid);
  background: linear-gradient(
    180deg,
    var(--white) 0%,
    var(--cream) 42%,
    var(--cream) 100%
  );
  border: 1px solid var(--border);
  border-radius: var(--card-radius);
  padding: var(--card-pad-y) var(--card-pad-x);
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.9),
    0 1px 2px rgba(26, 23, 20, 0.04),
    0 10px 28px -6px rgba(26, 23, 20, 0.07),
    0 0 0 1px rgba(184, 150, 90, 0.06);
  transition:
    border-color 0.25s var(--ease),
    box-shadow 0.25s var(--ease);
}

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

/* Use on links / clickable cards only — avoids hover flash on static panels */
@media (hover: hover) {
  .card--interactive:hover {
    border-color: var(--border-on);
    box-shadow:
      inset 0 1px 0 rgba(255, 255, 255, 0.95),
      0 2px 4px rgba(26, 23, 20, 0.05),
      0 14px 36px -8px rgba(26, 23, 20, 0.09),
      0 0 0 1px rgba(184, 150, 90, 0.12);
  }

  .card--interactive.card--accent:hover {
    box-shadow:
      inset 0 1px 0 rgba(255, 255, 255, 0.9),
      0 2px 6px rgba(26, 23, 20, 0.06),
      0 14px 40px -8px rgba(184, 150, 90, 0.16),
      0 0 0 1px rgba(184, 150, 90, 0.18);
  }
}

.card > :first-child {
  margin-top: 0;
}

.card > :last-child {
  margin-bottom: 0;
}

.card--compact {
  --card-pad-y: 0.75rem;
  --card-pad-x: 1rem;
}

.card--flush {
  padding: 0;
  overflow: hidden;
}

.card--accent {
  border-color: var(--border-on);
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.85),
    0 1px 2px rgba(26, 23, 20, 0.05),
    0 10px 28px -6px rgba(184, 150, 90, 0.12),
    0 0 0 1px rgba(184, 150, 90, 0.1);
}

.card__title {
  margin: 0 0 0.5rem;
  font-size: 1.05rem;
  font-weight: 600;
  letter-spacing: 0.02em;
  color: var(--ink);
}

.card__meta {
  margin: 0 0 0.75rem;
  font-size: 0.8125rem;
  color: var(--ink-soft);
  letter-spacing: 0.03em;
  text-transform: uppercase;
}

/* Equal-height cards:
 * - Plain HTML: put `card-row` on the wrapper around the three columns (each column may wrap its .card in an extra div).
 * - Elementor: add CSS class `card-row` on the section, *or* on the inner `.elementor-container` if you prefer. */
.card-row:not(.elementor-section):not(.elementor-container) {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 1.5rem;
  align-items: stretch;
}

.card-row.elementor-section > .elementor-container,
.card-row.elementor-container {
  display: grid !important;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 1.5rem;
  align-items: stretch;
  width: 100%;
}

@media (max-width: 991px) {
  .card-row:not(.elementor-section):not(.elementor-container),
  .card-row.elementor-section > .elementor-container,
  .card-row.elementor-container {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 575px) {
  .card-row:not(.elementor-section):not(.elementor-container),
  .card-row.elementor-section > .elementor-container,
  .card-row.elementor-container {
    grid-template-columns: 1fr;
  }
}

/* Grid cells: flex column so .card can grow to full row height */
.card-row:not(.elementor-section) > * {
  display: flex;
  flex-direction: column;
  min-width: 0;
}

.card-row:not(.elementor-section) > .card,
.card-row:not(.elementor-section) > * .card {
  flex: 1 1 auto;
  width: 100%;
  min-height: 100%;
}

/* Elementor columns: flex chain down to .card */
.card-row.elementor-section > .elementor-container > .elementor-column,
.card-row.elementor-container > .elementor-column {
  display: flex;
  flex-direction: column;
  min-width: 0;
  align-self: stretch;
}

.card-row.elementor-section
  > .elementor-container
  > .elementor-column
  > .elementor-widget-wrap,
.card-row.elementor-container > .elementor-column > .elementor-widget-wrap {
  display: flex;
  flex-direction: column;
  flex: 1 1 auto;
  min-height: 0;
  width: 100%;
}

.card-row.elementor-section
  > .elementor-container
  > .elementor-column
  > .elementor-widget-wrap
  > .elementor-element,
.card-row.elementor-container
  > .elementor-column
  > .elementor-widget-wrap
  > .elementor-element {
  flex: 1 1 auto;
  display: flex;
  flex-direction: column;
  min-height: 0;
}

.card-row.elementor-section
  > .elementor-container
  > .elementor-column
  > .elementor-widget-wrap
  > .elementor-element
  .card,
.card-row.elementor-container
  > .elementor-column
  > .elementor-widget-wrap
  > .elementor-element
  .card {
  flex: 1 1 auto;
  min-height: 100%;
  width: 100%;
}

/* Optional: push footer/actions to bottom inside a tall card */
.card__footer {
  margin-top: auto;
  padding-top: 1rem;
}

/* Remove woolentor stock indicator */
.woolentor-product-addtocart .stock {
  display: none;
}
/* END */

/* Product card: stock indicator top-right (same style as blocks/stock-indicator) */
.stl-product-card {
  position: relative;
}

.stl-product-card__stock-indicator {
  position: absolute;
  top: 10px;
  right: 10px;
  z-index: 5;
  pointer-events: none;
}

.stl-product-card__inner {
  position: relative;
}

.stl-product-card.product .post_item .post_featured {
  /* background: #ebebeb; */
  background: #fff;
  margin-bottom: 0px;
  padding: 1rem 0;
}

/*
 * Shop search layout: theme uses 2 fixed columns for /shop?s=... while shop has responsive grid.
 * body.stl-shop-search is added by functions.php when search runs on shop.
 * Override theme's float/flex layout with responsive grid (4→3→2→1 cols) to match shop.
 */
body.stl-shop-search ul.products {
  display: grid !important;
  grid-template-columns: repeat(4, 1fr) !important;
  gap: 1.5rem;
}
body.stl-shop-search ul.products li.product {
  width: auto !important;
  float: none !important;
  flex: unset !important;
  clear: none !important;
}
@media (max-width: 1200px) {
  body.stl-shop-search ul.products {
    grid-template-columns: repeat(3, 1fr) !important;
  }
}
@media (max-width: 768px) {
  body.stl-shop-search ul.products {
    grid-template-columns: repeat(2, 1fr) !important;
  }
}
@media (max-width: 480px) {
  body.stl-shop-search ul.products {
    grid-template-columns: 1fr !important;
  }
}

:root {
  --gold: #b8965a;
  --gold-lt: #d4af72;
  --gold-pale: #f5ede0;
  --gold-dim: rgba(184, 150, 90, 0.18);
  --ink: #1a1714;
  --ink-mid: #4a3f38;
  --ink-soft: #8c7f76;
  --border: rgba(184, 150, 90, 0.22);
  --border-on: rgba(184, 150, 90, 0.65);
  --white: #ffffff;
  --cream: #faf8f4;
  --error: #c0392b;
  --ease: cubic-bezier(0.4, 0, 0.2, 1);
  --blue: #2563eb;
  --blue-lt: #3b82f6;
  --blue-pale: #eff6ff;
  --blue-dim: rgba(37, 99, 235, 0.15);
}

/* Stock indicator: backorder = "On Request" — inviting gold from theme */
.stl-stock-indicator--on-backorder {
  color: var(--gold);
  /* background-color: var(--gold-pale); */
  box-shadow: 0 2px 12px var(--gold-dim);
}

/* Stock indicator: out of stock = "Contact for Pricing" — inviting blue */
.stl-stock-indicator--out-of-stock {
  color: var(--blue);
  background-color: var(--blue-pale);
  box-shadow: 0 2px 12px var(--blue-dim);
}

/* old custom css*/

/* hide template widgets in mobile */
.menu_mobile_widgets_area .extra_item {
  display: none !important;
}
.socials_mobile {
  display: none !important;
}
/*  */
.single_product_custom_text_style .custom_icons_1,
.single_product_custom_text_style .custom_icons_3 {
  display: none !important;
}

.single_product_custom_text_after_price {
  display: none !important;
}

.product-template-default .slider_outer {
  display: none !important;
}

.sc_layouts_row_fixed_ater_scroll * {
}

/*  header black on home */
.home [data-elementor-id="2253"] > section:nth-of-type(1) *,
.home [data-elementor-id="2253"] > section:nth-of-type(2),
.home [data-id="4a79826"] {
  background: black;
}

.home [data-elementor-id="2253"] > section:nth-of-type(2) *,
.home [data-elementor-id="2253"] > section:nth-of-type(1) *,
.home [data-id="4a79826"] * {
  color: white !important;
}

.home .slider_wrap {
  background: black;
}

@media (max-width: 787px) {
  #product-main {
    flex-direction: column-reverse;
  }
}

#product-main .woocommerce.sidebar_hide div.product div.images,
.woocommerce-page.sidebar_hide div.product div.images,
.woocommerce.sidebar_hide #content div.product div.images,
.woocommerce-page.sidebar_hide #content div.product div.images {
  width: 100% !important;
}

#product-main .wp-post-image {
  height: 100% !important;
  max-height: 700px !important;
  width: auto !important;
}

#product-info {
  justify-content: center;
}

.woolentor-product-additional-info h2 {
  display: none;
}

.single-product .page_content_wrap {
  padding-top: 0 !important;
}

/*  tailwind */
.sr-only {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border-width: 0;
}

.visible {
  visibility: visible;
}

.fixed {
  position: fixed;
}

.absolute {
  position: absolute;
}

.relative {
  position: relative;
}

.left-8 {
  left: 2rem;
}

.top-\[calc\(100\%\+0rem\)\] {
  top: calc(100% + 0rem);
}

.m-0 {
  margin: 0px;
}

.mx-auto {
  margin-left: auto;
  margin-right: auto;
}

.mb-0 {
  margin-bottom: 0px;
}

.mb-12 {
  margin-bottom: 3rem;
}

.mb-16 {
  margin-bottom: 4rem;
}

.mb-2 {
  margin-bottom: 0.5rem;
}

.mb-3 {
  margin-bottom: 0.75rem;
}

.mb-4 {
  margin-bottom: 1rem;
}

.mb-6 {
  margin-bottom: 1.5rem;
}

.mb-8 {
  margin-bottom: 2rem;
}

.ml-2 {
  margin-left: 0.5rem;
}

.ml-8 {
  margin-left: 2rem;
}

.mr-2 {
  margin-right: 0.5rem;
}

.mr-4 {
  margin-right: 1rem;
}

.mr-8 {
  margin-right: 2rem;
}

.mt-1 {
  margin-top: 0.25rem;
}

.mt-12 {
  margin-top: 3rem;
}

.mt-16 {
  margin-top: 4rem;
}

.mt-4 {
  margin-top: 1rem;
}

.mt-6 {
  margin-top: 1.5rem;
}

.mt-8 {
  margin-top: 2rem;
}

.mt-\[5px\] {
  margin-top: 5px;
}

.block {
  display: block;
}

.inline-block {
  display: inline-block;
}

.flex {
  display: flex;
}

.grid {
  display: grid;
}

.hidden {
  display: none;
}

.h-5 {
  height: 1.25rem;
}

.h-6 {
  height: 1.5rem;
}

.h-\[23px\] {
  height: 23px;
}

.h-auto {
  height: auto;
}

.max-h-\[100px\] {
  max-height: 100px;
}

.min-h-screen {
  min-height: 100vh;
}

.w-5 {
  width: 1.25rem;
}

.w-6 {
  width: 1.5rem;
}

.w-\[11px\] {
  width: 11px;
}

.w-\[23px\] {
  width: 23px;
}

.w-\[268px\] {
  width: 268px;
}

.w-full {
  width: 100%;
}

.max-w-2xl {
  max-width: 42rem;
}

.max-w-none {
  max-width: none;
}

.flex-1 {
  flex: 1 1 0%;
}

.transform {
  transform: translate(var(--tw-translate-x), var(--tw-translate-y))
    rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y))
    scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y));
}

.cursor-pointer {
  cursor: pointer;
}

.list-none {
  list-style-type: none;
}

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

.flex-col {
  flex-direction: column;
}

.flex-wrap {
  flex-wrap: wrap;
}

.items-center {
  align-items: center;
}

.justify-end {
  justify-content: flex-end;
}

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

.justify-between {
  justify-content: space-between;
}

.gap-2 {
  gap: 0.5rem;
}

.gap-4 {
  gap: 1rem;
}

.gap-6 {
  gap: 1.5rem;
}

.gap-8 {
  gap: 2rem;
}

.gap-\[9px\] {
  gap: 9px;
}

.gap-px {
  gap: 1px;
}

.space-y-6 > :not([hidden]) ~ :not([hidden]) {
  --tw-space-y-reverse: 0;
  margin-top: calc(1.5rem * calc(1 - var(--tw-space-y-reverse)));
  margin-bottom: calc(1.5rem * var(--tw-space-y-reverse));
}

.space-y-8 > :not([hidden]) ~ :not([hidden]) {
  --tw-space-y-reverse: 0;
  margin-top: calc(2rem * calc(1 - var(--tw-space-y-reverse)));
  margin-bottom: calc(2rem * var(--tw-space-y-reverse));
}

.rounded {
  border-radius: 0.25rem;
}

.rounded-full {
  border-radius: 9999px;
}

.rounded-lg {
  border-radius: 8px;
}

.border {
  border-width: 1px;
}

.border-b {
  border-bottom-width: 1px;
}

.border-r {
  border-right-width: 1px;
}

.border-t {
  border-top-width: 1px;
}

.border-none {
  border-style: none;
}

.border-\[\#232323\] {
  --tw-border-opacity: 1;
  border-color: rgb(35 35 35 / var(--tw-border-opacity, 1));
}

.border-black\/20 {
  border-color: rgb(0 0 0 / 0.2);
}

.border-border {
  --tw-border-opacity: 1;
  border-color: rgb(224 224 224 / var(--tw-border-opacity, 1));
}

.border-gray-700 {
  --tw-border-opacity: 1;
  border-color: rgb(55 65 81 / var(--tw-border-opacity, 1));
}

.bg-accent {
  --tw-bg-opacity: 1;
  background-color: rgb(26 26 26 / var(--tw-bg-opacity, 1));
}

.bg-black {
  --tw-bg-opacity: 1;
  background-color: rgb(0 0 0 / var(--tw-bg-opacity, 1));
}

.bg-button {
  --tw-bg-opacity: 1;
  background-color: rgb(26 26 26 / var(--tw-bg-opacity, 1));
}

.bg-transparent {
  background-color: transparent;
}

.bg-white {
  --tw-bg-opacity: 1;
  background-color: rgb(255 255 255 / var(--tw-bg-opacity, 1));
}

.p-0 {
  padding: 0px;
}

.p-2 {
  padding: 0.5rem;
}

.p-5 {
  padding: 1.25rem;
}

.p-6 {
  padding: 1.5rem;
}

.px-16 {
  padding-left: 4rem;
  padding-right: 4rem;
}

.px-2\.5 {
  padding-left: 0.625rem;
  padding-right: 0.625rem;
}

.px-4 {
  padding-left: 1rem;
  padding-right: 1rem;
}

.px-6 {
  padding-left: 1.5rem;
  padding-right: 1.5rem;
}

.py-1\.5 {
  padding-top: 0.375rem;
  padding-bottom: 0.375rem;
}

.py-12 {
  padding-top: 3rem;
  padding-bottom: 3rem;
}

.py-16 {
  padding-top: 4rem;
  padding-bottom: 4rem;
}

.py-2\.5 {
  padding-top: 0.625rem;
  padding-bottom: 0.625rem;
}

.py-3 {
  padding-top: 0.75rem;
  padding-bottom: 0.75rem;
}

.py-4 {
  padding-top: 1rem;
  padding-bottom: 1rem;
}

.py-8 {
  padding-top: 2rem;
  padding-bottom: 2rem;
}

.pb-6 {
  padding-bottom: 1.5rem;
}

.pb-8 {
  padding-bottom: 2rem;
}

.pt-12 {
  padding-top: 3rem;
}

.pt-4 {
  padding-top: 1rem;
}

.pt-6 {
  padding-top: 1.5rem;
}

.text-left {
  text-align: left;
}

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

.text-right {
  text-align: right;
}

.text-2xl {
  font-size: 1.5rem;
}

.text-3xl {
  font-size: 1.875rem;
}

.text-4xl {
  font-size: 2.25rem;
}

.text-\[13px\] {
  font-size: 13px;
}

.text-\[15px\] {
  font-size: 15px;
}

.text-base {
  font-size: 1rem;
}

.text-lg {
  font-size: 1.125rem;
}

.text-sm {
  font-size: 0.875rem;
}

.text-xs {
  font-size: 0.75rem;
}

.font-bold {
  font-weight: 700;
}

.font-light {
  font-weight: 300;
}

.font-medium {
  font-weight: 500;
}

.font-normal {
  font-weight: 400;
}

.font-semibold {
  font-weight: 600;
}

.uppercase {
  text-transform: uppercase;
}

.leading-\[18px\] {
  line-height: 18px;
}

.leading-relaxed {
  line-height: 1.75;
}

.tracking-wider {
  letter-spacing: 0.05em;
}

.text-accent {
  --tw-text-opacity: 1;
  color: rgb(26 26 26 / var(--tw-text-opacity, 1));
}

.text-black {
  --tw-text-opacity: 1;
  color: rgb(0 0 0 / var(--tw-text-opacity, 1));
}

.text-black\/80 {
  color: rgb(0 0 0 / 0.8);
}

.text-gray-400 {
  --tw-text-opacity: 1;
  color: rgb(156 163 175 / var(--tw-text-opacity, 1));
}

.text-primary-text {
  --tw-text-opacity: 1;
  color: rgb(26 26 26 / var(--tw-text-opacity, 1));
}

.text-text-secondary {
  --tw-text-opacity: 1;
  color: rgb(102 102 102 / var(--tw-text-opacity, 1));
}

.text-white {
  --tw-text-opacity: 1;
  color: rgb(255 255 255 / var(--tw-text-opacity, 1));
}

.underline {
  text-decoration-line: underline;
}

.no-underline {
  text-decoration-line: none;
}

.outline {
  outline-style: solid;
}

.transition {
  transition-property:
    color, background-color, border-color, text-decoration-color, fill, stroke,
    opacity, box-shadow, transform, filter, backdrop-filter;
  transition-timing-function: cubic-bezier(0.4, 0, 0.2, 1);
  transition-duration: 150ms;
}

.transition-all {
  transition-property: all;
  transition-timing-function: cubic-bezier(0.4, 0, 0.2, 1);
  transition-duration: 150ms;
}

.duration-300 {
  transition-duration: 300ms;
}

.transition-base {
  transition-property: all;
  transition-duration: 200ms;
  transition-timing-function: cubic-bezier(0.4, 0, 0.2, 1);
}

/* Screen reader only */

.sr-only {
  position: absolute;
  margin: -1px;
  height: 1px;
  width: 1px;
  overflow: hidden;
  padding: 0px;
  white-space: nowrap;
  border-width: 0px;
  clip: rect(0, 0, 0, 0);
}

.sr-only:focus {
  position: static;
  margin: 0px;
  height: auto;
  width: auto;
  overflow: visible;
  padding: 0px;
  white-space: normal;
  clip: auto;
}

/**
 * Custom Base Styles
 */

/**
 * Custom Components
 */

/**
 * Custom Utilities
 */

.hover\:border-primary-text:hover {
  --tw-border-opacity: 1;
  border-color: rgb(26 26 26 / var(--tw-border-opacity, 1));
}

.hover\:bg-button-hover:hover {
  --tw-bg-opacity: 1;
  background-color: rgb(51 51 51 / var(--tw-bg-opacity, 1));
}

.hover\:text-accent-hover:hover {
  --tw-text-opacity: 1;
  color: rgb(51 51 51 / var(--tw-text-opacity, 1));
}

.hover\:text-primary-text:hover {
  --tw-text-opacity: 1;
  color: rgb(26 26 26 / var(--tw-text-opacity, 1));
}

.hover\:shadow-lg:hover {
  --tw-shadow: 0 10px 15px rgba(0, 0, 0, 0.1);
  --tw-shadow-colored: 0 10px 15px var(--tw-shadow-color);
  box-shadow:
    var(--tw-ring-offset-shadow, 0 0 #0000), var(--tw-ring-shadow, 0 0 #0000),
    var(--tw-shadow);
}

.focus\:not-sr-only:focus {
  position: static;
  width: auto;
  height: auto;
  padding: 0;
  margin: 0;
  overflow: visible;
  clip: auto;
  white-space: normal;
}

.focus\:absolute:focus {
  position: absolute;
}

.focus\:left-0:focus {
  left: 0px;
}

.focus\:top-0:focus {
  top: 0px;
}

.focus\:z-50:focus {
  z-index: 50;
}

.focus\:bg-black:focus {
  --tw-bg-opacity: 1;
  background-color: rgb(0 0 0 / var(--tw-bg-opacity, 1));
}

.focus\:p-2:focus {
  padding: 0.5rem;
}

.focus\:text-white:focus {
  --tw-text-opacity: 1;
  color: rgb(255 255 255 / var(--tw-text-opacity, 1));
}

@media (min-width: 768px) {
  .md\:block {
    display: block;
  }

  .md\:hidden {
    display: none;
  }

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

  .md\:grid-cols-3 {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }

  .md\:flex-row {
    flex-direction: row;
  }
}

@media (min-width: 1024px) {
  .lg\:grid-cols-2 {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .lg\:grid-cols-3 {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }

  .lg\:gap-12 {
    gap: 3rem;
  }
}

/* BANER FULL SCREEN - HEADER */
.banner {
  min-height: calc(100vh - 227px);
}

@media (min-width: 768px) {
  .banner {
    min-height: calc(100vh - 187px);
  }
}

/*
 */

 .outofstock_label {
  display: none !important;
 }

 /*  */

/* header.top_panel [data-elementor-type="cpt_layouts"] section:nth-of-type(1) {

  border-bottom: 1px solid #262626;
} */
