/* ============================================================
   traiteur.css — Styles exclusifs à traiteur-casher-cannes
   Requiert bekef.css chargé avant ce fichier.
   Toutes les règles communes (nav, hero, split, btn, footer…)
   sont dans bekef.css — aucune duplication ici.
   ============================================================ */

/* ── Menu card ── */
.menu-card {
    background: var(--bg-3);
    border: 1px solid var(--line);
    border-radius: 5px;
    overflow: hidden;
    display: grid;
    grid-template-columns: 1.15fr 1fr;
  }
  .menu-body {
    padding: 46px 48px;
  }
  .menu-body h3 {
    font-size: 34px;
    margin: 14px 0 26px;
  }
  .menu-list {
    list-style: none;
    display: flex;
    flex-direction: column;
  }
  .menu-list li {
    display: flex;
    justify-content: space-between;
    gap: 18px;
    align-items: baseline;
    padding: 13px 0;
    border-bottom: 1px dashed var(--line-soft);
  }
  .menu-list li:last-child { border-bottom: 0; }
  .menu-list .nm {
    font-size: 16px;
    color: var(--text);
  }
  .menu-list .nm small {
    display: block;
    font-size: 12.5px;
    color: var(--text-faint);
    font-weight: 300;
    margin-top: 2px;
  }
  .menu-list .pr {
    font-family: var(--serif);
    font-size: 21px;
    color: var(--gold);
    white-space: nowrap;
  }
  .menu-foot {
    margin-top: 30px;
    display: flex;
    align-items: center;
    gap: 18px;
    flex-wrap: wrap;
  }
  .menu-note {
    font-size: 12.5px;
    color: var(--text-faint);
    display: flex;
    align-items: center;
    gap: 8px;
  }
  .menu-visual { position: relative; }
  .menu-visual .ph { position: absolute; inset: 0; }
  
  /* ── Dish grid ── */
  .dish-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 24px;
  }
  .dish {
    background: var(--bg-3);
    border: 1px solid var(--line-soft);
    border-radius: 5px;
    overflow: hidden;
    transition: .25s;
  }
  .dish:hover {
    border-color: var(--line);
    transform: translateY(-4px);
  }
  .dish .img {
    aspect-ratio: 3/2;
    position: relative;
  }
  .dish .img .ph {
    position: absolute;
    inset: 0;
    border: 0;
    border-bottom: 1px solid var(--line-soft);
  }
  .dish .txt { padding: 24px 26px 28px; }
  .dish .txt h3 { font-size: 25px; margin-bottom: 8px; }
  .dish .txt p { font-size: 14px; color: var(--text-dim); font-weight: 300; }
  .dish .tag {
    font-size: 11px;
    letter-spacing: .16em;
    text-transform: uppercase;
    color: var(--gold);
    font-weight: 600;
    margin-bottom: 12px;
    display: block;
  }
  
  /* ── Events ── */
  .events {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 64px;
    align-items: center;
  }
  .ev-list {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 14px;
    margin: 34px 0 0;
  }
  .ev-list div {
    border-left: 2px solid var(--gold);
    padding: 4px 0 4px 16px;
    font-size: 15px;
    color: var(--text);
  }
  .ev-list div small {
    display: block;
    font-size: 12.5px;
    color: var(--text-faint);
    font-weight: 300;
  }
  .ev-visual {
    position: relative;
    aspect-ratio: 1/1;
    border-radius: 5px;
  }
  .ev-visual .ph {
    position: absolute;
    inset: 0;
    border-radius: 5px;
  }
  
  /* ── Order section ── */
  .order {
    display: grid;
    grid-template-columns: 1.1fr .9fr;
    gap: 64px;
  }
  .order h2 {
    font-size: clamp(32px, 4vw, 50px);
    margin: 18px 0 22px;
  }
  .order p {
    color: var(--text-dim);
    font-size: 16px;
    font-weight: 300;
    max-width: 440px;
  }
  .order-actions {
    display: flex;
    gap: 14px;
    margin-top: 34px;
    flex-wrap: wrap;
  }
  
  /* ============================================================
     RESPONSIVE 940px
     Seules les classes spécifiques à cette page —
     les classes communes (.hero-grid, .split, .foot-grid…)
     sont déjà gérées par bekef.css
     ============================================================ */
  @media (max-width: 940px) {
    .events,
    .order,
    .menu-card       { grid-template-columns: 1fr; }
    .dish-grid       { grid-template-columns: 1fr 1fr; }
    .menu-visual     { min-height: 240px; }
  }
  
  /* ============================================================
     RESPONSIVE 600px
     ============================================================ */
  @media (max-width: 600px) {
    .dish-grid,
    .ev-list         { grid-template-columns: 1fr; }
    .menu-body       { padding: 32px 26px; }
  }