  :root{
    --cream:#FBF3E4;
    --cream-deep:#F4E8D0;
    --ink:#27190E;
    --harissa:#C13A17;
    --harissa-deep:#9E2E10;
    --saffron:#F0B431;
    --citron:#F6E27A;
    --olive:#42511F;
    --olive-deep:#2C3715;
    --display:"Bricolage Grotesque", sans-serif;
    --body:"Hanken Grotesk", sans-serif;
  }
  *{ margin:0; padding:0; box-sizing:border-box; }
  html{ scroll-behavior:smooth; }
  body{
    font-family:var(--body);
    background:var(--cream);
    color:var(--ink);
    font-size:17px;
    line-height:1.55;
    -webkit-font-smoothing:antialiased;
  }
  img{ display:block; max-width:100%; height:auto; }
  a{ color:inherit; }

  .wrap{ width:min(1120px, 100% - 40px); margin-inline:auto; }

  /* ---------- header ---------- */
  header{
    position:sticky; top:0; z-index:50;
    background:color-mix(in oklab, var(--cream) 92%, transparent);
    backdrop-filter:blur(8px);
    border-bottom:1.5px solid var(--ink);
  }
  .header-in{
    display:flex; align-items:center; justify-content:space-between;
    gap:16px; padding:12px 0;
  }
  .wordmark{
    font-family:var(--display); font-weight:800; font-size:21px;
    letter-spacing:.02em; text-decoration:none; line-height:1;
  }
  .wordmark small{
    display:block; font-family:var(--body); font-weight:600;
    font-size:10.5px; letter-spacing:.16em; text-transform:uppercase;
    color:var(--harissa); margin-top:3px;
  }
  .header-nav{ display:none; gap:28px; }
  .header-nav a{
    text-decoration:none; font-weight:600; font-size:15px;
  }
  .header-nav a:hover{ color:var(--harissa); }
  .btn{
    display:inline-flex; align-items:center; justify-content:center; gap:9px;
    font-family:var(--display); font-weight:700; font-size:16px;
    text-decoration:none; border:1.5px solid var(--ink);
    border-radius:999px; padding:11px 20px;
    transition:transform .15s ease, box-shadow .15s ease;
  }
  .btn-red{
    background:var(--harissa); color:var(--cream);
    box-shadow:3px 3px 0 var(--ink);
  }
  .btn-red:hover{ transform:translate(-1px,-1px); box-shadow:5px 5px 0 var(--ink); }
  .btn-ghost{ background:transparent; color:var(--ink); }
  .btn-ghost:hover{ background:var(--cream-deep); }
  .header-call{ padding:9px 16px; font-size:15px; }

  /* ---------- hero ---------- */
  .hero{ padding:44px 0 56px; overflow:clip; }
  .hero-grid{ display:grid; gap:40px; }
  .hero-rating{
    display:inline-flex; align-items:center; gap:10px;
    background:#fff; border:1.5px solid var(--ink); border-radius:999px;
    padding:7px 15px 7px 11px; font-weight:700; font-size:14.5px;
    box-shadow:2px 2px 0 var(--ink); width:max-content;
  }
  .hero-rating .stars{ color:var(--harissa); letter-spacing:1px; font-size:13px; }
  .hero-rating span b{ font-size:15px; }
  .hero-rating small{ font-weight:600; color:#7A6A57; font-size:13px; }
  h1{
    font-family:var(--display); font-weight:800;
    font-size:clamp(40px, 9.5vw, 76px);
    line-height:1.02; letter-spacing:-.015em;
    margin:22px 0 18px; text-wrap:balance;
  }
  h1 .accent{ color:var(--harissa); font-style:italic; font-weight:700; }
  .hero-sub{
    font-size:clamp(17px,2vw,19px); max-width:46ch; text-wrap:pretty;
    color:#4A3A29;
  }
  .hero-sub b{ color:var(--ink); }
  .hero-ctas{ display:flex; flex-wrap:wrap; gap:13px; margin-top:28px; }
  .hero-facts{
    display:flex; flex-wrap:wrap; gap:8px 18px; margin-top:26px;
    font-weight:600; font-size:14.5px; color:#5B4A36;
  }
  .hero-facts li{ list-style:none; display:flex; align-items:center; gap:7px; }
  .hero-facts .dot{ width:7px; height:7px; border-radius:50%; background:var(--saffron); border:1px solid var(--ink); flex:none; }

  .hero-photos{ position:relative; min-height:430px; }
  .ph{
    position:absolute; border:2px solid var(--ink); border-radius:14px;
    overflow:hidden; background:#fff; box-shadow:6px 6px 0 rgba(39,25,14,.18);
  }
  .ph img{ width:100%; height:100%; object-fit:cover; }
  .ph-front{ width:62%; aspect-ratio:3/4; left:0; top:8%; transform:rotate(-3deg); z-index:2; }
  .ph-food{ width:52%; aspect-ratio:3/4; right:0; top:0; transform:rotate(2.5deg); z-index:1; }
  .ph-caption{
    position:absolute; left:50%; bottom:-2%; transform:translateX(-50%) rotate(-1.5deg);
    background:var(--saffron); border:1.5px solid var(--ink); border-radius:10px;
    font-family:var(--display); font-weight:700; font-size:14px;
    padding:8px 14px; z-index:3; white-space:nowrap;
    box-shadow:3px 3px 0 var(--ink);
  }

  /* ---------- marquee ---------- */
  .marquee{
    background:var(--harissa); color:var(--cream);
    border-block:2px solid var(--ink);
    overflow:hidden; padding:13px 0;
  }
  .marquee-track{
    display:flex; gap:0; width:max-content;
    animation:scroll 26s linear infinite;
  }
  @media (prefers-reduced-motion: reduce){ .marquee-track{ animation:none; } }
  .marquee-track span{
    font-family:var(--display); font-weight:700; font-size:16px;
    letter-spacing:.08em; text-transform:uppercase; white-space:nowrap;
    padding-right:14px;
  }
  .marquee-track span::after{ content:"✶"; color:var(--saffron); padding-left:14px; }
  @keyframes scroll{ to{ transform:translateX(-50%); } }

  /* ---------- concept ---------- */
  .concept{ background:var(--olive-deep); color:var(--cream); padding:72px 0 80px; }
  .kicker{
    font-weight:700; font-size:13px; letter-spacing:.2em; text-transform:uppercase;
    display:flex; align-items:center; gap:12px;
  }
  .kicker::before{ content:""; width:26px; height:2px; background:currentColor; }
  .concept .kicker{ color:var(--saffron); }
  h2{
    font-family:var(--display); font-weight:800;
    font-size:clamp(31px,5.5vw,50px); line-height:1.06;
    letter-spacing:-.01em; margin:16px 0 14px; text-wrap:balance;
  }
  .concept-lede{ max-width:54ch; font-size:18px; color:#E4DDC4; text-wrap:pretty; }
  .concept-lede b{ color:var(--citron); }
  .concept-grid{ display:grid; gap:14px; margin-top:42px; }
  .concept-card{
    border:1.5px solid #6B7A3E; border-radius:16px; padding:24px 22px;
    background:color-mix(in oklab, var(--olive) 45%, transparent);
  }
  .concept-card .num{
    font-family:var(--display); font-weight:800; font-size:15px;
    color:var(--saffron); letter-spacing:.06em;
  }
  .concept-card h3{
    font-family:var(--display); font-weight:700; font-size:22px;
    margin:10px 0 8px; line-height:1.15;
  }
  .concept-card p{ font-size:15.5px; color:#D8D2B8; text-wrap:pretty; }
  .concept-photos{
    display:grid; grid-template-columns:1fr 1fr; gap:14px; margin-top:42px;
  }
  .concept-photos figure{
    border:2px solid var(--ink); border-radius:14px; overflow:hidden;
    aspect-ratio:4/5; background:#1E2510;
  }
  .concept-photos img{ width:100%; height:100%; object-fit:cover; }

  /* ---------- carte ---------- */
  .carte{ padding:72px 0 80px; }
  .carte-head{ display:grid; gap:10px; margin-bottom:40px; }
  .carte .kicker{ color:var(--harissa); }
  .carte-head p{ max-width:52ch; color:#4A3A29; text-wrap:pretty; }
  .price-pill{
    display:inline-flex; align-items:center; gap:9px;
    background:var(--citron); border:1.5px solid var(--ink); border-radius:999px;
    padding:8px 17px; font-family:var(--display); font-weight:700; font-size:15.5px;
    width:max-content; box-shadow:2px 2px 0 var(--ink); margin-top:6px;
  }
  .dish-grid{ display:grid; gap:22px; }
  .dish{
    border:2px solid var(--ink); border-radius:18px; overflow:hidden;
    background:#fff; box-shadow:5px 5px 0 rgba(39,25,14,.15);
    display:grid;
  }
  .dish-media{ position:relative; aspect-ratio:16/10; background:var(--cream-deep); }
  .dish-media img{ width:100%; height:100%; object-fit:cover; }
  .dish-media .duo{
    display:grid; grid-template-columns:1fr 1fr; height:100%;
  }
  .dish-media .duo img{ height:100%; }
  .dish-media .duo img + img{ border-left:2px solid var(--ink); }
  .placeholder{
    width:100%; height:100%;
    display:flex; flex-direction:column; align-items:center; justify-content:center; gap:8px;
    background:repeating-linear-gradient(-45deg, var(--cream-deep) 0 14px, #EDDFC2 14px 28px);
    color:#8A7456; font-weight:700; font-size:14px; letter-spacing:.06em;
    text-transform:uppercase; text-align:center; padding:16px;
  }
  .placeholder .frame{
    width:34px; height:26px; border:2px dashed #8A7456; border-radius:6px;
  }
  .dish-tag{
    position:absolute; top:13px; left:13px;
    background:var(--harissa); color:var(--cream);
    border:1.5px solid var(--ink); border-radius:999px;
    font-family:var(--display); font-weight:700; font-size:12.5px;
    letter-spacing:.08em; text-transform:uppercase; padding:5px 12px;
  }
  .dish-body{ padding:22px 22px 26px; }
  .dish-body h3{
    font-family:var(--display); font-weight:800; font-size:26px; line-height:1.1;
  }
  .dish-body p{ margin-top:9px; font-size:15.5px; color:#4A3A29; text-wrap:pretty; }
  .carte-note{
    margin-top:30px; font-size:14.5px; color:#7A6A57; font-style:italic;
    text-align:center; text-wrap:balance;
  }

  /* ---------- avis ---------- */
  .avis{ background:var(--harissa); color:var(--cream); padding:72px 0 80px; border-block:2px solid var(--ink); }
  .avis .kicker{ color:var(--citron); }
  .avis-grid{ display:grid; gap:44px; }
  .big-note{ display:flex; align-items:baseline; gap:14px; margin-top:10px; }
  .big-note .note{
    font-family:var(--display); font-weight:800;
    font-size:clamp(84px,18vw,130px); line-height:.9; letter-spacing:-.03em;
  }
  .big-note .meta{ display:grid; gap:4px; }
  .big-note .meta .stars{ color:var(--citron); font-size:22px; letter-spacing:3px; }
  .big-note .meta span{ font-weight:600; font-size:15.5px; color:#F4D9C9; }
  .g-badge{
    display:inline-flex; align-items:center; gap:8px; margin-top:18px;
    background:#fff; color:var(--ink); border:1.5px solid var(--ink);
    border-radius:999px; padding:7px 15px; font-weight:700; font-size:13.5px;
    box-shadow:2px 2px 0 var(--ink); width:max-content;
  }
  .g-badge .g{
    font-family:var(--display); font-weight:800; font-size:15px;
    color:#4285F4;
  }
  .word-cloud{ display:flex; flex-wrap:wrap; gap:10px; margin:26px 0 8px; }
  .word-cloud span{
    font-family:var(--display); font-weight:700;
    border:1.5px solid var(--cream); border-radius:999px; padding:8px 18px;
    font-size:16px;
  }
  .word-cloud span.hot{ background:var(--saffron); color:var(--ink); border-color:var(--ink); box-shadow:2px 2px 0 var(--ink); }
  .word-cloud-cap{ font-size:13.5px; color:#F4D9C9; font-weight:600; }
  .quotes{ display:grid; gap:14px; }
  .quote{
    background:color-mix(in oklab, var(--harissa-deep) 70%, transparent);
    border:1.5px solid #E08A6A; border-radius:16px; padding:22px;
  }
  .quote p{
    font-family:var(--display); font-weight:600; font-size:18.5px;
    line-height:1.35; text-wrap:pretty;
  }
  .quote p .hl{ color:var(--citron); }
  .quote small{
    display:block; margin-top:12px; font-weight:600; font-size:13px;
    color:#F4D9C9; letter-spacing:.04em;
  }

  /* ---------- infos ---------- */
  .infos{ padding:72px 0 80px; }
  .infos .kicker{ color:var(--olive); }
  .infos-grid{ display:grid; gap:16px; margin-top:36px; }
  .info-card{
    border:2px solid var(--ink); border-radius:18px; background:#fff;
    padding:24px 22px; box-shadow:5px 5px 0 rgba(39,25,14,.12);
  }
  .info-card h3{
    font-family:var(--display); font-weight:800; font-size:14px;
    letter-spacing:.16em; text-transform:uppercase; color:var(--harissa);
    margin-bottom:13px;
  }
  .info-card .big{
    font-family:var(--display); font-weight:700; font-size:23px; line-height:1.2;
  }
  .info-card p{ font-size:15.5px; color:#4A3A29; margin-top:7px; text-wrap:pretty; }
  .info-card a.tel{
    font-family:var(--display); font-weight:800; font-size:27px;
    text-decoration:none; color:var(--ink); letter-spacing:.01em;
    display:inline-block; border-bottom:3px solid var(--saffron); line-height:1.25;
  }
  .info-card a.tel:hover{ border-color:var(--harissa); color:var(--harissa); }
  .open-now{
    display:inline-flex; align-items:center; gap:9px;
    background:#E8F0D8; border:1.5px solid var(--olive); border-radius:999px;
    color:var(--olive-deep); font-weight:700; font-size:14.5px; padding:7px 15px;
    margin-bottom:13px;
  }
  .open-now .pulse{
    width:9px; height:9px; border-radius:50%; background:#5F8A1E; flex:none;
    box-shadow:0 0 0 3px rgba(95,138,30,.25);
  }
  .services{ display:grid; gap:10px; margin-top:4px; }
  .services li{
    list-style:none; display:flex; align-items:center; gap:11px;
    font-weight:600; font-size:16px;
  }
  .services .check{
    width:22px; height:22px; flex:none; border-radius:50%;
    background:var(--saffron); border:1.5px solid var(--ink);
    display:inline-flex; align-items:center; justify-content:center;
    font-size:12px; font-weight:800;
  }
  .map-card{ padding:0; overflow:hidden; display:grid; }
  .map-ph{
    aspect-ratio:16/10; position:relative;
    background:
      repeating-linear-gradient(0deg, transparent 0 39px, rgba(39,25,14,.09) 39px 40px),
      repeating-linear-gradient(90deg, transparent 0 39px, rgba(39,25,14,.09) 39px 40px),
      #EFE3CB;
    display:flex; align-items:center; justify-content:center;
  }
  .map-pin{
    background:#fff; border:1.5px solid var(--ink); border-radius:12px;
    padding:13px 18px; text-align:center; box-shadow:3px 3px 0 var(--ink);
    transform:rotate(-1deg); max-width:78%;
  }
  .map-pin .pin-dot{
    display:block; width:14px; height:14px; border-radius:50% 50% 50% 0; background:var(--harissa);
    border:1.5px solid var(--ink); transform:rotate(-45deg); margin:0 auto 8px;
  }
  .map-pin b{ font-family:var(--display); font-size:15.5px; display:block; }
  .map-pin small{ color:#7A6A57; font-weight:600; font-size:12.5px; }
  .map-body{ padding:20px 22px 24px; display:grid; gap:14px; }
  .map-body .addr{ font-family:var(--display); font-weight:700; font-size:20px; line-height:1.25; }
  .map-body .addr small{ display:block; font-family:var(--body); font-weight:600; font-size:14px; color:#7A6A57; margin-top:3px; }

  /* ---------- footer ---------- */
  footer{
    background:var(--ink); color:#CBB9A4; padding:44px 0 40px;
  }
  .footer-in{ display:grid; gap:22px; }
  .footer-brand{
    font-family:var(--display); font-weight:800; font-size:22px; color:var(--cream);
  }
  .footer-brand small{
    display:block; font-family:var(--body); font-weight:600; font-size:11px;
    letter-spacing:.16em; text-transform:uppercase; color:var(--saffron); margin-top:4px;
  }
  .footer-meta{ display:grid; gap:6px; font-size:14.5px; }
  .footer-meta a{ color:var(--cream); text-decoration:none; font-weight:600; }
  .footer-meta a:hover{ color:var(--saffron); }
  .footer-note{
    border-top:1px solid #4A3A29; padding-top:18px; font-size:12.5px; color:#8A7456;
    display:flex; flex-wrap:wrap; gap:6px 20px; justify-content:space-between;
  }

  /* ---------- desktop ---------- */
  @media (min-width: 760px){
    .header-nav{ display:flex; }
    .hero{ padding:64px 0 80px; }
    .hero-grid{ grid-template-columns:1.05fr .95fr; align-items:center; gap:56px; }
    .hero-photos{ min-height:520px; }
    .concept-grid{ grid-template-columns:repeat(3,1fr); gap:18px; }
    .concept-photos{ grid-template-columns:repeat(3,1fr); }
    .concept-photos figure:nth-child(2){ transform:translateY(20px); }
    .dish-grid{ grid-template-columns:repeat(3,1fr); }
    .avis-grid{ grid-template-columns:1fr 1.1fr; gap:64px; align-items:start; }
    .infos-grid{ grid-template-columns:repeat(3,1fr); align-items:start; }
    .map-card{ grid-column:1 / -1; grid-template-columns:1.2fr 1fr; }
    .map-ph{ aspect-ratio:auto; min-height:260px; }
    .map-body{ align-content:center; }
    .footer-in{ grid-template-columns:1fr auto; align-items:start; }
    .footer-note{ grid-column:1 / -1; }
  }

/* ---------- ajouts production (INFERA) ---------- */
/* vraie carte Google Maps dans la map-card */
.map-embed{ position:relative; min-height:240px; }
.map-embed iframe{
  position:absolute; inset:0; width:100%; height:100%; border:0; display:block;
}
@media (min-width: 760px){
  .map-embed{ min-height:260px; }
}

/* tuile « couscous sans photo » — assume l'absence avec le sourire */
.dish-media .teaser{
  width:100%; height:100%;
  display:flex; flex-direction:column; align-items:center; justify-content:center; gap:10px;
  background:var(--saffron);
  text-align:center; padding:18px;
}
.dish-media .teaser .star{
  font-size:30px; color:var(--harissa); line-height:1;
}
.dish-media .teaser p{
  font-family:var(--display); font-weight:800;
  font-size:clamp(19px, 2.2vw, 23px); line-height:1.15;
  color:var(--ink); letter-spacing:-.01em;
}
