/* Maison de Beauté Nawar — shared theme */

body { font-family: 'Manrope', sans-serif; background: #FFFFFF; color: #2A2522; font-weight: 300; }
.font-display { font-family: 'Cormorant Garamond', serif; }
.eyebrow { font-family: 'Cormorant Garamond', serif; font-style: italic; font-weight: 400; color: #8B6F4E; letter-spacing: 0.02em; }

.hero-display { font-size: clamp(3rem, 8vw, 7.5rem); line-height: 0.95; letter-spacing: -0.02em; }
.section-display { font-size: clamp(2.25rem, 5.5vw, 4.75rem); line-height: 1; letter-spacing: -0.01em; }

/* Photo en arcade — signature visuelle Anna */
.arch { border-radius: 200px 200px 16px 16px; overflow: hidden; }
.arch-soft { border-radius: 140px 140px 12px 12px; overflow: hidden; }
.arch-mini { border-radius: 80px 80px 8px 8px; overflow: hidden; }

/* Polaroid */
.polaroid {
  background: #FFFFFF;
  padding: 12px 12px 48px 12px;
  box-shadow: 0 16px 40px -8px rgba(74, 53, 39, 0.18), 0 4px 8px rgba(74, 53, 39, 0.08);
  transition: transform 0.5s cubic-bezier(.2,.8,.2,1);
}
.polaroid:hover { transform: rotate(0deg) scale(1.02); }
.polaroid img { display: block; width: 100%; height: auto; }
.polaroid-rotate-left { transform: rotate(-4deg); }
.polaroid-rotate-right { transform: rotate(3deg); }
.polaroid-caption {
  font-family: 'Cormorant Garamond', serif;
  font-style: italic;
  font-size: 1.05rem;
  letter-spacing: 0.02em;
  color: #4A3527;
  text-align: center;
  margin-top: 12px;
}

/* Boutons */
.btn-mocha {
  background: #4A3527;
  color: #FFFFFF;
  transition: background 0.3s ease, transform 0.3s ease, box-shadow 0.3s ease;
  box-shadow: 0 4px 12px rgba(74, 53, 39, 0.18);
}
.btn-mocha:hover { background: #2A2522; transform: translateY(-2px); box-shadow: 0 8px 20px rgba(74, 53, 39, 0.25); }
.btn-taupe {
  background: #C9B89E;
  color: #4A3527;
  transition: background 0.3s ease, transform 0.3s ease;
}
.btn-taupe:hover { background: #B5A285; transform: translateY(-1px); }

/* Galerie horizontale */
.scroll-snap-x { scroll-snap-type: x mandatory; -webkit-overflow-scrolling: touch; scrollbar-width: thin; }
.scroll-snap-x > * { scroll-snap-align: start; }
.scroll-snap-x::-webkit-scrollbar { height: 4px; }
.scroll-snap-x::-webkit-scrollbar-track { background: #F8F4ED; border-radius: 2px; }
.scroll-snap-x::-webkit-scrollbar-thumb { background: #C9B89E; border-radius: 2px; }

.organic-shape { position: absolute; pointer-events: none; z-index: 0; }

@keyframes fadeUp { from { opacity: 0; transform: translateY(24px); } to { opacity: 1; transform: translateY(0); } }
@keyframes fadeIn { from { opacity: 0; } to { opacity: 1; } }
.reveal { opacity: 0; }
.reveal.in { animation: fadeUp 1s ease-out both; }

.card-hover { transition: transform 0.5s cubic-bezier(.2,.8,.2,1), box-shadow 0.5s ease; }
.card-hover:hover { transform: translateY(-6px); box-shadow: 0 24px 48px rgba(74, 53, 39, 0.1); }

html { scroll-behavior: smooth; }

.nav-floating { backdrop-filter: blur(16px) saturate(180%); -webkit-backdrop-filter: blur(16px) saturate(180%); }

/* Glassmorphism — frosted glass effect */
.glass {
  background: rgba(255, 255, 255, 0.55);
  backdrop-filter: blur(20px) saturate(180%);
  -webkit-backdrop-filter: blur(20px) saturate(180%);
  border: 1px solid rgba(255, 255, 255, 0.6);
  box-shadow: 0 8px 32px rgba(74, 53, 39, 0.08), inset 0 1px 0 rgba(255, 255, 255, 0.4);
}
.glass-soft {
  background: rgba(255, 255, 255, 0.7);
  backdrop-filter: blur(14px) saturate(150%);
  -webkit-backdrop-filter: blur(14px) saturate(150%);
  border: 1px solid rgba(255, 255, 255, 0.5);
  box-shadow: 0 4px 24px rgba(74, 53, 39, 0.06);
}
.glass-dark {
  background: rgba(74, 53, 39, 0.45);
  backdrop-filter: blur(20px) saturate(180%);
  -webkit-backdrop-filter: blur(20px) saturate(180%);
  border: 1px solid rgba(255, 255, 255, 0.12);
  box-shadow: 0 8px 32px rgba(0, 0, 0, 0.18);
}
.glass-tinted {
  background: rgba(220, 229, 211, 0.55);
  backdrop-filter: blur(18px) saturate(160%);
  -webkit-backdrop-filter: blur(18px) saturate(160%);
  border: 1px solid rgba(255, 255, 255, 0.5);
  box-shadow: 0 6px 28px rgba(74, 53, 39, 0.07);
}

.thin-divider {
  width: 60px;
  height: 1px;
  background: #C9B89E;
  margin: 0 auto;
}

@media (prefers-reduced-motion: reduce) {
  .reveal.in { animation: fadeIn 0.4s ease-out both; }
  .card-hover:hover, .polaroid:hover { transform: none; }
  html { scroll-behavior: auto; }
}

@media (max-width: 768px) {
  .sticky-cta-mobile { position: fixed; bottom: 1rem; left: 1rem; right: 1rem; z-index: 40; }
}
