/* Parfumerie Mira — LymaWeb prototype
   Palette: noir #111111 · or #D4AF37 · crème #F6F1E7 · encre douce #2A2622 */

:root {
  --noir: #111111;
  --noir-soft: #1c1a17;
  --or: #D4AF37;
  --or-soft: #e6cd7a;
  --creme: #F6F1E7;
  --encre: #2A2622;
  --muted: #8a8378;
  --radius: 14px;
  --shadow: 0 12px 36px rgba(17, 17, 17, .14);
  --font-serif: "Cormorant Garamond", Georgia, serif;
  --font-sans: "Jost", "Helvetica Neue", Arial, sans-serif;
}

* { margin: 0; padding: 0; box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  font-family: var(--font-sans);
  font-weight: 300;
  color: var(--encre);
  background: var(--creme);
  line-height: 1.65;
  font-size: 16.5px;
}
img { max-width: 100%; height: auto; display: block; }
a { color: inherit; }

.container { width: min(1120px, 92%); margin-inline: auto; }

h1, h2, h3 { font-family: var(--font-serif); font-weight: 500; line-height: 1.15; color: var(--noir); }
h1 { font-size: clamp(2.3rem, 6vw, 3.8rem); }
h2 { font-size: clamp(1.8rem, 4.5vw, 2.6rem); }
h3 { font-size: 1.35rem; }
.center { text-align: center; }
.muted { color: var(--muted); }
.small { font-size: .85rem; }

.eyebrow {
  font-family: var(--font-sans);
  text-transform: uppercase;
  letter-spacing: .28em;
  font-size: .78rem;
  color: var(--or);
  margin-bottom: 14px;
  font-weight: 500;
}

/* ---------- Header ---------- */
.site-header {
  position: sticky; top: 0; z-index: 50;
  background: rgba(17, 17, 17, .96);
  backdrop-filter: blur(8px);
  border-bottom: 1px solid rgba(212, 175, 55, .25);
}
.nav { display: flex; align-items: center; justify-content: space-between; padding-block: 14px; }
.brand { text-decoration: none; font-family: var(--font-serif); letter-spacing: .18em; font-size: 1.05rem; }
.brand-main { color: var(--creme); }
.brand-accent { color: var(--or); }
.nav-links { display: flex; gap: 28px; list-style: none; align-items: center; }
.nav-links a {
  text-decoration: none; color: var(--creme);
  font-size: .92rem; letter-spacing: .06em; text-transform: uppercase;
  transition: color .25s;
}
.nav-links a:hover { color: var(--or); }
.nav-cta {
  border: 1px solid var(--or); padding: 8px 18px; border-radius: 999px;
  color: var(--or) !important;
}
.nav-cta:hover { background: var(--or); color: var(--noir) !important; }
.nav-toggle { display: none; background: none; border: 0; cursor: pointer; }
.nav-toggle span { display: block; width: 24px; height: 2px; background: var(--creme); margin: 5px 0; transition: .3s; }

/* ---------- Hero ---------- */
.hero {
  background: radial-gradient(1100px 540px at 75% -10%, #3a342a 0%, var(--noir) 58%);
  color: var(--creme);
  padding-block: clamp(64px, 11vw, 130px);
}
.hero-inner { display: grid; grid-template-columns: 1.15fr .85fr; gap: 48px; align-items: center; }
.hero h1 { color: var(--creme); margin-bottom: 20px; }
.hero h1 em { color: var(--or); font-style: italic; }
.lead { font-size: 1.12rem; color: #d9d2c4; max-width: 46ch; }
.hero-actions { display: flex; flex-wrap: wrap; gap: 14px; margin-top: 30px; }
.hero-badges { list-style: none; display: flex; flex-wrap: wrap; gap: 10px 22px; margin-top: 30px; }
.hero-badges li {
  font-size: .82rem; letter-spacing: .14em; text-transform: uppercase; color: var(--or-soft);
}
.hero-badges li::before { content: "◆ "; font-size: .6rem; vertical-align: 2px; }
.hero-visual img { filter: drop-shadow(0 24px 40px rgba(0,0,0,.45)); }

/* ---------- Buttons ---------- */
.btn {
  display: inline-flex; align-items: center; gap: 10px;
  padding: 14px 26px; border-radius: 999px;
  text-decoration: none; font-weight: 500; font-size: .98rem;
  transition: transform .2s, box-shadow .2s, background .25s, color .25s;
}
.btn:hover { transform: translateY(-2px); box-shadow: var(--shadow); }
.btn-whatsapp { background: #25D366; color: #fff; }
.btn-whatsapp:hover { background: #1ebe5b; }
.btn-ghost { border: 1px solid currentColor; color: inherit; }
.hero .btn-ghost { color: var(--or-soft); }
.contact .btn-ghost, .delivery .btn-ghost { color: var(--encre); }

/* ---------- Réassurance ---------- */
.reassurance { padding-block: clamp(56px, 8vw, 90px); }
.re-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 28px; }
.re-item {
  background: #fff; border-radius: var(--radius); padding: 34px 28px;
  border-top: 3px solid var(--or);
  box-shadow: 0 6px 22px rgba(17,17,17,.06);
  transition: transform .25s, box-shadow .25s;
}
.re-item:hover { transform: translateY(-4px); box-shadow: var(--shadow); }
.re-item h3 { margin-bottom: 10px; }

/* ---------- Catalogue ---------- */
.catalogue { padding-block: clamp(56px, 8vw, 96px); background: #fff; }
.catalogue h2 { margin-bottom: 42px; }
.cat-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 28px; }
.cat-card {
  position: relative; display: block; border-radius: var(--radius); overflow: hidden;
  text-decoration: none; background: var(--noir);
  box-shadow: 0 8px 26px rgba(17,17,17,.10);
  transition: transform .25s, box-shadow .25s;
}
.cat-card:hover { transform: translateY(-5px); box-shadow: var(--shadow); }
.cat-card img { width: 100%; aspect-ratio: 4/3; object-fit: cover; opacity: .92; transition: opacity .3s, scale .4s; }
.cat-card:hover img { opacity: 1; scale: 1.03; }
.cat-label {
  position: absolute; inset-inline: 0; bottom: 0;
  padding: 40px 22px 18px;
  background: linear-gradient(to top, rgba(17,17,17,.92), transparent);
}
.cat-label h3 { color: var(--creme); }
.cat-label p { color: #cfc7b8; font-size: .9rem; }
.cat-note { margin-top: 30px; text-align: center; color: var(--muted); font-size: .92rem; }
.cat-note a { color: var(--or); }

/* ---------- Livraison ---------- */
.delivery { padding-block: clamp(56px, 8vw, 96px); }
.delivery-inner { display: grid; grid-template-columns: .9fr 1.1fr; gap: 48px; align-items: center; }
.delivery-visual img { border-radius: var(--radius); box-shadow: var(--shadow); width: 100%; }
.check-list { list-style: none; margin: 18px 0 28px; }
.check-list li { padding-inline-start: 30px; position: relative; margin-bottom: 10px; }
.check-list li::before {
  content: "✓"; position: absolute; inset-inline-start: 0;
  color: var(--or); font-weight: 600;
}

/* ---------- À propos / boutique ---------- */
.about { padding-block: clamp(56px, 8vw, 96px); background: var(--noir); color: #d9d2c4; }
.about h2 { color: var(--creme); margin-bottom: 18px; }
.about p { margin-bottom: 14px; }
.about-inner { display: grid; grid-template-columns: 1.1fr .9fr; gap: 48px; align-items: center; }
.about-visual img { border-radius: var(--radius); box-shadow: 0 18px 48px rgba(0,0,0,.5); width: 100%; }

/* ---------- Preuve sociale ---------- */
.social-proof { padding-block: clamp(48px, 7vw, 80px); background: var(--or); }
.proof-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 24px; text-align: center; }
.proof-num { display: block; font-family: var(--font-serif); font-size: clamp(2rem, 4.5vw, 3rem); color: var(--noir); font-weight: 600; }
.proof-label { font-size: .88rem; letter-spacing: .04em; color: #4a3d14; }

/* ---------- Contact ---------- */
.contact { padding-block: clamp(56px, 8vw, 96px); background: #fff; }
.contact-inner { display: grid; grid-template-columns: 1fr 1fr; gap: 48px; align-items: stretch; }
.contact h2 { margin-bottom: 14px; }
.contact-actions { display: flex; flex-wrap: wrap; gap: 14px; margin-top: 26px; }
.socials { list-style: none; display: flex; gap: 22px; margin-top: 26px; }
.socials a { color: var(--or); font-weight: 500; text-decoration: none; border-bottom: 1px solid transparent; transition: border-color .2s; }
.socials a:hover { border-color: var(--or); }
.contact-map { border-radius: var(--radius); overflow: hidden; box-shadow: var(--shadow); min-height: 320px; }
.contact-map iframe { width: 100%; height: 100%; min-height: 320px; border: 0; }

/* ---------- Footer ---------- */
.site-footer { background: var(--noir-soft); color: #b7afa0; padding-block: 48px; text-align: center; font-size: .95rem; }
.footer-brand { display: inline-block; margin-bottom: 16px; font-size: 1.2rem; text-decoration: none; }
.site-footer p { margin-bottom: 8px; }
.site-footer a { color: var(--or-soft); }
.footer-credit { margin-top: 18px; font-size: .8rem; color: #7a7264; }

/* ---------- WhatsApp flottant ---------- */
.wa-float {
  position: fixed; inset-inline-end: 20px; bottom: 20px; z-index: 60;
  width: 58px; height: 58px; border-radius: 50%;
  background: #25D366; color: #fff;
  display: flex; align-items: center; justify-content: center;
  box-shadow: 0 10px 28px rgba(37, 211, 102, .45);
  transition: transform .2s;
}
.wa-float:hover { transform: scale(1.08); }

/* ---------- Reveal animation ---------- */
.reveal { opacity: 0; transform: translateY(22px); transition: opacity .7s ease, transform .7s ease; }
.reveal.visible { opacity: 1; transform: none; }
@media (prefers-reduced-motion: reduce) {
  .reveal { opacity: 1; transform: none; transition: none; }
  html { scroll-behavior: auto; }
}

/* ---------- Responsive ---------- */
@media (max-width: 920px) {
  .hero-inner, .delivery-inner, .about-inner, .contact-inner { grid-template-columns: 1fr; gap: 36px; }
  .hero-visual { order: -1; max-width: 420px; margin-inline: auto; }
  .re-grid, .cat-grid { grid-template-columns: 1fr; }
  .proof-grid { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 760px) {
  .nav-toggle { display: block; }
  .nav-links {
    position: absolute; top: 100%; inset-inline: 0;
    flex-direction: column; gap: 0;
    background: var(--noir);
    border-bottom: 1px solid rgba(212,175,55,.25);
    max-height: 0; overflow: hidden; transition: max-height .35s ease;
  }
  .nav-links.open { max-height: 360px; }
  .nav-links li { width: 100%; text-align: center; }
  .nav-links a { display: block; padding: 15px 0; }
  .nav-cta { border: 0; border-top: 1px solid rgba(212,175,55,.25); border-radius: 0; }
}
