/* ================== VARIABLES ================== */
:root{
  --bg:#ffffff;
  --text:#121212;
  --muted:#6b6b6b;
  --gold:#c7a35b;          /* doré élégant */
  --line:#e9e9e9;
  --card:#f8f8f8;
  --brand:#1f2937;         /* pour .tab.is-active */
}

/* ================== BASE ================== */
*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{
  font-family:Inter,system-ui,-apple-system,Segoe UI,Roboto,"Helvetica Neue",Arial,sans-serif;
  color:var(--text);
  background:var(--bg);
  line-height:1.6;
}

/* ================== LAYOUT ================== */
.container{width:min(1120px,92%);margin-inline:auto}
.section{padding:64px 0}
.section-alt{background:#fcfcfc}
.center{text-align:center}
.grid-2{display:grid;gap:32px}
@media (min-width:900px){ .grid-2{grid-template-columns:1fr 1fr} }

/* ================== TITRES ================== */
.h2{
  font-family:"Playfair Display",serif;
  font-size:clamp(28px,4vw,40px);
  line-height:1.2;
  margin:0 0 12px;
}
.h3{
  font-family:"Playfair Display",serif;
  font-size:clamp(18px,2.4vw,24px);
  margin:0;
}

/* ======== HEADER + NAV (version unique et propre) ======== */

/* ===== Header / Nav ===== */
.site-header{
  --header-h: 64px;
  position: sticky; top: 0; z-index: 2000;
  background: rgba(255,255,255,.92);
  backdrop-filter: saturate(1.2) blur(8px);
  border-bottom: 1px solid var(--line);
}
.header-inner{
  display:flex; align-items:center; justify-content:space-between;
  padding-block:12px;
}

.brand{ display:flex; align-items:center; gap:10px; text-decoration:none; color:inherit; }
.logo{ width:42px; height:42px; object-fit:contain; border-radius:50%; }
.brand-text{ font-family:"Playfair Display",serif; font-weight:700; font-size:22px; color:#1a1a1a; }

/* Burger – style unique */
.nav-toggle{
  appearance:none; background:transparent; border:0; padding:6px;
  width:44px; height:44px; display:inline-flex; flex-direction:column; justify-content:center; gap:5px;
  border-radius:10px; cursor:pointer;
}
.nav-toggle .bar{ width:22px; height:2px; background:#111; border-radius:2px; display:block; }

/* Menu de base (mobile: fermé) */
.nav-menu{
  display:none;
  list-style:none; margin:0; padding:0;
}

/* Backdrop derrière le menu */
.nav-backdrop{
  position:fixed; inset:0; background:rgba(0,0,0,.35);
  backdrop-filter: blur(2px);
  opacity:0; pointer-events:none; transition:opacity .2s;
  z-index: 2100; /* au-dessus du hero/overlay */
}
.nav-backdrop.is-visible{ opacity:1; pointer-events:auto; }

/* Menu ouvert (mobile) */
.nav-menu.is-open{
  position:fixed; left:0; right:0; top:var(--header-h); bottom:0;
  display:flex; flex-direction:column; gap:16px;
  padding:18px 20px 28px;
  background:#fff; border-top:1px solid var(--line);
  z-index: 2200;  /* au-dessus du backdrop et du hero */
}
.nav-menu a{
  display:block; padding:12px 10px; font-weight:600; color:var(--text); text-decoration:none; border-radius:10px;
}
.nav-menu a:hover{ background:rgba(0,0,0,.04); }

/* Bloque le scroll quand le menu est ouvert */
html.noscroll, body.noscroll{ overflow:hidden; }

/* Desktop : menu horizontal et on cache le burger */
@media (min-width: 900px){
  .nav-toggle{ display:none; }
  .nav-menu{
    display:flex !important; position:static; background:transparent;
    padding:0; gap:22px; flex-direction:row; border:0; box-shadow:none;
    z-index:auto;
  }
  .nav-backdrop{ display:none !important; }
}
/* Effet souligné doré au survol — desktop uniquement */
@media (min-width: 900px){
  .nav-menu a{
    position: relative;
    padding: 8px 10px;
  }
  .nav-menu a::after{
    content:"";
    position:absolute;
    left:10px; right:10px; bottom:-6px;
    height:2px;
    background: var(--gold);
    border-radius: 2px;
    transform: scaleX(0);
    transform-origin: left;
    transition: transform .25s ease;
  }
  /* au survol / focus clavier */
  .nav-menu a:is(:hover,:focus-visible)::after{
    transform: scaleX(1);
  }
  /* état actif (si tu ajoutes la classe .is-active sur le lien courant) */
  .nav-menu a.is-active::after{
    transform: scaleX(1);
  }
}


/* ================== BOUTONS ================== */
.btn{
  display:inline-flex; align-items:center; justify-content:center;
  padding:12px 18px; border-radius:999px; border:1px solid var(--text);
  text-decoration:none; color:var(--text); font-weight:600; transition:.2s;
}
.btn:hover{ transform:translateY(-1px); }
.btn-primary{
  background:var(--text); color:#fff; border-color:var(--text);
  box-shadow:0 8px 20px rgba(0,0,0,.14);
}
.btn-primary:hover{ opacity:.92; }
.btn-ghost {
    border-color: var(--gold);
    color: #ffffff;
}

.btn-ghost:hover{ background:var(--gold); color:#ffffff; border-color:var(--gold); }

/* ================== HERO ================== */
.hero{ position:relative; min-height:64svh; display:grid; place-items:center; overflow:hidden; }
.hero-media{
  position:absolute; inset:0;
  background:url('assets/hero.jpg') center/cover no-repeat;
  transform:scale(1.02);
}
.hero-overlay{
  position:absolute; inset:0;
  background:linear-gradient(180deg,rgba(0,0,0,.35),rgba(0,0,0,.45));
}
.hero-content{ position:relative; color:#fff; text-align:center; }
.hero-title{
  font-family:"Playfair Display",serif; font-weight:700;
  font-size:clamp(34px,6vw,64px); margin:0 0 8px;
}
.hero-title span{ color:var(--gold); }
.hero-sub{ opacity:.95; margin:0 0 18px; }

/* ===== Variante HERO — Glass ===== */
.hero--glass .hero-content{
  background: rgba(13,13,13,.35);
  backdrop-filter: blur(8px) saturate(120%);
  -webkit-backdrop-filter: blur(8px) saturate(120%);
  border: 1px solid rgba(255,255,255,.18);
  border-radius: 18px;
  padding: clamp(28px, 4.5vw, 40px) clamp(22px, 4vw, 36px);
  box-shadow: 0 12px 40px rgba(0,0,0,.35);
}
.hero--glass .hero-overlay{
  background: rgba(0,0,0,.25);
}

/* Option desktop : assombrir un peu le fond pour plus de contraste */
@media (min-width: 992px){
  .hero--glass .hero-overlay{ background: rgba(0,0,0,.35); }
  .hero--glass .hero-media{ filter: brightness(.6) saturate(1.05) contrast(1.1); }
}


/* ================== CARTES ================== */
.card{
  background:var(--card); border:1px solid var(--line); border-radius:14px;
  overflow:hidden; box-shadow:0 8px 24px rgba(0,0,0,.06);
}
.card img{ display:block; width:100%; height:auto; }

/* ================== ABOUT ================== */
.hours{ margin-top:18px; padding:16px; }
.hours-list{ margin:8px 0 0 20px; }

/* ================== MENU GRID ================== */
.menu-grid{ display:grid; gap:20px; margin-top:18px; }
@media (min-width:700px){ .menu-grid{ grid-template-columns:repeat(2,1fr); } }
@media (min-width:1100px){ .menu-grid{ grid-template-columns:repeat(4,1fr); } }
.menu-item-body{ padding:14px; }
.menu-item-head{ display:flex; align-items:center; justify-content:space-between; margin-bottom:6px; }
.price{ font-weight:700; color:var(--gold); }

/* ================== FORM ================== */
.form{ padding:18px; }
.form-row{ display:flex; flex-direction:column; gap:6px; margin-bottom:12px; }
.form-row-inline{ display:grid; gap:12px; }
@media (min-width:640px){ .form-row-inline{ grid-template-columns:1fr 1fr 1fr; } }
label{ font-size:.9rem; color:#333; }
input,textarea{
  width:100%; padding:12px 14px; border:1px solid var(--line); border-radius:10px; background:#fff; font:inherit;
}
input:focus,textarea:focus{ outline:2px solid var(--gold); border-color:transparent; }
.form-msg{ margin-top:10px; font-weight:600; }

/* Spécifique mobile form */
@media (max-width:640px){
  .form-row-inline{ display:block; }
  .form-row-inline .form-row{ width:100%; margin-right:0; }
  .form-row-inline .form-row + .form-row{ margin-top:12px; }
}
.form input[type="text"],
.form input[type="tel"],
.form input[type="email"],
.form input[type="number"],
.form input[type="date"],
.form input[type="time"],
.form textarea{
  font-size:16px; height:52px; padding:12px 14px;  /* évite zoom iOS */
}
.form input[type="date"],
.form input[type="time"]{ -webkit-appearance:none; appearance:none; line-height:1.2; }

#reservation{ scroll-margin-top:90px; }

/* Optionnel : rétrécir le badge reCAPTCHA sur mobile */
@media (max-width:640px){
  .grecaptcha-badge{ transform:scale(0.9); transform-origin:bottom right; right:8px !important; bottom:8px !important; }
}

/* ================== GALERIE ================== */
.gallery{ display:grid; gap:10px; margin-top:16px; }
.gallery img{ width:100%; height:230px; object-fit:cover; border-radius:12px; }
@media (min-width:800px){ .gallery{ grid-template-columns:repeat(3,1fr); } }

/* ================== MAP ================== */
.map iframe{ width:100%; height:340px; border:0; border-radius:12px; }

/* ================== FOOTER ================== */
.site-footer{ border-top:1px solid var(--line); padding:24px 0; background:#fff; }
.footer-inner{ display:flex; align-items:center; justify-content:space-between; gap:12px; }
.to-top{ text-decoration:none; color:var(--text); border:1px solid var(--line); padding:4px 10px; border-radius:999px; }

/* ================== UTILS ================== */
.section .card img{ aspect-ratio:16/10; object-fit:cover; }
.about-photo img,.reserve-photo img{ height:100%; object-fit:cover; }

/* ================== ONGLET MENU ================== */
.tabs{ margin-top:10px; }
.tabs-list{
  display:flex; gap:10px; justify-content:center; flex-wrap:wrap;
  margin:0 0 16px; border-bottom:1px solid rgba(0,0,0,.08); padding-bottom:10px;
}
.tab{
  appearance:none; border:1px solid rgba(0,0,0,.1);
  background:#fff; padding:15px 20px; border-radius:999px;
  font-weight:600; cursor:pointer; transition:all .18s ease;
}
.tab:hover{ transform:translateY(-1px); box-shadow:0 6px 16px rgba(0,0,0,.06); }
.tab.is-active{ background:var(--brand); color:#fff; border-color:transparent; }
.tab-panel{ animation: tabFade .22s ease; }
@keyframes tabFade{ from{opacity:0; transform:translateY(6px)} to{opacity:1; transform:translateY(0)} }

/* Listes nom + points + prix */
.menu-list{ list-style:none; padding:0; margin:8px 0 20px; display:flex; flex-direction:column; gap:8px; }
.menu-row{ display:flex; align-items:baseline; gap:12px; flex-wrap:nowrap; line-height:1.4; }
.menu-row .name{ font-weight:600; }
.menu-row .sub{ color:#666; font-size:.95rem; padding-left:0; }
.menu-row .price{ margin-left:auto; white-space:nowrap; font-weight:700; }
.menu-row .dots{
  flex:1 1 auto; align-self:stretch;
  background-image: radial-gradient(currentColor 1px, transparent 1px);
  background-size: 6px 6px; background-repeat: repeat-x; background-position: left 1.05em;
  opacity:.35;
}

/* Titres de groupe */
.menu-group-title{
  position:relative; margin:34px 0 12px; font-size:1.15rem; font-weight:800; letter-spacing:.5px;
  text-transform:uppercase; color:#a47e3c; border-bottom:2px solid rgba(164,126,60,0.25); padding-bottom:4px;
}

/* Deux colonnes pizzeria */
.two-col{ display:grid; grid-template-columns:repeat(2,minmax(0,1fr)); gap:24px; }
@media (max-width:900px){ .two-col{ grid-template-columns:1fr; } }
@media (max-width:600px){
  .menu-row{ gap:10px; }
  .menu-row .dots{ background-size:5px 5px; }
}

/* Optionnel : rétrécir le badge reCAPTCHA sur mobile */

