/* =====================================================
   LA PÉPITE — styles.css (palette & system)
===================================================== */

/* -----------------------
   Design tokens
----------------------- */
:root{
  /* Palette */
  --black:#000000; --bordeaux:#7C1229; --green:#21645C; --rose:#F5EDEC;

  /* Theme */
  --bg: var(--black);
  --bg-elev:#0a0a0a;
  --text: var(--rose);
  --muted: color-mix(in srgb, var(--rose) 70%, #888 30%);

  /* Brand */
  --primary: var(--bordeaux);
  --primary-2: color-mix(in srgb, var(--bordeaux) 78%, #000 22%);
  --accent: var(--green);

  /* UI */
  --radius: 18px;
  --shadow: 0 10px 30px rgba(0,0,0,.45);
  --max: 1160px;

  /* Type scale */
  --fs-h1: clamp(2.4rem, 6vw, 6rem);
  --fs-h2: clamp(1.6rem, 3vw, 2.4rem);
  --fs-base: clamp(1rem, 1.4vw, 1.125rem);

  /* Fonts */
  --font-display:"Rogie","Times New Roman",ui-serif,Georgia,serif;
  --font-sans: "PoppinsLocal", ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  --font-desc: var(--font-sans);
}

/* Fonts (local) */
@font-face{
  font-family:"Rogie";
  src:url("assets/rogie.woff2") format("woff2"), url("assets/rogie.ttf") format("truetype");
  font-weight:400; font-style:normal; font-display:swap;
}
@font-face{
  font-family:"PoppinsLocal";
  src:url("assets/Poppins-Regular.woff2") format("woff2"), url("assets/Poppins-Regular.ttf") format("truetype");
  font-weight:400; font-style:normal; font-display:swap;
}

/* -----------------------
   Base
----------------------- */
*{ box-sizing:border-box; }
html,body{ height:100%; }
html{ scroll-behavior:smooth; }
body{
  margin:0;
  font-family: var(--font-sans);
  font-weight:400;
  line-height:1.6;
  overflow-x:hidden;
  background:
    radial-gradient(1200px 800px at 80% -10%, color-mix(in srgb, var(--bordeaux) 8%, #111 92%) 10%, var(--bg) 60%),
    radial-gradient(900px 600px at 0% 10%, color-mix(in srgb, var(--bordeaux) 12%, transparent) 0%, transparent 60%),
    var(--bg);
  color:var(--text);
}
h1,h2,h3,.headline-01,.headline-02,.headline-03{
  font-family:var(--font-display);
  font-weight:400; line-height:1.1;
}
h1{ font-size:clamp(2.4rem, 3.6vw + 1rem, 4rem); }
h2{ font-size:clamp(1.8rem, 2.4vw + .6rem, 2.6rem); }
h3{ font-size:clamp(1.4rem, 1.4vw + .5rem, 1.8rem); }
p, li, small, .description, .desc, .caption, .lead, .hero .subtitle{ font-family:var(--font-desc); }

/* -----------------------
   Utilities / layout
----------------------- */
.container{ width:min(100% - 2rem, var(--max)); margin-inline:auto; }
.section{ padding:clamp(3rem, 6vw, 6rem) 0; }
.section__header{ text-align:center; margin-bottom:2rem; }
.center{text-align:center;}
.mt-l{margin-top:2rem;}
.stack > * + *{ margin-top:1rem; }
.grid-2{ display:grid; gap:clamp(1rem, 3vw, 2rem); grid-template-columns:1.1fr 1fr; }
@media (max-width:900px){ .grid-2{ grid-template-columns:1fr; } }
.muted{ color:var(--muted); }

/* -----------------------
   Buttons & chips
----------------------- */
.btn{
  display:inline-flex; align-items:center; justify-content:center;
  padding:.9rem 1.2rem; border-radius:var(--radius);
  border:1px solid color-mix(in srgb, var(--rose) 14%, #fff0 86%);
  color:var(--text); background:transparent;
  transition:transform .2s ease, background .2s ease, border-color .2s ease, filter .2s ease;
  text-decoration:none; font-weight:600;
}
.btn:hover{ transform:translateY(-1px); background:color-mix(in srgb, var(--rose) 7%, transparent); }
.btn--primary{ background:linear-gradient(135deg, var(--primary), var(--primary-2)); border-color:transparent; }
.btn--primary:hover{ filter:brightness(1.06); }
.btn--ghost{ background:#0000; }
.btn--ghost:hover{ background:color-mix(in srgb, var(--green) 10%, transparent); }

.chip{
  background:#ffffff10; border:1px solid #ffffff20;
  padding:.5rem .8rem; border-radius:999px; color:#fff; cursor:pointer;
}
.chip.is-active, .chip:hover{ background:var(--primary); border-color:transparent; }

/* -----------------------
   Header / Nav
----------------------- */
.site-header{
  position:sticky; top:0; z-index:50;
  display:flex; align-items:center; justify-content:space-between;
  padding:.75rem 1rem; backdrop-filter:blur(6px);
  background:color-mix(in srgb, var(--bg) 70%, transparent);
  border-bottom:1px solid #ffffff0f;
}
.brand{ display:flex; align-items:center; gap:.7rem; color:var(--text); text-decoration:none; font-weight:800; letter-spacing:.5px; }
.brand img{ width:36px; height:36px; object-fit:contain; border-radius:8px; }

.nav__toggle{ display:none; }
.nav__list{ display:flex; gap:1rem; align-items:center; list-style:none; margin:0; padding:0; }
.nav__list a{ color:var(--text); text-decoration:none; opacity:.9; }
.nav__cta .btn{ padding:.6rem .9rem; }

@media (max-width:900px){
  .nav__toggle{ display:inline-flex; flex-direction:column; gap:5px; background:none; border:0; }
  .nav__toggle span{ width:26px; height:2px; background:#fff; display:block; transition:.2s; }
  .nav__list{
    position:fixed; inset:60px 0 auto 0; background:var(--bg);
    transform:translateY(-110%); transition:transform .3s ease;
    padding:1rem; flex-direction:column; gap:1rem; border-bottom:1px solid #ffffff14;
  }
  .nav__list.is-open{ transform:translateY(0); }
}

/* -----------------------
   Hero
----------------------- */
.hero{ position:relative; min-height:88svh; display:grid; place-items:center; overflow:clip; }
.hero__video{
  position:absolute; inset:0; width:100%; height:100%; object-fit:cover;
  filter:saturate(1.05) contrast(1.05) brightness(.8); transform:scale(1.02);
}
.hero__scrim{
  position:absolute; inset:0;
  background: radial-gradient(80% 70% at 50% 30%, transparent 20%, color-mix(in srgb, var(--bordeaux) 25%, #000 75%) 65%, #000b 100%);
}
.hero__content{ position:relative; text-align:center; padding:2rem; }
.hero h1{ font-size:var(--fs-h1); line-height:.95; letter-spacing:2px; text-shadow:0 10px 40px #000; }
.hero__subtitle{ font-size: clamp(1rem, 1.6vw, 1.4rem); color:#eee; opacity:.9; }
.hero__ctas{ display:inline-flex; gap:.8rem; flex-wrap:wrap; margin-top:1rem; }
.hero__badges{ margin-top:1rem; font-size:.95rem; display:flex; gap:.8rem; flex-wrap:wrap; justify-content:center; color:var(--muted); }
.scroll-down{ position:absolute; bottom:16px; left:50%; translate:-50% 0; background:none; border:0; color:#fff; opacity:.7; cursor:pointer; }

/* -----------------------
   Marquee
----------------------- */
.marquee{ border-block:1px solid #ffffff12; background:#ffffff07; overflow:clip; }
.marquee__track{ display:flex; gap:3rem; padding:.6rem 0; white-space:nowrap; animation:scroll 22s linear infinite; }
.marquee__track span{ opacity:.8; }
@keyframes scroll{ from{ transform:translateX(10%);} to{ transform:translateX(-80%);} }

/* -----------------------
   About
----------------------- */
.about-media{ display:grid; place-items:center; }
.stack-img{
  display:grid; grid-template-columns:repeat(2,1fr); gap:.8rem;
  max-width:620px; width:100%; margin-inline:auto;
}
.stack-img img{
  width:100%; height:auto; aspect-ratio:4/5; object-fit:cover;
  border-radius:var(--radius); box-shadow:var(--shadow);
}
@media (min-width:900px){
  .stack-img{ grid-template-columns:1.2fr 1fr; grid-auto-rows:1fr; }
  .stack-img img:nth-child(1){ grid-row:1 / span 2; aspect-ratio:3/4; }
}
@media (max-width:899.98px){
  .stack-img img:nth-child(1){ grid-column:1 / -1; }
}

/* -----------------------
   Gallery — grille uniforme + filters
----------------------- */
.filters{ display:flex; gap:.5rem; justify-content:center; margin-bottom:1rem; flex-wrap:wrap; }

.masonry{
  display:grid; grid-template-columns:repeat(auto-fill, minmax(240px,1fr)); gap:1rem;
}
@media (min-width:900px){ .masonry{ grid-template-columns:repeat(auto-fill, minmax(260px,1fr)); } }

.masonry__item{
  position:relative; display:block; aspect-ratio:1/1;
  border-radius:var(--radius); overflow:hidden; border:1px solid #ffffff14; background:#111; box-shadow:var(--shadow);
}
.masonry__item img{
  position:absolute; inset:0; width:100%; height:100%; object-fit:cover;
  transition:transform .3s ease, filter .3s ease; display:block; filter:saturate(1.02) contrast(1.02);
}
.masonry__item:hover img{ transform:scale(1.03); }
.masonry__item:focus-visible{ outline:2px solid color-mix(in srgb, var(--rose) 60%, #fff); outline-offset:2px; }

/* -----------------------
   Hours + Map
----------------------- */
.hours{ list-style:none; padding:0; margin:0; }
.hours li{ display:flex; justify-content:space-between; border-bottom:1px dashed #ffffff18; padding:.5rem 0; }
.map iframe{ width:100%; min-height:340px; border:0; border-radius:var(--radius); }

/* -----------------------
   Contact / Social
----------------------- */
#contact .contact-grid{
  display:flex; gap:1rem; justify-content:center; align-items:stretch; flex-wrap:wrap;
  margin-inline:auto; max-width:820px;
}
#contact .contact-grid > .social-card{ flex:1 1 320px; max-width:380px; }
.social-card{
  display:flex; align-items:center; gap:.8rem; padding:1rem 1.2rem;
  background:var(--bg-elev); border:1px solid #ffffff12; border-radius:var(--radius);
  text-decoration:none; color:var(--text); width:100%;
}
.social-card img{ width:28px; height:28px; }

/* -----------------------
   Footer
----------------------- */
.site-footer{ text-align:center; padding:3rem 1rem; color:var(--muted); border-top:1px solid #ffffff14; }

/* -----------------------
   Lightbox
----------------------- */
.lightbox{ position:fixed; inset:0; background:#000c; display:none; place-items:center; z-index:120; }
.lightbox.is-open{ display:grid; }
.lightbox__img{ max-width:92vw; max-height:82vh; border-radius:12px; box-shadow:var(--shadow); }
.lightbox__close, .lightbox__ctrl{
  position:absolute; background:#ffffff14; border:1px solid #ffffff22; color:#fff;
  width:44px; height:44px; border-radius:50%; display:grid; place-items:center; cursor:pointer;
}
.lightbox__close{ top:12px; right:12px; font-size:28px; }
.lightbox__ctrl.prev{ left:12px; } .lightbox__ctrl.next{ right:12px; }

/* -----------------------
   Reveal on scroll
----------------------- */
.reveal{ opacity:0; transform:translateY(16px); transition:.6s ease; }
.reveal.is-visible{ opacity:1; transform:translateY(0); }

/* -----------------------
   Preloader
----------------------- */
.preloader{ position:fixed; inset:0; background:#0b0a0c; display:grid; place-items:center; z-index:200; }
.preloader.hidden{ opacity:0; pointer-events:none; transition:opacity .5s ease .2s; }
.loader-ring{
  width:70px; height:70px; border-radius:50%;
  border:3px solid #ffffff18; border-top-color:var(--primary);
  animation:spin 1s linear infinite; position:absolute;
}
.loader-logo{ width:68px; border-radius:14px; filter:drop-shadow(0 6px 18px rgba(0,0,0,.5)); }
@keyframes spin{ to{ transform:rotate(360deg); } }

/* -----------------------
   Reduced motion
----------------------- */
@media (prefers-reduced-motion: reduce){
  *{ animation-duration:.001s !important; transition-duration:.001s !important; scroll-behavior:auto !important; }
  .marquee__track{ animation:none; }
}
/* ================
   La Pépite — Responsive Hotfix
   Empile les grilles, rend le menu utilisable, images 100%, hero mobile-safe.
=================== */

/* 0) Base fluidité */
img, video, canvas, svg { max-width: 100%; height: auto; }
iframe { width: 100%; border: 0; }
*, *::before, *::after { box-sizing: border-box; }

/* 1) Hero mobile-safe : utilise dvh quand dispo, sinon fallback */
.hero { min-height: 88vh; }
@supports (min-height: 100dvh) {
  .hero { min-height: 88dvh; }
}
.hero__content { padding: 2rem 1rem; }

/* 2) Container & spacing */
.container { width: min(100% - 1.25rem, 1160px); margin-inline: auto; }
.section { padding: clamp(2rem, 6vw, 6rem) 0; }
.hero__ctas { gap: .6rem; flex-wrap: wrap; }
.hero__badges { padding: 0 .5rem; }

/* 3) Typos qui respirent sur petit écran */
h1 { font-size: clamp(2rem, 7vw, 3.6rem); }
h2 { font-size: clamp(1.4rem, 5vw, 2.2rem); }
.hero__subtitle { font-size: clamp(1rem, 3.8vw, 1.25rem); }

/* 4) Header / Nav : burger < 960px */
.nav__list { display: flex; gap: 1rem; align-items: center; list-style: none; margin: 0; padding: 0; }
.nav__toggle { display: none; }

@media (max-width: 960px) {
  .nav__toggle{ 
    display: inline-flex; flex-direction: column; gap: 5px; background: none; border: 0; 
  }
  .nav__toggle span{ width: 26px; height: 2px; background: #fff; display: block; }
  .nav__list{
    position: fixed; left: 0; right: 0; top: 60px;
    background: #0a0a0a; border-bottom: 1px solid #ffffff14;
    transform: translateY(-120%); transition: transform .3s ease;
    padding: 1rem; flex-direction: column; gap: .8rem;
  }
  .nav__list.is-open { transform: translateY(0); }
  .nav__cta .btn { width: 100%; }
}

/* 5) Grilles -> empilage */
.grid-2 { display: grid; gap: clamp(1rem, 3vw, 2rem); grid-template-columns: 1.1fr 1fr; }
@media (max-width: 960px) { .grid-2 { grid-template-columns: 1fr; } }

/* 6) About photos : garde une belle mosaïque */
.stack-img { display: grid; grid-template-columns: repeat(2, 1fr); gap: .8rem; width: 100%; }
@media (max-width: 960px) {
  .stack-img { grid-template-columns: 1fr 1fr; }
  .stack-img img:nth-child(1) { grid-column: 1 / -1; }
}

/* 7) Galerie : colonnes fluides */
.masonry { display: grid; gap: 1rem; grid-template-columns: repeat(auto-fill, minmax(240px, 1fr)); }
@media (max-width: 640px) {
  .masonry { grid-template-columns: repeat(2, 1fr); }
  .masonry__item { aspect-ratio: 1 / 1; }
}

/* 8) Horaires & carte */
.hours li { gap: 1rem; }
.map iframe { min-height: 320px; border-radius: 18px; }

/* 9) Cartes sociales : pleine largeur quand étroit */
#contact .contact-grid { gap: 1rem; }
#contact .contact-grid > .social-card { flex: 1 1 320px; max-width: 420px; }

/* 10) Marquee : coupe proprement si très petit */
@media (max-width: 480px) { .marquee__track { gap: 1.5rem; } }

/* 11) Accessibilité mobile : focus visible */
:focus-visible { outline: 2px solid #fff; outline-offset: 2px; }
/* ===== HERO CONTRAST BOOSTER ===== */

/* 1) Scrim plus dense + léger dégradé bas */
.hero__scrim{
  background:
    radial-gradient(80% 70% at 50% 30%,
      #0000 18%,
      color-mix(in srgb, var(--bordeaux) 28%, #000 72%) 58%,
      rgba(0,0,0,.68) 100%),
    linear-gradient(to bottom, rgba(0,0,0,.00) 0%, rgba(0,0,0,.35) 55%, rgba(0,0,0,.65) 100%);
}

/* 2) Titre: blanc pur + outline discret + ombre multi-couches */
.hero h1{
  color:#fff;
  -webkit-text-stroke: .6px rgba(0,0,0,.35);
  text-shadow:
    0 2px 0 rgba(0,0,0,.18),
    0 14px 32px rgba(0,0,0,.55),
    0 0 1px rgba(0,0,0,.4);
}

/* 3) Sous-titre: pastille lisible (blur + fond) */
.hero__subtitle{
  color:#fff;
  display:inline-block;
  padding:.35rem .75rem;
  border-radius:12px;
  background: color-mix(in srgb, #000 38%, transparent);
  backdrop-filter: blur(6px);
  box-shadow: 0 6px 24px rgba(0,0,0,.35);
}

/* 4) Badges: plus clairs et sur pastilles */
.hero__badges{
  gap:.6rem; 
}
.hero__badges span{
  color:#fff;
  background: color-mix(in srgb, #000 28%, transparent);
  backdrop-filter: blur(4px);
  padding:.25rem .6rem;
  border-radius: 10px;
}

/* 5) Réduction légère de la saturation vidéo (évite les rouges trop vifs sous le texte) */
.hero__video{
  filter: saturate(.95) contrast(1.05) brightness(.78);
}

/* 6) Petits écrans: taille & respiration du titre */
@media (max-width: 520px){
  .hero h1{ font-size: clamp(2rem, 10vw, 3.2rem); letter-spacing: 1.2px; }
  .hero__subtitle{ padding:.4rem .6rem; border-radius:10px; }
}
