/* =========================================
   ELARA — SHOP PAGE CLEAN WHITE PRO
   file: /assets/css/shop.css
========================================= */

:root {
  --lux-surface: #ffffff;
  --lux-surface-soft: #f7f5f1;
  --lux-surface-warm: #fbfaf7;

  --lux-text: #111111;
  --lux-text-soft: rgba(17, 17, 17, .62);
  --lux-text-dim: rgba(17, 17, 17, .42);

  --lux-line: rgba(17, 17, 17, .10);
  --lux-line-strong: rgba(17, 17, 17, .18);

  --lux-accent: #c6a15b;
  --lux-accent-dark: #8d6a2f;
  --lux-purple: #7b4dff;

  --lux-radius-sm: 14px;
  --lux-radius-md: 22px;
  --lux-radius-lg: 34px;
  --lux-radius-pill: 999px;

  --lux-shadow-soft: 0 18px 50px rgba(17, 17, 17, .06);
  --lux-shadow-card: 0 26px 80px rgba(17, 17, 17, .10);

  --lux-shell-x: clamp(18px, 4vw, 72px);
  --lux-sidebar-w: 220px;
  --lux-gap-shell: clamp(34px, 5vw, 86px);
  --lux-gap-grid: clamp(18px, 2vw, 30px);
}

/* =========================================
   PAGE BASE
========================================= */

body.woocommerce,
body.woocommerce-page {
  background: var(--lux-surface);
  color: var(--lux-text);
}

body.woocommerce #page,
body.woocommerce-page #page,
body.woocommerce .site,
body.woocommerce-page .site {
  background: var(--lux-surface);
  overflow-x: clip;
}

body.woocommerce .site-main,
body.woocommerce-page .site-main {
  background: var(--lux-surface);
  padding-top: clamp(24px, 4vw, 52px);
  padding-bottom: clamp(70px, 8vw, 130px);
  padding: 0 150px 0 150px;
}

/* =========================================
   FULL WIDTH CONTAINER FIX
========================================= */

.woocommerce-page .col-full {
  width: 100% !important;
  max-width: 100% !important;
  margin: 0 !important;
  padding-left: var(--lux-shell-x) !important;
  padding-right: var(--lux-shell-x) !important;
}

/* =========================================
   SHOP SHELL
========================================= */

.lux-shop-shell {
  width: min(1640px, 100%);
  margin: 0 auto;

  display: grid;
  grid-template-columns: var(--lux-sidebar-w) minmax(0, 1fr);
  gap: var(--lux-gap-shell);
  align-items: start;
}

/* =========================================
   SIDEBAR CATEGORIES
========================================= */

.lux-cat {
  position: sticky;
  top: calc(var(--header-h, 88px) + 34px);
  align-self: start;
  padding-top: 8px;
}

.lux-cat__nav {
  display: grid;
  gap: 30px;
}

.lux-cat__group {
  padding-bottom: 24px;
  border-bottom: 1px solid var(--lux-line);
}

.lux-cat__group:last-child {
  border-bottom: 0;
}

.lux-cat__root {
  display: inline-flex;
  align-items: center;
  gap: 10px;

  color: var(--lux-text);
  text-decoration: none;

  font-size: 11px;
  font-weight: 700;
  line-height: 1.2;
  letter-spacing: .18em;
  text-transform: uppercase;

  transition:
    color .22s ease,
    transform .22s ease;
}

.lux-cat__root::before {
  content: "";
  width: 6px;
  height: 6px;
  flex: 0 0 6px;

  border-radius: 999px;
  background: var(--lux-accent);
  opacity: .45;

  transition:
    opacity .22s ease,
    transform .22s ease;
}

.lux-cat__root:hover,
.lux-cat__root.is-current {
  color: var(--lux-accent-dark);
  transform: translateX(2px);
}

.lux-cat__root:hover::before,
.lux-cat__root.is-current::before {
  opacity: 1;
  transform: scale(1.25);
}

.lux-cat__list {
  list-style: none;
  margin: 15px 0 0 16px;
  padding: 0;

  display: grid;
  gap: 9px;
}

.lux-cat__list a {
  display: inline-block;

  color: var(--lux-text-soft);
  text-decoration: none;

  font-size: 13px;
  line-height: 1.35;

  transition:
    color .22s ease,
    transform .22s ease;
}

.lux-cat__list a:hover,
.lux-cat__list a.is-current {
  color: var(--lux-text);
  transform: translateX(2px);
}

/* =========================================
   MAIN AREA
========================================= */

.lux-main {
  min-width: 0;
}

/* =========================================
   TOPBAR — ORDERING ONLY
========================================= */

.lux-shop-topbar {
  display: flex;
  align-items: center;
  justify-content: flex-end;

  margin-bottom: clamp(22px, 3vw, 38px);
}

.lux-shop-topbar__right {
  display: flex;
  align-items: center;
  justify-content: flex-end;
}

.lux-shop-topbar .woocommerce-ordering {
  position: relative;
  margin: 0 !important;
}

.lux-shop-topbar .orderby {
  appearance: none;
  -webkit-appearance: none;

  height: 44px;
  min-width: 230px;

  border: 1px solid var(--lux-line);
  border-radius: var(--lux-radius-pill);

  background: #fff;
  color: var(--lux-text);

  padding: 0 46px 0 18px;

  font-size: 10px;
  font-weight: 700;
  letter-spacing: .14em;
  text-transform: uppercase;

  cursor: pointer;
  outline: none;

  box-shadow: 0 10px 34px rgba(17, 17, 17, .04);

  transition:
    border-color .22s ease,
    box-shadow .22s ease,
    transform .22s ease;
}

.lux-shop-topbar .woocommerce-ordering::after {
  content: "▾";
  position: absolute;
  right: 18px;
  top: 50%;

  transform: translateY(-50%);
  pointer-events: none;

  color: var(--lux-text-soft);
  font-size: 12px;
}

.lux-shop-topbar .orderby:hover,
.lux-shop-topbar .orderby:focus {
  border-color: var(--lux-accent);
  box-shadow: 0 16px 44px rgba(198, 161, 91, .12);
  transform: translateY(-1px);
}

/* =========================================
   PRODUCT GRID
========================================= */

.woocommerce ul.products {
  margin: 0 !important;
  padding: 0 !important;

  display: grid !important;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: var(--lux-gap-grid);

  background: transparent;
}

.woocommerce ul.products::before,
.woocommerce ul.products::after {
  content: none !important;
  display: none !important;
}

.woocommerce ul.products li.product {
  float: none !important;
  width: auto !important;
  min-width: 0;

  margin: 0 !important;
  padding: 0 !important;
}

/* =========================================
   MINIMAL PAGINATION
========================================= */

.woocommerce nav.woocommerce-pagination {
  display: none !important;
}

.lux-min-pagination {
  width: 100%;

  margin-top: clamp(42px, 5vw, 78px);
  padding-top: clamp(24px, 3vw, 42px);

  display: flex;
  align-items: center;
  justify-content: center;
  gap: clamp(28px, 4vw, 52px);

  font-family: var(--lux-font-body, Inter, system-ui, sans-serif);
}

.lux-min-pagination__label {
  color: #000;

  font-size: clamp(16px, 1.3vw, 20px);
  font-weight: 500;
  line-height: 1;
  letter-spacing: -0.02em;

  white-space: nowrap;
}

.lux-min-pagination__arrow {
  width: 44px;
  height: 44px;

  display: inline-flex;
  align-items: center;
  justify-content: center;

  color: #000;
  text-decoration: none;

  border: 0;
  background: transparent;

  transition:
    color .2s ease,
    transform .2s ease,
    opacity .2s ease;
}

.lux-min-pagination__arrow svg {
  width: 34px;
  height: 34px;
}

.lux-min-pagination__arrow path {
  fill: none;
  stroke: currentColor;
  stroke-width: 1.65;
  stroke-linecap: round;
  stroke-linejoin: round;
}

.lux-min-pagination__arrow:hover {
  color: var(--lux-accent);
  transform: translateY(-1px);
}

.lux-min-pagination__arrow.is-disabled {
  color: rgba(0, 0, 0, .22);
  pointer-events: none;
}



/* =========================================
   SIDEBAR CATEGORIES — DESKTOP NORMAL / MOBILE ACCORDION
========================================= */

.lux-cat {
  position: sticky;
  top: calc(var(--header-h, 88px) + 34px);
  align-self: start;
  padding-top: 8px;
}

.lux-cat__nav {
  display: grid;
  gap: 30px;
}

.lux-cat__group {
  padding-bottom: 24px;
  border-bottom: 1px solid var(--lux-line);
}

.lux-cat__group:last-child {
  border-bottom: 0;
}

/* desktop link */
.lux-cat__root {
  display: inline-flex;
  align-items: center;
  gap: 10px;

  color: var(--lux-text);
  text-decoration: none;

  font-size: 11px;
  font-weight: 700;
  line-height: 1.2;
  letter-spacing: .18em;
  text-transform: uppercase;

  transition: color .22s ease, transform .22s ease;
}

.lux-cat__root::before {
  content: "";
  width: 6px;
  height: 6px;
  flex: 0 0 6px;

  border-radius: 999px;
  background: var(--lux-accent);
  opacity: .45;

  transition: opacity .22s ease, transform .22s ease;
}

.lux-cat__root:hover,
.lux-cat__root.is-current {
  color: var(--lux-accent-dark);
  transform: translateX(2px);
}

.lux-cat__root:hover::before,
.lux-cat__root.is-current::before {
  opacity: 1;
  transform: scale(1.25);
}

/* mobile button hidden on desktop */
.lux-cat__toggle {
  display: none;
}

/* desktop panel/list always visible */
.lux-cat__panel {
  display: block;
}

.lux-cat__all {
  display: none;
}

.lux-cat__list {
  list-style: none;
  margin: 15px 0 0 16px;
  padding: 0;

  display: grid;
  gap: 9px;
}

.lux-cat__list a {
  display: inline-block;

  color: var(--lux-text-soft);
  text-decoration: none;

  font-size: 13px;
  line-height: 1.35;

  transition: color .22s ease, transform .22s ease;
}

.lux-cat__list a:hover,
.lux-cat__list a.is-current {
  color: var(--lux-text);
  transform: translateX(2px);
}

@media (max-width: 980px) {
  .lux-shop-shell {
    grid-template-columns: 1fr;
    gap: 28px;
  }

  .lux-cat {
    position: relative;
    top: auto;

    padding: 0 0 18px;
    border-bottom: 1px solid var(--lux-line);
  }

  .lux-cat__nav {
    display: grid;
    gap: 10px;
  }

  .lux-cat__group {
    padding: 0;
    border-bottom: 0;
  }

  /* desktop link nascosto su mobile */
  .lux-cat__root {
    display: none;
  }

  /* mobile toggle visibile */
  .lux-cat__toggle {
    width: 100%;
    min-height: 48px;

    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 14px;

    padding: 0 16px;

    border: 1px solid var(--lux-line);
    border-radius: var(--lux-radius-pill);
    background: #fff;
    color: var(--lux-text);

    text-align: left;
    cursor: pointer;

    font-size: 10px;
    font-weight: 700;
    line-height: 1.2;
    letter-spacing: .14em;
    text-transform: uppercase;

    transition:
      color .22s ease,
      background .22s ease,
      border-color .22s ease;
  }

  .lux-cat__chev {
    display: inline-flex;
    align-items: center;
    justify-content: center;

    width: 22px;
    height: 22px;

    border-radius: 999px;
    border: 1px solid var(--lux-line);
    color: var(--lux-text-soft);

    font-size: 14px;
    font-weight: 400;
    line-height: 1;
  }

  .lux-cat__group.is-open .lux-cat__toggle {
    background: var(--lux-text);
    border-color: var(--lux-text);
    color: #fff;
  }

  .lux-cat__group.is-open .lux-cat__chev {
    background: #fff;
    border-color: #fff;
    color: var(--lux-text);
  }

  /* su mobile panel chiuso di default */
  .lux-cat__panel {
    display: none;
  }

  .lux-cat__group.is-open .lux-cat__panel {
    display: block;

    margin-top: 10px;
    padding: 14px;

    border: 1px solid var(--lux-line);
    border-radius: 22px;
    background: var(--lux-surface-soft);
  }

  .lux-cat__all {
    display: inline-block;
    margin-bottom: 12px;

    color: var(--lux-accent-dark);
    text-decoration: none;

    font-size: 10px;
    font-weight: 700;
    letter-spacing: .12em;
    text-transform: uppercase;

    border-bottom: 1px solid currentColor;
    padding-bottom: 4px;
  }

  .lux-cat__list {
    display: flex;
    flex-wrap: nowrap;
    gap: 8px;

    margin: 0;
    padding: 0 0 2px;

    overflow-x: auto;
    overflow-y: hidden;

    scrollbar-width: none;
    -webkit-overflow-scrolling: touch;
  }

  .lux-cat__list::-webkit-scrollbar {
    display: none;
  }

  .lux-cat__list li {
    flex: 0 0 auto;
  }

  .lux-cat__list a {
    display: inline-flex;
    align-items: center;
    justify-content: center;

    min-height: 36px;
    padding: 0 13px;

    border: 1px solid var(--lux-line);
    border-radius: var(--lux-radius-pill);
    background: #fff;

    color: var(--lux-text-soft);

    font-size: 12px;
    line-height: 1;
    white-space: nowrap;
  }

  .lux-cat__list a:hover,
  .lux-cat__list a.is-current {
    color: var(--lux-text);
    border-color: var(--lux-accent);
    transform: none;
  }
}

/* =========================================
   SHOP AFTER SECTIONS
   Se usi “Dalla selezione Elara” sotto la griglia
========================================= */

.lux-shop-featured,
.lux-shop-related {
  margin-top: clamp(64px, 8vw, 120px);
  padding-top: clamp(42px, 5vw, 76px);
  border-top: 1px solid var(--lux-line);
}

.lux-shop-related {
  margin-top: clamp(52px, 6vw, 90px);
}

.lux-home-products__inner {
  width: 100%;
}

.lux-home-products__head {
  max-width: 720px;
  margin-bottom: clamp(28px, 4vw, 46px);
}

.lux-home-products__kicker {
  display: inline-block;
  margin-bottom: 12px;

  color: var(--lux-accent-dark);

  font-size: 11px;
  font-weight: 700;
  letter-spacing: .18em;
  text-transform: uppercase;
}

.lux-home-products__head h2 {
  margin: 0;

  color: var(--lux-text);

  font-family: var(--lux-font-display, Georgia, serif);
  font-size: clamp(34px, 4.5vw, 72px);
  font-weight: 500;
  line-height: .96;
  letter-spacing: -.045em;
}

.lux-home-products__head p {
  max-width: 520px;
  margin: 18px 0 0;

  color: var(--lux-text-soft);

  font-size: 15px;
  line-height: 1.7;
}

.lux-home-products__grid .woocommerce {
  width: 100%;
}

.lux-home-products__grid ul.products {
  margin: 0 !important;
  padding: 0 !important;

  display: grid !important;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: var(--lux-gap-grid);
}

.lux-home-products__grid ul.products::before,
.lux-home-products__grid ul.products::after {
  content: none !important;
  display: none !important;
}

.lux-home-products__grid ul.products li.product {
  float: none !important;
  width: auto !important;
  margin: 0 !important;
  padding: 0 !important;
}

/* =========================================
   RESPONSIVE
========================================= */

@media (min-width: 1500px) {
  :root {
    --lux-sidebar-w: 240px;
    --lux-gap-shell: clamp(48px, 5vw, 96px);
  }

  .woocommerce ul.products {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
}

@media (max-width: 1200px) {
  :root {
    --lux-sidebar-w: 190px;
    --lux-gap-shell: 34px;
    --lux-gap-grid: 20px;
  }

  .woocommerce ul.products {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }

  .lux-home-products__grid ul.products {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
}

@media (max-width: 980px) {
  :root {
    --lux-shell-x: clamp(16px, 4vw, 28px);
    --lux-gap-grid: 18px;
  }
body.woocommerce-page .site-main {
  padding: 0 10px 0 10px;
}
  .lux-shop-shell {
    grid-template-columns: 1fr;
    gap: 28px;
  }

  .lux-cat {
    position: relative;
    top: auto;

    padding: 0 0 18px;
    border-bottom: 1px solid var(--lux-line);

    overflow: hidden;
  }

  .lux-cat__nav {
    display: flex;
    flex-wrap: nowrap;
    gap: 14px;

    overflow-x: auto;
    overflow-y: hidden;

    padding: 2px 0 8px;

    scroll-snap-type: x proximity;
    scrollbar-width: none;
    -webkit-overflow-scrolling: touch;
  }

  .lux-cat__nav::-webkit-scrollbar {
    display: none;
  }

  .lux-cat__group {
    flex: 0 0 min(280px, 78vw);

    padding: 14px;
    border: 1px solid var(--lux-line);
    border-radius: 22px;
    background: #fff;

    scroll-snap-align: start;
  }

  .lux-cat__root {
    min-height: auto;
    padding: 0;

    border: 0;
    border-radius: 0;
    background: transparent;

    font-size: 10px;
    letter-spacing: .16em;
    white-space: normal;
  }

  .lux-cat__root::before {
    display: inline-block;
  }

  .lux-cat__list {
    display: flex;
    flex-wrap: nowrap;
    gap: 8px;

    margin: 14px 0 0;
    padding: 0;

    overflow-x: auto;
    overflow-y: hidden;

    scrollbar-width: none;
    -webkit-overflow-scrolling: touch;
  }

  .lux-cat__list::-webkit-scrollbar {
    display: none;
  }

  .lux-cat__list li {
    flex: 0 0 auto;
  }

  .lux-cat__list a {
    display: inline-flex;
    align-items: center;
    justify-content: center;

    min-height: 34px;
    padding: 0 12px;

    border: 1px solid var(--lux-line);
    border-radius: var(--lux-radius-pill);
    background: var(--lux-surface-soft);

    color: var(--lux-text-soft);
    font-size: 12px;
    line-height: 1;
    white-space: nowrap;

    transition:
      color .22s ease,
      border-color .22s ease,
      background .22s ease,
      transform .22s ease;
  }

  .lux-cat__list a:hover,
  .lux-cat__list a.is-current {
    color: var(--lux-text);
    border-color: var(--lux-accent);
    background: #fff;
    transform: translateY(-1px);
  }

  .lux-shop-topbar {
    margin-bottom: 24px;
  }
}


@media (max-width: 760px) {
  body.woocommerce .site-main,
  body.woocommerce-page .site-main {
    padding-top: 22px;
    padding-bottom: 72px;
  }

  .woocommerce ul.products {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 16px;
  }

  .lux-home-products__grid ul.products {
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 16px;
  }

  .lux-shop-topbar,
  .lux-shop-topbar__right,
  .lux-shop-topbar .woocommerce-ordering,
  .lux-shop-topbar .orderby {
    width: 100%;
  }

  .lux-shop-topbar .orderby {
    min-width: 0;
  }

  .lux-min-pagination {
    gap: 20px;
    margin-top: 36px;
  }

  .lux-min-pagination__label {
    font-size: 15px;
  }

  .lux-min-pagination__arrow {
    width: 38px;
    height: 38px;
  }

  .lux-min-pagination__arrow svg {
    width: 30px;
    height: 30px;
  }

  .lux-home-products__head h2 {
    font-size: clamp(32px, 11vw, 48px);
  }
}

@media (max-width: 420px) {
  :root {
    --lux-shell-x: 14px;
    --lux-gap-grid: 12px;
  }

  .woocommerce ul.products {
    gap: 12px;
  }

  .lux-home-products__grid ul.products {
    gap: 12px;
  }

  .woocommerce ul.products li.product .woocommerce-loop-product__title {
    font-size: 13px;
  }

  .woocommerce ul.products li.product .price {
    font-size: 13px;
  }
}

/* =========================================
   FOOTER SAFETY
========================================= */

body.woocommerce footer,
body.woocommerce .site-footer,
body.woocommerce-page footer,
body.woocommerce-page .site-footer {
  clear: both;
}