/* ================================================================
   LA FRAISE TOUCH — Design System
   DA : crème #fbfaf8 · texte #1b1714 · serif Times · sans système
   ================================================================ */

/* ================================================================
   1. VARIABLES
   ================================================================ */
:root{
  --bg: #fbfaf8;
  --text: #1b1714;
  --muted: rgba(27,23,20,0.68);
  --muted-light: rgba(27,23,20,0.45);
  --line: rgba(27,23,20,0.10);

  --serif: "Times New Roman", Times, serif;
  --sans: -apple-system, BlinkMacSystemFont, "Helvetica Neue", Helvetica, Arial, sans-serif;

  --radius: 18px;
  --shadow-soft: 0 18px 60px rgba(0,0,0,0.06);
  --shadow-card: 0 30px 90px rgba(0,0,0,0.08);

  --max-w: 1180px;
  --drawer-w: min(86vw, 420px);

  --ok: #1b7a3a;
  --err: #b42318;

  /* Refonte tunnel : tokens additionnels */
  --gold: #c7a25a;
  --gold-strong: #b48d44;
  --success: #1a5c3a;
  --danger: #b42318;
  --shadow-cta: 0 18px 50px rgba(199,162,90,0.35);
}

/* ================================================================
   2. RESET
   ================================================================ */
*,
*::before,
*::after{ box-sizing:border-box; }

html, body{ height:100%; }

body{
  margin:0;
  background:var(--bg);
  color:var(--text);
  font-family:var(--sans);
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  overflow-x:hidden;
  line-height:1.6;
}

a{ color:inherit; text-decoration:none; }

/* ================================================================
   3. HEADER
   ================================================================ */
.header{
  position:fixed;
  top:0; left:0; right:0;
  z-index:100;
  padding:16px 22px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  background:rgba(251,250,248,0.88);
  backdrop-filter:blur(10px);
  -webkit-backdrop-filter:blur(10px);
  border-bottom:1px solid rgba(27,23,20,0.08);
}
.header__left,
.header__right{
  display:flex;
  align-items:center;
  gap:16px;
}

/* ================================================================
   4. BRAND
   ================================================================ */
.brand{
  display:flex;
  align-items:center;
  justify-content:center;
  text-align:center;
  line-height:1;
  letter-spacing:0.14em;
  text-transform:uppercase;
  font-size:12px;
  font-weight:900;
  user-select:none;
}

/* ================================================================
   5. ICON BUTTON (circular)
   ================================================================ */
.icon-btn{
  width:44px;
  height:44px;
  display:flex;
  align-items:center;
  justify-content:center;
  border-radius:50%;
  border:1px solid rgba(27,23,20,0.12);
  background:transparent;
  cursor:pointer;
  position:relative;
  transition:transform .2s ease, border-color .2s ease, background .2s ease;
  flex-shrink:0;
}
.icon-btn:hover{
  transform:translateY(-2px);
  border-color:rgba(27,23,20,0.25);
  background:rgba(27,23,20,0.02);
}
.icon-btn svg{
  width:18px;
  height:18px;
  stroke:var(--text);
  fill:none;
  stroke-width:1.7;
  stroke-linecap:round;
  stroke-linejoin:round;
  opacity:0.9;
}

/* ================================================================
   6. CART COUNT BADGE
   ================================================================ */
.cart-count{
  position:absolute;
  top:-4px; right:-4px;
  width:18px; height:18px;
  border-radius:50%;
  background:var(--text);
  color:#fff;
  font-size:10px;
  font-weight:900;
  display:flex;
  align-items:center;
  justify-content:center;
  letter-spacing:0;
  line-height:1;
}

/* ================================================================
   7. DRAWER (side menu)
   ================================================================ */
.drawer-overlay{
  position:fixed;
  inset:0;
  background:rgba(0,0,0,0.35);
  opacity:0;
  pointer-events:none;
  transition:opacity .25s ease;
  z-index:200;
}
.drawer{
  position:fixed;
  top:0; left:0;
  height:100%;
  width:var(--drawer-w);
  background:rgba(251,250,248,0.98);
  backdrop-filter:blur(10px);
  -webkit-backdrop-filter:blur(10px);
  border-right:1px solid var(--line);
  transform:translateX(-102%);
  transition:transform .28s cubic-bezier(.2,.9,.2,1);
  z-index:210;
  display:flex;
  flex-direction:column;
  padding:22px;
}
.drawer__top{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:14px;
  padding-bottom:18px;
  border-bottom:1px solid var(--line);
  margin-bottom:18px;
}
.drawer__brand{
  font-size:11px;
  letter-spacing:0.26em;
  text-transform:uppercase;
  font-weight:900;
}
.drawer__close{
  width:44px; height:44px;
  border-radius:50%;
  border:1px solid rgba(27,23,20,0.12);
  background:transparent;
  cursor:pointer;
  display:flex;
  align-items:center;
  justify-content:center;
  transition:transform .2s ease, border-color .2s ease, background .2s ease;
}
.drawer__close:hover{
  transform:translateY(-2px);
  border-color:rgba(27,23,20,0.25);
  background:rgba(27,23,20,0.02);
}
.drawer__close svg{
  width:18px; height:18px;
  stroke:var(--text); fill:none;
  stroke-width:1.7; stroke-linecap:round; stroke-linejoin:round;
  opacity:0.9;
}
.drawer__nav{
  display:flex;
  flex-direction:column;
  gap:6px;
  padding:10px 0;
}
.drawer__link{
  padding:14px 10px;
  border-radius:12px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:14px;
  transition:background .2s ease;
}
.drawer__link:hover{
  background:rgba(27,23,20,0.04);
}
.drawer__link span{
  font-size:12px;
  letter-spacing:0.22em;
  text-transform:uppercase;
  font-weight:900;
}
.drawer__link i{
  font-style:normal;
  font-size:12px;
  opacity:0.7;
}
.drawer__section-title{
  margin-top:18px;
  font-size:10px;
  letter-spacing:0.22em;
  text-transform:uppercase;
  color:var(--muted-light);
  font-weight:900;
}
.drawer__footer{
  margin-top:auto;
  padding-top:18px;
  border-top:1px solid var(--line);
  font-size:11px;
  letter-spacing:0.18em;
  text-transform:uppercase;
  color:var(--muted-light);
  line-height:1.7;
}
body.drawer-open{ overflow:hidden; touch-action:none; }
body.drawer-open .drawer-overlay{ opacity:1; pointer-events:auto; }
body.drawer-open .drawer{ transform:translateX(0); }

/* ================================================================
   8. FOOTER
   ================================================================ */
.footer{
  border-top:1px solid var(--line);
}
.footer__bottom{
  padding:28px 22px 60px;
  text-align:center;
  color:var(--muted-light);
  font-size:11px;
  letter-spacing:0.18em;
  text-transform:uppercase;
  line-height:1.7;
}
.footer__pro{
  padding:48px 22px;
  background:rgba(199,162,90,0.06);
  border-bottom:1px solid var(--line);
}
.footer__pro-inner{
  max-width:var(--max-w);
  margin:0 auto;
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:40px;
  align-items:start;
}
.footer__pro-title{
  margin:0 0 12px;
  font-size:22px;
  text-transform:uppercase;
  letter-spacing:0.06em;
}
.footer__pro-text p{
  margin:0;
  color:var(--muted);
  font-size:13px;
  line-height:1.8;
  max-width:440px;
}
.footer__pro-form{ max-width:480px; }

@media(max-width:820px){
  .footer__pro-inner{ grid-template-columns:1fr; gap:24px; }
}

/* ================================================================
   9. TYPOGRAPHY HELPERS
   ================================================================ */
.muted{ color:var(--muted); }

.kicker{
  font-size:11px;
  letter-spacing:0.28em;
  text-transform:uppercase;
  color:rgba(27,23,20,0.58);
  font-weight:900;
}

/* ================================================================
   10. TRUST LINE (dots)
   ================================================================ */
.trust-line{
  display:flex;
  flex-wrap:wrap;
  gap:12px 18px;
  align-items:center;
  margin-top:10px;
  color:rgba(27,23,20,0.55);
  font-size:12px;
  letter-spacing:0.08em;
  text-transform:uppercase;
}
.trust-line span{
  display:inline-flex;
  align-items:center;
  gap:8px;
}
.dot{
  width:5px; height:5px;
  border-radius:50%;
  background:rgba(27,23,20,0.30);
  display:inline-block;
  flex-shrink:0;
}

/* ================================================================
   11. INTRO / PAGE HEADER
   ================================================================ */
.intro{
  padding:120px 22px 46px;
}
.intro__inner{
  max-width:var(--max-w);
  margin:0 auto;
  padding-bottom:36px;
  border-bottom:1px solid var(--line);
}
.intro__kicker{
  font-size:11px;
  letter-spacing:0.28em;
  text-transform:uppercase;
  color:rgba(27,23,20,0.58);
  font-weight:900;
  margin-bottom:8px;
}
h1.intro__title{
  margin:0;
  font-family:var(--serif);
  font-weight:400;
  letter-spacing:0.07em;
  text-transform:uppercase;
  font-size:clamp(30px, 5vw, 58px);
  line-height:1.02;
  max-width:920px;
}
.intro__desc{
  max-width:720px;
  font-size:15px;
  line-height:1.9;
  color:var(--muted);
  margin:0;
}
.intro__actions{
  display:flex;
  align-items:center;
  gap:18px;
  flex-wrap:wrap;
  margin-top:16px;
}

/* Hero boutique (particuliers.php) : texte + visuel */
.intro--shop .intro__inner--shop{
  display:grid;
  grid-template-columns:1.05fr 0.95fr;
  gap:44px;
  align-items:center;
}
.intro__visual{
  height:380px;
  border-radius:var(--radius);
  background-size:cover;
  background-position:center;
  background-repeat:no-repeat;
  box-shadow:var(--shadow-soft);
}
@media(max-width:900px){
  .intro--shop .intro__inner--shop{ grid-template-columns:1fr; gap:28px; }
  .intro__visual{ height:280px; order:-1; }
}
@media(max-width:520px){
  .intro__visual{ height:220px; }
}

/* ================================================================
   12. LINK CTA (text + line)
   ================================================================ */
.link-cta{
  display:inline-flex;
  align-items:center;
  gap:14px;
  font-size:12px;
  text-transform:uppercase;
  letter-spacing:0.22em;
  font-weight:900;
  padding:0;
  border:none;
  background:none;
  cursor:pointer;
  white-space:nowrap;
  color:var(--text);
}
.link-cta::after{
  content:"";
  width:56px; height:1px;
  background:var(--text);
  opacity:0.65;
  transition:width .25s ease;
  flex-shrink:0;
}
.link-cta:hover::after{ width:92px; }

/* ================================================================
   13. SECTION
   ================================================================ */
.section{ padding:32px 22px 95px; }
.section__inner{ max-width:var(--max-w); margin:0 auto; }

/* ================================================================
   14. TABS NAV
   ================================================================ */
.tabs-nav{
  display:flex;
  gap:24px;
  align-items:center;
  padding:0 0 18px;
  border-bottom:1px solid var(--line);
  margin-bottom:26px;
}
.tab-btn{
  background:none;
  border:none;
  cursor:pointer;
  font-size:11px;
  letter-spacing:0.28em;
  text-transform:uppercase;
  font-weight:900;
  color:rgba(27,23,20,0.48);
  padding:0;
  position:relative;
  white-space:nowrap;
}
.tab-btn.active{ color:rgba(27,23,20,0.92); }
.tab-btn.active::after{
  content:"";
  position:absolute;
  left:0; bottom:-10px;
  width:100%; height:1px;
  background:var(--text);
  opacity:0.65;
}
.tab-content{ display:none; }
.tab-content.active{ display:block; }

/* ================================================================
   15. PRODUCT GRID & CARD
   ================================================================ */
.products-grid{
  display:grid;
  grid-template-columns:repeat(3, minmax(0, 1fr));
  gap:28px;
}

.product-card{
  border:1px solid rgba(27,23,20,0.12);
  border-radius:var(--radius);
  overflow:hidden;
  background:#fff;
  box-shadow:var(--shadow-soft);
  transition:transform .25s ease, box-shadow .25s ease;
  display:flex;
  flex-direction:column;
}
.product-card:hover{
  transform:translateY(-6px);
  box-shadow:var(--shadow-card);
}

.product-packshot{
  height:360px;
  background:var(--bg);
  display:flex;
  align-items:center;
  justify-content:center;
  overflow:hidden;
  border-bottom:1px solid rgba(27,23,20,0.10);
  cursor:pointer;
  position:relative;
}
.product-media{
  width:100%; height:100%;
  background-repeat:no-repeat;
  background-position:center;
  background-size:contain;
  transform:scale(0.92);
  filter:drop-shadow(0 22px 35px rgba(0,0,0,0.18));
}

.product-thumbs{
  display:flex;
  gap:8px;
  padding:14px 16px 0;
  justify-content:center;
  background:#fff;
}
.thumb{
  width:42px; height:42px;
  border-radius:12px;
  border:1px solid rgba(27,23,20,0.12);
  background-size:cover;
  background-position:center;
  cursor:pointer;
  transition:transform .2s ease, border-color .2s ease;
}
.thumb:hover{
  transform:translateY(-2px);
  border-color:rgba(27,23,20,0.24);
}

.product-body{
  padding:22px 22px 26px;
  display:flex;
  flex-direction:column;
  flex:1;
}
.product-top{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:12px;
  margin-bottom:10px;
}
.product-title{
  margin:0;
  font-family:var(--serif);
  font-weight:400;
  text-transform:uppercase;
  letter-spacing:0.10em;
  font-size:18px;
  line-height:1.2;
  max-width:18ch;
}
.product-price{
  font-size:14px;
  font-weight:900;
  letter-spacing:0.02em;
  white-space:nowrap;
  color:rgba(27,23,20,0.90);
}
.product-actions{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
  align-items:center;
  margin-bottom:18px;
}

/* ================================================================
   16. BUTTONS
   ================================================================ */
.btn-outline{
  border:1px solid rgba(27,23,20,0.12);
  background:transparent;
  padding:10px 14px;
  border-radius:999px;
  font-size:10px;
  font-weight:900;
  letter-spacing:0.22em;
  text-transform:uppercase;
  cursor:pointer;
  color:rgba(27,23,20,0.72);
  transition:transform .2s ease, border-color .2s ease, background .2s ease;
}
.btn-outline:hover{
  transform:translateY(-2px);
  border-color:rgba(27,23,20,0.26);
  background:rgba(27,23,20,0.02);
}

.btn-add{
  margin-top:auto;
  width:100%;
  border:none;
  border-radius:14px;
  height:52px;
  background:var(--text);
  color:#fff;
  font-size:11px;
  font-weight:900;
  text-transform:uppercase;
  letter-spacing:0.22em;
  cursor:pointer;
  box-shadow:var(--shadow-cta);
  transition:transform .2s ease, opacity .2s ease, box-shadow .2s ease;
}
.btn-add:hover{
  transform:translateY(-2px);
  opacity:0.92;
  box-shadow:0 22px 60px rgba(199,162,90,0.45);
}
.btn-add:disabled{
  cursor:not-allowed;
  opacity:0.45;
  box-shadow:none;
  transform:none;
}

.btn-primary{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  border:none;
  border-radius:14px;
  height:52px;
  padding:0 18px;
  background:var(--text);
  color:#fff;
  font-size:10px;
  font-weight:900;
  text-transform:uppercase;
  letter-spacing:0.22em;
  cursor:pointer;
  box-shadow:var(--shadow-cta);
  transition:transform .2s ease, opacity .2s ease, box-shadow .2s ease;
  text-decoration:none;
}
.btn-primary:hover{
  transform:translateY(-2px);
  opacity:0.92;
  box-shadow:0 22px 60px rgba(199,162,90,0.45);
}

/* ================================================================
   17. PRODUCT BADGE (overlay pill)
   ================================================================ */
.prod-badge{
  position:absolute;
  top:14px; left:14px;
  z-index:2;
  font-size:10px;
  font-weight:900;
  letter-spacing:0.12em;
  text-transform:uppercase;
  padding:6px 12px;
  border-radius:999px;
  box-shadow:0 4px 12px rgba(0,0,0,0.10);
  pointer-events:none;
}

/* ================================================================
   18. CART BUTTON STATES & ANIMATION
   ================================================================ */
.cart-btn.has-items{
  border-color:rgba(255,0,80,0.55) !important;
  background:rgba(255,0,80,0.08) !important;
}
.cart-btn.has-items .cart-icon{
  stroke:rgb(255,0,80);
  opacity:1;
}
.cart-btn.has-items .cart-count{
  background:rgb(255,0,80);
  color:#fff;
  box-shadow:0 10px 22px rgba(255,0,80,0.25);
}
@keyframes cartBounce{
  0%  { transform:translateY(0) scale(1); }
  18% { transform:translateY(-6px) scale(1.03); }
  36% { transform:translateY(0) scale(1); }
  52% { transform:translateY(-3px) scale(1.01); }
  70% { transform:translateY(0) scale(1); }
  100%{ transform:translateY(0) scale(1); }
}
.cart-btn.bump{
  animation:cartBounce 520ms cubic-bezier(.2,.9,.2,1);
}

/* ================================================================
   19. MODAL
   ================================================================ */
.modal-overlay{
  position:fixed; inset:0;
  background:rgba(0,0,0,0.45);
  opacity:0; visibility:hidden;
  transition:all .25s ease;
  display:flex;
  align-items:center;
  justify-content:center;
  z-index:999;
  backdrop-filter:blur(4px);
}
.modal-overlay.active{ opacity:1; visibility:visible; }
.modal-card{
  width:min(620px, 90vw);
  background:var(--bg);
  border:1px solid rgba(27,23,20,0.12);
  border-radius:var(--radius);
  box-shadow:0 40px 120px rgba(0,0,0,0.18);
  padding:26px 26px 28px;
  position:relative;
  transform:translateY(14px);
  transition:transform .25s ease;
  max-height:84vh;
  overflow:auto;
}
.modal-overlay.active .modal-card{ transform:translateY(0); }
.modal-close{
  position:absolute;
  top:14px; right:14px;
  width:44px; height:44px;
  border-radius:50%;
  border:1px solid rgba(27,23,20,0.12);
  background:transparent;
  cursor:pointer;
  display:flex;
  align-items:center;
  justify-content:center;
  transition:transform .2s ease, background .2s ease, border-color .2s ease;
}
.modal-close:hover{
  transform:translateY(-2px);
  background:rgba(27,23,20,0.02);
  border-color:rgba(27,23,20,0.25);
}
.modal-close svg{
  width:18px; height:18px;
  stroke:var(--text); fill:none;
  stroke-width:1.7; stroke-linecap:round; stroke-linejoin:round;
}
.modal-title{
  margin:0 0 12px;
  font-family:var(--serif);
  font-weight:400;
  text-transform:uppercase;
  letter-spacing:0.10em;
  font-size:20px;
  line-height:1.2;
  padding-right:56px;
}
.modal-content{
  font-size:14px;
  line-height:1.9;
  color:rgba(27,23,20,0.72);
}

/* ================================================================
   20. STICKY CTA (mobile only)
   ================================================================ */
.sticky-cta{
  display:none;
  position:fixed;
  bottom:0; left:0; right:0;
  z-index:90;
  padding:14px 16px;
  background:rgba(251,250,248,0.96);
  backdrop-filter:blur(10px);
  border-top:1px solid var(--line);
  box-shadow:0 -8px 30px rgba(0,0,0,0.08);
}
.sticky-cta .cta-inner{
  max-width:420px;
  margin:0 auto;
  display:flex;
  gap:10px;
  align-items:center;
}
.sticky-cta .cta-btn{
  flex:1;
  height:50px;
  border:none;
  border-radius:14px;
  background:var(--text);
  color:#fff;
  font-size:11px;
  font-weight:900;
  letter-spacing:0.18em;
  text-transform:uppercase;
  cursor:pointer;
  text-align:center;
  display:flex;
  align-items:center;
  justify-content:center;
  text-decoration:none;
}
.sticky-cta .cta-cart{
  background:none;
  border:1px solid rgba(27,23,20,0.14);
  border-radius:14px;
  height:50px; width:50px;
  flex:0 0 50px;
  display:flex;
  align-items:center;
  justify-content:center;
  cursor:pointer;
  position:relative;
}
.sticky-cta .cta-cart svg{
  width:20px; height:20px;
  stroke:var(--text); fill:none; stroke-width:1.7;
}
.sticky-cta .cta-badge{
  position:absolute; top:-5px; right:-5px;
  width:18px; height:18px; border-radius:50%;
  background:rgb(255,0,80); color:#fff;
  font-size:10px; font-weight:900;
  display:flex; align-items:center; justify-content:center;
}

/* ================================================================
   21. INDEX — INTRO (2-column layout)
   ================================================================ */
.intro--home{
  padding:120px 22px 60px;
  position:relative;
}
.intro--home::before{
  content:"";
  position:absolute; inset:0;
  background:
    radial-gradient(900px 420px at 20% 10%, rgba(214,73,114,0.08), transparent 60%),
    radial-gradient(820px 380px at 80% 15%, rgba(199,162,90,0.10), transparent 62%);
  pointer-events:none;
}
.intro--home > *{ position:relative; z-index:1; }

.intro--home .intro__inner{
  max-width:var(--max-w);
  margin:0 auto;
  display:grid;
  grid-template-columns:1.15fr 0.85fr;
  gap:44px;
  align-items:start;
  padding-bottom:44px;
  border-bottom:1px solid rgba(27,23,20,0.10);
}

/* ================================================================
   22. INDEX — PRODUCT GALLERY (right column)
   ================================================================ */
.product-gallery{
  position:relative;
  border-left:1px solid rgba(27,23,20,0.10);
  padding-left:26px;
}
.gallery-head{
  display:flex;
  align-items:flex-end;
  justify-content:space-between;
  gap:16px;
  margin-bottom:12px;
}
.gallery-head h2{
  margin:0;
  font-size:11px;
  letter-spacing:0.28em;
  text-transform:uppercase;
  font-weight:900;
  color:rgba(27,23,20,0.58);
}
.gallery-nav{
  display:flex;
  gap:12px;
  align-items:center;
}
.gallery-btn{
  border:none; background:none; cursor:pointer;
  padding:8px;
  display:flex; align-items:center; justify-content:center;
  opacity:0.85;
  transition:opacity .2s ease, transform .2s ease;
}
.gallery-btn:hover{ opacity:1; transform:translateY(-1px); }
.gallery-btn svg{
  width:28px; height:12px;
  stroke:rgba(27,23,20,0.9);
  stroke-width:1.6; fill:none;
  stroke-linecap:round; stroke-linejoin:round;
}
.gallery-viewport{ overflow:hidden; position:relative; padding-top:6px; }
.gallery-track{
  display:flex;
  gap:22px;
  transition:transform .55s cubic-bezier(.2,.8,.2,1);
  will-change:transform;
}
.slide{
  flex:0 0 100%; max-width:100%;
  cursor:pointer; user-select:none;
}
.slide-img{
  width:100%; height:330px;
  background-size:cover;
  background-position:center;
  background-repeat:no-repeat;
  display:block;
}
.slide-text{ padding-top:16px; }
.slide-title{
  margin:0 0 6px;
  font-size:14px; font-weight:700;
  letter-spacing:0.02em;
  color:rgba(27,23,20,0.92);
}
.slide-sub{
  margin:0;
  font-size:12px; letter-spacing:0.06em;
  color:rgba(27,23,20,0.55);
  line-height:1.6;
}

/* ================================================================
   23. INDEX — UNIVERSE SECTION
   ================================================================ */
.section--home{ padding:50px 22px 95px; }
.section__inner{ max-width:var(--max-w); margin:0 auto; }
.section__head{
  display:flex;
  align-items:flex-end;
  justify-content:space-between;
  gap:20px;
  margin-bottom:28px;
}
h2.section__title{
  margin:0;
  font-family:var(--serif);
  font-weight:400;
  text-transform:uppercase;
  letter-spacing:0.12em;
  font-size:22px;
}

.grid{
  display:grid;
  grid-template-columns:repeat(2, minmax(0, 1fr));
  gap:28px;
}
.universe{
  border:1px solid rgba(27,23,20,0.12);
  border-radius:var(--radius);
  overflow:hidden;
  background:#fff;
  box-shadow:var(--shadow-soft);
  transition:transform .25s ease, box-shadow .25s ease;
}
.universe:hover{
  transform:translateY(-6px);
  box-shadow:var(--shadow-card);
}
.universe__img{
  height:420px;
  background-size:cover;
  background-position:center;
  background-repeat:no-repeat;
  position:relative;
}
.universe__img::after{
  content:"";
  position:absolute; inset:0;
  background:linear-gradient(to top, rgba(0,0,0,0.30), rgba(0,0,0,0.00) 55%);
}
.universe__label{
  position:absolute;
  left:22px; bottom:18px;
  z-index:2;
  color:#fff;
}
.universe__label .k{
  font-size:11px; letter-spacing:0.22em;
  text-transform:uppercase; font-weight:900;
  opacity:0.95; margin-bottom:10px;
}
.universe__label .t{
  font-family:var(--serif);
  font-weight:400; font-size:30px;
  letter-spacing:0.08em;
  text-transform:uppercase;
  line-height:1.05;
}
.universe__body{
  padding:26px 24px 30px;
}
.universe__action{
  display:inline-flex;
  align-items:center;
  gap:14px;
  font-size:12px;
  text-transform:uppercase;
  letter-spacing:0.22em;
  font-weight:900;
}
.universe__action::after{
  content:"";
  width:52px; height:1px;
  background:var(--text); opacity:0.6;
  transition:width .25s ease;
}
.universe:hover .universe__action::after{ width:84px; }

/* Section en première position : compense le header fixe */
.section--top{ padding-top:120px; }
@media(max-width:520px){
  .section--top{ padding-top:112px; }
}

/* Bannière boutique unique (mise en avant) */
.grid--single{ grid-template-columns:1fr; }
.universe--featured .universe__img{ height:520px; }
.universe--featured .universe__label{
  left:0; right:0; bottom:0;
  width:100%;
  text-align:center;
  padding:0 24px 34px;
}
.universe--featured .universe__label .k{ font-size:12px; }
.universe--featured .universe__label .t{ font-size:42px; }
.universe--featured .universe__body{
  padding:34px 24px 40px;
  text-align:center;
}
.universe--featured .universe__action{
  font-size:13px;
  padding:16px 38px;
  border-radius:999px;
  background:var(--text);
  color:#fff;
  box-shadow:var(--shadow-cta);
}
.universe--featured .universe__action::after{ display:none; }
.universe--featured .universe__action:hover{ opacity:0.9; }
@media(max-width:760px){
  .universe--featured .universe__img{ height:360px; }
  .universe--featured .universe__label .t{ font-size:30px; }
}

/* Présentation / savoir-faire */
.section--brand{ padding:50px 22px 95px; }
.brand-grid{
  display:grid;
  grid-template-columns:0.85fr 1.15fr;
  gap:44px;
  align-items:center;
}
.brand-grid__media{
  height:420px;
  border-radius:var(--radius);
  background-size:cover;
  background-position:center;
  background-repeat:no-repeat;
  box-shadow:var(--shadow-soft);
}
@media(max-width:900px){
  .brand-grid{ grid-template-columns:1fr; gap:28px; }
  .brand-grid__media{ height:320px; order:-1; }
}
@media(max-width:520px){
  .brand-grid__media{ height:240px; }
  .section--brand{ padding:45px 16px 85px; }
}

/* ================================================================
   24. FORMS (shared across checkout, login, account pages)
   ================================================================ */
.field-label{
  font-size:10px;
  letter-spacing:0.22em;
  text-transform:uppercase;
  font-weight:900;
  color:rgba(27,23,20,0.50);
  display:block;
  margin-bottom:6px;
}
.field-input{
  width:100%;
  border:none; outline:none;
  background:transparent;
  font-size:15px;
  color:rgba(27,23,20,0.88);
  padding:0; height:28px;
  font-family:var(--sans);
}
.field-input:focus{ border-color:rgba(199,162,90,0.75); }

/* ================================================================
   25. ESPACE CLIENT B2C — account pages
   ================================================================ */
.page-b2c-account .account-wrap{ padding:56px 0 80px; }
.page-b2c-account .account-shell{ max-width:760px; margin:0 auto; }
.page-b2c-account .account-shell-wide{ max-width:1100px; margin:0 auto; }
.page-b2c-account .login-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:30px;
  align-items:start;
}
.page-b2c-account .account-card{
  background:rgba(255,255,255,.94);
  border:1px solid rgba(0,0,0,.08);
  border-radius:22px;
  padding:34px;
  box-shadow:0 22px 55px rgba(0,0,0,.10);
  backdrop-filter:blur(1px);
  height:100%;
}
.page-b2c-account .account-title{
  margin:0 0 10px;
  letter-spacing:.06em;
  text-transform:uppercase;
  font-weight:700;
  color:#2a241f;
}
.page-b2c-account .account-subtitle{
  margin:0 0 26px;
  color:var(--muted);
  font-size:14px;
  line-height:1.6;
}
.page-b2c-account .account-section{ margin-top:22px; }
.page-b2c-account .account-h4{
  margin:0 0 10px;
  font-size:22px; line-height:1.1;
  letter-spacing:.01em;
  color:#2a241f;
}
.page-b2c-account .account-help{
  margin:12px 0 0;
  color:var(--muted);
  font-size:13px;
}
.page-b2c-account .field{
  display:flex; flex-direction:column;
  gap:8px; margin:14px 0;
}
.page-b2c-account .field label{
  font-size:12px; letter-spacing:.06em;
  text-transform:uppercase;
  color:rgba(0,0,0,.70);
}
.page-b2c-account .input{
  width:100%;
  padding:14px;
  border-radius:14px;
  border:1px solid rgba(0,0,0,.16);
  background:rgba(255,255,255,.98);
  color:var(--text);
  font-size:15px;
}
.page-b2c-account .input:focus{
  outline:none;
  border-color:rgba(199,162,90,.75);
  box-shadow:0 0 0 3px rgba(199,162,90,.22);
}
.page-b2c-account .btn-row{
  display:flex; gap:12px;
  align-items:center; flex-wrap:wrap;
  margin-top:18px;
}
.page-b2c-account .btn-row .btn,
.page-b2c-account .btn-row .btn-ghost{ width:100%; }
@media(min-width:640px){
  .page-b2c-account .btn-row .btn,
  .page-b2c-account .btn-row .btn-ghost{ width:auto; }
}
.page-b2c-account .btn-ghost{
  border:1px solid rgba(0,0,0,.18);
  padding:11px 18px; border-radius:999px;
  text-decoration:none;
  color:#2a241f;
  background:rgba(255,255,255,.70);
  transition:transform .15s ease, box-shadow .15s ease, background .15s ease;
}
.page-b2c-account .btn-ghost:hover{
  transform:translateY(-1px);
  background:rgba(255,255,255,.92);
  box-shadow:0 14px 26px rgba(0,0,0,.10);
}
.page-b2c-account .or-divider{
  display:grid;
  grid-template-columns:1fr auto 1fr;
  align-items:center;
  gap:14px; margin:26px 0;
}
.page-b2c-account .or-divider::before,
.page-b2c-account .or-divider::after{
  content:""; height:1px;
  background:linear-gradient(to right, transparent, rgba(199,162,90,.65), transparent);
}
.page-b2c-account .or-divider span{
  font-size:12px; letter-spacing:.18em;
  text-transform:uppercase; font-weight:800;
  color:rgba(107,77,35,.85);
  padding:6px 10px; border-radius:999px;
  border:1px solid rgba(199,162,90,.35);
  background:rgba(255,255,255,.85);
}
.page-b2c-account .account-foot{
  margin-top:18px; color:var(--muted); font-size:13px;
}
@media(max-width:900px){
  .page-b2c-account .login-grid{ grid-template-columns:1fr; }
}
@media(max-width:520px){
  .page-b2c-account .account-card{ padding:24px; border-radius:18px; }
  .page-b2c-account .account-wrap{ padding:44px 0 70px; }
}

/* ================================================================
   26. ESPACE PRO (B2B)
   ================================================================ */
.pro-auth-stage{
  padding:60px 0 100px;
  background-image:url("../img/marbre.jpeg");
  background-size:cover;
  background-position:center;
  min-height:80vh;
  display:flex;
  flex-direction:column;
  justify-content:center;
}
.pro-auth-head{ margin-bottom:50px; }
.pro-auth-title{
  font-size:clamp(30px, 4vw, 48px);
  color:#6b4d23;
  margin:0 0 16px;
  letter-spacing:0.05em;
}
.pro-auth-grid2{
  display:grid;
  grid-template-columns:1fr auto 1fr;
  gap:40px;
  align-items:stretch;
}
.pro-auth-sep{
  display:flex; flex-direction:column;
  align-items:center; justify-content:center; gap:10px;
}
.pro-auth-sep__line{ flex:1; width:1px; background:rgba(107,77,35,.2); }
.pro-auth-sep__pill{
  font-size:11px; font-weight:800;
  text-transform:uppercase; letter-spacing:.1em;
  padding:4px 8px;
  background:#fff;
  border:1px solid rgba(107,77,35,.2);
  border-radius:99px; color:#6b4d23;
}
.pro-card{
  border-radius:20px; padding:40px;
  display:flex; flex-direction:column;
  transition:transform .3s ease, box-shadow .3s ease;
}
.pro-card--login{
  background:rgba(255,255,255,.9);
  border:1px solid rgba(255,255,255,.5);
  box-shadow:0 20px 40px rgba(0,0,0,.05);
}
.pro-card--register{
  background:linear-gradient(145deg, #1c1a18, #2a2622);
  color:#fff;
  box-shadow:0 30px 60px rgba(0,0,0,.25);
  border:1px solid rgba(199,162,90,.1);
}
.pro-card__head{ margin-bottom:30px; }
.pro-chip{
  display:inline-block;
  font-size:10px; text-transform:uppercase; font-weight:800;
  letter-spacing:.12em; padding:5px 10px; border-radius:6px;
  margin-bottom:12px; background:#eee; color:#555;
}
.pro-chip--gold{
  background:linear-gradient(90deg, #c7a25a, #e6c885);
  color:#1a1917;
}
.pro-card__title{ margin:0 0 10px; font-size:26px; line-height:1.1; }
.pro-card__sub{ font-size:14px; color:var(--muted); line-height:1.5; margin:0; }
.pro-card__sub--dark{ color:rgba(255,255,255,.7); }
.pro-form{ display:flex; flex-direction:column; gap:18px; }
.pro-field label{
  display:block; font-size:11px; text-transform:uppercase;
  letter-spacing:.08em; font-weight:700; margin-bottom:6px;
  color:rgba(0,0,0,.6);
}
.pro-label-dark{ color:rgba(255,255,255,.6) !important; }
.pro-field input{
  width:100%; padding:12px 16px;
  border-radius:10px; border:1px solid rgba(0,0,0,.15);
  background:#fff; font-size:15px;
  transition:border .2s, box-shadow .2s;
}
.pro-field input:focus{
  outline:none;
  border-color:#c7a25a;
  box-shadow:0 0 0 3px rgba(199,162,90,.2);
}
.pro-btn-full{ width:100%; justify-content:center; padding:14px; font-size:13px; }
.pro-check{
  display:flex; gap:10px; align-items:flex-start;
  font-size:13px; color:rgba(255,255,255,.8);
}
.pro-check input{ margin-top:3px; accent-color:#c7a25a; }
.pro-note{ font-size:12px; color:var(--muted); margin:10px 0 0; text-align:center; }
.pro-note--dark{ color:rgba(255,255,255,.4); }
.pro-form-error{ color:#b23b3b; font-size:13px; font-weight:700; text-align:center; min-height:20px; }
.pro-form-error--dark{ color:#ff6b6b; }
.pro-auth-overlay{
  position:fixed; inset:0;
  background:rgba(255,255,255,.85);
  backdrop-filter:blur(5px);
  z-index:9999;
  display:flex; align-items:center; justify-content:center;
  animation:fadeIn .3s ease forwards;
}
.pro-auth-overlay__card{
  background:#fff; padding:40px; border-radius:20px;
  box-shadow:0 25px 50px rgba(0,0,0,.15); text-align:center;
}
.pro-auth-overlay__spinner{
  width:40px; height:40px; margin:0 auto 20px;
  border:4px solid #f3f3f3;
  border-top:4px solid #c7a25a;
  border-radius:50%;
  animation:spin 1s linear infinite;
}
@keyframes spin{ 100%{ transform:rotate(360deg); } }
@keyframes fadeIn{ from{opacity:0} to{opacity:1} }
.pro-tabs{
  background:#fff; padding:6px; border-radius:12px;
  box-shadow:0 5px 20px rgba(0,0,0,.05);
  display:inline-flex;
}
.pro-tab{
  border:none; background:transparent;
  padding:10px 20px; font-size:13px; font-weight:600;
  color:var(--muted); cursor:pointer;
  border-radius:8px; transition:all .2s ease;
}
.pro-tab:hover{ color:var(--text); background:#f9f9f9; }
.pro-tab.is-active{
  background:var(--text); color:#fff;
  box-shadow:0 4px 12px rgba(0,0,0,.15);
}
.pro-tabpanel{ display:none; animation:slideUp .3s ease forwards; }
.pro-tabpanel.is-active{ display:block; }
@keyframes slideUp{
  from{ opacity:0; transform:translateY(10px); }
  to{ opacity:1; transform:translateY(0); }
}
.pay-pill{
  flex:1; border:1px solid rgba(0,0,0,.1);
  background:#fff; padding:10px; border-radius:10px;
  text-align:center; cursor:pointer; font-size:13px; font-weight:600;
  transition:.2s;
}
.pay-pill:has(input:checked){
  border-color:#c7a25a;
  background:rgba(199,162,90,.1);
  color:#6b4d23;
}
.pay-pill input{ display:none; }
@media(max-width:900px){
  .pro-auth-grid2{ grid-template-columns:1fr; gap:30px; }
  .pro-auth-sep{ flex-direction:row; width:100%; }
  .pro-auth-sep__line{ height:1px; width:100%; }
}

/* ================================================================
   27. AUTH PAGES (login, register, forgot-password, reset-password)
   ================================================================ */

/* Split 2-col layout */
.intro--split .intro__inner{
  display:grid;
  grid-template-columns:1.15fr 0.85fr;
  gap:44px;
  align-items:start;
  padding-bottom:44px;
}

/* Right panel */
.panel{
  border-left:1px solid var(--line);
  padding-left:26px;
}
.panel-head{ margin-bottom:8px; }
.panel-head h2{
  margin:0;
  font-size:11px;
  letter-spacing:0.28em;
  text-transform:uppercase;
  font-weight:900;
  color:rgba(27,23,20,0.58);
}

/* Auth form */
.form{ margin-top:12px; }
.field{
  padding:14px 0;
  border-bottom:1px solid var(--line);
}
.label{
  display:block;
  font-size:10px;
  letter-spacing:0.22em;
  text-transform:uppercase;
  font-weight:900;
  color:rgba(27,23,20,0.50);
  margin-bottom:10px;
}
.input{
  width:100%;
  border:none; outline:none; background:transparent;
  font-size:15px;
  color:rgba(27,23,20,0.88);
  padding:0; height:28px;
  font-family:var(--sans);
}
.input::placeholder{ color:rgba(27,23,20,0.35); }

/* Password row */
.pw-row{ display:flex; align-items:center; gap:14px; }
.pw-row .input{ flex:1; }
.pw-toggle{
  border:none; background:none; cursor:pointer; padding:0;
  display:inline-flex; align-items:center; gap:12px;
  font-size:11px; letter-spacing:0.18em; text-transform:uppercase; font-weight:900;
  color:rgba(27,23,20,0.65); white-space:nowrap;
}
.pw-toggle::after{
  content:"";
  width:40px; height:1px;
  background:var(--text); opacity:0.55;
  transition:width .25s ease;
}
.pw-toggle:hover{ color:rgba(27,23,20,0.85); }
.pw-toggle:hover::after{ width:66px; }

/* Submit / form actions */
.submit-link{
  display:inline-flex; align-items:center; gap:14px;
  font-size:12px; text-transform:uppercase; letter-spacing:0.22em; font-weight:900;
  border:none; background:none; cursor:pointer; padding:0; color:var(--text);
}
.submit-link::after{
  content:"";
  width:56px; height:1px;
  background:var(--text); opacity:0.65;
  transition:width .25s ease;
}
.submit-link:hover::after{ width:92px; }
.form-actions{
  display:flex; align-items:center; justify-content:space-between;
  gap:16px; padding-top:18px; flex-wrap:wrap;
}

/* Messages */
.msg{
  margin-top:12px; padding-top:12px;
  border-top:1px solid var(--line);
  font-size:12px; line-height:1.85;
  color:rgba(27,23,20,0.72);
}
.msg ul{ margin:0; padding-left:18px; }
.msg li{ margin:6px 0; }

/* Success indicator */
.success-line{
  display:flex; align-items:center; gap:10px;
  font-size:11px; letter-spacing:0.18em; text-transform:uppercase;
  color:rgba(27,23,20,0.55);
  padding-top:12px; border-top:1px solid var(--line); margin-top:12px;
}
.success-dot{
  width:6px; height:6px;
  border-radius:50%;
  background:rgba(27,23,20,0.60);
  display:inline-block;
}

/* Register extras */
.checkbox{ display:flex; align-items:flex-start; gap:12px; padding:16px 0 0; }
.checkbox input{ margin-top:3px; width:16px; height:16px; accent-color:var(--text); }
.checkbox label{ font-size:12px; line-height:1.75; color:rgba(27,23,20,0.62); }
.checkbox a{ text-decoration:underline; text-underline-offset:3px; }
.mini{
  font-size:11px; letter-spacing:0.18em; text-transform:uppercase;
  color:var(--muted-light); line-height:1.7; margin-top:14px;
}
.intro__meta{
  margin-top:16px; font-size:11px;
  letter-spacing:0.18em; text-transform:uppercase;
  color:var(--muted-light); line-height:1.7;
}

/* ================================================================
   28. RESPONSIVE — COMMON
   ================================================================ */
@media(max-width:980px){
  .products-grid{ grid-template-columns:repeat(2, minmax(0, 1fr)); }
  .grid{ grid-template-columns:1fr; gap:22px; }
  .universe__img{ height:300px; }
  .intro--home .intro__inner{
    grid-template-columns:1fr;
    gap:28px;
  }
  .intro--split .intro__inner{
    grid-template-columns:1fr;
    gap:32px;
  }
  .panel{
    border-left:none;
    padding-left:0;
    padding-top:32px;
    border-top:1px solid var(--line);
  }
  .product-gallery{
    border-left:none;
    padding-left:0;
  }
  .slide{ flex:0 0 82%; max-width:82%; }
  .slide-img{ height:320px; }
  .section__head{ flex-direction:column; align-items:flex-start; }
}

@media(max-width:520px){
  .header{ padding:14px 14px; }
  .icon-btn{ width:42px; height:42px; }
  .intro{ padding:112px 16px 46px; }
  .intro--home{ padding:112px 16px 50px; }
  .section{ padding:45px 16px 120px; }
  .section--home{ padding:45px 16px 85px; }
  .products-grid{ grid-template-columns:1fr; }
  .product-packshot{ height:320px; }
  .sticky-cta{ display:block; }
  .slide{ flex:0 0 88%; max-width:88%; }
  .slide-img{ height:300px; }
  .pw-toggle::after{ width:28px; }
  .pw-toggle:hover::after{ width:46px; }
}

/* ================================================================
   29. AVIS / PREUVE SOCIALE
   ================================================================ */
.stars{
  color:rgba(27,23,20,0.25);
  font-size:13px;
  letter-spacing:2px;
  line-height:1;
}
.stars--gold{ color:var(--gold-strong); }
.stars--sm{ font-size:12px; letter-spacing:1px; }

.product-reviews{
  display:flex;
  align-items:center;
  gap:8px;
  font-size:12px;
  color:var(--muted);
  margin:-2px 0 12px;
}
.product-reviews span{ font-weight:700; }

.section--reviews{ padding-top:10px; }
.reviews-head{
  display:flex;
  align-items:center;
  justify-content:space-between;
  flex-wrap:wrap;
  gap:14px;
  margin-bottom:22px;
}
.reviews-global{
  display:flex;
  align-items:center;
  gap:10px;
  font-size:13px;
  color:var(--text);
}
.reviews-global strong{ font-size:14px; }

.reviews-grid{
  display:grid;
  grid-template-columns:repeat(3, minmax(0,1fr));
  gap:22px;
}
.reviews-summary{
  display:flex;
  align-items:center;
  gap:10px;
  font-size:13px;
  color:var(--text);
  margin-bottom:14px;
  padding-bottom:14px;
  border-bottom:1px solid var(--line);
}
.reviews-list{
  display:flex;
  flex-direction:column;
  gap:14px;
}

.review-card{
  background:rgba(255,255,255,0.78);
  border:1px solid var(--line);
  border-radius:var(--radius);
  box-shadow:var(--shadow-soft);
  backdrop-filter:blur(10px);
  -webkit-backdrop-filter:blur(10px);
  padding:18px 20px;
}
.review-head{
  display:flex;
  align-items:center;
  gap:10px;
  flex-wrap:wrap;
  margin-bottom:8px;
}
.review-author{
  font-size:11px;
  font-weight:900;
  letter-spacing:0.12em;
  text-transform:uppercase;
  color:rgba(27,23,20,0.78);
}
.review-verified{
  font-size:9px;
  font-weight:900;
  letter-spacing:0.16em;
  text-transform:uppercase;
  color:var(--success);
  background:rgba(26,92,58,0.08);
  border-radius:999px;
  padding:4px 10px;
}
.review-title{
  margin:4px 0;
  font-weight:900;
  font-size:13px;
  color:rgba(27,23,20,0.90);
}
.review-comment{
  margin:0;
  font-size:13px;
  line-height:1.7;
  color:var(--muted);
}
.review-product{
  margin:8px 0 0;
  font-size:11px;
  letter-spacing:0.08em;
  text-transform:uppercase;
}

/* ================================================================
   30. URGENCE / RARETÉ
   ================================================================ */
.badge-urgency{
  position:absolute;
  top:14px; right:14px;
  z-index:2;
  font-size:10px;
  font-weight:900;
  letter-spacing:0.10em;
  text-transform:uppercase;
  padding:6px 12px;
  border-radius:999px;
  box-shadow:0 4px 12px rgba(0,0,0,0.10);
  pointer-events:none;
  display:flex;
  align-items:center;
  gap:6px;
  color:#fff;
}
.badge-urgency--low_stock{ background:var(--danger); }
.badge-urgency--out_of_stock{ background:rgba(27,23,20,0.55); }
.badge-urgency--limited_edition{ background:var(--gold-strong); }

.countdown{
  font-family:var(--serif);
  font-weight:400;
  letter-spacing:0.04em;
}

/* ================================================================
   31. UPSELL / CROSS-SELL
   ================================================================ */
.upsell-grid{
  display:grid;
  grid-template-columns:repeat(3, minmax(0,1fr));
  gap:16px;
}
.upsell-card{
  border:1px solid var(--line);
  border-radius:var(--radius);
  overflow:hidden;
  background:#fff;
  display:flex;
  flex-direction:column;
}
.upsell-img{
  height:120px;
  background:var(--bg);
  background-size:contain;
  background-position:center;
  background-repeat:no-repeat;
}
.upsell-body{
  padding:12px 14px 16px;
  display:flex;
  flex-direction:column;
  gap:8px;
}
.upsell-name{
  margin:0;
  font-size:12px;
  font-weight:900;
  letter-spacing:0.06em;
  text-transform:uppercase;
  color:rgba(27,23,20,0.88);
  line-height:1.3;
}
.upsell-price{
  margin:0;
  font-size:13px;
  font-weight:900;
  color:var(--text);
}
.upsell-card .btn-outline{
  align-self:flex-start;
}

.upsell-post-grid{
  grid-template-columns:repeat(3, minmax(0,1fr));
}
.upsell-post .items-head{ margin-bottom:12px; }
.upsell-post{ margin-top:18px; border-top:1px solid var(--line); padding-top:18px; }

/* ================================================================
   32. PANIER — alerte stock
   ================================================================ */
.stock-warning{
  margin:6px 0 0;
  font-size:11px;
  font-weight:700;
  color:var(--danger);
}

/* ================================================================
   33. AVIS POST-ACHAT (formulaire success.php)
   ================================================================ */
.review-form-section{
  margin-top:18px;
  border-top:1px solid var(--line);
  padding-top:18px;
}
.review-form{
  display:flex;
  flex-direction:column;
  gap:12px;
  max-width:480px;
}
.review-form-row{
  display:flex;
  flex-direction:column;
  gap:6px;
}
.review-form-row label{
  font-size:10px;
  font-weight:900;
  letter-spacing:0.18em;
  text-transform:uppercase;
  color:rgba(27,23,20,0.55);
}
.review-form-row input,
.review-form-row select,
.review-form-row textarea{
  border:1px solid var(--line);
  border-radius:12px;
  padding:12px 14px;
  font-size:13px;
  font-family:var(--sans);
  background:rgba(255,255,255,0.85);
  color:var(--text);
  resize:vertical;
}
.review-form .btn-primary{ align-self:flex-start; }

/* ================================================================
   33b. MODALE FICHE PRODUIT (onglets)
   ================================================================ */
.modal-tabs{
  display:flex;
  gap:20px;
  flex-wrap:wrap;
  padding-bottom:14px;
  border-bottom:1px solid var(--line);
  margin-bottom:18px;
}
.modal-tab-btn{
  background:none;
  border:none;
  cursor:pointer;
  font-size:10px;
  letter-spacing:0.22em;
  text-transform:uppercase;
  font-weight:900;
  color:rgba(27,23,20,0.48);
  padding:0;
  position:relative;
  white-space:nowrap;
}
.modal-tab-btn.active{ color:rgba(27,23,20,0.92); }
.modal-tab-btn.active::after{
  content:"";
  position:absolute;
  left:0; bottom:-8px;
  width:100%; height:1px;
  background:var(--text);
  opacity:0.65;
}
.modal-tab-content{ display:none; }
.modal-tab-content.active{ display:block; }

/* ================================================================
   34. TOAST
   ================================================================ */
.lft-toast{
  position:fixed;
  left:50%;
  bottom:24px;
  transform:translate(-50%, 20px);
  background:var(--text);
  color:#fff;
  font-size:12px;
  font-weight:700;
  padding:12px 20px;
  border-radius:999px;
  box-shadow:var(--shadow-card);
  opacity:0;
  pointer-events:none;
  transition:opacity .25s ease, transform .25s ease;
  z-index:999;
  max-width:90vw;
  text-align:center;
}
.lft-toast.show{
  opacity:1;
  transform:translate(-50%, 0);
}

@media(max-width:980px){
  .reviews-grid{ grid-template-columns:repeat(2, minmax(0,1fr)); }
  .upsell-grid{ grid-template-columns:repeat(2, minmax(0,1fr)); }
  .upsell-post-grid{ grid-template-columns:repeat(2, minmax(0,1fr)); }
}
@media(max-width:520px){
  .reviews-grid{ grid-template-columns:1fr; }
  .upsell-grid{ grid-template-columns:1fr; }
  .upsell-post-grid{ grid-template-columns:1fr; }
  .badge-urgency{ top:10px; right:10px; font-size:9px; padding:5px 10px; }
}
