/* =========================================================
   AU P'TIT PARADIS — styles
   Palette dérivée du logo : noir encre, or caramel, crème.
   Touche "bord de mer" très sobre en accent (section horaires).
   ========================================================= */

:root{
  --ink:        #211c17;
  --ink-soft:   #4a423a;
  --cream:      #fbf6ee;
  --sand:       #f1e6d3;
  --gold:       #c8853a;
  --gold-deep:  #8c5a26;
  --gold-pale:  #e7c79a;
  --sea:        #5c7a78;
  --sea-pale:   #e7eeec;
  --white:      #ffffff;

  --font-display: "Atma", sans-serif;
  --font-script:  "Atma", sans-serif;
  --font-body:    "Jost", sans-serif;

  --max-w: 1140px;
  --radius: 4px;
  --ease: cubic-bezier(.4,0,.2,1);
}

/* ---------- Reset ---------- */
*,*::before,*::after{ box-sizing:border-box; }
html{ scroll-behavior:smooth; }
body{
  margin:0;
  background:var(--cream);
  color:var(--ink);
  font-family:var(--font-body);
  font-size:16px;
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
}
img{ max-width:100%; display:block; }
a{ color:inherit; text-decoration:none; }
ul{ margin:0; padding:0; list-style:none; }
h1,h2,h3{ font-family:var(--font-display); font-weight:600; margin:0 0 .4em; color:var(--ink); }
p{ margin:0 0 1em; color:var(--ink-soft); }

[data-dynamic]{ opacity:0; transition:opacity .3s ease; }
[data-dynamic].is-loaded{ opacity:1; }

.skip-link{
  position:absolute; left:-999px; top:0;
  background:var(--gold); color:var(--white); padding:.6em 1em; z-index:200;
}
.skip-link:focus{ left:0; }

:focus-visible{ outline:3px solid var(--sea); outline-offset:3px; }

@media (prefers-reduced-motion: reduce){
  html{ scroll-behavior:auto; }
  *{ animation-duration:.001ms !important; animation-iteration-count:1 !important; transition-duration:.001ms !important; }
}

/* ---------- Layout helpers ---------- */
.section-inner{ max-width:var(--max-w); margin:0 auto; padding:5rem 1.5rem; }
.eyebrow{
  font-family:var(--font-body); text-transform:uppercase; letter-spacing:.18em;
  font-size:.78rem; font-weight:600; color:var(--gold-deep); margin-bottom:.8em;
}
.eyebrow-script{
  font-family:var(--font-script); font-size:2.8rem; font-weight:300; color:var(--gold); margin:0 0 .1rem 0; line-height:1; letter-spacing:.12em;
}
.btn{
  display:inline-block; padding:.85em 1.8em; border-radius:var(--radius);
  font-family:var(--font-body); font-weight:600; font-size:.95rem; letter-spacing:.02em;
  border:1.5px solid transparent; transition:transform .25s var(--ease), background .25s var(--ease), color .25s var(--ease), border-color .25s var(--ease);
}
.btn-primary{ background:var(--gold); color:var(--white); }
.btn-primary:hover{ background:var(--gold-deep); transform:translateY(-2px); }
.btn-ghost{ background:none; border-color:var(--ink); color:var(--ink); }
.btn-ghost:hover{ background:var(--ink); color:var(--cream); transform:translateY(-2px); }

/* ---------- Header ---------- */
.site-header{
  position:fixed; top:0; left:0; right:0; z-index:100;
  background:rgba(251,246,238,0); transition:background .35s var(--ease), box-shadow .35s var(--ease);
}
.site-header.is-scrolled{
  background:rgba(251,246,238,.92); backdrop-filter:blur(6px);
  box-shadow:0 1px 0 rgba(33,28,23,.08);
}
.header-inner{
  max-width:var(--max-w); margin:0 auto; padding:.75rem 1.5rem;
  display:flex; align-items:center; justify-content:space-between;
}
.brand{ display:flex; align-items:center; text-decoration:none; }
.brand-logo-header{ height:52px; width:auto; object-fit:contain; }
.main-nav ul{ display:flex; align-items:center; gap:2.4rem; }
.main-nav a{
  font-size:.88rem; font-weight:500; color:var(--ink-soft); position:relative; padding:.3em 0; letter-spacing:.02em;
  transition:color .2s var(--ease);
}
.main-nav a::after{
  content:""; position:absolute; left:0; right:100%; bottom:-3px; height:1.5px; background:var(--gold);
  transition:right .25s var(--ease);
}
.main-nav a:hover{ color:var(--ink); }
.main-nav a:hover::after{ right:0; }

.nav-toggle{
  display:none; flex-direction:column; justify-content:center; gap:5px;
  width:38px; height:38px; background:none; border:none; cursor:pointer;
}
.nav-toggle span{ display:block; height:2px; width:100%; background:var(--ink); transition:transform .25s var(--ease), opacity .25s var(--ease); }

/* ---------- Hero ---------- */
.hero{
  position:relative; min-height:100vh; display:flex; align-items:center; justify-content:center;
  overflow:hidden; padding:6rem 1.5rem 4rem; text-align:center;
  background:radial-gradient(circle at 50% 18%, var(--sand) 0%, var(--cream) 55%);
}
.hero::after{
  content:""; position:absolute; inset:0; z-index:0;
  background:url('../assets/hero-bg.jpg') center/cover no-repeat;
  opacity:.12; pointer-events:none;
}
.hero::before{
  content:""; position:absolute; bottom:0; left:0; right:0; z-index:1;
  height:180px; pointer-events:none;
  background:linear-gradient(to bottom, transparent, var(--cream));
}
.hero-wave{
  position:absolute; inset:0; width:100%; height:100%; z-index:0; opacity:.9;
}
.wave-path{
  fill:none; stroke:var(--gold-pale); stroke-width:3; stroke-linecap:round;
  stroke-dasharray:2000; stroke-dashoffset:2000;
  animation:draw 2.6s var(--ease) .2s forwards;
}
@keyframes draw{ to{ stroke-dashoffset:0; } }

.hero-inner{ position:relative; z-index:1; max-width:720px; }
.hero-logo{ width:600px; max-width:90vw; mix-blend-mode:multiply; display:block; margin:0 auto; }
.hero h1{
  font-size:clamp(3rem, 8vw, 5.2rem); letter-spacing:.01em; margin-top:0;
}
.hero-tagline{
  font-size:1.15rem; color:var(--ink-soft); max-width:520px; margin:0 auto 2rem;
}
.hero-actions{ display:flex; gap:1rem; justify-content:center; flex-wrap:wrap; }

.scroll-cue{
  position:absolute; bottom:2rem; left:50%; transform:translateX(-50%);
  width:26px; height:42px; border:2px solid var(--ink-soft); border-radius:20px;
}
.scroll-cue span{
  position:absolute; top:6px; left:50%; width:4px; height:8px; margin-left:-2px;
  background:var(--gold); border-radius:2px; animation:scrollcue 1.8s ease-in-out infinite;
}
@keyframes scrollcue{ 0%{ opacity:1; top:6px; } 70%{ opacity:0; top:22px; } 100%{ opacity:0; top:6px; } }

/* ---------- Dividers (motif vague récurrent) ---------- */
.divider{
  line-height:0; color:var(--gold-pale);
  overflow:hidden;
}
.divider svg{
  width:100%; height:80px; display:block;
  transform-origin:center center;
  animation:wave-breathe 4s ease-in-out infinite;
  will-change:transform;
}
.divider path{ fill:none; stroke:currentColor; stroke-width:3.5; vector-effect:non-scaling-stroke; }
.divider-flip{ transform:scaleY(-1); }
.divider-flip svg{ animation-duration:5.5s; animation-delay:-2s; }

/* Dégradés inter-sections — couleurs inversées pour les .divider-flip */
.hero       + .divider{ background:linear-gradient(to bottom, var(--cream), var(--cream)); }
.specialites + .divider{ background:linear-gradient(to bottom, var(--sand),  var(--cream)); }
.histoire    + .divider{ background:linear-gradient(to bottom, var(--sand),  var(--sea-pale)); }
.horaires    + .divider{ background:linear-gradient(to bottom, var(--white), var(--sea-pale)); }

@keyframes wave-breathe{
  0%,100%{ transform:scaleY(.75); }
  50%{ transform:scaleY(1.18); }
}

/* ---------- Reveal on scroll ---------- */
.reveal{ opacity:0; transform:translateY(28px); transition:opacity .7s var(--ease), transform .7s var(--ease); }
.reveal.is-visible{ opacity:1; transform:none; }

/* ---------- Spécialités ---------- */
.specialites{ background:var(--cream); }
.specialites h2, .histoire h2, .horaires h2, .contact h2{ font-size:clamp(2rem, 4vw, 2.6rem); }
.cards{ display:grid; grid-template-columns:repeat(3, 1fr); gap:2rem; margin-top:2.5rem; }
.card{
  background:var(--white); border:1px solid var(--sand); border-radius:10px;
  padding:2.4rem 1.8rem; text-align:left; transition:transform .3s var(--ease), box-shadow .3s var(--ease);
}
.card:hover{ transform:translateY(-6px); box-shadow:0 14px 30px -16px rgba(33,28,23,.25); }
.card-icon{ display:inline-flex; width:48px; height:48px; margin-bottom:1.2rem; }
.card-icon img{ width:100%; height:100%; filter:brightness(0) saturate(100%) invert(35%) sepia(60%) saturate(500%) hue-rotate(12deg) brightness(82%); }

/* Produits vedettes dans les cartes spécialités */
.spec-produits{ display:flex; flex-direction:column; gap:.75rem; margin-top:1.2rem; border-top:1px solid var(--sand); padding-top:1.1rem; }
.spec-produit{ display:flex; align-items:center; gap:.9rem; }
.spec-produit-img{ width:82px; height:82px; object-fit:cover; border-radius:10px; flex-shrink:0; background:var(--sand); }
.spec-produit-info{ display:flex; flex-direction:column; gap:.15rem; }
.spec-produit-header{ display:flex; align-items:center; gap:.5rem; flex-wrap:wrap; }
.spec-produit-info strong{ font-size:.92rem; font-family:var(--font-display); font-weight:600; color:var(--ink); }
.spec-produit-info > span{ font-size:.8rem; color:var(--ink-soft); line-height:1.4; }
.produit-tag{ font-size:.68rem; font-weight:700; letter-spacing:.05em; padding:.2em .55em; border-radius:100px; white-space:nowrap; }
.produit-tag--top-vente{ background:#fff4e0; color:#a06020; }
.produit-tag--selection{ background:#e8f0ee; color:var(--sea); }
.produit-tag--nouveaute{ background:#edf0ff; color:#4a5bcc; }
.card h3{ font-size:1.4rem; margin-bottom:.5rem; }
.card p{ font-size:.96rem; margin-bottom:0; }

/* ---------- Histoire ---------- */
.histoire{ background:var(--sand); }
.histoire-grid{ display:grid; grid-template-columns:.85fr 1.15fr; gap:3.5rem; align-items:center; }
.histoire-frame{
  background:var(--white); border-radius:50%; aspect-ratio:1; width:min(100%, 360px); margin:0 auto;
  display:flex; align-items:center; justify-content:center; padding:2.5rem;
  box-shadow:0 20px 40px -22px rgba(33,28,23,.35);
}
.histoire-frame img{ width:100%; }
.histoire-text h2{ max-width:480px; }

/* ---------- Horaires & accès ---------- */
.horaires{ background:var(--sea-pale); }
.horaires-grid{ display:grid; grid-template-columns:1fr 1fr; gap:3.5rem; align-items:start; }
.hours-table{ width:100%; border-collapse:collapse; margin:1.6rem 0 1.8rem; font-size:.96rem; }
.hours-table th,.hours-table td{ text-align:left; padding:.55em 0; border-bottom:1px solid rgba(33,28,23,.12); }
.hours-table th{ font-weight:600; color:var(--ink); width:48%; }
.hours-table td{ color:var(--ink-soft); }
address{ font-style:normal; color:var(--ink-soft); margin-bottom:1.6rem; line-height:1.8; }
address a{ color:var(--gold-deep); font-weight:600; }
.social-row{ display:flex; gap:.9rem; }
.social-icon{
  width:42px; height:42px; border-radius:50%; border:1.5px solid var(--sea);
  display:flex; align-items:center; justify-content:center; transition:background .25s var(--ease), color .25s var(--ease);
}
.social-icon svg{ width:20px; height:20px; fill:none; stroke:var(--sea); stroke-width:1.6; }
.social-icon:hover{ background:var(--sea); }
.social-icon:hover svg{ stroke:var(--white); }
.map-col iframe{ width:100%; height:100%; min-height:320px; border:0; border-radius:10px; }

/* ---------- Contact ---------- */
.contact{ background:var(--cream); }
.contact-inner{ max-width:640px; text-align:center; }
.contact-intro{ max-width:440px; margin:0 auto 2.4rem; }
.contact-form{ text-align:left; display:flex; flex-direction:column; gap:1.2rem; }
.form-row{ display:flex; flex-direction:column; gap:.4rem; }
.form-row label{ font-size:.85rem; font-weight:600; color:var(--ink); }
.form-row input, .form-row textarea{
  font-family:var(--font-body); font-size:1rem; padding:.7em .9em;
  border:1.5px solid var(--sand); border-radius:var(--radius); background:var(--white); color:var(--ink);
  transition:border-color .25s var(--ease);
}
.form-row input:focus, .form-row textarea:focus{ border-color:var(--gold); }
.contact-form .btn{ align-self:flex-start; margin-top:.4rem; }

/* ---------- Lightbox ---------- */
.lightbox{
  position:fixed; inset:0; z-index:200;
  background:rgba(15,12,9,.85); backdrop-filter:blur(8px);
  display:flex; align-items:center; justify-content:center; padding:1.5rem;
  opacity:0; pointer-events:none;
  transition:opacity .3s cubic-bezier(.4,0,.2,1);
}
.lightbox.is-open{ opacity:1; pointer-events:auto; }

.lightbox-inner{
  position:relative; max-width:min(90vw, 780px); max-height:90vh;
  display:flex; flex-direction:column; align-items:center; gap:.8rem;
  transform:scale(.86) translateY(12px);
  transition:transform .35s cubic-bezier(.34,1.26,.64,1);
}
.lightbox.is-open .lightbox-inner{ transform:scale(1) translateY(0); }

.lightbox-img{
  max-width:100%; max-height:80vh; object-fit:contain;
  border-radius:12px; box-shadow:0 32px 80px -16px rgba(0,0,0,.7);
  display:block;
}
.lightbox-caption{
  color:rgba(255,255,255,.72); font-size:.88rem; font-family:var(--font-body);
  text-align:center; letter-spacing:.02em;
}
.lightbox-close{
  position:fixed; top:1.2rem; right:1.4rem;
  width:40px; height:40px; border-radius:50%;
  background:rgba(255,255,255,.15); border:1px solid rgba(255,255,255,.2);
  color:#fff; font-size:1.1rem; cursor:pointer; line-height:1;
  transition:background .2s, transform .2s;
}
.lightbox-close:hover{ background:rgba(255,255,255,.28); transform:scale(1.1); }

.spec-produit-img{ cursor:zoom-in; transition:transform .25s var(--ease), box-shadow .25s var(--ease); }
.spec-produit-img:hover{ transform:scale(1.06); box-shadow:0 8px 20px -8px rgba(33,28,23,.3); }

/* ---------- Bandeau avis Google ---------- */
.google-reviews-band{
  display:flex; align-items:center; gap:1.2rem; justify-content:center; flex-wrap:wrap;
  padding:1.3rem 1.5rem; background:var(--white);
  border-top:1px solid var(--sand); border-bottom:1px solid var(--sand);
  text-decoration:none; color:var(--ink);
  transition:background .25s var(--ease);
}
.google-reviews-band:hover{ background:var(--cream); }
.google-g{ width:28px; height:28px; flex-shrink:0; }
.google-reviews-text{ display:flex; flex-direction:column; line-height:1.2; }
.google-reviews-stars{ color:#f4b400; font-size:1rem; letter-spacing:.05em; }
.star-half{ opacity:.4; }
.google-reviews-count{ font-size:.8rem; color:var(--ink-soft); font-family:var(--font-body); }
.google-reviews-cta{
  margin-left:.4rem; font-size:.85rem; font-weight:600;
  color:var(--gold-deep); text-decoration:underline; text-underline-offset:3px;
}

/* ---------- Footer ---------- */
.site-footer{ background:var(--ink); color:var(--sand); }

.footer-top{ padding:4rem 1.5rem 3rem; }
.footer-grid{
  max-width:var(--max-w); margin:0 auto;
  display:grid; grid-template-columns:2fr 1fr 1.3fr; gap:4rem;
}
.footer-brand-link{ display:flex; align-items:center; gap:.9rem; text-decoration:none; margin-bottom:1rem; }
.footer-logo{ height:48px; width:48px; border-radius:50%; object-fit:contain; padding:4px; background:rgba(251,246,238,.1); flex-shrink:0; }
.footer-brand-text{ display:flex; flex-direction:column; gap:.2rem; }
.footer-brand-name{ font-family:var(--font-display); font-size:1.15rem; font-weight:600; color:var(--cream); }
.footer-brand-tagline{ font-size:.75rem; color:var(--gold-pale); letter-spacing:.05em; }
.footer-brand-desc{ font-size:.86rem; color:rgba(241,230,211,.45); line-height:1.65; margin:0; font-style:italic; }

.footer-section-label{
  font-size:.66rem; font-weight:700; text-transform:uppercase; letter-spacing:.13em;
  color:var(--gold); margin:0 0 1rem;
}
.footer-nav ul{ list-style:none; display:flex; flex-direction:column; gap:.7rem; }
.footer-nav a{ font-size:.88rem; color:rgba(241,230,211,.6); transition:color .2s; }
.footer-nav a:hover{ color:var(--cream); }

.footer-contact address{ font-style:normal; }
.footer-contact p{ font-size:.88rem; color:rgba(241,230,211,.6); line-height:1.7; margin:0 0 1.2rem; }
.footer-socials{ display:flex; gap:.55rem; }
.footer-social-link{
  display:flex; align-items:center; justify-content:center;
  width:36px; height:36px; border-radius:8px;
  border:1px solid rgba(241,230,211,.14);
  transition:background .2s, border-color .2s;
}
.footer-social-link:hover{ background:rgba(241,230,211,.09); border-color:rgba(241,230,211,.35); }
.footer-social-link img{ filter:brightness(0) invert(.65); transition:filter .2s; }
.footer-social-link:hover img{ filter:brightness(0) invert(1); }

.footer-bottom{ border-top:1px solid rgba(241,230,211,.08); }
.footer-bottom-inner{
  max-width:var(--max-w); margin:0 auto; padding:1.2rem 1.5rem;
  display:flex; justify-content:space-between; align-items:center;
}
.footer-bottom p{ font-size:.78rem; color:rgba(241,230,211,.28); margin:0; }
.footer-admin-link{ font-size:.72rem; color:rgba(241,230,211,.18); transition:color .2s; }
.footer-admin-link:hover{ color:rgba(241,230,211,.5); }

/* =========================================================
   Responsive
   ========================================================= */
@media (max-width: 900px){
  .histoire-grid, .horaires-grid{ grid-template-columns:1fr; }
  .histoire-visual{ order:-1; }
  .footer-grid{ grid-template-columns:1fr 1fr; gap:2.5rem; }
  .footer-brand{ grid-column:span 2; }
}

@media (max-width: 720px){
  .main-nav{
    position:fixed; inset:0 0 0 30%; top:0; background:var(--cream);
    box-shadow:-8px 0 24px -10px rgba(0,0,0,.2);
    transform:translateX(100%); transition:transform .35s var(--ease);
    padding:6.5rem 1.8rem 2rem; z-index:90;
  }
  .main-nav.is-open{ transform:translateX(0); }
  .main-nav ul{ flex-direction:column; align-items:flex-start; gap:1.6rem; }
  .nav-toggle{ display:flex; }
  .cards{ grid-template-columns:1fr; }
  .footer-grid{ grid-template-columns:1fr; gap:2rem; }
  .footer-brand{ grid-column:auto; }
  .footer-bottom-inner{ flex-direction:column; gap:.6rem; text-align:center; }
}

/* =========================================================
   Sections dynamiques (générées depuis l'admin)
   ========================================================= */

/* --- Bannière / annonce --- */
.block-banner{
  padding:1.4rem 1.5rem; text-align:center;
  display:flex; align-items:center; justify-content:center; gap:1.2rem; flex-wrap:wrap;
}
.block-banner.style-info{ background:var(--sand); color:var(--ink); }
.block-banner.style-highlight{ background:var(--gold); color:var(--white); }
.block-banner p{ margin:0; font-weight:600; color:inherit; }
.block-banner .btn{ flex-shrink:0; }
.block-banner.style-highlight .btn-primary{ background:var(--ink); }
.block-banner.style-highlight .btn-primary:hover{ background:var(--gold-deep); }

/* --- Grille de cartes (réutilise .cards/.card) --- */
.block-cards{ background:var(--cream); }

/* --- Texte + image --- */
.block-text-image{ background:var(--sand); }
.block-text-image:nth-of-type(even){ background:var(--cream); }
.text-image-grid{ display:grid; grid-template-columns:1fr 1fr; gap:3.5rem; align-items:center; }
.text-image-grid.img-right .text-image-visual{ order:2; }
.text-image-frame{
  background:var(--white); border-radius:18px; overflow:hidden;
  box-shadow:0 20px 40px -22px rgba(33,28,23,.3);
}
.text-image-frame img{ width:100%; height:100%; object-fit:cover; display:block; }

/* --- Galerie --- */
.block-gallery{ background:var(--cream); }
.gallery-grid{ display:grid; grid-template-columns:repeat(3, 1fr); gap:1.2rem; margin-top:2rem; }
.gallery-grid img{
  width:100%; aspect-ratio:1; object-fit:cover; border-radius:10px;
  box-shadow:0 10px 24px -14px rgba(33,28,23,.3); transition:transform .3s var(--ease);
}
.gallery-grid img:hover{ transform:scale(1.03); }

@media (max-width: 900px){
  .text-image-grid{ grid-template-columns:1fr; }
  .text-image-grid.img-right .text-image-visual{ order:-1; }
}
@media (max-width: 600px){
  .gallery-grid{ grid-template-columns:repeat(2, 1fr); }
}

@media (max-width: 480px){
  .section-inner{ padding:3.8rem 1.2rem; }
  .hero h1{ font-size:2.8rem; }
}
