/* ====== RESET & BASE ====== */
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
:root{
  --noir:#0a0a0a;
  --noir-doux:#1a1a1a;
  --or:#c9a961;
  --or-clair:#e0c989;
  --or-fonce:#8b7340;
  --blanc:#ffffff;
  --beige:#f5f1ea;
  --gris:#888;
  --gris-clair:#e5e5e5;
  --transition:all .4s cubic-bezier(.4,0,.2,1);
}
html{scroll-behavior:smooth}
body{
  font-family:'Cormorant Garamond',Georgia,serif;
  background:var(--blanc);
  color:var(--noir);
  line-height:1.7;
  font-size:18px;
  overflow-x:hidden;
}
img{max-width:100%;display:block}
a{text-decoration:none;color:inherit}

h1,h2,h3,h4{font-family:'Playfair Display',Georgia,serif;font-weight:400;letter-spacing:.5px;line-height:1.2}
h1{font-size:clamp(2.5rem,6vw,5rem)}
h2{font-size:clamp(2rem,4vw,3.5rem)}
h3{font-size:clamp(1.4rem,2.5vw,2rem)}

.container{max-width:1280px;margin:0 auto;padding:0 5%}
.section{padding:120px 0}
.eyebrow{
  font-family:'Montserrat',sans-serif;
  text-transform:uppercase;
  letter-spacing:4px;
  font-size:12px;
  color:var(--or);
  font-weight:500;
  display:inline-block;
  margin-bottom:20px;
}
.eyebrow::before{content:'— '}
.eyebrow::after{content:' —'}

.btn{
  display:inline-block;
  padding:16px 38px;
  font-family:'Montserrat',sans-serif;
  font-size:12px;
  letter-spacing:3px;
  text-transform:uppercase;
  font-weight:500;
  border:1px solid var(--or);
  color:var(--or);
  background:transparent;
  cursor:pointer;
  transition:var(--transition);
  position:relative;
  overflow:hidden;
}
.btn:hover{background:var(--or);color:var(--noir)}
.btn-dark{background:var(--noir);color:var(--blanc);border-color:var(--noir)}
.btn-dark:hover{background:var(--or);border-color:var(--or);color:var(--noir)}
.btn-or{background:var(--or);color:var(--noir);border-color:var(--or)}
.btn-or:hover{background:transparent;color:var(--or)}

/* ====== NAVIGATION ====== */
.nav{
  position:fixed;
  top:0;left:0;right:0;
  z-index:1000;
  padding:25px 5%;
  display:flex;
  align-items:center;
  justify-content:space-between;
  transition:var(--transition);
  background:transparent;
}
.nav.scrolled{
  background:rgba(10,10,10,.95);
  backdrop-filter:blur(10px);
  padding:15px 5%;
  box-shadow:0 2px 30px rgba(0,0,0,.2);
}
.nav-logo{
  font-family:'Playfair Display',serif;
  font-size:28px;
  color:var(--blanc);
  letter-spacing:4px;
  font-weight:400;
}
.nav-logo span{color:var(--or);font-style:italic}
.nav-links{
  display:flex;
  gap:42px;
  list-style:none;
}
.nav-links a{
  color:var(--blanc);
  font-family:'Montserrat',sans-serif;
  font-size:12px;
  letter-spacing:2.5px;
  text-transform:uppercase;
  font-weight:400;
  position:relative;
  padding:5px 0;
}
.nav-links a::after{
  content:'';
  position:absolute;
  bottom:0;left:50%;
  transform:translateX(-50%);
  width:0;
  height:1px;
  background:var(--or);
  transition:var(--transition);
}
.nav-links a:hover{color:var(--or)}
.nav-links a:hover::after,.nav-links a.active::after{width:100%}
.nav-links a.active{color:var(--or)}

.nav-cta{
  padding:10px 24px;
  border:1px solid var(--or);
  color:var(--or);
  font-family:'Montserrat',sans-serif;
  font-size:11px;
  letter-spacing:2px;
  text-transform:uppercase;
  transition:var(--transition);
}
.nav-cta:hover{background:var(--or);color:var(--noir)}

.hamburger{
  display:none;
  width:32px;
  height:24px;
  flex-direction:column;
  justify-content:space-between;
  cursor:pointer;
  z-index:1001;
}
.hamburger span{
  display:block;
  height:2px;
  width:100%;
  background:var(--blanc);
  transition:var(--transition);
}
.hamburger.active span:nth-child(1){transform:translateY(11px) rotate(45deg)}
.hamburger.active span:nth-child(2){opacity:0}
.hamburger.active span:nth-child(3){transform:translateY(-11px) rotate(-45deg)}

/* ====== HERO ====== */
.hero{
  height:100vh;
  min-height:700px;
  position:relative;
  display:flex;
  align-items:center;
  justify-content:center;
  text-align:center;
  color:var(--blanc);
  overflow:hidden;
}
.hero-bg{
  position:absolute;
  inset:0;
  background-size:cover;
  background-position:center;
  z-index:1;
  animation:slowZoom 20s ease-in-out infinite alternate;
}
@keyframes slowZoom{
  from{transform:scale(1)}
  to{transform:scale(1.1)}
}
.hero::after{
  content:'';
  position:absolute;inset:0;
  background:linear-gradient(180deg,rgba(0,0,0,.5) 0%,rgba(0,0,0,.4) 50%,rgba(0,0,0,.7) 100%);
  z-index:2;
}
.hero-content{
  position:relative;
  z-index:3;
  max-width:900px;
  padding:0 5%;
  animation:fadeUp 1.5s ease;
}
@keyframes fadeUp{
  from{opacity:0;transform:translateY(40px)}
  to{opacity:1;transform:translateY(0)}
}
.hero h1{
  font-size:clamp(3rem,8vw,7rem);
  margin-bottom:30px;
  font-weight:300;
  letter-spacing:2px;
}
.hero h1 span{color:var(--or);font-style:italic;display:block;font-weight:400}
.hero-tagline{
  font-family:'Montserrat',sans-serif;
  font-size:13px;
  letter-spacing:6px;
  text-transform:uppercase;
  margin-bottom:30px;
  color:var(--or-clair);
}
.hero-desc{
  font-size:20px;
  max-width:650px;
  margin:0 auto 50px;
  opacity:.95;
  font-style:italic;
}
.hero-actions{
  display:flex;
  gap:20px;
  justify-content:center;
  flex-wrap:wrap;
}
.hero-scroll{
  position:absolute;
  bottom:40px;
  left:50%;
  transform:translateX(-50%);
  z-index:3;
  color:var(--blanc);
  font-family:'Montserrat',sans-serif;
  font-size:10px;
  letter-spacing:3px;
  text-transform:uppercase;
  animation:bounce 2s infinite;
}
.hero-scroll::after{
  content:'';
  display:block;
  width:1px;
  height:40px;
  background:var(--or);
  margin:15px auto 0;
}
@keyframes bounce{
  0%,100%{transform:translateX(-50%) translateY(0)}
  50%{transform:translateX(-50%) translateY(10px)}
}

/* ====== INNER HERO ====== */
.inner-hero{
  height:60vh;
  min-height:400px;
  position:relative;
  display:flex;
  align-items:center;
  justify-content:center;
  text-align:center;
  color:var(--blanc);
  overflow:hidden;
}
.inner-hero-bg{
  position:absolute;inset:0;
  background-size:cover;
  background-position:center;
  z-index:1;
}
.inner-hero::after{
  content:'';
  position:absolute;inset:0;
  background:rgba(0,0,0,.55);
  z-index:2;
}
.inner-hero-content{position:relative;z-index:3;padding-top:80px}
.inner-hero h1{font-size:clamp(2.5rem,5vw,4rem);margin-bottom:15px}
.breadcrumb{
  font-family:'Montserrat',sans-serif;
  font-size:11px;
  letter-spacing:3px;
  text-transform:uppercase;
  color:var(--or-clair);
}
.breadcrumb a:hover{color:var(--or)}

/* ====== INTRO / À PROPOS ====== */
.intro{
  background:var(--blanc);
  padding:140px 0;
}
.intro-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:80px;
  align-items:center;
}
.intro-image{
  position:relative;
  height:600px;
  overflow:hidden;
}
.intro-image img{
  width:100%;
  height:100%;
  object-fit:cover;
  transition:transform 1s ease;
}
.intro-image:hover img{transform:scale(1.05)}
.intro-image::before{
  content:'';
  position:absolute;
  inset:20px;
  border:1px solid var(--or);
  z-index:2;
  pointer-events:none;
}
.intro-text h2{margin-bottom:30px;font-style:italic}
.intro-text p{margin-bottom:25px;color:#444;font-size:19px}
.intro-text .signature{
  font-family:'Playfair Display',serif;
  font-style:italic;
  font-size:24px;
  color:var(--or);
  margin-top:30px;
}

/* ====== SPECIALITES ====== */
.specialites{
  background:var(--noir);
  color:var(--blanc);
  padding:140px 0;
  position:relative;
}
.specialites-header{
  text-align:center;
  max-width:700px;
  margin:0 auto 80px;
}
.specialites-header h2{color:var(--blanc);margin-bottom:20px}
.specialites-header p{color:#bbb;font-size:19px;font-style:italic}
.specialites-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:40px;
}
.spec-card{
  background:var(--noir-doux);
  overflow:hidden;
  transition:var(--transition);
  position:relative;
  border:1px solid #222;
}
.spec-card:hover{transform:translateY(-10px);border-color:var(--or)}
.spec-img{
  height:300px;
  overflow:hidden;
  position:relative;
}
.spec-img img{
  width:100%;
  height:100%;
  object-fit:cover;
  transition:transform .8s ease;
}
.spec-card:hover .spec-img img{transform:scale(1.1)}
.spec-content{padding:35px}
.spec-content h3{margin-bottom:15px;color:var(--or)}
.spec-content p{color:#aaa;font-size:16px}
.spec-content .price{
  font-family:'Playfair Display',serif;
  color:var(--or);
  font-size:22px;
  margin-top:20px;
  display:block;
}

/* ====== EXPÉRIENCE ====== */
.experience{
  background:var(--beige);
  padding:140px 0;
}
.exp-grid{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:50px;
  text-align:center;
}
.exp-item{padding:30px 20px}
.exp-icon{
  width:60px;
  height:60px;
  margin:0 auto 25px;
  color:var(--or);
}
.exp-icon svg{width:100%;height:100%}
.exp-item h3{margin-bottom:12px;font-size:22px}
.exp-item p{color:#666;font-size:16px}

/* ====== GALERIE ====== */
.galerie-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:15px;
}
.galerie-item{
  position:relative;
  overflow:hidden;
  aspect-ratio:1;
  cursor:pointer;
}
.galerie-item img{
  width:100%;
  height:100%;
  object-fit:cover;
  transition:transform .8s ease;
}
.galerie-item:hover img{transform:scale(1.1)}
.galerie-item::after{
  content:'';
  position:absolute;inset:0;
  background:rgba(0,0,0,0);
  transition:var(--transition);
}
.galerie-item:hover::after{background:rgba(0,0,0,.3)}
.galerie-item.tall{grid-row:span 2;aspect-ratio:1/2}

/* ====== TÉMOIGNAGES ====== */
.temoignages{
  background:var(--noir);
  color:var(--blanc);
  padding:140px 0;
}
.temoignages-header{text-align:center;margin-bottom:80px}
.temoignages-header h2{color:var(--blanc)}
.temoignages-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:50px;
}
.temoignage{
  text-align:center;
  padding:50px 30px;
  border:1px solid #222;
  background:var(--noir-doux);
  transition:var(--transition);
}
.temoignage:hover{border-color:var(--or)}
.stars{color:var(--or);font-size:18px;letter-spacing:5px;margin-bottom:25px}
.temoignage-text{
  font-style:italic;
  font-size:18px;
  color:#ddd;
  margin-bottom:30px;
}
.temoignage-author{
  font-family:'Playfair Display',serif;
  color:var(--or);
  font-size:18px;
}
.temoignage-author small{
  display:block;
  color:#999;
  font-size:12px;
  letter-spacing:2px;
  text-transform:uppercase;
  margin-top:5px;
  font-family:'Montserrat',sans-serif;
}

/* ====== CTA RESERVATION ====== */
.cta-resa{
  position:relative;
  padding:140px 0;
  text-align:center;
  color:var(--blanc);
  overflow:hidden;
}
.cta-resa-bg{
  position:absolute;inset:0;
  background-size:cover;
  background-position:center;
  background-attachment:fixed;
  z-index:1;
}
.cta-resa::after{
  content:'';position:absolute;inset:0;
  background:rgba(0,0,0,.7);z-index:2;
}
.cta-resa-content{position:relative;z-index:3}
.cta-resa h2{margin-bottom:25px;font-style:italic}
.cta-resa p{font-size:20px;max-width:600px;margin:0 auto 40px;color:#ddd}

/* ====== CARTE / MENU ====== */
.menu-section{padding:100px 0}
.menu-section:nth-child(even){background:var(--beige)}
.menu-category{margin-bottom:80px}
.menu-category:last-child{margin-bottom:0}
.menu-cat-title{
  text-align:center;
  margin-bottom:60px;
}
.menu-cat-title h2{font-style:italic}
.menu-cat-title .ornament{
  display:flex;
  align-items:center;
  justify-content:center;
  gap:20px;
  margin-top:15px;
}
.menu-cat-title .ornament::before,
.menu-cat-title .ornament::after{
  content:'';
  display:block;
  width:60px;
  height:1px;
  background:var(--or);
}
.menu-cat-title .ornament span{color:var(--or);font-size:18px}

.menu-items{
  display:grid;
  grid-template-columns:repeat(2,1fr);
  gap:50px;
}
.menu-item{
  display:grid;
  grid-template-columns:120px 1fr auto;
  gap:25px;
  align-items:start;
  padding-bottom:30px;
  border-bottom:1px dashed #ccc;
}
.menu-item-img{
  width:120px;
  height:120px;
  overflow:hidden;
  border-radius:4px;
}
.menu-item-img img{width:100%;height:100%;object-fit:cover;transition:transform .5s}
.menu-item:hover .menu-item-img img{transform:scale(1.1)}
.menu-item-info h3{
  font-size:22px;
  margin-bottom:8px;
}
.menu-item-info p{
  color:#666;
  font-size:15px;
  font-style:italic;
  line-height:1.5;
}
.menu-item-price{
  font-family:'Playfair Display',serif;
  font-size:24px;
  color:var(--or);
  white-space:nowrap;
}

/* ====== FORMULAIRES ====== */
.form-section{
  padding:120px 0;
  background:var(--beige);
}
.form-wrapper{
  max-width:700px;
  margin:0 auto;
  background:var(--blanc);
  padding:60px;
  box-shadow:0 30px 60px rgba(0,0,0,.08);
}
.form-wrapper h2{text-align:center;margin-bottom:15px;font-style:italic}
.form-wrapper .form-intro{
  text-align:center;
  color:#666;
  margin-bottom:50px;
  font-size:18px;
}
.form-group{margin-bottom:25px}
.form-row{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:20px;
}
.form-group label{
  display:block;
  font-family:'Montserrat',sans-serif;
  font-size:11px;
  letter-spacing:2px;
  text-transform:uppercase;
  color:var(--noir);
  margin-bottom:10px;
  font-weight:500;
}
.form-group input,
.form-group select,
.form-group textarea{
  width:100%;
  padding:14px 18px;
  border:1px solid #ddd;
  background:var(--blanc);
  font-family:inherit;
  font-size:16px;
  color:var(--noir);
  transition:var(--transition);
}
.form-group input:focus,
.form-group select:focus,
.form-group textarea:focus{
  outline:none;
  border-color:var(--or);
  box-shadow:0 0 0 3px rgba(201,169,97,.1);
}
.form-group textarea{resize:vertical;min-height:140px;font-family:'Cormorant Garamond',serif}
.form-submit{
  text-align:center;
  margin-top:30px;
}
.form-message{
  padding:15px 20px;
  margin-bottom:20px;
  text-align:center;
  display:none;
}
.form-message.success{background:#e8f5e9;color:#2e7d32;display:block}
.form-message.error{background:#ffebee;color:#c62828;display:block}

/* ====== CONTACT ====== */
.contact-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:80px;
  margin-bottom:60px;
}
.contact-info h2{margin-bottom:30px;font-style:italic}
.contact-info p{color:#555;margin-bottom:30px;font-size:18px}
.contact-block{
  display:flex;
  gap:20px;
  margin-bottom:30px;
  padding-bottom:30px;
  border-bottom:1px solid #eee;
}
.contact-block:last-child{border:none}
.contact-block-icon{
  width:50px;
  height:50px;
  border:1px solid var(--or);
  display:flex;
  align-items:center;
  justify-content:center;
  flex-shrink:0;
  color:var(--or);
}
.contact-block-icon svg{width:22px;height:22px}
.contact-block h4{
  font-family:'Montserrat',sans-serif;
  font-size:11px;
  letter-spacing:3px;
  text-transform:uppercase;
  color:var(--or);
  margin-bottom:8px;
}
.contact-block p{color:#333;margin:0;font-size:17px}

.map-wrapper{
  width:100%;
  height:450px;
  overflow:hidden;
  border:1px solid #eee;
}
.map-wrapper iframe{width:100%;height:100%;border:0;filter:grayscale(.3)}

/* ====== HORAIRES ====== */
.horaires{
  background:var(--noir-doux);
  color:var(--blanc);
  padding:80px 0;
  text-align:center;
}
.horaires h2{color:var(--blanc);margin-bottom:40px}
.horaires-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:50px;
  max-width:700px;
  margin:0 auto;
}
.horaires-bloc h3{color:var(--or);margin-bottom:20px;font-size:24px}
.horaires-bloc p{color:#ddd;font-size:17px;margin-bottom:5px}

/* ====== FOOTER ====== */
.footer{
  background:#050505;
  color:#999;
  padding:80px 0 30px;
}
.footer-grid{
  display:grid;
  grid-template-columns:2fr 1fr 1fr 1fr;
  gap:50px;
  margin-bottom:60px;
}
.footer-brand h3{
  color:var(--blanc);
  font-family:'Playfair Display',serif;
  font-size:32px;
  letter-spacing:4px;
  margin-bottom:20px;
}
.footer-brand h3 span{color:var(--or);font-style:italic}
.footer-brand p{font-size:16px;line-height:1.7;color:#888}
.footer-col h4{
  color:var(--blanc);
  font-family:'Montserrat',sans-serif;
  font-size:12px;
  letter-spacing:3px;
  text-transform:uppercase;
  margin-bottom:25px;
}
.footer-col ul{list-style:none}
.footer-col li{margin-bottom:12px}
.footer-col a{color:#888;font-size:15px;transition:var(--transition)}
.footer-col a:hover{color:var(--or)}
.footer-bottom{
  border-top:1px solid #1a1a1a;
  padding-top:30px;
  text-align:center;
  font-size:13px;
  letter-spacing:1px;
}

/* ====== REVEAL ANIMATIONS ====== */
.reveal{opacity:0;transform:translateY(40px);transition:all 1s cubic-bezier(.4,0,.2,1)}
.reveal.visible{opacity:1;transform:translateY(0)}
.reveal-left{opacity:0;transform:translateX(-40px);transition:all 1s cubic-bezier(.4,0,.2,1)}
.reveal-left.visible{opacity:1;transform:translateX(0)}
.reveal-right{opacity:0;transform:translateX(40px);transition:all 1s cubic-bezier(.4,0,.2,1)}
.reveal-right.visible{opacity:1;transform:translateX(0)}

/* Fallback : si JS désactivé ou observer ne se déclenche pas */
@keyframes revealFallback{to{opacity:1;transform:translateY(0)}}
.reveal{animation:revealFallback 1s ease .5s forwards}

/* ====== RESPONSIVE ====== */
@media(max-width:1024px){
  .intro-grid,.contact-grid{grid-template-columns:1fr;gap:50px}
  .intro-image{height:450px}
  .specialites-grid,.temoignages-grid{grid-template-columns:1fr 1fr}
  .exp-grid{grid-template-columns:1fr 1fr;gap:30px}
  .menu-items{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr 1fr}
}
@media(max-width:768px){
  body{font-size:16px}
  .section{padding:80px 0}
  .nav{padding:20px 5%}
  .nav-cta{display:none}
  .hamburger{display:flex}
  .nav-links{
    position:fixed;
    top:0;right:-100%;
    width:80%;max-width:340px;
    height:100vh;
    background:var(--noir);
    flex-direction:column;
    justify-content:center;
    align-items:center;
    gap:30px;
    transition:right .4s ease;
    box-shadow:-10px 0 30px rgba(0,0,0,.3);
  }
  .nav-links.open{right:0}
  .nav-links a{font-size:14px}
  .hero{min-height:600px}
  .hero h1{font-size:3rem}
  .hero-desc{font-size:17px}
  .specialites-grid,.temoignages-grid,.exp-grid,.galerie-grid{grid-template-columns:1fr}
  .galerie-item.tall{aspect-ratio:1;grid-row:span 1}
  .menu-item{grid-template-columns:80px 1fr;gap:15px}
  .menu-item-img{width:80px;height:80px}
  .menu-item-price{grid-column:2;font-size:20px}
  .form-wrapper{padding:40px 25px}
  .form-row{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr;gap:40px;text-align:center}
  .horaires-grid{grid-template-columns:1fr;gap:30px}
  .intro,.specialites,.experience,.temoignages,.cta-resa{padding:80px 0}
}
