/* ===== Sleep Moon — Extras CSS (v1.1) ===== */

/* Category bento - use background image with overlay */
.cat-card {
  position: relative;
  overflow: hidden;
}
.cat-overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(to bottom, rgba(0,0,0,0.1) 0%, rgba(0,0,0,0.55) 100%);
  z-index: 1;
}
.cat-card .cat-content {
  z-index: 2;
  position: relative;
}

/* Cart popup notification (top right) */
.cart-popup {
  position: fixed;
  top: 100px;
  right: 24px;
  width: 360px;
  max-width: calc(100vw - 32px);
  background: white;
  border-radius: 16px;
  box-shadow: 0 16px 48px rgba(0,0,0,0.2);
  padding: 20px;
  z-index: 1300;
  opacity: 0;
  transform: translateX(400px);
  transition: opacity .3s, transform .3s ease;
  pointer-events: none;
}
.cart-popup.show {
  opacity: 1;
  transform: translateX(0);
  pointer-events: auto;
}
.cart-popup-head {
  display: flex;
  align-items: center;
  gap: 10px;
  margin-bottom: 12px;
  padding-bottom: 12px;
  border-bottom: 1px solid var(--border);
}
.cart-popup-head strong { flex: 1; font-size: 15px; }
.cart-popup-close {
  background: var(--soft);
  border: none;
  width: 28px;
  height: 28px;
  border-radius: 50%;
  cursor: pointer;
}
.cart-popup-item {
  display: flex;
  gap: 12px;
  align-items: center;
  margin-bottom: 14px;
}
.cart-popup-item img {
  width: 56px;
  height: 56px;
  object-fit: contain;
  background: var(--soft);
  border-radius: 8px;
}
.cart-popup-emoji {
  width: 56px;
  height: 56px;
  background: var(--soft);
  border-radius: 8px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 28px;
}
.cart-popup-name {
  font-size: 14px;
  font-weight: 600;
}
.cart-popup-price {
  font-size: 14px;
  color: var(--accent-hot);
  font-weight: 700;
  margin-top: 2px;
}
.cart-popup-actions {
  display: flex;
  gap: 8px;
}
.cart-popup-actions .btn {
  padding: 10px 16px;
  font-size: 13px;
}

/* Quantity dropdown */
.qty-select-wrap {
  display: flex;
  align-items: center;
}
.qty-select {
  padding: 12px 16px;
  border: 2px solid var(--border);
  border-radius: 12px;
  font-size: 15px;
  font-weight: 700;
  background: white;
  cursor: pointer;
}

/* Drawer mobile - better category styling */
@media (max-width: 900px) {
  .drawer-link {
    padding: 14px 20px;
    font-size: 15px;
    border-left: 4px solid transparent;
    display: flex;
    align-items: center;
    gap: 12px;
  }
  .drawer-link .icon {
    font-size: 22px;
    flex-shrink: 0;
  }
  .drawer-link .badge-mini {
    margin-left: auto;
    background: var(--soft);
    color: var(--text-light);
    border-radius: 999px;
    padding: 2px 9px;
    font-size: 11px;
    font-weight: 700;
  }
  .drawer-section {
    background: var(--soft);
    margin: 8px 0 0;
    padding: 10px 20px;
    color: var(--primary);
    font-weight: 800;
    font-size: 11px;
    letter-spacing: 1.5px;
    border-top: 1px solid var(--border);
    border-bottom: 1px solid var(--border);
  }
  .drawer-link.hot { background: linear-gradient(90deg, rgba(255,71,87,0.08), transparent); }

  /* Cart popup mobile: from top center */
  .cart-popup {
    top: 80px;
    right: 16px;
    left: 16px;
    width: auto;
    max-width: none;
  }
}

/* Checkout button — mare, auriu, vizibil ca un buton real */
.btn-checkout-big,
.wc-proceed-to-checkout .checkout-button,
.wc-proceed-to-checkout .button.checkout,
.woocommerce-cart .wc-proceed-to-checkout a,
.woocommerce-cart .wc-proceed-to-checkout .button,
#place_order {
  background: var(--accent) !important;
  color: var(--night) !important;
  padding: 16px 28px !important;
  font-size: 16px !important;
  font-weight: 800 !important;
  border-radius: 999px !important;
  width: 100% !important;
  text-align: center !important;
  text-transform: none !important;
  text-decoration: none !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  gap: 8px !important;
  box-shadow: 0 8px 24px rgba(255,184,77,0.5) !important;
  border: none !important;
  transition: transform .2s, box-shadow .2s !important;
  cursor: pointer;
  line-height: 1.2;
}
.btn-checkout-big:hover,
.wc-proceed-to-checkout .checkout-button:hover,
.woocommerce-cart .wc-proceed-to-checkout a:hover,
#place_order:hover {
  transform: translateY(-2px) !important;
  box-shadow: 0 12px 32px rgba(255,184,77,0.6) !important;
  background: var(--accent) !important;
  color: var(--night) !important;
}

/* Asterisc roșu lângă fiecare câmp obligatoriu */
.woocommerce form .form-row.validate-required > label > .required,
.woocommerce form .form-row .required,
.required {
  color: var(--accent-hot) !important;
  font-weight: 800;
  margin-left: 3px;
}
.woocommerce form .form-row.validate-required > label::after {
  content: ' *';
  color: var(--accent-hot);
  font-weight: 800;
}
.woocommerce form .form-row.woocommerce-validated > label::after,
.woocommerce form .form-row.woocommerce-invalid > label::after { content: none; }

/* Ascunde marcajul "(optional)" și "opțional" peste tot */
.woocommerce form .form-row label .optional,
.woocommerce-checkout .optional {
  display: none !important;
}

/* Ascunde descrierile detaliate din cart-ul WC default (caz când plugin extern le adaugă) */
.woocommerce-cart-form .product-name .product-short-description,
.woocommerce-cart-form .product-name .wc-product-shop-loop-short-desc,
.woocommerce-cart-form .product-name > p,
.wc-block-cart-item__short-description,
.woocommerce-cart-form td.product-name p:not(.stock):not([class*="variation"]) {
  display: none !important;
}

/* În rezumatul de checkout, ascunde orice descriere de produs */
.woocommerce-checkout-review-order .product-name p,
.woocommerce-checkout-review-order .wc-item-meta {
  display: none !important;
}
.woocommerce-checkout-review-order .product-name .variation,
.woocommerce-checkout-review-order .product-name dl.variation {
  display: block !important;
}

/* Cart item meta — show only relevant configured fields */
.woocommerce-cart-form .product-name dl.variation dt,
.woocommerce-cart-form .product-name dl.variation dd {
  font-size: 13px;
}
.woocommerce-cart-form .product-name .wc-item-meta {
  margin-top: 4px;
}

/* My Account redesign - own wrapper because we removed .woocommerce wrapper */
.sleepmoon-account-wrap {
  display: grid;
  grid-template-columns: 280px 1fr;
  gap: 24px;
  padding: 40px 0;
  max-width: 1280px;
  margin: 0 auto;
}
@media (max-width: 900px) {
  .sleepmoon-account-wrap { grid-template-columns: 1fr; padding: 20px 16px; }
}

.woocommerce-MyAccount-navigation {
  background: white;
  border: 1px solid var(--border);
  border-radius: 16px;
  padding: 16px;
  height: fit-content;
  position: sticky;
  top: 160px;
}
@media (max-width: 900px) {
  .woocommerce-MyAccount-navigation { position: static; }
}
.woocommerce-MyAccount-navigation ul {
  list-style: none;
  padding: 0;
  margin: 0;
}
.woocommerce-MyAccount-navigation ul li {
  margin: 0;
}
.woocommerce-MyAccount-navigation ul li a {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 14px 16px;
  border-radius: 10px;
  font-size: 15px;
  font-weight: 600;
  color: var(--text);
  transition: all .2s;
}
.woocommerce-MyAccount-navigation ul li a:hover {
  background: var(--soft);
  color: var(--primary);
}
.woocommerce-MyAccount-navigation ul li.is-active a {
  background: var(--primary);
  color: white;
}
.woocommerce-MyAccount-navigation ul li.woocommerce-MyAccount-navigation-link--dashboard a::before,
.woocommerce-MyAccount-navigation ul li.woocommerce-MyAccount-navigation-link--orders a::before,
.woocommerce-MyAccount-navigation ul li.woocommerce-MyAccount-navigation-link--downloads a::before,
.woocommerce-MyAccount-navigation ul li.woocommerce-MyAccount-navigation-link--edit-address a::before,
.woocommerce-MyAccount-navigation ul li.woocommerce-MyAccount-navigation-link--edit-account a::before,
.woocommerce-MyAccount-navigation ul li.woocommerce-MyAccount-navigation-link--customer-logout a::before { content: ''; }

.woocommerce-MyAccount-content {
  background: white;
  border: 1px solid var(--border);
  border-radius: 16px;
  padding: 32px;
}
.woocommerce-account .woocommerce {
  display: grid;
  grid-template-columns: 280px 1fr;
  gap: 24px;
  padding: 40px 0;
}
@media (max-width: 900px) {
  .woocommerce-account .woocommerce {
    grid-template-columns: 1fr;
  }
}

/* Hide Dezvoltare category */
.product_cat-dezvoltare,
.menu-item a[href*="/dezvoltare/"],
.cat-item.cat-item-dezvoltare {
  display: none !important;
}

/* Configurator: prevent layout shift when materials hidden */
.config-opts { min-height: 60px; }
.config-opt.is-hidden,
#material-options .material-aroma[hidden],
#material-options[data-size="70x70"] .material-aroma {
  display: none !important;
}

.menu-item a[href*="/paturi/"],
.drawer-link[href*="/paturi/"],
.nav-list a[href*="/paturi/"] {
  display: none !important;
}
.menu-item:has(a[href*="/paturi/"]),
.nav-list li:has(a[href*="/paturi/"]) {
  display: none !important;
}

/* Required field marker (red asterisk) */
.required {
  color: var(--accent-hot);
  font-weight: 700;
}

/* Filter button highlight when filters active */
.mobile-filter-bar button.has-active::after {
  content: '';
  display: inline-block;
  width: 8px;
  height: 8px;
  background: var(--accent-hot);
  border-radius: 50%;
  margin-left: 6px;
}

/* ===========================================================
   BLOCK-BASED CART/CHECKOUT OVERRIDES (WooCommerce 8+ blocks)
   Aplicate doar dacă userul ține pagina Cart/Checkout pe blocuri
   În loc de shortcode-uri.
   =========================================================== */

/* Ascunde descrierile scurte din block cart */
.wc-block-cart-item__short-description,
.wc-block-cart-items__row .wc-block-components-product-details,
.wc-block-components-product-details,
.wc-block-cart-items__row p:not([class*="price"]):not([class*="quantity"]),
.wc-block-mini-cart__items p {
  display: none !important;
}

/* Buton "Continuă cu finalizarea comenzii" - block cart */
.wp-block-woocommerce-proceed-to-checkout-block .wc-block-cart__submit-button,
.wp-block-woocommerce-proceed-to-checkout-block button,
.wc-block-cart__submit-container button,
.wc-block-components-checkout-place-order-button,
.wc-block-components-button.wc-block-cart__submit-button {
  background: var(--accent) !important;
  color: var(--night) !important;
  padding: 16px 28px !important;
  font-size: 16px !important;
  font-weight: 800 !important;
  border-radius: 999px !important;
  width: 100% !important;
  text-align: center !important;
  text-transform: none !important;
  border: none !important;
  box-shadow: 0 8px 24px rgba(255,184,77,0.5) !important;
}
.wp-block-woocommerce-proceed-to-checkout-block .wc-block-cart__submit-button:hover,
.wc-block-components-checkout-place-order-button:hover {
  transform: translateY(-2px) !important;
  background: var(--accent) !important;
  color: var(--night) !important;
}

/* Telefon obligatoriu (block-based) - ascunde "(optional)" */
.wc-block-components-text-input label .wc-block-components-text-input__optional,
.wc-block-components-checkout-step .optional,
.wc-block-components-form .optional {
  display: none !important;
}

/* Asterisc roșu lângă fiecare label de input (block cart) */
.wc-block-components-text-input label::after,
.wc-block-components-select label::after,
.wc-block-components-form label::after {
  content: ' *';
  color: var(--accent-hot);
  font-weight: 800;
}

/* Ascunde descrierile din checkout block order summary */
.wc-block-components-order-summary-item__description,
.wc-block-components-order-summary-item p:not(.wc-block-components-product-price) {
  display: none !important;
}

/* Notice "Nu este disponibilă nicio metodă de plată" — stilizare mai prietenoasă */
.wc-block-components-notice-banner.is-error,
.woocommerce-error {
  border-radius: 12px !important;
  border-left: 4px solid var(--accent-hot) !important;
}

/* ===========================================================
   v1.4 — Side Cart panel (slide-in din dreapta, stil iStyle)
   =========================================================== */

.side-cart-bg {
  position: fixed; inset: 0;
  background: rgba(0,0,0,0.55);
  z-index: 1399;
  opacity: 0; visibility: hidden;
  transition: opacity .3s;
}
.side-cart-bg.open { opacity: 1; visibility: visible; }

.side-cart {
  position: fixed;
  top: 0; right: -480px; bottom: 0;
  width: 460px;
  max-width: 92vw;
  background: white;
  z-index: 1400;
  transition: right .35s cubic-bezier(.16,1,.3,1);
  display: flex;
  flex-direction: column;
  box-shadow: -10px 0 40px rgba(0,0,0,0.2);
}
.side-cart.open { right: 0; }

.side-cart-head {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 18px 20px;
  border-bottom: 1px solid var(--border);
}
.side-cart-continue {
  background: none;
  border: none;
  color: var(--primary);
  font-weight: 600;
  font-size: 14px;
  cursor: pointer;
  padding: 4px 8px;
}
.side-cart-continue:hover { text-decoration: underline; }
.side-cart-close {
  background: var(--soft);
  border: none;
  width: 36px;
  height: 36px;
  border-radius: 50%;
  cursor: pointer;
  font-size: 16px;
}
.side-cart-close:hover { background: var(--accent-hot); color: white; }

.side-cart-body {
  flex: 1;
  overflow-y: auto;
  padding: 24px 20px;
}

.side-cart-success {
  display: flex;
  align-items: center;
  gap: 12px;
  margin-bottom: 24px;
}
.side-cart-success .success-icon {
  width: 32px;
  height: 32px;
  background: var(--success);
  color: white;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-weight: 800;
  font-size: 18px;
  flex-shrink: 0;
}
.side-cart-success strong {
  font-size: 22px;
  color: var(--night);
}

.side-cart-item {
  display: flex;
  gap: 14px;
  align-items: center;
  padding-bottom: 24px;
  border-bottom: 1px solid var(--border);
}
.side-cart-item img {
  width: 80px;
  height: 80px;
  object-fit: contain;
  background: var(--soft);
  border-radius: 12px;
  flex-shrink: 0;
}
.side-cart-emoji {
  width: 80px;
  height: 80px;
  background: var(--soft);
  border-radius: 12px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 36px;
  flex-shrink: 0;
}
.side-cart-info { flex: 1; }
.side-cart-name {
  font-size: 16px;
  font-weight: 700;
  color: var(--night);
  margin-bottom: 4px;
}
.side-cart-price {
  font-size: 16px;
  color: var(--accent-hot);
  font-weight: 800;
}

.side-cart-footer {
  padding: 20px;
  border-top: 1px solid var(--border);
  background: var(--soft);
}
.side-cart-subtotal {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding-bottom: 14px;
  font-size: 16px;
}
.side-cart-subtotal strong {
  font-size: 20px;
  font-weight: 800;
  color: var(--night);
}

.btn-side-cart {
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  background: var(--primary) !important;
  color: white !important;
  padding: 16px !important;
  border-radius: 999px !important;
  font-size: 16px !important;
  font-weight: 700 !important;
  text-decoration: none !important;
  margin-bottom: 10px !important;
  transition: background .2s, transform .2s !important;
}
.btn-side-cart:hover {
  background: var(--primary-dark) !important;
  transform: translateY(-2px);
}

.btn-side-checkout {
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  gap: 6px !important;
  background: var(--accent) !important;
  color: var(--night) !important;
  padding: 16px !important;
  border-radius: 999px !important;
  font-size: 16px !important;
  font-weight: 800 !important;
  text-decoration: none !important;
  box-shadow: 0 8px 24px rgba(255,184,77,0.4) !important;
  transition: transform .2s, box-shadow .2s !important;
}
.btn-side-checkout:hover {
  transform: translateY(-2px);
  box-shadow: 0 12px 32px rgba(255,184,77,0.6) !important;
}

@media (max-width: 600px) {
  .side-cart { width: 100%; max-width: 100%; right: -100%; }
}

/* ===========================================================
   v1.4 — Cart page polish
   =========================================================== */

.woocommerce-cart .woocommerce {
  max-width: 1280px;
  margin: 0 auto;
  padding: 32px 24px;
}
.woocommerce-cart .shop_table {
  background: white;
  border: 1px solid var(--border);
  border-radius: 16px;
  overflow: hidden;
  box-shadow: 0 4px 16px rgba(0,0,0,0.04);
}
.woocommerce-cart .shop_table thead {
  background: var(--soft);
}
.woocommerce-cart .shop_table th {
  padding: 16px 20px;
  font-size: 12px;
  text-transform: uppercase;
  letter-spacing: 1px;
  color: var(--text-light);
  font-weight: 700;
}
.woocommerce-cart .shop_table td {
  padding: 20px;
  vertical-align: middle;
  border-top: 1px solid var(--border);
}
.woocommerce-cart .product-thumbnail img {
  width: 80px !important;
  height: 80px !important;
  object-fit: contain;
  background: var(--soft);
  border-radius: 12px;
  padding: 4px;
}
.woocommerce-cart .product-name a {
  color: var(--night) !important;
  font-weight: 700;
  font-size: 16px;
  text-decoration: none;
}
.woocommerce-cart .product-name a:hover { color: var(--primary) !important; }
.woocommerce-cart .product-name dl.variation {
  margin-top: 8px;
  font-size: 13px;
  color: var(--text-light);
}
.woocommerce-cart .product-name dl.variation dt {
  font-weight: 700;
  display: inline;
}
.woocommerce-cart .product-name dl.variation dd {
  display: inline;
  margin: 0 8px 0 0;
}
.woocommerce-cart .product-price,
.woocommerce-cart .product-subtotal {
  font-size: 16px;
  font-weight: 700;
  color: var(--night);
}
.woocommerce-cart .cart-collaterals {
  margin-top: 32px;
  display: grid;
  grid-template-columns: 1fr 380px;
  gap: 32px;
}
.woocommerce-cart .cart_totals {
  background: white;
  border: 1px solid var(--border);
  border-radius: 16px;
  padding: 24px;
  height: fit-content;
  position: sticky;
  top: 160px;
}
.woocommerce-cart .cart_totals h2 {
  font-size: 18px;
  margin-bottom: 16px;
}
.woocommerce-cart .cart_totals .order-total .amount {
  font-size: 24px;
  font-weight: 800;
  color: var(--night);
}
@media (max-width: 900px) {
  .woocommerce-cart .cart-collaterals {
    grid-template-columns: 1fr;
  }
  .woocommerce-cart .cart_totals { position: static; }
}

/* ===========================================================
   v1.4 — Checkout polish: sticky right summary
   =========================================================== */

.woocommerce-checkout form.checkout {
  display: grid;
  grid-template-columns: 1fr 420px;
  gap: 32px;
  max-width: 1280px;
  margin: 0 auto;
  padding: 32px 24px;
}
.woocommerce-checkout #customer_details {
  background: white;
  border: 1px solid var(--border);
  border-radius: 16px;
  padding: 32px;
}
.woocommerce-checkout #order_review_heading {
  display: none;
}
.woocommerce-checkout #order_review {
  background: white;
  border: 1px solid var(--border);
  border-radius: 16px;
  padding: 24px;
  height: fit-content;
  position: sticky;
  top: 160px;
}
.woocommerce-checkout #order_review h3 {
  font-size: 20px;
  margin-bottom: 16px;
  color: var(--night);
}
.woocommerce-checkout .woocommerce-checkout-review-order-table {
  margin-bottom: 0;
}
.woocommerce-checkout .woocommerce-checkout-review-order-table th,
.woocommerce-checkout .woocommerce-checkout-review-order-table td {
  padding: 12px 0 !important;
  border-bottom: 1px solid var(--border);
}
.woocommerce-checkout .order-total td .amount {
  font-size: 24px;
  font-weight: 800;
  color: var(--night);
}
.woocommerce-checkout .col2-set {
  margin-bottom: 24px;
}
.woocommerce-checkout h3 {
  font-size: 18px;
  margin: 0 0 16px;
}

/* Form fields polish */
.woocommerce form .form-row input.input-text,
.woocommerce form .form-row textarea,
.woocommerce form .form-row select,
.select2-selection {
  padding: 12px 14px !important;
  border: 1px solid var(--border) !important;
  border-radius: 10px !important;
  font-size: 14px !important;
}
.woocommerce form .form-row input.input-text:focus,
.woocommerce form .form-row textarea:focus,
.woocommerce form .form-row select:focus {
  border-color: var(--primary) !important;
  outline: none;
}
.woocommerce form .form-row label {
  font-size: 13px;
  font-weight: 600;
  color: var(--text);
  margin-bottom: 6px;
  display: block;
}

@media (max-width: 900px) {
  .woocommerce-checkout form.checkout { grid-template-columns: 1fr; }
  .woocommerce-checkout #order_review { position: static; }
}

/* ===========================================================
   v1.4.1 FIXES — Layout & asterisc dublu
   =========================================================== */

/* FIX: elimin dublarea asteriscului (WC pune <abbr>*</abbr> + eu puneam ::after) */
.woocommerce form .form-row.validate-required > label::after,
.woocommerce-checkout form .form-row.validate-required > label::after {
  content: none !important;
}

/* Asteriscul lui WC e prin <abbr class="required"> */
.woocommerce form .form-row .required,
.woocommerce form .form-row abbr.required {
  color: var(--accent-hot) !important;
  text-decoration: none !important;
  border: none !important;
  font-weight: 800 !important;
  margin-left: 3px;
}

/* FIX: în checkout, secțiunile "Detalii facturare" și "Informații suplimentare"
   nu trebuie pe 2 coloane (sunt prea înguste). Stackuim vertical. */
.woocommerce-checkout #customer_details .col2-set,
.woocommerce-checkout .col2-set {
  display: block !important;
}
.woocommerce-checkout .col2-set .col-1,
.woocommerce-checkout .col2-set .col-2,
.woocommerce-checkout #customer_details .col-1,
.woocommerce-checkout #customer_details .col-2 {
  width: 100% !important;
  float: none !important;
  max-width: none !important;
  margin: 0 0 24px !important;
}

/* Câmpurile prenume + nume să stea pe 2 coloane (sunt complementare) */
.woocommerce form .form-row-first,
.woocommerce form .form-row-last,
.woocommerce-checkout .form-row-first,
.woocommerce-checkout .form-row-last {
  width: calc(50% - 8px) !important;
  display: inline-block !important;
  float: none !important;
  vertical-align: top;
  margin-right: 0 !important;
}
.woocommerce form .form-row-first { margin-right: 14px !important; }

/* Form-row spațiere între câmpuri */
.woocommerce form .form-row,
.woocommerce-checkout .form-row {
  margin-bottom: 18px !important;
}

/* FIX: Cart - layout 2 coloane (table stânga, total dreapta sticky) */
@media (min-width: 901px) {
  .woocommerce-cart .woocommerce {
    display: grid;
    grid-template-columns: 1fr 380px;
    gap: 32px;
    align-items: start;
    max-width: 1280px;
    margin: 0 auto;
    padding: 32px 24px;
  }
  .woocommerce-cart .woocommerce-cart-form,
  .woocommerce-cart .woocommerce-notices-wrapper {
    grid-column: 1 / 2;
  }
  .woocommerce-cart .cart-collaterals {
    grid-column: 2 / 3;
    margin-top: 0 !important;
    width: 100% !important;
    max-width: none !important;
    display: block !important;
  }
  .woocommerce-cart .cart_totals {
    width: 100% !important;
    max-width: none !important;
    float: none !important;
    position: sticky;
    top: 160px;
  }
}

/* Cart total — butonul "Continuă cu finalizarea comenzii" nu trebuie să facă wrap */
.woocommerce-cart .wc-proceed-to-checkout {
  margin-top: 16px;
}
.woocommerce-cart .wc-proceed-to-checkout .checkout-button {
  white-space: normal !important;
  line-height: 1.3 !important;
  padding: 16px 20px !important;
  font-size: 15px !important;
}

/* Cart totals - layout tabelar curat */
.woocommerce-cart .cart_totals table {
  width: 100%;
  border-collapse: separate;
  border-spacing: 0;
}
.woocommerce-cart .cart_totals table th,
.woocommerce-cart .cart_totals table td {
  padding: 12px 0 !important;
  border-bottom: 1px solid var(--border);
  border-top: none !important;
  text-align: left;
  white-space: normal;
}
.woocommerce-cart .cart_totals table td { text-align: right; }
.woocommerce-cart .cart_totals .order-total .amount {
  font-size: 24px;
  font-weight: 800;
  color: var(--night);
}

/* Notice "metoda de plata indisponibila" sub order_review — mai prietenos */
.woocommerce-checkout .woocommerce-info,
.woocommerce-checkout .woocommerce-notice {
  background: #fff8e1 !important;
  border-left: 4px solid var(--accent) !important;
  padding: 14px 16px !important;
  border-radius: 8px;
  font-size: 14px;
  margin: 16px 0;
}

/* ===========================================================
   v1.4.2 CRITICAL FIX — Cart layout cu flex + imagini vizibile
   Selectori cu body.* pentru specificitate maximă
   =========================================================== */

body.woocommerce-cart .woocommerce {
  display: flex !important;
  flex-wrap: wrap !important;
  gap: 32px !important;
  align-items: flex-start !important;
  max-width: 1280px !important;
  margin: 0 auto !important;
  padding: 32px 24px !important;
}
body.woocommerce-cart .woocommerce > .woocommerce-notices-wrapper { flex-basis: 100%; }
body.woocommerce-cart .woocommerce-cart-form {
  flex: 1 1 0 !important;
  min-width: 0 !important;
  width: auto !important;
  float: none !important;
  margin: 0 !important;
}
body.woocommerce-cart .cart-collaterals {
  flex: 0 0 380px !important;
  width: 380px !important;
  max-width: 380px !important;
  margin: 0 !important;
  float: none !important;
  display: block !important;
}
body.woocommerce-cart .cart-collaterals .cart_totals {
  width: 100% !important;
  max-width: none !important;
  float: none !important;
}
@media (max-width: 900px) {
  body.woocommerce-cart .woocommerce { flex-direction: column !important; }
  body.woocommerce-cart .cart-collaterals { flex: 1 0 100% !important; width: 100% !important; max-width: none !important; }
}

/* Cart table — imagini 80x80 vizibile, fără wrapping agresiv pe nume */
body.woocommerce-cart .shop_table {
  width: 100% !important;
  table-layout: auto !important;
  border-collapse: separate !important;
  background: white !important;
  border: 1px solid var(--border) !important;
  border-radius: 16px !important;
  overflow: hidden !important;
}
body.woocommerce-cart .shop_table thead { background: var(--soft) !important; }
body.woocommerce-cart .shop_table th,
body.woocommerce-cart .shop_table td {
  padding: 18px 20px !important;
  vertical-align: middle !important;
  white-space: normal !important;
}
body.woocommerce-cart .shop_table .product-thumbnail {
  width: 110px !important;
}
body.woocommerce-cart .shop_table .product-thumbnail img,
body.woocommerce-cart .shop_table .product-thumbnail a img {
  width: 80px !important;
  height: 80px !important;
  max-width: 80px !important;
  display: block !important;
  object-fit: contain !important;
  background: var(--soft) !important;
  border-radius: 12px !important;
  padding: 4px !important;
  margin: 0 !important;
}
body.woocommerce-cart .shop_table .product-name {
  font-size: 15px !important;
  min-width: 200px !important;
}
body.woocommerce-cart .shop_table .product-name a {
  color: var(--night) !important;
  font-weight: 700 !important;
  text-decoration: none !important;
  white-space: normal !important;
}
body.woocommerce-cart .shop_table .product-price,
body.woocommerce-cart .shop_table .product-subtotal {
  font-weight: 700 !important;
  color: var(--night) !important;
  white-space: nowrap !important;
}
body.woocommerce-cart .shop_table .product-quantity { width: 110px !important; }
body.woocommerce-cart .shop_table .product-quantity .quantity input {
  width: 70px !important;
  text-align: center !important;
  padding: 8px !important;
  border: 1px solid var(--border) !important;
  border-radius: 8px !important;
}
body.woocommerce-cart .shop_table .product-remove { width: 50px !important; text-align: center !important; }

/* Checkout — folosesc body.woocommerce-checkout pentru specificitate */
body.woocommerce-checkout form.checkout {
  display: flex !important;
  flex-wrap: wrap !important;
  gap: 32px !important;
  align-items: flex-start !important;
  max-width: 1280px !important;
  margin: 0 auto !important;
  padding: 32px 24px !important;
}
body.woocommerce-checkout #customer_details {
  flex: 1 1 0 !important;
  min-width: 0 !important;
  background: white !important;
  border: 1px solid var(--border) !important;
  border-radius: 16px !important;
  padding: 32px !important;
}
body.woocommerce-checkout #order_review,
body.woocommerce-checkout #order_review_heading {
  flex: 0 0 380px !important;
  width: 380px !important;
  max-width: 380px !important;
}
body.woocommerce-checkout #order_review {
  background: white !important;
  border: 1px solid var(--border) !important;
  border-radius: 16px !important;
  padding: 24px !important;
  position: sticky;
  top: 160px;
}
@media (max-width: 900px) {
  body.woocommerce-checkout form.checkout { flex-direction: column !important; }
  body.woocommerce-checkout #order_review,
  body.woocommerce-checkout #order_review_heading {
    flex: 1 0 100% !important; width: 100% !important; max-width: none !important; position: static;
  }
}

/* ===========================================================
   v1.4.4 — Cart NO OVERLAP via Grid + minmax(0, 1fr)
   Flexul anterior permitea overflow → folosesc grid strict
   =========================================================== */

body.woocommerce-cart .woocommerce {
  display: grid !important;
  grid-template-columns: minmax(0, 1fr) 380px !important;
  gap: 32px !important;
  align-items: flex-start !important;
  max-width: 1280px !important;
  margin: 0 auto !important;
  padding: 32px 24px !important;
  /* Resetăm flex-ul anterior care permitea overlap */
  flex-wrap: initial !important;
}
body.woocommerce-cart .woocommerce > * { min-width: 0 !important; }
body.woocommerce-cart .woocommerce-cart-form {
  grid-column: 1 !important;
  width: 100% !important;
  min-width: 0 !important;
  max-width: 100% !important;
  overflow-x: auto !important;
}
body.woocommerce-cart .cart-collaterals {
  grid-column: 2 !important;
  width: 100% !important;
  max-width: 380px !important;
  margin: 0 !important;
  float: none !important;
}
body.woocommerce-cart .cart_totals {
  width: 100% !important;
  max-width: none !important;
  position: sticky;
  top: 160px;
  background: white;
  border: 1px solid var(--border);
  border-radius: 16px;
  padding: 24px;
}
@media (max-width: 900px) {
  body.woocommerce-cart .woocommerce {
    grid-template-columns: 1fr !important;
  }
  body.woocommerce-cart .cart-collaterals {
    grid-column: 1 !important;
    max-width: none !important;
  }
  body.woocommerce-cart .cart_totals { position: static; }
}

/* Same fix pentru checkout - previne overflow */
body.woocommerce-checkout form.checkout {
  display: grid !important;
  grid-template-columns: minmax(0, 1fr) 380px !important;
  gap: 32px !important;
  align-items: flex-start !important;
  flex-wrap: initial !important;
}
body.woocommerce-checkout form.checkout > * { min-width: 0 !important; }
@media (max-width: 900px) {
  body.woocommerce-checkout form.checkout {
    grid-template-columns: 1fr !important;
  }
}

/* ===========================================================
   v1.5.0 - iStyle-inspired WooCommerce checkout surface
   =========================================================== */

body.side-cart-open {
  overflow: hidden;
}

.side-cart-bg {
  position: fixed !important;
  inset: 0 !important;
  background: rgba(0, 0, 0, 0.48) !important;
  z-index: 1399 !important;
  opacity: 0 !important;
  visibility: hidden !important;
  transition: opacity .22s ease, visibility .22s ease !important;
}

.side-cart-bg.open {
  opacity: 1 !important;
  visibility: visible !important;
}

.side-cart {
  position: fixed !important;
  top: 32px !important;
  right: min(-900px, -56vw) !important;
  bottom: 18px !important;
  width: min(900px, 56vw) !important;
  max-width: calc(100vw - 40px) !important;
  background: #fff !important;
  color: #050505 !important;
  z-index: 1400 !important;
  display: flex !important;
  flex-direction: column !important;
  border-radius: 8px 0 0 8px !important;
  box-shadow: -24px 0 60px rgba(0, 0, 0, .22) !important;
  overflow: hidden !important;
  transition: right .28s ease !important;
}

.side-cart.open {
  right: 0 !important;
}

.side-cart-head {
  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;
  gap: 16px !important;
  padding: 38px 40px 20px !important;
  border-bottom: 0 !important;
  background: #fff !important;
}

.side-cart-continue {
  appearance: none !important;
  border: 0 !important;
  background: transparent !important;
  color: #006de8 !important;
  font-size: 17px !important;
  font-weight: 700 !important;
  padding: 4px 0 !important;
}

.side-cart-continue span {
  font-size: 28px !important;
  line-height: 0 !important;
  position: relative !important;
  top: 2px !important;
}

.side-cart-close {
  appearance: none !important;
  width: 44px !important;
  height: 44px !important;
  border: 0 !important;
  border-radius: 50% !important;
  background: #fff !important;
  color: #111 !important;
  font-size: 34px !important;
  line-height: 1 !important;
  font-weight: 300 !important;
}

.side-cart-close:hover {
  background: #f4f4f4 !important;
  color: #111 !important;
}

.side-cart-body {
  flex: 1 1 auto !important;
  overflow-y: auto !important;
  padding: 18px 40px 36px !important;
  background: #fff !important;
}

.side-cart-success {
  display: flex !important;
  align-items: center !important;
  gap: 12px !important;
  margin: 0 0 28px !important;
}

.side-cart-success .success-icon {
  width: 20px !important;
  height: 20px !important;
  border-radius: 50% !important;
  background: #00a51a !important;
  position: relative !important;
  flex: 0 0 20px !important;
}

.side-cart-success .success-icon::after {
  content: '' !important;
  position: absolute !important;
  left: 6px !important;
  top: 3px !important;
  width: 7px !important;
  height: 11px !important;
  border: solid #fff !important;
  border-width: 0 2px 2px 0 !important;
  transform: rotate(45deg) !important;
}

.side-cart-success strong {
  color: #050505 !important;
  font-size: clamp(26px, 3vw, 34px) !important;
  line-height: 1.15 !important;
  font-weight: 800 !important;
}

.side-cart-item {
  display: flex !important;
  align-items: center !important;
  gap: 20px !important;
  padding: 0 0 34px !important;
  border-bottom: 1px solid #d8d8d8 !important;
  min-height: 94px !important;
}

.side-cart-product-media,
.side-cart-product-media a,
.side-cart-placeholder {
  width: 76px !important;
  height: 76px !important;
  flex: 0 0 76px !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
}

.side-cart-product-media img,
.side-cart-item img {
  width: 76px !important;
  height: 76px !important;
  object-fit: contain !important;
  padding: 2px !important;
  background: #fff !important;
  border-radius: 0 !important;
}

.side-cart-placeholder {
  background: #f5f5f7 !important;
  border-radius: 6px !important;
}

.side-cart-info {
  flex: 1 1 auto !important;
  min-width: 0 !important;
}

.side-cart-name,
.side-cart-name a {
  color: #050505 !important;
  font-size: 18px !important;
  line-height: 1.25 !important;
  font-weight: 800 !important;
  text-decoration: none !important;
}

.side-cart-price {
  color: #050505 !important;
  font-size: 15px !important;
  font-weight: 500 !important;
  margin-top: 4px !important;
}

.side-cart-item-empty {
  color: #4f4f4f !important;
  font-size: 15px !important;
}

.side-cart-suggestions {
  margin-top: 34px !important;
}

.side-cart-suggestions:empty {
  display: none !important;
}

.side-cart-suggestions-title {
  color: #050505 !important;
  font-size: 28px !important;
  line-height: 1.2 !important;
  font-weight: 800 !important;
  margin-bottom: 18px !important;
}

.side-cart-suggestions-grid {
  display: grid !important;
  gap: 14px !important;
}

.side-cart-suggestion {
  display: grid !important;
  grid-template-columns: 64px minmax(0, 1fr) !important;
  gap: 18px !important;
  align-items: center !important;
  padding: 18px 20px !important;
  border-radius: 8px !important;
  background: #f5f5f7 !important;
  color: #050505 !important;
}

.side-cart-suggestion-img img {
  width: 56px !important;
  height: 56px !important;
  object-fit: contain !important;
}

.side-cart-suggestion-copy strong,
.side-cart-suggestion-copy span {
  display: block !important;
}

.side-cart-suggestion-copy strong {
  font-size: 16px !important;
  line-height: 1.25 !important;
  margin-bottom: 4px !important;
}

.side-cart-footer {
  flex: 0 0 auto !important;
  padding: 30px 40px !important;
  border-top: 1px solid #eee !important;
  background: #f5f5f7 !important;
}

.side-cart-subtotal {
  display: flex !important;
  justify-content: space-between !important;
  gap: 18px !important;
  margin-bottom: 18px !important;
  color: #050505 !important;
}

.side-cart-subtotal span {
  font-size: 16px !important;
}

.side-cart-subtotal strong {
  color: #050505 !important;
  font-size: 20px !important;
  font-weight: 800 !important;
}

.btn-side-cart {
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  width: 100% !important;
  min-height: 62px !important;
  border-radius: 999px !important;
  background: #0877e8 !important;
  color: #fff !important;
  border: 0 !important;
  font-size: 17px !important;
  font-weight: 800 !important;
  text-align: center !important;
  text-decoration: none !important;
  box-shadow: none !important;
}

.btn-side-cart:hover {
  background: #0062c9 !important;
  color: #fff !important;
  transform: none !important;
}

@media (max-width: 900px) {
  .side-cart {
    top: 0 !important;
    right: -100% !important;
    bottom: 0 !important;
    width: 100% !important;
    max-width: 100% !important;
    border-radius: 0 !important;
  }
  .side-cart.open {
    right: 0 !important;
  }
  .side-cart-head,
  .side-cart-body,
  .side-cart-footer {
    padding-left: 24px !important;
    padding-right: 24px !important;
  }
  .side-cart-success strong {
    font-size: 28px !important;
  }
}

/* Cart page */
body.woocommerce-cart .woocommerce {
  max-width: 1240px !important;
  display: grid !important;
  grid-template-columns: minmax(0, 1fr) 360px !important;
  gap: 28px !important;
  align-items: start !important;
  padding: 40px 24px 64px !important;
}

body.woocommerce-cart .cart-collaterals {
  width: 100% !important;
  max-width: none !important;
  margin: 0 !important;
}

body.woocommerce-cart .woocommerce-cart-form,
body.woocommerce-cart .cart_totals {
  background: #fff !important;
  border: 1px solid #e6e6e6 !important;
  border-radius: 8px !important;
  box-shadow: 0 1px 2px rgba(0, 0, 0, .03) !important;
}

body.woocommerce-cart .woocommerce-cart-form {
  overflow: hidden !important;
}

body.woocommerce-cart .shop_table {
  width: 100% !important;
  border: 0 !important;
  border-radius: 0 !important;
  box-shadow: none !important;
  background: #fff !important;
}

body.woocommerce-cart .shop_table thead {
  background: #fff !important;
  border-bottom: 1px solid #e6e6e6 !important;
}

body.woocommerce-cart .shop_table th,
body.woocommerce-cart .shop_table td {
  padding: 22px 24px !important;
  color: #050505 !important;
  border-top: 0 !important;
  border-bottom: 1px solid #e6e6e6 !important;
}

body.woocommerce-cart .shop_table th {
  font-size: 13px !important;
  text-transform: none !important;
  letter-spacing: 0 !important;
  color: #6e6e73 !important;
}

body.woocommerce-cart .product-thumbnail img {
  width: 86px !important;
  height: 86px !important;
  object-fit: contain !important;
}

body.woocommerce-cart .product-name a {
  color: #050505 !important;
  font-size: 17px !important;
  font-weight: 800 !important;
}

body.woocommerce-cart .product-name dl.variation {
  color: #6e6e73 !important;
  margin-top: 8px !important;
}

body.woocommerce-cart .quantity input.qty {
  width: 74px !important;
  height: 42px !important;
  border: 1px solid #d2d2d7 !important;
  border-radius: 8px !important;
  text-align: center !important;
}

body.woocommerce-cart .product-price,
body.woocommerce-cart .product-subtotal {
  font-size: 16px !important;
  font-weight: 800 !important;
  white-space: nowrap !important;
}

body.woocommerce-cart .product-remove .remove {
  width: 34px !important;
  height: 34px !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  border-radius: 50% !important;
  background: #f5f5f7 !important;
  color: #050505 !important;
  font-size: 0 !important;
  line-height: 1 !important;
}

body.woocommerce-cart .product-remove .remove::before {
  content: '\00d7' !important;
  font-size: 24px !important;
  line-height: 1 !important;
}

body.woocommerce-cart td.actions {
  background: #fbfbfd !important;
}

body.woocommerce-cart td.actions .coupon {
  display: flex !important;
  gap: 10px !important;
  flex-wrap: wrap !important;
}

body.woocommerce-cart td.actions input.input-text {
  min-height: 44px !important;
  border: 1px solid #d2d2d7 !important;
  border-radius: 8px !important;
  padding: 0 14px !important;
}

body.woocommerce-cart .cart_totals {
  position: sticky !important;
  top: 124px !important;
  padding: 24px !important;
}

body.woocommerce-cart .cart_totals h2 {
  font-size: 24px !important;
  margin: 0 0 18px !important;
  color: #050505 !important;
}

body.woocommerce-cart .cart_totals table th,
body.woocommerce-cart .cart_totals table td {
  padding: 13px 0 !important;
  border: 0 !important;
  border-bottom: 1px solid #e6e6e6 !important;
}

body.woocommerce-cart .wc-proceed-to-checkout .checkout-button,
body.woocommerce-cart button[name="update_cart"],
body.woocommerce-cart button[name="apply_coupon"] {
  border-radius: 999px !important;
}

body.woocommerce-cart .wc-proceed-to-checkout .checkout-button {
  background: #0877e8 !important;
  color: #fff !important;
  min-height: 56px !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  font-weight: 800 !important;
}

@media (max-width: 900px) {
  body.woocommerce-cart .woocommerce {
    grid-template-columns: 1fr !important;
    padding: 24px 16px 48px !important;
  }
  body.woocommerce-cart .cart_totals {
    position: static !important;
  }
}

/* Checkout page */
body.woocommerce-checkout form.checkout.sleepmoon-checkout-layout {
  max-width: 1240px !important;
  margin: 0 auto !important;
  padding: 40px 24px 64px !important;
  display: grid !important;
  grid-template-columns: minmax(0, 1fr) 390px !important;
  gap: 28px !important;
  align-items: start !important;
}

body.woocommerce-checkout .sleepmoon-checkout-main,
body.woocommerce-checkout .sleepmoon-checkout-sidebar #order_review {
  background: #fff !important;
  border: 1px solid #e6e6e6 !important;
  border-radius: 8px !important;
  box-shadow: 0 1px 2px rgba(0, 0, 0, .03) !important;
}

body.woocommerce-checkout .sleepmoon-checkout-main {
  padding: 30px !important;
}

.sleepmoon-checkout-step {
  display: flex !important;
  align-items: center !important;
  gap: 14px !important;
  padding-bottom: 22px !important;
  margin-bottom: 26px !important;
  border-bottom: 1px solid #e6e6e6 !important;
}

.sleepmoon-checkout-step-number {
  width: 34px !important;
  height: 34px !important;
  border-radius: 50% !important;
  background: #0877e8 !important;
  color: #fff !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  font-weight: 800 !important;
}

.sleepmoon-checkout-step h2 {
  color: #050505 !important;
  font-size: 24px !important;
  line-height: 1.2 !important;
  margin: 0 0 4px !important;
}

.sleepmoon-checkout-step p {
  color: #6e6e73 !important;
  font-size: 14px !important;
  margin: 0 !important;
}

body.woocommerce-checkout .sleepmoon-checkout-main .col2-set,
body.woocommerce-checkout .sleepmoon-checkout-main .col-1,
body.woocommerce-checkout .sleepmoon-checkout-main .col-2 {
  width: 100% !important;
  float: none !important;
  max-width: none !important;
}

body.woocommerce-checkout .sleepmoon-checkout-main .col-2 {
  margin-top: 20px !important;
}

body.woocommerce-checkout .sleepmoon-checkout-sidebar {
  position: sticky !important;
  top: 124px !important;
}

body.woocommerce-checkout .sleepmoon-checkout-sidebar #order_review {
  padding: 24px !important;
  width: 100% !important;
  max-width: none !important;
  position: static !important;
}

body.woocommerce-checkout #order_review_heading {
  display: block !important;
  flex: initial !important;
  width: auto !important;
  max-width: none !important;
  position: static !important;
  color: #050505 !important;
  font-size: 23px !important;
  line-height: 1.2 !important;
  margin: 0 0 18px !important;
}

body.woocommerce-checkout .woocommerce-checkout-review-order-table {
  margin: 0 !important;
  border: 0 !important;
}

body.woocommerce-checkout .woocommerce-checkout-review-order-table th,
body.woocommerce-checkout .woocommerce-checkout-review-order-table td {
  padding: 13px 0 !important;
  border: 0 !important;
  border-bottom: 1px solid #e6e6e6 !important;
  color: #050505 !important;
  text-align: right !important;
}

body.woocommerce-checkout .woocommerce-checkout-review-order-table th {
  text-align: left !important;
  color: #6e6e73 !important;
  font-weight: 600 !important;
}

body.woocommerce-checkout .woocommerce-checkout-review-order-table .product-name {
  text-align: left !important;
}

.sm-review-product {
  display: grid !important;
  grid-template-columns: 58px minmax(0, 1fr) !important;
  gap: 12px !important;
  align-items: center !important;
}

.sm-review-product-img img {
  width: 54px !important;
  height: 54px !important;
  object-fit: contain !important;
}

.sm-review-product-copy strong {
  display: inline !important;
  color: #050505 !important;
  font-size: 14px !important;
}

.sm-review-product-copy .product-quantity {
  color: #6e6e73 !important;
  font-weight: 600 !important;
}

.sm-review-product-copy dl.variation {
  margin: 5px 0 0 !important;
  color: #6e6e73 !important;
  font-size: 12px !important;
}

.sm-review-product-copy dl.variation dt,
.sm-review-product-copy dl.variation dd {
  display: inline !important;
  margin: 0 5px 0 0 !important;
}

body.woocommerce-checkout .order-total th,
body.woocommerce-checkout .order-total td,
body.woocommerce-checkout .order-total .amount {
  color: #050505 !important;
  font-size: 22px !important;
  font-weight: 900 !important;
}

body.woocommerce-checkout #payment {
  background: transparent !important;
  border-radius: 0 !important;
  margin-top: 22px !important;
}

body.woocommerce-checkout #payment ul.payment_methods {
  padding: 0 !important;
  border: 0 !important;
}

body.woocommerce-checkout #payment li.wc_payment_method {
  background: #f5f5f7 !important;
  border-radius: 8px !important;
  padding: 14px 16px !important;
  margin-bottom: 10px !important;
}

body.woocommerce-checkout #place_order {
  width: 100% !important;
  min-height: 56px !important;
  border-radius: 999px !important;
  background: #0877e8 !important;
  color: #fff !important;
  font-size: 16px !important;
  font-weight: 800 !important;
  box-shadow: none !important;
}

body.woocommerce-checkout #place_order:hover {
  background: #0062c9 !important;
  color: #fff !important;
}

body.woocommerce-checkout .form-row input.input-text,
body.woocommerce-checkout .form-row textarea,
body.woocommerce-checkout .form-row select,
body.woocommerce-checkout .select2-selection {
  min-height: 46px !important;
  border: 1px solid #d2d2d7 !important;
  border-radius: 8px !important;
  background: #fff !important;
}

body.woocommerce-checkout .form-row label {
  color: #050505 !important;
  font-size: 13px !important;
  font-weight: 700 !important;
}

@media (max-width: 900px) {
  body.woocommerce-checkout form.checkout.sleepmoon-checkout-layout {
    grid-template-columns: 1fr !important;
    padding: 24px 16px 48px !important;
  }
  body.woocommerce-checkout .sleepmoon-checkout-sidebar {
    position: static !important;
  }
  body.woocommerce-checkout .sleepmoon-checkout-main {
    padding: 22px !important;
  }
}

/* My account */
body.woocommerce-account .sleepmoon-account-wrap {
  max-width: 1240px !important;
  margin: 0 auto !important;
  padding: 40px 24px 64px !important;
  display: grid !important;
  grid-template-columns: 280px minmax(0, 1fr) !important;
  gap: 28px !important;
}

body.woocommerce-account .woocommerce-MyAccount-navigation,
body.woocommerce-account .woocommerce-MyAccount-content,
.sleepmoon-auth-panel {
  background: #fff !important;
  border: 1px solid #e6e6e6 !important;
  border-radius: 8px !important;
  box-shadow: 0 1px 2px rgba(0, 0, 0, .03) !important;
}

body.woocommerce-account .woocommerce-MyAccount-navigation {
  padding: 12px !important;
  height: fit-content !important;
  position: sticky !important;
  top: 124px !important;
}

body.woocommerce-account .woocommerce-MyAccount-navigation ul li a {
  border-radius: 8px !important;
  color: #050505 !important;
  padding: 13px 14px !important;
  font-weight: 700 !important;
}

body.woocommerce-account .woocommerce-MyAccount-navigation ul li.is-active a {
  background: #0877e8 !important;
  color: #fff !important;
}

body.woocommerce-account .woocommerce-MyAccount-content {
  padding: 30px !important;
  color: #050505 !important;
}

body.woocommerce-account .woocommerce-MyAccount-content a {
  color: #006de8 !important;
  font-weight: 700 !important;
}

.sleepmoon-auth-wrap {
  max-width: 1040px !important;
  margin: 40px auto 64px !important;
  padding: 0 24px !important;
  display: grid !important;
  grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  gap: 24px !important;
}

.sleepmoon-auth-wrap.login-only {
  max-width: 560px !important;
  grid-template-columns: 1fr !important;
}

.sleepmoon-auth-panel {
  padding: 30px !important;
}

.sleepmoon-auth-head {
  display: flex !important;
  align-items: center !important;
  gap: 14px !important;
  padding-bottom: 22px !important;
  margin-bottom: 22px !important;
  border-bottom: 1px solid #e6e6e6 !important;
}

.sleepmoon-auth-step {
  width: 34px !important;
  height: 34px !important;
  border-radius: 50% !important;
  background: #0877e8 !important;
  color: #fff !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  font-weight: 800 !important;
}

.sleepmoon-auth-head h2 {
  color: #050505 !important;
  font-size: 24px !important;
  margin: 0 0 4px !important;
}

.sleepmoon-auth-head p,
.sleepmoon-auth-note {
  color: #6e6e73 !important;
  margin: 0 !important;
}

.sleepmoon-auth-panel input.input-text,
.sleepmoon-auth-panel input[type="email"],
.sleepmoon-auth-panel input[type="password"],
.sleepmoon-auth-panel input[type="text"] {
  width: 100% !important;
  min-height: 46px !important;
  border: 1px solid #d2d2d7 !important;
  border-radius: 8px !important;
  padding: 0 14px !important;
}

.sleepmoon-auth-actions {
  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;
  gap: 14px !important;
  flex-wrap: wrap !important;
}

.sleepmoon-auth-actions .button {
  border-radius: 999px !important;
  min-height: 46px !important;
}

@media (max-width: 900px) {
  body.woocommerce-account .sleepmoon-account-wrap,
  .sleepmoon-auth-wrap {
    grid-template-columns: 1fr !important;
    padding: 24px 16px 48px !important;
  }
  body.woocommerce-account .woocommerce-MyAccount-navigation {
    position: static !important;
  }
}

/* ===========================================================
   v1.5.1 - Coupon notice and My Account layout fixes
   =========================================================== */

body.woocommerce-checkout .woocommerce-form-coupon-toggle {
  max-width: 1240px !important;
  margin: 18px auto 0 !important;
  padding: 0 24px !important;
}

body.woocommerce-checkout .woocommerce-form-coupon-toggle .woocommerce-info {
  position: relative !important;
  display: flex !important;
  align-items: center !important;
  min-height: 56px !important;
  margin: 0 !important;
  padding: 15px 20px 15px 56px !important;
  border: 1px solid #d6e8ff !important;
  border-left: 4px solid #0877e8 !important;
  border-top: 1px solid #d6e8ff !important;
  border-radius: 8px !important;
  background: #f3f8ff !important;
  color: #1d1d1f !important;
  font-size: 15px !important;
  line-height: 1.35 !important;
  box-shadow: 0 1px 2px rgba(0, 0, 0, .03) !important;
}

body.woocommerce-checkout .woocommerce-form-coupon-toggle .woocommerce-info::before {
  content: '%' !important;
  position: absolute !important;
  left: 20px !important;
  top: 50% !important;
  width: 24px !important;
  height: 24px !important;
  transform: translateY(-50%) !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  border-radius: 50% !important;
  background: #0877e8 !important;
  color: #fff !important;
  font-size: 13px !important;
  font-weight: 800 !important;
  font-family: inherit !important;
}

body.woocommerce-checkout .woocommerce-form-coupon-toggle .showcoupon {
  color: #006de8 !important;
  font-weight: 800 !important;
  text-decoration: none !important;
}

body.woocommerce-checkout .woocommerce-form-coupon-toggle .showcoupon:hover {
  text-decoration: underline !important;
}

body.woocommerce-checkout form.checkout_coupon,
body.woocommerce-checkout form.woocommerce-form-coupon {
  max-width: 1240px !important;
  margin: 12px auto 0 !important;
  padding: 20px 24px !important;
  border: 1px solid #e6e6e6 !important;
  border-radius: 8px !important;
  background: #fff !important;
  box-shadow: 0 1px 2px rgba(0, 0, 0, .03) !important;
}

body.woocommerce-checkout form.checkout_coupon p,
body.woocommerce-checkout form.woocommerce-form-coupon p {
  margin-bottom: 12px !important;
  color: #6e6e73 !important;
}

body.woocommerce-checkout form.checkout_coupon .form-row,
body.woocommerce-checkout form.woocommerce-form-coupon .form-row {
  margin: 0 10px 0 0 !important;
}

body.woocommerce-checkout form.checkout_coupon input.input-text,
body.woocommerce-checkout form.woocommerce-form-coupon input.input-text {
  min-height: 46px !important;
  border: 1px solid #d2d2d7 !important;
  border-radius: 8px !important;
  padding: 0 14px !important;
}

body.woocommerce-checkout form.checkout_coupon button,
body.woocommerce-checkout form.woocommerce-form-coupon button {
  min-height: 46px !important;
  border-radius: 999px !important;
  background: #0877e8 !important;
  color: #fff !important;
  padding: 0 22px !important;
  font-weight: 800 !important;
}

body.woocommerce-account .woocommerce {
  display: block !important;
  max-width: none !important;
  width: 100% !important;
  margin: 0 !important;
  padding: 0 !important;
}

body.woocommerce-account .sleepmoon-account-wrap {
  width: min(100%, 1240px) !important;
  max-width: 1240px !important;
  margin: 0 auto !important;
  padding: 40px 24px 64px !important;
  display: grid !important;
  grid-template-columns: 300px minmax(0, 1fr) !important;
  gap: 32px !important;
  align-items: start !important;
}

body.woocommerce-account .woocommerce-MyAccount-navigation,
body.woocommerce-account .woocommerce-MyAccount-content {
  float: none !important;
  width: 100% !important;
  max-width: none !important;
  min-width: 0 !important;
  clear: none !important;
  box-sizing: border-box !important;
}

body.woocommerce-account .woocommerce-MyAccount-navigation {
  grid-column: 1 !important;
  overflow: visible !important;
}

body.woocommerce-account .woocommerce-MyAccount-navigation ul {
  display: grid !important;
  gap: 6px !important;
  width: 100% !important;
}

body.woocommerce-account .woocommerce-MyAccount-navigation ul li {
  width: 100% !important;
}

body.woocommerce-account .woocommerce-MyAccount-navigation ul li a {
  width: 100% !important;
  min-height: 46px !important;
  justify-content: flex-start !important;
  white-space: normal !important;
  word-break: normal !important;
  overflow-wrap: normal !important;
  line-height: 1.25 !important;
}

body.woocommerce-account .woocommerce-MyAccount-navigation ul li a::before {
  width: 22px !important;
  min-width: 22px !important;
  text-align: center !important;
}

body.woocommerce-account .woocommerce-MyAccount-content {
  grid-column: 2 !important;
  font-size: 16px !important;
  line-height: 1.65 !important;
}

body.woocommerce-account .woocommerce-MyAccount-content p {
  max-width: 720px !important;
  margin-bottom: 14px !important;
}

body.woocommerce-account .woocommerce-MyAccount-content .sm-account-avatar {
  max-width: 720px !important;
}

body.woocommerce-account .woocommerce-MyAccount-content table {
  width: 100% !important;
}

@media (max-width: 900px) {
  body.woocommerce-checkout .woocommerce-form-coupon-toggle {
    padding: 0 16px !important;
  }
  body.woocommerce-checkout form.checkout_coupon,
  body.woocommerce-checkout form.woocommerce-form-coupon {
    margin-left: 16px !important;
    margin-right: 16px !important;
  }
  body.woocommerce-account .sleepmoon-account-wrap {
    grid-template-columns: 1fr !important;
    padding: 24px 16px 48px !important;
  }
  body.woocommerce-account .woocommerce-MyAccount-navigation,
  body.woocommerce-account .woocommerce-MyAccount-content {
    grid-column: 1 !important;
  }
}

/* ===========================================================
   v1.5.2 - Checkout interface inspired by clean two-column checkout
   =========================================================== */

body.woocommerce-checkout header,
body.woocommerce-checkout nav.main-nav,
body.woocommerce-checkout .promo-bar {
  display: none !important;
}

body.woocommerce-checkout {
  background: linear-gradient(90deg, #fff 0, #fff 53%, #f5f5f5 53%, #f5f5f5 100%) !important;
}

.sleepmoon-checkout-shell {
  min-height: 100vh !important;
  background: transparent !important;
}

.sleepmoon-checkout-brandbar {
  height: 92px !important;
  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;
  max-width: 1240px !important;
  margin: 0 auto !important;
  padding: 0 24px !important;
  border-bottom: 1px solid #dedede !important;
}

.sleepmoon-checkout-logo {
  color: #050505 !important;
  font-size: 31px !important;
  line-height: 1 !important;
  font-weight: 900 !important;
  letter-spacing: 0 !important;
  text-decoration: none !important;
}

.sleepmoon-checkout-bag {
  width: 42px !important;
  height: 42px !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  border-radius: 50% !important;
}

.sleepmoon-checkout-bag span {
  width: 19px !important;
  height: 22px !important;
  border: 2px solid #006de8 !important;
  border-radius: 5px !important;
  position: relative !important;
}

.sleepmoon-checkout-bag span::before {
  content: '' !important;
  position: absolute !important;
  left: 4px !important;
  right: 4px !important;
  top: -8px !important;
  height: 10px !important;
  border: 2px solid #006de8 !important;
  border-bottom: 0 !important;
  border-radius: 8px 8px 0 0 !important;
}

body.woocommerce-checkout form.checkout.sleepmoon-checkout-layout {
  max-width: 1240px !important;
  padding: 44px 24px 72px !important;
  grid-template-columns: minmax(0, 1fr) 456px !important;
  gap: 64px !important;
}

body.woocommerce-checkout .sleepmoon-checkout-main {
  padding: 0 !important;
  border: 0 !important;
  border-radius: 0 !important;
  box-shadow: none !important;
  background: transparent !important;
}

.sleepmoon-checkout-contact-head,
.sleepmoon-checkout-delivery-head h2 {
  margin: 0 !important;
}

.sleepmoon-checkout-contact-head {
  display: flex !important;
  justify-content: space-between !important;
  align-items: baseline !important;
  gap: 18px !important;
  margin-bottom: 18px !important;
}

.sleepmoon-checkout-contact-head h2,
.sleepmoon-checkout-delivery-head h2 {
  color: #050505 !important;
  font-size: 26px !important;
  line-height: 1.15 !important;
  font-weight: 800 !important;
  letter-spacing: 0 !important;
}

.sleepmoon-checkout-contact-head a {
  color: #006de8 !important;
  font-size: 15px !important;
  font-weight: 600 !important;
  text-decoration: underline !important;
}

.sleepmoon-checkout-delivery-head {
  margin: 36px 0 18px !important;
}

.sleepmoon-courier-card {
  display: flex !important;
  align-items: center !important;
  gap: 16px !important;
  margin-top: 18px !important;
  padding: 18px 20px !important;
  border: 1px solid #d2d2d7 !important;
  border-radius: 10px !important;
  background: #f5f5f7 !important;
}

.sleepmoon-courier-icon {
  width: 34px !important;
  height: 34px !important;
  border-radius: 8px !important;
  border: 2px solid #050505 !important;
  position: relative !important;
  flex: 0 0 34px !important;
}

.sleepmoon-courier-icon::before {
  content: '' !important;
  position: absolute !important;
  left: 5px !important;
  right: 5px !important;
  top: 9px !important;
  height: 10px !important;
  border-top: 2px solid #050505 !important;
  border-bottom: 2px solid #050505 !important;
}

.sleepmoon-courier-card strong {
  display: block !important;
  color: #050505 !important;
  font-size: 16px !important;
  margin-bottom: 2px !important;
}

.sleepmoon-courier-card p {
  color: #6e6e73 !important;
  font-size: 14px !important;
  margin: 0 !important;
}

body.woocommerce-checkout .sleepmoon-checkout-main h3,
body.woocommerce-checkout .sleepmoon-checkout-main .woocommerce-billing-fields > h3,
body.woocommerce-checkout .sleepmoon-checkout-main .woocommerce-shipping-fields > h3,
body.woocommerce-checkout .sleepmoon-checkout-main .woocommerce-additional-fields > h3 {
  display: none !important;
}

body.woocommerce-checkout .sleepmoon-checkout-main .form-row {
  margin: 0 0 18px !important;
}

body.woocommerce-checkout .sleepmoon-checkout-main .form-row-first,
body.woocommerce-checkout .sleepmoon-checkout-main .form-row-last {
  width: calc(50% - 10px) !important;
}

body.woocommerce-checkout .sleepmoon-checkout-main .form-row-first {
  margin-right: 16px !important;
}

body.woocommerce-checkout .sleepmoon-checkout-main .form-row-wide {
  width: 100% !important;
}

body.woocommerce-checkout .sleepmoon-checkout-main label {
  position: absolute !important;
  width: 1px !important;
  height: 1px !important;
  overflow: hidden !important;
  clip: rect(0, 0, 0, 0) !important;
}

body.woocommerce-checkout .sleepmoon-checkout-main input.input-text,
body.woocommerce-checkout .sleepmoon-checkout-main textarea,
body.woocommerce-checkout .sleepmoon-checkout-main select,
body.woocommerce-checkout .sleepmoon-checkout-main .select2-selection {
  min-height: 64px !important;
  border: 1px solid #d2d2d7 !important;
  border-radius: 9px !important;
  background: #fff !important;
  color: #050505 !important;
  font-size: 16px !important;
  padding: 18px 15px !important;
  box-shadow: none !important;
}

body.woocommerce-checkout .sleepmoon-checkout-main input.input-text:focus,
body.woocommerce-checkout .sleepmoon-checkout-main textarea:focus,
body.woocommerce-checkout .sleepmoon-checkout-main select:focus,
body.woocommerce-checkout .sleepmoon-checkout-main .select2-container--open .select2-selection {
  border-color: #006de8 !important;
  box-shadow: 0 0 0 1px #006de8 !important;
}

body.woocommerce-checkout .sleepmoon-checkout-main .select2-selection__rendered {
  line-height: 28px !important;
  padding-left: 0 !important;
}

body.woocommerce-checkout .sleepmoon-checkout-main .select2-selection__arrow {
  top: 18px !important;
}

body.woocommerce-checkout .woocommerce-additional-fields {
  margin-top: 8px !important;
}

body.woocommerce-checkout .sleepmoon-checkout-sidebar {
  position: sticky !important;
  top: 24px !important;
}

body.woocommerce-checkout .sleepmoon-checkout-sidebar #order_review {
  padding: 0 !important;
  border: 0 !important;
  border-radius: 0 !important;
  box-shadow: none !important;
  background: transparent !important;
}

.sleepmoon-order-review-card {
  color: #050505 !important;
}

.sm-checkout-products {
  display: grid !important;
  gap: 18px !important;
  margin-bottom: 30px !important;
}

.sm-checkout-product {
  display: grid !important;
  grid-template-columns: 82px minmax(0, 1fr) auto !important;
  gap: 18px !important;
  align-items: start !important;
}

.sm-checkout-product-img {
  width: 82px !important;
  height: 82px !important;
  position: relative !important;
  border: 1px solid #dcdcdc !important;
  border-radius: 10px !important;
  background: #fff !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  box-shadow: 0 2px 8px rgba(0, 0, 0, .08) !important;
}

.sm-checkout-product-img img {
  width: 64px !important;
  height: 64px !important;
  object-fit: contain !important;
}

.sm-checkout-product-qty {
  position: absolute !important;
  top: -8px !important;
  right: -8px !important;
  min-width: 26px !important;
  height: 26px !important;
  padding: 0 8px !important;
  border-radius: 999px !important;
  background: #050505 !important;
  color: #fff !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  font-size: 14px !important;
  font-weight: 800 !important;
}

.sm-checkout-product-copy strong {
  display: block !important;
  color: #1d1d1f !important;
  font-size: 17px !important;
  line-height: 1.35 !important;
  font-weight: 500 !important;
}

.sm-checkout-product-copy dl.variation {
  margin: 5px 0 0 !important;
  color: #6e6e73 !important;
  font-size: 13px !important;
}

.sm-checkout-product-copy dl.variation dt,
.sm-checkout-product-copy dl.variation dd {
  display: inline !important;
  margin: 0 5px 0 0 !important;
}

.sm-checkout-product-total {
  color: #1d1d1f !important;
  font-size: 16px !important;
  font-weight: 500 !important;
  white-space: nowrap !important;
}

.sm-checkout-coupon {
  display: grid !important;
  grid-template-columns: minmax(0, 1fr) auto !important;
  gap: 14px !important;
  margin: 0 0 34px !important;
}

.sm-checkout-coupon input {
  height: 62px !important;
  border: 1px solid #d2d2d7 !important;
  border-radius: 9px !important;
  background: #fff !important;
  color: #1d1d1f !important;
  font-size: 16px !important;
  padding: 0 16px !important;
}

.sm-checkout-coupon button {
  height: 62px !important;
  min-width: 86px !important;
  border: 1px solid #dcdcdc !important;
  border-radius: 9px !important;
  background: #efeff1 !important;
  color: #6e6e73 !important;
  font-size: 16px !important;
  font-weight: 800 !important;
}

.sm-checkout-coupon button:hover {
  background: #0877e8 !important;
  color: #fff !important;
}

.sleepmoon-coupon-message {
  grid-column: 1 / -1 !important;
  font-size: 13px !important;
  color: #006de8 !important;
}

.sleepmoon-coupon-message .woocommerce-error,
.sleepmoon-coupon-message .woocommerce-message,
.sleepmoon-coupon-message .woocommerce-info {
  margin: 0 !important;
  padding: 10px 12px !important;
  border-radius: 8px !important;
  font-size: 13px !important;
}

.sleepmoon-coupon-message .is-error {
  color: #c62828 !important;
}

.sm-checkout-totals {
  width: 100% !important;
  border: 0 !important;
  margin: 0 0 28px !important;
}

body.woocommerce-checkout .sm-checkout-totals th,
body.woocommerce-checkout .sm-checkout-totals td {
  padding: 8px 0 !important;
  border: 0 !important;
  color: #1d1d1f !important;
  font-size: 16px !important;
  font-weight: 400 !important;
  text-align: right !important;
}

body.woocommerce-checkout .sm-checkout-totals th {
  text-align: left !important;
}

body.woocommerce-checkout .sm-checkout-totals .sm-courier-shipping-row td {
  color: #6e6e73 !important;
}

body.woocommerce-checkout .sm-checkout-totals .order-total th,
body.woocommerce-checkout .sm-checkout-totals .order-total td,
body.woocommerce-checkout .sm-checkout-totals .order-total .amount {
  padding-top: 22px !important;
  color: #050505 !important;
  font-size: 25px !important;
  font-weight: 900 !important;
}

body.woocommerce-checkout .sm-checkout-totals .order-total th {
  font-size: 25px !important;
}

.sm-checkout-recommendations {
  margin-top: 28px !important;
}

.sm-checkout-recommendations h3 {
  color: #050505 !important;
  font-size: 18px !important;
  line-height: 1.25 !important;
  font-weight: 800 !important;
  margin: 0 0 20px !important;
}

.sm-checkout-recommendations-list {
  display: grid !important;
  gap: 20px !important;
}

.sm-checkout-rec {
  display: grid !important;
  grid-template-columns: 80px minmax(0, 1fr) 116px !important;
  gap: 16px !important;
  align-items: center !important;
}

.sm-checkout-rec-img {
  width: 80px !important;
  height: 80px !important;
  background: #fff !important;
  border: 1px solid #dcdcdc !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
}

.sm-checkout-rec-img img {
  width: 68px !important;
  height: 68px !important;
  object-fit: contain !important;
}

.sm-checkout-rec-copy a {
  color: #050505 !important;
  font-size: 15px !important;
  line-height: 1.25 !important;
  font-weight: 800 !important;
}

.sm-checkout-rec-price {
  color: #1d1d1f !important;
  font-size: 14px !important;
  margin-top: 5px !important;
}

.sm-checkout-rec-price del {
  color: #6e6e73 !important;
}

.sm-checkout-rec-price ins {
  color: #e02020 !important;
  text-decoration: none !important;
}

.sm-checkout-rec-add {
  min-height: 62px !important;
  border-radius: 9px !important;
  background: #0877e8 !important;
  color: #fff !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  text-align: center !important;
  font-size: 16px !important;
  font-weight: 800 !important;
  text-decoration: none !important;
}

.sm-checkout-rec-add:hover {
  background: #0062c9 !important;
  color: #fff !important;
}

body.woocommerce-checkout #payment {
  margin-top: 28px !important;
  padding-top: 24px !important;
  border-top: 1px solid #dcdcdc !important;
}

body.woocommerce-checkout #payment ul.payment_methods {
  display: grid !important;
  gap: 10px !important;
}

body.woocommerce-checkout #payment li.wc_payment_method {
  background: #fff !important;
  border: 1px solid #d2d2d7 !important;
  border-radius: 9px !important;
}

@media (max-width: 1020px) {
  body.woocommerce-checkout {
    background: #fff !important;
  }
  body.woocommerce-checkout form.checkout.sleepmoon-checkout-layout {
    grid-template-columns: 1fr !important;
    gap: 32px !important;
  }
  body.woocommerce-checkout .sleepmoon-checkout-sidebar {
    position: static !important;
    background: #f5f5f5 !important;
    padding: 24px !important;
    border-radius: 10px !important;
  }
}

@media (max-width: 640px) {
  .sleepmoon-checkout-brandbar {
    height: 72px !important;
    padding: 0 16px !important;
  }
  .sleepmoon-checkout-logo {
    font-size: 24px !important;
  }
  body.woocommerce-checkout form.checkout.sleepmoon-checkout-layout {
    padding: 28px 16px 48px !important;
  }
  body.woocommerce-checkout .sleepmoon-checkout-main .form-row-first,
  body.woocommerce-checkout .sleepmoon-checkout-main .form-row-last {
    width: 100% !important;
    margin-right: 0 !important;
  }
  .sm-checkout-product,
  .sm-checkout-rec {
    grid-template-columns: 72px minmax(0, 1fr) !important;
  }
  .sm-checkout-product-total,
  .sm-checkout-rec-add {
    grid-column: 2 !important;
    justify-self: start !important;
  }
  .sm-checkout-coupon {
    grid-template-columns: 1fr !important;
  }
}

/* ===========================================================
   v1.5.3 - Checkout width, title and AJAX fragment fixes
   =========================================================== */

body.woocommerce-checkout #app > .container {
  width: 100% !important;
  max-width: none !important;
  padding: 0 !important;
}

body.woocommerce-checkout #app > .container > article > h1:first-child {
  display: none !important;
}

body.woocommerce-checkout #app > .container > article,
body.woocommerce-checkout #app > .container .page-content {
  width: 100% !important;
  max-width: none !important;
  margin: 0 !important;
  line-height: inherit !important;
}

body.woocommerce-checkout .sleepmoon-order-review-card.woocommerce-checkout-review-order-table {
  display: block !important;
  margin: 0 !important;
  padding: 0 !important;
  border: 0 !important;
  background: transparent !important;
  box-shadow: none !important;
}

body.woocommerce-checkout .sleepmoon-order-review-card .woocommerce-checkout-review-order-table {
  display: none !important;
}

body.woocommerce-checkout #customer_details.sleepmoon-checkout-main {
  border: 0 !important;
  border-radius: 0 !important;
  box-shadow: none !important;
  background: transparent !important;
}

body.woocommerce-checkout .sleepmoon-checkout-main .col2-set {
  display: block !important;
}

body.woocommerce-checkout .sleepmoon-checkout-main .col-1,
body.woocommerce-checkout .sleepmoon-checkout-main .col-2 {
  width: 100% !important;
  max-width: none !important;
  float: none !important;
}

body.woocommerce-checkout .sleepmoon-checkout-main .col-2 {
  margin-top: 0 !important;
}

body.woocommerce-checkout .sm-checkout-products + .sm-checkout-products,
body.woocommerce-checkout .sm-checkout-coupon + .sm-checkout-coupon,
body.woocommerce-checkout .sm-checkout-recommendations + .sm-checkout-recommendations {
  display: none !important;
}

body.woocommerce-checkout #payment .woocommerce-info,
body.woocommerce-checkout #payment .woocommerce-notice {
  position: relative !important;
  margin: 0 0 18px !important;
  padding: 16px 18px !important;
  border: 1px solid #ffe1a8 !important;
  border-left: 4px solid #ffb84d !important;
  border-radius: 8px !important;
  background: #fff7df !important;
  color: #424245 !important;
  font-size: 14px !important;
  line-height: 1.7 !important;
}

body.woocommerce-checkout #payment .woocommerce-info::before,
body.woocommerce-checkout #payment .woocommerce-notice::before {
  display: none !important;
  content: none !important;
}

/* ===========================================================
   v1.5.4 - Checkout validation, continue link and item removal
   =========================================================== */

.sleepmoon-checkout-brand-left {
  display: flex !important;
  flex-direction: column !important;
  align-items: flex-start !important;
  gap: 8px !important;
}

.sleepmoon-continue-shopping {
  display: inline-flex !important;
  align-items: center !important;
  gap: 6px !important;
  color: #006de8 !important;
  font-size: 14px !important;
  line-height: 1.2 !important;
  font-weight: 700 !important;
  text-decoration: none !important;
}

.sleepmoon-continue-shopping:hover {
  color: #004fb5 !important;
  text-decoration: underline !important;
}

.sleepmoon-continue-shopping span {
  font-size: 22px !important;
  line-height: 1 !important;
}

body.woocommerce-checkout form.checkout.sleepmoon-checkout-layout > .woocommerce-NoticeGroup,
body.woocommerce-checkout form.checkout.sleepmoon-checkout-layout > .woocommerce-NoticeGroup-checkout {
  grid-column: 1 / -1 !important;
  width: 100% !important;
  order: -1 !important;
  margin: 0 0 8px !important;
}

body.woocommerce-checkout form.checkout.sleepmoon-checkout-layout > .woocommerce-NoticeGroup .woocommerce-error,
body.woocommerce-checkout form.checkout.sleepmoon-checkout-layout > .woocommerce-NoticeGroup-checkout .woocommerce-error {
  position: relative !important;
  width: 100% !important;
  margin: 0 !important;
  padding: 16px 18px !important;
  border: 1px solid #ffb8b8 !important;
  border-left: 4px solid #e02020 !important;
  border-radius: 10px !important;
  background: #fff7f7 !important;
  color: #3a3a3c !important;
  box-shadow: none !important;
  list-style: none !important;
  line-height: 1.55 !important;
}

body.woocommerce-checkout form.checkout.sleepmoon-checkout-layout > .woocommerce-NoticeGroup .woocommerce-error::before,
body.woocommerce-checkout form.checkout.sleepmoon-checkout-layout > .woocommerce-NoticeGroup-checkout .woocommerce-error::before {
  display: none !important;
  content: none !important;
}

body.woocommerce-checkout form.checkout.sleepmoon-checkout-layout > .woocommerce-NoticeGroup .woocommerce-error li,
body.woocommerce-checkout form.checkout.sleepmoon-checkout-layout > .woocommerce-NoticeGroup-checkout .woocommerce-error li {
  margin: 0 !important;
  padding: 0 !important;
  color: #3a3a3c !important;
}

body.woocommerce-checkout .sleepmoon-checkout-main .form-row.woocommerce-invalid input.input-text,
body.woocommerce-checkout .sleepmoon-checkout-main .form-row.woocommerce-invalid textarea,
body.woocommerce-checkout .sleepmoon-checkout-main .form-row.woocommerce-invalid select,
body.woocommerce-checkout .sleepmoon-checkout-main .form-row.woocommerce-invalid .select2-selection {
  border-color: #e02020 !important;
  box-shadow: 0 0 0 1px rgba(224, 32, 32, .16) !important;
}

body.woocommerce-checkout .sleepmoon-checkout-main .woocommerce-error {
  margin: 6px 0 0 !important;
  padding: 0 !important;
  border: 0 !important;
  background: transparent !important;
  color: #c40000 !important;
  font-size: 12px !important;
  line-height: 1.4 !important;
  list-style: none !important;
}

body.woocommerce-checkout .sleepmoon-checkout-main .woocommerce-error::before {
  display: none !important;
  content: none !important;
}

.sm-checkout-product {
  grid-template-columns: 82px minmax(0, 1fr) auto 32px !important;
  align-items: center !important;
}

.sm-checkout-product-remove {
  width: 32px !important;
  height: 32px !important;
  border: 1px solid #d2d2d7 !important;
  border-radius: 999px !important;
  background: #fff !important;
  color: #6e6e73 !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  font-size: 22px !important;
  line-height: 1 !important;
  font-weight: 400 !important;
  text-decoration: none !important;
  transition: color .18s ease, border-color .18s ease, background .18s ease, opacity .18s ease !important;
}

.sm-checkout-product-remove:hover,
.sm-checkout-product-remove:focus {
  border-color: #006de8 !important;
  background: #f0f7ff !important;
  color: #006de8 !important;
  outline: none !important;
}

.sm-checkout-product-remove.loading {
  pointer-events: none !important;
  opacity: .45 !important;
}

@media (max-width: 1020px) {
  .sleepmoon-checkout-brand-left {
    gap: 6px !important;
  }

  body.woocommerce-checkout form.checkout.sleepmoon-checkout-layout > .woocommerce-NoticeGroup,
  body.woocommerce-checkout form.checkout.sleepmoon-checkout-layout > .woocommerce-NoticeGroup-checkout {
    grid-column: 1 !important;
  }
}

@media (max-width: 640px) {
  .sleepmoon-checkout-brandbar {
    align-items: center !important;
  }

  .sleepmoon-checkout-logo {
    font-size: 21px !important;
  }

  .sleepmoon-continue-shopping {
    font-size: 13px !important;
  }

  .sm-checkout-product {
    grid-template-columns: 72px minmax(0, 1fr) 32px !important;
    gap: 12px !important;
  }

  .sm-checkout-product-total {
    grid-column: 2 !important;
    justify-self: start !important;
  }

  .sm-checkout-product-remove {
    grid-column: 3 !important;
    grid-row: 1 / span 2 !important;
    align-self: start !important;
  }
}

/* ===========================================================
   v1.5.5 - Modern Cart page
   =========================================================== */

body.woocommerce-cart > .container {
  width: 100% !important;
  max-width: none !important;
  padding: 0 !important;
}

body.woocommerce-cart > .container > article > h1:first-child {
  display: none !important;
}

body.woocommerce-cart > .container > article > .page-content {
  line-height: 1.5 !important;
}

body.woocommerce-cart .woocommerce {
  display: block !important;
  width: 100% !important;
  max-width: none !important;
  margin: 0 !important;
  padding: 0 !important;
  background: #fff !important;
}

body.woocommerce-cart .woocommerce > .woocommerce-notices-wrapper {
  width: 100% !important;
  max-width: 1180px !important;
  margin: 0 auto !important;
  padding: 24px 24px 0 !important;
}

.sleepmoon-cart-page {
  width: 100% !important;
  max-width: 1180px !important;
  margin: 0 auto !important;
  padding: 44px 24px 72px !important;
}

.sleepmoon-cart-header {
  display: flex !important;
  align-items: flex-end !important;
  justify-content: space-between !important;
  gap: 24px !important;
  margin: 0 0 28px !important;
}

.sleepmoon-cart-header p {
  margin: 0 0 6px !important;
  color: #006de8 !important;
  font-size: 13px !important;
  line-height: 1.2 !important;
  font-weight: 800 !important;
  text-transform: uppercase !important;
  letter-spacing: 0 !important;
}

.sleepmoon-cart-header h1 {
  margin: 0 !important;
  color: #050505 !important;
  font-size: clamp(32px, 4vw, 48px) !important;
  line-height: 1.05 !important;
  font-weight: 900 !important;
  letter-spacing: 0 !important;
}

.sleepmoon-cart-continue {
  min-height: 44px !important;
  padding: 0 18px !important;
  border: 1px solid #d2d2d7 !important;
  border-radius: 999px !important;
  color: #006de8 !important;
  background: #fff !important;
  display: inline-flex !important;
  align-items: center !important;
  gap: 6px !important;
  font-size: 15px !important;
  font-weight: 800 !important;
  text-decoration: none !important;
  white-space: nowrap !important;
}

.sleepmoon-cart-continue:hover {
  border-color: #006de8 !important;
  background: #f0f7ff !important;
  color: #006de8 !important;
}

.sleepmoon-cart-continue span {
  font-size: 22px !important;
  line-height: 1 !important;
}

.sleepmoon-cart-layout {
  display: grid !important;
  grid-template-columns: minmax(0, 1fr) 380px !important;
  gap: 28px !important;
  align-items: start !important;
}

body.woocommerce-cart .sleepmoon-cart-form {
  width: 100% !important;
  min-width: 0 !important;
  max-width: none !important;
  margin: 0 !important;
  overflow: visible !important;
}

.sleepmoon-cart-card,
body.woocommerce-cart .sleepmoon-cart-totals,
body.woocommerce-cart .sleepmoon-cart-collaterals .cross-sells {
  background: #fff !important;
  border: 1px solid #dcdcdc !important;
  border-radius: 10px !important;
  box-shadow: none !important;
}

.sleepmoon-cart-card {
  overflow: hidden !important;
}

.sleepmoon-cart-card-head {
  min-height: 76px !important;
  padding: 20px 24px !important;
  border-bottom: 1px solid #e5e5e5 !important;
  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;
  gap: 16px !important;
}

.sleepmoon-cart-card-head span,
.sleepmoon-cart-totals-head span {
  display: block !important;
  color: #6e6e73 !important;
  font-size: 13px !important;
  line-height: 1.2 !important;
  font-weight: 800 !important;
  text-transform: uppercase !important;
  letter-spacing: 0 !important;
}

.sleepmoon-cart-card-head strong {
  display: block !important;
  margin-top: 4px !important;
  color: #050505 !important;
  font-size: 21px !important;
  line-height: 1.2 !important;
  font-weight: 900 !important;
}

body.woocommerce-cart .sleepmoon-cart-update-top,
body.woocommerce-cart .sleepmoon-cart-update {
  min-height: 42px !important;
  padding: 0 18px !important;
  border: 1px solid #d2d2d7 !important;
  border-radius: 999px !important;
  background: #fff !important;
  color: #1d1d1f !important;
  font-size: 14px !important;
  font-weight: 800 !important;
  box-shadow: none !important;
}

body.woocommerce-cart .sleepmoon-cart-update-top:hover,
body.woocommerce-cart .sleepmoon-cart-update:hover {
  border-color: #006de8 !important;
  color: #006de8 !important;
}

body.woocommerce-cart .sleepmoon-cart-table,
body.woocommerce-cart .sleepmoon-cart-table tbody {
  display: block !important;
  width: 100% !important;
  margin: 0 !important;
  border: 0 !important;
  border-radius: 0 !important;
  background: transparent !important;
  box-shadow: none !important;
  table-layout: auto !important;
  overflow: visible !important;
}

body.woocommerce-cart .sleepmoon-cart-table thead {
  display: none !important;
}

body.woocommerce-cart .sleepmoon-cart-table th,
body.woocommerce-cart .sleepmoon-cart-table td {
  display: block !important;
  padding: 0 !important;
  border: 0 !important;
  background: transparent !important;
  color: #1d1d1f !important;
  vertical-align: initial !important;
}

body.woocommerce-cart .sleepmoon-cart-item {
  display: grid !important;
  grid-template-columns: 96px minmax(0, 1fr) 96px 112px 118px 36px !important;
  gap: 18px !important;
  align-items: center !important;
  padding: 24px !important;
  border-bottom: 1px solid #e5e5e5 !important;
}

body.woocommerce-cart .sleepmoon-cart-item:last-of-type {
  border-bottom: 0 !important;
}

.sleepmoon-cart-item-media,
.sleepmoon-cart-item-media a {
  width: 96px !important;
  height: 96px !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
}

body.woocommerce-cart .sleepmoon-cart-item-media img,
body.woocommerce-cart .sleepmoon-cart-item-media a img {
  width: 86px !important;
  height: 86px !important;
  max-width: 86px !important;
  object-fit: contain !important;
  padding: 6px !important;
  border: 1px solid #e5e5e5 !important;
  border-radius: 10px !important;
  background: #fff !important;
  box-shadow: 0 2px 8px rgba(0, 0, 0, .06) !important;
}

.sleepmoon-cart-label {
  display: none !important;
  margin-bottom: 6px !important;
  color: #6e6e73 !important;
  font-size: 12px !important;
  line-height: 1.2 !important;
  font-weight: 800 !important;
  text-transform: uppercase !important;
}

body.woocommerce-cart .sleepmoon-cart-product-title,
body.woocommerce-cart .sleepmoon-cart-product-title a,
body.woocommerce-cart .sleepmoon-cart-item-copy > a {
  color: #050505 !important;
  font-size: 17px !important;
  line-height: 1.32 !important;
  font-weight: 850 !important;
  text-decoration: none !important;
}

body.woocommerce-cart .sleepmoon-cart-product-title:hover,
body.woocommerce-cart .sleepmoon-cart-item-copy > a:hover {
  color: #006de8 !important;
}

body.woocommerce-cart .sleepmoon-cart-item-copy dl.variation {
  display: flex !important;
  flex-wrap: wrap !important;
  gap: 6px 10px !important;
  margin: 10px 0 0 !important;
  color: #6e6e73 !important;
  font-size: 13px !important;
  line-height: 1.35 !important;
}

body.woocommerce-cart .sleepmoon-cart-item-copy dl.variation dt,
body.woocommerce-cart .sleepmoon-cart-item-copy dl.variation dd {
  display: inline !important;
  margin: 0 !important;
}

body.woocommerce-cart .sleepmoon-cart-item-copy dl.variation dt {
  font-weight: 800 !important;
}

body.woocommerce-cart .sleepmoon-cart-item-price,
body.woocommerce-cart .sleepmoon-cart-item-total {
  color: #1d1d1f !important;
  font-size: 16px !important;
  line-height: 1.3 !important;
  font-weight: 800 !important;
  white-space: nowrap !important;
}

body.woocommerce-cart .sleepmoon-cart-item-total {
  text-align: right !important;
}

body.woocommerce-cart .sleepmoon-cart-item-qty .quantity {
  display: inline-flex !important;
  align-items: center !important;
}

body.woocommerce-cart .sleepmoon-cart-item-qty .quantity input.qty {
  width: 76px !important;
  height: 44px !important;
  min-height: 44px !important;
  border: 1px solid #d2d2d7 !important;
  border-radius: 9px !important;
  background: #fff !important;
  color: #050505 !important;
  text-align: center !important;
  font-size: 16px !important;
  font-weight: 800 !important;
  box-shadow: none !important;
}

body.woocommerce-cart .sleepmoon-cart-item-remove {
  text-align: right !important;
}

body.woocommerce-cart .sleepmoon-cart-item-remove .remove {
  width: 36px !important;
  height: 36px !important;
  border: 1px solid #d2d2d7 !important;
  border-radius: 999px !important;
  background: #fff !important;
  color: #6e6e73 !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  font-size: 24px !important;
  line-height: 1 !important;
  font-weight: 400 !important;
  text-decoration: none !important;
}

body.woocommerce-cart .sleepmoon-cart-item-remove .remove::before {
  display: none !important;
  content: none !important;
}

body.woocommerce-cart .sleepmoon-cart-item-remove .remove:hover {
  border-color: #006de8 !important;
  background: #f0f7ff !important;
  color: #006de8 !important;
}

body.woocommerce-cart .sleepmoon-cart-actions-row {
  display: block !important;
  border: 0 !important;
}

body.woocommerce-cart .sleepmoon-cart-actions-row td.actions {
  display: block !important;
  padding: 0 !important;
  background: #fbfbfd !important;
  border-top: 1px solid #e5e5e5 !important;
}

.sleepmoon-cart-actions-inner {
  display: flex !important;
  align-items: flex-end !important;
  justify-content: space-between !important;
  gap: 18px !important;
  padding: 22px 24px !important;
}

body.woocommerce-cart .sleepmoon-cart-coupon {
  display: grid !important;
  gap: 8px !important;
  flex: 1 1 auto !important;
  max-width: 520px !important;
}

.sleepmoon-cart-coupon label {
  color: #6e6e73 !important;
  font-size: 13px !important;
  font-weight: 800 !important;
}

.sleepmoon-cart-coupon div {
  display: grid !important;
  grid-template-columns: minmax(0, 1fr) auto !important;
  gap: 10px !important;
}

body.woocommerce-cart .sleepmoon-cart-coupon input.input-text {
  width: 100% !important;
  min-height: 48px !important;
  border: 1px solid #d2d2d7 !important;
  border-radius: 9px !important;
  background: #fff !important;
  color: #1d1d1f !important;
  padding: 0 14px !important;
  font-size: 15px !important;
}

body.woocommerce-cart .sleepmoon-cart-coupon button {
  min-height: 48px !important;
  padding: 0 18px !important;
  border: 1px solid #dcdcdc !important;
  border-radius: 9px !important;
  background: #efeff1 !important;
  color: #6e6e73 !important;
  font-size: 15px !important;
  font-weight: 800 !important;
}

body.woocommerce-cart .sleepmoon-cart-coupon button:hover {
  border-color: #006de8 !important;
  background: #006de8 !important;
  color: #fff !important;
}

body.woocommerce-cart .sleepmoon-cart-collaterals {
  display: flex !important;
  flex-direction: column !important;
  gap: 18px !important;
  width: 100% !important;
  max-width: none !important;
  margin: 0 !important;
  position: sticky !important;
  top: 124px !important;
}

body.woocommerce-cart .sleepmoon-cart-totals {
  order: 1 !important;
  width: 100% !important;
  max-width: none !important;
  margin: 0 !important;
  padding: 24px !important;
  position: static !important;
}

.sleepmoon-cart-totals-head {
  margin: 0 0 18px !important;
}

body.woocommerce-cart .sleepmoon-cart-totals h2 {
  margin: 4px 0 0 !important;
  color: #050505 !important;
  font-size: 26px !important;
  line-height: 1.15 !important;
  font-weight: 900 !important;
}

body.woocommerce-cart .sleepmoon-cart-totals-table {
  width: 100% !important;
  margin: 0 !important;
  border: 0 !important;
  border-collapse: collapse !important;
  border-radius: 0 !important;
  background: transparent !important;
  box-shadow: none !important;
}

body.woocommerce-cart .sleepmoon-cart-totals-table tbody {
  display: table-row-group !important;
}

body.woocommerce-cart .sleepmoon-cart-totals-table tr {
  display: table-row !important;
}

body.woocommerce-cart .sleepmoon-cart-totals-table th,
body.woocommerce-cart .sleepmoon-cart-totals-table td {
  display: table-cell !important;
  padding: 14px 0 !important;
  border: 0 !important;
  border-bottom: 1px solid #e5e5e5 !important;
  background: transparent !important;
  color: #1d1d1f !important;
  font-size: 15px !important;
  line-height: 1.4 !important;
  font-weight: 500 !important;
  vertical-align: top !important;
}

body.woocommerce-cart .sleepmoon-cart-totals-table th {
  text-align: left !important;
}

body.woocommerce-cart .sleepmoon-cart-totals-table td {
  text-align: right !important;
}

body.woocommerce-cart .sleepmoon-cart-totals-table .order-total th,
body.woocommerce-cart .sleepmoon-cart-totals-table .order-total td,
body.woocommerce-cart .sleepmoon-cart-totals-table .order-total .amount {
  padding-top: 20px !important;
  border-bottom: 0 !important;
  color: #050505 !important;
  font-size: 24px !important;
  line-height: 1.2 !important;
  font-weight: 900 !important;
}

.sleepmoon-cart-summary-note {
  margin: 6px 0 20px !important;
  padding: 12px 14px !important;
  border-radius: 9px !important;
  background: #f5f5f7 !important;
  color: #6e6e73 !important;
  font-size: 13px !important;
  line-height: 1.45 !important;
}

body.woocommerce-cart .sleepmoon-cart-totals .wc-proceed-to-checkout {
  padding: 0 !important;
  margin: 0 !important;
}

body.woocommerce-cart .sleepmoon-cart-totals .checkout-button {
  min-height: 58px !important;
  width: 100% !important;
  border-radius: 999px !important;
  background: #0877e8 !important;
  color: #fff !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  font-size: 16px !important;
  line-height: 1.2 !important;
  font-weight: 900 !important;
  text-align: center !important;
  text-decoration: none !important;
  box-shadow: 0 12px 28px rgba(8, 119, 232, .18) !important;
}

body.woocommerce-cart .sleepmoon-cart-totals .checkout-button:hover {
  background: #0062c9 !important;
  color: #fff !important;
}

body.woocommerce-cart .sleepmoon-cart-totals #shipping_method {
  display: grid !important;
  gap: 8px !important;
  margin: 0 !important;
  padding: 0 !important;
  list-style: none !important;
  text-align: left !important;
}

body.woocommerce-cart .sleepmoon-cart-totals #shipping_method li {
  margin: 0 !important;
  padding: 0 !important;
}

body.woocommerce-cart .sleepmoon-cart-totals .woocommerce-shipping-destination,
body.woocommerce-cart .sleepmoon-cart-totals .woocommerce-shipping-calculator {
  margin: 8px 0 0 !important;
  color: #6e6e73 !important;
  font-size: 13px !important;
  line-height: 1.45 !important;
}

body.woocommerce-cart .sleepmoon-cart-collaterals .cross-sells {
  order: 2 !important;
  padding: 20px !important;
}

body.woocommerce-cart .sleepmoon-cart-collaterals .cross-sells h2 {
  margin: 0 0 14px !important;
  color: #050505 !important;
  font-size: 18px !important;
  line-height: 1.25 !important;
  font-weight: 900 !important;
}

body.woocommerce-cart .sleepmoon-cart-collaterals .cross-sells ul.products {
  display: grid !important;
  grid-template-columns: 1fr !important;
  gap: 12px !important;
  margin: 0 !important;
}

@media (max-width: 1100px) {
  .sleepmoon-cart-layout {
    grid-template-columns: 1fr !important;
  }

  body.woocommerce-cart .sleepmoon-cart-collaterals {
    position: static !important;
  }
}

@media (max-width: 820px) {
  .sleepmoon-cart-page {
    padding: 32px 16px 52px !important;
  }

  .sleepmoon-cart-header {
    align-items: flex-start !important;
    flex-direction: column !important;
  }

  .sleepmoon-cart-card-head {
    align-items: flex-start !important;
    flex-direction: column !important;
  }

  body.woocommerce-cart .sleepmoon-cart-update-top {
    display: none !important;
  }

  body.woocommerce-cart .sleepmoon-cart-item {
    grid-template-columns: 82px minmax(0, 1fr) 36px !important;
    gap: 14px !important;
    padding: 20px 16px !important;
  }

  .sleepmoon-cart-item-media,
  .sleepmoon-cart-item-media a {
    width: 82px !important;
    height: 82px !important;
  }

  body.woocommerce-cart .sleepmoon-cart-item-media img,
  body.woocommerce-cart .sleepmoon-cart-item-media a img {
    width: 74px !important;
    height: 74px !important;
  }

  body.woocommerce-cart .sleepmoon-cart-item-copy {
    grid-column: 2 !important;
  }

  body.woocommerce-cart .sleepmoon-cart-item-price,
  body.woocommerce-cart .sleepmoon-cart-item-qty,
  body.woocommerce-cart .sleepmoon-cart-item-total {
    grid-column: 2 / -1 !important;
    display: flex !important;
    align-items: center !important;
    justify-content: space-between !important;
    gap: 16px !important;
    text-align: left !important;
  }

  .sleepmoon-cart-label {
    display: block !important;
  }

  body.woocommerce-cart .sleepmoon-cart-item-remove {
    grid-column: 3 !important;
    grid-row: 1 !important;
    align-self: start !important;
  }

  body.woocommerce-cart .sleepmoon-cart-item-remove .remove {
    width: 34px !important;
    height: 34px !important;
  }

  .sleepmoon-cart-actions-inner {
    align-items: stretch !important;
    flex-direction: column !important;
    padding: 20px 16px !important;
  }

  body.woocommerce-cart .sleepmoon-cart-coupon {
    max-width: none !important;
  }
}

@media (max-width: 520px) {
  .sleepmoon-cart-coupon div {
    grid-template-columns: 1fr !important;
  }

  body.woocommerce-cart .sleepmoon-cart-totals {
    padding: 20px !important;
  }
}

/* ===========================================================
   v1.5.6 - Cart row anti-overlap fixes
   =========================================================== */

body.woocommerce-cart #app > .container,
body.woocommerce-cart > div.container {
  width: 100% !important;
  max-width: none !important;
  padding-left: 0 !important;
  padding-right: 0 !important;
}

body.woocommerce-cart #app > .container > article > h1:first-child,
body.woocommerce-cart > div.container > article > h1:first-child {
  display: none !important;
}

body.woocommerce-cart .sleepmoon-cart-layout {
  grid-template-columns: minmax(0, 1fr) minmax(340px, 380px) !important;
}

body.woocommerce-cart .sleepmoon-cart-item {
  grid-template-columns: 96px minmax(0, 1fr) 88px 112px 36px !important;
  grid-template-areas:
    "media copy copy qty remove"
    "media price total total remove" !important;
  gap: 10px 16px !important;
  align-items: center !important;
}

body.woocommerce-cart .sleepmoon-cart-item-media {
  grid-area: media !important;
}

body.woocommerce-cart .sleepmoon-cart-item-copy {
  grid-area: copy !important;
  min-width: 0 !important;
}

body.woocommerce-cart .sleepmoon-cart-item-price {
  grid-area: price !important;
  color: #6e6e73 !important;
  font-size: 14px !important;
  font-weight: 700 !important;
  text-align: left !important;
}

body.woocommerce-cart .sleepmoon-cart-item-qty {
  grid-area: qty !important;
  justify-self: start !important;
}

body.woocommerce-cart .sleepmoon-cart-item-total {
  grid-area: total !important;
  justify-self: end !important;
  text-align: right !important;
}

body.woocommerce-cart .sleepmoon-cart-item-remove {
  grid-area: remove !important;
  align-self: center !important;
}

body.woocommerce-cart .sleepmoon-cart-product-title,
body.woocommerce-cart .sleepmoon-cart-item-copy > a {
  display: block !important;
  max-width: 100% !important;
  overflow-wrap: anywhere !important;
  word-break: normal !important;
}

body.woocommerce-cart .sleepmoon-cart-item-copy dl.variation {
  max-width: 100% !important;
  overflow-wrap: anywhere !important;
}

body.woocommerce-cart .sleepmoon-cart-item-qty .quantity input.qty {
  width: 72px !important;
}

@media (max-width: 1100px) {
  body.woocommerce-cart .sleepmoon-cart-layout {
    grid-template-columns: 1fr !important;
  }
}

@media (max-width: 760px) {
  body.woocommerce-cart .sleepmoon-cart-item {
    grid-template-columns: 82px minmax(0, 1fr) 36px !important;
    grid-template-areas:
      "media copy remove"
      "media price remove"
      "media qty remove"
      "media total remove" !important;
    gap: 10px 14px !important;
  }

  body.woocommerce-cart .sleepmoon-cart-item-price,
  body.woocommerce-cart .sleepmoon-cart-item-qty,
  body.woocommerce-cart .sleepmoon-cart-item-total {
    grid-column: auto !important;
    display: block !important;
    text-align: left !important;
    justify-self: stretch !important;
  }

  body.woocommerce-cart .sleepmoon-cart-item-total {
    display: flex !important;
    justify-content: space-between !important;
    gap: 16px !important;
  }

  body.woocommerce-cart .sleepmoon-cart-item-remove {
    grid-column: auto !important;
    grid-row: auto !important;
  }
}

@media (max-width: 520px) {
  body.woocommerce-cart .sleepmoon-cart-item {
    grid-template-columns: 74px minmax(0, 1fr) 34px !important;
    padding: 18px 14px !important;
  }

  body.woocommerce-cart .sleepmoon-cart-product-title,
  body.woocommerce-cart .sleepmoon-cart-item-copy > a {
    font-size: 15px !important;
  }
}

/* ===========================================================
   v1.5.7 - Cart coupon alignment and Romania-only checkout
   =========================================================== */

.woocommerce-cart .cart-collaterals.sleepmoon-cart-collaterals,
body.woocommerce-cart .cart-collaterals.sleepmoon-cart-collaterals {
  margin-top: 0 !important;
  padding-top: 0 !important;
  align-self: start !important;
  transform: none !important;
}

.woocommerce-cart .cart-collaterals.sleepmoon-cart-collaterals .cart_totals.sleepmoon-cart-totals,
body.woocommerce-cart .cart-collaterals.sleepmoon-cart-collaterals .cart_totals.sleepmoon-cart-totals {
  margin-top: 0 !important;
  top: auto !important;
}

body.woocommerce-cart .sleepmoon-cart-actions-inner {
  align-items: center !important;
}

body.woocommerce-cart .sleepmoon-cart-coupon {
  grid-template-columns: auto minmax(260px, 1fr) !important;
  align-items: center !important;
}

body.woocommerce-cart .sleepmoon-cart-coupon label {
  height: 48px !important;
  margin: 0 !important;
  display: inline-flex !important;
  align-items: center !important;
  white-space: nowrap !important;
}

body.woocommerce-checkout #billing_country_field,
body.woocommerce-checkout #shipping_country_field,
body.woocommerce-checkout .sleepmoon-hidden-country {
  display: none !important;
}

@media (max-width: 820px) {
  body.woocommerce-cart .sleepmoon-cart-coupon {
    grid-template-columns: 1fr !important;
  }

  body.woocommerce-cart .sleepmoon-cart-coupon label {
    justify-content: center !important;
    text-align: center !important;
  }
}

/* ===========================================================
   v1.5.8 - Empty cart, sort control and softer filter empty state
   =========================================================== */

.woocommerce-cart .cart-collaterals.sleepmoon-cart-collaterals,
body.woocommerce-cart .cart-collaterals.sleepmoon-cart-collaterals {
  margin-top: -44px !important;
  padding-top: 0 !important;
  align-self: start !important;
}

.woocommerce-cart .cart-collaterals.sleepmoon-cart-collaterals .cart_totals.sleepmoon-cart-totals,
body.woocommerce-cart .cart-collaterals.sleepmoon-cart-collaterals .cart_totals.sleepmoon-cart-totals {
  margin-top: 0 !important;
}

.sleepmoon-empty-cart {
  min-height: 48vh !important;
  max-width: 680px !important;
  margin: 0 auto !important;
  padding: 80px 24px !important;
  display: flex !important;
  flex-direction: column !important;
  align-items: center !important;
  justify-content: center !important;
  text-align: center !important;
}

.sleepmoon-empty-cart-icon {
  width: 78px !important;
  height: 78px !important;
  margin-bottom: 22px !important;
  border: 2px solid #d2d2d7 !important;
  border-radius: 22px !important;
  position: relative !important;
  background: #f5f5f7 !important;
}

.sleepmoon-empty-cart-icon::before {
  content: '' !important;
  position: absolute !important;
  left: 20px !important;
  right: 20px !important;
  top: -14px !important;
  height: 26px !important;
  border: 2px solid #0877e8 !important;
  border-bottom: 0 !important;
  border-radius: 20px 20px 0 0 !important;
}

.sleepmoon-empty-cart p {
  margin: 0 0 8px !important;
  color: #050505 !important;
  font-size: 34px !important;
  line-height: 1.1 !important;
  font-weight: 900 !important;
}

.sleepmoon-empty-cart h1 {
  margin: 0 0 28px !important;
  max-width: 500px !important;
  color: #6e6e73 !important;
  font-size: 17px !important;
  line-height: 1.5 !important;
  font-weight: 500 !important;
}

.sleepmoon-empty-cart-button {
  min-height: 54px !important;
  padding: 0 28px !important;
  border: 0 !important;
  border-radius: 999px !important;
  background: #0877e8 !important;
  color: #fff !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  font-size: 16px !important;
  font-weight: 850 !important;
  text-decoration: none !important;
  box-shadow: 0 12px 28px rgba(8, 119, 232, .18) !important;
}

.sleepmoon-empty-cart-button:hover {
  background: #0062c9 !important;
  color: #fff !important;
}

.toolbar-controls .woocommerce-ordering {
  margin: 0 !important;
  position: relative !important;
}

.toolbar-controls .woocommerce-ordering select,
.toolbar-controls .woocommerce-ordering .orderby {
  min-height: 48px !important;
  min-width: 280px !important;
  padding: 0 42px 0 16px !important;
  border: 1px solid #d2d2d7 !important;
  border-radius: 999px !important;
  background-color: #fff !important;
  color: #1d1d1f !important;
  font-size: 14px !important;
  font-weight: 800 !important;
  box-shadow: 0 8px 24px rgba(0, 0, 0, .05) !important;
}

.toolbar-controls .woocommerce-ordering select.sleepmoon-native-sort,
.sleepmoon-native-sort {
  position: absolute !important;
  width: 1px !important;
  height: 1px !important;
  opacity: 0 !important;
  pointer-events: none !important;
}

.sleepmoon-sort {
  position: relative !important;
  min-width: min(320px, 78vw) !important;
  z-index: 30 !important;
}

.sleepmoon-sort-button {
  width: 100% !important;
  min-height: 48px !important;
  padding: 0 14px 0 18px !important;
  border: 1px solid #d2d2d7 !important;
  border-radius: 999px !important;
  background: #fff !important;
  color: #1d1d1f !important;
  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;
  gap: 14px !important;
  font-size: 14px !important;
  font-weight: 800 !important;
  box-shadow: 0 8px 24px rgba(0, 0, 0, .05) !important;
}

.sleepmoon-sort.open .sleepmoon-sort-button,
.sleepmoon-sort-button:hover {
  border-color: #0877e8 !important;
  color: #006de8 !important;
}

.sleepmoon-sort-arrow {
  width: 28px !important;
  height: 28px !important;
  border-radius: 50% !important;
  background: #f0f7ff !important;
  color: #006de8 !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  font-size: 12px !important;
  line-height: 1 !important;
  font-weight: 900 !important;
}

.sleepmoon-sort-menu {
  position: absolute !important;
  top: calc(100% + 8px) !important;
  left: 0 !important;
  right: 0 !important;
  padding: 8px !important;
  border: 1px solid #dcdcdc !important;
  border-radius: 14px !important;
  background: #fff !important;
  box-shadow: 0 18px 44px rgba(0, 0, 0, .16) !important;
  display: none !important;
}

.sleepmoon-sort.open .sleepmoon-sort-menu {
  display: grid !important;
  gap: 3px !important;
}

.sleepmoon-sort-option {
  width: 100% !important;
  min-height: 42px !important;
  padding: 0 12px !important;
  border: 0 !important;
  border-radius: 9px !important;
  background: #fff !important;
  color: #1d1d1f !important;
  text-align: left !important;
  font-size: 14px !important;
  font-weight: 700 !important;
}

.sleepmoon-sort-option:hover,
.sleepmoon-sort-option.active {
  background: #f0f7ff !important;
  color: #006de8 !important;
}

.sleepmoon-filter-submit {
  width: 100% !important;
  justify-content: center !important;
  margin-top: 16px !important;
}

.sleepmoon-pagination {
  margin-top: 32px !important;
}

.sleepmoon-filter-empty {
  max-width: 620px !important;
  margin: 54px auto 72px !important;
  padding: 42px 28px !important;
  border: 1px solid #e5e5e5 !important;
  border-radius: 14px !important;
  background: #fff !important;
  text-align: center !important;
  box-shadow: 0 16px 40px rgba(0, 0, 0, .05) !important;
}

.sleepmoon-filter-empty-icon {
  width: 56px !important;
  height: 56px !important;
  margin: 0 auto 18px !important;
  border: 4px solid #9bb7ca !important;
  border-radius: 50% !important;
  position: relative !important;
  background: #eaf5ff !important;
}

.sleepmoon-filter-empty-icon::after {
  content: '' !important;
  position: absolute !important;
  width: 18px !important;
  height: 7px !important;
  right: -12px !important;
  bottom: 3px !important;
  border-radius: 999px !important;
  background: #6e8798 !important;
  transform: rotate(45deg) !important;
}

.sleepmoon-filter-empty h3 {
  margin: 0 0 10px !important;
  color: #1d1d1f !important;
  font-size: 24px !important;
  line-height: 1.2 !important;
  font-weight: 900 !important;
}

.sleepmoon-filter-empty p {
  margin: 0 auto 22px !important;
  max-width: 460px !important;
  color: #6e6e73 !important;
  font-size: 16px !important;
  line-height: 1.5 !important;
}

.sleepmoon-filter-empty-actions {
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  gap: 12px !important;
  flex-wrap: wrap !important;
}

@media (max-width: 1100px) {
  .woocommerce-cart .cart-collaterals.sleepmoon-cart-collaterals,
  body.woocommerce-cart .cart-collaterals.sleepmoon-cart-collaterals {
    margin-top: 0 !important;
  }
}

.cart-badge.is-empty,
#drawer-cart-badge.is-empty,
.cart-badge[data-count="0"],
#drawer-cart-badge[data-count="0"] {
  display: none !important;
}

.cart-badge:not(.is-synced),
#drawer-cart-badge:not(.is-synced) {
  visibility: hidden !important;
}

/* ===========================================================
   v1.6.7 - Mobile cart and checkout polish
   =========================================================== */

@media (max-width: 760px) {
  html,
  body.woocommerce-cart,
  body.woocommerce-checkout {
    overflow-x: hidden !important;
  }

  body.woocommerce-cart .sleepmoon-cart-page {
    width: 100% !important;
    max-width: 100% !important;
    padding: 22px 14px 44px !important;
    overflow: hidden !important;
  }

  body.woocommerce-cart .sleepmoon-cart-header {
    gap: 16px !important;
    margin-bottom: 20px !important;
  }

  body.woocommerce-cart .sleepmoon-cart-header h1 {
    font-size: 34px !important;
    line-height: 1.05 !important;
  }

  body.woocommerce-cart .sleepmoon-cart-continue {
    width: 100% !important;
    justify-content: center !important;
    min-height: 46px !important;
  }

  body.woocommerce-cart .sleepmoon-cart-layout {
    display: block !important;
    width: 100% !important;
    max-width: 100% !important;
  }

  body.woocommerce-cart .sleepmoon-cart-card,
  body.woocommerce-cart .sleepmoon-cart-totals {
    border-radius: 14px !important;
  }

  body.woocommerce-cart .sleepmoon-cart-card-head {
    min-height: 0 !important;
    padding: 18px !important;
  }

  body.woocommerce-cart .sleepmoon-cart-card-head strong {
    font-size: 26px !important;
  }

  body.woocommerce-cart table.shop_table_responsive tr td::before,
  body.woocommerce-cart .sleepmoon-cart-table td::before,
  body.woocommerce-cart .sleepmoon-cart-table td::after {
    display: none !important;
    content: none !important;
  }

  body.woocommerce-cart .sleepmoon-cart-table,
  body.woocommerce-cart .sleepmoon-cart-table tbody,
  body.woocommerce-cart .sleepmoon-cart-table tr,
  body.woocommerce-cart .sleepmoon-cart-table td {
    width: 100% !important;
    max-width: 100% !important;
    box-sizing: border-box !important;
  }

  body.woocommerce-cart .sleepmoon-cart-table tr.sleepmoon-cart-item {
    display: grid !important;
    grid-template-columns: 78px minmax(0, 1fr) 38px !important;
    grid-template-areas:
      "media copy remove"
      "media qty remove"
      "media total remove" !important;
    gap: 8px 12px !important;
    align-items: start !important;
    padding: 18px 14px !important;
  }

  body.woocommerce-cart .sleepmoon-cart-table td {
    display: block !important;
    padding: 0 !important;
    text-align: left !important;
  }

  body.woocommerce-cart .sleepmoon-cart-item-media {
    grid-area: media !important;
    width: 78px !important;
    height: 78px !important;
  }

  body.woocommerce-cart .sleepmoon-cart-item-media a {
    width: 78px !important;
    height: 78px !important;
  }

  body.woocommerce-cart .sleepmoon-cart-item-media img,
  body.woocommerce-cart .sleepmoon-cart-item-media a img {
    width: 72px !important;
    height: 72px !important;
    max-width: 72px !important;
  }

  body.woocommerce-cart .sleepmoon-cart-item-copy {
    grid-area: copy !important;
    min-width: 0 !important;
  }

  body.woocommerce-cart .sleepmoon-cart-product-title,
  body.woocommerce-cart .sleepmoon-cart-item-copy > a {
    font-size: 16px !important;
    line-height: 1.28 !important;
    overflow-wrap: anywhere !important;
  }

  body.woocommerce-cart .sleepmoon-cart-label {
    display: none !important;
  }

  body.woocommerce-cart .sleepmoon-cart-item-price {
    display: none !important;
  }

  body.woocommerce-cart .sleepmoon-cart-item-qty {
    grid-area: qty !important;
  }

  body.woocommerce-cart .sleepmoon-cart-item-total {
    grid-area: total !important;
    font-size: 16px !important;
    font-weight: 900 !important;
    text-align: left !important;
  }

  body.woocommerce-cart .sleepmoon-cart-item-qty .quantity input.qty {
    width: 66px !important;
    height: 42px !important;
    min-height: 42px !important;
  }

  body.woocommerce-cart .sleepmoon-cart-item-remove {
    grid-area: remove !important;
    align-self: start !important;
    justify-self: end !important;
    width: auto !important;
    text-align: right !important;
  }

  body.woocommerce-cart .sleepmoon-cart-item-remove .remove {
    width: 36px !important;
    height: 36px !important;
  }

  body.woocommerce-cart .sleepmoon-cart-actions-inner {
    display: grid !important;
    gap: 16px !important;
    padding: 18px 14px !important;
  }

  body.woocommerce-cart .sleepmoon-cart-coupon {
    max-width: none !important;
    width: 100% !important;
    text-align: center !important;
  }

  body.woocommerce-cart .sleepmoon-cart-coupon div {
    grid-template-columns: 1fr !important;
  }

  body.woocommerce-cart .sleepmoon-cart-coupon input.input-text,
  body.woocommerce-cart .sleepmoon-cart-coupon button,
  body.woocommerce-cart .sleepmoon-cart-update {
    width: 100% !important;
  }

  body.woocommerce-cart .sleepmoon-cart-collaterals {
    position: static !important;
    margin-top: 18px !important;
  }

  body.woocommerce-cart .sleepmoon-cart-totals {
    padding: 20px !important;
  }

  body.woocommerce-checkout {
    background: #fff !important;
  }

  body.woocommerce-checkout .sleepmoon-checkout-shell,
  body.woocommerce-checkout form.checkout.sleepmoon-checkout-layout,
  body.woocommerce-checkout .sleepmoon-checkout-main,
  body.woocommerce-checkout .sleepmoon-checkout-sidebar,
  body.woocommerce-checkout #order_review,
  body.woocommerce-checkout .sleepmoon-order-review-card {
    width: 100% !important;
    max-width: 100% !important;
    min-width: 0 !important;
    box-sizing: border-box !important;
  }

  body.woocommerce-checkout .sleepmoon-checkout-brandbar {
    height: auto !important;
    min-height: 74px !important;
    padding: 14px !important;
    gap: 14px !important;
  }

  body.woocommerce-checkout .sleepmoon-checkout-logo {
    font-size: 21px !important;
  }

  body.woocommerce-checkout form.checkout.sleepmoon-checkout-layout {
    display: flex !important;
    flex-direction: column !important;
    gap: 24px !important;
    padding: 20px 14px 42px !important;
    margin: 0 !important;
  }

  body.woocommerce-checkout .sleepmoon-checkout-main input.input-text,
  body.woocommerce-checkout .sleepmoon-checkout-main textarea,
  body.woocommerce-checkout .sleepmoon-checkout-main select,
  body.woocommerce-checkout .sleepmoon-checkout-main .select2-selection {
    min-height: 56px !important;
    font-size: 15px !important;
    padding: 14px !important;
  }

  body.woocommerce-checkout .sleepmoon-checkout-sidebar {
    position: static !important;
    padding: 16px !important;
    border-radius: 14px !important;
    background: #f5f5f7 !important;
  }

  body.woocommerce-checkout .sm-checkout-products {
    gap: 14px !important;
    margin-bottom: 22px !important;
  }

  body.woocommerce-checkout .sm-checkout-product {
    display: grid !important;
    grid-template-columns: 72px minmax(0, 1fr) 36px !important;
    grid-template-areas:
      "image copy remove"
      "image total remove" !important;
    gap: 8px 12px !important;
    align-items: start !important;
  }

  body.woocommerce-checkout .sm-checkout-product-img {
    grid-area: image !important;
    width: 72px !important;
    height: 72px !important;
  }

  body.woocommerce-checkout .sm-checkout-product-img img {
    width: 58px !important;
    height: 58px !important;
  }

  body.woocommerce-checkout .sm-checkout-product-copy {
    grid-area: copy !important;
    min-width: 0 !important;
  }

  body.woocommerce-checkout .sm-checkout-product-copy strong {
    font-size: 15px !important;
    line-height: 1.28 !important;
    font-weight: 750 !important;
    overflow-wrap: anywhere !important;
  }

  body.woocommerce-checkout .sm-checkout-product-total {
    grid-area: total !important;
    justify-self: start !important;
    font-size: 15px !important;
    font-weight: 800 !important;
    white-space: normal !important;
  }

  body.woocommerce-checkout .sm-checkout-product-remove {
    grid-area: remove !important;
    width: 34px !important;
    height: 34px !important;
    justify-self: end !important;
    align-self: start !important;
  }

  body.woocommerce-checkout .sm-checkout-coupon {
    grid-template-columns: 1fr !important;
    gap: 10px !important;
    margin-bottom: 24px !important;
  }

  body.woocommerce-checkout .sm-checkout-coupon input,
  body.woocommerce-checkout .sm-checkout-coupon button {
    width: 100% !important;
    height: 56px !important;
  }

  body.woocommerce-checkout .sm-checkout-totals {
    table-layout: fixed !important;
  }

  body.woocommerce-checkout .sm-checkout-totals th,
  body.woocommerce-checkout .sm-checkout-totals td {
    font-size: 15px !important;
  }

  body.woocommerce-checkout .sm-checkout-totals .order-total th,
  body.woocommerce-checkout .sm-checkout-totals .order-total td,
  body.woocommerce-checkout .sm-checkout-totals .order-total .amount {
    font-size: 24px !important;
  }

  body.woocommerce-checkout .sm-checkout-rec {
    display: grid !important;
    grid-template-columns: 74px minmax(0, 1fr) !important;
    grid-template-areas:
      "image copy"
      "button button" !important;
    gap: 12px 14px !important;
    align-items: start !important;
    width: 100% !important;
    max-width: 100% !important;
  }

  body.woocommerce-checkout .sm-checkout-rec-img {
    grid-area: image !important;
    width: 74px !important;
    height: 74px !important;
  }

  body.woocommerce-checkout .sm-checkout-rec-img img {
    width: 64px !important;
    height: 64px !important;
  }

  body.woocommerce-checkout .sm-checkout-rec-copy {
    grid-area: copy !important;
    min-width: 0 !important;
  }

  body.woocommerce-checkout .sm-checkout-rec-copy a {
    font-size: 16px !important;
    line-height: 1.25 !important;
    overflow-wrap: anywhere !important;
  }

  body.woocommerce-checkout .sm-checkout-rec-add {
    grid-area: button !important;
    grid-column: 1 / -1 !important;
    width: 100% !important;
    max-width: 100% !important;
    min-height: 52px !important;
    padding: 0 16px !important;
    border-radius: 12px !important;
    box-sizing: border-box !important;
  }
}

@media (max-width: 390px) {
  body.woocommerce-cart .sleepmoon-cart-table tr.sleepmoon-cart-item,
  body.woocommerce-checkout .sm-checkout-product {
    grid-template-columns: 66px minmax(0, 1fr) 34px !important;
  }

  body.woocommerce-cart .sleepmoon-cart-item-media,
  body.woocommerce-cart .sleepmoon-cart-item-media a,
  body.woocommerce-checkout .sm-checkout-product-img {
    width: 66px !important;
    height: 66px !important;
  }

  body.woocommerce-cart .sleepmoon-cart-item-media img,
  body.woocommerce-cart .sleepmoon-cart-item-media a img,
  body.woocommerce-checkout .sm-checkout-product-img img {
    width: 58px !important;
    height: 58px !important;
  }
}

/* ===========================================================
   v1.6.8 - Mobile archive spacing and single cart price
   =========================================================== */

@media (max-width: 768px) {
  body.woocommerce .mobile-filter-bar,
  body.post-type-archive-product .mobile-filter-bar,
  body.tax-product_cat .mobile-filter-bar {
    margin-top: 18px !important;
    margin-bottom: 28px !important;
  }
}

@media (max-width: 760px) {
  body.woocommerce-cart .sleepmoon-cart-table tr.sleepmoon-cart-item {
    grid-template-areas:
      "media copy remove"
      "media qty remove"
      "media total remove" !important;
  }

  body.woocommerce-cart table.shop_table_responsive.cart tr.cart_item td.product-price.sleepmoon-cart-item-price,
  body.woocommerce-cart .sleepmoon-cart-table tr.sleepmoon-cart-item > td.product-price,
  body.woocommerce-cart .sleepmoon-cart-table tr.sleepmoon-cart-item > td.sleepmoon-cart-item-price {
    display: none !important;
    visibility: hidden !important;
    width: 0 !important;
    height: 0 !important;
    min-height: 0 !important;
    padding: 0 !important;
    margin: 0 !important;
    overflow: hidden !important;
  }
}

/* ===========================================================
   v1.7.7 - Static offer gifts in cart and checkout
   =========================================================== */

.sleepmoon-gift-badge,
.sleepmoon-gift-price,
.sleepmoon-gift-quantity {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  width: fit-content !important;
  min-height: 26px !important;
  padding: 0 10px !important;
  border-radius: 999px !important;
  font-size: 12px !important;
  line-height: 1 !important;
  font-weight: 900 !important;
}

.sleepmoon-gift-badge {
  margin-right: 7px !important;
  background: #eaf7ef !important;
  color: #128143 !important;
}

.sleepmoon-gift-price {
  background: #eaf3ff !important;
  color: #0877e8 !important;
}

.sleepmoon-gift-quantity {
  border: 1px solid #d6ead9 !important;
  background: #fff !important;
  color: #128143 !important;
}

body.woocommerce-cart .sleepmoon-cart-gift,
body.woocommerce-checkout .sleepmoon-cart-gift {
  background: linear-gradient(90deg, rgba(234, 247, 239, .62), rgba(255, 255, 255, 0)) !important;
}

body.woocommerce-cart .sleepmoon-cart-gift .sleepmoon-cart-product-title,
body.woocommerce-cart .sleepmoon-cart-gift .sleepmoon-cart-item-copy > a,
body.woocommerce-checkout .sleepmoon-cart-gift .sm-checkout-product-copy strong {
  color: #0d3b25 !important;
}

/* ===========================================================
   v1.6.9 - Promotional homepage
   =========================================================== */

.sm-home-hero {
  padding: 74px 0 56px !important;
  background:
    linear-gradient(135deg, rgba(9, 38, 71, .96) 0%, rgba(10, 93, 151, .94) 54%, rgba(23, 142, 205, .92) 100%),
    #0b5f99 !important;
  color: #fff !important;
  overflow: hidden !important;
}

.sm-home-hero-grid {
  display: grid !important;
  grid-template-columns: minmax(0, 1.02fr) minmax(360px, .88fr) !important;
  gap: 54px !important;
  align-items: center !important;
}

.sm-home-kicker,
.sm-home-hero .sm-home-kicker {
  width: fit-content !important;
  margin-bottom: 18px !important;
  padding: 8px 14px !important;
  border: 1px solid rgba(255, 255, 255, .28) !important;
  border-radius: 999px !important;
  background: rgba(255, 255, 255, .12) !important;
  color: #fff !important;
  font-size: 12px !important;
  line-height: 1 !important;
  font-weight: 850 !important;
  letter-spacing: .08em !important;
  text-transform: uppercase !important;
}

.sm-home-hero h1 {
  max-width: 720px !important;
  margin: 0 0 18px !important;
  color: #fff !important;
  font-size: clamp(42px, 5.6vw, 74px) !important;
  line-height: .98 !important;
  font-weight: 950 !important;
}

.sm-home-hero p {
  max-width: 590px !important;
  margin: 0 0 28px !important;
  color: rgba(255, 255, 255, .88) !important;
  font-size: 18px !important;
  line-height: 1.55 !important;
}

.sm-home-hero-actions {
  display: flex !important;
  flex-wrap: wrap !important;
  gap: 12px !important;
  align-items: center !important;
}

.sm-home-hero-actions .btn-ghost {
  border-color: rgba(255, 255, 255, .42) !important;
  color: #fff !important;
  background: rgba(255, 255, 255, .08) !important;
}

.sm-home-trust-row {
  display: flex !important;
  flex-wrap: wrap !important;
  gap: 12px !important;
  margin-top: 30px !important;
}

.sm-home-trust-row span {
  min-height: 48px !important;
  padding: 0 18px !important;
  border-radius: 999px !important;
  background: rgba(255, 255, 255, .18) !important;
  border: 1px solid rgba(255, 255, 255, .28) !important;
  color: #fff !important;
  display: inline-flex !important;
  align-items: center !important;
  box-shadow: 0 14px 34px rgba(7, 22, 44, .16) !important;
  font-size: 14px !important;
  font-weight: 900 !important;
}

.sm-home-hero-visual {
  position: relative !important;
  min-height: 0 !important;
  display: grid !important;
  grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  grid-template-areas:
    "main main"
    "mini-a mini-b" !important;
  gap: 16px !important;
}

.sm-home-hero-card {
  border: 1px solid rgba(255, 255, 255, .38) !important;
  border-radius: 18px !important;
  background: rgba(255, 255, 255, .94) !important;
  color: #07162c !important;
  box-shadow: 0 30px 80px rgba(0, 0, 0, .22) !important;
}

.sm-home-hero-card-main {
  grid-area: main !important;
  position: relative !important;
  inset: auto !important;
  min-height: 470px !important;
  display: flex !important;
  flex-direction: column !important;
  justify-content: space-between !important;
  padding: 28px !important;
  overflow: hidden !important;
}

.sm-home-hero-card-main span,
.sm-home-offer-copy span,
.sm-home-newsletter span {
  width: fit-content !important;
  display: inline-flex !important;
  align-items: center !important;
  min-height: 30px !important;
  padding: 0 12px !important;
  border-radius: 999px !important;
  background: #ff3f55 !important;
  color: #fff !important;
  font-size: 12px !important;
  font-weight: 900 !important;
  letter-spacing: .04em !important;
  text-transform: uppercase !important;
}

.sm-home-hero-card-main strong {
  max-width: 100% !important;
  margin-top: 18px !important;
  display: block !important;
  color: #07162c !important;
  font-size: 31px !important;
  line-height: 1.08 !important;
  font-weight: 950 !important;
}

.sm-home-hero-card-main p {
  max-width: 430px !important;
  margin: 14px 0 12px !important;
  color: #516070 !important;
  font-size: 15px !important;
}

.sm-home-hero-card-main img {
  align-self: center !important;
  width: min(88%, 430px) !important;
  height: auto !important;
  object-fit: contain !important;
  border-radius: 18px !important;
  filter: drop-shadow(0 22px 28px rgba(7, 22, 44, .18)) !important;
}

.sm-home-mini-offer {
  position: relative !important;
  z-index: 2 !important;
  width: auto !important;
  min-height: 104px !important;
  padding: 18px !important;
  border: 1px solid rgba(255, 255, 255, .54) !important;
  border-radius: 16px !important;
  background: #fff !important;
  color: #07162c !important;
  box-shadow: 0 18px 48px rgba(0, 0, 0, .18) !important;
}

.sm-home-mini-offer span {
  display: block !important;
  color: #0877e8 !important;
  font-size: 30px !important;
  line-height: 1 !important;
  font-weight: 950 !important;
}

.sm-home-mini-offer strong {
  display: block !important;
  margin-top: 5px !important;
  font-size: 14px !important;
  line-height: 1.25 !important;
}

.sm-home-mini-offer-a {
  grid-area: mini-a !important;
  right: auto !important;
  top: auto !important;
}

.sm-home-mini-offer-b {
  grid-area: mini-b !important;
  left: auto !important;
  bottom: auto !important;
}

.sm-home-offer-strip {
  padding: 20px 0 !important;
  background: #fff !important;
  border-bottom: 1px solid #e6edf5 !important;
}

.sm-home-offer-strip-grid {
  display: grid !important;
  grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
  gap: 14px !important;
}

.sm-home-offer-strip a {
  min-height: 78px !important;
  padding: 16px 18px !important;
  border: 1px solid #dde7f0 !important;
  border-radius: 14px !important;
  background: #f8fbff !important;
  color: #07162c !important;
  display: flex !important;
  flex-direction: column !important;
  justify-content: center !important;
  text-decoration: none !important;
}

.sm-home-offer-strip strong {
  display: block !important;
  color: #0877e8 !important;
  font-size: 20px !important;
  line-height: 1.1 !important;
  font-weight: 950 !important;
}

.sm-home-offer-strip span {
  margin-top: 4px !important;
  color: #5b6776 !important;
  font-size: 14px !important;
  font-weight: 650 !important;
}

.sm-home-offer-strip-grid > a.added_to_cart.wc-forward,
.sm-home-offer-copy > a.added_to_cart.wc-forward {
  display: none !important;
}

.sm-home-offers,
.sm-home-products,
.sm-home-categories {
  background: #fff !important;
}

.sm-home-offers-grid {
  display: grid !important;
  grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
  gap: 20px !important;
}

.sm-home-offer-card {
  position: relative !important;
  min-height: 486px !important;
  padding: 28px !important;
  border: 1px solid #dbe7f2 !important;
  border-radius: 24px !important;
  background: linear-gradient(180deg, #f8fbff 0%, #eef7ff 100%) !important;
  display: flex !important;
  flex-direction: column !important;
  justify-content: space-between !important;
  overflow: hidden !important;
  box-shadow: 0 22px 60px rgba(7, 22, 44, .07) !important;
  transition: transform .22s ease, box-shadow .22s ease !important;
}

.sm-home-offer-card:hover {
  transform: translateY(-3px) !important;
  box-shadow: 0 28px 72px rgba(7, 22, 44, .11) !important;
}

.sm-home-offer-card h3 {
  margin: 18px 0 10px !important;
  color: #07162c !important;
  font-size: 30px !important;
  line-height: 1.08 !important;
  font-weight: 950 !important;
}

.sm-home-offer-card p {
  margin: 0 0 18px !important;
  color: #536171 !important;
  font-size: 15px !important;
  line-height: 1.5 !important;
}

.sm-home-offer-card a {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  min-height: 46px !important;
  padding: 0 20px !important;
  border-radius: 999px !important;
  background: #0877e8 !important;
  color: #fff !important;
  font-size: 14px !important;
  font-weight: 850 !important;
  text-decoration: none !important;
  box-shadow: 0 12px 26px rgba(8, 119, 232, .20) !important;
}

.sm-home-offer-image {
  width: 100% !important;
  margin-top: 28px !important;
  min-height: 250px !important;
  padding: 18px !important;
  border: 1px solid rgba(210, 224, 236, .82) !important;
  border-radius: 24px !important;
  background: linear-gradient(180deg, rgba(255, 255, 255, .94) 0%, rgba(248, 251, 255, .82) 100%) !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  gap: 12px !important;
  overflow: hidden !important;
}

.sm-home-offer-image img {
  width: min(92%, 330px) !important;
  max-height: 225px !important;
  height: auto !important;
  object-fit: contain !important;
  border-radius: 16px !important;
  background: #fff !important;
  box-shadow: 0 18px 38px rgba(7, 22, 44, .12) !important;
  filter: none !important;
}

.sm-home-offer-image-bonus {
  position: relative !important;
  min-height: 260px !important;
  justify-content: center !important;
  align-items: flex-end !important;
  padding: 28px 18px 18px !important;
}

.sm-home-offer-image-bonus .sm-home-offer-main-img {
  width: min(88%, 315px) !important;
  max-height: 220px !important;
  height: auto !important;
  object-fit: contain !important;
}

.sm-home-offer-bonus-badge {
  position: absolute !important;
  top: 14px !important;
  right: 14px !important;
  display: flex !important;
  align-items: center !important;
  gap: 10px !important;
  padding: 8px 10px !important;
  border-radius: 18px !important;
  background: rgba(255, 255, 255, .96) !important;
  border: 1px solid rgba(8, 119, 232, .22) !important;
  box-shadow: 0 18px 40px rgba(7, 22, 44, .14) !important;
}

.sm-home-offer-bonus-badge img.sm-home-offer-image-extra {
  width: 112px !important;
  height: 82px !important;
  aspect-ratio: auto !important;
  object-fit: cover !important;
  border-radius: 12px !important;
  box-shadow: none !important;
  filter: none !important;
}

.sm-home-offer-plus {
  width: 38px !important;
  height: 38px !important;
  border-radius: 999px !important;
  background: #0877e8 !important;
  color: #fff !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  flex: 0 0 38px !important;
  font-size: 25px !important;
  line-height: 1 !important;
  font-weight: 950 !important;
  box-shadow: 0 12px 24px rgba(8, 119, 232, .2) !important;
}

.sm-home-offer-green {
  background: linear-gradient(180deg, #f8fff7 0%, #eef9ef 100%) !important;
  border-color: #d6ead9 !important;
}

.sm-home-offer-green .sm-home-offer-copy span {
  background: #1f8a56 !important;
}

.sm-home-offer-coral {
  background: linear-gradient(180deg, #fff8f5 0%, #fff0eb 100%) !important;
  border-color: #f1ddd5 !important;
}

.sm-home-offer-coral .sm-home-offer-copy span {
  background: #ff6a3d !important;
}

.sm-home-benefits {
  padding: 28px 0 !important;
  background: #07162c !important;
  color: #fff !important;
}

.sm-home-benefits-grid {
  display: grid !important;
  grid-template-columns: repeat(4, minmax(0, 1fr)) !important;
  gap: 14px !important;
}

.sm-home-benefits-grid div {
  padding: 18px !important;
  border: 1px solid rgba(255, 255, 255, .12) !important;
  border-radius: 14px !important;
  background: rgba(255, 255, 255, .06) !important;
}

.sm-home-benefits-grid span {
  display: block !important;
  margin-bottom: 10px !important;
  color: #7bd0ff !important;
  font-size: 24px !important;
  line-height: 1 !important;
  font-weight: 950 !important;
}

.sm-home-benefits-grid strong {
  display: block !important;
  color: #fff !important;
  font-size: 16px !important;
  font-weight: 850 !important;
}

.sm-home-benefits-grid p {
  margin: 6px 0 0 !important;
  color: rgba(255, 255, 255, .72) !important;
  font-size: 13px !important;
  line-height: 1.4 !important;
}

.sm-home-center-action {
  margin-top: 38px !important;
  text-align: center !important;
}

.sm-home-categories {
  padding-top: 72px !important;
  background: #f5f7fb !important;
}

.sm-home-category-grid {
  display: grid !important;
  grid-template-columns: 1.25fr 1fr 1fr !important;
  gap: 18px !important;
}

.sm-home-category-card {
  min-height: 250px !important;
  padding: 22px !important;
  border: 1px solid #dde7f0 !important;
  border-radius: 18px !important;
  background: #fff !important;
  color: #07162c !important;
  display: flex !important;
  flex-direction: column !important;
  justify-content: space-between !important;
  overflow: hidden !important;
  text-decoration: none !important;
}

.sm-home-category-large {
  grid-row: span 2 !important;
  min-height: 518px !important;
}

.sm-home-category-card img {
  align-self: center !important;
  width: min(72%, 260px) !important;
  max-height: 260px !important;
  object-fit: contain !important;
  transition: transform .25s ease !important;
}

.sm-home-category-card:hover img {
  transform: scale(1.04) !important;
}

.sm-home-category-card span {
  color: #0877e8 !important;
  font-size: 12px !important;
  font-weight: 900 !important;
  letter-spacing: .08em !important;
  text-transform: uppercase !important;
}

.sm-home-category-card strong {
  display: block !important;
  margin-top: 8px !important;
  color: #07162c !important;
  font-size: 19px !important;
  line-height: 1.22 !important;
  font-weight: 900 !important;
}

.sm-home-configurator {
  padding: 76px 0 !important;
  background: #fff !important;
}

.sm-home-configurator-grid {
  display: grid !important;
  grid-template-columns: minmax(0, .95fr) minmax(340px, 1fr) !important;
  gap: 48px !important;
  align-items: center !important;
}

.sm-home-configurator .sm-home-kicker {
  border-color: #d8e6f2 !important;
  background: #f3f8ff !important;
  color: #0877e8 !important;
}

.sm-home-configurator h2,
.sm-home-newsletter h2 {
  margin: 0 0 14px !important;
  color: #07162c !important;
  font-size: 40px !important;
  line-height: 1.08 !important;
  font-weight: 950 !important;
}

.sm-home-configurator p,
.sm-home-newsletter p {
  max-width: 570px !important;
  margin: 0 0 26px !important;
  color: #536171 !important;
  font-size: 17px !important;
  line-height: 1.55 !important;
}

.sm-home-configurator img {
  width: 100% !important;
  max-height: 420px !important;
  object-fit: contain !important;
  border-radius: 18px !important;
  background: #f5f7fb !important;
  box-shadow: 0 24px 64px rgba(7, 22, 44, .12) !important;
}

.sm-configurator-preview {
  position: relative !important;
  min-height: 420px !important;
  border-radius: 28px !important;
  background:
    radial-gradient(circle at 78% 16%, rgba(255, 184, 77, .38) 0 22%, transparent 23%),
    linear-gradient(135deg, #0a2748 0%, #123d68 100%) !important;
  overflow: hidden !important;
  box-shadow: 0 30px 80px rgba(7, 22, 44, .18) !important;
}

.sm-configurator-preview-panel {
  position: absolute !important;
  border-radius: 26px !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  overflow: hidden !important;
  background: rgba(255, 255, 255, .96) !important;
  box-shadow: 0 24px 58px rgba(0, 0, 0, .18) !important;
}

.sm-configurator-preview-panel img {
  width: 100% !important;
  height: 100% !important;
  max-height: none !important;
  object-fit: contain !important;
  border-radius: 0 !important;
  background: #fff !important;
  box-shadow: none !important;
}

.sm-configurator-preview-back {
  z-index: 1 !important;
  top: 34px !important;
  right: 36px !important;
  width: 58% !important;
  height: 58% !important;
  border: 5px solid #ffbf47 !important;
  transform: rotate(2deg) !important;
}

.sm-configurator-preview-front {
  z-index: 2 !important;
  left: 42px !important;
  bottom: 54px !important;
  width: 62% !important;
  height: 48% !important;
  border: 5px solid #46b86f !important;
  transform: rotate(-4deg) !important;
}

.sm-configurator-preview-copy {
  position: absolute !important;
  z-index: 3 !important;
  right: 42px !important;
  bottom: 34px !important;
  padding: 14px 18px !important;
  border-radius: 16px !important;
  background: rgba(7, 22, 44, .76) !important;
  color: #fff !important;
  box-shadow: 0 18px 42px rgba(0, 0, 0, .16) !important;
}

.sm-configurator-preview-copy strong,
.sm-configurator-preview-copy span {
  display: block !important;
}

.sm-configurator-preview-copy strong {
  font-size: 20px !important;
  font-weight: 950 !important;
  line-height: 1.1 !important;
}

.sm-configurator-preview-copy span {
  margin-top: 4px !important;
  color: #ffbf47 !important;
  font-size: 13px !important;
  font-weight: 850 !important;
}

.sm-home-newsletter {
  padding: 74px 0 !important;
  background: #f5f7fb !important;
  text-align: center !important;
}

.sm-home-newsletter span {
  margin: 0 auto 16px !important;
  background: #0877e8 !important;
}

.sm-home-newsletter p {
  margin-left: auto !important;
  margin-right: auto !important;
}

@media (max-width: 980px) {
  .sm-home-hero-grid,
  .sm-home-configurator-grid {
    grid-template-columns: 1fr !important;
  }

  .sm-home-hero-visual {
    min-height: 430px !important;
  }

  .sm-configurator-preview {
    min-height: 380px !important;
  }

  .sm-home-offers-grid,
  .sm-home-benefits-grid,
  .sm-home-category-grid {
    grid-template-columns: 1fr 1fr !important;
  }

  .sm-home-category-large {
    grid-row: auto !important;
    min-height: 250px !important;
  }
}

@media (max-width: 760px) {
  .sm-home-hero {
    padding: 44px 0 34px !important;
  }

  .sm-home-hero h1 {
    font-size: 40px !important;
  }

  .sm-home-hero p {
    font-size: 16px !important;
  }

  .sm-home-hero-actions .btn {
    width: 100% !important;
    justify-content: center !important;
  }

  .sm-home-trust-row span {
    width: 100% !important;
    text-align: center !important;
  }

  .sm-home-hero-visual {
    min-height: 0 !important;
    display: grid !important;
    gap: 12px !important;
  }

  .sm-home-hero-card-main,
  .sm-home-mini-offer {
    position: static !important;
    width: 100% !important;
  }

  .sm-home-hero-card-main strong {
    font-size: 28px !important;
  }

  .sm-home-hero-card-main img {
    width: 82% !important;
    align-self: center !important;
  }

  .sm-configurator-preview {
    min-height: 330px !important;
  }

  .sm-configurator-preview-back {
    top: 26px !important;
    right: 22px !important;
    width: 66% !important;
    height: 52% !important;
  }

  .sm-configurator-preview-front {
    left: 20px !important;
    bottom: 62px !important;
    width: 70% !important;
    height: 44% !important;
  }

  .sm-configurator-preview-copy {
    left: 20px !important;
    right: 20px !important;
    bottom: 18px !important;
  }

  .sm-home-offer-strip-grid,
  .sm-home-offers-grid,
  .sm-home-benefits-grid,
  .sm-home-category-grid {
    grid-template-columns: 1fr !important;
  }

  .sm-home-offer-card,
  .sm-home-category-card,
  .sm-home-category-large {
    min-height: 0 !important;
  }

  .sm-home-offer-card h3 {
    font-size: 25px !important;
  }

  .sm-home-offer-image {
    min-height: 120px !important;
  }

  .sm-home-configurator h2,
  .sm-home-newsletter h2 {
    font-size: 30px !important;
  }

  .sm-home-newsletter .news-form {
    width: 100% !important;
  }
}

/* v1.7.9 - Static offers on Reductions and refined offer copy */
.sm-home-mini-offer span {
  font-size: clamp(20px, 2vw, 28px) !important;
  line-height: 1.05 !important;
}

.sm-reduceri-offers {
  padding-top: 54px !important;
}

.sm-reduceri-page-hero {
  background: linear-gradient(135deg, #12345a, #0f91e3) !important;
}

.sm-reduceri-page-content {
  padding: 0 0 56px !important;
}

.sm-reduceri-products {
  padding: 64px 0 70px !important;
}

.sm-reduceri-products .section-header {
  margin-bottom: 34px !important;
}

.sm-reduceri-products .products-grid {
  margin-top: 0 !important;
}

.sm-reduceri-page-content .page-content:empty {
  display: none !important;
}

.sm-reduceri-note {
  margin: 28px 0 56px !important;
  padding: 24px !important;
  border: 1px solid #dbe7f2 !important;
  border-radius: 18px !important;
  background: #f8fbff !important;
  display: grid !important;
  gap: 6px !important;
  color: #10213d !important;
}

.sm-reduceri-note strong {
  font-size: 20px !important;
  font-weight: 950 !important;
}

.sm-reduceri-note span {
  color: #607086 !important;
  font-size: 15px !important;
}

/* v1.8.0 - Homepage category photos and cleaner hero benefits */
.sm-home-hero-visual {
  grid-template-columns: 1fr !important;
  grid-template-areas: "main" !important;
  align-content: center !important;
}

.sm-home-hero-card-main {
  min-height: 540px !important;
}

.sm-home-trust-row {
  display: grid !important;
  grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
  gap: 14px !important;
  margin-top: 36px !important;
  max-width: 760px !important;
}

.sm-home-trust-row span {
  min-width: 0 !important;
  min-height: 58px !important;
  padding: 0 18px !important;
  justify-content: center !important;
  background: rgba(255, 255, 255, .24) !important;
  border-color: rgba(255, 255, 255, .38) !important;
  font-size: 16px !important;
  text-align: center !important;
  white-space: normal !important;
  line-height: 1.18 !important;
  overflow-wrap: anywhere !important;
  box-shadow: 0 18px 44px rgba(7, 22, 44, .22) !important;
}

.sm-home-category-card {
  min-height: 360px !important;
  gap: 16px !important;
  padding: 20px !important;
}

.sm-home-category-large {
  min-height: 600px !important;
}

.sm-home-category-card img {
  width: 100% !important;
  max-height: none !important;
  height: 250px !important;
  border-radius: 18px !important;
  background: #fff !important;
  object-fit: cover !important;
  object-position: center !important;
  box-shadow: 0 18px 42px rgba(7, 22, 44, .08) !important;
}

.sm-home-category-large img {
  height: 430px !important;
}

@media (max-width: 980px) {
  .sm-home-hero-card-main {
    min-height: 460px !important;
  }

  .sm-home-category-large,
  .sm-home-category-card {
    min-height: 360px !important;
  }

  .sm-home-category-large img,
  .sm-home-category-card img {
    height: 250px !important;
  }
}

@media (max-width: 760px) {
  .sm-home-trust-row {
    grid-template-columns: 1fr !important;
    max-width: 100% !important;
  }

  .sm-home-trust-row span {
    min-width: 0 !important;
    min-height: 54px !important;
    font-size: 15px !important;
    white-space: normal !important;
  }

  .sm-home-hero-card-main {
    min-height: 0 !important;
  }

  .sm-home-category-large img,
  .sm-home-category-card img {
    height: 220px !important;
  }
}

/* v1.8.2 - Real pillow photos in configurator */
.config-preview-image-wrap {
  width: min(100%, 620px) !important;
  min-height: 330px !important;
  padding: 0 !important;
  border-radius: 24px !important;
  background: #fbfbfa !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  overflow: hidden !important;
  box-shadow: 0 28px 70px rgba(0, 0, 0, .24) !important;
}

.config-pillow-photo {
  width: 100% !important;
  height: 345px !important;
  max-width: none !important;
  object-fit: cover !important;
  object-position: center !important;
  border-radius: 24px !important;
  background: #fbfbfa !important;
  transition: opacity .18s ease, transform .18s ease !important;
}

.config-visual #config-preview-text {
  max-width: 620px !important;
  color: rgba(255, 255, 255, .9) !important;
  font-size: 20px !important;
  line-height: 1.5 !important;
  font-weight: 650 !important;
  text-align: center !important;
  margin-left: auto !important;
  margin-right: auto !important;
}

.config-visual #config-firmness {
  color: rgba(255, 255, 255, .72) !important;
  font-size: 15px !important;
  text-align: center !important;
}

.config-step-card {
  text-align: center !important;
}

.config-step-card .step-head {
  justify-content: center !important;
  text-align: center !important;
  font-size: 19px !important;
}

.config-step-card .step-head strong {
  font-size: 19px !important;
  line-height: 1.25 !important;
}

.config-step-card > p {
  font-size: 14px !important;
  line-height: 1.5 !important;
  text-align: center !important;
}

.config-opt {
  font-size: 15px !important;
  font-weight: 750 !important;
  min-height: 58px !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
}

.config-summary-card {
  text-align: center !important;
}

.config-summary-card .label,
.config-summary-card #config-summary {
  text-align: center !important;
}

.config-summary-card #config-summary {
  font-size: 16px !important;
  line-height: 1.55 !important;
  margin-left: auto !important;
  margin-right: auto !important;
}

@media (max-width: 760px) {
  .config-preview-image-wrap {
    min-height: 240px !important;
  }

  .config-pillow-photo {
    height: 260px !important;
  }
}

/* Transport label cleanup + global scroll top */
body.woocommerce-cart .sleepmoon-cart-totals-table th,
body.woocommerce-cart .sleepmoon-cart-totals-table td {
  font-size: 17px !important;
  line-height: 1.45 !important;
}

body.woocommerce-cart .sleepmoon-cart-totals-table .shipping th,
body.woocommerce-cart .sleepmoon-cart-totals-table .shipping td,
body.woocommerce-cart .sleepmoon-cart-totals #shipping_method label,
body.woocommerce-cart .sleepmoon-cart-totals #shipping_method .amount {
  font-size: 17px !important;
  font-weight: 750 !important;
  color: #07162c !important;
}

body.woocommerce-checkout .sm-checkout-totals th,
body.woocommerce-checkout .sm-checkout-totals td,
body.woocommerce-checkout .sm-checkout-totals .sm-courier-shipping-row td,
body.woocommerce-checkout .sm-checkout-totals .sm-courier-shipping-row .amount {
  font-size: 18px !important;
  line-height: 1.45 !important;
}

body.woocommerce-checkout .sm-checkout-totals .sm-courier-shipping-row td,
body.woocommerce-checkout .sm-checkout-totals .sm-courier-shipping-row .amount {
  color: #07162c !important;
  font-weight: 750 !important;
}

.sleepmoon-scroll-top {
  position: fixed !important;
  right: 24px !important;
  bottom: 24px !important;
  z-index: 999 !important;
  width: 54px !important;
  height: 54px !important;
  border: 0 !important;
  border-radius: 50% !important;
  background: #0877e8 !important;
  color: #fff !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  font-size: 28px !important;
  line-height: 1 !important;
  font-weight: 900 !important;
  box-shadow: 0 18px 38px rgba(8, 119, 232, .26) !important;
  opacity: 0 !important;
  pointer-events: none !important;
  transform: translateY(14px) !important;
  transition: opacity .18s ease, transform .18s ease, background .18s ease !important;
}

.sleepmoon-scroll-top.is-visible {
  opacity: 1 !important;
  pointer-events: auto !important;
  transform: translateY(0) !important;
}

.sleepmoon-scroll-top:hover,
.sleepmoon-scroll-top:focus-visible {
  background: #0062c9 !important;
  outline: none !important;
}

body.side-cart-open .sleepmoon-scroll-top {
  display: none !important;
}

@media (max-width: 760px) {
  .sleepmoon-scroll-top {
    right: 16px !important;
    bottom: 82px !important;
    width: 50px !important;
    height: 50px !important;
    font-size: 25px !important;
  }

  body.woocommerce-cart .sleepmoon-cart-totals-table th,
  body.woocommerce-cart .sleepmoon-cart-totals-table td,
  body.woocommerce-checkout .sm-checkout-totals th,
  body.woocommerce-checkout .sm-checkout-totals td {
    font-size: 18px !important;
  }
}

/* Order received page */
body.woocommerce-checkout.woocommerce-order-received {
  background: #f5f7fb !important;
}

body.woocommerce-order-received .woocommerce {
  max-width: none !important;
}

.sleepmoon-thankyou-page {
  width: min(1180px, calc(100vw - 48px));
  margin: 48px auto 80px;
  color: #07162c;
}

.sleepmoon-thankyou-hero {
  position: relative;
  overflow: hidden;
  min-height: 340px;
  border-radius: 28px;
  padding: 54px;
  background:
    radial-gradient(circle at 86% 20%, rgba(255, 185, 75, .24), transparent 28%),
    linear-gradient(135deg, #0b3f73 0%, #0877e8 100%);
  color: #fff;
  box-shadow: 0 28px 70px rgba(8, 119, 232, .18);
}

.sleepmoon-thankyou-hero::after {
  content: "";
  position: absolute;
  right: 46px;
  bottom: -42px;
  width: 330px;
  height: 210px;
  border-radius: 42px;
  background: rgba(255, 255, 255, .12);
  transform: rotate(-8deg);
}

.sleepmoon-thankyou-check {
  width: 58px;
  height: 58px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  margin-bottom: 22px;
  background: #ffffff;
  color: #0877e8;
  font-size: 34px;
  font-weight: 900;
}

.sleepmoon-thankyou-kicker,
.sleepmoon-thankyou-section-label {
  display: block;
  color: #0877e8;
  font-size: 13px;
  font-weight: 900;
  letter-spacing: .08em;
  text-transform: uppercase;
}

.sleepmoon-thankyou-hero .sleepmoon-thankyou-kicker {
  color: rgba(255, 255, 255, .86);
}

.sleepmoon-thankyou-hero h1 {
  max-width: 700px;
  margin: 0 0 18px;
  color: #fff;
  font-size: clamp(42px, 6vw, 76px);
  line-height: .96;
  letter-spacing: 0;
}

.sleepmoon-thankyou-hero p {
  max-width: 620px;
  margin: 0 0 28px;
  color: rgba(255, 255, 255, .88);
  font-size: 19px;
  line-height: 1.55;
}

.sleepmoon-thankyou-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 14px;
}

.sleepmoon-thankyou-primary,
.sleepmoon-thankyou-secondary {
  min-height: 56px !important;
  padding: 0 28px !important;
  border-radius: 999px !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  font-size: 16px !important;
  font-weight: 900 !important;
  text-decoration: none !important;
}

.sleepmoon-thankyou-primary {
  border: 0 !important;
  background: #0877e8 !important;
  color: #fff !important;
  box-shadow: 0 18px 42px rgba(8, 119, 232, .22) !important;
}

.sleepmoon-thankyou-hero .sleepmoon-thankyou-primary {
  background: #ffba49 !important;
  color: #07162c !important;
  box-shadow: 0 18px 42px rgba(255, 186, 73, .24) !important;
}

.sleepmoon-thankyou-secondary {
  border: 1px solid rgba(255, 255, 255, .5) !important;
  background: rgba(255, 255, 255, .1) !important;
  color: #fff !important;
}

.sleepmoon-thankyou-grid {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 360px;
  gap: 28px;
  align-items: start;
  margin-top: 28px;
}

.sleepmoon-thankyou-main {
  display: grid;
  gap: 22px;
}

.sleepmoon-thankyou-card {
  border: 1px solid #dbe3ec;
  border-radius: 22px;
  background: #fff;
  box-shadow: 0 20px 60px rgba(7, 22, 44, .06);
}

.sleepmoon-thankyou-card-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 18px;
  padding: 26px 30px;
  border-bottom: 1px solid #e4e8ee;
}

.sleepmoon-thankyou-card-head span {
  color: #647184;
  font-size: 13px;
  font-weight: 900;
  letter-spacing: .08em;
  text-transform: uppercase;
}

.sleepmoon-thankyou-card-head strong {
  font-size: 28px;
}

.sleepmoon-thankyou-meta {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 1px;
  background: #e4e8ee;
  border-bottom: 1px solid #e4e8ee;
}

.sleepmoon-thankyou-meta div {
  padding: 22px 24px;
  background: #fbfcfe;
}

.sleepmoon-thankyou-meta span,
.sleepmoon-thankyou-total-card > span {
  display: block;
  margin-bottom: 8px;
  color: #647184;
  font-size: 12px;
  font-weight: 900;
  letter-spacing: .08em;
  text-transform: uppercase;
}

.sleepmoon-thankyou-meta strong {
  display: block;
  font-size: 15px;
  line-height: 1.35;
  word-break: break-word;
}

.sleepmoon-thankyou-products {
  display: grid;
}

.sleepmoon-thankyou-product {
  display: grid;
  grid-template-columns: 82px minmax(0, 1fr) auto;
  gap: 18px;
  align-items: center;
  padding: 22px 30px;
  border-bottom: 1px solid #e4e8ee;
}

.sleepmoon-thankyou-product:last-child {
  border-bottom: 0;
}

.sleepmoon-thankyou-product-img {
  position: relative;
  width: 74px;
  height: 74px;
}

.sleepmoon-thankyou-product-img img {
  width: 74px;
  height: 74px;
  object-fit: cover;
  border: 1px solid #dde5ee;
  border-radius: 14px;
  background: #fff;
  box-shadow: 0 10px 22px rgba(7, 22, 44, .08);
}

.sleepmoon-thankyou-product-img span {
  position: absolute;
  top: -9px;
  right: -9px;
  min-width: 26px;
  height: 26px;
  padding: 0 7px;
  border-radius: 999px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: #07162c;
  color: #fff;
  font-size: 13px;
  font-weight: 900;
}

.sleepmoon-thankyou-product-copy strong {
  display: block;
  font-size: 17px;
  line-height: 1.35;
}

.sleepmoon-thankyou-product-copy .wc-item-meta {
  margin: 8px 0 0;
  padding: 0;
  list-style: none;
  color: #647184;
  font-size: 13px;
}

.sleepmoon-thankyou-product-total {
  font-size: 17px;
  font-weight: 900;
  white-space: nowrap;
}

.sleepmoon-thankyou-address-card {
  display: grid;
  grid-template-columns: 1fr;
  gap: 18px;
  padding: 28px 30px;
}

.sleepmoon-thankyou-address-card address,
.sleepmoon-thankyou-address-card p {
  margin: 12px 0 0;
  color: #314159;
  font-style: normal;
  font-size: 16px;
  line-height: 1.65;
}

.sleepmoon-thankyou-sidebar {
  position: sticky;
  top: 24px;
}

.sleepmoon-thankyou-total-card {
  padding: 30px;
}

.sleepmoon-thankyou-total-card > strong {
  display: block;
  margin-bottom: 22px;
  font-size: 38px;
  line-height: 1;
}

.sleepmoon-thankyou-total-card dl {
  display: grid;
  gap: 0;
  margin: 0 0 24px;
  padding: 0;
  border-top: 1px solid #e4e8ee;
}

.sleepmoon-thankyou-total-card dl div {
  display: flex;
  justify-content: space-between;
  gap: 16px;
  padding: 16px 0;
  border-bottom: 1px solid #e4e8ee;
}

.sleepmoon-thankyou-total-card dt,
.sleepmoon-thankyou-total-card dd {
  margin: 0;
  font-size: 15px;
}

.sleepmoon-thankyou-total-card dt {
  color: #647184;
  font-weight: 800;
}

.sleepmoon-thankyou-total-card dd {
  text-align: right;
  color: #07162c;
  font-weight: 900;
}

.sleepmoon-thankyou-total-card .order_total dt,
.sleepmoon-thankyou-total-card .order_total dd {
  color: #07162c;
  font-size: 19px;
}

.sleepmoon-thankyou-payment-note {
  margin: 0 0 24px;
  padding: 16px 18px;
  border-radius: 14px;
  background: #f3f6fa;
  color: #536171;
  font-size: 15px;
  line-height: 1.55;
}

.sleepmoon-thankyou-payment-note p {
  margin: 0;
}

.sleepmoon-thankyou-total-card .sleepmoon-thankyou-primary {
  width: 100%;
}

.sleepmoon-thankyou-hero-empty,
.sleepmoon-thankyou-hero-failed {
  background: #fff;
  color: #07162c;
  border: 1px solid #dbe3ec;
  box-shadow: 0 20px 60px rgba(7, 22, 44, .06);
}

.sleepmoon-thankyou-hero-empty h1,
.sleepmoon-thankyou-hero-failed h1 {
  color: #07162c;
}

.sleepmoon-thankyou-hero-empty p,
.sleepmoon-thankyou-hero-failed p {
  color: #536171;
}

.sleepmoon-thankyou-hero-empty .sleepmoon-thankyou-secondary,
.sleepmoon-thankyou-hero-failed .sleepmoon-thankyou-secondary {
  border-color: #dbe3ec !important;
  background: #fff !important;
  color: #0877e8 !important;
}

body.woocommerce-order-received .woocommerce-order-details,
body.woocommerce-order-received .woocommerce-customer-details {
  display: none !important;
}

@media (max-width: 980px) {
  .sleepmoon-thankyou-page {
    width: min(100% - 32px, 760px);
    margin-top: 28px;
  }

  .sleepmoon-thankyou-hero {
    padding: 38px 28px;
    min-height: auto;
  }

  .sleepmoon-thankyou-hero::after {
    display: none;
  }

  .sleepmoon-thankyou-grid {
    grid-template-columns: 1fr;
  }

  .sleepmoon-thankyou-sidebar {
    position: static;
  }

  .sleepmoon-thankyou-meta {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 640px) {
  .sleepmoon-thankyou-page {
    width: calc(100% - 24px);
    margin-bottom: 48px;
  }

  .sleepmoon-thankyou-hero h1 {
    font-size: 38px;
  }

  .sleepmoon-thankyou-hero p {
    font-size: 16px;
  }

  .sleepmoon-thankyou-actions,
  .sleepmoon-thankyou-actions .button {
    width: 100%;
  }

  .sleepmoon-thankyou-meta {
    grid-template-columns: 1fr;
  }

  .sleepmoon-thankyou-product {
    grid-template-columns: 70px minmax(0, 1fr);
    gap: 14px;
    padding: 18px;
  }

  .sleepmoon-thankyou-product-total {
    grid-column: 2;
    font-size: 18px;
  }

  .sleepmoon-thankyou-card-head,
  .sleepmoon-thankyou-address-card,
  .sleepmoon-thankyou-total-card {
    padding: 22px;
  }

  .sleepmoon-thankyou-card-head {
    align-items: flex-start;
    flex-direction: column;
  }
}

/* ===========================================================
   v1.9.4 - Clean My Account
   =========================================================== */

body.woocommerce-account {
  background: #f7f9fc !important;
}

body.woocommerce-account #app > .container,
body.woocommerce-account .site-main,
body.woocommerce-account main .container {
  max-width: 1280px !important;
}

body.woocommerce-account .entry-title,
body.woocommerce-account h1.page-title {
  width: min(100% - 48px, 1180px) !important;
  margin: 42px auto 0 !important;
  color: #07162f !important;
  font-size: clamp(36px, 5vw, 64px) !important;
  line-height: 1 !important;
  letter-spacing: 0 !important;
}

body.woocommerce-account .woocommerce {
  display: block !important;
  width: 100% !important;
  margin: 0 !important;
  padding: 0 !important;
}

body.woocommerce-account .sleepmoon-account-wrap {
  width: min(100% - 48px, 1180px) !important;
  max-width: 1180px !important;
  margin: 32px auto 80px !important;
  padding: 0 !important;
  display: grid !important;
  grid-template-columns: 280px minmax(0, 1fr) !important;
  gap: 26px !important;
  align-items: start !important;
}

body.woocommerce-account .woocommerce-MyAccount-navigation,
body.woocommerce-account .woocommerce-MyAccount-content {
  float: none !important;
  width: 100% !important;
  min-width: 0 !important;
  box-sizing: border-box !important;
  background: #fff !important;
  border: 1px solid #dfe7f1 !important;
  border-radius: 22px !important;
  box-shadow: 0 18px 48px rgba(7, 22, 47, .07) !important;
}

body.woocommerce-account .woocommerce-MyAccount-navigation {
  position: sticky !important;
  top: 126px !important;
  padding: 18px !important;
  overflow: hidden !important;
}

.sm-account-nav-head {
  padding: 4px 4px 18px !important;
  margin-bottom: 12px !important;
  border-bottom: 1px solid #edf1f6 !important;
}

.sm-account-nav-head span {
  display: block !important;
  margin-bottom: 8px !important;
  color: #0877e8 !important;
  font-size: 12px !important;
  line-height: 1 !important;
  text-transform: uppercase !important;
  letter-spacing: 0 !important;
  font-weight: 900 !important;
}

.sm-account-nav-head strong,
.sm-account-nav-head small {
  display: block !important;
  max-width: 100% !important;
  overflow: hidden !important;
  text-overflow: ellipsis !important;
}

.sm-account-nav-head strong {
  color: #07162f !important;
  font-size: 17px !important;
  line-height: 1.25 !important;
}

.sm-account-nav-head small {
  margin-top: 4px !important;
  color: #69758a !important;
  font-size: 13px !important;
}

body.woocommerce-account .woocommerce-MyAccount-navigation ul {
  display: grid !important;
  gap: 6px !important;
  padding: 0 !important;
  margin: 0 !important;
  list-style: none !important;
}

body.woocommerce-account .woocommerce-MyAccount-navigation li {
  margin: 0 !important;
}

body.woocommerce-account .woocommerce-MyAccount-navigation a {
  position: relative !important;
  display: flex !important;
  align-items: center !important;
  min-height: 46px !important;
  padding: 12px 14px 12px 18px !important;
  border-radius: 14px !important;
  color: #14233c !important;
  font-size: 15px !important;
  font-weight: 800 !important;
  line-height: 1.25 !important;
  text-decoration: none !important;
  transition: background .18s ease, color .18s ease, transform .18s ease !important;
}

body.woocommerce-account .woocommerce-MyAccount-navigation a::before {
  content: '' !important;
  display: block !important;
  width: 6px !important;
  height: 6px !important;
  margin-right: 12px !important;
  border-radius: 999px !important;
  background: #c7d3e3 !important;
  flex: 0 0 auto !important;
}

body.woocommerce-account .woocommerce-MyAccount-navigation a:hover {
  background: #f2f7ff !important;
  color: #0877e8 !important;
}

body.woocommerce-account .woocommerce-MyAccount-navigation li.is-active a {
  background: linear-gradient(135deg, #0877e8, #159fe7) !important;
  color: #fff !important;
  box-shadow: 0 12px 28px rgba(8, 119, 232, .22) !important;
}

body.woocommerce-account .woocommerce-MyAccount-navigation li.is-active a::before {
  background: #fff !important;
}

body.woocommerce-account .woocommerce-MyAccount-content {
  grid-column: 2 !important;
  padding: 34px !important;
  color: #07162f !important;
  font-size: 16px !important;
  line-height: 1.65 !important;
}

.sm-account-dashboard {
  display: grid !important;
  gap: 22px !important;
}

.sm-account-welcome {
  display: grid !important;
  grid-template-columns: minmax(0, 1fr) auto !important;
  gap: 24px !important;
  align-items: center !important;
  padding: 30px !important;
  border-radius: 20px !important;
  background:
    radial-gradient(circle at 100% 0%, rgba(15, 145, 227, .14), transparent 36%),
    linear-gradient(135deg, #f8fbff, #fff) !important;
  border: 1px solid #dfeaf7 !important;
}

.sm-account-welcome-main {
  display: flex !important;
  align-items: center !important;
  gap: 18px !important;
}

.sm-account-avatar-clean {
  width: 72px !important;
  height: 72px !important;
  border-radius: 22px !important;
  background: linear-gradient(135deg, #0877e8, #07162f) !important;
  color: #fff !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  font-size: 28px !important;
  font-weight: 900 !important;
  flex: 0 0 auto !important;
}

.sm-account-eyebrow {
  display: block !important;
  color: #0877e8 !important;
  font-size: 12px !important;
  text-transform: uppercase !important;
  letter-spacing: 0 !important;
  font-weight: 900 !important;
  margin-bottom: 8px !important;
}

.sm-account-welcome h2 {
  margin: 0 0 8px !important;
  color: #07162f !important;
  font-size: clamp(26px, 3vw, 38px) !important;
  line-height: 1.05 !important;
}

.sm-account-welcome p {
  margin: 0 !important;
  color: #5f6d82 !important;
  max-width: 560px !important;
}

.sm-account-welcome-actions {
  display: flex !important;
  flex-direction: column !important;
  gap: 10px !important;
}

.sm-account-btn,
body.woocommerce-account .woocommerce-MyAccount-content .button,
body.woocommerce-account .woocommerce-MyAccount-content button.button {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  min-height: 46px !important;
  padding: 0 20px !important;
  border-radius: 999px !important;
  border: 1px solid #d8e2ee !important;
  background: #fff !important;
  color: #0877e8 !important;
  font-size: 14px !important;
  font-weight: 900 !important;
  text-decoration: none !important;
}

.sm-account-btn-primary,
body.woocommerce-account .woocommerce-MyAccount-content .button,
body.woocommerce-account .woocommerce-MyAccount-content button.button {
  border-color: #0877e8 !important;
  background: #0877e8 !important;
  color: #fff !important;
}

.sm-account-quick-grid {
  display: grid !important;
  grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
  gap: 16px !important;
}

.sm-account-quick-card {
  display: grid !important;
  gap: 8px !important;
  min-height: 170px !important;
  padding: 22px !important;
  border-radius: 18px !important;
  background: #fff !important;
  border: 1px solid #dfe7f1 !important;
  color: #07162f !important;
  text-decoration: none !important;
}

.sm-account-quick-card span {
  width: 42px !important;
  height: 42px !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  border-radius: 14px !important;
  background: #f2f7ff !important;
  font-size: 20px !important;
}

.sm-account-quick-card strong {
  font-size: 18px !important;
  line-height: 1.2 !important;
}

.sm-account-quick-card small {
  color: #65738a !important;
  font-size: 14px !important;
  line-height: 1.45 !important;
}

body.woocommerce-account .woocommerce-MyAccount-content p,
body.woocommerce-account .woocommerce-MyAccount-content address {
  color: #263754 !important;
  max-width: 760px !important;
}

body.woocommerce-account .woocommerce-MyAccount-content a {
  color: #0877e8 !important;
  font-weight: 800 !important;
}

body.woocommerce-account .woocommerce-MyAccount-content table {
  width: 100% !important;
  overflow: hidden !important;
  border: 1px solid #dfe7f1 !important;
  border-radius: 16px !important;
  background: #fff !important;
  border-collapse: separate !important;
  border-spacing: 0 !important;
}

body.woocommerce-account .woocommerce-MyAccount-content table th,
body.woocommerce-account .woocommerce-MyAccount-content table td {
  padding: 16px !important;
  border-bottom: 1px solid #edf1f6 !important;
}

body.woocommerce-account .woocommerce-MyAccount-content input.input-text,
body.woocommerce-account .woocommerce-MyAccount-content input[type="text"],
body.woocommerce-account .woocommerce-MyAccount-content input[type="email"],
body.woocommerce-account .woocommerce-MyAccount-content input[type="password"],
body.woocommerce-account .woocommerce-MyAccount-content select {
  min-height: 50px !important;
  border: 1px solid #cfd8e6 !important;
  border-radius: 12px !important;
  padding: 0 14px !important;
  background: #fff !important;
}

@media (max-width: 900px) {
  body.woocommerce-account .entry-title,
  body.woocommerce-account h1.page-title {
    width: calc(100% - 32px) !important;
    margin-top: 28px !important;
    font-size: 44px !important;
  }

  body.woocommerce-account .sleepmoon-account-wrap {
    width: calc(100% - 32px) !important;
    grid-template-columns: 1fr !important;
    margin-top: 24px !important;
    margin-bottom: 56px !important;
  }

  body.woocommerce-account .woocommerce-MyAccount-navigation {
    position: static !important;
  }

  body.woocommerce-account .woocommerce-MyAccount-content {
    grid-column: 1 !important;
    padding: 22px !important;
  }

  .sm-account-welcome {
    grid-template-columns: 1fr !important;
    padding: 22px !important;
  }

  .sm-account-welcome-main {
    align-items: flex-start !important;
  }

  .sm-account-welcome-actions {
    flex-direction: row !important;
    flex-wrap: wrap !important;
  }

  .sm-account-quick-grid {
    grid-template-columns: 1fr !important;
  }
}

/* ===========================================================
   v1.9.5 - My Account polish
   =========================================================== */
body.woocommerce-account .woocommerce-MyAccount-navigation li {
  margin: 0 !important;
}

body.woocommerce-account .woocommerce-MyAccount-navigation ul {
  display: grid !important;
  gap: 8px !important;
}

body.woocommerce-account .woocommerce-MyAccount-navigation li.woocommerce-MyAccount-navigation-link--customer-logout a {
  margin-top: 10px !important;
  color: #ef3f55 !important;
}

body.woocommerce-account .woocommerce-MyAccount-navigation li.woocommerce-MyAccount-navigation-link--customer-logout a::before {
  background: #ffd2da !important;
}

body.woocommerce-account .woocommerce-MyAccount-navigation li.woocommerce-MyAccount-navigation-link--customer-logout a:hover {
  background: #fff2f4 !important;
  color: #d72f45 !important;
}

.sm-account-card-icon {
  color: #0877e8 !important;
  font-size: 16px !important;
  font-weight: 950 !important;
  letter-spacing: 0 !important;
}

.sm-account-quick-card {
  position: relative !important;
  overflow: hidden !important;
}

.sm-account-quick-card::after {
  content: '>' !important;
  position: absolute !important;
  right: 22px !important;
  top: 22px !important;
  color: #9aa9bc !important;
  font-size: 18px !important;
  font-weight: 900 !important;
  transition: transform .18s ease, color .18s ease !important;
}

.sm-account-quick-card:hover {
  border-color: #b7d7f6 !important;
  box-shadow: 0 18px 40px rgba(8, 34, 72, .08) !important;
  transform: translateY(-2px) !important;
}

.sm-account-quick-card:hover::after {
  color: #0877e8 !important;
  transform: translateX(3px) !important;
}

body.woocommerce-account .sleepmoon-auth-wrap {
  width: min(100% - 48px, 1100px) !important;
  margin: 48px auto 72px !important;
  display: grid !important;
  grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  gap: 24px !important;
}

body.woocommerce-account .sleepmoon-auth-wrap.login-only {
  grid-template-columns: minmax(0, 560px) !important;
  justify-content: center !important;
}

body.woocommerce-account .sleepmoon-auth-panel {
  border: 1px solid #dfe7f1 !important;
  border-radius: 22px !important;
  background: #fff !important;
  box-shadow: 0 18px 48px rgba(8, 34, 72, .08) !important;
  padding: 30px !important;
}

body.woocommerce-account .sleepmoon-auth-head {
  align-items: flex-start !important;
  gap: 14px !important;
  margin-bottom: 24px !important;
}

body.woocommerce-account .sleepmoon-auth-step {
  width: 40px !important;
  height: 40px !important;
  border-radius: 14px !important;
  background: #0877e8 !important;
  color: #fff !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  font-weight: 950 !important;
}

body.woocommerce-account .sleepmoon-auth-head h2 {
  margin: 0 0 8px !important;
  color: #07162f !important;
  font-size: 30px !important;
  line-height: 1.1 !important;
}

body.woocommerce-account .sleepmoon-auth-head p,
body.woocommerce-account .sleepmoon-auth-note {
  color: #65738a !important;
  font-size: 15px !important;
  line-height: 1.55 !important;
}

body.woocommerce-account .sleepmoon-auth-panel label {
  color: #243653 !important;
  font-size: 14px !important;
  font-weight: 850 !important;
}

body.woocommerce-account .sleepmoon-auth-panel input.input-text,
body.woocommerce-account .sleepmoon-auth-panel input[type="email"],
body.woocommerce-account .sleepmoon-auth-panel input[type="password"],
body.woocommerce-account .sleepmoon-auth-panel input[type="text"] {
  width: 100% !important;
  min-height: 54px !important;
  border: 1px solid #cfd8e6 !important;
  border-radius: 14px !important;
  background: #f9fbfe !important;
  padding: 0 16px !important;
  font-size: 16px !important;
}

body.woocommerce-account .sleepmoon-auth-actions {
  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;
  gap: 14px !important;
}

@media (max-width: 900px) {
  body.woocommerce-account .sleepmoon-auth-wrap {
    width: calc(100% - 32px) !important;
    grid-template-columns: 1fr !important;
    margin-top: 28px !important;
  }
}

/* ===========================================================
   v1.9.6 - Account icons and active promo badge
   =========================================================== */
body.woocommerce-account .woocommerce-MyAccount-navigation a::before {
  content: none !important;
  display: none !important;
}

body.woocommerce-account .woocommerce-MyAccount-navigation a {
  gap: 12px !important;
  padding-left: 12px !important;
}

.sm-account-nav-icon {
  width: 34px !important;
  height: 34px !important;
  flex: 0 0 34px !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  border-radius: 12px !important;
  background: #eef5ff !important;
  color: #0877e8 !important;
  transition: background .18s ease, color .18s ease, transform .18s ease !important;
}

.sm-account-nav-icon svg {
  width: 19px !important;
  height: 19px !important;
  display: block !important;
  fill: none !important;
  stroke: currentColor !important;
  stroke-width: 2 !important;
  stroke-linecap: round !important;
  stroke-linejoin: round !important;
}

body.woocommerce-account .woocommerce-MyAccount-navigation a:hover .sm-account-nav-icon {
  background: #dff0ff !important;
  transform: translateY(-1px) !important;
}

body.woocommerce-account .woocommerce-MyAccount-navigation li.is-active .sm-account-nav-icon {
  background: rgba(255, 255, 255, .18) !important;
  color: #fff !important;
}

body.woocommerce-account .woocommerce-MyAccount-navigation li.woocommerce-MyAccount-navigation-link--customer-logout .sm-account-nav-icon {
  background: #fff2f4 !important;
  color: #ef3f55 !important;
}

body.woocommerce-account .woocommerce-MyAccount-navigation li.woocommerce-MyAccount-navigation-link--customer-logout a:hover .sm-account-nav-icon {
  background: #ffe3e8 !important;
  color: #d72f45 !important;
}

/* ===========================================================
   v1.9.14 - Account order actions and pay-order page polish
   =========================================================== */
.sm-account-welcome-actions .sm-account-btn-primary,
body.woocommerce-account .woocommerce-MyAccount-content .sm-account-welcome-actions .sm-account-btn-primary {
  color: #fff !important;
}

body.woocommerce-account .woocommerce-orders-table__cell-order-actions {
  display: flex !important;
  align-items: center !important;
  gap: 10px !important;
  flex-wrap: wrap !important;
}

body.woocommerce-account .woocommerce-orders-table__cell-order-actions .button {
  margin: 0 !important;
  min-width: 88px !important;
}

body.woocommerce-account .woocommerce-orders-table__cell-order-actions .woocommerce-button.cancel {
  background: #f8fbff !important;
  border-color: #d8e2ee !important;
  color: #0877e8 !important;
}

body.woocommerce-checkout.woocommerce-order-pay #app > .container {
  width: 100% !important;
  max-width: none !important;
  padding: 0 !important;
}

body.woocommerce-checkout.woocommerce-order-pay #app > .container > article,
body.woocommerce-checkout.woocommerce-order-pay #app > .container .page-content {
  width: 100% !important;
  max-width: none !important;
  margin: 0 !important;
}

body.woocommerce-checkout.woocommerce-order-pay #app > .container > article > h1:first-child {
  display: none !important;
}

.sleepmoon-pay-order-shell {
  max-width: 1120px !important;
  margin: 38px auto 72px !important;
  padding: 0 20px !important;
  color: #07162f !important;
}

.sleepmoon-pay-order-head {
  display: flex !important;
  align-items: flex-end !important;
  justify-content: space-between !important;
  gap: 18px !important;
  margin-bottom: 24px !important;
}

.sleepmoon-pay-order-head span {
  display: block !important;
  margin-bottom: 8px !important;
  color: #0877e8 !important;
  font-size: 13px !important;
  font-weight: 950 !important;
  text-transform: uppercase !important;
}

.sleepmoon-pay-order-head h1 {
  margin: 0 0 8px !important;
  color: #07162f !important;
  font-size: clamp(34px, 5vw, 58px) !important;
  line-height: .98 !important;
}

.sleepmoon-pay-order-head p {
  margin: 0 !important;
  color: #61708a !important;
  font-size: 17px !important;
}

.sleepmoon-pay-order-back {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  min-height: 48px !important;
  padding: 0 22px !important;
  border: 1px solid #d8e2ee !important;
  border-radius: 999px !important;
  background: #fff !important;
  color: #0877e8 !important;
  font-weight: 900 !important;
  text-decoration: none !important;
  white-space: nowrap !important;
}

.sleepmoon-pay-order-form {
  display: grid !important;
  grid-template-columns: minmax(0, 1fr) 380px !important;
  gap: 24px !important;
  align-items: start !important;
}

.sleepmoon-pay-order-card {
  border: 1px solid #dfe7f1 !important;
  border-radius: 20px !important;
  background: #fff !important;
  box-shadow: 0 22px 60px rgba(7, 22, 44, .07) !important;
  overflow: hidden !important;
}

.sleepmoon-pay-order-card h2 {
  margin: 0 !important;
  padding: 22px 24px !important;
  border-bottom: 1px solid #edf1f6 !important;
  color: #07162f !important;
  font-size: 24px !important;
  line-height: 1.15 !important;
}

.sleepmoon-pay-order-products {
  display: grid !important;
}

.sleepmoon-pay-order-product {
  display: grid !important;
  grid-template-columns: 74px minmax(0, 1fr) 66px 110px !important;
  gap: 16px !important;
  align-items: center !important;
  padding: 18px 24px !important;
  border-bottom: 1px solid #edf1f6 !important;
}

.sleepmoon-pay-order-product-img {
  width: 74px !important;
  height: 74px !important;
  border: 1px solid #e0e8f1 !important;
  border-radius: 14px !important;
  background: #fff !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  overflow: hidden !important;
}

.sleepmoon-pay-order-product-img img {
  width: 68px !important;
  height: 68px !important;
  object-fit: contain !important;
}

.sleepmoon-pay-order-product-copy strong {
  display: block !important;
  color: #07162f !important;
  font-size: 16px !important;
  line-height: 1.35 !important;
}

.sleepmoon-pay-order-product-copy .wc-item-meta,
.sleepmoon-pay-order-product-copy dl {
  margin: 8px 0 0 !important;
  color: #66758d !important;
  font-size: 13px !important;
}

.sleepmoon-pay-order-product-qty span {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  min-width: 46px !important;
  min-height: 34px !important;
  border: 1px solid #d8e2ee !important;
  border-radius: 999px !important;
  color: #07162f !important;
  font-weight: 900 !important;
}

.sleepmoon-pay-order-product-total {
  color: #07162f !important;
  font-size: 15px !important;
  font-weight: 900 !important;
  text-align: right !important;
}

.sleepmoon-pay-order-totals {
  width: 100% !important;
  border: 0 !important;
  margin: 0 !important;
  border-collapse: collapse !important;
}

.sleepmoon-pay-order-totals th,
.sleepmoon-pay-order-totals td {
  padding: 14px 24px !important;
  border-bottom: 1px solid #edf1f6 !important;
  color: #07162f !important;
  font-size: 15px !important;
}

.sleepmoon-pay-order-totals th {
  text-align: left !important;
  font-weight: 800 !important;
}

.sleepmoon-pay-order-totals td {
  text-align: right !important;
  font-weight: 900 !important;
}

.sleepmoon-pay-order-totals tr:last-child th,
.sleepmoon-pay-order-totals tr:last-child td,
.sleepmoon-pay-order-totals tr.order_total th,
.sleepmoon-pay-order-totals tr.order_total td {
  font-size: 22px !important;
  font-weight: 950 !important;
}

.sleepmoon-pay-order-payment {
  position: sticky !important;
  top: 24px !important;
}

.sleepmoon-pay-order-payment #payment {
  margin: 0 !important;
  padding: 0 !important;
  border: 0 !important;
  background: transparent !important;
}

.sleepmoon-pay-order-payment #payment ul.payment_methods {
  display: grid !important;
  gap: 12px !important;
  margin: 0 !important;
  padding: 20px 20px 0 !important;
  border: 0 !important;
}

.sleepmoon-pay-order-payment #payment li.wc_payment_method {
  margin: 0 !important;
  padding: 16px !important;
  border: 1px solid #d8e2ee !important;
  border-radius: 14px !important;
  background: #fff !important;
}

.sleepmoon-pay-order-payment #payment .payment_box {
  margin: 12px 0 0 !important;
  padding: 14px !important;
  border-radius: 12px !important;
  background: #f5f8fc !important;
  color: #263754 !important;
  font-size: 14px !important;
}

.sleepmoon-pay-order-payment #payment .form-row {
  margin: 0 !important;
  padding: 20px !important;
}

.sleepmoon-pay-order-submit,
.sleepmoon-pay-order-payment #place_order {
  width: 100% !important;
  min-height: 56px !important;
  border: 0 !important;
  border-radius: 999px !important;
  background: #0877e8 !important;
  color: #fff !important;
  font-size: 16px !important;
  font-weight: 950 !important;
  box-shadow: 0 16px 34px rgba(8, 119, 232, .22) !important;
}

.sleepmoon-pay-order-submit:hover,
.sleepmoon-pay-order-payment #place_order:hover {
  background: #0062c9 !important;
  color: #fff !important;
}

@media (max-width: 900px) {
  .sleepmoon-pay-order-head {
    align-items: flex-start !important;
    flex-direction: column !important;
  }

  .sleepmoon-pay-order-form {
    grid-template-columns: 1fr !important;
  }

  .sleepmoon-pay-order-payment {
    position: static !important;
  }

  .sleepmoon-pay-order-product {
    grid-template-columns: 68px minmax(0, 1fr) 54px !important;
  }

  .sleepmoon-pay-order-product-total {
    grid-column: 2 / -1 !important;
    text-align: left !important;
  }
}

@media (max-width: 640px) {
  .sleepmoon-pay-order-shell {
    margin-top: 24px !important;
    padding: 0 14px !important;
  }

  .sleepmoon-pay-order-card h2,
  .sleepmoon-pay-order-product,
  .sleepmoon-pay-order-totals th,
  .sleepmoon-pay-order-totals td {
    padding-left: 16px !important;
    padding-right: 16px !important;
  }
}

.sm-home-kicker,
.sm-home-hero .sm-home-kicker {
  display: inline-flex !important;
  align-items: center !important;
  gap: 9px !important;
  letter-spacing: 0 !important;
}

.sm-home-kicker-status {
  position: relative !important;
  width: 10px !important;
  height: 10px !important;
  border-radius: 999px !important;
  background: #2ee66b !important;
  box-shadow: 0 0 0 5px rgba(46, 230, 107, .14), 0 0 20px rgba(46, 230, 107, .95) !important;
  flex: 0 0 auto !important;
}

.sm-home-kicker-status::after {
  content: '' !important;
  position: absolute !important;
  inset: -7px !important;
  border-radius: inherit !important;
  border: 1px solid rgba(46, 230, 107, .55) !important;
  animation: smActiveGlow 1.7s ease-out infinite !important;
}

@keyframes smActiveGlow {
  0% {
    opacity: .9;
    transform: scale(.72);
  }
  100% {
    opacity: 0;
    transform: scale(1.7);
  }
}

/* ===========================================================
   v1.9.7 - Legal pages
   =========================================================== */
.sm-legal-page {
  background: #f7f9fc !important;
  padding: 56px 0 82px !important;
}

.sm-legal-container {
  width: min(100% - 48px, 1120px) !important;
}

.sm-legal-hero {
  margin-bottom: 28px !important;
  padding: 36px !important;
  border: 1px solid #dfe8f4 !important;
  border-radius: 24px !important;
  background:
    radial-gradient(circle at 100% 0%, rgba(8, 119, 232, .12), transparent 32%),
    #fff !important;
  box-shadow: 0 20px 54px rgba(7, 22, 47, .08) !important;
}

.sm-legal-hero span {
  display: inline-flex !important;
  min-height: 30px !important;
  padding: 0 12px !important;
  align-items: center !important;
  border-radius: 999px !important;
  background: #e9f4ff !important;
  color: #0877e8 !important;
  font-size: 12px !important;
  font-weight: 950 !important;
  text-transform: uppercase !important;
}

.sm-legal-hero h1 {
  margin: 16px 0 12px !important;
  color: #07162f !important;
  font-size: clamp(38px, 5vw, 64px) !important;
  line-height: 1 !important;
  letter-spacing: 0 !important;
}

.sm-legal-hero p {
  max-width: 720px !important;
  margin: 0 0 18px !important;
  color: #526178 !important;
  font-size: 18px !important;
  line-height: 1.6 !important;
}

.sm-legal-hero small {
  color: #718096 !important;
  font-size: 13px !important;
}

.sm-legal-grid {
  display: grid !important;
  grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  gap: 18px !important;
}

.sm-legal-card,
.sm-legal-anpc {
  border: 1px solid #dfe8f4 !important;
  border-radius: 20px !important;
  background: #fff !important;
  padding: 26px !important;
  box-shadow: 0 14px 34px rgba(7, 22, 47, .05) !important;
}

.sm-legal-card h2 {
  margin: 0 0 14px !important;
  color: #07162f !important;
  font-size: 22px !important;
  line-height: 1.2 !important;
}

.sm-legal-card ul {
  display: grid !important;
  gap: 10px !important;
  margin: 0 !important;
  padding: 0 !important;
  list-style: none !important;
}

.sm-legal-card li {
  position: relative !important;
  padding-left: 22px !important;
  color: #2a3a54 !important;
  font-size: 15.5px !important;
  line-height: 1.6 !important;
}

.sm-legal-card li::before {
  content: '' !important;
  position: absolute !important;
  left: 0 !important;
  top: .68em !important;
  width: 8px !important;
  height: 8px !important;
  border-radius: 999px !important;
  background: #0877e8 !important;
  box-shadow: 0 0 0 4px rgba(8, 119, 232, .1) !important;
}

.sm-legal-anpc {
  margin-top: 18px !important;
  background: #07162f !important;
  color: #fff !important;
}

.sm-legal-anpc strong {
  display: block !important;
  margin-bottom: 8px !important;
  font-size: 22px !important;
}

.sm-legal-anpc p {
  margin: 0 0 18px !important;
  color: rgba(255, 255, 255, .76) !important;
  line-height: 1.6 !important;
}

.sm-legal-anpc div {
  display: flex !important;
  flex-wrap: wrap !important;
  gap: 12px !important;
}

.sm-legal-anpc a {
  min-height: 44px !important;
  padding: 0 18px !important;
  border-radius: 999px !important;
  background: #0877e8 !important;
  color: #fff !important;
  display: inline-flex !important;
  align-items: center !important;
  text-decoration: none !important;
  font-weight: 900 !important;
}

.footer-legal-links {
  display: grid !important;
  gap: 7px !important;
  margin-top: 14px !important;
}

.sm-anpc-sal-badge {
  width: 250px !important;
  height: 50px !important;
  margin-top: 18px !important;
  padding: 0 !important;
  border: 0 !important;
  border-radius: 0 !important;
  background: transparent !important;
  color: inherit !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: flex-start !important;
  text-decoration: none !important;
  box-shadow: none !important;
}

.sm-anpc-sal-badge:hover {
  transform: translateY(-1px) !important;
}

.sm-anpc-sal-badge img {
  display: block !important;
  width: 250px !important;
  height: 50px !important;
  object-fit: contain !important;
}

.sm-legal-anpc .sm-anpc-sal-badge {
  margin-top: 16px !important;
}

/* v1.9.10 - Info pages and cookie consent */
.sm-info-page {
  background:
    radial-gradient(circle at 12% 0%, rgba(8, 119, 232, .08), transparent 34%),
    linear-gradient(180deg, #f5f8fc 0%, #fff 42%, #f8fbff 100%) !important;
  padding: 56px 0 78px !important;
}

.sm-info-container {
  max-width: 1160px !important;
}

.sm-info-hero {
  max-width: 820px !important;
  margin-bottom: 28px !important;
  padding: 34px !important;
  border: 1px solid #dbe6f2 !important;
  border-radius: 24px !important;
  background: rgba(255, 255, 255, .92) !important;
  box-shadow: 0 22px 54px rgba(13, 38, 76, .08) !important;
  overflow: hidden !important;
}

.sm-info-hero span {
  color: #0877e8 !important;
  display: inline-flex !important;
  margin-bottom: 10px !important;
  font-size: 13px !important;
  font-weight: 950 !important;
  letter-spacing: .08em !important;
  text-transform: uppercase !important;
}

.sm-info-hero h1 {
  margin: 0 0 14px !important;
  color: #07162d !important;
  font-size: clamp(42px, 6vw, 76px) !important;
  line-height: .98 !important;
  letter-spacing: 0 !important;
}

.sm-info-hero p {
  margin: 0 !important;
  color: #40516a !important;
  font-size: 20px !important;
  line-height: 1.55 !important;
}

.sm-info-grid {
  display: grid !important;
  grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  gap: 18px !important;
}

.sm-info-card {
  border: 1px solid #dbe6f2 !important;
  border-radius: 22px !important;
  background: rgba(255, 255, 255, .92) !important;
  padding: 28px !important;
  box-shadow: 0 22px 54px rgba(13, 38, 76, .08) !important;
}

.sm-info-wide,
.sm-info-content {
  grid-column: 1 / -1 !important;
}

.sm-info-icon {
  width: 44px !important;
  height: 44px !important;
  border-radius: 16px !important;
  background: #eaf5ff !important;
  color: #0877e8 !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  margin-bottom: 16px !important;
  font-size: 13px !important;
  font-weight: 950 !important;
  letter-spacing: .04em !important;
}

.sm-info-card h2 {
  margin: 0 0 12px !important;
  color: #07162d !important;
  font-size: 24px !important;
  line-height: 1.15 !important;
}

.sm-info-card p,
.sm-info-card li {
  color: #40516a !important;
  font-size: 16px !important;
  line-height: 1.65 !important;
}

.sm-info-card p {
  margin: 0 0 10px !important;
}

.sm-info-card a {
  color: #0877e8 !important;
  font-weight: 850 !important;
}

.sm-info-card a.sm-info-button {
  color: #fff !important;
}

.sm-info-button {
  min-height: 48px !important;
  padding: 0 22px !important;
  border-radius: 999px !important;
  background: #0877e8 !important;
  color: #fff !important;
  display: inline-flex !important;
  align-items: center !important;
  text-decoration: none !important;
  box-shadow: 0 18px 38px rgba(8, 119, 232, .22) !important;
}

.sm-info-button:hover {
  color: #fff !important;
  transform: translateY(-1px) !important;
}

.sm-info-about .sm-info-icon,
.sm-info-contact .sm-info-card:nth-child(2) .sm-info-icon {
  display: none !important;
}

.sm-info-content {
  margin-top: 18px !important;
}

.sm-cookie-consent {
  position: fixed !important;
  left: 50% !important;
  bottom: 22px !important;
  width: min(960px, calc(100% - 32px)) !important;
  z-index: 99998 !important;
  border: 1px solid rgba(7, 22, 45, .12) !important;
  border-radius: 22px !important;
  background: rgba(255, 255, 255, .96) !important;
  color: #07162d !important;
  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;
  gap: 20px !important;
  padding: 18px !important;
  box-shadow: 0 26px 80px rgba(7, 22, 45, .2) !important;
  opacity: 0 !important;
  transform: translate(-50%, 18px) !important;
  transition: opacity .22s ease, transform .22s ease !important;
}

.sm-cookie-consent[hidden] {
  display: none !important;
}

.sm-cookie-consent.is-visible {
  opacity: 1 !important;
  transform: translate(-50%, 0) !important;
}

.sm-cookie-copy strong {
  display: block !important;
  margin-bottom: 5px !important;
  font-size: 18px !important;
  font-weight: 950 !important;
}

.sm-cookie-copy p {
  max-width: 620px !important;
  margin: 0 !important;
  color: #4b5b72 !important;
  font-size: 14px !important;
  line-height: 1.5 !important;
}

.sm-cookie-actions {
  display: flex !important;
  align-items: center !important;
  gap: 10px !important;
  flex: 0 0 auto !important;
}

.sm-cookie-actions a,
.sm-cookie-actions button {
  min-height: 42px !important;
  padding: 0 16px !important;
  border-radius: 999px !important;
  font-size: 14px !important;
  font-weight: 900 !important;
  text-decoration: none !important;
  cursor: pointer !important;
}

.sm-cookie-actions a,
.sm-cookie-secondary {
  border: 1px solid #d8e3ef !important;
  background: #fff !important;
  color: #0877e8 !important;
}

.sm-cookie-primary {
  border: 1px solid #0877e8 !important;
  background: #0877e8 !important;
  color: #fff !important;
}

@media (max-width: 800px) {
  .sm-legal-page {
    padding: 34px 0 58px !important;
  }

  .sm-legal-container {
    width: calc(100% - 32px) !important;
  }

  .sm-legal-hero {
    padding: 24px !important;
  }

  .sm-legal-grid {
    grid-template-columns: 1fr !important;
  }

  .sm-anpc-sal-badge {
    width: min(250px, 100%) !important;
  }

  .sm-info-page {
    padding: 34px 0 56px !important;
  }

  .sm-info-container {
    width: calc(100% - 32px) !important;
  }

  .sm-info-hero h1 {
    font-size: clamp(38px, 13vw, 58px) !important;
  }

  .sm-info-hero p {
    font-size: 17px !important;
  }

  .sm-info-grid {
    grid-template-columns: 1fr !important;
  }

  .sm-cookie-consent {
    align-items: stretch !important;
    flex-direction: column !important;
    padding: 16px !important;
  }

  .sm-cookie-actions {
    flex-wrap: wrap !important;
  }

  .sm-cookie-actions a,
  .sm-cookie-actions button {
    flex: 1 1 auto !important;
    justify-content: center !important;
  }
}

/* ===========================================================
   v1.9.14 final overrides - account actions and pay order
   =========================================================== */
body.woocommerce-account .woocommerce-orders-table__cell-order-actions {
  display: flex !important;
  align-items: center !important;
  justify-content: flex-start !important;
  gap: 12px !important;
  flex-wrap: wrap !important;
}

body.woocommerce-account .woocommerce-orders-table__cell-order-actions .button,
body.woocommerce-account .woocommerce-orders-table__cell-order-actions a.button {
  min-width: 92px !important;
  min-height: 46px !important;
  margin: 0 !important;
  padding: 0 18px !important;
  border-radius: 999px !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  line-height: 1 !important;
  white-space: nowrap !important;
}

body.woocommerce-account .sm-account-welcome-actions .sm-account-btn-primary {
  min-width: 204px !important;
  color: #fff !important;
  font-size: 15px !important;
  opacity: 1 !important;
  visibility: visible !important;
}

body.woocommerce-account .sm-account-welcome-actions .sm-account-btn-primary:hover,
body.woocommerce-account .sm-account-welcome-actions .sm-account-btn-primary:focus {
  color: #fff !important;
}

body.woocommerce-checkout.woocommerce-order-pay .sleepmoon-pay-order-payment #place_order,
body.woocommerce-checkout.woocommerce-order-pay .sleepmoon-pay-order-submit {
  background: #0877e8 !important;
  color: #fff !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  text-align: center !important;
  line-height: 1.1 !important;
}

@media (max-width: 640px) {
  body.woocommerce-account .woocommerce-orders-table__cell-order-actions {
    gap: 10px !important;
  }

  body.woocommerce-account .woocommerce-orders-table__cell-order-actions .button,
  body.woocommerce-account .woocommerce-orders-table__cell-order-actions a.button {
    flex: 1 1 120px !important;
  }
}

/* ===========================================================
   v1.9.15 - isolate WooCommerce order-pay from checkout sidebar CSS
   =========================================================== */
body.woocommerce-checkout.woocommerce-order-pay form#order_review.sleepmoon-pay-order-form,
form#order_review.sleepmoon-pay-order-form {
  width: 100% !important;
  max-width: none !important;
  min-width: 0 !important;
  height: auto !important;
  margin: 0 !important;
  padding: 0 !important;
  border: 0 !important;
  border-radius: 0 !important;
  background: transparent !important;
  box-shadow: none !important;
  position: static !important;
  top: auto !important;
  flex: none !important;
  display: grid !important;
  grid-template-columns: minmax(0, 1fr) 410px !important;
  gap: 28px !important;
  align-items: start !important;
}

body.woocommerce-checkout.woocommerce-order-pay .sleepmoon-pay-order-shell {
  width: min(100% - 48px, 1180px) !important;
  max-width: 1180px !important;
  margin: 46px auto 82px !important;
  padding: 0 !important;
}

body.woocommerce-checkout.woocommerce-order-pay .sleepmoon-pay-order-head {
  width: 100% !important;
  margin-bottom: 28px !important;
}

body.woocommerce-checkout.woocommerce-order-pay .sleepmoon-pay-order-card {
  width: 100% !important;
  max-width: none !important;
  min-width: 0 !important;
  box-sizing: border-box !important;
}

body.woocommerce-checkout.woocommerce-order-pay .sleepmoon-pay-order-payment {
  position: sticky !important;
  top: 110px !important;
}

body.woocommerce-checkout.woocommerce-order-pay .sleepmoon-pay-order-payment #payment {
  margin: 0 !important;
  padding: 0 !important;
  border: 0 !important;
  background: transparent !important;
}

body.woocommerce-checkout.woocommerce-order-pay .sleepmoon-pay-order-payment #payment ul.payment_methods {
  margin: 0 !important;
  padding: 20px !important;
  border: 0 !important;
  display: grid !important;
  gap: 12px !important;
}

body.woocommerce-checkout.woocommerce-order-pay .sleepmoon-pay-order-payment #payment li.wc_payment_method {
  margin: 0 !important;
  padding: 16px !important;
  border: 1px solid #d8e2ee !important;
  border-radius: 14px !important;
  background: #fff !important;
}

body.woocommerce-checkout.woocommerce-order-pay .sleepmoon-pay-order-payment #payment .form-row {
  margin: 0 !important;
  padding: 0 20px 20px !important;
}

body.woocommerce-checkout.woocommerce-order-pay .sleepmoon-pay-order-payment #payment .payment_box {
  width: auto !important;
  margin: 12px 0 0 !important;
}

body.woocommerce-checkout.woocommerce-order-pay .sleepmoon-pay-order-product-copy strong,
body.woocommerce-checkout.woocommerce-order-pay .sleepmoon-pay-order-product-total,
body.woocommerce-checkout.woocommerce-order-pay .sleepmoon-pay-order-totals th,
body.woocommerce-checkout.woocommerce-order-pay .sleepmoon-pay-order-totals td {
  font-size: 16px !important;
}

@media (max-width: 980px) {
  body.woocommerce-checkout.woocommerce-order-pay form#order_review.sleepmoon-pay-order-form,
  form#order_review.sleepmoon-pay-order-form {
    grid-template-columns: 1fr !important;
  }

  body.woocommerce-checkout.woocommerce-order-pay .sleepmoon-pay-order-payment {
    position: static !important;
  }
}

@media (max-width: 640px) {
  body.woocommerce-checkout.woocommerce-order-pay .sleepmoon-pay-order-shell {
    width: calc(100% - 28px) !important;
    margin-top: 28px !important;
  }
}

/* ===========================================================
   v1.9.16 - polished order-pay fallback and homepage action
   =========================================================== */
body.woocommerce-checkout.woocommerce-order-pay .sleepmoon-pay-order-actions {
  display: flex !important;
  align-items: center !important;
  justify-content: flex-end !important;
  gap: 12px !important;
  flex-wrap: wrap !important;
}

body.woocommerce-checkout.woocommerce-order-pay .sleepmoon-pay-order-home,
body.woocommerce-checkout.woocommerce-order-pay .sleepmoon-orderpay-home {
  min-height: 48px !important;
  padding: 0 22px !important;
  border-radius: 999px !important;
  border: 1px solid #ffbd4a !important;
  background: #ffbd4a !important;
  color: #07162f !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  font-size: 15px !important;
  font-weight: 900 !important;
  line-height: 1 !important;
  text-decoration: none !important;
  box-shadow: 0 16px 32px rgba(255, 189, 74, 0.26) !important;
}

body.woocommerce-checkout.woocommerce-order-pay .sleepmoon-pay-order-back,
body.woocommerce-checkout.woocommerce-order-pay .sleepmoon-orderpay-shop {
  min-height: 48px !important;
  padding: 0 22px !important;
  border-radius: 999px !important;
  border: 1px solid #d8e3ef !important;
  background: #fff !important;
  color: #0877e8 !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  font-size: 15px !important;
  font-weight: 900 !important;
  line-height: 1 !important;
  text-decoration: none !important;
}

body.woocommerce-checkout.woocommerce-order-pay .sleepmoon-orderpay-fallback {
  width: min(100% - 48px, 1120px) !important;
  max-width: 1120px !important;
  margin: 42px auto 82px !important;
  color: #07162f !important;
  font-family: inherit !important;
}

body.woocommerce-checkout.woocommerce-order-pay .sleepmoon-orderpay-fallback-head {
  margin-bottom: 26px !important;
  padding: 28px !important;
  border: 1px solid #d8e3ef !important;
  border-radius: 26px !important;
  background:
    radial-gradient(circle at 100% 0%, rgba(8, 119, 232, 0.12), transparent 42%),
    linear-gradient(135deg, #f8fbff 0%, #ffffff 100%) !important;
  box-shadow: 0 24px 52px rgba(7, 22, 47, 0.08) !important;
  display: flex !important;
  align-items: flex-end !important;
  justify-content: space-between !important;
  gap: 22px !important;
}

body.woocommerce-checkout.woocommerce-order-pay .sleepmoon-orderpay-fallback-title span {
  margin-bottom: 8px !important;
  color: #0877e8 !important;
  display: block !important;
  font-size: 13px !important;
  font-weight: 950 !important;
  letter-spacing: 0 !important;
  text-transform: uppercase !important;
}

body.woocommerce-checkout.woocommerce-order-pay .sleepmoon-orderpay-fallback-title h1 {
  margin: 0 !important;
  color: #07162f !important;
  font-size: clamp(38px, 5vw, 64px) !important;
  font-weight: 950 !important;
  line-height: 0.96 !important;
  letter-spacing: 0 !important;
}

body.woocommerce-checkout.woocommerce-order-pay .sleepmoon-orderpay-fallback-title p {
  margin: 12px 0 0 !important;
  color: #52647c !important;
  font-size: 17px !important;
  line-height: 1.55 !important;
}

body.woocommerce-checkout.woocommerce-order-pay .sleepmoon-orderpay-fallback-actions {
  display: flex !important;
  align-items: center !important;
  justify-content: flex-end !important;
  gap: 12px !important;
  flex-wrap: wrap !important;
  flex: 0 0 auto !important;
}

body.woocommerce-checkout.woocommerce-order-pay .sleepmoon-orderpay-fallback form#order_review {
  width: 100% !important;
  max-width: none !important;
  min-width: 0 !important;
  margin: 0 !important;
  padding: 0 !important;
  border: 0 !important;
  border-radius: 0 !important;
  background: transparent !important;
  box-shadow: none !important;
  position: static !important;
  top: auto !important;
  display: grid !important;
  grid-template-columns: minmax(0, 1fr) 380px !important;
  gap: 24px !important;
  align-items: start !important;
}

body.woocommerce-checkout.woocommerce-order-pay .sleepmoon-orderpay-fallback form#order_review::before,
body.woocommerce-checkout.woocommerce-order-pay .sleepmoon-orderpay-fallback form#order_review::after {
  content: none !important;
}

body.woocommerce-checkout.woocommerce-order-pay .sleepmoon-orderpay-fallback table.shop_table {
  width: 100% !important;
  margin: 0 !important;
  border: 1px solid #d8e3ef !important;
  border-radius: 22px !important;
  border-collapse: separate !important;
  border-spacing: 0 !important;
  overflow: hidden !important;
  background: #fff !important;
  box-shadow: 0 18px 44px rgba(7, 22, 47, 0.06) !important;
}

body.woocommerce-checkout.woocommerce-order-pay .sleepmoon-orderpay-fallback table.shop_table th,
body.woocommerce-checkout.woocommerce-order-pay .sleepmoon-orderpay-fallback table.shop_table td {
  padding: 18px 22px !important;
  border: 0 !important;
  border-bottom: 1px solid #e5edf6 !important;
  color: #07162f !important;
  font-size: 17px !important;
  line-height: 1.35 !important;
  vertical-align: middle !important;
}

body.woocommerce-checkout.woocommerce-order-pay .sleepmoon-orderpay-fallback table.shop_table thead th {
  background: #f7f9fc !important;
  color: #52647c !important;
  font-size: 13px !important;
  font-weight: 950 !important;
  text-transform: uppercase !important;
}

body.woocommerce-checkout.woocommerce-order-pay .sleepmoon-orderpay-fallback table.shop_table td.product-name {
  font-weight: 850 !important;
}

body.woocommerce-checkout.woocommerce-order-pay .sleepmoon-orderpay-fallback table.shop_table tfoot th,
body.woocommerce-checkout.woocommerce-order-pay .sleepmoon-orderpay-fallback table.shop_table tfoot td {
  font-size: 18px !important;
  font-weight: 900 !important;
}

body.woocommerce-checkout.woocommerce-order-pay .sleepmoon-orderpay-fallback table.shop_table tfoot tr:last-child th,
body.woocommerce-checkout.woocommerce-order-pay .sleepmoon-orderpay-fallback table.shop_table tfoot tr:last-child td {
  border-bottom: 0 !important;
  background: #f8fbff !important;
  font-size: 22px !important;
}

body.woocommerce-checkout.woocommerce-order-pay .sleepmoon-orderpay-fallback table.shop_table tfoot tr.shipping td small,
body.woocommerce-checkout.woocommerce-order-pay .sleepmoon-orderpay-fallback table.shop_table tfoot tr.shipping td .woocommerce-shipping-destination,
body.woocommerce-checkout.woocommerce-order-pay .sleepmoon-orderpay-fallback table.shop_table tfoot tr.shipping td .woocommerce-shipping-calculator {
  display: none !important;
}

body.woocommerce-checkout.woocommerce-order-pay .sleepmoon-orderpay-fallback #payment {
  margin: 0 !important;
  padding: 22px !important;
  border: 1px solid #d8e3ef !important;
  border-radius: 22px !important;
  background: #fff !important;
  box-shadow: 0 18px 44px rgba(7, 22, 47, 0.06) !important;
  position: sticky !important;
  top: 112px !important;
}

body.woocommerce-checkout.woocommerce-order-pay .sleepmoon-orderpay-fallback #payment::before {
  content: "Alege metoda de plata" !important;
  margin: 0 0 16px !important;
  display: block !important;
  color: #07162f !important;
  font-size: 24px !important;
  font-weight: 950 !important;
  line-height: 1.15 !important;
}

body.woocommerce-checkout.woocommerce-order-pay .sleepmoon-orderpay-fallback #payment ul.payment_methods {
  margin: 0 !important;
  padding: 0 !important;
  border: 0 !important;
  display: grid !important;
  gap: 12px !important;
}

body.woocommerce-checkout.woocommerce-order-pay .sleepmoon-orderpay-fallback #payment li.wc_payment_method {
  margin: 0 !important;
  padding: 16px !important;
  border: 1px solid #d8e3ef !important;
  border-radius: 16px !important;
  background: #f9fbfe !important;
  list-style: none !important;
}

body.woocommerce-checkout.woocommerce-order-pay .sleepmoon-orderpay-fallback #payment li.wc_payment_method > label {
  color: #07162f !important;
  font-size: 16px !important;
  font-weight: 850 !important;
}

body.woocommerce-checkout.woocommerce-order-pay .sleepmoon-orderpay-fallback #payment .payment_box {
  width: auto !important;
  margin: 12px 0 0 !important;
  padding: 14px 16px !important;
  border-radius: 14px !important;
  background: #eef5ff !important;
  color: #314259 !important;
  font-size: 14px !important;
  line-height: 1.5 !important;
}

body.woocommerce-checkout.woocommerce-order-pay .sleepmoon-orderpay-fallback #payment .payment_box::before {
  border-bottom-color: #eef5ff !important;
}

body.woocommerce-checkout.woocommerce-order-pay .sleepmoon-orderpay-fallback #payment .form-row {
  margin: 0 !important;
  padding: 18px 0 0 !important;
}

body.woocommerce-checkout.woocommerce-order-pay .sleepmoon-orderpay-fallback #payment .woocommerce-terms-and-conditions-wrapper {
  color: #52647c !important;
  font-size: 14px !important;
  line-height: 1.55 !important;
}

body.woocommerce-checkout.woocommerce-order-pay .sleepmoon-orderpay-fallback #place_order {
  width: 100% !important;
  min-height: 56px !important;
  margin: 16px 0 0 !important;
  padding: 0 22px !important;
  border: 0 !important;
  border-radius: 999px !important;
  background: #0877e8 !important;
  color: #fff !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  font-size: 16px !important;
  font-weight: 950 !important;
  line-height: 1 !important;
  text-align: center !important;
  box-shadow: 0 18px 34px rgba(8, 119, 232, 0.24) !important;
}

body.woocommerce-checkout.woocommerce-order-pay .sleepmoon-orderpay-fallback #place_order:hover,
body.woocommerce-checkout.woocommerce-order-pay .sleepmoon-orderpay-fallback #place_order:focus {
  background: #0066d8 !important;
  color: #fff !important;
}

body.woocommerce-checkout.woocommerce-order-pay .sleepmoon-orderpay-fallback + .woocommerce,
body.woocommerce-checkout.woocommerce-order-pay .entry-title {
  display: none !important;
}

@media (max-width: 980px) {
  body.woocommerce-checkout.woocommerce-order-pay .sleepmoon-orderpay-fallback {
    width: calc(100% - 32px) !important;
    margin-top: 28px !important;
  }

  body.woocommerce-checkout.woocommerce-order-pay .sleepmoon-orderpay-fallback-head {
    align-items: flex-start !important;
    flex-direction: column !important;
  }

  body.woocommerce-checkout.woocommerce-order-pay .sleepmoon-orderpay-fallback-actions {
    width: 100% !important;
    justify-content: flex-start !important;
  }

  body.woocommerce-checkout.woocommerce-order-pay .sleepmoon-orderpay-fallback form#order_review {
    grid-template-columns: 1fr !important;
  }

  body.woocommerce-checkout.woocommerce-order-pay .sleepmoon-orderpay-fallback #payment {
    position: static !important;
  }
}

@media (max-width: 640px) {
  body.woocommerce-checkout.woocommerce-order-pay .sleepmoon-pay-order-actions,
  body.woocommerce-checkout.woocommerce-order-pay .sleepmoon-orderpay-fallback-actions {
    align-items: stretch !important;
    flex-direction: column !important;
  }

  body.woocommerce-checkout.woocommerce-order-pay .sleepmoon-pay-order-home,
  body.woocommerce-checkout.woocommerce-order-pay .sleepmoon-pay-order-back,
  body.woocommerce-checkout.woocommerce-order-pay .sleepmoon-orderpay-home,
  body.woocommerce-checkout.woocommerce-order-pay .sleepmoon-orderpay-shop {
    width: 100% !important;
  }

  body.woocommerce-checkout.woocommerce-order-pay .sleepmoon-orderpay-fallback-head {
    padding: 22px !important;
    border-radius: 20px !important;
  }

  body.woocommerce-checkout.woocommerce-order-pay .sleepmoon-orderpay-fallback table.shop_table th,
  body.woocommerce-checkout.woocommerce-order-pay .sleepmoon-orderpay-fallback table.shop_table td {
    padding: 14px !important;
    font-size: 15px !important;
  }

  body.woocommerce-checkout.woocommerce-order-pay .sleepmoon-orderpay-fallback table.shop_table tfoot tr:last-child th,
  body.woocommerce-checkout.woocommerce-order-pay .sleepmoon-orderpay-fallback table.shop_table tfoot tr:last-child td {
    font-size: 19px !important;
  }
}

/* v1.9.17 - archive filters and order-pay polish */
body.woocommerce-checkout.woocommerce-order-pay,
body.woocommerce-checkout.woocommerce-order-pay #page,
body.woocommerce-checkout.woocommerce-order-pay #app,
body.woocommerce-checkout.woocommerce-order-pay .site,
body.woocommerce-checkout.woocommerce-order-pay main,
body.woocommerce-checkout.woocommerce-order-pay .container,
body.woocommerce-checkout.woocommerce-order-pay article,
body.woocommerce-checkout.woocommerce-order-pay .entry-content {
  background: #f7f9fc !important;
}

body.woocommerce-checkout.woocommerce-order-pay .sleepmoon-pay-order-payment #payment .woocommerce-terms-and-conditions-wrapper,
body.woocommerce-checkout.woocommerce-order-pay .sleepmoon-orderpay-fallback #payment .woocommerce-terms-and-conditions-wrapper {
  margin-bottom: 20px !important;
}

body.woocommerce-checkout.woocommerce-order-pay .sleepmoon-pay-order-payment #place_order,
body.woocommerce-checkout.woocommerce-order-pay .sleepmoon-pay-order-submit,
body.woocommerce-checkout.woocommerce-order-pay .sleepmoon-orderpay-fallback #place_order {
  margin-top: 24px !important;
}

.sleepmoon-subcat-filter .acc-body {
  display: grid !important;
  gap: 10px !important;
}

.sleepmoon-subcat-filter .filter-option {
  align-items: center !important;
  min-height: 38px !important;
}

@media (max-width: 768px) {
  body.woocommerce .mobile-filter-bar,
  body.post-type-archive-product .mobile-filter-bar,
  body.tax-product_cat .mobile-filter-bar {
    display: grid !important;
    grid-template-columns: minmax(0, 1fr) !important;
    gap: 0 !important;
    margin-top: 22px !important;
    margin-bottom: 28px !important;
  }

  body.woocommerce .mobile-filter-bar button,
  body.post-type-archive-product .mobile-filter-bar button,
  body.tax-product_cat .mobile-filter-bar button {
    width: 100% !important;
    min-height: 58px !important;
  }
}
