/* ===== Theme ===== */
:root{
  --bg:#0f0d0c; --bg-soft:#171312; --card:#1b1614; --card-2:#221a17;
  --accent:#c08a5b; --accent-2:#ffe8c8; --text:#f5efe9; --muted:#bba89a;
  --shadow:0 12px 36px rgba(0,0,0,.42); --ring:0 0 0 3px color-mix(in oklab, var(--accent), transparent 72%);
  --r-lg:18px; --wrap:clamp(960px,86vw,1200px);
  --fs-xxl:clamp(2.2rem,3.6vw + 1rem,4rem); --fs-xl:clamp(1.6rem,1.6vw + .9rem,2.2rem);
  --fs-lg:clamp(1.05rem,.6vw + .8rem,1.25rem); --fs-md:clamp(.95rem,.3vw + .8rem,1rem); --fs-sm:clamp(.85rem,.2vw + .75rem,.95rem);
}
*,*::before,*::after{box-sizing:border-box}
html,body{height:100%}
body{
  margin:0; font-family:Poppins,system-ui,-apple-system,Segoe UI,Roboto;
  color:var(--text);
  background: radial-gradient(1100px 800px at 80% -10%, rgba(192,138,91,.10), transparent 60%), var(--bg);
  line-height:1.6; overflow-x:hidden; scroll-behavior:smooth;
  -webkit-font-smoothing:antialiased; -moz-osx-font-smoothing:grayscale;
}
html[dir="rtl"] body{font-family:Tajawal,Poppins,system-ui,-apple-system,Segoe UI,Roboto}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block;border-radius:12px}

/* Layout helpers */
.wrap{max-width:var(--wrap);margin-inline:auto}
section{padding:clamp(2rem,4vw,4rem) 1rem}
h2.sec-title{font-size:var(--fs-xl);margin:0 0 .9rem}
p.lead{color:var(--muted);max-width:60ch;font-size:var(--fs-md)}

/* ===== Nav ===== */
.nav{position:sticky;top:0;z-index:40;backdrop-filter:saturate(1.2) blur(8px);
  background:linear-gradient(180deg, rgba(15,13,12,.82), rgba(15,13,12,.38));
  border-bottom:1px solid rgba(255,255,255,.06);
}
.nav-inner{max-width:var(--wrap);margin-inline:auto;display:flex;align-items:center;justify-content:space-between;gap:.75rem;padding:.8rem 1rem}
.brand{display:inline-flex;align-items:center;gap:.75rem}
.brand-top{font-family:"Marcellus",serif;font-size:clamp(1.1rem,1.2vw + 1rem,1.6rem);letter-spacing:.18em;text-transform:uppercase;display:inline-block;background:linear-gradient(90deg,#f7e7d2,#caa57a 45%,#8e6a42 85%);-webkit-background-clip:text;background-clip:text;color:transparent;filter:drop-shadow(0 1px 0 rgba(0,0,0,.25))}
.brand-top .dot{margin:0 .35ch;color:color-mix(in oklab, var(--accent), #fff 20%)}
.nav-right{display:flex;gap:.6rem;align-items:center}

.pill{display:inline-flex;align-items:center;gap:.5rem;padding:.4rem .7rem;border-radius:999px;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.1);color:var(--text);cursor:pointer}
.pill-ico{font-size:1rem}
.pill-badge{display:inline-grid;place-items:center;min-width:1.3rem;height:1.3rem;padding:0 .25rem;border-radius:999px;background:var(--accent);color:#1a120e;font-weight:800}

.lang-switch{display:inline-flex;gap:.4rem;padding:.25rem;border-radius:999px;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.08)}
.lang-switch button{padding:.45rem .7rem;border:0;background:transparent;color:var(--text);border-radius:999px;cursor:pointer;opacity:.9}
.lang-switch button.active{background:var(--accent);color:#1a120e;font-weight:700;box-shadow:var(--ring)}

/* ===== Drawer & Backdrop (RIGHT) ===== */
#cart-backdrop{position:fixed;inset:0;z-index:45;background:rgba(0,0,0,.35);opacity:0;pointer-events:none;transition:opacity .2s ease}
#cart-backdrop.open{opacity:1;pointer-events:auto}

#cart-drawer{
  position:fixed; top:0; right:0; z-index:50; height:100dvh; width:min(420px, 94vw);
  background:var(--bg-soft); color:var(--text); border-left:1px solid rgba(255,255,255,.08);
  transform:translateX(100%); transition:transform .25s ease; display:grid; grid-template-rows:auto 1fr auto;
}
#cart-drawer.open{transform:translateX(0)}
#cart-drawer[hidden]{display:none}
body.is-cart-open{overflow:hidden}

.cart-head{display:flex;align-items:center;justify-content:space-between;padding:1rem;border-bottom:1px solid rgba(255,255,255,.08)}
.icon-btn{background:transparent;border:0;color:var(--text);font-size:1.5rem;cursor:pointer}
.cart-list{list-style:none;margin:0;padding:.5rem;display:grid;gap:.6rem;overflow:auto}
.cart-item{display:grid;grid-template-columns:52px 1fr auto;gap:.6rem;align-items:center;background:rgba(255,255,255,.03);border:1px solid rgba(255,255,255,.08);border-radius:12px;padding:.6rem}
.cart-item img{width:52px;height:52px;object-fit:cover;border-radius:10px}
.ci-name{font-weight:700}
.ci-meta{font-size:.9rem;color:var(--muted)}
.ci-actions{display:flex;align-items:center;gap:.5rem}
.qty{display:inline-grid;grid-auto-flow:column;grid-auto-columns:28px min-content 28px;align-items:center;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.12);border-radius:999px}
.qty button{background:transparent;border:0;color:var(--text);cursor:pointer;height:28px}
.qty span{padding:0 .5rem;font-weight:700}
.remove{background:transparent;border:0;color:#fff8;cursor:pointer;font-size:1rem}
.cart-foot{padding:1rem;border-top:1px solid rgba(255,255,255,.08);background:rgba(255,255,255,.02)}
.tot-row{display:flex;align-items:center;justify-content:space-between;margin:.25rem 0}
.cart-actions{display:grid;grid-template-columns:1fr 1.2fr;gap:.6rem;margin-top:.6rem}

/* Buttons */
.btn{border:1px solid rgba(255,255,255,.1);background:linear-gradient(180deg, rgba(255,255,255,.08), rgba(255,255,255,.02));padding:.8rem 1.1rem;border-radius:12px;color:var(--text);cursor:pointer;transition:transform .2s ease, background .2s ease, box-shadow .2s ease}
.btn:hover{transform:translateY(-1px);background:rgba(255,255,255,.12);box-shadow:0 10px 26px rgba(0,0,0,.35)}
.btn.primary{background:linear-gradient(90deg,var(--accent),color-mix(in oklab, var(--accent-2), #fff 10%));color:#1a120e;border-color:transparent;font-weight:700;box-shadow:var(--ring);text-align:center;display:inline-grid;place-items:center}
.btn.ghost{background:transparent;border-color:rgba(255,255,255,.16)}

/* ===== Hero/Menu/Social (trimmed) ===== */
.hero{position:relative;isolation:isolate;overflow:clip;min-height:clamp(72vh,86vh,96vh);display:grid;place-items:center;background:
  radial-gradient(800px 500px at 10% -10%, rgba(255,232,200,.07), transparent 60%),
  url('https://images.unsplash.com/photo-1504754524776-8f4f37790ca0?q=80&w=1400&auto=format&fit=crop') center/cover no-repeat;}
.hero::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg, rgba(15,13,12,.55), rgba(15,13,12,.86));z-index:-1}
.hero-content{text-align:center;padding:3rem 1rem;max-width:min(900px,92vw)}
.kicker{letter-spacing:.25em;text-transform:uppercase;font-size:var(--fs-sm);color:var(--muted)}
h1.title{font-size:var(--fs-xxl);margin:.4rem 0 1rem;line-height:1.05}
.subtitle{font-size:var(--fs-lg);color:var(--muted);max-width:70ch;margin-inline:auto}
.cta-row{margin-top:1.4rem;display:flex;gap:.8rem;flex-wrap:wrap;justify-content:center}

.filter-row{display:flex;gap:.6rem;flex-wrap:wrap;margin:.9rem 0 1.1rem}
.chip{color:#fff;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.16);padding:.5rem .9rem;border-radius:999px;cursor:pointer;transition:.15s}
.chip[aria-pressed="true"]{background:var(--accent);border-color:transparent;color:#1a120e;box-shadow:var(--ring)}

.cards{display:grid;grid-template-columns:repeat(auto-fit, minmax(230px,1fr));gap:clamp(.8rem,1.6vw,1.2rem)}
.card{min-height:260px;background:linear-gradient(180deg, rgba(255,255,255,.03), rgba(255,255,255,.015));border:1px solid rgba(255,255,255,.08);border-radius:var(--r-lg);overflow:hidden;display:grid;grid-template-rows:300px 1fr;transition:transform .25s ease, box-shadow .25s ease, border-color .25s ease}
.card:hover{transform:translateY(-4px);box-shadow:0 14px 40px rgba(0,0,0,.45);border-color:rgba(255,255,255,.12)}
.card .media{position:relative;background:#222}
.card .media img{width:100%;height:100%;object-fit:cover}
.badge{position:absolute;top:.6rem;inset-inline:.6rem auto;background:rgba(0,0,0,.55);color:var(--accent-2);padding:.25rem .5rem;border-radius:999px;font-size:.8rem;border:1px solid rgba(255,255,255,.1)}
.card .body{padding:.9rem;display:grid;align-content:start;gap:.35rem}
.price{font-weight:800;color:var(--accent);letter-spacing:.5px}
.ing{font-size:.92rem;color:var(--muted)}
.actions{margin-top:.35rem}
.add-btn{width:100%;}

/* Order section */
.order{position:relative;border-radius:22px;padding-block:clamp(2rem,3vw,3rem);overflow:hidden}
.order::before{content:"";position:absolute;inset:0;z-index:-1;border-radius:inherit;background:
  radial-gradient(900px 420px at 25% 0%, rgba(192,138,91,.10), transparent 60%),
  radial-gradient(900px 420px at 75% 0%, rgba(255,232,200,.07), transparent 65%),
  linear-gradient(180deg, rgba(255,255,255,.02), rgba(255,255,255,.00))}
.socials{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:clamp(.9rem,1.8vw,1.2rem);margin-top:1rem}
.social{--btn-bg:var(--card-2);display:grid;grid-auto-flow:column;grid-auto-columns:max-content 1fr;align-items:center;gap:.95rem;padding:1.05rem 1.15rem;border-radius:20px;background:var(--btn-bg);border:1px solid rgba(255,255,255,.09);box-shadow:var(--shadow)}
.social__icon{width:44px;height:44px;border-radius:12px;display:grid;place-items:center;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.1)}
.social__label{font-weight:700;letter-spacing:.3px}
/* Give WhatsApp a subtle green accent */
.social--wa .social__icon{background:#25D36622;border-color:#25D36644}

/* Floating Cart FAB (light, fixed bottom-right in all languages) */
.fab{
  position: fixed;
  right: 16px !important;
  left: auto !important;
  bottom: max(20px, env(safe-area-inset-bottom));
  z-index: 60;
  width: 58px; height: 58px;
  border-radius: 50%;
  background: var(--accent-2);            /* light cream */
  color: #1a120e;                          /* dark text/icon */
  border: 1px solid var(--accent);         /* subtle outline */
  display: inline-flex; align-items: center; justify-content: center;
  box-shadow: 0 12px 30px rgba(0,0,0,.28);
  transition: transform .15s ease, box-shadow .15s ease, background .15s ease;
}
.fab:hover{ transform: translateY(-1px); box-shadow: 0 16px 36px rgba(0,0,0,.34); }

.fab-badge{
  position: absolute; top: -6px; right: -6px;
  min-width: 20px; height: 20px; padding: 0 6px;
  border-radius: 999px; background: #e11d48; color: #fff;
  font-size: .75rem; display: flex; align-items: center; justify-content: center;
  border: 2px solid #fff;
}

/* Do NOT mirror in RTL: keep it bottom-right always */
html[dir="rtl"] .fab{ right: 16px !important; left: auto !important; }

/* Footer */
footer{padding:1.6rem 1rem;margin-top:.4rem;color:var(--muted);text-align:center;border-top:1px solid rgba(255,255,255,.06);background:var(--bg-soft);font-size:var(--fs-sm)}

/* Reveal */
.reveal{opacity:0;transform:translateY(16px);filter:blur(6px);transition:opacity .6s ease, transform .6s ease, filter .6s ease}
.reveal.in{opacity:1;transform:none;filter:none}

/* Responsive tweaks */
@media (max-width:600px){
  .nav-inner{padding:.6rem .8rem}
  .hero-content{padding:2.1rem 1rem}
  #cart-drawer{width:100vw}
  .cart-actions{grid-template-columns:1fr}
}

/* ===== Order & Connect — brandy social cards ===== */

/* Brand colors */
:root{
  --wa:#25D366;
  --ig1:#F58529; --ig2:#DD2A7B; --ig3:#8134AF; --ig4:#515BD4;
  --tt-cyan:#69C9D0; --tt-pink:#EE1D52;
}

.socials--cta .social{
  position: relative;
  overflow: hidden;
  transition: transform .18s ease, box-shadow .18s ease, border-color .18s ease, background .18s ease;
}
.socials--cta .social:hover{ transform: translateY(-2px); }

/* Common: icon styling + focus ring */
.socials--cta .social .social__icon svg{ display:block }
.socials--cta .social:focus-visible{
  outline: none;
  box-shadow: 0 0 0 3px color-mix(in oklab, #fff, transparent 75%), 0 0 0 6px color-mix(in oklab, var(--accent), transparent 70%);
}

/* WhatsApp */
.social--wa .social__icon{
  color: var(--wa);
  background: color-mix(in oklab, var(--wa), transparent 85%);
  border-color: color-mix(in oklab, var(--wa), transparent 70%);
}
.social--wa:hover{
  border-color: color-mix(in oklab, var(--wa), transparent 40%);
  background:
    linear-gradient(180deg, color-mix(in oklab, var(--wa), transparent 92%), transparent 60%),
    var(--card-2);
  box-shadow: 0 14px 36px color-mix(in oklab, var(--wa), transparent 70%);
}

/* Instagram */
.social--ig .social__icon{
  background: linear-gradient(135deg, var(--ig4), var(--ig3) 35%, var(--ig2) 70%, var(--ig1));
  border-color: color-mix(in oklab, var(--ig2), #fff 35%);
  color:#fff;
}
.social--ig:hover{
  border-color: color-mix(in oklab, var(--ig2), transparent 30%);
  background:
    linear-gradient(135deg,
      color-mix(in oklab, var(--ig4), transparent 90%),
      color-mix(in oklab, var(--ig3), transparent 92%) 35%,
      color-mix(in oklab, var(--ig2), transparent 92%) 70%,
      color-mix(in oklab, var(--ig1), transparent 92%)
    ),
    var(--card-2);
  box-shadow:
    0 12px 34px color-mix(in oklab, var(--ig2), transparent 75%),
    0 2px 0 rgba(0,0,0,.12) inset;
}

/* TikTok */
.social--tt .social__icon{
  background:
    radial-gradient(120% 120% at 30% 30%, color-mix(in oklab, var(--tt-cyan), transparent 70%), transparent 60%),
    radial-gradient(110% 110% at 70% 70%, color-mix(in oklab, var(--tt-pink), transparent 72%), transparent 52%);
  border-color: color-mix(in oklab, var(--tt-pink), transparent 45%);
  color:#fff;
}
.social--tt:hover{
  border-color: color-mix(in oklab, var(--tt-cyan), transparent 40%);
  background:
    radial-gradient(160% 140% at 20% 20%, color-mix(in oklab, var(--tt-cyan), transparent 88%), transparent 60%),
    radial-gradient(140% 120% at 80% 80%, color-mix(in oklab, var(--tt-pink), transparent 88%), transparent 50%),
    var(--card-2);
  box-shadow:
    0 14px 36px color-mix(in oklab, var(--tt-pink), transparent 74%),
    0 10px 26px color-mix(in oklab, var(--tt-cyan), transparent 78%);
}

/* Gentle inner shine on hover (all) */
.socials--cta .social::after{
  content:"";
  position:absolute; inset:0;
  background: radial-gradient(120% 80% at 20% 0%, rgba(255,255,255,.06), transparent 55%);
  opacity:0; transition:opacity .18s ease;
  pointer-events:none;
}
.socials--cta .social:hover::after{ opacity:.9; }

/* ----- Order & Connect: info cards ----- */
.order .order-info{
  display:grid;
  grid-template-columns: repeat(2, minmax(0,1fr));
  gap:16px;
  margin-top:20px;
}
@media (max-width:720px){
  .order .order-info{ grid-template-columns: 1fr; }
}

.order .order-info__card{
  background: rgba(255,255,255,0.06);
  border: 1px solid rgba(255,255,255,0.12);
  border-radius: 16px;
  padding: 16px 14px;
  backdrop-filter: blur(4px);
}

.order .order-info__title{
  margin:0 0 6px 0;
  font-weight: 700;
  letter-spacing: .2px;
}

.order .order-info__text{ margin:0 0 8px 0; opacity:.95; }
.order .order-info__link{
  display:inline-block;
  margin-top:2px;
  text-decoration: underline;
}

.order .order-info__badges{ display:flex; gap:8px; flex-wrap:wrap; }
.pill--soft{
  background: rgba(255,255,255,0.08);
  border: 1px solid rgba(255,255,255,0.14);
}
.order .order-info__note{ margin:.5rem 0 0 0; opacity:.8; font-size:.95rem; }

/* ============= Order & Connect ============= */
#order{
  position: relative;           /* anchor for chef badge */
  overflow: visible;            /* ensure badge isn't clipped */
}

/* --- Info cards grid --- */
.order .order-info{
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 16px;
  margin-top: 20px;
}

/* Flip layout & text flow automatically in RTL */
[dir="rtl"] .order .order-info{
  direction: rtl;               /* text & grid start become right */
}

.order .order-info__card{
  direction: inherit;           /* follow parent dir (LTR/RTL) */
  background: rgba(255,255,255,0.06);
  border: 1px solid rgba(255,255,255,0.12);
  border-radius: 16px;
  padding: 16px 14px;
  backdrop-filter: blur(4px);
}

.order .order-info__title{
  margin: 0 0 6px 0;
  font-weight: 800;
  letter-spacing: .2px;
}

.order .order-info__text{
  margin: 0 0 8px 0;
  opacity: .95;
}

.order .order-info__link{
  display: inline-block;
  margin-top: 2px;
  text-decoration: underline;
}

/* Payment pills */
.order .order-info__badges{
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
  justify-content: flex-start;  /* start = right in RTL, left in LTR */
}

.pill--soft{
  background: rgba(255,255,255,0.08);
  border: 1px solid rgba(255,255,255,0.14);
  border-radius: 999px;
  padding: 8px 14px;
  line-height: 1;
}

.order .order-info__note{
  margin: .6rem 0 0 0;
  opacity: .8;
  font-size: .95rem;
}

/* --- Socials row under the cards --- */
.order .socials--cta{
  margin-top: 18px;
}

/* --- Chef photo badge (logical positioning) --- */
/* Default: top-end (right in LTR) */
/* --- Anchor --- */
#order { position: relative; }

/* --- Default (LTR): top-right --- */
.chef-badge{
  position: absolute;
  top: 14px;
  right: 14px;     /* LTR corner */
  width: 130px;
  height: 130px;
  object-fit: cover;
  border-radius: 50%;
  border: 2px solid rgba(255,255,255,.85);
  box-shadow: 0 6px 20px rgba(0,0,0,.35);
  transform: rotate(-2deg);
  z-index: 3;
  pointer-events: none;
}

/* --- RTL override: move to top-left --- */
[dir="rtl"] .chef-badge{
  right: auto;     /* unset LTR side */
  left: 14px;      /* RTL corner */
  transform: rotate(2deg);
}

/* --- Mobile tweak --- */
@media (max-width: 720px){
  .chef-badge{
    top: 10px;
    width: 78px;
    height: 78px;
  }
  [dir="rtl"] .chef-badge{
    left: 10px;
  }
}


/* Make all grid cells equal height (nice-to-have) */
.cards { align-items: stretch; }

/* Let the body stack and grow, then pin actions to the bottom */
.card .body{
  display: flex;               /* was: display:grid */
  flex-direction: column;
  align-content: initial;      /* neutralize previous grid setting */
  gap: .35rem;
  padding: .9rem;
  min-height: 0;               /* prevents overflow issues */
  flex: 1 1 auto;              /* ensures the body takes remaining space */
}

/* Actions row pinned to the bottom of the body */
.card .actions{
  margin-top: auto;            /* 👈 pushes this block to the bottom */
  padding-top: .6rem;          /* small spacing from price/desc */
}

/* Button styling stays the same */
.add-btn{ width:100%; }

/* Body = flex column (from previous fix) */
.card .body{
  display: flex;
  flex-direction: column;
  gap: .35rem;
  padding: .9rem;
  min-height: 0;
  flex: 1 1 auto;
}

/* Pin the PRICE to the bottom area, just above the button */
.card .price{
  margin-top: auto;      /* 👈 pushes price to the bottom */
  padding-top: .4rem;    /* small separation from text */
}

/* Keep the button right under the price, aligned across cards */
.card .actions{
  margin-top: .5rem;     /* distance between price and button */
}

/* Button styling (unchanged) */
.add-btn{ width:100%; }

/* ====== Gallery: fixed 3x2 grid (scoped) ====== */
#gallery { position: relative; }

/* Exactly 3 columns, wraps to 2 rows for 6 items */
#gallery .gallery{
  display: grid;
  grid-template-columns: repeat(3, 1fr);  /* always 3 per row */
  gap: 12px;                               /* card spacing */
  margin-top: .6rem;
}

/* Framed tiles */
#gallery .g-item{
  position: relative;
  display: block;
  padding: 10px;                           /* inner frame padding */
  border-radius: 16px;
  background: rgba(255,255,255,.04);
  border: 1px solid rgba(255,255,255,.10);
  overflow: hidden;
  transition: transform .2s ease, box-shadow .2s ease, border-color .2s ease, background .2s ease;
}

/* Visual height via aspect ratio (4:3 looks good for shop photos) */
#gallery .g-item::before{
  content:"";
  display:block;
  aspect-ratio: 4 / 3;                     /* frame ratio */
}

/* Show the full photo inside the frame (no crop) */
#gallery .g-item img{
  position: absolute;
  inset: 10px;                              /* same as padding */
  margin: auto;
  max-width: calc(100% - 20px);
  max-height: calc(100% - 20px);
  width: auto; height: auto;
  object-fit: contain;                      /* full image visible */
  border-radius: 12px;
  display: block;
  box-shadow: 0 6px 18px rgba(0,0,0,.18);
}

/* Hover polish */
#gallery .g-item:hover{
  transform: translateY(-2px);
  background: rgba(255,255,255,.06);
  border-color: rgba(255,255,255,.16);
  box-shadow: 0 14px 32px rgba(0,0,0,.28);
}

/* (Optional) If fewer than 6 images, keep slots visually balanced
   by centering the last row’s items. Comment out if not needed. */
#gallery .gallery{
  justify-items: stretch;                   /* full-width tiles */
}

@media (max-width: 600px){
  html[dir="rtl"] .order .order-info__badges{
    display: flex !important;
    flex-direction: column !important;  /* stack vertically */
    flex-wrap: nowrap !important;       /* no side-by-side */
    align-items: flex-start;
    gap: 10px;
  }

  /* make each pill a block (so it can't share a line) */
  html[dir="rtl"] .order .order-info__badges .pill,
  html[dir="rtl"] .order .order-info__badges .pill--soft{
    display: block !important;
    width: fit-content;                  /* use 100% if you want full-width buttons */
  }
}

/* Extra gap between "Our Place" (#gallery) and "Order & Connect" (#order) */
#gallery + #order{
  margin-top: clamp(24px, 4vw, 60px);
}

@media (max-width:720px){
  #gallery + #order{ margin-top: 40px; }
}

@media (min-width: 1024px){
  /* Keep gallery lead on one line (desktop only) */
  #gallery .lead{
    max-width: 100% !important;   /* override the 60ch cap */
    white-space: nowrap;          /* no wrapping */
    overflow: hidden;             /* hide overflow */
    text-overflow: ellipsis;      /* … if it doesn’t fit */
    hyphens: none;
  }
}