
:root {
  --bg-color: #F3E8DD;
  --primary-color: #C56434;        /* terracotta */
  --primary-dark: #9A4521;
  --accent-color: #D9B287;         /* beige-or */
  --text-color: #2B2B2B;
  --heading-font: 'Playfair Display', serif;
  --body-font: 'Inter', system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
}
*{box-sizing:border-box} html{scroll-behavior:smooth}
body{margin:0;font-family:var(--body-font);color:var(--text-color);background:var(--bg-color);line-height:1.6;overflow-x:hidden}
.container{width:min(1100px,92%);margin-inline:auto}
/* Announcement */
#announcement{background:linear-gradient(90deg,var(--primary-dark),var(--primary-color));color:#fff;text-align:center;padding:.5rem 2.5rem;position:relative}
#announcement button{position:absolute;right:.8rem;top:50%;transform:translateY(-50%);background:0;border:0;color:#fff;font-size:1.2rem;cursor:pointer}
/* Header & burger */
header{position:sticky;top:0;z-index:1000;background:rgba(255,255,255,.7);backdrop-filter:blur(10px)}
.nav{display:flex;align-items:center;gap:12px;padding:.7rem 1rem}
.burger{display:flex;flex-direction:column;justify-content:space-between;width:24px;height:18px;cursor:pointer}
.burger span{display:block;height:3px;background:#333;border-radius:2px}
.logo-wrap{display:flex;align-items:center;gap:10px;text-decoration:none}
.logo-wrap img{height:34px;width:auto;display:block}
/* Side menu */
#side-menu{position:fixed;top:0;left:-280px;height:100%;width:270px;background:#fff;box-shadow:10px 0 30px rgba(0,0,0,.08);padding:1.2rem 1rem;transition:left .28s ease;z-index:1100;overflow-y:auto}
#side-menu.open{left:0}
#side-menu .brand{display:flex;align-items:center;gap:10px;margin-bottom:1rem}
#side-menu .brand img{height:42px}
#side-menu ul{list-style:none;padding:0;margin:0}
#side-menu li{margin:.6rem 0}
#side-menu a{text-decoration:none;color:#333;font-weight:600}
#side-menu .reserve-btn{display:block;margin-top:1rem;background:var(--primary-color);color:#fff;text-align:center;padding:.7rem;border-radius:8px;text-decoration:none}
/* Hero slider */
.hero{position:relative;min-height:58vh;display:grid;place-items:center;text-align:center;background:#fff}
/* Sections */
section{padding:3rem 1.3rem}
.section-title{font-family:var(--heading-font);color:var(--primary-dark);font-size:2rem;margin-bottom:.6rem}
/* Menu page */
.menu-tabs{display:flex;gap:.5rem;flex-wrap:wrap;margin-bottom:1rem}
.menu-tabs button{background:#fff;border:1px solid #eee;padding:.65rem 1rem;border-radius:12px;cursor:pointer;font-size:1.05rem}
.menu-tabs button.active{background:var(--primary-color);color:#fff;border-color:transparent}
.search-container input{width:100%;max-width:420px;padding:.55rem .8rem;border:1px solid #ddd;border-radius:10px}
.menu-items{display:grid;gap:1.2rem}
.menu-subsection h3{color:var(--accent-color);margin:.4rem 0;font-family:var(--heading-font)}
.menu-item{display:flex;justify-content:space-between;gap:.5rem;border-bottom:1px dotted #ddd;padding:.2rem 0}
.menu-item .price{color:var(--primary-dark);font-weight:700}
/* Events */
.event-list{display:grid;gap:1.1rem}
.event-item{background:#fff;border:1px solid #eee;border-radius:12px;padding:12px;display:grid;grid-template-columns:86px 1fr;gap:12px}
.event-item img{width:86px;height:86px;object-fit:cover;border-radius:8px}
.event-item .date{color:#777;font-size:.92rem;margin:.25rem 0}
/* Gallery */
.gallery-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:12px}
.gallery-grid img{width:100%;height:160px;object-fit:cover;border-radius:10px;cursor:pointer}
.lightbox{display:none;position:fixed;inset:0;background:rgba(0,0,0,.85);z-index:2000;align-items:center;justify-content:center}
.lightbox img{max-width:92%;max-height:80%;border-radius:10px}
.lightbox button{position:absolute;top:18px;right:18px;font-size:2rem;background:0;border:0;color:#fff;cursor:pointer}
/* Forms */
.btn-primary{background:var(--primary-color);color:#fff;padding:.7rem 1.1rem;border-radius:10px;border:0;cursor:pointer;text-decoration:none}
.btn-primary:hover{background:var(--primary-dark)}
footer{background:#fff;border-top:1px solid #eee;text-align:center;padding:18px 10px;color:#666}
footer a{color:var(--primary-color);text-decoration:none}

/* Marquee (scrolling announcement text) */
#announcement .marquee{overflow:hidden; white-space:nowrap}
#announcement .marquee span{display:inline-block; padding-left:100%; animation:marquee 18s linear infinite}
@keyframes marquee{0%{transform:translateX(0)}100%{transform:translateX(-100%)}}
/* Assure que le formulaire passe AU-DESSUS de tout overlay du header */
.reservation-wrap{
  position: relative;
  z-index: 5;
}

