/* ══════════════════════════════════════════════════════════════════════════ */
/* ATELIER MIRAGE — SHARED DESIGN SYSTEM                                       */
/* Haute Pâtisserie · Marseille                                               */
/* ══════════════════════════════════════════════════════════════════════════ */

/* ══════════════════════════════════════
   1. TOKENS & BASELINE
══════════════════════════════════════ */
:root {
  --cream:      #F8E8D6;
  --cream-2:    #F2EAE0;
  --cream-3:    #EDE0D4;
  --ink:        #1A1714;
  --ink-muted:  #6B6560;
  --gold:       #A8895C;
  --gold-light: #C9AA7C;
  --gold-pale:  #E8D5B8;
  --white:      #FDFAF7;
  --serif:      'Cormorant Garamond', Georgia, serif;
  --sans:       'Outfit', system-ui, sans-serif;
  --mono:       'JetBrains Mono', monospace;
  --ease-out:   cubic-bezier(0.16, 1, 0.3, 1);
  --ease-spring:cubic-bezier(0.34, 1.56, 0.64, 1);
  --ease-expo:  cubic-bezier(0.87, 0, 0.13, 1);
  --ease:       cubic-bezier(0.16, 1, 0.3, 1);
}

/* ══════════════════════════════════════
   2. RESET + BASE
══════════════════════════════════════ */
*, *::before, *::after { margin:0; padding:0; box-sizing:border-box; }
html { scroll-behavior: smooth; font-size:16px; }

body {
  font-family: var(--sans);
  background: var(--cream);
  color: var(--ink);
  overflow-x: hidden;
  -webkit-font-smoothing: antialiased;
}

/* ══════════════════════════════════════
   3. GRAIN OVERLAY & MASQUE FONDU
══════════════════════════════════════ */
body::before {
  content: '';
  position: fixed;
  top: 0; left: 0; right: 0;
  height: 5.5rem;
  background: linear-gradient(to bottom, var(--cream) 40%, transparent);
  z-index: 700;
  pointer-events: none;
}

body::after {
  content: '';
  position: fixed;
  inset: 0;
  z-index: 9999;
  pointer-events: none;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='300' height='300'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.75' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='300' height='300' filter='url(%23n)' opacity='0.04'/%3E%3C/svg%3E");
}

/* ══════════════════════════════════════
   4. BASE ELEMENT RESETS & SCROLLBAR
══════════════════════════════════════ */
img { display:block; max-width:100%; }
a   { text-decoration:none; color:inherit; }

::-webkit-scrollbar { width: 2px; }
::-webkit-scrollbar-track { background: var(--cream); }
::-webkit-scrollbar-thumb { background: var(--gold); border-radius:2px; }
html { scrollbar-color: var(--gold) var(--cream); scrollbar-width: thin; }

/* ══════════════════════════════════════
   5. SHARED TYPOGRAPHY & BUTTONS
══════════════════════════════════════ */
.section-eyebrow {
  font-family: var(--mono); font-size: 0.58rem; letter-spacing: 0.38em; text-transform: uppercase;
  color: var(--gold); margin-bottom: 1.5rem; display: flex; align-items: center; gap: 1rem;
}
.section-eyebrow::before { content: ''; display: inline-block; width: 30px; height: 1px; background: var(--gold); opacity: 0.5; }
.section-h2 { font-family: var(--serif); font-weight: 300; font-size: clamp(2.8rem, 5vw, 5.5rem); line-height: 0.9; letter-spacing: -0.02em; }
.section-h2 em { font-style: italic; color: var(--gold-light); }
.section-desc { font-size: 0.875rem; line-height: 1.9; color: var(--ink-muted); max-width: 42ch; align-self: end; }

.btn-primary {
  position: relative; display: inline-flex; align-items: center; gap: 0.8rem; padding: 1rem 2.2rem;
  background: var(--ink); color: var(--cream); border-radius: 999px; font-family: var(--mono); font-size: 0.62rem;
  letter-spacing: 0.2em; text-transform: uppercase; overflow: hidden; transition: transform 0.15s var(--ease-spring);
  border: 1px solid var(--ink); box-shadow: inset 0 1px 0 rgba(255,255,255,0.15);
}
.btn-primary::before { content: ''; position: absolute; inset: 0; background: var(--gold); transform: translateX(-101%); transition: transform 0.55s var(--ease-out); }
.btn-primary:hover::before { transform: translateX(0); }
.btn-primary span { position: relative; z-index: 1; }
.btn-primary:active { transform: scale(0.96); }

.btn-arrow { width: 2.2rem; height: 2.2rem; border-radius: 50%; border: 1px solid rgba(253,250,247,0.25); display: flex; align-items: center; justify-content: center; transition: transform 0.3s var(--ease-spring), border-color 0.3s; position: relative; z-index: 1; }
.btn-primary:hover .btn-arrow { transform: translateX(5px); border-color: rgba(255,255,255,0.4); }

.btn-ghost { display: inline-flex; align-items: center; gap: 0.8rem; padding: 1rem 2.2rem; border-radius: 999px; font-family: var(--mono); font-size: 0.62rem; letter-spacing: 0.2em; text-transform: uppercase; color: var(--cream); border: 1px solid rgba(255,255,255,0.18); transition: background 0.35s; }
.btn-ghost:hover { background: rgba(255,255,255,0.1); }

/* ══════════════════════════════════════
   6. NAVIGATION — Épurée
══════════════════════════════════════ */
#navbar {
  position: fixed; top: 1.5rem; left: 50%; transform: translateX(-50%); z-index: 1000;
  width: min(92vw, 1200px); display: grid; grid-template-columns: 1fr auto 1fr; align-items: center;
  padding: 0.75rem 1.8rem; border-radius: 999px; background: rgba(248, 232, 214, 0.45);
  backdrop-filter: blur(24px) saturate(1.6); -webkit-backdrop-filter: blur(24px) saturate(1.6);
  border: 1px solid rgba(255,255,255,0.4); box-shadow: inset 0 1px 0 rgba(255,255,255,0.6), 0 8px 32px rgba(26,23,20,0.05);
  transition: all 0.5s var(--ease-out); opacity: 0; translate: 0 -20px;
}
#navbar.visible { opacity:1; translate:0 0; }
#navbar.scrolled { background: rgba(248,232,214,0.88); box-shadow: inset 0 1px 0 rgba(255,255,255,0.8), 0 16px 48px rgba(26,23,20,0.1); }
.nav-links { display: none !important; }
.nav-actions { display: contents; }

.nav-burger { 
  display: flex !important; grid-column: 1; grid-row: 1; justify-self: start; flex-direction: column !important; gap: 5px; 
  justify-content: center !important; align-items: center !important; padding: 0 !important; background: transparent !important; 
  border: none !important; cursor: pointer !important; min-width: 44px !important; min-height: 44px !important; 
  position: relative !important; z-index: 1005 !important;
}
.nav-burger::after { content: ''; display: block !important; position: absolute; top: -8px; bottom: -8px; left: -8px; right: -8px; }
.nav-burger span { display: block; width: 22px; height: 1.5px; background: var(--ink); border-radius: 2px; transition: transform 0.4s; transform-origin: center; pointer-events: none !important; }
.nav-burger.open span:nth-child(1) { transform: translateY(6.5px) rotate(45deg); }
.nav-burger.open span:nth-child(2) { opacity: 0; }
.nav-burger.open span:nth-child(3) { transform: translateY(-6.5px) rotate(-45deg); }

.nav-brand { display: flex; align-items: center; gap: 0.9rem; grid-column: 2; grid-row: 1; justify-self: center; }
.brand-logo { height: 36px; width: auto; object-fit: contain; filter: brightness(0) saturate(100%); transition: opacity 0.3s; }
.brand-name { font-family: var(--serif); font-weight: 300; font-size: 0.72rem; letter-spacing: 0.22em; text-transform: uppercase; color: var(--ink); line-height:1; }

.nav-cta {
  grid-column: 3; grid-row: 1; justify-self: end; position: relative; z-index: 1005; display: inline-flex; align-items: center; gap: 0.6rem;
  font-family: var(--mono); font-size: 0.58rem; letter-spacing: 0.2em; text-transform: uppercase; color: var(--white);
  background: var(--ink); padding: 0.55rem 1.3rem; border-radius: 999px; transition: all 0.3s var(--ease-spring);
  border: 1px solid transparent; box-shadow: inset 0 1px 0 rgba(255,255,255,0.15);
}
.nav-cta:hover { background: var(--gold); }
.nav-cta:active { transform: scale(0.96); }

/* ══════════════════════════════════════
   7. FORMULAIRES (B2B & ÉVÉNEMENTS)
══════════════════════════════════════ */
.back-link { font-family: var(--mono); font-size: 0.65rem; letter-spacing: 0.2em; text-transform: uppercase; display: flex; align-items: center; gap: 0.8rem; color: var(--ink-muted); text-decoration: none; transition: color 0.4s var(--ease), transform 0.4s var(--ease); }
.back-link:hover { color: var(--ink); transform: translateX(-5px); }
.eyebrow { font-family: var(--mono); font-size: 0.6rem; letter-spacing: 0.4em; text-transform: uppercase; color: var(--gold); margin-bottom: 2rem; display: flex; align-items: center; gap: 1rem; }
.eyebrow::before { content: ''; width: 40px; height: 1px; background: var(--gold); opacity: 0.4; }

.form-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 2.5rem 3rem; }
.full-width { grid-column: span 2; }

.input-group { position: relative; margin-top: 1rem; }
.input-group label { position: absolute; top: 1rem; left: 0; font-family: var(--mono); font-size: 0.65rem; text-transform: uppercase; letter-spacing: 0.15em; color: var(--ink-muted); transition: transform 0.4s var(--ease), color 0.4s var(--ease); transform-origin: left top; pointer-events: none; }
.input-group input, .input-group textarea { width: 100%; background: transparent; border: none; border-bottom: 1px solid rgba(26,23,20,0.15); padding: 1rem 0 0.8rem; font-family: var(--sans); font-size: 1.05rem; color: var(--ink); outline: none; transition: border-color 0.4s var(--ease); }
.input-group textarea { min-height: 80px; resize: none; overflow: hidden; }

.input-group input:focus ~ label, .input-group input:not(:placeholder-shown) ~ label, 
.input-group textarea:focus ~ label, .input-group textarea:not(:placeholder-shown) ~ label { transform: translateY(-1.8rem) scale(0.85); color: var(--gold); }
.input-group input:focus, .input-group textarea:focus { border-bottom-color: var(--gold); }

/* L'icône de validation est verrouillée en taille ici */
.validation-icon { position: absolute; right: 0; bottom: 1rem; width: 16px !important; height: 16px !important; opacity: 0; transform: scale(0.5); transition: all 0.4s var(--ease-spring); color: var(--gold); }
.input-group input:valid:not(:placeholder-shown) ~ .validation-icon { opacity: 1; transform: scale(1); }

.custom-select-wrapper { position: relative; user-select: none; margin-top: 1rem; }
.custom-select-wrapper label { position: absolute; top: -0.8rem; left: 0; font-family: var(--mono); font-size: 0.55rem; text-transform: uppercase; letter-spacing: 0.15em; color: var(--gold); }
.custom-select { position: relative; display: flex; justify-content: space-between; align-items: center; padding: 1rem 0 0.8rem; border-bottom: 1px solid rgba(26,23,20,0.15); font-family: var(--sans); font-size: 1.05rem; color: var(--ink); cursor: pointer; transition: border-color 0.4s var(--ease); }
.custom-select:hover { border-bottom-color: var(--gold); }
.custom-select::after { content: ''; width: 8px; height: 8px; border-right: 1px solid var(--ink); border-bottom: 1px solid var(--ink); transform: translateY(-3px) rotate(45deg); transition: transform 0.4s var(--ease-spring); }
.custom-select.open::after { transform: translateY(2px) rotate(-135deg); border-color: var(--gold); }

.custom-options { position: absolute; top: 100%; left: 0; right: 0; background: var(--white); border-radius: 0 0 1.5rem 1.5rem; box-shadow: 0 20px 50px rgba(26,23,20,0.1); opacity: 0; visibility: hidden; transform: translateY(-10px); transition: all 0.4s var(--ease); z-index: 100; overflow: hidden; padding: 0.5rem 0; }
.custom-select.open + .custom-options { opacity: 1; visibility: visible; transform: translateY(0); }
.custom-option { padding: 1rem 1.5rem; font-size: 0.95rem; color: var(--ink-muted); cursor: pointer; transition: background 0.3s, color 0.3s; }
.custom-option:hover, .custom-option.selected { background: var(--cream); color: var(--ink); }
select { display: none; }

.submit-wrap { margin-top: 4rem; display: flex; align-items: center; justify-content: space-between; }
.submit-btn { padding: 1.2rem 2.5rem; background: var(--ink); color: var(--cream); border: none; border-radius: 999px; font-family: var(--mono); font-size: 0.65rem; letter-spacing: 0.25em; text-transform: uppercase; cursor: pointer; display: flex; align-items: center; gap: 1.2rem; transition: all 0.4s var(--ease-spring); position: relative; overflow: hidden; }
.submit-btn::before { content: ''; position: absolute; inset: 0; background: var(--gold); transform: translateX(-101%); transition: transform 0.5s var(--ease); z-index: 0; }
.submit-btn:hover::before { transform: translateX(0); }
.submit-btn span, .submit-btn svg { position: relative; z-index: 1; }
.submit-btn:hover { transform: translateY(-2px); box-shadow: 0 15px 30px rgba(168,137,92,0.25); }
.submit-btn:active { transform: translateY(1px) scale(0.98); }

.privacy-note { font-family: var(--mono); font-size: 0.5rem; letter-spacing: 0.15em; color: var(--ink-muted); text-transform: uppercase; max-width: 150px; }

.success-overlay { position: absolute; inset: 0; background: var(--white); border-radius: 2.5rem; display: flex; flex-direction: column; align-items: center; justify-content: center; text-align: center; padding: 3rem; opacity: 0; pointer-events: none; z-index: 10; }
.success-overlay.active { opacity: 1; pointer-events: auto; }
.success-mark { width: 60px; height: 60px; border-radius: 50%; border: 1px solid var(--gold); display: flex; align-items: center; justify-content: center; margin-bottom: 2rem; color: var(--gold); }
.success-mark svg { width: 24px; height: 24px; }


/* ══════════════════════════════════════
   8. PAGE SECTIONS (HERO, ATELIER, ETC)
══════════════════════════════════════ */
.hero { min-height: 100dvh; position: relative; overflow: hidden; display: flex; align-items: flex-end; }
.hero-left { position: relative; z-index: 2; padding: 8rem 7vw 6rem; max-width: 600px; }
.hero-left::before { content:''; position:absolute; bottom: 0; left: -10%; width: 60%; height: 50%; background: radial-gradient(ellipse, rgba(168,137,92,0.08) 0%, transparent 70%); pointer-events:none; }
.hero-eyebrow { font-family: var(--mono); font-size: 0.6rem; letter-spacing: 0.55em; text-transform: uppercase; color: var(--gold); margin-bottom: 2.5rem; display: flex; align-items: center; gap: 1rem; opacity: 0; transform: translateY(20px); }
.hero-eyebrow::before { content:''; display:inline-block; width:40px; height:1px; background:var(--gold); opacity:0.5; }
.hero-h1 { font-family: var(--serif); font-weight: 300; font-size: clamp(3.8rem, 6.5vw, 8rem); line-height: 0.86; letter-spacing: -0.02em; color: var(--ink); opacity: 0; transform: translateY(50px); }
.hero-h1 em { font-style: italic; color: var(--gold-light); }
.hero-desc { margin-top: 3rem; font-size: 0.88rem; line-height: 1.9; color: var(--ink-muted); max-width: 40ch; opacity: 0; transform: translateY(20px); }
.hero-actions { margin-top: 3.5rem; display: flex; align-items: center; gap: 2.5rem; opacity: 0; transform: translateY(20px); }
.hero-right { position: absolute; inset: 0; z-index: 0; }
.hero-img-main { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; object-position: 65% center; opacity: 0; will-change: transform; }
.hero-right::after { content: ''; position: absolute; inset: 0; background: linear-gradient(to right, rgba(248,232,214,0.97) 0%, rgba(248,232,214,0.75) 30%, rgba(248,232,214,0.15) 55%, transparent 75%); z-index: 1; }
.scroll-hint { position: absolute; bottom: 2.5rem; left: 7vw; display: flex; flex-direction: column; align-items: center; gap: 0.5rem; opacity: 0; }
.scroll-hint-line { width: 1px; height: 3.5rem; background: linear-gradient(to bottom, var(--gold), transparent); animation: scrollLine 2.5s ease-in-out infinite; }
.scroll-hint-label { font-family: var(--mono); font-size: 0.52rem; letter-spacing: 0.35em; text-transform: uppercase; color: var(--ink-muted); writing-mode: vertical-rl; }

.atelier { padding: 14rem 0 10rem; overflow: hidden; position: relative; }
.atelier::before { content:''; position:absolute; top:0; left:0; right:0; height:1px; background: linear-gradient(to right, transparent, rgba(26,23,20,0.08), transparent); }
.atelier-header { padding: 0 6vw; display: grid; grid-template-columns: 1fr 1fr; gap:4rem; align-items:end; margin-bottom: 6rem; }
.atelier-steps-outer { padding-left: 6vw; overflow: hidden; }
.atelier-steps { display: flex; gap: 3rem; width: max-content; will-change: transform; }
.atelier-step { width: 380px; flex-shrink: 0; }
.atelier-step-num { font-family: var(--mono); font-size: 0.6rem; letter-spacing: 0.3em; text-transform: uppercase; color: var(--gold); margin-bottom: 2rem; display:flex; align-items:center; gap:1rem; }
.atelier-step-num::after { content:''; flex:1; height:1px; background:rgba(168,137,92,0.2); }
.atelier-step-img { width:100%; aspect-ratio: 4/3; border-radius: 2rem; overflow:hidden; background: var(--cream-2); margin-bottom: 2rem; position:relative; }
.atelier-step-img img { width:100%; height:100%; object-fit:cover; mix-blend-mode:multiply; }
.atelier-step-title { font-family: var(--serif); font-size: 1.8rem; font-weight:300; letter-spacing:-0.01em; line-height:1.1; color:var(--ink); margin-bottom:1rem; }
.atelier-step-desc { font-size:0.85rem; line-height:1.85; color:var(--ink-muted); }

.philosophy { padding: 14rem 6vw; display: grid; grid-template-columns: 1fr 1fr; gap: 10vw; align-items: center; position: relative; }
.philosophy::before { content:''; position:absolute; top:0; left:6vw; right:6vw; height:1px; background: linear-gradient(to right, transparent, rgba(26,23,20,0.08) 30%, rgba(26,23,20,0.08) 70%, transparent); }
.philosophy-quote { font-family: var(--serif); font-style: italic; font-size: clamp(2.2rem, 3.8vw, 4rem); line-height: 1.15; font-weight: 300; color: var(--ink); letter-spacing: -0.01em; margin-bottom: 3rem; }
.philosophy-quote em { color: var(--gold-light); font-style:normal; }
.philosophy-body { font-size: 0.875rem; line-height: 1.95; color: var(--ink-muted); max-width: 46ch; }
.philosophy-divider { display: flex; align-items:center; gap:1.5rem; margin:2.5rem 0; }
.philosophy-divider-line { flex:1; height:1px; background:rgba(26,23,20,0.08); }
.philosophy-divider-text { font-family:var(--mono); font-size:0.55rem; letter-spacing:0.3em; text-transform:uppercase; color:var(--gold); }
.philosophy-visual { position:relative; height:520px; }
.phil-img-a { position:absolute; top:0; right:0; width:72%; border-radius: 40% 60% 60% 40% / 30% 30% 70% 70%; overflow:hidden; filter: drop-shadow(0 30px 70px rgba(26,23,20,0.14)); }
.phil-img-a img { width:100%; height:360px; object-fit:cover; }
.phil-img-b { position:absolute; bottom:0; left:0; width:52%; border-radius: 2.5rem; overflow:hidden; filter: drop-shadow(0 20px 50px rgba(26,23,20,0.1)); }
.phil-img-b img { width:100%; height:230px; object-fit:cover; }
.phil-stats { position:absolute; top:48%; left:35%; background: rgba(248,232,214,0.8); backdrop-filter: blur(24px); border: 1px solid rgba(255,255,255,0.5); box-shadow: inset 0 1px 0 rgba(255,255,255,0.6), 0 10px 40px rgba(26,23,20,0.07); border-radius: 1.4rem; padding: 1.4rem 1.8rem; }
.phil-stats-val { font-family:var(--serif); font-size:2.5rem; font-weight:300; line-height:1; color:var(--ink); }
.phil-stats-label { font-family:var(--mono); font-size:0.56rem; letter-spacing:0.2em; text-transform:uppercase; color:var(--ink-muted); margin-top:0.4rem; }

.boutique { padding: 14rem 6vw 10rem; position: relative; }
.boutique::before { content:''; position:absolute; top:0; left:6vw; right:6vw; height:1px; background: linear-gradient(to right, transparent, rgba(26,23,20,0.08) 30%, rgba(26,23,20,0.08) 70%, transparent); }
.boutique-header { display:grid; grid-template-columns:1fr 1fr; gap:4rem; align-items:end; margin-bottom:7rem; }
.boutique-filters { display:flex; gap:0.6rem; flex-wrap:wrap; margin-bottom:4rem; }
.filter-pill { font-family: var(--mono); font-size: 0.6rem; letter-spacing: 0.2em; text-transform: uppercase; padding: 0.5rem 1.2rem; border-radius: 999px; border: 1px solid rgba(26,23,20,0.15); color: var(--ink-muted); background: transparent; transition: all 0.3s var(--ease-out); cursor:pointer; }
.filter-pill:hover, .filter-pill.active { background: var(--ink); color: var(--cream); border-color: var(--ink); }
.filter-pill.active { border-color: var(--gold); background: var(--gold); }
.shop-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 3.5rem 2.5rem; }
.shop-card { position:relative; }
.shop-card-img-wrap { position:relative; width:100%; aspect-ratio:1; border-radius:2.5rem; overflow:hidden; background: var(--cream-2); margin-bottom:1.5rem; }
.shop-card-img-wrap img.shop-card-main { width:100%; height:100%; object-fit:cover; mix-blend-mode:multiply; transition:transform 0.7s var(--ease-out), opacity 0.5s var(--ease-out); }

/* Modification de l'effet loupe (Pan Zoom) */
.shop-card-img-wrap img.shop-card-zoom { 
  position:absolute; inset:0; width:100%; height:100%; object-fit:cover; mix-blend-mode:multiply; opacity:0; 
  transform: scale(1.8); 
  transition:opacity 0.6s var(--ease-out); z-index:1; 
  pointer-events: none; 
}

.shop-card:hover .shop-card-img-wrap img.shop-card-main { transform:scale(1.05); opacity:0; }
.shop-card:hover .shop-card-img-wrap img.shop-card-zoom { opacity:1; }
.shop-card-zoom-hint { position:absolute; bottom:1.5rem; left:1.5rem; font-family:var(--mono); font-size:0.48rem; letter-spacing:0.2em; text-transform:uppercase; color:var(--ink-muted); opacity:0; transition:opacity 0.4s; z-index:2; display:flex; align-items:center; gap:0.4rem; }
.shop-card:hover .shop-card-zoom-hint { opacity:0.7; }
.shop-card-badge-new { position:absolute; top:1.2rem; right:1.2rem; font-family:var(--mono); font-size:0.52rem; letter-spacing:0.2em; text-transform:uppercase; padding:0.4rem 0.9rem; border-radius:999px; background:var(--gold); color:var(--white); z-index:2; box-shadow: 0 4px 12px rgba(168,137,92,0.3); }
.shop-card-add { position:absolute; bottom:1.5rem; right:1.5rem; width:3rem; height:3rem; border-radius:50%; background:var(--ink); border:1px solid rgba(255,255,255,0.1); display:flex; align-items:center; justify-content:center; opacity:0.3; transition:opacity 0.4s, transform 0.4s var(--ease-out), background 0.3s; z-index:3; cursor:pointer; }
.shop-card:hover .shop-card-add { opacity:1; }
.shop-card-add:hover { background:var(--gold); border-color:transparent; }
.shop-card-add svg { stroke:var(--cream); }
.shop-card-name { font-family:var(--serif); font-size:1.5rem; font-weight:300; letter-spacing:-0.01em; margin-bottom:0.4rem; }
.shop-card-sub { font-family:var(--mono); font-size:0.55rem; letter-spacing:0.18em; text-transform:uppercase; color:var(--ink-muted); margin-bottom:1.2rem; }
.shop-card-footer { display:flex; justify-content:space-between; align-items:center; }
.shop-card-price { font-family:var(--serif); font-size:1.4rem; font-weight:300; color:var(--ink); }
.shop-card-price span { font-family:var(--mono); font-size:0.6rem; color:var(--ink-muted); letter-spacing:0.1em; margin-left:0.3rem; }

.parallax-section { position: relative; padding: 15rem 6vw; background-image: url('img/boite-trans.png'); background-size: cover; background-position: center; background-repeat: no-repeat; display: flex; align-items: center; justify-content: center; text-align: center; min-height: 70vh; background-attachment: fixed; }
.engagements-overlay { position: absolute; inset: 0; background: rgba(26, 23, 20, 0.45); z-index: 1; }
.engagements-content { position: relative; z-index: 2; max-width: 800px; display: flex; flex-direction: column; align-items: center; }
.engagements .section-eyebrow.eyebrow-light { color: var(--gold-light); margin-bottom: 2.5rem; justify-content: center; }
.engagements .section-eyebrow.eyebrow-light::before { background: var(--gold-light); }
.engagements-quote { font-family: var(--serif); font-size: clamp(2rem, 4vw, 3.5rem); font-weight: 300; font-style: italic; line-height: 1.25; color: var(--white); text-shadow: 0 4px 15px rgba(0, 0, 0, 0.5); }

.faq { padding: 12rem 6vw 10rem; display:grid; grid-template-columns:1fr 1.8fr; gap:8vw; align-items:start; position:relative; }
.faq::before { content:''; position:absolute; top:0; left:6vw; right:6vw; height:1px; background: linear-gradient(to right, transparent, rgba(26,23,20,0.08) 30%, rgba(26,23,20,0.08) 70%, transparent); }
.faq-left { position:sticky; top:120px; }
.faq-items { display:flex; flex-direction:column; }
.faq-item { border-bottom:1px solid rgba(26,23,20,0.07); overflow:hidden; }
.faq-question { width:100%; background:none; border:none; padding:2rem 0; display:flex; justify-content:space-between; align-items:center; text-align:left; gap:2rem; cursor:pointer; }
.faq-q-text { font-family:var(--serif); font-size:1.25rem; font-weight:300; color:var(--ink); transition:color 0.3s; }
.faq-question:hover .faq-q-text { color:var(--gold); }
.faq-icon { width:2rem; height:2rem; flex-shrink:0; border-radius:50%; border:1px solid rgba(26,23,20,0.12); display:flex; align-items:center; justify-content:center; transition:transform 0.4s, background 0.3s; }
.faq-item.open .faq-icon { transform:rotate(45deg); background:var(--gold); border-color:var(--gold); }
.faq-item.open .faq-icon svg { stroke:var(--white); }
.faq-answer { max-height:0; overflow:hidden; transition:max-height 0.5s, padding 0.4s; padding:0; }
.faq-item.open .faq-answer { max-height:500px; padding-bottom:2rem; }
.faq-answer p { font-size:0.875rem; line-height:1.9; color:var(--ink-muted); max-width:55ch; }

.newsletter-band { margin: 0 4vw 0; padding: 5rem 6vw; border-radius:3rem 3rem 0 0; background:var(--cream-3); display:grid; grid-template-columns:1fr 1fr; gap:4rem; align-items:center; }
.newsletter-h { font-family:var(--serif); font-size:clamp(1.8rem,3vw,2.8rem); font-weight:300; line-height:1.1; }
.newsletter-h em { font-style:italic; color:var(--gold-light); }
.newsletter-input-wrap { display:flex; align-items:center; border-bottom:1px solid rgba(26,23,20,0.2); transition:border-color 0.3s; }
.newsletter-input-wrap:focus-within { border-bottom-color:var(--gold); }
.newsletter-input { flex:1; padding:1rem 1.5rem; border:none; outline:none; background:transparent; font-family:var(--sans); font-size:0.875rem; color:var(--ink); }
.newsletter-submit { padding:0.8rem 1.6rem; background:var(--ink); color:var(--cream); border:none; border-radius:999px; font-family:var(--mono); font-size:0.58rem; letter-spacing:0.2em; text-transform:uppercase; cursor:pointer; transition:background 0.3s; }
.newsletter-submit:hover { background:var(--gold); }

.cta-banner { margin: 0 4vw 8rem; padding: 5rem 6vw; border-radius: 3rem; background: var(--ink); display: grid; grid-template-columns: 1fr auto; gap: 4rem; align-items: center; }
.cta-banner-eyebrow { font-family:var(--mono); font-size:0.58rem; letter-spacing:0.3em; text-transform:uppercase; color:rgba(201,170,124,0.65); margin-bottom:1.5rem; }
.cta-banner-h { font-family:var(--serif); font-weight:300; font-size:clamp(2.5rem, 4vw, 4.5rem); line-height:0.9; letter-spacing:-0.02em; color:var(--white); }
.cta-banner-h em { font-style:italic; color:var(--gold-light); }

footer { padding: 6rem 6vw 3rem; border-top: 1px solid rgba(26,23,20,0.06); text-align: center; }
.footer-logo-wrap { margin-bottom: 0.8rem; }
.footer-nav { display:flex; justify-content:center; flex-wrap:wrap; gap:1rem 2.5rem; margin-bottom:3rem; }
.footer-nav a { font-family:var(--mono); font-size:0.55rem; letter-spacing:0.18em; text-transform:uppercase; color:var(--ink-muted); transition:color 0.3s; }
.footer-nav a:hover { color:var(--ink); }

/* ══════════════════════════════════════
   9. COMPONENTS (MODALS, CARTS, ETC)
══════════════════════════════════════ */
#preloader { position:fixed; inset:0; z-index:99999; background:var(--cream); display:flex; align-items:center; justify-content:center; flex-direction:column; gap:1.5rem; transition:opacity 0.6s var(--ease-out), visibility 0.6s; }
#preloader.done { opacity:0; visibility:hidden; pointer-events:none; }
#preloader img { height:42px; filter:brightness(0) saturate(100%); animation:preloaderPulse 1.5s ease-in-out infinite; }
#preloader .preloader-line { width:60px; height:1px; background:var(--gold); transform:scaleX(0); animation:preloaderLine 1.2s var(--ease-out) 0.3s forwards; }

#order-gateway { position: fixed; inset: 0; z-index: 10000; background: rgba(26, 23, 20, 0.88); backdrop-filter: blur(24px) saturate(1.2); -webkit-backdrop-filter: blur(24px) saturate(1.2); color: var(--cream); display: flex; align-items: center; padding: 6vw; opacity: 0; pointer-events: none; visibility: hidden; transition: opacity 0.6s var(--ease-out), visibility 0.6s; will-change: opacity, visibility; }
#order-gateway.open { opacity: 1; pointer-events: auto; visibility: visible; }
.order-close { position: absolute; top: 2.5rem; right: 4vw; background: transparent; border: none; color: rgba(248,232,214,0.6); font-family: var(--mono); font-size: 0.6rem; letter-spacing: 0.2em; text-transform: uppercase; display: flex; align-items: center; gap: 1rem; padding: 1rem; transition: color 0.3s; cursor:pointer; }
.order-close:hover { color: var(--cream); }
.order-gateway-inner { width: 100%; max-width: 1400px; margin: 0 auto; }
.order-header { margin-bottom: 6rem; }
.order-eyebrow { font-family: var(--mono); font-size: 0.6rem; letter-spacing: 0.4em; text-transform: uppercase; color: var(--gold); margin-bottom: 1.5rem; }
.order-h2 { font-family: var(--serif); font-size: clamp(3rem, 6vw, 5.5rem); font-weight: 300; line-height: 0.9; letter-spacing: -0.02em; }
.order-h2 em { font-style: italic; color: var(--gold-light); }
.order-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 6vw; }
.order-path { border-top: 1px solid rgba(248,232,214,0.15); padding-top: 2.5rem; transform: translateY(30px); opacity: 0; transition: transform 0.8s var(--ease-out), opacity 0.8s var(--ease-out); }
#order-gateway.open .order-path { transform: translateY(0); opacity: 1; }
#order-gateway.open .order-path:nth-child(1) { transition-delay: 0.1s; }
#order-gateway.open .order-path:nth-child(2) { transition-delay: 0.2s; }
#order-gateway.open .order-path:nth-child(3) { transition-delay: 0.3s; }
.order-path-num { font-family: var(--mono); font-size: 0.55rem; letter-spacing: 0.25em; color: rgba(248,232,214,0.4); margin-bottom: 2rem; }
.order-path-title { font-family: var(--serif); font-size: 2.2rem; font-weight: 300; margin-bottom: 1.5rem; color: var(--white); }
.order-path-desc { font-size: 0.85rem; line-height: 1.9; color: rgba(248,232,214,0.78); margin-bottom: 3rem; max-width: 35ch; }
.order-path-link { display: inline-flex; flex-direction: column; gap: 0.6rem; font-family: var(--mono); font-size: 0.6rem; letter-spacing: 0.2em; text-transform: uppercase; color: var(--gold-light); }
.link-line { width: 100%; height: 1px; background: rgba(201,170,124,0.3); position: relative; overflow: hidden; }
.link-line::after { content: ''; position: absolute; top: 0; left: 0; bottom: 0; width: 100%; background: var(--gold-light); transform: translateX(-101%); transition: transform 0.5s var(--ease-out); }
.order-path-link:hover .link-line::after { transform: translateX(0); }

#mobile-overlay { position: fixed; inset: 0; z-index: 900; background: var(--ink); display: flex; flex-direction: column; align-items: flex-start; justify-content: center; padding: 0 2rem 4rem; opacity: 0; pointer-events: none; visibility: hidden; transition: opacity 0.5s, visibility 0.5s; }
#mobile-overlay.open { opacity: 1; pointer-events: all; visibility: visible; }
.mobile-nav-item { font-family: var(--serif); font-size: clamp(2.5rem, 8vw, 4rem); font-weight: 300; color: rgba(248,232,214,0.15); line-height: 1.1; transition: color 0.3s; margin-bottom: 0.5rem; }
#mobile-overlay.open .mobile-nav-item { color: var(--cream); }

#cart-toast { position:fixed; bottom:2rem; left:50%; transform:translateX(-50%) translateY(20px); background:var(--ink); color:var(--cream); padding:1rem 2rem; border-radius:999px; font-family:var(--mono); font-size:0.6rem; letter-spacing:0.2em; text-transform:uppercase; z-index:10006; opacity:0; transition:opacity 0.4s, transform 0.4s; pointer-events:none; display:flex; align-items:center; gap:0.8rem; }
#cart-toast.show { opacity:1; transform:translateX(-50%) translateY(0); pointer-events:auto; }
.cart-toast-dot { width:6px; height:6px; border-radius:50%; background:var(--gold); animation:breathe 1.5s ease-in-out infinite; }
#cart-count-badge { position:absolute; top:-6px; right:-6px; width:18px; height:18px; border-radius:50%; background:var(--gold); color:var(--white); font-family:var(--mono); font-size:0.55rem; display:flex; align-items:center; justify-content:center; opacity:0; transform:scale(0); transition:opacity 0.3s, transform 0.4s; }
#cart-count-badge.show { opacity:1; transform:scale(1); }

#cart-panel { 
  position:fixed; top:0; right:0; bottom:0; width:min(420px, 92vw); z-index:10003; 
  background:var(--cream); box-shadow:-20px 0 60px rgba(26,23,20,0.12); 
  display:flex; flex-direction:column;
  transform: translateX(100%); 
  transition: transform 0.65s cubic-bezier(0.19, 1, 0.22, 1); 
}
#cart-panel.open { transform:translateX(0); }
#cart-overlay { position:fixed; inset:0; z-index:10002; background:rgba(26,23,20,0.35); backdrop-filter:blur(4px); opacity:0; pointer-events:none; transition:opacity 0.5s cubic-bezier(0.16, 1, 0.3, 1); }
#cart-overlay.open { opacity:1; pointer-events:auto; }
.cart-header { display:flex; justify-content:space-between; align-items:center; padding:2rem 2rem 1.5rem; border-bottom:1px solid rgba(26,23,20,0.06); }
.cart-title { font-family:var(--serif); font-size:1.5rem; font-weight:300; }
.cart-close { width:2.6rem; height:2.6rem; border-radius:50%; border:1px solid rgba(26,23,20,0.1); background:transparent; display:flex; align-items:center; justify-content:center; cursor:pointer; transition:background 0.3s; }
.cart-close:hover { background:var(--cream-3); }
.cart-items { flex:1; overflow-y:auto; padding:1.5rem 2rem; }
.cart-shipping-tracker { padding: 1.5rem 2rem 0; border-bottom: 1px solid rgba(26,23,20,0.04); padding-bottom: 1.2rem; background: var(--cream); }
.cart-shipping-tracker p { font-family: var(--mono); font-size: 0.55rem; letter-spacing: 0.15em; text-transform: uppercase; color: var(--ink-muted); text-align: center; margin-bottom: 0.8rem; }
.cart-shipping-tracker p span { color: var(--gold); font-weight: 600; }
.shipping-bar-bg { width: 100%; height: 2px; background: rgba(26,23,20,0.06); border-radius: 2px; overflow: hidden; }
.shipping-bar-fill { height: 100%; background: var(--gold); width: 0%; transition: width 0.6s; }
.cart-item { display:grid; grid-template-columns:60px 1fr auto; gap:1rem; align-items:center; padding:1.2rem 0; border-bottom:1px solid rgba(26,23,20,0.05); }
.cart-item-img { width:60px; height:60px; border-radius:1rem; background:var(--cream-2); display:flex; align-items:center; justify-content:center; overflow:hidden; }
.cart-item-img img { width:85%; mix-blend-mode:multiply; }
.cart-item-name { font-family:var(--serif); font-size:1rem; font-weight:300; }
.cart-item-sub { font-family:var(--mono); font-size:0.5rem; letter-spacing:0.15em; text-transform:uppercase; color:var(--ink-muted); margin-top:0.2rem; }
.cart-item-qty { display:flex; align-items:center; gap:0.6rem; margin-top:0.5rem; }
.cart-qty-btn { width:2.6rem; height:2.6rem; border-radius:50%; border:1px solid rgba(26,23,20,0.12); background:transparent; display:flex; align-items:center; justify-content:center; cursor:pointer; font-size:0.75rem; color:var(--ink-muted); transition:border-color 0.3s; }
.cart-qty-btn:hover { border-color:var(--gold); }
.cart-qty-num { font-family:var(--mono); font-size:0.7rem; min-width:1.2rem; text-align:center; }
.cart-item-price { font-family:var(--serif); font-size:1rem; font-weight:300; white-space:nowrap; }
.cart-footer { padding:1.5rem 2rem 2rem; border-top:1px solid rgba(26,23,20,0.08); }
.cart-footer-pricing { display:flex; flex-direction:column; margin-bottom:1.5rem; }
.cart-footer-row { display:flex; justify-content:space-between; margin-bottom:0.6rem; font-family:var(--mono); font-size:0.55rem; letter-spacing:0.15em; color:var(--ink-muted); text-transform:uppercase; }
.cart-footer-row.total { margin-bottom:0; padding-top:0.8rem; border-top:1px dashed rgba(26,23,20,0.1); }
.cart-footer-row.total span:first-child { color:var(--ink); font-weight:500; }
.cart-footer-row.total span:last-child { font-family:var(--serif); font-size:1.6rem; font-weight:300; }
.cart-checkout { display:block; width:100%; padding:1.15rem 1rem; background:var(--ink); color:var(--cream); border-radius:999px; font-family:var(--mono); font-size:0.65rem; letter-spacing:0.2em; text-transform:uppercase; cursor:pointer; text-align:center; transition:all 0.3s; border:none; }
.cart-checkout:hover { background:var(--gold); transform:translateY(-2px); }
.cart-whatsapp { display:flex; align-items:center; justify-content:center; gap:0.6rem; width:100%; padding:1.1rem 1rem; background:transparent; color:var(--ink); border:1px solid rgba(26,23,20,0.3); border-radius:999px; font-family:var(--mono); font-size:0.65rem; letter-spacing:0.2em; text-transform:uppercase; cursor:pointer; transition:all 0.3s; margin-top:0.8rem; }
.cart-whatsapp:hover { border-color:var(--ink); background:rgba(26,23,20,0.03); transform:translateY(-2px); }
.wa-input { width: 100%; padding: 0.8rem 1.2rem; border: 1px solid rgba(26,23,20,0.15); border-radius: 999px; font-family: var(--sans); font-size: 0.8rem; background: transparent; color: var(--ink); outline: none; margin-bottom:0.6rem; }
.wa-input:focus { border-color: var(--gold); }
.cart-empty { display:flex; flex-direction:column; justify-content:center; height:100%; padding:0 1rem; }
.cart-empty p { font-family:var(--serif); font-size:1.6rem; color:var(--ink); margin-bottom:0.8rem; font-weight:300; }
.cart-empty button { width:100%; padding:1rem; background:var(--ink); color:var(--cream); border:none; border-radius:999px; font-family:var(--mono); font-size:0.62rem; letter-spacing:0.2em; text-transform:uppercase; cursor:pointer; transition:background 0.3s; }

#product-modal { 
  position:fixed; inset:0; z-index:10005; 
  background:rgba(26,23,20,0.4); 
  backdrop-filter: blur(0px); 
  display:flex; align-items:center; justify-content:center; 
  opacity:0; pointer-events:none; 
  transition: opacity 0.5s var(--ease-out), backdrop-filter 0.5s var(--ease-out); 
}
#product-modal.open { 
  opacity:1; pointer-events:auto; backdrop-filter: blur(12px); 
}
.pm-inner { 
  background:var(--cream); border-radius:2.5rem; 
  max-width:800px; width:92vw; max-height:90vh; overflow-y:auto; 
  display:grid; grid-template-columns:1fr 1fr; 
  box-shadow:0 40px 80px rgba(26,23,20,0.15); 
  transform: translateY(40px) scale(0.92); opacity: 0;
  transition: transform 0.7s var(--ease-spring), opacity 0.4s var(--ease-out); 
  position:relative; 
}
#product-modal.open .pm-inner { transform: translateY(0) scale(1); opacity: 1; }

.pm-img { background:var(--cream-2); border-radius:2.5rem 0 0 2.5rem; min-height:400px; position:relative; overflow:hidden; }
.pm-img img { position:absolute; inset:0; width:100%; height:100%; object-fit:cover; mix-blend-mode:multiply; transition:opacity 0.4s var(--ease-out); }
.pm-img img.pm-img-zoom { opacity:0; }
.pm-img.zoom-active img.pm-img-main { opacity:0; }
.pm-img.zoom-active img.pm-img-zoom { opacity:1; }
.pm-toggle-wrap { position:absolute; bottom:1.5rem; left:50%; transform:translateX(-50%); display:flex; gap:0.3rem; background:rgba(248,232,214,0.7); backdrop-filter:blur(12px); border-radius:999px; padding:0.25rem; z-index:5; }
.pm-toggle-btn { font-family:var(--mono); font-size:0.5rem; letter-spacing:0.15em; text-transform:uppercase; padding:0.4rem 0.9rem; border-radius:999px; border:none; background:transparent; color:var(--ink-muted); cursor:pointer; transition:all 0.3s; }
.pm-toggle-btn.active { background:var(--ink); color:var(--cream); }
.pm-body { padding:3.5rem; display:flex; flex-direction:column; justify-content:center; }
.pm-close { position:absolute; top:1rem; right:1rem; width:2.8rem; height:2.8rem; border-radius:50%; border:1px solid rgba(26,23,20,0.1); background:var(--cream); display:flex; align-items:center; justify-content:center; cursor:pointer; z-index:10; box-shadow:0 4px 16px rgba(26,23,20,0.12); }
.pm-close svg { width: 14px; height: 14px; }
.pm-name { font-family:var(--serif); font-size:2.2rem; font-weight:300; margin-bottom:0.3rem; }
.pm-sub { font-family:var(--mono); font-size:0.6rem; letter-spacing:0.18em; text-transform:uppercase; color:var(--ink-muted); margin-bottom:1.5rem; }
.pm-desc { font-size:0.9rem; line-height:1.8; color:var(--ink-muted); margin-bottom:2rem; }
.pm-section-label { font-family:var(--mono); font-size:0.55rem; letter-spacing:0.2em; text-transform:uppercase; color:var(--gold); margin-bottom:0.6rem; }
.pm-allergens { display:flex; flex-wrap:wrap; gap:0.4rem; margin-bottom:1.5rem; }
.pm-allergen-tag { font-family:var(--mono); font-size:0.55rem; letter-spacing:0.1em; padding:0.3rem 0.7rem; border-radius:999px; border:1px solid rgba(26,23,20,0.1); color:var(--ink-muted); }
.pm-price { font-family:var(--serif); font-size:1.8rem; font-weight:300; }
.pm-add-cart {
  display: inline-flex; align-items: center; gap: 0.8rem;
  margin-top: 2rem; padding: 1rem 2.2rem;
  background: var(--ink); color: var(--cream);
  border: 1px solid var(--ink); border-radius: 999px;
  font-family: var(--mono); font-size: 0.65rem;
  letter-spacing: 0.18em; text-transform: uppercase;
  cursor: pointer; transition: background 0.3s var(--ease-spring), transform 0.15s var(--ease-spring);
}
.pm-add-cart:hover { background: var(--gold); }
.pm-add-cart:active { transform: scale(0.96); }
.pm-add-cart svg { stroke: var(--cream); }

#chat-bubble { position: fixed; bottom: 2rem; right: 2rem; z-index: 800; width: 3.2rem; height: 3.2rem; border-radius: 50%; background: var(--ink); border: 1px solid rgba(255,255,255,0.08); display: flex; align-items: center; justify-content: center; cursor: pointer; box-shadow: 0 8px 32px rgba(26,23,20,0.18); transition: transform 0.3s, background 0.3s; }
#chat-bubble:hover { transform: scale(1.08); }
#chat-bubble svg { stroke: var(--cream); }
#chat-bubble .chat-icon-close { display:none; }
#chat-bubble.open .chat-icon-msg { display:none; }
#chat-bubble.open .chat-icon-close { display:block; }
#chat-bubble.open { background: var(--gold); }
#chat-badge { position: absolute; top: -2px; right: -2px; width: 10px; height: 10px; border-radius: 50%; background: var(--gold); border: 2px solid var(--ink); animation: breathe 2s ease-in-out infinite; }
#chat-bubble.open #chat-badge { display: none; }
#chat-window { position: fixed; bottom: 5.5rem; right: 2rem; z-index: 800; width: min(380px, calc(100vw - 2rem)); max-height: min(520px, calc(100dvh - 8rem)); background: var(--cream); border-radius: 1.8rem; border: 1px solid rgba(26,23,20,0.08); box-shadow: 0 24px 80px rgba(26,23,20,0.15); display: flex; flex-direction: column; overflow: hidden; opacity: 0; transform: translateY(12px) scale(0.96); pointer-events: none; transition: opacity 0.35s, transform 0.35s; }
#chat-window.open { opacity: 1; transform: translateY(0) scale(1); pointer-events: auto; }
.chat-header { padding: 1.4rem 1.6rem; border-bottom: 1px solid rgba(26,23,20,0.06); display: flex; align-items: center; gap: 1rem; }
.chat-header-avatar { width: 2rem; height: 2rem; border-radius: 50%; background: var(--ink); display: flex; align-items: center; justify-content: center; }
.chat-messages { flex: 1; overflow-y: auto; padding: 1.2rem 1.4rem; display: flex; flex-direction: column; gap: 0.8rem; }
.chat-msg { max-width: 85%; padding: 0.75rem 1.1rem; font-size: 0.82rem; line-height: 1.65; border-radius: 1.2rem; }
.chat-msg.bot { background: var(--cream-3); color: var(--ink); border-bottom-left-radius: 0.3rem; align-self: flex-start; }
.chat-msg.user { background: var(--ink); color: var(--cream); border-bottom-right-radius: 0.3rem; align-self: flex-end; }
.chat-typing { align-self: flex-start; padding: 0.75rem 1.1rem; background: var(--cream-3); border-radius: 1.2rem; display: none; gap: 0.3rem; align-items: center; }
.chat-typing.show { display: flex; }
.chat-typing-dot { width: 5px; height: 5px; border-radius: 50%; background: var(--ink-muted); animation: typingBounce 1.2s infinite; }
.chat-quick-replies { display: flex; flex-wrap: wrap; gap: 0.4rem; padding: 0 1.4rem 0.8rem; }
.chat-quick-btn { font-family: var(--mono); font-size: 0.55rem; letter-spacing: 0.12em; text-transform: uppercase; padding: 0.45rem 0.9rem; border-radius: 999px; border: 1px solid rgba(26,23,20,0.12); background: transparent; color: var(--ink-muted); cursor: pointer; transition: all 0.2s; }
.chat-quick-btn:hover { background: var(--ink); color: var(--cream); border-color: var(--ink); }
.chat-quick-btn.wa-btn { border-color: var(--gold) !important; color: var(--ink) !important; }
.chat-quick-btn.wa-btn:hover { background: var(--gold) !important; color: var(--white) !important; }
.chat-input-area { padding: 0.8rem 1rem; border-top: 1px solid rgba(26,23,20,0.06); display: flex; align-items: center; gap: 0.6rem; }
.chat-input { flex: 1; border: none; outline: none; background: transparent; font-family: var(--sans); font-size: 0.82rem; color: var(--ink); }
.chat-send { width: 2rem; height: 2rem; border-radius: 50%; background: var(--ink); border: none; display: flex; align-items: center; justify-content: center; cursor: pointer; }

/* ══════════════════════════════════════
   10. KEYFRAME ANIMATIONS
══════════════════════════════════════ */
@keyframes scrollLine { 0% { transform:scaleY(0); transform-origin:top; } 50% { transform:scaleY(1); transform-origin:top; } 50.1%{ transform:scaleY(1); transform-origin:bottom; } 100% { transform:scaleY(0); transform-origin:bottom; } }
@keyframes breathe { 0%, 100% { transform: scale(1); opacity: 0.6; } 50% { transform: scale(1.1); opacity: 1; } }
@keyframes typingBounce { 0%,60%,100% { transform:translateY(0); } 30% { transform:translateY(-4px); } }

/* ════════════════════════════════════════════════════════
   11. ACCESSIBILITÉ : Ajustement global des micro-typographies 
════════════════════════════════════════════════════════ */
.nav-link, .nav-cta, .section-eyebrow, .btn-primary, .btn-ghost, 
.atelier-step-num, .philosophy-divider-text, .order-eyebrow, 
.order-path-num, .order-path-link, .filter-pill, .shop-card-sub, 
.shop-card-price span, .cart-footer-row, .pm-sub, .pm-section-label, 
.pm-allergen-tag, .newsletter-submit, .cta-banner-eyebrow, 
.footer-nav a, .chat-quick-btn {
    font-size: 0.7rem;
}

.scroll-hint-label, .shop-card-zoom-hint, .shop-card-badge-new, 
.cart-item-sub, .pm-toggle-btn, .cart-shipping-tracker p {
    font-size: 0.65rem;
}

.cart-checkout, .cart-whatsapp {
    font-size: 0.75rem;
}

/* ══════════════════════════════════════
   12. RESPONSIVE MEDIA QUERIES
══════════════════════════════════════ */

/* --- TABLETTE --- */
@media (max-width: 1024px) {
  .nav-cta { padding: 0 !important; width: 44px; height: 44px; justify-content: center; gap: 0 !important; border-radius: 50% !important; }
  .cart-text-label { display: none; }
  .nav-cta svg { width: 18px; height: 18px; margin: 0; }
  #cart-count-badge { top: -2px; right: -2px; }

  .atelier-steps-outer { padding-left: 6vw; padding-right: 0; overflow-x: auto; -webkit-overflow-scrolling: touch; scrollbar-width: none; }
  .atelier-steps-outer::-webkit-scrollbar { display: none; } 
  .atelier-steps { display: flex; width: max-content; gap: 2rem; padding-right: 6vw; }
  .atelier-step { width: 320px; flex-shrink: 0; }
}

/* --- MOBILE --- */
@media (max-width: 768px) {
  #navbar { padding: 0.6rem 1rem; }
  
  .nav-cta { width: 38px; height: 38px; }
  .nav-cta svg { width:16px; height:16px; margin: 0; }
  #cart-count-badge { top:-4px; right:-4px; }
  
  .brand-name { font-size: 0.6rem; letter-spacing: 0.15em; margin-left: -5px; }
  .brand-logo { height: 28px; }

  .atelier-header, .boutique-header { grid-template-columns:1fr; }
  .shop-grid { grid-template-columns:1fr 1fr; }
  .philosophy { grid-template-columns:1fr; gap:4rem; }
  .philosophy-visual { height:350px; }
  .phil-img-a { width:60%; }
  .phil-img-b { width:45%; }
  .faq { grid-template-columns:1fr; }
  .faq-left { position:static; margin-bottom:2rem; }
  .newsletter-band { grid-template-columns:1fr; gap:2rem; }
  .cta-banner { grid-template-columns:1fr; text-align:center; }
  .order-grid { grid-template-columns:1fr; }
  .pm-inner { grid-template-columns:1fr; }
  .pm-img { border-radius:2.5rem 2.5rem 0 0; min-height:250px; }
  #chat-bubble { bottom: 1.2rem; right: 1.2rem; }
  #chat-window { bottom: 4.8rem; right: 1.2rem; width: calc(100vw - 2.4rem); }
  #cart-toast { bottom: 5.5rem; }

  .parallax-section { background-attachment: scroll !important; padding: 8rem 6vw !important; min-height: auto !important; background-position: center center !important; }
  
  .atelier-steps { gap: 1.2rem; }
  .atelier-step { width: 82vw; max-width: 280px; }

  /* Le Bouton Sticky sur la modale Produit */
  .pm-body { padding: 2rem 1.5rem 2.5rem; }
  #pmAddCart {
    position: sticky;
    bottom: 1rem;
    width: 100%;
    justify-content: center;
    z-index: 100;
    margin-top: 1.5rem;
    box-shadow: 0 12px 35px rgba(26, 23, 20, 0.4);
  }
}

/* --- PETIT MOBILE --- */
@media (max-width: 480px) {
  .shop-grid { grid-template-columns:1fr; }
  .hero-h1 { font-size: clamp(2.8rem, 10vw, 4rem); }
}

/* ══════════════════════════════════════
   13. CORRECTIFS SPÉCIFIQUES & PC
══════════════════════════════════════ */
@media (hover: none) and (pointer: coarse) {
  .parallax-section { background-attachment: scroll !important; background-position: center center; min-height: 500px; }
}

@media (min-width: 1024px) {
  .atelier-steps-outer { padding: 0 6vw !important; overflow: visible !important; }
  .atelier-steps { display: grid !important; grid-template-columns: repeat(4, 1fr) !important; gap: 2.5vw !important; width: 100% !important; }
  .atelier-step { width: 100% !important; min-width: auto !important; }
  .atelier-step-img { aspect-ratio: 4/3; height: auto; }
}

/* ════════════════════════════════════════════════════════
   14. UX : LOUPE INTERACTIVE DANS LA MODALE PRODUIT
════════════════════════════════════════════════════════ */
#pmImgWrap.loupe-active img.pm-img-main { 
  opacity: 0; 
}
#pmImgWrap.loupe-active img.pm-img-zoom {
  opacity: 1;
  transform: scale(2.2); 
  transition: none; 
  z-index: 2;
}