/* ============================================================
   INCINKTO v5 — Luxury Editorial Theme
   Fonts: Cormorant / Outfit / Cinzel
   Full-width forced, no container restrictions
   ============================================================ */

:root {
  --black:   #06050a;
  --dark:    #0e0c14;
  --surface: #16141e;
  --card:    #1e1b28;
  --lift:    #252233;
  --gold:    #c8a96a;
  --gold2:   #e4c98e;
  --gold3:   #8a6e3a;
  --cream:   #f0e8d8;
  --dim:     #7a7088;
  --border:  rgba(200,169,106,0.14);
  --ease:    cubic-bezier(0.16,1,0.3,1);
}

/* ── Reset total ── */
*, *::before, *::after {
  box-sizing: border-box !important;
  margin: 0 !important;
  padding: 0 !important;
}
html { font-size: 16px; scroll-behavior: smooth; -webkit-font-smoothing: antialiased; }
body {
  font-family: 'Outfit', sans-serif !important;
  background: var(--black) !important;
  color: var(--cream) !important;
  width: 100% !important;
  max-width: none !important;
  overflow-x: hidden;
  min-height: 100vh;
}
img { display: block; max-width: 100%; height: auto; }
a { text-decoration: none; color: inherit; }
button { font-family: 'Outfit', sans-serif; }
ul, ol { list-style: none; }

/* Force pleine largeur sur tout wrapper WordPress */
#page, #wrapper, .site, .site-content, .site-inner,
#content, #primary, #main, article, .entry,
.hentry, .post, .page, .wp-site-blocks,
.content-area, .widget-area {
  all: unset !important;
  display: block !important;
  width: 100% !important;
  max-width: none !important;
}

/* ====================================================
   NAVIGATION — Ultra fine, transparent puis noire
   ==================================================== */
#incinkto-nav {
  position: fixed !important;
  inset: 0 0 auto 0 !important;
  z-index: 900;
  height: 68px;
  display: flex !important;
  align-items: center;
  justify-content: space-between;
  padding: 0 56px !important;
  transition: background .5s, border-color .5s;
  border-bottom: 1px solid transparent;
}
#incinkto-nav.stuck {
  background: rgba(6,5,10,0.95) !important;
  backdrop-filter: blur(20px) saturate(1.4);
  border-color: var(--border) !important;
}

.iw-logo {
  font-family: 'Cinzel', serif !important;
  font-size: 18px !important;
  font-weight: 500 !important;
  letter-spacing: 0.22em !important;
  color: var(--cream) !important;
  text-decoration: none !important;
  transition: color .3s;
}
.iw-logo em { font-style: normal; color: var(--gold); }
.iw-logo:hover { color: var(--gold) !important; }

.iw-menu {
  display: flex !important;
  gap: 32px !important;
  align-items: center !important;
  list-style: none !important;
  padding: 0 !important; margin: 0 !important;
}
.iw-menu li { padding: 0 !important; margin: 0 !important; }
.iw-menu a {
  font-size: 10px !important;
  font-weight: 400 !important;
  letter-spacing: 0.2em !important;
  text-transform: uppercase !important;
  color: rgba(240,232,216,.55) !important;
  text-decoration: none !important;
  transition: color .3s !important;
  position: relative;
}
.iw-menu a::after {
  content: '';
  position: absolute;
  bottom: -4px; left: 0;
  width: 0; height: 1px;
  background: var(--gold);
  transition: width .35s var(--ease);
}
.iw-menu a:hover { color: var(--cream) !important; }
.iw-menu a:hover::after { width: 100%; }

.iw-nav-right {
  display: flex !important;
  align-items: center !important;
  gap: 18px !important;
}
.iw-nav-icon {
  background: none !important;
  border: none !important;
  color: rgba(240,232,216,.5) !important;
  display: flex !important;
  align-items: center !important;
  gap: 6px !important;
  font-size: 10px !important;
  letter-spacing: .15em !important;
  text-transform: uppercase !important;
  transition: color .3s !important;
  padding: 6px !important;
  text-decoration: none !important;
}
.iw-nav-icon:hover { color: var(--gold) !important; }
.iw-cart-wrap { position: relative !important; }
.iw-cart-count {
  position: absolute !important;
  top: -4px !important; right: -6px !important;
  width: 15px !important; height: 15px !important;
  background: var(--gold) !important;
  color: var(--black) !important;
  border-radius: 50% !important;
  font-size: 8px !important;
  font-weight: 600 !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
}
.iw-cart-count:empty { display: none !important; }

/* ====================================================
   HERO — Cinématique pleine hauteur
   ==================================================== */
.iw-hero {
  position: relative;
  width: 100% !important;
  height: 100vh !important;
  min-height: 680px;
  display: flex !important;
  align-items: center;
  overflow: hidden;
  padding: 0 !important; margin: 0 !important;
}

.iw-hero-bg {
  position: absolute; inset: 0;
  background:
    radial-gradient(ellipse 75% 90% at 68% 38%, rgba(200,169,106,.08) 0%, transparent 60%),
    radial-gradient(ellipse 45% 55% at 8% 88%, rgba(100,60,200,.06) 0%, transparent 55%),
    linear-gradient(155deg, #0d0b14 0%, #06050a 45%, #0a0814 100%);
}
.iw-hero-grid {
  position: absolute; inset: 0;
  background-image:
    linear-gradient(rgba(200,169,106,.022) 1px, transparent 1px),
    linear-gradient(90deg, rgba(200,169,106,.022) 1px, transparent 1px);
  background-size: 72px 72px;
  -webkit-mask-image: radial-gradient(ellipse 90% 90% at 50% 50%, #000 20%, transparent 100%);
  mask-image: radial-gradient(ellipse 90% 90% at 50% 50%, #000 20%, transparent 100%);
}
.iw-hero-vline {
  position: absolute;
  left: 47%; top: 0; bottom: 0; width: 1px;
  background: linear-gradient(to bottom, transparent, rgba(200,169,106,.18) 30%, rgba(200,169,106,.18) 70%, transparent);
}

/* Contenu gauche */
.iw-hero-left {
  position: relative; z-index: 2;
  padding: 0 0 0 9vw !important;
  max-width: 620px;
  animation: iw-up 1.4s var(--ease) both;
}
@keyframes iw-up { from { opacity:0; transform:translateY(40px) } to { opacity:1; transform:none } }

.iw-hero-tag {
  display: flex; align-items: center; gap: 14px;
  margin-bottom: 24px !important;
}
.iw-hero-tag-line { width: 44px; height: 1px; background: var(--gold); }
.iw-hero-tag-text {
  font-size: 10px; font-weight: 400; letter-spacing: .38em;
  text-transform: uppercase; color: var(--gold);
}

.iw-hero-title {
  font-family: 'Cormorant', serif !important;
  font-size: clamp(56px, 7vw, 104px) !important;
  font-weight: 300 !important;
  line-height: .96 !important;
  color: var(--cream) !important;
  margin-bottom: 0 !important;
  letter-spacing: -.02em;
}
.iw-hero-title em {
  font-style: italic; color: var(--gold2); display: block; font-weight: 300;
}

.iw-hero-rule {
  width: 100%; height: 1px;
  background: linear-gradient(to right, rgba(200,169,106,.35), transparent);
  margin: 28px 0 !important;
}

.iw-hero-sub {
  font-size: 14px !important; font-weight: 300 !important;
  line-height: 1.78 !important; color: var(--dim) !important;
  max-width: 380px; margin-bottom: 44px !important;
  letter-spacing: .025em;
}

.iw-hero-ctas { display: flex; gap: 14px; align-items: center; }

.iw-btn-fill {
  display: inline-flex; align-items: center; gap: 10px;
  padding: 15px 34px !important;
  background: var(--gold) !important; color: var(--black) !important;
  font-family: 'Outfit', sans-serif !important;
  font-size: 10px !important; font-weight: 500 !important;
  letter-spacing: .22em; text-transform: uppercase;
  border: none !important; text-decoration: none !important;
  transition: all .35s var(--ease); position: relative; overflow: hidden;
}
.iw-btn-fill::after {
  content: ''; position: absolute; inset: 0;
  background: var(--gold2); transform: scaleX(0); transform-origin: right;
  transition: transform .4s var(--ease); z-index: 0;
}
.iw-btn-fill span, .iw-btn-fill svg { position: relative; z-index: 1; }
.iw-btn-fill:hover::after { transform: scaleX(1); transform-origin: left; }
.iw-btn-fill svg { transition: transform .3s; }
.iw-btn-fill:hover svg { transform: translateX(4px); }

.iw-btn-ghost {
  display: inline-flex; align-items: center; gap: 10px;
  padding: 14px 28px !important;
  background: transparent !important; color: rgba(240,232,216,.7) !important;
  font-family: 'Outfit', sans-serif !important;
  font-size: 10px !important; font-weight: 400 !important;
  letter-spacing: .2em; text-transform: uppercase;
  border: 1px solid rgba(200,169,106,.25) !important; text-decoration: none !important;
  transition: all .3s;
}
.iw-btn-ghost:hover {
  border-color: var(--gold) !important; color: var(--cream) !important;
}

/* Visuel droit flacon */
.iw-hero-right {
  position: absolute !important;
  right: 0; top: 0; bottom: 0; width: 50%;
  display: flex; align-items: center; justify-content: center;
  overflow: hidden; pointer-events: none;
  animation: iw-fade 1.2s .5s var(--ease) both;
}
@keyframes iw-fade { from { opacity:0 } to { opacity:1 } }

.iw-hero-bottle-scene {
  position: relative; width: 340px; height: 520px;
  display: flex; align-items: center; justify-content: center;
}
.iw-ring {
  position: absolute; border-radius: 50%; border: 1px solid;
  animation: iw-spin linear infinite;
}
.iw-ring-1 { width: 460px; height: 460px; border-color: rgba(200,169,106,.06); animation-duration: 45s; }
.iw-ring-2 { width: 340px; height: 340px; border-color: rgba(200,169,106,.1); animation-duration: 30s; animation-direction: reverse; }
@keyframes iw-spin { to { transform: rotate(360deg); } }

.iw-hero-glow {
  position: absolute;
  width: 260px; height: 260px;
  background: radial-gradient(circle, rgba(200,169,106,.14) 0%, transparent 70%);
  border-radius: 50%;
  animation: iw-glow-pulse 4s ease-in-out infinite;
}
@keyframes iw-glow-pulse { 0%,100%{transform:scale(.95);opacity:.6} 50%{transform:scale(1.08);opacity:1} }

.iw-hero-bottle-svg {
  position: relative; z-index: 2;
  width: 190px;
  filter: drop-shadow(0 40px 80px rgba(200,169,106,.2));
  animation: iw-bottle-float 7s ease-in-out infinite;
}
@keyframes iw-bottle-float {
  0%,100% { transform: translateY(0) rotate(-.5deg); }
  50%      { transform: translateY(-20px) rotate(.5deg); }
}

/* Stats héro */
.iw-hero-stats {
  position: absolute; bottom: 44px; right: 5vw;
  display: flex; gap: 44px;
  animation: iw-up 1.6s .6s var(--ease) both;
}
.iw-hstat-n {
  font-family: 'Cormorant', serif;
  font-size: 36px; font-weight: 300; color: var(--gold2); line-height: 1;
  margin-bottom: 4px !important;
}
.iw-hstat-l {
  font-size: 9px; letter-spacing: .28em; text-transform: uppercase; color: var(--dim);
}

/* Scroll indicator */
.iw-hero-scroll {
  position: absolute; bottom: 44px; left: 9vw;
  display: flex; align-items: center; gap: 12px;
  color: var(--dim); font-size: 9px; letter-spacing: .3em; text-transform: uppercase;
}
.iw-scroll-bar {
  width: 1px; height: 52px;
  background: linear-gradient(to bottom, var(--gold), transparent);
  animation: iw-scroll-pulse 2.2s ease infinite;
}
@keyframes iw-scroll-pulse { 0%,100%{opacity:.3} 50%{opacity:1} }

/* ====================================================
   MARQUEE
   ==================================================== */
.iw-marquee {
  width: 100% !important;
  overflow: hidden; padding: 16px 0 !important;
  background: var(--surface);
  border-top: 1px solid var(--border);
  border-bottom: 1px solid var(--border);
}
.iw-marquee-track {
  display: flex; width: max-content;
  animation: iw-marquee 28s linear infinite;
}
@keyframes iw-marquee { from{transform:translateX(0)} to{transform:translateX(-50%)} }
.iw-marquee-item {
  display: flex; align-items: center; gap: 0;
  padding: 0 44px !important;
  font-size: 9px; letter-spacing: .32em; text-transform: uppercase;
  color: var(--dim); white-space: nowrap;
  border-right: 1px solid var(--border);
}
.iw-marquee-item b { color: var(--gold); margin-right: 14px !important; font-weight: 400; font-size: 12px; }

/* ====================================================
   LAYOUT helpers
   ==================================================== */
.iw-sec { padding: 96px 7vw !important; margin: 0 !important; width: 100% !important; }
.iw-sec-dark    { background: var(--dark); }
.iw-sec-surface { background: var(--surface); }
.iw-sec-card    { background: var(--card); }
.iw-sec-black   { background: var(--black); }

.iw-sec-head {
  display: flex; align-items: flex-end; justify-content: space-between;
  margin-bottom: 52px !important;
}
.iw-eyebrow {
  font-size: 9px; font-weight: 400; letter-spacing: .38em; text-transform: uppercase;
  color: var(--gold); margin-bottom: 10px !important;
  display: flex; align-items: center; gap: 12px;
}
.iw-eyebrow::before { content: ''; width: 24px; height: 1px; background: var(--gold); flex-shrink: 0; }
.iw-h2 {
  font-family: 'Cormorant', serif !important;
  font-size: clamp(32px,4.5vw,60px) !important;
  font-weight: 300 !important; line-height: 1.05 !important;
  color: var(--cream) !important; margin: 0 !important;
}
.iw-h2 em { font-style: italic; color: var(--gold2); }
.iw-see-all {
  font-size: 9px; letter-spacing: .28em; text-transform: uppercase;
  color: var(--gold) !important; text-decoration: none !important;
  border-bottom: 1px solid rgba(200,169,106,.3) !important;
  padding-bottom: 3px !important;
  display: flex; align-items: center; gap: 8px;
  transition: gap .3s, border-color .3s;
}
.iw-see-all:hover { gap: 14px !important; border-color: var(--gold) !important; }

/* ====================================================
   GRILLE PRODUITS — Cards modernes
   ==================================================== */
.iw-grid {
  display: grid !important;
  grid-template-columns: repeat(3,1fr) !important;
  gap: 1px !important;
  background: var(--border);
  width: 100% !important; padding: 0 !important; margin: 0 !important;
}

.iw-card {
  background: var(--card) !important;
  position: relative; overflow: hidden;
  display: flex; flex-direction: column;
  transition: transform .5s var(--ease);
}
.iw-card:hover { transform: translateY(-3px); z-index: 2; }

/* Image zone */
.iw-card-img {
  position: relative; height: 300px;
  display: flex; align-items: center; justify-content: center;
  overflow: hidden;
  background: linear-gradient(160deg, var(--surface) 0%, var(--card) 100%);
}
.iw-card-img img {
  max-height: 220px; max-width: 150px;
  width: auto; height: auto;
  object-fit: contain;
  transition: transform .7s var(--ease);
  filter: drop-shadow(0 24px 48px rgba(0,0,0,.6));
  margin: 0 auto !important;
}
.iw-card:hover .iw-card-img img { transform: translateY(-10px) scale(1.04); }

.iw-card-glow {
  position: absolute; inset: 0;
  background: radial-gradient(ellipse at center, rgba(200,169,106,.1) 0%, transparent 70%);
  opacity: 0; transition: opacity .5s;
}
.iw-card:hover .iw-card-glow { opacity: 1; }

/* Badge */
.iw-badge {
  position: absolute; top: 16px; left: 16px; z-index: 2;
  padding: 4px 11px !important;
  font-size: 8px; font-weight: 500; letter-spacing: .2em; text-transform: uppercase;
  background: var(--gold); color: var(--black);
}

/* Overlay quick add */
.iw-quick {
  position: absolute; inset-x: 0; bottom: 0; z-index: 3;
  display: flex; align-items: center; justify-content: center; gap: 8px;
  padding: 14px !important;
  background: rgba(6,5,10,.85); backdrop-filter: blur(8px);
  border-top: 1px solid var(--border);
  font-size: 9px; font-weight: 500; letter-spacing: .2em; text-transform: uppercase;
  color: var(--gold) !important; text-decoration: none !important;
  transform: translateY(100%); transition: transform .38s var(--ease);
  border: none !important; width: 100%;
}
.iw-card:hover .iw-quick { transform: translateY(0); }
.iw-quick:hover { background: var(--gold) !important; color: var(--black) !important; }

/* Info produit */
.iw-card-body {
  padding: 22px 24px 26px !important;
  border-top: 1px solid var(--border);
  flex: 1; display: flex; flex-direction: column;
}
.iw-card-cat {
  font-size: 8px; letter-spacing: .28em; text-transform: uppercase;
  color: var(--gold3); margin-bottom: 6px !important;
}
.iw-card-name {
  font-family: 'Cormorant', serif !important;
  font-size: 22px !important; font-weight: 400 !important;
  color: var(--cream) !important; margin-bottom: 5px !important;
  line-height: 1.2 !important;
}
.iw-card-short {
  font-size: 11px !important; color: var(--dim) !important;
  line-height: 1.6 !important; margin-bottom: 14px !important; font-weight: 300 !important;
}
.iw-card-notes {
  display: flex; gap: 5px; flex-wrap: wrap; margin-bottom: 18px !important;
}
.iw-note {
  padding: 2px 9px !important;
  border: 1px solid rgba(200,169,106,.18) !important;
  font-size: 8px !important; letter-spacing: .12em !important;
  text-transform: uppercase; color: rgba(240,232,216,.45) !important;
  border-radius: 20px !important;
}
.iw-card-foot { display: flex; align-items: center; justify-content: space-between; margin-top: auto; }

.iw-price {
  font-family: 'Cormorant', serif !important;
  font-size: 26px !important; font-weight: 300 !important;
  color: var(--gold2) !important;
}
.iw-price .woocommerce-Price-amount,
.iw-price bdi, .iw-price .amount {
  font-family: 'Cormorant', serif !important;
  font-size: 26px !important; font-weight: 300 !important;
  color: var(--gold2) !important;
}
.iw-price .woocommerce-Price-currencySymbol { font-size: 14px !important; vertical-align: super; }

.iw-add {
  width: 40px !important; height: 40px !important;
  display: flex !important; align-items: center !important; justify-content: center !important;
  border: 1px solid rgba(200,169,106,.28) !important;
  background: transparent !important; color: var(--cream) !important;
  text-decoration: none !important; border-radius: 0 !important;
  transition: all .3s !important; padding: 0 !important;
}
.iw-add:hover { background: var(--gold) !important; border-color: var(--gold) !important; color: var(--black) !important; }

.iw-card-bottle-default {
  width: 100%; height: 100%;
  display: flex; align-items: center; justify-content: center;
  background: linear-gradient(160deg, var(--surface), var(--card));
}

/* ====================================================
   COLLECTIONS — 2 grandes cartes
   ==================================================== */
.iw-collections {
  display: grid !important; grid-template-columns: 1fr 1fr !important;
  gap: 2px !important; padding: 0 !important; margin: 0 !important;
  width: 100% !important;
}
.iw-col-item {
  position: relative; height: 500px; overflow: hidden;
  display: flex; align-items: flex-end;
  background: var(--dark);
}
.iw-col-bg {
  position: absolute; inset: 0;
  transition: transform .9s var(--ease);
}
.iw-col-item:hover .iw-col-bg { transform: scale(1.05); }
.iw-col-overlay {
  position: absolute; inset: 0;
  background: linear-gradient(to top, rgba(6,5,10,.9) 0%, rgba(6,5,10,.1) 55%, transparent 100%);
}
.iw-col-body {
  position: relative; z-index: 2;
  padding: 44px !important; width: 100%;
}
.iw-col-tag {
  font-size: 8px; letter-spacing: .3em; text-transform: uppercase;
  color: var(--gold); margin-bottom: 8px !important;
}
.iw-col-name {
  font-family: 'Cormorant', serif !important;
  font-size: 40px !important; font-weight: 300 !important;
  color: var(--cream) !important; margin-bottom: 8px !important; line-height: 1.05 !important;
}
.iw-col-desc {
  font-size: 12px !important; color: rgba(240,232,216,.55) !important;
  margin-bottom: 22px !important; letter-spacing: .06em;
}
.iw-col-link {
  display: inline-flex; align-items: center; gap: 8px;
  font-size: 9px; letter-spacing: .22em; text-transform: uppercase;
  color: var(--gold) !important; text-decoration: none !important;
  border-bottom: 1px solid rgba(200,169,106,.3) !important; padding-bottom: 3px !important;
  transition: gap .3s, border-color .3s;
}
.iw-col-link:hover { gap: 14px !important; border-color: var(--gold) !important; }

/* ====================================================
   BANDE AVANTAGES
   ==================================================== */
.iw-perks {
  width: 100% !important;
  display: grid !important; grid-template-columns: repeat(3,1fr) !important;
  border-top: 1px solid var(--border);
  border-bottom: 1px solid var(--border);
  background: var(--lift);
}
.iw-perk {
  display: flex; gap: 20px; align-items: flex-start;
  padding: 36px 44px !important;
  border-right: 1px solid var(--border);
}
.iw-perk:last-child { border-right: none; }
.iw-perk-icon {
  width: 38px; height: 38px; flex-shrink: 0;
  border: 1px solid rgba(200,169,106,.24);
  display: flex; align-items: center; justify-content: center;
  color: var(--gold);
}
.iw-perk-title {
  font-family: 'Cormorant', serif;
  font-size: 17px; font-weight: 400; color: var(--cream);
  margin-bottom: 4px !important;
}
.iw-perk-desc { font-size: 12px; color: var(--dim); line-height: 1.55; font-weight: 300; }

/* ====================================================
   SECTION ABOUT — Split editorial
   ==================================================== */
.iw-about {
  display: grid !important; grid-template-columns: 1fr 1fr !important;
  width: 100% !important; padding: 0 !important; margin: 0 !important;
}
.iw-about-left { padding: 96px 7vw !important; background: var(--dark); }
.iw-about-right {
  position: relative; background: var(--surface);
  min-height: 540px; overflow: hidden;
  display: flex; align-items: center; justify-content: center;
}
.iw-about-word {
  position: absolute;
  font-family: 'Cormorant', serif;
  font-size: 220px; font-weight: 700; font-style: italic;
  color: rgba(200,169,106,.04); letter-spacing: -.05em;
  user-select: none; white-space: nowrap;
}
.iw-about-bottles-wrap {
  position: relative; z-index: 1;
  display: flex; align-items: flex-end; gap: 20px;
}
.iw-about-left p {
  font-size: 14px !important; line-height: 1.85 !important;
  color: var(--dim) !important; font-weight: 300 !important;
  margin-bottom: 18px !important; max-width: 440px;
}
.iw-kpis {
  display: flex; gap: 36px;
  margin-top: 44px !important; padding-top: 44px !important;
  border-top: 1px solid var(--border);
}
.iw-kpi-n {
  font-family: 'Cormorant', serif;
  font-size: 44px; font-weight: 300; color: var(--gold2);
  line-height: 1; margin-bottom: 4px !important;
}
.iw-kpi-l { font-size: 9px; letter-spacing: .25em; text-transform: uppercase; color: var(--dim); }

/* ====================================================
   INGRÉDIENTS — 4 colonnes
   ==================================================== */
.iw-ingr-grid {
  display: grid !important; grid-template-columns: repeat(4,1fr) !important;
  border: 1px solid var(--border) !important;
  margin-top: 52px !important; padding: 0 !important;
}
.iw-ingr {
  padding: 44px 28px !important;
  border-right: 1px solid var(--border);
  text-align: center; transition: background .3s;
}
.iw-ingr:last-child { border-right: none; }
.iw-ingr:hover { background: rgba(200,169,106,.04); }
.iw-ingr-icon { font-size: 26px; display: block; margin: 0 auto 16px !important; transition: transform .3s; }
.iw-ingr:hover .iw-ingr-icon { transform: scale(1.1); }
.iw-ingr-name {
  font-family: 'Cormorant', serif !important;
  font-size: 18px !important; font-weight: 400 !important;
  color: var(--cream) !important; margin-bottom: 8px !important;
}
.iw-ingr-origin {
  font-size: 8px; letter-spacing: .26em; text-transform: uppercase;
  color: var(--gold); margin-bottom: 12px !important;
  display: inline-block;
}
.iw-ingr-text { font-size: 11px !important; color: var(--dim) !important; line-height: 1.65 !important; }

/* ====================================================
   TÉMOIGNAGES
   ==================================================== */
.iw-reviews {
  display: grid !important; grid-template-columns: repeat(3,1fr) !important;
  gap: 1px !important; background: var(--border) !important;
  margin-top: 52px !important; padding: 0 !important;
}
.iw-review {
  padding: 44px 36px !important; background: var(--card); position: relative;
  transition: background .3s;
}
.iw-review:hover { background: var(--lift); }
.iw-review-q {
  font-family: 'Cormorant', serif; font-size: 80px;
  color: rgba(200,169,106,.1); position: absolute; top: 14px; left: 28px; line-height: .9;
}
.iw-review-stars { color: var(--gold); font-size: 11px; letter-spacing: 3px; margin-bottom: 14px !important; display: block; }
.iw-review-text {
  font-family: 'Cormorant', serif !important;
  font-size: 17px !important; font-style: italic !important;
  line-height: 1.7 !important; color: rgba(240,232,216,.88) !important;
  margin-bottom: 24px !important; position: relative;
}
.iw-review-name { font-size: 13px; color: var(--cream); font-weight: 500; margin-bottom: 2px !important; }
.iw-review-role { font-size: 9px; color: var(--dim); letter-spacing: .18em; text-transform: uppercase; }

/* ====================================================
   NEWSLETTER
   ==================================================== */
.iw-nl {
  padding: 96px 7vw !important; background: var(--card);
  text-align: center; position: relative; overflow: hidden;
}
.iw-nl-bg {
  position: absolute; font-family: 'Cinzel', serif;
  font-size: clamp(100px,15vw,200px); font-weight: 500;
  color: rgba(200,169,106,.03); letter-spacing: .2em;
  top: 50%; left: 50%; transform: translate(-50%,-50%);
  white-space: nowrap; pointer-events: none; user-select: none;
}
.iw-nl-inner { position: relative; max-width: 520px; margin: 0 auto !important; }
.iw-nl-title {
  font-family: 'Cormorant', serif !important;
  font-size: clamp(30px,4vw,52px) !important; font-weight: 300 !important;
  color: var(--cream) !important; margin-bottom: 14px !important; line-height: 1.08 !important;
}
.iw-nl-title em { font-style: italic; color: var(--gold2); }
.iw-nl-sub {
  font-size: 13px !important; color: var(--dim) !important;
  margin-bottom: 36px !important; line-height: 1.75 !important; font-weight: 300 !important;
}
.iw-nl-form {
  display: flex !important;
  border: 1px solid rgba(200,169,106,.22); overflow: hidden;
}
.iw-nl-input {
  flex: 1; padding: 17px 22px !important;
  background: rgba(255,255,255,.03) !important; border: none !important;
  color: var(--cream) !important; font-family: 'Outfit', sans-serif !important;
  font-size: 13px !important; outline: none !important;
}
.iw-nl-input::placeholder { color: var(--dim) !important; }
.iw-nl-btn {
  padding: 17px 30px !important;
  background: var(--gold) !important; border: none !important;
  color: var(--black) !important; font-family: 'Outfit', sans-serif !important;
  font-size: 9px !important; font-weight: 500 !important;
  letter-spacing: .22em; text-transform: uppercase;
  transition: background .3s !important; white-space: nowrap;
}
.iw-nl-btn:hover { background: var(--gold2) !important; }

/* ====================================================
   FOOTER
   ==================================================== */
footer#iw-footer {
  background: var(--surface) !important;
  border-top: 1px solid var(--border);
  padding: 72px 7vw 36px !important;
  margin: 0 !important;
}
.iw-footer-grid {
  display: grid !important; grid-template-columns: 2fr 1fr 1fr 1fr !important;
  gap: 56px !important; padding-bottom: 56px !important; margin-bottom: 36px !important;
  border-bottom: 1px solid var(--border);
}
.iw-footer-logo {
  font-family: 'Cinzel', serif; font-size: 20px; font-weight: 500;
  letter-spacing: .2em; color: var(--cream); text-decoration: none;
  display: block; margin-bottom: 14px !important;
}
.iw-footer-logo em { font-style: normal; color: var(--gold); }
.iw-footer-about {
  font-size: 12px !important; line-height: 1.8 !important;
  color: var(--dim) !important; max-width: 250px;
  margin-bottom: 24px !important; font-weight: 300 !important;
}
.iw-socials { display: flex; gap: 8px; }
.iw-social {
  width: 32px; height: 32px;
  border: 1px solid var(--border) !important;
  display: flex; align-items: center; justify-content: center;
  font-size: 10px; color: var(--dim) !important;
  text-decoration: none !important; transition: all .3s;
}
.iw-social:hover { border-color: var(--gold) !important; color: var(--gold) !important; }

.iw-fcol-title {
  font-size: 9px !important; letter-spacing: .28em !important; text-transform: uppercase !important;
  color: var(--cream) !important; margin-bottom: 18px !important;
  font-family: 'Outfit', sans-serif !important; font-weight: 500 !important;
}
.iw-fcol ul { display: flex; flex-direction: column; gap: 9px; padding: 0 !important; margin: 0 !important; }
.iw-fcol li { padding: 0 !important; margin: 0 !important; }
.iw-fcol a {
  font-size: 12px !important; color: var(--dim) !important;
  text-decoration: none !important; transition: color .3s !important; font-weight: 300 !important;
}
.iw-fcol a:hover { color: var(--gold2) !important; }

.iw-footer-bottom {
  display: flex; justify-content: space-between; align-items: center;
  font-size: 10px; color: rgba(122,112,136,.55); letter-spacing: .1em;
}

/* ====================================================
   CART DRAWER
   ==================================================== */
.iw-overlay {
  position: fixed; inset: 0; z-index: 1000;
  background: rgba(6,5,10,.75); backdrop-filter: blur(8px);
  opacity: 0; pointer-events: none; transition: opacity .4s;
}
.iw-overlay.on { opacity: 1; pointer-events: all; }

.iw-drawer {
  position: fixed; top: 0; right: 0; width: 420px; height: 100%;
  background: var(--dark) !important;
  border-left: 1px solid var(--border);
  z-index: 1001; transform: translateX(100%);
  transition: transform .45s var(--ease);
  display: flex; flex-direction: column;
  padding: 0 !important; margin: 0 !important;
}
.iw-drawer.on { transform: translateX(0); }

.iw-drawer-head {
  padding: 26px 30px !important;
  border-bottom: 1px solid var(--border);
  display: flex; align-items: center; justify-content: space-between; flex-shrink: 0;
}
.iw-drawer-title {
  font-family: 'Cormorant', serif; font-size: 20px; font-weight: 300; color: var(--cream);
}
.iw-drawer-close {
  width: 34px; height: 34px;
  border: 1px solid var(--border) !important; background: none !important;
  color: var(--dim) !important; display: flex; align-items: center; justify-content: center;
  font-size: 16px; transition: all .3s; padding: 0 !important;
}
.iw-drawer-close:hover { border-color: var(--gold) !important; color: var(--cream) !important; }

.iw-drawer-body { flex: 1; overflow-y: auto; padding: 22px 30px !important; }
.iw-drawer-empty {
  text-align: center; padding: 60px 0 !important;
  color: var(--dim); font-size: 13px; letter-spacing: .1em;
}

.iw-citem {
  display: flex; gap: 14px;
  padding: 18px 0 !important; border-bottom: 1px solid var(--border); margin: 0 !important;
}
.iw-citem-img {
  width: 64px; height: 78px; flex-shrink: 0;
  background: var(--surface); overflow: hidden;
}
.iw-citem-img img { width: 100%; height: 100%; object-fit: cover; margin: 0 !important; }
.iw-citem-name {
  font-family: 'Cormorant', serif; font-size: 16px; color: var(--cream);
  margin-bottom: 3px !important;
}
.iw-citem-meta { font-size: 10px; color: var(--dim); margin-bottom: 10px !important; }
.iw-citem-price { font-family: 'Cormorant', serif; font-size: 18px; color: var(--gold2); }
.iw-citem-price .woocommerce-Price-amount { color: var(--gold2) !important; font-family: 'Cormorant', serif !important; }

.iw-drawer-foot {
  padding: 22px 30px !important; border-top: 1px solid var(--border); flex-shrink: 0;
}
.iw-drawer-total-row {
  display: flex; justify-content: space-between; align-items: center;
  margin-bottom: 6px !important;
}
.iw-drawer-total-lbl { font-size: 9px; letter-spacing: .22em; text-transform: uppercase; color: var(--dim); }
.iw-drawer-total-val {
  font-family: 'Cormorant', serif; font-size: 26px; color: var(--gold2);
}
.iw-drawer-total-val .woocommerce-Price-amount { color: var(--gold2) !important; font-family: 'Cormorant', serif !important; font-size: 26px !important; }
.iw-drawer-ship { font-size: 10px; color: var(--dim); text-align: center; margin: 10px 0 18px !important; }

.iw-checkout-btn {
  display: flex !important; align-items: center !important; justify-content: center !important;
  width: 100% !important; padding: 17px !important;
  background: var(--gold) !important; border: none !important;
  color: var(--black) !important; font-family: 'Outfit', sans-serif !important;
  font-size: 10px !important; font-weight: 500 !important;
  letter-spacing: .22em; text-transform: uppercase;
  text-decoration: none !important; text-align: center !important;
  transition: background .3s !important; margin-bottom: 8px !important;
}
.iw-checkout-btn:hover { background: var(--gold2) !important; color: var(--black) !important; }
.iw-cart-link {
  display: block !important; width: 100% !important; padding: 13px !important;
  background: transparent !important;
  border: 1px solid var(--border) !important; color: var(--dim) !important;
  font-family: 'Outfit', sans-serif !important; font-size: 10px !important;
  letter-spacing: .18em; text-transform: uppercase;
  text-align: center !important; text-decoration: none !important;
  transition: all .3s !important;
}
.iw-cart-link:hover { border-color: var(--gold) !important; color: var(--cream) !important; }

/* Toast */
.iw-toast {
  position: fixed; bottom: 34px; left: 50%;
  transform: translateX(-50%) translateY(14px);
  background: var(--lift); border: 1px solid var(--gold);
  padding: 13px 26px !important;
  font-size: 11px; letter-spacing: .15em; color: var(--cream);
  z-index: 1100; opacity: 0; transition: all .4s var(--ease); pointer-events: none;
}
.iw-toast.on { opacity: 1; transform: translateX(-50%) translateY(0); }

/* ====================================================
   WOOCOMMERCE PAGES
   ==================================================== */
.woocommerce-page .woocommerce,
.woocommerce { padding: 80px 7vw !important; background: var(--black) !important; }

/* Boutique */
.woocommerce ul.products {
  display: grid !important; grid-template-columns: repeat(3,1fr) !important;
  gap: 1px !important; background: var(--border) !important;
  list-style: none !important; padding: 0 !important; margin: 0 !important;
  float: none !important; width: auto !important;
}
.woocommerce ul.products::before,
.woocommerce ul.products::after { display: none !important; }
.woocommerce ul.products li.product {
  background: var(--card) !important;
  padding: 0 !important; margin: 0 !important;
  float: none !important; width: auto !important;
}
.woocommerce ul.products li.product img {
  width: 100% !important; height: 220px !important;
  object-fit: cover !important; margin: 0 !important;
}
.woocommerce ul.products li.product .woocommerce-loop-product__title {
  font-family: 'Cormorant', serif !important;
  font-size: 20px !important; font-weight: 400 !important;
  color: var(--cream) !important; padding: 14px 20px 6px !important; margin: 0 !important;
}
.woocommerce ul.products li.product .price {
  font-family: 'Cormorant', serif !important;
  font-size: 22px !important; color: var(--gold2) !important;
  padding: 0 20px !important; display: block;
}
.woocommerce ul.products li.product .button {
  margin: 10px 20px 20px !important;
  background: transparent !important; border: 1px solid rgba(200,169,106,.28) !important;
  color: var(--cream) !important; font-family: 'Outfit', sans-serif !important;
  font-size: 9px !important; letter-spacing: .2em !important;
  text-transform: uppercase !important; padding: 10px 18px !important;
  border-radius: 0 !important; transition: all .3s !important;
}
.woocommerce ul.products li.product .button:hover {
  background: var(--gold) !important; border-color: var(--gold) !important; color: var(--black) !important;
}

/* Fiche produit */
.woocommerce div.product { padding: 80px 7vw !important; background: var(--black) !important; }
.woocommerce div.product .product_title {
  font-family: 'Cormorant', serif !important;
  font-size: clamp(32px,5vw,60px) !important; font-weight: 300 !important;
  color: var(--cream) !important; line-height: 1.08 !important;
}
.woocommerce div.product p.price,
.woocommerce div.product span.price {
  font-family: 'Cormorant', serif !important;
  font-size: 36px !important; color: var(--gold2) !important;
}
.woocommerce div.product .woocommerce-product-details__short-description {
  color: var(--dim) !important; font-size: 14px !important; line-height: 1.85 !important;
}
.woocommerce div.product form.cart .button {
  background: var(--gold) !important; color: var(--black) !important; border: none !important;
  font-family: 'Outfit', sans-serif !important; font-size: 10px !important;
  font-weight: 500 !important; letter-spacing: .22em !important; text-transform: uppercase !important;
  padding: 17px 40px !important; border-radius: 0 !important; transition: all .35s !important;
}
.woocommerce div.product form.cart .button:hover { background: var(--gold2) !important; }

/* Panier & Checkout */
.woocommerce-cart .woocommerce,
.woocommerce-checkout .woocommerce,
.woocommerce-account .woocommerce { padding: 80px 7vw !important; max-width: none !important; }
.woocommerce table.shop_table {
  width: 100% !important; border: 1px solid var(--border) !important;
  color: var(--cream) !important; background: transparent !important;
}
.woocommerce table.shop_table th {
  font-size: 9px !important; letter-spacing: .28em !important; text-transform: uppercase !important;
  color: var(--dim) !important; border-bottom: 1px solid var(--border) !important;
  padding: 14px 20px !important; background: var(--surface) !important;
  font-family: 'Outfit', sans-serif !important; font-weight: 400 !important;
}
.woocommerce table.shop_table td {
  border-bottom: 1px solid var(--border) !important;
  padding: 20px !important; background: transparent !important; color: var(--cream) !important;
}
.woocommerce table.shop_table .product-name a {
  font-family: 'Cormorant', serif !important;
  font-size: 18px !important; color: var(--cream) !important; text-decoration: none !important;
}
.woocommerce form .form-row label {
  font-size: 9px !important; letter-spacing: .22em !important;
  text-transform: uppercase !important; color: var(--dim) !important;
}
.woocommerce form .form-row input.input-text,
.woocommerce form .form-row textarea {
  background: var(--surface) !important; border: 1px solid var(--border) !important;
  color: var(--cream) !important; padding: 13px 17px !important;
  font-family: 'Outfit', sans-serif !important; font-size: 13px !important;
  width: 100% !important; outline: none !important; border-radius: 0 !important;
  transition: border-color .3s !important;
}
.woocommerce form .form-row input.input-text:focus { border-color: var(--gold) !important; }
.woocommerce #payment { background: var(--surface) !important; border: 1px solid var(--border) !important; padding: 26px !important; border-radius: 0 !important; }
.woocommerce #payment ul.payment_methods li { color: var(--cream) !important; font-size: 13px !important; }
.woocommerce #place_order {
  background: var(--gold) !important; color: var(--black) !important;
  font-family: 'Outfit', sans-serif !important; font-size: 10px !important;
  font-weight: 500 !important; letter-spacing: .22em !important; text-transform: uppercase !important;
  padding: 17px !important; border: none !important; width: 100% !important; border-radius: 0 !important;
  transition: background .3s !important;
}
.woocommerce #place_order:hover { background: var(--gold2) !important; }
.woocommerce-message,.woocommerce-info,.woocommerce-error {
  border-top-color: var(--gold) !important; background: var(--surface) !important; color: var(--cream) !important;
}
.woocommerce-MyAccount-navigation ul { list-style: none !important; padding: 0 !important; margin: 0 !important; }
.woocommerce-MyAccount-navigation a { color: var(--dim) !important; text-decoration: none !important; font-size: 11px !important; letter-spacing: .18em !important; text-transform: uppercase !important; transition: color .3s !important; }
.woocommerce-MyAccount-navigation a:hover,
.woocommerce-MyAccount-navigation .is-active a { color: var(--gold) !important; }

/* ====================================================
   ANIMATIONS
   ==================================================== */
.iw-reveal {
  opacity: 0; transform: translateY(28px);
  transition: opacity .8s var(--ease), transform .8s var(--ease);
}
.iw-reveal.visible { opacity: 1; transform: none; }
.iw-reveal-d1 { transition-delay: .1s; }
.iw-reveal-d2 { transition-delay: .2s; }
.iw-reveal-d3 { transition-delay: .3s; }

/* ====================================================
   RESPONSIVE
   ==================================================== */
@media(max-width:1100px) {
  #incinkto-nav { padding: 0 28px !important; }
  .iw-menu { display: none !important; }
  .iw-hero-left { padding: 0 28px !important; max-width: 100%; }
  .iw-hero-right { display: none !important; }
  .iw-hero-stats { display: none !important; }
  .iw-sec { padding: 68px 28px !important; }
  .iw-grid { grid-template-columns: 1fr !important; }
  .iw-collections { grid-template-columns: 1fr !important; }
  .iw-perks { grid-template-columns: 1fr !important; }
  .iw-about { grid-template-columns: 1fr !important; }
  .iw-about-right { display: none !important; }
  .iw-ingr-grid { grid-template-columns: 1fr 1fr !important; }
  .iw-reviews { grid-template-columns: 1fr !important; }
  .iw-footer-grid { grid-template-columns: 1fr 1fr !important; gap: 36px !important; }
  footer#iw-footer { padding: 56px 28px 28px !important; }
  .iw-drawer { width: 100% !important; }
  .woocommerce ul.products { grid-template-columns: 1fr !important; }
  .woocommerce div.product { padding: 56px 28px !important; }
  .woocommerce-cart .woocommerce,
  .woocommerce-checkout .woocommerce,
  .woocommerce-account .woocommerce { padding: 56px 28px !important; }
}
@media(max-width:640px) {
  .iw-ingr-grid { grid-template-columns: 1fr !important; }
  .iw-footer-grid { grid-template-columns: 1fr !important; }
  .iw-hero-title { font-size: clamp(44px,12vw,72px) !important; }
}
