/* =====================================================
   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); }


/* -----------------------
   Header / Nav
----------------------- */
.site-header{
  position:sticky; top:0; z-index:50;
  display:flex; align-items:center; justify-content:center;
  padding: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; font-size:1.1rem; }
.brand img{ width:40px; height:40px; object-fit:contain; border-radius:8px; }


/* -----------------------
   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);
  z-index: 1;
}
.hero__fallback{
  position:absolute; inset:0; width:100%; height:100%; object-fit:cover;
  filter:saturate(1.05) contrast(1.05) brightness(.8); transform:scale(1.02);
  z-index: 1;
  display: none;
}
/* Fallback pour navigateurs qui ne supportent pas la vidéo */
.no-video .hero__video{ display: none; }
.no-video .hero__fallback{ display: block; }
.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; z-index: 2; }
.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; 
  margin: 1rem 0;
  display: block;
}
.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); }


/* -----------------------
   About
----------------------- */
#about .center{
  max-width: 800px;
  margin: 0 auto;
}
#about .stack{
  text-align: center;
}
#about h3{
  font-size: clamp(1.4rem, 2.5vw, 1.8rem);
  margin-bottom: 1rem;
}
#about p{
  font-size: clamp(1rem, 1.5vw, 1.125rem);
  line-height: 1.7;
  margin-bottom: 2rem;
}

/* -----------------------
   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; justify-content: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%; transition:transform .2s ease, background .2s ease;
}
.social-card:hover{ transform:translateY(-2px); background:color-mix(in srgb, var(--primary) 8%, var(--bg-elev)); }
.social-card img{ width:32px; height:32px; }

/* -----------------------
   Google Rating
----------------------- */
.google-rating{
  background: #1a1a1a;
  padding: 4rem 0;
  margin-top: 2rem;
}
.rating-card{
  background: #2a2a2a;
  border: 2px solid #444;
  border-radius: 20px;
  padding: 3rem 2rem;
  text-align: center;
  max-width: 600px;
  margin: 0 auto;
  box-shadow: 0 10px 30px rgba(0,0,0,0.5);
}
.rating-header{
  margin-bottom: 2rem;
}
.google-logo{
  width: 100px;
  height: auto;
  margin-bottom: 1rem;
}
.rating-header h3{
  color: #fff;
  margin: 0;
  font-size: 1.4rem;
  font-weight: 600;
}
.rating-stars{
  margin-bottom: 1.5rem;
}
.stars{
  font-size: 3rem;
  color: #ffd700;
  display: block;
  margin-bottom: 0.5rem;
}
.rating-score{
  font-size: 2rem;
  font-weight: bold;
  color: #fff;
  margin-left: 1rem;
}
.rating-text{
  color: #ccc;
  margin-bottom: 2rem;
  font-size: 1.2rem;
}
.rating-link{
  display: inline-block;
  padding: 1rem 2rem;
  background: #7C1229;
  border: none;
  border-radius: 25px;
  color: #fff;
  text-decoration: none;
  font-weight: 600;
  font-size: 1.1rem;
  transition: background 0.3s ease;
}
.rating-link:hover{
  background: #8a1a35;
  color: #fff;
  text-decoration: none;
}

/* -----------------------
   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; }
}
/* ================
   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 : centré et épuré */
@media (max-width: 900px) {
  .site-header{ padding: .8rem 1rem; }
  .brand{ font-size: 1rem; }
  .brand img{ width: 36px; height: 36px; }
}

/* 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; }


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

/* 12) Google Rating responsive */
@media (max-width: 640px) {
  .rating-card{ 
    padding: 2rem 1.5rem; 
    margin: 0 1rem;
  }
  .google-logo{ width: 80px; }
  .rating-header h3{ font-size: 1.2rem; }
  .stars{ font-size: 2.5rem; }
  .rating-score{ font-size: 1.5rem; }
  .rating-text{ font-size: 1rem; }
  .rating-link{ 
    padding: 0.8rem 1.5rem; 
    font-size: 1rem; 
  }
}
/* ===== 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 !important;
  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);
  margin: 1rem 0 !important;
  font-size: clamp(1rem, 1.6vw, 1.4rem) !important;
}

/* 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; }
}
