/*
Theme Name: Instoria WooCommerce Premium
Theme URI: https://atelierinstoria.fr
Author: L'Atelier Instoria
Description: Thème WordPress WooCommerce premium pour créations personnalisées Instoria.
Version: 2.0.0
Requires at least: 6.0
Requires PHP: 7.4
Text Domain: instoria
Tags: woocommerce, handmade, elegant, beige
*/

@import url('https://fonts.googleapis.com/css2?family=Cormorant+Garamond:wght@400;500;600&family=Montserrat:wght@300;400;500;600;700&display=swap');

:root{
  --ivory:#FAF7F2;
  --soft-ivory:#F5EFE7;
  --sand:#D8C3A5;
  --greige:#CBBBA0;
  --terracotta:#C98C73;
  --terracotta-dark:#B87560;
  --wood:#B08968;
  --charcoal:#2B2B2B;
  --brown:#5E4634;
  --white:#FFFFFF;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;background:var(--ivory);color:var(--charcoal);font-family:'Montserrat',Arial,sans-serif;font-weight:400}
a{color:inherit;text-decoration:none}
a:hover{color:var(--terracotta)}
h1,h2,h3,h4,.site-title{font-family:'Cormorant Garamond',Georgia,serif;font-weight:500}
.container{width:min(1280px,calc(100% - 64px));margin:0 auto}

/* HEADER */
.site-header{
  position:sticky;
  top:0;
  left:0;
  width:100%;
  z-index:999;
  background:rgba(250,247,242,.82);
  backdrop-filter:blur(18px);
  -webkit-backdrop-filter:blur(18px);
  border-bottom:1px solid rgba(216,195,165,.35);
}

.home .site-header,
.front-page .site-header{
  position:absolute;
  background:rgba(250,247,242,.28);
  border:none;
}

.header-inner{
  min-height:190px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:42px;
}

.site-branding{display:flex;align-items:center;flex:0 0 auto;position:relative;z-index:5}
.logo-link{display:flex;align-items:center;line-height:0}
.instoria-logo{
  height:200px!important;
  max-height:200px!important;
  width:auto!important;
  object-fit:contain;
  display:block;
  background:transparent!important;
  filter:drop-shadow(0 10px 24px rgba(255,255,255,.65)) drop-shadow(0 10px 30px rgba(43,43,43,.12));
  transition:.3s ease;
}
.logo-link:hover .instoria-logo{transform:scale(1.015)}

.main-navigation{flex:1;display:flex;justify-content:center;padding-top:18px}
.main-navigation ul{list-style:none;display:flex;align-items:center;gap:32px;padding:0;margin:0}
.main-navigation a{
  text-transform:uppercase;
  letter-spacing:.16em;
  font-size:12px;
  color:#3A312B;
  font-weight:700;
  text-shadow:0 1px 10px rgba(255,255,255,.55);
  transition:.25s ease;
}
.main-navigation a:hover{color:var(--terracotta)}

.header-actions{display:flex;align-items:center;gap:14px;flex:0 0 auto;padding-top:18px}

.quote-link{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height:48px;
  padding:14px 24px;
  border-radius:999px;
  background:var(--terracotta);
  border:1px solid var(--terracotta);
  color:#fff;
  text-transform:uppercase;
  letter-spacing:.14em;
  font-size:11px;
  font-weight:800;
  box-shadow:0 16px 36px rgba(201,140,115,.30);
  transition:.25s ease;
}
.quote-link:hover{background:var(--terracotta-dark);border-color:var(--terracotta-dark);color:#fff;transform:translateY(-2px)}

.header-cart{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:10px;
  min-height:48px;
  padding:14px 22px;
  border-radius:999px;
  background:#2B2B2B;
  border:1px solid #2B2B2B;
  color:#fff;
  text-transform:uppercase;
  letter-spacing:.14em;
  font-size:11px;
  font-weight:800;
  box-shadow:0 16px 36px rgba(43,43,43,.20);
  transition:.25s ease;
}
.header-cart:hover{background:var(--terracotta);border-color:var(--terracotta);color:#fff;transform:translateY(-2px)}
.header-cart span{
  display:inline-grid;
  place-items:center;
  min-width:22px;
  height:22px;
  border-radius:999px;
  background:#fff;
  color:#2B2B2B;
  font-size:11px;
  font-weight:700;
}

/* HERO - image sans texte */
.instoria-hero{
  position:relative;
  min-height:100vh;
  display:flex;
  align-items:center;
  overflow:hidden;
  background:var(--ivory);
  padding-top:120px;
}

.instoria-hero::before{
  content:"";
  position:absolute;
  inset:0;
  background-image:url('assets/images/hero-instoria.png');
  background-size:cover;
  background-position:center center;
  background-repeat:no-repeat;
  z-index:0;
}

.instoria-hero::after{
  content:"";
  position:absolute;
  inset:0;
  background:linear-gradient(90deg,rgba(250,247,242,.32) 0%,rgba(250,247,242,.10) 46%,rgba(250,247,242,0) 100%);
  z-index:1;
  pointer-events:none;
}

.hero-overlay-content{
  position:relative;
  z-index:2;
  width:min(1280px,calc(100% - 64px));
  margin:0 auto;
}

.hero-content{width:min(520px,45vw)}
.kicker{
  color:var(--terracotta);
  text-transform:uppercase;
  letter-spacing:.34em;
  font-size:14px;
  margin:0 0 24px;
  font-weight:600;
}
.instoria-hero h1{
  font-size:clamp(54px,5.6vw,92px);
  line-height:.96;
  color:#584f48;
  margin:0 0 28px;
  letter-spacing:-.03em;
}
.hero-description{color:#5E5148;font-size:20px;line-height:1.7;max-width:500px;margin:0}
.hero-actions{display:flex;gap:18px;flex-wrap:wrap;margin-top:38px}

/* BUTTONS */
.instoria-btn,.instoria-btn-outline,
.button,button,input[type=submit],.wp-block-button__link,
.woocommerce a.button,.woocommerce button.button,.woocommerce input.button{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height:54px;
  padding:16px 30px;
  border-radius:999px;
  text-transform:uppercase;
  letter-spacing:.14em;
  font-size:12px;
  font-weight:700;
  transition:.25s ease;
  cursor:pointer;
}

.instoria-btn,.button,button,input[type=submit],.wp-block-button__link,
.woocommerce a.button,.woocommerce button.button,.woocommerce input.button{
  background:var(--terracotta);
  border:1px solid var(--terracotta);
  color:#fff;
}

.instoria-btn:hover,.button:hover,button:hover,input[type=submit]:hover,.wp-block-button__link:hover,
.woocommerce a.button:hover,.woocommerce button.button:hover,.woocommerce input.button:hover{
  background:var(--terracotta-dark);
  border-color:var(--terracotta-dark);
  color:#fff;
  transform:translateY(-2px);
}

.instoria-btn-outline{
  background:rgba(250,247,242,.88);
  color:var(--terracotta-dark);
  border:1px solid var(--terracotta);
  box-shadow:0 12px 30px rgba(94,70,52,.08);
}
.instoria-btn-outline:hover{background:var(--terracotta);color:#fff}

/* SECTIONS */
.instoria-section{padding:86px 0}
.collections-section{padding:120px 0;background:var(--ivory)}
.section-heading{margin-bottom:56px}
.section-heading.center{text-align:center}
.section-kicker{
  color:var(--terracotta);
  text-transform:uppercase;
  letter-spacing:.28em;
  font-size:13px;
  font-weight:700;
  margin:0 0 18px;
}
.section-title{
  font-size:clamp(34px,4vw,62px);
  line-height:1.08;
  color:var(--charcoal);
  max-width:820px;
  margin:0 auto;
}
.category-grid{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:28px;
}
.instoria-card{
  background:#fff;
  border-radius:32px;
  overflow:hidden;
  box-shadow:0 18px 60px rgba(94,70,52,.08);
  transition:.3s ease;
}
.instoria-card:hover{transform:translateY(-6px);box-shadow:0 28px 80px rgba(94,70,52,.14)}
.card-visual{
  aspect-ratio:1/1;
  background:linear-gradient(135deg,var(--soft-ivory),var(--sand));
  background-size:cover;
  background-position:center;
}
.card-content{padding:28px}
.instoria-card h3{font-size:34px;margin:0 0 12px;color:var(--charcoal)}
.instoria-card p{color:var(--brown);line-height:1.8;font-size:15px;margin:0}

.brand-story-section{
  padding:140px 0;
  background:#fff;
}

.brand-story-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:90px;
  align-items:center;
}

.brand-story-visual{

  aspect-ratio: 4 / 5;

  border-radius:36px;

  overflow:hidden;

  padding:40px;

  background-color:#F5EFE7;

  background-image:
  url("https://atelierinstoria.fr/wp-content/uploads/2026/05/infini-apropos.png");

  background-size:contain;

  background-position:center;

  background-repeat:no-repeat;

  box-shadow:
  0 24px 80px rgba(94,70,52,.10);
}


.brand-story-content h2{
  font-size:clamp(42px,5vw,76px);
  line-height:1.02;
  color:var(--charcoal);
  margin:0 0 28px;
}
.brand-story-content p{color:var(--brown);font-size:18px;line-height:1.9;margin:0 0 36px;max-width:520px}

.site-footer{border-top:1px solid var(--sand);padding:40px 0;color:var(--brown);background:var(--ivory)}
.footer-inner{display:flex;justify-content:space-between;gap:24px;flex-wrap:wrap}

/* WooCommerce */
.woocommerce-main{padding:70px 0 90px;background:var(--ivory)}
.woocommerce ul.products{display:grid;grid-template-columns:repeat(3,1fr);gap:28px}
.woocommerce ul.products:before,.woocommerce ul.products:after{display:none}
.woocommerce ul.products li.product{
  width:auto!important;
  margin:0!important;
  background:#fff;
  border-radius:28px;
  padding:24px;
  box-shadow:0 18px 50px rgba(94,70,52,.08);
  transition:.25s;
}
.woocommerce ul.products li.product img{border-radius:22px;margin-bottom:18px}
.woocommerce ul.products li.product .woocommerce-loop-product__title{
  font-family:'Cormorant Garamond',Georgia,serif;
  font-size:26px;
  color:var(--charcoal);
}
.woocommerce div.product{
  background:#fff;
  border:1px solid rgba(216,195,165,.45);
  border-radius:34px;
  padding:34px;
  box-shadow:0 24px 70px rgba(94,70,52,.08);
}
.woocommerce div.product:after{content:"";display:block;clear:both}
.woocommerce div.product div.images{width:48%}
.woocommerce div.product div.summary{width:46%;padding-top:10px}
.woocommerce div.product div.images img{border-radius:28px;background:var(--soft-ivory);box-shadow:none}
.woocommerce div.product .product_title{font-size:clamp(38px,4.5vw,62px);line-height:1.05;color:var(--charcoal);margin-bottom:16px}
.woocommerce div.product p.price,.woocommerce div.product span.price,.woocommerce ul.products li.product .price{
  color:var(--terracotta);
  font-size:24px;
  font-weight:700;
}
.woocommerce-product-details__short-description{color:var(--brown);font-size:16px;line-height:1.8;margin-bottom:26px}
.woocommerce div.product form.cart{display:flex;gap:14px;flex-wrap:wrap;align-items:center;margin-top:24px}
.woocommerce .quantity .qty{
  min-height:52px;
  width:86px;
  border:1px solid var(--sand);
  border-radius:999px;
  background:var(--ivory);
  color:var(--charcoal);
  padding:0 14px;
}
.woocommerce div.product form.cart .button{border-radius:999px;min-height:52px}
.woocommerce table.shop_table{background:#fff;border-radius:22px;overflow:hidden;border:1px solid var(--sand)}
.page-content,.entry-content{padding:50px 0}

@media(max-width:1100px){
  .hero-content{width:min(510px,54vw)}
  .instoria-hero::before{background-position:56% center}
  .category-grid{grid-template-columns:1fr 1fr}
  .brand-story-grid{grid-template-columns:1fr;gap:60px}
}

@media(max-width:980px){
  .site-header,.home .site-header,.front-page .site-header{
    position:relative;
    background:rgba(250,247,242,.98);
    border-bottom:1px solid var(--sand);
  }
  .header-inner{min-height:auto;padding:14px 0;align-items:flex-start;flex-wrap:wrap}
  .instoria-logo{height:108px!important;max-height:108px!important}
  .main-navigation{justify-content:flex-start;order:3;width:100%;padding-top:0}
  .main-navigation ul{gap:14px;flex-wrap:wrap}
  .header-actions{margin-left:auto;padding-top:0}
  .instoria-hero{min-height:780px;align-items:flex-start;padding-top:80px}
  .instoria-hero::before{background-position:62% center}
  .hero-overlay-content{width:min(100% - 48px,1180px);padding-top:40px}
  .hero-content{width:min(520px,70vw)}
  .woocommerce ul.products{grid-template-columns:1fr 1fr}
  .woocommerce div.product{padding:22px}
  .woocommerce div.product div.images,.woocommerce div.product div.summary{width:100%;float:none}
  .woocommerce div.product div.summary{padding-top:28px}
}

@media(max-width:640px){
  .container{width:calc(100% - 36px)}
  .header-inner,.footer-inner{align-items:flex-start;flex-direction:column}
  .instoria-logo{height:92px!important;max-height:92px!important}
  .header-actions{margin-left:0;width:100%;display:grid;grid-template-columns:1fr 1fr}
  .quote-link,.header-cart{width:100%;padding-left:12px;padding-right:12px}
  .main-navigation ul{flex-direction:column;align-items:flex-start}
  .instoria-hero{min-height:760px;padding-top:40px;align-items:flex-start}
  .instoria-hero::before{background-size:cover;background-position:67% bottom;opacity:.92}
  .instoria-hero::after{background:linear-gradient(180deg,rgba(250,247,242,.86) 0%,rgba(250,247,242,.58) 42%,rgba(250,247,242,.08) 100%)}
  .hero-overlay-content{width:calc(100% - 36px);padding-top:34px}
  .hero-content{width:100%}
  .kicker{font-size:12px;letter-spacing:.24em;margin-bottom:18px}
  .instoria-hero h1{font-size:clamp(44px,15vw,62px);max-width:350px}
  .hero-description{font-size:16px;max-width:360px}
  .hero-actions{flex-direction:column;align-items:flex-start;margin-top:26px}
  .instoria-btn,.instoria-btn-outline{width:100%;max-width:340px}
  .collections-section,.brand-story-section{padding:80px 0}
  .category-grid,.woocommerce ul.products{grid-template-columns:1fr}
  .section-title{font-size:42px}
  .brand-story-content h2{font-size:48px}
  .brand-story-visual{min-height:420px}
  .woocommerce-main{padding:38px 0 60px}
  .woocommerce div.product{border-radius:24px;padding:18px}
  .woocommerce div.product .product_title{font-size:38px}
}

.instoria-form-grid{
    display:grid;
    grid-template-columns:1fr 1fr;
    gap:24px;
}

.instoria-form-field{
    display:flex;
    flex-direction:column;
}

.instoria-form-field.full{
    grid-column:1/-1;
}

.instoria-form-field label{
    margin-bottom:10px;
    font-size:13px;
    text-transform:uppercase;
    letter-spacing:.12em;
    color:#5E4634;
    font-weight:600;
}

.instoria-form-field input,
.instoria-form-field select,
.instoria-form-field textarea{
    width:100%;
    border:1px solid #D8C3A5;
    background:#FAF7F2;
    border-radius:18px;
    padding:16px 18px;
    font-size:15px;
    color:#2B2B2B;
    transition:.25s ease;
}

.instoria-form-field textarea{
    min-height:180px;
    resize:vertical;
}

.instoria-form-field input:focus,
.instoria-form-field select:focus,
.instoria-form-field textarea:focus{
    outline:none;
    border-color:#C98C73;
    box-shadow:0 0 0 4px rgba(201,140,115,.12);
}

.instoria-form-field .wpcf7-submit{
    background:#C98C73;
    color:#fff;
    border:none;
    border-radius:999px;
    min-height:54px;
	max-width: 300px;
    padding:16px 32px;
    text-transform:uppercase;
    letter-spacing:.14em;
    font-size:12px;
    font-weight:700;
    cursor:pointer;
    transition:.25s ease;
}

.instoria-form-field .wpcf7-submit:hover{
    background:#B87560;
    transform:translateY(-2px);
}

.consent{
    font-size:14px;
    color:#5E4634;
}

@media(max-width:768px){

    .instoria-form-grid{
        grid-template-columns:1fr;
    }
}

/* =========================
   WOOCOMMERCE VARIATIONS
   Style Instoria premium
========================= */

.woocommerce div.product form.cart .variations {
    width: 100%;
    margin: 0 0 26px;
    border-collapse: separate;
    border-spacing: 0 18px;
}

.woocommerce div.product form.cart .variations tbody,
.woocommerce div.product form.cart .variations tr,
.woocommerce div.product form.cart .variations td,
.woocommerce div.product form.cart .variations th {
    display: block;
    width: 100%;
    padding: 0;
    border: 0;
}

.woocommerce div.product form.cart .variations label {
    display: block;
    margin-bottom: 10px;
    font-size: 13px;
    text-transform: uppercase;
    letter-spacing: .12em;
    color: #5E4634;
    font-weight: 600;
}

.woocommerce div.product form.cart .variations select {
    width: 100%;
    min-height: 54px;
    border: 1px solid #D8C3A5;
    background: #FAF7F2;
    border-radius: 18px;
    padding: 0 18px;
    font-size: 15px;
    color: #2B2B2B;
    transition: .25s ease;
}

.woocommerce div.product form.cart .variations select:focus {
    outline: none;
    border-color: #C98C73;
    box-shadow: 0 0 0 4px rgba(201,140,115,.12);
}

.woocommerce div.product form.cart .variations .reset_variations {
    display: inline-flex !important;
    margin-top: 12px;
    font-size: 12px;
    color: #B87560;
    text-transform: uppercase;
    letter-spacing: .12em;
    font-weight: 700;
}

.woocommerce div.product .single_variation_wrap {
    width: 100%;
}

.woocommerce div.product .single_variation {
    margin: 10px 0 18px;
    color: #5E4634;
    font-size: 15px;
}

.woocommerce div.product .woocommerce-variation-price {
    margin-bottom: 16px;
}

.woocommerce div.product .woocommerce-variation-price .price {
    color: #C98C73;
    font-size: 24px;
    font-weight: 700;
}

.woocommerce div.product .woocommerce-variation-availability {
    color: #5E4634;
    font-size: 14px;
}

.woocommerce div.product form.cart .woocommerce-variation-add-to-cart {
    display: flex;
    gap: 14px;
    flex-wrap: wrap;
    align-items: center;
}

.woocommerce div.product form.cart .quantity .qty {
    min-height: 54px;
    border: 1px solid #D8C3A5;
    background: #FAF7F2;
    border-radius: 999px;
    color: #2B2B2B;
}

.woocommerce div.product form.cart .single_add_to_cart_button {
    min-height: 54px;
    border-radius: 999px;
    background: #C98C73;
    border-color: #C98C73;
    color: #fff;
}

.woocommerce div.product form.cart .single_add_to_cart_button:hover {
    background: #B87560;
    border-color: #B87560;
}

/* Mobile */

@media(max-width: 640px) {
    .woocommerce div.product form.cart .woocommerce-variation-add-to-cart {
        flex-direction: column;
        align-items: stretch;
    }

    .woocommerce div.product form.cart .quantity .qty,
    .woocommerce div.product form.cart .single_add_to_cart_button {
        width: 100%;
    }
}

/* =========================
   HEADER SEARCH
========================= */
.header-search{flex:0 1 260px;padding-top:18px}
.header-search form,.header-search .woocommerce-product-search,.header-search .search-form{position:relative;display:flex;align-items:center;width:100%}
.header-search input[type="search"],.header-search .search-field{width:100%;min-height:48px;border:1px solid rgba(216,195,165,.85);border-radius:999px;background:rgba(250,247,242,.88);padding:0 48px 0 18px;font-size:13px;color:var(--charcoal);outline:none;box-shadow:0 12px 30px rgba(94,70,52,.06);transition:.25s ease}
.header-search input[type="search"]:focus,.header-search .search-field:focus{border-color:var(--terracotta);box-shadow:0 0 0 4px rgba(201,140,115,.12);background:#fff}
.header-search button,.header-search input[type="submit"]{position:absolute;right:5px;top:50%;transform:translateY(-50%);width:38px;height:38px;min-height:38px;padding:0;border-radius:999px;background:var(--terracotta);border:1px solid var(--terracotta);color:#fff;font-size:0;box-shadow:none}
.header-search button::before,.header-search input[type="submit"]::before{content:"⌕";font-size:18px;line-height:1}
.header-search button:hover,.header-search input[type="submit"]:hover{background:var(--terracotta-dark);border-color:var(--terracotta-dark)}

/* =========================
   PRODUCT GALLERY PREMIUM
========================= */
.woocommerce div.product div.images.instoria-product-gallery,.instoria-product-gallery{width:48%;float:left;margin-bottom:0}
.instoria-product-swiper{width:100%;border-radius:34px;overflow:hidden;background:var(--soft-ivory);box-shadow:0 24px 70px rgba(94,70,52,.08)}
.instoria-product-swiper .swiper-slide{background:var(--soft-ivory)}
.instoria-product-swiper img{width:100%;height:720px;object-fit:cover;display:block;border-radius:0!important}
.instoria-product-swiper .swiper-button-prev,.instoria-product-swiper .swiper-button-next{width:48px;height:48px;border-radius:999px;background:rgba(255,255,255,.92);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);box-shadow:0 14px 34px rgba(94,70,52,.14);color:var(--brown)}
.instoria-product-swiper .swiper-button-prev::after,.instoria-product-swiper .swiper-button-next::after{font-size:16px;font-weight:800}
.instoria-product-swiper .swiper-pagination-bullet{width:9px;height:9px;background:var(--sand);opacity:1}
.instoria-product-swiper .swiper-pagination-bullet-active{background:var(--terracotta)}
.instoria-product-thumbs{margin-top:18px;overflow:hidden}
.instoria-product-thumbs .swiper-slide{border-radius:18px;overflow:hidden;cursor:pointer;opacity:.55;background:var(--soft-ivory);border:2px solid transparent;transition:.25s ease}
.instoria-product-thumbs .swiper-slide-thumb-active{opacity:1;border-color:var(--terracotta)}
.instoria-product-thumbs img{width:100%;height:110px;object-fit:cover;display:block}
.woocommerce div.product div.summary{width:46%;float:right}

/* =========================
   RELATED / UPSELLS PREMIUM
========================= */
.related.products,.upsells.products{clear:both;margin-top:90px;padding-top:70px;border-top:1px solid rgba(216,195,165,.45)}
.related.products>h2,.upsells.products>h2{font-family:'Cormorant Garamond',Georgia,serif;font-size:clamp(36px,4vw,58px);font-weight:500;color:var(--charcoal);text-align:center;margin:0 0 42px}
.woocommerce div.product .related ul.products,.woocommerce div.product .upsells ul.products{display:grid;grid-template-columns:repeat(4,1fr);gap:28px}

@media(max-width:1200px){.header-search{flex-basis:220px}}
@media(max-width:980px){.header-search{order:4;width:100%;flex:1 1 100%;padding-top:0}.woocommerce div.product div.images.instoria-product-gallery,.instoria-product-gallery,.woocommerce div.product div.summary{width:100%;float:none}.woocommerce div.product div.summary{padding-top:30px}.instoria-product-swiper img{height:620px}.woocommerce div.product .related ul.products,.woocommerce div.product .upsells ul.products{grid-template-columns:repeat(2,1fr)}}
@media(max-width:640px){.header-search{width:100%}.instoria-product-swiper{border-radius:24px}.instoria-product-swiper img{height:460px}.instoria-product-thumbs img{height:82px}.woocommerce div.product .related ul.products,.woocommerce div.product .upsells ul.products{grid-template-columns:1fr}}


/* =========================
   INSTORIA UPSELLS PREMIUM
========================= */

.instoria-upsells-section{
    clear:both;
    margin-top:90px;
    padding-top:70px;
    border-top:1px solid rgba(216,195,165,.45);
}

.instoria-upsells-section > h2{
    font-family:'Cormorant Garamond',Georgia,serif;
    font-size:clamp(36px,4vw,58px);
    font-weight:500;
    color:var(--charcoal);
    text-align:center;
    margin:0 0 16px;
}

.instoria-upsells-intro{
    max-width:680px;
    margin:0 auto 44px;
    text-align:center;
    color:var(--brown);
    font-size:16px;
    line-height:1.8;
}

.instoria-upsells-section ul.products{
    display:grid!important;
    grid-template-columns:repeat(4,1fr)!important;
    gap:28px!important;
}

@media(max-width:980px){
    .instoria-upsells-section ul.products{
        grid-template-columns:repeat(2,1fr)!important;
    }
}

@media(max-width:640px){
    .instoria-upsells-section{
        margin-top:60px;
        padding-top:50px;
    }

    .instoria-upsells-section ul.products{
        grid-template-columns:1fr!important;
    }
}


/* =========================
   MENU CATÉGORIES DYNAMIQUE
========================= */

.main-navigation li {
    position: relative;
}

.main-navigation .sub-menu {
    position: absolute;
    top: 100%;
    left: 50%;
    transform: translateX(-50%) translateY(14px);

    min-width: 250px;

    background: rgba(250,247,242,.96);
    backdrop-filter: blur(18px);
    -webkit-backdrop-filter: blur(18px);

    border: 1px solid rgba(216,195,165,.45);
    border-radius: 22px;

    padding: 14px;

    box-shadow: 0 24px 70px rgba(94,70,52,.14);

    opacity: 0;
    visibility: hidden;
    pointer-events: none;

    transition: .25s ease;

    z-index: 9999;
}

.main-navigation li:hover > .sub-menu,
.main-navigation li:focus-within > .sub-menu {
    opacity: 1;
    visibility: visible;
    pointer-events: auto;
    transform: translateX(-50%) translateY(0);
}

.main-navigation .sub-menu li {
    width: 100%;
}

.main-navigation .sub-menu a {
    display: block;

    padding: 12px 16px;

    border-radius: 14px;

    font-size: 12px;
    letter-spacing: .12em;

    color: #5E4634;
    text-transform: uppercase;
    white-space: nowrap;
}

.main-navigation .sub-menu a:hover {
    background: #F5EFE7;
    color: #C98C73;
}

.main-navigation .sub-menu .sub-menu {
    top: 0;
    left: 100%;
    transform: translateX(14px);
}

.main-navigation .sub-menu li:hover > .sub-menu,
.main-navigation .sub-menu li:focus-within > .sub-menu {
    transform: translateX(0);
}

/* Ajustement header avec recherche + menu dynamique */
.header-search {
    flex: 0 1 250px;
}

@media(max-width: 1180px) {
    .main-navigation ul {
        gap: 18px;
    }

    .header-search {
        flex-basis: 210px;
    }
}

@media(max-width: 980px) {
    .main-navigation .sub-menu {
        position: static;
        transform: none;
        opacity: 1;
        visibility: visible;
        pointer-events: auto;
        box-shadow: none;
        border: none;
        background: transparent;
        backdrop-filter: none;
        -webkit-backdrop-filter: none;
        padding: 8px 0 8px 18px;
    }

    .main-navigation .sub-menu .sub-menu {
        transform: none;
        padding-left: 18px;
    }

    .main-navigation .sub-menu a {
        white-space: normal;
        padding: 8px 0;
    }
}
/* Masquer l'UGS des pages produits */
.product .sku_wrapper {
      display: none;
}
