
/* ============================================
   BLACK SHOP - Custom Design CSS
   ============================================ */

:root {
  --gold:  #C9A84C;
  --dark:  #1A1A1A;
  --white: #FFFFFF;
  --light: #F7F5F0;
  --grey:  #888888;
}

/* BODY */
body {
  font-family: 'Raleway', 'Helvetica Neue', Arial, sans-serif !important;
  background: var(--light) !important;
  color: #2C2C2C !important;
}

/* HEADER */
#header, .ct-header, header {
  background: #FFFFFF !important;
  border-bottom: 1px solid rgba(201,168,76,0.25) !important;
  box-shadow: 0 2px 12px rgba(0,0,0,0.06) !important;
}

/* LOGO */
.site-title, .site-title a, a.brand,
.ct-header a.brand, .header-branding .site-title,
.ct-header .logo-container {
  font-family: 'Playfair Display', Georgia, serif !important;
  font-size: 26px !important;
  font-weight: 700 !important;
  letter-spacing: 5px !important;
  text-transform: uppercase !important;
  color: var(--gold) !important;
  text-decoration: none !important;
}

/* NAVIGATION */
#menu-main-menu > li > a,
.ct-menu li > a,
.header-menu-1 .menu > li > a,
ul.menu > li > a {
  color: #2C2C2C !important;
  font-size: 12px !important;
  font-weight: 700 !important;
  letter-spacing: 2.5px !important;
  text-transform: uppercase !important;
  padding: 8px 14px !important;
  transition: color 0.25s !important;
  text-decoration: none !important;
}
#menu-main-menu > li > a:hover,
.ct-menu li > a:hover,
.header-menu-1 .menu > li > a:hover,
ul.menu > li > a:hover {
  color: var(--gold) !important;
}

/* PRODUITS */
.woocommerce ul.products li.product {
  background: var(--white) !important;
  box-shadow: 0 2px 8px rgba(0,0,0,0.06) !important;
  transition: box-shadow 0.3s, transform 0.3s !important;
  overflow: hidden !important;
  border: none !important;
}
.woocommerce ul.products li.product:hover {
  box-shadow: 0 8px 24px rgba(0,0,0,0.12) !important;
  transform: translateY(-4px) !important;
}
.woocommerce ul.products li.product img { margin: 0 !important; }
.woocommerce ul.products li.product .woocommerce-loop-product__title {
  font-size: 12px !important;
  font-weight: 700 !important;
  letter-spacing: 2px !important;
  text-transform: uppercase !important;
  color: var(--dark) !important;
  padding: 16px 16px 4px !important;
}
.woocommerce ul.products li.product .price {
  color: var(--gold) !important;
  font-size: 15px !important;
  font-weight: 700 !important;
  padding: 0 16px 12px !important;
}

/* BOUTONS */
.woocommerce a.button,
.woocommerce button.button,
.woocommerce input[type=submit] {
  background: var(--dark) !important;
  color: var(--white) !important;
  border: none !important;
  border-radius: 0 !important;
  font-size: 11px !important;
  font-weight: 700 !important;
  letter-spacing: 2.5px !important;
  text-transform: uppercase !important;
  padding: 13px 28px !important;
  transition: background 0.3s !important;
}
.woocommerce a.button:hover,
.woocommerce button.button:hover,
.woocommerce input[type=submit]:hover {
  background: var(--gold) !important;
  color: var(--white) !important;
}
.single_add_to_cart_button {
  background: var(--gold) !important;
  border-radius: 0 !important;
  letter-spacing: 3px !important;
  padding: 16px 44px !important;
}
.single_add_to_cart_button:hover {
  background: var(--dark) !important;
}

/* BADGE PROMO */
.woocommerce span.onsale {
  background: var(--gold) !important;
  color: var(--white) !important;
  border-radius: 0 !important;
  font-size: 10px !important;
  font-weight: 700 !important;
  letter-spacing: 1px !important;
  padding: 5px 10px !important;
}

/* TITRES */
h1, h2, h3, h4 {
  font-family: 'Playfair Display', Georgia, serif !important;
  color: var(--dark) !important;
}
.woocommerce-products-header__title,
.page-title, .entry-title {
  font-family: 'Playfair Display', Georgia, serif !important;
  font-size: 32px !important;
  letter-spacing: 3px !important;
  text-transform: uppercase !important;
  color: var(--dark) !important;
}

/* FIL D'ARIANE */
.woocommerce-breadcrumb,
.woocommerce-breadcrumb a {
  color: var(--grey) !important;
  font-size: 11px !important;
  letter-spacing: 1px !important;
  text-transform: uppercase !important;
}
.woocommerce-breadcrumb a:hover { color: var(--gold) !important; }

/* FOOTER */
#footer, footer#footer, .ct-footer, .site-footer {
  background: var(--dark) !important;
  color: #AAAAAA !important;
}
.ct-footer .ct-container,
.footer-widgets .ct-container {
  padding-top: 60px !important;
  padding-bottom: 40px !important;
}
.ct-footer .widget-title,
.ct-footer .widgettitle,
.footer-widgets .widget-title,
#footer .widget-title {
  color: var(--white) !important;
  font-family: 'Raleway', sans-serif !important;
  font-size: 11px !important;
  font-weight: 700 !important;
  letter-spacing: 3px !important;
  text-transform: uppercase !important;
  margin-bottom: 20px !important;
  padding-bottom: 12px !important;
  border-bottom: 1px solid rgba(201,168,76,0.35) !important;
}
.ct-footer a, #footer a, .footer-widgets a {
  color: #999999 !important;
  font-size: 13px !important;
  text-decoration: none !important;
  line-height: 2.2 !important;
  transition: color 0.2s !important;
}
.ct-footer a:hover, #footer a:hover, .footer-widgets a:hover {
  color: var(--gold) !important;
}
.ct-copyright, .footer-bottom, .site-info {
  background: #111111 !important;
  color: #555555 !important;
  font-size: 11px !important;
  letter-spacing: 1px !important;
  text-transform: uppercase !important;
  padding: 16px 0 !important;
  border-top: 1px solid rgba(255,255,255,0.05) !important;
}

/* SIDEBAR CACHEE */
.widget-area, .woocommerce-sidebar, #secondary {
  display: none !important;
}

/* FORMULAIRES */
.woocommerce input[type=text],
.woocommerce input[type=email],
.woocommerce input[type=tel],
.woocommerce input[type=password],
.woocommerce textarea,
.woocommerce select {
  border-radius: 0 !important;
  border: 1px solid #DDDDDD !important;
  padding: 10px 14px !important;
}
.woocommerce input[type=text]:focus,
.woocommerce input[type=email]:focus {
  border-color: var(--gold) !important;
  box-shadow: 0 0 0 2px rgba(201,168,76,0.15) !important;
  outline: none !important;
}

/* MESSAGES */
.woocommerce-message, .woocommerce-info {
  border-top-color: var(--gold) !important;
  background: var(--white) !important;
}
.woocommerce-message::before, .woocommerce-info::before {
  color: var(--gold) !important;
}

/* SCROLLBAR */
::-webkit-scrollbar { width: 6px; }
::-webkit-scrollbar-track { background: var(--light); }
::-webkit-scrollbar-thumb { background: var(--gold); border-radius: 3px; }


/* ── HOME PAGE ── */

/* ── HERO ── */
.bs-hero {
  position: relative;
  width: 100%;
  height: 90vh;
  min-height: 500px;
  background: #1a1a1a url('/wp-content/uploads/2026/05/hero-bg.jpg') center/cover no-repeat;
  display: flex;
  align-items: center;
  justify-content: center;
  overflow: hidden;
}
.bs-hero__overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(135deg, rgba(0,0,0,0.55) 0%, rgba(0,0,0,0.3) 100%);
}
.bs-hero__content {
  position: relative;
  z-index: 2;
  text-align: center;
  padding: 0 20px;
}
.bs-hero__sub {
  color: #C9A84C;
  font-family: 'Raleway', sans-serif;
  font-size: 13px;
  font-weight: 700;
  letter-spacing: 4px;
  text-transform: uppercase;
  margin-bottom: 20px;
}
.bs-hero__title {
  color: #ffffff;
  font-family: 'Playfair Display', Georgia, serif;
  font-size: clamp(36px, 6vw, 72px);
  font-weight: 700;
  line-height: 1.15;
  letter-spacing: 2px;
  text-transform: uppercase;
  margin-bottom: 40px;
}
.bs-hero__btn {
  display: inline-block;
  background: transparent;
  color: #ffffff;
  border: 2px solid #C9A84C;
  padding: 16px 48px;
  font-family: 'Raleway', sans-serif;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 4px;
  text-transform: uppercase;
  text-decoration: none;
  transition: background 0.3s, color 0.3s;
}
.bs-hero__btn:hover {
  background: #C9A84C;
  color: #ffffff;
  text-decoration: none;
}

/* ── GRILLE CATÉGORIES ── */
.bs-cats { padding: 0; margin: 0; background: #1a1a1a; }
.bs-cats__grid {
  display: grid;
  grid-template-columns: 1fr 1fr 1fr;
  height: 480px;
  gap: 2px;
}
.bs-cat {
  position: relative;
  overflow: hidden;
  display: block;
  text-decoration: none;
  cursor: pointer;
}
.bs-cat--large { grid-column: span 1; }
.bs-cat--split {
  display: grid;
  grid-template-rows: 1fr 1fr;
  gap: 2px;
}
.bs-cat--half { display: block; }
.bs-cat__img {
  position: absolute;
  inset: 0;
  background-size: cover;
  background-position: center;
  transition: transform 0.5s ease;
  filter: brightness(0.75);
}
.bs-cat:hover .bs-cat__img {
  transform: scale(1.06);
  filter: brightness(0.6);
}
.bs-cat__overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(to top, rgba(0,0,0,0.65) 0%, transparent 60%);
}
.bs-cat__label {
  position: absolute;
  top: 16px;
  left: 16px;
  color: #C9A84C;
  font-family: 'Raleway', sans-serif;
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 3px;
  text-transform: uppercase;
  z-index: 2;
}
.bs-cat__name {
  position: absolute;
  bottom: 20px;
  left: 20px;
  color: #ffffff;
  font-family: 'Playfair Display', Georgia, serif;
  font-size: 22px;
  font-weight: 700;
  letter-spacing: 2px;
  text-transform: uppercase;
  z-index: 2;
}

/* ── NOUVEAUTÉS ── */
.bs-featured {
  background: #F7F5F0;
  padding: 80px 40px;
}
.bs-section-header { text-align: center; margin-bottom: 50px; }
.bs-section-title {
  font-family: 'Playfair Display', Georgia, serif;
  font-size: 36px;
  font-weight: 700;
  color: #1A1A1A;
  letter-spacing: 3px;
  text-transform: uppercase;
  margin-bottom: 10px;
}
.bs-section-sub {
  color: #888;
  font-size: 13px;
  letter-spacing: 2px;
  text-transform: uppercase;
}

/* ── BANNIÈRE INFO ── */
.bs-banner {
  background: #1A1A1A;
  padding: 20px 40px;
}
.bs-banner__text {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 20px;
  color: #aaaaaa;
  font-family: 'Raleway', sans-serif;
  font-size: 12px;
  font-weight: 600;
  letter-spacing: 2px;
  text-transform: uppercase;
  flex-wrap: wrap;
}
.bs-sep { color: #C9A84C; font-size: 20px; }

@media (max-width: 768px) {
  .bs-cats__grid { grid-template-columns: 1fr; height: auto; }
  .bs-cats__grid > * { height: 240px; }
  .bs-cat--split { grid-template-rows: 1fr 1fr; height: 480px; }
}


/* ── LOGO ── */

/* ── LOGO SVG Black Shop ── */
.custom-logo-link,
.site-logo a,
a.brand {
  display: inline-flex !important;
  align-items: center !important;
}

.custom-logo,
.site-logo img,
a.brand img {
  height: 60px !important;
  width: auto !important;
  max-width: 200px !important;
  object-fit: contain !important;
}

/* Masquer le texte "Black Shop" si le logo image est chargé */
.custom-logo-link ~ .site-title,
.has-custom-logo .site-title {
  display: none !important;
}


/* ── HERO LOGO ── */

/* ── Logo dans le hero ── */
.bs-hero__logo {
  display: block;
  margin: 0 auto 28px auto;
  height: 80px;
  width: auto;
  max-width: 320px;
  filter: drop-shadow(0 2px 12px rgba(201,168,76,0.45));
  animation: fadeDown 0.9s ease both;
}

@keyframes fadeDown {
  from { opacity: 0; transform: translateY(-18px); }
  to   { opacity: 1; transform: translateY(0); }
}

/* Décaler légèrement le sous-titre quand logo présent */
.bs-hero__logo + .bs-hero__sub {
  margin-top: 0;
  animation: fadeDown 0.9s ease 0.15s both;
}
.bs-hero__title {
  animation: fadeDown 0.9s ease 0.3s both;
}
.bs-hero__btn {
  animation: fadeDown 0.9s ease 0.45s both;
}


/* ── LOGO HEADER ── */

/* ── Logo header haut gauche ── */
.custom-logo-link {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: flex-start !important;
}
.custom-logo {
  height: 55px !important;
  width: auto !important;
  max-width: 180px !important;
  object-fit: contain !important;
  display: block !important;
}
/* Masquer le texte si logo image présent */
.has-custom-logo .site-title,
.custom-logo-link ~ .site-title {
  display: none !important;
}
/* Supprimer logo du hero (au cas où) */
.bs-hero__logo { display: none !important; }


/* ── ABOUT & CONTACT ── */

/* ── PAGE HERO (About / Contact) ── */
.bs-page-hero {
  position: relative;
  height: 340px;
  background: #ffffff;
  border-bottom: 1px solid rgba(201,168,76,0.25);
  display: flex; align-items: center; justify-content: center;
}
.bs-page-hero__overlay {
  display: none;
}
.bs-page-hero__content { position:relative; z-index:2; text-align:center; }
.bs-page-hero__sub {
  color: #C9A84C; font-size:12px; font-weight:700;
  letter-spacing:4px; text-transform:uppercase; margin-bottom:12px;
}
.bs-page-hero__title {
  color: #1A1A1A; font-family:'Playfair Display',Georgia,serif;
  font-size:clamp(30px,5vw,52px); font-weight:700; line-height:1.2;
}

/* ── LABEL DORÉ ── */
.bs-label {
  display:inline-block; color:#C9A84C; font-size:11px; font-weight:700;
  letter-spacing:3px; text-transform:uppercase; margin-bottom:14px;
}

/* ══════════════════════════════ ABOUT ══════════════════════════════ */
.bs-about { max-width:1200px; margin:0 auto; padding:0 30px; }

/* Intro */
.bs-about__intro {
  display:grid; grid-template-columns:1fr 1fr; gap:60px;
  align-items:center; padding:80px 0;
}
.bs-about__intro-text h2 {
  font-family:'Playfair Display',Georgia,serif;
  font-size:36px; color:#1a1a1a; margin:0 0 24px; line-height:1.2;
}
.bs-about__intro-text p { color:#555; line-height:1.8; margin-bottom:16px; font-size:15px; }
.bs-about__intro-img img {
  width:100%; height:480px; object-fit:cover;
  box-shadow:0 12px 40px rgba(0,0,0,0.15);
}

/* Valeurs */
.bs-values { background:#F7F5F0; padding:80px 30px; margin:0 -30px; }
.bs-values__grid {
  display:grid; grid-template-columns:repeat(4,1fr); gap:30px;
  max-width:1200px; margin:40px auto 0;
}
.bs-value-card {
  background:#fff; padding:32px 24px; text-align:center;
  box-shadow:0 2px 12px rgba(0,0,0,0.06);
}
.bs-value-card__icon { color:#C9A84C; font-size:24px; margin-bottom:16px; }
.bs-value-card h3 {
  font-family:'Playfair Display',Georgia,serif; font-size:18px;
  color:#1a1a1a; margin-bottom:12px;
}
.bs-value-card p { color:#666; font-size:13px; line-height:1.7; }

/* Histoire */
.bs-story {
  display:grid; grid-template-columns:1fr 1fr; gap:60px;
  align-items:center; padding:80px 0;
}
.bs-story__img img {
  width:100%; height:500px; object-fit:cover;
  box-shadow:0 12px 40px rgba(0,0,0,0.15);
}
.bs-story__text h2 {
  font-family:'Playfair Display',Georgia,serif; font-size:34px; color:#1a1a1a;
  margin:0 0 24px; line-height:1.2;
}
.bs-story__text p { color:#555; line-height:1.8; margin-bottom:16px; font-size:15px; }

/* Stats */
.bs-stats {
  background:#1a1a1a; display:grid; grid-template-columns:repeat(4,1fr);
  padding:60px 30px; margin:0 -30px; text-align:center;
}
.bs-stat__number {
  font-family:'Playfair Display',Georgia,serif; font-size:52px;
  font-weight:700; color:#C9A84C; line-height:1;
}
.bs-stat__label { color:#aaa; font-size:13px; letter-spacing:2px; text-transform:uppercase; margin-top:10px; }

/* ══════════════════════════════ CONTACT ══════════════════════════════ */
.bs-contact { max-width:1200px; margin:0 auto; padding:80px 30px; }

.bs-contact__grid { display:grid; grid-template-columns:1fr 1.4fr; gap:60px; }

.bs-contact__info h2 {
  font-family:'Playfair Display',Georgia,serif; font-size:30px; color:#1a1a1a; margin:0 0 16px;
}
.bs-contact__info > p { color:#666; line-height:1.8; margin-bottom:32px; }

.bs-contact__items { display:flex; flex-direction:column; gap:20px; margin-bottom:36px; }
.bs-contact__item { display:flex; align-items:flex-start; gap:16px; }
.bs-contact__item-icon {
  width:40px; height:40px; background:#C9A84C; color:#fff;
  display:flex; align-items:center; justify-content:center;
  font-size:16px; flex-shrink:0;
}
.bs-contact__item-body { display:flex; flex-direction:column; gap:2px; }
.bs-contact__item-body strong { font-size:12px; letter-spacing:1px; text-transform:uppercase; color:#1a1a1a; }
.bs-contact__item-body a { color:#C9A84C; text-decoration:none; font-size:15px; }
.bs-contact__item-body a:hover { text-decoration:underline; }
.bs-contact__item-body span, .bs-contact__item-body small { color:#666; font-size:14px; }

.bs-social-links { display:flex; gap:12px; margin-top:12px; }
.bs-social-link {
  padding:8px 20px; border:1px solid #C9A84C; color:#C9A84C;
  font-size:11px; font-weight:700; letter-spacing:1px; text-transform:uppercase;
  text-decoration:none; transition:all 0.25s;
}
.bs-social-link:hover { background:#C9A84C; color:#fff; }

/* Formulaire */
.bs-contact__form h2 {
  font-family:'Playfair Display',Georgia,serif; font-size:30px; color:#1a1a1a; margin:0 0 24px;
}
.bs-form { display:flex; flex-direction:column; gap:18px; }
.bs-form__row--2 { display:grid; grid-template-columns:1fr 1fr; gap:18px; }
.bs-form__group { display:flex; flex-direction:column; gap:6px; }
.bs-form__group label { font-size:11px; font-weight:700; letter-spacing:1px; text-transform:uppercase; color:#1a1a1a; }
.bs-form__group input,
.bs-form__group select,
.bs-form__group textarea {
  border:1px solid #ddd; padding:12px 14px; font-size:14px;
  font-family:'Raleway',sans-serif; outline:none; border-radius:0;
  transition:border-color 0.2s;
}
.bs-form__group input:focus,
.bs-form__group select:focus,
.bs-form__group textarea:focus { border-color:#C9A84C; }
.bs-form__group textarea { resize:vertical; min-height:120px; }
.bs-form__btn {
  background:#1a1a1a; color:#fff; border:none; padding:16px 40px;
  font-size:12px; font-weight:700; letter-spacing:3px; text-transform:uppercase;
  cursor:pointer; transition:background 0.3s; align-self:flex-start;
}
.bs-form__btn:hover { background:#C9A84C; }

/* FAQ */
.bs-contact__faq {
  background:#F7F5F0; padding:60px 40px; margin-top:60px;
}
.bs-contact__faq h3 {
  font-family:'Playfair Display',Georgia,serif; font-size:26px; color:#1a1a1a;
  text-align:center; margin-bottom:36px;
}
.bs-faq__grid { display:grid; grid-template-columns:1fr 1fr; gap:24px; }
.bs-faq__item { background:#fff; padding:24px; box-shadow:0 2px 8px rgba(0,0,0,0.05); }
.bs-faq__item strong { display:block; color:#1a1a1a; margin-bottom:8px; font-size:14px; }
.bs-faq__item p { color:#666; font-size:13px; line-height:1.7; margin:0; }

/* Responsive */
@media(max-width:768px){
  .bs-about__intro, .bs-story { grid-template-columns:1fr; }
  .bs-values__grid { grid-template-columns:1fr 1fr; }
  .bs-stats { grid-template-columns:1fr 1fr; }
  .bs-contact__grid { grid-template-columns:1fr; }
  .bs-faq__grid { grid-template-columns:1fr; }
  .bs-form__row--2 { grid-template-columns:1fr; }
}


/* ── BARRE RECHERCHE CATEGORIES ── */

/* ── Barre de recherche catégories ── */
.bs-cat-search {
  margin: 0 0 36px 0;
  width: 100%;
}
.bs-cat-search__form {
  width: 100%;
}
.bs-cat-search__wrap {
  display: flex;
  align-items: center;
  border: 2px solid var(--gold, #C9A84C);
  border-radius: 4px;
  background: #fff;
  overflow: hidden;
  max-width: 640px;
  margin: 0 auto;
  box-shadow: 0 2px 12px rgba(201,168,76,0.10);
  transition: box-shadow .2s;
}
.bs-cat-search__wrap:focus-within {
  box-shadow: 0 4px 20px rgba(201,168,76,0.22);
}
.bs-cat-search__icon {
  width: 20px;
  height: 20px;
  flex-shrink: 0;
  margin: 0 10px 0 16px;
  color: var(--gold, #C9A84C);
}
.bs-cat-search__input {
  flex: 1;
  border: none !important;
  outline: none !important;
  box-shadow: none !important;
  background: transparent !important;
  font-family: 'Raleway', sans-serif;
  font-size: 15px;
  color: #1a1a1a;
  padding: 14px 0 !important;
  margin: 0 !important;
}
.bs-cat-search__input::placeholder {
  color: #aaa;
  font-style: italic;
}
.bs-cat-search__clear {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 32px;
  height: 32px;
  color: #999;
  font-size: 16px;
  text-decoration: none;
  flex-shrink: 0;
  transition: color .2s;
}
.bs-cat-search__clear:hover { color: #1a1a1a; }
.bs-cat-search__btn {
  background: var(--gold, #C9A84C);
  color: #fff;
  border: none;
  cursor: pointer;
  font-family: 'Raleway', sans-serif;
  font-size: 13px;
  font-weight: 700;
  letter-spacing: 1px;
  text-transform: uppercase;
  padding: 0 22px;
  height: 50px;
  flex-shrink: 0;
  transition: background .2s;
}
.bs-cat-search__btn:hover {
  background: #1a1a1a;
}
.bs-cat-search__info {
  text-align: center;
  margin: 12px 0 0;
  font-size: 14px;
  color: #666;
  font-family: 'Raleway', sans-serif;
}
.bs-cat-search__info strong { color: var(--gold, #C9A84C); }

@media (max-width: 600px) {
  .bs-cat-search__btn { padding: 0 14px; font-size: 12px; }
  .bs-cat-search__wrap { max-width: 100%; }
}


/* ── FIX ICON POSITION ── */

/* ── FIX icône recherche catégorie ── */
.bs-cat-search__wrap {
  position: relative;
}
.bs-cat-search__icon {
  position: absolute;
  left: 14px;
  top: 50%;
  transform: translateY(-50%);
  width: 18px;
  height: 18px;
  color: var(--gold, #C9A84C);
  pointer-events: none;
  margin: 0;
}
.bs-cat-search__input {
  padding-left: 44px !important;
}


/* ── FIX ICON SIZE ── */

/* ── FIX icône taille ── */
.bs-cat-search__icon {
  width: 16px !important;
  height: 16px !important;
  min-width: 16px !important;
  min-height: 16px !important;
  max-width: 16px !important;
  max-height: 16px !important;
  left: 12px;
  top: 50%;
  transform: translateY(-50%);
  position: absolute;
  margin: 0 !important;
  padding: 0 !important;
  flex-shrink: 0;
}


/* ── LOGO JPEG HEADER ── */

/* ── Logo JPEG header gauche ── */
.custom-logo-link {
  display: inline-flex !important;
  align-items: center !important;
}
.custom-logo {
  height: 55px !important;
  width: auto !important;
  max-width: 200px !important;
  object-fit: contain !important;
  display: block !important;
}
.has-custom-logo .site-title,
.custom-logo-link ~ .site-title {
  display: none !important;
}


/* ── FORMULAIRE CONTACT ── */

/* ── Page Contact ── */
.bs-contact-wrap {
  max-width: 1160px;
  margin: 60px auto;
  padding: 0 24px 80px;
}
.bs-contact-grid {
  display: grid;
  grid-template-columns: 1fr 1.6fr;
  gap: 60px;
  align-items: start;
}
@media(max-width:768px){ .bs-contact-grid{ grid-template-columns:1fr; gap:40px; } }

/* Infos */
.bs-contact-info__title,
.bs-contact-form__title {
  font-family: 'Playfair Display', serif;
  font-size: 24px;
  color: #1a1a1a;
  margin: 0 0 28px;
  padding-bottom: 12px;
  border-bottom: 2px solid #C9A84C;
}
.bs-contact-item {
  display: flex;
  align-items: flex-start;
  gap: 16px;
  margin-bottom: 24px;
}
.bs-contact-item__icon {
  width: 44px;
  height: 44px;
  border-radius: 50%;
  background: #f7f5f0;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}
.bs-contact-item__label {
  font-size: 12px;
  text-transform: uppercase;
  letter-spacing: 1px;
  color: #999;
  margin: 0 0 2px;
}
.bs-contact-item__value {
  font-size: 15px;
  color: #1a1a1a;
  margin: 0;
}
.bs-contact-item__value a {
  color: #1a1a1a;
  text-decoration: none;
}
.bs-contact-item__value a:hover { color: #C9A84C; }

/* Formulaire */
.bs-contact-form-wrap {
  background: #fff;
  border: 1px solid #eee;
  border-radius: 6px;
  padding: 36px 32px;
  box-shadow: 0 4px 24px rgba(0,0,0,0.06);
}
.bs-form-row--2 {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 16px;
}
@media(max-width:500px){ .bs-form-row--2{ grid-template-columns:1fr; } }
.bs-form-group { margin-bottom: 20px; }
.bs-form-label {
  display: block;
  font-size: 13px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: .8px;
  color: #444;
  margin-bottom: 7px;
  font-family: 'Raleway', sans-serif;
}
.bs-form-label span { color: #C9A84C; }
.bs-form-input,
.bs-form-select,
.bs-form-textarea {
  width: 100%;
  border: 1.5px solid #ddd;
  border-radius: 4px;
  padding: 12px 14px;
  font-family: 'Raleway', sans-serif;
  font-size: 14px;
  color: #1a1a1a;
  background: #fafafa;
  transition: border-color .2s, box-shadow .2s;
  box-sizing: border-box;
  -webkit-appearance: none;
  appearance: none;
}
.bs-form-input:focus,
.bs-form-select:focus,
.bs-form-textarea:focus {
  outline: none;
  border-color: #C9A84C;
  box-shadow: 0 0 0 3px rgba(201,168,76,0.12);
  background: #fff;
}
.bs-form-textarea { resize: vertical; min-height: 140px; }
.bs-form-submit {
  width: 100%;
  padding: 15px;
  background: #1a1a1a;
  color: #fff;
  border: 2px solid #1a1a1a;
  border-radius: 4px;
  font-family: 'Raleway', sans-serif;
  font-size: 13px;
  font-weight: 700;
  letter-spacing: 2px;
  text-transform: uppercase;
  cursor: pointer;
  transition: background .2s, color .2s;
  margin-top: 8px;
}
.bs-form-submit:hover {
  background: #C9A84C;
  border-color: #C9A84C;
  color: #fff;
}

/* Notice succès / erreur */
.bs-notice {
  padding: 14px 18px;
  border-radius: 4px;
  margin-bottom: 20px;
  font-family: 'Raleway', sans-serif;
  font-size: 14px;
}
.bs-notice--success {
  background: #edf7ed;
  border: 1px solid #a3d9a3;
  color: #2d6a2d;
}
.bs-notice--error {
  background: #fdf0f0;
  border: 1px solid #e0a0a0;
  color: #8b2020;
}


/* ── FOOTER CONTENU ── */

/* ── Pied de page – contenu ── */
.footer-desc {
  font-size: 14px;
  color: #aaa;
  line-height: 1.7;
  margin: 0 0 10px;
  font-family: 'Raleway', sans-serif;
}
.footer-tagline {
  font-size: 13px;
  color: var(--gold, #C9A84C);
  font-style: italic;
  font-family: 'Playfair Display', serif;
  margin: 0;
}
.footer-nav {
  list-style: none;
  margin: 0;
  padding: 0;
}
.footer-nav li { margin-bottom: 9px; }
.footer-nav a {
  font-family: 'Raleway', sans-serif;
  font-size: 13px;
  color: #aaa;
  text-decoration: none;
  letter-spacing: .5px;
  transition: color .2s;
}
.footer-nav a:hover { color: var(--gold, #C9A84C); }

.footer-contact p {
  display: flex;
  align-items: center;
  gap: 10px;
  font-family: 'Raleway', sans-serif;
  font-size: 13px;
  color: #aaa;
  margin: 0 0 10px;
}
.footer-contact a { color: #aaa; text-decoration: none; transition: color .2s; }
.footer-contact a:hover { color: var(--gold, #C9A84C); }
.fc-icon { font-size: 15px; color: var(--gold, #C9A84C); flex-shrink: 0; }

.footer-pay {
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: 1.5px;
  color: #666;
  margin: 16px 0 8px !important;
  font-family: 'Raleway', sans-serif;
}
.footer-badges {
  display: flex;
  gap: 6px;
  flex-wrap: wrap;
}
.footer-badge {
  background: #2a2a2a;
  border: 1px solid #3a3a3a;
  color: #ccc;
  font-size: 11px;
  font-family: 'Raleway', sans-serif;
  font-weight: 700;
  padding: 4px 10px;
  border-radius: 3px;
  letter-spacing: .5px;
}

/* Widget title dans le footer */
.ct-footer .widget-title,
.ct-footer .widgettitle {
  font-family: 'Playfair Display', serif !important;
  font-size: 15px !important;
  font-weight: 700 !important;
  color: #fff !important;
  text-transform: uppercase;
  letter-spacing: 2px;
  margin: 0 0 20px !important;
  padding-bottom: 10px !important;
  border-bottom: 1px solid var(--gold, #C9A84C) !important;
}


/* ── HERO BG AFRICAN FASHION ── */

/* ── Hero background – mode africaine ── */
.bs-hero {
  background-image: url('http://www.terangafashion.fr/wp-content/uploads/2026/05/hero-bg-african-fashion.jpg') !important;
  background-size: cover !important;
  background-position: center top !important;
  background-repeat: no-repeat !important;
}
.bs-hero__overlay {
  background: linear-gradient(
    to bottom,
    rgba(0,0,0,0.45) 0%,
    rgba(0,0,0,0.30) 50%,
    rgba(26,26,26,0.65) 100%
  ) !important;
}


/* ── HERO BG LOCAL ── */

/* ── Hero background local ── */
.bs-hero {
  background-image: url('http://www.terangafashion.fr/wp-content/uploads/2026/05/hero-bg.jpg') !important;
  background-size: cover !important;
  background-position: center center !important;
  background-repeat: no-repeat !important;
}
.bs-hero__overlay {
  background: linear-gradient(
    to bottom,
    rgba(0,0,0,0.40) 0%,
    rgba(0,0,0,0.25) 50%,
    rgba(26,26,26,0.60) 100%
  ) !important;
}


/* ── HERO TEXT VISIBILITY ── */

/* ── Texte hero visible sur image ── */
.bs-hero {
  position: relative;
  min-height: 90vh;
  display: flex;
  align-items: center;
  justify-content: center;
}
.bs-hero__overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(
    to bottom,
    rgba(0,0,0,0.50) 0%,
    rgba(0,0,0,0.35) 40%,
    rgba(0,0,0,0.65) 100%
  ) !important;
  z-index: 1;
}
.bs-hero__content {
  position: relative;
  z-index: 2;
  text-align: center;
  padding: 40px 24px;
  max-width: 800px;
  margin: 0 auto;
}
.bs-hero__sub {
  color: var(--gold, #C9A84C) !important;
  font-family: 'Raleway', sans-serif !important;
  font-size: 13px !important;
  font-weight: 700 !important;
  letter-spacing: 4px !important;
  text-transform: uppercase !important;
  margin: 0 0 16px !important;
  text-shadow: 0 1px 4px rgba(0,0,0,0.6) !important;
}
.bs-hero__title {
  color: #ffffff !important;
  font-family: 'Playfair Display', serif !important;
  font-size: clamp(32px, 5vw, 64px) !important;
  font-weight: 700 !important;
  line-height: 1.15 !important;
  margin: 0 0 28px !important;
  text-shadow: 0 2px 16px rgba(0,0,0,0.7), 0 1px 4px rgba(0,0,0,0.5) !important;
  letter-spacing: 1px !important;
}
.bs-hero__btn {
  display: inline-block !important;
  background: var(--gold, #C9A84C) !important;
  color: #fff !important;
  font-family: 'Raleway', sans-serif !important;
  font-size: 13px !important;
  font-weight: 700 !important;
  letter-spacing: 3px !important;
  text-transform: uppercase !important;
  text-decoration: none !important;
  padding: 16px 44px !important;
  border: 2px solid var(--gold, #C9A84C) !important;
  border-radius: 2px !important;
  transition: background .25s, color .25s, border-color .25s !important;
  box-shadow: 0 4px 20px rgba(0,0,0,0.30) !important;
}
.bs-hero__btn:hover {
  background: transparent !important;
  color: #fff !important;
  border-color: #fff !important;
}


/* ── HERO TITLE COLOR ── */

/* ── Titre hero blanc ivoire ── */
.bs-hero__title {
  color: #F5F0E8 !important;
  text-shadow: 0 2px 20px rgba(0,0,0,0.65), 0 1px 4px rgba(0,0,0,0.40) !important;
}


/* ── CATEGORIES FULL WIDTH ── */

/* ── Pages catégories – pleine largeur + 4 colonnes ── */

/* Conteneur pleine largeur */
.tax-product_cat .site-content,
.tax-product_cat .content-area,
.tax-product_cat .ct-container,
.tax-product_cat .ct-container-fluid,
.tax-product_cat main {
  max-width: 100% !important;
  width: 100% !important;
  padding-left: 32px !important;
  padding-right: 32px !important;
}

/* Masquer la sidebar sur ces pages */
.tax-product_cat .ct-sidebar,
.tax-product_cat aside,
.tax-product_cat .widget-area {
  display: none !important;
}

/* Zone principale pleine largeur */
.tax-product_cat .ct-main-area,
.tax-product_cat #primary,
.tax-product_cat .woocommerce-notices-wrapper + *,
.tax-product_cat .woocommerce {
  width: 100% !important;
  max-width: 100% !important;
  flex: 0 0 100% !important;
}

/* Grille produits – 4 colonnes */
.tax-product_cat ul.products,
.tax-product_cat .products {
  display: grid !important;
  grid-template-columns: repeat(4, 1fr) !important;
  gap: 24px !important;
  width: 100% !important;
}

/* Barre de recherche pleine largeur */
.tax-product_cat .bs-cat-search__wrap {
  max-width: 100% !important;
}

/* Responsive */
@media (max-width: 1200px) {
  .tax-product_cat ul.products,
  .tax-product_cat .products {
    grid-template-columns: repeat(3, 1fr) !important;
  }
}
@media (max-width: 768px) {
  .tax-product_cat ul.products,
  .tax-product_cat .products {
    grid-template-columns: repeat(2, 1fr) !important;
    gap: 14px !important;
  }
  .tax-product_cat .ct-container,
  .tax-product_cat .site-content {
    padding-left: 16px !important;
    padding-right: 16px !important;
  }
}
@media (max-width: 480px) {
  .tax-product_cat ul.products,
  .tax-product_cat .products {
    grid-template-columns: 1fr 1fr !important;
    gap: 10px !important;
  }
}


/* ── FIX RIGHT SPACE ── */

/* ── Fix espace droit catégories ── */
.tax-product_cat .ct-container,
.tax-product_cat .ct-container-fluid,
.tax-product_cat .entry-content,
.tax-product_cat .woocommerce,
.tax-product_cat .woocommerce-page,
.tax-product_cat #primary,
.tax-product_cat .ct-main-area,
.tax-product_cat .content-area,
.tax-product_cat .site-content {
  padding-right: 32px !important;
  margin-right: 0 !important;
  max-width: 100% !important;
  box-sizing: border-box !important;
}

/* Supprimer tout margin/padding hérité du sidebar vide */
.tax-product_cat .ct-sidebar-area,
.tax-product_cat .ct-sidebar,
.tax-product_cat aside {
  display: none !important;
  width: 0 !important;
  padding: 0 !important;
  margin: 0 !important;
}

/* Forcer le layout en une seule colonne sans sidebar */
.tax-product_cat .ct-content-area-wrap {
  display: block !important;
  width: 100% !important;
  max-width: 100% !important;
  grid-template-columns: 1fr !important;
  padding-right: 0 !important;
}

.tax-product_cat .ct-main-area {
  width: 100% !important;
  max-width: 100% !important;
  flex: none !important;
  padding-right: 0 !important;
}


/* ════ REDESIGN CATEGORIES ════ */

/* ════════════════════════════════════════════
   REDESIGN PAGES CATÉGORIES
   ════════════════════════════════════════════ */

/* ── Hero catégorie ── */
.bs-cat-hero {
  background: #1a1a1a;
  background-image:
    repeating-linear-gradient(
      45deg,
      rgba(201,168,76,0.04) 0px,
      rgba(201,168,76,0.04) 1px,
      transparent 1px,
      transparent 12px
    ),
    repeating-linear-gradient(
      -45deg,
      rgba(201,168,76,0.04) 0px,
      rgba(201,168,76,0.04) 1px,
      transparent 1px,
      transparent 12px
    );
  border-radius: 14px;
  text-align: center;
  padding: 64px 40px 56px;
  margin: 0 0 40px;
}
.bs-cat-hero__collection {
  font-family: 'Raleway', sans-serif;
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 4px;
  text-transform: uppercase;
  color: var(--gold, #C9A84C);
  margin: 0 0 16px;
}
.bs-cat-hero__title {
  font-family: 'Playfair Display', serif;
  font-size: clamp(40px, 7vw, 80px);
  font-weight: 700;
  color: #ffffff;
  margin: 0 0 14px;
  letter-spacing: 6px;
  line-height: 1;
}
.bs-cat-hero__desc {
  font-family: 'Raleway', sans-serif;
  font-size: 15px;
  font-style: italic;
  color: var(--gold, #C9A84C);
  margin: 0 0 20px;
}
.bs-cat-hero__line {
  display: block;
  width: 48px;
  height: 1px;
  background: var(--gold, #C9A84C);
  margin: 0 auto 24px;
}
.bs-cat-hero__btn {
  display: inline-block;
  background: var(--gold, #C9A84C);
  color: #1a1a1a;
  font-family: 'Raleway', sans-serif;
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 3px;
  text-transform: uppercase;
  text-decoration: none;
  padding: 14px 36px;
  border-radius: 4px;
  transition: background .2s, color .2s;
}
.bs-cat-hero__btn:hover {
  background: #fff;
  color: #1a1a1a;
}

/* ── Cartes sous-catégories ── */
.bs-subcats {
  display: flex;
  gap: 16px;
  margin: 0 0 32px;
  flex-wrap: wrap;
}
.bs-subcat {
  flex: 1;
  min-width: 160px;
  background: #f5f0e8;
  border-radius: 12px;
  padding: 24px 20px;
  text-align: center;
  text-decoration: none;
  transition: transform .2s, box-shadow .2s;
  border: 1px solid #ebe6da;
}
.bs-subcat:hover {
  transform: translateY(-3px);
  box-shadow: 0 8px 24px rgba(0,0,0,0.08);
}
.bs-subcat__icon {
  display: block;
  color: var(--gold, #C9A84C);
  margin: 0 auto 10px;
  width: 28px;
  height: 28px;
}
.bs-subcat__name {
  display: block;
  font-family: 'Raleway', sans-serif;
  font-size: 14px;
  font-weight: 700;
  color: #1a1a1a;
  margin-bottom: 4px;
}
.bs-subcat__count {
  display: block;
  font-family: 'Raleway', sans-serif;
  font-size: 12px;
  color: #999;
}

/* ── Barre de filtre ── */
.bs-filter-bar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  margin: 0 0 28px;
  flex-wrap: wrap;
}
.bs-filter-bar__left {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
}
.bs-filter-btn {
  display: inline-block;
  padding: 9px 20px;
  border: 1.5px solid #ddd;
  border-radius: 4px;
  font-family: 'Raleway', sans-serif;
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 1.5px;
  text-transform: uppercase;
  color: #555;
  text-decoration: none;
  transition: all .2s;
  background: transparent;
}
.bs-filter-btn:hover,
.bs-filter-btn.active {
  background: #1a1a1a;
  border-color: #1a1a1a;
  color: #fff;
}

/* ── Cartes produits – design sombre ── */
.tax-product_cat ul.products li.product,
.tax-product_cat .products li.product {
  background: #252525 !important;
  border-radius: 14px !important;
  overflow: hidden !important;
  border: none !important;
  box-shadow: 0 2px 12px rgba(0,0,0,0.15) !important;
  transition: transform .25s, box-shadow .25s !important;
  position: relative !important;
  padding: 0 0 18px !important;
}
.tax-product_cat ul.products li.product:hover {
  transform: translateY(-5px) !important;
  box-shadow: 0 12px 32px rgba(0,0,0,0.25) !important;
}

/* Image produit */
.tax-product_cat .product .woocommerce-loop-product__link img,
.tax-product_cat .product a img {
  border-radius: 10px 10px 0 0 !important;
  width: 100% !important;
  aspect-ratio: 3/4 !important;
  object-fit: cover !important;
  display: block !important;
  background: #1a1a1a !important;
}

/* Contenu carte */
.tax-product_cat .product .woocommerce-loop-product__link,
.tax-product_cat .product > a:first-child {
  text-decoration: none !important;
}
.tax-product_cat .product .woocommerce-loop-product__title,
.tax-product_cat .product h2 {
  font-family: 'Raleway', sans-serif !important;
  font-size: 14px !important;
  font-weight: 700 !important;
  color: #f0ece4 !important;
  padding: 14px 16px 4px !important;
  margin: 0 !important;
  line-height: 1.3 !important;
}
.bs-product-sizes {
  font-family: 'Raleway', sans-serif !important;
  font-size: 12px !important;
  color: #888 !important;
  padding: 0 16px 8px !important;
  margin: 0 !important;
}
.tax-product_cat .product .price {
  display: block !important;
  padding: 0 16px 12px !important;
  font-family: 'Raleway', sans-serif !important;
  font-size: 16px !important;
  font-weight: 700 !important;
  color: var(--gold, #C9A84C) !important;
}
.tax-product_cat .product .price del {
  color: #666 !important;
  font-size: 13px !important;
  margin-right: 6px !important;
}
.tax-product_cat .product .button,
.tax-product_cat .product .add_to_cart_button {
  display: block !important;
  margin: 0 16px !important;
  background: #1a1a1a !important;
  color: #fff !important;
  border: none !important;
  border-radius: 6px !important;
  font-family: 'Raleway', sans-serif !important;
  font-size: 11px !important;
  font-weight: 700 !important;
  letter-spacing: 2px !important;
  text-transform: uppercase !important;
  padding: 12px !important;
  text-align: center !important;
  transition: background .2s !important;
  cursor: pointer !important;
  text-decoration: none !important;
}
.tax-product_cat .product .button:hover,
.tax-product_cat .product .add_to_cart_button:hover {
  background: var(--gold, #C9A84C) !important;
  color: #fff !important;
}

/* ── Badges ── */
.bs-badge {
  position: absolute;
  top: 12px;
  z-index: 3;
  font-family: 'Raleway', sans-serif;
  font-size: 10px;
  font-weight: 800;
  letter-spacing: 1px;
  text-transform: uppercase;
  padding: 5px 10px;
  border-radius: 4px;
}
.bs-badge--new {
  left: 12px;
  background: var(--gold, #C9A84C);
  color: #1a1a1a;
}
.bs-badge--sale {
  right: 12px;
  background: #c0392b;
  color: #fff;
}

/* ── Masquer éléments WooCommerce indésirables ── */
.tax-product_cat .woocommerce-result-count { display: none !important; }
.tax-product_cat .woocommerce-ordering { display: none !important; }


/* ── TOOLBAR UNIFIE ── */

/* ── Toolbar (filtres + recherche côte à côte) ── */
.bs-toolbar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  margin: 0 0 28px;
  flex-wrap: wrap;
}
.bs-toolbar__filters {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
  align-items: center;
}
.bs-toolbar__search {
  flex-shrink: 0;
}
.bs-toolbar__search-wrap {
  display: flex;
  align-items: center;
  gap: 8px;
  border: 1.5px solid var(--gold, #C9A84C);
  border-radius: 4px;
  background: #fff;
  padding: 0 12px;
  height: 40px;
  min-width: 220px;
  transition: box-shadow .2s;
}
.bs-toolbar__search-wrap:focus-within {
  box-shadow: 0 0 0 3px rgba(201,168,76,0.15);
}
.bs-toolbar__search-input {
  border: none !important;
  outline: none !important;
  box-shadow: none !important;
  background: transparent !important;
  font-family: 'Raleway', sans-serif;
  font-size: 13px;
  color: #1a1a1a;
  flex: 1;
  padding: 0 !important;
  margin: 0 !important;
  min-width: 0;
}
.bs-toolbar__search-input::placeholder { color: #aaa; font-style: italic; }
.bs-toolbar__search-clear {
  color: #aaa;
  text-decoration: none;
  font-size: 13px;
  line-height: 1;
  transition: color .2s;
  flex-shrink: 0;
}
.bs-toolbar__search-clear:hover { color: #1a1a1a; }

/* Masquer l'ancienne barre de recherche standalone */
.bs-cat-search { display: none !important; }

@media (max-width: 640px) {
  .bs-toolbar { flex-direction: column; align-items: flex-start; }
  .bs-toolbar__search-wrap { min-width: 100%; width: 100%; }
  .bs-toolbar__search { width: 100%; }
}


/* ── REVERT TOOLBAR ── */

/* ── Revert toolbar : search séparé ── */
.bs-cat-search { display: block !important; }
.bs-toolbar { display: none !important; }


/* ── TRI DROPDOWN ── */

/* ── Tri ── */
.bs-filter-bar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  margin: 0 0 28px;
  flex-wrap: wrap;
}
.bs-sort-form { flex-shrink: 0; }
.bs-sort-wrap {
  display: flex;
  align-items: center;
  gap: 8px;
  border: 1.5px solid #ddd;
  border-radius: 4px;
  background: #fff;
  padding: 0 12px;
  height: 40px;
  transition: border-color .2s;
}
.bs-sort-wrap:focus-within { border-color: var(--gold, #C9A84C); }
.bs-sort-select {
  border: none !important;
  outline: none !important;
  background: transparent !important;
  font-family: 'Raleway', sans-serif;
  font-size: 13px;
  color: #444;
  cursor: pointer;
  padding: 0 !important;
  -webkit-appearance: none;
  appearance: none;
  min-width: 160px;
}
@media (max-width: 640px) {
  .bs-filter-bar { flex-direction: column; align-items: flex-start; }
  .bs-sort-wrap { width: 100%; }
}


/* ── SEARCH ICON RIGHT ── */

/* ── Icône recherche déplacée à droite ── */
.bs-cat-search__wrap {
  flex-direction: row-reverse;
}
.bs-cat-search__icon {
  position: static !important;
  transform: none !important;
  margin: 0 12px 0 8px !important;
}
.bs-cat-search__input {
  padding-left: 14px !important;
}
.bs-cat-search__btn {
  order: -1;
}
.bs-cat-search__clear {
  order: -1;
}


/* ════ HERO EXACT REFERENCE ════ */

/* ════════════════════════════════════
   HERO CATÉGORIE – EXACT REFERENCE
   ════════════════════════════════════ */
.bs-cat-hero {
  background-color: #1c1c1c !important;
  background-image:
    repeating-linear-gradient(
      45deg,
      rgba(255,255,255,0.03) 0px,
      rgba(255,255,255,0.03) 1px,
      transparent 1px,
      transparent 14px
    ),
    repeating-linear-gradient(
      -45deg,
      rgba(255,255,255,0.03) 0px,
      rgba(255,255,255,0.03) 1px,
      transparent 1px,
      transparent 14px
    ) !important;
  border-radius: 14px !important;
  padding: 70px 60px 60px !important;
  margin: 0 0 40px !important;
  text-align: center !important;
  width: 100% !important;
  box-sizing: border-box !important;
}

.bs-cat-hero__collection {
  font-family: 'Raleway', sans-serif !important;
  font-size: 11px !important;
  font-weight: 700 !important;
  letter-spacing: 5px !important;
  text-transform: uppercase !important;
  color: #C9A84C !important;
  margin: 0 0 18px !important;
  display: block !important;
}

.bs-cat-hero__title {
  font-family: 'Raleway', sans-serif !important;
  font-size: clamp(52px, 9vw, 88px) !important;
  font-weight: 800 !important;
  color: #ffffff !important;
  letter-spacing: 8px !important;
  text-transform: uppercase !important;
  line-height: 1 !important;
  margin: 0 0 20px !important;
  display: block !important;
}

.bs-cat-hero__desc {
  font-family: 'Playfair Display', serif !important;
  font-size: 15px !important;
  font-style: italic !important;
  color: #C9A84C !important;
  letter-spacing: 1px !important;
  margin: 0 0 22px !important;
  display: block !important;
}

.bs-cat-hero__line {
  display: block !important;
  width: 44px !important;
  height: 1px !important;
  background: #C9A84C !important;
  margin: 0 auto 28px !important;
}

.bs-cat-hero__btn {
  display: inline-block !important;
  background: #C9A84C !important;
  color: #1c1c1c !important;
  font-family: 'Raleway', sans-serif !important;
  font-size: 12px !important;
  font-weight: 800 !important;
  letter-spacing: 3px !important;
  text-transform: uppercase !important;
  text-decoration: none !important;
  padding: 16px 48px !important;
  border-radius: 3px !important;
  border: none !important;
  transition: background .2s, color .2s !important;
}
.bs-cat-hero__btn:hover {
  background: #b8960a !important;
  color: #fff !important;
}


/* ── FIX CONTACT INPUTS ── */

/* ── Fix inputs formulaire contact ── */
.bs-contact-form-wrap,
.bs-contact-form {
  position: static !important;
}
.bs-contact-form-wrap *,
.bs-contact-form * {
  pointer-events: auto !important;
}
.bs-form-input,
.bs-form-select,
.bs-form-textarea {
  pointer-events: auto !important;
  position: relative !important;
  z-index: 10 !important;
  -webkit-user-select: text !important;
  user-select: text !important;
  cursor: text !important;
  display: block !important;
  opacity: 1 !important;
  visibility: visible !important;
}
.bs-form-select {
  cursor: pointer !important;
}
.bs-form-row--2 {
  position: relative !important;
  z-index: 5 !important;
}
.bs-form-group {
  position: relative !important;
  z-index: 5 !important;
}


/* ── MENU MOBILE FIX ── */

/* Overlay sombre derrière le drawer */
.ct-overlay {
  position: fixed !important;
  inset: 0 !important;
  background: rgba(0, 0, 0, 0.80) !important;
  z-index: 9000 !important;
}

/* Fond solide du panneau mobile */
.ct-drawer-canvas,
.ct-panel {
  background: #1A1A1A !important;
  z-index: 9999 !important;
}
.ct-panel-content,
.ct-panel-inner,
.ct-panel-content-inner {
  background: #1A1A1A !important;
  min-height: 100vh !important;
}

/* Liens menu mobile */
.mobile-menu .ct-menu-link,
.ct-panel .menu a,
.ct-panel nav a {
  color: #FFFFFF !important;
  font-family: 'Raleway', sans-serif !important;
  font-size: 14px !important;
  font-weight: 700 !important;
  letter-spacing: 2.5px !important;
  text-transform: uppercase !important;
  padding: 16px 24px !important;
  display: block !important;
  border-bottom: 1px solid rgba(255, 255, 255, 0.08) !important;
  text-decoration: none !important;
}
.mobile-menu .ct-menu-link:hover,
.ct-panel .menu a:hover,
.ct-panel nav a:hover {
  color: var(--gold, #C9A84C) !important;
  background: rgba(201, 168, 76, 0.06) !important;
}

/* Icône hamburger (couleur sombre sur fond blanc du header) */
.ct-header-trigger svg {
  color: #1A1A1A !important;
  fill: #1A1A1A !important;
}
.ct-header-trigger:hover svg {
  color: var(--gold, #C9A84C) !important;
  fill: var(--gold, #C9A84C) !important;
}

/* Bouton fermeture × dans le drawer */
.ct-toggle-close svg {
  color: #FFFFFF !important;
  fill: #FFFFFF !important;
}
.ct-panel-actions {
  background: #1A1A1A !important;
  border-bottom: 1px solid rgba(201, 168, 76, 0.25) !important;
  padding: 16px 24px !important;
}

/* Bloquer le scroll du body quand le menu est ouvert */
body.has-drawer-open,
body.ct-has-overlay {
  overflow: hidden !important;
  height: 100% !important;
}


/* ── DRAWER : CORRECTIONS LOGO & ADRESSE ── */

/* Supprimer la fausse adresse "Our Location" dans le drawer */
#offcanvas .ct-header-text[data-id="text"],
.ct-panel .ct-header-text[data-id="text"] {
  display: none !important;
}

/* Corriger la taille du logo dans le drawer */
[data-id="offcanvas-logo"] .default-logo {
  height: 52px !important;
  width: auto !important;
  max-width: 180px !important;
  object-fit: contain !important;
}


/* ════════════════════════════════════════════════
   DESIGN PRODUITS UNIFIÉ — TOUTES PAGES
   Police : Times New Roman — Luxury Fashion
   ════════════════════════════════════════════════ */

/* ── Carte produit (toutes pages) ── */
.woocommerce ul.products li.product,
.woocommerce-page ul.products li.product,
.tax-product_cat ul.products li.product,
.tax-product_cat .products li.product,
.home ul.products li.product {
  background: #ffffff !important;
  border: 1px solid #ece8e0 !important;
  border-radius: 0 !important;
  box-shadow: 0 2px 14px rgba(0,0,0,0.06) !important;
  overflow: hidden !important;
  transition: transform 0.3s ease, box-shadow 0.3s ease !important;
  position: relative !important;
  padding: 0 0 18px !important;
  display: flex !important;
  flex-direction: column !important;
  transform: none !important;
}
.woocommerce ul.products li.product:hover,
.tax-product_cat ul.products li.product:hover {
  transform: translateY(-5px) !important;
  box-shadow: 0 14px 40px rgba(0,0,0,0.13) !important;
}

/* ── Image produit ── */
.woocommerce ul.products li.product figure,
.tax-product_cat .product figure {
  margin: 0 !important;
  overflow: hidden !important;
  background: #f5f0e8 !important;
  flex-shrink: 0 !important;
}
.woocommerce ul.products li.product figure img,
.woocommerce ul.products li.product .ct-media-container img,
.tax-product_cat .product figure img,
.tax-product_cat .product .ct-media-container img,
.tax-product_cat .product a img {
  width: 100% !important;
  aspect-ratio: 3/4 !important;
  object-fit: cover !important;
  display: block !important;
  border-radius: 0 !important;
  background: #f5f0e8 !important;
  transition: transform 0.5s ease !important;
}
.woocommerce ul.products li.product:hover figure img,
.tax-product_cat .product:hover img {
  transform: scale(1.04) !important;
}

/* ── Titre produit — Times New Roman ── */
.woocommerce ul.products li.product .woocommerce-loop-product__title,
.woocommerce ul.products li.product h2,
.tax-product_cat .product .woocommerce-loop-product__title,
.tax-product_cat .product h2,
.home .product .woocommerce-loop-product__title {
  font-family: 'Times New Roman', Times, serif !important;
  font-size: 15px !important;
  font-weight: 700 !important;
  color: #1a1a1a !important;
  padding: 14px 14px 5px !important;
  margin: 0 !important;
  line-height: 1.4 !important;
  letter-spacing: 0.2px !important;
  text-transform: none !important;
}

/* ── Prix — Times New Roman ── */
.woocommerce ul.products li.product .price,
.tax-product_cat .product .price,
.home .product .price {
  font-family: 'Times New Roman', Times, serif !important;
  font-size: 16px !important;
  font-weight: 700 !important;
  color: var(--gold, #C9A84C) !important;
  padding: 3px 14px 10px !important;
  display: block !important;
  margin: 0 !important;
}
.woocommerce ul.products li.product .price del,
.tax-product_cat .product .price del {
  font-family: 'Times New Roman', Times, serif !important;
  color: #bbb !important;
  font-size: 13px !important;
  font-weight: 400 !important;
  margin-right: 5px !important;
  text-decoration: line-through !important;
}
.woocommerce ul.products li.product .price ins,
.tax-product_cat .product .price ins {
  text-decoration: none !important;
}

/* ── Tailles — Times New Roman ── */
.bs-product-sizes {
  font-family: 'Times New Roman', Times, serif !important;
  font-size: 12px !important;
  color: #999 !important;
  padding: 0 14px 8px !important;
  margin: 0 !important;
  font-style: italic !important;
}

/* ── Notes étoiles ── */
.ct-woo-card-rating {
  padding: 0 14px 8px !important;
}

/* ── Bouton panier — Times New Roman ── */
.woocommerce ul.products li.product .button,
.woocommerce ul.products li.product .add_to_cart_button,
.tax-product_cat .product .button,
.tax-product_cat .product .add_to_cart_button,
.home .product .button {
  display: block !important;
  margin: 4px 14px 0 !important;
  width: calc(100% - 28px) !important;
  box-sizing: border-box !important;
  background: #1a1a1a !important;
  color: #ffffff !important;
  border: 2px solid #1a1a1a !important;
  border-radius: 0 !important;
  font-family: 'Times New Roman', Times, serif !important;
  font-size: 12px !important;
  font-weight: 700 !important;
  letter-spacing: 2px !important;
  text-transform: uppercase !important;
  padding: 11px 14px !important;
  text-align: center !important;
  transition: background 0.25s, border-color 0.25s, color 0.25s !important;
  cursor: pointer !important;
  text-decoration: none !important;
}
.woocommerce ul.products li.product .button:hover,
.tax-product_cat .product .button:hover {
  background: var(--gold, #C9A84C) !important;
  border-color: var(--gold, #C9A84C) !important;
  color: #ffffff !important;
}

/* ── Badges NOUVEAU / PROMO ── */
.bs-badge {
  font-family: 'Times New Roman', Times, serif !important;
  font-size: 10px !important;
  font-weight: 700 !important;
  letter-spacing: 1px !important;
  text-transform: uppercase !important;
  padding: 5px 10px !important;
  border-radius: 0 !important;
  position: absolute !important;
  top: 12px !important;
  z-index: 3 !important;
}
.bs-badge--new { left: 12px !important; background: var(--gold,#C9A84C) !important; color: #1a1a1a !important; }
.bs-badge--sale { right: 12px !important; background: #c0392b !important; color: #fff !important; }

/* ════════════════════════════════════════════════
   SECTION PAIEMENT — CHECKOUT BLACK SHOP
   ════════════════════════════════════════════════ */

/* Titre "Moyen de paiement" */
#payment .woocommerce-checkout-payment h3,
#payment ul.wc_payment_methods + h3 {
  font-family: 'Times New Roman', Times, serif !important;
  font-size: 13px !important;
  font-weight: 700 !important;
  letter-spacing: 2px !important;
  text-transform: uppercase !important;
  color: #1a1a1a !important;
  margin-bottom: 16px !important;
}

/* Liste des méthodes */
#payment ul.wc_payment_methods {
  list-style: none !important;
  padding: 0 !important;
  margin: 0 0 24px !important;
  border: 1px solid #ece8e0 !important;
  background: #fff !important;
}

/* Chaque méthode */
#payment ul.wc_payment_methods li.wc_payment_method {
  border-bottom: 1px solid #ece8e0 !important;
  padding: 0 !important;
}
#payment ul.wc_payment_methods li.wc_payment_method:last-child {
  border-bottom: none !important;
}

/* Label cliquable */
#payment ul.wc_payment_methods li.wc_payment_method label {
  display: flex !important;
  align-items: center !important;
  gap: 12px !important;
  padding: 16px 20px !important;
  cursor: pointer !important;
  font-family: 'Times New Roman', Times, serif !important;
  font-size: 14px !important;
  font-weight: 600 !important;
  color: #1a1a1a !important;
  transition: background 0.2s !important;
}
#payment ul.wc_payment_methods li.wc_payment_method label:hover {
  background: #faf8f4 !important;
}

/* Radio button custom — doré */
#payment ul.wc_payment_methods li.wc_payment_method input[type="radio"] {
  appearance: none !important;
  -webkit-appearance: none !important;
  width: 18px !important;
  height: 18px !important;
  min-width: 18px !important;
  border: 2px solid #ccc !important;
  border-radius: 50% !important;
  background: #fff !important;
  cursor: pointer !important;
  transition: border-color 0.2s, background 0.2s !important;
  position: relative !important;
  flex-shrink: 0 !important;
}
#payment ul.wc_payment_methods li.wc_payment_method input[type="radio"]:checked {
  border-color: var(--gold, #C9A84C) !important;
  background: var(--gold, #C9A84C) !important;
  box-shadow: inset 0 0 0 4px #fff !important;
}

/* Méthode sélectionnée — fond doré très léger */
#payment ul.wc_payment_methods li.wc_payment_method:has(input:checked) {
  background: #fdf9f0 !important;
}
#payment ul.wc_payment_methods li.wc_payment_method:has(input:checked) label {
  color: #1a1a1a !important;
  font-weight: 700 !important;
}

/* Icônes de paiement */
#payment ul.wc_payment_methods li.wc_payment_method img {
  height: 24px !important;
  width: auto !important;
  margin-left: auto !important;
  opacity: 0.85 !important;
}

/* Desc sous la méthode (ex: "Payer en 3x sans frais") */
#payment .payment_box {
  background: #faf8f4 !important;
  border-top: 1px solid #ece8e0 !important;
  padding: 14px 20px !important;
  font-family: 'Times New Roman', Times, serif !important;
  font-size: 13px !important;
  color: #555 !important;
  margin: 0 !important;
}

/* Bouton "Commander" */
#payment #place_order {
  font-family: 'Times New Roman', Times, serif !important;
  font-size: 14px !important;
  font-weight: 700 !important;
  letter-spacing: 2px !important;
  text-transform: uppercase !important;
  background: #1a1a1a !important;
  color: #ffffff !important;
  border: 2px solid #1a1a1a !important;
  border-radius: 0 !important;
  padding: 16px 40px !important;
  width: 100% !important;
  cursor: pointer !important;
  transition: background 0.25s, border-color 0.25s !important;
}
#payment #place_order:hover {
  background: var(--gold, #C9A84C) !important;
  border-color: var(--gold, #C9A84C) !important;
  color: #fff !important;
}

/* ── Responsive ── */
@media (max-width: 1024px) {
  .woocommerce ul.products:not(.tax-product_cat ul.products),
  .woocommerce-page ul.products {
    grid-template-columns: repeat(3, 1fr) !important;
  }
}
@media (max-width: 768px) {
  .woocommerce ul.products,
  .woocommerce-page ul.products,
  .tax-product_cat ul.products,
  .tax-product_cat .products {
    grid-template-columns: repeat(2, 1fr) !important;
    gap: 12px !important;
  }
  .woocommerce ul.products li.product .woocommerce-loop-product__title,
  .tax-product_cat .product .woocommerce-loop-product__title {
    font-size: 13px !important;
    padding: 10px 10px 4px !important;
  }
  .woocommerce ul.products li.product .price,
  .tax-product_cat .product .price {
    font-size: 14px !important;
    padding: 2px 10px 8px !important;
  }
  .woocommerce ul.products li.product .button,
  .tax-product_cat .product .button {
    margin: 0 10px !important;
    width: calc(100% - 20px) !important;
    font-size: 10px !important;
    padding: 9px 8px !important;
    letter-spacing: 1px !important;
  }
  .ct-woo-card-rating { padding: 0 10px 6px !important; }
  .bs-product-sizes { padding: 0 10px 6px !important; }
}
