/* ====================================================
   ARVUM — Premium Olive Oil · Global Styles v2
   ==================================================== */
:root {
  --green-deep:  #1A3A0E;
  --green-mid:   #2D5A1B;
  --green-light: #4A8A2E;
  --gold:        #C9A84C;
  --gold-light:  #E8C97E;
  --gold-dark:   #9A7A2A;
  --cream:       #F7F2E8;
  --cream-dark:  #EDE8DC;
  --black:       #0A0A0A;
  --text-dark:   #1A1A1A;
  --text-mid:    #555555;
  --white:       #ffffff;
  --ease:        cubic-bezier(0.25, 0.46, 0.45, 0.94);
  --transition:  all 0.4s var(--ease);
  --shadow-dark: 0 24px 70px rgba(0,0,0,0.22);
}

/* ---- Reset ---- */
*, *::before, *::after { margin:0; padding:0; box-sizing:border-box; -webkit-tap-highlight-color:transparent; }
html {
  scroll-behavior:smooth; font-size:14px; scroll-padding-top:82px;
  -webkit-text-size-adjust:100%; text-size-adjust:100%;
  overflow-x:hidden;
  width:100%;
}
body {
  font-family:'Inter',sans-serif;
  background:var(--cream); color:var(--text-dark);
  overflow-x:hidden; cursor:none;
  position:relative;
  width:100%;
  max-width:100vw;
}
[lang="ar"] body { font-family:'Noto Sans Arabic','Inter',sans-serif; }
[lang="ar"] h1,[lang="ar"] h2,[lang="ar"] h3 { font-family:'Amiri','Playfair Display',serif; }
@media (max-width:768px){ body{ cursor:auto; } }
img { display:block; max-width:100%; }
a   { text-decoration:none; }
button { cursor:pointer; touch-action:manipulation; }
.btn-primary, .btn-ghost, .btn-submit { touch-action:manipulation; }

/* ====================================================
   GRAIN OVERLAY
   ==================================================== */
.grain-overlay {
  position:fixed; inset:0; z-index:9990;
  pointer-events:none;
  background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='noise'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23noise)' opacity='1'/%3E%3C/svg%3E");
  opacity:0.028;
  mix-blend-mode:overlay;
}

/* ====================================================
   SCROLL PROGRESS BAR
   ==================================================== */
.scroll-progress {
  position:fixed; top:0; left:0; width:0%; height:2px;
  background:linear-gradient(to right, var(--gold-dark), var(--gold), var(--gold-light));
  z-index:9999; transition:width 0.05s linear;
  box-shadow:0 0 8px rgba(201,168,76,0.6);
}

/* ====================================================
   CUSTOM CURSOR
   ==================================================== */
#cursor {
  width:8px; height:8px; background:var(--gold);
  border-radius:50%; position:fixed; top:0; left:0;
  pointer-events:none; z-index:9998;
  transform:translate(-50%,-50%);
  transition:transform 0.15s var(--ease), background 0.3s;
}
#cursor-follower {
  width:34px; height:34px; border:1.5px solid var(--gold);
  border-radius:50%; position:fixed; top:0; left:0;
  pointer-events:none; z-index:9997;
  transform:translate(-50%,-50%);
  transition:transform 0.18s var(--ease), opacity 0.3s;
  opacity:0.55;
}

/* ====================================================
   LOADER
   ==================================================== */
#loader {
  position:fixed; inset:0; background:var(--green-deep);
  z-index:10000; display:flex; align-items:center; justify-content:center;
}
.loader-inner { text-align:center; }
.loader-logo-text {
  display:block; font-family:'Playfair Display',serif;
  font-size:clamp(3.5rem,9vw,6.5rem); color:var(--gold);
  letter-spacing:0.35em; opacity:0; transform:translateY(18px);
  animation:loaderIn 0.9s 0.3s var(--ease) forwards;
}
.loader-tagline {
  display:block; color:rgba(247,242,232,0.6);
  font-size:0.78rem; letter-spacing:0.22em; text-transform:uppercase;
  opacity:0; animation:loaderIn 0.9s 0.7s var(--ease) forwards;
  margin-bottom:2.2rem;
}
.loader-bar { width:220px; height:1px; background:rgba(201,168,76,0.25); margin:0 auto; overflow:hidden; }
.loader-fill { height:100%; width:0; background:var(--gold); animation:loadFill 2.1s 0.5s var(--ease) forwards; }
@keyframes loaderIn { to{ opacity:1; transform:translateY(0); } }
@keyframes loadFill { to{ width:100%; } }

/* ====================================================
   LANGUAGE SWITCHER
   ==================================================== */
.lang-switcher {
  display:flex; align-items:center; gap:2px;
  background:rgba(255,255,255,0.07);
  border:1px solid rgba(255,255,255,0.12);
  border-radius:3px; padding:2px;
}
.lang-btn {
  background:none; border:none; color:rgba(255,255,255,0.5);
  font-size:0.7rem; font-weight:600; letter-spacing:0.08em;
  padding:0.32rem 0.55rem; border-radius:2px;
  transition:var(--transition); font-family:'Inter',sans-serif;
  text-transform:uppercase;
}
.lang-btn:hover   { color:var(--gold); background:rgba(201,168,76,0.1); }
.lang-btn.is-active { color:var(--black); background:var(--gold); }

.mobile-lang { margin-top:1.5rem; background:rgba(255,255,255,0.06); }
.mobile-lang .lang-btn { font-size:0.85rem; padding:0.5rem 0.9rem; }

/* ====================================================
   NAVBAR
   ==================================================== */
#navbar {
  position:fixed; top:0; left:0; right:0; z-index:1000;
  padding:1.4rem 0; transition:var(--transition);
  -webkit-transform:translate3d(0,0,0);
  transform:translate3d(0,0,0);
  will-change:transform;
  background:linear-gradient(to bottom, rgba(5,10,3,0.55) 0%, transparent 100%);
}
#navbar.scrolled {
  background:rgba(10,10,10,0.95); backdrop-filter:blur(22px);
  -webkit-backdrop-filter:blur(22px); padding:0.9rem 0;
  box-shadow:0 4px 40px rgba(0,0,0,0.35);
}
.nav-container {
  max-width:1220px; margin:0 auto; padding:0 2rem;
  display:flex; align-items:center; justify-content:space-between; gap:1rem;
  min-height:0;
}
.nav-logo {
  font-family:'Playfair Display',serif; font-size:1.8rem; font-weight:700;
  color:var(--gold); letter-spacing:0.22em;
  transition:text-shadow 0.3s;
}
.nav-logo:hover { text-shadow:0 0 20px rgba(201,168,76,0.5); }

.nav-links { display:flex; align-items:center; gap:2rem; }
.nav-links a {
  color:var(--white); font-size:0.78rem; letter-spacing:0.12em;
  text-transform:uppercase; opacity:0.78; position:relative;
  transition:color 0.3s, opacity 0.3s;
}
.nav-links a::after {
  content:''; position:absolute; bottom:-4px; left:0; width:0; height:1px;
  background:var(--gold); transition:width 0.35s var(--ease);
}
.nav-links a:hover { opacity:1; color:var(--gold-light); }
.nav-links a:hover::after { width:100%; }

.nav-cta {
  background:var(--gold) !important; color:var(--black) !important;
  padding:0.5rem 1.3rem !important; border-radius:2px !important;
  opacity:1 !important; font-weight:600 !important;
  letter-spacing:0.06em !important; display:flex !important; align-items:center;
  transition:background 0.3s, transform 0.3s !important;
}
.nav-cta::after { display:none !important; }
.nav-cta:hover  { background:var(--gold-light) !important; transform:translateY(-2px) !important; }

.nav-toggle { display:none; flex-direction:column; gap:5px; background:none; border:none; padding:6px; }
.nav-toggle span { display:block; width:26px; height:2px; background:var(--white); transition:var(--transition); }
.nav-toggle.open span:nth-child(1) { transform:translateY(7px) rotate(45deg); }
.nav-toggle.open span:nth-child(2) { opacity:0; }
.nav-toggle.open span:nth-child(3) { transform:translateY(-7px) rotate(-45deg); }

/* ====================================================
   MOBILE MENU
   ==================================================== */
.mobile-menu {
  position:fixed; inset:0; background:var(--green-deep);
  z-index:999; display:flex; flex-direction:column;
  align-items:center; justify-content:center; gap:1.6rem;
  opacity:0; pointer-events:none; transition:opacity 0.45s var(--ease);
}
.mobile-menu.open { opacity:1; pointer-events:all; }
.mobile-menu a {
  font-family:'Playfair Display',serif; font-size:clamp(1.6rem,5vw,2.4rem);
  color:var(--cream); letter-spacing:0.08em; transition:color 0.3s;
}
.mobile-menu a:hover { color:var(--gold); }
.mobile-menu-close {
  position:absolute; top:2rem; right:2rem; background:none; border:none;
  color:rgba(255,255,255,0.4); font-size:2.5rem; line-height:1; transition:color 0.3s;
}
.mobile-menu-close:hover { color:var(--gold); }

/* ====================================================
   FLOATING WHATSAPP BUTTON
   ==================================================== */
.wa-float {
  position:fixed; bottom:2rem; right:2rem; z-index:9000;
  width:58px; height:58px; border-radius:50%;
  background:#25D366; color:#fff;
  display:flex; align-items:center; justify-content:center;
  box-shadow:0 6px 30px rgba(37,211,102,0.4);
  transition:transform 0.35s var(--ease), box-shadow 0.35s;
}
.wa-float:hover { transform:scale(1.12) translateY(-3px); box-shadow:0 12px 40px rgba(37,211,102,0.55); }
.wa-float-pulse {
  position:absolute; inset:-6px; border-radius:50%;
  border:2px solid rgba(37,211,102,0.5);
  animation:waPulse 2.5s ease-out infinite;
}
@keyframes waPulse {
  0%   { transform:scale(0.9); opacity:1; }
  100% { transform:scale(1.5); opacity:0; }
}

/* ====================================================
   HERO
   ==================================================== */
#hero { height:100vh; min-height:680px; position:relative; display:flex; align-items:center; overflow:hidden; width:100%; max-width:100vw; }
section, footer { max-width:100vw; overflow-x:hidden; }

#heroParticles {
  position:absolute; inset:0; z-index:1; pointer-events:none;
  width:100% !important; height:100% !important;
}
.hero-video {
  position:absolute; inset:0; width:100%; height:100%;
  object-fit:cover; z-index:0; pointer-events:none;
}
.hero-overlay {
  position:absolute; inset:0;
  background:linear-gradient(130deg, rgba(8,18,4,0.9) 0%, rgba(26,58,14,0.68) 45%, rgba(8,12,5,0.5) 100%);
  z-index:2;
}
.hero-content {
  position:relative; z-index:3; max-width:1220px; margin:0 auto;
  padding:0 2.5rem; width:100%; display:flex; align-items:center;
  justify-content:space-between; gap:4rem;
}
.hero-text { max-width:580px; }

.hero-tagline {
  font-size:0.78rem; letter-spacing:0.35em; text-transform:uppercase;
  color:var(--gold); margin-bottom:1.4rem;
  opacity:0; transform:translateY(20px);
}
.hero-title {
  font-family:'Playfair Display',serif;
  font-size:clamp(2.8rem,5.5vw,5.2rem); line-height:1.1; color:var(--white);
  margin-bottom:1.4rem; opacity:0; transform:translateY(30px);
}
.hero-title em { color:var(--gold); font-style:italic; }

.hero-desc {
  font-size:0.95rem; color:rgba(255,255,255,0.68); letter-spacing:0.18em;
  text-transform:uppercase; margin-bottom:2.8rem;
  opacity:0; transform:translateY(20px);
}
.hero-actions { display:flex; gap:1rem; flex-wrap:wrap; opacity:0; transform:translateY(20px); }
.hero-bottle {
  position: absolute; right: 0; top: 0; bottom: 0;
  left: 50%; z-index: 3; pointer-events: none;
  display: flex; align-items: center; justify-content: center;
}
.bottles-composition {
  display: flex; align-items: flex-end; justify-content: center;
  height: 100%; padding-bottom: 26vh;
}
.bottle-img {
  object-fit: contain; display: block; flex-shrink: 0;
  filter: drop-shadow(0 32px 64px rgba(0,0,0,0.72)) drop-shadow(0 8px 22px rgba(201,168,76,0.25));
  margin-left: -3vw;
}
.bottle-lg {
  height: min(56vh, 440px);
  animation: bottleFloat 3.4s ease-in-out infinite;
  position: relative; z-index: 3;
}
.bottle-md {
  height: min(42vh, 330px);
  animation: bottleFloat 2.9s ease-in-out infinite;
  animation-delay: 0.55s;
  position: relative; z-index: 2;
}
.bottle-sm {
  height: min(30vh, 235px);
  animation: bottleFloat 3.8s ease-in-out infinite;
  animation-delay: 1.1s;
  position: relative; z-index: 1;
}
@keyframes bottleFloat {
  0%,100% { transform: translateY(0px); }
  50%     { transform: translateY(-20px); }
}

.hero-scroll-indicator {
  position:absolute; bottom:2.5rem; left:50%; transform:translateX(-50%);
  z-index:3; text-align:center; color:rgba(255,255,255,0.45);
  font-size:0.7rem; letter-spacing:0.22em; text-transform:uppercase;
}
.scroll-line {
  width:1px; height:52px;
  background:linear-gradient(to bottom, var(--gold), transparent);
  margin:0.6rem auto 0; animation:scrollPulse 2.2s ease-in-out infinite;
}
@keyframes scrollPulse {
  0%,100%{ opacity:1; transform:scaleY(1) translateY(0); }
  50%    { opacity:0.3; transform:scaleY(0.7) translateY(6px); }
}

/* ====================================================
   BUTTONS
   ==================================================== */
.btn-primary {
  display:inline-block; padding:0.9rem 2.4rem; background:var(--gold); color:var(--black);
  font-size:0.8rem; font-weight:600; letter-spacing:0.12em; text-transform:uppercase;
  border-radius:2px; border:2px solid var(--gold); transition:var(--transition);
  position:relative; overflow:hidden;
}
.btn-primary::after {
  content:''; position:absolute; inset:0;
  background:rgba(255,255,255,0.15);
  transform:translateX(-100%) skewX(-15deg);
  transition:transform 0.5s var(--ease);
}
.btn-primary:hover::after { transform:translateX(120%) skewX(-15deg); }
.btn-primary:hover { background:transparent; color:var(--gold); transform:translateY(-2px); box-shadow:0 12px 40px rgba(201,168,76,0.28); }

.btn-ghost {
  display:inline-block; padding:0.9rem 2.4rem; background:transparent; color:var(--white);
  font-size:0.8rem; font-weight:500; letter-spacing:0.12em; text-transform:uppercase;
  border-radius:2px; border:1px solid rgba(255,255,255,0.38); transition:var(--transition);
}
.btn-ghost:hover { border-color:var(--gold); color:var(--gold); transform:translateY(-2px); }

/* Magnetic wrapper — set by JS */
.magnetic { display:inline-block; }

/* Ripple on click */
.ripple-effect {
  position:absolute; border-radius:50%; background:rgba(255,255,255,0.3);
  transform:scale(0); animation:rippleAnim 0.7s linear; pointer-events:none;
}
@keyframes rippleAnim { to{ transform:scale(4); opacity:0; } }

/* ====================================================
   SHARED TYPOGRAPHY
   ==================================================== */
.section-label {
  display:block; font-size:0.72rem; letter-spacing:0.38em;
  text-transform:uppercase; color:var(--gold); margin-bottom:0.9rem;
}
.section-label.light { color:var(--gold-light); }
.section-title {
  font-family:'Playfair Display',serif;
  font-size:clamp(2rem,3.8vw,3.4rem); line-height:1.18; color:var(--text-dark); margin-bottom:1.4rem;
}
@supports (text-wrap:balance) {
  .section-title, .hero-title { text-wrap:balance; }
}
.section-title em             { color:var(--gold); font-style:italic; }
.section-title.light          { color:var(--white); }
.section-title.light em       { color:var(--gold-light); }
.section-title.light-on-dark  { color:var(--white); }
.section-title.light-on-dark em { color:var(--gold); }
.section-header { text-align:center; margin-bottom:4.5rem; }
.divider-gold {
  width:56px; height:2px;
  background:linear-gradient(to right, transparent, var(--gold), transparent);
  margin:0.8rem 0 2rem;
}
.divider-gold.centered { margin-left:auto; margin-right:auto; }

/* Gold shimmer animation */
@keyframes shimmer {
  0%   { background-position: -200% center; }
  100% { background-position:  200% center; }
}
.shimmer-gold {
  background:linear-gradient(90deg, var(--gold-dark) 25%, var(--gold-light) 50%, var(--gold-dark) 75%);
  background-size:200% auto;
  -webkit-background-clip:text; -webkit-text-fill-color:transparent;
  background-clip:text;
  animation:shimmer 4s linear infinite;
}

/* ====================================================
   ACCESSIBILITY — FOCUS VISIBLE
   ==================================================== */
:focus-visible {
  outline: 2px solid var(--gold);
  outline-offset: 3px;
}
button:focus-visible, a:focus-visible { outline: 2px solid var(--gold); outline-offset: 3px; border-radius:2px; }

/* ====================================================
   CONTAINER
   ==================================================== */
.container { max-width:1220px; margin:0 auto; padding:0 2.5rem; }

/* ====================================================
   PARALLAX
   ==================================================== */
.parallax-bg { background-size:cover; background-position:center; will-change:transform; }
@media (max-width:768px){ .parallax-bg{ background-attachment:scroll; } }

/* ====================================================
   ABOUT
   ==================================================== */
#about { padding:8rem 0; background:var(--cream); }
.about-grid { display:grid; grid-template-columns:1fr 1fr; gap:6rem; align-items:center; }
.about-image { position:relative; }
.about-image img { width:100%; height:580px; object-fit:cover; object-position:center top; box-shadow:var(--shadow-dark); }
.about-badge {
  position:absolute; bottom:-2rem; right:-2rem;
  background:var(--green-deep); padding:1.6rem 2.2rem; text-align:center;
  border:1px solid var(--gold-dark); box-shadow:var(--shadow-dark);
}
.badge-year { display:block; font-family:'Playfair Display',serif; font-size:2.8rem; color:var(--gold); line-height:1; }
.badge-text { display:block; font-size:0.72rem; color:var(--cream); letter-spacing:0.12em; text-transform:uppercase; margin-top:0.3rem; }

.about-content p { color:var(--text-mid); line-height:1.85; margin-bottom:1.5rem; font-size:1rem; }
.about-content em { color:var(--green-mid); font-style:italic; }
.about-stats { display:flex; gap:3rem; margin:2.5rem 0 2.8rem; padding-top:2rem; border-top:1px solid var(--cream-dark); }
.stat-num { display:block; font-family:'Playfair Display',serif; font-size:2.4rem; color:var(--gold); line-height:1; }
.stat-label { display:block; font-size:0.75rem; color:var(--text-mid); letter-spacing:0.1em; text-transform:uppercase; margin-top:0.3rem; }

/* ====================================================
   HERITAGE
   ==================================================== */
#heritage { position:relative; padding:10rem 0; overflow:hidden; }
.heritage-bg { position:absolute; inset:-25%; z-index:0; }
.heritage-overlay { position:absolute; inset:0; z-index:1; background:linear-gradient(to bottom, rgba(8,20,4,0.76), rgba(22,50,12,0.88)); }
#heritage .container { position:relative; z-index:2; }
.heritage-content { max-width:860px; margin:0 auto; text-align:center; }
.heritage-text { color:rgba(255,255,255,0.78); font-size:1.08rem; line-height:1.85; margin-bottom:4.5rem; }
.heritage-pillars { display:grid; grid-template-columns:repeat(4,1fr); gap:1.5rem; }
.pillar {
  padding:2.2rem 1.4rem; border:1px solid rgba(201,168,76,0.25);
  background:rgba(0,0,0,0.22); backdrop-filter:blur(12px);
  -webkit-backdrop-filter:blur(12px); transition:var(--transition);
}
@media (hover:hover){ .pillar:hover { border-color:var(--gold); background:rgba(201,168,76,0.1); transform:translateY(-6px); box-shadow:0 20px 50px rgba(0,0,0,0.3); } }
.pillar-icon { font-size:2rem; margin-bottom:1rem; }
.pillar h3 { font-family:'Playfair Display',serif; color:var(--gold); font-size:1rem; margin-bottom:0.5rem; }
.pillar p  { font-size:0.83rem; color:rgba(255,255,255,0.65); line-height:1.6; }

/* ====================================================
   PRODUCTS
   ==================================================== */
#products { padding:8rem 0; background:var(--black); }
.products-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:2rem; margin-bottom:3rem; }
.product-card {
  background:rgba(255,255,255,0.03); border:1px solid rgba(255,255,255,0.07);
  padding:3.5rem 2rem 2.5rem; text-align:center; position:relative;
  transition:var(--transition); overflow:hidden;
  transform-style:preserve-3d; will-change:transform;
}
.product-card::before {
  content:''; position:absolute; inset:0;
  background:linear-gradient(140deg, transparent, rgba(201,168,76,0.06));
  opacity:0; transition:opacity 0.45s;
}
@media (hover:hover){
  .product-card:hover { border-color:rgba(201,168,76,0.5); box-shadow:0 40px 90px rgba(0,0,0,0.45); }
  .product-card:hover::before { opacity:1; }
}
.product-card.featured { border-color:rgba(201,168,76,0.4); background:rgba(201,168,76,0.05); }
.product-featured-label {
  position:absolute; top:1.4rem; left:50%; transform:translateX(-50%);
  font-size:0.68rem; letter-spacing:0.18em; text-transform:uppercase; color:var(--gold);
  white-space:nowrap; padding:0.28rem 1.1rem; border:1px solid rgba(201,168,76,0.5);
}
.product-bottle-wrap {
  position:relative; width:min(220px,85%); height:300px;
  margin:0 auto 2rem;
  display:flex; align-items:flex-end; justify-content:center;
}
.product-glow {
  position:absolute; bottom:-5px; left:50%; transform:translateX(-50%);
  width:180px; height:50px;
  background:radial-gradient(ellipse, rgba(201,168,76,0.35), transparent 70%);
  filter:blur(10px);
}
.featured-glow { width:220px; background:radial-gradient(ellipse, rgba(201,168,76,0.55), transparent 70%); }

/* Bouteille : taille contrôlée par height de l'img, alignée au bas du wrap */
.product-img {
  width:auto; max-width:100%;
  object-fit:contain;
  display:block;
  transition:transform 0.55s var(--ease);
  filter:drop-shadow(0 24px 40px rgba(0,0,0,0.6));
}
@media (hover:hover){ .product-card:hover .product-img { transform:scale(1.06) rotateY(8deg); } }

/* 250ml petite · 500ml moyenne · 750ml grande — toutes alignées au bas */
.products-grid .product-card:nth-child(1) .product-img { height:160px; }
.products-grid .product-card:nth-child(2) .product-img { height:230px; }
.products-grid .product-card:nth-child(3) .product-img { height:290px; }
.product-size { display:block; font-size:0.72rem; letter-spacing:0.22em; color:var(--gold); text-transform:uppercase; margin-bottom:0.5rem; }
.product-info h3 { font-family:'Playfair Display',serif; font-size:1.3rem; color:var(--white); margin-bottom:0.9rem; }
.product-info p  { font-size:0.88rem; color:rgba(255,255,255,0.55); line-height:1.72; margin-bottom:1.5rem; }
.product-tags { display:flex; gap:0.5rem; justify-content:center; }
.product-badge { display:inline-block; padding:0.32rem 1rem; border:1px solid rgba(201,168,76,0.35); font-size:0.68rem; letter-spacing:0.15em; text-transform:uppercase; color:var(--gold); }
.products-note { text-align:center; color:rgba(255,255,255,0.35); font-size:0.82rem; letter-spacing:0.06em; padding-top:2.5rem; border-top:1px solid rgba(255,255,255,0.07); }
.products-note strong { color:rgba(255,255,255,0.65); }

/* ====================================================
   PROCESS — ANIMATED TIMELINE REDESIGN
   ==================================================== */
#process { position:relative; padding:10rem 0 6rem; overflow:hidden; isolation:isolate; }
.process-bg { position:absolute; inset:-25%; z-index:0; }
.process-overlay { position:absolute; inset:0; z-index:1; background:rgba(6,6,6,0.93); }
#process .container { position:relative; z-index:2; }

/* --- Timeline Wrapper --- */
.tl-wrapper {
  position:relative;
  max-width:960px;
  margin:0 auto 5rem;
  overflow-x:hidden;
}

/* Vertical track */
.tl-track {
  position:absolute; left:50%; top:0; bottom:0; width:2px;
  background:rgba(201,168,76,0.1); transform:translateX(-50%);
  overflow:hidden;
}
.tl-fill {
  width:100%; height:0%;
  background:linear-gradient(to bottom, var(--gold-dark), var(--gold), var(--gold-light));
  box-shadow:0 0 12px rgba(201,168,76,0.6);
  transition:height 0.08s linear;
}

/* Timeline Row */
.tl-row {
  display:grid; grid-template-columns:1fr 80px 1fr;
  align-items:center; position:relative; margin-bottom:3rem;
}

/* Center column with node */
.tl-center-col { display:flex; align-items:center; justify-content:center; }

/* Node badge */
.tl-node {
  width:60px; height:60px; border-radius:50%;
  background:var(--black); border:2px solid rgba(201,168,76,0.3);
  display:flex; align-items:center; justify-content:center;
  font-family:'Playfair Display',serif; font-size:1rem; color:rgba(201,168,76,0.5);
  position:relative; z-index:2; transition:all 0.5s var(--ease);
}
.tl-node.lit {
  border-color:var(--gold); color:var(--gold);
  background:rgba(201,168,76,0.1);
  box-shadow:0 0 24px rgba(201,168,76,0.4), 0 0 50px rgba(201,168,76,0.12);
}
/* Ripple rings when lit */
.tl-node.lit::before,.tl-node.lit::after {
  content:''; position:absolute; border-radius:50%;
  border:1px solid rgba(201,168,76,0.3); animation:nodeRipple 2.5s ease-out infinite;
}
.tl-node.lit::before { inset:-12px; animation-delay:0s; }
.tl-node.lit::after  { inset:-22px; animation-delay:0.6s; }
@keyframes nodeRipple { 0%{ transform:scale(0.85); opacity:1; } 100%{ transform:scale(1.35); opacity:0; } }

/* Spacer col */
.tl-spacer {}

/* Card col */
.tl-card-col { padding:0 1.5rem; }

/* Timeline Card */
.tl-card {
  background:rgba(18,18,18,0.85);
  backdrop-filter:blur(20px); -webkit-backdrop-filter:blur(20px);
  border:1px solid rgba(255,255,255,0.05);
  border-left:3px solid rgba(201,168,76,0.3);
  padding:2rem 2.2rem; position:relative; overflow:hidden;
  transition:all 0.55s var(--ease);
}
.tl-card::before {
  content:attr(data-num); position:absolute; top:-0.8rem; right:1rem;
  font-family:'Playfair Display',serif; font-size:5.5rem; line-height:1;
  color:rgba(201,168,76,0.05); pointer-events:none;
}
@media (hover:hover){
.tl-card:hover {
  border-left-color:var(--gold);
  background:rgba(26,26,26,0.95);
  transform:translateY(-4px) scale(1.01);
  box-shadow:0 20px 60px rgba(0,0,0,0.5), 0 0 30px rgba(201,168,76,0.06);
}
}

/* Right-aligned cards (tl-right) get border on right */
.tl-right .tl-card { border-left:none; border-right:3px solid rgba(201,168,76,0.3); }
.tl-right .tl-card:hover { border-right-color:var(--gold); }
.tl-right .tl-card::before { right:auto; left:1rem; }

.tl-icon-wrap { margin-bottom:0.9rem; }
.tl-icon { font-size:2rem; display:inline-block; animation:iconFloat 3.5s ease-in-out infinite; }
.tl-row[data-tl="2"] .tl-icon { animation-delay:-1.2s; }
.tl-row[data-tl="3"] .tl-icon { animation-delay:-0.5s; }
.tl-row[data-tl="4"] .tl-icon { animation-delay:-2.1s; }
.tl-row[data-tl="5"] .tl-icon { animation-delay:-0.9s; }
.tl-row[data-tl="6"] .tl-icon { animation-delay:-1.7s; }
@keyframes iconFloat { 0%,100%{ transform:translateY(0) rotate(0deg); } 50%{ transform:translateY(-7px) rotate(4deg); } }

.tl-card h3 { font-family:'Playfair Display',serif; color:var(--white); font-size:1.2rem; margin-bottom:0.6rem; }
.tl-card p  { font-size:0.86rem; color:rgba(255,255,255,0.5); line-height:1.75; }

/* Timeline card reveal animations */
.tl-left  .tl-card { opacity:0; transform:translateX(-55px) rotateY(6deg); }
.tl-right .tl-card { opacity:0; transform:translateX(55px) rotateY(-6deg); }
.tl-left  .tl-card.tl-visible { opacity:1; transform:none; }
.tl-right .tl-card.tl-visible { opacity:1; transform:none; }

/* Process catalogue images */
.process-catalogue { display:grid; grid-template-columns:1fr 1fr; gap:1.5rem; }
.process-catalogue img { width:100%; height:320px; object-fit:cover; border:1px solid rgba(201,168,76,0.15); transition:transform 0.6s var(--ease); }
.process-catalogue img:hover { transform:scale(1.02); }

/* ====================================================
   QUALITY
   ==================================================== */
#quality { padding:8rem 0; background:var(--cream); }
.quality-grid { display:grid; grid-template-columns:1fr 1fr; gap:6rem; align-items:center; }
.quality-list { list-style:none; margin:1.8rem 0 3rem; }
.quality-list li { padding:0.85rem 0; border-bottom:1px solid var(--cream-dark); color:var(--text-mid); font-size:0.95rem; display:flex; align-items:center; gap:0.9rem; transition:color 0.3s; }
.quality-list li:hover { color:var(--text-dark); }
.check { color:var(--gold); font-size:0.85rem; flex-shrink:0; }
.quality-image { position:relative; }
.quality-image img { width:100%; height:auto; min-height:280px; max-height:560px; object-fit:contain; }
.quality-cert {
  position:absolute; bottom:2rem; left:2rem; right:2rem;
  background:rgba(8,8,8,0.92); backdrop-filter:blur(14px); -webkit-backdrop-filter:blur(14px);
  padding:1.3rem 1.6rem; display:flex; align-items:center; gap:1.2rem; border-left:3px solid var(--gold);
}
.cert-icon { font-size:2rem; }
.quality-cert strong { display:block; color:var(--gold); font-size:0.9rem; letter-spacing:0.06em; }
.quality-cert span   { font-size:0.73rem; color:rgba(255,255,255,0.55); display:block; margin-top:0.2rem; }

/* ====================================================
   GALLERY
   ==================================================== */
#gallery { padding:8rem 0; background:var(--black); }
.gallery-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:0.9rem; }
.gallery-item { position:relative; overflow:hidden; aspect-ratio:4/3; cursor:pointer; }
.gallery-item img { width:100%; height:100%; object-fit:cover; transition:transform 0.65s var(--ease); }
.gallery-overlay {
  position:absolute; inset:0; background:linear-gradient(to top, rgba(8,20,4,0.88) 0%, transparent 55%);
  opacity:0; transition:opacity 0.4s; display:flex; align-items:flex-end; justify-content:center; padding-bottom:1.8rem;
}
.gallery-overlay span { color:var(--gold); font-size:0.74rem; letter-spacing:0.3em; text-transform:uppercase; border-bottom:1px solid var(--gold); padding-bottom:0.28rem; }
@media (hover:hover){
  .gallery-item:hover img              { transform:scale(1.08); }
  .gallery-item:hover .gallery-overlay { opacity:1; }
}

/* ====================================================
   LIGHTBOX
   ==================================================== */
.lightbox {
  position:fixed; inset:0; background:rgba(0,0,0,0.96); z-index:9000;
  display:flex; align-items:center; justify-content:center;
  opacity:0; pointer-events:none; transition:opacity 0.4s var(--ease);
}
.lightbox.active { opacity:1; pointer-events:all; }
.lightbox img { max-width:88vw; max-height:84vh; object-fit:contain; box-shadow:0 0 100px rgba(0,0,0,0.9); }
.lightbox-close,.lightbox-prev,.lightbox-next { background:none; border:none; color:rgba(255,255,255,0.65); position:absolute; transition:color 0.3s; line-height:1; }
.lightbox-close { top:1.8rem; right:2rem; font-size:3rem; }
.lightbox-prev  { left:2rem;  top:50%; transform:translateY(-50%); font-size:3rem; }
.lightbox-next  { right:2rem; top:50%; transform:translateY(-50%); font-size:3rem; }
.lightbox-close:hover,.lightbox-prev:hover,.lightbox-next:hover { color:var(--gold); }

/* ====================================================
   CONTACT
   ==================================================== */
#contact { position:relative; padding:10rem 0; overflow:hidden; }
.contact-bg { position:absolute; inset:-25%; z-index:0; }
.contact-overlay { position:absolute; inset:0; z-index:1; background:rgba(8,18,4,0.91); }
#contact .container { position:relative; z-index:2; }
.contact-content { max-width:680px; margin:0 auto; text-align:center; }
.contact-desc { color:rgba(255,255,255,0.65); font-size:1rem; line-height:1.82; margin-bottom:3rem; }
.contact-form { text-align:left; }
.form-row { display:grid; grid-template-columns:1fr 1fr; gap:1rem; margin-bottom:1rem; }
.contact-form input,.contact-form select,.contact-form textarea {
  width:100%; padding:1rem 1.25rem; background:rgba(255,255,255,0.07);
  border:1px solid rgba(255,255,255,0.14); color:var(--white); border-radius:2px;
  font-family:'Inter',sans-serif; font-size:0.92rem; outline:none;
  transition:border-color 0.3s, background 0.3s; margin-bottom:1rem;
  -webkit-appearance:none; appearance:none;
}
.contact-form select { background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%23C9A84C' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E"); background-repeat:no-repeat; background-position:right 1.2rem center; padding-right:2.8rem; cursor:pointer; }
.contact-form input::placeholder,.contact-form textarea::placeholder { color:rgba(255,255,255,0.32); }
.contact-form select option { background:var(--green-deep); color:var(--white); }
.contact-form textarea      { resize:vertical; min-height:120px; }
.contact-form input:focus,.contact-form select:focus,.contact-form textarea:focus { border-color:var(--gold); background:rgba(201,168,76,0.06); }
.btn-submit { display:block; width:100%; text-align:center; font-family:'Inter',sans-serif; border:2px solid var(--gold); }

/* ====================================================
   FOOTER
   ==================================================== */
footer { background:var(--black); padding:5.5rem 0 2.5rem; border-top:1px solid rgba(255,255,255,0.04); }
.footer-grid { display:grid; grid-template-columns:2fr 1fr 1fr; gap:4.5rem; margin-bottom:4rem; }
.footer-logo { font-family:'Playfair Display',serif; font-size:2.1rem; color:var(--gold); letter-spacing:0.22em; margin-bottom:1.5rem; }
.footer-brand p { font-size:0.88rem; color:rgba(255,255,255,0.45); line-height:1.85; max-width:330px; margin-bottom:2rem; }

/* Social Icons */
.social-icons { display:flex; gap:0.8rem; align-items:center; }
.social-icon {
  width:40px; height:40px; border-radius:50%;
  border:1px solid rgba(255,255,255,0.12);
  display:flex; align-items:center; justify-content:center;
  color:rgba(255,255,255,0.45);
  transition:var(--transition);
}
.social-icon svg { width:18px; height:18px; }
.social-icon:hover { border-color:var(--gold); color:var(--gold); transform:translateY(-3px); box-shadow:0 8px 25px rgba(201,168,76,0.25); background:rgba(201,168,76,0.08); }
.social-icon.social-wa:hover { border-color:#25D366; color:#25D366; box-shadow:0 8px 25px rgba(37,211,102,0.3); background:rgba(37,211,102,0.08); }

.footer-links h4,.footer-contact h4 {
  font-family:'Playfair Display',serif; color:var(--white); font-size:1rem;
  letter-spacing:0.1em; margin-bottom:1.6rem; padding-bottom:0.8rem;
  border-bottom:1px solid rgba(201,168,76,0.28);
}
.footer-links a { display:block; color:rgba(255,255,255,0.45); font-size:0.84rem; margin-bottom:0.8rem; letter-spacing:0.05em; transition:color 0.3s; }
.footer-links a:hover { color:var(--gold); }
.footer-contact p { font-size:0.84rem; color:rgba(255,255,255,0.45); margin-bottom:0.8rem; word-break:break-word; overflow-wrap:break-word; }
.footer-contact-item {
  display:flex; align-items:center; gap:0.7rem;
  margin-bottom:0.9rem !important;
}
.footer-contact-item svg {
  color:var(--gold); flex-shrink:0;
  transition:transform 0.3s var(--ease);
}
.footer-contact .footer-contact-item a,
.footer-contact .footer-contact-item a:link,
.footer-contact .footer-contact-item a:visited,
.footer-contact .footer-contact-item a:active {
  color:rgba(255,255,255,0.55) !important;
  font-size:0.86rem; letter-spacing:0.02em;
  transition:color 0.3s var(--ease);
  word-break:break-word; overflow-wrap:anywhere;
  text-decoration:none;
}
.footer-contact .footer-contact-item a:hover {
  color:var(--gold) !important;
}
.footer-contact-item:hover svg { transform:scale(1.15) rotate(-4deg); }
.footer-bottom { padding-top:2rem; border-top:1px solid rgba(255,255,255,0.05); text-align:center; }
.footer-bottom p { font-size:0.78rem; color:rgba(255,255,255,0.22); letter-spacing:0.06em; }

/* ====================================================
   SCROLL REVEAL
   ==================================================== */
.reveal-up,.reveal-left,.reveal-right {
  opacity:0;
  transition:opacity 0.85s var(--ease), transform 0.85s var(--ease);
  will-change:opacity, transform;
}
.reveal-up    { transform:translateY(44px); }
.reveal-left  { transform:translateX(-52px); }
.reveal-right { transform:translateX(52px); }
.reveal-up.visible,.reveal-left.visible,.reveal-right.visible { opacity:1; transform:translate(0); }

/* Sur mobile : translations verticales uniquement pour éviter overflow horizontal */
@media (max-width:680px){
  .reveal-left, .reveal-right { transform:translateY(30px); }
}

/* ====================================================
   RTL SUPPORT (Arabic)
   ==================================================== */
[dir="rtl"] .hero-bottle      { right:42%; left:0; }
[dir="rtl"] .bottles-composition { flex-direction:row-reverse; }
[dir="rtl"] .bottle-img      { margin-left:0; margin-right:-3vw; }
[dir="rtl"] .nav-links        { flex-direction:row-reverse; }
[dir="rtl"] .about-badge      { right:auto; left:-2rem; }
[dir="rtl"] .divider-gold     { margin-left:0; margin-right:0; }
[dir="rtl"] .tl-left          { direction:rtl; }
[dir="rtl"] .tl-right         { direction:rtl; }
[dir="rtl"] .tl-card          { border-left:none; border-right:3px solid rgba(201,168,76,0.3); }
[dir="rtl"] .tl-card:hover    { border-right-color:var(--gold); }
[dir="rtl"] .tl-right .tl-card { border-right:none; border-left:3px solid rgba(201,168,76,0.3); }
[dir="rtl"] .quality-cert     { border-left:none; border-right:3px solid var(--gold); }
[dir="rtl"] .footer-brand p   { margin-right:0; margin-left:auto; }
[dir="rtl"] .contact-form     { text-align:right; }
[dir="rtl"] .quality-list li  { flex-direction:row-reverse; }

/* ====================================================
   RESPONSIVE — HERO TEXT OVERLAP FIX (mid-range)
   ==================================================== */
@media (min-width:961px) and (max-width:1200px){
  .hero-text { max-width:44vw; }
}

/* ====================================================
   RESPONSIVE — TABLET
   ==================================================== */
@media (max-width:1100px){
  .heritage-pillars { grid-template-columns:repeat(2,1fr); }
  .footer-grid      { grid-template-columns:1fr 1fr; gap:3rem; }
  .footer-brand     { grid-column:1 / -1; }
  .nav-links        { gap:1.4rem; }
  #navbar .lang-switcher { display:none; } /* hide navbar switcher — mobile menu has its own */
}

@media (max-width:960px){
  .nav-links  { display:none; }
  .nav-toggle { display:flex; padding:10px; }
  #navbar .lang-switcher { display:none; }

  /* --- Hero mobile: contenu centré + bouteilles SOUS le texte avec respiration --- */
  #hero {
    min-height:100vh; min-height:100svh; height:auto;
    flex-direction:column; justify-content:center; align-items:stretch;
    padding:6rem 0 2.5rem;
  }
  .hero-content { justify-content:center; text-align:center; padding:0 1.5rem; gap:1.2rem; order:1; }
  .hero-text    { max-width:600px; }
  .hero-actions { justify-content:center; }

  /* Bouteilles repositionnées en flex normal sous le texte */
  .hero-bottle {
    display:flex !important;
    position:relative;
    inset:auto; left:auto; right:auto; top:auto; bottom:auto;
    width:100%; height:auto;
    order:2;
    margin-top:4rem;
    z-index:3;
  }
  .bottles-composition {
    padding-bottom:0;
    height:auto;
    align-items:flex-end;
    justify-content:center;
    width:100%;
  }
  .bottle-img {
    margin-left:-3vw;
    filter:drop-shadow(0 22px 38px rgba(0,0,0,0.7)) drop-shadow(0 8px 16px rgba(201,168,76,0.25));
  }
  .bottle-lg { height:270px; }
  .bottle-md { height:215px; }
  .bottle-sm { height:160px; }

  /* RTL: bouteilles centrées sans renversement sur mobile */
  [dir="rtl"] .hero-bottle { right:auto; left:auto; }
  [dir="rtl"] .bottle-img  { margin-left:0; margin-right:-3vw; }

  /* --- Sections: padding réduit mobile --- */
  #about     { padding:5rem 0; }
  #heritage  { padding:6rem 0; }
  #products  { padding:5rem 0; }
  #process   { padding:6rem 0 4rem; }
  #quality   { padding:5rem 0; }
  #gallery   { padding:5rem 0; }
  #contact   { padding:6rem 0; }
  footer     { padding:4rem 0 2rem; }

  /* --- About / Quality grids --- */
  .about-grid,.quality-grid { grid-template-columns:1fr; gap:3.5rem; }
  .about-image img { height:420px; }
  .quality-image img { min-height:240px; max-height:440px; }
  .about-badge { right:1rem; bottom:-1.2rem; }
  .quality-list li { align-items:flex-start; gap:0.7rem; }
  .quality-list .check { padding-top:0.18rem; }

  /* --- Products --- */
  .products-grid { grid-template-columns:1fr; max-width:400px; margin:0 auto 3rem; }
  .product-bottle-wrap { height:420px; }
  .products-grid .product-card:nth-child(1) .product-img { height:260px; }
  .products-grid .product-card:nth-child(2) .product-img { height:340px; }
  .products-grid .product-card:nth-child(3) .product-img { height:400px; }

  /* --- Gallery --- */
  .gallery-grid  { grid-template-columns:repeat(2,1fr); }

  /* --- Formulaire: 16px pour éviter zoom iOS --- */
  .contact-form input,
  .contact-form select,
  .contact-form textarea { font-size:16px; padding:0.95rem 1.1rem; }

  /* --- Touch targets améliorés --- */
  .mobile-lang .lang-btn { min-height:44px; min-width:44px; display:flex; align-items:center; justify-content:center; }
  .mobile-menu-close     { padding:8px 12px; font-size:2.2rem; }
  .mobile-menu a         { padding:0.4rem 1rem; }

  /* --- Timeline mobile: single column --- */
  .tl-wrapper { max-width:100%; }
  .tl-track   { left:30px; }
  .tl-row     { grid-template-columns:60px 1fr; gap:0; margin-bottom:2rem; }
  .tl-center-col { width:60px; }
  .tl-spacer  { display:none; }
  .tl-card-col { grid-column:2; padding:0 0 0 1.2rem; }
  .tl-node    { width:44px; height:44px; font-size:0.88rem; }
  .tl-left .tl-card  { transform:translateX(-30px); }
  .tl-right .tl-card { transform:translateX(-30px); border-right:none; border-left:3px solid rgba(201,168,76,0.3); }
  .tl-right .tl-card:hover { border-right:none; border-left-color:var(--gold); }
  .tl-row.tl-right { grid-template-columns:60px 1fr; }
  .tl-row.tl-right .tl-center-col { order:1; }
  .tl-row.tl-right .tl-card-col   { order:2; }
}

@media (max-width:680px){
  .about-stats      { flex-direction:column; gap:1.5rem; }
  .heritage-pillars { grid-template-columns:1fr 1fr; }
  .process-catalogue{ grid-template-columns:1fr; }
  .form-row         { grid-template-columns:1fr; }
  .footer-grid      { grid-template-columns:1fr; gap:2.5rem; }
  .gallery-grid     { grid-template-columns:1fr 1fr; }
  #hero             { text-align:center; }
  .hero-title       { font-size:2.6rem; line-height:1.15; }
  .hero-text        { max-width:100%; }
  .hero-actions     { justify-content:center; gap:0.75rem; }
  .hero-tagline     { font-size:0.72rem; letter-spacing:0.25em; }
  .hero-desc        { font-size:0.85rem; letter-spacing:0.1em; margin-bottom:2rem; }
  .wa-float         { bottom:1.5rem; right:1.5rem; width:52px; height:52px; }

  /* --- Letter-spacing réduit sur mobile pour éviter overflow --- */
  .nav-logo         { letter-spacing:0.15em; font-size:1.5rem; }
  .footer-logo      { letter-spacing:0.15em; font-size:1.8rem; }
  .section-label    { letter-spacing:0.22em; }
  .loader-logo-text { letter-spacing:0.18em; }

  /* --- Typographie sections plus dense --- */
  .heritage-text    { font-size:0.95rem; line-height:1.75; margin-bottom:3rem; }
  .about-content p  { font-size:0.92rem; line-height:1.75; }
  .quality-list li  { font-size:0.9rem; }
  .contact-desc     { font-size:0.92rem; margin-bottom:2.2rem; }

  /* --- Boutons mobile plus compacts --- */
  .btn-primary, .btn-ghost { padding:0.85rem 1.8rem; font-size:0.78rem; }

  /* --- Lightbox boutons plus discrets --- */
  .lightbox-close   { top:1rem; right:1rem; font-size:2.2rem; padding:8px; }
  .lightbox-prev    { left:0.4rem; font-size:2.2rem; padding:8px; }
  .lightbox-next    { right:0.4rem; font-size:2.2rem; padding:8px; }
  .lightbox img     { max-width:94vw; max-height:78vh; }

  .footer-contact p { font-size:0.82rem; }
  .section-header   { margin-bottom:2.5rem; }
}

@media (max-width:480px){
  .hero-scroll-indicator { display:none; }
}

@media (max-width:440px){
  .gallery-grid     { grid-template-columns:1fr; }
  .hero-title       { font-size:2.1rem; }
  .about-image img  { height:300px; }
  .tl-card          { padding:1.5rem; }
  .heritage-pillars { grid-template-columns:1fr; }
  .product-card     { padding:2.5rem 1.5rem 2rem; }
  .product-bottle-wrap { height:340px; }
  .products-grid .product-card:nth-child(1) .product-img { height:200px; }
  .products-grid .product-card:nth-child(2) .product-img { height:265px; }
  .products-grid .product-card:nth-child(3) .product-img { height:320px; }
  .pillar           { padding:1.6rem 1.2rem; }
  .section-label    { font-size:0.68rem; letter-spacing:0.2em; }
  .container        { padding:0 1.25rem; }
  .nav-container    { padding:0 1.25rem; }
  .about-badge      { padding:1.1rem 1.4rem; right:0.75rem; bottom:-1rem; }
  .badge-year       { font-size:2rem; }
  .badge-text       { font-size:0.66rem; }

  /* --- Sections: padding encore plus serré sur xs --- */
  #about, #products, #quality, #gallery { padding:4rem 0; }
  #heritage, #process, #contact          { padding:4.5rem 0; }
  footer                                  { padding:3rem 0 1.5rem; }

  /* --- Hero ultra-petit: stacking buttons OK --- */
  .hero-actions     { flex-direction:column; align-items:stretch; width:100%; max-width:280px; margin:0 auto; }
  .hero-actions .btn-primary,
  .hero-actions .btn-ghost { width:100%; text-align:center; }
  .hero-title       { font-size:1.9rem; }
  .hero-desc        { font-size:0.78rem; margin-bottom:1.6rem; }

  /* Bouteilles smartphone — agrandies */
  .bottle-lg { height:230px; }
  .bottle-md { height:180px; }
  .bottle-sm { height:135px; }
  .bottle-img { margin-left:-3.5vw; }
  [dir="rtl"] .bottle-img { margin-right:-3.5vw; margin-left:0; }
  .hero-bottle { margin-top:3.5rem; }

  /* --- About content compact --- */
  .about-content p  { font-size:0.88rem; margin-bottom:1.2rem; }
  .about-stats      { margin:2rem 0 2.2rem; padding-top:1.5rem; }
  .stat-num         { font-size:2rem; }

  /* --- Heritage / pillars --- */
  .pillar-icon      { font-size:1.6rem; }
  .pillar h3        { font-size:0.95rem; }
  .pillar p         { font-size:0.78rem; }

  /* --- Timeline ultra-compact --- */
  .tl-track         { left:22px; }
  .tl-row           { grid-template-columns:46px 1fr; }
  .tl-center-col    { width:46px; }
  .tl-node          { width:38px; height:38px; font-size:0.78rem; }
  .tl-card-col      { padding:0 0 0 0.8rem; }
  .tl-card h3       { font-size:1.05rem; }
  .tl-card p        { font-size:0.8rem; }
  .tl-icon          { font-size:1.7rem; }

  /* --- WhatsApp float plus petit --- */
  .wa-float         { bottom:1rem; right:1rem; width:48px; height:48px; }
  .wa-float svg     { width:22px; height:22px; }

  /* --- Footer compact --- */
  .footer-logo      { font-size:1.6rem; margin-bottom:1rem; }
  .footer-brand p   { font-size:0.82rem; margin-bottom:1.4rem; }
  .footer-links h4, .footer-contact h4 { margin-bottom:1rem; padding-bottom:0.6rem; }
}

/* ====================================================
   RESPONSIVE — MOBILE LANDSCAPE (téléphone tourné)
   Hauteur très basse, on libère le hero
   ==================================================== */
@media (max-height:560px) and (orientation:landscape){
  #hero { min-height:auto; height:auto; padding:6rem 0 3rem; }
  .hero-scroll-indicator { display:none; }
  #heroParticles { display:none; }
}

/* ====================================================
   RESPONSIVE — XS ultra (≤360px : iPhone 5/SE 1ère gen)
   ==================================================== */
@media (max-width:360px){
  .hero-title       { font-size:1.75rem; }
  .nav-logo         { font-size:1.35rem; letter-spacing:0.12em; }
  .container        { padding:0 1rem; }
  .nav-container    { padding:0 1rem; }
  .about-badge      { padding:0.9rem 1.2rem; }
  .badge-year       { font-size:1.7rem; }

  /* Bouteilles iPhone SE / petits écrans — agrandies */
  .bottle-lg { height:200px; }
  .bottle-md { height:155px; }
  .bottle-sm { height:115px; }
}
