:root{
  --green:#2f4f3e;
  --green-dark:#233a2d;
  --green-soft:#789381;
  --cream:#f6f3ee;
  --paper:#fffdf9;
  --accent:#c7a36b;
  --accent-soft:#eadfce;
  --text:#1a1a1a;
  --muted:#6b6b6b;
  --line:#e8e3dc;
  --shadow:0 16px 40px rgba(35,58,45,.08);
}

*{box-sizing:border-box}

.product-card{position:relative}
.product-card::after{
  pointer-events:none;
  content:'';
  position:absolute;
  inset:0;
  border-radius:22px;
  background:linear-gradient(180deg,transparent,rgba(0,0,0,0.04));
  opacity:0;
  transition:.2s;
}
.product-card:hover::after{opacity:1}

.btn-primary{position:relative;overflow:hidden}
.btn-primary::after{
  pointer-events:none;
  content:'';
  position:absolute;
  inset:0;
  background:linear-gradient(120deg,transparent,rgba(255, 255, 255, 0.4),transparent);
  opacity:0;
  transition:.3s;
}
.btn-primary:hover::after{opacity:1}

.modal-panel{animation:fadeIn .25s ease}
@keyframes fadeIn{
  from{opacity:0;transform:translateY(10px)}
  to{opacity:1;transform:translateY(0)}
}

.option-item input:checked + span{
  font-weight:700;
  color:var(--green-dark);
}
.option-item:has(input:checked){
  border-color:var(--green);
  background:#f1ede6;
}

.cart{backdrop-filter:blur(8px)}
.cart-fab{transition:.2s}
.cart-fab:hover{transform:scale(1.05)}

html{scroll-behavior:smooth}
body{margin:0;font-family:'Manrope',Arial,sans-serif;background:linear-gradient(180deg,#f8f5ef 0%,#f4efe7 100%);color:var(--text)}
a{text-decoration:none;color:inherit}
button,input{font:inherit}
.container{width:min(1160px,100%);margin:auto;padding:0 18px}

.topbar{display:flex;justify-content:space-between;align-items:center;padding:16px 24px;background:rgba(255,253,249,.88);backdrop-filter:blur(10px);border-bottom:1px solid var(--line);position:sticky;top:0;z-index:20}
.brand-wrap{display:flex;align-items:center;gap:12px}
.logo{
  width:48px;
  height:48px;
  border-radius:12px;
  overflow:hidden;
  display:flex;
  align-items:center;
  justify-content:center;
  background:#fff;
  box-shadow:0 6px 18px rgba(0,0,0,.15);
}

.logo img{
  width:100%;
  height:100%;
  object-fit:cover;
}
.logo{
  width:52px;
  height:52px;
  border-radius:50%;
}
.brand{font-family:'DM Serif Display',serif;font-size:24px;line-height:1}
.brand-sub{font-size:12px;color:var(--muted);margin-top:2px}
.nav{display:flex;align-items:center;gap:18px;flex-wrap:wrap}
.nav a{font-size:14px;color:var(--green);font-weight:700}
.nav-call{
  background:linear-gradient(135deg,#2f4f3e,#3f6b54);
  color:#fff;
  padding:12px 20px;
  border-radius:999px;
  font-weight:800;
  font-size:14px;
  display:flex;
  align-items:center;
  gap:8px;
  box-shadow:0 10px 24px rgba(47,79,62,.25);
  transition:.2s;
}

.nav-call:hover{
  transform:translateY(-2px);
  box-shadow:0 14px 30px rgba(47,79,62,.35);
}

.hero{padding:76px 0 54px;background:linear-gradient(rgba(24,36,30,.58),rgba(24,36,30,.68)),url('../img/hero.jpg');background-size:cover;background-position:center;color:#fff;position:relative}
.hero-grid{
  display:grid;
  grid-template-columns:220px 1fr 260px;
  gap:20px;
  align-items:center;
}
.hero-center{
  text-align:center;
  max-width:780px;
  margin:auto;
  padding:46px 34px;
  border-radius:30px;
  background:linear-gradient(180deg,rgba(255,255,255,.10),rgba(255,255,255,.04));
  border:1px solid rgba(255,255,255,.08);
  box-shadow:0 14px 40px rgba(0,0,0,.12);
}
.hero h1{font-family:'DM Serif Display',serif;font-size:56px;line-height:.98;margin:12px 0 12px}
.hero p{color:#ece6de;font-size:16px;max-width:560px;margin:0 auto}
.pill,.section-kicker{display:inline-flex;align-items:center;gap:8px;padding:8px 14px;border-radius:999px;font-size:12px;font-weight:800;letter-spacing:.02em}
.pill{background:rgba(255,255,255,.14);border:1px solid rgba(255,255,255,.1)}
.section-kicker{background:#f3ecdf;color:var(--green)}
.hero-actions{display:flex;justify-content:center;gap:12px;flex-wrap:wrap;margin-top:24px}

.mini-card,.card,.product-card,.cart-item{background:var(--paper);border:1px solid var(--line);box-shadow:var(--shadow)}
.mini-card{
  padding:22px 18px;
  border-radius:24px;
  background:rgba(255,253,249,.92);
  min-height:120px;
  display:flex;
  flex-direction:column;
  justify-content:center;
}
.mini-title{font-weight:800;color:var(--green);margin-bottom:12px}
.social-box{margin-top:10px;padding:12px 14px;border-radius:16px;border:1px dashed #d9ccb9;background:#fff;text-align:center;font-weight:700;color:var(--green)}

.btn{display:inline-flex;align-items:center;justify-content:center;padding:12px 18px;border-radius:999px;font-weight:700;font-size:14px;border:none;cursor:pointer;transition:transform .18s ease, box-shadow .18s ease;position:relative;z-index:4}
.btn:hover{transform:translateY(-1px)}
.btn-primary{background:var(--accent);color:#1a1a1a;box-shadow:0 10px 24px rgba(199,163,107,.24)}
.btn-secondary{background:#fff;color:var(--green);box-shadow:0 10px 24px rgba(255,255,255,.12)}
.btn-ghost{background:transparent;color:#fff;border:1px solid rgba(255,255,255,.22)}
.btn-block{width:100%}

.showcase{
  display:grid;
  grid-template-columns:260px 1fr;
  gap:16px;
  margin-top:-12px;
  position:relative;
  z-index:2;
}
.card{border-radius:26px;padding:24px}
.showcase-item{display:flex;gap:16px;align-items:center}
.fake-img,.best-thumb,.product-thumb,.gallery-item,.fake-room{display:grid;place-items:center;color:#fff;font-weight:800;background:linear-gradient(135deg,var(--green-soft),var(--accent));position:relative;overflow:hidden}
.fake-img::after,.best-thumb::after,.product-thumb::after,.gallery-item::after,.fake-room::after{content:'';position:absolute;inset:auto auto -22px -22px;width:88px;height:88px;border-radius:50%;background:rgba(255,255,255,.12)}
.fake-img{min-height:120px;border-radius:20px}
.best-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:14px;margin-top:14px}
.best-item{display:flex;gap:12px;padding:14px;border:1px solid var(--line);border-radius:20px;background:#fff}
.best-thumb{width:72px;height:72px;border-radius:18px;font-size:12px;text-align:center;padding:0}
.best-item h4{margin:0 0 4px;font-size:16px}
.best-item p{margin:0;color:var(--muted);font-size:13px;line-height:1.35}

.menu-section{padding:66px 0 24px}
.section-head{display:flex;justify-content:space-between;align-items:end;gap:18px;flex-wrap:wrap;margin-bottom:22px}
.section-head h2{font-family:'DM Serif Display',serif;font-size:42px;margin:8px 0 8px;line-height:1}
.section-head p{margin:0;color:var(--muted)}
.menu-note{background:#fff;padding:13px 16px;border-radius:18px;border:1px solid var(--line);max-width:420px;color:var(--muted)}
.category-buttons{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:14px;margin-bottom:26px}
.category-btn{position:relative;border:none;padding:18px 20px;border-radius:22px;background:linear-gradient(180deg,#fff,#fbf7f1);color:var(--green);cursor:pointer;border:1px solid var(--line);font-weight:800;transition:.18s;text-align:left;min-height:78px;display:flex;align-items:flex-end;box-shadow:0 10px 24px rgba(47,79,62,.06)}
.category-btn::before{content:'';position:absolute;inset:0 0 auto 0;height:6px;border-radius:22px 22px 0 0;background:linear-gradient(90deg,var(--accent),var(--green-soft));opacity:.9}
.category-btn::after{content:'Ouvrir';position:absolute;top:14px;right:16px;font-size:11px;letter-spacing:.05em;text-transform:uppercase;color:var(--muted);font-weight:700}
.category-btn.active,.category-btn:hover{background:linear-gradient(135deg,var(--green),#3b624d);color:#fff;box-shadow:0 16px 32px rgba(47,79,62,.16);transform:translateY(-2px)}
.category-btn.active::after,.category-btn:hover::after{color:#f5ead7}
.category-panel{display:none}
.category-panel.active{display:block}
.product-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.product-card{border-radius:22px;padding:16px;transition:.2s}
.product-card:hover{transform:translateY(-6px);box-shadow:0 16px 32px rgba(0,0,0,.08)}
.product-thumb{
  height:126px;
  border-radius:14px;
  margin-bottom:12px;
  padding:0;
}

.product-thumb:before{
  display:none;
}

.product-thumb.media-frame > span{
  display:none !important;
}
.product-card h3{margin:0 0 6px;font-size:18px}
.product-card p{margin:0;color:var(--muted);font-size:14px;line-height:1.45;min-height:60px}
.product-footer{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-top:14px;position:relative;z-index:3}
.price{font-weight:800;color:var(--green);font-size:18px}

.about,.gallery,.contact{padding:36px 0 60px}
.about{display:grid;grid-template-columns:1.05fr .95fr;gap:20px;align-items:stretch}
.about h2,.contact h2{font-family:'DM Serif Display',serif;font-size:38px;line-height:1;margin:10px 0 14px}
.fake-room{min-height:280px;border-radius:26px;font-size:28px}
.gallery-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}
.gallery-item{min-height:180px;border-radius:22px;padding:0}
.contact.card{display:grid;grid-template-columns:1fr auto;gap:18px;align-items:center}
.contact-actions{display:flex;gap:12px;flex-wrap:wrap}

.cart{position:fixed;right:0;top:0;width:340px;height:100%;background:#fffdf9;border-left:1px solid var(--line);padding:16px;display:flex;flex-direction:column;transform:translateX(100%);transition:transform .25s ease;z-index:40;box-shadow:-12px 0 30px rgba(0,0,0,.08)}
.cart.open{transform:translateX(0)}
.cart-head,.cart-total-line,.cart-row,.modal-head,.modal-actions{display:flex;justify-content:space-between;align-items:center;gap:12px}
.cart-items{flex:1;overflow:auto;padding:10px 0;display:flex;flex-direction:column;gap:10px}
.cart-item{padding:14px;border-radius:18px}
.cart-item h4{margin:0 0 6px}
.cart-item p{margin:0;color:var(--muted);font-size:13px;line-height:1.4}
.cart-footer{border-top:1px solid var(--line);padding-top:12px;display:flex;flex-direction:column;gap:10px}
.cart-fab{position:fixed;bottom:20px;right:20px;background:var(--green);color:#fff;padding:14px 16px;border-radius:30px;border:none;cursor:pointer;z-index:30;box-shadow:0 10px 24px rgba(47,79,62,.24)}
.icon-btn{width:38px;height:38px;border-radius:50%;border:1px solid var(--line);background:#fff;cursor:pointer}

.modal.hidden{display:none}
.modal{position:fixed;inset:0;z-index:60}
.modal-backdrop{position:absolute;inset:0;background:rgba(19,26,22,.45)}
.modal-panel{position:relative;background:#fffdf9;width:min(720px,calc(100% - 24px));margin:22px auto;padding:22px;border-radius:28px;max-height:calc(100vh - 44px);overflow:auto;box-shadow:0 30px 80px rgba(0,0,0,.18)}
.modal-desc{color:var(--muted);margin:10px 0 0}
.option-group{
  padding:18px;
  border:1px solid var(--line);
  border-radius:20px;
  background:#fff;
  margin-top:16px;
  box-shadow:0 6px 18px rgba(0,0,0,.04);
}
.option-group h4{
  margin:0 0 12px;
  font-size:15px;
  display:flex;
  justify-content:space-between;
  align-items:center;
}
.option-required{
  font-size:11px;
  color:#fff;
  background:var(--green);
  padding:3px 8px;
  border-radius:999px;
}
.option-list{
  display:grid;
  grid-template-columns:repeat(2,1fr);
  gap:10px;
}
.option-item{
  display:flex;
  gap:10px;
  align-items:center;
  padding:10px 12px;
  border:1px solid var(--line);
  border-radius:14px;
  background:#fcfaf5;
  cursor:pointer;
  transition:.15s;
}
.option-item:hover{
  border-color:var(--green);
  background:#f4efe7;
}
.option-item input{accent-color:var(--green)}
.small-muted,.empty{color:var(--muted)}
.empty{text-align:center;padding:24px 8px}

/* SUPPORT IMAGES */
.media-frame{
  position:relative;
  overflow:hidden;
}
.media-frame img{
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
}
.media-frame > span{
  position:absolute;
  inset:0;
  display:grid;
  place-items:center;
  text-align:center;
  padding:10px;
  color:#fff;
  font-weight:800;
  z-index:1;
  background:linear-gradient(180deg,rgba(0,0,0,.05),rgba(0,0,0,.26));
}
.media-frame.media-missing > span{
  background:transparent;
}
.media-square{height:120px}
.media-wide{width:140px;min-width:140px;height:120px}
.media-room{padding:0}
.media-modal{
  margin-top:14px;
  height:220px;
  border-radius:20px;
  background:linear-gradient(135deg,var(--green-soft),var(--accent));
}
.media-modal > span{
  display:grid;
}
#modalProductImage{
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
}
#modalProductFallback{
  position:absolute;
  inset:0;
  display:none;
  place-items:center;
  font-weight:800;
  color:#fff;
}
.best-thumb img,
.product-thumb img,
.fake-img img,
.fake-room img,
.gallery-item img,
.social-box img{
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
}
.product-thumb{
  height:160px;
}

.product-thumb img{
  object-fit:cover;
  object-position:center 40%;
}


@media(max-width:980px){
  .hero-grid,.showcase,.about,.contact.card{grid-template-columns:1fr}
  .product-grid,.gallery-grid,.category-buttons{grid-template-columns:repeat(2,1fr)}
  .media-wide{width:100%;min-width:0}
}
@media(max-width:800px){
  .topbar{padding:14px 16px;align-items:flex-start;gap:12px;flex-direction:column}
  .hero h1{font-size:42px}
  .product-grid,.gallery-grid,.option-list,.category-buttons{grid-template-columns:1fr}
  .cart{width:min(100%,360px)}
}
.btn.btn-primary{
  background:#012f09;
  color:#fff;
}
/* Texte des horaires */
.mini-card p{
  color:#060606;
  font-weight:600;
}

/* Ligne des heures → mise en avant */
.mini-card p:nth-child(3){
  color:#0b0b0b;
  font-weight:800;
}

/* Ligne "fermé" → rouge */
.mini-card p:last-child{
  color:#c0392b;
  font-weight:700;
}

/* Titre Horaires */
.mini-title{
  color:#0b0b0b;
}
/* ===== FACEBOOK CARD ===== */
.fb-card{
  display:block;
  border-radius:20px;
  overflow:hidden;
  background:#fff;
  border:1px solid var(--line);
  box-shadow:var(--shadow);
  transition:.25s;
}

.fb-card:hover{
  transform:translateY(-4px);
  box-shadow:0 20px 40px rgba(0,0,0,.12);
}

/* image */
.fb-image{
  height:120px;
  overflow:hidden;
}

.fb-image img{
  width:100%;
  height:100%;
  object-fit:cover;
}

/* contenu */
.fb-content{
  padding:12px;
}

.fb-title{
  font-weight:800;
  color:#1877f2; /* bleu Facebook */
  font-size:14px;
}

.fb-text{
  font-size:13px;
  color:var(--muted);
}




/* effet carte */
.fb-live:hover{
  transform:translateY(-3px);
  transition:.2s;
  box-shadow:0 20px 40px rgba(0,0,0,.12);
}

/* iframe */

.hero-grid > .mini-card:first-child{
  max-width:220px;
  width:100%;
}
.hero-grid > .mini-card:first-child p{
  line-height:1.35;
  word-break:normal;
}

.hero-grid > .mini-card:first-child{
  padding:24px 20px;
}
.hero-grid{
  display:grid;
  grid-template-columns:240px 1fr 260px;
  gap:20px;
  align-items:center;
}

.hero-grid > .mini-card:first-child{
  max-width:240px;
  width:100%;
  padding:24px 20px;
}

.hero-grid > .mini-card:first-child p{
  line-height:1.35;
  word-break:normal;
}

.hero-grid > .mini-card:last-child{
  max-width:260px;
  margin-left:auto;
}

.showcase > .card:first-child{
  min-height:160px;
}

.best-grid{
  display:grid;
  grid-template-columns:repeat(2,1fr);
  gap:14px;
  margin-top:14px;
}

.fb-live{
  padding:0;
  overflow:hidden;
  border-radius:18px;
  background:#fff;
  border:1px solid var(--line);
  box-shadow:var(--shadow);
  height:340px;
}

.fb-live:hover{
  transform:translateY(-3px);
  transition:.2s;
  box-shadow:0 20px 40px rgba(0,0,0,.12);
}

.fb-live iframe{
  display:block;
  border:0;
  transform:scale(0.82);
  transform-origin:top left;
  width:122%;
  height:410px;
}
.contact h2{
  font-family:'Playfair Display', serif;
  font-size:42px;
  letter-spacing:0.5px;
}

.contact p{
  font-family:'Manrope', sans-serif;
  font-size:15px;
  line-height:1.6;
}
.contact h2{
  font-family:'DM Serif Display', serif;
  font-size:40px;
}

.contact{
  font-size:15px;
  letter-spacing:0.2px;
}
.contact{
  background:#fffdf9;
}

.contact strong{
  color:var(--green);
}

.nav-call{
  background:#012f09;
  color:#fff;
  padding:12px 22px;
  border-radius:999px;
  font-weight:800;
  font-size:15px;
  letter-spacing:0.3px;
  box-shadow:0 12px 28px rgba(0,0,0,.25);
}

.nav-call:hover{
  background:#014d12;
}
.hero-grid > .mini-card:first-child{
  max-width:240px;
  width:100%;
  padding:24px 20px;

  display:flex;
  flex-direction:column;
  justify-content:center;
  align-items:center;   /* 🔥 centre horizontal */
  text-align:center;    /* 🔥 centre texte */
}
.bloc-footer{
  position:relative;
  margin-top:30px;
  padding-bottom:50px; /* espace pour le bouton */
}

.btn-appeler{
  position:absolute;
  right:0;
  bottom:0;

  background:#012f09;
  color:#fff;
  padding:10px 18px;
  border-radius:20px;
  text-decoration:none;
  font-weight:600;
}
.about .card::before{
  content:'';
  position:absolute;
  top:0;
  left:0;
  width:60px;
  height:5px;
  background:var(--accent);
  border-radius:0 0 8px 0;
}