/* Global Padding Fix */
.content_wrapper .section_wrapper,
.container,
.four.columns .widget-area {
	padding-left: 2px !important;
	padding-right: 2px !important;
}

/* Subheader & Breadcrumbs */
#Subheader ul.breadcrumbs {
	text-align: left;
	width: 100%;
	margin-top: 10px;
}

#Subheader ul.breadcrumbs li {
	display: inline-block !important;
}

#Subheader ul.breadcrumbs.has-link .mfn-breadcrumbs-separator {
	display: inline-flex !important;
	align-items: center;
	justify-content: center;
	width: 14px;
	min-width: 14px;
	margin: 0 8px;
	color: rgba(0, 0, 0, .45);
	font-size: 13px;
	font-weight: 500;
	line-height: 1;
	vertical-align: middle;
}

#Subheader ul.breadcrumbs.has-link .mfn-breadcrumbs-separator i {
	display: none !important;
}

#Subheader ul.breadcrumbs.has-link .mfn-breadcrumbs-separator::before {
	content: "|";
	display: block;
}

#Content {
	padding-top: 0px !important;
}

/* Mobile Styles */
@media only screen and (max-width: 767px) {
	#Subheader {
		padding: 10px !important;
		display: inline !important;
	}

	#Subheader ul.breadcrumbs {
		display: block !important;
		/* li display block is commented out intentionally */
	}

	.content_wrapper .mcb-column-inner {
		margin: 0 1px 1px !important;
	}

	body.mobile-row-2-products .products_wrapper ul.products li.product {
		width: 49%;
	}
}

/* Remove Related Posts */
/*
.jp-relatedposts {
	display: none;
}
*/

/* Scrollable Submenu */
.mfn-header-menu .mfn-menu-li .mfn-submenu {
	max-height: 420px;
	overflow-x: auto;
}


/* WooCommerce Breadcrumbs & Product Section Adjustments */
@media screen and (max-width: 768px) {
	.woocommerce .column_product_breadcrumbs {
		display: none;
	}

	.mcb-section-4a3xn1pe {
		padding-top: 0px !important;
	}

	.mcb-section .mcb-wrap-ifjk51bg .mcb-wrap-inner-ifjk51bg {
		margin-bottom: 0px !important;
	}


}

/* Product gallery interactions are handled by single-product/single-product.css. */
.woocommerce div.product div.images .woocommerce-product-gallery__trigger,
.woocommerce div.product div.images .mfn-wish-button,
.woocommerce .mfn-product-gallery-grid .woocommerce-product-gallery__trigger,
.woocommerce .mfn-product-gallery-grid .mfn-wish-button {
	display: none;
}

/* Hide Checkout Order Header */
#order_review_heading {
	display: none;
}

/* Typography and Links */
title,
a {
	color: black !important;
}



.woocommerce ul.products li.product a,
.woocommerce-page ul.products li.product a {
	color: black !important;
}


.woocommerce ul.products li.product {
	text-align: left !important;
}

/* Theme-wide Black Color Override */
.themecolor,
.opening_hours .opening_hours_wrapper li span,
.fancy_heading_icon .icon_top,
.fancy_heading_arrows .icon-right-dir,
.fancy_heading_arrows .icon-left-dir,
.fancy_heading_line .title,
.button-love a.mfn-love,
.format-link .post-title .icon-link,
.pager-single > span,
.pager-single a:hover,
.widget_meta ul,
.widget_pages ul,
.widget_rss ul,
.widget_mfn_recent_comments ul li:after,
.widget_archive ul,
.widget_recent_comments ul li:after,
.widget_nav_menu ul,
.woocommerce ul.products li.product .price,
.shop_slider .shop_slider_ul li .item_wrapper .price,
.woocommerce-page ul.products li.product .price,
.widget_price_filter .price_label .from,
.widget_price_filter .price_label .to,
.woocommerce ul.product_list_widget li .quantity .amount,
.woocommerce .product div.entry-summary .price,
.woocommerce .product .woocommerce-variation-price .price,
.woocommerce .star-rating span,
#Error_404 .error_pic i,
.style-simple #Filters .filters_wrapper ul li a:hover,
.style-simple #Filters .filters_wrapper ul li.current-cat a,
.style-simple .quick_fact .title,
.mfn-cart-holder .mfn-ch-content .mfn-ch-product .woocommerce-Price-amount,
.woocommerce .comment-form-rating p.stars a:before,
.wishlist .wishlist-row .price,
.search-results .search-item .post-product-price,
.progress_icons.transparent .progress_icon.themebg {
	color: black;
}

/* Buttons */
.button {
	border-radius: 10px;
}


/* Truncate Product Titles */
.woocommerce ul.products li.product .title a {
	color: inherit;
	overflow: hidden;
	display: -webkit-box;
	-webkit-line-clamp: 2;
	-webkit-box-orient: vertical;
	white-space: normal;
	text-overflow: ellipsis;
	width: 90% !important;
	
}

/* Section Padding */
section.mcb-section-qrjot3gfd {
	padding-left: 0% !important;
	padding-right: 0% !important;
}

/* Hide Order Details on Thank You Page */
.woocommerce .woocommerce-customer-details,
.woocommerce .woocommerce-order-details .order-again {
	display: none !important;
}

/* Center Extra Info Title */
.ts-extra-info .ts-extra-heading {
	text-align: center;
}

/* Order Details Padding */
.woocommerce .woocommerce-order-details {
	padding: 15px 1px 0px 1px !important;
}









/* === Fix BeRocket brand pages to match WooCommerce category styles === */

.br_brand_archive .woocommerce ul.products li.product .woocommerce-loop-product__title,
.br_brand_archive .woocommerce ul.products li.product .price {
    font-family: 'myFraunces' !important;
    font-size: 18px !important;
    line-height: 28px;
    font-weight: 700;
    color: #000000;
    letter-spacing: 0;
    text-align: left;
    -webkit-font-smoothing: antialiased;
    margin-bottom: 3px;
}

.br_brand_archive .woocommerce ul.products li.product .price {
    font-weight: 400;
    margin: 0 0 7px;
}

/*  Hide added to basket button  */

.single-product .added_to_cart {
  display: none !important;
}




#Subheader .title {
	font-size: 25px !important;
	line-height: 20px !important;
	letter-spacing: -1px !important;
}

.shop-filters {
    margin-bottom: 7px !important;
    padding: 0px 1% !important;
}











/* Product gallery and PDP quantity are handled by single-product/single-product.css. */







/* Optional: hide SKU if needed */
.sku_wrapper {
  display: none !important;
}










@media only screen and (max-width: 767px) {
    body.mobile-row-2-products .products_wrapper ul.products li.product {
        width: 49.7% !important;
    }
}



.mfn_after_shop_content_wrapper {
	  margin: 10px 6px 20px 6px !important;
}


.subheader-both-center #Subheader .title {
    font-weight: 500 !important;

}



/* Shop landing page – product-card titles only 
body.post-type-archive-product          
  ul.products li.product h1.mfn-woo-product-title {
    font-size: 13px !important;
		line-height: 17px !important;
		
}*/









/* 0) Keep Woo's native button functional but invisible (AJAX stays intact) */
.woocommerce ul.products li.product .mfn-li-product-row-button .button,
.woocommerce-page ul.products li.product .mfn-li-product-row-button .button {
  position: absolute !important;
  width: 1px !important;
  height: 1px !important;
  padding: 0 !important;
  margin: -1px !important;
  overflow: hidden !important;
  clip: rect(0 0 0 0) !important;
  white-space: nowrap !important;
  border: 0 !important;
}

/* 1) Make each product card align perfectly (price row pinned to bottom) */
.woocommerce ul.products li.product {
  display: flex !important;
  flex-direction: column !important;
  height: 100% !important;
}
.woocommerce ul.products li.product > * { width: 100%; }

/* Titles clamped to 2 lines so rows align across the grid */
.woocommerce ul.products li.product .mfn-li-product-row-title h1.title,
.woocommerce ul.products li.product .woocommerce-loop-product__title,
.woocommerce ul.products li.product .mfn-woo-product-title {
  line-height: 1.3 !important;
  display: -webkit-box !important;
  -webkit-box-orient: vertical !important;
  -webkit-line-clamp: 2 !important;
  overflow: hidden !important;
  min-height: calc(1.3em * 2) !important;
  margin: 6px 0 !important;
}

/* 2) Price row: price left, icon fully right with soft inner padding */
.mfn-li-product-row-price {
  margin-top: auto !important;
  display: flex !important;
  align-items: center !important;
  justify-content: flex-start !important;
  column-gap: 0 !important;
  padding-right: 10px !important; /* distance from next card */
}
.mfn-li-product-row-price .price {
  display: inline-flex !important;
  align-items: center !important;
  margin: 0 !important;
  padding-right: 0 !important;
  line-height: 1.1 !important;
  flex: 1 1 auto !important;
  min-width: 0 !important; /* guards against overflow in tight grids */
}

.woocommerce ul.products li.product .mfn-li-product-row-price .price,
.woocommerce ul.products li.product .mfn-li-product-row-price .price *,
.woocommerce-page ul.products li.product .mfn-li-product-row-price .price,
.woocommerce-page ul.products li.product .mfn-li-product-row-price .price *{
  color: #000 !important;
}

.woocommerce ul.products li.product .mfn-li-product-row-price .price del,
.woocommerce-page ul.products li.product .mfn-li-product-row-price .price del{
  opacity: .48 !important;
}

.woocommerce ul.products li.product .mfn-li-product-row-price .price ins,
.woocommerce-page ul.products li.product .mfn-li-product-row-price .price ins{
  color: #000 !important;
  background: transparent !important;
  text-decoration: none !important;
}

/* 3) Landscape cart chip (radius 10px) aligned with price row */
.mfn-li-product-row-price .mfn-add-to-cart-icon,
.mfn-add-to-cart-icon {
  display: inline-block;
  box-sizing: border-box;
  width: 56px !important;              /* landscape */
  height: 25px !important;
  flex: 0 0 40px !important;
  margin-left: auto !important;
  margin-right: 0 !important;

  /* glyph is drawn with ::before so it does not depend on staging media URLs */
  background-image: none !important;

  /* chip styling */
  background-color: rgba(0,0,0,0.05) !important;
  border-radius: 10px !important;
  box-shadow:
    inset 0 0 0 1px rgba(0,0,0,0.07),
    0 1px 2px rgba(0,0,0,0.05) !important;

  position: relative;
  overflow: visible;
  cursor: pointer;
  touch-action: manipulation;
  -webkit-tap-highlight-color: transparent;
  transition: transform .16s ease, background-color .16s ease, box-shadow .16s ease;
}

.mfn-add-to-cart-icon::before {
  content: "";
  position: absolute;
  inset: 0;
  display: block;
  width: 20px;
  height: 20px;
  margin: auto;
  background: currentColor;
  -webkit-mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath d='M7 18a2 2 0 1 0 0 4 2 2 0 0 0 0-4Zm10 0a2 2 0 1 0 0 4 2 2 0 0 0 0-4ZM6.2 6l1.1 7.5h8.9l1-5.5H8.1L7.7 6H5V4h4.2l.4 2H20l-1.6 9.5H6.1L4.8 6H3V4h3.2Z'/%3E%3C/svg%3E") center / contain no-repeat;
  mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath d='M7 18a2 2 0 1 0 0 4 2 2 0 0 0 0-4Zm10 0a2 2 0 1 0 0 4 2 2 0 0 0 0-4ZM6.2 6l1.1 7.5h8.9l1-5.5H8.1L7.7 6H5V4h4.2l.4 2H20l-1.6 9.5H6.1L4.8 6H3V4h3.2Z'/%3E%3C/svg%3E") center / contain no-repeat;
}

/* Hover / focus */
@media (hover:hover) {
  .mfn-add-to-cart-icon:hover {
    background-color: rgba(0,0,0,0.07) !important;
    transform: translateY(-1px) scale(1.02);
    box-shadow:
      inset 0 0 0 1px rgba(0,0,0,0.09),
      0 2px 6px rgba(0,0,0,0.07) !important;
    outline: none;
  }
}
.mfn-add-to-cart-icon:focus-visible {
  outline: 2px solid #000;
  outline-offset: 2px;
}

/* 4) Kill theme loader / legacy spinner */
.woocommerce ul.products li.product .product-loading-icon { display: none !important; }
.mfn-add-to-cart-icon.is-loading::after { content: none !important; }

/* 5) Loading: hide glyph; show inner spinner centered inside the chip */
.mfn-add-to-cart-icon.is-loading {
  pointer-events: none;
  background-image: none !important;
  opacity: 1;
}
.mfn-add-to-cart-icon.is-loading::before {
  content: "";
  position: absolute;
  inset: 0;
  margin: auto;
  width: 22px;  /* balanced inside 32px height */
  height: 22px;
  background: transparent !important;
  -webkit-mask: none !important;
  mask: none !important;
  box-sizing: border-box;
  border: 3px solid rgba(0,0,0,.22);
  border-top-color: #000;
  border-radius: 50%;
  animation: jc-spin .7s linear infinite;
  z-index: 1;
}

/* 6) Success micro-pulse (JS toggles .is-added) */
.mfn-add-to-cart-icon.is-added { animation: jc-pulse .28s ease; }

/* 7) Motion preferences */
@media (prefers-reduced-motion: reduce) {
  .mfn-add-to-cart-icon.is-loading::before { animation: none; }
}

/* Keyframes */
@keyframes jc-spin { to { transform: rotate(360deg); } }
@keyframes jc-pulse { 0%{transform:scale(1)} 50%{transform:scale(1.05)} 100%{transform:scale(1)} }

/* Optional: match product thumbnail softness */
.woocommerce ul.products li.product .product-loop-thumb { border-radius: 12px; }

/* Existing mobile rule kept intact */
@media only screen and (max-width: 767px) {
  body.mobile-row-2-products .products_wrapper ul.products li.product:nth-child(2n+1) { clear: both; }
}























/* ================================
   Just Cosmetics — Hero Carousel CSS
   Clean, premium, bulletproof.
   ================================ */

/* Wrapper + 5px space after carousel (for dots row below) */
.jc-hero-carousel{
  width:100%;
  position:relative;
  margin-bottom:5px !important; /* requested gap after carousel */
}

/* Viewport (clips slides) */
.jc-hero-viewport{
  position:relative;
  overflow:hidden;
  width:100%;
  border-radius:18px; /* remove if you want square */
  background:#fff;
}

/* Track (single row) */
.jc-hero-track{
  display:flex !important;
  flex-wrap:nowrap !important;
  width:100% !important;
  transform:translateX(0);
  transition:transform .45s ease;
  will-change:transform;
  backface-visibility:hidden;
  -webkit-transform:translateX(0);
}

/* Each slide = full viewport width */
.jc-hero-slide{
  position:relative;
  flex:0 0 100% !important;
  width:100% !important;

  /* Locks height to 920x1260 so overlays stay aligned on all devices */
  aspect-ratio: 920 / 1260;

  overflow:hidden;
  background:#fff;
}

/* Media wrapper fills the slide */
.jc-hero-media{
  position:absolute;
  inset:0;
  width:100%;
  height:100%;
  display:block;
}

/* Make image fill the slide area without distortion */
.jc-hero-slide img{
  position:absolute;
  inset:0;
  width:100% !important;
  height:100% !important;
  object-fit:contain;      /* full banner visible (no crop) */
  object-position:center;  /* center it */
  display:block;
}

/* ================================
   Button (premium pill, white text)
   Ratio-locked position: stays aligned on all screens
   ================================ */
.jc-hero-btn{
  position:absolute;
  left:40px;
  top:79.5%;
  transform:translateY(-50%);
  z-index:5;

  width:135px;
  height:38px;

  background:#201a16 !important;
  color:#fff !important;
  -webkit-text-fill-color:#fff !important;
  text-decoration:none !important;

  border-radius:999px;
  border:1px solid rgba(255,255,255,.10);

  display:inline-flex;
  align-items:center;
  justify-content:center;

  font-weight:800;
  font-size:13px;
  letter-spacing:.10em;
  text-transform:uppercase;

  line-height:1;
  padding:0 18px;

  box-shadow:
    0 10px 22px rgba(0,0,0,.18),
    0 2px 0 rgba(255,255,255,.05) inset;

  transition:opacity .18s ease, transform .18s ease, box-shadow .18s ease;
  -webkit-tap-highlight-color:transparent;
}

/* Keep white text even if theme overrides */
.jc-hero-btn,
.jc-hero-btn *{
  color:#fff !important;
  -webkit-text-fill-color:#fff !important;
}

/* Hover / active */
.jc-hero-btn:hover{
  opacity:.92;
  transform:translateY(-50%) translateY(-1px);
  box-shadow:
    0 14px 26px rgba(0,0,0,.22),
    0 2px 0 rgba(255,255,255,.05) inset;
}
.jc-hero-btn:active{
  transform:translateY(-50%) scale(.98);
  opacity:.95;
}

/* ================================
   Dots (small, perfectly centered, outside image)
   ================================ */
.jc-hero-dots{
  position:relative !important;        /* BELOW the viewport */
  left:auto !important;
  right:auto !important;
  bottom:auto !important;

  display:flex !important;
  justify-content:center !important;
  align-items:center !important;       /* fixes any vertical mis-centering */
  gap:7px !important;

  margin-top:5px !important;           /* dots spacing below carousel */
  padding:0 !important;

  pointer-events:auto !important;
}

.jc-hero-dots button{
  width:6px !important;
  height:6px !important;
  padding:0 !important;

  border:0 !important;
  border-radius:999px !important;

  background:#000 !important;
  opacity:.22 !important;

  display:block !important;
  cursor:pointer !important;

  box-shadow:none !important;          /* remove theme shadows */
  outline:none !important;
  transform:translateZ(0) !important;
  transition:opacity .18s ease, transform .18s ease, box-shadow .18s ease;
}

/* Active dot ring: centered (no offset) */
.jc-hero-dots button.active{
  opacity:1 !important;
  transform:scale(1.05) translateZ(0) !important;
  box-shadow:0 0 0 3px rgba(0,0,0,.10) !important;
}

.jc-hero-dots button:hover{
  opacity:.55 !important;
}

/* ================================
   Mobile refinement
   ================================ */
@media (max-width: 420px){
  .jc-hero-viewport{ border-radius:16px; }

  .jc-hero-btn{
    left:34px;
    width:130px;
    height:38px;     /* keep consistent height */
    font-size:13px;
  }

  .jc-hero-dots{
    margin-top:5px !important;
    gap:7px !important;
  }
}

/* ================================
   Motion accessibility
   ================================ */
@media (prefers-reduced-motion: reduce){
  .jc-hero-track{ transition:none; }
  .jc-hero-btn{ transition:none; }
  .jc-hero-dots button{ transition:none; }
}









































@media (max-width: 991px) {

	/* Hide the original language row inside the mobile slide menu */
	.mfn-header-tmpl-menu-sidebar .menu-item-language-switcher {
		display: none !important;
	}

	/* New mobile header language icon */
	.jc-mobile-lang-icon {
		display: inline-flex;
		align-items: center;
		justify-content: center;
		margin-left: 12px;
		text-decoration: none;
		line-height: 1;
		vertical-align: middle;
	}

	.jc-mobile-lang-icon img {
		display: block;
		width: 20px;
		height: 20px;
		object-fit: cover;
		border-radius: 50%;
	}

	/* Keep search icon + language icon nicely aligned */
	.mcb-header-section.hide-desktop.hide-laptop .mcb-item-5zrxjgpk .mcb-column-inner {
		display: flex;
		align-items: center;
		justify-content: flex-end;
		gap: 12px;
	}

	.mcb-header-section.hide-desktop.hide-laptop .mfn-header-search-link {
		margin: 0;
	}
}

.subheader-both-center #Subheader .breadcrumbs{
  padding-top: 9px !important;
  margin: 0 !important;
}
