/* ============================================
   AGENCE DARE-DARE · Style CSS v4
   Identité marocaine renforcée + contenu enrichi
   ============================================ */

/* ---------- Custom Properties ---------- */
:root {
  /* Palette Numéro · quasi monochrome */
  --ivory: #FFFFFF;
  --ink: #0A0A0A;
  --gold: #1A1A1A;
  --gold-light: #3A3A3A;
  --gold-dark: #000000;
  --terracotta: #0A0A0A;
  --terracotta-light: #3A3A3A;
  --terracotta-dark: #000000;
  --fes-blue: #0A0A0A;
  --fes-blue-light: #1A1A1A;
  --sage: #6C757D;
  --sage-light: #8A939B;
  --sand: #E8E8E8;
  --sand-light: #F5F5F5;
  --sand-dark: #D0D0D0;
  --white: #FFFFFF;
  --grey: #6C757D;
  --grey-text: #6C757D;
  /* Accent unique · doré très discret */
  --accent: #B8860B;

  /* Typographie · Numéro editorial */
  --font-display: 'Inter', 'Helvetica Neue', Helvetica, Arial, sans-serif;
  --font-body: 'Inter', 'Helvetica Neue', Helvetica, Arial, sans-serif;
  --font-moroccan: 'Inter', 'Helvetica Neue', sans-serif;

  /* Spacing */
  --section-padding: clamp(60px, 8vw, 120px);
  --container-max: 1200px;
  --nav-height: 70px;

  /* Transitions */
  --transition-fast: 200ms ease;
  --transition-base: 300ms ease;
  --transition-slow: 500ms ease;
}

/* ---------- Reset & Base ---------- */
*, *::before, *::after {
  margin: 0;
  padding: 0;
  box-sizing: border-box;
}

html {
  scroll-behavior: smooth;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

body {
  font-family: var(--font-body);
  font-weight: 300;
  font-size: 17px;
  line-height: 1.7;
  color: var(--ink);
  background-color: var(--ivory);
  overflow-x: hidden;
}

img { display: block; max-width: 100%; }
a { color: inherit; text-decoration: none; }
button { font-family: inherit; cursor: pointer; border: none; background: none; }
ul, ol { list-style: none; }

/* ---------- Skip to content ---------- */
.skip-link {
  position: absolute; top: -100%; left: 16px; z-index: 10000;
  padding: 8px 16px; background: var(--terracotta); color: #fff;
  font-family: var(--font-body); font-size: 14px; font-weight: 500;
  border-radius: 0 0 4px 4px;
}
.skip-link:focus { top: 0; }

/* ---------- Focus visible ---------- */
*:focus-visible { outline: 2px solid var(--gold); outline-offset: 2px; }

/* ---------- Utility ---------- */
.container {
  max-width: var(--container-max);
  margin: 0 auto;
  padding-left: 24px;
  padding-right: 24px;
}

.section-title {
  font-family: var(--font-display);
  font-weight: 700;
  font-size: clamp(36px, 5vw, 64px);
  line-height: 1.05;
  letter-spacing: -0.03em;
  color: var(--ink);
}

.section-subtitle {
  font-family: var(--font-body);
  font-weight: 400;
  font-style: normal;
  font-size: clamp(16px, 1.5vw, 20px);
  color: var(--grey-text);
  margin-top: 16px;
  line-height: 1.6;
}

/* Star separator · hidden in editorial mode */
.star-sep {
  display: none;
  margin: 16px auto;
  width: 20px;
  height: 20px;
  color: var(--gold);
}

/* Diamond separator */
.diamond-sep {
  color: var(--gold); margin: 0 10px; font-size: 8px; opacity: 0.6;
}

/* Animated underline for links */
.link-underline { position: relative; display: inline-block; }
.link-underline::after {
  content: ''; position: absolute; bottom: -2px; left: 0;
  width: 0; height: 1px; background: var(--gold);
  transition: width var(--transition-base);
}
.link-underline:hover::after { width: 100%; }

/* Font moroccan class */
.font-moroccan { font-family: var(--font-moroccan); }

/* CLEAN: supprimé zellige-pattern (DISABLED, --light, --gold) + zellige-band · tous désactivés/orphelins */

/* ---------- Grain overlay ---------- */
.grain-overlay { position: relative; overflow: hidden; }
.grain-overlay::after {
  content: ''; position: absolute; inset: 0;
  opacity: 0.06; pointer-events: none; z-index: 2;
  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)'/%3E%3C/svg%3E");
  background-size: 128px 128px;
}

/* ---------- Tadelakt texture ---------- */
.tadelakt-texture {
  background-color: var(--ivory);
  background-image:
    radial-gradient(ellipse at 20% 50%, rgba(197,183,164,0.15) 0%, transparent 50%),
    radial-gradient(ellipse at 80% 20%, rgba(197,183,164,0.10) 0%, transparent 50%),
    radial-gradient(ellipse at 50% 80%, rgba(197,183,164,0.12) 0%, transparent 50%);
}

/* CLEAN: supprimé arch-divider, section-fade-top · tous désactivés/orphelins */

/* ---------- 8-branch star SVG inline ---------- */
.star-8 {
  display: inline-block;
  width: 16px; height: 16px;
  color: var(--gold);
}
.star-8--large { width: 24px; height: 24px; }

/* ---------- Moroccan frame ---------- */
.moroccan-frame {
  border: none;
  padding: 0;
  position: relative;
}
/* CLEAN: supprimé moroccan-frame__corner + variantes positionnelles · éléments absents du HTML */

/* ---------- Marquee ---------- */
.marquee {
  overflow: hidden;
  white-space: nowrap;
  border-top: 1px solid var(--sand);
  padding: 20px 0;
  margin-top: 40px;
}
.marquee__title {
  font-family: var(--font-body);
  font-weight: 500; font-size: 11px;
  text-transform: uppercase; letter-spacing: 0.2em;
  color: #6C757D; text-align: center;
  margin-bottom: 16px;
}
.marquee__track {
  display: flex; width: max-content;
  animation: marquee-scroll 40s linear infinite;
}
.marquee__item {
  font-family: var(--font-body);
  font-weight: 500; font-size: 12px;
  text-transform: uppercase; letter-spacing: 0.15em;
  color: var(--grey); opacity: 0.6;
  padding: 0 16px; white-space: nowrap;
  flex-shrink: 0;
}
.marquee__diamond {
  color: var(--gold); font-size: 6px; opacity: 0.4;
  display: inline-flex; align-items: center;
  padding: 0 8px; flex-shrink: 0;
}
@keyframes marquee-scroll {
  0% { transform: translateX(0); }
  100% { transform: translateX(-50%); }
}

/* ---------- NAVIGATION ---------- */
.nav {
  position: fixed; top: 0; left: 0; right: 0;
  z-index: 1000; height: var(--nav-height);
  display: flex; align-items: center;
  transition: background-color var(--transition-base), box-shadow var(--transition-base);
}
.nav--transparent { background: transparent; }
.nav--scrolled {
  background: #fff;
  box-shadow: 0 1px 0 rgba(0,0,0,0.08);
}
.nav__inner {
  display: flex; align-items: center; justify-content: space-between;
  width: 100%; max-width: var(--container-max);
  margin: 0 auto; padding: 0 24px;
  gap: 8px;
}
.nav__logo {
  display: flex; align-items: center;
  flex-shrink: 0;
  transition: filter var(--transition-base);
}
/* LOGO: SVG inline · plus besoin de filter/invert/blend-mode */
.nav__logo-svg {
  height: 30px;
  width: auto;
  display: block;
  transition: color var(--transition-base);
}
/* Sur fond sombre : logo blanc */
.nav--transparent .nav__logo-svg {
  color: #fff;
}
/* Sur fond clair : logo noir */
.nav--scrolled .nav__logo-svg {
  color: var(--ink);
}

.nav__links { display: flex; align-items: center; flex-shrink: 1; flex-wrap: nowrap; }
.nav__link {
  font-family: var(--font-body); font-weight: 500;
  font-size: 11px; text-transform: uppercase;
  letter-spacing: 0.08em; white-space: nowrap;
  transition: color var(--transition-fast), opacity var(--transition-fast);
  padding: 8px 0;
}
.nav--transparent .nav__link { color: rgba(255,255,255,0.85); }
.nav--transparent .nav__link:hover { color: #fff; }
.nav--scrolled .nav__link { color: var(--ink); opacity: 0.7; }
.nav--scrolled .nav__link:hover { opacity: 1; }

/* UX: lien nav actif correspondant à la section visible */
.nav__link.is-active { opacity: 1; }
.nav--transparent .nav__link.is-active { color: #fff; }
.nav__link.is-active::after { width: 100%; }

.nav__diamond { font-size: 3px; margin: 0 10px; opacity: 0.25; }
.nav--transparent .nav__diamond { color: #fff; }
.nav--scrolled .nav__diamond { color: var(--ink); }

.nav__cta {
  font-family: var(--font-body); font-weight: 600;
  font-size: 10px; text-transform: uppercase; letter-spacing: 0.14em;
  padding: 8px 20px;
  border: none; border-radius: 0;
  background: #0A0A0A; color: #fff;
  position: relative; overflow: hidden;
  transition: all var(--transition-base);
  margin-left: 4px; flex-shrink: 0; white-space: nowrap;
  clip-path: polygon(8% 0%, 100% 0%, 92% 100%, 0% 100%);
}
.nav__cta::after {
  content: ''; position: absolute; bottom: 0; left: 0; right: 0;
  height: 2px; background: #fff;
  transform: scaleX(0); transform-origin: right;
  transition: transform 0.4s cubic-bezier(0.25, 0.46, 0.45, 0.94);
}
.nav__cta:hover::after { transform: scaleX(1); transform-origin: left; }
.nav--transparent .nav__cta { background: #fff; color: #0A0A0A; }
.nav--transparent .nav__cta::after { background: #0A0A0A; }
.nav--scrolled .nav__cta { background: #0A0A0A; color: #fff; }
.nav__cta:hover { opacity: 0.9; }

/* i18n · Language Toggle */
.lang-toggle {
  display: flex; align-items: center; gap: 2px;
  margin-left: 6px; flex-shrink: 0;
}
.lang-toggle__btn {
  background: none; border: none; cursor: pointer;
  padding: 3px 5px; border-radius: 2px;
  font-family: var(--font-body); font-size: 10px; font-weight: 600;
  letter-spacing: 0.06em; text-transform: uppercase;
  color: var(--grey); transition: color var(--transition-fast), background var(--transition-fast);
}
.lang-toggle__btn.active {
  color: var(--ink); background: var(--sand);
}
.lang-toggle__btn:hover:not(.active) { color: var(--ink); }
.lang-toggle__sep { color: var(--sand-dark); font-size: 9px; user-select: none; }
.nav--transparent .lang-toggle__btn { color: rgba(255,255,255,0.45); }
.nav--transparent .lang-toggle__btn.active { color: #fff; background: rgba(255,255,255,0.15); }
.nav--transparent .lang-toggle__sep { color: rgba(255,255,255,0.2); }

/* Mobile lang toggle */
.lang-toggle--mobile {
  margin: 24px auto 0; justify-content: center;
}
.lang-toggle--mobile .lang-toggle__btn { color: rgba(255,255,255,0.5); font-size: 13px; padding: 6px 10px; }
.lang-toggle--mobile .lang-toggle__btn.active { color: #fff; background: rgba(255,255,255,0.15); }
.lang-toggle--mobile .lang-toggle__sep { color: rgba(255,255,255,0.25); }

/* Mode Toggle (PRO/PRIVÉ) */
.mode-toggle {
  display: flex; align-items: center; gap: 2px;
  margin-left: 6px; flex-shrink: 0;
}
.mode-toggle__btn {
  background: none; border: none; cursor: pointer;
  padding: 3px 5px; border-radius: 2px;
  font-family: var(--font-body); font-size: 10px; font-weight: 600;
  letter-spacing: 0.06em; text-transform: uppercase;
  color: var(--grey); transition: color var(--transition-fast), background var(--transition-fast);
}
.mode-toggle__btn.active { color: var(--ink); background: var(--sand); }
.mode-toggle__btn:hover:not(.active) { color: var(--ink); }
.mode-toggle__sep { color: var(--sand-dark); font-size: 9px; user-select: none; }
.nav--transparent .mode-toggle__btn { color: rgba(255,255,255,0.7); }
.nav--transparent .mode-toggle__btn.active { color: #fff; background: rgba(255,255,255,0.2); }
.nav--transparent .mode-toggle__sep { color: rgba(255,255,255,0.5); }
.mode-toggle--mobile { margin: 12px auto 0; justify-content: center; }
.mode-toggle--mobile .mode-toggle__btn { color: rgba(255,255,255,0.5); font-size: 13px; padding: 6px 10px; }
.mode-toggle--mobile .mode-toggle__btn.active { color: #fff; background: rgba(255,255,255,0.15); }
.mode-toggle--mobile .mode-toggle__sep { color: rgba(255,255,255,0.25); }

/* Hamburger */
.nav__hamburger {
  display: none; flex-direction: column; justify-content: center;
  align-items: center; width: 44px; height: 44px; cursor: pointer; z-index: 1002;
}
.nav__hamburger span {
  display: block; width: 24px; height: 1.5px; margin: 3px 0;
  transition: transform var(--transition-base), opacity var(--transition-fast);
}
.nav--transparent .nav__hamburger span { background: #fff; }
.nav--scrolled .nav__hamburger span { background: var(--ink); }
.nav__hamburger.active span { background: #fff !important; }
.nav__hamburger.active span:nth-child(1) { transform: translateY(4.5px) rotate(45deg); }
.nav__hamburger.active span:nth-child(2) { opacity: 0; }
.nav__hamburger.active span:nth-child(3) { transform: translateY(-4.5px) rotate(-45deg); }

/* Mobile Menu */
.mobile-menu {
  position: fixed; inset: 0; z-index: 1001;
  background: var(--fes-blue);
  display: flex; flex-direction: column; align-items: center; justify-content: center;
  opacity: 0; pointer-events: none;
  transition: opacity var(--transition-base);
}
.mobile-menu.active { opacity: 1; pointer-events: all; }
.mobile-menu__link {
  font-family: var(--font-display); font-weight: 600; font-size: 32px;
  color: #fff; margin: 12px 0;
  opacity: 0; transform: translateY(20px);
  transition: opacity var(--transition-base), transform var(--transition-base), color var(--transition-fast);
}
.mobile-menu.active .mobile-menu__link { opacity: 1; transform: translateY(0); }
.mobile-menu__link:hover { color: var(--gold-light); }
.mobile-menu.active .mobile-menu__link:nth-child(1) { transition-delay: 100ms; }
.mobile-menu.active .mobile-menu__link:nth-child(2) { transition-delay: 150ms; }
.mobile-menu.active .mobile-menu__link:nth-child(3) { transition-delay: 200ms; }
.mobile-menu.active .mobile-menu__link:nth-child(4) { transition-delay: 250ms; }
.mobile-menu.active .mobile-menu__link:nth-child(5) { transition-delay: 300ms; }
.mobile-menu.active .mobile-menu__link:nth-child(6) { transition-delay: 350ms; }
.mobile-menu.active .mobile-menu__link:nth-child(7) { transition-delay: 400ms; }

/* ---------- HERO ---------- */
.hero {
  position: relative; min-height: 100vh;
  display: flex; flex-direction: column;
  align-items: center; justify-content: center;
  overflow: hidden; color: #fff;
}
.hero__bg { position: absolute; inset: 0; z-index: 0; }
.hero__bg--gradient {
  background: #0A0A0A;
}
/* CLEAN: supprimé hero__bg--gradient::before et hero__bg::after display:none */
/* Floating stars */
.hero__stars {
  position: absolute; inset: 0; overflow: hidden;
}
.hero__star-float {
  position: absolute; color: var(--gold-light); opacity: 0;
  animation: star-float 8s ease-in-out infinite;
}
.hero__star-float svg {
  width: 100%; height: 100%;
}
@keyframes star-float {
  0% { opacity: 0; transform: translateY(20px) rotate(0deg) scale(0.8); }
  20% { opacity: 0.15; }
  50% { opacity: 0.08; transform: translateY(-15px) rotate(22.5deg) scale(1); }
  80% { opacity: 0.15; }
  100% { opacity: 0; transform: translateY(20px) rotate(45deg) scale(0.8); }
}

/* CLEAN: supprimé hero__zellige-reveal + keyframes zellige-reveal + zellige-star-pulse */

.hero__content {
  position: relative; z-index: 2;
  text-align: center; max-width: 840px; padding: 0 24px;
}

/* Tabs */
.hero__tabs {
  display: flex; align-items: center; justify-content: center;
  flex-wrap: wrap; gap: 0; margin-bottom: 48px;
  position: relative; z-index: 2; margin-top: 40px;
}
.hero__tab {
  font-family: var(--font-body); font-weight: 500; font-size: 13px;
  text-transform: uppercase; letter-spacing: 0.12em;
  color: rgba(255,255,255,0.55); background: none; border: none;
  padding: 8px 4px; cursor: pointer; position: relative;
  transition: color var(--transition-fast); white-space: nowrap;
}
.hero__tab:hover { color: rgba(255,255,255,0.9); }
.hero__tab.active { color: #fff; }
.hero__tab::after {
  content: ''; position: absolute; bottom: 0; left: 0;
  width: 0; height: 2px; background: var(--gold-light);
  transition: width var(--transition-base);
}
.hero__tab.active::after { width: 100%; }
.hero__tab-diamond {
  font-size: 4px; color: rgba(255,255,255,0.3); opacity: 1;
  margin: 0 16px; user-select: none;
}

.hero__title-wrapper { overflow: hidden; }
.hero__title {
  font-family: var(--font-display); font-weight: 700;
  font-size: clamp(38px, 5vw, 72px); line-height: 1.05;
  letter-spacing: -0.03em;
  max-width: 800px; margin: 0 auto;
  transition: opacity var(--transition-base);
}
.hero__subtitle {
  font-family: var(--font-body); font-weight: 300; font-size: 18px;
  color: rgba(255,255,255,0.8); max-width: 600px;
  margin: 24px auto 0; line-height: 1.6;
  transition: opacity var(--transition-base);
}
.hero__ctas {
  display: flex; align-items: center; justify-content: center;
  gap: 16px; margin-top: 40px; flex-wrap: wrap;
}
.hero__cta-primary {
  display: inline-block; font-family: var(--font-body);
  font-weight: 500; font-size: 13px; text-transform: uppercase;
  letter-spacing: 0.15em; padding: 16px 48px;
  background: #fff; color: #0A0A0A;
  border-radius: 0; border: none;
  transition: background var(--transition-base), color var(--transition-base);
}
.hero__cta-primary:hover { background: #E8E8E8; }
.hero__cta-secondary {
  display: inline-block; font-family: var(--font-body);
  font-weight: 400; font-size: 13px; text-transform: uppercase;
  letter-spacing: 0.15em; padding: 15px 48px;
  border: 1px solid rgba(255,255,255,0.4); color: #fff;
  border-radius: 0;
  transition: border-color var(--transition-base), background var(--transition-base);
}
.hero__cta-secondary:hover { border-color: #fff; background: rgba(255,255,255,0.1); }

.hero__locations {
  position: absolute; bottom: 32px; left: 50%; transform: translateX(-50%);
  z-index: 2; text-align: center; white-space: nowrap;
}
.hero__locations-brands {
  font-family: var(--font-display); font-weight: 600; font-style: italic;
  font-size: 14px; color: rgba(255,255,255,0.5); letter-spacing: 0.05em;
}
.hero__tagline {
  font-family: var(--font-display); font-style: italic;
  font-size: 20px; color: rgba(255,255,255,0.6); letter-spacing: 0.08em;
  margin-bottom: 8px; text-transform: uppercase;
}
.hero__locations-cities {
  font-family: var(--font-body); font-weight: 500; font-size: 11px;
  text-transform: uppercase; letter-spacing: 0.2em;
  color: rgba(255,255,255,0.4); margin-top: 4px;
}

/* ---------- SERVICES ---------- */
.services {
  background: var(--ivory); padding: var(--section-padding) 0;
  position: relative;
}
.services__header { text-align: center; margin-bottom: 56px; }
.services__grid {
  display: grid; grid-template-columns: repeat(3, 1fr);
  gap: 24px; margin-bottom: 0;
}
.service-card {
  background: #F8F8F8; padding: 48px 40px;
  border: 1px solid #EBEBEB;
  border-radius: 24px;
  position: relative; overflow: hidden;
  transition: border-color var(--transition-base), transform var(--transition-base), box-shadow var(--transition-base);
}
/* CLEAN: supprimé .service-card::before { display: none; } */
.service-card:hover {
  border-color: #0A0A0A;
  transform: translateY(-2px);
  box-shadow: 0 12px 40px rgba(0,0,0,0.06);
}
.service-card__icon { display: none; }
.service-card__title {
  font-family: var(--font-body); font-weight: 500; font-size: 13px;
  text-transform: uppercase; letter-spacing: 0.1em;
  margin-bottom: 12px; color: var(--ink);
}
.service-card__desc {
  font-family: var(--font-body); font-weight: 300; font-size: 16px;
  color: var(--grey-text); line-height: 1.7;
}
.service-card__toggle {
  display: inline-flex; align-items: center; gap: 8px;
  margin-top: 24px; padding: 0; border: none; border-radius: 0;
  background: none; cursor: pointer;
  font-family: var(--font-body); font-weight: 500; font-size: 12px;
  text-transform: uppercase; letter-spacing: 0.1em;
  color: #0A0A0A; transition: opacity 0.25s ease;
  border-bottom: 1px solid #0A0A0A; padding-bottom: 2px;
}
.service-card__toggle:hover { opacity: 0.5; }
.service-card__toggle-icon {
  display: inline-flex; align-items: center; justify-content: center;
  width: 16px; height: 16px; font-size: 12px; line-height: 1;
  transition: transform 0.3s;
  border: none;
}
.service-card__toggle:hover .service-card__toggle-icon { color: #fff; }
.service-card__features {
  list-style: none; padding: 0; margin: 0;
  max-height: 0; overflow: hidden; opacity: 0;
  transition: max-height 0.4s ease, opacity 0.3s ease, margin 0.3s ease;
}
.service-card.expanded .service-card__features {
  max-height: 300px; opacity: 1; margin-top: 20px;
  padding-top: 16px; border-top: 1px solid var(--sand);
}
.service-card__features li {
  font-family: var(--font-body); font-weight: 300; font-size: 14px;
  color: var(--grey-text); line-height: 1.6;
  padding: 4px 0 4px 16px; position: relative;
}
.service-card__features li::before {
  content: '◆'; position: absolute; left: 0; top: 4px;
  color: var(--gold); font-size: 6px; line-height: 1.6;
}

/* CTA */
.services__cta-wrap { text-align: center; margin-top: 48px; }
.services__cta {
  display: inline-block; font-family: var(--font-body);
  font-weight: 500; font-size: 13px; text-transform: uppercase;
  letter-spacing: 0.15em; padding: 16px 48px;
  border: 1px solid #0A0A0A; color: #0A0A0A;
  border-radius: 0;
  transition: background var(--transition-base), color var(--transition-base);
}
.services__cta:hover { background: #0A0A0A; color: #fff; }

/* ---------- DESTINATIONS ---------- */
.destinations {
  background: #fff; padding: var(--section-padding) 0;
  position: relative;
}
.destinations__header { text-align: center; margin-bottom: 64px; }

/* Showcase layout */
.dest-showcase {
  display: flex; flex-direction: column;
  gap: 2px;
}
.dest-showcase__item {
  display: grid; grid-template-columns: 1.2fr 1fr;
  min-height: 520px; position: relative;
  overflow: hidden; cursor: pointer;
  background: #0A0A0A;
}
.dest-showcase__item:nth-child(even) {
  direction: rtl;
}
.dest-showcase__item:nth-child(even) > * {
  direction: ltr;
}

/* Image wrap with dual-image hover swap */
.dest-showcase__img-wrap {
  position: relative; overflow: hidden;
}
.dest-showcase__img {
  position: absolute; inset: 0;
  width: 100%; height: 100%; object-fit: cover;
  transition: opacity 0.6s ease, transform 1.2s cubic-bezier(0.25, 0.46, 0.45, 0.94);
}
.dest-showcase__img--hover {
  opacity: 0;
}
.dest-showcase__item:hover .dest-showcase__img:not(.dest-showcase__img--hover) {
  opacity: 0; transform: scale(1.05);
}
.dest-showcase__item:hover .dest-showcase__img--hover {
  opacity: 1; transform: scale(1);
}

/* Content */
.dest-showcase__content {
  display: flex; flex-direction: column;
  justify-content: center;
  padding: 64px;
  color: #fff;
}
.dest-showcase__number {
  font-family: var(--font-body); font-weight: 700;
  font-size: 12px; letter-spacing: 0.2em;
  color: rgba(255,255,255,0.25);
  margin-bottom: 16px;
}
.dest-showcase__city {
  font-family: var(--font-display); font-weight: 700;
  font-size: clamp(48px, 6vw, 80px);
  letter-spacing: -0.04em; line-height: 0.9;
  margin-bottom: 12px;
  transition: transform 0.5s cubic-bezier(0.25, 0.46, 0.45, 0.94);
}
.dest-showcase__item:hover .dest-showcase__city {
  transform: translateX(12px);
}
.dest-showcase__tagline {
  font-family: var(--font-body); font-weight: 400;
  font-size: 16px; font-style: italic;
  color: rgba(255,255,255,0.5);
  margin-bottom: 24px;
  transition: color 0.4s;
}
.dest-showcase__item:hover .dest-showcase__tagline {
  color: rgba(255,255,255,0.7);
}

/* Details · reveal on hover */
.dest-showcase__details {
  max-height: 0; overflow: hidden; opacity: 0;
  transition: max-height 0.6s cubic-bezier(0.25, 0.46, 0.45, 0.94),
              opacity 0.4s ease 0.1s;
}
.dest-showcase__item:hover .dest-showcase__details {
  max-height: 200px; opacity: 1;
}
.dest-showcase__details p {
  font-family: var(--font-body); font-weight: 300;
  font-size: 14px; line-height: 1.7;
  color: rgba(255,255,255,0.6);
  margin-bottom: 16px;
}
.dest-showcase__keywords {
  display: flex; gap: 8px; flex-wrap: wrap;
}
.dest-showcase__keywords span {
  padding: 5px 14px;
  border: 1px solid rgba(255,255,255,0.15);
  font-family: var(--font-body); font-size: 11px;
  font-weight: 500; text-transform: uppercase;
  letter-spacing: 0.08em; color: rgba(255,255,255,0.5);
  transition: all 0.3s;
}
.dest-showcase__item:hover .dest-showcase__keywords span {
  border-color: rgba(255,255,255,0.3);
  color: rgba(255,255,255,0.7);
}

/* UX: tap-to-reveal destinations · réplique le hover pour le tactile */
.dest-showcase__item.is-tapped .dest-showcase__city {
  transform: translateX(12px);
}
.dest-showcase__item.is-tapped .dest-showcase__tagline {
  color: rgba(255,255,255,0.7);
}
.dest-showcase__item.is-tapped .dest-showcase__details {
  max-height: 200px; opacity: 1;
}
.dest-showcase__item.is-tapped .dest-showcase__keywords span {
  border-color: rgba(255,255,255,0.3);
  color: rgba(255,255,255,0.7);
}

/* Elsewhere CTA */
.destinations__elsewhere {
  text-align: center; margin-top: 48px;
  font-family: var(--font-body); font-weight: 300; font-size: 16px;
  color: var(--grey); line-height: 1.6;
}
.destinations__elsewhere strong { font-weight: 600; color: var(--ink); }

/* ---------- LIEUX D'EXCEPTION ---------- */
.lieux {
  padding: var(--section-padding) 0;
  position: relative;
}
/* ---------- PORTFOLIO ---------- */
.portfolio { padding: clamp(48px, 6vw, 100px) 0; background: var(--ivory); }
.portfolio__header { text-align: center; margin-bottom: 40px; }
.portfolio__header .section-subtitle { max-width: 560px; margin: 0 auto; }

/* Filters */
.portfolio__filters {
  display: flex; justify-content: center; gap: 8px; flex-wrap: wrap;
  margin-bottom: 48px;
}
.portfolio__filter {
  padding: 10px 24px; border: 1px solid #D0D0D0; border-radius: 100px;
  background: transparent; color: var(--ink);
  font-family: var(--font-body); font-weight: 500; font-size: 13px;
  letter-spacing: 0.02em; cursor: pointer;
  transition: all 0.3s ease;
}
.portfolio__filter:hover { border-color: var(--ink); }
.portfolio__filter.is-active {
  background: var(--ink); color: #fff; border-color: var(--ink);
}

/* Grid */
.portfolio__grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  grid-auto-rows: 340px;
  gap: 6px;
}
.portfolio__card {
  position: relative; overflow: hidden; cursor: pointer;
  border-radius: 0;
  transition: opacity 0.4s ease, transform 0.4s ease;
}
.portfolio__card[data-visible="false"] {
  display: none;
}
.portfolio__card.portfolio__card--revealing {
  display: block;
  animation: portfolioReveal 0.6s cubic-bezier(0.25, 0.46, 0.45, 0.94) forwards;
}
@keyframes portfolioReveal {
  from { opacity: 0; transform: translateY(30px) scale(0.97); }
  to { opacity: 1; transform: translateY(0) scale(1); }
}

/* Large cards */
.portfolio__card--large {
  grid-column: span 2;
  grid-row: span 1;
}

/* Asymmetric border-radius signatures */
.portfolio__card:nth-child(6n+1) { border-radius: 0 0 0 80px; }
.portfolio__card:nth-child(6n+2) { border-radius: 0 60px 0 0; }
.portfolio__card:nth-child(6n+3) { border-radius: 0 0 60px 0; }
.portfolio__card:nth-child(6n+4) { border-radius: 80px 0 0 0; }
.portfolio__card:nth-child(6n+5) { border-radius: 0 0 80px 80px; }
.portfolio__card:nth-child(6n+6) { border-radius: 60px 0 0 60px; }

/* Image */
.portfolio__card img {
  width: 100%; height: 100%; object-fit: cover;
  transition: transform 1s cubic-bezier(0.25, 0.46, 0.45, 0.94), filter 0.8s ease;
  filter: grayscale(15%) brightness(0.95);
}
.portfolio__card:hover img,
.portfolio__card.is-tapped img {
  transform: scale(1.08);
  filter: grayscale(0%) brightness(1);
}

/* UX: cursor personnalisé sur les cartes portfolio */
.portfolio__card { cursor: crosshair; }

/* Clip-path reveal on scroll */
.portfolio__card.reveal {
  clip-path: inset(8% 8% 8% 8%);
  transition: clip-path 0.8s cubic-bezier(0.25, 0.46, 0.45, 0.94), opacity 0.6s ease;
  opacity: 0;
}
.portfolio__card.reveal.visible {
  clip-path: inset(0% 0% 0% 0%);
  opacity: 1;
}

/* Index number */
.portfolio__card::before {
  content: attr(data-index);
  position: absolute; top: 20px; left: 24px; z-index: 5;
  font-family: var(--font-display); font-weight: 700; font-size: 11px;
  color: rgba(255,255,255,0.5); letter-spacing: 0.1em;
  transition: color 0.4s ease;
}
.portfolio__card:hover::before,
.portfolio__card.is-tapped::before {
  color: rgba(255,255,255,0.9);
}

/* Default state · name + tag at bottom */
.portfolio__default {
  position: absolute; bottom: 0; left: 0; right: 0; z-index: 3;
  padding: 28px; display: flex; flex-direction: column; gap: 8px;
  background: linear-gradient(0deg, rgba(10,10,10,0.7) 0%, rgba(10,10,10,0.1) 60%, transparent 100%);
  transition: opacity 0.4s ease;
}
.portfolio__tag {
  display: inline-block; align-self: flex-start;
  padding: 4px 14px; border: 1px solid rgba(255,255,255,0.4); border-radius: 100px;
  font-family: var(--font-body); font-weight: 400; font-size: 11px;
  color: rgba(255,255,255,0.85); text-transform: uppercase; letter-spacing: 0.1em;
}
.portfolio__name {
  font-family: var(--font-display); font-weight: 700;
  font-size: clamp(20px, 2.5vw, 30px);
  color: #fff; line-height: 1.1; letter-spacing: -0.02em;
}

/* Hover detail overlay */
.portfolio__detail {
  position: absolute; inset: 0; z-index: 4;
  display: flex; flex-direction: column; justify-content: flex-end;
  padding: 32px;
  background: linear-gradient(0deg, rgba(10,10,10,0.95) 0%, rgba(10,10,10,0.75) 40%, rgba(10,10,10,0.35) 100%);
  opacity: 0;
  transition: opacity 0.5s ease;
}
.portfolio__card:hover .portfolio__detail,
.portfolio__card.is-tapped .portfolio__detail {
  opacity: 1;
}
.portfolio__card:hover .portfolio__default,
.portfolio__card.is-tapped .portfolio__default {
  opacity: 0;
}
/* Detail children stagger */
.portfolio__detail > * {
  transform: translateY(15px);
  opacity: 0;
  transition: transform 0.5s cubic-bezier(0.25, 0.46, 0.45, 0.94), opacity 0.4s ease;
}
.portfolio__card:hover .portfolio__detail > *,
.portfolio__card.is-tapped .portfolio__detail > * {
  transform: translateY(0);
  opacity: 1;
}
.portfolio__card:hover .portfolio__detail > *:nth-child(1) { transition-delay: 0.05s; }
.portfolio__card:hover .portfolio__detail > *:nth-child(2) { transition-delay: 0.1s; }
.portfolio__card:hover .portfolio__detail > *:nth-child(3) { transition-delay: 0.15s; }
.portfolio__card:hover .portfolio__detail > *:nth-child(4) { transition-delay: 0.2s; }
.portfolio__card:hover .portfolio__detail > *:nth-child(5) { transition-delay: 0.25s; }
/* Outer border reveal on hover */
.portfolio__card::after {
  content: '';
  position: absolute; inset: 6px; z-index: 5;
  border: 1px solid rgba(255,255,255,0.3);
  border-radius: inherit;
  opacity: 0;
  transition: opacity 0.4s ease, inset 0.5s cubic-bezier(0.25, 0.46, 0.45, 0.94);
  pointer-events: none;
}
.portfolio__card:hover::after,
.portfolio__card.is-tapped::after {
  inset: 12px;
  opacity: 1;
}
.portfolio__detail-client {
  font-family: var(--font-display); font-weight: 700;
  font-size: clamp(22px, 2.5vw, 32px);
  color: #fff; line-height: 1.1; letter-spacing: -0.02em;
  margin-bottom: 6px;
}
.portfolio__detail-type {
  font-family: var(--font-body); font-weight: 400; font-size: 12px;
  color: rgba(255,255,255,0.6); text-transform: uppercase; letter-spacing: 0.1em;
  margin-bottom: 16px;
}
.portfolio__detail-meta {
  display: flex; gap: 20px; margin-bottom: 16px;
}
.portfolio__detail-meta span {
  font-family: var(--font-body); font-weight: 500; font-size: 13px;
  color: rgba(255,255,255,0.8);
  display: flex; align-items: center; gap: 6px;
}
.portfolio__detail-meta span::before {
  content: '';
  width: 4px; height: 4px; border-radius: 50%;
  background: rgba(255,255,255,0.5);
  flex-shrink: 0;
}
.portfolio__detail-quote {
  font-family: var(--font-body); font-weight: 300; font-size: 14px;
  color: rgba(255,255,255,0.9); line-height: 1.6;
  margin-bottom: 14px; font-style: italic;
  border-left: 2px solid rgba(255,255,255,0.3);
  padding-left: 14px;
}
.portfolio__detail-role {
  font-family: var(--font-body); font-weight: 400; font-size: 12px;
  color: rgba(255,255,255,0.5); letter-spacing: 0.02em;
}

/* Show more button */
.portfolio__more-wrap { text-align: center; margin-top: 48px; }
.portfolio__more-btn {
  display: inline-flex; align-items: center; gap: 12px;
  padding: 16px 48px;
  background: transparent; border: 1px solid var(--ink); color: var(--ink);
  font-family: var(--font-body); font-weight: 600; font-size: 13px;
  text-transform: uppercase; letter-spacing: 0.12em;
  cursor: pointer; border-radius: 0;
  transition: all 0.3s ease;
}
.portfolio__more-btn:hover {
  background: var(--ink); color: #fff;
}
.portfolio__more-count {
  display: inline-flex; align-items: center; justify-content: center;
  width: 28px; height: 28px; border-radius: 50%;
  background: var(--ink); color: #fff;
  font-size: 11px; font-weight: 700;
  transition: all 0.3s ease;
}
.portfolio__more-btn:hover .portfolio__more-count {
  background: #fff; color: var(--ink);
}
.portfolio__more-btn.is-hidden { display: none; }

/* CTA */
.portfolio__cta-text {
  text-align: center; margin-top: 40px;
  font-family: var(--font-body); font-weight: 300; font-size: 16px;
  color: var(--grey); line-height: 1.6;
}
.portfolio__cta-wrap { text-align: center; margin-top: 24px; }
.portfolio__cta {
  display: inline-block; padding: 16px 48px;
  background: #0A0A0A; color: #fff;
  font-family: var(--font-body); font-weight: 500; font-size: 13px;
  text-transform: uppercase; letter-spacing: 0.15em;
  border-radius: 0; text-decoration: none;
  transition: opacity 0.3s ease;
}
.portfolio__cta:hover { opacity: 0.8; }

/* ---------- CHIFFRES ---------- */
.chiffres {
  background: #0A0A0A; padding: clamp(48px, 6vw, 80px) 0;
  text-align: center; position: relative;
}
.chiffres__title {
  font-family: var(--font-display); font-weight: 600;
  font-size: clamp(28px, 3.5vw, 44px);
  color: var(--sand-light); margin-bottom: 48px;
}
.chiffres__grid {
  display: flex; justify-content: center;
  gap: clamp(32px, 5vw, 64px); flex-wrap: wrap;
}
.chiffre-item { text-align: center; min-width: 120px; }
.chiffre-item__number {
  font-family: var(--font-display); font-weight: 700;
  font-size: clamp(40px, 5vw, 64px);
  color: #fff; line-height: 1; margin-bottom: 8px;
  letter-spacing: -0.03em;
}
.chiffre-item__label {
  font-family: var(--font-body); font-weight: 500; font-size: 12px;
  text-transform: uppercase; letter-spacing: 0.12em;
  color: rgba(239,231,218,0.7);
}

/* ---------- TEMOIGNAGES ---------- */
.temoignages {
  background: var(--ivory); padding: var(--section-padding) 0;
  text-align: center;
}
.temoignages__header { margin-bottom: 48px; }
.temoignages__slider {
  position: relative; max-width: 740px; margin: 0 auto; min-height: 200px;
}
.temoignage-slide {
  opacity: 0; position: absolute; top: 0; left: 0; right: 0;
  transition: opacity var(--transition-base); pointer-events: none;
}
.temoignage-slide.active { opacity: 1; position: relative; pointer-events: all; }

/* Testimonial card */
.temoignage-slide__inner {
  border: none; padding: 48px 0;
  position: relative; border-radius: 0;
  background: transparent;
  border-top: 1px solid #E8E8E8;
  border-bottom: 1px solid #E8E8E8;
}
/* CLEAN: supprimé .temoignage-slide__corner { display: none; } · aucun élément HTML */

.temoignage-slide__star {
  display: block; margin: 0 auto 16px; width: 20px; height: 20px;
  color: var(--gold); opacity: 0.4;
}
.temoignage-slide__text {
  font-family: var(--font-display); font-weight: 600; font-style: italic;
  font-size: clamp(20px, 2.5vw, 24px);
  color: var(--ink); line-height: 1.6; margin-bottom: 24px;
}
.temoignage-slide__author {
  font-family: var(--font-body); font-weight: 500; font-size: 13px;
  text-transform: uppercase; letter-spacing: 0.12em;
  color: var(--gold);
  display: inline-flex; align-items: center; gap: 12px;
}
.temoignage-slide__author::before {
  content: ''; display: block; width: 24px; height: 1px; background: var(--gold);
}
.temoignages__nav {
  display: flex; align-items: center; justify-content: center;
  gap: 16px; margin-top: 36px;
}
.temoignages__nav-btn {
  width: 40px; height: 40px;
  display: flex; align-items: center; justify-content: center;
  border: 1px solid #D0D0D0;
  border-radius: 0;
  color: #0A0A0A; font-size: 18px;
  transition: border-color var(--transition-fast), background var(--transition-fast);
}
.temoignages__nav-btn:hover { border-color: #0A0A0A; background: #F5F5F5; }
.temoignages__dots { display: flex; gap: 8px; }
.temoignages__dot {
  position: relative;
  width: 8px; height: 8px; border-radius: 50%;
  background: #D0D0D0; cursor: pointer;
  transition: background var(--transition-fast);
}
/* Zone tactile élargie (44px) sans modifier l'apparence du point */
.temoignages__dot::before {
  content: ''; position: absolute; inset: -18px;
}
.temoignages__dot.active { background: #0A0A0A; }

/* ---------- A PROPOS ---------- */
.apropos { background: var(--sand); padding: var(--section-padding) 0; }
.apropos__layout { display: flex; align-items: center; gap: 0; }
.apropos__image-wrap {
  flex: 0 0 45%; position: relative; overflow: visible; min-height: 500px;
  padding: 40px;
}
.apropos__image {
  width: 100%; height: 100%; object-fit: cover;
  filter: saturate(0.85);
  border-radius: 60% 40% 50% 45% / 45% 55% 40% 55%;
  box-shadow: 0 20px 60px rgba(44,30,20,0.2), 0 0 0 8px rgba(166,124,82,0.1);
  position: absolute; inset: 40px;
}
.apropos__text {
  flex: 1; padding: 60px 60px 60px 72px;
  display: flex; flex-direction: column; justify-content: center;
}
.apropos__title {
  font-family: var(--font-display); font-weight: 600;
  font-size: clamp(32px, 3.5vw, 48px);
  margin-bottom: 32px; color: var(--ink);
}
.apropos__dynamic {
  font-family: var(--font-body); font-weight: 300; font-size: 17px;
  color: var(--grey-text); line-height: 1.7; margin-bottom: 20px;
  transition: opacity var(--transition-base);
}
.apropos__fixed {
  font-family: var(--font-body); font-weight: 300; font-size: 17px;
  color: var(--grey-text); line-height: 1.7;
}

/* ---------- FAQ ---------- */
.faq { background: var(--ivory); padding: var(--section-padding) 0; }
.faq__header { text-align: center; margin-bottom: 48px; }
.faq__list { max-width: 800px; margin: 0 auto; }
.faq-item { border-bottom: 1px solid #E8E8E8; }
.faq-item__question {
  width: 100%; display: flex; align-items: center;
  justify-content: space-between; padding: 24px 0;
  font-family: var(--font-body); font-weight: 500; font-size: 17px;
  color: #0A0A0A; text-align: left; cursor: pointer;
  background: none; border: none;
  transition: color var(--transition-fast);
}
.faq-item__question:hover { opacity: 0.6; }
.faq-item__icon {
  flex-shrink: 0; width: 24px; height: 24px;
  display: flex; align-items: center; justify-content: center;
  font-size: 20px; color: #0A0A0A;
  transition: transform var(--transition-fast); margin-left: 16px;
}
.faq-item.open .faq-item__icon { transform: rotate(45deg); }
.faq-item__answer { max-height: 0; overflow: hidden; transition: max-height var(--transition-base); }
.faq-item__answer-inner {
  padding: 0 0 20px;
  font-family: var(--font-body); font-weight: 300; font-size: 16px;
  color: var(--grey-text); line-height: 1.7;
}

/* ---------- LEXIQUE / DÉFINITION ---------- */
.lexique {
  background: #0A0A0A; color: #fff;
  padding: clamp(80px, 10vw, 140px) 0;
}
.lexique__inner {
  max-width: 720px; margin: 0 auto;
}
.lexique__entry {
  padding: 32px 0;
}
.lexique__lang {
  font-family: var(--font-body); font-weight: 500; font-size: 11px;
  text-transform: uppercase; letter-spacing: 0.25em;
  color: rgba(255,255,255,0.35); margin-bottom: 12px;
}
.lexique__word {
  font-family: var(--font-display); font-weight: 700;
  font-size: clamp(36px, 5vw, 56px); letter-spacing: -0.03em;
  line-height: 1.1; margin-bottom: 8px;
}
.lexique__phonetic {
  font-weight: 400; font-size: 0.45em;
  color: rgba(255,255,255,0.4); letter-spacing: 0;
  margin-left: 12px; vertical-align: middle;
}
.lexique__arabic {
  font-size: 0.5em; color: rgba(255,255,255,0.5);
  margin-left: 8px; vertical-align: middle;
}
.lexique__type {
  font-family: var(--font-body); font-weight: 400; font-size: 14px;
  font-style: italic; color: rgba(255,255,255,0.4);
  margin-bottom: 16px;
}
.lexique__def {
  font-family: var(--font-body); font-weight: 300; font-size: 17px;
  color: rgba(255,255,255,0.75); line-height: 1.7;
}
.lexique__example {
  display: block; margin-top: 12px;
  font-style: italic; font-size: 15px;
  color: rgba(255,255,255,0.45);
}
.lexique__divider {
  width: 40px; height: 1px;
  background: rgba(255,255,255,0.15);
  margin: 8px 0;
}
.lexique__footer {
  margin-top: 48px; padding-top: 40px;
  border-top: 1px solid rgba(255,255,255,0.1);
  text-align: center;
}
.lexique__conclusion {
  font-family: var(--font-display); font-weight: 600;
  font-size: clamp(20px, 2.5vw, 28px);
  color: #fff; letter-spacing: -0.01em;
  line-height: 1.4;
}

/* ---------- CONTACT: Multi-step form ---------- */
.contact {
  background: var(--ink); padding: var(--section-padding) 0;
  position: relative; color: #fff; overflow: hidden;
}
.contact__header { text-align: center; margin-bottom: 48px; }
.contact__title {
  font-family: var(--font-display); font-weight: 700;
  font-size: clamp(36px, 5vw, 64px); letter-spacing: -0.03em;
}
.contact__subtitle {
  font-family: var(--font-body); font-weight: 400;
  font-size: 16px; color: rgba(255,255,255,0.5); margin-top: 12px;
}

/* Progress */
.contact__progress { margin-bottom: 48px; }
.contact__progress-bar {
  height: 2px; background: rgba(255,255,255,0.1); border-radius: 1px;
  margin-bottom: 20px; overflow: hidden;
}
.contact__progress-fill {
  height: 100%; width: 25%; background: #fff;
  transition: width 0.5s cubic-bezier(0.25, 0.46, 0.45, 0.94);
}
.contact__progress-steps {
  display: flex; justify-content: space-between; gap: 8px;
}
.contact__step-dot {
  background: none; border: none; color: rgba(255,255,255,0.3);
  font-family: var(--font-body); font-size: 12px; letter-spacing: 0.05em;
  text-transform: uppercase; cursor: pointer; padding: 0;
  transition: color 0.3s;
}
.contact__step-dot span {
  font-weight: 700; margin-right: 4px; font-size: 13px;
}
.contact__step-dot.active { color: #fff; }
.contact__step-dot.done { color: rgba(255,255,255,0.6); }

/* Panels */
.contact__step-panel {
  display: none;
  animation: fadeSlideUp 0.4s ease;
}
.contact__step-panel.active { display: block; }
@keyframes fadeSlideUp {
  from { opacity: 0; transform: translateY(20px); }
  to { opacity: 1; transform: translateY(0); }
}
.contact__step-question {
  font-family: var(--font-display); font-weight: 600;
  font-size: clamp(22px, 3vw, 32px); margin-bottom: 32px;
  text-align: center; letter-spacing: -0.02em;
}
.contact__step-hint {
  text-align: center; font-size: 14px; color: rgba(255,255,255,0.4);
  margin-top: -20px; margin-bottom: 32px;
}

/* Step 1: Event type cards */
.contact__cards {
  display: grid; grid-template-columns: repeat(3, 1fr);
  gap: 16px; max-width: 800px; margin: 0 auto;
}
.contact__card { cursor: pointer; position: relative; }
.contact__card input { display: none; }
.contact__card-inner {
  display: flex; flex-direction: column; align-items: center;
  gap: 8px; padding: 36px 16px 24px;
  background: rgba(255,255,255,0.03);
  transition: background 0.3s;
  position: relative;
  /* Forme arche · inspiration architecturale marocaine */
  clip-path: polygon(
    0% 18%, 6% 8%, 15% 3%, 25% 0.5%, 50% 0%, 75% 0.5%, 85% 3%, 94% 8%, 100% 18%,
    100% 100%, 0% 100%
  );
}
/* Contour arche via pseudo-element */
.contact__card-inner::before {
  content: '';
  position: absolute;
  inset: 0;
  background: rgba(255,255,255,0.12);
  clip-path: polygon(
    0% 18%, 6% 8%, 15% 3%, 25% 0.5%, 50% 0%, 75% 0.5%, 85% 3%, 94% 8%, 100% 18%,
    100% 100%, 0% 100%,
    /* Inner cutout (1px inset) */
    1px 100%, 1px calc(18% + 1px),
    calc(6% + 1px) calc(8% + 1px), calc(15% + 1px) calc(3% + 1px),
    calc(25% + 0.5px) calc(0.5% + 1px), 50% 1px,
    calc(75% - 0.5px) calc(0.5% + 1px), calc(85% - 1px) calc(3% + 1px),
    calc(94% - 1px) calc(8% + 1px), calc(100% - 1px) calc(18% + 1px),
    calc(100% - 1px) 100%, 1px 100%
  );
  pointer-events: none;
  transition: background 0.3s;
}
.contact__card:hover .contact__card-inner {
  background: rgba(255,255,255,0.06);
}
.contact__card:hover .contact__card-inner::before {
  background: rgba(255,255,255,0.3);
}
.contact__card input:checked ~ .contact__card-inner {
  background: rgba(255,255,255,0.1);
}
.contact__card input:checked ~ .contact__card-inner::before {
  background: #fff;
}
.contact__card-icon {
  display: flex; align-items: center; justify-content: center;
  width: 36px; height: 36px;
  color: var(--sand);
  transition: color var(--transition-base);
}
.contact__card-icon svg { width: 100%; height: 100%; }
.contact__card input:checked ~ .contact__card-inner .contact__card-icon { color: #fff; }

/* ---- Contact card icon hover animations ---- */

/* Clink · two champagne glasses side by side */
.contact__card-icon--wide { width: 56px; gap: 2px; }
.contact__card-icon--wide svg { width: 26px; height: 26px; }
.contact__card-icon--wide .clink-left {
  transform: rotate(-10deg);
  transform-origin: bottom right;
}
.contact__card-icon--wide .clink-right {
  transform: rotate(10deg);
  transform-origin: bottom left;
}
@keyframes clink-left {
  0%   { transform: rotate(-10deg); }
  30%  { transform: rotate(-22deg) translateX(-3px); }
  55%  { transform: rotate(2deg) translateX(1px); }
  70%  { transform: rotate(-10deg); }
  100% { transform: rotate(-10deg); }
}
@keyframes clink-right {
  0%   { transform: rotate(10deg); }
  30%  { transform: rotate(22deg) translateX(3px); }
  55%  { transform: rotate(-2deg) translateX(-1px); }
  70%  { transform: rotate(10deg); }
  100% { transform: rotate(10deg); }
}
.contact__card:hover [data-anim="clink"] .clink-left {
  animation: clink-left 700ms ease-in-out;
  transform-origin: bottom right;
}
.contact__card:hover [data-anim="clink"] .clink-right {
  animation: clink-right 700ms ease-in-out;
  transform-origin: bottom left;
}

/* Crew · four stick figures, arms down → arms up + jump on hover */
.contact__card-icon--crew { width: 80px; gap: 2px; }
.contact__card-icon--crew .crew-person { width: 20px; height: 34px; }

/* Arms transition from down to up */
.crew-arm-l, .crew-arm-r {
  transition: d 400ms ease-in-out;
}
/* Hover: arms go up · use transform on arm paths */
.contact__card:hover .contact__card-icon--crew .crew-arm-l {
  d: path("M8 9l-5 -5");
}
.contact__card:hover .contact__card-icon--crew .crew-arm-r {
  d: path("M8 9l5 -5");
}

/* Jump animation on hover */
@keyframes crew-jump {
  0%   { transform: translateY(0); }
  30%  { transform: translateY(-8px); }
  50%  { transform: translateY(-8px); }
  70%  { transform: translateY(0); }
  85%  { transform: translateY(-3px); }
  100% { transform: translateY(0); }
}
.contact__card:hover [data-anim="crew"] .crew-person {
  animation: crew-jump 700ms ease-in-out;
}
.contact__card:hover [data-anim="crew"] .crew-person:nth-child(2) { animation-delay: 50ms; }
.contact__card:hover [data-anim="crew"] .crew-person:nth-child(3) { animation-delay: 100ms; }
.contact__card:hover [data-anim="crew"] .crew-person:nth-child(4) { animation-delay: 150ms; }

/* Camera · real flash burst */
[data-anim="camera"] { position: relative; overflow: visible; }
[data-anim="camera"]::after {
  content: '';
  position: absolute;
  inset: -8px;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(255,255,255,0.9) 0%, rgba(255,255,255,0) 70%);
  opacity: 0;
  transform: scale(0.3);
  pointer-events: none;
}
@keyframes camera-flash-svg {
  0%   { transform: scale(1); }
  25%  { transform: scale(1.06); }
  30%  { transform: scale(1); }
  100% { transform: scale(1); }
}
@keyframes camera-flash-burst {
  0%   { opacity: 0; transform: scale(0.3); }
  20%  { opacity: 0; transform: scale(0.3); }
  30%  { opacity: 1; transform: scale(1.8); }
  50%  { opacity: 0.8; transform: scale(2.2); }
  70%  { opacity: 0; transform: scale(2.5); }
  100% { opacity: 0; transform: scale(0.3); }
}
.contact__card:hover [data-anim="camera"] svg {
  animation: camera-flash-svg 700ms ease-in-out;
}
.contact__card:hover [data-anim="camera"]::after {
  animation: camera-flash-burst 700ms ease-out;
}

/* Plane · orbits around the card text */
.contact__card:has([data-anim="plane"]) { overflow: visible; position: relative; }
[data-anim="plane"] { overflow: visible; }
@keyframes plane-orbit {
  0%   { transform: translate(0, 0) rotate(0deg) scale(1); }
  8%   { transform: translate(40px, -20px) rotate(15deg) scale(0.85); }
  20%  { transform: translate(100px, 15px) rotate(40deg) scale(0.7); }
  35%  { transform: translate(60px, 65px) rotate(110deg) scale(0.65); }
  50%  { transform: translate(-10px, 75px) rotate(180deg) scale(0.6); }
  65%  { transform: translate(-80px, 50px) rotate(240deg) scale(0.65); }
  78%  { transform: translate(-90px, -10px) rotate(310deg) scale(0.75); }
  90%  { transform: translate(-30px, -25px) rotate(350deg) scale(0.9); }
  100% { transform: translate(0, 0) rotate(360deg) scale(1); }
}
.contact__card:hover [data-anim="plane"] svg {
  animation: plane-orbit 1400ms ease-in-out;
}

/* Rocket · straight launch with exhaust smoke */
[data-anim="rocket"] { position: relative; overflow: visible; }
[data-anim="rocket"]::after {
  content: '';
  position: absolute;
  bottom: 2px;
  left: 50%;
  width: 8px; height: 8px;
  margin-left: -4px;
  border-radius: 50%;
  background: rgba(255,255,255,0.7);
  opacity: 0;
  pointer-events: none;
  box-shadow:
    -6px  5px 2px 1px rgba(255,255,255,0.5),
     6px  5px 2px 1px rgba(255,255,255,0.5),
     0px 12px 3px 2px rgba(255,255,255,0.4),
    -8px 18px 4px 2px rgba(255,255,255,0.3),
     8px 18px 4px 2px rgba(255,255,255,0.3),
    -3px 24px 5px 3px rgba(255,255,255,0.2),
     3px 24px 5px 3px rgba(255,255,255,0.2),
     0px 30px 6px 3px rgba(255,255,255,0.1);
}
@keyframes rocket-launch {
  0%   { transform: translateY(0); opacity: 1; }
  40%  { transform: translateY(-28px); opacity: 0; }
  41%  { transform: translateY(12px); opacity: 0; }
  70%  { transform: translateY(0); opacity: 1; }
  100% { transform: translateY(0); opacity: 1; }
}
@keyframes rocket-smoke {
  0%   { opacity: 0; transform: scaleY(0.2) scaleX(0.5); filter: blur(0px); }
  10%  { opacity: 0.7; transform: scaleY(0.5) scaleX(0.7); filter: blur(1px); }
  30%  { opacity: 0.6; transform: scaleY(0.9) scaleX(1); filter: blur(2px); }
  50%  { opacity: 0.35; transform: scaleY(1.1) scaleX(1.3); filter: blur(3px); }
  70%  { opacity: 0.1; transform: scaleY(1.3) scaleX(1.5); filter: blur(5px); }
  100% { opacity: 0; transform: scaleY(1.5) scaleX(1.8); filter: blur(6px); }
}
.contact__card:hover [data-anim="rocket"] svg {
  animation: rocket-launch 900ms ease-in-out;
}
.contact__card:hover [data-anim="rocket"]::after {
  animation: rocket-smoke 900ms ease-out;
}

/* Sparkles · twinkle / shimmer */
@keyframes sparkle-twinkle {
  0%   { transform: scale(1) rotate(0); opacity: 1; }
  20%  { transform: scale(0.85) rotate(-8deg); opacity: 0.6; }
  40%  { transform: scale(1.15) rotate(6deg); opacity: 1; }
  60%  { transform: scale(0.9) rotate(-4deg); opacity: 0.7; }
  80%  { transform: scale(1.1) rotate(3deg); opacity: 1; }
  100% { transform: scale(1) rotate(0); opacity: 1; }
}
.contact__card:hover [data-anim="sparkles"] svg {
  animation: sparkle-twinkle 800ms ease-in-out;
}

/* ---- PRIVÉ card animations ---- */

/* Clink: two glasses tilt inward to clink */
.contact__card-icon--prive-clink { display: flex; gap: 6px; }
.contact__card-icon--prive-clink svg { width: 45%; height: 100%; }
.contact__card-icon--prive-clink .prive-glass-l { transform: rotate(-10deg); transform-origin: bottom center; }
.contact__card-icon--prive-clink .prive-glass-r { transform: rotate(10deg) scaleX(-1); transform-origin: bottom center; }
@keyframes prive-clink-l { 0% { transform: rotate(-10deg); } 35% { transform: rotate(-22deg); } 50% { transform: rotate(-6deg); } 100% { transform: rotate(-10deg); } }
@keyframes prive-clink-r { 0% { transform: rotate(10deg) scaleX(-1); } 35% { transform: rotate(22deg) scaleX(-1); } 50% { transform: rotate(6deg) scaleX(-1); } 100% { transform: rotate(10deg) scaleX(-1); } }
.contact__card:hover [data-anim="prive-clink"] .prive-glass-l { animation: prive-clink-l 700ms ease-in-out; }
.contact__card:hover [data-anim="prive-clink"] .prive-glass-r { animation: prive-clink-r 700ms ease-in-out; }

/* Cloche: dome lifts up to reveal */
@keyframes prive-cloche-lift {
  0%   { transform: translateY(0) rotate(0); }
  30%  { transform: translateY(-8px) rotate(-5deg); }
  50%  { transform: translateY(-10px) rotate(3deg); }
  70%  { transform: translateY(-5px) rotate(-2deg); }
  100% { transform: translateY(0) rotate(0); }
}
.contact__card:hover [data-anim="prive-cloche"] .cloche-dome {
  animation: prive-cloche-lift 800ms ease-in-out;
  transform-origin: center bottom;
}

/* Kiss: bride (robe) + groom (cravate) lean in, heart pulses */
.contact__card-icon--prive-kiss { display: flex; align-items: flex-end; gap: 2px; }
.contact__card-icon--prive-kiss .prive-bride { width: 38%; height: 100%; }
.contact__card-icon--prive-kiss .prive-heart { width: 18%; height: 40%; align-self: flex-start; margin-top: 4px; opacity: 0.5; }
.contact__card-icon--prive-kiss .prive-groom { width: 38%; height: 100%; }
@keyframes prive-lean-l { 0% { transform: rotate(0); } 35% { transform: rotate(10deg) translateX(3px); } 100% { transform: rotate(0); } }
@keyframes prive-lean-r { 0% { transform: rotate(0); } 35% { transform: rotate(-10deg) translateX(-3px); } 100% { transform: rotate(0); } }
@keyframes prive-heart-pulse { 0% { transform: scale(1); opacity: 0.5; } 25% { transform: scale(0.5); opacity: 0; } 50% { transform: scale(1.4); opacity: 1; } 75% { transform: scale(1); } 100% { transform: scale(1); opacity: 0.5; } }
.contact__card:hover [data-anim="prive-kiss"] .prive-bride { animation: prive-lean-l 900ms ease-in-out; transform-origin: bottom right; }
.contact__card:hover [data-anim="prive-kiss"] .prive-groom { animation: prive-lean-r 900ms ease-in-out; transform-origin: bottom left; }
.contact__card:hover [data-anim="prive-kiss"] .prive-heart { animation: prive-heart-pulse 900ms ease-in-out; }

/* Plane: rectangle orbit tracing the card edges */
.contact__card:has([data-anim="prive-plane"]) { overflow: visible; position: relative; }
.contact__card:has([data-anim="prive-plane"]) .contact__card-inner { overflow: visible; clip-path: none; }
[data-anim="prive-plane"] { overflow: visible; z-index: 10; position: relative; }
@keyframes prive-plane-orbit {
  0%   { transform: translate(0, 0); }
  10%  { transform: translate(70px, -60px) rotate(0deg); }
  25%  { transform: translate(70px, 60px) rotate(90deg); }
  50%  { transform: translate(-70px, 60px) rotate(180deg); }
  75%  { transform: translate(-70px, -60px) rotate(270deg); }
  90%  { transform: translate(0px, -60px) rotate(340deg); }
  100% { transform: translate(0, 0) rotate(360deg); }
}
.contact__card:hover [data-anim="prive-plane"] svg { animation: prive-plane-orbit 2000ms linear; }

/* Sparkles: twinkle individually */
@keyframes prive-sparkle-main { 0% { transform: scale(1) rotate(0); } 25% { transform: scale(1.15) rotate(8deg); } 50% { transform: scale(0.9) rotate(-5deg); } 75% { transform: scale(1.1) rotate(3deg); } 100% { transform: scale(1) rotate(0); } }
@keyframes prive-sparkle-sm { 0% { opacity: 1; } 30% { opacity: 0.2; } 60% { opacity: 1; } 80% { opacity: 0.3; } 100% { opacity: 1; } }
.contact__card:hover [data-anim="prive-sparkle"] .sparkle-main { animation: prive-sparkle-main 900ms ease-in-out; }
.contact__card:hover [data-anim="prive-sparkle"] .sparkle-sm1 { animation: prive-sparkle-sm 600ms ease-in-out; }
.contact__card:hover [data-anim="prive-sparkle"] .sparkle-sm2 { animation: prive-sparkle-sm 600ms 150ms ease-in-out; }

.contact__card-title {
  font-family: var(--font-body); font-weight: 600; font-size: 13px;
  text-transform: uppercase; letter-spacing: 0.08em; text-align: center;
}
.contact__card-desc {
  font-size: 12px; color: rgba(255,255,255,0.4); text-align: center;
}

/* Step 2: Service tags */
.contact__tags {
  display: flex; flex-wrap: wrap; gap: 10px;
  justify-content: center; max-width: 700px; margin: 0 auto;
}
.contact__tag { cursor: pointer; }
.contact__tag input { display: none; }
.contact__tag span {
  display: inline-block; padding: 10px 20px;
  border: 1px solid rgba(255,255,255,0.15);
  font-family: var(--font-body); font-size: 13px; font-weight: 500;
  letter-spacing: 0.03em; color: rgba(255,255,255,0.6);
  transition: all 0.3s;
}
.contact__tag:hover span {
  border-color: rgba(255,255,255,0.4); color: #fff;
}
.contact__tag input:checked ~ span {
  background: #fff; color: #0A0A0A; border-color: #fff;
}

/* Step 3: Budget & timing */
.contact__concrete { max-width: 700px; margin: 0 auto; }
.contact__field-row {
  display: grid; grid-template-columns: 1fr 1fr; gap: 32px;
  margin-bottom: 28px;
}
.contact__field { display: flex; flex-direction: column; gap: 10px; }
.contact__field-label {
  font-family: var(--font-body); font-weight: 600; font-size: 11px;
  text-transform: uppercase; letter-spacing: 0.1em;
  color: rgba(255,255,255,0.5);
}
.contact__range-wrap { position: relative; }
.contact__range {
  width: 100%; -webkit-appearance: none; appearance: none;
  height: 2px; background: rgba(255,255,255,0.15); outline: none;
  border-radius: 1px;
}
.contact__range::-webkit-slider-thumb {
  -webkit-appearance: none; width: 18px; height: 18px;
  background: #fff; border-radius: 50%; cursor: pointer;
  border: 2px solid #0A0A0A;
}
.contact__range-value {
  display: block; text-align: center; margin-top: 8px;
  font-family: var(--font-display); font-weight: 700;
  font-size: 48px; letter-spacing: -0.03em;
}
.contact__range-mood {
  text-align: center; font-size: 14px; font-style: italic;
  color: rgba(255,255,255,0.45); margin-top: 4px;
  transition: opacity 0.3s;
}
.contact__field-full {
  margin-bottom: 36px;
}
.contact__budget-options {
  display: flex; flex-wrap: wrap; gap: 8px;
}
.contact__budget-pill { cursor: pointer; }
.contact__budget-pill input { display: none; }
.contact__budget-pill span {
  display: inline-block; padding: 8px 16px;
  border: 1px solid rgba(255,255,255,0.15);
  font-family: var(--font-body); font-size: 13px; font-weight: 500;
  color: rgba(255,255,255,0.6); transition: all 0.3s;
}
.contact__budget-pill:hover span {
  border-color: rgba(255,255,255,0.4); color: #fff;
}
.contact__budget-pill input:checked ~ span {
  background: #fff; color: #0A0A0A; border-color: #fff;
}
.contact__date-input,
.contact__text-input {
  width: 100%; background: transparent; border: none;
  border-bottom: 1px solid rgba(255,255,255,0.2);
  padding: 12px 0; font-family: var(--font-body);
  font-size: 15px; color: #fff;
  transition: border-color 0.3s;
}
.contact__date-input:focus,
.contact__text-input:focus {
  outline: none; border-bottom-color: #fff;
}
.contact__date-input::placeholder,
.contact__text-input::placeholder { color: rgba(255,255,255,0.3); }
.contact__date-input::-webkit-calendar-picker-indicator { filter: invert(1); }

/* Step 4: Final fields */
.contact__final-fields { max-width: 700px; margin: 0 auto; }
.contact__textarea {
  width: 100%; background: transparent; border: none;
  border-bottom: 1px solid rgba(255,255,255,0.2);
  padding: 12px 0; font-family: var(--font-body);
  font-size: 15px; color: #fff; resize: vertical; min-height: 80px;
  transition: border-color 0.3s;
}
.contact__textarea:focus { outline: none; border-bottom-color: #fff; }
.contact__textarea::placeholder { color: rgba(255,255,255,0.3); }

/* Nav buttons */
.contact__nav {
  display: flex; justify-content: center; gap: 16px;
  margin-top: 48px;
}
.contact__nav-btn {
  font-family: var(--font-body); font-weight: 600; font-size: 13px;
  text-transform: uppercase; letter-spacing: 0.12em;
  padding: 16px 40px; cursor: pointer; border: none;
  transition: all 0.3s;
}
.contact__nav-prev {
  background: transparent; color: rgba(255,255,255,0.5);
  border: 1px solid rgba(255,255,255,0.15) !important;
}
.contact__nav-prev:hover { color: #fff; border-color: rgba(255,255,255,0.4) !important; }
.contact__nav-prev:disabled { opacity: 0.2; cursor: not-allowed; }
.contact__nav-next,
.contact__nav-submit {
  background: #fff; color: #0A0A0A;
  clip-path: polygon(4% 0%, 100% 0%, 96% 100%, 0% 100%);
}
.contact__nav-next:hover,
.contact__nav-submit:hover { background: #E8E8E8; }

/* Success */
.contact__success {
  display: none; text-align: center; padding: 64px 0;
}
.contact__success.visible { display: block; animation: fadeSlideUp 0.5s ease; }
.contact__success-emoji { font-size: 56px; display: block; margin-bottom: 24px; }
.contact__success-title {
  font-family: var(--font-display); font-weight: 700;
  font-size: clamp(28px, 4vw, 48px); margin-bottom: 12px;
}
.contact__success-text {
  font-size: 16px; color: rgba(255,255,255,0.5);
}

/* Info bar */
.contact__info-bar {
  display: flex; justify-content: center; align-items: center;
  flex-wrap: wrap; gap: 12px;
  margin-top: 64px; padding-top: 32px;
  border-top: 1px solid rgba(255,255,255,0.08);
}
.contact__info-link {
  font-family: var(--font-body); font-size: 13px; font-weight: 400;
  color: rgba(255,255,255,0.4); transition: color 0.3s;
  display: inline-flex; align-items: center; gap: 6px;
}
.contact__info-link:hover { color: #fff; }
.contact__info-icon { width: 15px; height: 15px; flex-shrink: 0; }
.contact__info-sep { color: rgba(255,255,255,0.15); font-size: 12px; }

/* UX: validation form · messages d'erreur inline */
.contact__error {
  display: none;
  font-family: var(--font-body); font-size: 12px; font-weight: 400;
  color: #ff6b6b; margin-top: 6px;
  animation: fadeSlideUp 0.3s ease;
}
.contact__error.visible { display: block; }
.contact__text-input.has-error,
.contact__textarea.has-error {
  border-bottom-color: #ff6b6b;
}
@keyframes shake {
  0%, 100% { transform: translateX(0); }
  20%, 60% { transform: translateX(-6px); }
  40%, 80% { transform: translateX(6px); }
}
.contact__shake { animation: shake 0.4s ease; }

/* ---------- FOOTER ---------- */
.footer {
  background: var(--ink); padding: 48px 0 32px; text-align: center;
  position: relative;
}
.footer__logo {
  margin-bottom: 12px;
  display: flex; align-items: center; justify-content: center;
}
/* LOGO: SVG inline footer */
.footer__logo-svg {
  height: 36px;
  width: auto;
  display: block;
  margin: 0 auto;
  color: rgba(255,255,255,0.85);
  transition: color var(--transition-base);
}
.footer__logo-svg:hover {
  color: #fff;
}
.footer__tagline {
  font-family: var(--font-display); font-style: italic;
  font-size: 14px; color: rgba(255,255,255,0.6); letter-spacing: 0.03em;
  margin-bottom: 20px;
}
.footer__links {
  display: flex; align-items: center; justify-content: center;
  gap: 0; margin-bottom: 20px;
}
.footer__link {
  font-family: var(--font-body); font-weight: 500; font-size: 11px;
  text-transform: uppercase; letter-spacing: 0.12em;
  color: rgba(239,231,218,0.6);
  transition: color var(--transition-fast);
}
.footer__link:hover { color: var(--sand-light); }
.footer__diamond { font-size: 6px; color: rgba(255,255,255,0.3); margin: 0 14px; }
.footer__social { display: flex; justify-content: center; gap: 16px; margin-bottom: 24px; }
.footer__social-link {
  width: 20px; height: 20px; color: rgba(239,231,218,0.6);
  transition: color var(--transition-fast);
}
.footer__social-link:hover { color: var(--gold); }
.footer__copyright {
  font-family: var(--font-body); font-weight: 300; font-size: 13px;
  color: rgba(239,231,218,0.4); margin-bottom: 8px;
}
.footer__legal {
  font-family: var(--font-body); font-weight: 300; font-size: 12px;
  color: rgba(239,231,218,0.3);
}
.footer__legal a { transition: color var(--transition-fast); }
.footer__legal a:hover { color: var(--gold); }
.footer__star { display: block; margin: 24px auto 0; }

/* ---------- Scroll reveal ---------- */
.reveal {
  opacity: 0; transform: translateY(24px);
  transition: opacity 600ms ease, transform 600ms ease;
}
.reveal.visible { opacity: 1; transform: translateY(0); }
.reveal-stagger > .reveal:nth-child(1) { transition-delay: 0ms; }
.reveal-stagger > .reveal:nth-child(2) { transition-delay: 100ms; }
.reveal-stagger > .reveal:nth-child(3) { transition-delay: 200ms; }
.reveal-stagger > .reveal:nth-child(4) { transition-delay: 300ms; }

/* WHATSAPP: bouton flottant */
.whatsapp-float {
  position: fixed;
  bottom: 32px;
  right: 88px; /* décalé à gauche du back-to-top (44px bouton + 12px gap + 32px right) */
  z-index: 900;
  width: 48px;
  height: 48px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: var(--ink);
  color: #fff;
  border: 1px solid rgba(255,255,255,0.15);
  border-radius: 50%;
  cursor: pointer;
  text-decoration: none;
  opacity: 0;
  pointer-events: none;
  transform: translateY(10px) scale(0.9);
  transition: opacity 0.4s ease, transform 0.4s ease, background 0.3s ease, border-color 0.3s ease;
}

/* WHATSAPP: état visible */
.whatsapp-float.visible {
  opacity: 1;
  pointer-events: all;
  transform: translateY(0) scale(1);
}

/* WHATSAPP: hover */
.whatsapp-float:hover {
  background: #1A1A1A;
  border-color: rgba(255,255,255,0.35);
  transform: translateY(0) scale(1.08);
}

/* WHATSAPP: focus accessible */
.whatsapp-float:focus-visible {
  outline: 2px solid #fff;
  outline-offset: 3px;
}

/* WHATSAPP: masqué quand le visiteur est dans la section contact */
.whatsapp-float.hidden-in-contact {
  opacity: 0 !important;
  pointer-events: none !important;
  transform: translateY(10px) scale(0.9) !important;
}

/* WHATSAPP: pulse unique après 8s pour attirer l'attention */
@keyframes whatsapp-pulse {
  0% { box-shadow: 0 0 0 0 rgba(255,255,255,0.3); }
  70% { box-shadow: 0 0 0 14px rgba(255,255,255,0); }
  100% { box-shadow: 0 0 0 0 rgba(255,255,255,0); }
}
.whatsapp-float.pulse {
  animation: whatsapp-pulse 1.2s ease-out;
}

/* WHATSAPP: tooltip au hover (desktop only) */
.whatsapp-float::after {
  content: 'Un projet ? Écrivez-nous';
  position: absolute;
  right: 60px;
  top: 50%;
  transform: translateY(-50%);
  white-space: nowrap;
  background: var(--ink);
  color: #fff;
  font-family: var(--font-body);
  font-size: 12px;
  font-weight: 500;
  letter-spacing: 0.02em;
  padding: 8px 16px;
  border: 1px solid rgba(255,255,255,0.15);
  border-radius: 6px;
  opacity: 0;
  pointer-events: none;
  transition: opacity 0.25s ease;
}
.whatsapp-float:hover::after {
  opacity: 1;
}

/* UX: bouton retour en haut */
.back-to-top {
  position: fixed; bottom: 32px; right: 32px; z-index: 900;
  width: 44px; height: 44px;
  display: flex; align-items: center; justify-content: center;
  background: var(--ink); color: #fff;
  border: 1px solid rgba(255,255,255,0.15);
  font-size: 18px; cursor: pointer;
  opacity: 0; pointer-events: none;
  transition: opacity 0.3s, transform 0.3s;
  transform: translateY(10px);
}
.back-to-top.visible {
  opacity: 1; pointer-events: all;
  transform: translateY(0);
}
.back-to-top:hover {
  background: #1A1A1A;
}

/* ---------- Reduced Motion ---------- */
@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after {
    animation-duration: 0.01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.01ms !important;
    scroll-behavior: auto !important;
  }
  .reveal { opacity: 1; transform: none; }
  /* CLEAN: supprimé .hero__zellige-reveal { display: none; } · élément supprimé */
  .marquee__track { animation: none; }
}

/* ---------- RESPONSIVE ---------- */
@media (max-width: 1200px) {
  .services__grid { gap: 16px; }
  .service-card { padding: 28px; }
  .apropos__text { padding: 40px; }
  .dest-showcase__content { padding: 48px; }
  .portfolio__grid { grid-template-columns: repeat(2, 1fr); grid-auto-rows: 300px; }
  .portfolio__card--large { grid-column: span 2; }
  .portfolio__default { opacity: 1; }
}

/* Breakpoint tablette · passage en hamburger */
@media (max-width: 1080px) {
  .nav__links, .nav__cta, .lang-toggle:not(.lang-toggle--mobile) { display: none; }
  .nav__hamburger { display: flex; }
  .nav__logo-svg { height: 28px; }
}

@media (max-width: 768px) {
  :root { --section-padding: 56px; }
  body { font-size: 16px; }

  /* WHATSAPP: mobile · légèrement plus gros pour le touch */
  .whatsapp-float {
    width: 52px;
    height: 52px;
    bottom: 24px;
    right: 76px;
  }
  .whatsapp-float svg {
    width: 26px;
    height: 26px;
  }
  /* WHATSAPP: pas de tooltip sur mobile */
  .whatsapp-float::after {
    display: none;
  }

  .hero__tabs {
    overflow-x: auto; justify-content: flex-start;
    -webkit-overflow-scrolling: touch;
    scroll-snap-type: x mandatory;
    padding: 0 16px; margin-bottom: 32px;
    scrollbar-width: none; -ms-overflow-style: none;
  }
  .hero__tabs::-webkit-scrollbar { display: none; }
  .hero__tab { scroll-snap-align: center; flex-shrink: 0; font-size: 11px; }
  .hero__tab-diamond { margin: 0 8px; }
  .hero__title { font-size: clamp(32px, 8vw, 48px); }
  .hero__subtitle { font-size: 16px; }
  .hero__ctas { flex-direction: column; align-items: center; }
  .hero__cta-primary, .hero__cta-secondary { width: 100%; max-width: 280px; text-align: center; }
  .hero__locations-brands { font-size: 12px; }
  .hero__tagline { font-size: 20px; }

  .services__grid { grid-template-columns: 1fr; }

  .dest-showcase__item { grid-template-columns: 1fr; min-height: 400px; }
  .dest-showcase__item:nth-child(even) { direction: ltr; }
  .dest-showcase__img-wrap { min-height: 280px; }
  .dest-showcase__content { padding: 32px 24px; }
  .dest-showcase__city { font-size: clamp(36px, 10vw, 56px); }
  /* UX: détails cachés par défaut sur mobile, révélés au tap */
  .dest-showcase__details { max-height: 0; opacity: 0; }

  .portfolio__grid { grid-template-columns: 1fr; grid-auto-rows: 280px; }
  .portfolio__card--large { grid-column: span 1; }
  .portfolio__default { opacity: 1; }
  .portfolio__filters { gap: 6px; }
  .portfolio__filter { padding: 8px 16px; font-size: 12px; }
  .maroc-panel { padding: 32px 24px; }
  .maroc-panel__grid { grid-template-columns: 1fr; gap: 24px; }

  .chiffres__grid { gap: 24px; }
  .chiffre-item { min-width: 100px; }

  .temoignage-slide__text { font-size: 20px; }
  .temoignage-slide__inner { padding: 24px; }

  .apropos__layout { flex-direction: column; }
  .apropos__image-wrap { flex: none; width: 100%; min-height: 350px; padding: 24px; }
  .apropos__image { inset: 24px; border-radius: 55% 45% 50% 45% / 45% 50% 45% 55%; }
  .apropos__text { padding: 32px 24px; }

  .contact__cards { grid-template-columns: repeat(2, 1fr); }
  .contact__field-row { grid-template-columns: 1fr; gap: 24px; }
  .contact__progress-steps { flex-wrap: wrap; justify-content: center; }
  .contact__info-bar { flex-direction: column; gap: 8px; }
  .contact__info-sep { display: none; }

  .footer__links { flex-direction: column; gap: 12px; }
  .footer__diamond { display: none; }

}

/* ============================================
   MODE PRIVÉ · Inversion noir/blanc
   ============================================ */

/* Logo flip animation */
.nav__logo-svg,
.footer__logo-svg {
  transition: color var(--transition-base), transform 0.6s cubic-bezier(0.4, 0, 0.2, 1);
}

/* Upside-down logo in PRIVÉ mode */
.mode-prive .nav__logo-svg,
.mode-prive .footer__logo-svg {
  transform: rotate(180deg);
}

/* Smooth global transitions for mode switch */
.mode-prive,
.mode-prive .hero,
.mode-prive .services,
.mode-prive .dest-showcase,
.mode-prive .portfolio,
.mode-prive .temoignages,
.mode-prive .contact,
.mode-prive .footer,
.mode-prive .nav,
.mode-prive .nav--transparent,
.mode-prive .nav--scrolled {
  transition: background-color 0.5s ease, color 0.5s ease;
}

/* Hero section inversion */
.mode-prive .hero { color: var(--ink); }
.mode-prive .hero__bg--gradient { background: #fff; }
.mode-prive .hero__star-float { color: var(--sand-dark); }
.mode-prive .hero__title,
.mode-prive .hero__subtitle { color: var(--ink); }
.mode-prive .hero__tab { color: rgba(0,0,0,0.55); }
.mode-prive .hero__tab.active { color: var(--ink); }
.mode-prive .hero__tab-diamond { color: rgba(0,0,0,0.25); }
.mode-prive .hero__cta-primary { background: var(--ink); color: #fff; }
.mode-prive .hero__cta-secondary { background: transparent; color: var(--ink); border-color: var(--ink); }
.mode-prive .hero__tagline { color: rgba(0,0,0,0.6); }
.mode-prive .hero__locations-brands { color: rgba(0,0,0,0.4); }

/* Nav inversion */
.mode-prive .nav--transparent { background: rgba(255,255,255,0.95); }
.mode-prive .nav--transparent .nav__logo-svg { color: var(--ink); }
.mode-prive .nav--transparent .nav__link { color: var(--ink); }
.mode-prive .nav--transparent .nav__diamond { color: rgba(0,0,0,0.2); }
.mode-prive .nav--transparent .nav__cta { background: var(--ink); color: #fff; }
.mode-prive .nav--transparent .nav__hamburger span { background: var(--ink); }
.mode-prive .nav--transparent .lang-toggle__btn { color: rgba(0,0,0,0.4); }
.mode-prive .nav--transparent .lang-toggle__btn.active { color: var(--ink); background: var(--sand); }
.mode-prive .nav--transparent .lang-toggle__sep { color: rgba(0,0,0,0.2); }
.mode-prive .nav--transparent .mode-toggle__btn { color: rgba(0,0,0,0.4); }
.mode-prive .nav--transparent .mode-toggle__btn.active { color: var(--ink); background: var(--sand); }
.mode-prive .nav--transparent .mode-toggle__sep { color: rgba(0,0,0,0.2); }

/* Services section inversion */
.mode-prive .services { background: #fff; }
.mode-prive .section-title { color: var(--ink); }
.mode-prive .section-subtitle { color: var(--sage); }
.mode-prive .service-card { background: var(--sand-light); border-color: var(--sand); }
.mode-prive .service-card__icon { color: var(--ink); }
.mode-prive .service-card__title { color: var(--ink); }
.mode-prive .service-card__desc { color: var(--sage); }
.mode-prive .service-card__toggle { color: var(--ink); }
.mode-prive .service-card__features li { color: var(--sage); }
.mode-prive .service-card__features li::before { color: var(--ink); }
.mode-prive .marquee__title { color: var(--sage); }
.mode-prive .marquee__item { color: var(--ink); }
.mode-prive .marquee__diamond { color: var(--sand-dark); }
.mode-prive .services__cta { background: var(--ink); color: #fff; }

/* Destinations inversion (only section bg, NOT card content which stays on dark overlay) */
.mode-prive .dest-showcase { background: var(--sand-light); }
.mode-prive .dest-showcase .section-title { color: var(--ink); }
.mode-prive .dest-showcase .section-subtitle { color: var(--sage); }

/* Portfolio inversion */
.mode-prive .portfolio { background: #fff; }
.mode-prive .portfolio__filter { color: var(--sage); border-color: var(--sand); }
.mode-prive .portfolio__filter.active { background: var(--ink); color: #fff; }

/* Testimonials inversion */
.mode-prive .temoignages { background: #fff; }
.mode-prive .temoignage-slide__text { color: var(--ink); }
.mode-prive .temoignage-slide__author { color: var(--sage); }
.mode-prive .temoignage-slide__star { color: var(--sand-dark); }
.mode-prive .temoignages__dot { background: var(--sand-dark); }
.mode-prive .temoignages__dot.active { background: var(--ink); }

/* About section */
.mode-prive .apropos { background: #fff; }
.mode-prive .apropos__text { color: var(--ink); }
.mode-prive .apropos__title { color: var(--ink); }
.mode-prive .apropos__fixed { color: var(--sage); }
.mode-prive .apropos__dynamic { color: var(--ink); }
.mode-prive .apropos__image-wrap { background: var(--sand-light); }

/* Lexique */
.mode-prive .lexique { background: #fff; color: var(--ink); }
.mode-prive .lexique__lang { color: rgba(0,0,0,0.35); }
.mode-prive .lexique__word { color: var(--ink); }
.mode-prive .lexique__phonetic { color: rgba(0,0,0,0.4); }
.mode-prive .lexique__arabic { color: rgba(0,0,0,0.5); }
.mode-prive .lexique__type { color: rgba(0,0,0,0.4); }
.mode-prive .lexique__def { color: var(--sage); }
.mode-prive .lexique__example { color: rgba(0,0,0,0.5); }
.mode-prive .lexique__divider { background: rgba(0,0,0,0.15); }
.mode-prive .lexique__conclusion { color: var(--ink); }
.mode-prive .lexique__footer-line { background: rgba(0,0,0,0.15); }

/* Stats */
.mode-prive .chiffres { background: #fff; }
.mode-prive .chiffres__title { color: var(--ink); }
.mode-prive .chiffre-item__number { color: var(--ink); }
.mode-prive .chiffre-item__label { color: var(--sage); }

/* FAQ inversion */
.mode-prive .faq { background: #fff; }
.mode-prive .faq-item { border-color: var(--sand); }
.mode-prive .faq-item__question { color: var(--ink); }
.mode-prive .faq-item__answer-inner { color: var(--sage); }

/* Contact section inversion */
.mode-prive .contact { background: var(--sand-light); }
.mode-prive .contact__title { color: var(--ink); }
.mode-prive .contact__subtitle { color: var(--sage); }
.mode-prive .contact__step-question { color: var(--ink); }
.mode-prive .contact__step-hint { color: var(--sage); }
.mode-prive .contact__card-inner {
  border-color: rgba(0,0,0,0.1);
  background: rgba(0,0,0,0.02);
}
.mode-prive .contact__card-inner::before { background: rgba(0,0,0,0.1); }
.mode-prive .contact__card:hover .contact__card-inner { background: rgba(0,0,0,0.05); }
.mode-prive .contact__card:hover .contact__card-inner::before { background: rgba(0,0,0,0.2); }
.mode-prive .contact__card input:checked ~ .contact__card-inner { background: rgba(0,0,0,0.08); }
.mode-prive .contact__card input:checked ~ .contact__card-inner::before { background: var(--ink); }
.mode-prive .contact__card-icon { color: var(--sage); width: 36px; height: 36px; }
.mode-prive .contact__card-icon--prive-clink { width: 52px; }
.mode-prive .contact__card-icon--prive-kiss { width: 56px; height: 40px; }
.mode-prive .contact__card input:checked ~ .contact__card-inner .contact__card-icon { color: var(--ink); }
.mode-prive .contact__card-title { color: var(--ink); }
.mode-prive .contact__card-desc { color: var(--sage); }
.mode-prive .contact__tag span { color: var(--ink); border-color: var(--sand); }
.mode-prive .contact__tag input:checked + span { background: var(--ink); color: #fff; }
.mode-prive .contact__field label { color: var(--ink); }
.mode-prive .contact__field input,
.mode-prive .contact__field textarea,
.mode-prive .contact__field select { color: var(--ink); border-color: var(--sand); background: #fff; }
.mode-prive .contact__nav-next { background: var(--ink); color: #fff; }
.mode-prive .contact__nav-prev { color: var(--ink); border-color: var(--sand); }
.mode-prive .contact__nav-submit { background: var(--ink); color: #fff; }
.mode-prive .contact__progress-step { color: var(--sage); }
.mode-prive .contact__progress-step.active { color: var(--ink); }
.mode-prive .contact__step-dot { color: rgba(0,0,0,0.3); }
.mode-prive .contact__step-dot.active { color: var(--ink); }
.mode-prive .contact__info-link { color: var(--ink); }
.mode-prive .contact__info-sep { color: var(--sand-dark); }

/* Footer inversion */
.mode-prive .footer { background: var(--sand-light); }
.mode-prive .footer__logo-svg { color: var(--ink); }
.mode-prive .footer__tagline { color: var(--ink); }
.mode-prive .footer__link { color: var(--ink); border-color: rgba(0,0,0,0.1); }
.mode-prive .footer__copyright { color: var(--sage); }
.mode-prive .footer__social-link { color: var(--ink); border-color: rgba(0,0,0,0.1); }

/* Contact progress bar & range */
.mode-prive .contact__progress-bar { background: var(--sand); }
.mode-prive .contact__progress-fill { background: var(--ink); }
.mode-prive .contact__range { background: var(--sand); }
.mode-prive .contact__range::-webkit-slider-thumb { background: var(--ink); border-color: var(--ink); }
.mode-prive .contact__range-value { color: var(--ink); }
.mode-prive .contact__range-mood { color: var(--sage); }
.mode-prive .contact__success-title { color: var(--ink); }
.mode-prive .contact__success-text { color: var(--sage); }

/* Testimonials nav buttons */
.mode-prive .temoignages__nav-btn { color: var(--ink); border-color: var(--sand); }
.mode-prive .temoignages__nav-btn:hover { background: var(--sand-light); }
.mode-prive .temoignage-slide { border-color: var(--sand); }

/* Portfolio "show more" + mention + CTA in PRIVÉ */
.mode-prive .portfolio__more-wrap { display: none; }
.mode-prive .portfolio__mention { color: var(--sage); }
.mode-prive .portfolio__cta-text { color: var(--ink); }
.mode-prive .portfolio__cta { background: var(--ink); color: #fff; }
.mode-prive .portfolio__subtitle { color: var(--sage); }

/* Marquee hidden in PRIVÉ (B2B brands irrelevant for private clients) */
.mode-prive .marquee { display: none; }

/* Mobile menu in PRIVÉ */
.mode-prive .mobile-menu { background: var(--ink); }

/* WhatsApp float */
.mode-prive .whatsapp-float { background: var(--ink); }
.mode-prive #backToTop { background: var(--ink); color: #fff; }
